@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Oswald:wght@500;600;700&display=swap');

/* =====================================================================
   Survivor — tema "estádio à noite": verde-gramado sobre fundo escuro.
   Uma única folha responsiva (desktop + mobile/m.bitsapiens).
   ===================================================================== */
:root {
  --bg:        #0e1411;
  --bg-2:      #0b1310;
  --panel:     #16201b;
  --panel-2:   #121a16;
  --line:      #1d2b25;
  --border:    #20302a;

  --field-1:   #0f3d28;  --field-2:   #0d3724;  --field-border: #1f6b45;
  --field-f1:  #0c3120;  --field-f2:  #0a2c1c;  --field-f-border: #234b39;

  --text:  #e9f0ec;  --muted: #8aa399;  --dim: #6f8a7e;
  --lime:  #a6f04a;  --lime-soft: rgba(166,240,74,.12);
  --red:   #ff5b5b;
  --gold:  #ffd24a;  --silver: #cfd6dd;  --bronze: #e0915a;

  --radius: 12px;  --radius-sm: 8px;
  --font:  'Inter', system-ui, 'Segoe UI', Arial, sans-serif;
  --font-head: 'Oswald', 'Inter', system-ui, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}
h1, h2, h3 { font-family: var(--font-head); font-weight: 600; letter-spacing: .5px; margin: 0 0 .6em; }
a { color: var(--lime); text-decoration: none; }
img { vertical-align: middle; }

/* ---- Telas de entrada (login/cadastro/reset): fundo de estádio ---- */
.bg-survivor {
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(31,107,69,.55), transparent 60%),
    radial-gradient(60% 50% at 50% 120%, rgba(166,240,74,.10), transparent 70%),
    var(--bg);
  min-height: 100vh;
}
.card-center { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 16px; }

/* ---- Cartões / caixas ---- */
.box {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  max-width: 420px; width: 100%;
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
}
.box.small { display: inline-block; width: auto; margin: 10px; vertical-align: top; }
.box h1, .box h3 { text-align: center; color: var(--text); }
.box h1 { color: var(--lime); }
.box label { display: block; margin: 10px 0; font-size: 14px; color: var(--muted); }
.box input {
  width: 100%; margin-top: 5px; padding: 11px 12px;
  background: #0c1310; color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-sm); font-size: 15px;
}
.box input:focus { outline: none; border-color: var(--lime); box-shadow: 0 0 0 3px var(--lime-soft); }
.links { display: flex; justify-content: space-between; gap: 8px; margin-top: 14px; align-items: center; }
.erro { color: var(--red); text-align: center; }

/* ---- Botões ---- */
.box button, .btn, button[type=submit] {
  font-family: var(--font); font-weight: 600; font-size: 15px;
  background: var(--lime); color: #0b2114;
  border: 0; padding: 11px 18px; border-radius: var(--radius-sm);
  cursor: pointer; text-decoration: none; display: inline-block; transition: filter .15s;
}
.box button:hover, .btn:hover { filter: brightness(1.08); }
.box button[onclick*="index"], .links button { background: #1f2c26; color: var(--text); }

/* ---- Barra superior ---- */
.topbar {
  display: flex; gap: 16px; align-items: center;
  background: var(--bg-2); border-bottom: 1px solid var(--line);
  padding: 12px 18px; position: sticky; top: 0; z-index: 20;
}
.topbar strong { font-family: var(--font-head); font-size: 19px; letter-spacing: 1px; }
.topbar a { color: var(--dim); }
.topbar a:hover { color: var(--lime); }
.topbar a + a { margin-left: 12px; }
.topbar span { color: var(--muted); font-size: 14px; }
.topbar b { color: var(--lime); }

.flash { background: rgba(166,240,74,.12); border: 1px solid var(--field-border); color: #d8ffb0; padding: 10px 18px; font-size: 14px; }

/* ---- Abas (pílulas) ---- */
.tabs {
  display: flex; flex-wrap: wrap; gap: 6px;
  padding: 12px 16px; background: var(--bg);
  position: sticky; top: 49px; z-index: 19;
}
.tab-btn {
  background: #172420; color: var(--muted);
  border: 1px solid transparent; padding: 8px 16px;
  border-radius: 999px; cursor: pointer; font-size: 13.5px; text-decoration: none;
  font-family: var(--font); transition: background .15s, color .15s;
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active { background: var(--lime); color: #0b2114; font-weight: 600; }
.tab-pane { display: none; padding: 18px; }
.tab-pane.active { display: block; }

/* ---- Tabelas (ranking / palpites) ---- */
.grid { border-collapse: collapse; width: 100%; background: transparent; }
.grid th, .grid td { border: 1px solid var(--border); padding: 8px 10px; font-size: 14px; }
.grid th { background: #13201a; color: var(--muted); font-weight: 500; text-align: left; }
.grid tbody tr { background: var(--panel-2); }
.grid tbody tr:nth-child(even) { background: var(--panel); }
.morto { color: var(--dim); }
.derrota { color: var(--red); font-weight: 600; }
.icone { width: 20px; height: 20px; }

/* Top 3 com medalha + sua linha destacada */
.medal-1 td:first-child { color: var(--gold); font-weight: 700; }
.medal-2 td:first-child { color: var(--silver); font-weight: 700; }
.medal-3 td:first-child { color: var(--bronze); font-weight: 700; }
.medal-1 { box-shadow: inset 3px 0 0 var(--gold); }
.medal-2 { box-shadow: inset 3px 0 0 var(--silver); }
.medal-3 { box-shadow: inset 3px 0 0 var(--bronze); }
.eu-linha { background: var(--lime-soft) !important; box-shadow: inset 3px 0 0 var(--lime); }
.nome-rank { cursor: pointer; }
.nome-rank:hover { color: var(--lime); }

/* ---- Tabuleiro de apostas (gramado) ---- */
.prazo { color: var(--muted); font-size: 13px; margin: 4px 0 14px; }
.prazo::before { content: "\23F1"; margin-right: 6px; }
.board-scroll { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 10px; scroll-snap-type: x proximity; }
.board {
  width: max-content; min-width: 360px; flex: 0 0 auto; scroll-snap-align: start;
  background: repeating-linear-gradient(90deg, var(--field-f1) 0 24px, var(--field-f2) 24px 48px);
  border: 1px solid var(--field-f-border); border-radius: var(--radius);
  padding: 10px; position: relative;
}
.board:first-child {
  background: repeating-linear-gradient(90deg, var(--field-1) 0 24px, var(--field-2) 24px 48px);
  border-color: var(--field-border); box-shadow: 0 0 0 1px rgba(166,240,74,.15), 0 10px 30px rgba(0,0,0,.35);
}
.board h3 { font-size: 14px; text-align: center; color: #bff29a; margin: 4px 0 10px; }
.board .grid { background: transparent; width: 100%; }
.board .grid td {
  border: 0; padding: 9px 8px; background: rgba(0,0,0,.18);
  border-radius: 7px; white-space: nowrap;
}
.board .grid tr { background: transparent; }
.board .grid tr td:first-child { border-radius: 7px 0 0 7px; }
.board .grid tr td:last-child { border-radius: 0 7px 7px 0; }
.time-dir { text-align: right; } .time-esq { text-align: left; }
.board .icone { width: 18px; height: 18px; margin: 0 5px; }
.x { text-align: center; color: #cfe0d7; font-size: 12px; white-space: nowrap; padding: 0 8px; width: 1%; }
.x b { color: #fff; }

/* Estados dos times */
.t-vermelho { color: var(--red) !important; font-weight: 600; }       /* selecionado */
.t-branco   { color: #fff !important; }                                /* disponível  */
.t-amarelo  { color: var(--gold) !important; font-weight: 600; }        /* futuro      */
.t-preto    { color: var(--dim) !important; text-decoration: line-through; } /* já usado */
a.aposta-link { display: inline-block; padding: 2px 4px; border-radius: 6px; }
a.aposta-link:hover { background: rgba(255,255,255,.08); }

.legenda { margin-top: 12px; font-size: 13px; color: var(--muted); }
.legenda span { font-size: 16px; padding: 0 3px 0 12px; }

/* ---- Filtro de grupo ---- */
.filtro { margin-bottom: 12px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.filtro label { color: var(--muted); font-size: 14px; }
.filtro input, .filtro select { background: #0c1310; color: var(--text); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 9px 12px; font-size: 14px; }
.filtro select { min-width: 200px; }
.filtro button { background: #1f2c26; color: var(--text); border: 0; padding: 9px 16px; border-radius: var(--radius-sm); cursor: pointer; }
.filtro button:hover { background: #27382f; }

/* ---- Palpites (matriz participantes x rodadas) ---- */
.palp-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 6px; }
.palp-matrix { border-collapse: separate; border-spacing: 4px; }
.palp-matrix th { color: var(--muted); font-weight: 400; font-size: 11px; min-width: 34px; text-align: center; }
.palp-matrix th.sticky-col, .palp-matrix td.sticky-col {
  position: sticky; left: 0; z-index: 2; text-align: left;
  background: var(--bg); min-width: 130px; padding: 4px 10px 4px 2px;
}
.palp-matrix thead th.sticky-col { color: var(--muted); }
.palp-matrix td.nome { font-size: 13px; font-weight: 500; }
.palp-matrix tr.morto td.nome { color: var(--dim); text-decoration: line-through; }
.palp-matrix tr.morto { opacity: .55; }
.palp-matrix tr.eu-linha td.nome { color: var(--lime); background: var(--bg); box-shadow: inset 3px 0 0 var(--lime); }

.palp-cell {
  width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
  border-radius: 7px; border: 1px solid transparent; margin: auto;
}
.palp-cell img { width: 22px; height: 22px; }
.palp-cell[data-time] { cursor: pointer; }
.res-vit { background: rgba(31,122,77,.35);  border-color: #2ecc71; }
.res-emp { background: rgba(255,210,74,.18);  border-color: var(--gold); }
.res-der { background: rgba(255,91,91,.18);   border-color: var(--red); }
.res-pend{ background: rgba(255,255,255,.05);  border-color: var(--border); }
.sem-aposta { border: 1px dashed var(--red); color: var(--red); font-weight: 600; }
.vazio { color: #46544c; }

.palp-legenda { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 12px; font-size: 12px; color: var(--muted); align-items: center; }
.palp-legenda .leg { display: inline-block; width: 12px; height: 12px; border-radius: 3px; border: 1px solid transparent; vertical-align: -1px; margin-right: 4px; }
.palp-dica { color: var(--dim); font-style: italic; }

/* Balão com o nome do time ao clicar numa célula */
.palp-balloon {
  position: fixed; z-index: 60; background: var(--panel); color: var(--text);
  border: 1px solid var(--field-border); border-radius: 10px; padding: 8px 12px;
  font-size: 13px; box-shadow: 0 10px 30px rgba(0,0,0,.55); max-width: 220px;
}
.palp-balloon .b-time { font-weight: 600; display: flex; align-items: center; gap: 6px; }
.palp-balloon .b-res { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* ---- Estatísticas ---- */
.est { max-width: 720px; }
.est-head { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; }
.est-title { font-family: var(--font-head); font-size: 18px; color: var(--lime); letter-spacing: .5px; }
.est-sel { color: var(--muted); font-size: 14px; }
.est-sel select { background: #0c1310; color: var(--text); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 8px 12px; margin-left: 6px; }
.est-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 18px; }
.est-card { background: var(--panel); border-radius: 9px; padding: 12px 14px; }
.est-lbl { font-size: 12px; color: var(--muted); }
.est-num { font-family: var(--font-head); font-size: 26px; font-weight: 600; }
.est-num.verde { color: var(--lime); } .est-num.vermelho { color: var(--red); } .est-num.amarelo { color: var(--gold); }
.est-sub { font-size: 12px; color: var(--muted); letter-spacing: .5px; text-transform: uppercase; margin: 6px 0 10px; }
.est-bars { display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.est-bar { display: flex; align-items: center; gap: 10px; }
.est-bar-time { width: 150px; display: flex; align-items: center; gap: 6px; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.est-bar-time .icone { width: 18px; height: 18px; flex-shrink: 0; }
.est-bar-track { flex: 1; height: 16px; background: var(--panel); border-radius: 5px; overflow: hidden; }
.est-bar-fill { display: block; height: 100%; background: var(--lime); border-radius: 5px; }
.est-bar-val { width: 86px; text-align: right; font-size: 12px; color: #cfe0d7; white-space: nowrap; }
svg.est-curva { width: 100%; height: 90px; display: block; }

/* ---- "Times disponíveis" ---- */
.restante { margin-top: 14px; }
.restante:not(:empty) {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px;
}
.restante.aberto { z-index: 50; box-shadow: 0 14px 40px rgba(0,0,0,.6); max-height: 60vh; overflow: auto; }
.pop-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.pop-head b { font-size: 15px; color: var(--text); }
.fechar-restante { color: var(--lime); font-weight: 600; font-size: 16px; line-height: 1; flex-shrink: 0; }
.pop-body { line-height: 2; font-size: 14px; color: #d4e2da; }
.pop-label { display: block; color: var(--muted); font-size: 12px; margin-bottom: 4px; }
.pop-body .icone { width: 20px; height: 20px; margin: 0 4px 0 8px; }

/* ---- Área administrativa ---- */
.admin { max-width: 1100px; margin: 0 auto; padding: 18px; }
.panel {
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 18px 20px; margin-bottom: 18px;
}
.panel h3 { color: var(--lime); display: flex; align-items: center; gap: 10px; }
.panel .badge { background: #1f2c26; color: var(--text); font-size: 12px; font-weight: 500; padding: 2px 10px; border-radius: 999px; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.vazio { color: var(--muted); text-align: center; padding: 16px; }

/* ---- Texto longo (regulamento/dúvidas) ---- */
.texto { max-width: 820px; line-height: 1.7; color: #d4e2da; }
.texto h2 { color: var(--lime); font-size: 18px; margin-top: 1.2em; }
.texto b { color: var(--text); }
.hint { font-size: 12px; color: var(--dim); }

/* ---- Chat ---- */
.chat { max-width: 720px; margin: 20px auto; padding: 0 12px; }
.chat-box { height: 480px; overflow: auto; background: var(--panel-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px; }
.chat-meta { color: var(--muted); font-weight: 500; }
.chat-msg { color: #bff29a; }
.chat form { display: flex; gap: 6px; margin-top: 8px; }
.chat input { flex: 1; padding: 11px; background: #0c1310; color: var(--text); border: 1px solid var(--border); border-radius: var(--radius-sm); }

/* =====================================================================
   RESPONSIVO / MOBILE — mesma base, layout adaptado ao celular.
   ===================================================================== */
@media (max-width: 640px) {
  body { font-size: 15px; -webkit-text-size-adjust: 100%; }
  .topbar { flex-wrap: wrap; gap: 8px; font-size: 14px; padding: 10px 14px; }
  .tabs { top: 44px; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .tab-btn { white-space: nowrap; padding: 10px 14px; }
  .tab-pane { padding: 12px; }

  .box, .box.small { max-width: 100%; width: 100%; margin: 8px 0; }
  .card-center { padding: 12px; }
  .box input { padding: 13px; font-size: 16px; }     /* 16px evita zoom no iOS */
  .box button, .btn { padding: 13px 16px; font-size: 16px; width: 100%; }
  .links { flex-direction: column; }

  /* Cada rodada ocupa quase a tela toda; rolagem horizontal por cards. */
  .board-scroll { gap: 10px; scroll-snap-type: x mandatory; }
  .board { width: auto; min-width: 88vw; scroll-snap-align: start; }

  .board .grid td { padding: 11px 8px; }
  .icone { width: 22px; height: 22px; }

  /* Ranking esconde colunas secundárias no celular. */
  .grid th, .grid td { padding: 7px 6px; font-size: 13px; }
  #tab-ranking .grid th:nth-child(4), #tab-ranking .grid td:nth-child(4),
  #tab-ranking .grid th:nth-child(5), #tab-ranking .grid td:nth-child(5),
  #tab-ranking .grid th:nth-child(6), #tab-ranking .grid td:nth-child(6),
  #tab-ranking .grid th:nth-child(7), #tab-ranking .grid td:nth-child(7) { display: none; }

  /* Estatísticas mais compactas no celular. */
  .est-bar-time { width: 92px; font-size: 12px; }
  .est-bar-val { width: 68px; }
  .est-cards { gap: 6px; }
  .est-num { font-size: 22px; }

  /* "Times disponíveis" como folha fixa no rodapé. */
  .restante:not(:empty) {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 30;
    border-radius: 14px 14px 0 0; max-height: 45vh; overflow: auto;
    box-shadow: 0 -8px 24px rgba(0,0,0,.5);
  }
  .chat { margin: 10px auto; }
  .chat-box { height: 60vh; }
  .chat input { font-size: 16px; }
}

@media (max-width: 380px) {
  .palpite-user { width: 100%; }
}
