/* Reset padrão para garantir consistência entre navegadores */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}

body {
    min-height: 100vh;
    width: 100%;
    background: #f1f5f9; /* Tom de cinza azulado moderno */
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
}

.container {
    width: 100%;
    max-width: 400px; /* Garante que não estoure em telas grandes */
    background: white;
    border-radius: 12px;
    padding: 30px; 
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    text-align: center; 
}

h2 {
    font-weight: 800;
    font-size: 28px;
    color: #1e293b; /* Azul escuro para melhor leitura */
    margin-bottom: 20px;
}

/* Estilização do Formulário */
form {
    display: flex;
    flex-direction: column;
    text-align: left;
}

label {
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 8px;
    color: #475569;
    text-transform: uppercase; /* Dá um ar mais profissional */
    letter-spacing: 0.5px;
}

input {
    padding: 12px;
    border: 1.5px solid #cbd5e1;
    border-radius: 8px;
    margin-bottom: 20px;
    outline: none;
    font-size: 16px;
    color: #334155;
    transition: all 0.2s ease-in-out;
}

input:focus {
    border-color: #22c55e; /* Verde que você escolheu */
    box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.15);
}

/* Remove o ícone nativo de 'olhinho' do Edge e Internet Explorer */
input::-ms-reveal,
input::-ms-clear {
    display: none;
}

/* Botão de Ação */
button {
    padding: 14px;
    border-radius: 8px;
    border: none;
    font-weight: 700;
    font-size: 16px;
    background-color: #0ea5e9; /* Azul celeste com melhor contraste que o anterior */
    color: white;
    cursor: pointer;
    transition: transform 0.1s, background 0.2s;
    margin-top: 10px;
}

button:hover {
    background-color: #0284c7;
}

button:active {
    transform: scale(0.98); /* Efeito de clique real */
}

/* Link de voltar ou recuperar senha */
 a {
    
   display: inline-block;
    align-self: center; /* ESTA É A CHAVE: Centraliza o item dentro do flex column */
    text-decoration: none;
    color: #64748b;
    font-size: 14px;
    margin-top: 20px;
    transition: color 0.2s;
}

a:hover {
    color: #22c55e;
    text-decoration: underline;
}

/* Estilo para Mensagens de Erro (PHP) */
.erro {
    background-color: #fee2e2;
    color: #dc2626;
    padding: 10px;
    border-radius: 6px;
    margin-bottom: 15px;
    font-size: 14px;
    border: 1px solid #fecaca;
}