@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

:root { 
    --cor-principal: #a2c4c6; 
    --cor-destaque: #f8c8dc; 
    --cor-apoio: #f7b288; 
    --cor-texto: #5a5a5a;
    --cor-texto-claro: #777;
    --cor-fundo: #fefcf9; 
    --cor-cinza-claro: #f5f5f5;
    --sombra-suave: 0 8px 25px rgba(0, 0, 0, 0.06);
    --transicao-rapida: all 0.3s ease;
}

body {
    font-family: 'Poppins', sans-serif;
    background-color: var(--cor-cinza-claro);
    color: var(--cor-texto);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.auth-container {
    display: flex;
    min-height: 100vh;
    width: 100%;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.auth-card {
    display: flex;
    width: 100%;
    max-width: 1000px;
    min-height: 650px;
    background-color: #fff;
    border: none;
    border-radius: 1.5rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    overflow: hidden;
}

.auth-form-section {
    flex: 1;
    padding: 2.5rem 3rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow-y: auto; /* Permite scroll se o formulário for grande */
}

.auth-image-section {
    flex: 1;
    /* Imagem padrão, pode ser sobreposta */
    background: url('https://images.pexels.com/photos/1648377/pexels-photo-1648377.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1') no-repeat center center;
    background-size: cover;
}

/* Imagens customizadas por página */
.auth-image-register {
    background-image: url('https://images.pexels.com/photos/3661633/pexels-photo-3661633.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1');
}
.auth-image-forgot {
     background-image: url('https://images.pexels.com/photos/4011317/pexels-photo-4011317.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1');
}
.auth-image-pending {
     background-image: url('https://images.pexels.com/photos/7136611/pexels-photo-7136611.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1');
}


/* Em telas menores, esconde a imagem */
@media (max-width: 992px) {
    .auth-image-section {
        display: none;
    }
    .auth-card {
        max-width: 500px;
        min-height: auto;
        margin-top: 2rem;
        margin-bottom: 2rem;
    }
    .auth-form-section {
        padding: 2rem 2.5rem;
    }
}

.auth-logo {
    max-width: 140px;
    margin-bottom: 1.5rem;
}

.auth-title {
    font-weight: 700;
    font-size: 2rem;
    color: #333;
}

.auth-subtitle {
    color: var(--cor-texto-claro);
    margin-bottom: 2rem;
    font-size: 1.1rem;
}

.form-label {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--cor-texto);
}

.form-control {
    border-radius: 0.5rem;
    padding: 0.85rem 1rem;
    background-color: var(--cor-cinza-claro);
    border: 1px solid #e0e0e0;
    transition: var(--transicao-rapida);
}

.form-control:focus {
    background-color: #fff;
    border-color: var(--cor-principal);
    box-shadow: 0 0 0 4px rgba(162, 196, 198, 0.3);
}

.btn-primary {
    background-color: var(--cor-principal);
    border: none;
    padding: 0.85rem;
    border-radius: 0.5rem;
    font-weight: 700;
    color: white;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(162, 196, 198, 0.4);
}

.btn-primary:hover {
    background-color: #8bb9bb; /* Tom mais escuro */
    transform: translateY(-3px);
    box-shadow: 0 7px 20px rgba(162, 196, 198, 0.6);
}

.auth-links {
    font-size: 0.9rem;
    margin-top: 1.5rem;
    text-align: center;
}
.auth-links a {
    color: var(--cor-principal);
    text-decoration: none;
    font-weight: 600;
}
.auth-links a:hover {
    color: var(--cor-apoio);
}

/* Para o formulário de registro */
.auth-form-section .row {
     max-height: 450px; /* Limita a altura da área de scroll */
     overflow-y: auto;
     padding-right: 15px;
     margin-right: -15px;
}

/* Ajustes de Alerta */
.alert {
    border-radius: 0.5rem;
    padding: 0.85rem 1rem;
}
.alert-danger {
    background-color: #f8d7da;
    border-color: #f5c6cb;
    color: #721c24;
}
.alert-success {
    background-color: #d4edda;
    border-color: #c3e6cb;
    color: #155724;
}
.alert-info {
    background-color: #d1ecf1;
    border-color: #bee5eb;
    color: #0c5460;
}

/* Página de Verificação (sem imagem) */
.auth-card-simple {
    max-width: 600px;
    min-height: auto;
    text-align: center;
}