
/* Embedded fonts */
@font-face {
  font-family: 'Moderniz';
  src: url('../assets/fonts/fonts_e2a88b557a6b.otf') format('opentype');
  font-display: swap;
}
@font-face {
  font-family: 'RobotoCondensed';
  src: url('../assets/fonts/fonts_3dfac3e16a83.ttf') format('truetype');
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: 'RobotoCondensed';
  src: url('../assets/fonts/fonts_1f10cda1ee30.ttf') format('truetype');
  font-weight: 700;
  font-display: swap;
}

:root {
  --bg: #050505;
  --ink: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);
  --line: rgba(255,255,255,.14);
  --red: #ff2b2b;
  --red2: #ff3d6e;
  --shadow: 0 24px 80px rgba(0,0,0,.55);
  --radius: 20px;
  --max: 1140px;

  --h1: clamp(44px, 6.6vw, 92px);
  --h2: clamp(30px, 4.2vw, 58px);
  --k: clamp(12px, 1.2vw, 14px);
  --p: clamp(16px, 1.7vw, 19px);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: radial-gradient(1200px 800px at 70% -10%, rgba(255,43,43,.18), transparent 60%),
              radial-gradient(900px 700px at 15% 15%, rgba(255,61,110,.10), transparent 60%),
              linear-gradient(180deg, #000, #060606 30%, #000 100%);
  color: var(--ink);
  font-family: RobotoCondensed, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  letter-spacing: .01em;
  overflow-x:hidden;
}
a{color:inherit}
button,input,select,textarea{font:inherit}
::selection{background: rgba(255,43,43,.35)}

/* global grain */
.grain::before{
  content:'';
  pointer-events:none;
  position:fixed; inset:0;
  background-image:url("../assets/images/images_d58ab25fe628.svg");
  opacity:.18;
  mix-blend-mode:overlay;
  filter: contrast(120%) brightness(110%);
  z-index:2;
}
/* soft vignette */
.grain::after{
  content:'';
  pointer-events:none;
  position:fixed; inset:-2px;
  background: radial-gradient(1200px 700px at 50% 0%, transparent 55%, rgba(0,0,0,.55) 95%);
  z-index:2;
}

#app{position:relative; z-index:3}

/* top bar */
.topbar{
  position:fixed;
  top:0; left:0; right:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 18px clamp(16px, 3vw, 28px);
  z-index:50;
  backdrop-filter: blur(8px);
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,0));
}
.brand{
  display:flex; align-items:center; gap:12px;
}

.brand img{width:46px; height:46px; border-radius:12px; box-shadow: 0 12px 40px rgba(0,0,0,.35)}
.brand .word{
  line-height:1.05;
  font-family: Moderniz, system-ui, sans-serif;
  letter-spacing:.08em;
  font-size: 20px;
  text-transform: uppercase;
}
.brand .tag{font-size:12px; color:var(--muted); letter-spacing:.12em; text-transform:uppercase}

.nav{
  display:flex; gap:12px; align-items:center;
}
.nav a{
  text-decoration:none;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(255,255,255,.75);
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  background: rgba(0,0,0,.25);
  transition: transform .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}
.nav a:hover{
  transform: translateY(-1px);
  border-color: rgba(255,43,43,.40);
  background: rgba(255,43,43,.10);
  color: rgba(255,255,255,.95);
}
.nav .cta{
  border-color: rgba(255,43,43,.55);
  background: rgba(255,43,43,.16);
}
.menuBtn{
  display:none;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.25);
  color: rgba(255,255,255,.85);
  border-radius: 999px;
  padding: 10px 12px;
}

@media (max-width: 860px){
  .nav a{display:none}
  .menuBtn{display:inline-flex}
}

/* panel base */
.panel{
  position:relative;
  min-height: 100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 110px 18px 84px;
  overflow:hidden;  border-top: none;
}
.panel + .panel{
  border-top: 1px solid rgba(255,255,255,.06);
}

.panel .inner{
  width: min(var(--max), 100%);
  margin: 0 auto;
  position:relative;
  z-index:4;
}
.kicker{
  font-size: var(--k);
  letter-spacing:.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  display:inline-flex;
  gap:10px;
  align-items:center;
}
.kicker::before{
  content:'';
  width: 22px; height:1px;
  background: rgba(255,43,43,.85);
  box-shadow: 0 0 26px rgba(255,43,43,.45);
}
.h2{
  margin: 16px 0 18px;
  font-family: Moderniz, system-ui, sans-serif;
  font-size: var(--h2);
  letter-spacing:.06em;
  text-transform: uppercase;
  line-height:1.05;
}
.p{
  margin: 0;
  font-size: var(--p);
  line-height: 1.5;
  color: var(--muted);
  max-width: 62ch;
  white-space: normal;
}
.xglow{
  color: var(--red);
  text-shadow: 0 0 18px rgba(255,43,43,.55), 0 0 55px rgba(255,43,43,.25);
}

#lookbook .brandGlow{
  color: var(--ink);
  text-shadow: 0 0 14px rgba(255,43,43,.22);
}
/* reveal */
[data-reveal]{
  opacity:0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease;
}
[data-reveal].in{
  opacity:1;
  transform:none;
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  [data-reveal]{opacity:1; transform:none; transition:none}
}

/* HERO */
.hero{
  padding: 0;
  border-top:none;
}
.hero .heroWrap{
  position:relative;
  width: 100%;
  min-height: 100vh;
  display:grid;
  grid-template-columns: 1fr minmax(320px, 540px);
}
.hero .media{
  position:absolute; inset:0;
  z-index:1;
}
.hero .media img{
  width:100%; height:100%;
  object-fit:cover;
  transform: scale(var(--heroScale,1));
  transition: transform .08s linear;
}
.hero .media::after{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(900px 680px at 25% 30%, transparent 45%, rgba(0,0,0,.70) 78%),
    linear-gradient(90deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.26) 42%, rgba(0,0,0,.85) 72%, rgba(0,0,0,.95) 100%);
}
.hero .content{
  position:relative;
  z-index:3;
  grid-column:2;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding: 120px clamp(18px, 3.2vw, 36px) 92px;
}
.hero .h1{
  font-family: Moderniz, system-ui, sans-serif;
  font-size: var(--h1);
  letter-spacing: .08em;
  text-transform: uppercase;
  line-height: .95;
  margin: 0 0 14px;
}
.hero .sub{
  margin: 0 0 24px;
  font-size: 14px;
  letter-spacing:.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
}
.hero .ctaRow{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  align-items:center;
}
.btn{
  appearance:none;
  border: 1px solid rgba(255,43,43,.55);
  background: linear-gradient(180deg, rgba(255,43,43,.22), rgba(255,43,43,.10));
  color: rgba(255,255,255,.92);
  padding: 14px 16px;
  border-radius: 999px;
  text-decoration:none;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-size: 12px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{transform: translateY(-1px); border-color: rgba(255,43,43,.85); background: rgba(255,43,43,.20)}
.btn.secondary{
  border-color: rgba(255,255,255,.18);
  background: rgba(0,0,0,.28);
}
.pulseDot{
  width:8px; height:8px; border-radius:99px;
  background: var(--red);
  box-shadow: 0 0 0 0 rgba(255,43,43,.55);
  animation: pulse 1.8s infinite;
}
@keyframes pulse {
  0% {box-shadow: 0 0 0 0 rgba(255,43,43,.55)}
  70% {box-shadow: 0 0 0 18px rgba(255,43,43,0)}
  100% {box-shadow: 0 0 0 0 rgba(255,43,43,0)}
}
.scrollCue{
  position:absolute;
  left: 20px;
  bottom: 18px;
  z-index:4;
  display:flex;
  gap:12px;
  align-items:center;
  color: rgba(255,255,255,.70);
  font-size: 12px;
  letter-spacing:.20em;
  text-transform: uppercase;
}
.scrollArrow{
  width: 14px; height: 22px;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 999px;
  position:relative;
  opacity:.9;
}
.scrollArrow::after{
  content:'';
  position:absolute; left:50%; top:6px;
  width:3px; height:3px;
  background: rgba(255,255,255,.75);
  border-radius:99px;
  transform: translateX(-50%);
  animation: scrolldot 1.5s infinite;
}
@keyframes scrolldot{
  0%{transform: translate(-50%,0); opacity:0}
  20%{opacity:1}
  80%{transform: translate(-50%,10px); opacity:0}
  100%{opacity:0}
}

@media (max-width: 860px){
  .hero .heroWrap{grid-template-columns: 1fr}
  .hero .content{grid-column:1; max-width: 560px}
  .hero .media::after{background:
    radial-gradient(900px 680px at 40% 28%, transparent 40%, rgba(0,0,0,.72) 80%),
    linear-gradient(180deg, rgba(0,0,0,.18) 0%, rgba(0,0,0,.72) 70%, rgba(0,0,0,.92) 100%);
  }
  .scrollCue{left: 16px}
}

/* image cards */
.grid2{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items:center;
}
@media (max-width: 980px){
  .grid2{grid-template-columns: 1fr; gap: 18px}
}
.card{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(0,0,0,.38);
  box-shadow: var(--shadow);
}
.card .img{
  position:relative;
  height: clamp(260px, 42vw, 460px);
}
.card .img img{
  width:100%; height:100%;
  object-fit:cover;
  transform: scale(1.02);
}
.card .img::after{
  content:'';
  position:absolute; inset:0;
  background: radial-gradient(800px 500px at 70% 20%, rgba(255,43,43,.12), transparent 55%),
              linear-gradient(180deg, transparent 30%, rgba(0,0,0,.70) 100%);
}
.card .cap{
  padding: 16px 16px 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.70);
  font-size: 12px;
  letter-spacing:.14em;
  text-transform: uppercase;
  display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,43,43,.35);
  background: rgba(255,43,43,.10);
  color: rgba(255,255,255,.85);
  font-size: 11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}

/* big statement */
.statement{
  text-align:center;
}
.statement .h2{
  max-width: 18ch;
  margin-left:auto;
  margin-right:auto;
}
.statement .scanline{
  width: min(780px, 92%);
  height: 1px;
  margin: 26px auto 0;
  background: linear-gradient(90deg, transparent, rgba(255,43,43,.65), transparent);
  box-shadow: 0 0 28px rgba(255,43,43,.30);
}

/* product carousel */
.carousel{
  position:relative;
  margin-top: 20px;
}
.track{
  display:flex;
  gap: 14px;
  overflow:auto;
  scroll-snap-type: x mandatory;
  padding: 8px 4px 12px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.20) transparent;
}
.track::-webkit-scrollbar{height:8px}
.track::-webkit-scrollbar-thumb{background: rgba(255,255,255,.20); border-radius:999px}
.item{
  flex: 0 0 min(380px, 86vw);
  scroll-snap-align: start;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  box-shadow: var(--shadow);
}
.item .ph{
  position:relative;
  height: 360px;
}
.item img{width:100%; height:100%; object-fit:cover}
.item .ph::after{
  content:'';
  position:absolute; inset:0;
  background: radial-gradient(700px 460px at 70% 20%, rgba(255,43,43,.10), transparent 55%),
              linear-gradient(180deg, transparent 40%, rgba(0,0,0,.75) 100%);
}
.item .meta{
  padding: 14px 14px 16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.item .meta .t{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing:.18em;
  color: rgba(255,255,255,.75);
}
.item .meta .s{
  margin-top: 6px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  letter-spacing:.08em;
}
.arrowRow{
  display:flex;
  gap: 10px;
  margin-top: 12px;
}
.iconBtn{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.28);
  color: rgba(255,255,255,.85);
  border-radius: 999px;
  padding: 10px 12px;
  cursor:pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.iconBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(255,43,43,.45);
  background: rgba(255,43,43,.10);
}

/* form */
.formWrap{
  margin-top: 22px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 860px){
  .formWrap{grid-template-columns:1fr}
}
.field{
  display:flex;
  flex-direction:column;
  gap: 8px;
}
label{
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
}
input,textarea,select{
  width: 100%;
  padding: 14px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.92);
  outline:none;
}
textarea{min-height: 120px; resize: vertical}
input:focus,textarea:focus,select:focus{border-color: rgba(255,43,43,.55); box-shadow: 0 0 0 4px rgba(255,43,43,.10)}
.formActions{grid-column:1 / -1; display:flex; flex-wrap:wrap; gap: 12px; align-items:center}
.note{
  font-size: 12px;
  color: rgba(255,255,255,.55);
  letter-spacing:.04em;
}
.toast{
  position:fixed;
  left: 18px;
  bottom: 18px;
  z-index: 90;
  background: rgba(0,0,0,.62);
  border:1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: var(--shadow);
  transform: translateY(14px);
  opacity:0;
  pointer-events:none;
  transition: opacity .25s ease, transform .25s ease;
}
.toast.show{opacity:1; transform:none}
.toast b{letter-spacing:.14em; text-transform: uppercase; font-size: 12px}
.toast div{margin-top: 6px; font-size:12px; color: rgba(255,255,255,.62)}

/* footer */
footer{
  padding: 40px 18px 70px;
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.62);
}
footer .inner{
  width: min(var(--max), 100%);
  margin: 0 auto;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap: 14px;
}
.footerLinks{display:flex; gap:14px; flex-wrap:wrap}
.footerLinks a{text-decoration:none; border-bottom: 1px solid rgba(255,255,255,.22)}
.smallcaps{font-size: 11px; letter-spacing:.18em; text-transform:uppercase}

/* modal nav (mobile) */
.modal{
  position:fixed; inset:0;
  z-index:80;
  display:none;
}
.modal.open{display:block}
.modal .backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
}
.modal .sheet{
  position:absolute;
  right: 14px;
  top: 14px;
  left: 14px;
  border-radius: 20px;
  background: rgba(0,0,0,.72);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  padding: 14px;
}
.modal .sheet .row{display:flex; justify-content:space-between; align-items:center; gap:10px}
.modal .sheet .row b{font-size: 12px; letter-spacing:.18em; text-transform:uppercase}
.modal .sheet a{
  display:block;
  text-decoration:none;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  margin-top: 10px;
  background: rgba(255,255,255,.05);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size: 12px;
}
.modal .sheet a:hover{border-color: rgba(255,43,43,.40); background: rgba(255,43,43,.10)}
.closeBtn{padding: 10px 12px}

/* topbar alignment: logo hard-left, nav right */
.topbar{justify-content:space-between !important;}
.topbar .brand{position:relative !important;left:0 !important;transform:none !important;}
/* STEP 1.2 — Hero text visibility */
@media (min-width: 861px){
  .hero .heroWrap{
    grid-template-columns: 1fr minmax(340px, 640px);
  }
}


/* STEP 1.3 — Hero headline visibility (size + position) */
@media (min-width: 861px){
  .hero .content{
    transform: translateX(-5vw);
  }
  .hero .h1{
    font-size: clamp(38px, 5.4vw, 78px);
  }
}
@media (max-width: 860px){
  .hero .h1{
    font-size: clamp(34px, 9vw, 54px);
  }
}


/* STEP WTF — Moderniz font for WTF H1 */
@font-face{
  font-family:"Moderniz";
  src:url(../assets/fonts/fonts_e2a88b557a6b.otf) format("opentype");
  font-weight:400;
  font-style:normal;
}

@media (min-width: 861px){
  #wtf .h1{
    font-family:"Moderniz","FreeRoad",sans-serif;
    font-size: clamp(34px, 4.8vw, 64px);
    line-height: 1.05;
  }
}

@media (max-width: 860px){
  #wtf .h1{
    font-family:"Moderniz","FreeRoad",sans-serif;
    font-size: clamp(30px, 8vw, 46px);
    line-height: 1.05;
  }
}


/* STEP WTF — BRAUX label font (embedded) */
@font-face{
  font-family:"BrauxFont";
  src:url(../assets/fonts/fonts_3dfac3e16a83.ttf) format("truetype");
  font-weight:400;
  font-style:normal;
}

#wtf .brauxLabel{
  font-family:"BrauxFont","FreeRoad",sans-serif;
}


/* STEP CULTURE — show more image */
#culture .card .img{
  height: clamp(320px, 50vw, 620px);
}
#culture .card .img img{
  transform: none;
  object-position: 50% 20%;
}


/* STEP LEADERS — show more powerstance image */
#leaders .card .cap{border-top-color: rgba(255,255,255,.06);} /* match panel hairline */


/* PANEL DIVIDER CLEANUP — neutralize internal card dividers that can be mistaken for section breaks */
#wtf .card .cap{ border-top: none; padding-top: 14px; }
#crew .card .cap{ border-top: none; padding-top: 14px; }
/* (leaders keeps its cap divider; enable the next line only if needed) */
/* #leaders .card .cap{ border-top: none; padding-top: 14px; } */
#leaders .card .img{
  height: clamp(320px, 50vw, 640px);
}
#leaders .card .img img{
  transform: none;
  object-position: 50% 12%;
}





/* STEP CREW — boxing baddie (full frame) */
#crew .card .img{
  height: clamp(360px, 56vw, 700px);
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.22);
}
#crew .card .img img{
  transform: none;
  object-fit: contain;
  object-position: 50% 12%;
}

/* FIX — leaders panel top/bottom separator alignment on shorter viewports
   Cause: #leaders content can exceed 100vh (large image + fixed panel padding),
   so the .panel flex centering makes the section "float" and the separator borders
   appear misaligned. This keeps the content pinned from the top and scales the card
   height by viewport height when needed. */
@media (max-height: 860px){
  #leaders.panel{
    justify-content: flex-start;
    padding-top: 96px;
    padding-bottom: 64px;
  }
  #leaders .grid2{ align-items: flex-start; }
  #leaders .card .img{ height: clamp(280px, 44vh, 560px); }
}
@media (max-height: 740px){
  #leaders.panel{
    padding-top: 86px;
    padding-bottom: 54px;
  }
  #leaders .card .img{ height: clamp(240px, 40vh, 500px); }
}


/* Launch variants viewer */
#launch .grid2{
  grid-template-columns: .75fr 1.25fr;
  align-items: start;
}
.variants{ position:relative; margin-top: 20px; }
#launch .variants{ margin-top: 4px; }
.variantGrid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
}
@media (min-width: 1100px){
  .variantGrid{ grid-template-columns: 1fr 1fr; }
  #launch .grid2{ grid-template-columns: .72fr 1.28fr; }
}
.variantCard{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}
.variantHead{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px 8px;
}
.variantLabel{
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
}
.toggleRow{ display:flex; gap: 8px; }
.toggleBtn{
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.88);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 8px 10px;
  cursor: pointer;
  user-select:none;
}
.toggleBtn:hover{ border-color: rgba(255,255,255,.22); }
.toggleBtn.is-active{
  border-color: rgba(255,43,43,.55);
  box-shadow: 0 0 0 4px rgba(255,43,43,.10);
}
.variantImgWrap{
  position: relative;
  padding: 10px 12px 14px;
  height: clamp(340px, 48vh, 680px);
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(900px 500px at 50% 30%, rgba(255,43,43,.10), transparent 60%),
    rgba(0,0,0,.20);
}
@media (min-width: 1100px){
  .variantImgWrap{ height: clamp(360px, 52vh, 720px); }
}
.variantImgWrap img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: saturate(1.02) contrast(1.02);
}
@media (max-height: 820px){
  .variantImgWrap{ height: clamp(280px, 40vh, 560px); }
}

/* =========================
   LIGHTBOX (image zoom)
   ========================= */
body.lb-lock{ overflow:hidden; }

.variantImgWrap img{ cursor: zoom-in; }

.zoomHint{
  margin-top: 10px;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .68;
}

.lbOverlay{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 22px;
  background: rgba(0,0,0,.82);
  z-index: 9999;
}
.lbOverlay.is-open{ display:flex; }

.lbPanel{
  position: relative;
  width: min(1200px, 96vw);
  height: min(88vh, 900px);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(10,10,10,.55);
  box-shadow: 0 30px 90px rgba(0,0,0,.62);
  backdrop-filter: blur(10px);
}

.lbTop{
  position: absolute;
  top: 0; left: 0; right: 0;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(0,0,0,.60), rgba(0,0,0,0));
}

.lbTitle{
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .84;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lbActions{ display:flex; gap: 10px; align-items:center; }

.lbBtn{
  appearance:none;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  color: inherit;
  padding: 10px 14px;
  border-radius: 999px;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
}
.lbBtn:hover{ border-color: rgba(255,255,255,.22); background: rgba(0,0,0,.32); }

.lbStage{
  position: absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding-top: 54px; /* make space for top bar */
  touch-action: none;
}

.lbStage img{
  max-width: 92%;
  max-height: 86%;
  user-select: none;
  -webkit-user-drag: none;
  transform: translate3d(0,0,0) scale(1);
  transition: transform .08s linear;
  cursor: grab;
}
.lbStage img.is-grabbing{ cursor: grabbing; }

.lbHint{
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  font-size: 12px;
  line-height: 1.25;
  opacity: .80;
  border-radius: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.38);
}

@media (max-width: 700px){
  .lbPanel{ height: 90vh; }
  .lbHint{ font-size: 11px; }
}


/* =========================================================
   LOOKBOOK (STEP 2) — GRID + PLACEHOLDERS ONLY (NO JS)
   ========================================================= */
#lookbook .lbWrap{ margin-top: 22px; }
#lookbook .lbGrid{
  --lbUnit: clamp(58px, 6.8vw, 92px);
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: var(--lbUnit);
  gap: 14px;
}
#lookbook .lbTile{
  position: relative;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(0,0,0,.38);
  box-shadow: var(--shadow);
}
#lookbook .lbTile::before{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(760px 460px at 65% 18%, rgba(255,43,43,.10), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.32));
}
#lookbook .lbPh{
  position:absolute; inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family: Moderniz, system-ui, sans-serif;
  letter-spacing:.14em;
  font-size: 20px;
  color: rgba(255,255,255,.32);
  text-transform: uppercase;
}


#lookbook .lbTile{ background: transparent; }
#lookbook .lbTile::before{ display:none; }
#lookbook .lbImg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center;
}
/* Desktop placement to match the model */
#lookbook .lb-a{ grid-column: 1; grid-row: 1 / span 3; }
#lookbook .lb-b{ grid-column: 2; grid-row: 1 / span 3; }
#lookbook .lb-c{ grid-column: 3; grid-row: 1 / span 3; }
#lookbook .lb-d{ grid-column: 4; grid-row: 1 / span 3; }

#lookbook .lb-e{ grid-column: 1 / span 3; grid-row: 4 / span 3; }
#lookbook .lb-f{ grid-column: 4;          grid-row: 4 / span 3; }

#lookbook .lb-g{ grid-column: 1 / span 2; grid-row: 7 / span 3; }
#lookbook .lb-h{ grid-column: 3;          grid-row: 7 / span 3; }
#lookbook .lb-i{ grid-column: 4;          grid-row: 7 / span 3; }

/* Responsive fallbacks (still placeholders) */
@media (max-width: 980px){
  #lookbook .lbGrid{
    --lbUnit: clamp(64px, 14vw, 112px);
    grid-template-columns: repeat(2, 1fr);
  }
  #lookbook .lbTile{ grid-column:auto !important; grid-row:auto !important; }
  #lookbook .lb-a, #lookbook .lb-b, #lookbook .lb-c, #lookbook .lb-d,
  #lookbook .lb-f, #lookbook .lb-h, #lookbook .lb-i{ grid-row: span 3 !important; }
  #lookbook .lb-e, #lookbook .lb-g{ grid-column: 1 / -1 !important; grid-row: span 3 !important; }
}
@media (max-width: 640px){
  #lookbook .lbGrid{
    --lbUnit: clamp(74px, 22vw, 122px);
    grid-template-columns: 1fr;
  }
  #lookbook .lbTile{ grid-column: 1 / -1 !important; grid-row: span 3 !important; }
}


.btnTight{letter-spacing:0; display:inline-block; white-space:nowrap;}


/* HERO CTA tightening + BRX spacing */
.heroCta{
  padding: 12px 14px;
  gap: 8px;
  letter-spacing: .12em;
}
.heroCta .btnLabel{white-space:nowrap;}
.heroCta .btnTight{letter-spacing: 0 !important; word-spacing: 0;}
.heroCta .btnTight .xglow{display:inline-block; margin-left:-0.03em; margin-right:-0.03em;}
.hero .heroBrand{margin:0 0 24px;}
.hero .heroTag{margin:0 0 14px;}
.hero .heroBrand{display:inline-block;}
.hero .heroFierce{display:inline-block;}

/* HERO LIGHTING — static key light + X halo + desktop hover intensification (no looping) */
.hero .heroBrand{
  position: relative;
  display: inline-block;
}
.hero .heroBrand::after{
  content: attr(data-text);
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg,
    rgba(255,255,255,.42) 0%,
    rgba(255,255,255,.16) 18%,
    rgba(255,255,255,0) 42%,
    rgba(255,255,255,0) 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  opacity: .78;
  mix-blend-mode: normal;
  filter: blur(.15px);
  pointer-events: none;
  transition: opacity .22s ease;
}
@media (hover:hover) and (pointer:fine){
  .hero .heroBrand:hover::after{ opacity: 1; }
}
/* refine hero-only X backlight (halo, not neon) */
.hero .heroBrand .xglow{
  text-shadow:
    0 0 10px rgba(255,43,43,.62),
    0 0 28px rgba(255,43,43,.28),
    0 0 70px rgba(255,43,43,.16);}



/* panel break tidy: scanline removed */
.statement .scanline{display:none !important;}
