@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700&display=swap');

/* --- Variáveis Globais --- */
:root {
    --C01: #0e1627;
    --C02: #1d4ed8;
    --C03: #1e293b; /* Corrigido para valor exato sem var(--tw-bg-opacity) */
    --C04: #334155; /* Corrigido para valor exato sem var(--tw-bg-opacity) */
    --C05: #9CA3AF;
    --C06: #D1D5D8;

    --F01: 'inter', sans-serif;
    --F02: 'roboto', sans-serif;
    --F03: 'poppins', sans-serif;
    --F04: 'Open Sans', sans-serif;
    --F05: 'Nunito', sans-serif;
}

/* --- Reset e Estilos Base --- */
* {
    margin: 0;
    padding: 0;
    border: 0;
    box-sizing: border-box;
}

html, body {
    width: 100%;
    height: 100dvh;
    background-color: var(--C01);
    font-family: var(--F03);
    display: flex;
    /* ADICIONADO: Centraliza o container de login na página */
    justify-content: center;
    align-items: center;
}

/* --- Container Principal do Login --- */
#login-section {
    width: 1000px;
    margin: auto;
    display: flex;
    border-radius: 10px;
    box-shadow: 0 8px 20px 0px #080c1693;
    background-color: var(--C01); /* Adicionado para consistência */
}

/* --- Lado Esquerdo (Logo) --- */
.login-left {
    width: 50%;
    padding: 5%;
    display: flex;
    align-items: center;
    justify-content: center; /* Centraliza o conteúdo */
    text-align: center;
    color: var(--C06);
}

.login-left .logo {
    max-width: 100%;
    margin-bottom: 10px;
}

/* --- Lado Direito (Formulário) --- */
.login-right {
    background-color: var(--C03);
    width: 50%;
    border-radius: 0 10px 10px 0;
    color: var(--C05);
    padding: 5%;
}

.login-right .box h1 {
    color: white;
    font-size: 2em;
}

.login-right .box p {
    font-size: 0.8em;
}

/* --- Formulário --- */
.login-form {
    margin-top: 20px;
}

.form-group {
    margin-top: 30px;
}

.form-group label {
    color: var(--C06);
    font-size: 0.8em;
    margin-bottom: 5px;
    font-weight: 600;
    display: block; /* Garante que o label ocupe a linha */
}

.input-group {
    background-color: var(--C04);
    width: 100%;
    height: 45px;
    border-radius: 5px;
    color: white;
    margin-top: 2px;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.473);
    display: flex;
    align-items: center;
    padding-left: 10px;
    overflow: hidden;
}

.input-group input {
    color: white;
    outline: none;
    background-color: transparent;
    height: 100%;
    width: 100%;
    padding-left: 10px;
}

.input-group input::placeholder {
    color: var(--C05);
}

/* Override browser autofill styles */
.input-group input:-webkit-autofill,
.input-group input:-webkit-autofill:hover, 
.input-group input:-webkit-autofill:focus, 
.input-group input:-webkit-autofill:active {
    -webkit-text-fill-color: white !important;
    -webkit-box-shadow: 0 0 0px 1000px var(--C04) inset !important;
    transition: background-color 5000s ease-in-out 0s;
}

.input-group .icon {
    color: var(--C05);
}

#btn-eye {
    background-color: transparent;
    cursor: pointer;
    padding: 0 10px; /* Adiciona espaçamento */
}

.fa-eye, .fa-eye-slash {
    color: var(--C05);
    font-size: 18px;
}

.btn-submit {
    background-color: var(--C02);
    color: white;
    width: 100%;
    padding: 15px;
    margin-top: 30px;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s; /* Adiciona transição suave */
}

.btn-submit:hover {
    background-color: #0f3dbd;
}

/* --- Mensagem de Erro --- */
.error-message {
    background-color: #f8d7da;
    color: #721c24;
    padding: 10px 15px;
    border-radius: 5px;
    border: 1px solid #f5c6cb;
    text-align: center;
    margin-top: 20px;
    margin-bottom: 10px;
    font-size: 0.9em;
}

.error-message .fa-circle-exclamation {
    margin-right: 8px;
}

/* --- Media Queries para Responsividade --- */

/* Tablets (ex: iPad) */
@media (max-width: 1024px) {
    #login-section {
        flex-direction: column;
        width: 90%;
        max-width: 500px;
    }

    .login-left, .login-right {
        width: 100%;
    }

    .login-left {
        border-radius: 10px 10px 0 0;
        padding: 8%;
    }

    .login-right {
        border-radius: 0 0 10px 10px;
        padding: 8%;
    }

    .login-left .logo {
        max-width: 80%;
    }
}

/* Celulares (ex: iPhone) */
@media (max-width: 768px) {
    /* O body já está centralizando tudo, não precisa de mais regras aqui */
    #login-section {
        width: 95%; /* Um pouco de margem nas laterais fica melhor */
        max-width: 400px; /* Limite para não ficar largo demais */
        /* REMOVIDO: height: 100%, border-radius, box-shadow */
        /* Essas regras forçavam o container a ocupar a tela toda */
    }

    .login-left {
        display: none; /* Mantido, pois é uma boa estratégia para mobile */
    }

    .login-right {
        border-radius: 10px; /* Adiciona borda arredondada de volta */
        padding: 12%;
        /* REMOVIDO: height: 100% e outras regras de flex */
        /* Deixa o conteúdo ditar a altura do card */
    }

    .login-right .box h1 {
        font-size: 1.8em;
    }
}