:root{
  --bg:#0a0a0b; --bg2:#101012; --ink:#ededed; --grey:#8a8a8e;
  --lime:#d8ff1e; --lime-dim:rgba(216,255,30,.35);
  --hair:rgba(255,255,255,.12); --ghost:rgba(255,255,255,.045);
  --ease:cubic-bezier(.77,0,.18,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Space Grotesk',sans-serif;
  overflow-x:hidden; cursor:none;
}
::selection{background:var(--lime);color:#0a0a0b}
a{color:inherit;text-decoration:none;cursor:none}
.mono{font-family:'Space Mono',monospace}

/* ---------- GRAIN ---------- */
.grain{position:fixed;inset:-100%;width:300%;height:300%;pointer-events:none;z-index:2000;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 250 250' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(10) infinite}
@keyframes grain{
  0%,100%{transform:translate(0,0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}
  30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}
  60%{transform:translate(15%,0)}70%{transform:translate(0,15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}

/* ---------- CURSOR ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:3000;border-radius:50%}
.cursor-dot{width:8px;height:8px;background:var(--lime);transform:translate(-50%,-50%)}
.cursor-ring{width:36px;height:36px;border:1px solid var(--lime-dim);transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s}
.cursor-ring.is-hover{width:64px;height:64px;border-color:var(--lime)}
@media (hover:none){.cursor-dot,.cursor-ring{display:none}body,a{cursor:auto}}

/* ---------- PRELOADER ---------- */
.preloader{position:fixed;inset:0;background:#060607;z-index:4000;display:flex;align-items:flex-end;justify-content:space-between;padding:5vh 4vw;transition:transform 1s var(--ease)}
/* Bug fix (2026-06-10): the slid-away preloader kept capturing wheel scroll
   as a full-viewport fixed layer, freezing page scroll. visibility flips
   only AFTER the 1s slide completes, so the approved animation is untouched. */
.preloader.done{transform:translateY(-101%);visibility:hidden;pointer-events:none;transition:transform 1s var(--ease),visibility 0s 1s}
.preloader .count{font-family:'Anton',sans-serif;font-size:18vw;line-height:.8;color:var(--lime)}
.preloader .tag{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.3em;color:var(--grey);text-transform:uppercase;padding-bottom:2vh}
.preloader .bar{position:absolute;left:0;bottom:0;height:3px;background:var(--lime);width:0%}

/* ---------- PROGRESS ---------- */
.progress{position:fixed;top:0;left:0;height:2px;background:var(--lime);width:0%;z-index:1500}

/* ---------- NAV ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:22px 4vw;border-bottom:1px solid transparent;transition:padding .4s var(--ease),background .4s,border-color .4s}
nav.scrolled{padding:12px 4vw;background:rgba(10,10,11,.65);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-color:var(--hair)}
.logo{font-family:'Anton',sans-serif;font-size:20px;letter-spacing:.02em}
.logo span{color:var(--lime)}
.nav-links{display:flex;gap:34px;font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.nav-links a{position:relative;padding:4px 0}
.nav-links a::after{content:'';position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--lime);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.btn-connect{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:#0a0a0b;background:var(--lime);padding:10px 22px;display:inline-block;transition:transform .3s var(--ease),box-shadow .3s}
.btn-connect:hover{box-shadow:0 0 30px var(--lime-dim)}
@media(max-width:760px){.nav-links{display:none}}

/* ---------- CONTENT FRAME (hero giant type + footer stay full-bleed) ---------- */
.masthead,.hero-meta,.pullquote,.editorials,.pillars,.folio,.foot-cta{
  max-width:1360px;margin-left:auto;margin-right:auto}
@media(min-width:1500px){
  .masthead,.hero-meta,.pullquote,.editorials,.pillars,.folio{padding-left:0;padding-right:0}
}

/* ---------- MASTHEAD ---------- */
.masthead{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:76px 4vw 0;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--grey)}
.masthead .rule{flex:1;height:1px;background:var(--hair)}
.barcode{display:flex;gap:2px;align-items:flex-end;height:18px}
.barcode i{display:block;width:2px;background:var(--ink)}
.barcode i:nth-child(odd){height:100%}.barcode i:nth-child(even){height:60%}.barcode i:nth-child(3n){width:4px}

/* ---------- HERO ---------- */
.hero{position:relative;padding:2vh 0 6vh;min-height:88vh}
.ghost-word{position:absolute;top:0;left:-2vw;font-family:'Anton',sans-serif;font-size:24vw;line-height:.9;color:transparent;-webkit-text-stroke:1px var(--ghost);letter-spacing:.02em;white-space:nowrap;user-select:none;z-index:0;will-change:transform}
.ghost-word.fill{color:var(--ghost);-webkit-text-stroke:0}
.hero-title{position:relative;z-index:2;padding:3.5vw 4vw 0;font-family:'Anton',sans-serif;font-size:clamp(56px,10.5vw,164px);line-height:.92;text-transform:uppercase;color:var(--lime)}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line>span{display:block;transform:translateY(110%);transition:transform 1.1s var(--ease)}
.hero-title .line:nth-child(2)>span{transition-delay:.12s}
body.split .hero-title .line>span{transform:none;transition:none}
.hero-title .ch{display:inline-block;transform:translateY(115%) rotate(4deg);transition:transform .85s var(--ease)}
body.loaded .hero-title .ch{transform:translateY(0) rotate(0)}
.hero-title .line:nth-child(2){margin-left:8vw;margin-right:-6vw}
body.loaded .hero-title .line>span{transform:translateY(0)}
.hero-meta{position:relative;z-index:2;display:flex;flex-wrap:wrap;gap:6vw;align-items:flex-start;padding:4vh 4vw 0}
.portrait-wrap{width:min(300px,72vw)}
.side-label{position:absolute;right:18px;top:30vh;writing-mode:vertical-rl;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.4em;color:var(--grey);text-transform:uppercase;z-index:3}

/* portrait */
.portrait-wrap{position:relative;width:min(340px,72vw);flex-shrink:0;perspective:900px}
.portrait{position:relative;transform-style:preserve-3d;transition:transform .2s ease-out;
  clip-path:polygon(0 2%,4% 0,96% 1%,100% 4%,99% 96%,95% 100%,5% 99%,1% 95%);
  background:#161618;border:1px solid var(--hair)}
.portrait svg{display:block;width:100%;height:auto;filter:grayscale(1) contrast(1.15)}
.halftone{position:absolute;inset:0;background-image:radial-gradient(rgba(0,0,0,.55) 1px,transparent 1.5px);background-size:4px 4px;mix-blend-mode:multiply;pointer-events:none}
.misreg{position:absolute;inset:0;background:linear-gradient(120deg,rgba(216,255,30,0),rgba(216,255,30,.07));opacity:0;transition:opacity .4s;pointer-events:none}
.portrait-wrap:hover .misreg{opacity:1}
.tape{position:absolute;top:-12px;left:34%;width:110px;height:26px;background:var(--lime);opacity:.85;transform:rotate(-4deg);z-index:4;box-shadow:0 2px 10px rgba(0,0,0,.4)}
.credit{margin-top:12px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--grey)}
.hero-quote{max-width:380px;padding-top:4vh}
.hero-quote p{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(18px,1.6vw,24px);line-height:1.5;color:var(--ink)}
.hero-quote .who{margin-top:22px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.3em;color:var(--lime);text-transform:uppercase}

/* ---------- MARQUEE ---------- */
.marquee{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);overflow:hidden;padding:18px 0;background:var(--bg2)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;width:max-content;animation:marquee 28s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:'Anton',sans-serif;font-size:clamp(20px,2.6vw,38px);text-transform:uppercase;letter-spacing:.04em;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.35)}
.marquee-track span.lime{color:var(--lime);-webkit-text-stroke:0}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- SECTION FURNITURE ---------- */
.folio{display:flex;align-items:center;gap:16px;padding:0 4vw;margin:9vh 0 0;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--grey)}
.folio .rule{flex:1;height:1px;background:var(--hair)}

/* ---------- PULL QUOTE ---------- */
.pullquote{position:relative;padding:10vh 4vw;text-align:center}
.pullquote blockquote{font-family:'Playfair Display',serif;font-weight:700;font-size:clamp(32px,4.8vw,72px);line-height:1.18;font-style:italic;max-width:22ch;margin:0 auto}
.pullquote .hl{position:relative;display:inline-block}
.pullquote .hl svg{position:absolute;left:0;bottom:-.08em;width:100%;height:.28em;overflow:visible}
.pullquote .hl path{fill:none;stroke:var(--lime);stroke-width:5;stroke-linecap:round;stroke-dasharray:1000;stroke-dashoffset:1000}
.pullquote.visible .hl path{animation:draw 1.1s var(--ease) forwards}
.pullquote .hl:nth-of-type(2) path{animation-delay:.35s}
@keyframes draw{to{stroke-dashoffset:0}}
.pullquote .attrib{margin-top:4vh;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.45em;color:var(--grey);text-transform:uppercase}

/* ---------- EDITORIALS ---------- */
.editorials{padding:6vh 4vw 4vh}
.ed-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6vh}
.ed-head h2{font-family:'Anton',sans-serif;font-size:clamp(26px,3vw,44px);text-transform:uppercase;letter-spacing:.03em}
.ed-head .range{font-family:'Space Mono',monospace;font-size:11px;color:var(--lime);letter-spacing:.25em}
.ed-grid{display:grid;grid-template-columns:1fr 1fr;gap:4vw;align-items:start}
@media(max-width:760px){.ed-grid{grid-template-columns:1fr}}
.card{position:relative;border:1px solid var(--hair);background:#0e0e10;padding:42px 34px 34px;min-height:380px;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;transition:transform .5s var(--ease),border-color .5s,box-shadow .5s}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--lime);transform:scaleX(.18);transform-origin:left;transition:transform .6s var(--ease)}
.card:hover::before{transform:scaleX(1)}
.card:hover{transform:translateY(-10px);border-color:var(--lime-dim);box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 0 1px var(--lime-dim)}
.card .num{position:absolute;right:-10px;bottom:-30px;font-family:'Anton',sans-serif;font-size:13rem;line-height:1;color:var(--ghost);user-select:none;transition:transform .6s var(--ease),color .6s}
.card:hover .num{transform:translateY(-12px);color:rgba(216,255,30,.08)}
.card .cat{display:flex;justify-content:space-between;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--grey);margin-bottom:auto}
.card .cat .arrow{color:var(--lime);transition:transform .4s var(--ease)}
.card:hover .cat .arrow{transform:translate(6px,-6px)}
.card h3{position:relative;font-family:'Anton',sans-serif;font-size:clamp(30px,3.2vw,52px);line-height:1.02;text-transform:uppercase;margin:26px 0 14px}
.card p{font-size:14px;line-height:1.6;color:var(--grey);max-width:34ch}
.card.tilt{transform:rotate(-1.6deg)}
.card.tilt:hover{transform:rotate(0) translateY(-10px)}
.card.offset{margin-top:8vh}
@media(max-width:760px){.card.offset{margin-top:0}}
.card .tab{position:absolute;top:0;left:34px;background:var(--lime);color:#0a0a0b;font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.2em;padding:4px 10px;text-transform:uppercase}

/* ---------- PILLARS ---------- */
.pillars{padding:10vh 4vw 12vh}
.pillars h2{font-family:'Anton',sans-serif;font-size:clamp(26px,3vw,44px);text-transform:uppercase;margin-bottom:5vh}
.pillars h2 em{font-style:normal;color:var(--lime)}
.row{position:relative;display:grid;grid-template-columns:160px 1fr 1.2fr auto;gap:3vw;align-items:center;padding:34px 0;border-top:1px solid var(--hair);transition:background .4s,padding-left .4s var(--ease)}
.row:last-child{border-bottom:1px solid var(--hair)}
.row:hover{background:rgba(255,255,255,.025);padding-left:14px}
.row .rnum{font-family:'Anton',sans-serif;font-size:64px;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.18);transition:color .4s,-webkit-text-stroke .4s}
.row:hover .rnum{color:var(--lime);-webkit-text-stroke:0}
.row .rname{font-family:'Anton',sans-serif;font-size:clamp(20px,2.4vw,36px);text-transform:uppercase;letter-spacing:.02em}
.row .rdesc{font-size:14px;color:var(--grey);line-height:1.6;max-width:46ch}
.row .rarrow{font-family:'Space Mono',monospace;color:var(--lime);font-size:20px;transform:translateX(-8px);opacity:0;transition:all .4s var(--ease)}
.row:hover .rarrow{transform:translateX(0);opacity:1}
@media(max-width:760px){.row{grid-template-columns:70px 1fr;grid-template-rows:auto auto}.row .rdesc{grid-column:2}.row .rarrow{display:none}.row .rnum{font-size:40px}}

/* ---------- FOOTER ---------- */
footer{position:relative;padding:14vh 0 0;overflow:hidden;background:linear-gradient(#0a0a0b,#070708)}
.foot-cta{text-align:center;margin-bottom:8vh;padding:0 4vw}
.foot-cta .small{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--grey);display:block;margin-bottom:18px}
.foot-cta a.mail{font-family:'Playfair Display',serif;font-style:italic;font-size:clamp(22px,3vw,42px);border-bottom:1px solid var(--hair);transition:border-color .4s,color .4s}
.foot-cta a.mail:hover{color:var(--lime);border-color:var(--lime)}
.giant-wrap{position:relative;line-height:.72;text-align:center}
.giant{font-family:'Anton',sans-serif;font-size:23vw;text-transform:uppercase;color:rgba(255,255,255,.10);letter-spacing:.01em;transition:letter-spacing 1s var(--ease),color 1s;display:inline-block;transform:translateY(18%)}
.giant-wrap:hover .giant{letter-spacing:.09em;color:rgba(255,255,255,.16)}
.sticker{position:absolute;right:12vw;top:6%;background:var(--lime);color:#0a0a0b;font-family:'Anton',sans-serif;font-size:clamp(16px,2vw,30px);text-transform:uppercase;padding:14px 26px;transform:rotate(-7deg);box-shadow:0 10px 30px rgba(0,0,0,.5);transition:transform .4s var(--ease);z-index:5}
.sticker:hover{transform:rotate(-3deg) scale(1.06)}
.sticker small{display:block;font-family:'Space Mono',monospace;font-size:8px;letter-spacing:.2em}
/* flex-wrap added 2026-06-10 so the stacked network/documents rows
   wrap on narrow screens instead of overflowing. No visual change
   at desktop widths. */
.foot-bar{position:relative;display:flex;justify-content:space-between;gap:20px;padding:18px 4vw;border-top:1px solid var(--hair);font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey);background:#060607;flex-wrap:wrap}
.foot-bar .links{display:flex;gap:26px;flex-wrap:wrap}
.foot-bar a:hover{color:var(--lime)}

/* ---------- REVEAL ---------- */
[data-reveal]{opacity:0;transform:translateY(48px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].visible{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  body{cursor:auto}.cursor-dot,.cursor-ring{display:none}
  [data-reveal]{opacity:1;transform:none}
  .hero-title .line>span{transform:none}
}
