/* =================================================================
   Travel & Tours — Pereira / Eje Cafetero
   Mobile-first · compacto · premium
   ================================================================= */

/* ---------- TOKENS ---------- */
:root{
  --forest:#143427;        /* verde café profundo */
  --forest-2:#1d4a35;
  --green:#2f6b4c;         /* verde montaña */
  --moss:#4f9d69;
  --cream:#faf5ea;
  --cream-2:#f4ecda;
  --beige:#e8dabf;
  --coffee:#4a2e1e;        /* café tostado */
  --gold:#cda349;          /* dorado suave */
  --gold-2:#e3c074;
  --terra:#c8603a;         /* terracota */
  --terra-2:#e07f4e;
  --wa:#1ca64f;            /* acción / WhatsApp */
  --wa-2:#24c463;

  --ink:#20281e;
  --ink-soft:#566153;
  --line:rgba(20,52,39,.12);
  --white:#ffffff;

  --r-xs:10px; --r-sm:14px; --r:18px; --r-lg:26px; --r-pill:999px;

  --sh-sm:0 2px 8px rgba(20,52,39,.08);
  --sh:0 10px 30px -12px rgba(20,52,39,.28);
  --sh-lg:0 26px 60px -22px rgba(20,52,39,.42);

  --maxw:1180px;
  --pad-x:clamp(1.05rem,4.4vw,2rem);
  --pad-sec:clamp(2.7rem,7vw,5.2rem);

  --h1:clamp(2rem,7.4vw,3.5rem);
  --h2:clamp(1.45rem,4.6vw,2.35rem);
  --lead:clamp(.99rem,2.5vw,1.14rem);

  --hdr-h:60px;
  --ease:cubic-bezier(.22,.61,.36,1);

  --bg-hero:linear-gradient(135deg,#1d4a35,#143427);
  --bg-raices:linear-gradient(135deg,#2f6b4c,#143427);
  --bg-premium:linear-gradient(135deg,#1d4a35,#0f2419);
  --bg-cta:linear-gradient(135deg,#2f6b4c,#143427);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;line-height:1.08;font-weight:600;letter-spacing:-.01em}
input,output{font:inherit}
:focus-visible{outline:2.5px solid var(--gold);outline-offset:3px;border-radius:6px}
::selection{background:var(--gold-2);color:var(--forest)}
section{scroll-margin-top:calc(var(--hdr-h) + 8px)}

.icon{width:1.15em;height:1.15em;flex:none;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.sec{padding-block:var(--pad-sec);position:relative}
.sec--cream{background:
  radial-gradient(120% 80% at 100% 0,rgba(205,163,73,.06),transparent 60%),
  var(--cream)}
.muted{color:var(--ink-soft);font-weight:500}
.hl{color:var(--terra-2)}
.sec--cream .hl,.raices .hl{color:var(--terra)}

.skip-link{position:fixed;top:-60px;left:12px;z-index:200;background:var(--forest);color:#fff;
  padding:.6rem 1rem;border-radius:0 0 var(--r-sm) var(--r-sm);transition:top .2s}
.skip-link:focus{top:0}

/* ---------- KICKER / HEADINGS ---------- */
.kicker{display:inline-flex;align-items:center;gap:.4rem;font-family:"Plus Jakarta Sans";
  font-weight:700;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--green);margin-bottom:.55rem}
.kicker .icon{width:1rem;height:1rem;color:var(--gold)}
.kicker--gold{color:var(--gold-2)}
.sec__title{font-size:var(--h2);color:var(--forest);text-wrap:balance}
.sec__title--light{color:var(--cream)}
.sec__head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.3rem}
.sec__head--center{flex-direction:column;align-items:center;text-align:center;gap:0}
.lead{font-size:var(--lead);color:var(--ink-soft);max-width:46ch}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:700;font-size:.94rem;line-height:1;border-radius:var(--r-pill);
  padding:.85rem 1.25rem;min-height:46px;white-space:nowrap;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  will-change:transform}
.btn .icon{width:1.2em;height:1.2em}
.btn:active{transform:scale(.96)}
.btn--lg{padding:1rem 1.5rem;font-size:1rem;min-height:54px}
.btn--block{width:100%}
.btn--wa{background:linear-gradient(180deg,var(--wa-2),var(--wa));color:#fff;
  box-shadow:0 12px 24px -10px rgba(28,166,79,.7)}
.btn--wa .icon{stroke-width:1.6}
.btn--wa:hover{box-shadow:0 16px 30px -10px rgba(28,166,79,.85);transform:translateY(-2px)}
.btn--solid{background:var(--forest);color:var(--cream)}
.btn--solid:hover{background:var(--forest-2);transform:translateY(-2px);box-shadow:var(--sh)}
.btn--ghost{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.5);
  backdrop-filter:blur(6px)}
.btn--ghost:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}

.chip{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:600;
  padding:.45rem .8rem;border-radius:var(--r-pill)}
.chip .icon{width:1rem;height:1rem;color:var(--gold-2)}
.chip--glass{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(8px)}

.badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.74rem;font-weight:700;
  padding:.5rem .8rem;border-radius:var(--r-pill);background:var(--white);color:var(--forest);
  box-shadow:var(--sh);letter-spacing:.01em}
.badge .icon{width:1.05rem;height:1.05rem;color:var(--gold)}

/* ---------- REVEAL ---------- */
.js [data-reveal]{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js [data-reveal].is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js [data-reveal]{opacity:1!important;transform:none!important;transition:none}
}

/* =================================================================
   LOADER
   ================================================================= */
.loader{position:fixed;inset:0;z-index:300;display:grid;place-content:center;justify-items:center;gap:.2rem;
  background:radial-gradient(120% 120% at 50% 30%,#1d4a35,#0f2419);
  transition:opacity .6s var(--ease),visibility .6s}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.loader__svg{width:min(64vw,230px);height:auto;overflow:visible}
.loader__mtn{fill:none;stroke:rgba(255,255,255,.22);stroke-width:2}
.loader__road{fill:none;stroke:var(--gold);stroke-width:2.5;stroke-dasharray:6 8;
  stroke-dashoffset:200;animation:dash 1.6s linear infinite}
.loader__van{color:var(--cream);offset-path:path("M18 104 C70 92 130 116 184 100");
  offset-rotate:auto;animation:drive 1.8s var(--ease) infinite}
.loader__van .icon{stroke-width:1.7}
.loader__sun{fill:var(--terra-2);opacity:.9;animation:pulse 1.8s ease-in-out infinite}
.loader__brand{font-family:"Fraunces",serif;color:var(--cream);font-size:1.5rem;margin-top:.6rem;font-weight:600}
.loader__brand span{color:var(--gold-2)}
.loader__tag{color:rgba(250,245,234,.6);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase}
@keyframes dash{to{stroke-dashoffset:0}}
@keyframes drive{0%{offset-distance:0%}100%{offset-distance:100%}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.18);opacity:1}}
@media (prefers-reduced-motion:reduce){
  .loader__road,.loader__van,.loader__sun{animation:none}
  .loader__van{offset-distance:60%}
}

/* =================================================================
   HEADER / NAV
   ================================================================= */
.hdr{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--hdr-h);
  display:flex;align-items:center;transition:background .3s,box-shadow .3s,backdrop-filter .3s}
.hdr.is-scrolled{background:rgba(250,245,234,.86);backdrop-filter:blur(12px) saturate(140%);
  box-shadow:0 1px 0 var(--line),0 10px 24px -20px rgba(20,52,39,.5)}
.hdr__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);
  display:flex;align-items:center;gap:1rem}

.brand{display:flex;align-items:center;gap:.55rem;margin-right:auto}
.brand__mark{display:grid;place-content:center;width:38px;height:38px;border-radius:11px;
  background:linear-gradient(150deg,var(--green),var(--forest));box-shadow:var(--sh-sm);flex:none}
.brand__mark svg{width:24px;height:24px;fill:none;stroke:var(--cream);stroke-width:2;stroke-linejoin:round}
.brand__mark .bm-sun{fill:var(--gold-2);stroke:none}
.brand__name{font-family:"Fraunces",serif;font-weight:600;font-size:1.12rem;color:var(--forest);line-height:1}
.brand__name em{font-style:normal;color:var(--terra)}
.brand__sub{display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-top:.18rem}
.hdr:not(.is-scrolled) .brand__name{color:#fff}
.hdr:not(.is-scrolled) .brand__name em{color:var(--gold-2)}
.hdr:not(.is-scrolled) .brand__sub{color:rgba(255,255,255,.7)}

.nav{display:none}
.nav__link{font-weight:600;font-size:.92rem;padding:.4rem .2rem;position:relative;color:var(--forest)}
.hdr:not(.is-scrolled) .nav__link{color:rgba(255,255,255,.92)}
.nav__link::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:var(--terra);transition:right .25s var(--ease)}
.nav__link:hover::after{right:0}

.hdr__cta{display:none}
.hdr__burger{display:grid;place-content:center;width:44px;height:44px;border-radius:12px;color:var(--forest);
  background:rgba(255,255,255,.5)}
.hdr:not(.is-scrolled) .hdr__burger{color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25)}
.hdr__burger .icon{width:24px;height:24px}

.nav-scrim{position:fixed;inset:0;z-index:90;background:rgba(15,36,25,.5);backdrop-filter:blur(2px);
  opacity:0;transition:opacity .3s}
.nav-scrim.is-open{opacity:1}

@media (min-width:920px){
  .nav{display:flex;align-items:center;gap:1.6rem;margin-right:1.2rem}
  .hdr__cta{display:inline-flex}
  .hdr__burger{display:none}
  .brand{margin-right:1.4rem}
  .nav{margin-left:auto;margin-right:1.2rem}
}

/* mobile menu panel */
.nav.is-open{
  display:flex;flex-direction:column;gap:.2rem;
  position:fixed;top:calc(var(--hdr-h) + 8px);left:12px;right:12px;z-index:95;
  background:var(--cream);border-radius:var(--r-lg);padding:.8rem;
  box-shadow:var(--sh-lg);border:1px solid var(--line);
  animation:drop .28s var(--ease)}
.nav.is-open .nav__link{color:var(--forest);padding:.85rem 1rem;border-radius:var(--r-sm);font-size:1.02rem}
.nav.is-open .nav__link::after{display:none}
.nav.is-open .nav__link:hover{background:var(--cream-2)}
@keyframes drop{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}

/* =================================================================
   HERO
   ================================================================= */
.hero{position:relative;min-height:clamp(580px,92svh,840px);display:flex;flex-direction:column;
  justify-content:flex-end;padding-top:calc(var(--hdr-h) + 1rem);overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:-6% 0 0 0;z-index:-3;background-image:var(--bg-hero);
  background-size:cover;background-position:center;transform:scale(1.06);will-change:transform}
.hero__veil{position:absolute;inset:0;z-index:-2;background:
  linear-gradient(180deg,rgba(15,36,25,.55) 0%,rgba(15,36,25,.18) 30%,rgba(15,36,25,.5) 70%,rgba(15,36,25,.92) 100%)}
.hero__ridge{position:absolute;left:0;right:0;bottom:-1px;z-index:-1;width:100%;height:clamp(60px,12vw,140px);
  fill:var(--cream)}
.hero__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);
  padding-bottom:.4rem;color:#fff}
.hero__title{font-size:var(--h1);font-weight:600;max-width:16ch;margin:.7rem 0 .6rem;
  text-shadow:0 2px 24px rgba(0,0,0,.28)}
.hero__sub{font-size:var(--lead);max-width:42ch;color:rgba(255,255,255,.92);margin-bottom:1.1rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1.1rem}
.hero__cta .btn{flex:1 1 auto}
.hero__trust{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;list-style:none;padding:0}
.hero__trust li{display:inline-flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:rgba(255,255,255,.92)}
.hero__trust .icon{width:1.15rem;height:1.15rem;color:var(--gold-2)}

.hero__stats{position:relative;z-index:1;width:100%;max-width:var(--maxw);margin:0 auto;
  padding:0 var(--pad-x);display:flex;gap:.6rem;margin-top:1.1rem;margin-bottom:1.4rem}
.stat{flex:1;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(8px);border-radius:var(--r-sm);padding:.7rem .5rem;text-align:center;color:#fff}
.stat b{display:flex;align-items:center;justify-content:center;gap:.15rem;font-family:"Fraunces",serif;
  font-size:1.35rem;font-weight:600;line-height:1}
.stat span{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.stat__star{width:.95rem;height:.95rem;color:var(--gold-2);fill:var(--gold-2);stroke:none}

@media (min-width:680px){
  .hero{justify-content:center}
  .hero__cta .btn{flex:0 0 auto}
  .hero__stats{position:absolute;bottom:1.6rem;left:0;right:0;max-width:420px;margin-inline:auto}
}
@media (min-width:920px){
  .hero__stats{left:auto;right:var(--pad-x);margin:0;max-width:380px;bottom:2rem}
}

/* =================================================================
   BENEFICIOS
   ================================================================= */
.ben-grid{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.ben{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:1rem .9rem;
  box-shadow:var(--sh-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.ben:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.ben__ic{display:grid;place-content:center;width:42px;height:42px;border-radius:12px;margin-bottom:.6rem;
  background:linear-gradient(150deg,rgba(79,157,105,.18),rgba(205,163,73,.16));color:var(--green)}
.ben__ic .icon{width:22px;height:22px}
.ben h3{font-size:1rem;color:var(--forest);margin-bottom:.2rem}
.ben p{font-size:.82rem;color:var(--ink-soft);line-height:1.45}
@media (min-width:720px){.ben-grid{grid-template-columns:repeat(3,1fr);gap:1rem}.ben{padding:1.3rem 1.1rem}.ben p{font-size:.88rem}}

/* =================================================================
   RAÍCES
   ================================================================= */
.raices{background:
  radial-gradient(100% 60% at 0 0,rgba(47,107,76,.08),transparent 55%),var(--cream-2)}
.raices__grid{display:grid;gap:1.4rem}
.raices__media{position:relative}
.raices__img{aspect-ratio:4/3;border-radius:var(--r-lg);background-image:var(--bg-raices);
  background-size:cover;background-position:center;box-shadow:var(--sh-lg)}
.badge--unesco{position:absolute;left:.8rem;bottom:.8rem}
.raices__body{display:flex;flex-direction:column;align-items:flex-start;gap:.55rem}
.facts{list-style:none;padding:0;display:flex;gap:.5rem;width:100%;margin:.3rem 0 .4rem}
.facts li{flex:1;background:var(--white);border:1px solid var(--line);border-radius:var(--r-sm);
  padding:.7rem .4rem;text-align:center;box-shadow:var(--sh-sm)}
.facts b{display:block;font-family:"Fraunces",serif;font-size:1.3rem;color:var(--terra);line-height:1}
.facts span{font-size:.68rem;color:var(--ink-soft);letter-spacing:.04em}
@media (min-width:820px){
  .raices__grid{grid-template-columns:1.05fr 1fr;align-items:center;gap:2.4rem}
  .raices__img{aspect-ratio:5/6}
}

/* =================================================================
   DESTINOS — tabs + carrusel
   ================================================================= */
.tabs{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;padding-bottom:.3rem;margin-bottom:1.1rem}
.tabs::-webkit-scrollbar{display:none}
.tab{flex:none;font-weight:700;font-size:.84rem;padding:.55rem 1rem;border-radius:var(--r-pill);
  background:var(--white);color:var(--ink-soft);border:1px solid var(--line);transition:.2s var(--ease)}
.tab.is-active{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.tab:not(.is-active):hover{color:var(--forest);border-color:var(--green)}

.carousel{position:relative;margin-inline:calc(var(--pad-x) * -1);padding-inline:var(--pad-x);
  perspective:1100px}
.carousel__track{display:flex;gap:.85rem;overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding:.5rem .2rem 1rem;-webkit-overflow-scrolling:touch}
.carousel__track::-webkit-scrollbar{display:none}
.carousel__nav{display:none;gap:.4rem}
.cbtn{width:42px;height:42px;border-radius:50%;display:grid;place-content:center;background:var(--white);
  border:1px solid var(--line);color:var(--forest);box-shadow:var(--sh-sm);transition:.2s var(--ease)}
.cbtn:hover{background:var(--forest);color:#fff;transform:translateY(-2px)}
.cbtn:first-child .icon{transform:rotate(180deg)}
.swipe-hint{display:flex;align-items:center;gap:.4rem;justify-content:center;color:var(--ink-soft);
  font-size:.78rem;font-weight:600;margin-top:.2rem}
.swipe-hint .icon{width:1rem;height:1rem;animation:nudge 1.4s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
@media (prefers-reduced-motion:reduce){.swipe-hint .icon{animation:none}}

.dcard{flex:0 0 78%;max-width:300px;scroll-snap-align:start;background:var(--white);
  border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh);
  transition:box-shadow .3s var(--ease);transform-style:preserve-3d;will-change:transform}
.dcard:hover{box-shadow:var(--sh-lg)}
.dcard__media{position:relative;aspect-ratio:4/3;background:var(--cream-2);overflow:hidden}
.dcard__media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.dcard:hover .dcard__media img{transform:scale(1.07)}
.dcard__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(15,36,25,.5))}
.dcard__cat{position:absolute;top:.6rem;left:.6rem;z-index:1;font-size:.66rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;padding:.32rem .6rem;border-radius:var(--r-pill);
  background:rgba(250,245,234,.92);color:var(--forest)}
.dcard__body{padding:.85rem .9rem 1rem;transform:translateZ(20px)}
.dcard__body h3{font-size:1.08rem;color:var(--forest);margin-bottom:.2rem}
.dcard__body p{font-size:.82rem;color:var(--ink-soft);line-height:1.45;min-height:2.3em}
.dcard__meta{display:flex;flex-wrap:wrap;gap:.4rem;margin:.6rem 0 .7rem}
.dcard__meta span{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:600;
  color:var(--green);background:rgba(47,107,76,.1);padding:.28rem .55rem;border-radius:var(--r-pill)}
.dcard__meta .icon{width:.9rem;height:.9rem}
.dcard__add{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.84rem;
  color:var(--forest);padding:.55rem .9rem;border-radius:var(--r-pill);border:1.5px solid var(--green);
  transition:.2s var(--ease)}
.dcard__add .icon{width:1.05rem;height:1.05rem;transition:transform .3s var(--ease)}
.dcard__add:hover{background:var(--green);color:#fff}
.dcard__add.is-added{background:var(--forest);color:#fff;border-color:var(--forest)}
.dcard__add.is-added .icon{transform:rotate(135deg)}
@media (min-width:620px){.dcard{flex-basis:46%}}
@media (min-width:920px){
  .dcard{flex-basis:31%}
  .carousel__nav{display:flex}
  .swipe-hint{display:none}
}
@media (min-width:1180px){.dcard{flex-basis:23.5%}}

/* =================================================================
   SERVICIOS (dark)
   ================================================================= */
.servicios{background:
  radial-gradient(110% 70% at 100% 0,rgba(205,163,73,.14),transparent 55%),
  linear-gradient(160deg,var(--forest-2),var(--forest))}
.serv-grid{list-style:none;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;margin-top:1.4rem}
.serv{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);
  padding:1rem .85rem;transition:transform .25s var(--ease),background .25s}
.serv:hover{transform:translateY(-4px);background:rgba(255,255,255,.1)}
.serv__ic{display:grid;place-content:center;width:40px;height:40px;border-radius:11px;margin-bottom:.55rem;
  background:linear-gradient(150deg,rgba(205,163,73,.22),rgba(224,127,78,.16));color:var(--gold-2)}
.serv__ic .icon{width:21px;height:21px}
.serv h3{font-size:.95rem;color:var(--cream);margin-bottom:.15rem}
.serv p{font-size:.78rem;color:rgba(250,245,234,.62);line-height:1.4}
@media (min-width:560px){.serv-grid{grid-template-columns:repeat(3,1fr)}}
@media (min-width:980px){.serv-grid{grid-template-columns:repeat(5,1fr);gap:1rem}}

/* =================================================================
   ARMA TU RECORRIDO
   ================================================================= */
.armar__grid{display:grid;gap:1.4rem}
.armar__intro .lead{margin-bottom:1rem}
.armar__steps{list-style:none;padding:0;display:flex;flex-direction:column;gap:.6rem}
.armar__steps li{display:flex;align-items:center;gap:.7rem;font-weight:600;font-size:.9rem;color:var(--forest)}
.armar__steps span{display:grid;place-content:center;width:28px;height:28px;border-radius:50%;flex:none;
  background:var(--forest);color:var(--cream);font-family:"Fraunces",serif;font-size:.9rem}

.builder{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.1rem,4vw,1.6rem);box-shadow:var(--sh-lg);display:flex;flex-direction:column;gap:1rem}
.field{display:flex;flex-direction:column;gap:.5rem}
.field>label{display:flex;align-items:center;gap:.45rem;font-weight:700;font-size:.86rem;color:var(--forest)}
.field>label .icon{width:1.1rem;height:1.1rem;color:var(--green)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.chips{display:flex;gap:.45rem;overflow-x:auto;scrollbar-width:none;padding-bottom:.2rem}
.chips::-webkit-scrollbar{display:none}
.chips--wrap{flex-wrap:wrap;overflow:visible}
.chip-sel{flex:none;font-weight:600;font-size:.82rem;padding:.5rem .85rem;border-radius:var(--r-pill);
  background:var(--cream);color:var(--ink-soft);border:1.5px solid var(--line);transition:.18s var(--ease)}
.chip-sel:hover{border-color:var(--green);color:var(--forest)}
.chip-sel.is-active{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.chip-sel.is-active::before{content:"✓ ";font-weight:800}
input[type=date]{width:100%;padding:.7rem .85rem;border-radius:var(--r-sm);border:1.5px solid var(--line);
  background:var(--cream);color:var(--forest);font-weight:600;min-height:46px}
input[type=date]:focus{border-color:var(--green);background:#fff}
.stepper{display:flex;align-items:center;justify-content:space-between;background:var(--cream);
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.25rem;min-height:46px}
.step{width:38px;height:38px;border-radius:10px;display:grid;place-content:center;background:#fff;
  color:var(--forest);box-shadow:var(--sh-sm);transition:.15s}
.step:hover{background:var(--forest);color:#fff}
.step .icon{width:20px;height:20px}
.stepper output{font-family:"Fraunces",serif;font-size:1.25rem;font-weight:600;color:var(--forest)}
.builder__note{text-align:center;font-size:.76rem;color:var(--ink-soft);margin-top:-.2rem}
@media (min-width:820px){.armar__grid{grid-template-columns:1fr 1.1fr;align-items:start;gap:2.4rem}}

/* =================================================================
   PREMIUM
   ================================================================= */
.premium{position:relative;overflow:hidden;isolation:isolate;color:#fff}
.premium__bg{position:absolute;inset:0;z-index:-3;background-image:var(--bg-premium);
  background-size:cover;background-position:center;transform:scale(1.05)}
.premium__veil{position:absolute;inset:0;z-index:-2;background:linear-gradient(120deg,rgba(15,36,25,.9),rgba(15,36,25,.62))}
.premium__head{max-width:30ch;margin-bottom:1.3rem}
.premium__list{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1rem}
.premium__list li{display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.88rem;
  color:rgba(255,255,255,.95)}
.premium__list .icon{width:1.4rem;height:1.4rem;flex:none;color:var(--forest);background:var(--gold-2);
  border-radius:50%;padding:.18rem;stroke-width:2.6}
@media (min-width:760px){.premium__list{grid-template-columns:repeat(3,1fr);gap:1rem 1.6rem}.premium__list li{font-size:.95rem}}

/* =================================================================
   GALERÍA (marquee)
   ================================================================= */
.galeria{padding-bottom:calc(var(--pad-sec) + .5rem);overflow:hidden}
.marquee{margin-top:1.4rem;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee__track{display:flex;gap:.8rem;width:max-content;animation:scrollx 42s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.gitem{flex:none;width:clamp(180px,52vw,290px);aspect-ratio:3/4;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--sh);background:var(--cream-2);position:relative}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gitem:hover img{transform:scale(1.06)}
.gitem::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(15,36,25,.35))}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;overflow-x:auto;width:auto}}

/* =================================================================
   TESTIMONIOS
   ================================================================= */
.tcard{flex:0 0 82%;max-width:360px;scroll-snap-align:start;background:var(--white);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:1.2rem 1.1rem;box-shadow:var(--sh);
  display:flex;flex-direction:column;gap:.7rem}
.tstars{display:flex;gap:.1rem;color:var(--gold)}
.tstars .icon{width:1.05rem;height:1.05rem;fill:var(--gold);stroke:none}
.tcard p{font-size:.92rem;color:var(--ink);line-height:1.55;font-style:italic}
.tcard__by{display:flex;align-items:center;gap:.65rem;margin-top:auto}
.tavatar{display:grid;place-content:center;width:40px;height:40px;border-radius:50%;flex:none;
  font-family:"Fraunces",serif;font-weight:600;color:#fff;
  background:linear-gradient(150deg,var(--green),var(--terra))}
.tcard__by b{font-size:.9rem;color:var(--forest);display:block;line-height:1.1}
.tcard__by small{font-size:.74rem;color:var(--ink-soft)}
@media (min-width:620px){.tcard{flex-basis:48%}}
@media (min-width:920px){.tcard{flex-basis:32%}}

/* =================================================================
   CTA FINAL
   ================================================================= */
.cta{position:relative;overflow:hidden;isolation:isolate;color:#fff;text-align:center;
  padding-block:clamp(3rem,9vw,6rem)}
.cta__bg{position:absolute;inset:0;z-index:-3;background-image:var(--bg-cta);background-size:cover;
  background-position:center;transform:scale(1.05)}
.cta__veil{position:absolute;inset:0;z-index:-2;background:linear-gradient(180deg,rgba(15,36,25,.7),rgba(15,36,25,.84))}
.cta__inner{display:flex;flex-direction:column;align-items:center;gap:.7rem}
.cta__title{font-size:clamp(1.7rem,5.6vw,3rem);max-width:18ch;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.cta__title .hl{color:var(--gold-2)}
.cta__sub{font-size:var(--lead);max-width:46ch;color:rgba(255,255,255,.9)}
.cta__inner .btn{margin-top:.5rem}
.cta__mini{font-size:.78rem;color:rgba(255,255,255,.7);letter-spacing:.02em}

/* =================================================================
   FOOTER
   ================================================================= */
.foot{background:var(--coffee);color:rgba(250,245,234,.8);padding-top:clamp(2.2rem,6vw,3.4rem)}
.foot__grid{display:grid;gap:1.6rem;padding-bottom:1.8rem}
.foot__brand p{font-size:.86rem;margin:.7rem 0 .9rem;max-width:38ch;line-height:1.5}
.brand--foot .brand__name{color:var(--cream)}
.brand--foot .brand__name em{color:var(--gold-2)}
.foot__social{display:flex;gap:.5rem}
.sbtn{width:42px;height:42px;border-radius:12px;display:grid;place-content:center;
  background:rgba(250,245,234,.1);color:var(--cream);transition:.2s var(--ease)}
.sbtn:hover{background:var(--wa);transform:translateY(-3px)}
.foot__col h4{font-family:"Plus Jakarta Sans";font-weight:800;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-2);margin-bottom:.8rem}
.foot__col a{display:block;padding:.32rem 0;font-size:.9rem;color:rgba(250,245,234,.82);transition:.15s}
.foot__col a:hover{color:#fff;padding-left:.3rem}
.foot__contact{display:flex;align-items:center;gap:.5rem;font-size:.9rem;padding:.32rem 0}
.foot__contact .icon{width:1.1rem;height:1.1rem;color:var(--gold-2)}
.foot__bar{border-top:1px solid rgba(250,245,234,.12);padding:1rem var(--pad-x);text-align:center}
.foot__bar p{font-size:.78rem;color:rgba(250,245,234,.6);max-width:var(--maxw);margin-inline:auto}
@media (min-width:720px){.foot__grid{grid-template-columns:2fr 1fr 1.2fr;gap:2rem}}

/* =================================================================
   DOCK (barra inferior móvil)
   ================================================================= */
.dock{position:fixed;left:0;right:0;bottom:0;z-index:80;display:flex;gap:.5rem;
  padding:.5rem .7rem calc(.5rem + env(safe-area-inset-bottom));
  background:rgba(250,245,234,.9);backdrop-filter:blur(12px);border-top:1px solid var(--line);
  transform:translateY(120%);transition:transform .35s var(--ease)}
.dock.is-visible{transform:none}
.dock__btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  font-weight:700;font-size:.9rem;padding:.8rem;border-radius:var(--r-pill);min-height:50px;position:relative}
.dock__btn .icon{width:1.25rem;height:1.25rem}
.dock__btn--wa{background:linear-gradient(180deg,var(--wa-2),var(--wa));color:#fff;
  box-shadow:0 8px 18px -8px rgba(28,166,79,.7)}
.dock__btn--alt{background:var(--forest);color:var(--cream)}
.dock__badge{position:absolute;top:-6px;right:8px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;
  background:var(--terra);color:#fff;font-size:.7rem;font-weight:800;display:grid;place-content:center;
  box-shadow:0 2px 6px rgba(0,0,0,.3);animation:pop .3s var(--ease)}
.dock__badge[hidden]{display:none}
@keyframes pop{from{transform:scale(0)}to{transform:scale(1)}}
@media (min-width:920px){.dock{display:none}}

/* toast */
.toast{position:fixed;left:50%;bottom:calc(72px + env(safe-area-inset-bottom));transform:translate(-50%,20px);
  z-index:120;background:var(--forest);color:var(--cream);padding:.7rem 1.1rem;border-radius:var(--r-pill);
  font-size:.84rem;font-weight:600;box-shadow:var(--sh-lg);opacity:0;pointer-events:none;
  transition:opacity .3s,transform .3s;display:flex;align-items:center;gap:.5rem}
.toast.is-show{opacity:1;transform:translate(-50%,0)}
.toast .icon{width:1.1rem;height:1.1rem;color:var(--gold-2)}
@media (min-width:920px){.toast{bottom:24px}}

/* body padding so dock doesn't cover footer on mobile */
@media (max-width:919px){body{padding-bottom:74px}}

/* =================================================================
   HARDENING RESPONSIVE MÓVIL — corrige overflow sin tocar la estética
   ================================================================= */

/* Red de seguridad: jamás scroll horizontal */
html,body{overflow-x:hidden}

/* Hijos de flex/grid pueden encogerse (evita overflow por contenido ancho) */
.armar__grid>*,.raices__grid>*,.foot__grid>*,
.field,.field-row>.field,.builder,
.ben,.serv,.stat,.facts>li,.premium__list>li,
.sec__head>*,.dcard__body,.tcard{min-width:0}

/* Grids de UNA columna en móvil con minmax(0,1fr): impide el "blowout" del grid */
@media (max-width:819px){.armar__grid,.raices__grid{grid-template-columns:minmax(0,1fr)}}
@media (max-width:719px){.foot__grid{grid-template-columns:minmax(0,1fr)}}

/* Palabras largas se parten; etiquetas en flex pueden romper para no desbordar */
h1,h2,h3,h4,p,a,li,label,.hero__title,.sec__title,.cta__title{overflow-wrap:break-word}
.premium__list li,.hero__trust li,.armar__steps li,.foot__contact,.dcard__meta span,.facts span,.stat span{overflow-wrap:anywhere}

/* La lista Premium nunca se desborda en pantallas angostas */
@media (max-width:560px){
  .premium__list{gap:.55rem .7rem}
  .premium__list li{font-size:.84rem;gap:.5rem}
  .premium__list .icon{width:1.2rem;height:1.2rem}
}

/* ---------- BUILDER "Arma tu recorrido": robusto en móvil ---------- */
.builder{max-width:100%}
.chips{flex-wrap:wrap;overflow:visible}            /* muestra TODAS las opciones, sin scroll lateral */
.field>label{flex-wrap:wrap;row-gap:.2rem}
input[type="date"]{width:100%;min-width:0;max-width:100%;-webkit-appearance:none;appearance:none}
.stepper{min-width:0}

/* Teléfonos: apilar Personas+Fecha y COMPACTAR el cuadro */
@media (max-width:560px){
  .field-row{grid-template-columns:1fr;gap:.7rem}
  .armar__grid{gap:1rem}
  .builder{width:100%;padding:1rem .9rem;gap:.7rem}
  .field{gap:.4rem}
  .field>label{font-size:.8rem}
  .chip-sel{padding:.42rem .72rem;font-size:.78rem}
  .armar__steps li{font-size:.84rem}
  input[type="date"]{padding:.6rem .7rem;min-height:46px;font-size:16px}
  .builder__note{font-size:.72rem}
  .btn{white-space:normal;max-width:100%}
}
/* Más aire lateral en móvil en toda la landing */
@media (max-width:560px){:root{--pad-x:clamp(1.15rem,4.8vw,2rem)}}
