/* ft-hidden-guard v1 */
[hidden]{display:none!important;}
*, *::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; }

:root {
  --space-xs: 10px;
  --space-sm: 13px;
  --space-md: 24px;
  --space-lg: 50px;
  --space-xl: 73px;
  --card-padding-y: 24px;
  --card-padding-x: 21px;
  --card-gap: 18px;
  --card-radius: 18px;
  --card-border-width: 2px;
  --card-min-height: 324px;
  --card-min-col-width: 301px;
  --btn-padding-y: 11px;
  --btn-padding-x: 21px;
  --btn-radius: 17px;
  --btn-gap-from-text: 14px;
  --grid-gap: 26px;
  --lh-heading: 1.24;
  --lh-body: 1.68;
  --ls-heading: 0.000em;

  --cobalt-deep: #050f2e;
  --cobalt: #0a1b4a;
  --cobalt-soft: #122463;
  --cream: #fff6e6;
  --cream-dim: #f3e6cf;
  --tangerine: #ff7a1a;
  --tangerine-hot: #ff9436;
  --bulb: #ffd27a;
  --steel: #2a3559;
}

body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--cobalt-deep);
  color: var(--cream);
  line-height: var(--lh-body);
}

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

h1, h2, h3, h4 {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-heading);
  color: var(--cream);
  margin: 0 0 var(--space-md) 0;
  font-weight: 800;
}
h1 { font-size: clamp(2rem, 5vw, 3.6rem); }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.4rem); }
h3 { font-size: 1.25rem; }
p { margin: 0 0 var(--space-md) 0; }
a { color: var(--tangerine-hot); text-decoration: underline; text-underline-offset: 3px; }
a:hover { color: var(--bulb); }

/* Header */
.site-header {
  background: linear-gradient(180deg, rgba(5,15,46,0.95), rgba(5,15,46,0.78));
  border-bottom: 2px solid var(--tangerine);
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(6px);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: var(--space-sm) 0; gap: var(--space-md); flex-wrap: wrap; }
.brand { color: var(--cream); text-decoration: none; font-weight: 800; font-size: 1.1rem; display: inline-flex; align-items: center; gap: var(--space-xs); }
.brand-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--tangerine); box-shadow: 0 0 12px var(--tangerine), 0 0 24px rgba(255,122,26,0.5); display: inline-block; }
.nav { display: flex; gap: var(--space-md); flex-wrap: wrap; }
.nav a { color: var(--cream); text-decoration: none; font-weight: 600; }
.nav a:hover { color: var(--tangerine-hot); }

/* Hero */
.hero {
  position: relative;
  padding: var(--space-xl) 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,122,26,0.18), transparent 60%),
    radial-gradient(ellipse at 20% 100%, rgba(255,148,54,0.10), transparent 50%),
    linear-gradient(180deg, var(--cobalt) 0%, var(--cobalt-deep) 100%);
  overflow: hidden;
  text-align: center;
}
.hero::after {
  content:''; position: absolute; left:0; right:0; bottom:0; height: 30%;
  background: radial-gradient(ellipse at 50% 100%, rgba(255,210,122,0.12), transparent 70%);
  pointer-events: none;
}
.hero-inner { position: relative; z-index: 2; }
.marquee-badge {
  position: relative;
  width: min(420px, 80%);
  margin: 0 auto var(--space-lg) auto;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--cobalt-soft), var(--steel));
  border-radius: 24px;
  border: 3px solid var(--tangerine);
  box-shadow: 0 0 40px rgba(255,122,26,0.45), inset 0 0 30px rgba(0,0,0,0.4);
  display: grid; place-items: center;
}
.marquee-label { font-size: clamp(3rem, 8vw, 5rem); font-weight: 900; color: var(--cream); letter-spacing: 0.05em; text-shadow: 0 0 18px rgba(255,210,122,0.6); }
.bulbs { position: absolute; display: flex; gap: 12px; }
.bulbs-top, .bulbs-bottom { left: 18px; right: 18px; justify-content: space-between; }
.bulbs-top { top: -7px; }
.bulbs-bottom { bottom: -7px; }
.bulbs-left, .bulbs-right { top: 18px; bottom: 18px; flex-direction: column; justify-content: space-between; }
.bulbs-left { left: -7px; }
.bulbs-right { right: -7px; }
.bulbs::before, .bulbs::after,
.bulbs { }
.bulbs-top::before, .bulbs-top::after, .bulbs-bottom::before, .bulbs-bottom::after,
.bulbs-left::before, .bulbs-left::after, .bulbs-right::before, .bulbs-right::after {
  content:''; width:14px; height:14px; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, #fff, var(--bulb) 60%, var(--tangerine));
  box-shadow: 0 0 10px var(--bulb), 0 0 18px rgba(255,122,26,0.6);
}
.bulbs { background-image:
  radial-gradient(circle, var(--bulb) 4px, transparent 5px);
  background-size: 26px 14px;
  background-repeat: repeat-x;
  background-position: center;
}
.bulbs-left, .bulbs-right { background-size: 14px 26px; background-repeat: repeat-y; }

.lede { font-size: 1.15rem; max-width: 640px; margin: 0 auto var(--space-md); color: var(--cream-dim); }
.age-band {
  display: inline-block;
  margin: var(--space-sm) 0 var(--space-md);
  padding: var(--space-xs) var(--space-md);
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--tangerine);
  border-radius: 999px;
  color: var(--cream);
  font-size: 0.92rem;
}
.hero-ctas { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; margin-top: var(--btn-gap-from-text); }

/* Buttons */
.btn {
  display: inline-block;
  padding: var(--btn-padding-y) var(--btn-padding-x);
  border-radius: var(--btn-radius);
  font-weight: 700;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
  font-size: 1rem;
}
.btn-primary { background: var(--tangerine); color: #1a0a00; border-color: var(--tangerine); box-shadow: 0 0 0 rgba(255,122,26,0); }
.btn-primary:hover { background: var(--tangerine-hot); transform: translateY(-2px); box-shadow: 0 8px 22px rgba(255,122,26,0.45); color:#1a0a00; }
.btn-ghost { background: transparent; color: var(--cream); border-color: var(--cream-dim); }
.btn-ghost:hover { background: rgba(255,246,230,0.08); color: var(--bulb); }

/* Sections */
.section { padding: var(--space-xl) 0; }
.section-alt { background: linear-gradient(180deg, var(--cobalt-deep), var(--cobalt) 50%, var(--cobalt-deep)); }
.sub { color: var(--cream-dim); max-width: 640px; margin-bottom: var(--space-lg); }

/* Grids */
.games-grid, .rooms-grid, .feat-grid {
  display: grid;
  gap: var(--grid-gap);
  grid-template-columns: repeat(auto-fit, minmax(var(--card-min-col-width), 1fr));
}
.game-card, .room-card, .feat {
  background: linear-gradient(180deg, var(--cobalt-soft), var(--cobalt));
  border: var(--card-border-width) solid var(--tangerine);
  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: 0 0 0 rgba(255,122,26,0);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.game-card:hover, .room-card:hover, .feat:hover { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(255,122,26,0.22); }
.feat { min-height: 180px; }
.room-tag { display: inline-block; align-self: flex-start; padding: 4px 12px; background: var(--tangerine); color: #1a0a00; border-radius: 999px; font-weight: 800; font-size: 0.8rem; letter-spacing: 0.08em; text-transform: uppercase; }
.room-feat { list-style: none; padding: 0; margin: 0 0 var(--space-md); display: flex; flex-direction: column; gap: 6px; color: var(--cream-dim); }
.room-feat li::before { content:'●'; color: var(--tangerine); margin-right: 8px; }
.room-card .btn { margin-top: auto; align-self: flex-start; }

/* FAQ */
details {
  background: var(--cobalt-soft);
  border: 2px solid var(--steel);
  border-radius: var(--card-radius);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  transition: border-color 0.15s ease;
}
details[open] { border-color: var(--tangerine); }
summary { cursor: pointer; font-weight: 700; color: var(--cream); list-style: none; }
summary::-webkit-details-marker { display: none; }
summary::after { content:'+'; float: right; color: var(--tangerine); font-size: 1.4rem; line-height: 1; }
details[open] summary::after { content:'−'; }
details p { margin-top: var(--space-sm); color: var(--cream-dim); }

/* Footer */
.site-footer { background: #02091e; border-top: 2px solid var(--tangerine); padding: var(--space-xl) 0 var(--space-md); margin-top: var(--space-xl); }
.foot-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--grid-gap); margin-bottom: var(--space-lg); }
.foot-cols h4 { color: var(--tangerine-hot); margin-bottom: var(--space-sm); font-size: 1rem; letter-spacing: 0.04em; text-transform: uppercase; }
.foot-links { list-style: none; padding: 0; margin: 0; }
.foot-links li { margin-bottom: 6px; }
.foot-links a { color: var(--cream); text-decoration: none; }
.foot-links a:hover { color: var(--tangerine-hot); }
.logo-row { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin-bottom: var(--space-md); background: rgba(255,246,230,0.92); padding: var(--space-sm); border-radius: 12px; }
.logo-row img { width: 80px; height: 40px; object-fit: contain; }
.statutory { color: var(--cream-dim); font-size: 0.92rem; border-top: 1px solid var(--steel); padding-top: var(--space-md); }
.copy { color: var(--cream-dim); font-size: 0.88rem; }

/* Age gate */
.age-gate { position: fixed; inset: 0; background: rgba(2,9,30,0.92); z-index: 1000; align-items: center; justify-content: center; padding: var(--space-md); }
.age-gate[hidden] { display: none !important; }
.age-gate:not([hidden]) { display: flex; }
.age-card { background: var(--cobalt); border: 3px solid var(--tangerine); border-radius: var(--card-radius); padding: var(--space-lg); max-width: 460px; width: 100%; text-align: center; box-shadow: 0 0 50px rgba(255,122,26,0.4); }
.age-buttons { display: flex; gap: var(--space-md); justify-content: center; flex-wrap: wrap; margin-top: var(--space-md); }

/* Cookie banner */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; background: var(--cobalt); border-top: 2px solid var(--tangerine); z-index: 900; padding: var(--space-md) 0; box-shadow: 0 -10px 30px rgba(0,0,0,0.5); }
.cookie-banner[hidden] { display: none !important; }
.cookie-banner:not([hidden]) { display: block; }
.cookie-inner { display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; justify-content: space-between; }
.cookie-inner p { margin: 0; flex: 1 1 320px; color: var(--cream-dim); }
.cookie-buttons { display: flex; gap: var(--space-sm); flex-wrap: wrap; }

/* Under-18 */
.u18 { background: var(--cobalt-deep); color: var(--cream); }
.u18 main { max-width: 640px; padding-top: var(--space-xl); }

/* Game cards */
.game-card iframe { border-radius: 12px; background: var(--cobalt-deep); }

@media (max-width: 640px) {
  .hero { padding: var(--space-lg) 0; }
  .section { padding: var(--space-lg) 0; }
}
