/* Estilo PADRÃO para o body de TODAS as páginas */
body {
    font-family: Arial, sans-serif;
    background-color: #f4f4f4;
    margin: 0;
    padding: 0;
}

/* Estilo ESPECÍFICO para centralizar conteúdo, SÓ para a página de login */
.body-center {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
}

.login-container {
    background-color: white;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    width: 100%;
    max-width: 400px;
    margin: 2rem auto;
}

h2 {
    text-align: center;
    color: #333;
    margin-bottom: 1.5rem;
}

.input-group {
    margin-bottom: 1rem;
}

.input-group label {
    display: block;
    margin-bottom: 0.5rem;
    color: #555;
}

.input-group input {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-sizing: border-box; /* Garante que o padding não aumente a largura total */
}

button {
    width: 100%;
    padding: 0.75rem;
    border: none;
    border-radius: 4px;
    background-color: #007bff;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    transition: background-color 0.3s;
}

button:hover {
    background-color: #0056b3;
}

.error-message {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
    padding: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    border-radius: 0.25rem;
    text-align: center;
}
/* Estilos do Dashboard */
.dashboard-container {
    background-color: white;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    width: 100%;
    max-width: 800px;
    margin: 2rem auto; /* <-- ADICIONE ESTA LINHA */
}

.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eee;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
}

.dashboard-header h2 {
    margin: 0;
}

.logout-button {
    text-decoration: none;
    background-color: #dc3545;
    color: white;
    padding: 0.5rem 1rem;
    border-radius: 4px;
    transition: background-color 0.3s;
}

.logout-button:hover {
    background-color: #c82333;
}

.data-group {
    margin-bottom: 1.5rem;
    border: 1px solid #ddd;
    padding: 1rem;
    border-radius: 4px;
}

.data-group h4 {
    margin-top: 0;
}

.data-group p {
    margin: 0.5rem 0;
    line-height: 1.6;
}

.button-primary {
    display: inline-block;
    text-decoration: none;
    width: 100%;
    padding: 0.75rem;
    border: none;
    border-radius: 4px;
    background-color: #28a745;
    color: white;
    font-size: 1rem;
    cursor: pointer;
    text-align: center;
    transition: background-color 0.3s;
    box-sizing: border-box;
}

.button-primary:hover {
    background-color: #218838;
}

/* Estilos da Página de Edição */
.edit-container {
    background-color: white;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    width: 100%;
    max-width: 800px;
    margin: 2rem auto; /* Adiciona margem para rolar a página */
}

.edit-container p {
    color: #555;
    margin-bottom: 1.5rem;
}

fieldset {
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 1.5rem;
    margin-bottom: 1.5rem;
}

legend {
    padding: 0 0.5rem;
    font-weight: bold;
    color: #333;
}

input[disabled] {
    background-color: #e9ecef;
    cursor: not-allowed;
}

small {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.8rem;
    color: #6c757d;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
    margin-top: 1.5rem;
}

.button-secondary {
    display: inline-block;
    text-decoration: none;
    padding: 0.75rem 1.5rem;
    border: 1px solid #6c757d;
    border-radius: 4px;
    background-color: transparent;
    color: #6c757d;
    font-size: 1rem;
    text-align: center;
    transition: all 0.3s;
}

.button-secondary:hover {
    background-color: #6c757d;
    color: white;
}

/* Estilos para mensagens de sucesso e erro */
.success-message {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
    padding: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    border-radius: 0.25rem;
}

/* Estilos do Tema Admin */
.admin-theme {
    border-top: 5px solid #343a40; /* Uma borda escura no topo */
}

.admin-theme h2 {
    color: #343a40;
}

.admin-theme button {
    background-color: #5a6268;
}

.admin-theme button:hover {
    background-color: #343a40;
}

/* Estilos do Dashboard do Admin */
.admin-dashboard-container {
    background-color: white;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    width: 100%;
    max-width: 1200px; /* Mais largo para a tabela */
    margin: 2rem auto;
}

.admin-actions {
    margin-bottom: 1.5rem;
    display: flex;
    gap: 1rem;
}

.admin-table {
    width: 100%;
    border-collapse: collapse; /* Remove espaços entre as células */
    margin-top: 1rem;
}

.admin-table th, .admin-table td {
    border: 1px solid #ddd;
    padding: 12px 15px;
    text-align: left;
}

.admin-table th {
    background-color: #f8f9fa;
    font-weight: bold;
}

.admin-table tbody tr:nth-child(even) {
    background-color: #f2f2f2; /* Cor alternada para as linhas */
}

.admin-table tbody tr:hover {
    background-color: #e9ecef;
}

.status-alert {
    color: #dc3545;
    font-weight: bold;
}

.status-ok {
    color: #28a745;
}

.action-buttons {
    display: flex;
    gap: 0.5rem;
}

.action-btn {
    text-decoration: none;
    color: white;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 0.9rem;
}

.action-btn.edit {
    background-color: #007bff;
}
.action-btn.edit:hover {
    background-color: #0056b3;
}

.action-btn.delete {
    background-color: #dc3545;
}
.action-btn.delete:hover {
    background-color: #c82333;
}

.action-btn.acknowledge {
    background-color: #28a745; /* Verde */
}
.action-btn.acknowledge:hover {
    background-color: #218838;
}
.action-btn.view {
    background-color: #6c757d; /* Cinza */
}
.action-btn.view:hover {
    background-color: #5a6268;
}
/* Estilo para o logo nas páginas de login */
.login-logo {
    display: block; /* Permite o uso de margens automáticas */
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5rem; /* Espaço entre o logo e o título */
    max-width: 250px; /* Limita a largura para telas menores */
}
/* ================================================================== */
/* ESTILOS PARA TELAS PEQUENAS (CELULARES E TABLETS) - DESIGN RESPONSIVO */
/* ================================================================== */

@media (max-width: 768px) {

    /* 1. Ajusta os containers principais para ocupar mais espaço e ter menos padding */
    .login-container,
    .dashboard-container,
    .edit-container,
    .admin-dashboard-container {
        width: 90%; /* Ocupa 90% da tela ao invés de ter um max-width fixo */
        padding: 1.5rem;
        margin: 1rem auto; /* Reduz a margem superior/inferior */
    }

    /* 2. Reduz o tamanho dos títulos para caber melhor */
    h2 {
        font-size: 1.5rem;
    }

    /* 3. A MÁGICA PARA A TABELA DO ADMIN: Transforma a tabela em "cartões" */
    .admin-table {
        border: 0; /* Remove a borda geral */
    }

    /* Esconde o cabeçalho original da tabela */
    .admin-table thead {
        display: none;
    }

    /* Faz com que cada linha (tr) pareça um cartão separado */
    .admin-table tr {
        display: block;
        margin-bottom: 1rem;
        border: 1px solid #ddd;
        border-radius: 4px;
    }

    /* Faz com que cada célula (td) ocupe uma linha inteira */
    .admin-table td {
        display: block;
        text-align: right; /* Alinha o dado à direita */
        border: none;
        border-bottom: 1px solid #eee;
        position: relative;
        padding-left: 50%; /* Espaço para o "título" que vamos adicionar */
    }

    /* Adiciona o "título" da coluna antes do dado, usando o atributo 'data-label' */
    .admin-table td:before {
        content: attr(data-label); /* Pega o texto do atributo data-label */
        position: absolute;
        left: 10px;
        width: 45%;
        padding-right: 10px;
        white-space: nowrap;
        text-align: left;
        font-weight: bold;
    }

    /* Ajusta a última célula de cada "cartão" */
    .admin-table td:last-child {
        border-bottom: 0;
    }

    /* Garante que os botões de ação fiquem bem posicionados */
    .action-buttons {
        text-align: center;
        padding-top: 1rem;
        padding-left: 0; /* Reseta o padding da célula */
    }
}
.config-section {
    background-color: #f8f9fa;
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 1.5rem;
    margin-bottom: 2rem;
}
.config-section h4 {
    margin-top: 0;
}
.config-item span {
    margin-right: 10px;
}
/* Estilos para cabeçalhos de tabela clicáveis */
.th-sortable {
    cursor: pointer;
    user-select: none; /* Impede que o texto seja selecionado ao clicar */
}

.th-sortable:hover {
    background-color: #e9ecef; /* Um leve destaque ao passar o mouse */
}

.th-filtered {
    background-color: #f8d7da; /* Destaque vermelho quando o filtro está ativo */
    color: #721c24;
}
/* Estilo para caixas de informação/aviso */
.info-message {
    background-color: #fff3cd; /* Amarelo claro */
    color: #664d03; /* Texto escuro */
    border: 1px solid #ffecb5; /* Borda amarela */
    padding: 0.75rem 1.25rem;
    margin-bottom: 1rem;
    border-radius: 0.25rem;
    font-size: 0.9rem;
}
.info-message strong {
    color: #523e02;
}
