/* ==========================================================================
   VL Login Form — BEM (vl-login__*)
   ========================================================================== */
:root {
    --vl-primary: #6C5CE7;
    --vl-primary-dark: #5849d1;
    --vl-text: #0f172a;
    --vl-muted: #64748b;
    --vl-border: #e5e7eb;
    --vl-bg-soft: #f8f9fb;
    --vl-success: #059669;
    --vl-success-bg: #ecfdf5;
    --vl-success-border: #a7f3d0;
    --vl-error: #dc2626;
    --vl-error-bg: #fef2f2;
    --vl-error-border: #fecaca;
    --vl-shadow: 0 10px 40px -12px rgba(15, 23, 42, 0.12), 0 2px 6px -2px rgba(15, 23, 42, 0.06);
}

/* Card container */
.vl-wrapper .vl-login {
    max-width: 480px !important;
    margin: 0 auto !important;
    background: var(--vl-card-bg, #ffffff) !important;
    padding: 40px !important;
    border-radius: 16px !important;
    box-shadow: var(--vl-shadow) !important;
    box-sizing: border-box !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, Roboto, Oxygen, Ubuntu, sans-serif;
    color: var(--vl-text);
    position: relative;
}

.vl-wrapper .vl-login *,
.vl-wrapper .vl-login *::before,
.vl-wrapper .vl-login *::after {
    box-sizing: border-box;
}

/* Header */
.vl-wrapper .vl-login__header {
    margin-bottom: 28px !important;
    text-align: center;
}

.vl-wrapper .vl-login__heading {
    margin: 0 0 8px !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: var(--vl-text);
    letter-spacing: -0.02em;
}

.vl-wrapper .vl-login__sub {
    margin: 0 !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: var(--vl-muted);
}

/* Messages */
.vl-wrapper .vl-login__message {
    padding: 12px 16px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 500;
    margin-bottom: 20px !important;
    border: 1px solid transparent;
    line-height: 1.45;
}
.vl-wrapper .vl-login__message--success {
    color: var(--vl-success) !important;
    background: var(--vl-success-bg) !important;
    border-color: var(--vl-success-border) !important;
}
.vl-wrapper .vl-login__message--error {
    color: var(--vl-error) !important;
    background: var(--vl-error-bg) !important;
    border-color: var(--vl-error-border) !important;
}

/* Form */
.vl-wrapper .vl-login__form {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
}
.vl-wrapper .vl-login__form[hidden] {
    display: none !important;
}

.vl-wrapper .vl-login__field {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
}

.vl-wrapper .vl-login__label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--vl-muted) !important;
    text-transform: none;
    letter-spacing: 0;
}

.vl-wrapper .vl-login__input {
    width: 100% !important;
    height: 48px !important;
    padding: 0 16px !important;
    background: var(--vl-bg-soft) !important;
    border: 1px solid var(--vl-border) !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    color: var(--vl-text) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
    outline: none !important;
    line-height: 1.5;
    font-family: inherit;
}
.vl-wrapper .vl-login__input::placeholder { color: #9ca3af; }
.vl-wrapper .vl-login__input:hover { border-color: #cbd5e1 !important; }
.vl-wrapper .vl-login__input:focus {
    background: #ffffff !important;
    border-color: var(--vl-primary) !important;
    box-shadow: 0 0 0 4px rgba(108, 92, 231, 0.18) !important;
}

/* Options row */
.vl-wrapper .vl-login__row {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    font-size: 14px;
    flex-wrap: wrap;
}

.vl-wrapper .vl-login__check {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    cursor: pointer;
    color: var(--vl-muted);
    font-size: 14px;
    user-select: none;
}
.vl-wrapper .vl-login__check input[type="checkbox"] {
    width: 16px; height: 16px; margin: 0; accent-color: var(--vl-primary); cursor: pointer;
}

/* Button */
.vl-wrapper .vl-login__btn {
    position: relative;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding: 14px 20px !important;
    margin-top: 4px !important;
    background: var(--vl-primary) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background-color 0.2s ease !important;
    font-family: inherit;
    line-height: 1.2;
    box-shadow: 0 4px 14px -4px rgba(108, 92, 231, 0.5);
}
.vl-wrapper .vl-login__btn:hover:not(:disabled) {
    background: var(--vl-primary-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 8px 20px -6px rgba(108, 92, 231, 0.55) !important;
}
.vl-wrapper .vl-login__btn:active:not(:disabled) { transform: translateY(0) !important; }
.vl-wrapper .vl-login__btn:disabled { opacity: 0.7; cursor: not-allowed; }

.vl-wrapper .vl-login__btn--secondary {
    background: #f1f5f9 !important;
    color: var(--vl-text) !important;
    box-shadow: none !important;
}
.vl-wrapper .vl-login__btn--secondary:hover:not(:disabled) {
    background: #e2e8f0 !important;
}

/* Spinner */
.vl-wrapper .vl-login__spinner {
    width: 16px; height: 16px; display: none;
    border: 2px solid rgba(255,255,255,0.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: vl-login-spin 0.7s linear infinite;
}
.vl-wrapper .vl-login__btn.is-loading .vl-login__spinner { display: inline-block; }
.vl-wrapper .vl-login__btn.is-loading .vl-login__btn-text { opacity: 0.7; }
@keyframes vl-login-spin { to { transform: rotate(360deg); } }

/* Links */
.vl-wrapper .vl-login__link {
    color: var(--vl-primary) !important;
    text-decoration: none !important;
    font-weight: 500;
    font-size: 14px;
    transition: color 0.15s ease;
}
.vl-wrapper .vl-login__link:hover {
    color: var(--vl-primary-dark) !important;
    text-decoration: underline !important;
}

.vl-wrapper .vl-login__forgot { margin-left: auto; }
.vl-wrapper .vl-login__back { display: inline-block; margin-top: 12px; }

/* Footer */
.vl-wrapper .vl-login__footer {
    margin-top: 24px !important;
    padding-top: 20px !important;
    border-top: 1px solid #f1f5f9 !important;
    text-align: center !important;
    font-size: 14px;
    color: var(--vl-muted);
}

/* Logged-in state */
.vl-wrapper .vl-login--logged-in { text-align: center; }
.vl-wrapper .vl-login--logged-in .vl-login__logout-form { margin-top: 20px; }

/* Responsive */
@media (max-width: 1024px) {
    .vl-wrapper .vl-login { max-width: 440px !important; }
}
@media (max-width: 768px) {
    .vl-wrapper .vl-login {
        padding: 28px 22px !important;
        border-radius: 14px !important;
    }
    .vl-wrapper .vl-login__heading { font-size: 24px !important; }
    .vl-wrapper .vl-login__sub { font-size: 14px !important; }
    .vl-wrapper .vl-login__input { height: 46px !important; font-size: 15px !important; }
    .vl-wrapper .vl-login__row { align-items: flex-start; }
    .vl-wrapper .vl-login__forgot { margin-left: 0; }
}
