:root {
  --ink: #151916;
  --muted: #63706a;
  --dark: #145372;
  --primary: #145372;
  --accent: #b86f31;
  --accent-2: #22785f;
  --paper: #eef8f5;
  --surface: #ffffff;
  --line: color-mix(in srgb, var(--muted) 26%, white);
  --white: #ffffff;
  --shadow: 0 18px 48px rgba(20, 28, 24, 0.14);
  --radius: 8px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background:
    linear-gradient(115deg, color-mix(in srgb, var(--accent) 10%, transparent) 0 1px, transparent 1px 150px),
    linear-gradient(65deg, color-mix(in srgb, var(--accent-2) 8%, transparent) 0 1px, transparent 1px 170px),
    var(--paper);
  font-family: Inter, "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  line-height: 1.58;
  overflow-x: hidden;
}
body.is-locked { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, textarea { font: inherit; }
button { cursor: pointer; }
.site-shell { min-height: 100vh; opacity: 0; pointer-events: none; }
body.age-ok .site-shell, body.layout-restricted .site-shell { opacity: 1; pointer-events: auto; }
.site-header {
  position: sticky;
  top: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 72px;
  padding: 0.8rem clamp(1rem, 4vw, 3rem);
  background: color-mix(in srgb, var(--paper) 90%, white);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}
.brand, .brand-mini { display: inline-flex; align-items: center; gap: 0.72rem; min-width: 0; text-decoration: none; }
.brand__mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius);
  color: var(--white);
  background: linear-gradient(135deg, var(--dark), var(--accent));
  font-weight: 900;
  letter-spacing: 0;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2);
}
.brand strong, .brand small { display: block; line-height: 1.12; }
.brand strong { font-size: 1.02rem; }
.brand small { color: var(--muted); }
.main-nav { display: flex; align-items: center; gap: 0.25rem; }
.main-nav a { padding: 0.7rem 0.8rem; border-radius: var(--radius); text-decoration: none; color: var(--muted); font-weight: 800; }
.main-nav a:hover, .main-nav a.is-active { color: var(--ink); background: color-mix(in srgb, var(--accent) 13%, transparent); }
.nav-toggle { display: none; width: 42px; height: 42px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
.nav-toggle span { display: block; width: 18px; height: 2px; margin: 4px auto; background: var(--ink); }
.hero {
  width: min(1160px, calc(100% - 2rem));
  margin: clamp(1rem, 3vw, 2.5rem) auto;
  min-height: clamp(500px, 66vh, 690px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: center;
}
.hero__copy { max-width: 760px; }
.eyebrow { margin: 0 0 0.6rem; color: var(--accent); font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.78rem; }
h1, h2, h3, p { overflow-wrap: anywhere; }
h1 { margin: 0; font-size: clamp(2.25rem, 6.4vw, 5.15rem); line-height: 0.97; letter-spacing: 0; }
h2 { margin: 0; font-size: clamp(1.7rem, 4vw, 3rem); line-height: 1.05; letter-spacing: 0; }
h3 { margin: 0; font-size: 1.18rem; line-height: 1.2; }
.hero__lead, .page-hero p, .section__heading p:last-child, .safe-copy p:not(.eyebrow), .legal-stack p, .text-panel p, .game-card p, .contact-card p { color: var(--muted); }
.hero__lead { max-width: 62ch; font-size: clamp(1rem, 1.8vw, 1.18rem); }
.hero__actions, .age-gate__actions, .cookie-banner div { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 44px;
  padding: 0.78rem 1rem;
  border: 1px solid transparent;
  border-radius: var(--radius);
  text-decoration: none;
  cursor: pointer;
  font-weight: 900;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}
.button:hover { transform: translateY(-1px); }
.button--primary { color: var(--white); background: var(--dark); box-shadow: 0 14px 34px color-mix(in srgb, var(--dark) 24%, transparent); }
.button--secondary, .button--ghost { color: var(--ink); background: transparent; border-color: var(--line); }
.button--card { width: 100%; color: var(--white); background: var(--accent-2); }
.button--small { min-height: 38px; padding: 0.55rem 0.78rem; }
.hero-board {
  min-height: 360px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, color-mix(in srgb, var(--dark) 92%, white), color-mix(in srgb, var(--accent-2) 72%, var(--dark)));
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: var(--white);
  overflow: hidden;
  position: relative;
}
.hero-board::before {
  content: "";
  position: absolute;
  inset: 26px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius);
}
.board-screen { position: relative; text-align: center; }
.board-screen span {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  margin: 0 auto 1rem;
  border-radius: 50%;
  background: var(--accent);
  color: var(--white);
  font-weight: 900;
  font-size: 1.4rem;
}
.board-screen strong { display: block; font-size: clamp(2.8rem, 7vw, 5rem); line-height: 0.95; }
.board-screen small { color: rgba(255,255,255,0.78); font-weight: 800; }
.disclaimer-band {
  width: min(1160px, calc(100% - 2rem));
  margin: 0 auto 1rem;
  padding: 1rem;
  border: 1px solid color-mix(in srgb, var(--accent) 32%, white);
  background: color-mix(in srgb, var(--accent) 10%, white);
  border-radius: var(--radius);
}
.proof-band {
  width: min(1160px, calc(100% - 2rem));
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: var(--radius);
  overflow: hidden;
}
.proof-band div { padding: 1rem; border-right: 1px solid var(--line); }
.proof-band div:last-child { border-right: 0; }
.proof-band strong, .proof-band span { display: block; }
.proof-band span { color: var(--muted); font-size: 0.92rem; }
.section { width: min(1160px, calc(100% - 2rem)); margin: clamp(3rem, 8vw, 6rem) auto; }
.section__heading { max-width: 760px; margin-bottom: 1.5rem; }
.section-link a { color: var(--accent-2); font-weight: 900; }
.game-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.game-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  min-width: 0;
}
.game-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; background: var(--dark); }
.game-card__body { padding: 1rem; }
.game-card__tag { display: inline-flex; margin-bottom: 0.6rem; color: var(--accent); font-weight: 900; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; }
.safe-section { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 1.2rem; align-items: start; }
.safe-copy { padding: clamp(1rem, 3vw, 2rem); background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); }
.rules-list, .step-grid, .responsible-layout, .legal-stack { display: grid; gap: 0.75rem; }
.rules-list div, .step-grid article, .responsible-layout section, .legal-stack section, .text-panel, .access-page {
  padding: 1rem;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}
.rules-list div, .step-grid article { display: grid; grid-template-columns: 56px 1fr; gap: 1rem; align-items: center; }
.rules-list span, .step-grid span { color: var(--accent); font-weight: 900; }
.rules-list p, .step-grid p { margin: 0; color: var(--muted); }
.rules-list.wide div { grid-template-columns: 72px 1fr; }
.responsible-layout { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.text-panel { display: grid; gap: 0.8rem; }
.contact-card { display: grid; grid-template-columns: 0.8fr 1fr; gap: 1rem; padding: clamp(1rem, 3vw, 2rem); background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); }
.contact-card a { color: var(--accent-2); font-weight: 900; }
.contact-form { display: grid; gap: 0.85rem; }
.contact-form label { display: grid; gap: 0.35rem; color: var(--muted); font-weight: 800; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); padding: 0.82rem 0.9rem; color: var(--ink); background: color-mix(in srgb, var(--paper) 55%, white); }
.form-status { margin: 0; color: var(--accent-2); font-weight: 900; }
.page-hero {
  width: min(1160px, calc(100% - 2rem));
  margin: 2rem auto 1rem;
  padding: clamp(2rem, 6vw, 4rem);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.page-hero__inner { max-width: 780px; }
.site-footer { margin-top: 4rem; padding: clamp(2rem, 5vw, 3rem); background: var(--dark); color: var(--white); }
.footer-warning { padding-bottom: 1.2rem; border-bottom: 1px solid rgba(255,255,255,0.18); }
.footer-warning strong { display: block; max-width: 1120px; }
.footer-brand { color: var(--white); font-size: 1.2rem; font-weight: 900; text-decoration: none; }
.site-footer p, .site-footer a { color: rgba(255,255,255,0.74); }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 1rem; margin-top: 1.5rem; }
.footer-grid a { display: block; margin: 0.35rem 0; text-decoration: none; }
.copyright { margin-top: 1.5rem; }
.age-gate { position: fixed; inset: 0; z-index: 300; display: grid; place-items: center; padding: 1rem; background: color-mix(in srgb, var(--dark) 88%, black); }
.age-gate.is-hidden { display: none; }
.age-gate__panel { width: min(520px, 100%); padding: clamp(1.2rem, 4vw, 2rem); background: var(--paper); color: var(--ink); border: 1px solid color-mix(in srgb, var(--accent) 40%, white); box-shadow: var(--shadow); border-radius: var(--radius); }
.age-gate__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.age-gate__top strong, .access-page strong { display: grid; place-items: center; width: 52px; height: 52px; border-radius: 50%; color: var(--white); background: var(--accent); }
.age-gate__facts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; margin: 1rem 0; }
.age-gate__facts span { padding: 0.65rem; border: 1px solid var(--line); background: var(--surface); color: var(--ink); text-align: center; font-size: 0.85rem; font-weight: 900; border-radius: var(--radius); }
.cookie-banner { position: fixed; left: 1rem; right: 1rem; bottom: 1rem; z-index: 240; display: none; align-items: center; justify-content: space-between; gap: 1rem; padding: 1rem; background: var(--surface); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.cookie-banner.is-visible { display: flex; }
.cookie-banner p { margin: 0; color: var(--muted); }
.game-modal { position: fixed; inset: 1rem; z-index: 260; display: none; grid-template-rows: auto 1fr; background: var(--surface); color: var(--ink); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
.game-modal.is-open { display: grid; }
.game-modal__bar { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.9rem 1rem; border-bottom: 1px solid var(--line); }
.game-modal__bar span { display: block; color: var(--muted); font-size: 0.9rem; }
.icon-button { display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid var(--line); border-radius: var(--radius); background: transparent; color: var(--ink); cursor: pointer; font-weight: 900; }
.demo-screen { display: grid; place-items: center; align-content: center; gap: 1rem; min-height: 340px; text-align: center; padding: 2rem; background: radial-gradient(circle at 50% 35%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 36%); }
.demo-screen__label { color: var(--muted); font-weight: 900; text-transform: uppercase; letter-spacing: 0.08em; }
.demo-screen strong { font-size: clamp(3rem, 10vw, 7rem); line-height: 0.9; color: var(--dark); }
.demo-screen p { max-width: 540px; margin: 0; color: var(--muted); }
.access-page { max-width: 720px; margin: 0 auto; text-align: center; display: grid; justify-items: center; gap: 1rem; }
@media (max-width: 860px) {
  .nav-toggle { display: block; }
  .main-nav { position: fixed; top: 72px; left: 1rem; right: 1rem; display: none; flex-direction: column; align-items: stretch; padding: 0.8rem; background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); }
  .main-nav.is-open { display: flex; }
  .hero, .proof-band, .game-grid, .safe-section, .contact-card, .footer-grid, .responsible-layout { grid-template-columns: 1fr; }
  .proof-band div { border-right: 0; border-bottom: 1px solid var(--line); }
  .proof-band div:last-child { border-bottom: 0; }
  .hero { min-height: auto; margin-top: 1rem; }
  .hero-board { min-height: 280px; }
  .age-gate__facts { grid-template-columns: 1fr; }
  .cookie-banner { flex-direction: column; align-items: stretch; }
}
@media (max-width: 520px) {
  .brand small { display: none; }
  .rules-list div, .step-grid article, .rules-list.wide div { grid-template-columns: 1fr; }
  .page-hero { padding: 1.3rem; }
  .game-modal { inset: 0.5rem; }
}


/* v5: ready free games in iframe modal */
.variant-1 .hero { grid-template-columns: minmax(300px, 420px) minmax(0, 1fr); }
.variant-1 .hero-board { order: -1; }
.variant-2 .hero { grid-template-columns: 1fr; text-align: center; }
.variant-2 .hero__copy { margin: 0 auto; }
.variant-2 .hero__actions { justify-content: center; }
.variant-2 .hero-board { width: min(760px, 100%); min-height: 280px; margin: 0 auto; }
.variant-3 {
  color: var(--white);
  background: radial-gradient(circle at 18% 10%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 26%), var(--dark);
}
.variant-3 .site-header,
.variant-3 .game-card,
.variant-3 .safe-copy,
.variant-3 .rules-list div,
.variant-3 .step-grid article,
.variant-3 .responsible-layout section,
.variant-3 .legal-stack section,
.variant-3 .text-panel,
.variant-3 .contact-card,
.variant-3 .page-hero,
.variant-3 .proof-band,
.variant-3 .disclaimer-band,
.variant-3 .studio-strip {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--white);
}
.variant-3 .brand small,
.variant-3 .hero__lead,
.variant-3 .page-hero p,
.variant-3 .section__heading p:last-child,
.variant-3 .game-card p,
.variant-3 .rules-list p,
.variant-3 .safe-copy p:not(.eyebrow),
.variant-3 .studio-strip p { color: rgba(255,255,255,0.72); }
.studio-strip {
  display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 1rem; align-items: center;
  padding: clamp(1rem, 3vw, 1.6rem); background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius);
}
.studio-strip p { margin: 0; color: var(--muted); }
.how-flow {
  display: grid;
  gap: 1rem;
}
.how-flow h2,
.how-flow h3,
.how-flow p { margin: 0; }
.how-summary,
.how-control-panel,
.how-card-grid article,
.how-timeline li,
.how-rail-steps article,
.how-dashboard-head,
.how-dashboard-grid article {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.how-summary {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: center;
  padding: clamp(1rem, 2.5vw, 1.5rem);
}
.how-summary p,
.how-card-grid p,
.how-rail-steps p,
.how-dashboard-grid p,
.how-dashboard-head p,
.how-control-panel span { color: var(--muted); }
.how-mark {
  display: grid;
  place-items: center;
  width: 72px;
  aspect-ratio: 1;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: var(--white);
  font-weight: 900;
  font-size: 1.35rem;
}
.how-timeline {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.how-timeline li {
  position: relative;
  min-height: 168px;
  padding: 1.1rem;
  display: grid;
  align-content: start;
  gap: 0.55rem;
}
.how-timeline li > span,
.how-card-grid small,
.how-rail-steps span,
.how-dashboard-grid span {
  color: var(--accent);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.76rem;
}
.how-game-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
.how-chip {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.55rem 0.8rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--line));
  font-weight: 900;
}
.how-flow--split {
  grid-template-columns: minmax(250px, 0.78fr) 1.4fr;
  align-items: stretch;
}
.how-control-panel {
  padding: clamp(1rem, 2.5vw, 1.5rem);
  display: grid;
  gap: 0.85rem;
  align-content: start;
}
.how-control-panel > strong {
  font-size: clamp(2.5rem, 8vw, 5.4rem);
  line-height: 0.9;
  color: var(--primary);
}
.how-meter {
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 12%, var(--line));
}
.how-meter i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--primary), var(--accent));
}
.how-mini-list {
  display: grid;
  gap: 0.45rem;
}
.how-mini-list p {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  color: var(--muted);
}
.how-mini-list b { color: var(--dark); }
.how-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}
.how-card-grid article {
  min-height: 150px;
  padding: 1rem;
  display: grid;
  align-content: start;
  gap: 0.5rem;
}
.how-flow--rail {
  grid-template-columns: minmax(220px, 0.58fr) 1.42fr;
  align-items: stretch;
}
.how-rail-visual {
  min-height: 420px;
  border-radius: var(--radius);
  padding: 1.2rem;
  display: grid;
  align-content: space-between;
  background:
    linear-gradient(160deg, color-mix(in srgb, var(--primary) 82%, #000), color-mix(in srgb, var(--accent) 72%, #111));
  color: var(--white);
  box-shadow: var(--shadow);
}
.how-rail-visual span,
.how-rail-visual strong {
  font-weight: 900;
  font-size: clamp(2rem, 5vw, 4rem);
  line-height: 0.95;
}
.how-rail-visual i {
  display: block;
  height: 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.42);
}
.how-rail-visual i:nth-of-type(2) { width: 72%; }
.how-rail-visual i:nth-of-type(3) { width: 48%; }
.how-rail-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}
.how-rail-steps article {
  padding: 1rem;
  display: grid;
  align-content: start;
  gap: 0.55rem;
}
.how-dashboard-head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: clamp(1rem, 2.5vw, 1.5rem);
}
.how-dashboard-head > strong {
  display: grid;
  place-items: center;
  width: 74px;
  aspect-ratio: 1;
  border-radius: 16px;
  background: var(--accent);
  color: var(--dark);
  font-size: 1.5rem;
}
.how-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}
.how-dashboard-grid article {
  min-height: 150px;
  padding: 1rem;
  display: grid;
  align-content: start;
  gap: 0.55rem;
}
.how-dashboard-grid .how-wide { grid-column: span 3; min-height: auto; }
.variant-3 .how-summary,
.variant-3 .how-control-panel,
.variant-3 .how-card-grid article,
.variant-3 .how-timeline li,
.variant-3 .how-rail-steps article,
.variant-3 .how-dashboard-head,
.variant-3 .how-dashboard-grid article {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--white);
}
.variant-3 .how-summary p,
.variant-3 .how-card-grid p,
.variant-3 .how-rail-steps p,
.variant-3 .how-dashboard-grid p,
.variant-3 .how-dashboard-head p,
.variant-3 .how-control-panel span,
.variant-3 .how-mini-list p { color: rgba(255,255,255,0.72); }
.variant-3 .how-mini-list b { color: var(--white); }
.game-grid--ready { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.1rem; }
.game-card--ready img { aspect-ratio: 16 / 11; object-fit: cover; filter: saturate(1.05) contrast(1.02); }
.game-modal--iframe {
  inset: 1rem;
  width: calc(100vw - 2rem);
  height: calc(100vh - 2rem);
  max-width: 1260px;
  max-height: 860px;
  margin: auto;
  background: #05070a;
  color: #f7fbff;
  border: 1px solid rgba(255,255,255,0.18);
}
.game-modal--iframe .game-modal__bar {
  background: linear-gradient(90deg, #0e1420, #121a27);
  border-color: rgba(255,255,255,0.14);
}
.game-modal--iframe .game-modal__bar span { color: rgba(255,255,255,0.64); }
.game-modal--iframe .icon-button { color: #fff; border-color: rgba(255,255,255,0.22); }
.game-modal--iframe iframe {
  width: 100%;
  height: 100%;
  min-height: 0;
  border: 0;
  background: #05070a;
}
@media (max-width: 980px) {
  .variant-1 .hero, .game-grid--ready, .studio-strip, .how-flow--split, .how-flow--rail { grid-template-columns: 1fr; }
  .variant-1 .hero-board { order: 0; }
  .how-timeline, .how-rail-steps, .how-dashboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .how-dashboard-grid .how-wide { grid-column: span 2; }
  .how-rail-visual { min-height: 260px; }
}
@media (max-width: 560px) {
  .game-modal--iframe { inset: 0.3rem; width: calc(100vw - 0.6rem); height: calc(100vh - 0.6rem); }
  .how-summary, .how-dashboard-head, .how-timeline, .how-card-grid, .how-rail-steps, .how-dashboard-grid { grid-template-columns: 1fr; }
  .how-dashboard-grid .how-wide { grid-column: auto; }
  .how-mark, .how-dashboard-head > strong { width: 58px; }
  .how-timeline li, .how-card-grid article, .how-rail-steps article, .how-dashboard-grid article { min-height: auto; }
}


/* v6: page-unique layouts */
.v6-home {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
  padding: clamp(1.2rem, 4vw, 3rem);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow);
}
.v6-home__copy { display: grid; align-content: center; gap: 1rem; }
.v6-home__copy h1 { margin: 0; font-size: clamp(2.25rem, 6vw, 5.2rem); line-height: 0.96; }
.v6-home__visual {
  position: relative;
  min-height: 390px;
  overflow: hidden;
  border-radius: var(--radius);
  background: var(--dark);
  color: var(--white);
}
.v6-home__visual img { width: 100%; height: 100%; object-fit: cover; filter: saturate(1.04) contrast(1.02); }
.v6-home__visual div {
  position: absolute;
  inset: auto 1rem 1rem 1rem;
  display: grid;
  gap: 0.25rem;
  padding: 1rem;
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,0.62);
  backdrop-filter: blur(8px);
}
.v6-home__visual span { color: var(--accent); font-weight: 900; }
.v6-home__visual strong { font-size: clamp(1.5rem, 3vw, 2.4rem); line-height: 1; }
.v6-home__visual small { color: rgba(255,255,255,0.74); }
.v6-home--1 { grid-template-columns: minmax(330px, 0.88fr) minmax(0, 1.12fr); }
.v6-home--1 .v6-home__visual { order: -1; }
.v6-home--2 { grid-template-columns: 1fr; text-align: center; }
.v6-home--2 .hero__actions { justify-content: center; }
.v6-home--2 .v6-home__visual { min-height: 310px; }
.v6-home--3 {
  background: radial-gradient(circle at 20% 15%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 32%), var(--dark);
  color: var(--white);
}
.v6-home--3 .hero__lead { color: rgba(255,255,255,0.76); }
.v6-home--4 { grid-template-columns: minmax(0, 0.95fr) minmax(300px, 1.05fr); }
.v6-home--4 .v6-home__visual { min-height: 460px; }
.v6-proof,
.v6-safety,
.v6-chip-row {
  display: grid;
  gap: 0.75rem;
}
.v6-proof {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 1rem 0;
}
.v6-proof div,
.v6-safety div,
.v6-side-note,
.v6-story,
.v6-stat-board,
.v6-legal section,
.v6-contact-form,
.v6-access {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.v6-proof div,
.v6-safety div {
  padding: 1rem;
}
.v6-proof strong,
.v6-safety span,
.v6-stat-board strong { display: block; color: var(--accent); font-weight: 900; }
.v6-proof span,
.v6-safety p,
.v6-side-note p,
.v6-story p,
.v6-legal p,
.v6-stat-board span { color: var(--muted); }
.v6-curation {
  display: grid;
  grid-template-columns: minmax(260px, 0.74fr) 1fr;
  gap: 1rem;
  align-items: center;
}
.v6-curation p, .v6-curation h2 { margin: 0; }
.v6-chip-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-column: 1 / -1;
}
.v6-chip-row span {
  min-height: 42px;
  display: grid;
  place-items: center;
  padding: 0.65rem;
  border: 1px solid color-mix(in srgb, var(--accent) 34%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
  font-weight: 900;
  text-align: center;
}
.v6-safety { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.page-hero--v6 {
  position: relative;
  overflow: hidden;
}
.page-hero--v6::after {
  content: "";
  position: absolute;
  width: 220px;
  aspect-ratio: 1;
  right: -70px;
  bottom: -90px;
  border-radius: 50%;
  border: 34px solid color-mix(in srgb, var(--accent) 26%, transparent);
}
.page-hero--shape-1 { text-align: center; }
.page-hero--shape-1 .page-hero__inner { margin: 0 auto; }
.page-hero--shape-2 { background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 92%, white), var(--dark)); color: var(--white); }
.page-hero--shape-2 p { color: rgba(255,255,255,0.78); }
.page-hero--shape-3 { min-height: 260px; display: grid; align-items: end; }
.page-hero--shape-4 .page-hero__inner { max-width: 980px; }
.v6-page-layout {
  display: grid;
  gap: 1rem;
}
.v6-page-layout--0,
.v6-page-layout--3 { grid-template-columns: minmax(250px, 0.7fr) 1.3fr; align-items: start; }
.v6-page-layout--1,
.v6-page-layout--4 { grid-template-columns: 1fr; }
.v6-page-layout--2 { grid-template-columns: 1.25fr minmax(250px, 0.75fr); align-items: start; }
.v6-page-layout--2 .v6-side-note { order: 2; }
.v6-side-note,
.v6-story,
.v6-contact-form,
.v6-access { padding: clamp(1rem, 3vw, 1.5rem); }
.v6-side-note h2,
.v6-story h2,
.v6-access h2 { margin: 0 0 0.65rem; }
.v6-games-page .game-grid--ready { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.v6-legal {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}
.v6-legal section {
  min-height: 150px;
  padding: 1rem;
}
.v6-legal h3 { margin-top: 0; }
.v6-legal--numbered section { counter-increment: legal; }
.v6-legal--numbered section h3::before {
  content: counter(legal, decimal-leading-zero) " ";
  color: var(--accent);
}
.v6-about { grid-template-columns: 1.15fr 0.85fr; }
.v6-stat-board {
  padding: 1rem;
  display: grid;
  gap: 0.8rem;
}
.v6-stat-board div {
  padding: 0.85rem;
  border-radius: var(--radius-sm);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
}
.v6-stat-board strong { font-size: clamp(2rem, 5vw, 4rem); line-height: 0.95; }
.v6-contact { grid-template-columns: minmax(260px, 0.8fr) 1.2fr; }
.v6-contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}
.v6-contact-form label:nth-child(4),
.v6-contact-form button,
.v6-contact-form .form-status { grid-column: 1 / -1; }
.v6-access {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}
.v6-access > strong {
  display: inline-grid;
  place-items: center;
  width: 92px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--accent);
  color: var(--dark);
  font-size: 2rem;
}
.variant-3 .v6-proof div,
.variant-3 .v6-safety div,
.variant-3 .v6-side-note,
.variant-3 .v6-story,
.variant-3 .v6-stat-board,
.variant-3 .v6-legal section,
.variant-3 .v6-contact-form,
.variant-3 .v6-access,
.variant-3 .v6-curation {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--white);
}
.variant-3 .v6-proof span,
.variant-3 .v6-safety p,
.variant-3 .v6-side-note p,
.variant-3 .v6-story p,
.variant-3 .v6-legal p,
.variant-3 .v6-stat-board span { color: rgba(255,255,255,0.72); }

/* v7: explicit contrast pass */
.eyebrow,
.game-card__tag,
.how-timeline li > span,
.how-card-grid small,
.how-rail-steps span,
.how-dashboard-grid span,
.v6-legal--numbered section h3::before {
  color: color-mix(in srgb, var(--dark) 86%, #000);
}
.section-link a,
.contact-card a,
.v6-side-note a {
  color: color-mix(in srgb, var(--dark) 82%, #000);
}
.button--card {
  background: color-mix(in srgb, var(--dark) 92%, #000);
  color: #fff;
}
.brand__mark {
  background: color-mix(in srgb, var(--dark) 92%, #000);
  color: #fff;
}
.button--secondary,
.button--ghost {
  color: color-mix(in srgb, var(--dark) 88%, #000);
  background: color-mix(in srgb, var(--surface) 74%, transparent);
}
.v6-proof strong,
.v6-safety span,
.v6-stat-board strong,
.how-control-panel > strong {
  color: color-mix(in srgb, var(--dark) 86%, #000);
}
.v6-chip-row span,
.how-chip {
  color: color-mix(in srgb, var(--dark) 88%, #000);
}
.page-hero--shape-2,
.v6-home--3,
.how-rail-visual {
  background: linear-gradient(135deg, color-mix(in srgb, var(--dark) 94%, #000), color-mix(in srgb, var(--accent-2) 34%, var(--dark)));
  color: #fff;
}
.page-hero--shape-2 *,
.v6-home--3 *,
.how-rail-visual * {
  color: inherit;
}
.page-hero--shape-2 p,
.v6-home--3 .hero__lead,
.how-rail-visual small {
  color: rgba(255,255,255,0.84);
}
.page-hero--shape-2 .eyebrow,
.v6-home--3 .eyebrow,
.how-rail-visual .eyebrow {
  color: #fff;
}
.page-hero--shape-2 .button--secondary,
.page-hero--shape-2 .button--ghost,
.v6-home--3 .button--secondary,
.v6-home--3 .button--ghost {
  color: #fff;
  border-color: rgba(255,255,255,0.34);
  background: rgba(255,255,255,0.12);
}
.v6-home--3 .button--primary {
  color: color-mix(in srgb, var(--dark) 90%, #000);
  background: #fff;
}
.variant-3 .site-header {
  background: rgba(8,12,18,0.9);
  color: #fff;
}
.variant-3 .v6-home {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: #fff;
}
.variant-3 .v6-home .hero__lead {
  color: rgba(255,255,255,0.78);
}
.variant-3 .brand strong,
.variant-3 .main-nav a {
  color: rgba(255,255,255,0.84);
}
.variant-3 .main-nav a:hover,
.variant-3 .main-nav a.is-active {
  color: #fff;
  background: rgba(255,255,255,0.14);
}
.variant-3 .nav-toggle {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.22);
}
.variant-3 .nav-toggle span {
  background: #fff;
}
.variant-3 .eyebrow,
.variant-3 .game-card__tag,
.variant-3 .how-timeline li > span,
.variant-3 .how-card-grid small,
.variant-3 .how-rail-steps span,
.variant-3 .how-dashboard-grid span,
.variant-3 .v6-legal--numbered section h3::before {
  color: #fff;
}
.variant-3 .button--secondary,
.variant-3 .button--ghost {
  color: #fff;
  border-color: rgba(255,255,255,0.34);
  background: rgba(255,255,255,0.1);
}
.variant-3 .button--primary {
  color: color-mix(in srgb, var(--dark) 88%, #000);
  background: #fff;
}
.variant-3 .button--card {
  background: #fff;
  color: color-mix(in srgb, var(--dark) 88%, #000);
}
.variant-3 .cookie-banner,
.variant-3 .age-gate__panel {
  background: #fff;
  color: #111827;
}
.variant-3 .cookie-banner p,
.variant-3 .age-gate__panel p {
  color: #4b5563;
}
.variant-3 .cookie-banner .button--ghost,
.variant-3 .age-gate__panel .button--ghost,
.variant-3 .cookie-banner .button--secondary,
.variant-3 .age-gate__panel .button--secondary {
  color: #111827;
  background: #fff;
  border-color: #d1d5db;
}
.variant-3 .cookie-banner .button--primary,
.variant-3 .age-gate__panel .button--primary {
  color: #fff;
  background: #111827;
}
.variant-3 .contact-form label,
.variant-3 .v6-contact-form label {
  color: rgba(255,255,255,0.86);
}
.variant-3 .contact-form input,
.variant-3 .contact-form textarea,
.variant-3 .contact-form select {
  color: #111827;
  background: #fff;
}
.variant-3 .v6-proof strong,
.variant-3 .v6-safety span,
.variant-3 .v6-stat-board strong,
.variant-3 .how-control-panel > strong,
.variant-3 .v6-chip-row span,
.variant-3 .how-chip {
  color: #fff;
}
.variant-3 .how-dashboard-head > strong,
.variant-3 .v6-access > strong {
  color: color-mix(in srgb, var(--dark) 88%, #000);
}
.variant-3 .v6-chip-row span,
.variant-3 .how-chip {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.24);
}
@media (max-width: 980px) {
  .v6-home,
  .v6-home--1,
  .v6-home--4,
  .v6-curation,
  .v6-page-layout--0,
  .v6-page-layout--2,
  .v6-page-layout--3,
  .v6-about,
  .v6-contact { grid-template-columns: 1fr; }
  .v6-page-layout--2 .v6-side-note { order: 0; }
  .v6-proof,
  .v6-safety,
  .v6-legal { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .v6-home__visual { min-height: 280px; }
  .v6-proof,
  .v6-safety,
  .v6-chip-row,
  .v6-legal,
  .v6-contact-form,
  .v6-games-page .game-grid--ready { grid-template-columns: 1fr; }
  .v6-contact-form label:nth-child(4),
  .v6-contact-form button,
  .v6-contact-form .form-status { grid-column: auto; }
}
