/* ============================================================
   TUP Inversión — Stylesheet (DARK · continuo · patrones del pack)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; min-width: 0; }
html { overflow-x: clip; }
html, body { height: 100%; max-width: 100vw; }
body {
  font-family: var(--ff-body);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--c-text-soft);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
  position: relative;
}

/* GRID GLOBAL — continuo en toda la página, fija detrás */
body::before {
  content: ""; position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
  z-index: 0;
}

/* GLOW NARANJA — orbita por la página, da continuidad */
body::after {
  content: ""; position: fixed; inset: 0;
  background:
    radial-gradient(1100px 700px at 85% 8%,  rgba(255,164,23,0.10), transparent 60%),
    radial-gradient(900px 600px at 10% 65%, rgba(255,164,23,0.06), transparent 60%);
  pointer-events: none;
  z-index: 0;
}

img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
a { color: inherit; text-decoration: none; }
ul, ol { padding: 0; list-style: none; }

/* ---------- Typography (pesos más contenidos) ---------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  letter-spacing: -0.012em;
  color: var(--c-text);
}
h1 { font-size: var(--fs-h1); }
html { scroll-behavior: smooth; scroll-padding-top: 70px; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
h2 { font-size: var(--fs-h2); max-width: 900px; }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); font-weight: var(--fw-semi); }
h1, h2, h3 { text-wrap: balance; }

.eyebrow {
  display: inline-block;
  font-family: var(--ff-body);
  font-weight: var(--fw-bold);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-size: 0.74rem;
  color: var(--c-accent);
}
.eyebrow--pill {
  padding: 0.65rem 1.3rem;
  border: 1.5px solid var(--c-accent);
  border-radius: var(--r-full);
  background: rgba(255,164,23,0.08);
  color: var(--c-text);
  font-weight: var(--fw-bold);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
}
.eyebrow--pill .hl { color: var(--c-accent); }

.lead { font-size: 1.1rem; color: var(--c-text-soft); line-height: var(--lh-loose); }
.muted { color: var(--c-text-muted); }
.small { font-size: var(--fs-small); }
.micro { font-size: var(--fs-micro); color: var(--c-text-muted); }
.hl { color: var(--c-accent); }

/* ---------- Layout helpers ---------- */
.container {
  width: 100%;
  max-width: var(--w-container);
  margin-inline: auto;
  padding-inline: var(--gutter);
  position: relative;
  z-index: 1;
}
.narrow { max-width: var(--w-narrow); margin-inline: auto; }
.section { padding-block: var(--section-py); position: relative; }
.section-head { text-align: center; margin-bottom: var(--sp-7); }
.section-head .eyebrow { display: inline-block; margin-bottom: var(--sp-4); }
.section-head h2 { max-width: 900px; margin-inline: auto; }
.section-head p { margin-top: var(--sp-4); max-width: 900px; margin-inline: auto; color: var(--c-text-soft); }

/* SPLIT HEAD — K7/K46 pattern: heading izq + body der */
.split-head {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: end;
  margin-bottom: var(--sp-8);
}
.split-head h2 {
  max-width: 900px;
  font-size: clamp(1.7rem, 2.4vw, 2.3rem);
  line-height: 1.18;
  font-weight: var(--fw-semi);
}
.split-head .eyebrow { display: block; margin-bottom: var(--sp-3); }
.split-head p { color: var(--c-text-soft); line-height: var(--lh-loose); font-size: 1.02rem; }
@media (max-width: 768px) {
  .split-head { grid-template-columns: 1fr; align-items: start; }
}

.stack > * + * { margin-top: var(--sp-4); }
.stack-lg > * + * { margin-top: var(--sp-6); }

/* ---------- Topbar logo — banda en flow, padding simétrico ---------- */
.topbar {
  padding: var(--sp-6) var(--gutter);
  display: flex; justify-content: center; align-items: center;
  position: relative; z-index: 5;
}
.topbar__logo { display: inline-flex; }
.topbar__logo img { height: 48px; width: auto; display: block; }

/* ---------- URGENCY BAR (fixed top, animada) ---------- */
.urgency-bar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: linear-gradient(90deg, var(--c-accent) 0%, #ff8a00 50%, var(--c-accent) 100%);
  background-size: 200% 100%;
  animation: urgency-pan 8s linear infinite;
  color: var(--c-accent-ink);
  padding: 0.6rem var(--gutter);
  font-size: 0.84rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.01em;
  text-align: center;
  display: flex; align-items: center; justify-content: center; gap: var(--sp-4);
  flex-wrap: wrap;
  box-shadow: 0 2px 12px rgba(255,164,23,0.25);
}
/* Empuja el contenido para que no quede tapado por el banner fijo */
body { padding-top: 46px; }
@media (max-width: 640px) { body { padding-top: 42px; } }
@keyframes urgency-pan { 0% { background-position: 0% 0; } 100% { background-position: 200% 0; } }
.urgency-bar__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-accent-ink);
  animation: urgency-pulse 1.4s infinite;
}
@keyframes urgency-pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .4; transform: scale(1.3); } }
.urgency-bar__mini {
  display: inline-flex; gap: var(--sp-2);
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  letter-spacing: -0.01em;
  padding: 0.25rem 0.8rem;
  background: rgba(10,10,10,0.85);
  color: var(--c-accent);
  border-radius: var(--r-full);
  font-size: 0.85rem;
}
.urgency-bar__mini b { color: var(--c-text); font-weight: var(--fw-bold); }
.urgency-bar__mini-label {
  font-family: var(--ff-body);
  font-weight: var(--fw-semi);
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.85);
  font-size: 0.78rem;
  text-transform: none;
  margin-right: var(--sp-2);
}
/* En mobile mantenemos la etiqueta pero más compacta */
@media (max-width: 640px) {
  .urgency-bar__mini-label { font-size: 0.66rem; margin-right: 6px; letter-spacing: 0; }
}
/* En pantallas MUY pequeñas (<360px) reducimos a "Cierran en:" via JS o aceptamos el wrap */
.urgency-bar a {
  text-decoration: underline; text-underline-offset: 3px;
  text-decoration-thickness: 1.5px;
}
@media (max-width: 640px) { .urgency-bar { font-size: 0.78rem; padding: 0.5rem var(--sp-4); gap: var(--sp-3); } }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-3);
  padding: 1rem 1.75rem;
  font-weight: var(--fw-bold);
  font-size: 0.92rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: var(--r-full);
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform var(--t-fast), box-shadow var(--t-base), background var(--t-base);
  text-align: center; white-space: nowrap;
}
.btn--primary { background: var(--c-accent); color: var(--c-accent-ink); box-shadow: var(--shadow-orange); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 14px 36px rgba(255,164,23,0.4); }
.btn--ghost { background: transparent; color: var(--c-text); border-color: var(--c-border-strong); }
.btn--ghost:hover { background: rgba(255,255,255,0.06); }
.btn--lg { padding: 1.1rem 2.2rem; font-size: 0.98rem; }
.btn--xl { padding: 1.3rem 2.5rem; font-size: 1.02rem; }
.btn--block { width: 100%; }
.btn-arrow {
  display: inline-flex; align-items: center; gap: var(--sp-3);
  color: var(--c-accent); font-weight: var(--fw-bold); font-size: var(--fs-small);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.btn-arrow::after { content: "→"; transition: transform var(--t-fast); }
.btn-arrow:hover::after { transform: translateX(4px); }

/* ---------- Placeholders ---------- */
.ph {
  display: flex; align-items: center; justify-content: center; text-align: center;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.025) 25%, transparent 25%) -20px 0,
    linear-gradient(225deg, rgba(255,255,255,0.025) 25%, transparent 25%) -20px 0,
    linear-gradient(315deg, rgba(255,255,255,0.025) 25%, transparent 25%),
    linear-gradient(45deg, rgba(255,255,255,0.025) 25%, transparent 25%);
  background-size: 40px 40px;
  background-color: #1d1d1d;
  color: var(--c-text-muted);
  font-family: var(--ff-body);
  font-size: var(--fs-small);
  font-weight: var(--fw-medium);
  border: 1px dashed rgba(255,255,255,0.12);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  width: 100%;
}
.ph--16x9 { aspect-ratio: 16/9; }
.ph--4x3  { aspect-ratio: 4/3; }
.ph--3x2  { aspect-ratio: 3/2; }
.ph--1x1  { aspect-ratio: 1/1; }
.ph--3x4  { aspect-ratio: 3/4; }
.ph--4x5  { aspect-ratio: 4/5; }
.ph__hint { font-weight: var(--fw-bold); color: var(--c-text); margin-bottom: var(--sp-1); }
.ph__meta { font-size: var(--fs-micro); }

/* ---------- Icon (line-art naranja, patrón K382) ---------- */
.icon-line {
  width: 44px; height: 44px;
  color: var(--c-accent);
  flex-shrink: 0;
}
.icon-line svg { width: 100%; height: 100%; }
.icon-line--lg { width: 56px; height: 56px; }
.icon-line--xs { width: 24px; height: 24px; }

/* ============================================================
   HERO — grid bg, polaroid Sergio+Juan
   ============================================================ */
.hero {
  padding: var(--sp-6) 0 var(--sp-9);
  position: relative;
  overflow: visible;
}
.hero__head { text-align: center; max-width: 1200px; margin: 0 auto var(--sp-8); padding-inline: 0; }
.hero__head .eyebrow--pill { margin-bottom: var(--sp-5); }
.hero__h1 {
  font-size: clamp(2rem, 2.2vw + 1rem, 3rem);
  line-height: 1.18;
  letter-spacing: -0.018em;
  text-wrap: wrap;
  font-weight: var(--fw-medium);
  max-width: 1200px;
  margin-inline: auto;
}
.hero__h1 .hl { font-weight: var(--fw-semi); }
.hero__h1 .hl { color: var(--c-accent); }
.hero__sub {
  margin-top: var(--sp-5);
  font-size: 1.08rem;
  color: var(--c-text-soft);
  line-height: var(--lh-loose);
  max-width: 900px;
  margin-inline: auto;
}

.hero__body {
  display: grid;
  grid-template-columns: 45fr 55fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: stretch;
}

.hero__date {
  display: inline-flex; align-items: center; gap: var(--sp-3);
  padding: 0.7rem 1.1rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  font-size: var(--fs-small);
  color: var(--c-text);
  margin-bottom: var(--sp-5);
}
.hero__date strong { color: var(--c-accent); font-weight: var(--fw-bold); }

.hero__card {
  background: rgba(255,255,255,0.035);
  backdrop-filter: blur(24px) saturate(120%);
  -webkit-backdrop-filter: blur(24px) saturate(120%);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--r-lg);
  padding: var(--sp-7);
  box-shadow: 0 4px 24px rgba(0,0,0,0.3);
}

/* Glassmorphism utility — aplicado a cards principales */
.module,
.expert,
.tool,
.testimonial,
.plan,
.pillar,
.calc-frame,
.posdatas,
.fit-col,
.stack-table__inner,
.press-card {
  background: rgba(255,255,255,0.035) !important;
  backdrop-filter: blur(20px) saturate(120%);
  -webkit-backdrop-filter: blur(20px) saturate(120%);
  border-color: rgba(255,255,255,0.08) !important;
}
.plan--featured {
  background: linear-gradient(180deg, rgba(255,164,23,0.10), rgba(255,255,255,0.035) 35%) !important;
  border-color: var(--c-accent) !important;
}

/* IMAGE ORBIT — imagen sobre círculo naranja sólido (patrón web real) */
.image-orbit {
  position: relative;
  display: grid; place-items: center;
  padding: var(--sp-7) 0;
}
.image-orbit::before {
  content: ""; position: absolute;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 70%; aspect-ratio: 1;
  background: var(--c-accent);
  border-radius: 50%;
  z-index: 0;
  filter: blur(0px);
}
.image-orbit > * { position: relative; z-index: 1; max-width: 90%; }

/* SPLIT image+content pattern */
.split-content {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}
.split-content--reverse > *:first-child { order: 2; }
@media (max-width: 768px) {
  .split-content { grid-template-columns: 1fr; }
  .split-content--reverse > *:first-child { order: 0; }
}
.hero__card h3 {
  font-size: 1.05rem;
  color: var(--c-text);
  margin-bottom: var(--sp-4);
  line-height: 1.45;
  font-weight: var(--fw-semi);
}
.hero__card h3 strong { color: var(--c-accent); font-weight: var(--fw-bold); }
.hero__card > .eyebrow { margin-bottom: var(--sp-5); }
.hero__bullets { display: grid; gap: var(--sp-4); margin-bottom: var(--sp-5); }
.hero__bullets li {
  position: relative;
  padding-left: 32px;
  font-size: var(--fs-small);
  color: var(--c-text-soft);
  line-height: var(--lh-normal);
}
.hero__bullets li::before {
  content: "";
  position: absolute;
  left: 0; top: 2px;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--c-accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a0a0a' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 12px;
  background-position: center;
  background-repeat: no-repeat;
}
.hero__card .btn {
  display: flex;
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  padding-inline: 3.5rem;
}
.hero__card-foot {
  margin-top: var(--sp-4);
  text-align: center;
  font-size: var(--fs-micro);
  color: var(--c-text-muted);
}

.hero__polaroid {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-lg);
  min-height: 100%;
}
.hero__polaroid > img,
.hero__polaroid > .ph { width: 100%; height: 100%; object-fit: cover; min-height: 480px; display: block; }

/* Variante PNG transparente con destello naranja detrás */
.hero__polaroid--png {
  background: transparent;
  border: none;
  box-shadow: none;
  overflow: visible;
  min-height: 0;
  padding: 0;
  margin: 0;
  display: block;
  position: relative;
}
.hero__polaroid--png::before {
  content: "";
  position: absolute;
  inset: 0 10% 25% 10%;
  background:
    radial-gradient(ellipse 50% 45% at 50% 35%, rgba(255,164,23,0.55) 0%, rgba(255,164,23,0.22) 30%, transparent 65%),
    radial-gradient(circle at 60% 22%, rgba(255,138,0,0.30) 0%, transparent 45%);
  filter: blur(45px);
  z-index: 0;
  pointer-events: none;
  animation: hero-pulse 6s ease-in-out infinite;
}
.hero__polaroid--png::after {
  content: "";
  position: absolute;
  inset: 0 20% 40% 20%;
  background: radial-gradient(ellipse 50% 40% at 50% 30%, rgba(255,255,255,0.14) 0%, transparent 65%);
  filter: blur(25px);
  z-index: 0;
  pointer-events: none;
}
@keyframes hero-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.06); }
}
.hero__polaroid--png > img {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  height: auto;
  min-height: 0;
  display: block;
  margin: 0;
  padding: 0;
}
@media (max-width: 880px) {
  .hero__polaroid--png { max-width: 560px; margin-inline: auto; }
}

/* COLLAGE 10 expertos (grid 5×2) */
.hero__experts-collage {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  grid-template-rows: 1fr 1fr;
  gap: 2px;
  width: 100%;
  min-height: 480px;
  background: rgba(255,164,23,0.08);
}
.hero__experts-collage img {
  width: 100%; height: 100%; object-fit: cover;
  background: var(--c-bg-elevated);
  filter: grayscale(15%) brightness(0.92);
  transition: filter var(--t-base), transform var(--t-base);
}
.hero__experts-collage img:hover {
  filter: none;
  transform: scale(1.04);
  z-index: 2;
  position: relative;
}
@media (max-width: 880px) {
  .hero__experts-collage { grid-template-columns: repeat(5, 1fr); grid-template-rows: 1fr 1fr; min-height: 280px; }
}
@media (max-width: 480px) {
  .hero__experts-collage { min-height: 220px; }
}
.hero__polaroid-badge {
  position: absolute; right: var(--sp-5); top: var(--sp-5);
  padding: 0.5rem 1rem;
  background: rgba(10,10,10,0.7);
  backdrop-filter: blur(8px);
  border: 1px solid var(--c-accent);
  border-radius: var(--r-full);
  color: var(--c-accent);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  z-index: 1;
}

.countdown {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: var(--sp-3);
  padding: var(--sp-5) var(--sp-6);
  background: linear-gradient(135deg, #ffb840 0%, var(--c-accent) 45%, #ff8a00 100%);
  border: none;
  color: var(--c-accent-ink);
  border-radius: var(--r-md);
  margin: var(--sp-7) auto 0;
  max-width: 540px;
  box-shadow: 0 14px 40px rgba(255,164,23,0.35), inset 0 1px 0 rgba(255,255,255,0.35);
  position: relative;
  overflow: hidden;
}
.countdown__label-row {
  grid-column: 1 / -1;
  text-align: center;
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(10,10,10,0.75);
  margin-bottom: var(--sp-2);
  font-weight: var(--fw-bold);
  position: relative;
}
.countdown__cell { text-align: center; position: relative; }
.countdown__num { font-family: var(--ff-display); font-size: 2rem; font-weight: var(--fw-bold); line-height: 1; color: var(--c-accent-ink); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.countdown__unit { font-size: 0.7rem; color: rgba(10,10,10,0.65); margin-top: 6px; text-transform: uppercase; letter-spacing: 0.16em; font-weight: var(--fw-bold); }

@media (max-width: 880px) {
  .hero__body { grid-template-columns: 1fr; }
  .hero__polaroid { order: -1; }
  .hero__polaroid img,
  .hero__polaroid > .ph { min-height: 360px; }
}

/* ============================================================
   FEATURE-ROW (patrón K382: 4 columnas con icon-line + título + body)
   ============================================================ */
.feature-row-wrap { padding-block: var(--sp-5) !important; }
.feature-row-wrap__head { margin-bottom: var(--sp-5); }
.feature-row-wrap .feature-row {
  padding-block: var(--sp-6);
  border-bottom: none;
}
.feature-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
  padding-block: var(--section-py);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
}
.feature {
  display: grid; gap: var(--sp-3);
}
.feature__title {
  font-size: 1.05rem;
  font-weight: var(--fw-bold);
  color: var(--c-text);
  margin-top: var(--sp-2);
  line-height: 1.3;
}
.feature__desc { font-size: var(--fs-small); color: var(--c-text-muted); line-height: var(--lh-normal); }

@media (max-width: 880px) { .feature-row { grid-template-columns: 1fr 1fr; gap: var(--sp-5); } }
@media (max-width: 480px) { .feature-row { grid-template-columns: 1fr; } }

/* ============================================================
   ORIGIN — sustituye al VSL: foto Sergio+Juan + copy
   ============================================================ */
.origin__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.origin__photo {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--c-border);
  aspect-ratio: 4 / 5;
}
.origin__photo img { width: 100%; height: 100%; object-fit: cover; }
.origin__photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.6));
  pointer-events: none;
}
.origin__photo-badge {
  position: absolute; left: var(--sp-5); bottom: var(--sp-5);
  padding: 6px 14px;
  background: rgba(255,164,23,0.95);
  color: var(--c-accent-ink);
  border-radius: var(--r-full);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  z-index: 1;
}
.origin__copy .eyebrow { display: block; margin-bottom: var(--sp-3); }
.origin__copy h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.6rem);
  font-weight: var(--fw-semi);
  line-height: 1.2;
  margin-bottom: var(--sp-5);
}
.origin__copy p { font-size: 1.02rem; line-height: var(--lh-loose); color: var(--c-text-soft); margin-bottom: var(--sp-4); }
.origin__copy p strong { color: var(--c-text); font-weight: var(--fw-bold); }
@media (max-width: 880px) {
  .origin__grid { grid-template-columns: 1fr; }
  .origin__photo { max-width: 380px; margin-inline: auto; aspect-ratio: 3/4; }
}

/* ============================================================
   PRENSA
   ============================================================ */
.press__strip {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-7);
}
.press-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
  aspect-ratio: 4 / 3;
  position: relative;
}
.press-card img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 0.5s cubic-bezier(.22,.7,.27,1);
}
.press-card--clickable {
  cursor: zoom-in;
  padding: 0;
  font: inherit;
  color: inherit;
}
.press-card--clickable:hover { transform: translateY(-4px); border-color: var(--c-accent); box-shadow: 0 16px 40px rgba(255,164,23,0.18); }
.press-card--clickable:hover img { transform: scale(1.06); }
.press-card__zoom {
  position: absolute;
  inset: auto var(--sp-3) var(--sp-3) auto;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(10,10,10,0.7);
  backdrop-filter: blur(6px);
  color: #fff;
  display: grid; place-items: center;
  opacity: 0; transform: translateY(6px);
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.press-card--clickable:hover .press-card__zoom { opacity: 1; transform: translateY(0); }
.press-card__zoom svg { width: 16px; height: 16px; }

/* En móvil: la press card se ve como imagen, sin cursor zoom ni icono lupa */
@media (max-width: 768px) {
  .press-card--clickable { cursor: default; }
  .press-card--clickable:hover { transform: none; border-color: var(--c-border); box-shadow: none; }
  .press-card--clickable:hover img { transform: none; }
  .press-card__zoom { display: none; }
}

/* LIGHTBOX (GSAP Flip) */
.lightbox {
  position: fixed; inset: 0; z-index: 200;
  display: grid; place-items: center;
  padding: clamp(1rem, 4vw, 3rem);
  pointer-events: none;
  visibility: hidden;
}
.lightbox.is-open { pointer-events: auto; visibility: visible; }
.lightbox__backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.85);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  cursor: zoom-out;
  opacity: 0;
  transition: opacity 0.35s ease;
}
.lightbox.is-open .lightbox__backdrop { opacity: 1; }

.lightbox__stage {
  position: relative; z-index: 1;
  max-width: min(720px, 92vw);
  max-height: 80vh;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lightbox__stage img {
  max-width: 100%;
  max-height: 80vh;
  width: auto; height: auto;
  border-radius: var(--r-md);
  box-shadow: 0 30px 80px rgba(0,0,0,0.7);
  display: block;
}

.lightbox__close {
  position: absolute;
  top: clamp(1rem, 3vw, 2rem); right: clamp(1rem, 3vw, 2rem);
  z-index: 2;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: #fff;
  cursor: pointer;
  display: grid; place-items: center;
  transition: background var(--t-fast), transform var(--t-fast), opacity 0.25s ease;
  opacity: 0;
}
.lightbox.is-open .lightbox__close { opacity: 1; transition-delay: 0.2s; }
.lightbox__close:hover { background: var(--c-accent); color: var(--c-accent-ink); transform: scale(1.05); }
.lightbox__close svg { width: 18px; height: 18px; }

/* La imagen que está volando con Flip queda por encima de todo */
.is-flying {
  position: fixed !important;
  z-index: 210 !important;
  pointer-events: none;
  box-shadow: 0 30px 80px rgba(0,0,0,0.7);
}
.press__close {
  text-align: center;
  max-width: 900px;
  margin: var(--sp-7) auto 0;
  font-size: 1.25rem;
  font-weight: var(--fw-semi);
  color: var(--c-text);
}
@media (max-width: 720px) { .press__strip { grid-template-columns: 1fr; } }

/* ============================================================
   LAS CUENTAS (numbers)
   ============================================================ */
.numbers__body { font-size: 1.08rem; line-height: var(--lh-loose); }
.numbers__body strong { color: var(--c-text); font-weight: var(--fw-bold); }
.numbers__highlight {
  font-size: 1.25rem;
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  margin-top: var(--sp-5);
  padding: var(--sp-5);
  border-left: 3px solid var(--c-accent);
  background: rgba(255,164,23,0.06);
  border-radius: 0 var(--r-md) var(--r-md) 0;
}

/* ============================================================
   CALCULADORA — interactiva con gráfica SVG real
   ============================================================ */
.calc-frame {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  margin-top: var(--sp-6);
  position: relative;
  overflow: hidden;
  max-width: 1080px;
  margin-inline: auto;
}
.calc-frame::before {
  content: ""; position: absolute; top: 0; right: 0;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255,164,23,0.10), transparent 70%);
  filter: blur(20px);
  pointer-events: none;
}
.calc-frame__top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--c-border);
  position: relative;
}
.calc-frame__title { display: flex; align-items: center; gap: var(--sp-3); }
.calc-frame__title-icon { width: 36px; height: 36px; border-radius: var(--r-sm); background: rgba(255,164,23,0.12); display: grid; place-items: center; color: var(--c-accent); }
.calc-frame__title strong { color: var(--c-text); font-family: var(--ff-display); font-weight: var(--fw-bold); font-size: 1rem; letter-spacing: 0.04em; }
.calc-frame__pill { font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-accent); padding: 0.4rem 0.9rem; background: rgba(255,164,23,0.10); border: 1px solid rgba(255,164,23,0.3); border-radius: var(--r-full); font-weight: var(--fw-bold); }

.calc__layout {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: var(--sp-5);
  position: relative;
}
.calc__inputs {
  display: grid; gap: var(--sp-4);
}
.calc-input {
  background: rgba(255,255,255,0.03);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.calc-input:focus-within,
.calc-input.is-active { border-color: var(--c-accent); background: rgba(255,164,23,0.05); }
.calc-input__row {
  display: flex; align-items: baseline; justify-content: space-between; gap: var(--sp-3);
}
.calc-input label {
  font-weight: var(--fw-bold);
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.66rem;
}
.calc-input__value {
  font-family: var(--ff-display);
  font-size: 1.35rem;
  font-weight: var(--fw-bold);
  color: var(--c-text);
  letter-spacing: -0.015em;
  outline: none;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: 6px;
  text-align: right;
  padding: 4px 10px;
  width: 130px;
  cursor: text;
  transition: border-color var(--t-fast), background var(--t-fast);
}
.calc-input__value:hover { background: rgba(255,255,255,0.06); }
.calc-input__value:focus { border-color: var(--c-accent); background: rgba(255,164,23,0.06); }
.calc-input__value::placeholder { color: var(--c-text-muted); }

/* Slider */
.calc-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: linear-gradient(to right, var(--c-accent) 0%, var(--c-accent) var(--pct,30%), rgba(255,255,255,0.08) var(--pct,30%), rgba(255,255,255,0.08) 100%);
  outline: none;
  margin-top: var(--sp-3);
  cursor: pointer;
}
.calc-slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--c-accent);
  border: 3px solid #fff;
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(255,164,23,0.18), 0 2px 6px rgba(0,0,0,0.4);
  transition: transform var(--t-fast);
}
.calc-slider::-webkit-slider-thumb:hover { transform: scale(1.15); }
.calc-slider::-webkit-slider-thumb:active { transform: scale(1.25); }
.calc-slider::-moz-range-thumb {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--c-accent);
  border: 3px solid #fff;
  cursor: pointer;
  box-shadow: 0 0 0 4px rgba(255,164,23,0.18);
}

/* Presets */
.calc-presets {
  display: flex; gap: 6px; margin-top: var(--sp-3); flex-wrap: wrap;
}
.calc-preset {
  padding: 5px 11px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  color: var(--c-text-soft);
  font-size: 0.72rem;
  font-weight: var(--fw-bold);
  cursor: pointer;
  transition: all var(--t-fast);
  font-family: var(--ff-body);
}
.calc-preset:hover { background: rgba(255,164,23,0.10); color: var(--c-accent); border-color: rgba(255,164,23,0.3); }
.calc-preset.is-active {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: var(--c-accent-ink);
}

.calc__viz {
  display: grid; gap: var(--sp-4);
}
.calc__chart {
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  padding: var(--sp-4);
  position: relative;
}
.calc__chart svg { width: 100%; height: 180px; display: block; }
.calc__chart-legend {
  display: flex; flex-wrap: wrap; gap: var(--sp-4); margin-top: var(--sp-2);
  font-size: var(--fs-micro);
}
.calc__chart-legend span { display: inline-flex; align-items: center; gap: var(--sp-2); color: var(--c-text-muted); }
.calc__chart-legend span::before {
  content: ""; width: 10px; height: 10px; border-radius: 2px; background: var(--legend-color, var(--c-accent));
}

.calc__cards {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3);
}

/* Mega bloque "Diferencia a tu favor" — protagonista de la calculadora */
.calc__hero-diff {
  margin-top: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  background: linear-gradient(135deg, #ffb840 0%, var(--c-accent) 45%, #ff8a00 100%);
  color: var(--c-accent-ink);
  border-radius: var(--r-md);
  display: grid; grid-template-columns: minmax(0,1.4fr) minmax(0,1fr);
  gap: var(--sp-5); align-items: center;
  box-shadow: 0 14px 40px rgba(255,164,23,0.35), inset 0 1px 0 rgba(255,255,255,0.3);
  position: relative; overflow: hidden;
  min-height: 120px;
}
.calc__hero-diff-label {
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  position: relative;
}
.calc__hero-diff-amount {
  font-family: var(--ff-display);
  font-size: clamp(1.8rem, 3.8vw, 2.8rem);
  font-weight: var(--fw-bold);
  line-height: 1.05;
  margin-top: 6px;
  letter-spacing: -0.03em;
  position: relative;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.calc__hero-diff-desc {
  font-weight: var(--fw-semi);
  font-size: 0.92rem;
  max-width: 22ch;
  position: relative;
  text-align: right;
}
@media (max-width: 720px) {
  .calc__hero-diff { grid-template-columns: 1fr; }
  .calc__hero-diff-desc { text-align: left; }
}
.calc-card {
  padding: var(--sp-4);
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--c-border);
}
.calc-card--accent {
  background: linear-gradient(180deg, rgba(255,164,23,0.10), transparent 80%);
  border-color: rgba(255,164,23,0.35);
}
.calc-card--diff {
  background: var(--c-accent);
  color: var(--c-accent-ink);
  border-color: var(--c-accent);
}
.calc-card__tag { font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: var(--fw-bold); color: var(--c-text-muted); }
.calc-card--accent .calc-card__tag { color: var(--c-accent); }
.calc-card--diff .calc-card__tag { color: var(--c-accent-ink); }
.calc-card__amount {
  font-family: var(--ff-display);
  font-size: 1.5rem;
  font-weight: var(--fw-bold);
  color: var(--c-text);
  margin-top: 4px;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.calc-card--diff .calc-card__amount { color: var(--c-accent-ink); }
.calc-card__note { color: var(--c-text-muted); margin-top: 2px; font-size: 0.72rem; }
.calc-card--diff .calc-card__note { color: rgba(10,10,10,0.7); font-weight: var(--fw-semi); }

.calc__disclaimer { margin-top: var(--sp-4); font-size: 0.72rem; }
.calc__cta { margin-top: var(--sp-5); text-align: center; position: relative; }

@media (max-width: 880px) {
  .calc__layout { grid-template-columns: 1fr; }
  .calc__cards { grid-template-columns: 1fr; }
}

/* ============================================================
   INTRO PILLARS
   ============================================================ */
.intro { text-align: center; }
.intro__body { max-width: 900px; margin: 0 auto; font-size: 1.08rem; color: var(--c-text-soft); line-height: var(--lh-loose); }
.intro__pillars {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5);
  margin-top: var(--sp-7);
  text-align: center;
}
.pillar {
  padding: var(--sp-6);
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.pillar::after {
  content: ""; position: absolute; left: 50%; top: -1px;
  width: 60px; height: 3px; transform: translateX(-50%);
  background: var(--c-accent);
  border-radius: 0 0 4px 4px;
}
.pillar__num { font-family: var(--ff-display); font-size: 3rem; font-weight: var(--fw-bold); color: var(--c-accent); line-height: 1; letter-spacing: -0.02em; }
.pillar__text { margin-top: var(--sp-3); color: var(--c-text-soft); font-size: var(--fs-small); }
@media (max-width: 880px) { .intro__pillars { grid-template-columns: 1fr 1fr; } }

/* ============================================================
   TEMARIO — módulos con icono temático + número overlay
   ============================================================ */
.curriculum__list {
  display: grid; gap: var(--sp-5);
  margin-top: var(--sp-7);
  grid-template-columns: 1fr 1fr;
}
.module {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  position: relative;
  transition: transform var(--t-base), border-color var(--t-base);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.module:hover { transform: translateY(-3px); border-color: var(--c-accent); }
.module::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--c-accent);
  opacity: 0; transition: opacity var(--t-base);
}
.module:hover::before { opacity: 1; }

.module__head {
  display: grid; grid-template-columns: auto 1fr auto; gap: var(--sp-5);
  align-items: center;
  margin-bottom: var(--sp-5);
}
.module__icon {
  width: 64px; height: 64px;
  background: rgba(255,164,23,0.10);
  border: 1px solid rgba(255,164,23,0.3);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  color: var(--c-accent);
}
.module__icon svg { width: 30px; height: 30px; stroke-width: 1.6; }
.module__meta { min-width: 0; }
.module__eyebrow {
  font-family: var(--ff-body);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.module__title { font-size: 1.18rem; color: var(--c-text); margin-top: 2px; line-height: 1.25; }
.module__big-num {
  font-family: var(--ff-display);
  font-size: 2.6rem;
  font-weight: var(--fw-bold);
  color: rgba(255,164,23,0.15);
  line-height: 1;
  letter-spacing: -0.04em;
}
.module__desc { color: var(--c-text-soft); font-size: var(--fs-small); margin-bottom: var(--sp-5); line-height: var(--lh-normal); padding-bottom: var(--sp-5); border-bottom: 1px solid var(--c-border); }
.module__sales { font-size: 0.78rem; font-weight: var(--fw-bold); margin-bottom: var(--sp-3); color: var(--c-text); text-transform: uppercase; letter-spacing: 0.1em; }
.module__bullets { display: grid; gap: var(--sp-3); color: var(--c-text-soft); font-size: var(--fs-small); margin-bottom: var(--sp-5); }
.module__bullets li {
  padding-left: 26px;
  position: relative;
  line-height: var(--lh-normal);
}
.module__bullets li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.18em;
  width: 16px; height: 16px;
  border-radius: 4px;
  background: var(--c-accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a0a0a' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-position: center;
  background-repeat: no-repeat;
}
.module__expert {
  margin-top: auto;
  padding: var(--sp-4);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-small);
  color: var(--c-text-soft);
  display: flex; align-items: center; gap: var(--sp-3);
  line-height: 1.35;
}
.module__expert-avatar {
  width: 52px; height: 52px;
  border-radius: 10px;
  background-size: cover;
  background-position: center top;
  border: 1.5px solid var(--c-accent);
  flex-shrink: 0;
  background-color: var(--c-bg-elevated);
  box-shadow: 0 4px 14px rgba(0,0,0,0.4);
}
.module__expert-label {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent);
  font-weight: var(--fw-bold);
  margin-bottom: 2px;
}
.module__expert strong { color: var(--c-text); font-weight: var(--fw-bold); font-size: 0.98rem; }
.module__expert-desc { font-size: 0.82rem; color: var(--c-text-muted); margin-top: 2px; }

.curriculum__foot { text-align: center; margin-top: var(--sp-7); font-size: 1rem; color: var(--c-text-soft); }

@media (max-width: 920px) { .curriculum__list { grid-template-columns: 1fr; } }

/* ---------- Curriculum: divider entre fases del temario ---------- */
.curriculum__divider {
  display: flex; align-items: center; gap: var(--sp-5);
  margin: var(--sp-7) auto;
  max-width: 880px;
}
.curriculum__divider-line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,164,23,0.4), transparent);
}
.curriculum__divider-text {
  font-family: var(--ff-display);
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .curriculum__divider { gap: var(--sp-3); margin: var(--sp-5) auto; }
  .curriculum__divider-text { font-size: 0.92rem; }
}

/* ---------- Masterclass cards (variante visual) ---------- */
.module--masterclass {
  background: linear-gradient(135deg, rgba(255,164,23,0.06) 0%, rgba(255,164,23,0.02) 100%);
  border: 1px solid rgba(255,164,23,0.3);
  position: relative;
}
.module--masterclass:hover { border-color: rgba(255,164,23,0.6); }
.module--masterclass::after {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-accent) 0%, #ff8a00 100%);
  border-top-left-radius: var(--r-lg);
  border-top-right-radius: var(--r-lg);
}
.module__eyebrow--mc {
  color: var(--c-accent) !important;
  letter-spacing: 0.14em !important;
}
.module__icon--mc {
  background: var(--c-accent);
  color: var(--c-accent-ink);
}
.module__mc-intro {
  font-family: var(--ff-body);
  font-size: 0.96rem;
  font-weight: var(--fw-medium);
  color: var(--c-text-soft);
  line-height: var(--lh-loose);
  font-style: italic;
  margin: 0 0 var(--sp-4);
}

/* ---------- Disclaimer accordion (Terminos y condiciones) ---------- */
.disclaimer-accordion {
  max-width: 900px;
  margin: 0 auto var(--sp-6);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.02);
  overflow: hidden;
}
.disclaimer-accordion[open] { background: rgba(255,255,255,0.025); }
.disclaimer-accordion summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  font-family: var(--ff-display);
  font-weight: var(--fw-semi);
  font-size: 0.95rem;
  color: var(--c-text-soft);
  letter-spacing: 0.01em;
  user-select: none;
  transition: color var(--t-fast);
}
.disclaimer-accordion summary::-webkit-details-marker { display: none; }
.disclaimer-accordion summary::marker { display: none; }
.disclaimer-accordion summary:hover { color: var(--c-text); }
.disclaimer-accordion__chev {
  flex-shrink: 0;
  color: var(--c-text-muted);
  transition: transform var(--t-base);
}
.disclaimer-accordion[open] .disclaimer-accordion__chev { transform: rotate(180deg); color: var(--c-accent); }
.disclaimer-accordion__body {
  padding: 0 var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--c-border);
}
.disclaimer-accordion__body p {
  font-size: 0.82rem;
  line-height: var(--lh-loose);
  color: var(--c-text-muted);
  margin: var(--sp-4) 0 0;
}
.disclaimer-accordion__body p:first-child { margin-top: var(--sp-5); }
.disclaimer-accordion__body strong { color: var(--c-text-soft); font-weight: var(--fw-semi); }

/* ============================================================
   EXPERTOS — slider cinematográfico (1 protagonista a la vez)
   ============================================================ */
.experts { position: relative; overflow: hidden; }
.experts .section-head h2 { font-size: clamp(1.6rem, 2.6vw, 2.3rem); }

.experts-slider { margin-top: var(--sp-7); position: relative; }
.experts-slider__stage {
  background: rgba(255,255,255,0.035);
  backdrop-filter: blur(20px) saturate(120%);
  -webkit-backdrop-filter: blur(20px) saturate(120%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-xl);
  padding: clamp(1.5rem, 3vw, 3rem);
  position: relative;
  overflow: hidden;
}
.experts-slider__stage::before {
  content: ""; position: absolute;
  inset: -80px auto auto -80px;
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(255,164,23,0.20), transparent 70%);
  filter: blur(30px); pointer-events: none;
}

.expert-slide {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: center;
  position: relative;
}
.expert-slide[hidden] { display: none; }

.expert-slide__counter {
  display: inline-flex; align-items: center; gap: var(--sp-3);
  font-family: var(--ff-display);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  margin-bottom: var(--sp-5);
}
.expert-slide__counter b { font-size: 1.5rem; font-weight: var(--fw-bold); color: var(--c-text); }
.expert-slide__counter span { color: var(--c-text-muted); }

.expert-slide__name {
  font-family: var(--ff-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: var(--fw-bold);
  color: var(--c-text);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin-bottom: var(--sp-3);
}
.expert-slide__role {
  display: inline-block;
  padding: 5px 14px;
  border-radius: var(--r-full);
  background: rgba(255,164,23,0.12);
  border: 1px solid rgba(255,164,23,0.3);
  color: var(--c-accent);
  font-size: 0.72rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: var(--sp-5);
}
.expert-slide__bio {
  font-size: 1.04rem;
  color: var(--c-text-soft);
  line-height: var(--lh-loose);
  margin-bottom: var(--sp-5);
}
.expert-slide__module {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: var(--fs-small);
}
.expert-slide__module-tag {
  padding: 3px 9px;
  background: var(--c-accent);
  color: var(--c-accent-ink);
  border-radius: var(--r-sm);
  font-family: var(--ff-display);
  font-size: 0.72rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.expert-slide__module-text { color: var(--c-text-soft); }
.expert-slide__module-text strong { color: var(--c-text); }

.expert-slide__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-bg-elevated);
  box-shadow: 0 30px 70px rgba(0,0,0,0.5);
}
.expert-slide__photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.expert-slide__photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.4));
  pointer-events: none;
}
.expert-slide__photo-badge {
  position: absolute; left: var(--sp-4); bottom: var(--sp-4);
  z-index: 1;
  padding: 6px 14px;
  background: rgba(255,164,23,0.95);
  color: var(--c-accent-ink);
  border-radius: var(--r-full);
  font-size: 0.7rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

/* Nav arrows */
.experts-slider__nav {
  display: flex; gap: var(--sp-3); justify-content: center;
  margin-top: var(--sp-5);
}
.experts-slider__btn {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  color: var(--c-text);
  cursor: pointer;
  display: grid; place-items: center;
  transition: all var(--t-fast);
}
.experts-slider__btn:hover { background: var(--c-accent); color: var(--c-accent-ink); border-color: var(--c-accent); }
.experts-slider__btn svg { width: 18px; height: 18px; }

/* Thumb strip */
.experts-slider__thumbs {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
  gap: var(--sp-2);
  margin-top: var(--sp-5);
}
.experts-slider__thumb {
  aspect-ratio: 1;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 2px solid transparent;
  opacity: 0.5;
  cursor: pointer;
  transition: all var(--t-fast);
  background: var(--c-bg-elevated);
  padding: 0;
}
.experts-slider__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.experts-slider__thumb:hover { opacity: 0.85; transform: translateY(-2px); }
.experts-slider__thumb.is-active {
  opacity: 1;
  border-color: var(--c-accent);
  box-shadow: 0 6px 20px rgba(255,164,23,0.3);
}

@media (max-width: 880px) {
  .expert-slide { grid-template-columns: 1fr; gap: var(--sp-5); }
  .expert-slide__photo { max-width: 380px; margin-inline: auto; }
  .experts-slider__thumbs { grid-template-columns: repeat(5, 1fr); }
}

/* ============================================================
   TOOLS · cards con número overlay + icon line-art (patrón K7)
   ============================================================ */
.tools__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-5);
  margin-top: var(--sp-7);
}
.tool {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  padding: var(--sp-7);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.tool::after {
  content: ""; position: absolute;
  inset: -50px auto auto -50px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(255,164,23,0.14), transparent 70%);
  filter: blur(30px); pointer-events: none;
}
.tool__num-overlay {
  position: absolute; top: var(--sp-5); right: var(--sp-5);
  width: 44px; height: 44px;
  background: var(--c-accent); color: var(--c-accent-ink);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--ff-display); font-weight: var(--fw-bold); font-size: 0.95rem;
  letter-spacing: -0.02em;
  z-index: 1;
}
.tool__icon {
  width: 64px; height: 64px;
  background: rgba(255,164,23,0.08);
  border: 1px solid rgba(255,164,23,0.3);
  border-radius: var(--r-md);
  display: grid; place-items: center;
  color: var(--c-accent);
  margin-bottom: var(--sp-5);
  position: relative;
}
.tool__icon svg { width: 30px; height: 30px; stroke-width: 1.6; }
.tool__name { font-size: 1.3rem; color: var(--c-text); }
.tool__tagline { color: var(--c-accent); font-weight: var(--fw-bold); font-size: var(--fs-small); margin-top: var(--sp-1); margin-bottom: var(--sp-3); }
.tool__desc { color: var(--c-text-soft); font-size: var(--fs-small); line-height: var(--lh-loose); }
@media (max-width: 880px) { .tools__grid { grid-template-columns: 1fr; } }

/* ============================================================
   TESTIMONIOS
   ============================================================ */
/* Wrap del carrusel */
.testimonials-wrap {
  margin-top: var(--sp-7);
  position: relative;
}

/* Viewport (overflow: hidden, oculta cards fuera del marco) */
.testimonials-viewport {
  overflow: hidden;
  padding-block: var(--sp-3);
}

/* Track con flex y translateX controlado por JS */
.testimonials-track {
  display: flex;
  gap: var(--sp-5);
  transition: transform 0.45s cubic-bezier(.22,.7,.27,1);
  will-change: transform;
}
.testimonials-track > .testimonial {
  flex: 0 0 calc((100% - 2 * var(--sp-5)) / 3);
}
@media (max-width: 880px) {
  .testimonials-track > .testimonial { flex: 0 0 100%; }
  .testimonials-wrap { margin-top: var(--sp-5); }
  .testimonials .section-head { margin-bottom: var(--sp-4); }
}

/* Nav arrows */
.testimonials-nav {
  display: flex;
  justify-content: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}
.testimonials-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  color: var(--c-text);
  cursor: pointer;
  display: grid; place-items: center;
  transition: all var(--t-fast);
}
.testimonials-btn:hover {
  background: var(--c-accent);
  color: var(--c-accent-ink);
  border-color: var(--c-accent);
}
.testimonials-btn svg { width: 18px; height: 18px; }
.testimonials-btn:disabled,
.testimonials-btn.is-disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }

.testimonial {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-7);
  scroll-snap-align: start;
  min-width: 0;
  transition: transform var(--t-base), border-color var(--t-base);
}
.testimonial:hover { transform: translateY(-3px); border-color: rgba(255,164,23,0.4); }

.testimonial::before {
  content: "\201C";
  font-family: var(--ff-display);
  font-size: 4rem;
  line-height: 0.6;
  color: var(--c-accent);
  display: block;
  margin-bottom: var(--sp-4);
}
.testimonial__quote { font-size: 1rem; line-height: var(--lh-loose); color: var(--c-text-soft); font-style: italic; }
.testimonial__author {
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--c-border);
  display: flex; gap: var(--sp-3); align-items: center;
  font-size: var(--fs-small);
}
.testimonial__avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  flex: 0 0 44px;
  background-color: var(--c-bg-elevated);
  background-size: cover;
  background-position: center;
  border: 1.5px solid var(--c-accent);
}
.testimonial__name { font-weight: var(--fw-bold); color: var(--c-text); }
.testimonial__role { color: var(--c-text-muted); font-size: var(--fs-micro); }

/* ============================================================
   VALUE STACK (split: mockup STICKY izq + lista der con precios tachados)
   ============================================================ */
.stack-split {
  display: grid; grid-template-columns: 1fr 1.05fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
  margin-top: var(--sp-7);
}
.stack-split__visual-wrap {
  position: sticky;
  top: 110px; /* compensa urgency-bar (~38px) + breathing */
  align-self: start;
}
.stack-split__visual {
  position: relative;
  display: grid; place-items: center;
  max-width: 480px;
  margin-inline: auto;
  padding-block: var(--sp-5);
}
/* Círculo CSS eliminado — el mockup ya lo incluye en la propia imagen */
.stack-split__visual > img {
  position: relative; z-index: 1;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 580px;
  object-fit: contain;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.6));
}
@media (max-width: 880px) {
  .stack-split { grid-template-columns: 1fr; }
  .stack-split__visual-wrap { position: static; }
  .stack-split__visual { max-width: 360px; margin-inline: auto; }
}
.stack-table__inner {
  background: var(--c-bg-card);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-border);
  overflow: hidden;
  margin: 0;
}
.stack-row {
  display: grid;
  grid-template-columns: 1fr auto;
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--c-border);
  align-items: center;
  gap: var(--sp-4);
}
.stack-row:last-child { border-bottom: none; }
.stack-row__label { font-weight: var(--fw-medium); color: var(--c-text-soft); }
.stack-row__value {
  font-weight: var(--fw-bold);
  color: var(--c-text-muted);
  white-space: nowrap;
  text-decoration: line-through;
  text-decoration-thickness: 1.5px;
  text-decoration-color: rgba(255,255,255,0.35);
}
.stack-row--total { background: rgba(255,255,255,0.04); padding-block: var(--sp-6); }
.stack-row--total .stack-row__label { font-family: var(--ff-display); font-weight: var(--fw-bold); font-size: 1rem; color: var(--c-text); letter-spacing: 0.08em; text-transform: uppercase; }
.stack-row--total .stack-row__value {
  color: var(--c-text);
  font-family: var(--ff-display);
  font-size: 1.4rem;
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: var(--c-danger);
}

/* PRICE REVEAL — bloque final que destaca el precio real */
.price-reveal {
  margin-top: var(--sp-4);
  padding: var(--sp-6) var(--sp-7);
  background: linear-gradient(135deg, #ffb840 0%, var(--c-accent) 45%, #ff8a00 100%);
  color: var(--c-accent-ink);
  border-radius: var(--r-lg);
  text-align: center;
  box-shadow: 0 14px 40px rgba(255,164,23,0.35), inset 0 1px 0 rgba(255,255,255,0.3);
  position: relative;
  overflow: hidden;
}
.price-reveal__label {
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  position: relative;
  margin-bottom: var(--sp-2);
}
.price-reveal__amount {
  font-family: var(--ff-display);
  font-size: clamp(2.6rem, 5vw, 3.6rem);
  font-weight: var(--fw-bold);
  line-height: 1;
  letter-spacing: -0.03em;
  position: relative;
}
.price-reveal__from { font-weight: var(--fw-bold); font-size: 1.1rem; vertical-align: middle; margin-right: 0.25rem; }
.price-reveal__premium {
  margin-top: var(--sp-3);
  font-size: 0.95rem;
  font-weight: var(--fw-semi);
  position: relative;
}
.price-reveal__cta { margin-top: var(--sp-5); position: relative; }
.price-reveal__cta .btn {
  background: var(--c-accent-ink);
  color: var(--c-accent);
  padding: 1rem 1.8rem;
  font-size: 0.92rem;
}
.price-reveal__cta .btn:hover { background: #1a1a1a; color: var(--c-accent); transform: translateY(-2px); }

/* Product mockup en final CTA — video loop sin interacción */
.product-mockup {
  max-width: 980px;
  margin: var(--sp-9) auto 0;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--c-border);
  position: relative;
}
.product-mockup__video {
  width: 100%;
  height: auto;
  display: block;
  /* Bloquear cualquier interacción: click izquierdo, derecho, drag, selección */
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-user-drag: none;
}

/* ============================================================
   PRICING
   ============================================================ */
.pricing__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); margin-top: var(--sp-7); }

/* Pricing H2 destacado */
.pricing .section-head h2 {
  font-size: clamp(2.2rem, 3.2vw, 3.4rem);
  font-weight: var(--fw-bold);
  letter-spacing: -0.018em;
  line-height: 1.15;
  max-width: 1100px;
}
.pricing .section-head h2 .hl { font-weight: var(--fw-bold); }
.pricing .section-head p { margin-top: var(--sp-4); font-size: 1rem; max-width: 800px; }

/* Pricing single = layout 1 plan (mockup izq STICKY + card der STICKY) */
.pricing-single {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(2rem, 5vw, 4rem);
  margin-top: var(--sp-7);
  max-width: 1080px;
  margin-inline: auto;
}
.pricing-single__visual {
  position: relative;
}
.pricing-single__visual img {
  display: block;
  margin: 0 auto;
  max-width: 100%;
  max-height: 520px;
  width: auto;
  height: auto;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,0.6));
  position: sticky;
  top: 120px;
}
.pricing-single__plan {
  margin: 0;
  position: sticky;
  top: 110px;
  align-self: start;
}
@media (max-width: 880px) {
  .pricing-single { grid-template-columns: 1fr; }
  .pricing-single__visual img,
  .pricing-single__plan { position: static; top: auto; }
  .pricing-single__visual img { max-height: 380px; }
}
.plan__lead {
  font-size: 0.78rem;
  color: var(--c-text-muted);
  margin-bottom: var(--sp-2);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: var(--fw-bold);
}

/* Bloque de financiación SeQura */
.finance {
  margin-top: var(--sp-5);
  padding: var(--sp-5);
  border: 1px solid rgba(255,164,23,0.3);
  background: rgba(255,164,23,0.04);
  border-radius: var(--r-md);
}
.finance__label {
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  margin-bottom: var(--sp-4);
}
.finance__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3);
}
.finance__opt {
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
  padding: var(--sp-3);
  background: rgba(0,0,0,0.28);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
}
.finance__opt-label {
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-text-muted);
  font-weight: var(--fw-bold);
}
.finance__opt-val {
  font-family: var(--ff-display);
  font-size: 1.15rem;
  font-weight: var(--fw-bold);
  color: var(--c-text);
  margin-top: 4px;
  letter-spacing: -0.01em;
}
.finance__foot {
  margin-top: var(--sp-3);
  font-size: 0.74rem;
  color: var(--c-text-muted);
  text-align: center;
}
.plan {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-7);
  display: flex; flex-direction: column; gap: var(--sp-5);
  position: relative;
}
.plan--featured {
  border: 2px solid var(--c-accent);
  background: linear-gradient(180deg, rgba(255,164,23,0.08), transparent 30%), var(--c-bg-card);
  box-shadow: var(--shadow-orange);
}
.plan__badge {
  position: absolute; top: -14px; left: 50%;
  transform: translateX(-50%);
  background: var(--c-accent);
  color: var(--c-accent-ink);
  padding: 5px 16px;
  border-radius: var(--r-full);
  font-size: 0.68rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.plan__name { font-size: 1.4rem; color: var(--c-text); }
.plan__price { font-family: var(--ff-display); font-size: clamp(2.2rem, 3.6vw, 2.8rem); font-weight: var(--fw-bold); line-height: 1; color: var(--c-text); letter-spacing: -0.02em; }
.plan__features { display: grid; gap: var(--sp-3); }
.plan__features li {
  position: relative;
  padding-left: 30px;
  font-size: var(--fs-small);
  color: var(--c-text-soft);
  line-height: var(--lh-normal);
}
.plan__features li::before {
  content: "";
  position: absolute;
  left: 0; top: 3px;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--c-accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a0a0a' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-position: center;
  background-repeat: no-repeat;
}
.plan__features li em { font-style: italic; opacity: 0.8; }
.plan__foot { font-size: var(--fs-small); color: var(--c-text-muted); margin-top: var(--sp-2); text-align: center; }
.pricing__micro { text-align: center; margin-top: var(--sp-6); }
@media (max-width: 880px) { .pricing__grid { grid-template-columns: 1fr; } }

/* ============================================================
   GARANTÍA
   ============================================================ */
.guarantee__inner {
  display: grid; grid-template-columns: 280px 1fr;
  gap: var(--sp-7); align-items: center;
  max-width: 880px; margin-inline: auto;
}
.guarantee__seal {
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  position: relative;
  filter: drop-shadow(0 12px 30px rgba(255,164,23,0.35));
}
.guarantee__seal::before {
  content: ""; position: absolute;
  inset: 10%;
  background: radial-gradient(circle, rgba(255,164,23,0.35), transparent 65%);
  filter: blur(30px);
  z-index: 0;
  pointer-events: none;
}
.guarantee__seal img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: auto;
  object-fit: contain;
}
.guarantee__text { font-size: 1.05rem; line-height: var(--lh-loose); color: var(--c-text-soft); }

/* CTA WhatsApp */
.whatsapp-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  padding: 0.85rem 1.4rem;
  background: #25D366;
  color: #0a0a0a;
  font-weight: var(--fw-bold);
  font-size: 0.92rem;
  letter-spacing: 0.02em;
  border-radius: var(--r-full);
  text-decoration: none;
  transition: transform var(--t-fast), box-shadow var(--t-base), background var(--t-fast);
  box-shadow: 0 8px 24px rgba(37,211,102,0.35);
}
.whatsapp-cta:hover { transform: translateY(-2px); background: #20bd5a; box-shadow: 0 12px 30px rgba(37,211,102,0.45); }
.whatsapp-cta svg { flex-shrink: 0; }
@media (max-width: 720px) {
  .guarantee__inner { grid-template-columns: 1fr; text-align: center; }
  .guarantee__seal { width: 220px; margin-inline: auto; }
}

/* ============================================================
   FITNESS (sí/no)
   ============================================================ */
.fitness__table {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  max-width: 920px; margin: var(--sp-7) auto 0;
  border-radius: var(--r-lg); overflow: hidden;
  border: 1px solid var(--c-border);
}
.fit-col { padding: var(--sp-6) var(--sp-6) var(--sp-7); background: var(--c-bg-card); }
.fit-col + .fit-col { border-left: 1px solid var(--c-border); }
.fit-col__head { font-size: 1.1rem; font-weight: var(--fw-bold); padding-bottom: var(--sp-4); margin-bottom: var(--sp-4); border-bottom: 1px solid var(--c-border); color: var(--c-text); display: flex; align-items: center; gap: var(--sp-3); }
.fit-col__head-icon {
  width: 32px; height: 32px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: var(--fw-bold);
  font-size: 1.05rem;
  flex-shrink: 0;
}
.fit-col--yes .fit-col__head { color: var(--c-success); }
.fit-col--yes .fit-col__head-icon { background: rgba(74,222,128,0.15); color: var(--c-success); }
.fit-col--no .fit-col__head  { color: var(--c-danger); }
.fit-col--no .fit-col__head-icon  { background: rgba(248,113,113,0.15); color: var(--c-danger); }
.fit-col ul { display: grid; gap: var(--sp-4); }
.fit-col li { font-size: var(--fs-small); color: var(--c-text-soft); line-height: var(--lh-loose); padding-left: 1.6rem; position: relative; }
.fit-col--yes li::before { content: "✓"; position: absolute; left: 0; color: var(--c-success); font-weight: var(--fw-bold); }
.fit-col--no li::before  { content: "✕"; position: absolute; left: 0; color: var(--c-danger);  font-weight: var(--fw-bold); }
@media (max-width: 720px) {
  .fitness__table { grid-template-columns: 1fr; }
  .fit-col + .fit-col { border-left: none; border-top: 1px solid var(--c-border); }
}

/* ============================================================
   FAQ
   ============================================================ */
.section.faq { padding-top: calc(var(--section-py) + var(--sp-6)); }
.faq__list {
  max-width: 820px; margin: var(--sp-7) auto 0;
  display: grid; gap: 0;
  border-top: 1px solid var(--c-border);
}
.faq-item { border-bottom: 1px solid var(--c-border); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--sp-5) 0;
  font-weight: var(--fw-semi);
  color: var(--c-text);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--sp-4);
  transition: color var(--t-fast);
}
.faq-item summary:hover { color: var(--c-accent); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  color: var(--c-accent);
  font-size: 1.5rem; line-height: 1;
  transition: transform var(--t-fast);
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,164,23,0.10);
  display: grid; place-items: center;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item__body {
  padding-bottom: var(--sp-5);
  color: var(--c-text-soft);
  line-height: var(--lh-loose);
}

/* ============================================================
   BANNER CTA NARANJA
   ============================================================ */
.banner-cta {
  background: var(--c-accent);
  color: var(--c-accent-ink);
  padding: var(--sp-7) var(--gutter);
  position: relative;
  overflow: hidden;
}
.banner-cta__inner {
  max-width: var(--w-container); margin-inline: auto;
  display: grid; grid-template-columns: 1fr auto;
  gap: var(--sp-6); align-items: center;
  position: relative;
}
.banner-cta h3 { color: var(--c-accent-ink); font-size: 1.6rem; max-width: 30ch; line-height: 1.2; font-weight: var(--fw-bold); letter-spacing: -0.01em; }
.banner-cta p { color: rgba(10,10,10,0.7); margin-top: var(--sp-2); font-weight: var(--fw-medium); }
.banner-cta .btn--primary { background: var(--c-accent-ink); color: var(--c-accent); box-shadow: none; }
.banner-cta .btn--primary:hover { background: #1a1a1a; color: var(--c-accent); }
@media (max-width: 720px) { .banner-cta__inner { grid-template-columns: 1fr; } }

/* ============================================================
   FINAL CTA + posdatas
   ============================================================ */
.final-cta { position: relative; overflow: hidden; padding-block: clamp(4rem, 6vw, 6rem); }
.final-cta .section-head { margin-bottom: var(--sp-6); }
.final-cta .section-head h2 { font-size: clamp(2rem, 3.6vw, 3.2rem); font-weight: var(--fw-semi); }
.final-cta .section-head p { color: var(--c-text-soft); font-size: 1.05rem; }
.final-cta__cta { text-align: center; position: relative; }
.final-cta__cta .btn--mega {
  padding: 1.6rem 3.5rem;
  font-size: 1.15rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  position: relative;
  z-index: 1;
  animation: pulse-orange 2.4s ease-in-out infinite;
}
@keyframes pulse-orange {
  0%, 100% { box-shadow: 0 8px 28px rgba(255,164,23,0.35), 0 0 0 0 rgba(255,164,23,0.5); }
  50%      { box-shadow: 0 12px 36px rgba(255,164,23,0.45), 0 0 0 14px rgba(255,164,23,0); }
}
.final-cta__micro { text-align: center; margin-top: var(--sp-4); }

/* Closing note — frase única antes de la firma */
.closing-note {
  max-width: 640px;
  margin: var(--sp-8) auto 0;
  text-align: center;
}
.closing-note p {
  font-size: 1rem;
  line-height: var(--lh-loose);
  color: var(--c-text-soft);
}
.closing-note a { color: var(--c-accent); text-decoration: underline; text-underline-offset: 3px; }

/* Firma con foto pequeña */
.sig {
  margin-top: var(--sp-6);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-5) var(--sp-3) var(--sp-3);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: var(--r-full);
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.sig__photo {
  width: 52px; height: 52px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center top;
  border: 2px solid var(--c-accent);
  flex-shrink: 0;
}
.sig__name {
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  color: var(--c-text);
  font-size: 1.05rem;
}
.sig__role {
  font-size: var(--fs-micro);
  color: var(--c-text-muted);
  letter-spacing: 0.06em;
}

/* ============================================================
   SCROLL REVEAL — fade-up sutil al entrar en viewport
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.65s cubic-bezier(.2,.7,.3,1), transform 0.65s cubic-bezier(.2,.7,.3,1);
  will-change: opacity, transform;
}
.reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background: #050505;
  color: var(--c-text-muted);
  padding-block: var(--sp-8);
  font-size: var(--fs-small);
  line-height: var(--lh-loose);
  border-top: 1px solid var(--c-border);
  position: relative;
  z-index: 1;
}
.site-footer h4 { color: var(--c-text); font-size: 1rem; margin-bottom: var(--sp-3); font-weight: var(--fw-bold); }
.disclaimer { max-width: 920px; margin-inline: auto; }
.disclaimer p + p { margin-top: var(--sp-4); }
.disclaimer strong { color: var(--c-text); }
.footer-bottom {
  max-width: 920px; margin: var(--sp-6) auto 0;
  padding-top: var(--sp-5);
  border-top: 1px solid var(--c-border);
  display: flex; justify-content: space-between;
  flex-wrap: wrap; gap: var(--sp-3);
  font-size: var(--fs-micro); color: var(--c-text-muted);
}
.footer-bottom a { color: var(--c-text-soft); }
.footer-bottom a:hover { color: var(--c-accent); }

/* ============================================================
   VSL PLAYER — facade que carga iframe al click (lazy)
   ============================================================ */
.vsl-player {
  max-width: 980px;
  margin: var(--sp-7) auto 0;
  aspect-ratio: 16 / 9;
  border-radius: var(--r-lg);
  overflow: hidden;
  position: relative;
  cursor: pointer;
  background:
    radial-gradient(800px 500px at 30% 30%, rgba(255,164,23,0.18), transparent 60%),
    linear-gradient(135deg, #1a1410 0%, #0a0a0a 70%);
  border: 1px solid var(--c-border);
  box-shadow: var(--shadow-lg);
}
.vsl-player::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,164,23,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,164,23,0.05) 1px, transparent 1px);
  background-size: 50px 50px;
  mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, #000 40%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, #000 40%, transparent 100%);
  pointer-events: none;
}

/* Cuando el JS detectó thumbnail de YouTube → fondo con el frame del vídeo */
.vsl-player--has-thumb {
  background-image: var(--vsl-thumb);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.vsl-player--has-thumb::before {
  background-image: none;
  background: linear-gradient(180deg, rgba(0,0,0,0.20) 0%, rgba(0,0,0,0.10) 40%, rgba(0,0,0,0.65) 100%);
  mask-image: none; -webkit-mask-image: none;
  transition: background 0.3s ease;
}
.vsl-player--has-thumb:hover::before {
  background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.05) 40%, rgba(0,0,0,0.6) 100%);
}
.vsl-player--has-thumb .vsl-player__hint {
  color: rgba(255,255,255,0.95);
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.vsl-player__placeholder {
  position: absolute; inset: 0;
  display: grid; place-items: center; gap: var(--sp-3);
  z-index: 1;
  grid-auto-flow: row;
  grid-template-rows: 1fr auto;
  padding-bottom: var(--sp-6);
}
.vsl-player__placeholder > * { align-self: center; }
.vsl-player__play {
  width: 88px; height: 88px;
  border-radius: 50%;
  background: var(--c-accent);
  display: grid; place-items: center;
  transition: transform var(--t-base), box-shadow var(--t-base);
  box-shadow: 0 8px 32px rgba(255,164,23,0.45), inset 0 1px 0 rgba(255,255,255,0.3);
  color: var(--c-accent-ink);
}
.vsl-player:hover .vsl-player__play,
.vsl-player:focus .vsl-player__play {
  transform: scale(1.08);
  box-shadow: 0 14px 40px rgba(255,164,23,0.55);
}
.vsl-player__play svg { width: 30px; height: 30px; margin-left: 5px; }
.vsl-player__hint {
  font-size: 0.85rem;
  color: var(--c-text-soft);
  letter-spacing: 0.06em;
  font-weight: var(--fw-semi);
  align-self: end;
}
.vsl-player iframe { width: 100%; height: 100%; border: 0; display: block; position: relative; z-index: 2; }
@media (max-width: 720px) {
  .vsl-player__play { width: 64px; height: 64px; }
  .vsl-player__play svg { width: 22px; height: 22px; }
}

/* ============================================================
   HOVER INVERT — tools, pillars, press-cards, plan base
   (módulos y testimonios mantienen su hover sutil original)
   ============================================================ */
.tool,
.pillar,
.press-card,
.plan:not(.plan--featured) {
  transition:
    background var(--t-base),
    border-color var(--t-base),
    color var(--t-base),
    transform var(--t-base),
    box-shadow var(--t-base);
}

.tool:hover,
.pillar:hover,
.press-card:hover,
.plan:not(.plan--featured):hover {
  background: var(--c-accent) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: var(--c-accent) !important;
  color: var(--c-accent-ink);
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(255,164,23,0.25);
}

/* TOOL hover internals */
.tool:hover .tool__name { color: var(--c-accent-ink); }
.tool:hover .tool__tagline { color: rgba(10,10,10,0.85); }
.tool:hover .tool__desc { color: rgba(10,10,10,0.75); }
.tool:hover .tool__icon {
  background: rgba(10,10,10,0.12);
  border-color: rgba(10,10,10,0.2);
  color: var(--c-accent-ink);
}
.tool:hover .tool__num-overlay {
  background: rgba(10,10,10,0.85);
  color: var(--c-accent);
}
.tool:hover::after { display: none; }

/* PILLAR hover */
.pillar:hover .pillar__num { color: var(--c-accent-ink); }
.pillar:hover .pillar__text { color: rgba(10,10,10,0.78); }
.pillar:hover::after { background: rgba(10,10,10,0.6); }

/* PLAN BASE hover */
.plan:not(.plan--featured):hover .eyebrow { color: rgba(10,10,10,0.7); }
.plan:not(.plan--featured):hover .plan__name,
.plan:not(.plan--featured):hover .plan__price { color: var(--c-accent-ink); }
.plan:not(.plan--featured):hover .plan__features li { color: rgba(10,10,10,0.78); }
.plan:not(.plan--featured):hover .plan__features li::before {
  background: var(--c-accent-ink);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FFA417' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size: 11px;
  background-position: center;
  background-repeat: no-repeat;
}
.plan:not(.plan--featured):hover .plan__foot { color: rgba(10,10,10,0.6); }
.plan:not(.plan--featured):hover .btn--ghost {
  background: var(--c-accent-ink);
  color: var(--c-accent);
  border-color: var(--c-accent-ink);
}

/* Touch devices: desactivar hover */
@media (hover: none) {
  .tool:hover,
  .pillar:hover,
  .press-card:hover,
  .plan:not(.plan--featured):hover {
    background: rgba(255,255,255,0.035) !important;
    border-color: rgba(255,255,255,0.08) !important;
    color: var(--c-text-soft);
    transform: none;
    box-shadow: none;
  }
}

/* ============================================================
   MOBILE — ajustes responsive (≤ 768px y ≤ 480px)
   ============================================================ */
@media (max-width: 768px) {
  /* URGENCY BAR — compacta */
  .urgency-bar {
    font-size: 0.72rem;
    padding: 0.45rem var(--sp-3);
    gap: var(--sp-3);
    flex-wrap: nowrap;
    justify-content: space-between;
  }
  .urgency-bar > span:not(.urgency-bar__mini),
  .urgency-bar__dot { display: none; }
  .urgency-bar__mini { font-size: 0.78rem; padding: 3px 9px; flex-shrink: 0; }
  .urgency-bar a { white-space: nowrap; font-size: 0.74rem; }

  /* TOPBAR logo */
  .topbar { padding: var(--sp-5) var(--gutter); }
  .topbar__logo img { height: 36px; }

  /* HERO compacto */
  .hero { padding: var(--sp-5) 0 var(--sp-7); }
  .hero__head { padding-inline: 0; margin-bottom: var(--sp-6); }
  .hero__h1 { font-size: clamp(1.65rem, 6vw, 2.2rem); line-height: 1.18; }
  .hero__sub { font-size: 0.98rem; }
  .hero__card { padding: var(--sp-5); }
  .hero__bullets li { font-size: 0.88rem; }
  .eyebrow--pill { font-size: 0.66rem; padding: 0.55rem 1rem; letter-spacing: 0.14em; }

  /* SECCIONES — padding general más corto */
  .section { padding-block: var(--sp-8); }
  .section-head { margin-bottom: var(--sp-6); }
  .section-head h2 { font-size: clamp(1.6rem, 6vw, 2.2rem); }
  .split-head { gap: var(--sp-4); margin-bottom: var(--sp-6); }
  .split-head h2 { font-size: clamp(1.6rem, 6vw, 2.2rem); }

  /* FEATURE ROW — apilada */
  .feature-row { grid-template-columns: 1fr; gap: var(--sp-5); padding-block: var(--sp-7); }
  .icon-line--lg { width: 44px; height: 44px; }

  /* CALCULADORA */
  .calc-frame { padding: var(--sp-5); }
  .calc-frame__top { flex-wrap: wrap; gap: var(--sp-3); }
  .calc-frame__title strong { font-size: 0.85rem; }
  .calc__chart svg { height: 140px; }
  .calc-input__value { font-size: 1.15rem; width: 110px; }
  .calc-input { padding: var(--sp-3) var(--sp-4); }
  .calc-preset { font-size: 0.68rem; padding: 4px 9px; }
  .calc__hero-diff { padding: var(--sp-4) var(--sp-5); }
  .calc__hero-diff-amount { font-size: clamp(1.8rem, 8vw, 2.6rem); }

  /* INTRO PILLARS */
  .intro__pillars { grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
  .pillar { padding: var(--sp-5); }
  .pillar__num { font-size: 2.4rem; }

  /* TEMARIO — fix break de palabras y big-num */
  .module { padding: var(--sp-5); }
  .module__head { gap: var(--sp-3); margin-bottom: var(--sp-4); }
  .module__meta { min-width: 0; }
  .module__title {
    font-size: 1.05rem;
    word-break: keep-all;
    overflow-wrap: break-word;
    hyphens: none;
    line-height: 1.25;
  }
  .module__big-num { font-size: 1.8rem; }
  .module__icon { width: 48px; height: 48px; }
  .module__icon svg { width: 22px; height: 22px; }
  .module__bullets li, .module__desc { font-size: 0.88rem; }

  /* SLIDER EXPERTOS */
  .experts-slider__stage { padding: var(--sp-5); }
  .expert-slide { gap: var(--sp-5); }
  .expert-slide__counter b { font-size: 1.2rem; }
  .expert-slide__name { font-size: clamp(1.6rem, 7vw, 2.2rem); }
  .expert-slide__bio { font-size: 0.95rem; }
  .expert-slide__photo { max-width: 320px; margin-inline: auto; aspect-ratio: 4/5; }

  /* TOOLS */
  .tool { padding: var(--sp-5); }
  .tool__num-overlay { width: 36px; height: 36px; font-size: 0.85rem; top: var(--sp-4); right: var(--sp-4); }
  .tool__icon { width: 52px; height: 52px; }
  .tool__icon svg { width: 24px; height: 24px; }
  .tool__name { font-size: 1.15rem; }

  /* TESTIMONIOS */
  .testimonial { padding: var(--sp-5); }

  /* VALUE STACK — círculo naranja más pequeño */
  .stack-split { gap: var(--sp-5); }
  .stack-split__visual { max-width: 260px; margin-inline: auto; }
  .stack-table__inner { font-size: 0.88rem; }
  .stack-row { padding: var(--sp-4) var(--sp-5); }
  .stack-row--total .stack-row__label { font-size: 1rem; }
  .stack-row--total .stack-row__value { font-size: 1.25rem; }

  /* PRICING */
  .plan { padding: var(--sp-6); }
  .plan__price { font-size: 2.2rem; }

  /* GARANTÍA */
  .guarantee__seal { width: 140px; }
  .guarantee__seal .num { font-size: 2.6rem; }

  /* BANNER CTA naranja */
  .banner-cta { padding: var(--sp-6) var(--gutter); }
  .banner-cta h3 { font-size: 1.25rem; }

  /* CTA FINAL */
  .final-cta__cta .btn { padding: 1.1rem 1.6rem; font-size: 0.88rem; }
  .product-mockup { margin-top: var(--sp-6); }
  .closing-note { margin-top: var(--sp-5); }
  .sig { margin-top: var(--sp-5); }
  .posdatas { margin-top: var(--sp-6); }

  /* BOTONES móvil — permitir wrap, ajustar padding y tracking */
  .btn {
    white-space: normal;
    font-size: 0.82rem;
    padding: 0.95rem 1.3rem;
    line-height: 1.2;
    letter-spacing: 0.04em;
  }
  .btn--lg { font-size: 0.88rem; padding: 1.05rem 1.5rem; }
  .btn--xl { font-size: 0.92rem; padding: 1.15rem 1.6rem; }
  .btn--block { padding-inline: var(--sp-4); }
  .hero__card .btn,
  .plan .btn,
  .price-reveal__cta .btn,
  .calc__cta .btn { letter-spacing: 0.03em; }
  .posdatas { padding: var(--sp-5); }
  .posdatas p { font-size: 0.92rem; }

  /* FAQ */
  .faq-item summary { font-size: 0.95rem; padding: var(--sp-4) 0; }
  .faq-item__body { font-size: 0.92rem; }

  /* COUNTDOWN hero — más compacto */
  .countdown { padding: var(--sp-4) var(--sp-5); margin-top: var(--sp-5); }
  .countdown__num { font-size: 1.3rem; }

  /* HEADINGS dentro de cards no centrados */
  .stack-table__foot { text-align: center !important; }
}

@media (max-width: 480px) {
  .urgency-bar a { display: none; }
  .urgency-bar { justify-content: center; }
  .topbar__logo img { height: 32px; }
  .topbar { padding: var(--sp-4) var(--gutter); }

  .hero { padding: var(--sp-4) 0 var(--sp-6); }
  .hero__h1 { font-size: 1.55rem; }

  .calc-input__value { font-size: 1.05rem; width: 100px; }
  .calc-card__amount { font-size: 1.25rem; }
  .calc__hero-diff-amount { font-size: 2rem; }
  .calc__chart svg { height: 120px; }

  /* Pillars 1 col en pantallas mini */
  .intro__pillars { grid-template-columns: 1fr; }

  /* Slider expertos: thumbs scroll horizontal en muy pequeño */
  .experts-slider__thumbs {
    grid-template-columns: repeat(10, 60px);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: var(--sp-2);
    -webkit-overflow-scrolling: touch;
  }
  .experts-slider__thumb { scroll-snap-align: start; }

  /* Posdatas */
  .signature { font-size: 1.05rem; }

  /* Footer */
  .footer-bottom { justify-content: center; text-align: center; }
}

/* ============================================================
   COMMUNITY WhatsApp banner
   ============================================================ */
.community { padding-block: var(--sp-7); }
.community__card {
  display: grid;
  grid-template-columns: 64px 1fr auto;
  align-items: center;
  gap: clamp(1rem, 3vw, 2rem);
  padding: var(--sp-6) var(--sp-7);
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color: #fff;
  border-radius: var(--r-lg);
  text-decoration: none;
  box-shadow: 0 12px 36px rgba(37,211,102,0.25);
  transition: transform var(--t-base), box-shadow var(--t-base);
  max-width: 1080px;
  margin-inline: auto;
  position: relative;
  overflow: hidden;
}
.community__card::before {
  content: ""; position: absolute;
  top: -50%; right: -10%;
  width: 320px; height: 320px;
  background-image:
    linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  opacity: 0.5;
}
.community__card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 48px rgba(37,211,102,0.4);
}
.community__icon {
  width: 64px; height: 64px;
  background: rgba(255,255,255,0.18);
  border-radius: 50%;
  display: grid; place-items: center;
  color: #fff;
  position: relative;
}
.community__text { position: relative; }
.community__eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  opacity: 0.85;
  margin-bottom: 4px;
}
.community__title {
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  font-size: 1.25rem;
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin-bottom: 4px;
}
.community__desc { font-size: 0.92rem; opacity: 0.9; line-height: var(--lh-normal); }
.community__cta {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: 0.85rem 1.4rem;
  background: rgba(10,10,10,0.85);
  color: #fff;
  border-radius: var(--r-full);
  font-weight: var(--fw-bold);
  font-size: 0.88rem;
  letter-spacing: 0.03em;
  white-space: nowrap;
  transition: background var(--t-fast);
  position: relative;
}
.community__cta svg { width: 16px; height: 16px; }
.community__card:hover .community__cta { background: #000; }
@media (max-width: 768px) {
  .community__card {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    justify-items: center;
    text-align: center;
    padding: var(--sp-5);
    gap: var(--sp-4);
  }
  .community__icon { width: 56px; height: 56px; }
  .community__text { position: relative; }
  .community__cta { grid-column: 1 / -1; justify-content: center; }
  .community__title { font-size: 1.1rem; }
}

/* ============================================================
   WHATSAPP FLOATING BUTTON (estilo joinchat)
   ============================================================ */
.wa-float {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 90;
  display: inline-flex;
  align-items: center;
  background: #25D366;
  color: #fff;
  text-decoration: none;
  border-radius: 999px;
  box-shadow: 0 12px 32px rgba(37,211,102,0.35), 0 4px 12px rgba(0,0,0,0.35);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  isolation: isolate;
}
.wa-float__pulse {
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #25D366;
  z-index: -1;
  transform-origin: center;
  animation: wa-pulse 2.2s ease-out infinite;
}
@keyframes wa-pulse {
  0%   { transform: scale(1);    opacity: 0.55; }
  70%  { transform: scale(1.7);  opacity: 0; }
  100% { transform: scale(1.7);  opacity: 0; }
}
.wa-float__icon {
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: #fff;
}
.wa-float__label {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  white-space: nowrap;
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-width 0.35s ease, opacity 0.25s ease, padding-right 0.35s ease;
  padding-right: 0;
}
.wa-float:hover,
.wa-float:focus-visible {
  background: #1ebe5b;
  transform: translateY(-3px);
  box-shadow: 0 18px 44px rgba(37,211,102,0.55), 0 6px 16px rgba(0,0,0,0.4);
}
.wa-float:hover .wa-float__label,
.wa-float:focus-visible .wa-float__label {
  max-width: 220px;
  opacity: 1;
  padding-right: 22px;
}
@media (max-width: 768px) {
  .wa-float { bottom: 18px; right: 18px; }
  .wa-float__icon { width: 56px; height: 56px; }
  .wa-float__icon svg { width: 28px; height: 28px; }
  .wa-float__pulse { width: 56px; height: 56px; }
  .wa-float__label { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .wa-float__pulse { animation: none; opacity: 0; }
  .wa-float { transition: none; }
}

/* ============================================================
   OBJECIONES (reemplaza Feature row)
   ============================================================ */
.objections__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
}
.objection-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: border-color var(--t-base), transform var(--t-base);
}
.objection-card:hover {
  border-color: rgba(255,164,23,0.35);
  transform: translateY(-2px);
}
.objection-card__icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255,164,23,0.12);
  color: var(--c-accent);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.objection-card__objection {
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  color: var(--c-text);
  font-size: 0.98rem;
  line-height: 1.35;
  letter-spacing: -0.005em;
}
.objection-card__answer {
  font-size: 0.9rem;
  color: var(--c-text-soft);
  line-height: var(--lh-loose);
  margin: 0;
}
@media (max-width: 880px) {
  .objections__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 540px) {
  .objections__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   CHECKOUT MODAL (pre-form antes de Hotmart)
   ============================================================ */
.checkout-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  overflow-y: auto;
}
.checkout-modal.is-open {
  display: flex;
}
.checkout-modal__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.78);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  animation: cm-fade 0.25s ease-out;
  cursor: pointer;
}
.checkout-modal__panel {
  position: relative;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  max-width: 460px;
  width: 100%;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  z-index: 1;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,164,23,0.08);
  animation: cm-slide-up 0.32s cubic-bezier(0.16, 1, 0.3, 1);
  margin: auto;
}
.checkout-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--c-border);
  background: rgba(255,255,255,0.04);
  color: var(--c-text-muted);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.checkout-modal__close:hover {
  background: rgba(255,255,255,0.1);
  color: var(--c-text);
  border-color: rgba(255,164,23,0.3);
}
.checkout-modal__header {
  margin-bottom: var(--sp-5);
  text-align: center;
}
.checkout-modal__eyebrow {
  display: inline-block;
  color: var(--c-accent);
  font-family: var(--ff-body);
  font-weight: var(--fw-bold);
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: var(--sp-3);
}
.checkout-modal__header h3 {
  font-family: var(--ff-display);
  font-size: clamp(1.35rem, 2.5vw, 1.65rem);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--sp-2);
  line-height: 1.18;
  letter-spacing: -0.012em;
  color: var(--c-text);
}
.checkout-modal__header p {
  font-size: 0.9rem;
  color: var(--c-text-soft);
  margin: 0;
}
.checkout-form {
  display: grid;
  gap: var(--sp-4);
}
.checkout-form__field {
  display: grid;
  gap: 6px;
}
.checkout-form__field label {
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  color: var(--c-text-muted);
}
.checkout-form__field input,
.checkout-form__field select {
  font-family: var(--ff-body);
  font-size: 0.98rem;
  background: rgba(255,255,255,0.04);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: 8px;
  padding: 0.85rem 1rem;
  outline: none;
  transition: border-color 0.2s, background 0.2s;
  width: 100%;
}
.checkout-form__phone {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 8px;
}
/* Dropdown custom de prefijo con banderas */
.checkout-form__prefix-wrap { position: relative; }
.checkout-form__prefix-btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--c-border);
  border-radius: 8px;
  padding: 0.85rem 0.7rem 0.85rem 0.85rem;
  color: var(--c-text);
  font-family: var(--ff-body);
  font-size: 0.98rem;
  font-weight: var(--fw-semi);
  cursor: pointer;
  outline: none;
  transition: border-color 0.2s, background 0.2s;
}
.checkout-form__prefix-btn:hover { background: rgba(255,255,255,0.06); }
.checkout-form__prefix-btn[aria-expanded="true"],
.checkout-form__prefix-btn:focus { border-color: var(--c-accent); background: rgba(255,164,23,0.06); }
.checkout-form__prefix-flag {
  display: block;
  border-radius: 2px;
  flex-shrink: 0;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.08);
}
.checkout-form__prefix-label { flex: 1; text-align: left; }
.checkout-form__prefix-chev {
  color: var(--c-accent);
  flex-shrink: 0;
  transition: transform 0.2s;
}
.checkout-form__prefix-btn[aria-expanded="true"] .checkout-form__prefix-chev { transform: rotate(180deg); }
.checkout-form__prefix-list {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: 10;
  min-width: 260px;
  max-height: 280px;
  overflow-y: auto;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: 8px;
  box-shadow: 0 12px 36px rgba(0,0,0,0.5);
  margin: 0;
  padding: 4px 0;
  list-style: none;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,164,23,0.3) transparent;
}
.checkout-form__prefix-list::-webkit-scrollbar { width: 6px; }
.checkout-form__prefix-list::-webkit-scrollbar-thumb { background: rgba(255,164,23,0.3); border-radius: 3px; }
.checkout-form__prefix-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  cursor: pointer;
  font-size: 0.92rem;
  color: var(--c-text);
  transition: background 0.1s;
}
.checkout-form__prefix-list li:hover,
.checkout-form__prefix-list li[aria-selected="true"] {
  background: rgba(255,164,23,0.1);
}
.checkout-form__prefix-list li img { border-radius: 2px; flex-shrink: 0; box-shadow: 0 0 0 1px rgba(255,255,255,0.08); }
.checkout-form__prefix-list li span { flex: 1; }
.checkout-form__prefix-list li em {
  font-style: normal;
  color: var(--c-text-muted);
  font-weight: var(--fw-semi);
  font-size: 0.85rem;
}
.checkout-form__field input::placeholder {
  color: var(--c-text-muted);
  opacity: 0.7;
}
.checkout-form__field input:focus {
  border-color: var(--c-accent);
  background: rgba(255,164,23,0.06);
}
.checkout-form__field input.is-invalid {
  border-color: #ef4444;
  background: rgba(239,68,68,0.06);
}
.checkout-form__submit {
  width: 100%;
  margin-top: var(--sp-2);
  position: relative;
  padding: 1.05rem 1.5rem;
}
.checkout-form__spinner {
  display: none;
  width: 20px;
  height: 20px;
  border: 2.5px solid rgba(10,10,10,0.28);
  border-top-color: var(--c-accent-ink);
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -10px 0 0 -10px;
  animation: cm-spin 0.7s linear infinite;
}
.checkout-form__submit.is-loading .checkout-form__btn-label { visibility: hidden; }
.checkout-form__submit.is-loading .checkout-form__spinner { display: block; }
.checkout-form__submit:disabled { opacity: 0.8; cursor: wait; }
.checkout-form__legal {
  font-size: 0.74rem;
  color: var(--c-text-muted);
  text-align: center;
  margin: var(--sp-2) 0 0;
  line-height: 1.4;
}
.checkout-form__legal a {
  color: var(--c-accent);
  text-decoration: underline;
}
@keyframes cm-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes cm-slide-up { from { opacity: 0; transform: translateY(24px) scale(0.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes cm-spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) {
  .checkout-modal__backdrop, .checkout-modal__panel { animation: none; }
}
@media (max-width: 540px) {
  .checkout-modal { padding: var(--sp-3); align-items: flex-start; }
  .checkout-modal__panel { margin-top: var(--sp-5); }
}

/* ============================================================
   BONUS DE ACCIÓN RÁPIDA (24h post apertura, auto-hide)
   Lenguaje visual: dark card + barra superior degradada + glow sutil
   Consistente con .module--masterclass y .pricing-single
   ============================================================ */
.bonus-fast {
  padding-block: var(--sp-7);
}
.bonus-fast__card {
  width: 100%;
  margin-inline: auto;
  background: var(--c-bg-card);
  border: 1px solid rgba(255,164,23,0.28);
  border-radius: var(--r-lg);
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
  position: relative;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.45), 0 0 0 1px rgba(255,164,23,0.06);
  text-align: center;
}
/* Barra superior degradada — igual patrón que masterclass */
.bonus-fast__card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, #ff8a00 0%, var(--c-accent) 50%, #ff8a00 100%);
}
/* Glow sutil ambient — más discreto que antes */
.bonus-fast__card::after {
  content: "";
  position: absolute;
  top: -180px; right: -120px;
  width: 380px; height: 380px;
  background: radial-gradient(circle, rgba(255,164,23,0.15) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.bonus-fast__body {
  position: relative;
  z-index: 1;
  max-width: 760px;
  margin: 0 auto;
}

/* Eyebrow PROMINENTE — foco del bonus */
.bonus-fast__eyebrow {
  display: inline-block;
  font-family: var(--ff-display);
  font-weight: var(--fw-bold);
  font-size: 0.92rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent-ink);
  background: var(--c-accent);
  padding: 8px 18px;
  border-radius: var(--r-full);
  margin-bottom: var(--sp-6);
  box-shadow: 0 8px 24px rgba(255,164,23,0.35);
}

.bonus-fast__title {
  font-family: var(--ff-display);
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  font-weight: var(--fw-bold);
  line-height: 1.22;
  letter-spacing: -0.018em;
  margin: 0 auto var(--sp-5);
  color: var(--c-text);
  max-width: 820px;
}
.bonus-fast__title .hl { color: var(--c-accent); }

.bonus-fast__desc {
  font-size: 1rem;
  line-height: var(--lh-loose);
  color: var(--c-text-soft);
  margin: 0 auto var(--sp-7);
  max-width: 680px;
}

/* Fila de accion: countdown + CTA con misma altura */
.bonus-fast__action-row {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
}

/* Countdown alineado en altura con el boton */
.bonus-fast__countdown {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0 20px;
  background: rgba(255,164,23,0.08);
  border: 1px solid rgba(255,164,23,0.25);
  border-radius: var(--r-full);
  margin: 0;
}
.bonus-fast__countdown-label {
  font-family: var(--ff-body);
  font-size: 0.74rem;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--c-accent);
  margin-right: 4px;
}
.bonus-fast__pill {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  padding: 4px 10px;
  background: var(--c-accent);
  color: var(--c-accent-ink);
  border-radius: 999px;
  font-family: var(--ff-display);
}
.bonus-fast__pill b {
  font-weight: var(--fw-bold);
  font-size: 0.95rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.bonus-fast__pill i {
  font-style: normal;
  font-size: 0.7rem;
  font-weight: var(--fw-semi);
  opacity: 0.78;
}

.bonus-fast__cta {
  padding: 0 2.5rem;
  display: inline-flex;
  align-items: center;
  min-height: 56px;
  font-size: 1rem;
}

@media (max-width: 880px) {
  .bonus-fast__eyebrow { font-size: 0.78rem; padding: 7px 14px; }
  .bonus-fast__countdown { justify-content: center; padding: 12px 18px; }
  .bonus-fast__action-row { gap: var(--sp-3); }
  .bonus-fast__cta { width: 100%; max-width: 360px; }
}

/* Disclaimer regulatorio bajo el slider de expertos */
.experts__disclaimer {
  max-width: 900px;
  margin: var(--sp-7) auto 0;
  text-align: center;
  font-size: 0.78rem;
  line-height: 1.6;
  color: var(--c-text-muted);
  padding: var(--sp-4) var(--sp-5);
  border-top: 1px solid var(--c-border);
  font-style: italic;
}
