.vl-login{background:var(--bg-base);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.vl-login__card{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-card);flex-direction:column;align-items:center;gap:6px;padding:40px 32px;display:flex}.vl-login__logo{background:var(--accent-blue);color:#fff;border-radius:14px;place-items:center;width:48px;height:48px;margin-bottom:4px;font-size:18px;font-weight:700;display:grid}.vl-login__title{color:var(--text-primary);margin:0;font-size:24px;font-weight:700}.vl-login__sub{color:var(--text-secondary);margin:0 0 20px;font-size:13px}.vl-login__form{flex-direction:column;gap:14px;width:100%;display:flex}.vl-login__field{flex-direction:column;gap:6px;display:flex}.vl-login__field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.vl-login__field input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:15px;font-family:var(--font-ui);outline:none;padding:12px 14px;transition:border-color .2s}.vl-login__field input:focus{border-color:var(--accent-blue);background:#fff}.vl-login__error{color:var(--accent-red);text-align:center;background:var(--accent-red-light);border-radius:var(--radius-sm);margin:0;padding:8px 12px;font-size:13px}.vl-login__btn{background:var(--accent-blue);color:#fff;cursor:pointer;letter-spacing:.06em;font-size:15px;font-weight:600;font-family:var(--font-ui);border:none;border-radius:30px;margin-top:6px;padding:13px;transition:opacity .2s}.vl-login__btn:hover:not(:disabled){opacity:.85}.vl-login__btn:disabled{opacity:.5;cursor:default}.vl-bottom-nav{width:100%;max-width:480px;height:var(--nav-h);background:var(--bg-card);border-top:1px solid var(--border);z-index:100;align-items:stretch;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.vl-bottom-nav__item{color:var(--text-muted);-webkit-tap-highlight-color:transparent;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 2px;text-decoration:none;transition:color .15s;display:flex}.vl-bottom-nav__item--active{color:var(--accent-blue)}.vl-bottom-nav__icon{justify-content:center;align-items:center;width:22px;height:22px;display:flex}.vl-bottom-nav__icon svg{width:22px;height:22px}.vl-bottom-nav__label{letter-spacing:.03em;font-size:9px;font-weight:500;line-height:1}.vl-dashboard{background:var(--bg-base);flex-direction:column;min-height:100dvh;display:flex}.vl-dashboard__body{padding:12px var(--gap) calc(var(--nav-h) + 16px);flex-direction:column;flex:1;gap:12px;display:flex}.vl-skeleton{background:#e5e7eb;animation:1.4s ease-in-out infinite vl-pulse}@keyframes vl-pulse{0%,to{opacity:1}50%{opacity:.5}}.vl-error{background:var(--accent-red-light);border-radius:var(--radius-sm);color:var(--accent-red);border:1px solid #fca5a5;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;display:flex}.vl-error button{background:var(--accent-red);color:#fff;cursor:pointer;font-size:12px;font-family:var(--font-ui);border:none;border-radius:6px;padding:4px 12px}.vl-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:12px var(--gap);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.vl-header__brand{align-items:center;gap:6px;display:flex}.vl-header__bolt{flex-shrink:0;width:20px;height:20px}.vl-header__title{font-family:var(--font-ui);color:var(--text-primary);font-size:17px;font-weight:700}.vl-header__date{color:var(--text-secondary);text-align:center;flex:1;padding:0 8px;font-size:12px}.vl-header__avatar{cursor:pointer;background:0 0;border:none;padding:0}.vl-header__initials{background:var(--accent-blue);color:#fff;width:34px;height:34px;font-size:13px;font-weight:600;font-family:var(--font-ui);border-radius:50%;place-items:center;display:grid}.vl-counter-row{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.vl-counter{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);flex-direction:column;gap:3px;min-width:0;padding:12px 10px;display:flex}.vl-counter__label{color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;font-size:9px;font-weight:600;overflow:hidden}.vl-counter__value{font-family:var(--font-mono);color:var(--accent-blue);font-size:1.5rem;font-weight:600;line-height:1.1}.vl-counter__value--over{color:var(--accent-red)}.vl-counter__unit{font-size:.9rem;font-weight:400}.vl-counter__norm{color:var(--text-secondary);font-size:10px}.vl-counter__track{background:var(--bg-base);border-radius:2px;height:4px;margin-top:6px;overflow:hidden}.vl-counter__fill{border-radius:2px;height:100%;transition:width .6s}.vl-timer-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:20px}.vl-timer-card__idle,.vl-timer-card__running{flex-direction:column;align-items:center;gap:12px;display:flex}.vl-timer-card__clock{width:40px;height:40px}.vl-timer-card__idle-label{color:var(--text-secondary);font-size:14px}.vl-timer-card__project{color:var(--text-primary);font-size:14px;font-weight:600}.vl-timer-card__time-row{align-items:center;gap:10px;display:flex}.vl-timer-card__dot{background:var(--accent-green);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:1.4s ease-in-out infinite vl-dot-pulse}@keyframes vl-dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.vl-timer-card__elapsed{font-family:var(--font-mono);color:var(--accent-green);letter-spacing:.02em;font-size:2.5rem;font-weight:600}.vl-timer-card__btn{width:100%;font-family:var(--font-ui);letter-spacing:.08em;cursor:pointer;border:none;border-radius:30px;padding:12px;font-size:14px;font-weight:600;transition:opacity .2s}.vl-timer-card__btn:hover{opacity:.85}.vl-timer-card__btn--start{background:var(--accent-green);color:#fff}.vl-timer-card__btn--stop{background:var(--accent-red);color:#fff}.vl-mode{background:var(--bg-card);box-shadow:var(--shadow-card);border-radius:30px;gap:8px;padding:4px;display:flex}.vl-mode__btn{font-family:var(--font-ui);color:var(--text-secondary);background:var(--bg-base);cursor:pointer;border:none;border-radius:24px;flex:1;padding:9px 0;font-size:14px;font-weight:500;transition:background .2s,color .2s}.vl-mode__btn--work{background:var(--accent-blue);color:#fff}.vl-mode__btn--side{background:var(--accent-yellow);color:#fff}.vl-entries-card{background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow:hidden}.vl-entries-card__title{color:var(--text-primary);border-bottom:1px solid var(--border);padding:14px 16px 10px;font-size:14px;font-weight:600}.vl-entries-card__empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:8px;padding:28px 16px;font-size:13px;display:flex}.vl-entries-card__empty svg{width:32px;height:32px}.vl-entry{justify-content:space-between;align-items:flex-start;gap:8px;padding:12px 16px;display:flex}.vl-entry__left{flex:1;align-items:flex-start;gap:10px;min-width:0;display:flex}.vl-entry__dot{background:var(--accent-blue);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:4px}.vl-entry__dot--side{background:var(--accent-yellow)}.vl-entry__info{flex-direction:column;gap:2px;min-width:0;display:flex}.vl-entry__project{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.vl-entry__time{color:var(--text-secondary);font-size:11px;font-family:var(--font-mono)}.vl-entry__right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.vl-entry__dur{color:var(--text-primary);font-size:13px;font-weight:600}.vl-entry__addr{color:var(--text-muted);text-align:right;font-size:10px}:root{--bg-base:#f0f2f5;--bg-surface:#fff;--bg-card:#fff;--border:#e2e6ea;--text-primary:#1a1f2e;--text-secondary:#6b7280;--text-muted:#9ca3af;--accent-blue:#2563eb;--accent-blue-light:#dbeafe;--accent-green:#16a34a;--accent-green-light:#dcfce7;--accent-red:#dc2626;--accent-red-light:#fee2e2;--accent-yellow:#d97706;--accent-yellow-light:#fef3c7;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--shadow-card:0 1px 4px #00000014, 0 4px 16px #0000000f;--font-ui:"DM Sans", system-ui, sans-serif;--font-mono:"IBM Plex Mono", "Fira Mono", monospace;--nav-h:64px;--gap:16px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;min-height:100dvh}#root{max-width:480px;margin:0 auto}
