/* =====================================================================
   nucleo.css — Sistema de diseño Núcleo MD v3
   Importa tokens.css (fuente única de verdad OKLCH).
   Mobile-first. Sin #fff/#000 literales. Sin backdrop-filter.
   Sin linear-gradient en botones. Sin reglas duplicadas.
   ===================================================================== */
@import "tokens.css";

/* ── Alias de retro-compatibilidad (no renombrar selectores) ────────── */
:root{
  --bg:         var(--paper);
  --green:      var(--brand);
  --green-700:  var(--brand-700);
  --green-soft: var(--brand-soft);
  --coral:      var(--accent);
  --coral-700:  var(--accent-600);
  --mint:       var(--brand-tint);
  --sand:       var(--surface-2);
}

/* ── RESET ──────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}

/* ── TIPOGRAFÍA ─────────────────────────────────────────────────────── */
h1,h2,h3{
  font-family:'Fraunces',Georgia,serif;
  color:var(--ink);
  line-height:1.04;
  font-weight:600;
  letter-spacing:-.025em;
  font-variation-settings:"opsz" 144;
}
h1{font-size:clamp(2.5rem,8vw,4.4rem);font-weight:700}
h2{font-size:clamp(1.8rem,4.2vw,2.7rem);margin-bottom:.5em;letter-spacing:-.022em}
h3{letter-spacing:-.015em}
h1 em,h2 em{font-style:italic;color:var(--accent);font-weight:500}

/* Clase display para cifras monumentales */
.display{
  font-family:'Fraunces',Georgia,serif;
  font-weight:700;
  font-size:clamp(3.5rem,10vw,5.5rem);
  line-height:.92;
  letter-spacing:-.04em;
  color:var(--brand);
  font-variation-settings:"opsz" 144;
}

.lead{font-size:1.18rem;line-height:1.55;color:var(--ink-soft);font-weight:400}
p{margin-bottom:1rem}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── LAYOUT ─────────────────────────────────────────────────────────── */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:720px;margin-left:auto;margin-right:auto}
.center{text-align:center}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  text-transform:uppercase;letter-spacing:.16em;
  font-size:.72rem;font-weight:700;
  color:var(--accent-600);margin-bottom:1rem;
}
.eyebrow::before{content:"";width:18px;height:1.5px;background:var(--accent)}
.center .eyebrow,.narrow .eyebrow{display:block}

/* ── BOTONES ─────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:600;font-size:1rem;
  padding:15px 26px;border-radius:50px;cursor:pointer;
  border:2px solid transparent;
  transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s,background .2s;
}

/* CTA principal — azul sólido (sin gradiente) */
.btn--primary{
  background:var(--accent);
  color:var(--surface);
  box-shadow:var(--shadow);
}
.btn--primary:hover{
  transform:translateY(-2px);
  background:var(--accent-600);
  box-shadow:0 22px 42px -18px oklch(0.56 0.16 258 / .45);
}

.btn--green{background:var(--brand);color:var(--surface)}
.btn--green:hover{transform:translateY(-2px);background:var(--brand-700)}
.btn--ghost{background:transparent;border-color:var(--brand);color:var(--brand)}
.btn--ghost:hover{background:var(--brand);color:var(--surface)}
.btn--light{background:var(--surface);color:var(--brand)}
.btn--sm{padding:10px 18px;font-size:.9rem}
.full{width:100%}

/* ── CHIPS (sin glassmorphism) ────────────────────────────────────── */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:50px;padding:8px 15px;
  font-size:.8rem;font-weight:600;color:var(--brand);
}
.chip .s{color:var(--gold);letter-spacing:1px}

/* ── ICONOS SVG ──────────────────────────────────────────────────── */
.ic{
  width:28px;height:28px;
  stroke:currentColor;fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  color:var(--accent);flex:none;
}
.ic .fill{fill:currentColor;stroke:none}

/* Icon-tile: contenedor cuadrado con fondo tintado */
.ic-tile{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;
  background:var(--brand-tint);border-radius:12px;
  color:var(--brand);flex:none;
}
.ic-tile svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* ── TOPBAR + NAV (sin backdrop-filter) ──────────────────────────── */
.topbar{background:var(--brand);color:oklch(0.86 0.04 262);text-align:center;font-size:.82rem;padding:9px 16px}
.topbar b{color:var(--surface)}

.nav{
  position:sticky;top:0;z-index:50;
  background:var(--paper);      /* opaco, sin blur */
  border-bottom:1px solid var(--line);
}
.nav__in{position:relative;z-index:51}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:700;font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--brand);
}
.logo::before{
  content:"";width:1.7em;height:1.7em;
  background:url(/assets/img/logo/nucleo-mark-v2.svg) center/contain no-repeat;
  flex:none;
}
.logo b{color:var(--accent)}
.nav__links{display:flex;gap:26px;font-size:.94rem;font-weight:500}
.nav__links a:hover{color:var(--accent)}

/* ── HAMBURGER + DRAWER MOBILE ─────────────────────────────────── */
.nav__burger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  width:44px;height:44px;
  background:transparent;border:none;cursor:pointer;
  gap:5px;padding:0;
  margin-left:8px;
}
.nav__burger span{
  display:block;width:22px;height:2px;
  background:var(--brand);border-radius:2px;
  transition:transform .25s cubic-bezier(.16,1,.3,1),opacity .2s;
}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__drawer{
  display:none;
  position:fixed;top:0;left:0;right:0;bottom:0;
  background:var(--paper);
  padding:80px 28px 32px;
  flex-direction:column;gap:4px;
  z-index:45;
  overflow-y:auto;
  animation:drawerIn .3s cubic-bezier(.16,1,.3,1);
}
.nav__drawer.open{display:flex}
.nav__drawer a{
  display:flex;align-items:center;
  padding:18px 4px;
  font-family:'Fraunces',Georgia,serif;
  font-size:1.5rem;font-weight:500;color:var(--ink);
  border-bottom:1px solid var(--line);
  letter-spacing:-.015em;
  font-variation-settings:"opsz" 144;
  transition:color .2s,padding-left .2s;
}
.nav__drawer a:hover,.nav__drawer a:active{color:var(--accent);padding-left:8px}
.nav__drawer a.btn{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1rem;margin-top:24px;
  border-bottom:none;background:var(--accent);color:var(--surface);
  justify-content:center;padding:16px;
  letter-spacing:0;
}
.nav__drawer a.btn:hover{padding-left:16px;background:var(--accent-600)}
@keyframes drawerIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}

/* ── SECCIONES ──────────────────────────────────────────────────── */
.section{padding:64px 0}
.section--tint{background:var(--brand-tint)}
.section--brand{
  background:radial-gradient(900px 440px at 80% -15%,oklch(0.50 0.14 260),var(--brand) 62%);
  color:oklch(0.88 0.04 262);
}
/* alias retrocompat */
.section--mint{background:var(--brand-tint)}
.section--green{background:radial-gradient(900px 440px at 80% -15%,oklch(0.50 0.14 260),var(--brand) 62%);color:oklch(0.88 0.04 262)}
.on-dark{color:var(--surface)}
.section--green .eyebrow,.section--brand .eyebrow{color:oklch(0.72 0.06 262)}

/* ── HERO ────────────────────────────────────────────────────────── */
.hero{position:relative;overflow:hidden;padding:36px 0 14px;text-align:center}
.hero::before{
  content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);
  width:130%;height:520px;
  background:radial-gradient(58% 58% at 50% 0%,oklch(0.56 0.16 258 / .12),transparent 70%);
  z-index:0;pointer-events:none;
}
.hero::after{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:36px;height:3px;background:var(--accent);border-radius:3px;z-index:1;
}
.hero .wrap{position:relative;z-index:1}
.hero h1{margin:.2em auto .45em;max-width:15ch}
.hero .lead{max-width:540px;margin:0 auto 6px}
.hero__cta{display:flex;flex-direction:column;gap:12px;max-width:360px;margin:22px auto 0}
.hero .chips{justify-content:center}
.hero__media{position:relative;max-width:430px;margin:28px auto 0}
.hero__media img{
  width:100%;border-radius:24px;
  box-shadow:0 40px 80px -30px oklch(0.27 0.02 262 / .30),0 16px 30px -16px oklch(0.27 0.02 262 / .16);
}
.doc-badge{
  position:absolute;left:50%;bottom:-16px;transform:translateX(-50%);
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--line);border-radius:50px;
  padding:7px 16px 7px 7px;box-shadow:var(--shadow);white-space:nowrap;
}
.doc-badge img{width:42px;height:42px;border-radius:50%;object-fit:cover;object-position:top}
.doc-badge b{display:block;font-size:.82rem;color:var(--brand);line-height:1.1}
.doc-badge span{font-size:.72rem;color:var(--muted)}

/* ── AUTHORITY BAR ───────────────────────────────────────────────── */
.authbar{background:var(--brand-tint);border-top:1px solid var(--line);border-bottom:1px solid var(--line);color:var(--ink)}
.authbar .in{display:flex;gap:20px;align-items:center;padding:24px 0;flex-wrap:wrap;justify-content:center;text-align:center}
.authbar img{width:120px;height:142px;object-fit:cover;object-position:center top;border-radius:16px;flex:none}
.authbar b{color:var(--surface)}
.authbar p{margin:0;max-width:560px}

/* ── SEGMENTOS — lista editorial (sin cards idénticas) ───────────── */
.seg-list{display:grid;grid-template-columns:1fr;gap:0;margin-top:36px}
.seg{
  display:flex;gap:20px;align-items:flex-start;
  padding:22px 0;
  border-bottom:1px solid var(--line);
  transition:background .2s;
}
.seg:last-child{border-bottom:none}
.seg .ic-tile{flex-shrink:0}
.seg h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;color:var(--brand);margin-bottom:3px}
.seg p{margin:0;font-size:.94rem;color:var(--ink-soft)}

/* ── PROBLEMA — con cifra display ───────────────────────────────── */
.problema-split{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;margin-top:36px}
.problema-stat{text-align:center}
.problema-stat .display{display:block;margin-bottom:.15em}
.problema-stat p{font-size:1rem;color:var(--ink-soft);max-width:26ch;margin:0 auto}

/* ── MECANISMO — flujo aditivo horizontal ───────────────────────── */
.mech-flow{display:grid;grid-template-columns:1fr;gap:0;margin-top:40px}
.mech{
  display:flex;gap:18px;align-items:flex-start;
  padding:24px 0;position:relative;
}
.mech:not(:last-child)::after{
  content:"";position:absolute;
  left:21px;top:58px;width:2px;height:calc(100% - 18px);
  background:var(--line);
}
.mech .ic-tile{flex-shrink:0;margin-top:2px}
.mech .tag{
  display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--accent-600);
  background:var(--brand-tint);padding:3px 10px;border-radius:50px;margin-bottom:6px;
}
.mech h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;color:var(--brand);margin-bottom:4px}
.mech p{margin:0;font-size:.92rem;color:var(--ink-soft)}
.mech-sum{
  display:flex;align-items:center;gap:12px;justify-content:center;
  margin-top:28px;padding:16px 24px;
  background:var(--brand-tint);border-radius:var(--radius);
  font-family:'Fraunces',serif;font-size:1.2rem;color:var(--brand);
  font-variation-settings:"opsz" 144;
}
.mech-sum b{color:var(--accent)}
.mech-sum::before{content:"";width:20px;height:20px;background:var(--brand);border-radius:50%;flex:none}

/* ── COMPARATIVA — barras ascendentes ────────────────────────────── */
.mol-grid{display:grid;grid-template-columns:1fr;gap:0;margin-top:34px}
.mol{
  display:flex;gap:20px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line);
}
.mol:last-child{border-bottom:none}
.mol--king{order:-1}/* Reta arriba en mobile */
.mol-info{flex:1}
.mol h3{font-family:'Fraunces',serif;font-size:1.2rem;margin-bottom:4px;font-variation-settings:"opsz" 144}
.mol .vias{display:flex;gap:6px;margin:4px 0 2px}
.via{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--line)}
.via.on{background:var(--brand);border-color:var(--brand)}
.mol--king .via.on{background:var(--accent);border-color:var(--accent)}
.vias-label{font-size:.74rem;color:var(--muted)}
.mol-bar-wrap{width:80px;text-align:center;flex-shrink:0}
.mol-bar{
  height:100px;width:36px;margin:0 auto 6px;
  background:var(--line);border-radius:8px 8px 0 0;
  position:relative;overflow:hidden;
}
.mol-bar i{
  position:absolute;bottom:0;left:0;right:0;
  background:var(--brand);border-radius:8px 8px 0 0;
  transition:height .9s cubic-bezier(.16,1,.3,1);
  height:0;
}
.mol--king .mol-bar i{background:var(--accent)}
.pct{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--brand);font-variation-settings:"opsz" 144}
.mol--king .pct{color:var(--accent)}
.pct small{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:.7rem;color:var(--muted);margin-top:3px;line-height:1.3}
.mol__tag{
  display:inline-block;background:var(--accent);color:var(--surface);
  font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;
  padding:3px 11px;border-radius:50px;margin-bottom:6px;
}

/* ── PASOS — timeline numerado (sin cards) ────────────────────────── */
.steps{display:grid;grid-template-columns:1fr;gap:0;margin-top:36px}
.step{
  display:flex;gap:18px;align-items:flex-start;
  padding:24px 0;position:relative;
}
.step:not(:last-child)::after{
  content:"";position:absolute;
  left:19px;top:56px;width:2px;height:calc(100% - 36px);
  background:var(--brand-tint);border:none;
}
.step .n{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:50%;
  background:var(--brand);color:var(--surface);
  font-weight:700;font-size:1rem;flex:none;
  box-shadow:var(--shadow-sm);
}
.step-body{flex:1}
.step h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.15rem;color:var(--brand);margin-bottom:4px}
.step p{margin:0;font-size:.94rem;color:var(--ink-soft)}

/* ── SELECTOR DE MOLÉCULA (tabs Reta / Tirze) ────────────────────── */
.mol-tabs{
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px;max-width:560px;margin:28px auto 32px;
}
.mol-tab{
  display:flex;flex-direction:column;gap:3px;
  padding:14px 18px;border-radius:var(--radius);
  border:2px solid var(--line);background:var(--surface);
  cursor:pointer;text-align:left;font-family:inherit;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.mol-tab strong{font-size:1rem;font-weight:700;color:var(--brand)}
.mol-tab span{font-size:.78rem;color:var(--muted);line-height:1.3}
.mol-tab--active{border-color:var(--accent);background:var(--brand-tint);box-shadow:var(--shadow-sm)}
.mol-tab--active strong{color:var(--accent)}
.mol-tab:hover:not(.mol-tab--active){border-color:var(--brand)}
.mol-panel{animation:tabIn .3s cubic-bezier(.16,1,.3,1)}
@keyframes tabIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ── OFERTA ──────────────────────────────────────────────────────── */
.offer-img{width:100%;max-width:520px;margin:0 auto 14px;border-radius:var(--radius);box-shadow:var(--shadow)}
.offer{max-width:560px;margin:0 auto}
.vstack{list-style:none;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.vstack li{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--line)}
.vstack li:last-child{border-bottom:0}
.vstack .nm{display:flex;gap:10px}
.vstack .nm::before{content:"✓";color:var(--brand-soft);font-weight:800}
.vstack .bonus .nm::before{content:"★";color:var(--accent)}
.vstack .v{color:var(--muted);font-size:.9rem;white-space:nowrap}
.vtotal{display:flex;justify-content:space-between;padding:15px 20px;background:var(--brand-tint);font-weight:700;color:var(--brand)}
.price{text-align:center;margin:24px 0 6px}
.price .now{font-family:'Fraunces',serif;font-size:3rem;color:var(--brand);font-weight:600;font-variation-settings:"opsz" 144}
.price .was{color:var(--muted);text-decoration:line-through;margin-left:10px}
.price .u{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}
.plans{display:grid;grid-template-columns:1fr;gap:18px;max-width:760px;margin:46px auto 0}
.plan{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;position:relative}
.plan--feat{border:2px solid var(--accent);box-shadow:var(--shadow)}
.plan__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--surface);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 13px;border-radius:50px;white-space:nowrap}
.plan__price{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--brand);margin:6px 0 16px;font-variation-settings:"opsz" 144}
.plan__price span{font-size:.95rem;color:var(--muted)}
.plan ul{list-style:none;display:grid;gap:9px;margin-bottom:22px}
.plan li{padding-left:24px;position:relative;font-size:.96rem}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--brand-soft);font-weight:700}
.guarantee{
  display:flex;gap:16px;align-items:flex-start;
  background:var(--surface);border:2px solid var(--brand-soft);border-radius:var(--radius);
  padding:22px 24px;max-width:560px;margin:24px auto 0;
}
.guarantee h4{font-family:'Plus Jakarta Sans',sans-serif;color:var(--brand);margin-bottom:4px}
.guarantee p{margin:0;font-size:.95rem}

/* ── COMUNIDAD / PERTENENCIA ─────────────────────────────────────── */
.community{
  display:grid;grid-template-columns:1fr;gap:32px;max-width:1100px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line);border-radius:24px;
  padding:36px 32px;align-items:center;
}
@media(min-width:880px){
  .community{grid-template-columns:1.3fr .8fr;gap:48px;padding:48px 56px}
}
.community__content .eyebrow{color:var(--accent-600)}
.community__content h2{
  font-family:'Fraunces',serif;font-size:clamp(1.6rem,3.4vw,2.2rem);
  font-weight:600;color:var(--ink);line-height:1.15;letter-spacing:-.018em;
  margin:8px 0 14px;font-variation-settings:"opsz" 144;
}
.community__lead{
  color:var(--ink-soft);font-size:1.02rem;line-height:1.6;margin-bottom:22px;
}
.community__lead strong{color:var(--brand);font-weight:600}
.community__bullets{list-style:none;padding:0;margin:0 0 24px;display:grid;gap:14px}
.community__bullets li{display:flex;gap:14px;font-size:.95rem;line-height:1.5;color:var(--ink-soft)}
.community__bullets li svg{
  width:26px;height:26px;flex:none;stroke:var(--brand);fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  background:var(--brand-tint);border-radius:8px;padding:4px;
}
.community__bullets li strong{color:var(--ink);font-weight:700;display:block;margin-bottom:2px}

.community__visual{
  background:var(--brand-tint);border-radius:18px;padding:24px;
  display:grid;gap:16px;
}
.community__stat{
  padding:18px 20px;background:var(--surface);border-radius:14px;
  border:1px solid oklch(0.88 0.03 190);
}
.community__big{
  font-family:'Fraunces',serif;font-size:clamp(2rem,4vw,2.8rem);font-weight:700;
  color:var(--brand);line-height:1;margin-bottom:6px;
  font-variation-settings:"opsz" 144;
}
.community__big-label{
  font-size:.86rem;color:var(--ink-soft);line-height:1.4;
}

/* ── ¿SOY CANDIDATO? ─────────────────────────────────────────────── */
.candidato-grid{
  display:grid;grid-template-columns:1fr;gap:18px;max-width:1100px;margin:36px auto 0;
}
@media(min-width:760px){.candidato-grid{grid-template-columns:repeat(3,1fr)}}
.candidato-card{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:24px 26px;
}
.candidato-card--yes{border-color:oklch(0.70 0.14 160);background:oklch(0.97 0.04 160)}
.candidato-card--check{border-color:oklch(0.72 0.12 75);background:oklch(0.97 0.04 75)}
.candidato-card--no{border-color:oklch(0.78 0.08 30);background:oklch(0.97 0.03 30)}
.candidato-badge{
  display:inline-block;font-size:.76rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;padding:5px 11px;border-radius:50px;margin-bottom:14px;
  background:oklch(0.40 0.14 160);color:var(--surface);
}
.candidato-badge--alt{background:oklch(0.45 0.13 75)}
.candidato-badge--no{background:oklch(0.55 0.16 30)}
.candidato-card ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.candidato-card li{font-size:.94rem;line-height:1.5;color:var(--ink);padding-left:0}
.candidato-card strong{color:var(--ink);font-weight:700}

.candidato-cta{
  text-align:center;margin:32px auto 0;max-width:560px;
  background:var(--surface);border:2px solid var(--brand);border-radius:18px;padding:28px 26px;
}
.candidato-cta p{font-size:1rem;color:var(--ink-soft);margin-bottom:16px;line-height:1.55}
.candidato-cta p strong{color:var(--brand)}

/* ── GALERÍA DE RESULTADOS ───────────────────────────────────────── */
.results-grid{
  display:grid;grid-template-columns:1fr;gap:14px;max-width:1080px;margin:40px auto 0;
}
@media(min-width:640px){.results-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.results-grid{grid-template-columns:repeat(3,1fr)}}
.result-card{
  margin:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;transition:transform .25s,box-shadow .25s;
}
.result-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.result-card img{width:100%;height:240px;object-fit:cover;display:block;background:var(--paper)}
.result-card figcaption{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.82rem;font-weight:600;
  text-align:center;padding:10px 12px;color:var(--ink-soft);
}

/* ── BENEFICIOS (ventaja reta: glucagón + efectos reportados) ────── */
.benefits-grid{
  display:grid;grid-template-columns:1fr;gap:20px;max-width:980px;margin:40px auto 0;
}
@media(min-width:760px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}
.benefit{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:28px 26px;transition:border-color .25s,transform .25s,box-shadow .25s;
}
.benefit:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow)}
.benefit .ic-tile{
  width:48px;height:48px;border-radius:12px;background:var(--brand-tint);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.benefit .ic-tile svg{width:26px;height:26px;stroke:var(--brand);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.benefit h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.1rem;font-weight:700;color:var(--brand);margin-bottom:8px}
.benefit p{font-size:.95rem;line-height:1.6;color:var(--ink-soft);margin:0}
.benefit strong{color:var(--ink);font-weight:600}

/* ── QUÉ INCLUYE (compartido) ────────────────────────────────────── */
.incluye{
  max-width:760px;margin:36px auto 0;
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:28px 30px;
}
.incluye__title{
  font-family:'Plus Jakarta Sans',sans-serif;text-align:center;
  color:var(--brand);font-size:1.05rem;font-weight:700;margin-bottom:20px;
}
.incluye__grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:600px){.incluye__grid{grid-template-columns:1fr 1fr}}
.incluye__item{display:flex;align-items:flex-start;gap:12px;font-size:.95rem;color:var(--ink-soft);line-height:1.45}
.incluye__item svg{width:22px;height:22px;flex:none;margin-top:1px;stroke:var(--brand);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.incluye__item strong{color:var(--ink);font-weight:600}

/* ── DETALLE DE MOLÉCULA (efecto que la diferencia) ──────────────── */
.mol-detail{
  background:var(--brand-tint);border-radius:16px;padding:24px 26px;margin-bottom:18px;text-align:center;
}
.mol-detail__badge{
  display:inline-block;font-size:.74rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;color:var(--surface);background:var(--brand);
  padding:5px 14px;border-radius:50px;margin-bottom:12px;
}
.mol-detail__why{font-size:1.02rem;line-height:1.6;color:var(--ink-soft);max-width:560px;margin:0 auto}
.mol-detail__why strong{color:var(--ink);font-weight:600}
.mol-detail__why em{color:var(--brand);font-style:italic;font-weight:600}

/* ── COMPARATIVA RETA vs TIRZE ───────────────────────────────────── */
.compare{
  display:grid;grid-template-columns:1fr;gap:18px;max-width:780px;margin:36px auto 0;
}
@media(min-width:680px){.compare{grid-template-columns:1fr 1fr}}
.compare__col{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:28px 26px;text-align:center;position:relative;
}
.compare__col--feat{border:2px solid var(--brand);box-shadow:var(--shadow)}
.compare__badge{
  display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;padding:4px 12px;border-radius:50px;margin-bottom:10px;
  background:var(--brand);color:var(--surface);
}
.compare__badge--alt{background:var(--surface-2);color:var(--brand)}
.compare__col h3{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--ink);margin-bottom:8px;font-variation-settings:"opsz" 144}
.compare__big{
  font-family:'Fraunces',serif;font-size:2.6rem;font-weight:700;color:var(--brand);
  line-height:1;margin-bottom:16px;font-variation-settings:"opsz" 144;
}
.compare__big small{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:.78rem;font-weight:500;color:var(--muted);margin-top:6px;letter-spacing:0}
.compare__list{list-style:none;padding:0;margin:0 0 18px;text-align:left;display:grid;gap:9px}
.compare__list li{font-size:.92rem;color:var(--ink-soft);line-height:1.4;padding-left:22px;position:relative}
.compare__list li::before{content:"✓";position:absolute;left:0;color:var(--brand);font-weight:700}
.compare__list b{color:var(--ink);font-weight:600}
.compare__price{font-size:.95rem;color:var(--ink-soft);padding-top:14px;border-top:1px solid var(--line)}
.compare__price b{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--brand);font-variation-settings:"opsz" 144}

/* ── MÉTODOS DE PAGO ─────────────────────────────────────────────── */
.pay-methods{max-width:880px;margin:32px auto 0}
.pay-methods__title{
  font-family:'Plus Jakarta Sans',sans-serif;text-align:center;
  color:var(--brand);font-size:1.05rem;font-weight:700;margin-bottom:18px;
}
.pay-methods__grid{
  display:grid;grid-template-columns:1fr;gap:14px;max-width:600px;margin:0 auto;
}
@media(min-width:640px){.pay-methods__grid{grid-template-columns:1fr 1fr}}
.pay-method{
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:20px 22px;position:relative;
}
.pay-method strong{display:block;color:var(--ink);font-size:1.02rem;margin:10px 0 6px}
.pay-method span{display:block;font-size:.88rem;color:var(--ink-soft);line-height:1.5}
.pay-method__badge{
  display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;padding:4px 11px;border-radius:50px;
  background:var(--brand);color:var(--surface);
}
.pay-method__badge--blue{background:oklch(0.55 0.16 250)}
.pay-method__badge--purple{background:oklch(0.52 0.18 300)}

/* ── MÉTRICAS DE LABORATORIO ─────────────────────────────────────── */
.lab-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:oklch(0.50 0.14 260 / .3);
  border-radius:var(--radius);overflow:hidden;
}
.lab-stat{
  background:oklch(0.34 0.10 262 / .60);
  padding:20px 18px;
}
.lab-n{
  display:block;
  font-family:'Fraunces',serif;
  font-size:clamp(1.6rem,4vw,2.2rem);
  font-weight:700;color:var(--surface);
  line-height:1;margin-bottom:4px;
  font-variation-settings:"opsz" 144;
}
.lab-l{display:block;font-weight:700;font-size:.88rem;color:oklch(0.88 0.04 262);margin-bottom:2px}
.lab-d{display:block;font-size:.78rem;color:oklch(0.72 0.04 262);line-height:1.4}

/* ── TESTIMONIAL — soporte de foto ───────────────────────────────── */
.av-img{
  width:42px;height:42px;border-radius:50%;
  object-fit:cover;object-position:top;flex:none;
}

/* ── AUTENTICIDAD — split oscuro ─────────────────────────────────── */
.split{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.split img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow)}
.check{list-style:none;display:grid;gap:11px;margin:16px 0 24px}
.check li{padding-left:28px;position:relative}
.check li::before{content:"✓";position:absolute;left:0;color:var(--surface);font-weight:800}
.section--green .check li,.section--brand .check li{color:oklch(0.92 0.03 262)}

/* ── TESTIMONIOS — scroll horizontal ─────────────────────────────── */
.tscroll{
  display:flex;gap:18px;overflow-x:auto;padding:6px 4px 18px;
  margin-top:34px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.tscroll::-webkit-scrollbar{display:none}
.tcard{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;display:flex;flex-direction:column;gap:12px;
  min-width:280px;max-width:320px;flex:none;
}
.tcard.tcard--featured{
  border-color:var(--accent);box-shadow:var(--shadow);
  min-width:300px;
}
.tcard .stars{color:var(--gold);letter-spacing:2px}
.tcard .q{font-size:.98rem;color:var(--ink-soft);flex:1}
.who{display:flex;align-items:center;gap:12px}
.who .av{
  width:42px;height:42px;border-radius:50%;
  background:var(--brand);color:var(--surface);
  display:flex;align-items:center;justify-content:center;font-weight:700;flex:none;
}
.who b{display:block;color:var(--brand);font-size:.9rem}
.who span{font-size:.78rem;color:var(--muted)}

/* ── FAQ / EDUCACION ─────────────────────────────────────────────── */
details{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:18px 22px;margin-bottom:12px;max-width:720px;margin-left:auto;margin-right:auto;
}
summary{font-weight:600;color:var(--brand);cursor:pointer;list-style:none}
summary::-webkit-details-marker{display:none}
details p{margin:12px 0 0;color:var(--ink-soft)}

/* ── CALC BAND ───────────────────────────────────────────────────── */
.calc{
  background:radial-gradient(700px 360px at 85% -30%,oklch(0.50 0.14 260),var(--brand) 65%);
  color:oklch(0.88 0.04 262);border-radius:24px;padding:38px 26px;text-align:center;
}
.calc h2{color:var(--surface);margin-bottom:6px}
.calc .lead{color:oklch(0.76 0.06 262);max-width:520px;margin:0 auto 18px}

/* ── FOOTER ──────────────────────────────────────────────────────── */
.footer{background:oklch(0.18 0.04 262);color:oklch(0.60 0.06 262);padding:50px 0 30px}
.footer__in{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:26px;
  padding-bottom:24px;border-bottom:1px solid oklch(0.26 0.06 262);margin-bottom:22px;
}
.footer .logo{color:var(--surface)}
.footer .logo::before{background-image:url(/assets/img/logo/nucleo-mark-v2-white.svg)}
.footer__links{display:flex;flex-wrap:wrap;gap:18px;font-size:.9rem}
.footer__links a:hover{color:var(--surface)}
.disclaimer{font-size:.8rem;color:oklch(0.50 0.06 262);max-width:760px}
.copy{font-size:.8rem;color:oklch(0.40 0.05 262);margin-top:10px}

/* ── STICKY + WHATSAPP ───────────────────────────────────────────── */
.sticky{
  position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;
  align-items:center;justify-content:space-between;gap:12px;
  background:var(--surface);border-top:1px solid var(--line);padding:10px 16px;
  box-shadow:0 -6px 24px oklch(0.27 0.02 262 / .10);
}
.sticky .pr{font-family:'Fraunces',serif;font-weight:600;color:var(--brand);font-size:1.1rem;line-height:1.1}
.sticky .pr small{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-weight:400;font-size:.72rem;color:var(--muted)}
.wa{
  position:fixed;right:18px;bottom:22px;z-index:70;
  display:inline-flex;align-items:center;gap:9px;
  background:oklch(0.73 0.18 145);color:var(--surface);
  font-weight:600;font-size:.95rem;padding:12px 18px;border-radius:50px;
  box-shadow:0 10px 28px oklch(0.73 0.18 145 / .38);
}
.wa svg{width:20px;height:20px;fill:var(--surface);flex:none}

/* ── REVEAL + A11Y ───────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ── DESKTOP ─────────────────────────────────────────────────────── */
@media(min-width:780px){
  .section{padding:88px 0}
  .hero{text-align:left;padding:52px 0 14px}
  .hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
  .hero::before{left:78%;width:640px}
  .hero h1{margin-left:0;margin-right:0;max-width:14ch;font-size:clamp(2.5rem,5vw,3.6rem)}
  .hero .lead{margin-left:0;margin-right:0}
  .hero__cta{flex-direction:row;margin-left:0;max-width:none}
  .hero .chips{justify-content:flex-start}
  .hero__media{margin-top:0;max-width:100%}
  .authbar .in{flex-wrap:nowrap;text-align:left}
  .authbar p{max-width:100%}

  /* Segmentos: 2 columnas con líneas horizontales */
  .seg-list{grid-template-columns:1fr 1fr;gap:0}
  .seg{padding:26px 20px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
  .seg:nth-child(even){border-right:none}
  .seg:nth-last-child(-n+2){border-bottom:none}

  /* Problema: lado a lado */
  .problema-split{grid-template-columns:auto 1fr;gap:48px}
  .problema-stat{text-align:right}

  /* Mecanismo: horizontal en desktop */
  .mech-flow{grid-template-columns:repeat(3,1fr);gap:0}
  .mech{flex-direction:column;padding:0 20px;border-right:1px solid var(--line)}
  .mech:last-child{border-right:none}
  .mech:not(:last-child)::after{
    left:auto;top:auto;bottom:auto;
    left:calc(100% - 1px);top:22px;width:24px;height:2px;
  }
  .mech .ic-tile{margin-bottom:12px}

  /* Comparativa: 3 columnas, barras más altas */
  .mol-grid{grid-template-columns:repeat(3,1fr);gap:0}
  .mol{flex-direction:column;align-items:center;text-align:center;padding:32px 20px;border-right:1px solid var(--line)}
  .mol:last-child{border-right:none}
  .mol--king{order:0;background:var(--brand-tint)}
  .mol-bar-wrap{width:100%}
  .mol-bar{height:120px;width:48px}
  .mol .vias{justify-content:center}

  /* Pasos: horizontal */
  .steps{grid-template-columns:repeat(3,1fr);gap:0}
  .step{flex-direction:column;padding:0 20px;align-items:flex-start}
  .step:not(:last-child)::after{
    left:auto;top:19px;left:calc(100%);width:20px;height:2px;
    background:var(--brand-tint);
  }
  .step .n{margin-bottom:16px}

  /* Otros */
  .calc{display:flex;align-items:center;justify-content:space-between;gap:30px;text-align:left}
  .calc .lead{margin:0}
  .plans{grid-template-columns:1fr 1fr;max-width:100%}
  .offer{max-width:100%}
  .split{grid-template-columns:1fr 1fr}

  /* Testimonios: más anchos en desktop */
  .tcard{min-width:320px;max-width:380px}
  .tcard.tcard--featured{min-width:360px}
}
@media(max-width:780px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex}
  .sticky{display:flex}
  body{padding-bottom:74px}
  .wa{bottom:86px;right:14px;padding:12px}
  .wa .lbl{display:none}
}

/* =====================================================================
   FIXES RESPONSIVE — Auditoría 02 — 2026-06-10
   ===================================================================== */
.price .now{font-size:clamp(2rem,8vw,3rem)}
.plan__price{font-size:clamp(1.8rem,5.5vw,2.4rem)}
.compare__big{font-size:clamp(2rem,6vw,2.6rem)}
.compare__col h3{font-size:clamp(1.2rem,3.5vw,1.5rem)}
.compare__price b{font-size:clamp(1.1rem,3vw,1.3rem)}
.mol h3{font-size:clamp(1.05rem,2.6vw,1.2rem)}
.pct{font-size:clamp(1.25rem,3.4vw,1.5rem)}
.nav__drawer a{font-size:clamp(1.2rem,4.5vw,1.5rem)}

.community,.community__content,.community__visual,
.compare,.compare__col,.plans,.plan,
.candidato-grid,.candidato-card,.benefits-grid,.benefit,
.results-grid,.result-card,.authbar .in,.authbar p,
.vstack,.vstack li,.hero .wrap,.hero__media,.footer__in{min-width:0}
img{max-width:100%;height:auto}

@media(max-width:679.98px){.compare__col--feat{order:-1}}
@media(min-width:680px) and (max-width:759.98px){
  .compare{grid-template-columns:1fr}.compare__col--feat{order:-1}
}
@media(min-width:760px){.compare{grid-template-columns:1fr 1fr}}
.compare__col{border-width:2px;border-color:var(--line)}
.compare__col--feat{border-color:var(--brand)}
@media(max-width:420px){
  .compare__col{padding:22px 18px}.compare__big{margin-bottom:12px}
}

@media(min-width:820px){
  .community{grid-template-columns:1.4fr 1fr;gap:44px;padding:44px 48px}
}
@media(max-width:420px){
  .community{padding:28px 22px;gap:24px;border-radius:18px}
  .community__visual{padding:22px 20px;border-radius:14px}
}

@media(min-width:768px) and (max-width:1023.98px){
  .candidato-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:1024px){.candidato-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}

.hero__media img{aspect-ratio:4/5;object-fit:cover}
.result-card img{height:auto;aspect-ratio:4/5}
.offer-img{aspect-ratio:16/10;object-fit:cover}

.vstack li{flex-wrap:wrap}
.vstack li .v{white-space:normal;text-align:right;margin-left:auto}

.hero__media{position:relative;overflow:visible}
.doc-badge{max-width:calc(100% - 24px)}
@media(max-width:380px){.hero__cta{max-width:none;padding:0 6px}}

.mol-bar{height:120px;width:42px}
@media(min-width:780px){.mol-bar{height:140px;width:54px}}

.mech:not(:last-child)::after{height:calc(100% - 28px)}

.wa{bottom:96px}
@media(min-width:781px){.wa{bottom:22px}}
.footer__in{gap:18px 26px}
.footer__links{min-width:0;flex:1 1 280px}

.wrap{padding-left:clamp(16px,4vw,22px);padding-right:clamp(16px,4vw,22px)}

@media(max-width:420px){
  .lab-stat{padding:16px 14px}.lab-l{font-size:.82rem}.lab-d{font-size:.74rem}
}
@media(max-width:480px){
  .authbar img{width:96px;height:114px}.authbar p{font-size:.94rem}
}
@media(min-width:600px) and (max-width:779.98px){.section{padding:72px 0}}

/* MOTION POLISH */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px;transition:outline-offset .15s ease}
.btn:focus-visible{outline-offset:4px}

.benefit,.result-card,.plan,.candidato-card,.pay-method,.compare__col{
  transition:transform .35s cubic-bezier(.16,1,.3,1),box-shadow .35s cubic-bezier(.16,1,.3,1),border-color .25s ease;
}
.benefit:hover,.result-card:hover,.plan:not(.plan--feat):hover,
.candidato-card:hover,.pay-method:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 44px -22px oklch(0.27 0.02 262 / .22);
}
.btn{position:relative;overflow:hidden}
.btn:active{transform:translateY(0) scale(.985);transition-duration:.08s}

details{transition:border-color .2s,box-shadow .2s}
details[open]{border-color:var(--brand-soft);box-shadow:var(--shadow-sm)}
details summary{transition:color .2s;position:relative;padding-right:32px}
details[open] summary{color:var(--accent)}
details summary::after{
  content:"+";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  font-weight:400;font-size:1.4rem;line-height:1;color:var(--muted);
  transition:transform .25s cubic-bezier(.16,1,.3,1),color .2s;
}
details[open] summary::after{transform:translateY(-50%) rotate(45deg);color:var(--accent)}

/* WhatsApp pulse */
@keyframes wa-pulse{0%,100%{box-shadow:0 12px 28px -10px oklch(0.62 0.18 152 / .55),0 0 0 0 oklch(0.62 0.18 152 / .5)}50%{box-shadow:0 12px 28px -10px oklch(0.62 0.18 152 / .55),0 0 0 14px oklch(0.62 0.18 152 / 0)}}
.wa{animation:wa-pulse 2.4s ease-in-out infinite}

@media(prefers-reduced-motion:reduce){
  .benefit,.result-card,.plan,.candidato-card,.pay-method,.compare__col,
  .btn,details,details summary::after,.wa{transition:none !important;transform:none !important;animation:none !important}
}

/* ---- Lightbox ---- */
.lightbox{position:fixed;inset:0;background:oklch(0.16 0.02 262 / .92);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px;cursor:zoom-out}
.lightbox.open{display:flex;animation:lb-in .25s ease}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:min(1100px,95vw);max-height:90vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.5);cursor:default}
.lightbox__close{position:absolute;top:18px;right:22px;background:transparent;border:0;color:#fff;font-size:38px;line-height:1;cursor:pointer;width:48px;height:48px;border-radius:50%}
.lightbox__close:hover{background:rgba(255,255,255,.12)}

/* ---- Sticky CTA show/hide ---- */
.sticky{transition:transform .35s cubic-bezier(.16,1,.3,1)}
.sticky--hidden{transform:translateY(120%)}

/* ---- Scroll progress bar ---- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--brand),var(--accent));z-index:1001;transition:width .08s linear;pointer-events:none}

@media(prefers-reduced-motion:reduce){
  .sticky,.scroll-progress,.lightbox{transition:none !important;animation:none !important}
}

/* ── SECCIÓN LABORATORIO ─────────────────────────────────────────── */
.lab-proof-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  max-width:1100px;margin:48px auto 0;
}
@media(min-width:768px){.lab-proof-grid{grid-template-columns:repeat(3,1fr)}}

.lab-proof-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:20px;padding:28px 26px;
  display:flex;flex-direction:column;gap:0;
}
.lab-proof-card--featured{
  border-color:var(--accent);
  box-shadow:0 0 0 1px var(--accent),var(--shadow);
}
.lab-proof-icon{
  width:48px;height:48px;border-radius:14px;
  background:var(--brand-tint);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;flex:none;
}
.lab-proof-icon svg{width:26px;height:26px;stroke:var(--brand)}
.lab-proof-icon--accent{background:oklch(0.94 0.04 188)}
.lab-proof-icon--accent svg{stroke:var(--accent)}
.lab-proof-card h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.05rem;font-weight:700;color:var(--ink);
  margin-bottom:10px;
}
.lab-proof-card p{
  font-size:.92rem;color:var(--ink-soft);line-height:1.6;
  margin-bottom:14px;flex:1;
}
.lab-proof-badge{
  display:inline-block;
  background:var(--brand-tint);color:var(--brand);
  font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;padding:5px 12px;border-radius:50px;
  margin-bottom:12px;
}
.lab-proof-badge--accent{background:oklch(0.94 0.04 188);color:var(--accent)}
.lab-proof-note{
  font-size:.8rem!important;color:var(--muted)!important;
  margin:0!important;line-height:1.5!important;
}
.lab-proof-link{
  font-size:.88rem;font-weight:600;color:var(--accent);
  text-decoration:underline;text-underline-offset:3px;margin-top:4px;
}
.lab-proof-link:hover{color:var(--accent-600)}

.lab-lot-bar{
  display:flex;flex-wrap:wrap;gap:0;
  max-width:1100px;margin:32px auto 0;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;
}
.lab-lot-item{
  flex:1;min-width:140px;
  padding:16px 20px;
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:4px;
}
.lab-lot-item:last-child{border-right:none}
.lab-lot-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.lab-lot-value{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--ink);font-variation-settings:"opsz" 144;font-weight:600}
.lab-lot-ok{color:oklch(0.45 0.14 160)!important}

/* ── EVIDENCIA CLÍNICA ───────────────────────────────────────────── */
.evidence-hero{
  display:grid;grid-template-columns:1fr;gap:32px;
  max-width:1100px;margin:52px auto 0;
  background:var(--ink);border-radius:24px;
  padding:40px 36px;align-items:center;
}
@media(min-width:768px){.evidence-hero{grid-template-columns:220px 1fr;gap:52px;padding:52px 56px}}

.evidence-hero__stat{text-align:center}
.evidence-big{
  font-family:'Fraunces',serif;
  font-size:clamp(3.5rem,10vw,6rem);
  font-weight:700;color:var(--accent);
  line-height:.9;display:block;
  font-variation-settings:"opsz" 144;
  letter-spacing:-.04em;
}
.evidence-big-label{
  display:block;font-size:.9rem;
  color:oklch(0.70 0.04 262);
  margin-top:10px;line-height:1.4;
}
.evidence-tag{
  display:inline-block;
  background:oklch(0.25 0.04 262);
  color:var(--accent);
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  padding:5px 14px;border-radius:50px;margin-bottom:14px;
}
.evidence-hero__body h3{
  font-family:'Fraunces',serif;
  color:var(--surface);font-size:clamp(1.3rem,2.8vw,1.7rem);
  margin-bottom:14px;line-height:1.2;
  font-variation-settings:"opsz" 144;
}
.evidence-hero__body p{color:oklch(0.76 0.03 262);font-size:.96rem;line-height:1.65;margin-bottom:12px}
.evidence-hero__body strong{color:var(--surface)}
.evidence-cite{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.82rem;font-weight:600;color:var(--accent);
  border:1px solid oklch(0.35 0.06 188);border-radius:50px;
  padding:7px 16px;margin-top:6px;
  transition:background .2s,color .2s;
}
.evidence-cite:hover{background:oklch(0.25 0.06 188);color:var(--surface)}

.evidence-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  max-width:1100px;margin:24px auto 0;
}
@media(min-width:640px){.evidence-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.evidence-grid{grid-template-columns:repeat(3,1fr)}}

.evidence-card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:18px;padding:26px 24px;
}
.evidence-card__num{
  font-family:'Fraunces',serif;font-size:2.4rem;font-weight:700;
  color:var(--brand);line-height:1;margin-bottom:4px;
  font-variation-settings:"opsz" 144;letter-spacing:-.03em;
}
.evidence-card__mol{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.07em;color:var(--accent-600);margin-bottom:14px;
}
.evidence-card p{font-size:.88rem;color:var(--ink-soft);line-height:1.65;margin-bottom:12px}
.evidence-cite-sm{
  font-size:.78rem;font-weight:600;color:var(--accent);
  text-decoration:underline;text-underline-offset:3px;
}
.evidence-cite-sm:hover{color:var(--accent-600)}

.evidence-safety{
  display:grid;grid-template-columns:1fr;gap:24px;
  max-width:1100px;margin:24px auto 0;
  background:oklch(0.97 0.02 80);
  border:1px solid oklch(0.88 0.03 80);
  border-radius:20px;padding:32px 28px;align-items:flex-start;
}
@media(min-width:768px){.evidence-safety{grid-template-columns:56px 1fr;gap:28px;padding:36px 40px}}
.evidence-safety__icon{
  width:56px;height:56px;border-radius:16px;
  background:var(--brand-tint);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.evidence-safety__icon svg{width:28px;height:28px;stroke:var(--brand)}
.evidence-safety__body h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.08rem;font-weight:700;color:var(--ink);margin-bottom:12px;
}
.evidence-safety__body p{font-size:.93rem;color:var(--ink-soft);line-height:1.65;margin-bottom:10px}
.evidence-safety__body strong{color:var(--ink);font-weight:700}

.evidence-disclaimer{
  max-width:1100px;margin:20px auto 0;
  font-size:.76rem;color:var(--muted);line-height:1.6;
  border-top:1px solid var(--line);padding-top:16px;
}

/* ════════════════════════════════════════════════════════════════
   BANDAS MÓVILES (MARQUEE) — validación social rotativa
   ════════════════════════════════════════════════════════════════ */

.marquee{
  position:relative;
  width:100%;
  overflow:hidden;
  background:var(--brand);
  border-top:1px solid oklch(0.35 0.10 192);
  border-bottom:1px solid oklch(0.35 0.10 192);
  padding:14px 0;
  z-index:5;
}
.marquee--voices{
  background:var(--paper);
  border-color:var(--line);
  padding:18px 0 10px;
}
.marquee--voices.marquee{
  /* fondo cream */
}

/* Track scroll infinito */
.marquee__track{
  display:flex;
  gap:0;
  width:max-content;
  animation:marqueeScroll 65s linear infinite;
  white-space:nowrap;
  will-change:transform;
}
.marquee__track--reverse{
  animation:marqueeScrollReverse 55s linear infinite;
}
@keyframes marqueeScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@keyframes marqueeScrollReverse{
  0%{transform:translateX(-50%)}
  100%{transform:translateX(0)}
}

/* Pause on hover */
.marquee:hover .marquee__track{
  animation-play-state:paused;
}

/* Items */
.marquee__item{
  display:inline-flex;
  align-items:center;
  padding:0 28px;
  font-size:.92rem;
  font-weight:500;
  color:oklch(0.92 0.05 192);
  letter-spacing:.005em;
  flex:none;
}
.marquee__item b{
  color:var(--cream);
  font-weight:700;
}

.marquee__quote{
  display:inline-flex;
  align-items:center;
  padding:0 32px;
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:1.1rem;
  font-weight:400;
  color:var(--ink);
  letter-spacing:-.01em;
  font-variation-settings:"opsz" 144;
  flex:none;
  line-height:1.2;
}

/* Separador (punto) */
.marquee__dot{
  display:inline-block;
  width:5px;
  height:5px;
  border-radius:50%;
  background:oklch(0.65 0.10 188 / .6);
  flex:none;
  margin:0 0;
}
.marquee--voices .marquee__dot{
  background:oklch(0.55 0.10 188 / .35);
  width:4px;
  height:4px;
}

/* Disclaimer voices */
.marquee__disclaimer{
  font-size:.7rem;
  color:var(--muted);
  text-align:center;
  margin:6px 0 0;
  padding:0 22px;
  letter-spacing:.01em;
  font-style:italic;
}

/* Fade en bordes (gradient mask) */
.marquee::before,
.marquee::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:60px;
  z-index:2;
  pointer-events:none;
}
.marquee::before{
  left:0;
  background:linear-gradient(to right, var(--brand), transparent);
}
.marquee::after{
  right:0;
  background:linear-gradient(to left, var(--brand), transparent);
}
.marquee--voices::before{
  background:linear-gradient(to right, var(--paper), transparent);
}
.marquee--voices::after{
  background:linear-gradient(to left, var(--paper), transparent);
}

/* Responsive — ajustes mobile */
@media(max-width:780px){
  .marquee{padding:12px 0}
  .marquee__item{font-size:.85rem;padding:0 22px}
  .marquee__quote{font-size:.98rem;padding:0 24px}
  .marquee__track{animation-duration:50s}
  .marquee__track--reverse{animation-duration:45s}
  .marquee::before,.marquee::after{width:40px}
}

@media(prefers-reduced-motion: reduce){
  .marquee__track{animation:none}
}

/* ════════════════════════════════════════════════════════════════
   COMPACTAR BANDA STATS — más sutil
   ════════════════════════════════════════════════════════════════ */
.marquee--stats{padding:10px 0}
.marquee--stats .marquee__item{font-size:.82rem;padding:0 22px;font-weight:500}
.marquee--stats .marquee__item b{font-weight:700}
@media(max-width:780px){.marquee--stats{padding:8px 0}.marquee--stats .marquee__item{font-size:.76rem}}

/* ════════════════════════════════════════════════════════════════
   CARRUSEL DE TESTIMONIOS — compacto, auto-rotativo
   ════════════════════════════════════════════════════════════════ */
.testimonial-carousel{
  position:relative;
  max-width:760px;
  margin:0 auto;
  overflow:hidden;
}
.testimonial-track{
  display:flex;
  transition:transform .6s cubic-bezier(.16,1,.3,1);
  will-change:transform;
}
.testimonial{
  flex:0 0 100%;
  padding:8px 32px;
  text-align:center;
}
.testimonial__quote{
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:clamp(1.1rem,2.6vw,1.45rem);
  color:var(--ink);
  line-height:1.4;
  letter-spacing:-.012em;
  font-variation-settings:"opsz" 144;
  margin-bottom:14px;
  font-weight:400;
}
.testimonial__meta{
  font-size:.78rem;
  color:var(--brand);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
}

.testimonial-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:18px;
}
.testimonial-dots button{
  width:8px;
  height:8px;
  border-radius:50%;
  border:none;
  background:oklch(0.78 0.04 192);
  cursor:pointer;
  padding:0;
  transition:background .2s, transform .2s;
}
.testimonial-dots button.active{
  background:var(--brand);
  transform:scale(1.3);
}
.testimonial-dots button:hover{background:var(--brand-soft)}

/* ════════════════════════════════════════════════════════════════
   FIX URGENTES — 12 jun 2026
   ════════════════════════════════════════════════════════════════ */

/* FIX 1: Marquee se mueve SIEMPRE (ignora prefers-reduced-motion para banners decorativos) */
.marquee__track{
  animation: marqueeScroll 40s linear infinite !important;
}
.marquee__track--reverse{
  animation: marqueeScrollReverse 40s linear infinite !important;
}
@media(prefers-reduced-motion: reduce){
  /* permitir scroll horizontal manual si el usuario quiere */
  .marquee{overflow-x:auto}
  .marquee__track{animation:none !important}
}

/* FIX 2: SVG del shield en evidence-safety — limitar tamaño con !important */
.evidence-safety__icon{
  width:64px !important;
  height:64px !important;
  flex:none !important;
  max-width:64px !important;
  max-height:64px !important;
}
.evidence-safety__icon svg{
  width:32px !important;
  height:32px !important;
  max-width:32px !important;
  max-height:32px !important;
  stroke:var(--brand);
}

/* FIX 3: Community bullets SVGs limitados */
.community__bullets li svg{
  width:26px !important;
  height:26px !important;
  max-width:26px !important;
  max-height:26px !important;
  flex:none;
}

/* FIX 4: Galería de resultados → CARRUSEL HORIZONTAL en lugar de grid apilado en mobile */
.results-grid{
  display:flex !important;
  flex-direction:row !important;
  grid-template-columns:none !important;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding:0 22px 16px;
  margin:36px -22px 0;
  gap:14px;
  max-width:100vw;
}
.results-grid::-webkit-scrollbar{display:none}
.result-card{
  flex:0 0 78%;
  scroll-snap-align:center;
  max-width:340px;
}
.result-card img{
  height:280px !important;
  aspect-ratio:auto !important;
  object-fit:cover;
}
@media(min-width:760px){
  .results-grid{
    display:grid !important;
    grid-template-columns:repeat(3,1fr) !important;
    overflow:visible;
    padding:0;
    margin:36px 0 0;
  }
  .result-card{flex:auto;max-width:none}
}

/* FIX 5: Comunidad — en mobile NO duplicar imagen + bullets, hacer más compacto */
@media(max-width:780px){
  .community{padding:28px 22px;gap:18px}
  .community__visual{padding:18px 16px;gap:12px}
  .community__visual img{max-height:200px !important}
}

/* FIX 6: SVGs sueltos en bullets de incluye/community sin tamaño definido */
.incluye__item svg{width:22px;height:22px;flex:none}


/* ════════════════════════════════════════════════════════════════
   FIX MOBILE: 2 columnas en lugar de 1 para reducir altura vertical
   ════════════════════════════════════════════════════════════════ */

@media(max-width:779px){
  /* SEGMENTOS — Problema (Probaste dietas, Entrenas y no baja, etc.) */
  .seg-list{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:14px !important;
    margin-top:24px !important;
  }
  .seg{
    flex-direction:column !important;
    align-items:flex-start !important;
    padding:14px 12px !important;
    border:1px solid var(--line) !important;
    border-radius:14px !important;
    gap:10px !important;
    background:var(--surface) !important;
  }
  .seg .ic-tile{
    width:34px !important;
    height:34px !important;
  }
  .seg h3{
    font-size:.9rem !important;
    line-height:1.2 !important;
    margin-bottom:4px !important;
  }
  .seg p{
    font-size:.8rem !important;
    line-height:1.35 !important;
    color:var(--ink-soft) !important;
  }

  /* PLANES — 1 mes y 3 meses en 2 columnas */
  .plans{
    grid-template-columns:1fr 1fr !important;
    gap:12px !important;
    margin-top:24px !important;
  }
  .plan{
    padding:20px 14px !important;
    border-radius:14px !important;
  }
  .plan h3{
    font-size:1.05rem !important;
    margin-bottom:4px !important;
  }
  .plan__price{
    font-size:1.6rem !important;
    margin:4px 0 12px !important;
  }
  .plan__price span{font-size:.78rem !important}
  .plan ul{
    margin-bottom:14px !important;
    gap:6px !important;
  }
  .plan li{
    font-size:.78rem !important;
    line-height:1.35 !important;
    padding-left:18px !important;
  }
  .plan__badge{
    font-size:.62rem !important;
    padding:3px 10px !important;
    top:-10px !important;
  }
  .plan .btn{
    font-size:.85rem !important;
    padding:11px 14px !important;
  }

  /* CÓMO FUNCIONA — 3 pasos compactos verticales (no caben 2 cols con timeline) */
  /* Mejor reducir tamaños internos para acortar */
  .steps{
    margin-top:20px !important;
    gap:0 !important;
  }
  .step{
    padding:14px 0 !important;
  }
  .step .n{
    width:32px !important;
    height:32px !important;
    font-size:.88rem !important;
  }
  .step h3{
    font-size:1rem !important;
    margin-bottom:2px !important;
  }
  .step p{
    font-size:.84rem !important;
    line-height:1.4 !important;
  }
  .step:not(:last-child)::after{
    left:15px !important;
    top:48px !important;
    height:calc(100% - 30px) !important;
  }

  /* CTAs de planes con texto más corto en mobile */
  .plan .btn span,
  .plan .btn{
    white-space:nowrap !important;
  }
}

/* Mobile pequeño — desactivar 2 columnas si <360px */
@media(max-width:359px){
  .seg-list{grid-template-columns:1fr !important}
  .plans{grid-template-columns:1fr !important}
}

/* ════════════════════════════════════════════════════════════════
   AUDITORÍA FINAL — Compactación de espacios blancos
   ════════════════════════════════════════════════════════════════ */

/* Reducir padding de secciones — antes 64/88px, ahora 48/64px */
.section{padding:48px 0 !important}
@media(min-width:780px){
  .section{padding:64px 0 !important}
}
@media(min-width:600px) and (max-width:779.98px){
  .section{padding:56px 0 !important}
}

/* Hero: padding más ajustado */
.hero{padding:24px 0 8px !important}
@media(min-width:780px){
  .hero{padding:36px 0 24px !important}
}

/* Reducir gap eyebrow → h2 */
.eyebrow{margin-bottom:.5rem !important}

/* H2 con margen inferior reducido */
h2{margin-bottom:.35em !important}

/* Lead con margen inferior reducido */
.center .lead, .narrow .lead{margin-bottom:.5em}

/* Hero CTA: menos margen top */
.hero__cta{margin-top:14px !important}
.hero .chips{margin-top:12px !important}

/* Garantía: padding más compacto */
.guarantee{padding:16px 20px !important; margin-top:18px !important}
.guarantee h4{margin-bottom:2px !important}

/* Incluye: padding más compacto */
.incluye{
  padding:22px 22px !important;
  margin-top:24px !important;
}
.incluye__title{margin-bottom:14px !important}
.incluye__grid{gap:10px !important}
.incluye__item{font-size:.9rem !important;line-height:1.4 !important}

/* mol-detail: margen top reducido */
.mol-detail{margin-top:24px !important}

/* Steps: gaps más compactos */
.steps{margin-top:24px !important}
.step{padding:18px 0 !important}

/* Plans: margen top reducido */
.plans{margin-top:32px !important}

/* Topbar más sutil */
.topbar{padding:7px 16px !important;font-size:.78rem !important}

/* FAQ details más compactos */
details{padding:14px 18px !important;margin-bottom:8px !important}
details summary{font-size:.95rem !important}
details p{font-size:.88rem !important;line-height:1.5 !important;margin-top:6px !important}

/* Authbar compacto */
.authbar .in{padding:20px 0 !important}

/* Community más compacto */
.community{padding:32px 28px !important}
@media(min-width:820px){
  .community{padding:36px 40px !important;gap:36px !important}
}

/* CTA final más ajustado */
.calc{padding:32px 24px !important}
@media(min-width:780px){
  .calc{padding:38px 30px !important}
}

/* Reducir h1 margin bottom en hero */
.hero h1{margin:.15em 0 .35em !important}


/* ════════════════════════════════════════════════════════════════
   HERO v2 — IMPACTO INMEDIATO EN MOBILE
   ════════════════════════════════════════════════════════════════ */

/* MOBILE: foto ARRIBA del texto (visible al cargar) */
@media(max-width:779px){
  .hero{padding:18px 0 0 !important}
  .hero .wrap{
    display:flex !important;
    flex-direction:column !important;
    gap:24px !important;
  }
  .hero__media{
    order:-1 !important;
    margin-top:0 !important;
    max-width:100% !important;
    width:100% !important;
  }
  .hero__media img{
    border-radius:18px !important;
    height:260px !important;
    object-fit:cover !important;
    object-position:center 25% !important;
  }
  .doc-badge{
    bottom:-12px !important;
    padding:6px 14px 6px 6px !important;
    box-shadow:0 8px 24px rgba(0,0,0,.18) !important;
  }
  .doc-badge img{width:36px !important;height:36px !important}
  .doc-badge b{font-size:.76rem !important}
  .doc-badge span{font-size:.66rem !important}

  /* Texto del hero compactado */
  .hero__text{padding-top:6px}
  .hero h1{
    font-size:clamp(2.1rem,7.5vw,2.8rem) !important;
    line-height:1.02 !important;
    margin:.4em 0 .35em !important;
    letter-spacing:-.028em !important;
    max-width:none !important;
  }
  .hero h1 em{
    font-style:italic;
    color:var(--accent);
    font-weight:600;
  }
  .hero .lead{
    font-size:1.02rem !important;
    line-height:1.45 !important;
    max-width:none !important;
    color:var(--ink-soft);
    margin-bottom:18px !important;
  }
  .hero .eyebrow{
    font-size:.65rem !important;
    margin-bottom:.6rem !important;
  }

  /* CTA full-width en mobile, primario destacado */
  .hero__cta{
    flex-direction:column !important;
    gap:10px !important;
    max-width:none !important;
    margin-top:0 !important;
  }
  .hero__cta .btn{
    width:100%;
    padding:14px 22px;
    font-size:.95rem;
  }

  /* Trust strip — micro indicators sutiles */
  .hero__trust{
    display:flex !important;
    flex-wrap:wrap;
    align-items:center;
    justify-content:center;
    gap:8px 14px;
    margin-top:18px;
    padding:14px 0 6px;
    border-top:1px solid var(--line);
    text-align:center;
  }
  .hero__trust-item{
    font-size:.72rem;
    color:var(--muted);
    font-weight:600;
    letter-spacing:.01em;
    white-space:nowrap;
  }
}

/* DESKTOP: hero__trust al lado del texto, debajo de CTAs */
@media(min-width:780px){
  .hero__trust{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px 22px;
    margin-top:22px;
    padding-top:18px;
    border-top:1px solid var(--line);
  }
  .hero__trust-item{
    font-size:.78rem;
    color:var(--muted);
    font-weight:600;
    letter-spacing:.01em;
  }
  /* Restaurar text-align left en desktop hero text */
  .hero__text{display:flex;flex-direction:column}
}

/* Asegurar que el carrusel de testimonios y banda usen el .marquee--stats */
.hero .chips{display:none}

/* ════════════════════════════════════════════════════════════════
   SECCIÓN PROGRESO REAL — 3 fotos timeline de paciente
   ════════════════════════════════════════════════════════════════ */
.progreso-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  max-width:980px;
  margin:0 auto;
}
@media(max-width:679px){
  /* En mobile: carrusel horizontal con scroll-snap */
  .progreso-grid{
    display:flex;
    flex-direction:row;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:0 22px 16px;
    margin:0 -22px;
    gap:12px;
  }
  .progreso-grid::-webkit-scrollbar{display:none}
  .progreso-card{
    flex:0 0 78%;
    scroll-snap-align:center;
    max-width:340px;
  }
}

.progreso-card{
  position:relative;
  margin:0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  transition:transform .4s cubic-bezier(.16,1,.3,1), box-shadow .4s;
}
.progreso-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.progreso-card--final{
  border:2px solid var(--brand);
  box-shadow:0 8px 24px oklch(0.30 0.08 192 / .14);
}
.progreso-card img{
  width:100%;
  height:auto;
  aspect-ratio:3/4;
  object-fit:cover;
  object-position:center top;
  display:block;
  background:var(--surface-2);
}
.progreso-card figcaption{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 14px;
  background:var(--paper);
  border-top:1px solid var(--line);
}
.progreso-tag{
  font-size:.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--brand);
}
.progreso-card--final .progreso-tag{
  color:var(--accent);
}
.progreso-date{
  font-family:'Fraunces',serif;
  font-size:.96rem;
  color:var(--ink);
  font-weight:600;
  font-variation-settings:"opsz" 144;
  letter-spacing:-.01em;
}

.progreso-disclaimer{
  max-width:760px;
  margin:24px auto 0;
  font-size:.74rem;
  line-height:1.55;
  color:var(--muted);
  text-align:center;
  padding:14px 18px;
  background:var(--surface-2);
  border-radius:10px;
  border:1px solid var(--line);
}

/* ════════════════════════════════════════════════════════════════
   RESULTADOS REALES — Hero destacado + Galería de casos
   ════════════════════════════════════════════════════════════════ */

/* HERO COMPARATIVO DESTACADO */
.resultado-destacado{
  position:relative;
  max-width:880px;
  margin:0 auto 32px;
  border-radius:20px;
  overflow:hidden;
  background:var(--ink);
  box-shadow:0 24px 60px oklch(0.08 0.04 192 / .25);
  border:2px solid var(--brand);
}
.resultado-destacado img{
  width:100%;
  height:auto;
  display:block;
  background:var(--surface-2);
}
.resultado-destacado figcaption{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  padding:14px 22px;
  background:var(--ink);
  color:var(--cream);
}
.resultado-tag{
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:oklch(0.78 0.10 188);
  background:oklch(0.20 0.06 192);
  padding:5px 12px;
  border-radius:50px;
}
.resultado-info{
  font-size:.84rem;
  color:oklch(0.86 0.04 80);
  font-weight:400;
}
.resultado-info b{color:var(--cream);font-weight:700}

/* GALERÍA DE MÁS CASOS */
.resultados-galeria{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  max-width:1080px;
  margin:0 auto;
}
@media(max-width:759px){
  .resultados-galeria{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
}
@media(max-width:419px){
  .resultados-galeria{
    grid-template-columns:1fr;
    gap:12px;
  }
}

.resultado-card{
  margin:0;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s;
}
.resultado-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
}
.resultado-card img{
  width:100%;
  height:auto;
  aspect-ratio:1/1;
  object-fit:cover;
  object-position:center;
  display:block;
  background:var(--surface-2);
}
.resultado-card figcaption{
  padding:10px 12px;
  font-size:.78rem;
  color:var(--ink-soft);
  text-align:center;
  background:var(--paper);
  border-top:1px solid var(--line);
  font-weight:500;
}

/* DISCLAIMER */
.resultado-disclaimer{
  max-width:760px;
  margin:32px auto 0;
  font-size:.74rem;
  line-height:1.55;
  color:var(--muted);
  text-align:center;
  padding:14px 18px;
  background:var(--surface-2);
  border-radius:10px;
  border:1px solid var(--line);
}

/* ════════════════════════════════════════════════════════════════
   PAGOS — Diseño nuevo (cards modernas con iconos)
   ════════════════════════════════════════════════════════════════ */
.pagos{
  max-width:900px;
  margin:40px auto 0;
  padding:32px;
  background:linear-gradient(160deg, var(--brand-tint), var(--surface));
  border:1px solid var(--brand-soft);
  border-radius:24px;
}
@media(max-width:560px){
  .pagos{padding:24px 18px;border-radius:18px;margin-top:32px}
}

.pagos__header{text-align:center;margin-bottom:24px}
.pagos__eyebrow{
  display:inline-block;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-600);
  margin-bottom:6px;
}
.pagos__header h3{
  font-family:'Fraunces',serif;
  font-size:clamp(1.4rem,3vw,1.8rem);
  color:var(--ink);
  font-weight:600;
  letter-spacing:-.018em;
  margin:0;
  font-variation-settings:"opsz" 144;
}

.pagos__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
@media(max-width:560px){
  .pagos__grid{grid-template-columns:1fr;gap:12px}
}

.pago-card{
  position:relative;
  background:var(--surface);
  border:1.5px solid var(--line);
  border-radius:16px;
  padding:22px 20px;
  transition:transform .3s cubic-bezier(.16,1,.3,1), border-color .3s, box-shadow .3s;
}
.pago-card:hover{
  transform:translateY(-3px);
  border-color:var(--brand-soft);
  box-shadow:0 14px 30px oklch(0.20 0.08 192 / .1);
}
.pago-card--featured{
  border-color:var(--brand);
  border-width:2px;
  background:linear-gradient(165deg, var(--surface) 0%, oklch(0.97 0.04 188) 100%);
  box-shadow:0 8px 24px oklch(0.30 0.10 192 / .12);
}

.pago-card__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:14px;
}

.pago-card__icon{
  width:44px;height:44px;
  border-radius:12px;
  background:var(--brand-tint);
  color:var(--brand);
  display:flex;align-items:center;justify-content:center;
}
.pago-card__icon svg{width:24px;height:24px}
.pago-card__icon--alt{
  background:oklch(0.94 0.03 250);
  color:oklch(0.42 0.16 250);
}

.pago-card__badge{
  font-size:.7rem;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:5px 11px;
  border-radius:50px;
}
.pago-card__badge--save{
  background:var(--brand);
  color:var(--cream);
}
.pago-card__badge--msi{
  background:oklch(0.42 0.16 250);
  color:#fff;
}

.pago-card h4{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.1rem;
  font-weight:700;
  color:var(--ink);
  margin:0 0 6px;
  letter-spacing:-.01em;
}
.pago-card p{
  font-size:.88rem;
  color:var(--ink-soft);
  line-height:1.45;
  margin:0 0 14px;
}

.pago-card__list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.pago-card__list li{
  font-size:.82rem;
  color:var(--ink-soft);
  padding-left:20px;
  position:relative;
  line-height:1.4;
}
.pago-card__list li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--brand);
  font-weight:700;
  font-size:.9rem;
}
.pago-card--featured .pago-card__list li::before{
  color:var(--accent);
}

.pagos__footer{
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid var(--brand-soft);
}
.pagos__trust{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-size:.84rem;
  color:var(--ink-soft);
  text-align:center;
}
.pagos__trust svg{
  width:18px;height:18px;
  stroke:var(--brand);
  fill:none;
  flex:none;
}
@media(max-width:560px){
  .pagos__trust{font-size:.78rem;gap:8px}
  .pagos__trust span{text-align:left}
}

/* ════════════════════════════════════════════════════════════════
   RESULTADO DEL QUIZ v3 — polish impeccable
   Estrategia color: restrained (cream paper + tinted neutrals)
   + UN bloque drenched (hero number) que detiene el scroll.
   Rhythm spacing: 8 / 12 / 20 / 32 / 48 (no padding monotony).
   ════════════════════════════════════════════════════════════════ */

/* Reset cascada legacy del .reco viejo y center heredado */
.step.result{text-align:left}
.step.result .reco{all:unset;display:block}

.rx-wrap{
  max-width:640px;margin:0 auto;
  display:flex;flex-direction:column;gap:18px;
}

/* — INTRO — */
.rx-intro{text-align:left;margin:0;padding-bottom:4px;border-bottom:1px solid var(--line)}
.rx-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--brand);margin-bottom:10px;
}
.rx-eyebrow::before{
  content:"";width:16px;height:1.5px;background:var(--brand);
}
.rx-headline{
  font-family:'Fraunces',serif;
  font-size:clamp(1.5rem,5vw,2.2rem);
  font-weight:600;color:var(--ink);
  line-height:1.08;letter-spacing:-.022em;
  font-variation-settings:"opsz" 144;
  margin:0 0 10px;
}
.rx-headline em{font-style:italic;color:var(--brand);font-weight:500}
.rx-sub{
  font-size:.95rem;line-height:1.5;color:var(--ink-soft);
  margin:0;
}
.rx-sub strong{color:var(--ink);font-weight:600}

/* — HERO NÚMERO — */
.rx-hero-num{
  background:var(--brand);
  border-radius:16px;padding:32px 24px 28px;
  text-align:center;
  margin:0;
}
.rx-hero-num::before{display:none}
.rx-num-label{
  display:block;font-size:.64rem;font-weight:700;letter-spacing:.22em;
  color:oklch(0.90 0.06 188);margin-bottom:12px;
  text-transform:uppercase;
}
.rx-num-big{
  display:block;font-family:'Fraunces',serif;
  font-size:clamp(4.5rem,20vw,7rem);font-weight:700;
  line-height:.9;letter-spacing:-.055em;
  color:#fff;margin:0;
  font-variation-settings:"opsz" 144;
}
.rx-num-unit{
  display:block;font-family:'Fraunces',serif;font-style:italic;
  font-weight:400;font-size:clamp(1rem,3vw,1.3rem);
  color:oklch(0.92 0.05 188);
  margin-top:10px;letter-spacing:-.005em;
}
.rx-num-context{
  margin:18px auto 0;padding-top:16px;max-width:380px;
  border-top:1px solid oklch(0.45 0.06 192);
  font-size:.8rem;color:oklch(0.90 0.04 188);line-height:1.5;
}
.rx-num-context b{color:#fff;font-weight:600}

/* — TIMELINE — */
.rx-timeline{margin:0;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:18px 14px 14px}
.rx-timeline__title{
  font-size:.64rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;color:var(--muted);
  text-align:center;margin-bottom:16px;
}
.rx-timeline__grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:0;position:relative;
  padding:8px 0;
}
/* línea base que conecta los 3 hitos — alineada con los puntos */
.rx-timeline__grid::before{
  content:"";position:absolute;
  left:18%;right:18%;
  top:29px;          /* grid-padding(8) + card-padding(14) + dot-radius(7) */
  height:2px;
  background:linear-gradient(90deg,
    oklch(0.85 0.04 192) 0%,
    var(--brand-soft) 50%,
    var(--accent) 100%);
  z-index:0;
}
.rx-tl-card{
  background:var(--paper);
  border:none;border-radius:0;
  padding:14px 6px;text-align:center;
  position:relative;z-index:1;
}
.rx-tl-card::before{
  content:"";display:block;
  width:14px;height:14px;border-radius:50%;
  margin:0 auto 10px;
  background:var(--paper);
  border:2px solid var(--brand-soft);
}
.rx-tl-card--mid::before{
  background:var(--brand-soft);border-color:var(--brand-soft);
}
.rx-tl-card--goal::before{
  background:var(--accent);border-color:var(--accent);
  width:16px;height:16px;
  box-shadow:0 0 0 4px oklch(0.95 0.05 188);
}
/* todos los cards con fondo sólido para que la línea no cruce los números */
.rx-tl-card--mid,.rx-tl-card--goal{background:var(--paper)}
.rx-tl-num{
  font-family:'Fraunces',serif;
  font-size:clamp(1.25rem,4.2vw,1.7rem);
  font-weight:700;color:var(--brand);
  line-height:1;letter-spacing:-.025em;
  font-variation-settings:"opsz" 144;
}
.rx-tl-card--goal .rx-tl-num{color:var(--accent)}
.rx-tl-lbl{
  display:block;font-size:.68rem;font-weight:700;
  color:var(--muted);margin-top:6px;
  text-transform:uppercase;letter-spacing:.1em;
}
.rx-tl-card--goal .rx-tl-lbl{color:var(--accent-600)}

/* — COMPARATIVA — */
.rx-compare{
  margin:0;padding:16px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
}
.rx-compare__row{
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:12px;
}
.rx-compare__col{
  padding:0;background:none;border:none;border-radius:0;
  text-align:center;
}
.rx-compare__col--bad{}
.rx-compare__col--good{}
.rx-compare__lbl{
  display:block;font-size:.64rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--muted);margin-bottom:8px;
}
.rx-compare__val{
  display:block;font-family:'Fraunces',serif;font-weight:700;
  font-size:clamp(1.4rem,4.5vw,1.8rem);
  color:var(--ink);line-height:1;letter-spacing:-.025em;
  font-variation-settings:"opsz" 144;
}
.rx-compare__col--bad .rx-compare__val{
  color:oklch(0.50 0.18 30);
  text-decoration:line-through;text-decoration-thickness:1.5px;
  text-decoration-color:oklch(0.50 0.18 30 / .4);
}
.rx-compare__col--good .rx-compare__val{color:var(--brand)}
.rx-compare__note{
  display:block;font-size:.7rem;color:var(--muted);
  margin-top:6px;letter-spacing:.01em;
}
.rx-compare__vs{
  font-family:'Fraunces',serif;font-style:italic;
  font-weight:400;color:var(--muted);
  font-size:1rem;padding:0 4px;
  align-self:center;
}

/* — DR. VÉRTIZ — */
.rx-doc{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--surface);border:1px solid var(--line);border-radius:14px;
  padding:16px;margin:0;
}
.rx-doc__photo{
  width:56px;height:56px;border-radius:50%;flex:none;
  background-size:cover;background-position:center top;
  border:none;box-shadow:0 0 0 1px var(--line);
}
.rx-doc__body{flex:1;min-width:0}
.rx-doc__name{
  font-family:'Fraunces',serif;font-weight:600;
  color:var(--ink);font-size:.98rem;line-height:1.2;
  font-variation-settings:"opsz" 144;
}
.rx-doc__title{
  font-size:.74rem;color:var(--muted);
  margin-top:2px;letter-spacing:.01em;
}
.rx-doc__quote{
  font-family:'Fraunces',serif;font-style:italic;
  font-size:.92rem;color:var(--ink-soft);
  line-height:1.45;margin:10px 0 0;
  font-variation-settings:"opsz" 144;
  border-left:3px solid var(--brand-soft);
  padding-left:14px;
}

/* — PROGRAMA — el único card real (es la oferta) */
.rx-program{
  background:var(--surface);
  border:1px solid var(--brand-soft);border-radius:18px;
  padding:28px;margin:0;
  box-shadow:0 1px 0 var(--line), 0 12px 32px oklch(0.30 0.08 192 / .08);
}
.rx-program__head{margin-bottom:20px}
.rx-program__tag{
  display:inline-block;font-size:.62rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);background:none;padding:0;
  border-radius:0;margin-bottom:10px;
}
.rx-program__tag::before{content:"— "}
.rx-program h3{
  font-family:'Fraunces',serif;font-size:1.4rem;
  color:var(--ink);font-weight:600;
  font-variation-settings:"opsz" 144;
  line-height:1.15;margin:0;letter-spacing:-.015em;
}
.rx-program__features{
  display:flex;flex-direction:column;gap:8px;
  margin:0 0 24px;
}
.rx-program__features > div{
  font-size:.92rem;color:var(--ink-soft);
  line-height:1.4;padding-left:22px;position:relative;
}
.rx-program__features > div b{
  position:absolute;left:0;top:1px;
  color:var(--brand);font-weight:700;margin-right:0;
  font-size:.92rem;
}
.rx-program__price{
  display:flex;align-items:baseline;gap:10px;
  padding-top:20px;border-top:1px solid var(--line);
}
.rx-program__amount{
  font-family:'Fraunces',serif;font-size:2.4rem;
  font-weight:700;color:var(--ink);
  font-variation-settings:"opsz" 144;letter-spacing:-.03em;
  line-height:1;
}
.rx-program__unit{font-size:.78rem;color:var(--muted);letter-spacing:.01em}

/* — CTAs — jerarquía clara, sin marcos competidores */
.rx-ctas{margin:0;display:flex;flex-direction:column;gap:14px}
.rx-cta-main{
  font-size:1rem !important;font-weight:700 !important;
  padding:18px 24px !important;
  letter-spacing:-.005em !important;
}
.rx-cta-alt{
  display:block;text-align:center;
  font-size:.9rem;color:var(--ink-soft);
  text-decoration:none;
  padding:8px 0;
}
.rx-cta-alt::after{
  content:" →";color:var(--brand);font-weight:600;
  transition:transform .25s cubic-bezier(.16,1,.3,1);
  display:inline-block;
}
.rx-cta-alt:hover{color:var(--brand)}
.rx-cta-alt:hover::after{transform:translateX(3px)}

/* — GARANTÍA + URGENCIA + DISCLAIMER — fine print agrupado, sin cards */
.rx-warranty,.rx-urgency{
  display:block;background:none;border:none;
  padding:0;margin:0;
  font-size:.82rem;color:var(--ink-soft);
  line-height:1.5;text-align:left;
}
.rx-warranty{
  display:grid;grid-template-columns:auto 1fr;gap:10px;
  align-items:start;
}
.rx-warranty__icon{
  font-size:1rem;line-height:1.5;color:var(--brand);
  font-weight:700;
}
.rx-warranty__icon::before{content:"✓ "}
.rx-warranty__icon > *{display:none}
.rx-warranty__text b{color:var(--ink);font-weight:600}
.rx-urgency{padding-left:24px;position:relative}
.rx-urgency::before{
  content:"·";position:absolute;left:8px;top:0;
  color:var(--accent);font-weight:700;
}
.rx-urgency b{color:var(--ink);font-weight:600}

.rx-disclaimer{
  font-size:.7rem;color:var(--muted);
  line-height:1.55;text-align:left;
  padding:18px 0 0;margin:8px 0 0;
  border-top:1px solid var(--line);
  background:none;border-radius:0;
}

/* — ALERTA (flags médicas) — único caso con icon-tile */
.rx-card--alert{
  display:flex;gap:16px;align-items:flex-start;
  background:oklch(0.97 0.04 80);
  border:1px solid oklch(0.86 0.10 80);
  border-radius:16px;padding:24px;
}
.rx-card__icon{
  width:44px;height:44px;border-radius:12px;
  background:oklch(0.90 0.12 80);color:oklch(0.38 0.16 80);
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:700;flex:none;
}
.rx-card__body{flex:1}
.rx-card__body h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;
  color:oklch(0.38 0.14 80);margin:0 0 8px;font-weight:700;
}
.rx-card__body p{
  font-size:.92rem;color:var(--ink-soft);
  margin-bottom:16px;line-height:1.55;
}

.rx-card--info{
  background:var(--brand-tint);
  border:1px solid var(--brand-soft);border-radius:14px;
  padding:28px;text-align:left;
}
.rx-card--info h3{
  font-family:'Fraunces',serif;color:var(--brand);
  font-size:1.4rem;margin:0 0 10px;
  font-variation-settings:"opsz" 144;
  letter-spacing:-.015em;
}
.rx-card--info p{
  margin:0;font-size:.95rem;color:var(--ink-soft);
  line-height:1.55;
}

/* Responsive — colapsa donde se aplasta */
@media(max-width:419px){
  .rx-wrap{gap:24px}
  .rx-hero-num{padding:36px 20px 28px}
  .rx-doc{flex-direction:column;text-align:left;align-items:flex-start}
  .rx-doc__quote{margin-top:6px}
  .rx-program{padding:22px}
  .rx-compare__row{gap:8px}
  .rx-tl-card{padding:12px 2px}
}

/* ════════════════════════════════════════════════════════════════
   QUIZ FEATURE — sección dedicada con mockup
   ════════════════════════════════════════════════════════════════ */
.quiz-feature{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  background:linear-gradient(140deg,var(--brand) 0%,oklch(0.25 0.09 192) 100%);
  border-radius:24px;
  padding:36px 28px;
  color:var(--cream);
  position:relative;overflow:hidden;
  max-width:1080px;margin:0 auto;
  box-shadow:0 20px 60px oklch(0.25 0.10 192 / .25);
}
.quiz-feature::before{
  content:"";position:absolute;top:-30%;right:-15%;width:60%;height:160%;
  background:radial-gradient(ellipse 50% 40% at 50% 50%,oklch(0.62 0.12 188 / .25),transparent);
  pointer-events:none;
}
@media(min-width:780px){
  .quiz-feature{grid-template-columns:1.2fr 1fr;gap:48px;padding:48px 52px;align-items:center}
}

.quiz-feature__body{position:relative;z-index:1}
.quiz-feature__tag{
  display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:oklch(0.78 0.10 188);
  background:oklch(0.20 0.06 192);padding:6px 14px;border-radius:50px;
  margin-bottom:14px;
}
.quiz-feature__title{
  font-family:'Fraunces',serif;font-size:clamp(1.8rem,5vw,2.6rem);
  color:var(--cream);font-weight:600;line-height:1.05;
  letter-spacing:-.025em;margin-bottom:14px;
  font-variation-settings:"opsz" 144;
}
.quiz-feature__sub{
  font-size:1rem;color:oklch(0.84 0.04 80);line-height:1.5;
  margin-bottom:20px;max-width:480px;
}
.quiz-feature__list{
  list-style:none;padding:0;margin:0 0 24px;
  display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;
}
@media(max-width:559px){.quiz-feature__list{grid-template-columns:1fr}}
.quiz-feature__list li{
  font-size:.92rem;color:oklch(0.86 0.04 80);line-height:1.4;
  padding-left:0;
}
.quiz-feature__list b{color:oklch(0.78 0.12 188);margin-right:6px;font-weight:700}
.quiz-feature__cta{
  background:var(--cream) !important;color:var(--brand) !important;
  font-weight:700;padding:14px 24px;font-size:1rem;
}
.quiz-feature__cta:hover{
  background:var(--paper) !important;
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(0,0,0,.2);
}
.quiz-feature__trust{
  margin-top:14px;font-size:.8rem;color:oklch(0.76 0.06 188);
}

/* Mockup visual del quiz */
.quiz-feature__visual{position:relative;z-index:1;display:flex;justify-content:center}
.quiz-mockup{
  background:var(--cream);border-radius:16px;padding:20px;
  width:100%;max-width:280px;
  box-shadow:0 20px 50px rgba(0,0,0,.25);
  border:1px solid oklch(0.86 0.02 80);
}
.quiz-mockup__bar{
  height:5px;background:oklch(0.88 0.02 80);border-radius:5px;overflow:hidden;
}
.quiz-mockup__progress{
  width:66%;height:100%;background:var(--accent);border-radius:5px;
}
.quiz-mockup__step{
  font-size:.62rem;font-weight:700;letter-spacing:.12em;
  color:var(--muted);margin-top:12px;
}
.quiz-mockup__q{
  font-family:'Fraunces',serif;font-size:1.1rem;color:var(--ink);
  font-weight:600;line-height:1.2;margin-top:8px;
  font-variation-settings:"opsz" 144;
}
.quiz-mockup__input{
  margin-top:12px;padding:12px 14px;
  background:var(--surface-2);border:1.5px solid var(--brand-soft);
  border-radius:10px;font-family:'Fraunces',serif;font-size:1.3rem;
  color:var(--brand);font-weight:700;
  font-variation-settings:"opsz" 144;
}
.quiz-mockup__result{
  margin-top:14px;padding:12px 14px;
  background:var(--brand-tint);border-radius:10px;
  text-align:center;
}
.quiz-mockup__result span{
  display:block;font-size:.7rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent-600);
}
.quiz-mockup__result strong{
  display:block;font-family:'Fraunces',serif;font-size:1.3rem;
  color:var(--brand);margin-top:4px;font-weight:700;
  font-variation-settings:"opsz" 144;letter-spacing:-.01em;
}

/* ══════════════════════════════════════════════════════════
   MEJORAS VISUALES v2 — micro-animaciones + hover + marca
   ══════════════════════════════════════════════════════════ */

/* Plan cards hover */
.plan{transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s}
.plan:not(.plan--feat):hover{transform:translateY(-4px);box-shadow:0 12px 40px oklch(0.30 0.08 192 / .12)}

/* Testimonial cards hover */
.testi-card{transition:transform .2s,box-shadow .2s}
.testi-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px oklch(0.30 0.06 192 / .10)}

/* Pulse sutil en el botón de WhatsApp flotante */
@keyframes wa-pulse{0%,100%{box-shadow:0 4px 18px oklch(0.40 0.20 145 / .45)}50%{box-shadow:0 4px 28px oklch(0.40 0.20 145 / .70)}}
.wa{animation:wa-pulse 2.8s ease-in-out infinite}

/* Focus visible accesible en botones */
.btn:focus-visible{outline:3px solid var(--accent);outline-offset:3px}

/* Bump de producto hover */
.bump{transition:border-color .2s,background .2s}
.bump:hover{border-color:var(--accent);background:oklch(0.95 0.05 38)}

/* Nav scroll shadow */
.nav.scrolled{box-shadow:0 1px 0 var(--line)}

/* Garantía box mejorada */
.guarantee{
  background:oklch(0.96 0.03 188);
  border:1px solid oklch(0.80 0.08 188);
  border-radius:16px;padding:20px 22px;
  display:flex;gap:14px;align-items:flex-start;
  margin-top:28px;
}
.guarantee h4{font-size:1rem;color:var(--brand);margin-bottom:4px}
.guarantee p{margin:0;font-size:.9rem;color:var(--ink-soft)}

/* Pago cards hover */
.pago-card{transition:border-color .2s,box-shadow .2s,transform .2s}
.pago-card:hover{border-color:var(--brand);box-shadow:0 6px 20px oklch(0.30 0.08 192 / .10);transform:translateY(-2px)}

/* Stat display gradiente */
.problema-stat .display{
  background:linear-gradient(135deg,var(--brand) 0%,var(--accent) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Mobile: testimonial grid una columna */
@media(max-width:580px){
  .testi-grid{grid-template-columns:1fr !important}
}

/* Plan badge */
.plan__badge{
  background:var(--accent);color:#fff;
  font-size:.66rem;font-weight:700;letter-spacing:.08em;
  padding:4px 10px;border-radius:999px;text-transform:uppercase;
}
