:root{--radius: 8px;--font: "Roboto", system-ui, sans-serif}[data-mode=dark]{--bg: #121214;--surface: #1c1c1f;--surface-2: #2a2a2e;--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;--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}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-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-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-segments-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.time-segment-add{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem .75rem;align-items:end;margin-bottom:.75rem}@media (max-width: 640px){.time-segment-add{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-segment-edit{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.time-segment-edit-actions{grid-column:1 / -1;display:flex;gap:.5rem}.time-segments-empty{margin:0;font-size:.9rem}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.badge.clocked-in-badge{background:#6ee7b733;color:var(--accent, #6ee7b7);font-size:.7rem;margin-left:.35rem;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{width:auto}.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=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}.upload-pdf-modal h2{margin:0 0 .5rem;font-size:1.15rem}.upload-pdf-help{margin:0 0 1rem;font-size:.9rem}.upload-pdf-events{list-style:none;margin:0 0 1rem;padding:0;max-height:12rem;overflow-y:auto;background:var(--surface-2);border-radius:6px}.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:.5rem;cursor:pointer}.upload-pdf-picker-hint{margin:.5rem 0 0;font-size:.8rem}.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{vertical-align:middle}.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:repeat(auto-fit,minmax(300px,1fr))}.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}.donut-chart{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem 1.25rem}.donut-svg{flex-shrink:0}.donut-legend{list-style:none;margin:0;padding:0;flex:1 1 10rem;min-width:0;font-size:.8rem}.donut-legend li{display:flex;align-items:baseline;gap:.4rem;margin-bottom:.35rem}.donut-swatch{flex-shrink:0;width:.55rem;height:.55rem;border-radius:2px;margin-top:.15rem}.donut-legend-label{flex:1 1 auto;min-width:0}.donut-legend-value{flex-shrink:0;color:var(--muted);font-size:.75rem}.donut-pct{color:var(--muted);opacity:.85}.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-dot{fill:var(--accent)}.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-by-axis-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.pay-by-axis-header h3{margin:0 0 .25rem}.pay-by-axis-help{margin:0;font-size:.8rem;padding:0}.pay-by-axis-select{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--muted);min-width:10rem}.pay-by-axis-chart-wrap{min-height:12rem}.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{display:flex;flex-direction:column;gap:.35rem}.column-chart-svg{width:100%;max-width:100%;height:auto;display:block}.column-chart-bar{opacity:.92}.column-chart-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{padding:.45rem .65rem;font-size:.9rem;color:var(--text);cursor:pointer}.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}
