body{ background:var(--bg); color:var(--text); }

.games{ margin-top:14px; }

.games-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.games-head h1{ margin:0; font-size:22px; letter-spacing:.4px; }
.games-head .muted{ margin-top:4px; }

.games-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:14px;
}

@media (max-width: 900px){
  .games-grid{ grid-template-columns:1fr; }
}

/* ================= Cards (grid) ================= */

.game-card{
  border:2px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.03);
  border-radius:18px;
  overflow:hidden;
  position:relative;
  box-shadow: 0 18px 50px rgba(0,0,0,.25);
  transform: translateZ(0);
  transition: transform .18s ease, border-color .18s ease, filter .18s ease;
}
.game-card:hover{ transform: translateY(-2px); filter: brightness(1.02); }

/* Faixa de cor do jogo (mais grossa e nítida) */
.game-card:before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:14px; /* ✅ mais grosso */
  background: var(--game-accent, rgba(255,255,255,.22));
  opacity:.92;
  pointer-events:none;
}

.game-banner{
  /*
    Enroll banner sem distorção:
    - o container “abraça” a imagem (sem altura fixa)
    - mantém a proporção nativa (height:auto)
    - sem “frame” maior que a imagem
  */
  width: fit-content;
  max-width: 100%;
  margin: 14px auto 10px auto;
  display:block;
  position:relative;
  border-radius:14px;
  overflow:hidden;
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
}

/* Em telas muito pequenas, reduz um pouco os espaçamentos */
@media (max-width: 520px){
  .game-banner{ margin: 12px auto 8px auto; border-radius:12px; }
}

.game-banner-img{
  /*
    Mantém proporção original do banner (sem crop e sem esticar).
    O banner se adapta ao card, mas nunca distorce.
  */
  display:block;
  max-width: min(792px, 100%);
  height:auto;
}
.game-banner:after{ content:''; position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.00) 0%, rgba(0,0,0,.10) 70%, rgba(0,0,0,.16) 100%); pointer-events:none; }

.game-banner-fallback{
  width: min(792px, 100%);
  aspect-ratio: 792 / 427;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.04);
}

.game-banner-title{ font-weight:900; font-size:20px; letter-spacing:.4px; }

.rules-cta{
  width:100%;
  border:0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.92);
  font-weight:900;
  letter-spacing:.6px;
  font-size:12px;
  padding:10px 12px;
  cursor:pointer;
}
.rules-cta:hover{ background:rgba(255,255,255,.07); }

.game-meta{ padding:10px 12px 12px; display:flex; flex-direction:column; gap:6px; }
.game-title{ font-weight:900; font-size:15px; line-height:1.1; }
.game-actions{ margin-top:4px; }

.game-meta-centered{ align-items:center; text-align:center; }
.game-meta-centered .game-actions{ width:100%; display:flex; justify-content:center; }

/* ================= Regras (modal) ================= */

.rules-modal{ position:fixed; inset:0; display:none; z-index:9999; }
.rules-modal.open{ display:block; }
.rules-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.62); }
.rules-dialog{
  position:relative;
  max-width:560px;
  margin:8vh auto 0;
  background:rgba(20,20,24,.96);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:14px;
  box-shadow:0 18px 60px rgba(0,0,0,.55);
}
.rules-close{
  position:absolute;
  top:10px;
  right:10px;
  width:32px;
  height:32px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:#fff;
  cursor:pointer;
  font-size:18px;
  line-height:1;
}
.rules-title{ font-weight:900; font-size:16px; letter-spacing:.2px; padding-right:42px; }
.rules-body{ margin-top:10px; display:flex; flex-direction:column; gap:6px; }
.rules-line{ color:rgba(255,255,255,.86); line-height:1.35; }

/* ================= Listas de lobbies/jogos ================= */

.games-listing{ margin-top:18px; }
.section-title{ margin:0; font-size:16px; letter-spacing:.3px; }

.match-list{ margin-top:10px; display:flex; flex-direction:column; gap:10px; }

.match-row{
  position:relative;
  border:1px solid rgba(255,255,255,.10);
  border-radius:16px;
  padding:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:rgba(255,255,255,.03);
  overflow:hidden;
}

/* Faixa de cor do jogo no lobby (mais grossa) */
.match-row:after{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:14px; /* ✅ mais grosso */
  background: var(--game-accent, rgba(255,255,255,.22));
  opacity:.92;
  pointer-events:none;
  z-index:1;
}

.match-row:before{
  content:'';
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 16% 10%, rgba(255,255,255,.08), transparent 45%);
  pointer-events:none;
  opacity:.65;
}

.match-main{ flex:1; min-width:0; text-align:center; position:relative; }
.match-title{ font-weight:900; letter-spacing:.25px; }
.match-sub{ margin-top:4px; display:flex; gap:8px; align-items:center; justify-content:center; flex-wrap:wrap; }
.match-lobbyline{ margin-top:6px; display:flex; gap:8px; align-items:center; justify-content:center; flex-wrap:wrap; }
.match-link{ color:rgba(255,255,255,.92); text-decoration:underline; text-underline-offset:2px; }

.match-actions{ flex:0 0 auto; position:relative; }

.rules-pill{
  position:absolute;
  top:10px;
  right:10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.30);
  color:#fff;
  font-weight:900;
  letter-spacing:.55px;
  font-size:11px;
  padding:6px 10px;
  cursor:pointer;
  z-index:3;
}
.rules-pill:hover{ filter:brightness(1.08); }

.chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:3px 9px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
}
.chip-filling{ background:rgba(255,255,255,.07); }
.chip-active{ background:rgba(80,255,170,.12); border-color:rgba(80,255,170,.22); }
.chip-finished{ background:rgba(255,255,255,.05); opacity:.9; }

/* ================= Cores por jogo ================= */

.game-color-default{ --game-accent: rgba(255,255,255,.22); --game-bg: rgba(255,255,255,.03); --game-border: rgba(255,255,255,.18); }
.game-color-ilha{ --game-accent: rgba(160,110,55,.55); --game-bg: rgba(160,110,55,.12); --game-border: rgba(160,110,55,.40); }
.game-color-casa{ --game-accent: rgba(80,160,255,.55); --game-bg: rgba(80,160,255,.10); --game-border: rgba(80,160,255,.40); }
.game-color-arena{ --game-accent: rgba(255,70,70,.55); --game-bg: rgba(255,70,70,.12); --game-border: rgba(255,70,70,.40); }
.game-color-cacadores{ --game-accent: rgba(245,205,95,.55); --game-bg: rgba(245,205,95,.12); --game-border: rgba(245,205,95,.40); }
.game-color-fazenda{ --game-accent: rgba(0,200,120,.50); --game-bg: rgba(0,200,120,.10); --game-border: rgba(0,200,120,.40); }
.game-color-mansao{ --game-accent: rgba(155,123,255,.55); --game-bg: rgba(155,123,255,.10); --game-border: rgba(155,123,255,.40); }

.match-row.game-color-default{ background:var(--game-bg); }
.match-row.game-color-ilha{ background:var(--game-bg); }
.match-row.game-color-casa{ background:var(--game-bg); }
.match-row.game-color-arena{ background:var(--game-bg); }
.match-row.game-color-cacadores{ background:var(--game-bg); }
.match-row.game-color-fazenda{ background:var(--game-bg); }
.match-row.game-color-mansao{ background:var(--game-bg); }

.game-card.game-color-default{ border-color:var(--game-border); }
.game-card.game-color-ilha{ border-color:var(--game-border); }
.game-card.game-color-casa{ border-color:var(--game-border); }
.game-card.game-color-arena{ border-color:var(--game-border); }
.game-card.game-color-cacadores{ border-color:var(--game-border); }
.game-card.game-color-fazenda{ border-color:var(--game-border); }
.game-card.game-color-mansao{ border-color:var(--game-border); }

.match-row.game-color-ilha{ border-color:var(--game-border); }
.match-row.game-color-casa{ border-color:var(--game-border); }
.match-row.game-color-arena{ border-color:var(--game-border); }
.match-row.game-color-cacadores{ border-color:var(--game-border); }
.match-row.game-color-fazenda{ border-color:var(--game-border); }
.match-row.game-color-mansao{ border-color:var(--game-border); }


@media (max-width: 700px){
  .match-row{ flex-direction:column; align-items:stretch; padding-top:40px; }
  .match-actions{ display:flex; justify-content:center; }
  .rules-pill{ top:10px; right:10px; }
}

.card{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
  border-radius:14px;
  padding:12px;
  margin-top:12px;
}

.game-meta .muted{ font-size:12px; opacity:.9; margin-top:-2px; }


/* ===== Abas: Reality Shows / Treinamento ===== */
.tg-games-tabs{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.tg-games-tab{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:999px;
  text-decoration:none; font-weight:1000;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.92);
  transition: transform .12s ease, background .12s ease;
}
.tg-games-tab:hover{ transform: translateY(-1px); background: rgba(255,255,255,.05); }
.tg-games-tab.active{
  background: linear-gradient(90deg, rgba(0,220,255,.9), rgba(140,90,255,.9));
  color: rgba(0,0,0,.88);
  border-color: transparent;
}
