/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
:root {
  --space-xs: 6px;
  --space-sm: 18px;
  --space-md: 24px;
  --space-lg: 53px;
  --space-xl: 80px;
  --card-padding-y: 32px;
  --card-padding-x: 22px;
  --card-gap: 25px;
  --card-radius: 22px;
  --card-border-width: 2px;
  --card-min-height: 324px;
  --card-min-col-width: 281px;
  --btn-padding-y: 13px;
  --btn-padding-x: 30px;
  --btn-radius: 9px;
  --btn-gap-from-text: 16px;
  --grid-gap: 31px;
  --lh-heading: 1.24;
  --lh-body: 1.52;
  --ls-heading: 0.060em;

  --marigold: #ffc629;
  --marigold-deep: #f0a800;
  --magenta: #ff1d8e;
  --ink: #0b0b0b;
  --paper: #fff7df;
}

*, *::before, *::after { box-sizing: border-box; min-width: 0; }
img, svg, video { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; }
html { scroll-behavior: smooth; }
body { margin: 0; }

body {
  font-family: system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background: var(--marigold);
  color: var(--ink);
  line-height: var(--lh-body);
  font-size: 17px;
  background-image:
    radial-gradient(rgba(0,0,0,0.05) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,0.04) 1px, transparent 1px);
  background-size: 4px 4px, 7px 7px;
  background-position: 0 0, 2px 2px;
}

.wrap { max-width: 1080px; margin: 0 auto; padding: 0 var(--space-md); }

/* HEADER */
.site-header {
  background: var(--ink);
  color: var(--marigold);
  border-bottom: 4px solid var(--magenta);
}
.site-header__row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-sm) var(--space-md);
  gap: var(--space-md); flex-wrap: wrap;
}
.brand { display: flex; align-items: center; gap: var(--space-xs); color: var(--marigold); text-decoration: none; }
.brand img { background: var(--marigold); border-radius: 4px; padding: 3px; }
.brand__name { font-weight: 900; letter-spacing: var(--ls-heading); font-size: 22px; }
.nav { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.nav a { color: var(--marigold); text-decoration: none; font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-heading); font-size: 13px; border-bottom: 2px solid transparent; padding-bottom: 2px; }
.nav a:hover { border-bottom-color: var(--magenta); }

/* HERO */
.hero {
  background: var(--marigold);
  padding: var(--space-xl) 0 var(--space-lg);
  border-bottom: 4px dashed var(--ink);
  position: relative;
  overflow: hidden;
}
.hero--slim { padding: var(--space-lg) 0 var(--space-md); }
.hero__inner { text-align: center; position: relative; }
.hero__badge { display: flex; justify-content: center; margin-bottom: var(--space-sm); }
.hero__badge svg { filter: drop-shadow(4px 4px 0 var(--magenta)); }
.hero__kicker { text-transform: uppercase; letter-spacing: 0.12em; font-weight: 700; font-size: 13px; margin: 0 0 var(--space-sm); color: var(--ink); }
.hero__title {
  font-size: clamp(38px, 7vw, 78px);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  font-weight: 900;
  margin: 0 auto var(--space-md);
  max-width: 16ch;
  color: var(--ink);
  text-shadow: 4px 4px 0 var(--magenta);
}
.hero__sub { max-width: 56ch; margin: 0 auto var(--space-md); font-size: 19px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: var(--btn-gap-from-text); justify-content: center; margin-bottom: var(--space-md); }

.disclaimer-band {
  display: inline-block;
  background: var(--ink);
  color: var(--marigold);
  padding: 10px var(--space-md);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.04em;
  border: 2px solid var(--ink);
  margin-top: var(--space-sm);
}

/* BUTTONS */
.btn {
  display: inline-block;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-radius);
  border: var(--card-border-width) solid var(--ink);
  font-weight: 900;
  text-decoration: none;
  cursor: pointer;
  letter-spacing: var(--ls-heading);
  text-transform: uppercase;
  font-size: 15px;
  background: var(--marigold);
  color: var(--ink);
}
.btn--primary { background: var(--magenta); color: #fff; box-shadow: 4px 4px 0 var(--ink); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--stamp {
  background: var(--magenta); color: #fff;
  box-shadow: 5px 5px 0 var(--ink);
  transform: rotate(-1.5deg);
  padding: 16px 36px;
  font-size: 17px;
}
.btn:hover { transform: translate(-1px,-1px); }
.btn--stamp:hover { transform: rotate(-1.5deg) translate(-2px,-2px); box-shadow: 7px 7px 0 var(--ink); }

/* SECTION HELPERS */
.section-title {
  font-size: clamp(28px, 4vw, 44px);
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  font-weight: 900;
  margin: 0 0 var(--space-sm);
  text-shadow: 3px 3px 0 var(--magenta);
}
.section-lead { font-size: 18px; max-width: 60ch; margin: 0 0 var(--space-md); }

/* GAMES / CABINETS */
.games { padding: var(--space-xl) 0; background: var(--marigold); border-bottom: 4px dashed var(--ink); }
.cabinet {
  background: var(--paper);
  border: 3px solid var(--ink);
  border-radius: var(--card-radius);
  padding: var(--card-padding-y) var(--card-padding-x);
  margin-bottom: var(--card-gap);
  box-shadow: 8px 8px 0 var(--magenta), 8px 8px 0 1px var(--ink);
  min-height: var(--card-min-height);
}
.cabinet__head { margin-bottom: var(--space-md); }
.cabinet__head h3 { font-size: 32px; letter-spacing: var(--ls-heading); margin: var(--space-xs) 0 var(--space-sm); line-height: var(--lh-heading); }
.cabinet__foot { margin-top: var(--space-md); }
.chip { display: inline-block; background: var(--ink); color: var(--marigold); padding: 4px 12px; font-size: 11px; font-weight: 900; letter-spacing: 0.14em; border-radius: 4px; }

/* ABOUT */
.about { background: var(--paper); padding: var(--space-xl) 0; border-bottom: 4px dashed var(--ink); }
.about__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(var(--card-min-col-width), 1fr)); gap: var(--grid-gap); align-items: start; }
.about__col p { font-size: 18px; }
.facts { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm); }
.facts li { background: var(--marigold); border: 3px solid var(--ink); border-radius: var(--card-radius); padding: var(--space-md); text-align: center; box-shadow: 4px 4px 0 var(--magenta); }
.facts strong { display: block; font-size: 36px; font-weight: 900; line-height: 1; letter-spacing: var(--ls-heading); margin-bottom: var(--space-xs); }
.facts span { font-size: 13px; text-transform: uppercase; font-weight: 700; letter-spacing: 0.08em; }

/* FEATURES */
.features { background: var(--marigold); padding: var(--space-xl) 0; border-bottom: 4px dashed var(--ink); }
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(var(--card-min-col-width), 1fr)); gap: var(--grid-gap); }
.feature { background: var(--paper); border: 3px solid var(--ink); border-radius: var(--card-radius); padding: var(--card-padding-y) var(--card-padding-x); box-shadow: 5px 5px 0 var(--magenta); }
.feature h3 { margin: 0 0 var(--space-xs); font-size: 22px; letter-spacing: var(--ls-heading); line-height: var(--lh-heading); }
.feature p { margin: 0; }

/* FAQ */
.faq { background: var(--paper); padding: var(--space-xl) 0; }
.faq details { background: var(--marigold); border: 3px solid var(--ink); border-radius: var(--card-radius); padding: var(--space-md); margin-bottom: var(--space-sm); box-shadow: 4px 4px 0 var(--magenta); }
.faq summary { font-weight: 900; font-size: 18px; cursor: pointer; letter-spacing: var(--ls-heading); }
.faq details p { margin: var(--space-sm) 0 0; }

/* PROSE (policies) */
.prose { background: var(--paper); padding: var(--space-xl) 0; }
.prose h2 { font-size: 26px; letter-spacing: var(--ls-heading); margin-top: var(--space-lg); line-height: var(--lh-heading); }
.prose p, .prose li { font-size: 17px; }
.prose ul { padding-left: 1.4em; }

/* FOOTER */
.site-footer { background: var(--ink); color: var(--marigold); padding: var(--space-xl) 0 var(--space-md); border-top: 4px solid var(--magenta); }
.site-footer a { color: var(--marigold); }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--grid-gap); margin-bottom: var(--space-lg); }
.footer-about, .footer-addr { margin: 0 0 var(--space-sm); font-size: 14px; }
.footer-nav { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.footer-nav a { font-weight: 700; text-transform: uppercase; letter-spacing: var(--ls-heading); font-size: 13px; text-decoration: none; }
.footer-nav a:hover { color: var(--magenta); }
.logo-strips { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--grid-gap); margin-bottom: var(--space-lg); padding: var(--space-md); background: #1a1a1a; border-radius: var(--card-radius); }
.logo-strip__label { margin: 0 0 var(--space-sm); font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; font-weight: 700; color: var(--marigold); }
.logo-row { display: flex; flex-wrap: wrap; gap: var(--space-sm); align-items: center; }
.logo-row img { background: var(--paper); padding: 6px; border-radius: 6px; object-fit: contain; }
.statutory { font-size: 13px; opacity: 0.85; margin: var(--space-md) 0 var(--space-xs); }
.copyright { font-size: 12px; opacity: 0.7; margin: 0; }

/* AGE GATE */
.age-gate {
  position: fixed; inset: 0;
  background: rgba(11,11,11,0.92);
  z-index: 9999;
  align-items: center; justify-content: center;
  padding: var(--space-md);
}
.age-gate:not([hidden]) { display: flex; }
.age-gate__panel {
  background: var(--marigold);
  border: 4px solid var(--ink);
  border-radius: var(--card-radius);
  padding: var(--space-lg);
  max-width: 480px;
  text-align: center;
  box-shadow: 10px 10px 0 var(--magenta);
}
.age-gate__panel h2 { margin: 0 0 var(--space-sm); font-size: 30px; letter-spacing: var(--ls-heading); line-height: var(--lh-heading); }
.age-gate__buttons { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; margin-top: var(--space-md); }

/* COOKIE BANNER */
.cookie-banner {
  position: fixed; left: var(--space-md); right: var(--space-md); bottom: var(--space-md);
  background: var(--ink); color: var(--marigold);
  border: 3px solid var(--magenta);
  border-radius: var(--card-radius);
  padding: var(--space-md);
  z-index: 9998;
  max-width: 720px; margin: 0 auto;
  box-shadow: 6px 6px 0 var(--magenta);
}
.cookie-banner:not([hidden]) { display: block; }
.cookie-banner p { margin: 0 0 var(--space-sm); font-size: 14px; }
.cookie-banner a { color: var(--marigold); }
.cookie-banner__buttons { display: flex; gap: var(--space-sm); flex-wrap: wrap; }

/* UNDER 18 */
.under18-body { background: var(--marigold); }
.under18 { min-height: 80vh; display: flex; align-items: center; padding: var(--space-xl) 0; }
.under18 h1 { font-size: clamp(32px, 5vw, 56px); letter-spacing: var(--ls-heading); line-height: var(--lh-heading); margin: 0 0 var(--space-md); text-shadow: 3px 3px 0 var(--magenta); }
.under18 p { font-size: 19px; margin: 0 0 var(--space-md); max-width: 50ch; }

@media (max-width: 600px) {
  .facts { grid-template-columns: 1fr; }
  .hero__title { text-shadow: 2px 2px 0 var(--magenta); }
  .section-title { text-shadow: 2px 2px 0 var(--magenta); }
}
