@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{color-scheme:light;--bg: #f2f7ff;--surface: #ffffff;--surface-alt: #eaf1ff;--ink: #12243f;--muted: #4d627f;--brand: #3b82f6;--brand-strong: #2563eb;--danger: #e07a7a;--danger-strong: #cf6666;--border: #d3deef;--shadow: 0 14px 36px rgba(18, 36, 63, .12);--bg-spot-a: #d8e7ff;--bg-spot-b: #f8dfc6;--auth-spot-a: rgba(176, 209, 255, .55);--auth-spot-b: rgba(251, 218, 185, .5);--auth-grad-a: #eef4ff;--auth-grad-b: #e3edff;--auth-card-bg: rgba(255, 255, 255, .64);--auth-card-border: rgba(255, 255, 255, .58);--auth-card-shadow: rgba(19, 47, 99, .18);--auth-card-inset: rgba(255, 255, 255, .62);--auth-field-bg: rgba(255, 255, 255, .72);--auth-field-border: rgba(122, 150, 199, .55);--soft-surface: #fbfcff;--tooltip-bg: #0f2623;--tooltip-ink: #ffffff;--ghost-bg: #ffffff;--ghost-hover-bg: #eef4ff;--ghost-ink: var(--ink);--input-bg: #ffffff;--input-border: #bfd0bc;--focus-ring: rgba(37, 99, 235, .35)}:root[data-theme=dark]{color-scheme:dark;--bg: #0c1323;--surface: #111b31;--surface-alt: #15213a;--ink: #e3ecff;--muted: #9bb0d6;--brand: #60a5fa;--brand-strong: #3b82f6;--danger: #d84f4f;--danger-strong: #bf3a3a;--border: #253453;--shadow: 0 14px 36px rgba(3, 7, 14, .45);--bg-spot-a: #1a2540;--bg-spot-b: #2a2235;--auth-spot-a: rgba(78, 128, 219, .34);--auth-spot-b: rgba(153, 103, 168, .28);--auth-grad-a: #0f1a31;--auth-grad-b: #101b34;--auth-card-bg: rgba(15, 26, 49, .75);--auth-card-border: rgba(64, 89, 143, .48);--auth-card-shadow: rgba(2, 5, 12, .55);--auth-card-inset: rgba(129, 164, 234, .12);--auth-field-bg: rgba(12, 23, 44, .92);--auth-field-border: rgba(60, 86, 140, .75);--soft-surface: #16233c;--tooltip-bg: #f0f4ff;--tooltip-ink: #142747;--ghost-bg: #182644;--ghost-hover-bg: #223458;--ghost-ink: #e3ecff;--input-bg: #111b31;--input-border: #2a3e66;--focus-ring: rgba(96, 165, 250, .4)}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,system-ui,sans-serif;background:radial-gradient(circle at 12% 0%,var(--bg-spot-a) 0,transparent 30%),radial-gradient(circle at 88% 100%,var(--bg-spot-b) 0,transparent 24%),var(--bg);color:var(--ink)}.app-shell{max-width:1160px;margin:0 auto;padding:28px 18px 40px}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:20px;align-content:center;gap:16px;background:radial-gradient(circle at 16% 14%,var(--auth-spot-a) 0,transparent 34%),radial-gradient(circle at 84% 86%,var(--auth-spot-b) 0,transparent 32%),linear-gradient(145deg,var(--auth-grad-a) 0%,var(--auth-grad-b) 100%)}.auth-card{width:min(480px,100%);background:var(--auth-card-bg);border:1px solid var(--auth-card-border);border-radius:20px;box-shadow:0 18px 42px var(--auth-card-shadow),inset 0 1px 0 var(--auth-card-inset);backdrop-filter:blur(14px) saturate(135%);-webkit-backdrop-filter:blur(14px) saturate(135%);padding:20px;display:grid;gap:12px}.auth-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.auth-theme-switch{width:76px;min-width:76px;height:32px;min-height:32px}.auth-theme-switch .theme-option,.auth-theme-switch .theme-thumb{width:24px;height:24px}.auth-theme-switch.light .theme-thumb{transform:translate(40px)}.auth-card input,.auth-card select,.auth-card button.ghost{background:var(--auth-field-bg);border-color:var(--auth-field-border);color:var(--ink)}.password-field{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.password-toggle{width:44px;min-width:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center}.password-toggle svg{width:16px;height:16px;fill:currentColor}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}.auth-tabs button.active{background:var(--brand);border-color:var(--brand);color:#fff}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.user-bar{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;min-width:0;gap:10px}.lang-dropdown{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.lang-dropdown-trigger{width:auto;min-width:124px;min-height:34px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--ghost-bg) 86%,transparent 14%);color:var(--ink);font-weight:600;line-height:1.2;cursor:pointer;display:inline-flex;align-items:center;justify-content:space-between;gap:10px}.lang-dropdown-trigger.compact{min-width:132px;min-height:32px}.lang-dropdown-trigger:hover{background:color-mix(in srgb,var(--ghost-hover-bg) 86%,transparent 14%)}.lang-dropdown-trigger:focus-visible{outline:3px solid var(--focus-ring);outline-offset:1px}.lang-dropdown-caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-1px);color:var(--muted);transition:transform .12s ease}.lang-dropdown-caret.open{transform:rotate(-135deg) translateY(-1px)}.lang-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:100%;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:grid;gap:4px;z-index:70}.lang-dropdown-option{width:100%;min-height:34px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--ink);font-weight:600;text-align:left;padding:8px 10px}.lang-dropdown-option:hover{background:color-mix(in srgb,var(--soft-surface) 86%,var(--brand) 14%);border-color:color-mix(in srgb,var(--border) 72%,var(--brand) 28%)}.lang-dropdown-option.active{background:color-mix(in srgb,var(--brand) 20%,var(--surface) 80%);border-color:color-mix(in srgb,var(--brand) 40%,var(--border) 60%)}.welcome-line{font-weight:600;max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-switch{position:relative;width:86px;min-width:86px;min-height:34px;height:34px;border-radius:999px;border:1px solid var(--border);background:var(--ghost-bg);padding:3px 4px;display:inline-flex;align-items:center;justify-content:space-between;gap:4px;cursor:pointer}.theme-switch:hover{background:var(--ghost-hover-bg)}.theme-switch .theme-option{z-index:2;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}.theme-switch .theme-option svg{width:14px;height:14px;fill:currentColor}.theme-switch .theme-thumb{position:absolute;top:3px;left:4px;width:28px;height:28px;border-radius:999px;background:var(--brand);opacity:.86;border:1px solid rgba(255,255,255,.35);box-shadow:0 4px 10px #0003;transition:transform .16s ease}.theme-switch.dark .theme-thumb{transform:translate(0)}.theme-switch.light .theme-thumb{transform:translate(48px)}.theme-switch.dark .theme-option:first-child,.theme-switch.light .theme-option:last-child{color:#fff}.header-date-line{margin:-6px 0 14px;color:var(--muted);font-size:.9rem;text-transform:capitalize}.eyebrow{margin:0;font-size:.82rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}h1,h2,h3,p{margin:0}h1{font-size:clamp(1.6rem,3vw,2rem)}h2{font-size:1.2rem}.nav-tabs-shell{position:relative;margin-bottom:16px}.nav-tabs{display:flex;flex-wrap:nowrap;gap:8px;margin-bottom:0;overflow:visible;padding:0}.nav-tabs button{min-height:44px;min-width:0;flex:1 1 0;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--ink);cursor:pointer;font-weight:600}.nav-tabs button.active{background:var(--brand);border-color:var(--brand);color:#fff}.nav-tabs-hint{display:none}.error-banner{margin-bottom:14px;padding:12px;border-radius:10px;border:1px solid #ebc6c6;background:#fff1f1;color:#7e1c1c}.success-banner{margin-top:12px;padding:12px;border-radius:10px;border:1px solid #bfd5ff;background:#eff5ff;color:#1e4ab9}.view-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px}.hero-card,.quick-entry-card,.stats-card,.project-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:16px}.hero-card{grid-column:span 6;background:linear-gradient(140deg,var(--brand),var(--brand-strong));color:#fff}.hero-value{margin-top:12px;font-size:clamp(2rem,6vw,3rem);font-weight:700}.hero-label{margin-top:4px;color:#e8f6ef}.hero-sub{margin-top:10px;color:#d7efe5;font-size:.86rem;text-transform:capitalize}.hero-card.today-card,.stats-card.month-card,.quick-entry-card.quick-dashboard-card{grid-column:span 4;min-height:252px;height:252px;display:flex;flex-direction:column}.quick-entry-card.quick-dashboard-card{overflow:hidden}.quick-entry-card.quick-dashboard-card .entry-form{overflow-y:auto;padding-right:4px}.month-value{margin-top:12px;font-size:clamp(2rem,5vw,2.6rem);font-weight:700;color:var(--ink)}.month-label{margin-top:4px;color:var(--muted)}.month-sub{margin-top:10px;font-size:.86rem;color:var(--muted);text-transform:capitalize}.quick-entry-card{grid-column:span 6;background:var(--surface-alt)}.stats-card{grid-column:span 6}.stats-card.full,.hero-card.full{grid-column:span 12}.project-card{grid-column:span 4}label{display:block;margin-top:10px;margin-bottom:4px;color:var(--muted);font-size:.88rem}input,select,button{width:100%;border-radius:10px;border:1px solid var(--input-border);min-height:44px;padding:10px 12px;font:inherit}input,select{background:var(--input-bg);color:var(--ink)}button{background:var(--brand);color:#fff;border-color:var(--brand);cursor:pointer;font-weight:600}button:hover{background:var(--brand-strong);border-color:var(--brand-strong)}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--focus-ring);outline-offset:1px}button:disabled{opacity:.65;cursor:not-allowed}button.ghost{background:var(--ghost-bg);color:var(--ghost-ink);border-color:var(--border)}button.ghost:hover{background:var(--ghost-hover-bg)}button.danger{background:var(--danger);border-color:var(--danger)}button.danger:hover{background:var(--danger-strong);border-color:var(--danger-strong)}button.link{background:transparent;border:none;color:var(--brand-strong);text-decoration:underline;min-height:auto;padding:0}.project-form,.entry-form{display:grid;gap:8px;margin-top:10px}.inline-btn{width:auto;min-height:36px;padding:6px 12px;display:inline-flex;align-items:center;gap:6px}.inline-btn svg{width:14px;height:14px;fill:currentColor}.inline-note{margin-top:6px;color:var(--muted);font-size:.88rem}.account-info-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.account-info-item{border:1px solid var(--border);border-radius:12px;background:var(--soft-surface);padding:10px;display:grid;gap:4px}.account-info-item span{color:var(--muted);font-size:.85rem}.account-info-item strong{font-size:.98rem}.stats-list,.entries-list{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:8px}.stats-list li,.entries-list li{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--soft-surface)}.stats-list li span,.entries-list li span{display:block;color:var(--muted);font-size:.9rem}.right-stats{display:flex;align-items:center;gap:10px}.project-summary{margin-top:8px;display:grid;gap:2px}.project-summary p{color:var(--muted);font-size:.86rem}.compact-project-card{padding:12px}.compact-project-card h3{font-size:1.02rem}.compact-project-card .row-actions{margin-top:8px}.entry-actions{display:inline-flex;align-items:center;gap:8px}.entry-main{display:grid;gap:2px}.entries-list li .entry-activity{font-size:1.02rem;color:var(--ink)}.entries-list li .entry-date{font-size:.78rem;color:var(--muted)}.row-actions{display:flex;gap:8px;margin-top:10px}.row-actions.compact{margin-top:0}.row-actions .content-btn{width:auto;min-width:0;min-height:36px;padding:8px 12px;display:inline-flex;align-items:center;gap:7px}.row-actions .content-btn svg{width:14px;height:14px;fill:currentColor}.icon-btn{width:42px;min-width:42px;min-height:42px;padding:0;display:inline-flex;align-items:center;justify-content:center;position:relative}.icon-btn svg{width:17px;height:17px;fill:currentColor}.tooltip-wrap .tooltip-bubble{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%) translateY(4px);opacity:0;visibility:hidden;width:max-content;max-width:240px;background:var(--tooltip-bg);color:var(--tooltip-ink);font-size:.76rem;line-height:1.3;text-align:center;border-radius:10px;padding:8px 10px;box-shadow:0 8px 18px #06141259;transition:opacity .12s ease,transform .12s ease,visibility .12s ease;pointer-events:none;z-index:20}.tooltip-wrap .tooltip-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:var(--tooltip-bg) transparent transparent transparent}.tooltip-wrap:hover .tooltip-bubble,.tooltip-wrap:focus-visible .tooltip-bubble{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.header-actions{display:flex;align-items:center;gap:8px}.small-nav-btn{min-height:32px;padding:5px 10px;font-size:.84rem}.admin-table-wrap{margin-top:14px;overflow-x:auto}.admin-toolbar{margin-top:10px;display:flex;align-items:center;gap:8px}.admin-toolbar input{max-width:360px;flex:1}.virtual-list{margin-top:12px;overflow-y:auto;border:1px solid var(--border);border-radius:12px;background:var(--soft-surface)}.virtual-list-inner{margin:0;padding:0}.virtual-list .tooltip-wrap .tooltip-bubble{left:auto;right:calc(100% + 8px);top:50%;bottom:auto;transform:translateY(-50%) translate(4px)}.virtual-list .tooltip-wrap .tooltip-bubble:after{top:50%;left:100%;transform:translateY(-50%);border-color:transparent transparent transparent var(--tooltip-bg)}.virtual-list .tooltip-wrap:hover .tooltip-bubble,.virtual-list .tooltip-wrap:focus-visible .tooltip-bubble{transform:translateY(-50%) translate(0)}.admin-table{width:100%;border-collapse:collapse;min-width:680px}.admin-table th,.admin-table td{border-bottom:1px solid var(--border);text-align:left;padding:10px 8px}.role-pill{display:inline-block;border-radius:999px;padding:4px 10px;font-size:.82rem;font-weight:600;background:#eef2ed}.role-pill.admin{background:#dbe9ff;color:#1f4ba8}.role-pill.user{background:#e9edf8;color:#365495}.pagination{margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px}.pagination span{color:var(--muted);font-size:.9rem}.compact-btn{width:36px;min-width:36px;min-height:36px;height:36px;padding:0}.app-footer{margin-top:20px;text-align:center;color:var(--muted)}.project-charts{margin-top:14px;display:grid;grid-template-columns:1.25fr .95fr;gap:12px}.chart-card{border:1px solid var(--border);background:var(--soft-surface);border-radius:14px;padding:12px;min-height:320px}.chart-card h3{margin-bottom:10px;font-size:1rem}.chart-empty{color:var(--muted);margin-top:6px}.bar-chart{list-style:none;margin:0;padding:0;display:grid;gap:10px}.bar-chart li{display:grid;gap:6px}.bar-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.bar-head strong{font-size:.92rem}.bar-head span{color:var(--muted);font-size:.85rem}.bar-track{min-height:12px;height:12px;border-radius:999px;border:0;padding:0;background:#e3ecdf;overflow:hidden;cursor:pointer}.bar-track:hover{background:#d7e3d2;border-color:transparent}.bar-fill{display:block;height:100%;border-radius:inherit}.donut-wrap{position:relative;width:180px;margin:8px auto 12px}.donut-wrap svg{width:100%;height:auto;display:block}.donut-track{fill:none;stroke:#e3ecdf;stroke-width:16}.donut-segment{fill:none;stroke-width:16;stroke-linecap:butt}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;align-content:center;text-align:center}.donut-center strong{font-size:1.2rem;line-height:1}.donut-center span{color:var(--muted);font-size:.82rem}.chart-legend{list-style:none;margin:0;padding:0;display:grid;gap:8px}.chart-legend li{display:flex;align-items:center;gap:8px}.legend-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.legend-link{background:transparent;border:0;padding:0;min-height:0;color:var(--ink);text-align:left;font-size:.9rem;cursor:pointer;text-decoration:underline}.legend-link:hover{color:var(--brand-strong);background:transparent;border-color:transparent}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c1a1885;display:grid;place-items:center;padding:16px;z-index:80}.modal-card{width:min(480px,100%);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:0 16px 44px #0716123d;padding:16px}.modal-description{margin-top:8px;color:var(--muted)}.report-modal-card{width:min(760px,100%)}.report-controls{margin-top:10px;display:grid;grid-template-columns:minmax(220px,1fr) auto;align-items:end;gap:8px}.report-controls button{width:auto}.report-result{margin-top:12px}.report-total{margin-bottom:8px}.report-table-wrap{max-height:320px;overflow:auto;border:1px solid var(--border);border-radius:10px}.report-table{min-width:100%}.calendar-field{display:grid;gap:4px;position:relative}.calendar-trigger{width:100%;min-height:44px;border-radius:10px;border:1px solid var(--border);background:var(--input-bg);color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;cursor:pointer}.calendar-trigger:hover{border-color:var(--brand);background:color-mix(in srgb,var(--input-bg) 88%,var(--brand) 12%)}.calendar-trigger:focus-visible{outline:3px solid var(--focus-ring);outline-offset:1px}.calendar-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:50;width:min(320px,100%);border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 12px 30px #12243f29;padding:10px}.calendar-input-icon{width:16px;height:16px;color:var(--muted)}.calendar-input-icon svg{width:100%;height:100%;fill:currentColor}.calendar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.calendar-header strong{font-size:.95rem}.calendar-nav-btn{min-height:30px;width:30px;min-width:30px;height:30px}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;margin-bottom:4px}.calendar-weekdays span{text-align:center;font-size:.75rem;color:var(--muted)}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.month-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.calendar-empty{min-height:32px}.calendar-day-btn{min-height:32px;height:32px;border-radius:8px;border:1px solid transparent;background:var(--soft-surface);color:var(--ink);padding:0}.calendar-day-btn:hover{background:color-mix(in srgb,var(--soft-surface) 80%,var(--brand) 20%);border-color:color-mix(in srgb,var(--border) 60%,var(--brand) 40%)}.calendar-day-btn.selected{background:var(--brand);color:#fff;border-color:var(--brand)}.report-group-row td{background:color-mix(in srgb,var(--soft-surface) 82%,var(--brand) 18%);font-weight:600}.report-item-row td{background:var(--surface)}.report-item-row td:nth-child(2){padding-left:18px}.report-toggle{width:auto;min-height:0;padding:0;border:0;background:transparent;color:var(--ink);font:inherit;font-weight:600;cursor:pointer;text-align:left}.report-toggle:hover{color:var(--brand-strong);background:transparent;border-color:transparent}.report-toggle:focus-visible,.legend-link:focus-visible,.bar-track:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media (max-width: 980px){.nav-tabs{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding:0 40px 2px 0}.nav-tabs button{min-width:148px;flex:0 0 auto}.nav-tabs-hint{display:block;position:absolute;top:0;right:0;width:38px;height:46px;pointer-events:none;background:linear-gradient(to right,transparent 0%,var(--bg) 78%)}.hero-card,.quick-entry-card,.stats-card,.project-card,.hero-card.today-card,.stats-card.month-card,.quick-entry-card.quick-dashboard-card{grid-column:span 12}.project-charts,.account-info-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.user-bar{width:100%;justify-content:flex-start}.welcome-line{max-width:100%}.header-actions{width:100%;flex-wrap:wrap}.report-controls{grid-template-columns:1fr;align-items:stretch}}@media (prefers-reduced-motion: reduce){*{transition:none!important;animation:none!important}}
