/* ===========================================================
   CÓDIGO DIVINO v2 — Landing premium (auditada)
   Negro cálido · Dorado luminoso · Serif + Sans moderno
   =========================================================== */

:root{
  --bg:        #f8f6f1;
  --bg-2:      #f0ede6;
  --surface:   #ffffff;
  --surface-2: #faf9f6;
  --hairline:  rgba(180,150,70,0.18);
  --hairline-soft: rgba(0,0,0,0.06);

  --gold-1: #fbe6b0;
  --gold-2: #b8860b;
  --gold-3: #9a7012;
  --gold-4: #9a7012;
  --gold-grad: linear-gradient(135deg,#fbe6b0 0%,#e8c66a 38%,#c79a2e 72%,#a3781a 100%);
  --gold-grad-soft: linear-gradient(135deg,#f3dd97,#cfa23a);

  --ink:    #1a1610;
  --ink-2:  #3d3828;
  --ink-3:  #6e6758;
  --ink-4:  #9e9688;

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;

  --shadow-sm: 0 2px 10px rgba(0,0,0,.08);
  --shadow-md: 0 18px 50px -16px rgba(0,0,0,.12);
  --shadow-gold: 0 20px 60px -18px rgba(199,154,46,.25);

  --maxw: 1180px;
  --radius: 22px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  font-weight:400;
  letter-spacing:-0.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:rgba(184,134,11,.2); color:#1a1610; }

body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(900px 600px at 78% -8%, rgba(199,154,46,.07), transparent 60%),
    radial-gradient(700px 520px at 8% 8%, rgba(155,112,18,.04), transparent 55%);
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; position:relative; z-index:1; }

/* ---- Tipografía ---- */
.eyebrow{
  font-family:var(--sans); font-weight:700; font-size:12.5px;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold-2);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--gold-3); opacity:.7; }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:-0.015em; color:var(--ink); }
h1{ font-size:clamp(36px,7.5vw,74px); }
h2{ font-size:clamp(30px,5.2vw,56px); }
h3{ font-size:clamp(21px,2.8vw,27px); }
.serif-em{ font-style:italic; }

.gold-text{
  background:linear-gradient(135deg,#b8860b 0%,#9a7012 50%,#7a5a0a 100%);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.lead{ font-size:clamp(16.5px,2vw,20px); color:var(--ink-2); line-height:1.65; text-wrap:pretty; }
.muted{ color:var(--ink-3); }

section{ position:relative; z-index:1; padding:clamp(64px,10vw,120px) 0; }
.section-head{ max-width:720px; margin:0 auto clamp(36px,6vw,64px); text-align:center; }
.section-head .lead{ margin-top:18px; }
.section-head h2{ margin-top:16px; }

/* ---- Botones (min 48px touch) ---- */
.btn{
  font-family:var(--sans); font-weight:700; font-size:16.5px; letter-spacing:-0.01em;
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:18px 34px; min-height:52px; border-radius:60px; border:none; cursor:pointer;
  position:relative; transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, filter .35s;
  text-align:center; line-height:1.15;
}
.btn-gold{
  background:linear-gradient(135deg,#c79a2e 0%,#a3781a 50%,#8a6510 100%); color:#fff;
  box-shadow:var(--shadow-gold), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-gold:hover{ transform:translateY(-3px); filter:brightness(1.08); box-shadow:0 28px 70px -16px rgba(199,154,46,.35), inset 0 1px 0 rgba(255,255,255,.3); }
.btn-gold:active{ transform:translateY(-1px) scale(.99); }
.btn-ghost{
  background:transparent; color:var(--ink); border:none; backdrop-filter:none;
  padding:16px 30px; position:relative;
}
.btn-ghost::before{
  content:""; position:absolute; left:0; bottom:12px; width:0; height:1.5px;
  background:var(--gold-grad); transition:width .4s cubic-bezier(.2,.8,.2,1);
}
.btn-ghost:hover{ background:transparent; transform:none; }
.btn-ghost:hover::before{ width:100%; }
.btn-lg{ padding:20px 40px; font-size:17.5px; min-height:56px; }
.btn .arrow{ transition:transform .35s; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-block{ width:100%; }

.btn-gold::after{
  content:""; position:absolute; inset:0; border-radius:inherit; overflow:hidden;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  background-size:240% 100%; background-position:140% 0;
  mix-blend-mode:overlay; opacity:.9; pointer-events:none;
}
.btn-gold:hover::after{ animation:sheen 1.1s ease forwards; }
@keyframes sheen{ to{ background-position:-60% 0; } }

/* sub-text under CTA */
.cta-sub{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:6px 16px; margin-top:14px; font-size:13px; color:var(--ink-4); }
.cta-sub svg{ flex:none; }

/* ---- Chips / badges ---- */
.chip{
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:600; letter-spacing:.02em;
  padding:9px 16px; border-radius:60px;
  border:1px solid var(--hairline); background:rgba(184,134,11,.08); color:var(--ink-2);
}
.chip .dot{ width:7px; height:7px; border-radius:50%; background:var(--gold-2); box-shadow:0 0 0 4px rgba(232,198,106,.18); animation:pulse 2.2s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 3px rgba(232,198,106,.22);} 50%{ box-shadow:0 0 0 8px rgba(232,198,106,0);} }

.stars{ color:var(--gold-2); letter-spacing:3px; font-size:15px; }

.glass{
  background:rgba(255,255,255,.7);
  border:1px solid var(--hairline-soft);
  border-radius:var(--radius);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  box-shadow:var(--shadow-md);
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; transition:background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(248,246,241,.92); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--hairline-soft); padding:10px 24px;
}
.brand{ display:flex; align-items:center; gap:10px; font-family:'Playfair Display', var(--serif); font-size:21px; font-weight:800; letter-spacing:-.02em; }
.brand-logo{ width:36px; height:36px; border-radius:7px; object-fit:contain; flex:none; filter:none; }
.nav-cta{ display:none; }
@media(min-width:860px){ .nav-cta{ display:inline-flex; padding:12px 24px; font-size:14px; } }

/* =========================================================
   HERO
   ========================================================= */
.hero{ padding-top:116px; padding-bottom:50px; overflow:hidden; }
.hero-grid{ display:grid; gap:40px; align-items:center; }
@media(min-width:960px){ .hero-grid{ grid-template-columns:1.08fr .92fr; gap:28px; } }

.hero-copy .chip{ margin-bottom:22px; }
.hero h1{ margin-bottom:20px; line-height:1.06; letter-spacing:-0.04em; }
.hero h1 .gold-text{ display:inline; }
.hero .lead{ max-width:520px; margin-bottom:14px; }
.hero-cta-row{ display:flex; flex-wrap:wrap; gap:12px; margin-top:30px; }
.hero-assure{ display:flex; flex-wrap:wrap; gap:14px 0; margin-top:48px; }
.hero-assure .ha{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink-3); padding:0 18px; border-right:1px solid var(--hairline-soft); }
.hero-assure .ha:last-child{ border-right:none; }
.hero-assure .ha:first-child{ padding-left:0; }
.hero-assure svg{ flex:none; }

.hero-cover-img{
  width:min(360px,76%); height:auto; position:relative; z-index:2;
  filter:drop-shadow(0 40px 60px rgba(0,0,0,.15)) drop-shadow(0 10px 20px rgba(199,154,46,.12));
  animation:bookfloat 7s ease-in-out infinite;
}
.book-stage{ display:grid; place-items:center; min-height:420px; position:relative; }
.book-glow{
  position:absolute; width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle,rgba(184,134,11,.12),transparent 62%);
  filter:blur(20px); animation:breathe 6s ease-in-out infinite;
}
@keyframes breathe{ 0%,100%{ transform:scale(1); opacity:.85;} 50%{ transform:scale(1.12); opacity:1;} }
@keyframes bookfloat{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-14px); }
}

.hero-float-badge{
  position:absolute; right:4%; bottom:10%;
  display:flex; align-items:center; gap:11px;
  padding:12px 16px; border-radius:14px;
  animation:bookfloat 7s ease-in-out infinite reverse;
}
.hero-float-badge .big{ font-family:var(--serif); font-size:28px; line-height:1; }
.hero-float-badge .lbl{ font-size:11px; color:var(--ink-3); }

/* =========================================================
   TRUST STRIP
   ========================================================= */
.trust{ padding:30px 0; border-top:1px solid var(--hairline-soft); border-bottom:1px solid var(--hairline-soft); }
.trust-inner{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:14px 38px; }
.trust-item{ display:flex; align-items:center; gap:10px; color:var(--ink-3); font-size:13.5px; font-weight:600; }
.trust-item .n{ font-family:var(--serif); font-size:28px; color:var(--gold-2); line-height:1; }

/* =========================================================
   DOLOR
   ========================================================= */
.pain{ background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%); }
.pain-card{ background:var(--surface); box-shadow:var(--shadow-sm); }
.pain-grid{ display:grid; gap:18px; }
@media(min-width:760px){ .pain-grid{ grid-template-columns:repeat(3,1fr); } }
.pain-card{ padding:30px 26px; border-radius:var(--radius); border:1px solid var(--hairline-soft); background:var(--surface); position:relative; overflow:hidden; }
.pain-card .pn{ font-family:var(--serif); font-size:42px; color:var(--ink-4); line-height:1; }
.pain-card h3{ margin:14px 0 10px; }
.pain-card p{ color:var(--ink-3); font-size:15px; }
.pain-card::after{ content:""; position:absolute; left:0; top:0; bottom:0; width:3px; background:linear-gradient(180deg,transparent,rgba(184,134,11,.5),transparent); }

/* ---- Mid-page CTA banner ---- */
.mid-cta{ padding:clamp(44px,7vw,70px) 0; text-align:center; border-top:1px solid var(--hairline-soft); border-bottom:1px solid var(--hairline-soft); }

/* ---- Hero micro-proof ---- */
.hero-micro-proof{
  display:flex; align-items:center; gap:10px; margin-top:28px;
  padding:12px 16px; border-radius:12px; background:rgba(0,0,0,.03); border:1px solid var(--hairline-soft);
  max-width:460px;
}
.hmp-av{ width:32px; height:32px; border-radius:50%; flex:none; object-fit:cover; }
.hmp-text{ font-size:13px; color:var(--ink-3); font-style:italic; line-height:1.45; }
.hmp-text strong{ font-style:normal; color:var(--ink-2); }

/* ---- 3 Steps ---- */
.steps-section{ padding:clamp(50px,8vw,80px) 0; border-top:1px solid var(--hairline-soft); border-bottom:1px solid var(--hairline-soft); }
.steps-row{ display:grid; gap:24px; }
@media(min-width:760px){ .steps-row{ grid-template-columns:repeat(3,1fr); gap:32px; } }
.step-item{ text-align:center; }
.step-n{
  width:44px; height:44px; border-radius:50%; display:grid; place-items:center;
  margin:0 auto 16px; font-family:var(--serif); font-size:22px; font-weight:700;
  background:linear-gradient(135deg,#c79a2e,#8a6510); color:#fff;
  box-shadow:0 6px 16px -4px rgba(154,112,18,.3);
}
.step-item h3{ font-size:20px; margin-bottom:8px; }
.step-item p{ font-size:14.5px; color:var(--ink-3); max-width:280px; margin:0 auto; }

/* =========================================================
   SOLUCIÓN
   ========================================================= */
.solution-grid{ display:grid; gap:44px; align-items:center; }
@media(min-width:960px){ .solution-grid{ grid-template-columns:1fr 1fr; } }
.sol-media{ position:relative; }
.sol-media img{ border-radius:18px; box-shadow:0 30px 60px -16px rgba(0,0,0,.12), 0 0 0 1px rgba(184,134,11,.1); }
.sol-checklist{ list-style:none; margin-top:28px; display:flex; flex-direction:column; gap:14px; }
.sol-checklist li{ display:flex; gap:12px; align-items:flex-start; font-size:16px; color:var(--ink-2); }
.sol-checklist .ck{
  flex:none; width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  background:rgba(184,134,11,.1); border:1px solid var(--hairline); color:var(--gold-3); margin-top:1px;
}

/* =========================================================
   ¿PARA QUIÉN ES?
   ========================================================= */
.quien-grid{ display:grid; gap:18px; }
@media(min-width:760px){ .quien-grid{ grid-template-columns:repeat(2,1fr); } }
.quien-card{ padding:28px 26px; border-radius:var(--radius); border:1px solid var(--hairline-soft); background:var(--surface); display:flex; gap:16px; align-items:flex-start; }
.quien-card .qi{
  flex:none; width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(155deg,rgba(184,134,11,.12),rgba(199,154,46,.04));
  border:1px solid var(--hairline); color:var(--gold-3); font-size:20px;
}
.quien-card h3{ font-size:20px; margin-bottom:6px; }
.quien-card p{ font-size:14.5px; color:var(--ink-3); }

/* =========================================================
   BENEFICIOS
   ========================================================= */
.benefits-grid{ display:grid; gap:18px; grid-template-columns:1fr; }
@media(min-width:680px){ .benefits-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1000px){ .benefits-grid{ grid-template-columns:repeat(3,1fr); } }
.benefit{ padding:30px 26px; border-radius:var(--radius); position:relative; overflow:hidden; transition:transform .4s cubic-bezier(.2,.8,.2,1), border-color .4s; }
.benefit:hover{ transform:translateY(-5px); border-color:var(--hairline); }
.benefit .ico{
  width:50px; height:50px; border-radius:13px; display:grid; place-items:center; margin-bottom:20px;
  background:linear-gradient(155deg,rgba(184,134,11,.12),rgba(199,154,46,.04));
  border:1px solid var(--hairline); color:var(--gold-3);
}
.benefit h3{ font-size:22px; margin-bottom:8px; }
.benefit p{ color:var(--ink-3); font-size:15px; }

/* =========================================================
   STACK VISUAL — "Todo lo que recibes"
   ========================================================= */
.stack-list{ max-width:620px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.stack-item{
  display:flex; gap:16px; align-items:center; padding:18px 22px;
  border-radius:16px; border:1px solid var(--hairline-soft); background:var(--surface);
}
.stack-item img{ flex:none; width:56px; height:72px; object-fit:contain; border-radius:6px; filter:drop-shadow(0 4px 10px rgba(0,0,0,.4)); }
.stack-item .si-info{ flex:1; min-width:0; }
.stack-item .si-name{ font-weight:700; font-size:15.5px; color:var(--ink); }
.stack-item .si-desc{ font-size:13px; color:var(--ink-3); margin-top:2px; }
.stack-item .si-val{ flex:none; text-align:right; }
.stack-item .si-val s{ display:block; font-size:12px; color:var(--ink-4); }
.stack-item .si-val b{ font-family:var(--serif); font-size:20px; color:var(--gold-2); }
.stack-total{
  max-width:620px; margin:18px auto 0; padding:22px 26px; border-radius:16px;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px;
}
.stack-total .stl{ font-size:14px; color:var(--ink-3); }
.stack-total .stl b{ display:block; font-family:var(--serif); font-size:36px; color:var(--ink); }
.stack-total .stl b .cur{ font-size:18px; color:var(--gold-2); }
.stack-total .str{ font-size:13px; color:var(--ink-4); }
.stack-total .str b{ color:var(--gold-2); font-size:15px; }

/* =========================================================
   GALERÍA
   ========================================================= */
.gallery{ background:var(--bg); }
.shot{ background:var(--surface); box-shadow:var(--shadow-sm); }
.shot img{ background:var(--bg-2); }
.gallery-grid{ display:grid; gap:14px; grid-template-columns:repeat(2,1fr); }
@media(min-width:900px){ .gallery-grid{ grid-template-columns:repeat(12,1fr); grid-auto-rows:200px; } }
.shot{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--hairline-soft); position:relative; background:var(--surface); }
.shot img{ width:100%; height:100%; object-fit:contain; padding:16px; background:var(--bg-2); }
@media(min-width:900px){
  .shot.a{ grid-column:1/6; grid-row:1/3; }
  .shot.b{ grid-column:6/10; grid-row:1/2; }
  .shot.c{ grid-column:10/13; grid-row:1/3; }
  .shot.d{ grid-column:6/10; grid-row:2/3; }
  .shot.a img{ padding:24px; }
}
.shot .tag{ position:absolute; left:12px; bottom:12px; z-index:2; font-size:11.5px; font-weight:600; letter-spacing:.02em; padding:6px 12px; border-radius:30px; background:rgba(255,255,255,.85); border:1px solid var(--hairline-soft); backdrop-filter:blur(8px); color:var(--ink-2); }

/* =========================================================
   PRUEBA SOCIAL
   ========================================================= */
.social-rating{ display:flex; flex-direction:column; align-items:center; gap:8px; margin-bottom:48px; }
.social-rating .big{ font-family:var(--serif); font-size:60px; line-height:1; }
.testi-grid{ columns:1; column-gap:16px; }
@media(min-width:680px){ .testi-grid{ columns:2; } }
@media(min-width:1000px){ .testi-grid{ columns:3; } }
.testi{ break-inside:avoid; margin-bottom:16px; padding:26px 24px; border-radius:16px; border:1px solid var(--hairline-soft); background:var(--surface); }
.testi .stars{ margin-bottom:12px; display:block; }
.testi p{ font-size:15.5px; color:var(--ink-2); line-height:1.55; font-style:italic; }
.testi .who{ display:flex; align-items:center; gap:11px; margin-top:18px; }
.testi .av{
  width:40px; height:40px; border-radius:50%; flex:none; display:grid; place-items:center;
  font-family:var(--serif); font-weight:600; font-size:17px; color:#fff;
  background:linear-gradient(135deg,#c79a2e,#8a6510); border:2px solid var(--hairline);
}
.testi .av-img{ width:40px; height:40px; border-radius:50%; flex:none; object-fit:cover; border:2px solid var(--hairline); }
.testi .who .nm{ font-size:14px; font-weight:700; color:var(--ink); }
.testi .who .mt{ font-size:12px; color:var(--ink-4); }
.testi .who .vf{ margin-left:auto; font-size:11px; color:var(--gold-3); display:flex; align-items:center; gap:4px; }

/* =========================================================
   OFERTA
   ========================================================= */
.offer{ background:linear-gradient(180deg,var(--bg),#ece8df); }
.offer-card{ max-width:540px; margin:0 auto; padding:0; overflow:hidden; border:1px solid var(--hairline); box-shadow:var(--shadow-gold); }
.offer-top{ text-align:center; padding:36px 30px 6px; }
.offer-top .chip{ margin-bottom:18px; }
.offer-top .offer-cover{ width:160px; height:auto; margin:12px auto; filter:drop-shadow(0 14px 28px rgba(0,0,0,.5)); }
.offer-price{ display:flex; align-items:flex-end; justify-content:center; gap:12px; margin:16px 0 6px; }
.offer-price .old{ font-size:22px; color:var(--ink-4); text-decoration:line-through; text-decoration-color:rgba(199,154,46,.6); padding-bottom:10px; }
.offer-price .cur{ font-family:var(--serif); font-size:28px; color:var(--gold-2); align-self:flex-start; margin-top:6px; }
.offer-price .now{ font-family:var(--serif); font-size:78px; line-height:.8; }
.offer-price .cents{ font-family:var(--serif); font-size:32px; align-self:flex-start; margin-top:6px; color:var(--ink); }
.offer-save{ font-size:14px; color:var(--gold-2); font-weight:700; }
.offer-list{ list-style:none; padding:26px 34px 8px; display:flex; flex-direction:column; gap:12px; }
.offer-list li{ display:flex; gap:10px; align-items:center; font-size:15px; color:var(--ink-2); }
.offer-list .ck{ flex:none; color:var(--gold-2); }
.offer-foot{ padding:8px 30px 34px; }
.offer-foot .guarantee{ display:flex; align-items:center; gap:12px; margin-top:20px; padding:14px; border-radius:12px; background:rgba(184,134,11,.06); border:1px solid var(--hairline-soft); }
.offer-foot .guarantee .seal{ flex:none; width:48px; height:48px; }
.offer-foot .guarantee .gt{ font-size:13px; color:var(--ink-3); }
.offer-foot .guarantee .gt b{ color:var(--ink); display:block; font-size:14px; font-family:var(--serif); margin-bottom:2px; }
.offer-secure{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:16px; font-size:12px; color:var(--ink-4); }

/* payment icons row */
.pay-icons{ display:flex; align-items:center; justify-content:center; gap:10px; margin-top:14px; flex-wrap:wrap; }
.pay-icons .pi{
  display:flex; align-items:center; justify-content:center;
  padding:6px 12px; border-radius:6px; background:rgba(0,0,0,.03); border:1px solid var(--hairline-soft);
  font-size:11px; font-weight:700; color:var(--ink-3); letter-spacing:.02em;
}

/* countdown */
.countdown{ display:flex; justify-content:center; gap:8px; margin:6px 0 22px; }
.cd-box{ min-width:68px; padding:12px 6px; border-radius:12px; background:rgba(0,0,0,.03); border:1px solid var(--hairline-soft); text-align:center; }
.cd-box .v{ font-family:var(--serif); font-size:34px; line-height:1; color:var(--ink); font-variant-numeric:tabular-nums; }
.cd-box .l{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-4); margin-top:5px; }

/* =========================================================
   BONOS
   ========================================================= */
.bonus-grid{ display:grid; gap:16px; }
@media(min-width:760px){ .bonus-grid{ grid-template-columns:repeat(2,1fr); } }
.bonus-card{ display:flex; gap:18px; padding:24px; border-radius:16px; border:1px solid var(--hairline-soft); background:var(--surface); align-items:center; }
.bonus-card .bimg{ flex:none; width:80px; height:100px; border-radius:6px; overflow:hidden; box-shadow:var(--shadow-sm); }
.bonus-card .bimg img{ width:100%; height:100%; object-fit:cover; }
.bonus-card .bx h3{ font-size:20px; margin-bottom:6px; }
.bonus-card .bx p{ font-size:13.5px; color:var(--ink-3); }
.bonus-card .bval{ margin-top:8px; font-size:13px; }
.bonus-card .bval s{ color:var(--ink-4); } .bonus-card .bval b{ color:var(--gold-2); }

/* =========================================================
   ORDER BUMPS
   ========================================================= */
.bumps{ background:linear-gradient(180deg,#ece8df,var(--bg)); }
.bumps-wrap{ max-width:720px; margin:0 auto; }
.bump{
  display:flex; gap:14px; align-items:center; padding:18px 20px; margin-bottom:12px;
  border-radius:16px; border:1.5px solid var(--hairline-soft); background:var(--surface);
  cursor:pointer; transition:border-color .3s, background .3s, transform .25s;
  position:relative;
}
.bump:hover{ border-color:var(--hairline); transform:translateY(-2px); }
.bump.on{ border-color:var(--gold-3); background:linear-gradient(170deg,rgba(184,134,11,.08),rgba(199,154,46,.02)); box-shadow:var(--shadow-gold); }
.bump .check{
  flex:none; width:28px; height:28px; border-radius:8px; border:2px solid var(--ink-4);
  display:grid; place-items:center; transition:.25s; color:transparent;
}
.bump.on .check{ background:linear-gradient(135deg,#c79a2e,#8a6510); border-color:transparent; color:#fff; }
.bump .bthumb{ flex:none; width:48px; height:62px; border-radius:5px; overflow:hidden; background:var(--surface-2); }
.bump .bthumb img{ width:100%; height:100%; object-fit:cover; }
.bump .binfo{ flex:1; min-width:0; }
.bump .binfo .bt{ font-size:15px; font-weight:700; color:var(--ink); letter-spacing:-.01em; }
.bump .binfo .bd{ font-size:12.5px; color:var(--ink-3); margin-top:2px; }
.bump .bprice{ flex:none; text-align:right; }
.bump .bprice s{ display:block; font-size:12px; color:var(--ink-4); }
.bump .bprice b{ font-family:var(--serif); font-size:20px; color:var(--gold-2); }

.bump-total{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; margin-top:22px; padding:22px 24px; border-radius:16px; }
.bump-total .tl{ font-size:13px; color:var(--ink-3); }
.bump-total .tl b{ display:block; font-family:var(--serif); font-size:34px; color:var(--ink); }
.bump-total .tl b .cur{ font-size:18px; color:var(--gold-2); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-wrap{ max-width:720px; margin:0 auto; }
.faq-item{ border-bottom:1px solid var(--hairline-soft); }
.faq-q{ width:100%; background:none; border:none; cursor:pointer; text-align:left; padding:24px 4px; display:flex; align-items:center; justify-content:space-between; gap:16px; color:var(--ink); font-family:var(--serif); font-size:clamp(18px,2.3vw,22px); font-weight:600; min-height:52px; }
.faq-q .pm{ flex:none; width:28px; height:28px; border-radius:50%; border:1px solid var(--hairline); display:grid; place-items:center; color:var(--gold-3); transition:transform .35s, background .35s; font-size:16px; }
.faq-item.open .pm{ transform:rotate(45deg); background:rgba(184,134,11,.1); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .42s cubic-bezier(.4,0,.2,1); }
.faq-a p{ padding:0 4px 24px; color:var(--ink-3); font-size:15.5px; max-width:620px; }

/* =========================================================
   CTA FINAL
   ========================================================= */
.final{ text-align:center; overflow:hidden; }
.final::before{ content:""; position:absolute; left:50%; top:40%; transform:translate(-50%,-50%); width:700px; height:700px; max-width:120vw; border-radius:50%; background:radial-gradient(circle,rgba(184,134,11,.08),transparent 60%); pointer-events:none; }
.final h2{ max-width:720px; margin:0 auto 20px; }
.final .lead{ max-width:540px; margin:0 auto 34px; }
.final .chip{ margin-bottom:26px; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ border-top:1px solid var(--hairline-soft); padding:48px 0 120px; }
.footer-grid{ display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:flex-start; }
.footer .brand{ font-size:18px; }
.footer p{ font-size:13px; color:var(--ink-4); max-width:360px; margin-top:12px; line-height:1.6; }
.footer .fcontact{ font-size:13px; color:var(--ink-3); display:flex; flex-direction:column; gap:7px; }
.footer .fcontact a{ color:var(--gold-2); }
.footer-bottom{ margin-top:34px; padding-top:20px; border-top:1px solid var(--hairline-soft); font-size:12px; color:var(--ink-4); display:flex; flex-wrap:wrap; gap:6px 20px; justify-content:space-between; align-items:center; }
.footer-bottom a{ color:var(--gold-2); text-decoration:underline; min-height:44px; display:inline-flex; align-items:center; }

/* =========================================================
   STICKY: WhatsApp + mobile CTA
   ========================================================= */
.wa-fab{
  position:fixed; right:16px; bottom:88px; z-index:70;
  width:56px; height:56px; border-radius:50%; display:grid; place-items:center;
  background:linear-gradient(155deg,#25d366,#128c4b); color:#fff;
  box-shadow:0 14px 34px -8px rgba(18,140,75,.7); cursor:pointer;
  transition:transform .3s;
}
.wa-fab:hover{ transform:scale(1.08) translateY(-2px); }

/* WA tooltip label */
.wa-label{
  position:absolute; right:68px; top:50%; transform:translateY(-50%);
  white-space:nowrap; font-size:13px; font-weight:600; color:#1a1a1a;
  background:#fff; padding:8px 14px; border-radius:10px;
  box-shadow:0 6px 20px rgba(0,0,0,.25);
  opacity:0; pointer-events:none; transition:opacity .4s;
}
.wa-label::after{
  content:""; position:absolute; right:-6px; top:50%; transform:translateY(-50%);
  width:0; height:0; border-top:6px solid transparent; border-bottom:6px solid transparent; border-left:7px solid #fff;
}
.wa-label.show{ opacity:1; pointer-events:auto; }

/* Last sale social proof */
.last-sale{
  margin-top:16px; font-size:13px; color:var(--ink-4);
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.last-sale .ls-dot{
  width:6px; height:6px; border-radius:50%; background:#25d366;
  box-shadow:0 0 0 3px rgba(37,211,102,.2);
}
.wa-fab::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid rgba(37,211,102,.5); animation:wapulse 2.4s infinite; }
@keyframes wapulse{ 0%{ transform:scale(1); opacity:.8;} 100%{ transform:scale(1.7); opacity:0;} }
@media(min-width:860px){ .wa-fab{ bottom:24px; } }

.mobile-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:65;
  display:flex; align-items:center; gap:12px; padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(248,246,241,.92); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border-top:1px solid var(--hairline-soft);
  transform:translateY(120%); transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.mobile-cta.show{ transform:translateY(0); }
.mobile-cta .mc-price{ flex:none; }
.mobile-cta .mc-price .o{ font-size:11.5px; color:var(--ink-4); text-decoration:line-through; }
.mobile-cta .mc-price .n{ font-family:var(--serif); font-size:24px; line-height:1; color:var(--gold-3); }
.mobile-cta .btn{ flex:1; padding:14px 18px; font-size:15px; }
@media(min-width:860px){ .mobile-cta{ display:none; } }

/* =========================================================
   LEGAL MODALS
   ========================================================= */
.legal-modal{
  position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .35s, visibility .35s;
}
.legal-modal.show{ opacity:1; visibility:visible; }
.legal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.4); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); }
.legal-content{
  position:relative; z-index:2; width:92%; max-width:660px; max-height:80vh;
  padding:40px 36px; overflow-y:auto; border:1px solid var(--hairline);
  transform:translateY(20px); transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.legal-modal.show .legal-content{ transform:none; }
.legal-close{
  position:absolute; top:14px; right:14px; width:34px; height:34px; border-radius:50%;
  background:rgba(0,0,0,.04); border:1px solid var(--hairline-soft); color:var(--ink-3);
  font-size:15px; cursor:pointer; display:grid; place-items:center; transition:background .3s, color .3s;
  min-height:44px; min-width:44px;
}
.legal-close:hover{ background:rgba(0,0,0,.08); color:var(--ink); }
.legal-body h3{ font-family:var(--serif); font-size:19px; color:var(--gold-2); margin:24px 0 8px; }
.legal-body p{ font-size:14.5px; color:var(--ink-2); line-height:1.7; margin-bottom:12px; }
.legal-content::-webkit-scrollbar{ width:5px; }
.legal-content::-webkit-scrollbar-track{ background:transparent; }
.legal-content::-webkit-scrollbar-thumb{ background:var(--hairline); border-radius:3px; }

/* =========================================================
   ENTRANCE
   ========================================================= */
.reveal{ opacity:1; transform:none; }
@media(prefers-reduced-motion:no-preference){
  .reveal.anim{ animation:revealIn .8s cubic-bezier(.2,.8,.2,1) both; }
  .reveal.anim.d1{ animation-delay:.08s; }
  .reveal.anim.d2{ animation-delay:.16s; }
  .reveal.anim.d3{ animation-delay:.24s; }
  .reveal.anim.d4{ animation-delay:.32s; }
}
@keyframes revealIn{ from{ opacity:0; transform:translateY(24px); } to{ opacity:1; transform:none; } }

/* =========================================================
   MOBILE OVERRIDES
   ========================================================= */
@media(max-width:680px){
  .wrap{ padding:0 16px; }
  section{ padding:clamp(48px,8vw,80px) 0; }
  
  /* Nav */
  .nav{ padding:12px 16px; }
  .nav.scrolled{ padding:8px 16px; }
  .brand-logo{ width:30px; height:30px; }
  .brand{ font-size:18px; gap:8px; }

  /* Hero */
  .hero{ padding-top:90px; padding-bottom:36px; }
  .hero-grid{ gap:28px; }
  .hero h1{ font-size:clamp(28px,8.5vw,40px); line-height:1.1; }
  .hero .lead{ font-size:15.5px; }
  .hero-cta-row{ flex-direction:column; gap:10px; }
  .hero-cta-row .btn{ width:100%; text-align:center; }
  .btn-lg{ padding:18px 28px; font-size:16px; }
  .hero-assure{ gap:10px 0; margin-top:20px; }
  .hero-assure .ha{ font-size:12.5px; padding:0 12px; }
  .hero-micro-proof{ max-width:100%; padding:10px 12px; margin-top:20px; }
  .hmp-text{ font-size:12px; }
  .book-stage{ min-height:300px; }
  .hero-cover-img{ width:min(240px,66%); }
  .book-glow{ width:240px; height:240px; }
  .hero-float-badge{ padding:10px 12px; right:2%; bottom:6%; }
  .hero-float-badge .big{ font-size:22px; }
  .hero-float-badge .lbl{ font-size:10px; }

  /* Trust */
  .trust-inner{ gap:10px 20px; }
  .trust-item{ font-size:12px; }
  .trust-item .n{ font-size:22px; }

  /* Section heads */
  .section-head{ margin-bottom:clamp(28px,5vw,44px); }
  .section-head h2{ font-size:clamp(24px,6.5vw,34px); }
  .section-head .lead{ font-size:15px; margin-top:12px; }
  .eyebrow{ font-size:11px; letter-spacing:.26em; }

  /* Pain */
  .pain-grid{ grid-template-columns:1fr; gap:12px; }
  .pain-card{ padding:24px 20px; }
  .pain-card .pn{ font-size:34px; }
  .pain-card h3{ font-size:19px; }
  .pain-card p{ font-size:14px; }

  /* Solution */
  .solution-grid{ gap:30px; }
  .sol-copy h2{ font-size:clamp(24px,6.5vw,34px); }
  .sol-checklist li{ font-size:14.5px; gap:10px; }
  .sol-media img{ max-width:100%; }

  /* Para quién */
  .quien-grid{ grid-template-columns:1fr; gap:12px; }
  .quien-card{ padding:22px 20px; gap:12px; }
  .quien-card h3{ font-size:18px; }
  .quien-card p{ font-size:13.5px; }

  /* Benefits */
  .benefits-grid{ grid-template-columns:1fr; gap:12px; }
  .benefit{ padding:24px 20px; }
  .benefit .ico{ width:44px; height:44px; margin-bottom:16px; }
  .benefit h3{ font-size:19px; }
  .benefit p{ font-size:14px; }

  /* Gallery */
  .gallery-grid{ gap:8px; grid-template-columns:1fr 1fr; }
  .shot img{ padding:10px; }

  /* Testimonials */
  .testi-grid{ columns:1; }
  .testi{ padding:20px 18px; }
  .testi p{ font-size:14.5px; }
  .testi .who{ gap:9px; margin-top:14px; }
  .testi .av-img{ width:34px; height:34px; }

  /* Steps */
  .steps-row{ gap:18px; }
  .step-item h3{ font-size:18px; }
  .step-item p{ font-size:13.5px; }

  /* Stack */
  .stack-list{ gap:10px; }
  .stack-item{ padding:14px 16px; gap:12px; flex-wrap:nowrap; }
  .stack-item img{ width:44px; height:56px; }
  .stack-item .si-name{ font-size:14px; }
  .stack-item .si-desc{ font-size:12px; }
  .stack-item .si-val b{ font-size:17px; }
  .stack-total{ padding:18px 20px; }
  .stack-total .tl b{ font-size:30px; }

  /* Offer */
  .offer-card{ border-radius:18px; }
  .offer-top{ padding:26px 18px 6px; }
  .offer-cover{ width:120px; }
  .offer-price .now{ font-size:56px; }
  .offer-price .cur{ font-size:20px; }
  .offer-price .cents{ font-size:24px; }
  .offer-price .old{ font-size:18px; }
  .offer-list{ padding:20px 18px 8px; }
  .offer-list li{ font-size:14px; gap:8px; }
  .offer-foot{ padding:8px 18px 26px; }
  .offer-foot .guarantee{ padding:12px; gap:10px; }
  .offer-foot .guarantee .seal{ width:40px; height:40px; }
  .offer-foot .guarantee .gt{ font-size:12px; }
  .offer-foot .guarantee .gt b{ font-size:13px; }
  .countdown{ gap:6px; margin-bottom:18px; }
  .cd-box{ min-width:58px; padding:10px 4px; }
  .cd-box .v{ font-size:28px; }
  .cd-box .l{ font-size:9px; }
  .pay-icons{ gap:6px; }
  .pay-icons .pi{ padding:5px 10px; font-size:10px; }

  /* Bumps */
  .bump{ flex-wrap:wrap; gap:10px; padding:14px 16px; }
  .bump .bthumb{ width:42px; height:54px; }
  .bump .binfo .bt{ font-size:14px; }
  .bump .binfo .bd{ font-size:11.5px; }
  .bump .bprice{ width:100%; text-align:left; display:flex; gap:8px; align-items:center; }
  .bump .bprice s{ display:inline; font-size:11px; }
  .bump .bprice b{ font-size:17px; }
  .bump-total{ padding:18px 20px; }
  .bump-total .tl b{ font-size:28px; }

  /* FAQ */
  .faq-q{ padding:20px 2px; font-size:clamp(16px,4.5vw,20px); gap:12px; }
  .faq-a p{ font-size:14.5px; padding-bottom:20px; }

  /* Final CTA */
  .final h2{ font-size:clamp(24px,6.5vw,34px); }
  .final .lead{ font-size:15px; }

  /* Footer */
  .footer{ padding:40px 0 110px; }
  .footer-grid{ gap:20px; }
  .footer .brand{ font-size:16px; }
  .footer p{ font-size:12px; margin-top:10px; }
  .footer-bottom{ font-size:11px; gap:6px 12px; }

  /* Mobile CTA bar */
  .mobile-cta{ padding:8px 12px calc(8px + env(safe-area-inset-bottom)); gap:10px; }
  .mobile-cta .mc-price .n{ font-size:20px; }
  .mobile-cta .mc-price .o{ font-size:10px; }
  .mobile-cta .btn{ font-size:14px; padding:12px 16px; }

  /* WA fab */
  .wa-fab{ width:50px; height:50px; right:14px; bottom:78px; }
  .wa-label{ right:60px; font-size:12px; padding:7px 12px; }

  /* Legal modals */
  .legal-content{ padding:28px 22px; max-height:85vh; }
  .legal-body h3{ font-size:17px; }
  .legal-body p{ font-size:13.5px; }
}
