/* ==========================================================================
   VOIARA — Luxury travel editorial
   A boutique Oman travel brand by RoutXplore
   ========================================================================== */

/* ---------- Reset & base --------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{min-height:100vh;line-height:1.5;font-family:var(--font-body);color:var(--ink);background:var(--ivory);overflow-x:hidden}
img,picture,video{max-width:100%;height:auto;display:block}
input,button,textarea,select{font:inherit;color:inherit;background:none;border:none;outline:none}
button{cursor:pointer;-webkit-appearance:none;appearance:none}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ---------- Design tokens -------------------------------------------------- */
:root{
  /* Palette — warm editorial, desert-inspired */
  --ivory:         #F7F3EC;
  --ivory-soft:    #FAF6EF;
  --ivory-deep:    #EFE7D8;
  --sand:          #E6D9C3;
  --sand-deep:     #CDBC9E;
  --bronze:        #9C7A4E;
  --bronze-deep:   #6B532F;
  --bronze-soft:   #C4A77D;
  --olive:         #4E5C3D;
  --ink:           #1A1612;
  --ink-soft:      #3D3631;
  --ink-muted:     #80766B;
  --ink-ghost:     #B3A99B;
  --obsidian:      #161310;
  --obsidian-2:    #1F1A15;
  --line:          rgba(26,22,18,0.12);
  --line-strong:   rgba(26,22,18,0.24);
  --line-ghost:    rgba(255,247,232,0.14);

  /* Fonts */
  --font-display:  'Fraunces', 'Cormorant Garamond', Georgia, serif;
  --font-body:     'Outfit', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;

  /* Fluid type scale */
  --fs-eyebrow:    clamp(.68rem, .6rem + .3vw, .78rem);
  --fs-body:       clamp(.95rem, .9rem + .2vw, 1.05rem);
  --fs-lead:       clamp(1.15rem, 1rem + .6vw, 1.45rem);
  --fs-h4:         clamp(1.3rem, 1.1rem + .8vw, 1.75rem);
  --fs-h3:         clamp(1.6rem, 1.2rem + 1.6vw, 2.4rem);
  --fs-h2:         clamp(2.2rem, 1.6rem + 2.8vw, 4rem);
  --fs-h1:         clamp(3rem, 2rem + 5.5vw, 7.5rem);
  --fs-display:    clamp(3.5rem, 2rem + 7vw, 9rem);

  /* Spacing (rem-based fluid) */
  --s-1: .25rem;   --s-2: .5rem;   --s-3: .75rem;  --s-4: 1rem;
  --s-5: 1.5rem;   --s-6: 2rem;    --s-7: 3rem;    --s-8: 4rem;
  --s-9: 6rem;     --s-10: 8rem;   --s-11: 10rem;  --s-12: 14rem;

  /* Layout */
  --wrap:     min(1320px, 92vw);
  --wrap-lg:  min(1480px, 94vw);
  --wrap-sm:  min(780px, 90vw);
  --nav-h:    72px;

  /* Motion */
  --ease-out:  cubic-bezier(.22,1,.36,1);
  --ease-in-out: cubic-bezier(.76,0,.24,1);
  --t-fast:  .25s;
  --t-med:   .5s;
  --t-slow:  1s;
}

/* ---------- Typography ----------------------------------------------------- */
body{font-size:var(--fs-body);font-weight:400;letter-spacing:.005em}

.display,h1,h2,h3,h4{font-family:var(--font-display);font-weight:350;line-height:1.04;letter-spacing:-.02em;color:var(--ink)}
h1,.h1{font-size:var(--fs-h1)}
h2,.h2{font-size:var(--fs-h2)}
h3,.h3{font-size:var(--fs-h3);font-weight:400;letter-spacing:-.015em;line-height:1.1}
h4,.h4{font-size:var(--fs-h4);font-weight:400;letter-spacing:-.01em;line-height:1.2}
.display-xl{font-size:var(--fs-display);line-height:.96;letter-spacing:-.035em}

/* Italic serif lift — the "voice" */
em,.serif-italic{font-family:var(--font-display);font-style:italic;font-weight:350;letter-spacing:-.01em}

.eyebrow{
  font-family:var(--font-body);font-size:var(--fs-eyebrow);
  text-transform:uppercase;letter-spacing:.22em;font-weight:500;
  color:var(--ink-muted);line-height:1;
}
.eyebrow-num{
  font-family:var(--font-display);font-style:italic;font-weight:350;
  color:var(--bronze);letter-spacing:0;text-transform:none;
  font-size:1em;margin-right:.6em;
}

.lead{font-size:var(--fs-lead);line-height:1.45;font-weight:300;color:var(--ink-soft);letter-spacing:-.005em}
.meta{font-size:.82rem;color:var(--ink-muted);letter-spacing:.04em}
.small{font-size:.85rem;color:var(--ink-muted)}

p{max-width:60ch}
p + p{margin-top:1em}

/* ---------- Buttons -------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  padding:.95em 1.7em;
  font-family:var(--font-body);font-size:.86rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  border-radius:999px;
  transition:background .35s var(--ease-out),color .35s var(--ease-out),transform .35s var(--ease-out),border-color .35s var(--ease-out);
  will-change:transform;
}
.btn-primary{background:var(--ink);color:var(--ivory)}
.btn-primary:hover{background:var(--bronze);transform:translateY(-1px)}
.btn-ghost{border:1px solid var(--line-strong);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--ivory)}
.btn-light{border:1px solid var(--line-ghost);color:var(--ivory)}
.btn-light:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory)}
.btn-bronze{background:var(--bronze);color:var(--ivory)}
.btn-bronze:hover{background:var(--bronze-deep)}
.btn .arr{display:inline-block;transition:transform .35s var(--ease-out)}
.btn:hover .arr{transform:translateX(4px)}

.link-line{
  display:inline-flex;align-items:center;gap:.7em;
  font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  padding-bottom:.4em;border-bottom:1px solid var(--line-strong);
  transition:border-color .3s,color .3s;
}
.link-line:hover{border-color:var(--bronze);color:var(--bronze)}
.link-line .arr{transition:transform .35s var(--ease-out)}
.link-line:hover .arr{transform:translateX(4px)}

/* ---------- Layout utilities ----------------------------------------------- */
.wrap{width:var(--wrap);margin-inline:auto}
.wrap-lg{width:var(--wrap-lg);margin-inline:auto}
.wrap-sm{width:var(--wrap-sm);margin-inline:auto}
.section{padding-block:clamp(4rem, 6vw, 8rem)}
.section-lg{padding-block:clamp(5rem, 9vw, 11rem)}
.section-sm{padding-block:clamp(2.5rem, 4vw, 4.5rem)}
.hairline{height:1px;background:var(--line);width:100%}
.rule-v{width:1px;background:var(--line);align-self:stretch}

.grid{display:grid;gap:var(--s-5)}
.flex{display:flex;gap:var(--s-4)}
.stack{display:flex;flex-direction:column}
.center{display:grid;place-items:center}

/* ---------- Navigation ---------------------------------------------------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  height:var(--nav-h);
  display:flex;align-items:center;
  padding:0 clamp(1rem, 4vw, 2.5rem);
  background:transparent;
  transition:background .4s var(--ease-out), backdrop-filter .4s var(--ease-out), color .4s var(--ease-out), border-color .4s var(--ease-out);
  color:var(--ivory);
  border-bottom:1px solid transparent;
}
.nav.is-solid{
  background:rgba(247,243,236,0.92);
  backdrop-filter:saturate(1.2) blur(14px);
  -webkit-backdrop-filter:saturate(1.2) blur(14px);
  color:var(--ink);
  border-bottom-color:var(--line);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%}
/* ---------- Brand lockup ------------------------------------------------- */
.brand{display:inline-flex;align-items:center;gap:.7em;line-height:1;color:var(--ink);text-decoration:none}
.brand__mark{width:26px;height:26px;flex-shrink:0;color:var(--bronze);transition:transform .7s var(--ease-out),color .35s}
.brand__mark .ring{stroke:currentColor;fill:none;stroke-width:1}
.brand__mark .v{stroke:currentColor;fill:none;stroke-width:1.1;stroke-linecap:round;stroke-linejoin:round}
.brand__mark .pt{fill:currentColor}
.brand:hover .brand__mark{transform:rotate(-12deg);color:var(--ink)}
.brand__word{font-family:var(--font-display);font-style:italic;font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 100;font-size:1.75rem;letter-spacing:-.01em;color:currentColor;display:inline-block;position:relative;top:-.05em}
.brand__word::first-letter{font-variation-settings:"opsz" 144,"SOFT" 0;font-weight:350}
.brand__caption{display:none;font-family:var(--font-body);font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;color:currentColor;opacity:.55;font-weight:500;margin-top:.55rem}
/* Stacked variant (footer) */
.brand--stack{flex-direction:column;align-items:flex-start;gap:.45em}
.brand--stack .brand__mark{width:34px;height:34px}
.brand--stack .brand__word{font-size:2.4rem}
.brand--stack .brand__caption{display:block}
.brand--stack .brand__caption::before{content:"";display:inline-block;width:22px;height:1px;background:currentColor;opacity:.4;vertical-align:middle;margin-right:.85em}
.nav-links{display:flex;align-items:center;gap:clamp(1rem,2.2vw,2.2rem)}
.nav-links a{font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;opacity:.88;transition:opacity .2s}
.nav-links a:hover,.nav-links a.is-active{opacity:1;color:var(--bronze)}
.nav-cta{padding:.65em 1.2em;border-radius:999px;border:1px solid currentColor;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:background .3s,color .3s,border-color .3s}
.nav-cta:hover{background:var(--bronze);border-color:var(--bronze);color:var(--ivory)}

.burger{display:none;flex-direction:column;gap:5px;padding:10px;border-radius:6px}
.burger span{width:22px;height:1.5px;background:currentColor;transition:transform .3s var(--ease-out),opacity .2s}
.burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (max-width: 920px){
  .nav-links, .nav-cta-wrap{display:none}
  .burger{display:flex}
}

/* Mobile drawer */
.mdrawer{
  position:fixed;inset:0;z-index:79;
  background:var(--ivory);color:var(--ink);
  padding:calc(var(--nav-h) + 2rem) 1.5rem 2rem;
  opacity:0;pointer-events:none;transform:translateY(-10px);
  transition:opacity .35s var(--ease-out),transform .35s var(--ease-out);
  overflow-y:auto;
}
.mdrawer.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}
.mdrawer-links a{display:block;font-family:var(--font-display);font-size:2rem;font-weight:350;letter-spacing:-.015em;padding:.6rem 0;border-bottom:1px solid var(--line)}
.mdrawer-cta{margin-top:1.5rem;display:flex;flex-direction:column;gap:.7rem}
.mdrawer-meta{margin-top:auto;padding-top:2rem;color:var(--ink-muted);font-size:.85rem}

/* ---------- Hero ----------------------------------------------------------- */
.hero{
  position:relative;height:100svh;min-height:640px;max-height:980px;
  overflow:hidden;color:var(--ivory);
  display:flex;align-items:flex-end;
}
.hero-media{position:absolute;inset:0;z-index:1}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.08);animation:kenburns 18s ease-out forwards}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,8,5,0.22) 0%, rgba(10,8,5,0) 28%, rgba(10,8,5,0) 52%, rgba(10,8,5,0.72) 100%),
    linear-gradient(90deg, rgba(10,8,5,0.38) 0%, rgba(10,8,5,0.05) 46%, rgba(10,8,5,0) 70%);
}
@keyframes kenburns{from{transform:scale(1.12)}to{transform:scale(1.0)}}

.hero-inner{position:relative;z-index:2;width:var(--wrap);margin:0 auto;padding-bottom:clamp(3rem,7vw,7rem);padding-top:clamp(6rem,12vw,10rem);display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end}
.hero-copy{max-width:880px}
.hero .eyebrow{color:rgba(247,243,236,.8)}
.hero h1{color:var(--ivory);margin-top:1.4rem;font-weight:300;letter-spacing:-.03em}
.hero h1 em{color:var(--bronze-soft);font-weight:300}
.hero .lead{color:rgba(247,243,236,.82);margin-top:1.4rem;max-width:48ch;font-weight:300}
.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2.2rem}

.hero-meta{display:flex;flex-direction:column;gap:.6rem;align-items:flex-end;padding-bottom:.4rem;opacity:.82}
.hero-meta .meta-label{font-family:var(--font-body);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(247,243,236,.7)}
.hero-meta .meta-val{font-family:var(--font-display);font-style:italic;font-size:1.2rem}

.hero-scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.6rem;color:rgba(247,243,236,.7);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase}
.hero-scroll::after{content:"";width:1px;height:54px;background:linear-gradient(to bottom, rgba(247,243,236,.6), transparent);animation:scroll-line 2.2s ease-in-out infinite}
@keyframes scroll-line{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

@media (max-width: 720px){
  .hero-inner{grid-template-columns:1fr}
  .hero-meta{flex-direction:row;align-self:flex-start;align-items:center;gap:1.2rem}
  .hero-meta .meta-val{font-size:1rem}
}

/* ---------- Section headers ----------------------------------------------- */
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:clamp(2rem,5vw,5rem);align-items:end;margin-bottom:clamp(2rem,5vw,4.5rem)}
.sec-head-title h2{max-width:16ch}
.sec-head-meta{display:flex;flex-direction:column;gap:1rem;align-items:flex-end;text-align:right;max-width:38ch}
.sec-head-meta .lead{max-width:38ch}
@media (max-width: 820px){
  .sec-head{grid-template-columns:1fr}
  .sec-head-meta{align-items:flex-start;text-align:left}
}

/* Feature row "01 / Destinations" */
.sec-tag{display:inline-flex;align-items:center;gap:.8rem;margin-bottom:1.6rem}
.sec-tag::before{content:"";width:28px;height:1px;background:var(--bronze);display:inline-block}

/* ---------- Destination showcase ----------------------------------------- */
.dest-grid{display:grid;grid-template-columns:1.2fr .8fr;grid-template-rows:1fr 1fr;gap:clamp(1rem,2vw,1.6rem)}
@media (max-width: 920px){.dest-grid{grid-template-columns:1fr;grid-template-rows:none}}

.dest-card{position:relative;overflow:hidden;background:var(--ink);color:var(--ivory);border-radius:2px;isolation:isolate;aspect-ratio:4/5;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(1.4rem,2.5vw,2.2rem);cursor:pointer;transform:translateZ(0)}
.dest-card.wide{grid-row:span 2}
.dest-card.tall{aspect-ratio:auto}
.dest-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.2s var(--ease-out),filter .6s var(--ease-out)}
.dest-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg, rgba(10,8,5,0.15) 0%, rgba(10,8,5,0) 40%, rgba(10,8,5,0.75) 100%)}
.dest-card:hover img{transform:scale(1.05)}
.dest-card .dest-eyebrow{font-family:var(--font-body);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;opacity:.8;margin-bottom:.8rem}
.dest-card h3{color:var(--ivory);font-weight:350;font-size:clamp(1.5rem,2.2vw,2.2rem);margin-bottom:.4rem}
.dest-card h3 em{color:var(--bronze-soft)}
.dest-card p{color:rgba(247,243,236,.8);font-size:.95rem;max-width:42ch;font-weight:300}
.dest-card .link-line{margin-top:1.2rem;color:var(--ivory);border-bottom-color:rgba(247,243,236,.3)}
.dest-card .link-line:hover{color:var(--bronze-soft);border-color:var(--bronze-soft)}

/* ---------- Experience / Feature split ----------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split.reverse .split-media{order:2}
@media (max-width: 820px){.split{grid-template-columns:1fr}.split.reverse .split-media{order:0}}

.split-media{position:relative;overflow:hidden;border-radius:2px}
.split-media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease-out)}
.split-media:hover img{transform:scale(1.04)}
.split-media.ratio-tall{aspect-ratio:4/5}
.split-media.ratio-wide{aspect-ratio:5/4}
.split-body{padding-block:clamp(1rem,3vw,3rem)}
.split-body h2{margin-bottom:1.4rem}

/* Floating caption */
.caption-frame{position:absolute;left:-18px;bottom:-18px;background:var(--ivory);padding:1.1rem 1.3rem;font-family:var(--font-display);font-style:italic;font-size:1.05rem;max-width:18rem;color:var(--ink);line-height:1.35;box-shadow:0 14px 40px -18px rgba(26,22,18,.22)}
.caption-frame .small{display:block;font-family:var(--font-body);font-style:normal;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted);margin-top:.6rem}
@media (max-width: 820px){.caption-frame{left:0;bottom:0;position:relative;margin-top:1rem}}

/* ---------- Value pillars -------------------------------------------------- */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:clamp(1.5rem,3vw,3rem);}
.pillar{padding-top:2rem;border-top:1px solid var(--line)}
.pillar .num{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:1.1rem;color:var(--bronze);margin-bottom:1.2rem;display:block}
.pillar h4{margin-bottom:.8rem}
.pillar p{color:var(--ink-soft);font-size:.95rem;font-weight:300;max-width:30ch}

/* ---------- Dark section --------------------------------------------------- */
.dark{background:var(--obsidian);color:var(--ivory)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--ivory)}
.dark .lead{color:rgba(247,243,236,.72)}
.dark .meta,.dark .small,.dark .eyebrow{color:rgba(247,243,236,.55)}
.dark .hairline{background:var(--line-ghost)}
.dark .pillar{border-top-color:var(--line-ghost)}
.dark .pillar p{color:rgba(247,243,236,.65)}
.dark .sec-tag::before{background:var(--bronze-soft)}
.dark .btn-ghost{border-color:var(--line-ghost);color:var(--ivory)}
.dark .btn-ghost:hover{background:var(--ivory);color:var(--ink);border-color:var(--ivory)}

/* ---------- Testimonials --------------------------------------------------- */
.quote{max-width:32ch;font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(1.5rem,2.5vw,2.4rem);line-height:1.3;color:var(--ink)}
.quote::before{content:"“";font-size:1.4em;line-height:0;display:inline-block;transform:translateY(.2em);margin-right:.1em;color:var(--bronze)}
.quote::after{content:"”";font-size:1.4em;line-height:0;display:inline-block;transform:translateY(.2em);color:var(--bronze)}
.quote-meta{margin-top:1.6rem;display:flex;align-items:center;gap:1rem;color:var(--ink-muted);font-size:.85rem;letter-spacing:.08em}
.quote-meta strong{color:var(--ink);font-weight:500;letter-spacing:0}

.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(2.5rem,4vw,4.5rem)}

/* ---------- Marquee / ticker ---------------------------------------------- */
.ticker{overflow:hidden;padding:1.6rem 0;border-block:1px solid var(--line);background:var(--ivory-soft)}
.ticker-track{display:flex;gap:3rem;animation:ticker 32s linear infinite;white-space:nowrap;width:max-content}
.ticker-item{font-family:var(--font-display);font-size:1.6rem;letter-spacing:-.01em;color:var(--ink);display:inline-flex;align-items:center;gap:3rem}
.ticker-item::after{content:"◇";color:var(--bronze);font-size:.7em;opacity:.8}
.ticker-item em{color:var(--bronze)}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ---------- Gallery (masonry editorial) ----------------------------------- */
.mason{columns:3 280px;column-gap:clamp(1rem,1.6vw,1.3rem)}
.mason figure{break-inside:avoid;margin:0 0 clamp(1rem,1.6vw,1.3rem) 0;overflow:hidden;position:relative;border-radius:1px}
.mason figure img{width:100%;height:auto;transition:transform 1s var(--ease-out),filter .4s}
.mason figure:hover img{transform:scale(1.04)}
.mason figcaption{position:absolute;left:0;right:0;bottom:0;padding:1rem;color:var(--ivory);font-family:var(--font-display);font-style:italic;font-size:1rem;background:linear-gradient(to top, rgba(10,8,5,.75), transparent);opacity:0;transform:translateY(6px);transition:.4s var(--ease-out)}
.mason figure:hover figcaption{opacity:1;transform:translateY(0)}

/* ---------- Itinerary / step list ---------------------------------------- */
.steps{display:grid;gap:0}
.step{display:grid;grid-template-columns:120px 1fr auto;gap:2rem;padding:2rem 0;border-top:1px solid var(--line);align-items:baseline}
.step:last-child{border-bottom:1px solid var(--line)}
.step .n{font-family:var(--font-display);font-style:italic;font-size:1.5rem;color:var(--bronze)}
.step h4{margin-bottom:.4rem}
.step p{color:var(--ink-soft);font-size:.95rem;font-weight:300;max-width:58ch}
.step .dur{color:var(--ink-muted);font-size:.85rem;letter-spacing:.08em;white-space:nowrap}
@media (max-width: 720px){.step{grid-template-columns:auto 1fr;gap:1rem}.step .dur{grid-column:2;color:var(--bronze)}}

/* ---------- Tour cards ---------------------------------------------------- */
.tours{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:clamp(1.2rem,2vw,2rem)}
.tour{background:var(--ivory-soft);border:1px solid var(--line);transition:border-color .3s,transform .3s var(--ease-out);display:flex;flex-direction:column}
.tour:hover{border-color:var(--ink);transform:translateY(-3px)}
.tour-media{aspect-ratio:4/3;overflow:hidden}
.tour-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease-out)}
.tour:hover .tour-media img{transform:scale(1.05)}
.tour-body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;gap:.8rem;flex:1}
.tour-meta{display:flex;gap:1rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);font-weight:500}
.tour h4{font-size:1.4rem;letter-spacing:-.015em}
.tour p{font-size:.92rem;color:var(--ink-soft);font-weight:300;flex:1}
.tour-foot{padding-top:1rem;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.tour-foot .from{font-family:var(--font-display);font-style:italic;color:var(--ink);font-size:1rem}
.tour-foot .from span{color:var(--ink-muted);font-size:.75rem;font-style:normal;letter-spacing:.14em;text-transform:uppercase;display:block}

/* ---------- Inquiry / form ------------------------------------------------ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem 1.6rem}
.form-grid .col-span{grid-column:span 2}
@media (max-width: 640px){.form-grid{grid-template-columns:1fr}.form-grid .col-span{grid-column:auto}}
.field{display:flex;flex-direction:column;gap:.45rem}
.field label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:var(--ink-muted)}
.field input,.field select,.field textarea{
  padding:.95rem 1rem;background:transparent;border:0;border-bottom:1px solid var(--line-strong);
  color:var(--ink);font-size:1rem;font-weight:300;transition:border-color .3s;font-family:var(--font-body);
}
.field input:focus,.field select:focus,.field textarea:focus{border-bottom-color:var(--bronze)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-ghost)}
.field textarea{resize:vertical;min-height:7rem}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-muted) 50%),linear-gradient(135deg,var(--ink-muted) 50%,transparent 50%);background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;background-size:5px 5px,5px 5px;background-repeat:no-repeat}

.dark .field input,.dark .field select,.dark .field textarea{color:var(--ivory);border-bottom-color:var(--line-ghost)}
.dark .field input::placeholder,.dark .field textarea::placeholder{color:rgba(247,243,236,.35)}
.dark .field input:focus,.dark .field select:focus,.dark .field textarea:focus{border-bottom-color:var(--bronze-soft)}
.dark .field select{background-image:linear-gradient(45deg,transparent 50%,rgba(247,243,236,.6) 50%),linear-gradient(135deg,rgba(247,243,236,.6) 50%,transparent 50%)}

/* Contact intents */
.intents{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:3rem}
.intent{padding:1.3rem 1.4rem;border:1px solid var(--line);display:flex;flex-direction:column;gap:.3rem;transition:border-color .3s,background .3s;cursor:pointer}
.intent:hover{border-color:var(--ink);background:var(--ivory-soft)}
.intent .intent-lbl{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-muted);font-weight:500}
.intent strong{font-family:var(--font-display);font-weight:400;font-size:1.25rem;color:var(--ink);letter-spacing:-.01em}

/* ---------- FAQ ----------------------------------------------------------- */
.faq-list{border-top:1px solid var(--line)}
.faq{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:baseline;gap:1.5rem;padding:1.6rem 0;cursor:pointer;font-family:var(--font-display);font-weight:400;font-size:clamp(1.1rem,1.6vw,1.4rem);letter-spacing:-.01em;color:var(--ink);transition:color .2s}
.faq-q:hover{color:var(--bronze)}
.faq-q .plus{font-family:var(--font-body);font-size:1.4rem;font-weight:300;color:var(--bronze);transition:transform .3s var(--ease-out);line-height:1;margin-top:.1em}
.faq.is-open .faq-q .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease-out);color:var(--ink-soft);font-weight:300}
.faq-a > div{padding:0 0 1.8rem;max-width:58ch;font-size:.98rem;line-height:1.6}
.faq.is-open .faq-a{max-height:500px}

/* ---------- Footer -------------------------------------------------------- */
.footer{background:var(--obsidian);color:rgba(247,243,236,.7);padding:clamp(4rem,7vw,7rem) 0 2rem}
.footer h4{color:var(--ivory);font-size:1rem;font-family:var(--font-body);font-weight:500;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1.2rem}
.footer a{transition:color .2s}
.footer a:hover{color:var(--bronze-soft)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(1.5rem,3vw,3rem);padding-bottom:4rem;border-bottom:1px solid var(--line-ghost)}
@media (max-width: 820px){.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:span 2}}
@media (max-width: 520px){.footer-top{grid-template-columns:1fr}.footer-brand{grid-column:auto}}
.footer-brand .brand{color:var(--ivory)}
.footer-brand .brand__mark{color:var(--bronze-soft)}
.footer-brand .brand__caption{color:rgba(247,243,236,.55)}
.footer-brand p{max-width:36ch;font-size:.95rem;font-weight:300;color:rgba(247,243,236,.6);margin-top:1.2rem}
.footer-list li{padding:.4rem 0}
.footer-list a{font-size:.95rem;font-weight:300}
.footer-bottom{padding-top:2rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem;letter-spacing:.06em;color:rgba(247,243,236,.45)}
.footer-bottom em{color:var(--bronze-soft);font-style:italic;font-family:var(--font-display);letter-spacing:0}

/* ---------- Floating WhatsApp CTA ---------------------------------------- */
.fab{
  position:fixed;right:clamp(1rem,2vw,1.5rem);bottom:clamp(1rem,2vw,1.5rem);z-index:70;
  width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:var(--ivory);
  display:grid;place-items:center;
  box-shadow:0 20px 50px -15px rgba(26,22,18,.5), 0 0 0 0 rgba(156,122,78,.4);
  transition:transform .3s var(--ease-out),background .3s;
  animation:fab-pulse 2.6s ease-in-out infinite;
}
.fab:hover{background:var(--bronze);transform:scale(1.08);animation:none}
.fab svg{width:24px;height:24px}
@keyframes fab-pulse{
  0%,100%{box-shadow:0 20px 50px -15px rgba(26,22,18,.5), 0 0 0 0 rgba(156,122,78,.45)}
  50%{box-shadow:0 20px 50px -15px rgba(26,22,18,.5), 0 0 0 14px rgba(156,122,78,0)}
}

/* Sticky mobile CTA */
.sticky-mobile{display:none}
@media (max-width: 720px){
  .sticky-mobile{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--ivory);border-top:1px solid var(--line);padding:.7rem;gap:.6rem;backdrop-filter:blur(12px)}
  .sticky-mobile .btn{flex:1;justify-content:center;padding:.85em 1em;font-size:.78rem}
  body{padding-bottom:70px}
  .fab{bottom:82px}
}

/* ---------- Page hero (inner pages) -------------------------------------- */
.page-hero{padding:calc(var(--nav-h) + clamp(4rem,8vw,8rem)) 0 clamp(3rem,5vw,5rem);background:var(--ivory)}
.page-hero .eyebrow-num{display:block;margin-bottom:1.4rem}
.page-hero h1{font-size:clamp(2.6rem, 2rem + 4vw, 6rem);max-width:18ch}
.page-hero h1 em{color:var(--bronze)}
.page-hero .lead{margin-top:1.8rem;max-width:60ch}

.page-hero-media{margin-top:clamp(2rem,4vw,4rem);aspect-ratio:16/7;overflow:hidden;position:relative}
.page-hero-media img{width:100%;height:100%;object-fit:cover}

/* ---------- Scroll reveal ------------------------------------------------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-img{clip-path:inset(0 100% 0 0);transition:clip-path 1.3s var(--ease-out)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
.reveal-up{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.reveal-up.in{opacity:1;transform:translateY(0)}

[data-stagger] > *{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
[data-stagger].in > *{opacity:1;transform:translateY(0)}
[data-stagger].in > *:nth-child(1){transition-delay:0s}
[data-stagger].in > *:nth-child(2){transition-delay:.08s}
[data-stagger].in > *:nth-child(3){transition-delay:.16s}
[data-stagger].in > *:nth-child(4){transition-delay:.24s}
[data-stagger].in > *:nth-child(5){transition-delay:.32s}
[data-stagger].in > *:nth-child(6){transition-delay:.4s}
[data-stagger].in > *:nth-child(7){transition-delay:.48s}

/* ---------- Utility ------------------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.text-center{text-align:center}
.text-bronze{color:var(--bronze)}
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:2rem}.mt-8{margin-top:4rem}
.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:2rem}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .hero-media img{animation:none;transform:scale(1)}
}

/* Print (light-touch) */
@media print{
  .nav,.fab,.sticky-mobile,.footer{display:none!important}
}
