/* ============================================================
   Gestando Estrellas · Onboarding de gestantes
   Paleta extraída del sitio oficial:
   primario #173B64 · secundario #A3C4EB · acento #FFDE70
   texto #353535 · fondos beige #F7EEE3 / crema #FBF7F0
   Tipografías reales del sitio: Gambarino (títulos) + Lato (texto)
============================================================ */
@font-face{
  font-family:'Gambarino';
  src:url('assets/fonts/Gambarino-Regular.woff') format('woff');
  font-weight:400;font-style:normal;font-display:swap;
}
:root{
  --navy:#173B64;
  --navy-700:#0f2b4b;
  --blue:#A3C4EB;
  --blue-soft:#E4EEFA;
  --yellow:#FFDE70;
  --yellow-soft:#FFEEB6;
  --text:#353535;
  --muted:#6c6c6c;
  --cream:#FBF7F0;
  --beige:#F7EEE3;
  --line:#E5E2DE;
  --white:#ffffff;
  --ok:#2e7d57;
  --shadow:0 18px 50px rgba(23,59,100,.10);
  --shadow-sm:0 6px 20px rgba(23,59,100,.08);
  --radius:22px;
  --radius-sm:14px;
  --display:'Gambarino', 'Lato', system-ui, sans-serif;
  --body:'Lato', system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box}
[hidden]{display:none !important}
/* vista=directo: oculta la info repetitiva de la landing (deja solo el hero con la edad) */
body.vista-directo .announce,
body.vista-directo .screen--intro .content-sec{display:none !important}
html,body{margin:0;padding:0}
body{
  font-family:var(--body);
  color:var(--text);
  background:
    radial-gradient(1100px 600px at 85% -10%, var(--blue-soft) 0%, transparent 55%),
    radial-gradient(900px 500px at -10% 110%, var(--yellow-soft) 0%, transparent 50%),
    var(--cream);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
}

/* ---------------- Header ---------------- */
.site-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,5vw,48px);
}
.brand img{height:46px;width:auto;display:block}
.header-help{
  font-family:var(--body);font-weight:700;font-size:.92rem;color:var(--navy);text-decoration:none;
  border:none;background:none;border-bottom:2px solid var(--yellow);padding:0 0 2px;cursor:pointer;
}
.header-help:hover{color:var(--navy-700)}

/* ---------------- Modal ¿Tienes dudas? ---------------- */
.modal-overlay{position:fixed;inset:0;z-index:100;background:rgba(15,43,75,.55);
  display:flex;align-items:center;justify-content:center;padding:20px;animation:fade .25s ease both}
.modal{position:relative;background:#fff;border-radius:24px;max-width:420px;width:100%;
  padding:34px 28px 30px;text-align:center;box-shadow:var(--shadow)}
.modal__close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:1.7rem;
  line-height:1;color:var(--muted);cursor:pointer;padding:4px 8px}
.modal__close:hover{color:var(--navy)}
.modal__icon{display:block;width:56px;height:56px;margin:0 auto 16px;color:#25D366}
.modal__icon svg{width:100%;height:100%}
.modal h3{font-family:var(--display);font-weight:400;font-size:1.6rem;color:var(--navy);margin:0 0 10px}
.modal p{color:var(--text);line-height:1.55;font-size:1rem;margin:0 0 24px;max-width:34ch;margin-inline:auto}
.btn--wa{background:#25D366;color:#fff;width:100%;justify-content:center;
  text-transform:none;letter-spacing:0;font-size:1.02rem;gap:10px;
  box-shadow:0 10px 24px rgba(37,211,102,.3)}
.btn--wa:hover{background:#1fb457;box-shadow:0 12px 28px rgba(37,211,102,.36)}
.btn--wa svg{width:22px;height:22px;fill:currentColor;flex:none}

/* ---------------- Progreso ---------------- */
.progress-wrap{
  max-width:760px;margin:0 auto;width:100%;
  padding:6px clamp(18px,5vw,32px) 0;
  display:flex;align-items:center;gap:14px;
}
.progress-track{flex:1;height:8px;background:#eadfce;border-radius:999px;overflow:hidden}
.progress-bar{height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--blue),var(--navy));
  transition:width .45s cubic-bezier(.4,0,.2,1)}
.progress-label{font-size:.78rem;font-weight:700;color:var(--muted);white-space:nowrap}

/* ---------------- Layout app ---------------- */
.app{
  flex:1;width:100%;max-width:1080px;margin:0 auto;
  padding:0 clamp(16px,4vw,36px);
}

.screen{display:none;animation:fade .5s ease both}
.screen.is-active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* Los pasos del formulario y el final se centran verticalmente; la landing fluye */
#questions .screen.is-active,
.screen--verify.is-active,
.screen--final.is-active{
  min-height:calc(100vh - 210px);
  display:flex;flex-direction:column;justify-content:center;
  padding:24px 0;
}
.q-card,.final-card{max-width:680px;width:100%;margin:0 auto}

/* Verificación de teléfono */
.screen--verify .q-card{max-width:540px;margin:0 auto;width:100%}
.verify-back{background:none;border:none;color:var(--navy);font-weight:700;cursor:pointer;
  padding:0;margin-bottom:18px;font-size:.95rem;letter-spacing:.02em}
.verify-back:hover{color:var(--navy-700)}
.otp{display:flex;gap:10px;justify-content:center;margin-top:2px}
.otp-box{width:54px;height:62px;text-align:center;font-family:var(--body);font-size:1.6rem;
  font-weight:700;color:var(--navy);border:2px solid var(--line);border-radius:14px;
  background:var(--cream);outline:none;transition:border-color .2s,box-shadow .2s,background .2s}
.otp-box:focus{border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-soft);background:#fff}
.otp-box.filled{border-color:var(--navy);background:#fff}
@media (max-width:560px){.otp{gap:8px}.otp-box{width:46px;height:56px;font-size:1.4rem}}
.verify-submit{width:100%;justify-content:center;margin-top:8px}
.verify-resend{margin:16px 0 0;font-size:.88rem;color:var(--muted);text-align:center;min-height:1.2em}
.verify-resend strong{color:var(--navy)}
.link-btn{background:none;border:none;color:var(--navy);font-weight:700;
  text-decoration:underline;cursor:pointer;font:inherit}

/* Código postal: campo corto (solo 5 dígitos) */
#f_postalCode{max-width:200px;letter-spacing:.12em}

/* ---------------- Headings ---------------- */
h1,h2{font-family:var(--display);color:var(--navy);line-height:1.14;font-weight:400;margin:0}
h1{font-size:clamp(2.1rem,5.6vw,3.3rem)}
h1 em{font-style:normal;color:var(--navy);position:relative}
h1 em::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.28em;
  background:var(--yellow);opacity:.55;z-index:-1;border-radius:4px}
.q-title{font-size:clamp(1.5rem,3.6vw,2.1rem);margin-bottom:8px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);color:var(--navy);font-weight:700;
  font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;
  padding:7px 14px;border-radius:999px;box-shadow:var(--shadow-sm);margin-bottom:18px;
}
.star{width:16px;height:16px;fill:var(--yellow);stroke:var(--navy);stroke-width:.6}

/* ---------------- Barra de anuncio ---------------- */
.announce{background:var(--yellow);color:var(--navy);text-align:center;
  font-weight:700;font-size:.88rem;padding:10px 16px;line-height:1.3}

/* ---------------- HERO (visible sin scroll) ---------------- */
.screen--intro.is-active{display:block}
.hero{
  display:grid;grid-template-columns:1.25fr .9fr;gap:40px;align-items:center;
  padding:32px 0 20px;
}
.hero__content .lead{font-size:1.06rem;line-height:1.6;color:var(--text);max-width:50ch;margin:14px 0 20px}
.micro{font-size:.82rem;color:var(--muted);margin-top:14px}
.chk{flex:none;width:24px;height:24px;border-radius:50%;background:var(--blue-soft);
  color:var(--navy);font-weight:900;display:grid;place-items:center;font-size:.8rem;margin-top:1px}
.hero__aside{display:grid;gap:18px}

/* Imagen del hero limpia (sin tapar) + testimonio y experiencia DEBAJO */
.hero__media{display:flex;flex-direction:column;gap:16px;justify-self:stretch}
.hero__img{position:relative;border-radius:28px;overflow:hidden;box-shadow:var(--shadow);
  aspect-ratio:4/5;max-height:460px}
.hero__img img{width:100%;height:100%;object-fit:cover;display:block}
.hero__img::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, rgba(23,59,100,.10) 0%, rgba(23,59,100,0) 45%, rgba(23,59,100,.20) 100%);
  mix-blend-mode:multiply}
.hero__caption{display:flex;flex-direction:column;gap:8px;padding:0 4px}
.hero__stars{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.hero__stars .s{color:var(--yellow);letter-spacing:2px;font-size:.95rem}
.hero__stars em{font-family:var(--display);font-style:normal;color:var(--navy);font-size:1.02rem}
.hero__exp{font-size:.9rem;color:var(--muted)}
.hero__exp strong{font-family:var(--display);color:var(--navy);font-size:1.05rem;margin-right:4px}

/* ---------------- Secciones de contenido ---------------- */
.content-sec{padding:clamp(32px,5vw,56px) 0;text-align:center}
.hero + .content-sec{padding-top:clamp(12px,2.5vw,24px)}
.content-sec > h2{font-size:clamp(1.6rem,3.6vw,2.4rem);margin-bottom:18px}
.sec-text{max-width:64ch;margin:0 auto 14px;color:var(--text);line-height:1.75;font-size:1.04rem}
.content-sec--tint{background:var(--beige);border-radius:28px;
  padding:clamp(36px,5vw,60px) clamp(20px,4vw,48px);margin:8px 0}

/* Beneficios: tarjetas de color con icono de línea (estilo sitio oficial) */
.benefits{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:28px}
.benefit{flex:1 1 280px;max-width:332px;border-radius:22px;padding:30px 26px;text-align:left;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.benefit__ico{width:44px;height:44px;margin-bottom:20px;color:var(--navy)}
.benefit__ico svg{width:100%;height:100%;display:block}
.benefit h3{font-family:var(--display);font-weight:400;font-size:1.35rem;line-height:1.18;margin:0 0 8px;color:var(--navy)}
.benefit p{margin:0;font-size:.97rem;line-height:1.5;color:var(--navy)}
/* temas de color */
.benefit--blue{background:var(--blue)}
.benefit--yellow{background:var(--yellow)}
.benefit--cream{background:var(--beige)}
.benefit--navy{background:var(--navy)}
.benefit--navy h3{color:#fff}
.benefit--navy p{color:#cdd9ec}
.benefit--navy .benefit__ico{color:var(--yellow)}

/* Requisitos */
.reqs{list-style:none;padding:0;max-width:700px;margin:24px auto 30px;display:grid;gap:12px}
.reqs li{display:flex;gap:12px;align-items:flex-start;text-align:left;
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;
  font-size:1rem;line-height:1.45;color:var(--text)}

/* Proceso */
.process{list-style:none;padding:0;max-width:720px;margin:24px auto 0;display:grid;gap:14px}
.process li{display:flex;gap:16px;align-items:flex-start;text-align:left}
.process__n{flex:none;width:40px;height:40px;border-radius:50%;background:var(--navy);
  color:#fff;font-family:var(--display);font-weight:700;display:grid;place-items:center;font-size:1.05rem}
.process h3{font-family:var(--body);font-size:1.05rem;color:var(--navy);font-weight:800;margin:7px 0 2px}
.process p{margin:0;font-size:.93rem;color:var(--muted);line-height:1.45}

/* FAQ */
.faq-list{max-width:720px;margin:24px auto 0;display:grid;gap:12px;text-align:left}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0 20px}
.faq-item summary{cursor:pointer;font-weight:800;color:var(--navy);padding:18px 0;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:1.02rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.5rem;color:var(--blue);font-weight:400;line-height:1}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin:0 0 18px;color:var(--text);line-height:1.6;font-size:.98rem}

/* CTA final */
.cta-band{background:var(--navy);color:#fff;border-radius:28px;
  padding:clamp(40px,6vw,64px) 24px;margin:8px 0 44px}
.cta-band h2{color:#fff}
.cta-band .sec-text{color:#d7e3f3}
.cta-band .btn--primary{background:var(--yellow);color:var(--navy);margin-top:18px;
  box-shadow:0 10px 24px rgba(0,0,0,.2)}
.cta-band .btn--primary:hover{background:#ffd24d}

@media (max-width:760px){
  .hero{grid-template-columns:1fr;gap:18px;padding:24px 0 8px}
  .hero__media{display:none}
  .benefit{max-width:none}
}

/* ============== Mejoras de UX en mobile ============== */
@media (max-width:760px){
  /* Pasos del formulario: tarjeta anclada arriba (no flotando al centro) */
  #questions .screen.is-active{justify-content:flex-start;padding-top:6px;min-height:calc(100svh - 188px)}
  .q-card{padding:24px 22px}
  /* Nav inferior cómoda para el pulgar + safe-area (notch) */
  .bottom-nav{padding:12px 18px calc(16px + env(safe-area-inset-bottom));gap:10px}
  .bottom-nav #nextBtn{flex:1;justify-content:center;padding:18px 24px}
  .bottom-nav #backBtn{flex:none;padding:18px 10px}
  /* Durante el flujo, oculta el footer legal para no competir con la nav */
  body.in-flow .site-footer{display:none}
  /* Verificación / final: un poco más arriba y con aire para el pulgar */
  .screen--verify.is-active,.screen--final.is-active{justify-content:flex-start;padding-top:8px}
  .verify-submit,.final-actions .btn{padding:18px 24px}
  /* Header un poco más compacto */
  .site-header{padding:14px clamp(16px,5vw,48px)}
}
/* Evita el zoom de iOS al enfocar inputs (fuente >=16px) */
@media (max-width:760px){
  .field input,.field select,.field textarea,.intro-start__row input,.otp-box{font-size:16px}
  .slider-num{font-size:2rem}
}

/* Primera pregunta: recuadro azul destacado (es la acción clave de la landing) */
.intro-start{margin-top:8px;background:var(--navy);border-radius:24px;
  padding:24px 24px 20px;box-shadow:var(--shadow)}
.intro-start__label{display:block;font-family:var(--display);font-size:1.2rem;color:#fff;margin-bottom:12px}
.intro-start__row{display:flex;gap:12px;flex-wrap:wrap}
.intro-start__row input{flex:1;min-width:200px;font-family:var(--body);font-size:1.05rem;color:var(--text);
  padding:16px 18px;border:2px solid transparent;border-radius:var(--radius-sm);background:#fff;outline:none;
  transition:border-color .2s,box-shadow .2s}
.intro-start__row input:focus{border-color:var(--yellow);box-shadow:0 0 0 4px rgba(255,222,112,.45)}
.intro-start__row .btn{flex:none}
.intro-start__cta{width:100%;justify-content:center;margin-top:16px}
.intro-start .err{margin-top:8px;color:#ffb3ab}
.intro-start .micro{margin-top:12px;color:#cdd9ec}
/* Slider de edad compacto dentro del recuadro azul del hero */
.intro-start__slider.slider-field{padding:0;margin-top:2px}
/* Estado "sin tocar": obliga a mover el slider antes de avanzar */
.intro-start__prompt{color:var(--yellow);font-weight:700;font-size:.92rem}
.intro-start__value{display:none}
.intro-start__slider:not(.is-untouched) .intro-start__value{display:inline}
.intro-start__slider:not(.is-untouched) .intro-start__prompt{display:none}
.intro-start__slider.is-untouched .intro-start__prompt{animation:nudge 1.5s ease-in-out infinite}
@keyframes nudge{0%,100%{opacity:.6;transform:translateX(0)}50%{opacity:1;transform:translateX(3px)}}
.intro-start__slider.is-untouched input[type=range]::-webkit-slider-runnable-track{background:rgba(255,255,255,.3)}
.intro-start__slider.is-untouched input[type=range]::-moz-range-progress{background:transparent}
.intro-start__slider.shake{animation:shake .42s}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
#introErr{color:#ffe7a3}
.intro-start__sliderhead{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:12px}
.intro-start__qlabel{font-family:var(--display);font-size:1.12rem;color:#fff;line-height:1.2}
.intro-start__age{color:#cdd9ec;font-size:.9rem;white-space:nowrap}
.intro-start__slider .slider-num{font-family:var(--display);font-size:1.55rem;color:var(--yellow);line-height:1;margin-right:1px}
.intro-start__slider input[type=range]{height:26px}
.intro-start__slider input[type=range]::-webkit-slider-runnable-track{
  background:linear-gradient(to right, var(--yellow) var(--pct,0%), rgba(255,255,255,.28) var(--pct,0%))}
.intro-start__slider input[type=range]::-webkit-slider-thumb{background:var(--yellow);border-color:#fff;
  width:26px;height:26px;margin-top:-10px}
.intro-start__slider input[type=range]::-moz-range-track{background:rgba(255,255,255,.28)}
.intro-start__slider input[type=range]::-moz-range-progress{background:var(--yellow)}
.intro-start__slider input[type=range]::-moz-range-thumb{background:var(--yellow);border-color:#fff;width:26px;height:26px}
@media (max-width:560px){
  .intro-start__row{flex-direction:column}
  .intro-start__row .btn{width:100%;justify-content:center}
}

.intro-aside{display:grid;gap:18px}
.quote-card{background:var(--white);border-radius:var(--radius);padding:22px 24px;box-shadow:var(--shadow);
  border:1px solid var(--line)}
.quote-card .stars{color:var(--yellow);font-size:1.1rem;letter-spacing:2px}
.quote-card p{font-family:var(--display);font-style:italic;font-size:1.18rem;color:var(--navy);margin:10px 0 12px;line-height:1.4}
.quote-by{font-size:.82rem;color:var(--muted)}
.trust-badge{background:var(--navy);color:#fff;border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow)}
.trust-badge strong{display:block;font-family:var(--display);font-size:1.7rem;color:var(--yellow)}
.trust-badge span{font-size:.9rem;color:#d7e3f3;line-height:1.4}

/* ---------------- Tarjeta de pregunta ---------------- */
.q-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(24px,4vw,40px)}
.q-kicker{font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;font-size:.76rem;margin-bottom:10px}
.q-kicker b{color:var(--navy)}
.q-help{color:var(--muted);font-size:.95rem;line-height:1.55;margin:6px 0 22px}

/* inputs */
.field{margin-top:6px}
.field + .field{margin-top:18px}
.field-label{display:block;font-weight:700;color:var(--navy);font-size:.95rem;margin-bottom:8px}
.field-hint{font-size:.8rem;color:var(--muted);margin:7px 0 0}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field-grid .field,.field-grid .field + .field{margin-top:0}
.input-prefix{display:flex;align-items:stretch}
.input-prefix .prefix{display:flex;align-items:center;padding:0 14px;font-weight:700;color:var(--navy);
  background:var(--blue-soft);border:2px solid var(--line);border-right:none;
  border-radius:var(--radius-sm) 0 0 var(--radius-sm)}
.input-prefix input{border-radius:0 var(--radius-sm) var(--radius-sm) 0 !important}
@media (max-width:560px){.field-grid{grid-template-columns:1fr}}

/* Slider de edad */
.slider-field{position:relative;margin-top:10px;padding:54px 6px 8px}
.slider-value{position:absolute;top:6px;transform:translateX(-50%);white-space:nowrap;text-align:center;
  transition:left .05s linear}
.slider-num{font-family:var(--display);font-size:2.2rem;color:var(--navy);line-height:1}
.slider-value em{font-style:normal;color:var(--muted);font-size:1.05rem;margin-left:5px}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:30px;background:transparent;
  cursor:pointer;outline:none}
.slider-field input[type=range]:focus,
.slider-field input[type=range]:focus-visible{outline:none;box-shadow:none;border:none}
input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:999px;
  background:linear-gradient(to right, var(--navy) var(--pct,0%), #dfe4ec var(--pct,0%))}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-12px;
  width:30px;height:30px;border-radius:50%;background:var(--navy);border:5px solid #fff;
  box-shadow:0 2px 8px rgba(23,59,100,.35)}
input[type=range]::-moz-range-track{height:6px;border-radius:999px;background:#dfe4ec}
input[type=range]::-moz-range-progress{height:6px;border-radius:999px;background:var(--navy)}
input[type=range]::-moz-range-thumb{width:30px;height:30px;border-radius:50%;background:var(--navy);
  border:5px solid #fff;box-shadow:0 2px 8px rgba(23,59,100,.35)}
.field input[type=text],.field input[type=tel],.field input[type=email],
.field input[type=number],.field select,.field textarea{
  width:100%;font-family:var(--body);font-size:1.05rem;color:var(--text);
  padding:15px 16px;border:2px solid var(--line);border-radius:var(--radius-sm);
  background:var(--cream);transition:border-color .2s,box-shadow .2s;outline:none}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-soft);background:#fff}
.field .row{display:flex;gap:12px;flex-wrap:wrap}
.field .row > *{flex:1;min-width:140px}

/* opciones tipo tarjeta (radio) */
.options{display:grid;gap:12px;margin-top:6px}
.options.cols-2{grid-template-columns:1fr 1fr}
.opt{position:relative}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.opt label{display:flex;align-items:center;gap:13px;cursor:pointer;
  border:2px solid var(--line);background:var(--cream);border-radius:var(--radius-sm);
  padding:16px 18px;font-size:1.02rem;font-weight:600;color:var(--text);transition:all .18s}
.opt .dot{flex:none;width:22px;height:22px;border-radius:50%;border:2px solid var(--blue);
  background:#fff;display:grid;place-items:center;transition:all .18s}
.opt .dot::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--navy);transform:scale(0);transition:transform .18s}
.opt label:hover{border-color:var(--blue);background:#fff}
.opt input:checked + label{border-color:var(--navy);background:var(--blue-soft);box-shadow:var(--shadow-sm)}
.opt input:checked + label .dot{border-color:var(--navy)}
.opt input:checked + label .dot::after{transform:scale(1)}
.opt input:focus-visible + label{box-shadow:0 0 0 4px var(--blue-soft)}

/* error */
.err{color:#b3261e;font-size:.86rem;font-weight:700;margin-top:10px;min-height:1em}

/* consentimiento */
.consent{display:flex;align-items:flex-start;gap:11px;margin-top:18px;font-size:.9rem;color:var(--muted);line-height:1.5}
.consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--navy);flex:none}
.consent a{color:var(--navy);font-weight:700}

/* ---------------- Botones ---------------- */
/* Botones estilo sitio oficial: pill amarillo, texto azul, MAYÚSCULAS */
.btn{font-family:var(--body);font-weight:700;font-size:.9rem;cursor:pointer;
  text-transform:uppercase;letter-spacing:.03em;
  border:none;border-radius:999px;padding:15px 30px;transition:transform .15s,box-shadow .2s,background .2s;
  display:inline-flex;align-items:center;gap:8px}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--yellow);color:var(--navy);box-shadow:0 8px 22px rgba(23,59,100,.16)}
.btn--primary:hover{background:#ffd24d;box-shadow:0 12px 28px rgba(23,59,100,.22)}
.btn--lg{padding:18px 38px;font-size:.95rem}
.btn--ghost{background:transparent;color:var(--navy);box-shadow:none;padding-left:8px;letter-spacing:.02em}
.btn--ghost:hover{color:var(--navy-700)}
.btn--ghost[hidden]{display:none}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none}

/* ---------------- Nav inferior ---------------- */
.bottom-nav{position:sticky;bottom:0;width:100%;max-width:760px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px clamp(18px,5vw,32px);
  background:linear-gradient(180deg,rgba(251,247,240,0),var(--cream) 38%)}

/* ---------------- Final ---------------- */
.final-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:clamp(28px,5vw,52px);text-align:center}
.final-emoji{font-size:3rem;line-height:1}
.final-card h2{font-size:clamp(1.8rem,4.4vw,2.6rem);margin:14px 0 12px}
.final-card p{font-size:1.05rem;line-height:1.65;color:var(--text);max-width:52ch;margin:0 auto 10px}
.badge-status{display:inline-flex;align-items:center;gap:9px;font-weight:700;
  padding:9px 18px;border-radius:999px;margin:6px 0 18px;font-size:.95rem}
.badge-status.qualify{background:#e7f5ee;color:var(--ok)}
.badge-status.review{background:var(--yellow-soft);color:#8a6d1f}
.final-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.summary{margin:22px auto 0;max-width:440px;text-align:left;background:var(--cream);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 20px}
.summary h3{font-family:var(--body);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);margin:0 0 12px}
.summary dl{display:grid;grid-template-columns:auto 1fr;gap:8px 16px;margin:0;font-size:.93rem}
.summary dt{color:var(--muted)}
.summary dd{margin:0;font-weight:700;color:var(--navy);text-align:right}

/* ---------------- Footer ---------------- */
.site-footer{padding:22px clamp(18px,5vw,48px);text-align:center}
.site-footer p{margin:0;font-size:.78rem;color:var(--muted);line-height:1.5;max-width:640px;margin:0 auto}

/* ---------------- Responsive ---------------- */
@media (max-width:760px){
  .screen--intro.is-active{grid-template-columns:1fr;gap:24px}
  .intro-aside{order:-1;grid-template-columns:1fr;display:none}
  .options.cols-2{grid-template-columns:1fr}
  .brand img{height:38px}
}
