/* ============================================================
   Sorteador Fut6 — Estilos globais
   Mobile-first, legível de longe na quadra
   ============================================================ */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --verde:      #1a7a2e;
  --verde-esc:  #115c20;
  --verde-claro:#2db84b;
  --amarelo:    #f5c518;
  --branco:     #f8f9fa;
  --cinza-bg:   #121212;
  --cinza-card: #1e1e1e;
  --cinza-borda:#2e2e2e;
  --texto:      #e8e8e8;
  --texto-fraco:#888;
  --vermelho:   #c0392b;
  --radius:     10px;
  --sombra:     0 2px 8px rgba(0,0,0,.4);
}

html {
  font-size: 16px;
}

body {
  background: var(--cinza-bg);
  color: var(--texto);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  line-height: 1.5;
  min-height: 100vh;
}

/* ---------- Layout ---------- */

.container {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 16px 40px;
}

header {
  background: var(--verde-esc);
  padding: 18px 16px;
  text-align: center;
  box-shadow: var(--sombra);
  margin-bottom: 24px;
}

header h1 {
  font-size: 1.6rem;
  color: var(--amarelo);
  letter-spacing: 1px;
}

header p {
  color: #ccc;
  font-size: .85rem;
  margin-top: 4px;
}

.header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 32px;
	width: 100%;
	max-width: 550px;
	margin: 0 auto;
}
.btn-link {
  background: #cbcbcb;
  border-radius: 100px;
  padding: 2px 24px;
  text-decoration: none;
  color: #333;
  font-weight: 600;

}

/* ---------- Seções ---------- */

.secao {
  background: var(--cinza-card);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  padding: 18px;
  margin-bottom: 20px;
}

.secao h2 {
  font-size: 1rem;
  color: var(--verde-claro);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 14px;
}

/* ---------- Lista de mensalistas ---------- */

.lista-mensalistas {
  list-style: none;
    display: flex;
    width: 100%;
    /* flex-direction: column; */
    gap: 8px;
    flex-wrap: wrap;
}

.lista-mensalistas li label {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--cinza-bg);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 1rem;
  transition: background .15s;
}

.lista-mensalistas li label:active {
  background: #2a2a2a;
}

.lista-mensalistas li input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: var(--verde-claro);
  cursor: pointer;
  flex-shrink: 0;
}

.lista-mensalistas li label.marcado {
  border-color: var(--verde-claro);
  background: rgba(45,184,75,.08);
}

/* ---------- Avulsos ---------- */

.busca-avulso {
  display: flex;
  gap: 8px;
  margin-bottom: 12px;
}

.busca-avulso input {
  flex: 1;
  padding: 11px 14px;
  background: var(--cinza-bg);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  color: var(--texto);
  font-size: 1rem;
}

.busca-avulso input:focus {
  outline: none;
  border-color: var(--verde-claro);
}

.sugestoes {
  list-style: none;
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 10px;
  display: none;
}

.sugestoes.visivel {
  display: block;
}

.sugestoes li {
  padding: 11px 14px;
  cursor: pointer;
  font-size: .95rem;
  background: var(--cinza-bg);
  border-bottom: 1px solid var(--cinza-borda);
  transition: background .1s;
}

.sugestoes li:last-child {
  border-bottom: none;
}

.sugestoes li:hover, .sugestoes li:active {
  background: #2a2a2a;
}

.sugestoes li .vezes {
  font-size: .8rem;
  color: var(--texto-fraco);
  margin-left: 6px;
}

.tags-avulsos {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tag-avulso {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(45,184,75,.15);
  border: 1px solid var(--verde-claro);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: .9rem;
  color: var(--texto);
}

.tag-avulso button {
  background: none;
  border: none;
  color: var(--texto-fraco);
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0;
}

.tag-avulso button:hover {
  color: var(--vermelho);
}

/* ---------- Contador de jogadores ---------- */

.contador {
  text-align: center;
  font-size: 1rem;
  color: var(--texto-fraco);
  margin-bottom: 4px;
}

.contador span {
  font-size: 1.3rem;
  font-weight: bold;
  color: var(--amarelo);
}

/* ---------- Botões ---------- */

.btn {
  display: inline-block;
  padding: 14px 24px;
  border: none;
  border-radius: var(--radius);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
  text-decoration: none;
  text-align: center;
}

.btn:active {
  transform: scale(.97);
  opacity: .9;
}

.btn-primario {
  background: var(--verde);
  color: #fff;
  width: 100%;
  font-size: 1.15rem;
  padding: 16px;
}

.btn-primario:hover {
  background: var(--verde-claro);
}

.btn-primario:disabled {
  background: #444;
  color: #666;
  cursor: not-allowed;
  transform: none;
}

.btn-secundario {
  background: #2a2a2a;
  color: var(--texto);
  border: 1px solid var(--cinza-borda);
}

.btn-perigo {
  background: var(--vermelho);
  color: #fff;
}

.btn-sm {
  padding: 7px 14px;
  font-size: .85rem;
}

/* ---------- Resultado do sorteio ---------- */

#resultado {
  display: none;
}

#resultado.visivel {
  display: block;
}

.time-card {
  border-radius: var(--radius);
  padding: 18px;
  margin-bottom: 16px;
  box-shadow: var(--sombra);
}

.time-card.jogando {
  background: var(--verde-esc);
  border: 2px solid var(--verde-claro);
}

.time-card.proximo {
  background: var(--cinza-card);
  border: 1px solid var(--cinza-borda);
}

.time-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.time-titulo {
  font-size: 1.3rem;
  font-weight: 700;
}

.time-card.jogando .time-titulo {
  color: var(--amarelo);
}

.time-badge {
  font-size: .75rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.badge-jogando {
  background: var(--amarelo);
  color: #000;
}

.badge-proximo {
  background: #333;
  color: var(--texto-fraco);
}

.time-jogadores {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.time-jogadores li {
  font-size: 1.1rem;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
  display: flex;
  align-items: center;
  gap: 8px;
}

.time-jogadores li:last-child {
  border-bottom: none;
}

.time-jogadores li::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--verde-claro);
  border-radius: 50%;
  flex-shrink: 0;
}

.time-card.jogando .time-jogadores li::before {
  background: var(--amarelo);
}

/* ---------- Mensagens de estado ---------- */

.msg-vazio {
  text-align: center;
  color: var(--texto-fraco);
  padding: 16px;
  font-size: .9rem;
}

.msg-erro {
  color: var(--vermelho);
  font-size: .9rem;
  margin-top: 8px;
}

/* ---------- Admin ---------- */

.admin-nav {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.tabela-admin {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}

.tabela-admin th {
  text-align: left;
  padding: 10px 12px;
  background: #1a1a1a;
  color: var(--texto-fraco);
  font-weight: 600;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .4px;
}

.tabela-admin td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--cinza-borda);
}

.tabela-admin tr:last-child td {
  border-bottom: none;
}

.tabela-admin tr.inativo td {
  opacity: .45;
}

.badge-ativo {
  display: inline-block;
  padding: 3px 9px;
  border-radius: 12px;
  font-size: .78rem;
  font-weight: 600;
}

.badge-ativo.sim  { background: rgba(45,184,75,.2);  color: var(--verde-claro); }
.badge-ativo.nao  { background: rgba(192,57,43,.2);  color: #e74c3c; }

.form-inline {
  display: flex;
  gap: 8px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.form-inline input {
  flex: 1;
  min-width: 180px;
  padding: 10px 14px;
  background: var(--cinza-bg);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  color: var(--texto);
  font-size: .95rem;
}

.form-inline input:focus {
  outline: none;
  border-color: var(--verde-claro);
}

/* ---------- Login ---------- */

.login-card {
  max-width: 340px;
  margin: 80px auto 0;
  background: var(--cinza-card);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  padding: 32px 24px;
  text-align: center;
}

.login-card h2 {
  font-size: 1.2rem;
  color: var(--amarelo);
  margin-bottom: 20px;
}

.login-card input {
  width: 100%;
  padding: 12px 14px;
  background: var(--cinza-bg);
  border: 1px solid var(--cinza-borda);
  border-radius: var(--radius);
  color: var(--texto);
  font-size: 1rem;
  margin-bottom: 14px;
}

.login-card input:focus {
  outline: none;
  border-color: var(--verde-claro);
}

/* ---------- Utilitários ---------- */

.mt-8  { margin-top:  8px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mb-16 { margin-bottom: 16px; }
.text-center { text-align: center; }
.oculto { display: none !important; }

@media (max-width: 400px) {
  header h1 { font-size: 1.3rem; }
  .btn-primario { font-size: 1rem; }
  .time-titulo  { font-size: 1.1rem; }
  .time-jogadores li { font-size: 1rem; }
}
