/* ferias/static/ferias/css/style.css */

/*
 * ETAPA 1: DEFINIÇÃO DAS VARIÁVEIS DE ESTILO (VERSÃO "SUAVE")
*/
:root {
    --cor-primaria: #D4580A;
    --cor-primaria-hover: #B8470A;
    --cor-fundo: #f5f6fa;
    --cor-fundo-card: #ffffff;
    --cor-texto: #1a1a2e;
    --cor-texto-suave: #5a6876;
    --cor-borda: #e2e8f0;

    --cor-sucesso: #16a34a;
    --cor-perigo: #dc2626;
    --cor-aviso: #d97706;

    --raio-borda-arredondado: 50px;
    --raio-borda-padrao: 10px;

    --fonte-principal: 'Lato', sans-serif;
    --peso-titulo: 700;
    --peso-normal: 400;
    --peso-leve: 300;

    --sombra-card: 0 1px 3px rgba(0,0,0,0.04), 0 4px 12px rgba(0,0,0,0.06);
    --sombra-hover: 0 4px 16px rgba(0,0,0,0.10);
    --transicao: 0.2s ease;
}

/* --- RESET BÁSICO E APLICAÇÃO DA BASE --- */
*, *::before, *::after {
  box-sizing: border-box;
}

body {
    font-family: var(--fonte-principal);
    font-weight: var(--peso-normal);
    background-color: var(--cor-fundo);
    color: var(--cor-texto);
    margin: 0;
    line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: var(--peso-titulo);
    text-transform: none;
    margin-top: 0;
}

p {
    font-weight: var(--peso-leve);
}

/* --- COMPONENTES ATUALIZADOS --- */

/* 1. Layout e Navegação */
.container-principal {
    max-width: 1100px;
    margin: 30px auto;
    padding: 0 15px;
}

.navegacao-principal {
    width: 100%;
    background-color: var(--cor-fundo-card);
    padding: 16px 0;
    border-bottom: 1px solid var(--cor-borda);
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}

.navegacao-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
}

.logo {
    font-family: var(--fonte-principal);
    font-size: 1.5rem;
    font-weight: var(--peso-titulo);
    color: var(--cor-primaria);
    text-decoration: none;
    text-transform: uppercase;
}

.menu-principal ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
.menu-principal li {
    display: inline-block;
    margin-left: 25px;
}
.menu-principal a {
    color: var(--cor-texto-suave);
    text-decoration: none;
    font-size: 1rem;
    font-weight: var(--peso-normal);
    transition: color 0.2s;
}
.menu-principal a:hover {
    color: var(--cor-primaria);
}

.menu-navegacao-container {
    display: flex;
    align-items: center;
}
.menu-acoes-usuario {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
    margin-left: 25px;
}

/* 2. Botoes */
.botao-acao-principal,
.botao-principal,
.botao-sucesso,
.botao-perigo,
.botao-secundario {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 22px;
    font-size: 0.875rem;
    font-weight: var(--peso-titulo);
    color: #fff;
    text-decoration: none;
    border: none;
    border-radius: var(--raio-borda-padrao);
    cursor: pointer;
    transition: background-color var(--transicao), transform var(--transicao), box-shadow var(--transicao);
    letter-spacing: 0.01em;
}
.botao-acao-principal:hover,
.botao-principal:hover,
.botao-sucesso:hover,
.botao-perigo:hover,
.botao-secundario:hover {
    transform: translateY(-1px);
    box-shadow: var(--sombra-hover);
}

.botao-acao-principal,
.botao-principal {
    background-color: var(--cor-primaria);
    box-shadow: 0 2px 8px rgba(212, 88, 10, 0.2);
}
.botao-acao-principal:hover,
.botao-principal:hover {
    background-color: var(--cor-primaria-hover);
}
.botao-sucesso {
    background-color: var(--cor-sucesso);
    box-shadow: 0 2px 8px rgba(22, 163, 74, 0.2);
}
.botao-sucesso:hover {
    background-color: #15803d;
}
.botao-secundario {
    background-color: var(--cor-fundo);
    color: var(--cor-texto);
    border: 1px solid var(--cor-borda);
    box-shadow: none;
}
.botao-secundario:hover {
    background-color: var(--cor-borda);
    border-color: var(--cor-texto-suave);
}
.botao-perigo {
    background-color: var(--cor-perigo);
    box-shadow: 0 2px 8px rgba(220, 38, 38, 0.2);
}
.botao-perigo:hover {
    background-color: #b91c1c;
}
.botao-sm {
    padding: 5px 14px;
    font-size: 0.82rem;
}

/* 3. Formularios */
.campo-form {
    margin-bottom: 20px;
}
.campo-form label {
    font-weight: var(--peso-titulo);
    text-transform: none;
    font-size: 0.875rem;
    display: block;
    margin-bottom: 6px;
    color: var(--cor-texto);
}

.input-form {
    width: 100%;
    padding: 11px 16px;
    font-size: 0.95rem;
    font-family: var(--fonte-principal);
    font-weight: var(--peso-normal);
    color: var(--cor-texto);
    background-color: var(--cor-fundo-card);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-borda-padrao);
    transition: border-color var(--transicao), box-shadow var(--transicao);
}
.input-form:focus {
    border-color: var(--cor-primaria);
    box-shadow: 0 0 0 3px rgba(212, 88, 10, 0.15);
    outline: none;
}

.input-form.azul-focus:focus {
    border-color: #007bff;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.15);
}

/* Container para inputs com ícones */
.input-group {
    position: relative;
    width: 100%;
}
.input-group .input-form {
    padding-right: 40px; /* Espaço para o ícone à direita */
}
.input-group-icon {
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--cor-texto-suave);
    pointer-events: none;
}


/* 4. Tabelas */
table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
}
th, td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--cor-borda);
    text-align: left;
    font-weight: var(--peso-normal);
    font-size: 0.9rem;
}
thead th {
    background-color: var(--cor-fundo);
    font-weight: var(--peso-titulo);
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    color: var(--cor-texto-suave);
    padding: 10px 16px;
}
tbody tr {
    transition: background-color var(--transicao);
}
tbody tr:hover {
    background-color: var(--cor-fundo);
}

/* 5. Cards */
.card {
    background-color: var(--cor-fundo-card);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-borda-padrao);
    box-shadow: var(--sombra-card);
    margin-bottom: 20px;
    overflow: hidden;
}
.card-header {
    padding: 18px 24px;
    background-color: var(--cor-fundo-card);
    border-bottom: 1px solid var(--cor-borda);
    border-left: 3px solid var(--cor-primaria);
}
.card-body {
    padding: 24px;
    font-weight: var(--peso-leve);
}

/* 6. Badges (Etiquetas de Status) */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 6px;
    letter-spacing: 0.02em;
}
.badge-sucesso { background: #dcfce7; color: #166534; }
.badge-perigo { background: #fee2e2; color: #991b1b; }
.badge-aviso { background: #fef3c7; color: #78350f; }
.badge-neutro { background: #f3f4f6; color: #6b7280; }
.badge-gestor { background: #fef3c7; color: #92400e; }
.badge-servidor { background: #e0e7ff; color: #3730a3; }

/* 7. Dropdown do Usuário */
.dropdown-usuario {
    position: relative;
    margin-left: 15px;
}
.dropdown-menu {
    display: none; position: absolute; right: 0; top: 100%;
    min-width: 200px; background-color: var(--cor-fundo-card);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-borda-padrao);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    z-index: 100; padding: 10px 0; margin-top: 10px;
}
.dropdown-menu.ativo { display: block; }

.dropdown-menu li { list-style: none; }
.dropdown-menu a {
    display: block; padding: 8px 15px;
    color: var(--cor-texto); text-decoration: none;
    font-weight: var(--peso-normal);
}
.dropdown-menu a:hover { background-color: var(--cor-fundo); }
.dropdown-menu hr { border: 0; border-top: 1px solid var(--cor-borda); margin: 5px 0; }
.dropdown-info {
    display: block; padding: 8px 15px;
    color: var(--cor-texto-suave); font-style: italic; font-size: 0.9rem;
}
.dropdown-link-botao {
    background: none; border: none; color: var(--cor-primaria);
    padding: 8px 15px; text-align: left; width: 100%;
    cursor: pointer; font-size: 1rem; font-family: var(--fonte-principal);
    font-weight: var(--peso-normal);
}
.dropdown-link-botao:hover { background-color: var(--cor-fundo); }

/* 7b. Dropdown de Gestão (navbar admin) */
.dropdown-gestao {
    position: relative;
    display: inline-block;
    margin-left: 25px;
}
.dropdown-botao-gestao {
    background: none;
    border: none;
    color: var(--cor-texto-suave);
    font-size: 1rem;
    font-family: var(--fonte-principal);
    font-weight: var(--peso-normal);
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: color 0.2s;
}
.dropdown-botao-gestao:hover { color: var(--cor-primaria); }
.chevron-gestao {
    font-size: 0.7rem;
    transition: transform 0.2s;
}
.dropdown-gestao.aberto .chevron-gestao {
    transform: rotate(180deg);
}
.dropdown-menu-gestao {
    display: none;
    position: absolute;
    left: 0;
    top: 100%;
    min-width: 220px;
    background-color: var(--cor-fundo-card);
    border: 1px solid var(--cor-borda);
    border-radius: var(--raio-borda-padrao);
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    z-index: 100;
    padding: 10px 0;
    margin-top: 10px;
    list-style: none;
}
.dropdown-gestao.aberto .dropdown-menu-gestao { display: block; }
.dropdown-menu-gestao li { list-style: none; }
.dropdown-menu-gestao a {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 15px;
    color: var(--cor-texto);
    text-decoration: none;
    font-weight: var(--peso-normal);
    white-space: nowrap;
}
.dropdown-menu-gestao a:hover { background-color: var(--cor-fundo); }
.dropdown-menu-gestao hr { border: 0; border-top: 1px solid var(--cor-borda); margin: 5px 0; }

/* 8. Estilos do Dashboard */
.container-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.titulo-secao {
    margin-top: 30px;
    margin-bottom: 15px;
}

/* 9. Estilos da Pagina de Login */
.login-page {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background-color: var(--cor-fundo);
    padding: 20px;
}
.login-wrapper {
    width: 100%;
    max-width: 420px;
}
.login-wrapper .card {
    text-align: center;
    padding: 48px 40px 36px;
}
.login-brasao {
    width: 72px;
    height: auto;
    margin-bottom: 16px;
    opacity: 0.9;
}
.login-titulo {
    font-size: 1.5rem;
    color: var(--cor-primaria);
    margin-bottom: 4px;
    letter-spacing: -0.3px;
}
.login-subtitulo {
    font-size: 0.88rem;
    color: var(--cor-texto-suave);
    font-weight: var(--peso-leve);
    margin-bottom: 32px;
}
.login-btn-entrar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 13px 20px;
    border-radius: var(--raio-borda-padrao);
    font-size: 1rem;
    font-weight: var(--peso-titulo);
    text-decoration: none;
    border: none;
    cursor: pointer;
    color: #fff;
    background-color: var(--cor-primaria);
    box-shadow: 0 2px 8px rgba(212, 88, 10, 0.25);
    transition: background-color var(--transicao), transform var(--transicao);
    margin-bottom: 12px;
}
.login-btn-entrar:hover {
    background-color: var(--cor-primaria-hover);
    transform: translateY(-1px);
}
.login-btn-admin {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    padding: 11px 20px;
    border-radius: var(--raio-borda-padrao);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid var(--cor-borda);
    cursor: pointer;
    color: var(--cor-texto-suave);
    background: var(--cor-fundo);
    transition: border-color var(--transicao), color var(--transicao);
    margin-bottom: 8px;
}
.login-btn-admin:hover {
    border-color: var(--cor-texto-suave);
    color: var(--cor-texto);
}
.login-admin-form {
    display: none;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--cor-borda);
    text-align: left;
    animation: fadeIn 0.25s ease;
}
.login-admin-form.visible { display: block; }
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}
.login-admin-submit {
    width: 100%;
    padding: 11px 20px;
    border-radius: var(--raio-borda-padrao);
    font-size: 0.9rem;
    font-weight: 600;
    border: none;
    cursor: pointer;
    color: #fff;
    background: var(--cor-texto-suave);
    transition: background var(--transicao);
}
.login-admin-submit:hover { background: var(--cor-texto); }
.login-voltar {
    display: inline-block;
    margin-top: 10px;
    font-size: 0.82rem;
    color: var(--cor-texto-suave);
    cursor: pointer;
    text-decoration: underline;
    border: none;
    background: none;
    font-family: var(--fonte-principal);
}
.login-voltar:hover { color: var(--cor-texto); }
.login-cadastro {
    margin-top: 28px;
    font-size: 0.85rem;
    color: var(--cor-texto-suave);
}
.login-cadastro a {
    color: var(--cor-primaria);
    text-decoration: none;
    font-weight: 600;
}
.login-cadastro a:hover { text-decoration: underline; }
.botao-principal.full-width {
    width: 100%;
    margin-top: 20px;
}

@media (max-width: 480px) {
    .login-wrapper .card { padding: 36px 24px 28px; }
    .login-titulo { font-size: 1.3rem; }
}

/* 10. Alertas */
.mensagens-container {
    margin-bottom: 20px;
}
.alerta {
    padding: 15px 20px;
    border: 1px solid transparent;
    border-radius: var(--raio-borda-padrao);
}
.alerta-success {
    background-color: #d1e7dd;
    color: #0f5132;
    border-color: #badbcc;
}
.alerta-error {
    background-color: #f8d7da;
    color: #721c24;
    border-color: #f5c6cb;
}
.alerta-info {
    padding: 15px 20px;
    background-color: #f0f4f8;
    color: #31708f;
    border: 1px solid #bce8f1;
    border-radius: var(--raio-borda-padrao);
}

/* 11. Modal */
.modal {
    display: none; position: fixed; z-index: 1000;
    left: 0; top: 0; width: 100%; height: 100%;
    background-color: rgba(0,0,0,0.5);
    justify-content: center; align-items: center;
}
.modal.ativo { display: flex; }
.modal-conteudo {
    background-color: var(--cor-fundo-card);
    border-radius: var(--raio-borda-padrao);
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    width: 100%; max-width: 500px;
    animation: modalFadeIn 0.3s ease-out;
}
.modal-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 15px 20px; border-bottom: 1px solid var(--cor-borda);
}
.modal-header h3 { margin: 0; font-size: 1.5rem; }
.modal-fechar {
    font-size: 2rem; font-weight: bold; line-height: 1;
    color: #aaa; cursor: pointer; background: none; border: none;
}
.modal-fechar:hover { color: var(--cor-texto); }
.modal-body { padding: 20px; }
.modal-body p { font-weight: var(--peso-normal); }
.modal-body strong { font-weight: var(--peso-titulo); color: var(--cor-primaria); }
.modal-footer {
    display: flex; justify-content: flex-end;
    gap: 10px; padding: 15px 20px;
    border-top: 1px solid var(--cor-borda);
}
@keyframes modalFadeIn {
  from { opacity: 0; transform: translateY(-30px); }
  to { opacity: 1; transform: translateY(0); }
}

/* 12. Calendário */
.fc { font-family: var(--fonte-principal); }
.fc .fc-button {
    background-color: #E9ECEF; color: var(--cor-texto);
    border: none; padding: 8px 15px;
    font-weight: var(--peso-titulo); text-transform: uppercase;
    font-size: 0.8rem; border-radius: var(--raio-borda-arredondado);
    transition: background-color 0.2s; box-shadow: none;
}
.fc .fc-today-button {
    background-color: var(--cor-primaria);
    color: #fff;
    box-shadow: 0 2px 8px rgba(212, 88, 10, 0.2);
}
.fc .fc-button:hover { background-color: #dee2e6; }
.fc .fc-today-button:hover { background-color: var(--cor-primaria-hover); }
.fc-daygrid-event {
    background-color: #198754; border: none;
    border-radius: 4px; padding: 2px 5px;
}
.fc .fc-toolbar-title {
    font-weight: var(--peso-titulo);
    font-size: 1.8rem;
}
.fc .fc-col-header-cell-cushion {
    font-weight: var(--peso-titulo);
    color: var(--cor-texto-suave);
    text-decoration: none;
    font-size: 0.9rem;
}
.fc .fc-day-today { background-color: var(--cor-fundo); }

/* 13. O CÓDIGO QUE FALTAVA (ESTILOS DA FOTO NO HEADER) */
.dropdown-botao-icone {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    padding: 0;
    overflow: hidden;
    background-color: var(--cor-fundo);
    border: 1px solid var(--cor-borda);
    cursor: pointer;
}
.navbar-profile-pic {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}
.dropdown-botao-icone .bi-person-circle {
     font-size: 2.2rem;
     color: var(--cor-texto-suave);
     line-height: 1;
}
.dropdown-botao-icone:hover .bi-person-circle {
    color: var(--cor-primaria);
}

/* 14. TEMA ESCURO — variaveis + overrides */
body.tema-escuro {
    --cor-fundo: #121212;
    --cor-fundo-card: #1e1e1e;
    --cor-texto: #e0e0e0;
    --cor-texto-suave: #999;
    --cor-borda: #333;
    --sombra-card: 0 1px 3px rgba(0,0,0,0.2), 0 4px 12px rgba(0,0,0,0.15);
}
body.tema-escuro .navegacao-principal { background-color: #1a1a1a; border-color: #2a2a2a; }
body.tema-escuro .logo { color: var(--cor-primaria); }
body.tema-escuro .menu-principal a { color: #999; }
body.tema-escuro .menu-principal a:hover { color: #fff; }
body.tema-escuro .dropdown-botao-icone { background-color: #2a2a2a; border-color: #444; }
body.tema-escuro .dropdown-botao-icone .bi-person-circle { color: #777; }
body.tema-escuro .dropdown-menu { background-color: #252525; border-color: #444; }
body.tema-escuro .dropdown-menu a { color: #ddd; }
body.tema-escuro .dropdown-menu a:hover { background-color: #333; }
body.tema-escuro .dropdown-menu hr { border-top: 1px solid #444; }
body.tema-escuro .dropdown-info { color: #999; }
body.tema-escuro .dropdown-link-botao { color: #e87a5a; }
body.tema-escuro .dropdown-link-botao:hover { background-color: #333; }
body.tema-escuro .input-form { background-color: #252525; color: #eee; border-color: #444; }
body.tema-escuro .card-header { background-color: #252525; }
body.tema-escuro .botao-secundario { background-color: #252525; border-color: #444; color: #ddd; }
body.tema-escuro .botao-secundario:hover { background-color: #333; border-color: #666; }
body.tema-escuro thead th { background-color: #1a1a1a; }
body.tema-escuro .alerta-info { background-color: #1a2a33; color: #a3daff; border-color: #2a5a75; }
body.tema-escuro .alerta-success { background-color: #1a3a2a; color: #a3ffc7; border-color: #2a5a3a; }
body.tema-escuro .alerta-error { background-color: #3a1a1a; color: #ffbaba; border-color: #6a3a3a; }
body.tema-escuro .modal-conteudo { background-color: #1e1e1e; border-color: #444; }
body.tema-escuro .modal-header, body.tema-escuro .modal-footer { border-color: #333; }
body.tema-escuro .modal-fechar { color: #777; }
body.tema-escuro .modal-fechar:hover { color: #eee; }
body.tema-escuro .fc .fc-button { background-color: #2a2a2a; color: #ddd; }
body.tema-escuro .fc .fc-today-button { background-color: var(--cor-primaria); }
body.tema-escuro .fc .fc-toolbar-title { color: #eee; }
body.tema-escuro .fc .fc-col-header-cell-cushion { color: #999; }
body.tema-escuro .fc .fc-day-today { background-color: #1a1a1a; }
body.tema-escuro .fc-theme-standard th, body.tema-escuro .fc-theme-standard td { border-color: #333; }
body.tema-escuro .fc-theme-standard th { background-color: #1e1e1e; }
body.tema-escuro .fc .fc-daygrid-day-number { color: #eee; }
body.tema-escuro .fc .fc-day-other .fc-daygrid-day-number { color: #666; }
body.tema-escuro .menu-hamburger { color: #999; }
/* dark mode badges */
body.tema-escuro .badge-sucesso { background: #14532d; color: #86efac; }
body.tema-escuro .badge-perigo { background: #7f1d1d; color: #fca5a5; }
body.tema-escuro .badge-aviso, body.tema-escuro .badge-pendente { background: #713f12; color: #fde68a; }
body.tema-escuro .badge-neutro { background: #374151; color: #9ca3af; }
body.tema-escuro .badge-gestor { background: #713f12; color: #fde68a; }
body.tema-escuro .badge-servidor { background: #312e81; color: #a5b4fc; }
body.tema-escuro .text-sucesso { color: #86efac; }
body.tema-escuro .servidor-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.3); }


/* 15. Container centralizado (páginas de formulário) */
.container-centralizado {
    max-width: 900px;
    margin: 30px auto;
}
.container-centralizado.estreito {
    max-width: 800px;
}

/* 16. Separador de seção (substitui border-top hardcoded) */
.secao-separador {
    margin-top: 30px;
    padding-top: 15px;
    border-top: 2px solid var(--cor-borda);
}

/* 17. Perfil */
.perfil-container {
    display: flex;
    align-items: flex-start;
    gap: 30px;
}
.perfil-foto {
    flex-basis: 200px;
    text-align: center;
}
.perfil-foto img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 50%;
    border: 4px solid var(--cor-borda);
}
.foto-placeholder {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background-color: var(--cor-fundo);
    display: flex;
    justify-content: center;
    align-items: center;
    border: 4px solid var(--cor-borda);
}
.perfil-info { flex-grow: 1; }
.info-lista {
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 1.1rem;
    font-weight: var(--peso-leve);
}
.info-lista li {
    padding: 8px 0;
    border-bottom: 1px dashed var(--cor-borda);
}
.info-lista li strong {
    font-weight: var(--peso-titulo);
    color: var(--cor-texto-suave);
    min-width: 150px;
    display: inline-block;
}
@media (max-width: 768px) {
    .perfil-container { flex-direction: column; align-items: center; }
    .perfil-foto { flex-basis: auto; }
}

/* 18. Badge pendente */
.badge-pendente { background: #fef3c7; color: #78350f; }

/* 19. Erros inline de campo de formulário */
.erro-campo {
    color: #dc3545;
    font-size: 0.85rem;
    margin-top: 4px;
}

/* 20. Alerta de aviso (warning) */
.alerta-aviso {
    padding: 12px 15px;
    background-color: #fff3cd;
    color: #856404;
    border: 1px solid #ffeeba;
    border-radius: var(--raio-borda-padrao);
    margin-top: 5px;
    font-size: 0.9rem;
}

/* 21. Ações em linha (botões de aprovar/recusar) */
.acoes-container {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.acoes-container .botao-sucesso,
.acoes-container .botao-perigo {
    padding: 6px 14px;
    font-size: 0.82rem;
}

/* 22. Ajuste de tabela dentro de card (sem margem dupla) */
.card table { margin-bottom: 0; }

/* 23. Área de upload (drag & drop) */
.upload-zona {
    border: 2px dashed var(--cor-borda);
    border-radius: var(--raio-borda-padrao);
    background-color: var(--cor-fundo);
    padding: 30px 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background-color 0.2s;
    min-height: 180px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
}
.upload-zona:hover {
    border-color: var(--cor-primaria);
    background-color: #fff5f2;
}
.upload-zona.dragover {
    border-color: var(--cor-primaria);
    border-style: solid;
    background-color: #ffe8e0;
    transform: scale(1.01);
}
.upload-zona-icone {
    font-size: 3rem;
    color: var(--cor-primaria);
}
.upload-zona-texto { color: var(--cor-texto-suave); font-size: 0.95rem; }
.upload-zona-destaque { color: var(--cor-primaria); font-weight: var(--peso-titulo); }
.upload-nome-arquivo { color: #198754; font-weight: var(--peso-titulo); font-size: 0.9rem; }

/* 24. Layout de dois painéis (arquivos) */
.layout-dois-paineis {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
    align-items: start;
}
@media (max-width: 768px) {
    .layout-dois-paineis { grid-template-columns: 1fr; }
}

/* 25. Rodapé simples */
.rodape {
    text-align: center;
    padding: 20px 15px;
    margin-top: 40px;
    border-top: 1px solid var(--cor-borda);
    color: var(--cor-texto-suave);
    font-size: 0.85rem;
    font-weight: var(--peso-leve);
}

/* 26. Skip link de acessibilidade */
.skip-link {
    position: absolute;
    top: -100px;
    left: 15px;
    background: var(--cor-primaria);
    color: #fff;
    padding: 8px 15px;
    border-radius: var(--raio-borda-padrao);
    font-weight: var(--peso-titulo);
    text-decoration: none;
    z-index: 9999;
    transition: top 0.2s;
}
.skip-link:focus { top: 10px; }

/* 27. Dark mode — overrides para classes com cores especificas */
body.tema-escuro .foto-placeholder { background-color: #252525; border-color: #444; }
body.tema-escuro .perfil-foto img { border-color: #444; }
body.tema-escuro .upload-zona { background-color: #1a1a1a; border-color: #333; }
body.tema-escuro .upload-zona:hover { background-color: #252525; border-color: var(--cor-primaria); }
body.tema-escuro .upload-zona.dragover { background-color: #2a1a0a; }
body.tema-escuro .alerta-aviso { background-color: #2a2000; color: #ffd970; border-color: #554200; }
body.tema-escuro .rodape { color: #555; }

/* 28. Utilidades faltantes */
.sr-only {
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

.row-campos { display: flex; gap: 20px; width: 100%; }
.col-metade { flex: 1; }
@media (max-width: 600px) {
    .row-campos { flex-direction: column; gap: 0; }
}

.tabela-responsiva { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* 28b. Grid de servidores */
.servidores-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(420px, 1fr));
    gap: 16px;
}
.servidor-card { transition: box-shadow 0.15s; }
.servidor-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); }

.servidor-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
}
.servidor-card-info { flex: 1; min-width: 0; }
.servidor-card-nome {
    margin: 0 0 2px;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--cor-texto);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.servidor-card-usuario { font-size: 0.85rem; }
.servidor-card-badges { display: flex; gap: 6px; flex-shrink: 0; flex-wrap: wrap; }

.servidor-card-detalhes {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 16px;
    margin-bottom: 14px;
    font-size: 0.875rem;
    color: var(--cor-texto-suave);
}
.servidor-detalhe i { margin-right: 4px; opacity: 0.7; }

.servidor-card-acoes {
    display: flex;
    gap: 8px;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid var(--cor-borda);
}

@media (max-width: 500px) {
    .servidores-grid { grid-template-columns: 1fr; }
    .servidor-card-header { flex-direction: column; }
}

.card-header h5 { margin: 0; }

@keyframes pulso {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.3); }
    100% { transform: scale(1); }
}
.icone-pulsando { display: inline-block; animation: pulso 1.5s infinite ease-in-out; }

/* 29. Menu hambúrguer (mobile) */
.menu-hamburger {
    display: none;
    background: none;
    border: none;
    font-size: 1.5rem;
    color: var(--cor-texto);
    cursor: pointer;
    padding: 5px;
}
@media (max-width: 768px) {
    .menu-hamburger { display: block; }
    .menu-navegacao-container {
        display: none;
        flex-direction: column;
        width: 100%;
        position: absolute;
        top: 100%;
        left: 0;
        background-color: var(--cor-fundo-card);
        border-bottom: 1px solid var(--cor-borda);
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        padding: 15px;
        z-index: 99;
    }
    .menu-navegacao-container.menu-aberto { display: flex; }
    .menu-principal { flex-direction: column; }
    .menu-principal li { display: block; margin: 10px 0; margin-left: 0; }
    .menu-acoes-usuario { flex-direction: column; margin-left: 0; margin-top: 15px; }
    .navegacao-container { flex-wrap: wrap; position: relative; }
}

/* === ESTILOS DA TELA DE ONBOARDING === */

.onboarding-card-body {
    display: flex;
    justify-content: space-between; /* Joga o input para um lado e o check para o outro */
    align-items: center;
    gap: 20px;
    padding: 15px 20px;
}

.onboarding-campo {
    flex-grow: 1; /* Faz o campo de input ocupar o espaço disponível */
}

.onboarding-check {
    flex-shrink: 0; /* Impede que o checkbox encolha */
    /* Estilização bonita para o checkbox, como na foto */
    transform: scale(1.5); /* Aumenta o tamanho do checkbox */
    accent-color: var(--cor-primaria); /* Deixa o checkbox laranja */
}

/* Remove as setinhas do input de número (para ficar mais limpo) */
input[type=number]::-webkit-inner-spin-button, 
input[type=number]::-webkit-outer-spin-button { 
  -webkit-appearance: none; 
  margin: 0; 
}
input[type=number] {
  -moz-appearance: textfield;
}

/* 32. Utilidades de layout para eliminar inline styles */
.d-flex { display: flex; }
.d-inline { display: inline; }
.flex-wrap { flex-wrap: wrap; }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.flex-col { flex-direction: column; }
.gap-sm { gap: 8px; }
.gap-md { gap: 10px; }
.gap-lg { gap: 16px; }
.flex-1 { flex: 1; }
.mb-0 { margin-bottom: 0; }
.mb-md { margin-bottom: 15px; }
.mb-lg { margin-bottom: 20px; }
.mt-sm { margin-top: 5px; }
.mt-md { margin-top: 10px; }
.m-0 { margin: 0; }
.p-md { padding: 15px; }
.text-center { text-align: center; }
.text-sm { font-size: 0.85rem; }
.text-muted { color: var(--cor-texto-suave); }
.text-sucesso { color: #166534; }
.text-body { color: var(--cor-texto); }
.ht-btn { height: 42px; }
.word-wrap-cell { max-width: 300px; word-wrap: break-word; white-space: normal; }

/* Spinner overlay */
.spinner-overlay {
    display: none; position: fixed; top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(255,255,255,0.85); z-index: 9999;
    align-items: center; justify-content: center;
    flex-direction: column; gap: 16px;
}
.spinner-circle {
    width: 48px; height: 48px;
    border: 4px solid var(--cor-borda);
    border-top-color: var(--cor-primaria);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}
.spinner-msg {
    font-size: 1.05rem; font-weight: 600; color: var(--cor-texto);
}
.icone-sucesso { color: #16a34a; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Busca/filtro bar */
.busca-bar { display: flex; gap: 10px; align-items: flex-end; }
.busca-bar .campo-form { flex: 1; margin-bottom: 0; }

/* Rodapé de tabela / ações inline */
.tabela-footer {
    padding: 15px; border-top: 1px solid var(--cor-borda);
    display: flex; justify-content: space-between; align-items: center;
}

/* Paginação */
.paginacao {
    list-style: none; margin: 0; padding: 0;
    display: flex; align-items: center; gap: 10px;
}
.paginacao-info { font-size: 0.85rem; color: var(--cor-texto-suave); }

/* Cabeçalho de card com ações */
.card-header-acoes {
    display: flex; justify-content: space-between; align-items: center;
}

/* Info banner acima de tabela */
.info-banner {
    padding: 15px; background: var(--cor-fundo);
    border-bottom: 1px solid var(--cor-borda);
}

/* Select-all area */
.select-all-area {
    padding: 15px;
}
.select-all-area label {
    display: flex; align-items: center; gap: 8px;
    cursor: pointer; margin-bottom: 0;
}

/* Empty state */
.empty-state {
    text-align: center; color: var(--cor-texto-suave);
    padding: 30px 15px;
}
.empty-state .bi { font-size: 2.5rem; }

/* Dashboard resumo paragraph */
.resumo-periodo {
    margin: 15px 0 25px;
}

/* Botão inline nos textos */
.botao-inline {
    padding: 4px 12px; font-size: 0.82rem; vertical-align: middle;
}

/* Ações de tabela */
.acoes-celula { white-space: nowrap; }
.acoes-celula .botao-secundario,
.acoes-celula .botao-perigo {
    padding: 5px 12px; font-size: 0.82rem; margin-right: 4px;
}
.acoes-celula form { display: inline; }

/* Botão de visualizar documento */
.botao-visualizar {
    padding: 2px 8px; font-size: 0.78rem;
}

/* Dark mode overrides for new utilities */
body.tema-escuro .spinner-overlay { background: rgba(0,0,0,0.85); }
body.tema-escuro .info-banner { background: var(--cor-fundo); }
}