/* --- Estilos para a Página de Ranking --- */

body {
    background-color: #f0f4f8; /* Um fundo global um pouco mais suave */
}

/* Container principal com um fundo suave e mais espaçamento */
.ranking-container {
    background-color: #f8f9fa;
    padding: 20px 30px 40px 30px;
    border-radius: 15px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

/* Título e Subtítulo */
.ranking-container h1 {
    color: #005a9c; /* Azul mais forte e escolar */
    font-weight: 700;
    text-align: center;
    margin-bottom: 10px;
}

.ranking-container .lead {
    text-align: center;
    color: #5a6a7b;
    margin-bottom: 30px;
}

/* Estilo para o formulário de filtro */
#ano-letivo-form {
    margin: 30px auto !important;
    border-bottom: 2px solid #e9ecef;
    padding-bottom: 30px;
    max-width: 400px !important;
}

#ano_letivo_select {
    background-color: #fff;
    border: 1px solid #ced4da;
    font-size: 1rem;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s;
}

#ano_letivo_select:hover {
    border-color: #80bdff;
}

#ano_letivo_select:focus {
    outline: none;
    border-color: #80bdff;
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* Tabela de Ranking - Usando um layout mais de "cards" */
.ranking-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 12px; /* Espaçamento entre as linhas/cards */
    margin-top: 20px;
}

.ranking-table thead {
    display: none; /* Cabeçalho tradicional escondido */
}

.ranking-table tr {
    background-color: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
    transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
    overflow: hidden; /* Garante que o border-radius se aplique aos filhos */
}

.ranking-table tr:hover {
    transform: translateY(-4px) scale(1.01);
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

.ranking-table td, .ranking-table th {
    padding: 18px 22px;
    vertical-align: middle;
    border: none;
}

/* Célula da Posição */
.ranking-table .posicao {
    font-size: 1.6em;
    font-weight: bold;
    color: #fff;
    background-color: #6c757d; /* Cor base para 4º lugar em diante */
    text-align: center;
    width: 90px;
    border-top-left-radius: 12px;
    border-bottom-left-radius: 12px;
    position: relative; /* Para o posicionamento dos ícones */
}

/* Célula do Nome do Aluno */
.ranking-table .nome-aluno {
    font-weight: 600;
    font-size: 1.1em;
    color: #343a40;
}

/* Célula da Turma */
.ranking-table .turma {
    color: #6c757d;
    font-size: 0.95em;
}

/* Célula da Média */
.ranking-table .media {
    font-size: 1.3em;
    font-weight: bold;
    color: #28a745;
    text-align: right;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
}


/* --- ESTILOS ESPECIAIS PARA O TOP 3 --- */

/* 1º Lugar - Ouro */
.ranking-table .top-1 .posicao {
    background: linear-gradient(135deg, #ffd700, #fcc200); /* Dourado */
}
.ranking-table .top-1 .posicao::before {
    content: '🏆'; /* Ícone de troféu */
    font-size: 1em;
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

/* 2º Lugar - Prata */
.ranking-table .top-2 .posicao {
    background: linear-gradient(135deg, #e0e0e0, #b8b8b8); /* Prata */
}
.ranking-table .top-2 .posicao::before {
    content: '🥈';
    font-size: 1em;
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
}

/* 3º Lugar - Bronze */
.ranking-table .top-3 .posicao {
    background: linear-gradient(135deg, #cd7f32, #b8732e); /* Bronze */
}
.ranking-table .top-3 .posicao::before {
    content: '🥉';
    font-size: 1em;
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
}


/* --- Media Queries para Responsividade --- */

@media (max-width: 768px) {
    /* Ajusta o container principal para telas menores */
    .ranking-container {
        padding: 15px;
    }

    .ranking-container h1 {
        font-size: 1.8em;
    }

    /* Transforma cada linha da tabela em um card empilhado */
    .ranking-table tr {
        display: block;
        margin-bottom: 15px;
        border-radius: 12px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    }
    
    .ranking-table tr:hover {
        transform: none; /* Desativa o hover effect em mobile para evitar bugs de toque */
        box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    }

    /* Faz cada célula ocupar a largura total */
    .ranking-table td, .ranking-table th.posicao {
        display: block;
        width: 100%;
        box-sizing: border-box;
        text-align: left !important; /* Alinha tudo à esquerda para consistência */
        border-radius: 0;
    }

    /* A célula da posição vira o "cabeçalho" do card */
    .ranking-table .posicao {
        border-radius: 12px 12px 0 0; /* Arredonda cantos superiores */
        padding-left: 50px; /* Mais espaço para o ícone */
        font-size: 1.4em;
    }
    .ranking-table .top-1 .posicao::before,
    .ranking-table .top-2 .posicao::before,
    .ranking-table .top-3 .posicao::before {
        left: 15px; /* Ajusta posição do ícone */
    }


    /* Adiciona labels às outras células para dar contexto */
    .ranking-table .nome-aluno,
    .ranking-table .turma,
    .ranking-table .media {
        padding-left: 20px;
        position: relative;
    }
    
    .ranking-table .nome-aluno::before,
    .ranking-table .turma::before,
    .ranking-table .media::before {
        content: attr(data-label);
        font-weight: bold;
        display: inline-block;
        width: 80px; /* Largura fixa para o label */
        color: #343a40;
    }
    
    .ranking-table .media {
         border-radius: 0 0 12px 12px; /* Arredonda cantos inferiores */
    }
}

@media (max-width: 480px) {
    .ranking-container h1 {
        font-size: 1.5em;
    }
    .ranking-container .lead {
        font-size: 1em;
    }
    
    /* Ajuste fino para telas muito pequenas */
    .ranking-table .nome-aluno::before,
    .ranking-table .turma::before,
    .ranking-table .media::before {
        display: block; /* Coloca o label em sua própria linha */
        width: auto;
        margin-bottom: 5px;
    }
    
    .ranking-table .nome-aluno,
    .ranking-table .turma,
    .ranking-table .media {
        padding-left: 15px;
    }
}