/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
:root {
  --space-xs: 7px;
  --space-sm: 17px;
  --space-md: 22px;
  --space-lg: 48px;
  --space-xl: 98px;
  --card-padding-y: 28px;
  --card-padding-x: 23px;
  --card-gap: 16px;
  --card-radius: 12px;
  --card-border-width: 1px;
  --card-min-height: 346px;
  --card-min-col-width: 260px;
  --btn-padding-y: 10px;
  --btn-padding-x: 34px;
  --btn-radius: 12px;
  --btn-gap-from-text: 28px;
  --grid-gap: 25px;
  --lh-heading: 1.14;
  --lh-body: 1.65;
  --ls-heading: 0.020em;

  --cherry: #d6173a;
  --cherry-deep: #9c0e26;
  --tangerine: #ff7a1a;
  --yellow: #ffd23f;
  --chrome-1: #e9e9ee;
  --chrome-2: #b8bcc4;
  --chrome-3: #7a7e88;
  --ink: #1a1414;
  --cream: #fff4e6;
  --paper: #fffaf2;
}

*, *::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; font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; background: var(--paper); color: var(--ink); line-height: var(--lh-body); }

h1, h2, h3, h4, h5 { font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; line-height: var(--lh-heading); letter-spacing: var(--ls-heading); font-weight: 800; }
a { color: var(--cherry-deep); }

.wrap { width: 100%; max-width: 1100px; margin: 0 auto; padding-left: var(--space-md); padding-right: var(--space-md); }

/* Header */
.site-header { background: var(--ink); color: var(--cream); border-bottom: 4px solid var(--yellow); }
.nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding-top: var(--space-sm); padding-bottom: var(--space-sm); flex-wrap: wrap; }
.brand { display: inline-flex; align-items: center; gap: var(--space-xs); color: var(--cream); text-decoration: none; font-weight: 900; font-size: 22px; }
.brand__mark { background: var(--cherry); color: var(--yellow); width: 32px; height: 32px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; box-shadow: 0 0 0 3px var(--yellow), 0 0 0 5px var(--cherry); font-size: 16px; }
.nav__links { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.nav__links a { color: var(--cream); text-decoration: none; font-weight: 700; }
.nav__links a:hover { color: var(--yellow); }

/* Hero */
.hero {
  background:
    radial-gradient(circle at 18% 20%, rgba(255,210,63,.35), transparent 40%),
    radial-gradient(circle at 82% 80%, rgba(255,122,26,.35), transparent 45%),
    linear-gradient(135deg, #d6173a 0%, #b1102e 60%, #7a0a22 100%);
  color: var(--cream);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><circle cx='20' cy='20' r='1.5' fill='%23ffd23f' opacity='0.25'/></svg>");
  pointer-events: none;
}
.hero--tangerine { background: linear-gradient(135deg, #ff7a1a 0%, #e0590a 60%, #a8410a 100%); }
.hero__inner { padding-top: var(--space-xl); padding-bottom: var(--space-lg); position: relative; z-index: 1; }
.hero--inner .hero__inner { padding-top: var(--space-lg); padding-bottom: var(--space-md); }
.ribbon { display: inline-block; background: var(--tangerine); color: var(--ink); padding: var(--space-xs) var(--space-md); border-radius: 999px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; font-size: 13px; box-shadow: 0 4px 0 var(--cherry-deep); }
.ribbon--tangerine { background: var(--yellow); }
.hero__h1 { font-size: clamp(34px, 5vw, 56px); margin: var(--space-md) 0 var(--space-sm); max-width: 22ch; text-shadow: 0 3px 0 rgba(0,0,0,.18); }
.hero__sub { font-size: 18px; max-width: 62ch; margin: 0 0 var(--btn-gap-from-text); }
.hero__cta { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.hero__art { margin-top: var(--space-lg); max-width: 480px; }

.disclaimer-band { background: var(--tangerine); color: var(--ink); text-align: center; padding: var(--space-sm) var(--space-md); font-weight: 800; letter-spacing: .02em; border-top: 3px solid var(--ink); border-bottom: 3px solid var(--ink); }

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; padding: var(--btn-padding-y) var(--btn-padding-x); border-radius: var(--btn-radius); border: 2px solid var(--ink); font-weight: 800; text-decoration: none; cursor: pointer; transition: transform .15s ease, box-shadow .15s ease, background .15s ease; }
.btn--primary { background: var(--yellow); color: var(--ink); box-shadow: 0 4px 0 var(--ink); }
.btn--primary:hover { transform: translateY(-2px); box-shadow: 0 6px 0 var(--ink); }
.btn--ghost { background: transparent; color: inherit; border-color: currentColor; }
.btn--ghost:hover { background: rgba(255,255,255,.12); }
.btn--pill { border-radius: 999px; padding: 16px 36px; font-size: 18px; }
.btn--bounce { animation: vwhBounce 1.8s ease-in-out 0s 2; }
@keyframes vwhBounce {
  0%   { transform: translateY(0); }
  20%  { transform: translateY(-12px); }
  40%  { transform: translateY(0); }
  55%  { transform: translateY(-6px); }
  70%  { transform: translateY(0); }
  100% { transform: translateY(0); }
}

/* Sections */
.section { padding-top: var(--space-xl); padding-bottom: var(--space-xl); }
.section--tinted { background: linear-gradient(180deg, var(--cream), #ffe9d6); }
.section__h2 { font-size: clamp(28px, 3.5vw, 40px); margin: 0 0 var(--space-sm); color: var(--cherry-deep); }
.section__lede { font-size: 18px; max-width: 60ch; margin: 0 0 var(--space-lg); }

.prose h2 { color: var(--cherry-deep); margin-top: var(--space-lg); }
.prose ul { padding-left: 1.2em; }
.prose li { margin-bottom: var(--space-xs); }

/* Games */
.games-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: var(--grid-gap); }
.game-frame { background: var(--ink); border-radius: var(--card-radius); padding: var(--card-padding-y) var(--card-padding-x); border: 3px solid var(--yellow); }
.game-frame h3 { color: var(--yellow); margin: 0 0 var(--space-sm); }
.game-frame iframe { background: var(--cream); border-radius: 8px; }

/* Cards */
.card-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(var(--card-min-col-width), 1fr)); gap: var(--grid-gap); }
.card { background: var(--paper); border: var(--card-border-width) solid var(--ink); border-radius: var(--card-radius); padding: var(--card-padding-y) var(--card-padding-x); min-height: var(--card-min-height); display: flex; flex-direction: column; gap: var(--card-gap); box-shadow: 6px 6px 0 var(--ink); transition: transform .2s ease, box-shadow .2s ease; }
.card:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 var(--cherry); }
.card__topper { width: 64px; min-height: var(--card-min-height); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 36px; border: 3px solid var(--ink); gap: var(--card-gap); }
.card__topper--cherry { background: var(--cherry); }
.card__topper--tangerine { background: var(--tangerine); }
.card__h3 { font-size: 24px; margin: 0; color: var(--cherry-deep); }
.card__blurb { margin: 0; flex: 1; }
.card__list { margin: 0; padding-left: 1.2em; }
.card__list li { margin-bottom: 4px; }
.card .btn { align-self: flex-start; margin-top: var(--btn-gap-from-text); }

/* Feature grid */
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--grid-gap); }
.feature { background: var(--paper); border: 2px solid var(--ink); border-radius: var(--card-radius); padding: var(--card-padding-y) var(--card-padding-x); }
.feature h3 { margin: 0 0 var(--space-xs); color: var(--cherry-deep); font-size: 20px; }
.feature p { margin: 0; }

/* FAQ */
.faq { background: var(--paper); border: 2px solid var(--ink); border-radius: var(--card-radius); padding: var(--space-sm) var(--space-md); margin-bottom: var(--space-sm); }
.faq summary { cursor: pointer; font-weight: 800; font-size: 18px; color: var(--cherry-deep); list-style: none; }
.faq summary::after { content: " +"; }
.faq[open] summary::after { content: " −"; }
.faq p { margin: var(--space-sm) 0 0; }

/* Footer */
.site-footer { background: var(--ink); color: var(--cream); padding: var(--space-xl) 0 var(--space-lg); margin-top: var(--space-xl); border-top: 6px solid var(--yellow); }
.footer__top { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--grid-gap); margin-bottom: var(--space-lg); }
.site-footer h4 { color: var(--yellow); margin: 0 0 var(--space-sm); }
.site-footer h5 { color: var(--tangerine); margin: 0 0 var(--space-sm); text-transform: uppercase; letter-spacing: .08em; font-size: 13px; }
.site-footer a { color: var(--cream); }
.footer__list { list-style: none; padding: 0; margin: 0; }
.footer__list li { margin-bottom: var(--space-xs); }
.footer__logos { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--grid-gap); background: var(--paper); padding: var(--space-md); border-radius: var(--card-radius); margin-bottom: var(--space-lg); }
.logo-group h5 { color: var(--cherry-deep); }
.logo-row { display: flex; flex-wrap: wrap; gap: var(--space-md); align-items: center; }
.logo-row img { background: #fff; padding: 4px 8px; border-radius: 6px; }
.footer__statutory { font-weight: 700; color: var(--yellow); margin: var(--space-lg) 0 var(--space-sm); }
.footer__copy { margin: 0; font-size: 14px; opacity: .8; }
.footer__addr { font-size: 14px; }

/* Age gate + cookie banner */
.age-gate { position: fixed; inset: 0; background: rgba(20,10,10,.85); z-index: 1000; align-items: center; justify-content: center; padding: var(--space-md); }
.age-gate:not([hidden]) { display: flex; }
.age-gate__card { background: var(--paper); border: 3px solid var(--ink); border-radius: var(--card-radius); padding: var(--card-padding-y) var(--card-padding-x); max-width: 460px; width: 100%; box-shadow: 8px 8px 0 var(--cherry); }
.age-gate__card h2 { margin: 0 0 var(--space-sm); color: var(--cherry-deep); }
.age-gate__row { display: flex; gap: var(--space-sm); flex-wrap: wrap; margin-top: var(--space-md); }

.cookie-banner { position: fixed; left: var(--space-md); right: var(--space-md); bottom: var(--space-md); background: var(--ink); color: var(--cream); border: 3px solid var(--yellow); border-radius: var(--card-radius); padding: var(--space-md); z-index: 900; box-shadow: 0 6px 0 var(--cherry-deep); }
.cookie-banner:not([hidden]) { display: block; }
.cookie-banner p { margin: 0 0 var(--space-sm); }
.cookie-banner a { color: var(--yellow); }
.cookie-banner__row { display: flex; gap: var(--space-sm); flex-wrap: wrap; }

/* Under 18 */
.under18 { background: var(--cream); }
.under18__wrap { max-width: 640px; margin: 0 auto; padding: var(--space-xl) var(--space-md); text-align: center; }
.under18__wrap h1 { font-size: 32px; color: var(--cherry-deep); }

@media (max-width: 600px) {
  .hero__h1 { font-size: 32px; }
  .btn--pill { width: 100%; }
}
