*,:after,:before{box-sizing:border-box}#root,body,html{min-height:100%;width:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0000;color:var(--text);margin:0;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit}button{touch-action:manipulation}img,svg{display:block;max-width:100%}a{color:inherit}::selection{background:#2f5ec429}.landing-shell{background:radial-gradient(circle at 14% 16%,#d9af6f2e,#0000 24%),radial-gradient(circle at 84% 10%,#78a0d633,#0000 22%),linear-gradient(180deg,#f5efe4,#ece4d8 48%,#e5ddd1);color:var(--text);min-height:100vh}.landing-loading{grid-gap:.75rem;display:grid;gap:.75rem;min-height:100vh;padding:2rem;place-items:center;text-align:center}.landing-loading h1{color:var(--accent-strong);font-size:clamp(2.5rem,8vw,4rem);letter-spacing:-.06em;margin:0}.landing-loading p{color:var(--text-muted);margin:0}.landing-hero,.landing-section{margin:0 auto;width:min(1120px,calc(100% - 2rem))}.landing-hero{align-content:start;display:grid;min-height:100vh;padding:1.25rem 0 3.5rem}.landing-nav{align-items:center;display:flex;gap:1rem;justify-content:space-between;padding:.4rem 0 1.5rem}.landing-brand{align-items:center;color:#14304f;display:inline-flex;font-weight:800;gap:.75rem;letter-spacing:-.04em}.landing-brand-mark{background:linear-gradient(135deg,#17345f,#27537d);border-radius:.85rem;box-shadow:0 14px 28px #17345f33;color:#fff;display:grid;height:2.4rem;place-items:center;width:2.4rem}.landing-nav-links{align-items:center;color:#70819a;display:inline-flex;gap:1rem}.landing-nav-links a{text-decoration:none}.landing-nav-links a:focus-visible,.landing-nav-links a:hover{color:#17345f}.landing-hero-grid{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:minmax(0,1.05fr) minmax(280px,.95fr);padding:2rem 0 0}.landing-hero-copy{max-width:34rem}.landing-eyebrow{color:#596a82;font-size:.82rem;font-weight:800;letter-spacing:.16em;margin:0 0 .9rem;text-transform:uppercase}.landing-hero-copy h1,.landing-section h2{text-wrap:balance;letter-spacing:-.06em;margin:0}.landing-hero-copy h1{color:#14304f;font-size:clamp(3rem,6vw,5.2rem);line-height:.94;max-width:11ch}.landing-intro{color:#65758d;font-size:1.06rem;line-height:1.7;margin:1.25rem 0 0;max-width:32rem}.landing-cta-row{align-items:center;display:flex;flex-wrap:wrap;gap:.95rem;margin-top:1.75rem}.landing-primary-cta{min-width:13.5rem}.landing-secondary-cta{align-items:center;background:#fffaf4b8;border:1px solid #1a40671f;border-radius:999px;color:#1a4067;display:inline-flex;font-weight:700;gap:.55rem;min-height:3.2rem;padding:.85rem 1.2rem;text-decoration:none}.landing-secondary-cta:focus-visible,.landing-secondary-cta:hover{background:#fff8f1eb;transform:translateY(-1px)}.landing-meta{color:#5f6c7d;font-size:.94rem;margin:1rem 0 0}.landing-poster{background:radial-gradient(circle at 22% 80%,#cea5662e,#0000 20%),linear-gradient(165deg,#17345f,#21486e 58%,#295777);border-radius:2.2rem;box-shadow:0 30px 80px #12223d38;min-height:31rem;overflow:hidden;padding:1.5rem;position:relative}.landing-poster-glow{background:#d6ad6e2e;border-radius:999px;filter:blur(18px);height:14rem;inset:auto auto 3rem 2rem;position:absolute;width:14rem}.landing-poster-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#eff5fc1a;border:1px solid #e6ecf51f;border-radius:1.7rem;position:relative;z-index:1}.landing-poster-panel-main{margin-top:1rem;max-width:25rem;padding:1.5rem}.landing-mini-label,.landing-panel-label{align-items:center;color:#ecf2f9d1;display:inline-flex;font-size:.82rem;font-weight:700;gap:.45rem;letter-spacing:.08em;text-transform:uppercase}.landing-poster-panel-main h2{color:#fff;font-size:clamp(1.7rem,4vw,2.6rem);line-height:1.02;margin:1rem 0 0}.landing-poster-panel-main p,.landing-poster-panel-stack p{color:#dfe8f4d6;line-height:1.6;margin:.9rem 0 0}.landing-poster-panel-stack{grid-gap:1rem;bottom:1.5rem;display:grid;gap:1rem;padding:1.25rem;position:absolute;right:1.5rem;width:min(18rem,calc(100% - 3rem))}.landing-section{padding:4rem 0}.landing-section-heading{max-width:42rem}.landing-section h2{color:#17345f;font-size:clamp(2rem,4vw,3.4rem);line-height:1.02}.landing-feature-columns{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:2rem}.landing-feature-columns h3{color:#17345f;font-size:1.15rem;margin:0 0 1rem}.landing-feature-list{grid-gap:.9rem;display:grid;gap:.9rem;list-style:none;margin:0;padding:0}.landing-feature-list li{grid-gap:.85rem;align-items:start;border-top:1px solid #17345f1a;color:#5f6f86;display:grid;gap:.85rem;grid-template-columns:auto 1fr;padding:1rem 0}.landing-feature-list li:last-child{border-bottom:1px solid #17345f1a}.landing-feature-list svg{color:#17345f;margin-top:.15rem}.landing-feature-list.premium svg{color:#8b6230}.landing-detail{padding-top:0}.landing-detail-card{grid-gap:2rem;background:#fff9f1b3;border:1px solid #17345f14;border-radius:2rem;box-shadow:0 20px 56px #222b3e0f;display:grid;gap:2rem;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);padding:2rem}.landing-detail-points{grid-gap:1rem;display:grid;gap:1rem}.landing-detail-points p{grid-gap:.85rem;border-top:1px solid #17345f1a;color:#61718a;display:grid;gap:.85rem;grid-template-columns:auto 1fr;line-height:1.65;margin:0;padding:1rem 0}.landing-detail-points p:last-child{border-bottom:1px solid #17345f1a}.landing-detail-points svg{color:#17345f;margin-top:.1rem}.landing-footer-cta{padding-bottom:5rem;padding-top:0}.landing-footer-cta h2{max-width:16ch}@media (max-width:920px){.landing-hero{min-height:auto;padding-bottom:2.5rem}.landing-detail-card,.landing-feature-columns,.landing-hero-grid{grid-template-columns:1fr}.landing-hero-copy h1{max-width:12ch}.landing-poster{min-height:26rem}}@media (max-width:640px){.landing-hero,.landing-section{width:min(100%,calc(100% - 1.5rem))}.landing-nav{align-items:flex-start;flex-direction:column}.landing-nav-links{gap:.8rem}.landing-hero-grid{padding-top:1rem}.landing-hero-copy h1{font-size:clamp(2.6rem,14vw,4rem);max-width:none}.landing-poster{min-height:24rem;padding:1rem}.landing-detail-card,.landing-poster-panel-main,.landing-poster-panel-stack{padding:1.2rem}.landing-poster-panel-stack{margin-top:1rem;position:static;width:100%}}.dashboard,.gst-report-page,.invoice-page,.invoices-page,.preferences-page,.projects-page,.reports-page,.subscription-page,.support-page,.tax-obligations-page{padding-left:5rem;padding-left:var(--nav-rail-width,5rem);transition:padding-left .22s ease}.top-bar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(180deg,#f8f6eff5,#f8f6efe6);border-bottom:1px solid #1f293714;position:sticky;top:0;z-index:120}.top-bar-content{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1400px;padding:1rem 2rem}.app-name-link{color:inherit;min-width:0;text-decoration:none}.app-name{color:#172033;font-size:clamp(1.4rem,2vw,2rem);font-weight:700;letter-spacing:-.04em;margin:0}.avatar-button,.logout-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:.75rem;color:#32415f;cursor:pointer;display:inline-flex;gap:.875rem;justify-content:flex-start;min-height:3rem;min-width:0;padding:0 .75rem;transition:color .2s ease,background-color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease;width:100%}.avatar-button:hover,.logout-btn:hover{background:#1f293714;border-color:#0000;color:#172033}.avatar-button{overflow:visible}.avatar-button.active{box-shadow:0 0 0 4px #1ba36729}.avatar-button.expiring{box-shadow:0 0 0 4px #d9770629}.avatar-button.expired{box-shadow:0 0 0 4px #dc262629}.user-avatar,.user-avatar-placeholder{border-radius:999px;flex:0 0 1.75rem;height:1.75rem;width:1.75rem}.user-avatar{object-fit:cover}.user-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#2f5ec4,#1c7c73);color:#fff;display:inline-flex;justify-content:center}.logout-btn:hover{color:#b42318}.nav-rail{background:linear-gradient(180deg,#fffaf2fa,#f6f6f1f0);border-right:1px solid #1f29371a;bottom:0;box-shadow:10px 0 40px #0f172a14;display:flex;flex-direction:column;gap:.5rem;left:0;overflow:hidden;padding:.5rem;position:fixed;top:0;transition:width .22s ease,box-shadow .22s ease,background-color .22s ease;width:1rem;width:var(--nav-rail-width,1rem);z-index:130}.nav-rail.expanded{box-shadow:16px 0 54px #0f172a1f}.nav-item,.nav-toggle-btn{align-items:center;border-radius:.75rem;color:#334155;display:flex;gap:.875rem;min-height:2.75rem;min-width:0;position:relative;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease;width:100%}.nav-toggle-btn{background:#0000;border:1px solid #0000;cursor:pointer;font:inherit;justify-content:flex-start;padding:0 .625rem}.nav-toggle-btn:hover{background:#1f293714;border-color:#0000;color:#172033}.nav-rail-content{display:flex;flex-direction:column;gap:.4rem}.nav-item{background:#0000;border:1px solid #0000;padding:0 .625rem;text-decoration:none}.nav-item:hover{background:#1f293714;border-color:#0000;color:#172033}.nav-item.active{background:#2f5ec429;border-color:#0000;color:#12305a}.logout-btn svg,.nav-item svg,.nav-toggle-btn svg{flex:0 0 1rem}.nav-label{min-width:7rem;opacity:1;overflow:hidden;transform:translateX(0);transition:opacity .18s ease,transform .18s ease;white-space:nowrap}.nav-rail.collapsed .avatar-button,.nav-rail.collapsed .logout-btn,.nav-rail.collapsed .nav-item,.nav-rail.collapsed .nav-toggle-btn{align-self:center;gap:0;height:2.5rem;justify-content:center;min-height:2.5rem;padding:0;width:2.5rem}.nav-rail.collapsed .nav-label{min-width:0;opacity:0;pointer-events:none;transform:translateX(-.5rem);width:0}.nav-rail.collapsed .user-avatar,.nav-rail.collapsed .user-avatar-placeholder{flex-basis:1.5rem;height:1.5rem;width:1.5rem}.nav-rail-actions{display:flex;flex-direction:column;gap:.4rem;margin-top:auto}@media (prefers-reduced-motion:reduce){.avatar-button,.dashboard,.gst-report-page,.invoice-page,.invoices-page,.logout-btn,.nav-item,.nav-label,.nav-rail,.nav-toggle-btn,.preferences-page,.projects-page,.reports-page,.support-page,.tax-obligations-page{transition:none}}@media (prefers-color-scheme:dark){.top-bar{background:linear-gradient(180deg,#111827f5,#111827e0);border-bottom-color:#94a3b82e}.app-name{color:#eff6ff}.avatar-button,.logout-btn{background:#0000;border-color:#0000;color:#e2e8f0}.avatar-button:hover,.logout-btn:hover{background:#94a3b824;border-color:#0000;color:#fff}.nav-rail{background:linear-gradient(180deg,#0f172afa,#111827f5);border-right-color:#94a3b829;box-shadow:10px 0 40px #02061761}.nav-toggle-btn{background:#0000;border-color:#0000;color:#e2e8f0}.nav-toggle-btn:hover{background:#94a3b824;border-color:#0000;color:#fff}.nav-item{background:#0000;color:#dbe4f0}.nav-item:hover{background:#94a3b824;border-color:#0000;color:#fff}.nav-item.active{background:#7dd3fc2e;border-color:#0000;color:#f8fafc}}@media (max-width:768px){.dashboard,.gst-report-page,.invoice-page,.preferences-page,.projects-page,.reports-page,.subscription-page,.tax-obligations-page{padding-left:4.25rem}.nav-rail{padding:.65rem .4rem;width:3.5rem}.nav-rail.expanded{width:min(14rem,76vw)}.avatar-button,.logout-btn,.nav-item,.nav-toggle-btn{border-radius:.625rem;min-height:2.75rem}.nav-rail.collapsed .avatar-button,.nav-rail.collapsed .logout-btn,.nav-rail.collapsed .nav-item,.nav-rail.collapsed .nav-toggle-btn{height:2.5rem;width:2.5rem}.top-bar-content{padding:.85rem 1rem}}@media print{.nav-rail,.top-bar{display:none!important}.dashboard,.gst-report-page,.invoice-page,.preferences-page,.projects-page,.reports-page,.subscription-page,.tax-obligations-page{padding-left:0!important}}.dashboard{--dashboard-content-max-width:1280px;--dashboard-horizontal-padding:2rem;background-color:#fff;min-height:100vh}@media (prefers-color-scheme:dark){.dashboard{background-color:#111827}}.timer-bar{background-color:#fff;padding:1.5rem var(--dashboard-horizontal-padding);width:100%}@media (prefers-color-scheme:dark){.timer-bar{background-color:#111827}}.timer-bar-content{--timer-control-height:4rem;align-items:stretch;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin:0 auto;max-width:calc(var(--dashboard-content-max-width) - var(--dashboard-horizontal-padding)*2)}.task-input-wrapper{align-items:stretch;display:flex;flex:1 1;justify-content:flex-start;min-width:0;position:relative}.task-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#111827;font-size:1.125rem;min-height:var(--timer-control-height);outline:none;padding:0 1.5rem;text-align:center;transition:all .2s;width:100%}.task-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.task-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.task-input::placeholder{color:#9ca3af}.search-suggestions{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-shadow:0 4px 12px #0000001a;left:0;margin-top:.5rem;max-height:300px;overflow-y:auto;position:absolute;top:100%;width:100%;z-index:1000}.modal-content .search-suggestions{left:0;max-width:100%;transform:none}.search-suggestion-item{border-bottom:1px solid #e5e7eb;cursor:pointer;padding:.75rem 1rem;text-align:left;transition:background-color .2s}.search-suggestion-item:last-child{border-bottom:none}.search-suggestion-item:hover{background-color:#f3f4f6}.suggestion-description{color:#111827;font-size:.9375rem;font-weight:500;margin-bottom:.25rem}.suggestion-project{color:#6b7280;font-size:.8125rem}@media (prefers-color-scheme:dark){.task-input{background-color:#1f2937;border-color:#4b5563;color:#f9fafb}.task-input:focus{border-color:#3b82f6}.task-input:disabled{background-color:#1f2937}.task-input::placeholder{color:#6b7280}.search-suggestions{background-color:#1f2937;border-color:#4b5563;box-shadow:0 4px 12px #0000004d}.search-suggestion-item{border-bottom-color:#374151}.search-suggestion-item:hover{background-color:#374151}.suggestion-description{color:#f9fafb}.suggestion-project{color:#9ca3af}}.timer-controls{align-items:stretch;display:flex;flex-shrink:0;flex-wrap:wrap;gap:1rem;justify-content:flex-end}.timer-display{align-items:center;color:#111827;display:inline-flex;font-family:Courier New,monospace;font-size:1.875rem;font-weight:700;justify-content:center;min-height:var(--timer-control-height);min-width:140px;padding:0 .25rem;text-align:right}.timer-display.clickable{cursor:pointer;transition:color .2s}.timer-display.clickable:hover{color:#3b82f6}@media (prefers-color-scheme:dark){.timer-display{color:#f9fafb}.timer-display.clickable:hover{color:#60a5fa}}.timer-btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;height:var(--timer-control-height);justify-content:center;padding:1rem;transition:all .2s;width:var(--timer-control-height)}.timer-btn-start{background-color:#10b981;color:#fff}.timer-btn-start:hover{background-color:#059669}.timer-btn-stop{background-color:#ef4444;color:#fff}.timer-btn-stop:hover{background-color:#dc2626}.timer-btn:disabled{cursor:not-allowed;opacity:.6}.timer-btn.loading{opacity:.8}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #0000;border-top-color:currentcolor;height:32px;width:32px}.project-btn{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#374151;cursor:pointer;display:flex;font-size:1.5rem;font-weight:500;gap:.5rem;min-height:var(--timer-control-height);padding:.5rem .75rem;transition:all .2s;white-space:nowrap}.project-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.project-btn:disabled{cursor:not-allowed;opacity:.5}.project-name{max-width:150px;overflow:hidden;text-overflow:ellipsis}@media (prefers-color-scheme:dark){.project-btn{background-color:#1f2937;border-color:#4b5563;color:#e5e7eb}.project-btn:hover{background-color:#374151;border-color:#6b7280}}.content-area{color:#6b7280;margin:0 auto;max-width:var(--dashboard-content-max-width);min-width:0;padding:2rem var(--dashboard-horizontal-padding) 2rem}@media (prefers-color-scheme:dark){.content-area{color:#9ca3af}}.view-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:.75rem;min-height:2rem}.view-toggle{background-color:#f3f4f6;border-radius:.5rem;margin-left:auto;max-width:100%;padding:.25rem}.view-toggle,.week-nav{align-items:center;display:flex;flex-wrap:wrap;gap:.25rem}@media (prefers-color-scheme:dark){.view-toggle{background-color:#374151}}.view-toggle-btn{align-items:center;background-color:initial;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s}.view-toggle-btn:hover{color:#111827}.view-toggle-btn.active{background-color:#fff;box-shadow:0 1px 3px #0000001a;color:#3b82f6}@media (prefers-color-scheme:dark){.view-toggle-btn{color:#9ca3af}.view-toggle-btn:hover{color:#f9fafb}.view-toggle-btn.active{background-color:#1f2937;color:#60a5fa}}.timer-list{gap:1.5rem}.timer-day-group,.timer-list{display:flex;flex-direction:column}.timer-day-group{gap:.5rem}.day-header{color:#6b7280;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;padding:.5rem .75rem;text-transform:uppercase}@media (prefers-color-scheme:dark){.day-header{color:#9ca3af}}.timer-entry{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:.625rem 1rem;transition:all .2s}.timer-entry:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000001a}.ghost-timer{animation:pulse 2s ease-in-out infinite;border-style:dashed!important;opacity:.7}@keyframes pulse{0%,to{opacity:.7}50%{opacity:.5}}@media (prefers-color-scheme:dark){.timer-entry{background-color:#1f2937;border-color:#374151}.timer-entry:hover{border-color:#4b5563;box-shadow:0 2px 8px #0000004d}}.timer-entry-main{align-items:center;display:flex;gap:1.5rem}.timer-entry-time{color:#6b7280;font-family:Courier New,monospace;font-size:.8125rem;min-width:110px;text-align:left}@media (prefers-color-scheme:dark){.timer-entry-time{color:#9ca3af}}.timer-entry-description{flex:1 1;min-width:0;text-align:left}.entry-description{color:#111827;font-size:.9375rem;font-weight:500;margin-bottom:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.entry-project{border:1px solid;border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.125rem .5rem;width:fit-content}@media (prefers-color-scheme:dark){.entry-description{color:#f9fafb}}.timer-entry-duration{color:#3b82f6;font-family:Courier New,monospace;font-size:1rem;font-weight:600;min-width:80px;text-align:right}@media (prefers-color-scheme:dark){.timer-entry-duration{color:#60a5fa}}.timer-entry-actions{align-items:center;display:flex;gap:.25rem;justify-content:flex-end;min-width:70px}.timer-action-btn{align-items:center;background-color:initial;border:none;border-radius:.375rem;cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:all .2s}.timer-start-btn{color:#10b981}.timer-start-btn:hover{background-color:#d1fae5;color:#059669}@media (prefers-color-scheme:dark){.timer-start-btn{color:#34d399}.timer-start-btn:hover{background-color:#064e3b;color:#6ee7b7}}.timer-menu-btn{align-items:center;background-color:initial;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:.375rem;transition:all .2s}.timer-menu-btn:hover{background-color:#f3f4f6;color:#111827}@media (prefers-color-scheme:dark){.timer-menu-btn{color:#9ca3af}.timer-menu-btn:hover{background-color:#374151;color:#f9fafb}}.timer-menu-popup{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 4px 12px #00000026;min-width:140px;padding:.5rem;z-index:1000}@media (prefers-color-scheme:dark){.timer-menu-popup{background-color:#1f2937;border-color:#374151;box-shadow:0 4px 12px #00000080}}.menu-item{background-color:initial;border:none;border-radius:.375rem;color:#111827;cursor:pointer;display:block;font-size:.875rem;padding:.625rem 1rem;text-align:left;transition:background-color .2s;width:100%}.menu-item:hover{background-color:#f3f4f6}.menu-item-delete{color:#ef4444}.menu-item-delete:hover{background-color:#fef2f2}@media (prefers-color-scheme:dark){.menu-item{color:#f9fafb}.menu-item:hover{background-color:#374151}.menu-item-delete{color:#f87171}.menu-item-delete:hover{background-color:#991b1b}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.modal-content{background-color:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:90%}@media (prefers-color-scheme:dark){.modal-content{background-color:#1f2937}}.modal-title{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}@media (prefers-color-scheme:dark){.modal-title{color:#f9fafb}}.form-group{margin-bottom:1.25rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1 1}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}@media (prefers-color-scheme:dark){.form-label{color:#d1d5db}}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box;color:#111827;font-size:.875rem;outline:none;padding:.625rem .875rem;transition:all .2s;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-hint{color:#6b7280;font-size:.75rem;margin-bottom:0;margin-top:.375rem}@media (prefers-color-scheme:dark){.form-input{background-color:#374151;border-color:#4b5563;color:#f9fafb}.form-input:focus{border-color:#3b82f6}.form-hint{color:#9ca3af}}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}@media (prefers-color-scheme:dark){.modal-actions{border-top-color:#374151}}.btn{border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.btn-cancel{background-color:#fff;border:1px solid #d1d5db;color:#374151}.btn-cancel:hover{background-color:#f9fafb}@media (prefers-color-scheme:dark){.btn-cancel{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.btn-cancel:hover{background-color:#4b5563}}.btn-save{background-color:#3b82f6;color:#fff}.btn-save:hover{background-color:#2563eb}.project-selector-modal{max-width:500px}.start-time-edit-modal{max-width:400px}.create-project-form-container{display:flex;flex-direction:column;gap:1rem}.create-project-section{margin-bottom:1.5rem}.create-project-form,.create-project-section{display:flex;flex-direction:column;gap:.75rem}.client-selector-wrapper{width:100%}.client-button-list{display:flex;flex-wrap:wrap;gap:.5rem}.client-button{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#111827;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.client-button:hover{background-color:#f9fafb;border-color:#3b82f6}.client-button.selected{background-color:#eff6ff;border-color:#3b82f6;color:#3b82f6;font-weight:500}@media (prefers-color-scheme:dark){.client-button{background-color:#374151;border-color:#4b5563;color:#f9fafb}.client-button:hover{background-color:#4b5563;border-color:#3b82f6}.client-button.selected{background-color:#1e3a5f;border-color:#3b82f6;color:#60a5fa}}.client-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#111827;cursor:pointer;font-size:.875rem;padding:.5rem;width:100%}.client-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}@media (prefers-color-scheme:dark){.client-select{background-color:#374151;border-color:#4b5563;color:#f9fafb}.client-select:focus{border-color:#3b82f6}}.create-client-inline{align-items:center;display:flex;gap:.5rem}.create-client-inline .form-input{flex:1 1}.create-client-inline .btn{min-width:fit-content;padding:.5rem 1rem}.create-project-section>.btn{align-self:flex-start;white-space:nowrap}.btn-secondary{background-color:#6b7280;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s;white-space:nowrap}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}@media (prefers-color-scheme:dark){.btn-secondary{background-color:#4b5563}.btn-secondary:hover:not(:disabled){background-color:#374151}}.project-list-divider{align-items:center;color:#6b7280;display:flex;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.project-list-divider:after,.project-list-divider:before{border-bottom:1px solid #e5e7eb;content:"";flex:1 1}.project-list-divider:before{margin-right:.75rem}.project-list-divider:after{margin-left:.75rem}@media (prefers-color-scheme:dark){.project-list-divider{color:#9ca3af}.project-list-divider:after,.project-list-divider:before{border-bottom-color:#4b5563}}.project-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;max-height:400px;overflow-y:auto}.project-item{align-items:center;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;color:#111827;cursor:pointer;display:flex;font-size:.875rem;gap:.75rem;padding:.875rem 1rem;text-align:left;transition:all .2s;width:100%}.project-item-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.project-item-name{font-weight:500}.project-item-client{color:#6b7280;font-size:.75rem}@media (prefers-color-scheme:dark){.project-item-client{color:#9ca3af}}.project-item:hover{background-color:#f9fafb;border-color:#3b82f6}.project-item.selected{background-color:#eff6ff;border-color:#3b82f6;color:#3b82f6}@media (prefers-color-scheme:dark){.project-item{background-color:#374151;border-color:#4b5563;color:#f9fafb}.project-item:hover{background-color:#4b5563;border-color:#3b82f6}.project-item.selected{background-color:#1e3a5f;border-color:#3b82f6;color:#60a5fa}}.no-projects{color:#6b7280;font-size:.875rem;padding:2rem 1rem;text-align:center}@media (prefers-color-scheme:dark){.no-projects{color:#9ca3af}}.calendar-view{display:flex;flex-direction:column;gap:0;min-width:0}.calendar-title{color:#111827;flex:1 1 18rem;font-size:1.125rem;font-weight:600;line-height:1.3;margin:0;min-width:0}@media (prefers-color-scheme:dark){.calendar-title{color:#f9fafb}}.calendar-nav-btn{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;color:#6b7280;cursor:pointer;font-size:1.25rem;font-weight:700;padding:.5rem 1rem;transition:all .2s}.calendar-nav-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#d1d5db;color:#111827}.calendar-nav-btn:disabled{cursor:not-allowed;opacity:.4}.calendar-nav-btn.today-btn{font-size:.875rem;font-weight:600;padding:.5rem 1rem}@media (prefers-color-scheme:dark){.calendar-nav-btn{background-color:#1f2937;border-color:#374151;color:#9ca3af}.calendar-nav-btn:hover:not(:disabled){background-color:#374151;border-color:#4b5563;color:#f9fafb}}.calendar-grid{grid-gap:.5rem;align-items:start;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,10rem),1fr))}.calendar-day{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;flex-direction:column;font-size:.8125rem;min-height:150px;min-width:0}.calendar-day.today{border-color:#3b82f6;border-width:2px}@media (prefers-color-scheme:dark){.calendar-day{background-color:#1f2937;border-color:#374151}.calendar-day.today{border-color:#60a5fa}}.calendar-day-header{border-bottom:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.25rem;min-width:0;padding:.5rem;position:relative}@media (prefers-color-scheme:dark){.calendar-day-header{border-bottom-color:#374151}}.calendar-add-btn{align-items:center;background-color:#fff;border:1px solid #d1d5db;border-radius:.25rem;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;height:20px;justify-content:center;line-height:1;padding:0;position:absolute;right:.25rem;top:.25rem;transition:all .2s;width:20px}.calendar-add-btn:hover{background-color:#3b82f6;border-color:#3b82f6;color:#fff}@media (prefers-color-scheme:dark){.calendar-add-btn{background-color:#374151;border-color:#4b5563;color:#9ca3af}.calendar-add-btn:hover{background-color:#3b82f6;border-color:#3b82f6;color:#fff}}.calendar-day-name{color:#111827;font-size:.75rem;font-weight:600;padding-right:1.75rem}@media (prefers-color-scheme:dark){.calendar-day-name{color:#f9fafb}}.calendar-day-total{background-color:#eff6ff;border-radius:.25rem;color:#3b82f6;font-size:.6875rem;font-weight:600;padding:.125rem .375rem;text-align:center}@media (prefers-color-scheme:dark){.calendar-day-total{background-color:#1e3a5f;color:#60a5fa}}.calendar-day-timers{flex:1 1;flex-direction:column;min-width:0;overflow-y:auto}.calendar-day-timers,.calendar-timer{display:flex;gap:.375rem;padding:.375rem}.calendar-timer{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.25rem;justify-content:space-between;position:relative;transition:all .2s}.calendar-timer:hover{background-color:#f3f4f6;border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.calendar-timer.ghost-timer{border-style:dashed}@media (prefers-color-scheme:dark){.calendar-timer{background-color:#111827;border-color:#374151}.calendar-timer:hover{background-color:#1f2937;border-color:#4b5563;box-shadow:0 1px 3px #0000004d}}.calendar-timer-content{flex:1 1;min-width:0}.calendar-timer-actions{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.125rem}.calendar-timer-time{color:#6b7280;font-family:Courier New,monospace;font-size:.6875rem;font-weight:600;margin-bottom:.125rem}@media (prefers-color-scheme:dark){.calendar-timer-time{color:#9ca3af}}.calendar-timer-description{color:#111827;font-size:.75rem;font-weight:500;margin-bottom:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme:dark){.calendar-timer-description{color:#f9fafb}}.calendar-timer-project{border:1px solid;border-radius:.25rem;display:block;font-size:.625rem;font-weight:500;margin-bottom:.125rem;max-width:100%;overflow:hidden;padding:.125rem .375rem;text-overflow:ellipsis;white-space:nowrap;width:max-content}.calendar-timer-duration{color:#3b82f6;font-family:Courier New,monospace;font-size:.6875rem;font-weight:600}@media (prefers-color-scheme:dark){.calendar-timer-duration{color:#60a5fa}}@media (max-width:1024px){.calendar-day{min-height:120px}.calendar-day-name{font-size:.6875rem}}@media (max-width:768px){.calendar-grid{gap:.375rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,14rem),1fr))}.calendar-day{min-height:100px}.calendar-day-header{padding:.25rem}.calendar-day-name{font-size:.625rem}.calendar-timer{padding:.25rem}.calendar-timer-duration,.calendar-timer-project,.calendar-timer-time{font-size:.625rem}.calendar-timer-description{font-size:.6875rem}}@media (max-width:900px){.timer-bar{padding:1rem 1rem .5rem}.timer-bar-content{align-items:stretch}.task-input-wrapper,.timer-controls{flex-basis:100%}.timer-controls{justify-content:space-between}.view-header{align-items:stretch}.view-toggle{justify-content:space-between;margin-left:0;width:100%}}@media (max-width:640px){.dashboard{--dashboard-horizontal-padding:1rem}.content-area{padding:1rem var(--dashboard-horizontal-padding)}.calendar-title{font-size:1rem}.week-nav{justify-content:space-between;width:100%}.calendar-nav-btn{flex:1 1 3rem;padding:.5rem .75rem}.calendar-nav-btn.today-btn{flex:1 1 5rem}}.timesheet-view{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:0}.timesheet-table{border:1px solid #e5e7eb;border-collapse:initial;border-radius:.5rem;border-spacing:0;font-size:.875rem;overflow:hidden;width:100%}.timesheet-table td,.timesheet-table th{border-bottom:1px solid #e5e7eb;padding:1rem;text-align:right;vertical-align:middle}.timesheet-table th{background-color:#f9fafb;color:#374151;font-size:.75rem;font-weight:600;letter-spacing:.05em;position:sticky;text-align:right;text-transform:uppercase;top:0;white-space:nowrap;z-index:10}.timesheet-table td:first-child,.timesheet-table th:first-child{padding-left:1.25rem;text-align:left!important}.timesheet-table td:last-child,.timesheet-table th:last-child{font-weight:600;padding-right:1.25rem}.timesheet-table tbody tr:last-child td{border-bottom:none}.timesheet-table tr:hover{background-color:#f9fafb}.timesheet-hours{color:#374151;font-weight:500;padding-right:1.5rem}.timesheet-hours,.timesheet-total{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-size:.875rem;text-align:right}.timesheet-total{color:#111827;font-weight:700}.timesheet-totals-row{background-color:#f9fafb;border-top:2px solid #d1d5db;font-weight:600}.timesheet-totals-row td{color:#111827;padding-bottom:1rem;padding-top:1rem}.timesheet-totals-row:hover{background-color:#f9fafb!important}.timesheet-grand-total{background-color:#eff6ff;border-left:3px solid #3b82f6;color:#1e40af;font-weight:700}.timesheet-project{border:1px solid;border-radius:.375rem;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.025em;padding:.25rem .5rem;width:fit-content}.timesheet-draggable-row{cursor:move;transition:background-color .15s ease}.timesheet-draggable-row:active{cursor:grabbing}.timesheet-draggable-row:hover{background-color:#f3f4f6!important}.timesheet-draggable-row.dragging{opacity:.4}.timesheet-draggable-row.drag-over-above{background-color:#eff6ff!important;border-top:3px solid #3b82f6}.timesheet-draggable-row.drag-over-below{background-color:#eff6ff!important;border-bottom:3px solid #3b82f6}@media (prefers-color-scheme:dark){.timesheet-view{background-color:#1f2937}.timesheet-table{border-color:#374151}.timesheet-table th{background-color:#374151;border-color:#4b5563;color:#e5e7eb}.timesheet-table td{border-color:#374151;color:#e5e7eb}.timesheet-hours{color:#d1d5db}.timesheet-total{color:#f3f4f6}.timesheet-table tr:hover{background-color:#374151}.timesheet-draggable-row:hover{background-color:#374151!important}.timesheet-draggable-row.drag-over-above{background-color:#1e3a5f!important;border-top:3px solid #60a5fa}.timesheet-draggable-row.drag-over-below{background-color:#1e3a5f!important;border-bottom:3px solid #60a5fa}.timesheet-totals-row{background-color:#374151;border-top-color:#6b7280}.timesheet-totals-row td{color:#f3f4f6}.timesheet-totals-row:hover{background-color:#374151!important}.timesheet-grand-total{background-color:#1e3a8a;border-left-color:#60a5fa;color:#93c5fd}}@media (max-width:768px){.timesheet-header{align-items:flex-start;flex-direction:column;gap:1rem}.timesheet-table{font-size:.75rem}.timesheet-table td,.timesheet-table th{padding:.5rem .25rem}.timesheet-view{padding:1rem}.timesheet-week-range{font-size:.875rem}}.dashboard{background:radial-gradient(circle at top left,#ffe8c7a6,#0000 24%),linear-gradient(180deg,#fffaf2d6,#f4f0e9f5)}.timer-bar{background:#0000;padding-top:1.25rem}.content-area,.timer-bar-content{width:min(1280px,100%)}.task-input{background:#ffffffe0;border-color:#1720331a;border-radius:1.1rem;box-shadow:0 16px 38px #17203314;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.task-input:focus{border-color:#2f5ec46b;box-shadow:0 16px 40px #1720331f,0 0 0 4px #2f5ec41f}.search-suggestions{background:#fffdf8f5;border-color:#17203314;border-radius:1rem;box-shadow:0 22px 48px #17203324;overflow:hidden}.search-suggestion-item{background:#0000;border:0;border-bottom:1px solid #17203314;transition:background-color .18s ease,color .18s ease;width:100%}.search-suggestion-item:focus-visible,.search-suggestion-item:hover{background:#2f5ec414}.timer-display{font-feature-settings:"tnum";background:#0000;border:0;font-variant-numeric:tabular-nums;letter-spacing:-.04em;padding:.35rem .5rem}.timer-display:disabled{opacity:1}.timer-display.clickable{border-radius:.9rem;transition:color .2s ease,background-color .2s ease}.timer-display.clickable:hover{background:#2f5ec414}.project-btn,.timer-btn{border-radius:1rem;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease}.project-btn:hover,.timer-btn:hover{box-shadow:0 14px 32px #17203324;transform:translateY(-1px)}.project-btn{background:#ffffffe0;border-color:#1720331a;color:#22304d}.project-name{min-width:0}.content-area{padding-top:1rem}.modal-overlay{overscroll-behavior:contain}@media (prefers-reduced-motion:reduce){.project-btn,.search-suggestion-item,.task-input,.timer-btn,.timer-display.clickable{transition:none}}@media (prefers-color-scheme:dark){.dashboard{background:radial-gradient(circle at top left,#1e40af38,#0000 28%),linear-gradient(180deg,#080f1dfa,#0f172a)}.task-input{background:#0f172ae0;border-color:#94a3b82e;box-shadow:0 20px 48px #02061752}.search-suggestions{background:#0f172af5;border-color:#94a3b829;box-shadow:0 22px 48px #0206176b}.search-suggestion-item{border-bottom-color:#94a3b81f}.search-suggestion-item:focus-visible,.search-suggestion-item:hover{background:#7dd3fc1f}.timer-display.clickable:hover{background:#7dd3fc1a}.project-btn{background:#0f172ae0;border-color:#94a3b82e;color:#e2e8f0}.project-btn:hover,.timer-btn:hover{box-shadow:0 14px 32px #02061757}}.support-page{background:radial-gradient(circle at top left,#ffedd0b8,#0000 24%),linear-gradient(180deg,#f7f3ea,#eef2f6);min-height:100vh}.support-shell{margin:0 auto;padding:2rem 0 4rem;width:min(960px,calc(100% - 2rem))}.support-hero{grid-gap:1.5rem;align-items:end;background:#fffdf8e0;border:1px solid #17203314;border-radius:2rem;box-shadow:0 24px 72px #1c23351a;display:grid;gap:1.5rem;grid-template-columns:minmax(0,1fr) auto;padding:2rem}.support-eyebrow{color:#5e6f86;font-size:.82rem;font-weight:800;letter-spacing:.16em;margin:0 0 .85rem;text-transform:uppercase}.support-hero h1{text-wrap:balance;font-size:clamp(2.4rem,5vw,4rem);letter-spacing:-.06em;line-height:.98;margin:0}.support-intro{color:var(--text-muted);line-height:1.7;margin:1rem 0 0;max-width:40rem}.support-primary-link{align-items:center;background:linear-gradient(135deg,#2459bd,#1b7ea2);border-radius:999px;box-shadow:0 14px 30px #2459bd33;color:#fff;display:inline-flex;font-weight:700;gap:.65rem;justify-content:center;min-height:3.25rem;padding:.9rem 1.25rem;text-decoration:none}.support-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1.5rem}.support-card{grid-gap:.9rem;align-content:start;background:#ffffffbd;border:1px solid #17203314;border-radius:1.6rem;display:grid;gap:.9rem;padding:1.5rem}.support-card h2{font-size:1.15rem;margin:0}.support-card li,.support-card p{color:var(--text-muted);line-height:1.65}.support-card ul{margin:0;padding-left:1.1rem}.support-card a{color:var(--accent-strong);font-weight:700;text-decoration:none}@media (prefers-color-scheme:dark){.support-page{background:radial-gradient(circle at top left,#4e73ab29,#0000 24%),linear-gradient(180deg,#0f172a,#111827)}.support-hero{background:#0f172ac7;border-color:#94a3b829;box-shadow:0 24px 72px #02061757}.support-eyebrow{color:#9fb5d8}.support-card h2,.support-card svg,.support-hero h1{color:#f8fafc}.support-card li,.support-card p,.support-intro{color:#cbd5e1}.support-card{background:#0f172aa3;border-color:#94a3b829}.support-card a{color:#93c5fd}}@media (max-width:860px){.support-grid,.support-hero{grid-template-columns:1fr}}@media (max-width:640px){.support-shell{padding-top:1.5rem;width:min(100%,calc(100% - 1.5rem))}.support-card,.support-hero{padding:1.25rem}}:root{--app-bg:#f5f1e8;--surface:#fffaf2e0;--surface-strong:#fffdf8;--surface-muted:#ffffffb3;--text:#172033;--text-muted:#546179;--accent:#2f5ec4;--accent-strong:#123c86;--accent-soft:#2f5ec424;--focus-ring:0 0 0 3px #2f5ec438;--border:#1720331a;--danger:#b42318;--shadow-lg:0 24px 80px #1c233529;color-scheme:light}*{box-sizing:border-box}html{background:radial-gradient(circle at top left,#ffe7c2e6,#0000 32%),radial-gradient(circle at top right,#b9e1ffb3,#0000 28%),linear-gradient(180deg,#f8f5ee,#f0ebe1);scroll-behavior:smooth}body,html{min-height:100%}.App{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Avenir Next,Segoe UI,Helvetica Neue,sans-serif;min-height:100vh}.App,.skip-link{color:#172033;color:var(--text)}.skip-link{background:#fffdf8;background:var(--surface-strong);border-radius:999px;box-shadow:0 24px 80px #1c233529;box-shadow:var(--shadow-lg);left:1rem;padding:.85rem 1rem;position:absolute;text-decoration:none;top:0;transform:translateY(-140%);z-index:200}.skip-link:focus-visible{transform:translateY(1rem)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.loading-state,.page-loading{color:#546179;color:var(--text-muted);display:grid;min-height:40vh;padding:2rem;place-items:center;text-align:center}.loading-state{gap:1rem}.loading-spinner{animation:spin .8s linear infinite;border:2px solid #54617938;border-radius:50%;border-top:2px solid var(--accent);height:1.25rem;width:1.25rem}@keyframes spin{to{transform:rotate(1turn)}}.error-boundary,.login-container{background:radial-gradient(circle at 15% 20%,#ffe7c2eb,#0000 24%),radial-gradient(circle at 80% 0,#b9e1ffb3,#0000 24%),linear-gradient(145deg,#f4ede0,#e9f1fb 52%,#eef5ef);display:grid;min-height:100vh;padding:2rem;place-items:center}.error-boundary-content,.login-box{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(180deg,#ffffffeb,#fffcf7d6);border:1px solid #1720331a;border:1px solid var(--border);border-radius:1.75rem;box-shadow:0 24px 80px #1c233529;box-shadow:var(--shadow-lg);padding:2.5rem;width:min(100%,460px)}.error-boundary-content h1,.login-box .app-name{text-wrap:balance;line-height:1;margin:0}.login-box .app-name{color:#123c86;color:var(--accent-strong);font-size:clamp(2.4rem,8vw,3.75rem);font-weight:800;letter-spacing:-.06em}.app-tagline{color:#546179;color:var(--text-muted);font-size:1rem;margin-top:.85rem}.login-section{grid-gap:.9rem;display:grid;gap:.9rem;margin-top:2rem}.btn-primary,.google-oauth-btn,.retry-btn{align-items:center;background:linear-gradient(135deg,#2459bd,#1b7ea2);border:1px solid #123c861f;border-radius:999px;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:700;gap:.75rem;justify-content:center;min-height:3.25rem;padding:.9rem 1.25rem;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.btn-primary:hover,.google-oauth-btn:hover,.retry-btn:hover{box-shadow:0 14px 30px #2459bd33;filter:saturate(1.05);transform:translateY(-1px)}.fallback-description,.oauth-description{color:#546179;color:var(--text-muted);font-size:.875rem;line-height:1.5;margin:0}.auth-status{grid-gap:.75rem;display:grid;gap:.75rem;text-align:center}.auth-status.success{color:#156f51}.auth-status.error{color:#b42318;color:var(--danger)}.error-message{background:#b4231814;border:1px solid #b4231824;border-radius:1rem;color:#8a1f17;margin-top:.5rem;padding:.9rem 1rem}.error-boundary-content{text-align:center;width:min(100%,640px)}.error-boundary-content h1{color:#b42318;color:var(--danger);font-size:clamp(2rem,6vw,3rem)}.error-boundary-content .error-message{margin-top:1rem}.error-details{background:#ffffffb3;background:var(--surface-muted);border:1px solid #1720331a;border:1px solid var(--border);border-radius:1rem;margin-top:1.5rem;padding:1rem;text-align:left}.error-details summary{color:#172033;color:var(--text);cursor:pointer;font-weight:700}.error-stack{background:#172033;border-radius:1rem;color:#eff6ff;font-size:.875rem;margin-top:1rem;overflow:auto;padding:1rem;white-space:pre-wrap}.error-actions{margin-top:1.75rem}:focus-visible{box-shadow:0 0 0 3px #2f5ec438;box-shadow:var(--focus-ring);outline:none}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.btn-primary,.google-oauth-btn,.loading-spinner,.retry-btn{animation:none;transition:none}}@media (prefers-color-scheme:dark){:root{--app-bg:#0f172a;--surface:#0f172ad1;--surface-strong:#111c31;--surface-muted:#0f172ab8;--text:#eff6ff;--text-muted:#b6c2d3;--accent:#7dd3fc;--accent-strong:#c7f1ff;--accent-soft:#7dd3fc33;--border:#94a3b829;--focus-ring:0 0 0 3px #7dd3fc3d;--shadow-lg:0 24px 80px #02061775;color-scheme:dark}html{background:radial-gradient(circle at top left,#1b4e866b,#0000 28%),radial-gradient(circle at top right,#1c7c7359,#0000 24%),linear-gradient(180deg,#09111f,#0f172a)}.error-boundary,.login-container{background:radial-gradient(circle at 15% 20%,#205bac3d,#0000 24%),radial-gradient(circle at 85% 0,#20a69738,#0000 24%),linear-gradient(145deg,#0b1220,#101b2f 52%,#102225)}.error-boundary-content,.login-box{background:linear-gradient(180deg,#0f172aeb,#111827d1)}.error-message{background:#b4231829;border-color:#fca5a529;color:#fecaca}.error-stack{background:#020617}}@media (max-width:640px){.error-boundary,.login-container{padding:1rem}.error-boundary-content,.login-box{padding:1.5rem}}