/* =====================================================================
   RoadRiders.pk — Global Stylesheet  (v2 · Light theme + motion)
   Premium travel design system | Mobile-first | Vanilla CSS3
   ===================================================================== */

:root{
  --navy:#0D3B66; --navy-700:#0a3057; --navy-900:#072138;
  --blue:#2F80ED; --blue-600:#1f6fd6; --blue-soft:#e9f2fe;
  --green:#00C48C; --green-600:#00a877; --green-soft:#e2f8f0;
  --orange:#F4A261; --orange-700:#e98e44; --coral:#ff7a59;
  --bg:#ffffff; --bg-alt:#f4f8fc; --surface:#ffffff;
  --ink:#16263a; --muted:#5c6b7e; --line:#e7eef6; --gold:#f6b73c;
  --grad-primary:linear-gradient(135deg,#2F80ED 0%,#00C48C 100%);
  --grad-warm:linear-gradient(135deg,#F4A261 0%,#ff7a59 100%);
  --grad-cool:linear-gradient(135deg,#1f6fd6 0%,#0D3B66 100%);
  --radius:18px; --radius-sm:12px; --radius-lg:26px;
  --shadow-sm:0 4px 14px rgba(13,59,102,.06);
  --shadow:0 14px 36px rgba(13,59,102,.10);
  --shadow-lg:0 28px 64px rgba(13,59,102,.16);
  --ring:0 0 0 4px rgba(47,128,237,.22);
  --maxw:1180px; --gut:clamp(20px,5vw,40px);
  --h-font:"Sora",system-ui,-apple-system,sans-serif;
  --b-font:"Manrope",system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1); --bounce:cubic-bezier(.34,1.56,.64,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--b-font);color:var(--ink);background:var(--bg);line-height:1.65;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4,h5{font-family:var(--h-font);font-weight:700;line-height:1.13;color:var(--navy);letter-spacing:-.015em}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:8px}
::selection{background:var(--green);color:#fff}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(56px,9vw,112px);position:relative}
.section--tight{padding-block:clamp(40px,6vw,64px)}
.bg-surface,.section.bg-surface{background:var(--bg-alt)}
.grid{display:grid;gap:24px}
.center{text-align:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--h-font);font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-600);margin-bottom:14px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--green);border-radius:2px}
.eyebrow.center{justify-content:center}
@keyframes lineGrow{from{width:14px;opacity:.6}to{width:30px;opacity:1}}
.section-head{max-width:680px;margin-bottom:clamp(32px,5vw,54px)}
.section-head.center{margin-inline:auto}
.section-head h2{font-size:clamp(1.8rem,3.8vw,2.7rem)}
.section-head p{color:var(--muted);margin-top:14px;font-size:1.06rem}
.lead{font-size:1.12rem;color:var(--muted)}
.grad-text{background:var(--grad-primary);-webkit-background-clip:text;background-clip:text;color:transparent}
.bg-alt::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(60% 50% at 85% 0%,rgba(0,196,140,.10),transparent 70%),radial-gradient(50% 45% at 5% 100%,rgba(47,128,237,.10),transparent 70%)}
.section>.container{position:relative;z-index:1}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--h-font);font-weight:600;font-size:.95rem;padding:14px 26px;border-radius:999px;position:relative;overflow:hidden;transition:transform .28s var(--bounce),box-shadow .28s var(--ease),background .3s,color .3s,border-color .3s;white-space:nowrap;line-height:1;isolation:isolate}
.btn svg{width:18px;height:18px;flex:none}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;z-index:-1;background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg);transition:left .6s var(--ease)}
.btn:hover::after{left:130%}
.btn:hover{transform:translateY(-3px)}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn--primary{background:var(--grad-warm);color:#3a2410;box-shadow:0 12px 26px rgba(244,162,97,.45)}
.btn--primary:hover{box-shadow:0 18px 36px rgba(255,122,89,.5)}
.btn--wa{background:var(--green);color:#fff;box-shadow:0 12px 26px rgba(0,196,140,.38)}
.btn--wa:hover{background:var(--green-600);box-shadow:0 18px 34px rgba(0,196,140,.5)}
.btn--navy{background:var(--grad-cool);color:#fff;box-shadow:0 12px 26px rgba(13,59,102,.3)}
.btn--navy:hover{box-shadow:0 18px 34px rgba(13,59,102,.42)}
.btn--ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.6);backdrop-filter:blur(8px)}
.btn--ghost:hover{background:rgba(255,255,255,.26)}
.btn--outline{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn--outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-soft)}
.btn--lg{padding:17px 34px;font-size:1.02rem}
.btn--block{width:100%}
.btn--sm{padding:11px 18px;font-size:.85rem}

.tag{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:600;font-family:var(--h-font);padding:6px 12px;border-radius:999px;background:var(--blue-soft);color:var(--blue);letter-spacing:.02em}
.tag--green{background:var(--green-soft);color:var(--green-600)}
.tag--orange{background:#fdeedd;color:#bf6a1e}
.tag--hot{background:#ffe7e0;color:#d6502c}
@keyframes pulseTag{0%,100%{box-shadow:0 0 0 0 rgba(214,80,44,.4)}50%{box-shadow:0 0 0 6px rgba(214,80,44,0)}}
.stars{color:var(--gold);letter-spacing:1px;font-size:.95rem}
.pill-row{display:flex;flex-wrap:wrap;gap:8px}

/* HEADER */
.site-header{position:fixed;inset:0 0 auto 0;z-index:200;background:rgba(255,255,255,.88);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid transparent;transition:box-shadow .3s var(--ease),border-color .3s,background .3s,padding .3s;padding-block:14px}
.site-header.solid{background:rgba(255,255,255,.97);box-shadow:0 8px 28px rgba(13,59,102,.10);border-bottom-color:var(--line);padding-block:10px}
.nav{display:flex;align-items:center;gap:20px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--h-font);font-weight:800;font-size:1.18rem;color:var(--navy);letter-spacing:-.02em;flex:none}
.brand img{width:42px;height:42px;border-radius:12px;background:#fff;padding:3px;box-shadow:0 4px 12px rgba(13,59,102,.14);object-fit:contain;transition:transform .35s var(--ease)}
.brand:hover img{transform:rotate(-5deg) scale(1.05)}
.brand span{font-family:var(--h-font);font-weight:800}
.brand span b{color:var(--green-600);font-weight:800}
.brand span i{color:var(--blue);font-style:normal;font-weight:700}
.nav-links{display:none;align-items:center;gap:2px;margin-inline:auto}
.nav-links a{font-family:var(--h-font);font-weight:500;font-size:.94rem;color:var(--ink);padding:9px 14px;border-radius:10px;position:relative;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;border-radius:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .28s var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--blue)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{display:none;gap:10px;align-items:center}
.menu-toggle{margin-left:auto;display:inline-flex;flex-direction:column;gap:5px;padding:11px;border-radius:12px;background:var(--blue-soft)}
.menu-toggle span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}
@media(min-width:1024px){.nav-links{display:flex}.nav-cta{display:flex}.menu-toggle{display:none}}

.mobile-menu{position:fixed;inset:0;z-index:300;visibility:hidden;pointer-events:none}
.mobile-menu .scrim{position:absolute;inset:0;background:rgba(8,36,63,.55);opacity:0;transition:.35s;backdrop-filter:blur(2px)}
.mobile-panel{position:absolute;top:0;right:0;height:100%;width:min(86%,360px);background:#fff;box-shadow:-20px 0 60px rgba(0,0,0,.25);transform:translateX(100%);transition:transform .42s var(--ease);display:flex;flex-direction:column;padding:22px;overflow-y:auto}
.mobile-menu.open{visibility:visible;pointer-events:auto}
.mobile-menu.open .scrim{opacity:1}
.mobile-menu.open .mobile-panel{transform:translateX(0)}
.mobile-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.mobile-close{font-size:1.7rem;color:var(--navy);width:44px;height:44px;border-radius:12px;background:var(--bg-alt)}
.mobile-panel nav a{display:block;padding:15px 12px;font-family:var(--h-font);font-weight:500;color:var(--ink);border-bottom:1px solid var(--line);transition:.2s}
.mobile-panel nav a:hover,.mobile-panel nav a.active{color:var(--blue);padding-left:18px}
.mobile-cta{margin-top:auto;display:grid;gap:10px;padding-top:20px}

/* HERO (homepage) */
.hero{position:relative;min-height:clamp(560px,92vh,820px);display:flex;align-items:center;color:#fff;overflow:hidden;isolation:isolate;padding-top:74px}
.hero__bg{position:absolute;inset:0;z-index:-2;background-image:url('assets/img/photos/p44.jpg'),linear-gradient(135deg,#1b6db5 0%,#0D3B66 55%,#06223c 100%);background-color:#0d3b66;background-size:cover;background-position:center}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(6,26,46,.80) 0%,rgba(6,26,46,.52) 42%,rgba(6,26,46,.20) 75%,rgba(6,26,46,.06) 100%),linear-gradient(180deg,rgba(6,26,46,.30) 0%,rgba(6,26,46,0) 30%,rgba(6,26,46,.48) 100%)}
.hero__inner{max-width:720px;padding-block:clamp(48px,9vh,90px)}
.hero__eyebrow{display:inline-flex;align-items:center;font-family:var(--h-font);font-weight:600;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#bff0e1;background:rgba(0,196,140,.16);border:1px solid rgba(0,196,140,.4);padding:7px 14px;border-radius:999px;margin-bottom:20px}
.hero h1{color:#fff;font-size:clamp(2.1rem,5.4vw,3.7rem);font-weight:800;line-height:1.08;letter-spacing:-.02em;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.hero h1 span{color:var(--green)}
.hero__sub{margin-top:18px;max-width:600px;font-size:clamp(1.02rem,2vw,1.2rem);color:#eaf2fb;line-height:1.6;text-shadow:0 1px 10px rgba(0,0,0,.3)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero__badges{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:32px;padding-top:24px;border-top:1px solid rgba(255,255,255,.18)}
.hero__badges li{display:inline-flex;align-items:center;gap:8px;font-family:var(--h-font);font-weight:600;font-size:.9rem;color:#eaf2fb}
.hero__badges svg{width:18px;height:18px;color:var(--green);background:rgba(0,196,140,.18);border-radius:50%;padding:3px}
.hero__inner>*{opacity:0;animation:heroIn .8s var(--ease) forwards}
.hero__inner>*:nth-child(1){animation-delay:.05s}
.hero__inner>*:nth-child(2){animation-delay:.16s}
.hero__inner>*:nth-child(3){animation-delay:.27s}
.hero__inner>*:nth-child(4){animation-delay:.38s}
.hero__inner>*:nth-child(5){animation-delay:.49s}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.page-hero{position:relative;color:#fff;padding:clamp(120px,18vh,180px) 0 clamp(50px,7vw,78px);overflow:hidden;isolation:isolate;background:var(--grad-cool)}
.page-hero__bg{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center;animation:slowzoom 26s ease-in-out infinite alternate}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(8,36,63,.86),rgba(13,59,102,.5))}
.page-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.3rem);text-shadow:0 3px 24px rgba(0,0,0,.3);animation:heroIn .8s var(--ease) both}
.page-hero p{color:rgba(255,255,255,.92);margin-top:12px;max-width:620px;font-size:1.1rem;animation:heroIn .8s var(--ease) .12s both}

.crumbs{display:flex;flex-wrap:wrap;gap:8px;font-size:.84rem;margin-bottom:16px;opacity:.94}
.crumbs a:hover{text-decoration:underline}
.crumbs span{opacity:.6}

.scene{background-size:cover;background-position:center;position:relative;background-color:#dfe9f5}

/* CARDS */
.cards{display:grid;gap:26px}
.cards--3{grid-template-columns:1fr}
@media(min-width:640px){.cards--3{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.cards--3{grid-template-columns:repeat(3,1fr)}}
.cards--2{grid-template-columns:1fr}
@media(min-width:760px){.cards--2{grid-template-columns:1fr 1fr}}
.dest-card{position:relative;border-radius:var(--radius);overflow:hidden;min-height:340px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease),box-shadow .45s}
.dest-card .scene{position:absolute;inset:0;transition:transform .7s var(--ease)}
.dest-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,36,63,0) 28%,rgba(8,36,63,.5) 62%,rgba(8,36,63,.9) 100%)}
.dest-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.dest-card:hover .scene{transform:scale(1.1)}
.dest-card__body{position:relative;z-index:2;padding:24px;transition:transform .4s var(--ease)}
.dest-card:hover .dest-card__body{transform:translateY(-4px)}
.dest-card__body h3{color:#fff;font-size:1.4rem}
.dest-card__body p{color:rgba(255,255,255,.88);font-size:.92rem;margin:6px 0 14px}
.dest-card__link{display:inline-flex;align-items:center;gap:7px;font-family:var(--h-font);font-weight:600;font-size:.9rem;color:#5ff0c4}
.dest-card__link svg{width:16px;height:16px;transition:transform .3s var(--bounce)}
.dest-card:hover .dest-card__link svg{transform:translateX(5px)}

.tour-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s;border:1px solid var(--line);position:relative}
.tour-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;z-index:3;background:var(--grad-primary);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.tour-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.tour-card:hover::before{transform:scaleX(1)}
.tour-card__media{position:relative;aspect-ratio:16/10;overflow:hidden}
.tour-card__media .scene{position:absolute;inset:0;transition:transform .7s var(--ease)}
.tour-card:hover .tour-card__media .scene{transform:scale(1.09)}
.tour-card__media .badges{position:absolute;top:12px;left:12px;display:flex;gap:7px;flex-wrap:wrap;z-index:2}
.tour-card__fav{position:absolute;top:12px;right:12px;z-index:2;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);display:grid;place-items:center;color:var(--navy);transition:.25s var(--bounce)}
.tour-card__fav:hover{transform:scale(1.15);color:var(--coral)}
.tour-card__body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.tour-card__meta{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--muted);margin-bottom:8px;gap:8px}
.tour-card__body h3{font-size:1.18rem;line-height:1.25}
.tour-card__feat{display:flex;flex-wrap:wrap;gap:6px 14px;margin:12px 0;font-size:.84rem;color:var(--muted)}
.tour-card__feat span{display:inline-flex;align-items:center;gap:6px}
.tour-card__feat svg{width:15px;height:15px;color:var(--blue)}
.tour-card__foot{margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;padding-top:14px;border-top:1px solid var(--line)}
.price{font-family:var(--h-font);font-weight:700;color:var(--navy);font-size:1.4rem;line-height:1}
.price small{display:block;font-weight:500;font-size:.72rem;color:var(--muted);margin-bottom:3px}
.price s{font-size:.85rem;color:var(--muted);font-weight:500}
.tour-card__btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}
.seats-left{font-size:.78rem;color:#d6502c;font-weight:600}

/* FEATURES */
.feature-grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:600px){.feature-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.feature-grid{grid-template-columns:repeat(3,1fr)}}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;position:relative;overflow:hidden}
.feature::before{content:"";position:absolute;inset:0;opacity:0;transition:.4s;background:radial-gradient(80% 60% at 50% 0%,rgba(47,128,237,.07),transparent)}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.feature:hover::before{opacity:1}
.feature__icon{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:var(--grad-cool);color:#fff;margin-bottom:18px;box-shadow:0 10px 22px rgba(47,128,237,.3);transition:transform .4s var(--bounce)}
.feature:nth-child(3n+2) .feature__icon{background:var(--grad-primary);box-shadow:0 10px 22px rgba(0,196,140,.3)}
.feature:nth-child(3n) .feature__icon{background:var(--grad-warm);color:#fff;box-shadow:0 10px 22px rgba(244,162,97,.35)}
.feature:hover .feature__icon{transform:scale(1.08) rotate(-5deg)}
.feature__icon svg{width:28px;height:28px}
.feature h3{font-size:1.14rem}
.feature p{color:var(--muted);font-size:.94rem;margin-top:8px}

/* TIMELINE */
.timeline{position:relative;display:grid;gap:8px}
.timeline::before{content:"";position:absolute;left:19px;top:8px;bottom:8px;width:2px;background:var(--grad-primary)}
.tl-item{position:relative;display:flex;gap:20px;padding:16px 0;align-items:center}
.tl-dot{width:42px;height:42px;border-radius:50%;background:#fff;border:2px solid var(--blue);display:grid;place-items:center;flex:none;z-index:2;font-family:var(--h-font);font-weight:700;color:var(--navy);font-size:.74rem;line-height:1.05;text-align:center;box-shadow:var(--shadow-sm);transition:.3s var(--bounce)}
.tl-item:hover .tl-dot{transform:scale(1.12);border-color:var(--green);color:var(--green-600)}
.tl-body{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px 18px;flex:1;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;transition:.3s}
.tl-item:hover .tl-body{box-shadow:var(--shadow-sm);transform:translateX(4px)}
.tl-body h4{font-size:1.02rem}
.tl-body .meta{font-size:.84rem;color:var(--muted)}

/* REVIEWS */
.reviews{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:760px){.reviews{grid-template-columns:1fr 1fr}}
@media(min-width:1040px){.reviews{grid-template-columns:repeat(3,1fr)}}
.review{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;transition:.35s var(--ease);position:relative}
.review::before{content:"\201C";position:absolute;top:6px;right:22px;font-family:Georgia,serif;font-size:4rem;color:var(--blue-soft);line-height:1}
.review:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.review p{color:#33455c;font-size:.96rem;position:relative;z-index:1}
.review__head{display:flex;align-items:center;gap:13px;margin-top:auto}
.avatar{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--h-font);font-weight:700;background:var(--grad-cool)}
.review__head b{font-size:.95rem;color:var(--navy);font-family:var(--h-font)}
.review__head small{display:block;color:var(--muted);font-size:.8rem}
.gmark{margin-left:auto;font-size:.74rem;color:var(--muted);display:flex;align-items:center;gap:5px}

/* IG GRID */
.ig-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(min-width:760px){.ig-grid{grid-template-columns:repeat(6,1fr)}}
.ig-grid a{aspect-ratio:1;border-radius:14px;overflow:hidden;position:relative}
.ig-grid .scene{position:absolute;inset:0;transition:transform .55s var(--ease)}
.ig-grid a::after{content:"";position:absolute;inset:0;background:rgba(13,59,102,0);transition:.3s}
.ig-grid a:hover::after{background:rgba(13,59,102,.32)}
.ig-grid a:hover .scene{transform:scale(1.14)}

/* ACCORDION */
.accordion{display:grid;gap:12px}
.acc-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:.3s}
.acc-item.open{box-shadow:var(--shadow-sm);border-color:var(--blue-soft)}
.acc-q{width:100%;text-align:left;padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--h-font);font-weight:600;color:var(--navy);font-size:1.02rem}
.acc-q .ico{flex:none;width:28px;height:28px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-size:1.2rem;transition:transform .35s var(--bounce),background .3s}
.acc-item.open .acc-q .ico{transform:rotate(135deg);background:var(--grad-primary);color:#fff}
.acc-a{max-height:0;overflow:hidden;transition:max-height .42s var(--ease)}
.acc-a p{padding:0 22px 20px;color:var(--muted)}

/* CTA BANNER */
.cta-banner{position:relative;border-radius:var(--radius-lg);overflow:hidden;color:#fff;padding:clamp(42px,7vw,76px);text-align:center;isolation:isolate;box-shadow:var(--shadow)}
.cta-banner .scene{position:absolute;inset:0;z-index:-2;animation:slowzoom 26s ease-in-out infinite alternate}
.cta-banner::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,rgba(8,36,63,.9),rgba(47,128,237,.62))}
.cta-banner h2{color:#fff;font-size:clamp(1.7rem,4vw,2.7rem)}
.cta-banner p{color:rgba(255,255,255,.92);max-width:560px;margin:14px auto 0}
.cta-banner .hero__cta{justify-content:center}

/* FLOATS */
.floats{position:fixed;right:18px;bottom:18px;z-index:250;display:flex;flex-direction:column;gap:12px}
.float-btn{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 12px 28px rgba(0,0,0,.24);transition:transform .28s var(--bounce);position:relative}
.float-btn:hover{transform:scale(1.12)}
.float-btn svg{width:27px;height:27px}
.float-wa{background:#25D366;animation:floatPulse 2.4s ease-in-out infinite}
@keyframes floatPulse{0%,100%{box-shadow:0 12px 28px rgba(0,0,0,.24),0 0 0 0 rgba(37,211,102,.5)}50%{box-shadow:0 12px 28px rgba(0,0,0,.24),0 0 0 12px rgba(37,211,102,0)}}
.float-call{background:var(--blue)}
.float-top{background:var(--navy);opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s}
.float-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.float-wa::after{content:"1";position:absolute;top:-2px;right:-2px;background:var(--orange);color:#3a2410;font-size:.7rem;font-weight:700;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-family:var(--h-font)}

/* TRUST STRIP */
.trust-strip{background:var(--bg-alt);border-block:1px solid var(--line)}
.trust-strip .container{display:flex;flex-wrap:wrap;gap:16px 30px;justify-content:center;padding-block:22px;text-align:center}
.trust-strip span{display:inline-flex;align-items:center;gap:9px;font-size:.9rem;font-weight:600;color:var(--navy)}
.trust-strip svg{width:20px;height:20px;color:var(--green-600)}

/* FORMS */
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--h-font);font-weight:600;font-size:.86rem;color:var(--navy);margin-bottom:7px}
.field .req{color:#d6502c}
.input,select.input,textarea.input{width:100%;padding:14px 15px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.96rem;color:var(--ink);background:#fff;transition:border .2s,box-shadow .2s}
.input:focus{border-color:var(--blue);box-shadow:var(--ring);outline:none}
textarea.input{resize:vertical;min-height:110px}
.field-row{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:640px){.field-row{grid-template-columns:1fr 1fr}}
.hint{font-size:.8rem;color:var(--muted);margin-top:6px}
.err{color:#d6502c;font-size:.8rem;margin-top:6px;display:none}
.field.invalid .input{border-color:#d6502c}
.field.invalid .err{display:block}
.choice{display:flex;align-items:flex-start;gap:11px;font-size:.92rem;color:#33455c;cursor:pointer}
.choice input{margin-top:3px;width:18px;height:18px;accent-color:var(--blue);flex:none}
.card-box{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,4vw,38px);box-shadow:var(--shadow-sm)}
.opt-grid{display:grid;gap:12px;grid-template-columns:1fr}
@media(min-width:560px){.opt-grid{grid-template-columns:1fr 1fr}}
.opt-card{position:relative;border:1.5px solid var(--line);border-radius:14px;padding:16px;cursor:pointer;transition:.25s var(--ease)}
.opt-card input{position:absolute;opacity:0}
.opt-card:hover{border-color:var(--blue);transform:translateY(-2px)}
.opt-card h4{font-size:1rem}
.opt-card p{font-size:.84rem;color:var(--muted);margin-top:3px}
.opt-card:has(input:checked){border-color:var(--blue);background:var(--blue-soft);box-shadow:var(--ring)}
.opt-card__check{position:absolute;top:14px;right:14px;width:22px;height:22px;border-radius:50%;border:2px solid var(--line);display:grid;place-items:center;transition:.2s}
.opt-card:has(input:checked) .opt-card__check{border-color:var(--blue);background:var(--blue);color:#fff}
.opt-card__check svg{width:13px;height:13px}

/* STEPPER */
.stepper{display:flex;justify-content:space-between;position:relative;margin-bottom:30px;max-width:680px}
.stepper::before{content:"";position:absolute;top:18px;left:24px;right:24px;height:2px;background:var(--line);z-index:0}
.step{display:flex;flex-direction:column;align-items:center;gap:8px;z-index:1;flex:1;text-align:center}
.step__num{width:38px;height:38px;border-radius:50%;background:#fff;border:2px solid var(--line);display:grid;place-items:center;font-family:var(--h-font);font-weight:700;color:var(--muted);transition:.35s var(--bounce)}
.step__label{font-size:.74rem;color:var(--muted);font-weight:600;font-family:var(--h-font)}
.step.active .step__num{background:var(--grad-primary);border-color:transparent;color:#fff;box-shadow:var(--ring);transform:scale(1.1)}
.step.done .step__num{background:var(--green);border-color:var(--green);color:#fff}
.step.active .step__label,.step.done .step__label{color:var(--navy)}
.fstep{display:none;animation:fade .45s var(--ease)}
.fstep.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.step-nav{display:flex;justify-content:space-between;gap:12px;margin-top:26px}
.summary{position:sticky;top:90px}
.summary__row{display:flex;justify-content:space-between;padding:9px 0;font-size:.94rem;color:#33455c;gap:10px}
.summary__row.total{border-top:1px dashed var(--line);margin-top:8px;padding-top:14px;font-family:var(--h-font);font-weight:700;color:var(--navy);font-size:1.2rem}
.summary__row .disc{color:var(--green-600)}

/* TOUR DETAIL */
.detail-grid{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:980px){.detail-grid{grid-template-columns:1fr 360px;align-items:start}}
.gallery-hero{display:grid;gap:10px;grid-template-columns:1fr;border-radius:var(--radius);overflow:hidden}
@media(min-width:760px){.gallery-hero{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;height:440px}}
.gallery-hero .g-main{grid-row:1/3;position:relative;border-radius:16px;overflow:hidden;min-height:240px}
.gallery-hero .g-sub{position:relative;border-radius:16px;overflow:hidden;min-height:120px}
.gallery-hero .scene{position:absolute;inset:0;transition:transform .6s var(--ease)}
.gallery-hero .g-main:hover .scene,.gallery-hero .g-sub:hover .scene{transform:scale(1.06)}
.summary-facts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:22px 0}
.fact{background:var(--bg-alt);border:1px solid var(--line);border-radius:14px;padding:14px;transition:.3s}
.fact:hover{border-color:var(--blue);transform:translateY(-2px)}
.fact small{color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em}
.fact b{display:block;font-family:var(--h-font);color:var(--navy);font-size:1.05rem;margin-top:3px}
.detail-block{margin-bottom:38px}
.detail-block h2{font-size:1.55rem;margin-bottom:18px}
.itin-day{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}
.itin-day:last-child{border-bottom:none}
.itin-num{flex:none;width:56px;height:56px;border-radius:15px;background:var(--grad-cool);color:#fff;display:grid;place-items:center;font-family:var(--h-font);font-weight:700;text-align:center;line-height:1.05;font-size:.78rem}
.itin-day h4{font-size:1.05rem}
.itin-day p{color:var(--muted);font-size:.92rem;margin-top:5px}
.inc-list{display:grid;gap:10px}
.inc-list li{display:flex;gap:11px;align-items:flex-start;font-size:.95rem;color:#33455c}
.inc-list svg{width:20px;height:20px;flex:none;margin-top:2px}
.inc-yes svg{color:var(--green-600)}
.inc-no{color:var(--muted)}.inc-no svg{color:#c2502c}
.two-col{display:grid;gap:30px;grid-template-columns:1fr}
@media(min-width:680px){.two-col{grid-template-columns:1fr 1fr}}
.hotel-card,.transport-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;display:flex;flex-direction:column;transition:.35s}
.hotel-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-4px)}
.hotel-card .scene{height:140px}
.hotel-card__b{padding:14px 16px}
.hotel-card__b h4{font-size:1rem}
.hotel-card__b p{font-size:.84rem;color:var(--muted);margin-top:3px}
.packing{display:grid;gap:10px;grid-template-columns:1fr}
@media(min-width:560px){.packing{grid-template-columns:1fr 1fr}}
.pack-item{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px 15px;cursor:pointer;font-size:.92rem;transition:.2s}
.pack-item input{width:19px;height:19px;accent-color:var(--green)}
.pack-item:has(input:checked){background:var(--green-soft);border-color:var(--green)}
.pack-item:has(input:checked) span{text-decoration:line-through;color:var(--muted)}
.book-side{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);position:sticky;top:90px}
.book-side .price{font-size:1.95rem}
.book-side hr{border:none;border-top:1px solid var(--line);margin:16px 0}

/* FILTERS */
.tools-bar{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:26px}
.search-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.search-row .input{flex:1;min-width:200px}
.filters{display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:14px}
@media(min-width:760px){.filters{grid-template-columns:repeat(5,1fr)}}
.filters select{padding:12px;font-size:.88rem}
.results-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.results-meta b{font-family:var(--h-font);color:var(--navy)}
.layout-2{display:grid;gap:30px;grid-template-columns:1fr}
@media(min-width:1024px){.layout-2{grid-template-columns:280px 1fr;align-items:start}}
.sidebar-filter{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:sticky;top:90px}
.sidebar-filter h4{font-size:.92rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:18px 0 10px}
.sidebar-filter h4:first-child{margin-top:0}

/* GALLERY */
.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:30px}
.gf-btn{padding:10px 19px;border-radius:999px;border:1.5px solid var(--line);background:#fff;font-family:var(--h-font);font-weight:500;font-size:.88rem;color:var(--muted);transition:.25s var(--ease)}
.gf-btn.active,.gf-btn:hover{background:var(--grad-cool);color:#fff;border-color:transparent;box-shadow:0 8px 20px rgba(13,59,102,.22)}
.masonry{columns:2;column-gap:14px}
@media(min-width:680px){.masonry{columns:3}}
@media(min-width:1024px){.masonry{columns:4}}
.masonry .m-item{break-inside:avoid;margin-bottom:14px;border-radius:16px;overflow:hidden;position:relative;cursor:pointer}
.masonry .scene{display:block;transition:transform .55s var(--ease)}
.masonry .m-item:hover .scene{transform:scale(1.08)}
.masonry .m-item.tall .scene{height:300px}
.masonry .m-item.short .scene{height:190px}
.masonry .m-item.mid .scene{height:240px}
.masonry .m-item::after{content:"";position:absolute;inset:0;background:rgba(13,59,102,0);transition:.3s}
.masonry .m-item:hover::after{background:rgba(13,59,102,.28)}
.m-item .cap{position:absolute;bottom:0;left:0;right:0;padding:14px;color:#fff;z-index:2;background:linear-gradient(transparent,rgba(8,36,63,.82));font-size:.86rem;font-weight:600;opacity:0;transform:translateY(8px);transition:.3s}
.m-item:hover .cap{opacity:1;transform:translateY(0)}

/* BLOG */
.blog-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.blog-card .scene{height:210px;position:relative;transition:transform .6s var(--ease)}
.blog-card:hover .scene{transform:scale(1.05)}
.blog-card .scene .tag{position:absolute;top:14px;left:14px}
.blog-card__b{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-card__b .meta{font-size:.8rem;color:var(--muted);margin-bottom:8px}
.blog-card__b h3{font-size:1.18rem;line-height:1.3}
.blog-card__b p{color:var(--muted);font-size:.92rem;margin-top:8px}
.blog-card__b a{margin-top:auto;padding-top:14px;color:var(--blue);font-weight:600;font-family:var(--h-font);font-size:.9rem}
.article{max-width:760px;margin-inline:auto}
.article p{margin:0 0 18px;color:#33455c;font-size:1.06rem}
.article h2{font-size:1.5rem;margin:34px 0 14px}
.article h3{font-size:1.2rem;margin:26px 0 12px}
.article ul{list-style:disc;padding-left:22px;margin:0 0 18px;color:#33455c}
.article ul li{margin-bottom:8px}
.article blockquote{border-left:4px solid var(--green);padding:8px 20px;margin:24px 0;background:var(--green-soft);border-radius:0 12px 12px 0;color:var(--navy);font-style:italic}
.article figure .scene{height:340px;border-radius:var(--radius)}
.article figcaption{text-align:center;color:var(--muted);font-size:.84rem;margin-top:8px}

/* ABOUT/STATS */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{text-align:center;padding:28px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);transition:.35s}
.stat:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.stat b{display:block;font-family:var(--h-font);font-size:clamp(1.9rem,4vw,2.8rem);background:var(--grad-primary);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat span{color:var(--muted);font-size:.9rem}
.split{display:grid;gap:40px;grid-template-columns:1fr;align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}}
.split--rev>*:first-child{order:2}
.split .scene{height:clamp(280px,40vw,440px);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.value-list{display:grid;gap:16px;margin-top:20px}
.value-list li{display:flex;gap:14px;align-items:flex-start}
.value-list .vi{flex:none;width:44px;height:44px;border-radius:13px;background:var(--green-soft);color:var(--green-600);display:grid;place-items:center;transition:.3s var(--bounce)}
.value-list li:hover .vi{transform:scale(1.1) rotate(-5deg)}
.value-list .vi svg{width:22px;height:22px}
.value-list h4{font-size:1.04rem}
.value-list p{color:var(--muted);font-size:.9rem;margin-top:2px}
.team-grid{display:grid;gap:22px;grid-template-columns:1fr}
@media(min-width:600px){.team-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.team-grid{grid-template-columns:repeat(4,1fr)}}
.team-card{text-align:center}
.team-card .scene{height:230px;border-radius:var(--radius);margin-bottom:14px;transition:.4s}
.team-card:hover .scene{transform:translateY(-5px);box-shadow:var(--shadow)}
.team-card h4{font-size:1.05rem}
.team-card span{color:var(--green-600);font-size:.86rem;font-weight:600}

/* CONTACT */
.contact-cards{display:grid;gap:18px;grid-template-columns:1fr}
@media(min-width:600px){.contact-cards{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.contact-cards{grid-template-columns:repeat(4,1fr)}}
.contact-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px 22px;text-align:center;transition:.35s var(--ease)}
.contact-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.contact-card .ci{width:56px;height:56px;border-radius:16px;margin:0 auto 14px;display:grid;place-items:center;color:#fff;transition:.35s var(--bounce)}
.contact-card:hover .ci{transform:scale(1.08) rotate(-5deg)}
.contact-card .ci svg{width:27px;height:27px}
.contact-card h4{font-size:1.06rem}
.contact-card p{color:var(--muted);font-size:.9rem;margin-top:6px;word-break:break-word}
.map-embed{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);position:relative;min-height:320px;background:linear-gradient(135deg,#e2edf8,#cfe0f1);display:grid;place-items:center}
.map-embed .pin{text-align:center;color:var(--navy)}
.map-embed .pin svg{width:46px;height:46px;color:var(--blue);animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* SUCCESS */
.success-wrap{max-width:640px;margin-inline:auto;text-align:center}
.success-check{width:100px;height:100px;border-radius:50%;background:var(--green-soft);color:var(--green-600);display:grid;place-items:center;margin:0 auto 24px;animation:pop .6s var(--bounce)}
.success-check svg{width:54px;height:54px}
@keyframes pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
.ref-box{background:var(--surface);border:2px dashed var(--blue);border-radius:var(--radius);padding:22px;margin:24px 0;display:inline-block}
.ref-box small{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em}
.ref-box b{display:block;font-family:var(--h-font);font-size:1.85rem;color:var(--navy);letter-spacing:.05em;margin-top:4px}

/* FOOTER */
.site-footer{background:var(--navy);color:#cdd9e8;margin-top:0;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:-40%;right:-10%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(0,196,140,.16),transparent 70%);pointer-events:none}
.footer-cta{background:var(--grad-primary);color:#fff;text-align:center;padding:clamp(36px,5vw,54px) 0;position:relative}
.footer-cta h3{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem)}
.footer-cta p{opacity:.94;margin:8px 0 20px}
.footer-main{padding:clamp(48px,7vw,74px) 0 0;position:relative;z-index:1}
.footer-grid{display:grid;gap:34px;grid-template-columns:1fr}
@media(min-width:680px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
@media(min-width:980px){.footer-grid{grid-template-columns:1.6fr 1fr 1fr 1.2fr}}
.footer-brand .brand{color:#fff;margin-bottom:14px}
.footer-brand p{font-size:.92rem;opacity:.82;max-width:300px}
.footer-col h5{color:#fff;font-family:var(--h-font);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.footer-col a,.footer-col li{display:block;font-size:.92rem;padding:6px 0;opacity:.84;transition:.2s}
.footer-col a:hover{opacity:1;color:#5ff0c4;transform:translateX(4px)}
.footer-col .ic{display:inline-flex;align-items:center;gap:9px}
.footer-col svg{width:16px;height:16px;color:#5ff0c4;flex:none}
.socials{display:flex;gap:12px;margin-top:16px}
.socials a{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;transition:.28s var(--bounce)}
.socials a:hover{background:var(--green);transform:translateY(-4px) rotate(-6deg)}
.socials svg{width:20px;height:20px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:44px;padding:22px 0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:.84rem;opacity:.74}
.footer-bottom a:hover{color:#5ff0c4}

/* REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}.hero__inner>*{opacity:1}}

/* utilities */
.mt-s{margin-top:14px}.mt-m{margin-top:26px}.mt-l{margin-top:44px}
.muted{color:var(--muted)}
.text-c{text-align:center}
.flex-btns{display:flex;flex-wrap:wrap;gap:12px}
.divider{height:1px;background:var(--line);border:none;margin:0}
.note{background:var(--blue-soft);border-left:4px solid var(--blue);border-radius:0 12px 12px 0;padding:14px 18px;color:var(--navy);font-size:.92rem}
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(20px);z-index:400;background:var(--navy);color:#fff;padding:14px 22px;border-radius:14px;box-shadow:var(--shadow-lg);font-size:.92rem;opacity:0;visibility:hidden;transition:.35s var(--ease);max-width:90vw}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

/* MOBILE REFINEMENTS */
@media(max-width:600px){
  .hero{min-height:86vh}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
  .hero__trust{gap:8px}
  .hero__trust span{font-size:.84rem;padding:7px 12px}
  .btn{padding:14px 22px}
  .section-head p{font-size:1rem}
  .trust-strip .container{gap:12px 20px}
  .trust-strip span{font-size:.82rem}
  .footer-bottom{flex-direction:column;text-align:center}
  .stepper{margin-bottom:24px}
  .step__label{font-size:.66rem}
  .detail-grid{gap:24px}
  .floats{right:14px;bottom:14px}
  .float-btn{width:52px;height:52px}
}
@media(max-width:380px){.step__label{display:none}.brand span{font-size:1.05rem}}
