:root {
  --bg: #121515;
  --panel: rgba(0, 0, 0, .6);
  --panel-2: #171a1a;
  --text: #fff;
  --muted: #b3bec1;
  --faint: #849194;
  --brand: #2cd97d;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  background: #0e1010;
  color: var(--text);
  font-family: Inter, Arial, Helvetica, sans-serif;
}

button, a { font: inherit; }
button { cursor: pointer; border: 0; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.site-shell { overflow: hidden; background: var(--bg); }
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(23, 26, 26, .3);
  backdrop-filter: blur(16px);
}
.topbar-inner {
  max-width: 1260px;
  margin: 0 auto;
  min-height: 64px;
  padding: 10px 24px;
  display: flex;
  align-items: center;
  gap: 64px;
}
.brand { width: 132px; flex: 0 0 auto; }
.nav { display: flex; gap: 48px; color: var(--text); font-weight: 800; }
.nav a:hover { color: var(--brand); }

.hero {
  position: relative;
  min-height: 0;
  margin-top: -64px;
  overflow: hidden;
  isolation: isolate;
}
.hero-bg {
  position: absolute;
  inset: 0;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  z-index: -1;
}
.hero-bg.desktop { background-image: url("assets/hero-pc.0920a70a.png"); }
.hero-bg.mobile { display: none; background-image: url("assets/hero-bg.9a304051.png"); }
.hero-content {
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  padding: 274px 16px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.host {
  margin: 0 0 4px;
  color: var(--brand);
  font-size: 28px;
  line-height: 1.2;
  font-weight: 900;
}
h1 {
  margin: 0;
  font-size: clamp(54px, 8vw, 108px);
  line-height: .95;
  font-family: Impact, Haettenschweiler, "Arial Black", sans-serif;
  letter-spacing: 0;
  font-weight: 900;
  text-transform: uppercase;
}
h1 span { display: inline; }
.hero-copy {
  margin: 10px 0 0;
  max-width: 800px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.35;
  font-weight: 800;
}
.primary-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(387px, 100%);
  height: 64px;
  margin-top: 28px;
  border-radius: 12px;
  background: var(--brand);
  color: #062013;
  font-size: 24px;
  font-weight: 900;
  box-shadow: 0 18px 40px rgba(44, 217, 125, .22);
  transition: transform .18s ease, filter .18s ease;
}
.primary-btn:hover { transform: translateY(-1px); filter: brightness(1.06); }
.primary-btn.compact { width: auto; height: 52px; padding: 0 22px; font-size: 17px; }

.stage-showcase {
  width: 100%;
  margin-top: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
}
.stage-card {
  position: relative;
  border: 1px solid rgba(255,255,255,.1);
  background: var(--panel);
  backdrop-filter: blur(18px);
  border-radius: 12px;
  overflow: hidden;
  text-align: left;
}
.stage-card.small {
  width: 262px;
  min-height: 128px;
  padding: 20px;
}
.stage-card.featured {
  width: 374px;
  min-height: 192px;
  padding: 28px;
  background:
    radial-gradient(circle at 70% 35%, rgba(44, 217, 125, .2), transparent 36%),
    rgba(0, 0, 0, .68);
}
.stage-card span { color: #ced4d5; font-size: 13px; font-weight: 800; }
.stage-card h3 { margin: 8px 0 10px; font-size: 18px; line-height: 1.2; }
.stage-card strong { color: var(--brand); font-size: 24px; font-weight: 1000; }
.stage-card p { margin: 8px 0 0; color: var(--muted); font-size: 13px; line-height: 1.35; font-weight: 700; }

.stats-band { background: var(--panel-2); }
.stats {
  max-width: 1260px;
  min-height: 90px;
  margin: 0 auto;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0;
  padding: 16px 24px;
}
.stats div {
  width: 126px;
  min-height: 58px;
  display: grid;
  place-items: center;
}
.stats strong {
  color: var(--brand);
  font-size: 32px;
  line-height: .9;
  font-family: Impact, Haettenschweiler, "Arial Black", sans-serif;
}
.stats span { color: var(--muted); font-size: 14px; font-weight: 700; text-align: center; }

.content {
  max-width: 1260px;
  margin: 0 auto;
  padding: 72px 16px 80px;
  display: grid;
  gap: 72px;
}
.section-heading {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
}
.section-heading img { width: 40px; height: 40px; object-fit: contain; }
.section-heading h2 { margin: 0; font-size: 32px; line-height: 1.2; }
.section-heading span { color: var(--faint); font-size: 20px; font-weight: 700; }

.timeline {
  display: flex;
  justify-content: center;
  padding: 0 0 8px;
  overflow-x: auto;
}
.phase {
  position: relative;
  display: block;
  width: 275px;
  aspect-ratio: 55 / 32;
  margin-left: -40px;
  flex: 0 0 auto;
  background: transparent;
  color: var(--text);
  border: 0;
  cursor: pointer;
}
.phase:first-child { margin-left: 0; }
.phase-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: opacity .2s ease;
}
.phase .selected { opacity: 0; }
.phase.active .selected { opacity: 1; }
.phase.active .default { opacity: 0; }
.phase > span {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  font-size: 18px;
  font-weight: 900;
}
.phase span img { width: 60px; height: 60px; object-fit: contain; }
.phase small { color: var(--muted); font-size: 16px; font-weight: 700; }

.leaderboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.leaderboard-grid article,
.table-card {
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, #1d2222 0%, #171a1a 100%);
  overflow: hidden;
}
.leaderboard-grid article { padding: 22px; }
.leaderboard-grid span {
  color: var(--brand);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}
.leaderboard-grid h3 { margin: 8px 0 18px; min-height: 48px; font-size: 20px; line-height: 1.2; }
dl { margin: 0; display: grid; gap: 10px; }
dl div {
  padding: 12px;
  border-radius: 8px;
  background: rgba(255,255,255,.045);
}
dt { color: var(--faint); font-size: 12px; font-weight: 800; }
dd { margin: 4px 0 0; color: var(--text); font-size: 13px; line-height: 1.3; font-weight: 800; }
.stage-note,
.table-note {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
  font-weight: 700;
}

.tables {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.table-card { padding: 18px; }
.table-card h3 { margin: 0 0 14px; color: var(--brand); font-size: 20px; }
.prize-row {
  display: grid;
  grid-template-columns: 1fr 1fr .8fr 1fr;
  gap: 10px;
  min-height: 40px;
  align-items: center;
  padding: 0 12px;
  border-radius: 8px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}
.prize-row:nth-child(odd) { background: rgba(255,255,255,.045); }
.prize-row.head { color: var(--text); background: rgba(44,217,125,.14); text-transform: uppercase; font-size: 12px; }
.prize-row span:last-child { color: var(--brand); }
.prize-row.total {
  margin-top: 8px;
  color: var(--text);
  background: rgba(44,217,125,.18);
}

.coverage-grid,
.opt-steps {
  display: grid;
  gap: 16px;
}
.coverage-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.opt-steps {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 16px;
}
.coverage-grid article,
.opt-steps article {
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, #1d2222 0%, #171a1a 100%);
  padding: 22px;
}
.coverage-grid span,
.opt-steps span {
  display: block;
  color: var(--brand);
  font-size: 15px;
  font-weight: 900;
}
.coverage-grid p,
.opt-steps p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
  font-weight: 700;
}
.opt-steps strong {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin-bottom: 14px;
  border-radius: 50%;
  background: rgba(44,217,125,.18);
  color: var(--brand);
  font-size: 18px;
}

.terms-section {
  scroll-margin-top: 82px;
}
.terms-intro {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}
.terms-intro article,
.terms-grid article {
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, #1d2222 0%, #171a1a 100%);
  padding: 22px;
}
.terms-intro span {
  display: block;
  color: var(--brand);
  font-size: 15px;
  font-weight: 900;
  text-transform: uppercase;
}
.terms-intro p {
  margin: 10px 0 0;
  color: var(--muted);
  line-height: 1.5;
  font-weight: 700;
}
.terms-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.terms-grid h3 {
  margin: 0 0 12px;
  color: var(--brand);
  font-size: 18px;
}
.terms-grid ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.48;
  font-weight: 700;
}
.terms-grid li + li {
  margin-top: 8px;
}
.currency-table {
  margin-top: 16px;
}
.currency-row {
  display: grid;
  grid-template-columns: 130px minmax(0, 1fr);
  gap: 14px;
  min-height: 44px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  font-weight: 800;
}
.currency-row:nth-child(odd) {
  background: rgba(255,255,255,.045);
}
.currency-row.head {
  color: var(--text);
  background: rgba(44,217,125,.14);
  text-transform: uppercase;
  font-size: 12px;
}
.currency-row span:first-child {
  color: var(--text);
}

.rules {
  position: relative;
  min-height: 360px;
  padding: 42px 48px;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(44,217,125,.08), transparent 34%),
    linear-gradient(180deg, #151919, #101313);
  border: 1px solid rgba(255,255,255,.08);
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(440px, 1.1fr);
  gap: 44px;
  align-items: center;
  overflow: hidden;
}
.rules:before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 22% 30%, rgba(44,217,125,.2), transparent 38%);
}
.rules > * { position: relative; }
.rules-copy span { color: var(--brand); text-transform: uppercase; font-weight: 900; letter-spacing: .04em; }
.rules h2 {
  margin: 10px 0 16px;
  font-family: Impact, Haettenschweiler, "Arial Black", sans-serif;
  color: var(--brand);
  font-size: clamp(44px, 5.8vw, 74px);
  line-height: .96;
  max-width: 520px;
}
.rules p { margin: 0; color: var(--muted); line-height: 1.5; max-width: 520px; font-weight: 700; }
.pool-panel {
  position: relative;
  min-height: 310px;
  padding: 30px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 75% 18%, rgba(44,217,125,.2), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018));
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  text-align: left;
  overflow: hidden;
}
.pool-panel:before {
  content: "";
  position: absolute;
  inset: 18px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  pointer-events: none;
}
.pool-panel > * { position: relative; }
.pool-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.pool-panel span {
  color: var(--brand);
  font-size: 14px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 900;
}
.pool-panel small {
  color: var(--faint);
  font-weight: 800;
}
.pool-panel strong {
  margin-top: 18px;
  color: var(--brand);
  font-family: Impact, Haettenschweiler, "Arial Black", sans-serif;
  font-size: clamp(72px, 8vw, 112px);
  line-height: .82;
  letter-spacing: 0;
  text-shadow: 0 16px 44px rgba(44,217,125,.18);
}
.pool-panel p {
  margin: 18px 0 0;
  max-width: 520px;
  color: var(--text);
  font-weight: 800;
}
.pool-breakdown {
  width: 100%;
  margin-top: 26px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.pool-breakdown div {
  padding: 14px 12px;
  border-radius: 8px;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.08);
}
.pool-breakdown b {
  display: block;
  color: var(--brand);
  font-size: 22px;
}
.pool-breakdown small {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.cta {
  min-height: 300px;
  background: linear-gradient(180deg, rgba(18,21,21,.1), rgba(18,21,21,.55)), url("assets/cta-grass-bg.ba80bc11.png") center/cover no-repeat;
  display: grid;
  place-items: center;
  text-align: center;
}
.cta p { margin: 0 0 8px; color: var(--brand); font-weight: 900; }
.cta h2 { margin: 0; font-size: clamp(36px, 6vw, 72px); font-family: Impact, Haettenschweiler, "Arial Black", sans-serif; }

footer {
  padding: 34px 24px 44px;
  background: #0e1010;
  color: var(--faint);
  text-align: center;
  font-size: 13px;
}
footer img { width: 150px; margin: 0 auto 18px; }
footer p { max-width: 920px; margin: 0 auto; line-height: 1.5; }

@media (max-width: 1040px) {
  .stage-showcase {
    max-width: 720px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .stage-card.small, .stage-card.featured { width: auto; }
  .stage-card.featured { grid-column: 1 / -1; min-height: 160px; }
  .leaderboard-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tables, .rules { grid-template-columns: 1fr; }
  .coverage-grid, .opt-steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .terms-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 700px) {
  body { width: 100%; }
  .site-shell { width: 100%; overflow-x: hidden; }
  .topbar-inner { min-height: 56px; padding: 8px 14px; }
  .brand { width: 88px; }
  .nav { display: none; }
  .hero { margin-top: -56px; }
  .hero-bg.desktop { display: none; }
  .hero-bg.mobile { display: block; background-size: cover; background-position: top center; }
  .hero-content { padding: 222px 12px 32px; }
  .host { font-size: 18px; }
  h1 {
    width: 100%;
    max-width: 340px;
    color: #000;
    overflow-wrap: anywhere;
    word-break: break-word;
    font-size: 34px;
    line-height: 1.05;
  }
  h1 span { display: block; }
  .hero-copy {
    width: 100%;
    max-width: 338px;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
    padding: 0;
  }
  .primary-btn { width: min(100%, 348px); height: 48px; font-size: 18px; border-radius: 6px; }
  .primary-btn.compact { width: 100%; }
  .stage-showcase {
    width: min(100%, 348px);
    padding: 0;
    margin-top: 24px;
    grid-template-columns: 1fr;
    justify-content: center;
    gap: 12px;
  }
  .stage-card.small { width: 100%; min-height: 144px; padding: 12px; }
  .stage-card.featured { width: 100%; padding: 20px; }
  .stage-card h3 { font-size: 14px; }
  .stage-card h3,
  .stage-card p,
  .stage-card span { overflow-wrap: anywhere; }
  .stage-card strong { font-size: 21px; }
  .stats-band { background: #151919; }
  .stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: initial;
    gap: 12px;
    padding: 22px 18px;
  }
  .stats div { width: auto; }
  .stats strong { font-size: 28px; }
  .stats span { font-size: 11px; }
  .content { width: 100%; padding: 36px 12px 56px; gap: 42px; }
  .section { width: 100%; min-width: 0; }
  .section-heading { gap: 10px; margin-bottom: 18px; align-items: flex-start; }
  .section-heading img { width: 28px; height: 28px; }
  .section-heading h2 {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 20px;
    min-width: 0;
    max-width: calc(100vw - 74px);
    overflow-wrap: anywhere;
  }
  .section-heading span { display: block; font-size: 13px; }
  .timeline {
    width: min(100%, 348px);
    margin: 0 auto;
    display: grid;
    gap: 8px;
    overflow: visible;
  }
  .phase {
    width: 100%;
    height: 64px;
    margin-left: 0;
    aspect-ratio: auto;
    border-radius: 8px;
    background: #202525;
    border: 1px solid rgba(255,255,255,.08);
    overflow: hidden;
  }
  .phase.active {
    border-color: rgba(44,217,125,.4);
    background: linear-gradient(90deg, rgba(44,217,125,.24), rgba(23,26,26,.95));
  }
  .phase-bg { display: none; }
  .phase > span {
    position: static;
    height: 100%;
    flex-direction: row;
    justify-content: flex-start;
    padding: 0 14px;
    gap: 12px;
    font-size: 15px;
    text-align: left;
  }
  .phase small {
    margin-left: auto;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.1;
    text-align: right;
    white-space: nowrap;
  }
  .phase span img { width: 38px; height: 38px; }
  .leaderboard-grid { grid-template-columns: 1fr; }
  .leaderboard-grid article { padding: 16px; border-radius: 8px; }
  .leaderboard-grid h3 { min-height: 0; font-size: 18px; }
  dl { gap: 8px; }
  dl div { padding: 10px; }
  .stage-note { font-size: 12px; }
  .tables { grid-template-columns: 1fr; }
  .table-card { overflow: visible; padding: 14px; border-radius: 8px; }
  .table-card h3 { font-size: 18px; }
  .prize-row {
    min-width: 0;
    grid-template-columns: .9fr .9fr .8fr .9fr;
    gap: 6px;
    min-height: 38px;
    padding: 8px;
    font-size: 12px;
  }
  .prize-row.head { font-size: 10px; }
  .terms-intro article,
  .terms-grid article { padding: 16px; border-radius: 8px; }
  .terms-grid ul { font-size: 13px; }
  .currency-row {
    min-width: 0;
    grid-template-columns: 1fr;
    gap: 4px;
    align-items: start;
    padding: 10px;
  }
  .currency-row span:first-child { color: var(--brand); font-weight: 900; }
  .currency-row.head { display: none; }
  .rules {
    padding: 22px 16px;
    grid-template-columns: 1fr;
    gap: 22px;
    border-radius: 8px;
  }
  .rules h2 { font-size: 42px; }
  .pool-panel { min-height: 240px; padding: 22px 16px; border-radius: 8px; }
  .pool-topline { align-items: flex-start; flex-direction: column; gap: 4px; }
  .pool-panel strong { font-size: 64px; }
  .pool-breakdown { grid-template-columns: repeat(2, 1fr); }
  .coverage-grid, .opt-steps { grid-template-columns: 1fr; }
  .terms-intro, .terms-grid { grid-template-columns: 1fr; }
  .currency-table { overflow: visible; }
  .cta { min-height: 220px; padding: 34px 12px; }
  .cta h2 { font-size: 38px; }
  footer { padding: 30px 18px 38px; }
  footer img { width: 112px; }
}
