:root{--radius: 8px;--font: "Roboto", system-ui, sans-serif;--scrollbar-size: 10px;--scrollbar-track: transparent;--scrollbar-thumb: rgba(139, 156, 176, .45);--scrollbar-thumb-hover: rgba(139, 156, 176, .7)}[data-mode=dark]{--bg: #121214;--surface: #1c1c1f;--surface-2: #2a2a2e;--scrollbar-thumb: rgba(139, 156, 176, .4);--scrollbar-thumb-hover: rgba(157, 173, 192, .65);--text: #ececef;--muted: #9a9aa3;--danger: #e57373;--accent: #8b9cb0;--accent-hover: #9dadc0;--paid: #86efac;--pending: #fdba74;--invoiced: #d8b4fe;--calendar-today: #d4b454;--paid-bg: rgba(134, 239, 172, .16);--paid-border: rgba(134, 239, 172, .5);--pending-bg: rgba(253, 186, 116, .18);--pending-border: rgba(253, 186, 116, .52);--invoiced-bg: rgba(216, 180, 254, .18);--invoiced-border: rgba(216, 180, 254, .5)}[data-mode=light]{--bg: #f4f1ea;--surface: #ffffff;--surface-2: #e8e4db;--scrollbar-thumb: rgba(100, 116, 139, .35);--scrollbar-thumb-hover: rgba(71, 85, 105, .55);--text: #1a1816;--muted: #5c574f;--danger: #dc2626;--accent: #8fa3b3;--accent-hover: #7a92a2;--paid: #3f6212;--pending: #9a3412;--invoiced: #6b21a8;--calendar-today: #a16207;--paid-bg: #dcfce7;--paid-border: #86efac;--pending-bg: #ffedd5;--pending-border: #fdba74;--invoiced-bg: #f3e8ff;--invoiced-border: #d8b4fe}[data-mode=dark][data-dev-accent=vivid]{--paid: #4ade80;--pending: #fbbf24;--invoiced: #c084fc;--paid-bg: rgba(74, 222, 128, .18);--paid-border: rgba(74, 222, 128, .55);--pending-bg: rgba(251, 191, 36, .2);--pending-border: rgba(251, 191, 36, .58);--invoiced-bg: rgba(192, 132, 252, .2);--invoiced-border: rgba(192, 132, 252, .55)}[data-mode=dark][data-dev-accent=electric]{--paid: #a3e635;--pending: #22d3ee;--invoiced: #e879f9;--paid-bg: rgba(163, 230, 53, .18);--paid-border: rgba(163, 230, 53, .55);--pending-bg: rgba(34, 211, 238, .18);--pending-border: rgba(34, 211, 238, .55);--invoiced-bg: rgba(232, 121, 249, .2);--invoiced-border: rgba(232, 121, 249, .55)}[data-mode=dark][data-dev-accent=sunset]{--paid: #2dd4bf;--pending: #fb923c;--invoiced: #f472b6;--paid-bg: rgba(45, 212, 191, .18);--paid-border: rgba(45, 212, 191, .55);--pending-bg: rgba(251, 146, 60, .2);--pending-border: rgba(251, 146, 60, .58);--invoiced-bg: rgba(244, 114, 182, .2);--invoiced-border: rgba(244, 114, 182, .55)}[data-mode=dark][data-dev-accent=signal]{--paid: #34d399;--pending: #facc15;--invoiced: #818cf8;--paid-bg: rgba(52, 211, 153, .18);--paid-border: rgba(52, 211, 153, .55);--pending-bg: rgba(250, 204, 21, .2);--pending-border: rgba(250, 204, 21, .58);--invoiced-bg: rgba(129, 140, 248, .2);--invoiced-border: rgba(129, 140, 248, .55)}[data-mode=dark][data-dev-accent=traffic]{--paid: #4ade80;--pending: #f87171;--invoiced: #fbbf24;--paid-bg: rgba(74, 222, 128, .18);--paid-border: rgba(74, 222, 128, .55);--pending-bg: rgba(248, 113, 113, .2);--pending-border: rgba(248, 113, 113, .58);--invoiced-bg: rgba(251, 191, 36, .2);--invoiced-border: rgba(251, 191, 36, .55)}[data-mode=dark][data-dev-accent=bold]{--paid: #34e0a0;--pending: #ff8c42;--invoiced: #bf5af2;--paid-bg: rgba(52, 224, 160, .18);--paid-border: rgba(52, 224, 160, .55);--pending-bg: rgba(255, 140, 66, .22);--pending-border: rgba(255, 140, 66, .6);--invoiced-bg: rgba(191, 90, 242, .22);--invoiced-border: rgba(191, 90, 242, .58)}[data-mode=dark][data-dev-accent=jewel]{--paid: #34d399;--pending: #fbbf24;--invoiced: #60a5fa;--paid-bg: rgba(52, 211, 153, .18);--paid-border: rgba(52, 211, 153, .55);--pending-bg: rgba(251, 191, 36, .2);--pending-border: rgba(251, 191, 36, .58);--invoiced-bg: rgba(96, 165, 250, .2);--invoiced-border: rgba(96, 165, 250, .55)}[data-mode=dark][data-dev-accent=ocean]{--paid: #38bdf8;--pending: #fcd34d;--invoiced: #6366f1;--paid-bg: rgba(56, 189, 248, .18);--paid-border: rgba(56, 189, 248, .55);--pending-bg: rgba(252, 211, 77, .2);--pending-border: rgba(252, 211, 77, .58);--invoiced-bg: rgba(99, 102, 241, .2);--invoiced-border: rgba(99, 102, 241, .55)}[data-mode=dark][data-dev-accent=dusk]{--paid: #86efac;--pending: #fdba74;--invoiced: #d8b4fe;--paid-bg: rgba(134, 239, 172, .16);--paid-border: rgba(134, 239, 172, .5);--pending-bg: rgba(253, 186, 116, .18);--pending-border: rgba(253, 186, 116, .52);--invoiced-bg: rgba(216, 180, 254, .18);--invoiced-border: rgba(216, 180, 254, .5)}[data-mode=light][data-dev-accent=vivid]{--paid: #047857;--pending: #b45309;--invoiced: #6d28d9;--paid-bg: #ecfdf5;--paid-border: #6ee7b7;--pending-bg: #fffbeb;--pending-border: #fcd34d;--invoiced-bg: #f5f3ff;--invoiced-border: #c4b5fd}[data-mode=light][data-dev-accent=electric]{--paid: #3f6212;--pending: #0e7490;--invoiced: #a21caf;--paid-bg: #f7fee7;--paid-border: #bef264;--pending-bg: #ecfeff;--pending-border: #67e8f9;--invoiced-bg: #fdf4ff;--invoiced-border: #f0abfc}[data-mode=light][data-dev-accent=sunset]{--paid: #0f766e;--pending: #c2410c;--invoiced: #be185d;--paid-bg: #f0fdfa;--paid-border: #5eead4;--pending-bg: #fff7ed;--pending-border: #fdba74;--invoiced-bg: #fdf2f8;--invoiced-border: #f9a8d4}[data-mode=light][data-dev-accent=signal]{--paid: #047857;--pending: #a16207;--invoiced: #4338ca;--paid-bg: #ecfdf5;--paid-border: #6ee7b7;--pending-bg: #fefce8;--pending-border: #fde047;--invoiced-bg: #eef2ff;--invoiced-border: #a5b4fc}[data-mode=light][data-dev-accent=traffic]{--paid: #15803d;--pending: #b91c1c;--invoiced: #b45309;--paid-bg: #f0fdf4;--paid-border: #86efac;--pending-bg: #fef2f2;--pending-border: #fca5a5;--invoiced-bg: #fffbeb;--invoiced-border: #fcd34d}[data-mode=light][data-dev-accent=bold]{--paid: #0d9488;--pending: #ea580c;--invoiced: #7e22ce;--paid-bg: #f0fdfa;--paid-border: #5eead4;--pending-bg: #fff7ed;--pending-border: #fb923c;--invoiced-bg: #faf5ff;--invoiced-border: #d8b4fe}[data-mode=light][data-dev-accent=jewel]{--paid: #047857;--pending: #a16207;--invoiced: #1d4ed8;--paid-bg: #ecfdf5;--paid-border: #6ee7b7;--pending-bg: #fefce8;--pending-border: #fde047;--invoiced-bg: #eff6ff;--invoiced-border: #93c5fd}[data-mode=light][data-dev-accent=ocean]{--paid: #0369a1;--pending: #b45309;--invoiced: #3730a3;--paid-bg: #f0f9ff;--paid-border: #7dd3fc;--pending-bg: #fffbeb;--pending-border: #fcd34d;--invoiced-bg: #eef2ff;--invoiced-border: #a5b4fc}[data-mode=light][data-dev-accent=dusk]{--paid: #3f6212;--pending: #9a3412;--invoiced: #6b21a8;--paid-bg: #dcfce7;--paid-border: #86efac;--pending-bg: #ffedd5;--pending-border: #fdba74;--invoiced-bg: #f3e8ff;--invoiced-border: #d8b4fe}[data-mode=light] .pdf-preview-frame{border-color:var(--surface-2)}[data-mode=light] .combobox-list{box-shadow:0 8px 24px #0000001a}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track)}*::-webkit-scrollbar{width:var(--scrollbar-size);height:var(--scrollbar-size)}*::-webkit-scrollbar-track{background:var(--scrollbar-track)}*::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb);border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover)}.scroll-panel{overflow:auto;overscroll-behavior:contain}body{margin:0;min-height:100vh}*{box-sizing:border-box}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5}.app{max-width:1100px;margin:0 auto;padding:2rem 1.25rem 3rem}.app-wide{max-width:1400px}.header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.header-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.65rem}.user-bar{display:flex;align-items:center;gap:.65rem}.user-name{font-size:.85rem;color:var(--muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.login-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;width:min(380px,100%);display:flex;flex-direction:column;gap:.85rem}.login-card h1{margin:0}.login-hint{margin:0 0 .5rem;padding:0}.login-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.login-btn{margin-top:.25rem}.loading-msg{padding:3rem;text-align:center}.clickable-row{cursor:pointer}.clickable-row:hover{background:var(--surface-2)}.highlight-row{outline:2px solid var(--accent);outline-offset:-2px}.linked-cell-inner{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.event-chip{font-size:.8rem}.invoice-sender-section{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--surface-2)}.invoice-sender-header{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.5rem;margin-bottom:.35rem}.invoice-sender-header h3{margin:0;font-size:.95rem}.invoice-sender-actions{display:flex;flex-wrap:wrap;gap:.75rem}.invoice-sender-help{margin:0 0 .75rem;font-size:.8rem;line-height:1.4}.invoice-editor-toolbar{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.invoice-number-field{flex:1 1 14rem;max-width:22rem;display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.invoice-number-field input{width:100%}.invoice-editor-actions{display:flex;gap:.5rem}.invoice-number-label{color:var(--muted);margin:0 0 .75rem}.linked-events{margin-bottom:1rem}.linked-events-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}.event-detail-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.event-detail-title{flex:1 1 auto;margin:0;font-size:1.25rem;min-width:0}.event-detail-actions{display:flex;flex-wrap:wrap;gap:.5rem}.event-detail-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;margin-bottom:1rem;font-size:.9rem}.event-detail-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(16rem,1fr));gap:1rem;margin-bottom:1.25rem}.linked-section .stat-label{display:block;margin-bottom:.35rem}.related-list{list-style:none;margin:0;padding:0}.related-list li+li{margin-top:.35rem}.related-list-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;text-align:left;padding:.55rem .7rem;border-radius:6px;border:1px solid var(--surface-2);background:var(--surface);color:var(--text);font:inherit;cursor:pointer}.related-list-btn:hover{border-color:var(--accent);background:var(--surface-2)}.related-list-primary{font-weight:500}.related-list-meta{font-size:.8rem}.event-detail-form-panel h3{margin:0 0 .75rem;font-size:1rem}.time-tracking-panel{margin:1rem 0 0;padding:1rem 1.25rem;background:var(--surface-elevated, rgba(255, 255, 255, .04));border:1px solid var(--border);border-radius:var(--radius)}.time-tracking-modal{max-width:36rem}.time-tracking-modal-header{margin-bottom:.75rem}.time-tracking-modal-event{margin:.25rem 0 0}.time-tracking-modal .time-tracking-panel{margin-top:.5rem}.time-tracking-modal .form-actions{margin-top:1rem;justify-content:flex-end}.total-hours-field .total-hours-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem}.total-hours-field .total-hours-row input{flex:1 1 6rem;min-width:5rem}.reset-clock-hours-btn{white-space:nowrap}.clock-times-section{margin:.5rem 0 .25rem}.clock-times-summary{list-style:none;margin:.35rem 0 0;padding:0}.clock-times-summary li{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.35rem .75rem;padding:.45rem 0;border-top:1px solid var(--border)}.clock-times-summary li:first-child{border-top:none;padding-top:0}.clock-track-wrap{display:inline-flex;vertical-align:top}.hours-track-wrap{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.2rem}.hours-value{line-height:1.2}.hours-status-dot{width:.55rem;height:.55rem;border-radius:50%;flex-shrink:0}.actions-inner .clock-track-wrap.clock-logged .btn.icon.clock-track{color:var(--paid)}.actions-inner .clock-track-wrap.clock-logged .btn.icon.clock-track:hover{background:var(--paid-bg)}.hours-track-wrap.clock-logged .hours-status-dot{background:var(--paid)}.actions-inner .clock-track-wrap.clock-active .btn.icon.clock-track{color:var(--pending)}.actions-inner .clock-track-wrap.clock-active .btn.icon.clock-track:hover{background:var(--pending-bg)}.hours-track-wrap.clock-active .hours-status-dot{background:var(--pending)}.hours-col{text-align:left}.time-tracking-title{margin:0 0 .75rem;font-size:.95rem}.time-tracking-tz{font-size:.8rem;font-weight:400}.time-tracking-clock{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:.75rem}.time-tracking-status{margin:0;flex:1 1 12rem}.time-tracking-status.clocked-in{color:var(--accent, #6ee7b7)}.time-tracking-live{font-weight:600}.time-tracking-total{margin:0 0 1rem;font-size:.95rem}.time-tracking-panel .btn.secondary.btn-sm{border:1px solid var(--border);background:var(--surface)}.time-tracking-panel .btn.secondary.btn-sm:hover{background:var(--surface-2)}.time-segments-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.time-segment-form{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;align-items:start;margin-bottom:.75rem}.time-segment-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted);min-width:0}.time-segment-form label input[type=datetime-local]{width:100%;min-width:0;box-sizing:border-box}.time-segment-form label input[type=datetime-local]:focus{outline:none;border-color:var(--accent)}.time-segment-form .field-hint{margin-top:0}.time-segment-form-actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.time-segment-form-actions .btn.secondary{border:1px solid var(--border);background:var(--surface)}.time-segment-form-actions .btn.secondary:hover{background:var(--surface-2)}@media (max-width: 640px){.time-segment-form{grid-template-columns:1fr}}.time-segments-list{list-style:none;margin:0;padding:0}.time-segments-list li{padding:.6rem 0;border-top:1px solid var(--border)}.time-segments-list li.active-segment{background:#6ee7b70f;margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;border-radius:var(--radius-sm, 4px)}.time-segment-times{font-size:.9rem}.time-segment-meta{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.25rem;font-size:.85rem}.time-segment-actions{display:flex;gap:.75rem}.time-segments-empty{margin:0;font-size:.9rem}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.badge.clocked-in-badge{background:var(--pending-bg);color:var(--pending);border:1px solid var(--pending-border);font-size:.7rem;margin-left:0;vertical-align:middle}.invoice-editor-split{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;align-items:start}@media (max-width: 960px){.invoice-editor-split{grid-template-columns:1fr}}.invoice-form-panel,.invoice-preview-panel{background:var(--surface);border-radius:var(--radius);padding:1rem 1.25rem}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.preview-header h3{margin:0}.preview-header-actions{display:flex;align-items:center;gap:.65rem;flex-shrink:0}.preview-header-actions .muted{padding:0;font-size:.8rem}.pdf-preview-frame{width:100%;height:min(80vh,720px);border:1px solid var(--surface-2);border-radius:6px;background:#fff}.preview-placeholder{padding:2rem 1rem;text-align:center}.line-items-header{display:flex;justify-content:space-between;align-items:center;margin:1.25rem 0 .75rem}.line-items-header h3{margin:0}.line-items-table-wrap{overflow-x:auto}.line-items-table input{width:100%;min-width:0}.line-items-table .narrow{width:4.5rem}.line-items-table td,.line-items-table th{padding:.4rem;font-size:.85rem}.invoice-totals{display:flex;justify-content:flex-end;gap:1.25rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--surface-2)}.tabs{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.tab{background:var(--surface);color:var(--muted);border:1px solid var(--surface-2);border-radius:6px;padding:.45rem .9rem;cursor:pointer;font:inherit}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.section-header{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.checkbox-row{display:flex;align-items:center;gap:.5rem;color:var(--text);font-size:.9rem;margin-top:.5rem}.checkbox-row input[type=checkbox]{margin-top:.1rem}.inline-select{padding:.25rem .4rem;font-size:.85rem}.eyebrow{margin:0;color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}h1{margin:.15rem 0 0;font-size:1.75rem}.toolbar{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem}.toolbar label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.toolbar .combobox{min-width:10rem}input,select,textarea{background:var(--surface);border:1px solid var(--surface-2);color:var(--text);border-radius:6px;padding:.5rem .65rem;font:inherit}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:1.125rem;height:1.125rem;margin:0;padding:0;flex-shrink:0;border:1px solid color-mix(in srgb,var(--muted) 55%,var(--surface-2));border-radius:4px;background:var(--surface);cursor:pointer;vertical-align:middle;position:relative;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}input[type=checkbox]:after{content:"";position:absolute;left:50%;top:46%;width:.28rem;height:.52rem;border:solid var(--bg);border-width:0 2px 2px 0;transform:translate(-50%,-55%) rotate(45deg) scale(.4);opacity:0;transition:transform .12s ease,opacity .12s ease}input[type=checkbox]:hover:not(:disabled){border-color:var(--accent-hover)}input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}input[type=checkbox]:checked:after{opacity:1;transform:translate(-50%,-55%) rotate(45deg) scale(1)}input[type=checkbox]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input[type=checkbox]:disabled{opacity:.45;cursor:not-allowed}[data-mode=light] input[type=checkbox]:checked:after{border-color:var(--surface)}input[type=date].date-input{min-height:2.25rem;color:var(--text)}[data-mode=dark] input[type=date].date-input{color-scheme:dark}[data-mode=light] input[type=date].date-input{color-scheme:light}input[type=date].date-input-empty::-webkit-datetime-edit,input[type=date].date-input-empty::-webkit-datetime-edit-fields-wrapper{opacity:0}input[type=date].date-input-empty:focus::-webkit-datetime-edit,input[type=date].date-input-empty:focus::-webkit-datetime-edit-fields-wrapper,input[type=date].date-input-has-value::-webkit-datetime-edit,input[type=date].date-input-has-value::-webkit-datetime-edit-fields-wrapper{opacity:1}@supports (-moz-appearance: none){input[type=date].date-input-empty:not(:focus):not(.date-input-has-value){color:transparent}input[type=date].date-input-empty:focus,input[type=date].date-input-has-value{color:var(--text)}}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;margin-left:.15rem;opacity:.75}[data-mode=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:none;opacity:.9}[data-mode=light] input[type=date]::-webkit-calendar-picker-indicator{opacity:.6}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;margin-bottom:1.5rem}.stats article{background:var(--surface);border-radius:var(--radius);padding:.9rem 1rem}.stat-label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:.25rem}.stats strong{font-size:1.35rem}.events-toolbar{align-items:flex-end}.events-clear-dates{align-self:flex-end;margin-bottom:.35rem}.events-list-meta{margin:0;padding:.75rem 1rem 0;font-size:.85rem}.events-panel-message{padding:1rem 1.15rem;margin:0}.events-scroll-sentinel{min-height:3rem;padding:.75rem 1rem 1rem;text-align:center}.profile-modal h2{margin-top:0}.profile-preview{margin:0 0 1rem;padding:.65rem .75rem;background:var(--surface-2);border-radius:var(--radius);font-size:.85rem}.profile-preview-label{margin:0 0 .35rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em}.profile-preview-address{margin:.25rem 0;font-family:inherit;font-size:.85rem;white-space:pre-wrap;background:transparent;border:none;padding:0;color:inherit}.profile-modal-help{margin:0 0 1rem;font-size:.85rem}.rename-field-modal{max-width:26rem}.rename-field-help{margin:0 0 1rem;font-size:.88rem;line-height:1.45}.rename-field-modal label{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem;font-size:.8rem;color:var(--muted)}.rename-field-confirm-lead{margin:0 0 .75rem;font-size:.9rem}.rename-field-compare{margin:0 0 1rem;display:grid;gap:.75rem}.rename-field-compare dt{margin:0;font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.rename-field-compare dd{margin:.2rem 0 0;font-size:1rem}.readonly-input{background:var(--surface-2);color:var(--muted);cursor:default}.upload-pdf-modal{max-width:32rem;max-height:min(90vh,44rem);overflow-y:auto}.upload-pdf-modal h2{margin:0 0 .5rem;font-size:1.15rem}.upload-pdf-help{margin:0 0 1rem;font-size:.9rem}.upload-pdf-picker{margin-bottom:1rem}.upload-pdf-search-label{display:block;margin-bottom:.5rem;font-size:.85rem;font-weight:600}.upload-pdf-search{display:block;width:100%;margin-top:.35rem}.upload-pdf-picker-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem;font-size:.8rem}.upload-pdf-picker-actions{display:flex;gap:.75rem}.upload-pdf-empty{margin:0;padding:.75rem;font-size:.85rem}.upload-pdf-fields{display:grid;gap:.75rem;margin-bottom:.5rem}.upload-pdf-events{list-style:none;margin:0;padding:0;max-height:14rem;background:var(--surface-2);border:1px solid var(--surface-2);border-radius:var(--radius)}.upload-pdf-events li{padding:.5rem .75rem;border-bottom:1px solid var(--bg);font-size:.85rem}.upload-pdf-events li:last-child{border-bottom:none}.upload-pdf-events li .muted{display:block;font-size:.8rem}.upload-pdf-events-pick label{display:flex;align-items:flex-start;gap:.65rem;cursor:pointer;width:100%}.upload-pdf-event-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.upload-pdf-event-text .muted{font-size:.78rem;line-height:1.35}.invoice-uploaded-tag{display:block;font-size:.75rem;margin-top:.15rem}.uploaded-pdf-notice{margin:0 0 1rem;padding:.65rem .85rem;background:var(--surface-2);border-radius:6px;font-size:.85rem}.events-panel{background:var(--surface);border-radius:var(--radius);overflow:hidden}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--surface-2)}th{font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}td .sub{display:block;font-size:.8rem;color:var(--muted)}.badge{display:inline-block;padding:.2rem .55rem;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.02em;border:1px solid transparent}.badge.paid{background:var(--paid-bg);color:var(--paid);border-color:var(--paid-border)}.badge.pending{background:var(--pending-bg);color:var(--pending);border-color:var(--pending-border)}.badge.invoiced{background:var(--invoiced-bg);color:var(--invoiced);border-color:var(--invoiced-border)}.badge.no_pay{background:var(--surface);color:var(--muted);border-color:var(--surface-2);font-weight:500}.status-badge-btn{border:1px solid transparent;font:inherit;cursor:pointer;transition:filter .12s ease,transform .12s ease}.status-badge-btn:hover{filter:brightness(1.12)}.status-badge-btn.paid:hover{border-color:var(--paid-border)}.status-badge-btn.pending:hover{border-color:var(--pending-border)}.status-badge-btn.invoiced:hover{border-color:var(--invoiced-border)}.status-badge-btn.no_pay:hover{border-color:var(--muted);filter:none}.status-select{min-width:6.5rem}.btn{border:none;border-radius:6px;padding:.5rem .9rem;font:inherit;cursor:pointer}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-hover)}.btn.secondary{background:var(--surface-2);color:var(--text)}.btn.btn-sm{padding:.35rem .65rem;font-size:.8rem}.btn.link{background:none;color:var(--accent);padding:.2rem .4rem}.btn.link.danger{color:var(--danger)}th.actions-col,td.actions-col{width:6.5rem;min-width:6.5rem;text-align:right;vertical-align:top}.actions-inner{display:inline-flex;align-items:center;justify-content:flex-end;gap:.1rem;flex-wrap:nowrap}.btn.icon{background:none;border:none;border-radius:4px;padding:.3rem;color:var(--accent);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;line-height:0}.btn.icon:hover{background:#82aaff1f}.btn.icon.danger{color:var(--danger)}.btn.icon.danger:hover{background:#ff6b6b1f}.events-panel tbody td{vertical-align:top}th.checkbox-col,td.checkbox-col{width:2.75rem;text-align:center;vertical-align:top}td.checkbox-col input[type=checkbox]{display:block;margin:.15rem auto 0}.confirm-anchor{position:relative;display:inline-block}.confirm-popover{z-index:200;background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);padding:.75rem;min-width:11rem;box-shadow:0 8px 24px #00000073}.confirm-popover-portal{position:fixed}.confirm-popover p{margin:0 0 .65rem;font-size:.9rem;white-space:nowrap}.confirm-popover-actions{display:flex;gap:.5rem;justify-content:flex-end}.btn.danger-btn{background:var(--danger);color:#fff;border:none;border-radius:6px;padding:.4rem .75rem;font:inherit;cursor:pointer}.invoice-links{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}.line-event-picker{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start;min-width:8rem}.line-event-picker select{width:100%;max-width:12rem}.event-link-cell{min-width:8rem}.sub-tabs{display:flex;gap:.35rem}.form-hint{margin:.5rem 0 0;font-size:.85rem;padding:0}.route-cell{font-size:.85rem;color:var(--muted);max-width:14rem}.mileage-badge{font-size:.8rem;color:var(--invoiced)}.stats-toolbar{align-items:flex-end}.filter-clear-btn{align-self:flex-end;margin-bottom:.35rem}.stats-filter-summary{margin:-.5rem 0 1rem;font-size:.85rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.25rem}.stats-panel{background:var(--surface);border-radius:var(--radius);padding:1rem 1.15rem}.stats-panel h3{margin:0 0 .85rem;font-size:1rem}.stats-section-title{margin:.5rem 0 1rem;font-size:1.15rem;font-weight:600}.stats-grid-insights{grid-template-columns:1fr}.stats-insights-top{grid-column:1 / -1;display:grid;grid-template-columns:1fr;gap:1rem;align-items:stretch}@media (min-width: 960px){.stats-insights-top{grid-template-columns:minmax(0,2.35fr) minmax(240px,1fr)}.stats-insights-top .stats-panel-trends,.stats-insights-top .pay-breakdown-panel{min-height:100%}.stats-insights-top .pay-breakdown-panel{width:100%}.stats-insights-top .pay-breakdown-charts{flex:1;justify-content:space-between}.stats-insights-top .pay-breakdown-chart-body{min-height:0;flex:1}.stats-insights-top .pay-breakdown-chart-body .column-chart{min-height:9.5rem}.stats-insights-top .pay-breakdown-chart-body .column-chart-svg{height:100%;min-height:8.5rem}}.stats-insights-row{grid-column:1 / -1;display:grid;grid-template-columns:1fr;gap:1rem;align-items:stretch}@media (min-width: 720px){.stats-insights-row{grid-template-columns:repeat(3,minmax(0,1fr))}}.stats-insights-row .stats-panel{display:flex;flex-direction:column;min-width:0;min-height:100%}.stats-insights-row .stats-panel h3{flex-shrink:0}.stats-insights-row .hbar-chart,.stats-insights-row .bar-chart{flex:1;min-height:0;max-height:18rem;overflow-y:auto;padding-right:.15rem}.stats-insights-row .hbar-row{grid-template-columns:minmax(4.5rem,34%) 1fr minmax(3.5rem,auto)}.stats-insights-row .bar-row{display:grid;grid-template-columns:minmax(4.5rem,34%) 1fr minmax(3.5rem,auto);align-items:center}.stats-insights-row .bar-label{flex:unset;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-insights-row .hbar-value,.stats-insights-row .bar-value{font-size:.75rem;white-space:nowrap}.stats-panel-wide{grid-column:1 / -1}@media (min-width: 900px){.stats-panel-wide{grid-column:span 2}}.chart-empty{margin:.5rem 0;font-size:.85rem}.line-chart{position:relative}.chart-tooltip{position:absolute;z-index:10;pointer-events:none;display:flex;flex-direction:column;gap:.1rem;padding:.35rem .6rem;background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);box-shadow:0 6px 20px #00000047;transform:translate(-50%,calc(-100% - .45rem));line-height:1.25;max-width:min(20rem,90vw);white-space:normal}.chart-tooltip-label{font-size:.68rem;color:var(--muted)}.chart-tooltip-value{font-size:.8rem;font-weight:600;color:var(--text)}.chart-tooltip-detail{font-size:.65rem;color:var(--muted)}.hover-tooltip-anchor{display:inline-flex;vertical-align:top}.app-tooltip-portal{position:fixed;z-index:200}.line-chart{display:flex;flex-direction:column;gap:.35rem}.line-chart-svg{width:100%;max-width:100%;height:auto;display:block}.line-chart-grid{stroke:var(--surface-2);stroke-width:1}.line-chart-line{stroke:var(--accent);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}.line-chart-hit{fill:transparent;cursor:default}.line-chart-hit:focus{outline:none}.line-chart-hit:focus-visible+.line-chart-dot,.line-chart-hit:focus-visible~.line-chart-dot{stroke:var(--accent-hover);stroke-width:2}.line-chart-dot{fill:var(--accent);transition:r .08s ease}.line-chart-dot.is-active{fill:var(--accent-hover)}.line-chart-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);padding:0 .25rem;gap:.15rem}.line-chart-label-skip{visibility:hidden}.stats-period{margin:-.5rem 0 1rem;font-size:.85rem}.line-chart-endpoints{display:flex;justify-content:space-between;font-size:.7rem;color:var(--muted);margin-top:-.15rem}.pay-breakdown-panel{display:flex;flex-direction:column;gap:1.1rem;margin:0}.pay-breakdown-panel>h3{margin-bottom:0}.pay-breakdown-charts{display:flex;flex-direction:column;gap:1.1rem;flex:1}.pay-breakdown-chart{display:flex;flex-direction:column;gap:.35rem;flex:1;min-height:0}.pay-breakdown-chart-body{flex:1;display:flex;flex-direction:column;justify-content:flex-end;min-height:10.5rem}.pay-breakdown-chart-body .column-chart{flex:1;display:flex;flex-direction:column;justify-content:flex-end}.stats-panel-trends{display:flex;flex-direction:column;gap:1.1rem}.stats-panel-trends>h3{margin-bottom:0}.stats-subchart-title{margin:.35rem 0 0;font-size:.92rem;font-weight:600;color:var(--text)}.column-chart{position:relative;display:flex;flex-direction:column;gap:.35rem}.column-chart-svg{width:100%;max-width:100%;height:auto;display:block}.column-chart-hit{fill:transparent;cursor:default}.column-chart-hit:focus{outline:none}.column-chart-bar{opacity:.92;transition:opacity .08s ease}.column-chart-bar.is-active{opacity:1}.column-chart-label{fill:var(--muted);font-size:10px;font-family:inherit}.column-chart-y-label{fill:var(--muted);font-size:9px;font-family:inherit}.hbar-chart{display:flex;flex-direction:column;gap:.45rem}.hbar-row{display:grid;grid-template-columns:minmax(4rem,28%) 1fr auto;align-items:center;gap:.5rem;font-size:.8rem}.hbar-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.hbar-track{min-width:0;background:var(--surface-2);border-radius:4px;height:.65rem;overflow:hidden}.hbar-fill{height:100%;border-radius:4px;transition:width .15s ease}.hbar-value{color:var(--muted);font-size:.75rem;white-space:nowrap}.bar-chart{display:flex;flex-direction:column;gap:.35rem}.bar-row{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.bar-label{flex:0 0 2rem;color:var(--muted)}.bar-track{flex:1 1 auto;min-width:0;background:var(--surface-2);border-radius:4px;height:.65rem;overflow:hidden}.bar-fill{background:var(--accent);height:100%;border-radius:4px;transition:width .15s ease}.bar-value{flex:0 0 auto;text-align:right;color:var(--muted);font-size:.75rem;white-space:nowrap;min-width:4.5rem}.calendar-nav{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.calendar-title-wrap{position:relative;flex:1;display:flex;justify-content:center;min-width:10rem}.calendar-title-btn{margin:0;padding:.25rem .5rem;font-size:1.25rem;font-weight:600;font-family:inherit;color:var(--text);background:none;border:none;border-radius:6px;cursor:pointer}.calendar-title-btn:hover{background:var(--surface-2)}.calendar-month-picker{position:absolute;top:calc(100% + .35rem);left:50%;transform:translate(-50%);z-index:20;display:flex;gap:.75rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--surface-2);border-radius:var(--radius);box-shadow:0 8px 24px #00000059}.calendar-month-picker label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.calendar-grid-wrap{position:relative;margin-bottom:1.25rem;transition:opacity .15s ease}.calendar-grid-wrap.is-refreshing{opacity:.65;pointer-events:none}.calendar-grid-wrap.is-initial-load{opacity:.5}.calendar-loading-hint{position:absolute;top:.5rem;right:.5rem;z-index:2;margin:0;font-size:.8rem;padding:.2rem .5rem;background:var(--surface);border-radius:4px}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:.75rem;color:var(--muted);padding:.35rem;font-weight:600}.calendar-cell{min-height:5.5rem;background:var(--surface);border:1px solid var(--surface-2);border-radius:6px;padding:.35rem;text-align:left;cursor:pointer;color:var(--text);font:inherit;display:flex;flex-direction:column;gap:.2rem}.calendar-cell-empty{background:transparent;border-color:transparent;cursor:default}.calendar-cell.has-events{border-color:var(--accent)}.calendar-cell.today{border-color:var(--calendar-today)}.calendar-cell.today .calendar-day-num{color:var(--calendar-today)}.calendar-cell.selected{background:var(--surface-2)}.calendar-day-num{font-size:.8rem;font-weight:600;color:var(--muted)}.calendar-event-list{list-style:none;margin:0;padding:0;font-size:.7rem;line-height:1.25}.calendar-event-list li{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.calendar-more{color:var(--muted)!important}.calendar-detail h3{margin-top:0}.calendar-detail-list{list-style:none;margin:0;padding:0}.calendar-detail-list li{padding:.65rem 0;border-bottom:1px solid var(--surface-2)}.calendar-detail-link{display:block;text-align:left;padding:0}@media (max-width: 768px){.calendar-cell{min-height:3.5rem}.calendar-event-list{font-size:.65rem}.calendar-event-list li:not(:first-child){display:none}}.field-hint{font-size:.75rem;color:var(--muted);margin-top:.2rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;z-index:100;overflow-y:auto}.modal{background:var(--surface);border-radius:var(--radius);width:min(720px,100%);padding:1.25rem 1.5rem 1.5rem}.event-form h2{margin-top:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1rem}.form-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted)}.form-grid .full-width{grid-column:1 / -1}.combobox{position:relative}.combobox input{width:100%}.combobox-list{position:absolute;z-index:30;top:calc(100% + 2px);left:0;right:0;margin:0;padding:.25rem 0;list-style:none;max-height:11rem;overflow-y:auto;background:var(--surface);border:1px solid var(--surface-2);border-radius:6px;box-shadow:0 8px 24px #00000059}.combobox-list li{display:flex;align-items:center;gap:.25rem;padding:0;font-size:.9rem;color:var(--text)}.combobox-option-pick{flex:1;min-width:0;padding:.45rem .35rem .45rem .65rem;border:none;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.combobox-option-rename{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;margin-right:.2rem;padding:0;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer}.combobox-option-rename:hover{background:var(--surface);color:var(--text)}.combobox-list li.is-active,.combobox-list li:hover{background:var(--surface-2)}.form-actions,.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.modal-divider{border:none;border-top:1px solid var(--surface-2);margin:1.25rem 0}.account-section-title{margin:0 0 .75rem;font-size:.95rem}.account-field{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted);margin-bottom:.75rem}.account-modal form+form{margin-top:0}.notice-box{margin:1rem 0 0;padding:.75rem 1rem;background:var(--surface-2);border-radius:6px;font-size:.9rem;line-height:1.45}.success-msg{color:var(--paid);margin:.75rem 0 0}.user-list{list-style:none;margin:0;padding:0}.user-list li{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--surface-2);font-size:.9rem}.user-list .user-email{display:block;font-size:.8rem}.user-list .badge{margin-left:.35rem;font-size:.7rem;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent) 18%,transparent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.user-list .inactive-badge{color:var(--muted);background:color-mix(in srgb,var(--muted) 20%,transparent);border-color:color-mix(in srgb,var(--muted) 35%,transparent)}.user-list-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.15rem .65rem;flex-shrink:0}.checkbox-label{flex-direction:row;align-items:center;gap:.5rem;color:var(--text)}.create-user-modal{max-width:32rem}.error{color:var(--danger);margin-bottom:1rem}.muted{color:var(--muted);padding:1.5rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.header{flex-direction:column;align-items:stretch}table{font-size:.9rem}}.login-page-wrap{min-height:100vh;display:flex;flex-direction:column}.login-page-wrap .login-page{flex:1;min-height:0}.login-theme-bar{display:flex;justify-content:flex-end;padding:1rem 1.25rem 0;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box}.theme-toggle{display:inline-flex;border:1px solid var(--surface-2);border-radius:999px;overflow:hidden;background:var(--surface);flex-shrink:0}.theme-toggle button{display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--muted);width:2.1rem;height:2.1rem;padding:0;cursor:pointer}.theme-toggle button:hover{color:var(--text);background:var(--surface-2)}.theme-toggle button.is-active{background:var(--accent);color:#fff}
