/* ============================================================
   BADSCANDAL — shared styles for index / lukepower / store / about
   (The private player, private.html, has its own styles.)
   ============================================================ */
:root{
  --ink:#0B0705;
  --ink-2:#161009;
  --ink-3:#211810;
  --uv:#F0791E;
  --uv-soft:rgba(240,121,30,.45);
  --uv-line:rgba(240,121,30,.18);
  --ember:#FFB454;
  --paper:#F3E9DD;
  --white:#FFFFFF;
  --muted:#A08C77;
  --muted-2:#7A6753;
  --maxw:1000px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--paper);
  background:var(--ink);
  min-height:100%;
  display:flex;flex-direction:column;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.mono{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif}
a{color:inherit}

/* ============================================================
   BACKGROUND — grainy gradient artwork, pulsing like a slow heartbeat
   ============================================================ */
/* static fallback image — sits behind the WebGL canvas */
body::before{
  content:"";position:fixed;inset:0;z-index:-4;
  background:var(--ink) url("bg.jpg") center center / cover no-repeat;
  filter:brightness(.8) saturate(1.0);
  transform-origin:center;
  animation:bs-heartbeat 9s ease-in-out infinite;
  will-change:opacity, transform;
}
/* WebGL liquid gradient canvas (added by bg.js; covers the fallback when active) */
#bs-bg{
  position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;
  z-index:-3;display:block;pointer-events:none;
}
/* grain + vignette + top/bottom scrim for legibility */
body::after{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"),
    linear-gradient(180deg, rgba(8,5,4,.62) 0%, rgba(8,5,4,0) 15%, rgba(8,5,4,0) 76%, rgba(8,5,4,.6) 100%),
    radial-gradient(135% 120% at 50% 28%, transparent 44%, rgba(8,5,4,.55) 100%);
  background-size:140px 140px, 100% 100%, cover;
  background-repeat:repeat, no-repeat, no-repeat;
}
@keyframes bs-heartbeat{
  0%   { opacity:.42; transform:scale(1.000); }
  10%  { opacity:.80; transform:scale(1.035); }  /* lub */
  18%  { opacity:.56; transform:scale(1.014); }
  27%  { opacity:.72; transform:scale(1.028); }  /* dub */
  45%  { opacity:.42; transform:scale(1.000); }  /* rest */
  100% { opacity:.42; transform:scale(1.000); }
}

/* keep all content above the background layers */
header,main,footer{position:relative;z-index:1}

/* ---------- top bar ---------- */
header{
  max-width:var(--maxw);width:100%;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:26px 24px;
}
.mark{
  font-weight:700;letter-spacing:.4em;font-size:14px;text-transform:uppercase;
  text-decoration:none;color:var(--white);
  text-shadow:0 2px 22px rgba(0,0,0,.55);
}
.mark b{color:var(--white);font-weight:700}
nav a{
  color:var(--muted);text-decoration:none;font-size:12px;letter-spacing:.18em;
  text-transform:uppercase;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;margin-left:22px;
  transition:color .18s;text-shadow:0 2px 16px rgba(0,0,0,.5);
}
nav a:hover,nav a.active{color:var(--white)}

/* ---------- shared main wrapper ---------- */
main{
  flex:1;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:40px 24px 90px;
}

/* ---------- hero / page head ---------- */
.eyebrow{
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:12px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ember);margin-bottom:24px;
  text-shadow:0 2px 20px rgba(0,0,0,.6);
}
h1{
  font-size:clamp(56px,15vw,180px);line-height:.86;font-weight:700;
  letter-spacing:-.03em;text-transform:uppercase;color:var(--white);
  text-shadow:0 4px 40px rgba(0,0,0,.5);
}
h1.small{font-size:clamp(44px,9vw,96px)}
/* single-word BADSCANDAL on the home page, always one line */
h1.home-title{white-space:nowrap;font-size:clamp(38px,13vw,168px)}
.tagline{
  margin-top:28px;max-width:50ch;color:var(--paper);font-size:clamp(16px,2.2vw,20px);
  line-height:1.55;text-shadow:0 2px 24px rgba(0,0,0,.6);
}
.tagline b{color:var(--white);font-weight:500}

/* ---------- doorways (home) ---------- */
.doors{
  margin-top:54px;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;
}
.door{
  border:1px solid var(--uv-line);border-radius:10px;padding:22px 20px;
  text-decoration:none;color:var(--paper);background:rgba(15,10,7,.55);
  backdrop-filter:blur(2px);
  transition:border-color .2s, background .2s, transform .12s;display:block;
}
.door:hover{border-color:var(--uv-soft);background:rgba(28,22,15,.7);transform:translateY(-2px)}
.door .n{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.2em;color:var(--uv);text-transform:uppercase}
.door .t{font-size:20px;font-weight:600;margin-top:12px;color:var(--white)}
.door .t::after{content:" →";color:var(--muted-2)}
.door .d{font-size:13px;color:var(--muted);margin-top:6px;line-height:1.45}

/* ---------- prose sections (about / info) ---------- */
.prose{max-width:62ch;margin-top:40px}
.prose p{color:var(--paper);font-size:17px;line-height:1.7;margin-bottom:22px}
.prose p b{color:var(--white);font-weight:500}
.section-label{
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--uv);margin:48px 0 16px;
  padding-top:24px;border-top:1px solid var(--uv-line);
}

/* ---------- link buttons (streaming / socials / contact) ---------- */
.links{margin-top:28px;display:flex;flex-direction:column;gap:12px;max-width:560px}
.linkbtn{
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid var(--uv-line);border-radius:10px;padding:18px 22px;
  text-decoration:none;color:var(--paper);background:rgba(15,10,7,.55);
  backdrop-filter:blur(2px);
  transition:border-color .2s, background .2s, transform .12s;
}
.linkbtn:hover{border-color:var(--uv-soft);background:rgba(28,22,15,.7);transform:translateY(-2px)}
.linkbtn .l{font-size:17px;font-weight:500;color:var(--white)}
.linkbtn .r{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.linkbtn.primary{background:var(--uv);border-color:var(--uv)}
.linkbtn.primary .l{color:#1a0d03;font-weight:600}
.linkbtn.primary .r{color:rgba(26,13,3,.65)}
.linkbtn.primary:hover{background:var(--ember);transform:translateY(-2px)}

/* ---------- social grid (lukepower hub) ---------- */
.social-grid{
  margin-top:28px;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;max-width:680px;
}
.social{
  border:1px solid var(--uv-line);border-radius:10px;padding:18px 18px;
  text-decoration:none;background:rgba(15,10,7,.55);backdrop-filter:blur(2px);
  transition:border-color .2s, background .2s, transform .12s;
}
.social:hover{border-color:var(--uv-soft);background:rgba(28,22,15,.7);transform:translateY(-2px)}
.social .p{font-size:16px;font-weight:600;color:var(--white)}
.social .h{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.06em;color:var(--muted);margin-top:4px}

/* ---------- IG / social feed embed ---------- */
.feed{
  margin-top:24px;border:1px solid var(--uv-line);border-radius:12px;
  background:rgba(15,10,7,.5);backdrop-filter:blur(2px);
  padding:14px;max-width:680px;min-height:120px;
}
.feed-placeholder{
  display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;
  text-align:center;padding:46px 24px;color:var(--muted);
  border:1px dashed var(--uv-line);border-radius:8px;
}
.feed-placeholder .t{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--uv)}
.feed-placeholder .d{font-size:13px;line-height:1.5;max-width:42ch}
/* live Instagram feed widget (Behold) */
.feed behold-widget{
  display:block;width:100%;
  --behold-gap:8px;
  --behold-row-gap:8px;
  --behold-column-gap:8px;
  --behold-image-border-radius:10px;
  --behold-border-radius:10px;
}
.feed .feed-link{
  display:inline-block;margin-top:14px;
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--uv);text-decoration:none;opacity:.85;transition:opacity .2s ease;
}
.feed .feed-link:hover{opacity:1}

/* ---------- store grid ---------- */
.store-grid{
  margin-top:28px;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;
}
.product{
  border:1px solid var(--uv-line);border-radius:12px;overflow:hidden;
  background:rgba(15,10,7,.55);backdrop-filter:blur(2px);
}
.product .ph{
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg, rgba(240,121,30,.18), rgba(15,10,7,.6));
  color:var(--muted-2);font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
}
.product .meta{padding:14px 16px}
.product .meta .nm{font-size:15px;font-weight:600;color:var(--white)}
.product .meta .pr{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:13px;color:var(--uv);margin-top:4px}

/* ---------- footer ---------- */
footer{
  max-width:var(--maxw);width:100%;margin:0 auto;
  padding:24px;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:11px;
  letter-spacing:.1em;color:var(--muted-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  border-top:1px solid var(--uv-line);
}
footer a{color:var(--muted-2);text-decoration:none}
footer a:hover{color:var(--muted)}

@media (max-width:680px){
  header{flex-direction:column;gap:16px;align-items:flex-start}
  nav{display:flex;flex-wrap:wrap;gap:6px 0}
  nav a:first-child{margin-left:0}
}
@media (prefers-reduced-motion:reduce){
  body::before{animation:none;opacity:.5}
  *{transition:none!important}
}

/* ============================================================
   INTRO GATE + "UNLOCK THE DROP" GAME + CHAOS BUTTON
   ============================================================ */
body.bs-intro-lock{ overflow:hidden; }

#bs-intro{
  position:fixed; inset:0; z-index:99999; overflow:hidden;
  background:radial-gradient(120% 90% at 50% 40%, #0b0603 0%, #050301 60%, #010100 100%);
  opacity:1; transition:opacity .6s ease;
}
#bs-intro.bs-intro-out{ opacity:0; pointer-events:none; }
.bs-intro-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:1; }

.bs-intro-stage{
  position:absolute; inset:0; z-index:2;
  display:flex; align-items:flex-end; justify-content:center;
  padding-bottom:13vh; pointer-events:none;
}
.bs-intro-choices{
  display:flex; flex-direction:column; gap:12px; align-items:center;
  opacity:0; transform:translateY(16px);
  transition:opacity .6s ease, transform .6s ease; pointer-events:none;
}
.bs-intro-choices.show{ opacity:1; transform:none; pointer-events:auto; }

/* shared slick button */
.bs-btn{
  font:600 14px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:.04em;
  padding:15px 26px; border-radius:999px; cursor:pointer;
  border:1px solid var(--uv-line); background:rgba(20,14,9,.7); color:var(--paper);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  transition:transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.bs-btn:hover{ transform:translateY(-2px); border-color:var(--uv-soft); }
.bs-btn:active{ transform:translateY(0); }
.bs-btn.primary{ background:var(--uv); border-color:var(--uv); color:#1a0d04; box-shadow:0 0 30px rgba(240,121,30,.35); }
.bs-btn.primary:hover{ box-shadow:0 0 46px rgba(240,121,30,.55); }
.bs-btn.ghost{ background:transparent; color:var(--muted); }
.bs-btn.ghost:hover{ color:var(--paper); }
.bs-btn span{ color:inherit; }

/* game */
.bs-game{ position:absolute; inset:0; z-index:3; display:none; }
.bs-game.show{ display:block; }
.bs-game-hud{
  position:absolute; top:0; left:0; right:0; height:64px; z-index:4;
  display:flex; align-items:center; justify-content:space-between; padding:0 20px;
  font:700 14px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:.12em;
  text-transform:uppercase; color:var(--paper);
  background:linear-gradient(to bottom, rgba(6,4,3,.9), rgba(6,4,3,0));
}
.bs-game-hud b{ color:var(--uv); font-size:18px; }
.bs-game-label{ color:var(--muted); font-size:10px; letter-spacing:.26em; }
.bs-game-arena{ position:absolute; inset:0; z-index:3; }

.bs-target{
  position:absolute; width:60px; height:60px; padding:0; border:none; background:none;
  transform:translate(-50%,-50%) scale(0); transform-origin:center;
  font-size:34px; line-height:1; cursor:pointer; border-radius:50%;
  filter:drop-shadow(0 0 10px rgba(240,121,30,.85));
  animation:bs-pop .18s ease forwards;
  -webkit-tap-highlight-color:transparent; touch-action:manipulation;
}
.bs-target::before{
  content:""; position:absolute; inset:-12px; border-radius:50%; z-index:-1;
  background:radial-gradient(circle, rgba(240,121,30,.38), transparent 70%);
  animation:bs-pulse 1s ease-in-out infinite;
}
@keyframes bs-pop{ to{ transform:translate(-50%,-50%) scale(1); } }
@keyframes bs-pulse{ 50%{ transform:scale(1.28); opacity:.55; } }
.bs-target.hit{ animation:bs-hit .2s ease forwards; }
@keyframes bs-hit{ to{ transform:translate(-50%,-50%) scale(1.9); opacity:0; } }
.bs-target.gone{ animation:bs-gone .22s ease forwards; }
@keyframes bs-gone{ to{ transform:translate(-50%,-50%) scale(0); opacity:0; } }

/* result */
.bs-result{
  position:absolute; inset:0; z-index:6; display:none;
  flex-direction:column; align-items:center; justify-content:center; gap:8px;
  text-align:center; padding:24px;
  background:radial-gradient(100% 80% at 50% 45%, rgba(11,7,5,.55), rgba(5,3,2,.93));
}
.bs-result.show{ display:flex; animation:bs-rfade .4s ease; }
@keyframes bs-rfade{ from{ opacity:0; transform:scale(.98); } }
.bs-result-score{
  font:800 clamp(64px,16vw,104px)/0.9 'Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--white); display:flex; align-items:baseline; gap:12px;
}
.bs-result-score span{ font-size:15px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.bs-result-score.win{ color:var(--uv); text-shadow:0 0 44px rgba(240,121,30,.6); }
.bs-result-score.mid{ color:var(--ember); }
.bs-result-title{
  font:800 clamp(22px,5vw,30px)/1.1 'Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--paper); text-transform:lowercase; margin-top:8px;
}
.bs-result-sub{ color:var(--muted); font-size:14px; letter-spacing:.03em; }
.bs-result-actions{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:22px; }

.bs-hype{
  position:absolute; z-index:7; pointer-events:none; white-space:nowrap;
  font:800 clamp(18px,4.4vw,32px)/1 'Helvetica Neue',Helvetica,Arial,sans-serif;
  color:var(--uv); text-shadow:0 0 20px rgba(240,121,30,.75);
  transform:rotate(var(--rot,0deg)); animation:bs-hype 2.2s ease forwards;
}
@keyframes bs-hype{
  0%{ opacity:0; transform:rotate(var(--rot)) scale(.5); }
  18%{ opacity:1; transform:rotate(var(--rot)) scale(1.12); }
  78%{ opacity:1; }
  100%{ opacity:0; transform:rotate(var(--rot)) translateY(-34px) scale(1); }
}

/* floating buttons */
.bs-fab{
  position:fixed; bottom:18px; z-index:9000;
  font:600 12px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:.08em;
  padding:11px 16px; border-radius:999px; cursor:pointer;
  border:1px solid var(--uv-line); background:rgba(14,9,6,.82); color:var(--paper);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:inline-flex; align-items:center; gap:7px;
  transition:transform .15s ease, border-color .2s ease, box-shadow .2s ease;
  -webkit-tap-highlight-color:transparent;
}
.bs-fab:hover{ transform:translateY(-2px); border-color:var(--uv-soft); box-shadow:0 0 24px rgba(240,121,30,.3); }
.bs-fab span{ color:var(--uv); font-size:14px; }
.bs-fab-game{ right:18px; }
.bs-fab-chaos{ left:18px; }

/* chaos effect */
body.bs-chaos header, body.bs-chaos main, body.bs-chaos footer{
  animation:bs-shake .42s cubic-bezier(.36,.07,.19,.97) infinite;
}
@keyframes bs-shake{
  10%{ transform:translate(-2px,1px) rotate(-.4deg); }
  20%{ transform:translate(3px,-2px) rotate(.5deg); }
  30%{ transform:translate(-4px,2px) rotate(-.6deg); }
  40%{ transform:translate(4px,-1px) rotate(.5deg); }
  50%{ transform:translate(-3px,2px) rotate(-.4deg); }
  60%{ transform:translate(3px,-2px) rotate(.4deg); }
  70%{ transform:translate(-2px,1px) rotate(-.3deg); }
  80%{ transform:translate(2px,-1px) rotate(.3deg); }
  100%{ transform:translate(0,0) rotate(0); }
}
.bs-chaos-flash{
  position:fixed; inset:0; z-index:8500; pointer-events:none;
  background:linear-gradient(45deg, rgba(240,121,30,.28), rgba(255,77,26,.22));
  mix-blend-mode:screen; animation:bs-flash 4s ease forwards;
}
@keyframes bs-flash{ 0%{opacity:0;} 8%{opacity:1;} 16%{opacity:.15;} 26%{opacity:.8;} 36%{opacity:.1;} 50%{opacity:.6;} 70%{opacity:.15;} 88%{opacity:.4;} 100%{opacity:0;} }
.bs-chaos-word{
  font-family:'Helvetica Neue',Helvetica,Arial,sans-serif; font-weight:800;
  letter-spacing:.01em; white-space:nowrap; text-transform:lowercase;
  text-shadow:0 0 16px rgba(240,121,30,.55);
}
.bs-chaos-bit{
  position:fixed; top:-60px; z-index:8600; pointer-events:none; will-change:transform,opacity;
  animation-name:bs-rain; animation-timing-function:linear; animation-fill-mode:forwards;
}
@keyframes bs-rain{
  0%{ transform:translateY(-60px) translateX(0) rotate(0); opacity:0; }
  10%{ opacity:1; }
  100%{ transform:translateY(112vh) translateX(var(--drift,0)) rotate(360deg); opacity:.9; }
}

@media (max-width:560px){
  .bs-fab{ font-size:11px; padding:10px 13px; }
  .bs-target{ width:54px; height:54px; font-size:30px; }
}

/* ============================================================
   LIVE STORE (catalog grid, cart drawer, variant modal)
   ============================================================ */
.shop-head{ display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.cart-btn{
  margin-top:6px; flex:none; cursor:pointer; position:relative;
  font:600 12px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:.1em; text-transform:uppercase;
  padding:12px 18px; border-radius:999px; color:var(--paper);
  border:1px solid var(--uv-line); background:rgba(20,14,9,.7);
  transition:border-color .2s ease, transform .15s ease;
}
.cart-btn:hover{ border-color:var(--uv-soft); transform:translateY(-1px); }
.cart-count{
  position:absolute; top:-7px; right:-7px; min-width:20px; height:20px; padding:0 5px;
  display:flex; align-items:center; justify-content:center;
  background:var(--uv); color:#1a0d04; border-radius:999px; font-size:11px; font-weight:800;
}
#shop-banner{ margin:18px 0 4px; padding:12px 16px; border-radius:10px; font-size:14px; }
#shop-banner.good{ background:rgba(240,121,30,.14); border:1px solid var(--uv-soft); color:var(--paper); }
#shop-banner.warn{ background:rgba(255,77,26,.12); border:1px solid rgba(255,77,26,.4); color:var(--paper); }
.shop-status{ margin-top:26px; color:var(--muted); font-size:14px; }

.shop-grid{
  margin-top:26px; display:grid; gap:16px;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
}
.shop-card{
  text-align:left; cursor:pointer; padding:0; overflow:hidden;
  border:1px solid var(--uv-line); border-radius:14px; background:rgba(15,10,7,.5);
  color:var(--paper); transition:transform .18s ease, border-color .2s ease, box-shadow .2s ease;
}
.shop-card:hover{ transform:translateY(-3px); border-color:var(--uv-soft); box-shadow:0 14px 40px rgba(0,0,0,.45); }
.shop-card-img{ aspect-ratio:1/1; background:var(--ink-2); display:flex; align-items:center; justify-content:center; }
.shop-card-img img{ width:100%; height:100%; object-fit:cover; display:block; }
.shop-card-meta{ padding:13px 14px 16px; }
.shop-card-meta .nm{ font-weight:700; font-size:15px; }
.shop-card-meta .pr{ color:var(--uv); font-size:13px; margin-top:4px; letter-spacing:.02em; }

/* overlay */
.shop-overlay{ position:fixed; inset:0; z-index:9500; background:rgba(4,3,2,.72); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); opacity:0; transition:opacity .25s ease; }
.shop-overlay.show{ opacity:1; }

/* variant modal */
.variant-modal{ position:fixed; inset:0; z-index:9600; display:flex; align-items:center; justify-content:center; padding:20px; }
.vm-card{
  width:100%; max-width:380px; background:var(--ink-2); border:1px solid var(--uv-line);
  border-radius:18px; padding:18px; position:relative;
  box-shadow:0 30px 80px rgba(0,0,0,.6); animation:bs-rfade .25s ease;
}
.vm-close{ position:absolute; top:10px; right:12px; background:none; border:none; color:var(--muted); font-size:26px; line-height:1; cursor:pointer; }
.vm-close:hover{ color:var(--paper); }
.vm-img{ aspect-ratio:1/1; border-radius:12px; overflow:hidden; background:var(--ink-3); margin-bottom:14px; }
.vm-img img{ width:100%; height:100%; object-fit:cover; }
.vm-name{ font-weight:800; font-size:19px; }
.vm-label{ display:block; margin:14px 0 6px; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.vm-select{
  width:100%; padding:13px 14px; border-radius:10px; cursor:pointer;
  background:var(--ink-3); color:var(--paper); border:1px solid var(--uv-line);
  font:500 14px/1 'Helvetica Neue',Helvetica,Arial,sans-serif;
}

/* cart drawer */
.cart-drawer{
  position:fixed; top:0; right:0; bottom:0; width:min(92vw, 380px); z-index:9600;
  background:var(--ink-2); border-left:1px solid var(--uv-line);
  transform:translateX(102%); transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex; flex-direction:column;
}
.cart-drawer.open{ transform:none; box-shadow:-20px 0 60px rgba(0,0,0,.5); }
.cart-drawer-head{ padding:22px 20px 14px; font-weight:800; font-size:18px; border-bottom:1px solid var(--uv-line); }
.cart-items{ flex:1; overflow-y:auto; padding:8px 20px; }
.cart-row{ padding:14px 0; border-bottom:1px solid rgba(240,121,30,.1); }
.cart-row-name{ font-size:14px; font-weight:600; margin-bottom:8px; }
.cart-row-ctl{ display:flex; align-items:center; gap:10px; font-size:13px; }
.cart-row-ctl button{
  width:26px; height:26px; border-radius:7px; cursor:pointer; color:var(--paper);
  border:1px solid var(--uv-line); background:var(--ink-3); font-size:15px; line-height:1;
}
.cart-row-ctl button:hover{ border-color:var(--uv-soft); }
.cart-row-pr{ margin-left:auto; color:var(--uv); font-weight:700; }
.cart-row-x{ width:auto !important; padding:0 8px; color:var(--muted) !important; font-size:11px !important; letter-spacing:.06em; }
.cart-foot{ padding:18px 20px 22px; border-top:1px solid var(--uv-line); }
.cart-total-row{ display:flex; justify-content:space-between; font-weight:800; font-size:17px; margin-bottom:4px; }
.cart-note{ color:var(--muted); font-size:12px; margin-bottom:14px; }

@media (max-width:560px){
  .shop-grid{ grid-template-columns:repeat(auto-fill, minmax(150px, 1fr)); gap:12px; }
}

/* ============================================================
   HOMEPAGE — centered layout, spaced wordmark, intro name,
   and the "stick man reveal" of the tagline swear
   (scoped to body.home so the inner pages are untouched)
   ============================================================ */

/* center the whole homepage column */
body.home main{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding-top:7vh;
}
body.home .eyebrow{ margin-bottom:16px; }
body.home .tagline{ margin-left:auto; margin-right:auto; }
/* doors span the full width so the 4 cards stay symmetric/centered */
body.home .doors{ width:100%; align-self:stretch; max-width:var(--maxw); }

/* big BADSCANDAL — airy tracking to echo the small wordmark, kept on one line */
body.home .home-title{
  letter-spacing:.10em;
  font-size:clamp(30px,10.8vw,140px);
  padding-left:.10em;            /* optical re-center for the trailing track */
}

/* small "Luke Power" inside the intro, sitting just above the forming wordmark */
.bs-intro-name{
  position:absolute; left:0; right:0; top:34%; z-index:2;
  text-align:center; pointer-events:none;
  font:600 12px/1 'Helvetica Neue',Helvetica,Arial,sans-serif;
  letter-spacing:.42em; text-transform:uppercase; color:var(--ember);
  opacity:0; transform:translateY(8px);
  transition:opacity .6s ease, transform .6s ease;
  text-shadow:0 2px 18px rgba(0,0,0,.6);
}
.bs-intro-name.show{ opacity:.92; transform:none; }

/* the tagline becomes the positioning context for the walker */
body.home .tagline{ position:relative; display:inline-block; }
/* each asterisk is its own element so he can grab them one at a time.
   The real letters (u, c, k) are injected by JS at runtime — the served
   HTML only ever contains "f***", so search engines stay clean. */
.bs-star{ display:inline-block; will-change:transform,opacity; }
.bs-star.gone{
  transition:transform .14s ease, opacity .14s ease;
  transform:translateY(-7px) scale(1.7) rotate(12deg); opacity:0;
}
.bs-star.lit{ animation:bs-letter-in .5s cubic-bezier(.2,.8,.3,1) both; }
@keyframes bs-letter-in{
  0%  { opacity:0; transform:translateY(8px) scale(.5); color:var(--uv); text-shadow:0 0 14px rgba(240,121,30,.95); }
  55% { opacity:1; color:var(--ember); text-shadow:0 0 10px rgba(255,180,84,.55); }
  100%{ opacity:1; transform:none; color:inherit; text-shadow:none; }
}

/* ---------- the little troublemaker (stick man) ---------- */
.bs-stickman{
  position:absolute; left:0; top:0; z-index:5; pointer-events:none;
  /* width/height/left/top are set by JS, relative to the tagline */
}
.bs-stickman .sm-rig{ display:block; width:100%; height:100%; }
.bs-stickman svg{ width:100%; height:100%; display:block; overflow:visible; }
.bs-stickman .sm{ stroke:#fff; stroke-width:2.1; stroke-linecap:round; fill:none; }
.bs-stickman .head{ stroke-width:2; }
.bs-stickman svg *{ transform-box:fill-box; }

/* ENTRANCE — swing in on an arc from off-screen upper-left, settle upright */
.bs-stickman.swing .sm-rig{ animation:bs-sm-swingin 1.25s cubic-bezier(.2,.65,.3,1) both; }
@keyframes bs-sm-swingin{
  0%  { transform:translate(-82vw,-46vh) rotate(-46deg); opacity:0; }
  12% { opacity:1; }
  45% { transform:translate(-26vw,-18vh) rotate(-26deg); }
  70% { transform:translate(-3vw,-2vh)   rotate(14deg); }
  82% { transform:translate(2px,2px)     rotate(-7deg); }
  92% { transform:rotate(4deg); }
  100%{ transform:translate(0,0) rotate(0); }
}

/* WALK — legs + arms swing, gentle body bob */
.bs-stickman.walking .leg-front{ animation:bs-sm-legA .32s ease-in-out infinite; transform-origin:top center; }
.bs-stickman.walking .leg-back { animation:bs-sm-legB .32s ease-in-out infinite; transform-origin:top center; }
.bs-stickman.walking .arm-front{ animation:bs-sm-armA .32s ease-in-out infinite; transform-origin:top center; }
.bs-stickman.walking .arm-back { animation:bs-sm-armB .32s ease-in-out infinite; transform-origin:top center; }
.bs-stickman.walking .sm-bob   { animation:bs-sm-bob  .32s ease-in-out infinite; }
@keyframes bs-sm-legA{ 0%,100%{ transform:rotate(22deg);} 50%{ transform:rotate(-22deg);} }
@keyframes bs-sm-legB{ 0%,100%{ transform:rotate(-22deg);} 50%{ transform:rotate(22deg);} }
@keyframes bs-sm-armA{ 0%,100%{ transform:rotate(-16deg);} 50%{ transform:rotate(16deg);} }
@keyframes bs-sm-armB{ 0%,100%{ transform:rotate(16deg);} 50%{ transform:rotate(-16deg);} }
@keyframes bs-sm-bob { 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-1.1px);} }

/* GRAB — front arm reaches up to the star, quick snatch, back down */
.bs-stickman.grab .arm-front{ animation:bs-sm-grab .56s cubic-bezier(.3,.6,.3,1) both; transform-origin:top center; }
@keyframes bs-sm-grab{
  0%  { transform:rotate(0deg); }
  38% { transform:rotate(-118deg); }
  50% { transform:rotate(-128deg); }   /* snatch */
  62% { transform:rotate(-116deg); }
  100%{ transform:rotate(0deg); }
}

@media (prefers-reduced-motion:reduce){
  .bs-stickman{ display:none; }
}

/* ---- mobile: tighten the homepage so there's less to scroll ---- */
@media (max-width:680px){
  body.home main{ padding-top:5vh; padding-bottom:60px; }
  body.home .doors{ grid-template-columns:repeat(2,1fr); gap:10px; margin-top:38px; }
  body.home .door{ padding:16px 14px; }
  body.home .door .t{ font-size:17px; margin-top:8px; }
  body.home .door .d{ font-size:12px; }
}
@media (max-width:380px){
  body.home .doors{ grid-template-columns:1fr; }
}

/* ============================================================
   INTRO BACKGROUND VIDEO (optional) — sits behind the particles.
   Drop a compressed intro.mp4 in to enable; gradient is the fallback.
   ============================================================ */
.bs-intro-photo{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; pointer-events:none; display:block;
}
.bs-intro-veil{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  /* >>> EDIT DARKNESS HERE <<< raise the alphas to darken further,
     lower them to brighten. Set very dark — backdrop just barely visible. */
  background:radial-gradient(125% 95% at 50% 42%,
              rgba(4,3,2,.55) 0%, rgba(2,1,1,.74) 62%, rgba(0,0,0,.86) 100%);
}

/* ============================================================
   STORE — "coming soon": stick man drops a bomb, it explodes
   into the COMING SOON reveal + notify button. (store-soon.js)
   ============================================================ */
.soon{
  position:relative; min-height:62vh; margin-top:24px;
  display:flex; align-items:center; justify-content:center;
}
.soon-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:1; pointer-events:none; }
.soon-content{ position:relative; z-index:2; text-align:center; max-width:560px; padding:0 16px; }
.soon-title{
  font-size:clamp(40px,9vw,96px); line-height:.9; font-weight:700;
  text-transform:uppercase; letter-spacing:.06em; color:var(--white);
  text-shadow:0 4px 40px rgba(0,0,0,.5);
}
.soon-sub{ margin-top:16px; color:var(--paper); font-size:clamp(14px,2.2vw,17px); line-height:1.55; }
.soon-btn{
  display:inline-flex; align-items:center; gap:8px; margin-top:26px;
  font:600 13px/1 'Helvetica Neue',Helvetica,Arial,sans-serif; letter-spacing:.08em; text-transform:uppercase;
  padding:15px 26px; border-radius:999px; text-decoration:none;
  background:var(--uv); color:#1a0d04; border:1px solid var(--uv);
  box-shadow:0 0 30px rgba(240,121,30,.35);
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
}
.soon-btn:hover{ transform:translateY(-2px); background:var(--ember); box-shadow:0 0 46px rgba(240,121,30,.55); }

/* entrance animations for the reveal */
.soon-title.soon-in{ animation:soon-title-in .6s cubic-bezier(.2,.8,.3,1) both; }
@keyframes soon-title-in{
  0%  { opacity:0; transform:scale(.6); filter:blur(6px); text-shadow:0 0 50px rgba(240,121,30,.9); }
  60% { opacity:1; }
  100%{ opacity:1; transform:none; filter:none; }
}
.soon-sub.soon-in, .soon-btn.soon-in{ animation:soon-fade-in .5s ease both; }
@keyframes soon-fade-in{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }

/* the bomb */
.soon-bomb{ position:absolute; z-index:3; pointer-events:none; transform:translate(-50%,-50%); }
.soon-bomb svg{ overflow:visible; display:block; }
.soon-bomb .fuse-spark{ filter:drop-shadow(0 0 6px #ffd27a); animation:soon-spark .12s steps(2,jump-none) infinite; }
@keyframes soon-spark{ 0%{opacity:1;} 50%{opacity:.35;} 100%{opacity:1;} }
.soon-bomb.boom{ animation:soon-boom .2s ease forwards; }
@keyframes soon-boom{ 0%{transform:translate(-50%,-50%) scale(1);} 55%{transform:translate(-50%,-50%) scale(1.6);} 100%{transform:translate(-50%,-50%) scale(2.3); opacity:0;} }

/* blast flash */
.soon-flash{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:radial-gradient(circle at var(--fx,50%) var(--fy,55%),
              rgba(255,205,130,.55), rgba(255,120,40,0) 58%);
  animation:soon-flash .5s ease forwards;
}
@keyframes soon-flash{ 0%{opacity:0;} 12%{opacity:1;} 100%{opacity:0;} }

/* stick man faces left when he flees */
.bs-stickman.sm-flip .sm-rig{ transform:scaleX(-1); }
