/* ===========================================================================
   UniWardrobe — shared design system  (uw.css)
   Voice: "Worthy of the Memory". Light theme, warm. Fonts: Bricolage Grotesque
   (display), Hanken Grotesk (body), Space Mono (labels). No em dashes in copy.
   Edit tokens once here; every page follows.
   =========================================================================== */
:root{
  --cream:#FAF5E1;--paper:#FFFDF6;--amber:#F39130;--amber2:#e07a16;
  --ink:#1b1815;--sky:#118DC3;--whisper:#C9F2EA;--dune:#F4DFB0;--night:#141210;--muted:#8a8175;--line:#e8dcc0;
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}/* note: never set scroll-behavior:smooth here, it breaks ScrollTrigger + Lenis */
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--cream);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;line-height:.94;letter-spacing:-.025em}
a{color:inherit;text-decoration:none}img,video,canvas{display:block;max-width:100%}
.mono{font-family:'Space Mono',monospace}
em{font-style:normal;color:var(--amber)}
.amber{color:var(--amber)}
.center{text-align:center}

.grain{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.cursor, #cursor{position:fixed;top:0;left:0;width:14px;height:14px;border-radius:50%;background:var(--amber);z-index:9999;pointer-events:none;mix-blend-mode:multiply;transform:translate(-50%,-50%);transition:width .25s,height .25s;display:none}
.cursor.big, #cursor.big{width:74px;height:74px;background:rgba(243,145,48,.3)}
@media(hover:hover) and (pointer:fine){.cursor, #cursor{display:block}body,a,button,input{cursor:none}}

/* ---------- buttons ---------- */
.cta{font-family:'Bricolage Grotesque';font-weight:700;font-size:14px;background:var(--ink);color:var(--cream);padding:11px 18px;border-radius:40px;display:inline-flex;align-items:center;gap:8px;transition:transform .25s,background .25s;white-space:nowrap;border:none}
.cta.amber{background:var(--amber);color:var(--ink)}.cta.amber:hover{background:var(--ink);color:var(--cream)}
.cta.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}.cta.ghost:hover{border-color:var(--ink)}
.cta.lg{font-size:16px;padding:15px 26px}
.cta.light{background:#fff;color:var(--ink)}
.btnrow{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}

/* ---------- tickers ---------- */
.ticker{background:var(--ink);color:var(--cream);overflow:hidden}
.ticker.amber{background:var(--amber);color:var(--ink)}
.ticker .row{display:flex;width:max-content;animation:tick 22s linear infinite}
.ticker .item{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1rem,3.6vw,1.7rem);text-transform:uppercase;padding:11px 20px;white-space:nowrap;display:flex;gap:18px;align-items:center}
.ticker .item::after{content:"✦";color:var(--amber)}.ticker.amber .item::after{color:var(--ink)}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- header ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:15px clamp(20px,5vw,60px);transition:.35s;padding-top:max(15px,env(safe-area-inset-top))}
.header.scrolled{background:rgba(250,245,225,.85);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line)}
.header .logo{height:44px; transform: scale(2.5); transform-origin: left center;}
.header-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:32px}
.header-center .lnk{font-family:'Space Mono';font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:0.05em;color:var(--ink);text-decoration:none;}
.header-center .lnk:hover{color:var(--amber2)}
.header-right{display:flex;align-items:center;gap:20px}
.icon-btn{background:none;border:none;cursor:pointer;color:var(--ink);display:grid;place-items:center}
.icon-btn:hover{color:var(--amber)}
.icon-btn svg{width:22px;height:22px;stroke-width:2;stroke:currentColor;fill:none}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px;cursor:pointer}
.burger span{width:26px;height:2.5px;background:var(--ink);border-radius:2px}
@media(max-width:900px){.header-center{display:none}.burger{display:flex} .header .logo { transform: scale(2.2) translateX(-5px) !important; transform-origin: left center !important; height: 44px !important; }}

/* ---------- mobile menu ---------- */
.mm{position:fixed;inset:0;z-index:120;background:#0a0a0a;display:flex;flex-direction:column;justify-content:center;gap:4px;padding:40px;opacity:0;pointer-events:none;transition:.4s}
.mm.open{opacity:1;pointer-events:auto}.mm a{color:#fff;font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.9rem,8.5vw,2.6rem);padding:3px 0}.mm a:hover{color:var(--amber)}
.mm .close{position:absolute;top:20px;right:24px;color:#fff;font-size:28px;background:none;border:none}
.mm .mmcta{margin-top:18px;align-self:flex-start}

/* ---------- sticker ---------- */
.sticker{position:fixed;z-index:95;right:clamp(12px,4vw,34px);bottom:max(20px,env(safe-area-inset-bottom));width:92px;height:92px;display:grid;place-items:center;transition:opacity .4s,transform .4s}
.sticker svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 13s linear infinite}
.sticker .dot{width:46px;height:46px;border-radius:50%;background:var(--amber);display:grid;place-items:center;color:var(--ink);font-size:20px;box-shadow:0 8px 24px -8px rgba(243,145,48,.7)}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:560px){.sticker{width:74px;height:74px}.sticker .dot{width:36px;height:36px;font-size:16px}}
body.hide-sticker .sticker{opacity:0;pointer-events:none;transform:scale(.6)}

/* ---------- reveal guards (opacity only, never transform) ---------- */
.gsap-ready [data-reveal]{opacity:0}
.gsap-ready [data-anim]{opacity:0}
.gsap-ready .hero h1 .ln-in{opacity:0}
.gsap-ready .hero-kicker,.gsap-ready .hero-tagline{opacity:0}
.gsap-ready .frag{opacity:0}
[data-anim="chars"]{perspective:600px}

/* ---------- section base ---------- */
.section{position:relative;padding:clamp(64px,11vh,140px) clamp(18px,5vw,80px);overflow:hidden}
.section.tight{padding-top:clamp(40px,7vh,80px);padding-bottom:clamp(40px,7vh,80px)}
.wrap{max-width:var(--maxw);margin:0 auto}
.wrap.narrow{max-width:760px}
.idx{font-family:'Space Mono';font-weight:700;font-size:13px;letter-spacing:.18em;color:var(--amber2);display:inline-block;margin-bottom:16px}
.idx .bar{display:inline-block;width:32px;height:2px;background:currentColor;vertical-align:middle;margin-right:10px}
.bignum-bg{position:absolute;font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(8rem,30vw,24rem);color:rgba(27,24,21,.045);line-height:.66;z-index:0;pointer-events:none;letter-spacing:-.05em;will-change:transform;max-width:100%}
.h-xl{font-size:clamp(2.3rem,8.5vw,5.6rem)}.h-lg{font-size:clamp(1.9rem,6vw,3.6rem)}.h-md{font-size:clamp(1.6rem,4.5vw,2.6rem)}
.lede{font-size:clamp(1.05rem,2.4vw,1.35rem);color:#46403a;max-width:46ch;margin-top:18px}
.lede.wide{max-width:60ch}
.body{font-size:1.05rem;color:#46403a;max-width:60ch;margin-top:14px}
.eyebrow{font-family:'Space Mono';font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber2);display:block;margin-bottom:14px}
.dark{background:var(--night);color:#fff}
.dark .body,.dark .lede{color:rgba(255,255,255,.72)}
.dark .eyebrow{color:var(--amber)}
.splt .ln,.lines-split .ln{overflow:hidden;display:block}.splt .ln-in{display:block}

/* ---------- chapter marker (pinned scenes) ---------- */
.chapter{position:absolute;top:max(clamp(64px,9vh,90px),env(safe-area-inset-top));left:clamp(18px,5vw,80px);font-family:'Space Mono';font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--amber2);z-index:6}
.chapter.light{color:rgba(255,255,255,.75)}

/* ---------- fragments ---------- */
.fragset{margin-top:22px;display:flex;flex-direction:column;gap:6px}
.frag{font-family:'Bricolage Grotesque';font-weight:700;font-size:clamp(1.25rem,5vw,2.4rem);line-height:1.06;letter-spacing:-.02em}
.frag .mk{background:var(--amber);color:var(--ink);padding:0 .14em;border-radius:5px}
.frag .sk{color:var(--muted)}
.dark .frag .sk{color:rgba(255,255,255,.5)}

/* ---------- cut-out product ---------- */
.cut{width:100%;height:auto;mix-blend-mode:multiply;-webkit-mask-image:radial-gradient(128% 118% at 50% 47%,#000 50%,transparent 85%);mask-image:radial-gradient(128% 118% at 50% 47%,#000 50%,transparent 85%);will-change:transform}
.float{position:relative;z-index:1}
.bob{animation:bob 6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ===================== HERO (home, full-bleed media reel) ===================== */
.hero{position:relative;padding:84px clamp(10px,2.5vw,22px) 0;min-height:100svh;display:flex;flex-direction:column}
.reel{position:relative;flex:1;border-radius:22px;overflow:hidden;min-height:70svh;background:#d8c8a0;box-shadow:0 40px 90px -50px rgba(22,20,20,.55)}
.reel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.12);transition:opacity 1.1s ease}
.reel img.on{opacity:1}
.reel::after{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(255,250,235,.14) 0%,transparent 24%,transparent 42%,rgba(20,18,15,.6) 100%)}
.hero-copy{position:absolute;z-index:3;left:clamp(16px,4vw,46px);bottom:clamp(22px,5vw,48px);right:clamp(16px,4vw,46px)}
.hero-kicker{font-family:'Space Mono';font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:rgba(20,18,15,.4);backdrop-filter:blur(6px);padding:7px 12px;border-radius:30px;display:inline-block;margin-bottom:13px}
.hero h1{color:#fff;font-size:clamp(2.6rem,12vw,7.5rem);letter-spacing:-.035em;text-shadow:0 4px 30px rgba(0,0,0,.25)}
.hero h1 .ln{display:block;overflow:hidden}.hero h1 .ln i{display:block;font-style:normal}
.hero-tagline{color:rgba(255,255,255,.92);font-size:clamp(.95rem,2vw,1.2rem);font-weight:500;margin-top:11px;max-width:38ch}
.hero-scroll{position:absolute;z-index:3;right:clamp(14px,4vw,40px);top:clamp(78px,12vw,110px);color:#fff;font-family:'Space Mono';font-size:11px;letter-spacing:.14em;writing-mode:vertical-rl}
@media(min-width:880px){.reel{min-height:80svh}.hero-copy{max-width:80%}}

/* ===================== INNER HERO (image + copy) ===================== */
.hero-inner{position:relative;min-height:88svh;display:flex;align-items:flex-end;padding:120px clamp(18px,5vw,80px) clamp(40px,7vw,80px);overflow:hidden;color:#fff}
.hero-inner .bg{position:absolute;inset:0;z-index:-2}
.hero-inner .bg img{width:100%;height:100%;object-fit:cover}
.hero-inner::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,18,15,.25) 0%,transparent 30%,rgba(20,18,15,.78) 100%)}
.hero-inner.lightpaper{color:var(--ink);background:var(--paper);min-height:auto;padding-top:140px}
.hero-inner.lightpaper::after{display:none}
.hero-inner h1{font-size:clamp(2.6rem,10vw,6.4rem);max-width:16ch}
.hero-inner.lightpaper h1{color:var(--ink)}
.hero-inner .sub{font-size:clamp(1.05rem,2.6vw,1.5rem);margin-top:16px;max-width:42ch;color:rgba(255,255,255,.9)}
.hero-inner.lightpaper .sub{color:#46403a}
.hero-inner .eyebrow{color:var(--amber)}

/* ===================== two-column feature / beat ===================== */
.feature{display:grid;grid-template-columns:1fr;gap:32px;align-items:center}
.feature .visual{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3;background:var(--dune)}
.feature .visual img{width:100%;height:100%;object-fit:cover}
.feature .visual.cutbox{background:transparent;aspect-ratio:1/1;border-radius:0;overflow:visible;display:grid;place-items:center}
.feature.flip .text{order:2}
@media(min-width:860px){.feature{grid-template-columns:1fr 1fr;gap:54px}.feature.flip .visual{order:2}.feature.flip .text{order:1}}

/* ===================== Our Story beats ===================== */
.beat{display:grid;grid-template-columns:1fr;gap:28px;align-items:center;margin-top:clamp(56px,9vh,110px)}
.beat:first-of-type{margin-top:0}
.beat .num{font-family:'Space Mono';font-weight:700;font-size:13px;letter-spacing:.18em;color:var(--amber2)}
.beat .visual{border-radius:20px;overflow:hidden;aspect-ratio:4/3;background:var(--dune)}
.beat .visual img{width:100%;height:100%;object-fit:cover}
@media(min-width:860px){.beat{grid-template-columns:1fr 1fr;gap:54px}.beat.flip .visual{order:2}}

/* values cards */
.values{display:grid;grid-template-columns:1fr;gap:14px;margin-top:30px}
.valcard{background:var(--paper);border:1.5px solid var(--line);border-radius:18px;padding:24px}
.valcard h4{font-family:'Bricolage Grotesque';font-size:1.4rem;margin-bottom:8px}
.valcard p{color:#56504a;font-size:.98rem}
@media(min-width:680px){.values{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.values{grid-template-columns:repeat(4,1fr)}}
.mission{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2rem,6.5vw,3.8rem);letter-spacing:-.03em;line-height:1.02;max-width:18ch}

/* ===================== PINNED SCRUB SCENES (home) ===================== */
.pin-scene{height:100svh;min-height:540px;position:relative;overflow:hidden;display:block}
.s-sol{background:var(--paper)}
.sol-garment{position:absolute;left:50%;top:42%;width:min(66vw,380px);transform:translate(-50%,-50%);z-index:1;filter:drop-shadow(0 34px 40px rgba(20,18,15,.22))}
.sol-lines{position:absolute;left:0;right:0;bottom:13%;text-align:center;z-index:3;padding:0 clamp(18px,6vw,40px);min-height:1.2em}
.sol-line{position:absolute;left:0;right:0;padding:0 clamp(18px,6vw,40px);font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.8rem,7.5vw,4.2rem);letter-spacing:-.03em;line-height:1.02}
.sol-prog,.morph-prog{position:absolute;left:50%;bottom:6%;transform:translateX(-50%);width:min(58vw,300px);height:4px;background:rgba(27,24,21,.12);border-radius:4px;z-index:4}
.sol-prog .f,.morph-prog .f{height:100%;width:0;background:var(--amber);border-radius:4px}

.s-how{background:var(--night);color:#fff;overflow:hidden;height:100svh;display:flex;flex-direction:column;justify-content:center}
.s-how .chapter{color:var(--amber)}
.how-head{padding:0 clamp(18px,5vw,80px);margin-bottom:18px;max-width:var(--maxw)}
.how-head h2{color:#fff;font-size:clamp(1.7rem,6vw,3rem);margin-top:6px}
.steps{display:flex;gap:16px;width:max-content;will-change:transform;padding-left:clamp(18px,5vw,80px);align-items:stretch}
.stepc{flex:0 0 76vw;max-width:330px;background:#211d19;border-radius:20px;overflow:hidden;height:min(58vh,460px);display:flex;flex-direction:column}
.stepc .pic{flex:1;min-height:120px;overflow:hidden}.stepc .pic img{width:100%;height:100%;object-fit:cover}
.stepc .tx{padding:18px 20px 22px}.stepc .n{font-family:'Bricolage Grotesque';font-weight:800;font-size:2.2rem;color:var(--amber);line-height:1}
.stepc h3{color:#fff;font-size:1.2rem;margin:4px 0 6px}.stepc p{color:rgba(255,255,255,.6);font-size:.92rem}
@media(min-width:760px){.stepc{flex:0 0 330px}}
@media(max-height:680px){.stepc{height:min(70vh,430px)}}

/* why-brand */
.s-why{background:var(--cream);position:relative}
.kwrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);margin:4px -5vw;width:110vw}
.kmarq{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.2rem,11vw,7rem);line-height:1;letter-spacing:-.03em;display:flex;width:max-content;animation:tick 30s linear infinite}
.kmarq.rev{animation-direction:reverse;animation-duration:36s}
.kmarq .it{padding:0 .35em;white-space:nowrap;color:transparent;-webkit-text-stroke:2px var(--ink)}
.kmarq.fill .it{color:var(--amber);-webkit-text-stroke:0}
.billboard{font-size:clamp(1.5rem,5.5vw,2.8rem);font-weight:800;font-family:'Bricolage Grotesque';max-width:18ch;margin-top:20px;line-height:1.04}
.splitbar{margin-top:28px;height:clamp(54px,12vw,72px);border-radius:50px;overflow:hidden;display:flex;border:2.5px solid var(--ink);background:#fff}
.splitbar .b{display:grid;place-items:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(.95rem,3.4vw,1.4rem);white-space:nowrap}
.splitbar .brandb{background:var(--ink);color:#fff;width:0}
.splitbar .youb{background:var(--amber);color:var(--ink);width:0}
.split-cap{display:flex;justify-content:space-between;font-family:'Space Mono';font-size:12px;color:var(--muted);margin-top:10px;text-transform:uppercase;letter-spacing:.07em}
.s-why .float{position:absolute;right:-2%;top:13%;width:28%;max-width:320px;z-index:0}
@media(max-width:900px){.s-why .float{display:none}}

/* stats grid */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:28px}
.statcard{background:var(--paper);border:1.5px solid var(--line);border-radius:18px;padding:18px}
.dark .statcard{background:#211d19;border-color:#2c2722}
.statcard .v{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.7rem,6vw,2.8rem);color:var(--ink);line-height:1}
.dark .statcard .v{color:#fff}
.statcard .l{font-size:.8rem;color:var(--muted);margin-top:6px}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stats.three{grid-template-columns:repeat(1,1fr)}
@media(min-width:760px){.stats.three{grid-template-columns:repeat(3,1fr)}}

/* problem + morph */
.s-end{background:var(--cream);position:relative}
.s-end .pic-bleed{position:relative;border-radius:20px;overflow:hidden;margin-top:24px;aspect-ratio:16/10}
.s-end .pic-bleed img{width:100%;height:100%;object-fit:cover}
.s-end .pic-bleed::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(20,18,15,.5))}
.s-morph{background:radial-gradient(120% 90% at 50% 30%,#fffdf6 0%,var(--cream) 70%)}
.morph-wrap{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:min(82vw,460px);height:min(82vw,460px);max-height:64vh;z-index:1}
.morph-wrap canvas{position:absolute;inset:0;width:100%;height:100%}
.morph-still{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:88%;filter:drop-shadow(0 30px 38px rgba(20,18,15,.2))}
.morph-cap{position:absolute;left:0;right:0;bottom:10%;text-align:center;padding:0 clamp(18px,6vw,40px);z-index:3}
.mcap{position:absolute;left:0;right:0;padding:0 clamp(18px,6vw,40px);font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(1.6rem,6.5vw,3.6rem);letter-spacing:-.03em;line-height:1.04}
.mcap em{color:var(--amber)}

/* proof */
.s-proof{background:var(--ink);color:#fff;text-align:center}
.proofgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 16px}
.proofgrid .num{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.6rem,9vw,5rem);color:var(--amber);line-height:1}
.proofgrid .lbl{color:rgba(255,255,255,.6);font-size:.88rem;margin-top:6px}
@media(min-width:780px){.proofgrid{grid-template-columns:repeat(5,1fr)}}

/* lanes */
.lanes{display:grid;grid-template-columns:1fr;gap:16px;margin-top:36px}
.lane{position:relative;border-radius:20px;overflow:hidden;min-height:380px;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;isolation:isolate}
.lane img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .7s}
.lane::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,transparent 34%,rgba(20,18,15,.86))}
.lane:hover img{transform:scale(1.07)}
.lane h3{font-size:1.6rem}.lane p{color:rgba(255,255,255,.85);margin-top:6px;font-size:.92rem;max-width:30ch}
.lane .go{margin-top:12px;font-family:'Bricolage Grotesque';font-weight:700;color:var(--amber)}
@media(min-width:880px){.lanes{grid-template-columns:repeat(3,1fr)}}

/* trust marquees */
.s-trust{background:var(--paper);overflow:hidden;padding:50px 0}
.tr-cap{text-align:center;font-family:'Space Mono';font-size:12px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;padding:0 16px}
.logos{display:flex;gap:14px;width:max-content;animation:tick 30s linear infinite}.logos.rev{animation-direction:reverse}
.logos .l{flex:0 0 auto;background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:15px 26px;font-family:'Bricolage Grotesque';font-weight:700;color:var(--muted);min-width:140px;text-align:center}
.mwrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}

/* newsletter */
.s-news{background:var(--amber);text-align:center}.s-news h2{font-size:clamp(2rem,7.5vw,4.2rem)}
.s-news p{max-width:42ch;margin:14px auto 24px;font-size:1.05rem;color:#3a2c14}
.nf{display:flex;gap:10px;max-width:440px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.nf input{flex:1;min-width:200px;padding:15px 20px;border-radius:40px;border:1.5px solid rgba(27,24,21,.25);background:rgba(255,255,255,.55);font-family:'Hanken Grotesk';font-size:15px}
.nf input:focus{outline:none;border-color:var(--ink);background:#fff}

/* ===================== process flow ===================== */
.flow{display:flex;flex-direction:column;gap:10px;margin-top:22px}
.flow .label{font-family:'Space Mono';font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber2);margin-bottom:4px}
.flowline{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.flowline .step{background:var(--paper);border:1.5px solid var(--line);border-radius:40px;padding:9px 16px;font-weight:600;font-size:.92rem}
.flowline .arrow{color:var(--amber);font-weight:700}
.dark .flowline .step{background:#211d19;border-color:#2c2722;color:#fff}

/* ===================== FAQ accordion ===================== */
.faq{margin-top:24px;border-top:1px solid var(--line)}
.faq .q{border-bottom:1px solid var(--line);padding:20px 0;cursor:pointer}
.faq .q h4{font-family:'Bricolage Grotesque';font-size:clamp(1.1rem,3.5vw,1.5rem);display:flex;justify-content:space-between;gap:18px;align-items:center}
.faq .q h4 .pl{color:var(--amber);font-weight:700;transition:transform .3s;flex:0 0 auto}
.faq .q.open h4 .pl{transform:rotate(45deg)}
.faq .q .a{max-height:0;overflow:hidden;transition:max-height .4s ease;color:#56504a}
.faq .q .a p{padding-top:12px;max-width:60ch}

/* ===================== tiers ===================== */
.tiers{display:grid;grid-template-columns:1fr;gap:16px;margin-top:30px}
.tier{background:var(--paper);border:1.5px solid var(--line);border-radius:20px;padding:26px;display:flex;flex-direction:column}
.tier.feat{border-color:var(--amber);box-shadow:0 24px 60px -40px rgba(243,145,48,.6)}
.tier .name{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.7rem}
.tier .units{font-family:'Space Mono';font-size:13px;color:var(--amber2);margin:4px 0 16px;letter-spacing:.04em}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.tier li{font-size:.96rem;color:#46403a;padding-left:22px;position:relative}
.tier li::before{content:"✦";position:absolute;left:0;color:var(--amber)}
@media(min-width:880px){.tiers{grid-template-columns:repeat(3,1fr)}}

/* ===================== calculator ===================== */
.calc{background:var(--paper);border:1.5px solid var(--line);border-radius:22px;padding:clamp(20px,4vw,34px);margin-top:30px;display:grid;grid-template-columns:1fr;gap:26px}
.calc .controls{display:flex;flex-direction:column;gap:20px}
.calc .field label{display:flex;justify-content:space-between;font-weight:600;font-size:.95rem;margin-bottom:8px}
.calc .field label b{font-family:'Space Mono';color:var(--amber2)}
.calc select,.calc input[type=range]{width:100%}
.calc select{padding:12px 14px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-family:'Hanken Grotesk';font-size:15px}
.calc input[type=range]{accent-color:var(--amber);height:6px}
.calc .seg{display:flex;gap:8px;flex-wrap:wrap}
.calc .seg button{flex:1;min-width:80px;padding:10px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-family:'Hanken Grotesk';font-weight:600;font-size:.9rem;cursor:pointer}
.calc .seg button.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.calc .readout{background:var(--ink);color:#fff;border-radius:18px;padding:26px;display:flex;flex-direction:column;justify-content:center;gap:14px}
.calc .readout .row{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:12px}
.calc .readout .row:last-child{border-bottom:none}
.calc .readout .k{color:rgba(255,255,255,.6);font-size:.9rem}
.calc .readout .v{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.5rem}
.calc .readout .big .v{font-size:clamp(2rem,7vw,2.8rem);color:var(--amber)}
@media(min-width:820px){.calc{grid-template-columns:1.1fr 1fr;gap:34px}}

/* ===================== gate (sponsorship) ===================== */
.gateform{background:var(--paper);border:1.5px solid var(--line);border-radius:22px;padding:clamp(22px,4vw,34px);max-width:520px;margin-top:30px}
.gateform .grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gateform .full{grid-column:1/-1}
.field-in{width:100%;padding:13px 16px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-family:'Hanken Grotesk';font-size:15px;margin-top:6px}
.field-in:focus{outline:none;border-color:var(--ink)}
.field-lab{font-weight:600;font-size:.9rem;color:#56504a}
.locked{display:none}
.locked.unlocked{display:block;animation:fadeup .6s ease}
@keyframes fadeup{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.gate-note{font-size:.82rem;color:var(--muted);margin-top:12px}

/* ===================== blog ===================== */
.blog-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:30px}
.post-card{background:var(--paper);border:1.5px solid var(--line);border-radius:18px;overflow:hidden;transition:transform .3s}
.post-card:hover{transform:translateY(-4px)}
.post-card .pic{aspect-ratio:16/10;overflow:hidden;background:var(--dune)}
.post-card .pic img{width:100%;height:100%;object-fit:cover}
.post-card .b{padding:20px}
.post-card .cat{font-family:'Space Mono';font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber2)}
.post-card h3{font-size:1.25rem;margin:8px 0}
.post-card p{color:#56504a;font-size:.92rem}
@media(min-width:680px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.featured-post{display:grid;grid-template-columns:1fr;gap:0;border-radius:22px;overflow:hidden;background:var(--ink);color:#fff;margin-top:30px}
.featured-post .pic{aspect-ratio:16/10;overflow:hidden}
.featured-post .pic img{width:100%;height:100%;object-fit:cover}
.featured-post .b{padding:clamp(24px,4vw,44px);display:flex;flex-direction:column;justify-content:center}
.featured-post .cat{font-family:'Space Mono';font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--amber)}
.featured-post h2{font-size:clamp(1.6rem,4.5vw,2.6rem);margin:12px 0}
.featured-post p{color:rgba(255,255,255,.72)}
.cats{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.cats .c{background:var(--paper);border:1.5px solid var(--line);border-radius:40px;padding:9px 18px;font-weight:600;font-size:.9rem}
@media(min-width:860px){.featured-post{grid-template-columns:1.2fr 1fr}.featured-post .pic{aspect-ratio:auto}}

/* ===================== contact ===================== */
.routes{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:24px}
.route{background:var(--paper);border:1.5px solid var(--line);border-radius:16px;padding:20px;cursor:pointer;transition:.25s}
.route.on,.route:hover{border:3px solid #fff;background:#fff;box-shadow:0 8px 24px -8px rgba(0,0,0,0.12)}
.route h4{font-family:'Bricolage Grotesque';font-size:1.15rem}
.route p{font-size:.85rem;color:var(--muted);margin-top:4px}
.cform{margin-top:26px;display:grid;gap:14px;max-width:560px}
@media(min-width:680px){.routes{grid-template-columns:repeat(4,1fr)}}
textarea.field-in{min-height:130px;resize:vertical}

/* products row */
.prodrow{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:30px}
.prod{background:var(--paper);border:1.5px solid var(--line);border-radius:18px;padding:18px;text-align:center}
.prod img{width:100%;aspect-ratio:1/1;object-fit:contain;mix-blend-mode:multiply}
.prod .nm{font-family:'Bricolage Grotesque';font-weight:700;margin-top:8px}
@media(min-width:680px){.prodrow{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1000px){.prodrow{grid-template-columns:repeat(6,1fr)}}

/* ===================== legal / prose ===================== */
.legal{max-width:760px;margin:0 auto}
.legal h1{font-size:clamp(2.2rem,7vw,3.6rem);margin-bottom:8px}
.legal .meta{font-family:'Space Mono';font-size:12px;color:var(--muted);margin-bottom:30px}
.legal h2{font-size:1.4rem;margin:34px 0 10px}
.legal p,.legal li{color:#46403a;font-size:1rem;margin-bottom:10px;line-height:1.65}
.legal ul{padding-left:22px;margin-bottom:10px}

/* 404 */
.f404{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px}
.f404 .big{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(6rem,30vw,18rem);line-height:.9;color:var(--amber)}

/* ===================== footer ===================== */
.footer{background:var(--night);color:rgba(255,255,255,.66);padding:clamp(52px,9vh,104px) clamp(18px,5vw,80px) 30px;overflow:hidden}
.footer-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;max-width:var(--maxw);margin:0 auto;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer img.flogo{height:28px;margin-bottom:14px}
.footer h4{color:#fff;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:13px;font-family:'Space Mono'}
.footer a{display:block;color:rgba(255,255,255,.6);padding:5px 0;font-size:14.5px}.footer a:hover{color:var(--amber)}
.fbig{font-family:'Bricolage Grotesque';font-weight:800;font-size:clamp(2.4rem,13.5vw,12rem);color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.14);text-align:center;line-height:.9;margin:34px 0 0;letter-spacing:-.04em;white-space:nowrap;overflow:hidden}
.fbot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;max-width:var(--maxw);margin:22px auto 0;font-size:12.5px;color:rgba(255,255,255,.4)}
@media(min-width:780px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}


/* ===================== contact page details & visual ===================== */
.contact-hero {
  position: relative;
  z-index: 2;
  max-width: 760px;
  background: rgba(250, 245, 225, 0.65);
  padding: clamp(24px, 5vw, 44px);
  border-radius: 24px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1.5px solid rgba(255, 255, 255, 0.5);
}
.company-details {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  margin: 32px 0 32px;
  padding: 32px;
  background: var(--paper);
  border: 1.5px solid var(--line);
  border-radius: 20px;
  max-width: 680px;
}
@media (min-width: 600px) {
  .company-details {
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
}
.detail-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.det-label {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--amber2);
}
.det-val {
  font-size: 0.95rem;
  color: var(--ink);
  line-height: 1.45;
  font-weight: 500;
}
.red-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  background-color: #d12e2e;
  border-radius: 50%;
  margin-left: 6px;
  vertical-align: middle;
}
.lnk-und {
  position: relative;
  display: inline-block;
  color: inherit;
  text-decoration: none;
  transition: color 0.25s;
}
.lnk-und::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 100%;
  height: 1px;
  background: var(--amber);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 0.25s ease;
}
.lnk-und:hover {
  color: var(--amber2);
}
.lnk-und:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* Apply background images directly to the section */
.contact-section {
  background-image: url('../images/contact-bg-desktop.png');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media (max-width: 800px) {
  .contact-section {
    background-image: url('../images/contact-bg-mobile.png');
    background-position: 80% center; /* Keep receiver visible */
  }
}

@media (prefers-reduced-motion: reduce){*{animation:none!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}


/* ---------- PHYSICS FOOTER (GLOBAL) ---------- */
.physics-footer {
  position: relative;
  background: var(--night);
  padding: 150px 20px 60px;
  overflow: hidden;
  border-top: 1px solid rgba(255,255,255,0.05);
  color: #fff;
}
#footer-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}
.footer-content {
  position: relative;
  z-index: 2;
  text-align: center;
  background: rgba(10, 10, 12, 0.4);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  padding: 80px 40px 60px;
  border-radius: 32px;
  max-width: 1400px;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,0.05);
  box-shadow: 0 30px 60px rgba(0,0,0,0.4);
  pointer-events: none;
}
.footer-content > * { pointer-events: auto; }
.f-links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 40px;
  text-align: left;
  margin: 0 auto 50px;
  max-width: 900px;
}
.f-col h4 {
  font-family: 'Space Mono'; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 24px; color: #fff;
}
.f-col-links {
  display: flex; flex-direction: column; gap: 16px; font-size: 1.05rem; font-weight: 600;
}
.f-col-links a { color: rgba(255,255,255,0.6); text-decoration: none; transition: color 0.2s;}
.f-col-links a:hover { color: var(--amber); }
.f-massive {
  font-family: 'Bricolage Grotesque'; font-size: clamp(1.8rem, 8vw, 12rem); font-weight: 800; letter-spacing: -0.04em; margin: 60px 0 30px; color: #fff; width: 100%; text-align: center; word-break: break-word; overflow-wrap: break-word;
}
.standard-bottom-footer {
  margin-top: 40px; padding-top: 30px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: space-between; align-items: center; font-family: 'Space Mono'; font-size: 13px; color: rgba(255,255,255,0.4); text-transform: uppercase;
}
.standard-bottom-footer a { color: rgba(255,255,255,0.4); text-decoration:none; }
.standard-bottom-footer a:hover { color: var(--amber); }
@media(max-width: 600px) {
  .standard-bottom-footer { flex-direction: column; gap: 20px; text-align: center; }
}

/* ===========================================================================
   INDEX.HTML EXTRACTED GLOBAL STYLES (Header, Footer, Scrubber, Bento, Matrix)
   =========================================================================== */
/* OVERRIDES FOR GLOBAL HEADER */
.header { display: flex !important; align-items: center; justify-content: space-between; padding: 14px clamp(20px, 5vw, 60px) !important; width: 100%; z-index: 100; position: fixed; top: 0; transition: background 0.3s; }
.header.scrolled { background: rgba(253, 251, 247, 0.9); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,0.05); }
.header .logo { height: 55px !important; max-width: none !important; }
.header-center { position: absolute; left: 50%; transform: translateX(-50%); display: flex; gap: 32px; }
.header-center .lnk { font-family: 'Space Mono'; font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-ink); text-decoration: none; position: relative;}
.header-center .lnk::after { content: ''; position: absolute; width: 0; height: 2px; bottom: -4px; left: 0; background-color: var(--accent); transition: width 0.3s; }
.header-center .lnk:hover::after { width: 100%; }
.header-right { margin-left: auto; display: flex; align-items: center; gap: 20px; }
.icon-btn { background: none; border: none; cursor: pointer; color: var(--text-ink); display: grid; place-items: center; padding: 0; transition: 0.2s; }
.icon-btn:hover { color: var(--accent); transform: scale(1.1); }
.icon-btn svg { width: 24px; height: 24px; stroke-width: 2; stroke: currentColor; fill: none; pointer-events: none; }

/* 2. THE 3D TUNNEL */
.tunnel-section { position: relative; background: var(--bg-cream); height: 100svh; display: flex; align-items: center; justify-content: center; overflow: hidden; border-top: 1px solid rgba(0,0,0,0.05); }
.tunnel-title { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; font-family: 'Bricolage Grotesque'; font-size: clamp(2.5rem, 8vw, 6rem); font-weight: 800; letter-spacing: -0.03em; z-index: 10; opacity: 0; width: 100%; white-space: normal; padding: 0 20px; line-height: 1.1; word-break: break-word; }
.tunnel-bg-name { position: absolute; top: 40%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-family: 'Bricolage Grotesque', sans-serif; font-size: clamp(3rem, 12vw, 10rem); font-weight: 800; line-height: 0.9; letter-spacing: -0.04em; color: var(--accent); opacity: 0; z-index: 0; white-space: nowrap; }
.tunnel-product { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.01); opacity: 0; width: 450px; max-width: 75vw; object-fit: contain; filter: drop-shadow(0 50px 80px rgba(0,0,0,0.3)); }
.tunnel-ui { position: absolute; bottom: 10%; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 15px; opacity: 0; z-index: 15; width: 100%; padding: 0 20px; }
.tunnel-price { font-family: 'Space Mono'; font-weight: 700; font-size: clamp(1rem, 2vw, 1.2rem); text-transform: uppercase; letter-spacing: 0.1em; color: #fff; background: var(--text-ink); padding: 12px 24px; border-radius: 40px; box-shadow: 0 20px 40px rgba(0,0,0,0.2); }
.tunnel-desc { font-size: 1.1rem; color: #555; text-align: center; max-width: 400px; font-weight: 500; }

/* 3. WARM-UP GSAP SCRUBBER */
.scrubber-section { padding: clamp(150px, 20vh, 250px) 20px; background: var(--text-ink); color: #fff; text-align: center; display: flex; align-items: center; justify-content: center; min-height: 80vh; }
.scrub-text { font-family: 'Bricolage Grotesque'; font-size: clamp(1.8rem, 6vw, 5.5rem); font-weight: 800; line-height: 1.1; max-width: 1200px; margin: 0 auto; letter-spacing: -0.03em; word-break: break-word; }
.scrub-word { opacity: 0.15; transition: opacity 0.1s; }

/* 4. THE 80/20 BENTO GRID */
.bento-section { padding: clamp(100px, 15vh, 160px) 20px; background: #f4f2ea; }
.bento-header { text-align: center; margin-bottom: 80px; }
.bento-header h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 7vw, 6rem); font-weight: 800; letter-spacing: -0.03em; margin-bottom: 20px; }
.bento-header p { font-size: 1.4rem; color: #555; max-width: 600px; margin: 0 auto; }
.bento-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: minmax(250px, auto); gap: 24px; grid-auto-flow: dense; max-width: 1300px; margin: 0 auto; }
.b-cell { background: #fff; border-radius: 32px; padding: 40px; border: 1px solid rgba(0,0,0,0.05); display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.b-cell::before { content: ''; position: absolute; inset: 0; border-radius: 32px; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.5); z-index: 2; pointer-events: none; }
.b-huge { grid-column: span 4; grid-row: span 2; display: grid; grid-template-columns: 1fr 1fr; padding: 0; background: var(--text-ink); color: #fff; }
.b-tall { grid-row: span 2; grid-column: span 2; }
.b-wide { grid-column: span 2; grid-row: span 1; }
@media(max-width: 900px) { .bento-grid { grid-template-columns: 1fr; } .b-huge, .b-tall, .b-wide { grid-column: span 1; grid-row: auto; } .b-huge { grid-template-columns: 1fr; } }
/* Bento Math Content */
.math-col { padding: 60px; display: flex; flex-direction: column; justify-content: center; }
.math-col:first-child { border-right: 1px solid rgba(255,255,255,0.1); background: #1a1a1a; }
.math-col h3 { font-family: 'Space Mono'; font-size: 1.2rem; text-transform: uppercase; letter-spacing: 0.1em; color: #888; margin-bottom: 20px; }
.math-col .price { font-family: 'Bricolage Grotesque'; font-size: clamp(4rem, 8vw, 8rem); font-weight: 800; line-height: 1; }
.math-col.accent { background: var(--accent); }
.math-col.accent h3 { color: rgba(0,0,0,0.6); font-weight: 700; }
.math-col.accent .price { color: var(--text-ink); }
/* Bento Other Content */
.b-cell h4 { font-family: 'Bricolage Grotesque'; font-size: 2.2rem; font-weight: 800; margin-bottom: 15px; letter-spacing: -0.02em; z-index: 5; position: relative;}
.b-cell p { font-size: 1.1rem; color: #555; line-height: 1.5; z-index: 5; position: relative; }
.b-img-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.15; mix-blend-mode: multiply; transition: 0.6s cubic-bezier(0.16, 1, 0.3, 1); }
.b-cell:hover .b-img-bg { transform: scale(1.05); opacity: 0.25; }

/* 5. FAST FASHION HORIZONTAL PIN */
.pin-master { width: 100%; overflow: hidden; background: var(--text-ink); color: #fff; }
.pin-container { display: flex; width: 200vw; height: 100svh; }
.pin-panel { width: 100vw; height: 100svh; display: flex; align-items: center; justify-content: center; padding: 40px; position: relative; }
.panel-dark { background: var(--text-ink); }
.panel-light { background: #e8e4db; color: var(--text-ink); }
.pin-content { max-width: 800px; z-index: 10; }
.pin-content h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 8vw, 7rem); font-weight: 800; line-height: 0.9; letter-spacing: -0.04em; margin-bottom: 30px; }
.pin-content p { font-size: clamp(1.2rem, 3vw, 1.8rem); line-height: 1.4; opacity: 0.8; }
.pin-bg-img { position: absolute; top: 0; right: 0; height: 100%; width: 50%; object-fit: cover; opacity: 0.5; mask-image: linear-gradient(to right, transparent, black 40%); -webkit-mask-image: linear-gradient(to right, transparent, black 40%); }

/* 6. DUAL HOW IT WORKS */
.dual-how { background: var(--bg-cream); }
/* Brand Journey (Data Flow) */
.brand-how { padding: 160px 20px; background: #0a0a0a; color: #fff; position: relative; overflow: hidden; }
.brand-how::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at top right, rgba(243,145,48,0.15) 0%, transparent 60%); }
.brand-how h2 { position: relative; font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 6vw, 5rem); font-weight: 800; text-align: center; margin-bottom: 120px; letter-spacing: -0.03em; }
.tech-flow { max-width: 1000px; margin: 0 auto; position: relative; display: flex; flex-direction: column; gap: 100px; }
.tf-line { position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; background: rgba(255,255,255,0.05); transform: translateX(-50%); }
.tf-progress { position: absolute; left: 50%; top: 0; height: 0%; width: 2px; background: var(--accent); box-shadow: 0 0 20px var(--accent); transform: translateX(-50%); }
.tf-step { display: flex; justify-content: space-between; align-items: center; width: 100%; position: relative; z-index: 2; }
.tf-content { width: 45%; opacity: 0; transform: translateY(40px); }
.tf-step:nth-child(even) .tf-content { margin-left: 55%; text-align: left; }
.tf-step:nth-child(odd) .tf-content { text-align: right; }
.tf-dot { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 24px; height: 24px; border-radius: 50%; background: #0a0a0a; border: 3px solid rgba(255,255,255,0.2); transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.tf-step.active .tf-dot { border-color: var(--accent); background: var(--accent); box-shadow: 0 0 30px var(--accent); scale: 1.2; }
.tf-content h3 { font-family: 'Bricolage Grotesque'; font-size: 2.2rem; font-weight: 800; margin-bottom: 15px; color: #fff; }
.tf-content p { font-size: 1.15rem; color: #888; line-height: 1.6; }
@media(max-width: 800px) {
  .tf-line, .tf-progress, .tf-dot { left: 30px; transform: none; }
  .tf-step:nth-child(even) .tf-content, .tf-step:nth-child(odd) .tf-content { width: calc(100% - 60px); margin-left: 60px; text-align: left; }
  .tf-content { transform: translateX(20px); }
}

/* 7. ULTIMATE US VS THEM MATRIX */
.matrix-section { padding: 160px 20px; background: #ffffff; }
.matrix-container { max-width: 1400px; margin: 0 auto; }
.matrix-container h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 800; text-align: center; margin-bottom: 100px; letter-spacing: -0.03em; }
.mx-wrapper { display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,0.1); border-radius: 40px; overflow: hidden; background: var(--bg-cream); }
.mx-row { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid rgba(0,0,0,0.05); transition: background 0.3s; }
.mx-row:last-child { border-bottom: none; }
.mx-row:hover { background: #fff; }
.mx-col { padding: 40px; }

/* ===========================================================================
   INDEX.HTML EXTRACTED GLOBAL STYLES (Header, Footer, Scrubber, Bento, Matrix)
   =========================================================================== */
/* OVERRIDES FOR GLOBAL HEADER */
.header { display: flex !important; align-items: center; justify-content: space-between; padding: 14px clamp(20px, 5vw, 60px) !important; width: 100%; z-index: 100; position: fixed; top: 0; transition: background 0.3s; }
.header.scrolled { background: rgba(253, 251, 247, 0.9); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,0.05); }
.header .logo { height: 55px !important; max-width: none !important; }
.header-center { position: absolute; left: 50%; transform: translateX(-50%); display: flex; gap: 32px; }
.header-center .lnk { font-family: 'Space Mono'; font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-ink); text-decoration: none; position: relative;}
.header-center .lnk::after { content: ''; position: absolute; width: 0; height: 2px; bottom: -4px; left: 0; background-color: var(--accent); transition: width 0.3s; }
.header-center .lnk:hover::after { width: 100%; }
.header-right { margin-left: auto; display: flex; align-items: center; gap: 20px; }
.icon-btn { background: none; border: none; cursor: pointer; color: var(--text-ink); display: grid; place-items: center; padding: 0; transition: 0.2s; }
.icon-btn:hover { color: var(--accent); transform: scale(1.1); }
.icon-btn svg { width: 24px; height: 24px; stroke-width: 2; stroke: currentColor; fill: none; pointer-events: none; }

/* MOBILE MENU DRAWER */
.mobile-menu { position: fixed; inset: 0; background: #0a0a0a; z-index: 99; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: clamp(10px, 3vh, 30px); transform: translateX(100%); transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1); pointer-events: none; }
.mobile-menu.open { transform: translateX(0); pointer-events: auto; }
.mobile-menu a { font-family: 'Bricolage Grotesque'; font-size: clamp(2rem, 8vw, 3rem); font-weight: 800; color: #fff; text-decoration: none; opacity: 0; transform: translateY(20px); transition: all 0.3s ease; line-height: 1.1; text-align: center; }
.mobile-menu.open a { opacity: 1; transform: translateY(0); }
.mobile-menu a:nth-child(1) { transition-delay: 0.2s; }
.mobile-menu a:nth-child(2) { transition-delay: 0.3s; }
.mobile-menu a:nth-child(3) { transition-delay: 0.4s; }
.mobile-menu a:nth-child(4) { transition-delay: 0.5s; }
.mobile-menu a:nth-child(5) { transition-delay: 0.6s; }
.mobile-menu a:nth-child(6) { transition-delay: 0.7s; }
.hamburger.open span:nth-child(1) { transform: rotate(45deg); top: 9px; }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: rotate(-45deg); top: 9px; }
.hamburger.open span { background: #fff !important; }

/* 2. THE 3D TUNNEL */
.tunnel-section { position: relative; background: var(--bg-cream); height: 100svh; display: flex; align-items: center; justify-content: center; overflow: hidden; border-top: 1px solid rgba(0,0,0,0.05); }
.tunnel-title { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center; font-family: 'Bricolage Grotesque'; font-size: clamp(2.5rem, 8vw, 6rem); font-weight: 800; letter-spacing: -0.03em; z-index: 10; opacity: 0; width: 100%; white-space: normal; padding: 0 20px; line-height: 1.1; word-break: break-word; }
.tunnel-bg-name { position: absolute; top: 40%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-family: 'Bricolage Grotesque', sans-serif; font-size: clamp(3rem, 12vw, 10rem); font-weight: 800; line-height: 0.9; letter-spacing: -0.04em; color: var(--accent); opacity: 0; z-index: 0; white-space: nowrap; }
.tunnel-product { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.01); opacity: 0; width: 450px; max-width: 75vw; object-fit: contain; filter: drop-shadow(0 50px 80px rgba(0,0,0,0.3)); }
.tunnel-ui { position: absolute; bottom: 10%; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 15px; opacity: 0; z-index: 15; width: 100%; padding: 0 20px; }
.tunnel-price { font-family: 'Space Mono'; font-weight: 700; font-size: clamp(1rem, 2vw, 1.2rem); text-transform: uppercase; letter-spacing: 0.1em; color: #fff; background: var(--text-ink); padding: 12px 24px; border-radius: 40px; box-shadow: 0 20px 40px rgba(0,0,0,0.2); }
.tunnel-desc { font-size: 1.1rem; color: #555; text-align: center; max-width: 400px; font-weight: 500; }

/* 3. WARM-UP GSAP SCRUBBER */
.scrubber-section { padding: clamp(150px, 20vh, 250px) 20px; background: var(--text-ink); color: #fff; text-align: center; display: flex; align-items: center; justify-content: center; min-height: 80vh; }
.scrub-text { font-family: 'Bricolage Grotesque'; font-size: clamp(1.8rem, 6vw, 5.5rem); font-weight: 800; line-height: 1.1; max-width: 1200px; margin: 0 auto; letter-spacing: -0.03em; word-break: break-word; }
.scrub-word { opacity: 0.15; transition: opacity 0.1s; }

/* 4. THE 80/20 BENTO GRID */
.bento-section { padding: clamp(100px, 15vh, 160px) 20px; background: #f4f2ea; }
.bento-header { text-align: center; margin-bottom: 80px; }
.bento-header h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 7vw, 6rem); font-weight: 800; letter-spacing: -0.03em; margin-bottom: 20px; }
.bento-header p { font-size: 1.4rem; color: #555; max-width: 600px; margin: 0 auto; }
.bento-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: minmax(250px, auto); gap: 24px; grid-auto-flow: dense; max-width: 1300px; margin: 0 auto; }
.b-cell { background: #fff; border-radius: 32px; padding: 40px; border: 1px solid rgba(0,0,0,0.05); display: flex; flex-direction: column; justify-content: center; position: relative; overflow: hidden; }
.b-cell::before { content: ''; position: absolute; inset: 0; border-radius: 32px; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.5); z-index: 2; pointer-events: none; }
.b-huge { grid-column: span 4; grid-row: span 2; display: grid; grid-template-columns: 1fr 1fr; padding: 0; background: var(--text-ink); color: #fff; }
.b-tall { grid-row: span 2; grid-column: span 2; }
.b-wide { grid-column: span 2; grid-row: span 1; }
@media(max-width: 900px) { .bento-grid { grid-template-columns: 1fr; } .b-huge, .b-tall, .b-wide { grid-column: span 1; grid-row: auto; } .b-huge { grid-template-columns: 1fr; } }
/* Bento Math Content */
.math-col { padding: 60px; display: flex; flex-direction: column; justify-content: center; }
.math-col:first-child { border-right: 1px solid rgba(255,255,255,0.1); background: #1a1a1a; }
.math-col h3 { font-family: 'Space Mono'; font-size: 1.2rem; text-transform: uppercase; letter-spacing: 0.1em; color: #888; margin-bottom: 20px; }
.math-col .price { font-family: 'Bricolage Grotesque'; font-size: clamp(4rem, 8vw, 8rem); font-weight: 800; line-height: 1; }
.math-col.accent { background: var(--accent); }
.math-col.accent h3 { color: rgba(0,0,0,0.6); font-weight: 700; }
.math-col.accent .price { color: var(--text-ink); }
/* Bento Other Content */
.b-cell h4 { font-family: 'Bricolage Grotesque'; font-size: 2.2rem; font-weight: 800; margin-bottom: 15px; letter-spacing: -0.02em; z-index: 5; position: relative;}
.b-cell p { font-size: 1.1rem; color: #555; line-height: 1.5; z-index: 5; position: relative; }
.b-img-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.15; mix-blend-mode: multiply; transition: 0.6s cubic-bezier(0.16, 1, 0.3, 1); }
.b-cell:hover .b-img-bg { transform: scale(1.05); opacity: 0.25; }

/* 5. FAST FASHION HORIZONTAL PIN */
.pin-master { width: 100%; overflow: hidden; background: var(--text-ink); color: #fff; }
.pin-container { display: flex; width: 200vw; height: 100svh; }
.pin-panel { width: 100vw; height: 100svh; display: flex; align-items: center; justify-content: center; padding: 40px; position: relative; }
.panel-dark { background: var(--text-ink); }
.panel-light { background: #e8e4db; color: var(--text-ink); }
.pin-content { max-width: 800px; z-index: 10; }
.pin-content h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 8vw, 7rem); font-weight: 800; line-height: 0.9; letter-spacing: -0.04em; margin-bottom: 30px; }
.pin-content p { font-size: clamp(1.2rem, 3vw, 1.8rem); line-height: 1.4; opacity: 0.8; }
.pin-bg-img { position: absolute; top: 0; right: 0; height: 100%; width: 50%; object-fit: cover; opacity: 0.5; mask-image: linear-gradient(to right, transparent, black 40%); -webkit-mask-image: linear-gradient(to right, transparent, black 40%); }

/* 6. DUAL HOW IT WORKS */
.dual-how { background: var(--bg-cream); }
/* Brand Journey (Data Flow) */
.brand-how { padding: 160px 20px; background: #0a0a0a; color: #fff; position: relative; overflow: hidden; }
.brand-how::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at top right, rgba(243,145,48,0.15) 0%, transparent 60%); }
.brand-how h2 { position: relative; font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 6vw, 5rem); font-weight: 800; text-align: center; margin-bottom: 120px; letter-spacing: -0.03em; }
.tech-flow { max-width: 1000px; margin: 0 auto; position: relative; display: flex; flex-direction: column; gap: 100px; }
.tf-line { position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; background: rgba(255,255,255,0.05); transform: translateX(-50%); }
.tf-progress { position: absolute; left: 50%; top: 0; height: 0%; width: 2px; background: var(--accent); box-shadow: 0 0 20px var(--accent); transform: translateX(-50%); }
.tf-step { display: flex; justify-content: space-between; align-items: center; width: 100%; position: relative; z-index: 2; }
.tf-content { width: 45%; opacity: 0; transform: translateY(40px); }
.tf-step:nth-child(even) .tf-content { margin-left: 55%; text-align: left; }
.tf-step:nth-child(odd) .tf-content { text-align: right; }
.tf-dot { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 24px; height: 24px; border-radius: 50%; background: #0a0a0a; border: 3px solid rgba(255,255,255,0.2); transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1); }
.tf-step.active .tf-dot { border-color: var(--accent); background: var(--accent); box-shadow: 0 0 30px var(--accent); scale: 1.2; }
.tf-content h3 { font-family: 'Bricolage Grotesque'; font-size: 2.2rem; font-weight: 800; margin-bottom: 15px; color: #fff; }
.tf-content p { font-size: 1.15rem; color: #888; line-height: 1.6; }
@media(max-width: 800px) {
  .tf-line, .tf-progress, .tf-dot { left: 30px; transform: none; }
  .tf-step:nth-child(even) .tf-content, .tf-step:nth-child(odd) .tf-content { width: calc(100% - 60px); margin-left: 60px; text-align: left; }
  .tf-content { transform: translateX(20px); }
}

/* 7. ULTIMATE US VS THEM MATRIX */
.matrix-section { padding: 160px 20px; background: #ffffff; }
.matrix-container { max-width: 1400px; margin: 0 auto; }
.matrix-container h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 800; text-align: center; margin-bottom: 100px; letter-spacing: -0.03em; }
.mx-wrapper { display: flex; flex-direction: column; border: 1px solid rgba(0,0,0,0.1); border-radius: 40px; overflow: hidden; background: var(--bg-cream); }
.mx-row { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid rgba(0,0,0,0.05); transition: background 0.3s; }
.mx-row:last-child { border-bottom: none; }
.mx-row:hover { background: #fff; }
.mx-col { padding: 40px; }
.mx-them { border-right: 1px solid rgba(0,0,0,0.05); filter: grayscale(100%); opacity: 0.6; transition: 0.3s; }
.mx-us { background: rgba(243, 145, 48, 0.05); }
.mx-row:hover .mx-them { opacity: 0.3; }
.mx-label { font-family: 'Space Mono'; font-weight: 700; text-transform: uppercase; font-size: 13px; color: #888; margin-bottom: 15px; letter-spacing: 0.1em; }
.mx-val { font-family: 'Bricolage Grotesque'; font-size: clamp(1.8rem, 3vw, 2.5rem); font-weight: 800; line-height: 1.1; color: var(--text-ink); }
.sh-desc { font-size: clamp(1.2rem, 2vw, 1.6rem); color: rgba(255,255,255,0.7); line-height: 1.4; }
@media(max-width: 900px) {
  .sh-section { flex-direction: column; justify-content: center; text-align: center; padding: 20px; }
  .sh-content { width: 100%; }
  .sh-visual { width: 100%; opacity: 0.4; mask-image: linear-gradient(to top, transparent, black 40%); -webkit-mask-image: linear-gradient(to top, transparent, black 40%); }
}

/* Matrix US Side */
.mx-us .mx-label { color: var(--accent); }
.mx-us .mx-val { color: var(--accent); display: flex; align-items: flex-start; gap: 15px; }
.mx-us .mx-val svg { width: 32px; height: 32px; flex-shrink: 0; margin-top: 4px; }
@media(max-width: 800px) { .mx-row { grid-template-columns: 1fr; } .mx-them { border-right: none; border-bottom: 1px solid rgba(0,0,0,0.05); } }

/* PHYSICS FOOTER (DARK THEME — GLOBAL) */
.physics-footer { position: relative; background: var(--night); padding: 150px 20px 60px; overflow: hidden; color: #fff; }
#footer-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; pointer-events: none; }
.footer-content { position: relative; z-index: 2; text-align: center; background: rgba(17, 17, 17, 0.85); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); padding: 80px 40px 60px; border-radius: 40px; max-width: 1400px; margin: 0 auto; border: 1px solid rgba(255,255,255,0.05); box-shadow: 0 40px 100px rgba(0,0,0,0.5); pointer-events: none; }
.footer-content > * { pointer-events: auto; }
.f-massive { font-family: 'Bricolage Grotesque'; font-size: clamp(1.8rem, 8vw, 10rem); font-weight: 800; letter-spacing: -0.04em; margin: 80px 0 40px; color: #fff; width: 100%; text-align: center; word-break: break-word; overflow-wrap: break-word; }
.f-links-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px; text-align: left; margin: 0 auto 60px; max-width: 1000px; }
.f-col h4 { font-family: 'Space Mono'; font-weight: 700; font-size: 14px; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 30px; color: rgba(255,255,255,0.3); }
.f-col a { display: block; color: rgba(255,255,255,0.8); text-decoration: none; font-size: 1.1rem; font-weight: 600; transition: 0.2s; }
.f-col a:hover { color: var(--accent); }
.f-col div { display: flex; flex-direction: column; gap: 16px; }
.standard-bottom-footer { margin-top: 40px; padding-top: 40px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: space-between; align-items: center; font-family: 'Space Mono'; font-size: 13px; color: rgba(255,255,255,0.4); text-transform: uppercase; }
.standard-bottom-footer a { color: rgba(255,255,255,0.4); text-decoration: none; }
.standard-bottom-footer a:hover { color: #fff; }
@media(max-width: 600px) { .f-links-grid { grid-template-columns: 1fr; gap: 40px; } .standard-bottom-footer { flex-direction: column; gap: 20px; text-align: center; } }

/* STUDENT JOURNEY (Cinematic Pinned Sequence) */
.student-how { width: 100%; background: #0e0e0e; color: #fff; position: relative; }
.student-how-heading { text-align: center; padding: clamp(60px, 8vh, 100px) 20px clamp(40px, 5vh, 60px); background: var(--bg-cream); color: var(--text-ink); }
.student-how-heading h2 { font-family: 'Bricolage Grotesque'; font-size: clamp(3rem, 6vw, 5rem); font-weight: 800; letter-spacing: -0.03em; }
.sj-container { display: flex; width: 100%; height: 100svh; position: relative; overflow: hidden; }
.sj-text-col { width: 50%; height: 100%; position: relative; display: flex; align-items: center; justify-content: flex-start; z-index: 10; padding: 40px clamp(20px, 5vw, 80px); }
.sj-text-block { position: absolute; left: 0; opacity: 0; width: 100%; padding-left: clamp(20px, 5vw, 80px); padding-right: 40px; transform: translateY(40px); }
.sj-text-block.active { opacity: 1; transform: translateY(0); }
.sh-num { font-family: 'Space Mono'; font-size: 1.5rem; font-weight: 700; color: var(--accent); margin-bottom: 20px; display: block; }
.sh-title { font-family: 'Bricolage Grotesque'; font-size: clamp(2.5rem, 5vw, 5rem); font-weight: 800; line-height: 0.95; letter-spacing: -0.03em; margin-bottom: 30px; }
.sh-desc { font-size: clamp(1.1rem, 2vw, 1.4rem); color: rgba(255,255,255,0.65); line-height: 1.5; }
.sj-visual-col { width: 50%; height: 100%; position: relative; display: flex; align-items: center; justify-content: center; z-index: 1; }
.sj-img { position: absolute; width: 70%; max-width: 600px; max-height: 75vh; object-fit: contain; opacity: 0; filter: drop-shadow(0 40px 60px rgba(0,0,0,0.5)); will-change: opacity; }
@media(max-width: 900px) {
  .sj-container { flex-direction: column; }
  .sj-text-col { width: 100%; height: 45svh; align-items: flex-start; padding-top: 80px; }
  .sj-text-block { padding-left: 20px; padding-right: 20px; }
  .sj-visual-col { width: 100%; height: 55svh; align-items: flex-end; padding-bottom: 40px; }
  .sj-img { width: 85%; max-height: 45svh; object-fit: contain; }
  .sh-num { margin-bottom: 10px; font-size: 1rem; }
  .sh-title { font-size: clamp(2rem, 8vw, 3rem); margin-bottom: 15px; }
  .sh-desc { font-size: 1rem; }
}


/* GLOBAL HEADER (Moved from index.html) */
.header { display: flex !important; align-items: center; justify-content: space-between; padding: 14px clamp(20px, 5vw, 60px) !important; width: 100%; z-index: 100; position: fixed; top: 0; transition: background 0.3s; }
.header.scrolled { background: rgba(250, 245, 225, 0.9); backdrop-filter: blur(12px); border-bottom: 1px solid rgba(0,0,0,0.05); }
.header .logo { height: 55px !important; max-width: none !important; }
.header-center { position: absolute; left: 50%; transform: translateX(-50%); display: flex; gap: 32px; }
.header-center .lnk { font-family: 'Space Mono', monospace; font-weight: 700; font-size: 13px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--ink); text-decoration: none; position: relative;}
.header-center .lnk::after { content: ''; position: absolute; width: 0; height: 2px; bottom: -4px; left: 0; background-color: var(--amber); transition: width 0.3s; }
.header-center .lnk:hover::after { width: 100%; }
.header-right { display: flex; align-items: center; gap: 20px; }
.icon-btn{background:none;border:none;cursor:pointer;color:var(--ink);display:grid;place-items:center;padding:0;transition:.2s;}
.icon-btn:hover{color:var(--amber);transform:scale(1.1);}
.icon-btn svg{width:24px;height:24px;stroke-width:2;stroke:currentColor;fill:none;}
/* Ensure icons are visible on dark themed pages */
.header .icon-btn{color:var(--amber);}
.header .icon-btn:hover{color:var(--amber);}
.hamburger { display: none; background: none; border: none; cursor: pointer; width: 30px; height: 20px; position: relative; z-index: 101; }
.hamburger span { position: absolute; width: 100%; height: 2px; background: var(--ink); left: 0; transition: 0.3s; pointer-events: none; }
.hamburger span:nth-child(1) { top: 0; }
.hamburger span:nth-child(2) { top: 9px; }
.hamburger span:nth-child(3) { top: 18px; }
@media (max-width: 900px) {
  .header-center { display: none; }
  .hamburger { display: block; }
}
