/* ══════════════════════════════════════
   RESET & TOKENS
══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --black:      #070707;
  --dark:       #0d0d0d;
  --card:       #111111;
  --border:     rgba(255,255,255,0.07);
  --border-hi:  rgba(255,255,255,0.12);
  --white:      #ffffff;
  --muted:      rgba(255,255,255,0.42);
  --faint:      rgba(255,255,255,0.2);
  --accent:     #e8ff4a;
  --aRGB:       232,255,74;
  --glass:      rgba(255,255,255,0.028);
  --glassB:     rgba(255,255,255,0.07);
  --font:       'Space Grotesk',system-ui,sans-serif;
  --mono:       'Space Mono',monospace;
  --ease:       cubic-bezier(0.16,1,0.3,1);
  --easeOut:    cubic-bezier(0.22,1,0.36,1);
  --SYS:        26px;   /* system-bar height */
  --NAV:        52px;   /* nav height */
  --TOP:        calc(var(--SYS) + var(--NAV));
}

html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--black);color:var(--white);
  font-family:var(--font);line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
::selection{background:var(--accent);color:var(--black)}
a{color:inherit;text-decoration:none}
em{font-style:italic;color:var(--accent);font-weight:300}
sup{font-size:.55em;vertical-align:super}

/* ══════════════════════════════════════
   GRAIN (animated film grain over everything)
══════════════════════════════════════ */
.grain{
  position:fixed;inset:0;z-index:9999;
  pointer-events:none;user-select:none;
  opacity:.042;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-size:180px 180px;
  animation:grainShift .12s steps(1) infinite;
  mix-blend-mode:overlay;
}
@keyframes grainShift{
  0%  {transform:translate(0,0)}
  25% {transform:translate(-3px,-2px)}
  50% {transform:translate(2px,0)}
  75% {transform:translate(0,3px)}
  100%{transform:translate(-2px,2px)}
}

/* ══════════════════════════════════════
   LAYOUT
══════════════════════════════════════ */
.container{max-width:1200px;margin:0 auto;padding:0 40px}

/* ══════════════════════════════════════
   TYPOGRAPHY UTILS
══════════════════════════════════════ */
.section-label{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--accent);
  display:flex;align-items:center;gap:10px;margin-bottom:16px;
}
.section-label::before{
  content:'';display:block;width:16px;height:1px;
  background:var(--accent);opacity:.55;flex-shrink:0;
}
.section-title{
  font-size:clamp(24px,3.2vw,44px);font-weight:600;
  line-height:1.12;letter-spacing:-.025em;
}
.section-header{margin-bottom:52px}

/* Bracket motif */
.bracket{position:relative}
.bracket::before,.bracket::after{
  content:'';position:absolute;
  width:12px;height:12px;
  border-color:rgba(var(--aRGB),.26);border-style:solid;
  pointer-events:none;transition:border-color .3s;
}
.bracket::before{top:-2px;left:-2px;border-width:1px 0 0 1px}
.bracket::after{bottom:-2px;right:-2px;border-width:0 1px 1px 0}
.bracket:hover::before,.bracket:hover::after{border-color:rgba(var(--aRGB),.5)}

/* ══════════════════════════════════════
   REVEAL
══════════════════════════════════════ */
.reveal{
  opacity:0;transform:translateY(22px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
  transition-delay:var(--delay,0s);
}
.reveal.visible{opacity:1;transform:none}

/* ══════════════════════════════════════
   BUTTONS
══════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;font-family:var(--font);font-size:13px;
  font-weight:500;letter-spacing:.03em;border-radius:3px;
  border:none;cursor:pointer;white-space:nowrap;
  position:relative;will-change:transform;
  transition:background .22s,border-color .22s,color .22s,
             box-shadow .35s,transform .45s var(--easeOut);
}
.btn--primary{
  background:var(--accent);color:var(--black);
  box-shadow:0 4px 20px rgba(var(--aRGB),.12);
}
.btn--primary:hover{
  background:#f3ff70;
  box-shadow:0 0 32px rgba(var(--aRGB),.4),0 8px 28px rgba(var(--aRGB),.18);
}
.btn--ghost{
  background:transparent;color:var(--white);
  border:1px solid var(--border-hi);
  backdrop-filter:blur(8px);
}
.btn--ghost:hover{
  background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.22);
}
.btn--lg{padding:16px 38px;font-size:14px}

/* magnetic base */
.mag{
  transition:transform .45s var(--easeOut),background .22s,
             border-color .22s,box-shadow .35s;
}

/* ══════════════════════════════════════
   SYSTEM BAR
══════════════════════════════════════ */
.sys-bar{
  position:fixed;top:0;left:0;right:0;
  height:var(--SYS);
  background:rgba(7,7,7,.96);border-bottom:1px solid var(--border);
  overflow:hidden;z-index:300;display:flex;align-items:center;
}
.sys-bar__track{
  display:flex;gap:20px;width:max-content;
  animation:sysTick 44s linear infinite;
  font-family:var(--mono);font-size:9px;letter-spacing:.13em;
  text-transform:uppercase;color:var(--faint);align-items:center;
}
.sys-sep{color:rgba(var(--aRGB),.35);font-size:10px}
@keyframes sysTick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══════════════════════════════════════
   NAV
══════════════════════════════════════ */
.nav{
  position:fixed;top:var(--SYS);left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 40px;height:var(--NAV);
  background:rgba(7,7,7,.55);
  backdrop-filter:blur(22px) saturate(1.4);
  -webkit-backdrop-filter:blur(22px) saturate(1.4);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:background .4s var(--ease),border-color .4s,padding .3s;
}
.nav.scrolled{background:rgba(7,7,7,.94);border-color:var(--border);padding:10px 40px}
.nav__logo{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--white);letter-spacing:-.02em;transition:color .2s}
.nav__bracket{color:var(--accent);transition:letter-spacing .2s}
.nav__logo:hover{color:var(--accent)}
.nav__logo:hover .nav__bracket{letter-spacing:.05em}
.nav__links{display:flex;gap:28px}
.nav__links a{
  font-size:11px;letter-spacing:.08em;color:var(--muted);
  text-transform:uppercase;transition:color .2s;position:relative;
}
.nav__links a::after{
  content:'';position:absolute;bottom:-2px;left:0;
  width:0;height:1px;background:var(--accent);
  transition:width .25s var(--ease);
}
.nav__links a:hover{color:var(--white)}
.nav__links a:hover::after{width:100%}
.nav__end{display:flex;align-items:center;gap:14px}
.nav__live{
  display:flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:9px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--faint);
}
.nav__live-dot{width:5px;height:5px;border-radius:50%;background:#4aff8a;animation:livePulse 2.4s ease-in-out infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(74,255,138,.5)}50%{box-shadow:0 0 0 4px rgba(74,255,138,0)}}
.nav__burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:30px;height:30px;background:none;border:none;cursor:pointer;padding:0;
}
.nav__burger span{display:block;height:1px;background:var(--white);transition:all .35s var(--ease);transform-origin:center}
.nav__burger.active span:first-child{transform:translateY(6px) rotate(45deg)}
.nav__burger.active span:last-child{transform:translateY(-6px) rotate(-45deg)}

/* Mobile menu */
.mobile-menu{
  position:fixed;inset:0;background:rgba(7,7,7,.97);backdrop-filter:blur(20px);
  z-index:190;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:28px;
  opacity:0;pointer-events:none;transition:opacity .35s var(--ease);
}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu__link{font-size:36px;font-weight:600;letter-spacing:-.03em;color:var(--muted);transition:color .2s}
.mobile-menu__link:hover{color:var(--white)}

/* System dot */
.sys-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
.sys-dot--pulse{animation:livePulse 2s ease-in-out infinite}
.sys-dot--green{background:#4aff8a}
.sys-green{display:flex;align-items:center;gap:6px;color:#4aff8a}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;align-items:center;
  /* viewport-height–aware padding so hero fits on 13" MacBooks */
  padding:max(78px,calc(var(--TOP) + 18px)) 0 max(44px,6svh);
  overflow:hidden;
}

/* BG */
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__glow{
  position:absolute;border-radius:50%;
  filter:blur(100px);pointer-events:none;
}
.hero__glow--1{
  width:580px;height:580px;top:-200px;right:-120px;
  background:radial-gradient(circle,rgba(var(--aRGB),.08) 0%,transparent 65%);
  animation:glowA 16s ease-in-out infinite alternate;
}
.hero__glow--2{
  width:440px;height:440px;bottom:-140px;left:-80px;
  background:radial-gradient(circle,rgba(80,80,220,.06) 0%,transparent 65%);
  animation:glowB 20s ease-in-out infinite alternate;
}
@keyframes glowA{from{transform:translate(0,0) scale(1)}to{transform:translate(-40px,30px) scale(1.09)}}
@keyframes glowB{from{transform:translate(0,0)}to{transform:translate(32px,-26px) scale(1.06)}}
.hero__grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at 55% 42%,black 8%,transparent 62%);
  -webkit-mask-image:radial-gradient(ellipse at 55% 42%,black 8%,transparent 62%);
}
.hero__noise{
  position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.88' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.028'/%3E%3C/svg%3E");
  background-size:256px;
}
.hero__vignette{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%,transparent 18%,rgba(7,7,7,.72) 100%);
}
.hero__wave{
  position:absolute;bottom:0;left:0;width:100%;height:120px;
  z-index:1;pointer-events:none;
}

/* System cards (right panel) */
.hero__panel{
  position:absolute;right:68px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;gap:10px;z-index:10;width:196px;
}
.sys-card{
  background:rgba(12,12,12,.84);
  backdrop-filter:blur(22px) saturate(1.3);
  -webkit-backdrop-filter:blur(22px) saturate(1.3);
  border:1px solid var(--glassB);border-radius:7px;
  padding:13px 14px;transition:border-color .3s;
}
.sys-card:hover{border-color:rgba(var(--aRGB),.22)}
.sys-card--wave{animation:floatB 6s ease-in-out infinite}
.sys-card:not(.sys-card--wave){animation:floatA 5s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes floatB{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

.sys-card__header{display:flex;align-items:center;gap:7px;margin-bottom:10px}
.sys-card__title{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);flex:1}
.sys-card__clock{font-family:var(--mono);font-size:9px;color:rgba(var(--aRGB),.5);letter-spacing:.04em}
.sys-card__rows{display:flex;flex-direction:column;gap:5px;margin-bottom:10px}
.sys-card__row{display:flex;justify-content:space-between;align-items:center}
.sys-card__row span{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.07em;text-transform:uppercase}
.sys-card__row strong{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--accent)}
.sys-card__bar{height:2px;background:var(--border);border-radius:1px;position:relative;overflow:hidden;margin-bottom:5px}
.sys-card__bar-fill{
  position:absolute;left:0;top:0;bottom:0;background:var(--accent);
  animation:barIn 1.8s var(--ease) 1.2s both;
}
@keyframes barIn{from{width:0}to{width:72%}}
.sys-card__bar-label{font-family:var(--mono);font-size:8px;color:var(--faint);letter-spacing:.08em}

/* Waveform equaliser */
.waveform-eq{display:flex;align-items:flex-end;gap:2px;height:26px}
.waveform-eq span{
  flex:1;background:var(--accent);border-radius:1px;min-height:3px;
  animation:wEq .9s ease-in-out infinite alternate;
}
.waveform-eq span:nth-child(2){animation-delay:-.12s}
.waveform-eq span:nth-child(3){animation-delay:-.26s}
.waveform-eq span:nth-child(4){animation-delay:-.06s;animation-duration:.72s}
.waveform-eq span:nth-child(5){animation-delay:-.33s;animation-duration:1.1s}
.waveform-eq span:nth-child(6){animation-delay:-.18s}
.waveform-eq span:nth-child(7){animation-delay:-.44s;animation-duration:.82s}
.waveform-eq span:nth-child(8){animation-delay:-.22s}
.waveform-eq span:nth-child(9){animation-delay:-.38s;animation-duration:1.2s}
.waveform-eq span:nth-child(10){animation-delay:-.11s}
.waveform-eq span:nth-child(11){animation-delay:-.48s;animation-duration:.76s}
.waveform-eq span:nth-child(12){animation-delay:-.24s}
@keyframes wEq{from{height:14%}to{height:var(--h,80%)}}

/* Hero body */
.hero__body{
  position:relative;z-index:10;
  padding:0 40px;max-width:700px;width:100%;
  will-change:transform,opacity; /* JS drives this */
}

.hero__eyebrow{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:9px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:clamp(18px,2.8svh,30px);
}
.hero__eyebrow-dash{
  display:block;width:22px;height:1px;
  background:var(--accent);opacity:.5;flex-shrink:0;
}

/* Title — chars split by JS, fallback opacity animation */
.hero__title{
  display:flex;flex-direction:column;
  margin-bottom:clamp(16px,2.5svh,28px);
  line-height:.93;
}
.hero__line{
  display:block;
  font-size:clamp(44px,min(5.8vw,9.5svh),92px);
  font-weight:700;letter-spacing:-.052em;
  /* default (no-JS) reveal */
  opacity:0;transform:translateY(28px);
  animation:lineIn .8s var(--ease) both;
}
.hero__line--soft{
  font-weight:300;
  font-size:clamp(34px,min(4.2vw,7svh),68px);
  color:rgba(255,255,255,.35);letter-spacing:-.04em;
  padding-left:.12em;
}
.hero__line--italic em{font-style:italic;font-weight:300}
@keyframes lineIn{to{opacity:1;transform:none}}
.hero__line:nth-child(1){animation-delay:.06s}
.hero__line:nth-child(2){animation-delay:.2s}
.hero__line:nth-child(3){animation-delay:.34s}

/* Char split (added by JS) */
.c-wrap{display:inline-block;overflow:hidden;vertical-align:top}
.c{
  display:inline-block;
  opacity:0;transform:translateY(70%) rotateX(-14deg);
  animation:cIn .65s var(--ease) both;
  animation-delay:calc(var(--ci,0) * 36ms + 80ms);
}
@keyframes cIn{to{opacity:1;transform:none}}

.hero__sub{
  font-size:clamp(13px,1.4vw,16px);color:var(--muted);
  line-height:1.72;max-width:380px;
  margin-bottom:clamp(20px,3.5svh,40px);
  opacity:0;animation:lineIn .8s var(--ease) .52s both;
}
.hero__actions{
  display:flex;gap:12px;flex-wrap:wrap;
  opacity:0;animation:lineIn .8s var(--ease) .66s both;
}

/* Side / scroll */
.hero__side{
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  display:flex;flex-direction:column;align-items:center;gap:9px;z-index:10;
}
.hero__side span{
  font-family:var(--mono);font-size:8px;letter-spacing:.17em;
  text-transform:uppercase;color:var(--faint);
  writing-mode:vertical-lr;transform:rotate(180deg);
}
.hero__side-rule{width:1px;height:44px;background:linear-gradient(to bottom,var(--faint),transparent)}
.hero__scroll-ind{
  position:absolute;bottom:28px;right:40px;
  display:flex;align-items:center;gap:9px;z-index:10;
}
.hero__scroll-ind span{font-family:var(--mono);font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.hero__scroll-bar{width:34px;height:1px;background:var(--border);position:relative;overflow:hidden}
.hero__scroll-pip{
  position:absolute;left:0;top:0;width:12px;height:1px;
  background:var(--accent);animation:scrollPip 2.2s ease-in-out infinite;
}
@keyframes scrollPip{0%{left:-12px}100%{left:100%}}

/* ══════════════════════════════════════
   MARQUEE
══════════════════════════════════════ */
.marquee{
  background:var(--card);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:11px 0;overflow:hidden;
}
.marquee__inner{
  display:flex;gap:22px;width:max-content;
  animation:marqueeRun 26s linear infinite;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted);align-items:center;
}
.msep{color:var(--accent);font-size:12px}
@keyframes marqueeRun{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ══════════════════════════════════════
   ABOUT
══════════════════════════════════════ */
.about{padding:clamp(72px,9vw,110px) 0;border-bottom:1px solid var(--border)}
.about__split{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:start}
.about__heading{
  font-size:clamp(24px,3.2vw,44px);font-weight:600;
  line-height:1.1;letter-spacing:-.03em;margin-top:6px;margin-bottom:24px;
}

/* System info table */
.sys-table{
  border:1px solid var(--border);border-radius:6px;overflow:hidden;
  font-family:var(--mono);
}
.sys-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 12px;border-bottom:1px solid var(--border);font-size:10px;
}
.sys-row--last{border-bottom:none}
.sys-row span{color:var(--muted);letter-spacing:.07em;text-transform:uppercase}
.sys-row b{color:var(--white);font-weight:700;letter-spacing:.04em}

.about__body{font-size:16px;line-height:1.8;color:rgba(255,255,255,.62);margin-bottom:18px}
.about__pull{
  font-size:17px;font-weight:500;color:var(--white);line-height:1.55;
  border-left:2px solid var(--accent);padding-left:16px;margin-top:28px;
}

/* ══════════════════════════════════════
   NUMBERS
══════════════════════════════════════ */
.numbers{border-bottom:1px solid var(--border)}
.numbers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border)}
.num-item{
  background:var(--dark);padding:clamp(44px,6vw,72px) clamp(24px,3.5vw,52px);
  position:relative;overflow:hidden;transition:background .3s;cursor:default;
}
.num-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:0;transition:opacity .4s;
}
.num-item:hover{background:#0f0f0f}
.num-item:hover::before{opacity:.35}
.num-item__label{
  font-family:var(--mono);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin-bottom:14px;
}
.num-item__val{
  display:block;font-family:var(--mono);
  font-size:clamp(60px,8vw,108px);
  font-weight:700;letter-spacing:-.05em;
  color:var(--accent);line-height:1;margin-bottom:12px;
}
.num-item__sub{
  font-family:var(--mono);font-size:9px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
}

/* ══════════════════════════════════════
   DIRECTIONS
══════════════════════════════════════ */
.directions{padding:clamp(72px,9vw,110px) 0;border-bottom:1px solid var(--border)}
.directions .section-header{padding:0 40px;max-width:1200px;margin-left:auto;margin-right:auto}
.dir-list{max-width:1200px;margin:0 auto}
.dir-row{
  display:grid;grid-template-columns:68px 1fr auto 32px;
  align-items:center;gap:24px;padding:26px 40px;
  border-bottom:1px solid var(--border);cursor:default;position:relative;
  transition:background .3s;
}
.dir-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--accent);transform:scaleY(0);
  transform-origin:top;transition:transform .4s var(--ease);
}
.dir-row:hover{background:rgba(255,255,255,.016)}
.dir-row:hover::before{transform:scaleY(1)}
.dir-num{font-family:var(--mono);font-size:10px;color:var(--accent);letter-spacing:.1em}
.dir-body h3{font-size:clamp(15px,1.7vw,21px);font-weight:600;letter-spacing:-.02em;margin-bottom:4px;transition:color .2s}
.dir-row:hover .dir-body h3{color:var(--accent)}
.dir-body p{font-size:13px;line-height:1.65;color:var(--muted);max-width:460px}
.dir-tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.dir-tags span{
  font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--border);padding:3px 8px;border-radius:2px;
  transition:all .2s;
}
.dir-row:hover .dir-tags span{border-color:rgba(var(--aRGB),.3);color:var(--accent)}
.dir-arrow{font-size:17px;color:var(--faint);transition:color .2s,transform .3s var(--ease)}
.dir-row:hover .dir-arrow{color:var(--accent);transform:translate(4px,-4px)}

/* ══════════════════════════════════════
   ECOSYSTEM
══════════════════════════════════════ */
.ecosystem{padding:clamp(72px,9vw,110px) 0 56px;border-bottom:1px solid var(--border);overflow:hidden}
.eco-header{text-align:center;margin-bottom:44px}
.eco-header .section-label{justify-content:center}
.eco-header .section-label::before{display:none}
.eco-title{font-size:clamp(26px,3.6vw,50px);font-weight:600;letter-spacing:-.03em;line-height:1.1;margin-bottom:12px}
.eco-hint{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.eco-canvas-wrap{position:relative;width:100%;height:500px}
#ecoCanvas{width:100%;height:100%;display:block;cursor:crosshair}
.eco-tip{
  position:absolute;
  background:rgba(10,10,10,.96);backdrop-filter:blur(12px);
  border:1px solid var(--border-hi);border-radius:6px;
  padding:10px 14px;font-size:12px;line-height:1.55;
  pointer-events:none;opacity:0;transition:opacity .18s;
  z-index:20;max-width:186px;color:var(--white);
}
.eco-tip.visible{opacity:1}
.eco-legend{
  display:flex;justify-content:center;gap:22px;flex-wrap:wrap;padding-top:26px;
}
.eco-legend span{
  display:flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
}
.eco-legend i{display:block;width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.5;font-style:normal}

/* ══════════════════════════════════════
   PHILOSOPHY (cinematic)
══════════════════════════════════════ */
.philo{
  position:relative;
  padding:clamp(90px,12vw,140px) 0;
  border-bottom:1px solid var(--border);overflow:hidden;
}
.philo__ambient{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(var(--aRGB),.03) 0%,transparent 65%);
  pointer-events:none;
}
.philo__wave-svg{
  position:absolute;bottom:0;left:0;right:0;height:80px;opacity:.055;pointer-events:none;
}
.philo__wave-svg svg{width:100%;height:100%}
.pw{fill:none;stroke:var(--accent);stroke-width:1.5}
.pw--1{animation:waveDrift 15s ease-in-out infinite alternate}
.pw--2{animation:waveDrift 20s ease-in-out infinite alternate-reverse;opacity:.55}
@keyframes waveDrift{from{transform:translateX(0)}to{transform:translateX(-26px)}}

.philo__inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.philo__inner .section-label{margin-bottom:40px}

.philo__setup{
  font-size:clamp(14px,1.6vw,18px);color:rgba(255,255,255,.5);
  line-height:1.8;margin-bottom:0;max-width:620px;
}
.philo__setup p{margin-bottom:12px}
.philo__setup p:last-child{margin-bottom:0}

/* THE BIG CINEMATIC STATEMENT */
.philo__statement{
  font-size:clamp(48px,7vw,100px);
  font-weight:700;letter-spacing:-.04em;line-height:1.04;
  color:var(--white);
  margin:clamp(40px,6vw,72px) 0;
}

.philo__close{
  font-size:clamp(14px,1.6vw,18px);color:rgba(255,255,255,.5);
  line-height:1.8;max-width:560px;
}
.philo__close p{margin-bottom:12px}
.philo__close p:last-child{margin-bottom:0}

.philo__sig{
  margin-top:48px;font-family:var(--mono);font-size:10px;
  letter-spacing:.1em;color:var(--muted);
}

/* ══════════════════════════════════════
   PROJECTS BENTO
══════════════════════════════════════ */
.projects{padding:clamp(72px,9vw,110px) 0;border-bottom:1px solid var(--border)}
.bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-areas:"a b c" "a d d" "e e f";
  gap:1px;background:var(--border);border:1px solid var(--border);
}
.bc{
  background:var(--dark);padding:34px 30px;
  position:relative;overflow:hidden;
  transition:background .3s;display:flex;flex-direction:column;cursor:pointer;
}
.bc:hover{background:#101010}
.bc--a{grid-area:a;min-height:290px;background:rgba(var(--aRGB),.032)}
.bc--a:hover{background:rgba(var(--aRGB),.06)}
.bc--b{grid-area:b}
.bc--c{grid-area:c}
.bc--d{grid-area:d}
.bc--e{grid-area:e}
.bc--f{grid-area:f;background:#0a0a0a}

.bc__bg-r{
  position:absolute;bottom:-14px;right:-6px;
  font-size:110px;font-weight:700;color:rgba(var(--aRGB),.036);
  line-height:1;pointer-events:none;letter-spacing:-.05em;transition:color .3s;
}
.bc--a:hover .bc__bg-r{color:rgba(var(--aRGB),.068)}

.bc__cat{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.bc__name{font-size:clamp(16px,1.8vw,22px);font-weight:600;letter-spacing:-.02em;margin-bottom:9px;line-height:1.2}
.bc__desc{font-size:13px;line-height:1.7;color:rgba(255,255,255,.44);flex-grow:1}
.bc__foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:20px;font-family:var(--mono);font-size:9px;
  color:var(--muted);letter-spacing:.08em;text-transform:uppercase;
}
.bc__arr{font-size:15px;color:var(--faint);transition:color .2s,transform .3s var(--ease)}
.bc:hover .bc__arr{color:var(--accent);transform:translate(4px,-4px)}

/* ══════════════════════════════════════
   CTA
══════════════════════════════════════ */
.cta{position:relative;padding:clamp(90px,12vw,140px) 0;overflow:hidden}
.cta__glows{position:absolute;inset:0;pointer-events:none}
.cta__glow{position:absolute;border-radius:50%;filter:blur(100px)}
.cta__glow--1{
  width:460px;height:460px;top:-100px;left:-80px;
  background:radial-gradient(circle,rgba(var(--aRGB),.055) 0%,transparent 65%);
  animation:glowA 22s ease-in-out infinite alternate;
}
.cta__glow--2{
  width:360px;height:360px;bottom:-80px;right:-60px;
  background:radial-gradient(circle,rgba(80,80,220,.044) 0%,transparent 65%);
  animation:glowB 26s ease-in-out infinite alternate;
}
.cta__watermark{
  position:absolute;bottom:-55px;right:-28px;
  font-size:clamp(150px,18vw,280px);font-weight:700;
  letter-spacing:-.06em;color:rgba(255,255,255,.015);
  pointer-events:none;user-select:none;line-height:1;font-family:var(--mono);
}
.cta__body{position:relative;z-index:1;max-width:780px}
.cta__heading{
  font-size:clamp(30px,4.8vw,66px);font-weight:600;
  line-height:1.08;letter-spacing:-.035em;margin:14px 0 18px;
}
.cta__sub{font-size:16px;color:var(--muted);margin-bottom:44px}
.cta__btns{display:flex;gap:12px;flex-wrap:wrap}

/* ══════════════════════════════════════
   FOOTER
══════════════════════════════════════ */
.footer{border-top:1px solid var(--border);padding:44px 0 28px}
.footer__top{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:28px;margin-bottom:24px}
.footer__logo{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--accent);margin-bottom:5px}
.footer__brand p{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.footer__nav{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.footer__nav a{font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;transition:color .2s}
.footer__nav a:hover{color:var(--white)}
.footer__meta{text-align:right;font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.08em;line-height:2}
.footer__rule{height:1px;background:var(--border);margin-bottom:16px}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:9px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase;
}
.footer__status{display:flex;align-items:center;gap:5px}

/* ══════════════════════════════════════
   CURSOR GLOW
══════════════════════════════════════ */
.cursor-glow{
  position:fixed;width:460px;height:460px;border-radius:50%;
  background:radial-gradient(circle,rgba(var(--aRGB),.03) 0%,transparent 65%);
  pointer-events:none;z-index:0;transform:translate(-50%,-50%);top:0;left:0;
}

/* ══════════════════════════════════════
   SCROLL
══════════════════════════════════════ */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--black)}
::-webkit-scrollbar-thumb{background:rgba(var(--aRGB),.2);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1100px){
  .hero__panel{right:36px}
  .dir-row{grid-template-columns:56px 1fr auto 28px;gap:18px}
}
@media(max-width:900px){
  :root{--SYS:0px}
  .sys-bar{display:none}
  .container{padding:0 24px}
  .nav{top:0;padding:12px 24px;height:auto}
  .nav.scrolled{padding:10px 24px}
  .nav__links,.nav__live{display:none}
  .nav__burger{display:flex}

  .hero__body{padding:0 24px}
  .hero__panel,.hero__side,.hero__scroll-ind{display:none}

  .about__split{grid-template-columns:1fr;gap:36px}

  .numbers__grid{grid-template-columns:1fr}

  .directions .section-header{padding:0 24px}
  .dir-row{
    grid-template-columns:48px 1fr;grid-template-rows:auto auto;
    gap:8px 12px;padding:20px 24px;
  }
  .dir-tags{display:none}
  .dir-arrow{grid-column:2;justify-self:end;grid-row:1}

  .eco-canvas-wrap{height:350px}
  .philo__statement{font-size:clamp(36px,11vw,70px)}

  .bento{
    grid-template-columns:1fr 1fr;
    grid-template-areas:"a a" "b c" "d d" "e f";
  }

  .footer__top{grid-template-columns:1fr;text-align:center;gap:16px}
  .footer__nav{justify-content:center}
  .footer__meta{text-align:center}
  .footer__bottom{flex-direction:column;gap:8px}
}
@media(max-width:600px){
  .hero__line{font-size:clamp(38px,12vw,64px)}
  .hero__line--soft{font-size:clamp(28px,9vw,48px)}
  .num-item__val{font-size:clamp(52px,14vw,78px)}
  .philo__statement{font-size:clamp(32px,10vw,56px)}
  .eco-canvas-wrap{height:270px}
  .bento{grid-template-columns:1fr;grid-template-areas:"a""b""c""d""e""f"}
  .bc{min-height:auto!important;padding:24px 20px}
  .dir-row{padding:18px 16px}
  .cta__heading{font-size:clamp(26px,9vw,44px)}
}
