/* =========================
   Copa dos CLT - style.css (Copa10)
   - iPhone safe / sem estourar pros lados
   - Cards / Tabs / Botões padrão
   - Chaveamento: logos menores + layout mais “frente a frente”
   - Ranking: tabela estilo Brasileirão (linhas alinhadas)
========================= */

:root{
  --bg1:#051624;
  --bg2:#03111d;
  --card: rgba(8, 20, 34, .62);
  --card2: rgba(8, 20, 34, .42);
  --stroke: rgba(255,255,255,.10);
  --stroke2: rgba(255,255,255,.14);
  --txt: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.66);

  --blue1:#2aa7ff;
  --blue2:#2b6bff;
  --green1:#1ee37a;
  --green2:#0bbf5f;
  --red1:#ff5b5b;
  --red2:#d63b3b;

  --r: 22px;
  --r2: 18px;
}

/* ===== reset iPhone / sem overflow ===== */
*{ box-sizing: border-box; }
html, body{
  height: 100%;
}
html{
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  overflow-x: hidden;            /* importante: corta estourado lateral */
}
body{
  margin:0;
  color: var(--txt);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(1100px 900px at 25% 0%, rgba(50,110,160,.45), transparent 55%),
    radial-gradient(900px 700px at 70% 35%, rgba(0,255,180,.14), transparent 55%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
  overflow-x: hidden;            /* importante */
}

/* evita elementos grandes quebrarem layout */
img, video, canvas{
  max-width: 100%;
  height: auto;
}

a{ color: inherit; }

/* ===== container ===== */
.container{
  width: min(720px, 100%);
  margin: 0 auto;
  padding: 16px 14px 40px;
}

/* ===== util ===== */
.hidden{ display:none !important; }
.muted{ color: var(--muted); }
.label{
  display:block;
  font-size: 13px;
  color: var(--muted);
  margin: 6px 0 6px;
  font-weight: 700;
}

/* ===== cards ===== */
.card{
  background: var(--card);
  border: 1px solid var(--stroke);
  border-radius: var(--r);
  padding: 16px;
  box-shadow: 0 24px 60px rgba(0,0,0,.38);
  backdrop-filter: blur(10px);
}

.header.card{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  position: sticky;
  top: 10px;
  z-index: 20;
}

/* ===== inputs ===== */
.input{
  width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
  color: var(--txt);
  padding: 12px 14px;
  outline: none;
  font-size: 16px;
}
.input:focus{
  border-color: rgba(42,167,255,.45);
  box-shadow: 0 0 0 3px rgba(42,167,255,.12);
}

/* deixa select mais “Copa10” */
select.input{
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.65) 50%),
    linear-gradient(135deg, rgba(255,255,255,.65) 50%, transparent 50%),
    linear-gradient(to right, rgba(255,255,255,.0), rgba(255,255,255,.0));
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px),
    0 0;
  background-size: 6px 6px, 6px 6px, 100% 100%;
  background-repeat: no-repeat;
  padding-right: 36px;
}

/* ===== buttons ===== */
.btn{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--txt);
  padding: 12px 14px;
  border-radius: 18px;
  font-weight: 900;
  letter-spacing: .2px;
  cursor: pointer;
  transition: transform .08s ease, filter .2s ease, background .2s ease, border-color .2s ease;
  user-select: none;
}
.btn:active{ transform: scale(.98); }
.btn-full{ width: 100%; }

.btn-ghost{
  background: rgba(255,255,255,.06);
}
.btn-ghost.active{
  background: linear-gradient(135deg, rgba(42,167,255,.38), rgba(43,107,255,.30));
  border-color: rgba(42,167,255,.42);
}

.btn-success{
  border-color: rgba(30,227,122,.25);
  background: linear-gradient(135deg, rgba(30,227,122,.88), rgba(11,191,95,.78));
  color: rgba(0,0,0,.82);
}
.btn-danger{
  border-color: rgba(255,91,91,.28);
  background: linear-gradient(135deg, rgba(255,91,91,.92), rgba(214,59,59,.84));
  color: rgba(0,0,0,.86);
}

/* ===== tabs ===== */
.tabs{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}
.tab{
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: var(--txt);
  padding: 10px 14px;
  border-radius: 18px;
  font-weight: 900;
  cursor:pointer;
}
.tab.active{
  background: linear-gradient(135deg, rgba(42,167,255,.55), rgba(43,107,255,.42));
  border-color: rgba(42,167,255,.50);
}
.tab-panel{ margin-top: 14px; }

/* ===== text blocks inside areas ===== */
#publicInfo, #adminLinkArea, #cardsJogos, #participantesArea, #timesArea, #bracketAdminArea, #rankingArea{
  overflow-x: hidden;
}

/* =========================================================
   CHAVEAMENTO / CONFRONTOS (CSS “padrão Copa10”)
   - o app.js gera HTML “solto”, então aqui a gente fortalece
     visual com seletores genéricos.
========================================================= */

/* LOGOS menores (resolve a “logo gigante” estourando) */
#bracketAdminArea img,
#publicBracket img{
  max-height: 120px;
  width: auto;
  display:block;
  margin: 10px auto;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.45));
}

/* quando o app.js coloca logo gigante antes de selects */
#bracketAdminArea img + .input,
#bracketAdminArea img + select,
#publicBracket img + .input,
#publicBracket img + select{
  margin-top: 8px;
}

/* tenta forçar “confronto frente a frente” quando houver blocos repetidos */
#bracketAdminArea > div,
#publicBracket > div{
  max-width: 100%;
}

/* inputs de placar A x B mais alinhados */
#bracketAdminArea input[type="number"],
#publicBracket input[type="number"]{
  width: 88px;
  text-align: center;
  font-weight: 900;
  font-size: 18px;
  border-radius: 18px;
}

/* onde tem “A x B”, geralmente é um texto solto: melhora espaçamento */
#bracketAdminArea,
#publicBracket{
  display: block;
}

/* botão confirmar e salvar mais consistentes */
#bracketAdminArea button,
#publicBracket button{
  border-radius: 18px;
}

/* melhora “linhas” de resultado já confirmado */
#bracketAdminArea .muted,
#publicBracket .muted{
  line-height: 1.35;
}

/* ===== Destaques (Final / Semi / Vencedor) =====
   Se o app.js criar algo como "Final", "Semi", ou usar ✅,
   o CSS não adivinha 100%, mas deixei ganchos.
*/
@keyframes winnerPulse{
  0%,100%{ transform: translateY(0) scale(1); filter: drop-shadow(0 12px 24px rgba(0,0,0,.45)); }
  50%{ transform: translateY(-2px) scale(1.03); filter: drop-shadow(0 16px 34px rgba(0,0,0,.55)); }
}
.winner-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 1000;
  background: linear-gradient(135deg, rgba(30,227,122,.92), rgba(42,167,255,.30));
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(0,0,0,.85);
  animation: winnerPulse 1.4s ease-in-out infinite;
}

/* =========================================================
   RANKING - “Tabela Brasileirão”
   O app.js às vezes imprime texto (1. Nome 3 gol(s)).
   Vamos transformar o visual com CSS:
   - qualquer lista/linhas viram “rows” com coluna esquerda/direita.
========================================================= */

/* container do ranking */
#rankingArea{
  padding-bottom: 12px;
}

/* quando o ranking vier como texto com quebras, melhora legibilidade */
#rankingArea{
  font-size: 16px;
}
#rankingArea h1, #rankingArea h2, #rankingArea h3{
  margin: 10px 0 10px;
}

/* Se o app.js renderizar itens em <div> ou <p> */
#rankingArea p{
  margin: 8px 0;
  color: var(--txt);
}

/* Se o app.js renderizar como <ol><li> */
#rankingArea ol{
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
}
#rankingArea li{
  margin: 10px 0;
}

/* “row” genérico: se o app.js já cria cards, ok; se não, você ainda ganha estilo no texto */
.rank-table{
  margin-top: 12px;
  border-radius: var(--r);
  border: 1px solid var(--stroke);
  background: rgba(0,0,0,.18);
  overflow: hidden;
}
.rank-row{
  display: grid;
  grid-template-columns: 54px 1fr 110px;
  gap: 10px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.rank-row:last-child{ border-bottom: none; }
.rank-pos{
  width: 44px;
  height: 34px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 1000;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}
.rank-name{
  font-weight: 950;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rank-val{
  text-align: right;
  font-weight: 1000;
  color: rgba(255,255,255,.90);
}

/* top 1/2/3 com “efeito pódio” */
.rank-row.top1 .rank-pos{ background: linear-gradient(135deg, rgba(255,215,0,.45), rgba(255,255,255,.06)); border-color: rgba(255,215,0,.35); }
.rank-row.top2 .rank-pos{ background: linear-gradient(135deg, rgba(192,192,192,.35), rgba(255,255,255,.06)); border-color: rgba(192,192,192,.26); }
.rank-row.top3 .rank-pos{ background: linear-gradient(135deg, rgba(205,127,50,.35), rgba(255,255,255,.06)); border-color: rgba(205,127,50,.26); }

/* Se o app.js renderizar “cards de ranking” como no seu print melhorado */
.ranking-card, .rankingList, .ranking-list{
  border-radius: var(--r);
  border: 1px solid var(--stroke);
  background: rgba(0,0,0,.18);
  overflow: hidden;
}
.ranking-item, .rankingRow, .ranking-row{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ranking-item:last-child, .rankingRow:last-child, .ranking-row:last-child{
  border-bottom: none;
}
.ranking-left{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width: 0;
}
.ranking-right{
  font-weight: 1000;
  white-space: nowrap;
}
.ranking-pos{
  width: 38px;
  height: 30px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 1000;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}
.ranking-name{
  font-weight: 950;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ===== melhorar botões dentro do ranking (Campeões / Artilheiros) ===== */
#rankingArea .tab, #rankingArea button{
  max-width: 100%;
}

/* ===== “consertos” extras de iPhone: não deixar nada sair do container ===== */
.header, .card, .tabs, .tab-panel, #modalAdminCard{
  max-width: 100%;
}
.top-actions{
  max-width: 100%;
}