body.login-page {
    font-family: 'Inter', sans-serif;
    min-height: 100vh;
    background: radial-gradient(circle at 0 0, rgba(13, 110, 253, 0.15), transparent 50%),
                radial-gradient(circle at 100% 100%, rgba(32, 201, 151, 0.12), transparent 45%),
                #f8fafc;
}

.login-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.login-card {
    border-radius: 18px;
    box-shadow: 0 14px 40px rgba(15, 23, 42, 0.12);
    background-color: #ffffff;
}

.login-logo {
    filter: drop-shadow(0 6px 14px rgba(15, 23, 42, 0.1));
}

.login-title {
    font-size: 1.65rem;
    font-weight: 700;
    color: #0f172a;
}

.login-subtitle {
    color: #64748b;
}

.login-label {
    font-size: 0.92rem;
    font-weight: 600;
    color: #334155;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}

.login-validator {
    font-size: 0.78rem;
    color: #dc3545;
}

.login-input {
    border-radius: 12px;
    border: 1px solid #cbd5e1;
    transition: box-shadow 0.2s ease, border-color 0.2s ease;
}

.login-input:focus {
    border-color: #0d6efd;
    box-shadow: 0 0 0 0.18rem rgba(13, 110, 253, 0.2);
}

.login-button {
    border-radius: 12px;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.login-footer {
    color: #64748b;
    font-size: 0.9rem;
}

.login-footer a {
    color: #0d6efd;
}

@media (max-width: 576px) {
    .login-card {
        border-radius: 14px;
    }

    .login-title {
        font-size: 1.45rem;
    }
}