@import"https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap";:root{--bg: #faf8f3;--paper: #faf8f3;--paper-2: #f3f0e8;--paper-3: #ebe8df;--ink: #1a1814;--ink-2: #4a463e;--ink-3: #807a6e;--ink-4: #b3ad9f;--line: #d9d4c5;--line-soft: #e7e3d6;--accent: oklch(56% .13 28);--accent-fg: #faf8f3;--accent-soft: oklch(94% .04 28);--success: oklch(60% .1 150);--warning: oklch(70% .12 75);--danger: oklch(58% .16 22);--c1: oklch(64% .14 25);--c2: oklch(64% .14 75);--c3: oklch(64% .14 145);--c4: oklch(64% .14 200);--c5: oklch(64% .14 250);--c6: oklch(64% .14 300);--c7: oklch(64% .14 340);--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-pill: 999px;--shadow-rgb: 26, 24, 20;--shadow-1: 0 1px 2px rgba(var(--shadow-rgb), .04), 0 1px 1px rgba(var(--shadow-rgb), .03);--shadow-2: 0 4px 12px -4px rgba(var(--shadow-rgb), .08), 0 2px 4px rgba(var(--shadow-rgb), .04);--shadow-3: 0 16px 40px -12px rgba(var(--shadow-rgb), .18), 0 4px 8px rgba(var(--shadow-rgb), .06);--shadow-4: 0 24px 60px -16px rgba(var(--shadow-rgb), .22), 0 6px 12px rgba(var(--shadow-rgb), .08);--inverse: #1a1814;--inverse-2: #2a2520;--inverse-fg: #faf8f3;--font-sans: "Geist", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono: "Geist Mono", "JetBrains Mono", ui-monospace, monospace;--font-display: "Geist", system-ui, sans-serif}[data-theme=dark]{--bg: #3a322b;--paper: #23211e;--paper-2: #2c2925;--paper-3: #36322d;--ink: #f5f0e4;--ink-2: #d4cdbd;--ink-3: #a39a8a;--ink-4: #6e6557;--line: #4a4036;--line-soft: #383127;--accent: oklch(72% .13 32);--accent-fg: #1a1714;--accent-soft: oklch(38% .07 28);--success: oklch(72% .11 150);--warning: oklch(78% .13 75);--danger: oklch(70% .16 22);--c1: oklch(72% .13 25);--c2: oklch(74% .13 75);--c3: oklch(72% .13 145);--c4: oklch(72% .12 200);--c5: oklch(72% .12 250);--c6: oklch(72% .13 300);--c7: oklch(72% .13 340);--shadow-rgb: 0, 0, 0;--inverse: #f5f0e4;--inverse-2: #d4cdbd;--inverse-fg: #1a1714}[data-theme=system]{color-scheme:light dark}@media(prefers-color-scheme:dark){[data-theme=system]{--bg: #3a322b;--paper: #23211e;--paper-2: #2c2925;--paper-3: #36322d;--ink: #f5f0e4;--ink-2: #d4cdbd;--ink-3: #a39a8a;--ink-4: #6e6557;--line: #4a4036;--line-soft: #383127;--accent: oklch(72% .13 32);--accent-fg: #1a1714;--accent-soft: oklch(38% .07 28);--success: oklch(72% .11 150);--warning: oklch(78% .13 75);--danger: oklch(70% .16 22);--c1: oklch(72% .13 25);--c2: oklch(74% .13 75);--c3: oklch(72% .13 145);--c4: oklch(72% .12 200);--c5: oklch(72% .12 250);--c6: oklch(72% .13 300);--c7: oklch(72% .13 340);--shadow-rgb: 0, 0, 0;--inverse: #f5f0e4;--inverse-2: #d4cdbd;--inverse-fg: #1a1714}}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:14px;line-height:1.5;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit;color:inherit}.font-mono{font-family:var(--font-mono);font-feature-settings:"tnum"}.tnum{font-variant-numeric:tabular-nums}.t-display{font-family:var(--font-display);font-size:56px;font-weight:500;line-height:1;letter-spacing:-.03em}.t-h1{font-size:32px;font-weight:600;line-height:1.1;letter-spacing:-.025em}.t-h2{font-size:22px;font-weight:600;line-height:1.2;letter-spacing:-.018em}.t-h3{font-size:17px;font-weight:600;line-height:1.3;letter-spacing:-.012em}.t-body{font-size:14px;line-height:1.5}.t-sm{font-size:13px;line-height:1.45}.t-xs{font-size:12px;line-height:1.4}.t-label{font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.t-num{font-family:var(--font-display);font-variant-numeric:tabular-nums;font-feature-settings:"tnum";font-weight:500;letter-spacing:-.02em}.muted{color:var(--ink-3)}.muted-2{color:var(--ink-4)}.ink-2{color:var(--ink-2)}.logo{display:inline-flex;align-items:center;gap:10px;color:var(--ink)}.logo-mark{width:28px;height:28px;border-radius:6px;display:block;flex-shrink:0}.logo-word{font-family:var(--font-mono);font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--ink)}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);position:relative}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid var(--line-soft);background:var(--paper);position:sticky;top:0;z-index:5}.app-body{flex:1;padding:32px;display:flex;flex-direction:column;gap:24px;max-width:1320px;width:100%;margin:0 auto}.header-actions{display:flex;align-items:center;gap:12px}.avatar{width:32px;height:32px;border-radius:50%;background:var(--ink);color:var(--paper);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;letter-spacing:.02em;cursor:default}.user-menu{position:relative;outline:none}.user-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:60;min-width:220px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-3);padding:14px;display:flex;flex-direction:column;gap:12px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .12s ease,transform .12s ease,visibility .12s ease;pointer-events:none}.user-menu:hover .user-pop,.user-menu:focus-within .user-pop,.user-pop:hover{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.user-pop:before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px}.user-pop-token{display:flex;flex-direction:column;gap:4px;padding-bottom:12px;border-bottom:1px solid var(--line-soft)}.user-pop-handle{font-size:13px;color:var(--ink);font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:36px;padding:0 14px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--paper);font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;transition:background .12s ease,border-color .12s ease,color .12s ease;white-space:nowrap}.btn:hover{background:var(--paper-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn-primary:hover{background:var(--ink-2);border-color:var(--ink-2)}.btn-accent{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--paper-2)}.btn-danger{color:var(--danger);border-color:var(--line)}.btn-danger:hover{background:#ffeceb;background:oklch(96% .03 22);border-color:#f3bfbc}.btn-lg{height:44px;padding:0 18px;font-size:14px}.btn-sm{height:28px;padding:0 10px;font-size:12px}.btn-block{width:100%}.btn-icon{width:36px;padding:0}.btn-icon-sm{width:28px;height:28px;padding:0}.input{display:block;width:100%;height:40px;padding:0 14px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:14px;outline:none;transition:border-color .12s,box-shadow .12s}.input:focus{border-color:var(--ink-2);box-shadow:0 0 0 3px var(--paper-3)}.input::placeholder{color:var(--ink-4)}.input-sm{height:32px;font-size:13px;padding:0 10px}select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:32px;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%23807a6e' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><polyline points='3 5 6 8 9 5'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:12px 12px}select.input::-ms-expand{display:none}.dtf{position:relative;display:block}.dtf-button{display:flex;align-items:center;gap:8px;width:100%;height:32px;padding:0 12px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--paper);color:var(--ink);font:inherit;font-size:13px;cursor:pointer;text-align:left;transition:border-color .12s,box-shadow .12s}.dtf-button:hover{border-color:var(--ink-4)}.dtf-button:focus{outline:none;border-color:var(--ink-2);box-shadow:0 0 0 3px var(--paper-3)}.dtf-button[disabled]{opacity:.6;cursor:not-allowed}.dtf-button.large{height:36px}.dtf-text{flex:1;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.dtf-text.placeholder{color:var(--ink-4)}.dtf-icon{color:var(--ink-3);display:inline-flex;flex-shrink:0}.dtf-pop{position:fixed;z-index:200;width:280px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-3);padding:12px;display:flex;flex-direction:column;gap:10px}.dtf-pop.wide{width:304px}.dtf-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}.dtf-preset{height:26px;border-radius:var(--r-sm);border:1px solid var(--line);background:var(--paper);font-size:11px;font-weight:500;color:var(--ink-2);font-family:var(--font-mono);cursor:pointer;font-variant-numeric:tabular-nums}.dtf-preset:hover{background:var(--paper-2)}.dtf-preset.active{background:var(--ink);border-color:var(--ink);color:var(--paper)}.dtf-mhead{display:flex;align-items:center;justify-content:space-between;gap:8px}.dtf-mlabel{flex:1;text-align:center;font-size:13px;font-weight:600;letter-spacing:-.01em}.dtf-nav{width:28px;height:28px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;color:var(--ink-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.dtf-nav:hover{background:var(--paper-2);border-color:var(--line-soft)}.dtf-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dtf-dow{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);text-align:center;padding:4px 0;font-weight:500}.dtf-day{height:30px;border:1px solid transparent;background:transparent;border-radius:var(--r-sm);color:var(--ink);font-size:12px;font-variant-numeric:tabular-nums;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.dtf-day:hover{background:var(--paper-2)}.dtf-day.muted{color:var(--ink-4)}.dtf-day.today{border-color:var(--line)}.dtf-day.selected{background:var(--ink);color:var(--paper);border-color:var(--ink)}.dtf-day.selected:hover{background:var(--ink-2)}.dtf-time{display:flex;align-items:center;gap:6px;border-top:1px solid var(--line-soft);padding-top:10px;font-variant-numeric:tabular-nums}.dtf-time-label{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;font-weight:500;margin-right:auto}.dtf-num{width:48px;height:30px;border:1px solid var(--line);border-radius:var(--r-sm);background:var(--paper);text-align:center;font:inherit;font-size:13px;font-family:var(--font-mono);color:var(--ink);font-variant-numeric:tabular-nums;outline:none;-moz-appearance:textfield}.dtf-num::-webkit-outer-spin-button,.dtf-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dtf-num:focus{border-color:var(--ink-2);box-shadow:0 0 0 3px var(--paper-3)}.dtf-num-wide{width:64px}.dtf-num-double{width:116px}.dtf-colon{color:var(--ink-3);font-weight:500;font-size:13px;width:8px;text-align:center;flex:0 0 auto}.dtf-foot{display:flex;justify-content:space-between;border-top:1px solid var(--line-soft);padding-top:10px}.dtf-link{background:transparent;border:0;color:var(--ink-2);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:var(--r-sm)}.dtf-link:hover{background:var(--paper-2);color:var(--ink)}.field-label{font-size:12px;font-weight:500;color:var(--ink-2);margin-bottom:6px;display:block}.code-row{display:flex;gap:8px;justify-content:center}.code-cell{width:48px;height:56px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--paper);text-align:center;font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--ink);font-variant-numeric:tabular-nums;outline:none;transition:border-color .12s,box-shadow .12s}.code-cell.filled{background:var(--paper-2)}.code-cell:focus{border-color:var(--ink);box-shadow:0 0 0 3px var(--paper-3)}.card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}.card-soft{background:var(--paper-2);border:1px solid var(--line-soft);border-radius:var(--r-lg)}.card-elev{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);box-shadow:var(--shadow-2)}.pad-12{padding:12px}.pad-16{padding:16px}.pad-20{padding:20px}.pad-24{padding:24px}.pad-28{padding:28px}.pad-32{padding:32px}.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:var(--r-pill);font-size:11px;font-weight:500;background:var(--paper-2);color:var(--ink-2);border:1px solid var(--line-soft)}.pill-up{color:#236436;background:#dcf7e1;border-color:#bce3c3}.pill-down{color:#99393b;background:#ffe7e5;background:oklch(95% .04 22);border-color:#fdc9c6}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-overlap{background:conic-gradient(from 20deg,#e45361,#dd7b40 12.5%,#d88b21 18.75%,#d68f13,#d59300,#d29700,#cf9c00 25%,#c29f00 28.12%,#bba00c,#b3a21d 31.25%,#8fa83d,#62ac51 43.75%,#41ae5a 46.88%,#27ae5e 48.44%,#0daf60 49.22%,#00af61,#00ae64 50%,#00a787,#00a0a4,#0097c0,#008ddc 75%,#0b8cdd,#1e8cdb 75.78%,#318bd8 76.56%,#4a8ad0 78.12%,#6c86c2 81.25%,#9b7ca4,#c26c84,#e45361);background:conic-gradient(from 20deg,#e45361,#dd7b40 12.5%,#d88b21 18.75%,#d68f13,color(xyz 0.378 0.349 0.045) 21.88%,color(xyz 0.378 0.368 0.031),color(xyz 0.346 0.361 0.047) 28.12%,#bba00c,#b3a21d 31.25%,#8fa83d,#62ac51 43.75%,#41ae5a 46.88%,#27ae5e 48.44%,#0daf60,color(xyz 0.171 0.314 0.166) 50%,color(xyz 0.178 0.296 0.275),color(xyz 0.189 0.279 0.404),color(xyz 0.205 0.26 0.556),color(xyz 0.225 0.241 0.732) 75%,#1e8cdb,#318bd8 76.56%,#4a8ad0 78.12%,#6c86c2 81.25%,#9b7ca4,#c26c84,#e45361);box-shadow:inset 0 0 0 1px #00000014}.dot.lg{width:10px;height:10px}.dot.xl{width:14px;height:14px}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;padding:10px 16px;font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--line-soft);background:var(--paper)}.tbl td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--line-soft);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--paper-2)}.hours-stack{display:flex;flex-direction:row;align-items:flex-end;justify-content:flex-end;gap:10px;white-space:nowrap}.hours-sub{font-size:11px;color:var(--ink-3)}.hours-sub.overage{color:var(--danger)}.revenue-cell{display:flex;align-items:center;justify-content:flex-end;gap:8px;white-space:nowrap}.bar-track{height:4px;background:var(--paper-3);border-radius:var(--r-pill);overflow:hidden;width:100%}.bar-track.retainer-track{background:color-mix(in oklab,var(--paper-3),var(--ink-4) 18%)}.bar-track.overage{background:color-mix(in oklab,var(--danger),var(--paper-3) 72%)}.bar-fill{height:100%;border-radius:var(--r-pill)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--paper)}.auth-card{width:100%;max-width:460px;padding:36px;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);box-shadow:var(--shadow-2);display:flex;flex-direction:column;gap:24px}.auth-head{display:flex;flex-direction:column;gap:6px;text-align:center}.auth-foot{font-size:12px;color:var(--ink-3);text-align:center;border-top:1px solid var(--line-soft);padding-top:14px;cursor:pointer;background:none;border-left:0;border-right:0;border-bottom:0}.auth-foot:hover{color:var(--ink-2)}.auth-error{text-align:center;font-size:13px;color:var(--danger)}.auth-dev{background:var(--paper-2);border:1px dashed var(--line);border-radius:var(--r-md);padding:10px 12px;font-size:12px;color:var(--ink-2);font-family:var(--font-mono);text-align:center}.between{display:flex;align-items:center;justify-content:space-between;gap:16px}.row{display:flex;flex-direction:row;gap:16px}.row-tight{display:flex;flex-direction:row;gap:8px;align-items:center}.col{display:flex;flex-direction:column;gap:12px}.month-nav{display:flex;align-items:center;gap:4px}.month-label{min-width:180px;text-align:center;font-size:22px;font-weight:600;letter-spacing:-.018em}.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.kpi{padding:24px;display:flex;flex-direction:column;gap:12px}.kpi-value-row{display:flex;align-items:baseline;gap:6px}.kpi-value{font-size:48px}.kpi-suffix{color:var(--ink-3);font-size:17px;font-weight:400}.kpi-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-3)}.graph-card{padding:24px}.graph-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}.graph-legend{display:flex;flex-wrap:wrap;gap:14px;font-size:12px}.graph-legend-item{display:inline-flex;align-items:center;gap:6px;color:var(--ink-2)}.graph{display:flex;width:100%;height:280px;position:relative}.graph-yaxis{width:36px;position:relative;flex-shrink:0}.graph-ylabel{position:absolute;right:8px;font-size:10px;font-family:var(--font-mono);color:var(--ink-4);font-variant-numeric:tabular-nums;transform:translateY(-50%)}.graph-plot{flex:1;position:relative}.graph-grid{position:absolute;left:0;right:0;border-top:1px dashed var(--line-soft)}.graph-grid.solid{border-top-style:solid}.graph-cols{display:flex;width:100%;height:100%;position:relative}.graph-col{flex:1;position:relative;height:100%;z-index:1}.graph-stack{position:absolute;bottom:28px;left:50%;transform:translate(-50%);display:flex;flex-direction:column-reverse;gap:3px;align-items:center}.graph-dot-wrap{position:relative;width:10px;height:10px;display:grid;place-items:center;outline:none}.graph-dot{width:10px;height:10px;border-radius:50%;opacity:.95;display:block}.graph-dot.overlap{background:conic-gradient(from 20deg,#e45361 0 22%,#cf9c00 22% 47%,#00ae64 47% 72%,#008cdd 72% 100%);background:conic-gradient(from 20deg,#e45361 0 22%,oklch(72% .16 85) 22% 47%,oklch(66% .17 155) 47% 72%,oklch(62% .16 245) 72% 100%);box-shadow:inset 0 0 0 1px #0000001f,0 0 0 1px var(--paper)}.graph-dot-wrap.weekend{opacity:.35}.graph-col:has(.graph-dot-wrap:hover),.graph-col:has(.graph-dot-wrap:focus-visible){z-index:80}.graph-popover{position:absolute;left:50%;bottom:calc(100% + 9px);z-index:100;min-width:172px;padding:9px 10px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper);color:var(--ink);box-shadow:var(--shadow-3);display:grid;gap:6px;font-size:11px;opacity:0;pointer-events:none;transform:translate(-50%,4px);transition:opacity .12s,transform .12s}.graph-popover:after{content:"";position:absolute;left:50%;bottom:-5px;width:8px;height:8px;background:var(--paper);border-right:1px solid var(--line);border-bottom:1px solid var(--line);transform:translate(-50%) rotate(45deg)}.graph-dot-wrap:hover,.graph-dot-wrap:focus-visible{z-index:30}.graph-dot-wrap:hover .graph-popover,.graph-dot-wrap:focus-visible .graph-popover{opacity:1;transform:translate(-50%)}.graph-popover-title{font-weight:650;white-space:nowrap}.graph-popover-row{display:grid;grid-template-columns:8px minmax(0,1fr) auto;align-items:center;gap:7px;color:var(--ink-2)}.graph-popover-row span:nth-child(2){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.graph-xlabel{position:absolute;bottom:4px;left:50%;transform:translate(-50%);font-size:10px;font-family:var(--font-mono);color:var(--ink-4);font-variant-numeric:tabular-nums}.section-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--line-soft)}.entry-row{display:grid;grid-template-columns:12px minmax(120px,160px) minmax(140px,1fr) minmax(220px,320px) 28px 28px;gap:10px;padding:12px 16px;align-items:center;border-bottom:1px solid var(--line-soft)}.entry-row:last-child{border-bottom:none}.entry-row .input{height:32px;padding:0 10px;font-size:13px}.entry-row select.input{padding-right:28px}.trackings-more{width:100%;height:44px;border:0;border-top:1px solid var(--line-soft);background:var(--paper-2);color:var(--ink-2);font:inherit;font-size:13px;font-weight:600;cursor:pointer}.trackings-more:hover,.trackings-more:focus-visible{background:var(--paper-3);color:var(--ink);outline:none}.entry-running{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;font-size:12px;font-weight:500;color:var(--ink-2);text-transform:uppercase;letter-spacing:.06em}.entry-running .dot{background:var(--accent);animation:pulse-soft 2.2s ease-in-out infinite}.manual-form{display:grid;grid-template-columns:minmax(140px,180px) minmax(140px,1fr) minmax(240px,360px) auto;gap:10px;padding:16px 24px;background:var(--paper-2);border-bottom:1px solid var(--line-soft)}.manual-form .input{height:36px}.empty{padding:32px 24px;text-align:center;color:var(--ink-3);font-size:13px}.timer-stack{position:fixed;bottom:24px;right:24px;z-index:50;display:grid;gap:8px;justify-items:end}.timer-stack-item{display:grid;gap:8px;justify-items:end}.timer-chip{display:flex;align-items:center;gap:12px;width:min(360px,calc(100vw - 48px));padding:10px 12px 10px 14px;background:var(--inverse);color:var(--inverse-fg);border-radius:var(--r-pill);box-shadow:var(--shadow-3);font-size:13px;font-weight:500;cursor:pointer;outline:none;transition:box-shadow .12s,transform .12s}.timer-chip:hover,.timer-chip:focus-visible{box-shadow:var(--shadow-3),0 0 0 3px var(--paper-3)}.timer-chip.open{transform:translateY(-1px)}.timer-chip .timer-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse-soft 2.2s ease-in-out infinite;flex-shrink:0}.timer-chip .timer-eyebrow{color:color-mix(in oklab,var(--inverse-fg) 70%,transparent);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:500}.timer-chip .timer-customer{color:color-mix(in oklab,var(--inverse-fg) 95%,transparent);min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timer-chip .timer-time{font-family:var(--font-mono);font-size:13px;font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:-.01em;flex-shrink:0}.timer-chip .timer-stop{width:28px;height:28px;border-radius:50%;background:color-mix(in oklab,var(--inverse-fg) 10%,transparent);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;margin-left:4px;border:none;color:var(--inverse-fg);flex-shrink:0}.timer-chip .timer-stop:hover{background:color-mix(in oklab,var(--inverse-fg) 18%,transparent)}.timer-editor{width:min(360px,calc(100vw - 48px));padding:12px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper);color:var(--ink);box-shadow:var(--shadow-3);display:grid;gap:10px}.timer-editor-field{min-width:0}.timer-editor .field-label{margin-bottom:5px;font-size:11px;color:var(--ink-3)}.timer-editor .input{background-color:var(--paper)}.modal-layer{position:fixed;inset:0;z-index:130;display:grid;place-items:center;padding:24px;background:rgba(var(--shadow-rgb),.42)}.confirm-modal{width:min(420px,100%);display:grid;grid-template-columns:42px 1fr;gap:14px;padding:18px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--paper);color:var(--ink);box-shadow:var(--shadow-3)}.confirm-icon{width:42px;height:42px;border-radius:var(--r-md);display:inline-flex;align-items:center;justify-content:center;color:var(--danger);background:color-mix(in oklab,var(--danger),var(--paper-2) 86%)}.confirm-copy{min-width:0}.confirm-title{margin:4px 0 6px;font-size:18px;line-height:1.2;font-weight:650;overflow-wrap:anywhere}.confirm-text{margin:0;color:var(--ink-3);font-size:13px;line-height:1.45}.confirm-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:8px;padding-top:4px}@keyframes pulse{0%{box-shadow:0 0 #b4524880}70%{box-shadow:0 0 0 6px #b4524800}to{box-shadow:0 0 #b4524800}}@keyframes pulse-soft{0%,to{opacity:.55;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.drawer-backdrop{position:fixed;inset:0;background:rgba(var(--shadow-rgb),.36);z-index:90;opacity:0;pointer-events:none;transition:opacity .22s ease}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:720px;z-index:100;background:var(--paper);border-left:1px solid var(--line);box-shadow:-16px 0 40px -12px rgba(var(--shadow-rgb),.18);transform:translate(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;pointer-events:none}.drawer.open{transform:translate(0);pointer-events:auto}.drawer.obscured:after{content:"";position:absolute;inset:0;z-index:5;background:rgba(var(--shadow-rgb),.34);pointer-events:auto}.drawer-form{z-index:110;max-width:660px;border-left:1px solid var(--line);box-shadow:-16px 0 40px -12px rgba(var(--shadow-rgb),.22)}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;border-bottom:1px solid var(--line-soft);flex-shrink:0}.drawer-title{display:flex;flex-direction:column;gap:2px}.drawer-close{width:32px;height:32px;border-radius:var(--r-md);border:1px solid transparent;background:transparent;color:var(--ink-2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.drawer-close:hover{background:var(--paper-2);border-color:var(--line-soft);color:var(--ink)}.drawer-body{flex:1;overflow:auto;padding:16px 24px 32px;display:flex;flex-direction:column;gap:14px}.drawer-foot{padding:16px 24px;border-top:1px solid var(--line-soft);display:flex;gap:8px;justify-content:flex-end}.cust-row{display:grid;grid-template-columns:12px 1fr auto auto;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line-soft);border-radius:var(--r-md);background:var(--paper);cursor:pointer;transition:background .12s,border-color .12s}.cust-row:hover{background:var(--paper-2);border-color:var(--line)}.cust-row.archived{opacity:.55}.cust-name{font-weight:500;font-size:14px;color:var(--ink)}.cust-rate{font-family:var(--font-mono);font-size:12px;color:var(--ink-3)}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;background:var(--swatch)}.color-swatch.selected{border-color:var(--ink);box-shadow:0 0 0 2px var(--paper)}.field{display:flex;flex-direction:column;gap:6px}.kbd{font-family:var(--font-mono);font-size:10px;padding:2px 5px;border:1px solid var(--line);border-radius:4px;background:var(--paper-2);color:var(--ink-2)}.divider{height:1px;background:var(--line-soft)}@media(max-width:960px){.app-header{padding:12px 20px}.app-body{padding:20px;gap:16px}.kpis{grid-template-columns:1fr}.entry-row{grid-template-columns:1fr;gap:8px}.manual-form{grid-template-columns:1fr}.drawer,.drawer-form{max-width:100%}}
