/*
Theme Name: Unsolved Mordgåtor
Theme URI: https://unsolved.se
Author: DetectIt
Description: Mörkt noir-tema för mordgåtebutik med spelhantering, filterbar butik och SEO.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: unsolved
Tags: dark, noir, detective, game, immersive, full-width, custom-menu
*/

/* ============================================================
   DESIGN TOKENS
============================================================ */
:root {
  --ink:          #06080d;
  --ink-2:        #0b0e17;
  --ink-3:        #111826;
  --ink-4:        #1a2235;
  --silver:       #c2c8d4;
  --silver-dim:   #6b7280;
  --cream:        #f2ede6;
  --gold:         #c9a84c;
  --gold-bright:  #e8c96e;
  --gold-dim:     rgba(201,168,76,.18);
  --red:          #8c2020;
  --border:       rgba(194,200,212,.08);
  --border-gold:  rgba(201,168,76,.25);
  --glow:         rgba(201,168,76,.06);

  --font-display: 'Bebas Neue', sans-serif;
  --font-serif:   'Cormorant Garamond', Georgia, serif;
  --font-mono:    'DM Mono', 'Courier New', monospace;

  --nav-h:        68px;
  --container:    1360px;
  --pad-x:        clamp(1.25rem, 5vw, 4rem);
  --ease-expo:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-snappy:  cubic-bezier(0.25, 0, 0, 1);
  --ease-bounce:  cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ============================================================
   RESET
============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body { background: var(--ink); color: var(--cream); font-family: var(--font-serif); overflow-x: hidden; }
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
input, select, textarea { font: inherit; }
::selection { background: var(--gold); color: var(--ink); }

/* ============================================================
   FILM GRAIN + VIGNETTE
============================================================ */
body::before {
  content: '';
  position: fixed; inset: 0; z-index: 9998;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: .028;
  animation: grain 0.5s steps(1) infinite;
}

body::after {
  content: '';
  position: fixed; inset: 0; z-index: 9997;
  pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(6,8,13,.7) 100%);
}

@keyframes grain {
  0%   { transform: translate(0,0); }
  10%  { transform: translate(-2%,-2%); }
  20%  { transform: translate(2%,1%); }
  30%  { transform: translate(-1%,2%); }
  40%  { transform: translate(1%,-1%); }
  50%  { transform: translate(-2%,2%); }
  60%  { transform: translate(2%,-2%); }
  70%  { transform: translate(-1%,1%); }
  80%  { transform: translate(1%,2%); }
  90%  { transform: translate(-2%,-1%); }
  100% { transform: translate(0,0); }
}

/* ============================================================
   TYPOGRAPHY
============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 0.95;
  color: var(--cream);
  text-transform: uppercase;
}

h1 { font-size: clamp(3.5rem, 10vw, 8rem); }
h2 { font-size: clamp(2.4rem, 6vw, 5rem); }
h3 { font-size: clamp(1.6rem, 3.5vw, 2.8rem); }
h4 { font-size: clamp(1.1rem, 2.5vw, 1.6rem); }

p {
  font-family: var(--font-serif);
  font-size: clamp(.95rem, 2vw, 1.1rem);
  font-weight: 300;
  line-height: 1.8;
  color: var(--silver);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--font-mono);
  font-size: .62rem;
  font-weight: 400;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
}

.eyebrow::before {
  content: '';
  display: block;
  width: 24px; height: 1px;
  background: var(--gold);
  flex-shrink: 0;
}

/* ============================================================
   LAYOUT
============================================================ */
.container {
  width: min(var(--container), 100% - var(--pad-x) * 2);
  margin-inline: auto;
}

.container--narrow {
  width: min(780px, 100% - var(--pad-x) * 2);
  margin-inline: auto;
}

.section { padding-block: clamp(4rem, 10vw, 7rem); position: relative; }

/* ============================================================
   CUSTOM CURSOR (desktop only)
============================================================ */
@media (pointer: fine) {
  body { cursor: none; }

  .cursor {
    position: fixed; top: 0; left: 0;
    width: 8px; height: 8px;
    background: var(--gold);
    border-radius: 50%;
    pointer-events: none;
    z-index: 99999;
    transform: translate(-50%,-50%);
    transition: width .25s var(--ease-expo), height .25s var(--ease-expo);
    mix-blend-mode: difference;
  }

  .cursor-ring {
    position: fixed; top: 0; left: 0;
    width: 40px; height: 40px;
    border: 1px solid rgba(201,168,76,.45);
    border-radius: 50%;
    pointer-events: none;
    z-index: 99998;
    transform: translate(-50%,-50%);
    transition: transform .15s var(--ease-expo), width .35s var(--ease-expo), height .35s var(--ease-expo), opacity .3s;
  }

  .cursor.hover { width: 14px; height: 14px; }
  .cursor-ring.hover { width: 64px; height: 64px; opacity: .5; }
}

/* ============================================================
   BUTTONS
============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .6em;
  font-family: var(--font-mono);
  font-size: .62rem;
  font-weight: 400;
  letter-spacing: .25em;
  text-transform: uppercase;
  padding: .9em 2.2em;
  border: 1px solid transparent;
  position: relative;
  overflow: hidden;
  transition: color .4s var(--ease-expo);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  min-height: 48px;
}

.btn__bg {
  position: absolute; inset: 0;
  transform: translateX(-101%);
  transition: transform .5s var(--ease-expo);
  z-index: 0;
}

.btn > *:not(.btn__bg) { position: relative; z-index: 1; }
.btn:hover .btn__bg, .btn:focus .btn__bg { transform: translateX(0); }

.btn--primary { border-color: rgba(194,200,212,.25); color: var(--cream); }
.btn--primary .btn__bg { background: var(--cream); }
.btn--primary:hover, .btn--primary:focus { color: var(--ink); }

.btn--gold { border-color: var(--border-gold); color: var(--gold); }
.btn--gold .btn__bg { background: var(--gold); }
.btn--gold:hover, .btn--gold:focus { color: var(--ink); }

.btn--filled { background: var(--gold); border-color: var(--gold); color: var(--ink); }
.btn--filled .btn__bg { background: var(--cream); }

.btn--ghost { border-color: var(--border); color: var(--silver-dim); font-size: .58rem; padding: .7em 1.5em; min-height: 40px; }
.btn--ghost .btn__bg { background: var(--ink-4); }
.btn--ghost:hover, .btn--ghost:focus { color: var(--cream); }

.btn svg { width: 13px; height: 13px; flex-shrink: 0; transition: transform .35s var(--ease-expo); }
.btn:hover svg { transform: translateX(3px); }

/* ============================================================
   SITE HEADER
============================================================ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 900;
  display: flex; align-items: center;
  transition: background .5s, backdrop-filter .5s, border-color .5s;
  border-bottom: 1px solid transparent;
}

.site-header.scrolled {
  background: rgba(6,8,13,.88);
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border-bottom-color: var(--border);
}

.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 2rem;
  width: 100%;
  padding-inline: var(--pad-x);
}

.site-logo {
  display: flex; align-items: center; gap: .5rem;
  font-family: var(--font-display);
  font-size: 1.15rem; letter-spacing: .12em;
  color: var(--cream); flex-shrink: 0;
}

.site-logo__icon {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border-gold);
  padding: 5px; color: var(--gold);
}

.site-logo__icon svg { width: 100%; height: 100%; }

.primary-nav {
  display: flex; align-items: center; justify-content: center; gap: .1rem;
}

.primary-nav a {
  font-family: var(--font-mono);
  font-size: .58rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--silver-dim); padding: .55rem 1rem;
  transition: color .2s; position: relative;
}

.primary-nav a::after {
  content: '';
  position: absolute; bottom: 0; left: 1rem; right: 1rem;
  height: 1px; background: var(--gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s var(--ease-expo);
}

.primary-nav a:hover, .primary-nav a.current-menu-item { color: var(--cream); }
.primary-nav a:hover::after, .primary-nav a.current-menu-item::after { transform: scaleX(1); }

.header-right {
  display: flex; align-items: center; gap: 1rem; justify-content: flex-end;
}

.city-pill {
  display: flex; align-items: center; gap: .4rem;
  font-family: var(--font-mono);
  font-size: .56rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--silver-dim); padding: .45rem .9rem;
  border: 1px solid var(--border); transition: all .2s; cursor: pointer;
  white-space: nowrap;
}

.city-pill:hover { border-color: var(--border-gold); color: var(--gold); }
.city-pill svg { width: 10px; height: 10px; }

.nav-toggle {
  display: none;
  flex-direction: column; justify-content: center; gap: 5px;
  width: 44px; height: 44px;
  border: 1px solid var(--border); padding: 12px;
  transition: border-color .2s;
  -webkit-tap-highlight-color: transparent;
}

.nav-toggle:hover { border-color: var(--border-gold); }

.nav-toggle span {
  display: block; width: 100%; height: 1px;
  background: var(--cream); transition: all .4s var(--ease-expo);
}

.nav-toggle.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ============================================================
   MOBILE NAV
============================================================ */
.mobile-nav {
  position: fixed; inset: 0; z-index: 800;
  background: var(--ink);
  display: flex; flex-direction: column;
  padding: calc(var(--nav-h) + 2rem) var(--pad-x) 3rem;
  overflow-y: auto;
  transform: translateY(-100%);
  transition: transform .65s var(--ease-expo);
  visibility: hidden;
}

.mobile-nav.open { transform: translateY(0); visibility: visible; }

.mobile-nav__links {
  flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 0;
}

.mobile-nav__links a {
  font-family: var(--font-display);
  font-size: clamp(3rem, 12vw, 5.5rem);
  line-height: 1.05;
  color: rgba(242,237,230,.15);
  letter-spacing: .03em;
  padding: .05em 0;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  transition: color .3s, padding-left .3s;
}

.mobile-nav__links a:first-child { border-top: 1px solid var(--border); }
.mobile-nav__links a:hover { color: var(--cream); padding-left: .1em; }

.mobile-nav__links a svg { width: 28px; height: 28px; opacity: .2; transition: opacity .3s; flex-shrink: 0; }
.mobile-nav__links a:hover svg { opacity: .7; }

.mobile-nav__footer {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
  padding-top: 2rem; border-top: 1px solid var(--border); margin-top: 2rem;
}

.mobile-nav__socials { display: flex; gap: .5rem; }
.mobile-nav__socials a {
  width: 40px; height: 40px; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--silver-dim); transition: all .2s;
}
.mobile-nav__socials a:hover { border-color: var(--gold); color: var(--gold); }
.mobile-nav__socials svg { width: 16px; height: 16px; }

/* ============================================================
   HERO
============================================================ */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; align-items: flex-end;
  overflow: hidden;
}

.hero__media { position: absolute; inset: 0; z-index: 0; }

.hero__media img, .hero__media video {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 20%;
  transform: scale(1.05);
  animation: heroZoom 12s ease-out forwards;
  filter: brightness(.28) saturate(.55);
}

@keyframes heroZoom {
  from { transform: scale(1.05); }
  to   { transform: scale(1); }
}

.hero__media::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(to top,   var(--ink) 0%, transparent 45%),
    linear-gradient(to right, rgba(6,8,13,.88) 0%, transparent 60%),
    linear-gradient(to bottom, rgba(6,8,13,.5) 0%, transparent 25%);
}

.hero__body {
  position: relative; z-index: 2;
  width: 100%;
  padding: calc(var(--nav-h) + 5rem) var(--pad-x) clamp(4rem, 8vw, 6rem);
  max-width: min(var(--container), 100%);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}

@media (min-width: 900px) {
  .hero__body { grid-template-columns: 1fr 1fr; align-items: flex-end; }
}

.hero__eyebrow { margin-bottom: 1.5rem; animation: fadeUp .8s var(--ease-expo) .1s both; }

.hero__title {
  font-size: clamp(4rem, 13vw, 9.5rem);
  line-height: .9;
  margin-bottom: 2rem;
  animation: fadeUp .9s var(--ease-expo) .2s both;
}

.hero__title em {
  font-style: normal;
  font-family: var(--font-serif);
  font-size: .42em; font-weight: 300;
  letter-spacing: .06em; display: block;
  color: rgba(242,237,230,.45);
  text-transform: none; line-height: 1.4; margin-bottom: .15em;
}

.hero__tagline {
  font-family: var(--font-serif);
  font-size: clamp(1rem, 2.2vw, 1.2rem); font-weight: 300; font-style: italic;
  color: var(--silver); max-width: 400px; line-height: 1.75;
  margin-bottom: 2.5rem;
  animation: fadeUp .9s var(--ease-expo) .3s both;
}

.hero__actions {
  display: flex; align-items: center; flex-wrap: wrap; gap: 1rem;
  animation: fadeUp .9s var(--ease-expo) .4s both;
}

.hero__right {
  display: none;
  animation: fadeUp .9s var(--ease-expo) .5s both;
}

@media (min-width: 900px) {
  .hero__right {
    display: flex; flex-direction: column;
    align-items: flex-end; justify-content: flex-end; gap: .75rem;
  }
}

.hero__stat-card {
  background: rgba(11,14,23,.75);
  backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-left: 2px solid var(--gold);
  padding: 1.2rem 1.5rem;
  min-width: 185px;
  transition: transform .35s var(--ease-expo), border-left-color .2s;
}

.hero__stat-card:hover { transform: translateX(-5px); }

.hero__stat-num {
  font-family: var(--font-display);
  font-size: 2.8rem; color: var(--gold); line-height: 1; display: block;
}

.hero__stat-label {
  font-family: var(--font-mono);
  font-size: .52rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--silver-dim); display: block; margin-top: .25rem;
}

.hero__vert-text {
  position: absolute; bottom: 8rem; right: var(--pad-x);
  writing-mode: vertical-lr; transform: rotate(180deg);
  font-family: var(--font-mono); font-size: .52rem; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(107,114,128,.4); display: none; z-index: 2;
}

@media (min-width: 1100px) { .hero__vert-text { display: block; } }

.hero__scroll-cue {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
  cursor: pointer; animation: fadeUp 1s var(--ease-expo) .8s both;
}

.hero__scroll-cue span {
  font-family: var(--font-mono); font-size: .52rem; letter-spacing: .3em; text-transform: uppercase;
  color: rgba(107,114,128,.5);
}

.hero__scroll-mouse {
  width: 20px; height: 32px; border: 1px solid rgba(107,114,128,.3); border-radius: 10px;
  position: relative; display: flex; justify-content: center; padding-top: 6px;
}

.hero__scroll-mouse::before {
  content: '';
  width: 2px; height: 7px; background: var(--gold); border-radius: 1px;
  animation: mouseScroll 1.8s ease-in-out infinite;
}

@keyframes mouseScroll {
  0%   { opacity: 1; transform: translateY(0); }
  80%  { opacity: 0; transform: translateY(10px); }
  100% { opacity: 0; }
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ============================================================
   MARQUEE STRIP
============================================================ */
.marquee-strip {
  position: relative; background: var(--gold);
  overflow: hidden; height: 44px;
  display: flex; align-items: center;
  border-block: 1px solid rgba(232,201,110,.3);
}

.marquee-strip__track {
  display: flex; gap: 0;
  animation: marquee 22s linear infinite;
  white-space: nowrap; will-change: transform;
}

.marquee-strip__track:hover { animation-play-state: paused; }

.marquee-strip__item {
  display: flex; align-items: center; gap: 1.5rem;
  padding-inline: 2rem;
  font-family: var(--font-display);
  font-size: 1rem; letter-spacing: .08em; color: var(--ink);
}

.marquee-strip__sep { font-size: 1.2rem; opacity: .3; }

@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   ATMOSPHERE GALLERY
============================================================ */
.atmosphere { background: var(--ink-2); }

.atm-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 1.5rem; margin-bottom: clamp(2rem, 5vw, 3.5rem);
}

.atm-grid {
  display: grid; gap: .75rem;
  grid-template-columns: repeat(6, 1fr);
}

.atm-grid__item {
  position: relative; overflow: hidden; background: var(--ink-3); cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}

.atm-grid__item:nth-child(1) { grid-column: span 4; aspect-ratio: 16/9; }
.atm-grid__item:nth-child(2) { grid-column: span 2; aspect-ratio: 3/4; }
.atm-grid__item:nth-child(3),
.atm-grid__item:nth-child(4),
.atm-grid__item:nth-child(5) { grid-column: span 2; aspect-ratio: 4/3; }

.atm-grid__item img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.25) brightness(.5);
  transition: filter .7s var(--ease-expo), transform .7s var(--ease-expo);
}

.atm-grid__item:hover img { filter: saturate(.65) brightness(.7); transform: scale(1.04); }

.atm-grid__overlay {
  position: absolute; inset: 0; background: rgba(6,8,13,.3);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .4s;
}

.atm-grid__item:hover .atm-grid__overlay { opacity: 1; }

.atm-play {
  width: 56px; height: 56px; border: 1px solid rgba(242,237,230,.6);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  transform: scale(.8); transition: transform .4s var(--ease-bounce);
  backdrop-filter: blur(8px);
}

.atm-grid__item:hover .atm-play { transform: scale(1); }
.atm-play svg { width: 18px; height: 18px; fill: var(--cream); margin-left: 3px; }

@media (max-width: 700px) {
  .atm-grid { grid-template-columns: repeat(2, 1fr); }
  .atm-grid__item { grid-column: span 1 !important; aspect-ratio: 4/3 !important; }
  .atm-grid__item:nth-child(1) { grid-column: span 2 !important; aspect-ratio: 16/9 !important; }
}

/* ============================================================
   GAMES SECTION
============================================================ */
.games-section__header {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 2rem; margin-bottom: clamp(2rem, 5vw, 3.5rem);
}

.scroll-hint {
  display: none; align-items: center; gap: .5rem;
  font-family: var(--font-mono); font-size: .55rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--silver-dim); margin-bottom: 1rem;
}

.scroll-hint svg { width: 16px; height: 16px; animation: nudge 1.5s ease-in-out infinite; }

@keyframes nudge { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(5px); } }

@media (max-width: 900px) { .scroll-hint { display: flex; } }

.games-scroll {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border);
}

@media (max-width: 900px) {
  .games-scroll {
    display: flex; overflow-x: auto;
    scroll-snap-type: x mandatory; gap: .75rem;
    background: none;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 1rem;
  }
  .games-scroll::-webkit-scrollbar { display: none; }
}

.game-card {
  background: var(--ink-2); position: relative; overflow: hidden;
  transition: transform .5s var(--ease-expo);
  display: flex; flex-direction: column;
}

@media (max-width: 900px) {
  .game-card {
    min-width: min(310px, 82vw); flex-shrink: 0;
    scroll-snap-align: start;
    border: 1px solid var(--border);
  }
}

.game-card::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, var(--gold), transparent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .5s var(--ease-expo); z-index: 1;
}

.game-card:hover::after { transform: scaleX(1); }
.game-card:hover { transform: translateY(-3px); }

.game-card__visual {
  position: relative; aspect-ratio: 16/10; overflow: hidden; flex-shrink: 0;
}

.game-card__visual img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.2) brightness(.45);
  transition: filter .7s var(--ease-expo), transform .7s var(--ease-expo);
}

.game-card:hover .game-card__visual img { filter: saturate(.5) brightness(.6); transform: scale(1.06); }

.game-card__badge {
  position: absolute; top: 1rem; left: 0; z-index: 1;
  font-family: var(--font-mono); font-size: .52rem; letter-spacing: .18em; text-transform: uppercase;
  padding: .4em .8em;
}

.badge--hard   { background: var(--red); color: #faa; }
.badge--medium { background: rgba(201,168,76,.2); color: var(--gold); border: 1px solid var(--border-gold); }
.badge--easy   { background: rgba(34,120,80,.25); color: #6fcf97; }

.game-card__num {
  position: absolute; top: .5rem; right: .75rem;
  font-family: var(--font-display); font-size: 4.5rem; line-height: 1;
  color: rgba(242,237,230,.05); z-index: 0; user-select: none;
}

.game-card__body { padding: 1.5rem; display: flex; flex-direction: column; flex: 1; }

.game-card__meta { display: flex; gap: 1.25rem; margin-bottom: 1rem; flex-wrap: wrap; }

.game-card__meta-item {
  display: flex; align-items: center; gap: .4rem;
  font-family: var(--font-mono); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--silver-dim);
}
.game-card__meta-item svg { width: 11px; height: 11px; opacity: .55; }

.game-card__title {
  font-size: clamp(1.4rem, 4vw, 1.9rem); margin-bottom: .6rem;
  transition: color .25s; line-height: 1;
}

.game-card:hover .game-card__title { color: var(--gold); }

.game-card__desc {
  font-size: .9rem; color: var(--silver-dim); line-height: 1.65;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden; flex: 1; margin-bottom: 1.5rem;
  font-family: var(--font-serif); font-weight: 300;
}

.game-card__footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 1rem; border-top: 1px solid var(--border);
  gap: 1rem; flex-wrap: wrap;
}

.game-card__price {
  font-family: var(--font-display); font-size: 1.6rem; line-height: 1; color: var(--gold);
}

.game-card__price small {
  font-family: var(--font-mono); font-size: .52rem; letter-spacing: .12em;
  color: var(--silver-dim); display: block; margin-top: .15rem;
}

/* ============================================================
   ABOUT SECTION
============================================================ */
.about { background: var(--ink); overflow: hidden; }

.about__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 7vw, 6rem); align-items: center;
}

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

.about__visual { position: relative; }

.about__img-main {
  width: 100%; aspect-ratio: 3/4; overflow: hidden; position: relative;
}

.about__img-main img {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(.35); transition: filter 1s;
}

.about__img-main:hover img { filter: saturate(.6); }

.about__img-main::before,
.about__img-main::after {
  content: ''; position: absolute; z-index: 2; pointer-events: none;
}

.about__img-main::before {
  top: -10px; right: -10px;
  width: 70px; height: 70px;
  border-top: 2px solid var(--gold); border-right: 2px solid var(--gold);
}

.about__img-main::after {
  bottom: -10px; left: -10px;
  width: 70px; height: 70px;
  border-bottom: 2px solid var(--gold); border-left: 2px solid var(--gold);
}

.about__stats-badge {
  position: absolute; bottom: -1.5rem; right: -1.5rem; z-index: 3;
  background: var(--ink-2); border: 1px solid var(--border-gold);
  display: grid; grid-template-columns: 1fr 1fr;
}

@media (max-width: 800px) {
  .about__stats-badge { right: 0; bottom: 0; position: relative; margin-top: 1.5rem; }
  .about__img-main::before, .about__img-main::after { display: none; }
}

.about__stat {
  padding: 1.1rem 1.3rem; text-align: center; border: 1px solid var(--border);
}

.about__stat-num {
  font-family: var(--font-display); font-size: 2.2rem; line-height: 1;
  color: var(--gold); display: block;
}

.about__stat-label {
  font-family: var(--font-mono); font-size: .52rem; letter-spacing: .15em; text-transform: uppercase;
  color: var(--silver-dim); display: block; margin-top: .3rem;
}

.about__text h2 { margin-bottom: 1.25rem; }
.about__text p { margin-bottom: 1rem; }

.about__features { display: grid; grid-template-columns: 1fr 1fr; gap: .6rem; margin-block: 2rem; }

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

.feature-pill {
  display: flex; align-items: center; gap: .7rem;
  padding: .7rem 1rem; border: 1px solid var(--border);
  background: var(--glow); transition: border-color .2s;
}

.feature-pill:hover { border-color: var(--border-gold); }

.feature-pill__icon { width: 26px; height: 26px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--gold); }
.feature-pill__icon svg { width: 14px; height: 14px; }

.feature-pill__text { font-family: var(--font-mono); font-size: .58rem; letter-spacing: .15em; text-transform: uppercase; color: var(--silver); }

/* ============================================================
   CORPORATE
============================================================ */
.corporate { position: relative; overflow: hidden; background: var(--ink-2); }

.corporate__bg-img { position: absolute; inset: 0; z-index: 0; }
.corporate__bg-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.08) saturate(.3); }
.corporate__bg-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to right, var(--ink-2) 40%, rgba(11,14,23,.6) 100%);
}

.corporate__inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(3rem, 7vw, 6rem); align-items: start;
}

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

.perk-list { display: flex; flex-direction: column; gap: .4rem; margin-block: 2rem; }

.perk-row {
  display: flex; align-items: center; gap: 1.25rem;
  padding: .85rem 1.25rem; border: 1px solid var(--border);
  background: rgba(6,8,13,.45); transition: border-color .25s, background .25s;
}

.perk-row:hover { border-color: var(--border-gold); background: var(--glow); }

.perk-row__num { font-family: var(--font-display); font-size: 1.6rem; line-height: 1; color: var(--gold); opacity: .35; min-width: 2rem; }
.perk-row__text { font-family: var(--font-serif); font-size: 1rem; font-weight: 300; color: var(--cream); line-height: 1.35; }

.enquiry-card {
  background: var(--ink-3); border: 1px solid var(--border); padding: 2.5rem; position: relative;
}

.enquiry-card::before {
  content: ''; position: absolute; top: -1px; left: 2rem; right: 2rem; height: 2px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
}

.form-heading {
  font-family: var(--font-display); font-size: 1.4rem; letter-spacing: .08em; text-transform: uppercase;
  color: var(--cream); margin-bottom: 1.75rem; padding-bottom: .9rem; border-bottom: 1px solid var(--border);
}

.form-row { display: grid; gap: 1rem; margin-bottom: 1rem; }
.form-row--2 { grid-template-columns: 1fr 1fr; }
@media (max-width: 480px) { .form-row--2 { grid-template-columns: 1fr; } }

.form-group { display: flex; flex-direction: column; gap: .4rem; }

.form-group label {
  font-family: var(--font-mono); font-size: .55rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--silver-dim);
}

.form-group input,
.form-group select,
.form-group textarea {
  background: rgba(255,255,255,.03); border: 1px solid var(--border);
  color: var(--cream); font-family: var(--font-serif); font-size: 1rem; font-weight: 300;
  padding: .75rem 1rem; outline: none;
  transition: border-color .25s, background .25s; width: 100%; -webkit-appearance: none;
}

.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--gold); background: rgba(201,168,76,.04);
}

.form-group textarea { resize: vertical; min-height: 90px; }
.form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center; padding-right: 2.5rem; cursor: pointer;
}
.form-group option { background: var(--ink-3); color: var(--cream); }
.form-group input::placeholder, .form-group textarea::placeholder { color: var(--silver-dim); opacity: .4; }

#form-feedback { display: none; padding: .8rem 1rem; font-family: var(--font-mono); font-size: .62rem; letter-spacing: .1em; margin-block: 1rem; }

/* ============================================================
   TESTIMONIALS
============================================================ */
.testimonials { background: var(--ink); }

.testimonials__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: var(--border);
  margin-top: clamp(2rem, 5vw, 3.5rem);
}

@media (max-width: 820px) {
  .testimonials__grid { grid-template-columns: 1fr; background: none; border: 1px solid var(--border); }
}

.testimonial {
  background: var(--ink-2); padding: 2rem;
  position: relative; overflow: hidden; transition: background .3s;
}

.testimonial:hover { background: var(--ink-3); }

.testimonial__giant-quote {
  position: absolute; top: -.5rem; right: 1rem;
  font-family: var(--font-display); font-size: 8rem; line-height: 1;
  color: var(--gold); opacity: .05; pointer-events: none; user-select: none;
}

.testimonial__stars { display: flex; gap: .2rem; margin-bottom: 1.25rem; color: var(--gold); font-size: .85rem; }

.testimonial__text {
  font-family: var(--font-serif); font-size: 1.05rem; font-weight: 300; font-style: italic;
  color: rgba(242,237,230,.7); line-height: 1.75; margin-bottom: 1.5rem; position: relative; z-index: 1;
}

.testimonial__author { display: flex; align-items: center; gap: .9rem; padding-top: 1.25rem; border-top: 1px solid var(--border); }

.testimonial__avatar {
  width: 40px; height: 40px; border-radius: 50%; overflow: hidden;
  background: var(--ink-4); border: 1px solid var(--border); flex-shrink: 0;
}

.testimonial__avatar img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }

.testimonial__name { font-family: var(--font-display); font-size: .9rem; letter-spacing: .08em; text-transform: uppercase; color: var(--cream); display: block; line-height: 1.2; }
.testimonial__game { font-family: var(--font-mono); font-size: .52rem; letter-spacing: .15em; text-transform: uppercase; color: var(--gold); display: block; margin-top: .2rem; }

/* ============================================================
   FRANCHISE
============================================================ */
.franchise { background: var(--ink-2); border-block: 1px solid var(--border); }

.franchise__inner { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(3rem, 7vw, 6rem); align-items: center; }
@media (max-width: 780px) { .franchise__inner { grid-template-columns: 1fr; } }

.franchise__numbers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); }
.franchise__num-item { background: var(--ink-3); padding: 1.5rem 1rem; text-align: center; }
.franchise__num-big { font-family: var(--font-display); font-size: 3rem; line-height: 1; color: var(--gold); display: block; }
.franchise__num-label { font-family: var(--font-mono); font-size: .52rem; letter-spacing: .18em; text-transform: uppercase; color: var(--silver-dim); display: block; margin-top: .4rem; }

/* ============================================================
   FOOTER
============================================================ */
.site-footer { background: var(--ink); border-top: 1px solid var(--border); padding-top: clamp(3.5rem, 8vw, 6rem); padding-bottom: 2rem; }

.footer-grid {
  display: grid; grid-template-columns: 2.5fr 1fr 1fr 1fr;
  gap: 3rem; padding-bottom: clamp(3rem, 6vw, 4rem);
  border-bottom: 1px solid var(--border); margin-bottom: 2rem;
}

@media (max-width: 960px) { .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; } }
@media (max-width: 540px) { .footer-grid { grid-template-columns: 1fr; gap: 2rem; } }

.footer-brand__tagline {
  font-family: var(--font-serif); font-size: 1rem; font-weight: 300; font-style: italic;
  color: var(--silver-dim); line-height: 1.7; max-width: 280px; margin-block: 1.25rem;
}

.social-row { display: flex; gap: .5rem; margin-top: 1.5rem; }

.social-btn {
  width: 36px; height: 36px; border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  color: var(--silver-dim); transition: all .25s; flex-shrink: 0;
}

.social-btn svg { width: 15px; height: 15px; }
.social-btn:hover { border-color: var(--gold); color: var(--gold); background: var(--glow); }

.footer-col__title {
  font-family: var(--font-mono); font-size: .58rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--cream); margin-bottom: 1.25rem; padding-bottom: .75rem; border-bottom: 1px solid var(--border);
}

.footer-links { display: flex; flex-direction: column; gap: .5rem; }
.footer-links a { font-family: var(--font-serif); font-size: .95rem; font-weight: 300; color: var(--silver-dim); transition: color .2s, padding-left .25s; display: block; padding: .1rem 0; }
.footer-links a:hover { color: var(--cream); padding-left: .4rem; }

.footer-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
.footer-copy { font-family: var(--font-mono); font-size: .56rem; letter-spacing: .15em; color: var(--silver-dim); }
.footer-legal { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-legal a { font-family: var(--font-mono); font-size: .56rem; letter-spacing: .15em; text-transform: uppercase; color: var(--silver-dim); transition: color .2s; }
.footer-legal a:hover { color: var(--gold); }

/* ============================================================
   SCROLL REVEAL
============================================================ */
[data-reveal] {
  opacity: 0; transform: translateY(28px);
  transition: opacity .75s var(--ease-expo), transform .75s var(--ease-expo);
}

[data-reveal="left"]  { transform: translateX(-28px); }
[data-reveal="right"] { transform: translateX(28px); }
[data-reveal="scale"] { transform: scale(.95); }

[data-reveal].in-view { opacity: 1; transform: none; }
[data-delay="1"] { transition-delay: .1s; }
[data-delay="2"] { transition-delay: .2s; }
[data-delay="3"] { transition-delay: .3s; }
[data-delay="4"] { transition-delay: .4s; }
[data-delay="5"] { transition-delay: .5s; }

/* ============================================================
   PAGE BANNER
============================================================ */
.page-banner {
  min-height: 50vh; display: flex; align-items: flex-end; position: relative; overflow: hidden;
  padding-bottom: clamp(3rem, 6vw, 5rem); padding-top: calc(var(--nav-h) + 3rem);
}

.page-banner__bg {
  position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(135deg, var(--ink-2) 0%, var(--ink) 100%);
}

.page-banner__bg::before {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 48px, var(--border) 48px, var(--border) 49px),
    repeating-linear-gradient(90deg, transparent, transparent 48px, var(--border) 48px, var(--border) 49px);
  opacity: .4;
}

.page-banner__bg::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 20% 80%, rgba(201,168,76,.06) 0%, transparent 60%);
}

.page-banner .container { position: relative; z-index: 1; }

/* ============================================================
   ENTRY HERO
============================================================ */
.entry-hero { height: 65vh; min-height: 400px; position: relative; overflow: hidden; }
.entry-hero img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.3) saturate(.4); }
.entry-hero::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, var(--ink) 0%, transparent 50%), linear-gradient(to right, rgba(6,8,13,.7) 0%, transparent 60%);
}
.entry-hero__meta { position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; padding: 2rem var(--pad-x); }

/* ============================================================
   POST BODY
============================================================ */
.post-body { color: var(--silver); }
.post-body h2, .post-body h3, .post-body h4 { color: var(--cream); margin: 2rem 0 .75rem; }
.post-body p { margin-bottom: 1.25rem; }
.post-body ul, .post-body ol { padding-left: 1.5rem; margin-bottom: 1.25rem; }
.post-body li { margin-bottom: .5rem; color: var(--silver); }
.post-body strong { color: var(--cream); font-weight: 600; }
.post-body a { color: var(--gold); border-bottom: 1px solid rgba(201,168,76,.3); transition: border-color .2s; }
.post-body a:hover { border-color: var(--gold); }
.post-body blockquote { border-left: 2px solid var(--gold); padding-left: 1.5rem; margin: 2rem 0; font-style: italic; color: rgba(242,237,230,.6); }

/* ============================================================
   DETAIL SIDEBAR
============================================================ */
.detail-sidebar { background: var(--ink-2); border: 1px solid var(--border); padding: 2rem; position: sticky; top: calc(var(--nav-h) + 2rem); }
.detail-sidebar::before { content: ''; display: block; height: 2px; background: linear-gradient(to right, var(--gold), transparent); margin-bottom: 2rem; }
.detail-row { display: flex; align-items: center; gap: .75rem; padding: .9rem 0; border-bottom: 1px solid var(--border); }
.detail-row:first-of-type { border-top: 1px solid var(--border); }
.detail-row__icon { color: var(--gold); opacity: .65; flex-shrink: 0; }
.detail-row__label { font-family: var(--font-mono); font-size: .52rem; letter-spacing: .18em; text-transform: uppercase; color: var(--silver-dim); min-width: 70px; }
.detail-row__value { font-family: var(--font-display); font-size: .95rem; letter-spacing: .06em; text-transform: uppercase; color: var(--cream); }
.detail-price { text-align: center; padding: 1.5rem 0; }
.detail-price__num { font-family: var(--font-display); font-size: 3.5rem; line-height: 1; color: var(--gold); }
.detail-price__sub { font-family: var(--font-mono); font-size: .52rem; letter-spacing: .18em; text-transform: uppercase; color: var(--silver-dim); display: block; margin-top: .25rem; }

/* ============================================================
   ARCHIVE GRID
============================================================ */
.archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); }
@media (max-width: 820px) { .archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px)  { .archive-grid { grid-template-columns: 1fr; } }

/* ============================================================
   404
============================================================ */
.error-page { min-height: 95svh; display: flex; align-items: center; justify-content: center; text-align: center; position: relative; overflow: hidden; }
.error-page__bg-num { position: absolute; font-family: var(--font-display); font-size: clamp(12rem, 35vw, 28rem); color: rgba(242,237,230,.03); line-height: 1; user-select: none; pointer-events: none; top: 50%; left: 50%; transform: translate(-50%, -50%); }

/* ============================================================
   SEARCH FORM
============================================================ */
.search-form { display: flex; }
.search-field { flex: 1; min-width: 0; background: rgba(255,255,255,.03); border: 1px solid var(--border); border-right: none; color: var(--cream); font-family: var(--font-serif); font-size: 1rem; font-weight: 300; padding: .75rem 1.25rem; outline: none; transition: border-color .25s; }
.search-field:focus { border-color: var(--gold); }
.search-field::placeholder { color: var(--silver-dim); opacity: .5; }
.search-submit { background: var(--gold); border: 1px solid var(--gold); color: var(--ink); font-family: var(--font-mono); font-size: .58rem; letter-spacing: .2em; text-transform: uppercase; padding: 0 1.5rem; cursor: pointer; transition: background .2s; flex-shrink: 0; }
.search-submit:hover { background: var(--gold-bright); }

/* ============================================================
   PAGINATION
============================================================ */
.page-numbers { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; justify-content: center; }
.page-numbers a, .page-numbers span { font-family: var(--font-mono); font-size: .58rem; letter-spacing: .12em; padding: .6em .9em; min-width: 38px; text-align: center; border: 1px solid var(--border); color: var(--silver-dim); transition: all .2s; }
.page-numbers a:hover, .page-numbers .current { border-color: var(--gold); color: var(--gold); }

/* ============================================================
   WP CORE CLASSES
============================================================ */
.alignleft { float: left; margin: 0 2rem 1rem 0; }
.alignright { float: right; margin: 0 0 1rem 2rem; }
.aligncenter { display: block; margin: 1.5rem auto; }
.sticky {} .bypostauthor {}

/* ============================================================
   GUTENBERG BLOCKS
============================================================ */
.wp-block-quote { border-left: 2px solid var(--gold); padding-left: 1.5rem; margin: 2rem 0; }
.wp-block-quote p { font-style: italic; color: rgba(242,237,230,.65); }
.wp-block-separator { border: none; border-top: 1px solid var(--border); margin: 3rem 0; }
.wp-block-button .wp-block-button__link { font-family: var(--font-mono) !important; font-size: .62rem !important; letter-spacing: .2em !important; text-transform: uppercase !important; border-radius: 0 !important; padding: .9em 2em !important; background: transparent !important; border: 1px solid var(--cream) !important; color: var(--cream) !important; transition: all .35s !important; }
.wp-block-button .wp-block-button__link:hover { background: var(--cream) !important; color: var(--ink) !important; }

/* ============================================================
   RESPONSIVE TOUCH TARGETS
============================================================ */
@media (max-width: 900px) {
  .primary-nav { display: none; }
  .city-pill { display: none; }
  .nav-toggle { display: flex; }
  .site-logo span { display: none; }
}

@media (max-width: 480px) {
  .hero__actions { flex-direction: column; }
  .hero__actions .btn { width: 100%; justify-content: center; }
}

/* ============================================================
   LIGHTBOX
============================================================ */
.lightbox { position: fixed; inset: 0; z-index: 10000; background: rgba(6,8,13,.95); display: flex; align-items: center; justify-content: center; opacity: 0; visibility: hidden; transition: opacity .4s, visibility .4s; padding: var(--pad-x); -webkit-tap-highlight-color: transparent; }
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox__inner { width: 100%; max-width: 960px; aspect-ratio: 16/9; position: relative; transform: scale(.9); transition: transform .5s var(--ease-expo); }
.lightbox.open .lightbox__inner { transform: scale(1); }
.lightbox__close { position: absolute; top: -2.5rem; right: 0; font-family: var(--font-mono); font-size: .58rem; letter-spacing: .2em; color: var(--silver-dim); text-transform: uppercase; display: flex; align-items: center; gap: .5rem; cursor: pointer; transition: color .2s; }
.lightbox__close:hover { color: var(--cream); }
.lightbox__close svg { width: 14px; height: 14px; }

/* ============================================================
   PRINT
============================================================ */
@media print {
  .site-header, .site-footer, .mobile-nav, .cursor, .cursor-ring, .hero__scroll-cue, .marquee-strip { display: none !important; }
  body { background: white; color: black; }
}

/* ============================================================
   SHOP SECTION — GAME GRID + FILTERS
============================================================ */
.shop-section { background: var(--ink-2); position: relative; }
.shop-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 40% at 50% 0%, rgba(201,168,76,.04), transparent); pointer-events:none; }

.shop-header { text-align:center; margin-bottom: clamp(2rem,4vw,3.5rem); }
.shop-header .eyebrow { justify-content:center; margin-bottom:1.25rem; }
.shop-header h2 { margin-bottom:.75rem; }
.shop-header p { max-width:520px; margin-inline:auto; }

/* Filter Bar */
.shop-filters { display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:2.5rem; position:sticky; top:var(--nav-h); z-index:50; padding:1.2rem var(--pad-x); background:rgba(11,14,23,.9); backdrop-filter:blur(20px); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

.filter-group { display:flex; align-items:center; gap:.4rem; }
.filter-group__label { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver-dim); white-space:nowrap; }
.filter-sep { width:1px; height:20px; background:var(--border); margin-inline:.4rem; }

.filter-btn { font-family:var(--font-mono); font-size:.54rem; letter-spacing:.14em; text-transform:uppercase; padding:.45em 1em; border:1px solid var(--border); color:var(--silver-dim); background:transparent; cursor:pointer; transition:all .25s; white-space:nowrap; min-height:36px; }
.filter-btn:hover { border-color:var(--border-gold); color:var(--gold); }
.filter-btn.active { border-color:var(--gold); background:var(--gold); color:var(--ink); }

.filter-reset { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.14em; text-transform:uppercase; padding:.45em 1em; border:1px solid var(--border); color:var(--silver-dim); background:transparent; cursor:pointer; transition:all .25s; min-height:36px; }
.filter-reset:hover { border-color:var(--red); color:var(--red); }

/* Games Grid */
.games-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px,1fr)); gap:1.5rem; }

/* Loading state */
.games-grid--loading { opacity:.4; pointer-events:none; }
.shop-loader { display:none; justify-content:center; align-items:center; padding:3rem; gap:1rem; font-family:var(--font-mono); font-size:.58rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver-dim); }
.shop-loader.active { display:flex; }
.shop-loader__spinner { width:20px; height:20px; border:1px solid var(--border-gold); border-top-color:var(--gold); border-radius:50%; animation:spin .8s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* No results */
.unsolved-no-results { text-align:center; padding:4rem 2rem; font-family:var(--font-serif); font-size:1.1rem; color:var(--silver-dim); font-style:italic; grid-column:1/-1; }

/* Active filters display */
.active-filters { display:flex; flex-wrap:wrap; gap:.5rem; align-items:center; margin-bottom:1.5rem; min-height:32px; }
.active-filter-tag { display:inline-flex; align-items:center; gap:.4rem; font-family:var(--font-mono); font-size:.52rem; letter-spacing:.12em; text-transform:uppercase; background:var(--gold-dim); border:1px solid var(--border-gold); color:var(--gold); padding:.3em .8em; }
.active-filter-tag button { background:none; border:none; cursor:pointer; color:var(--gold); font-size:.75rem; line-height:1; padding:0; margin-left:.2rem; }
.results-count { font-family:var(--font-mono); font-size:.54rem; letter-spacing:.15em; text-transform:uppercase; color:var(--silver-dim); margin-left:auto; }

/* ============================================================
   GAME CARD
============================================================ */
.game-card { background:var(--ink-3); border:1px solid var(--border); position:relative; overflow:hidden; transition:transform .5s var(--ease-expo), border-color .3s, box-shadow .5s; display:flex; flex-direction:column; }
.game-card:hover { transform:translateY(-8px); border-color:var(--border-gold); box-shadow:0 30px 60px rgba(0,0,0,.5),0 0 40px rgba(201,168,76,.06); }
.game-card__cover { position:relative; aspect-ratio:2/3; overflow:hidden; flex-shrink:0; }
.game-card__cover img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-expo); }
.game-card:hover .game-card__cover img { transform:scale(1.06); }
.game-card__placeholder { width:100%; height:100%; background:var(--ink-4); }
.game-card__cover-overlay { position:absolute; inset:0; background:linear-gradient(to top, var(--ink-3) 0%, transparent 50%); }
.game-card__tag { position:absolute; top:.9rem; left:.9rem; font-family:var(--font-mono); font-size:.52rem; letter-spacing:.2em; text-transform:uppercase; background:var(--gold); color:var(--ink); padding:.3em .8em; font-weight:400; }
.game-card__body { padding:1.4rem; display:flex; flex-direction:column; flex:1; }
.game-card__sub { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:.5rem; }
.game-card__title { font-family:var(--font-display); font-size:clamp(1.4rem,3vw,1.9rem); letter-spacing:.04em; color:var(--cream); margin-bottom:.75rem; line-height:.95; text-transform:uppercase; }
.game-card__title a { color:inherit; transition:color .2s; }
.game-card__title a:hover { color:var(--gold); }
.game-card__desc { font-family:var(--font-serif); font-size:.88rem; color:var(--silver-dim); line-height:1.6; margin-bottom:1rem; flex:1; }
.game-card__meta { display:flex; gap:1rem; font-family:var(--font-mono); font-size:.52rem; letter-spacing:.12em; text-transform:uppercase; color:var(--silver-dim); margin-bottom:1.2rem; padding-bottom:1.2rem; border-bottom:1px solid var(--border); flex-wrap:wrap; }
.game-card__footer { display:flex; align-items:center; justify-content:space-between; gap:.5rem; }
.game-card__price { font-family:var(--font-display); font-size:1.6rem; color:var(--cream); letter-spacing:.04em; }

/* ============================================================
   SINGLE GAME PAGE
============================================================ */
.single-game { padding-top:0; }
.single-game__hero { position:relative; min-height:70svh; display:flex; align-items:flex-end; overflow:hidden; }
.single-game__hero-media { position:absolute; inset:0; }
.single-game__hero-media img { width:100%; height:100%; object-fit:cover; filter:brightness(.3) saturate(.5); }
.single-game__hero-media::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, var(--ink) 0%, transparent 55%), linear-gradient(to right, rgba(6,8,13,.9) 0%, transparent 65%); }
.single-game__hero-body { position:relative; z-index:2; padding:calc(var(--nav-h) + 3rem) var(--pad-x) 4rem; max-width:min(var(--container),100%); margin-inline:auto; width:100%; }
.single-game__hero-body .eyebrow { margin-bottom:1rem; }
.single-game__hero-body h1 { font-size:clamp(3rem,8vw,7rem); margin-bottom:1.5rem; }
.single-game__hero-body .hero__tagline { max-width:540px; }

.single-game__content { padding-block:clamp(3rem,7vw,5rem); }
.single-game__grid { display:grid; gap:3rem; align-items:start; }
@media(min-width:900px) { .single-game__grid { grid-template-columns:1fr 320px; } }

.single-game__sidebar { background:var(--ink-3); border:1px solid var(--border); border-left:2px solid var(--gold); padding:2rem; position:sticky; top:calc(var(--nav-h) + 2rem); }
.game-detail-list { list-style:none; display:flex; flex-direction:column; gap:1rem; margin-bottom:2rem; }
.game-detail-list li { display:flex; justify-content:space-between; align-items:center; font-family:var(--font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; padding-bottom:1rem; border-bottom:1px solid var(--border); }
.game-detail-list li:last-child { border-bottom:none; padding-bottom:0; }
.game-detail-list__label { color:var(--silver-dim); }
.game-detail-list__value { color:var(--cream); text-align:right; }
.game-sidebar__price { font-family:var(--font-display); font-size:3rem; color:var(--gold); line-height:1; display:block; margin-bottom:1.5rem; }

/* ============================================================
   GIFT CARD SECTION
============================================================ */
.giftcard-section { background:var(--ink); position:relative; overflow:hidden; }
.giftcard-section::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 50% at 50% 50%, rgba(201,168,76,.04), transparent); pointer-events:none; }
.giftcard-inner { display:grid; gap:3rem; align-items:center; position:relative; z-index:1; }
@media(min-width:768px) { .giftcard-inner { grid-template-columns:1fr auto; } }
.giftcard-badge { background:var(--ink-4); border:1px solid var(--border-gold); padding:2rem; display:flex; align-items:center; gap:1.5rem; min-width:220px; }
.giftcard-badge__icon { font-size:3rem; flex-shrink:0; }
.giftcard-badge__label { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.2em; text-transform:uppercase; color:var(--silver-dim); margin-bottom:.3rem; display:block; }
.giftcard-badge__price { font-family:var(--font-display); font-size:2.2rem; color:var(--gold); display:block; letter-spacing:.06em; }

/* ============================================================
   ADMIN STYLES (admin.css) — included via enqueue
============================================================ */

/* ============================================================
   POST BODY TYPOGRAPHY
============================================================ */
.post-body { font-family: var(--font-serif); color: var(--silver); line-height: 1.85; }
.post-body h1,.post-body h2,.post-body h3,.post-body h4 { color: var(--cream); margin-block: 2rem 1rem; }
.post-body h2 { font-size: clamp(1.6rem,3vw,2.2rem); }
.post-body h3 { font-size: clamp(1.2rem,2.5vw,1.7rem); }
.post-body p  { margin-bottom: 1.4rem; }
.post-body a  { color: var(--gold); border-bottom: 1px solid var(--border-gold); transition: border-color .2s; }
.post-body a:hover { border-color: var(--gold); }
.post-body ul,.post-body ol { padding-left: 1.5rem; margin-bottom: 1.4rem; }
.post-body li { margin-bottom: .4rem; }
.post-body blockquote { border-left: 2px solid var(--gold); padding: 1rem 1.5rem; margin: 2rem 0; background: var(--ink-3); font-style: italic; }
.post-body img { border: 1px solid var(--border); margin-block: 1.5rem; }
.post-body table { width: 100%; border-collapse: collapse; margin-bottom: 1.5rem; font-size: .9rem; }
.post-body th { background: var(--ink-4); border: 1px solid var(--border); padding: .6rem 1rem; font-family: var(--font-mono); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); text-align: left; }
.post-body td { border: 1px solid var(--border); padding: .6rem 1rem; }

/* ============================================================
   PAGINATION
============================================================ */
.nav-links { display: flex; justify-content: center; gap: .5rem; margin-top: 3rem; flex-wrap: wrap; }
.page-numbers { font-family: var(--font-mono); font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; padding: .6em 1.1em; border: 1px solid var(--border); color: var(--silver-dim); transition: all .2s; }
.page-numbers:hover,.page-numbers.current { border-color: var(--gold); color: var(--gold); background: var(--gold-dim); }
.page-numbers.dots { border-color: transparent; }

/* ============================================================
   SEARCH FORM
============================================================ */
.search-form { display: flex; gap: .5rem; max-width: 500px; margin-inline: auto; }
.search-field { flex: 1; background: var(--ink-3); border: 1px solid var(--border); color: var(--cream); font-family: var(--font-serif); font-size: 1rem; padding: .75rem 1rem; outline: none; transition: border-color .2s; }
.search-field:focus { border-color: var(--border-gold); }
.search-submit { background: var(--gold); border: none; color: var(--ink); font-family: var(--font-mono); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; padding: .75rem 1.5rem; cursor: pointer; transition: background .2s; }
.search-submit:hover { background: var(--gold-bright); }

/* ============================================================
   POST NAVIGATION
============================================================ */
.post-navigation { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem; }
.post-navigation a { display: block; padding: 1rem 1.25rem; border: 1px solid var(--border); color: var(--silver-dim); font-family: var(--font-mono); font-size: .56rem; letter-spacing: .14em; text-transform: uppercase; transition: all .2s; }
.post-navigation a:hover { border-color: var(--border-gold); color: var(--gold); }
.post-navigation .nav-next { text-align: right; }

/* ============================================================
   ABOUT SECTION STEPS
============================================================ */
.steps-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 1.5rem; margin-top: 2rem; }
.step-card { border: 1px solid var(--border); border-left: 2px solid var(--gold); padding: 1.5rem; transition: border-color .3s; }
.step-card:hover { border-color: var(--border-gold); }
.step-num { font-family: var(--font-display); font-size: 2.5rem; color: var(--gold); line-height: 1; display: block; margin-bottom: .75rem; letter-spacing: .04em; }
.step-card h4 { font-size: 1rem; margin-bottom: .5rem; letter-spacing: .06em; }
.step-card p  { font-size: .85rem; line-height: 1.65; }

/* ============================================================
   REVEAL ANIMATION
============================================================ */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .85s var(--ease-expo), transform .85s var(--ease-expo); }
.reveal.visible { opacity: 1; transform: none; }

/* ============================================================
   SECTION DIVIDER
============================================================ */
.section-divider { width: 100%; height: 1px; background: linear-gradient(to right, transparent, var(--border-gold), transparent); }

/* ============================================================
   FOOTER
============================================================ */
.site-footer { background: var(--ink-2); border-top: 1px solid var(--border); padding-block: 3rem 1.5rem; }
.footer-grid { display: grid; gap: 3rem; margin-bottom: 3rem; }
@media (min-width: 768px) { .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; } }
.footer-logo { font-family: var(--font-display); font-size: 1.4rem; letter-spacing: .12em; color: var(--cream); margin-bottom: .75rem; }
.footer-tagline { font-family: var(--font-serif); font-size: .9rem; color: var(--silver-dim); font-style: italic; }
.footer-heading { font-family: var(--font-mono); font-size: .54rem; letter-spacing: .25em; text-transform: uppercase; color: var(--gold); margin-bottom: 1rem; display: block; }
.footer-links { display: flex; flex-direction: column; gap: .5rem; }
.footer-links a { font-family: var(--font-serif); font-size: .9rem; color: var(--silver-dim); transition: color .2s; }
.footer-links a:hover { color: var(--cream); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
.footer-bottom p { font-family: var(--font-mono); font-size: .52rem; letter-spacing: .15em; color: var(--silver-dim); }

/* ============================================================
   MOBILE NAV
============================================================ */
.mobile-nav { position: fixed; inset: 0; z-index: 800; background: var(--ink); display: flex; flex-direction: column; padding: calc(var(--nav-h) + 2rem) var(--pad-x) 3rem; overflow-y: auto; transform: translateY(-100%); transition: transform .65s var(--ease-expo); visibility: hidden; }
.mobile-nav.open { transform: translateY(0); visibility: visible; }
.mobile-nav__links { flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 0; }
.mobile-nav__links a { font-family: var(--font-display); font-size: clamp(2.5rem,10vw,5rem); line-height: 1.1; color: rgba(242,237,230,.15); letter-spacing: .03em; padding: .06em 0; border-bottom: 1px solid var(--border); display: block; transition: color .3s, padding-left .3s; }
.mobile-nav__links a:first-child { border-top: 1px solid var(--border); }
.mobile-nav__links a:hover { color: var(--cream); padding-left: .1em; }

/* ============================================================
   USP GRID
============================================================ */
.usp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.usp-card { background:var(--ink-3); border:1px solid var(--border); padding:2rem; transition:border-color .3s,transform .4s var(--ease-expo); }
.usp-card:hover { border-color:var(--border-gold); transform:translateY(-4px); }
.usp-card__icon { font-size:2rem; margin-bottom:1rem; display:block; }
.usp-card__title { font-family:var(--font-display); font-size:1.3rem; letter-spacing:.04em; color:var(--cream); margin-bottom:.6rem; text-transform:uppercase; }
.usp-card__text { font-family:var(--font-serif); font-size:.9rem; color:var(--silver-dim); line-height:1.7; }

/* ============================================================
   PUBLISHERS GRID
============================================================ */
.publishers-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.publisher-card { background:var(--ink-3); border:1px solid var(--border); border-left:2px solid var(--gold); padding:2rem; display:flex; flex-direction:column; gap:1rem; transition:border-color .3s; }
.publisher-card:hover { border-color:var(--border-gold); }
.publisher-card__header { display:flex; align-items:baseline; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.publisher-card__name { font-family:var(--font-display); font-size:1.5rem; letter-spacing:.04em; color:var(--cream); text-transform:uppercase; line-height:1; }
.publisher-card__count { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); flex-shrink:0; }
.publisher-card__desc { font-family:var(--font-serif); font-size:.9rem; color:var(--silver-dim); line-height:1.7; flex:1; }

/* ============================================================
   REVIEWS GRID
============================================================ */
.reviews-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.review-card { background:var(--ink-3); border:1px solid var(--border); padding:2rem; display:flex; flex-direction:column; gap:1rem; }
.review-card__stars { color:var(--gold); font-size:1.1rem; letter-spacing:.1em; }
.review-card__quote { font-family:var(--font-serif); font-size:1rem; font-style:italic; color:var(--silver); line-height:1.7; flex:1; quotes:"\201C""\201D"; }
.review-card__quote::before { content:open-quote; color:var(--gold); font-size:1.4rem; line-height:0; vertical-align:-.3em; }
.review-card__author { display:flex; flex-direction:column; gap:.2rem; border-top:1px solid var(--border); padding-top:1rem; }
.review-card__author strong { font-family:var(--font-mono); font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; color:var(--cream); }
.review-card__author span { font-family:var(--font-mono); font-size:.52rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }

/* ============================================================
   FAQ
============================================================ */
.faq-layout { display:grid; gap:3rem; align-items:start; }
@media(min-width:900px) { .faq-layout { grid-template-columns:1fr 1.6fr; } }
.faq-list { display:flex; flex-direction:column; gap:.5rem; }
.faq-item { border:1px solid var(--border); transition:border-color .2s; }
.faq-item[open] { border-color:var(--border-gold); }
.faq-item__question { font-family:var(--font-mono); font-size:.62rem; letter-spacing:.16em; text-transform:uppercase; color:var(--cream); padding:1.2rem 1.5rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; transition:color .2s; user-select:none; }
.faq-item__question::-webkit-details-marker { display:none; }
.faq-item__question::after { content:'+'; color:var(--gold); font-size:1.2rem; font-family:var(--font-display); transition:transform .3s; flex-shrink:0; margin-left:1rem; }
.faq-item[open] .faq-item__question::after { transform:rotate(45deg); }
.faq-item__question:hover { color:var(--gold); }
.faq-item__answer { font-family:var(--font-serif); font-size:.95rem; color:var(--silver); line-height:1.75; padding:0 1.5rem 1.25rem; }

/* ============================================================
   SEO TEXT BLOCK
============================================================ */
.seo-text-section { }
.seo-text-block { }
.seo-text-block h2 { font-size:clamp(1.8rem,4vw,3rem); margin-bottom:1.5rem; }
.seo-text-block h3 { font-family:var(--font-display); font-size:clamp(1.2rem,2.5vw,1.8rem); letter-spacing:.04em; text-transform:uppercase; color:var(--cream); margin-top:2.5rem; margin-bottom:1rem; }
.seo-text-block p { font-family:var(--font-serif); font-size:1rem; color:var(--silver); line-height:1.85; margin-bottom:1.2rem; }
.seo-faq { margin-top:2rem; }
.seo-faq__item { border-bottom:1px solid var(--border); }
.seo-faq__question { font-family:var(--font-mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--cream); padding:1rem 0; cursor:pointer; list-style:none; }
.seo-faq__question::-webkit-details-marker { display:none; }
.seo-faq__answer { font-family:var(--font-serif); font-size:.92rem; color:var(--silver); line-height:1.75; padding-bottom:1rem; }

/* ============================================================
   SHOP PAGE — HERO
============================================================ */
.shop-page-hero { background:var(--ink-2); border-bottom:1px solid var(--border); padding:calc(var(--nav-h) + 4rem) 0 3rem; }
.shop-page-hero__inner { display:grid; gap:2.5rem; align-items:center; }
@media(min-width:900px) { .shop-page-hero__inner { grid-template-columns:1fr auto; } }
.shop-page-hero__title { font-size:clamp(3rem,7vw,6rem); line-height:.9; margin-bottom:1rem; }
.shop-page-hero__desc { font-family:var(--font-serif); font-size:1.1rem; color:var(--silver); max-width:520px; line-height:1.7; }
.shop-page-hero__stats { display:flex; flex-direction:column; gap:1rem; }
@media(min-width:900px) { .shop-page-hero__stats { align-items:flex-end; } }
.shop-hero-stat { background:rgba(11,14,23,.7); border:1px solid var(--border); border-left:2px solid var(--gold); padding:1rem 1.5rem; min-width:170px; text-align:right; }
.shop-hero-stat__num { font-family:var(--font-display); font-size:2rem; color:var(--gold); display:block; line-height:1; letter-spacing:.04em; }
.shop-hero-stat__label { font-family:var(--font-mono); font-size:.5rem; letter-spacing:.18em; text-transform:uppercase; color:var(--silver-dim); display:block; margin-top:.25rem; }

/* ============================================================
   SHOP SEARCH
============================================================ */
.shop-search-wrap { position:relative; }
.shop-search-input { background:var(--ink-3); border:1px solid var(--border); color:var(--cream); font-family:var(--font-serif); font-size:.9rem; padding:.5rem 2.2rem .5rem 1rem; outline:none; transition:border-color .2s; min-height:36px; width:180px; }
.shop-search-input:focus { border-color:var(--border-gold); }
.shop-search-icon { position:absolute; right:.6rem; top:50%; transform:translateY(-50%); width:14px; height:14px; color:var(--silver-dim); pointer-events:none; }
.shop-filters--page .shop-filters__inner { display:flex; flex-wrap:wrap; gap:.6rem; align-items:center; padding-block:.8rem; }

/* ============================================================
   STEPS GRID (override for 4-col)
============================================================ */
.steps-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1.5rem; }
