*,: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}.top-bar{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(180deg,#f8f6eff5,#f8f6efe6);border-bottom:1px solid #1f293714;position:-webkit-sticky;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,.hamburger-btn,.logout-btn{align-items:center;background:#ffffffb8;border:1px solid #1f29371f;color:#32415f;cursor:pointer;display:inline-flex;justify-content:center;transition:color .2s ease,background-color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}.hamburger-btn,.logout-btn{border-radius:999px;height:2.75rem;width:2.75rem}.avatar-button:hover,.hamburger-btn:hover,.logout-btn:hover{background:#fffffff2;border-color:#2b4ca047;color:#172033;transform:translateY(-1px)}.user-section{align-items:center;display:flex;gap:.75rem}.avatar-button{border-radius:999px;height:2.75rem;overflow:hidden;padding:.125rem;width:2.75rem}.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;height:100%;width:100%}.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-backdrop{background:#0a0e1957;border:0;inset:0;position:fixed;z-index:109}.nav-menu{background:linear-gradient(180deg,#fffaf2fa,#f6f6f1f5);border:1px solid #1f29371a;border-radius:1.5rem;box-shadow:0 28px 80px #0f172a29;left:50%;position:fixed;top:5.5rem;transform:translateX(-50%);width:min(720px,calc(100vw - 2rem));z-index:110}.nav-menu-content{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:1rem}.nav-item{align-items:center;background:#fffc;border:1px solid #0000;border-radius:1rem;color:#334155;display:flex;gap:.75rem;min-width:0;padding:.9rem 1rem;text-decoration:none;transition:background-color .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.nav-item:hover{background:#fffffffa;border-color:#2f5ec42e;color:#172033;transform:translateY(-1px)}.nav-item.active{background:linear-gradient(135deg,#b9e1ffdb,#faf0d6f5);border-color:#2f5ec433;color:#12305a}@media (prefers-reduced-motion:reduce){.avatar-button,.hamburger-btn,.logout-btn,.nav-item{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,.hamburger-btn,.logout-btn{background:#1e293bcc;border-color:#94a3b833;color:#e2e8f0}.avatar-button:hover,.hamburger-btn:hover,.logout-btn:hover{background:#1e293bf5;border-color:#7dd3fc52;color:#fff}.nav-menu{background:linear-gradient(180deg,#0f172afa,#111827f5);border-color:#94a3b829;box-shadow:0 28px 80px #0206177a}.nav-item{background:#1e293bc7;color:#dbe4f0}.nav-item:hover{background:#243552f2;border-color:#7dd3fc3d;color:#fff}.nav-item.active{background:linear-gradient(135deg,#193c6eeb,#1c7c73db);border-color:#7dd3fc4d;color:#f8fafc}}@media (max-width:768px){.top-bar-content{padding:.85rem 1rem}.nav-menu{top:5rem;width:calc(100vw - 1rem)}.nav-menu-content{grid-template-columns:1fr}}@media print{.nav-backdrop,.nav-menu,.top-bar{display:none!important}}.dashboard{background-color:#fff;min-height:100vh}@media (prefers-color-scheme:dark){.dashboard{background-color:#111827}}.timer-bar{background-color:#fff;padding:1.5rem 2rem;width:100%}@media (prefers-color-scheme:dark){.timer-bar{background-color:#111827}}.timer-bar-content{align-items:center;display:flex;gap:1.5rem;justify-content:space-between;margin:0 auto;max-width:1280px}.task-input-wrapper{display:flex;flex:1 1;justify-content:center;position:relative}.task-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;color:#111827;font-size:1.125rem;max-width:48rem;outline:none;padding:1rem 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:50%;margin-top:.5rem;max-height:300px;max-width:48rem;overflow-y:auto;position:absolute;top:100%;transform:translateX(-50%);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:center;display:flex;flex-shrink:0;gap:1rem}.timer-display{color:#111827;font-family:Courier New,monospace;font-size:1.875rem;font-weight:700;min-width:140px;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:64px;justify-content:center;padding:1rem;transition:all .2s;width:64px}.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;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:1280px;padding:2rem}@media (prefers-color-scheme:dark){.content-area{color:#9ca3af}}.view-header{align-items:center;display:flex;gap:1rem;justify-content:flex-end;margin-bottom:.75rem;min-height:2rem}.view-toggle{background-color:#f3f4f6;border-radius:.5rem;padding:.25rem}.view-toggle,.week-nav{align-items:center;display:flex;gap:.25rem}.week-nav{margin-left:auto}@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:-webkit-fit-content;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:-webkit-fit-content;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}.calendar-title{color:#111827;font-size:1.125rem;font-weight:600;margin: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;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr);grid-template-columns:repeat(var(--calendar-columns,5),1fr)}.calendar-day{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;flex-direction:column;font-size:.8125rem;min-height:150px}.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;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}@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;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;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;font-size:.625rem;font-weight:500;margin-bottom:.125rem;overflow:hidden;padding:.125rem .375rem;text-overflow:ellipsis;white-space:nowrap;width:-webkit-fit-content;width:fit-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:.25rem;grid-template-columns:repeat(5,minmax(100px,1fr));grid-template-columns:repeat(var(--calendar-columns,5),minmax(100px,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}}.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:-webkit-sticky;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:-webkit-fit-content;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}}: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}}