:root{
  --bg:#0F1A2E;--surface:#1B2D45;--surface-2:#243B5C;--ink:#E8EDF3;--ink-soft:#8B9BB0;
  --accent:#D4A853;--accent-2:#5B9279;--line:rgba(232,237,243,.12);--line-strong:rgba(232,237,243,.22);
  --header-h:72px;--max-w:1080px;--pad:clamp(1.5rem,4vw,3rem);
  --radius:8px;--radius-lg:14px;
  --font-heading:'DM Serif Display','Cambria','Georgia',serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1);--ease-out:cubic-bezier(.4,0,.2,1);
  interpolate-size:allow-keywords;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{overflow-x:hidden;max-width:100vw;margin:0}
body{
  font-family:var(--font-body);font-size:clamp(15px,1vw + 12px,17px);
  font-weight:400;letter-spacing:-.01em;line-height:1.65;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color 240ms var(--ease-out)}
a:hover{color:var(--ink)}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit}

/* Skip link */
.skip-link{
  position:fixed;top:-100%;left:16px;background:var(--accent);color:var(--bg);
  padding:8px 18px;border-radius:var(--radius);font-weight:600;font-size:14px;
  z-index:9999;transition:top 200ms;
}
.skip-link:focus{top:12px}

/* Focus ring */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

/* Typography */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-heading);font-weight:700;line-height:1.15;
  letter-spacing:-.012em;color:var(--ink);
}
h1{font-size:clamp(2.25rem,5vw,4.5rem)}
h2{font-size:clamp(1.8rem,4vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.8rem)}
h4{font-size:clamp(1.1rem,1.8vw,1.35rem)}
.eyebrow{
  font-family:var(--font-body);font-size:clamp(11px,1.2vw,13px);font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
  margin-bottom:12px;display:inline-block;
}
.section-sub{color:var(--ink-soft);max-width:560px;margin:12px auto 0}

/* Layout */
.container{
  max-width:var(--max-w);margin:0 auto;
  padding-left:clamp(16px,4vw,32px);padding-right:clamp(16px,4vw,32px);
}
main{padding-top:var(--header-h)}
section{padding:clamp(3rem,8vw,6rem) 0;position:relative}
section[id]{scroll-margin-top:var(--header-h)}
.section-header{text-align:center;margin-bottom:clamp(2rem,5vw,3.5rem)}

/* ============ HEADER ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1080;
  background:rgba(15,26,46,.85);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  transition:background 240ms ease,box-shadow 240ms ease,padding 240ms ease;
  padding:0 clamp(16px,4vw,32px);
}
.site-header.scrolled{
  background:rgba(15,26,46,.98);
  box-shadow:0 8px 24px -16px rgba(0,0,0,.35);
}
.header-inner{
  max-width:var(--max-w);margin:0 auto;display:flex;
  align-items:center;justify-content:space-between;height:var(--header-h);
  transition:height 240ms ease;
}
.site-header.scrolled .header-inner{height:calc(var(--header-h) - 10px)}

/* Scroll progress */
.scroll-progress{
  position:absolute;bottom:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:none;z-index:1;pointer-events:none;
}
.logo{
  font-family:var(--font-heading);font-size:clamp(18px,2vw,22px);
  color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:10px;
  white-space:nowrap;
}
.logo:hover{color:var(--accent)}
.logo svg{width:28px;height:28px;flex-shrink:0}

/* Desktop nav */
.nav-desktop{display:none;align-items:center;gap:clamp(18px,2.5vw,32px)}
@media(min-width:1024px){.nav-desktop{display:flex}}
.nav-desktop a{
  font-size:14px;font-weight:500;color:var(--ink-soft);
  text-decoration:none;position:relative;padding:4px 0;
  transition:color 240ms var(--ease-out);
}
.nav-desktop a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;
  background:var(--accent);transition:width 280ms var(--ease);
}
.nav-desktop a:hover{color:var(--ink)}
.nav-desktop a:hover::after{width:100%}
.nav-desktop a.is-active{color:var(--accent)}
.nav-desktop a.is-active::after{width:100%}
.nav-desktop .nav-cta{
  background:var(--accent);color:var(--bg);padding:8px 20px;
  border-radius:var(--radius);font-weight:600;font-size:13px;
  letter-spacing:.04em;text-transform:uppercase;
  transition:background 240ms var(--ease-out),color 240ms var(--ease-out),transform 180ms var(--ease);
}
.nav-desktop .nav-cta::after{display:none}
.nav-desktop .nav-cta:hover{background:var(--ink);color:var(--bg);transform:translateY(-2px)}
.nav-desktop .nav-cta.is-active{background:var(--accent);color:var(--bg)}

/* Hamburger */
.nav-toggle{
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  width:48px;height:48px;z-index:1100;position:relative;cursor:pointer;
  background:none;border:none;padding:0;touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;border-radius:var(--radius);
  transition:background 200ms var(--ease-out);
}
.nav-toggle:hover{background:rgba(232,237,243,.08)}
.nav-toggle:active{background:rgba(232,237,243,.12)}
@media(min-width:1024px){.nav-toggle{display:none}}
.nav-toggle span{
  display:block;width:24px;height:2px;background:var(--ink);
  border-radius:2px;transition:transform 320ms var(--ease),opacity 240ms;
  position:absolute;pointer-events:none;
}
.nav-toggle span:nth-child(1){transform:translateY(-7px)}
.nav-toggle span:nth-child(3){transform:translateY(7px)}
.nav-toggle.is-open span:nth-child(1){transform:rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:rotate(-45deg)}

/* Mobile drawer */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1040;
  opacity:0;pointer-events:none;transition:opacity 240ms var(--ease-out);
}
.drawer-backdrop.is-open{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(360px,92vw);
  background:var(--surface);z-index:1050;
  transform:translateX(100%);transition:transform 320ms var(--ease);
  padding:calc(var(--header-h) + 24px) 32px 32px;
  display:flex;flex-direction:column;gap:8px;
  overflow-y:auto;
}
.drawer.is-open{transform:translateX(0)}
.drawer a{
  font-size:18px;font-weight:500;color:var(--ink-soft);
  padding:14px 0;border-bottom:1px solid var(--line);
  display:block;transition:color 240ms var(--ease-out),padding-left 240ms var(--ease),
    background 200ms;border-radius:var(--radius);padding-left:8px;padding-right:8px;
}
.drawer a:hover,.drawer a:active{color:var(--accent);padding-left:16px;background:rgba(212,168,83,.04)}
.drawer a.is-active{color:var(--accent)}
.drawer .drawer-cta{
  margin-top:16px;background:var(--accent);color:var(--bg);
  padding:14px 24px;border-radius:var(--radius);text-align:center;
  font-weight:600;border:none;
  transition:background 240ms var(--ease-out),color 240ms var(--ease-out);
}
.drawer .drawer-cta:hover{background:var(--ink);color:var(--bg)}

/* Drawer close button */
.drawer-close{
  position:absolute;top:16px;right:16px;width:44px;height:44px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;color:var(--ink-soft);background:rgba(232,237,243,.08);
  border:none;border-radius:var(--radius);cursor:pointer;z-index:2;
  transition:color 200ms var(--ease-out),background 200ms var(--ease-out);
}
.drawer-close:hover{color:var(--ink);background:rgba(232,237,243,.14)}

/* Drawer scroll lock */
html.drawer-is-open,html.drawer-is-open body{overflow:hidden}
html.drawer-is-open body{touch-action:none}

/* ============ HERO ============ */
.hero{
  min-height:min(calc(100vh - var(--header-h)),56rem);display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:clamp(4rem,12vw,8rem) 0 clamp(3rem,8vw,5rem);
}
.hero-topo{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  overflow:hidden;
  background:radial-gradient(ellipse 80% 60% at 50% 80%,rgba(91,146,121,.06),transparent);
}
.hero-topo svg{
  width:100%;height:100%;opacity:.25;
}
.topo-line{
  stroke-dasharray:2000;stroke-dashoffset:2000;
  animation:contour-draw 3.5s cubic-bezier(.22,.68,.36,1) forwards;
}
.topo-line:nth-child(2){animation-delay:.3s}
.topo-line:nth-child(3){animation-delay:.6s}
.topo-line:nth-child(4){animation-delay:.9s}
.topo-line:nth-child(5){animation-delay:1.2s}
.topo-line:nth-child(6){animation-delay:1.5s}
.topo-line:nth-child(7){animation-delay:1.8s}
.topo-line:nth-child(8){animation-delay:2.1s}
@keyframes contour-draw{to{stroke-dashoffset:0}}

.hero-content{position:relative;z-index:1;text-align:center;width:100%}
.hero h1{
  font-size:clamp(2.25rem,5vw,4.5rem);line-height:1.05;
  margin-bottom:clamp(16px,3vw,28px);
  color:var(--ink);
  background:linear-gradient(135deg,var(--ink) 60%,var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-sub{
  font-size:clamp(16px,1.8vw,20px);color:var(--ink-soft);
  max-width:620px;margin:0 auto clamp(24px,4vw,40px);line-height:1.6;
}
.hero-km{
  display:flex;align-items:baseline;justify-content:center;
  gap:8px;margin-bottom:clamp(20px,4vw,36px);
}
.hero-km .km-number{
  font-family:var(--font-heading);font-size:clamp(3rem,6vw,5rem);
  color:var(--accent);line-height:1;
}
.hero-km .km-label{
  font-size:clamp(14px,1.4vw,18px);color:var(--ink-soft);
  font-weight:500;letter-spacing:.04em;
}

/* Trust strip */
.trust-strip{
  padding:clamp(1.5rem,3vw,2.5rem) 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--surface);
}
.trust-items{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:clamp(16px,3vw,32px);
}
.trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:clamp(12px,1.2vw,14px);font-weight:500;
  color:var(--ink-soft);white-space:nowrap;
}
.trust-item svg{width:20px;height:20px;color:var(--accent);flex-shrink:0}

/* ============ BUTTONS ============ */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:var(--bg);
  padding:14px 32px;border-radius:var(--radius);
  font-weight:600;font-size:15px;letter-spacing:.02em;
  transition:background 240ms var(--ease-out),color 240ms var(--ease-out),transform 180ms var(--ease),box-shadow 240ms;
  border:none;cursor:pointer;
}
.btn-primary:hover,.btn-primary:focus-visible{
  background:var(--ink);color:var(--bg);
  transform:translateY(-2px);
  box-shadow:0 8px 24px -8px rgba(212,168,83,.3);
}
.btn-primary::after{
  content:'→';font-size:18px;transition:transform 200ms var(--ease);
}
.btn-primary:hover::after{transform:translateX(4px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--ink);
  padding:14px 32px;border-radius:var(--radius);
  border:1px solid var(--line-strong);
  font-weight:600;font-size:15px;
  transition:background 240ms var(--ease-out),color 240ms var(--ease-out),border-color 240ms,transform 180ms var(--ease);
  cursor:pointer;
}
.btn-ghost:hover,.btn-ghost:focus-visible{
  background:var(--surface);color:var(--ink);
  border-color:var(--accent);transform:translateY(-2px);
}

/* ============ TOPO SEPARATOR ============ */
.topo-sep{
  display:block;width:100%;height:60px;margin:0;padding:0;
  overflow:visible;pointer-events:none;
}
.topo-sep path{fill:none;stroke:var(--line-strong);stroke-width:1}
.topo-sep path:nth-child(2){stroke:var(--line);stroke-dasharray:6 4}

/* Compass motif */
.compass-motif{
  position:absolute;width:48px;height:48px;opacity:.12;
  animation:compass-drift 20s linear infinite;pointer-events:none;
}
.compass-tl{top:24px;left:24px}
.compass-br{bottom:24px;right:24px;animation-direction:reverse}
@keyframes compass-drift{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ============ TIMELINE / EXPEDICIONES ============ */
.timeline-section{background:var(--surface)}
.timeline-wrap{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  position:relative;
}
.timeline-wrap::before{
  content:'';position:absolute;top:40px;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--accent),var(--accent-2),transparent);
  z-index:0;
}
.timeline-card{
  position:relative;z-index:1;overflow:hidden;
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(20px,3vw,28px);
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease);
}
.timeline-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px -12px rgba(212,168,83,.22),0 0 24px -6px rgba(212,168,83,.08);
  border-color:rgba(212,168,83,.3);
}
.timeline-dot{
  width:16px;height:16px;border-radius:50%;
  background:var(--accent);border:3px solid var(--bg);
  margin:0 auto 20px;position:relative;z-index:2;
  box-shadow:0 0 0 3px var(--accent);
}
.timeline-days{
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);margin-bottom:8px;display:block;
}
.timeline-card h3{margin-bottom:8px}
.timeline-difficulty{
  font-size:13px;color:var(--ink-soft);margin-bottom:14px;
  display:flex;align-items:center;gap:6px;
}
.timeline-difficulty svg{width:16px;height:16px;color:var(--accent-2)}
.timeline-highlights{margin-bottom:18px}
.timeline-highlights li{
  font-size:13px;color:var(--ink-soft);padding:4px 0;
  padding-left:18px;position:relative;
}
.timeline-highlights li::before{
  content:'';position:absolute;left:0;top:10px;
  width:6px;height:6px;border-radius:50%;background:var(--accent-2);
}
.timeline-price{
  font-family:var(--font-heading);font-size:clamp(1.2rem,2vw,1.5rem);
  color:var(--accent);border-top:1px solid var(--line);
  padding-top:14px;margin-top:4px;
}
.timeline-price small{font-family:var(--font-body);font-size:12px;color:var(--ink-soft);font-weight:400}
.price-disclaimer{
  text-align:center;margin-top:24px;font-size:13px;color:var(--ink-soft);
  font-style:italic;
}

@media(max-width:1024px){
  .timeline-wrap{grid-template-columns:repeat(2,1fr)}
  .timeline-wrap::before{display:none}
}
@media(max-width:640px){
  .timeline-wrap{grid-template-columns:1fr}
}

/* ============ TEAM ============ */
.team-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:clamp(24px,4vw,40px);
}
.team-card{
  display:grid;grid-template-columns:100px 1fr;gap:20px;
  align-items:start;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(20px,3vw,28px);
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease);
}
.team-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px -8px rgba(91,146,121,.18),0 0 20px -6px rgba(91,146,121,.08);
  border-color:rgba(91,146,121,.3);
}
.team-photo{
  width:100px;height:100px;border-radius:50%;
  background:var(--surface-2);border:3px solid var(--accent);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  flex-shrink:0;
}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-photo svg{width:40px;height:40px;color:var(--ink-soft)}
.team-info h3{margin-bottom:4px;font-size:clamp(1.1rem,1.6vw,1.3rem)}
.team-role{
  font-size:13px;color:var(--accent);font-weight:600;
  letter-spacing:.04em;margin-bottom:10px;display:block;
}
.team-bio{font-size:14px;color:var(--ink-soft);line-height:1.6}

@media(max-width:768px){
  .team-grid{grid-template-columns:1fr}
  .team-card{grid-template-columns:80px 1fr;gap:16px}
  .team-photo{width:80px;height:80px}
}

/* ============ TESTIMONIALS ============ */
.testimonials-section{background:var(--surface)}
.testimonials-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px);
}
.testimonial-card{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,32px);position:relative;
}
.testimonial-card::before{
  content:'\201C';font-family:var(--font-heading);font-size:4rem;
  color:var(--accent);opacity:.3;position:absolute;top:12px;left:20px;line-height:1;
}
.testimonial-card:first-child{grid-row:span 2}
.testimonial-text{
  font-size:15px;line-height:1.7;color:var(--ink);
  margin-bottom:18px;padding-top:12px;
  font-style:italic;
}
.testimonial-author{
  font-size:13px;color:var(--accent);font-weight:600;
}
.testimonial-meta{font-size:12px;color:var(--ink-soft);margin-top:2px}

@media(max-width:768px){
  .testimonials-grid{grid-template-columns:1fr}
  .testimonial-card:first-child{grid-row:auto}
}

/* ============ CHECKLIST ============ */
.checklist-cats{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.checklist-cat{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(18px,2.5vw,24px);
  transition:transform 280ms var(--ease),border-color 280ms var(--ease),box-shadow 280ms var(--ease);
}
.checklist-cat:hover{
  transform:translateY(-3px);border-color:rgba(91,146,121,.25);
  box-shadow:0 8px 24px -8px rgba(91,146,121,.12);
}
.checklist-cat h4{
  display:flex;align-items:center;gap:10px;
  margin-bottom:14px;font-size:1rem;
}
.checklist-cat h4 svg{width:22px;height:22px;color:var(--accent)}
.checklist-item{
  display:flex;align-items:flex-start;gap:10px;
  padding:6px 0;font-size:14px;color:var(--ink-soft);
}
.field input[type="checkbox"],
.checklist-item input[type="checkbox"],
.field-check input[type="checkbox"]{
  appearance:auto;-webkit-appearance:auto;
  width:18px;height:18px;min-width:18px;min-height:18px;
  padding:0;border:0;margin:2px 0 0;
  accent-color:var(--accent);cursor:pointer;
}
.checklist-item label{cursor:pointer;user-select:none;line-height:1.4}

/* ============ BOOKING / RESERVA ============ */
.reserva-section{background:var(--surface)}
.reserva-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,48px);
  align-items:start;
}
.reserva-info h2{margin-bottom:16px}
.reserva-info p{color:var(--ink-soft);margin-bottom:14px}
.reserva-info .stat-row{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:24px;
}
.stat-box{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;text-align:center;
}
.stat-box .stat-num{
  font-family:var(--font-heading);font-size:clamp(1.4rem,2.5vw,2rem);
  color:var(--accent);display:block;line-height:1.2;
}
.stat-box .stat-label{font-size:12px;color:var(--ink-soft);margin-top:4px}

@media(max-width:768px){
  .reserva-grid{grid-template-columns:1fr}
}

/* ============ FORM ============ */
.form-card{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,4vw,36px);
}
.form-grid{display:grid;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:640px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;font-weight:600;color:var(--ink-soft);letter-spacing:.02em}
.field input:not([type="checkbox"]),.field textarea,.field select{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:12px 16px;color:var(--ink);font-size:15px;
  transition:border-color 240ms var(--ease-out),box-shadow 240ms;
  width:100%;
}
.field input:not([type="checkbox"]):focus,.field textarea:focus,.field select:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(212,168,83,.15);outline:none;
}
.field textarea{min-height:120px;resize:vertical}
.field select{cursor:pointer}
.field-check{
  display:flex;align-items:flex-start;gap:10px;
  font-size:13px;color:var(--ink-soft);line-height:1.5;
}
.field-check a{text-decoration:underline}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.form-status{
  padding:14px 18px;border-radius:var(--radius);font-size:14px;
  margin-top:12px;display:none;
}
.form-status.is-success{display:block;background:rgba(91,146,121,.15);color:var(--accent-2);border:1px solid rgba(91,146,121,.3)}
.form-status.is-error{display:block;background:rgba(200,60,60,.12);color:#e8655a;border:1px solid rgba(200,60,60,.2)}

/* ============ FAQ ============ */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-item summary{
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.5vw,22px) 0;
  font-family:var(--font-heading);font-size:clamp(1rem,1.6vw,1.15rem);
  cursor:pointer;color:var(--ink);
  list-style:none;transition:color 200ms;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-family:var(--font-body);font-size:1.4rem;
  color:var(--accent);transition:transform 280ms var(--ease);
  flex-shrink:0;margin-left:16px;
}
.faq-item[open] summary::after{content:'−'}
.faq-item summary:hover{color:var(--accent)}
.faq-item .faq-body{
  height:0;padding:0 clamp(18px,3vw,28px);
  overflow:hidden;
  transition:height 360ms var(--ease-out),padding-block-end 360ms var(--ease-out);
}
.faq-item[open] .faq-body{height:auto;padding-block-end:22px}
.faq-body p{font-size:15px;line-height:1.7;color:var(--ink-soft)}

/* ============ STATS COUNTER ============ */
.stats-band{
  padding:clamp(2rem,4vw,3.5rem) 0;
  background:linear-gradient(135deg,var(--surface) 0%,var(--bg) 100%);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-counter .counter-num{
  font-family:var(--font-heading);font-size:clamp(2rem,4vw,3rem);
  color:var(--accent);line-height:1.1;display:block;
}
.stat-counter .counter-label{font-size:13px;color:var(--ink-soft);margin-top:4px}
@media(max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ PROCESS ============ */
.process-timeline{position:relative;padding-left:48px}
.process-timeline::before{
  content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
}
.process-step{
  position:relative;padding-bottom:clamp(28px,4vw,40px);
}
.process-step:last-child{padding-bottom:0}
.process-dot{
  position:absolute;left:-48px;top:4px;width:32px;height:32px;
  border-radius:50%;background:var(--surface);border:2px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-heading);font-size:14px;color:var(--accent);z-index:1;
}
.process-step h4{margin-bottom:6px}
.process-time{font-size:12px;color:var(--accent-2);font-weight:600;margin-bottom:8px;display:block}
.process-step p{font-size:14px;color:var(--ink-soft);line-height:1.6}

/* ============ PRICING DETAIL ============ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pricing-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,32px);display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform 280ms var(--ease),box-shadow 280ms var(--ease),border-color 280ms var(--ease);
}
.pricing-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px -12px rgba(212,168,83,.2),0 0 24px -6px rgba(212,168,83,.06);
  border-color:rgba(212,168,83,.25);
}
.pricing-card.featured{border-color:var(--accent)}
.pricing-card h3{margin-bottom:4px}
.pricing-card .price-tag{
  font-family:var(--font-heading);font-size:clamp(1.5rem,2.5vw,2rem);
  color:var(--accent);margin:12px 0 18px;
}
.pricing-card .price-tag small{font-family:var(--font-body);font-size:13px;color:var(--ink-soft);font-weight:400}
.pricing-card h5{
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  margin:14px 0 8px;
}
.included-list li,.excluded-list li{font-size:14px;padding:5px 0;padding-left:22px;position:relative;color:var(--ink-soft)}
.included-list li::before{content:'✓';position:absolute;left:0;color:var(--accent-2);font-weight:700}
.excluded-list li::before{content:'✕';position:absolute;left:0;color:#e8655a;font-weight:700}
.pricing-card .delivery{font-size:12px;color:var(--ink-soft);margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}

@media(max-width:768px){.pricing-grid{grid-template-columns:1fr}}

/* ============ CANCELLATION ============ */
.cancel-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0}
.cancel-tier{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;text-align:center;
}
.cancel-tier .tier-period{font-weight:700;color:var(--ink);margin-bottom:6px;font-size:15px}
.cancel-tier .tier-policy{font-size:14px;color:var(--accent)}
@media(max-width:640px){.cancel-tiers{grid-template-columns:1fr}}

/* ============ CONTACT CHANNELS ============ */
.contact-channels{display:grid;gap:0}
.channel-row{
  display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;
  padding:clamp(14px,2vw,18px) 0;border-bottom:1px solid var(--line);
  transition:transform 240ms var(--ease-out),background 240ms;
  border-radius:var(--radius);padding-left:8px;padding-right:8px;
}
.channel-row:hover{transform:translateX(4px);background:rgba(27,45,69,.5)}
.channel-row svg{
  width:20px;height:20px;color:var(--ink-soft);margin-top:2px;flex-shrink:0;
  transition:color 240ms var(--ease-out);
}
.channel-row:hover svg{color:var(--accent)}
.channel-label{font-weight:600;font-size:13px;color:var(--ink-soft);letter-spacing:.04em;margin-bottom:2px}
.channel-value{color:var(--ink);font-size:15px;word-break:break-all;overflow-wrap:anywhere}
.channel-value a{color:var(--ink)}
.channel-value a:hover{color:var(--accent)}

/* ============ ALTIMETER (theme signature) ============ */
.altimeter{
  position:fixed;right:20px;top:50%;transform:translateY(-50%);
  z-index:100;pointer-events:none;display:none;
}
@media(min-width:1280px){.altimeter{display:block}}
.altimeter svg{width:56px;height:300px}
.altimeter-marker{transition:cy 600ms var(--ease)}
.altimeter-elev{
  font-family:var(--font-heading);font-size:13px;fill:var(--accent);
  text-anchor:middle;transition:all 600ms var(--ease);
}
.altimeter-label{font-family:var(--font-body);font-size:9px;fill:var(--ink-soft);text-anchor:middle}
@keyframes alt-pulse{0%,100%{r:5;opacity:1}50%{r:7;opacity:.75}}
.altimeter-dot{animation:alt-pulse 2.5s ease infinite}

/* ============ FOOTER ============ */
.site-footer{
  background:var(--surface);border-top:1px solid var(--line);
  padding:clamp(2.5rem,6vw,4rem) 0 0;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(24px,4vw,40px);margin-bottom:clamp(2rem,4vw,3rem);
}
.footer-brand{max-width:300px}
.footer-brand .logo{margin-bottom:14px}
.footer-brand p{font-size:14px;color:var(--ink-soft);line-height:1.6}
.footer-col h5{
  font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:16px;
}
.footer-col a{
  display:block;font-size:14px;color:var(--ink-soft);
  padding:5px 0;transition:color 200ms,padding-left 200ms;
}
.footer-col a:hover{color:var(--accent);padding-left:6px}
.footer-contact-item{
  display:flex;align-items:start;gap:8px;padding:5px 0;font-size:14px;color:var(--ink-soft);
}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--accent)}
.footer-contact-item a{padding:0;display:inline}
.footer-bottom{
  border-top:1px solid var(--line);padding:20px 0;
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;
  gap:12px;font-size:12px;color:var(--ink-soft);
}
.footer-legal{display:flex;flex-wrap:wrap;gap:8px 20px}
.footer-legal a{font-size:12px;color:var(--ink-soft)}
.footer-legal a:hover{color:var(--accent)}

@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:span 2}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:auto}
}

/* ============ COOKIE BANNER ============ */
.cookie-banner{
  position:fixed;bottom:16px;left:16px;right:16px;max-width:520px;
  margin:0 auto;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);padding:clamp(18px,3vw,24px);
  transform:translateY(140%);opacity:0;
  transition:transform 280ms var(--ease),opacity 240ms;
  z-index:9999;
  box-shadow:0 16px 48px -12px rgba(0,0,0,.5);
}
@media(min-width:768px){.cookie-banner{left:24px;right:auto;max-width:420px}}
.cookie-banner.is-visible{transform:translateY(0);opacity:1}
.cookie-banner h4{font-size:16px;margin-bottom:8px}
.cookie-banner p{font-size:13px;color:var(--ink-soft);line-height:1.6;margin-bottom:16px}
.cookie-banner p a{text-decoration:underline}
.cookie-btns{display:flex;gap:8px;flex-wrap:wrap}
.cookie-btns button{
  flex:1;min-width:100px;padding:12px 18px;border-radius:var(--radius);
  font-size:14px;font-weight:600;cursor:pointer;
  transition:background 200ms,color 200ms,transform 180ms var(--ease),border-color 200ms;
  min-height:48px;min-width:48px;
}
.cookie-btns .cb-accept{background:var(--accent);color:var(--bg);border:2px solid var(--accent)}
.cookie-btns .cb-accept:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);transform:translateY(-1px)}
.cookie-btns .cb-reject{background:rgba(232,237,243,.08);color:var(--ink);border:2px solid var(--line-strong)}
.cookie-btns .cb-reject:hover{background:var(--surface-2);color:var(--ink);border-color:var(--accent);transform:translateY(-1px)}
.cookie-btns .cb-settings{background:transparent;color:var(--ink-soft);border:1px solid var(--line)}
.cookie-btns .cb-settings:hover{background:var(--surface-2);color:var(--ink);border-color:var(--accent);transform:translateY(-1px)}


/* ============ REVEAL ============ */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 700ms cubic-bezier(.16,1,.3,1),transform 700ms cubic-bezier(.16,1,.3,1);
}
.reveal.is-in{opacity:1;transform:none}
.reveal[style*="--i"]{transition-delay:calc(var(--i,0) * 100ms)}
@keyframes reveal-safety{to{opacity:1;transform:none}}
.js .reveal{animation:reveal-safety 0s 2.5s both}
.js .reveal.is-in{animation:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important;animation:none !important}
}
html.no-js .reveal{opacity:1;transform:none}

/* ============ NICHE ANIMATIONS ============ */
/* 1. Contour line draw — defined above with .topo-line */
/* 2. Peak glow on altitude markers */
@keyframes peak-glow{
  0%,100%{text-shadow:0 0 8px rgba(212,168,83,0)}
  50%{text-shadow:0 0 20px rgba(212,168,83,.4)}
}
.elevation-marker{animation:peak-glow 3s ease infinite}

/* 3. Trail path draw for SVG routes */
@keyframes trail-draw{from{stroke-dashoffset:800}to{stroke-dashoffset:0}}
.trail-path{stroke-dasharray:800;stroke-dashoffset:800}
.trail-path.is-in{animation:trail-draw 2.5s var(--ease) forwards}

/* 4. Mountain silhouette float */
@keyframes mtn-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.mtn-float{animation:mtn-float 8s ease-in-out infinite}

/* 5. Ice crystal shimmer */
@keyframes ice-shimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
.ice-shimmer{
  background:linear-gradient(90deg,transparent 30%,rgba(212,168,83,.06) 50%,transparent 70%);
  background-size:200% 100%;animation:ice-shimmer 12s linear infinite;
}

/* 6. Golden trail hover for interactive cards */
.timeline-card::after,.pricing-card::after{
  content:'';position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg,rgba(212,168,83,.1),rgba(91,146,121,.04) 40%,transparent 70%);
  opacity:0;transition:opacity 400ms var(--ease-out);pointer-events:none;
}
.timeline-card:hover::after,.pricing-card:hover::after{opacity:1}

/* 6b. Frost breath on glacier-themed card hover */
.timeline-card:hover,.pricing-card:hover{
  box-shadow:0 16px 48px -12px rgba(212,168,83,.18),0 0 32px -8px rgba(91,146,121,.06);
}

/* 7. Testimonial card hover */
.testimonial-card{transition:transform 280ms var(--ease),box-shadow 280ms var(--ease)}
.testimonial-card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 24px -8px rgba(212,168,83,.1);
}

/* 8. FAQ summary hover background */
.faq-item summary{border-radius:var(--radius);padding-left:8px;padding-right:8px;
  transition:color 200ms,background 200ms}
.faq-item summary:hover{background:rgba(212,168,83,.04)}

/* 9. Cancel tier hover */
.cancel-tier{transition:transform 240ms var(--ease),border-color 240ms var(--ease)}
.cancel-tier:hover{transform:translateY(-3px);border-color:rgba(212,168,83,.3)}

/* 10. Channel row icon glow on hover */
.channel-row:hover svg{filter:drop-shadow(0 0 4px rgba(212,168,83,.3))}

/* 11. Checklist item hover */
.checklist-item{border-radius:4px;padding-left:4px;padding-right:4px;
  transition:background 200ms}
.checklist-item:hover{background:rgba(212,168,83,.04)}

/* 12. Stat counter hover glow */
.stat-counter{transition:transform 280ms var(--ease)}
.stat-counter .counter-num{transition:text-shadow 300ms var(--ease-out),transform 300ms var(--ease)}
.stat-counter:hover{transform:translateY(-3px)}
.stat-counter:hover .counter-num{text-shadow:0 0 24px rgba(212,168,83,.35);transform:scale(1.04)}

/* 13. Button press effect */
.btn-primary:active{transform:translateY(0) scale(.97)}
.btn-ghost:active{transform:translateY(0) scale(.97)}

/* 14. Trail marker pulse — expedition waypoints */
@keyframes trail-pulse{
  0%,100%{box-shadow:0 0 0 3px var(--accent)}
  50%{box-shadow:0 0 0 3px var(--accent),0 0 14px 2px rgba(212,168,83,.2)}
}
.timeline-dot{animation:trail-pulse 3s ease-in-out infinite}

/* 15. Campfire warm glow on hero CTA */
@keyframes camp-glow{
  0%,100%{box-shadow:0 2px 12px -4px rgba(212,168,83,.12)}
  50%{box-shadow:0 6px 28px -4px rgba(212,168,83,.32),0 0 48px -8px rgba(212,168,83,.1)}
}
.hero .btn-primary{animation:camp-glow 3.5s ease-in-out infinite}
.hero .btn-primary:hover{animation:none;box-shadow:0 8px 32px -8px rgba(212,168,83,.35)}

/* 16. Glacier frost ring on team photos */
@keyframes frost-ring{
  0%,100%{border-color:var(--accent);box-shadow:0 0 0 0 rgba(212,168,83,0)}
  33%{border-color:var(--accent-2);box-shadow:0 0 12px -4px rgba(91,146,121,.2)}
  66%{border-color:var(--accent);box-shadow:0 0 12px -4px rgba(212,168,83,.15)}
}
.team-photo{animation:frost-ring 8s ease-in-out infinite}
.team-card:hover .team-photo{border-color:var(--accent);box-shadow:0 0 20px -4px rgba(212,168,83,.25)}

/* 17. Patagonian wind sway on topo separator lines */
@keyframes wind-sway{
  0%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  50%{transform:translateX(3px)}
  75%{transform:translateX(-10px)}
  100%{transform:translateX(0)}
}
.topo-sep path:first-child{animation:wind-sway 14s ease-in-out infinite}
.topo-sep path:nth-child(2){animation:wind-sway 18s ease-in-out infinite reverse}

/* 18. Featured pricing card border shimmer */
@keyframes border-shimmer{
  0%,100%{border-color:var(--accent)}
  50%{border-color:rgba(212,168,83,.5)}
}
.pricing-card.featured{animation:border-shimmer 3s ease-in-out infinite}

/* 19. Stat counter scale on reveal */
.stat-counter.reveal.is-in .counter-num{
  animation:stat-pop .6s cubic-bezier(.16,1,.3,1) both;
}
@keyframes stat-pop{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}

/* 20. FAQ accordion smooth open */
.faq-item[open] summary{color:var(--accent)}

/* 21. Trust item subtle hover */
.trust-item{transition:color 200ms var(--ease-out);border-radius:var(--radius);padding:6px 10px}
.trust-item:hover{color:var(--ink)}
.trust-item:hover svg{color:var(--ink)}

@media(prefers-reduced-motion:reduce){
  .compass-motif,.mtn-float,.ice-shimmer,.altimeter-dot,.elevation-marker,.trail-path{
    animation:none !important;
  }
  .topo-line{stroke-dashoffset:0 !important;animation:none !important}
  .faq-item .faq-body{transition:none !important}
  .timeline-card,.pricing-card,.team-card,.testimonial-card,.cancel-tier,.stat-counter,.stat-counter .counter-num,
  .checklist-item,.checklist-cat,.channel-row,.channel-row svg,.nav-toggle{transition:none !important}
  .timeline-card::after,.pricing-card::after{display:none}
  .btn-primary:active,.btn-ghost:active{transform:none}
  .timeline-dot,.hero .btn-primary,.team-photo,.topo-sep path,.topo-sep path:nth-child(2),
  .pricing-card.featured,.stat-counter.reveal.is-in .counter-num{animation:none !important}
  .reveal{animation:none !important}
}

/* ============ TABLE SCROLL ============ */
.table-scroll{
  display:block;width:100%;max-width:100%;min-width:0;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  margin:18px 0;border:1px solid var(--line);border-radius:6px;
}
.table-scroll>table{margin:0 !important;min-width:480px;width:100%}
:where(*:has(>.table-scroll),*:has(>*>.table-scroll),*:has(>*>*>.table-scroll)){min-width:0}
table{border-collapse:collapse;width:100%;font-size:14px}
th{
  background:var(--surface-2);font-weight:600;font-size:13px;
  letter-spacing:.04em;text-align:left;padding:12px 16px;color:var(--ink-soft);
  border-bottom:2px solid var(--line-strong);
}
td{padding:12px 16px;border-bottom:1px solid var(--line);color:var(--ink-soft)}
tr:last-child td{border-bottom:none}

/* ============ POLICY / TEXT PAGES ============ */
.page-hero{
  padding:clamp(2rem,6vw,4rem) 0 clamp(1.5rem,4vw,2.5rem);
  text-align:center;background:var(--surface);
  border-bottom:1px solid var(--line);
}
.text-content{padding:clamp(2rem,5vw,3.5rem) 0;line-height:1.7}
.text-content h2{margin:clamp(1.5rem,3vw,2.5rem) 0 14px;font-size:clamp(1.4rem,2.5vw,1.8rem)}
.text-content h3{margin:clamp(1rem,2vw,1.5rem) 0 10px;font-size:clamp(1.1rem,1.8vw,1.35rem)}
.text-content p{color:var(--ink-soft);margin-bottom:14px;max-width:72ch}
.text-content ul,.text-content ol{margin:10px 0 14px 20px;color:var(--ink-soft)}
.text-content li{padding:4px 0;list-style:disc}
.text-content ol li{list-style:decimal}
.text-content a{text-decoration:underline;word-break:break-word;overflow-wrap:anywhere}
.text-content strong{color:var(--ink);font-weight:600}

/* 404 page */
.page-404{
  min-height:60vh;display:flex;align-items:center;justify-content:center;
  text-align:center;padding:4rem 0;
}
.page-404 h1{font-size:clamp(5rem,12vw,10rem);color:var(--accent);opacity:.6;line-height:1}
.page-404 p{color:var(--ink-soft);margin:12px 0 28px}

/* Sitemap */
.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.sitemap-group h3{margin-bottom:12px;font-size:1.1rem}
.sitemap-group a{display:block;padding:5px 0;font-size:14px;color:var(--ink-soft)}
.sitemap-group a:hover{color:var(--accent)}

/* ============ PRINT ============ */
@media print{
  .site-header,.drawer,.drawer-backdrop,.cookie-banner,.altimeter,.nav-toggle,.topo-sep,.compass-motif,.hero-topo{display:none !important}
  body{background:#fff;color:#111;font-size:12pt}
  main{padding-top:0}
  a{color:#111;text-decoration:underline}
  .reveal{opacity:1 !important;transform:none !important;animation:none !important}
}

/* ============ RESPONSIVE ============ */
@media(max-width:1440px){}
@media(max-width:1280px){
  .altimeter{display:none}
}
@media(max-width:1024px){
  :root{--header-h:64px}
}
@media(max-width:768px){
  section{padding:clamp(2.5rem,6vw,4rem) 0}
  .hero{min-height:auto;padding:clamp(3rem,8vw,5rem) 0}
  .hero h1{font-size:clamp(2rem,6vw,3rem)}
  .cookie-btns{flex-wrap:nowrap}
  .cookie-btns button{min-width:0;padding:12px 14px;font-size:13px}
}
@media(max-width:640px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .cancel-tiers{grid-template-columns:1fr}
  .trust-items{gap:12px 20px}
}
@media(max-width:480px){
  :root{--header-h:60px}
  .hero h1{font-size:clamp(2rem,9vw,3rem)}
  .team-card{grid-template-columns:1fr;text-align:center}
  .team-photo{margin:0 auto}
}
@media(max-width:390px){
  .container{padding-left:16px;padding-right:16px}
  .cookie-banner{left:8px;right:8px;bottom:8px}
}
@media(max-width:360px){
  .hero-km .km-number{font-size:2.5rem}
  .timeline-card{padding:16px}
}
