/* ===========================================================
   Brasileirão Série A 2026 — Tema Escuro
   Mesmo design base da copa2026
   =========================================================== */

:root {
    --cor-fundo: #0D0F14;
    --cor-superficie: #161B25;
    --cor-superficie-alt: #1D2330;
    --cor-acento: #00E5A0;       /* verde Brasileirão */
    --cor-ambar: #F5A623;
    --cor-texto: #E8EAED;
    --cor-texto-secundario: #9AA4B2;
    --cor-borda: #262C3A;
    --cor-vermelho: #FF5C5C;
    --cor-azul: #3B82F6;

    /* Zonas */
    --cor-g6: #00E5A0;           /* Libertadores */
    --cor-g7: #3B82F6;           /* Sul-Americana */
    --cor-z4: #FF5C5C;           /* Rebaixamento */
}

* { box-sizing: border-box; }

body {
    background-color: var(--cor-fundo);
    color: var(--cor-texto);
    font-family: 'Inter', sans-serif;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

a {
    color: var(--cor-acento);
    text-decoration: none;
}
a:hover { color: var(--cor-ambar); }

/* ---- Utilitários ---- */
.text-acento   { color: var(--cor-acento) !important; }
.text-ambar    { color: var(--cor-ambar) !important; }
.text-vermelho { color: var(--cor-vermelho) !important; }
.text-azul     { color: var(--cor-azul) !important; }
.text-texto    { color: var(--cor-texto) !important; }
.fw-500        { font-weight: 500; }
.fw-600        { font-weight: 600; }
.bg-superficie { background-color: var(--cor-superficie) !important; }
.border-borda  { border-color: var(--cor-borda) !important; }
.border-vermelho { border-color: var(--cor-vermelho) !important; }

/* ---- Navbar ---- */
.navbar-brasileirao {
    background-color: var(--cor-superficie);
    border-bottom: 1px solid var(--cor-borda);
}
.navbar-brasileirao .navbar-brand {
    font-weight: 700;
    font-size: 1.1rem;
    color: var(--cor-texto) !important;
    letter-spacing: 0.3px;
}
.navbar-brasileirao .navbar-brand .accent { color: var(--cor-acento); }
.navbar-brasileirao .navbar-brand .brand-year { color: var(--cor-ambar); }
.navbar-brasileirao .brand-icon { font-size: .95rem; }
.navbar-brasileirao .nav-link {
    color: var(--cor-texto-secundario) !important;
    font-weight: 500;
    font-size: .9rem;
    transition: color .15s;
}
.navbar-brasileirao .nav-link.active,
.navbar-brasileirao .nav-link:hover { color: var(--cor-acento) !important; }

/* ---- Cards ---- */
.card-copa {
    background-color: var(--cor-superficie);
    border: 1px solid var(--cor-borda);
    border-radius: 12px;
}
.card-copa-header {
    background-color: var(--cor-superficie-alt);
    border-bottom: 1px solid var(--cor-borda);
    border-radius: 12px 12px 0 0;
    padding: .85rem 1.1rem;
    font-weight: 700;
    font-size: .9rem;
}

/* ---- Botões ---- */
.btn-acento {
    background-color: var(--cor-acento);
    color: #06120c;
    font-weight: 600;
    border: none;
}
.btn-acento:hover {
    background-color: #00ccbe;
    color: #06120c;
}
.btn-outline-acento {
    border: 1px solid var(--cor-acento);
    color: var(--cor-acento);
    background: transparent;
    font-weight: 500;
}
.btn-outline-acento:hover {
    background-color: var(--cor-acento);
    color: #06120c;
}

/* ---- Escudos ---- */
.escudo {
    width: 24px;
    height: 24px;
    object-fit: contain;
    border-radius: 3px;
    vertical-align: middle;
    flex-shrink: 0;
}
.escudo-lg {
    width: 40px;
    height: 40px;
}
.escudo-time-card {
    width: 56px;
    height: 56px;
    object-fit: contain;
}
.escudo-placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    background: var(--cor-superficie-alt);
    border: 1px solid var(--cor-borda);
    border-radius: 4px;
    font-size: .65rem;
    font-weight: 700;
    color: var(--cor-texto-secundario);
    flex-shrink: 0;
}
.escudo-placeholder-lg {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    background: var(--cor-superficie-alt);
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--cor-texto-secundario);
}

/* ---- Time nome (card de jogo) ---- */
.time-nome {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    flex: 1 1 0%;
    min-width: 0;
}
.time-nome span {
    overflow-wrap: break-word;
    font-size: .88rem;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ---- Cards de jogo ---- */
.jogo-card {
    background-color: var(--cor-superficie);
    border: 1px solid #1E2736;
    border-radius: 10px;
    padding: .9rem 1rem;
    transition: border-color .15s;
}
.jogo-card:hover { border-color: var(--cor-acento); }
.jogo-card.ao-vivo { border-color: rgba(255,92,92,.5); }

.jogo-placar {
    flex-shrink: 0;
    min-width: 56px;
}
.placar-num {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--cor-texto);
}
.placar-sep {
    font-size: 1.2rem;
    color: var(--cor-texto-secundario);
    margin: 0 .15rem;
}
.horario-jogo {
    font-size: 1rem;
    font-weight: 600;
    color: var(--cor-ambar);
}

/* ---- Status badges ---- */
.status-badge {
    display: inline-block;
    border-radius: 999px;
    padding: 2px 10px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.badge-ao-vivo {
    background-color: var(--cor-vermelho);
    color: #fff;
    animation: pulso 1.6s infinite;
}
.badge-encerrado {
    background-color: var(--cor-acento);
    color: #06120c;
}
.badge-agendado {
    background-color: var(--cor-superficie-alt);
    color: var(--cor-texto-secundario);
}

@keyframes pulso {
    0%   { box-shadow: 0 0 0 0 rgba(255,92,92,.55); }
    70%  { box-shadow: 0 0 0 7px rgba(255,92,92,0); }
    100% { box-shadow: 0 0 0 0 rgba(255,92,92,0); }
}

/* ---- Separadores de data ---- */
.data-separador {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.data-separador::before,
.data-separador::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--cor-borda);
}
.data-separador span {
    font-size: .75rem;
    font-weight: 600;
    color: var(--cor-texto-secundario);
    text-transform: uppercase;
    letter-spacing: .05em;
    white-space: nowrap;
}

.rodada-header {
    border-left: 3px solid var(--cor-acento);
    padding-left: .75rem;
}

/* ---- Tabela de classificação ---- */
.table-classificacao {
    color: var(--cor-texto);
    margin-bottom: 0;
    font-size: .88rem;
}
.table-classificacao thead th {
    background-color: var(--cor-superficie-alt);
    color: var(--cor-texto-secundario);
    border-bottom: 1px solid var(--cor-borda);
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .6rem .75rem;
    white-space: nowrap;
}
.table-classificacao td,
.table-classificacao th {
    border-color: var(--cor-borda);
    vertical-align: middle;
    padding: .55rem .75rem;
}
.table-classificacao tbody tr:hover td {
    background-color: rgba(255,255,255,.025);
}

/* Barra lateral de zona */
.zona-barra {
    width: 3px;
    height: 28px;
    border-radius: 2px;
    background: transparent;
    flex-shrink: 0;
}
.zona-barra-g6 { background: var(--cor-g6); }
.zona-barra-g7 { background: var(--cor-g7); }
.zona-barra-z4 { background: var(--cor-z4); }

.zona-col { padding-left: .5rem !important; }

/* Linha inteira de zona */
.zona-row.zona-g6 td { background-color: rgba(0,229,160,.045); }
.zona-row.zona-g7 td { background-color: rgba(59,130,246,.045); }
.zona-row.zona-z4 td { background-color: rgba(255,92,92,.045); }

.posicao-num {
    font-size: .85rem;
    font-weight: 700;
    color: var(--cor-texto-secundario);
    min-width: 18px;
    display: inline-block;
    text-align: right;
}

/* ---- Legenda de zonas ---- */
.zona-indicador {
    width: 4px;
    height: 36px;
    border-radius: 3px;
    flex-shrink: 0;
}
.zona-indicador.zona-g6 { background: var(--cor-g6); }
.zona-indicador.zona-g7 { background: var(--cor-g7); }
.zona-indicador.zona-z4 { background: var(--cor-z4); }

.zona-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}
.zona-dot.zona-g6 { background: var(--cor-g6); }
.zona-dot.zona-g7 { background: var(--cor-g7); }
.zona-dot.zona-z4 { background: var(--cor-z4); }

/* ---- Zonas nos cards de times ---- */
.zona-card-g6 { border-top: 3px solid var(--cor-g6) !important; }
.zona-card-g7 { border-top: 3px solid var(--cor-g7) !important; }
.zona-card-z4 { border-top: 3px solid var(--cor-z4) !important; }

.zona-badge-sm {
    display: inline-block;
    border-radius: 999px;
    padding: 1px 7px;
    font-size: .65rem;
    font-weight: 700;
}
.zona-badge-sm.zona-g6 { background: rgba(0,229,160,.15); color: var(--cor-g6); }
.zona-badge-sm.zona-g7 { background: rgba(59,130,246,.15); color: var(--cor-azul); }
.zona-badge-sm.zona-z4 { background: rgba(255,92,92,.15); color: var(--cor-vermelho); }

.zona-badge {
    display: inline-block;
    border-radius: 5px;
    padding: 2px 9px;
    font-size: .72rem;
    font-weight: 600;
}
.zona-badge.zona-g6 { background: rgba(0,229,160,.15); color: var(--cor-g6); border: 1px solid rgba(0,229,160,.25); }
.zona-badge.zona-g7 { background: rgba(59,130,246,.15); color: var(--cor-azul); border: 1px solid rgba(59,130,246,.25); }
.zona-badge.zona-z4 { background: rgba(255,92,92,.15); color: var(--cor-vermelho); border: 1px solid rgba(255,92,92,.25); }

/* ---- Cards de times ---- */
.time-card .card-copa {
    transition: border-color .15s, transform .1s;
}
.time-card:hover .card-copa {
    border-color: var(--cor-acento);
    transform: translateY(-2px);
}
.time-card .card-copa { color: var(--cor-texto); }

/* ---- Footer ---- */
.footer-brasileirao {
    background-color: var(--cor-superficie);
    border-top: 1px solid var(--cor-borda);
}

/* ---- Formulários no admin ---- */
.form-control,
.form-select {
    color: var(--cor-texto) !important;
    background-color: var(--cor-superficie) !important;
    border-color: var(--cor-borda) !important;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--cor-acento) !important;
    box-shadow: 0 0 0 3px rgba(0,229,160,.15) !important;
    outline: none;
}
.form-control::placeholder { color: var(--cor-texto-secundario) !important; }

/* Alert reajuste */
.alert-success {
    background-color: rgba(0,229,160,.12);
    border-color: rgba(0,229,160,.3);
    color: var(--cor-acento);
}
.alert-danger {
    background-color: rgba(255,92,92,.12);
    border-color: rgba(255,92,92,.3);
    color: var(--cor-vermelho);
}
.alert-warning {
    background-color: rgba(245,166,35,.12);
    border-color: rgba(245,166,35,.3);
    color: var(--cor-ambar);
}

/* ---- Log list ---- */
.list-group-item { color: var(--cor-texto); }

/* ---- Contador ao vivo ---- */
#contador-ao-vivo { font-weight: 700; color: var(--cor-acento); }

/* ---- Responsivo ≤576px (mobile) ---- */
@media (max-width: 576px) {
    .placar-num  { font-size: 1.1rem; }
    .jogo-card   { padding: .7rem .75rem; }
    .time-nome span { font-size: .82rem; }
    .table-classificacao td,
    .table-classificacao th { padding: .45rem .5rem; font-size: .82rem; }

    /* Admin: campos de senha empilhados, botões full-width */
    .admin-senha-row > [class*="col-"] { flex: 0 0 100%; max-width: 100%; }
}

/* ---- Responsivo ≤374px (320px — iPhone SE, Galaxy A series) ---- */
@media (max-width: 374px) {
    /* Container sem padding lateral excessivo */
    .container { padding-left: 10px; padding-right: 10px; }

    /* Jogo card: placar mais compacto */
    .jogo-placar { min-width: 44px; }
    .placar-num  { font-size: 1rem; }
    .placar-sep  { margin: 0 .1rem; }
    .horario-jogo { font-size: .9rem; }

    /* Nomes dos times: permite quebrar linha (evita truncamento excessivo) */
    .time-nome span {
        font-size: .78rem;
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
        line-height: 1.3;
    }

    /* Tabela: padding mínimo, fonte menor */
    .table-classificacao td,
    .table-classificacao th { padding: .35rem .4rem; font-size: .76rem; }
    .posicao-num { font-size: .76rem; min-width: 14px; }
    .zona-barra  { width: 2px; }

    /* Filtros em jogos.php: botões full-width */
    .filtros-botoes { flex-direction: column; }
    .filtros-botoes .btn { width: 100%; }

    /* Legenda de zonas: fonte menor */
    .legenda-zonas { gap: .5rem !important; font-size: .75rem; }

    /* Cards de times: 2 colunas com menos padding */
    .time-card .card-copa { padding: .6rem .4rem !important; }
    .escudo-time-card { width: 44px; height: 44px; }

    /* Navbar brand mais compacto */
    .navbar-brasileirao .navbar-brand { font-size: .95rem; }
    .brand-icon { display: none; }

    /* Admin stats cards */
    .admin-stat-card .h2 { font-size: 1.4rem; }
}
