/* ===================================================
   STYLE.CSS - Portal CEDI (Tema Claro - CORRIGIDO)
   =================================================== */

/* --- 1. Variáveis de Cor (Tema Claro) --- */
:root {
    --cor-fundo: #f4f7f6;           /* Cinza muito claro, quase branco */
    --cor-superficie: #ffffff;       /* Branco (para cards, header) */
    --cor-borda: #dce1e3;          /* Cinza claro para bordas */
    --cor-texto-principal: #2d3748; /* Cinza escuro (quase preto) */
    --cor-texto-secundario: #5a6a85; /* Cinza médio */
    
    --cor-primaria: #0056b3;       /* Azul CEDI (Principal) */
    --cor-primaria-escura: #004a91; /* Azul CEDI (Hover) */
    --cor-secundaria: #f0c000;     /* Dourado/Amarelo (Destaque sutil) */
    --cor-sucesso: #28a745;        /* Verde */
    --cor-erro: #dc3545;          /* Vermelho */
}

/* Badges (utilitário simples) */
.badge {
  display: inline-block;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.85em;
  font-weight: 600;
  border: 1px solid var(--cor-borda);
  background: var(--cor-fundo);
  color: var(--cor-texto-secundario);
}
.badge-success {
  border-color: rgba(22, 163, 74, 0.35);
  background: rgba(22, 163, 74, 0.10);
  color: #166534;
}
.badge-warning {
  border-color: rgba(234, 179, 8, 0.35);
  background: rgba(234, 179, 8, 0.12);
  color: #854d0e;
}

/* --- 2. Reset e Padrões Globais --- */
body {
    margin: 0;
    padding: 0;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    background-color: var(--cor-fundo);
    color: var(--cor-texto-principal);
    line-height: 1.6;
}

main.container {
    max-width: 1100px;
    margin: 20px auto 40px auto;
    padding: 0 20px;
}

h1, h2, h3, h4 {
    color: var(--cor-primaria-escura);
    font-weight: 700;
    margin-top: 1.5em;
    margin-bottom: 0.5em;
    line-height: 1.3;
}
h1 { font-size: 2.25rem; }
h2 { font-size: 1.75rem; border-bottom: 2px solid var(--cor-borda); padding-bottom: 8px; }
h3 { font-size: 1.35rem; color: var(--cor-primaria); }

p {
    margin-bottom: 1rem;
    color: var(--cor-texto-secundario);
}
a {
    color: var(--cor-primaria);
    text-decoration: none;
    transition: color 0.2s;
}
a:hover {
    color: var(--cor-primaria-escura);
    text-decoration: none;
}

hr {
    border: 0;
    border-top: 1px solid var(--cor-borda);
    margin: 2rem 0;
}

/* --- 3. Layout (Header e Footer) --- */
header.header {
    width: 100%;
    background-color: var(--cor-superficie);
    border-bottom: 1px solid var(--cor-borda);
    padding: 15px 0;
    box-shadow: 0 2px 5px rgba(0,0,0,0.03);
    position: sticky;
    top: 0;
    z-index: 100;
}

/* CORREÇÃO DE LAYOUT: Garante que o header fique na horizontal */
div.nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

nav .logo-group {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--cor-primaria-escura);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0; /* Não deixa o logo encolher */
    transition: transform 0.2s ease-in-out; /* Efeito de zoom */
}
nav .logo-group:hover {
    transform: scale(1.05); /* Zoom no hover */
}
nav .logo-group img {
    height: 40px;
}

footer {
    text-align: center;
    padding: 30px 20px;
    background-color: var(--cor-superficie);
    border-top: 1px solid var(--cor-borda);
    margin-top: 40px;
    color: var(--cor-texto-secundario);
    font-size: 0.9rem;
}

/* --- 4. Componentes (Botões, Cards, Formulários) --- */

/* Botões */
.btn, button, input[type="submit"] {
    display: inline-block;
    padding: 12px 24px;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    border-radius: 8px;
    border: 2px solid transparent;
    transition: all 0.2s ease-in-out;
}
.btn {
    background-color: var(--cor-primaria);
    color: #ffffff;
}
.btn:hover {
    background-color: var(--cor-primaria-escura);
    color: #ffffff;
    text-decoration: none;
    transform: translateY(-2px);
}
.btn-outline {
    background-color: transparent;
    color: var(--cor-primaria);
    border-color: var(--cor-primaria);
}
.btn-outline:hover {
    background-color: var(--cor-primaria);
    color: #ffffff;
    text-decoration: none;
}
.btn-danger {
    background-color: var(--cor-erro);
    color: #ffffff;
    border-color: var(--cor-erro);
}
.btn-danger:hover {
    background-color: #a71d2a;
    border-color: #a71d2a;
}
.btn-small {
    padding: 8px 16px;
    font-size: 0.9rem;
}

/* Cards */
.card {
    background-color: var(--cor-superficie);
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
    padding: clamp(20px, 4vw, 30px);
    margin-bottom: 20px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

/* Formulários */
label {
    display: block;
    margin-bottom: 8px;
    font-weight: 600;
    color: var(--cor-texto-principal);
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="date"],
input[type="tel"],
input[type="number"],
input[type="datetime-local"],
textarea,
select {
    width: 100%;
    padding: 12px;
    font-size: 1rem;
    border: 1px solid var(--cor-borda);
    border-radius: 4px;
    box-sizing: border-box; 
    background-color: #fcfcfc;
    color: var(--cor-texto-principal);
    margin-bottom: 15px;
}
input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--cor-primaria);
    box-shadow: 0 0 0 2px rgba(0, 86, 179, 0.2);
}
textarea {
    min-height: 120px;
    line-height: 1.5;
}

/* --- 5. Componentes Específicos (Alertas, Tabelas) --- */
.alert { padding: 15px; margin-bottom: 20px; border: 1px solid transparent; border-radius: 4px; font-weight: 500; }
.alert-success { color: #155724; background-color: #d4edda; border-color: #c3e6cb; }
.alert-error, .alert-danger { color: #721c24; background-color: #f8d7da; border-color: #f5c6cb; }
.alert-info { color: #0c5460; background-color: #d1ecf1; border-color: #bee5eb; }

.table-list { width: 100%; border-collapse: collapse; margin-top: 20px; overflow-x: auto; display: block; }
.table-list th, .table-list td { border: 1px solid var(--cor-borda); padding: 12px; text-align: left; white-space: nowrap; }
.table-list thead { background-color: var(--cor-fundo); color: var(--cor-primaria-escura); }
.table-list tbody tr:nth-child(even) { background-color: #fdfdfd; }
.table-list tbody tr:hover { background-color: #eef5fa; }

/* ===================================================
   HEADER CORRIGIDO (Layout: Logo | Botões | Hambúrguer)
   (SEM JS e COM CORES CORRIGIDAS)
   =================================================== */

/* Container da Direita (Botões + Hambúrguer) */
.nav-right-container {
    display: flex;
    align-items: center;
    gap: 15px; /* Espaço entre botões e hambúrguer */
}

/* Botões Visíveis (Entrar/Cadastrar ou Painel) */
.nav-actions-visible {
    display: flex; /* Mantém os botões na horizontal */
    gap: 10px;
}

/* Esconde botões no mobile para não quebrar linha */
@media (max-width: 500px) {
    .nav-actions-visible {
        display: none; /* Esconde botões no mobile */
    }
}

/* Container do Menu Hambúrguer */
.hamburger-menu {
    position: relative;
    z-index: 100;
}

/* Ícone (Label) */
.hamburger-menu-icon {
    display: block;
    font-size: 1.6rem;
    cursor: pointer;
    padding: 5px;
    /* CORREÇÃO FORÇADA: Define a cor do label (que contém o ícone) */
    color: #0056b3; 
}
/* CORREÇÃO FORÇADA: Define a cor do ícone 'i' dentro do label */
.hamburger-menu-icon i {
    color: #0056b3; /* Força o Azul CEDI */
}

/* O checkbox invisível */
#hamburger-toggle {
    display: none;
}

/* O Menu Dropdown */
.hamburger-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    background: var(--cor-superficie); /* Fundo branco */
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    min-width: 250px;
    z-index: 99;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity 0.2s, transform 0.2s, visibility 0.2s;
    padding: 5px;
}

/* Mostra o menu quando o checkbox está marcado */
#hamburger-toggle:checked ~ .hamburger-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Links dentro do menu */
.hamburger-dropdown a.menu-link {
    display: flex;
    align-items: center;
    padding: 10px 15px;
    text-decoration: none;
    color: var(--cor-texto-principal);
    font-size: 0.95rem;
    transition: background-color 0.1s;
    gap: 12px;
    border-radius: 6px;
}
.hamburger-dropdown a.menu-link i {
    width: 20px;
    text-align: center;
    color: var(--cor-primaria); /* Ícone azul */
}
.hamburger-dropdown a.menu-link:hover {
    background-color: var(--cor-fundo); /* Fundo cinza claro */
    color: var(--cor-primaria-escura);
    text-decoration: none;
}
.hamburger-dropdown hr {
    margin: 5px 0;
    border-top: 1px solid var(--cor-borda);
}

/* Botões de Login/Cadastro (QUANDO ESTÃO DENTRO DO MENU, no mobile) */
.hamburger-dropdown .menu-actions {
    padding: 10px 15px;
    display: flex;
    gap: 10px;
    border-top: 1px solid var(--cor-borda);
    margin-top: 5px;
}
.hamburger-dropdown .menu-actions .btn,
.hamburger-dropdown .menu-actions .btn-outline {
    flex-grow: 1;
    text-align: center;
}

/* Mostra os botões de Login/Cadastro no menu SÓ no mobile */
.menu-actions-mobile-only {
    display: none;
}
@media (max-width: 500px) {
    .menu-actions-mobile-only {
        display: flex;
    }
}