/* ===========================================================
   Copa do Brasil 2026 — Tema Escuro
   Base compartilhada com copa2026 e brasileirao
   =========================================================== */

:root {
    --cor-fundo:             #0D0F14;
    --cor-superficie:        #161B25;
    --cor-superficie-alt:    #1D2330;
    --cor-acento:            #00E5A0;   /* verde Copa do Brasil */
    --cor-ambar:             #FFD700;   /* ouro Copa do Brasil */
    --cor-texto:             #E8EAED;
    --cor-texto-secundario:  #9AA4B2;
    --cor-borda:             #262C3A;
    --cor-vermelho:          #FF5C5C;
    --cor-verde-escuro:      #006633;   /* verde oficial */
    --cor-azul-escuro:       #003399;   /* azul oficial */
}

* { 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-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; }
.text-texto    { color: var(--cor-texto)                    !important; }

/* ---- Navbar ---- */
.navbar-copabrasil {
    background: linear-gradient(90deg, var(--cor-verde-escuro) 0%, var(--cor-azul-escuro) 100%);
    border-bottom: 2px solid var(--cor-ambar);
}
.navbar-copabrasil .navbar-brand {
    font-weight: 700;
    font-size: 1.1rem;
    color: #fff !important;
    letter-spacing: 0.3px;
}
.navbar-copabrasil .navbar-brand .accent    { color: var(--cor-ambar); }
.navbar-copabrasil .navbar-brand .brand-year { color: var(--cor-acento); }
.navbar-copabrasil .brand-icon              { font-size: .95rem; }
.navbar-copabrasil .nav-link {
    color: rgba(255,255,255,.75) !important;
    font-weight: 500;
    font-size: .9rem;
    transition: color .15s;
}
.navbar-copabrasil .nav-link.active,
.navbar-copabrasil .nav-link:hover { color: var(--cor-ambar) !important; }
.navbar-copabrasil .navbar-toggler-icon {
    filter: invert(1);
}

/* ---- 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-ambar {
    background-color: var(--cor-ambar);
    color: #1a0f00;
    font-weight: 600;
    border: none;
}
.btn-ambar:hover { background-color: #e6c200; color: #1a0f00; }

.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 ---- */
.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;
}

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

/* ---- Bracket de chaveamento ---- */
.bracket {
    position: relative;
    display: flex;
    gap: 2.5rem;
    overflow-x: auto;
    padding-bottom: 1rem;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
}
.bracket-conexoes {
    position: absolute;
    top: 0; left: 0;
    pointer-events: none;
    z-index: 0;
}
.bracket-linha-conexao {
    stroke: #1E2736;
    stroke-width: 2;
}
.bracket-coluna {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    gap: 1rem;
    min-width: 230px;
    flex-shrink: 0;
    scroll-snap-align: start;
}
.bracket-coluna-titulo {
    text-align: center;
    color: var(--cor-ambar);
    font-weight: 700;
    font-size: .85rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .5rem;
}
.bracket-jogo {
    background-color: var(--cor-superficie);
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
    padding: .6rem .75rem;
    font-size: .85rem;
    min-height: 96px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.bracket-jogo:hover { border-color: var(--cor-acento); }
.bracket-jogo.vencedor-definido { border-color: rgba(0,229,160,.3); }

.bracket-linha-time {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .5rem;
    padding: .2rem 0;
}
.bracket-linha-time .time-nome { flex: 1 1 auto; min-width: 0; }
.bracket-gol { flex-shrink: 0; font-weight: 700; min-width: 16px; text-align: right; }
.bracket-linha-time.vencedor .time-nome span { color: var(--cor-acento); font-weight: 700; }
.bracket-linha-time.vencedor .bracket-gol   { color: var(--cor-acento); }
.bracket-tbd { color: var(--cor-texto-secundario); font-style: italic; font-size: .82rem; }
.bracket-agregado {
    font-size: .72rem;
    color: var(--cor-texto-secundario);
    margin-top: .25rem;
    text-align: center;
}

@media (max-width: 575.98px) {
    .bracket-coluna { min-width: 86vw; }
}

/* ---- 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); }

/* ---- Fase tag ---- */
.fase-tag {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .8rem;
    border-radius: 999px;
    border: 1px solid var(--cor-borda);
    background: var(--cor-superficie-alt);
    font-size: .78rem;
    font-weight: 600;
    color: var(--cor-texto-secundario);
    cursor: pointer;
    transition: all .15s;
    text-decoration: none;
}
.fase-tag:hover, .fase-tag.ativo {
    background: var(--cor-verde-escuro);
    border-color: var(--cor-acento);
    color: #fff;
}
.fase-tag .qtd {
    background: rgba(255,255,255,.12);
    border-radius: 999px;
    padding: 0 6px;
    font-size: .7rem;
}

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

/* ---- Formulários ---- */
.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; }

/* ---- Alertas ---- */
.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(255,215,0,.12);
    border-color: rgba(255,215,0,.3);
    color: var(--cor-ambar);
}

/* ---- Seção ao vivo ---- */
#secao-ao-vivo .jogo-card.ao-vivo { border-color: var(--cor-vermelho); }

/* ---- Admin stats ---- */
.admin-stat-card .display-6 { color: var(--cor-ambar); font-weight: 700; }

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

/* ---- Responsivo ≤374px ---- */
@media (max-width: 374px) {
    .container    { padding-left: 10px; padding-right: 10px; }
    .jogo-placar  { min-width: 44px; }
    .placar-num   { font-size: 1rem; }
    .placar-sep   { margin: 0 .1rem; }
    .horario-jogo { font-size: .9rem; }
    .time-nome span {
        font-size: .78rem;
        white-space: normal;
        overflow: visible;
        text-overflow: clip;
        line-height: 1.3;
    }
    .filtros-botoes { flex-direction: column; }
    .filtros-botoes .btn { width: 100%; }
    .navbar-copabrasil .navbar-brand { font-size: .95rem; }
    .brand-icon { display: none; }
}
