/* =========================================================
   LIBRETA DIGITAL · Landing
   Tema dark + glassmorphism + animaciones
   ========================================================= */

/* -------- 1. RESET BASE -------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter Tight','Inter',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  cursor:none;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

/* -------- 2. VARIABLES -------- */
:root{
  --primary-start:#d946ef;
  --primary-end:#8b5cf6;
  --primary-grad:linear-gradient(135deg,#d946ef 0%,#8b5cf6 100%);
  --accent:#d946ef;

  --bg:#08080f;
  --bg-elev:rgba(20,20,32,.55);
  --bg-card:rgba(22,22,38,.65);
  --bg-glass:rgba(18,18,30,.5);

  --border-soft:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.11);
  --border-strong:rgba(255,255,255,.18);

  --text:#f4f4fb;
  --text-muted:#a8a8c0;
  --text-dim:#6f6f88;

  --success:#22c55e;
  --warn:#f59e0b;
  --danger:#ef4444;

  --r-sm:10px;
  --r-md:16px;
  --r-lg:22px;
  --r-xl:32px;

  --shadow-card:0 12px 40px -12px rgba(0,0,0,.7), 0 2px 8px rgba(0,0,0,.4);
  --shadow-card-hover:0 24px 60px -16px rgba(217,70,239,.45), 0 8px 20px -8px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.12);
  --shadow-glow:0 0 60px -10px rgba(217,70,239,.45);
  --shadow-btn-primary:0 14px 50px -10px rgba(217,70,239,.7), inset 0 0 0 1px rgba(255,255,255,.25);
  --shadow-btn-primary-hover:0 22px 70px -10px rgba(217,70,239,.85), inset 0 0 0 1px rgba(255,255,255,.35);
  --glow-magenta:0 0 24px rgba(217,70,239,.5);
  --glow-violet:0 0 24px rgba(139,92,246,.5);

  --ease-out-quint:cubic-bezier(.2,.8,.2,1);
  --ease-in-out-smooth:cubic-bezier(.4,0,.2,1);

  --max:1200px;
  --gap:24px;
}

/* -------- 3. TIPOGRAFÍA -------- */
h1,h2,h3,h4{
  font-family:'Bricolage Grotesque','Inter Tight',sans-serif;
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.02em;
  color:#fff;
}
h1{font-size:clamp(2.4rem,5.5vw,4.4rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:700}
h3{font-size:clamp(1.15rem,1.4vw,1.35rem);font-weight:700}
.accent{
  background:linear-gradient(90deg,#d946ef 0%,#8b5cf6 50%,#d946ef 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  animation:gradShift 8s ease-in-out infinite;
}
@keyframes gradShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

/* -------- 4. LAYOUT -------- */
.container{
  width:100%;max-width:var(--max);
  margin:0 auto;padding:0 24px;
}
section{padding:clamp(64px,9vw,128px) 0;position:relative;z-index:2}
.section-head{margin-bottom:clamp(40px,6vw,72px)}
.section-head.center{text-align:center;max-width:760px;margin-left:auto;margin-right:auto}
.section-eyebrow{
  display:inline-block;
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.18em;
  color:var(--accent);
  padding:6px 12px;
  border:1px solid rgba(217,70,239,.3);
  border-radius:999px;
  background:rgba(217,70,239,.06);
  margin-bottom:18px;
}
.section-title{margin-bottom:14px}
.section-lead{
  font-size:clamp(1rem,1.2vw,1.12rem);
  color:var(--text-muted);max-width:640px;
}
.section-head.center .section-lead{margin-left:auto;margin-right:auto}

/* -------- 5. BUTTONS -------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:inherit;font-weight:600;font-size:.95rem;
  padding:13px 22px;border-radius:999px;
  position:relative;isolation:isolate;
  transition:transform .35s var(--ease-out-quint), box-shadow .35s var(--ease-out-quint), background .35s var(--ease-out-quint), border-color .35s var(--ease-out-quint);
  white-space:nowrap;cursor:none;
  letter-spacing:-.005em;
}
.btn-large{padding:16px 28px;font-size:1rem}
.btn-block{width:100%}
.btn-primary{
  background:var(--primary-grad);
  background-size:200% 100%;
  background-position:0% 50%;
  color:#fff;
  box-shadow:var(--shadow-btn-primary);
  transition:transform .35s var(--ease-out-quint), box-shadow .35s var(--ease-out-quint), background-position .6s var(--ease-out-quint);
}
.btn-primary:hover{
  transform:translateY(-3px);
  background-position:100% 50%;
  box-shadow:var(--shadow-btn-primary-hover);
}
.btn-primary:active{transform:translateY(-1px)}

/* Pulse rings on large primary CTA */
.btn-primary.has-pulse-ring::before,
.btn-primary.has-pulse-ring::after{
  content:'';position:absolute;inset:0;
  border-radius:inherit;
  border:1.5px solid rgba(217,70,239,.55);
  pointer-events:none;
  animation:pulseExpand 2.4s var(--ease-out-quint) infinite;
  z-index:-1;
}
.btn-primary.has-pulse-ring::after{animation-delay:1.2s}
@keyframes pulseExpand{
  0%{transform:scale(1);opacity:.8}
  100%{transform:scale(1.45);opacity:0}
}

.btn-ghost{
  background:rgba(255,255,255,.04);
  color:#fff;
  border:1px solid var(--border-strong);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.1);transform:translateY(-3px);border-color:rgba(217,70,239,.4)}
.btn-whatsapp{
  background:#25d366;color:#062b14;font-weight:700;
  box-shadow:0 10px 30px -10px rgba(37,211,102,.6), inset 0 1px 0 rgba(255,255,255,.3);
}
.btn-whatsapp:hover{transform:translateY(-3px);box-shadow:0 18px 50px -10px rgba(37,211,102,.8), inset 0 1px 0 rgba(255,255,255,.4)}

/* -------- 6. BACKGROUND LAYERS -------- */
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 80%);
}
.bg-orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{
  position:absolute;width:520px;height:520px;border-radius:50%;
  filter:blur(110px);opacity:.4;will-change:transform;
}
.orb-1{background:#d946ef;top:-120px;left:-100px;animation:orbA 28s ease-in-out infinite}
.orb-2{background:#8b5cf6;top:30%;right:-160px;animation:orbB 32s ease-in-out infinite}
.orb-3{background:#a855f7;bottom:-160px;left:30%;animation:orbC 24s ease-in-out infinite}
@keyframes orbA{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(80px,40px) scale(1.08)}
  66%{transform:translate(120px,80px) scale(.95)}
}
@keyframes orbB{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-100px,140px) scale(1.1)}
}
@keyframes orbC{
  0%,100%{transform:translate(0,0) scale(1)}
  40%{transform:translate(60px,-50px) scale(.92)}
  80%{transform:translate(80px,-80px) scale(1.05)}
}
.bg-noise{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence baseFrequency='0.9'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.7'/></svg>");
}

/* -------- 7. CURSOR CUSTOM -------- */
.cursor-ring,.cursor-dot{
  position:fixed;top:0;left:0;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:opacity .2s ease;
  will-change:transform;
}
.cursor-ring{
  width:32px;height:32px;border:1.5px solid rgba(217,70,239,.55);
  border-radius:50%;
  transition:transform .18s ease-out, width .2s ease, height .2s ease, border-color .2s ease;
}
.cursor-dot{
  width:6px;height:6px;background:var(--primary-grad);border-radius:50%;
}
.cursor-ring.is-hover{width:54px;height:54px;border-color:rgba(217,70,239,.85)}
@media (hover:none){.cursor-ring,.cursor-dot{display:none}body{cursor:auto} .btn{cursor:pointer}}

/* -------- 8. HEADER -------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:16px 0;
  transition:padding .25s ease, background .25s ease, backdrop-filter .25s ease, border-color .25s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  padding:10px 0;
  background:rgba(8,8,15,.7);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border-bottom-color:var(--border-soft);
}
.header-inner{
  max-width:var(--max);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:var(--primary-grad);
  box-shadow:0 6px 18px -6px rgba(217,70,239,.6);
  overflow:hidden;
}
.brand-mark img{width:24px;height:24px;object-fit:contain;filter:brightness(0) invert(1)}
.brand-name{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;font-size:1.15rem;letter-spacing:-.02em;
}
.brand-name b{
  background:var(--primary-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  font-weight:800;
}
.nav{display:flex;align-items:center;gap:18px}

/* -------- 9. HERO -------- */
.hero{
  min-height:100vh;
  padding-top:140px;padding-bottom:80px;
  display:flex;align-items:center;
  position:relative;
}
.hero-inner{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:60px;align-items:center;
}
.hero-text{max-width:620px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:.8rem;font-weight:600;
  color:var(--text-muted);
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  margin-bottom:24px;
  text-transform:uppercase;letter-spacing:.12em;
}
.pulse{
  width:8px;height:8px;border-radius:50%;
  background:#22c55e;
  position:relative;
}
.pulse::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  background:#22c55e;opacity:.4;
  animation:pulseRing 1.8s ease-out infinite;
}
@keyframes pulseRing{
  0%{transform:scale(.6);opacity:.6}
  100%{transform:scale(2.2);opacity:0}
}
.hero h1{margin-bottom:20px;perspective:1000px}
.rot{
  display:inline-block;position:relative;min-width:280px;text-align:left;
  perspective:600px;
}
.rot-word{
  display:inline-block;
  background:linear-gradient(90deg,#d946ef 0%,#8b5cf6 50%,#d946ef 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  white-space:nowrap;
  animation:gradShift 6s ease-in-out infinite;
  transform-origin:center bottom;
}
.cursor-blink{
  display:inline-block;width:3px;height:1em;
  background:var(--accent);
  border-radius:1px;
  vertical-align:-.12em;margin-left:5px;
  animation:blink 1s steps(2) infinite;
  box-shadow:0 0 8px rgba(217,70,239,.6);
}
@keyframes blink{50%{opacity:0}}

/* Word-by-word reveal for hero H1 — animation triggers only when parent .reveal is visible */
.word-anim{
  display:inline-block;
  opacity:0;
  transform:translateY(20px) rotateX(-45deg);
  transform-origin:center bottom;
}
.reveal.is-visible .word-anim,
.is-visible .word-anim{
  animation:letterIn .7s var(--ease-out-quint) forwards;
}
@keyframes letterIn{
  to{opacity:1;transform:translateY(0) rotateX(0)}
}
/* When H1 has word-anim children, skip the reveal fade so per-word animation isn't muted */
.hero-text h1.reveal{transition-duration:0s}
.hero-subtitle{
  font-size:clamp(1.05rem,1.3vw,1.2rem);
  color:var(--text-muted);
  margin-bottom:32px;line-height:1.6;
  max-width:540px;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.hero-trust{
  display:flex;gap:22px;flex-wrap:wrap;
  font-size:.92rem;color:var(--text-muted);
}
.hero-trust .check{
  color:#22c55e;font-weight:700;margin-right:4px;
}

/* -------- 10. HERO STAGE / CARD STACK -------- */
.hero-stage{
  position:relative;height:520px;
  display:flex;align-items:center;justify-content:center;
  perspective:1400px;
}
.stage-glow{
  position:absolute;inset:0;
  background:radial-gradient(circle at center, rgba(217,70,239,.25) 0%, transparent 60%);
  filter:blur(40px);z-index:0;
}
.card-stack{
  position:relative;width:340px;height:200px;
  transform-style:preserve-3d;
}
.acct-card{
  position:absolute;inset:0;
  border-radius:var(--r-lg);
  padding:22px 24px;
  display:flex;flex-direction:column;justify-content:space-between;
  color:#fff;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.55), 0 2px 0 rgba(255,255,255,.1) inset;
  border:1px solid rgba(255,255,255,.12);
  background:#222;
  transition:transform .8s cubic-bezier(.5,1.5,.5,1), opacity .8s ease, box-shadow .5s var(--ease-out-quint);
  will-change:transform,opacity;
  overflow:hidden;
}
.acct-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% -20%, rgba(255,255,255,.22), transparent 50%);
  pointer-events:none;
}
.acct-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(300px circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.18), transparent 45%);
  opacity:0;transition:opacity .4s var(--ease-out-quint);
  mix-blend-mode:overlay;
}
.acct-card[data-pos="0"]:hover::after{opacity:1}
.acct-card[data-pos="0"]:hover{
  box-shadow:0 40px 80px -20px rgba(217,70,239,.4), 0 30px 60px -20px rgba(0,0,0,.6), 0 2px 0 rgba(255,255,255,.18) inset;
}
.acct-card .row1{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.acct-logo{
  width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.95);
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
  overflow:hidden;
}
.acct-logo img{width:30px;height:30px;object-fit:contain;filter:brightness(0)}
.acct-info{min-width:0;flex:1}
.acct-name{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:700;font-size:1.02rem;
  letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.acct-sub{font-size:.78rem;opacity:.8;margin-top:2px}
.acct-row2{
  display:flex;align-items:center;justify-content:space-between;
  position:relative;z-index:1;
  padding-top:14px;border-top:1px solid rgba(255,255,255,.18);
}
.acct-label{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;opacity:.7}
.acct-countdown{
  font-family:'JetBrains Mono',monospace;
  font-weight:600;font-size:.95rem;
  padding:5px 10px;border-radius:8px;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(8px);
}
.acct-countdown.ok{color:#86efac}
.acct-countdown.warn{color:#fde047}
.acct-countdown.danger{color:#fca5a5;background:rgba(239,68,68,.25)}

/* Card stack positions — controlled via JS data-pos */
.acct-card[data-pos="0"]{transform:translate(0,0) rotate(0deg);z-index:4;opacity:1}
.acct-card[data-pos="1"]{transform:translate(-22px,-26px) rotate(-5deg);z-index:3;opacity:.85}
.acct-card[data-pos="2"]{transform:translate(22px,-46px) rotate(4deg);z-index:2;opacity:.65}
.acct-card[data-pos="3"]{transform:translate(0,-66px) rotate(0deg) scale(.94);z-index:1;opacity:.4}

/* -------- WA TOAST -------- */
.wa-toast{
  position:absolute;bottom:-10px;right:-20px;
  display:flex;gap:12px;align-items:flex-start;
  padding:14px 16px;
  background:rgba(20,22,30,.92);
  border:1px solid var(--border-strong);
  border-radius:14px;
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  box-shadow:0 16px 40px -14px rgba(0,0,0,.7);
  max-width:280px;
  z-index:5;
  animation:waFloat 5s ease-in-out infinite;
}
@keyframes waFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}
@keyframes waFloatMobile{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(-6px)}
}
.wa-ic{
  width:36px;height:36px;border-radius:50%;
  background:#25d366;color:#fff;
  display:grid;place-items:center;
  flex-shrink:0;
}
.wa-body{flex:1;min-width:0}
.wa-head{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  margin-bottom:3px;
}
.wa-from{font-weight:700;font-size:.85rem;color:#fff}
.wa-time{font-size:.72rem;color:var(--text-dim)}
.wa-msg{font-size:.85rem;color:var(--text-muted);line-height:1.4}

/* -------- 11. STATS -------- */
.stats{padding:60px 0;border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;text-align:center;
}
.stat-num{
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;font-size:clamp(2.2rem,3.5vw,3rem);
  letter-spacing:-.03em;
  background:var(--primary-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  line-height:1;
}
.stat-num small{font-size:.55em;opacity:.85;margin-left:2px}
.stat-lbl{
  margin-top:8px;font-size:.88rem;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:.06em;font-weight:500;
}

/* -------- 12. HOW (CÓMO FUNCIONA) -------- */
.how-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:flex-start;
}
.how-left{position:sticky;top:120px;align-self:flex-start}
.how-visual{
  position:relative;
  width:100%;aspect-ratio:1/1;max-width:480px;margin:0 auto;
  border-radius:var(--r-xl);
  background:linear-gradient(135deg, rgba(217,70,239,.08), rgba(139,92,246,.08));
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  overflow:hidden;
}
#howScene{position:absolute;inset:28px;}
.how-scene{
  position:absolute;inset:0;
  border-radius:var(--r-lg);
  background:rgba(15,15,25,.7);
  border:1px solid var(--border);
  padding:24px;
  display:flex;flex-direction:column;gap:12px;
  opacity:0;transform:translateY(20px) scale(.96);
  transition:opacity .55s ease, transform .55s ease;
  pointer-events:none;
  overflow:hidden;
}
.how-scene[data-active]{opacity:1;transform:translateY(0) scale(1)}

/* scene 0: form */
.scene-form .form-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:12px 14px;border-radius:10px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border-soft);
  font-size:.92rem;
  opacity:0;animation:slideIn .5s ease forwards;
}
.how-scene.scene-form[data-active] .form-row:nth-child(1){animation-delay:.1s}
.how-scene.scene-form[data-active] .form-row:nth-child(2){animation-delay:.25s}
.how-scene.scene-form[data-active] .form-row:nth-child(3){animation-delay:.4s}
.how-scene.scene-form[data-active] .form-row:nth-child(4){animation-delay:.55s}
@keyframes slideIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.scene-form .lbl{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em}
.scene-form .val{font-weight:600;color:#fff}
.scene-form .caret{
  display:inline-block;width:2px;height:1em;background:var(--accent);
  margin-left:3px;vertical-align:-.1em;border-radius:1px;
  animation:blink 1s steps(2) infinite;
  box-shadow:0 0 6px rgba(217,70,239,.6);
}

/* scene 1: list */
.scene-list{gap:8px}
.scene-list .li{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:10px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border-soft);
  font-size:.92rem;
  opacity:0;transform:translateX(-12px);
  animation:slideRight .5s ease forwards;
}
@keyframes slideRight{
  to{opacity:1;transform:translateX(0)}
}
.scene-list .li-dot{
  width:30px;height:30px;border-radius:8px;
  display:grid;place-items:center;
  font-weight:800;font-size:.78rem;color:#fff;
  flex-shrink:0;
  overflow:hidden;
}
.scene-list .li-dot img{
  width:18px;height:18px;object-fit:contain;
  filter:brightness(0) invert(1);
}
.scene-list .li strong{flex:1;font-weight:600}
.scene-list .li-state{
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;font-weight:600;
  padding:3px 8px;border-radius:6px;
}
.scene-list .li-state.ok{background:rgba(34,197,94,.18);color:#86efac}
.scene-list .li-state.warn{background:rgba(245,158,11,.18);color:#fde047}

/* scene 2: notif */
.scene-notif{align-items:center;justify-content:center}
.scene-notif .phone{
  display:flex;flex-direction:column;gap:10px;width:100%;max-width:280px;
}
.scene-notif .ntf{
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  opacity:0;
  animation:notifIn .5s ease forwards;
}
.how-scene.scene-notif[data-active] .ntf:nth-child(1){animation-delay:.2s}
@keyframes notifIn{
  from{opacity:0;transform:translateY(12px) scale(.94)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.scene-notif .ntf-head{
  font-size:.72rem;color:var(--text-dim);
  margin-bottom:4px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
}
.scene-notif .ntf-body{font-size:.86rem;color:#fff;line-height:1.4}
.scene-notif .ntf-cta{
  margin-top:14px;
  font-size:.8rem;color:#86efac;font-weight:600;
  text-align:center;
}

/* scene 3: money */
.scene-money{justify-content:space-between}
.scene-money .money-head{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}
.scene-money .money-num{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:2.4rem;font-weight:800;letter-spacing:-.03em;
  background:var(--primary-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  line-height:1;
}
.scene-money .money-sub{font-size:.85rem;color:var(--text-muted);margin-top:4px}
.scene-money .bars{
  display:flex;gap:6px;align-items:flex-end;height:80px;
}
.scene-money .bar{
  flex:1;background:var(--primary-grad);border-radius:4px;
  opacity:0;transform:scaleY(0);transform-origin:bottom;
  animation:barGrow .6s ease forwards;
}
@keyframes barGrow{
  to{opacity:1;transform:scaleY(1)}
}

/* steps right side */
.how-right{display:flex;flex-direction:column;gap:18px}
.step{
  padding:24px 26px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  backdrop-filter:blur(14px);
  transition:border-color .4s var(--ease-out-quint), transform .4s var(--ease-out-quint), background .4s var(--ease-out-quint), box-shadow .4s var(--ease-out-quint);
  position:relative;
  overflow:hidden;
  cursor:pointer;
  user-select:none;
}
.step:hover:not(.is-active){
  transform:translateX(4px);
  border-color:rgba(217,70,239,.25);
  background:rgba(217,70,239,.03);
}
.step:focus{outline:none}
.step:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(217,70,239,.55), 0 14px 36px -16px rgba(217,70,239,.45);
}
.step::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--primary-grad);
  transform:scaleY(0);transform-origin:top;
  transition:transform .5s var(--ease-out-quint);
}
.step::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%), rgba(217,70,239,.15), transparent 50%);
  opacity:0;transition:opacity .4s var(--ease-out-quint);
}
.step:hover::after{opacity:1}
.step > *{position:relative;z-index:1}
.step.is-active{
  border-color:rgba(217,70,239,.4);
  background:rgba(217,70,239,.06);
  transform:translateX(8px);
  box-shadow:0 14px 36px -16px rgba(217,70,239,.45);
}
.step.is-active::before{transform:scaleY(1)}
.step-num{
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;font-weight:600;
  color:var(--accent);
  letter-spacing:.1em;
}
.step h3{margin:6px 0 8px;color:#fff}
.step p{color:var(--text-muted);font-size:.95rem;line-height:1.55;margin-bottom:14px}
.step-hint{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;font-weight:600;
  color:var(--text-dim);
  text-transform:uppercase;letter-spacing:.1em;
  padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border-soft);
  transition:color .25s var(--ease-out-quint), border-color .25s var(--ease-out-quint), background .25s var(--ease-out-quint);
}
.step-hint .step-hint-arrow{
  width:12px;height:12px;flex-shrink:0;
  transition:transform .25s var(--ease-out-quint);
}
.step:hover .step-hint{
  color:var(--accent);
  border-color:rgba(217,70,239,.4);
  background:rgba(217,70,239,.08);
}
.step:hover .step-hint-arrow{transform:translateX(4px)}
.step.is-active .step-hint{
  color:#fff;
  border-color:rgba(217,70,239,.6);
  background:rgba(217,70,239,.18);
}
.step.is-active .step-hint .step-hint-text::after{content:'';display:none}
.step.is-active .step-hint-text{display:none}
.step.is-active .step-hint::before{
  content:'Mirando';
  font-family:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;text-transform:inherit;
}
.step.is-active .step-hint-arrow{transform:translateX(2px)}

/* -------- 13. FEATURES -------- */
.features-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.feature{
  position:relative;
  padding:30px 28px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  transition:transform .4s var(--ease-out-quint), border-color .4s var(--ease-out-quint), background .4s var(--ease-out-quint), box-shadow .4s var(--ease-out-quint);
  transform-style:preserve-3d;
  overflow:hidden;
}
.feature::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%), rgba(217,70,239,.22), transparent 45%);
  opacity:0;transition:opacity .4s var(--ease-out-quint);
}
.feature:hover{
  border-color:rgba(217,70,239,.35);
  background:rgba(28,28,46,.75);
  transform:translateY(-6px);
  box-shadow:var(--shadow-card-hover);
}
.feature:hover::after{opacity:1}
.feature:hover .feature-ic{
  transform:scale(1.08) rotate(-3deg);
  box-shadow:0 10px 26px -6px rgba(217,70,239,.45);
}
.feature-ic{transition:transform .4s var(--ease-out-quint), box-shadow .4s var(--ease-out-quint);position:relative;z-index:1}
.feature h3,.feature p{position:relative;z-index:1}
.feature-ic{
  width:48px;height:48px;border-radius:12px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, rgba(217,70,239,.18), rgba(139,92,246,.18));
  border:1px solid rgba(217,70,239,.25);
  color:#d946ef;
  margin-bottom:18px;
}
.feature-ic svg{width:22px;height:22px}
.feature h3{color:#fff;margin-bottom:8px}
.feature p{color:var(--text-muted);font-size:.94rem;line-height:1.55}

/* features 2x2 variant — original landing default */
.features:not(.security) .features-grid{grid-template-columns:repeat(2,1fr)}
@media (min-width:1100px){
  .features:not(.security) .features-grid{grid-template-columns:repeat(4,1fr)}
}

/* -------- 14. COMPARE -------- */
.compare-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.compare-col{
  padding:34px 32px;
  border-radius:var(--r-lg);
  border:1px solid var(--border);
  backdrop-filter:blur(14px);
}
.compare-col.bad{
  background:rgba(40,15,15,.4);
  border-color:rgba(239,68,68,.2);
}
.compare-col.good{
  background:rgba(15,30,20,.5);
  border-color:rgba(34,197,94,.25);
  box-shadow:0 14px 40px -16px rgba(34,197,94,.25);
}
.compare-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;font-weight:600;
  padding:6px 12px;border-radius:999px;
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:16px;
}
.compare-col.bad .compare-tag{background:rgba(239,68,68,.15);color:#fca5a5}
.compare-col.good .compare-tag{background:rgba(34,197,94,.15);color:#86efac}
.compare-col h3{margin-bottom:18px;font-size:1.4rem}
.compare-list li{
  display:flex;gap:12px;align-items:flex-start;
  padding:10px 0;
  font-size:.96rem;color:var(--text-muted);
  border-bottom:1px solid var(--border-soft);
}
.compare-list li:last-child{border-bottom:none}
.compare-list .ic{
  width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;flex-shrink:0;
  font-weight:800;font-size:.78rem;
  margin-top:1px;
}
.compare-col.bad .ic{background:rgba(239,68,68,.18);color:#fca5a5}
.compare-col.good .ic{background:rgba(34,197,94,.18);color:#86efac}

/* -------- 15. MARQUEE -------- */
.marquee-wrap{
  position:relative;
  overflow:hidden;
  padding:20px 0;
  mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
}
.marquee-track{
  display:flex;gap:32px;width:max-content;
  animation:marquee 40s linear infinite;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.marquee-item{
  display:flex;align-items:center;justify-content:center;
  height:80px;width:160px;
  padding:18px 22px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  flex-shrink:0;
  transition:transform .35s var(--ease-out-quint), border-color .35s var(--ease-out-quint), background .35s var(--ease-out-quint), box-shadow .35s var(--ease-out-quint);
}
.marquee-item:hover{
  transform:translateY(-5px) scale(1.04);
  border-color:rgba(217,70,239,.4);
  background:rgba(255,255,255,.08);
  box-shadow:0 14px 28px -10px rgba(217,70,239,.4);
}
.marquee-wrap:hover .marquee-track{animation-play-state:paused}
.marquee-item img{
  max-height:36px;width:auto;
  filter:brightness(0) invert(1);
  opacity:.75;
  transition:opacity .25s ease, filter .25s ease;
}
.marquee-item:hover img{opacity:1;filter:none}

/* -------- 16. TESTIMONIALS -------- */
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.tcard{
  position:relative;
  padding:36px 30px 28px;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  backdrop-filter:blur(14px);
  display:flex;flex-direction:column;
  overflow:hidden;
  transition:transform .4s var(--ease-out-quint), border-color .4s var(--ease-out-quint), box-shadow .4s var(--ease-out-quint);
}
.tcard::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(380px circle at var(--mx,50%) var(--my,50%), rgba(217,70,239,.18), transparent 50%);
  opacity:0;transition:opacity .4s var(--ease-out-quint);
}
.tcard:hover{
  border-color:rgba(217,70,239,.3);
  transform:translateY(-6px);
  box-shadow:var(--shadow-card-hover);
}
.tcard:hover::after{opacity:1}
.tcard > *{position:relative;z-index:1}
.quote-mark{
  position:absolute;top:14px;right:24px;
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:4.5rem;font-weight:800;
  background:var(--primary-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  line-height:1;opacity:.5;
  pointer-events:none;
}
.stars{
  font-size:.95rem;letter-spacing:1px;color:#fde047;margin-bottom:12px;
}
.tcard blockquote{
  font-size:1.02rem;color:#e8e8f4;
  line-height:1.55;margin-bottom:24px;flex:1;
}
.who{display:flex;align-items:center;gap:12px;margin-top:auto}
.avatar{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--primary-grad);
  font-weight:700;font-size:.92rem;color:#fff;
  letter-spacing:.02em;
  flex-shrink:0;
}
.who-name{font-weight:700;font-size:.95rem;color:#fff}
.who-role{font-size:.82rem;color:var(--text-muted)}

/* -------- 17. PRICING -------- */
.price-card{
  max-width:520px;margin:0 auto;
  padding:42px 38px;
  background:var(--bg-card);
  border:1px solid var(--border-strong);
  border-radius:var(--r-xl);
  backdrop-filter:blur(20px);
  text-align:center;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-glow), var(--shadow-card);
  transition:transform .5s var(--ease-out-quint), box-shadow .5s var(--ease-out-quint);
}
.price-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(500px circle at var(--mx,50%) var(--my,50%), rgba(217,70,239,.18), transparent 50%);
  opacity:0;transition:opacity .5s var(--ease-out-quint);
  z-index:0;
}
.price-card:hover{
  transform:translateY(-6px);
  box-shadow:0 30px 70px -10px rgba(217,70,239,.55), var(--shadow-card);
}
.price-card:hover::after{opacity:1}
.price-card > *{position:relative;z-index:1}
.price-card::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  padding:1px;
  background:linear-gradient(135deg, rgba(217,70,239,.6), rgba(139,92,246,.2), transparent 60%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
}
.price-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:rgba(34,197,94,.15);color:#86efac;
  font-family:'JetBrains Mono',monospace;
  font-size:.74rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:18px;
  border:1px solid rgba(34,197,94,.3);
}
.price-headline{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(2.4rem,4vw,3.4rem);font-weight:800;
  letter-spacing:-.03em;line-height:1;
  background:var(--primary-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  margin-bottom:6px;
}
.price-after{
  font-size:.85rem;color:var(--text-dim);
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:18px;
}
.price-options{
  display:flex;align-items:center;justify-content:center;gap:18px;
  margin-bottom:28px;flex-wrap:wrap;
}
.price-opt{display:flex;flex-direction:column;align-items:center;gap:2px}
.price-val{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1;
}
.price-cur{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.price-div{color:var(--text-dim);font-weight:500}
.price-feats{
  text-align:left;margin-bottom:26px;
  display:flex;flex-direction:column;gap:10px;
}
.price-feats li{
  display:flex;align-items:center;gap:10px;
  font-size:.94rem;color:var(--text-muted);
}
.price-feats .ic{
  width:20px;height:20px;border-radius:50%;
  background:rgba(34,197,94,.18);color:#86efac;
  display:grid;place-items:center;font-weight:800;font-size:.72rem;
  flex-shrink:0;
}
.price-fine{
  margin-top:14px;font-size:.78rem;color:var(--text-dim);
}

/* -------- 18. FAQ -------- */
.faq-list{
  max-width:760px;margin:0 auto;
  display:flex;flex-direction:column;gap:12px;
}
.faq-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  backdrop-filter:blur(12px);
  overflow:hidden;
  position:relative;
  transition:border-color .35s var(--ease-out-quint), background .35s var(--ease-out-quint), box-shadow .35s var(--ease-out-quint);
}
.faq-item::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(320px circle at var(--mx,50%) var(--my,50%), rgba(217,70,239,.12), transparent 55%);
  opacity:0;transition:opacity .35s var(--ease-out-quint);
}
.faq-item:hover{border-color:rgba(217,70,239,.28)}
.faq-item:hover::after{opacity:1}
.faq-item.is-open{
  border-color:rgba(217,70,239,.4);
  background:rgba(217,70,239,.06);
  box-shadow:0 16px 36px -16px rgba(217,70,239,.35);
}
.faq-item > *{position:relative;z-index:1}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;
  padding:18px 22px;
  font-size:1rem;font-weight:600;text-align:left;color:#fff;
}
.faq-plus{
  width:24px;height:24px;flex-shrink:0;
  position:relative;
  transition:transform .35s ease;
}
.faq-plus::before,.faq-plus::after{
  content:'';position:absolute;
  background:var(--accent);
  border-radius:2px;
}
.faq-plus::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%)}
.faq-plus::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);transition:transform .35s ease}
.faq-item.is-open .faq-plus{transform:rotate(180deg)}
.faq-item.is-open .faq-plus::after{transform:translateX(-50%) scaleY(0)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .45s ease;
}
.faq-a-inner{
  padding:0 22px 20px;
  font-size:.95rem;color:var(--text-muted);line-height:1.6;
}

/* -------- 19. CONTACT -------- */
.contact-inner{text-align:center;max-width:680px;margin:0 auto;padding:60px 24px}
.contact-inner h2{margin-bottom:14px}
.contact-inner p{color:var(--text-muted);font-size:1.1rem;margin-bottom:28px}

/* -------- 20. FOOTER -------- */
.site-footer{
  border-top:1px solid var(--border-soft);
  padding:48px 0 36px;
  position:relative;z-index:2;
}
.footer-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;gap:24px;
}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-brand img{width:32px;height:32px;object-fit:contain}
.footer-tag{font-size:.92rem;color:var(--text-muted)}
.footer-links{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.footer-links a{
  font-size:.92rem;color:var(--text-muted);
  transition:color .2s ease;
}
.footer-links a:hover{color:#fff}
.footer-copy{
  font-size:.82rem;color:var(--text-dim);text-align:right;
}

/* -------- 21. REVEAL ANIMATIONS -------- */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s ease, transform .8s ease;
  transition-delay:var(--rd, 0s);
}
.reveal.is-visible{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms!important;
    animation-iteration-count:1!important;
    transition-duration:.001ms!important;
  }
  .reveal{opacity:1;transform:none}
}

/* -------- 22. CONFETTI -------- */
.confetti-piece{
  position:fixed;top:0;left:0;
  width:8px;height:8px;
  pointer-events:none;z-index:9998;
  will-change:transform,opacity;
}

/* -------- 23. RESPONSIVE -------- */
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:50px}
  .hero-stage{height:440px;margin-top:20px}
  .how-wrap{grid-template-columns:1fr;gap:50px}
  .how-left{position:relative;top:0}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .features:not(.security) .features-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(4,1fr);gap:18px}
  .testimonials-grid{grid-template-columns:1fr;max-width:620px;margin:0 auto}
}

/* TOUCH / no-hover devices: kill cursor custom, allow native cursor, simplify hover-only effects */
@media (hover:none){
  body{cursor:auto}
  .btn{cursor:pointer}
  .cursor-ring,.cursor-dot{display:none}
  /* Pulse rings se mantienen, son CSS puro */
  /* tilt 3D queda en identidad por JS guard */
  .feature:hover,.tcard:hover,.faq-item:hover,.price-card:hover,.step:hover{transform:none}
  .marquee-item:hover{transform:none}
  /* Reducir intensidad de orbes en mobile para mejor performance */
  .orb{filter:blur(80px);opacity:.32}
  /* desactivar magnetic-buttons effect heredado */
}

@media (max-width:720px){
  section{padding:56px 0}
  .hero{padding-top:110px;min-height:auto;padding-bottom:40px}
  h1{font-size:clamp(2rem,8vw,2.6rem);line-height:1.1}
  h2{font-size:clamp(1.7rem,6vw,2.1rem)}
  .section-head{margin-bottom:36px}
  .section-eyebrow{font-size:.72rem;padding:5px 11px}
  .hero-eyebrow{font-size:.72rem;padding:6px 12px}
  .hero-subtitle{font-size:1rem;line-height:1.55;margin-bottom:24px}
  .hero-trust{gap:14px;font-size:.85rem}
  .hero-stage{height:360px}
  .card-stack{width:min(300px,86vw);height:180px}
  .acct-card[data-pos="1"]{transform:translate(-16px,-22px) rotate(-4deg)}
  .acct-card[data-pos="2"]{transform:translate(16px,-40px) rotate(3deg)}
  .acct-card[data-pos="3"]{transform:translate(0,-58px) scale(.94)}
  .acct-card{padding:18px 20px}
  .acct-name{font-size:.95rem}
  .acct-sub{font-size:.74rem}
  .acct-countdown{font-size:.86rem;padding:4px 8px}
  .wa-toast{right:auto;left:50%;bottom:-25px;max-width:min(280px,90vw);width:max-content;animation:waFloatMobile 5s ease-in-out infinite}
  .stats{padding:40px 0}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:28px}
  .features-grid,.features:not(.security) .features-grid{grid-template-columns:1fr;gap:16px}
  .feature{padding:24px 22px}
  .compare-grid{grid-template-columns:1fr;gap:16px}
  .compare-col{padding:26px 22px}
  .testimonials-grid{gap:16px}
  .tcard{padding:30px 24px 24px}
  .price-card{padding:32px 22px}
  .price-headline{font-size:clamp(2rem,8vw,2.6rem)}
  .price-feats li{font-size:.92rem}
  .hero-ctas{flex-direction:column;align-items:stretch;width:100%;gap:10px}
  .hero-ctas .btn{width:100%}
  .btn{padding:14px 22px;font-size:.95rem;min-height:48px}
  .btn-large{padding:16px 26px;min-height:54px;font-size:1rem}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-brand{justify-content:center}
  .footer-copy{text-align:center}
  .footer-links{gap:18px;justify-content:center}
  .marquee-item{height:64px;width:124px;padding:14px 16px}
  .marquee-item img{max-height:30px}
  .marquee-track{gap:18px}
  .quote-mark{font-size:3.5rem}
  .nav-cta{padding:10px 18px;font-size:.88rem;min-height:42px}
  .brand-mark{width:32px;height:32px}
  .brand-name{font-size:1.05rem}
  .site-header{padding:12px 0}
  .site-header.is-scrolled{padding:8px 0}
  .pricing .price-card{margin:0 auto}
  /* word-by-word más rápido en mobile */
  .word-anim{animation-duration:.5s}
  /* rot ancho se adapta al texto en mobile */
  .rot{min-width:0}
  /* contact CTA full width */
  .contact-inner .btn{width:100%;justify-content:center}
  .contact-inner{padding:40px 12px}
  .contact-inner p{font-size:1rem}
}

@media (max-width:480px){
  .container{padding:0 16px}
  h1{font-size:clamp(1.85rem,8.5vw,2.3rem)}
  h2{font-size:clamp(1.55rem,7vw,1.9rem)}
  .hero{padding-top:100px}
  .hero-eyebrow{padding:5px 10px;font-size:.68rem;letter-spacing:.08em}
  .hero-subtitle{font-size:.95rem}
  .price-options{flex-direction:column;gap:14px}
  .price-div{display:none}
  .price-card{padding:28px 18px}
  .feature{padding:22px 18px}
  .feature h3{font-size:1.05rem}
  .feature p{font-size:.9rem}
  .step{padding:20px 22px}
  .compare-col{padding:24px 18px}
  .compare-list li{font-size:.92rem}
  .tcard blockquote{font-size:.96rem}
  .faq-q{padding:16px 18px;font-size:.95rem}
  .faq-a-inner{padding:0 18px 18px;font-size:.9rem}
  .stat-num{font-size:clamp(1.9rem,8vw,2.4rem)}
  .stat-lbl{font-size:.78rem}
  .stats-grid{gap:22px}
  .hero-trust{gap:10px 18px;font-size:.82rem}
  .marquee-item{height:56px;width:110px;padding:12px 14px}
  .marquee-item img{max-height:26px}
  /* el cursor blink debe verse bien */
  .cursor-blink{width:2px;height:.9em}
  /* hero stage compacto */
  .hero-stage{height:300px;margin-top:8px}
  .card-stack{width:min(280px,82vw);height:160px}
  .acct-card{padding:16px 18px}
  .acct-logo{width:38px;height:38px;border-radius:10px}
  .acct-logo img{width:24px;height:24px}
  .wa-toast{padding:11px 13px;max-width:min(260px,88vw)}
  .wa-msg{font-size:.8rem}
  .wa-from{font-size:.8rem}
}

/* Extra small phones */
@media (max-width:360px){
  .hero h1{font-size:1.7rem}
  .rot{min-width:0}
  .price-headline{font-size:1.8rem}
}

/* Tap targets — accessibility */
@media (pointer:coarse){
  .btn,.faq-q,.nav a,.footer-links a{
    min-height:44px;
  }
}

/* Prevenir overflow horizontal */
html,body{overflow-x:hidden}

/* =========================================================
   24. MOBILE OPTIMIZATIONS — preserva desktop sin tocarlo
   ========================================================= */

/* ----- 24.1 Cómo funciona: tabs horizontales en mobile ----- */
/* El info dinámico solo se muestra en mobile (≤1024px, donde el grid colapsa). En desktop queda oculto. */
.how-active-info{display:none}

@media (max-width:1024px){
  /* Layout completo mobile: tabs → escena → info */
  .how-wrap{
    display:flex;
    flex-direction:column;
    gap:18px;
  }
  .how-right{
    order:0;
    display:flex;flex-direction:row;
    overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;
    gap:10px;
    padding:4px 4px 10px;
    margin:0 -4px;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .how-right::-webkit-scrollbar{display:none}
  .how-left{order:1;position:relative;top:0;width:100%}
  .how-active-info{order:2;display:block}

  /* Cada step se vuelve una pill compacta */
  .step{
    flex:0 0 auto;min-width:148px;max-width:220px;
    padding:14px 16px;
    scroll-snap-align:start;
  }
  .step::before,
  .step::after{display:none}  /* raya magenta y glow no aplican en pills horizontales */
  .step .step-num{font-size:.7rem}
  .step h3{font-size:.95rem;margin:4px 0 0}
  .step p,.step-hint{display:none}
  .step.is-active{
    transform:none;
    border-color:rgba(217,70,239,.55);
    background:rgba(217,70,239,.1);
    box-shadow:0 10px 28px -14px rgba(217,70,239,.5);
  }

  /* Visual del escenario: ya no es absolute, las escenas se montan en flujo natural */
  .how-visual{
    max-width:none;
    aspect-ratio:auto;
    min-height:0;
    height:auto;
    padding:14px;
    background:linear-gradient(135deg, rgba(217,70,239,.06), rgba(139,92,246,.06));
  }
  /* En mobile, el contenedor inicial absolute pasa a flujo */
  #howScene{
    position:relative;inset:auto;
    width:100%;
    min-height:300px;
  }
  /* Solo la escena activa se renderiza; el resto se oculta para evitar overlap */
  .how-scene{
    position:relative;inset:auto;
    display:none;
    opacity:1;transform:none;
    width:100%;
    min-height:280px;
  }
  .how-scene[data-active]{
    display:flex;
    animation:sceneFadeIn .4s var(--ease-out-quint);
  }

  /* Info del step activo (h3 + p) debajo de la escena */
  .how-active-info{
    padding:6px 4px 0;
    transition:opacity .25s ease;
  }
  .how-active-info h3{
    color:#fff;
    font-family:'Bricolage Grotesque',sans-serif;
    font-size:1.25rem;line-height:1.2;
    margin-bottom:8px;
  }
  .how-active-info p{
    color:var(--text-muted);
    font-size:.95rem;line-height:1.55;
  }
  .how-active-info .step-num-inline{
    display:inline-block;
    font-family:'JetBrains Mono',monospace;
    font-size:.72rem;font-weight:600;
    color:var(--accent);
    letter-spacing:.12em;text-transform:uppercase;
    margin-bottom:6px;
  }
  .how-active-info.fade-out{opacity:0}
}

@keyframes sceneFadeIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

/* ----- 24.2 Card stack swipe touch-action ----- */
.card-stack{touch-action:pan-y}

/* ----- 24.3 Marquee: pausa al tap mantenido en mobile ----- */
.marquee-wrap:active .marquee-track{animation-play-state:paused}

/* ----- 24.4 Feedback al entrar viewport en mobile (one-shot spotlight) ----- */
@media (hover:none){
  @keyframes tapSpot{
    0%{box-shadow:0 0 0 0 rgba(217,70,239,0)}
    35%{box-shadow:0 0 0 4px rgba(217,70,239,.18), 0 18px 42px -16px rgba(217,70,239,.45)}
    100%{box-shadow:0 0 0 0 rgba(217,70,239,0)}
  }
  .feature.reveal.is-visible,
  .tcard.reveal.is-visible,
  .price-card.reveal.is-visible{
    animation:tapSpot 1.4s var(--ease-out-quint) .15s 1;
  }
}

/* ----- 24.5 Feedback táctil en CTAs ----- */
.btn:active{transform:scale(.98)}
.btn-primary:active{transform:scale(.98) translateY(-1px)}