/* ════════════════════════════════════════════════════════════
   ARISE — Become More · Landing
   Sistema visual heredado de la app (antes Atlas)
   ════════════════════════════════════════════════════════════ */

:root{
  /* ── TOKENS REALES DE LA APP (src/theme/colors.ts) ── */
  /* fondos: negro-violeta ELEVADO (las superficies "flotan"; legible a plena luz) */
  --bg:#0B0910; --bg2:#15131C;
  --base:#15131C; --base-elev:#1E1B28;
  --surface:#2A2738; --surface2:#353147; --surface3:#403B54;
  --border:rgba(255,255,255,.14); --border2:rgba(255,255,255,.24);
  --text:#F6F5FB; --muted:#BDBBCB; --faint:#8C89A0;
  /* violeta del Sistema */
  --v1:#C9A0FF; --v2:#8C63FF; --v3:#5733E0;
  --primary-soft:rgba(140,99,255,.16);
  /* gradiente del Sistema: magenta → violeta → azul (energía: orbe, XP, CTA, rango) */
  --sys-a:#E64DFF; --sys-b:#8C63FF; --sys-c:#3B6BFF;
  --sys:linear-gradient(135deg,var(--sys-a) 0%,var(--sys-b) 50%,var(--sys-c) 100%);
  /* cian: acento de "Ventana del Sistema" / datos */
  --cyan:#46E5FF; --cyan2:#2CC9E6; --cyan-soft:#A8F2FF;
  /* ember: consecuencias / rachas (ámbar → rojo). amber* = alias de ember */
  --ember1:#FFB13D; --ember2:#FF3D5A; --ember-soft:#FFD08A;
  --amber:#FFB13D; --amber2:#FF7A45; --amber-soft:#FFD08A;
  --lime:#A3E635; --rose:#FB7BA2;
  --ember:linear-gradient(135deg,var(--ember1),var(--ember2));
  /* gradientes compuestos (en hues de marca) */
  --ai:linear-gradient(135deg,var(--cyan) 0%,var(--v2) 100%);
  --warm:linear-gradient(135deg,var(--ember-soft) 0%,var(--ember1) 45%,var(--ember2) 100%);
  --spectrum:linear-gradient(110deg,var(--sys-a) 0%,var(--v2) 46%,var(--cyan) 100%);
  --recovery:linear-gradient(135deg,#46E5FF,#5B8CFF);
  /* liquid glass: SOLO para superficies que flotan sobre contenido/aura */
  --glass-bg:rgba(48,44,64,0.66);
  --glass-brd:rgba(255,255,255,.16);
  --glass-blur:18px;
  --font:'Manrope',system-ui,sans-serif;
  --disp:'Space Grotesk',system-ui,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
  --maxw:1180px;
  --pad:clamp(20px,5vw,40px);
  --space:1; /* densidad multiplier */
  --anim:1;  /* intensidad de animación 0..1 */
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.mono{font-family:var(--mono);letter-spacing:-.02em}
.muted{color:var(--muted)}
.grad-text{background:var(--sys);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── Cosmic backdrop ─────────────────────────────────── */
.cosmos{position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(62% 46% at 50% -10%,rgba(140,99,255,.20),transparent 62%),
    radial-gradient(40% 36% at 85% 8%,rgba(70,229,255,.07),transparent 60%),
    radial-gradient(46% 44% at 12% 96%,rgba(140,99,255,.08),transparent 62%),
    var(--bg);}
.cosmos__grid{position:absolute;inset:0;opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask:radial-gradient(80% 60% at 50% 0%,#000,transparent 80%);
  mask:radial-gradient(80% 60% at 50% 0%,#000,transparent 80%);}
.stars{position:absolute;inset:0;}
.stars i{position:absolute;width:2px;height:2px;border-radius:50%;background:#fff;opacity:.5;
  animation:twinkle 4s ease-in-out infinite}
@keyframes twinkle{0%,100%{opacity:.08}50%{opacity:.5}}

/* ── Shell ───────────────────────────────────────────── */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative}
.sec-pad{padding-top:calc(110px * var(--space));padding-bottom:calc(110px * var(--space))}

/* ── Eyebrow ─────────────────────────────────────────── */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);
  font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--v2);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(140,99,255,.55);animation:pulseDot 2.6s infinite}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(140,99,255,.5)}70%{box-shadow:0 0 0 7px rgba(140,99,255,0)}100%{box-shadow:0 0 0 0 rgba(140,99,255,0)}}

.sec-head{max-width:760px}
.sec-head .eyebrow{margin-bottom:18px}
h2.sec-title{font-family:var(--disp);font-weight:700;letter-spacing:-.025em;line-height:1.05;
  font-size:clamp(32px,5.2vw,54px);margin:0;text-wrap:balance}
.sec-sub{color:var(--muted);font-size:clamp(16px,1.6vw,19px);margin-top:20px;max-width:620px;text-wrap:pretty}

/* ── Buttons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;
  font-size:15px;border-radius:14px;padding:15px 24px;transition:transform .14s ease,box-shadow .2s,filter .2s;
  white-space:nowrap}
.btn:active{transform:scale(.97)}
.btn--primary{color:#0A0A0F;background:var(--sys);
  box-shadow:0 8px 30px rgba(124,99,255,.42),inset 0 1px 0 rgba(255,255,255,.4)}
.btn--primary:hover{filter:brightness(1.07);box-shadow:0 12px 40px rgba(124,99,255,.55),inset 0 1px 0 rgba(255,255,255,.5)}
.btn--ghost{color:var(--text);background:var(--surface2);border:1px solid var(--border2)}
.btn--ghost:hover{border-color:rgba(160,138,230,.5);background:var(--surface3)}
.btn--lg{font-size:16px;padding:17px 30px;border-radius:16px}
.btn--block{width:100%}

/* ── Nav ─────────────────────────────────────────────── */
.nav{position:sticky;top:0;z-index:60;transition:background .3s,border-color .3s,backdrop-filter .3s;
  border-bottom:1px solid transparent}
.nav--scrolled{background:rgba(10,10,15,.72);backdrop-filter:blur(18px) saturate(150%);
  -webkit-backdrop-filter:blur(18px) saturate(150%);border-bottom-color:var(--border)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:11px}
.brand__mark{width:30px;height:30px;border-radius:9px;background:var(--sys);display:grid;place-items:center;
  box-shadow:0 0 18px rgba(140,99,255,.5);flex-shrink:0}
.brand__mark span{width:10px;height:10px;background:#0A0A0F;border-radius:2px;transform:rotate(45deg)}
.brand__name{font-family:var(--disp);font-weight:700;letter-spacing:.24em;font-size:17px;padding-left:2px}
.brand__tag{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--faint);
  border:1px solid var(--border);border-radius:99px;padding:3px 8px;margin-left:4px;text-transform:uppercase}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:14.5px;font-weight:600;color:var(--muted);transition:color .2s}
.nav__links a:hover{color:var(--text)}
.nav__cta{display:flex;align-items:center;gap:14px}
.nav__burger{display:none}

/* ── Hero ────────────────────────────────────────────── */
.hero{position:relative;padding-top:clamp(60px,9vh,110px);padding-bottom:40px;text-align:center;overflow:hidden}
.hero__aura{position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:min(900px,120vw);height:760px;
  pointer-events:none;z-index:0;
  background:radial-gradient(45% 45% at 50% 45%,rgba(140,99,255,.20),transparent 72%);
  animation:auraBreathe 11s ease-in-out infinite}
@keyframes auraBreathe{0%,100%{opacity:.7;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.06)}}
.hero__in{position:relative;z-index:2;max-width:880px;margin:0 auto}
.hero__orb{margin:0 auto 30px}
.hero h1{font-family:var(--disp);font-weight:700;letter-spacing:-.03em;line-height:1.02;
  font-size:clamp(40px,8vw,84px);margin:0;text-wrap:balance}
.hero h1 em{font-style:normal;display:block}
.hero__sub{color:#C7C4D6;font-size:clamp(17px,1.9vw,21px);line-height:1.55;margin:26px auto 0;
  max-width:600px;text-wrap:pretty}
.hero__sub b{color:var(--text);font-weight:700}

/* waitlist form */
.waitlist{display:flex;gap:10px;max-width:480px;margin:34px auto 0;
  background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:7px;
  box-shadow:0 20px 60px rgba(0,0,0,.45)}
.waitlist input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--text);
  font-family:inherit;font-size:15px;font-weight:500;padding:0 14px}
.waitlist input::placeholder{color:var(--faint)}
.waitlist .btn{flex-shrink:0}
.waitlist--ok{justify-content:center;color:#C9A0FF;font-weight:700;padding:18px}
.hero__trust{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:20px;
  font-size:13px;color:var(--muted);flex-wrap:wrap}
.hero__avatars{display:flex}
.hero__avatars span{width:26px;height:26px;border-radius:50%;margin-left:-8px;border:2px solid var(--bg);
  background:var(--sys);box-shadow:0 0 0 1px var(--border)}
.hero__avatars span:nth-child(2){background:linear-gradient(135deg,#B9A0E8,#7A4DE0)}
.hero__avatars span:nth-child(3){background:linear-gradient(135deg,#8C8AA0,#4A4860)}
.hero__avatars span:nth-child(4){background:linear-gradient(135deg,#C9A8FF,#9C6BFF)}
.dotsep{color:var(--faint)}

/* ── Phone device ────────────────────────────────────── */
.phone{position:relative;width:248px;border-radius:42px;padding:9px;flex-shrink:0;
  background:linear-gradient(160deg,#26242F,#0d0d12);
  box-shadow:0 2px 0 rgba(255,255,255,.06) inset,0 40px 80px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.04);}
.phone::before{content:'';position:absolute;top:16px;left:50%;transform:translateX(-50%);
  width:78px;height:22px;background:#000;border-radius:99px;z-index:3}
.phone__screen{position:relative;border-radius:34px;overflow:hidden;background:#000;aspect-ratio:445/920}
.phone__screen img{width:100%;height:100%;object-fit:cover}
.phone__glow{position:absolute;inset:-18% -12%;z-index:-1;border-radius:50%;
  background:radial-gradient(50% 50% at 50% 50%,rgba(140,99,255,.30),transparent 70%);filter:blur(22px)}

/* hero phone trio */
.hero__stage{position:relative;z-index:2;display:flex;justify-content:center;align-items:flex-end;
  gap:clamp(-30px,-2vw,0px);margin-top:54px;perspective:1600px}
.hero__stage .phone{transition:transform .5s cubic-bezier(.22,1,.36,1)}
.hero__stage .phone--l{transform:translateX(40px) translateY(34px) rotateY(16deg) scale(.86);opacity:.92;z-index:1}
.hero__stage .phone--c{z-index:3;transform:translateY(-6px)}
.hero__stage .phone--r{transform:translateX(-40px) translateY(34px) rotateY(-16deg) scale(.86);opacity:.92;z-index:1}
@media(hover:hover){
  .hero__stage:hover .phone--l{transform:translateX(8px) translateY(20px) rotateY(10deg) scale(.9)}
  .hero__stage:hover .phone--r{transform:translateX(-8px) translateY(20px) rotateY(-10deg) scale(.9)}
}

/* scroll progress + ambient cursor glow */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:80;
  background:linear-gradient(90deg,var(--v1),var(--v3));box-shadow:0 0 12px rgba(140,99,255,.55)}
.hero__cursor{position:absolute;width:520px;height:520px;border-radius:50%;z-index:1;pointer-events:none;
  left:50%;top:34%;transform:translate(-50%,-50%);opacity:0;transition:opacity .6s ease;mix-blend-mode:screen;
  background:radial-gradient(50% 50% at 50% 50%,rgba(124,99,255,.14),transparent 68%)}
.hero:hover .hero__cursor{opacity:1}

/* ── Marquee strip ───────────────────────────────────── */
.strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:26px 0;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent);
  mask:linear-gradient(90deg,transparent,#000 14%,#000 86%,transparent)}
.strip__track{display:flex;gap:0;width:max-content;animation:marquee 40s linear infinite}
.strip__track span{font-family:var(--mono);font-weight:400;font-size:12.5px;letter-spacing:.26em;color:var(--faint);
  text-transform:uppercase;display:inline-flex;align-items:center;gap:46px;white-space:nowrap;padding-right:46px}
.strip__track span::after{content:'—';color:var(--v3);opacity:.5}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ── Orb (recreado de la app) ────────────────────────── */
.orb{position:relative;border-radius:50%;display:grid;place-items:center;flex-shrink:0}
.orb__glow{position:absolute;inset:-30%;border-radius:50%;
  background:radial-gradient(50% 50% at 50% 50%,rgba(150,90,255,.7),rgba(90,60,255,.25) 55%,transparent 72%);
  animation:orbPulse 4s ease-in-out infinite;filter:blur(2px)}
@keyframes orbPulse{0%,100%{transform:scale(.92);opacity:.5}50%{transform:scale(1.08);opacity:.85}}
.orb__swirl{position:absolute;inset:6%;border-radius:50%;
  background:conic-gradient(from 0deg,transparent,rgba(200,150,255,.65),transparent 40%,rgba(120,90,255,.55),transparent 75%);
  filter:blur(3px);animation:spin 9s linear infinite;mix-blend-mode:screen}
.orb__swirl--rev{inset:18%;animation:spin 13s linear infinite reverse;
  background:conic-gradient(from 120deg,transparent,rgba(150,110,255,.5),transparent 50%,rgba(190,160,255,.45),transparent)}
@keyframes spin{to{transform:rotate(360deg)}}
.orb__core{position:absolute;inset:30%;border-radius:50%;
  background:radial-gradient(40% 40% at 45% 40%,#F0E2FF,#9C6BFF 40%,#5733E0 75%,#2A1C66);
  box-shadow:0 0 18px rgba(160,110,255,.7),inset 0 0 8px rgba(255,255,255,.4)}
.orb__rim{position:absolute;inset:4%;border-radius:50%;border:1px solid rgba(190,160,255,.35)}

/* ── Concepto: ¿Qué es el Sistema? ───────────────────── */
.concept{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(40px,6vw,90px);align-items:center}
.concept__media{position:relative;display:flex;justify-content:center}
.concept__media .phone{width:288px}
.concept__quote{font-family:var(--font);font-weight:500;font-size:clamp(16px,1.7vw,20px);
  line-height:1.58;letter-spacing:0;margin:22px 0 0;color:#D8D6E2;max-width:560px;text-wrap:pretty}
.concept__quote b{font-weight:700;color:var(--text)}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px}
.pillar{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:18px 16px}
.pillar__ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#C9A0FF;
  background:linear-gradient(135deg,rgba(140,99,255,.22),rgba(124,99,255,.08));margin-bottom:13px}
.pillar h4{font-family:var(--disp);font-weight:700;font-size:16px;margin:0}
.pillar p{font-size:13px;color:var(--muted);margin:5px 0 0;line-height:1.45}

/* ── Cómo funciona ───────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:56px;counter-reset:step}
.step{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:26px 22px;
  overflow:hidden;transition:border-color .3s,transform .3s}
.step:hover{border-color:rgba(140,99,255,.32);transform:translateY(-4px)}
.step__n{counter-increment:step;font-family:var(--mono);font-size:13px;font-weight:700;color:var(--v2);
  letter-spacing:.1em}
.step__n::before{content:'0' counter(step)}
.step__ico{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;color:#C9A0FF;margin:18px 0 16px;
  background:linear-gradient(135deg,rgba(140,99,255,.2),rgba(124,99,255,.07));border:1px solid rgba(140,99,255,.2)}
.step h4{font-family:var(--disp);font-weight:700;font-size:18px;margin:0}
.step p{font-size:14px;color:var(--muted);margin:8px 0 0;line-height:1.5;text-wrap:pretty}
.step__line{position:absolute;top:62px;right:-8px;width:16px;height:2px;background:var(--border2);z-index:2}

/* ── Features ────────────────────────────────────────── */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:56px}
.feat{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:26px;
  transition:border-color .3s,transform .3s,background .3s;position:relative;overflow:hidden}
.feat:hover{border-color:rgba(140,99,255,.3);transform:translateY(-4px);
  background:linear-gradient(180deg,rgba(124,99,255,.05),var(--surface))}
.feat__ico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#C9A0FF;margin-bottom:18px;
  background:linear-gradient(135deg,rgba(140,99,255,.2),rgba(124,99,255,.07));border:1px solid rgba(140,99,255,.18)}
.feat h4{font-family:var(--disp);font-weight:700;font-size:19px;margin:0}
.feat p{font-size:14.5px;color:var(--muted);margin:9px 0 0;line-height:1.55;text-wrap:pretty}
.feat--wide{grid-column:span 2;display:flex;align-items:center;gap:30px}
.feat--wide .feat__body{flex:1}
.feat--wide .phone{width:170px}

/* ── El Sistema te observa (banda de compromiso) ─────── */
.observe{position:relative;overflow:hidden;
  background:radial-gradient(80% 100% at 50% 0%,rgba(124,99,255,.12),transparent 60%),
    linear-gradient(180deg,#0d0c14,#0A0A0F)}
.observe::before,.observe::after{content:'';position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.observe::before{top:-120px;left:-80px;width:380px;height:380px;
  background:radial-gradient(50% 50% at 50% 50%,rgba(124,99,255,.12),transparent 70%)}
.observe__in{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.observe__media{display:flex;justify-content:center;gap:18px}
.observe__media .phone{width:210px}
.observe__media .phone:nth-child(2){margin-top:48px}
.consequences{margin-top:30px;display:flex;flex-direction:column;gap:11px;max-width:440px}
.conseq{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--surface);
  border:1px solid var(--border);border-radius:15px;padding:16px 18px}
.conseq--reward{border-color:rgba(124,99,255,.32);background:linear-gradient(180deg,rgba(124,99,255,.08),var(--surface))}
.conseq--pen{border-color:rgba(206,138,150,.2)}
.conseq__l{display:flex;align-items:center;gap:13px;font-size:14.5px;color:#D8D6E2}
.conseq__l b{color:#fff;font-weight:700}
.conseq__xp{font-family:var(--mono);font-size:17px;font-weight:700;color:#C9A0FF;flex-shrink:0}
.conseq__xp--pen{color:#CE8A96}
.conseq__ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;
  background:var(--surface2);color:#C9A0FF}
.conseq--pen .conseq__ico{color:#CE8A96;background:rgba(206,138,150,.08)}

/* ── Planes / Pricing ────────────────────────────────── */
.pricing{position:relative;overflow:hidden;
  background:radial-gradient(78% 100% at 50% 0%,rgba(124,99,255,.10),transparent 58%),linear-gradient(180deg,#0d0c14,var(--bg))}
.pricing .sec-head{margin:0 auto;text-align:center}
.pricing .sec-head .eyebrow{justify-content:center}

/* anclaje de valor */
.anchor{max-width:680px;margin:34px auto 0;background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:22px 26px}
.anchor__row{display:flex;align-items:stretch;justify-content:center;gap:14px;flex-wrap:wrap}
.anchor__item{display:flex;flex-direction:column;gap:3px;min-width:0}
.anchor__k{font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap}
.anchor__v{font-family:var(--mono);font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.02em}
.anchor__item--hi .anchor__k{color:#C9A0FF}
.anchor__item--hi .anchor__v{background:var(--sys);-webkit-background-clip:text;background-clip:text;color:transparent}
.anchor__op{align-self:center;font-family:var(--mono);font-size:18px;color:var(--faint);font-weight:700}
.anchor__note{text-align:center;color:var(--muted);font-size:14px;margin:16px 0 0;text-wrap:pretty}
.anchor__note b{color:var(--text);font-weight:700}

/* toggle mensual / anual */
.ptoggle{display:inline-flex;gap:6px;margin:30px auto 0;background:var(--surface);border:1px solid var(--border2);
  border-radius:14px;padding:5px;align-self:center}
.pricing .ptoggle{display:flex;width:max-content;margin-left:auto;margin-right:auto}
.ptoggle button{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:10px;font-size:14px;
  font-weight:700;color:var(--muted);transition:background .2s,color .2s}
.ptoggle button.on{background:var(--surface3);color:var(--text);box-shadow:inset 0 0 0 1px rgba(140,99,255,.35)}
.ptoggle .save{font-family:var(--mono);font-size:10px;font-weight:700;color:#9FE7C2;
  border:1px solid rgba(127,224,168,.32);background:rgba(127,224,168,.1);border-radius:99px;padding:2px 7px;letter-spacing:.02em}

/* tarjetas de plan */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:34px;align-items:start}
.plan{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:28px 24px;
  display:flex;flex-direction:column;transition:border-color .3s,transform .3s}
.plan:hover{border-color:rgba(140,99,255,.3);transform:translateY(-4px)}
.plan--hi{border-color:rgba(140,99,255,.5);background:linear-gradient(180deg,rgba(124,99,255,.08),var(--surface));
  box-shadow:0 24px 60px rgba(124,99,255,.16)}
.plan__pop{position:absolute;top:-11px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:10px;
  font-weight:700;letter-spacing:.12em;color:#0A0A0F;background:var(--sys);border-radius:99px;padding:5px 14px;white-space:nowrap}
.plan__name{font-family:var(--disp);font-weight:700;font-size:24px;margin:0}
.plan__tag{color:var(--muted);font-size:13.5px;margin:5px 0 0}
.plan__price{display:flex;align-items:baseline;gap:6px;margin-top:22px}
.plan__amt{font-family:var(--mono);font-weight:700;font-size:34px;letter-spacing:-.03em;color:var(--text)}
.plan__per{color:var(--muted);font-size:14px;font-weight:600}
.plan__hint{font-size:12.5px;color:var(--faint);margin:6px 0 0;min-height:18px}
.plan__feats{list-style:none;margin:22px 0 26px;padding:0;display:flex;flex-direction:column;gap:11px;flex:1}
.plan__feats li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#CFCDDC;line-height:1.4}
.plan__feats li.is-head{color:var(--text);font-weight:700}
.plan__feats svg{flex-shrink:0;margin-top:2px;color:#C9A0FF}
.plan--free .plan__feats svg{color:var(--muted)}
.plan__cta{margin-top:auto}
.pricing__foot{text-align:center;color:var(--faint);font-size:13px;margin:30px auto 0;max-width:560px;line-height:1.6;text-wrap:pretty}
.pricing__foot b{color:var(--muted);font-weight:700}

/* ── FAQ ─────────────────────────────────────────────── */
.faq{max-width:780px;margin:48px auto 0}
.qa{border-bottom:1px solid var(--border)}
.qa__q{display:flex;align-items:center;justify-content:space-between;gap:18px;width:100%;text-align:left;
  padding:24px 4px;font-family:var(--disp);font-weight:600;font-size:clamp(17px,2vw,21px);color:var(--text)}
.qa__q:hover{color:#C9B6FF}
.qa__plus{position:relative;width:20px;height:20px;flex-shrink:0}
.qa__plus::before,.qa__plus::after{content:'';position:absolute;background:var(--v2);border-radius:2px;
  top:50%;left:50%;transform:translate(-50%,-50%);transition:transform .3s}
.qa__plus::before{width:16px;height:2px}
.qa__plus::after{width:2px;height:16px}
.qa--open .qa__plus::after{transform:translate(-50%,-50%) scaleY(0)}
.qa__a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.qa__a p{margin:0 4px 24px;color:var(--muted);font-size:15.5px;line-height:1.6;text-wrap:pretty;max-width:660px}

/* ── CTA final ───────────────────────────────────────── */
.cta{text-align:center;position:relative;overflow:hidden}
.cta__aura{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(820px,110vw);height:600px;z-index:0;
  background:radial-gradient(45% 45% at 50% 50%,rgba(140,99,255,.26),transparent 70%);
  animation:auraBreathe 9s ease-in-out infinite;pointer-events:none}
.cta__in{position:relative;z-index:2}
.cta__orb{margin:0 auto 28px}
.cta h2{font-family:var(--disp);font-weight:700;letter-spacing:-.03em;line-height:1;
  font-size:clamp(44px,9vw,96px);margin:0;text-wrap:balance}
.cta__sub{color:#C7C4D6;font-size:clamp(16px,1.8vw,20px);margin:22px auto 0;max-width:520px;text-wrap:pretty}
.cta__stores{display:flex;align-items:center;justify-content:center;gap:13px;margin-top:24px;flex-wrap:wrap}
.store{display:inline-flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border2);
  border-radius:14px;padding:12px 18px;transition:border-color .2s,background .2s}
.store:hover{border-color:rgba(168,242,255,.4);background:rgba(64,59,84,.55)}
.store small{display:block;font-size:10px;color:var(--faint);letter-spacing:.05em;text-transform:uppercase;line-height:1.2}
.store b{font-family:var(--disp);font-size:15px;font-weight:700}
.store__badge{font-family:var(--mono);font-size:9px;color:#C9A0FF;border:1px solid rgba(140,99,255,.3);
  border-radius:99px;padding:2px 7px;letter-spacing:.06em}

/* ── Footer ──────────────────────────────────────────── */
.footer{border-top:1px solid var(--border);padding:56px 0 40px;background:var(--bg2)}
.footer__top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.footer__brand{max-width:320px}
.footer__brand p{color:var(--muted);font-size:14px;margin:16px 0 0;line-height:1.55}
.footer__cols{display:flex;gap:64px;flex-wrap:wrap}
.footer__col h5{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:0 0 16px}
.footer__col a{display:block;color:var(--muted);font-size:14px;margin-bottom:11px;transition:color .2s}
.footer__col a:hover{color:var(--text)}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  margin-top:48px;padding-top:24px;border-top:1px solid var(--border);font-size:13px;color:var(--faint)}
.footer__bottom .brand__tag{margin:0}

/* ── Reveal animation ────────────────────────────────── */
.reveal{opacity:0;transform:translateY(calc(26px * var(--anim)));
  transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}

/* anim intensity off */
body[data-anim="0"] .hero__aura,
body[data-anim="0"] .cta__aura,
body[data-anim="0"] .orb__glow,
body[data-anim="0"] .orb__swirl,
body[data-anim="0"] .pulse-dot,
body[data-anim="0"] .stars i,
body[data-anim="0"] .strip__track{animation:none}
body[data-anim="0"] .reveal{transition-duration:.001s}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;animation-iteration-count:1!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:960px){
  .concept{grid-template-columns:1fr;gap:48px}
  .concept__media{order:-1}
  .observe__in{grid-template-columns:1fr;gap:44px}
  .observe__media{order:-1}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step__line{display:none}
  .features{grid-template-columns:repeat(2,1fr)}
  .feat--wide{grid-column:span 2}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav__links{display:none}
  .nav__cta .btn--ghost{display:none}
  .hero__stage{margin-top:40px}
  .hero__stage .phone--l,.hero__stage .phone--r{display:none}
  .pillars{grid-template-columns:1fr}
  .features{grid-template-columns:1fr}
  .plans{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}
  .anchor__op{transform:rotate(90deg)}
  .feat--wide{grid-column:span 1;flex-direction:column;align-items:flex-start}
  .frag{display:none}
  .footer__top{flex-direction:column;gap:32px}
}
@media(max-width:520px){
  .steps{grid-template-columns:1fr}
  .waitlist{flex-direction:column;background:transparent;border:none;padding:0;box-shadow:none}
  .waitlist input{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:15px}
  .concept__media .phone{width:240px}
}

/* ════════════════════════════════════════════════════════════
   REDESIGN LAYER · color (violeta + cian + ámbar), liquid glass,
   orbe dinámico, showcase de IA. Sobreescribe por cascada.
   ════════════════════════════════════════════════════════════ */

/* ── Gradient text utils ─────────────────────────────── */
.grad-ai{background:var(--ai);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-warm{background:var(--warm);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-spectrum{background:var(--spectrum);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── Liquid glass: SOLO para superficies que flotan (manifiesto, nav, hojas) ── */
.glass{
  background:linear-gradient(160deg,rgba(60,55,84,.50),rgba(24,21,36,.40));
  border-color:rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  box-shadow:0 1px 0 rgba(255,255,255,.10) inset,0 18px 44px rgba(0,0,0,.34);
}
/* tarjetas = cristal real sobre el cosmos (el starfield de fondo hace que el glass
   SÍ se lea; en la app el fondo era plano y por eso se revirtió · DESIGN_STATUS §Fase5). */
.pillar,.step,.feat,.conseq,.anchor,.store,.ptoggle,.ai-tile{
  background:linear-gradient(160deg,rgba(60,55,84,.50),rgba(24,21,36,.40));
  border-color:rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  backdrop-filter:blur(16px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 16px 40px rgba(0,0,0,.32);
}
/* barrido especular "liquid" al hover */
.glass-sheen{position:relative;overflow:hidden}
.glass-sheen::after{content:'';position:absolute;top:-60%;left:-45%;width:55%;height:220%;z-index:4;
  pointer-events:none;transform:rotate(14deg);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);
  transition:left .75s cubic-bezier(.22,1,.36,1)}
.glass-sheen:hover::after{left:140%}

/* nav glass un poco más marcado */
.nav--scrolled{background:rgba(12,12,18,.55);backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);border-bottom-color:var(--glass-brd)}

/* plan: cristal real; el plan SELECCIONADO lleva el realce violeta (Pro por defecto) */
.plan{cursor:pointer;
  background:linear-gradient(160deg,rgba(60,55,84,.50),rgba(24,21,36,.40));border-color:rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(18px) saturate(150%);backdrop-filter:blur(18px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 16px 40px rgba(0,0,0,.34)}
.plan.is-selected{background:linear-gradient(180deg,rgba(140,99,255,.24),rgba(40,36,58,.46));
  border-color:rgba(176,148,255,.6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14),0 26px 64px rgba(140,99,255,.30);
  transform:translateY(-4px) scale(1.02)}
.plan.is-selected:hover{transform:translateY(-7px) scale(1.02)}
/* conseq: re-declarar modificadores tras la base sólida. Penalización = ember (rojo) */
.conseq--reward{border-color:rgba(140,99,255,.4);
  background:linear-gradient(180deg,rgba(140,99,255,.16),var(--surface))}
.conseq--pen{border-color:rgba(255,61,90,.30);
  background:linear-gradient(180deg,rgba(255,61,90,.10),var(--surface))}
.conseq__xp--pen{color:var(--ember2)}
.conseq--pen .conseq__ico{color:var(--ember2);background:rgba(255,61,90,.10)}

/* ── Acentos de color: iconos por categoría ──────────── */
.ico--cyan{color:var(--cyan-soft)!important;
  background:linear-gradient(135deg,rgba(70,229,255,.24),rgba(70,229,255,.06))!important;
  border:1px solid rgba(70,229,255,.26)!important}
.ico--amber{color:var(--amber-soft)!important;
  background:linear-gradient(135deg,rgba(255,177,61,.24),rgba(255,177,61,.06))!important;
  border:1px solid rgba(255,177,61,.26)!important}
.ico--violet{color:#C9A0FF!important;
  background:linear-gradient(135deg,rgba(140,99,255,.24),rgba(124,99,255,.07))!important;
  border:1px solid rgba(140,99,255,.24)!important}
/* puntos pulse y checks con color */
.pulse-dot.dot--cyan{background:var(--cyan);box-shadow:0 0 0 0 rgba(70,229,255,.5)}
.pulse-dot.dot--amber{background:var(--amber);box-shadow:0 0 0 0 rgba(255,177,61,.5)}
.btn--ai{color:#04141a;background:var(--ai);
  box-shadow:0 8px 30px rgba(70,229,255,.34),inset 0 1px 0 rgba(255,255,255,.5)}
.btn--ai:hover{filter:brightness(1.06);box-shadow:0 12px 40px rgba(70,229,255,.46),inset 0 1px 0 rgba(255,255,255,.55)}
/* marquee: guiones multicolor */
.strip__track span:nth-child(3n)::after{color:var(--cyan)}
.strip__track span:nth-child(3n+1)::after{color:var(--amber)}

/* ── Orbe del Sistema (esfera violeta/púrpura glossy, como en la app) ─── */
.orb__glow{background:radial-gradient(50% 50% at 50% 50%,rgba(160,110,255,.72),rgba(124,99,255,.30) 52%,transparent 72%);
  animation:orbPulse 4s ease-in-out infinite}
.orb__swirl{background:conic-gradient(from 0deg,transparent,rgba(201,160,255,.55),transparent 34%,
  rgba(230,77,255,.40),transparent 64%,rgba(140,99,255,.45),transparent 88%);
  animation:spin 9s linear infinite}
.orb__swirl--rev{background:conic-gradient(from 140deg,transparent,rgba(190,160,255,.45),transparent 52%,
  rgba(150,110,255,.45),transparent 86%);animation:spin 13s linear infinite reverse}
.orb__core{background:radial-gradient(42% 42% at 38% 33%,#FFFFFF,#D9C2FF 22%,#9C6BFF 52%,#5E37C9 100%);
  box-shadow:0 0 22px rgba(160,110,255,.7),0 0 44px rgba(124,99,255,.30),inset 0 0 9px rgba(255,255,255,.5)}
.orb__rim{border-color:rgba(190,170,255,.42);box-shadow:0 0 14px rgba(160,110,255,.28) inset}
/* reactividad puntero (la setea el JS con --orb-rx/--orb-ry) */
.orb{transform:perspective(600px) rotateX(var(--orb-rx,0deg)) rotateY(var(--orb-ry,0deg));
  transition:transform .25s ease-out}

/* ── Sección IA ──────────────────────────────────────── */
.aisec{position:relative;overflow:hidden;
  background:
    radial-gradient(60% 80% at 84% 2%,rgba(70,229,255,.10),transparent 60%),
    radial-gradient(60% 80% at 2% 100%,rgba(124,99,255,.12),transparent 60%),
    radial-gradient(40% 50% at 50% 120%,rgba(255,177,61,.06),transparent 60%),
    linear-gradient(180deg,var(--bg),#0c0b13)}
.aisec .sec-head .eyebrow{color:var(--cyan-soft)}
.ai-grid{display:grid;grid-template-columns:1.25fr 1fr 1fr;grid-auto-rows:1fr;gap:16px;margin-top:52px}
.ai-tile{position:relative;border-radius:22px;padding:22px;overflow:hidden;display:flex;flex-direction:column;gap:12px;
  transition:transform .3s,border-color .3s}
.ai-tile:hover{transform:translateY(-4px);border-color:rgba(70,229,255,.32)}
.ai-tile--feature{grid-column:1;grid-row:1 / span 2;align-items:stretch}
.ai-tile__head{display:flex;align-items:center;gap:12px}
.ai-tile__ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}
.ai-tile__tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan-soft)}
.ai-tile h4{font-family:var(--disp);font-weight:700;font-size:17.5px;margin:0;line-height:1.15}
.ai-tile p{font-size:13.5px;color:var(--muted);margin:0;line-height:1.5;text-wrap:pretty}
.ai-tile__viz{margin-top:auto}

/* mini-visuales de cada tile */
.macro-row{display:flex;gap:8px;flex-wrap:wrap}
.macro{display:flex;flex-direction:column;gap:1px;padding:9px 12px;border-radius:12px;
  background:rgba(255,255,255,.04);border:1px solid var(--border)}
.macro b{font-family:var(--mono);font-size:16px;color:var(--text);line-height:1}
.macro span{font-size:9.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.06em}
.macro--kcal b{color:var(--amber-soft)} .macro--prot b{color:var(--cyan-soft)} .macro--carb b{color:var(--v1)}

.ring{--p:74;width:84px;height:84px;border-radius:50%;display:grid;place-items:center;position:relative;
  background:conic-gradient(var(--cyan) calc(var(--p)*1%),rgba(255,255,255,.07) 0)}
.ring::before{content:'';position:absolute;inset:8px;border-radius:50%;background:#100f17}
.ring b{position:relative;font-family:var(--mono);font-size:16px;color:#fff}
.ring small{position:relative;display:block;text-align:center;font-size:8px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase}

.mini-list{display:flex;flex-direction:column;gap:7px}
.mini-list div{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12.5px;color:#CFCDDC;
  padding:8px 11px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.mini-list span{font-family:var(--mono);font-size:11px;color:var(--v1)}

.state-chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:11px;font-weight:600;padding:5px 11px;border-radius:99px;border:1px solid var(--border2);color:var(--muted)}
.chip--warn{color:var(--amber-soft);border-color:rgba(255,177,61,.32);background:rgba(255,177,61,.10)}
.chip--ok{color:var(--cyan-soft);border-color:rgba(70,229,255,.32);background:rgba(70,229,255,.10)}
.chip--note{color:var(--v1);border-color:rgba(140,99,255,.32);background:rgba(140,99,255,.10)}

/* pantalla "Coach IA" dentro del marco de teléfono (mock, swap-ready) */
.ai-screen{position:absolute;inset:0;display:flex;flex-direction:column;gap:9px;
  padding:44px 13px 14px;background:linear-gradient(180deg,#0e0d16,#08080d)}
.ai-screen__top{display:flex;align-items:center;gap:9px;padding-bottom:9px;border-bottom:1px solid var(--border)}
.ai-screen__av{width:30px;height:30px;border-radius:9px;background:var(--ai);display:grid;place-items:center;flex-shrink:0;
  box-shadow:0 0 14px rgba(70,229,255,.5)}
.ai-screen__top b{font-family:var(--disp);font-size:13px;display:block;line-height:1.1}
.ai-screen__top small{font-size:9.5px;color:var(--cyan-soft);font-family:var(--mono);letter-spacing:.05em}
.coach{display:flex;flex-direction:column;gap:8px;overflow:hidden}
.coach__msg{max-width:84%;padding:9px 12px;border-radius:15px;font-size:11.5px;line-height:1.38}
.coach__msg--ai{align-self:flex-start;color:#DCFAFE;background:rgba(70,229,255,.13);
  border:1px solid rgba(70,229,255,.24);border-bottom-left-radius:5px}
.coach__msg--me{align-self:flex-end;color:#ECEAF4;background:var(--surface3);
  border:1px solid var(--border2);border-bottom-right-radius:5px}
.ai-screen__input{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:rgba(255,255,255,.05);border:1px solid var(--border2);border-radius:99px;padding:8px 8px 8px 14px;
  font-size:11px;color:var(--faint)}
.ai-screen__send{width:26px;height:26px;border-radius:50%;background:var(--ai);display:grid;place-items:center;flex-shrink:0;color:#04141a}
.ai-feature__cap{display:flex;align-items:center;gap:10px;margin-top:16px}
.ai-feature__cap b{font-family:var(--disp);font-size:15px}
.ai-feature__cap span{font-size:12px;color:var(--muted)}

/* marco de teléfono con glow multicolor para la sección IA */
.aisec .phone__glow{background:radial-gradient(50% 50% at 50% 50%,rgba(70,229,255,.32),rgba(124,99,255,.22) 55%,transparent 72%)}
.ai-tile--feature .phone{width:100%;max-width:230px;margin:0 auto}

/* slot de imagen "listo para rellenar" (placeholder de captura real) */
.shot{position:relative}
.shot[data-swap]::after{content:attr(data-swap);position:absolute;left:8px;bottom:8px;z-index:4;
  font-family:var(--mono);font-size:8.5px;letter-spacing:.06em;color:var(--cyan-soft);
  background:rgba(8,8,13,.6);border:1px solid rgba(70,229,255,.28);border-radius:7px;padding:3px 7px;
  backdrop-filter:blur(6px);opacity:.85}

/* ── Responsive sección IA ───────────────────────────── */
@media(max-width:960px){
  .ai-grid{grid-template-columns:1fr 1fr}
  .ai-tile--feature{grid-column:1 / -1;grid-row:auto;flex-direction:row;align-items:center;gap:22px}
  .ai-tile--feature .ai-feature__body{flex:1}
  .ai-tile--feature .phone{max-width:200px;margin:0}
}
@media(max-width:620px){
  .ai-grid{grid-template-columns:1fr}
  .ai-tile--feature{flex-direction:column;align-items:stretch}
  .ai-tile--feature .phone{max-width:220px;margin:0 auto}
}

/* ── Acentos de color en iconos existentes (cian / ámbar) ── */
.pillars .pillar:nth-child(2) .pillar__ico,
.steps .step:nth-child(1) .step__ico,
.steps .step:nth-child(4) .step__ico,
.features .feat:nth-child(3) .feat__ico,
.features .feat:nth-child(4) .feat__ico{
  color:var(--cyan-soft);
  background:linear-gradient(135deg,rgba(70,229,255,.22),rgba(70,229,255,.06));
  border:1px solid rgba(70,229,255,.24)}
.pillars .pillar:nth-child(3) .pillar__ico,
.steps .step:nth-child(3) .step__ico,
.features .feat:nth-child(2) .feat__ico,
.features .feat:nth-child(5) .feat__ico{
  color:var(--amber-soft);
  background:linear-gradient(135deg,rgba(255,177,61,.22),rgba(255,177,61,.06));
  border:1px solid rgba(255,177,61,.24)}
/* el “+200 XP” de recompensa en cian para variar del violeta */
.conseq--reward .conseq__xp{color:var(--cyan-soft)}
.conseq--reward .conseq__ico{color:var(--cyan-soft);background:rgba(70,229,255,.10)}

/* ── Manifiesto (voz del fundador) ───────────────────── */
.manifesto{position:relative;overflow:hidden;
  background:radial-gradient(60% 80% at 50% -10%,rgba(124,99,255,.10),transparent 60%),
    radial-gradient(40% 60% at 90% 110%,rgba(70,229,255,.07),transparent 60%),
    linear-gradient(180deg,#0c0b13,var(--bg))}
.manifesto__card{max-width:800px;margin:0 auto;border-radius:28px;
  padding:clamp(30px,5vw,56px);text-align:center;position:relative;z-index:1}
.manifesto__mark{width:58px;height:58px;margin:0 auto 22px;border-radius:16px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(70,229,255,.18),rgba(124,99,255,.16));border:1px solid var(--glass-brd);
  box-shadow:0 0 26px rgba(124,99,255,.3)}
.manifesto .eyebrow{justify-content:center}
.manifesto__title{font-family:var(--disp);font-weight:700;letter-spacing:-.025em;line-height:1.08;
  font-size:clamp(28px,4.6vw,46px);margin:14px 0 0;text-wrap:balance}
.manifesto__body{margin:26px auto 0;max-width:620px}
.manifesto__body p{color:#C8C5D7;font-size:clamp(16px,1.7vw,19px);line-height:1.72;margin:0 0 16px;text-wrap:pretty}
.manifesto__body p:last-child{margin-bottom:0}
.manifesto__body b{color:var(--text);font-weight:700}
.manifesto__sign{margin-top:28px;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:13px;letter-spacing:.03em;color:var(--cyan-soft)}
.manifesto__sign::before{content:'';width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--cyan))}

/* ── Páginas legales (términos / privacidad) ─────────── */
.legal-nav{position:sticky;top:0;z-index:60;background:rgba(11,9,16,.72);
  -webkit-backdrop-filter:blur(18px) saturate(150%);backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid var(--border)}
.legal-nav .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.legal-back{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--muted)}
.legal-back:hover{color:var(--text)}
.legal{max-width:760px;margin:0 auto;padding:clamp(36px,6vw,72px) var(--pad) 96px}
.legal__kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-soft)}
.legal h1{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;font-size:clamp(30px,5vw,46px);margin:14px 0 6px;color:var(--text)}
.legal__upd{color:var(--faint);font-size:13.5px;margin:0}
.legal h2{font-family:var(--disp);font-weight:700;font-size:clamp(19px,2.4vw,24px);margin:38px 0 12px;color:var(--text)}
.legal p,.legal li{color:#CFCDDC;font-size:16px;line-height:1.72;text-wrap:pretty}
.legal p{margin:0 0 14px}
.legal ul{margin:0 0 16px;padding-left:20px;display:flex;flex-direction:column;gap:8px}
.legal a{color:var(--v1);text-decoration:underline;text-underline-offset:2px}
.legal strong{color:var(--text);font-weight:700}
.legal__foot{margin-top:48px;padding-top:22px;border-top:1px solid var(--border);font-size:13.5px;color:var(--faint);
  display:flex;gap:18px;flex-wrap:wrap}
.legal__foot a{color:var(--muted)}

/* ── Badge "Próximamente" (features aún no construidas · regla de oro) ── */
.soon{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--cyan-soft);border:1px solid rgba(70,229,255,.32);
  background:rgba(70,229,255,.08);border-radius:99px;padding:2px 7px;vertical-align:middle;white-space:nowrap}
.ai-tile__head .soon{margin-left:auto}
.plan__feats .soon{margin-left:6px;font-size:8.5px;padding:1px 6px}

/* ── Acceso anticipado + cuenta atrás ────────────────── */
.access{position:relative;overflow:hidden;text-align:center;
  background:radial-gradient(60% 80% at 50% -6%,rgba(140,99,255,.13),transparent 60%),
    radial-gradient(40% 50% at 88% 100%,rgba(70,229,255,.06),transparent 60%),
    linear-gradient(180deg,var(--bg),#0c0b13)}
.access .sec-head{margin:0 auto}
.countdown{display:flex;justify-content:center;gap:clamp(8px,2vw,16px);margin:34px 0 10px;flex-wrap:wrap}
.cd-cell{min-width:clamp(72px,18vw,104px);padding:clamp(14px,2.4vw,20px) 14px;border-radius:18px;
  background:var(--surface);border:1px solid var(--border);
  box-shadow:0 1px 0 rgba(255,255,255,.05) inset,0 16px 40px rgba(0,0,0,.34)}
.cd-num{display:block;font-family:var(--mono);font-weight:700;font-size:clamp(30px,5.4vw,48px);line-height:1;
  letter-spacing:-.02em;font-variant-numeric:tabular-nums;
  background:var(--sys);-webkit-background-clip:text;background-clip:text;color:transparent}
.cd-lbl{display:block;margin-top:9px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--faint)}
.access__date{font-family:var(--mono);font-size:13px;color:var(--cyan-soft);letter-spacing:.04em;margin:0}
.perks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:820px;margin:36px auto 0}
.perk{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:20px 18px;text-align:left;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset}
.perk b{display:block;font-family:var(--disp);font-weight:700;font-size:clamp(21px,2.6vw,28px);line-height:1.05;
  background:var(--sys);-webkit-background-clip:text;background-clip:text;color:transparent}
.perk span{display:block;margin-top:8px;font-size:13.5px;color:var(--muted);line-height:1.5;text-wrap:pretty}
.access .waitlist{margin-left:auto;margin-right:auto}
.access__fine{margin:14px 0 0;font-size:12.5px;color:var(--faint)}
@media(max-width:640px){.perks{grid-template-columns:1fr;max-width:420px}}

/* ── Tira compacta de 4 pasos (cómo funciona · dentro de Sección A) ── */
.flow{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:32px}
.flow__step{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);
  border-radius:14px;padding:14px 15px}
.flow__n{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--v1);flex-shrink:0;line-height:1.5}
.flow__step b{font-family:var(--disp);font-weight:700;font-size:14.5px;display:block;color:var(--text)}
.flow__step span{font-size:12.5px;color:var(--muted);line-height:1.42;display:block;margin-top:2px}
@media(max-width:520px){.flow{grid-template-columns:1fr}}

/* ── Hueco de vídeo (placeholder · Sección B, listo para incrustar) ── */
.video-slot{position:relative;margin:44px auto 0;max-width:860px;aspect-ratio:16/9;border-radius:24px;overflow:hidden;
  border:1px solid var(--glass-brd);cursor:pointer;
  background:
    radial-gradient(60% 80% at 50% 36%,rgba(140,99,255,.20),transparent 70%),
    linear-gradient(160deg,rgba(48,44,64,.55),rgba(18,16,26,.65));
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  display:grid;place-items:center;box-shadow:0 26px 64px rgba(0,0,0,.42)}
.video-slot::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(150deg,rgba(255,255,255,.06),transparent 40%)}
.video-slot__inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
.video-slot__play{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;color:#fff;margin-bottom:8px;
  background:var(--sys);box-shadow:0 10px 34px rgba(124,99,255,.55)}
.video-slot__inner b{font-family:var(--disp);font-weight:700;font-size:clamp(18px,2.4vw,24px);color:var(--text)}
.video-slot__hint{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan-soft)}

/* ── Mini barras de atributo (tile Rangos/XP) ── */
.attr-mini{display:flex;flex-direction:column;gap:9px;width:100%}
.attr-mini > div{display:grid;grid-template-columns:72px 1fr;align-items:center;gap:10px}
.attr-mini span{font-size:11px;color:var(--muted)}
.attr-mini i{height:6px;border-radius:99px;background:rgba(255,255,255,.08);position:relative;overflow:hidden;display:block}
.attr-mini i::after{content:'';position:absolute;left:0;top:0;bottom:0;width:var(--v);border-radius:99px;background:var(--sys)}
.attr-mini i.ember::after{background:var(--ember)}

/* ════════════════════════════════════════════════════════════
   HERO + ACCESO a 2 columnas (texto+form izq · móviles der).
   Más compacto y con tipografía menor (feedback del usuario).
   ════════════════════════════════════════════════════════════ */
.hero{padding-top:clamp(32px,6vh,64px);padding-bottom:clamp(40px,6vh,64px);text-align:left}
.hero__grid{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(24px,4vw,56px);align-items:center;position:relative;z-index:2}
.hero__col{max-width:600px}
.hero__orb{margin:0 0 14px}
.hero .eyebrow{margin-bottom:14px}
.hero h1{margin:0;line-height:1.04}
.hero h1 .h1-sm{display:block;font-family:var(--disp);font-weight:600;letter-spacing:-.02em;line-height:1.14;
  font-size:clamp(19px,2.5vw,30px);color:var(--muted);text-wrap:balance;margin-bottom:6px}
.hero h1 .h1-big{display:block;font-family:var(--disp);font-weight:700;letter-spacing:-.03em;line-height:1;
  font-size:clamp(46px,6.6vw,80px)}
.hero__sub{margin:16px 0 0;max-width:460px;font-size:clamp(15.5px,1.6vw,18px);line-height:1.5}
.countdown--sm{justify-content:flex-start;gap:8px;margin:22px 0 0;flex-wrap:nowrap}
.countdown--sm .cd-cell{min-width:0;flex:1;max-width:76px;padding:9px 6px;border-radius:13px}
.countdown--sm .cd-num{font-size:clamp(20px,2.8vw,28px)}
.countdown--sm .cd-lbl{font-size:8px;margin-top:5px;letter-spacing:.12em}

/* formulario único: selector de intención + email + ayuda */
.waitlist-form{margin:22px 0 0;max-width:480px}
.waitlist-form .waitlist{margin:0;max-width:none}
.intent{display:flex;gap:8px;margin:0 0 10px}
.intent__opt{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;
  padding:10px 10px;border-radius:12px;border:1px solid var(--border2);background:var(--surface);
  font-size:12.5px;font-weight:600;color:var(--muted);text-align:center;line-height:1.2;
  transition:border-color .2s,color .2s,background .2s}
.intent__opt input{accent-color:var(--v2);margin:0;flex-shrink:0}
.intent__opt:hover{color:var(--text)}
.intent__opt:has(input:checked){border-color:rgba(140,99,255,.6);color:var(--text);background:var(--surface2);
  box-shadow:inset 0 0 0 1px rgba(140,99,255,.4)}
.intent__help{font-size:12px;color:var(--muted);line-height:1.5;margin:10px 2px 0;text-wrap:pretty}
.intent__help b{color:var(--text)}

/* móviles del hero en la columna derecha (pueden sangrar al borde) */
.hero__grid .hero__stage{margin-top:0;justify-content:center}
.hero__grid .hero__stage .phone{width:clamp(150px,15vw,188px)}

@media(max-width:860px){
  .hero{text-align:center}
  .hero__grid{grid-template-columns:1fr;gap:28px}
  .hero__col{max-width:560px;margin:0 auto}
  .hero__orb{margin:0 auto 14px}
  .hero .eyebrow{justify-content:center}
  .hero__sub{margin-left:auto;margin-right:auto}
  .countdown--sm{justify-content:center}
  .waitlist-form{margin-left:auto;margin-right:auto}
  .intent__help{text-align:center}
  .hero__grid .hero__stage .phone{width:clamp(160px,40vw,210px)}
}
@media(max-width:520px){
  .intent{flex-direction:column}
  .hero h1 .h1-big{font-size:clamp(38px,12vw,56px)}
}

/* ════════════════════════════════════════════════════════════
   REFINAMIENTO · fondo cósmico estrellado UNIFORME (sin costuras)
   + cada sección llena una pantalla. (Feedback: quitar fondos de
   sección disruptivos, el orbe del hero, y que nada quede cortado.)
   ════════════════════════════════════════════════════════════ */

/* Fondos de sección transparentes → el mismo cosmos del hero en TODA
   la web. Adiós a las costuras y al "verde" de La app. */
.aisec, .pricing, .manifesto, .cta, .hero{background:transparent}
.aisec{box-shadow:none}

/* Solo el hero ocupa la pantalla completa. Las demás secciones se ajustan a su
   contenido (con aire), para no generar vacíos crecientes en las secciones cortas. */
.hero{min-height:100svh; display:flex; flex-direction:column; justify-content:center}
.sec-pad{padding-top:clamp(72px,10vh,104px); padding-bottom:clamp(48px,8vh,88px)}
.hero{padding-top:clamp(84px,12vh,120px)}
.hero__col{padding-top:0}

/* ── "La app": bento compacto (vídeo 2×2 + 8 capacidades) en una pantalla ── */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:clamp(16px,2.4vh,26px)}
#ia.sec-pad{padding-top:clamp(56px,7vh,84px);padding-bottom:clamp(40px,5vh,64px)}
.bento .ai-tile{padding:15px;gap:7px;border-radius:18px;min-height:0}
.bento .ai-tile__head{gap:10px}
.bento .ai-tile__ico{width:36px;height:36px;border-radius:10px}
.bento .ai-tile__ico svg{width:18px;height:18px}
.bento .ai-tile__tag{font-size:9px;letter-spacing:.12em}
.bento .ai-tile h4{font-size:14px;line-height:1.15}
.bento .ai-tile p{font-size:12px;line-height:1.38}
.bento .ai-tile__viz{margin-top:auto;padding-top:4px}
.bento .chip{font-size:10px;padding:4px 9px}
.bento .soon{font-size:8px;padding:2px 6px}

/* ── tarjetas = cristal real sobre el cosmos (ya no superficie opaca) ── */
.bento .ai-tile.is-glass{
  background:linear-gradient(155deg,rgba(60,55,84,.52),rgba(24,21,36,.40));
  border:1px solid rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  backdrop-filter:blur(18px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 16px 40px rgba(0,0,0,.34)}
.bento .ai-tile.is-glass:hover{border-color:rgba(168,242,255,.34)}

/* ── tarjetas-foto: la imagen manda, el texto va sobre un degradado ── */
.bento .ai-tile.is-photo{
  padding:0;overflow:hidden;min-height:176px;justify-content:flex-end;
  background-size:cover;background-position:center;
  border:0;box-shadow:0 16px 40px rgba(0,0,0,.40),inset 0 0 0 1px rgba(255,255,255,.10)}
.bento .ai-tile.is-photo::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(to top,rgba(8,6,14,.95) 3%,rgba(8,6,14,.58) 38%,rgba(8,6,14,.06) 74%,transparent 100%),
    linear-gradient(160deg,rgba(124,99,255,.20),transparent 52%,rgba(70,229,255,.12))}
.bento .ai-tile.is-photo:hover{box-shadow:0 18px 44px rgba(0,0,0,.42),inset 0 0 0 1px rgba(168,242,255,.40)}
.ai-tile__body{position:relative;z-index:1;display:flex;flex-direction:column;padding:13px 14px}
.bento .ai-tile.is-photo h4{font-size:15px;color:#fff;margin:1px 0 3px;line-height:1.12}
.bento .ai-tile.is-photo .ai-tile__tag{color:var(--cyan-soft)}
.bento .ai-tile.is-photo p{font-size:11.5px;color:rgba(246,245,251,.82);line-height:1.4}

/* pastillas de cristal sobre la foto (macros reales / etiquetas) */
.photo-macros,.photo-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.photo-macros span{font-family:var(--mono);font-size:9.5px;letter-spacing:.02em;color:rgba(246,245,251,.78);
  background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.18);border-radius:8px;padding:4px 7px;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
.photo-macros b{font-size:12px;font-weight:700;color:#fff;margin-right:3px}
.photo-macros span:nth-child(1) b{color:var(--amber-soft)}
.photo-macros span:nth-child(2) b{color:var(--cyan-soft)}
.photo-macros span:nth-child(3) b{color:var(--v1)}
.photo-macros span:nth-child(4) b{color:var(--ember-soft)}
.ptag{font-size:10.5px;font-weight:600;color:rgba(246,245,251,.92);
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:4px 9px;
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}

/* ── iconos premium: glifo blanco sobre relleno de degradado de marca ── */
.bento .ai-tile__ico{color:#fff!important;border:1px solid rgba(255,255,255,.22)!important;
  box-shadow:0 6px 15px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.42)}
.bento .ico--cyan{background:linear-gradient(140deg,#5EE9FF,#2D7BFF)!important}
.bento .ico--violet{background:linear-gradient(140deg,#CBA4FF,#7C4DFF)!important}
.bento .ico--amber{background:linear-gradient(140deg,#FFC24D,#FF5A4D)!important}
.bento .ai-tile__ico svg{width:18px;height:18px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.22))}

/* ── Sección "El Sistema": mismas tarjetas premium que el bento ── */
/* pilares + pasos = cristal real sobre el cosmos (ya no superficie opaca) */
#sistema .pillar,
#sistema .flow__step{
  background:linear-gradient(155deg,rgba(60,55,84,.52),rgba(24,21,36,.40));
  border:1px solid rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(18px) saturate(150%);
  backdrop-filter:blur(18px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 16px 40px rgba(0,0,0,.34);
  transition:transform .3s,border-color .3s}
#sistema .pillar:hover,
#sistema .flow__step:hover{border-color:rgba(168,242,255,.30);transform:translateY(-3px)}
/* iconos premium: glifo blanco sobre relleno de degradado de marca */
#sistema .pillar__ico{color:#fff!important;border:1px solid rgba(255,255,255,.22)!important;
  background:linear-gradient(140deg,#CBA4FF,#7C4DFF)!important;
  box-shadow:0 6px 15px rgba(0,0,0,.32),inset 0 1px 0 rgba(255,255,255,.42)}
#sistema .pillars .pillar:nth-child(2) .pillar__ico{background:linear-gradient(140deg,#5EE9FF,#2D7BFF)!important}
#sistema .pillars .pillar:nth-child(3) .pillar__ico{background:linear-gradient(140deg,#FFC24D,#FF5A4D)!important}
#sistema .pillar__ico svg{filter:drop-shadow(0 1px 1px rgba(0,0,0,.22))}
/* número del paso en una pastilla premium */
#sistema .flow__n{color:#fff;background:linear-gradient(140deg,#CBA4FF,#7C4DFF);
  border-radius:8px;padding:3px 7px;box-shadow:0 4px 10px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.4)}

/* badges de store = estilo oficial (fondo negro, logos a color · NO cristal) */
.store{background:#08070d;border:1px solid rgba(255,255,255,.16);
  -webkit-backdrop-filter:none;backdrop-filter:none;
  box-shadow:0 10px 28px rgba(0,0,0,.5)}
.store:hover{background:#0e0c17;border-color:rgba(255,255,255,.3)}

/* tile de vídeo (placeholder) ocupando 2×2 en el bento */
.bento__video{grid-column:span 2;grid-row:span 2;position:relative;border-radius:20px;overflow:hidden;cursor:pointer;
  display:grid;place-items:center;text-align:center;border:1px solid var(--glass-brd);min-height:240px;
  background:linear-gradient(160deg,rgba(48,44,64,.5),rgba(18,16,26,.55));
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.bento__video::after{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 70% at 50% 36%,rgba(140,99,255,.20),transparent 70%)}
.bento__video__in{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:5px;padding:18px}
.bento__play{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;margin-bottom:6px;
  background:var(--sys);box-shadow:0 10px 30px rgba(124,99,255,.5)}
.bento__video b{font-family:var(--disp);font-weight:700;font-size:clamp(17px,2vw,22px);color:var(--text)}
.bento__video small{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan-soft)}

@media(max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento__video{grid-column:span 2;grid-row:span 1;min-height:200px}
}
@media(max-width:520px){
  .bento{grid-template-columns:1fr}
  .bento__video{grid-column:span 1}
}
