:root{
  --navy:#0b1f3a; --navy2:#13294b; --blue:#1e6fff; --blue-d:#155ce0;
  --ink:#0e1726; --gray:#5b6573; --line:#e6eaf0; --bg:#f4f6fb; --white:#fff;
  --green:#0fae6b; --amber:#f5a623; --red:#e5484d;
  --r:16px; --r-sm:11px; --shadow:0 6px 24px rgba(16,30,54,.10);
  --shadow-lg:0 18px 50px rgba(16,30,54,.20);
  --safe-b:env(safe-area-inset-bottom,0px);
  --card:#fff;
}
html[data-theme=dark]{
  --ink:#e8edf5; --gray:#9aa7b8; --line:#26344a; --bg:#0a1626; --white:#0f1f33; --card:#13243b;
  --shadow:0 6px 24px rgba(0,0,0,.35); --shadow-lg:0 18px 50px rgba(0,0,0,.5);
}
html[data-theme=dark] .fcard__buy{background:linear-gradient(180deg,#13243b,#0e1d31)}
html[data-theme=dark] .field,html[data-theme=dark] .trip,html[data-theme=dark] .cls-seg button,
html[data-theme=dark] .pax-tab,html[data-theme=dark] .sort-tabs{background:#0d1b2e}
html[data-theme=dark] .field__code,html[data-theme=dark] .swap{background:#0a1626}
html[data-theme=dark] .sub__form input{background:#0d1b2e;color:var(--ink)}
html[data-theme=dark] .fcard,html[data-theme=dark] .filters,html[data-theme=dark] .bk-card,
html[data-theme=dark] .deal,html[data-theme=dark] .route,html[data-theme=dark] .ft,
html[data-theme=dark] .rev,html[data-theme=dark] .faq__i,html[data-theme=dark] .cal__d,
html[data-theme=dark] .sort-tabs,html[data-theme=dark] .pbreak,html[data-theme=dark] .sheet__bar,
html[data-theme=dark] .sheet__panel,html[data-theme=dark] .mnav,html[data-theme=dark] .trust__in,
html[data-theme=dark] .pax-pop,html[data-theme=dark] .ac,html[data-theme=dark] .seat.taken,
html[data-theme=dark] .extra__ic,html[data-theme=dark] .pay-opt,html[data-theme=dark] .cur-menu,
html[data-theme=dark] .to-top{background:var(--card)}
html[data-theme=dark] .sheet__body,html[data-theme=dark] .bk-foot{background:var(--bg)}
html[data-theme=dark] .fcard__price,html[data-theme=dark] .bk-foot__sum b,html[data-theme=dark] .route__r b,
html[data-theme=dark] .deal__pr b,html[data-theme=dark] .trust__i b,html[data-theme=dark] .pbreak__r.tot{color:#fff}
html[data-theme=dark] .cal__d.lo{background:linear-gradient(180deg,#13243b,#0f2a22)}
html[data-theme=dark] .seat{background:#15324a;border-color:#1d4a3a}
html,body{transition:background .3s,color .3s}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 16px}
.muted{color:var(--gray)}
.link{color:var(--blue);background:none;font-weight:600;font-size:13px}
[hidden]{display:none!important}

/* ===== HEADER ===== */
.hdr{position:sticky;top:0;z-index:50;background:rgba(11,31,58,.0);transition:.25s}
.hdr.solid{background:var(--navy);box-shadow:0 2px 14px rgba(0,0,0,.18)}
.hdr__in{display:flex;align-items:center;gap:24px;height:64px}
.logo{display:flex;align-items:center;gap:9px;color:#fff;font-weight:800;font-size:20px}
.logo__mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--blue),#5aa0ff);color:#fff}
.hdr__nav{display:flex;gap:22px;margin-left:8px}
.hdr__nav a{color:#fff;font-weight:600;font-size:14px;opacity:.95}
.hdr__nav a.muted{opacity:.6}
.hdr__right{margin-left:auto;display:flex;align-items:center;gap:10px}
.chip-cur{color:#fff;font-weight:600;font-size:13px;padding:7px 11px;border-radius:9px;
  background:rgba(255,255,255,.14)}
.btn-ghost{color:#fff;font-weight:600;font-size:14px;padding:8px 16px;border-radius:10px;
  background:rgba(255,255,255,.16)}
.btn-ghost:hover{background:rgba(255,255,255,.26)}

/* ===== HERO ===== */
/* NB: overflow:hidden is on .hero__bg (not .hero) so the autocomplete dropdown can overflow the hero */
.hero{position:relative;padding:34px 0 70px}
.hero__bg{position:absolute;inset:0;z-index:-1;overflow:hidden;
  background:linear-gradient(160deg,#0b1f3a 0%,#13294b 45%,#1d3e74 100%)}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:radial-gradient(900px 400px at 80% -10%,rgba(94,160,255,.35),transparent 60%),
             radial-gradient(700px 350px at 10% 110%,rgba(15,174,107,.18),transparent 60%)}
.hero__title{color:#fff;font-size:34px;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.hero__sub{color:#c7d4ea;margin-top:8px;font-size:15px}

/* ===== SEARCH ===== */
.search{margin-top:22px;background:var(--white);border-radius:var(--r);padding:14px;
  box-shadow:var(--shadow-lg)}
.search__trips{display:flex;gap:6px;margin-bottom:12px;overflow-x:auto;scrollbar-width:none}
.search__trips::-webkit-scrollbar{display:none}
.trip{white-space:nowrap;padding:8px 15px;border-radius:999px;font-weight:600;font-size:13.5px;
  color:var(--gray);background:var(--bg)}
.trip.is-on{background:var(--navy);color:#fff}
.search__grid{display:grid;gap:8px;position:relative;
  grid-template-columns:1fr auto 1fr 1fr 1fr 1.2fr auto;align-items:stretch}
.field{position:relative;background:var(--bg);border:1.5px solid transparent;border-radius:var(--r-sm);
  padding:9px 12px;min-width:0;transition:.15s}
.field:focus-within{background:#fff;border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,111,255,.12)}
.field label{display:block;font-size:11px;font-weight:600;color:var(--gray);text-transform:uppercase;
  letter-spacing:.03em}
.field input{width:100%;border:none;background:none;outline:none;font-size:15px;font-weight:600;
  color:var(--ink);padding-top:2px}
.field input::placeholder{color:#9aa4b2;font-weight:500}
.field__code{position:absolute;right:12px;top:11px;font-size:12px;font-weight:700;color:var(--gray);
  background:#fff;padding:2px 6px;border-radius:6px}
.field--date input{cursor:pointer}
.swap{align-self:center;display:grid;place-items:center;width:34px;height:34px;border-radius:10px;
  background:#fff;border:1.5px solid var(--line);color:var(--blue);margin:0 -4px;z-index:2;flex:none}
.swap:hover{border-color:var(--blue)}
.pax-btn{width:100%;text-align:left;font-size:15px;font-weight:600;color:var(--ink);padding-top:2px}
.btn-search{display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;font-weight:700;font-size:15px;
  border-radius:var(--r-sm);padding:0 22px;min-height:58px}
.btn-search:hover{filter:brightness(1.06)}
.btn-search:active{transform:scale(.98)}
.ck{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--gray);margin-top:11px;
  cursor:pointer;font-weight:500}
.ck input{width:17px;height:17px;accent-color:var(--blue)}

/* autocomplete */
.ac{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border-radius:12px;
  box-shadow:var(--shadow-lg);z-index:60;padding:6px;max-height:min(440px,70vh);overflow:auto;
  min-width:300px;width:max-content;max-width:min(360px,90vw)}
.ac__i{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;cursor:pointer}
.ac__i .ac__sub{white-space:nowrap}
.ac__i:hover,.ac__i.is-on{background:var(--bg)}
.ac__pin{width:30px;height:30px;border-radius:8px;background:#eaf1ff;color:var(--blue);display:grid;
  place-items:center;font-weight:700;font-size:14px;flex:none}
.ac__flag{width:30px;height:30px;border-radius:8px;background:var(--bg);display:grid;place-items:center;font-size:18px;flex:none}
.ac__flag-sm{font-size:12px}
.ac__name{font-weight:600;font-size:14px}
.ac__sub{font-size:12px;color:var(--gray)}
.ac__code{margin-left:auto;font-weight:700;color:var(--gray);font-size:13px;flex:none}
.ac__code.ac__all{background:var(--blue);color:#fff;font-size:11px;padding:3px 8px;border-radius:6px}

/* pax popover */
.pax-pop{position:absolute;top:calc(100% + 6px);right:0;width:300px;background:#fff;border-radius:14px;
  box-shadow:var(--shadow-lg);z-index:30;padding:14px}
.pax-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line)}
.pax-row:last-of-type{border:none}
.pax-row b{font-size:14.5px}.pax-row small{display:block;color:var(--gray);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(--blue);display:grid;place-items:center}
.stepper button:disabled{opacity:.35;color:var(--gray)}
.stepper span{min-width:18px;text-align:center;font-weight:700}
.cls-seg{display:flex;gap:6px;margin-top:12px}
.cls-seg button{flex:1;padding:8px;border-radius:9px;background:var(--bg);font-weight:600;font-size:12.5px;color:var(--gray)}
.cls-seg button.is-on{background:var(--navy);color:#fff}
.pax-done{width:100%;margin-top:12px;background:var(--blue);color:#fff;font-weight:700;padding:11px;border-radius:10px}

/* hero tags */
.hero__tags{display:flex;align-items:center;gap:8px;margin-top:18px;flex-wrap:wrap}
.hero__tags>span{color:#c7d4ea;font-size:13px;font-weight:600}
.dest-chip{color:#fff;background:rgba(255,255,255,.13);font-weight:600;font-size:13px;padding:7px 14px;
  border-radius:999px}
.dest-chip:hover{background:rgba(255,255,255,.25)}

/* ===== TRUST ===== */
.trust__in{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:-26px;
  background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:18px;position:relative;z-index:5}
.trust__i{text-align:center}
.trust__i b{display:block;font-size:22px;font-weight:800;color:var(--navy)}
.trust__i span{font-size:13px;color:var(--gray)}

/* ===== RESULTS ===== */
.results{padding:22px 16px 90px}
.res__head{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.back-link{color:var(--blue);font-weight:600;font-size:14px}
.res__route{font-weight:700;font-size:17px}
.res__route small{color:var(--gray);font-weight:500;font-size:14px}
.res__layout{display:grid;grid-template-columns:260px 1fr;gap:22px;align-items:start}

.filters{background:#fff;border-radius:var(--r);padding:18px;box-shadow:var(--shadow);
  position:sticky;top:80px}
.filters__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.filters__head h3{font-size:16px}
.fblock{padding:16px 0;border-bottom:1px solid var(--line)}
.fblock:last-child{border:none;padding-bottom:0}
.fblock h4{font-size:13px;font-weight:700;margin-bottom:10px;text-transform:uppercase;letter-spacing:.03em;color:var(--gray)}
.fblock .ck{margin-top:9px}
.fblock .ck:first-of-type{margin-top:0}
#priceRange{width:100%;accent-color:var(--blue)}
.frow{display:flex;justify-content:space-between;margin-top:8px;font-size:13px;color:var(--gray)}
.frow b{color:var(--ink)}

.sortbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.sort-tabs{display:flex;background:#fff;border-radius:12px;padding:5px;box-shadow:var(--shadow);flex:1;overflow:hidden}
.sort-tabs button{flex:1;padding:10px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--gray);white-space:nowrap}
.sort-tabs button.is-on{background:var(--navy);color:#fff}
.filters-toggle{display:none;background:#fff;box-shadow:var(--shadow);padding:11px 16px;border-radius:12px;font-weight:600;font-size:14px}
.res__count{font-size:13.5px;color:var(--gray);margin-bottom:12px}

/* flight card */
.fcard{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:12px;
  overflow:hidden;transition:.18s;border:1.5px solid transparent}
.fcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.fcard.is-best{border-color:#cfe0ff}
.fcard__tag{display:inline-flex;gap:5px;align-items:center;background:linear-gradient(135deg,var(--blue),#5aa0ff);
  color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-bottom-right-radius:12px}
.fcard__in{display:grid;grid-template-columns:1fr 200px;gap:0}
.fcard__thumb{display:none}
.fcard__thumb{position:relative;overflow:hidden;background:linear-gradient(135deg,#1e3a5f,#2c4a82)}
.fcard__thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s}
.fcard__thumb img.loaded{opacity:1}
.fcard__thumb span{position:absolute;left:0;right:0;bottom:0;padding:5px 8px;font-size:10.5px;font-weight:700;color:#fff;
  background:linear-gradient(transparent,rgba(7,16,33,.8));z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.fcard__legs{padding:16px 18px}
.leg{display:flex;align-items:center;gap:14px;padding:8px 0}
.leg+.leg{border-top:1px dashed var(--line)}
.leg__al{display:flex;flex-direction:column;align-items:center;gap:4px;width:54px;flex:none}
.leg__logo{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;font-weight:800;
  color:#fff;font-size:13px}
.leg__al small{font-size:10px;color:var(--gray);text-align:center;line-height:1.1}
.leg__time{text-align:center;flex:none}
.leg__time b{display:block;font-size:18px;font-weight:700}
.leg__time span{font-size:12px;color:var(--gray);font-weight:600}
.leg__path{flex:1;text-align:center;min-width:0}
.leg__dur{font-size:12px;color:var(--gray);font-weight:600}
.leg__line{position:relative;height:2px;background:var(--line);margin:7px 0;border-radius:2px}
.leg__line::before,.leg__line::after{content:"";position:absolute;top:50%;width:7px;height:7px;
  border-radius:50%;background:var(--blue);transform:translateY(-50%)}
.leg__line::before{left:0}.leg__line::after{right:0;background:var(--navy)}
.leg__stops{font-size:12px;font-weight:600}
.leg__stops.direct{color:var(--green)}
.leg__stops.stop{color:var(--amber)}
.leg__plane{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:0 4px;color:var(--blue)}
.fcard__buy{background:linear-gradient(180deg,#f7f9fd,#eef3fb);padding:16px 18px;display:flex;
  flex-direction:column;justify-content:center;align-items:flex-end;border-left:1px solid var(--line)}
.fcard__price{font-size:24px;font-weight:800;color:var(--navy)}
.fcard__pp{font-size:12px;color:var(--gray);margin-bottom:10px}
.fcard__feat{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;justify-content:flex-end}
.feat{font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;background:#fff;color:var(--gray)}
.feat.ok{color:var(--green);background:#e7f8f0}
.feat.no{color:var(--gray)}
.btn-pick{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;font-weight:700;
  font-size:14px;padding:11px 22px;border-radius:11px;width:100%;text-align:center}
.btn-pick:hover{filter:brightness(1.06)}
.btn-pick:active{transform:scale(.98)}

/* skeleton */
.sk{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:12px;height:118px;
  position:relative;overflow:hidden}
.sk::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);
  animation:shimmer 1.3s infinite}
@keyframes shimmer{100%{transform:translateX(100%)}}
.sk::after{transform:translateX(-100%)}

/* ===== MOBILE NAV ===== */
.mnav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:40;background:#fff;
  border-top:1px solid var(--line);padding:8px 0 calc(6px + var(--safe-b));
  grid-template-columns:repeat(3,1fr)}
.mnav button{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:600;color:var(--gray)}
.mnav button svg{width:22px;height:22px;fill:currentColor}
.mnav button.is-on{color:var(--blue)}

/* ===== SHEET / BOOKING ===== */
.sheet{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.sheet__overlay{position:absolute;inset:0;background:rgba(11,31,58,.55);backdrop-filter:blur(3px);
  animation:fade .2s}
.sheet__panel{position:relative;background:var(--bg);width:min(720px,100%);max-height:92vh;
  border-radius:20px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg);
  animation:pop .25s cubic-bezier(.2,.8,.3,1.1)}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.98)}}
.sheet__bar{display:flex;align-items:center;gap:14px;padding:14px 18px;background:#fff;border-bottom:1px solid var(--line)}
.sheet__close{width:34px;height:34px;border-radius:10px;background:var(--bg);font-size:15px;color:var(--gray);flex:none}
.steps{display:flex;gap:6px;flex:1;overflow-x:auto;scrollbar-width:none}
.steps::-webkit-scrollbar{display:none}
.steps span{white-space:nowrap;font-size:12.5px;font-weight:600;color:#9aa4b2;display:flex;align-items:center;gap:6px}
.steps span::before{content:"";width:7px;height:7px;border-radius:50%;background:#d3d9e2}
.steps span.is-on{color:var(--blue)}.steps span.is-on::before{background:var(--blue)}
.steps span.done{color:var(--green)}.steps span.done::before{background:var(--green)}
.sheet__body{padding:18px;overflow:auto;-webkit-overflow-scrolling:touch}

/* booking inner */
.bk-h{font-size:19px;font-weight:800;margin-bottom:4px}
.bk-sub{color:var(--gray);font-size:13.5px;margin-bottom:16px}
.bk-card{background:#fff;border-radius:14px;padding:16px;box-shadow:var(--shadow);margin-bottom:14px}
.bk-seg{display:flex;align-items:center;gap:12px;padding:10px 0}
.bk-seg+.bk-seg{border-top:1px solid var(--line)}
.bk-seg__logo{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:13px;flex:none}
.bk-seg__main{flex:1}
.bk-seg__top{display:flex;justify-content:space-between;font-weight:700;font-size:15px}
.bk-seg__sub{display:flex;justify-content:space-between;color:var(--gray);font-size:12.5px;margin-top:2px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.inp{display:flex;flex-direction:column;gap:5px}
.inp label{font-size:12.5px;font-weight:600;color:var(--gray)}
.inp input,.inp select{padding:11px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;
  font-weight:500;outline:none;background:#fff;width:100%}
.inp input:focus,.inp select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,111,255,.12)}
.inp.full{grid-column:1/-1}
.inp.err input{border-color:var(--red)}
.inp .emsg{color:var(--red);font-size:11.5px;display:none}
.inp.err .emsg{display:block}

.pax-tabs{display:flex;gap:8px;margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.pax-tab{white-space:nowrap;padding:9px 14px;border-radius:10px;background:#fff;box-shadow:var(--shadow);
  font-weight:600;font-size:13px;color:var(--gray)}
.pax-tab.is-on{background:var(--navy);color:#fff}
.pax-tab.ok::after{content:" ✓";color:var(--green)}

/* extras */
.extra{display:flex;align-items:center;gap:12px;padding:12px 0}
.extra+.extra{border-top:1px solid var(--line)}
.extra__ic{width:40px;height:40px;border-radius:10px;background:#eaf1ff;color:var(--blue);display:grid;place-items:center;flex:none}
.extra__ic svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2}
.extra__m{flex:1}
.extra__m b{font-size:14.5px}.extra__m small{display:block;color:var(--gray);font-size:12px}
.extra__pr{font-weight:700;margin-right:6px}
.tgl{width:46px;height:27px;border-radius:999px;background:#d3d9e2;position:relative;flex:none;transition:.2s}
.tgl::after{content:"";position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.tgl.on{background:var(--green)}.tgl.on::after{transform:translateX(19px)}

/* seatmap */
.seatmap{display:flex;flex-direction:column;align-items:center;gap:6px;margin:8px 0 4px}
.seat-row{display:flex;gap:6px;align-items:center}
.seat-row__n{width:18px;font-size:11px;color:var(--gray);text-align:center}
.seat{width:30px;height:30px;border-radius:7px;background:#e7f8f0;border:1.5px solid #bfe9d4;font-size:10px;
  font-weight:700;color:var(--green);display:grid;place-items:center}
.seat.aisle{width:14px;background:none;border:none;pointer-events:none}
.seat.taken{background:#eef0f4;border-color:#e0e3e9;color:#c2c8d2;cursor:not-allowed}
.seat.extra-leg{background:#fff6e6;border-color:#f5d493;color:#b9831a}
.seat.sel{background:var(--blue);border-color:var(--blue);color:#fff}
.seat-leg{display:flex;gap:16px;justify-content:center;font-size:12px;color:var(--gray);margin-top:6px;flex-wrap:wrap}
.seat-leg i{display:inline-block;width:14px;height:14px;border-radius:4px;vertical-align:-2px;margin-right:4px}

/* payment */
.pay-cards{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.pay-opt{flex:1;min-width:120px;border:1.5px solid var(--line);border-radius:12px;padding:12px;display:flex;
  align-items:center;gap:9px;font-weight:600;font-size:13.5px;background:#fff}
.pay-opt.is-on{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,111,255,.12)}
.pay-opt .dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex:none}
.pay-opt.is-on .dot{border-color:var(--blue);background:radial-gradient(circle,var(--blue) 0 5px,#fff 6px)}
.cc{background:linear-gradient(135deg,#1a2a4a,#2c4a82);border-radius:16px;padding:18px;color:#fff;margin-bottom:14px;
  box-shadow:var(--shadow);position:relative;overflow:hidden}
.cc::after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.07)}
.cc__num{font-size:19px;letter-spacing:2px;font-weight:600;margin:18px 0 14px;font-variant-numeric:tabular-nums}
.cc__row{display:flex;justify-content:space-between;font-size:12px;opacity:.85}
.cc__row b{display:block;font-size:14px;opacity:1;margin-top:2px;text-transform:uppercase}

/* summary bar */
.bk-foot{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);
  margin:0 -18px -18px;padding:14px 18px calc(14px + var(--safe-b));display:flex;align-items:center;gap:14px}
.bk-foot__sum{flex:1}
.bk-foot__sum small{display:block;color:var(--gray);font-size:12px}
.bk-foot__sum b{font-size:21px;font-weight:800;color:var(--navy)}
.btn-next{background:linear-gradient(135deg,var(--blue),var(--blue-d));color:#fff;font-weight:700;font-size:15px;
  padding:14px 26px;border-radius:12px;white-space:nowrap}
.btn-next:hover{filter:brightness(1.06)}.btn-next:active{transform:scale(.98)}
.btn-next:disabled{opacity:.5}

/* price breakdown */
.pbreak{background:#fff;border-radius:14px;padding:16px;box-shadow:var(--shadow);margin-bottom:14px}
.pbreak__r{display:flex;justify-content:space-between;padding:7px 0;font-size:14px}
.pbreak__r.tot{border-top:1px solid var(--line);margin-top:6px;padding-top:12px;font-weight:800;font-size:17px}
.pbreak__r .g{color:var(--green)}

/* success */
.done-wrap{text-align:center;padding:18px 0}
.done-ic{width:84px;height:84px;border-radius:50%;background:#e7f8f0;display:grid;place-items:center;margin:0 auto 18px;
  animation:pop .4s cubic-bezier(.2,.8,.3,1.3)}
.done-ic svg{width:44px;height:44px;stroke:var(--green);stroke-width:3;fill:none}
.done-wrap h2{font-size:24px;font-weight:800}
.pnr{display:inline-block;margin:14px 0;background:var(--navy);color:#fff;font-weight:800;font-size:22px;
  letter-spacing:3px;padding:10px 24px;border-radius:12px}
.boarding{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:18px;text-align:left;margin-top:18px;
  border:2px dashed var(--line)}
.bp-route{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.bp-route .ap{text-align:center}
.bp-route .ap b{font-size:26px;font-weight:800;display:block}
.bp-route .ap small{color:var(--gray);font-size:12px}
.bp-route .arrow{color:var(--blue);flex:1;text-align:center}
.bp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border-top:1px solid var(--line);padding-top:14px}
.bp-grid div small{display:block;color:var(--gray);font-size:11px;text-transform:uppercase}
.bp-grid div b{font-size:15px}

/* toast */
.toast{position:fixed;bottom:calc(20px + var(--safe-b));left:50%;transform:translateX(-50%);z-index:200;
  background:var(--navy);color:#fff;font-weight:600;font-size:14px;padding:12px 22px;border-radius:12px;
  box-shadow:var(--shadow-lg);animation:toastin .3s}
@keyframes toastin{from{opacity:0;transform:translate(-50%,12px)}}

/* ====================== HOMEPAGE SECTIONS ====================== */
.sec{padding:46px 16px 10px}
.sec__head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.sec__title{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.sec__sub{color:var(--gray);font-size:14.5px;margin-top:4px}
.sec__more{color:var(--blue);font-weight:700;font-size:14px}

/* price calendar */
.cal__legend{display:flex;gap:14px;font-size:12.5px;color:var(--gray);align-items:center}
.cal__legend i{display:inline-block;width:12px;height:12px;border-radius:4px;vertical-align:-2px;margin-right:5px}
.cal__legend i.lo{background:#cdeede}.cal__legend i.mid{background:#ffe3a3}.cal__legend i.hi{background:#ffc9c9}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.cal__d{background:#fff;border-radius:12px;padding:12px 8px;text-align:center;box-shadow:var(--shadow);
  cursor:pointer;transition:.15s;border:1.5px solid transparent}
.cal__d:hover{transform:translateY(-2px);border-color:#cfe0ff}
.cal__d small{display:block;font-size:11px;color:var(--gray);font-weight:600}
.cal__d b{display:block;font-size:14px;margin-top:5px;font-weight:700}
.cal__d.lo b{color:#0f9e63}.cal__d.mid b{color:#c98a10}.cal__d.hi b{color:#d0192b}
.cal__d.lo{background:linear-gradient(180deg,#fff,#f0fbf5)}

/* destinations grid */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dcard{position:relative;border-radius:16px;overflow:hidden;height:200px;cursor:pointer;box-shadow:var(--shadow);
  display:flex;align-items:flex-end;color:#fff;transition:.2s}
.dcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.dcard:hover .dcard__img{transform:scale(1.06)}
.dcard__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  opacity:0;transition:opacity .5s ease,transform .5s ease}
.dcard__img.loaded{opacity:1}
.dcard::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 30%,rgba(7,16,33,.82))}
.dcard__in{position:relative;z-index:2;padding:16px;width:100%}
.dcard__city{font-size:19px;font-weight:800}
.dcard__sub{font-size:12.5px;opacity:.85}
.dcard__price{margin-top:8px;font-size:13px}
.dcard__price b{font-size:18px}
.dcard--big{grid-row:span 2;height:auto;min-height:416px}

/* deals */
.deals{background:linear-gradient(160deg,#0b1f3a,#1d3e74);padding:44px 0;margin-top:30px}
.deal-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.deal{background:#fff;border-radius:14px;box-shadow:var(--shadow);position:relative;cursor:pointer;transition:.18s;overflow:hidden}
.deal:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.deal__ph{position:relative;height:96px;background:linear-gradient(135deg,#1e3a5f,#2c4a82);overflow:hidden}
.deal__ph img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s,transform .4s}
.deal__ph img.loaded{opacity:1}
.deal:hover .deal__ph img{transform:scale(1.06)}
.deal__body{padding:14px 16px 16px}
.deal__off{position:absolute;top:10px;right:10px;background:var(--red);color:#fff;font-size:11px;font-weight:700;
  padding:3px 9px;border-radius:7px;box-shadow:0 2px 8px rgba(0,0,0,.25);z-index:2}
.deal__route{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px}
.deal__route .al{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-size:10px;font-weight:800;flex:none}
.deal__date{color:var(--gray);font-size:12.5px;margin:8px 0 10px}
.deal__pr{display:flex;align-items:baseline;gap:8px}
.deal__pr b{font-size:21px;font-weight:800;color:var(--navy)}
.deal__pr s{color:var(--gray);font-size:13px}

/* routes */
.routes{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 28px}
.route{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:#fff;
  border-radius:12px;box-shadow:var(--shadow);cursor:pointer;transition:.15s}
.route:hover{transform:translateX(3px);box-shadow:var(--shadow-lg)}
.route__l{font-weight:600;font-size:14.5px}
.route__l small{display:block;color:var(--gray);font-size:12px;font-weight:500}
.route__r{text-align:right}
.route__r b{font-size:16px;font-weight:800;color:var(--navy)}
.route__r small{display:block;color:var(--green);font-size:11px;font-weight:600}

/* features */
.feats{padding:48px 16px 20px}
.feats__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ft{background:#fff;border-radius:16px;padding:22px;box-shadow:var(--shadow);transition:.18s}
.ft:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.ft__ic{font-size:30px;margin-bottom:10px}
.ft h3{font-size:17px;font-weight:700;margin-bottom:6px}
.ft p{color:var(--gray);font-size:13.5px;line-height:1.5}

/* subscribe */
.sub{padding:30px 16px}
.sub__card{background:linear-gradient(135deg,var(--blue),#5aa0ff);border-radius:20px;padding:30px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff;box-shadow:var(--shadow-lg);flex-wrap:wrap}
.sub__txt h2{font-size:24px;font-weight:800}
.sub__txt p{opacity:.9;margin-top:5px;font-size:14.5px}
.sub__form{display:flex;gap:10px;flex:1;min-width:280px;max-width:460px}
.sub__form input{flex:1;border:none;border-radius:12px;padding:14px 16px;font-size:15px;outline:none}
.sub__form button{background:var(--navy);color:#fff;font-weight:700;font-size:15px;padding:0 24px;border-radius:12px;white-space:nowrap}
.sub__form button:hover{background:#08172d}

/* reviews */
.rev-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rev{background:#fff;border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.rev__stars{color:#f5a623;font-size:14px;letter-spacing:2px}
.rev__txt{font-size:14px;line-height:1.55;margin:10px 0 14px}
.rev__who{display:flex;align-items:center;gap:10px}
.rev__av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px}
.rev__who b{font-size:14px}.rev__who small{display:block;color:var(--gray);font-size:12px}

/* faq */
.faq{display:flex;flex-direction:column;gap:10px}
.faq__i{background:#fff;border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
.faq__q{width:100%;text-align:left;padding:16px 18px;font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq__q span:last-child{color:var(--blue);font-size:20px;transition:.2s;flex:none}
.faq__i.open .faq__q span:last-child{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .25s ease;color:var(--gray);font-size:14px;line-height:1.55}
.faq__a div{padding:0 18px 16px}
.faq__i.open .faq__a{max-height:200px}

/* footer */
.foot{background:var(--navy);color:#c7d4ea;padding:44px 16px 24px;margin-top:30px}
.foot__in{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot__brand p{font-size:13.5px;line-height:1.55;margin:12px 0 14px;max-width:300px}
.foot .logo__txt{color:#fff}
.foot__pay{display:flex;gap:8px}
.foot__pay span{background:rgba(255,255,255,.12);color:#fff;font-size:11px;font-weight:700;padding:5px 9px;border-radius:6px}
.foot__col h4{color:#fff;font-size:14px;margin-bottom:12px}
.foot__col a{display:block;font-size:13.5px;padding:5px 0;color:#c7d4ea}
.foot__col a:hover{color:#fff}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;font-size:13px;flex-wrap:wrap;gap:12px}
.foot__soc{display:flex;gap:10px}
.foot__soc a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;color:#fff}
.foot__soc a:hover{background:var(--blue)}

/* ===== currency menu ===== */
.cur-menu{position:fixed;z-index:120;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);
  padding:6px;min-width:170px;animation:pop .18s}
.cur-menu button{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:9px 12px;border-radius:9px;text-align:left}
.cur-menu button:hover{background:var(--bg)}
.cur-menu button.is-on{background:var(--bg)}
.cur-menu button b{font-size:14px}.cur-menu button span{font-size:12px;color:var(--gray)}

/* ===== login ===== */
.login{max-width:380px;margin:0 auto;padding:8px 0}
.login__logo{display:grid;place-items:center;margin-bottom:8px}
.login__logo .logo__mark{width:50px;height:50px;border-radius:14px}
.login__or{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--gray);font-size:12.5px}
.login__or::before,.login__or::after{content:"";flex:1;height:1px;background:var(--line)}
.login__soc{display:flex;gap:10px}
.login__soc button{flex:1;height:46px;border:1.5px solid var(--line);border-radius:11px;font-weight:700;font-size:15px;background:#fff}
.login__soc button:hover{border-color:var(--blue)}

/* ===== back to top ===== */
.to-top{position:fixed;right:20px;bottom:calc(24px + var(--safe-b));z-index:60;width:46px;height:46px;border-radius:50%;
  background:#fff;box-shadow:var(--shadow-lg);color:var(--blue);font-size:20px;font-weight:700;transition:.2s}
.to-top:hover{background:var(--blue);color:#fff;transform:translateY(-2px)}

/* ===== scroll reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}

/* ===== multi-city editor ===== */
.multi{margin-top:10px}
.multi__rows{display:flex;flex-direction:column;gap:8px}
.mseg{display:grid;grid-template-columns:26px 1fr 16px 1fr 150px 32px;gap:8px;align-items:center}
.mseg__n{width:26px;height:26px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:700;font-size:12px}
.mseg__arrow{text-align:center;color:var(--gray)}
.mseg input{background:var(--bg);border:1.5px solid transparent;border-radius:10px;padding:11px 12px;font-size:14px;font-weight:600;outline:none;min-width:0}
.mseg input:focus{background:#fff;border-color:var(--blue)}
.mseg__rm{width:32px;height:32px;border-radius:9px;background:var(--bg);color:var(--gray);font-size:13px}
.mseg__rm:hover{background:#ffe3e3;color:var(--red)}
.multi__add{margin-top:10px;color:var(--blue);font-weight:700;font-size:14px;padding:8px 0}
html[data-theme=dark] .mseg input,html[data-theme=dark] .mseg__rm{background:#0d1b2e}

/* ===== multi-city results ===== */
.is-multi .filters,.is-multi .sortbar{display:none!important}
.is-multi .res__layout{grid-template-columns:1fr}
.mblock{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}
.mblock__h{display:flex;align-items:baseline;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.mblock__h b{font-size:15px}.mblock__h span{color:var(--gray);font-size:13px}
.mblock__list{display:flex;flex-direction:column}
.moption{display:grid;grid-template-columns:42px 1fr auto auto;gap:12px;align-items:center;padding:12px 18px;text-align:left;border-bottom:1px solid var(--line);transition:.12s}
.moption:last-child{border:none}
.moption:hover{background:var(--bg)}
.moption.is-on{background:#eef4ff;box-shadow:inset 3px 0 0 var(--blue)}
.moption__al{width:34px;height:34px;border-radius:8px;color:#fff;font-weight:800;font-size:11px;display:grid;place-items:center}
.moption__t b{font-size:15px}.moption__t small{display:block;color:var(--gray);font-size:12px}
.moption__d{text-align:right;font-size:12.5px;color:var(--gray);font-weight:600}
.moption__d small{display:block}.moption__d small.direct{color:var(--green)}.moption__d small.stop{color:var(--amber)}
.moption__p{font-size:17px;font-weight:800;color:var(--navy);text-align:right;min-width:64px}
.mfoot{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:#fff;border-radius:var(--r);box-shadow:var(--shadow-lg);padding:14px 18px;margin-top:4px}
.mfoot small{display:block;color:var(--gray);font-size:12px}
.mfoot b{font-size:22px;font-weight:800;color:var(--navy)}
html[data-theme=dark] .mblock,html[data-theme=dark] .mfoot{background:var(--card)}
html[data-theme=dark] .moption.is-on{background:#13243b}
html[data-theme=dark] .moption__p,html[data-theme=dark] .mfoot b{color:#fff}
@media(max-width:680px){
  .mseg{grid-template-columns:22px 1fr 1fr 28px;grid-auto-rows:auto;gap:6px}
  .mseg__arrow{display:none}
  .mseg__d{grid-column:2/4}
  .moption{grid-template-columns:36px 1fr auto;gap:8px}
  .moption__d{display:none}
}

/* ===== language menu ===== */
.lang-menu{position:fixed;z-index:120;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;min-width:150px;animation:pop .18s}
.lang-menu button{display:flex;align-items:center;gap:9px;width:100%;padding:9px 12px;border-radius:9px;text-align:left;font-weight:600;font-size:14px}
.lang-menu button:hover,.lang-menu button.is-on{background:var(--bg)}
.lang-menu button span{font-size:18px}
html[data-theme=dark] .lang-menu{background:var(--card)}

/* ===== cookie consent ===== */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:130;max-width:560px;margin:0 auto;
  background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:18px 20px;display:flex;gap:18px;
  align-items:center;animation:cookieIn .4s cubic-bezier(.2,.8,.3,1.05);border:1px solid var(--line)}
@keyframes cookieIn{from{opacity:0;transform:translateY(20px)}}
.cookie__txt{flex:1}
.cookie__txt b{display:block;font-size:14.5px;margin-bottom:3px}
.cookie__txt span{font-size:12.5px;color:var(--gray);line-height:1.45}
.cookie__btns{display:flex;gap:8px;flex:none}
.cookie__b{padding:10px 16px;border-radius:10px;font-weight:600;font-size:13px;white-space:nowrap}
.cookie__b.ghost{background:var(--bg);color:var(--ink)}
.cookie__b.solid{background:var(--blue);color:#fff}
.cookie__b.solid:hover{filter:brightness(1.06)}
html[data-theme=dark] .cookie{background:var(--card)}
@media(max-width:560px){.cookie{flex-direction:column;align-items:stretch}.cookie__btns{flex-direction:row}.cookie__b{flex:1}}

/* ===== My Trips ===== */
.trip-card{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);margin-bottom:14px;overflow:hidden}
.trip-card__top{display:flex;align-items:center;gap:14px;padding:16px 18px;border-bottom:1px solid var(--line)}
.trip-card__logo{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;flex:none}
.trip-card__route{flex:1}
.trip-card__route b{font-size:18px;font-weight:800}
.trip-card__route small{display:block;color:var(--gray);font-size:12.5px}
.trip-card__pnr{background:var(--navy);color:#fff;font-weight:800;letter-spacing:2px;padding:7px 14px;border-radius:10px;font-size:14px}
.trip-card__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:16px 18px}
.trip-card__grid div small{display:block;color:var(--gray);font-size:11px;text-transform:uppercase}
.trip-card__grid div b{font-size:14.5px}
.trip-card__foot{display:flex;gap:10px;padding:0 18px 16px}
.trip-card__foot button{padding:9px 16px;border-radius:10px;font-weight:600;font-size:13px;background:var(--bg);color:var(--navy)}
.trips-empty{background:#fff;border-radius:var(--r);box-shadow:var(--shadow);padding:48px 20px;text-align:center;color:var(--gray)}
.trips-empty .ic{font-size:46px;margin-bottom:12px}
.trips-empty b{display:block;color:var(--ink);font-size:18px;margin-bottom:6px}
html[data-theme=dark] .trip-card,html[data-theme=dark] .trips-empty{background:var(--card)}
@media(max-width:560px){.trip-card__grid{grid-template-columns:repeat(2,1fr)}}

/* ===== fare options (booking step 0) ===== */
.fares{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:6px}
.fare{border:1.5px solid var(--line);border-radius:14px;padding:14px;cursor:pointer;transition:.15s;background:#fff;position:relative}
.fare:hover{border-color:#cfe0ff}
.fare.is-on{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,111,255,.12)}
.fare__name{font-weight:700;font-size:14px}
.fare__price{font-size:18px;font-weight:800;color:var(--navy);margin:6px 0 10px}
.fare__price small{font-size:12px;color:var(--gray);font-weight:600}
.fare__li{display:flex;gap:7px;font-size:12px;color:var(--gray);padding:3px 0}
.fare__li.ok{color:var(--ink)}
.fare__li i{font-style:normal;width:14px;flex:none}
.fare__li.ok i{color:var(--green)}
.fare__badge{position:absolute;top:-8px;left:14px;background:var(--blue);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px}
html[data-theme=dark] .fare{background:var(--card)}
@media(max-width:560px){.fares{grid-template-columns:1fr}}

/* ===== flight details expand ===== */
.fcard__more{width:100%;text-align:center;padding:9px;font-size:12.5px;font-weight:600;color:var(--blue);
  border-top:1px dashed var(--line);background:none}
.fcard__details{max-height:0;overflow:hidden;transition:max-height .3s ease}
.fcard.open .fcard__details{max-height:340px}
.fdet{padding:14px 18px;background:var(--bg);font-size:13px}
.fdet__row{display:flex;justify-content:space-between;padding:5px 0;color:var(--gray)}
.fdet__row b{color:var(--ink);font-weight:600}
.fdet__seg{display:flex;gap:12px;align-items:center;padding:8px 0;border-bottom:1px solid var(--line)}
.fdet__seg:last-child{border:none}
.fdet__dot{width:9px;height:9px;border-radius:50%;background:var(--blue);flex:none}
html[data-theme=dark] .fdet{background:#0d1b2e}

/* ===== date picker / price calendar popover ===== */
.field--date{position:relative}
.dp{position:absolute;top:calc(100% + 6px);left:0;z-index:40;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);
  padding:14px;width:300px;animation:pop .18s}
.dp__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dp__head b{font-size:14px}
.dp__nav{width:30px;height:30px;border-radius:8px;background:var(--bg);font-size:15px;color:var(--blue);display:grid;place-items:center}
.dp__nav:disabled{opacity:.3}
.dp__wd{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.dp__wd span{text-align:center;font-size:10.5px;color:var(--gray);font-weight:600}
.dp__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.dp__d{aspect-ratio:1;border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-size:13px;font-weight:600;cursor:pointer;background:none;line-height:1.1}
.dp__d:hover:not(:disabled){background:var(--bg)}
.dp__d:disabled{color:#c2c8d2;cursor:default}
.dp__d.sel{background:var(--blue);color:#fff!important}
.dp__d small{font-size:8.5px;font-weight:700;margin-top:1px}
.dp__d.lo small{color:var(--green)}.dp__d.mid small{color:#c98a10}.dp__d.hi small{color:var(--red)}
.dp__d.sel small{color:#fff}
.dp__flex{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:12.5px;color:var(--gray);font-weight:500;cursor:pointer}
html[data-theme=dark] .dp{background:var(--card)}
html[data-theme=dark] .dp__d.lo{background:rgba(15,174,107,.12)}

/* nearby dates strip */
.nearby{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:14px}
.nearby__d{background:#fff;border-radius:11px;box-shadow:var(--shadow);padding:9px 4px;text-align:center;
  border:1.5px solid transparent;transition:.15s}
.nearby__d:hover{border-color:#cfe0ff}
.nearby__d.is-on{border-color:var(--blue);background:#eef4ff}
.nearby__d small{display:block;font-size:10.5px;color:var(--gray);font-weight:600}
.nearby__d b{font-size:13px;font-weight:800;color:var(--navy)}
html[data-theme=dark] .nearby__d{background:var(--card)}
html[data-theme=dark] .nearby__d.is-on{background:#13243b}
html[data-theme=dark] .nearby__d b{color:#fff}
@media(max-width:680px){.nearby{grid-template-columns:repeat(4,1fr)}.nearby__d:nth-child(n+5){display:none}}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  .res__layout{grid-template-columns:1fr}
  .filters{position:fixed;inset:0;z-index:90;border-radius:0;overflow:auto;display:none;top:0}
  .filters.open{display:block}
  .filters__head{position:sticky;top:0;background:#fff;padding-bottom:14px;margin:-18px -18px 0;padding:18px}
  .filters-toggle{display:block}
  .dest-grid{grid-template-columns:repeat(2,1fr)}
  .dcard--big{grid-row:auto;height:200px;min-height:0}
  .deal-row{grid-template-columns:repeat(2,1fr)}
  .routes{grid-template-columns:repeat(2,1fr)}
  .feats__grid,.rev-row{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .hdr__nav{display:none}
  .hero{padding:18px 0 54px}
  .hero__title{font-size:26px}
  .search__grid{grid-template-columns:1fr 1fr;gap:8px}
  .field--from{grid-column:1/2;grid-row:1}
  .field--to{grid-column:2/3;grid-row:1}
  .field--to .ac{left:auto;right:0}
  .ac{max-width:min(340px,94vw)}
  .swap{position:absolute;left:calc(50% - 17px);top:18px;grid-column:auto;z-index:5}
  .field--date{grid-column:span 1}
  .field--pax{grid-column:1/-1}
  .btn-search{grid-column:1/-1;min-height:54px}
  .trust__in{grid-template-columns:repeat(2,1fr);gap:18px 10px}
  .mnav{display:grid}
  body{padding-bottom:64px}
  .to-top{bottom:calc(78px + var(--safe-b))}
  .hdr__right{gap:6px}
  #themeBtn{padding:7px 9px}
  .fcard__in{grid-template-columns:1fr}
  .fcard__buy{border-left:none;border-top:1px solid var(--line);flex-direction:row;align-items:center;justify-content:space-between}
  .fcard__buy .btn-pick{width:auto;padding:11px 28px}
  .fcard__feat{justify-content:flex-start}
  .fcard__price-wrap{text-align:left}
  .form-grid{grid-template-columns:1fr}
  .sheet{align-items:flex-end}
  .sheet__panel{max-height:96vh;border-radius:20px 20px 0 0;width:100%;animation:slideup .3s cubic-bezier(.2,.8,.3,1)}
  @keyframes slideup{from{transform:translateY(100%)}}
  .bp-grid{grid-template-columns:repeat(2,1fr)}
  .res__route{font-size:15px}
  .sec{padding:34px 16px 6px}
  .sec__title{font-size:22px}
  .cal{grid-template-columns:repeat(4,1fr)}
  .deal-row{grid-template-columns:1fr 1fr}
  .routes{grid-template-columns:1fr}
  .feats__grid,.rev-row{grid-template-columns:1fr}
  .sub__card{flex-direction:column;align-items:stretch;text-align:center}
  .sub__form{max-width:none}
  .foot__in{grid-template-columns:1fr 1fr;gap:22px}
  .foot__brand{grid-column:1/-1}
}
@media(max-width:400px){
  .trust__i b{font-size:18px}
  .fcard__buy{flex-direction:column;align-items:stretch}
  .fcard__buy .btn-pick{width:100%}
}
