/* =====================================================================
   Albandeira Eco Tours — style.css
   Display: Bricolage Grotesque · Body: DM Sans · Labels: DM Mono
   Signature: the dotted "sun" motif + lime→green gradient on warm sand.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --sand:        #f8f6ef;
  --sand-2:      #f1eee3;
  --paper:       #ffffff;
  --ink:         #14241a;
  --ink-soft:    #3c4a40;
  --muted:       #6b756d;
  --line:        #e4e0d3;

  --green:       #0c9f45;
  --green-d:     #0a7f37;
  --green-dd:    #075f2a;
  --lime:        #a8cc30;
  --sun:         #f2d50c;
  --sun-d:       #e6c200;

  --grad:        var(--green);
  --grad-sun:    var(--sun);

  --shadow-sm:   0 2px 10px rgba(20,36,26,.06);
  --shadow:      0 14px 40px rgba(20,36,26,.10);
  --shadow-lg:   0 30px 70px rgba(20,36,26,.16);

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-pill: 999px;

  --container: 1200px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display: "Bricolage Grotesque", system-ui, sans-serif;
  --font-body:    "DM Sans", system-ui, -apple-system, sans-serif;
  --font-mono:    "DM Mono", ui-monospace, "SFMono-Regular", monospace;
}

/* ---------- Reset-ish ---------- */
*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior: auto; } }

body{
  margin: 0;
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--sand);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img{ max-width: 100%; display: block; }
a{ color: var(--green-d); text-decoration: none; }
a:hover{ color: var(--green-dd); }
h1,h2,h3,h4{ font-family: var(--font-display); font-weight: 700; line-height: 1.08; color: var(--ink); margin: 0 0 .4em; letter-spacing: -.01em; }
p{ margin: 0 0 1rem; }
ul{ margin: 0; padding: 0; list-style: none; }
li::marker{
  content: "";
}

.container{ width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: 22px; }

/* ---------- Accessibility ---------- */
.skip-link{
  position: absolute; left: 12px; top: -60px; z-index: 1100;
  background: var(--ink); color: #fff; padding: 10px 16px; border-radius: 8px;
  transition: top .2s var(--ease);
}
.skip-link:focus{ top: 12px; color:#fff; }
:focus-visible{ outline: 3px solid var(--green); outline-offset: 2px; border-radius: 4px; }

/* ---------- Eyebrow / section heads ---------- */
.eyebrow{
  font-family: var(--font-mono);
  font-size: .74rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--green-d); margin: 0 0 .7rem; display: inline-flex; align-items: center; gap: .55em;
}
.eyebrow::before{ content: ""; width: 22px; height: 2px; background: var(--grad); border-radius: 2px; }
.eyebrow--light{ color: #eaf6ea; }
.eyebrow--light::before{ background: var(--sun); }

.section{ padding: clamp(56px, 8vw, 110px) 0; }
.section-title{ font-size: clamp(1.9rem, 3.6vw, 3rem); }
.section-title--light{ color: #fff; }
.section-head{
  display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem;
  margin-bottom: clamp(28px, 4vw, 52px);
}
.section-head--center{ flex-direction: column; align-items: center; text-align: center; }
.section-lead, .section-head--center .section-lead{ color: var(--muted); max-width: 38ch; margin: 0; }
.section-cta{ text-align: center; margin-top: clamp(30px, 4vw, 50px); }

/* ---------- Buttons ---------- */
.btn{
  --bg: var(--green); --fg: #fff;
  font-family: var(--font-body); font-weight: 600; font-size: .98rem;
  display: inline-flex; align-items: center; gap: .5em; justify-content: center;
  padding: .82em 1.5em; border-radius: var(--r-pill); border: 2px solid transparent;
  background: var(--bg); color: var(--fg); cursor: pointer;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
  white-space: nowrap;
}
.btn:hover{ transform: translateY(-2px); color: var(--fg); }
.btn:active{ transform: translateY(0); }
.btn svg{ flex: none; }

.btn-primary{ background: var(--green); color:#fff; box-shadow: 0 8px 22px rgba(12,159,69,.28); }
.btn-primary:hover{ background: var(--green-d); box-shadow: 0 12px 30px rgba(12,159,69,.34); }

.btn-sun{ background: var(--sun); color: var(--ink); box-shadow: 0 8px 22px rgba(242,213,12,.4); }
.btn-sun:hover{ background: var(--sun-d); color: var(--ink); box-shadow: 0 12px 30px rgba(242,213,12,.5); }

.btn-book{ background: var(--ink); color:#fff; padding: .48em 1.25em; }
.btn-book:hover{ background:#0a1611; color:#fff; }

.btn-outline{ background: transparent; color: var(--green-d); border-color: var(--line); }
.btn-outline:hover{ border-color: var(--green); color: var(--green-dd); background: rgba(12,159,69,.05); }

.btn-ghost-light{ background: rgba(255,255,255,.12); color:#fff; border-color: rgba(255,255,255,.55); backdrop-filter: blur(4px); }
.btn-ghost-light:hover{ background: rgba(255,255,255,.22); color:#fff; }

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.site-header{
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: transparent;
  backdrop-filter: none;
  border-bottom: 1px solid transparent;
  transition: border-color .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), backdrop-filter .25s var(--ease);
}
.site-header.is-scrolled{ box-shadow: var(--shadow-sm); background: #14241a; backdrop-filter: saturate(140%) blur(12px); }
.site-header.is-scrolled .navbar-nav .nav-link{ color: rgba(255,255,255,.88); }
.site-header.is-scrolled .navbar-nav .nav-link:hover,
.site-header.is-scrolled .navbar-nav .nav-link.is-active{ color: #fff; }
.site-header.is-scrolled .btn-book{ background: var(--sun); color: var(--ink); }
.site-header.is-scrolled .btn-book:hover{ background: var(--sun-d); color: var(--ink); }
.site-header:not(.is-scrolled) .navbar-nav .nav-link{ color: rgba(255,255,255,.88); }
.site-header:not(.is-scrolled) .navbar-nav .nav-link:hover,
.site-header:not(.is-scrolled) .navbar-nav .nav-link.is-active{ color: #fff; }
.site-header:not(.is-scrolled) .navbar-toggler{ background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.35); }
.site-header:not(.is-scrolled) .toggler-bar{ background: #fff; }
.site-header .navbar{ padding: .6rem 0; }
.navbar-brand{ display: inline-flex; align-items: center; gap: .6rem; padding: 0; }
.brand-mark{ object-fit: contain; }
.brand-words{ display: flex; flex-direction: column; line-height: 1; font-family: var(--font-display); }
.brand-words strong{ font-size: 1.18rem; font-weight: 800; color: var(--green-d); letter-spacing: -.02em; }
.brand-words span{ font-size: .64rem; letter-spacing: .26em; text-transform: uppercase; color: var(--muted); font-family: var(--font-mono); margin-top: 2px; }

.navbar-nav .nav-link{
  font-weight: 600; color: var(--ink-soft); padding: .5rem .9rem; border-radius: var(--r-pill);
  position: relative; transition: color .15s var(--ease);
}
.navbar-nav .nav-link:hover{ color: var(--green-d); }
.navbar-nav .nav-link.is-active{ color: var(--green-dd); }
.navbar-nav .nav-link.is-active::after{
  content:""; position:absolute; left: 50%; transform: translateX(-50%); bottom: 2px;
  width: 18px; height: 3px; border-radius: 3px; background: var(--grad);
}

.nav-actions{ display: flex; align-items: center; gap: .8rem; }
.lang-switch{ display: inline-flex; gap: 2px; padding: 3px; background: var(--sand-2); border: 1px solid var(--line); border-radius: var(--r-pill); }
.lang-opt{
  font-family: var(--font-mono); font-size: .72rem; font-weight: 500; letter-spacing: .04em;
  color: var(--muted); padding: .28em .62em; border-radius: var(--r-pill); transition: all .15s var(--ease);
}
.lang-opt:hover{ color: var(--ink); }
.lang-opt.is-active{ background: var(--green); color:#fff; }

.navbar-toggler{ border: 1px solid var(--line); border-radius: 10px; padding: 9px 10px; background: var(--paper); }
.navbar-toggler:focus{ box-shadow: none; }
.toggler-bar{ display: block; width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .25s var(--ease), opacity .2s var(--ease); }
.toggler-bar + .toggler-bar{ margin-top: 5px; }

@media (max-width: 991.98px){
  .navbar-collapse{
    margin-top: .8rem; padding: 1rem; background: var(--paper);
    border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow);
  }
  .navbar-nav{ margin-bottom: 1rem; }
  .navbar-nav .nav-link{ padding: .7rem .4rem; }
  .navbar-nav .nav-link.is-active::after{ left: 4px; transform: none; }
  .nav-actions{ justify-content: space-between; }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{ position: relative; color:#fff; isolation: isolate; }
.hero__media{ position: absolute; inset: 0; z-index: -1; overflow: hidden; }
.hero__media img{ width: 100%; height: 100%; object-fit: cover; }
.hero__scrim{
  position: absolute; inset: 0;
  background: rgba(7,40,22,.42);
}
.hero__inner{
  position: relative; min-height: min(86vh, 760px);
  display: flex; align-items: center; padding: clamp(80px,12vh,150px) 22px clamp(60px,9vh,110px);
}
.hero__content{ max-width: 660px; }
.hero__title{ color: var(--sand); font-size: clamp(2.5rem, 6.2vw, 4.6rem); font-weight: 800; text-shadow: 0 2px 30px rgba(0,0,0,.25); }
.hero__title em{ font-style: normal; color: var(--sun); }
.hero__subtitle{ font-size: clamp(1.05rem, 1.6vw, 1.28rem); max-width: 50ch; color: #eef6ee; margin: 1.1rem 0 1.8rem; }
.hero__actions{ display: flex; flex-wrap: wrap; gap: .8rem; }
.hero__card{
  position: absolute; right: 22px; bottom: clamp(28px,6vh,60px); max-width: 260px;
  background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.3);
  backdrop-filter: blur(10px); border-radius: var(--r); padding: 1rem 1.1rem;
  display: flex; gap: .8rem; align-items: center; box-shadow: var(--shadow);
}
.hero__card img{ width: 54px; height: 38px; border-radius: 8px; }
.hero__card p{ margin: 0; font-size: .82rem; line-height: 1.4; color:#fff; }
@media (max-width: 767.98px){ .hero__card{ display: none; } }
.hero__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/* =====================================================================
   TRUST BAR
   ===================================================================== */
.trust{ background: var(--paper); border-block: 1px solid var(--line); }
.trust .container{ display: flex; align-items: center; flex-wrap: wrap; gap: 1rem 2.4rem; padding-block: 22px; }
.trust__title{ font-family: var(--font-mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin: 0; }
.trust__logos{ display: flex; flex-wrap: wrap; gap: 1.2rem 2.4rem; }
.trust__logos li{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
}
.trust__logos img{
  width: auto;
  height: 28px;
  max-width: 150px;
  object-fit: contain;


  transition: opacity .18s var(--ease), filter .18s var(--ease), transform .18s var(--ease);
}
.trust__logos li:hover img{


  transform: translateY(-2px);
}

/* =====================================================================
   TOURS GRID
   ===================================================================== */
.tour-grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
@media (max-width: 991.98px){ .tour-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px){ .tour-grid{ grid-template-columns: 1fr; } }

.tour-card{
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg);
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.tour-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-lg); border-color: transparent; }
.tour-card__media{ position: relative; display: block; aspect-ratio: 72/52; overflow: hidden; }
.tour-card__media img{ width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.tour-card:hover .tour-card__media img{ transform: scale(1.05); }
.tour-card__flag{
  position: absolute; top: 12px; left: 12px; font-family: var(--font-mono);
  font-size: .66rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 500;
  background: var(--sun); color: var(--ink); padding: .4em .7em; border-radius: var(--r-pill);
}
.tour-card__price{
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(255,255,255,.92); color: var(--ink); backdrop-filter: blur(4px);
  font-size: .78rem; padding: .4em .8em; border-radius: var(--r-pill); box-shadow: var(--shadow-sm);
}
.tour-card__price strong{ font-family: var(--font-display); font-size: .95rem; color: var(--green-dd); }
.tour-card__body{ padding: 1.2rem 1.3rem 1.4rem; display: flex; flex-direction: column; flex: 1; }
.tour-card__title{ font-size: 1.22rem; margin-bottom: .5rem; }
.tour-card__title a{ color: var(--ink); }
.tour-card__title a:hover{ color: var(--green-d); }
.tour-card__text{ color: var(--muted); font-size: .93rem; margin-bottom: 1rem; }
.tour-card__meta{ margin-bottom: .9rem; }
.rating{ display: inline-flex; align-items: center; gap: .35em; color: var(--sun-d); font-size: .9rem; }
.rating strong{ color: var(--ink); font-family: var(--font-display); }
.rating__count{ color: var(--muted); }
.tour-card__foot{ margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: .8rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.tour-card__loc{ display: inline-flex; align-items: center; gap: .35em; color: var(--muted); font-size: .82rem; }
.tour-card__loc svg{ color: var(--green); flex: none; }
.tour-card__link{ display: inline-flex; align-items: center; gap: .35em; font-weight: 600; font-size: .9rem; color: var(--green-d); }
.tour-card__link svg{ transition: transform .2s var(--ease); }
.tour-card__link:hover svg{ transform: translateX(3px); }

/* =====================================================================
   PLAN YOUR DAY
   ===================================================================== */
.section-plan{ position: relative; color:#fff; padding: clamp(64px,9vw,120px) 0; isolation: isolate; }
.plan__bg{ position: absolute; inset: 0; z-index: -1; overflow: hidden; }
.plan__bg img,
.plan__video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.plan__scrim{ position: absolute; inset: 0; background: rgba(7,55,30,.72); }
.plan__head{ max-width: 620px; margin-bottom: clamp(34px,5vw,56px); }
.plan__lead{ color:#dcefdc; }
.plan__steps{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; counter-reset: step; }
@media (max-width: 767.98px){ .plan__steps{ grid-template-columns: 1fr; } }
.plan__step{
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16);
  border-radius: var(--r-lg); padding: 1.6rem 1.5rem; position: relative; backdrop-filter: blur(3px);
}
.plan__num{ font-family: var(--font-mono); font-size: .8rem; color: var(--sun); letter-spacing: .1em; }
.plan__icon{
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 14px; background: var(--grad-sun); color: var(--ink);
  margin: .9rem 0 1rem;
}
.plan__step-title{ color:#fff; font-size: 1.2rem; margin-bottom: .4rem; }
.plan__step-text{ color:#cfe6cf; font-size: .92rem; margin: 0; }

/* =====================================================================
   LOCALS
   ===================================================================== */
.locals__text{ color: var(--ink-soft); margin-bottom: 1.4rem; }
.collage{ position: relative; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 16px; }
.collage img{ width: 100%; border-radius: var(--r); box-shadow: var(--shadow); object-fit: cover; }
.collage__a{ grid-row: span 2; aspect-ratio: 6/7.6; }
.collage__b{ aspect-ratio: 6/5.2; }
.collage__c{ aspect-ratio: 5.6/4.2; }
.check-list{ display: grid; gap: .7rem; margin-bottom: 1.6rem; }
.check-list li{ display: flex; align-items: flex-start; gap: .65em; color: var(--ink-soft); font-weight: 500; }
.check-list svg{ flex: none; margin-top: 3px; color: var(--green); }

/* =====================================================================
   STATS  (dotted-sun signature)
   ===================================================================== */
.stats{ position: relative; overflow: hidden; background: var(--sand-2); }
.stats__sun{
  position: absolute; top: -120px; right: -120px; width: 420px; height: 420px; z-index: 0;
  border-radius: 50%; opacity: .5;
  background:
    radial-gradient(circle, var(--sun) 0 5px, transparent 6px) 0 0 / 30px 30px,
    radial-gradient(circle at center, rgba(242,213,12,.18), transparent 62%);
  -webkit-mask: radial-gradient(circle at center, #000 38%, transparent 70%);
          mask: radial-gradient(circle at center, #000 38%, transparent 70%);
  animation: spin 90s linear infinite;
}
@keyframes spin{ to{ transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce){ .stats__sun{ animation: none; } }
.stats .container{ position: relative; z-index: 1; }
.stats__intro{ color: var(--ink-soft); max-width: 56ch; }
.stats__label{ font-family: var(--font-mono); font-size: .74rem; letter-spacing: .16em; text-transform: uppercase; color: var(--green-d); margin: 1.4rem 0 .4rem; }
.stats__story{ color: var(--ink-soft); max-width: 56ch; margin: 0; }
.stats__cards{ display: grid; gap: 16px; }
.stat{
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--r);
  padding: 1.4rem 1.5rem; box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: .2rem;
}
.stat__value{ font-family: var(--font-display); font-weight: 800; font-size: 2.1rem; color: var(--green-d); letter-spacing: -.02em; }
.stat__label{ color: var(--muted); font-size: .9rem; }

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.testi{ background: var(--paper); }
.testi__grid{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 991.98px){ .testi__grid{ grid-template-columns: 1fr; max-width: 640px; margin-inline: auto; } }
.review{ background: var(--sand); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.6rem 1.6rem 1.4rem; margin: 0; display: flex; flex-direction: column; }
.review__stars{ display: inline-flex; gap: 2px; color: var(--sun-d); margin-bottom: .9rem; }
.review__text{ font-size: 1.02rem; color: var(--ink); margin: 0 0 1.3rem; line-height: 1.55; }
.review__by{ display: flex; align-items: center; gap: .8rem; margin-top: auto; }
.review__avatar{
  width: 44px; height: 44px; border-radius: 50%; flex: none;
  background: var(--grad); color:#fff; display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 700; font-size: 1.1rem;
}
.review__by strong{ display: block; font-family: var(--font-display); }
.review__by em{ font-style: normal; color: var(--muted); font-size: .84rem; }

/* =====================================================================
   FINAL CTA
   ===================================================================== */
.final-cta{ padding-bottom: clamp(64px,9vw,120px); }
.final-cta__panel{
  position: relative; border-radius: var(--r-lg); overflow: hidden;
  background: var(--green-dd);
  box-shadow: var(--shadow-lg); isolation: isolate;
}
.final-cta__imgs{
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: .38;
  overflow: hidden;
}
.final-cta__video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.final-cta__box{
  position: relative;
  z-index: 1;
  padding: clamp(40px,6vw,72px);
  max-width: 640px;
  color:#fff;
}
.final-cta__title{ color:#fff; font-size: clamp(1.8rem,3.4vw,2.8rem); }
.final-cta__text{ color:#e7f6e7; margin-bottom: 1.6rem; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{ background: var(--ink); color: #c7d2c9; padding: clamp(54px,7vw,84px) 0 2rem; }
.footer-logo{ width: 200px; height: auto; margin-bottom: 1.1rem; }
.footer-about{ font-size: .92rem; color:#a9b6ab; max-width: 38ch; }
.footer-rnaat{ font-family: var(--font-mono); font-size: .76rem; color:#8a988c; margin-top: .4rem; }
.footer-social{ display: flex; gap: .6rem; margin-top: 1.1rem; }
.footer-social a{
  width: 40px; height: 40px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.08); color:#fff; transition: background .2s var(--ease), transform .2s var(--ease);
}
.footer-social a:hover{ background: var(--green); transform: translateY(-2px); }
.footer-h{ font-family: var(--font-display); font-size: 1rem; color:#fff; margin-bottom: 1.1rem; letter-spacing: .01em; }
.footer-list{ display: grid; gap: .55rem; }
.footer-list a{ color:#b4c0b6; font-size: .92rem; }
.footer-list a:hover{ color: var(--lime); }
.footer-contact{ display: grid; gap: .8rem; margin-bottom: 1.2rem; }
.footer-contact a{ color:#cdd8cf; font-size: .94rem; }
.footer-contact a:hover{ color: var(--lime); }
.footer-note{ display: block; font-size: .76rem; color:#8a988c; margin-top: 2px; }
.footer-book{ width: 100%; }
.footer-bottom{
  margin-top: clamp(34px,5vw,52px); padding-top: 1.6rem; border-top: 1px solid rgba(255,255,255,.1);
  display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  font-size: .82rem; color:#8a988c;
}

/* Privacy consent */
.privacy-consent{
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 950;
  display: flex;
  justify-content: center;
  pointer-events: none;
}
.privacy-consent[hidden]{
  display: none;
}
.privacy-consent__content{
  width: min(100%, 760px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.1rem;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow-lg);
  pointer-events: auto;
}
.privacy-consent__content p{
  margin: 0;
  color: var(--ink-soft);
  font-size: .92rem;
}
.privacy-consent__content a{
  font-weight: 700;
}
.privacy-consent__content .btn{
  flex: none;
  padding: .65em 1.2em;
}
@media (max-width: 575.98px){
  .privacy-consent{
    left: 12px;
    right: 12px;
    bottom: 12px;
  }
  .privacy-consent__content{
    align-items: stretch;
    flex-direction: column;
  }
  .privacy-consent__content .btn{
    width: 100%;
  }
}

/* Back to top */
.to-top{
  position: fixed; right: 18px; bottom: 18px; z-index: 900;
  width: 46px; height: 46px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center;
  background: var(--ink); color:#fff; box-shadow: var(--shadow);
  opacity: 0; visibility: hidden; transform: translateY(10px);
  transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s, background .2s;
}
.to-top.is-visible{ opacity: 1; visibility: visible; transform: translateY(0); }
.to-top:hover{ background: var(--green-d); color:#fff; }

/* =====================================================================
   INNER PAGES
   ===================================================================== */
.page-hero{
  position: relative; color:#fff; isolation: isolate; padding: clamp(90px,14vh,150px) 0 clamp(48px,7vw,80px);
  background: var(--green-dd);
  overflow: hidden;
}
.page-hero::after{
  content:""; position:absolute; top:-100px; right:-80px; width: 360px; height: 360px; z-index:1; opacity:.5;
  border-radius:50%;
  background: radial-gradient(circle, var(--sun) 0 4px, transparent 5px) 0 0 / 26px 26px;
  -webkit-mask: radial-gradient(circle at center, #000 36%, transparent 70%);
          mask: radial-gradient(circle at center, #000 36%, transparent 70%);
}
.page-hero__video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  display: block;
}

.page-hero__overlay{
  position: absolute;
  inset: 0;
  background: rgba(7,40,22,.48);
  z-index: 1;
}

.page-hero .container{
  position: relative;
  z-index: 2;
}
.page-hero h1{ color:#fff; font-size: clamp(2.1rem,4.6vw,3.4rem); }
.page-hero__lead{ color:#e7f6e7; max-width: 56ch; font-size: 1.1rem; margin: 0; }
.breadcrumbs{ font-family: var(--font-mono); font-size: .76rem; letter-spacing: .06em; color: rgba(255,255,255,.8); margin-bottom: 1rem; display:flex; gap:.5em; flex-wrap: wrap; }
.breadcrumbs a{ color: rgba(255,255,255,.8); }
.breadcrumbs a:hover{ color:#fff; }
.breadcrumbs span{ color: var(--sun); }

/* Prose */
.prose{ max-width: 70ch; }
.prose h2{ font-size: 1.5rem; margin-top: 2rem; }
.prose p{ color: var(--ink-soft); }
.prose .lede{ font-size: 1.15rem; color: var(--ink); }

/* About values */
.values{ display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 1rem; }
@media (max-width: 767.98px){ .values{ grid-template-columns: 1fr; } }
.value{ background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.6rem; box-shadow: var(--shadow-sm); }
.value__icon{ width: 48px; height: 48px; border-radius: 14px; background: var(--grad); color:#fff; display:inline-flex; align-items:center; justify-content:center; margin-bottom: 1rem; }
.value h3{ font-size: 1.2rem; }
.value p{ color: var(--muted); margin: 0; font-size: .94rem; }

.about-split{ display: grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px,5vw,60px); align-items: center; }
@media (max-width: 991.98px){ .about-split{ grid-template-columns: 1fr; } }
.about-split img{ border-radius: var(--r-lg); box-shadow: var(--shadow); width: 100%; }

/* =====================================================================
   TOUR DETAIL
   ===================================================================== */
.tourd{ display: grid; grid-template-columns: 1.6fr .9fr; gap: clamp(28px,4vw,48px); align-items: start; }
@media (max-width: 991.98px){ .tourd{ grid-template-columns: 1fr; } }
.tourd__media{ border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); margin-bottom: 1.8rem; }
.tourd__media img{ width: 100%; aspect-ratio: 72/52; object-fit: cover; }
.tourd__body h2{ font-size: 1.5rem; margin-top: 1.6rem; }
.tourd__body p{ color: var(--ink-soft); }
.tourd__includes{ display: grid; gap: .7rem; margin-top: .6rem; }
.tourd__includes li{ display: flex; align-items: flex-start; gap: .6em; color: var(--ink-soft); }
.tourd__includes svg{ flex: none; margin-top: 3px; color: var(--green); }

.book-card{
  position: sticky; top: 96px; background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: 1.6rem; box-shadow: var(--shadow);
}
.book-card__price{ font-family: var(--font-display); font-weight: 800; font-size: 2.2rem; color: var(--green-d); letter-spacing: -.02em; }
.book-card__price small{ font-size: .9rem; color: var(--muted); font-weight: 400; font-family: var(--font-body); }
.book-card__rating{ margin: .4rem 0 1.2rem; }
.book-meta{ display: grid; gap: .8rem; margin: 1.2rem 0; padding: 1.2rem 0; border-block: 1px solid var(--line); }
.book-meta__row{ display: flex; align-items: center; gap: .7em; color: var(--ink-soft); font-size: .94rem; }
.book-meta__row svg{ color: var(--green); flex: none; }
.book-meta__row strong{ color: var(--ink); }
.book-card .btn{ width: 100%; }
.tour-back{ display: inline-flex; align-items: center; gap: .4em; font-weight: 600; color: var(--green-d); margin-bottom: 1.4rem; }
.tour-back svg{ transition: transform .2s var(--ease); }
.tour-back:hover svg{ transform: translateX(-3px); }

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact-grid{ display: grid; grid-template-columns: 1.3fr .9fr; gap: clamp(28px,4vw,52px); align-items: start; }
@media (max-width: 991.98px){ .contact-grid{ grid-template-columns: 1fr; } }
.form-card{ background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.5rem,3vw,2.2rem); box-shadow: var(--shadow-sm); }
.field{ margin-bottom: 1.1rem; }
.field label{ display: block; font-weight: 600; font-size: .9rem; margin-bottom: .4rem; color: var(--ink); }
.field input, .field textarea{
  width: 100%; font-family: var(--font-body); font-size: 1rem; color: var(--ink);
  background: var(--sand); border: 1.5px solid var(--line); border-radius: var(--r-sm);
  padding: .8rem 1rem; transition: border-color .15s var(--ease), box-shadow .15s var(--ease);
}
.field input:focus, .field textarea:focus{ outline: none; border-color: var(--green); box-shadow: 0 0 0 3px rgba(12,159,69,.15); }
.field textarea{ min-height: 150px; resize: vertical; }
.field--error input, .field--error textarea{ border-color: #d4493c; }
.field__err{ color:#c63a2e; font-size: .82rem; margin: .35rem 0 0; }
.hp-field{ position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note{ font-size: .82rem; color: var(--muted); margin-top: .8rem; }

.alert-flash{ border-radius: var(--r); padding: 1rem 1.2rem; margin-bottom: 1.4rem; font-weight: 500; }
.alert-flash--ok{ background: #e7f7ec; border: 1px solid #bce6c9; color: #176b33; }
.alert-flash--err{ background: #fdecea; border: 1px solid #f5c6c0; color: #b1352a; }

.info-card{ background: var(--sand-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.8rem; }
.info-card h2{ font-size: 1.25rem; }
.info-list{ display: grid; gap: 1.1rem; margin-top: 1.2rem; }
.info-list li{ display: flex; gap: .8em; align-items: flex-start; }
.info-ico{ width: 40px; height: 40px; border-radius: 12px; background: var(--paper); border: 1px solid var(--line); display: inline-flex; align-items: center; justify-content: center; color: var(--green); flex: none; }
.info-list a{ color: var(--ink); font-weight: 500; }
.info-list a:hover{ color: var(--green-d); }
.info-list small{ display: block; color: var(--muted); font-size: .8rem; }

/* =====================================================================
   404 / generic centred
   ===================================================================== */
.centered{ text-align: center; max-width: 540px; margin-inline: auto; padding: clamp(60px,12vw,120px) 0; }
.centered .big{ font-family: var(--font-display); font-weight: 800; font-size: clamp(4rem,14vw,8rem); line-height: 1; color: var(--green); letter-spacing: -.04em; }
.centered p{ color: var(--muted); }

/* Related tours */
.related-grid{ display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; margin-top: 1.4rem; }
@media (max-width: 991.98px){ .related-grid{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 575.98px){ .related-grid{ grid-template-columns: 1fr; } }

/* Reveal on scroll */
.reveal{ opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.is-in{ opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity: 1 !important; transform: none !important; transition: none; } }
