/* ===================================================================
   trainstatus.com — premium brand design system
   Brand: EMERALD + warm GOLD. No blue. Light default + dark theme.
   Status hues kept separate from brand; "live/now" uses gold so it
   never collides with on-time green.
   Theme switching: <html data-theme="light|dark"> (server picks the
   default by IST hour; visitor can override via the navbar toggle).
   =================================================================== */

:root {
  /* Brand — emerald (fixed across themes) */
  --brand-900:#022c22;
  --brand-800:#064e3b;
  --brand-700:#065f46;
  --brand-600:#047857;
  --brand-500:#059669;
  --brand-400:#10b981;
  --brand-300:#6ee7b7;

  /* Accent — warm gold (fixed) */
  --gold-600:#b45309;
  --gold-500:#f59e0b;
  --gold-400:#fbbf24;

  /* ---- Light theme semantic tokens ---- */
  --bg:#f4faf7;            /* page — mint white */
  --surface:#ffffff;       /* cards / blocks */
  --surface-2:#eef5f1;     /* insets / inputs */
  --border:#e1ebe6;
  --border-strong:#cfdcd5;

  --ink-900:#0c1f1a;       /* headings — near-black green */
  --ink-800:#17302a;
  --ink-700:#2c473f;
  --ink-600:#496159;
  --ink-500:#6b837a;
  --ink-400:#93a8a0;
  --ink-300:#c2d0ca;
  --ink-200:#e1ebe6;       /* alias kept for legacy refs */
  --ink-100:#eef5f1;

  /* Brand-tinted helpers (adapt per theme) */
  --brand-ink:#047857;     /* brand text / links */
  --brand-tint:#e7f6ef;    /* soft brand fill */
  --brand-tint-2:#d6efe3;
  --brand-tint-border:#c4e7d6;

  /* Gold helpers (used for "live / current / now") */
  --gold-ink:#b45309;
  --gold-tint:#fef3c7;
  --gold-tint-border:#fce2a6;

  /* Status (separate from brand) */
  --ok-500:#10b981; --ok-600:#059669; --ok-ink:#059669; --ok-tint:#d1fae5;
  --bad-500:#ef4444; --bad-600:#dc2626; --bad-ink:#dc2626; --bad-tint:#fee2e2;
  --warn-500:#f59e0b; --warn-ink:#b45309; --warn-tint:#fef3c7;
  --early-500:#0d9488; --early-ink:#0d9488; --early-tint:#ccfbf1;

  /* Always-dark surfaces (footer, current-position bar) */
  --ink-bg:#06140f;
  --ink-bg-2:#0a1d16;

  --radius:14px;
  --radius-lg:20px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(6,30,22,.06), 0 1px 3px rgba(6,30,22,.07);
  --shadow:0 4px 14px rgba(6,30,22,.08), 0 2px 4px rgba(6,30,22,.05);
  --shadow-lg:0 18px 40px -12px rgba(2,44,34,.26), 0 8px 16px -8px rgba(6,30,22,.10);
  --shadow-brand:0 14px 30px -10px rgba(4,120,87,.42);

  --font-sans:'Inter','Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-head:'Plus Jakarta Sans','Inter','Segoe UI',sans-serif;
  --maxw:1140px;

  --header-bg:rgba(255,255,255,.82);
}

/* ---- Dark theme overrides ---- */
[data-theme="dark"] {
  --bg:#0a1612;
  --surface:#11201b;
  --surface-2:#16271f;
  --border:#23352d;
  --border-strong:#2e433a;

  --ink-900:#f1f7f4;
  --ink-800:#e2ece8;
  --ink-700:#c6d5ce;
  --ink-600:#9eb3aa;
  --ink-500:#849a90;
  --ink-400:#6d837a;
  --ink-300:#475a52;
  --ink-200:#23352d;
  --ink-100:#16271f;

  --brand-ink:#34d399;
  --brand-tint:rgba(16,185,129,.13);
  --brand-tint-2:rgba(16,185,129,.18);
  --brand-tint-border:rgba(16,185,129,.28);

  --gold-ink:#fbbf24;
  --gold-tint:rgba(245,158,11,.14);
  --gold-tint-border:rgba(245,158,11,.32);

  --ok-ink:#34d399; --ok-tint:rgba(16,185,129,.16);
  --bad-ink:#f87171; --bad-tint:rgba(239,68,68,.16);
  --warn-ink:#fbbf24; --warn-tint:rgba(245,158,11,.16);
  --early-ink:#2dd4bf; --early-tint:rgba(45,212,191,.16);

  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 4px 14px rgba(0,0,0,.45);
  --shadow-lg:0 18px 40px -12px rgba(0,0,0,.6);
  --shadow-brand:0 14px 30px -10px rgba(4,120,87,.5);

  --header-bg:rgba(12,26,21,.82);

  color-scheme:dark;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font-sans);color:var(--ink-800);
  background:var(--bg);line-height:1.55;font-size:15.5px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  transition:background-color .3s ease,color .3s ease;
}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--ink-900);line-height:1.2;margin:0 0 .4em;font-weight:700}
a{color:var(--brand-ink);text-decoration:none;transition:color .15s}
a:hover{color:var(--brand-500)}
img{max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.muted{color:var(--ink-500)}
.tiny{font-size:12.5px}
.center{text-align:center}
.nowrap{white-space:nowrap}

/* ---------- Header / navbar ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--header-bg);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:800;font-size:20px;color:var(--ink-900);letter-spacing:-.02em}
.brand:hover{color:var(--ink-900)}
.brand .logo{
  width:38px;height:38px;border-radius:11px;flex:0 0 auto;
  background:linear-gradient(135deg,var(--brand-500),var(--brand-700));
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:var(--shadow-brand);position:relative;
}
.brand .logo svg{width:21px;height:21px}
.brand .logo::after{content:"";position:absolute;right:-3px;top:-3px;width:11px;height:11px;border-radius:50%;background:var(--gold-500);border:2px solid var(--surface)}
.brand b{color:var(--brand-ink)}
.brand .dotcom{color:var(--ink-400);font-weight:600}
.nav{display:flex;align-items:center;gap:6px}
.nav a{padding:8px 14px;border-radius:9px;color:var(--ink-600);font-weight:600;font-size:14.5px}
.nav a:hover{background:var(--brand-tint);color:var(--brand-ink)}

/* Theme toggle */
.theme-toggle{
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  width:40px;height:40px;border-radius:11px;cursor:pointer;
  border:1.5px solid var(--border);background:var(--surface-2);color:var(--ink-600);
  transition:color .15s,border-color .15s,background .15s,transform .12s;
}
.theme-toggle:hover{color:var(--gold-ink);border-color:var(--gold-tint-border);background:var(--gold-tint)}
.theme-toggle:active{transform:scale(.94)}
.theme-toggle svg{width:19px;height:19px}
.theme-toggle .ic-sun{display:none}
.theme-toggle .ic-moon{display:block}
[data-theme="dark"] .theme-toggle .ic-sun{display:block}
[data-theme="dark"] .theme-toggle .ic-moon{display:none}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:radial-gradient(1200px 400px at 80% -10%,rgba(245,158,11,.20),transparent 60%),
             linear-gradient(135deg,var(--brand-900) 0%,var(--brand-800) 45%,var(--brand-600) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 2px,transparent 2px 46px);
  -webkit-mask-image:linear-gradient(to bottom,transparent,#000 40%,transparent);
          mask-image:linear-gradient(to bottom,transparent,#000 40%,transparent);
}
.hero .container{position:relative;padding-top:54px;padding-bottom:104px}
.hero h1{color:#fff;font-size:clamp(28px,4.4vw,46px);font-weight:800;letter-spacing:-.025em;margin-bottom:.3em}
.hero h1 .accent{color:var(--gold-400)}
.hero p.lead{color:rgba(255,255,255,.85);font-size:clamp(15px,2vw,19px);max-width:620px;margin:0 auto}
.hero.center .container{text-align:center}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  color:#fff;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:18px}
.hero .eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--gold-400);box-shadow:0 0 0 0 rgba(251,191,36,.7);animation:pulse 1.8s infinite}

/* ---------- Search card ---------- */
.search-wrap{max-width:760px;margin:30px auto 0;position:relative;z-index:5}
.search-card{
  background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
  padding:18px;display:flex;gap:12px;align-items:stretch;flex-wrap:wrap;border:1px solid var(--border);
}
.search-card .field{flex:1 1 230px;min-width:0;position:relative;display:flex;flex-direction:column}
.search-card .field.date{flex:1 1 180px}
.search-card label{font-size:11.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-500);margin:2px 4px 6px}
.search-card input,.search-card select{
  width:100%;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);
  padding:13px 14px;font-size:15.5px;font-family:var(--font-sans);color:var(--ink-900);transition:border-color .15s,box-shadow .15s;
}
.search-card input:focus,.search-card select:focus{outline:none;border-color:var(--brand-400);box-shadow:0 0 0 4px var(--brand-tint);background:var(--surface)}
.search-card .go{flex:0 0 auto;display:flex;align-items:flex-end}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;
  font-family:var(--font-head);font-weight:700;font-size:15.5px;border:none;border-radius:var(--radius-sm);
  padding:13px 26px;color:#fff;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));
  box-shadow:var(--shadow-brand);transition:transform .12s,box-shadow .2s,filter .2s;white-space:nowrap;
}
.btn:hover{color:#fff;filter:brightness(1.06);box-shadow:0 16px 34px -10px rgba(4,120,87,.55)}
.btn:active{transform:translateY(1px)}
.btn svg{width:18px;height:18px}
.btn.gold{background:linear-gradient(135deg,var(--gold-400),var(--gold-600));box-shadow:0 14px 30px -10px rgba(180,83,9,.5)}
.btn-block{width:100%}
.btn.ghost{background:transparent;color:var(--brand-ink);box-shadow:none;border:1.5px solid var(--border)}
.btn.ghost:hover{background:var(--brand-tint);color:var(--brand-ink);filter:none}

/* Autocomplete dropdown */
.ac-list{
  position:absolute;top:100%;left:0;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:60;max-height:320px;overflow:auto;display:none;
}
.ac-list.open{display:block}
.ac-item{padding:11px 14px;cursor:pointer;display:flex;align-items:center;gap:11px;border-bottom:1px solid var(--border)}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item.active{background:var(--brand-tint)}
.ac-item .code{font-weight:800;color:var(--brand-ink);font-size:13px;background:var(--brand-tint);border:1px solid var(--brand-tint-border);border-radius:7px;padding:3px 8px;flex:0 0 auto}
.ac-item .label{color:var(--ink-800);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---------- Layout sections ---------- */
.section{padding:38px 0}
.pull-up{margin-top:-64px;position:relative;z-index:4}
.grid{display:grid;gap:22px}
.grid.cols-2{grid-template-columns:2fr 1fr}
@media(max-width:900px){.grid.cols-2{grid-template-columns:1fr}}

/* ---------- Block / card ---------- */
.block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}
.block + .block{margin-top:22px}
.block-title{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border)}
.block-title h2,.block-title h3{font-size:16.5px;margin:0;display:flex;align-items:center;gap:10px}
.block-title h2::before{content:"";width:4px;height:18px;border-radius:3px;background:linear-gradient(var(--brand-500),var(--brand-700));display:inline-block}
.block-content{padding:20px}
.block-content.flush{padding:0}

/* ---------- Badges / chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:12.5px;padding:4px 11px;border-radius:999px;line-height:1.4}
.chip.ontime{background:var(--ok-tint);color:var(--ok-ink)}
.chip.late{background:var(--bad-tint);color:var(--bad-ink)}
.chip.early{background:var(--early-tint);color:var(--early-ink)}
.chip.live{background:var(--gold-tint);color:var(--gold-ink)}
.chip.reached{background:var(--ok-tint);color:var(--ok-ink)}
.chip.pending{background:var(--surface-2);color:var(--ink-600)}
.chip.pf{background:var(--gold-tint);color:var(--gold-ink)}
.chip .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.chip.live .dot{animation:pulse 1.6s infinite}

/* ---------- Status summary header ---------- */
.status-head{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.status-head .top{padding:22px 24px;display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;
  background:linear-gradient(135deg,var(--brand-tint),var(--surface))}
.status-head .tno{font-family:var(--font-head);font-weight:800;color:var(--brand-ink);font-size:14px;letter-spacing:.06em}
.status-head h1{font-size:clamp(20px,3vw,27px);margin:.15em 0 .1em;letter-spacing:-.02em}
.status-head .route{color:var(--ink-600);font-weight:600;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.status-head .route .arr{color:var(--brand-400)}
.status-head .delaybox{text-align:right;flex:0 0 auto}
.status-head .delaybox .big{font-family:var(--font-head);font-weight:800;font-size:30px;line-height:1}
.status-head .delaybox .big.late{color:var(--bad-ink)}
.status-head .delaybox .big.ontime{color:var(--ok-ink)}
.status-head .delaybox .big.early{color:var(--early-ink)}
.status-head .cpos{padding:14px 24px;background:var(--ink-bg);color:#fff;display:flex;align-items:center;gap:12px;font-weight:600;font-size:14.5px}
.status-head .cpos svg{width:18px;height:18px;color:var(--gold-400);flex:0 0 auto}
.status-head .cpos .upd{margin-left:auto;color:rgba(255,255,255,.6);font-weight:500;font-size:12.5px}

/* progress bar */
.progress{height:9px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin:0}
.progress > span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand-500),var(--gold-500))}
.progress-wrap{padding:16px 24px;border-top:1px solid var(--border)}
.progress-wrap .pl{display:flex;justify-content:space-between;font-size:12.5px;font-weight:600;color:var(--ink-500);margin-bottom:8px}

/* ---------- Station timeline ---------- */
.timeline{position:relative;padding:6px 0}
.tl-item{position:relative;display:grid;grid-template-columns:34px 1fr auto;gap:14px;padding:14px 22px;align-items:start}
.tl-item::before{content:"";position:absolute;left:38px;top:0;bottom:0;width:2px;background:var(--border-strong)}
.tl-item:first-child::before{top:50%}
.tl-item:last-child::before{bottom:50%}
.tl-node{position:relative;z-index:2;width:18px;height:18px;border-radius:50%;margin:4px 0 0 9px;background:var(--surface);border:3px solid var(--border-strong);flex:0 0 auto}
.tl-item.passed .tl-node{background:var(--ok-500);border-color:var(--ok-500)}
.tl-item.passed .tl-node::after{content:"";position:absolute;left:4px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.tl-item.current .tl-node{border-color:var(--gold-500);background:var(--gold-500);box-shadow:0 0 0 5px var(--gold-tint);animation:ring 1.8s infinite}
.tl-item.upcoming .tl-node{background:var(--surface);border-color:var(--border-strong)}
.tl-item.current{background:linear-gradient(90deg,var(--gold-tint),transparent)}
.tl-main .sname{font-family:var(--font-head);font-weight:700;color:var(--ink-900);font-size:15.5px}
.tl-main .scode{color:var(--ink-400);font-weight:700;font-size:12px;margin-left:6px}
.tl-main .shn{color:var(--ink-500);font-size:13px;margin-top:1px}
.tl-main .meta{margin-top:7px;display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.tl-times{text-align:right;font-size:13px;min-width:120px}
.tl-times .row{display:flex;gap:8px;justify-content:flex-end;align-items:baseline;white-space:nowrap}
.tl-times .lab{color:var(--ink-400);font-size:11px;font-weight:700;text-transform:uppercase}
.tl-times .sch{color:var(--ink-400);text-decoration:line-through}
.tl-times .act{font-weight:700;color:var(--ink-900)}
.tl-times .act.late{color:var(--bad-ink)}
.tl-times .act.ontime{color:var(--ok-ink)}
.tl-times .act.early{color:var(--early-ink)}

/* ---------- Popular trains grid ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}
.tcard{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 17px;box-shadow:var(--shadow-sm);transition:transform .14s,box-shadow .2s,border-color .2s}
.tcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--brand-tint-border);color:inherit}
.tcard .tcno{font-family:var(--font-head);font-weight:800;color:var(--brand-ink);font-size:13px;letter-spacing:.04em}
.tcard .tcname{font-family:var(--font-head);font-weight:700;color:var(--ink-900);font-size:16px;margin:3px 0 10px;line-height:1.25}
.tcard .tcfoot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px}
.tcard .tcloc{color:var(--ink-500);font-size:13px;display:flex;align-items:center;gap:6px;min-width:0}
.tcard .tcloc svg{width:14px;height:14px;color:var(--brand-400);flex:0 0 auto}
.tcard .tcloc span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ---------- Map ---------- */
#routemap{height:420px;width:100%;border-radius:var(--radius);overflow:hidden;z-index:1}
.leaflet-container{font-family:var(--font-sans)}

/* ---------- Dedicated map page ---------- */
.map-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.map-bar .tno{font-family:var(--font-head);font-weight:800;color:var(--brand-ink);font-size:13px;letter-spacing:.06em}
.map-bar h1{font-size:clamp(19px,2.6vw,24px);margin:.1em 0 .15em}
.map-bar .route{color:var(--ink-600);font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:14px}
.map-bar .route .arr{color:var(--brand-400)}
.map-bar .actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.maproute{display:grid;grid-template-columns:1fr 384px;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}
.maproute .map-pane{position:relative;min-height:640px}
.maproute #routemap{height:100%;border-radius:0}
.maproute .stn-pane{border-left:1px solid var(--border);min-height:640px;max-height:80vh;overflow:auto;background:var(--surface)}
.stn-pane .ph{position:sticky;top:0;z-index:2;background:var(--surface);border-bottom:1px solid var(--border);padding:13px 16px;font-family:var(--font-head);font-weight:700;font-size:14px;color:var(--ink-700);display:flex;justify-content:space-between;align-items:center}
.stnrow{display:grid;grid-template-columns:24px 1fr auto;gap:11px;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s}
.stnrow:last-child{border-bottom:none}
.stnrow:hover,.stnrow.hl{background:var(--brand-tint)}
.stnrow .nd{position:relative;width:14px;height:14px;border-radius:50%;margin:3px 0 0 4px;background:var(--surface);border:3px solid var(--border-strong);flex:0 0 auto}
.stnrow.passed .nd{background:var(--ok-500);border-color:var(--ok-500)}
.stnrow.current .nd{background:var(--gold-500);border-color:var(--gold-500);box-shadow:0 0 0 4px var(--gold-tint)}
.stnrow .sn{font-family:var(--font-head);font-weight:700;color:var(--ink-900);font-size:14.5px;line-height:1.2}
.stnrow .sc{color:var(--ink-400);font-weight:700;font-size:11.5px;margin-left:5px}
.stnrow .sub{margin-top:4px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.stnrow .tm{text-align:right;font-size:12.5px;white-space:nowrap;color:var(--ink-600)}
.stnrow .tm .big{font-weight:700;color:var(--ink-900);font-size:13.5px}
.stnrow .tm .big.late{color:var(--bad-ink)}
.stnrow .tm .big.ontime{color:var(--ok-ink)}
.map-pop{font-family:var(--font-sans)}
.map-pop b{font-family:var(--font-head)}
@media(max-width:900px){
  .maproute{grid-template-columns:1fr}
  .maproute .map-pane{min-height:380px}
  .maproute .stn-pane{border-left:none;border-top:1px solid var(--border);min-height:0;max-height:460px}
}

/* ---------- Notice ---------- */
.notice{display:flex;gap:13px;align-items:flex-start;background:var(--gold-tint);border:1px solid var(--gold-tint-border);color:var(--gold-ink);border-radius:var(--radius);padding:16px 18px;font-weight:500}
.notice svg{width:20px;height:20px;flex:0 0 auto;margin-top:1px}
.notice.info{background:var(--brand-tint);border-color:var(--brand-tint-border);color:var(--brand-ink)}

/* ---------- Date stepper (status page) ---------- */
.datenav{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:18px 0 0}
.datenav .dn-cur{font-size:13.5px;color:var(--ink-600);font-weight:600}
.datenav .dn-cur b{color:var(--ink-900)}
.btn.sm{padding:9px 16px;font-size:14px;border-radius:var(--radius-sm)}
.btn.ghost.sm svg{width:16px;height:16px}

/* ---------- Breadcrumb ---------- */
.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:13px;font-weight:600;color:var(--ink-500);padding:14px 0 2px}
.breadcrumb a{color:var(--ink-500)}
.breadcrumb a:hover{color:var(--brand-ink)}
.breadcrumb span[aria-current]{color:var(--ink-800)}
.breadcrumb .sep{width:15px;height:15px;color:var(--ink-300);flex:0 0 auto}

/* ---------- FAQ ---------- */
.faq{margin-top:22px}
.faq details{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden}
.faq details[open]{border-color:var(--brand-tint-border)}
.faq summary{list-style:none;cursor:pointer;padding:16px 18px;font-family:var(--font-head);font-weight:700;font-size:15.5px;color:var(--ink-900);display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:22px;font-weight:600;color:var(--brand-ink);line-height:1;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 18px 16px;color:var(--ink-700);font-size:14.5px;line-height:1.6}

/* ---------- Feature strip ---------- */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.feature{padding:4px 6px}
.feature .ic{width:44px;height:44px;border-radius:12px;background:var(--brand-tint);color:var(--brand-ink);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.feature .ic svg{width:22px;height:22px}
.feature h3{font-size:16px;margin-bottom:5px}
.feature p{color:var(--ink-500);font-size:14px;margin:0}

/* ---------- Footer (always dark) ---------- */
.site-footer{background:var(--ink-bg);color:rgba(255,255,255,.7);margin-top:48px;padding:42px 0 28px}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:#fff}
.site-footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:28px;padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.08)}
@media(max-width:760px){.site-footer .cols{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:14px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:14px}
.site-footer .fbrand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;font-size:19px;color:#fff;margin-bottom:10px}
.site-footer .fbrand .logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--brand-500),var(--brand-700));display:flex;align-items:center;justify-content:center}
.site-footer .fbrand .logo svg{width:19px;height:19px;color:#fff}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer ul li{margin-bottom:9px;font-size:14px}
.site-footer .copy{padding-top:20px;font-size:13px;color:rgba(255,255,255,.45);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ---------- Animations ---------- */
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(251,191,36,.6)}70%{box-shadow:0 0 0 9px rgba(251,191,36,0)}100%{box-shadow:0 0 0 0 rgba(251,191,36,0)}}
@keyframes ring{0%{box-shadow:0 0 0 0 rgba(245,158,11,.45)}70%{box-shadow:0 0 0 8px rgba(245,158,11,0)}100%{box-shadow:0 0 0 0 rgba(245,158,11,0)}}

/* ---------- Responsive ---------- */
@media(max-width:620px){
  .search-card{padding:14px;gap:10px}
  .search-card .field,.search-card .go{flex:1 1 100%}
  .btn.go-btn,.search-card .go .btn{width:100%}
  .hero .container{padding-bottom:88px}
  .status-head .delaybox{text-align:left}
  .tl-item{grid-template-columns:30px 1fr;gap:10px;padding:14px 16px}
  .tl-item::before{left:33px}
  .tl-times{grid-column:2;text-align:left;margin-top:8px}
  .tl-times .row{justify-content:flex-start}
  .nav a:not(.btn):not(.theme-toggle){display:none}
}
