body{margin:0;min-height:100vh}:root{--bg: #0f1419;--surface: #1a2332;--surface-2: #243044;--text: #e8edf4;--muted: #8b9cb3;--accent: #3d9cf5;--accent-hover: #5aadff;--danger: #f07178;--paid: #7fd99a;--pending: #f0c674;--invoiced: #82aaff;--calendar-today: #e8b84a;--radius: 10px;--font: "Segoe UI", system-ui, sans-serif}*{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{display:flex;flex-wrap:wrap;gap:.35rem}.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}.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}.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}.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-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:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge.paid{background:#7fd99a33;color:var(--paid)}.badge.pending{background:#f0c67433;color:var(--pending)}.badge.invoiced{background:#82aaff33;color:var(--invoiced)}.status-badge-btn{border:none;font:inherit;cursor:pointer}.status-badge-btn:hover{filter:brightness(1.08)}.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.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}.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}.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}}
