:root{--bg: #0d1117;--surface: #161b22;--surface2: #1f2937;--border: #30363d;--text: #e6edf3;--muted: #8b949e;--accent: #0078c6;--accent-dim: #006aad;--accent2: #ffdd00;--fabric: #6b9bd1;--samsara: #c9a227;--service: #c97b6b;--error: #e07070;--radius: 10px;font-family:DM Sans,system-ui,sans-serif;color:var(--text);background:var(--bg);line-height:1.45}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .25s ease both}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.login-view{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(ellipse at 60% 30%,rgba(0,120,198,.07) 0%,transparent 65%),radial-gradient(ellipse at 20% 80%,rgba(255,221,0,.05) 0%,transparent 60%),var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:48px 52px;text-align:center;max-width:420px;width:90%;box-shadow:0 20px 60px #00000080}.login-logo-text{font-size:26px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.login-logo-sub{font-size:11px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:2px}.login-title{font-size:18px;font-weight:700;margin:24px 0 6px}.login-desc{font-size:13px;color:var(--muted);margin-bottom:32px;line-height:1.6}.btn-ms{background:#0078d4;color:#fff;width:100%;justify-content:center;padding:11px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;gap:10px;display:inline-flex;align-items:center;transition:background .15s}.btn-ms:hover:not(:disabled){background:#106ebe}.btn-ms:disabled{opacity:.6;cursor:default}.login-error{margin-top:16px;font-size:12px;color:var(--error);background:#ee312414;border:1px solid rgba(238,49,36,.2);border-radius:8px;padding:10px 12px}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:100}.header-logo{font-size:16px;font-weight:800;color:var(--accent);letter-spacing:-.5px;flex-shrink:0}.header-title{font-size:13px;color:var(--muted);flex-shrink:0}.header-nav{display:flex;gap:4px;margin-left:8px;flex-wrap:wrap}.header-nav__link{font-size:12.5px;font-weight:600;color:var(--muted);padding:6px 12px;border-radius:8px;cursor:pointer;transition:background .15s,color .15s;background:transparent;border:none;font-family:inherit}.header-nav__link:hover{background:var(--surface2);color:var(--text)}.header-nav__link.active{background:var(--surface2);color:var(--accent2)}.header-spacer{flex:1}.header-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;background:#0078c626;color:var(--accent)}.header-user{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.header-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.header-user-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-signout{padding:4px 10px;font-size:11px}.header-dev{font-size:11px}.app-main{max-width:1600px;margin:0 auto;padding:1.25rem 1.5rem 2rem}.btn--ghost{background:transparent;border:1px solid var(--border);color:var(--muted);padding:.35rem .75rem;border-radius:6px;cursor:pointer}.btn--ghost:hover{color:var(--text);border-color:var(--muted)}code,.mono{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.85em}.muted{color:var(--muted);font-size:.875rem}.topbar__controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.control{display:flex;flex-direction:column;gap:.3rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.control--grow{min-width:220px}.control select,.control input{font:inherit;font-size:.95rem;text-transform:none;letter-spacing:normal;color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:.5rem .65rem}.banner{background:var(--surface2);border:1px solid var(--accent-dim);border-left:4px solid var(--accent);border-radius:var(--radius);padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;color:var(--muted)}.banner--error{border-color:var(--error);border-left-color:var(--error);color:var(--error)}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1.25rem}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;display:flex;flex-direction:column;gap:.2rem}.kpi-card--accent{border-color:var(--accent-dim);background:#152420}.kpi-card__label{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.kpi-card__value{font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.kpi-card__hint{font-size:.78rem;color:var(--muted)}.layout{display:grid;grid-template-columns:1fr;gap:1rem;min-height:480px}.layout--split{grid-template-columns:1fr minmax(340px,420px)}.main-panel,.detail-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.panel-head__actions{display:flex;align-items:center;gap:.75rem}.panel-head{padding:.85rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline;justify-content:space-between}.panel-head h2{margin:0;font-size:1rem;font-weight:600}.pad{padding:1rem}.table-wrap{overflow:auto;max-height:calc(100vh - 280px)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{position:sticky;top:0;background:var(--surface2);text-align:left;padding:.55rem .75rem;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border)}.data-table th.num,.data-table td.num{text-align:right}.data-table td{padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:top}.data-table tbody tr{cursor:pointer;transition:background .12s}.data-table tbody tr:hover{background:var(--surface2)}.data-table tbody tr.selected{background:#1a2a28;outline:1px solid var(--accent-dim)}.unit-cell{display:flex;flex-direction:column;gap:.15rem}.match-note{font-size:.72rem;color:var(--accent)}.badges{display:flex;flex-wrap:wrap;gap:.25rem}.badge{font-size:.65rem;padding:.15rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}.badge--fabric{background:#6b9bd133;color:var(--fabric)}.badge--samsara{background:#c9a22726;color:var(--samsara)}.badge--service{background:#c97b6b26;color:var(--service)}.badge--live{background:#48bb7833;color:#48bb78;margin-left:.35rem}.badge--csv{background:#a0aec033;color:var(--muted);margin-left:.35rem}.setup-view{display:flex;flex-direction:column;gap:1.25rem}.setup-view__header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem}.setup-view__header h2{margin:0 0 .35rem}.setup-card h3{margin:0 0 .75rem;font-size:1.05rem}.setup-card h4{margin:1.25rem 0 .5rem;font-size:.95rem}.setup-lead{margin:0 0 1rem}.setup-steps{margin:0;padding-left:1.25rem}.setup-steps li{margin-bottom:.65rem}.setup-copy{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin:.35rem 0}.setup-table{width:100%;border-collapse:collapse;font-size:.875rem}.setup-table td,.setup-table th{padding:.45rem .5rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.setup-table--compact th{color:var(--muted);font-weight:500}.setup-pill{display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;margin-right:.25rem}.setup-pill--ok{background:#3d9a8b40;color:#7dd3c4}.setup-pill--bad{background:#e0707033;color:var(--error)}.setup-pill--unknown{background:#8b9aab26;color:var(--muted)}.setup-note{margin:1rem 0 0;padding:.75rem;background:var(--surface2);border-radius:var(--radius);border-left:3px solid var(--samsara)}.detail-panel{display:flex;flex-direction:column;max-height:calc(100vh - 200px)}.detail-panel__header{display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;border-bottom:1px solid var(--border)}.detail-panel__header h2{margin:0;font-size:1.1rem}.btn-ghost{background:none;border:none;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .25rem}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 .5rem}.tabs__btn{background:none;border:none;color:var(--muted);font:inherit;font-size:.8rem;padding:.65rem .75rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs__btn.active{color:var(--accent);border-bottom-color:var(--accent)}.detail-panel__body{padding:1rem;overflow:auto;flex:1}.detail-stats{display:grid;gap:.75rem;margin:0}.detail-stats>div{display:grid;grid-template-columns:140px 1fr;gap:.5rem}.detail-stats dt{margin:0;color:var(--muted);font-size:.8rem}.detail-stats dd{margin:0;font-weight:500}.callout{grid-column:1 / -1;background:var(--surface2);border-radius:8px;padding:.65rem .75rem;font-size:.85rem;color:var(--muted)}.mini-table-wrap--all-lines{max-height:none}.detail-panel__body .mini-table-wrap--all-lines{overflow:visible}.mini-table-wrap{overflow:auto;max-height:360px}.mini-table{width:100%;border-collapse:collapse;font-size:.78rem}.mini-table th,.mini-table td{padding:.4rem .5rem;border-bottom:1px solid var(--border);text-align:left}.mini-table .route{max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty{padding:2rem;text-align:center;color:var(--muted)}@media(max-width:960px){.layout--split{grid-template-columns:1fr}.detail-panel{max-height:none}.unit-analysis{grid-template-columns:1fr}}.pad-sm{padding:.5rem}.sidebar-hint{font-size:.8rem;color:var(--muted);margin:.25rem 0 0}.topbar__controls--inline{margin-bottom:1rem}.unit-analysis{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:1rem;align-items:start}.unit-analysis__sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;position:sticky;top:1rem;max-height:calc(100vh - 120px);overflow:auto}.control--full{width:100%;margin-bottom:.75rem}.unit-picker{display:flex;flex-direction:column;gap:2px;max-height:220px;overflow:auto;margin-bottom:1rem;border:1px solid var(--border);border-radius:8px}.unit-picker__item{display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;padding:.5rem .65rem;border:none;background:transparent;color:var(--text);font:inherit;text-align:left;cursor:pointer;border-bottom:1px solid var(--border)}.unit-picker__item:last-child{border-bottom:none}.unit-picker__item:hover{background:var(--surface2)}.unit-picker__item.active{background:#1a2a28;border-left:3px solid var(--accent)}.month-multi__presets{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.6rem}.chip{font:inherit;font-size:.72rem;padding:.25rem .55rem;border-radius:999px;border:1px solid var(--border);background:var(--surface2);color:var(--muted);cursor:pointer}.chip--active,.chip:hover{border-color:var(--accent-dim);color:var(--accent)}.month-multi__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem .5rem}.month-check{display:flex;align-items:center;gap:.35rem;font-size:.8rem;cursor:pointer}.month-check input{accent-color:var(--accent)}.backfill-tag{font-size:.65rem;color:var(--samsara);font-style:normal;margin-left:.25rem}.month-multi__hint{margin:.5rem 0 0;font-size:.75rem}.unit-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.driver-metric-tabs{flex-shrink:0}.product-by-product{margin-bottom:1rem}.product-section-title{margin:0 0 .5rem;font-size:.95rem;font-weight:600}.data-table--compact th,.data-table--compact td{padding:.35rem .5rem;font-size:.82rem}.product-cell{font-size:.8rem;max-width:14rem}.unit-volume-panel{margin-top:.5rem}.product-trip-detail{margin-top:1rem}.detail-note{margin-top:.75rem;font-size:.85rem}.unit-hero h2{margin:0;font-size:1.35rem}.rank-note{font-size:.8rem;color:var(--accent);margin:.35rem 0 0}.btn{font:inherit;font-size:.85rem;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--accent-dim);background:var(--accent-dim);color:var(--text);cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:hover:not(:disabled){background:var(--accent)}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.btn--primary:hover:not(:disabled){background:var(--accent-dim);border-color:var(--accent-dim)}.trend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem;margin-bottom:1rem}.trend-bars{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem}.trend-bars__title{margin:0 0 .75rem;font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.trend-bars__chart{display:flex;align-items:flex-end;gap:.5rem;height:140px}.trend-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.trend-bar__value{font-size:.65rem;color:var(--muted);margin-bottom:.25rem;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.trend-bar__track{flex:1;width:100%;max-width:48px;background:var(--surface2);border-radius:4px 4px 0 0;display:flex;align-items:flex-end;overflow:hidden}.trend-bar__fill{width:100%;height:var(--bar-h, 0%);border-radius:4px 4px 0 0;min-height:2px;transition:height .3s ease}.trend-bar__fill--serviceCost{background:var(--service)}.trend-bar__fill--samsaraKm{background:var(--samsara)}.trend-bar__fill--fabricTrips{background:var(--fabric)}.trend-bar__fill--costPerKm{background:var(--accent)}.trend-bar__label{font-size:.7rem;color:var(--muted);margin-top:.35rem}.trend-bars__caption{margin:.5rem 0 0;font-size:.7rem}.compare-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:1rem}.compare-panel h3{margin:0 0 .75rem;font-size:.95rem}.compare-selects{display:flex;gap:1rem;margin-bottom:1rem}.compare-selects label{display:flex;flex-direction:column;gap:.25rem;font-size:.75rem;color:var(--muted)}.compare-selects select{font:inherit;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:.35rem .5rem}.compare-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.compare-metric{background:var(--surface2);border-radius:8px;padding:.65rem .75rem}.compare-metric__label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.compare-metric__vals{display:flex;align-items:center;gap:.5rem;font-weight:600;margin:.35rem 0;font-size:.9rem}.compare-arrow{color:var(--muted);font-weight:400}.compare-delta{font-size:.8rem;font-weight:600}.compare-delta.up{color:var(--service)}.compare-delta.down{color:var(--accent)}.totals-row{background:var(--surface2);font-weight:600}.totals-row td{border-top:2px solid var(--border)}.warn-tag{display:inline-block;font-size:.65rem;color:var(--samsara);margin-left:.35rem}.planner__intro{margin-bottom:1rem}.planner__grid{display:grid;grid-template-columns:1fr minmax(300px,400px);gap:1rem;align-items:start}.planner__form{padding:1.25rem}.planner__form h2,.planner__result h2{margin:0 0 1rem;font-size:1.05rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field span{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.field input,.field select,.field__search{font:inherit;padding:.5rem .65rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.planner-note{font-size:.8rem;margin:.25rem 0}.planner__result{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;position:sticky;top:1rem}.kpi-row--stack{grid-template-columns:1fr;margin-bottom:1rem}.cost-breakdown{width:100%;border-collapse:collapse;font-size:.9rem}.cost-breakdown td{padding:.5rem .35rem;border-bottom:1px solid var(--border)}.cost-breakdown td.num{text-align:right;white-space:nowrap}.planner-disclaimer{font-size:.75rem;margin-top:1rem}.link-btn{font:inherit;font-size:.7rem;text-transform:none;letter-spacing:0;margin-left:.5rem;padding:0;border:none;background:none;color:var(--accent);cursor:pointer;text-decoration:underline}@media(max-width:900px){.planner__grid{grid-template-columns:1fr}.planner__result{position:static}.field-row{grid-template-columns:1fr}}.row-excluded{opacity:.45}.row-excluded td{text-decoration:line-through}.breakdown-toolbar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:.75rem}.breakdown-toolbar .seg{display:inline-flex;border:1px solid var(--border);border-radius:6px;overflow:hidden}.breakdown-toolbar .seg button{font:inherit;font-size:.8rem;padding:.35rem .75rem;border:none;background:transparent;color:var(--muted);cursor:pointer}.breakdown-toolbar .seg button.active{background:var(--accent-dim);color:var(--accent)}.month-cell-click{cursor:pointer;-webkit-user-select:none;user-select:none}.month-cell-click:hover{color:var(--accent)}.month-detail{background:var(--bg);border-top:1px solid var(--border)}.month-detail td{padding:.75rem 1rem;vertical-align:top}.month-detail__tickets{max-width:100%;overflow-x:auto}.month-detail__tickets table{width:100%;font-size:.8rem}.month-detail__tickets th,.month-detail__tickets td{padding:.35rem .5rem;text-decoration:none}.driver-list{margin:.5rem 0 0;padding-left:1.1rem;font-size:.8rem;color:var(--muted)}.driver-list li{margin:.2rem 0}.hos-note{font-size:.75rem;color:var(--muted);margin-top:.5rem;padding:.5rem;border-left:3px solid var(--border)}.hos-panel{margin-top:.5rem}.hos-table{width:100%;max-width:420px;border-collapse:collapse;font-size:.9rem}.hos-table th{text-align:left;font-weight:600;padding:.45rem .75rem .45rem 0;color:var(--muted);width:55%}.hos-table td{padding:.45rem 0;font-weight:500}.hos-table__flagged td{background:#fef08a33;color:#f87171;font-weight:700}.driver-detail-grid{display:grid;gap:1.25rem;grid-template-columns:minmax(200px,280px) 1fr;align-items:start}.driver-metrics-inline{display:flex;flex-direction:column;gap:.75rem}.driver-metrics-inline strong{display:block;font-size:1.25rem;margin-top:.15rem}@media(max-width:800px){.driver-detail-grid{grid-template-columns:1fr}}@keyframes skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.btn-refresh{padding:.35rem .75rem;margin-right:.6rem;font-size:.85rem}.skeleton-block{display:inline-block;background:linear-gradient(90deg,#0000000f 25%,#0000001f 37%,#0000000f 63%);background-size:400% 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite}.skeleton-rows{display:grid;gap:.5rem}.skeleton-row{display:grid;grid-template-columns:repeat(var(--skeleton-cols, 4),1fr);gap:.75rem}.skeleton-list{display:grid;gap:.4rem;padding:.5rem}.warm-banner{padding:.5rem 1rem;background:#1f2d3a;color:#b4d4ff;display:flex;align-items:center;gap:.75rem;font-size:.9rem}.warm-banner--error{background:#3a1f1f;color:#ffb4b4}.warm-banner__message{flex:1}.warm-banner .btn,.warm-banner .btn-ghost{font-size:.85rem}.banner__retry{margin-left:.75rem;font-size:.85rem}.error-boundary{margin:1rem}.error-boundary p{margin-top:.5rem;white-space:pre-wrap}.error-boundary__reload{margin-top:.75rem}
