/* ===== NYX REBORN — shared styles ===== */
@font-face{font-family:'Affigere';src:url('fonts/affigere.woff2') format('woff2'),url('fonts/affigere.woff') format('woff');font-weight:400;font-display:swap}
@font-face{font-family:'Credible';src:url('fonts/credible.woff') format('woff'),url('fonts/credible.otf') format('opentype');font-weight:400;font-display:swap}
@font-face{font-family:'Hanken';src:url('fonts/hanken.ttf') format('truetype');font-weight:100 900;font-display:swap}

:root{
  --coal:#0b0b0c;--coal-2:#0f0f11;--coal-3:#151517;--bone:#e8e8e3;
  --flare:#d62a26;--ember:#ff6a2b;--ember-2:#ffb347;
  --dim:rgba(232,232,227,.46);--dim-2:rgba(232,232,227,.7);
  --line:rgba(232,232,227,.12);--line-2:rgba(232,232,227,.28);
  --ease:cubic-bezier(.16,1,.3,1);--pad:clamp(20px,4vw,56px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--coal);color:var(--bone);font-family:'Hanken','Helvetica Neue',Arial,sans-serif;font-weight:300;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
::selection{background:var(--flare);color:var(--bone)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.display{font-family:'Affigere','Arial Narrow',sans-serif;font-weight:400;text-transform:uppercase;line-height:.88;letter-spacing:.008em}
.scrawl{font-family:'Credible',cursive;font-weight:400}
.flare{color:var(--flare)}
.muted{color:var(--dim)}

/* grain */
.grain{position:fixed;inset:0;z-index:6;pointer-events:none;opacity:.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* fire cursor */
#embers{position:fixed;inset:0;z-index:9998;pointer-events:none}
.cursor-glow{position:fixed;top:0;left:0;width:340px;height:340px;margin:-170px 0 0 -170px;z-index:9997;pointer-events:none;border-radius:50%;
  background:radial-gradient(circle,rgba(255,106,43,.16),rgba(214,42,38,.06) 40%,transparent 68%);mix-blend-mode:screen;opacity:0;transition:opacity .6s}
body.moving .cursor-glow{opacity:1}
@media(hover:none){#embers,.cursor-glow{display:none}}

/* intro veil */
#veil{position:fixed;inset:0;z-index:9999;background:var(--coal);display:flex;align-items:center;justify-content:center;transition:opacity .9s var(--ease),visibility .9s}
#veil.gone{opacity:0;visibility:hidden}
#veil .vmark{width:60px;opacity:.9;animation:emberpulse 2.4s ease-in-out infinite}
@keyframes emberpulse{0%,100%{filter:drop-shadow(0 0 0 rgba(255,106,43,0))}50%{filter:drop-shadow(0 6px 26px rgba(255,106,43,.55))}}

/* header + ticker */
.header{position:fixed;top:0;left:0;right:0;z-index:50;transition:transform .55s var(--ease)}
.header.hide{transform:translateY(-100%)}
.ticker{overflow:hidden;height:34px;display:flex;align-items:center;background:var(--coal);border-bottom:1px solid var(--line);transition:height .5s var(--ease),opacity .4s var(--ease),border-color .5s}
.ticker .track{display:flex;flex:none;white-space:nowrap;will-change:transform;animation:marquee 34s linear infinite}
.ticker .track span{display:inline-block;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim-2)}
.ticker:hover .track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.header.scrolled .ticker{height:0;opacity:0;border-color:transparent}

/* nav */
.nav{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;padding:22px var(--pad);transition:padding .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease);border-bottom:1px solid transparent}
.header.scrolled .nav{padding:13px var(--pad);background:rgba(11,11,12,.74);backdrop-filter:blur(16px);border-color:var(--line)}
.header.scrolled .nav .brand .wm,.header.scrolled .nav .navtog,.header.scrolled .nav .links a{text-shadow:none}
.links a sup{color:var(--flare);font-size:.62em;top:-.7em;margin-left:1px;font-weight:600}
.links a.bag{display:inline-flex;align-items:center;gap:1px}
.links a.bag svg{display:block;width:19px;height:19px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{height:30px;width:auto;display:block}
.brand .mark svg,.brand .mark img{height:30px;width:auto;display:block}
.brand .wm{font-family:'Affigere',sans-serif;font-size:21px;letter-spacing:.05em;text-transform:uppercase;line-height:1}
.links{display:flex;gap:34px;align-items:center}
.links a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);position:relative;transition:color .4s}
.links a::after{content:'';position:absolute;left:0;bottom:-5px;width:100%;height:1px;background:var(--flare);transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.links a:hover{color:var(--bone)}
.links a:hover::after{transform:scaleX(1);transform-origin:left}
.links a.on{color:var(--bone)}

/* buttons */
.btn{position:relative;display:inline-flex;align-items:center;gap:12px;padding:17px 32px;border:1px solid var(--flare);background:var(--flare);color:var(--bone);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;overflow:hidden;cursor:pointer;transition:color .5s var(--ease)}
.btn span{position:relative;z-index:1}
.btn::before{content:'';position:absolute;inset:0;background:var(--bone);transform:translateY(102%);transition:transform .55s var(--ease)}
.btn:hover{color:var(--coal)}
.btn:hover::before{transform:none}
.btn.ghost{background:transparent;border-color:var(--line-2);color:var(--bone)}
.btn.ghost:hover{color:var(--coal)}
.btn.block{width:100%;justify-content:center}

/* utility text */
.eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--dim)}
.lede{font-size:clamp(20px,2vw,30px);font-weight:300;line-height:1.3;letter-spacing:-.01em}

/* reveal / mask animations */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1.05s var(--ease),transform 1.05s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.09s}.d2{transition-delay:.18s}.d3{transition-delay:.27s}.d4{transition-delay:.36s}
.mask{display:block;overflow:hidden}
.mask>span{display:block;transform:translateY(115%);transition:transform 1.05s var(--ease)}
.reveal.in .mask>span,.mask.in>span{transform:none}
.mask.m2>span{transition-delay:.1s}.mask.m3>span{transition-delay:.2s}

/* sections base */
section{position:relative}
.wrap{padding-left:var(--pad);padding-right:var(--pad)}

/* section heading */
.shead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;padding:0 var(--pad) 42px;border-bottom:1px solid var(--line);margin-bottom:58px}
.shead h2{font-size:clamp(38px,6.4vw,98px)}
.shead .side{font-size:13px;color:var(--dim);max-width:30ch;line-height:1.5;text-align:right}

/* frame / poster */
.frame{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--coal-2)}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.5s var(--ease)}
.frame.tall{aspect-ratio:3/4}
.hoverzoom:hover img{transform:scale(1.04)}

/* product grid */
.grid{display:grid;gap:clamp(20px,2.4vw,36px)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.piece{cursor:pointer}
.piece .ph{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bone)}
.piece .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.piece .ph::after{content:'';position:absolute;inset:0;background:radial-gradient(120% 100% at 50% 100%,rgba(214,42,38,.28),transparent 60%);opacity:0;transition:opacity .6s}
.piece:hover .ph img{transform:scale(1.05)}
.piece:hover .ph::after{opacity:1}
.piece .badge{position:absolute;top:14px;left:14px;z-index:2;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--bone);background:rgba(11,11,12,.55);backdrop-filter:blur(6px);padding:6px 10px}
.piece .meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px;border-top:1px solid var(--line);padding-top:13px}
.piece .meta .nm{font-family:'Affigere',sans-serif;text-transform:uppercase;font-size:clamp(20px,1.8vw,28px);letter-spacing:.02em}
.piece .meta .cat{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.piece .meta .arrow{color:var(--flare);opacity:0;transform:translateX(-6px);transition:.45s var(--ease)}
.piece:hover .meta .arrow{opacity:1;transform:none}

/* footer */
.foot{background:var(--coal-2);border-top:1px solid var(--line);padding:88px var(--pad) 32px;overflow:hidden}
.foot-main{display:flex;justify-content:space-between;gap:60px;flex-wrap:wrap;padding-bottom:60px;border-bottom:1px solid var(--line)}
.foot-news{max-width:400px}
.foot-news h3{font-family:'Affigere',sans-serif;text-transform:uppercase;font-size:clamp(30px,3.4vw,50px);line-height:.92;margin-bottom:22px}
.foot-input{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line-2);padding:11px 0;cursor:text;max-width:340px}
.foot-cols{display:flex;gap:60px}
.foot-cols h4{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--flare);margin-bottom:16px}
.foot-cols a{display:block;font-size:14px;color:var(--bone);opacity:.75;margin-bottom:10px;transition:opacity .3s}
.foot-cols a:hover{opacity:1}
.foot-word{display:block;font-family:'Affigere',sans-serif;text-transform:uppercase;font-weight:400;font-size:clamp(48px,14.6vw,214px);line-height:.8;letter-spacing:.004em;color:var(--bone);text-align:center;white-space:nowrap;margin:clamp(54px,8vh,120px) 0 clamp(42px,6vh,92px);transition:color .6s var(--ease)}
.foot-word:hover{color:var(--flare)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.foot-bot .mk{display:flex;align-items:center;gap:11px}
.foot-bot .mk img{height:26px;width:auto}
.foot-bot .mk span,.foot-bot .c{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}
.foot-bot .bfa{font-size:26px;color:var(--flare)}

/* ===== HOME ===== */
.hero{min-height:100svh;display:grid;grid-template-columns:1.02fr 1fr;align-items:stretch}
.hero .left{display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:140px 5vw 52px}
.hero .left .logo{height:150px;width:auto;align-self:flex-start;margin-bottom:auto}
.hero .left .h1{font-size:clamp(56px,7vw,116px);margin:34px 0 0}
.hero .left .sub{font-size:clamp(16px,1.3vw,20px);font-weight:300;line-height:1.4;max-width:22ch;color:var(--dim-2);margin-top:22px}
.hero .cta{display:flex;gap:14px;align-items:center;margin-top:38px;flex-wrap:wrap}
.hero .scrollcue{margin-top:40px;font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--dim);display:flex;align-items:center;gap:10px}
.hero .scrollcue i{width:30px;height:1px;background:var(--dim);display:block}
.hero .right{position:relative;overflow:hidden;background:#c9241f}
.hero .right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

.statement{min-height:78vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:26px;padding:18vh 8vw}
.statement .big{font-size:clamp(28px,3.7vw,52px);font-weight:300;line-height:1.16;max-width:19ch;letter-spacing:-.012em}
.statement .scrawl{font-size:clamp(36px,5vw,70px);color:var(--flare)}

.story-split{display:grid;grid-template-columns:1fr 1fr;min-height:98svh;align-items:stretch}
.story-split.rev{direction:rtl}.story-split.rev>*{direction:ltr}
.story-split .media{position:relative;overflow:hidden;background:var(--coal-2)}
.story-split .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.story-split .txt{display:flex;flex-direction:column;justify-content:center;gap:26px;padding:14vh 6vw}
.story-split .txt .q{font-size:clamp(26px,3vw,46px);font-weight:300;line-height:1.18;letter-spacing:-.012em}
.story-split .txt .q .scrawl{display:block;color:var(--flare);font-size:1.1em;margin-bottom:4px}
.story-split .txt p{color:var(--dim);max-width:44ch;font-size:15.5px;line-height:1.75}

.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,30px);padding:12vh var(--pad)}
.collection{padding:16vh 0 12vh}

/* red finale (web-built) */
.finale{position:relative;min-height:104svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  background:radial-gradient(120% 90% at 50% 30%,#e23a2f 0%,#c9241f 40%,#8f1712 100%)}
.finale #ash{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.6}
.finale .phoenix{position:relative;z-index:2;width:clamp(118px,15vw,216px);aspect-ratio:150/358;margin-bottom:30px;
  -webkit-mask:url('logo/mark-hi.png') center/contain no-repeat;mask:url('logo/mark-hi.png') center/contain no-repeat;
  background:linear-gradient(180deg,#ffffff 0%,#ffe4c4 45%,#ffb27a 78%,#ff8a4a 100%);
  animation:phx 3.4s ease-in-out infinite}
@keyframes phx{0%,100%{filter:drop-shadow(0 0 18px rgba(255,140,80,.45))}50%{filter:drop-shadow(0 0 42px rgba(255,185,120,.85))}}
.finale h2{position:relative;z-index:2;font-size:clamp(52px,11vw,168px);color:#fff}
.finale p{position:relative;z-index:2;color:rgba(255,255,255,.86);margin-top:14px;font-size:15px;letter-spacing:.02em}
.finale .cta{position:relative;z-index:2;margin-top:40px}
.finale .btn{background:#0b0b0c;border-color:#0b0b0c;color:#fff}
.finale .btn::before{background:#fff}
.finale .btn:hover{color:#c9241f}

/* ===== SHOP (PLP) ===== */
.page-head{padding:150px var(--pad) 60px}
.page-head h1{font-size:clamp(58px,12vw,190px);line-height:.86}
.page-head .row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-top:26px;flex-wrap:wrap}
.page-head .count{font-size:13px;color:var(--dim);letter-spacing:.04em}
.filters{display:flex;gap:12px;flex-wrap:wrap}
.chip{-webkit-appearance:none;appearance:none;background:transparent;font-family:inherit;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:10px 17px;border:1px solid var(--line-2);color:var(--dim-2);cursor:pointer;transition:color .4s,border-color .4s,background .4s}
.chip:hover{color:var(--bone);border-color:var(--bone)}
.chip.on{background:var(--bone);color:var(--coal);border-color:var(--bone)}
.plp{padding:0 var(--pad) 16vh}

/* ===== PDP ===== */
.pdp{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,4.5vw,88px);padding:132px var(--pad) 9vh;align-items:start}
.pdp .gallery{display:flex;flex-direction:column;gap:16px}
.pdp .gallery .main{aspect-ratio:3/4;overflow:hidden;background:var(--coal-3)}
.pdp .gallery .main img{width:100%;height:100%;object-fit:cover}
.pdp .gallery .thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pdp .gallery .thumbs .t{aspect-ratio:3/4;overflow:hidden;background:var(--coal-3);cursor:pointer;padding:0;border:1px solid transparent;opacity:.6;transition:opacity .4s,border-color .4s}
.pdp .gallery .thumbs .t img{width:100%;height:100%;object-fit:cover}
.pdp .gallery .thumbs .t:hover{opacity:1}
.pdp .gallery .thumbs .t[aria-pressed="true"]{opacity:1;border-color:var(--line-2)}
.pdp .info{position:sticky;top:118px;align-self:start;height:min-content;padding:8px 0 2vh}
.pdp .info h1{font-size:clamp(48px,4.8vw,86px);line-height:.9;margin:18px 0 24px}
.pdp .info .desc{color:var(--dim-2);font-size:16px;line-height:1.8;max-width:44ch;margin-bottom:38px}
.pdp .info .row{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.pdp .sizes{display:flex;gap:10px;margin:2px 0 36px;flex-wrap:wrap}
.pdp .sizes .sz{position:relative;z-index:0;min-width:58px;height:54px;padding:0 10px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-2);font-size:13px;letter-spacing:.05em;cursor:pointer;background:none;color:var(--bone);overflow:hidden;transition:color .45s var(--ease),border-color .4s}
.pdp .sizes .sz::before{content:'';position:absolute;inset:0;z-index:-1;background:var(--bone);transform:translateY(101%);transition:transform .45s var(--ease)}
.pdp .sizes .sz:hover{border-color:var(--bone)}
.pdp .sizes .sz.on{color:var(--coal);border-color:var(--bone)}
.pdp .sizes .sz.on::before{transform:none}
.pdp .acc{border-top:1px solid var(--line);margin-top:8px}
.pdp .acc .item{border-bottom:1px solid var(--line)}
.pdp .acc .q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:24px 0;cursor:pointer;font-family:'Affigere',sans-serif;font-size:17px;letter-spacing:.05em;text-transform:uppercase;color:var(--bone);background:none;border:none;text-align:left;transition:color .4s var(--ease)}
.pdp .acc .q:hover{color:var(--flare)}
.pdp .acc .q .p{position:relative;width:15px;height:15px;flex:none;color:var(--flare);transition:transform .5s var(--ease)}
.pdp .acc .q .p::before,.pdp .acc .q .p::after{content:'';position:absolute;left:50%;top:50%;background:currentColor}
.pdp .acc .q .p::before{width:15px;height:1.5px;transform:translate(-50%,-50%)}
.pdp .acc .q .p::after{width:1.5px;height:15px;transform:translate(-50%,-50%);transition:transform .5s var(--ease)}
.pdp .acc .item.open .q .p::after{transform:translate(-50%,-50%) scaleY(0)}
.pdp .acc .a{max-height:0;overflow:hidden;opacity:0;transition:max-height .55s var(--ease),opacity .45s var(--ease);color:var(--dim-2);font-size:14.5px;line-height:1.78}
.pdp .acc .item.open .a{max-height:240px;opacity:1}
.pdp .acc .a p{padding-bottom:26px;max-width:44ch}

/* ===== CHECKOUT ===== */
.checkout{display:grid;grid-template-columns:1.3fr .7fr;gap:0;padding-top:120px;min-height:100svh}
.checkout .items{padding:4vh var(--pad) 10vh}
.checkout .summary{background:var(--coal-2);border-left:1px solid var(--line);padding:5vh 4vw 10vh}
.line{display:flex;gap:20px;align-items:flex-start;padding:26px 0;border-bottom:1px solid var(--line)}
.line .th{width:96px;aspect-ratio:3/4;overflow:hidden;background:var(--bone);flex:none}
.line .th img{width:100%;height:100%;object-fit:cover}
.line .mid{flex:1}
.line .mid .nm{font-family:'Affigere',sans-serif;text-transform:uppercase;font-size:24px;letter-spacing:.02em}
.line .mid .sub{color:var(--dim);font-size:13px;margin-top:4px}
.line .mid .rm{-webkit-appearance:none;appearance:none;background:none;border:none;padding:0;font-family:inherit;color:var(--flare);font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-top:12px;display:inline-block;cursor:pointer}
.line .qty{display:flex;border:1px solid var(--line-2)}
.line .qty span{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}
.form{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:8px}
.field{grid-column:span 1;border-bottom:1px solid var(--line-2);padding:12px 0}
.field.full{grid-column:span 2}
.field label{display:block;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:6px}
.field input{width:100%;background:transparent;border:none;color:var(--bone);font-family:inherit;font-size:15px;outline:none}
.srow{display:flex;justify-content:space-between;align-items:center;padding:12px 0;font-size:14px;color:var(--dim-2)}
.srow.tot{border-top:1px solid var(--line-2);margin-top:12px;padding-top:20px}
.srow.tot b{font-family:'Affigere',sans-serif;font-size:26px;color:var(--bone)}
.empty{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:20px}
.empty h2{font-size:clamp(48px,9vw,120px)}

/* accessibility */
a:focus-visible,.btn:focus-visible,input:focus-visible,.chip:focus-visible,.sz:focus-visible{outline:2px solid var(--flare);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}#embers,.cursor-glow,#ash{display:none!important}.reveal{opacity:1!important;transform:none!important}.mask>span{transform:none!important}}

/* ===== page hero / editorial helpers ===== */
.page-hero{min-height:90svh;display:flex;flex-direction:column;justify-content:flex-end;padding:0 var(--pad) 9vh;gap:22px;position:relative;overflow:hidden}
.page-hero.center{justify-content:center;align-items:center;text-align:center}
.page-hero h1{font-size:clamp(64px,13vw,224px);line-height:.84}
.page-hero .intro{font-size:clamp(18px,1.6vw,27px);max-width:32ch;color:var(--dim-2);font-weight:300;line-height:1.35}
.page-hero .bgimg{position:absolute;inset:0;z-index:-1;opacity:.5}
.page-hero .bgimg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) contrast(1.05) brightness(.7)}
.center-frame{display:flex;justify-content:center;padding:13vh var(--pad)}
.center-frame .frame{width:min(560px,86vw)}
.bleed-line{padding:15vh var(--pad);text-align:center}
.bleed-line h2{font-size:clamp(34px,7vw,120px);line-height:.9;max-width:16ch;margin:0 auto}

/* lookbook masonry */
.look{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.4vw,22px);padding:0 var(--pad) 16vh}
.look .cell{position:relative;overflow:hidden;background:var(--coal-3);aspect-ratio:3/4}
.look .cell.full{grid-column:1/-1;aspect-ratio:16/7}
.look .cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.5s var(--ease),filter 1.5s}
.look .cell:hover img{transform:scale(1.045)}
.look .cell .cap{position:absolute;left:16px;bottom:14px;font-family:'Affigere',sans-serif;text-transform:uppercase;font-size:20px;letter-spacing:.03em;opacity:0;transform:translateY(8px);transition:.5s var(--ease);z-index:2;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.6)}
.look .cell:hover .cap{opacity:1;transform:none}

/* atelier steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,64px);padding:12vh var(--pad)}
.step .n{font-family:'Affigere',sans-serif;font-size:clamp(40px,4vw,72px);color:var(--flare);line-height:1}
.step h3{font-family:'Affigere',sans-serif;text-transform:uppercase;font-size:26px;margin:16px 0 12px;letter-spacing:.02em}
.step p{color:var(--dim);font-size:15px;line-height:1.7;max-width:34ch}

@media(max-width:900px){.look{grid-template-columns:repeat(2,1fr)}.look .cell.full{aspect-ratio:16/9}.steps{grid-template-columns:1fr;gap:40px}}
@media(max-width:560px){.look{grid-template-columns:1fr}.look .cell.full{grid-column:auto;aspect-ratio:3/4}}

/* ===== capture mode ===== */
.cap .page-hero{min-height:0!important;padding-top:150px!important;padding-bottom:70px!important}
.cap .center-frame{padding:80px var(--pad)!important}
.cap .bleed-line{padding:100px var(--pad)!important}
.cap .look{padding-bottom:100px!important}.cap .steps{padding:80px var(--pad)!important}
.cap .reveal{opacity:1!important;transform:none!important}
.cap .mask>span{transform:none!important}
.cap #veil{display:none!important}.cap .header{position:absolute!important}.cap .header .ticker{height:34px!important;opacity:1!important}
.cap .hero{min-height:0!important;height:auto!important}.cap .hero .right{height:860px!important}
.cap .statement{min-height:0!important;padding:130px 8vw!important}
.cap .story-split{min-height:0!important}.cap .story-split .media{height:860px!important}
.cap .finale{min-height:0!important;height:920px!important}
.cap .collection{padding:130px 0!important}.cap .checkout,.cap .pdp{min-height:0!important}
.cap .pdp .info{position:static!important}
.cap .duo{padding:70px var(--pad)!important}
.cap .story-split .txt{padding:90px 6vw!important}
.cap .pdp{padding-top:132px!important}.cap .page-head{padding-top:150px!important}
.cap .pdp .info{padding:8px 0 40px!important}
.cap .checkout .items,.cap .checkout .summary{padding-top:40px!important;padding-bottom:60px!important}

@media(max-width:900px){
  .links{display:none}
  .hero{grid-template-columns:1fr}.hero .right{min-height:74svh;order:-1}.hero .left{padding:118px var(--pad) 44px}.hero .left .logo{height:110px}
  .g3{grid-template-columns:1fr 1fr}.duo{grid-template-columns:1fr}
  .story-split{grid-template-columns:1fr}.story-split.rev{direction:ltr}.story-split .media{min-height:78svh}
  .shead{flex-direction:column;align-items:flex-start}.shead .side{text-align:left}
  .pdp{grid-template-columns:1fr}.pdp .gallery{padding:0 var(--pad)}.pdp .info{position:static;padding:6vh var(--pad)}
  .checkout{grid-template-columns:1fr}.checkout .summary{border-left:none;border-top:1px solid var(--line)}
  .foot-main{flex-direction:column;gap:40px}.foot-word{font-size:19vw;margin:6vh 0 5vh}.foot-bot{flex-direction:column;align-items:flex-start;gap:20px}
}
@media(max-width:560px){.g3{grid-template-columns:1fr}.form{grid-template-columns:1fr}.field{grid-column:span 1}.field.full{grid-column:span 1}}

/* ===================== committee polish ===================== */
:root{--dim:rgba(232,232,227,.62)}
/* buttons: coal text on flare for AA + couture feel */
.btn{color:#0b0b0c;font-weight:600}
.btn:hover{color:#0b0b0c}
.foot-cols h4{color:var(--dim-2)}
/* nav: scrim floor over bright hero + legible links + mobile toggle */
.nav::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,12,.62),transparent);z-index:-1;pointer-events:none}
.links a{color:var(--dim-2)}
.navtog{display:none;background:none;border:none;color:var(--bone);font-size:26px;line-height:1;cursor:pointer;z-index:2;padding:4px 8px}
/* one house photography treatment on dark plates + resolve-into-coal vignette */
.piece .ph img,.look .cell img,.pdp .gallery .main img,.line .th img{filter:grayscale(.12) contrast(1.06) brightness(.94) saturate(1.03)}
.piece .ph{background:var(--coal-3)}
.look .cell{background:var(--coal-3)}
.pdp .gallery .main{background:var(--coal-3)}
.line .th{background:var(--coal-3)}
.piece .ph::before,.look .cell::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(11,11,12,.6));pointer-events:none;z-index:1}
/* homepage brand statement on the display face */
.statement .big{font-family:'Affigere','Arial Narrow',sans-serif;text-transform:uppercase;font-weight:400;font-size:clamp(40px,5.6vw,94px);line-height:.92;letter-spacing:.006em;max-width:16ch;text-wrap:balance}
/* non-display story-split headline gets real weight; scrawl becomes a kicker */
.story-split .txt .q:not(.display){font-family:'Affigere',sans-serif;text-transform:uppercase;font-weight:400;font-size:clamp(30px,3.4vw,54px);line-height:.94;color:var(--bone);letter-spacing:.005em}
.story-split .txt .q .scrawl{font-size:.5em;margin-bottom:2px}
/* de-tagged pdp availability + checkout labels + held marker */
.pdp .info .avail{border:none;padding:0;text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:var(--dim-2)}
.field label{font-size:13px;letter-spacing:0;text-transform:none;color:var(--dim-2)}
.held{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim-2)}
/* SIGNATURE: smooth cursor + wipe transition + gated finale */
.cursor-glow{will-change:transform}
#veil{transition:transform .72s var(--ease)}
#veil.gone{transform:translateY(-100%);opacity:1;visibility:visible}
.finale{background:radial-gradient(120% 92% at 50% 28%,#d63a30 0%,#a81b15 42%,#5c120d 78%,#2a0b08 100%)}
.finale .phoenix{opacity:0;transform:translateY(26px) scale(.95)}
.finale.lit .phoenix{opacity:1;transform:none;transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
.cap .finale .phoenix{opacity:1!important;transform:none!important}
.cap #veil{display:none!important}
@media(max-width:900px){
  .navtog{display:block}
  .links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:2px;background:rgba(11,11,12,.98);backdrop-filter:blur(16px);padding:14px var(--pad) 24px;border-bottom:1px solid var(--line)}
  .nav.open .links{display:flex}
  .links a{font-size:16px;padding:13px 0;color:var(--bone);width:100%;letter-spacing:.14em}
}
/* footer newsletter as a real form */
.foot-input{cursor:auto}
.foot-input input{background:transparent;border:none;color:var(--bone);font:inherit;font-size:14px;flex:1;outline:none;letter-spacing:.06em}
.foot-input input::placeholder{color:var(--dim);text-transform:uppercase;letter-spacing:.14em;font-size:12px}
.foot-input button{background:none;border:none;color:var(--flare);font-size:18px;cursor:pointer;padding:0 0 0 12px;line-height:1}
.pdp .info .avail{text-transform:none;font-size:13px;letter-spacing:.02em}
/* nav legibility over bright hero */
.nav::before{background:linear-gradient(180deg,rgba(11,11,12,.82),rgba(11,11,12,.34) 62%,transparent)}
.brand .wm,.navtog,.links a{text-shadow:0 1px 16px rgba(0,0,0,.5)}
.nav.scrolled .brand .wm,.nav.scrolled .navtog,.nav.scrolled .links a{text-shadow:none}
/* hamburger drawn in CSS (font-independent), guaranteed at mobile */
@media(max-width:900px){
  .navtog{display:block;width:26px;height:15px;padding:0;border:none;font-size:0;color:transparent;background-color:transparent;background-image:linear-gradient(var(--bone),var(--bone)),linear-gradient(var(--bone),var(--bone)),linear-gradient(var(--bone),var(--bone));background-size:100% 2px;background-position:left top,left 6px,left bottom;background-repeat:no-repeat;filter:drop-shadow(0 1px 6px rgba(0,0,0,.65))}
  .nav.open .navtog{background-image:linear-gradient(var(--bone),var(--bone))}
}






