.login-container {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 80vh;
}

.login-box {
    background-color: #ffffff;
    padding: 2rem;
    border-radius: 10px;
    width: 320px;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.input-group {
    margin-bottom: 1.2rem;
}

label {
    display: block;
    margin-bottom: 0.5rem;
}

input[type="text"],
input[type="password"] {
    width: 100%;
    padding: 0.6rem;
    border: 1px solid #ccc;
    border-radius: 5px;
}

.login-button {
    width: 100%;
    padding: 0.8rem;
    background-color: #007BFF;
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}

.flash-messages {
    margin-bottom: 1rem;
    list-style: none;
    padding: 0;
}

.flash {
    padding: 0.5rem;
    margin-bottom: 0.5rem;
    border-radius: 5px;
}

.flash.success { background-color: #d4edda; color: #155724; }
.flash.danger  { background-color: #f8d7da; color: #721c24; }
.flash.warning { background-color: #fff3cd; color: #856404; }
.flash.info    { background-color: #d1ecf1; color: #0c5460; }

.g-recaptcha {
    display: flex;
    justify-content: center;
    margin: 1.2rem 0;
}
