/* =========================================================
   BREAKING GAMES — shared styles
   Modernized neon arcade. Editorial composition, neon accents.
   ========================================================= */

:root{
  /* palette: INDIE BLUE (brand standards default) */
  --ink: #0B1230;         /* deeper than Indie Blue for backgrounds */
  --ink-2: #141C42;        /* card */
  --ink-3: #1C2658;        /* elevated */
  --indie: #222D68;        /* Main Indie Blue */
  --sky:   #409FC2;        /* Secondary blue */
  --deep:  #2B5675;        /* Tertiary blue */
  --paper: #F4F1E8;
  --paper-dim: #A8B0C8;
  --line: rgba(255,255,255,.08);
  --line-strong: rgba(255,255,255,.18);

  /* action colors from brand */
  --green: #32B563;        /* Link green */
  --red:   #BB2827;        /* Headline red */
  --orange:#F04E23;        /* Subline orange */

  /* arcade neon accents (used sparingly on hero/spot to keep site energy) */
  --neon-pink: #FF2D9C;
  --neon-cyan: #19F3FF;
  --neon-yellow:#FFE94A;

  /* role tokens */
  --accent:   var(--orange);   /* primary accent — brand subline orange */
  --accent-2: var(--sky);      /* secondary — brand sky blue */
  --accent-3: var(--neon-yellow);/* tertiary — neon yellow energy */
  --pink: var(--neon-pink);
  --cyan: var(--neon-cyan);
  --acid: var(--neon-yellow);
  --plum: var(--indie);

  /* type — brand: Ubuntu primary, Avenir Next Condensed for headlines (Oswald is the closest free analog) */
  --f-display: "Oswald", "Avenir Next Condensed", "Ubuntu", system-ui, sans-serif;
  --f-body: "Ubuntu", ui-sans-serif, system-ui, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1320px;
  --pad: clamp(16px, 3vw, 36px);
  --radius: 14px;
  --radius-lg: 22px;
}

/* Brand-on (default neon-on-indie-blue, like the live site) */
[data-palette="neon"]{
  --accent: var(--neon-pink);
  --accent-2: var(--neon-cyan);
  --accent-3: var(--neon-yellow);
}
/* Editorial: brand-color-forward, less neon */
[data-palette="editorial"]{
  --ink: #0B1230;
  --ink-2: #141C42;
  --accent: var(--orange);
  --accent-2: var(--sky);
  --accent-3: var(--green);
  --pink: var(--orange);
  --cyan: var(--sky);
  --acid: var(--green);
}
/* Sunset: warm fall, brand-adjacent */
[data-palette="sunset"]{
  --ink: #1A0F1F;
  --ink-2: #251530;
  --ink-3: #321B3F;
  --accent: var(--orange);
  --accent-2: #FFB347;
  --accent-3: var(--red);
  --pink: var(--orange);
  --cyan: #FFB347;
  --acid: var(--red);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html, body{ background:var(--ink); color:var(--paper); font-family:var(--f-body); -webkit-font-smoothing:antialiased; }
html{ scroll-behavior:smooth; }
body{ overflow-x:hidden; min-height:100vh; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }
::selection{ background:var(--accent); color:var(--ink); }

/* layout */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(56px, 8vw, 120px); position:relative; }
.section--tight{ padding-block:clamp(36px, 5vw, 72px); }

/* typography */
.eyebrow{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent-2);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{
  content:""; width:18px; height:1px; background:currentColor;
}
.display-xl{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(56px, 10vw, 148px);
  line-height:1.0;
  letter-spacing:-.03em;
  text-wrap:balance;
}
.display-l{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(40px, 6vw, 88px);
  line-height:1.02;
  letter-spacing:-.025em;
  text-wrap:balance;
}
.display-m{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(28px, 3.4vw, 48px);
  line-height:1.02;
  letter-spacing:-.02em;
  text-wrap:balance;
}
.display-s{
  font-family:var(--f-display);
  font-weight:700;
  font-size:clamp(22px, 2.2vw, 30px);
  line-height:1.1;
  letter-spacing:-.01em;
}
.lede{ font-size:clamp(16px, 1.4vw, 19px); line-height:1.55; color:var(--paper); opacity:.86; max-width:60ch; text-wrap:pretty; }
.body{ font-size:15px; line-height:1.6; color:var(--paper); opacity:.78; }
.label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-dim); }
.hl-pink{ color:var(--pink); }
.hl-cyan{ color:var(--cyan); }
.hl-acid{ color:var(--acid); }

/* utility: neon outline text */
.neon-outline{
  -webkit-text-stroke: 1.2px var(--cyan);
  color:transparent;
}

/* buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 22px;
  border-radius:999px;
  font-family:var(--f-body);
  font-weight:600;
  font-size:14px;
  letter-spacing:.01em;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn--primary{
  background:var(--paper);
  color:var(--ink);
  box-shadow: 0 8px 0 -2px var(--accent), 0 14px 30px rgba(255,45,156,.25);
}
.btn--primary:hover{ transform:translateY(-2px); box-shadow: 0 10px 0 -2px var(--accent), 0 18px 40px rgba(255,45,156,.35); }
.btn--ghost{
  background:transparent;
  color:var(--paper);
  border:1px solid var(--line-strong);
}
.btn--ghost:hover{ border-color:var(--paper); background:rgba(255,255,255,.04); }
.btn--accent{
  background:var(--accent);
  color:var(--ink);
  box-shadow: 0 0 0 1px var(--accent), 0 0 30px rgba(255,45,156,.35);
}
.btn--accent:hover{ transform:translateY(-2px); }
.btn--xs{ padding:8px 14px; font-size:12px; }
.btn--sm{ padding:10px 16px; font-size:13px; }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(3px); }

/* chips / pills */
.chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--line-strong);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase;
  background:rgba(255,255,255,.03);
}
.chip--accent{ border-color:var(--accent); color:var(--accent); }
.chip--cyan{ border-color:var(--cyan); color:var(--cyan); }
.chip--acid{ border-color:var(--acid); color:var(--acid); }
.chip .dot{ width:6px; height:6px; border-radius:50%; background:currentColor; }

/* ============ Promo bar ============ */
.promo-bar{
  background:var(--ink-3);
  border-bottom:1px solid var(--line);
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--paper);
  overflow:hidden;
}
.promo-bar .marquee{
  display:flex;
  gap:60px;
  white-space:nowrap;
  padding:10px 0;
  animation: marquee 38s linear infinite;
  width:max-content;
}
.promo-bar span{ display:inline-flex; align-items:center; gap:14px; }
.promo-bar span::after{
  content:"✕"; color:var(--cyan); opacity:.6;
}
@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ============ Header / Nav ============ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(10,7,18,.78);
  backdrop-filter: blur(16px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-family:var(--f-display); font-weight:800;
}
.brand img.bg-logo{ display:block; height:52px; width:auto; }
.site-header .brand img.bg-logo{ height:48px; }
.footer .brand img.bg-logo{ height:64px; }
.brand-text-fallback{
  font-family:var(--f-display); font-weight:800;
  font-size:19px; letter-spacing:-.01em;
}
.brand .mark{
  width:34px; height:34px; border-radius:9px;
  background:var(--accent);
  display:grid; place-items:center;
  color:var(--ink);
  font-family:var(--f-display);
  font-weight:900; font-size:18px;
  position:relative;
  box-shadow: 2px 2px 0 var(--cyan);
}
.brand .mark::after{
  content:""; position:absolute; inset:6px;
  background:
    linear-gradient(45deg, transparent 47%, var(--ink) 47% 53%, transparent 53%),
    linear-gradient(-45deg, transparent 47%, var(--ink) 47% 53%, transparent 53%);
}
.nav-links{
  display:flex; gap:28px;
  font-size:14px; font-weight:500;
}
.nav-links a{ position:relative; padding:8px 0; opacity:.88; }
.nav-links a:hover{ opacity:1; }
.nav-links a.active{ color:var(--accent-2); }
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:2px; background:currentColor;
}
.nav-actions{ display:flex; align-items:center; gap:10px; }
.icon-btn{
  width:40px; height:40px; border-radius:50%;
  border:1px solid var(--line-strong);
  display:grid; place-items:center;
  transition:border-color .2s ease, background .2s ease;
}
.icon-btn:hover{ border-color:var(--paper); }
.icon-btn .badge{
  position:absolute; transform:translate(12px,-12px);
  background:var(--accent); color:var(--ink);
  font-family:var(--f-mono); font-size:10px; font-weight:700;
  border-radius:999px; padding:1px 6px;
  pointer-events:none;
}
.icon-btn{ position:relative; }

@media (max-width: 880px){
  .nav-links{ display:none; }
}

/* ============ Hero ============ */
.hero{
  position:relative;
  padding-block:clamp(56px, 8vw, 96px) clamp(40px, 6vw, 80px);
  overflow:hidden;
  isolation:isolate;
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 80% at 20% 30%, rgba(255,45,156,.15), transparent 60%),
    radial-gradient(50% 70% at 85% 70%, rgba(25,243,255,.12), transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap:clamp(20px, 4vw, 60px);
  align-items:center;
}
.hero-left{ position:relative; }
.hero-headline{
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(56px, 9.5vw, 136px);
  line-height:1.0;
  letter-spacing:-.035em;
}
.hero-headline .line{ display:block; padding-block:.04em; }
.hero-headline .line{ display:block; }
.hero-headline em{ font-style:normal; color:var(--accent); }
.hero-headline .out{
  -webkit-text-stroke: 1.5px var(--cyan);
  color:transparent;
  font-style:italic;
}
.hero-lede{
  margin-top:24px;
  font-size:clamp(15px, 1.3vw, 18px);
  line-height:1.55;
  max-width:48ch; color:var(--paper); opacity:.82;
}
.hero-ctas{ display:flex; gap:12px; margin-top:32px; flex-wrap:wrap; }
.hero-meta{
  display:flex; gap:22px; flex-wrap:wrap;
  margin-top:36px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--paper-dim);
}
.hero-meta span{ display:inline-flex; align-items:center; gap:8px; }
.hero-meta span::before{ content:""; width:6px; height:6px; background:var(--accent-3); border-radius:50%; }

/* spotlight stack on right */
.hero-stack{
  position:relative; aspect-ratio:1/1.05;
  width:100%;
}
.spot-card{
  position:absolute; border-radius:18px; overflow:hidden;
  background:var(--ink-2);
  border:1px solid var(--line-strong);
  box-shadow: 0 30px 60px rgba(0,0,0,.5);
}
.spot-card img{ width:100%; height:100%; object-fit:cover; }
.spot-card.s1{ inset: 0 22% 28% 0; transform:rotate(-4deg); z-index:2; border-color:var(--pink); box-shadow: 0 0 0 1px var(--pink), 0 20px 50px rgba(255,45,156,.25); }
.spot-card.s2{ inset: 14% 0 8% 26%; transform:rotate(3deg); z-index:3; border-color:var(--cyan); box-shadow: 0 0 0 1px var(--cyan), 0 20px 50px rgba(25,243,255,.25); }
.spot-card.s3{ inset: 42% 32% 0 14%; transform:rotate(-2deg); z-index:1; border-color:var(--acid); box-shadow: 0 0 0 1px var(--acid), 0 20px 50px rgba(214,255,61,.18); }
.spot-tag{
  position:absolute; top:14px; left:14px;
  background:var(--ink); color:var(--paper);
  font-family:var(--f-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  padding:6px 10px; border-radius:999px;
  border:1px solid var(--line-strong);
}
.spot-price{
  position:absolute; bottom:14px; right:14px;
  background:var(--paper); color:var(--ink);
  font-family:var(--f-mono); font-weight:700; font-size:13px;
  padding:6px 12px; border-radius:8px;
}

/* hero quiz cta */
.hero-quiz{
  margin-top:28px;
  display:inline-flex; align-items:center; gap:14px;
  padding:8px 8px 8px 18px;
  border:1px solid var(--line-strong);
  border-radius:999px;
  background:rgba(255,255,255,.03);
}
.hero-quiz .qtext{ font-size:13px; color:var(--paper); opacity:.9; }
.hero-quiz .qtext b{ color:var(--accent-2); font-weight:600; }

/* floating star/decoration */
.deco{ position:absolute; pointer-events:none; user-select:none; opacity:.7; }
.deco--star{ font-family:var(--f-display); font-weight:900; color:var(--accent-3); }
.deco--star.s-1{ top:10%; right:-2%; font-size:80px; transform:rotate(15deg); }
.deco--star.s-2{ bottom:8%; left:38%; font-size:48px; transform:rotate(-12deg); color:var(--cyan); }

/* ============ Marquee strip ============ */
.strip{
  background:var(--paper);
  color:var(--ink);
  border-block:1px solid var(--line);
  overflow:hidden;
  position:relative;
}
.strip .marquee{
  display:flex; gap:50px;
  font-family:var(--f-display);
  font-weight:800;
  font-size:clamp(28px, 4vw, 48px);
  letter-spacing:-.02em;
  padding:14px 0;
  white-space:nowrap;
  animation: marquee 30s linear infinite;
  width:max-content;
}
.strip span{ display:inline-flex; align-items:center; gap:24px; }
.strip span::after{ content:"✕"; color:var(--pink); font-size:.7em; transform:translateY(-.1em); }

/* ============ Section heading ============ */
.section-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:24px;
  margin-bottom:48px; flex-wrap:wrap;
}
.section-head .left{ max-width:60ch; }
.section-head .right{ display:flex; gap:10px; flex-wrap:wrap; }

/* ============ Shop by category ============ */
.cat-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:18px;
}
.cat-card{
  position:relative;
  aspect-ratio: 4/5;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--ink-2);
  border:1px solid var(--line);
  transition:transform .3s ease, border-color .2s ease;
  isolation:isolate;
}
.cat-card:hover{ transform:translateY(-6px); border-color:var(--accent); }
.cat-card img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  z-index:-1; opacity:.55;
  transition:opacity .3s ease, transform .5s ease;
}
.cat-card:hover img{ opacity:.75; transform:scale(1.05); }
.cat-card::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(180deg, transparent 30%, rgba(10,7,18,.85) 100%);
}
.cat-card .inner{
  position:absolute; left:0; right:0; bottom:0;
  padding:24px;
}
.cat-card h3{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(28px, 3vw, 40px);
  letter-spacing:-.02em;
  margin-bottom:6px;
}
.cat-card p{ font-size:13px; opacity:.8; }
.cat-card .num{
  position:absolute; top:18px; left:20px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em;
  color:var(--paper);
}
.cat-card .arr{
  position:absolute; top:18px; right:20px;
  width:36px; height:36px; border-radius:50%;
  background:var(--paper); color:var(--ink);
  display:grid; place-items:center; font-size:18px;
  transition:transform .2s ease;
}
.cat-card:hover .arr{ transform:rotate(-45deg); }
.cat-card[data-cat="family"] .num{ color:var(--cyan); }
.cat-card[data-cat="party"] .num{ color:var(--pink); }
.cat-card[data-cat="strategy"] .num{ color:var(--acid); }

@media (max-width: 880px){
  .cat-grid{ grid-template-columns: 1fr; }
}

/* ============ Spotlight ============ */
.spotlight{
  display:grid; grid-template-columns: 1fr 1fr; gap:48px;
  align-items:center;
}
.spotlight-art{
  position:relative; aspect-ratio:1/1;
  background:var(--ink-2);
  border-radius:var(--radius-lg);
  border:1px solid var(--accent);
  overflow:hidden;
  box-shadow: 0 0 0 1px var(--accent), 0 30px 80px rgba(255,45,156,.2);
}
.spotlight-art img{ width:100%; height:100%; object-fit:cover; }
.spotlight-art .corner{
  position:absolute;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  background:var(--ink); border:1px solid var(--accent); color:var(--accent);
  padding:6px 10px; border-radius:6px;
}
.spotlight-art .corner.tl{ top:14px; left:14px; }
.spotlight-art .corner.br{ bottom:14px; right:14px; color:var(--cyan); border-color:var(--cyan); }
.spotlight-info h2{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(36px, 5vw, 72px);
  line-height:1.04; letter-spacing:-.025em;
  margin-block:14px 20px;
}
.spotlight-info .stars{ display:inline-flex; gap:2px; color:var(--acid); font-size:14px; margin-bottom:14px; }
.spotlight-info .specs{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:0; margin-top:28px;
  border:1px solid var(--line); border-radius:12px; overflow:hidden;
}
.spotlight-info .spec{
  padding:16px;
  border-right:1px solid var(--line);
}
.spotlight-info .spec:last-child{ border-right:none; }
.spotlight-info .spec .k{ font-family:var(--f-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-dim); }
.spotlight-info .spec .v{ font-family:var(--f-display); font-size:22px; font-weight:700; margin-top:4px; }
.spotlight-info .actions{ display:flex; gap:10px; margin-top:30px; flex-wrap:wrap; }

@media (max-width: 880px){ .spotlight{ grid-template-columns: 1fr; } }

/* ============ Quiz teaser ============ */
.quiz-teaser{
  background:
    radial-gradient(60% 100% at 0% 50%, rgba(255,45,156,.18), transparent 60%),
    radial-gradient(70% 100% at 100% 50%, rgba(25,243,255,.16), transparent 60%),
    var(--ink-2);
  border-radius:var(--radius-lg);
  padding:clamp(36px, 5vw, 64px);
  border:1px solid var(--line-strong);
  position:relative; overflow:hidden;
}
.quiz-teaser::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 56px, rgba(255,45,156,.07) 56px, rgba(255,45,156,.07) 57px),
    repeating-linear-gradient(90deg, transparent, transparent 56px, rgba(25,243,255,.07) 56px, rgba(25,243,255,.07) 57px);
  opacity:.6;
}
.quiz-teaser .qt-grid{
  position:relative;
  display:grid; grid-template-columns: 1.2fr .8fr; gap:40px; align-items:center;
}
.quiz-teaser h2{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(36px, 5vw, 64px);
  line-height:1.04; letter-spacing:-.025em;
}
.quiz-teaser .qt-bullets{ list-style:none; display:flex; flex-direction:column; gap:14px; }
.quiz-teaser .qt-bullets li{
  display:flex; align-items:flex-start; gap:14px;
  font-size:14px; line-height:1.5;
}
.quiz-teaser .qt-bullets li b{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.18em;
  color:var(--ink); background:var(--accent-3);
  padding:4px 8px; border-radius:6px; flex-shrink:0;
  text-transform:uppercase; font-weight:700;
}
.qt-preview{
  background:var(--ink); border:1px solid var(--line-strong);
  border-radius:14px; padding:22px; position:relative;
}
.qt-preview .qline{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent-2); margin-bottom:12px;
}
.qt-preview .qq{ font-family:var(--f-display); font-weight:700; font-size:22px; line-height:1.15; margin-bottom:18px; }
.qt-preview .qopts{ display:flex; flex-direction:column; gap:8px; }
.qt-preview .qopt{
  display:flex; align-items:center; gap:10px;
  padding:10px 14px; border:1px solid var(--line-strong); border-radius:10px;
  font-size:14px; color:var(--paper); opacity:.9;
  transition:border-color .2s ease, transform .2s ease;
}
.qt-preview .qopt:hover{ border-color:var(--accent-2); transform:translateX(4px); }
.qt-preview .qopt .e{ font-size:18px; }

@media (max-width: 880px){
  .quiz-teaser .qt-grid{ grid-template-columns: 1fr; }
}

/* ============ Game grid ============ */
.games-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:18px;
}
.game-card{
  position:relative;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition:transform .25s ease, border-color .2s ease;
  display:flex; flex-direction:column;
}
.game-card:hover{ transform:translateY(-4px); border-color:var(--accent-2); }
.game-card .thumb{
  aspect-ratio: 1/1; background:var(--ink-3);
  position:relative;
}
.game-card .thumb img{ width:100%; height:100%; object-fit:cover; }
.game-card .stamp{
  position:absolute; top:10px; left:10px;
  background:var(--accent); color:var(--ink);
  font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  padding:4px 8px; border-radius:999px; font-weight:700;
}
.game-card .stamp.new{ background:var(--acid); }
.game-card .stamp.bestseller{ background:var(--cyan); }
.game-card .stamp.award{ background:var(--paper); }
.game-card .meta{ padding:14px 16px 18px; }
.game-card .pname{ font-family:var(--f-display); font-weight:700; font-size:17px; line-height:1.1; letter-spacing:-.01em; margin-bottom:4px; }
.game-card .ptags{ font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:10px; }
.game-card .prow{ display:flex; justify-content:space-between; align-items:center; }
.game-card .price{ font-family:var(--f-mono); font-weight:700; font-size:14px; color:var(--paper); }
.game-card .rate{ font-size:11px; color:var(--paper-dim); font-family:var(--f-mono); letter-spacing:.1em; }
.game-card .rate b{ color:var(--acid); }

@media (max-width: 1080px){ .games-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px){ .games-grid{ grid-template-columns: repeat(2, 1fr); } }

/* ============ Reviews ============ */
.reviews-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:18px;
}
.review-card{
  padding:28px;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex; flex-direction:column; gap:14px;
}
.review-card .stars{ color:var(--acid); font-size:13px; letter-spacing:.18em; }
.review-card blockquote{
  font-family:var(--f-display);
  font-weight:600;
  font-size:20px; line-height:1.25; letter-spacing:-.01em;
  text-wrap:pretty;
}
.review-card .author{ display:flex; align-items:center; gap:12px; margin-top:auto; }
.review-card .avatar{
  width:36px; height:36px; border-radius:50%;
  background:var(--accent); color:var(--ink);
  display:grid; place-items:center;
  font-family:var(--f-display); font-weight:800; font-size:13px;
}
.review-card .who{ font-size:13px; }
.review-card .who small{ display:block; color:var(--paper-dim); font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; }
.review-card[data-tint="cyan"] .avatar{ background:var(--cyan); }
.review-card[data-tint="acid"] .avatar{ background:var(--acid); }

@media (max-width: 880px){ .reviews-grid{ grid-template-columns: 1fr; } }

/* ============ Gift Guide ============ */
.gifts-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:16px;
}
.gift-card{
  position:relative;
  padding:24px;
  border-radius:var(--radius);
  border:1px solid var(--line-strong);
  background:var(--ink-2);
  display:flex; flex-direction:column; gap:14px;
  aspect-ratio: 1/1.1;
  transition:transform .25s ease, border-color .2s ease, background .2s ease;
  overflow:hidden;
}
.gift-card:hover{ transform:translateY(-4px); }
.gift-card[data-occ="grownup"]{ background:linear-gradient(160deg, rgba(255,45,156,.15), var(--ink-2)); }
.gift-card[data-occ="grownup"]:hover{ border-color:var(--pink); }
.gift-card[data-occ="family"]{ background:linear-gradient(160deg, rgba(25,243,255,.15), var(--ink-2)); }
.gift-card[data-occ="family"]:hover{ border-color:var(--cyan); }
.gift-card[data-occ="strategy"]{ background:linear-gradient(160deg, rgba(214,255,61,.15), var(--ink-2)); }
.gift-card[data-occ="strategy"]:hover{ border-color:var(--acid); }
.gift-card[data-occ="couples"]{ background:linear-gradient(160deg, rgba(107,43,217,.25), var(--ink-2)); }
.gift-card[data-occ="couples"]:hover{ border-color:var(--plum); }
.gift-card h3{ font-family:var(--f-display); font-weight:800; font-size:24px; line-height:1.1; letter-spacing:-.02em; margin-top:auto; }
.gift-card .num{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; color:var(--paper-dim); }
.gift-card .glyph{
  font-family:var(--f-display); font-weight:800; font-size:88px;
  line-height:1; letter-spacing:-.05em;
}
.gift-card[data-occ="grownup"] .glyph{ color:var(--pink); }
.gift-card[data-occ="family"] .glyph{ color:var(--cyan); }
.gift-card[data-occ="strategy"] .glyph{ color:var(--acid); }
.gift-card[data-occ="couples"] .glyph{ color:var(--paper); }

@media (max-width: 1080px){ .gifts-grid{ grid-template-columns: repeat(2, 1fr); } }

/* ============ Press strip ============ */
.press{
  border-block:1px solid var(--line);
  padding-block:36px;
  display:flex; align-items:center; justify-content:space-between; gap:36px; flex-wrap:wrap;
}
.press .plabel{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-dim); }
.press ul{ list-style:none; display:flex; gap:36px; flex-wrap:wrap; align-items:center; }
.press li{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(18px, 2vw, 26px); letter-spacing:-.01em;
  opacity:.85;
}
.press li.italic{ font-style:italic; font-weight:700; }
.press li.serif{ font-family:"Times New Roman", serif; font-weight:700; }
.press li.mono{ font-family:var(--f-mono); font-weight:700; letter-spacing:.04em; }

/* ============ FAQ ============ */
.faq{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line-strong); }
.faq-item{ border-bottom:1px solid var(--line-strong); }
.faq-q{
  width:100%; text-align:left;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:24px 0;
  font-family:var(--f-display); font-weight:700; font-size:clamp(18px, 2vw, 24px);
  letter-spacing:-.01em;
}
.faq-q .plus{
  font-family:var(--f-mono); font-weight:400;
  width:32px; height:32px; border-radius:50%;
  border:1px solid var(--line-strong);
  display:grid; place-items:center;
  transition:background .2s ease, color .2s ease, transform .2s ease;
  flex-shrink:0;
}
.faq-item[open] .plus{ background:var(--accent); color:var(--ink); border-color:var(--accent); transform:rotate(45deg); }
.faq-a{ padding:0 0 24px; max-width:78ch; color:var(--paper); opacity:.78; font-size:15px; line-height:1.6; }

/* ============ Newsletter ============ */
.news{
  display:grid; grid-template-columns: 1fr 1fr; gap:48px; align-items:center;
}
.news-form{
  display:flex; gap:8px; flex-wrap:wrap;
  margin-top:20px;
}
.news-form input{
  flex:1; min-width:220px;
  background:var(--ink-2); color:var(--paper);
  border:1px solid var(--line-strong); border-radius:999px;
  padding:14px 20px;
  font-family:var(--f-body); font-size:14px;
}
.news-form input:focus{ outline:none; border-color:var(--accent-2); }
.news .perks{
  display:flex; flex-direction:column; gap:14px;
  font-size:14px;
}
.news .perks li{ display:flex; align-items:center; gap:14px; }
.news .perks li::before{
  content:"✕"; color:var(--accent); font-weight:800; font-size:18px;
  width:30px; height:30px; border-radius:50%;
  border:1px solid var(--accent); display:grid; place-items:center; flex-shrink:0;
}
.news .perks li:nth-child(2)::before{ content:"○"; color:var(--cyan); border-color:var(--cyan); }
.news .perks li:nth-child(3)::before{ content:"+"; color:var(--acid); border-color:var(--acid); }

@media (max-width: 880px){ .news{ grid-template-columns: 1fr; } }

/* ============ Footer ============ */
.footer{
  background:var(--ink-2);
  border-top:1px solid var(--line);
  padding-block:64px 32px;
}
.footer .cols{
  display:grid; grid-template-columns: 1.5fr repeat(4, 1fr); gap:40px;
}
.footer h4{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper-dim); margin-bottom:18px; }
.footer ul{ list-style:none; display:flex; flex-direction:column; gap:10px; font-size:14px; }
.footer ul a{ opacity:.8; }
.footer ul a:hover{ opacity:1; color:var(--accent-2); }
.footer .brand-block{ max-width:34ch; }
.footer .brand-block p{ font-size:14px; line-height:1.55; opacity:.7; margin-top:14px; }
.footer .legal{
  display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap;
  margin-top:60px; padding-top:24px; border-top:1px solid var(--line);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim);
}

@media (max-width: 880px){ .footer .cols{ grid-template-columns: 1fr 1fr; } }

/* ============ Breadcrumbs / page header ============ */
.page-head{
  padding-block:clamp(48px, 6vw, 96px);
  border-bottom:1px solid var(--line);
  position:relative;
}
.crumbs{
  display:flex; gap:8px;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--paper-dim);
  margin-bottom:24px;
}
.crumbs a{ color:var(--accent-2); }
.crumbs span{ opacity:.5; }

/* filter bar */
.filters{
  display:flex; gap:10px; flex-wrap:wrap;
  margin-bottom:30px;
}
.filter-pill{
  padding:8px 16px; border-radius:999px;
  border:1px solid var(--line-strong);
  font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  background:transparent; color:var(--paper);
  transition:all .2s ease;
}
.filter-pill:hover{ border-color:var(--paper); }
.filter-pill.active{ background:var(--paper); color:var(--ink); border-color:var(--paper); }

/* ============ Game detail page ============ */
.pdp{
  display:grid; grid-template-columns: 1.1fr 1fr; gap:60px;
  padding-block:clamp(40px, 5vw, 64px);
}
.pdp-gallery{ position:relative; }
.pdp-hero{
  aspect-ratio:1/1; border-radius:var(--radius-lg);
  background:var(--ink-2); border:1px solid var(--cyan);
  overflow:hidden; position:relative;
  box-shadow: 0 0 0 1px var(--cyan), 0 30px 60px rgba(25,243,255,.18);
}
.pdp-hero img{ width:100%; height:100%; object-fit:cover; }
.pdp-thumbs{ display:flex; gap:10px; margin-top:14px; }
.pdp-thumb{
  width:90px; height:90px; border-radius:10px;
  border:1px solid var(--line-strong); background:var(--ink-3);
  overflow:hidden; cursor:pointer;
  transition:border-color .2s ease;
}
.pdp-thumb.active{ border-color:var(--accent); }
.pdp-thumb img{ width:100%; height:100%; object-fit:cover; }
.pdp-info h1{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(40px, 5vw, 72px); line-height:1.04; letter-spacing:-.025em;
  margin-block:14px 18px;
}
.pdp-rate{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.pdp-rate .stars{ color:var(--acid); font-size:14px; letter-spacing:.18em; }
.pdp-rate .num{ font-family:var(--f-mono); font-size:12px; color:var(--paper-dim); letter-spacing:.12em; }
.pdp-price{
  display:flex; align-items:baseline; gap:14px;
  font-family:var(--f-display); font-weight:800; font-size:42px; letter-spacing:-.02em;
  margin-block:18px 22px;
}
.pdp-price s{ font-size:18px; color:var(--paper-dim); font-weight:600; }
.pdp-price .save{
  background:var(--acid); color:var(--ink); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  padding:4px 8px; border-radius:6px; font-family:var(--f-mono); font-weight:700;
}
.pdp-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-block:24px 30px; }
.pdp-feats{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:0;
  border:1px solid var(--line); border-radius:12px; overflow:hidden;
}
.pdp-feats .f{
  padding:16px; border-right:1px solid var(--line); text-align:center;
}
.pdp-feats .f:last-child{ border-right:none; }
.pdp-feats .v{ font-family:var(--f-display); font-weight:700; font-size:22px; }
.pdp-feats .k{ font-family:var(--f-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); margin-top:4px; }
.pdp-desc{ margin-top:28px; font-size:15px; line-height:1.65; opacity:.85; max-width:60ch; }
.pdp-perks{ display:flex; gap:18px; margin-top:24px; flex-wrap:wrap; font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--paper-dim); }
.pdp-perks span{ display:flex; align-items:center; gap:8px; }
.pdp-perks span::before{ content:"✓"; color:var(--accent-3); font-weight:800; }

@media (max-width: 980px){ .pdp{ grid-template-columns: 1fr; } }

/* ============ Quiz page ============ */
.quiz-wrap{
  min-height:80vh;
  display:flex; align-items:center;
  padding-block:clamp(48px, 6vw, 96px);
  position:relative;
}
.quiz-card{
  width:100%; max-width:780px; margin:0 auto;
  background:var(--ink-2); border:1px solid var(--line-strong);
  border-radius:var(--radius-lg);
  padding:clamp(28px, 4vw, 56px);
  position:relative;
}
.quiz-progress{ display:flex; gap:6px; margin-bottom:30px; }
.quiz-bar{ flex:1; height:4px; background:var(--ink-3); border-radius:2px; overflow:hidden; }
.quiz-bar.done{ background:var(--accent-3); }
.quiz-bar.active{ background:linear-gradient(90deg, var(--accent-3), var(--accent-3) 50%, var(--ink-3) 50%); background-size:200% 100%; animation:fillBar 1s forwards; }
@keyframes fillBar{ to{ background-position:-100% 0; } }

.quiz-step{ display:none; }
.quiz-step.active{ display:block; animation:fadeIn .4s ease; }
@keyframes fadeIn{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
.quiz-step .qstep-label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; color:var(--accent-2); text-transform:uppercase; margin-bottom:10px; }
.quiz-step h2{ font-family:var(--f-display); font-weight:800; font-size:clamp(28px, 4vw, 44px); line-height:1.05; letter-spacing:-.02em; margin-bottom:32px; text-wrap:balance; }
.quiz-opts{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.quiz-opt{
  text-align:left;
  display:flex; align-items:center; gap:14px;
  padding:18px 20px;
  background:var(--ink); border:1px solid var(--line-strong); border-radius:12px;
  transition:border-color .2s ease, background .2s ease, transform .2s ease;
}
.quiz-opt:hover{ border-color:var(--accent-2); transform:translateX(4px); background:rgba(25,243,255,.05); }
.quiz-opt .e{ font-size:22px; }
.quiz-opt .t{ font-size:15px; font-weight:500; line-height:1.3; }
@media (max-width:680px){ .quiz-opts{ grid-template-columns: 1fr; } }

.quiz-result{ display:none; text-align:center; animation:fadeIn .5s ease; }
.quiz-result.active{ display:block; }
.quiz-result .qr-label{ font-family:var(--f-mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); }
.quiz-result h2{ font-family:var(--f-display); font-weight:800; font-size:clamp(36px, 5vw, 56px); line-height:1.08; letter-spacing:-.025em; margin-block:8px 24px; }
.qr-games{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-block:24px; }
.qr-game{ width:140px; }
.qr-game img{ width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:12px; border:2px solid var(--accent-2); }
.qr-game .nm{ font-family:var(--f-display); font-weight:700; font-size:14px; margin-top:8px; }
.qr-price-card{
  display:inline-flex; flex-direction:column; align-items:center;
  background:var(--ink); border:1px solid var(--accent-3); border-radius:14px;
  padding:18px 30px; margin-block:18px;
}
.qr-price-card .orig{ font-family:var(--f-mono); font-size:12px; text-decoration:line-through; color:var(--paper-dim); }
.qr-price-card .bp{ font-family:var(--f-display); font-weight:800; font-size:42px; color:var(--accent-3); line-height:1; }
.qr-price-card .sv{ font-family:var(--f-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent-3); margin-top:4px; }

/* ============ Tweaks panel (host integration) ============ */
[data-tweaks-anchor]{ position:fixed; right:18px; bottom:18px; z-index:100; }

/* small responsive tidy */
@media (max-width: 880px){
  .hero-grid{ grid-template-columns: 1fr; }
  .hero-stack{ aspect-ratio:1/.9; max-width:520px; margin-inline:auto; }
}
