/* DieselUp Dispatch Console — design system
   Direction: industrial fleet-command terminal. Near-black canvas, lime as the "energy/savings"
   signal, tabular numerics, precise lines, generous breathing room. Not a template. */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap');

:root{
  --bg:#0A0A0A; --bg-2:#0e0f11;
  --surface:#121316; --surface-2:#17191d; --surface-3:#1d2025;
  --line:#23262c; --line-2:#2d3138;
  --text:#F4F6F3; --text-2:#aeb4bd; --muted:#787f89;
  --lime:#84CC16; --lime-bright:#a3e635; --lime-dim:#4d7c0f; --lime-glow:rgba(132,204,22,.18);
  --red:#f04444; --amber:#f5a524; --blue:#3b82f6; --orange:#fb923c;
  --green:#84CC16;
  --radius:14px; --radius-sm:10px; --radius-lg:20px;
  --shadow:0 1px 0 rgba(255,255,255,.02) inset, 0 8px 30px rgba(0,0,0,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(1200px 600px at 78% -10%, rgba(132,204,22,.07), transparent 60%),
    radial-gradient(900px 500px at -5% 110%, rgba(59,130,246,.05), transparent 55%),
    var(--bg);
  color:var(--text); font-family:var(--sans); font-size:14px; line-height:1.5;
  -webkit-font-smoothing:antialiased; letter-spacing:-.01em;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.muted{color:var(--muted)}
.dim{color:var(--text-2)}

/* ---------- App shell ---------- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;background:linear-gradient(180deg,var(--bg-2),#0b0c0e);
  border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 16px;gap:6px;
}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px;border-bottom:1px solid var(--line);margin-bottom:14px}
.brand .mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;
  background:linear-gradient(145deg,var(--lime),var(--lime-dim));color:#0a0a0a;font-weight:800;
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 6px 18px var(--lime-glow);font-size:18px}
.brand b{font-weight:800;font-size:16px;letter-spacing:-.02em}
.brand small{display:block;color:var(--muted);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;margin-top:1px}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--text-2);
  font-weight:500;transition:.16s var(--ease)}
.nav a svg{width:17px;height:17px;opacity:.8}
.nav a:hover{background:var(--surface);color:var(--text)}
.nav a.active{background:var(--lime-glow);color:var(--lime-bright)}
.nav a.active svg{opacity:1}
.nav .sep{height:1px;background:var(--line);margin:10px 6px}
.sidebar .foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.sidebar .foot .foot-label{display:block;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:3px}
.sidebar .foot .foot-customer{display:block;color:var(--text);font-size:13px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar .foot .foot-email{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;
  padding:14px 28px;background:rgba(10,10,10,.72);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.topbar h1{font-size:18px;font-weight:700;margin:0;letter-spacing:-.02em}
.topbar .sub{color:var(--muted);font-size:12.5px;margin-top:1px}
.spacer{flex:1}
.content{padding:26px 28px 60px;max-width:1480px;width:100%}

/* view toggle */
.toggle{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:3px}
.toggle a{padding:6px 13px;border-radius:8px;font-weight:600;font-size:12.5px;color:var(--text-2)}
.toggle a.active{background:linear-gradient(145deg,var(--lime),var(--lime-dim));color:#0a0a0a}

.userchip{display:flex;align-items:center;gap:10px;max-width:220px;min-width:0;padding:6px 7px 6px 12px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;font-size:12.5px}
.userchip .account-copy{display:grid;gap:1px;min-width:0;line-height:1.1}
.userchip b{display:block;color:var(--text);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.userchip small{display:block;color:var(--muted);font-size:10.5px;text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.userchip .av{width:26px;height:26px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;
  font-weight:700;color:var(--lime-bright)}

/* ---------- Cards & grid ---------- */
.grid{display:grid;gap:16px}
.cols-4{grid-template-columns:repeat(4,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);position:relative}
.card.pad-lg{padding:24px}
.card h3{margin:0 0 3px;font-size:13px;font-weight:600;color:var(--text-2)}
.card .hint{font-size:11.5px;color:var(--muted)}
.section-title{display:flex;align-items:center;gap:10px;margin:30px 2px 14px;font-size:13px;
  font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.section-title::after{content:"";flex:1;height:1px;background:var(--line)}

/* KPI */
.kpi .label{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.kpi .value{font-size:30px;font-weight:700;margin-top:8px;letter-spacing:-.03em}
.kpi .value.lime{color:var(--lime-bright)}
.kpi .delta{font-size:12px;margin-top:8px;color:var(--text-2);display:flex;gap:8px;flex-wrap:wrap}
.kpi .spark{height:34px;margin-top:10px}

/* money hero */
.hero{background:
    radial-gradient(700px 300px at 12% -40%, var(--lime-glow), transparent 60%),
    linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:30px 32px;overflow:hidden}
.hero .cap{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.hero .big{font-size:clamp(44px,7vw,86px);font-weight:800;line-height:.95;letter-spacing:-.04em;
  color:var(--lime-bright);text-shadow:0 0 40px var(--lime-glow);margin:8px 0 2px}
.hero .row{display:flex;gap:26px;flex-wrap:wrap;margin-top:18px}
.hero .row .stat .n{font-size:22px;font-weight:700;letter-spacing:-.02em}
.hero .row .stat .l{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}
.hero .lost{margin-top:22px;padding:14px 16px;border-radius:12px;background:rgba(240,68,68,.08);
  border:1px solid rgba(240,68,68,.25);color:#ffb4b4;font-weight:500}
.hero .lost b{color:#ff6b6b}

/* pills, badges */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:30px;font-size:11.5px;
  font-weight:600;background:var(--surface-3);color:var(--text-2);border:1px solid var(--line)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--muted)}
.pill.green{color:var(--lime-bright);background:var(--lime-glow);border-color:transparent}.pill.green .dot{background:var(--lime)}
.pill.red{color:#ffb4b4;background:rgba(240,68,68,.12)}.pill.red .dot{background:var(--red)}
.pill.amber{color:#ffd591;background:rgba(245,165,36,.12)}.pill.amber .dot{background:var(--amber)}
.pill.blue{color:#bcd4ff;background:rgba(59,130,246,.14)}.pill.blue .dot{background:var(--blue)}
.pill.orange{color:#ffd0a8;background:rgba(251,146,60,.14)}.pill.orange .dot{background:var(--orange)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:10px;border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--text);font-weight:600;font-size:13px;cursor:pointer;transition:.15s var(--ease)}
.btn:hover{border-color:var(--lime-dim);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(145deg,var(--lime),var(--lime-dim));color:#0a0a0a;border-color:transparent;
  box-shadow:0 6px 20px var(--lime-glow)}
.btn.primary:hover{filter:brightness(1.06)}
.btn.danger:hover{border-color:var(--red);color:#ffb4b4}
.btn.sm{padding:6px 11px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}
tbody td{padding:11px 12px;border-bottom:1px solid var(--line)}
tbody tr{transition:.12s var(--ease)}
tbody tr:hover{background:var(--surface)}
tbody tr.clickable{cursor:pointer}

/* fuel ring + gauges */
.ring{--p:0;--c:var(--lime);width:120px;height:120px;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(var(--c) calc(var(--p)*1%),var(--surface-3) 0);position:relative}
.ring::before{content:"";position:absolute;inset:9px;border-radius:50%;background:var(--bg-2)}
.ring .pv{position:relative;font-family:var(--mono);font-weight:700;font-size:26px}
.ring .pl{position:relative;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}

/* activity feed */
.feed{display:flex;flex-direction:column;gap:2px;max-height:560px;overflow:auto}
.feed .item{display:flex;gap:11px;padding:11px 8px;border-bottom:1px solid var(--line);align-items:flex-start}
.feed .item .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none;
  background:var(--surface-3);font-size:14px}
.feed .item.fill .ic{background:var(--lime-glow)}
.feed .item.flag .ic{background:rgba(251,146,60,.14)}
.feed .item .tx{font-size:12.8px;color:var(--text)}
.feed .item .ts{font-size:11px;color:var(--muted);margin-top:2px}

/* map */
#map{height:560px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
#livemap{height:calc(100vh - 260px);min-height:620px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.leaflet-container{background:#0b0d10!important;font-family:var(--sans)}
.leaflet-popup-content-wrapper{background:var(--surface-2);color:var(--text);border:1px solid var(--line-2);border-radius:12px}
.leaflet-popup-tip{background:var(--surface-2)}
.truck-dot{border-radius:50%;border:2px solid #0a0a0a;box-shadow:0 0 0 1px rgba(255,255,255,.12),0 0 12px currentColor}
.map-command{display:grid;grid-template-columns:repeat(4,minmax(110px,1fr)) minmax(280px,1.4fr);gap:10px;margin-bottom:12px}
.live-stat{min-height:72px;padding:13px 14px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,var(--surface),var(--bg-2));box-shadow:var(--shadow)}
.live-stat span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em}
.live-stat b{display:block;margin-top:4px;font:800 28px/1 var(--mono);color:var(--text)}
.live-stat.good b{color:var(--lime-bright)}
.live-stat.warn b{color:#ffd591}
.live-tools{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}
.input.dark{width:100%;height:36px;border:1px solid var(--line-2);border-radius:10px;background:var(--bg-2);color:var(--text);padding:0 12px;font:600 13px var(--sans);outline:none}
.input.dark:focus{border-color:var(--lime-dim);box-shadow:0 0 0 3px rgba(132,204,22,.08)}
.live-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.live-filter .btn.active{background:linear-gradient(145deg,var(--lime),var(--lime-dim));color:#0a0a0a;border-color:transparent}
.live-map-layout{display:grid;grid-template-columns:minmax(0,1.6fr) 360px;gap:16px;align-items:start}
.live-map-card{padding:16px}
.map-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px}
.map-head h3,.live-side h3{margin:0;font-size:14px;color:var(--text)}
.map-head p{margin:2px 0 0;color:var(--muted);font-size:12px}
.live-legend{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;color:var(--muted);font-size:11.5px}
.live-legend i{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
.live-side{position:sticky;top:86px;max-height:calc(100vh - 116px);display:flex;flex-direction:column;gap:12px;overflow:hidden}
.selected-truck{border:1px solid rgba(159,192,255,.22);border-radius:12px;background:rgba(59,130,246,.06);padding:14px}
.selected-truck.empty{padding:18px;color:var(--muted);text-align:left}
.selected-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}
.selected-grid span{display:block;padding:8px;border-radius:9px;background:rgba(255,255,255,.035);color:var(--muted);font-size:12px}
.selected-grid b{display:block;color:var(--text);font-family:var(--mono);font-size:15px;margin-top:1px}
.mini-proof{margin:10px 0;padding:10px;border:1px solid var(--line);border-radius:10px;background:rgba(0,0,0,.18);font-size:12px}
.mini-proof a{color:#9fc0ff;font-weight:700}
.truck-roster{display:flex;flex-direction:column;gap:6px;overflow:auto;padding-right:2px}
.truck-row{width:100%;display:grid;grid-template-columns:1fr 54px 58px;align-items:center;gap:8px;text-align:left;padding:10px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.025);color:var(--text);cursor:pointer}
.truck-row:hover,.truck-row.active{border-color:rgba(132,204,22,.45);background:rgba(132,204,22,.08)}
.truck-row small{display:block;color:var(--muted);font-size:11.5px;margin-top:1px}
.live-pin{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(10,10,10,.82);border:2px solid var(--pin);color:var(--pin);box-shadow:0 0 0 1px rgba(255,255,255,.12),0 0 18px color-mix(in srgb,var(--pin) 45%,transparent)}
.live-pin span{display:grid;place-items:center;transform-origin:center}
.live-pin.stale{opacity:.78}
.toggle .ck{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:8px;font-weight:600;font-size:12.5px;color:var(--text-2);cursor:pointer}
.toggle .ck input{accent-color:var(--lime);margin:0}
.lgnd{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle;margin-right:2px}

/* skeleton / empty */
.skel{background:linear-gradient(90deg,var(--surface) 25%,var(--surface-3) 37%,var(--surface) 63%);
  background-size:400% 100%;animation:sh 1.3s infinite;border-radius:8px}
@keyframes sh{0%{background-position:100% 0}100%{background-position:-100% 0}}
.empty{padding:40px;text-align:center;color:var(--muted)}
.empty .big{font-size:30px;margin-bottom:8px;opacity:.5}

/* IFTA explainer */
.ifta{display:flex;gap:12px;padding:14px 16px;border-radius:12px;background:rgba(59,130,246,.06);
  border:1px solid rgba(59,130,246,.22);font-size:12.8px;color:#cdd9f0}
.ifta b{color:#9fc0ff}
.support-link{display:inline-block;margin-top:8px;color:var(--lime-bright);font-weight:700}
.support-link:hover,.contact-email:hover{text-decoration:underline;text-underline-offset:3px}
.integration-head{margin-bottom:16px;align-items:stretch}
.contact-card{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px}
.contact-card .label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.contact-email{color:var(--lime-bright);font-weight:800;font-size:18px;letter-spacing:0}
.report-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px;
  padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface),var(--bg-2));box-shadow:var(--shadow)}
.report-downloads{justify-content:flex-end}
.report-meaning{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:-8px 0 16px;
  padding:10px;border:1px solid rgba(255,255,255,.06);border-radius:12px;
  background:linear-gradient(180deg,rgba(18,19,22,.78),rgba(10,10,10,.72));
  box-shadow:0 14px 30px rgba(0,0,0,.28),0 1px 0 rgba(255,255,255,.03) inset}
.meaning-item{padding:8px 9px;border-radius:9px;background:rgba(255,255,255,.025)}
.meaning-item b{display:block;margin-bottom:3px;color:var(--text);font-size:12.5px}
.meaning-item span{display:block;color:var(--text-2);font-size:11.5px;line-height:1.35}
.winner-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:10px 0 14px;
  padding:13px 14px;border-radius:12px;border:1px solid rgba(132,204,22,.28);
  background:linear-gradient(135deg,rgba(132,204,22,.18),rgba(132,204,22,.04))}
.winner-strip b{display:block;margin-top:5px;font-size:15px}
.winner-strip .num{color:var(--lime-bright);font-weight:800;font-size:22px}

/* Recommendation receipt */
.receipt-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}
.receipt-head h2{margin:4px 0 2px;font-size:30px;line-height:1.05;letter-spacing:0}
.receipt-head h2 span{color:var(--muted);font-weight:700}
.receipt-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.receipt-kpis{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:16px}
.receipt-kpi{min-height:118px}
.receipt-kpi .hint{margin-top:8px}
.receipt-grid{display:grid;grid-template-columns:minmax(300px,.48fr) minmax(0,1fr);gap:16px}
.receipt-stack{display:flex;flex-direction:column;gap:14px}
.receipt-proof h3,.receipt-map-card h3{margin:0;color:var(--text);font-size:14px}
.receipt-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line)}
.receipt-line span{color:var(--muted)}
.receipt-line b{text-align:right;font-weight:700}
.receipt-message{margin-top:12px;padding:12px;border-radius:10px;background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.22);
  color:#d4e2ff;font-size:12.5px;line-height:1.45}
.receipt-map-card{background:linear-gradient(180deg,var(--surface),var(--bg-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
#receiptmap{height:430px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#0b0d10}
.receipt-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;color:var(--text-2);font-size:12px}
.receipt-legend i{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:5px;vertical-align:-1px}
.receipt-legend .sel{background:var(--lime)}.receipt-legend .valid{background:var(--amber)}
.receipt-legend .out{background:var(--muted)}.receipt-legend .truck{background:var(--blue)}
.receipt-stops{display:flex;flex-direction:column;gap:8px;max-height:520px;overflow:auto}
.receipt-stop{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:10px;
  border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.025)}
.receipt-stop.selected{border-color:rgba(132,204,22,.5);background:rgba(132,204,22,.08)}
.receipt-stop.out_of_range{opacity:.68}
.receipt-stop b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.receipt-stop span:not(.pill){display:block;color:var(--muted);font-size:11.5px}
.receipt-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.receipt-chip{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;
  padding:10px;border:1px solid var(--line);border-radius:10px;background:rgba(255,255,255,.025);transition:.15s var(--ease)}
.receipt-chip:hover{border-color:var(--lime-dim);background:rgba(132,204,22,.08);transform:translateY(-1px)}
.receipt-chip b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.receipt-chip .muted{grid-column:2/4;font-size:11.5px}

/* misc */
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.stack{display:flex;flex-direction:column;gap:14px}
.admin-overview{grid-template-columns:1fr 1.1fr 1.1fr;margin-bottom:16px}
.admin-main{grid-template-columns:1fr 1fr}
.admin-id{background:linear-gradient(180deg,rgba(132,204,22,.08),var(--bg-2))}
.admin-id .label,.admin-list .admin-row span:first-child{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.admin-customer{font-size:28px;font-weight:800;letter-spacing:0;margin-top:6px}
.admin-list{display:flex;flex-direction:column;gap:8px;margin-top:13px}
.admin-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line)}
.admin-row:last-child{border-bottom:0}
.admin-row b{font-size:13px;color:var(--text);text-align:right}
.table-scroll{overflow:auto}

/* ---------- Platform superadmin portal ---------- */
.platform-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr);background:
  radial-gradient(900px 420px at 80% -10%,rgba(132,204,22,.08),transparent 56%),var(--bg)}
.platform-side{display:flex;flex-direction:column;min-height:100vh;padding:24px 18px;border-right:1px solid var(--line);
  background:linear-gradient(180deg,rgba(18,20,24,.86),rgba(9,10,10,.92))}
.platform-nav{display:flex;flex-direction:column;gap:6px;margin-top:26px}
.platform-nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:10px;color:var(--text-2);font-weight:600}
.platform-nav a.active,.platform-nav a:hover{background:var(--lime-glow);color:var(--lime-bright)}
.platform-main{min-width:0;padding:28px;max-width:1480px;width:100%}
.platform-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px}
.platform-top h1{font-size:28px;letter-spacing:0;margin:0}
.platform-top .sub{color:var(--muted);font-size:13px;margin-top:3px}
.platform-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.platform-kpi{padding:16px}.platform-kpi span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.09em}
.platform-kpi b{display:block;color:var(--text);font-size:28px;margin-top:8px;letter-spacing:0;font-variant-numeric:tabular-nums}
.platform-control{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.platform-search{min-width:280px;display:flex;align-items:center;gap:9px;padding:10px 12px;border:1px solid var(--line-2);
  border-radius:12px;background:var(--surface)}
.platform-search input{width:100%;border:0;outline:0;background:transparent;color:var(--text);font-family:var(--sans)}
.platform-new{margin-bottom:16px}.platform-new .inp{width:100%;padding:11px 13px;background:var(--surface-2);
  border:1px solid var(--line-2);border-radius:9px;color:var(--text);font-family:var(--sans)}
.platform-customers{display:grid;gap:12px}.customer-card{padding:18px}
.customer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.customer-head h2{margin:4px 0 0;font-size:19px;letter-spacing:0;color:var(--text)}
.customer-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.customer-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px}
.customer-metric{padding:11px;border:1px solid var(--line);border-radius:10px;background:var(--surface-2)}
.customer-metric b{display:block;color:var(--text);font-size:18px;font-variant-numeric:tabular-nums}
.customer-metric span{display:block;color:var(--muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;margin-top:3px}
.customer-status{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px}
.customer-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--line);
  padding-top:12px;color:var(--muted);font-size:12px}
.platform-login{min-height:100vh;display:grid;place-items:center;padding:24px}
.flex{display:flex;gap:10px;align-items:center}
.wrap{flex-wrap:wrap}
.tag-cost{font-family:var(--mono);font-weight:700}
.up{animation:pop .5s var(--ease)}
@keyframes pop{0%{transform:scale(1)}30%{transform:scale(1.08);color:var(--lime-bright)}100%{transform:scale(1)}}
.toast{position:fixed;bottom:24px;right:24px;background:var(--surface-2);border:1px solid var(--line-2);
  border-radius:12px;padding:13px 17px;box-shadow:var(--shadow);z-index:100;animation:pop .3s var(--ease);max-width:340px}
.toast.ok{border-color:var(--lime-dim)}.toast.err{border-color:var(--red)}

/* AI Assistant — command board */
.ai-board{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.55fr);gap:16px;align-items:start}
.ai-hero,.ai-console,.ai-side,.ai-answer-panel{
  border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden}
.ai-hero{grid-column:1/-1;display:flex;align-items:flex-end;justify-content:space-between;gap:18px;padding:22px 24px;
  min-height:134px;background:
    linear-gradient(90deg,rgba(132,204,22,.09),transparent 44%),
    linear-gradient(180deg,var(--surface),var(--bg-2))}
.ai-hero::before{content:"";position:absolute;inset:0;opacity:.42;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.028) 1px,transparent 1px);
  background-size:38px 38px}
.ai-hero>*{position:relative}
.ai-eyebrow{display:flex;align-items:center;gap:9px;color:var(--lime-bright);font:700 11px/1 var(--mono);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.ai-spark{width:8px;height:8px;background:var(--lime);box-shadow:0 0 18px var(--lime);transform:rotate(45deg)}
.ai-hero h2{margin:0;font-size:clamp(26px,3.4vw,46px);line-height:.98;letter-spacing:0;font-weight:800;max-width:720px}
.ai-status-strip{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.ai-console{padding:20px;background:linear-gradient(180deg,#14161a,#0d0e10)}
.ai-console::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--lime),var(--blue),var(--amber))}
.ai-console-top{display:grid;grid-template-columns:1fr 170px;gap:10px;margin-bottom:13px}
.ai-field{display:flex;flex-direction:column;gap:6px}
.ai-field span,.ai-side-k{font:700 10px/1 var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.ai-field input,.ai-field select,.ai-prompt-shell textarea{
  width:100%;border:1px solid var(--line-2);background:#0b0c0e;color:var(--text);font:600 13px/1.4 var(--sans);
  border-radius:9px;outline:none;appearance:none;color-scheme:dark}
.ai-field input,.ai-field select{height:42px;padding:0 12px}
.ai-field select{
  background-image:linear-gradient(45deg,transparent 50%,var(--text-2) 50%),linear-gradient(135deg,var(--text-2) 50%,transparent 50%);
  background-position:calc(100% - 16px) 18px,calc(100% - 11px) 18px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.ai-field input:focus,.ai-field select:focus,.ai-prompt-shell:focus-within{border-color:var(--lime-dim);box-shadow:0 0 0 3px var(--lime-glow)}
.ai-command-deck{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:13px}
.ai-command{min-width:0;text-align:left;border:1px solid var(--line);background:rgba(255,255,255,.025);color:var(--text);
  border-radius:8px;padding:10px 10px;cursor:pointer;transition:.14s var(--ease)}
.ai-command:hover{border-color:var(--lime-dim);background:rgba(132,204,22,.08);transform:translateY(-1px)}
.ai-command .num{display:block;color:var(--lime-bright);font-size:11px;margin-bottom:2px}
.ai-command b{display:block;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-prompt-shell{display:grid;grid-template-columns:58px 1fr;border:1px solid var(--line-2);border-radius:12px;
  background:#090a0b;overflow:hidden}
.ai-slash{display:grid;place-items:start center;padding-top:14px;border-right:1px solid var(--line);
  color:var(--lime-bright);font:800 13px/1 var(--mono);background:rgba(132,204,22,.05)}
.ai-prompt-shell textarea{border:0;border-radius:0;min-height:148px;resize:vertical;padding:14px 15px;font-size:15px;line-height:1.5}
.ai-action-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:13px}
.ai-ready{display:flex;align-items:center;gap:9px;color:var(--text-2);font-weight:600}
.ai-ready span{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 14px var(--lime)}
.ai-ask{min-width:126px;justify-content:center}
.ai-side{padding:18px;background:linear-gradient(180deg,var(--surface),#0b0c0e);display:flex;flex-direction:column;gap:16px}
.ai-side-block{padding-bottom:16px;border-bottom:1px solid var(--line)}
.ai-side-block:last-child{border-bottom:0;padding-bottom:0}
.ai-model{font:800 30px/1 var(--mono);letter-spacing:0;margin:10px 0;color:var(--text)}
.ai-side-sub{color:var(--text-2);font-size:12.5px}
.ai-skill-rack{display:grid;gap:8px;margin-top:12px}
.ai-skill-card{
  width:100%;min-height:58px;display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;
  padding:10px;border:1px solid var(--line);border-radius:11px;background:rgba(255,255,255,.025);color:var(--text);
  text-align:left;cursor:pointer;transition:border-color .16s var(--ease),background .16s var(--ease),transform .16s var(--ease)}
.ai-skill-card:hover{border-color:var(--lime-dim);background:rgba(132,204,22,.08);transform:translateY(-1px)}
.ai-skill-card.installed{border-color:rgba(132,204,22,.55);background:linear-gradient(135deg,rgba(132,204,22,.18),rgba(132,204,22,.05));
  box-shadow:0 0 0 1px rgba(132,204,22,.08) inset,0 12px 28px rgba(132,204,22,.08)}
.ai-skill-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--surface-3);color:var(--text-2)}
.ai-skill-card.installed .ai-skill-icon{background:linear-gradient(145deg,var(--lime),var(--lime-dim));color:#0a0a0a}
.ai-skill-copy{min-width:0;display:flex;flex-direction:column;gap:2px}
.ai-skill-tag{font:700 10px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.ai-skill-card b{font-size:13px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-skill-card small{justify-self:end;border:1px solid var(--line);border-radius:999px;padding:3px 8px;
  color:var(--text-2);font-size:11px;font-weight:800;line-height:1;background:#0b0c0e}
.ai-skill-card.installed small{border-color:transparent;background:var(--lime-glow);color:var(--lime-bright)}
.ai-mode-note{margin-top:10px;color:var(--muted);font-size:11.5px;line-height:1.45}
.ai-rule{display:flex;align-items:flex-start;gap:9px;margin-top:12px;color:var(--text-2);font-weight:600;font-size:12.5px}
.ai-rule .i{color:var(--lime-bright)}
.ai-answer-panel{grid-column:1/-1;background:#0b0c0e;min-height:300px}
.ai-answer-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--surface),var(--bg-2))}
.ai-answer-head b{display:block;margin-top:4px}
.ai-answer-panel pre{margin:0;padding:20px 22px;white-space:pre-wrap;font:500 14px/1.72 var(--sans);color:var(--text)}
.ai-empty{min-height:300px;display:grid;place-items:center;text-align:center;padding:28px;color:var(--muted)}
.ai-empty b{display:block;color:var(--text);font-size:17px;margin:10px 0 4px}
.ai-empty span{max-width:460px}
.ai-empty-mark{width:50px;height:50px;border:1px solid var(--line-2);border-radius:12px;display:grid;place-items:center;
  color:var(--lime-bright);background:rgba(132,204,22,.06);font:900 32px/1 var(--mono)}

/* ---------- icons & accessibility ---------- */
.i{display:inline-block;vertical-align:middle;flex:none}
.feed .item .ic .i{vertical-align:middle}
.feed .item.fill .ic{color:var(--lime-bright)}
.feed .item.flag .ic{color:var(--orange)}
.feed .item .ic{color:var(--text-2)}
/* keep emoji-prefixed headings aligned now that icons sit inline */
.card h3 .i,.section-title .i,.hero .i,.ifta .i{margin-right:7px}
.ifta .i,.hero.lost .i{margin-top:1px}

/* visible keyboard focus (was missing — Quick Ref §1 focus-states) */
:where(a,button,input,select,textarea,.chip,[tabindex]):focus-visible{
  outline:2px solid var(--lime-bright);outline-offset:2px;border-radius:8px}
.nav a:focus-visible{outline-offset:-2px}
.toggle a:focus-visible,.userchip:focus-within{outline-offset:1px}

/* respect reduced-motion: the KPI "pop" fires on every poll, skeleton shimmers, etc. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important}
  .skel{animation:none;background:var(--surface-3)}
  .btn:hover{transform:none}
}

/* responsive — usable from a truck cab (V2 §11) */
@media(max-width:920px){
  .platform-shell{grid-template-columns:1fr}
  .platform-side{min-height:auto;border-right:0;border-bottom:1px solid var(--line)}
  .platform-kpis,.customer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .platform-control,.customer-head,.customer-foot{align-items:stretch;flex-direction:column}
  .platform-search{min-width:0}
  .shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;overflow-x:auto;padding:10px 12px;gap:4px}
  .sidebar .brand,.sidebar .foot{display:none}
  .nav{flex-direction:row;gap:4px}.nav .sep{display:none}
  .nav a span{display:none}.nav a{padding:9px}
  .cols-4{grid-template-columns:repeat(2,1fr)}.cols-3,.cols-2{grid-template-columns:1fr}
  .admin-overview,.admin-main{grid-template-columns:1fr}
  .contact-card{align-items:flex-start;flex-direction:column}
  .report-bar{align-items:stretch;flex-direction:column}
  .report-meaning{grid-template-columns:repeat(2,minmax(0,1fr))}
  .report-downloads{justify-content:flex-start}
  .receipt-head{align-items:flex-start;flex-direction:column}
  .receipt-actions{justify-content:flex-start}
  .receipt-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}
  .receipt-grid{grid-template-columns:1fr}
  .receipt-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .content{padding:18px 14px 50px}
  #map{height:380px}
  #livemap{height:560px;min-height:420px}
  .map-command{grid-template-columns:repeat(2,minmax(0,1fr))}
  .live-tools{grid-column:1/-1}
  .live-map-layout{grid-template-columns:1fr}
  .live-side{position:static;max-height:none}
  .map-head{align-items:flex-start;flex-direction:column}
  .live-legend{justify-content:flex-start}
  table{display:block;overflow-x:auto;white-space:nowrap}
  .ai-board{grid-template-columns:1fr}
  .ai-hero{align-items:flex-start;flex-direction:column;min-height:0;padding:20px}
  .ai-status-strip{justify-content:flex-start}
  .ai-console-top{grid-template-columns:1fr}
  .ai-command-deck{grid-template-columns:repeat(2,minmax(0,1fr))}
  .ai-prompt-shell{grid-template-columns:1fr}
  .ai-slash{display:none}
  .ai-action-row,.ai-answer-head{align-items:stretch;flex-direction:column}
  .ai-ask{width:100%}
  .ai-skill-rack{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:520px){
  .platform-main{padding:18px}.platform-kpis,.customer-grid{grid-template-columns:1fr}
  .ai-command-deck{grid-template-columns:1fr}
  .ai-hero h2{font-size:28px}
  .ai-skill-rack{grid-template-columns:1fr}
  .report-meaning{grid-template-columns:1fr}
  .receipt-kpis{grid-template-columns:1fr}
  .receipt-stop{grid-template-columns:1fr}
  .receipt-strip{grid-template-columns:1fr}
  .receipt-chip{grid-template-columns:1fr}
  .receipt-chip .muted{grid-column:auto}
  .map-command{grid-template-columns:1fr}
  .live-tools{flex-direction:column;align-items:stretch}
  .truck-row{grid-template-columns:1fr 48px}
  .truck-row .muted{display:none}
}
