:root {
  --bg: #07130f;
  --panel: #0f241b;
  --panel-2: #132d22;
  --text: #f4fff9;
  --muted: #9bb7aa;
  --line: rgba(255, 255, 255, .1);
  --green: #35f28b;
  --green-2: #12b96b;
  --gold: #ffd166;
  --red: #ff6b6b;
  --shadow: 0 24px 70px rgba(0, 0, 0, .35);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(53, 242, 139, .18), transparent 34rem),
    radial-gradient(circle at top right, rgba(255, 209, 102, .13), transparent 30rem),
    var(--bg);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
}

a { color: inherit; text-decoration: none; }

.hero { padding: 24px clamp(18px, 4vw, 64px) 72px; }
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  max-width: 1180px;
  margin: 0 auto 70px;
}
.brand { display: flex; align-items: center; gap: 10px; font-weight: 850; font-size: 22px; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 14px; background: linear-gradient(135deg, var(--green), var(--green-2)); box-shadow: 0 10px 30px rgba(53, 242, 139, .25); }
.nav-links { display: flex; gap: 20px; color: var(--muted); font-size: 14px; }
.nav-links a:hover { color: var(--text); }

.hero-grid {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) 380px;
  gap: 34px;
  align-items: center;
}
.eyebrow { color: var(--green); text-transform: uppercase; letter-spacing: .16em; font-weight: 800; font-size: 12px; margin: 0 0 12px; }
h1 { font-size: clamp(42px, 7vw, 76px); line-height: .95; margin: 0 0 24px; letter-spacing: -0.06em; }
h2 { font-size: clamp(28px, 4vw, 44px); margin: 0; letter-spacing: -0.04em; }
.lead { color: #c7dbd1; font-size: clamp(17px, 2vw, 21px); line-height: 1.75; max-width: 760px; margin: 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.button { padding: 14px 18px; border-radius: 999px; font-weight: 800; border: 1px solid var(--line); }
.button.primary { background: linear-gradient(135deg, var(--green), var(--green-2)); color: #04140c; }
.button.ghost { background: rgba(255,255,255,.05); color: var(--text); }
.glass { background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.035)); border: 1px solid var(--line); box-shadow: var(--shadow); backdrop-filter: blur(16px); }
.score-card { border-radius: 32px; padding: 28px; min-height: 310px; display: flex; flex-direction: column; justify-content: center; }
.card-label { color: var(--muted); margin: 0 0 10px; }
.score-card strong { font-size: 74px; line-height: 1; color: var(--green); letter-spacing: -.06em; }
.score-card > span { color: #c7dbd1; margin-top: 8px; }
.mini-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 30px; }
.mini-stats div { background: rgba(0,0,0,.22); border: 1px solid var(--line); border-radius: 18px; padding: 14px; }
.mini-stats b { display: block; font-size: 22px; }
.mini-stats small { color: var(--muted); }

.section { max-width: 1180px; margin: 0 auto; padding: 46px clamp(18px, 4vw, 0px); }
.section.compact { padding-top: 6px; }
.section-title { margin-bottom: 24px; }
.section-title.wide { display: flex; justify-content: space-between; align-items: end; gap: 24px; }
.muted { color: var(--muted); margin: 0; max-width: 520px; line-height: 1.7; }
.chips { display: flex; flex-wrap: wrap; gap: 12px; }
.chip { border: 1px solid rgba(53,242,139,.28); background: rgba(53,242,139,.08); color: #dfffee; border-radius: 999px; padding: 11px 16px; font-weight: 750; }

.match-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.match-card { background: linear-gradient(180deg, var(--panel), rgba(15,36,27,.74)); border: 1px solid var(--line); border-radius: 28px; padding: 22px; box-shadow: var(--shadow); }
.match-top { display: flex; justify-content: space-between; gap: 14px; color: var(--muted); font-size: 13px; margin-bottom: 18px; }
.teams { font-size: 26px; font-weight: 900; letter-spacing: -.04em; margin-bottom: 8px; }
.venue { color: var(--muted); font-size: 13px; margin-bottom: 20px; }
.probs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 16px 0; }
.prob { background: rgba(255,255,255,.055); border: 1px solid var(--line); border-radius: 16px; padding: 12px; }
.prob small { color: var(--muted); display: block; margin-bottom: 4px; }
.prob b { color: var(--green); font-size: 20px; }
.pick { border: 1px solid rgba(53,242,139,.25); background: rgba(53,242,139,.075); border-radius: 18px; padding: 14px; margin: 16px 0; }
.pick b { color: var(--green); }
.prediction-lines { display: grid; gap: 8px; margin: 12px 0 4px; }
.prediction-lines span { border: 1px solid rgba(255,255,255,.11); background: rgba(0,0,0,.18); border-radius: 12px; padding: 9px 10px; color: #dfffee; font-size: 13px; font-weight: 750; }
.block { margin-top: 18px; }
.block h3 { margin: 0 0 10px; font-size: 15px; color: #dfffee; }
.list { margin: 0; padding-left: 18px; color: #bfd5ca; line-height: 1.7; font-size: 14px; }
.star-list { display: flex; flex-wrap: wrap; gap: 8px; }
.star { background: rgba(255,209,102,.11); border: 1px solid rgba(255,209,102,.22); color: #ffe6a3; border-radius: 999px; padding: 7px 10px; font-size: 13px; font-weight: 750; }

.table-wrap { border-radius: 28px; overflow: auto; }
table { width: 100%; border-collapse: collapse; min-width: 880px; }
th, td { padding: 16px; text-align: left; border-bottom: 1px solid var(--line); font-size: 14px; }
th { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
td { color: #dbece4; }
.badge { display: inline-flex; align-items: center; gap: 6px; border-radius: 999px; padding: 7px 10px; font-weight: 850; }
.badge.success { background: rgba(53,242,139,.13); color: var(--green); }
.badge.failed { background: rgba(255,107,107,.12); color: var(--red); }

.footer { max-width: 1180px; margin: 24px auto 0; padding: 34px clamp(18px, 4vw, 0px) 50px; color: var(--muted); display: flex; justify-content: space-between; gap: 16px; border-top: 1px solid var(--line); }

@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; }
  .match-grid { grid-template-columns: 1fr; }
  .score-card { min-height: auto; }
}
@media (max-width: 640px) {
  .nav { align-items: flex-start; flex-direction: column; margin-bottom: 46px; }
  .nav-links { flex-wrap: wrap; }
  .section-title.wide { align-items: flex-start; flex-direction: column; }
  .footer { flex-direction: column; }
  .score-card strong { font-size: 58px; }
}
