/* =========================================================
   LOS ENCINOS — Design System
   Palette drawn from the brand mark (layered oak canopy, green
   on white) plus two "trail" accents standing in for the two
   things every visitor actually does here: ride/climb (sun) and
   move through the forest at pace (sky).
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,500&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* --- Color: named, not generic --- */
  --pine-950:#0E2A1C;      /* deepest canopy — dark sections, footer */
  --pine-800:#123A26;
  --forest-600:#1B6B3C;    /* primary brand green (logo trunk-canopy) */
  --forest-500:#2C8A4D;
  --leaf-400:#5FB86A;      /* logo mid-green */
  --canopy-300:#9AD98F;    /* logo light green */
  --sun-500:#FF7A3D;       /* vivid — adventure / energy accent */
  --sun-600:#F0602A;
  --sky-500:#159AC0;       /* vivid — trail / motion accent */
  --sky-600:#0C7FA3;
  --paper-50:#FBF9F1;      /* warm paper, used sparingly */
  --paper-0:#FFFFFF;
  --ink-900:#122019;
  --ink-600:#3E4B43;
  --ink-400:#6B776E;
  --line:#DDE6DA;

  --display: 'Bricolage Grotesque', ui-sans-serif, system-ui, sans-serif;
  --body: 'Plus Jakarta Sans', ui-sans-serif, system-ui, sans-serif;
  --mono: 'Space Mono', ui-monospace, monospace;

  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-sm: 8px;
  --shadow-soft: 0 12px 30px -14px rgba(14,42,28,.28);
  --shadow-pop: 0 20px 45px -18px rgba(14,42,28,.38);
  --container: 1180px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth; scroll-padding-top:88px;}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink-900);
  background:var(--paper-0);
  line-height:1.6;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block;}
a{color:inherit;}
h1,h2,h3,h4{font-family:var(--display); margin:0 0 .5em; color:var(--pine-950); line-height:1.06; letter-spacing:-.01em;}
p{margin:0 0 1em; color:var(--ink-600);}
.container{max-width:var(--container); margin:0 auto; padding:0 24px;}
section{position:relative;}
::selection{background:var(--sun-500); color:#fff;}

:focus-visible{outline:3px solid var(--sky-500); outline-offset:3px; border-radius:4px;}

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

/* ---------- Eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--forest-600);
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{content:""; width:20px; height:2px; background:var(--sun-500); display:inline-block; border-radius:2px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--body); font-weight:700; font-size:15.5px;
  padding:14px 26px; border-radius:100px;
  text-decoration:none; cursor:pointer; border:none;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-whatsapp{background:#25D366; color:#06371c; box-shadow:var(--shadow-soft);}
.btn-whatsapp:hover{box-shadow:var(--shadow-pop);}
.btn-primary{background:var(--forest-600); color:#fff; box-shadow:var(--shadow-soft);}
.btn-primary:hover{background:var(--pine-800);}
.btn-outline{background:transparent; color:var(--pine-950); border:2px solid var(--line);}
.btn-outline:hover{border-color:var(--forest-600); color:var(--forest-600);}
.btn-sun{background:var(--sun-500); color:#fff; box-shadow:0 12px 30px -14px rgba(240,96,42,.55);}
.btn-sun:hover{background:var(--sun-600);}
.btn-ghost-light{background:rgba(255,255,255,.14); color:#fff; border:1.5px solid rgba(255,255,255,.4); backdrop-filter:blur(6px);}
.btn-ghost-light:hover{background:rgba(255,255,255,.24);}
.btn svg{width:19px; height:19px; flex-shrink:0;}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(251,249,241,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav-row{display:flex; align-items:center; justify-content:space-between; padding:14px 24px; gap:20px;}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none;}
.brand img{height:40px; width:auto;}
.brand-word{font-family:var(--display); font-weight:700; font-size:19px; color:var(--pine-950);}
.nav-links{display:flex; align-items:center; gap:28px; list-style:none; margin:0; padding:0;}
.nav-links a{
  text-decoration:none; color:var(--ink-600); font-weight:600; font-size:15px;
  padding:6px 2px; border-bottom:2px solid transparent; transition:.15s;
}
.nav-links a:hover, .nav-links a[aria-current="page"]{color:var(--forest-600); border-color:var(--sun-500);}
.nav-actions{display:flex; align-items:center; gap:14px;}
.lang-switch{display:flex; gap:4px; font-family:var(--mono); font-size:12.5px;}
.lang-switch a{padding:5px 9px; border-radius:100px; text-decoration:none; color:var(--ink-400); border:1px solid var(--line);}
.lang-switch a[aria-current="page"]{background:var(--pine-950); color:#fff; border-color:var(--pine-950);}
.nav-toggle{display:none; background:none; border:none; cursor:pointer; padding:8px;}
.nav-toggle svg{width:26px; height:26px; color:var(--pine-950);}

@media (max-width:920px){
  .nav-links{
    position:fixed; inset:70px 14px auto 14px; background:var(--paper-0); border:1px solid var(--line);
    border-radius:var(--radius-md); flex-direction:column; align-items:flex-start; padding:18px 22px;
    box-shadow:var(--shadow-pop); gap:14px; display:none;
  }
  .nav-links.open{display:flex;}
  .nav-toggle{display:inline-flex;}
  .nav-actions .btn-whatsapp span{display:none;}
}

/* ---------- Floating WhatsApp ---------- */
.float-whatsapp{
  position:fixed; right:20px; bottom:20px; z-index:200;
  width:60px; height:60px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 30px -10px rgba(6,55,28,.5);
  text-decoration:none;
  animation:pulse-wa 2.6s ease-in-out infinite;
}
.float-whatsapp svg{width:30px; height:30px; color:#0a3d1f;}
@keyframes pulse-wa{0%,100%{transform:scale(1);}50%{transform:scale(1.06);}}

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden;
  background:linear-gradient(175deg, var(--pine-950) 0%, var(--pine-800) 46%, var(--forest-600) 130%);
  color:#fff;
  padding:64px 0 0;
}
.hero-blob{
  position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; z-index:0;
}
.hero-blob.b1{width:420px; height:420px; background:var(--sun-500); top:-160px; right:-120px; opacity:.35;}
.hero-blob.b2{width:340px; height:340px; background:var(--sky-500); bottom:-140px; left:-100px; opacity:.3;}
.hero-inner{position:relative; z-index:2; display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; padding-bottom:70px;}
.hero h1{color:#fff; font-size:clamp(34px,4.6vw,58px); max-width:640px;}
.hero .lede{color:#D9E9DA; font-size:19px; max-width:520px;}
.hero-ctas{display:flex; gap:14px; flex-wrap:wrap; margin-top:26px;}
.hero-art{
  aspect-ratio:4/5; border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.14), transparent 55%),
    linear-gradient(150deg, var(--forest-500), var(--pine-800));
  display:flex; align-items:center; justify-content:center; position:relative;
  border:1px solid rgba(255,255,255,.15);
}
.hero-art .ph-icon{width:34%; height:34%; color:rgba(255,255,255,.5);}
.hero-art .ph-caption{
  position:absolute; bottom:18px; left:18px; right:18px;
  font-family:var(--mono); font-size:11.5px; color:rgba(255,255,255,.65);
  border-top:1px solid rgba(255,255,255,.2); padding-top:10px;
}
.hero-art.photo-slot img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  border-radius:inherit; display:none;
}
.hero-art.photo-slot.has-photo img{display:block;}
.hero-art.photo-slot.has-photo .ph-icon,
.hero-art.photo-slot.has-photo .ph-caption{display:none;}
.stat-row{
  position:relative; z-index:2;
  display:grid; grid-template-columns:repeat(4,1fr);
  background:rgba(255,255,255,.06); border-top:1px solid rgba(255,255,255,.16);
}
.stat{padding:20px 18px; border-right:1px solid rgba(255,255,255,.14);}
.stat:last-child{border-right:none;}
.stat .num{font-family:var(--mono); font-size:clamp(20px,2.4vw,28px); color:#fff; font-weight:700;}
.stat .lbl{font-size:12.5px; color:#BFE0C4; margin-top:2px;}

@media (max-width:860px){
  .hero-inner{grid-template-columns:1fr; padding-bottom:36px;}
  .hero-art{aspect-ratio:16/10;}
  .stat-row{grid-template-columns:repeat(2,1fr);}
  .stat:nth-child(2){border-right:none;}
  .stat{border-bottom:1px solid rgba(255,255,255,.14);}
}

/* ---------- Trail divider (signature element) ---------- */
.trail-divider{display:block; width:100%; height:auto; margin:-1px 0;}
.trail-divider path{vector-effect:non-scaling-stroke;}

/* ---------- Section scaffolding ---------- */
.section{padding:88px 0;}
.section-tight{padding:56px 0;}
.section-alt{background:var(--paper-50);}
.section-dark{background:var(--pine-950); color:#fff;}
.section-dark h2, .section-dark h3{color:#fff;}
.section-dark p{color:#BFD3C2;}
.section-head{max-width:640px; margin-bottom:44px;}
.section-head.center{margin-left:auto; margin-right:auto; text-align:center;}

/* ---------- Audience cards ---------- */
.audience-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
.audience-card{
  border-radius:var(--radius-lg); padding:28px 24px; border:1px solid var(--line);
  background:var(--paper-0); box-shadow:var(--shadow-soft);
  transition:transform .2s ease, box-shadow .2s ease;
}
.audience-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-pop);}
.audience-card .icon-wrap{
  width:54px; height:54px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:18px;
}
.audience-card .icon-wrap svg{width:28px; height:28px; color:#fff;}
.audience-card h3{font-size:20px;}
.audience-card p{font-size:14.5px;}
.audience-card ul{margin:0 0 16px; padding-left:18px; font-size:14px; color:var(--ink-600);}
.audience-card ul li{margin-bottom:5px;}
.audience-card a.card-link{font-size:14px; font-weight:700; color:var(--pine-950); text-decoration:none; display:inline-flex; align-items:center; gap:6px;}
.audience-card a.card-link svg{width:16px; height:16px; transition:transform .15s;}
.audience-card a.card-link:hover svg{transform:translateX(3px);}

.aud-schools .icon-wrap{background:var(--sky-500);}
.aud-business .icon-wrap{background:var(--forest-600);}
.aud-mtb .icon-wrap{background:var(--sun-500);}
.aud-families .icon-wrap{background:var(--leaf-400);}

@media (max-width:1000px){.audience-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.audience-grid{grid-template-columns:1fr;}}
.audience-grid.cols-3{grid-template-columns:repeat(3,1fr);}
@media (max-width:1000px){.audience-grid.cols-3{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.audience-grid.cols-3{grid-template-columns:1fr;}}

/* ---------- Activity gallery blocks ---------- */
.activity-block{padding:60px 0; border-bottom:1px solid var(--line);}
.activity-block:last-child{border-bottom:none;}
.activity-head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-bottom:26px;}
.activity-head .icon-badge{
  width:46px; height:46px; border-radius:14px; display:inline-flex; align-items:center; justify-content:center; margin-bottom:10px;
}
.activity-head .icon-badge svg{width:24px; height:24px; color:#fff;}
.gallery-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:14px;}
.gallery-grid.cols-3{grid-template-columns:repeat(3,1fr);}
.ph-tile{
  aspect-ratio:1/1; border-radius:var(--radius-md); position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line);
}
.ph-tile svg{width:30%; height:30%; color:rgba(255,255,255,.65);}
.ph-tile .tile-label{
  position:absolute; left:10px; bottom:8px; font-family:var(--mono); font-size:10.5px; color:rgba(255,255,255,.85);
}
.ph-tile.photo-slot img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:none;
}
.ph-tile.photo-slot.has-photo img{display:block;}
.ph-tile.photo-slot.has-photo svg,
.ph-tile.photo-slot.has-photo .tile-label{display:none;}
@media (max-width:900px){.gallery-grid, .gallery-grid.cols-3{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.gallery-grid, .gallery-grid.cols-3{grid-template-columns:1fr 1fr;}}

/* activity tint variants for placeholder tiles */
.tint-a{background:linear-gradient(150deg,var(--forest-500),var(--pine-800));}
.tint-b{background:linear-gradient(150deg,var(--sky-500),var(--pine-800));}
.tint-c{background:linear-gradient(150deg,var(--sun-500),#8a3a17);}
.tint-d{background:linear-gradient(150deg,var(--leaf-400),var(--forest-600));}
.tint-e{background:linear-gradient(150deg,var(--canopy-300),var(--forest-500));}
.tint-f{background:linear-gradient(150deg,#7a5cff,var(--pine-800));}

/* ---------- Testimonials ---------- */
.testi-wrap{max-width:760px; margin:0 auto; text-align:center;}
.testi-slide{display:none;}
.testi-slide.active{display:block; animation:fadeIn .5s ease;}
@keyframes fadeIn{from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);}}
.testi-quote{font-family:var(--display); font-size:clamp(20px,2.6vw,27px); color:var(--pine-950); font-weight:600; line-height:1.35; margin-bottom:18px;}
.testi-quote::before{content:"“"; color:var(--sun-500);}
.testi-quote::after{content:"”"; color:var(--sun-500);}
.testi-who{font-family:var(--mono); font-size:13px; color:var(--ink-400);}
.testi-dots{display:flex; justify-content:center; gap:8px; margin-top:26px;}
.testi-dots button{width:9px; height:9px; border-radius:50%; border:none; background:var(--line); cursor:pointer; padding:0;}
.testi-dots button.active{background:var(--sun-500); width:22px; border-radius:6px; transition:.2s;}

/* ---------- Package / group cards ---------- */
.package-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:22px;}
.package-card{
  border-radius:var(--radius-lg); border:1px solid var(--line); overflow:hidden; background:var(--paper-0);
  display:flex; flex-direction:column; box-shadow:var(--shadow-soft);
}
.package-card .p-head{padding:26px 26px 0;}
.package-card .p-tag{
  display:inline-block; font-family:var(--mono); font-size:11.5px; text-transform:uppercase; letter-spacing:.06em;
  color:#fff; padding:5px 12px; border-radius:100px; margin-bottom:14px;
}
.package-card .p-body{padding:0 26px 26px; flex:1; display:flex; flex-direction:column;}
.package-card ul{padding-left:18px; margin:0 0 20px; font-size:14.5px;}
.package-card ul li{margin-bottom:8px;}
.package-card .p-foot{margin-top:auto; display:flex; gap:10px; flex-wrap:wrap;}
@media (max-width:820px){.package-grid{grid-template-columns:1fr;}}

/* ---------- Map / contact ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:34px; align-items:start;}
.map-frame{border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-soft);}
.map-frame iframe{width:100%; height:420px; border:0; display:block;}
.contact-card{background:var(--paper-50); border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px;}
.info-row{display:flex; gap:14px; align-items:flex-start; margin-bottom:18px;}
.info-row svg{width:22px; height:22px; color:var(--forest-600); flex-shrink:0; margin-top:2px;}
.info-row .label{font-family:var(--mono); font-size:11.5px; text-transform:uppercase; color:var(--ink-400); letter-spacing:.06em;}
.info-row .value{font-weight:600; color:var(--pine-950);}
form.contact-form{display:flex; flex-direction:column; gap:14px; margin-top:10px;}
form.contact-form label{font-size:13.5px; font-weight:700; color:var(--pine-950); margin-bottom:-8px;}
form.contact-form input, form.contact-form select, form.contact-form textarea{
  font-family:var(--body); font-size:16px; padding:12px 14px; border-radius:var(--radius-sm);
  border:1.5px solid var(--line); background:#fff; resize:vertical;
}
form.contact-form input:focus, form.contact-form select:focus, form.contact-form textarea:focus{border-color:var(--forest-600);}
.form-note{font-size:13px; color:var(--ink-400); margin-top:2px;}
#form-status{font-size:14px; font-weight:700; min-height:20px;}
#form-status.ok{color:var(--forest-600);}
#form-status.err{color:var(--sun-600);}

@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}

/* ---------- Footer ---------- */
footer.site-footer{background:var(--pine-950); color:#BFD3C2; padding:56px 0 26px;}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:34px; margin-bottom:34px;}
.footer-grid h4{color:#fff; font-size:15px; margin-bottom:14px;}
.footer-grid ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:9px;}
.footer-grid a{color:#BFD3C2; text-decoration:none; font-size:14.5px;}
.footer-grid a:hover{color:#fff;}
.footer-brand{display:flex; align-items:center; gap:10px; margin-bottom:14px;}
.footer-brand img{height:36px;}
.footer-brand span{font-family:var(--display); font-weight:700; color:#fff; font-size:18px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14); padding-top:20px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:13px; color:#7E9585;}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr;}}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1; transform:translateY(0);}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{
  background:linear-gradient(175deg, var(--pine-950), var(--forest-600) 150%);
  color:#fff; padding:56px 0 46px;
}
.page-hero h1{color:#fff; font-size:clamp(30px,4vw,46px); max-width:700px;}
.page-hero p{color:#D9E9DA; max-width:560px; font-size:17.5px;}
.crumb{font-family:var(--mono); font-size:12px; color:#9FC7A6; margin-bottom:12px;}
.crumb a{color:#9FC7A6; text-decoration:none;}
.crumb a:hover{color:#fff;}

/* utility */
.center{text-align:center;}
.mt-0{margin-top:0;}
.max-60{max-width:600px;}
.max-70{max-width:700px;}
