@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&display=swap");

:root{
  --ink:#0B1234;
  --ink-2:#141d4a;
  --twilight-top:#0a1133;
  --twilight-mid:#2a2a63;
  --horizon:#ff8a5c;
  --horizon-2:#ffc06a;
  --glow:#ff7a4d;
  --cloud:#fbf8f2;
  --paper:#ffffff;
  --line:#e7e1d6;
  --line-strong:#d6cdbd;
  --muted:#6b6c84;
  --muted-2:#9a9bb0;
  --text:#1a1c33;
  --teal:#0f8a86;
  --ok:#178a5a;
  --shadow:0 18px 50px -22px rgba(11,18,52,.45);
  --radius:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter",system-ui,sans-serif;
  color:var(--text);
  background:var(--cloud);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.mono{font-family:"Space Mono",ui-monospace,monospace}
h1,h2{font-family:"Fraunces","Bricolage Grotesque",Georgia,serif;font-weight:600;line-height:1.06;letter-spacing:-.012em}
h3{font-family:"Bricolage Grotesque","Inter",sans-serif;line-height:1.05;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer}
a{color:inherit}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}

/* ---------- Nav ---------- */
header.nav{position:sticky;top:0;z-index:40;background:rgba(10,17,51,.82);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;color:#fff;text-decoration:none}
.brand-logo{height:42px;width:auto;display:block;background:#fff;border-radius:12px;padding:6px 13px;border:1px solid rgba(255,255,255,.55);box-shadow:0 6px 18px -8px rgba(0,0,0,.5)}
@media(max-width:480px){.brand-logo{height:36px;padding:5px 10px}}
.brand-mark{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--horizon),var(--horizon-2));box-shadow:0 6px 18px -6px var(--glow)}
.brand-mark svg{width:21px;height:21px}
.brand-name{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.18rem;letter-spacing:-.02em;line-height:1}
.brand-name small{display:block;font-family:"Space Mono";font-weight:400;font-size:.54rem;letter-spacing:.3em;color:var(--horizon-2);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:24px}
.nav-links a{color:rgba(255,255,255,.78);text-decoration:none;font-size:.9rem;font-weight:500}
.nav-links a:hover{color:#fff}
.nav-phone{display:flex;align-items:center;gap:7px;border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:7px 14px;color:#fff;font-size:.82rem;font-weight:600;text-decoration:none}
.nav-phone:hover{border-color:var(--horizon-2)}
.nav-phone svg{width:14px;height:14px;color:var(--horizon-2)}
@media(max-width:820px){.nav-links a{display:none}}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;padding:54px 0 120px;overflow:hidden;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(255,138,92,.45) 0%, rgba(255,138,92,0) 45%),
    radial-gradient(90% 80% at 12% 0%, rgba(94,98,200,.4) 0%, rgba(94,98,200,0) 50%),
    linear-gradient(180deg, rgba(10,17,51,.72) 0%, rgba(20,29,74,.85) 100%),
    url("https://upload.wikimedia.org/wikipedia/commons/thumb/6/62/SL_Demodara_near_Ella_asv2020-01_img02.jpg/1920px-SL_Demodara_near_Ella_asv2020-01_img02.jpg") center/cover no-repeat;
}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:120px;
  background:linear-gradient(180deg,rgba(255,138,92,0) 0%, rgba(255,138,92,.18) 100%);pointer-events:none}
.stars{position:absolute;inset:0;opacity:.5;pointer-events:none}
.stars i{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;animation:tw 4s ease-in-out infinite}
@keyframes tw{0%,100%{opacity:.2}50%{opacity:.9}}
.hero-in{position:relative;z-index:2;max-width:680px}
.eyebrow{font-family:"Space Mono";font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--horizon-2);margin-bottom:14px}
.hero h1{font-size:clamp(2.3rem,5.4vw,3.7rem);font-weight:800;max-width:16ch}
.hero h1 em{font-style:normal;background:linear-gradient(100deg,var(--horizon-2),var(--horizon));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lede{margin-top:14px;max-width:52ch;color:rgba(255,255,255,.78);font-size:1.02rem}
.trust-row{display:flex;gap:22px;margin-top:22px;flex-wrap:wrap}
.trust-row .ti{display:flex;align-items:center;gap:9px;font-size:.82rem;color:rgba(255,255,255,.82)}
.trust-row .ti b{color:#fff;font-weight:700}
.trust-row .ti .ic{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.1);display:grid;place-items:center;font-size:.9rem}

/* ---------- Search panel ---------- */
.search{position:relative;z-index:3;margin:30px auto -70px;max-width:1040px}
.panel{background:var(--paper);border-radius:22px;box-shadow:var(--shadow);padding:18px 18px 20px}
.triptabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.triptabs button{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:999px;padding:8px 16px;font-size:.86rem;font-weight:600;transition:.15s}
.triptabs button[aria-selected="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.mode-pill{margin-left:auto;display:flex;align-items:center;gap:7px;font-size:.72rem;font-weight:600;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:5px 11px}
.mode-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--muted-2)}
.mode-pill.live .dot{background:#3ee08f;box-shadow:0 0 0 3px rgba(62,224,143,.18)}
.mode-pill.mock .dot{background:var(--horizon)}

.fields{display:grid;grid-template-columns:1.5fr auto 1.5fr 1fr 1fr;gap:12px;align-items:end}
@media(max-width:900px){.fields{grid-template-columns:1fr 1fr}.swapbtn{order:0;justify-self:center}}
@media(max-width:560px){.fields{grid-template-columns:1fr}}
.field{position:relative}
.field label{display:block;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 6px 2px}
.field .control{border:1px solid var(--line);border-radius:14px;padding:11px 13px;background:#fff;transition:.15s;height:60px;display:flex;flex-direction:column;justify-content:center}
.field .control:focus-within{border-color:var(--ink);box-shadow:0 0 0 3px rgba(20,29,74,.12)}
.field input{border:0;outline:0;font-size:1rem;font-family:inherit;width:100%;background:transparent;color:var(--text)}
.field input::placeholder{color:var(--muted-2)}
.field .sub{font-size:.74rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}

/* autocomplete dropdown */
.ac{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);z-index:25;overflow:hidden;display:none}
.ac.open{display:block}
.ac .opt{display:flex;align-items:center;gap:11px;padding:10px 13px;cursor:pointer;border-bottom:1px solid var(--line)}
.ac .opt:last-child{border-bottom:0}
.ac .opt:hover,.ac .opt.active{background:var(--cloud)}
.ac .opt .iata{font-family:"Space Mono";font-weight:700;font-size:.86rem;background:var(--ink);color:#fff;border-radius:7px;padding:3px 7px;min-width:46px;text-align:center}
.ac .opt .meta .c{font-weight:600;font-size:.9rem}
.ac .opt .meta .n{font-size:.74rem;color:var(--muted)}

.swapbtn{align-self:end;margin-bottom:10px;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--ink);display:grid;place-items:center;transition:.2s}
.swapbtn:hover{transform:rotate(180deg);border-color:var(--ink)}
.swapbtn svg{width:18px;height:18px}

.paxbtn{width:100%;text-align:left}
.searchrow{display:flex;gap:12px;margin-top:14px;align-items:stretch}
.btn-search{flex:1;border:0;border-radius:14px;background:linear-gradient(100deg,var(--glow),var(--horizon-2));color:#3a1d05;font-weight:800;font-size:1rem;padding:15px;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px -10px var(--glow);transition:.15s}
.btn-search:hover{filter:brightness(1.04);transform:translateY(-1px)}
.btn-search:disabled{opacity:.7;cursor:wait;transform:none}
.btn-search svg{width:18px;height:18px}

.pax-pop{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:14px;z-index:20;display:none}
.pax-pop.open{display:block}
.pax-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line)}
.pax-row:last-child{border-bottom:0}
.pax-row .t{font-weight:600;font-size:.92rem}
.pax-row .d{font-size:.74rem;color:var(--muted)}
.stepper{display:flex;align-items:center;gap:12px}
.stepper button{width:30px;height:30px;border-radius:9px;border:1px solid var(--line);background:#fff;font-size:1.1rem;line-height:1;color:var(--ink)}
.stepper button:disabled{opacity:.3;cursor:not-allowed}
.stepper span{min-width:18px;text-align:center;font-weight:700}
.cabin-seg{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.cabin-seg button{flex:1;border:1px solid var(--line);background:#fff;border-radius:10px;padding:7px;font-size:.78rem;font-weight:600;color:var(--muted)}
.cabin-seg button[aria-selected="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---------- Results ---------- */
main{padding:110px 0 40px}
.results-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.results-head h2{font-size:1.5rem;font-weight:800}
.results-head .route-sum{color:var(--muted);font-size:.92rem;margin-top:3px}
.results-head .route-sum b{color:var(--text)}

.layout{display:grid;grid-template-columns:248px 1fr;gap:24px;align-items:start}
@media(max-width:840px){.layout{grid-template-columns:1fr}}
.filters{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;position:sticky;top:80px}
@media(max-width:840px){.filters{position:static}}
.filters h3{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:"Space Mono";font-weight:700;margin-bottom:12px}
.filter-group{padding:14px 0;border-top:1px solid var(--line)}
.filter-group:first-of-type{border-top:0;padding-top:0}
.filter-group .gl{font-size:.82rem;font-weight:700;margin-bottom:9px}
.check{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:.88rem;color:var(--text);cursor:pointer}
.check input{accent-color:var(--ink);width:16px;height:16px}
.check .px{margin-left:auto;color:var(--muted);font-size:.8rem}
.sortbar{display:flex;gap:6px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:5px;margin-bottom:16px;flex-wrap:wrap}
.sortbar button{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;font-weight:600;font-size:.82rem;color:var(--muted);min-width:90px}
.sortbar button[aria-selected="true"]{background:var(--cloud);color:var(--ink)}

/* boarding-pass flight card */
.flight{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;display:grid;grid-template-columns:1fr 168px;overflow:hidden;transition:.18s}
.flight:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-2px)}
@media(max-width:560px){.flight{grid-template-columns:1fr}}
.flight .main{padding:18px 20px}
.airline{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.al-logo{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:#fff;font-family:"Space Mono";font-weight:700;font-size:.72rem}
.airline .al-name{font-weight:600;font-size:.9rem}
.airline .al-flt{font-family:"Space Mono";font-size:.74rem;color:var(--muted)}
.itin{padding:6px 0}
.itin + .itin{border-top:1px dashed var(--line);margin-top:6px}
.itin .itin-tag{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:6px}
.legs{display:flex;align-items:center;gap:16px}
.leg{text-align:center}
.leg .time{font-family:"Space Mono";font-weight:700;font-size:1.28rem;letter-spacing:.01em}
.leg .ap{font-size:.78rem;color:var(--muted);font-weight:600;margin-top:2px}
.leg .ap b{color:var(--text)}
.path{flex:1;text-align:center;position:relative}
.path .dur{font-size:.74rem;color:var(--muted);margin-bottom:4px}
.path .barline{height:2px;background:var(--line-strong);position:relative;border-radius:2px}
.path .barline::before,.path .barline::after{content:"";position:absolute;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--ink)}
.path .barline::before{left:0}.path .barline::after{right:0}
.path .plane{position:absolute;top:50%;left:50%;transform:translate(-50%,-58%);background:#fff;padding:0 6px;color:var(--horizon)}
.path .plane svg{width:16px;height:16px;display:block}
.path .stops{font-size:.72rem;font-weight:700;margin-top:4px}
.path .stops.nonstop{color:var(--ok)}
.path .stops.has{color:var(--horizon)}

.stub{position:relative;background:linear-gradient(180deg,#fff 0%, #fbf8f2 100%);border-left:2px dashed var(--line-strong);padding:18px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.stub::before,.stub::after{content:"";position:absolute;left:-9px;width:16px;height:16px;border-radius:50%;background:var(--cloud);border:1px solid var(--line)}
.stub::before{top:-9px}.stub::after{bottom:-9px}
@media(max-width:560px){.stub{border-left:0;border-top:2px dashed var(--line-strong)}.stub::before{left:-9px;top:auto;bottom:-9px}.stub::after{left:auto;right:-9px;top:-9px;bottom:auto}}
.stub .from{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.stub .price{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.7rem;margin:2px 0 1px}
.stub .per{font-size:.7rem;color:var(--muted);margin-bottom:6px}
.stub .seats{font-size:.66rem;color:var(--horizon);font-weight:700;margin-bottom:10px;min-height:14px}
.stub .select{width:100%;border:0;border-radius:11px;background:var(--ink);color:#fff;padding:11px;font-weight:700;font-size:.86rem;transition:.15s}
.stub .select:hover{background:var(--glow);color:#3a1d05}

.empty{background:#fff;border:1px dashed var(--line-strong);border-radius:var(--radius);padding:54px 24px;text-align:center;color:var(--muted)}
.empty .big{font-family:"Bricolage Grotesque";font-weight:700;color:var(--text);font-size:1.3rem;margin-bottom:6px}

/* skeleton loading */
.skel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;padding:18px 20px;display:grid;grid-template-columns:1fr 168px;gap:18px}
.skel .bar{height:14px;border-radius:7px;background:linear-gradient(90deg,#eee 25%,#f6f3ec 37%,#eee 63%);background-size:400% 100%;animation:sh 1.3s ease infinite}
@keyframes sh{0%{background-position:100% 0}100%{background-position:-100% 0}}

.warn-banner{background:#fff7ee;border:1px solid var(--horizon);color:#8a4b1f;border-radius:12px;padding:11px 14px;font-size:.84rem;margin-bottom:14px}

/* ---------- Booking drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(10,17,51,.55);backdrop-filter:blur(2px);z-index:60;opacity:0;visibility:hidden;transition:.25s}
.scrim.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(460px,100%);background:var(--cloud);z-index:70;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-20px 0 60px -20px rgba(0,0,0,.4)}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:18px 22px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:space-between}
.drawer-head h3{font-size:1.1rem;font-weight:700}
.drawer-head .x{background:rgba(255,255,255,.14);border:0;color:#fff;width:34px;height:34px;border-radius:10px;font-size:1.2rem}
.drawer-body{padding:20px 22px;overflow-y:auto;flex:1}
.sumcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:18px}
.sumcard .r1{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.sumcard .seg-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0}
.sumcard .seg-row + .seg-row{border-top:1px dashed var(--line)}
.sumcard .seg{text-align:center}
.sumcard .seg .tm{font-family:"Space Mono";font-weight:700;font-size:1.05rem}
.sumcard .seg .cd{font-size:.74rem;color:var(--muted);font-weight:600}
.sumcard .arrow{flex:1;text-align:center;color:var(--muted);font-size:.7rem}
.fieldset{margin-bottom:18px}
.fieldset .fl{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-family:"Space Mono"}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.frow.one{grid-template-columns:1fr}
.frm{display:flex;flex-direction:column;gap:5px}
.frm label{font-size:.76rem;color:var(--muted);font-weight:600}
.frm input,.frm select{border:1px solid var(--line);border-radius:10px;padding:10px 11px;font-family:inherit;font-size:.92rem;background:#fff}
.frm input:focus,.frm select:focus{outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(20,29,74,.1)}
.fare{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:16px}
.fare .fr{display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem;color:var(--muted)}
.fare .fr.total{border-top:1px dashed var(--line);margin-top:6px;padding-top:12px;font-size:1.05rem;font-weight:800;color:var(--text)}
.fare .fr.total .mono{font-size:1.15rem}
.fare .pricing-note{font-size:.72rem;color:var(--muted);margin-top:8px}
.drawer-foot{padding:16px 22px;border-top:1px solid var(--line);background:#fff}
.btn-pay{width:100%;border:0;border-radius:13px;background:var(--ink);color:#fff;padding:15px;font-weight:800;font-size:1rem;transition:.15s}
.btn-pay:hover{background:var(--glow);color:#3a1d05}
.note{font-size:.74rem;color:var(--muted);text-align:center;margin-top:10px;line-height:1.5}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(140%);background:var(--ink);color:#fff;padding:14px 20px;border-radius:13px;z-index:90;box-shadow:var(--shadow);transition:transform .3s;max-width:90%;text-align:center;font-size:.92rem}
.toast.show{transform:translateX(-50%) translateY(0)}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:46px 0 30px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr}}
.foot-brand{color:#fff;font-family:"Bricolage Grotesque";font-weight:800;font-size:1.2rem;margin-bottom:8px}
.foot-grid p{font-size:.86rem;line-height:1.6}
.foot-col h4{color:#fff;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-family:"Space Mono";margin-bottom:12px;font-weight:700}
.foot-col a{display:block;color:rgba(255,255,255,.7);text-decoration:none;font-size:.88rem;padding:4px 0}
.foot-col a:hover{color:#fff}
.accred{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:16px}
.accred .badge{border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:8px 13px;font-size:.76rem;color:#fff;display:flex;align-items:center;gap:7px}
.accred .badge .mono{color:var(--horizon-2)}
.foot-legal{border-top:1px solid rgba(255,255,255,.1);margin-top:30px;padding-top:18px;font-size:.78rem;color:rgba(255,255,255,.55)}

@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
.vh{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ============================================================ *
 *  TOURISM SITE — shared components (home, tours, destinations) *
 * ============================================================ */

/* nav active + mobile */
.nav-links a.active{color:#fff}
.nav-links a.active::after{content:"";display:block;height:2px;background:var(--horizon-2);border-radius:2px;margin-top:3px}
.nav-burger{display:none;flex-direction:column;gap:5px;background:transparent;border:0;padding:8px}
.nav-burger span{width:22px;height:2px;background:#fff;border-radius:2px;transition:.2s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-mobile{display:none;flex-direction:column;background:rgba(10,17,51,.97);border-top:1px solid rgba(255,255,255,.08)}
.nav-mobile.open{display:flex}
.nav-mobile a{color:rgba(255,255,255,.85);text-decoration:none;padding:13px 22px;border-bottom:1px solid rgba(255,255,255,.06);font-weight:500}
.nav-mobile a.active{color:var(--horizon-2)}
.nav-mobile-cta{color:var(--horizon-2)!important;font-weight:700!important}
@media(max-width:820px){.nav-burger{display:flex}.nav-phone{display:none}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border:0;border-radius:13px;padding:13px 22px;font-weight:700;font-size:.95rem;text-decoration:none;cursor:pointer;transition:.15s;line-height:1}
.btn svg{width:17px;height:17px}
.btn-primary{background:linear-gradient(100deg,var(--glow),var(--horizon-2));color:#3a1d05;box-shadow:0 12px 26px -12px var(--glow)}
.btn-primary:hover{transform:translateY(-2px);filter:brightness(1.04)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--glow);color:#3a1d05}
.btn-ghost{background:transparent;border:1px solid var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--ink);background:#fff}
.btn-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}
.btn-light:hover{background:rgba(255,255,255,.2)}
.btn-wide{width:100%}

/* section scaffolding */
.section{padding:84px 0}
.section.tight{padding:52px 0}
.section-head{margin-bottom:40px;max-width:660px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{font-family:"Space Mono";font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--horizon);font-weight:700;margin-bottom:10px}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:800}
.section-head p{color:var(--muted);margin-top:10px;font-size:1.02rem}
.section-cloud{background:var(--cloud)}
.section-white{background:#fff}

/* generic page hero (interior pages) */
.page-hero{position:relative;color:#fff;padding:70px 0 56px;overflow:hidden;
  background:radial-gradient(120% 90% at 85% -20%, rgba(255,138,92,.4) 0%, rgba(255,138,92,0) 45%),
    linear-gradient(180deg, rgba(10,17,51,.8) 0%, rgba(20,29,74,.9) 100%),
    url("https://upload.wikimedia.org/wikipedia/commons/thumb/8/8e/Sigiriya_Rock_Fortress_View_from_Pidurangala_Rock.jpg/1600px-Sigiriya_Rock_Fortress_View_from_Pidurangala_Rock.jpg") center/cover no-repeat;}
.page-hero .kicker{color:var(--horizon-2)}
.page-hero h1{font-size:clamp(2rem,4.6vw,3rem);font-weight:800;max-width:18ch}
.page-hero p{color:rgba(255,255,255,.8);max-width:60ch;margin-top:12px}
.crumbs{font-size:.82rem;color:rgba(255,255,255,.6);margin-bottom:16px}
.crumbs a{color:rgba(255,255,255,.8);text-decoration:none}
.crumbs a:hover{color:#fff}

/* home hero extras */
.hero-cta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.hero-stats{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.hero-stats .s b{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.7rem;color:#fff;display:block;line-height:1}
.hero-stats .s span{font-size:.78rem;color:rgba(255,255,255,.7)}

/* rotating image hero (home) */
.hero-carousel{background:#0a1133;padding:104px 0 124px;min-height:600px;display:flex;flex-direction:column;justify-content:center}
.hero-carousel .stars{display:none}
.hero-slides{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slides .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease}
.hero-slides .slide.active{opacity:1;animation:kenburns 8s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.06)}to{transform:scale(1.14)}}
.hero-scrim{position:absolute;inset:0;z-index:1;background:
  radial-gradient(120% 90% at 82% -10%, rgba(255,138,92,.34) 0%, rgba(255,138,92,0) 46%),
  linear-gradient(180deg, rgba(10,17,51,.68) 0%, rgba(10,17,51,.46) 38%, rgba(20,29,74,.9) 100%)}
.hero-carousel .hero-in{position:relative;z-index:2}
.hero-dots{display:flex;gap:9px;margin-top:32px}
.hero-dots .dot{width:9px;height:9px;border-radius:50%;border:0;background:rgba(255,255,255,.42);cursor:pointer;transition:.25s;padding:0}
.hero-dots .dot:hover{background:rgba(255,255,255,.7)}
.hero-dots .dot.active{background:var(--horizon-2);width:28px;border-radius:6px}

/* experience cards */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.exp-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.exp-grid{grid-template-columns:1fr}}
.exp-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;transition:.18s}
.exp-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-3px)}
.exp-card .ic{font-size:1.9rem}
.exp-card h3{font-size:1.1rem;margin:12px 0 8px}
.exp-card p{font-size:.9rem;color:var(--muted)}

/* tour cards */
.tour-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.tour-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.tour-grid{grid-template-columns:1fr}}
.tour-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.18s;text-decoration:none;color:inherit}
.tour-card:hover{border-color:var(--line-strong);box-shadow:var(--shadow);transform:translateY(-4px)}
.tour-media{height:172px;position:relative;display:grid;place-items:center;color:#fff;background-size:cover;background-position:center;background-repeat:no-repeat}
.tour-media .emoji{font-size:3rem;filter:drop-shadow(0 6px 14px rgba(0,0,0,.3))}
.tour-media .ribbon{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.35);backdrop-filter:blur(4px);color:#fff;font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:999px}
.tour-media .dur{position:absolute;bottom:12px;right:12px;background:#fff;color:var(--ink);font-size:.74rem;font-weight:700;padding:5px 10px;border-radius:999px}
.tour-body{padding:16px 18px;display:flex;flex-direction:column;flex:1}
.tour-body h3{font-size:1.12rem;margin-bottom:6px}
.tour-body .route{font-size:.78rem;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tour-body .desc{font-size:.88rem;color:var(--muted);flex:1}
.tour-meta{display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.tour-meta .from{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.tour-meta .price{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.35rem;color:var(--ink);line-height:1}
.tour-meta .price small{font-size:.7rem;color:var(--muted);font-weight:600}
.tour-meta .rating{font-size:.82rem;color:var(--text);font-weight:600}
.tour-meta .rating .star{color:var(--horizon)}

/* filter chips */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.chips button{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:999px;padding:8px 16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:.15s}
.chips button[aria-selected="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}

/* destination tiles */
.dest-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.dest-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.dest-grid{grid-template-columns:1fr}}
.dest-tile{position:relative;border-radius:16px;overflow:hidden;min-height:200px;display:flex;align-items:flex-end;padding:16px;color:#fff;text-decoration:none;transition:.2s;background-size:cover;background-position:center;background-repeat:no-repeat}
.dest-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.dest-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 30%,rgba(0,0,0,.55) 100%)}
.dest-tile .emoji{position:absolute;top:14px;right:16px;font-size:1.8rem;z-index:2;filter:drop-shadow(0 4px 10px rgba(0,0,0,.35))}
.dest-tile .dt-in{position:relative;z-index:2}
.dest-tile .dt-in .n{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.2rem}
.dest-tile .dt-in .t{font-size:.78rem;opacity:.85}

/* split / feature band */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
@media(max-width:820px){.feature{grid-template-columns:1fr;gap:24px}}
.feature .media{border-radius:18px;min-height:320px;display:grid;place-items:center;color:#fff;font-size:4.5rem;background:linear-gradient(135deg,var(--twilight-mid),var(--horizon))}
.feature ul{list-style:none;margin-top:16px;display:grid;gap:10px}
.feature ul li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--text)}
.feature ul li::before{content:"✓";color:var(--ok);font-weight:800}

/* stats band */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
@media(max-width:600px){.stats-band{grid-template-columns:1fr 1fr}}
.stats-band .st b{font-family:"Bricolage Grotesque";font-weight:800;font-size:2.2rem;color:var(--ink);display:block;line-height:1}
.stats-band .st span{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* certificate band */
.cert-band{background:linear-gradient(135deg,var(--ink),var(--ink-2));color:#fff;border-radius:22px;padding:34px;display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center}
@media(max-width:760px){.cert-band{grid-template-columns:1fr;text-align:center}}
.cert-band .seal{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--horizon),var(--horizon-2));display:grid;place-items:center;font-size:2.4rem;margin:0 auto}
.cert-band h3{font-size:1.4rem;margin-bottom:8px}
.cert-band p{color:rgba(255,255,255,.78);font-size:.92rem;max-width:60ch}
.cert-band .num{font-family:"Space Mono";border:1px solid rgba(255,255,255,.25);border-radius:12px;padding:12px 16px;text-align:center;white-space:nowrap}
.cert-band .num span{display:block;font-size:.64rem;letter-spacing:.18em;color:var(--horizon-2)}
.cert-band .num b{font-size:1.1rem}

/* CTA band */
.cta-band{background:
  radial-gradient(100% 120% at 90% 0%, rgba(255,138,92,.5),rgba(255,138,92,0) 50%),
  linear-gradient(135deg,var(--twilight-top),var(--twilight-mid));
  color:#fff;border-radius:24px;padding:46px;text-align:center}
.cta-band h2{font-size:clamp(1.6rem,3.4vw,2.3rem);font-weight:800;max-width:20ch;margin:0 auto}
.cta-band p{color:rgba(255,255,255,.8);margin:12px auto 0;max-width:48ch}
.cta-band .hero-cta{justify-content:center}

/* ---- Tour detail page ---- */
.tour-detail-hero{position:relative;color:#fff;padding:64px 0;overflow:hidden}
.tour-detail-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,17,51,.25),rgba(10,17,51,.78))}
.tour-detail-hero .wrap{position:relative;z-index:2}
.tour-detail-hero .emoji{font-size:3rem}
.tour-detail-hero h1{font-size:clamp(2rem,4.4vw,3rem);font-weight:800;margin:10px 0 8px;max-width:20ch}
.tour-detail-hero .meta-row{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;font-size:.9rem;color:rgba(255,255,255,.85)}
.tour-detail-hero .meta-row b{color:#fff}
.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:30px;align-items:start;margin-top:-40px;position:relative;z-index:5}
@media(max-width:880px){.detail-grid{grid-template-columns:1fr}}
.detail-main{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px}
.detail-main h2{font-size:1.3rem;margin:26px 0 12px}
.detail-main h2:first-child{margin-top:0}
.detail-main p{color:var(--text)}
.tag-row{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}
.tag{background:var(--cloud);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;color:var(--text)}
.hl-list{list-style:none;display:grid;gap:9px;margin-top:6px}
.hl-list li{display:flex;gap:10px;font-size:.94rem}
.hl-list li::before{content:"✦";color:var(--horizon)}
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:560px){.incl-grid{grid-template-columns:1fr}}
.incl-grid h3{font-size:.95rem;margin-bottom:10px}
.incl-grid ul{list-style:none;display:grid;gap:8px}
.incl-grid .yes li,.incl-grid .no li{display:flex;gap:9px;font-size:.9rem;color:var(--muted)}
.incl-grid .yes li::before{content:"✓";color:var(--ok);font-weight:800}
.incl-grid .no li::before{content:"✕";color:#c0506a;font-weight:800}

/* itinerary timeline */
.timeline{position:relative;margin-top:8px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:9px;top:6px;bottom:6px;width:2px;background:var(--line-strong)}
.tl-item{position:relative;padding:0 0 20px}
.tl-item:last-child{padding-bottom:0}
.tl-item .dot{position:absolute;left:-30px;top:1px;width:20px;height:20px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-size:.66rem;font-weight:700;font-family:"Space Mono"}
.tl-item .d-title{font-weight:700;font-size:.98rem;margin-bottom:3px}
.tl-item .d-desc{font-size:.9rem;color:var(--muted)}

/* booking sidebar (sticky) */
.book-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;position:sticky;top:84px;box-shadow:var(--shadow)}
.book-card .pf{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.book-card .pp{font-family:"Bricolage Grotesque";font-weight:800;font-size:2rem;color:var(--ink);line-height:1.1}
.book-card .pp small{font-size:.8rem;color:var(--muted);font-weight:600}
.book-card .rating{margin:6px 0 16px;font-size:.86rem;color:var(--muted)}
.book-card .rating .star{color:var(--horizon)}
.book-card .frm{margin-bottom:12px}
.book-card label{font-size:.74rem;color:var(--muted);font-weight:600;display:block;margin-bottom:5px}
.book-card input,.book-card select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 11px;font-family:inherit;font-size:.92rem;background:#fff}
.book-card input:focus,.book-card select:focus{outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(20,29,74,.1)}
.book-card .est{background:var(--cloud);border-radius:12px;padding:12px 14px;margin:14px 0;font-size:.88rem}
.book-card .est .row{display:flex;justify-content:space-between;padding:3px 0;color:var(--muted)}
.book-card .est .row.tot{border-top:1px dashed var(--line-strong);margin-top:6px;padding-top:8px;color:var(--text);font-weight:800}
.book-card .or{text-align:center;font-size:.76rem;color:var(--muted);margin:12px 0}
.book-help{font-size:.78rem;color:var(--muted);text-align:center;margin-top:12px;line-height:1.5}

/* ---- forms / enquiry ---- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}}
.form-grid .full{grid-column:1/-1}
.frm-field{display:flex;flex-direction:column;gap:6px}
.frm-field label{font-size:.78rem;color:var(--muted);font-weight:600}
.frm-field input,.frm-field select,.frm-field textarea{border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-family:inherit;font-size:.95rem;background:#fff}
.frm-field textarea{resize:vertical;min-height:96px}
.frm-field input:focus,.frm-field select:focus,.frm-field textarea:focus{outline:0;border-color:var(--ink);box-shadow:0 0 0 3px rgba(20,29,74,.1)}

/* contact split */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:start}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.contact-list{display:grid;gap:14px}
.contact-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.contact-item .ic{width:42px;height:42px;border-radius:11px;background:var(--cloud);display:grid;place-items:center;font-size:1.2rem;flex:0 0 auto}
.contact-item .ci .l{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.contact-item .ci a,.contact-item .ci .v{font-weight:600;color:var(--text);text-decoration:none;font-size:.96rem}
.contact-item .ci a:hover{color:var(--glow)}

/* modal */
.modal-scrim{position:fixed;inset:0;background:rgba(10,17,51,.55);backdrop-filter:blur(2px);z-index:80;display:none;align-items:center;justify-content:center;padding:20px}
.modal-scrim.open{display:flex}
.modal{background:var(--cloud);border-radius:20px;max-width:520px;width:100%;max-height:90vh;overflow:auto;box-shadow:var(--shadow)}
.modal-head{padding:18px 22px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0}
.modal-head h3{font-size:1.1rem}
.modal-head .x{background:rgba(255,255,255,.14);border:0;color:#fff;width:34px;height:34px;border-radius:10px;font-size:1.2rem;cursor:pointer}
.modal-body{padding:22px}
.modal-body .ok{text-align:center;padding:16px 0}
.modal-body .ok .big{font-size:3rem}
.modal-body .ok h4{font-size:1.3rem;margin:8px 0}
.modal-body .ok p{color:var(--muted)}
