/* =========================================================================
   SOUTH COAST AVENTURAS — Design System
   Palette grounded in the real landscape: the red peridotite rock of
   Sierra Bermeja (rust), the deep pools of the Guadalmina & Genal canyons
   (teal), the pinsapo forest at dusk (canyon-black/green), Andalusian
   sun (gold). Contour lines = topographic maps, the guide's real tool.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Big+Shoulders:wght@600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600&display=swap');

:root{
  /* --- Color: Canyon at dusk ------------------------------------------ */
  --canyon-black:   #101d17;   /* base background */
  --canyon-surface: #16261f;   /* section / card surface */
  --canyon-surface-2:#1f3129;  /* elevated / hover surface */
  --canyon-line:    rgba(243,239,227,0.12); /* topo contour lines */
  --canyon-line-strong: rgba(243,239,227,0.22);

  --stone-ivory:    #f4f0e4;   /* primary text on dark */
  --stone-muted:    #b9c6ba;   /* secondary text on dark */
  --stone-faint:    #7f9186;   /* tertiary / captions */

  --bermeja-rust:       #c4522e; /* primary CTA / adrenaline accent */
  --bermeja-rust-hover: #de6b45;
  --bermeja-rust-soft:  rgba(196,82,46,0.14);

  --pool-gold:      #d4a24c;   /* secondary accent / highlights */
  --pool-gold-soft: rgba(212,162,76,0.14);
  --pool-teal:      #4e8c82;   /* water accent */
  --pool-teal-soft: rgba(78,140,130,0.16);

  --ink-on-gold:    #1a1305;

  /* --- Type -------------------------------------------------------------*/
  --font-display: 'Big Shoulders', sans-serif;
  --font-body:    'Space Grotesk', sans-serif;
  --font-mono:    'JetBrains Mono', monospace;

  /* --- Layout ------------------------------------------------------------*/
  --container: 1200px;
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 26px;
  --shadow-card: 0 18px 40px -18px rgba(0,0,0,0.55);
}

/* ---------- Reset -------------------------------------------------------*/
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--canyon-black);
  color:var(--stone-ivory);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--font-display); font-weight:800; letter-spacing:0.01em; }
p{ margin:0; }
button{ font-family:inherit; }

:focus-visible{
  outline:2px solid var(--pool-gold);
  outline-offset:3px;
  border-radius:4px;
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

.container{ max-width:var(--container); margin:0 auto; padding:0 24px; }
.section{ padding:88px 0; position:relative; }
.section--tight{ padding:56px 0; }
@media (max-width:760px){
  .section{ padding:56px 0; }
  .section--tight{ padding:36px 0; }
}

.eyebrow{
  font-family:var(--font-mono);
  font-size:12.5px;
  font-weight:600;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--pool-gold);
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
}
.eyebrow::before{
  content:'';
  width:22px; height:1px;
  background:var(--pool-gold);
}

.h1{ font-size:clamp(2.6rem, 6vw, 5.2rem); line-height:0.98; text-transform:uppercase; }
.h2{ font-size:clamp(2rem, 4vw, 3.1rem); line-height:1.02; text-transform:uppercase; }
.h3{ font-size:clamp(1.3rem, 2.2vw, 1.6rem); line-height:1.1; text-transform:uppercase; }
.lede{ font-size:1.15rem; color:var(--stone-muted); max-width:620px; }

.text-muted{ color:var(--stone-muted); }
.text-center{ text-align:center; margin-left:auto; margin-right:auto; }

/* ---------- Topo signature motif ---------------------------------------*/
.topo-bg{
  position:absolute; inset:0; overflow:hidden; z-index:0; pointer-events:none;
}
.topo-divider{
  height:64px; width:100%; display:block;
}
.topo-divider path{ fill:none; stroke:var(--canyon-line); stroke-width:1.2; }

/* ---------- Buttons ------------------------------------------------------*/
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-mono); font-weight:600; font-size:13px;
  letter-spacing:0.08em; text-transform:uppercase;
  padding:16px 26px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
.btn--rust{ background:var(--bermeja-rust); color:var(--stone-ivory); }
.btn--rust:hover{ background:var(--bermeja-rust-hover); }
.btn--gold{ background:var(--pool-gold); color:var(--ink-on-gold); }
.btn--gold:hover{ background:#e2b562; }
.btn--ghost{ background:transparent; color:var(--stone-ivory); border-color:var(--canyon-line-strong); }
.btn--ghost:hover{ border-color:var(--pool-gold); color:var(--pool-gold); }
.btn--whatsapp{ background:#25D366; color:#08210f; }
.btn--whatsapp:hover{ background:#3fe07c; }
.btn--sm{ padding:11px 18px; font-size:11.5px; }
.btn--block{ width:100%; }

/* ---------- Topbar --------------------------------------------------------*/
.topbar{
  position:sticky; top:0; z-index:50;
  background:rgba(16,29,23,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--canyon-line);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; max-width:var(--container); margin:0 auto;
}
.brand{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:800; font-size:1.35rem; letter-spacing:0.02em; text-transform:uppercase; }
.brand__mark{ width:30px; height:30px; flex-shrink:0; }
.brand small{ display:block; font-family:var(--font-mono); font-size:9.5px; letter-spacing:0.18em; color:var(--pool-gold); text-transform:uppercase; font-weight:600; }

.nav{ display:flex; align-items:center; gap:28px; }
.nav__links{ display:flex; align-items:center; gap:26px; }
.nav__links a{
  font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--stone-muted); font-weight:500; transition:color .15s ease;
  position:relative;
}
.nav__links a:hover, .nav__links a.is-active{ color:var(--stone-ivory); }
.nav__links a.is-active::after{
  content:''; position:absolute; left:0; right:0; bottom:-8px; height:2px; background:var(--bermeja-rust);
}
.nav__cta{ display:flex; align-items:center; gap:12px; }
.nav__toggle{
  display:none; background:none; border:1px solid var(--canyon-line-strong); border-radius:8px;
  width:42px; height:38px; color:var(--stone-ivory); align-items:center; justify-content:center;
}
.nav__mobile{ display:none; }

@media (max-width:920px){
  .nav__links{ display:none; }
  .nav__toggle{ display:flex; }
  .nav__cta .btn--ghost{ display:none; }
  .nav__mobile{
    display:block; position:fixed; inset:70px 0 0 0; background:var(--canyon-black);
    padding:32px 24px; z-index:60; transform:translateY(-8px); opacity:0; pointer-events:none;
    transition:opacity .2s ease, transform .2s ease;
  }
  .nav__mobile.is-open{ opacity:1; transform:translateY(0); pointer-events:auto; }
  .nav__mobile a{
    display:block; padding:16px 0; border-bottom:1px solid var(--canyon-line);
    font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.06em; font-size:14px; color:var(--stone-ivory);
  }
  .nav__mobile .btn{ margin-top:24px; }
}

/* ---------- Hero -----------------------------------------------------------*/
.hero{
  position:relative; overflow:hidden;
  padding:150px 0 110px;
  background:
    radial-gradient(ellipse 900px 500px at 18% -10%, rgba(212,162,76,0.16), transparent 60%),
    linear-gradient(180deg, #0d1712 0%, var(--canyon-black) 60%);
}
.hero__topo{ position:absolute; inset:0; z-index:0; opacity:0.9; }
.hero__grain{ position:absolute; inset:0; z-index:1; mix-blend-mode:overlay; opacity:0.5; }
.hero__inner{ position:relative; z-index:2; max-width:820px; }
.hero .h1{ margin-bottom:18px; }
.hero .h1 em{ font-style:normal; color:var(--bermeja-rust); }
.hero .h1 .h1-by{ font-style:normal; color:var(--pool-gold); font-size:0.5em; display:block; letter-spacing:0.04em; margin-top:6px; }
.hero__tagline{ font-family:var(--font-body); font-weight:600; font-size:1.35rem; color:var(--stone-ivory); max-width:640px; margin-bottom:16px; line-height:1.3; }
.hero__sub{ font-size:1.08rem; color:var(--stone-muted); max-width:600px; margin-bottom:38px; }
.hero__ctas{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:44px; }
.hero__proof{ display:flex; gap:28px; flex-wrap:wrap; }
.hero__proof-item{ font-family:var(--font-mono); font-size:12px; letter-spacing:0.05em; color:var(--stone-faint); text-transform:uppercase; }
.hero__proof-item b{ color:var(--stone-ivory); font-size:1rem; display:block; font-family:var(--font-display); letter-spacing:0; text-transform:none; }

/* ---------- Trust marquee ---------------------------------------------------*/
.marquee{
  border-top:1px solid var(--canyon-line); border-bottom:1px solid var(--canyon-line);
  background:var(--canyon-surface); overflow:hidden; padding:16px 0;
}
.marquee__track{ display:flex; gap:48px; white-space:nowrap; animation:marquee 32s linear infinite; width:max-content; }
.marquee__track span{ font-family:var(--font-mono); font-size:12.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--stone-muted); }
.marquee__track span b{ color:var(--pool-gold); }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ---------- Section headers -------------------------------------------------*/
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; margin-bottom:48px; flex-wrap:wrap; }
.section__head .lede{ margin-top:14px; }

/* ---------- Why-us columns -----------------------------------------------------*/
.why-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--canyon-line); border-radius:var(--radius-lg); overflow:hidden; }
.why-item{ background:var(--canyon-surface); padding:34px 26px; }
.why-item__num{ font-family:var(--font-mono); color:var(--bermeja-rust); font-size:12px; letter-spacing:0.06em; margin-bottom:14px; display:block; }
.why-item h3{ font-size:1.1rem; margin-bottom:10px; }
.why-item p{ color:var(--stone-muted); font-size:0.94rem; }
@media (max-width:980px){ .why-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .why-grid{ grid-template-columns:1fr; } }

/* ---------- SEO content blocks -----------------------------------------------*/
.seo-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
@media (max-width:820px){ .seo-grid{ grid-template-columns:1fr; } }
.seo-block{
  background:var(--canyon-surface); border:1px solid var(--canyon-line); border-radius:var(--radius-md);
  padding:32px; display:flex; flex-direction:column; gap:14px;
}
.seo-block h3{ font-size:1.25rem; }
.seo-block p{ color:var(--stone-muted); font-size:0.96rem; }
.seo-block a.link{ font-family:var(--font-mono); font-size:12px; text-transform:uppercase; letter-spacing:0.06em; color:var(--pool-gold); display:inline-flex; gap:8px; align-items:center; }
.seo-block a.link:hover{ color:var(--bermeja-rust-hover); }

/* ---------- Long-form article content (used on activity/SEO pages) -----------*/
.prose{ max-width:760px; }
.prose h2{ font-size:1.9rem; margin:44px 0 18px; text-transform:uppercase; }
.prose h2:first-child{ margin-top:0; }
.prose h3{ font-size:1.25rem; margin:28px 0 12px; text-transform:none; color:var(--pool-gold); }
.prose p{ color:var(--stone-muted); margin-bottom:16px; font-size:1.02rem; }
.prose ul{ margin-bottom:16px; }
.prose li{ color:var(--stone-muted); padding-left:22px; position:relative; margin-bottom:10px; }
.prose li::before{ content:''; position:absolute; left:0; top:9px; width:8px; height:8px; border-radius:50%; background:var(--bermeja-rust); }
.prose strong{ color:var(--stone-ivory); }

/* ---------- FAQ accordion ------------------------------------------------------*/
.faq{ max-width:820px; }
.faq-item{ border-bottom:1px solid var(--canyon-line); }
.faq-item summary{
  cursor:pointer; list-style:none; padding:22px 0; display:flex; align-items:center; justify-content:space-between; gap:16px;
  font-family:var(--font-display); font-weight:700; font-size:1.05rem; text-transform:uppercase;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:'+'; font-family:var(--font-mono); font-size:22px; color:var(--pool-gold); flex-shrink:0; transition:transform .2s ease; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ color:var(--stone-muted); padding-bottom:22px; max-width:680px; }

/* ---------- CTA band -------------------------------------------------------------*/
.cta-band{
  background:linear-gradient(120deg, var(--bermeja-rust) 0%, #a83f22 100%);
  border-radius:var(--radius-lg); padding:64px 56px; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
}
.cta-band::after{
  content:''; position:absolute; right:-60px; top:-60px; width:280px; height:280px; border-radius:50%;
  background:rgba(255,255,255,0.08);
}
.cta-band h2{ color:var(--stone-ivory); font-size:clamp(1.8rem,3.4vw,2.6rem); max-width:520px; position:relative; z-index:1; }
.cta-band__actions{ display:flex; gap:14px; flex-wrap:wrap; position:relative; z-index:1; }
.cta-band .btn--ghost{ border-color:rgba(244,240,228,0.5); }
.cta-band .btn--ghost:hover{ border-color:var(--stone-ivory); color:var(--stone-ivory); background:rgba(0,0,0,0.15); }

/* ---------- Footer -----------------------------------------------------------------*/
.footer{ background:#0c1611; border-top:1px solid var(--canyon-line); padding-top:64px; }
.footer__grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; padding-bottom:48px; }
.footer__brand p{ color:var(--stone-muted); font-size:0.92rem; margin-top:14px; max-width:280px; }
.footer h4{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.1em; text-transform:uppercase; color:var(--pool-gold); margin-bottom:18px; }
.footer li{ margin-bottom:10px; }
.footer a{ color:var(--stone-muted); font-size:0.92rem; transition:color .15s ease; }
.footer a:hover{ color:var(--stone-ivory); }
.footer__bottom{
  border-top:1px solid var(--canyon-line); padding:22px 0; display:flex; justify-content:space-between;
  flex-wrap:wrap; gap:12px; font-size:12.5px; color:var(--stone-faint); font-family:var(--font-mono);
}
.footer__note{
  background:var(--canyon-surface); border:1px solid var(--canyon-line); border-radius:var(--radius-md);
  padding:18px 22px; font-size:0.86rem; color:var(--stone-faint); margin-bottom:40px;
}
.footer__note strong{ color:var(--pool-gold); }
@media (max-width:900px){ .footer__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .footer__grid{ grid-template-columns:1fr; } }

/* ---------- WhatsApp floating button -----------------------------------------------*/
.wa-float{
  position:fixed; bottom:22px; right:22px; z-index:70;
  width:58px; height:58px; border-radius:50%; background:#25D366;
  display:flex; align-items:center; justify-content:center; box-shadow:0 10px 26px -8px rgba(0,0,0,0.6);
  animation:wa-pulse 2.6s ease-in-out infinite;
}
.wa-float svg{ width:28px; height:28px; }
@keyframes wa-pulse{ 0%,100%{ box-shadow:0 10px 26px -8px rgba(37,211,102,0.5); } 50%{ box-shadow:0 10px 34px -6px rgba(37,211,102,0.85); } }

/* ---------- Activity hero (páginas de producto individuales) ------------------------*/
.activity-hero{
  position:relative; height:min(56vw, 460px); min-height:320px; overflow:hidden;
  margin-top:70px; /* deja hueco para el topbar sticky */
}
.activity-hero img{
  width:100%; height:100%; object-fit:cover; object-position:center; display:block;
}
.activity-hero::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(16,29,23,0.15) 0%, rgba(16,29,23,0.55) 55%, var(--canyon-black) 100%);
}
.activity-hero__caption{
  position:absolute; left:0; right:0; bottom:0; z-index:2; padding:48px 0 32px;
}
.activity-hero__caption .container{ max-width:900px; }

/* ---------- Booking block (widget oficial de Bokun) ----------------------------------*/
.booking-block{
  background:var(--canyon-surface); border:1px solid var(--canyon-line); border-radius:var(--radius-lg);
  padding:40px; scroll-margin-top:90px;
}
.booking-block__head{ margin-bottom:24px; }
.booking-block__head p.eyebrow{ margin-bottom:10px; }
.booking-block__note{
  font-family:var(--font-mono); font-size:11.5px; color:var(--stone-faint);
  margin-top:18px; display:flex; align-items:center; gap:8px;
}
.booking-block__note::before{ content:'🔒'; font-size:12px; }
.bokunWidget{ min-height:120px; }
@media (max-width:600px){ .booking-block{ padding:24px; } }

/* ---------- Quick-fact icon rows (páginas de producto) --------------------------------*/
.fact-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--canyon-line); border-radius:var(--radius-md); overflow:hidden; margin-bottom:40px; }
.fact-row__item{ background:var(--canyon-surface); padding:20px; text-align:center; }
.fact-row__item span{ display:block; font-family:var(--font-mono); font-size:10.5px; letter-spacing:0.08em; text-transform:uppercase; color:var(--pool-gold); margin-bottom:8px; }
.fact-row__item b{ font-family:var(--font-display); font-size:1.05rem; text-transform:uppercase; }
@media (max-width:700px){ .fact-row{ grid-template-columns:repeat(2,1fr); } }
.breadcrumb{ font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.05em; text-transform:uppercase; color:var(--stone-faint); margin-bottom:24px; }
.breadcrumb a{ color:var(--stone-faint); }
.breadcrumb a:hover{ color:var(--pool-gold); }

/* ---------- Page hero (secondary pages, shorter than home) -------------------------*/
.page-hero{
  padding:140px 0 70px; position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse 700px 400px at 90% -20%, rgba(78,140,130,0.18), transparent 60%),
    linear-gradient(180deg, #0d1712 0%, var(--canyon-black) 70%);
}
.page-hero__inner{ position:relative; z-index:2; max-width:760px; }
.page-hero .h1{ font-size:clamp(2.2rem,4.6vw,3.6rem); margin-bottom:18px; }

/* ---------- Two-column layout w/ sidebar (activity pages) ---------------------------*/
.layout-with-side{ display:grid; grid-template-columns:1fr 320px; gap:48px; align-items:start; }
@media (max-width:920px){ .layout-with-side{ grid-template-columns:1fr; } }
.side-card{
  background:var(--canyon-surface); border:1px solid var(--canyon-line); border-radius:var(--radius-md);
  padding:26px; position:sticky; top:100px;
}
.side-card h4{ font-family:var(--font-mono); font-size:11px; letter-spacing:0.08em; text-transform:uppercase; color:var(--pool-gold); margin-bottom:14px; }
.side-card .btn{ margin-bottom:10px; }
.side-card__list li{ display:flex; justify-content:space-between; padding:10px 0; border-bottom:1px dashed var(--canyon-line); font-size:0.9rem; color:var(--stone-muted); }
.side-card__list li b{ color:var(--stone-ivory); font-weight:600; }
