/* ===== NÚCLEO MD — Sistema de diseño v3 (OKLCH unificado) ===== */
@import "tokens.css";
:root{
  /* Remap legacy nombres → tokens OKLCH (sin romper layouts existentes) */
  --navy:      var(--brand);
  --navy-soft: var(--brand-700);
  /* --gold queda como oro cálido de tokens.css — estrellas, detalles */
  --gold-deep: oklch(0.58 0.09 75);
  --bg:        var(--paper);
  --white:     var(--surface);
  --mist:      var(--brand-tint);
  --text:      var(--ink);
  --muted:     var(--muted);
  --line:      var(--line);
  --sage:      var(--brand-soft);
  --radius:    18px;
  --radius-sm: 12px;
  --maxw:      1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* Accesibilidad */
:focus-visible{outline:2px solid var(--gold-deep);outline-offset:2px;border-radius:3px}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
body{
  font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;color:var(--navy);line-height:1.1;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.6em}
h3{font-size:1.25rem;font-family:'Plus Jakarta Sans';font-weight:700}
h1 em{font-style:italic;color:var(--gold-deep)}
p{margin-bottom:1rem}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.narrow{max-width:760px}
.center{text-align:center}
.center-block{margin-left:auto;margin-right:auto;max-width:600px}
.lead{font-size:1.18rem;color:var(--text)}

/* eyebrow */
.eyebrow{display:inline-block;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:600;color:var(--gold-deep);margin-bottom:1rem}
.eyebrow--gold{color:var(--gold)}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:var(--surface);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav__links{display:flex;gap:28px;font-size:.95rem;font-weight:500}
.nav__links a:hover{color:var(--navy)}
.logo{display:inline-flex;align-items:center;gap:.5rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1.15rem;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);line-height:1}
.logo::before{content:"";width:1.9em;height:1.9em;background:url(/assets/img/logo/nucleo-mark.svg) center/contain no-repeat;flex:none}
.logo__md{color:var(--gold-deep)}
.logo--light{color:#fff}
.logo--light::before{background-image:url(/assets/img/logo/nucleo-mark-white.svg)}

/* buttons */
.btn{display:inline-block;padding:14px 28px;border-radius:var(--radius-sm);font-weight:600;font-size:1rem;transition:.2s;cursor:pointer;border:1.5px solid transparent}
.btn--sm{padding:9px 18px;font-size:.9rem}
.btn--primary{background:var(--navy);color:#fff}
.btn--primary:hover{background:var(--navy-soft)}
.btn--gold{background:var(--gold);color:var(--navy)}
.btn--gold:hover{background:var(--gold-deep)}
.btn--ghost{border-color:var(--navy);color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff}
.full{display:block;text-align:center;width:100%}

/* hero */
.hero{padding:72px 0 80px}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin:28px 0 24px}
.trust-row{list-style:none;display:flex;flex-wrap:wrap;gap:18px;font-size:.9rem;color:var(--navy);font-weight:500}

/* sections */
.section{padding:84px 0}
.section--mist{background:var(--mist)}
.section--navy{background:var(--navy);color:#cdd6e2}
.on-dark{color:#fff}
.eyebrow + h2{margin-top:0}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.step{background:var(--white);border:1px solid var(--mist);border-radius:var(--radius);padding:34px 28px;box-shadow:var(--shadow)}
.step__num{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;font-weight:700;font-family:'Fraunces';margin-bottom:18px}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split__copy h2{margin-bottom:.5em}
.check-list{list-style:none;margin:18px 0 26px;display:grid;gap:12px}
.check-list li{padding-left:30px;position:relative}
.check-list li::before{content:"✔";position:absolute;left:0;color:var(--sage);font-weight:700}
.section--navy .check-list li::before{color:var(--gold)}

/* image placeholders */
.img-placeholder{display:flex;align-items:center;justify-content:center;background:repeating-linear-gradient(45deg,var(--line),var(--line) 12px,var(--mist) 12px,var(--mist) 24px);border:2px dashed #d8cbb3;border-radius:var(--radius);color:var(--muted);text-align:center;font-weight:600;letter-spacing:.04em}
.img-placeholder small{font-weight:400;letter-spacing:0;color:var(--muted)}
.img-placeholder--portrait{aspect-ratio:4/5;width:100%}
.img-placeholder--square{aspect-ratio:1/1;width:100%}
.img-placeholder.dark{background:repeating-linear-gradient(45deg,#143153,#143153 12px,#0f2a48 12px,#0f2a48 24px);border-color:#2a4a72;color:#7e93b3}

/* pricing */
.pricing{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;max-width:820px;margin:48px auto 0}
.plan{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:36px 32px;position:relative}
.plan--featured{border:2px solid var(--gold);box-shadow:var(--shadow)}
.plan__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:5px 14px;border-radius:20px}
.plan__price{font-family:'Fraunces';font-size:2.6rem;color:var(--navy);font-weight:600;margin:8px 0 18px}
.plan__price span{font-size:1rem;color:var(--text)}
.plan ul{list-style:none;display:grid;gap:11px;margin-bottom:26px}
.plan li{padding-left:26px;position:relative;font-size:.97rem}
.plan li::before{content:"✔";position:absolute;left:0;color:var(--sage)}
.guarantee{text-align:center;margin-top:32px;font-size:1rem}

/* testimonials */
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
.placeholder-quote{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;color:var(--text);position:relative}
.placeholder-quote cite{display:block;margin-top:16px;font-style:normal;font-weight:700;color:var(--gold-deep);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em}

/* faq */
details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 22px;margin-bottom:12px}
summary{font-weight:600;color:var(--navy);cursor:pointer}
details p{margin:12px 0 0}

/* footer */
.footer{background:#071a2e;color:#94a3b8;padding:56px 0 32px}
.footer__inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;padding-bottom:28px;border-bottom:1px solid #122f4d;margin-bottom:24px}
.footer__tag{color:var(--gold);font-family:'Fraunces';font-style:italic;margin-top:6px}
.footer__links{display:flex;flex-wrap:wrap;gap:20px;font-size:.92rem}
.footer__links a:hover{color:#fff}
.disclaimer{font-size:.82rem;color:#6b7c92;max-width:760px}
.copy{font-size:.82rem;color:#54657c;margin-top:10px}

/* ===== Conversión ===== */
.topbar{background:var(--navy);color:#cdd6e2;font-size:.82rem;text-align:center;padding:9px 16px}
.topbar strong{color:var(--gold);font-weight:600}
.microtrust{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:18px;font-size:.86rem;color:var(--navy);font-weight:500}
.microtrust span{white-space:nowrap}
.microtrust span::before{content:"✓ ";color:var(--sage);font-weight:800}
.hero__media{position:relative}
.media-tag{position:absolute;left:14px;bottom:14px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:30px;padding:7px 14px;font-size:.8rem;font-weight:600;color:var(--navy);box-shadow:var(--shadow)}
.media-tag b{color:var(--gold-deep)}
/* trust strip */
.trust-strip{background:var(--mist);border-top:1px solid var(--mist);border-bottom:1px solid var(--mist)}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:24px 0;text-align:center}
.trust-grid .ic{font-size:1.5rem;display:block;margin-bottom:6px}
.trust-grid h4{font-family:'Plus Jakarta Sans';font-size:.98rem;color:var(--navy);margin-bottom:2px}
.trust-grid p{font-size:.82rem;color:var(--text);margin:0}
/* comparativa */
.compare{width:100%;border-collapse:collapse;margin-top:38px;background:var(--white);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.compare th,.compare td{padding:15px 14px;text-align:center;border-bottom:1px solid var(--line);font-size:.94rem}
.compare th{font-family:'Plus Jakarta Sans';font-weight:700;color:var(--navy)}
.compare td:first-child,.compare th:first-child{text-align:left;color:var(--text);font-weight:500}
.compare .col-us{background:#fbf7ee}
.compare .col-us.head{color:var(--gold-deep)}
.compare .yes{color:var(--sage);font-weight:800}
.compare .no{color:#b06a8e}
/* value stack */
.valuestack{list-style:none;display:grid;gap:11px;margin:16px 0 4px}
.valuestack li{padding-left:30px;position:relative;font-size:1rem}
.valuestack li::before{content:"✓";position:absolute;left:0;color:var(--sage);font-weight:800}
/* sticky CTA móvil */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;align-items:center;justify-content:space-between;gap:12px;background:var(--white);border-top:1px solid var(--line);padding:10px 16px;box-shadow:0 -6px 24px rgba(10,37,64,.14)}
.sticky-cta .price{font-family:'Fraunces';font-weight:600;color:var(--navy);font-size:1.15rem;line-height:1.1}
.sticky-cta .price small{display:block;font-family:'Plus Jakarta Sans';font-weight:400;font-size:.72rem;color:var(--text)}

/* ===== Motion (ease-out, sin bounce) ===== */
.step,.plan,.blog-card,.compare{transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.step:hover,.plan:hover{transform:translateY(-5px);box-shadow:0 26px 56px -22px rgba(60,42,14,.32)}
.btn{transition:transform .28s cubic-bezier(.16,1,.3,1),background .2s ease}
.btn--primary:hover,.btn--gold:hover{transform:translateY(-2px)}
.split__media img{transition:transform .7s cubic-bezier(.16,1,.3,1)}
.split__media:hover img{transform:scale(1.02)}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none}.split__media:hover img{transform:none}}

/* WhatsApp flotante (canal de confianza MX) */
.wa-fab{position:fixed;right:20px;bottom:24px;z-index:70;display:inline-flex;align-items:center;gap:9px;background:#25D366;color:#fff;font-weight:600;font-size:.95rem;padding:12px 18px;border-radius:40px;box-shadow:0 10px 28px rgba(37,211,102,.42);transition:transform .28s cubic-bezier(.16,1,.3,1)}
.wa-fab:hover{transform:translateY(-2px);color:#fff}
.wa-fab svg{width:20px;height:20px;fill:#fff;flex:none}

/* responsive */
@media(max-width:860px){
  .wa-fab{bottom:88px;right:14px;padding:12px}
  .wa-fab .lbl{display:none}
  .hero__inner,.split{grid-template-columns:1fr;gap:36px}
  .steps,.testimonials,.pricing{grid-template-columns:1fr}
  .nav__links{display:none}
  .hero{padding:40px 0 48px}
  .section{padding:56px 0}
  .split__media{order:-1}
  .trust-grid{grid-template-columns:1fr 1fr;gap:22px}
  .compare{font-size:.86rem}
  .compare th,.compare td{padding:11px 7px;font-size:.82rem}
  .mol-grid{grid-template-columns:1fr}
  .tgrid{grid-template-columns:1fr}
  .sticky-cta{display:flex}
  body{padding-bottom:76px}
  .lead-form{flex-direction:column}
  .vstack li{font-size:.94rem;padding:13px 16px}
}

/* ===== Oferta value-stack (Hormozi) ===== */
.offer{max-width:680px;margin:36px auto 0}
.vstack{list-style:none;background:var(--white);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:16px;padding:15px 22px;border-bottom:1px solid var(--line)}
.vstack li:last-child{border-bottom:0}
.vstack .v-name{display:flex;gap:11px;align-items:baseline}
.vstack .v-name::before{content:"✓";color:var(--sage);font-weight:800}
.vstack .v-bonus .v-name::before{content:"★";color:var(--gold-deep)}
.vstack .v-val{color:var(--muted);white-space:nowrap;font-size:.92rem}
.vtotal{display:flex;justify-content:space-between;padding:16px 22px;background:var(--mist);font-weight:700;color:var(--navy)}
.price-hero{text-align:center;margin:26px 0 6px}
.price-hero .now{font-family:'Fraunces';font-size:3.1rem;color:var(--navy);font-weight:600;line-height:1}
.price-hero .was{color:var(--muted);text-decoration:line-through;margin-left:12px;font-size:1.2rem}
.price-hero .unit{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}
.guarantee-box{background:var(--white);border:2px solid var(--sage);border-radius:var(--radius);padding:22px 24px;margin:24px auto 0;max-width:680px;display:flex;gap:16px;align-items:flex-start}
.guarantee-box .gi{font-size:1.8rem;flex:none}
.guarantee-box h4{font-family:'Plus Jakarta Sans';color:var(--navy);margin-bottom:4px}
.guarantee-box p{margin:0;font-size:.95rem}

/* ===== Comparativa de moléculas (por qué reta) ===== */
.mol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.mol{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;text-align:center;position:relative}
.mol--king{border:2px solid var(--gold);box-shadow:var(--shadow)}
.mol__tag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--navy);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:4px 13px;border-radius:20px;white-space:nowrap}
.mol h3{font-family:'Fraunces';margin-bottom:4px}
.mol .mech{font-size:.82rem;color:var(--muted);margin-bottom:16px}
.mol .pct{font-family:'Fraunces';font-size:2.3rem;color:var(--navy);line-height:1}
.mol .pct small{display:block;font-family:'Plus Jakarta Sans';font-size:.76rem;color:var(--muted);font-weight:400;margin-top:6px;line-height:1.4}

/* ===== Banda calculadora ===== */
.calc-band{background:var(--navy);color:#cdd6e2;border-radius:18px;padding:40px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.calc-band h2{color:#fff;margin-bottom:6px}
.calc-band .lead{color:#cdd6e2;max-width:560px;margin:0}
.calc-band .btn{flex:none}
@media(max-width:760px){.calc-band{padding:30px 22px;text-align:center;justify-content:center}.calc-band .btn{width:100%}}

/* ===== Mecanismo (3 vías) ===== */
.mech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.mech-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;text-align:center;box-shadow:var(--shadow)}
.mech-card .ic{font-size:2rem;display:block;margin-bottom:10px}
.mech-card .tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);background:var(--mist);padding:3px 11px;border-radius:20px;margin-bottom:10px}
.mech-card h3{font-family:'Plus Jakarta Sans';font-size:1.08rem;color:var(--navy);margin-bottom:6px}
.mech-card p{font-size:.92rem;margin:0}
.mech-sum{text-align:center;margin-top:30px;font-family:'Fraunces';font-size:clamp(1.15rem,2.4vw,1.45rem);color:var(--navy)}
.mech-sum b{color:var(--gold-deep)}
@media(max-width:760px){.mech-grid{grid-template-columns:1fr}}

/* ===== Diagrama de vías (moléculas) ===== */
.vias{display:flex;gap:8px;justify-content:center;margin:4px 0 8px}
.via{width:12px;height:12px;border-radius:50%;background:transparent;border:1.5px solid var(--line)}
.via.on{background:var(--navy);border-color:var(--navy)}
.mol--king .via.on{background:var(--gold);border-color:var(--gold)}
.vias-label{font-size:.74rem;color:var(--muted);margin-bottom:14px}
@keyframes tagpulse{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.06)}}
.mol--king .mol__tag{animation:tagpulse 2.6s ease-in-out infinite}
/* ===== Iconos de pasos ===== */
.step .ico{font-size:1.6rem;line-height:1;margin:2px 0 8px;display:block}
@media (prefers-reduced-motion: reduce){.mol--king .mol__tag{animation:none}}

/* ===== Testimonios ===== */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.tcard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;gap:14px}
.tcard .stars{color:var(--gold);letter-spacing:3px;font-size:.95rem}
.tcard .quote{font-size:1rem;color:var(--text);margin:0;flex:1;line-height:1.55}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .av{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Plus Jakarta Sans';flex:none}
.tcard .who b{display:block;color:var(--navy);font-size:.92rem;line-height:1.2}
.tcard .who span{font-size:.8rem;color:var(--muted)}

/* ===== Educación (acordeón) ===== */
.edu details{max-width:760px;margin:0 auto 12px}
.edu summary{font-size:1.02rem}

/* ===== Tarjeta de verificación (autenticidad) ===== */
.verify-card{background:var(--white);border-radius:16px;padding:24px;box-shadow:var(--shadow);max-width:390px;margin:0 auto}
.verify-card .vc-head{display:flex;align-items:center;gap:9px;font-weight:600;color:var(--navy);font-size:.95rem;padding-bottom:12px;border-bottom:1px solid var(--line);margin-bottom:10px}
.verify-card .vc-dot{width:9px;height:9px;border-radius:50%;background:var(--sage);box-shadow:0 0 0 4px rgba(94,132,103,.18)}
.verify-card .vc-row{display:flex;justify-content:space-between;font-size:.92rem;padding:7px 0;color:var(--text)}
.verify-card .vc-row strong{color:var(--navy)}
.verify-card .vc-qr{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:14px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.verify-card .vc-note{font-size:.7rem;color:var(--muted);margin-top:10px}

/* ===== Confianza: tarjetas con ícono ===== */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.why{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;text-align:center}
.why .ic{font-size:1.8rem;display:block;margin-bottom:10px}
.why h3{font-family:'Plus Jakarta Sans';font-size:1.05rem;color:var(--navy);margin-bottom:6px}
.why p{font-size:.92rem;color:var(--text);margin:0}
@media(max-width:760px){.why-grid{grid-template-columns:1fr}.verify-card{max-width:none}}

/* ===== Lead magnet ===== */
.lead-capture{background:var(--navy);color:#cdd6e2;border-radius:18px;padding:42px 32px;text-align:center;max-width:760px;margin:0 auto}
.lead-capture h2{color:#fff}
.lead-form{display:flex;gap:10px;max-width:460px;margin:18px auto 0}
.lead-form input{flex:1;min-width:0;padding:13px 16px;border-radius:9px;border:1.5px solid #2a4a72;background:#0f2a48;color:#fff;font:inherit}
.lead-form input::placeholder{color:#8ea3bf}
.lead-ok{margin-top:16px;color:var(--gold);font-weight:600;display:none}
.lead-note{font-size:.8rem;color:#8ea3bf;margin-top:12px}

/* =====================================================================
   NÚCLEO MD v3 — Motion + profundidad (sin gradientes en botones)
   ===================================================================== */

/* Botones sólidos (impeccable: sin linear-gradient en botones CTA) */
.btn{transition:transform .28s cubic-bezier(.16,1,.3,1),box-shadow .28s cubic-bezier(.16,1,.3,1),background .2s}
.btn--primary{background:var(--brand);color:var(--surface);box-shadow:var(--shadow-sm)}
.btn--primary:hover{transform:translateY(-2px);background:var(--brand-700);box-shadow:var(--shadow)}
.btn--gold{background:var(--gold);color:var(--brand);box-shadow:var(--shadow-sm)}
.btn--gold:hover{transform:translateY(-2px);background:oklch(0.70 0.10 80);box-shadow:var(--shadow)}

/* Secciones oscuras con profundidad (glow radial — teal v3) */
.section--navy{background:radial-gradient(900px 440px at 82% -15%, oklch(0.46 0.11 190) 0%, var(--brand) 58%)}
.footer{background:radial-gradient(820px 380px at 80% -45%, oklch(0.30 0.09 190), oklch(0.18 0.05 192) 62%)}
.cta-box,.lead-capture,.calc-band{background:radial-gradient(700px 360px at 85% -30%, oklch(0.42 0.11 190), var(--brand) 65%)}

/* Hero cinematográfico */
.hero{position:relative;overflow:hidden;padding-top:80px}
.hero::before{content:"";position:absolute;top:-220px;right:-160px;width:640px;height:640px;background:radial-gradient(circle,rgba(200,168,98,.22),transparent 62%);pointer-events:none;z-index:0}
.hero::after{content:"";position:absolute;bottom:-280px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(10,37,64,.10),transparent 64%);pointer-events:none;z-index:0}
.hero__inner{position:relative;z-index:1}
.hero h1{font-size:clamp(2.6rem,5.6vw,4.3rem);letter-spacing:-.02em;margin-bottom:.35em}
.hero .lead{font-size:1.22rem}
.hero__media::before{content:"";position:absolute;inset:0;margin:auto;width:78%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(200,168,98,.18),transparent 66%);z-index:0}
.hero__media img,.hero__media .media-tag{position:relative;z-index:1}
.hero__media img{animation:floaty 6.5s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Encabezado de sección con acento dorado bajo el eyebrow */
.eyebrow::after{content:"";display:block;width:34px;height:2px;background:var(--gold);margin-top:10px;opacity:.7}
.center .eyebrow::after,.center-block .eyebrow::after{margin-left:auto;margin-right:auto}
.eyebrow--gold::after{background:var(--gold)}

/* Tarjetas: borde superior dorado sutil al hover (vida) */
.mol,.plan,.tcard,.why,.step{position:relative;overflow:hidden}
.mol::after,.plan::after,.tcard::after,.why::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.mol:hover::after,.plan:hover::after,.tcard:hover::after,.why:hover::after{transform:scaleX(1)}
.mol--king::after,.plan--featured::after{transform:scaleX(1)}

@media (prefers-reduced-motion: reduce){ .hero__media img{animation:none} }
@media(max-width:860px){ .hero{padding-top:32px} .hero__media::before{width:62%} }
