/* style/programacao.css */

/* Estilos para os filtros */
.secao-filtros {
    display: flex;
    justify-content: center;
    gap: 10px; /* Espaçamento entre os botões */
    padding: 10px; /* Adiciona um pouco de padding ao redor dos botões */
    background-color: #ffffff; /* Um fundo leve para a barra de filtros */
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
    margin-top: -5px;
}

.filtro-btn {
    padding: 6px 10px;
    border: 1px solid #007bff;
    border-radius: 8px; /* Bordas arredondadas para os botões */
    background-color: #fcfcfc;
    color: #007bff;
    cursor: pointer;
    font-size: 1em;
    font-weight: bold;
    transition: all 0.3s ease;
    min-width: 90px; /* Garante largura mínima para os botões */
    text-align: center;
}

.filtro-btn:hover {
    background-color: #e9f5ff;
    transform: translateY(-2px); /* Efeito sutil ao passar o mouse */
}

.filtro-btn.active {
    background-color: #007bff;
    color: #fff;
    border-color: #007bff;
    box-shadow: 0 3px 6px rgba(0,123,255,0.3); /* Sombra para o botão ativo */
}

/* Estilos para o contêiner de jogos */
.secao-programacao {
    margin-top: 20px;
}

/* Estilos para os cards de jogos individuais */
.jogo-card {
    background-color: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px; /* Espaçamento entre os cards */
    margin-top: -10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
    display: flex;
    flex-direction: column;
    gap: 15px; /* Espaçamento entre as seções do card */
    transition: transform 0.2s ease-in-out;
}

.jogo-card:hover {
    transform: translateY(-5px); /* Efeito sutil ao passar o mouse */
}

.jogo-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 10px;
    border-bottom: 1px dashed #e0e0e0;
}

.jogo-header .hora {
    font-weight: bold;
    font-size: 1.2em;
    color: #333;
}

.jogo-header .liga {
    display: flex;
    align-items: center;
    font-size: 0.9em;
    color: #555;
    margin-top: -10px;
}

.liga-logo {
    width: 30px;
    height: 30px;
    margin-right: 8px;
    object-fit: contain; /* Garante que o logo não seja cortado */
}

/* Nova estrutura de estilos para times e placares */
.times-wrapper {
    display: flex;
    align-items: center; /* Alinha tudo verticalmente ao centro */
    justify-content: space-between; /* Distribui o espaço entre os times e o placar central */
    text-align: center;
    margin: 10px 0;
}

.time {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1; /* Permite que os times ocupem o espaço flexível */
    min-width: 120px; /* Garante um tamanho mínimo para os times */
}

.time-logo {
    width: 60px;
    height: 60px;
    margin-bottom: 8px;
    object-fit: contain;
}

.nome-time {
    font-weight: bold;
    font-size: 1.1em;
    color: #222;
    word-break: break-word;
    margin-top: 5px;
    margin-bottom: 5px;
}

.placar-central {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px; /* Espaço entre o placar da casa, 'x' e placar visitante */
    flex-shrink: 0; /* Impede que este contêiner encolha */
    padding: 0 10px; /* Espaçamento interno para não colar nos times */
    position: relative;   /* <-- propriedade movida para cá */
    padding-top: 10px;  /* <-- propriedade movida para cá */
}

.placar-casa,
.placar-visitante {
    font-size: 2.2em; /* Um pouco maior para destaque */
    font-weight: bolder;
    color: #007bff;
    min-width: 30px; /* Garante que o placar tenha uma largura mínima */
    text-align: center;
}

.vs {
    font-weight: bold;
    font-size: 1.5em;
    color: #888;
    margin: 0 5px; /* Ajuste a margem ao redor do 'x' conforme necessário */
}

.transmissao {
    text-align: center;
    margin-top: -10px;
    padding-top: 10px;
    border-top: 1px dashed #e0e0e0;
    font-size: 0.95em;
    color: #666;
    display: flex;
    flex-wrap: wrap; /* Permite que os canais quebrem a linha */
    justify-content: center;
    align-items: center;
    gap: 12px; /* Espaçamento entre os canais */
}

.transmissao span {
    display: flex;
    align-items: center;
    white-space: nowrap; /* Impede que o nome do canal quebre */
}

.transmissao .canal-logo {
    width: 30px;
    height: 30px;
    object-fit: contain;
    margin-right: 5px;
    vertical-align: middle;
}

/* Estilo para quando não houver jogos */
.secao-programacao h3, .secao-programacao p {
    text-align: center;
    color: #666;
    margin-top: 30px;
    font-size: 1.2em;
}

/* === INÍCIO DOS ESTILOS PARA O TEMPO DE JOGO === */
/* Estilo base do 'badge' de tempo/status */
.tempo-jogo-badge {
    position: absolute;   /* Posicionamento flutuante acima do 'vs' */
    top: -20px;               /* Alinha no topo do container .placar-central */
    left: 50%;            /* Centraliza horizontalmente */
    transform: translateX(-50%); /* Ajuste fino para centralização perfeita */
    
    color: #fff;          /* Cor do texto */
    padding: 3px 10px;    /* Espaçamento interno */
    border-radius: 12px;  /* Bordas arredondadas */
    font-size: 0.7em;     /* Tamanho da fonte */
    font-weight: bold;
    white-space: nowrap;  /* Garante que o texto não quebre linha */
    box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

/* Cor específica para jogos AO VIVO */
.tempo-jogo-badge.ao-vivo {
    background-color: #e74c3c; /* Vermelho para indicar "ao vivo" */
}

/* Animação de piscar para jogos AO VIVO */
.tempo-jogo-badge.ao-vivo::before {
    content: ' ';
    display: inline-block;
    width: 7px;
    height: 7px;
    background-color: #ffffff;
    border-radius: 50%;
    margin-right: 6px;
    animation: blinker 1.5s linear infinite;
}

/* Cor específica para jogos FINALIZADOS */
.tempo-jogo-badge.finalizado {
    background-color: #7f8c8d; /* Cinza para indicar "fim de jogo" */
}

/* Animação de piscar */
@keyframes blinker {
    50% {
        opacity: 0.3;
    }
}

/* === FIM DOS ESTILOS PARA O TEMPO DE JOGO === */

/* Responsividade */
@media (max-width: 480px) {
    .secao-filtros {
        flex-wrap: wrap;
        gap: 0; /* Ou remover, já que margin vai controlar */
        padding: 5px; /* Reduzir padding do container dos filtros */
    }
    .filtro-btn {
        flex: 1; /* Permite que os botões ocupem o espaço disponível */
        min-width: 80px; /* Largura mínima reduzida para telas menores */
        margin: 5px; /* Adiciona margem entre os botões */
    }
    .jogo-card {
        padding: 15px;
    }
    .jogo-header .hora {
        font-size: 1em;
    }
    .nome-time {
        font-size: 1em; /* Ajuste o tamanho da fonte dos nomes dos times */
    }
    .time-logo {
        width: 45px; /* Pode reduzir um pouco mais os logos dos times */
        height: 45px;
    }
    .placar-casa, .placar-visitante {
        font-size: 1.6em; /* Reduzir um pouco mais o placar para caber */
        min-width: 10px; /* Garante que o placar não fique muito pequeno */
    }
    .vs {
        font-size: 1.2em; /* Reduzir o 'x' */
        margin: 0 3px; /* Ajusta a margem ao redor do 'x' */
    }
    .jogo-header .liga {
        display: flex;
        align-items: center;
        font-size: 0.8em;
    }
    .transmissao .canal-logo {
        width: 20px;
        height: 20px;
    }
    .transmissao span {
        font-size: 0.8em; /* Reduz o tamanho da fonte dos canais */
    }
}