/* ============================================================
   DesmadrOS — landing de venta (desmadros.com)
   Port de producción del prototipo "DesmadrOS Landing.html"
   ============================================================ */

:root{
  --ink:#0b0c0e; --paper:#f6f4ef;
  --text:#edeef1; --text-2:#9a9da6; --text-3:#6a6e78;
  --accent:#2fae74; --accent-2:#46c98b;
  --pos:#2fae74; --neg:#f0616d; --gold:#d7b56d;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --sans:'Inter',-apple-system,system-ui,sans-serif;
  --hand:'Caveat',cursive;
}
*{box-sizing:border-box;margin:0;padding:0}
@media (prefers-reduced-motion: no-preference){html{scroll-behavior:smooth}}
body{font-family:var(--sans);background:var(--ink);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;letter-spacing:-.011em;overflow-x:hidden}

/* ============ fixed sky (scroll-driven) ============ */
.sky{position:fixed;inset:0;z-index:0;pointer-events:none}
.sky div{position:absolute;inset:0;opacity:0}
.sky-chaos{background:
  radial-gradient(900px 600px at 70% -10%, rgba(240,97,109,.16), transparent 60%),
  radial-gradient(700px 500px at 10% 30%, rgba(240,97,109,.07), transparent 55%),
  #0b0c0e;opacity:1}
.sky-chaos::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .05 0'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}
.sky-dawn{background:linear-gradient(180deg,#16172b 0%,#3a3566 34%,#8d6e9e 62%,#e8a875 86%,#f2c490 100%)}
.sky-day{background:linear-gradient(180deg,#aee0f7 0%,#cdecfa 45%,#eef8f4 80%,#f6f4ef 100%)}
.cloud{position:absolute;border-radius:999px;filter:blur(34px);background:rgba(255,255,255,.75)}
.c1{width:380px;height:110px;top:16%;left:6%}
.c2{width:520px;height:140px;top:9%;right:-6%;opacity:.85}
.c3{width:300px;height:90px;top:38%;right:14%;opacity:.6}
.sun{position:absolute;top:11%;left:50%;width:340px;height:340px;transform:translateX(-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(255,244,214,.95) 0%,rgba(255,233,178,.35) 45%,transparent 70%);filter:blur(6px)}

/* ============ capa de arte (ilustraciones fijas en cross-fade) ============ */
.art-layer{position:fixed;inset:0;z-index:0;pointer-events:none}
.art-scene{position:absolute;inset:0;opacity:0}
.art-scene.caos{opacity:1}
.art-scene .art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.art-veil{position:absolute;inset:0;pointer-events:none}
.veil-caos{background:linear-gradient(180deg,rgba(11,12,14,.30) 0%,rgba(11,12,14,.42) 55%,rgba(11,12,14,.62) 100%)}
.veil-dia{background:linear-gradient(180deg,rgba(246,244,239,.06) 0%,rgba(246,244,239,.42) 48%,rgba(246,244,239,.88) 82%,#f6f4ef 100%)}

/* ============ nav ============ */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;gap:12px;padding:14px clamp(16px,4vw,40px);background:transparent;border-bottom:1px solid transparent;transition:background-color .25s ease,border-color .25s ease}
nav.solid{background:rgba(246,244,239,.96);border-bottom-color:rgba(0,0,0,.07)}
.brand{display:flex;align-items:center;gap:11px;font-weight:450;font-size:21px;letter-spacing:-.025em;color:#c8cbd2;transition:color .3s}
.brand .os{font-weight:800;color:#fff}
nav.solid .brand{color:#5a5e68}
nav.solid .brand .os{color:#15171c}
.mark{width:46px;height:46px;display:grid;place-items:center;filter:drop-shadow(0 4px 12px rgba(0,0,0,.35))}
.mark svg{width:100%;height:100%}
nav .dom{font-family:var(--mono);font-size:11.5px;color:var(--text-3);margin-left:2px;transition:color .3s}
nav.solid .dom{color:#8a8d96}
nav .cta{margin-left:auto;display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#fff;background:linear-gradient(140deg,var(--accent),#1f8a5b);border:none;border-radius:10px;padding:9px 18px;cursor:pointer;text-decoration:none;box-shadow:0 8px 24px rgba(47,174,116,.35);transition:.18s}
nav .cta:hover{filter:brightness(1.12);transform:translateY(-1px)}
.nav-links{margin-left:auto;display:flex;gap:4px}
.nav-links a{font-size:13px;font-weight:550;color:var(--text-2);text-decoration:none;padding:7px 12px;border-radius:8px;transition:.15s}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.07)}
nav.solid .nav-links a{color:#5a5e68}
nav.solid .nav-links a:hover{color:#15171c;background:rgba(21,23,28,.06)}
nav .cta{margin-left:0}
@media(max-width:860px){.nav-links{display:none}nav .cta{margin-left:auto}}

main{position:relative;z-index:1}
section{position:relative;padding:0 clamp(16px,5vw,48px)}
.inner{max-width:1080px;margin:0 auto}

/* ============ HERO — caos ============ */
.hero{min-height:100vh;display:grid;place-items:center;text-align:center;overflow:hidden}
.hero .inner{position:relative;padding:120px 0 80px}
.hero h1{position:relative;z-index:2;font-size:clamp(44px,9vw,104px);line-height:.98;font-weight:800;letter-spacing:-.045em;text-shadow:0 6px 40px rgba(0,0,0,.55)}
.hero h1 .glitch{position:relative;display:inline-block;color:var(--neg);text-shadow:0 6px 40px rgba(0,0,0,.55)}
.hero h1 .dim{color:var(--text-2)}
.hero p.sub{position:relative;z-index:2;font-size:clamp(15px,2.2vw,19px);color:var(--text-2);max-width:54ch;margin:26px auto 0;font-weight:450;text-shadow:0 2px 18px rgba(0,0,0,.6)}
.hero p.sub b{color:var(--text);font-weight:600}
.scroll-cue{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.16em;color:var(--text-3);font-weight:600;z-index:5}
.scroll-cue .line{width:1px;height:44px;background:linear-gradient(180deg,var(--accent),transparent);animation:drip 1.8s infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}55%{transform:scaleY(1);transform-origin:top}56%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* glitch rojo del headline (ráfagas breves, se apaga con reduced-motion) */
.hero h1 .glitch::before,.hero h1 .glitch::after{content:attr(data-text);position:absolute;left:0;top:0;width:100%;pointer-events:none;opacity:0}
.hero h1 .glitch::before{color:#ff8b94;animation:glitch-a 4.3s steps(1,end) infinite}
.hero h1 .glitch::after{color:rgba(237,238,241,.85);animation:glitch-b 5.7s steps(1,end) infinite .9s}
@keyframes glitch-a{
  0%,90%{opacity:0;transform:none;clip-path:inset(0)}
  91%{opacity:.7;transform:translate(-6px,2px);clip-path:inset(8% 0 62% 0)}
  93%{opacity:.7;transform:translate(5px,-1px);clip-path:inset(56% 0 14% 0)}
  95%,100%{opacity:0;transform:none;clip-path:inset(0)}
}
@keyframes glitch-b{
  0%,93%{opacity:0;transform:none;clip-path:inset(0)}
  94%{opacity:.5;transform:translate(6px,2px);clip-path:inset(36% 0 40% 0)}
  96%{opacity:.5;transform:translate(-5px,-2px);clip-path:inset(74% 0 4% 0)}
  98%,100%{opacity:0;transform:none;clip-path:inset(0)}
}

/* fragmentos de caos */
.frag{position:absolute;pointer-events:none;will-change:transform,opacity}
.ticket{background:#15161a;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:11px 14px;font-family:var(--mono);font-size:11px;color:var(--text-2);box-shadow:0 18px 50px rgba(0,0,0,.6);text-align:left}
.ticket .neg{color:var(--neg);font-weight:600}
.ticket small{display:block;color:var(--text-3);font-size:9.5px;margin-top:3px}
.alert{background:rgba(240,97,109,.12);border:1px solid rgba(240,97,109,.4);color:#ff8b94;border-radius:9px;padding:9px 13px;font-size:11.5px;font-weight:600;box-shadow:0 14px 40px rgba(0,0,0,.5)}
.scribble{font-family:var(--hand);font-size:clamp(17px,2.4vw,24px);color:var(--gold);transform:rotate(-6deg);text-shadow:0 4px 20px rgba(0,0,0,.6)}
.f1{top:9%;left:2%;transform:rotate(-9deg)}
.f2{top:12%;right:2%;transform:rotate(7deg)}
.f3{bottom:11%;left:4%;transform:rotate(5deg)}
.f4{bottom:9%;right:4%;transform:rotate(-7deg)}
.f5{top:68%;left:-2%;transform:rotate(12deg)}
.f6{top:26%;right:-2%;transform:rotate(-11deg)}
.frag{opacity:.8;z-index:1}
@media(max-width:760px){.f5,.f6,.fb2,.fb4{display:none}.frag{opacity:.75}}

/* billetes, cheques y vouchers volando */
.fb1{top:32%;left:3%}.fb2{top:6%;left:30%}.fb3{top:78%;right:3%}.fb4{bottom:6%;left:22%}.fb5{top:7%;right:26%}
.bill{width:86px;height:42px;border-radius:6px;background:linear-gradient(140deg,#1d3a2a,#2a5a3e);border:1.5px solid #3f8a5d;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:17px;color:#7fd6a4;box-shadow:0 14px 36px rgba(0,0,0,.55);position:relative}
.bill::before,.bill::after{content:"";position:absolute;top:50%;width:18px;height:18px;border:1.5px solid rgba(127,214,164,.5);border-radius:50%;transform:translateY(-50%)}
.bill::before{left:6px}.bill::after{right:6px}
.cheque{width:120px;padding:10px 12px;border-radius:5px;background:#eceadf;color:#3a3e48;font-family:var(--mono);font-size:8.5px;box-shadow:0 14px 36px rgba(0,0,0,.55)}
.cheque .ln{height:4px;background:#c9c6b8;border-radius:2px;margin:5px 0}
.cheque .ln.s{width:60%}
.cheque .firma{font-family:var(--hand);font-size:16px;color:#1f8a5b;text-align:right;line-height:1}
.vouch{width:78px;padding:8px 9px 12px;background:#f4f2e9;color:#6a6e78;font-family:var(--mono);font-size:7.5px;line-height:1.7;box-shadow:0 14px 36px rgba(0,0,0,.55);clip-path:polygon(0 0,100% 0,100% 92%,87% 100%,75% 92%,62% 100%,50% 92%,38% 100%,25% 92%,13% 100%,0 92%)}
.vouch b{color:#2a2d34;font-size:8.5px}
.vouch .tot{color:var(--neg);font-weight:700}

/* ============ transición — amanecer ============ */
.dawn{min-height:92vh;display:grid;place-items:center;text-align:center}
.dawn h2{font-size:clamp(34px,6.4vw,72px);font-weight:800;letter-spacing:-.04em;line-height:1.04}
.dawn h2 .from{color:rgba(255,255,255,.55)}
.dawn h2 .to{background:linear-gradient(120deg,#fff 15%,#ffe9b2 55%,#ffd27a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.dawn p{font-size:clamp(15px,2vw,18px);color:rgba(255,255,255,.82);max-width:52ch;margin:22px auto 0;font-weight:450}
.dawn .osname{font-family:var(--mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:18px;display:block}

/* ============ renacimiento — app ============ */
.reborn{padding-top:8vh;padding-bottom:60px;text-align:center;color:#15171c}
.reborn .kicker{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;color:#1f8a5b;font-weight:700;margin-bottom:16px}
.reborn .kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.reborn h2{font-size:clamp(30px,5.4vw,58px);font-weight:800;letter-spacing:-.04em;line-height:1.05;color:#15171c}
.reborn p.sub{font-size:clamp(14.5px,2vw,17.5px);color:#5a5e68;max-width:56ch;margin:18px auto 0;font-weight:450}

/* app window */
.appwin{max-width:980px;margin:54px auto 0;background:#0e0f12;border:1px solid rgba(255,255,255,.1);border-radius:18px;overflow:hidden;box-shadow:0 50px 120px -30px rgba(21,23,28,.45),0 0 0 8px rgba(255,255,255,.45);text-align:left}
.aw-bar{display:flex;align-items:center;gap:6px;padding:11px 14px;background:#121316;border-bottom:1px solid rgba(255,255,255,.07)}
.aw-bar i{width:10px;height:10px;border-radius:50%;background:#2a2c33}
.aw-bar span{margin-left:10px;font-family:var(--mono);font-size:10.5px;color:#6a6e78}
.aw-body{display:grid;grid-template-columns:170px 1fr;min-height:380px}
.aw-sb{border-right:1px solid rgba(255,255,255,.07);padding:14px 10px;display:flex;flex-direction:column;gap:3px;background:#0e0f12}
.aw-sb .it{font-size:11px;color:#9a9da6;padding:6px 9px;border-radius:7px;font-weight:500;display:flex;gap:7px;align-items:center}
.aw-sb .it.on{background:rgba(70,201,139,.14);color:#edeef1;border:1px solid rgba(70,201,139,.3)}
.aw-sb .it .sw{width:6px;height:6px;border-radius:2px;background:#3a3d45}
.aw-sb .it.on .sw{background:var(--accent-2)}
.aw-main{padding:18px 20px}
.aw-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.aw-kpi{background:#121316;border:1px solid rgba(255,255,255,.07);border-radius:11px;padding:12px 14px}
.aw-kpi .l{font-size:8.5px;text-transform:uppercase;letter-spacing:.1em;color:#6a6e78;font-weight:700}
.aw-kpi .v{font-size:20px;font-weight:700;letter-spacing:-.03em;color:#edeef1;margin-top:5px;font-variant-numeric:tabular-nums}
.aw-kpi .v.hero-v{background:linear-gradient(120deg,#fff 30%,#46c98b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.aw-kpi .d{font-size:10px;color:var(--pos);font-family:var(--mono);font-weight:600;margin-top:3px}
.aw-chart{margin-top:9px;background:#121316;border:1px solid rgba(255,255,255,.07);border-radius:11px;padding:13px 14px}
.aw-chart .t{font-size:11px;font-weight:600;color:#edeef1;margin-bottom:8px;display:flex;justify-content:space-between}
.aw-chart .t span{font-family:var(--mono);font-size:9px;color:var(--pos)}
.aw-goals{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:9px}
.aw-goal{background:#121316;border:1px solid rgba(255,255,255,.07);border-radius:11px;padding:11px 13px}
.aw-goal .gh{display:flex;justify-content:space-between;font-size:10.5px;color:#edeef1;font-weight:600}
.aw-goal .gh span{font-family:var(--mono);color:#6a6e78;font-weight:400}
.aw-goal .bar{height:5px;border-radius:3px;background:#1d1f24;margin-top:8px;overflow:hidden}
.aw-goal .bar div{height:100%;border-radius:3px}
@media(max-width:760px){.aw-body{grid-template-columns:1fr}.aw-sb{display:none}.aw-kpis{grid-template-columns:1fr 1fr}}

/* ============ features ============ */
.feats{padding-top:70px;padding-bottom:30px;color:#15171c}
.feats .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1080px;margin:0 auto}
.feat{background:rgba(255,255,255,.7);backdrop-filter:blur(8px);border:1px solid rgba(21,23,28,.08);border-radius:16px;padding:26px 26px;text-align:left;box-shadow:0 20px 50px -30px rgba(21,23,28,.25)}
.feat .ic{width:40px;height:40px;border-radius:11px;background:linear-gradient(140deg,var(--accent),#1f8a5b);display:grid;place-items:center;margin-bottom:16px;color:#fff;box-shadow:0 8px 20px rgba(47,174,116,.3)}
.feat .ic svg{width:19px;height:19px}
.feat h3{font-size:16.5px;font-weight:700;letter-spacing:-.02em;color:#15171c;margin-bottom:7px}
.feat p{font-size:13.5px;color:#5a5e68;line-height:1.6;font-weight:450}
.feat p b{color:#15171c;font-weight:600}
@media(max-width:860px){.feats .grid{grid-template-columns:1fr}}

/* before/after strip */
.strip{max-width:880px;margin:64px auto 0;display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:stretch}
.strip .col{border-radius:14px;padding:20px 22px;text-align:left}
.strip .antes{background:#15161a;border:1px solid rgba(240,97,109,.25)}
.strip .antes h4{color:#ff8b94}
.strip .despues{background:rgba(255,255,255,.75);border:1px solid rgba(47,174,116,.3)}
.strip .despues h4{color:#1f8a5b}
.strip h4{font-size:11px;text-transform:uppercase;letter-spacing:.13em;font-weight:700;margin-bottom:12px}
.strip ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.strip .antes li{font-size:13px;color:#9a9da6}
.strip .despues li{font-size:13px;color:#3a3e48}
.strip .arrow{align-self:center;font-size:22px;color:#1f8a5b;font-weight:700}
@media(max-width:760px){.strip{grid-template-columns:1fr}.strip .arrow{transform:rotate(90deg);justify-self:center}}

/* ============ módulos — pestañas ============ */
.mods{padding-top:84px;color:#15171c;text-align:center}
.mods .kicker{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;color:#1f8a5b;font-weight:700;margin-bottom:16px}
.mods .kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* explorador por pestañas (estilo Fillout) */
.tabx{max-width:1080px;margin:36px auto 0}
.tabx-bar{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;background:rgba(255,255,255,.55);backdrop-filter:blur(6px);border:1px solid rgba(21,23,28,.08);border-radius:14px;padding:6px;width:fit-content;margin:0 auto}
.tx{font-family:var(--sans);font-size:13.5px;font-weight:600;color:#5a5e68;background:transparent;border:none;border-radius:9px;padding:9px 18px;cursor:pointer;transition:.15s}
.tx:hover{color:#15171c}
.tx.on{background:#fff;color:#15171c;box-shadow:0 4px 14px -4px rgba(21,23,28,.25)}
.tpane{display:none;grid-template-columns:1fr 1.05fr;gap:40px;align-items:center;background:#fff;border:1px solid rgba(21,23,28,.08);border-radius:22px;padding:clamp(24px,4vw,48px);margin-top:14px;box-shadow:0 30px 80px -40px rgba(21,23,28,.25);text-align:left}
.tpane.on{display:grid;animation:tpin .35s ease}
@keyframes tpin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.tp-copy h3{font-size:clamp(21px,2.8vw,28px);font-weight:800;letter-spacing:-.03em;color:#15171c;line-height:1.15}
.tp-copy ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:11px;padding:0}
.tp-copy li{font-size:14px;color:#3a3e48;display:flex;gap:10px;align-items:flex-start;font-weight:480}
.tp-copy li::before{content:"✓";color:#1f8a5b;font-weight:800;flex:0 0 auto}
.tp-cta{display:inline-block;margin-top:22px;font-size:13.5px;font-weight:700;color:#1f8a5b;text-decoration:none;border-bottom:1.5px solid rgba(31,138,91,.35);padding-bottom:2px;transition:.15s}
.tp-cta:hover{border-color:#1f8a5b}
.tp-mock{background:#0e0f12;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:16px;font-family:var(--mono);box-shadow:0 24px 60px -30px rgba(21,23,28,.55)}
.tm-bar{display:flex;gap:5px;align-items:center;margin-bottom:12px}
.tm-bar i{width:8px;height:8px;border-radius:50%;background:#2a2c33}
.tm-bar span{margin-left:auto;font-size:9.5px;color:#6a6e78;text-transform:uppercase;letter-spacing:.1em}
.tm-kpis{display:flex;gap:8px}
.tm-kpi{flex:1;background:#17181c;border:1px solid rgba(255,255,255,.07);border-radius:9px;padding:11px 13px}
.tm-kpi small{display:block;font-size:8.5px;color:#6a6e78;letter-spacing:.08em;margin-bottom:4px}
.tm-kpi b{font-size:19px;color:#edeef1;font-weight:600;letter-spacing:-.02em}
.tm-kpi.big b{font-size:23px}
.tm-kpi em{display:block;font-style:normal;font-size:9.5px;color:#9a9da6;margin-top:3px}
.tm-kpi em.up,.up{color:#46c98b}
.down{color:#f0616d}
.tm-row{display:flex;align-items:center;gap:9px;background:#17181c;border:1px solid rgba(255,255,255,.07);border-radius:9px;padding:10px 13px;margin-bottom:7px;font-size:11.5px;color:#9a9da6}
.tm-row b{margin-left:auto;color:#edeef1;font-weight:600}
.tm-row b.up{color:#46c98b}
.tm-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.tm-note{font-size:10.5px;color:#46c98b;background:rgba(70,201,139,.1);border:1px solid rgba(70,201,139,.25);border-radius:8px;padding:8px 11px;margin-top:4px;font-family:var(--sans);font-weight:550}
.tm-bud{display:flex;align-items:center;gap:10px;margin-bottom:11px;font-size:11px;color:#9a9da6}
.tm-bud span{flex:0 0 116px;font-family:var(--sans);font-weight:550;color:#c8cbd2}
.tm-bud .b{flex:1;height:6px;border-radius:4px;background:#1d1f24;overflow:hidden}
.tm-bud .b div{height:100%;border-radius:4px}
.tm-bud b{flex:0 0 38px;text-align:right;color:#edeef1;font-weight:600}
.tm-msg{font-family:var(--sans);font-size:12.5px;line-height:1.55;padding:10px 13px;border-radius:12px;margin-bottom:9px;max-width:92%}
.tm-msg.me{background:rgba(70,201,139,.16);border:1px solid rgba(70,201,139,.3);color:#edeef1;margin-left:auto;width:fit-content;border-bottom-right-radius:4px}
.tm-msg.bot{background:#17181c;border:1px solid rgba(255,255,255,.08);color:#9a9da6;border-bottom-left-radius:4px}
@media(max-width:860px){.tpane{grid-template-columns:1fr;gap:24px}.tx{padding:8px 13px;font-size:12.5px}}

/* ============ copiloto IA ============ */
.copi{padding-top:90px;color:#15171c}
.copi .wrap2{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1fr 400px;gap:44px;align-items:center}
.copi .kicker{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;color:#1f8a5b;font-weight:700;margin-bottom:16px}
.copi .kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.copi .chat{background:#0e0f12;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:18px;box-shadow:0 40px 90px -40px rgba(21,23,28,.5),0 0 0 8px rgba(255,255,255,.45)}
.copi .msg{max-width:88%;font-size:13px;line-height:1.55;padding:10px 13px;border-radius:12px;margin-bottom:9px;white-space:pre-line}
.copi .msg.me{background:rgba(47,174,116,.16);border:1px solid rgba(47,174,116,.3);color:#edeef1;margin-left:auto;border-bottom-right-radius:4px;width:fit-content}
.copi .msg.bot{background:#17181c;border:1px solid rgba(255,255,255,.08);color:#9a9da6;border-bottom-left-radius:4px}
.copi .msg.bot b{color:#edeef1}
.copi h2{font-size:clamp(28px,4.6vw,46px);font-weight:800;letter-spacing:-.035em;line-height:1.07;color:#15171c}
.copi p.cp{font-size:15.5px;color:#5a5e68;margin-top:16px;line-height:1.65;font-weight:450}
.copi ul{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:10px}
.copi li{font-size:13.5px;color:#3a3e48;display:flex;gap:10px;align-items:flex-start;font-weight:480}
.copi li::before{content:"✓";color:#1f8a5b;font-weight:800;flex:0 0 auto}
@media(max-width:860px){.copi .wrap2{grid-template-columns:1fr}}

/* ============ integraciones marquee ============ */
.integ{padding-top:90px;text-align:center;color:#15171c}
.integ .kicker{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;color:#1f8a5b;font-weight:700;margin-bottom:16px}
.integ .kicker .dot{width:6px;height:6px;border-radius:50%;background:var(--accent)}
.integ p.ip{font-size:14px;color:#5a5e68;max-width:52ch;margin:12px auto 28px}
.marquee{overflow:hidden;max-width:980px;margin:0 auto;-webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.mq-track{display:flex;gap:12px;width:max-content;animation:mq 28s linear infinite}
@keyframes mq{to{transform:translateX(-50%)}}
.mq-item{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.8);border:1px solid rgba(21,23,28,.08);border-radius:999px;padding:8px 16px 8px 9px;font-size:13px;font-weight:600;color:#3a3e48;white-space:nowrap}
.mq-item .mono{width:24px;height:24px;border-radius:6px;display:grid;place-items:center;font-family:var(--mono);font-style:normal;font-size:9.5px;font-weight:700;letter-spacing:-.02em;color:#fff;flex:0 0 auto}

/* ============ CTA final ============ */
.final{padding-top:90px;padding-bottom:110px;text-align:center;color:#15171c}
.final h2{font-size:clamp(32px,6vw,64px);font-weight:800;letter-spacing:-.045em;line-height:1.04;color:#15171c}
.final h2 em{font-style:normal;background:linear-gradient(120deg,#1f8a5b,#46c98b 60%,#2fae74);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.final p{font-size:16px;color:#5a5e68;margin:18px auto 30px;max-width:46ch}
.final .big-cta{display:inline-flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(140deg,var(--accent),#1f8a5b);border:none;border-radius:14px;padding:16px 32px;cursor:pointer;text-decoration:none;box-shadow:0 18px 50px rgba(47,174,116,.4);transition:.18s}
.final .big-cta:hover{filter:brightness(1.1);transform:translateY(-2px)}
.final .dom2{display:block;margin-top:22px;font-family:var(--mono);font-size:13px;color:#8a8d96}
footer{position:relative;z-index:1;padding:22px;text-align:center;font-size:12px;color:#8a8d96;border-top:1px solid rgba(21,23,28,.08)}

/* reveal on scroll */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.rv.in{opacity:1;transform:none}

/* ============ relámpagos del acto caos (capa generada por JS) ============
   Solo se anima opacity; el zigzag se regenera por strike en landing.js */
.storm{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.storm-bolts{position:absolute;inset:0;width:100%;height:100%;display:block}
.storm-bolts path{fill:none;stroke:#eaf3ff;stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round;opacity:0;will-change:opacity;
  filter:drop-shadow(0 0 6px rgba(156,200,255,.95)) drop-shadow(0 0 18px rgba(255,255,255,.55))}
.storm-bolts path.on{animation:storm-bolt .42s linear both}
.storm-flash{position:absolute;inset:0;opacity:0;will-change:opacity;
  background:radial-gradient(130% 95% at 50% -12%,rgba(223,237,255,.95) 0%,rgba(156,200,255,.55) 32%,rgba(96,134,193,.2) 60%,rgba(96,134,193,0) 82%)}
.storm-flash.on{animation:storm-flash .46s linear both}
/* doble parpadeo: pico fuerte, caída, segundo pico, apagón */
@keyframes storm-bolt{0%{opacity:0}5%{opacity:1}18%{opacity:.2}28%{opacity:.95}55%{opacity:.5}100%{opacity:0}}
@keyframes storm-flash{0%{opacity:0}6%{opacity:.5}22%{opacity:.1}34%{opacity:.35}60%{opacity:.12}100%{opacity:0}}

/* ============ prefers-reduced-motion ============ */
@media (prefers-reduced-motion: reduce){
  .frag{translate:none!important;rotate:none!important}
  .rv{opacity:1;transform:none;transition:none}
  .scroll-cue .line{animation:none}
  .mq-track{animation:none}
  .hero h1 .glitch::before,.hero h1 .glitch::after{animation:none;opacity:0;content:none}
  .tpane.on{animation:none}
  .storm{display:none}
}
