/* light-theme.css */

/* Variáveis do tema claro */
.app-light-theme {
    --background-color: #fafafa;                /* Fundo bem claro */
    --background-color-secondary: #ffffff;      /* Fundo secundário também claro */
    --text-color: #2e3d49;                      /* Texto escuro */
    --text-color-secondary: #6c757d;            /* Texto secundário em tom cinza */
    --button-background: #e0e0e0;               /* Botões em cinza claro */
    --button-color: #000000;                    /* Texto do botão preto */
    --button-background-success: #c3e6cb;       /* Verde clarinho para “sucesso” */
    --footer-background: #f1f1f1;               /* Rodapé cinza */
    --footer-text-color: #2e3d49;               /* Texto escuro no rodapé */
    --header-background: #ececec;               /* Cabeçalho cinza claro */
    --header-text-color: #2e3d49;               /* Texto escuro no cabeçalho */
    --dropdown-text-color: #000000;             /* Texto em dropdowns preto */
}
/* ============================= */
/* Estilos Globais */
/* ============================= */
.app-light-theme html, body {
    height: 100%;
    margin: 0;
    padding: 0;
    background-color: #e1e9f0; /* Fundo azul claro */
}

.app-light-theme #app-container {
    min-height: 100vh; /* Garante altura total da tela */
    display: flex;
    flex-direction: column;
    background-color: var(--background-color-secondary); /* Azul claro */
}

.app-light-theme #page-content {
    flex: 1;
    padding: 10px;
    background-color: var(--background-color-secondary); /* Azul claro */
}

/* ============================= */
/* Layout Padrão */
/* ============================= */
.app-light-theme body,
.app-light-theme .home-layout {
    background-color: var(--background-color) !important;
    color: var(--text-color) !important;
}

.app-light-theme .overview-section,
.app-light-theme .testimonials-section,
.app-light-theme .cta-section {
    background-color: var(--background-color-secondary) !important;
    color: var(--text-color) !important;
}

/* ============================= */
/* Cabeçalho (Header) */
/* ============================= */
.app-light-theme .header-section {
    background-color: var(--header-background) !important;
    color: var(--dropdown-text-color) !important;
    padding: 15px 20px;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 20px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.app-light-theme .header-logo {
    font-size: 1.8em;
    font-weight: bold;
    color: var(--header-text-color) !important;
    text-decoration: none;
    margin-right: 20px;
}

/* ============================= */
/* Links de Navegação */
/* ============================= */
.app-light-theme .nav-links {
    display: flex;
    gap: 15px;
    margin-left: 20px;
    flex-grow: 1;
}

.app-light-theme .nav-link {
    color: var(--header-text-color) !important;
    text-decoration: none;
    font-weight: 500;
    font-size: 1em;
    transition: color 0.2s ease;
}

.app-light-theme .nav-link:hover {
    color: #d1e9f0 !important;
}

/* ============================= */
/* Dropdown Geral */
/* ============================= */
.app-light-theme .theme-dropdown .Select__control {
    background-color: var(--header-background) !important;
    color: var(--dropdown-text-color) !important;
    border: 1px solid #d1d9e0;
    box-shadow: none !important;
    border-radius: 5px;
}

.app-light-theme .theme-dropdown .Select__menu {
    background-color: var(--background-color-secondary) !important;
    color: var(--dropdown-text-color) !important;
}

.app-light-theme .theme-dropdown .Select__option {
    background-color: var(--background-color-secondary) !important;
    color: var(--dropdown-text-color) !important;
    min-height: 30px !important;
}

.app-light-theme .theme-dropdown .Select__option--is-focused {
    background-color: #d1d9e0 !important;
}

.app-light-theme .theme-dropdown .Select__option--is-selected {
    background-color: var(--button-background) !important;
    color: #ffffff !important;
}

/* ========================================= */
/* Cartões de Funcionalidade (Feature Cards) */
/* ========================================= */
.app-light-theme .feature-card {
    background-color: #ffffff !important;
    color: var(--text-color-secondary) !important;
    border: 1px solid #d1d9e0;
    border-radius: 8px;
    padding: 20px;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.app-light-theme .feature-card:hover {
    transform: translateY(-5px);
    box-shadow: 0px 8px 15px rgba(0, 0, 0, 0.15);
    border-color: #4a90e2;
}

/* ============================= */
/*        Botões Padrão          */
/* ============================= */
.app-light-theme .button-primary {
    background-color: var(--button-background) !important;
    color: var(--button-color) !important;
    padding: 12px 20px;
    font-weight: bold;
    border-radius: 4px;
    text-transform: uppercase;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.app-light-theme .button-primary:hover {
    background-color: #357ab8; /* Azul mais escuro */
    transform: translateY(-2px);
}

/* ============================= */
/* Botão de Cadastro (Sign Up)   */
/* ============================= */
.app-light-theme .button-container {
    display: inline-block;
    margin: 0 5px;  /* Espaçamento entre os botões */
}

.app-light-theme .auth-link {
    display: inline-block;
    padding: 10px 20px;
    border-radius: 5px;
    font-weight: bold;
    color: #ffffff;
    text-align: center;
    text-decoration: none;
    background-color: #4a90e2; /* Cor padrão de fundo */
    transition: background-color 0.3s ease, transform 0.2s ease;
    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.1); /* Sombra leve */
}

.app-light-theme .button-sign-up:hover {
    background-color: #45a482;
    transform: translateY(-2px);
}

.app-light-theme .sign-in-container .auth-link {
    background-color: #4a90e2; /* Azul padrão para Sign In */
}

.app-light-theme .sign-up-container .auth-link {
    background-color: #56c6a9; /* Verde padrão para Sign Up */
}

/* Efeito de hover */
.app-light-theme .sign-in-container .auth-link:hover {
    background-color: #357ab8; /* Azul mais escuro no hover */
    transform: translateY(-2px); /* Leve elevação */
}

.app-light-theme .sign-up-container .auth-link:hover {
    background-color: #45a482; /* Verde mais escuro no hover */
    transform: translateY(-2px);
}

/* ============================= */
/*      Contêiner de Perfil      */
/* ============================= */
.app-light-theme .profile-icon-container {
    position: relative;
    display: inline-block;
}

.app-light-theme .profile-icon {
    font-size: 1.8em;
    color: #ffffff;
    cursor: pointer;
}

.app-light-theme .profile-dropdown {
    display: none;
    position: absolute;
    right: 0;
    background-color: #ffffff;
    min-width: 120px;
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.2);
    z-index: 1;
    border-radius: 5px;
}

.app-light-theme .profile-dropdown a {
    color: #333;
    padding: 10px 16px;
    text-decoration: none;
    display: block;
}

.app-light-theme .profile-dropdown a:hover {
    background-color: #f0f4f8;
}

.app-light-theme .profile-icon-container:hover .profile-dropdown {
    display: block;
}

/* ============================= */
/*        Rodapé (Footer)        */
/* ============================= */
.app-light-theme .footer-section {
    background-color: var(--footer-background) !important;
    color: var(--footer-text-color) !important;
    padding: 20px;
}

.app-light-theme .footer-link {
    color: var(--footer-text-color) !important;
    text-decoration: underline;
    transition: color 0.2s ease;
}

.app-light-theme .footer-link:hover {
    color: #d1e9f0;
}

/* ============================= */
/*      Formulário de Login      */
/* ============================= */
.app-light-theme .login-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start; /* Alinhamento mais próximo do topo */
    min-height: 100vh;  /* Garante que ocupa toda a altura da tela */
    background-color: #f0f4f8; /* Fundo claro */
    padding-top: 10vh; /* Adiciona um espaçamento controlado no topo */
    padding-bottom: 20px; /* Espaçamento na parte inferior */
}

.app-light-theme .login-header {
    text-align: center;
    margin-bottom: 15px; /* Margem um pouco reduzida para alinhar melhor */
}

.app-light-theme .login-title {
    font-size: 2.8em;
    color: #2e3d49;
    font-weight: bold;
}

.app-light-theme .login-form {
    background-color: #ffffff; /* Fundo branco */
    padding: 50px 60px;  /* Aumentado para tornar o formulário maior */
    border-radius: 12px;
    box-shadow: 0px 12px 30px rgba(0, 0, 0, 0.15); /* Sombra mais pronunciada */
    width: 100%;
    max-width: 550px;  /* Aumentado para maior largura */
    display: flex;
    flex-direction: column;
}

.app-light-theme .login-label {
    font-size: 1.3em;
    color: #6c757d;
    margin-bottom: 8px;
}

.app-light-theme .login-input {
    padding: 15px;
    font-size: 1.2em;
    border-radius: 8px;
    border: 1px solid #d1d9e0;
    margin-bottom: 25px;
    transition: border-color 0.3s ease;
}

.app-light-theme .login-input:focus {
    border-color: #4a90e2;
    outline: none;
}

.app-light-theme .login-button {
    padding: 18px 35px;
    background-color: #4a90e2;
    color: #ffffff;
    border: none;
    border-radius: 8px;
    font-size: 1.3em;
    font-weight: bold;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    text-transform: uppercase;
    margin-top: 10px;
}

.app-light-theme .login-button:hover {
    background-color: #357ab8;
    transform: translateY(-2px);
}

.app-light-theme #login-alert {
  margin-top: 20px;
}

/* ============================= */
/*  Mensagens de Erro e Sucesso  */
/* ============================= */
.app-light-theme .login-output {
    margin-top: 20px;
    padding: 15px;
    border-radius: 8px;
    color: #ffffff;
    background-color: #ff4d4d;
    text-align: center;
    font-weight: bold;
    font-size: 1.1em;
    display: none;
}

.app-light-theme .login-output.show {
    display: block;
}

.app-light-theme .login-output.show.success {
    background-color: #4CAF50;
}

/* ============================= */
/*    Link de Esqueceu a Senha   */
/* ============================= */
.app-light-theme .login-footer {
    margin-top: 20px;
    text-align: center;
    font-size: 14px;
}

.app-light-theme .login-forgot-password {
    color: #4a90e2;
    text-decoration: none;
    font-size: 1em;
    transition: color 0.3s ease;
}

.app-light-theme .login-forgot-password:hover {
    color: #357ab8;
}

/* ============================= */
/*  Contêiner de Configurações   */
/* ============================= */
.app-light-theme .settings-container {
    max-width: 700px;
    margin: 0 auto;
    padding: 20px;
    background-color: #ffffff;
    border-radius: 10px;
    box-shadow: 0px 8px 16px rgba(0, 0, 0, 0.1);
}

.app-light-theme .settings-title {
    font-size: 2em;
    text-align: center;
    color: #333;
    margin-bottom: 20px;
}

.app-light-theme .settings-section {
    margin-top: 20px;
    padding: 20px;
    border-top: 1px solid #d1d9e0;
}

.app-light-theme .settings-section-title {
    font-size: 1.5em;
    color: #4a4a4a;
    margin-bottom: 15px;
}

.app-light-theme .settings-label {
    font-size: 1.1em;
    color: #6c757d;
    margin-top: 15px;
    margin-bottom: 5px;
    display: block;
}

.app-light-theme .settings-input {
    width: 100%;
    padding: 10px;
    font-size: 1em;
    border-radius: 5px;
    border: 1px solid #d1d9e0;
    margin-bottom: 10px;
    transition: border-color 0.3s ease;
}

.app-light-theme .settings-input:focus {
    border-color: #4a90e2;
    outline: none;
}

.app-light-theme .settings-button {
    padding: 12px 20px;
    font-size: 1em;
    font-weight: bold;
    color: #ffffff;
    background-color: #4a90e2;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    text-transform: uppercase;
    transition: background-color 0.3s ease, transform 0.2s ease;
    margin-top: 10px;
}

.app-light-theme .settings-button:hover {
    background-color: #357ab8;
    transform: translateY(-2px);
}

.app-light-theme .feedback-message {
    margin-top: 10px;
    padding: 10px;
    border-radius: 5px;
    font-size: 0.9em;
    text-align: center;
}

.app-light-theme .feedback-message.success {
    color: #ffffff;
    background-color: #4CAF50;
}

.app-light-theme .feedback-message.error {
    color: #ffffff;
    background-color: #ff4d4d;
}

/* =============================== */
/* Contêiner de Registro Principal */
/* =============================== */

/* Título da página */
.app-light-theme .page-title {
    font-size: 42px;
    font-weight: bold;
    color: #2e3d49; /* Substitui var(--primary-text-color) */
    text-align: center;
    margin-bottom: 40px;
}

/* Estilos para os cards de registro */
.app-light-theme .registration-cards {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
    padding: 20px;
    margin-top: 10px;
}

/* Estilo individual dos cards */
.app-light-theme .registration-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #2e3d49; /* Substitui var(--text-color) */
    background-color: #ffffff; /* Substitui var(--card-background-color) */
    width: 250px;
    height: 175px;
    border: 1px solid #d1d9e0; /* Substitui var(--card-border-color) */
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    cursor: pointer;
}

/* Efeito hover para os cards */
.app-light-theme .registration-card:hover {
    transform: translateY(-8px);
    box-shadow: 0px 15px 25px rgba(0, 0, 0, 0.2);
    border-color: #4a90e2; /* Adiciona destaque ao hover */
}

/* Estilo do título dentro dos cards */
.app-light-theme .registration-card-title {
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    color: #2e3d49; /* Substitui var(--text-color) */
}




/* ============================================== */
/*      Estilos para o Formulário de Registro     */
/* ============================================== */

/* Formulário de Registro Principal */
.app-light-theme .registration-form {
    max-width: 650px;
    margin: auto;
    padding: 30px;
    background-color: #ffffff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Título do Formulário */
.app-light-theme .form-title {
    font-size: 2em;
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    margin-bottom: 20px;
}

/* Estilos Uniformes para Labels e Inputs */
.app-light-theme .form-group {
    display: flex;
    align-items: flex-start; /* Alinha no topo para que o feedback fique embaixo */
    margin-bottom: 20px; /* Aumenta o espaçamento entre os campos */
}

.app-light-theme .form-label {
    font-size: 1em;
    font-weight: bold;
    color: var(--text-color-secondary);
    min-width: 150px;
    margin-right: 10px;
    display: flex;
    align-items: center;
}

.app-light-theme .required-asterisk {
    color: red;
    font-weight: bold;
    margin-left: 4px;
}

/* Inputs e Dropdowns */
.app-light-theme .form-input, .form-dropdown {
    flex: 1; /* Expande o input para ocupar o espaço restante */
    width: calc(100% + 35px); /* Ajusta a largura para todos os inputs e dropdowns */
    max-width: 350px; /* Limita a largura máxima para manter consistência */
    padding: 7px;
    border-radius: 5px;
    border: 1px solid #d1d9e0;
    font-size: 1em;
    transition: border-color 0.3s ease;
}

.app-light-theme .form-input:focus, .form-dropdown:focus {
    border-color: #4a90e2;
    outline: none;
}

/* Feedback de Mensagem abaixo dos inputs */
.app-light-theme .feedback-message {
    color: #ff4d4d;
    font-size: 0.9em;
    margin-top: 4px;
    width: 100%;
    text-align: left;
    padding-left: 10px; /* Espaçamento para alinhar com o input */
}

/* Legenda de Campo Obrigatório Centralizada */
.app-light-theme .required-field-legend {
    font-size: 0.85em;
    color: #6c757d;
    text-align: center;
    margin-top: 20px;
}


/* Estilo para Requisitos de Senha */
.app-light-theme .requirement {
    font-size: 0.9em;
    margin-bottom: 5px;
    color: #ff4d4d; /* Vermelho para não atendidos */
}

.app-light-theme .requirement.satisfied {
    color: green; /* Verde para requisitos atendidos */
}

.app-light-theme .check-icon {
    color: green !important;
    font-size: 18px;
}



/* ============================= */
/* Botão de Registro (Register)  */
/* ============================= */

/* Botão de Registro ocupa toda a largura */
.app-light-theme #register-button {
    width: 100%;
    font-size: 1em;
    padding: 10px;
    font-weight: bold;
    background-color: var(--button-background);
    color: var(--button-color);
    border-radius: 5px;
    border: none;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.app-light-theme #register-button:hover {
    background-color: #357ab8;
    transform: translateY(-2px);
}

/* ================================================== */
/* Estilo do Botão Register Habilitado e Desabilitado */
/* ================================================== */




/* ====================================================== */
/*      Estilos para o Output do processo de Registro     */
/* ====================================================== */
.app-light-theme #additional-feedback-message {
    background-color: #f0f4f8;  /* Cor de fundo suave */
    color: #333;                /* Cor do texto escuro sutil */
    padding: 15px;              /* Espaçamento interno */
    border-radius: 8px;         /* Bordas arredondadas */
    margin-top: 20px;           /* Espaço acima do elemento */
    font-size: 1.1em;           /* Tamanho de fonte levemente aumentado */
    line-height: 1.6;           /* Espaçamento entre linhas */
}

/* ====================================================== */
/*     Estilos para a página de verificação de e-mail     */
/* ====================================================== */
/* Centraliza o card de verificação */
.app-light-theme .verification-container {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80vh; /* Alinha verticalmente na tela */
    width: 100%; /* Garante que o contêiner ocupe toda a largura */
    box-sizing: border-box; /* Inclui padding nas dimensões */
    overflow: visible; /* Garante que o conteúdo que expande não seja cortado */
}

/* Estiliza o card de verificação */
.app-light-theme .verification-card {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem; /* Espaçamento interno para a mensagem */
    background-color: #fff; /* Cor de fundo do card */
    border-radius: 8px; /* Borda arredondada */
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Sombra */
    width: auto; /* Permite que o card se ajuste ao conteúdo */
    height: auto; /* Permite que o card se ajuste à altura do conteúdo */
    max-width: none; /* Remove quaisquer limites no tamanho */
    white-space: normal; /* Permite quebra de linha no texto */
    overflow: visible; /* Garante que nada seja cortado */
    animation: fadeIn 0.8s ease-in-out;
}

/* Estilos do texto dentro do card */
.app-light-theme .verification-card p {
    margin: 0;
    padding: 0;
    text-align: center; /* Centraliza o texto */
    white-space: normal; /* Permite quebra de linha */
    word-wrap: break-word; /* Quebra palavras longas */
}

/* Para garantir compatibilidade responsiva */
@media (max-width: 768px) {
    .app-light-theme .verification-card {
        padding: 1rem; /* Adiciona padding consistente em telas menores */
    }
}

/* Animação de fade-in */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Estilo para o título */
.app-light-theme .verification-title {
    font-size: 1.8em;
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    margin-top: 10px;
    margin-bottom: 15px;
}

/* Mensagem de feedback com estilo */
.app-light-theme .verification-feedback-message {
    font-size: 1.2em;
    font-weight: 500;
    text-align: center;
    color: #4CAF50;
}

/* Feedback de erro */
.app-light-theme .verification-feedback-message.error {
    color: #ff4d4d;
}

/* Ícone de sucesso ou erro */
.app-light-theme .bi.bi-envelope-check-fill {
    margin-bottom: 15px;
    color: #4CAF50;
}

.app-light-theme .bi.bi-envelope-x-fill {
    margin-bottom: 15px;
    color: #ff4d4d;
}

/* Ajuste para responsividade */
@media (max-width: 768px) {
    .app-light-theme .verification-card {
        padding: 20px;
    }
    .app-light-theme .verification-title {
        font-size: 1.5em;
    }
}

/* ================================================================= */
/*         Estilos para a página de request de reset de senha        */
/* ================================================================= */

/* Centralização e estilização geral */
.app-light-theme .reset-password-request-form {
    max-width: 400px;  /* Define uma largura máxima mais adequada para o formulário */
    margin: 0 auto;  /* Centraliza o formulário na página */
    padding-top: 50px;  /* Espaçamento superior */
}

.app-light-theme .reset-password-request-form-title {
    text-align: center;
    font-weight: bold;
    margin-bottom: 20px;
}

.app-light-theme .reset-password-request-form-label {
    font-size: 1em;
    font-weight: 600;
    color: #333;
}

.app-light-theme .reset-password-request-form-input {
    width: 100%;  /* Garante que o campo de entrada ocupe a largura do contêiner */
    max-width: 100%;  /* Impede que o campo de entrada ultrapasse os limites do contêiner */
    margin-top: 8px;
    padding: 10px;  /* Ajusta o preenchimento interno */
    border-radius: 5px;
    border: 1px solid #d1d9e0;
    font-size: 1em;  /* Define um tamanho de fonte apropriado */
}

.app-light-theme .reset-password-request-feedback-message {
    color: #ff4d4d;
    font-size: 0.9em;
    margin-top: 5px;
    padding-left: 5px;
}

.app-light-theme .forgot-username-link {
    color: #007bff;
    text-decoration: none;
    font-size: 0.9em;
}

.app-light-theme .forgot-username-link:hover {
    text-decoration: underline;
}

/* Estilização do botão */
.app-light-theme #reset-password-request-button {
    width: 100%;
    font-size: 1em;
    padding: 10px;
    font-weight: bold;
    background-color: var(--button-background);
    color: var(--button-color);
    border-radius: 5px;
    border: none;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.app-light-theme #reset-password-request-button:hover {
    background-color: #357ab8;
    transform: translateY(-2px);
}

/* Mensagem geral de feedback (sucesso/erro) */
.app-light-theme .reset-password-general-feedback-message {
    font-size: 1.2em; /* Tamanho da fonte maior */
    font-weight: bold; /* Deixa o texto mais destacado */
    margin-top: 20px; /* Espaçamento acima da mensagem */
    padding: 15px 20px; /* Adiciona espaço interno */
    border-radius: 8px; /* Bordas arredondadas */
    color: #ffffff; /* Cor do texto */
    background-color: #4CAF50; /* Cor de fundo verde para sucesso */
    text-align: center; /* Centraliza o texto */
    max-width: 500px; /* Limita a largura para manter a mensagem compacta */
    margin-left: auto; /* Centraliza horizontalmente */
    margin-right: auto; /* Centraliza horizontalmente */
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1); /* Adiciona uma leve sombra */
    opacity: 0; /* Oculta por padrão */
    visibility: hidden; /* Garante que esteja invisível inicialmente */
    animation: fadeIn 1s ease-in-out; /* Animação para suavizar a exibição */
}

/* Exibir mensagem quando atualizado */
.app-light-theme .reset-password-general-feedback-message.show {
    opacity: 1; /* Torna visível */
    visibility: visible; /* Remove a invisibilidade */
}

/* Estilo para mensagens de erro */
.app-light-theme .reset-password-general-feedback-message.error {
    background-color: #ff4d4d; /* Vermelho para erros */
    visibility: visible; /* Remove a invisibilidade */
}



/* ====================================================== */
/*         Estilos para a página de reset de senha        */
/* ====================================================== */

/* Formulário de Reset de Senha */
.app-light-theme .reset-password-form {
    max-width: 650px;
    margin: auto;
    padding: 30px;
    background-color: #ffffff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Título do Formulário */
.app-light-theme .reset-password-title {
    font-size: 2em;
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    margin-bottom: 20px;
}

/* Estilos Uniformes para Labels e Inputs */
.app-light-theme .reset-password-form-group {
    display: flex;
    align-items: flex-start; /* Alinha no topo para que o feedback fique embaixo */
    margin-bottom: 20px; /* Aumenta o espaçamento entre os campos */
}

.app-light-theme .reset-password-label {
    font-size: 1em;
    font-weight: bold;
    color: var(--text-color-secondary);
    min-width: 150px;
    margin-right: 10px;
    display: flex;
    align-items: center;
}

/* Inputs e Dropdowns */
.app-light-theme .reset-password-input {
    flex: 1; /* Expande o input para ocupar o espaço restante */
    width: calc(100% + 35px); /* Ajusta a largura para todos os inputs */
    max-width: 350px; /* Limita a largura máxima para manter consistência */
    padding: 7px;
    border-radius: 5px;
    border: 1px solid #d1d9e0;
    font-size: 1em;
    transition: border-color 0.3s ease;
}

.app-light-theme .reset-password-input:focus {
    border-color: #4a90e2;
    outline: none;
}

/* Feedback de Mensagem abaixo dos inputs */
.app-light-theme .reset-password-feedback-message {
    color: #ff4d4d;
    font-size: 0.9em;
    margin-top: 4px;
    width: 100%;
    text-align: left;
    padding-left: 10px; /* Espaçamento para alinhar com o input */
}

/* Estilo para Requisitos de Senha */
.app-light-theme .reset-password-requirements {
    font-size: 0.9em;
    margin-bottom: 5px;
    color: #ff4d4d; /* Vermelho para não atendidos */
    padding-top: 10px; /* Adiciona espaço entre o campo de senha e os requisitos */
}


.app-light-theme .reset-password-requirement.satisfied {
    color: green; /* Verde para requisitos atendidos */
}

/* Ícone de Verificação */
.app-light-theme .reset-password-check-icon {
    color: green !important;
    font-size: 18px;
    text-align: right;
    padding-top: 8px;
}

.app-light-theme #reset-password-submit {
    width: 100%;
    font-size: 1em;
    padding: 10px;
    font-weight: bold;
    background-color: var(--button-background);
    color: var(--button-color);
    border-radius: 5px;
    border: none;
    transition: background-color 0.3s ease, color 0.3s ease;
}

.app-light-theme #reset-password-submit:hover {
    background-color: #357ab8;
    transform: translateY(-2px);
    cursor: pointer;
}


/* ======================================================= */
/*    Estilos para a página de feedback do reset de senha  */
/* ======================================================= */

/* Contêiner geral */
.app-light-theme .reset-password-feedback-container {
    text-align: center;
    margin-top: 50px;
    padding: 20px;
}

/* Mensagem de sucesso */
.app-light-theme .reset-password-feedback-message.success {
    color: #4CAF50; /* Verde para sucesso */
    font-size: 1.5em;
    font-weight: bold;
}

/* Mensagem de erro */
.app-light-theme .reset-password-feedback-message.error {
    color: #ff4d4d; /* Vermelho para erro */
    font-size: 1.5em;
    font-weight: bold;
}

/* Mensagem pendente */
.app-light-theme .reset-password-feedback-message.pending {
    color: #6c757d; /* Cinza enquanto está processando */
    font-size: 1.2em;
    font-style: italic;
}

/* Ícones */
.app-light-theme .reset-password-feedback-message .bi {
    margin-right: 10px;
    font-size: 1.5em;
    vertical-align: middle;
}

/* ========================================= */
/*    Estilos para a página forgot username  */
/* ========================================= */

/* Página de Forgot Username */
.app-light-theme .forgot-username-page {
    max-width: 600px;
    margin: 0 auto;
    padding: 20px;
    text-align: center;
    background-color: #f9f9f9;
    border-radius: 10px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
}

/* Cabeçalho */
.app-light-theme .forgot-username-header {
    margin-bottom: 20px;
}

.app-light-theme .forgot-username-title {
    font-size: 2em;
    font-weight: bold;
    color: #2e3d49;
    margin-bottom: 10px;
}

.app-light-theme .forgot-username-description {
    font-size: 1.2em;
    color: #6c757d;
}

/* Instruções */
.app-light-theme .forgot-username-instructions {
    margin-top: 20px;
    text-align: left;
}

.app-light-theme .forgot-username-steps {
    margin: 20px 0;
    padding-left: 20px;
    font-size: 1.1em;
    color: #2e3d49;
}

.app-light-theme .forgot-username-steps li {
    margin-bottom: 10px;
}

.app-light-theme .forgot-username-support {
    margin-top: 20px;
    font-size: 1em;
    color: #6c757d;
}

/* Link de suporte */
.app-light-theme .forgot-username-support-link {
    display: inline-block;
    margin-top: 10px;
    padding: 10px 15px;
    background-color: #4a90e2;
    color: #ffffff;
    text-decoration: none;
    border-radius: 5px;
    font-size: 1em;
    font-weight: bold;
    transition: background-color 0.3s ease;
}

.app-light-theme .forgot-username-support-link:hover {
    background-color: #357ab8;
}

/* ================================ */
/*   Estilos para a página suporte  */
/* ================================ */

/* Página de suporte */
.app-light-theme .support-page {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
    background-color: #f9f9f9;
    border-radius: 10px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    font-family: Arial, sans-serif;
}

/* Cabeçalho */
.app-light-theme .support-header {
    text-align: center;
    margin-bottom: 30px;
}

.app-light-theme .support-title {
    font-size: 2.5em;
    font-weight: bold;
    color: #2e3d49;
}

.app-light-theme .support-description {
    font-size: 1.2em;
    color: #6c757d;
}

/* FAQ Section */
.app-light-theme .support-faq {
    margin-bottom: 20px;
    margin-top: 20px;
}

.app-light-theme .faq-title {
    font-size: 2em;
    color: #2e3d49;
    margin: 20px;
    margin-top: 20px;
}


.app-light-theme .faq-section-title {
    font-size: 1.5em;
    margin: 20px;
    margin-top: 20px;
}

/* Form Section */
.app-light-theme .support-contact-form {
    margin-top: 40px;
}

.app-light-theme .contact-form-title {
    font-size: 2em;
    color: #2e3d49;
    margin-bottom: 20px;
    text-align: center;
}

.app-light-theme .contact-form-description {
    font-size: 1.1em;
    color: #6c757d;
    text-align: center;
    margin-bottom: 20px;
}

.app-light-theme .contact-form {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.app-light-theme .form-label {
    font-size: 1em;
    color: #2e3d49;
    font-weight: bold;
}

.app-light-theme .form-input,
.app-light-theme .form-textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid #d1d9e0;
    border-radius: 5px;
    font-size: 1em;
    color: #2e3d49;
}

.app-light-theme .form-input:focus,
.app-light-theme .form-textarea:focus {
    border-color: #4a90e2;
    outline: none;
}

.app-light-theme .form-textarea {
    min-height: 100px;
    resize: none;
}

.app-light-theme .form-submit-button {
    background-color: #4a90e2;
    color: #ffffff;
    padding: 10px 20px;
    font-size: 1.2em;
    font-weight: bold;
    border: none;
    border-radius: 5px;
    cursor: pointer;
    text-transform: uppercase;
    transition: background-color 0.3s ease;
}

.app-light-theme .form-submit-button:hover {
    background-color: #357ab8;
}

/* ================================== */
/*   Estilos para a página Dashboard  */
/* ================================== */

/* FILTROS */

/* Container de Filtros */
#filter-container {
    display: flex;
    flex-direction: column; /* Alinha os elementos verticalmente */
    align-items: left; /* Centraliza os itens horizontalmente */
    gap: 10px; /* Espaçamento uniforme entre os filtros */
    padding: 12px; /* Adiciona um espaço interno */
    background-color: #f8f9fa; /* Fundo claro */
    border-right: 1px solid #dee2e6;
    height: calc(100vh - 50px); /* Altura do container */
    max-width: 350px; /* Define largura máxima */
}

#filter-container-demo {
    display: flex;
    flex-direction: column; /* Alinha os elementos verticalmente */
    align-items: left; /* Centraliza os itens horizontalmente */
    gap: 10px; /* Espaçamento uniforme entre os filtros */
    padding: 12px; /* Adiciona um espaço interno */
    background-color: #f8f9fa; /* Fundo claro */
    border-right: 1px solid #dee2e6;
    height: calc(100vh - 50px); /* Altura do container */
    max-width: 350px; /* Define largura máxima */
}

/* Estilo dos labels */
.filter-label {
    font-size: 16px; /* Tamanho consistente */
    color: #6c757d;
    margin: 4px;
    display: block;
    text-align: left; /* Alinha o texto à esquerda */
    width: 100%; /* Garante que o label acompanhe o tamanho do elemento */
}

/* Estilo do dropdown */
.highlight-dropdown {
    width: 100%; /* Preenche a largura do container */
    max-width: 300px; /* Define largura máxima */
    margin: 4px;
    padding: 4px;
    font-size: 16px; /* Tamanho consistente */
    height: 40px; /* Altura consistente */
}

/* Estilo do time range picker */
.time-range-picker {
    width: 100%; /* Largura total */
    max-width: 300px; /* Define largura máxima */
    font-size: 16px; /* Tamanho consistente */
    margin: 4px; /* Espaçamento vertical */
    height: 40px; /* Altura consistente */
    padding: 4px; /* Ajusta padding interno */
}

/* Cartão de recomendação */
.recommendation-card {
    background-color: #f8f9fa;
    width: 60px; /* Largura ajustada */
    height: 40px; /* Altura ajustada */
    display: flex;
    align-items: center; /* Centraliza verticalmente */
    justify-content: center; /* Centraliza horizontalmente */
    margin: 4px;
    padding: 4px;
    font-size: 16px; /* Ajusta tamanho do texto */
    font-weight: bold; /* Destaca o texto */
    text-align: center;
}

/* Texto do número no cartão */
.recommendation-count {
    color: #28a745;
    font-weight: bold;
    font-size: 16px; /* Texto ajustado */
    text-align: center;
    margin: 4px;
}


/* CONTEUDO PRINCIPAL

/* Ajuste para o conteúdo principal */
/* Geral */
.dashboard-row {
    height: 100vh;
}

/* Container para o título */
#title-container {
    padding: 8px;
    margin: 12px 12px 12px 12px;
    position: sticky;
    top: 0;
    z-index: 1000; /* Garante que fique acima de outros elementos */
    background-color: var(--background-color); /* Adiciona um fundo consistente */
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.1); /* Sombra para destacar o título */
    border: 1px solid #dee2e6; /* Adiciona uma borda inferior */
}

/* Container para o título */
#title-container-demo {
    padding: 8px;
    margin: 12px 12px 12px 12px;
    position: sticky;
    top: 0;
    z-index: 1000; /* Garante que fique acima de outros elementos */
    background-color: var(--background-color); /* Adiciona um fundo consistente */
    box-shadow: 0 2px 2px rgba(0, 0, 0, 0.1); /* Sombra para destacar o título */
    border: 1px solid #dee2e6; /* Adiciona uma borda inferior */
}

/* Estilo do título */
.dashboard-title {
    text-align: center;
    color: var(--text-color); /* Usa cor definida no tema */
    font-weight: bold;
    font-size: 1.8em; /* Ajusta o tamanho do texto */
    margin: 0;
}


/* Conteúdo principal */
.main-content {
    padding: 15px;
    overflow-y: auto;
    height: calc(100vh - 60px); /* Altura total menos o título */
}

/* Mensagem inicial */
.initial-message {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;
}

/* Tabela de Recomendações */
.recommendations-table {
    border: 1px solid #dee2e6;
    border-radius: 10px;
}

/* Detalhes de Recomendações */
.recommendation-details-card {
    border: 1px solid #007BFF;
    border-radius: 10px;
    background-color: #f8f9fa;
}

.details-title {
    font-weight: bold;
    margin-bottom: 10px;
    color: #007BFF;
}

.details-message {
    font-size: 16px;
    color: #333;
    font-family: Arial, sans-serif;
}

.dashboard-card {
    padding: 15px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    background-color: #ffffff;
    margin-bottom: 20px;
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
    color: #2C3E50;
}

#recommendations-table-container {
    width: 100%; /* Ajusta a largura */
    margin-top: 20px;
    background-color: #FFFFFF; /* Fundo branco */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra leve */
}

#recommendations-table-container-demo {
    width: 100%; /* Ajusta a largura */
    margin-top: 20px;
    background-color: #FFFFFF; /* Fundo branco */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra leve */
}

.card-title {
    font-size: 18px;
    font-weight: bold;
    color: #2C3E50; /* Azul escuro */
    margin: 0;
}

.info-box {
    display: inline-block;
    margin-left: 8px; /* Espaçamento entre o título e o info box */
    vertical-align: middle; /* Alinha com o texto do título */
}

.d-flex {
    display: flex;
    align-items: center;
}

.me-2 {
    margin-right: 10px; /* Espaçamento entre o título e o info box */
}


.details-subtitle {
    font-weight: bold;
    font-size: 16px;
    color: #6c757d;
    margin-top: 20px;
}


/* DETALHES */
.app-light-theme .dashboard-info-button {
    font-size: 12px;
    padding: 1px;
    border: none;
    background-color: transparent;
    cursor: pointer;
}

/* Estilo genérico para todos os spans de status */
.app-light-theme .dashboard-status-text {
    font-weight: bold;
}

/* Estilo geral para as legendas */
.app-light-theme .dashboard-info-legend {
    font-size: 16px; /* Aumente o tamanho da fonte se necessário */
    line-height: 1.8; /* Torne o texto mais espaçado */
    max-width: 600px; /* Defina a largura máxima para as legendas */
    text-align: justify; /* Justifique o texto para uma aparência mais profissional */
    margin-bottom: 10px; /* Espaçamento entre legendas */
}

/* Estilo específico para títulos de seção */
.app-light-theme .dashboard-info-legend-title {
    font-size: 18px;
    font-weight: bold;
    margin-top: 15px;
    margin-bottom: 8px;
    color: #2C3E50; /* Cor do título */
}

/* Fulfilled */
.fulfilled {
    background-color: #E1F9DE; /* Verde claro */
}

/* Not Fulfilled */
.not-fulfilled {
    background-color: #EC7265; /* Vermelho claro */
}

/* No Data */
.no-data {
    background-color: #DBDBDE; /* Cinza claro */
}

/* Not Applicable */
.not-applicable {
    background-color: #EEF6FF; /* Azul claro */
}

/* Centralização e estilização dos modais */
.wide-modal {
    margin: auto; /* Centraliza horizontalmente */
    max-width: 600px; /* Largura máxima */
}

.ultra-wide-modal {
    margin: auto; /* Centraliza horizontalmente */
    max-width: 1000px; /* Largura máxima */
}

.modal-content {
    border-radius: 10px; /* Bordas arredondadas */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3); /* Sombra leve */
    padding: 20px; /* Espaçamento interno */
}

.modal-header, .modal-footer {
    border: none; /* Remove bordas padrão do modal */
}

.modal-title {
    font-size: 20px;
    font-weight: bold;
    color: #2C3E50; /* Azul escuro */
}

.modal-text {
    font-size: 16px;
    color: #4A4A4A; /* Cinza escuro */
    line-height: 1.5;
    text-align: justify;
}


/* Estilo padrão das células com datas */
.app-light-theme #recommendations-table-container tbody tr td:nth-child(n+2) {
    text-align: center;
    vertical-align: middle;
    padding: 8px;
    border: 1px solid #dee2e6; /* Linha de separação suave */
    cursor: pointer; /* Mantém o cursor como pointer se necessário */
}

/* Accordion com cor padrão do tema ao ser selecionado */
.app-light-theme .accordion-button:not(.collapsed) {
    font-weight: bold; /* Negrito para o texto */
}

/* Moldura ao passar o mouse sobre o Accordion */
.app-light-theme .accordion-button:hover {
    border-color: var(--button-background) !important; /* Moldura com cor padrão do tema */
    color: var(--text-color) !important; /* Texto com cor padrão do tema */
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

.app-light-theme .accordion-title {
    text-align: left;
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 0.8em;
}

html {
    scroll-behavior: smooth;
}

/* Estilo base para todos os ícones de exportação */
.export-icon {
    cursor: pointer;           /* Ícone clicável */
    font-size: 16px;           /* Tamanho do ícone */
    color: #007bff;            /* Cor azul */
    margin-left: 10px;         /* Espaço entre o ícone e o texto/elemento anterior */
    vertical-align: middle;
    transition: color 0.3s;    /* Animação suave ao passar o mouse */
}

/* Alteração de cor ao passar o mouse */
.export-icon:hover {
    color: #0056b3;            /* Cor azul escuro ao hover */
}

/* Container para alinhar título, info box e ícone */
.align-items-center {
    display: inline-block;
    margin-left: 10px; /* Espaçamento entre o título e o info box */
}

/* ============================= */
/* Estilos para Privacy Policy */
/* ============================= */

#privacy-policy-title {
    margin: 12px;
    padding: 12px;
}
/* Estilos para a seção centralizada */
.app-light-theme .privacy-section {
    background-color: #ffffff; /* Fundo branco */
    color: var(--text-color); /* Cor do texto */
    padding: 20px; /* Espaçamento interno */
    border-radius: 8px; /* Bordas arredondadas */
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); /* Sombra suave */
    margin: 20px auto; /* Espaçamento externo e centralização horizontal */
    max-width: 800px; /* Largura máxima */
    text-align: left; /* Texto centralizado */
}

/* Estilo para os títulos dentro da seção */
.app-light-theme .privacy-section h2 {
    font-size: 2em; /* Tamanho do título */
    font-weight: bold; /* Negrito */
    color: var(--text-color); /* Cor principal do texto */
    margin-bottom: 15px; /* Espaçamento inferior */
    text-align: left; /* Centraliza o título */
}

/* Estilo para os parágrafos */
.app-light-theme .privacy-section p {
    font-size: 1em; /* Tamanho do texto */
    line-height: 1.6; /* Espaçamento entre linhas */
    color: var(--text-color-secondary); /* Cor secundária do texto */
    margin-bottom: 15px; /* Espaçamento inferior */
}

/* Estilo para listas */
.app-light-theme .privacy-section ul {
    list-style-type: disc; /* Marcadores */
    margin: 15px auto; /* Centraliza a lista */
    padding-left: 40px; /* Espaçamento à esquerda */
    text-align: left; /* Alinha os itens à esquerda */
}

/* Estilo para itens de lista */
.app-light-theme .privacy-section li {
    margin-bottom: 10px; /* Espaçamento entre itens */
    color: var(--text-color-secondary); /* Cor secundária */
}

/* Estilo para subtítulos */
.app-light-theme .privacy-section h3 {
    font-size: 1.5em; /* Tamanho do subtítulo */
    font-weight: bold; /* Negrito */
    margin-top: 20px; /* Espaçamento superior */
    margin-bottom: 10px; /* Espaçamento inferior */
    text-align: left; /* Centraliza o subtítulo */
    color: var(--text-color); /* Cor principal */
}

/* ============================= */
/* Estilos para Terms of Service */
/* ============================= */

#privacy-policy-title {
    margin: 12px;
    padding: 12px;
}

/* Estilos para a seção centralizada */
.app-light-theme .privacy-section {
    background-color: #ffffff; /* Fundo branco */
    color: var(--text-color); /* Cor do texto */
    padding: 20px; /* Espaçamento interno */
    border-radius: 8px; /* Bordas arredondadas */
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); /* Sombra suave */
    margin: 20px auto; /* Espaçamento externo e centralização horizontal */
    max-width: 800px; /* Largura máxima */
    text-align: left; /* Texto alinhado à esquerda */
}

/* Estilo para os títulos dentro da seção */
.app-light-theme .privacy-section h2 {
    font-size: 2em; /* Tamanho do título */
    font-weight: bold; /* Negrito */
    color: var(--text-color); /* Cor principal do texto */
    margin-bottom: 15px; /* Espaçamento inferior */
    text-align: left; /* Títulos alinhados à esquerda */
}

/* Estilo para os parágrafos */
.app-light-theme .privacy-section p {
    font-size: 1em; /* Tamanho do texto */
    line-height: 1.6; /* Espaçamento entre linhas */
    color: var(--text-color-secondary); /* Cor secundária do texto */
    margin-bottom: 15px; /* Espaçamento inferior */
}

/* Estilo para listas */
.app-light-theme .privacy-section ul {
    list-style-type: disc; /* Marcadores */
    margin: 15px auto; /* Centraliza a lista */
    padding-left: 40px; /* Espaçamento à esquerda */
    text-align: left; /* Alinha os itens à esquerda */
}

/* Estilo para itens de lista */
.app-light-theme .privacy-section li {
    margin-bottom: 10px; /* Espaçamento entre itens */
    color: var(--text-color-secondary); /* Cor secundária */
}

/* Estilo para subtítulos */
.app-light-theme .privacy-section h3 {
    font-size: 1.5em; /* Tamanho do subtítulo */
    font-weight: bold; /* Negrito */
    margin-top: 20px; /* Espaçamento superior */
    margin-bottom: 10px; /* Espaçamento inferior */
    text-align: left; /* Subtítulos alinhados à esquerda */
    color: var(--text-color); /* Cor principal */
}


/* ============================= */
/*     Estilos para About Us     */
/* ============================= */

#about-us-title {
    margin: 12px;
    padding: 12px;
}

/* Estilo para o cabeçalho */
.app-light-theme .about-header {
    background-color: var(--background-color-secondary); /* Fundo suave */
    color: var(--text-color); /* Cor do texto */
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); /* Sombra */
    text-align: center;
}

/* Estilo para seções */
.app-light-theme .about-section {
    background-color: #ffffff; /* Fundo branco */
    color: var(--text-color); /* Cor do texto */
    padding: 20px; /* Espaçamento interno */
    border-radius: 8px; /* Bordas arredondadas */
    box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); /* Sombra */
    margin: 20px auto; /* Centralização e espaçamento */
    max-width: 800px; /* Largura máxima */
    text-align: left; /* Alinha o texto à esquerda */
}

/* Estilo para títulos dentro das seções */
.app-light-theme .about-section h2 {
    font-size: 2em; /* Tamanho do título */
    font-weight: bold; /* Negrito */
    margin-bottom: 15px; /* Espaçamento inferior */
    color: var(--text-color); /* Cor principal do texto */
}

/* Estilo para parágrafos */
.app-light-theme .about-section p {
    font-size: 1em; /* Tamanho do texto */
    line-height: 1.6; /* Espaçamento entre linhas */
    color: var(--text-color-secondary); /* Cor secundária do texto */
    margin-bottom: 15px; /* Espaçamento inferior */
}

/* =============================== */
/* Estilo da Página Approve Access */
/* =============================== */

/* Contêiner principal */
.approve-access-container {
    background-color: var(--background-color-secondary);
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
}

/* Título */
.approve-access-title {
    font-size: 2rem;
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    margin-bottom: 20px;
}

/* Mensagem de erro */
.approve-access-error-message {
    font-size: 1rem; /* Tamanho do texto reduzido */
    background-color: #f8d7da;
    padding: 12px 16px;
    border: 1px solid #f5c6cb;
    border-radius: 8px;
    text-align: center;
    max-width: 400px; /* Largura máxima */
    margin: 0 auto 12px auto; /* Centraliza horizontalmente */
}

/* Mensagem de aprovação */
.approve-access-message-container {
    text-align: center;
    margin: 12px 0;
}

.approve-access-message {
    font-size: 1.1rem;
    color: var(--text-color-secondary);
}

/* Botões de aprovação e rejeição */
.approve-access-button {
    padding: 8px 16px; /* Reduz o padding */
    margin: 8px 8px 8px 12px;
    font-size: 0.9rem; /* Reduz o tamanho da fonte */
    font-weight: bold;
    color: var(--button-color);
    border-radius: 4px;
    text-transform: uppercase;
    transition: background-color 0.3s ease, transform 0.2s ease;
    width: 120px; /* Largura fixa menor */
    text-align: center; /* Centraliza o texto */
    cursor: pointer;
}

.approve-access-button.approve {
    background-color: var(--button-background-success);
    border: none;
}

.approve-access-button.approve:hover {
    background-color: #45a482; /* Verde mais escuro no hover */
}

.approve-access-button.reject {
    background-color: #ff4d4d;
    border: none;
}

.approve-access-button.reject:hover {
    background-color: #d93025; /* Vermelho mais escuro no hover */
}

/* Espaçamento entre botões no grupo */
.approve-access-button-group > .btn {
    margin: 0 5px; /* Adiciona espaço horizontal entre os botões */
}

/* Botão desativado */
.approve-access-button.disabled {
    background-color: #e0e0e0;
    color: #b0b0b0;
    cursor: not-allowed;
}

/* Botão selecionado */
.approve-access-button.selected {
    border: 2px solid #0056b3;
    background-color: #0056b3;
    color: #ffffff;
}

/* Mensagem de feedback */
.approve-access-feedback {
    margin-top: 20px;
    font-size: 1rem;
    color: var(--text-color-secondary);
    text-align: center;
}

/* =============================== */
/* Estilo da Página Reset User Password */
/* =============================== */

/* Contêiner principal */
.reset-user-password-container {
    background-color: var(--background-color-secondary);
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
}

/* Título */
.reset-user-password-title {
    font-size: 2rem;
    font-weight: bold;
    color: var(--text-color);
    text-align: center;
    margin-bottom: 20px;
}

/* Mensagem de erro */
.reset-user-password-error-message {
    font-size: 1rem; /* Tamanho do texto reduzido */
    background-color: #f8d7da;
    padding: 12px 16px;
    border: 1px solid #f5c6cb;
    border-radius: 8px;
    text-align: center;
    max-width: 400px; /* Largura máxima */
    margin: 0 auto 12px auto; /* Centraliza horizontalmente */
}

/* Mensagem principal */
.reset-user-password-message-container {
    text-align: center;
    margin: 12px 0;
}

.reset-user-password-message {
    font-size: 1.1rem;
    color: var(--text-color-secondary);
}

/* Botões de confirmação e cancelamento */
.reset-user-password-button {
    padding: 8px 16px; /* Reduz o padding */
    margin: 8px 8px 8px 12px;
    font-size: 0.9rem; /* Reduz o tamanho da fonte */
    font-weight: bold;
    color: var(--button-color);
    border-radius: 4px;
    text-transform: uppercase;
    transition: background-color 0.3s ease, transform 0.2s ease;
    width: 120px; /* Largura fixa menor */
    text-align: center; /* Centraliza o texto */
    cursor: pointer;
}

.reset-user-password-button.confirm {
    background-color: var(--button-background-success);
    border: none;
}

.reset-user-password-button.confirm:hover {
    background-color: #45a482; /* Verde mais escuro no hover */
}

.reset-user-password-button.cancel {
    background-color: #ff4d4d;
    border: none;
}

.reset-user-password-button.cancel:hover {
    background-color: #d93025; /* Vermelho mais escuro no hover */
}

/* Espaçamento entre botões no grupo */
.reset-user-password-button-group > .btn {
    margin: 0 5px; /* Adiciona espaço horizontal entre os botões */
}

/* Botão desativado */
.reset-user-password-button.disabled {
    background-color: #e0e0e0;
    color: #b0b0b0;
    cursor: not-allowed;
}

/* Botão selecionado */
.reset-user-password-button.selected {
    border: 2px solid #0056b3;
    background-color: #0056b3;
    color: #ffffff;
}

/* Mensagem de feedback */
.reset-user-password-feedback {
    margin-top: 20px;
    font-size: 1rem;
    color: var(--text-color-secondary);
    text-align: center;
}
