/* FareDeal Expert — styles. Mobile-first, conversion-focused, premium brand.
   Compact, tight scale (v3): smaller type, denser spacing, well-aligned. */
:root{
  --navy:#0b2545; --navy-2:#0e2e57; --blue:#1d6fb8; --blue-dark:#16538a;
  --accent:#ff7a00; --accent-dark:#e66f00; --green:#1aa260;
  --ink:#1f2c38; --muted:#5b6b7a; --line:#e6ecf3; --bg:#f7fafc; --white:#fff;
  --radius:10px; --radius-lg:14px; --maxw:1140px;
  --shadow-sm:0 1px 2px rgba(11,37,69,.05), 0 1px 4px rgba(11,37,69,.05);
  --shadow:0 4px 16px rgba(11,37,69,.08);
  --shadow-md:0 8px 24px rgba(11,37,69,.10);
  --shadow-lg:0 16px 40px rgba(11,37,69,.14);
  --shadow-accent:0 4px 14px rgba(255,122,0,.30);
  --grad-brand:linear-gradient(135deg,var(--blue),var(--blue-dark));
  --grad-accent:linear-gradient(135deg,#ff9233,var(--accent) 55%,var(--accent-dark));
  --grad-hero:linear-gradient(155deg,#0b2545 0%,#123a6b 55%,#16538a 100%);
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:15px}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.55;font-size:1rem;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
h1,h2,h3{line-height:1.22;color:var(--navy);margin:.2em 0 .45em;letter-spacing:-.012em;font-weight:800}
h1{font-size:clamp(1.5rem,2.9vw,2.05rem)}
h2{font-size:clamp(1.18rem,2vw,1.5rem);margin-top:1.5em}
h3{font-size:1.02rem}
p{margin:.3em 0 .9em}
a{color:var(--blue-dark);text-decoration:none;transition:color .15s}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
strong{font-weight:700}
:focus-visible{outline:3px solid rgba(29,111,184,.5);outline-offset:2px;border-radius:6px}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}
.lead{font-size:1.02rem;color:var(--muted);max-width:64ch;line-height:1.6}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:999}

/* Buttons & call CTA */
.btn{display:inline-block;background:var(--grad-brand);color:#fff;border:0;padding:11px 20px;border-radius:10px;font-weight:700;font-size:.95rem;cursor:pointer;line-height:1.2;
  box-shadow:0 3px 10px rgba(29,111,184,.26);transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,filter .18s}
.btn:hover{filter:brightness(1.05);text-decoration:none;color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px rgba(29,111,184,.36)}
.btn:active{transform:translateY(0)}
.btn--block{display:block;width:100%;text-align:center;margin-top:10px}
.cta-call{position:relative;display:inline-flex;align-items:center;gap:9px;background:var(--grad-accent);color:#fff;padding:8px 15px;border-radius:11px;font-weight:700;line-height:1.1;
  box-shadow:var(--shadow-accent);transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,filter .18s}
.cta-call:hover{filter:brightness(1.04);color:#fff;text-decoration:none;transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,122,0,.4)}
.cta-call:active{transform:translateY(0)}
.cta-call__icon{font-size:1.15rem;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.18))}
.cta-call__text{display:flex;flex-direction:column;line-height:1.1}
.cta-call__text small{font-size:.62rem;font-weight:600;opacity:.95;text-transform:uppercase;letter-spacing:.04em}
.cta-call__text strong{font-size:.98rem;letter-spacing:.01em}
.cta-call--lg{padding:11px 20px;border-radius:12px}
.cta-call--lg .cta-call__text strong{font-size:1.12rem}

/* Topbar + header */
.topbar{background:var(--navy);color:#cfe0f0;font-size:.76rem;background-image:linear-gradient(90deg,var(--navy),var(--navy-2))}
.topbar__inner{display:flex;gap:20px;justify-content:center;padding:5px 0;flex-wrap:wrap}
.topbar__item{white-space:nowrap;opacity:.95}

/* Glassmorphic sticky header */
.site-header{position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.85);
  -webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(11,37,69,.04);
  transition:background .25s ease,box-shadow .25s ease,border-color .25s ease}
.site-header__inner{display:flex;align-items:center;gap:16px;padding:9px 20px;transition:padding .25s ease}
.site-header.is-scrolled{background:rgba(255,255,255,.94);box-shadow:var(--shadow-md);border-bottom-color:transparent}
.site-header.is-scrolled .site-header__inner{padding:6px 20px}
.brand{display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:1.12rem;color:var(--navy);letter-spacing:-.01em}
.brand:hover{text-decoration:none}
.brand__mark{color:var(--accent);font-size:1.25rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(255,122,0,.3))}
.brand__logo{display:block;height:50px;width:auto;max-width:62vw;object-fit:contain}
.site-header.is-scrolled .brand__logo{height:42px;transition:height .25s ease}
.mainnav{display:flex;gap:20px;margin-left:auto;font-weight:600;font-size:.92rem}
.mainnav a{position:relative;color:var(--ink);padding:4px 0}
.mainnav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;border-radius:2px;background:var(--grad-accent);transition:right .22s ease}
.mainnav a:hover{text-decoration:none;color:var(--navy)}
.mainnav a:hover::after{right:0}
.cta-call--header{margin-left:14px}

/* Hamburger toggle (mobile nav) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;flex:0 0 auto;
  width:42px;height:40px;margin-left:8px;padding:0 9px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--navy);border-radius:2px;transition:transform .22s ease,opacity .22s ease}
.site-header.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.site-header.nav-open .nav-toggle span:nth-child(2){opacity:0}
.site-header.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:840px){
  .nav-toggle{display:flex}
  .cta-call--header{margin-left:auto}
  .mainnav{position:absolute;top:100%;left:0;right:0;z-index:99;margin:0;display:none;flex-direction:column;gap:0;
    background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);
    padding:4px 18px 12px;font-size:1.02rem}
  .site-header.nav-open .mainnav{display:flex}
  .mainnav a{padding:13px 2px;border-bottom:1px solid var(--line);color:var(--ink)}
  .mainnav a:last-child{border-bottom:0}
  .mainnav a::after{display:none}
}

/* Hero — cinematic photo backdrop behind a navy wash + globe */
.hero{position:relative;overflow:hidden;isolation:isolate;color:#fff;padding:58px 0 66px;text-align:center;
  background:#0a2240 url('../img/hero-bg.jpg') center 30%/cover no-repeat}
.hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(180deg,rgba(8,28,56,.84) 0%,rgba(9,32,62,.74) 42%,rgba(7,24,50,.93) 100%),
    radial-gradient(70% 85% at 18% 8%,rgba(29,111,184,.45),transparent 60%),
    radial-gradient(55% 70% at 86% 94%,rgba(255,122,0,.26),transparent 60%)}
.hero-webgl{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:screen}
.hero-webgl canvas{width:100%;height:100%;display:block}
.hero__inner{position:relative;z-index:1}
.hero__inner::before{content:"";position:absolute;inset:-40px -50vw;z-index:-1;pointer-events:none;
  background:radial-gradient(60% 70% at 50% 42%,rgba(11,37,69,.55),rgba(11,37,69,.12) 70%,transparent)}
.hero__title{color:#fff;font-size:clamp(2rem,4vw,2.9rem);line-height:1.1;letter-spacing:-.022em;text-shadow:0 2px 22px rgba(0,0,0,.4)}
.hero__title span{color:var(--accent);background:linear-gradient(180deg,#ffb469,var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__sub{color:#e6eefb;max-width:56ch;margin:14px auto 24px;font-size:1.08rem;line-height:1.6;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.searchbar{display:flex;gap:8px;max-width:620px;margin:0 auto;background:rgba(255,255,255,.98);padding:8px;border-radius:14px;box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,255,255,.35);flex-wrap:wrap}
.searchbar input{flex:1 1 150px;border:1px solid var(--line);border-radius:9px;padding:11px 13px;font-size:.95rem;min-width:0;background:#fff;transition:border-color .15s,box-shadow .15s}
.searchbar input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,111,184,.18)}
.searchbar .btn{flex:0 0 auto}
.searchbar--page{margin:16px 0;background:#fff;box-shadow:var(--shadow)}
.hero__cta{display:flex;align-items:center;justify-content:center;gap:13px;margin-top:22px;flex-wrap:wrap;color:#dceaf8;font-size:.95rem}
.hero__trust{margin-top:16px;color:#ffd9b0;font-weight:700;letter-spacing:.02em;font-size:.92rem;text-shadow:0 1px 6px rgba(0,0,0,.2)}

/* Stats band */
.statsband{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.statsband__inner{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:22px 0}
.stat{text-align:center;padding:4px 10px;position:relative}
.stat+.stat::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--line)}
.stat__num{display:block;font-size:clamp(1.45rem,2.8vw,2rem);font-weight:800;line-height:1.05;letter-spacing:-.02em;
  background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--blue-dark)}
.stat__label{display:block;margin-top:3px;font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* Features */
.features{padding:32px 0}
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.feature{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px 18px;text-align:center;
  box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s,border-color .2s}
.feature::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--grad-accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.feature:hover::before{transform:scaleX(1)}
.feature__icon{display:inline-grid;place-items:center;width:44px;height:44px;margin-bottom:4px;font-size:1.4rem;border-radius:12px;
  background:linear-gradient(135deg,#eef5fc,#e3eefa);box-shadow:inset 0 0 0 1px rgba(29,111,184,.1)}
.feature h3{margin:.45em 0 .2em;font-size:1rem}
.feature p{margin:0;color:var(--muted);font-size:.88rem}

/* Content sections */
.content-section{padding-block:30px}   /* vertical only — keep .container's side gutters */
a[href^="tel:"]{white-space:nowrap}    /* never break a phone number mid-digits */
.content-section--center{text-align:center}
.content-section--prose{max-width:760px}
.content-section--prose h2{margin-top:1.3em}
.content-section--prose ul{padding-left:1.2em}
.content-section--prose li{margin:.25em 0}
.breadcrumbs{padding-top:16px;color:var(--muted);font-size:.86rem}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--blue-dark)}

/* Route hero */
.route-hero{position:relative;overflow:hidden;isolation:isolate;background:#fff;border-bottom:1px solid var(--line);padding:22px 0 30px}
.route-hero::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(55% 90% at 90% 0%,rgba(29,111,184,.07),transparent 60%)}
.route-hero .hero-webgl{opacity:.5}
.route-hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1.6fr 1fr;gap:26px;align-items:start}
.route-hero__lead{font-size:1.02rem;color:var(--muted)}
.route-hero__actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:16px}
.route-hero__perks{list-style:none;margin:24px 0 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:13px 20px;max-width:580px}
.route-hero__perks li{position:relative;padding-left:30px;color:var(--navy);font-weight:600;font-size:.92rem;line-height:1.35}
.route-hero__perks li::before{content:"\2713";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;
  background:var(--grad-accent);color:#fff;font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 6px rgba(255,122,0,.3)}
@media(max-width:560px){.route-hero__perks{grid-template-columns:1fr;gap:11px}}
.trust-inline{color:var(--green);font-weight:700;font-size:.86rem}
/* boarding-pass style fare card */
.fare-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg)}
.fare-card__head{display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--grad-hero);color:#fff;padding:13px 18px;border-radius:18px 18px 0 0}
.fare-card__tag{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;opacity:.92}
.fare-card__badge{background:rgba(255,255,255,.18);border-radius:20px;padding:4px 11px;font-size:.7rem;font-weight:700;white-space:nowrap}

.fare-card__route{display:flex;align-items:flex-start;gap:12px;padding:20px 18px 8px}
.fare-card__ap{flex:none;text-align:center;min-width:64px}
.fare-card__ap b{display:block;font-size:1.55rem;font-weight:800;color:var(--navy);letter-spacing:.03em;line-height:1}
.fare-card__ap small{display:block;font-size:.7rem;color:var(--muted);margin-top:5px;line-height:1.2}
.fare-card__mid{flex:1;position:relative;height:22px;margin-top:6px}
.fare-card__mid::before{content:"";position:absolute;left:0;right:0;top:50%;border-top:2px dotted #b9cce0}
.fare-card__mid::after{content:"\2708";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  background:#fff;padding:0 8px;color:var(--blue);font-size:1rem}

.fare-card__rows{padding:6px 18px 0}
.fare-card__row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:.9rem}
.fare-card__row:last-child{border-bottom:0}
.fare-card__row span{color:var(--muted)}
.fare-card__row strong{color:var(--navy)}

/* ticket perforation */
.fare-card__perf{position:relative;height:0;margin:6px 0;border-top:2px dashed #d3e0ee}
.fare-card__perf::before,.fare-card__perf::after{content:"";position:absolute;top:0;width:20px;height:20px;
  background:#fff;border:1px solid var(--line);border-radius:50%;transform:translateY(-50%)}
.fare-card__perf::before{left:-11px}
.fare-card__perf::after{right:-11px}

.fare-card__price{display:flex;align-items:baseline;justify-content:space-between;padding:8px 18px 0}
.fare-card__price span{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.fare-card__price strong{color:var(--accent);font-size:2rem;font-weight:800;line-height:1}
.fare-card__fresh{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin:4px 18px 0;font-size:.72rem;font-weight:600;color:var(--green,#0f9d58)}
.fare-card__fresh span{width:7px;height:7px;border-radius:50%;background:#0f9d58;box-shadow:0 0 0 3px rgba(15,157,88,.15)}
.fare-card__cta{margin:14px 18px 0;width:calc(100% - 36px)}
.fare-card__note{font-size:.72rem;color:var(--muted);text-align:center;margin:9px 0 16px}

/* Route cards / link grids */
.route-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(244px,1fr));gap:16px}
.route-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 18px 15px;
  box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .22s,border-color .22s}
/* accent bar slides in on hover */
.route-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:var(--grad-accent);
  transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.2,.7,.3,1)}
.route-card:hover{border-color:transparent;box-shadow:var(--shadow-md);text-decoration:none;transform:translateY(-4px)}
.route-card:hover::before{transform:scaleX(1)}

/* flight path: IATA · · ·✈· · · IATA */
.route-card__path{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.route-card__iata{font-weight:800;font-size:1.06rem;color:var(--navy);letter-spacing:.04em}
.route-card__conn{flex:1;position:relative;height:14px}
.route-card__conn::before{content:"";position:absolute;left:0;right:0;top:50%;border-top:2px dotted #b9cce0}
.route-card__conn::after{content:"\2708";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  background:#fff;padding:0 7px;color:var(--blue);font-size:.85rem;transition:left .35s cubic-bezier(.4,0,.2,1)}
.route-card:hover .route-card__conn::after{left:72%}

.route-card__cities{font-weight:700;color:var(--navy);font-size:1rem;line-height:1.3}
.route-card__arrow{color:var(--accent);font-weight:800;margin:0 1px}
.route-card__meta{font-size:.78rem;color:var(--muted);margin-top:4px}

.route-card__foot{display:flex;align-items:flex-end;justify-content:space-between;margin-top:14px;padding-top:13px;border-top:1px solid var(--line)}
.route-card__price{display:flex;flex-direction:column;line-height:1;font-weight:800;color:var(--accent);font-size:1.32rem}
.route-card__price small{font-weight:600;color:var(--muted);font-size:.66rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:4px}
.route-card__go{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;color:var(--blue);padding-bottom:2px}
.route-card__go::after{content:"\2192";transition:transform .2s}
.route-card:hover .route-card__go::after{transform:translateX(4px)}
.link-grid{list-style:none;padding:0;margin:14px 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.link-grid a{display:block;padding:9px 13px;background:#fff;border:1px solid var(--line);border-radius:9px;box-shadow:var(--shadow-sm);font-weight:500;font-size:.92rem;transition:transform .15s,border-color .15s,box-shadow .15s,color .15s}
.link-grid a:hover{border-color:var(--blue);text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow);color:var(--blue-dark)}
.country-head{font-size:1.1rem;margin-top:1.4em;border-bottom:2px solid var(--line);padding-bottom:7px}

/* Pills + FAQ + steps */
.pill-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:10px 0}
.pill{background:linear-gradient(135deg,#eef4fb,#e6eefa);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:.85rem;font-weight:600;color:var(--navy);transition:transform .15s,box-shadow .15s}
.pill:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.faq{margin-top:12px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:11px;padding:1px 16px;margin-bottom:9px;box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s}
.faq__item[open]{border-color:rgba(29,111,184,.45);box-shadow:var(--shadow)}
.faq__item summary{position:relative;cursor:pointer;font-weight:700;font-size:.96rem;padding:12px 28px 12px 0;color:var(--navy);list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";position:absolute;right:2px;top:50%;transform:translateY(-50%);font-size:1.3rem;font-weight:700;color:var(--blue);transition:transform .2s}
.faq__item[open] summary::after{content:"–";transform:translateY(-50%) rotate(180deg)}
.faq__item p{margin:0 0 14px;color:var(--muted);font-size:.94rem}
.howto{background:linear-gradient(180deg,#fff,#f9fbfe);border-top:1px solid var(--line);padding:30px 0}
.steps{counter-reset:step;list-style:none;padding:0;margin:0;display:grid;gap:13px;max-width:740px}
.steps li{position:relative;padding:3px 0 3px 48px;line-height:1.5}
.steps li::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:0;width:32px;height:32px;
  background:var(--grad-brand);color:#fff;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.95rem;
  box-shadow:0 3px 10px rgba(29,111,184,.32)}
.steps--lg li{font-size:1rem;padding-top:4px}

/* Call band */
.callband{position:relative;overflow:hidden;background:var(--grad-accent);color:#fff;padding:28px 0}
.callband::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 120% at 10% 0%,rgba(255,255,255,.22),transparent 55%)}
.callband__inner{position:relative;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.callband__title{color:#fff;margin:0;text-shadow:0 1px 8px rgba(0,0,0,.14)}
.callband__sub{margin:.25em 0 0;color:#fff;opacity:.96;font-size:.95rem}
.callband .cta-call{background:#fff;color:var(--accent-dark);box-shadow:0 6px 18px rgba(0,0,0,.18)}
.callband .cta-call:hover{background:#fff8f1;filter:none}

/* Search + contact */
.search-cta{background:linear-gradient(135deg,#fff,#f5f9fd);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;margin:18px 0;display:flex;gap:16px;align-items:center;flex-wrap:wrap;box-shadow:var(--shadow-sm)}
.search-cta p{margin:0}
.contact-phone a{display:inline-block;font-size:1.6rem;font-weight:800;color:var(--accent)}

/* Footer */
.site-footer{background:var(--navy);color:#b9cbe0;padding:34px 0 16px;margin-top:36px;background-image:linear-gradient(180deg,#0c2950,var(--navy));font-size:.92rem}
.site-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:26px}
.site-footer h3{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.7em}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.4em 0}
.site-footer a{color:#b9cbe0;transition:color .15s}
.site-footer a:hover{color:#fff;text-decoration:none}
.brand--footer{display:inline-block;background:#fff;padding:8px 13px;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.18)}
.brand--footer .brand__logo{height:44px}
.brand--footer .brand__name{color:#fff}
.site-footer__bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:24px;padding-top:14px}
.site-footer__bottom .muted{color:#8aa3bd;font-size:.82rem}

/* Sticky mobile call bar */
/* Sticky sitewide call bar */
body{padding-bottom:64px}                /* room for the fixed call bar */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:200;color:#fff;
  background:linear-gradient(180deg,#0e2f5a,#0a223f);
  box-shadow:0 -6px 24px rgba(7,20,42,.32);border-top:1px solid rgba(255,255,255,.08)}
.callbar__inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:9px 0}
.callbar__msg{font-weight:700;font-size:.95rem;color:#e9f1fb;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.callbar__cta{flex:0 0 auto;padding:8px 18px}

/* Responsive */
@media(max-width:900px){
  .features__grid{grid-template-columns:repeat(2,1fr)}
  .statsband__inner{grid-template-columns:repeat(2,1fr);gap:20px}
  .stat:nth-child(odd)::before{display:none}
  .route-hero__inner{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .brand__logo{height:40px}
  .topbar__item--hide-sm{display:none}
  .cta-call--header .cta-call__text small{display:none}
  .cta-call--header .cta-call__text strong{font-size:.9rem}
  .cta-call--header{padding:8px 13px}
  .hero{padding:34px 0 42px;background-image:url('../img/hero-bg-mobile.jpg')}
  .callbar__msg{display:none}            /* compact: just the CTA on phones */
  .callbar__inner{justify-content:center;padding:7px 0}
  .callbar__cta{width:100%;max-width:400px;justify-content:center}
  .callbar__cta .cta-call__text small{display:none}
  .callband__inner{flex-direction:column;text-align:center}
  .search-cta{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){
  /* Header CTA: cramped 2-line number → clean "Call" pill. The full number
     stays in the sticky bottom bar and page content. */
  .cta-call--header .cta-call__text{display:none}
  .cta-call--header::after{content:"Call";font-weight:800;font-size:1rem;letter-spacing:.01em}
  .cta-call--header{padding:10px 16px;gap:8px;white-space:nowrap}
}
@media(max-width:480px){
  .features__grid{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .statsband__inner{grid-template-columns:repeat(2,1fr)}
  .searchbar{flex-direction:column}
  .searchbar .btn{width:100%}
}

/* Shared content blocks usable outside articles (route pages etc.) */
.tipbox{background:linear-gradient(135deg,#fff7ee,#fff);border:1px solid #ffe0bf;border-left:4px solid var(--accent);border-radius:10px;padding:14px 16px;margin:1.2em 0;font-size:.95rem}
.tipbox strong{color:var(--accent-dark)}
.route-facts{width:100%;table-layout:fixed;border-collapse:collapse;margin:.9em 0 1.3em;font-size:.92rem;box-shadow:var(--shadow-sm);border-radius:10px;overflow:hidden}
.route-facts th,.route-facts td{border:1px solid var(--line);padding:9px 13px;text-align:left;word-break:break-word;overflow-wrap:anywhere}
.route-facts th{background:#eef4fb;color:var(--navy);font-weight:700;width:42%}
.route-facts tr:nth-child(even) td{background:#f9fbfe}

/* ===================================================================
   BLOG — index grid, square tiles
   =================================================================== */
.blog-head{max-width:760px;margin-bottom:4px}
.blog-cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;border-bottom:2px solid var(--line);padding-bottom:7px;margin-top:1.7em}
.blog-cat-head h2{margin:0;font-size:1.12rem}
.blog-cat-head h2 a{color:var(--navy)}
.blog-cat-head h2 a:hover{color:var(--blue-dark);text-decoration:none}
.blog-cat-head__all{font-size:.84rem;font-weight:700;color:var(--accent-dark);white-space:nowrap}
.blog-cat-head__all:hover{text-decoration:none;color:var(--accent)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-top:16px}
.blog-card{position:relative;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
  transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.blog-card__link{display:flex;flex-direction:column;height:100%;padding:17px;color:#fff;background:var(--grad-hero);position:relative;overflow:hidden}
.blog-card__link:hover{text-decoration:none;color:#fff}
.blog-card__link::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0%,rgba(255,255,255,.16),transparent 60%);pointer-events:none}
.blog-card__link::after{content:"\2708";position:absolute;right:-10px;bottom:-18px;font-size:5rem;line-height:1;opacity:.13;transform:rotate(-18deg);pointer-events:none}
.blog-card__cat{align-self:flex-start;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:rgba(255,255,255,.22);padding:4px 10px;border-radius:999px;backdrop-filter:blur(3px)}
.blog-card__title{font-size:1.02rem;line-height:1.3;color:#fff;font-weight:800;margin:auto 0 0;
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;line-clamp:4;overflow:hidden}
.blog-card__excerpt{display:none}
.blog-card__meta{position:relative;font-size:.7rem;color:rgba(255,255,255,.88);margin-top:10px;font-weight:600}
/* brand-coloured cards — each category in its airline's colour, fading to navy */
.blog-card--brand .blog-card__link{background:linear-gradient(152deg,var(--card,#16538a),#0a2240 88%)}
.blog-card--brand .blog-card__link::after{display:none}        /* replace plane with topical icon */
.blog-card__ic{position:absolute;right:13px;bottom:11px;z-index:2;font-size:2.6rem;line-height:1;
  opacity:.95;filter:drop-shadow(0 3px 8px rgba(0,0,0,.45));pointer-events:none;
  transition:transform .35s cubic-bezier(.2,.7,.3,1)}
.blog-card:hover .blog-card__ic{transform:scale(1.12) rotate(-6deg)}
.blog-card--brand .blog-card__cat,
.blog-card--brand .blog-card__title,
.blog-card--brand .blog-card__meta{position:relative;z-index:1}

/* photo-backed cards (destination guides) — show the city behind a dark wash */
.blog-card--photo picture{display:contents}
.blog-card--photo .blog-card__link{background:#0b2545}
.blog-card__img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;
  transition:transform .55s cubic-bezier(.2,.7,.3,1)}
.blog-card--photo:hover .blog-card__img{transform:scale(1.07)}
.blog-card--photo .blog-card__link::before{z-index:1;
  background:linear-gradient(180deg,rgba(11,37,69,.04) 0%,rgba(11,37,69,.42) 46%,rgba(8,24,50,.93) 100%)}
.blog-card--photo .blog-card__link::after{display:none}              /* hide the plane on photos */
.blog-card--photo .blog-card__cat{position:relative;z-index:2;background:rgba(7,20,42,.42)}
.blog-card--photo .blog-card__title,
.blog-card--photo .blog-card__meta{position:relative;z-index:2;text-shadow:0 1px 10px rgba(0,0,0,.5)}

/* ===================================================================
   ARTICLE — single blog post
   =================================================================== */
/* Two-column blog layout (article + sticky sidebar) — kills the "boxed" look */
.article-wrap{max-width:1260px;margin:0 auto;padding:6px 20px 0;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:42px;align-items:start}
.article-side{position:sticky;top:78px;display:flex;flex-direction:column;gap:14px}
.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 17px;box-shadow:var(--shadow-sm)}
.side-card__head{font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 8px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.side-links{list-style:none;margin:0;padding:0}
.side-links li+li{border-top:1px solid var(--line)}
.side-links a{display:block;padding:9px 0;font-size:.88rem;font-weight:600;color:var(--ink);line-height:1.35}
.side-links a:hover{color:var(--blue-dark);text-decoration:none}
.side-cta{background:linear-gradient(150deg,#0b2545,#16538a);color:#fff;text-align:center;border:0}
.side-cta__icon{font-size:1.5rem}
.side-cta strong{display:block;font-size:1.02rem;margin:5px 0 2px}
.side-cta p{color:#cfe0f0;font-size:.83rem;margin:0 0 12px}
.side-cta .btn{background:var(--grad-accent);box-shadow:var(--shadow-accent);font-size:1.02rem}
.side-cta__rating{display:block;margin-top:10px;font-size:.74rem;color:#ffd9b0;font-weight:600}
@media(max-width:900px){
  .article-wrap{grid-template-columns:1fr;gap:24px}
  .article-side{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
}

.article{min-width:0;padding-top:6px}
.article__head{margin-bottom:12px}
.article__cat{display:inline-block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-dark);background:rgba(255,122,0,.1);padding:4px 11px;border-radius:999px;margin-bottom:8px}
.article__title{margin:.1em 0}
.article__meta{color:var(--muted);font-size:.85rem;margin:0}
.article__body{font-size:1rem;line-height:1.7;color:#28333d}
.article__body h2{font-size:clamp(1.2rem,2.1vw,1.5rem);margin-top:1.5em}
.article__body h3{font-size:1.1rem;margin-top:1.3em;color:var(--navy-2)}
.article__body p{margin:0 0 1em}
.article__body ul,.article__body ol{margin:0 0 1.1em;padding-left:1.3em}
.article__body li{margin:.35em 0}
.article__body a{color:var(--blue-dark);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.article__body strong{color:var(--navy)}
.article__body blockquote{margin:1.1em 0;padding:12px 18px;border-left:4px solid var(--blue);background:#eef4fb;border-radius:0 10px 10px 0;color:var(--navy-2)}
.article__body .tipbox{margin:1.2em 0}
.article__body table{width:100%;table-layout:fixed;border-collapse:collapse;margin:1.1em 0;font-size:.92rem}
.article__body th,.article__body td{border:1px solid var(--line);padding:9px 12px;text-align:left;word-break:break-word;overflow-wrap:anywhere}
.article__body th{background:#eef4fb;color:var(--navy);font-weight:700}
.article__body tr:nth-child(even) td{background:#f9fbfe}

.article-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  background:linear-gradient(135deg,#0b2545,#16538a);color:#fff;border-radius:var(--radius-lg);
  padding:16px 20px;margin:20px 0;box-shadow:var(--shadow)}
.article-cta div{display:flex;flex-direction:column;gap:2px}
.article-cta strong{font-size:1.02rem}
.article-cta span{color:#cfe0f0;font-size:.88rem}
.article-cta--bottom{margin-top:28px}
.article__faq{margin-top:28px}
.article__tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:22px}
.tag{font-size:.78rem;color:var(--muted);background:#eef2f7;border:1px solid var(--line);padding:4px 11px;border-radius:999px}

@media(max-width:560px){
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:11px}
  .blog-card__link{padding:14px}
  .blog-card__title{font-size:.95rem;-webkit-line-clamp:5;line-clamp:5}
  .blog-card__link::after{font-size:4rem}
  .article-cta{flex-direction:column;align-items:flex-start}
}
@media(max-width:360px){
  .blog-grid{grid-template-columns:1fr}
}

/* ===================================================================
   HOMEPAGE — richer landing sections
   =================================================================== */
.section{padding:46px 0}
.section--tint{background:linear-gradient(180deg,#fff,#eef4fb)}
.section-head{text-align:center;max-width:660px;margin:0 auto 26px}
.section-head h2{margin:.1em 0 .25em}
.section-head p{color:var(--muted);margin:0;font-size:1rem}
.eyebrow{display:inline-block;font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-dark);background:rgba(255,122,0,.1);padding:5px 13px;border-radius:999px;margin-bottom:10px}

/* Hero eyebrow badge */
.hero__eyebrow{display:inline-block;margin-bottom:14px;padding:6px 15px;border-radius:999px;
  font-size:.74rem;font-weight:700;letter-spacing:.03em;color:#eaf3fc;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}

/* Flight-search widget (hero) */
.flightsearch{max-width:1040px;margin:6px auto 0;text-align:left;
  background:rgba(255,255,255,.98);padding:12px;border-radius:16px;
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(255,255,255,.35)}
/* Trip-type segmented control */
.fs-tabs{display:inline-flex;gap:3px;background:#eef2f7;border-radius:999px;padding:3px;margin-bottom:10px}
.fs-tab{cursor:pointer}
.fs-tab input{position:absolute;opacity:0;width:0;height:0}
.fs-tab span{display:block;padding:6px 16px;border-radius:999px;font-size:.8rem;font-weight:700;color:var(--muted);transition:background .15s,color .15s}
.fs-tab input:checked+span{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.fs-tab input:focus-visible+span{outline:2px solid var(--blue);outline-offset:1px}
/* One cohesive search bar: borderless segments joined by dividers */
.fs-row{display:flex;align-items:stretch;gap:9px}
.fs-fields{flex:1 1 auto;display:flex;align-items:stretch;min-width:0;
  border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}
.fs-field{position:relative;flex:1.35 1 120px;display:flex;flex-direction:column;justify-content:center;gap:2px;
  padding:9px 15px;min-width:0;cursor:text;transition:background .15s}
.fs-field--date{flex:1 1 102px}
.fs-field--pax{flex:0 1 144px}
.fs-field--date,.fs-field--pax{border-left:1px solid var(--line)}
.fs-field:hover{background:#f6f9fc}
.fs-field:focus-within{background:#eef4fb}
.fs-field__label{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.fs-field:focus-within .fs-field__label{color:var(--blue-dark)}
.fs-input{display:flex;align-items:center;gap:7px;min-width:0}
.fs-ic{font-size:.92rem;opacity:.55;flex:0 0 auto}
.fs-input input,.fs-input select{border:0;outline:0;background:transparent;font-size:.95rem;font-weight:600;
  color:var(--ink);width:100%;min-width:0;font-family:inherit;padding:0;height:22px}
.fs-input input::placeholder{color:#9aa7b4;font-weight:500}
.fs-input--date input::-webkit-calendar-picker-indicator{opacity:.45;cursor:pointer}
.fs-input--select select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:15px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%235b6b7a' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E") right center/9px no-repeat}
/* Floating swap circle between From and To */
.fs-swap{flex:0 0 auto;align-self:center;width:34px;height:34px;margin:0 -3px;border-radius:50%;
  border:1px solid var(--line);background:#fff;color:var(--blue);font-size:1rem;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:transform .25s ease,background .15s,color .15s}
.fs-swap:hover{background:var(--blue);color:#fff;transform:rotate(180deg)}
/* Search button as its own block */
.fs-go{flex:0 0 auto;align-self:stretch;padding:0 30px;border-radius:14px;font-size:1rem}
/* One-way hides the return date (toggled by app.js) */
.flightsearch.is-oneway .fs-return{display:none}
@media(max-width:680px){
  .fs-row{flex-direction:column;gap:8px}
  .fs-fields{flex-direction:column}
  .fs-field{flex:1 1 auto}
  .fs-field--date,.fs-field--pax{border-left:0}
  .fs-field:not(:first-child){border-top:1px solid var(--line)}
  .fs-swap{align-self:center;margin:3px 0;transform:rotate(90deg)}
  .fs-swap:hover{transform:rotate(270deg)}
  .fs-go{align-self:stretch;padding:13px}
}

/* Hero solo CTA + quick-link chips */
.hero__cta--solo{justify-content:center;margin-top:24px}
.hero__links{display:flex;justify-content:center;flex-wrap:wrap;gap:9px;margin-top:20px}
.hero__links a{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:#eaf3fc;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);padding:8px 15px;border-radius:999px;
  -webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);transition:background .15s,transform .15s,color .15s}
.hero__links a:hover{background:rgba(255,255,255,.2);color:#fff;text-decoration:none;transform:translateY(-1px)}

/* Hero trust badges */
.trustbar{display:flex;justify-content:center;flex-wrap:wrap;gap:8px 22px;margin-top:20px}
.trustbar span{display:inline-flex;align-items:center;gap:7px;color:#dceaf8;font-size:.84rem;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.2)}
.trustbar span::before{content:"✓";display:grid;place-items:center;width:17px;height:17px;border-radius:50%;background:rgba(127,212,166,.25);color:#9be9bf;font-size:.66rem;font-weight:800}

/* Destination tiles — real photos + readable overlay */
.dest-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.dest-tile{position:relative;aspect-ratio:5/4;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:flex-end;padding:15px;color:#fff;isolation:isolate;
  background:#0b2545 center/cover no-repeat;transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s}
.dest-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);text-decoration:none;color:#fff}
/* Zoomable photo layer so hover feels alive without moving the text */
.dest-tile picture,.city-tile picture{display:contents}
.dest-tile__img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.dest-tile:hover .dest-tile__img{transform:scale(1.07)}
.dest-tile::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,37,69,.04) 0%,rgba(11,37,69,.18) 42%,rgba(11,37,69,.82) 100%)}
.dest-tile__city{font-size:1.12rem;font-weight:800;line-height:1.15;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.dest-tile__sub{font-size:.74rem;color:rgba(255,255,255,.88);margin-top:1px;text-shadow:0 1px 5px rgba(0,0,0,.5)}
.dest-tile__price{display:inline-block;align-self:flex-start;margin-top:8px;font-size:.8rem;font-weight:800;color:var(--navy);background:#fff;padding:3px 10px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.dest-tile__price em{font-style:normal;color:var(--muted);font-weight:600}

/* Contact page */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:26px;align-items:start;margin-top:6px}
.contact-aside{display:flex;flex-direction:column;gap:12px}
.contact-call{background:linear-gradient(150deg,#0b2545,#16538a);color:#fff;border-radius:var(--radius-lg);padding:22px 20px;text-align:center;box-shadow:var(--shadow)}
.contact-call__label{font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#bcd4ee}
.contact-call__num{display:block;font-size:1.55rem;font-weight:800;color:#fff;margin:5px 0 12px}
.contact-call__num:hover{color:#fff}
.contact-call .btn{background:var(--grad-accent);box-shadow:var(--shadow-accent)}
.contact-call__hours{display:block;margin-top:10px;font-size:.76rem;color:#bcd4ee}
.method{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 15px;box-shadow:var(--shadow-sm)}
.method__ic{font-size:1.2rem;width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,#eef5fc,#e3eefa);flex:0 0 auto}
.method h3{margin:0 0 2px;font-size:.95rem}
.method p{margin:0;color:var(--muted);font-size:.88rem}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}
.contact-form h2{margin-top:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.field label{font-size:.78rem;font-weight:700;color:var(--navy)}
.field .req{color:var(--accent)}
.field input{border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:.95rem;font-family:inherit;background:#fff;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.field input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,111,184,.15)}
.form-note{font-size:.76rem;color:var(--muted);margin:8px 0 0;text-align:center}
.form-error{background:rgba(214,40,40,.08);border:1px solid rgba(214,40,40,.3);color:#b3261e;border-radius:10px;padding:10px 13px;margin-bottom:12px;font-size:.9rem}
.form-success{background:linear-gradient(135deg,#eafaf1,#fff);border:1px solid rgba(26,162,96,.35);border-radius:var(--radius-lg);padding:30px 24px;text-align:center;box-shadow:var(--shadow-sm)}
.form-success__ic{font-size:2.4rem}
.form-success h2{margin:.2em 0}
.form-success p{color:var(--muted);margin:0;max-width:46ch;margin-inline:auto}
@media(max-width:760px){
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* About — story split */
.about-split{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}
.about-split__text .eyebrow{margin-bottom:6px}
.about-split__img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);
  aspect-ratio:4/3;min-height:240px;background:#0b2545 center/cover no-repeat}
.about-check{list-style:none;padding:0;margin:14px 0 18px;display:grid;gap:9px}
.about-check li{position:relative;padding-left:30px;color:var(--ink)}
.about-check li em{font-style:normal;font-weight:700;color:var(--navy)}
.about-check li::before{content:"✓";position:absolute;left:0;top:1px;width:20px;height:20px;border-radius:50%;
  display:grid;place-items:center;font-size:.7rem;font-weight:800;color:#fff;background:var(--green)}
@media(max-width:760px){
  .about-split{grid-template-columns:1fr;gap:22px}
  .about-split__img{order:-1}
}

/* Destination hub — full-width photo hero */
.dest-hero{position:relative;isolation:isolate;overflow:hidden;color:#fff;padding:26px 0 40px;
  background:#0b2545 center/cover no-repeat}
.dest-hero--grad{background:var(--grad-hero)}
.dest-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(11,37,69,.92) 0%,rgba(11,37,69,.6) 48%,rgba(11,37,69,.28) 100%),
             linear-gradient(180deg,transparent 50%,rgba(11,37,69,.55) 100%)}
.dest-hero__inner{position:relative;z-index:1;max-width:740px}
.dest-hero .breadcrumbs{padding-top:0;margin-bottom:10px;color:rgba(255,255,255,.82)}
.dest-hero .breadcrumbs a{color:rgba(255,255,255,.82)}
.dest-hero .breadcrumbs a:hover{color:#fff}
.dest-hero h1{color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.dest-hero__lead{color:#e7eef7;font-size:1.04rem;max-width:58ch;text-shadow:0 1px 10px rgba(0,0,0,.3)}
.dest-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px}
.dest-chip{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;color:#fff;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);padding:6px 13px;border-radius:999px;
  -webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}
.dest-chip b{color:#ffd9b0;font-weight:800}

/* Airlines index — brand-color tiles */
.airline-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:15px;margin:14px 0 8px}
.airline-tile{position:relative;display:flex;flex-direction:column;min-height:150px;padding:16px 18px 15px;border-radius:16px;color:#fff;overflow:hidden;isolation:isolate;
  background:linear-gradient(140deg,var(--air,#16538a),#0b2545);box-shadow:var(--shadow);
  transition:transform .22s cubic-bezier(.2,.7,.3,1),box-shadow .22s}
/* sheen + plane silhouette */
.airline-tile::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 90% at 0% 0%,rgba(255,255,255,.16),transparent 55%)}
.airline-tile::after{content:"\2708";position:absolute;right:-8px;bottom:-16px;font-size:4rem;opacity:.13;transform:rotate(-18deg);
  transition:transform .35s cubic-bezier(.2,.7,.3,1),opacity .3s;pointer-events:none}
.airline-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);text-decoration:none;color:#fff}
.airline-tile:hover::after{transform:rotate(-18deg) translate(-6px,-6px) scale(1.05);opacity:.2}

.airline-tile__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:11px}
.airline-tile__iata{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.22);border-radius:9px;
  padding:4px 9px;font-size:.78rem;font-weight:800;letter-spacing:.06em}
.airline-tile__country{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.78);text-align:right}
.airline-tile__name{font-size:1.1rem;font-weight:800;line-height:1.22}
.airline-tile__chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.airline-tile__chips span{background:rgba(255,255,255,.15);border-radius:20px;padding:3px 10px;font-size:.7rem;font-weight:600;color:rgba(255,255,255,.92)}
.airline-tile__go{display:inline-flex;align-items:center;gap:6px;margin-top:auto;padding-top:13px;font-size:.8rem;font-weight:700;color:#fff;opacity:.9}
.airline-tile__go i{font-style:normal;transition:transform .2s}
.airline-tile:hover .airline-tile__go{opacity:1}
.airline-tile:hover .airline-tile__go i{transform:translateX(4px)}

/* Airline hub — brand-gradient hero (gradient set inline) */
.air-hero{position:relative;isolation:isolate;overflow:hidden;color:#fff;padding:26px 0 40px;background:#0b2545}
.air-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.28))}
.air-hero__inner{position:relative;z-index:1;max-width:780px}
.air-hero .breadcrumbs{padding-top:0;margin-bottom:10px;color:rgba(255,255,255,.82)}
.air-hero .breadcrumbs a{color:rgba(255,255,255,.82)}
.air-hero .breadcrumbs a:hover{color:#fff}
.air-hero h1{color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.32)}
.air-hero__badge{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.05em;color:#fff;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.26);padding:5px 12px;border-radius:999px;margin-bottom:10px}
.air-hero__lead{color:#e7eef7;font-size:1.04rem;max-width:64ch;text-shadow:0 1px 10px rgba(0,0,0,.25)}
.air-disclaimer{font-size:.8rem;margin-top:28px;padding-top:14px;border-top:1px solid var(--line)}

/* Deals — themed tiles */
.deal-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:13px;margin:16px 0 8px}
.deal-tile{position:relative;display:flex;flex-direction:column;gap:5px;padding:18px;border-radius:14px;color:#fff;overflow:hidden;isolation:isolate;
  background:linear-gradient(140deg,var(--deal,#16538a),#0b2545);box-shadow:var(--shadow);
  transition:transform .2s cubic-bezier(.2,.7,.3,1),box-shadow .2s}
.deal-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none;color:#fff}
.deal-tile__icon{font-size:1.7rem;line-height:1}
.deal-tile__name{font-size:1.04rem;font-weight:800;line-height:1.22}
.deal-tile__kw{font-size:.74rem;color:rgba(255,255,255,.82);font-weight:600}

/* City tiles (destinations index) — square photo cards w/ hover-pop */
.city-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:12px;margin:14px 0 8px}
.city-tile{position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;justify-content:flex-end;padding:13px;color:#fff;isolation:isolate;
  background:#0b2545 center/cover no-repeat;transition:transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s}
.city-tile:hover{transform:translateY(-6px) scale(1.035);box-shadow:var(--shadow-lg);text-decoration:none;color:#fff;z-index:2}
.city-tile__img{position:absolute;inset:0;z-index:-2;width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.2,.7,.3,1)}
.city-tile:hover .city-tile__img{transform:scale(1.1)}
.city-tile::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,37,69,.04) 0%,rgba(11,37,69,.24) 45%,rgba(11,37,69,.85) 100%)}
.city-tile__name{font-size:.98rem;font-weight:800;line-height:1.15;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.city-tile__iata{font-size:.7rem;color:rgba(255,255,255,.85);margin-top:2px;text-shadow:0 1px 5px rgba(0,0,0,.5);letter-spacing:.02em}
.city-tile--grad{background:var(--grad-hero)}
.city-tile--grad:nth-child(4n+2){background:linear-gradient(150deg,#123a6b,#2a86c9)}
.city-tile--grad:nth-child(4n+3){background:linear-gradient(150deg,#a8480a,#ef7c12)}
.city-tile--grad:nth-child(4n+4){background:linear-gradient(150deg,#0e3b46,#1aa6a0)}
@media(max-width:560px){.city-tiles{grid-template-columns:repeat(2,1fr);gap:10px}}

/* Savings showcase */
.compare-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
@media(max-width:820px){.compare-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:460px){.compare-grid{grid-template-columns:1fr}}
.compare-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px 18px 16px;box-shadow:var(--shadow-sm);text-align:center;transition:transform .2s,box-shadow .2s,border-color .2s}
.compare-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent;text-decoration:none}
.compare-card__route{font-weight:800;color:var(--navy);font-size:1.02rem}
.compare-card__meta{font-size:.78rem;color:var(--muted);margin-top:2px}
.compare-prices{display:flex;align-items:baseline;justify-content:center;gap:9px;margin:12px 0 8px}
.compare-old{color:var(--muted);text-decoration:line-through;font-size:1rem}
.compare-new{color:var(--accent);font-size:1.5rem;font-weight:800;letter-spacing:-.02em}
.compare-save{display:inline-block;background:rgba(26,162,96,.12);color:#127a47;font-weight:700;font-size:.76rem;padding:4px 11px;border-radius:999px}

/* Testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
@media(max-width:760px){.testi-grid{grid-template-columns:1fr}}
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.testi__stars{color:#ffb300;font-size:.95rem;letter-spacing:2px}
.testi__quote{margin:10px 0 16px;color:var(--ink);font-size:.95rem;line-height:1.62;flex:1}
.testi__author{display:flex;align-items:center;gap:11px}
.testi__avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:.9rem;color:#fff;background:var(--grad-brand);flex:0 0 auto}
.testi__name{font-weight:700;font-size:.88rem;color:var(--navy)}
.testi__loc{font-size:.76rem;color:var(--muted)}

@media(max-width:560px){
  .dest-tiles{grid-template-columns:repeat(2,1fr);gap:11px}
}

/* ===================================================================
   Entry call popup
   =================================================================== */
.cta-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:18px}
.cta-modal[hidden]{display:none}
.cta-modal__backdrop{position:absolute;inset:0;background:rgba(7,20,42,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fd-fade .25s ease}
.cta-modal__card{position:relative;z-index:1;display:flex;width:100%;max-width:780px;background:#fff;border-radius:24px;overflow:hidden;
  box-shadow:0 40px 100px rgba(7,20,42,.6);animation:fd-pop .36s cubic-bezier(.2,.85,.3,1)}
.cta-modal__close{position:absolute;top:14px;right:15px;z-index:4;width:38px;height:38px;border:0;border-radius:50%;
  background:rgba(255,255,255,.85);color:var(--navy);font-size:1.5rem;line-height:1;cursor:pointer;
  box-shadow:0 3px 10px rgba(0,0,0,.18);transition:.18s}
.cta-modal__close:hover{background:#fff;transform:rotate(90deg)}
/* Left photo panel */
.cta-modal__media{position:relative;flex:0 0 42%;min-height:420px;isolation:isolate;
  background:#0b2545 url('../img/hero-bg.jpg') center/cover no-repeat}
.cta-modal__media::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,rgba(11,37,69,.25) 0%,rgba(11,37,69,.5) 60%,rgba(255,122,0,.32) 100%)}
.cta-modal__rating{position:absolute;left:0;right:0;bottom:22px;z-index:1;text-align:center;color:#fff;font-size:.82rem;line-height:1.45;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.cta-modal__rating strong{font-size:1.02rem}
.cta-modal__stars{display:block;color:#ffc24d;font-size:1.05rem;letter-spacing:3px;margin-bottom:3px}
/* Right content panel */
.cta-modal__content{flex:1;min-width:0;padding:42px 40px 32px;display:flex;flex-direction:column;align-items:flex-start;text-align:left}
.cta-modal__eyebrow{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.04em;color:var(--accent-dark);
  background:rgba(255,122,0,.12);padding:6px 13px;border-radius:999px;margin-bottom:14px}
.cta-modal__title{color:var(--navy);font-size:2.05rem;line-height:1.12;margin:0 0 .35em;letter-spacing:-.02em}
.cta-modal__sub{color:var(--muted);font-size:1.04rem;line-height:1.55;margin:0 0 20px}
.cta-modal__call{width:100%;justify-content:center;padding:16px 26px;animation:fd-callpulse 2.1s ease-out infinite}
.cta-modal__call:hover{animation-play-state:paused}
.cta-modal__call .cta-call__icon{font-size:1.5rem}
.cta-modal__call .cta-call__text strong{font-size:1.45rem}
.cta-modal__call .cta-call__text small{font-size:.72rem}
.cta-modal__perks{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-wrap:wrap;gap:8px 18px;width:100%}
.cta-modal__perks li{position:relative;padding-left:23px;font-size:.86rem;font-weight:600;color:var(--ink)}
.cta-modal__perks li::before{content:"✓";position:absolute;left:0;top:-1px;width:17px;height:17px;border-radius:50%;
  display:grid;place-items:center;font-size:.62rem;font-weight:800;color:#fff;background:var(--green)}
.cta-modal__dismiss{align-self:center;margin-top:20px;padding:4px;background:0;border:0;color:#9aa7b4;font-size:.85rem;cursor:pointer}
.cta-modal__dismiss:hover{color:var(--muted);text-decoration:underline}
@keyframes fd-pop{from{opacity:0;transform:translateY(22px) scale(.95)}to{opacity:1;transform:none}}
@keyframes fd-fade{from{opacity:0}to{opacity:1}}
@keyframes fd-callpulse{0%{box-shadow:var(--shadow-accent),0 0 0 0 rgba(255,122,0,.5)}70%{box-shadow:var(--shadow-accent),0 0 0 16px rgba(255,122,0,0)}100%{box-shadow:var(--shadow-accent),0 0 0 0 rgba(255,122,0,0)}}
@media(max-width:640px){
  .cta-modal__card{flex-direction:column;max-width:430px}
  .cta-modal__media{flex:none;min-height:150px}
  .cta-modal__rating{bottom:14px}
  .cta-modal__content{padding:28px 26px 26px;align-items:center;text-align:center}
  .cta-modal__title{font-size:1.6rem}
  .cta-modal__sub{font-size:.98rem}
  .cta-modal__perks{justify-content:center}
}

/* Cookie consent banner */
.cookie{position:fixed;left:16px;bottom:80px;z-index:900;max-width:340px;display:flex;flex-direction:column;gap:11px;
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-lg);font-size:.85rem;line-height:1.5;color:var(--ink)}
.cookie[hidden]{display:none}
.cookie a{color:var(--blue-dark);font-weight:600}
.cookie__ok{align-self:flex-start;background:var(--grad-brand);color:#fff;border:0;padding:8px 20px;border-radius:9px;font-weight:700;font-size:.85rem;cursor:pointer;box-shadow:0 3px 10px rgba(29,111,184,.26)}
.cookie__ok:hover{filter:brightness(1.05)}
@media(max-width:640px){.cookie{left:10px;right:10px;bottom:72px;max-width:none}}

/* HTML site map — collapsible route groups */
.sitemap-routes{border-bottom:1px solid var(--line)}
.sitemap-routes summary{cursor:pointer;font-weight:700;color:var(--navy);padding:11px 0;list-style:none}
.sitemap-routes summary::-webkit-details-marker{display:none}
.sitemap-routes summary::before{content:"▸";color:var(--blue);margin-right:8px;display:inline-block;transition:transform .15s}
.sitemap-routes[open] summary::before{transform:rotate(90deg)}
.sitemap-routes .link-grid{margin:2px 0 14px}

/* Honor reduced-motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}
}
