:root{
  --paper:#FFF6FB;
  --paper-deep:#FCE7F3;
  --ink:#2E2440;
  --ink-soft:#6A5B86;
  --teal:#7C5CFC;
  --teal-deep:#5B3BE0;
  --teal-night:#2B1E5C;
  --coral:#FF5DA2;
  --coral-deep:#E84A8C;
  --sun:#FFC93C;
  --sky:#5AB8FF;
  --lilac:#2BD4C4;
  --leaf:#57CC74;
  --card:#FFFFFF;
  --r-lg:28px;
  --r-md:20px;
  --border:3px solid var(--ink);
  --pop:7px 7px 0 rgba(46,36,64,.9);
  --pop-sm:4px 4px 0 rgba(46,36,64,.9);
  --display:'Baloo 2',cursive;
  --body:'Atkinson Hyperlegible',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  /* sutil textura de papel punteado */
  background-image:radial-gradient(rgba(46,36,64,.05) 1px, transparent 1.4px);
  background-size:26px 26px;
}
::selection{background:var(--sun);color:var(--ink)}
h1,h2,h3,.display{font-family:var(--display);line-height:1.12}
img,svg{display:block;max-width:100%}
a{color:inherit}

/* ---------- iconos de línea ---------- */
.ico{fill:none;stroke:var(--ink);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.feat .icon .ico,.aud .icon .ico{width:32px;height:32px}
.priv-list .ic .ico{width:23px;height:23px;stroke:#fff;stroke-width:2}
.sticker .ico{width:22px;height:22px;stroke-width:2}
.chip .ico{width:15px;height:15px;stroke-width:2.4}
.node .ico{width:26px;height:26px;stroke-width:2}
.quote .avatar .ico{width:24px;height:24px;stroke-width:2}
.wrap{width:min(1120px,92%);margin-inline:auto}

/* ---------- accesibilidad ---------- */
.skip{position:absolute;left:-999px;top:8px;background:var(--ink);color:var(--paper);padding:.6rem 1rem;border-radius:10px;z-index:99}
.skip:focus{left:8px}
:focus-visible{outline:3px dashed var(--coral);outline-offset:3px}

/* ---------- nav ---------- */
nav{
  position:sticky;top:14px;z-index:50;
  width:min(1120px,94%);margin:14px auto 0;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
  border:var(--border);border-radius:999px;box-shadow:var(--pop-sm);
  padding:.55rem .65rem .55rem 1.1rem;
}
.logo{display:flex;align-items:center;gap:.55rem;text-decoration:none;font-family:var(--display);font-weight:800;font-size:1.3rem}
.logo .dot{color:var(--coral)}
.logo-mark{width:38px;height:38px;flex:none;animation:bob 4s ease-in-out infinite}
.nav-links{display:flex;gap:1.4rem;list-style:none;font-weight:700;font-size:.95rem;white-space:nowrap}
.nav-links a{text-decoration:none;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:3px;background:var(--coral);border-radius:3px;transition:right .25s ease}
.nav-links a:hover::after{right:0}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--display);font-weight:700;font-size:1rem;
  text-decoration:none;cursor:pointer;
  border:var(--border);border-radius:999px;
  padding:.65rem 1.4rem;background:var(--sun);color:var(--ink);
  box-shadow:var(--pop-sm);
  transition:transform .15s ease,box-shadow .15s ease;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 rgba(46,36,64,.9)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 rgba(46,36,64,.9)}
.btn--coral{background:var(--coral);color:#fff}
.btn--ghost{background:#fff}
.btn--lg{font-size:1.15rem;padding:.85rem 1.8rem}
.nav-actions{display:flex;align-items:center;gap:.6rem}
.nav-actions .btn{white-space:nowrap}
.lang-toggle{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--display);font-weight:700;font-size:.9rem;
  cursor:pointer;color:var(--ink);
  border:var(--border);border-radius:999px;background:#fff;
  padding:.5rem .85rem;box-shadow:var(--pop-sm);
  transition:transform .15s ease,box-shadow .15s ease;
}
.lang-toggle .ico{width:18px;height:18px;stroke:var(--ink);stroke-width:2}
.lang-toggle:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 rgba(46,36,64,.9)}
.lang-toggle:active{transform:translate(2px,2px);box-shadow:2px 2px 0 rgba(46,36,64,.9)}
@media(max-width:1000px){.nav-links{display:none}}
@media(max-width:760px){
  .cloud{display:none}
  .lang-toggle__label{display:none}
  .lang-toggle{padding:.5rem}
  nav{padding:.5rem .55rem .5rem .9rem}
  .logo{font-size:1.15rem}
  .logo-mark{width:32px;height:32px}
  .nav-actions .btn{font-size:.9rem;padding:.55rem 1rem}
}
@media(max-width:430px){
  /* Spanish CTA + full logo + toggle no longer fit; the hero CTA covers it */
  .nav-actions .btn{display:none}
}

/* ---------- hero ---------- */
.hero{position:relative;padding:4.5rem 0 7rem}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.kicker{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;border:var(--border);border-radius:999px;
  padding:.4rem 1rem;font-weight:700;font-size:.85rem;
  box-shadow:var(--pop-sm);transform:rotate(-1.5deg);
}
.kicker .pulse{width:10px;height:10px;border-radius:50%;background:var(--leaf);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(87,204,116,.55)}50%{box-shadow:0 0 0 7px rgba(87,204,116,0)}}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.3rem);font-weight:800;margin:1.3rem 0 1.1rem;letter-spacing:-.01em}
.hero h1 .scribble{position:relative;display:inline-block;color:var(--teal-deep)}
.hero h1 .scribble svg{position:absolute;left:-2%;bottom:-.18em;width:104%;height:.42em;overflow:visible}
.hero h1 .scribble path{stroke:var(--sun);stroke-width:10;fill:none;stroke-linecap:round;stroke-dasharray:600;stroke-dashoffset:600;animation:draw 1s .7s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.hero p.lead{font-size:1.2rem;color:var(--ink-soft);max-width:34rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}
.hero-meta{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:2.2rem;font-size:.9rem;font-weight:700;color:var(--ink-soft)}
.hero-meta span{display:inline-flex;align-items:center;gap:.45rem}
.hero-meta svg{width:20px;height:20px;flex:none}

/* nube decorativa */
.cloud{position:absolute;border-radius:999px;background:#fff;border:var(--border);opacity:.7;animation:drift 14s ease-in-out infinite}
.cloud::before,.cloud::after{content:"";position:absolute;background:#fff;border:var(--border);border-radius:50%}
.cloud-1{width:110px;height:42px;top:9%;left:4%}
.cloud-1::before{width:44px;height:44px;top:-22px;left:18px}
.cloud-1::after{width:30px;height:30px;top:-13px;left:58px}
.cloud-2{width:90px;height:36px;top:16%;right:6%;animation-delay:-6s}
.cloud-2::before{width:36px;height:36px;top:-18px;left:14px}
.cloud-2::after{width:24px;height:24px;top:-10px;left:48px}
@keyframes drift{0%,100%{transform:translateX(0)}50%{transform:translateX(26px)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ---------- teléfono ---------- */
.stage{position:relative;display:flex;justify-content:center}
.phone{
  width:min(330px,86%);background:var(--ink);border-radius:44px;padding:12px;
  box-shadow:14px 14px 0 rgba(46,36,64,.18);
  transform:rotate(2.5deg);position:relative;z-index:2;
}
.screen{background:linear-gradient(180deg,#E7E0FF 0%,#F6F2FF 60%);border-radius:34px;overflow:hidden;position:relative;padding-bottom:1.2rem}
.screen-top{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.1rem .4rem;font-family:var(--display);font-weight:700;font-size:.85rem}
.chip{display:inline-flex;align-items:center;gap:.3rem;background:#fff;border:2px solid var(--ink);border-radius:999px;padding:.18rem .6rem;font-size:.78rem;box-shadow:2px 2px 0 rgba(46,36,64,.85)}
.chip--streak{background:var(--sun)}
.path-wrap{position:relative;height:330px;margin-top:.4rem}
.path-wrap svg.trail{position:absolute;inset:0;width:100%;height:100%}
.trail path{fill:none;stroke:var(--teal);stroke-width:7;stroke-linecap:round;stroke-dasharray:2 16;opacity:.6}
.node{
  position:absolute;width:58px;height:58px;border-radius:50%;
  border:3px solid var(--ink);display:grid;place-items:center;
  font-size:1.35rem;box-shadow:0 5px 0 rgba(46,36,64,.85);
  background:#fff;
}
.node--done{background:var(--leaf)}
.node--active{background:var(--sun);animation:nodePulse 1.8s infinite}
.node--locked{background:#E8E2D6;filter:grayscale(.4);opacity:.85}
@keyframes nodePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.09)}}
.screen-mascot{position:absolute;right:8px;bottom:64px;width:96px;animation:bob 3.5s ease-in-out infinite}
.bubble{
  position:absolute;right:96px;bottom:138px;background:#fff;border:2px solid var(--ink);
  border-radius:14px;padding:.35rem .6rem;font-family:var(--display);font-weight:700;font-size:.72rem;
  box-shadow:2px 2px 0 rgba(46,36,64,.85);white-space:nowrap;
}
.bubble::after{content:"";position:absolute;right:-8px;bottom:8px;border:6px solid transparent;border-left-color:var(--ink)}
.screen-cta{margin:0 1rem;background:var(--coral);border:2px solid var(--ink);border-radius:14px;color:#fff;text-align:center;font-family:var(--display);font-weight:700;padding:.6rem;box-shadow:0 4px 0 rgba(46,36,64,.85);font-size:.92rem}

/* stickers flotantes alrededor del teléfono */
.sticker{
  position:absolute;z-index:3;background:#fff;border:var(--border);border-radius:16px;
  box-shadow:var(--pop-sm);font-family:var(--display);font-weight:700;
  padding:.55rem .85rem;display:flex;align-items:center;gap:.5rem;font-size:.9rem;
}
.sticker em{font-style:normal;font-size:1.25rem}
.stk-1{top:6%;left:-2%;transform:rotate(-7deg);animation:bob 5s ease-in-out infinite}
.stk-2{bottom:18%;left:-6%;transform:rotate(4deg);animation:bob 6s .8s ease-in-out infinite}
.stk-3{top:24%;right:-4%;transform:rotate(6deg);animation:bob 5.5s .4s ease-in-out infinite}
.stk-4{bottom:4%;right:0%;transform:rotate(-4deg);animation:bob 6.5s 1.2s ease-in-out infinite}
@media(max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:4rem}
  .stk-2{left:0}.stk-3{right:0}
}

/* ---------- marquee ---------- */
.marquee{
  background:var(--teal);border-top:var(--border);border-bottom:var(--border);
  padding:.8rem 0;overflow:hidden;transform:rotate(-1deg) scale(1.02);position:relative;z-index:4;
}
.marquee-track{display:flex;gap:3rem;width:max-content;animation:scroll 26s linear infinite;font-family:var(--display);font-weight:700;color:#fff;font-size:1.05rem;white-space:nowrap}
.marquee-track span{display:inline-flex;align-items:center;gap:3rem}
.marquee-track .star{color:var(--sun)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- secciones ---------- */
section{padding:5.5rem 0}
.sec-head{max-width:42rem;margin-bottom:3.2rem}
.sec-tag{
  display:inline-block;font-family:var(--display);font-weight:700;font-size:.85rem;
  background:var(--lilac);border:var(--border);border-radius:999px;padding:.3rem 1rem;
  box-shadow:var(--pop-sm);transform:rotate(-1deg);margin-bottom:1.1rem;
}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:800;margin-bottom:.8rem}
.sec-head p{color:var(--ink-soft);font-size:1.08rem}

/* problema */
.problem .wrap{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center}
.problem blockquote{
  background:#fff;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--pop);
  padding:2rem 2.2rem;font-size:1.15rem;position:relative;transform:rotate(-1deg);
}
.problem blockquote::before{
  content:"“";position:absolute;top:-34px;left:18px;font-family:var(--display);
  font-size:5rem;color:var(--coral);line-height:1;
}
.problem blockquote footer{margin-top:1rem;font-weight:700;font-size:.9rem;color:var(--ink-soft)}
.problem ul{list-style:none;display:grid;gap:1.1rem;margin-top:1.6rem}
.problem li{display:flex;gap:.85rem;align-items:flex-start;font-size:1.05rem}
.problem li .tick{flex:none;width:30px;height:30px;border-radius:50%;background:var(--sun);border:2.5px solid var(--ink);display:grid;place-items:center;font-weight:800;font-size:.95rem;margin-top:.1rem}
@media(max-width:880px){.problem .wrap{grid-template-columns:1fr}}

/* features */
.features{background:var(--paper-deep);border-top:var(--border);border-bottom:var(--border)}
.feat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.6rem}
.feat{
  background:var(--card);border:var(--border);border-radius:var(--r-lg);
  box-shadow:var(--pop);padding:1.8rem 1.7rem;grid-column:span 2;
  transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;
}
.feat:hover{transform:translate(-3px,-3px) rotate(-.4deg);box-shadow:10px 10px 0 rgba(46,36,64,.9)}
.feat:nth-child(4),.feat:nth-child(5){grid-column:span 3}
.feat .icon{
  width:62px;height:62px;border-radius:18px;border:var(--border);display:grid;place-items:center;
  font-size:1.8rem;margin-bottom:1.2rem;box-shadow:var(--pop-sm);
}
.feat h3{font-size:1.35rem;font-weight:700;margin-bottom:.5rem}
.feat p{color:var(--ink-soft);font-size:.98rem}
.feat .corner{position:absolute;top:-26px;right:-26px;width:84px;height:84px;border-radius:50%;opacity:.18}
.i-map{background:var(--sky)}.c-map{background:var(--sky)}
.i-game{background:var(--coral)}.c-game{background:var(--coral)}
.i-badge{background:var(--sun)}.c-badge{background:var(--sun)}
.i-pet{background:var(--leaf)}.c-pet{background:var(--leaf)}
.i-panel{background:var(--lilac)}.c-panel{background:var(--lilac)}
@media(max-width:880px){.feat,.feat:nth-child(4),.feat:nth-child(5){grid-column:span 6}}

/* privacidad — banda oscura */
.privacy{
  background:var(--teal-night);color:#F2EEFC;position:relative;overflow:hidden;
  border-bottom:var(--border);
}
.privacy::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.07) 1.5px,transparent 2px);
  background-size:30px 30px;pointer-events:none;
}
.privacy .wrap{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;position:relative}
.privacy .sec-tag{background:var(--sun);color:var(--ink)}
.privacy h2{font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:800;margin-bottom:1rem}
.privacy p{color:#D8CEF5;font-size:1.08rem}
.priv-list{list-style:none;display:grid;gap:1rem;margin-top:1.8rem}
.priv-list li{display:flex;gap:.9rem;align-items:flex-start}
.priv-list .ic{flex:none;width:42px;height:42px;border-radius:13px;background:var(--lilac);border:2.5px solid #14746B;display:grid;place-items:center;font-size:1.2rem;box-shadow:3px 3px 0 rgba(0,0,0,.3)}
.priv-list b{display:block;font-family:var(--display);font-size:1.05rem;color:#fff}
.priv-list span{color:#D8CEF5;font-size:.95rem}
.vault{
  background:#3A2A78;border:3px solid #281A5A;border-radius:var(--r-lg);
  box-shadow:10px 10px 0 rgba(0,0,0,.28);padding:2.4rem;text-align:center;transform:rotate(1.2deg);
}
.vault .big{font-family:var(--display);font-weight:800;font-size:clamp(3rem,6vw,4.6rem);color:var(--sun);line-height:1}
.vault .sub{font-family:var(--display);font-weight:700;font-size:1.25rem;color:#fff;margin-top:.3rem}
.vault p{margin-top:1rem;font-size:.95rem}
.vault .tags{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.4rem}
.vault .tags span{background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.25);border-radius:999px;padding:.25rem .8rem;font-size:.8rem;font-weight:700;color:#ECE6FB}
@media(max-width:880px){.privacy .wrap{grid-template-columns:1fr}}

/* plan — timeline */
.plan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;counter-reset:fase}
.phase{
  background:#fff;border:var(--border);border-radius:var(--r-md);box-shadow:var(--pop);
  padding:1.6rem 1.4rem;position:relative;counter-increment:fase;
  transition:transform .2s ease;
}
.phase:hover{transform:translateY(-5px) rotate(-.6deg)}
.phase::before{
  content:counter(fase);position:absolute;top:-20px;left:-12px;
  width:46px;height:46px;border-radius:50%;border:var(--border);
  background:var(--coral);color:#fff;font-family:var(--display);font-weight:800;
  display:grid;place-items:center;font-size:1.2rem;box-shadow:var(--pop-sm);
}
.phase .dur{font-family:var(--display);font-weight:700;font-size:.8rem;background:var(--paper-deep);border:2px solid var(--ink);border-radius:999px;padding:.15rem .7rem;display:inline-block;margin-bottom:.7rem}
.phase h3{font-size:1.2rem;margin-bottom:.45rem}
.phase p{font-size:.92rem;color:var(--ink-soft)}
.plan-total{
  margin-top:2.6rem;text-align:center;font-family:var(--display);font-weight:800;
  font-size:clamp(1.3rem,2.6vw,1.8rem);
}
.plan-total mark{background:var(--sun);padding:.1rem .6rem;border-radius:10px;border:2.5px solid var(--ink);box-shadow:var(--pop-sm)}
@media(max-width:980px){.plan-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.plan-grid{grid-template-columns:1fr}}

/* cómo funciona — pasos */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;counter-reset:fase}
.steps-grid .phase{padding-top:2.5rem}
@media(max-width:880px){.steps-grid{grid-template-columns:1fr}}

/* para quién — audiencias */
.success{background:var(--paper-deep);border-top:var(--border)}
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.aud{
  background:#fff;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--pop);
  padding:1.9rem 1.7rem;transition:transform .2s ease,box-shadow .2s ease;
}
.aud:hover{transform:translate(-3px,-3px) rotate(-.4deg);box-shadow:10px 10px 0 rgba(46,36,64,.9)}
.aud .icon{
  width:58px;height:58px;border-radius:16px;border:var(--border);display:grid;place-items:center;
  font-size:1.7rem;margin-bottom:1.1rem;box-shadow:var(--pop-sm);
}
.aud h3{font-size:1.3rem;font-weight:700;margin-bottom:.55rem}
.aud p{color:var(--ink-soft);font-size:.97rem}
@media(max-width:880px){.aud-grid{grid-template-columns:1fr}}
.crit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.crit{
  display:flex;gap:1.1rem;align-items:flex-start;background:#fff;border:var(--border);
  border-radius:var(--r-md);box-shadow:var(--pop-sm);padding:1.4rem 1.5rem;
}
.crit .check{
  flex:none;width:46px;height:46px;border-radius:14px;border:var(--border);
  background:var(--leaf);display:grid;place-items:center;box-shadow:var(--pop-sm);
}
.crit .check svg{width:24px;height:24px;stroke:#fff;stroke-width:3.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.crit p{font-size:1rem}
.crit b{font-family:var(--display)}
@media(max-width:760px){.crit-grid{grid-template-columns:1fr}}

/* IA generativa */
.ai-sec{background:#F2ECFC;border-bottom:var(--border)}
.ai-sec .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.ai-chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.3rem}
.ai-chips .chip{font-size:.82rem;padding:.3rem .85rem}
.ai-points{list-style:none;display:grid;gap:1.3rem;margin-top:1.9rem}
.ai-points li{display:flex;gap:1rem;align-items:flex-start}
.ai-points .ic{flex:none;width:46px;height:46px;border-radius:14px;border:var(--border);background:var(--lilac);display:grid;place-items:center;box-shadow:var(--pop-sm)}
.ai-points .ic .ico{width:24px;height:24px;stroke:var(--ink);stroke-width:2}
.ai-points b{display:block;font-family:var(--display);font-size:1.08rem}
.ai-points span{color:var(--ink-soft);font-size:.97rem}
.ai-note{margin-top:2rem;background:#fff;border:var(--border);border-radius:var(--r-md);box-shadow:var(--pop-sm);padding:1rem 1.2rem;display:flex;gap:.7rem;align-items:flex-start;font-size:.95rem;font-weight:700}
.ai-note .ico{flex:none;width:22px;height:22px;stroke:var(--teal-deep);stroke-width:2.2;margin-top:.15rem;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ai-card{background:#fff;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--pop);padding:2rem 1.9rem;transform:rotate(-1.2deg)}
.ai-card-head{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.ai-card-head .spark{width:20px;height:20px;flex:none;fill:var(--coral);stroke:var(--ink);stroke-width:1.4;stroke-linejoin:round}
.ai-bubble{background:var(--paper);border:2px solid var(--ink);border-radius:16px;padding:1rem 1.1rem;font-size:1.02rem;box-shadow:var(--pop-sm)}
.ai-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem}
.ai-tags span{background:var(--lilac);border:2px solid var(--ink);border-radius:999px;padding:.2rem .75rem;font-size:.78rem;font-weight:700;box-shadow:2px 2px 0 rgba(46,36,64,.85)}
.ai-card-foot{margin-top:1.3rem;font-size:.85rem;color:var(--ink-soft);font-weight:700;display:flex;gap:.5rem;align-items:center}
.ai-card-foot .ico{flex:none;width:20px;height:20px;stroke:var(--teal-deep);stroke-width:2;fill:none}
@media(max-width:880px){.ai-sec .wrap{grid-template-columns:1fr}}

/* social proof */
.proof-stats{display:flex;flex-wrap:wrap;gap:1.2rem;margin-bottom:3.2rem}
.proof-stat{flex:1 1 170px;background:#fff;border:var(--border);border-radius:var(--r-md);box-shadow:var(--pop-sm);padding:1.4rem 1.2rem;text-align:center}
.proof-stat .num{font-family:var(--display);font-weight:800;font-size:2.2rem;color:var(--teal-deep);line-height:1}
.proof-stat .lbl{font-size:.88rem;color:var(--ink-soft);font-weight:700;margin-top:.45rem}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.quote{background:#fff;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--pop);padding:1.8rem 1.7rem;transition:transform .2s ease,box-shadow .2s ease}
.quote:hover{transform:translate(-3px,-3px) rotate(-.4deg);box-shadow:10px 10px 0 rgba(46,36,64,.9)}
.quotes-lead{font-size:1.05rem;color:var(--ink-soft);font-weight:700;margin-bottom:1.6rem;max-width:42rem}
.quote p{font-size:1.02rem;margin-bottom:1.3rem;font-style:italic}
.quote .who{display:flex;align-items:center;gap:.75rem}
.quote .avatar{width:44px;height:44px;border-radius:50%;border:var(--border);display:grid;place-items:center;font-size:1.25rem;flex:none;box-shadow:var(--pop-sm)}
.quote .who b{font-family:var(--display);font-size:.98rem;display:block}
.quote .who span{font-size:.82rem;color:var(--ink-soft)}
@media(max-width:880px){.quotes{grid-template-columns:1fr}}

/* faq */
.faq{background:var(--paper-deep);border-top:var(--border)}
.faq-list{display:grid;gap:1.1rem;max-width:52rem}
.faq-item{background:#fff;border:var(--border);border-radius:var(--r-md);box-shadow:var(--pop-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:1.2rem 1.4rem;font-family:var(--display);font-weight:700;font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item .plus{flex:none;width:30px;height:30px;border-radius:50%;border:2.5px solid var(--ink);display:grid;place-items:center;background:var(--sun);font-size:1.25rem;line-height:1;transition:transform .25s ease,background .25s ease}
.faq-item[open] .plus{transform:rotate(135deg);background:var(--coral);color:#fff}
.faq-item .ans{padding:0 1.4rem 1.3rem;color:var(--ink-soft);font-size:1rem}

/* CTA final */
.cta-final{padding:6.5rem 0 7rem;position:relative}
.cta-card{
  background:#CE2E7E;border:var(--border);border-radius:36px;box-shadow:12px 12px 0 rgba(46,36,64,.9);
  padding:4rem 3rem;text-align:center;color:#fff;position:relative;overflow:hidden;
}
.cta-card::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.16) 2px,transparent 2.6px);
  background-size:34px 34px;pointer-events:none;
}
.cta-card h2{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:800;position:relative}
.cta-card p{max-width:34rem;margin:1rem auto 2.2rem;font-size:1.1rem;color:#fff;font-weight:600;position:relative}
.cta-card .btn{position:relative}
.cta-card .mascot-peek{position:absolute;width:130px;right:4%;bottom:-12px;transform:rotate(8deg)}
.steps{display:flex;justify-content:center;gap:2.2rem;flex-wrap:wrap;margin-top:2.6rem;position:relative}
.steps div{font-family:var(--display);font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:.5rem}
.steps .n{width:30px;height:30px;border-radius:50%;background:#fff;color:var(--coral-deep);display:grid;place-items:center;border:2.5px solid var(--ink);font-size:.9rem}
@media(max-width:680px){.cta-card .mascot-peek{display:none}}

/* footer */
footer{border-top:var(--border);background:#fff;padding:2.2rem 0}
footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}
footer small{color:var(--ink-soft);font-size:.85rem}
footer .logo{font-size:1.1rem}
footer .logo-mark{width:30px;height:30px;animation:none}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal:nth-child(2){transition-delay:.08s}
.reveal:nth-child(3){transition-delay:.16s}
.reveal:nth-child(4){transition-delay:.24s}
.reveal:nth-child(5){transition-delay:.32s}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
