/* ═══════════════════════════════════════════════════════════════
   EBOL. — MINI-GAMES · "Palpites da Copa"
   Conceito: placar de estádio / cartela de bolão. O board é VERDE
   (pitch): vibrante "de dia" no tema claro, noturno no tema escuro —
   sempre nativo ao tema do app. Cartões dos jogos são temáticos.
   Display: Anton (pôster). Corpo: Sora. Accent: dot laranja.
   ═══════════════════════════════════════════════════════════════ */

.mg {
  /* Board (pitch) — VERDE no claro, NOTURNO no escuro. Tokens próprios
     porque os greens do app invertem com o tema (não servem aqui). */
  --mg-board-bg: linear-gradient(150deg, #2f7355 0%, #205440 55%, #163f2f 100%);
  --mg-board-edge: rgba(255, 255, 255, 0.12);
  --mg-line: rgba(255, 255, 255, 0.13);
  --mg-line-strong: rgba(255, 255, 255, 0.2);
  --mg-on-board: #f4f9f5;
  --mg-on-board-dim: rgba(244, 249, 245, 0.74);
  --mg-grain: 0.05;

  --mg-display: 'Anton', var(--font-display);
  --mg-radius: 18px;

  --mg-shadow: 0 1px 2px rgba(16, 32, 24, 0.04), 0 8px 24px -12px rgba(16, 32, 24, 0.18);
  --mg-shadow-lift: 0 2px 4px rgba(16, 32, 24, 0.06), 0 18px 40px -16px rgba(16, 32, 24, 0.28);

  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  max-width: 100%;
}

[data-theme="dark"] .mg {
  --mg-board-bg: linear-gradient(150deg, #143b2b 0%, #0f2a1f 55%, #0a1c15 100%);
  --mg-board-edge: rgba(255, 255, 255, 0.06);
  --mg-line: rgba(255, 255, 255, 0.09);
  --mg-line-strong: rgba(255, 255, 255, 0.16);
  --mg-on-board: #f1f7f3;
  --mg-on-board-dim: rgba(241, 247, 243, 0.56);
  --mg-grain: 0.035;
}

/* ════════ SCOREBOARD (hero pitch) ════════ */

.mg-board {
  position: relative;
  overflow: hidden;
  border-radius: var(--mg-radius);
  background: var(--mg-board-bg);
  border: 1px solid var(--mg-board-edge);
  box-shadow: var(--mg-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.07);
  color: var(--mg-on-board);
  padding: 1.75rem 1.6rem 1.6rem;
}

/* Linhas de campo: faixa central + círculo + arcos, bem sutis */
.mg-board::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, transparent 49.7%, var(--mg-line) 49.7%, var(--mg-line) 50.3%, transparent 50.3%),
    radial-gradient(circle at 50% 50%, transparent 58px, var(--mg-line) 59px, var(--mg-line) 60px, transparent 61px);
  background-repeat: no-repeat;
  background-position: center, center;
  opacity: 0.9;
  pointer-events: none;
}
/* Grão sutil */
.mg-board::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity: var(--mg-grain);
  mix-blend-mode: screen;
  pointer-events: none;
}
.mg-board > * { position: relative; z-index: 1; }

.mg-board-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.1rem;
}

.mg-back {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--mg-on-board-dim);
  text-decoration: none;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: color 0.15s ease, transform 0.15s ease;
}
.mg-back:hover { color: var(--mg-on-board); transform: translateX(-2px); }

.mg-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--accent-glow);
  background: rgba(244, 123, 53, 0.12);
  border: 1px solid rgba(244, 123, 53, 0.32);
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
}
.mg-chip-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent-glow);
  box-shadow: 0 0 8px 1px var(--accent-glow);
  animation: mg-pulse 2.4s ease-in-out infinite;
}

.mg-eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--mg-on-board-dim);
  margin: 0 0 0.35rem;
}

.mg-board-title {
  font-family: var(--mg-display);
  font-weight: 400;
  font-size: clamp(2.2rem, 8.5vw, 4.4rem);
  line-height: 0.86;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin: 0;
  color: #fff;
  text-shadow: 0 2px 30px rgba(82, 183, 136, 0.25);
  overflow-wrap: break-word;
}
.mg-board-title .mg-dot { color: var(--accent); }
.mg-board-title em {
  font-style: normal;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(241, 247, 243, 0.5);
}

.mg-board-sub {
  margin: 0.85rem 0 0;
  max-width: 52ch;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--mg-on-board-dim);
}

/* ── Scoreboard de stats (acertos / palpites / posição) ── */
.mg-scoreboard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 1.5rem;
  border: 1px solid var(--mg-line-strong);
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.22);
  overflow: hidden;
}

.mg-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  padding: 0.95rem 0.5rem;
  position: relative;
  min-width: 0;
}
.mg-score + .mg-score { border-left: 1px solid var(--mg-line); }

.mg-score-num {
  font-family: var(--mg-display);
  font-weight: 400;
  font-size: 2.3rem;
  line-height: 1;
  color: var(--mg-on-board);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
}
.mg-score-num .mg-den {
  font-size: 1.1rem;
  color: var(--mg-on-board-dim);
}
.mg-score-num--accent { color: var(--accent-glow); }
.mg-score-label {
  font-size: 0.64rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--mg-on-board-dim);
}

/* ════════ LAYOUT (jogo + ranking) ════════ */

.mg-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 1.25rem;
  align-items: start;
}
.mg-main { display: flex; flex-direction: column; gap: 1.75rem; min-width: 0; }
.mg-aside { position: sticky; top: 1rem; display: flex; flex-direction: column; gap: 1rem; }

/* ════════ RODADAS (bracket labels) ════════ */

.mg-round { animation: mg-rise 0.5s cubic-bezier(0.2, 0.7, 0.2, 1) backwards; }
.mg-round:nth-child(1) { animation-delay: 0.02s; }
.mg-round:nth-child(2) { animation-delay: 0.08s; }
.mg-round:nth-child(3) { animation-delay: 0.14s; }
.mg-round:nth-child(4) { animation-delay: 0.2s; }
.mg-round:nth-child(5) { animation-delay: 0.26s; }

.mg-round-head {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  margin-bottom: 1rem;
}
.mg-round-title {
  font-family: var(--mg-display);
  font-weight: 400;
  font-size: clamp(1.2rem, 5vw, 1.5rem);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--text-primary);
  margin: 0;
  white-space: nowrap;
}
.mg-round-count {
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
}
.mg-round-rule {
  flex: 1;
  height: 1px;
  background: repeating-linear-gradient(90deg, var(--border) 0 8px, transparent 8px 14px);
}

.mg-fixtures {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 0.9rem;
}

/* ════════ CARD DE CONFRONTO (duelo) ════════ */

.mg-duel {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--mg-shadow);
  overflow: hidden;
  animation: mg-rise 0.45s cubic-bezier(0.2, 0.7, 0.2, 1) backwards;
  transition: box-shadow 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.mg-duel--open:hover { box-shadow: var(--mg-shadow-lift); border-color: var(--border-hover); }
.mg-duel--locked { opacity: 0.96; }
.mg-duel--decided { border-color: color-mix(in srgb, var(--green-mid) 32%, var(--border)); }

/* Barra de status (placar / horário) */
.mg-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.85rem;
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
}
.mg-status-when { display: inline-flex; align-items: center; gap: 0.4rem; }
.mg-status--live { color: var(--accent); }
.mg-live-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 var(--accent);
  animation: mg-blink 1.4s ease-in-out infinite;
}
.mg-status-score {
  font-family: var(--mg-display);
  font-size: 1rem;
  letter-spacing: 0.06em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.mg-status-lock { color: var(--text-muted); letter-spacing: 0.06em; }

/* Aviso inline (jogo travado, etc.) */
.mg-alert {
  margin: 0;
  padding: 0.5rem 0.85rem;
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--red-warning);
  background: color-mix(in srgb, var(--red-warning) 10%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--red-warning) 22%, transparent);
}

/* O duelo: TIME × TIME. minmax(0,1fr) deixa os painéis encolherem — nomes
   longos (ex: "Bósnia e Herzegovina") quebram em vez de estourar a largura. */
.mg-duel-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: stretch;
}

/* Lado do confronto (botão de palpite ou estático). padding-top reservado pra
   a faixa "Meu palpite" — mantém as bandeiras dos dois lados alinhadas tenha
   ou não palpite. */
.mg-side {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 1.75rem 0.7rem 1.15rem;
  text-align: center;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
  width: 100%;
  min-width: 0;
  position: relative;
}
button.mg-side {
  cursor: pointer;
  transition: background 0.15s ease;
}
button.mg-side:hover { background: var(--green-wash); }
button.mg-side:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -3px;
  border-radius: 10px;
}
/* button_to envolve num <form> — torna transparente no grid */
.mg-side-form { margin: 0; display: contents; }

.mg-flag-wrap {
  position: relative;
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
}
.mg-flag {
  width: 38px; height: 28px;
  object-fit: cover;
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
}
.mg-side-name {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.05;
  letter-spacing: -0.01em;
  max-width: 100%;
  overflow-wrap: break-word;
}
.mg-side-hint {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  opacity: 0;
  transition: opacity 0.15s ease;
}
button.mg-side:hover .mg-side-hint { opacity: 1; }

/* Estado: escolhido pelo jogador */
.mg-side--picked {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--green-primary) 24%, transparent), color-mix(in srgb, var(--green-primary) 10%, transparent));
  box-shadow: inset 0 0 0 2.5px var(--green-primary);
  animation: mg-pick-pop 0.4s cubic-bezier(0.2, 1.2, 0.3, 1);
}
button.mg-side--picked:hover { background: linear-gradient(180deg, color-mix(in srgb, var(--green-primary) 28%, transparent), color-mix(in srgb, var(--green-primary) 13%, transparent)); }
.mg-side--picked .mg-side-name { color: var(--green-deep); font-weight: 800; }
.mg-side--picked .mg-flag-wrap { border-color: var(--green-primary); }

/* Label "★ Meu palpite" — FAIXA no topo do painel escolhido. Ocupa a largura
   toda (sem sobrepor coroa, bandeira ou nome, que ficam abaixo dela graças ao
   padding-top reservado em .mg-side). Destaque forte do palpite. */
.mg-pick-label {
  display: none;
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1.4rem;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  font-size: 0.6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #fff;
  background: linear-gradient(180deg, var(--accent-glow), var(--accent));
  box-shadow: 0 2px 8px -1px rgba(232, 98, 26, 0.45);
  z-index: 4;
}
.mg-side--picked .mg-pick-label { display: flex; }

/* Estado: vencedor (avançou) */
.mg-side--winner { background: color-mix(in srgb, var(--green-mid) 12%, transparent); }
.mg-side--winner .mg-flag-wrap {
  border-color: var(--green-mid);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--green-mid) 22%, transparent);
}
/* Coroa do vencedor — acima da bandeira (dentro do flag-wrap) */
.mg-crown {
  position: absolute;
  top: -13px; left: 50%; transform: translateX(-50%);
  font-size: 1rem;
  line-height: 1;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.3));
  z-index: 3;
}
.mg-side--out { opacity: 0.5; }
.mg-side--out .mg-side-name { color: var(--text-muted); }

/* Medalhão central VS */
.mg-vs {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  align-self: center;
  width: 46px; height: 46px;
  border-radius: 50%;
  background: linear-gradient(150deg, #143b2b, #0c2018);
  color: var(--mg-on-board);
  box-shadow: 0 4px 12px -4px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.08);
  z-index: 2;
}
.mg-vs-x {
  font-family: var(--mg-display);
  font-size: 1.3rem;
  line-height: 1;
  color: var(--accent-glow);
}

/* Rodapé do duelo (palpite / verdito) */
.mg-foot {
  padding: 0.7rem 0.85rem;
  border-top: 1px solid var(--border);
  font-size: 0.78rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 2.2rem;
}
.mg-foot-cta { color: var(--text-muted); font-weight: 600; }
.mg-foot-pick { color: var(--text-secondary); }
.mg-foot-pick strong { color: var(--text-primary); }
.mg-foot-none { color: var(--text-muted); font-style: italic; }

/* Carimbo de verdito (acertou / errou) */
.mg-stamp {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--mg-display);
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.15rem 0.7rem;
  border-radius: 7px;
  transform: rotate(-2.5deg);
}
.mg-stamp--ok {
  color: var(--green-mid);
  border: 2px solid color-mix(in srgb, var(--green-mid) 60%, transparent);
  background: color-mix(in srgb, var(--green-mid) 9%, transparent);
}
.mg-stamp--miss {
  color: var(--red-warning);
  border: 2px solid color-mix(in srgb, var(--red-warning) 50%, transparent);
  background: color-mix(in srgb, var(--red-warning) 8%, transparent);
}

/* ════════ RANKING DE PALPITEIROS ════════ */

.mg-rank {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--mg-shadow);
  overflow: hidden;
}
.mg-rank-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.9rem 1rem;
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
}
.mg-rank-title {
  font-family: var(--mg-display);
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--text-primary);
  margin: 0;
}
/* Contagem de participantes (jogadores no bolão) */
.mg-rank-total {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.5rem;
  font-size: 0.8rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  border-radius: 999px;
  justify-content: center;
}
.mg-rank-total::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
}
.mg-rank-list { list-style: none; margin: 0; padding: 0.4rem; display: flex; flex-direction: column; gap: 0.1rem; }

.mg-rank-row {
  display: grid;
  grid-template-columns: 2rem 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.6rem;
  border-radius: 10px;
  transition: background 0.12s ease;
}
.mg-rank-row:hover { background: var(--bg-card); }
.mg-rank-row--me {
  background: color-mix(in srgb, var(--accent) 9%, transparent);
  box-shadow: inset 3px 0 0 var(--accent);
}
.mg-rank-row--me:hover { background: color-mix(in srgb, var(--accent) 13%, transparent); }

.mg-medal {
  display: flex; align-items: center; justify-content: center;
  width: 1.7rem; height: 1.7rem;
  border-radius: 50%;
  font-family: var(--mg-display);
  font-size: 0.85rem;
  color: var(--text-muted);
}
.mg-rank-row--p1 .mg-medal { color: #6b4e0a; background: linear-gradient(150deg, #fde08a, #d4a017); box-shadow: 0 2px 6px -1px rgba(212, 160, 23, 0.5); }
.mg-rank-row--p2 .mg-medal { color: #3c4248; background: linear-gradient(150deg, #eef1f4, #c2cad2); }
.mg-rank-row--p3 .mg-medal { color: #5a2f16; background: linear-gradient(150deg, #f0b787, #cd7f4a); }

.mg-rank-user {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--text-primary);
  text-decoration: none;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mg-rank-user:hover { color: var(--accent); }
.mg-rank-me-tag {
  font-size: 0.58rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--accent); margin-left: 0.35rem;
}

.mg-rank-score {
  font-family: var(--mg-display);
  font-size: 1.05rem;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.mg-rank-score .mg-den { font-size: 0.72rem; color: var(--text-muted); }

.mg-rank-empty { padding: 1.5rem 1rem; font-size: 0.85rem; line-height: 1.5; color: var(--text-muted); text-align: center; }

/* Divisor + linha "sua posição" (jogador fora do top 10) */
.mg-rank-sep {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0.35rem 0.6rem 0.1rem;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}
.mg-rank-sep::before,
.mg-rank-sep::after { content: ""; flex: 1; border-top: 1px dashed var(--border); }
.mg-rank-row--solo {
  margin: 0 0.4rem 0.4rem;
}
.mg-rank-foot {
  margin: 0;
  padding: 0.65rem 0.85rem 0.85rem;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--text-muted);
  text-align: center;
}

/* Atalho do scoreboard pro ranking (stat "no ranking" clicável) */
.mg-score--jump { text-decoration: none; cursor: pointer; transition: background 0.15s ease; }
.mg-score--jump:hover { background: rgba(255, 255, 255, 0.06); }
.mg-jump-arrow { color: var(--accent-glow); font-weight: 700; }

/* Toggle "ver jogos anteriores" */
.mg-past { display: flex; justify-content: center; padding-top: 0.25rem; }
.mg-past-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 0.55rem 1rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--bg-surface);
  transition: border-color 0.15s ease, color 0.15s ease;
}
.mg-past-link:hover { border-color: var(--accent); color: var(--text-primary); }
.mg-past-link--active { border-color: var(--accent); color: var(--text-primary); background: color-mix(in srgb, var(--accent) 7%, var(--bg-surface)); }
.mg-past-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.2rem;
  height: 1.2rem;
  padding: 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  color: #fff;
  background: var(--accent);
  border-radius: 999px;
}

/* Âncora do ranking — folga pro topbar/subnav fixos ao rolar */
#mg-ranking { scroll-margin-top: 90px; }

/* ════════ ESTADOS VAZIOS ════════ */
.mg-empty--soft { padding: 2rem 1.5rem; }
.mg-empty {
  position: relative;
  text-align: center;
  padding: 3rem 1.5rem;
  background: var(--bg-surface);
  border: 1px dashed var(--border-hover);
  border-radius: var(--mg-radius);
  box-shadow: var(--mg-shadow);
}
.mg-empty-emoji { font-size: 2.5rem; display: block; margin-bottom: 0.5rem; filter: grayscale(0.2); }
.mg-empty p { color: var(--text-muted); font-size: 0.95rem; line-height: 1.55; margin: 0 auto; max-width: 42ch; }

/* ════════ HUB (/mini-games) ════════ */
.mg-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}

.mg-card {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.5rem;
  min-height: 200px;
  padding: 1.4rem;
  border-radius: var(--mg-radius);
  text-decoration: none;
  overflow: hidden;
  animation: mg-rise 0.5s cubic-bezier(0.2, 0.7, 0.2, 1) backwards;
}
.mg-card:nth-child(2) { animation-delay: 0.08s; }

/* Card destaque: cartela pitch (verde no claro, noturno no escuro) */
.mg-card--feature {
  color: var(--mg-on-board);
  background: var(--mg-board-bg);
  border: 1px solid var(--mg-board-edge);
  box-shadow: var(--mg-shadow-lift);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.mg-card--feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, transparent 49.6%, var(--mg-line) 49.6%, var(--mg-line) 50.4%, transparent 50.4%),
    radial-gradient(circle at 50% 100%, var(--mg-line) 70px, transparent 71px);
  pointer-events: none;
}
.mg-card--feature:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -18px rgba(10, 28, 21, 0.6); }
.mg-card--feature .mg-card-name { color: #fff; }
.mg-card--feature .mg-card-desc { color: var(--mg-on-board-dim); }

.mg-card-emoji {
  position: relative;
  font-size: 2.2rem;
  z-index: 1;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.3));
}
.mg-card-body { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 0.35rem; }
.mg-card-name {
  font-family: var(--mg-display);
  font-size: 1.5rem;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: 0.95;
  color: var(--text-primary);
}
.mg-card-desc { font-size: 0.84rem; line-height: 1.45; color: var(--text-muted); }
.mg-card-go {
  position: relative; z-index: 1;
  display: inline-flex; align-items: center; gap: 0.4rem;
  align-self: flex-start;
  font-size: 0.74rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--accent-glow);
  transition: gap 0.18s ease;
}
.mg-card--feature:hover .mg-card-go { gap: 0.7rem; }

/* Card "em breve" — fantasma tracejado */
.mg-card--soon {
  background: var(--bg-surface);
  border: 1px dashed var(--border-hover);
  cursor: default;
}
.mg-card--soon .mg-card-emoji { filter: grayscale(1); opacity: 0.6; }

/* ════════ ANIMAÇÕES ════════ */
@keyframes mg-rise {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes mg-pick-pop {
  0%   { transform: scale(0.97); }
  60%  { transform: scale(1.015); }
  100% { transform: scale(1); }
}
@keyframes mg-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.45; transform: scale(0.82); }
}
@keyframes mg-blink {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 60%, transparent); }
  50%      { box-shadow: 0 0 0 5px transparent; }
}

@media (prefers-reduced-motion: reduce) {
  .mg-round, .mg-duel, .mg-card { animation: none; }
  .mg-side--picked { animation: none; }
  .mg-chip-dot, .mg-live-dot { animation: none; }
}

/* ════════ RESPONSIVO (mobile-first hardening) ════════ */
@media (max-width: 860px) {
  .mg { gap: 1.1rem; }
  .mg-layout { grid-template-columns: 1fr; }
  .mg-aside { position: static; }
  .mg-fixtures { grid-template-columns: 1fr; }
  .mg-main { gap: 1.35rem; }
}
@media (max-width: 480px) {
  /* Hero mais enxuto pra os jogos subirem na dobra */
  .mg-board { padding: 1.35rem 1.1rem; }
  .mg-board-sub { font-size: 0.88rem; margin-top: 0.7rem; }
  .mg-scoreboard { margin-top: 1.1rem; }
  .mg-score { padding: 0.8rem 0.4rem; }
  .mg-score-num { font-size: 1.9rem; }
  .mg-score-label { font-size: 0.58rem; letter-spacing: 0.06em; }
  /* Painéis do duelo um pouco mais justos no estreito (mantém topo p/ a faixa) */
  .mg-side { padding: 1.65rem 0.5rem 1rem; }
  .mg-flag-wrap { width: 46px; height: 46px; }
  /* Cards do hub ocupam a largura cheia e ficam mais baixos */
  .mg-cards { grid-template-columns: 1fr; }
  .mg-card { min-height: 0; }
}
