:root {
  --bg: #0f172a;
  --panel: #1e293b;
  --panel-2: #243049;
  --text: #e2e8f0;
  --muted: #94a3b8;
  --accent: #38bdf8;
  --accent-strong: #0ea5e9;
  --ok: #22c55e;
  --warn: #f59e0b;
  --err: #ef4444;
  --border: #334155;
  --btn-text: #04202e;   /* text on primary buttons */
  --input-bg: #0f172a;
  --card-shadow: none;
}

/* ---- Light theme ---- */
:root[data-theme="light"] {
  --bg: #f4f7fc;
  --panel: #ffffff;
  --panel-2: #eef2f8;
  --text: #1e293b;
  --muted: #64748b;
  --accent: #0ea5e9;
  --accent-strong: #0ea5e9;
  --ok: #16a34a;
  --warn: #d97706;
  --err: #dc2626;
  --border: #dbe3ee;
  --btn-text: #ffffff;
  --input-bg: #ffffff;
  --card-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}

/* ---- Accent color (applies to either theme) ---- */
:root[data-accent="green"] { --accent: #22c55e; --accent-strong: #16a34a; }
:root[data-accent="purple"] { --accent: #a855f7; --accent-strong: #9333ea; }

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

.hidden { display: none !important; }
.muted { color: var(--muted); }
.small { font-size: 0.8rem; }

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 10px;
}
.topbar h1 { margin: 0; font-size: 1.25rem; }
.topbar__right { display: flex; align-items: center; gap: 12px; }
.whoami { font-size: 0.85rem; color: var(--muted); }

.status { font-size: 0.78rem; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--border); }
.status--ok { color: var(--ok); border-color: var(--ok); }
.status--down { color: var(--err); border-color: var(--err); }
.status--checking { color: var(--muted); }

.layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.span-1 { grid-column: span 1; }
.span-2 { grid-column: span 2; }
@media (max-width: 760px) {
  .layout { grid-template-columns: 1fr; }
  .span-1, .span-2 { grid-column: span 1; }
}

.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 20px;
  box-shadow: var(--card-shadow);
}
.card__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.card h2 { margin: 0 0 12px; font-size: 1.05rem; }
.card h3 { margin: 18px 0 10px; font-size: 0.95rem; color: var(--accent); }

.subpanel { border-top: 1px solid var(--border); margin-top: 8px; }
.subpanel:first-of-type { border-top: none; }

.tabs { display: flex; gap: 8px; margin-bottom: 14px; }
.tab {
  background: transparent; border: 1px solid var(--border); color: var(--muted);
  padding: 8px 14px; border-radius: 8px; cursor: pointer; font-size: 0.85rem;
}
.tab.is-active { color: var(--text); border-color: var(--accent); background: color-mix(in srgb, var(--accent) 12%, transparent); }

/* Auth page — modern 50/50 segmented control (Log In | Register) */
.auth-tabs { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; padding: 4px; margin-bottom: 18px;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 12px; }
.auth-tabs .tab { display: flex; align-items: center; justify-content: center; border: none; background: transparent;
  color: var(--muted); padding: 11px 12px; border-radius: 9px; font-size: 0.92rem; font-weight: 600; cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease; }
.auth-tabs .tab:hover { color: var(--text); }
.auth-tabs .tab.is-active { background: var(--accent); color: #fff; border: none;
  box-shadow: 0 2px 10px color-mix(in srgb, var(--accent) 45%, transparent); }

.form { display: flex; flex-direction: column; gap: 12px; }
.row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 6px; }
.fromto { display: flex; align-items: flex-end; gap: 10px; }
.fromto .field { flex: 1; }
.fromto__swap {
  flex: 0 0 auto; margin-bottom: 4px;
  width: 38px; height: 38px; border-radius: 50%;
  background: transparent; border: 1px solid var(--accent); color: var(--accent);
  font-size: 1.1rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, transform .15s;
}
.fromto__swap:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); }
.fromto__swap:active { transform: rotate(180deg); }
.field { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; }
.field span { color: var(--muted); }

input, select, textarea {
  background: var(--input-bg); border: 1px solid var(--border); border-radius: 8px;
  padding: 10px 12px; color: var(--text); font-size: 0.92rem; width: 100%;
}
input:focus, select:focus, textarea:focus { outline: 2px solid var(--accent); }

.btn {
  background: var(--accent-strong); color: var(--btn-text); border: none; border-radius: 8px;
  padding: 10px 16px; font-weight: 600; cursor: pointer; font-size: 0.88rem;
}
.btn:hover { background: var(--accent); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn--ghost { background: transparent; color: var(--accent); border: 1px solid var(--accent); }
.btn--ghost:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); }
.btn--danger { background: transparent; color: var(--err); border: 1px solid var(--err); }
.btn--danger:hover { background: rgba(239,68,68,0.12); }

.form__msg { margin: 0; font-size: 0.84rem; min-height: 1em; }
.form__msg.ok { color: var(--ok); }
.form__msg.err { color: var(--err); }

.hint { margin-top: 16px; font-size: 0.8rem; color: var(--muted); border-top: 1px solid var(--border); padding-top: 12px; }
.hint em { color: var(--accent); font-style: normal; }

.cred-list { list-style: none; margin: 10px 0 6px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.cred {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px;
  padding: 8px 10px; cursor: pointer; transition: border-color .15s, background .15s, transform .05s;
}
.cred:hover { border-color: var(--accent); background: #2a3b57; }
.cred:active { transform: scale(0.99); }
.cred.is-active { border-color: var(--accent); box-shadow: inset 3px 0 0 var(--accent); }
.cred__who { font-weight: 600; color: var(--text); }
.cred__login { color: var(--muted); font-size: 0.78rem; margin-left: auto; }

.user-list { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.user-list li {
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px;
  padding: 10px 12px; display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.user-list .uname { font-weight: 600; }
.stack { display: flex; flex-direction: column; gap: 2px; }
.user-list .meta { color: var(--muted); font-size: 0.8rem; }
.urole { font-size: 0.72rem; color: var(--accent); border: 1px solid var(--accent); border-radius: 999px; padding: 2px 8px; white-space: nowrap; }

.pill { font-size: 0.7rem; border-radius: 999px; padding: 2px 8px; border: 1px solid var(--border); }
.pill--ACTIVE { color: var(--ok); border-color: var(--ok); }
.pill--PENDING { color: var(--warn); border-color: var(--warn); }
.pill--SUSPENDED, .pill--REJECTED { color: var(--err); border-color: var(--err); }
.pill--ON_TIME { color: var(--ok); border-color: var(--ok); }
.pill--DELAYED { color: var(--err); border-color: var(--err); }
.pill--ARRIVED { color: var(--accent); border-color: var(--accent); }
.pill--PASSED, .pill--SCHEDULED { color: var(--muted); border-color: var(--border); }

.selectable { cursor: pointer; transition: border-color .15s, background .15s; }
.selectable:hover { border-color: var(--accent); background: #2a3b57; }
.selectable.is-active { border-color: var(--accent); box-shadow: inset 3px 0 0 var(--accent); }

.result {
  background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px;
  font-size: 0.82rem; white-space: pre-wrap; word-break: break-word; margin: 6px 0 0; min-height: 1em;
}

/* Tracker */
.tracker { display: grid; grid-template-columns: 260px 1fr; gap: 16px; }
@media (max-width: 700px) { .tracker { grid-template-columns: 1fr; } }
.tracker__map { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; padding: 10px; }
#map { width: 100%; height: 300px; display: block; }
#map .route-line { fill: none; stroke: var(--border); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
#map .stop { fill: var(--accent); }
#map .stop-label { fill: var(--muted); font-size: 9px; }
#map .stop--from { fill: var(--ok); }
#map .stop--to { fill: var(--err); }
#map .bus { fill: var(--warn); stroke: #1a1300; stroke-width: 1; }
#map .bus-halo { fill: var(--warn); opacity: 0.25; }
.readout { margin-top: 8px; font-size: 0.82rem; font-variant-numeric: tabular-nums; }
/* Scan modal */
.modal {
  position: fixed; inset: 0; background: rgba(2, 6, 23, 0.7);
  display: flex; align-items: center; justify-content: center; padding: 20px; z-index: 50;
}
.modal__box {
  background: var(--panel); border: 1px solid var(--border); border-radius: 14px;
  padding: 20px; width: 100%; max-width: 420px;
  max-height: 92vh; overflow-y: auto; /* never overflow the viewport — scroll instead */
}
/* Keep the title + close button reachable while the body scrolls. */
.modal__box > .card__head {
  position: sticky; top: 0; z-index: 6;
  background: var(--panel); padding-bottom: 10px; margin-bottom: 4px;
}
.scan-video { width: 100%; border-radius: 10px; background: #000; min-height: 240px; max-height: 300px; object-fit: cover; }

/* Scan Bus QR popup — wider box, equal tabs, larger buttons, single visible pane */
.scan-box { max-width: 600px; }
.tabs--even { gap: 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin-bottom: 18px; }
.tabs--even .tab { flex: 1 1 0; border: none; border-radius: 0; padding: 13px 14px; font-size: 0.95rem; text-align: center; }
.tabs--even .tab + .tab { border-left: 1px solid var(--border); }
.scan-pane { display: flex; flex-direction: column; gap: 14px; }
/* Keep ← Back / ✓ Check In pinned to the bottom while the form scrolls. */
.scan-footer { position: sticky; bottom: -1px; z-index: 6; background: var(--panel); padding: 12px 0 4px; margin-top: 0; border-top: 1px solid var(--border); }
/* Confirm step: bus profile + scheduled trips */
.sched-list { display: flex; flex-direction: column; gap: 8px; margin-top: 6px; }
.sched { display: flex; align-items: center; gap: 10px; padding: 11px 12px; border: 1px solid var(--border); border-radius: 10px; background: var(--panel-2); cursor: pointer; }
.sched.is-sel { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 10%, transparent); }
.sched__main { display: flex; flex-direction: column; gap: 2px; }
.btn--lg { padding: 14px 20px; font-size: 1rem; }
.btn--block { width: 100%; }
.busbox--lg { gap: 8px; }
.busbox--lg .busbox__fixed { font-size: 1.15rem; padding: 0 18px; }
.busbox--lg .busbox__series,
.busbox--lg .busbox__seq { height: 50px; font-size: 1.1rem; }

/* Bus pass / barcode */
.pass-detail {
  margin-top: 12px; border-top: 1px solid var(--border); padding-top: 12px;
}
.pass-detail h4 { margin: 0 0 4px; }
.pass-detail .barcode { background: #fff; padding: 10px; border-radius: 8px; max-width: 100%; height: auto; }
.pass-code {
  font-family: ui-monospace, monospace; font-size: 1rem; letter-spacing: 1px;
  color: var(--accent); margin: 8px 0;
}

.clock { margin: 8px 0 0; font-size: 0.85rem; color: var(--accent); font-variant-numeric: tabular-nums; min-height: 1em; }
.clock strong { color: var(--text); }
.eta { color: var(--warn); }
.readout.live { color: var(--ok); }
.readout.alert { color: var(--err); }

.timetable { margin-top: 10px; border-top: 1px solid var(--border); padding-top: 8px; }
.timetable h4 { margin: 0 0 6px; font-size: 0.8rem; color: var(--accent); }
.timetable ol { list-style: none; margin: 0; padding: 0; }
.timetable li {
  display: flex; gap: 10px; align-items: baseline; font-size: 0.8rem;
  padding: 3px 0; color: var(--muted);
}
.timetable .tt-time { width: 52px; color: var(--text); font-variant-numeric: tabular-nums; }
.timetable .tt-stop { flex: 1; }
.timetable li.tt-from .tt-stop { color: var(--ok); font-weight: 600; }
.timetable li.tt-to .tt-stop { color: var(--err); font-weight: 600; }
.timetable .tt-eta { color: var(--muted); font-size: 0.76rem; font-variant-numeric: tabular-nums; white-space: nowrap; }
.timetable li.tt-live .tt-eta { color: var(--ok); }

/* ============================ APP SHELL ============================ */
.authscreen { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.auth-card { width: 100%; max-width: 460px; }
.auth-aux { text-align: right; margin: 2px 0 0; }
.auth-link { color: var(--accent); font-size: 0.85rem; text-decoration: none; }
.auth-link:hover { text-decoration: underline; }
.auth-card__head { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 16px; text-align: center; }
.auth-card__head h1 { margin: 0; font-size: 1.3rem; }

.appshell { min-height: 100vh; display: flex; flex-direction: column; }

.appbar {
  height: 60px; display: flex; align-items: center; gap: 14px; padding: 0 16px;
  background: var(--panel); border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 30;
}
.brand { font-size: 1.05rem; white-space: nowrap; }
.brand b { color: var(--accent); }
.appbar__search { flex: 1; max-width: 420px; margin: 0; }
.appbar__search input { width: 100%; }
.iconbtn {
  display: none; width: 38px; height: 38px; border-radius: 8px; cursor: pointer;
  background: transparent; border: 1px solid var(--border); color: var(--text); font-size: 1.1rem;
  align-items: center; justify-content: center;
}

.profile { position: relative; margin-left: auto; }
.profile__btn {
  display: flex; align-items: center; gap: 8px; cursor: pointer; color: var(--text);
  background: transparent; border: 1px solid var(--border); border-radius: 999px; padding: 5px 12px 5px 5px;
}
.profile__btn:hover { border-color: var(--accent); }
.avatar {
  width: 32px; height: 32px; border-radius: 50%; flex: 0 0 auto;
  background: var(--accent-strong); color: #04202e; font-weight: 700; font-size: 0.82rem;
  display: flex; align-items: center; justify-content: center;
}
.profile__meta { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.15; }
.profile__name { font-size: 0.85rem; font-weight: 600; }
.caret { color: var(--muted); font-size: 0.65rem; }

.dropdown {
  position: absolute; right: 0; top: calc(100% + 8px); min-width: 210px; z-index: 40;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: 6px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
}
.dropdown__item {
  display: block; width: 100%; text-align: left; cursor: pointer; font-size: 0.88rem;
  background: transparent; border: none; color: var(--text); padding: 9px 10px; border-radius: 7px;
}
.dropdown__item:hover { background: var(--panel); }
.dropdown__item--danger { color: var(--err); }
.dropdown__sep { border: none; border-top: 1px solid var(--border); margin: 4px 0; }

.appbody { flex: 1; display: flex; align-items: flex-start; }
.sidebar {
  width: 232px; flex: 0 0 232px; background: var(--panel); border-right: 1px solid var(--border);
  padding: 14px 10px; position: sticky; top: 60px; height: calc(100vh - 60px); overflow-y: auto;
}
.sidenav { display: flex; flex-direction: column; gap: 4px; }
.navitem {
  display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; cursor: pointer;
  padding: 10px 12px; border-radius: 9px; border: none; background: transparent;
  color: var(--muted); font-size: 0.9rem;
}
.navitem:hover { background: var(--panel-2); color: var(--text); }
.navitem.is-active { background: color-mix(in srgb, var(--accent) 12%, transparent); color: var(--text); box-shadow: inset 3px 0 0 var(--accent); }
.navitem .ico { width: 20px; text-align: center; flex: 0 0 auto; }

.main { flex: 1; padding: 22px 24px; max-width: 1000px; width: 100%; }
.view-title { margin: 0 0 16px; font-size: 1.25rem; }
.view .card { margin-bottom: 18px; }

.scrim { position: fixed; inset: 60px 0 0 0; background: rgba(0, 0, 0, 0.5); z-index: 25; }

.placeholder { text-align: center; padding: 46px 20px; }
.placeholder__icon { font-size: 2.4rem; margin-bottom: 8px; }

.dash-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.dash-card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px; box-shadow: var(--card-shadow); }
.dash-card h4 { margin: 0 0 6px; font-size: 0.78rem; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.4px; }
.dash-card .big { font-size: 1.5rem; font-weight: 700; }
.dash-card .sub { color: var(--muted); font-size: 0.82rem; }

@media (max-width: 860px) {
  .iconbtn { display: flex; }
  .sidebar {
    position: fixed; top: 60px; left: 0; z-index: 35;
    transform: translateX(-100%); transition: transform 0.2s ease;
  }
  .sidebar.is-open { transform: translateX(0); }
  .main { padding: 16px; }
}
@media (max-width: 600px) {
  /* Keep the search bar (Maps/Paytm-style header); drop the long brand + name to make room. */
  .brand { display: none; }
  .profile__meta { display: none; }
}

/* ============================ BUS DETAILS ============================ */
.bd-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 10px; }
.bd-head h3 { color: var(--text); }
.bd-next { font-size: 0.9rem; padding: 10px 12px; border: 1px solid var(--border); border-radius: 10px; background: var(--panel-2); }
/* Map on top, full-width route timeline below (stacked, not side by side). */
.bd-grid { display: flex; flex-direction: column; gap: 16px; margin: 16px 0; }
.bd-grid #bdMap { height: 380px; }
#bdMap { width: 100%; height: 280px; display: block; }
#bdMap .bdpt--passed { fill: var(--ok); }
#bdMap .bdpt--current { fill: var(--warn); }
#bdMap .bdpt--upcoming { fill: var(--muted); }

.bd-stops { list-style: none; margin: 0; padding: 0; }
.bd-stop {
  display: flex; align-items: flex-start; gap: 10px; padding: 8px 0;
  position: relative; border-left: 2px solid var(--border); margin-left: 6px; padding-left: 14px;
}
/* Timeline markers are status glyphs: ○ upcoming · ✓ passed · 🚌 current · 🏁 destination */
.bd-stop__dot {
  position: absolute; left: -12px; top: 6px; width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  background: var(--panel); border-radius: 50%; font-size: 12px; line-height: 1;
}
.bd-stop__dot::before { content: "○"; color: var(--muted); }
.bd-stop--passed { border-left-color: var(--ok); }
.bd-stop--passed .bd-stop__dot::before { content: "✓"; color: var(--ok); font-weight: 700; }
.bd-stop--current { border-left-color: var(--warn); }
.bd-stop--current .bd-stop__dot::before { content: "🚌"; font-size: 14px; }
.bd-stop--current .bd-stop__name { color: var(--warn); font-weight: 700; }
.bd-stop--arrived .bd-stop__dot::before { content: "🏁"; }
.bd-stop--last .bd-stop__dot::before { content: "🏁"; }
.bd-stop__main { flex: 1; display: flex; flex-direction: column; }
.bd-stop__name { font-weight: 600; }
.bd-stop__status { font-size: 0.74rem; white-space: nowrap; align-self: center; }
.st-passed { color: var(--ok); }
.st-current { color: var(--warn); font-weight: 700; }
.st-upcoming { color: var(--accent); }

/* 🕒 Time Table Details — scheduled-position timeline */
.ttd-note { margin: 6px 0 12px; }
.ttd-summary { margin: 8px 0 16px; }
.dash-card .big--text { font-size: 1.12rem; line-height: 1.3; word-break: break-word; }
.ttd-card--cur { border-color: var(--warn); box-shadow: 0 0 0 1px color-mix(in srgb, var(--warn) 45%, transparent); }
.ttd-card--cur .big--text { color: var(--warn); }

.tl { list-style: none; margin: 6px 0 0; padding: 0; }
.tl-item { position: relative; padding: 0 0 20px 42px; min-height: 30px; }
.tl-item--last { padding-bottom: 0; }
/* connector line between markers */
.tl-item::before { content: ''; position: absolute; left: 15px; top: 26px; bottom: -2px; width: 2px; background: var(--border); }
.tl-item--last::before { display: none; }
.tl-item--passed::before { background: var(--ok); }
.tl-marker {
  position: absolute; left: 0; top: 0; width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center; font-size: 15px; line-height: 1;
  background: var(--panel); border: 2px solid var(--border); color: var(--muted);
}
.tl-item--passed .tl-marker { border-color: var(--ok); color: var(--ok); font-weight: 700; }
.tl-item--upcoming .tl-marker::before { content: '○'; color: var(--muted); }
.tl-item--current .tl-marker {
  width: 38px; height: 38px; left: -3px; top: -3px; font-size: 20px;
  border-width: 3px; border-color: var(--warn); background: color-mix(in srgb, var(--warn) 18%, var(--panel));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--warn) 22%, transparent);
}
.tl-item--current { padding-left: 46px; }
.tl-body { display: flex; flex-direction: column; gap: 2px; padding-top: 3px; }
.tl-name { font-weight: 700; }
.tl-item--current .tl-name { color: var(--warn); font-size: 1.05rem; }
.tl-item--passed .tl-name { color: var(--muted); }
.tl-meta { color: var(--muted); font-size: 0.8rem; }
.tl-badge { font-size: 0.76rem; font-weight: 600; margin-top: 1px; }
.tl-badge--passed { color: var(--ok); }
.tl-badge--current { color: var(--warn); font-weight: 700; font-size: 0.82rem; }
.tl-eta { color: var(--ok); font-weight: 700; font-size: 0.82rem; margin-top: 1px; }

/* ============================ ALERTS ============================ */
.alert-btn {
  background: transparent; border: 1px solid var(--border); color: var(--muted);
  border-radius: 999px; padding: 3px 10px; font-size: 0.72rem; cursor: pointer; white-space: nowrap;
}
.alert-btn:hover { border-color: var(--accent); color: var(--accent); }
.alert-btn.is-on { border-color: var(--warn); color: var(--warn); }

.card-head-row { display: flex; align-items: center; gap: 8px; }

.alert-options { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; }
.alert-options label { display: flex; align-items: center; gap: 8px; font-size: 0.88rem; cursor: pointer; }
.alert-options input[type="checkbox"] { width: auto; }
.alert-options .alert-mystop { flex-direction: column; align-items: stretch; gap: 4px; padding-left: 24px; }

.toasts { position: fixed; right: 16px; bottom: 16px; z-index: 60; display: flex; flex-direction: column; gap: 8px; max-width: 320px; }
.toast {
  background: var(--panel-2); border: 1px solid var(--accent); border-left: 4px solid var(--accent);
  border-radius: 10px; padding: 10px 12px; font-size: 0.85rem; color: var(--text);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4); animation: toastIn 0.2s ease;
}
@keyframes toastIn { from { transform: translateY(8px); opacity: 0; } to { transform: none; opacity: 1; } }
.notif-time { color: var(--muted); font-size: 0.72rem; }

/* ============================ PROFILE PAGE ============================ */
.pf-head { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.pf-photo {
  width: 84px; height: 84px; border-radius: 50%; flex: 0 0 auto;
  background: var(--accent-strong); color: #04202e; font-weight: 700; font-size: 1.6rem;
  display: flex; align-items: center; justify-content: center; background-size: cover; background-position: center;
}
.pf-id { flex: 1; min-width: 180px; }
.pf-id h3 { margin: 0; }
.pf-id .meta { color: var(--muted); font-size: 0.85rem; }
.pf-photo-btn { font-size: 0.78rem; }
.pf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; margin-top: 4px; }
@media (max-width: 400px) { .pf-grid { grid-template-columns: 1fr; } }
.pf-readonly { color: var(--text); padding: 9px 0; font-size: 0.92rem; border-bottom: 1px solid var(--border); }

.pill.fare-pill { color: #facc15; border-color: #facc15; font-weight: 600; }

/* Operator (driver/conductor) controls on Bus Details */
.bd-controls { margin: 6px 0 4px; }
.bd-controls__bar {
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  padding: 10px 12px; background: var(--panel-2); border: 1px solid var(--border);
  border-radius: 10px;
}
.bd-controls .btn { padding: 8px 12px; font-size: 0.82rem; }

/* Driver trip-preparation checklist */
.prep-list { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 6px; max-height: 38vh; overflow-y: auto; }
.prep-item { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); font-size: 0.9rem; }
.prep-mark { font-weight: 700; }
.prep-item--ok .prep-mark { color: var(--ok); }
.prep-item--no .prep-mark { color: var(--err); }
.prep-item--wait .prep-mark { color: var(--warn); font-weight: 600; }

/* Generic SVG map styling so #bdMap and #roomMap render like #map */
.route-line { fill: none; stroke: var(--border); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
svg .stop { fill: var(--accent); }
svg .bus { fill: var(--warn); stroke: #1a1300; stroke-width: 1; }
svg .bus-halo { fill: var(--warn); opacity: 0.25; }
#roomMap, #bdMap { width: 100%; height: 260px; display: block; }

/* Map glyph markers: 🚌 live bus position · 🏁 destination */
/* Live bus marker: smooth movement + direction arrow rotates to travel heading + glow */
.bus-mark { transition: transform 0.7s linear; cursor: pointer; }
.bus-rot { transition: transform 0.45s ease; }
.bus-ico { font-size: 15px; text-anchor: middle; dominant-baseline: central; }
.flag-ico { font-size: 15px; text-anchor: middle; dominant-baseline: central; }
.bus-arrow { fill: var(--warn); }
.bus-glow { fill: var(--warn); opacity: 0.22; animation: buspulse 1.6s ease-in-out infinite; }
@keyframes buspulse { 0%, 100% { opacity: 0.14; } 50% { opacity: 0.42; } }
.bus-mark:hover .bus-ico { font-size: 18px; }
.busmark__lbl { fill: var(--text); font-size: 9px; font-weight: 600; text-anchor: middle; }

/* SOS markers on the Live Tracking map — 🔴 active (pulsing) / 🟡 ack / 🟢 resolved */
.sos-mark { transition: transform 0.7s linear; cursor: pointer; }
.sos-mark__ico { font-size: 14px; text-anchor: middle; dominant-baseline: central; }
.sos-mark:hover .sos-mark__ico { font-size: 18px; }
.sos-mark__ring { fill: none; stroke-width: 2.5; }
.sos-mark__pulse { transform-origin: center; }
.sos-mark--active .sos-mark__ring { stroke: #ef4444; }
.sos-mark--active .sos-mark__pulse { fill: #ef4444; animation: sospulse 1.1s ease-out infinite; }
.sos-mark--ack .sos-mark__ring { stroke: #f59e0b; }
.sos-mark--ack .sos-mark__pulse { fill: #f59e0b; opacity: 0.25; }
.sos-mark--resolved .sos-mark__ring { stroke: #22c55e; }
.sos-mark--resolved .sos-mark__pulse { fill: #22c55e; opacity: 0.18; }
@keyframes sospulse { 0% { opacity: 0.55; transform: scale(0.6); } 100% { opacity: 0; transform: scale(1.7); } }

/* Shared Trip live workspace: timeline (left ~35%) + big map & GPS (right ~65%) */
/* Map on top, full-width route timeline below (stacked, not side by side). */
.room-live-grid { display: flex; flex-direction: column; gap: 16px; margin-top: 4px; }
.room-live-grid > .card { margin: 0; }
.room-live-grid #roomMap { height: 420px; background: var(--panel-2); border: 1px solid var(--border); border-radius: 12px; }
@media (max-width: 920px) { .room-live-grid #roomMap { height: 320px; } }
/* Shared Trip activity / audit log */
.audit-list { list-style: none; margin: 6px 0 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.audit-list li { font-size: 0.85rem; padding: 7px 10px; border-left: 2px solid var(--accent); background: var(--panel-2); border-radius: 0 8px 8px 0; }
.audit-list .meta { font-variant-numeric: tabular-nums; }

/* Real-time GPS readout grid */
.gps-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 0 18px; margin: 12px 0 0; }
.gps-grid > div { display: flex; justify-content: space-between; gap: 10px; padding: 7px 0; border-bottom: 1px dashed var(--border); min-width: 0; }
.gps-grid dt { color: var(--muted); font-size: 0.78rem; white-space: nowrap; }
.gps-grid dd { margin: 0; font-weight: 600; font-size: 0.88rem; text-align: right; font-variant-numeric: tabular-nums; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 400px) { .gps-grid { grid-template-columns: 1fr; } }

/* Empty dashboard state for driver & conductor */
.empty-state { text-align: center; padding: 40px 24px; }
.empty-state__icon { font-size: 2.6rem; margin-bottom: 8px; }
.empty-state h3 { margin: 0 0 8px; }
.empty-state p { max-width: 460px; margin: 0 auto; }

/* ===== Driver / Conductor sectioned dashboard ===== */
.dash-sec { margin-bottom: 22px; }
.dash-sec__title { margin: 0 0 12px; font-size: 1.05rem; }

/* Profile summary */
.profile-summary { display: flex; align-items: center; gap: 16px; }
.profile-summary__avatar {
  width: 56px; height: 56px; border-radius: 50%; background: var(--panel-2);
  display: flex; align-items: center; justify-content: center; font-size: 1.6rem; flex: 0 0 auto;
}
.profile-summary__info h3 { margin: 0 0 4px; }
.profile-summary__info p { margin: 2px 0; }

/* Statistics & leaderboard cards: 4 per row → 2 (tablet) → 1 (mobile) */
.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.stat-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) { .stat-grid, .stat-grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .stat-grid, .stat-grid--3 { grid-template-columns: 1fr; } }
.stat-card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 18px; box-shadow: var(--card-shadow); }
.stat-card__label { color: var(--muted); font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.4px; font-weight: 600; margin-bottom: 6px; }
.stat-card__value { font-size: 1.5rem; font-weight: 700; font-variant-numeric: tabular-nums; }

/* Current bus */
.cur-bus__num { font-size: 1.4rem; font-weight: 700; }
.cur-bus__rows { display: flex; flex-wrap: wrap; gap: 8px 24px; margin-top: 10px; }
.ok { color: var(--ok); font-weight: 700; }

/* Targets — progress bars */
.target-card { display: flex; flex-direction: column; gap: 16px; }
.prog__head { display: flex; justify-content: space-between; font-size: 0.9rem; margin-bottom: 6px; }
.prog__track { height: 12px; background: var(--panel-2); border: 1px solid var(--border); border-radius: 999px; overflow: hidden; }
.prog__fill { height: 100%; background: var(--accent); border-radius: 999px; transition: width 0.4s ease; }

/* Achievements — badges */
.badge-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 900px) { .badge-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .badge-grid { grid-template-columns: 1fr; } }
.badge { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border: 1px solid var(--border); border-radius: 12px; background: var(--panel); }
.badge__icon { font-size: 1.6rem; line-height: 1; }
.badge__label { font-weight: 600; font-size: 0.92rem; }
.badge--locked { opacity: 0.45; filter: grayscale(1); }

/* Personal records — two columns */
.rec-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px 28px; }
@media (max-width: 400px) { .rec-grid { grid-template-columns: 1fr; } }
.rec { display: flex; justify-content: space-between; gap: 12px; padding: 9px 0; border-bottom: 1px dashed var(--border); }
.rec__v { font-weight: 700; font-variant-numeric: tabular-nums; }

/* Recent trips */
.trip-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.trip-row { display: flex; justify-content: space-between; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--border); }
.trip-row:last-child { border-bottom: none; }
.trip-row__num { font-weight: 600; }

/* Sectioned bus-creation form */
.busform { gap: 16px; }
.busform__sec { border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px 16px; margin: 0; }
.busform__sec legend { padding: 0 8px; font-weight: 700; color: var(--accent); font-size: 0.9rem; }
.grid2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (max-width: 400px) { .grid2 { grid-template-columns: 1fr; } }
.field__label { color: var(--muted); font-size: 0.8rem; font-weight: 600; }
.amenity-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 8px; }
@media (max-width: 760px) { .amenity-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .amenity-grid { grid-template-columns: 1fr; } }
.chk { display: flex; align-items: center; gap: 8px; font-size: 0.9rem; }
/* ===== Assign Duty — crew roster + status badges ===== */
.roster-list { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.roster-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 9px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.crew-badge { font-size: 0.8rem; font-weight: 600; white-space: nowrap; }
.crew-badge--available { color: var(--ok); }
.crew-badge--on_trip { color: var(--accent); }
.crew-badge--assigned { color: var(--err); }
.crew-badge--pending { color: var(--warn); }
.crew-badge--suspended, .crew-badge--rejected { color: var(--muted); }
.roster-row .stack { gap: 2px; }
.roster-note { font-size: 0.74rem; }
.roster-row--link { cursor: pointer; transition: border-color .12s, background .12s; }
.roster-row--link:hover, .roster-row--link:focus-visible { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, var(--panel-2)); outline: none; }
.roster-row__right { display: flex; align-items: center; gap: 10px; }
.roster-view { padding: 5px 9px; font-size: 0.76rem; white-space: nowrap; }
.uname--link { background: none; border: 0; padding: 0; font: inherit; font-weight: 600; color: var(--accent); cursor: pointer; text-align: left; }
.uname--link:hover { text-decoration: underline; }
.link-btn { background: none; border: 0; padding: 0; font: inherit; color: var(--accent); cursor: pointer; font-weight: 700; }
.link-btn:hover { text-decoration: underline; }

/* Crew profile modal (from Assign Duty) */
.crew-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.crew-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; }
.crew-field { display: flex; flex-direction: column; gap: 2px; padding: 9px 11px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.crew-field--wide { grid-column: 1 / -1; }
.crew-field span { font-size: 0.72rem; }
.crew-leave { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; margin-top: 12px; }
.crew-leave .crew-field { border-color: color-mix(in srgb, var(--warn) 45%, transparent); }
.crew-sec { margin: 16px 0 6px; }
.crew-actions { margin-top: 16px; flex-wrap: wrap; }

/* Status badges — shared by the crew dashboard card and Assign Duty roster. */
.status-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 0.82rem; font-weight: 700; white-space: nowrap; padding: 3px 10px; border-radius: 999px; border: 1px solid var(--border); background: var(--panel-2); }
.status-badge--lg { font-size: 1rem; padding: 6px 14px; }
.status-badge--available { color: var(--ok); border-color: color-mix(in srgb, var(--ok) 45%, transparent); }
.status-badge--on_trip { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.status-badge--assigned, .status-badge--emergency { color: var(--err); border-color: color-mix(in srgb, var(--err) 45%, transparent); }
.status-badge--on_leave, .status-badge--pending { color: var(--warn); border-color: color-mix(in srgb, var(--warn) 45%, transparent); }
.status-badge--unwell { color: #f59e0b; border-color: color-mix(in srgb, #f59e0b 50%, transparent); }
.status-badge--off_duty, .status-badge--suspended, .status-badge--rejected { color: var(--muted); }

/* My Status card (crew dashboard) */
.status-card { display: flex; flex-direction: column; gap: 12px; }
.status-card__now { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.status-detail { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 8px 16px; padding: 10px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.status-detail > div { display: flex; flex-direction: column; gap: 2px; }
.status-detail span { font-size: 0.74rem; }
.status-quick { display: flex; flex-wrap: wrap; gap: 8px; }
.status-quick__btn { flex: 1 1 auto; min-width: 140px; }
.status-quick__btn.is-active { outline: 2px solid var(--accent); outline-offset: 1px; }
.status-form:empty { display: none; }
.status-form { display: flex; flex-direction: column; gap: 0; }

/* Assign Duty — staff availability summary */
.staff-summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-top: 10px; }
.staff-sum { padding: 14px; border: 1px solid var(--border); border-radius: 12px; background: var(--panel-2); }
.staff-sum h3 { margin: 0 0 6px; }
.staff-sum__big { font-size: 1.5rem; font-weight: 800; color: var(--ok); margin-bottom: 10px; }
.staff-sum__break { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.staff-sum__break li { display: flex; justify-content: space-between; gap: 12px; }
.staff-sum__break span { color: var(--muted); }
.staff-sum__break strong { font-variant-numeric: tabular-nums; }

/* Sidebar bell unread badge + unread notification rows */
.navitem { position: relative; }
.nav__badge { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); min-width: 18px; height: 18px; padding: 0 5px; border-radius: 999px; background: var(--err); color: #fff; font-size: 0.7rem; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; }
.notif--unread { position: relative; }
.notif--unread::before { content: ''; position: absolute; left: -2px; top: 8px; width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }

.remaining-grid { display: grid; grid-template-columns: 1fr auto; gap: 8px 18px; margin-top: 8px; align-items: center; }
.remaining-grid span { color: var(--muted); }
.remaining-grid strong { font-variant-numeric: tabular-nums; }
.remaining-grid .big-num { font-size: 1.4rem; color: var(--ok); }

/* ===== Route Information (master route catalog) ===== */
.routes-grid { display: grid; grid-template-columns: minmax(320px, 1fr) minmax(320px, 1fr); gap: 16px; align-items: start; }
@media (max-width: 760px) { .routes-grid { grid-template-columns: 1fr; } }
.pill--type { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.route-builder__stops { margin-top: 12px; }
.route-builder__stops .card__head { margin-bottom: 6px; }
.route-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 10px; margin: 12px 0; }
.route-metrics .metric { background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; display: flex; flex-direction: column; gap: 3px; }
.route-metrics .metric span { color: var(--muted); font-size: 0.74rem; }
.route-metrics .metric strong { font-size: 1.05rem; font-variant-numeric: tabular-nums; }
.route-search { width: 100%; padding: 10px 12px; margin: 8px 0 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--input-bg, var(--panel-2)); color: var(--text); }
.route-list { display: flex; flex-direction: column; gap: 10px; }
.route-card { border: 1px solid var(--border); border-radius: 12px; background: var(--panel-2); padding: 12px 14px; }
.route-card__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.route-card__code { font-weight: 800; letter-spacing: 0.02em; }
.route-card__path { margin: 6px 0 2px; font-size: 1.02rem; }
.route-card__via { line-height: 1.35; }
.route-card__meta { margin-top: 4px; }
.route-card__acts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.route-card__acts .btn { padding: 6px 10px; font-size: 0.8rem; }
.route-seq { list-style: none; margin: 8px 0 0; padding: 0; }
.route-seq li { position: relative; padding: 7px 0 7px 22px; }
.route-seq li::before { content: ''; position: absolute; left: 5px; top: 14px; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.route-seq li:not(:last-child)::after { content: ''; position: absolute; left: 8px; top: 20px; bottom: -2px; width: 2px; background: var(--border); }
.route-seq li:first-child::before, .route-seq li:last-child::before { background: var(--ok); }
.route-tabs { margin-bottom: 14px; }

/* ===== 🆘 SOS Emergency ===== */
.sos-send { text-align: center; }
.sos-send h3 { color: var(--err); }
.sos-templates { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin: 10px 0; }
.sos-templates .btn { font-size: 0.8rem; padding: 6px 10px; }
.sos-send textarea { width: 100%; }
.sos-bigbtn { width: 100%; margin-top: 12px; background: var(--err); color: #fff; font-size: 1.15rem; font-weight: 800; padding: 18px; border: none; border-radius: 14px; letter-spacing: 0.03em; cursor: pointer; box-shadow: 0 6px 20px color-mix(in srgb, var(--err) 40%, transparent); }
.sos-bigbtn:hover { filter: brightness(1.07); }
.sos-bigbtn:active { transform: scale(0.99); }
.sos-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 12px; margin-bottom: 14px; }
.sos-filterbar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 14px; }
.sos-list { display: flex; flex-direction: column; gap: 10px; margin-top: 8px; }
.sos-card { border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: var(--panel-2); }
.sos-card--active { border-left: 4px solid var(--err); }
.sos-card--resolved { border-left: 4px solid var(--ok); opacity: 0.92; }
.sos-card__head { display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; align-items: center; }
.sos-card__who { font-weight: 700; display: flex; align-items: center; gap: 8px; }
.sos-card__msg { margin: 6px 0; font-style: italic; }
.sos-card__acts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.sos-card__acts .btn { padding: 6px 10px; font-size: 0.8rem; text-decoration: none; }
.sos-log { margin-top: 8px; font-size: 0.78rem; color: var(--muted); border-top: 1px dashed var(--border); padding-top: 6px; }
.sos-map { width: 100%; height: auto; background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; }
.set-check { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.set-check input { width: auto; }
.sos-contact { display: grid; grid-template-columns: 28px 1fr 1fr 1fr; gap: 8px; align-items: center; margin-bottom: 6px; }
.sos-contact__no { color: var(--muted); text-align: center; font-variant-numeric: tabular-nums; }
.sos-contact--head { font-size: 0.74rem; color: var(--muted); margin-bottom: 8px; }
.sos-contact--head span { padding-left: 2px; }
@media (max-width: 560px) { .sos-contact { grid-template-columns: 20px 1fr 1fr; } .sos-contact .sos-c-rel { grid-column: 2 / -1; } .sos-contact--head { display: none; } }
.sos-counts { display: flex; flex-wrap: wrap; gap: 12px; margin: 8px 0; font-size: 0.82rem; }
.sos-counts strong { font-variant-numeric: tabular-nums; }
.sos-accepted { font-size: 0.8rem; color: var(--ok); border-left: 3px solid var(--ok); padding-left: 8px; margin: 4px 0; }
.sos-flash { display: inline-block; background: var(--err); color: #fff; font-weight: 800; font-size: 0.78rem; padding: 3px 10px; border-radius: 999px; margin-bottom: 6px; animation: sosflash 1s steps(1) infinite; }
@keyframes sosflash { 50% { opacity: 0.35; } }

/* SOS page — Search & Filters + horizontal tabs */
.sos-filters { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding: 12px; }
.sos-filters .sos-search { flex: 1 1 220px; min-width: 160px; }
.sos-filters select { flex: 0 0 auto; max-width: 180px; }
.sos-tabs { display: flex; align-items: center; gap: 6px; border-bottom: 2px solid var(--border); margin-bottom: 14px; flex-wrap: wrap; }
.sos-tab { background: none; border: none; border-bottom: 3px solid transparent; color: var(--muted); font-weight: 600; font-size: 0.92rem; padding: 10px 14px; margin-bottom: -2px; cursor: pointer; white-space: nowrap; }
.sos-tab:hover { color: var(--text); }
.sos-tab.is-active { color: var(--accent); border-bottom-color: var(--accent); }
.sos-tabs__reload { margin-left: auto; padding: 6px 10px; font-size: 0.8rem; }
@media (max-width: 560px) { .sos-tabs__reload { margin-left: 0; } .sos-filters select { max-width: none; flex: 1 1 100%; } }

/* SOS sender — header with gear + large circular hold-to-send button */
.sos-send__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.sos-send__head h3 { margin: 0; }
.sos-gear { padding: 6px 12px; font-size: 0.85rem; white-space: nowrap; }
.sos-tpl.is-selected { border-color: var(--err); color: var(--err); font-weight: 700; }
.sos-circle-wrap { display: flex; flex-direction: column; align-items: center; gap: 12px; margin: 18px 0 6px; }
.sos-circle {
  position: relative; width: 200px; height: 200px; border-radius: 50%; border: none; cursor: pointer;
  background: radial-gradient(circle at 50% 38%, #ff6a6a 0%, #ef4444 45%, #b91c1c 100%);
  box-shadow: 0 0 0 8px rgba(239,68,68,0.16), 0 14px 40px rgba(185,28,28,0.55);
  color: #fff; display: grid; place-items: center; user-select: none; -webkit-tap-highlight-color: transparent;
  animation: sospulsebtn 1.8s ease-in-out infinite; transition: transform 0.12s ease;
}
.sos-circle:active { transform: scale(0.97); }
.sos-circle.is-holding { animation: none; }
@keyframes sospulsebtn { 0%, 100% { box-shadow: 0 0 0 6px rgba(239,68,68,0.14), 0 14px 40px rgba(185,28,28,0.5); } 50% { box-shadow: 0 0 0 16px rgba(239,68,68,0.05), 0 14px 46px rgba(185,28,28,0.7); } }
.sos-circle__ring { position: absolute; inset: 0; width: 100%; height: 100%; transform: rotate(-90deg); pointer-events: none; }
.sos-circle__track { fill: none; stroke: rgba(255,255,255,0.25); stroke-width: 6; }
.sos-circle__prog { fill: none; stroke: #fff; stroke-width: 6; stroke-linecap: round; stroke-dasharray: 339.3; stroke-dashoffset: 339.3; transition: stroke-dashoffset 0.25s ease; }
.sos-circle.is-holding .sos-circle__prog { stroke-dashoffset: 0; transition: stroke-dashoffset 3s linear; }
.sos-circle__label { display: flex; flex-direction: column; align-items: center; gap: 4px; z-index: 1; pointer-events: none; }
.sos-circle__title { font-size: 2rem; font-weight: 900; letter-spacing: 2px; }
.sos-circle__hint { font-size: 0.8rem; font-weight: 700; opacity: 0.9; letter-spacing: 1px; }
.sos-circle.is-active { background: radial-gradient(circle at 50% 38%, #ff7a7a 0%, #dc2626 50%, #7f1d1d 100%); animation: sosactive 1s ease-in-out infinite; cursor: default; }
.sos-circle.is-active .sos-circle__title { font-size: 1.5rem; }
@keyframes sosactive { 0%, 100% { box-shadow: 0 0 0 6px rgba(239,68,68,0.3), 0 0 50px rgba(239,68,68,0.5); } 50% { box-shadow: 0 0 0 20px rgba(239,68,68,0.05), 0 0 70px rgba(239,68,68,0.85); } }
.sos-circle__safe { margin-top: 2px; }
.sos-circle__note { text-align: center; max-width: 320px; margin: 0 auto; }

/* SOS Settings popup */
.btn--sm { padding: 5px 10px; font-size: 0.82rem; }
.sos-set-box { max-width: 460px; max-height: 88vh; overflow-y: auto; }
.sos-set-sec { border-top: 1px solid var(--border); padding: 12px 0; }
.sos-set-sec:first-child { border-top: none; }
.sos-set-sec h4 { margin: 0 0 8px; font-size: 0.9rem; }
.sos-set-sec__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.sos-set-sec__head h4 { margin: 0; }
.sos-set-contact { display: grid; grid-template-columns: 22px 1fr 1fr 1fr 28px; gap: 6px; align-items: center; margin-bottom: 6px; }
.sos-set-contact__no { color: var(--muted); text-align: center; font-variant-numeric: tabular-nums; }
.sos-set-contact input { padding: 6px 8px; }
.sc-del { color: var(--err); }
.sos-set-radios { display: flex; gap: 16px; flex-wrap: wrap; }
.sos-set-radio { display: flex; align-items: center; gap: 6px; cursor: pointer; }
.sos-set-radio input { width: auto; }
.sos-set-foot { border-top: 1px solid var(--border); padding-top: 12px; display: flex; align-items: center; gap: 12px; }
@media (max-width: 480px) { .sos-set-contact { grid-template-columns: 18px 1fr 1fr 26px; } .sos-set-contact .sc-rel { grid-column: 2 / 4; } }
/* Dynamic radius info + expansion ladder */
.sos-radius-info { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 8px 0; }
.sos-radius-info > div { display: flex; flex-direction: column; gap: 2px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; background: var(--panel-2); }
.sos-radius-info span { font-size: 0.72rem; color: var(--muted); }
@media (max-width: 480px) { .sos-radius-info { grid-template-columns: 1fr; } }
.sos-ladder { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 8px; }
.sos-tier { font-size: 0.78rem; padding: 3px 8px; border-radius: 999px; border: 1px solid var(--border); background: var(--panel-2); white-space: nowrap; }
.sos-tier.is-cap { border-color: var(--ok); color: var(--ok); }
.sos-tier__arrow { color: var(--muted); font-size: 0.75rem; }

/* 🆘 SOS Control Center (Admin & Super Admin) */
/* Active SOS (red) | SOS History (green) — two equal accent cards, side by side. */
.soscc-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: stretch; }
@media (max-width: 640px) { .soscc-cols { grid-template-columns: 1fr; } }
.sos-panel { display: flex; flex-direction: column; min-width: 0; background: var(--panel); border: 1px solid var(--border); border-radius: 14px; box-shadow: 0 6px 20px rgba(2, 6, 23, 0.22); overflow: hidden; }
.sos-panel__head { padding: 12px 16px; border-bottom: 1px solid var(--border); }
.sos-panel__head h3 { margin: 0; font-size: 1rem; }
.sos-panel__body { flex: 1; display: flex; flex-direction: column; gap: 12px; padding: 14px 16px; min-height: 180px; }
.sos-panel--active { border-top: 3px solid var(--err); }
.sos-panel--active .sos-panel__head { background: rgba(239, 68, 68, 0.10); border-bottom-color: rgba(239, 68, 68, 0.30); }
.sos-panel--active .sos-panel__head h3 { color: var(--err); }
.sos-panel--history { border-top: 3px solid var(--ok); }
.sos-panel--history .sos-panel__head { background: rgba(34, 197, 94, 0.10); border-bottom-color: rgba(34, 197, 94, 0.30); }
.sos-panel--history .sos-panel__head h3 { color: var(--ok); }
.sos-empty { margin: auto; text-align: center; color: var(--muted); padding: 24px 8px; }
.sos-empty__icon { font-size: 2rem; opacity: 0.5; margin-bottom: 8px; }
.sos-empty p { margin: 0; }
.sos-cc-intro h3 { margin: 0 0 4px; }
.sos-cc-stats { margin-bottom: 4px; }
.sos-cc-sec { margin: 4px 0; }
.sos-cc-card--active { border-color: var(--err); box-shadow: 0 0 0 1px rgba(239, 68, 68, 0.35); }
.sos-cc-card__msg { font-style: italic; margin: 4px 0 10px; }
.sos-cc-grid { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 720px) { .sos-cc-grid { grid-template-columns: 1fr 1fr; } }
.sos-cc-map-wrap { margin: 8px 0; }
.sos-cc-map-wrap h4, .sos-cc-block h4 { margin: 8px 0 6px; font-size: 0.85rem; }
.sos-cc-map { width: 100%; height: auto; background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; }
.sos-trail__line { fill: none; stroke: var(--err); stroke-width: 2.5; stroke-dasharray: 5 4; opacity: 0.75; }
.sos-trail__dot { fill: var(--err); opacity: 0.5; }
.sos-cc-counts { gap: 14px; }
.sos-cc-accept, .sos-cc-steps { margin: 4px 0; padding-left: 20px; font-size: 0.82rem; }
.sos-cc-accept li, .sos-cc-steps li { margin: 2px 0; }
.sos-cc-steps { list-style: none; padding-left: 0; }
.sos-cc-steps li.is-done { color: var(--ok); }
.sos-cc-retry .meta { margin-top: 4px; }
.sos-hist { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 8px; background: var(--panel-2); }
.sos-hist > summary { cursor: pointer; padding: 10px 12px; font-weight: 600; font-size: 0.86rem; }
.sos-hist__body { padding: 4px 12px 12px; display: flex; flex-direction: column; gap: 4px; }
.sos-hist__row { display: grid; grid-template-columns: 160px 1fr; gap: 10px; font-size: 0.82rem; border-top: 1px dashed var(--border); padding-top: 4px; }
.sos-hist__row .k { color: var(--muted); }
@media (max-width: 560px) { .sos-hist__row { grid-template-columns: 1fr; gap: 0; } }

/* ===== Reusable widgets ===== */
/* SOSButtonWidget wrapper */
.sosw { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.sosw__loc { font-size: 0.74rem; color: var(--muted); }
.sosw__settings { font-size: 0.82rem; }
.sos-circle.no-pulse { animation: none !important; }

/* RouteSearchWidget — From | ⇄ | To on row one, full-width Search below */
.rsw { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: end; }
.rsw-field { position: relative; }
.rsw-field > label { display: flex; flex-direction: column; gap: 4px; }
.rsw-field > label > span { font-size: 0.74rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.3px; }
.rsw-field input { width: 100%; }
.rsw-suggest { position: absolute; top: 100%; left: 0; right: 0; z-index: 30; margin: 2px 0 0; padding: 4px; list-style: none;
  background: var(--panel); border: 1px solid var(--accent); border-radius: 10px; box-shadow: 0 12px 28px rgba(2,6,23,0.45); max-height: 220px; overflow-y: auto; }
.rsw-suggest li { padding: 8px 10px; border-radius: 7px; cursor: pointer; font-size: 0.9rem; }
.rsw-suggest li:hover { background: var(--panel-2); color: var(--accent); }
.rsw-swap { align-self: end; height: 40px; min-width: 44px; background: var(--panel-2); border: 1px solid var(--border); color: var(--text); border-radius: 10px; font-size: 1.1rem; cursor: pointer; }
.rsw-swap:hover { border-color: var(--accent); color: var(--accent); }
.rsw-go { grid-column: 1 / -1; width: 100%; margin-top: 4px; }
.rsw-recent { margin-top: 12px; }
/* Keep the desktop two-line layout (From ⇄ To, then Search) down to very small phones. */
@media (max-width: 400px) { .rsw { grid-template-columns: 1fr; } .rsw-swap { justify-self: center; width: 100%; } }
.find-bus-card { max-width: 760px; margin-left: auto; margin-right: auto; }
.rsw-recent__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.rsw-recent__head span { font-size: 0.74rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.3px; }
.rsw-recent__chips { display: flex; flex-wrap: wrap; gap: 6px; }

/* Search Buses empty state → "📅 View Time Table" button (same height as Search) */
.search-empty { list-style: none; display: flex; flex-direction: column; align-items: center; gap: 14px; text-align: center; padding: 20px 10px; }
.search-empty__text { margin: 0; color: var(--muted); }
.btn--view-tt { min-width: 240px; } /* blue/rounded/hover inherited from .btn */
@media (max-width: 560px) { .btn--view-tt { width: 100%; } }

/* 💰 Wallet */
.wallet-hero { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; justify-content: space-between; }
.wallet-hero__main h3 { margin: 0 0 6px; }
.wallet-balance { font-size: 2.2rem; font-weight: 900; color: var(--accent); line-height: 1.1; }
.wallet-hero__act { flex: 1 1 240px; max-width: 360px; }
.wallet-withdraw { display: flex; gap: 8px; }
.wallet-withdraw input { flex: 1; }
.wallet-pending { background: var(--panel-2); border: 1px solid var(--border); border-left: 3px solid var(--warn); border-radius: 9px; padding: 8px 12px; font-size: 0.86rem; }
.wtx-list { display: flex; flex-direction: column; }
.wtx { display: grid; grid-template-columns: 110px 1fr auto; gap: 10px; align-items: center; padding: 8px 0; border-top: 1px dashed var(--border); font-size: 0.86rem; }
.wtx:first-child { border-top: none; }
.wtx__date { color: var(--muted); font-variant-numeric: tabular-nums; }
.wtx__amt { font-weight: 700; font-variant-numeric: tabular-nums; }
.wallet-accts { display: flex; flex-direction: column; }
.wallet-acct { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 0; border-top: 1px dashed var(--border); }
.wallet-acct:first-child { border-top: none; }
.wallet-acct__bal { font-weight: 700; font-variant-numeric: tabular-nums; margin-left: auto; }
.wallet-acct .btn--sm { margin-left: 10px; }
.wallet-wd-list { display: flex; flex-direction: column; gap: 10px; }
.wallet-wd { border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; background: var(--panel-2); }
.wallet-wd__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.wallet-wd__acts { display: flex; gap: 8px; margin-top: 8px; }
.wallet-bank { margin-top: 0; }
.wallet-mgmt-title { margin: 18px 0 6px; }
.table-wrap { overflow-x: auto; }
.wd-table { width: 100%; min-width: 820px; border-collapse: collapse; font-size: 0.85rem; }
.wd-table th, .wd-table td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); vertical-align: top; }
.wd-table th { color: var(--muted); font-weight: 600; white-space: nowrap; }
.wd-table th:nth-child(2), .wd-table td:nth-child(2) { min-width: 140px; }
.wd-table th:nth-child(4), .wd-table td:nth-child(4) { min-width: 230px; }
.wd-table th:nth-child(7), .wd-table td:nth-child(7) { min-width: 220px; }
.wd-bank { line-height: 1.5; }
.wd-acts { display: flex; flex-wrap: wrap; gap: 6px; }
.wd-acts .btn { padding: 4px 8px; font-size: 0.76rem; }

/* 📄 PDF Library */
.dash-card--link { cursor: pointer; transition: border-color 0.15s ease, transform 0.1s ease; }
.dash-card--link:hover { border-color: var(--accent); transform: translateY(-1px); }
.pdf-stats { margin: 4px 0 12px; }
.pdf-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.pdf-chip { background: var(--panel-2); border: 1px solid var(--border); color: var(--muted); border-radius: 999px; padding: 5px 12px; font-size: 0.8rem; cursor: pointer; white-space: nowrap; }
.pdf-chip:hover { color: var(--text); border-color: var(--accent); }
.pdf-chip.is-active { background: var(--accent); border-color: var(--accent); color: #fff; }
.pdf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; margin-top: 14px; }
.pdf-card { border: 1px solid var(--border); border-radius: 12px; background: var(--panel-2); padding: 14px; display: flex; flex-direction: column; gap: 4px; }
.pdf-card__top { display: flex; align-items: center; gap: 8px; }
.pdf-card__ico { font-size: 1.3rem; }
.pdf-cat { font-size: 0.72rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.3px; }
.pdf-card__name { font-weight: 700; margin-top: 4px; }
.pdf-card__meta { display: flex; flex-wrap: wrap; gap: 4px 12px; font-size: 0.76rem; color: var(--muted); margin: 8px 0; }
.pdf-card__acts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: auto; }
.pdf-card__acts .btn { padding: 5px 9px; font-size: 0.78rem; }
.pdf-del { color: var(--err); }

/* 📩 Complaints */
.cmp-filters { margin-top: 4px; }
.cmp-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-top: 14px; }
.cmp-card { border: 1px solid var(--border); border-left: 4px solid var(--border); border-radius: 12px; background: var(--panel-2); padding: 14px; display: flex; flex-direction: column; gap: 4px; }
.cmp-card--low { border-left-color: var(--ok); }
.cmp-card--medium { border-left-color: var(--warn); }
.cmp-card--high { border-left-color: #f97316; }
.cmp-card--critical { border-left-color: var(--err); }
.cmp-card__head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cmp-card__code { font-weight: 800; font-variant-numeric: tabular-nums; }
.cmp-card__subject { font-weight: 700; margin-top: 4px; }
.cmp-prio { font-size: 0.78rem; color: var(--muted); margin-left: auto; }
.cmp-card__acts { margin-top: auto; padding-top: 6px; }
.cmp-modal__head { display: flex; gap: 10px; align-items: center; margin-bottom: 6px; }
.cmp-modal__subject { margin: 0 0 10px; }
.cmp-desc { background: var(--panel-2); border: 1px solid var(--border); border-radius: 9px; padding: 10px 12px; margin: 10px 0; }
.cmp-replies { display: flex; flex-direction: column; gap: 8px; max-height: 240px; overflow-y: auto; margin-bottom: 10px; }
.cmp-reply { border: 1px solid var(--border); border-radius: 9px; padding: 8px 10px; background: var(--panel-2); font-size: 0.86rem; }
.cmp-reply__who { margin-bottom: 2px; }
.cmp-replybox { display: flex; gap: 8px; margin: 8px 0; }
.cmp-replybox input { flex: 1; }
.cmp-modal__acts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; border-top: 1px solid var(--border); padding-top: 12px; }
.wdist-grid { display: flex; flex-direction: column; gap: 6px; margin: 10px 0; }
.wdist-row { display: flex; align-items: center; gap: 8px; }
.wdist-row span:first-child { flex: 1; }
.wdist-row input { width: 90px; }
.wdist-table { width: 100%; border-collapse: collapse; margin-top: 12px; font-size: 0.85rem; }
.wdist-table th, .wdist-table td { text-align: left; padding: 6px 8px; border-bottom: 1px solid var(--border); }
.wdist-table th { color: var(--muted); font-weight: 600; }
.wdist-templates { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.wdist-pct.is-auto { color: var(--muted); font-style: italic; background: var(--panel-2); }
.wdist-prog { margin: 12px 0; }
.wdist-prog__head { display: flex; justify-content: space-between; font-size: 0.85rem; margin-bottom: 4px; }
.wdist-bar { height: 12px; border-radius: 999px; background: var(--panel-2); border: 1px solid var(--border); overflow: hidden; }
.wdist-bar__fill { height: 100%; width: 0; background: var(--accent); transition: width 0.25s ease, background 0.25s ease; }
.wdist-bar__fill.is-full { background: var(--ok, #22c55e); }
.wdist-bar__fill.is-over { background: var(--err, #ef4444); }
.wdist-status { margin-top: 6px; font-size: 0.85rem; font-weight: 600; }
.wdist-status.ok { color: var(--ok, #22c55e); }
.wdist-status.err { color: var(--err, #ef4444); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Full-screen incoming SOS "call" */
.soscall { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 20px;
  background: radial-gradient(circle at 50% 30%, color-mix(in srgb, var(--err) 55%, #000), #000); }
.soscall.hidden { display: none; }
.soscall__card { width: 100%; max-width: 380px; text-align: center; color: #fff; }
.soscall__label { font-size: 0.9rem; letter-spacing: 0.14em; font-weight: 800; animation: sosflash 1s steps(1) infinite; }
.soscall__id { font-size: 0.78rem; letter-spacing: 0.08em; opacity: 0.85; margin-top: 4px; }
.soscall__name { font-size: 2rem; font-weight: 800; margin: 10px 0 2px; }
.soscall__sub { opacity: 0.85; }
.soscall__dist { margin-top: 6px; font-weight: 700; }
.soscall__msg { margin: 16px 0; font-style: italic; opacity: 0.95; }
.soscall__actions { display: flex; gap: 18px; justify-content: center; margin-top: 28px; }
.soscall__btn { border: none; border-radius: 50%; width: 76px; height: 76px; font-size: 0.9rem; font-weight: 700; color: #fff; cursor: pointer; }
.soscall__btn--accept { background: #16a34a; }
.soscall__btn--reject { background: #dc2626; }
.soscall__btn:active { transform: scale(0.95); }

/* ===== Bus Stand Details ===== */
.bs-list { display: flex; flex-direction: column; gap: 12px; }
.bs-card { border: 1px solid var(--border); border-radius: 12px; background: var(--panel-2); padding: 14px 16px; }
.bs-card__name { font-size: 1.05rem; font-weight: 800; }
.bs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 18px; margin: 10px 0; }
.bs-row { display: flex; justify-content: space-between; gap: 12px; font-size: 0.86rem; padding: 2px 0; }
.bs-row--wide { grid-column: 1 / -1; }
.bs-row span { color: var(--muted); }
.bs-row strong { font-variant-numeric: tabular-nums; text-align: right; }
.bs-card__acts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.bs-card__acts .btn { padding: 6px 10px; font-size: 0.8rem; }
/* Facilities & Amenities */
.bs-fac-title { margin: 6px 0 4px; font-size: 0.9rem; border-top: 1px solid var(--border); padding-top: 12px; }
.bs-fac-chips { font-size: 1.05rem; letter-spacing: 3px; margin: 8px 0 2px; }
.bs-cond { font-size: 0.7rem; font-weight: 700; padding: 2px 8px; border-radius: 999px; vertical-align: middle; }
.bs-cond--excellent { background: rgba(34,197,94,0.18); color: #16a34a; }
.bs-cond--good { background: rgba(59,130,246,0.18); color: #2563eb; }
.bs-cond--average { background: rgba(245,158,11,0.18); color: #d97706; }
.bs-cond--poor { background: rgba(239,68,68,0.18); color: #dc2626; }
.bs-live { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }
.bs-live__pill { border: 1px solid var(--border); border-radius: 999px; padding: 4px 12px; font-size: 0.85rem; font-weight: 600; }
.bs-live__pill--in { color: var(--ok); border-color: color-mix(in srgb, var(--ok) 45%, transparent); }
.bs-live__pill--arr { color: var(--warn); border-color: color-mix(in srgb, var(--warn) 45%, transparent); }
.bs-live__pill--dep { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }

/* ===== Reusable staff filter bar (Sub Admin+) ===== */
.sf-host:empty { display: none; }
.sf-host { margin-bottom: 14px; }
.staff-filter { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; box-shadow: var(--card-shadow); }
.staff-filter select { width: auto; min-width: 170px; flex: 1 1 170px; }
.staff-filter .sf-refresh { margin-left: auto; white-space: nowrap; }
@media (max-width: 560px) { .staff-filter .sf-refresh { margin-left: 0; width: 100%; } }

/* ===== Transfer Management ===== */
.xfer-counts { padding: 8px 0; }
.xfer-checks { display: flex; flex-direction: column; gap: 8px; padding: 4px 0 10px; }
.xfer-checks label { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.xfer-checks input { width: auto; }
.xfer-list { display: flex; flex-direction: column; gap: 6px; margin: 8px 0; max-height: 320px; overflow-y: auto; border: 1px solid var(--border); border-radius: 10px; padding: 8px; }
.xfer-checkall { padding: 4px 6px 8px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.xfer-checkall label, .xfer-item { display: flex; align-items: center; gap: 8px; cursor: pointer; }
.xfer-item { padding: 7px 8px; border-radius: 8px; }
.xfer-item:hover { background: var(--panel-2); }
.xfer-item input { width: auto; }
.xfer-item.is-busy { opacity: 0.6; cursor: not-allowed; }
.xfer-item span:first-of-type { flex: 1; }
.xfer-history { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.xfer-hist { border: 1px solid var(--border); border-radius: 10px; background: var(--panel-2); padding: 12px 14px; }
.xfer-hist__flow { font-size: 1.02rem; margin: 4px 0; }
.xfer-hist__items { margin-bottom: 2px; }
.loc-list { display: flex; flex-direction: column; gap: 8px; }
.loc-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.loc-row__main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.loc-row__main .uname { font-weight: 700; }
.loc-row .btn { padding: 6px 10px; font-size: 0.8rem; }

/* Location catalog coordinate picker */
.loc-map-box { max-width: 780px; }
.loc-map-wrap { background: var(--bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
#locPickerMap { width: 100%; height: min(55vh, 430px); display: block; cursor: crosshair; }
.loc-map-bg { fill: var(--panel-2); stroke: var(--border); }
.loc-map-grid { stroke: var(--border); stroke-width: 1; opacity: 0.55; }
.loc-map-point circle { fill: var(--accent); stroke: var(--panel); stroke-width: 3; pointer-events: none; }
.loc-map-selected circle:first-child { fill: var(--ok); opacity: 0.2; }
.loc-map-selected path { fill: var(--ok); stroke: var(--panel); stroke-width: 1.5; }
.loc-map-selected circle:last-child { fill: var(--panel); }
.loc-map-readout { min-height: 1.25em; margin: 10px 0 4px; color: var(--ok); font-weight: 600; font-variant-numeric: tabular-nums; }
/* Location autocomplete (typo-tolerant) */
.ac-wrap { position: relative; }
.ac-suggest { position: absolute; z-index: 50; left: 0; right: 0; top: calc(100% + 4px); background: var(--panel); border: 1px solid var(--border); border-radius: 10px; box-shadow: 0 12px 30px rgba(0,0,0,0.35); max-height: 260px; overflow-y: auto; display: flex; flex-direction: column; padding: 4px; }
.ac-suggest.hidden { display: none; }
.ac-item { display: flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%; text-align: left; padding: 9px 11px; border: 0; background: transparent; color: var(--text); border-radius: 7px; cursor: pointer; font-size: 0.9rem; }
.ac-item:hover { background: var(--panel-2); }
.ac-sub { color: var(--muted); font-size: 0.78rem; white-space: nowrap; }
.ac-create { color: var(--accent); font-weight: 600; border-top: 1px solid var(--border); margin-top: 2px; }
.ac-divider { padding: 6px 11px 3px; font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); border-top: 1px solid var(--border); margin-top: 2px; }
input[readonly] { opacity: 0.85; cursor: default; }

.conn-list { display: flex; flex-direction: column; gap: 8px; }
.conn-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.conn-row__main { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.conn-row__main .uname { font-weight: 700; }
.conn-row .btn { padding: 6px 9px; font-size: 0.78rem; }
/* Live graph-expanded route preview in the route builder */
.route-expanded { margin: 10px 0; }
.route-expanded:empty { display: none; }
.route-expanded__title { margin-bottom: 6px; }
.route-expanded__path { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.rx-stop { padding: 3px 9px; border-radius: 999px; font-size: 0.82rem; font-weight: 600; border: 1px solid var(--border); }
.rx-stop--anchor { color: var(--text); background: var(--panel-2); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
.rx-stop--auto { color: var(--accent); background: transparent; border-style: dashed; }
.rx-arrow { color: var(--muted); }

/* Create-Emergency live location block */
.emg-loc { background: var(--panel-2); border: 1px solid var(--border); border-radius: 10px; padding: 12px; }
.emg-loc__area { font-size: 1.2rem; font-weight: 700; margin-bottom: 6px; }
.emg-loc__coords { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px; margin-bottom: 6px; font-variant-numeric: tabular-nums; }

/* ===== Emergency page (active | resolved side by side) ===== */
.emg-toolbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.emg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: start; }
@media (max-width: 640px) { .emg-grid { grid-template-columns: 1fr; } }
.emg-list { list-style: none; margin: 10px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.emg-card { border: 1px solid var(--border); border-left: 4px solid var(--border); border-radius: 10px; padding: 11px 13px; background: var(--panel-2); }
.emg-card--critical { border-left-color: var(--err); }
.emg-card--high { border-left-color: #f97316; }
.emg-card--medium { border-left-color: var(--warn); }
.emg-card--low { border-left-color: var(--ok); }
.emg-card__head { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.emg-card__type { font-weight: 700; }
.emg-card__desc { margin-top: 4px; font-style: italic; }
.emg-card__img { max-width: 100%; max-height: 160px; object-fit: cover; border-radius: 8px; margin-top: 8px; display: block; }
.emg-card__acts { margin-top: 9px; }
.emg-card__acts .btn { padding: 6px 11px; font-size: 0.8rem; }
.emg-locked { font-size: 0.82rem; color: var(--muted); }
.emg-edit { margin-top: 10px; padding-top: 10px; border-top: 1px dashed var(--border); display: flex; flex-direction: column; gap: 8px; }

/* ===== Recent searches (Search Buses) ===== */
.recent-box { margin: 14px 0; }
.recent-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.recent-head .btn { padding: 5px 10px; font-size: 0.78rem; }
.recent-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: var(--panel-2); border: 1px solid var(--border); color: var(--text); border-radius: 999px; padding: 6px 12px; font-size: 0.82rem; cursor: pointer; }
.chip:hover { border-color: var(--accent); color: var(--accent); }

/* ===== Settings / Appearance ===== */
.set-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin: 14px 0; }
.set-row > span:first-child { font-weight: 600; }
.seg { display: inline-flex; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.seg__btn { background: var(--panel-2); color: var(--muted); border: none; padding: 9px 16px; cursor: pointer; font-size: 0.9rem; }
.seg__btn + .seg__btn { border-left: 1px solid var(--border); }
.seg__btn.is-active { background: var(--accent-strong); color: var(--btn-text); }
.accent-row { display: inline-flex; gap: 10px; }
.accent-dot { width: 30px; height: 30px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; padding: 0; }
.accent-dot.is-active { border-color: var(--text); box-shadow: 0 0 0 2px var(--panel); }
.accent-dot--blue { background: #0ea5e9; }
.accent-dot--green { background: #22c55e; }
.accent-dot--purple { background: #a855f7; }

/* ===== Accounts page (merged create + manage) ===== */
.acct-toolbar { gap: 8px; flex-wrap: wrap; }
.acct-toolbar input[type="search"] { min-width: 180px; }
.acct-list { list-style: none; margin: 12px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.acct-card { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap;
  border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: var(--panel-2); }
.acct-card__id { display: flex; flex-direction: column; gap: 2px; }
.acct-card__id .uname { font-weight: 700; }
/* Clickable account cards → open profile */
.acct-card--link { cursor: pointer; transition: border-color .12s, background .12s, filter .12s; }
.acct-card--link:hover { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 8%, var(--panel-2)); filter: brightness(1.08); }
.acct-card--link .acct-card__id { cursor: pointer; }
/* Small "view profile" affordance used in lists (transfer, etc.) */
.xfer-prof { margin-left: auto; background: none; border: 0; cursor: pointer; font-size: 0.95rem; padding: 0 4px; width: auto; opacity: 0.7; }
.xfer-prof:hover { opacity: 1; }
.notif--link { cursor: pointer; transition: background .12s; }
.notif--link:hover { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.acct-card__tags { display: flex; gap: 8px; align-items: center; margin-top: 4px; }
.acct-card__acts { display: flex; gap: 8px; flex-wrap: wrap; }
.acct-card__acts .btn { padding: 7px 11px; font-size: 0.82rem; }
.acct-box { max-width: 640px; max-height: 86vh; overflow-y: auto; }

/* ===== User Live Tracking — Nearby Live Buses (Rapido / MarineTraffic style) ===== */
.track-search { margin-bottom: 16px; }
.track-search h3 { margin: 0 0 8px; }
.track-search input { width: 100%; }
.track-search__row { display: flex; gap: 10px; align-items: stretch; }
.track-search__row #trackSearch { flex: 1; min-width: 0; }
.track-scope { display: flex; gap: 6px; flex-shrink: 0; }
.track-scope .btn { white-space: nowrap; }
.track-scope.hidden { display: none; }
@media (max-width: 560px) { .track-search__row { flex-direction: column; } .track-scope { width: 100%; } .track-scope .btn { flex: 1; } }
.track-grid { display: grid; grid-template-columns: minmax(260px, 38%) 1fr; gap: 16px; align-items: start; }
@media (max-width: 760px) { .track-grid { grid-template-columns: 1fr; } }
.nearby-list { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; max-height: 520px; overflow-y: auto; }
.nearby-card { border: 1px solid var(--border); border-radius: 12px; padding: 11px 13px; background: var(--panel-2); cursor: pointer; transition: border-color 0.15s; }
.nearby-card:hover { border-color: var(--accent); }
.nearby-card__head { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.nearby-card__head .uname { font-weight: 700; }
.nearby-card__rows { display: grid; grid-template-columns: 1fr 1fr; gap: 2px 12px; margin-top: 6px; font-size: 0.82rem; color: var(--muted); }

.track-map-card { position: relative; }
.track-map-wrap { position: relative; }
#trackMap { width: 100%; height: 460px; display: block; background: var(--panel-2); border: 1px solid var(--border); border-radius: 12px; z-index: 0; }
@media (max-width: 900px) { #trackMap { height: 360px; } }
.you-dot { fill: var(--accent); }
.you-halo { fill: var(--accent); opacity: 0.25; }

/* 🗺️ Leaflet live map */
.map-net { font-size: 0.74rem; font-weight: 700; padding: 2px 9px; border-radius: 999px; border: 1px solid color-mix(in srgb, var(--ok) 45%, transparent); color: var(--ok); white-space: nowrap; }
.map-net.is-offline { color: var(--accent); border-color: color-mix(in srgb, var(--accent) 45%, transparent); }
/* Dark theme: tint the raster OSM tiles to match (markers/controls unaffected) */
#trackMap.map--dark .leaflet-tile { filter: invert(1) hue-rotate(180deg) brightness(0.92) contrast(0.95); }
.leaflet-container { background: var(--panel-2); font: inherit; }
.leaflet-popup-content-wrapper, .leaflet-control-attribution { font-size: 0.72rem; }
/* Bus marker (DivIcon): pin + number label */
.lbus { display: flex; flex-direction: column; align-items: center; line-height: 1; pointer-events: auto; }
.lbus__pin { font-size: 22px; filter: drop-shadow(0 1px 2px rgba(0,0,0,0.5)); }
.lbus__lbl { font-size: 9px; font-weight: 700; color: #fff; background: var(--accent-strong); border-radius: 6px; padding: 0 4px; margin-top: 1px; white-space: nowrap; }
/* SOS marker (DivIcon) — pulsing red / amber / green */
.lsos { font-size: 20px; text-align: center; filter: drop-shadow(0 1px 2px rgba(0,0,0,0.5)); }
.lsos.sos-mark--active { animation: lsospulse 1.1s ease-in-out infinite; }
@keyframes lsospulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.25); } }

/* Floating quick-info popup */
.bus-popup {
  position: absolute; top: 14px; right: 14px; width: min(300px, 90%);
  background: var(--panel); border: 1px solid var(--accent); border-radius: 14px;
  padding: 16px; box-shadow: 0 12px 32px rgba(2, 6, 23, 0.55); z-index: 1100;
}
.bus-popup h3 { margin: 0 0 2px; }
.bus-popup__close { position: absolute; top: 8px; right: 10px; background: none; border: none; color: var(--muted); font-size: 1rem; cursor: pointer; }
.pop-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; margin: 12px 0; }
.pop-grid div { display: flex; flex-direction: column; gap: 1px; }
.pop-grid dt { color: var(--muted); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.3px; }
.pop-grid dd { margin: 0; font-weight: 700; font-size: 0.9rem; }
.bus-popup__acts { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }

/* 🗺️ Live Tracking — interactive route viewer */
.map-controls { display: flex; flex-wrap: wrap; gap: 6px; margin: 0 0 10px; }
.map-controls .btn { white-space: nowrap; }
.map-controls .btn:disabled { opacity: 0.45; cursor: not-allowed; }
.nearby-selected {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  margin: 4px 0 10px; padding: 8px 12px; border-radius: 10px;
  border: 1px solid color-mix(in srgb, var(--accent) 50%, transparent);
  background: color-mix(in srgb, var(--accent) 12%, var(--panel-2)); font-size: 0.84rem;
}
.nearby-selected.hidden { display: none; }
.nearby-card.is-active { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 35%, transparent); }
.nearby-card__cta { margin-top: 6px; font-size: 0.74rem; color: var(--accent); font-weight: 600; }
.nearby-card.is-active .nearby-card__cta { color: var(--ok); }
/* Selected bus marker — brighter pin + accent label */
.lbus--selected .lbus__pin { font-size: 28px; filter: drop-shadow(0 0 6px #22c55e); }
.lbus--selected .lbus__lbl { background: #16a34a; }
/* Source (A) / destination (B) route end markers */
.lend { display: flex; flex-direction: column; align-items: center; line-height: 1; pointer-events: auto; }
.lend__pin { width: 22px; height: 22px; border-radius: 50%; border: 2px solid #fff;
  display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.5); }
.lend__pin--src { background: #16a34a; }
.lend__pin--dst { background: #ef4444; }
.lend__lbl { font-size: 9px; font-weight: 700; color: #fff; background: rgba(15,23,42,0.85);
  border-radius: 6px; padding: 0 5px; margin-top: 3px; white-space: nowrap; }

/* Route Builder — editable Via Stops */
.via-list { list-style: none; margin: 8px 0; padding: 0; display: flex; flex-direction: column; gap: 6px; max-height: 38vh; overflow-y: auto; }
.via-item { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border: 1px solid var(--border); border-radius: 9px; background: var(--panel-2); }
.via-item.dragging { opacity: 0.45; }
.via-item__grip { cursor: grab; color: var(--muted); user-select: none; }
.via-item__n { color: var(--muted); font-variant-numeric: tabular-nums; min-width: 20px; }
.via-item__name { flex: 1; font-weight: 600; }
.via-item__name select { width: 100%; }
.via-item__acts { display: flex; gap: 6px; flex-wrap: wrap; }
.via-item__acts .btn { padding: 5px 9px; font-size: 0.78rem; }
.via-add { margin-top: 6px; }
.via-add select { flex: 1; min-width: 160px; }

/* Searchable / typeahead stop picker (route builder) */
.stop-search { position: relative; margin-top: 8px; }
.stop-search__input { width: 100%; padding: 10px 12px; border: 1px solid var(--border); border-radius: 9px; background: var(--input-bg, var(--panel-2)); color: var(--text); }
.stop-search__input:focus { outline: none; border-color: var(--accent); }
.stop-suggest { position: absolute; z-index: 40; left: 0; right: 0; top: calc(100% + 4px); background: var(--panel); border: 1px solid var(--border); border-radius: 10px; box-shadow: 0 12px 30px rgba(0,0,0,0.35); max-height: 240px; overflow-y: auto; display: flex; flex-direction: column; padding: 4px; }
.stop-suggest.hidden { display: none; }
.stop-suggest__item { text-align: left; width: 100%; padding: 9px 11px; border: 0; background: transparent; color: var(--text); border-radius: 7px; cursor: pointer; font-size: 0.9rem; }
.stop-suggest__item:hover { background: var(--panel-2); }
.stop-suggest__create { color: var(--accent); font-weight: 600; border-top: 1px solid var(--border); margin-top: 2px; }
.rename-inp { padding: 6px 9px; border: 1px solid var(--accent); border-radius: 7px; background: var(--input-bg, var(--panel-2)); color: var(--text); min-width: 140px; }

.bus-qr { text-align: center; }
.buscode { font-family: monospace; font-size: 1.4rem; letter-spacing: 3px; font-weight: 700; margin: 6px 0; }

/* Bus Passes tabs + rows */
.pass-pane { display: flex; flex-direction: column; gap: 16px; }
.bus-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.bus-row { border: 1px solid var(--border); border-radius: 12px; padding: 12px 14px; background: var(--panel-2); }
.bus-row__main { cursor: pointer; display: flex; flex-direction: column; gap: 2px; }
.bus-row__main .uname { font-weight: 700; }
.buscode-sm { font-family: monospace; font-size: 0.82rem; color: var(--accent); letter-spacing: 1px; }
.mod-badge { align-self: flex-start; margin-top: 4px; font-size: 0.74rem; color: var(--accent); border: 1px solid var(--accent); border-radius: 999px; padding: 2px 10px; }
.mod-badge strong { font-weight: 700; }
/* Route verification audit trail on bus cards */
.verify-block { margin-top: 8px; border: 1px solid color-mix(in srgb, var(--ok) 40%, transparent); border-radius: 9px; padding: 8px 10px; background: color-mix(in srgb, var(--ok) 8%, transparent); max-width: 360px; }
.verify-block--none { color: var(--muted); border-color: var(--border); background: transparent; font-size: 0.8rem; }
.verify-block__title { color: var(--ok); font-weight: 700; font-size: 0.82rem; margin-bottom: 4px; }
.verify-row { display: flex; justify-content: space-between; gap: 10px; font-size: 0.8rem; padding: 2px 0; }
.bus-row__actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.bus-row__actions .btn { padding: 7px 11px; font-size: 0.82rem; }

.scan-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.scan-row { border: 1px solid var(--border); border-radius: 12px; padding: 11px 14px; background: var(--panel-2); }
.scan-row__head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.scan-row__action { font-weight: 700; letter-spacing: 0.3px; }

.qr-box { background: #fff; padding: 12px; border-radius: 10px; display: inline-block; margin: 6px 0; }
.qr-box .qrcode { display: block; }

/* Structured 3-box bus code: BUS | series | seq */
.busbox { display: flex; align-items: stretch; gap: 6px; margin: 8px 0; }
.busbox__fixed {
  display: flex; align-items: center; justify-content: center; font-weight: 700;
  background: var(--panel-2); border: 1px solid var(--border); border-radius: 8px;
  padding: 0 14px; color: var(--accent); letter-spacing: 1px;
}
.busbox__series { flex: 0 0 110px; text-transform: uppercase; }
.busbox__seq { flex: 0 0 90px; text-align: center; letter-spacing: 2px; font-variant-numeric: tabular-nums; }

/* ============================================================================ */
/* 📱 Mobile-first optimization — tuned for Samsung Galaxy M34 (~412×915 CSS px) */
/* and similar phones, while staying responsive on tablet/desktop.              */
/* ============================================================================ */
/* Never allow the page itself to scroll sideways (tables/maps scroll internally). */
html, body { max-width: 100%; overflow-x: hidden; }
img, svg, video, canvas { max-width: 100%; }

@media (max-width: 767px) {
  body { font-size: 16px; }

  /* Layout + spacing for one-hand use */
  .main { padding: 14px 12px; max-width: 100%; }
  .view-title { font-size: 1.4rem; margin-bottom: 14px; }     /* ~22px heading */
  .view .card { margin-bottom: 14px; }
  .card { padding: 16px; border-radius: 14px; }
  .card h3 { font-size: 1rem; }

  /* Readability — body 16px, small 14px */
  .field, .user-list .meta, .meta { font-size: 0.9rem; }
  .small, .muted.small { font-size: 0.875rem; }

  /* Touch targets ≥ 44×44 px; 16px inputs prevent mobile zoom-on-focus */
  .btn, .iconbtn, .navitem, .tab, .profile__btn, .auth-tabs .tab { min-height: 44px; }
  .btn { padding: 11px 16px; font-size: 0.95rem; }
  input, select, textarea, .field input, .field select { min-height: 44px; font-size: 16px; }

  /* Header: ☰ + full-width search + avatar (search ~65% of the row) */
  .appbar { gap: 8px; padding: 0 10px; }
  .appbar__search { display: block; flex: 1 1 auto; max-width: none; }

  /* Sidebar as a slide-out drawer (already fixed at ≤860px) — make it roomy */
  .sidebar { width: 82vw; max-width: 310px; flex-basis: 82vw; padding: 12px 10px; }
  .navitem { font-size: 1rem; padding: 12px 14px; gap: 12px; }

  /* Cards stay multi-column (scaled-down desktop, not a single stack) */
  .dash-cards { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .dash-card { padding: 14px; }
  .dash-card .big { font-size: 1.35rem; }
  .pdf-grid, .cmp-list { grid-template-columns: repeat(2, 1fr); gap: 10px; }

  /* Modals: 95% width / 90vh, content scrolls, never off-screen */
  .modal { padding: 10px; align-items: flex-start; padding-top: 20px; }
  .modal__box { max-width: 95%; max-height: 90vh; padding: 16px; }

  /* Buttons + rows wrap instead of compressing (passes, accounts, wallet, etc.) */
  .row, .card__head, .acct-card__acts, .bs-card__acts, .sos-card__acts,
  .cmp-card__acts, .wd-acts, .sos-cc-card .sos-card__acts { flex-wrap: wrap; gap: 8px; }
  .card__head { align-items: flex-start; }

  /* Account rows stay desktop-style rows that simply wrap when tight (compact rows) */
  .acct-card__acts .btn { flex: 1 1 auto; }

  /* Tables: keep them inside a horizontally-scrollable wrapper only when needed */
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Toasts span the width comfortably */
  .toasts { left: 10px; right: 10px; }
}

/* Very small phones: dashboard to a single column */
@media (max-width: 380px) {
  .dash-cards { grid-template-columns: 1fr; }
  .sos-stats { grid-template-columns: 1fr 1fr; }
}

/* Tablet: comfortable 2–3 column dashboards, sidebar still a drawer ≤860px */
@media (min-width: 768px) and (max-width: 1023px) {
  .main { padding: 18px 18px; }
  .dash-cards { grid-template-columns: repeat(3, 1fr); }
}

/* 📲 PWA install button */
.install-btn { display: inline-flex; align-items: center; gap: 4px; background: var(--accent-strong); color: var(--btn-text); border: none; border-radius: 8px; padding: 8px 12px; font-size: 0.82rem; font-weight: 600; cursor: pointer; white-space: nowrap; }
.install-btn:hover { background: var(--accent); }
@media (max-width: 600px) { .install-btn { padding: 8px 10px; font-size: 0; gap: 0; } .install-btn::before { content: '⬇'; font-size: 1rem; } }

/* 🎙 Voice SOS */
.voice-sos { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 6px; }
.voice-sos select { width: auto; min-width: 110px; }
.voice-sos__hint { flex: 1 1 100%; }
#voiceSosBtn.is-listening { color: var(--err); border-color: var(--err); animation: voicepulse 1.2s ease-in-out infinite; }
@keyframes voicepulse { 50% { opacity: 0.55; } }

/* 🕒 Time Table */
.tt-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; margin-top: 14px; }
.tt-card { border: 1px solid var(--border); border-radius: 12px; background: var(--panel-2); padding: 14px; }
.tt-card__head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.tt-grid { grid-template-columns: 1fr 1fr 1fr; margin: 10px 0; }
@media (max-width: 480px) { .tt-grid { grid-template-columns: 1fr 1fr; } }
.tt-stops > summary { cursor: pointer; font-size: 0.82rem; color: var(--accent); }
.tt-stops ol { margin: 6px 0 0; padding-left: 18px; font-size: 0.82rem; }
.tt-stops li { display: flex; justify-content: space-between; gap: 10px; padding: 2px 0; }
.tt-card__acts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.tt-fb { margin-top: 8px; border-top: 1px dashed var(--border); padding-top: 8px; }
.tt-fb-form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
/* Time Table result cards — sister styling to the Search Buses result list. */
.tt-results { margin-top: 14px; }
.tt-results li { align-items: flex-start; }
.tt-results .stack { flex: 1; min-width: 0; gap: 5px; }
.tt-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 2px; }
.tt-chip { font-size: 0.74rem; background: color-mix(in srgb, var(--accent) 8%, transparent); border: 1px solid var(--border); border-radius: 8px; padding: 2px 8px; white-space: nowrap; }
.tt-chip b { color: var(--muted); font-weight: 600; }
.tt-acts { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.tt-stops > summary { list-style: none; }
.tt-stops > summary::-webkit-details-marker { display: none; }
.tt-stop-rows { display: flex; flex-direction: column; gap: 6px; max-height: 320px; overflow-y: auto; }
.tt-stop-row { display: grid; grid-template-columns: 1fr 64px 120px; gap: 8px; align-items: center; }
.tt-srow-km { text-align: right; white-space: nowrap; }
/* Read-only derived summary (departure / arrival / duration) — driven by the stops. */
.tt-derived { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin: 14px 0 6px; }
.tt-derived__item { background: color-mix(in srgb, var(--accent) 8%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent); border-radius: 10px; padding: 10px 12px; display: flex; flex-direction: column; gap: 3px; }
.tt-derived__item span { font-size: 0.7rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.tt-derived__item strong { font-size: 1.05rem; font-variant-numeric: tabular-nums; }
@media (max-width: 560px) { .tt-derived { grid-template-columns: 1fr; } }
