/* =============================================================
   FIFA 2026 Predictor — STREET EDITION
   White-only · Neo-brutalism · Graffiti · Hard black borders
   ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=Bangers&family=Archivo+Black&family=Space+Grotesk:wght@400;500;600;700&family=Caveat:wght@600;700&display=swap');

:root {
  --font-display: 'Bangers', 'Archivo Black', system-ui, sans-serif;
  --font-block:   'Archivo Black', 'Bangers', system-ui, sans-serif;
  --font-body:    'Space Grotesk', system-ui, -apple-system, sans-serif;
  --font-script:  'Caveat', 'Permanent Marker', cursive;

  /* Street palette */
  --paper:       #ffffff;
  --paper-2:     #faf7ef;     /* off-white, slight cream */
  --ink:         #0a0a0a;
  --ink-soft:    #2a2a2a;
  --muted:       #6b6b6b;
  --line:        #0a0a0a;

  --yellow:      #ffe600;
  --pink:        #ff2d6f;
  --blue:        #1b5bff;
  --lime:        #00c46a;
  --orange:      #ff6b1a;
  --cyan:        #21d4fd;
  --purple:      #8b5cf6;

  --shadow-hard: 6px 6px 0 0 #0a0a0a;
  --shadow-hard-sm: 4px 4px 0 0 #0a0a0a;
  --shadow-hard-lg: 10px 10px 0 0 #0a0a0a;
  --shadow-pop:  8px 8px 0 0 var(--pink);

  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  min-height: 100vh;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Subtle paper texture + spray-paint splats */
body::before {
  content: ''; position: fixed; inset: 0; z-index: -2; pointer-events: none;
  background-image:
    radial-gradient(rgba(0,0,0,.025) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,.018) 1px, transparent 1px);
  background-size: 22px 22px, 13px 13px;
  background-position: 0 0, 11px 11px;
}
body::after {
  content: ''; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background:
    radial-gradient(circle at 8% 12%, rgba(255,230,0,.25), transparent 25%),
    radial-gradient(circle at 92% 18%, rgba(255,45,111,.18), transparent 22%),
    radial-gradient(circle at 75% 88%, rgba(27,91,255,.16), transparent 25%),
    radial-gradient(circle at 18% 82%, rgba(0,196,106,.18), transparent 25%);
  opacity: .9;
}

a { color: var(--ink); text-decoration: none; }
a:hover { color: var(--pink); }
button { font-family: inherit; cursor: pointer; }
::selection { background: var(--yellow); color: var(--ink); }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  background: var(--paper);
  border-bottom: 3px solid var(--ink);
}
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark { display: inline-flex; align-items: center; gap: 10px; }
.brand-hex {
  width: 44px; height: 44px; flex: none; position: relative;
  background: var(--yellow);
  border: 3px solid var(--ink);
  border-radius: 8px;
  transform: rotate(-4deg);
  box-shadow: var(--shadow-hard-sm);
}
.brand-hex::after {
  content: '⚽'; position: absolute; inset: 0; display: grid; place-items: center;
  font-size: 22px;
}
.brand-text {
  font-family: var(--font-display); font-size: 30px; letter-spacing: 2px;
  text-transform: uppercase; line-height: 1; color: var(--ink);
  -webkit-text-stroke: 0;
}
.brand-text .accent { color: var(--pink); -webkit-text-stroke: 1px var(--ink); }
.brand-sub {
  font-family: var(--font-script);
  font-size: 18px; color: var(--ink); transform: rotate(-6deg);
  margin-left: 4px; font-weight: 700;
}

.nav-desktop { display: flex; gap: 4px; }
.nav-desktop a {
  padding: 8px 16px;
  font-family: var(--font-block); font-size: 13px;
  text-transform: uppercase; letter-spacing: 1px;
  border: 2px solid transparent;
  border-radius: 999px;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.nav-desktop a:hover, .nav-desktop a.active {
  background: var(--yellow); border-color: var(--ink); color: var(--ink);
  transform: translateY(-1px) rotate(-1deg);
}

.header-actions { display: flex; align-items: center; gap: 10px; }
.avatar-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--paper); border: 3px solid var(--ink);
  padding: 4px 14px 4px 4px;
  border-radius: 999px; color: var(--ink);
  font-family: var(--font-block); font-size: 13px;
  box-shadow: var(--shadow-hard-sm);
  transition: transform .15s ease;
}
.avatar-btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 0 var(--pink); color: var(--ink); }
.avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--pink); color: var(--ink);
  border: 2px solid var(--ink);
  display: inline-grid; place-items: center;
  font-family: var(--font-block); font-size: 13px;
}
.user-pop { position: relative; }
.user-menu {
  position: absolute; top: calc(100% + 10px); right: 0; min-width: 220px;
  background: var(--paper); border: 3px solid var(--ink); border-radius: 14px;
  padding: 8px; display: flex; flex-direction: column; gap: 2px;
  box-shadow: var(--shadow-hard);
}
.user-menu[hidden] { display: none !important; }
.user-menu a { padding: 10px 14px; border-radius: 8px; font-size: 14px; font-weight: 600; }
.user-menu a:hover { background: var(--yellow); color: var(--ink); }

.hide-mobile { font-weight: 700; font-size: 13px; }
.hamburger { display: none; background: var(--paper); border: 3px solid var(--ink); border-radius: 10px; padding: 8px; flex-direction: column; gap: 4px; box-shadow: var(--shadow-hard-sm); }
.hamburger span { width: 22px; height: 3px; background: var(--ink); border-radius: 2px; }

.mobile-drawer {
  position: fixed; top: 72px; left: 12px; right: 12px; z-index: 40;
  background: var(--paper); border: 3px solid var(--ink); border-radius: 14px;
  padding: 12px; display: none; flex-direction: column; gap: 4px;
  box-shadow: var(--shadow-hard);
}
.mobile-drawer.open { display: flex; }
.mobile-drawer[hidden] { display: none !important; }
.mobile-drawer a { padding: 12px 16px; border-radius: 8px; font-weight: 700; font-family: var(--font-block); font-size: 13px; text-transform: uppercase; letter-spacing: 1px; }
.mobile-drawer a:hover { background: var(--yellow); }

/* ---------- Buttons (neobrutalism style) ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 22px;
  font-family: var(--font-block);
  font-weight: 700; font-size: 14px;
  text-transform: uppercase; letter-spacing: 1.2px;
  border: 3px solid var(--ink);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
  cursor: pointer;
  box-shadow: var(--shadow-hard-sm);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
  text-decoration: none;
}
.btn:hover { transform: translate(-2px, -2px); box-shadow: 6px 6px 0 0 var(--ink); color: var(--ink); }
.btn:active { transform: translate(2px, 2px); box-shadow: 1px 1px 0 0 var(--ink); }
.btn-primary { background: var(--yellow); }
.btn-primary:hover { background: var(--yellow); box-shadow: 6px 6px 0 0 var(--pink); }
.btn-secondary { background: var(--pink); color: var(--paper); }
.btn-secondary:hover { color: var(--paper); box-shadow: 6px 6px 0 0 var(--blue); }
.btn-blue { background: var(--blue); color: var(--paper); }
.btn-blue:hover { color: var(--paper); }
.btn-ghost { background: var(--paper); }
.btn-block { width: 100%; }
.btn-sm { padding: 8px 14px; font-size: 12px; box-shadow: 3px 3px 0 0 var(--ink); }
.btn-danger { background: var(--pink); color: var(--paper); }

/* Utilities */
.muted { color: var(--muted); }
.center { text-align: center; }
.flex { display: flex; gap: 12px; align-items: center; }
.between { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }

/* Flash messages */
.flash { padding: 12px 18px; margin: 0 24px 12px; border: 3px solid var(--ink); border-radius: 14px; font-weight: 700; box-shadow: var(--shadow-hard-sm); }
.flash-ok   { background: var(--lime); color: var(--ink); }
.flash-err  { background: var(--pink); color: var(--paper); }
.flash-info { background: var(--cyan); color: var(--ink); }
.announcement-bar {
  background: var(--ink); color: var(--yellow);
  padding: 10px 22px; text-align: center;
  font-family: var(--font-block); text-transform: uppercase; letter-spacing: 2px;
  font-size: 13px;
}

/* ---------- Main layout ---------- */
.site-main { max-width: 1280px; margin: 0 auto; padding: 36px 24px 120px; }
.page-head { margin-bottom: 32px; position: relative; }
.page-head h1 {
  font-family: var(--font-display);
  font-size: clamp(36px, 6vw, 64px);
  letter-spacing: 2px; line-height: .95;
  margin: 0 0 8px;
  text-transform: uppercase;
  color: var(--ink);
}
.page-head h1 .accent { color: var(--pink); }
.page-head p { color: var(--muted); margin: 0; font-size: 16px; max-width: 720px; }
.page-head::after {
  content: ''; position: absolute; left: 0; bottom: -10px;
  width: 60px; height: 6px; background: var(--yellow); border: 2px solid var(--ink);
  transform: rotate(-2deg);
}

/* ---------- Cards (sticker style) ---------- */
.card {
  background: var(--paper);
  border: 3px solid var(--ink);
  border-radius: var(--r-lg);
  padding: 22px;
  position: relative;
  box-shadow: var(--shadow-hard);
  transition: transform .15s ease, box-shadow .15s ease;
}
.card:hover { transform: translate(-2px, -2px); box-shadow: 10px 10px 0 0 var(--ink); }
.card.tilt-l { transform: rotate(-.8deg); }
.card.tilt-r { transform: rotate(.8deg); }
.card.tilt-l:hover, .card.tilt-r:hover { transform: rotate(0) translate(-2px,-2px); }

.grid { display: grid; gap: 22px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

/* ---------- Tape strips ---------- */
.tape {
  position: absolute; width: 90px; height: 22px;
  background: var(--yellow);
  border-left: 1px dashed rgba(0,0,0,.3); border-right: 1px dashed rgba(0,0,0,.3);
  opacity: .85;
}
.tape.tape-tl { top: -8px; left: 24px; transform: rotate(-8deg); }
.tape.tape-tr { top: -8px; right: 24px; transform: rotate(7deg); background: var(--pink); }

/* ---------- Forms ---------- */
.form-card { max-width: 480px; margin: 40px auto; position: relative; }
.form-card .card { padding: 36px; }
.field { margin-bottom: 18px; }
.field label {
  display: block;
  font-family: var(--font-block);
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 6px;
}
.field input, .field select, .field textarea {
  width: 100%; padding: 12px 14px;
  border: 3px solid var(--ink);
  border-radius: 12px;
  background: var(--paper);
  color: var(--ink);
  font: 500 15px var(--font-body);
  transition: box-shadow .15s ease, transform .15s ease;
}
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; box-shadow: 4px 4px 0 0 var(--pink); transform: translate(-2px,-2px);
}
.form-divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; color: var(--muted); font-size: 12px; }
.form-divider::before, .form-divider::after { content: ''; flex: 1; height: 2px; background: var(--ink); }

/* ---------- HOME / Hero ---------- */
.hero {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 50px; align-items: center;
  padding: 30px 0 50px;
  position: relative;
}
@media (max-width: 900px) { .hero { grid-template-columns: 1fr; gap: 30px; } }

.hero .eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  background: var(--ink); color: var(--yellow);
  padding: 6px 14px; border-radius: 99px;
  font-family: var(--font-block); font-size: 11px; letter-spacing: 2px; text-transform: uppercase;
  margin-bottom: 16px;
  transform: rotate(-2deg);
}
.hero .eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 0 3px rgba(0,196,106,.3); }

.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(48px, 9vw, 110px);
  line-height: .9; margin: 0 0 18px; letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--ink);
}
.hero h1 .splat {
  display: inline-block; position: relative;
  background: var(--yellow);
  padding: 0 10px;
  transform: rotate(-2deg);
  border: 3px solid var(--ink);
  border-radius: 8px;
  box-shadow: var(--shadow-hard-sm);
}
.hero h1 .marker { color: var(--pink); }
.hero h1 .underline-script {
  font-family: var(--font-script);
  color: var(--blue); font-size: .7em; font-weight: 700;
  display: inline-block; transform: rotate(-3deg);
  -webkit-text-stroke: 1px var(--ink);
}

.hero p.lead {
  font-size: 18px; color: var(--ink-soft); max-width: 520px;
  margin: 0 0 28px; font-weight: 500;
}
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }

.hero-art {
  position: relative; min-height: 420px;
}
.hero-art .photo {
  position: absolute; width: 56%; aspect-ratio: 3/4;
  background-size: cover; background-position: center;
  border: 4px solid var(--ink);
  border-radius: 18px;
  box-shadow: var(--shadow-hard-lg);
}
.hero-art .photo-1 {
  top: 0; left: 0;
  background-image: url('https://images.unsplash.com/photo-1574629810360-7efbbe195018?auto=format&fit=crop&w=800&q=60');
  transform: rotate(-4deg);
  z-index: 2;
}
.hero-art .photo-2 {
  bottom: 0; right: 0; width: 52%; aspect-ratio: 1/1.1;
  background-image: url('https://images.unsplash.com/photo-1551958219-acbc608c6377?auto=format&fit=crop&w=800&q=60');
  transform: rotate(5deg);
  z-index: 1;
}
.hero-art .sticker {
  position: absolute;
  background: var(--paper);
  border: 3px solid var(--ink);
  padding: 10px 14px;
  border-radius: 99px;
  font-family: var(--font-block); font-size: 12px; letter-spacing: 1.5px;
  text-transform: uppercase;
  box-shadow: var(--shadow-hard-sm);
  z-index: 5;
}
.hero-art .sticker-1 { top: 5%; right: 8%; background: var(--pink); color: var(--paper); transform: rotate(8deg); }
.hero-art .sticker-2 { bottom: 12%; left: -5%; background: var(--yellow); transform: rotate(-10deg); }
.hero-art .sticker-3 { top: 45%; right: -5%; background: var(--blue); color: var(--paper); transform: rotate(-5deg); }
.hero-art .blob-yellow {
  position: absolute; left: 30%; top: 30%; width: 200px; height: 200px;
  background: var(--yellow); border-radius: 50% 60% 70% 40% / 50% 60% 40% 50%;
  z-index: 0; opacity: .85;
}

/* Stats strip */
.stats-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px;
  padding: 26px;
  background: var(--ink);
  border: 3px solid var(--ink);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-hard-lg);
  margin: 40px 0 60px;
  position: relative;
}
.stats-strip::before {
  content: 'STATS'; position: absolute; top: -16px; left: 24px;
  background: var(--pink); color: var(--paper);
  padding: 4px 14px; border: 3px solid var(--ink); border-radius: 99px;
  font-family: var(--font-block); font-size: 12px; letter-spacing: 2px;
  transform: rotate(-3deg);
}
@media (max-width: 700px) { .stats-strip { grid-template-columns: repeat(2, 1fr); } }
.stat { text-align: center; color: var(--paper); }
.stat .v {
  font-family: var(--font-display); font-size: 38px;
  letter-spacing: 1px;
  color: var(--yellow);
  line-height: 1;
}
.stat .v.pink { color: var(--pink); }
.stat .v.blue { color: var(--cyan); }
.stat .v.lime { color: var(--lime); }
.stat .l {
  font-family: var(--font-block); font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; color: rgba(255,255,255,.7); margin-top: 6px;
}

/* Section heading */
.section-head { margin: 70px 0 28px; position: relative; }
.section-head .label {
  display: inline-block;
  background: var(--blue); color: var(--paper);
  padding: 4px 14px; border: 3px solid var(--ink); border-radius: 99px;
  font-family: var(--font-block); font-size: 11px; letter-spacing: 2px;
  margin-bottom: 10px;
  transform: rotate(-2deg);
}
.section-head h2 {
  font-family: var(--font-display); font-size: clamp(34px, 5vw, 52px);
  letter-spacing: 1.5px; line-height: .95;
  margin: 0 0 6px; text-transform: uppercase;
}
.section-head p { color: var(--muted); margin: 0; }

/* Feature cards on home */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
@media (max-width: 900px) { .feature-grid { grid-template-columns: 1fr; } }
.feature-card {
  position: relative;
  padding: 28px 26px 34px;
  border: 3px solid var(--ink); border-radius: var(--r-lg);
  background: var(--paper);
  box-shadow: var(--shadow-hard);
  transition: transform .15s ease, box-shadow .15s ease;
}
.feature-card:nth-child(3n+1) { background: var(--paper); }
.feature-card:nth-child(3n+2) { background: var(--yellow); }
.feature-card:nth-child(3n)   { background: var(--pink); color: var(--paper); }
.feature-card:nth-child(3n) h3,
.feature-card:nth-child(3n) p { color: var(--paper); }
.feature-card:hover { transform: translate(-3px,-3px) rotate(-.5deg); box-shadow: 12px 12px 0 0 var(--ink); }
.feature-card h3 {
  font-family: var(--font-display); font-size: 28px; letter-spacing: 1.5px;
  text-transform: uppercase; margin: 14px 0 8px;
}
.feature-card .num {
  font-family: var(--font-display); font-size: 80px;
  position: absolute; bottom: -16px; right: 18px;
  color: transparent; -webkit-text-stroke: 2px var(--ink);
  opacity: .25;
  pointer-events: none;
}
.feature-card:nth-child(3n) .num { -webkit-text-stroke: 2px var(--paper); }
.feature-card .ico {
  width: 56px; height: 56px; border-radius: 14px;
  border: 3px solid var(--ink); background: var(--paper);
  display: inline-grid; place-items: center;
  font-size: 26px;
  transform: rotate(-4deg);
  box-shadow: var(--shadow-hard-sm);
}

/* ---------- Group prediction cards ---------- */
.group-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
@media (max-width: 1000px) { .group-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .group-grid { grid-template-columns: 1fr; } }
.group-card { padding: 22px; }
.group-card:nth-child(odd) { transform: rotate(-.6deg); }
.group-card:nth-child(even) { transform: rotate(.6deg); }
.group-card:hover { transform: rotate(0) translate(-3px,-3px); }
.group-card h3 {
  font-family: var(--font-display); font-size: 26px; letter-spacing: 1px;
  display: inline-flex; align-items: center; gap: 12px;
  text-transform: uppercase;
  margin: 0 0 6px;
}
.badge-letter {
  display: inline-grid; place-items: center;
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--pink); color: var(--paper);
  border: 3px solid var(--ink);
  font-family: var(--font-display); font-size: 26px;
  box-shadow: var(--shadow-hard-sm);
  transform: rotate(-4deg);
}
.group-card .pos-list { list-style: none; padding: 0; margin: 16px 0 0; display: flex; flex-direction: column; gap: 8px; }
.team-row {
  display: flex; align-items: center; gap: 12px;
  background: var(--paper); border: 2.5px solid var(--ink);
  padding: 10px 12px; border-radius: 12px;
  cursor: grab;
  transition: transform .15s ease, box-shadow .15s ease;
  user-select: none;
  box-shadow: 3px 3px 0 0 var(--ink);
}
.team-row:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 0 var(--pink); }
.team-row.dragging { opacity: .4; }
.team-row.drag-over { border-style: dashed; box-shadow: 5px 5px 0 0 var(--blue); }
.team-row .pos {
  width: 30px; height: 30px; border-radius: 8px;
  display: inline-grid; place-items: center;
  font-family: var(--font-display); font-size: 16px;
  border: 2px solid var(--ink);
  background: var(--paper);
}
.team-row[data-pos="1"] .pos { background: var(--yellow); }
.team-row[data-pos="2"] .pos { background: #c0c4d6; }
.team-row[data-pos="3"] .pos { background: var(--orange); color: var(--paper); }
.team-row[data-pos="4"] .pos { background: var(--ink); color: var(--paper); }
.team-row .flag { font-size: 22px; line-height: 1; }
.team-row .name { font-weight: 700; flex: 1; font-size: 14px; }
.team-row .grip { color: var(--muted); font-family: monospace; }
.group-card .save-row { margin-top: 14px; display: flex; gap: 8px; justify-content: space-between; align-items: center; flex-wrap: wrap; }
.group-card .save-row .muted { font-size: 12px; }

/* ---------- Match prediction cards ---------- */
.match-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
@media (max-width: 900px) { .match-list { grid-template-columns: 1fr; } }
.match-card {
  padding: 20px;
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 14px; align-items: center;
}
.match-card:nth-child(odd) { transform: rotate(-.4deg); }
.match-card:nth-child(even) { transform: rotate(.4deg); }
.match-card:hover { transform: rotate(0) translate(-3px,-3px); }
.match-card .side { display: flex; flex-direction: column; gap: 6px; align-items: flex-start; }
.match-card .side.away { align-items: flex-end; text-align: right; }
.match-card .side .flag { font-size: 32px; line-height: 1; }
.match-card .side .team-name { font-family: var(--font-block); font-size: 14px; text-transform: uppercase; letter-spacing: 1px; }
.match-card .vs {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  font-family: var(--font-display); letter-spacing: 1px;
}
.score-input {
  width: 56px; padding: 10px 6px;
  border: 3px solid var(--ink); border-radius: 10px;
  background: var(--paper); color: var(--ink);
  text-align: center;
  font-family: var(--font-display); font-size: 24px;
  box-shadow: var(--shadow-hard-sm);
  transition: box-shadow .15s ease, transform .15s ease;
}
.score-input:focus { outline: none; transform: translate(-2px,-2px); box-shadow: 5px 5px 0 0 var(--pink); }
.score-row { display: flex; gap: 12px; align-items: center; }
.score-row > .muted { font-family: var(--font-display); font-size: 22px; color: var(--ink); }
.match-meta {
  grid-column: 1 / -1;
  display: flex; justify-content: space-between; align-items: center;
  color: var(--muted); font-size: 12px;
  padding-top: 12px; margin-top: 6px;
  border-top: 2px dashed var(--ink);
  flex-wrap: wrap; gap: 8px;
}
.match-meta .points-pill {
  background: var(--lime); color: var(--ink);
  padding: 4px 12px; border: 2px solid var(--ink); border-radius: 99px;
  font-family: var(--font-block); font-size: 11px; letter-spacing: 1px;
}
.match-meta .lock-pill {
  background: var(--paper); padding: 4px 12px;
  border: 2px solid var(--ink); border-radius: 99px;
  font-family: var(--font-block); font-size: 11px;
}
.match-meta .lock-pill.locked { background: var(--pink); color: var(--paper); }

/* ---------- Knockout Bracket ---------- */
.bracket-wrap { overflow-x: auto; padding-bottom: 14px; }
.bracket {
  display: inline-grid; grid-auto-flow: column; gap: 26px;
  align-items: stretch; padding: 8px;
}
.bracket-col { display: flex; flex-direction: column; justify-content: space-around; gap: 22px; min-width: 240px; }
.bracket-col h4 {
  font-family: var(--font-display); letter-spacing: 1.5px; font-size: 16px;
  background: var(--ink); color: var(--yellow);
  padding: 6px 14px; border-radius: 99px;
  text-align: center;
  text-transform: uppercase;
  margin: 0 auto 10px;
  display: inline-block;
}
.bracket-card { padding: 14px; }
.bracket-card .row { display: flex; align-items: center; gap: 10px; padding: 6px 4px; }
.bracket-card .row.win { color: var(--ink); }
.bracket-card .row.lose { color: var(--muted); }
.bracket-card .row input.score-input { width: 44px; padding: 6px; font-size: 16px; }
.bracket-card hr { border: none; border-top: 2px dashed var(--ink); margin: 6px 0; }

/* ---------- Awards predictions ---------- */
.award-card { padding: 24px; }
.award-card:nth-child(3n+1) { background: var(--paper); }
.award-card:nth-child(3n+2) { background: var(--yellow); }
.award-card:nth-child(3n)   { background: var(--cyan); }
.award-card h3 { font-family: var(--font-display); font-size: 22px; letter-spacing: 1px; text-transform: uppercase; margin: 12px 0 14px; }
.award-card .award-icon {
  width: 56px; height: 56px; border-radius: 14px;
  background: var(--ink); color: var(--yellow);
  border: 3px solid var(--ink);
  display: inline-grid; place-items: center;
  font-size: 28px;
  transform: rotate(-6deg);
  box-shadow: var(--shadow-hard-sm);
}

/* ---------- Leaderboard ---------- */
.lb-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.lb-tab {
  padding: 10px 18px;
  border: 3px solid var(--ink); border-radius: 99px;
  background: var(--paper);
  font-family: var(--font-block); font-size: 12px;
  text-transform: uppercase; letter-spacing: 1.5px;
  box-shadow: var(--shadow-hard-sm);
  transition: transform .12s ease;
}
.lb-tab:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 0 var(--pink); color: var(--ink); }
.lb-tab.active { background: var(--yellow); color: var(--ink); }

.lb-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.lb-table th, .lb-table td { padding: 14px 14px; text-align: left; }
.lb-table th {
  font-family: var(--font-block); font-size: 11px;
  text-transform: uppercase; letter-spacing: 1.5px;
  color: var(--ink);
  border-bottom: 3px solid var(--ink);
}
.lb-table tr td { border-bottom: 2px dashed var(--ink); }
.lb-table tr.me td { background: var(--yellow); }
.lb-table .rank {
  display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 10px;
  font-family: var(--font-display); font-size: 16px;
  border: 2px solid var(--ink);
  background: var(--paper);
}
.lb-table .rank.gold { background: var(--yellow); }
.lb-table .rank.silver { background: #d6d8e7; }
.lb-table .rank.bronze { background: var(--orange); color: var(--paper); }
.lb-table .points { font-family: var(--font-display); font-size: 20px; color: var(--pink); letter-spacing: 1px; }
.lb-table .player-cell { display: flex; align-items: center; gap: 12px; }
.lb-table .player-cell strong { font-family: var(--font-block); font-size: 14px; }

/* ---------- Bottom mobile nav ---------- */
.bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 30;
  display: none; justify-content: space-around; align-items: center;
  padding: 8px 4px env(safe-area-inset-bottom, 8px);
  background: var(--paper);
  border-top: 3px solid var(--ink);
}
.bottom-nav a {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-family: var(--font-block); font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase;
  padding: 6px 10px; border-radius: 10px;
  color: var(--muted);
}
.bottom-nav a.active { color: var(--ink); background: var(--yellow); }
.bn-ico { width: 22px; height: 22px; border: 2.5px solid currentColor; border-radius: 6px; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--ink); color: var(--paper);
  border-top: 3px solid var(--ink);
  padding: 60px 24px 30px;
  margin-top: 80px;
  position: relative;
}
.site-footer::before {
  content: ''; position: absolute; top: -3px; left: 0; right: 0; height: 18px;
  background: repeating-linear-gradient(45deg,
    var(--yellow) 0 18px, var(--pink) 18px 36px, var(--blue) 36px 54px, var(--lime) 54px 72px);
  border-top: 3px solid var(--ink);
  border-bottom: 3px solid var(--ink);
}
.foot-grid { max-width: 1280px; margin: 24px auto 0; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 36px; }
@media (max-width: 800px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
.site-footer .brand-text { color: var(--paper); }
.site-footer .brand-text .accent { color: var(--yellow); -webkit-text-stroke: 1px var(--paper); }
.foot-grid h5 { font-family: var(--font-display); font-size: 18px; letter-spacing: 2px; margin: 0 0 14px; color: var(--yellow); text-transform: uppercase; }
.foot-grid a { display: block; padding: 4px 0; color: rgba(255,255,255,.8); font-size: 14px; font-weight: 500; }
.foot-grid a:hover { color: var(--yellow); }
.foot-grid p { color: rgba(255,255,255,.65); margin: 0; font-size: 14px; }
.foot-bottom { max-width: 1280px; margin: 36px auto 0; padding-top: 22px; border-top: 1px dashed rgba(255,255,255,.3); text-align: center; color: rgba(255,255,255,.6); font-size: 13px; }

/* ---------- Badge chips ---------- */
.badge-chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border: 2.5px solid var(--ink); border-radius: 99px;
  background: var(--paper);
  font-family: var(--font-block); font-size: 11px; letter-spacing: 1.2px;
  text-transform: uppercase;
  box-shadow: 3px 3px 0 0 var(--ink);
  margin: 4px 4px 0 0;
}
.badge-chip.earned { background: var(--yellow); }
.badge-chip .icon { width: 14px; height: 14px; border-radius: 4px; background: var(--ink); }
.badge-chip.earned .icon { background: var(--pink); }

/* ---------- Empty state ---------- */
.empty {
  text-align: center; padding: 60px 30px;
  border: 3px dashed var(--ink); border-radius: var(--r-lg);
  color: var(--muted);
}
.empty .icon {
  width: 80px; height: 80px; border-radius: 20px; margin: 0 auto 16px;
  background: var(--yellow);
  border: 3px solid var(--ink);
  box-shadow: var(--shadow-hard-sm);
  transform: rotate(-6deg);
  display: grid; place-items: center;
  font-size: 36px;
}
.empty h3 { color: var(--ink); font-family: var(--font-display); letter-spacing: 1.5px; text-transform: uppercase; }

/* ---------- Mobile breakpoints ---------- */
@media (max-width: 900px) {
  .nav-desktop { display: none; }
  .hamburger { display: flex; }
  .site-main { padding: 24px 16px 110px; }
  .bottom-nav { display: flex; }
  .header-actions .btn { padding: 8px 14px; font-size: 12px; }
}

/* Reveal animation */
.reveal { animation: reveal .55s ease both; }
.reveal:nth-child(2) { animation-delay: .05s; }
.reveal:nth-child(3) { animation-delay: .1s; }
.reveal:nth-child(4) { animation-delay: .15s; }
@keyframes reveal { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
