/* =====================================================================
   SkyDesk — Customer site (public)
   Refined-minimal, Google-Flights-style. Navy+teal on white. Mobile-first.
   ===================================================================== */

:root {
  --navy-900:#0b1f33; --navy-800:#0f2942; --navy-700:#16395c;
  --teal-700:#0a6b66; --teal-600:#0a8a83; --teal-500:#00a39c; --teal-50:#eafaf8;
  --ink-1:#15212e; --ink-2:#43566a; --ink-3:#7a8aa0;
  --line:#e4e9f0; --line-2:#eef2f7; --surface:#ffffff; --bg:#f6f8fb;
  --amber-bg:#fff6e0; --red:#c0392b; --green:#0a8a3c;
  --r-sm:8px; --r-md:12px; --r-lg:18px; --r-xl:26px;
  --shadow-sm:0 1px 2px rgba(16,40,68,.06), 0 1px 3px rgba(16,40,68,.05);
  --shadow-md:0 4px 16px rgba(16,40,68,.08);
  --shadow-lg:0 12px 40px rgba(16,40,68,.14);
  --font-display:'Bricolage Grotesque', system-ui, sans-serif;
  --font-body:'Plus Jakarta Sans', system-ui, sans-serif;
  --maxw:1120px;
}

* { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; }
body {
  font-family:var(--font-body); color:var(--ink-1); background:var(--bg);
  line-height:1.5; -webkit-font-smoothing:antialiased; min-height:100vh;
  display:flex; flex-direction:column;
}
#main { flex:1 0 auto; }
h1,h2,h3,h4 { font-family:var(--font-display); font-weight:700; line-height:1.1; letter-spacing:-.01em; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input,select { font-family:inherit; font-size:15px; }
img { max-width:100%; display:block; }

/* ---- layout helpers ---- */
.wrap { max-width:var(--maxw); margin:0 auto; padding:0 20px; }
.hidden { display:none !important; }
.muted { color:var(--ink-3); }
.spinner { width:22px;height:22px;border:2.5px solid var(--line);border-top-color:var(--teal-500);
  border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ============================ HEADER ============================ */
.site-header {
  position:sticky; top:0; z-index:50; background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line);
}
.site-header .wrap { display:flex; align-items:center; gap:18px; height:64px; }
.brand { display:flex; align-items:center; gap:9px; font-family:var(--font-display);
  font-weight:800; font-size:21px; letter-spacing:-.02em; color:var(--navy-900); }
.brand .mark { width:30px;height:30px;border-radius:8px;
  background:linear-gradient(135deg,var(--teal-500),var(--navy-800));
  display:grid;place-items:center;color:#fff;font-size:16px; }
.brand .dot { color:var(--teal-500); }
.header-spacer { flex:1; }
.header-nav { display:flex; align-items:center; gap:6px; }
.header-link { padding:9px 14px; border-radius:10px; font-weight:600; font-size:14px;
  color:var(--ink-2); transition:background .14s, color .14s; }
.header-link:hover { background:var(--bg); color:var(--ink-1); }
.btn-signin { padding:9px 18px; border-radius:10px; font-weight:700; font-size:14px;
  background:var(--navy-900); color:#fff; transition:transform .12s, box-shadow .14s; }
.btn-signin:hover { transform:translateY(-1px); box-shadow:var(--shadow-md); }
.avatar-btn { display:flex; align-items:center; gap:9px; padding:5px 6px 5px 14px; border-radius:30px;
  border:1px solid var(--line); background:#fff; font-weight:600; font-size:14px; color:var(--ink-1); }
.avatar-btn:hover { box-shadow:var(--shadow-sm); }
.avatar { width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--teal-500),var(--navy-700));
  color:#fff; display:grid; place-items:center; font-weight:700; font-size:13px; }

/* user dropdown */
.menu-pop { position:fixed; top:58px; right:20px; background:#fff; border:1px solid var(--line);
  border-radius:14px; box-shadow:var(--shadow-lg); min-width:220px; padding:8px; z-index:120;
  animation:popIn .14s ease; }
@keyframes popIn { from { opacity:0; transform:translateY(-6px); } }
.menu-pop .mp-head { padding:10px 12px 12px; border-bottom:1px solid var(--line-2); margin-bottom:6px; }
.menu-pop .mp-name { font-weight:700; }
.menu-pop .mp-email { font-size:12.5px; color:var(--ink-3); }
.menu-pop button { display:flex; width:100%; align-items:center; gap:10px; padding:10px 12px;
  border-radius:9px; font-size:14px; font-weight:500; color:var(--ink-1); text-align:left; }
.menu-pop button:hover { background:var(--bg); }
.menu-pop .mp-sep { height:1px; background:var(--line-2); margin:6px 0; }

/* ============================ HERO ============================ */
.hero { position:relative; padding:54px 0 120px; }
.hero::before { content:''; position:absolute; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(1200px 400px at 15% -10%, rgba(0,163,156,.10), transparent 60%),
    radial-gradient(900px 380px at 95% 0%, rgba(22,57,92,.10), transparent 55%);
}
.hero h1 { font-size:clamp(30px, 5vw, 46px); color:var(--navy-900); max-width:14ch; }
.hero .sub { margin-top:12px; color:var(--ink-2); font-size:clamp(15px,2.2vw,18px); max-width:46ch; }

/* ============================ SEARCH CARD ============================ */
.search-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-xl);
  box-shadow:var(--shadow-md); padding:18px; margin-top:26px; }
.sc-top { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px; }
.sc-seg { display:inline-flex; background:var(--bg); border-radius:12px; padding:4px; gap:2px; }
.sc-seg button { padding:8px 14px; border-radius:9px; font-weight:600; font-size:13.5px; color:var(--ink-2); }
.sc-seg button.active { background:#fff; color:var(--navy-900); box-shadow:var(--shadow-sm); }
.sc-chip { display:inline-flex; align-items:center; gap:7px; padding:8px 13px; border:1px solid var(--line);
  border-radius:11px; font-weight:600; font-size:13.5px; color:var(--ink-1); background:#fff; }
.sc-chip:hover { border-color:var(--teal-500); }
.sc-chip .ico { color:var(--ink-3); }

/* fields row */
.sc-fields { display:grid; grid-template-columns:1fr 1fr 1fr 1fr auto; gap:10px; align-items:stretch; }
.sc-fields.oneway { grid-template-columns:1fr 1fr 1fr auto; }
.mc-row { align-items:center; grid-template-columns:auto 1fr 1fr 1fr auto; }
.mc-no { width:28px;height:28px;border-radius:50%;background:var(--navy-900);color:#fff;font-weight:700;
  font-size:13px; display:grid;place-items:center; align-self:center; }
.mc-rem { width:34px;height:34px;border-radius:50%; color:var(--ink-3); font-size:22px; align-self:center;
  display:grid;place-items:center; }
.mc-rem:hover { background:#fdecec; color:var(--red); }
.sc-field { position:relative; border:1.5px solid var(--line); border-radius:13px; padding:9px 13px;
  background:#fff; transition:border-color .14s, box-shadow .14s; min-width:0; }
.sc-field:focus-within { border-color:var(--teal-500); box-shadow:0 0 0 4px rgba(0,163,156,.10); }
.sc-field label { display:block; font-size:10.5px; text-transform:uppercase; letter-spacing:.5px;
  color:var(--ink-3); font-weight:700; margin-bottom:1px; }
.sc-field input { width:100%; border:none; outline:none; font-size:15px; font-weight:600; color:var(--ink-1);
  background:transparent; padding:2px 0; }
.sc-field input::placeholder { color:var(--ink-3); font-weight:500; }
.sc-field .val { font-size:15px; font-weight:600; color:var(--ink-1); cursor:pointer; padding:2px 0; }
.sc-field.btnfield { border:none; padding:0; }
.btn-search { width:100%; height:100%; min-height:56px; border-radius:13px; background:var(--teal-500);
  color:#fff; font-weight:700; font-size:15px; display:flex; align-items:center; justify-content:center; gap:8px;
  transition:background .14s, transform .12s; padding:0 22px; white-space:nowrap; }
.btn-search:hover { background:var(--teal-600); transform:translateY(-1px); }
.btn-search:active { transform:none; }

/* swap button between origin/dest */
.sc-swap { position:absolute; right:-6px; top:50%; transform:translateY(-50%); z-index:3;
  width:30px;height:30px;border-radius:50%; background:#fff; border:1px solid var(--line);
  display:grid;place-items:center; color:var(--ink-2); box-shadow:var(--shadow-sm); }
.sc-swap:hover { color:var(--teal-600); border-color:var(--teal-500); }

/* autocomplete */
.ac { position:absolute; top:calc(100% + 6px); left:0; right:0; background:#fff; border:1px solid var(--line);
  border-radius:14px; box-shadow:var(--shadow-lg); max-height:340px; overflow:auto; z-index:80; padding:6px; }
.ac-item { display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:10px; cursor:pointer; }
.ac-item:hover, .ac-item.hl { background:var(--bg); }
.ac-iata { font-family:var(--font-display); font-weight:700; font-size:13px; color:var(--teal-700);
  background:var(--teal-50); border-radius:7px; padding:4px 7px; min-width:42px; text-align:center; }
.ac-city { font-weight:600; font-size:14px; }
.ac-name { font-size:12px; color:var(--ink-3); }
.ac-group { font-size:10.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--ink-3);
  font-weight:700; padding:8px 12px 4px; }

/* passengers / cabin popover */
.pop { position:absolute; top:calc(100% + 8px); background:#fff; border:1px solid var(--line);
  border-radius:16px; box-shadow:var(--shadow-lg); padding:14px; z-index:90; min-width:280px; }
.pax-row { display:flex; align-items:center; justify-content:space-between; padding:10px 0; }
.pax-row + .pax-row { border-top:1px solid var(--line-2); }
.pax-lbl b { font-size:14.5px; } .pax-lbl small { display:block; color:var(--ink-3); font-size:12px; }
.stepper { display:flex; align-items:center; gap:12px; }
.stepper button { width:32px;height:32px;border-radius:50%;border:1.5px solid var(--line); font-size:18px;
  color:var(--teal-600); display:grid;place-items:center; }
.stepper button:disabled { opacity:.4; }
.stepper span { min-width:18px; text-align:center; font-weight:700; }
.cabin-opts { display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-top:6px; }
.cabin-opts button { padding:9px; border:1.5px solid var(--line); border-radius:10px; font-weight:600;
  font-size:13px; color:var(--ink-2); }
.cabin-opts button.active { border-color:var(--teal-500); background:var(--teal-50); color:var(--teal-700); }

/* ---- calendar ---- */
.cal { position:absolute; top:calc(100% + 8px); left:0; background:#fff; border:1px solid var(--line);
  border-radius:16px; box-shadow:var(--shadow-lg); padding:14px; z-index:90; width:300px; }
.cal-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.cal-head b { font-weight:700; font-size:14.5px; }
.cal-head button { width:30px;height:30px;border-radius:8px; color:var(--ink-2); }
.cal-head button:hover { background:var(--bg); }
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.cal-dow { text-align:center; font-size:11px; color:var(--ink-3); font-weight:700; padding:4px 0; }
.cal-day { aspect-ratio:1; border-radius:9px; font-size:13px; font-weight:600; color:var(--ink-1);
  display:grid;place-items:center; }
.cal-day:hover:not(.disabled) { background:var(--teal-50); }
.cal-day.disabled { color:var(--line); pointer-events:none; }
.cal-day.today { box-shadow:inset 0 0 0 1.5px var(--teal-500); }
.cal-day.sel { background:var(--teal-500); color:#fff; }

/* ============================ FOOTER ============================ */
.site-footer { margin-top:32px; border-top:1px solid var(--line); background:#fff; }
.site-footer .wrap { display:flex; flex-wrap:wrap; gap:16px; align-items:center; padding:18px 20px; }
.site-footer .brand { font-size:17px; }
.foot-links { display:flex; gap:18px; flex-wrap:wrap; }
.foot-links a { font-size:13.5px; color:var(--ink-2); font-weight:500; }
.foot-links a:hover { color:var(--teal-600); }
.foot-copy { width:100%; font-size:12px; color:var(--ink-3); border-top:1px solid var(--line-2);
  padding-top:12px; margin-top:2px; }

/* ============================ RESULTS ============================ */
.results-head { padding:22px 0 8px; }
.results-summary { display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.results-summary h2 { font-size:22px; color:var(--navy-900); }
.results-summary .rt { color:var(--ink-3); font-size:14px; }
.results-layout { display:grid; grid-template-columns:248px 1fr; gap:22px; padding-bottom:40px; align-items:start; }
.filters { position:sticky; top:80px; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:16px; }
.filters h4 { font-size:13px; text-transform:uppercase; letter-spacing:.5px; color:var(--ink-3); margin-bottom:10px; }
.filter-group + .filter-group { margin-top:16px; border-top:1px solid var(--line-2); padding-top:16px; }
.fopt { display:flex; align-items:center; gap:9px; padding:6px 0; font-size:14px; cursor:pointer; }
.fopt input { width:16px;height:16px; accent-color:var(--teal-500); }
.sortbar { display:inline-flex; background:#fff; border:1px solid var(--line); border-radius:12px; padding:4px; gap:2px; }
.sortbar button { padding:8px 16px; border-radius:9px; font-weight:600; font-size:13.5px; color:var(--ink-2); }
.sortbar button.active { background:var(--navy-900); color:#fff; }

/* flight card */
.flight-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:16px 18px;
  margin-bottom:12px; transition:border-color .14s, box-shadow .14s; }
.flight-card:hover { border-color:var(--teal-500); box-shadow:var(--shadow-md); }
.fc-main { display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center; }
.fc-legs { display:flex; flex-direction:column; gap:12px; min-width:0; }
.fc-leg { display:grid; grid-template-columns:34px 1fr; gap:12px; align-items:center; }
.fc-airline-logo { width:34px;height:34px;border-radius:9px; color:#fff; font-weight:800; font-size:12px;
  display:grid;place-items:center; flex-shrink:0; }
.fc-times { display:flex; align-items:center; gap:14px; min-width:0; }
.fc-time { font-family:var(--font-display); font-weight:700; font-size:18px; white-space:nowrap; }
.fc-airport { font-size:12px; color:var(--ink-3); font-weight:600; }
.fc-path { flex:1; display:flex; flex-direction:column; align-items:center; min-width:60px; }
.fc-path .dur { font-size:11.5px; color:var(--ink-3); white-space:nowrap; }
.fc-path .line { width:100%; height:2px; background:var(--line); position:relative; margin:3px 0; border-radius:2px; }
.fc-path .line::before,.fc-path .line::after { content:''; position:absolute; top:50%; transform:translateY(-50%);
  width:5px;height:5px;border-radius:50%; background:var(--ink-3); }
.fc-path .line::before { left:0; } .fc-path .line::after { right:0; }
.fc-stops { font-size:11.5px; font-weight:700; }
.fc-stops.nonstop { color:var(--green); } .fc-stops.stops { color:var(--ink-2); }
.fc-meta { font-size:12px; color:var(--ink-3); margin-top:2px; }
.fc-airline-name { font-weight:600; font-size:13.5px; }
.fc-price { text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:6px;
  border-left:1px solid var(--line-2); padding-left:18px; }
.fc-price .amt { font-family:var(--font-display); font-weight:700; font-size:24px; color:var(--navy-900); }
.fc-price .per { font-size:11.5px; color:var(--ink-3); }
.btn-select { padding:10px 22px; border-radius:11px; background:var(--teal-500); color:#fff; font-weight:700;
  font-size:14px; transition:background .14s, transform .12s; }
.btn-select:hover { background:var(--teal-600); transform:translateY(-1px); }
.fc-expand { margin-top:14px; border-top:1px dashed var(--line); padding-top:14px; display:none; }
.flight-card.open .fc-expand { display:block; }
.fc-detail-row { display:flex; gap:10px; font-size:13px; color:var(--ink-2); padding:4px 0; }
.fare-badge { display:inline-block; font-size:11px; font-weight:700; padding:2px 8px; border-radius:6px; }
.fare-badge.ref { background:#e7f7ec; color:var(--green); }
.fare-badge.nonref { background:#fdecec; color:var(--red); }

/* ============================ MODALS ============================ */
.overlay { position:fixed; inset:0; background:rgba(11,31,51,.45); backdrop-filter:blur(2px); z-index:100;
  display:flex; align-items:center; justify-content:center; padding:20px; animation:fade .16s ease; }
@keyframes fade { from { opacity:0; } }
.modal { background:#fff; border-radius:var(--r-xl); box-shadow:var(--shadow-lg); width:100%; max-width:480px;
  max-height:92vh; overflow:auto; animation:rise .2s ease; }
.modal.lg { max-width:760px; }
@keyframes rise { from { opacity:0; transform:translateY(14px); } }
.modal-head { display:flex; align-items:center; justify-content:space-between; padding:20px 24px 0; }
.modal-head h3 { font-size:21px; color:var(--navy-900); }
.modal-x { width:34px;height:34px;border-radius:50%; color:var(--ink-3); font-size:20px; display:grid;place-items:center; }
.modal-x:hover { background:var(--bg); }
.modal-body { padding:18px 24px 24px; }
.modal-foot { padding:0 24px 24px; display:flex; gap:10px; justify-content:flex-end; }

.field { margin-bottom:14px; }
.field label { display:block; font-size:12.5px; font-weight:700; color:var(--ink-2); margin-bottom:5px; }
.field input, .field select { width:100%; padding:11px 13px; border:1.5px solid var(--line); border-radius:11px;
  outline:none; transition:border-color .14s, box-shadow .14s; }
.field input:focus, .field select:focus { border-color:var(--teal-500); box-shadow:0 0 0 4px rgba(0,163,156,.10); }
.field .hint { font-size:12px; color:var(--ink-3); margin-top:4px; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.btn { padding:11px 20px; border-radius:11px; font-weight:700; font-size:14.5px; transition:all .14s; }
.btn-primary { background:var(--teal-500); color:#fff; } .btn-primary:hover { background:var(--teal-600); }
.btn-dark { background:var(--navy-900); color:#fff; } .btn-dark:hover { background:var(--navy-800); }
.btn-ghost { background:#fff; border:1.5px solid var(--line); color:var(--ink-1); } .btn-ghost:hover { background:var(--bg); }
.btn-block { width:100%; }
.btn:disabled { opacity:.55; pointer-events:none; }
.form-err { background:#fdecec; color:var(--red); font-size:13px; padding:9px 12px; border-radius:9px; margin-bottom:12px; }
.form-switch { text-align:center; margin-top:14px; font-size:14px; color:var(--ink-2); }
.form-switch a { color:var(--teal-600); font-weight:700; cursor:pointer; }

/* steps bar (booking) */
.steps { display:flex; align-items:center; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.step { display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:600; color:var(--ink-3); }
.step .num { width:26px;height:26px;border-radius:50%; background:var(--bg); color:var(--ink-3);
  display:grid;place-items:center; font-size:13px; border:1.5px solid var(--line); }
.step.active .num { background:var(--navy-900); color:#fff; border-color:var(--navy-900); }
.step.done .num { background:var(--teal-500); color:#fff; border-color:var(--teal-500); }
.step.active, .step.done { color:var(--ink-1); }
.step-line { flex:1; height:2px; background:var(--line); min-width:16px; }

/* summary side panel */
.bk-grid { display:grid; grid-template-columns:1fr 290px; gap:22px; }
.summary { background:var(--bg); border-radius:var(--r-lg); padding:16px; }
.summary h4 { font-size:12.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--ink-3); margin-bottom:10px; }
.sum-row { display:flex; justify-content:space-between; font-size:13.5px; padding:5px 0; color:var(--ink-2); }
.sum-total { display:flex; justify-content:space-between; font-family:var(--font-display); font-weight:700;
  font-size:19px; color:var(--navy-900); border-top:1px solid var(--line); margin-top:8px; padding-top:10px; }

/* passenger card */
.pax-card { border:1px solid var(--line); border-radius:var(--r-md); padding:14px; margin-bottom:12px; }
.pax-card-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:12px; }
.pax-card h5 { font-size:14px; display:flex; align-items:center; gap:8px; margin:0; }
.pax-type-badge { font-size:11px; font-weight:700; background:var(--teal-50); color:var(--teal-700);
  padding:2px 8px; border-radius:6px; text-transform:capitalize; }
.fill-from { position:relative; }
.fill-btn { display:inline-flex; align-items:center; gap:5px; padding:6px 12px; border:1.5px solid var(--line);
  border-radius:9px; background:#fff; font-size:12.5px; font-weight:600; color:var(--teal-700); white-space:nowrap; }
.fill-btn:hover { border-color:var(--teal-500); background:var(--teal-50); }
.fill-menu { position:absolute; top:calc(100% + 4px); right:0; background:#fff; border:1px solid var(--line);
  border-radius:11px; box-shadow:var(--shadow-lg); padding:6px; min-width:200px; z-index:10; }
.fill-opt { display:block; width:100%; text-align:left; padding:9px 11px; border-radius:8px; font-size:13.5px;
  font-weight:500; color:var(--ink-1); }
.fill-opt:hover { background:var(--bg); }

/* flow / payment container */
.pay-methods { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.pay-method { flex:1; min-width:120px; display:flex; flex-direction:column; align-items:center; gap:6px;
  padding:14px 8px; border:1.5px solid var(--line); border-radius:13px; font-weight:600; font-size:13px;
  color:var(--ink-2); }
.pay-method.active { border-color:var(--teal-500); background:var(--teal-50); color:var(--teal-700);
  box-shadow:0 0 0 3px rgba(0,163,156,.10); }
.pay-method .pm-ic { font-size:22px; }
#flow-container { min-height:60px; margin-top:6px; }

/* account / orders */
.acct-tabs { display:flex; gap:4px; border-bottom:1px solid var(--line); margin-bottom:22px; flex-wrap:wrap; }
.acct-tab { padding:12px 18px; font-weight:600; font-size:14.5px; color:var(--ink-2); border-bottom:2.5px solid transparent;
  margin-bottom:-1px; }
.acct-tab.active { color:var(--navy-900); border-bottom-color:var(--teal-500); }
.order-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:16px 18px;
  margin-bottom:12px; display:grid; grid-template-columns:1fr auto; gap:14px; align-items:center; cursor:pointer;
  transition:border-color .14s, box-shadow .14s; }
.order-card:hover { border-color:var(--teal-500); box-shadow:var(--shadow-sm); }
.order-route { font-family:var(--font-display); font-weight:700; font-size:17px; color:var(--navy-900); }
.order-meta { font-size:13px; color:var(--ink-3); margin-top:3px; }
.pill { display:inline-block; font-size:11.5px; font-weight:700; padding:3px 10px; border-radius:20px; }
.pill.paid { background:#e7f7ec; color:var(--green); }
.pill.unpaid { background:var(--amber-bg); color:#9a6a00; }
.pill.failed { background:#fdecec; color:var(--red); }
.pill.confirmed { background:var(--teal-50); color:var(--teal-700); }
.pill.cancelled, .pill.pending { background:#eef1f5; color:var(--ink-2); }

.empty { text-align:center; padding:48px 20px; color:var(--ink-3); }
.empty .ico { font-size:40px; margin-bottom:10px; }

/* toast */
.toast-wrap { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:200; display:flex;
  flex-direction:column; gap:8px; align-items:center; }
.toast { background:var(--navy-900); color:#fff; padding:12px 20px; border-radius:12px; font-size:14px;
  font-weight:600; box-shadow:var(--shadow-lg); animation:rise .2s ease; max-width:90vw; }
.toast.err { background:var(--red); } .toast.ok { background:var(--teal-600); }

/* loading bar */
.loadbar { position:fixed; top:0; left:0; height:3px; width:0; background:var(--teal-500); z-index:300;
  transition:width .3s ease, opacity .3s; }

/* ============================ RESPONSIVE ============================ */
@media (max-width:900px) {
  .sc-fields, .sc-fields.oneway { grid-template-columns:1fr 1fr; }
  .sc-fields .btnfield { grid-column:1 / -1; }
  .mc-row { grid-template-columns:auto 1fr 1fr; }
  .mc-row .mc-rem { grid-column:3; justify-self:end; }
  .results-layout { grid-template-columns:1fr; }
  .filters { position:static; }
  .bk-grid { grid-template-columns:1fr; }
  .summary { order:-1; }
}
@media (max-width:560px) {
  .sc-fields, .sc-fields.oneway { grid-template-columns:1fr; }
  .mc-row { grid-template-columns:auto 1fr; }
  .mc-row .mc-no { grid-row:1; }
  .fc-main { grid-template-columns:1fr; }
  .fc-price { border-left:none; border-top:1px solid var(--line-2); padding-left:0; padding-top:12px;
    flex-direction:row; align-items:center; justify-content:space-between; width:100%; }
  .header-link.hide-sm { display:none; }
  .fc-time { font-size:16px; }
  .modal-foot { flex-direction:column-reverse; }
  .modal-foot .btn { width:100%; }
  .modal-head h3 { font-size:19px; }
  .sc-top { gap:6px; }
  .acct-tab { padding:10px 12px; font-size:13.5px; }
}
