@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--color-canvas:#09090b;--color-surface-1:#18181b;--color-surface-2:#27272a;--color-surface-3:#3f3f46;--color-ink:#fafafa;--color-ink-muted:#a1a1aa;--color-ink-faint:#71717a;--color-accent:#2dd4bf;--color-accent-hover:#5eead4;--color-accent-subtle:#2dd4bf1f;--color-success:#34d399;--color-warning:#fbbf24;--color-danger:#f87171;--color-danger-hover:#ef4444;--color-stop:#f87171;--color-stop-hover:#ef4444;--color-hairline:#ffffff1a;--color-hairline-soft:#ffffff0d;--font-display:"Outfit", system-ui, -apple-system, sans-serif;--font-body:"Outfit", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-display-xl:56px;--text-display-lg:30px;--text-display-md:22px;--text-headline:20px;--text-subhead:17px;--text-body-lg:16px;--text-body:15px;--text-body-sm:14px;--text-caption:13px;--text-micro:11px;--space-hair:1px;--space-xxs:4px;--space-xs:8px;--space-sm:12px;--space-md:16px;--space-lg:20px;--space-xl:24px;--space-2xl:32px;--space-3xl:40px;--space-4xl:48px;--space-section:64px;--radius-xs:6px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-pill:100px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000001f, 0 1px 2px #00000014;--shadow-md:0 4px 16px -2px #0003;--shadow-lg:0 20px 40px -15px #0000004d;--shadow-focus:0 0 0 3px var(--color-accent-subtle);--transition-fast:.12s cubic-bezier(.16, 1, .3, 1);--transition-base:.2s cubic-bezier(.16, 1, .3, 1);--transition-slow:.35s cubic-bezier(.16, 1, .3, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width:240px;--topbar-height:56px}[data-theme=light]{--color-canvas:#fafafa;--color-surface-1:#fff;--color-surface-2:#f4f4f5;--color-surface-3:#e4e4e7;--color-ink:#18181b;--color-ink-muted:#52525b;--color-ink-faint:#a1a1aa;--color-accent:#0d9488;--color-accent-hover:#0f766e;--color-accent-subtle:#0d948814;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-stop:#dc2626;--color-stop-hover:#b91c1c;--color-hairline:#00000014;--color-hairline-soft:#0000000a;--shadow-sm:0 1px 3px #0000000a, 0 1px 2px #00000008;--shadow-md:0 4px 16px -2px #0000000f;--shadow-lg:0 20px 40px -15px #00000014;--shadow-focus:0 0 0 3px var(--color-accent-subtle)}[data-theme=light] .modal{box-shadow:var(--shadow-lg), inset 0 1px 0 #fffc;background:#ffffffd1;border-color:#0000000f}[data-theme=light] .timer-bar:focus-within{box-shadow:0 0 20px -4px #0d94881f, var(--shadow-focus)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px}body{font-family:var(--font-body);color:var(--color-ink);background-color:var(--color-canvas);min-height:100vh;font-weight:400;line-height:1.5;overflow-x:hidden}#root{min-height:100vh;display:flex}a{color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-accent-hover)}img,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit;background:0 0;border:none;outline:none}button{cursor:pointer;-webkit-user-select:none;user-select:none}::selection{background:var(--color-accent-subtle);color:var(--color-ink)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:var(--radius-pill)}::-webkit-scrollbar-thumb:hover{background:var(--color-ink-faint)}.text-display-xl{font-family:var(--font-display);font-size:var(--text-display-xl);letter-spacing:-3.1px;font-weight:600;line-height:1}.text-display-lg{font-family:var(--font-display);font-size:var(--text-display-lg);letter-spacing:-1px;font-weight:600;line-height:1.13}.text-display-md{font-family:var(--font-display);font-size:var(--text-display-md);letter-spacing:-.5px;font-weight:600;line-height:1.2}.text-headline{font-family:var(--font-display);font-size:var(--text-headline);letter-spacing:-.8px;font-weight:700;line-height:1.2}.text-body-lg{font-size:var(--text-body-lg);letter-spacing:-.16px;line-height:1.5}.text-body{font-size:var(--text-body);letter-spacing:-.15px;line-height:1.5}.text-body-sm{font-size:var(--text-body-sm);letter-spacing:-.14px;font-weight:500;line-height:1.4}.text-caption{font-size:var(--text-caption);letter-spacing:-.13px;color:var(--color-ink-muted);font-weight:500;line-height:1.2}.text-micro{font-size:var(--text-micro);letter-spacing:-.12px;color:var(--color-ink-muted);line-height:1.2}.text-muted{color:var(--color-ink-muted)}.text-accent{color:var(--color-accent)}.btn{justify-content:center;align-items:center;gap:var(--space-xs);font-size:var(--text-body-sm);letter-spacing:-.14px;border-radius:var(--radius-pill);transition:all var(--transition-base);white-space:nowrap;padding:10px 20px;font-weight:500;line-height:1;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)scale(.97)}.btn-primary{background:var(--color-ink);color:var(--color-canvas)}.btn-primary:hover{background:#e5e5e5}.btn-secondary{background:var(--color-surface-1);color:var(--color-ink)}.btn-secondary:hover{background:var(--color-surface-2)}.btn-accent{background:var(--color-accent);color:var(--color-ink)}.btn-accent:hover{background:var(--color-accent-hover)}.btn-danger{background:var(--color-danger);color:var(--color-ink)}.btn-danger:hover{background:var(--color-danger-hover)}.btn-stop{background:var(--color-stop);color:var(--color-ink)}.btn-stop:hover{background:var(--color-stop-hover)}.btn-ghost{color:var(--color-ink-muted);background:0 0}.btn-ghost:hover{background:var(--color-surface-1);color:var(--color-ink)}.btn-sm{font-size:var(--text-caption);padding:6px 14px}.btn-lg{font-size:var(--text-body);padding:14px 28px}.btn-icon{border-radius:var(--radius-full);width:40px;height:40px;padding:0}.btn-icon-sm{border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--text-body-sm);padding:0}.input{background:var(--color-surface-1);width:100%;color:var(--color-ink);font-size:var(--text-body);border-radius:var(--radius-md);transition:all var(--transition-base);border:1px solid #0000;padding:12px 16px}.input::placeholder{color:var(--color-ink-faint)}.input:focus{border-color:var(--color-accent);box-shadow:var(--shadow-focus)}.input-lg{font-size:var(--text-body-lg);border-radius:var(--radius-lg);padding:16px 20px}.label{font-size:var(--text-caption);color:var(--color-ink-muted);margin-bottom:var(--space-xxs);font-weight:500;display:block}.card{background:var(--color-surface-1);border-radius:var(--radius-xl);padding:var(--space-xl);border:1px solid var(--color-hairline-soft)}.card-sm{padding:var(--space-md);border-radius:var(--radius-lg)}.card-interactive{transition:all var(--transition-base);cursor:pointer}.card-interactive:hover{background:var(--color-surface-2);border-color:var(--color-hairline)}.divider{background:var(--color-hairline-soft);height:1px;margin:var(--space-lg) 0;border:none}.chip{align-items:center;gap:var(--space-xxs);font-size:var(--text-micro);border-radius:var(--radius-pill);background:var(--color-surface-2);color:var(--color-ink-muted);white-space:nowrap;padding:4px 10px;font-weight:500;display:inline-flex}.project-dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.timer-display{font-family:var(--font-mono);letter-spacing:-.5px;font-variant-numeric:tabular-nums;color:var(--color-ink);font-size:28px;font-weight:600}.timer-display-lg{letter-spacing:-1px;font-size:48px}.sidebar{width:var(--sidebar-width);background:var(--color-surface-1);border-right:1px solid var(--color-hairline-soft);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{padding:var(--space-xl) var(--space-lg);font-family:var(--font-display);font-size:var(--text-display-md);letter-spacing:-1px;color:var(--color-ink);font-weight:700}.sidebar-logo span{background:linear-gradient(135deg, var(--color-accent), #a78bfa, var(--color-accent));-webkit-text-fill-color:transparent;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;animation:4s ease-in-out infinite logoGradient}@keyframes logoGradient{0%,to{background-position:0%}50%{background-position:100%}}.sidebar-nav{padding:0 var(--space-sm);flex:1}.sidebar-section{margin-bottom:var(--space-lg)}.sidebar-section-title{font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.5px;color:var(--color-ink-faint);padding:var(--space-sm) var(--space-sm);margin-bottom:var(--space-xxs);font-weight:600}.nav-item{align-items:center;gap:var(--space-sm);padding:10px var(--space-sm);border-radius:var(--radius-md);font-size:var(--text-body-sm);color:var(--color-ink-muted);transition:all var(--transition-fast);width:100%;text-decoration:none;display:flex}.nav-item:hover{background:var(--color-surface-2);color:var(--color-ink)}.nav-item.active{background:var(--color-accent-subtle);color:var(--color-accent);position:relative}.nav-item.active:before{content:"";border-radius:var(--radius-pill);background:var(--color-accent);width:3px;position:absolute;top:6px;bottom:6px;left:-4px}.nav-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:18px;display:flex}.topbar{height:var(--topbar-height);background:var(--color-canvas);border-bottom:1px solid var(--color-hairline-soft);padding:0 var(--space-xl);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-timer{align-items:center;gap:var(--space-md);display:flex}.topbar-user{align-items:center;gap:var(--space-sm);display:flex}.topbar-avatar{border-radius:var(--radius-full);background:var(--color-surface-2);width:32px;height:32px;font-size:var(--text-caption);color:var(--color-ink-muted);justify-content:center;align-items:center;font-weight:600;display:flex}.topbar-active-entry{align-items:center;gap:var(--space-sm);max-width:400px;display:flex}.topbar-project{align-items:center;gap:var(--space-xxs);font-size:var(--text-caption);white-space:nowrap;font-weight:500;display:flex}.topbar-desc{font-size:var(--text-body-sm);color:var(--color-ink);white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden}.topbar-billable-badge{font-size:var(--text-micro);color:var(--color-success);border-radius:var(--radius-full);background:#34d39926;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-weight:700;display:flex}.topbar-timer-display{color:var(--color-ink)!important;font-size:18px!important}.app-layout{width:100%;min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-content{padding:var(--space-2xl);flex:1;width:100%;max-width:1200px}.timer-bar{background:var(--color-surface-1);border-radius:var(--radius-xl);padding:var(--space-md) var(--space-lg);align-items:center;gap:var(--space-md);border:1px solid var(--color-hairline-soft);transition:border-color var(--transition-base), box-shadow var(--transition-base);display:flex}.timer-bar:hover{border-color:var(--color-hairline);box-shadow:0 0 0 1px var(--color-hairline-soft), var(--shadow-md)}.timer-bar:focus-within{border-color:var(--color-accent);box-shadow:0 0 20px -4px #2dd4bf26, var(--shadow-focus)}.timer-bar-input{font-size:var(--text-body);color:var(--color-ink);background:0 0;border:none;outline:none;flex:1}.timer-bar-input::placeholder{color:var(--color-ink-faint)}.timer-bar-actions{align-items:center;gap:var(--space-xs);display:flex}.entry-row{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.entry-row:hover{background:var(--color-surface-1)}.entry-row-desc{flex:1;min-width:0}.entry-row-desc-text{font-size:var(--text-body);color:var(--color-ink);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.entry-row-project{font-size:var(--text-caption);color:var(--color-ink-muted);align-items:center;gap:var(--space-xxs);display:flex}.entry-row-duration{font-family:var(--font-mono);font-size:var(--text-body-sm);font-variant-numeric:tabular-nums;color:var(--color-ink);white-space:nowrap}.entry-row-time{font-size:var(--text-caption);color:var(--color-ink-faint);white-space:nowrap}.entry-row-actions{gap:var(--space-xxs);opacity:0;transition:opacity var(--transition-fast);display:flex}.entry-row:hover .entry-row-actions{opacity:1}.date-group{margin-bottom:var(--space-2xl)}.date-group-header{padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-xs);justify-content:space-between;align-items:center;display:flex}.date-group-title{font-size:var(--text-body-sm);color:var(--color-ink);font-weight:600}.date-group-total{font-family:var(--font-mono);font-size:var(--text-body-sm);color:var(--color-ink-muted);font-variant-numeric:tabular-nums}.login-page{background:var(--color-canvas);width:100%;min-height:100vh;padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface-1);border-radius:var(--radius-xl);width:100%;max-width:440px;padding:var(--space-3xl);border:1px solid var(--color-hairline-soft);box-shadow:var(--shadow-lg)}.login-logo{font-family:var(--font-display);font-size:var(--text-display-lg);letter-spacing:-1px;margin-bottom:var(--space-2xl);text-align:center;font-weight:700}.login-logo span{color:var(--color-accent)}.login-title{font-size:var(--text-headline);margin-bottom:var(--space-xxs);text-align:center;font-weight:600}.login-subtitle{font-size:var(--text-body);color:var(--color-ink-muted);text-align:center;margin-bottom:var(--space-2xl)}.login-form{gap:var(--space-md);flex-direction:column;display:flex}.login-form-group{flex-direction:column;display:flex}.login-divider{align-items:center;gap:var(--space-md);margin:var(--space-lg) 0;color:var(--color-ink-faint);font-size:var(--text-caption);display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-hairline);flex:1;height:1px}.login-oauth{gap:var(--space-sm);display:flex}.login-oauth .btn{flex:1}.login-footer{text-align:center;margin-top:var(--space-xl);font-size:var(--text-body-sm);color:var(--color-ink-muted)}.login-error{color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--text-body-sm);text-align:center;background:#ef44441a}.login-card .input{background:var(--color-surface-2)}.empty-state{padding:var(--space-4xl) var(--space-xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-xl);background:var(--color-surface-2);width:72px;height:72px;margin-bottom:var(--space-lg);color:var(--color-ink-faint);justify-content:center;align-items:center;animation:3s ease-in-out infinite floatIdle;display:flex}.empty-state-title{font-size:var(--text-body-lg);margin-bottom:var(--space-xs);font-weight:600}.empty-state-text{font-size:var(--text-body);color:var(--color-ink-muted);max-width:360px;line-height:1.6}.dropdown{display:inline-block;position:relative}.dropdown-menu{margin-top:var(--space-xxs);background:var(--color-surface-2);border:1px solid var(--color-hairline);border-radius:var(--radius-lg);padding:var(--space-xs);min-width:200px;box-shadow:var(--shadow-lg);z-index:200;max-height:300px;position:absolute;top:100%;left:0;overflow-y:auto}.dropdown-item{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-body-sm);color:var(--color-ink);cursor:pointer;transition:background var(--transition-fast);display:flex}.dropdown-item:hover{background:var(--color-surface-3)}.spinner{border:2px solid var(--color-surface-2);border-top-color:var(--color-accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{background:var(--color-canvas);justify-content:center;align-items:center;min-height:100vh;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-slow) cubic-bezier(.16, 1, .3, 1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIdle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes slideInRight{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:2s ease-in-out infinite pulse}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stagger-in>*{animation:.4s cubic-bezier(.16,1,.3,1) both fadeInUp}.stagger-in>:first-child{animation-delay:0s}.stagger-in>:nth-child(2){animation-delay:50ms}.stagger-in>:nth-child(3){animation-delay:.1s}.stagger-in>:nth-child(4){animation-delay:.15s}.stagger-in>:nth-child(5){animation-delay:.2s}.stagger-in>:nth-child(6){animation-delay:.25s}.stagger-in>:nth-child(7){animation-delay:.3s}.stagger-in>:nth-child(8){animation-delay:.35s}.stagger-in>:nth-child(n+9){animation-delay:.4s}.page-content{animation:.4s cubic-bezier(.16,1,.3,1) both fadeInUp}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-surface-2) 25%, var(--color-surface-3) 50%, var(--color-surface-2) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.8s ease-in-out infinite shimmer}.skeleton-text{width:60%;height:14px;margin-bottom:var(--space-xs)}.skeleton-text-sm{width:40%;height:10px}.skeleton-block{border-radius:var(--radius-lg);width:100%;height:120px}.skeleton-circle{border-radius:var(--radius-full);width:48px;height:48px}.projects-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;background:#0009;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);padding:var(--space-2xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg), inset 0 1px 0 #ffffff0f;-webkit-backdrop-filter:blur(24px)saturate(1.4);background:#18181bd9;border:1px solid #ffffff14;animation:.25s cubic-bezier(.16,1,.3,1) both scaleIn}.modal-title{font-size:var(--text-headline);margin-bottom:var(--space-lg);font-weight:600}.modal-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xl);display:flex}.color-picker{gap:var(--space-xs);flex-wrap:wrap;display:flex}.color-swatch{border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;transition:all var(--transition-fast);border:2px solid #0000}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--color-ink);box-shadow:0 0 0 2px var(--color-canvas)}.tags-list{gap:var(--space-xs);flex-direction:column;display:flex}.tag-list-item{background:var(--color-surface-1);border:1px solid var(--color-hairline-soft);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);cursor:pointer;transition:all var(--transition-base);justify-content:space-between;align-items:center;display:flex}.tag-list-item:hover{background:var(--color-surface-2);border-color:var(--color-hairline)}.tag-chip{align-items:center;gap:var(--space-xxs);font-size:var(--text-caption);border-radius:var(--radius-pill);white-space:nowrap;border:1px solid;padding:3px 10px;font-weight:500;display:inline-flex}.tag-picker-count{background:var(--color-accent);color:var(--color-ink-inverse);border-radius:var(--radius-full);justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:inline-flex}.tag-picker-chips{gap:var(--space-xxs);margin-top:var(--space-xxs);flex-wrap:wrap;display:flex}.calendar-wrapper{background:var(--color-surface-1);border-radius:var(--radius-xl);border:1px solid var(--color-hairline-soft);overflow:hidden}.calendar-header{border-bottom:1px solid var(--color-hairline-soft);grid-template-columns:60px repeat(7,1fr);display:grid}.calendar-time-gutter{flex-shrink:0;width:60px}.calendar-day-header{padding:var(--space-sm) var(--space-xs);border-left:1px solid var(--color-hairline-soft);flex-direction:column;align-items:center;gap:2px;display:flex}.calendar-day-header.is-today{background:var(--color-accent-subtle)}.calendar-day-name{font-size:var(--text-micro);color:var(--color-ink-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.calendar-day-number{font-size:var(--text-body-lg);font-weight:600}.calendar-day-number.today{background:var(--color-accent);color:var(--color-ink);border-radius:var(--radius-full);justify-content:center;align-items:center;width:28px;height:28px;display:flex}.calendar-day-total{font-size:var(--text-micro);color:var(--color-ink-faint);font-family:var(--font-mono)}.calendar-body{grid-template-columns:60px repeat(7,1fr);max-height:600px;display:grid;position:relative;overflow-y:auto}.calendar-hour-label{padding:0 var(--space-xs) 0 0;font-size:var(--text-micro);color:var(--color-ink-faint);justify-content:flex-end;align-items:flex-start;display:flex;position:relative;top:-6px}.calendar-day-column{border-left:1px solid var(--color-hairline-soft);min-height:1080px;position:relative}.calendar-day-column.is-today{background:var(--color-accent-subtle)}.calendar-hour-line{background:var(--color-hairline-soft);height:1px;position:absolute;left:0;right:0}.calendar-block{border-radius:var(--radius-sm);font-size:var(--text-micro);cursor:pointer;transition:opacity var(--transition-fast);z-index:1;padding:4px 6px;position:absolute;left:4px;right:4px;overflow:hidden}.calendar-block:hover{opacity:.85}.calendar-block-desc{color:var(--color-ink);white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.calendar-block-project{color:var(--color-ink-muted);margin-top:1px;font-size:10px}.calendar-block-resize{cursor:ns-resize;border-radius:0 0 var(--radius-sm) var(--radius-sm);height:6px;position:absolute;bottom:0;left:0;right:0}.calendar-block-resize:hover{background:#ffffff26}.calendar-block-resize-top{cursor:ns-resize;border-radius:var(--radius-sm) var(--radius-sm) 0 0;height:6px;position:absolute;top:0;left:0;right:0}.calendar-block-resize-top:hover{background:#ffffff26}.time-edit-row{align-items:center;gap:var(--space-sm);display:flex}.time-input{background:var(--color-surface-2);border:1px solid var(--color-hairline);border-radius:var(--radius-md);color:var(--color-ink);font-family:var(--font-mono);font-size:var(--text-body-sm);width:130px;transition:border-color var(--transition-fast);padding:8px 12px}.time-input:focus{border-color:var(--color-accent);box-shadow:var(--shadow-focus);outline:none}.time-edit-separator{color:var(--color-ink-faint);font-size:var(--text-body-sm)}.timesheet-wrapper{background:var(--color-surface-1);border-radius:var(--radius-xl);border:1px solid var(--color-hairline-soft);overflow-x:auto}.timesheet-table{border-collapse:collapse;width:100%;font-size:var(--text-body-sm)}.timesheet-table th,.timesheet-table td{padding:var(--space-sm) var(--space-md);text-align:center;border-bottom:1px solid var(--color-hairline-soft)}.timesheet-table th{font-weight:600;font-size:var(--text-caption);color:var(--color-ink-muted);background:var(--color-surface-2)}.timesheet-project-col{min-width:180px;text-align:left!important}.timesheet-day-col{min-width:80px}.timesheet-total-col{min-width:80px;font-weight:600!important}.timesheet-project-name{align-items:center;gap:var(--space-sm);display:flex}.timesheet-day-name{font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.3px}.timesheet-day-date{font-size:var(--text-micro);color:var(--color-ink-faint)}.timesheet-cell{position:relative}.timesheet-cell.has-value{background:var(--color-accent-subtle)}.timesheet-cell-value{font-family:var(--font-mono);font-size:var(--text-body-sm);color:var(--color-ink-muted)}.timesheet-cell.has-value .timesheet-cell-value{color:var(--color-ink)}.timesheet-total-cell{font-family:var(--font-mono);color:var(--color-ink);font-weight:600}.timesheet-grand-total{background:var(--color-accent-subtle);color:var(--color-accent)!important}.pomodoro-container{align-items:center;gap:var(--space-xl);flex-direction:column;max-width:400px;margin:0 auto;display:flex}.pomodoro-phases{gap:var(--space-xs);background:var(--color-surface-1);border-radius:var(--radius-pill);border:1px solid var(--color-hairline-soft);padding:4px;display:flex}.pomodoro-phase-tab{border-radius:var(--radius-pill);font-size:var(--text-caption);color:var(--color-ink-muted);cursor:default;transition:all var(--transition-fast);background:0 0;border:none;padding:8px 16px;font-weight:500}.pomodoro-phase-tab.active{background:var(--color-surface-2);color:var(--color-ink)}.pomodoro-timer-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.pomodoro-timer-center{align-items:center;gap:var(--space-xs);flex-direction:column;display:flex;position:absolute}.pomodoro-time{font-family:var(--font-mono);letter-spacing:-1px;font-variant-numeric:tabular-nums;font-size:52px;font-weight:600}.pomodoro-phase-label{font-size:var(--text-caption);text-transform:uppercase;letter-spacing:1px;font-weight:500}.pomodoro-controls{align-items:center;gap:var(--space-sm);display:flex}.pomodoro-stats{gap:var(--space-2xl);margin-top:var(--space-lg);display:flex}.pomodoro-stat{align-items:center;gap:var(--space-xxs);flex-direction:column;display:flex}.pomodoro-stat-value{font-family:var(--font-mono);font-size:var(--text-body-lg);font-weight:600}.pomodoro-stat-label{font-size:var(--text-micro);color:var(--color-ink-faint)}.reports-summary{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.reports-card{background:var(--color-surface-1);border:1px solid var(--color-hairline-soft);border-radius:var(--radius-xl);padding:var(--space-lg);align-items:center;gap:var(--space-md);display:flex}.reports-card-icon{border-radius:var(--radius-lg);background:var(--color-surface-2);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.reports-card-value{font-family:var(--font-mono);font-size:var(--text-body-lg);font-variant-numeric:tabular-nums;font-weight:600}.reports-card-label{font-size:var(--text-caption);color:var(--color-ink-muted)}.reports-charts{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.reports-charts{grid-template-columns:1fr}}.reports-table{border-collapse:collapse;width:100%;font-size:var(--text-body-sm)}.reports-table th{text-align:left;padding:var(--space-sm) var(--space-md);font-weight:600;font-size:var(--text-caption);color:var(--color-ink-muted);border-bottom:1px solid var(--color-hairline)}.reports-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-hairline-soft)}.reports-table tr:hover td{background:var(--color-surface-1)}.settings-section{background:var(--color-surface-1);border:1px solid var(--color-hairline-soft);border-radius:var(--radius-xl);margin-bottom:var(--space-lg);overflow:hidden}.settings-section-header{align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--color-hairline-soft);color:var(--color-ink-muted);display:flex}.settings-section-body{padding:var(--space-xl);gap:var(--space-md);flex-direction:column;display:flex}.settings-danger{border-color:#ef44444d}.settings-danger .settings-section-header{color:var(--color-danger);border-bottom-color:#ef444433}.filter-bar{align-items:flex-end;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface-1);border-radius:var(--radius-xl);border:1px solid var(--color-hairline-soft);margin-bottom:var(--space-lg);flex-wrap:wrap;display:flex}.bulk-actions-bar{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:var(--color-accent-subtle);border:1px solid var(--color-accent);border-radius:var(--radius-xl);margin-bottom:var(--space-md);display:flex}.list-checkbox{appearance:none;border:2px solid var(--color-surface-3);border-radius:var(--radius-xs);cursor:pointer;width:18px;height:18px;transition:all var(--transition-fast);flex-shrink:0;position:relative}.list-checkbox:checked{background:var(--color-accent);border-color:var(--color-accent)}.list-checkbox:checked:after{content:"✓";color:var(--color-ink);font-size:12px;font-weight:700;position:absolute;top:-1px;left:2px}.entry-row.selected{background:var(--color-accent-subtle)}.data-table{border-collapse:collapse;width:100%;font-size:var(--text-body-sm)}.data-table th{padding:var(--space-sm) var(--space-md);text-align:left;font-size:var(--text-caption);color:var(--color-ink-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-hairline);background:var(--color-surface-2);font-weight:600}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-hairline-soft);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-surface-2)}.invoice-status-badge{font-size:var(--text-micro);text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-pill);border:1px solid;align-items:center;padding:2px 10px;font-weight:600;display:inline-flex}.btn-icon-sm{border-radius:var(--radius-md);justify-content:center;align-items:center;width:28px;min-width:28px;height:28px;padding:0;display:inline-flex}.topbar-hamburger{width:36px;height:36px;color:var(--color-ink);cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:none}.topbar-hamburger:hover{background:var(--color-surface-2)}.sidebar-backdrop{display:none}@media (width<=768px){.topbar-hamburger{display:flex}.sidebar{z-index:1000;width:280px;box-shadow:none;transition:left .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;left:-280px}.sidebar.sidebar-open{box-shadow:var(--shadow-lg);left:0}.sidebar-backdrop{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.sidebar-backdrop.visible{display:block}.app-layout{grid-template-columns:1fr}.main-content{margin-left:0}.topbar{padding:0 var(--space-sm);gap:var(--space-xs)}.topbar-timer{gap:var(--space-xs)}.topbar-active-entry{display:none}.topbar-timer-display{font-size:var(--text-body-sm)!important}.page-content{padding:var(--space-md)}.reports-summary{grid-template-columns:1fr 1fr}.reports-charts{grid-template-columns:1fr}.reports-table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.settings-section-body{grid-template-columns:1fr!important}.calendar-grid{-webkit-overflow-scrolling:touch;overflow-x:auto}.calendar-grid>div:last-child{min-width:600px}.modal-content,.modal-body{max-height:85vh;width:92vw!important;min-width:0!important;max-width:92vw!important}.text-display-md{font-size:var(--text-headline)!important}.text-display-lg{font-size:var(--text-display-md)!important}.timer-controls{gap:var(--space-sm);flex-direction:column}.timesheet-grid{-webkit-overflow-scrolling:touch;overflow-x:auto}.timesheet-grid table{min-width:600px}.project-grid{grid-template-columns:1fr!important}.bulk-bar{left:var(--space-md)!important;right:var(--space-md)!important;width:auto!important;transform:none!important}}@media (width<=480px){.reports-summary{grid-template-columns:1fr}.page-content{padding:var(--space-sm)}.topbar-user{gap:var(--space-xxs)}}
