/* ============================================================
   Franquicia Digital — Sistema visual del deck (navy/oro)
   Lámina canónica 1920×1080. Texto real HTML (nítido).

   REGLA DE ORO (estilo PowerPoint): TODO el contenido vive
   dentro de la ZONA SEGURA. Nada se sale del 1920×1080.
   Las imágenes de personas NUNCA se recortan (object-fit
   contain o full-bleed con anclaje, jamás cover que corte caras).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root {
  --navy:        #0a1c33;
  --navy-deep:   #061322;
  --navy-card:   #0f2742;
  --gold:        #f5b820;
  --gold-soft:   #ffd97a;
  --ink:         #eaf1fb;
  --ink-dim:     #9fb3cc;
  --line:        rgba(245,184,32,.28);

  --w: 1920px;
  --h: 1080px;

  /* Zona segura: márgenes fijos. Banda inferior reservada para el pie. */
  --safe-x: 120px;
  --safe-top: 84px;
  --safe-bottom: 84px;    /* simétrico — sin pie de lámina */
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html, body {
  background: #05101d;
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  color: var(--ink);
}

/* ---- Escenario fijo 1920×1080 (export 1:1 a PNG) ---- */
.stage {
  position: relative;
  width: var(--w);
  height: var(--h);
  overflow: hidden;
  background:
    radial-gradient(120% 120% at 78% 22%, #143052 0%, var(--navy) 42%, var(--navy-deep) 100%);
}
.stage::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 50% 50%, transparent 58%, rgba(2,8,16,.5) 100%);
  pointer-events: none; z-index: 1;
}
.grid-glow {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(245,184,32,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,184,32,.04) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: radial-gradient(80% 70% at 75% 30%, #000 0%, transparent 75%);
  pointer-events: none;
}

/* ---- ZONA SEGURA: marco de contenido. Todo vive aquí dentro ---- */
.pad {
  position: absolute;
  top: var(--safe-top);
  left: var(--safe-x);
  right: var(--safe-x);
  bottom: var(--safe-bottom);
  z-index: 3;
  display: flex;
  flex-direction: column;
}

/* ---- Eyebrow / pill ---- */
.eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  align-self: flex-start;
  font-size: 26px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--gold);
  padding: 13px 28px;
  border: 1.5px solid var(--line); border-radius: 999px;
  background: rgba(245,184,32,.06);
}
.eyebrow .dot { width: 12px; height: 12px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 18px var(--gold); }

/* ---- Tipografía ---- */
.title {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: 72px; line-height: 1.05;
  letter-spacing: -.01em; color: #fff;
}
.title .gold { color: var(--gold); }

.subtitle {
  font-size: 36px; font-weight: 500; line-height: 1.32;
  color: var(--ink-dim);
}

/* ---- Bullets ---- */
.bullets { list-style: none; display: grid; gap: 24px; }
.bullets li {
  position: relative; font-size: 34px; font-weight: 500;
  line-height: 1.28; padding-left: 52px; color: var(--ink);
}
.bullets li::before {
  content: ''; position: absolute; left: 0; top: .42em;
  width: 22px; height: 22px; border-radius: 6px;
  background: var(--gold); box-shadow: 0 0 16px rgba(245,184,32,.55);
  transform: rotate(45deg);
}

/* ---- Pie de lámina (dentro de la banda reservada, nunca colisiona) ---- */
.foot {
  position: absolute; left: var(--safe-x); bottom: 46px; z-index: 4;
  font-size: 22px; color: var(--ink-dim); letter-spacing: .06em;
  display: flex; align-items: center; gap: 16px;
}
.foot .bar { width: 56px; height: 3px; background: var(--gold); border-radius: 2px; }

/* ============================================================
   L1 · PORTADA — UNA sola lámina integrada. Hero a fondo completo
   anclado a la derecha (persona + 3 tarjetas visibles). El texto
   se compone en la zona navy izquierda, sobre un velo suave.
   Una pieza, no dos bandas.
   ============================================================ */
.cover-bleed {
  position: absolute; inset: 0; z-index: 0;
  background-image: url('../_assets/ilustraciones/portada_hero.png');
  background-size: cover;
  background-position: center center;   /* ilustración 16:9 nativa, sin recorte */
  background-repeat: no-repeat;
}
/* velo suave a la izquierda para asentar el texto sobre el navy */
.cover-scrim {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(90deg,
      var(--navy) 0%, rgba(10,28,51,.92) 22%,
      rgba(10,28,51,.5) 36%, rgba(10,28,51,.08) 48%, transparent 58%);
}
.cover-content {
  position: absolute;
  top: var(--safe-top); left: var(--safe-x); bottom: var(--safe-bottom);
  width: 42%; z-index: 3;
  display: flex; flex-direction: column; justify-content: center; gap: 30px;
}
.cover-content .title { font-size: 62px; font-weight: 700; }
.cover-content .subtitle { font-size: 31px; max-width: 22ch; }

/* ---- Panel de ilustración CONTAIN (cuando se muestra una imagen sin recortar) ---- */
.art-panel {
  flex: 1; min-height: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(15,39,66,.35);
  border: 1.5px solid var(--line); border-radius: 24px;
  padding: 22px; overflow: hidden;
}
.art-panel img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;        /* muestra la imagen entera, nunca recorta */
  border-radius: 14px;
}

/* ============================================================
   L4 · TABLA COMPARATIVA — entra completa, sin colisionar el pie
   ============================================================ */
.cmp { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 30px; }
.cmp .head { display: grid; gap: 18px; flex: 0 0 auto; }
.cmp .head .title { font-size: 60px; }
.cmp-wrap { flex: 1; min-height: 0; display: flex; align-items: center; }
.cmp-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 30px; }
.cmp-table th, .cmp-table td { padding: 17px 32px; text-align: left; }
.cmp-table thead th { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 600; }
.cmp-table thead th.trad { color: var(--ink-dim); }
.cmp-table thead th.digi { color: var(--navy); background: var(--gold); border-radius: 14px 14px 0 0; }
.cmp-table tbody td:first-child { color: var(--ink-dim); font-weight: 600; font-size: 28px; }
.cmp-table tbody td.trad { color: var(--ink); }
.cmp-table tbody td.digi { color: #fff; font-weight: 700; background: rgba(245,184,32,.12); }
.cmp-table tbody tr:nth-child(odd) td.trad,
.cmp-table tbody tr:nth-child(odd) td:first-child { background: rgba(255,255,255,.025); }
.cmp-table tbody tr:last-child td.digi { border-radius: 0 0 14px 14px; }
.cmp-table td.digi::before { content: '✓'; color: var(--gold); font-weight: 800; margin-right: 14px; }

/* ============================================================
   L5 · REVEAL DE MARCA — Club emprenYA centrado
   ============================================================ */
.reveal {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: space-between;
  text-align: center; padding: 8px 0;
}
.reveal .eyebrow { align-self: center; }
.reveal-mid { display: flex; flex-direction: column; align-items: center; gap: 38px; }
.reveal .kicker { font-family: 'Fraunces', serif; font-size: 46px; font-weight: 500; color: var(--ink-dim); }
.reveal .brand-logo { width: 1080px; max-width: 86%; height: auto; filter: drop-shadow(0 14px 46px rgba(0,0,0,.55)); }
.reveal .reveal-sub { font-size: 37px; font-weight: 500; color: var(--ink); max-width: 30ch; line-height: 1.34; }
.reveal .reveal-sub b { color: var(--gold); font-weight: 700; }
.reveal .sublogos {
  display: flex; align-items: center; justify-content: center; gap: 84px;
  width: 100%; padding-top: 40px; border-top: 1px solid var(--line);
}
.reveal .sublogos img { height: 80px; width: auto; opacity: .92; }

/* ── Reveal premium ── */
.reveal.premium { position: relative; }
.reveal.premium .reveal-glow { display: none; }
.reveal.premium > *:not(.reveal-glow) { position: relative; z-index: 1; }
.reveal.premium .brand-logo { filter: drop-shadow(0 0 60px rgba(245,184,32,.4)) drop-shadow(0 14px 40px rgba(0,0,0,.6)); }
.reveal.premium .kicker { letter-spacing: .01em; }
.reveal-split { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: row-reverse; align-items: center; justify-content: center; gap: 30px; width: 100%; }
.reveal-lobo { flex: 0 0 auto; height: 100%; display: flex; align-items: flex-end; }
.reveal-lobo img { max-height: 100%; width: auto; object-fit: contain; filter: drop-shadow(0 18px 40px rgba(0,0,0,.55)) drop-shadow(0 0 50px rgba(245,184,32,.22)); }
.reveal-split .reveal-mid { flex: 1 1 auto; gap: 30px; }
.brand-cards { display: flex; align-items: stretch; justify-content: center; gap: 30px; width: 100%; }
.brand-card { flex: 0 1 340px; display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 24px 26px 22px; border-radius: 22px;
  background: linear-gradient(180deg, rgba(31,58,92,.5) 0%, var(--navy-card) 58%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.28); box-shadow: 0 16px 38px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.05);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.brand-card:hover { transform: translateY(-6px); border-color: rgba(245,184,32,.6); box-shadow: 0 24px 50px rgba(0,0,0,.5), 0 0 44px rgba(245,184,32,.24); }
.brand-card .bc-mascot { width: 118px; height: 118px; border-radius: 50%; overflow: hidden;
  background: radial-gradient(72% 72% at 50% 36%, rgba(245,184,32,.18), rgba(10,28,51,.4) 72%); border: 2px solid rgba(245,184,32,.5);
  display: flex; align-items: center; justify-content: center; box-shadow: 0 0 26px rgba(245,184,32,.3); }
.brand-card .bc-mascot img { width: 100%; height: 100%; object-fit: contain; padding: 6px 4px 0; }
.brand-card .bc-logo { height: 46px; width: auto; max-width: 80%; object-fit: contain; margin-top: 4px; }
.brand-card .bc-sector { font-size: 22px; font-weight: 600; color: var(--gold-soft); }

/* ============================================================
   L6 · TRES NEGOCIOS — 3 columnas con marca real + mascota
   ============================================================ */
.head-center { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 16px; }
.head-center .eyebrow { align-self: center; }
.head-center .title { font-size: 58px; }

.cols3 { flex: 1; min-height: 0; margin-top: 30px; display: grid; grid-template-columns: repeat(3, 1fr); align-items: center; gap: 32px; }
.line-card {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 22px 22px 24px; gap: 10px;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2));
  border: 1.5px solid var(--line); border-radius: 24px;
}
.line-card .line-logo { height: 70px; width: auto; object-fit: contain; margin-bottom: 4px; flex: 0 0 auto; }
.line-card .line-mascot { flex: 0 0 auto; height: 330px; width: 100%; display: flex; align-items: flex-end; justify-content: center; }
.line-card .line-mascot img { max-height: 100%; max-width: 100%; object-fit: contain; }
.line-card .line-name { flex: 0 0 auto; font-family: 'Fraunces', serif; font-size: 32px; font-weight: 600; color: var(--gold); margin-top: 14px; }
.line-card .line-desc { flex: 0 0 auto; font-size: 25px; font-weight: 500; color: var(--ink-dim); line-height: 1.3; min-height: 2.6em; }

/* ============================================================
   HUECOS GUÍA para marcas colocadas a mano (NATURKIN/viajaYA/TOMAYA)
   Por defecto: espacio reservado invisible (versión limpia).
   .stage.guide → muestra caja punteada + etiqueta (versión guía).
   ============================================================ */
.logo-slot { flex: 0 0 auto; position: relative; }
.stage.guide .logo-slot {
  border: 2px dashed rgba(245,184,32,.6); border-radius: 10px;
  background: rgba(245,184,32,.05);
}
.stage.guide .logo-slot::after {
  content: attr(data-label); position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: rgba(159,179,204,.95); font-size: 19px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
}

/* ============================================================
   LAYOUT: SPLIT (texto + imagen) — L02, L08, L10, L13...
   ============================================================ */
.split { flex: 1; min-height: 0; display: grid; grid-template-columns: 1.05fr .95fr; gap: 64px; align-items: center; }
.split-text { display: flex; flex-direction: column; gap: 30px; }
.split-text .title { font-size: 56px; }
.split-art { height: 82%; align-self: center; width: 100%; border-radius: 26px; overflow: hidden;
  border: 1.5px solid var(--line); box-shadow: 0 30px 90px rgba(0,0,0,.5); }
.split-art img { width: 100%; height: 100%; object-fit: cover; display: block; }
.split-art video { width: 100%; height: 100%; object-fit: cover; display: block; }
/* contenedor de la imagen "Cómo funciona" (pantallazo web) con proporción 16:9 */
.split-art.split-art-cf { width: 118%; margin-left: -18%; height: auto; aspect-ratio: 16 / 9; max-height: 100%; }

/* ============================================================
   LAYOUT: CONCEPTO (idea central + apoyo) — L03
   ============================================================ */
.concept { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 34px; max-width: 1500px; }
.concept .lead { font-size: 42px; line-height: 1.34; color: var(--ink); font-weight: 500; }
.concept .lead b { color: var(--gold); font-weight: 700; }
.concept .brand-chips { display: flex; gap: 20px; flex-wrap: wrap; }
.concept .chip { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 600; color: #fff;
  padding: 14px 30px; border: 1.5px solid var(--line); border-radius: 14px; background: rgba(245,184,32,.06); }
.concept .why { font-size: 32px; line-height: 1.4; color: var(--ink-dim); }
.concept .why b { color: var(--ink); font-weight: 700; }
.concept .bridge { font-size: 30px; font-style: italic; color: var(--gold-soft); border-left: 4px solid var(--gold); padding-left: 24px; }

/* ============================================================
   LAYOUT: GRID DE FEATURES (iconos) — L07, plan resume
   ============================================================ */
.feat-grid { flex: 1; min-height: 0; margin-top: 24px; display: flex; flex-wrap: wrap; justify-content: center; align-content: center; gap: 22px; }
.feat { width: calc(25% - 22px); min-height: 0;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2));
  border: 1.5px solid var(--line); border-radius: 20px; padding: 24px 24px;
  display: flex; flex-direction: column; gap: 12px; }
.feat img.icon { height: 62px; width: auto; object-fit: contain; }
.feat .ft { font-size: 23px; font-weight: 700; color: #fff; line-height: 1.2; }
.feat .fd { font-size: 18px; font-weight: 500; color: var(--ink-dim); line-height: 1.32; }

/* ============================================================
   LAYOUT: PASOS NUMERADOS — L08
   ============================================================ */
.steps { display: flex; flex-direction: column; gap: 26px; }
.step { display: flex; gap: 24px; align-items: center; }
.step .num { width: 60px; height: 60px; border-radius: 50%; background: var(--gold); color: var(--navy);
  font-family: 'Plus Jakarta Sans'; font-weight: 800; font-size: 28px; flex: 0 0 auto;
  display: flex; align-items: center; justify-content: center; box-shadow: 0 0 22px rgba(245,184,32,.4); }
.step .stext { font-size: 30px; font-weight: 500; line-height: 1.28; color: var(--ink); }

/* ---- Tarjetas de feature clickeables (con enlace) ---- */
a.feat { text-decoration: none; color: inherit; }
.feat.linked { cursor: pointer; position: relative; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.feat.linked:hover { transform: translateY(-5px); border-color: rgba(245,184,32,.65); box-shadow: 0 16px 40px rgba(0,0,0,.5); }
.feat.linked::after { content: "↗"; position: absolute; top: 15px; right: 18px; color: var(--gold); font-size: 22px; font-weight: 800; opacity: .75; }

/* ============================================================
   L3 · FRANQUICIAS GIGANTES — tarjetas imagen + marca + stats
   ============================================================ */
.franq-lead { flex: 0 0 auto; font-size: 32px; line-height: 1.34; color: var(--ink); font-weight: 500; margin-top: 20px; }
.franq-lead b { color: var(--gold); font-weight: 700; }
.franq-grid { flex: 1; min-height: 0; margin: 26px 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; align-items: stretch; }
.franq-card { display: flex; flex-direction: column; border: 1.5px solid var(--line); border-radius: 22px; overflow: hidden;
  background: linear-gradient(180deg, rgba(15,39,66,.5), rgba(10,28,51,.2)); }
.franq-card .img { flex: 1 1 auto; min-height: 220px; overflow: hidden; }
.franq-card .img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.franq-card .body { flex: 0 0 auto; padding: 22px 26px 24px; display: flex; flex-direction: column; gap: 14px; }
.franq-card .name { font-family: 'Fraunces', serif; font-size: 30px; font-weight: 600; color: #fff; }
.franq-card .stat { display: flex; align-items: baseline; gap: 12px; }
.franq-card .stat .num { font-size: 34px; font-weight: 800; color: var(--gold); line-height: 1; }
.franq-card .stat .lbl { font-size: 18px; color: var(--ink-dim); font-weight: 500; }
.franq-bridge { flex: 0 0 auto; font-size: 28px; font-style: italic; color: var(--gold-soft);
  border-left: 4px solid var(--gold); padding-left: 24px; }
.franq-src { flex: 0 0 auto; margin-top: 12px; font-size: 15px; color: rgba(159,179,204,.6); }

/* ============================================================
   LA EMPRESA — datos + misión
   ============================================================ */
.empresa { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: flex-start; gap: 22px; margin-top: 20px; }
.empresa-corp { flex: 1 1 auto; min-height: 0; border-radius: 20px; overflow: hidden; border: 1.5px solid var(--line); box-shadow: 0 18px 50px rgba(0,0,0,.4); }
.empresa-corp img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; display: block; }
.empresa-facts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.efact { background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); border: 1.5px solid var(--line);
  border-radius: 20px; padding: 30px 30px; display: flex; flex-direction: column; gap: 12px; }
.efact .big { font-family: 'Fraunces', serif; font-size: 40px; font-weight: 700; color: var(--gold); line-height: 1; }
.efact .et { font-size: 26px; font-weight: 500; color: var(--ink); line-height: 1.3; }
.mission { display: flex; gap: 22px; align-items: flex-start; background: rgba(245,184,32,.08);
  border: 1.5px solid var(--line); border-left: 5px solid var(--gold); border-radius: 18px; padding: 30px 36px; }
.mission .ml { font-family: 'Fraunces', serif; font-size: 30px; font-weight: 700; color: var(--gold); flex: 0 0 auto; }
.mission .mt { font-size: 28px; font-weight: 500; line-height: 1.4; color: var(--ink); }

/* ============================================================
   EL EQUIPO — fila de retratos (tarjetas ya con nombre + cargo)
   ============================================================ */
.team-row { flex: 1; min-height: 0; margin-top: 24px; display: flex; gap: 18px; align-items: center; justify-content: center; }
.team-row img { max-width: calc((100% - 72px) / 5); max-height: 100%; width: auto; height: auto; object-fit: contain;
  border-radius: 16px; box-shadow: 0 18px 50px rgba(0,0,0,.45); }

/* ---- EL EQUIPO v2 — foto recortada + nombre/cargo en HTML ---- */
.team2-row { flex: 1; min-height: 0; margin-top: 26px; display: flex; gap: 24px; justify-content: center; align-items: stretch; }
.team2-card { flex: 1 1 0; max-width: 322px; display: flex; flex-direction: column;
  background: linear-gradient(180deg, rgba(15,39,66,.6), rgba(10,28,51,.25));
  border: 1.5px solid var(--line); border-radius: 20px; overflow: hidden; }
.team2-card .ph { width: 100%; flex: 1 1 auto; min-height: 0; overflow: hidden; }
.team2-card .ph img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.team2-card .info { flex: 0 0 auto; padding: 18px 16px 22px; text-align: center; }
.team2-card .nm { font-family: 'Fraunces', serif; font-size: 24px; font-weight: 600; color: #fff; line-height: 1.12; }
.team2-card .nm b { color: var(--gold); font-weight: 600; }
.team2-card .rl { font-size: 16px; font-weight: 500; color: var(--ink-dim); margin-top: 7px; line-height: 1.28; }

/* ---- Tira compacta del equipo (al pie de La empresa) ---- */
.team-strip { flex: 1 1 auto; min-height: 0; display: flex; gap: 20px; justify-content: center; align-items: stretch; }
.ts-card { flex: 1 1 0; max-width: 312px; display: flex; flex-direction: column; }
.ts-card .tph { width: 100%; flex: 1 1 auto; min-height: 0; overflow: hidden; }
.ts-card .tph img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.ts-card .base { position: relative; z-index: 2; margin-top: -10px; text-align: center;
  padding: 13px 16px 15px; border: 1.5px solid var(--line); border-radius: 16px;
  background: linear-gradient(180deg, rgba(15,39,66,.94), rgba(8,22,40,.96)); }
.ts-card .tn { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 600; color: #fff; line-height: 1.12; }
.ts-card .tn b { color: var(--gold); }
.ts-card .tc { font-size: 16px; font-weight: 500; color: var(--ink-dim); line-height: 1.24; margin-top: 5px; min-height: 2.5em; }

/* ============================================================
   CASOS DE ÉXITO — 4 testimonios
   ============================================================ */
.testi-grid { flex: 1; min-height: 0; margin-top: 26px; display: grid; grid-template-columns: 1fr 1fr; gap: 28px; align-items: stretch; }
.testi { display: flex; flex-direction: row; align-items: center; gap: 26px; padding: 28px 32px;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); border: 1.5px solid var(--line); border-radius: 20px; }
.testi .ph { width: 156px; height: 156px; border-radius: 50%; overflow: hidden; border: 3px solid var(--gold); flex: 0 0 auto; box-shadow: 0 0 26px rgba(245,184,32,.35); }
.testi .ph img { width: 100%; height: 100%; object-fit: cover; }
.testi .content { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.testi .head-row { display: flex; align-items: center; gap: 14px; }
.testi .nm { font-family: 'Fraunces', serif; font-size: 27px; font-weight: 600; color: #fff; }
.testi .stars { color: var(--gold); font-size: 18px; letter-spacing: 2px; }
.testi .cat { font-size: 15px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); }
.testi .q { font-size: 19px; line-height: 1.4; color: var(--ink-dim); font-style: italic; margin-top: 4px; }

/* ============================================================
   DOS COLUMNAS — ahorrador vs emprendedor
   ============================================================ */
.twocol { flex: 1; min-height: 0; margin-top: 26px; display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
.col-card { display: flex; flex-direction: column; padding: 0; overflow: hidden; border: 1.5px solid var(--line); border-radius: 24px;
  background: linear-gradient(180deg, rgba(15,39,66,.5), rgba(10,28,51,.2)); }
.col-card.hot { border-color: var(--gold); background: rgba(245,184,32,.09); box-shadow: 0 0 50px rgba(245,184,32,.13); }
.col-card .ci { width: 100%; flex: 1 1 auto; min-height: 0; overflow: hidden; }
.col-card .ci img { width: 100%; height: 100%; object-fit: cover; display: block; }
.col-card .cbody { flex: 0 0 auto; padding: 26px 38px 30px; display: flex; flex-direction: column; gap: 12px; }
.col-card .tag { align-self: flex-start; font-size: 19px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold);
  padding: 7px 18px; border: 1.5px solid var(--line); border-radius: 999px; background: rgba(245,184,32,.06); }
.col-card .ct { font-family: 'Fraunces', serif; font-size: 40px; font-weight: 600; color: #fff; }
.col-card.hot .ct { color: var(--gold); }
.col-card .cd { font-size: 28px; line-height: 1.4; color: var(--ink-dim); }
.col-card .cd b { color: var(--ink); font-weight: 700; }
.twocol-note { flex: 0 0 auto; margin-top: 22px; font-size: 26px; text-align: center; color: var(--gold-soft); }
.twocol-note b { color: var(--gold); font-weight: 700; }

/* ============================================================
   INVERSIÓN — precios
   ============================================================ */
.price-row { flex: 1 1 auto; min-height: 0; margin-top: 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.price-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px; padding: 30px 38px;
  border: 1.5px solid var(--line); border-radius: 22px;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); justify-content: center; }
.price-card.intl { border-color: var(--gold); background: rgba(245,184,32,.08); }
.price-card .emblem { width: 150px; height: 150px; flex: 0 0 auto; margin-bottom: 2px; }
.price-card .emblem img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 8px 28px rgba(245,184,32,.35)); }
.price-card .pl { font-size: 23px; font-weight: 700; color: var(--ink); }
.price-card .pl span { color: var(--gold); }
.price-card .price { font-family: 'Fraunces', serif; font-size: 72px; font-weight: 700; color: var(--gold); line-height: 1; }
.price-card .price small { display: block; font-size: 23px; color: var(--ink-dim); font-weight: 500; margin-top: 6px; }
.price-card .pd { font-size: 22px; color: var(--ink-dim); line-height: 1.35; }
.price-card .pd b { color: #fff; }
.invest-foot { flex: 0 0 auto; margin-top: 22px; display: flex; gap: 24px; align-items: stretch; }
.invest-foot .memb { flex: 1; padding: 20px 28px; border: 1.5px solid var(--line); border-radius: 16px; background: rgba(15,39,66,.4);
  font-size: 24px; color: var(--ink); display: flex; align-items: center; }
.invest-foot .memb b { color: var(--gold); }
.invest-foot .warranty { flex: 1; padding: 20px 28px; border: 1.5px solid var(--line); border-left: 5px solid var(--gold);
  border-radius: 16px; background: rgba(245,184,32,.08); font-size: 23px; color: var(--ink); display: flex; align-items: center; }
.invest-foot .warranty b { color: var(--gold); }

/* ============================================================
   MEMBRESÍA SE PAGA SOLA — beneficios
   ============================================================ */
.pays { flex: 1; min-height: 0; margin-top: 22px; display: flex; flex-direction: column; gap: 24px; justify-content: center; }
.pays-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.pay-item { display: flex; align-items: center; gap: 18px; padding: 22px 28px; border: 1.5px solid var(--line); border-radius: 16px;
  background: linear-gradient(180deg, rgba(15,39,66,.5), rgba(10,28,51,.2)); }
.pay-item .pi-ic { width: 16px; height: 16px; border-radius: 4px; background: var(--gold); transform: rotate(45deg); flex: 0 0 auto; box-shadow: 0 0 14px rgba(245,184,32,.5); }
.pay-item .pi-t { font-size: 26px; color: var(--ink); font-weight: 500; }
.pay-item .pi-t b { color: var(--gold); font-weight: 700; }
.pays-free { padding: 26px 36px; border-radius: 18px; background: rgba(245,184,32,.1); border: 1.5px solid var(--gold);
  text-align: center; font-size: 30px; color: #fff; font-weight: 500; }
.pays-free b { color: var(--gold); font-weight: 800; }

/* Nota de garantía standalone (lámina de cierre) */
.split-text .warranty { align-self: flex-start; padding: 18px 28px; border: 1.5px solid var(--line);
  border-left: 5px solid var(--gold); border-radius: 14px; background: rgba(245,184,32,.08);
  font-size: 27px; color: var(--ink); line-height: 1.35; }
.split-text .warranty b { color: var(--gold); }

/* ============================================================
   PLAN DE COMPENSACIÓN — resumen + bonos
   ============================================================ */
.plan7 { flex: 1; min-height: 0; margin-top: 24px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; align-content: center; }
.plan7 .p7 { display: flex; gap: 16px; align-items: flex-start; padding: 22px 24px; border: 1.5px solid var(--line); border-radius: 16px;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); }
.plan7 .p7.wide { grid-column: span 2; }
.plan7 .num { width: 48px; height: 48px; border-radius: 12px; background: var(--gold); color: var(--navy);
  font-family: 'Plus Jakarta Sans'; font-weight: 800; font-size: 24px; display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.plan7 .p7-t { display: flex; flex-direction: column; gap: 4px; }
.plan7 .p7-n { font-size: 22px; font-weight: 700; color: #fff; line-height: 1.15; }
.plan7 .p7-d { font-size: 17px; color: var(--ink-dim); line-height: 1.3; }

.bono { flex: 1; min-height: 0; margin-top: 20px; display: flex; flex-direction: column; gap: 22px; justify-content: center; }
.bono .paga { font-size: 32px; line-height: 1.38; color: var(--ink); font-weight: 500; }
.bono .paga b { color: var(--gold); font-weight: 700; }
.bono .ejemplo { display: flex; align-items: center; gap: 22px; padding: 24px 32px; border: 1.5px solid var(--line);
  border-left: 5px solid var(--gold); border-radius: 16px; background: rgba(245,184,32,.08); }
.bono .ejemplo .elabel { font-size: 21px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--gold); flex: 0 0 auto; }
.bono .ejemplo .etext { font-size: 27px; color: var(--ink); line-height: 1.3; }
.bono .ejemplo .etext b { color: #fff; font-weight: 700; }
.bono .seal { font-size: 17px; color: var(--ink-dim); font-style: italic; }

/* tres cajas de % (Bono 3) */
.pct-row { display: flex; gap: 20px; }
.pct-box { flex: 1; text-align: center; padding: 24px; border: 1.5px solid var(--line); border-radius: 16px; background: rgba(15,39,66,.45); }
.pct-box .pn { font-family: 'Fraunces', serif; font-size: 50px; font-weight: 700; color: var(--gold); line-height: 1; }
.pct-box .pt { font-size: 22px; color: var(--ink-dim); margin-top: 8px; }

/* matriz / tabla de bono */
.bono-matrix { display: grid; grid-template-columns: 1.2fr 1fr; gap: 30px; align-items: center; flex: 1; min-height: 0; }
.mtable { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 22px; }
.mtable th, .mtable td { padding: 9px 18px; text-align: right; }
.mtable th { font-size: 18px; color: var(--gold); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; border-bottom: 2px solid var(--line); }
.mtable td:first-child, .mtable th:first-child { text-align: left; }
.mtable tbody tr:nth-child(odd) td { background: rgba(255,255,255,.025); }
.mtable .hi td { background: rgba(245,184,32,.14); color: #fff; font-weight: 700; }
.mtable .acc { color: var(--gold); font-weight: 700; }
.hilites { display: flex; flex-direction: column; gap: 20px; }
.hilite { padding: 26px 30px; border: 1.5px solid var(--gold); border-radius: 18px; background: rgba(245,184,32,.1); }
.hilite .hn { font-family: 'Fraunces', serif; font-size: 46px; font-weight: 700; color: var(--gold); line-height: 1; }
.hilite .hl { font-size: 22px; color: var(--ink); margin-top: 8px; }

/* ============================================================
   INVERSIÓN v2 — contraste dramático + opciones + badges
   ============================================================ */
.invest2 { flex: 1; min-height: 0; margin-top: 18px; display: flex; flex-direction: column; gap: 30px; justify-content: space-between; padding: 10px 0; }
.contrast { display: flex; align-items: center; justify-content: center; gap: 56px; padding: 40px 48px; flex: 1 1 auto;
  border: 1.5px solid var(--line); border-radius: 22px; background: linear-gradient(180deg, rgba(15,39,66,.5), rgba(10,28,51,.25)); }
.contrast .old { text-align: center; }
.contrast .old .ol { font-size: 23px; color: var(--ink-dim); text-transform: uppercase; letter-spacing: .1em; font-weight: 700; }
.contrast .old .ov { font-family: 'Fraunces', serif; font-size: 52px; color: var(--ink-dim); text-decoration: line-through; text-decoration-color: rgba(245,184,32,.7); margin-top: 8px; }
.contrast .arrow { font-size: 64px; color: var(--gold); line-height: 1; }
.contrast .new { text-align: center; }
.contrast .new .nl { font-size: 23px; color: var(--gold); text-transform: uppercase; letter-spacing: .1em; font-weight: 700; }
.contrast .new .nv { font-family: 'Fraunces', serif; font-size: 60px; color: var(--gold); font-weight: 700; line-height: 1; margin-top: 8px; }

.inv-reveal { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; gap: 30px; justify-content: space-between; }
.opt-row { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; flex: 1 1 auto; }
.opt { position: relative; display: flex; align-items: center; gap: 28px; padding: 34px 40px; border: 1.5px solid var(--line); border-radius: 20px;
  background: linear-gradient(180deg, rgba(15,39,66,.6), rgba(10,28,51,.25)); box-shadow: 0 14px 30px rgba(0,0,0,.3); }
.opt.intl { border-color: rgba(245,184,32,.5); background: rgba(245,184,32,.06); }
.opt.featured { border: 2px solid var(--gold);
  background: radial-gradient(120% 140% at 0% 0%, rgba(245,184,32,.2), transparent 55%), linear-gradient(180deg, rgba(60,46,12,.4), var(--navy-card) 70%, var(--navy-deep));
  box-shadow: 0 16px 38px rgba(0,0,0,.4), 0 0 40px rgba(245,184,32,.28); }
.opt .opt-pill { position: absolute; top: -16px; left: 36px; font-size: 17px; font-weight: 800; letter-spacing: .04em; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); padding: 7px 20px; border-radius: 999px; box-shadow: 0 6px 18px rgba(245,184,32,.45); }
.opt .op-price { font-family: 'Fraunces', serif; font-size: 88px; color: var(--gold); font-weight: 700; line-height: 1; flex: 0 0 auto; text-shadow: 0 0 28px rgba(245,184,32,.4); }
.opt .op-body { display: flex; flex-direction: column; gap: 8px; }
.opt .op-r { font-size: 28px; font-weight: 700; color: #fff; line-height: 1.15; }
.opt .op-d { font-size: 21px; color: var(--ink-dim); line-height: 1.36; }
.opt .op-d b { color: var(--gold); font-weight: 700; }

.badges { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; flex: 0 0 auto; }
.badge { display: flex; align-items: center; gap: 26px; padding: 26px 36px; border-radius: 18px; }
.badge.memb { border: 1.5px solid rgba(245,184,32,.28); background: linear-gradient(160deg, rgba(31,58,92,.4), rgba(15,39,66,.5)); box-shadow: 0 10px 26px rgba(0,0,0,.28); }
.badge.warr { border: 1.5px solid rgba(245,184,32,.5); border-left: 6px solid var(--gold);
  background: radial-gradient(90% 130% at 0% 50%, rgba(245,184,32,.16), transparent 60%), rgba(245,184,32,.06);
  box-shadow: 0 10px 28px rgba(0,0,0,.3), 0 0 30px rgba(245,184,32,.16); }
.badge .bic { width: 72px; height: 72px; border-radius: 50%; background: radial-gradient(circle at 38% 30%, rgba(245,184,32,.3), rgba(245,184,32,.12));
  border: 1.5px solid var(--gold); display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 36px; flex: 0 0 auto; box-shadow: 0 0 22px rgba(245,184,32,.4); }
.badge .bt { font-size: 25px; color: var(--ink); line-height: 1.32; }
.badge .bt b { color: var(--gold); font-weight: 700; }
/* sello de garantía — medalla con vida */
.guarantee-seal { position: relative; width: 96px; height: 96px; flex: 0 0 auto; border-radius: 50%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  background: radial-gradient(circle at 40% 32%, var(--gold-soft), var(--gold) 70%); color: var(--navy-deep);
  box-shadow: 0 0 30px rgba(245,184,32,.55), inset 0 2px 6px rgba(255,255,255,.4); }
.guarantee-seal::before { content: ''; position: absolute; inset: -9px; border-radius: 50%; border: 2.5px dashed rgba(245,184,32,.75);
  animation: sealspin 14s linear infinite; }
.guarantee-seal::after { content: ''; position: absolute; inset: -9px; border-radius: 50%; box-shadow: 0 0 26px rgba(245,184,32,.35);
  animation: sealpulse 2.6s ease-in-out infinite; }
@keyframes sealspin { to { transform: rotate(360deg); } }
@keyframes sealpulse { 0%,100% { opacity: .5; } 50% { opacity: 1; } }
.guarantee-seal .gs-num { font-family: 'Fraunces', serif; font-weight: 700; font-size: 40px; line-height: .9; }
.guarantee-seal .gs-lbl { font-size: 16px; font-weight: 800; letter-spacing: .14em; }

/* ============================================================
   MEMBRESÍA v2 — hero lifestyle + beneficios con icono
   ============================================================ */
.mem2 { flex: 1; min-height: 0; margin-top: 56px; display: flex; flex-direction: column; gap: 24px; justify-content: center; }
.mem-grid { flex: 1 1 auto; min-height: 0; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 26px; }
.mem-grid.six { grid-template-rows: repeat(3, 1fr); gap: 18px; }
.mem-item { display: flex; align-items: stretch; gap: 0; padding: 0; overflow: hidden; border: 1.5px solid var(--line); border-radius: 18px;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); }
.mem-item .mi-img { width: 300px; flex: 0 0 auto; overflow: hidden; border-right: 1.5px solid var(--line); }
.mem-grid.six .mem-item .mi-img { width: 230px; }
.mem-item .mi-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mem-item .mi-img.mascot { background: radial-gradient(75% 75% at 50% 38%, rgba(245,184,32,.16), rgba(10,28,51,.35) 70%); }
.mem-item .mi-img.mascot img { object-fit: contain; padding: 8px 6px 0; }
.mem-item .mi-img.mascot.trio img { padding: 14px 4px 0; }
.mem-item .mi-img.mascot.solo img { object-fit: contain; object-position: center bottom; padding: 0; }
.mem-item .mi-img.mascot img[src*="puntos"] { padding: 0; transform: scale(1.18); }
.mem-item .mt { flex: 1 1 auto; display: flex; align-items: center; padding: 0 36px; font-size: 29px; color: var(--ink); line-height: 1.3; }
.mem-grid.six .mem-item .mt { font-size: 30px; padding: 0 28px; }
.mem-item .mt b { color: var(--gold); font-weight: 700; }
.mem-item .mt .mi-note { font-size: .66em; font-weight: 500; color: var(--ink); opacity: .55; margin-left: .4em; letter-spacing: .01em; white-space: nowrap; }
.mem-free { flex: 0 0 auto; padding: 22px 36px; border-radius: 18px; background: rgba(245,184,32,.1); border: 1.5px solid var(--gold);
  display: flex; align-items: center; justify-content: center; gap: 28px;
  font-size: 32px; color: #fff; font-weight: 500; box-shadow: 0 0 40px rgba(245,184,32,.12); }
.mem-free b { color: var(--gold); font-weight: 800; }
/* protagonismo del bloque "5 socios → gratis" */
.mem-free.big { padding: 30px 50px; gap: 36px; font-size: 38px; border-width: 2.5px;
  background: radial-gradient(120% 160% at 50% 0%, rgba(245,184,32,.22), rgba(245,184,32,.08) 70%);
  box-shadow: 0 0 60px rgba(245,184,32,.3), inset 0 1px 0 rgba(255,255,255,.08); }
.mem-free.big .avatar-stack img, .mem-free.big .avatar-stack .more { width: 76px; height: 76px; border-width: 3px; }
.mem-free.big .avatar-stack .more { font-size: 30px; }
.mem-free .free-badge { display: inline-block; color: var(--navy-deep); font-weight: 800; font-family: 'Fraunces', serif;
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); padding: 6px 22px; border-radius: 999px; margin-left: 8px;
  box-shadow: 0 0 26px rgba(245,184,32,.55); }
.mem-free .mem-gift { flex: 0 0 auto; height: 132px; width: auto; object-fit: contain; margin: -18px -6px -18px 6px;
  transform: rotate(-11deg); filter: drop-shadow(0 8px 22px rgba(245,184,32,.5)); }
.avatar-stack { display: flex; align-items: center; flex: 0 0 auto; }
.avatar-stack img { width: 62px; height: 62px; border-radius: 50%; border: 2.5px solid var(--gold); object-fit: cover;
  margin-left: -18px; box-shadow: 0 4px 16px rgba(0,0,0,.45); }
.avatar-stack img:first-child { margin-left: 0; }
.avatar-stack .more { width: 62px; height: 62px; border-radius: 50%; border: 2.5px solid var(--gold); margin-left: -18px;
  background: var(--gold); color: var(--navy); font-family: 'Plus Jakarta Sans'; font-weight: 800; font-size: 26px;
  display: flex; align-items: center; justify-content: center; }

/* ============================================================
   L7 v2 · QUÉ INCLUYE — 3 negocios grandes + 4 extras
   ============================================================ */
.incl { flex: 1; min-height: 0; margin-top: 56px; display: flex; flex-direction: column; gap: 22px; justify-content: flex-start; }
.incl-main { flex: 0 0 auto; height: 470px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.biz { position: relative; display: flex; flex-direction: column; border: 1.5px solid var(--line); border-radius: 20px; overflow: hidden;
  background: linear-gradient(180deg, rgba(15,39,66,.55), rgba(10,28,51,.2)); text-decoration: none; color: inherit;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.biz:hover { transform: translateY(-5px); border-color: rgba(245,184,32,.65); box-shadow: 0 16px 40px rgba(0,0,0,.5); }
.biz .bbar { flex: 0 0 auto; display: flex; align-items: center; gap: 12px; padding: 12px 18px; background: rgba(6,16,28,.92); border-bottom: 1.5px solid var(--line); }
.biz .bbar .dots { display: flex; gap: 7px; flex: 0 0 auto; }
.biz .bbar .dots i { width: 11px; height: 11px; border-radius: 50%; background: rgba(245,184,32,.55); }
.biz .bbar .url { flex: 1 1 auto; font-size: 15px; color: var(--ink-dim); background: rgba(255,255,255,.06); border-radius: 7px; padding: 6px 14px; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.biz .biz-img { flex: 1 1 auto; min-height: 0; overflow: hidden; }
.biz .biz-img img,
.biz .biz-img video { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.biz .biz-body { flex: 0 0 auto; padding: 22px 26px 24px; display: flex; flex-direction: column; gap: 8px; }
.biz .biz-t { font-size: 27px; font-weight: 700; color: #fff; }
.biz .biz-d { font-size: 19px; color: var(--ink-dim); line-height: 1.3; min-height: 3.9em; }

.incl-extras { flex: 0 0 auto; min-height: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.extra { position: relative; display: flex; flex-direction: row; align-items: center; gap: 18px; padding: 18px 22px; border: 1.5px solid var(--line); border-radius: 16px;
  background: rgba(15,39,66,.42); text-decoration: none; color: inherit; transition: border-color .2s ease, transform .2s ease; }
.extra.linked:hover { transform: translateY(-3px); border-color: rgba(245,184,32,.6); }
.extra .ex-ic { width: 70px; height: 70px; border-radius: 16px; background: rgba(245,184,32,.12); border: 1.5px solid var(--line);
  display: flex; align-items: center; justify-content: center; flex: 0 0 auto; }
.extra .ex-ic img { width: 44px; height: 44px; object-fit: contain; }
.extra .ex-txt { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.extra .ex-t { font-size: 22px; font-weight: 700; color: #fff; line-height: 1.15; }
.extra .ex-d { font-size: 16px; color: var(--ink-dim); line-height: 1.3; }
.extra.linked::after { content: "↗"; position: absolute; top: 14px; right: 16px; color: var(--gold); font-size: 20px; font-weight: 800; opacity: .75; }

/* ============================================================
   DIVISOR — transición al plan de compensación (pattern interrupt)
   Lámina de respiro: fondo navy sólido, sin tarjetas, solo tipografía.
   ============================================================ */
.slide.divider-slide .stage {
  background:
    radial-gradient(80% 90% at 50% 18%, rgba(245,184,32,.10) 0%, transparent 55%),
    linear-gradient(180deg, var(--navy-deep) 0%, #081a30 50%, var(--navy-deep) 100%);
}
.divider {
  position: absolute; inset: 0; z-index: 3;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 0 200px;
}
.divider .eyebrow { align-self: center; margin-bottom: 46px; }
.divider .d-pre {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 64px; line-height: 1.1; color: var(--ink);
}
.divider .d-main {
  font-family: 'Fraunces', serif; font-weight: 600;
  font-size: 88px; line-height: 1.08; letter-spacing: -.015em;
  color: #fff; margin-top: 18px; max-width: 22ch;
}
.divider .d-main b { color: var(--gold); font-weight: 700; }
.divider .d-rule { width: 90px; height: 4px; background: var(--gold); border-radius: 2px; margin: 52px 0 40px; box-shadow: 0 0 22px rgba(245,184,32,.6); }
.divider .d-foot {
  font-size: 30px; font-weight: 500; color: var(--ink-dim);
  letter-spacing: .01em; max-width: 40ch;
}
.divider .d-foot b { color: var(--gold-soft); font-weight: 600; }

/* ============================================================
   PLAN — dos tipos de ingreso (lineal vs residual)
   ============================================================ */
.pfcard.linear { border-color: rgba(255,128,116,.4); }
.pfcard.residual { border-color: rgba(245,184,32,.45);
  background: radial-gradient(95% 70% at 50% 0%, rgba(245,184,32,.12), transparent 60%), linear-gradient(180deg, var(--navy-card), var(--navy-deep)); }
.pf-kicker.red { color: #ff8b7a; }
.inc-row { display: flex; gap: 26px; justify-content: center; align-items: flex-start; }
.inc-item { display: flex; flex-direction: column; align-items: center; gap: 11px; width: 120px; }
.inc-av { position: relative; width: 104px; height: 104px; }
.inc-av .pfav { width: 104px; height: 104px; }
/* avatares del panel lineal igualados al tamaño de los tiles de negocios (138px) */
.inc-row.lineal3 .inc-item { width: 150px; gap: 12px; }
.inc-row.lineal3 .inc-av, .inc-row.lineal3 .inc-av .pfav { width: 138px; height: 138px; }
.inc-row.lineal3 .inc-av .clk { width: 46px; height: 46px; bottom: -4px; right: -4px; }
.inc-row.lineal3 .inc-av .clk svg { width: 26px; height: 26px; }
.inc-row.lineal3 .inc-lbl { font-size: 22px; font-weight: 700; }
.inc-av .clk { position: absolute; bottom: -6px; right: -6px; width: 40px; height: 40px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; background: #21364f; border: 2px solid #ff8b7a; box-shadow: 0 0 10px rgba(255,128,116,.4); }
.inc-av .clk svg { width: 22px; height: 22px; fill: #ff8b7a; }
.inc-tile { width: 104px; height: 104px; border-radius: 20px; overflow: hidden; }
.inc-tile img { width: 100%; height: 100%; object-fit: cover; display: block; }
.inc-lbl { font-size: 22px; font-weight: 700; color: #fff; line-height: 1.1; text-align: center; }
.inc-chart { width: 100%; margin-top: 8px; }
.inc-chart svg { width: 100%; height: 104px; display: block; overflow: visible; }
.inc-chart .axis { stroke: rgba(255,255,255,.14); stroke-width: 2; stroke-dasharray: 4 6; }
.inc-chart .line-red { fill: none; stroke: #ff8b7a; stroke-width: 4; stroke-linecap: round; stroke-linejoin: round; }
.inc-chart .line-gold { fill: none; stroke: var(--gold); stroke-width: 4; stroke-linecap: round; stroke-linejoin: round; filter: drop-shadow(0 0 8px rgba(245,184,32,.5)); }
.inc-chart .dot-red { fill: #ff8b7a; }
.inc-chart .dot-gold { fill: var(--gold); }
.inc-chart .clbl { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 15px; font-weight: 700; }
.inc-chart .clbl.red { fill: #ff8b7a; }
.inc-chart .clbl.gold { fill: var(--gold-soft); }
.inc-chart .clbl.muted { fill: var(--ink-dim); }
.inc-chart .pum { fill: #ff5040; font-family: 'Fraunces', serif; font-weight: 800; font-size: 22px; }
.inc-chart .zero { fill: #ff8b7a; font-weight: 800; font-size: 18px; }

/* income v2 — énfasis, dolor, más ejemplos, secuencial */
.pf-kicker.big { align-self: flex-start; font-size: 30px; letter-spacing: .1em; padding: 7px 22px; border-radius: 999px; }
.pf-kicker.big.red { color: #ff8b7a; background: rgba(255,128,116,.12); border: 1.5px solid rgba(255,128,116,.5); }
.pf-kicker.big.gold { color: var(--gold); background: rgba(245,184,32,.12); border: 1.5px solid rgba(245,184,32,.5); }
.pfcard.linear { border-color: rgba(255,128,116,.5);
  background: radial-gradient(95% 70% at 50% 0%, rgba(255,80,70,.1), transparent 60%), linear-gradient(180deg, var(--navy-card), var(--navy-deep)); }
.inc-chips { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.inc-chips .chip { font-size: 18px; padding: 7px 16px; border-radius: 999px; background: rgba(255,255,255,.05); border: 1px solid var(--line); color: var(--ink-dim); }
.inc-row.five { gap: 22px; flex-wrap: nowrap; }
.inc-row.five .inc-item { width: 148px; gap: 12px; }
.inc-row.five .inc-tile { width: 138px; height: 138px; border-radius: 22px; }
.inc-row.five .inc-lbl { font-size: 22px; font-weight: 700; }
.pf-foot.pain { margin-top: auto; border: 1.5px solid rgba(255,128,116,.5); border-radius: 14px;
  background: rgba(255,80,70,.1); padding: 18px 22px; color: #ffd9d3; font-size: 23px; line-height: 1.36; }
.pf-foot.pain b { color: #ff6a5a; font-weight: 800; }
.pf-foot.gain { margin-top: auto; border: 1.5px solid rgba(245,184,32,.45); border-radius: 14px;
  background: rgba(245,184,32,.1); padding: 18px 22px; color: var(--gold-soft); font-size: 23px; line-height: 1.36; }
.pf-foot.gain b { color: var(--gold); font-weight: 800; }
.inc-chart .line-red { stroke-width: 5; filter: drop-shadow(0 0 7px rgba(255,90,80,.65)); }
/* punto luminoso que recorre las gráficas */
.spark-red { fill: #ffd2cb; filter: drop-shadow(0 0 7px #ff5040) drop-shadow(0 0 3px #fff); }
.spark-gold { fill: #fff6da; filter: drop-shadow(0 0 8px var(--gold)) drop-shadow(0 0 3px #fff); }
/* número creciente de ingresos (residual) */
.inc-chart.res { position: relative; }
.res-counter { position: absolute; top: 48px; right: 52px; white-space: nowrap;
  font-family: 'Fraunces', serif; font-weight: 800; font-size: 32px; color: var(--gold);
  text-shadow: 0 0 14px rgba(245,184,32,.65); }
.res-counter::after { content: ' €'; font-size: 19px; }

/* fragmentos — revelado secuencial por clic */
.frag { opacity: 0; transform: translateY(26px) scale(.985); pointer-events: none;
  transition: opacity .55s ease, transform .55s cubic-bezier(.2,.75,.25,1); }
.frag.shown { opacity: 1; transform: none; pointer-events: auto; }

/* ============================================================
   PLAN — dos perfiles (clientes vs socios)
   ============================================================ */
.profiles { flex: 1; min-height: 0; margin-top: 44px; display: grid; grid-template-columns: 1fr 1fr; gap: 42px; align-items: stretch; }
.pfcard { border-radius: 24px; padding: 46px 44px; display: flex; flex-direction: column; gap: 22px;
  background: linear-gradient(180deg, var(--navy-card), rgba(10,28,51,.5)); border: 1.5px solid var(--line); }
.pfcard.socio { border-color: rgba(245,184,32,.45);
  background: radial-gradient(95% 70% at 50% 0%, rgba(245,184,32,.12), transparent 60%), linear-gradient(180deg, var(--navy-card), var(--navy-deep)); }
.pf-ic { width: 96px; height: 96px; border-radius: 22px; display: flex; align-items: center; justify-content: center;
  background: rgba(245,184,32,.1); border: 1.5px solid rgba(245,184,32,.35); }
.pf-ic img { width: 56px; height: 56px; object-fit: contain; }
.pf-kicker { font-size: 22px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); }
.pf-title { font-family: 'Fraunces', serif; font-weight: 600; font-size: 46px; color: #fff; line-height: 1.05; margin-top: -6px; }
.pf-desc { font-size: 26px; color: var(--ink-dim); line-height: 1.4; }
.pf-foot { margin-top: auto; font-size: 22px; color: var(--ink); border-top: 1px solid var(--line); padding-top: 22px; line-height: 1.35; }
.pf-foot .pl { color: var(--ink-dim); font-weight: 700; }
.pf-foot b { color: var(--gold); font-weight: 700; }

/* avatar circular compartido por los visuales de perfiles */
.pfav { width: 132px; height: 132px; border-radius: 50%; overflow: hidden; border: 3px solid var(--gold);
  background: var(--navy-card); box-shadow: 0 0 18px rgba(245,184,32,.4); flex: 0 0 auto; }
.pfav img { width: 100%; height: 100%; object-fit: cover; display: block; }

.pf-visual { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px; }
.pf-cap { font-size: 24px; color: var(--ink-dim); }

/* clientes — gente que consume, con 3 ramas a lo que compra */
.cli-row { display: flex; gap: 36px; align-items: flex-start; justify-content: center; }
.cli { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.cli .rays { display: flex; gap: 16px; }
.cli .ray { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.cli .ray .rl { width: 2.5px; height: 18px; background: rgba(245,184,32,.55); }
.cli .ray .ric { width: 64px; height: 64px; border-radius: 15px; overflow: hidden;
  display: flex; align-items: center; justify-content: center; }
.cli .ray .ric img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cli .ray .ric svg { width: 36px; height: 36px; fill: var(--gold); }

/* socios — duplican: tienditas digitales en filas horizontales por niveles */
.shopgrid { display: flex; flex-direction: column; align-items: center; gap: 30px; }
.sg-row { display: flex; gap: 24px; justify-content: center; align-items: center; }
.store { position: relative; border-radius: 18px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(180deg, var(--navy-card), var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.4); }
.store .st-img { width: 100%; height: 100%; object-fit: cover; border-radius: 16px; display: block; }
.store.big { width: 162px; height: 162px; box-shadow: 0 0 30px rgba(245,184,32,.3); }
.store.sm { width: 106px; height: 106px; }
.store.xs { width: 80px; height: 80px; }
/* círculo de la foto: encima de la esquina, mitad dentro / mitad fuera del icono */
.store .av-corner { position: absolute; border-radius: 50%; overflow: hidden; border: 3px solid var(--gold);
  box-shadow: 0 0 14px rgba(245,184,32,.55); z-index: 2; background: var(--navy-card); }
.store.big .av-corner { top: -18px; right: -18px; width: 66px; height: 66px; }
.store.sm .av-corner { top: -13px; right: -13px; width: 46px; height: 46px; border-width: 2.5px; }
.store.xs .av-corner { top: -11px; right: -11px; width: 36px; height: 36px; border-width: 2px; }
.store .av-corner img { width: 100%; height: 100%; object-fit: cover; }

/* ---- Animación de moneditas (flujo de dinero hacia la tienda principal) ---- */
.pf-visual.mflow { position: relative; }
.store.big.mf-top { width: 146px; height: 146px; }
.mf-top { margin-bottom: 8px; }
.coins { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 6; }
.coin { position: absolute; width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 16px; color: var(--navy-deep);
  background: radial-gradient(circle at 35% 30%, var(--gold-soft), var(--gold) 72%);
  box-shadow: 0 0 11px rgba(245,184,32,.65); border: 1.5px solid rgba(255,233,170,.8);
  opacity: 0; animation: coinRise var(--dur, 2.8s) ease-in infinite; animation-delay: var(--d, 0s); }
@keyframes coinRise {
  0%   { transform: translate(0, 0) scale(.5); opacity: 0; }
  15%  { opacity: 1; }
  70%  { opacity: 1; }
  100% { transform: translate(var(--dx, 0), var(--dy, -240px)) scale(1); opacity: 0; }
}

/* ============================================================
   PLAN DE COMPENSACIÓN — resumen "7 formas de generar ingresos"
   ============================================================ */
.plan7 { flex: 1; min-height: 0; margin-top: 40px; display: flex; flex-direction: column; gap: 26px; justify-content: center; }
.plan7-row { display: grid; gap: 24px; }
.plan7-row.top { grid-template-columns: repeat(4, 1fr); }
.plan7-row.bot { grid-template-columns: repeat(3, 1fr); width: 75%; margin: 0 auto; }
.pway {
  position: relative; display: flex; align-items: center; gap: 22px;
  padding: 26px 28px; border-radius: 18px;
  background: linear-gradient(180deg, var(--navy-card) 0%, rgba(10,28,51,.5) 100%);
  border: 1.5px solid var(--line);
}
.pway .pnum {
  flex: 0 0 auto; width: 64px; height: 64px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-weight: 700; font-size: 34px; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold));
  box-shadow: 0 0 22px rgba(245,184,32,.45);
}
.pway .pbody { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.pway .pname { font-size: 25px; font-weight: 800; color: #fff; line-height: 1.12; }
.pway .pdesc { font-size: 18px; color: var(--ink-dim); line-height: 1.28; }

/* ============================================================
   PLAN DE COMPENSACIÓN — plantilla de BONO (reutilizable los 7)
   ============================================================ */
.bono-tag {            /* pill numerada del bono, dentro del head-center */
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 22px; font-weight: 800; letter-spacing: .04em;
  color: var(--navy-deep); background: linear-gradient(145deg, var(--gold-soft), var(--gold));
  padding: 8px 22px; border-radius: 999px; align-self: center; margin-bottom: 18px;
  box-shadow: 0 0 22px rgba(245,184,32,.4);
}
.bono { flex: 1; min-height: 0; margin-top: 44px; display: grid; grid-template-columns: 0.88fr 1.12fr; gap: 42px; align-items: stretch; }
.bono-left { display: flex; flex-direction: column; gap: 24px; justify-content: flex-start; }
.bono-pay { font-size: 30px; line-height: 1.42; color: var(--ink-dim); flex: 0 0 auto; }
.bono-pay b { color: #fff; font-weight: 700; }
.bono-pay .g { color: var(--gold); font-weight: 700; }
.b-chips { display: flex; flex-direction: column; gap: 20px; flex: 1; }
.b-chip {
  position: relative; overflow: hidden; border-radius: 20px; padding: 30px 36px; flex: 1;
  background: linear-gradient(180deg, var(--navy-card) 0%, rgba(10,28,51,.5) 100%);
  border: 1.5px solid rgba(245,184,32,.32); display: flex; flex-direction: row; align-items: center; gap: 30px;
}
.b-chip::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: .8; }
.b-chip::after { content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(70% 80% at 18% 50%, rgba(245,184,32,.14), transparent 65%); }
.b-chip .bc-amt { position: relative; z-index: 1; font-family: 'Fraunces', serif; font-weight: 700; font-size: 74px;
  color: var(--gold); line-height: 1; min-width: 150px; white-space: nowrap; flex: 0 0 auto; animation: amtGlow 2.6s ease-in-out infinite; }
.b-chip .bc-lbl { position: relative; z-index: 1; font-size: 26px; color: var(--ink-dim); line-height: 1.3; }
@keyframes amtGlow { 0%, 100% { text-shadow: 0 0 0 rgba(245,184,32,0); } 50% { text-shadow: 0 0 22px rgba(245,184,32,.65); } }
.bono-ex {
  border-radius: 24px; padding: 40px 48px;
  background:
    radial-gradient(90% 80% at 50% 0%, rgba(245,184,32,.12) 0%, transparent 60%),
    linear-gradient(180deg, var(--navy-card) 0%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.35);
  display: flex; flex-direction: column; gap: 18px; justify-content: center; align-items: center; text-align: center;
}
.bono-ex .be-tag { font-size: 23px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; color: var(--gold); }
.bono-ex .be-line { font-size: 31px; color: var(--ink); line-height: 1.3; }
.bono-ex .be-line b { color: #fff; font-weight: 700; }
.bono-ex .be-big { font-family: 'Fraunces', serif; font-weight: 700; font-size: 104px; color: #fff; line-height: 1.0; }
.bono-ex .be-big b { color: var(--gold); }
.bono-ex .be-note { font-size: 26px; color: var(--ink-dim); line-height: 1.3; white-space: nowrap; }

/* fila de personas (ejemplo visual del bono) */
.ppl-row { display: flex; gap: 18px; justify-content: center; align-items: flex-start; flex-wrap: nowrap; }
.ppl { display: flex; flex-direction: column; align-items: center; gap: 12px; }
.ppl .av {
  width: 92px; height: 92px; border-radius: 50%; overflow: hidden;
  border: 3px solid var(--gold); background: var(--navy-card);
  box-shadow: 0 0 20px rgba(245,184,32,.4);
}
.ppl .av img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ppl .pc { font-size: 26px; font-weight: 800; color: var(--gold); white-space: nowrap; }

/* Bono 1 — ejemplo animado: personas aparecen una a una */
.bono-ex .ppl { opacity: 0; transform: scale(.4); transition: opacity .4s ease, transform .5s cubic-bezier(.2,.9,.3,1.35); }
.bono-ex .ppl.in { opacity: 1; transform: none; }
.bono-ex .ppl.pop .av { animation: pplPop 1s ease; }
@keyframes pplPop { 0% { box-shadow: 0 0 0 rgba(245,184,32,0); } 28% { box-shadow: 0 0 36px rgba(245,184,32,.95); } 100% { box-shadow: 0 0 20px rgba(245,184,32,.4); } }
.ppl.more .av { border: 2.5px dashed rgba(245,184,32,.7); background: transparent; box-shadow: none; display: flex; align-items: center; justify-content: center; }
.ppl.more .av .plus { font-family: 'Fraunces', serif; font-weight: 700; font-size: 48px; color: var(--gold); line-height: 1; }
.ppl.more .pc { color: var(--ink-dim); font-weight: 700; }

/* Bono 1 — banner de membresía gratis (3er fragmento) */
.bono-bonus { flex: 0 0 auto; margin-top: 24px; display: flex; align-items: center; gap: 28px;
  border-radius: 20px; padding: 20px 34px; position: relative; overflow: hidden;
  background: linear-gradient(100deg, rgba(245,184,32,.18), rgba(245,184,32,.05));
  border: 1.5px solid rgba(245,184,32,.5); box-shadow: 0 0 34px rgba(245,184,32,.2); }
.bono-bonus .bb-ic { width: 92px; height: 92px; flex: 0 0 auto; border-radius: 18px; overflow: hidden; }
.bono-bonus .bb-ic img { width: 100%; height: 100%; object-fit: cover; }
.bono-bonus .bb-txt { display: flex; flex-direction: column; gap: 3px; flex: 0 0 auto; }
.bono-bonus .bb-stampwrap { flex: 1; display: flex; align-items: center; justify-content: center; }
.bono-bonus .bb-top { font-size: 22px; color: var(--gold-soft); font-weight: 600; }
.bono-bonus .bb-main { font-family: 'Fraunces', serif; font-size: 42px; color: #fff; font-weight: 600; line-height: 1.08; }
.bono-bonus .bb-main b { color: var(--gold); }
.bono-bonus .bb-sub { font-size: 26px; color: var(--ink-dim); }
.bono-bonus .bb-stamp { flex: 0 0 auto; font-family: 'Fraunces', serif; font-weight: 800; font-size: 48px;
  color: var(--navy-deep); background: linear-gradient(145deg, var(--gold-soft), var(--gold));
  padding: 16px 40px; border-radius: 16px; transform: rotate(-7deg); box-shadow: 0 0 26px rgba(245,184,32,.65); letter-spacing: .06em; }
.bono-bonus.shown .bb-stamp { animation: stampPop .6s cubic-bezier(.2,.9,.3,1.5) .2s both; }
@keyframes stampPop { 0% { transform: rotate(-7deg) scale(0); } 60% { transform: rotate(-7deg) scale(1.22); } 100% { transform: rotate(-7deg) scale(1); } }

/* ---- Stepper de bonos (1…7) con nombre, arriba de cada lámina ---- */
.bono-steps { display: flex; align-items: flex-start; justify-content: center; margin-top: -30px; margin-bottom: 34px; flex: 0 0 auto; }
.bstep { position: relative; display: flex; flex-direction: column; align-items: center; gap: 10px; width: 162px; }
.bstep-node { width: 54px; height: 54px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 23px; flex: 0 0 auto; z-index: 2;
  border: 1.5px solid var(--line); color: var(--ink-dim); background: #0c2138; transition: transform .2s, box-shadow .2s; }
.bstep-name { font-size: 17.5px; font-weight: 600; color: var(--ink-dim); text-align: center; line-height: 1.18; max-width: 146px; }
/* conector hacia el siguiente, a la altura del círculo */
.bstep::after { content: ''; position: absolute; top: 26px; left: calc(50% + 31px); width: calc(100% - 62px); height: 2.5px; background: var(--line); z-index: 1; }
.bstep:last-child::after { display: none; }
.bstep.done::after { background: rgba(245,184,32,.55); }
.bstep.done .bstep-node { border-color: rgba(245,184,32,.55); color: var(--gold); }
.bstep.done .bstep-name { color: rgba(245,184,32,.72); }
.bstep.active .bstep-node { background: linear-gradient(145deg, var(--gold-soft), var(--gold)); color: var(--navy-deep);
  border-color: var(--gold); box-shadow: 0 0 18px rgba(245,184,32,.55); transform: scale(1.14); }
.bstep.active .bstep-name { color: var(--gold); font-weight: 800; }

/* ---- BONO 2 · matriz 2×15 (lámina especial) ---- */
.mtx { flex: 1; min-height: 0; margin-top: 26px; display: grid; grid-template-columns: 0.82fr 1.18fr; gap: 46px; align-items: center; }
.mtx-left { display: flex; flex-direction: column; gap: 30px; }
.mtx-left .bono-pay { font-size: 29px; }
/* chip protagonista: 1 € al mes / 10 € al año */
.mchip { display: flex; align-items: center; gap: 24px; align-self: stretch; position: relative; overflow: hidden;
  background: linear-gradient(120deg, rgba(245,184,32,.18), rgba(245,184,32,.05));
  border: 1.5px solid rgba(245,184,32,.5); border-radius: 20px; padding: 26px 32px; box-shadow: 0 0 32px rgba(245,184,32,.2); }
.mchip::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: .85; }
.mchip .mc-amt { font-family: 'Fraunces', serif; font-weight: 700; font-size: 78px; color: var(--gold); line-height: 1;
  animation: amtGlow 2.6s ease-in-out infinite; }
.mchip .mc-lbl { font-size: 25px; color: var(--ink); line-height: 1.3; }
.mchip .mc-lbl b { color: var(--gold-soft); }

/* matriz de avatares interconectada (árbol binario) */
.mtree { position: relative; width: 100%; height: 500px; }
.mtree::before { content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(58% 64% at 50% 32%, rgba(245,184,32,.1), transparent 70%); }
.mtree-links { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
.mtree-links .mlink { fill: none; stroke: rgba(245,184,32,.55); stroke-width: 3; stroke-linecap: round;
  filter: drop-shadow(0 0 4px rgba(245,184,32,.5)); opacity: 0; transition: opacity 1.1s ease; }
.mtree-links .mlink.shown { opacity: 1; }
.mav { position: absolute; border-radius: 50%; overflow: hidden; border: 2.5px solid var(--gold);
  background: var(--navy-card); z-index: 2; opacity: 0; transform: scale(.5);
  transition: opacity 1s ease, transform 1.15s cubic-bezier(.2,.9,.3,1.35);
  box-shadow: 0 0 12px rgba(245,184,32,.4), 0 4px 12px rgba(0,0,0,.45); }
.mav.shown { opacity: 1; transform: none; }
/* estado intro: la tienda de arriba aparece en grande y centrada, luego se reduce a su sitio */
.mav.l1.intro { transform: translateY(195px) scale(2.85); z-index: 5; }
.mav::after { content: ''; position: absolute; inset: 0; border-radius: 50%; pointer-events: none;
  box-shadow: inset 0 0 0 2px rgba(255,233,170,.25), inset 0 -8px 14px rgba(0,0,0,.35); }
.mav.l1 { border-width: 3px; box-shadow: 0 0 30px rgba(245,184,32,.8), 0 4px 14px rgba(0,0,0,.5); }
.mav img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* variante tienda: cada nodo es una tiendita con la cara de su dueño en la esquina */
.mav.mstore { border: none; border-radius: 16px; overflow: visible; background: none; box-shadow: none; }
.mav.mstore::after { display: none; }
.mav.mstore .nst { width: 100%; height: 100%; object-fit: cover; border-radius: 14px; display: block;
  border: 1.5px solid rgba(245,184,32,.5); box-shadow: 0 0 12px rgba(245,184,32,.4), 0 4px 12px rgba(0,0,0,.45); }
.mav.mstore .nav { position: absolute; top: -10px; right: -10px; width: 42%; height: 42%; border-radius: 50%; overflow: hidden;
  border: 2.5px solid var(--gold); background: var(--navy-card); box-shadow: 0 0 10px rgba(245,184,32,.55); }
.mav.mstore.l1 .nav { border-width: 3px; }
.mav.mstore .nav img { width: 100%; height: 100%; object-fit: cover; }
.mav.mstore .mav-num { position: absolute; bottom: -22px; left: 50%; transform: translateX(-50%); z-index: 4;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 16px; color: var(--gold);
  background: rgba(10,28,51,.9); border: 1px solid rgba(245,184,32,.5); border-radius: 999px; padding: 2px 9px;
  white-space: nowrap; box-shadow: 0 2px 8px rgba(0,0,0,.55); }
.mav.mstore.l3 .mav-num, .mav.mstore.l4 .mav-num { font-size: 18px; bottom: -20px; padding: 2px 8px; }
/* moneditas de 1 € que suben siguiendo las líneas del árbol hasta la cima */
.mcoin { position: absolute; left: 0; top: 0; width: 34px; height: 34px; border-radius: 50%; z-index: 3; pointer-events: none;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 14px; color: var(--navy-deep);
  background: radial-gradient(circle at 35% 30%, var(--gold-soft), var(--gold) 72%);
  box-shadow: 0 0 12px rgba(245,184,32,.75); border: 1.5px solid rgba(255,233,170,.85);
  offset-rotate: 0deg; opacity: 0;
  animation-name: mcoinPath; animation-timing-function: linear; animation-iteration-count: infinite; }
@keyframes mcoinPath {
  0% { offset-distance: 0%; opacity: 0; }
  10% { opacity: 1; }
  86% { opacity: 1; }
  100% { offset-distance: 100%; opacity: 0; }
}
.dup { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.dup .dstep { display: flex; flex-direction: column; align-items: center; gap: 9px; }
.dup .dnodes { display: grid; grid-template-columns: repeat(4, 11px); gap: 5px; justify-content: center; max-width: 53px; }
.dup .dot { width: 11px; height: 11px; border-radius: 50%; background: linear-gradient(145deg, var(--gold-soft), var(--gold)); box-shadow: 0 0 7px rgba(245,184,32,.5); }
.dup .dnum { font-size: 24px; font-weight: 800; color: #fff; }
.dup .dx { color: var(--gold); font-weight: 800; font-size: 20px; }
.dup .dmore { font-size: 26px; color: var(--ink-dim); font-weight: 700; }
.mchart { display: flex; align-items: flex-end; justify-content: center; gap: 30px; height: 430px; }
.mbar { display: flex; flex-direction: column; align-items: center; gap: 12px; justify-content: flex-end; }
.mbar .mb-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 25px; color: #fff; white-space: nowrap; }
.mbar .mb-col { width: 82px; border-radius: 12px 12px 0 0;
  background: linear-gradient(180deg, #1d3a5c, #13283f); border: 1.5px solid var(--line); border-bottom: none; }
.mbar .mb-lvl { font-size: 18px; color: var(--ink-dim); white-space: nowrap; }
.mbar.hot .mb-col { background: linear-gradient(180deg, var(--gold-soft), var(--gold)); border-color: var(--gold); box-shadow: 0 0 28px rgba(245,184,32,.5); }
.mbar.hot .mb-val { color: var(--gold); }
.mbar.hot .mb-lvl { color: var(--gold-soft); font-weight: 700; }
/* Bono 3 · comisiones directas */
.b3 { flex: 1; min-height: 0; margin-top: 30px; display: flex; flex-direction: column; gap: 30px; }
.b3-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
/* Bono 3 sin tabla de categorías — tarjetas verticales grandes que llenan la lámina */
.b3.big { margin-top: 40px; }
.b3.big .b3-cards { flex: 1 1 auto; min-height: 0; gap: 36px; align-items: stretch; }
.b3.big .b3card { flex-direction: column; justify-content: flex-start; text-align: center; gap: 22px; padding: 40px 34px 30px; }
.b3.big .b3card .b3txt { align-items: center; gap: 16px; }
.b3.big .b3card .b3pct { font-size: 82px; position: relative; margin-bottom: -12px; z-index: 0; }
.b3.big .b3card .b3pct::before { content: ''; position: absolute; left: 50%; top: 52%; transform: translate(-50%, -50%); width: 128%; height: 200%; z-index: -1; pointer-events: none; border-radius: 50%; background: radial-gradient(closest-side, rgba(245,184,32,.34), rgba(245,184,32,.12) 55%, rgba(245,184,32,0) 78%); filter: blur(16px); }
.b3.big .b3card .b3logo { height: 98px; display: flex; align-items: center; justify-content: center; }
.b3.big .b3card .b3logo img { width: auto; max-width: 100%; object-fit: contain; display: block; }
.b3.big .b3card .b3logo.naturkin img { height: 70px; }
.b3.big .b3card .b3logo.viajaya img { height: 84px; }
.b3.big .b3card .b3logo.tomaya img { height: 68px; }
.b3.big .b3card .b3sub { font-size: 24px; margin-top: 2px; color: #fff; }
/* Mascota: emerge del borde inferior de la tarjeta (el contenedor la recorta) */
.b3.big .b3card .b3ic.mascot { margin: auto -34px -30px; width: auto; align-self: stretch; overflow: hidden; border: none; border-radius: 0 0 19px 19px; background: none; box-shadow: none; display: flex; align-items: flex-start; justify-content: center; }
.b3.big .b3card .b3ic.mascot img { width: auto; max-width: none; margin: 0; padding: 0; object-fit: contain; filter: drop-shadow(0 12px 22px rgba(0,0,0,.4)); }
/* Las tres mascotas igualadas a Tommy — misma escala + mismo recorte (cabeza a la cintura) */
.b3.big .b3card .b3ic.mascot { height: 300px; }
.b3.big .b3card .b3ic.mascot img { height: 410px; }
.b3.big .b3card .b3badge { font-size: 22px; padding: 12px 28px; top: -26px; }
.b3card { position: relative; border-radius: 20px; padding: 26px 30px; display: flex; align-items: center; gap: 22px;
  background: linear-gradient(155deg, rgba(31,58,92,.55) 0%, var(--navy-card) 52%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.3); box-shadow: 0 12px 30px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.05); }
.b3card::before { content: ''; position: absolute; top: 0; left: 22px; right: 22px; height: 3px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity: .7; }
.b3card.hot { border-color: rgba(245,184,32,.6); box-shadow: 0 12px 34px rgba(0,0,0,.42), 0 0 32px rgba(245,184,32,.22), inset 0 1px 0 rgba(255,233,170,.12); }
.b3card .b3ic { position: relative; z-index: 1; width: 88px; height: 88px; border-radius: 18px; overflow: hidden; flex: 0 0 auto;
  border: 1.5px solid rgba(245,184,32,.4); box-shadow: 0 0 20px rgba(245,184,32,.3); }
.b3card .b3ic img { width: 100%; height: 100%; object-fit: cover; display: block; }
.b3card .b3ic.mascot { background: radial-gradient(70% 70% at 50% 35%, rgba(245,184,32,.14), var(--navy-deep)); }
.b3card .b3ic.mascot img { object-fit: contain; padding: 6px; }
.b3card .b3txt { position: relative; z-index: 1; }
.b3card .b3txt { display: flex; flex-direction: column; }
.b3card .b3pct { font-family: 'Fraunces', serif; font-weight: 700; font-size: 46px; color: var(--gold); line-height: 1; white-space: nowrap;
  text-shadow: 0 0 20px rgba(245,184,32,.45); }
.b3card .b3name { font-size: 25px; font-weight: 800; color: #fff; margin-top: 3px; }
.b3card .b3sub { font-size: 17px; color: var(--ink-dim); line-height: 1.25; margin-top: 3px; }
.b3card .b3badge { position: absolute; top: -32px; right: 16px; z-index: 3; font-size: 19px; font-weight: 800; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); padding: 10px 24px; border-radius: 999px;
  box-shadow: 0 6px 18px rgba(0,0,0,.35), 0 0 22px rgba(245,184,32,.6); white-space: nowrap; }
.b3-esc { flex: 1; min-height: 0; border-radius: 20px; padding: 26px 36px; background: linear-gradient(180deg, var(--navy-card), rgba(10,28,51,.5));
  border: 1.5px solid var(--line); display: flex; flex-direction: column; gap: 18px; }
.b3esc-head { font-size: 24px; color: var(--ink-dim); }
.b3esc-head b { color: #fff; font-weight: 700; }
.b3catcards { flex: 1; min-height: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; align-items: stretch; }
.b3cc { position: relative; overflow: hidden; border-radius: 18px; padding: 22px 26px; display: flex; flex-direction: column; gap: 14px; justify-content: center;
  background: linear-gradient(160deg, rgba(31,58,92,.45) 0%, var(--navy-card) 58%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.22); box-shadow: 0 12px 28px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05); }
.b3cc::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, transparent, rgba(245,184,32,.7), transparent); opacity: .6; }
.b3cc .cc-cat { position: relative; z-index: 1; font-size: 36px; font-weight: 800; color: #fff; text-align: center; letter-spacing: .01em;
  padding-bottom: 16px; border-bottom: 1px solid rgba(245,184,32,.22); }
.b3cc .cc-row { position: relative; z-index: 1; display: flex; justify-content: space-between; align-items: baseline; gap: 16px; }
.b3cc .cc-v { text-align: left; font-size: 20px; color: #fff; font-weight: 700; line-height: 1.15; }
.b3cc .cc-p { font-family: 'Fraunces', serif; font-weight: 700; font-size: 25px; color: var(--ink); white-space: nowrap; display: inline-flex; align-items: baseline; gap: 8px; }
.b3cc .cc-plus { color: var(--gold); font-size: 25px; text-shadow: 0 0 14px rgba(245,184,32,.45); }
/* Empresario — tope premium */
.b3cc.hot { border-color: rgba(245,184,32,.65);
  background: radial-gradient(90% 70% at 50% 0%, rgba(245,184,32,.18), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.5), var(--navy-card) 60%, var(--navy-deep));
  box-shadow: 0 14px 34px rgba(0,0,0,.4), 0 0 34px rgba(245,184,32,.28); }
.b3cc.hot::before { opacity: 1; height: 4px; background: linear-gradient(90deg, var(--gold-soft), var(--gold), var(--gold-soft)); }
.b3cc.hot::after { content: '★'; position: absolute; top: 12px; right: 16px; color: var(--gold); font-size: 18px; opacity: .85; }
.b3cc.hot .cc-cat { color: var(--gold); border-bottom-color: rgba(245,184,32,.4); }
.b3cc.hot .cc-p { color: var(--gold-soft); text-shadow: 0 0 20px rgba(245,184,32,.6); }
.b3-ex { padding: 34px 40px; }

/* ── Bono 3b · ejemplos reales ── */
.b3ex { flex: 1; min-height: 0; display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; align-items: stretch; margin-top: 38px; }
.b3ex-card { position: relative; display: flex; flex-direction: column; border-radius: 22px; padding: 30px 32px 26px;
  background: linear-gradient(160deg, rgba(31,58,92,.5) 0%, var(--navy-card) 56%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 16px 34px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.05); }
.b3ex-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; border-radius: 22px 22px 0 0;
  background: linear-gradient(90deg, transparent, rgba(245,184,32,.7), transparent); opacity: .6; }
.b3ex-head { display: flex; align-items: center; gap: 18px; padding-bottom: 22px; border-bottom: 1px solid rgba(245,184,32,.2); }
.b3ex-mascot { width: 78px; height: 78px; border-radius: 50%; flex: 0 0 auto; overflow: hidden;
  background: radial-gradient(70% 70% at 50% 35%, rgba(245,184,32,.16), var(--navy-deep)); border: 2px solid rgba(245,184,32,.5);
  display: flex; align-items: center; justify-content: center; box-shadow: 0 0 18px rgba(245,184,32,.28); }
.b3ex-mascot img { width: 100%; height: 100%; object-fit: contain; }
.b3ex-brand { font-family: 'Fraunces', serif; font-weight: 700; font-size: 32px; color: #fff; line-height: 1; }
.b3ex-tag { margin-left: auto; font-size: 15px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--gold);
  background: rgba(245,184,32,.12); border: 1px solid rgba(245,184,32,.35); padding: 7px 15px; border-radius: 999px; }
.b3ex-calc { display: flex; flex-direction: column; gap: 0; padding: 18px 0 4px; }
.b3ex-calc .ex-line { display: flex; justify-content: space-between; align-items: baseline; gap: 16px; padding: 13px 0; border-bottom: 1px dashed rgba(255,255,255,.1); }
.b3ex-calc .ex-line:last-child { border-bottom: none; }
.b3ex-calc .ex-line.strong { border-bottom: none; margin-top: 4px; padding-top: 16px; border-top: 1.5px solid rgba(245,184,32,.3); }
.b3ex-calc .ex-line.strong .ex-lbl { color: #fff; font-weight: 700; }
.b3ex-calc .ex-line.strong .ex-val { color: var(--gold); font-family: 'Fraunces', serif; font-size: 28px; }
.ex-lbl { font-size: 20px; color: #cfe0f2; line-height: 1.25; }
.ex-lbl small { color: #8aa3bf; font-size: 16px; }
.ex-val { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 23px; color: #fff; white-space: nowrap; }
.b3ex-result { margin-top: auto; display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 20px 26px; border-radius: 16px; background: rgba(245,184,32,.1); border: 1.5px solid rgba(245,184,32,.45); }
.b3ex-result .er-lbl { font-size: 19px; font-weight: 700; color: var(--gold-soft); line-height: 1.2; }
.b3ex-result .er-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 52px; color: var(--gold); line-height: 1; white-space: nowrap;
  text-shadow: 0 0 22px rgba(245,184,32,.4); }
.b3ex-result .er-val small { font-family: 'Plus Jakarta Sans', sans-serif; font-size: 20px; font-weight: 700; color: var(--gold-soft); }
.er-val .ev-num { display: inline-block; }
.er-val.counting .ev-num { animation: evRise .75s cubic-bezier(.18,.85,.25,1) both; }
@keyframes evRise { from { transform: translateY(24px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.b3ex-result.two { flex-direction: column; align-items: stretch; gap: 14px; padding: 18px 24px; }
.b3ex-result.two .er-col { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.b3ex-result.two .er-col + .er-col { padding-top: 14px; border-top: 1px solid rgba(245,184,32,.25); }
.b3ex-result.two .er-val { font-size: 42px; }
.b3ex-bonus { margin-top: 14px; font-size: 18px; color: #cfe0f2; line-height: 1.3; padding: 13px 18px; border-radius: 12px;
  background: rgba(255,255,255,.04); border-left: 3px solid var(--gold); }
.b3ex-bonus b { color: var(--gold); font-weight: 800; }
.b3ex-note { margin-top: 14px; font-size: 16px; font-style: italic; color: #8aa3bf; text-align: center; }
.b3ex-card.hot { border-color: rgba(245,184,32,.6);
  background: radial-gradient(90% 60% at 50% 0%, rgba(245,184,32,.16), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.45), var(--navy-card) 60%, var(--navy-deep));
  box-shadow: 0 16px 36px rgba(0,0,0,.42), 0 0 34px rgba(245,184,32,.26); }
.b3ex-card.hot::before { opacity: 1; height: 4px; background: linear-gradient(90deg, var(--gold-soft), var(--gold), var(--gold-soft)); }

/* ── Bono 4a · concepto diferenciales ── */
.b4 { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 48px; margin-top: 30px; }
.b4-rule { display: flex; align-items: center; gap: 26px; align-self: center; max-width: 1180px; padding: 30px 42px; border-radius: 20px;
  background: radial-gradient(90% 120% at 0% 50%, rgba(245,184,32,.14), transparent 60%), linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.4); box-shadow: 0 14px 34px rgba(0,0,0,.36); }
.b4-rule-ic { width: 78px; height: 78px; flex: 0 0 auto; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-weight: 700; font-size: 42px; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); box-shadow: 0 0 24px rgba(245,184,32,.5); }
.b4-rule-tx { font-size: 34px; line-height: 1.3; color: #eaf2fb; }
.b4-rule-tx b { color: var(--gold); font-weight: 700; }
.b4-ladder { display: flex; align-items: flex-end; justify-content: center; gap: 26px; }
.b4-step { flex: 0 0 168px; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 14px;
  border-radius: 18px 18px 0 0; padding: 26px 0 22px; position: relative;
  background: linear-gradient(180deg, rgba(31,58,92,.6), var(--navy-card) 70%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.22); border-bottom: none; box-shadow: inset 0 1px 0 rgba(255,255,255,.05); }
.b4-step:nth-child(1) { height: 158px; }
.b4-step:nth-child(2) { height: 204px; }
.b4-step:nth-child(3) { height: 250px; }
.b4-step:nth-child(4) { height: 296px; }
.b4-step:nth-child(5) { height: 348px; }
.b4-step .bl-pct { font-family: 'Fraunces', serif; font-weight: 700; font-size: 50px; color: var(--gold); line-height: 1; }
.b4-step .bl-cat { font-size: 21px; font-weight: 700; letter-spacing: .05em; color: #cfe0f2; margin-top: auto; }
.b4-step.hot { border-color: rgba(245,184,32,.65);
  background: radial-gradient(90% 60% at 50% 0%, rgba(245,184,32,.2), transparent 60%), linear-gradient(180deg, rgba(60,46,12,.5), var(--navy-card) 65%, var(--navy-deep));
  box-shadow: 0 0 34px rgba(245,184,32,.3), inset 0 1px 0 rgba(255,255,255,.06); }
.b4-step.hot .bl-cat { color: var(--gold-soft); }
.b4-ladder-note { text-align: center; font-size: 24px; color: #9fb6cf; margin-top: 4px; }

/* ── Bono 4b · ejemplo diferenciales ── */
.b4ex { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 28px; margin-top: 26px; }
.b4ex-table { display: flex; flex-direction: column; border-radius: 20px; overflow: hidden;
  border: 1.5px solid rgba(245,184,32,.22); box-shadow: 0 14px 34px rgba(0,0,0,.34); }
.b4row { display: grid; grid-template-columns: 1.1fr 1.4fr 1.7fr 1.2fr 1.2fr; align-items: center; gap: 18px; padding: 20px 34px; }
.b4row:not(.b4head):nth-child(even) { background: rgba(255,255,255,.025); }
.b4row + .b4row { border-top: 1px solid rgba(255,255,255,.07); }
.b4head { background: linear-gradient(180deg, rgba(245,184,32,.16), rgba(245,184,32,.06)); }
.b4head span { font-size: 18px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--gold); }
.b4-name { font-family: 'Fraunces', serif; font-weight: 700; font-size: 27px; color: #fff; }
.b4-lvl { font-size: 22px; color: #cfe0f2; font-weight: 600; }
.b4-diff { font-size: 22px; color: #9fb6cf; }
.b4-diff b { font-family: 'Plus Jakarta Sans', sans-serif; color: #fff; font-weight: 800; font-size: 25px; }
.b4-pv { font-size: 23px; font-weight: 700; color: #eaf2fb; }
.b4-gain { font-family: 'Fraunces', serif; font-weight: 700; font-size: 32px; color: var(--gold); text-align: right; }
.b4ex-total { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 24px 42px; border-radius: 18px;
  background: radial-gradient(90% 120% at 100% 50%, rgba(245,184,32,.16), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.4), var(--navy-card) 60%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.5); box-shadow: 0 0 34px rgba(245,184,32,.24); }
.b4ex-total .b4t-lbl { font-size: 26px; font-weight: 700; color: var(--gold-soft); }
.b4ex-total .b4t-lbl b { color: var(--gold); font-weight: 800; }
.b4ex-total .er-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 72px; color: var(--gold); line-height: 1; white-space: nowrap; text-shadow: 0 0 26px rgba(245,184,32,.45); }
.b4ex-note { text-align: center; font-size: 17px; font-style: italic; color: #8aa3bf; }

/* ── Bono 5a · generacional concepto ── */
.b5 { flex: 1; min-height: 0; display: grid; grid-template-columns: 1fr 1.05fr; gap: 44px; align-items: center; margin-top: 30px; }
.b5-left { display: flex; flex-direction: column; gap: 26px; }
.b5-req { display: flex; align-items: center; gap: 20px; align-self: flex-start; padding: 18px 30px; border-radius: 16px;
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); color: var(--navy-deep); box-shadow: 0 0 26px rgba(245,184,32,.4); }
.b5-req-ic { font-size: 32px; }
.b5-req b { font-family: 'Fraunces', serif; font-size: 28px; }
.b5-req div { font-size: 19px; font-weight: 700; line-height: 1.25; }
.b5-explain { font-size: 28px; line-height: 1.45; color: #eaf2fb; }
.b5-explain b { color: var(--gold); font-weight: 700; }
.b5-note { font-size: 21px; line-height: 1.4; color: #cfe0f2; padding: 18px 24px; border-radius: 14px;
  background: rgba(255,255,255,.04); border-left: 4px solid var(--gold); }
.b5-note b { color: var(--gold-soft); font-weight: 700; }
.b5gen-table { display: flex; flex-direction: column; border-radius: 20px; overflow: hidden;
  border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 16px 36px rgba(0,0,0,.36); }
.b5gt-row { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; align-items: center; }
.b5gt-row + .b5gt-row { border-top: 1px solid rgba(255,255,255,.07); }
.b5gt-row span { padding: 20px 18px; text-align: center; font-size: 26px; font-weight: 700; color: #eaf2fb; }
.b5gt-row .b5c { text-align: left; padding-left: 30px; font-family: 'Fraunces', serif; color: #fff; }
.b5gt-head { background: linear-gradient(180deg, rgba(245,184,32,.16), rgba(245,184,32,.06)); }
.b5gt-head span { font-size: 18px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--gold); }
.b5gt-row.hot { background: radial-gradient(80% 120% at 0% 50%, rgba(245,184,32,.16), transparent 60%), rgba(245,184,32,.05); }
.b5gt-row.hot .b5c { color: var(--gold); }
.b5gt-row.hot span:not(.b5c) { color: var(--gold); font-family: 'Fraunces', serif; font-size: 30px; }

/* ── Bono 5b · árbol de generaciones ── */
.b5tree { flex: 1; min-height: 0; display: flex; flex-direction: column; align-items: center; gap: 13px; margin: 24px 0 14px; }
.b5you { display: flex; align-items: center; gap: 20px; padding: 18px 34px 18px 18px; border-radius: 999px;
  background: radial-gradient(90% 120% at 0% 50%, rgba(245,184,32,.2), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.5), var(--navy-card) 60%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.6); box-shadow: 0 0 30px rgba(245,184,32,.3); }
.b5av { width: 86px; height: 86px; border-radius: 50%; overflow: hidden; border: 2.5px solid var(--gold); flex: 0 0 auto; background: var(--navy-card); box-shadow: 0 0 16px rgba(245,184,32,.4); }
.b5av.sm { width: 70px; height: 70px; border-width: 2px; }
.b5av img { width: 100%; height: 100%; object-fit: cover; }
.b5you-tx { display: flex; flex-direction: column; }
.b5you-nm { font-family: 'Fraunces', serif; font-weight: 700; font-size: 34px; color: #fff; line-height: 1; }
.b5you-cat { font-size: 20px; font-weight: 700; color: var(--gold-soft); }
.b5gen { position: relative; display: flex; align-items: center; gap: 22px; width: 880px; max-width: 86%; padding: 13px 30px 13px 18px; border-radius: 18px;
  background: linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.22); box-shadow: 0 12px 28px rgba(0,0,0,.3); }
.b5g-conn { position: absolute; top: -13px; left: 51px; width: 3px; height: 13px; background: linear-gradient(180deg, transparent, var(--gold)); opacity: .7; }
.b5g-tx { display: flex; flex-direction: column; flex: 1; }
.b5g-lbl { font-family: 'Fraunces', serif; font-weight: 700; font-size: 28px; color: #fff; line-height: 1.1; }
.b5g-sub { font-size: 18px; color: #9fb6cf; }
.b5g-op { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 26px; color: #cfe0f2; white-space: nowrap; }
.b5g-eur { font-family: 'Fraunces', serif; font-weight: 700; font-size: 46px; color: var(--gold); line-height: 1; white-space: nowrap; min-width: 150px; text-align: right; text-shadow: 0 0 22px rgba(245,184,32,.45); }
.b5tree-total { display: flex; align-items: center; justify-content: space-between; gap: 20px; width: 880px; max-width: 86%; padding: 18px 36px; border-radius: 18px;
  background: radial-gradient(90% 120% at 100% 50%, rgba(245,184,32,.18), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.42), var(--navy-card) 60%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.55); box-shadow: 0 0 32px rgba(245,184,32,.26); margin: 4px auto 0; }
.b5tt-lbl { font-size: 25px; font-weight: 700; color: var(--gold-soft); }
.b5tt-lbl b { color: var(--gold); font-weight: 800; }
.b5tree-total .er-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 64px; color: var(--gold); line-height: 1; white-space: nowrap; text-shadow: 0 0 26px rgba(245,184,32,.45); }
.b5tree-note { text-align: center; font-size: 18px; font-style: italic; line-height: 1.4; color: #8aa3bf; max-width: 1180px; margin: 44px auto 0; }
.b5tree-note b { color: var(--gold-soft); font-weight: 700; font-style: normal; margin: 0 3px; }

/* ── Bono 6a · liderazgo concepto ── */
.b6 { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 44px; margin-top: 28px; }
.b6-rule { display: flex; align-items: center; gap: 26px; align-self: center; max-width: 1180px; padding: 28px 42px; border-radius: 20px;
  background: radial-gradient(90% 120% at 0% 50%, rgba(245,184,32,.14), transparent 60%), linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.4); box-shadow: 0 14px 34px rgba(0,0,0,.36); }
.b6-rule-ic { width: 74px; height: 74px; flex: 0 0 auto; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-weight: 700; font-size: 40px; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); box-shadow: 0 0 24px rgba(245,184,32,.5); }
.b6-rule-tx { font-size: 32px; line-height: 1.3; color: #eaf2fb; }
.b6-rule-tx b { color: var(--gold); font-weight: 700; }
.b6-ladder { display: flex; align-items: flex-end; justify-content: center; gap: 12px; }
.b6-step { flex: 0 0 154px; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 12px;
  border-radius: 16px 16px 0 0; padding: 20px 0 18px;
  background: linear-gradient(180deg, rgba(31,58,92,.6), var(--navy-card) 70%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.2); border-bottom: none; box-shadow: inset 0 1px 0 rgba(255,255,255,.05); }
.b6-step:nth-child(1) { height: 150px; }
.b6-step:nth-child(2) { height: 174px; }
.b6-step:nth-child(3) { height: 198px; }
.b6-step:nth-child(4) { height: 222px; }
.b6-step:nth-child(5) { height: 246px; }
.b6-step:nth-child(6) { height: 270px; }
.b6-step:nth-child(7) { height: 294px; }
.b6-step:nth-child(8) { height: 318px; }
.b6-step:nth-child(9) { height: 344px; }
.b6-step .bl-pct { font-family: 'Fraunces', serif; font-weight: 700; font-size: 38px; color: var(--gold); line-height: 1; white-space: nowrap; }
.b6-step .bl-cat { font-size: 19px; font-weight: 700; letter-spacing: .03em; color: #cfe0f2; margin-top: auto; }
.b6-step.hot { border-color: rgba(245,184,32,.65);
  background: radial-gradient(90% 60% at 50% 0%, rgba(245,184,32,.2), transparent 60%), linear-gradient(180deg, rgba(60,46,12,.5), var(--navy-card) 65%, var(--navy-deep));
  box-shadow: 0 0 34px rgba(245,184,32,.3), inset 0 1px 0 rgba(255,255,255,.06); }
.b6-step.hot .bl-cat { color: var(--gold-soft); }
.b6-ladder-note { text-align: center; font-size: 22px; color: #9fb6cf; margin-top: 2px; }

/* ── Bono 6b · liderazgo ejemplo ── */
.b6ex { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 30px; margin-top: 26px; }
.b6ex-table { display: flex; flex-direction: column; border-radius: 20px; overflow: hidden; align-self: center; width: 1180px; max-width: 92%;
  border: 1.5px solid rgba(245,184,32,.22); box-shadow: 0 16px 36px rgba(0,0,0,.36); }
.b6row { display: grid; grid-template-columns: 1.4fr 1.1fr 1fr; align-items: center; gap: 18px; padding: 26px 38px; }
.b6row + .b6row { border-top: 1px solid rgba(255,255,255,.07); }
.b6head { background: linear-gradient(180deg, rgba(245,184,32,.16), rgba(245,184,32,.06)); }
.b6head span { font-size: 18px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; color: var(--gold); }
.b6-name { font-family: 'Fraunces', serif; font-weight: 700; font-size: 30px; color: #fff; }
.b6-lvl { font-size: 24px; color: #cfe0f2; font-weight: 600; }
.b6-diff { font-size: 25px; color: #9fb6cf; text-align: right; }
.b6-diff b { font-family: 'Fraunces', serif; color: var(--gold); font-weight: 700; font-size: 34px; }
.b6row.hot { background: radial-gradient(80% 120% at 0% 50%, rgba(245,184,32,.14), transparent 60%), rgba(245,184,32,.05); }
.b6row.hot .b6-name { color: var(--gold); }
.b6ex-note { text-align: center; font-size: 22px; line-height: 1.4; color: #cfe0f2; max-width: 1180px; margin: 0 auto; }

/* ── Bono 7a · global concepto ── */
.b7 { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 44px; margin-top: 30px; }
.b7-hero { display: flex; align-items: center; gap: 44px; align-self: center; max-width: 1280px; padding: 40px 56px; border-radius: 28px;
  background: radial-gradient(80% 130% at 0% 50%, rgba(245,184,32,.2), transparent 62%), linear-gradient(160deg, rgba(60,46,12,.46), var(--navy-card) 58%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.55); box-shadow: 0 18px 44px rgba(0,0,0,.4), 0 0 40px rgba(245,184,32,.24); }
.b7-badge { width: 220px; height: 220px; flex: 0 0 auto; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(circle at 38% 30%, var(--gold-soft), var(--gold) 72%); box-shadow: 0 0 50px rgba(245,184,32,.5), inset 0 4px 14px rgba(255,255,255,.4); }
.b7-pct { font-family: 'Fraunces', serif; font-weight: 700; font-size: 96px; color: var(--navy-deep); line-height: 1; }
.b7-hero-tx { display: flex; flex-direction: column; gap: 14px; }
.b7-big { font-family: 'Fraunces', serif; font-weight: 600; font-size: 50px; color: #fff; line-height: 1.15; }
.b7-big b { color: var(--gold); font-weight: 700; }
.b7-sub { font-size: 26px; color: #cfe0f2; line-height: 1.4; max-width: 720px; }
.b7-foot { align-self: center; display: flex; align-items: center; gap: 14px; font-size: 27px; color: #eaf2fb; padding: 20px 38px; border-radius: 16px;
  background: rgba(255,255,255,.04); border: 1.5px solid var(--line); }
.b7-foot b { color: var(--gold); font-weight: 700; }
.b7-foot-ic { color: var(--gold); font-size: 30px; }

/* ── Bono 7b · global acciones ── */
.b7b { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 46px; margin-top: 28px; }
.b7-qualify { display: flex; align-items: center; gap: 24px; align-self: center; max-width: 1180px; padding: 26px 40px; border-radius: 18px;
  background: linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.4); box-shadow: 0 14px 32px rgba(0,0,0,.34); }
.b7q-ic { width: 64px; height: 64px; flex: 0 0 auto; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 32px; font-weight: 800;
  color: var(--navy-deep); background: linear-gradient(145deg, var(--gold-soft), var(--gold)); box-shadow: 0 0 22px rgba(245,184,32,.5); }
.b7q-tx { font-size: 30px; line-height: 1.3; color: #eaf2fb; }
.b7q-tx b { color: var(--gold); font-weight: 700; }
.b7-ladder { display: flex; align-items: stretch; justify-content: center; gap: 26px; }
.b7-step { flex: 0 0 240px; display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 30px 0 24px; border-radius: 20px;
  background: linear-gradient(180deg, rgba(31,58,92,.55), var(--navy-card) 64%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 14px 30px rgba(0,0,0,.32); }
.b7-step .b7s-act { font-family: 'Fraunces', serif; font-weight: 700; font-size: 72px; color: var(--gold); line-height: 1; text-shadow: 0 0 24px rgba(245,184,32,.45); }
.b7-step .b7s-lbl { font-size: 21px; font-weight: 700; color: var(--gold-soft); text-transform: uppercase; letter-spacing: .08em; }
.b7-step .b7s-cat { margin-top: 12px; font-size: 23px; font-weight: 700; color: #eaf2fb; padding-top: 14px; border-top: 1px solid rgba(245,184,32,.22); width: 72%; text-align: center; }
.b7-step.more { background: radial-gradient(90% 70% at 50% 0%, rgba(245,184,32,.16), transparent 60%), linear-gradient(180deg, rgba(60,46,12,.4), var(--navy-card) 64%, var(--navy-deep)); border-color: rgba(245,184,32,.5); }
.b7-step.more .b7s-cat { font-size: 19px; color: #9fb6cf; font-weight: 600; }
.b7b-note { text-align: center; font-size: 23px; line-height: 1.4; color: #cfe0f2; max-width: 1180px; margin: 0 auto; }

/* proyección primer año (Bono 2c) */
.mseal.proj-seal { position: relative; top: 54px; }
.proj { flex: 1; min-height: 0; margin-top: 14px; position: relative; display: flex; flex-direction: column; justify-content: flex-end; }
.proj-counter { position: absolute; top: 26px; left: 50%; transform: translateX(-50%); text-align: center; z-index: 2; }
.proj-counter .pc-num { font-family: 'Fraunces', serif; font-weight: 700; font-size: 96px; color: var(--gold); line-height: 1; text-shadow: 0 0 26px rgba(245,184,32,.5); }
.proj-counter .pc-num small { font-size: 32px; color: var(--ink-dim); font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 600; }
.proj-counter .pc-lbl { margin-top: 8px; font-size: 23px; color: var(--ink-dim); }
.proj-counter .pc-lbl span { color: var(--gold-soft); font-weight: 700; }
.proj-chart { display: flex; align-items: flex-end; justify-content: center; gap: 20px; height: 430px; padding: 0 20px; }
.pmonth { display: flex; flex-direction: column; align-items: center; gap: 9px; justify-content: flex-end; }
.pmonth .pval { font-family: 'Fraunces', serif; font-weight: 700; font-size: 17px; color: #fff; white-space: nowrap; opacity: 0; transition: opacity .4s ease; }
.pmonth .pbar { width: 72px; border-radius: 10px 10px 0 0; height: 0;
  background: linear-gradient(180deg, #20406a, #13283f); border: 1.5px solid var(--line); border-bottom: none;
  transition: height .75s cubic-bezier(.2,.8,.3,1); }
.pmonth .pm { font-size: 18px; color: var(--ink-dim); font-weight: 600; }
.pmonth.shown .pval { opacity: 1; }
.pmonth.hot .pbar { background: linear-gradient(180deg, var(--gold-soft), var(--gold)); border-color: var(--gold); box-shadow: 0 0 30px rgba(245,184,32,.55); }
.pmonth.hot .pval { color: var(--gold); font-size: 24px; }
.pmonth.hot .pm { color: var(--gold-soft); font-weight: 800; }

/* tabla de la matriz nivel a nivel (Bono 2b) */
.mtab-wrap { flex: 1; min-height: 0; margin-top: 18px; display: flex; align-items: center; justify-content: center; }
.mtab { border-collapse: collapse; width: 84%; font-family: 'Plus Jakarta Sans', sans-serif; }
.mtab th { font-size: 19px; font-weight: 800; color: var(--gold); text-transform: uppercase; letter-spacing: .05em;
  padding: 11px 22px; border-bottom: 2px solid rgba(245,184,32,.45); text-align: center; }
.mtab td { font-size: 22px; color: var(--ink); padding: 6px 22px; border-bottom: 1px solid var(--line); text-align: center; }

/* tabla de categorías — réplica oficial + columnas de negocios y ganancia por nivel */
.mtab-wrap { margin-top: 24px; margin-bottom: 26px; align-items: flex-start; flex: 0 0 auto; }
.mtab6 { table-layout: fixed; width: 1440px; max-width: 100%; margin: 0 auto; }
.mtab6 col { width: 15.33%; }
.mtab6 col:first-child { width: 8%; }
.mtab6 th { font-size: 17px; text-align: center; line-height: 1.14; padding: 8px 10px; white-space: nowrap; vertical-align: top; }
.mtab6 td { font-size: 21px; text-align: center; padding: 2px 10px; color: var(--ink); white-space: nowrap; }
.mtab6 th, .mtab6 td { border-right: 1px solid rgba(245,184,32,.13); }
.mtab6 th:last-child, .mtab6 td:last-child { border-right: none; }
.mtab6 td.lvl { color: var(--gold); font-weight: 800; }
.mtab6 td.num { font-family: 'Fraunces', serif; font-weight: 700; color: #fff; }
.mtab6 td.fill { font-size: 16px; font-weight: 700; color: var(--gold-soft); background: rgba(245,184,32,.07); }
.mtab6 td.gain { font-family: 'Fraunces', serif; font-weight: 700; color: var(--gold); }
.mtab6 th:last-child { color: var(--gold); }
.mtab6 tfoot .maxrow td { border-top: 2px solid rgba(245,184,32,.5); background: rgba(245,184,32,.12);
  font-family: 'Fraunces', serif; font-weight: 700; color: var(--gold); font-size: 23px; padding: 9px 8px; }
.mtab6 tfoot .maxrow td:first-child { font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800;
  font-size: 16px; color: var(--gold-soft); text-transform: uppercase; letter-spacing: .04em; text-align: left; }

.mseal { align-self: center; display: inline-flex; align-items: center; gap: 12px; margin-top: auto;
  font-size: 19px; color: var(--gold-soft); background: rgba(245,184,32,.08);
  border: 1.5px solid rgba(245,184,32,.3); border-radius: 999px; padding: 12px 28px; }
.mseal b { color: #fff; font-weight: 700; }
/* ── L1b · ¿Cuál es tu por qué? ── */
.porque { flex: 1; min-height: 0; display: flex; flex-direction: column; justify-content: center; gap: 30px; margin-top: 26px; }
.porque-row { display: flex; justify-content: center; gap: 34px; }
.porque.seven { gap: 30px; }
.porque.seven .porque-row { gap: 28px; }
.porque.seven .pq-card { width: 348px; padding: 30px 26px 26px; gap: 20px; }
.porque.seven .pq-img { width: 168px; height: 168px; }
.porque.seven .pq-tx { font-size: 30px; }
.pq-card { width: 360px; display: flex; flex-direction: column; align-items: center; gap: 20px; padding: 32px 30px 30px; border-radius: 24px;
  background: linear-gradient(180deg, rgba(31,58,92,.5) 0%, var(--navy-card) 60%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 16px 36px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.05);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.pq-card:hover { transform: translateY(-6px); border-color: rgba(245,184,32,.55);
  box-shadow: 0 22px 46px rgba(0,0,0,.46), 0 0 40px rgba(245,184,32,.22); }
.pq-img { width: 168px; height: 168px; flex: 0 0 auto; border-radius: 50%; overflow: hidden;
  background: radial-gradient(72% 72% at 50% 38%, rgba(245,184,32,.2), rgba(10,28,51,.4) 72%);
  border: 2px solid rgba(245,184,32,.5); box-shadow: 0 0 30px rgba(245,184,32,.3); display: flex; align-items: center; justify-content: center; }
.pq-img img { width: 100%; height: 100%; object-fit: cover; }
.pq-tx { font-family: 'Fraunces', serif; font-size: 30px; font-weight: 600; color: #eaf2fb; text-align: center; line-height: 1.25; }
.pq-tx b { color: var(--gold); font-weight: 700; }

/* ── Bono 3 · ejemplo por marca (NATURKIN / viajaYA / TOMAYA) — 2 columnas verticales ── */
.exm2 { flex: 1; min-height: 0; display: grid; grid-template-columns: 36% 1fr; gap: 30px; margin: 52px auto 14px; max-width: 1640px; width: 100%; }
.exm2-brand { display: flex; flex-direction: column; align-items: center; padding: 28px 24px 0; border-radius: 26px;
  background: radial-gradient(80% 60% at 50% 12%, rgba(245,184,32,.14), transparent 60%), linear-gradient(180deg, rgba(31,58,92,.5), var(--navy-card) 55%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.28); box-shadow: 0 16px 36px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.05); overflow: hidden; }
.exm2-coms { font-size: 26px; color: var(--ink-dim); font-weight: 600; }
.exm2-logo { height: 74px; width: auto; max-width: 80%; object-fit: contain; margin-top: 14px; }
.exm2-mascot { flex: 1 1 auto; min-height: 0; width: 100%; display: flex; align-items: flex-end; justify-content: center; margin-top: 8px; }
.exm2-mascot img { max-width: 100%; max-height: 100%; object-fit: contain; filter: drop-shadow(0 14px 30px rgba(245,184,32,.32)); }
.exm2-main { display: flex; flex-direction: column; gap: 30px; min-height: 0; }
.exm2-rate { flex: 1.7 1 0; min-height: 0; display: flex; flex-direction: row; align-items: center; justify-content: center; gap: 36px; padding: 26px 50px; border-radius: 26px;
  background: radial-gradient(75% 120% at 50% 50%, rgba(245,184,32,.14), transparent 62%), linear-gradient(160deg, rgba(31,58,92,.45), var(--navy-card) 58%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.3); box-shadow: 0 16px 36px rgba(0,0,0,.36); }
.exm2-pct { font-family: 'Fraunces', serif; font-weight: 700; font-size: 210px; color: var(--gold); line-height: .9; white-space: nowrap; flex: 0 0 auto; text-shadow: 0 0 44px rgba(245,184,32,.5); }
.exm2-rate-tx2 { font-size: 36px; font-weight: 700; color: #eaf2fb; line-height: 1.22; text-align: left; flex: 0 0 auto; }
.exm2-ej { flex: 1 1 0; min-height: 0; display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 22px 50px; border-radius: 22px;
  background: rgba(245,184,32,.08); border: 1.5px solid rgba(245,184,32,.4); }
.exm2-ej-q { flex: 1 1 auto; font-size: 31px; color: #eaf2fb; line-height: 1.28; text-align: left; }
.exm2-ej-q b { color: #fff; font-weight: 700; }
.exm2-ej-arrow { flex: 0 0 auto; font-size: 44px; font-weight: 800; color: var(--gold); letter-spacing: -5px; opacity: .85; text-shadow: 0 0 16px rgba(245,184,32,.5); }
.exm2-ej-r { flex: 0 0 auto; white-space: nowrap; }
.exm2-ej-r b.gold { font-family: 'Fraunces', serif; color: var(--gold); font-weight: 700; font-size: 104px; line-height: 1; text-shadow: 0 0 34px rgba(245,184,32,.45); }
/* TOMAYA — dos tarjetas (Excepción + Ejemplo); la rate del % se achica para darles protagonismo */
.exm2-main:has(.exm2-twocards) .exm2-rate { flex: 1 1 0; padding: 18px 50px; }
.exm2-main:has(.exm2-twocards) .exm2-pct { font-size: 158px; }
.exm2-main:has(.exm2-twocards) .exm2-rate-tx2 { text-align: center; }
.exm2-twocards { flex: 1.55 1 0; min-height: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.exm2-card2 { display: flex; flex-direction: column; justify-content: center; gap: 12px; padding: 24px 30px; border-radius: 22px;
  background: rgba(245,184,32,.08); border: 1.5px solid rgba(245,184,32,.4); box-shadow: 0 10px 26px rgba(0,0,0,.3); }
.exm2-c2-tag { font-size: 27px; font-weight: 800; color: var(--gold); letter-spacing: .02em; }
.exm2-c2-tx { font-size: 29px; color: #eaf2fb; line-height: 1.34; }
.exm2-c2-tx b { color: #fff; font-weight: 700; }
.exm2-c2-tx b.gold { color: var(--gold); }
.exm2-c2-tx b.c2-big { font-family: 'Fraunces', serif; font-weight: 700; font-size: 54px; color: var(--gold); line-height: 1; white-space: nowrap; }
.exm2-c2-tx b.c2-win { font-family: 'Fraunces', serif; font-weight: 700; font-size: 40px; color: var(--gold); white-space: nowrap; }
.exm2-card2.hot { border-color: rgba(245,184,32,.6); background: rgba(245,184,32,.1);
  box-shadow: 0 12px 30px rgba(0,0,0,.34), 0 0 22px rgba(245,184,32,.18); }

/* ── Plan Amigo · factura a 1€ ── */
.pa { flex: 1; min-height: 0; display: grid; grid-template-columns: 30% 1fr; gap: 26px; margin-top: 30px; align-items: stretch; }
.pa-left { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; padding: 16px; border-radius: 24px;
  background: radial-gradient(80% 60% at 50% 18%, rgba(245,184,32,.16), transparent 60%), linear-gradient(180deg, rgba(31,58,92,.5), var(--navy-card) 55%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.3); box-shadow: 0 16px 36px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.05); }
.pa-tommy { flex: 0 0 auto; position: relative; width: 100%; line-height: 0; }
.pa-tommy > img { width: 100%; height: auto; display: block; filter: drop-shadow(0 14px 30px rgba(245,184,32,.34)); }
.pa-bill-val.on-paper { position: absolute; left: 26%; top: 46%; transform: translate(-50%, -50%) rotate(5deg); z-index: 2;
  color: #e23b3a; font-size: 52px; text-shadow: none; text-align: center; white-space: nowrap; }
.pa-bill-val.on-paper.flash { transform: translate(-50%, -50%) rotate(5deg) scale(1.16); }
.pa-stats { flex: 0 0 auto; width: 100%; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pa-stats.one { grid-template-columns: 1fr; }
.pa-bill, .pa-com { display: flex; flex-direction: column; align-items: center; gap: 3px; padding: 14px 12px; border-radius: 18px; }
.pa-bill { background: rgba(10,28,51,.6); border: 1.5px solid rgba(245,184,32,.4); }
.pa-com { background: rgba(245,184,32,.1); border: 1.5px solid rgba(245,184,32,.55); }
.pa-bill-lbl, .pa-com-lbl { font-size: 18px; color: var(--ink-dim); font-weight: 600; text-align: center; }
.pa-com-lbl { color: var(--gold-soft); }
.pa-bill-val, .pa-com-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 52px; color: var(--gold); line-height: 1; text-shadow: 0 0 24px rgba(245,184,32,.5); transition: transform .25s ease; }
.pa-bill-val.flash, .pa-com-val.flash { transform: scale(1.14); }
.pa-bill-val.done { color: var(--gold-soft); }
.pa-friends { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-auto-rows: minmax(0, 1fr); gap: 14px; align-content: stretch; }
.pa-friend { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; padding: 10px; border-radius: 18px;
  background: linear-gradient(180deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.22);
  opacity: 0; transform: translateY(20px) scale(.92); transition: opacity .45s ease, transform .45s cubic-bezier(.2,.8,.25,1); }
.pa-friend.on { opacity: 1; transform: none; }
.pa-friend.biz { border-color: rgba(245,184,32,.4); background: radial-gradient(80% 80% at 50% 20%, rgba(245,184,32,.1), transparent 60%), linear-gradient(180deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); }
.pa-av { width: 104px; height: 104px; border-radius: 50%; overflow: hidden; border: 2.5px solid var(--gold); flex: 0 0 auto; background: var(--navy-card); box-shadow: 0 0 16px rgba(245,184,32,.4); }
.pa-av.biz { border-radius: 18px; }
.pa-av img { width: 100%; height: 100%; object-fit: cover; }
.pa-f-tx { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.pa-f-nm { font-size: 23px; font-weight: 700; color: #eaf2fb; line-height: 1.1; }
.pa-f-com { font-family: 'Fraunces', serif; font-weight: 700; font-size: 32px; color: var(--gold); line-height: 1; }
.pa-f-com.pos { color: #34c759; }

/* ── Proyección anual TOMAYA ── */
.proy2 { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 16px; margin-top: 14px; }
.proy2-break { flex: 0 0 auto; display: flex; align-items: stretch; justify-content: center; gap: 20px; }
.pb-card { display: flex; align-items: center; gap: 26px; padding: 20px 36px; border-radius: 18px;
  background: linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 10px 26px rgba(0,0,0,.3); }
.pb-tx { display: flex; flex-direction: column; gap: 3px; }
.pb-tx b { font-size: 32px; color: #fff; font-weight: 700; }
.pb-tx span { font-size: 22px; color: #cfe0f2; }
.pb-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 50px; color: var(--gold); white-space: nowrap; }
.pb-op { display: flex; align-items: center; font-family: 'Fraunces', serif; font-size: 56px; font-weight: 700; color: var(--gold); }
.pb-total { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; padding: 14px 42px; border-radius: 18px;
  background: radial-gradient(90% 120% at 50% 0%, rgba(245,184,32,.2), transparent 65%), rgba(245,184,32,.1); border: 1.5px solid rgba(245,184,32,.55); box-shadow: 0 0 30px rgba(245,184,32,.24); }
.pb-total-lbl { font-size: 22px; color: var(--gold-soft); font-weight: 600; text-transform: uppercase; letter-spacing: .08em; }
.pb-total-val { font-family: 'Fraunces', serif; font-weight: 700; font-size: 64px; color: var(--gold); line-height: 1; text-shadow: 0 0 24px rgba(245,184,32,.45); }
.proy2-note { flex: 0 0 auto; text-align: center; font-size: 24px; color: #cfe0f2; line-height: 1.3; }
.proy2-note b { color: #fff; font-weight: 700; }
.proy2-note b.gold { color: var(--gold); font-weight: 700; }
.proy2-chart { flex: 1 1 auto; min-height: 0; display: flex; align-items: flex-end; justify-content: center; gap: 16px; padding: 0 10px; }
.proy2-foot { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; gap: 30px; flex-wrap: nowrap; }
.pf-year { font-size: 23px; color: #eaf2fb; font-weight: 600; white-space: nowrap; flex: 0 0 auto; }
.pf-year span { font-family: 'Fraunces', serif; font-weight: 700; font-size: 50px; color: var(--gold); text-shadow: 0 0 28px rgba(245,184,32,.5); vertical-align: -7px; }
.pf-res { font-size: 22px; color: #cfe0f2; padding: 13px 24px; border-radius: 14px; background: rgba(255,255,255,.04); border-left: 4px solid var(--gold); flex: 0 1 auto; }
.pf-res b { color: #fff; font-weight: 700; }
.pf-res b.gold { font-family: 'Fraunces', serif; color: var(--gold); }

/* ── Variante NEURONAL del bono de expansión ── */
.mtree.neural { height: 600px; }
.mtree.neural::before { background: radial-gradient(46% 50% at 50% 50%, rgba(245,184,32,.2), transparent 70%); }
.mtree.neural .mav { opacity: 0; transform: translate(var(--dx, 0), var(--dy, 0)) scale(.12);
  transition: opacity .6s ease, transform .82s cubic-bezier(.2,.85,.3,1.12); }
.mtree.neural .mav.shown { opacity: 1; transform: translate(0, 0) scale(1); }
.mtree.neural .mlink { stroke: rgba(245,184,32,.5); stroke-width: 2.5; }
.mtree.neural .mav.ncenter .nst { border: 3px solid var(--gold); box-shadow: 0 0 32px rgba(245,184,32,.7), 0 0 60px rgba(245,184,32,.3); }
.mtree.neural .mav.ncenter .nav { width: 46%; height: 46%; border-width: 3px; }
.mtree.neural .mav.ncenter .mav-num { font-size: 20px; bottom: -24px; background: linear-gradient(145deg, var(--gold-soft), var(--gold)); color: var(--navy-deep); border-color: var(--gold); font-weight: 800; }
.mtree.neural .mav.nr2 .mav-num { font-size: 15px; bottom: -18px; padding: 1px 7px; }

/* ── Resumen de bonos 4-7 ── */
.bsum { flex: 1; min-height: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; align-items: stretch; margin-top: 36px; }
.bsum-card { display: flex; flex-direction: column; gap: 20px; padding: 32px 28px; border-radius: 22px;
  background: linear-gradient(180deg, rgba(31,58,92,.5) 0%, var(--navy-card) 58%, var(--navy-deep) 100%);
  border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 16px 38px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.05); }
.bsum-head { display: flex; align-items: center; gap: 18px; padding-bottom: 18px; border-bottom: 1px solid rgba(245,184,32,.22); }
.bsum-n { flex: 0 0 auto; width: 64px; height: 64px; border-radius: 16px; display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-weight: 700; font-size: 36px; color: var(--navy-deep);
  background: linear-gradient(145deg, var(--gold-soft), var(--gold)); box-shadow: 0 0 22px rgba(245,184,32,.45); }
.bsum-name { font-family: 'Fraunces', serif; font-weight: 700; font-size: 30px; color: #fff; line-height: 1.12; }
.bsum-tx { font-size: 25px; color: #cfe0f2; line-height: 1.4; }
.bsum-tx b { color: #fff; font-weight: 700; }
.bsum-tx b.gold { color: var(--gold); }
.bsum-img { margin-top: auto; border-radius: 16px; overflow: hidden; width: 100%; aspect-ratio: 3 / 2;
  border: 1px solid rgba(245,184,32,.25); box-shadow: 0 8px 22px rgba(0,0,0,.4); }
.bsum-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 16%; display: block; }
.bsum-card.hot .bsum-img { border-color: rgba(245,184,32,.5); }
.bsum-card.hot { border-color: rgba(245,184,32,.6);
  background: radial-gradient(90% 60% at 50% 0%, rgba(245,184,32,.16), transparent 60%), linear-gradient(180deg, rgba(60,46,12,.45), var(--navy-card) 60%, var(--navy-deep));
  box-shadow: 0 16px 40px rgba(0,0,0,.42), 0 0 38px rgba(245,184,32,.26); }

/* ── ¿Cómo llego al máximo? ── */
.maxi { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 32px; margin-top: 28px; justify-content: center; }
.maxi-ranges { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.mr-card { display: flex; align-items: center; gap: 20px; padding: 18px 28px; border-radius: 18px;
  background: linear-gradient(160deg, rgba(31,58,92,.5), var(--navy-card) 60%, var(--navy-deep)); border: 1.5px solid rgba(245,184,32,.24); box-shadow: 0 10px 26px rgba(0,0,0,.3); }
.mr-mascot { width: 76px; height: 76px; flex: 0 0 auto; border-radius: 50%; overflow: hidden;
  background: radial-gradient(72% 72% at 50% 36%, rgba(245,184,32,.16), var(--navy-deep)); border: 2px solid rgba(245,184,32,.5); }
.mr-mascot img { width: 100%; height: 100%; object-fit: contain; padding: 4px 3px 0; }
.mr-name { flex: 1; font-family: 'Fraunces', serif; font-weight: 700; font-size: 26px; color: #fff; }
.mr-range { display: flex; align-items: center; gap: 12px; flex: 0 0 auto; }
.mr-min { font-family: 'Fraunces', serif; font-weight: 700; font-size: 30px; color: var(--ink-dim); }
.mr-arrow { font-size: 26px; font-weight: 800; color: rgba(245,184,32,.7); letter-spacing: -4px; }
.mr-max { font-family: 'Fraunces', serif; font-weight: 700; font-size: 42px; color: var(--gold); text-shadow: 0 0 20px rgba(245,184,32,.45); }
.maxi-goal { flex: 0 0 auto; display: flex; align-items: stretch; gap: 0; border-radius: 26px; overflow: hidden;
  background: radial-gradient(80% 130% at 100% 50%, rgba(245,184,32,.18), transparent 60%), linear-gradient(160deg, rgba(60,46,12,.4), var(--navy-card) 58%, var(--navy-deep));
  border: 1.5px solid rgba(245,184,32,.5); box-shadow: 0 18px 42px rgba(0,0,0,.42), 0 0 40px rgba(245,184,32,.22); }
.maxi-goal-tx { flex: 1; display: flex; flex-direction: column; gap: 14px; padding: 38px 48px; justify-content: center; }
.mg-kick { font-size: 22px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); }
.mg-title { font-family: 'Fraunces', serif; font-weight: 700; font-size: 46px; color: #fff; line-height: 1.15; }
.mg-req { display: flex; align-items: center; gap: 26px; margin-top: 6px; }
.mg-pv { flex: 0 0 auto; font-family: 'Fraunces', serif; font-weight: 700; font-size: 76px; color: var(--gold); line-height: 1; white-space: nowrap; text-shadow: 0 0 30px rgba(245,184,32,.5); }
.mg-req-tx { font-size: 28px; color: #eaf2fb; line-height: 1.35; }
.mg-req-tx b { color: var(--gold-soft); font-weight: 700; }
.maxi-lobo { flex: 0 0 340px; position: relative; display: flex; align-items: flex-end; justify-content: center; }
.maxi-lobo img { max-height: 320px; width: auto; object-fit: contain; filter: drop-shadow(0 14px 30px rgba(0,0,0,.5)); }

/* ── Cierre · dos caminos ── */
.paths { flex: 1; min-height: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 34px; margin-top: 30px; align-items: stretch; }
.path-card { display: flex; flex-direction: column; border-radius: 24px; overflow: hidden; border: 1.5px solid var(--line); box-shadow: 0 16px 38px rgba(0,0,0,.4); }
.path-img { flex: 1 1 auto; min-height: 0; overflow: hidden; }
.path-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.path-card.warm .path-img img { object-position: center 18%; }
.path-tx { flex: 0 0 auto; display: flex; align-items: center; gap: 24px; padding: 34px 38px; }
.path-n { flex: 0 0 auto; width: 68px; height: 68px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-weight: 700; font-size: 36px; }
.path-title { font-family: 'Fraunces', serif; font-weight: 700; font-size: 38px; line-height: 1.1; margin-bottom: 8px; }
.path-desc { font-size: 28px; line-height: 1.36; }
.path-desc b { font-weight: 700; }
/* camino 1 — frío, apagado */
.path-card.cold { background: linear-gradient(180deg, rgba(40,48,60,.5), rgba(20,26,36,.6)); filter: saturate(.7); }
.path-card.cold .path-img img { filter: grayscale(.5) brightness(.78); }
.path-card.cold .path-n { background: rgba(150,160,175,.2); color: #9fb0c0; border: 1.5px solid rgba(150,160,175,.4); }
.path-card.cold .path-title { color: #aab6c4; }
.path-card.cold .path-desc { color: #8aa0b4; }
/* camino 2 — cálido, premium */
.path-card.warm { background: radial-gradient(90% 50% at 50% 100%, rgba(245,184,32,.14), transparent 60%), linear-gradient(180deg, rgba(31,58,92,.5), var(--navy-card) 70%); border-color: rgba(245,184,32,.55); box-shadow: 0 18px 44px rgba(0,0,0,.45), 0 0 40px rgba(245,184,32,.22); }
.path-card.warm .path-n { background: linear-gradient(145deg, var(--gold-soft), var(--gold)); color: var(--navy-deep); box-shadow: 0 0 20px rgba(245,184,32,.5); }
.path-card.warm .path-title { color: var(--gold); }
.path-card.warm .path-desc { color: #eaf2fb; }
.path-card.warm .path-desc b { color: var(--gold-soft); }

/* ── Cierre · frase Warren Buffett ── */
.buffett { flex: 1; min-height: 0; display: flex; align-items: center; justify-content: center; gap: 56px; }
.buffett-photo { flex: 0 0 auto; width: 420px; height: 520px; border-radius: 26px; overflow: hidden; border: 1.5px solid rgba(245,184,32,.4);
  box-shadow: 0 20px 50px rgba(0,0,0,.5), 0 0 40px rgba(245,184,32,.18); background: rgba(15,39,66,.5); }
.buffett-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.buffett-tx { flex: 1 1 auto; max-width: 900px; position: relative; }
.bq { font-family: 'Fraunces', serif; font-weight: 600; font-size: 56px; color: #fff; line-height: 1.24; margin: 0 0 24px; }
.bq .bq-q { color: var(--gold); font-weight: 700; }
.bq b { color: var(--gold); font-weight: 700; }
.bq-cite { font-size: 30px; font-weight: 700; color: var(--gold-soft); font-style: normal; letter-spacing: .04em; }

/* ============ AUTOPILOT — pantalla de inicio + cuenta atrás ============ */
.start-screen {
  position: fixed; inset: 0; z-index: 200; overflow-y: auto; -webkit-overflow-scrolling: touch;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(120% 85% at 50% 8%, rgba(245,184,32,.13), transparent 58%),
    radial-gradient(90% 70% at 50% 100%, rgba(15,39,66,.55), transparent 60%),
    linear-gradient(180deg, var(--navy-deep, #061322), var(--navy, #0a1c33));
  transition: opacity .5s ease, visibility .5s ease;
}
/* rejilla dorada tenue — misma textura que las láminas */
.start-screen::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(245,184,32,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,184,32,.045) 1px, transparent 1px);
  background-size: 96px 96px;
  -webkit-mask-image: radial-gradient(75% 65% at 50% 32%, #000 0%, transparent 78%);
  mask-image: radial-gradient(75% 65% at 50% 32%, #000 0%, transparent 78%);
}
/* viñeta de borde, igual que .stage::after */
.start-screen::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(120% 90% at 50% 50%, transparent 56%, rgba(2,8,16,.55) 100%);
}
.start-screen.hide { opacity: 0; visibility: hidden; pointer-events: none; }
.start-panel { position: relative; z-index: 1; text-align: center; max-width: 980px; padding: 44px 40px; margin: auto; box-sizing: border-box; }
.start-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 22px; letter-spacing: .26em; text-transform: uppercase;
  color: var(--gold); font-weight: 700; margin-bottom: 26px;
}
.start-eyebrow .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 16px var(--gold); }
.start-title { font-family: 'Fraunces', serif; font-size: 76px; line-height: 1.05; color: var(--ink, #fff); margin: 0 0 34px; }
.start-title .gold { color: var(--gold); }
.start-sub { font-size: 30px; color: var(--ink-dim, #b9c6d8); margin: 0 0 56px; }
.start-actions { display: flex; gap: 28px; justify-content: center; align-items: stretch; flex-wrap: wrap; }
.start-btn {
  display: flex; align-items: center; gap: 20px; text-align: left;
  padding: 26px 34px; border-radius: 20px; cursor: pointer;
  border: 1.5px solid var(--line, rgba(245,184,32,.25));
  background: linear-gradient(180deg, rgba(15,39,66,.7), rgba(10,28,51,.4));
  color: var(--ink, #fff); transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  width: 460px; box-sizing: border-box;
}
.start-btn .sb-tx small { white-space: nowrap; }
.start-btn:hover { transform: translateY(-4px); border-color: var(--gold); box-shadow: 0 18px 44px rgba(0,0,0,.45), 0 0 30px rgba(245,184,32,.2); }
.start-btn .sb-ic {
  width: 62px; height: 62px; flex: 0 0 auto; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 28px;
  background: rgba(245,184,32,.14); color: var(--gold); border: 1.5px solid rgba(245,184,32,.4);
}
.start-btn.primary { border-color: var(--gold); background: linear-gradient(180deg, rgba(245,184,32,.18), rgba(245,184,32,.06)); }
.start-btn.primary .sb-ic { background: var(--gold); color: #0a1c33; box-shadow: 0 0 26px rgba(245,184,32,.5); }
.start-btn .sb-tx { display: flex; flex-direction: column; gap: 4px; }
.start-btn .sb-tx b { font-size: 30px; font-weight: 700; }
.start-btn .sb-tx small { font-size: 18px; color: var(--ink-dim, #9fb0c4); font-weight: 500; }

.countdown {
  position: fixed; inset: 0; z-index: 210;
  display: flex; align-items: center; justify-content: center;
  background: radial-gradient(60% 60% at 50% 50%, rgba(10,28,51,.86), rgba(7,23,43,.97));
  opacity: 0; visibility: hidden; transition: opacity .35s ease, visibility .35s ease;
}
.countdown.show { opacity: 1; visibility: visible; }
.countdown span {
  font-family: 'Fraunces', serif; font-weight: 700; color: var(--gold);
  font-size: 300px; line-height: 1; text-shadow: 0 0 70px rgba(245,184,32,.45);
}
.countdown span.tick { animation: cdpop .9s ease; }
@keyframes cdpop {
  0% { transform: scale(.3); opacity: 0; }
  30% { transform: scale(1.08); opacity: 1; }
  70% { transform: scale(1); opacity: 1; }
  100% { transform: scale(.86); opacity: 0; }
}

/* indicador discreto de modo autopilot + botón salir */
.auto-badge {
  position: fixed; top: 22px; right: 24px; z-index: 120;
  display: none; align-items: center; gap: 10px;
  padding: 9px 16px; border-radius: 999px;
  background: rgba(10,28,51,.7); border: 1px solid rgba(245,184,32,.4);
  color: var(--ink, #fff); font-size: 16px; font-weight: 600; backdrop-filter: blur(6px);
}
.auto-badge.show { display: inline-flex; }
.auto-badge .ab-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 12px var(--gold); animation: abpulse 1.6s ease infinite; }
@keyframes abpulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }
.auto-badge .ab-exit { margin-left: 6px; opacity: .7; text-decoration: underline; cursor: pointer; font-weight: 500; }

/* botón pausa/play dentro del badge de autopilot */
.auto-badge .ab-pause {
  width: 30px; height: 30px; flex: 0 0 auto; margin-right: 2px;
  border-radius: 50%; border: 1px solid rgba(245,184,32,.5);
  background: rgba(245,184,32,.16); color: var(--gold);
  font-size: 13px; line-height: 1; cursor: pointer; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s ease, transform .15s ease;
}
.auto-badge .ab-pause:hover { background: var(--gold); color: #0a1c33; transform: scale(1.08); }

/* contador de tiempo del clip (esquina inferior izquierda) */
.auto-time {
  position: fixed; left: 20px; bottom: 18px; z-index: 120;
  display: none; padding: 7px 14px; border-radius: 999px;
  background: rgba(7,19,34,.82); border: 1px solid rgba(245,184,32,.35);
  color: var(--gold-soft, #ffd97a); font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px; font-weight: 600; letter-spacing: .02em;
  font-variant-numeric: tabular-nums; backdrop-filter: blur(6px);
}
.auto-time.show { display: inline-block; }

/* ============ MÓVIL — portada (pantalla de inicio) ============ */
@media (max-width: 620px) {
  .start-panel { padding: 0 22px; }
  .start-title { font-size: 44px; margin-bottom: 20px; line-height: 1.08; }
  .start-sub { font-size: 19px; margin-bottom: 32px; }
  .start-actions { gap: 14px; width: 100%; }
  .start-btn { width: 100%; max-width: 380px; padding: 18px 20px; gap: 16px; border-radius: 16px; }
  .start-btn .sb-ic { width: 48px; height: 48px; font-size: 21px; }
  .start-btn .sb-tx b { font-size: 22px; }
  .start-btn .sb-tx small { font-size: 14px; white-space: normal; }
}
@media (max-width: 380px) {
  .start-title { font-size: 38px; }
  .start-btn .sb-tx b { font-size: 20px; }
}
/* ==== Móvil en HORIZONTAL / alto reducido: compactar para que TODO quepa sin recorte
   (y la .start-screen ya permite scroll como red de seguridad) ==== */
@media (max-height: 500px) {
  .start-panel { padding: 20px 28px; }
  .start-eyebrow { font-size: 14px; margin-bottom: 8px; }
  .start-title { font-size: 30px; margin-bottom: 10px; line-height: 1.05; }
  .start-sub { font-size: 15px; margin-bottom: 14px; }
  /* el selector de idioma se compacta en deck.css (carga después → gana el orden) */
  .start-actions { gap: 12px; flex-wrap: nowrap; }
  .start-btn { width: auto; min-width: 260px; padding: 11px 16px; gap: 12px; border-radius: 14px; }
  .start-btn .sb-ic { width: 38px; height: 38px; font-size: 17px; }
  .start-btn .sb-tx b { font-size: 17px; }
  .start-btn .sb-tx small { font-size: 12px; white-space: normal; }
  .desktop-hint { display: none !important; }
}

/* ============ Aviso "gira el teléfono" (móvil en vertical) ============ */
.rotate-hint {
  position: fixed; inset: 0; z-index: 240;
  display: none; flex-direction: column; align-items: center; justify-content: center;
  gap: 18px; text-align: center; padding: 40px;
  background: linear-gradient(180deg, var(--navy-deep, #061322), var(--navy, #0a1c33));
  color: var(--ink, #fff);
}
.rotate-hint .rh-ic {
  font-size: 78px; color: var(--gold);
  animation: rhturn 2.2s ease-in-out infinite;
}
@keyframes rhturn {
  0%, 40% { transform: rotate(0deg); }
  70%, 100% { transform: rotate(-90deg); }
}
.rotate-hint .rh-tx { font-family: 'Fraunces', serif; font-size: 30px; }
.rotate-hint .rh-sub { font-size: 17px; color: var(--ink-dim, #9fb3cc); }
/* En móvil (iOS o Android) en vertical tras elegir modo: pide girar. En Android que sí puede
   forzar el giro, el aviso apenas parpadea; si el lock falla, queda como red de seguridad. */
@media (orientation: portrait) {
  body.is-mobile.needs-landscape .rotate-hint { display: flex; }
}

/* ============ Autopilot limpio — oculta controles manuales y llena la pantalla ============ */
body.autopilot-clean .progress,
body.autopilot-clean .hint,
body.autopilot-clean .home-btn,
body.autopilot-clean .nav-arrow,
body.autopilot-clean .hud-corner { display: none !important; }

/* ============ Badge flotante: auto-ocultado + safe-area (notch) ============ */
.auto-badge {
  top: max(22px, env(safe-area-inset-top));
  right: max(24px, env(safe-area-inset-right));
  transition: opacity .28s ease, transform .28s ease;
}
.auto-badge.dim { opacity: 0; transform: translateY(-10px); pointer-events: none; }
@media (prefers-reduced-motion: reduce) {
  .auto-badge { transition: none; }
}

/* ============ Barra de progreso dorada (solo Autopilot a pantalla completa) ============ */
.auto-progress {
  position: fixed; z-index: 130;
  left: var(--slide-left, 0); right: var(--slide-right, 0);   /* del marco izq al der de la lámina */
  top: var(--slide-bottom, auto); bottom: auto;              /* justo debajo del borde inferior */
  height: 10px;
  background: rgba(255,255,255,.12); display: none;
}
body.autopilot-clean .auto-progress { display: block; }
.auto-progress > i {
  display: block; height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--gold-soft, #ffd97a), var(--gold, #f5b820));
  box-shadow: 0 0 12px var(--gold, #f5b820);
  border-radius: 0 3px 3px 0;
  transition: width .25s linear;
}

/* ============ Aviso móvil en la portada: mejor en ordenador ============ */
.desktop-hint { display: none; }
@media (max-width: 920px) and (pointer: coarse) {
  .desktop-hint {
    display: block; margin-top: 26px;
    font-size: 14px; color: var(--ink-dim, #9fb3cc);
    letter-spacing: .02em;
  }
  .desktop-hint b { color: var(--gold-soft, #ffd97a); font-weight: 600; }
}

/* ============================================================
   BONO 3 · Oportunidad global — luz de España desde el mundo
   Mapa satelital de fondo + arco dorado animado LatAm → España
   ============================================================ */
.ga-stage { position: relative; overflow: hidden; }
.ga-map {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: .92;
}
/* velo para legibilidad: oscurece arriba (título) y abajo (chips) */
.ga-veil {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(5,16,29,.82) 0%, rgba(5,16,29,.30) 22%, transparent 42%,
                            transparent 62%, rgba(5,16,29,.55) 82%, rgba(5,16,29,.88) 100%);
}
/* en esta lámina el .pad ocupa todo el stage (anula los márgenes de seguridad).
   padding-top = safe-top para que el stepper (.bono-steps, hijo de flujo) caiga
   en la MISMA posición vertical que en las láminas vecinas. Los elementos del
   mapa son position:absolute → la caja de relleno no cambia, no se ven afectados. */
.ga-stage .pad { position: absolute; inset: 0; z-index: 2; padding-top: var(--safe-top); }
/* panel de texto en la parte inferior del mapa (resaltado con caja + sombra) */
.ga-head {
  position: absolute; left: 0; right: 0; bottom: 72px;   /* centrado por margin, NO transform */
  width: min(1560px, 92%); margin-inline: auto; text-align: center;
  background: rgba(6, 19, 34, .82);
  border: 1px solid rgba(245,184,32,.30);
  border-radius: 24px;
  padding: 30px 56px 32px;
  box-shadow: 0 24px 70px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(9px);
}
.ga-head .title { font-size: 46px; line-height: 1.08; margin: 0; white-space: nowrap; }
.ga-head .subtitle { font-size: 28px; margin: 14px 0 0; }
/* animación de entrada del panel — usa transform sin romper el centrado (que va por margin) */
.ga-head { opacity: 0; }
.slide.active .ga-head { animation: gaUp .7s cubic-bezier(.2,.7,.3,1) both .35s; }
@keyframes gaUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
/* entrada de los nodos — SOLO opacity, para no tocar el transform que ancla el punto */
.ga-node { opacity: 0; }
.slide.active .ga-node { animation: gaFade .6s ease both .55s; }
@keyframes gaFade { from { opacity: 0; } to { opacity: 1; } }

/* --- SVG arcos --- */
.ga-arc { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; pointer-events: none; }
/* pathLength=1000 normaliza: todos los arcos se dibujan igual sin importar su largo real */
.ga-path { stroke-dasharray: 1000; stroke-dashoffset: 1000; }
.slide.active .ga-path { animation: gaDraw 1.25s cubic-bezier(.25,.7,.3,1) forwards var(--d, .45s); }
@keyframes gaDraw { to { stroke-dashoffset: 0; } }
/* monedas € que viajan por cada arco en bucle */
.ga-coin { opacity: 0; filter: drop-shadow(0 0 8px rgba(255,217,122,.85)); }
.ga-coin-tx {
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; font-size: 21px;
  fill: #0a1c33; text-anchor: middle; dominant-baseline: middle;
}

/* --- nodos con pulso (dot exacto sobre la zona + etiqueta debajo) --- */
.ga-node {
  position: absolute; z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  transform: translate(-50%, -50%);
}
/* LatAm: dot en el INICIO del arco (Brasil), etiqueta debajo */
.ga-from {
  left: 18.75%; top: 58.1%;
  flex-direction: column;
  transform: translate(-50%, -11px);
}
/* España: dot en el FINAL del arco (centro de la península), etiqueta ARRIBA sobre el mar */
.ga-to {
  left: 75.4%; top: 27.8%;
  flex-direction: column-reverse;
  transform: translate(-50%, calc(-100% + 11px));
}
.ga-dot {
  width: 20px; height: 20px; border-radius: 50%;
  background: #ffd97a; flex: 0 0 auto;
  box-shadow: 0 0 14px 3px rgba(245,184,32,.7);
  position: relative;
}
.ga-dot::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(245,184,32,.6); animation: gaPing 2.1s infinite;
}
.ga-dot.to { background: #fff; box-shadow: 0 0 16px 4px rgba(255,255,255,.75); }
.ga-dot.to::after { animation-delay: 1s; box-shadow: 0 0 0 0 rgba(255,255,255,.6); }
@keyframes gaPing {
  0%   { box-shadow: 0 0 0 0 rgba(245,184,32,.55); }
  70%  { box-shadow: 0 0 0 26px rgba(245,184,32,0); }
  100% { box-shadow: 0 0 0 0 rgba(245,184,32,0); }
}
.ga-tag {
  font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 700; font-size: 31px;
  color: #fff; background: rgba(10,28,51,.66); padding: 11px 22px; border-radius: 999px;
  border: 1px solid var(--line); white-space: nowrap;
  box-shadow: 0 8px 26px rgba(0,0,0,.35); backdrop-filter: blur(5px);
}
.ga-tag.strong { background: rgba(245,184,32,.16); border-color: rgba(245,184,32,.55); }

/* --- banderitas en cada punto (reemplazan dots/etiquetas) --- */
.ga-flag img {
  display: block; width: 40px; height: auto; border-radius: 5px;
  border: 1.5px solid rgba(255,255,255,.55);
  box-shadow: 0 3px 11px rgba(0,0,0,.55), 0 0 14px rgba(245,184,32,.45);
}
/* España = centro emisor, un poco más grande */
.ga-flag.ga-hub img { width: 48px; box-shadow: 0 4px 14px rgba(0,0,0,.6), 0 0 18px rgba(245,184,32,.6); }

