/* ============================================================
   BLADE & RUBBER — "Coin-Op"  ·  retro-arcade cabinet kit
   Rubik Mono One (display) · Rubik (body) · VT323 (utility/score)
   Neon on cabinet-black. CRT scanlines · HI-SCORE rows · INSERT COIN.
   ============================================================ */

@font-face{
  font-family:"Rubik Mono One";
  src:url("../fonts/rubikmono.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Rubik";
  src:url("../fonts/rubik.woff2") format("woff2");
  font-weight:400 700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"VT323";
  src:url("../fonts/vt323.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}

/* ── tokens ─────────────────────────────────────────────── */
:root{
  --black:#0A0A12;       /* cabinet */
  --panel:#15121F;       /* raised panel */
  --panel-2:#1E1830;     /* lifted panel */
  --paper:#F0E9D0;       /* warm paper / primary text */
  --magenta:#FF2D8E;     /* hot accent */
  --cyan:#21E6D4;        /* neon cyan */
  --yellow:#FFD23F;      /* arcade yellow */
  --ink:#0A0A12;         /* dark text on neon blocks */
  --muted:rgba(240,233,208,.62);
  --line:rgba(240,233,208,.16);

  --disp:"Rubik Mono One","Arial Black",Arial,sans-serif;
  --body:"Rubik","Helvetica Neue",Arial,sans-serif;
  --mono:"VT323",ui-monospace,Menlo,monospace;

  --wrap:1180px;
  --gutter:clamp(1.15rem,4.5vw,4rem);
  --shadow-mag:7px 7px 0 var(--magenta);
  --shadow-cyan:7px 7px 0 var(--cyan);
  --shadow-ink:7px 7px 0 var(--black);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
[id]{scroll-margin-top:76px}

body{
  background:var(--black);
  color:var(--paper);
  font-family:var(--body);
  font-size:clamp(1rem,.97rem + .2vw,1.06rem);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}

/* ── CRT scanline overlay (signature) ──────────────────── */
body::before{
  content:"";position:fixed;inset:0;z-index:999;pointer-events:none;
  background:repeating-linear-gradient(
    to bottom,
    rgba(10,10,18,0) 0,
    rgba(10,10,18,0) 2px,
    rgba(10,10,18,.28) 3px,
    rgba(10,10,18,0) 4px);
  mix-blend-mode:multiply;
  animation:crt 8s linear infinite;
}
@keyframes crt{from{background-position:0 0}to{background-position:0 96px}}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* halftone helper: saturated block with retro dot grid */
.halftone{
  background-image:radial-gradient(circle,rgba(10,10,18,.28) 1.5px,transparent 1.6px);
  background-size:18px 18px;
}

/* ── typography ────────────────────────────────────────── */
.display,h1,h2,h3{
  font-family:var(--disp);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.01em;
  text-transform:uppercase;
}
h1{font-size:clamp(2.6rem,7.5vw,5.4rem)}
h2{font-size:clamp(1.9rem,4.4vw,3.1rem)}
h3{font-size:clamp(1.05rem,1.6vw,1.35rem);line-height:1.1}
p{max-width:64ch}

.eyebrow{
  font-family:var(--mono);
  font-size:1.1rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--cyan);
  font-weight:400;
  display:inline-block;
}
.eyebrow.mag{color:var(--magenta)}
.eyebrow.yel{color:var(--yellow)}
.mono{font-family:var(--mono);font-size:1.15rem;letter-spacing:.03em;line-height:1.35}
.muted{color:var(--muted)}
.lead{font-size:clamp(1.06rem,1rem + .5vw,1.3rem);line-height:1.5;color:var(--paper)}
.glow-mag{text-shadow:0 0 12px rgba(255,45,142,.55)}
.glow-cyan{text-shadow:0 0 12px rgba(33,230,212,.5)}

/* ── layout scaffolding ────────────────────────────────── */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(3rem,7vw,6rem)}
.stack>*+*{margin-top:1.1rem}
.rule{height:4px;background:var(--paper);border:0}

.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;margin-bottom:clamp(1.6rem,3.5vw,2.6rem)}
.sec-head h2{max-width:18ch}

/* ── coin ticker: mono strip like a marquee readout ────── */
.coinbar{
  background:var(--black);border-top:3px solid var(--magenta);border-bottom:3px solid var(--cyan);
  overflow:hidden;
}
.coinbar .row{
  max-width:var(--wrap);margin-inline:auto;padding:.55rem var(--gutter);
  display:flex;gap:clamp(1rem,4vw,2.8rem);flex-wrap:wrap;justify-content:space-between;
  font-family:var(--mono);font-size:1.15rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);
}
.coinbar .row b{color:var(--yellow);font-weight:400}

/* ── buttons: chunky pills ─────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--disp);font-size:.8rem;
  letter-spacing:.02em;text-transform:uppercase;
  padding:.9rem 1.6rem;border-radius:999px;border:3px solid var(--black);
  transition:transform .14s ease,background .14s ease,color .14s ease,box-shadow .14s ease;
  cursor:pointer;line-height:1;
}
.btn:hover{transform:translate(-2px,-2px)}
.btn-fill{background:var(--magenta);color:var(--paper);border-color:var(--paper);box-shadow:4px 4px 0 var(--black)}
.btn-fill:hover{background:var(--yellow);color:var(--ink);box-shadow:6px 6px 0 var(--black)}
.btn-cyan{background:var(--cyan);color:var(--ink);border-color:var(--black);box-shadow:4px 4px 0 var(--magenta)}
.btn-cyan:hover{background:var(--yellow);box-shadow:6px 6px 0 var(--magenta)}
.btn-ghost{background:transparent;color:var(--paper);border-color:var(--paper)}
.btn-ghost:hover{background:var(--paper);color:var(--ink)}
.arrow{font-family:var(--mono);font-size:1.2em}

/* ── header / nav: pill buttons on a black band ────────── */
.site-head{
  position:sticky;top:0;z-index:60;
  background:var(--black);
  border-bottom:4px solid var(--yellow);
}
.site-head .bar{
  max-width:var(--wrap);margin-inline:auto;padding:.7rem var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
}
.brand{
  font-family:var(--disp);font-size:clamp(1.15rem,2.2vw,1.5rem);color:var(--paper);
  letter-spacing:-.01em;line-height:1;
  border-bottom:4px dashed var(--yellow);padding-bottom:3px;
}
.brand b{color:var(--magenta)}
.nav{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.nav a{
  font-family:var(--disp);font-size:.66rem;letter-spacing:.02em;text-transform:uppercase;
  color:var(--paper);background:var(--panel);
  padding:.5rem .85rem;border-radius:999px;border:2px solid transparent;line-height:1;
  transition:background .14s ease,color .14s ease,border-color .14s ease;
}
.nav a:hover{background:var(--magenta);color:var(--paper);border-color:var(--paper)}
.nav a.active{background:var(--yellow);color:var(--ink)}
.nav a.cart{background:var(--cyan);color:var(--ink)}
.nav a.cart:hover{background:var(--yellow)}

/* ── hero: split color-block panels ────────────────────── */
.hero{display:grid;grid-template-columns:1.05fr .95fr;position:relative;border-bottom:4px solid var(--paper)}
@media(max-width:820px){.hero{grid-template-columns:1fr}}
.hero-l{
  background:var(--black);padding:clamp(2.6rem,6vw,5rem) var(--gutter);
  display:flex;flex-direction:column;justify-content:center;gap:1.2rem;
}
.hero-l h1{max-width:14ch}
.hero-l h1 em{font-style:normal;color:var(--magenta)}
.hero-l .lead{max-width:38ch;color:var(--muted)}
.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:.6rem}
.hero-r{
  position:relative;background:var(--cyan);overflow:hidden;min-height:320px;
  border-left:4px solid var(--paper);
}
@media(max-width:820px){.hero-r{border-left:0;border-top:4px solid var(--paper)}}
.hero-r img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;mix-blend-mode:luminosity;opacity:.92}
.hero-r::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(33,230,212,.15),rgba(255,45,142,.28))}
/* sticker badge over the split */
.sticker{
  position:absolute;z-index:5;width:132px;height:132px;border-radius:50%;
  background:var(--yellow);color:var(--ink);border:4px solid var(--ink);
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--disp);font-size:.82rem;text-transform:uppercase;line-height:1.15;
  transform:rotate(12deg);box-shadow:4px 4px 0 var(--magenta);padding:.4rem;
  left:calc(50% - 66px);top:calc(50% - 66px);
}
@media(max-width:820px){.sticker{left:auto;right:1rem;top:auto;bottom:-40px}}

/* ── compact interior header (carries identity everywhere) ── */
.hero-compact{
  background:var(--black);border-bottom:4px solid var(--paper);position:relative;
}
.hero-compact .inner{
  max-width:var(--wrap);margin-inline:auto;padding:clamp(2.2rem,5vw,3.6rem) var(--gutter) clamp(1.4rem,3vw,2rem);
  display:flex;flex-direction:column;gap:.7rem;
}
.hero-compact h1{font-size:clamp(2.1rem,5vw,3.6rem);max-width:20ch}
.hero-compact h1 em{font-style:normal;color:var(--magenta)}
.hero-compact .lead{color:var(--muted);max-width:52ch}

/* ── product cards: color-block + hard offset shadow ───── */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2.2rem)}
@media(max-width:840px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.card-grid{grid-template-columns:1fr}}
.pcard{
  position:relative;display:flex;flex-direction:column;
  background:var(--panel);border:3px solid var(--paper);border-radius:6px;overflow:hidden;
  box-shadow:var(--shadow-ink);transition:transform .15s ease,box-shadow .15s ease;
}
.pcard:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--magenta)}
.pcard:nth-child(3n+2){box-shadow:var(--shadow-cyan)}
.pcard:nth-child(3n+2):hover{box-shadow:10px 10px 0 var(--cyan)}
.pcard:nth-child(3n){box-shadow:var(--shadow-mag)}
.pcard:nth-child(3n):hover{box-shadow:10px 10px 0 var(--yellow)}
.pcard .fig{background:var(--panel-2);overflow:hidden;border-bottom:3px solid var(--paper)}
.pcard .fig img{width:100%;aspect-ratio:4/3;object-fit:cover}
.pcard .cbody{padding:1.1rem 1.2rem 1.4rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.pcard .tags{font-family:var(--mono);font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan)}
.pcard h3{font-size:1.05rem}
/* rotated sticker price tag */
.price-tag{
  align-self:flex-start;margin-top:auto;
  font-family:var(--disp);font-size:.9rem;color:var(--magenta);
  background:var(--yellow);border:3px solid var(--ink);border-radius:6px;
  padding:.3rem .7rem;transform:rotate(-3deg);box-shadow:3px 3px 0 var(--black);
}
.pcard:nth-child(even) .price-tag{transform:rotate(3deg)}

/* ── HI-SCORE table (signature) ─────────────────────────── */
.hiscore{
  background:var(--black);border:3px solid var(--cyan);border-radius:6px;
  padding:clamp(1.4rem,3.5vw,2.4rem);box-shadow:var(--shadow-mag);
}
.hiscore .hs-title{
  font-family:var(--disp);color:var(--yellow);font-size:clamp(1.2rem,2.6vw,1.8rem);
  text-transform:uppercase;text-align:center;margin-bottom:.3rem;
}
.hiscore .hs-sub{font-family:var(--mono);font-size:1.15rem;letter-spacing:.2em;text-transform:uppercase;color:var(--cyan);text-align:center;margin-bottom:1.4rem}
.hs-row{
  display:grid;grid-template-columns:2.6rem 1fr auto;gap:1rem;align-items:center;
  padding:.7rem 0;border-top:2px dashed var(--line);
  font-family:var(--mono);font-size:1.3rem;letter-spacing:.06em;text-transform:uppercase;
}
.hs-row .rank{color:var(--magenta)}
.hs-row .who{color:var(--paper);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hs-row .who a:hover{color:var(--cyan)}
.hs-row .score{color:var(--yellow);text-align:right}
@media(max-width:560px){.hs-row{font-size:1.1rem;grid-template-columns:2rem 1fr auto}}

/* ── tiles: nutra / ebook color blocks ─────────────────── */
.tile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2.5vw,1.8rem)}
@media(max-width:620px){.tile-grid{grid-template-columns:1fr}}
.tile{
  border:3px solid var(--ink);border-radius:6px;padding:1.5rem 1.6rem;
  display:flex;flex-direction:column;gap:.55rem;box-shadow:var(--shadow-ink);
}
.tile.mag{background:var(--magenta);color:var(--paper)}
.tile.cyan{background:var(--cyan);color:var(--ink)}
.tile.pane{background:var(--panel);color:var(--paper);border-color:var(--paper);box-shadow:var(--shadow-cyan)}
.tile .kicker{font-family:var(--mono);font-size:1.1rem;letter-spacing:.14em;text-transform:uppercase}
.tile.mag .kicker{color:var(--yellow)}
.tile.cyan .kicker{color:var(--ink)}
.tile.pane .kicker{color:var(--cyan)}
.tile h3{font-size:1.15rem}
.tile .price-flat{font-family:var(--disp);font-size:1.1rem;margin-top:.2rem}

/* ── blog tiles: color-block with header band ──────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2rem)}
@media(max-width:840px){.blog-grid{grid-template-columns:1fr}}
.bcard{
  display:flex;flex-direction:column;border:3px solid var(--paper);border-radius:6px;overflow:hidden;
  background:var(--panel);box-shadow:var(--shadow-ink);transition:transform .15s ease,box-shadow .15s ease;
}
.bcard:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--cyan)}
.bcard .band{
  font-family:var(--disp);font-size:.7rem;text-transform:uppercase;letter-spacing:.02em;
  padding:.6rem 1rem;color:var(--ink);
}
.bcard:nth-child(1) .band{background:var(--magenta);color:var(--paper)}
.bcard:nth-child(2) .band{background:var(--cyan)}
.bcard:nth-child(3) .band{background:var(--yellow)}
.bcard .bfig{background:var(--panel-2);overflow:hidden;border-block:3px solid var(--paper)}
.bcard .bfig img{width:100%;aspect-ratio:3/2;object-fit:cover}
.bcard .bbody{padding:1.1rem 1.2rem 1.4rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.bcard .bmeta{font-family:var(--mono);font-size:1.05rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.bcard h3{font-size:1.05rem}
.bcard .go{font-family:var(--mono);font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase;color:var(--yellow);margin-top:auto}

/* ── editorial split (about / pdp / teaser) ────────────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,5vw,3.5rem);align-items:center}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.split .fig{overflow:hidden;border:3px solid var(--paper);border-radius:6px;background:var(--panel-2);box-shadow:var(--shadow-mag)}
.split .fig img{width:100%;object-fit:cover;display:block}

.panel-block{
  background:var(--panel);border:3px solid var(--cyan);border-radius:6px;
  padding:clamp(1.5rem,4vw,2.6rem);box-shadow:var(--shadow-mag);
}
.two-col{columns:2;column-gap:2.2rem}
.two-col p{max-width:none;margin-bottom:1rem;break-inside:avoid}
@media(max-width:640px){.two-col{columns:1}}

/* ── PDP specifics ─────────────────────────────────────── */
.pdp-fig{background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-cyan)}
.pdp-fig img{width:100%;aspect-ratio:1/1;object-fit:cover}
.pdp .price-big{
  font-family:var(--disp);font-size:1.8rem;color:var(--magenta);
  background:var(--yellow);border:3px solid var(--ink);border-radius:8px;
  padding:.35rem .8rem;transform:rotate(-4deg);display:inline-block;box-shadow:4px 4px 0 var(--black);
}
.spec-list{list-style:none;display:flex;flex-direction:column;margin-top:.4rem}
.spec-list li{display:flex;gap:.7rem;padding:.65rem 0;border-top:2px dashed var(--line);font-size:1rem;color:var(--paper)}
.spec-list li::before{content:"✓";color:var(--cyan);font-family:var(--mono);font-size:1.3rem;line-height:1}

/* ── PDP v2: full-depth product pages ──────────────────── */
/* gallery: main + two-up filmstrip, no JS */
.pdp-gallery{display:flex;flex-direction:column;gap:1rem}
.pdp-gallery .main{background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-cyan)}
.pdp-gallery .main img{width:100%;aspect-ratio:1/1;object-fit:cover}
.pdp-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.pdp-thumbs figure{background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-mag)}
.pdp-thumbs:nth-child(n) figure:nth-child(2){box-shadow:var(--shadow-cyan)}
.pdp-thumbs img{width:100%;aspect-ratio:4/3;object-fit:cover}
.pdp-thumbs figcaption{font-family:var(--mono);font-size:1rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan);padding:.4rem .65rem;border-top:2px dashed var(--line)}

/* buy box helpers */
.pdp .buy-note{font-family:var(--mono);font-size:1.1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.pdp .buy-note b{color:var(--yellow);font-weight:400}

/* player-stats "card": speed/spin/control bars, VT323 figures */
.statblock{background:var(--black);border:3px solid var(--cyan);border-radius:6px;padding:clamp(1.4rem,3.5vw,2.2rem);box-shadow:var(--shadow-mag)}
.statblock .sb-title{font-family:var(--disp);color:var(--yellow);text-transform:uppercase;font-size:clamp(1.1rem,2.4vw,1.5rem);text-align:center;margin-bottom:.2rem}
.statblock .sb-sub{font-family:var(--mono);font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);text-align:center;margin-bottom:1.4rem}
.stat-row{display:grid;grid-template-columns:6.5rem 1fr 3rem;gap:.9rem;align-items:center;padding:.5rem 0;border-top:2px dashed var(--line)}
.stat-row:first-of-type{border-top:0}
.stat-row .lab{font-family:var(--mono);font-size:1.25rem;letter-spacing:.06em;text-transform:uppercase;color:var(--paper)}
.stat-row .bar{height:16px;background:var(--panel-2);border:2px solid var(--paper);border-radius:2px;overflow:hidden}
.stat-row .bar span{display:block;height:100%;background:var(--magenta)}
.stat-row:nth-child(3n) .bar span{background:var(--cyan)}
.stat-row:nth-child(3n+1) .bar span{background:var(--yellow)}
.stat-row .num{font-family:var(--mono);font-size:1.45rem;color:var(--yellow);text-align:right;line-height:1}

/* supplement "facts" block: arcade stat card, VT323 figures */
.facts{background:var(--black);border:3px solid var(--cyan);border-radius:6px;padding:clamp(1.4rem,3.5vw,2.2rem);box-shadow:var(--shadow-mag)}
.facts .f-title{font-family:var(--disp);color:var(--yellow);text-transform:uppercase;font-size:clamp(1.1rem,2.4vw,1.5rem);text-align:center;margin-bottom:.2rem}
.facts .f-sub{font-family:var(--mono);font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);text-align:center;margin-bottom:1.4rem}
.facts .f-row{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:baseline;padding:.6rem 0;border-top:2px dashed var(--line)}
.facts .f-row:first-of-type{border-top:0}
.facts .f-row .k{font-family:var(--mono);font-size:1.25rem;letter-spacing:.06em;text-transform:uppercase;color:var(--paper)}
.facts .f-row .v{font-family:var(--mono);font-size:1.35rem;color:var(--yellow);text-align:right;line-height:1.2}

/* trust row: chunky reassurance tiles */
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.8rem,2vw,1.2rem)}
.trust-row .trust{border:3px solid var(--paper);border-radius:6px;background:var(--panel);padding:1.1rem 1rem;text-align:center;box-shadow:var(--shadow-ink)}
.trust-row .trust .ic{font-family:var(--mono);font-size:2rem;color:var(--cyan);line-height:1}
.trust-row .trust .t{font-family:var(--disp);font-size:.68rem;text-transform:uppercase;color:var(--paper);margin-top:.45rem;line-height:1.1}
.trust-row .trust .d{font-family:var(--mono);font-size:1.02rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-top:.25rem}
@media(max-width:720px){.trust-row{grid-template-columns:repeat(2,1fr)}}

/* static reviews: unicode stars, no JS */
.reviews{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2rem)}
@media(max-width:640px){.reviews{grid-template-columns:1fr}}
.review{border:3px solid var(--paper);border-radius:6px;background:var(--panel);padding:1.5rem 1.6rem;box-shadow:var(--shadow-cyan);display:flex;flex-direction:column;gap:.7rem}
.review:nth-child(even){box-shadow:var(--shadow-mag)}
.review .stars{font-family:var(--mono);font-size:1.55rem;color:var(--yellow);letter-spacing:.12em;line-height:1}
.review .stars .off{color:var(--muted)}
.review .quote{color:var(--paper)}
.review .who{font-family:var(--disp);font-size:.8rem;text-transform:uppercase;color:var(--cyan)}
.review .who span{font-family:var(--mono);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:1rem;display:block;margin-top:.25rem}

/* ── article body ──────────────────────────────────────── */
.article{max-width:44rem;margin-inline:auto}
.article .hero-img{border:3px solid var(--paper);border-radius:6px;overflow:hidden;background:var(--panel-2);margin-bottom:2rem;box-shadow:var(--shadow-mag)}
.article .lead{margin:0 0 1.6rem}
.article p{margin-bottom:1.25rem;max-width:none;color:var(--paper)}
.article h2{font-size:clamp(1.4rem,3vw,2rem);margin:2rem 0 1rem;color:var(--cyan)}

/* ── cart mockup ───────────────────────────────────────── */
.cart-table{border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-cyan)}
.cart-head{background:var(--yellow);color:var(--ink);font-family:var(--disp);font-size:.72rem;text-transform:uppercase;
  display:grid;grid-template-columns:1fr auto;gap:1rem;padding:.7rem 1.2rem}
.cart-line{display:grid;grid-template-columns:1fr auto;gap:1rem;padding:1rem 1.2rem;border-top:2px dashed var(--line);
  font-family:var(--mono);font-size:1.25rem;color:var(--paper);background:var(--panel)}
.cart-line .muted{color:var(--muted)}
.cart-total{display:grid;grid-template-columns:1fr auto;gap:1rem;padding:1.1rem 1.2rem;border-top:3px solid var(--magenta);
  font-family:var(--disp);font-size:1.1rem;color:var(--yellow);background:var(--black)}

/* ── forms ─────────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-family:var(--mono);font-size:1.1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan)}
.field input,.field textarea{
  font-family:var(--body);font-size:1rem;padding:.8rem 1rem;
  background:var(--panel);border:3px solid var(--paper);border-radius:6px;color:var(--paper);
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field textarea:focus{outline:3px solid var(--magenta);outline-offset:2px;border-color:var(--magenta)}

/* ── footer ────────────────────────────────────────────── */
.site-foot{background:var(--black);border-top:4px solid var(--magenta);margin-top:clamp(2.5rem,6vw,5rem)}
.site-foot .inner{max-width:var(--wrap);margin-inline:auto;padding:clamp(2.2rem,5vw,3.6rem) var(--gutter)}
.site-foot .top{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;align-items:flex-start}
.site-foot .brand{font-size:1.7rem}
.site-foot nav{display:flex;gap:.9rem;flex-wrap:wrap}
.site-foot nav a{font-family:var(--disp);font-size:.64rem;text-transform:uppercase;color:var(--paper);
  background:var(--panel);padding:.45rem .8rem;border-radius:999px}
.site-foot nav a:hover{background:var(--magenta)}
.site-foot .credits{font-family:var(--mono);font-size:1.05rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  margin-top:2.2rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:2px dashed var(--line);padding-top:1.3rem}
.site-foot .credits b{color:var(--cyan)}

/* ── accessibility / motion floor ──────────────────────── */
a:focus-visible,.btn:focus-visible,.nav a:focus-visible,input:focus-visible,textarea:focus-visible,button:focus-visible{
  outline:3px solid var(--magenta);outline-offset:3px;border-radius:4px;
}
@keyframes riseIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.rise{animation:riseIn .7s cubic-bezier(.2,.7,.2,1) both}
.rise-2{animation-delay:.09s}
.rise-3{animation-delay:.18s}
.rise-4{animation-delay:.27s}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  body::before{animation:none!important}
}

/* ============================================================
   COMMERCE REALISM v4 — CSS-only gallery, variants, stock,
   compare-at pricing, frequently-bought, FAQ. Arcade kit, no JS.
   ============================================================ */

/* ── working gallery: radio + label, thumbnails swap main ─── */
.gsel{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;margin:0}
.gstage{position:relative;background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-cyan)}
.gstage .gimg{width:100%;aspect-ratio:1/1;object-fit:cover;display:none}
.gstage .gimg:first-of-type{display:block}          /* safe default */
.gsel:checked ~ .gstage .gimg{display:none}
.gsel:nth-of-type(1):checked ~ .gstage .gimg:nth-of-type(1),
.gsel:nth-of-type(2):checked ~ .gstage .gimg:nth-of-type(2),
.gsel:nth-of-type(3):checked ~ .gstage .gimg:nth-of-type(3){display:block}
.gfilm{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem}
.gfilm label{display:flex;flex-direction:column;cursor:pointer;background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-mag);transition:transform .14s ease,box-shadow .14s ease}
.gfilm label:hover{transform:translate(-2px,-2px)}
.gfilm label>img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.gfilm .cap{font-family:var(--mono);font-size:.95rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);padding:.35rem .55rem;border-top:2px dashed var(--line);line-height:1.15}
.gsel:nth-of-type(1):checked ~ .gfilm label:nth-of-type(1),
.gsel:nth-of-type(2):checked ~ .gfilm label:nth-of-type(2),
.gsel:nth-of-type(3):checked ~ .gfilm label:nth-of-type(3){border-color:var(--magenta);box-shadow:4px 4px 0 var(--cyan)}
.gsel:nth-of-type(1):checked ~ .gfilm label:nth-of-type(1) .cap,
.gsel:nth-of-type(2):checked ~ .gfilm label:nth-of-type(2) .cap,
.gsel:nth-of-type(3):checked ~ .gfilm label:nth-of-type(3) .cap{color:var(--magenta)}
.gsel:nth-of-type(1):focus-visible ~ .gfilm label:nth-of-type(1),
.gsel:nth-of-type(2):focus-visible ~ .gfilm label:nth-of-type(2),
.gsel:nth-of-type(3):focus-visible ~ .gfilm label:nth-of-type(3){outline:3px solid var(--yellow);outline-offset:3px}

/* ── compare-at price + stock badge ────────────────────────── */
.price-line{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin:0}
.msrp{font-family:var(--mono);font-size:1.4rem;color:var(--muted);text-decoration:line-through;text-decoration-color:var(--magenta);text-decoration-thickness:2px;line-height:1}
.save{font-family:var(--disp);font-size:.72rem;text-transform:uppercase;letter-spacing:.02em;color:var(--ink);background:var(--cyan);border:3px solid var(--ink);border-radius:999px;padding:.35rem .7rem;box-shadow:3px 3px 0 var(--black);line-height:1}
.stock{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:1.2rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cyan);margin:.2rem 0 0}
.stock .dot{width:.7rem;height:.7rem;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.stock.low{color:var(--yellow)}
.stock.low .dot{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}

/* ── variant swatches: radio + label ───────────────────────── */
.variants{display:flex;flex-direction:column;gap:.9rem;margin:.2rem 0}
.vgroup{display:flex;flex-direction:column;gap:.5rem}
.vgroup .vlabel{font-family:var(--mono);font-size:1.1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);line-height:1}
.vgroup .vlabel b{color:var(--yellow);font-weight:400}
.swatches{display:flex;gap:.55rem;flex-wrap:wrap}
.vsel{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none;margin:0}
.swatches label{display:inline-flex;align-items:center;font-family:var(--disp);font-size:.68rem;text-transform:uppercase;letter-spacing:.02em;color:var(--paper);background:var(--panel);border:3px solid var(--paper);border-radius:999px;padding:.55rem 1rem;cursor:pointer;line-height:1;transition:transform .14s ease,background .14s ease,color .14s ease,box-shadow .14s ease}
.swatches label:hover{transform:translate(-2px,-2px)}
.vsel:checked + label{background:var(--magenta);color:var(--paper);border-color:var(--paper);box-shadow:3px 3px 0 var(--black)}
.vsel:focus-visible + label{outline:3px solid var(--yellow);outline-offset:3px}
.swatches label .chip{width:.85rem;height:.85rem;border-radius:50%;border:2px solid var(--ink);margin-right:.45rem}

/* ── frequently bought together ────────────────────────────── */
.fbt{border:3px solid var(--paper);border-radius:6px;background:var(--panel);box-shadow:var(--shadow-cyan);padding:clamp(1.4rem,3.5vw,2.2rem)}
.fbt-items{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.fbt-item{display:flex;flex-direction:column;flex:1;min-width:150px;background:var(--panel-2);border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-ink)}
.fbt-item img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;border-bottom:3px solid var(--paper)}
.fbt-item .ib{padding:.6rem .85rem 1rem;display:flex;flex-direction:column;gap:.35rem}
.fbt-item .it{font-family:var(--mono);font-size:.92rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.fbt-item .in{font-family:var(--disp);font-size:.72rem;text-transform:uppercase;color:var(--paper);line-height:1.2}
.fbt-item .ip{font-family:var(--mono);font-size:1.25rem;color:var(--yellow);line-height:1}
.fbt-plus{font-family:var(--disp);font-size:1.6rem;color:var(--magenta);line-height:1}
.fbt-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.4rem;border-top:2px dashed var(--line);padding-top:1.3rem}
.fbt-sub{font-family:var(--disp);font-size:1.05rem;color:var(--yellow);text-transform:uppercase}
.fbt-sub b{color:var(--cyan);font-weight:400}
@media(max-width:560px){.fbt-plus{transform:rotate(90deg);align-self:center}}

/* ── FAQ accordion: <details>, no JS ───────────────────────── */
.faq{display:flex;flex-direction:column;gap:1rem}
.faq details{border:3px solid var(--paper);border-radius:6px;background:var(--panel);box-shadow:var(--shadow-ink);overflow:hidden}
.faq details[open]{border-color:var(--cyan);box-shadow:var(--shadow-cyan)}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--disp);font-size:.82rem;text-transform:uppercase;color:var(--paper);line-height:1.3}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);font-size:1.9rem;color:var(--magenta);line-height:1}
.faq details[open] summary{color:var(--cyan)}
.faq details[open] summary::after{content:"\2013";color:var(--cyan)}
.faq summary:focus-visible{outline:3px solid var(--magenta);outline-offset:-3px}
.faq .fa{padding:0 1.3rem 1.3rem}
.faq .fa p{max-width:none;margin:0;color:var(--paper)}

/* ── cart v4: steppers, promo, summary, upsell ─────────────── */
.cart-grid{display:grid;grid-template-columns:1.55fr .85fr;gap:clamp(1.4rem,4vw,2.6rem);align-items:start}
@media(max-width:860px){.cart-grid{grid-template-columns:1fr}}
.cart-item{display:grid;grid-template-columns:88px 1fr auto;gap:1rem;align-items:center;padding:1.1rem 1.2rem;border-top:2px dashed var(--line);background:var(--panel)}
.cart-item:first-of-type{border-top:0}
.cart-item .thumb{width:88px;height:88px;border:3px solid var(--paper);border-radius:6px;overflow:hidden;background:var(--panel-2)}
.cart-item .thumb img{width:100%;height:100%;object-fit:cover}
.cart-item .ci-name{font-family:var(--disp);font-size:.82rem;text-transform:uppercase;color:var(--paper);line-height:1.2}
.cart-item .ci-var{font-family:var(--mono);font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase;color:var(--cyan);margin-top:.35rem}
.cart-item .ci-remove{font-family:var(--mono);font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.35rem;display:inline-block}
.cart-item .ci-remove:hover{color:var(--magenta)}
.cart-item .ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:.55rem}
.cart-item .ci-price{font-family:var(--mono);font-size:1.35rem;color:var(--yellow);line-height:1}
.stepper{display:inline-flex;align-items:center;border:3px solid var(--paper);border-radius:999px;overflow:hidden;background:var(--panel-2)}
.stepper a{width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;font-family:var(--disp);font-size:1rem;color:var(--paper);background:var(--black)}
.stepper a:hover{background:var(--magenta);color:var(--paper)}
.stepper .qty{min-width:2.2rem;text-align:center;font-family:var(--mono);font-size:1.3rem;color:var(--yellow)}
.promo{display:flex;gap:.6rem;margin-top:1.2rem;flex-wrap:wrap}
.promo input{flex:1;min-width:0;font-family:var(--mono);font-size:1.15rem;letter-spacing:.1em;text-transform:uppercase;padding:.7rem .9rem;background:var(--panel);border:3px solid var(--paper);border-radius:999px;color:var(--paper)}
.promo input::placeholder{color:var(--muted)}
.promo input:focus{outline:3px solid var(--magenta);outline-offset:2px;border-color:var(--magenta)}
.summary{background:var(--panel);border:3px solid var(--cyan);border-radius:6px;padding:clamp(1.4rem,3.5vw,2rem);box-shadow:var(--shadow-mag)}
.sum-row{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-top:2px dashed var(--line);font-family:var(--mono);font-size:1.2rem;letter-spacing:.04em;text-transform:uppercase;color:var(--paper)}
.sum-row:first-of-type{border-top:0}
.sum-row .val{color:var(--yellow)}
.sum-row.free .val{color:var(--cyan)}
.sum-total{display:flex;justify-content:space-between;gap:1rem;margin-top:.6rem;border-top:3px solid var(--magenta);padding-top:.9rem;font-family:var(--disp);font-size:1.15rem;text-transform:uppercase;color:var(--yellow)}
.upsell{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;border:3px solid var(--paper);border-radius:6px;background:var(--panel-2);box-shadow:var(--shadow-ink);padding:1rem 1.2rem;margin-top:1.4rem}
.upsell img{width:64px;height:64px;object-fit:cover;border:3px solid var(--paper);border-radius:6px;background:var(--panel)}
.upsell .u-body{flex:1;min-width:150px}
.upsell .u-k{font-family:var(--mono);font-size:1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan)}
.upsell .u-n{font-family:var(--disp);font-size:.78rem;text-transform:uppercase;color:var(--paper);line-height:1.2;margin-top:.25rem}
.upsell .u-p{font-family:var(--mono);font-size:1.2rem;color:var(--yellow);margin-top:.2rem}

/* ============================================================
   TRUST + SUPPORT v5 — rating summary, verified badges, seals,
   press strip, payment marks, footer support column, size-guide
   tables, and the signature INSERT-COIN interaction. CSS-only.
   ============================================================ */

/* ── rating summary (PDP): average · stars · count · dist ─── */
.ratingsum{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(1.2rem,4vw,2.6rem);align-items:center;
  border:3px solid var(--cyan);border-radius:6px;background:var(--panel);
  box-shadow:var(--shadow-mag);padding:clamp(1.4rem,3.5vw,2.2rem);margin-bottom:clamp(1.6rem,3.5vw,2.4rem);
}
@media(max-width:560px){.ratingsum{grid-template-columns:1fr}}
.rs-score{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding-right:clamp(1rem,3vw,2rem);border-right:2px dashed var(--line)}
@media(max-width:560px){.rs-score{border-right:0;border-bottom:2px dashed var(--line);padding-right:0;padding-bottom:1.1rem}}
.rs-avg{font-family:var(--disp);font-size:clamp(2.4rem,6vw,3.4rem);color:var(--yellow);line-height:1}
.rs-stars{font-family:var(--mono);font-size:1.5rem;color:var(--yellow);letter-spacing:.1em;line-height:1}
.rs-stars .off{color:var(--muted)}
.rs-count{font-family:var(--mono);font-size:1.05rem;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan)}
.rs-dist{display:flex;flex-direction:column;gap:.45rem;min-width:0}
.rs-bar{display:grid;grid-template-columns:2.6rem 1fr 2.6rem;gap:.7rem;align-items:center}
.rs-bar .rs-k{font-family:var(--mono);font-size:1.1rem;color:var(--paper);text-transform:uppercase;line-height:1}
.rs-bar .rs-track{height:12px;background:var(--panel-2);border:2px solid var(--paper);border-radius:2px;overflow:hidden}
.rs-bar .rs-track span{display:block;height:100%;background:var(--magenta)}
.rs-bar:first-child .rs-track span{background:var(--cyan)}
.rs-bar .rs-n{font-family:var(--mono);font-size:1.1rem;color:var(--yellow);text-align:right;line-height:1}

/* ── verified-buyer badge (per review) ────────────────────── */
.vbadge{
  display:inline-flex;align-items:center;gap:.4rem;align-self:flex-start;
  font-family:var(--mono);font-size:.98rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink);background:var(--cyan);border:2px solid var(--ink);border-radius:999px;
  padding:.22rem .65rem;line-height:1;box-shadow:2px 2px 0 var(--black);
}
.vbadge svg{width:.95rem;height:.95rem;display:block}

/* ── trust seals: inline-SVG medallions ───────────────────── */
.seals{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:clamp(.9rem,2.2vw,1.3rem)}
.seal{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:.55rem;
  border:3px solid var(--paper);border-radius:6px;background:var(--panel);
  padding:1.3rem 1rem;box-shadow:var(--shadow-ink);
}
.seal:nth-child(3n+2){box-shadow:var(--shadow-cyan)}
.seal:nth-child(3n){box-shadow:var(--shadow-mag)}
.seal svg{width:66px;height:66px;display:block}
.seal .seal-t{font-family:var(--disp);font-size:.68rem;text-transform:uppercase;color:var(--paper);line-height:1.15}
.seal .seal-d{font-family:var(--mono);font-size:1rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);line-height:1.15}

/* ── press "as seen in" strip (home) ──────────────────────── */
.press{
  border:3px solid var(--paper);border-radius:6px;background:var(--panel);box-shadow:var(--shadow-ink);
  padding:clamp(1.4rem,3.5vw,2rem);display:flex;flex-direction:column;gap:1.1rem;align-items:center;text-align:center;
}
.press-lead{font-family:var(--mono);font-size:1.15rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan)}
.press-marks{display:flex;flex-wrap:wrap;gap:clamp(1.1rem,4vw,2.8rem);align-items:center;justify-content:center}
.press-mark{font-family:var(--disp);font-size:clamp(.9rem,2vw,1.15rem);text-transform:uppercase;letter-spacing:.02em;color:var(--muted);opacity:.82;transition:opacity .14s ease,color .14s ease}
.press-mark:hover{opacity:1;color:var(--paper)}
.press-mark b{font-weight:400;color:var(--paper)}
.press-mark.pm-mag b{color:var(--magenta)}
.press-mark.pm-cyan{font-family:var(--body);font-weight:700;font-style:italic;letter-spacing:0;text-transform:none}
.press-mark.pm-yel b{color:var(--yellow)}

/* ── payment marks (inline SVG) ───────────────────────────── */
.paymarks{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.paymarks svg{height:26px;width:40px;display:block;border-radius:4px}

/* ── footer: support column + payment strip ───────────────── */
.site-foot .top{align-items:flex-start}
.site-foot .foot-col{display:flex;flex-direction:column;gap:.7rem}
.site-foot .foot-col .foot-h{font-family:var(--disp);font-size:.72rem;text-transform:uppercase;letter-spacing:.02em;color:var(--yellow)}
.site-foot .foot-col nav{flex-direction:column;align-items:flex-start;gap:.5rem}
.site-foot .foot-pay{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:1.8rem;border-top:2px dashed var(--line);padding-top:1.4rem}
.site-foot .foot-pay .fp-label{font-family:var(--mono);font-size:1.05rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan)}

/* ── size-guide tables ────────────────────────────────────── */
.table-wrap{overflow-x:auto;margin:.2rem 0}
.guide-table{width:100%;border:3px solid var(--paper);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-cyan);border-collapse:separate;border-spacing:0}
.guide-table caption{font-family:var(--mono);font-size:1.1rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan);text-align:left;margin-bottom:.7rem}
.guide-table th,.guide-table td{text-align:left;padding:.75rem 1rem;font-size:1rem;border-top:2px dashed var(--line);vertical-align:top}
.guide-table thead th{background:var(--yellow);color:var(--ink);font-family:var(--disp);font-size:.7rem;text-transform:uppercase;border-top:0;letter-spacing:.02em}
.guide-table tbody th{font-family:var(--mono);font-size:1.2rem;color:var(--yellow);text-transform:uppercase;background:var(--panel);white-space:nowrap}
.guide-table td{background:var(--panel);color:var(--paper)}

/* ── SIGNATURE: INSERT-COIN plate (CRT flicker + hover surge) ─ */
.coinslot{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--disp);text-transform:uppercase;font-size:.8rem;letter-spacing:.02em;
  color:var(--yellow);background:var(--black);border:3px solid var(--yellow);border-radius:999px;
  padding:.75rem 1.4rem;box-shadow:4px 4px 0 var(--magenta);position:relative;line-height:1;
  transition:transform .14s ease,box-shadow .14s ease,color .14s ease;
}
.coinslot .blink{color:var(--cyan);animation:coinblink 1.1s steps(1) infinite}
@keyframes coinblink{0%,49%{opacity:1}50%,100%{opacity:.12}}
.coinslot:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--magenta);color:var(--paper);animation:crtsurge .45s steps(2) infinite}
@keyframes crtsurge{
  0%{text-shadow:0 0 0 transparent}
  50%{text-shadow:-2px 0 var(--magenta),2px 0 var(--cyan)}
  100%{text-shadow:0 0 9px var(--yellow)}
}
/* reduced-motion floor already zeroes .coinslot blink/surge/transition site-wide */
