/* GPS Trucking — Admin panel. Design tokens from the Claude Design handoff
 * (amber/gold on a flat dark ops theme; Space Grotesk + JetBrains Mono + Phosphor). */
:root {
  --bg: #0a0c10;
  --sidebar: #0b0e13;
  --card: #0e1116;
  --card-2: #0e131a;
  --card-3: #0f141b;
  --input: #06080b;
  --bd: #161d27;
  --bd-2: #18212c;
  --bd-3: #283242;
  --tx: #e7edf5;
  --tx-2: #cdd6e2;
  --tx-3: #9aa7b6;
  --label: #7a8696;
  --faint: #56616f;
  --faintest: #3f4b59;
  --accent: #fbbf24;
  --accent-soft: rgba(251, 191, 36, 0.1);
  --danger: #f43f5e;
  --ok: #34d399;
  --info: #3ea6ff;
  --shadow: 0 6px 18px rgba(0, 0, 0, 0.4);
  --radius: 12px;

  --st-PARKING: #7e8b9a;
  --st-LOADING: #3ea6ff;
  --st-ON_ROAD: #34d399;
  --st-AT_DISTRIBUTOR: #c084fc;
  --st-UNLOADING: #fb923c;
  --st-COMPLETED: #6b7a8d;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: 'Space Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background: var(--bg);
  color: var(--tx);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
}
.mono { font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; }
.loading { display: grid; place-items: center; height: 100vh; color: var(--faint); }
.muted { color: var(--tx-3); }
.caps { font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 1.6px; font-size: 10px; color: var(--faintest); }
.uinitial { width: 30px; height: 30px; border-radius: 7px; background: linear-gradient(135deg, var(--bd-3), var(--bd)); color: var(--tx-2); display: grid; place-items: center; font-weight: 700; font-size: 12px; flex: 0 0 auto; }
.act { color: var(--tx-3); font-size: 16px; cursor: pointer; }
.act:hover { color: var(--accent); }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #222c38; border-radius: 8px; border: 2px solid var(--bg); }
::-webkit-scrollbar-track { background: transparent; }

/* ---- shell ---- */
.app { display: grid; grid-template-columns: 248px 1fr; height: 100vh; overflow: hidden; }
.sidebar { background: var(--sidebar); border-right: 1px solid var(--bd); display: flex; flex-direction: column; overflow-y: auto; }
.brand { display: flex; align-items: center; gap: 12px; padding: 17px 18px 15px; border-bottom: 1px solid var(--bd); }
.brand-logo { width: 38px; height: 38px; border-radius: 9px; background: var(--accent); display: grid; place-items: center; color: var(--bg); font-size: 21px; box-shadow: 0 0 0 1px rgba(251, 191, 36, 0.3), 0 6px 18px rgba(251, 191, 36, 0.18); flex: 0 0 auto; }
.brand-name { font-weight: 700; font-size: 15px; line-height: 1.1; }
.brand-name b { color: var(--accent); font-weight: 700; }
.brand-sub { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 1.6px; color: var(--faint); margin-top: 3px; }
.nav-group { font-family: 'JetBrains Mono', monospace; text-transform: uppercase; letter-spacing: 1.8px; font-size: 10px; color: var(--faintest); padding: 16px 24px 6px; }
.nav-item { position: relative; display: flex; align-items: center; gap: 12px; margin: 1px 12px; padding: 9px 12px; border-radius: 8px; color: var(--tx-3); font-size: 13.5px; font-weight: 500; cursor: pointer; background: transparent; border: none; width: calc(100% - 24px); text-align: left; }
.nav-item .ph { font-size: 18px; }
.nav-item:hover { background: rgba(148, 163, 184, 0.06); color: var(--tx-2); }
.nav-item.active { background: var(--accent-soft); color: var(--accent); }
.nav-item.active::before { content: ''; position: absolute; left: -12px; top: 7px; bottom: 7px; width: 3px; border-radius: 0 3px 3px 0; background: var(--accent); }
.nav-item[hidden] { display: none; }
.sidebar-foot { margin-top: auto; padding: 14px 18px; border-top: 1px solid var(--bd); }
.sidebar-foot .row { display: flex; align-items: center; gap: 8px; }
.sidebar-foot small { display: block; font-family: 'JetBrains Mono', monospace; color: var(--faint); font-size: 10px; margin-top: 3px; }
.dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ok); }
.dot.pulse { box-shadow: 0 0 8px var(--ok); animation: blink 1.8s infinite; }
@keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: .2; } }
@keyframes scanline { 0% { transform: translateY(-100%); } 100% { transform: translateY(260px); } }
@keyframes vscan { 0% { top: 14%; } 100% { top: 82%; } }

.main { display: flex; flex-direction: column; min-width: 0; overflow: hidden; }
.topbar { height: 62px; flex: 0 0 auto; display: flex; align-items: center; gap: 18px; padding: 0 22px; border-bottom: 1px solid var(--bd); background: var(--sidebar); }
.topbar h1 { font-size: 16px; font-weight: 600; margin: 0; line-height: 1.1; letter-spacing: .2px; }
.topbar-sub { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--faint); margin-top: 2px; }
.topbar .spacer { flex: 1; }
.clock { display: flex; align-items: center; gap: 7px; font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--tx-2); }
.clock .utc { color: var(--faint); font-size: 11px; }
.segment { display: flex; gap: 2px; background: var(--card-2); border: 1px solid #1c2530; border-radius: 9px; padding: 3px; }
.seg-btn { border: none; background: transparent; color: var(--tx-3); padding: 6px 13px; border-radius: 7px; font-size: 12.5px; font-weight: 600; cursor: pointer; font-family: inherit; }
.seg-btn.active { background: var(--accent); color: var(--bg); }
.iconbtn { position: relative; width: 38px; height: 38px; border-radius: 9px; border: 1px solid #1c2530; background: var(--card-2); color: var(--tx-3); cursor: pointer; display: grid; place-items: center; font-size: 18px; }
.iconbtn:hover { border-color: var(--bd-3); }
.badge-count { position: absolute; top: -6px; right: -6px; min-width: 18px; height: 18px; border-radius: 9px; background: var(--danger); color: #fff; font-size: 10px; font-weight: 700; display: grid; place-items: center; padding: 0 4px; border: 2px solid var(--sidebar); font-family: 'JetBrains Mono', monospace; }
.avatar { width: 34px; height: 34px; border-radius: 8px; background: linear-gradient(135deg, var(--bd-3), var(--bd)); color: var(--tx-2); display: grid; place-items: center; font-weight: 700; font-size: 13px; }

.content { flex: 1; overflow-y: auto; padding: 20px 22px 60px; }
.grid { display: grid; gap: 16px; }

/* ---- panels / cards ---- */
.panel { background: var(--card); border: 1px solid var(--bd-2); border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px; }
.section-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin: 0 0 12px; }
.section-head h2 { margin: 0; font-size: 15px; font-weight: 600; }

.kpi-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(148px, 1fr)); gap: 12px; }
.kpi { position: relative; overflow: hidden; background: var(--card); border: 1px solid var(--bd-2); border-radius: var(--radius); padding: 13px 15px; }
.kpi .bar { position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: currentColor; opacity: .9; }
.kpi .num { font-family: 'JetBrains Mono', monospace; font-size: 29px; font-weight: 600; line-height: 1.1; }
.kpi .lbl { display: flex; align-items: center; gap: 6px; color: var(--label); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; margin-top: 6px; }
.kpi .lbl .ph { font-size: 13px; }

/* ---- tables ---- */
table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
thead th { text-align: left; color: var(--label); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; padding: 10px; border-bottom: 1px solid var(--bd-2); }
tbody td { padding: 11px 10px; border-bottom: 1px solid rgba(148, 163, 184, 0.06); }
tbody tr.click { cursor: pointer; }
tbody tr.click:hover { background: rgba(148, 163, 184, 0.05); }

/* ---- chips / badges ---- */
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 3px 11px; border-radius: 999px; font-size: 12px; font-weight: 600; }
.chip.dot::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.st-PARKING { color: var(--st-PARKING); } .chip.st-PARKING { background: rgba(126,139,154,.14); }
.st-LOADING { color: var(--st-LOADING); } .chip.st-LOADING { background: rgba(62,166,255,.13); }
.st-ON_ROAD { color: var(--st-ON_ROAD); } .chip.st-ON_ROAD { background: rgba(52,211,153,.13); }
.st-AT_DISTRIBUTOR { color: var(--st-AT_DISTRIBUTOR); } .chip.st-AT_DISTRIBUTOR { background: rgba(192,132,252,.13); }
.st-UNLOADING { color: var(--st-UNLOADING); } .chip.st-UNLOADING { background: rgba(251,146,60,.13); }
.st-COMPLETED { color: var(--st-COMPLETED); } .chip.st-COMPLETED { background: rgba(107,122,141,.16); }
.amber { color: var(--accent); }
.ok-tx { color: var(--ok); } .bad-tx { color: var(--danger); }
.badge-sm { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; font-weight: 700; padding: 2px 7px; border-radius: 5px; letter-spacing: .5px; }
.badge-sm.ok { background: rgba(52,211,153,.14); color: var(--ok); }
.badge-sm.bad { background: rgba(244,63,94,.14); color: var(--danger); }
.type-badge { font-family: 'JetBrains Mono', monospace; font-size: 10px; padding: 2px 7px; border-radius: 5px; background: rgba(148,163,184,.1); color: var(--tx-3); letter-spacing: .5px; }

/* ---- forms / buttons ---- */
label.field { display: block; margin-bottom: 12px; }
label.field > span { display: block; color: var(--label); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 5px; }
input, select, textarea { width: 100%; background: var(--input); border: 1px solid var(--bd-3); color: var(--tx); border-radius: 8px; padding: 9px 11px; font-size: 14px; font-family: inherit; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); }
textarea { min-height: 70px; resize: vertical; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.btn { cursor: pointer; border-radius: 8px; padding: 9px 14px; font-size: 13px; font-weight: 600; border: 1px solid var(--bd-3); background: rgba(148,163,184,.06); color: var(--tx); font-family: inherit; display: inline-flex; align-items: center; gap: 7px; }
.btn:hover { border-color: var(--bd-3); }
.btn .ph { font-size: 16px; }
.btn.primary { background: var(--accent); color: var(--bg); border: none; }
.btn.primary:hover { filter: brightness(1.06); }
.btn.danger { color: var(--danger); border-color: rgba(244,63,94,.4); background: transparent; }
.btn:disabled { opacity: .45; cursor: not-allowed; }
.row { display: flex; gap: 10px; flex-wrap: wrap; align-items: end; }
.row > * { flex: 1; min-width: 140px; }
.row.tight > * { flex: 0 0 auto; min-width: 0; }
.toolbar { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: 14px; }

/* ---- map ---- */
.map { height: 600px; border-radius: var(--radius); overflow: hidden; border: 1px solid var(--bd-2); }
.map.sm { height: 300px; }
.map.detail { height: 520px; }
.leaflet-container { background: #0a0c10 !important; font-family: 'JetBrains Mono', monospace; }
/* Dark map from reliable OSM tiles: invert + hue-shift the tile images only.
   Markers/circles/routes live in the overlay pane and are NOT affected. */
.leaflet-tile { filter: invert(1) hue-rotate(180deg) brightness(0.95) contrast(0.9); }
.leaflet-control-zoom a { background: #10141b !important; color: var(--tx-2) !important; border-color: var(--bd) !important; }
.leaflet-control-zoom a:hover { color: var(--accent) !important; }
.driver-pulse { border-radius: 50%; }
.driver-pulse::after { content: ''; position: absolute; inset: -4px; border-radius: 50%; border: 2px solid currentColor; animation: drvpulse 2.2s infinite; }
@keyframes drvpulse { 0% { transform: scale(.55); opacity: .85; } 70% { transform: scale(2.6); opacity: 0; } 100% { opacity: 0; } }

/* ---- ping feed ---- */
.feed { max-height: 320px; overflow-y: auto; }
.feed-row { display: flex; align-items: center; gap: 10px; padding: 8px 4px; border-bottom: 1px solid rgba(148,163,184,.06); font-size: 12.5px; animation: feedin .4s ease; }
.feed-row .mono { color: var(--tx-3); }
@keyframes feedin { from { opacity: 0; transform: translateX(8px); } to { opacity: 1; transform: none; } }

/* ---- drawer (right) + modal ---- */
.scrim { position: fixed; inset: 0; background: rgba(2, 5, 10, 0.6); z-index: 1000; }
.drawer { position: fixed; top: 0; right: 0; bottom: 0; width: min(860px, 96vw); background: var(--bg); border-left: 1px solid var(--bd-2); box-shadow: -20px 0 50px rgba(0,0,0,.5); z-index: 1001; overflow-y: auto; padding: 22px 24px 50px; animation: slidein .22s ease; }
@keyframes slidein { from { transform: translateX(30px); opacity: .4; } to { transform: none; opacity: 1; } }
.drawer-head { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.drawer-head .sap { font-family: 'JetBrains Mono', monospace; font-size: 19px; font-weight: 700; color: var(--accent); }
.drawer-head .x { margin-left: auto; }
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.kv { display: grid; grid-template-columns: 1fr 1fr; gap: 15px 22px; }
.kv .k { color: var(--label); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; }
.kv .v { font-size: 14px; margin-top: 3px; }
.statbar { display: flex; gap: 7px; flex-wrap: wrap; margin: 4px 0 16px; }
.statbar .s { padding: 5px 11px; border-radius: 999px; font-size: 12px; font-weight: 600; border: 1px solid var(--bd-2); color: var(--faint); }
.statbar .s.on { border-width: 0; }

.modal-backdrop { position: fixed; inset: 0; background: rgba(2,5,10,.66); display: grid; place-items: center; z-index: 1000; padding: 20px; }
.modal { background: var(--card-3); border: 1px solid var(--bd-3); border-radius: var(--radius); box-shadow: var(--shadow); width: min(720px, 100%); max-height: 88vh; overflow: auto; padding: 22px; }
.modal h2 { margin: 0 0 14px; font-size: 17px; }

/* ---- timeline ---- */
.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { position: relative; display: flex; gap: 12px; padding: 7px 0; }
.tl-ic { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; font-size: 16px; background: var(--accent-soft); color: var(--accent); flex: 0 0 auto; }
.timeline li.pending .tl-ic { background: rgba(148,163,184,.07); color: var(--faint); }
.tl-t { font-weight: 600; font-size: 13.5px; }
.timeline li.pending .tl-t { color: var(--faint); }
.tl-time { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--tx-3); }

/* ---- terminal (simulator) ---- */
.term { background: var(--input); border: 1px solid var(--bd); border-radius: var(--radius); padding: 14px; font-family: 'JetBrains Mono', monospace; font-size: 12.5px; color: #9be8d6; white-space: pre-wrap; height: 660px; overflow: auto; }
.term .req { color: var(--info); } .term .ok { color: var(--ok); } .term .err { color: var(--danger); } .term .dim { color: var(--faint); }

/* ---- banners / misc ---- */
.banner { padding: 11px 14px; border-radius: 10px; font-size: 13px; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.banner.warn { background: rgba(251,146,60,.08); border: 1px solid rgba(251,146,60,.3); color: #fdba74; }
.banner.ok { background: rgba(52,211,153,.1); border: 1px solid rgba(52,211,153,.3); color: #a7f3d0; }
.perm-grid { display: grid; grid-template-columns: 150px repeat(auto-fit, minmax(64px, 1fr)); gap: 6px 8px; align-items: center; font-size: 12px; }
.perm-grid .h { color: var(--label); font-size: 10px; text-transform: uppercase; }
.toast { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); background: var(--card-3); border: 1px solid var(--bd-3); padding: 11px 18px; border-radius: 10px; box-shadow: var(--shadow); opacity: 0; transition: opacity .2s; z-index: 1100; }
.toast.show { opacity: 1; }
.toast.bad { border-color: rgba(244,63,94,.5); color: #fecaca; }
.qr-box { display: grid; place-items: center; padding: 12px; background: #fff; border-radius: 10px; width: max-content; }

/* ---- login ---- */
.login-wrap { display: grid; place-items: center; min-height: 100vh; padding: 20px; }
.login-card { width: min(380px, 100%); }
.login-card .brand-logo { margin-bottom: 14px; }
.login-card h1 { font-size: 22px; margin: 0 0 4px; }

/* ===== handoff gap additions ===== */

/* toggle switch (checkpoint active/notif, rule on/off, special perms) */
.toggle { position: relative; width: 38px; height: 22px; border-radius: 999px; border: 1px solid var(--bd-3); background: var(--card-2); cursor: pointer; flex: 0 0 auto; padding: 0; transition: background .15s, border-color .15s; }
.toggle::after { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--faint); transition: transform .15s, background .15s; }
.toggle.on { background: var(--accent-soft); border-color: var(--accent); }
.toggle.on::after { transform: translateX(16px); background: var(--accent); }
.toggle.green.on { background: rgba(52, 211, 153, .16); border-color: var(--ok); }
.toggle.green.on::after { background: var(--ok); }
.toggle:disabled { opacity: .45; cursor: not-allowed; }
.toggle-row { display: flex; align-items: center; gap: 9px; font-size: 12.5px; color: var(--tx-3); }

/* dashboard map filters */
.filterbar { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 12px; }
.filterbar select, .filterbar input { width: auto; min-width: 132px; padding: 7px 10px; font-size: 12.5px; }
.filterbar .fb-label { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 1px; color: var(--faintest); text-transform: uppercase; }

/* driver pulse marker (Leaflet divIcon, CSP-safe — styled via JS) */
.driver-divicon { background: transparent; border: none; }
.driver-marker { position: relative; width: 16px; height: 16px; }
.dm-dot { position: absolute; left: 50%; top: 50%; width: 12px; height: 12px; margin: -6px 0 0 -6px; border-radius: 50%; box-shadow: 0 0 7px currentColor; }
.dm-pulse { position: absolute; left: 50%; top: 50%; width: 12px; height: 12px; margin: -6px 0 0 -6px; border-radius: 50%; animation: drvpulse 2.2s infinite; }
.leaflet-popup-content .btn { margin-top: 8px; padding: 6px 10px; font-size: 12px; }

/* distributor bulk bar + checkbox column */
.bulkbar { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.bulkbar .count { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--tx-3); }
td.cbx, th.cbx { width: 34px; text-align: center; }
input.cb { width: auto; }

/* notification cards (groups left / rules right) */
.ncard { background: var(--card-2); border: 1px solid var(--bd-2); border-radius: 10px; padding: 13px 14px; margin-bottom: 10px; }
.ncard-head { display: flex; align-items: center; gap: 9px; margin-bottom: 4px; }
.ncard-head .nname { font-weight: 600; font-size: 14px; }
.ncard-head .ph { color: var(--st-LOADING); font-size: 18px; }
.ncard .cid { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--tx-3); }
.ncard .chips { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 9px; }
.chip.sm { padding: 2px 9px; font-size: 11px; }
.nrule { background: var(--card-2); border: 1px solid var(--bd-2); border-radius: 10px; padding: 11px 13px; margin-bottom: 9px; }
.nrule-head { display: flex; align-items: center; gap: 10px; }
.nrule .flow { display: flex; align-items: center; gap: 7px; font-size: 13px; flex: 1; min-width: 0; flex-wrap: wrap; }
.nrule .arrow { color: var(--faint); }
.nrule .tmpl { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--tx-3); background: var(--input); border: 1px solid var(--bd); border-radius: 6px; padding: 5px 8px; margin-top: 9px; white-space: pre-wrap; word-break: break-word; }

/* settings tabs + split-pane */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--bd-2); margin-bottom: 16px; }
.tab { border: none; background: transparent; color: var(--tx-3); padding: 10px 14px; font-size: 13.5px; font-weight: 600; cursor: pointer; font-family: inherit; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.tab:hover { color: var(--tx-2); }
.tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.split { display: grid; grid-template-columns: 320px 1fr; gap: 16px; align-items: start; }
.userlist { display: flex; flex-direction: column; gap: 4px; }
.urow { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: 9px; border: 1px solid transparent; cursor: pointer; background: transparent; text-align: left; width: 100%; color: var(--tx); font-family: inherit; }
.urow:hover { background: rgba(148, 163, 184, .05); }
.urow.active { background: var(--accent-soft); border-color: rgba(251, 191, 36, .3); }
.urow .uname { font-size: 13.5px; }
.urow .uat { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--faint); }
.special { display: grid; gap: 10px; margin: 4px 0 16px; }
.special .toggle-row { justify-content: space-between; padding: 10px 12px; background: var(--card-2); border: 1px solid var(--bd-2); border-radius: 9px; }
.panel-empty { display: grid; place-items: center; min-height: 220px; color: var(--faint); text-align: center; }

/* order drawer: back link + status history */
.backlink { display: inline-flex; align-items: center; gap: 6px; background: transparent; border: none; color: var(--tx-3); font-family: inherit; font-size: 13px; cursor: pointer; padding: 0; margin-bottom: 12px; }
.backlink:hover { color: var(--accent); }
.shist { list-style: none; margin: 0; padding: 0; }
.shist li { display: flex; gap: 10px; align-items: center; padding: 8px 0; border-bottom: 1px solid rgba(148, 163, 184, .06); font-size: 13px; }
.shist .when { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--tx-3); flex: 0 0 auto; }
.shist .src { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--faint); flex: 0 0 auto; }

/* audit / system logs */
.logfilter { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.logfilter input, .logfilter select { width: auto; min-width: 150px; }
.actor { font-weight: 600; }
.actor.ADMIN { color: var(--accent); } .actor.DRIVER { color: var(--st-LOADING); } .actor.SYSTEM { color: var(--tx-3); }
.sapref { font-family: 'JetBrains Mono', monospace; color: var(--info); }

@media (max-width: 980px) {
  .app { grid-template-columns: 1fr; height: auto; overflow: visible; }
  .sidebar { flex-direction: row; flex-wrap: wrap; height: auto; }
  .sidebar-foot { display: none; }
  .main { overflow: visible; }
  .content { overflow: visible; }
  .two-col, .kv, .split { grid-template-columns: 1fr; }
}
