/* =========================================================
   RUNE — immersive single-scroll · jet black · luminous
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Syncopate:wght@400;700&family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500&display=swap');

:root{
  --bg:#000000;--panel:#050505;
  --ink:#f4f2ec;--dim:#8d8a82;--faint:#4a4843;--bone:#e9e2d1;
  --line:rgba(244,242,236,.10);--line-soft:rgba(244,242,236,.05);
  --maxw:1280px;--ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
/* overflow-x:clip stops sideways scroll WITHOUT breaking position:sticky */
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:#000;overflow-x:clip}
.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-stopped{overflow:hidden}
body{background:var(--bg);color:var(--ink);font-family:'Space Grotesk',system-ui,sans-serif;font-weight:400;
  line-height:1.6;overflow-x:clip;cursor:none}
@media (hover:none){body{cursor:auto}}
a{color:inherit;text-decoration:none}img,canvas,svg{display:block;max-width:100%}
::selection{background:var(--bone);color:#000}

/* overlays */
.grain{position:fixed;inset:-150%;z-index:90;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 6s steps(6) infinite}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-6%,3%)}40%{transform:translate(3%,-6%)}
  60%{transform:translate(-4%,4%)}80%{transform:translate(5%,-3%)}100%{transform:translate(0,0)}}
.vignette{position:fixed;inset:0;z-index:85;pointer-events:none;
  background:radial-gradient(125% 95% at 50% 42%,transparent 50%,rgba(0,0,0,.78) 100%)}

/* cursor */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:100;pointer-events:none;border-radius:50%;
  mix-blend-mode:difference;will-change:transform}
.cursor-dot{width:6px;height:6px;background:#fff;transform:translate(-50%,-50%)}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(255,255,255,.55);transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s}
.cursor-ring.hover{width:66px;height:66px;background:rgba(255,255,255,.07);border-color:transparent}
@media (hover:none){.cursor-dot,.cursor-ring{display:none!important}}

/* preloader */
.preloader{position:fixed;inset:0;z-index:120;background:#000;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:34px}
.preloader .pl-logo{width:74px;height:118px;overflow:visible;animation:plFloat 3.4s ease-in-out infinite}
.preloader .pl-logo path{stroke:var(--bone);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1;stroke-dashoffset:1;filter:drop-shadow(0 0 9px rgba(233,226,209,.6))}
.preloader .pl-logo .stem{animation:plDraw 1.3s var(--ease) .1s forwards, plGlow 2.6s ease-in-out 1.5s infinite}
.preloader .pl-logo .arms{animation:plDraw 1.2s var(--ease) .7s forwards, plGlow 2.6s ease-in-out 1.9s infinite}
@keyframes plDraw{to{stroke-dashoffset:0}}
@keyframes plGlow{0%,100%{filter:drop-shadow(0 0 6px rgba(233,226,209,.45))}50%{filter:drop-shadow(0 0 18px rgba(233,226,209,1))}}
@keyframes plFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.preloader .pl-bar{width:170px;height:1px;background:var(--line);position:relative;overflow:hidden}
.preloader .pl-bar i{position:absolute;inset:0;background:var(--bone);transform-origin:left;transform:scaleX(0);
  box-shadow:0 0 14px rgba(233,226,209,.7)}
.preloader .pl-count{font-family:'Syncopate';font-size:12px;letter-spacing:.45em;color:var(--dim)}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:70;display:flex;align-items:center;justify-content:space-between;
  padding:26px 42px;transition:padding .5s var(--ease),background .5s,border-color .5s;border-bottom:1px solid transparent}
.nav.scrolled{padding:15px 42px;background:rgba(0,0,0,.55);backdrop-filter:blur(18px);border-bottom:1px solid var(--line-soft)}
.nav .brand{font-family:'Syncopate';font-weight:700;font-size:15px;letter-spacing:.42em}
.nav .links{display:flex;align-items:center;gap:34px}
.nav .links a{font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);position:relative;transition:color .3s}
.nav .links a:hover{color:var(--ink)}
.nav .links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--bone);transition:width .4s var(--ease)}
.nav .links a:hover::after{width:100%}

/* ===== HERO (extra dark) ===== */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;background:#000}
.hero-media .img{position:absolute;inset:-3%;background-size:cover;background-position:center;transform:scale(1.1);
  filter:brightness(.5) contrast(1.05);will-change:transform}
.hero-media::after{content:"";position:absolute;inset:0;z-index:3;
  background:radial-gradient(58% 58% at 50% 47%,rgba(0,0,0,.42) 0%,rgba(0,0,0,.74) 54%,rgba(0,0,0,.98) 100%),
             linear-gradient(180deg,#000 0%,rgba(0,0,0,.45) 30%,rgba(0,0,0,.8) 74%,#000 100%)}
.smoke{position:absolute;inset:0;z-index:2;mix-blend-mode:screen;opacity:.85;pointer-events:none}

.hero-logo{position:relative;z-index:4;text-align:center;padding:0 24px;display:flex;flex-direction:column;align-items:center;perspective:1100px}
.hero-logo::before{content:"";position:absolute;left:50%;top:52%;transform:translate(-50%,-50%);
  width:130%;height:230%;z-index:0;pointer-events:none;
  background:radial-gradient(46% 42% at 50% 50%,rgba(0,0,0,.85),rgba(0,0,0,.4) 60%,transparent 78%);filter:blur(26px)}
.hero-logo .rays{position:absolute;left:50%;top:50%;width:min(150vw,1100px);height:min(150vw,1100px);
  transform:translate(-50%,-50%);z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:screen;
  background:conic-gradient(from 0deg,transparent 0 6deg,rgba(233,226,209,.10) 6.4deg 7deg,transparent 7.4deg 60deg,
    rgba(233,226,209,.10) 60.4deg 61deg,transparent 61.4deg 124deg,rgba(233,226,209,.10) 124.4deg 125deg,
    transparent 125.4deg 188deg,rgba(233,226,209,.10) 188.4deg 189deg,transparent 189.4deg 252deg,
    rgba(233,226,209,.10) 252.4deg 253deg,transparent 253.4deg 316deg,rgba(233,226,209,.10) 316.4deg 317deg,transparent 317.4deg 360deg);
  -webkit-mask:radial-gradient(circle,#000 0%,#000 18%,transparent 62%);mask:radial-gradient(circle,#000 0%,#000 18%,transparent 62%);
  animation:spin 60s linear infinite}
@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.hero-logo .halo{position:absolute;left:50%;top:50%;width:min(90vw,640px);height:min(90vw,640px);
  transform:translate(-50%,-50%);z-index:0;pointer-events:none;mix-blend-mode:screen;filter:blur(14px);
  background:radial-gradient(circle,rgba(255,253,245,.5) 0%,rgba(233,226,209,.24) 20%,rgba(233,226,209,.07) 42%,transparent 64%);
  animation:breathe 4.2s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.7;transform:translate(-50%,-50%) scale(.96)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.14)}}

.logo-tilt{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;transform-style:preserve-3d;will-change:transform}
.hero-logo .mark{display:block;width:88px;height:142px;margin:0 auto 22px;overflow:visible;opacity:0;transform:translateZ(45px)}
.hero-logo .mark path{stroke:var(--bone);fill:none;stroke-width:2;stroke-linecap:round}
.hero-logo.go .mark{animation:floaty 5s ease-in-out infinite}
.hero-logo.go .mark path{animation:markglow 4.2s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes markglow{0%,100%{filter:drop-shadow(0 0 7px rgba(233,226,209,.5))}50%{filter:drop-shadow(0 0 18px rgba(233,226,209,.95))}}
.word-wrap{position:relative;display:inline-block;font-size:clamp(2.2rem,8vw,6.4rem);line-height:1;transform:translateZ(22px)}
.hero-logo .word{display:block;position:relative;z-index:2;font-family:'Syncopate';font-weight:700;font-size:1em;
  letter-spacing:.22em;line-height:1;margin-left:.22em;opacity:0;
  background:radial-gradient(58% 150% at var(--mx,50%) var(--my,30%),#ffffff 0%,#f1ebda 36%,#c6beab 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-logo.go .word{animation:starglow 4.2s ease-in-out infinite}
@keyframes starglow{0%,100%{filter:drop-shadow(0 0 16px rgba(233,226,209,.45)) drop-shadow(0 0 38px rgba(233,226,209,.22))}
  50%{filter:drop-shadow(0 0 30px rgba(255,253,245,.85)) drop-shadow(0 0 78px rgba(233,226,209,.5))}}
.hero-logo .tag{position:relative;z-index:2;margin-top:26px;font-size:10px;letter-spacing:.55em;text-transform:uppercase;color:var(--dim);opacity:0}

.scroll-cue{position:absolute;left:50%;bottom:32px;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;
  align-items:center;gap:12px;color:var(--dim);font-size:10px;letter-spacing:.4em;text-transform:uppercase;opacity:0}
.scroll-cue .line{width:1px;height:50px;background:linear-gradient(var(--bone),transparent);position:relative;overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--bone);animation:drop 2.2s var(--ease) infinite}
@keyframes drop{0%{top:-60%}100%{top:120%}}

/* generic */
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 42px}
.block{padding:clamp(110px,20vh,240px) 0}
.eyebrow{font-family:'Syncopate';font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--dim)}
.statement{font-size:clamp(1.9rem,5vw,4rem);font-weight:400;line-height:1.16;letter-spacing:-.015em}
.statement .bone,.bone{color:var(--bone)}
.lead{font-size:clamp(1.05rem,1.5vw,1.3rem);color:var(--dim);font-weight:300;max-width:60ch;line-height:1.7}
.reveal-line{overflow:hidden;display:block}
.reveal-line>span{display:block;transform:translateY(110%);will-change:transform}
.fade{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.fade.in{opacity:1;transform:none}

/* marquee */
.marquee{padding:34px 0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  overflow:hidden;white-space:nowrap;background:#000;will-change:transform}
.marquee .track{display:inline-flex;gap:50px;will-change:transform;animation:marq 30s linear infinite}
.marquee:hover .track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.marquee span{font-family:'Syncopate';font-weight:700;font-size:clamp(1.4rem,3vw,2.4rem);letter-spacing:.16em;
  color:transparent;-webkit-text-stroke:1px rgba(233,226,209,.35);text-transform:uppercase}
.marquee span.sol{color:var(--bone);-webkit-text-stroke:0}

/* movement */
.movement{position:relative;overflow:hidden}
.movement .mbg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;z-index:0;opacity:.5;will-change:transform}
.movement::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,#000 0%,rgba(0,0,0,.4) 28%,rgba(0,0,0,.45) 60%,#000 100%),
            radial-gradient(70% 70% at 50% 45%,transparent,rgba(0,0,0,.55) 100%)}
.movement .wrap{position:relative;z-index:2}
.big-lines{font-size:clamp(2rem,6vw,5rem);font-weight:500;line-height:1.12;letter-spacing:-.02em}
.big-lines .reveal-line>span{color:var(--ink)}
.big-lines .soft span{color:var(--faint)}
.deny{display:flex;flex-wrap:wrap;gap:18px 30px;margin-top:64px}
.deny b{font-family:'Syncopate';font-weight:700;font-size:clamp(1.05rem,2.4vw,1.8rem);letter-spacing:.1em;text-transform:uppercase;
  color:transparent;-webkit-text-stroke:1px rgba(233,226,209,.55);animation:floatGlow 4.5s ease-in-out infinite}
.deny b:nth-child(2){animation-delay:.4s}.deny b:nth-child(3){animation-delay:.8s}.deny b:nth-child(4){animation-delay:1.2s}
.deny .only{color:var(--bone);-webkit-text-stroke:0;text-shadow:0 0 18px rgba(233,226,209,.6),0 0 44px rgba(233,226,209,.35)}
@keyframes floatGlow{0%,100%{transform:translateY(0);text-shadow:0 0 0 transparent}
  50%{transform:translateY(-10px);text-shadow:0 0 22px rgba(233,226,209,.5)}}

/* order */
.order{position:relative}
.order .head{position:sticky;top:0;height:100svh;display:flex;flex-direction:column;justify-content:center;pointer-events:none}
.order .head .idx{font-family:'Syncopate';font-weight:700;font-size:clamp(7rem,30vw,24rem);line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(233,226,209,.16)}
.order .panels{position:relative;z-index:2;margin-top:-100svh}
.principle{min-height:100svh;display:flex;align-items:center;border-top:1px solid var(--line-soft)}
.principle:first-child{border-top:0}
.principle .inner{max-width:680px;margin-left:auto;position:relative;z-index:1}
.principle .n{font-family:'Syncopate';font-size:13px;letter-spacing:.3em;color:var(--bone);margin-bottom:26px}
.principle h3{font-size:clamp(2.6rem,7vw,5.5rem);font-weight:600;letter-spacing:-.02em;line-height:1;margin-bottom:24px}
.principle p{font-size:clamp(1.1rem,1.7vw,1.5rem);color:var(--dim);font-weight:300;max-width:44ch}

/* origins */
.origins .people{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;margin-top:70px}
.person{position:relative}
.person .photo{position:relative;aspect-ratio:3/4;overflow:hidden;background:#0a0a0a;border:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:center}
.person .photo .ph-img{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:grayscale(1) brightness(.42) contrast(1.1);transform:scale(1.05);transition:transform 1.2s var(--ease),filter .6s}
.person:hover .photo .ph-img{transform:scale(1.12);filter:grayscale(1) brightness(.62) contrast(1.15)}
.person .photo svg{position:relative;z-index:2;width:32px;height:52px;opacity:.5}
.person .photo svg path{stroke:var(--bone);fill:none;stroke-width:2.4;stroke-linecap:round}
.person .photo .tagph{position:absolute;z-index:2;bottom:14px;left:14px;font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.person .name{margin-top:22px;font-size:1.5rem;font-weight:600;letter-spacing:-.01em}
.person .role{font-family:'Syncopate';font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--bone);margin-top:8px}
.person .story{margin-top:16px;color:var(--dim);font-size:.96rem;font-weight:300;line-height:1.7}

/* connect */
.connect{position:relative;overflow:hidden;border-top:1px solid var(--line-soft);min-height:100svh;display:flex;align-items:center}
.connect .cbg{position:absolute;inset:-12% 0;background-size:cover;background-position:center;z-index:0;opacity:.3;will-change:transform;filter:grayscale(1) contrast(1.05)}
.connect::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,#000,rgba(0,0,0,.55) 40%,#000),radial-gradient(80% 80% at 70% 30%,rgba(233,226,209,.05),transparent 60%)}
.connect .wrap{position:relative;z-index:2;width:100%;padding-top:120px;padding-bottom:120px}
.connect .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
.connect .huge{font-family:'Syncopate';font-weight:700;font-size:clamp(2.6rem,7vw,5.4rem);letter-spacing:.02em;line-height:1.02;margin:18px 0 26px}
.connect .huge .bone{color:var(--bone);text-shadow:0 0 30px rgba(233,226,209,.4)}
.connect .sub{color:var(--dim);font-weight:300;font-size:clamp(1rem,1.4vw,1.2rem);max-width:46ch;margin-bottom:46px}
.clinks{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.clink{position:relative;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 0;
  border-bottom:1px solid var(--line);color:var(--ink);overflow:hidden;transition:padding-left .45s var(--ease)}
.clink::before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,rgba(233,226,209,.10),transparent);transition:width .45s var(--ease)}
.clink:hover{padding-left:22px}.clink:hover::before{width:100%}
.clink .k{position:relative;font-family:'Syncopate';font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);min-width:90px}
.clink .v{position:relative;flex:1;font-size:clamp(1.05rem,2vw,1.6rem);font-weight:500;word-break:break-word}
.clink .arr{position:relative;font-size:1.3rem;color:var(--dim);transition:transform .45s var(--ease),color .45s}
.clink:hover .arr{transform:translateX(10px);color:var(--bone)}
.ccard{background:rgba(8,8,8,.6);border:1px solid var(--line);backdrop-filter:blur(8px);padding:42px 40px}
.ccard h4{font-family:'Syncopate';font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:28px}
.form{display:grid;gap:26px}
.field{position:relative}
.field input,.field select,.field textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  color:var(--ink);font-family:inherit;font-size:1.02rem;padding:13px 0;transition:border-color .4s}
.field textarea{resize:vertical;min-height:80px}
.field label{position:absolute;left:0;top:13px;color:var(--faint);font-size:1.02rem;pointer-events:none;transition:.35s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--bone)}
.field input:focus+label,.field input:valid+label,.field textarea:focus+label,.field textarea:valid+label,
.field select:focus+label,.field select:valid+label{top:-11px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--bone)}
.field select{cursor:pointer}.field select option{background:#0a0a0a}
.submit{position:relative;display:inline-flex;align-items:center;gap:12px;font-family:'Syncopate';font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;padding:18px 36px;border:1px solid var(--bone);color:#000;background:var(--bone);overflow:hidden;cursor:none;
  will-change:transform;transition:transform .35s var(--ease),color .4s var(--ease)}
.submit span{position:relative;z-index:2}
.submit::before{content:"";position:absolute;inset:0;background:#000;z-index:1;transform:translateY(101%);transition:transform .5s var(--ease)}
.submit:hover{color:var(--bone)}.submit:hover::before{transform:translateY(0)}
#form-note{color:var(--dim);font-size:.82rem;min-height:1em}

/* footer */
.footer{padding:70px 0 44px;background:#000;position:relative;z-index:2}
.footer .big{font-family:'Syncopate';font-weight:700;font-size:clamp(3.4rem,20vw,17rem);letter-spacing:.1em;line-height:.8;
  color:transparent;-webkit-text-stroke:1px rgba(233,226,209,.16);text-align:center;margin-bottom:50px;user-select:none}
.footer .base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:26px;border-top:1px solid var(--line-soft);
  font-size:.76rem;letter-spacing:.06em;color:var(--faint)}
.footer .base a:hover{color:var(--ink)}

/* desktop-ish breakpoints */
@media (max-width:980px){.connect .grid{grid-template-columns:1fr;gap:54px}}
@media (max-width:880px){
  .nav{padding:20px 22px}.nav.scrolled{padding:14px 22px}
  .wrap{padding:0 22px}
  .principle .inner{margin-left:0}
  .origins .people{grid-template-columns:1fr;gap:48px;max-width:420px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .reveal-line>span{transform:none}.fade{opacity:1;transform:none}
  .hero-logo .mark,.hero-logo .word,.hero-logo .tag,.scroll-cue{opacity:1}
  .hero-media .img{transform:scale(1)}
}

/* ===== added motion: progress · tilt · 3D wireframe accents ===== */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:100%;transform:scaleX(0);transform-origin:left;z-index:95;
  background:linear-gradient(90deg,var(--bone),#fff);box-shadow:0 0 14px rgba(233,226,209,.7);pointer-events:none}
.person,.principle .inner{transition:transform .5s var(--ease);transform-style:preserve-3d;will-change:transform}
.accent3d{position:absolute;pointer-events:none;z-index:0;perspective:1100px;opacity:.13}
.accent3d.a-ord{top:12%;right:5%;width:230px;height:230px;--hz:115px}
.accent3d.a-con{bottom:9%;left:4%;width:170px;height:170px;--hz:85px}
.cube3d{position:relative;width:100%;height:100%;transform-style:preserve-3d;animation:cubeSpin 28s linear infinite}
.cube3d .face{position:absolute;inset:0;border:1px solid var(--bone)}
.cube3d .fz{transform:translateZ(var(--hz))}
.cube3d .bz{transform:rotateY(180deg) translateZ(var(--hz))}
.cube3d .rt{transform:rotateY(90deg) translateZ(var(--hz))}
.cube3d .lf{transform:rotateY(-90deg) translateZ(var(--hz))}
.cube3d .tp{transform:rotateX(90deg) translateZ(var(--hz))}
.cube3d .bt{transform:rotateX(-90deg) translateZ(var(--hz))}
@keyframes cubeSpin{from{transform:rotateX(0) rotateY(0)}to{transform:rotateX(360deg) rotateY(360deg)}}
@media (max-width:880px){.accent3d{display:none}}
@media (prefers-reduced-motion:reduce){.accent3d,.scroll-prog{display:none}}

/* ===== pinned horizontal SPACES gallery + 3D orb (desktop) ===== */
.gallery{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:center;
  background:#000;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.gtrack{display:flex;align-items:center;gap:34px;padding:0 8vw;will-change:transform}
.gpanel{flex:0 0 auto}
.gintro{width:min(78vw,520px);display:flex;flex-direction:column;gap:30px}
.gintro .g-h,.gend .g-h{font-family:'Syncopate';font-weight:700;font-size:clamp(2rem,5vw,4rem);line-height:1.05;letter-spacing:-.01em}
.orb-wrap{perspective:800px;width:200px;height:200px;margin-top:6px}
.orb{position:relative;width:100%;height:100%;transform-style:preserve-3d;animation:orbSpin 24s linear infinite}
.orb .ring{position:absolute;inset:0;border:1px solid rgba(233,226,209,.45);border-radius:50%}
.orb .ring:nth-child(2){transform:rotateY(60deg)}
.orb .ring:nth-child(3){transform:rotateY(120deg)}
.orb .ring:nth-child(4){transform:rotateX(72deg)}
@keyframes orbSpin{to{transform:rotateY(360deg) rotateX(8deg)}}
.gcard{position:relative;width:min(70vw,420px);height:62vh;overflow:hidden;border:1px solid var(--line-soft);background:#0a0a0a}
.gcard .gimg{position:absolute;inset:-6% -14%;background-size:cover;background-position:center;
  filter:grayscale(1) contrast(1.05) brightness(.82);will-change:transform}
.gcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(0,0,0,.9))}
.gcard .ginfo{position:absolute;left:0;bottom:0;padding:30px;z-index:2}
.gcard .gn{font-family:'Syncopate';font-size:11px;letter-spacing:.3em;color:var(--bone)}
.gcard .gt{font-size:clamp(1.5rem,3vw,2.4rem);font-weight:600;margin-top:10px;letter-spacing:-.01em}
.gcard .gtag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-top:6px}
.gend{display:flex;align-items:center}

/* SPACES → stacked vertical layout on ANY touch device or narrow screen */
@media (max-width:900px), (hover:none){
  .gallery{height:auto;display:block;overflow:visible;padding:78px 0}
  .gtrack{flex-direction:column;transform:none!important;gap:22px;padding:0 22px;width:auto}
  .gpanel{width:100%}
  .gintro{width:auto;align-items:flex-start}
  .gcard{width:100%;height:56vh}
  .gcard .ginfo{opacity:1!important;transform:none!important}
  .orb-wrap{display:none}
  .gend{padding:10px 0}
}

/* ===== global network · 3D globe ===== */
.network{position:relative;min-height:110vh;overflow:hidden;background:#000;border-top:1px solid var(--line-soft)}
.network .globe-holder{position:absolute;inset:0;z-index:0;background:radial-gradient(60% 60% at 50% 60%,rgba(20,26,44,.5),#000 75%)}
.network .globe-holder canvas{display:block}
.network .net-copy{position:absolute;z-index:2;top:13%;left:0;right:0;margin:0 auto;max-width:var(--maxw);padding:0 42px;pointer-events:none}
.network .net-copy .statement{margin:18px 0 24px;text-shadow:0 4px 40px #000}
.network .net-copy .lead{max-width:44ch;text-shadow:0 2px 24px #000}
.network .net-cities{margin-top:24px;font-family:'Syncopate';font-size:clamp(.68rem,1.3vw,.95rem);letter-spacing:.18em;
  text-transform:uppercase;color:var(--bone);text-shadow:0 2px 20px #000}

/* =========================================================
   MOBILE / SMALL-SCREEN OPTIMISATION
   ========================================================= */
@media (max-width:760px){
  .block{padding:clamp(70px,12vh,130px) 0}
  .nav .links{display:none}

  /* THE ORDER → stacked, each principle gets its own big 01–04 number */
  .order .head{position:static;height:auto;display:block;padding:64px 0 6px;pointer-events:auto}
  .order .head .idx{display:none}
  .order .panels{margin-top:0}
  .principle{min-height:auto;display:block;padding:48px 0 40px;position:relative;overflow:hidden}
  .principle:first-child{padding-top:0;border-top:0}
  .principle .inner{margin-left:0;max-width:none}
  .principle::before{content:attr(data-idx);position:absolute;top:6px;right:-1%;z-index:0;pointer-events:none;
    font-family:'Syncopate';font-weight:700;font-size:30vw;line-height:.78;color:transparent;
    -webkit-text-stroke:1px rgba(233,226,209,.16);opacity:0;transform:translateX(14px);
    transition:opacity .9s var(--ease),transform .9s var(--ease)}
  .principle.seen::before{opacity:1;transform:none}

  .connect{min-height:auto}
  .connect .wrap{padding-top:90px;padding-bottom:90px}
  .network{min-height:78vh}
  .network .net-copy{top:9%}
}

@media (max-width:480px){
  .wrap{padding:0 18px}
  .nav{padding:18px 18px}
  .hero{min-height:560px}
  .hero-logo{padding:0 18px}
  .hero-logo .mark{width:62px;height:100px;margin-bottom:16px}
  .word-wrap{font-size:clamp(2rem,12vw,3rem)}
  .hero-logo .tag{font-size:9px;letter-spacing:.4em}
  .big-lines{font-size:clamp(1.7rem,8vw,2.4rem)}
  .deny{gap:12px 18px;margin-top:44px}
  .statement{font-size:clamp(1.7rem,8vw,2.4rem)}
  .ccard{padding:26px 20px}
  .footer .base{flex-direction:column;gap:8px;text-align:left}
  .footer .big{font-size:24vw}
}
