/* =====================================================================
   NÜFLVR — Event Growth Infrastructure
   Design system · "Direction 3" — premium, holographic, dark
   ---------------------------------------------------------------------
   1.  Tokens
   2.  Reset & base
   3.  Typography helpers
   4.  Ambient background (grid · grain · orbs · cursor glow · curtain)
   5.  Layout (container · sections · grids)
   6.  Navigation + mobile menu
   7.  Buttons
   8.  Core components (glass · metric · chip · icon · tag · marquee)
   9.  Hero
   10. Dashboard mock UI + charts
   11. Section patterns (eyebrow · statement · pillars · steps)
   12. Forms
   13. CTA band + footer
   14. Reveal / motion
   15. Responsive
   ===================================================================== */

/* 1. TOKENS ----------------------------------------------------------- */
:root{
  /* Base */
  --black:#0A0A0A;
  --soft-black:#1A1A1F;
  --charcoal:#111217;
  --graphite:#181A20;
  --off-white:#EFEFF2;
  --muted:#9A9AA3;
  --line:rgba(255,255,255,.08);
  --line-soft:rgba(255,255,255,.05);

  /* Accents */
  --violet:#A7BBFA;
  --mint:#00F0D1;
  --pink:#FF4DFF;
  --yellow:#FFEA00;
  --cyan:#67E7FF;
  --lime:#D7FF43;
  --pos:#5BE3A7;
  --neg:#FF6B8B;

  /* Signature holographic gradient */
  --holo:linear-gradient(100deg,#A7BBFA 0%,#67E7FF 26%,#00F0D1 50%,#FFEA00 74%,#FF4DFF 100%);
  --holo-soft:linear-gradient(120deg,rgba(167,187,250,.85),rgba(0,240,209,.7),rgba(255,77,255,.75));

  /* Glass */
  --glass:rgba(255,255,255,.035);
  --glass-2:rgba(255,255,255,.06);
  --glass-brd:rgba(255,255,255,.09);

  /* Type */
  --f-display:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --f-body:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --f-serif:"Bodoni Moda",Georgia,"Times New Roman",serif;

  /* Rhythm */
  --container:1240px;
  --gutter:clamp(20px,5vw,40px);
  --radius:20px;
  --radius-sm:12px;
  --radius-lg:28px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  /* cursor glow position (updated by JS) */
  --mx:50vw; --my:50vh;
}

/* 2. RESET & BASE ---------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--f-body);
  background:var(--black);
  color:var(--off-white);
  line-height:1.6;
  font-weight:400;
  overflow-x:hidden;
  position:relative;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--yellow);color:var(--black)}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:#26262e;border-radius:10px;border:2px solid var(--black)}
::-webkit-scrollbar-thumb:hover{background:#34343e}

/* 3. TYPOGRAPHY ------------------------------------------------------ */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:600;line-height:1.02;letter-spacing:-.02em}
.display-1{font-size:clamp(2.6rem,7.4vw,6.6rem);text-transform:uppercase;letter-spacing:-.03em;line-height:.94}
.display-2{font-size:clamp(2.1rem,5vw,4.2rem);line-height:.98}
.display-3{font-size:clamp(1.6rem,3vw,2.6rem)}
p{max-width:62ch}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:#c9c9d2;font-weight:350}
.muted{color:var(--muted)}
strong{font-weight:600;color:#fff}

/* Gradient (holographic) text */
.holo-text{
  background:var(--holo);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  background-size:160% 160%;
  animation:holoShift 9s ease infinite;
}
@keyframes holoShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* 4. AMBIENT BACKGROUND --------------------------------------------- */
.bg-layer{position:fixed;inset:0;pointer-events:none;z-index:0}
.bg-grid{
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 78%);
  mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 78%);
  opacity:.6;
}
.bg-grain{
  opacity:.4;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}
.orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;mix-blend-mode:screen;will-change:transform}
.orb--1{width:46vw;height:46vw;top:-12vw;left:-8vw;background:radial-gradient(circle,#A7BBFA,transparent 65%);animation:float1 22s var(--ease) infinite}
.orb--2{width:40vw;height:40vw;top:24vh;right:-12vw;background:radial-gradient(circle,#FF4DFF,transparent 62%);opacity:.32;animation:float2 26s var(--ease) infinite}
.orb--3{width:36vw;height:36vw;bottom:-14vw;left:30vw;background:radial-gradient(circle,#00F0D1,transparent 60%);opacity:.28;animation:float3 30s var(--ease) infinite}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(6vw,5vh)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-5vw,4vh)}}
@keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(4vw,-6vh)}}

.cursor-glow{
  position:fixed;left:0;top:0;width:520px;height:520px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(103,231,255,.10),rgba(167,187,250,.05) 40%,transparent 70%);
  pointer-events:none;z-index:1;
  left:var(--mx);top:var(--my);
  transition:opacity .4s;opacity:0;
}
body.has-pointer .cursor-glow{opacity:1}

.page-curtain{
  position:fixed;inset:0;z-index:9999;background:var(--black);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .7s var(--ease),visibility .7s;
}
.page-curtain::before,.page-curtain::after{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:clamp(124px,42vw,176px);aspect-ratio:2150 / 724;
  -webkit-mask:url(/assets/img/nuflvr-white.png) center/contain no-repeat;
          mask:url(/assets/img/nuflvr-white.png) center/contain no-repeat;
}
.page-curtain::before{background:rgba(255,255,255,.12)}            /* dim logo outline */
.page-curtain::after{background:var(--holo);animation:loaderFill 1.5s cubic-bezier(.45,0,.15,1) infinite} /* holo fills up */
@keyframes loaderFill{
  0%{clip-path:inset(100% 0 0 0);opacity:.85}
  55%{clip-path:inset(0 0 0 0);opacity:1}
  80%{clip-path:inset(0 0 0 0);opacity:1}
  100%{clip-path:inset(0 0 0 0);opacity:0}
}
body.loaded .page-curtain{opacity:0;visibility:hidden}

/* 5. LAYOUT ---------------------------------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.site-main{position:relative;z-index:2}
section{position:relative;z-index:2}
.section{padding-block:clamp(70px,10vw,140px)}
.section--tight{padding-block:clamp(48px,6vw,84px)}
.grid{display:grid;gap:24px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
.center{text-align:center;margin-inline:auto}
.center p{margin-inline:auto}
.stack-sm>*+*{margin-top:14px}
.mw-720{max-width:720px}
.mw-560{max-width:560px}

/* 6. NAVIGATION ------------------------------------------------------ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:transform .4s var(--ease),background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.site-nav.scrolled{background:rgba(10,10,10,.72);backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);border-bottom-color:var(--line)}
.site-nav.nav-hidden{transform:translateY(-100%)}
.nav-inner{max-width:1340px;margin-inline:auto;padding:16px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px}

.brand{display:inline-flex;align-items:flex-start;line-height:1;flex-shrink:0}
.brand-mark{font-family:var(--f-serif);font-size:1.72rem;font-weight:500;letter-spacing:.005em;color:var(--off-white);transition:color .3s}
.brand:hover .brand-mark{background:var(--holo);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand-tm{font-family:var(--f-display);font-size:.62rem;color:var(--muted);margin-top:.2em;margin-left:2px}
.brand-logo{height:25px;width:auto;max-width:none;flex:none;display:block}

.nav-links{display:flex;align-items:center;gap:6px}
.nav-link{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;font-size:.86rem;color:#c4c4ce;font-weight:500;letter-spacing:.01em;transition:color .25s,background .25s}
.nav-link:hover{color:#fff}
.nav-link.active{color:#fff}
.nav-link.active::after{content:"";position:absolute;left:14px;right:14px;bottom:2px;height:1.5px;background:var(--holo);border-radius:2px}
.chev{transition:transform .3s var(--ease);opacity:.7}

/* dropdown */
.nav-group{position:relative}
.nav-group.open .chev,.nav-group:hover .chev{transform:rotate(180deg)}
.nav-group.active>.nav-group-toggle{color:#fff}
.nav-dropdown{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  width:300px;padding:8px;background:rgba(17,18,23,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line);border-radius:18px;display:grid;gap:2px;
  opacity:0;visibility:hidden;transition:all .3s var(--ease);box-shadow:0 30px 60px -20px rgba(0,0,0,.7)
}
.nav-group:hover .nav-dropdown,.nav-group.open .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:flex;flex-direction:column;gap:1px;padding:11px 14px;border-radius:12px;transition:background .2s}
.nav-dropdown a span{font-family:var(--f-display);font-size:.92rem;font-weight:500}
.nav-dropdown a small{color:var(--muted);font-size:.74rem}
.nav-dropdown a:hover{background:var(--glass-2)}
.nav-dropdown-all{margin-top:4px;border-top:1px solid var(--line-soft)}
.nav-dropdown-all span{background:var(--holo);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

.nav-actions{display:flex;align-items:center;gap:14px}
.nav-burger{display:none;width:42px;height:42px;border-radius:12px;border:1px solid var(--line);flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-burger span{width:18px;height:1.5px;background:var(--off-white);transition:.3s var(--ease)}
.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile overlay */
.mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(10,10,10,.96);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s;display:flex;align-items:center}
.mobile-menu.open{opacity:1;visibility:visible}
.mobile-menu-inner{display:flex;flex-direction:column;gap:4px;padding:0 var(--gutter);width:100%}
.mobile-menu-inner a{font-family:var(--f-display);font-size:1.6rem;font-weight:500;padding:8px 0;transform:translateY(14px);opacity:0;transition:.5s var(--ease)}
.mobile-menu.open .mobile-menu-inner a{transform:none;opacity:1}
.mobile-menu-inner a:nth-child(n){transition-delay:calc(var(--i,0) * 40ms)}
.mobile-label{font-family:var(--f-body);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-top:18px;margin-bottom:2px}
.mobile-cta{margin-top:24px;color:var(--yellow)!important}

/* 7. BUTTONS --------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-family:var(--f-display);font-weight:500;font-size:.92rem;letter-spacing:.01em;
  position:relative;transition:transform .3s var(--ease),background .3s,color .3s,border-color .3s,box-shadow .3s;
  white-space:nowrap;will-change:transform
}
.btn--sm{padding:10px 18px;font-size:.84rem}
.btn-arrow{transition:transform .3s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}
.btn--primary{border:1.5px solid var(--yellow);color:var(--yellow);background:transparent}
.btn--primary:hover{background:var(--yellow);color:var(--black);box-shadow:0 0 0 1px var(--yellow),0 14px 40px -10px rgba(255,234,0,.5)}
.btn--solid{background:var(--yellow);color:var(--black)}
.btn--solid:hover{box-shadow:0 14px 40px -10px rgba(255,234,0,.55);transform:translateY(-2px)}
.btn--ghost{border:1px solid var(--line);color:var(--off-white);background:var(--glass)}
.btn--ghost:hover{border-color:rgba(255,255,255,.32);background:var(--glass-2)}
.btn--holo{border:1px solid transparent;color:#fff;background:linear-gradient(var(--charcoal),var(--charcoal)) padding-box,var(--holo) border-box}
.btn--holo:hover{box-shadow:0 14px 44px -14px rgba(103,231,255,.5);transform:translateY(-2px)}

/* 8. CORE COMPONENTS ------------------------------------------------- */
.glass{
  background:var(--glass);
  border:1px solid var(--glass-brd);
  border-radius:var(--radius);
  backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);
  position:relative;overflow:hidden;
}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(160deg,rgba(255,255,255,.18),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* interactive card */
.card{padding:28px;display:flex;flex-direction:column;gap:14px;transition:transform .4s var(--ease),border-color .4s,background .4s}
.card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.2)}
.card .card-glow{position:absolute;inset:0;opacity:0;transition:opacity .45s;background:radial-gradient(420px circle at var(--cx,50%) var(--cy,0%),rgba(103,231,255,.14),transparent 60%);pointer-events:none}
.card:hover .card-glow{opacity:1}
.card-index{font-family:var(--f-display);font-size:.8rem;color:var(--muted);letter-spacing:.1em}
.card h3{font-size:1.32rem}
.card p{color:#b9b9c4;font-size:.96rem}
.card-link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-family:var(--f-display);font-size:.86rem;color:var(--off-white);width:fit-content}
.card-link .btn-arrow{color:var(--mint)}
.card-link:hover{color:#fff}

/* icon tile (thin-line) */
.icon-tile{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;border:1px solid var(--line);background:var(--glass);flex-shrink:0}
.icon-tile svg{width:24px;height:24px;stroke:var(--off-white);fill:none;stroke-width:1.3}
.icon-tile--holo{border-color:transparent;background:linear-gradient(var(--charcoal),var(--charcoal)) padding-box,var(--holo-soft) border-box}

/* chips / tags */
.chip{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;border:1px solid var(--line);background:var(--glass);font-size:.76rem;letter-spacing:.04em;color:#cfcfd8}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--holo)}
.chip--holo{border:1px solid transparent;background:linear-gradient(var(--soft-black),var(--soft-black)) padding-box,var(--holo) border-box}
.tag{font-family:var(--f-display);font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.delta{font-family:var(--f-display);font-size:.8rem;font-weight:500;padding:3px 9px;border-radius:999px;white-space:nowrap}
.delta.pos{color:var(--pos);background:rgba(91,227,167,.12)}
.delta.neg{color:var(--neg);background:rgba(255,107,139,.12)}

/* stat row */
.stat-row{display:flex;flex-wrap:wrap;gap:clamp(20px,4vw,56px)}
.stat .stat-num{font-family:var(--f-display);font-size:clamp(2rem,4vw,3.1rem);font-weight:600;line-height:1;letter-spacing:-.02em}
.stat .stat-label{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* divider */
.hr{height:1px;background:var(--line);border:0;margin-block:clamp(40px,6vw,80px)}

/* marquee */
.marquee{overflow:hidden;border-block:1px solid var(--line);padding-block:18px;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:54px;width:max-content;animation:scrollX 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{font-family:var(--f-display);font-size:1.05rem;color:#8d8d97;display:inline-flex;align-items:center;gap:54px;letter-spacing:.02em}
.marquee-item::after{content:"✦";color:var(--mint);font-size:.7rem}
@keyframes scrollX{to{transform:translateX(-50%)}}

/* 9. HERO ------------------------------------------------------------ */
.hero{position:relative;padding-top:clamp(130px,17vh,200px);padding-bottom:clamp(60px,8vw,110px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,4vw,60px);align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:26px}
.hero h1{margin-bottom:24px}
.hero-sub{font-size:clamp(1.02rem,1.5vw,1.22rem);color:#c4c4ce;max-width:33ch;font-weight:350;margin-bottom:34px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.hero-pillars{display:flex;flex-wrap:wrap;gap:10px}
.hero-pillar{font-family:var(--f-display);font-size:.78rem;letter-spacing:.02em;color:#b4b4be;padding:7px 13px;border:1px solid var(--line);border-radius:999px;background:var(--glass);transition:.3s var(--ease)}
.hero-pillar:hover{color:#fff;border-color:rgba(255,255,255,.25);transform:translateY(-2px)}

/* uppercase holographic hero wordmark utility */
.wordmark-holo{font-family:var(--f-display);text-transform:uppercase;font-weight:700;letter-spacing:-.02em;background:var(--holo);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;background-size:170% 170%;animation:holoShift 8s ease infinite}

/* 10. DASHBOARD MOCK ------------------------------------------------- */
.dash{padding:18px;border-radius:var(--radius-lg);display:grid;grid-template-columns:148px 1fr;gap:14px;min-height:380px}
.dash--solo{grid-template-columns:1fr}
.dash-side{display:flex;flex-direction:column;gap:3px;padding-right:6px;border-right:1px solid var(--line-soft)}
.dash-brand{font-family:var(--f-serif);font-size:1.15rem;padding:6px 10px 14px}
.dash-side a,.dash-nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:10px;font-size:.8rem;color:#9696a0;transition:.2s}
.dash-nav-item.active{background:var(--glass-2);color:#fff}
.dash-nav-item .nd{width:5px;height:5px;border-radius:50%;background:#3a3a44}
.dash-nav-item.active .nd{background:var(--mint)}
.dash-main{display:flex;flex-direction:column;gap:14px;min-width:0}
.dash-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.dash-title{font-family:var(--f-display);font-size:.96rem}
.dash-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.dash-metrics.three{grid-template-columns:repeat(3,1fr)}
.metric{padding:14px;border-radius:14px;background:rgba(255,255,255,.025);border:1px solid var(--line-soft);min-width:0}
.metric-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.metric-value{font-family:var(--f-display);font-size:clamp(1.2rem,2.4vw,1.7rem);font-weight:600;margin-top:6px;letter-spacing:-.02em;line-height:1}
.metric-foot{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.72rem;color:var(--muted)}

/* event list */
.evt{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 12px;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--line-soft)}
.evt+.evt{margin-top:8px}
.evt-l{display:flex;align-items:center;gap:11px;min-width:0}
.evt-av{width:30px;height:30px;border-radius:8px;background:var(--holo-soft);flex-shrink:0;opacity:.85}
.evt-name{font-size:.84rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.evt-sub{font-size:.72rem;color:var(--muted)}
.evt-r{text-align:right;flex-shrink:0}

/* progress ring */
.ring{--p:0;width:64px;height:64px;display:grid;place-items:center;position:relative}
.ring svg{transform:rotate(-90deg)}
.ring-val{position:absolute;font-family:var(--f-display);font-size:.82rem;font-weight:600}

/* bar mini */
.bars{display:flex;align-items:flex-end;gap:6px;height:90px}
.bars .bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--violet),rgba(167,187,250,.15));height:0;transition:height 1.1s var(--ease-out)}
.bars .bar:nth-child(3n+2){background:linear-gradient(180deg,var(--mint),rgba(0,240,209,.12))}
.bars .bar:nth-child(3n){background:linear-gradient(180deg,var(--pink),rgba(255,77,255,.12))}

/* progress line (pacing) */
.pace{display:flex;flex-direction:column;gap:7px}
.pace-bar{height:8px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}
.pace-bar i{display:block;height:100%;width:0;border-radius:999px;background:var(--holo);transition:width 1.2s var(--ease-out)}
.pace-row{display:flex;align-items:center;justify-content:space-between;font-size:.78rem}
.pace-city{display:flex;align-items:center;gap:8px;color:#cfcfd8}

/* spark / line chart container */
.chart{width:100%;height:120px;display:block}
.chart .area{fill:url(#areaFill)}
.chart .line{fill:none;stroke:url(#lineStroke);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* 11. SECTION PATTERNS ---------------------------------------------- */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-display);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--holo)}
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,60px)}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{margin-bottom:18px}
.section-head p{color:#b6b6c0}

/* statement band */
.statement{padding-block:clamp(64px,9vw,120px);text-align:center}
.statement h2{font-size:clamp(1.9rem,5vw,4rem);line-height:1.02;max-width:18ch;margin-inline:auto}
.statement .sub{margin-top:22px;color:var(--muted)}

/* pillars (icon list) */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.pillar{display:flex;gap:16px;padding:22px;border-radius:var(--radius);border:1px solid var(--line);background:var(--glass);transition:.4s var(--ease)}
.pillar:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2)}
.pillar h4{font-family:var(--f-display);font-size:1.02rem;margin-bottom:5px}
.pillar p{font-size:.86rem;color:var(--muted)}

/* numbered steps */
.steps{display:grid;gap:2px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.step{display:grid;grid-template-columns:80px 1fr;gap:20px;padding:26px clamp(20px,3vw,34px);background:var(--charcoal);transition:background .3s}
.step:hover{background:var(--graphite)}
.step-n{font-family:var(--f-display);font-size:1.5rem;color:transparent;background:var(--holo);-webkit-background-clip:text;background-clip:text;font-weight:700}
.step h4{font-size:1.16rem;margin-bottom:8px}
.step p{color:#b0b0bb;font-size:.94rem}

/* feature list with checks */
.feat{display:grid;gap:12px}
.feat li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;color:#c4c4cd}
.feat li::before{content:"";width:18px;height:18px;border-radius:50%;flex-shrink:0;margin-top:3px;background:radial-gradient(circle at 50% 50%,#0A0A0A 36%,transparent 38%),var(--holo)}

/* media placeholder */
.media-ph{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:
  radial-gradient(120% 120% at 20% 10%,rgba(167,187,250,.25),transparent 50%),
  radial-gradient(120% 120% at 90% 80%,rgba(255,77,255,.22),transparent 55%),
  linear-gradient(160deg,#15151b,#0c0c10);
  min-height:280px;display:grid;place-items:center}
.media-ph .ph-label{font-family:var(--f-display);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.media-ph .silhouette{position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,rgba(0,0,0,.6),transparent 60%)}

/* 12. FORMS ---------------------------------------------------------- */
.form{display:grid;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;position:relative}
.field label{font-family:var(--f-display);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border-radius:12px;background:rgba(255,255,255,.03);
  border:1px solid var(--line);color:var(--off-white);font-family:var(--f-body);font-size:.96rem;transition:border-color .3s,box-shadow .3s,background .3s}
.field textarea{resize:vertical;min-height:130px}
.field input::placeholder,.field textarea::placeholder{color:#6c6c76}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(103,231,255,.14);background:rgba(255,255,255,.05)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239A9AA3' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.seg{display:flex;flex-wrap:wrap;gap:10px}
.seg label{display:inline-flex;cursor:pointer}
.seg input{position:absolute;opacity:0;pointer-events:none}
.seg span{padding:10px 16px;border-radius:999px;border:1px solid var(--line);background:var(--glass);font-size:.84rem;color:#c4c4cd;transition:.25s var(--ease)}
.seg label:hover span{border-color:rgba(255,255,255,.3)}
.seg input:checked+span{border-color:transparent;background:linear-gradient(var(--soft-black),var(--soft-black)) padding-box,var(--holo) border-box;color:#fff}
.form-note{font-size:.8rem;color:var(--muted)}
.form-success{display:none;padding:18px;border-radius:14px;border:1px solid transparent;background:linear-gradient(var(--charcoal),var(--charcoal)) padding-box,var(--holo) border-box;font-size:.94rem}
.form-success.show{display:block}

/* 13. CTA BAND + FOOTER --------------------------------------------- */
.cta-band{padding-block:clamp(70px,9vw,130px);position:relative;text-align:center}
.cta-band-inner{position:relative;z-index:2}
.cta-band .eyebrow{justify-content:center;margin-bottom:22px}
.cta-band-title{font-size:clamp(2.1rem,6vw,4.6rem);line-height:1.0}
.cta-band-sub{margin:22px auto 36px;color:#b6b6c0;max-width:48ch}
.cta-band-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.site-footer{border-top:1px solid var(--line);background:linear-gradient(180deg,transparent,rgba(255,255,255,.015));position:relative;z-index:2;padding-top:clamp(54px,7vw,86px)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:54px}
.footer-mark{font-size:2rem}
.footer-tagline{font-family:var(--f-display);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:#c4c4cd;margin-top:8px}
.footer-micro{color:var(--muted);font-size:.88rem;margin-top:12px;max-width:34ch}
.footer-social{display:flex;gap:10px;margin-top:20px}
.footer-social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;font-family:var(--f-display);font-size:.72rem;color:#c4c4cd;transition:.3s var(--ease)}
.footer-social a:hover{border-color:transparent;background:linear-gradient(var(--soft-black),var(--soft-black)) padding-box,var(--holo) border-box;color:#fff;transform:translateY(-2px)}
.footer-col-title{font-family:var(--f-display);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-col a{display:block;color:var(--muted);font-size:.92rem;padding:5px 0;transition:color .25s}
.footer-col a:hover{color:#fff}
.footer-col--cta .footer-micro{margin-bottom:16px}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-block:24px;border-top:1px solid var(--line);font-size:.82rem;color:var(--muted)}
.footer-legal a:hover{color:#fff}
.footer-concept{font-family:var(--f-display);letter-spacing:.16em}

/* 14. REVEAL / MOTION ----------------------------------------------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}
.float-soft{animation:floatSoft 7s var(--ease) infinite}
@keyframes floatSoft{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.tilt{transition:transform .5s var(--ease)}

/* 15. RESPONSIVE ----------------------------------------------------- */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .cols-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .nav-links{display:none}
  .nav-actions .btn{display:none}
  .nav-burger{display:flex}
  .split{grid-template-columns:1fr;gap:36px}
  .cols-3{grid-template-columns:1fr}
  .dash{grid-template-columns:1fr}
  .dash-side{flex-direction:row;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line-soft);padding-bottom:8px;padding-right:0;min-width:0}
  .dash-brand{display:none}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:560px){
  .cols-2,.cols-4{grid-template-columns:1fr}
  .dash-metrics,.dash-metrics.three{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .btn{width:100%;justify-content:center}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
}

/* Accessibility: respect reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:4px}

/* =====================================================================
   16. DIRECTION-2 FUSION — chrome · acid lime · technical / utility
   Pulled from the "Enter the Next Frequency" board and merged with the
   holographic Direction-3 system above. Later rules intentionally override.
   ===================================================================== */
:root{
  --acid:#C0FF00;          /* acid lime — primary action color */
  --acid-2:#D7FF43;
  --chrome:#DDD9DE;
  --f-mono:ui-monospace,"SF Mono",SFMono-Regular,Menlo,Consolas,monospace;
}
::selection{background:var(--acid);color:var(--black)}

/* Primary action shifts to acid lime (the common "go" signal in both boards) */
.btn--primary{border-color:var(--acid);color:var(--acid)}
.btn--primary:hover{background:var(--acid);color:var(--black);box-shadow:0 0 0 1px var(--acid),0 14px 40px -12px rgba(192,255,0,.5)}
.btn--solid{background:var(--acid);color:var(--black)}
.btn--solid:hover{box-shadow:0 14px 40px -12px rgba(192,255,0,.55)}
.mobile-cta{color:var(--acid)!important}
.dash-nav-item.active .nd{background:var(--acid)}
.marquee-item::after{color:var(--acid)}

/* Technical captions / coordinates (utility voice) */
.coord{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.coord--acid{color:var(--acid)}
.tech-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* Crosshair marker (decorative target) */
.crosshair{position:relative;width:16px;height:16px;display:inline-block;flex-shrink:0;vertical-align:middle}
.crosshair::before,.crosshair::after{content:"";position:absolute;background:var(--acid)}
.crosshair::before{left:50%;top:0;width:1px;height:100%;transform:translateX(-50%)}
.crosshair::after{top:50%;left:0;height:1px;width:100%;transform:translateY(-50%)}
.crosshair i{position:absolute;inset:3.5px;border:1px solid var(--acid);border-radius:50%}

/* Barcode strip (technical flavor) */
.barcode{height:26px;width:150px;border-radius:2px;opacity:.45;
  background:repeating-linear-gradient(90deg,var(--off-white) 0 1px,transparent 1px 3px,var(--off-white) 3px 4px,transparent 4px 8px,var(--off-white) 8px 10px,transparent 10px 13px)}

/* Holographic foil card (member-access style) */
.holo-card{position:relative;border-radius:18px;padding:20px;color:#0a0a0a;overflow:hidden;border:1px solid rgba(255,255,255,.35);
  background:linear-gradient(120deg,#A7BBFA,#67E7FF 28%,#00F0D1 48%,#FFEA00 70%,#FF4DFF);background-size:200% 200%;animation:holoShift 8s ease infinite}
.holo-card::after{content:"";position:absolute;inset:0;mix-blend-mode:overlay;opacity:.35;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.holo-card .hc-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--f-display);font-weight:700;font-size:.82rem;letter-spacing:.04em;position:relative;z-index:1}
.holo-card .hc-big{font-family:var(--f-display);font-size:1.5rem;font-weight:700;margin-top:34px;letter-spacing:.03em;position:relative;z-index:1}
.holo-card .hc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-family:var(--f-mono);font-size:.66rem;position:relative;z-index:1}

/* Chrome / liquid-metal decorative blob */
.chrome-blob{position:absolute;border-radius:50%;filter:blur(3px) contrast(1.08);opacity:.5;mix-blend-mode:screen;pointer-events:none;
  background:conic-gradient(from 130deg,#2a2a32,#cfcfe0,#6a6a78,#eef0f5,#3a3a44,#9a9ab0,#2a2a32)}

/* Donut / demographics ring legend */
.legend{display:grid;gap:8px}
.legend li{display:flex;align-items:center;gap:9px;font-size:.78rem;color:#c4c4cd}
.legend .sw{width:11px;height:11px;border-radius:3px;flex-shrink:0}

/* Section corner ticks (blueprint feel) */
.ticked{position:relative}
.ticked::before,.ticked::after{content:"+";position:absolute;font-family:var(--f-mono);color:var(--muted);font-size:1rem;opacity:.5}
.ticked::before{top:10px;left:10px}
.ticked::after{bottom:10px;right:10px}

/* =====================================================================
   17. UPGRADES — fx canvas · kinetic type · reveals · sticky CTA ·
       pinned ecosystem · interactive charts · case studies · 404
   ===================================================================== */

/* WebGL field */
.fx-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0;transition:opacity 1.4s ease}
.fx-canvas.ready{opacity:.82}
body.fx-on .orbs{opacity:.4}
.hero .container,.hero-grid{position:relative;z-index:2}

/* Kinetic / extended headline */
.kinetic{font-family:var(--f-display);text-transform:uppercase;font-weight:700;letter-spacing:.01em;line-height:.88}
.stretch-word{display:inline-block;transform:scaleX(1.16);transform-origin:left;letter-spacing:.02em}
.outline-word{-webkit-text-stroke:1.4px rgba(239,239,242,.55);-webkit-text-fill-color:transparent;color:transparent}

/* Word / line mask reveal */
.reveal-words .w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.04em}
.reveal-words .w i{display:inline-block;transform:translateY(115%);transition:transform .9s var(--ease-out);font-style:normal;transition-delay:calc(var(--wi,0)*55ms)}
.reveal-words.in .w i{transform:none}
.reduced .reveal-words .w i{transform:none}

/* Sticky CTA */
.sticky-cta{position:fixed;right:18px;bottom:18px;z-index:900;transform:translateY(160%);transition:transform .55s var(--ease);box-shadow:0 16px 50px -14px rgba(0,0,0,.7)}
.sticky-cta.show{transform:none}
@media(max-width:560px){.sticky-cta{right:12px;bottom:12px}.sticky-cta .btn{padding:11px 16px;font-size:.8rem}}

/* Pinned horizontal ecosystem */
.pin-wrap{position:relative;height:340vh}
.pin-sticky{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.pin-head{padding:0 var(--gutter);max-width:var(--container);margin-inline:auto;width:100%;margin-bottom:30px}
.pin-track{display:flex;gap:22px;padding-inline:var(--gutter);will-change:transform}
.pin-card{flex:0 0 min(82vw,520px);min-height:46vh;padding:34px;display:flex;flex-direction:column;gap:14px}
.pin-card .pin-i{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.18em;color:var(--acid)}
.pin-progress{height:2px;background:rgba(255,255,255,.08);border-radius:2px;margin:26px var(--gutter) 0;max-width:240px}
.pin-progress i{display:block;height:100%;width:0;background:var(--holo);border-radius:2px}
@media(max-width:860px){
  .pin-wrap{height:auto}
  .pin-sticky{position:static;height:auto;padding-block:0}
  .pin-track{flex-direction:column;transform:none!important;padding-inline:var(--gutter);max-width:var(--container);margin-inline:auto}
  .pin-card{flex:1 1 auto;min-height:0}
  .pin-progress{display:none}
}

/* Interactive chart + tooltip */
.ichart{position:relative;width:100%}
.ichart svg{width:100%;height:auto;display:block;overflow:visible}
.ichart .line{fill:none;stroke:url(#lineStroke);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.ichart .area{fill:url(#areaFill)}
.ichart-canvas{position:relative}
.ichart .pt{cursor:pointer;transition:r .2s}
.ichart .pt-hit{fill:transparent;cursor:pointer}
.chart-tip{position:absolute;left:0;top:0;transform:translate(-50%,-135%);background:rgba(17,18,23,.96);border:1px solid var(--line);border-radius:10px;padding:8px 11px;font-size:.74rem;pointer-events:none;opacity:0;transition:opacity .18s,transform .18s;white-space:nowrap;z-index:6}
.chart-tip.show{opacity:1}
.chart-tip b{font-family:var(--f-display);color:#fff}
.chart-cursor{position:absolute;top:0;bottom:0;width:1px;background:rgba(255,255,255,.18);opacity:0;transition:opacity .18s;pointer-events:none}
.chart-cursor.show{opacity:1}

/* Toggle group */
.toggle-group{display:inline-flex;gap:3px;padding:3px;border:1px solid var(--line);border-radius:999px;background:var(--glass)}
.toggle-group button{padding:6px 14px;border-radius:999px;font-family:var(--f-display);font-size:.76rem;color:var(--muted);transition:.2s}
.toggle-group button.active{background:var(--acid);color:#000}

/* Live metric subtle bump */
.js-live{transition:color .35s,text-shadow .35s}
.js-live.bump{color:#fff;text-shadow:0 0 18px rgba(192,255,0,.45)}

/* Case studies */
.case{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden;align-items:stretch}
.case:nth-child(even) .case-media{order:2}
.case-media{position:relative;min-height:300px;background:
  radial-gradient(120% 120% at 20% 10%,rgba(167,187,250,.3),transparent 50%),
  radial-gradient(120% 120% at 90% 90%,rgba(255,77,255,.26),transparent 55%),
  linear-gradient(160deg,#15151b,#0c0c10)}
.case-media .case-tag{position:absolute;left:18px;top:18px}
.case-media .ph-label{position:absolute;left:18px;bottom:18px;font-family:var(--f-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.case-body{padding:clamp(26px,3.5vw,44px);display:flex;flex-direction:column;gap:16px;justify-content:center}
.case-body h3{font-size:clamp(1.4rem,2.6vw,2rem)}
.case-metrics{display:flex;flex-wrap:wrap;gap:24px;margin-top:6px}
.case-metric b{font-family:var(--f-display);font-size:1.5rem;display:block;line-height:1}
.case-metric span{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
@media(max-width:760px){.case{grid-template-columns:1fr}.case:nth-child(even) .case-media{order:0}}

/* Testimonial + logo wall */
.testimonial{font-family:var(--f-display);font-weight:500;font-size:clamp(1.4rem,3.4vw,2.4rem);line-height:1.28;letter-spacing:-.01em}
.testimonial .holo-text{font-weight:500}
.logos{display:flex;flex-wrap:wrap;gap:clamp(24px,4vw,52px);align-items:center}
.logo-chip{font-family:var(--f-display);font-weight:500;letter-spacing:.04em;color:#cfcfd8;font-size:clamp(1rem,1.6vw,1.25rem);opacity:.8;transition:opacity .3s}
.logo-chip:hover{opacity:1}

/* Free-audit band */
.audit{border:1px solid transparent;border-radius:var(--radius-lg);background:linear-gradient(var(--charcoal),var(--charcoal)) padding-box,var(--holo) border-box;padding:clamp(30px,4vw,56px);text-align:center}
.audit .pill{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;background:rgba(192,255,0,.12);color:var(--acid);font-family:var(--f-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:18px}

/* 404 */
.error-wrap{min-height:74vh;display:grid;place-items:center;text-align:center;padding-block:120px}
.error-code{font-family:var(--f-display);font-weight:700;font-size:clamp(5rem,18vw,13rem);line-height:.9;letter-spacing:-.04em}

/* Skip link (a11y) */
.skip-link{position:fixed;left:-999px;top:10px;z-index:2000;background:var(--acid);color:#000;padding:10px 16px;border-radius:10px;font-family:var(--f-display);font-size:.85rem;font-weight:600}
.skip-link:focus{left:10px}
.toggle-group button[aria-pressed="true"]{background:var(--acid);color:#000}

/* Home hero: contain the long headline beside the dashboard (two-col only) */
@media(min-width:1025px){
  body[data-page="index"] .hero h1{font-size:clamp(2.6rem,4vw,4.3rem);line-height:1.05}
}
/* Balance headline vs the platform dashboard on wide screens */
@media(min-width:1025px){
  body[data-page="index"] .hero-grid{grid-template-columns:1.05fr .95fr}
}

/* Platform dashboard polish — crisp dark panel + tidy metric chips */
.dash{background:rgba(13,14,19,.66);backdrop-filter:blur(22px) saturate(125%);-webkit-backdrop-filter:blur(22px) saturate(125%)}
.metric{background:rgba(255,255,255,.04)}
.metric-foot{flex-wrap:wrap;row-gap:4px}
.metric-foot .delta{flex-shrink:0}
/* sidebar legibility over the holographic field */
.dash-nav-item{color:#b6b6c2}
.dash-side{border-right-color:rgba(255,255,255,.1)}

/* Dark scrim over the WebGL field — improves text legibility */
.bg-scrim{position:fixed;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(10,10,10,.46),rgba(10,10,10,.72))}

/* =====================================================================
   18. SCROLL HERO — centered text → full-width dashboard reveal
   ===================================================================== */
.scroll-hero{position:relative;height:230vh;z-index:2}
.scroll-hero-stick{position:sticky;top:0;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
.sh-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:90px var(--gutter) 0;will-change:transform,opacity;z-index:3}
.sh-text .hero-eyebrow{margin-bottom:24px}
.sh-text .display-1{font-size:clamp(2.4rem,6.4vw,5.6rem);max-width:16ch;margin:0 auto 24px;line-height:.98}
.sh-text .hero-sub{max-width:56ch;margin:0 auto 32px}
.sh-text .hero-actions{justify-content:center;margin-bottom:0}
.scroll-hint{margin-top:42px;font-family:var(--f-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:8px}
.scroll-hint i{font-style:normal;animation:bob 1.6s ease infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

.sh-dash{position:absolute;left:50%;top:50%;width:min(1240px,92vw);transform:translate(-50%,-50%) scale(.82);opacity:0;will-change:transform,opacity;z-index:2}
.dash--wide{grid-template-columns:172px 1fr;min-height:auto;padding:22px}
.dash--wide .dash-metrics{grid-template-columns:repeat(4,1fr)}
.dash-wide-row{display:grid;grid-template-columns:1.7fr 1fr;gap:14px}
.dash-chartbox{padding:16px}
.dash-chartbox .chart{height:clamp(120px,15vh,168px)}
.dash-eventcol{display:flex;flex-direction:column;gap:8px}
@media(max-width:980px){ .dash-wide-row{grid-template-columns:1fr} }

/* flat fallback: mobile / reduced motion → static stack */
.scroll-hero.flat{height:auto}
.scroll-hero.flat .scroll-hero-stick{position:static;height:auto;display:block;padding-top:clamp(120px,16vh,170px);padding-bottom:clamp(40px,6vw,70px)}
.scroll-hero.flat .sh-text{position:static;inset:auto;padding:0 var(--gutter)}
.scroll-hero.flat .sh-dash{position:static;left:auto;top:auto;width:100%;margin-top:44px;transform:none!important;opacity:1!important}
@media(max-width:860px){
  /* Mobile hero: static-stacked via CSS (robust even if JS doesn't run) */
  .scroll-hero{height:auto}
  .scroll-hero-stick{position:static;height:auto;display:block;padding:clamp(128px,17vh,180px) var(--gutter) clamp(40px,7vw,72px)}
  .sh-text{position:static;inset:auto;padding-left:0;padding-right:0}
  .sh-text .display-1{font-size:clamp(2rem,7.4vw,2.7rem);max-width:20ch;margin-bottom:18px}
  .sh-text .hero-sub{margin-bottom:24px}
  .sh-dash{position:static;left:auto;top:auto;width:100%;min-width:0;margin:38px 0 0;transform:none!important;opacity:1!important}
  .dash--wide{grid-template-columns:1fr;padding:16px;min-width:0}
  .dash--wide .dash-side{display:none}
  .dash--wide .dash-main{min-width:0}
  .dash--wide .dash-metrics{grid-template-columns:1fr 1fr}
  /* Nav fades into the hero on mobile — gradient only (no blur edge, no hard line) */
  .site-nav,.site-nav.scrolled{background:linear-gradient(180deg,rgba(10,10,10,.95) 0%,rgba(10,10,10,.74) 44%,rgba(10,10,10,0) 100%);backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom:0}
  .brand-logo{height:28px}
}



/* ── Mobile performance: drop GPU-heavy layers (WebGL hidden via JS too) ── */
@media (max-width:860px){
  .orb{filter:blur(55px);opacity:.30}
  .cursor-glow{display:none !important}
}
@media (prefers-reduced-motion: reduce){
  .fx-canvas,.fx-video{display:none !important}
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
}

/* Background video loop (replaces WebGL; decodes off main-thread) */
.fx-video{position:fixed;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none;opacity:.9}
body .fx-video{opacity:.9}
