:root{
  --ink:#05080F;
  --ink-2:#080D1A;
  --navy:#0A1228;
  --blue:#2F6BFF;
  --blue-deep:#1E3A8A;
  --cyan:#39E6FF;
  --paper:#F4F6FB;
  --text:#E8ECF6;
  --muted:#8B96B3;
  --line:rgba(139,150,179,.16);
  --font-display:'Unbounded',sans-serif;
  --font-body:'Archivo',sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
  --bg-current:var(--ink);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
::selection{background:var(--cyan);color:var(--ink)}
body{
  font-family:var(--font-body);
  background:var(--bg-current);
  color:var(--text);
  overflow-x:hidden;
  transition:background-color 1s cubic-bezier(.4,0,.2,1);
  cursor:none;
}
@media (hover:none),(pointer:coarse){body{cursor:auto}}
img{max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:none}
@media (hover:none){button{cursor:pointer}}

/* ---------- custom cursor ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;transform:translate(-50%,-50%)}
.cursor-dot{width:8px;height:8px;background:var(--cyan);transition:width .25s,height .25s,background .25s}
.cursor-ring{width:38px;height:38px;border:1px solid rgba(57,230,255,.55);transition:width .3s,height .3s,border-color .3s,background .3s}
.cursor-hover .cursor-ring{width:64px;height:64px;border-color:var(--cyan);background:rgba(57,230,255,.08)}
.cursor-hover .cursor-dot{width:4px;height:4px}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}

/* ---------- progress bar ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--blue),var(--cyan));z-index:1001;box-shadow:0 0 14px rgba(57,230,255,.7)}

/* ---------- nav ---------- */
.nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);width:min(1180px,calc(100% - 32px));z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-radius:18px;border:1px solid transparent;transition:background .4s,border-color .4s,backdrop-filter .4s,box-shadow .4s}
.nav.scrolled{background:rgba(6,10,20,.62);border-color:var(--line);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 14px 40px rgba(0,0,0,.35)}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.02rem;letter-spacing:.04em}
.logo-mark{width:36px;height:36px;border-radius:50%;background:#fff;display:grid;place-items:center;flex:0 0 auto}
.logo-mark svg{width:20px;height:20px}
.logo span em{font-style:normal;color:var(--cyan)}
.nav-links{display:flex;gap:34px;align-items:center;list-style:none}
.nav-links a{font-size:.86rem;font-weight:500;color:var(--muted);position:relative;transition:color .25s;letter-spacing:.02em}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--cyan);transition:width .3s cubic-bezier(.65,0,.35,1)}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-cta{font-family:var(--font-mono);font-size:.78rem;padding:11px 20px;border-radius:12px;background:var(--blue);color:#fff;border:none;letter-spacing:.04em;transition:transform .25s,box-shadow .25s,background .25s}
.nav-cta:hover{background:var(--cyan);color:var(--ink);box-shadow:0 0 26px rgba(57,230,255,.5)}
.burger{display:none;background:none;border:none;width:42px;height:42px;flex-direction:column;justify-content:center;gap:6px;align-items:center}
.burger span{display:block;width:22px;height:2px;background:var(--text);transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;background:rgba(5,8,15,.96);backdrop-filter:blur(20px);z-index:999;display:flex;flex-direction:column;justify-content:center;padding:0 8vw;gap:10px;clip-path:circle(0 at calc(100% - 48px) 48px);transition:clip-path .6s cubic-bezier(.65,0,.35,1);visibility:hidden}
.mobile-menu.open{clip-path:circle(150% at calc(100% - 48px) 48px);visibility:visible}
.mobile-menu a{font-family:var(--font-display);font-size:clamp(1.6rem,7vw,2.6rem);font-weight:600;padding:10px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;opacity:0;transform:translateY(24px);transition:opacity .4s,transform .4s,color .3s}
.mobile-menu.open a{opacity:1;transform:translateY(0)}
.mobile-menu a:hover{color:var(--cyan)}
.mobile-menu a .idx{font-family:var(--font-mono);font-size:.8rem;color:var(--muted)}

/* ---------- hero ---------- */
.hero{min-height:100svh;position:relative;display:flex;flex-direction:column;justify-content:center;padding:140px 6vw 80px;overflow:hidden}
#flow-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.85}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 55% at 50% 42%,transparent 30%,var(--ink) 100%);z-index:1;pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;width:100%}
.hero-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);border:1px solid rgba(57,230,255,.3);border-radius:999px;padding:9px 18px;margin-bottom:34px;background:rgba(57,230,255,.05)}
.hero-tag .pulse{width:7px;height:7px;border-radius:50%;background:var(--cyan);animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(57,230,255,.6)}70%{box-shadow:0 0 0 12px rgba(57,230,255,0)}100%{box-shadow:0 0 0 0 rgba(57,230,255,0)}}
h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2.3rem,6.4vw,5.1rem);line-height:1.05;letter-spacing:-.01em;max-width:16ch}
h1 .word{display:inline-block;overflow:hidden;vertical-align:bottom}
h1 .word span{display:inline-block;transform:translateY(110%);animation:rise .9s cubic-bezier(.22,1,.36,1) forwards;animation-delay:var(--d)}
@keyframes rise{to{transform:translateY(0)}}
.grad-text{background:linear-gradient(120deg,var(--blue) 0%,var(--cyan) 55%,#9BE8FF 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.outline-text{color:transparent;-webkit-text-stroke:1.5px rgba(232,236,246,.85)}
.hero-sub{margin-top:30px;max-width:54ch;color:var(--muted);font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.7;opacity:0;animation:fadeUp 1s .7s forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero-ctas{display:flex;gap:18px;margin-top:44px;flex-wrap:wrap;opacity:0;animation:fadeUp 1s .9s forwards}
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.05em;padding:17px 32px;border-radius:14px;border:none;position:relative;overflow:hidden;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s;will-change:transform}
.btn-primary{background:linear-gradient(120deg,var(--blue),#1d4ed8);color:#fff}
.btn-primary::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--cyan),var(--blue));opacity:0;transition:opacity .35s}
.btn-primary:hover::before{opacity:1}
.btn-primary span{position:relative;z-index:1}
.btn-primary:hover{box-shadow:0 12px 40px rgba(47,107,255,.45)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.3em;color:var(--muted);text-transform:uppercase}
.hero-scroll .line{width:1px;height:46px;background:linear-gradient(var(--cyan),transparent);animation:dropline 2s infinite}
@keyframes dropline{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}}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;position:relative;background:rgba(255,255,255,.012)}
.marquee-track{display:flex;gap:0;width:max-content;animation:scrollX 26s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:34px;padding:0 34px;font-family:var(--font-display);font-weight:300;font-size:clamp(1.1rem,2.4vw,1.7rem);white-space:nowrap;color:var(--muted);transition:color .3s}
.marquee-item:hover{color:var(--cyan)}
.marquee-item svg{width:14px;height:14px;color:var(--blue);flex:0 0 auto}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* ---------- shared section bits ---------- */
section{position:relative}
.wrap{max-width:1180px;margin:0 auto;padding:0 6vw}
.sec-label{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:14px;margin-bottom:22px}
.sec-label::before{content:"";width:42px;height:1px;background:var(--cyan)}
h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.7rem,4vw,3rem);line-height:1.15;letter-spacing:-.01em}
.reveal{opacity:0;transform:translateY(46px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);transition-delay:var(--rd,0s)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- services bento ---------- */
.services{padding:130px 0}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:64px;flex-wrap:wrap}
.services-head p{max-width:38ch;color:var(--muted);line-height:1.7}
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{grid-column:span 4;border:1px solid var(--line);border-radius:22px;padding:34px;background:linear-gradient(160deg,rgba(255,255,255,.03),rgba(255,255,255,0));position:relative;overflow:hidden;transition:transform .4s cubic-bezier(.22,1,.36,1),border-color .4s;min-height:280px;display:flex;flex-direction:column;justify-content:flex-end}
.card.lg{grid-column:span 8}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(47,107,255,.16),transparent 65%);opacity:0;transition:opacity .4s;pointer-events:none}
.card:hover::before{opacity:1}
.card:hover{transform:translateY(-7px);border-color:rgba(57,230,255,.35)}
.card .num{position:absolute;top:26px;right:30px;font-family:var(--font-mono);font-size:.74rem;color:var(--muted);letter-spacing:.1em}
.card .icon{width:52px;height:52px;border-radius:14px;border:1px solid var(--line);display:grid;place-items:center;margin-bottom:auto;background:rgba(47,107,255,.08);transition:background .35s,transform .35s}
.card:hover .icon{background:rgba(57,230,255,.14);transform:rotate(-8deg) scale(1.06)}
.card .icon svg{width:24px;height:24px;color:var(--cyan)}
.card h3{font-family:var(--font-display);font-weight:600;font-size:1.18rem;margin:26px 0 12px}
.card p{color:var(--muted);font-size:.92rem;line-height:1.65}
.card .tagrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.card .tag{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;padding:6px 12px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}

/* ---------- stats (light section) ---------- */
.stats{padding:150px 0;color:var(--ink)}
body[data-zone="light"]{ --bg-current:var(--paper) }
body[data-zone="navy"]{ --bg-current:var(--navy) }
body[data-zone="dark"]{ --bg-current:var(--ink) }
.stats .sec-label{color:var(--blue-deep)}
.stats .sec-label::before{background:var(--blue-deep)}
.stats h2{color:var(--ink)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:74px;border-top:1px solid rgba(5,8,15,.14)}
.stat{padding:44px 26px;border-right:1px solid rgba(5,8,15,.14);transition:background .35s}
.stat:last-child{border-right:none}
.stat:hover{background:rgba(47,107,255,.06)}
.stat .value{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,4.6vw,3.6rem);color:var(--blue-deep);display:flex;align-items:baseline}
.stat .value small{font-size:.45em;color:var(--blue)}
.stat .label{margin-top:12px;font-size:.88rem;color:#3D4663;line-height:1.5}

/* ---------- process ---------- */
.process{padding:150px 0}
.process-list{margin-top:70px;position:relative}
.process-line{position:absolute;left:25px;top:0;bottom:0;width:1px;background:var(--line)}
.process-line .fill{position:absolute;top:0;left:0;width:100%;height:0;background:linear-gradient(var(--blue),var(--cyan));box-shadow:0 0 12px rgba(57,230,255,.6)}
.step{display:grid;grid-template-columns:52px 1fr;gap:34px;padding:38px 0;position:relative}
.step .dot{width:52px;height:52px;border-radius:50%;border:1px solid var(--line);background:var(--bg-current);display:grid;place-items:center;font-family:var(--font-mono);font-size:.8rem;color:var(--muted);transition:border-color .4s,color .4s,box-shadow .4s;z-index:1}
.step.in .dot{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 22px rgba(57,230,255,.35)}
.step h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.15rem,2.4vw,1.6rem);margin-bottom:10px}
.step p{color:var(--muted);max-width:58ch;line-height:1.7}

/* ---------- CTA ---------- */
.cta{padding:170px 0;text-align:center;position:relative;overflow:hidden}
.cta .orb{position:absolute;width:560px;height:560px;border-radius:50%;filter:blur(110px);opacity:.35;pointer-events:none}
.cta .orb.a{background:var(--blue);top:-180px;left:-140px;animation:drift 14s ease-in-out infinite alternate}
.cta .orb.b{background:var(--cyan);bottom:-220px;right:-160px;animation:drift 17s ease-in-out infinite alternate-reverse}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(70px,50px) scale(1.15)}}
.cta h2{font-size:clamp(2rem,5.4vw,4.2rem);max-width:18ch;margin:0 auto}
.cta p{color:var(--muted);margin:26px auto 48px;max-width:48ch;line-height:1.7}
.magnetic{display:inline-block}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:64px 0 36px}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}
.foot-grid .col p{color:var(--muted);font-size:.88rem;margin-top:14px;max-width:30ch;line-height:1.6}
.foot-links{display:flex;gap:64px;flex-wrap:wrap}
.foot-links h4{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.foot-links a{display:block;font-size:.9rem;color:var(--text);opacity:.8;margin-bottom:12px;transition:color .25s,opacity .25s}
.foot-links a:hover{color:var(--cyan);opacity:1}
.foot-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:56px;padding-top:26px;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.72rem;color:var(--muted);letter-spacing:.06em}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .nav-links{display:none}
  .burger{display:flex}
  .bento{grid-template-columns:1fr}
  .card,.card.lg{grid-column:span 1;min-height:auto}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(5,8,15,.14)}
  .stat:nth-child(odd){border-right:1px solid rgba(5,8,15,.14)}
}
@media (max-width:560px){
  .stats-grid{grid-template-columns:1fr}
  .stat:nth-child(odd){border-right:none}
  .step{grid-template-columns:44px 1fr;gap:20px}
  .step .dot{width:44px;height:44px}
  .process-line{left:21px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  h1 .word span{transform:none;animation:none}
  .hero-sub,.hero-ctas{opacity:1;animation:none}
}
