/* ============================================================================
   ScienMIA — Versión A "refinada"
   Sistema de diseño. Mantiene el ADN (azul/púrpura/coral, DM Serif + DM Sans)
   y lo eleva con: escala tipográfica fluida, mono de laboratorio para datos,
   ritmo de 8px, foco visible y un elemento firma (riel de protocolo + hero
   en capas tipo manuscrito). Pensado para encolarse en WordPress (sin inline).
   ============================================================================ */

/* ----- 1. Tokens ----- */
:root{
  /* Marca (derivada del sitio actual, afinada) */
  --blue-900:#0A3766;
  --blue-800:#0C447C;
  --blue-600:#185FA5;
  --blue-100:#E6F1FB;
  --blue-light:#E6F1FB;   /* alias usado por chips/columnas (antes sin definir) */
  --purple-600:#4E45B0;
  --purple-400:#7F77DD;
  --purple-100:#EEEDFE;
  --coral-600:#C84E27;   /* afinado para contraste AA sobre blanco */
  --coral-500:#D85A30;
  --coral-300:#F0997B;
  --coral-50:#FAECE7;

  /* Neutros (papel académico cálido) */
  --ink:#16223A;
  --muted:#586173;
  --muted-on-dark:#AFC6E4;
  --paper:#FBFAF6;
  --surface:#FFFFFF;
  --line:rgba(22,34,58,.10);
  --line-strong:rgba(22,34,58,.16);

  /* Semánticos */
  --bg:var(--paper);
  --fg:var(--ink);
  --primary:var(--blue-800);
  --accent:var(--coral-600);

  /* Tipografía */
  --font-display:'DM Serif Display', Georgia, 'Times New Roman', serif;
  --font-body:'DM Sans', system-ui, -apple-system, sans-serif;
  --font-mono:'IBM Plex Mono', ui-monospace, 'SFMono-Regular', monospace;

  /* Escala fluida (clamp = mobile-first sin saltos bruscos) */
  --step--1:clamp(.78rem, .76rem + .1vw, .85rem);
  --step-0: clamp(1rem, .97rem + .15vw, 1.075rem);
  --step-1: clamp(1.2rem, 1.12rem + .4vw, 1.45rem);
  --step-2: clamp(1.5rem, 1.32rem + .9vw, 2.05rem);
  --step-3: clamp(1.95rem, 1.6rem + 1.7vw, 3rem);
  --step-4: clamp(2.5rem, 1.9rem + 3vw, 4.4rem);

  /* Ritmo 8px */
  --s-1:.5rem; --s-2:1rem; --s-3:1.5rem; --s-4:2rem;
  --s-5:3rem; --s-6:4rem; --s-7:6rem; --s-8:8rem;

  --radius:16px;
  --radius-sm:10px;
  --container:1140px;

  /* Movimiento (Emil) */
  --ease-out:cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out:cubic-bezier(0.77, 0, 0.175, 1);
}

/* ----- 2. Reset / base ----- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:var(--step-0);
  line-height:1.65;
  color:var(--fg);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}
h1,h2,h3,h4{line-height:1.1;font-weight:400}
:focus-visible{outline:3px solid var(--purple-400);outline-offset:3px;border-radius:4px}
::selection{background:var(--coral-300);color:#fff}
/* El header sticky no debe tapar el inicio de la sección al saltar por ancla */
[id]{scroll-margin-top:84px}
/* Táctil: sin delay de 300ms ni flash gris al tocar */
a,button,summary,.btn{touch-action:manipulation;-webkit-tap-highlight-color:transparent}

/* Salto de accesibilidad */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:1000;
  background:var(--ink);color:#fff;padding:12px 18px;border-radius:0 0 8px 0;
  font-weight:600;
}
.skip-link:focus{left:0}

/* ----- 3. Utilidades de layout ----- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,30px)}
.section{padding-block:clamp(var(--s-6),9vw,var(--s-8))}
.eyebrow{
  font-family:var(--font-mono);
  font-size:var(--step--1);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.section-head{max-width:46rem;margin-inline:auto;text-align:center;margin-bottom:var(--s-5)}
.section-title{
  font-family:var(--font-display);
  font-size:var(--step-3);
  color:var(--primary);
  margin-top:var(--s-2);
  letter-spacing:-.01em;
  text-wrap:balance;
}
.section-desc{color:var(--muted);font-size:var(--step-1);margin-top:var(--s-2);text-wrap:balance}
.tnum{font-variant-numeric:tabular-nums}

/* ----- 4. Botones ----- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-body);font-weight:600;font-size:var(--step-0);
  padding:1rem 2rem;border-radius:var(--radius-sm);
  text-decoration:none;border:1px solid transparent;cursor:pointer;
  transition:transform 160ms var(--ease-out), background-color 200ms ease,
             box-shadow 200ms ease, color 200ms ease;
  min-height:48px;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--coral-500);box-shadow:0 10px 30px -8px rgba(200,78,39,.5)}
.btn-primary:active{transform:scale(.97)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6)}
.btn-ghost:active{transform:scale(.97)}
.btn-block{width:100%;justify-content:center}
.btn .arrow{transition:transform 200ms var(--ease-out)}
.btn:hover .arrow{transform:translateX(4px)}

/* ----- 5. Riel de protocolo (ELEMENTO FIRMA) ----- */
/* Barra de progreso fina, fija a la izquierda, con marcas M·I·A.            */
.rail{
  position:fixed;left:max(14px,2.2vw);top:50%;transform:translateY(-50%);
  z-index:40;display:flex;flex-direction:column;align-items:center;gap:14px;
  pointer-events:none;
}
.rail__track{
  position:relative;width:2px;height:200px;background:var(--line-strong);
  border-radius:2px;overflow:hidden;
}
.rail__fill{
  position:absolute;inset:0;width:100%;
  transform:scaleY(0);transform-origin:top;   /* solo transform -> GPU */
  background:linear-gradient(180deg,var(--blue-600),var(--purple-600),var(--coral-500));
}
.rail__label{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;
  color:var(--muted);writing-mode:vertical-rl;
}
@media (max-width:1100px){ .rail{display:none} }

/* ----- 6. Header ----- */
.site-header{
  position:sticky;top:0;z-index:30;
  background:color-mix(in srgb, var(--blue-900) 92%, transparent);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.wordmark{display:flex;align-items:baseline;gap:.05em;font-family:var(--font-display);
  font-size:1.35rem;color:#fff;text-decoration:none;letter-spacing:-.01em}
.wordmark b{color:var(--coral-300);font-weight:400}
.nav__links{display:flex;gap:var(--s-3);list-style:none}
.nav__links a{color:#D6E4F5;text-decoration:none;font-size:var(--step--1);font-weight:500;
  letter-spacing:.01em;transition:color .2s}
.nav__links a:hover{color:#fff}
.nav__cta{font-size:var(--step--1);padding:.6rem 1.1rem;white-space:nowrap}
/* Acciones del header: enlace secundario "academia" + CTA de venta */
.nav__actions{display:flex;align-items:center;gap:var(--s-2)}
.nav__academia{display:inline-flex;align-items:center;gap:.45em;white-space:nowrap;
  font-family:var(--font-body);font-weight:600;color:#D6E4F5;text-decoration:none;
  border:1px solid rgba(255,255,255,.30);background:transparent;
  transition:color .2s, border-color .2s, background-color .2s, transform 160ms var(--ease-out)}
.nav__academia-short{display:none}
.nav__academia:hover{color:#fff;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.07)}
.nav__academia:active{transform:scale(.97)}
.nav__academia svg{width:14px;height:14px;flex:none;opacity:.9}
@media (max-width:760px){ .nav__links{display:none} }
/* Móvil: para no saturar, "Ingresa a la academia" pasa a enlace de texto */
@media (max-width:560px){
  .nav__actions{gap:var(--s-1)}
  .nav__academia{border-color:transparent;background:transparent;padding-inline:.25rem}
  .nav__academia svg{display:none}
  .nav__academia-full{display:none}   /* etiqueta corta para no saturar */
  .nav__academia-short{display:inline}
}

/* ----- 7. Hero (capas tipo manuscrito + parallax) ----- */
.hero{
  position:relative;overflow:hidden;background:var(--blue-900);color:#fff;
  padding-block:clamp(var(--s-6),12vw,9rem);
  isolation:isolate;
}
.hero__mesh{position:absolute;inset:0;z-index:-2;pointer-events:none}
.hero__blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.55}
.hero__blob--a{width:520px;height:520px;top:-160px;right:-120px;
  background:radial-gradient(circle,rgba(127,119,221,.5),transparent 68%)}
.hero__blob--b{width:420px;height:420px;bottom:-180px;left:-100px;
  background:radial-gradient(circle,rgba(24,95,165,.55),transparent 70%)}
/* "hojas" del manuscrito a distinta profundidad */
.hero__sheet{position:absolute;z-index:-1;border-radius:12px;
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.10);box-shadow:0 30px 60px -30px rgba(0,0,0,.5)}
.hero__sheet--1{width:200px;height:264px;top:12%;right:8%;transform:rotate(7deg)}
.hero__sheet--2{width:150px;height:198px;bottom:10%;right:22%;transform:rotate(-6deg)}
.hero__sheet--3{width:120px;height:160px;top:18%;left:6%;transform:rotate(-9deg)}
@media (max-width:880px){ .hero__sheet{display:none} }

.hero__rule{height:5px;width:120px;border-radius:5px;margin-bottom:var(--s-3);
  background:linear-gradient(90deg,var(--purple-600),var(--purple-400),var(--coral-500))}
.hero .container{position:relative;z-index:2;max-width:54rem}
.hero__badge{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.18em;
  text-transform:uppercase;color:var(--coral-300);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  padding:.5rem 1rem;border-radius:30px;margin-bottom:var(--s-3);
}
.hero h1{font-family:var(--font-display);font-size:var(--step-4);letter-spacing:-.02em;
  margin-bottom:var(--s-3);text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--coral-300);position:relative;white-space:nowrap}
.hero__sub{font-size:var(--step-1);color:#C9DEF6;max-width:40rem;margin-bottom:var(--s-4)}
.hero__sub strong{color:#fff;font-weight:600}
.hero__actions{display:flex;gap:var(--s-2);flex-wrap:wrap;align-items:center}
.hero__checks{display:flex;gap:var(--s-3);flex-wrap:wrap;margin-top:var(--s-4);
  color:#9CC0E8;font-size:var(--step--1)}
.hero__checks span{display:inline-flex;align-items:center;gap:.5em}
.hero__checks svg{width:16px;height:16px;flex:none;color:var(--coral-300)}

/* ----- 8. Trust bar ----- */
.trust{background:var(--purple-100);padding-block:var(--s-3)}
.trust__inner{display:flex;align-items:center;justify-content:center;gap:clamp(16px,4vw,40px);
  flex-wrap:wrap;text-align:center}
.trust__label{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.14em;
  text-transform:uppercase;color:var(--purple-600);font-weight:500}
.trust__logos{display:flex;gap:clamp(16px,3vw,32px);flex-wrap:wrap;justify-content:center}
.trust__logos span{font-weight:700;color:var(--purple-600);font-size:var(--step-0);opacity:.78}

/* ----- 9. Problema (stats) ----- */
.problema{background:var(--surface)}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
.stat{position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--s-4) var(--s-3);text-align:center;overflow:hidden}
.stat::before{content:"";position:absolute;inset:0 0 auto 0;height:5px}
.stat:nth-child(1)::before{background:var(--coral-500)}
.stat:nth-child(2)::before{background:var(--purple-600)}
.stat:nth-child(3)::before{background:var(--blue-800)}
.stat__num{font-family:var(--font-display);font-size:var(--step-4);line-height:1;letter-spacing:-.02em}
.stat:nth-child(1) .stat__num{color:var(--coral-600)}
.stat:nth-child(2) .stat__num{color:var(--purple-600)}
.stat:nth-child(3) .stat__num{color:var(--blue-800)}
.stat__desc{color:var(--muted);font-size:var(--step-0);margin-top:var(--s-1)}

/* ----- 10. Método M.I.A. (triptico firma) ----- */
.metodo{background:var(--paper)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3);position:relative}
/* línea base que conecta los 3 pilares */
.pillars::before{content:"";position:absolute;top:36px;left:16%;right:16%;height:1px;
  background:var(--line-strong);z-index:0}
@media (max-width:760px){ .pillars::before{display:none} }
.pillar{position:relative;z-index:1;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--s-4) var(--s-3);text-align:center;
  transition:transform 220ms var(--ease-out), box-shadow 220ms ease, border-color 220ms ease}
@media (hover:hover) and (pointer:fine){
  .pillar:hover{transform:translateY(-4px);box-shadow:0 20px 40px -24px rgba(22,34,58,.4);
    border-color:var(--line-strong)}
}
.pillar__letter{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;
  margin:0 auto var(--s-2);font-family:var(--font-display);font-size:2rem;color:#fff}
.pillar:nth-child(1) .pillar__letter{background:var(--blue-800)}
.pillar:nth-child(2) .pillar__letter{background:var(--purple-600)}
.pillar:nth-child(3) .pillar__letter{background:var(--coral-500)}
.pillar__kicker{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted)}
.pillar__title{font-family:var(--font-display);font-size:var(--step-2);margin-block:.2em .3em}
.pillar:nth-child(1) .pillar__title{color:var(--blue-800)}
.pillar:nth-child(2) .pillar__title{color:var(--purple-600)}
.pillar:nth-child(3) .pillar__title{color:var(--coral-600)}
.pillar__text{color:var(--muted);font-size:var(--step-0)}

/* ----- 11. Programas ----- */
.programas{background:var(--blue-900);color:#fff}
.programas .section-title{color:#fff}
.programas .section-desc{color:var(--muted-on-dark)}
.progs{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-3)}
.prog{background:var(--surface);color:var(--ink);border-radius:var(--radius);
  padding:var(--s-4);display:flex;flex-direction:column}
.prog__tag{align-self:flex-start;font-family:var(--font-mono);font-size:var(--step--1);
  letter-spacing:.12em;text-transform:uppercase;color:#fff;padding:.35rem .8rem;
  border-radius:30px;margin-bottom:var(--s-2)}
.prog:nth-child(1) .prog__tag{background:var(--purple-600)}
.prog:nth-child(2) .prog__tag{background:var(--coral-500)}
.prog h3{font-family:var(--font-display);font-size:var(--step-2);color:var(--blue-800)}
.prog__sub{font-weight:600;font-size:var(--step--1);margin-block:.3em .8em}
.prog:nth-child(1) .prog__sub{color:var(--purple-600)}
.prog:nth-child(2) .prog__sub{color:var(--coral-600)}
.prog__desc{color:var(--muted);margin-bottom:var(--s-3)}
.prog__list{list-style:none;margin-bottom:var(--s-4)}
.prog__list li{display:flex;gap:.7em;align-items:flex-start;padding-block:.55rem;
  border-bottom:1px solid var(--line);font-size:var(--step-0)}
.prog__list li:last-child{border-bottom:none}
.prog__list svg{width:20px;height:20px;flex:none;margin-top:.15em}
.prog:nth-child(1) .prog__list svg{color:var(--purple-600)}
.prog:nth-child(2) .prog__list svg{color:var(--coral-600)}
.prog .btn{margin-top:auto}

/* ----- 12. Timeline ----- */
.timeline{background:var(--surface)}
.tl{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
.tl__card{position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--s-4) var(--s-3);overflow:hidden}
.tl__card::before{content:"";position:absolute;inset:0 auto 0 0;width:5px}
.tl__card:nth-child(1)::before{background:var(--blue-800)}
.tl__card:nth-child(2)::before{background:var(--purple-600)}
.tl__card:nth-child(3)::before{background:var(--coral-500)}
.tl__week{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.1em;
  text-transform:uppercase}
.tl__card:nth-child(1) .tl__week{color:var(--blue-800)}
.tl__card:nth-child(2) .tl__week{color:var(--purple-600)}
.tl__card:nth-child(3) .tl__week{color:var(--coral-600)}
.tl__card h3{font-family:var(--font-display);font-size:var(--step-1);margin-block:.4em .6em;color:var(--ink)}
.tl__card p{color:var(--muted);font-size:var(--step-0);margin-bottom:.5em}
.tl__card p strong{color:var(--ink);font-weight:600}

/* ----- 13. Para quién ----- */
.paraquien{background:var(--paper)}
.pq{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-2) var(--s-5)}
.pq__item{display:flex;gap:.9em;align-items:flex-start;padding-block:var(--s-2);
  border-bottom:1px solid var(--line)}
.pq__item svg{width:26px;height:26px;flex:none;color:var(--blue-600);margin-top:.1em}
.pq__item p{font-size:var(--step-0)}
.pq__item strong{color:var(--blue-800);font-weight:600}
@media (max-width:680px){ .pq{grid-template-columns:1fr;gap:0} }

/* ----- 14. Testimonios ----- */
.testimonios{background:var(--purple-100)}
.tests{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
.test{background:var(--surface);border-radius:var(--radius);padding:var(--s-4) var(--s-3);
  border:1px solid var(--line);display:flex;flex-direction:column}
.test__mark{font-family:var(--font-display);font-size:3rem;line-height:.5;color:var(--purple-400);
  margin-bottom:.3em}
.test__text{font-size:var(--step-0);color:var(--ink);margin-bottom:var(--s-3)}
.test__who{display:flex;align-items:center;gap:.8em;margin-top:auto}
.test__avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  color:#fff;font-weight:700;font-size:var(--step--1)}
.test:nth-child(1) .test__avatar{background:var(--blue-800)}
.test:nth-child(2) .test__avatar{background:var(--purple-600)}
.test:nth-child(3) .test__avatar{background:var(--coral-500)}
.test__name{font-weight:600;font-size:var(--step-0)}
.test__role{font-size:var(--step--1);color:var(--muted)}

/* ----- 15. FAQ (details/summary nativo y accesible) ----- */
.faq{background:var(--surface)}
.faq__list{max-width:48rem;margin-inline:auto}
.faq__item{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  margin-bottom:var(--s-1);overflow:hidden}
.faq__item summary{list-style:none;cursor:pointer;padding:1.15rem 1.4rem;
  display:flex;justify-content:space-between;align-items:center;gap:1em;
  font-weight:600;color:var(--blue-800);font-size:var(--step-0)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .ico{flex:none;width:22px;height:22px;color:var(--coral-600);
  transition:transform 220ms var(--ease-out)}
.faq__item[open] summary .ico{transform:rotate(45deg)}
.faq__a{padding:0 1.4rem 1.2rem;color:var(--muted);font-size:var(--step-0)}

/* ----- 16. CTA final ----- */
.cta{background:var(--blue-900);color:#fff;text-align:center;position:relative;overflow:hidden;
  isolation:isolate}
.cta__glow{position:absolute;z-index:-1;bottom:-40%;left:50%;transform:translateX(-50%);
  width:680px;height:420px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(78,69,176,.4),transparent 68%)}
.cta h2{font-family:var(--font-display);font-size:var(--step-3);max-width:42rem;
  margin-inline:auto;margin-bottom:var(--s-2)}
.cta h2 em{font-style:normal;color:var(--coral-300)}
.cta__desc{color:var(--muted-on-dark);font-size:var(--step-1);margin-bottom:var(--s-4)}
.cta__note{color:#9CC0E8;font-size:var(--step--1);margin-top:var(--s-3)}
.cta__note a{color:#fff}

/* ----- 17. Footer ----- */
.footer{background:var(--ink);color:#fff;padding-block:var(--s-5) var(--s-4)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:var(--s-4);margin-bottom:var(--s-4)}
.footer__brand h3{font-family:var(--font-display);font-size:1.4rem}
.footer__brand p{color:#A9B4C6;font-size:var(--step--1);margin-top:.6em;max-width:24rem}
.footer h4{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.14em;
  text-transform:uppercase;color:var(--coral-300);margin-bottom:var(--s-2)}
.footer ul{list-style:none;display:grid;gap:.6em}
.footer a{color:#A9B4C6;text-decoration:none;font-size:var(--step--1);transition:color .2s}
.footer a:hover{color:#fff}
.footer__bar{border-top:1px solid rgba(255,255,255,.12);padding-top:var(--s-3);
  text-align:center;color:#8593A8;font-size:var(--step--1)}
@media (max-width:680px){ .footer__grid{grid-template-columns:1fr;gap:var(--s-3)} }

/* ============================================================================
   18. Programa Método M.I.A. · 10 semanas — secciones nuevas (misma identidad)
   ============================================================================ */

/* --- Hero: motivo de fondo sutil + capa extra (parallax reforzado) --- */
.hero__motif{position:absolute;inset:-12% -6%;z-index:-2;pointer-events:none;opacity:.6;
  background-image:radial-gradient(rgba(255,255,255,.11) 1.5px,transparent 1.6px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 72% 62% at 58% 28%,#000,transparent 76%);
          mask-image:radial-gradient(ellipse 72% 62% at 58% 28%,#000,transparent 76%)}
.hero__sheet--4{width:168px;height:222px;bottom:16%;right:4%;transform:rotate(11deg)}
.hero__support{margin-top:var(--s-3);font-family:var(--font-mono);font-size:var(--step--1);
  letter-spacing:.04em;color:#9CC0E8}
.hero__support b{color:var(--coral-300);font-weight:500}

/* --- Problema (dolor) --- */
.problema-mia{background:var(--surface)}
.pain-lead{font-family:var(--font-display);font-size:var(--step-2);color:var(--blue-800);
  max-width:22ch;margin-bottom:var(--s-4);line-height:1.15;text-wrap:balance}
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3)}
.pain{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--coral-500);
  border-radius:var(--radius-sm);padding:var(--s-3)}
.pain p{color:var(--muted)}
.pain__punch{margin-top:var(--s-4);font-family:var(--font-display);font-size:var(--step-1);
  color:var(--ink)}
.pain__punch b{color:var(--coral-600)}
@media (max-width:760px){ .pain-grid{grid-template-columns:1fr} }

/* --- Transformación (antes → después) --- */
.transform{background:var(--paper)}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3);align-items:stretch}
.ba__col{border-radius:var(--radius);padding:var(--s-4) var(--s-3)}
.ba__col--before{background:var(--surface);border:1px solid var(--line)}
.ba__col--after{background:var(--blue-900);color:#fff}
.ba__h{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.16em;
  text-transform:uppercase;margin-bottom:var(--s-2)}
.ba__col--before .ba__h{color:var(--muted)}
.ba__col--after .ba__h{color:var(--coral-300)}
.ba__list{list-style:none;display:grid;gap:.7em}
.ba__list li{display:flex;gap:.6em;align-items:flex-start;font-size:var(--step-0)}
.ba__col--before li{color:var(--muted)}
.ba__list svg{width:18px;height:18px;flex:none;margin-top:.2em}
.ba__col--before .ba__list svg{color:var(--muted)}
.ba__col--after .ba__list svg{color:var(--coral-300)}
.transform__note{text-align:center;margin-top:var(--s-4);font-family:var(--font-display);
  font-size:var(--step-1);color:var(--blue-800)}
@media (max-width:680px){ .ba{grid-template-columns:1fr} }

/* --- Método M.I.A. — nota copiloto --- */
.metodo .copilot{text-align:center;margin-top:var(--s-4);font-family:var(--font-display);
  font-size:var(--step-1);color:var(--purple-600)}

/* --- RECORRIDO 10 semanas / 3 módulos (ELEMENTO FIRMA) --- */
.journey{background:var(--paper)}
.journey__modules{display:grid;gap:var(--s-5);margin-top:var(--s-5)}
.module{--mc:var(--blue-800)}
.module--2{--mc:var(--purple-600)}
.module--3{--mc:var(--coral-600)}
.module__head{border-bottom:2px solid var(--mc);padding-bottom:var(--s-2);margin-bottom:var(--s-2)}
.module__tag{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.16em;
  text-transform:uppercase;color:var(--mc)}
.module__name{font-family:var(--font-display);font-size:var(--step-2);color:var(--ink);
  margin-top:.15em}
.module__note{color:var(--muted);font-size:var(--step-0);margin-top:.25em}
.weeks{position:relative}
.weeks::before{content:"";position:absolute;left:19px;top:16px;bottom:16px;width:2px;
  background:var(--line-strong)}
.week{display:grid;grid-template-columns:40px 1fr;gap:var(--s-3);padding-block:var(--s-3);
  align-items:start;position:relative}
.week__dot{position:relative;z-index:1;justify-self:center;width:14px;height:14px;border-radius:50%;
  background:var(--paper);border:2px solid var(--mc);margin-top:5px}
.week--live .week__dot{background:var(--mc);
  box-shadow:0 0 0 5px color-mix(in srgb, var(--mc) 20%, transparent)}
.week__meta{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:.5em}
.week__meta .online{color:var(--mc)}
.week__live{color:#fff;background:var(--mc);padding:.2em .7em;border-radius:20px;
  letter-spacing:.08em;font-weight:500;display:inline-flex;align-items:center;gap:.4em}
.week__live::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff}
.week__title{font-family:var(--font-display);font-size:var(--step-1);color:var(--ink);
  margin-block:.15em .25em}
.week__deliv{color:var(--muted);font-size:var(--step-0)}
.week__deliv b{color:var(--mc);font-weight:600}
.week__tools{margin-top:.35em;font-family:var(--font-mono);font-size:var(--step--1);color:var(--muted)}
@media (max-width:560px){
  .week{grid-template-columns:28px 1fr;gap:var(--s-2)}
  .weeks::before{left:13px}
}

/* --- Herramientas de IA (nota) --- */
.trust__note{flex-basis:100%;text-align:center;color:var(--purple-600);opacity:.85;
  font-size:var(--step--1);margin-top:.4em}

/* --- Qué incluye la inscripción --- */
.includes{background:var(--surface)}
.includes__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s-2) var(--s-4);
  max-width:52rem;margin-inline:auto;margin-top:var(--s-4)}
.includes__item{display:flex;gap:.7em;align-items:flex-start;padding-block:var(--s-1);
  border-bottom:1px solid var(--line)}
.includes__item svg{width:22px;height:22px;flex:none;color:var(--blue-600);margin-top:.15em}
.includes__item b{color:var(--blue-800);font-weight:600}
@media (max-width:680px){ .includes__grid{grid-template-columns:1fr} }

/* --- Dra. TesIA --- */
.tesia{background:var(--purple-100)}
.tesia__card{display:grid;grid-template-columns:auto 1fr;gap:var(--s-4);align-items:center;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:var(--s-4);max-width:60rem;margin-inline:auto}
.tesia__badge{width:96px;height:96px;border-radius:50%;background:var(--purple-600);color:#fff;
  display:grid;place-items:center;text-align:center;font-family:var(--font-mono);font-size:12px;
  letter-spacing:.1em;line-height:1.3;flex:none}
.tesia__badge b{font-family:var(--font-display);font-size:22px;display:block}
.tesia__body h3{font-family:var(--font-display);font-size:var(--step-2);color:var(--purple-600)}
.tesia__body p{color:var(--muted);margin-top:.4em}
.tesia__body .q{color:var(--ink);font-style:italic;margin-top:.6em}
@media (max-width:560px){ .tesia__card{grid-template-columns:1fr;text-align:center;justify-items:center} }

/* --- Para quién es / NO es --- */
.fit{background:var(--paper)}
.fit__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-3)}
.fit__col{border-radius:var(--radius);padding:var(--s-4);border:1px solid var(--line)}
.fit__col--yes{background:var(--blue-light)}
.fit__col--no{background:var(--surface)}
.fit__h{font-family:var(--font-display);font-size:var(--step-1);margin-bottom:var(--s-3)}
.fit__col--yes .fit__h{color:var(--blue-800)}
.fit__col--no .fit__h{color:var(--coral-600)}
.fit__list{list-style:none;display:grid;gap:.7em}
.fit__list li{display:flex;gap:.6em;align-items:flex-start;font-size:var(--step-0);color:var(--ink)}
.fit__list svg{width:20px;height:20px;flex:none;margin-top:.15em}
.fit__col--yes svg{color:var(--blue-600)}
.fit__col--no svg{color:var(--coral-600)}
@media (max-width:680px){ .fit__grid{grid-template-columns:1fr} }

/* --- Mentora Dra. Zavala --- */
.mentor{background:var(--surface)}
.mentor__card{display:grid;grid-template-columns:280px 1fr;gap:var(--s-5);align-items:start;
  max-width:64rem;margin-inline:auto}
.mentor__figure{margin:0;position:relative}
.mentor__figure img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;object-position:50% 28%;
  border-radius:var(--radius);display:block;background:var(--blue-light);
  box-shadow:0 20px 44px -26px rgba(22,34,58,.55)}
/* regla tricolor firma bajo el retrato */
.mentor__figure::after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:5px;
  border-radius:5px;background:linear-gradient(90deg,var(--blue-800),var(--purple-600),var(--coral-500))}
.mentor__body h3{font-family:var(--font-display);font-size:var(--step-2);color:var(--blue-800)}
.mentor__role{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.1em;
  text-transform:uppercase;color:var(--coral-600);margin-block:.3em .8em}
.mentor__body p{color:var(--muted)}
.mentor__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-2);margin-block:var(--s-3)}
.mentor__stat{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:var(--s-2) var(--s-2) calc(var(--s-2) - 2px)}
.mentor__stat b{font-family:var(--font-display);font-size:var(--step-2);line-height:1;display:block;
  font-variant-numeric:tabular-nums}
.mentor__stat:nth-child(1) b{color:var(--blue-800)}
.mentor__stat:nth-child(2) b{color:var(--purple-600)}
.mentor__stat:nth-child(3) b{color:var(--coral-600)}
.mentor__stat span{font-size:var(--step--1);color:var(--muted);display:block;margin-top:.2em}
.mentor__body p.mentor__harvard{display:flex;align-items:center;gap:.6em;background:var(--blue-light);
  border-radius:var(--radius-sm);padding:.7rem 1rem;margin-bottom:var(--s-3);
  font-size:var(--step-0);color:var(--blue-800)}   /* especificidad > .mentor__body p */
.mentor__harvard svg{width:20px;height:20px;flex:none;color:var(--blue-800)}
.mentor__mission{border-left:3px solid var(--coral-500);padding-left:var(--s-2);
  color:var(--ink)!important;font-style:italic}
@media (max-width:560px){
  .mentor__card{grid-template-columns:1fr;text-align:left}
  .mentor__figure{max-width:240px}
}

/* --- Logística --- */
.logistics{background:var(--paper)}
.logistics__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3);margin-top:var(--s-4)}
.logistics__item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:var(--s-3)}
.logistics__k{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.1em;
  text-transform:uppercase;color:var(--blue-600)}
.logistics__v{color:var(--ink);margin-top:.3em}
@media (max-width:760px){ .logistics__grid{grid-template-columns:1fr} }

/* --- Precio piloto --- */
.pricing{background:var(--blue-900);color:#fff;text-align:center;position:relative;overflow:hidden;
  isolation:isolate}
.pricing__glow{position:absolute;z-index:-1;top:-30%;left:50%;transform:translateX(-50%);
  width:640px;height:420px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(216,90,48,.28),transparent 68%)}
.pricing__card{max-width:38rem;margin-inline:auto;background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--radius);padding:var(--s-5) var(--s-4)}
.pricing__flag{font-family:var(--font-mono);font-size:var(--step--1);letter-spacing:.14em;
  text-transform:uppercase;color:var(--coral-300)}
.pricing__regular{color:#9CC0E8;text-decoration:line-through;font-size:var(--step-1);margin-top:var(--s-2)}
.pricing__now{font-family:var(--font-display);font-size:var(--step-4);line-height:1;margin-top:.1em}
.pricing__now span{color:var(--coral-300)}
.pricing__cupo{color:var(--muted-on-dark);margin-top:var(--s-2)}
.pricing .btn{margin-top:var(--s-4)}
.pricing__pay{font-family:var(--font-mono);font-size:var(--step--1);color:#9CC0E8;margin-top:var(--s-3)}

/* ============================================================================
   19. Movimiento: reveals + parallax + prefers-reduced-motion  (faltaba en A)
   ============================================================================ */
[data-reveal]{opacity:0;transform:translateY(18px);
  transition:opacity .6s var(--ease-out), transform .6s var(--ease-out);will-change:opacity,transform}
[data-reveal].is-visible{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.06s}
[data-reveal-delay="2"]{transition-delay:.12s}
[data-reveal-delay="3"]{transition-delay:.18s}
[data-reveal-delay="4"]{transition-delay:.24s}
[data-parallax]{will-change:transform}

@media (prefers-reduced-motion: reduce){
  [data-reveal]{transform:none;transition:opacity .3s ease}
  [data-parallax]{transform:none !important}
  .rail__fill{transition:none}
}

/* ----- Responsive de rejillas ----- */
@media (max-width:880px){
  .stats,.pillars,.progs,.tl,.tests{grid-template-columns:1fr}
  .hero__checks{flex-direction:column;gap:.6em}
}
