:root{
  --espacio:#0B0A12;--orbital:#15131F;--orbital-2:#1E1B2B;--linea:#2C2740;
  --bizcocho:#F6F1E7;--miga:#C9C0D6;--humo:#8E86A3;--logo-ink:#F6F1E7;
  --ember:#FF7A3D;--coral:#FF4D7D;--violeta:#8B5CF6;--orbita:#36C5F0;--amber:#FFB23D;
  --filamento:linear-gradient(100deg,#FFB23D 0%,#FF7A3D 24%,#FF4D7D 50%,#8B5CF6 76%,#36C5F0 100%);
  --display:'Space Grotesk',system-ui,sans-serif;--texto:'Hanken Grotesk','Inter',system-ui,sans-serif;--calida:'Fredoka',system-ui,sans-serif;
  --t-xs:clamp(.72rem,.69rem + .15vw,.82rem);--t-sm:clamp(.85rem,.8rem + .25vw,.98rem);--t-base:clamp(1rem,.94rem + .4vw,1.18rem);
  --t-lg:clamp(1.3rem,1.05rem + .9vw,1.8rem);--t-xl:clamp(2rem,1.4rem + 2.6vw,3.4rem);--t-2xl:clamp(2.8rem,1.8rem + 5vw,6rem);--t-3xl:clamp(3.4rem,2rem + 7vw,8.5rem);
  --maxw:1240px;--ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--texto);background:var(--espacio);color:var(--bizcocho);font-size:var(--t-base);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.loading{overflow:hidden;height:100vh}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.05;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}
::selection{background:var(--violeta);color:#fff}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.6rem)}
.grad{background:var(--filamento);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.grad.flow{animation:gradflow 7s linear infinite}
@keyframes gradflow{to{background-position:220% center}}
.divider{height:2px;width:100%;border:0;border-radius:2px;background:var(--filamento);background-size:220% auto;animation:gradflow 6s linear infinite;opacity:.55}
.divwrap{max-width:var(--maxw);margin:0 auto;padding:clamp(1rem,4vh,2.5rem) clamp(1.2rem,4vw,2.6rem)}
.eyebrow{font-family:var(--display);font-size:var(--t-xs);letter-spacing:.3em;text-transform:uppercase;color:var(--orbita);font-weight:500}
.muted{color:var(--miga)}.lg{display:block;width:100%;height:auto}
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--ember);color:#1a0e07;border:none;border-radius:100px;padding:.85rem 1.5rem;font-family:var(--display);font-weight:600;font-size:var(--t-sm);cursor:pointer;transition:.25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,122,61,.3)}
.btn.ghost{background:transparent;color:var(--bizcocho);border:1px solid var(--linea)}
.btn.ghost:hover{border-color:var(--violeta);box-shadow:none}
.reveal{opacity:0;transform:translateY(30px)}

/* LOADER */
#loader{position:fixed;inset:0;z-index:9999;background:var(--espacio);display:grid;place-items:center;transition:opacity .7s var(--ease),visibility .7s}
#loader.done{opacity:0;visibility:hidden}
#loader .lg{width:120px;margin-bottom:1rem}
#loader .bar{width:180px;height:3px;border-radius:3px;background:var(--linea);overflow:hidden}
#loader .bar i{display:block;height:100%;width:40%;background:var(--filamento);animation:load 1.1s var(--ease) infinite}
@keyframes load{0%{transform:translateX(-100%)}100%{transform:translateX(350%)}}

/* SCRUB HERO */
.scrub{position:relative;height:420vh}
.sticky{position:sticky;top:0;height:100vh;height:100svh;overflow:hidden}
.sticky video,.sticky .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.sticky .scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(11,10,18,.9),rgba(11,10,18,.25) 40%,rgba(11,10,18,.55));}
.sticky .title{position:absolute;z-index:3;left:0;right:0;top:42%;transform:translateY(-50%);text-align:center;padding:0 clamp(1.2rem,5vw,2rem);will-change:opacity,transform}
.sticky .title h1{font-size:clamp(2.4rem,2rem + 6vw,8rem);font-weight:700;letter-spacing:-.03em}
.sticky .title p{color:var(--miga);font-size:var(--t-lg);font-weight:300;margin-top:.8rem}
.stages{display:contents}
.stage{position:absolute;z-index:3;left:0;right:0;bottom:clamp(3rem,10vh,6rem);padding:0 clamp(1.2rem,4vw,2rem);text-align:center;opacity:0;transform:translateY(16px);will-change:opacity,transform}
.stage .n{font-family:var(--display);font-size:var(--t-xs);letter-spacing:.3em;text-transform:uppercase;color:var(--orbita);display:block;margin-bottom:.5rem}
.stage h2{font-size:clamp(1.7rem,1.05rem + 4.4vw,3.2rem);font-weight:700;letter-spacing:-.02em;line-height:1.06;max-width:20ch;margin:0 auto}
.stage p{color:var(--miga);max-width:42ch;margin:.5rem auto 0;font-weight:300;font-size:clamp(.9rem,.82rem + .5vw,1.1rem)}
.dots{position:absolute;z-index:4;right:clamp(1rem,3vw,2rem);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.7rem}
.dots i{width:8px;height:8px;border-radius:50%;background:#ffffff33;transition:.3s}
.dots i.on{background:var(--filamento);transform:scale(1.4)}
.scrollcue{position:absolute;z-index:4;bottom:1.2rem;left:50%;transform:translateX(-50%);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--humo);display:flex;flex-direction:column;align-items:center;gap:.4rem}
.scrollcue .bar{width:1px;height:34px;background:linear-gradient(var(--ember),transparent);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* SECTIONS */
.sec{padding:clamp(4rem,9vh,6.5rem) 0}
.manif{padding:clamp(4rem,10vh,7rem) 0;text-align:center;background:linear-gradient(180deg,var(--espacio),var(--orbital))}
.manif h2{font-family:var(--display);font-weight:500;font-size:var(--t-2xl);line-height:1.08;max-width:18ch;margin:0 auto}
.sec-head{max-width:680px;margin-bottom:2.6rem}
.sec-head .eyebrow{margin-bottom:.8rem;display:block}
.sec-head h2{font-size:var(--t-xl);margin-bottom:.8rem}
.sec-head p{color:var(--miga);font-size:var(--t-lg);font-weight:300}
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:900px){.serv-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.serv-grid{grid-template-columns:1fr}}
.serv{border:1px solid var(--linea);border-radius:18px;padding:1.6rem;background:var(--orbital);transition:.4s;position:relative;overflow:hidden}
.serv::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--filamento);transform:scaleY(0);transform-origin:top;transition:.4s var(--ease)}
.serv:hover{transform:translateY(-5px);border-color:var(--violeta)}.serv:hover::before{transform:scaleY(1)}
.serv .ic{font-size:1.7rem;margin-bottom:1rem}.serv h4{font-size:var(--t-lg);margin-bottom:.4rem}.serv p{color:var(--miga);font-size:var(--t-sm)}.serv .more{margin-top:1rem;font-family:var(--display);font-size:var(--t-sm);color:var(--ember)}
.serv.feat{background:linear-gradient(120deg,rgba(139,92,246,.12),rgba(255,122,61,.08));border-color:transparent;box-shadow:inset 0 0 0 1.5px var(--violeta)}
.serv.feat::before{transform:scaleY(1)}
.serv.feat h4{font-size:var(--t-lg)}
.clients-band{margin-top:clamp(3rem,7vh,5rem);text-align:center}
.clients-band .ch{margin-bottom:1.6rem}.clients-band h3{font-size:var(--t-lg);margin-top:.4rem}
.logos{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logos .track{display:flex;gap:1rem;width:max-content;animation:marquee 34s linear infinite}
.logos:hover .track{animation-play-state:paused}
.tile{border:1px solid var(--linea);border-radius:12px;padding:.85rem 1.6rem;font-family:var(--display);font-weight:500;color:var(--miga);white-space:nowrap;font-size:var(--t-base);transition:.3s}
.tile:hover{color:var(--bizcocho);border-color:var(--violeta)}
@keyframes marquee{to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.logos .track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}
.proc{background:linear-gradient(180deg,var(--orbital),var(--espacio))}
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;counter-reset:p}
@media(max-width:900px){.steps{grid-template-columns:1fr 1fr}}@media(max-width:560px){.steps{grid-template-columns:1fr}}
.stp{border:1px solid var(--linea);border-radius:16px;padding:1.3rem;background:var(--orbital)}
.stp .n{counter-increment:p;font-family:var(--display);color:var(--violeta);font-size:var(--t-sm)}.stp .n::before{content:counter(p,decimal-leading-zero)}
.stp h4{font-size:var(--t-base);margin:.5rem 0 .3rem}.stp p{font-size:var(--t-sm);color:var(--miga)}
.proc2{position:relative;max-width:760px;margin:0 auto;padding-left:2.9rem}
.proc2 .spine{position:absolute;left:9px;top:.4rem;bottom:1.4rem;width:3px;border-radius:3px;background:var(--linea);overflow:hidden}
.proc2 .spine .fill{position:absolute;left:0;right:0;top:0;height:0;background:var(--filamento);background-size:100% 260%;animation:gflowY 6s linear infinite}
@keyframes gflowY{to{background-position:0 -260%}}
.pstep{position:relative;padding:.1rem 0 2.1rem;opacity:.4;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.pstep:last-child{padding-bottom:0}
.pstep .node{position:absolute;left:-2.9rem;top:.2rem;width:22px;height:22px;border-radius:50%;background:var(--espacio);border:2px solid var(--linea);z-index:2;transition:.4s}
.pstep.on{opacity:1;transform:none}
.pstep.on .node{background:var(--filamento);border-color:transparent;box-shadow:0 0 0 6px rgba(139,92,246,.16)}
.pstep .ic{font-size:1.4rem;line-height:1;margin-bottom:.25rem}
.pstep .pn{font-family:var(--display);font-size:var(--t-sm);color:var(--humo);letter-spacing:.06em}
.pstep.on .pn{background:var(--filamento);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gradflow 7s linear infinite}
.pstep h4{font-size:var(--t-lg);margin:.15rem 0 .3rem}
.pstep p{color:var(--miga);font-size:var(--t-sm);max-width:48ch}
@media(prefers-reduced-motion:reduce){.proc2 .spine .fill{animation:none;height:100%!important}.pstep{opacity:1;transform:none}}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
@media(max-width:900px){.proj-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.proj-grid{grid-template-columns:1fr}}
.proj{display:block;position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;border:1px solid var(--linea)}
.proj img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}.proj:hover img{transform:scale(1.06)}
.proj .ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(11,10,18,.92),transparent 55%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.3rem}
.proj .tag{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orbita);font-family:var(--display)}.proj h4{font-size:var(--t-lg);margin-top:.3rem}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;text-align:center;border-top:1px solid var(--linea);border-bottom:1px solid var(--linea);padding:clamp(2.5rem,6vh,4rem) 0}
@media(max-width:560px){.stats{grid-template-columns:1fr;gap:2rem}}
.stat .num{font-family:var(--display);font-weight:700;font-size:var(--t-2xl);line-height:1}.stat .lab{color:var(--miga);font-size:var(--t-sm);margin-top:.4rem}
.quote{max-width:900px;margin:0 auto;text-align:center}
.quote blockquote{font-family:var(--display);font-weight:500;font-size:var(--t-xl);line-height:1.25;margin-bottom:1.4rem}.quote .who{color:var(--miga);font-size:var(--t-sm)}
.clients{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin-top:2.6rem}.clients span{border:1px solid var(--linea);border-radius:100px;padding:.4rem 1rem;font-size:var(--t-sm);color:var(--humo)}
.cta-band{position:relative;overflow:hidden;text-align:center;padding:clamp(4.5rem,11vh,8rem) 0;background:var(--orbital)}
.cta-band .bg{position:absolute;inset:0;z-index:0;opacity:.5}.cta-band .bg img{width:100%;height:100%;object-fit:cover}
.cta-band .scrim{position:absolute;inset:0;z-index:1;background:radial-gradient(120% 120% at 50% 0%,rgba(139,92,246,.3),transparent 55%),linear-gradient(0deg,rgba(11,10,18,.92),rgba(11,10,18,.7))}
.cta-band .inner{position:relative;z-index:2}.cta-band h2{font-size:var(--t-2xl);font-weight:700;max-width:18ch;margin:0 auto 1.4rem}
footer.ft{border-top:1px solid var(--linea);padding:clamp(3rem,7vh,4.5rem) 0 2rem}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;margin-bottom:2.5rem}@media(max-width:760px){.ft-grid{grid-template-columns:1fr 1fr}}
.ft-grid .lg{width:120px;margin-bottom:1rem}
.ft h5{font-family:var(--display);font-size:var(--t-xs);letter-spacing:.14em;text-transform:uppercase;color:var(--humo);margin-bottom:.9rem}
.ft a,.ft li{color:var(--miga);font-size:var(--t-sm);list-style:none;margin-bottom:.5rem;display:block}.ft a:hover{color:var(--ember)}
.ft-bottom{border-top:1px solid var(--linea);padding-top:1.4rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;color:var(--humo);font-size:var(--t-xs)}
.note-badge{position:fixed;bottom:.8rem;left:.8rem;z-index:400;background:rgba(21,19,31,.8);backdrop-filter:blur(8px);border:1px solid var(--linea);border-radius:100px;padding:.4rem .9rem;font-size:.66rem;color:var(--humo);font-family:var(--display)}
@media(max-width:600px){
  .dots{display:none}
  .stage{bottom:clamp(3.5rem,13vh,6.5rem)}
  .ft-grid{grid-template-columns:1fr 1fr}
}
@media(max-height:560px){
  .sticky .title{top:38%}.sticky .title p{display:none}
  .stage p{display:none}.stage h2{font-size:clamp(1.5rem,5vw,2.2rem)}
}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1!important;transform:none!important}.scrub{height:auto}.sticky{position:relative;height:auto;min-height:100svh}.grad.flow,.divider{animation:none}.stage{position:static;opacity:1!important;transform:none!important;margin:1.5rem 0}.sticky .title{position:static;transform:none;top:auto;padding-top:6rem}}

.cmp{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:600;max-width:560px;margin:0 auto;background:var(--orbital);border:1px solid var(--linea);border-radius:16px;padding:1.1rem 1.2rem;box-shadow:0 20px 50px rgba(0,0,0,.45);font-size:var(--t-sm);transform:translateY(160%);transition:transform .45s var(--ease)}
.cmp.show{transform:none}
.cmp p{color:var(--miga);margin:0 0 .8rem}.cmp a{color:var(--ember)}
.cmp .row{display:flex;gap:.6rem;flex-wrap:wrap}
.cmp .b{border:1px solid var(--linea);background:transparent;color:var(--bizcocho);border-radius:100px;padding:.55rem 1rem;font-family:var(--display);font-weight:600;font-size:var(--t-xs);cursor:pointer;transition:.2s}
.cmp .b:hover{border-color:var(--violeta)}.cmp .b.primary{background:var(--ember);color:#1a0e07;border-color:transparent}
.cmp .prefs{display:none;margin:.4rem 0 .9rem;border-top:1px solid var(--linea);padding-top:.8rem}
.cmp .prefs.open{display:block}
.cmp .opt{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.45rem 0;color:var(--miga)}
.cmp .opt b{color:var(--bizcocho);font-family:var(--display);font-size:var(--t-sm)}
.cmp .opt small{font-size:var(--t-xs);color:var(--humo)}
.cmp .sw{position:relative;width:42px;height:24px;border-radius:100px;background:var(--linea);cursor:pointer;flex:none;transition:.25s}
.cmp .sw.on{background:var(--violeta)}.cmp .sw.lock{opacity:.5;cursor:not-allowed}
.cmp .sw::after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.25s}
.cmp .sw.on::after{transform:translateX(18px)}
@media(prefers-reduced-motion:reduce){.cmp{transition:none}}
