/* ============================================================
   NETWRK Liechtenstein — main.css
   Cinematic · pure black · purple→pink · liquid glass
   ============================================================ */

:root{
  /* base */
  --bg:#08080A;
  --bg-deep:#0D0618;          /* breathing low */
  /* brand purple→pink */
  --purple-deep:#4C1D95;
  --purple:#7C3AED;
  --purple-bright:#A855F7;
  --magenta:#C026D3;
  --pink:#E879F9;
  --brand:linear-gradient(135deg,#4C1D95 0%,#7C3AED 40%,#A855F7 70%,#C026D3 100%);
  --brand-soft:linear-gradient(135deg,#7C3AED 0%,#A855F7 50%,#C026D3 100%);
  /* text */
  --white:#F4F4F7;
  --muted:#9a9aab;
  --faint:#82828f;
  /* accents (divider only) */
  --gold:#C9A227;
  --li-blue:#003979;
  --li-red:#CE1126;
  /* glass */
  --glass-bg:rgba(255,255,255,.04);
  --glass-bg-hi:rgba(255,255,255,.07);
  --glass-bd:rgba(255,255,255,.08);
  --glass-inset:inset 0 1px 0 rgba(255,255,255,.12);
  --glass-blur:blur(24px) saturate(180%);
  /* layout */
  --maxw:1320px;
  --pad:clamp(22px,5vw,90px);
  --ease:cubic-bezier(.22,1,.36,1);
  --font:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.lock{overflow:hidden}
a{color:inherit;text-decoration:none}
img,svg,canvas{display:block;max-width:100%}
::selection{background:var(--purple-bright);color:#0a0a0a}
h1,h2,h3,h4{font-family:var(--font);font-weight:700;line-height:1.02;letter-spacing:-.02em}

/* breathing background */
@keyframes breathe{0%,100%{background-color:var(--bg)}50%{background-color:var(--bg-deep)}}
body{animation:breathe 16s ease-in-out infinite}

/* gradient text helper */
.grad-text{background:var(--brand-soft);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent}

/* ===================== Glow blobs ===================== */
.glows{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.blob{position:absolute;width:46vw;height:46vw;max-width:680px;max-height:680px;border-radius:50%;
  filter:blur(110px);opacity:.5}
.blob.purple{background:radial-gradient(circle,rgba(124,58,237,.45),rgba(124,58,237,0) 68%)}
.blob.pink{background:radial-gradient(circle,rgba(192,38,211,.38),rgba(192,38,211,0) 68%)}
.blob.bright{background:radial-gradient(circle,rgba(168,85,247,.4),rgba(168,85,247,0) 68%)}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(8%,6%) scale(1.12)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1.05)}50%{transform:translate(-7%,-5%) scale(.92)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6%,-8%) scale(1.1)}}
.blob.a{animation:drift1 17s ease-in-out infinite}
.blob.b{animation:drift2 19s ease-in-out infinite}
.blob.c{animation:drift3 15s ease-in-out infinite}

/* ===================== Loader ===================== */
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:grid;place-items:center;
  transition:opacity .8s var(--ease),visibility .8s}
.loader.done{opacity:0;visibility:hidden}
.loader__logo{width:92px;height:92px;position:relative;-webkit-mask:url(../assets/img/logo-mark-white.png) center/contain no-repeat;mask:url(../assets/img/logo-mark-white.png) center/contain no-repeat;background:var(--brand-soft);background-size:200% 200%;animation:loaderShimmer 2.4s linear infinite}
.loader__logo img{opacity:0}
@keyframes loaderShimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.loader__bar{position:absolute;bottom:20%;width:min(50vw,220px);height:2px;background:rgba(255,255,255,.08);overflow:hidden;border-radius:2px}
.loader__bar span{display:block;height:100%;width:0;background:var(--brand-soft);box-shadow:0 0 12px rgba(168,85,247,.6)}
.loader__pct{position:absolute;bottom:15%;font-size:11px;letter-spacing:.3em;color:var(--muted);font-variant-numeric:tabular-nums}
.loader.iris{clip-path:circle(0% at 50% 50%);transition:clip-path .9s cubic-bezier(.7,0,.3,1),opacity .6s .3s}

/* ===================== Cursor glow follow (subtle) ===================== */
.cursor-glow{position:fixed;top:0;left:0;width:480px;height:480px;border-radius:50%;z-index:1;pointer-events:none;
  transform:translate(-50%,-50%);mix-blend-mode:screen;opacity:.5;
  background:radial-gradient(circle,rgba(168,85,247,.10),rgba(192,38,211,.05) 40%,transparent 70%)}
.cursor-dot{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;z-index:9000;pointer-events:none;
  transform:translate(-50%,-50%);background:#fff;mix-blend-mode:difference;
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s,opacity .3s}
body.cursor--link .cursor-dot{width:46px;height:46px;background:transparent;border:1px solid rgba(255,255,255,.9)}
body.cursor--grab .cursor-dot{width:54px;height:54px;background:rgba(168,85,247,.22);mix-blend-mode:normal;border:1px solid rgba(232,121,249,.7)}
body.cursor--text .cursor-dot{width:3px;height:26px;border-radius:2px}
@media (hover:none){.cursor-glow,.cursor-dot{display:none}}

/* scroll progress beam */
.scrollbeam{position:fixed;top:0;left:0;right:0;height:2px;z-index:1200;pointer-events:none;background:rgba(255,255,255,.05)}
.scrollbeam span{display:block;height:100%;width:100%;transform:scaleX(0);transform-origin:left;
  background:var(--brand-soft);box-shadow:0 0 12px rgba(168,85,247,.7)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* keyboard focus */
:focus-visible{outline:2px solid var(--pink);outline-offset:3px;border-radius:6px}
:focus:not(:focus-visible){outline:none}
.btn:focus-visible,.nav__cta:focus-visible{outline-offset:4px}
.skip{position:fixed;top:10px;left:10px;z-index:2000;background:var(--brand-soft);color:#fff;font-weight:600;
  padding:10px 18px;border-radius:8px;transform:translateY(-200%);transition:transform .3s var(--ease)}
.skip:focus{transform:none}

/* ===================== Navbar ===================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);transition:padding .5s var(--ease),background .5s,border-color .5s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(8,8,10,.8);backdrop-filter:blur(20px);border-bottom-color:rgba(168,85,247,.15);padding:12px var(--pad)}
.nav__brand{display:flex;align-items:center;gap:12px}
.nav__brand svg{width:30px;height:30px}
.nav__mark{width:30px;height:30px;object-fit:contain}
.nav__brand svg path{stroke:url(#brandGrad);stroke-width:6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.nav__name{font-family:var(--font);font-weight:700;font-size:17px;letter-spacing:.14em}
.nav__name b{font-weight:700}
.nav__name em{font-style:normal;display:block;font-size:8px;letter-spacing:.42em;color:var(--muted);margin-top:1px}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:13.5px;letter-spacing:.02em;color:var(--muted);transition:color .3s;position:relative}
.nav__links a:hover,.nav__links a.active{color:var(--white)}
.nav__links a.active{background:var(--brand-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.nav__burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:8px;z-index:1100}
.nav__burger span{width:26px;height:2px;background:var(--white);border-radius:2px;transition:.35s var(--ease)}
.nav__burger.open span:first-child{transform:translateY(8px) rotate(45deg)}
.nav__burger.open span:nth-child(2){opacity:0}
.nav__burger.open span:last-child{transform:translateY(-8px) rotate(-45deg)}

/* ===================== Buttons ===================== */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font);font-weight:600;font-size:14px;
  letter-spacing:.01em;padding:15px 30px;border-radius:50px;position:relative;cursor:pointer;border:0;
  transition:transform .35s var(--ease),box-shadow .45s var(--ease),background .4s}
.btn i{font-style:normal;transition:transform .35s var(--ease)}
.btn:hover i{transform:translateX(4px)}
.btn--grad{background:var(--brand-soft);color:#fff;border:1px solid rgba(255,255,255,.14);box-shadow:var(--glass-inset)}
.btn--grad:hover{box-shadow:0 0 32px rgba(168,85,247,.5),0 0 64px rgba(192,38,211,.3),var(--glass-inset);transform:translateY(-2px)}
.btn--glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);color:var(--white);
  border:1px solid var(--glass-bd);box-shadow:var(--glass-inset)}
.btn--glass:hover{background:var(--glass-bg-hi);box-shadow:0 0 30px rgba(168,85,247,.3),var(--glass-inset);transform:translateY(-2px)}
.nav__cta{padding:11px 22px;font-size:13px}

/* ===================== Glass surface ===================== */
.glass{position:relative;background:var(--glass-bg);backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-bd);box-shadow:var(--glass-inset);border-radius:22px;
  transition:transform .5s var(--ease),background .5s,box-shadow .5s}
/* gradient border layer revealed on hover */
.glass--int::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:var(--brand);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .5s var(--ease);pointer-events:none}
.glass--int:hover{--lift:-8;background:var(--glass-bg-hi);
  box-shadow:0 0 30px rgba(168,85,247,.25),0 0 60px rgba(192,38,211,.15),var(--glass-inset)}
.glass--int:hover::after{opacity:1}

/* ===================== Layout / typography ===================== */
section{position:relative;z-index:1}
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{font-family:var(--font);font-size:12px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  color:var(--purple-bright);margin-bottom:22px;display:inline-block}
.h-section{font-size:clamp(44px,8vw,118px);letter-spacing:-.03em;color:var(--white);line-height:.98}
.lede{color:var(--muted);font-size:clamp(16px,1.5vw,20px);max-width:54ch;font-weight:300}
.section-pad{padding:clamp(90px,15vh,180px) 0}

/* ===================== Crown divider ===================== */
.divider{display:flex;align-items:center;justify-content:center;gap:0;margin:30px 0}
.divider .bar{height:2px;width:clamp(40px,9vw,90px)}
.divider .bar.blue{background:var(--li-blue)}
.divider .bar.red{background:var(--li-red)}
.divider .crown{width:30px;height:24px;margin:0 14px;color:var(--gold);flex:none}
.divider.center{justify-content:center}

/* ===================== HERO ===================== */
.hero{min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
#particles{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero .glows .blob{opacity:.55}
.hero__inner{position:relative;z-index:3;padding:0 var(--pad);will-change:transform}
.hero__lockup{position:relative;width:clamp(240px,38vw,440px);margin:0 auto 28px}
.hero__logo{width:100%;height:auto;display:block}
html.gsap .hero__logo{clip-path:inset(0 100% 0 0)}
html:not(.gsap) .hero__logo{animation:heroLogoIn 1.2s var(--ease) both}
@keyframes heroLogoIn{from{opacity:0;clip-path:inset(0 100% 0 0)}to{opacity:1;clip-path:inset(0 0 0 0)}}
.hero__lockup.pulse{animation:logoPulse 1.1s var(--ease)}
@keyframes logoPulse{0%{filter:drop-shadow(0 0 0 rgba(168,85,247,0))}40%{filter:drop-shadow(0 0 30px rgba(168,85,247,.8)) drop-shadow(0 0 60px rgba(192,38,211,.5))}100%{filter:drop-shadow(0 0 14px rgba(168,85,247,.32))}}
.hero__sweep{position:absolute;inset:0;pointer-events:none;opacity:0;
  -webkit-mask:url(../assets/img/logo-white.png) center/contain no-repeat;mask:url(../assets/img/logo-white.png) center/contain no-repeat;
  background:linear-gradient(110deg,transparent 44%,rgba(255,255,255,.95) 49%,rgba(232,121,249,.85) 52%,rgba(168,85,247,.6) 55%,transparent 60%);
  background-size:280% 100%;background-position:180% 0}
.hero__tag{font-size:clamp(16px,2vw,22px);color:var(--white);font-weight:300;margin-top:26px}
.hero__tag span{display:inline-block;opacity:0;transform:translateY(14px);filter:blur(6px)}
.hero__tag span.in{opacity:1;transform:none;filter:none;transition:.7s var(--ease)}
.hero__cta{margin-top:42px;opacity:0;animation:fadeUp 1s var(--ease) 1.4s forwards;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero__scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;color:var(--faint);display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll i{width:1px;height:42px;background:linear-gradient(var(--purple-bright),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;inset:0;height:40%;background:var(--pink);animation:sd 2s var(--ease) infinite}
@keyframes sd{0%{transform:translateY(-100%)}100%{transform:translateY(260%)}}

/* ===================== SECTION 1b — Invest / app showcase ===================== */
.invest{position:relative;height:330vh}
.invest__sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center;
  justify-content:center;gap:clamp(30px,6vw,90px);padding:0 var(--pad);perspective:1400px}
.invest__panels{position:relative;z-index:3;max-width:480px;flex:1}
.invest__panels .eyebrow{margin-bottom:18px}
.invest__panel{position:absolute;top:34px;left:0;right:0;opacity:0;transform:translateY(26px);
  transition:opacity .6s var(--ease),transform .6s var(--ease);pointer-events:none}
.invest__panel.is-active{opacity:1;transform:none;pointer-events:auto;position:relative}
.invest__panel .h-section{font-size:clamp(40px,5.5vw,76px)}
.invest__panel .lede{margin-top:20px}
.invest__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.invest__dots{display:flex;gap:9px;margin-top:30px}
.invest__dots b{width:26px;height:8px;border-radius:5px;background:rgba(255,255,255,.18);
  transform:scaleX(.3);transform-origin:left;transition:background .4s var(--ease)}
.invest__dots b.on{background:var(--brand-soft)}

/* phone mockup */
.phone{position:relative;z-index:3;width:clamp(260px,28vw,330px);aspect-ratio:9/19;border-radius:42px;flex:none;
  background:linear-gradient(160deg,#1a1622,#0a0810);padding:12px;
  box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.06),inset 0 1px 0 rgba(255,255,255,.1),
    0 0 70px rgba(124,58,237,.25);will-change:transform}
.phone::after{content:"";position:absolute;inset:0;border-radius:42px;pointer-events:none;
  background:linear-gradient(140deg,rgba(255,255,255,.14),transparent 35%)}
.phone__notch{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:96px;height:26px;
  background:#05040a;border-radius:14px;z-index:4}
.phone__screen{width:100%;height:100%;border-radius:32px;background:radial-gradient(120% 80% at 50% 0,#16101f,#08060d 60%);
  overflow:hidden;padding:38px 16px 12px;display:flex;flex-direction:column;color:var(--white)}
.pf__top{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--muted)}
.pf__top b{font-family:var(--font);font-weight:600;font-size:15px;color:var(--white);letter-spacing:.02em}
.pf__dot{width:9px;height:9px;border-radius:50%;background:var(--pink)}
.pf__tabs{display:flex;gap:8px;margin:14px 0 10px;background:rgba(255,255,255,.05);border-radius:10px;padding:4px}
.pf__tabs b{flex:1;text-align:center;font-size:11px;padding:6px;border-radius:7px;color:var(--muted);font-weight:500}
.pf__tabs b.on{background:rgba(255,255,255,.1);color:var(--white)}
.pf__ring{position:relative;width:150px;height:150px;margin:10px auto 6px}
.pf__ring svg{width:100%;height:100%}
.pf__track{fill:none;stroke:rgba(255,255,255,.07);stroke-width:9}
.pf__seg{fill:none;stroke-width:9;stroke-linecap:butt;transform:rotate(-90deg);transform-origin:60px 60px;
  stroke-dasharray:0 327;transition:stroke-dasharray 1.1s var(--ease)}
#segBtc{stroke-dashoffset:0}#segEth{stroke-dashoffset:-153.8}#segXrp{stroke-dashoffset:-255}#segSol{stroke-dashoffset:-298}
.invest.in #segBtc{stroke-dasharray:151.8 327;transition-delay:.05s}
.invest.in #segEth{stroke-dasharray:99.3 327;transition-delay:.2s}
.invest.in #segXrp{stroke-dasharray:40.5 327;transition-delay:.35s}
.invest.in #segSol{stroke-dasharray:24.1 327;transition-delay:.5s}
.pf__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.pf__center span{font-size:10px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase}
.pf__total{font-family:var(--font);font-weight:700;font-size:19px;margin-top:3px;font-variant-numeric:tabular-nums}
.pf__meta{display:flex;gap:8px;margin:8px 0 12px}
.pf__meta div{flex:1;background:rgba(255,255,255,.04);border:1px solid var(--glass-bd);border-radius:11px;padding:9px 11px}
.pf__meta span{font-size:9px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;display:block}
.pf__meta b{font-size:13px;font-weight:600}
.pf__profit{color:#34D399}
.pf__list{list-style:none;display:flex;flex-direction:column;gap:9px;flex:1;overflow:hidden}
.pf__list li{display:flex;align-items:center;gap:10px}
.pf__list i{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-style:normal;
  color:#0a0a0a;font-weight:700;flex:none}
.pf__list li>div{display:flex;flex-direction:column}
.pf__list b{font-size:12.5px;font-weight:600}
.pf__list span{font-size:10px;color:var(--faint)}
.pf__r{margin-left:auto;text-align:right}
.pf__r .up{color:#34D399}.pf__r .down{color:#ff7a8a}
.pf__nav{display:flex;justify-content:space-between;padding:10px 6px 2px;margin-top:8px;border-top:1px solid var(--glass-bd)}
.pf__nav b{font-size:10px;color:var(--faint);font-weight:500}
.pf__nav b.on{color:var(--purple-bright)}
/* portfolio comes alive when the section enters (after the donut draws) */
.pf__meta div,.pf__list li{opacity:0;transform:translateY(10px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.invest.in .pf__meta div,.invest.in .pf__list li{opacity:1;transform:none}
.invest.in .pf__meta div{transition-delay:.35s}
.invest.in .pf__list li:nth-child(1){transition-delay:.55s}
.invest.in .pf__list li:nth-child(2){transition-delay:.67s}
.invest.in .pf__list li:nth-child(3){transition-delay:.79s}
.invest.in .pf__list li:nth-child(4){transition-delay:.91s}
@media (max-width:860px){
  /* mobile: no pin/crossfade — phone then feature blocks flow vertically */
  .invest{height:auto}
  .invest__sticky{position:static;height:auto;flex-direction:column;gap:34px;text-align:center;
    padding:clamp(70px,12vh,110px) var(--pad)}
  .phone{width:clamp(196px,58vw,240px)}
  .invest__panels{max-width:560px;width:100%}
  .invest__panel{position:relative!important;opacity:1!important;transform:none!important;
    pointer-events:auto!important;margin-bottom:36px}
  .invest__panel .h-section{font-size:clamp(30px,8vw,46px)}
  .invest__panel .lede{margin-left:auto;margin-right:auto}
  .invest__cta{justify-content:center}
  .invest__dots{display:none}
  .invest__panels .eyebrow{margin-bottom:10px}
}

/* ===================== SECTION 2 — 3D cards (sticky scroll) ===================== */
.cards{position:relative;height:320vh}
.cards__sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:flex-start;will-change:transform}
#cardsCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
/* GPU-promote the layers that transform/scrub continuously → smooth 60fps */
.cards__copy{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%;
  padding:clamp(96px,15vh,150px) var(--pad) 0;pointer-events:none}
.cards__copy::before,.globe__copy::before{content:"";position:absolute;z-index:-1;pointer-events:none;
  inset:-14% -26% -14% -34%;
  background:radial-gradient(115% 80% at 32% 42%,rgba(8,8,10,.74),rgba(8,8,10,.3) 55%,transparent 74%)}
.cards__copy .h-section{max-width:14ch}
.cards__copy .lede{margin-top:20px}
.cards__legend{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:26px;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cards__legend b{display:inline-flex;align-items:center;gap:8px;font-weight:500}
.cards__legend i{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ===================== SECTION 2b — Tiers / perks ===================== */
.tiers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px;align-items:stretch}
.tier{padding:38px 32px 32px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.tier__flag{position:absolute;top:16px;right:-38px;transform:rotate(45deg);background:var(--brand-soft);
  color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 42px;
  box-shadow:0 4px 18px rgba(168,85,247,.4);z-index:2}
.tier--black{padding-top:54px}
.tier__head{display:flex;align-items:center;gap:16px;padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid var(--glass-bd)}
.tier__chip{width:54px;height:38px;border-radius:9px;flex:none;position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 4px 14px rgba(0,0,0,.4)}
.tier__chip::after{content:"";position:absolute;inset:0;background:
  linear-gradient(115deg,transparent 30%,rgba(255,255,255,.5) 50%,transparent 70%);
  transform:translateX(calc(-120% + 240% * var(--shine,0)));transition:transform .7s var(--ease)}
.tier:hover .tier__chip::after{transform:translateX(120%)}
.tier__name{font-family:var(--font);font-weight:700;font-size:28px;letter-spacing:-.01em;line-height:1}
.tier__tag{color:var(--muted);font-size:13.5px;font-weight:300;margin-top:5px}
.tier__perks{list-style:none;display:flex;flex-direction:column;gap:15px;margin-bottom:30px;flex:1}
.tier__perks li{display:flex;align-items:flex-start;gap:12px;font-size:15.5px;color:var(--white);font-weight:300}
.tier__perks em{font-style:normal;color:var(--faint);font-size:13px}
.tick{width:20px;height:20px;flex:none;border-radius:50%;margin-top:2px;position:relative;
  background:rgba(168,85,247,.14);border:1px solid rgba(168,85,247,.4)}
.tick::after{content:"";position:absolute;left:6px;top:3px;width:5px;height:9px;
  border:solid var(--purple-bright);border-width:0 2px 2px 0;transform:rotate(45deg)}
.tier__cta{margin-top:auto;width:100%;justify-content:center}
/* tier accents */
.tier--silver .tier__chip{background:linear-gradient(135deg,#eceef3,#a9adba 55%,#cfd2db)}
.tier--gold .tier__chip{background:linear-gradient(135deg,#f7e08a,#c9a227 55%,#e9c95f)}
.tier--black .tier__chip{background:linear-gradient(135deg,#A855F7,#3a1064 55%,#C026D3)}
.tier--gold .tick{background:rgba(232,121,249,.14);border-color:rgba(232,121,249,.45)}
.tier--gold .tick::after{border-color:var(--pink)}
.tier--black{background:linear-gradient(180deg,rgba(168,85,247,.10),var(--glass-bg) 40%)}
.tier--black::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:var(--brand);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.6;pointer-events:none}
.tier--black .tick{background:rgba(232,121,249,.18);border-color:rgba(232,121,249,.55)}
.tier--black .tick::after{border-color:var(--pink)}
.tiers__note{text-align:center;margin-top:40px;color:var(--muted);font-size:15px}
.tiers__note a{background:var(--brand-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ===================== Strategy & Vision ===================== */
.ethos__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);margin-top:60px}
.ethos__col{position:relative;padding-top:28px;border-top:1px solid var(--glass-bd)}
.ethos__no{font-family:var(--font);font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--purple-bright);display:block;margin-bottom:18px}
.ethos__col p{color:var(--muted);font-size:clamp(16px,1.5vw,20px);font-weight:300;line-height:1.7}
.ethos__pills{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:48px}
.ethos__pills li{font-size:13px;letter-spacing:.03em;color:var(--muted);border:1px solid var(--glass-bd);
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);padding:8px 16px;border-radius:50px;transition:.3s var(--ease)}
.ethos__pills li:hover{color:var(--white);box-shadow:0 0 20px rgba(168,85,247,.25);border-color:rgba(168,85,247,.4)}
@media (max-width:760px){ .ethos__grid{grid-template-columns:1fr;gap:32px} }

/* ===================== SECTION 3 — Globe ===================== */
.globe{position:relative;height:280vh}
.globe__sticky{position:sticky;top:0;height:100svh;display:flex;align-items:center;overflow:hidden;will-change:transform}
#globeCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.globe__copy{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 var(--pad)}
.globe__copy .lede{margin-top:20px}
.globe__cities{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;max-width:560px}
.globe__cities span{font-size:12.5px;letter-spacing:.04em;color:var(--muted);border:1px solid var(--glass-bd);
  background:var(--glass-bg);backdrop-filter:var(--glass-blur);padding:7px 15px;border-radius:50px;transition:.3s var(--ease)}
.globe__cities span:hover{color:var(--white);box-shadow:0 0 20px rgba(168,85,247,.25)}

/* ===================== SECTION 4 — Services ===================== */
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.svc{padding:40px 34px;min-height:300px;display:flex;flex-direction:column}
.svc__icon{width:64px;height:64px;border-radius:16px;display:grid;place-items:center;margin-bottom:28px;
  background:rgba(168,85,247,.08);border:1px solid var(--glass-bd);transition:.5s var(--ease)}
.svc__icon svg{width:30px;height:30px;stroke:var(--purple-bright);fill:none;stroke-width:1.6;transition:.5s var(--ease)}
.svc:hover .svc__icon{box-shadow:0 0 24px rgba(168,85,247,.4),0 0 48px rgba(192,38,211,.2);background:rgba(192,38,211,.12)}
.svc:hover .svc__icon svg{stroke:var(--pink);filter:drop-shadow(0 0 6px rgba(232,121,249,.7))}
.svc h3{font-size:24px;margin-bottom:12px}
.svc p{color:var(--muted);font-size:15px;font-weight:300;margin-top:auto}

/* ===================== SECTION 5 — Stats ===================== */
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:70px}
.stat__num{font-family:var(--font);font-weight:800;font-size:clamp(48px,7vw,96px);color:var(--white);line-height:1;letter-spacing:-.03em}
.stat__line{height:3px;width:64px;background:var(--brand-soft);border-radius:3px;margin:18px 0 16px;
  transform:scaleX(0);transform-origin:left;box-shadow:0 0 14px rgba(168,85,247,.5)}
.stat__label{color:var(--muted);font-size:14px;letter-spacing:.04em}

/* ===================== SECTION 6 — Contact ===================== */
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,90px);align-items:center;margin-top:30px}
.contact h2{font-size:clamp(56px,9vw,120px)}
.contact__intro .lede{margin-top:24px}
.contact__meta{list-style:none;margin-top:40px;display:flex;flex-direction:column;gap:18px}
.contact__meta li{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--glass-bd);padding-top:14px}
.contact__meta span{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint)}
.contact__meta a:hover{color:var(--pink)}
.form{padding:clamp(28px,3.5vw,46px)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{position:relative;margin-bottom:20px}
.field input,.field select,.field textarea{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--glass-bd);
  border-radius:14px;color:var(--white);font-family:var(--font-body);font-size:15px;padding:18px 16px 16px;outline:none;
  transition:box-shadow .35s,border-color .35s,background .35s;resize:none}
.field textarea{min-height:120px}
.field select option{background:#140b22;color:var(--white)}
.field label{position:absolute;left:16px;top:17px;color:var(--faint);font-size:15px;pointer-events:none;transition:.3s var(--ease)}
.field.static label,.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label,
.field select:focus+label,.field select:valid+label{
  top:-9px;left:12px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  background:#0c0712;padding:0 6px;color:var(--purple-bright)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:transparent;
  background:rgba(255,255,255,.05);box-shadow:0 0 0 1px rgba(168,85,247,.6),0 0 20px rgba(168,85,247,.2)}
.form__note{margin-top:14px;min-height:22px;font-size:14px;color:var(--pink);text-align:center}
.form__note.err{color:#ff8080}
.form__check{width:74px;height:74px;margin:6px auto 14px;display:none}
.form__check path{stroke:url(#brandGrad);stroke-width:7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.form.sent .form__check{display:block}
.form.sent .form__row,.form.sent .field--msg,.form.sent .form__submit{display:none}

/* ===================== Footer ===================== */
.footer{position:relative;padding:clamp(70px,10vh,120px) 0 40px;overflow:hidden}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:160px;
  background:linear-gradient(180deg,rgba(124,58,237,.16),rgba(192,38,211,.06) 40%,transparent);pointer-events:none}
.footer__top{display:flex;justify-content:space-between;gap:50px;flex-wrap:wrap;align-items:flex-start;position:relative;z-index:2}
.footer__logo{width:64px;height:64px;margin-bottom:18px;object-fit:contain}
.footer__logo path{stroke:url(#brandGrad);stroke-width:6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.footer__word{font-family:var(--font);font-weight:800;font-size:clamp(40px,7vw,86px);letter-spacing:.02em;line-height:.9}
.footer__word em{font-style:normal;display:block;font-size:12px;letter-spacing:.4em;color:var(--muted);margin-top:12px}
.footer__nav{display:flex;flex-direction:column;gap:12px;text-align:right}
.footer__nav a{color:var(--muted);font-size:14px}
.footer__nav a:hover{color:var(--pink)}
.footer__base{position:relative;z-index:2;margin-top:50px;padding-top:24px;border-top:1px solid var(--glass-bd);
  display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:12.5px;color:var(--faint);letter-spacing:.03em}

/* ===================== Reveal ===================== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-stagger]{transition-delay:var(--d,0ms)}

/* ===================== Motion enhancements ===================== */
/* GSAP owns entrances when active; never leave anything permanently hidden */
html.gsap .reveal{opacity:1;transform:none;transition:none}

/* scroll entrances for .svc/.tier/.ethos__col/.stat are GSAP scrub animations (js/main.js).
   Cards animate the --ey/--es vars (below) so the entrance composes with the hover tilt. */

/* kinetic type */
.kt-word{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.08em}
/* no permanent will-change here: 100+ chars each pinning a GPU layer wastes memory;
   GSAP promotes the few that are mid-scrub on the fly (force3D). */
.kt-char{display:inline-block}

/* glass tilt + cursor-tracked glare */
.glass--int,.tier[data-tilt]{transform:perspective(1100px) rotateX(calc((var(--ry,0) + var(--erx,0)) * 1deg)) rotateY(calc(var(--rx,0) * 1deg))
  translateY(calc((var(--lift,0) + var(--ey,0)) * 1px)) scale(var(--es,1));
  transform-style:preserve-3d;transition:background .5s,box-shadow .5s}
.glass--int::before,.tier[data-tilt]::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  opacity:0;transition:opacity .4s var(--ease);mix-blend-mode:soft-light;z-index:0;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.55),transparent 62%)}
.glass--int:hover::before,.tier[data-tilt]:hover::before{opacity:.55}

/* nav underline + auto-hide */
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1.5px;
  background:var(--brand-soft);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.nav__links a:not(.nav__cta):hover::after,.nav__links a.active::after{transform:scaleX(1);transform-origin:left}
.nav.hidden{transform:translateY(-115%)}

/* footer + contact link underlines */
.footer__nav a,.contact__meta a{position:relative}
.footer__nav a::after,.contact__meta a::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;
  background:var(--brand-soft);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.footer__nav a:hover::after,.contact__meta a:hover::after{transform:scaleX(1);transform-origin:left}

/* gradient-button sheen sweep on hover */
.btn--grad::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.55) 50%,transparent 62%);
  background-size:250% 100%;background-position:210% 0;transition:background-position .8s var(--ease);mix-blend-mode:overlay}
.btn--grad:hover::before{background-position:-120% 0}
.btn .ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.45);transform:translate(-50%,-50%);
  pointer-events:none;mix-blend-mode:overlay}

/* hero scroll cue fades with scrub (set inline by GSAP) */

/* ===================== Tablet / iPad (<=1024) ===================== */
@media (max-width:1024px){
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:34px}
  .contact__grid{grid-template-columns:1fr;gap:44px}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  /* tiers: 2-up with Black spanning full width so 5 perks + flag breathe */
  .tiers__grid{grid-template-columns:repeat(2,1fr)}
  .tier--black{grid-column:1 / -1}
  .tier{padding:30px 26px 26px}
  .globe__copy .lede,.globe__cities{max-width:46ch}
}
/* overlay nav for iPad + phones (so links aren't cramped) */
@media (max-width:900px){
  /* nav bar must not create a containing block (filter/transform) or it re-bases the fixed overlay */
  .nav.scrolled{backdrop-filter:none;background:rgba(8,8,10,.92)}
  .nav__links{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:30px;
    background:rgba(8,8,10,.97);backdrop-filter:blur(24px);transform:translateY(-100%);
    transition:transform .55s var(--ease);z-index:1000}
  .nav__links.open{transform:none}
  .nav__links a{font-size:26px;font-family:var(--font);font-weight:600}
  .nav__links .glows{display:block}
  .nav__burger{display:flex;padding:12px;min-width:44px;min-height:44px;align-items:center;justify-content:center}
  .nav__cta{font-size:18px;padding:14px 34px}
}
/* ===================== Phones (<=600) ===================== */
@media (max-width:600px){
  .services__grid{grid-template-columns:1fr}
  .tiers__grid{grid-template-columns:1fr}
  .tier--black{grid-column:auto}
  .form__row{grid-template-columns:1fr}
  .field input,.field select,.field textarea{font-size:16px}   /* no iOS zoom */
  .section-pad{padding:clamp(56px,9vh,90px) 0}
  .services__grid,.stats__grid{margin-top:40px}
  .tiers__grid{margin-top:36px}
  .cards{height:240vh}
  .cards__copy .h-section{font-size:clamp(34px,9vw,52px)}
  .globe__copy .h-section{font-size:clamp(34px,9vw,52px)}
  .globe__sticky{align-items:flex-start;padding-top:13vh}
  .cards__legend{gap:12px;font-size:9px;flex-wrap:wrap;justify-content:center;width:92%;bottom:max(16px,env(safe-area-inset-bottom))}
  .hero__lockup{width:min(80vw,320px)}
  .footer__top{flex-direction:column}
  .footer__nav{text-align:left}
  .nav__cta{font-size:16px;padding:12px 30px}
}
@media (max-width:600px) and (max-height:680px){ .cards__legend{display:none} }

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
  body{animation:none}
  .hero__cta{opacity:1;animation:none}
  .kt-char,.kt-word{transform:none!important}
  .hero__logo{clip-path:none!important;animation:none}
  .glass--int,.tier[data-tilt]{transform:none!important}
  .scrollbeam span{transform:scaleX(1)}
  /* reduced motion → drop ALL pinning/scrubbing so no section becomes empty pinned scroll */
  .cards{height:auto}
  .cards__sticky{position:static;height:auto;min-height:60vh}
  .globe{height:auto}
  .globe__sticky{position:static;min-height:100svh}
  .invest{height:auto}
  .invest__sticky{position:static;height:auto;flex-direction:column;gap:34px}
  .invest__panel{position:relative;opacity:1;transform:none;pointer-events:auto}
  .invest__dots{display:none}
  /* elements whose BASE state is "hidden" and rely on a scrub that never runs under reduced motion */
  .stat__line{transform:scaleX(1)}
  #tiers .tier{--ey:0;--es:1;--erx:0;opacity:1}
  .globe__copy .h-section,.globe__copy .lede,.cards__copy{opacity:1;transform:none;filter:none}
  .globe__cities span,.tier__perks li,.ethos__pills li,.svc,.svc__icon{opacity:1;transform:none;filter:none}
  #tiers .tier,.svc{--ey:0;--es:1}
}
