:root {
  --bg: #07090f;
  --surface: #11151f;
  --surface-2: #191f2c;
  --text: #f8fbff;
  --muted: #a8b2c2;
  --lime: #c8ff36;
  --violet: #7c5cff;
  --cyan: #00e5ff;
  --border: #2c3546;
  --display: "Space Grotesk", Arial, sans-serif;
  --body: Inter, Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: hidden;
  color: var(--text);
  background: var(--bg);
  font-family: var(--body);
  line-height: 1.5;
}
button, a { font: inherit; }
a { color: inherit; text-decoration: none; }
button { color: inherit; }
.container { width: min(calc(100% - 40px), 1240px); margin-inline: auto; }
.section { padding-block: clamp(72px, 10vw, 140px); }

.ambient {
  position: fixed;
  z-index: -1;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  filter: blur(130px);
  opacity: .13;
  pointer-events: none;
}
.ambient-one { top: -200px; right: -160px; background: var(--violet); }
.ambient-two { top: 520px; left: -280px; background: var(--cyan); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  width: 100%;
  min-height: 80px;
  padding-inline: max(20px, calc((100% - 1360px) / 2));
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  background: rgba(7, 9, 15, .82);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 700; letter-spacing: -.03em; }
.brand-mark {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: #071006;
  background: var(--lime);
  box-shadow: 0 0 24px rgba(200,255,54,.25);
}
nav { display: flex; gap: 34px; color: var(--muted); font-size: 14px; font-weight: 600; }
nav a:hover { color: var(--text); }

.button {
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 0 24px;
  border: 0;
  border-radius: 999px;
  color: #071006;
  background: var(--lime);
  font-weight: 800;
  box-shadow: 0 12px 40px rgba(200,255,54,.15);
  transition: transform .2s ease, box-shadow .2s ease;
}
.button:hover { transform: translateY(-2px); box-shadow: 0 16px 48px rgba(200,255,54,.25); }
.button-small { min-height: 42px; padding-inline: 18px; font-size: 13px; }
.text-link { font-weight: 700; border-bottom: 1px solid var(--border); padding-block: 10px; }

.hero {
  min-height: 720px;
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  align-items: center;
  gap: clamp(40px, 8vw, 110px);
  padding-block: 70px;
}
.eyebrow {
  margin: 0 0 22px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.eyebrow span { width: 20px; height: 2px; background: var(--lime); box-shadow: 0 0 10px var(--lime); }
h1, h2, h3 { margin: 0; font-family: var(--display); line-height: .98; letter-spacing: -.055em; }
h1 { max-width: 720px; font-size: clamp(58px, 7.3vw, 106px); }
h1 em { color: var(--lime); font-style: normal; text-shadow: 0 0 40px rgba(200,255,54,.22); }
.hero-text { max-width: 610px; margin: 30px 0; color: var(--muted); font-size: clamp(16px, 2vw, 19px); }
.hero-actions { display: flex; align-items: center; gap: 28px; }
.hero-facts { display: flex; gap: 42px; margin: 52px 0 0; padding: 0; list-style: none; }
.hero-facts li { display: grid; }
.hero-facts strong { font-family: var(--display); font-size: 24px; }
.hero-facts span { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }

.reel-stage { min-height: 560px; position: relative; display: grid; place-items: center; }
.orbit { position: absolute; border: 1px solid var(--border); border-radius: 50%; }
.orbit-one { width: 500px; height: 500px; }
.orbit-two { width: 380px; height: 380px; border-style: dashed; animation: spin 25s linear infinite; }
.reel {
  position: relative;
  z-index: 2;
  width: min(390px, 92%);
  padding: 14px;
  border: 1px solid #364258;
  border-radius: 30px;
  background: rgba(17,21,31,.93);
  box-shadow: 0 35px 100px rgba(0,0,0,.48), 0 0 80px rgba(124,92,255,.12);
  transform: rotate(4deg);
}
.reel-top, .reel-bottom { display: flex; justify-content: space-between; align-items: center; padding: 10px 8px 18px; color: var(--muted); font-size: 10px; font-weight: 800; letter-spacing: .14em; }
.signal { width: 8px; height: 8px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 14px var(--lime); }
.reel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; }
.tile { aspect-ratio: 1; display: grid; place-items: center; border-radius: 17px; color: #fff; font-family: var(--display); font-size: 35px; font-weight: 700; }
.tile.lime { color: #142000; background: linear-gradient(135deg, #e5ff80, var(--lime)); box-shadow: inset 0 0 25px rgba(255,255,255,.35); }
.tile.violet { background: linear-gradient(135deg, #9f8aff, #5a36dd); }
.tile.cyan { color: #001b20; background: linear-gradient(135deg, #74f5ff, var(--cyan)); }
.reel-bottom { padding: 18px 8px 8px; }
.reel-bottom strong { color: var(--text); font-family: var(--display); font-size: 16px; }

.marquee { overflow: hidden; padding: 16px 0; color: #071006; background: var(--lime); transform: rotate(-1deg) scale(1.02); }
.marquee div { width: max-content; display: flex; gap: 26px; align-items: center; font-family: var(--display); font-size: 13px; font-weight: 700; letter-spacing: .07em; animation: marquee 22s linear infinite; }

.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 30px; margin-bottom: 38px; }
h2 { max-width: 760px; font-size: clamp(42px, 5.3vw, 76px); }
.filters { display: flex; gap: 8px; padding: 5px; border: 1px solid var(--border); border-radius: 999px; }
.filter { min-height: 40px; padding: 0 17px; border: 0; border-radius: 999px; background: transparent; color: var(--muted); cursor: pointer; font-weight: 700; }
.filter.active { background: var(--surface-2); color: var(--text); }
.game-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.game-card { overflow: hidden; border: 1px solid var(--border); border-radius: 22px; background: var(--surface); transition: transform .2s ease, border-color .2s ease; }
.game-card:hover { transform: translateY(-5px); border-color: #55647e; }
.game-art { aspect-ratio: 4/5; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; }
.game-art span { font-family: var(--display); font-size: clamp(54px, 7vw, 92px); line-height: 1; }
.game-art b { font-size: 11px; letter-spacing: .25em; }
.art-one { color: #162000; background: radial-gradient(circle at 50% 35%, #f0ffac, var(--lime) 40%, #4e7112); }
.art-two { background: radial-gradient(circle at 30% 20%, #ccbdff, var(--violet) 42%, #2d155e); }
.art-three { color: #001c20; background: radial-gradient(circle at 70% 25%, #a8faff, var(--cyan) 40%, #07546c); }
.art-four { background: radial-gradient(circle at 40% 30%, #ffb9ef, #c931a8 42%, #41105c); }
.game-info { display: flex; align-items: center; justify-content: space-between; padding: 18px; }
.game-info h3 { font-size: 17px; letter-spacing: -.02em; }
.game-info p { margin: 5px 0 0; color: var(--muted); font-size: 11px; }
.game-info button { width: 40px; height: 40px; border: 1px solid var(--border); border-radius: 50%; background: var(--surface-2); cursor: pointer; }

.reward-section { background: linear-gradient(135deg, #11151f 0%, #151129 60%, #11151f 100%); border-block: 1px solid var(--border); }
.reward-panel { display: grid; grid-template-columns: 1fr 340px; align-items: center; gap: 80px; }
.reward-card { padding: 34px; border: 1px solid rgba(200,255,54,.3); border-radius: 26px; background: rgba(7,9,15,.55); box-shadow: 0 25px 80px rgba(0,0,0,.28); }
.reward-card p { color: var(--lime); font-size: 10px; font-weight: 800; letter-spacing: .16em; }
.reward-card strong { display: block; font-family: var(--display); font-size: 82px; line-height: 1; letter-spacing: -.07em; }
.reward-card > span { display: block; margin: 10px 0 25px; color: var(--muted); }
.reward-card .button { width: 100%; }

.about { display: grid; grid-template-columns: 140px 1.1fr .9fr; gap: 55px; align-items: start; }
.about-number { color: var(--lime); font-family: var(--display); font-size: 96px; font-weight: 700; line-height: .8; opacity: .2; }
.about h2 { font-size: clamp(38px, 5vw, 68px); }
.about-copy { color: var(--muted); font-size: 16px; }
.about-copy p:first-child { margin-top: 0; }

.footer { border-top: 1px solid var(--border); }
.footer-inner { min-height: 130px; display: flex; align-items: center; justify-content: space-between; gap: 30px; color: var(--muted); font-size: 12px; }
.footer .brand { color: var(--text); }

@keyframes spin { to { transform: rotate(360deg); } }
@keyframes marquee { to { transform: translateX(-50%); } }

@media (max-width: 980px) {
  nav { display: none; }
  .hero { grid-template-columns: 1fr; padding-top: 100px; }
  .hero-copy { text-align: center; }
  .hero .eyebrow, .hero-actions, .hero-facts { justify-content: center; }
  .hero-text { margin-inline: auto; }
  .reel-stage { min-height: 500px; }
  .game-grid { grid-template-columns: repeat(2, 1fr); }
  .reward-panel { grid-template-columns: 1fr; }
  .reward-card { max-width: 440px; }
  .about { grid-template-columns: 80px 1fr; }
  .about-copy { grid-column: 2; }
}

@media (max-width: 620px) {
  .container { width: min(calc(100% - 32px), 1240px); }
  .site-header { padding-inline: 16px; }
  .site-header .button { display: none; }
  .hero { min-height: 0; padding-block: 80px 40px; }
  h1 { font-size: clamp(52px, 17vw, 76px); }
  .hero-actions { flex-direction: column; gap: 10px; }
  .hero-actions .button { width: 100%; }
  .hero-facts { gap: 20px; justify-content: space-between; }
  .hero-facts span { font-size: 9px; }
  .reel-stage { min-height: 420px; }
  .orbit-one { width: 390px; height: 390px; }
  .orbit-two { width: 300px; height: 300px; }
  .section-heading { align-items: start; flex-direction: column; }
  .filters { width: 100%; }
  .filter { flex: 1; }
  .game-grid { grid-template-columns: 1fr; }
  .game-art { aspect-ratio: 1.15; }
  .reward-card strong { font-size: 68px; }
  .about { grid-template-columns: 1fr; gap: 30px; }
  .about-number { font-size: 70px; }
  .about-copy { grid-column: auto; }
  .footer-inner { padding-block: 35px; flex-direction: column; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation: none !important; transition: none !important; }
}
