/* Reset básico e configurações globais */
*, *::before, *::after {
    box-sizing: border-box;
}

body {
    font-family: 'Inter', Arial, sans-serif;
    background-color: #f4f7f6;
    margin: 0;
    padding: 20px;
    color: #333;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    background-color: #ffffff;
    padding: 20px 30px;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

/* Estilo para a logo adicionada */
.logo {
    display: block;
    width: 80px;
    height: 80px;
    margin: 0 auto 15px auto; /* Centraliza horizontalmente e adiciona margem inferior */
    border-radius: 50%; /* Deixa a imagem redonda para um visual sutil */
    object-fit: cover;
}

h1, h2, h3 {
    text-align: center;
    color: #2c3e50;
    font-weight: 700;
    margin-bottom: 25px;
}

/* Formulário de Pesquisa */
#consultaForm {
    display: flex;
    gap: 10px;
    margin-bottom: 30px;
}

#pesquisa {
    flex-grow: 1;
    padding: 12px 15px;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-size: 16px;
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

#pesquisa:focus {
    outline: none;
    border-color: #5cb85c;
    box-shadow: 0 0 0 3px rgba(92, 184, 92, 0.2);
}

button {
    padding: 12px 20px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

#btnConsulta {
    background-color: #5cb85c;
    color: white;
}

#btnConsulta:hover {
    background-color: #4cae4c;
    transform: translateY(-2px);
}

#btnLimpar {
    background-color: #6c757d;
    color: white;
}

#btnLimpar:hover {
    background-color: #5a6268;
    transform: translateY(-2px);
}

/* Estilo da Tabela para Desktop */
.tabela-container {
    width: 100%;
    overflow-x: auto; /* Garante que a tabela não quebre o layout em telas médias */
}

table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
}

th, td {
    padding: 15px;
    text-align: left;
    border-bottom: 1px solid #ddd;
}

thead {
    background-color: #f2f2f2;
}

th {
    font-weight: 700;
    color: #34495e;
}

tbody tr:hover {
    background-color: #f5f5f5;
}

/* --- Design Responsivo para Mobile (max-width: 768px) --- */
@media (max-width: 768px) {
    .container {
        padding: 15px;
    }

    #consultaForm {
        flex-direction: column;
    }

    /* Tabela se transforma em "Cards" no mobile */
    thead {
        display: none; /* Esconde o cabeçalho da tabela */
    }

    tr {
        display: block;
        margin-bottom: 20px;
        border: 1px solid #ddd;
        border-radius: 8px;
        overflow: hidden;
        box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    }

    td {
        display: flex; /* MODIFICADO: Usa Flexbox para evitar sobreposição */
        justify-content: space-between; /* Empurra o título e o valor para lados opostos */
        align-items: flex-start; /* Alinha ao topo, ideal para textos com múltiplas linhas */
        padding: 12px 15px; /* Aumenta um pouco o padding para mais respiro */
        border-bottom: 1px solid #eee;
        text-align: right; /* Alinha o texto do valor à direita */
        word-break: break-word; /* Garante a quebra de palavras muito longas */
    }

    td:last-child {
        border-bottom: none;
    }

    /* Adiciona o "título" da coluna como um pseudo-elemento */
    td::before {
        content: attr(data-label);
        font-weight: 700;
        color: #333;
        text-align: left;
        padding-right: 15px; /* Espaço entre o título e o valor */
        flex-shrink: 0; /* Impede que o título encolha */
        /* REMOVIDO: Posição absoluta não é mais necessária com Flexbox */
    }
}

