/* ============================================================
   EL KIT DEL IMPORTADOR — VSL sales page
   Brand: #111314 ink · #0143f7 blue · #061237 navy · #ffffff
   Font: Inter
   ============================================================ */

:root {
  --ink: #111314;
  --ink-2: #0a0c12;
  --blue: #0143f7;
  --blue-bright: #2f6bff;
  --blue-soft: #6b97ff;
  --navy: #061237;
  --navy-2: #08163f;
  --navy-deep: #030a22;
  --white: #ffffff;

  --paper: #f5f7fc;
  --paper-2: #eaeefa;
  --paper-line: #dfe4f1;
  --ink-soft: #4c5366;
  --ink-faint: #767d92;

  --on-dark: rgba(255, 255, 255, 0.72);
  --on-dark-faint: rgba(255, 255, 255, 0.5);
  --line-dark: rgba(255, 255, 255, 0.1);

  --coral: #ff6b6b;
  --gold: #f5c451;

  --r-sm: 10px;
  --r: 16px;
  --r-lg: 24px;
  --r-xl: 32px;

  --shadow-blue: 0 18px 50px -12px rgba(1, 67, 247, 0.55);
  --shadow-card: 0 24px 60px -28px rgba(6, 18, 55, 0.35);

  --maxw: 1120px;
  --readw: 720px;
  --ease: cubic-bezier(0.4, 0, 0.1, 1);

  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font);
  color: var(--ink);
  background: var(--navy-deep);
  line-height: 1.55;
  font-weight: 400;
  overflow-x: clip;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ---------- layout primitives ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: 22px; }
.read { max-width: var(--readw); margin-inline: auto; }
.section { position: relative; padding: clamp(64px, 9vw, 116px) 0; overflow: clip; }
.section--paper { background: var(--paper); color: var(--ink); }
.section--paper2 { background: var(--paper-2); color: var(--ink); }
.section--dark { background: var(--navy-deep); color: var(--white); }
.section--ink { background: var(--ink); color: var(--white); }

.center { text-align: center; }

/* ---------- type ---------- */
.eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 9px;
  max-width: 100%;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1.4;
  padding: 8px 16px;
  border-radius: 100px;
}
.eyebrow--dark {
  color: var(--blue-soft);
  background: rgba(1, 67, 247, 0.12);
  border: 1px solid rgba(1, 67, 247, 0.32);
}
.eyebrow--light {
  color: var(--blue);
  background: rgba(1, 67, 247, 0.08);
  border: 1px solid rgba(1, 67, 247, 0.2);
}
.eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 12px 2px var(--blue); }

h1, h2, h3 { font-weight: 800; line-height: 1.06; letter-spacing: -0.022em; text-wrap: balance; }

.h-hero { font-size: clamp(30px, 4vw, 46px); font-weight: 900; letter-spacing: -0.028em; line-height: 1.06; }
.h1 { font-size: clamp(28px, 4.3vw, 48px); }
.h2 { font-size: clamp(25px, 3.4vw, 39px); }
.h3 { font-size: clamp(19px, 2vw, 23px); }

.lead { font-size: clamp(16px, 1.5vw, 19px); line-height: 1.6; }
.muted-d { color: var(--on-dark); }
.muted-l { color: var(--ink-soft); }
.small { font-size: 13.5px; }
.tiny { font-size: 12px; letter-spacing: 0.04em; }

.hl { color: var(--blue); }
.hl-d { color: var(--blue-soft); }
.u { text-decoration: underline; text-decoration-color: var(--blue); text-underline-offset: 5px; text-decoration-thickness: 3px; }
.hu { color: var(--blue-soft); text-decoration: underline; text-decoration-color: var(--blue); text-underline-offset: 5px; text-decoration-thickness: 3px; }
.nowrap { white-space: nowrap; }

.kicker {
  font-size: 11.5px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--blue);
}
.kicker--gold { color: #b8852a; }

/* ---------- buttons ---------- */
.btn {
  --bx: 0;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font); font-size: 16px; font-weight: 700; letter-spacing: -0.01em;
  padding: 18px 30px; border: none; border-radius: 100px; cursor: pointer;
  position: relative; transition: transform 0.25s var(--ease), box-shadow 0.25s var(--ease), filter 0.25s var(--ease);
  text-align: center; line-height: 1.2;
}
.btn .arr { transition: transform 0.3s var(--ease); font-weight: 600; }
.btn:hover .arr { transform: translateX(4px); }
.btn--primary {
  color: #fff;
  background: linear-gradient(180deg, var(--blue-bright) 0%, var(--blue) 60%, #0036cc 100%);
  box-shadow: var(--shadow-blue), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}
.btn--primary:hover { transform: translateY(-3px); box-shadow: 0 26px 60px -12px rgba(1, 67, 247, 0.7), inset 0 1px 0 rgba(255, 255, 255, 0.45); }
.btn--primary:active { transform: translateY(-1px); }
.btn--lg { font-size: clamp(16px, 1.7vw, 19px); padding: 21px 38px; }
.btn--block { display: flex; width: 100%; }

.cta-note { margin-top: 14px; font-size: 13px; letter-spacing: 0.02em; }
.cta-note--d { color: var(--on-dark-faint); }
.cta-note--l { color: var(--ink-faint); }
.cta-note b { color: inherit; font-weight: 700; }

/* ---------- decorative: glow + mosaic ---------- */
.glow { position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none; z-index: 0; }
.glow--blue { background: radial-gradient(circle, rgba(1, 67, 247, 0.55), transparent 65%); }
.glow--navy { background: radial-gradient(circle, rgba(20, 60, 180, 0.4), transparent 70%); }

.mosaic { position: absolute; z-index: 0; pointer-events: none; }
.mblock { position: absolute; border-radius: 4px; }
.mblock.b1 { background: var(--blue); }
.mblock.b2 { background: rgba(1, 67, 247, 0.45); }
.mblock.b3 { background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); }

.section > .wrap { position: relative; z-index: 2; }

/* grid texture overlay for dark sections */
.gridtex::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000, transparent 75%);
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000, transparent 75%);
}

/* ============================================================
   ROTATING BADGE + GEAR
   ============================================================ */
.badge { width: 100%; height: 100%; display: block; overflow: visible; }
.badge .ring-text { font-size: 9.2px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }
.badge-spin { transform-origin: 60px 60px; animation: spin 18s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .badge-spin { animation: none; } }

.gear-grad-a { stop-color: #cdd6e6; }
.gear-grad-b { stop-color: #7c8aa6; }

/* ============================================================
   HEADER
   ============================================================ */
.topbar {
  position: relative; z-index: 60;
  background: rgba(3, 10, 34, 0.7);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line-dark);
}
.topbar .wrap { display: flex; align-items: center; justify-content: center; min-height: 52px; padding-block: 9px; }
.announce {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--on-dark); text-align: center; line-height: 1.4;
}
.announce .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--blue); box-shadow: 0 0 12px 2px var(--blue); flex: none; }
@media (max-width: 600px) { .announce { font-size: 10.5px; letter-spacing: 0.08em; } }
.brand { display: flex; align-items: center; gap: 11px; color: #fff; }
.brand .gico { width: 30px; height: 30px; flex: none; }
.brand b { font-weight: 800; font-size: 15px; letter-spacing: -0.01em; }
.brand .sub { color: var(--blue-soft); font-weight: 600; }
.topbar .price-pill {
  font-size: 13px; font-weight: 700; color: #fff;
  background: rgba(1, 67, 247, 0.18); border: 1px solid rgba(1, 67, 247, 0.4);
  padding: 7px 15px; border-radius: 100px;
}
@media (max-width: 600px) { .topbar .price-pill { display: none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; overflow: clip;
  background:
    radial-gradient(120% 80% at 50% -10%, #0e2a7a 0%, transparent 55%),
    radial-gradient(80% 60% at 85% 20%, rgba(1, 67, 247, 0.35) 0%, transparent 60%),
    linear-gradient(180deg, var(--navy) 0%, var(--navy-deep) 100%);
  color: #fff;
  padding: clamp(30px, 3.4vw, 48px) 0 clamp(44px, 5vw, 70px);
}
.hero .badge-wrap {
  position: absolute; top: 26px; right: clamp(16px, 4vw, 60px);
  width: clamp(86px, 11vw, 132px); height: clamp(86px, 11vw, 132px); z-index: 4;
}
.hero-inner { max-width: 1060px; margin-inline: auto; text-align: center; position: relative; z-index: 3; }
.hero .eyebrow { margin-bottom: 18px; }
.hero h1 { margin-bottom: 0; }
.hero h1 .hl-d { display: inline; }

/* video */
.vsl { margin: clamp(24px, 2.6vw, 34px) auto 0; max-width: 720px; position: relative; z-index: 3; }
.vsl-soundbar {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  font-size: 12.5px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink); background: linear-gradient(180deg, var(--gold), #eab93f);
  padding: 11px; border-radius: var(--r) var(--r) 0 0; cursor: pointer;
  box-shadow: 0 0 0 1px rgba(245, 196, 81, 0.5);
}
.vsl-frame {
  position: relative; aspect-ratio: 16 / 9; background: #05080f; cursor: pointer;
  border: 1px solid rgba(255, 255, 255, 0.12); border-top: none;
  overflow: hidden; box-shadow: 0 40px 90px -30px rgba(0, 0, 0, 0.8), 0 0 0 1px rgba(1, 67, 247, 0.18);
}
.vsl-frame img, .vsl-frame video, .vsl-frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; border: 0; }
.vsl-poster {
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 60% at 50% 42%, rgba(1, 67, 247, 0.28), transparent 70%),
    linear-gradient(135deg, #0a1330, #05080f);
  display: flex; align-items: center; justify-content: center;
}
.vsl-poster::after {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
  background-size: 40px 40px;
}
.play {
  width: 78px; height: 78px; border-radius: 50%; position: relative; z-index: 2;
  background: linear-gradient(180deg, var(--blue-bright), var(--blue));
  display: grid; place-items: center;
  box-shadow: 0 0 0 10px rgba(1, 67, 247, 0.16), 0 16px 40px -8px rgba(1, 67, 247, 0.7);
  transition: transform 0.3s var(--ease);
}
.vsl-frame:hover .play { transform: scale(1.07); }
.play svg { width: 28px; height: 28px; margin-left: 4px; fill: #fff; }
.play-ripple { position: absolute; inset: 0; border-radius: 50%; border: 2px solid rgba(1,67,247,.5); animation: ripple 2.4s ease-out infinite; }
@keyframes ripple { 0% { transform: scale(1); opacity: 0.7; } 100% { transform: scale(2.1); opacity: 0; } }
.vsl-footbar {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--on-dark-faint); background: #05080f; padding: 9px;
  border: 1px solid rgba(255, 255, 255, 0.1); border-top: none; border-radius: 0 0 var(--r) var(--r);
}
.hero-cta { margin-top: clamp(26px, 3.5vw, 36px); text-align: center; }

/* ============================================================
   FEATURE CARDS (3 herramientas)
   ============================================================ */
.sec-head { text-align: center; max-width: 740px; margin: 0 auto clamp(34px, 5vw, 54px); }
.sec-head .eyebrow { margin-bottom: 18px; }
.sec-head p { margin-top: 16px; }

.cards3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.fcard {
  background: #fff; border: 1px solid var(--paper-line); border-radius: var(--r-lg);
  padding: 30px 26px; position: relative; overflow: hidden;
  box-shadow: var(--shadow-card); transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.fcard:hover { transform: translateY(-5px); box-shadow: 0 34px 70px -30px rgba(6, 18, 55, 0.4); }
.fcard::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--blue), var(--blue-bright)); }
.ficon {
  width: 56px; height: 56px; border-radius: 15px; display: grid; place-items: center; margin-bottom: 20px;
  background: linear-gradient(160deg, #0c2a82, var(--blue)); color: #fff;
  box-shadow: 0 12px 26px -10px rgba(1, 67, 247, 0.6);
}
.ficon svg { width: 27px; height: 27px; stroke: #fff; fill: none; stroke-width: 1.8; }
.fcard .num { position: absolute; top: 22px; right: 24px; font-size: 13px; font-weight: 800; color: var(--paper-line); }
.fcard h3 { font-size: 18px; letter-spacing: -0.01em; margin-bottom: 9px; }
.fcard p { font-size: 14.5px; color: var(--ink-soft); line-height: 1.55; }

/* ============================================================
   COMPARISON
   ============================================================ */
.cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 920px; margin-inline: auto; }
.cmp-col { border-radius: var(--r-lg); padding: 28px 26px; }
.cmp-col--bad { background: #fff; border: 1px solid #f1d4d4; }
.cmp-col--good {
  background: linear-gradient(170deg, var(--navy-2), var(--navy-deep)); color: #fff;
  border: 1px solid rgba(1, 67, 247, 0.4); box-shadow: var(--shadow-blue);
}
.cmp-head { display: flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 20px; padding-bottom: 18px; }
.cmp-col--bad .cmp-head { color: var(--coral); border-bottom: 1px solid #f1d4d4; }
.cmp-col--good .cmp-head { color: var(--blue-soft); border-bottom: 1px solid rgba(255, 255, 255, 0.14); }
.cmp-list { display: flex; flex-direction: column; gap: 16px; }
.cmp-item { display: flex; gap: 12px; font-size: 14.5px; line-height: 1.5; }
.cmp-item .ci { flex: none; width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; margin-top: 1px; }
.cmp-col--bad .cmp-item { color: var(--ink-soft); }
.cmp-col--bad .ci { background: #fdecec; color: var(--coral); }
.cmp-col--good .cmp-item { color: rgba(255, 255, 255, 0.84); }
.cmp-col--good .ci { background: rgba(1, 67, 247, 0.25); color: var(--blue-soft); }
.cmp-item .ci svg { width: 12px; height: 12px; stroke-width: 2.6; fill: none; stroke: currentColor; }

/* ============================================================
   AUTHORITY / STATS (Daniel)
   ============================================================ */
.auth { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 40px; align-items: center; }
.auth-card {
  border-radius: var(--r-lg); overflow: hidden; position: relative;
  background: linear-gradient(160deg, #0c2a82, var(--blue) 60%, #0036cc);
  border: 1px solid rgba(255, 255, 255, 0.16); aspect-ratio: 4 / 4.3;
  box-shadow: var(--shadow-blue);
}
.auth-photo { position: absolute; inset: 0; padding: 18px; }
.auth-photo .ph { width: 100%; height: 100%; object-fit: contain; object-position: center; }
.auth-card .ovl {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 30px 22px 22px;
  background: linear-gradient(0deg, rgba(3, 10, 34, 0.98) 0%, rgba(3, 10, 34, 0.92) 38%, rgba(3, 10, 34, 0.55) 70%, transparent 100%);
}
.auth-card .big { font-size: clamp(38px, 5vw, 54px); font-weight: 900; letter-spacing: -0.03em; line-height: 1; color: #fff; text-shadow: 0 2px 18px rgba(0, 0, 0, 0.6); }
.auth-card .cap { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue-soft); font-weight: 700; margin-top: 6px; }
.auth-badge { position: absolute; top: 16px; right: 16px; background: var(--coral); color: #fff; font-size: 10px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; padding: 6px 11px; border-radius: 100px; }
.auth-right h2 { margin-bottom: 26px; }
.stats { display: flex; flex-direction: column; gap: 16px; }
.stat { background: rgba(255, 255, 255, 0.04); border: 1px solid var(--line-dark); border-radius: var(--r); padding: 16px 18px; }
.stat-top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 9px; }
.stat-label { font-size: 13px; font-weight: 600; color: var(--on-dark); letter-spacing: 0.02em; }
.stat-val { font-size: 18px; font-weight: 800; color: #fff; }
.stat-val .hl-d { color: var(--blue-soft); }
.bar { height: 6px; border-radius: 100px; background: rgba(255, 255, 255, 0.08); overflow: hidden; }
.bar i { display: block; height: 100%; border-radius: 100px; background: linear-gradient(90deg, var(--blue), var(--blue-bright)); width: 0; }
.anim .bar i { transition: width 1.2s var(--ease); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.tcards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.tcard {
  background: #fff; border: 1px solid var(--paper-line); border-radius: var(--r-lg); padding: 26px;
  box-shadow: var(--shadow-card); display: flex; flex-direction: column;
}
.tcard .stars { color: var(--gold); font-size: 14px; letter-spacing: 2px; margin-bottom: 14px; }
.tcard .quote { font-size: 14.5px; line-height: 1.6; color: var(--ink); flex: 1; }
.tcard .who { display: flex; align-items: center; gap: 12px; margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--paper-2); }
.tcard .av { width: 42px; height: 42px; border-radius: 50%; flex: none; display: grid; place-items: center; color: #fff; font-weight: 800; font-size: 16px; background: linear-gradient(160deg, #0c2a82, var(--blue)); }
.tcard .who b { font-size: 14px; font-weight: 700; display: block; }
.tcard .who span { font-size: 12px; color: var(--ink-faint); }

/* ============================================================
   PARA TI (checklist) — dark
   ============================================================ */
.fitlist { display: flex; flex-direction: column; gap: 18px; max-width: 720px; margin: 0 auto; }
.fititem {
  display: flex; gap: 16px; align-items: flex-start;
  background: rgba(255, 255, 255, 0.04); border: 1px solid var(--line-dark);
  border-radius: var(--r); padding: 20px 22px;
  transition: border-color 0.3s var(--ease), background 0.3s var(--ease);
}
.fititem:hover { border-color: rgba(1, 67, 247, 0.5); background: rgba(1, 67, 247, 0.08); }
.fititem .chk {
  flex: none; width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; margin-top: 1px;
  background: linear-gradient(160deg, var(--blue-bright), var(--blue)); color: #fff;
  box-shadow: 0 6px 16px -4px rgba(1, 67, 247, 0.7);
}
.fititem .chk svg { width: 14px; height: 14px; stroke: #fff; stroke-width: 3; fill: none; }
.fititem p { font-size: 15px; line-height: 1.55; color: rgba(255, 255, 255, 0.84); }
.fititem p b { color: #fff; font-weight: 700; }

/* ============================================================
   BANNER
   ============================================================ */
.banner { background: var(--ink); padding: clamp(40px, 6vw, 64px) 0; text-align: center; position: relative; overflow: clip; }
.banner .sm { font-size: 13px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--blue-soft); font-weight: 600; margin-bottom: 14px; }
.banner .bigtitle { font-size: clamp(30px, 6vw, 64px); font-weight: 900; letter-spacing: -0.03em; line-height: 1; color: #fff; }
.banner .bigtitle .hl-d { color: var(--blue); }

/* ============================================================
   INCLUDES (tools breakdown)
   ============================================================ */
.incl { display: flex; flex-direction: column; gap: 18px; max-width: 880px; margin: 0 auto; }
.irow {
  display: grid; grid-template-columns: 244px 1fr; align-items: stretch;
  background: #fff; border: 1px solid var(--paper-line); border-radius: var(--r-lg);
  overflow: hidden; box-shadow: var(--shadow-card);
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.irow:hover { transform: translateY(-3px); box-shadow: 0 30px 64px -28px rgba(6, 18, 55, 0.4); }
.irow--bonus { background: linear-gradient(170deg, #fffbf0, #fff7e2); border-color: #f1e0b0; }

.imedia {
  position: relative; min-height: 198px; padding: 20px;
  display: grid; place-items: center;
  background: linear-gradient(160deg, var(--navy-2), var(--navy-deep));
}
.imedia img { width: 100%; height: 100%; max-height: 215px; object-fit: contain; filter: drop-shadow(0 16px 32px rgba(0, 0, 0, 0.5)); }
.imedia--full { padding: 12px; }
.imedia--full img { max-height: 220px; object-fit: contain; border-radius: 10px; filter: none; }

.inum {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center;
  font-size: 18px; font-weight: 900; color: #fff;
  background: linear-gradient(160deg, #0c2a82, var(--blue));
  box-shadow: 0 10px 22px -8px rgba(1, 67, 247, 0.7), 0 0 0 4px rgba(3, 10, 34, 0.35);
}
.irow--bonus .inum { background: linear-gradient(160deg, #d4a017, var(--gold)); color: #5a4106; box-shadow: 0 10px 22px -8px rgba(212, 160, 23, 0.6), 0 0 0 4px rgba(3, 10, 34, 0.35); }
.ibody { padding: 26px 28px; align-self: center; }
.irow .kicker { margin-bottom: 7px; }
.irow h3 { font-size: 19px; margin-bottom: 9px; }
.irow p { font-size: 14.5px; color: var(--ink-soft); line-height: 1.58; }
.irow .meta { display: flex; align-items: center; gap: 14px; margin-top: 14px; flex-wrap: wrap; }
.irow .val { font-size: 13px; font-weight: 700; color: var(--ink-faint); text-decoration: line-through; }
.irow .inc { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--blue); background: rgba(1, 67, 247, 0.08); padding: 5px 11px; border-radius: 100px; }
.irow--bonus .inc { color: #b8852a; background: rgba(212, 160, 23, 0.12); }
.irow .inc svg { width: 12px; height: 12px; stroke-width: 3; fill: none; stroke: currentColor; }

/* ============================================================
   OFFER / PRICE STACK
   ============================================================ */
.offer { max-width: 560px; margin: 0 auto; position: relative; z-index: 3; }

.offer-card {
  background: linear-gradient(170deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
  border: 1px solid rgba(255, 255, 255, 0.16); border-radius: var(--r-xl);
  padding: clamp(28px, 4vw, 40px); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 40px 90px -30px rgba(0, 0, 0, 0.7), inset 0 1px 0 rgba(255, 255, 255, 0.16);
}
.offer-title { font-size: 13px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue-soft); text-align: center; margin-bottom: 18px; }
.offer-stack { width: 100%; display: block; margin: 0 auto 22px; filter: drop-shadow(0 22px 40px rgba(0, 0, 0, 0.55)); }
.olist { display: flex; flex-direction: column; gap: 0; }
.oitem { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--line-dark); }
.oitem .nm { font-size: 14.5px; color: rgba(255, 255, 255, 0.86); display: flex; align-items: center; gap: 10px; }
.oitem .nm svg { width: 16px; height: 16px; color: var(--blue-soft); flex: none; stroke-width: 2.4; fill: none; stroke: currentColor; }
.oitem .pr { font-size: 13.5px; font-weight: 700; color: var(--on-dark-faint); text-decoration: line-through; flex: none; }
.ototal { display: flex; align-items: center; justify-content: space-between; margin-top: 22px; }
.ototal .lbl { font-size: 12px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; }
.ototal .tval { font-size: 24px; font-weight: 800; color: #fff; text-decoration: line-through; }
.oprice { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin: 12px 0 24px; padding-top: 22px; border-top: 1px dashed rgba(255, 255, 255, 0.2); }
.oprice .lbl { font-size: 13px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: #fff; }
.oprice .now { display: flex; align-items: baseline; gap: 8px; }
.oprice .now .dollar { font-size: 28px; font-weight: 800; color: var(--blue-soft); }
.oprice .now .amt { font-size: clamp(52px, 9vw, 70px); font-weight: 900; letter-spacing: -0.04em; color: #fff; line-height: 0.9; }
.oprice .now .usd { font-size: 16px; font-weight: 700; color: var(--on-dark); }

/* ============================================================
   GUARANTEE
   ============================================================ */
.guar { text-align: center; max-width: 680px; margin: 0 auto; }
.seal { width: 132px; height: auto; display: block; margin: 0 auto 24px; filter: drop-shadow(0 14px 26px rgba(150, 110, 10, 0.4)); }
.shield {
  width: 84px; height: 84px; margin: 0 auto 26px; border-radius: 22px; display: grid; place-items: center;
  background: linear-gradient(160deg, #0c2a82, var(--blue)); color: #fff;
  box-shadow: 0 18px 44px -14px rgba(1, 67, 247, 0.55);
}
.shield svg { width: 40px; height: 40px; stroke: #fff; stroke-width: 1.6; fill: none; }
.guar h2 { margin-bottom: 18px; }
.guar p { color: var(--ink-soft); font-size: 15.5px; line-height: 1.7; }

/* ============================================================
   FINAL CTA
   ============================================================ */
.final { text-align: center; position: relative; z-index: 3; }
.final h2 { font-size: clamp(28px, 4.6vw, 50px); font-weight: 900; letter-spacing: -0.03em; line-height: 1.05; max-width: 820px; margin: 0 auto 18px; }
.trust { display: flex; align-items: center; justify-content: center; gap: 10px 22px; flex-wrap: wrap; margin-top: 22px; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--on-dark-faint); font-weight: 600; }
.trust span { display: inline-flex; align-items: center; gap: 7px; }
.trust svg { width: 14px; height: 14px; color: var(--blue-soft); stroke-width: 2.2; fill: none; stroke: currentColor; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { background: #02060f; color: var(--on-dark-faint); padding: 40px 0; text-align: center; }
.foot .brand { justify-content: center; margin-bottom: 14px; }
.foot .copy { font-size: 12.5px; line-height: 1.7; }
.foot .disc { font-size: 11px; color: rgba(255, 255, 255, 0.3); margin-top: 12px; max-width: 640px; margin-inline: auto; }

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: rgba(3, 10, 34, 0.86); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-top: 1px solid rgba(1, 67, 247, 0.3);
  transform: translateY(120%); transition: transform 0.4s var(--ease);
}
.sticky-cta.show { transform: translateY(0); }
.sticky-info { display: flex; align-items: center; justify-content: center; gap: 14px; margin-bottom: 10px; }
.sticky-text { text-align: left; font-size: 12.5px; font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase; color: var(--on-dark); line-height: 1.25; }
.sticky-count { flex: none; color: #fff; font-size: 24px; font-weight: 800; font-variant-numeric: tabular-nums; background: rgba(1, 67, 247, 0.22); border: 1px solid rgba(1, 67, 247, 0.5); border-radius: 10px; padding: 7px 13px; letter-spacing: 0.04em; }
.sticky-cta .btn { padding: 15px; font-size: 15.5px; }
@media (min-width: 861px) {
  .sticky-cta { display: flex; align-items: center; justify-content: center; gap: 30px; padding: 14px 32px; }
  .sticky-info { margin-bottom: 0; gap: 18px; }
  .sticky-text { font-size: 14.5px; line-height: 1.2; }
  .sticky-count { font-size: 28px; padding: 8px 16px; }
  .sticky-cta .btn { width: auto; flex: none; padding: 15px 34px; font-size: 16.5px; }
}

/* ============================================================
   REVEAL ANIMATION
   Transform-only slide (no opacity fade) so that even if a transition
   freezes at its start frame (hidden/non-painting capture frames),
   content stays fully visible. Only active once `.anim` is on <html>.
   ============================================================ */
.anim .rev { transform: translateY(22px); transition: transform 0.6s var(--ease); }
.anim .rev.in { transform: none; }
.anim .rev.d1 { transition-delay: 0.08s; }
.anim .rev.d2 { transition-delay: 0.16s; }
.anim .rev.d3 { transition-delay: 0.24s; }
@media (prefers-reduced-motion: reduce) { .anim .rev { transform: none; transition: none; } }

/* ---- image entrance: fade + scale, only once the card is in view AND
   the image has actually loaded (prevents lazy-load pop-in) ---- */
.anim .imedia img,
.anim .offer-stack { opacity: 0; transform: translateY(16px) scale(0.96); transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
.anim .irow.in .imedia img.loaded,
.anim .offer-card.in .offer-stack.loaded { opacity: 1; transform: none; }
.anim .auth-card .ph { opacity: 0; transform: scale(1.05); transition: opacity 0.9s var(--ease), transform 1.3s var(--ease); }
.anim .auth-card.in .ph.loaded { opacity: 1; transform: none; }
.anim .seal { opacity: 0; transform: scale(0.86) translateY(10px); transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); }
.anim .guar.in .seal.loaded { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .anim .imedia img, .anim .offer-stack, .anim .auth-card .ph, .anim .seal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 860px) {
  .cards3 { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
  .tcards { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
  .cmp { grid-template-columns: 1fr; max-width: 480px; }
  .auth { grid-template-columns: 1fr; gap: 28px; }
  .auth-card { width: 100%; max-width: 420px; margin-inline: auto; aspect-ratio: 4 / 4.3; }
  body { padding-bottom: 76px; }
}

@media (max-width: 560px) {
  .wrap { padding-inline: 18px; }
  .btn { width: 100%; padding: 17px 22px; font-size: 15.5px; }
  .hero .badge-wrap { display: none; }
  .hero .mosaic { display: none; }
  .hero .eyebrow { font-size: 10.5px; letter-spacing: 0.1em; padding: 7px 14px; }
  .irow { grid-template-columns: 1fr; }
  .imedia { min-height: 150px; }
  .imedia img { max-height: 180px; }
  .ibody { padding: 22px 20px; }
  .inum { width: 40px; height: 40px; font-size: 16px; border-radius: 11px; }
  .vsl-soundbar { font-size: 10.5px; letter-spacing: 0.04em; }
  .play { width: 64px; height: 64px; }
  .h-hero { font-size: clamp(19px, 5.4vw, 26px) !important; line-height: 1.16 !important; }
  .hero { padding-top: 16px; }
  .vsl { margin-top: 16px; }
  .oitem .nm { font-size: 13px; }
  .oitem .pr { font-size: 12.5px; }
  .banner .bigtitle { font-size: clamp(30px, 11vw, 48px); }
}
