/**
 * VAD Custom Login - Clean Stylesheet
 * Modern, accessible, and maintainable
 */

/* FIX */
.bb-rl-login-header {display:none; }
.login-heading {
    text-align: center;
}
.lostmenot, .forgetmenot {
    display:none !important;
}
input {
    font-size:14px !important;
}
/* ==========================================================================
   CSS Variables & Base
   ========================================================================== */

:root {
    /* These are overridden by PHP */
    --vad-primary: #2a4b6d;
    --vad-accent: #c96858;
    --vad-radius: 8px;

    /* Static variables */
    --vad-gray-100: #f7f8fa;
    --vad-gray-200: #e9ecef;
    --vad-gray-300: #dee2e6;
    --vad-gray-400: #ced4da;
    --vad-gray-500: #adb5bd;
    --vad-gray-600: #6c757d;
    --vad-gray-700: #495057;
    --vad-gray-800: #343a40;
    --vad-gray-900: #212529;

    --vad-success: #28a745;
    --vad-error: #dc3545;
    --vad-warning: #ffc107;
    --vad-info: #17a2b8;

    --vad-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.05);
    --vad-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    --vad-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.15);

    --vad-transition: all 0.3s ease;
}

/* ==========================================================================
   Layout Structure
   ========================================================================== */

body.login {
    background: linear-gradient(135deg, var(--vad-gray-100) 0%, var(--vad-gray-200) 100%);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.vad-login-container {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    padding: 20px;
}


/* ==========================================================================
   WordPress Form Overrides
   ========================================================================== */

#login {
    width: 100%;
    padding: 20px;
    margin: 0;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.1));
}

#loginform {
    margin: 0;
    padding: 40px;
    background: white;
    border: 0;
    overflow: hidden;
    position: relative;
}


/* Logo/Header */
.login h1 a {
    background-image: none !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 0 30px 0;
    color: var(--vad-primary);
    font-size: 28px;
    font-weight: 600;
    text-decoration: none;
    text-indent: 0;
    display: block;
    text-align: center;
}
.login-heading {
    display:none;
}

/* ==========================================================================
   Magic Login & Password Toggle System
   ========================================================================== */

/* Magic Login Form (Primary) */
.magic-login-form {
    display: none;
    animation: fadeIn 0.3s ease;
}

.magic-login-form.active {
    display: block;
}

.login-method-intro {
    text-align: center;
    margin-bottom: 20px;
}

.login-method-intro p {
    color: var(--vad-gray-600);
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
}

/* Email Field Styling */
.magic-email-field {
    position: relative;
    margin-bottom: 15px;
}

.magic-email-field label {
    display: block;
    color: var(--vad-gray-700);
    font-weight: 500;
    margin-bottom: 8px;
    font-size: 14px;
}

.magic-email-field input {
    width: 100%;
    padding: 12px 15px;
    border: 1px solid var(--vad-gray-300);
    border-radius: var(--vad-radius);
    font-size: 14px;
    transition: var(--vad-transition);
    background: white;
    color: var(--vad-gray-900);
    box-sizing: border-box;
}

.magic-email-field input:focus {
    outline: none;
    border-color: var(--vad-primary);
    box-shadow: 0 0 0 3px rgba(42, 75, 109, 0.1);
}

.magic-email-field .field-icon {
    display: none;
}

/* Button Styling */
.magic-submit {
    margin-bottom: 10px;
}

.button-hero {
    width: 100%;
    padding: 14px 20px;
    background: var(--vad-accent) !important;
    color: white !important;
    border: none !important;
    border-radius: calc(var(--vad-radius) * 3) !important;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--vad-transition);
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: var(--vad-shadow-sm);
    float: none !important;
}

.button-hero:hover:not(:disabled) {
    background: var(--vad-primary);
    transform: translateY(-2px);
    box-shadow: var(--vad-shadow);
}

.button-hero:active:not(:disabled) {
    transform: translateY(0);
}

.button-hero:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.button-hero .button-icon {
    display: none;
}

/* Method Switch Links */
.login-method-switch {
    text-align: center;
    margin-top: 15px;
}

.method-switch-link {
    color: var(--vad-primary);
    text-decoration: none;
    font-size: 14px;
    transition: var(--vad-transition);
    display: inline-block;
    padding: 5px 10px;
}

.method-switch-link:hover {
    opacity: 0.7;
    text-decoration: underline;
}

/* Password Login Form (Fallback) */
.password-login-form {
    display: none;
}

.password-login-form.active {
    display: block;
}

.top-switch {
    margin-bottom: 20px;
    margin-top: 0;
}

/* ==========================================================================
   WordPress Fields Visibility Control
   ========================================================================== */

/* Hide WordPress fields by default */
#loginform:not(.show-password-fields) > p:first-child,
#loginform:not(.show-password-fields) #user_login,
#loginform:not(.show-password-fields) #user_pass,
#loginform:not(.show-password-fields) .user-pass-wrap,
#loginform:not(.show-password-fields) label[for="user_login"],
#loginform:not(.show-password-fields) label[for="user_pass"],
#loginform:not(.show-password-fields) .forgetmenot,
#loginform:not(.show-password-fields) .lostmenot,
#loginform:not(.show-password-fields) .submit {
    display: none !important;
}

/* Show WordPress fields when in password mode */
#loginform.show-password-fields #user_login,
#loginform.show-password-fields #user_pass {
    width: 100%;
    padding: 12px 15px;
    border: 2px solid var(--vad-gray-300);
    border-radius: var(--vad-radius);
    font-size: 16px;
    margin-bottom: 15px;
    transition: var(--vad-transition);
}

#loginform.show-password-fields #user_login:focus,
#loginform.show-password-fields #user_pass:focus {
    outline: none;
    border-color: var(--vad-primary);
    box-shadow: 0 0 0 3px rgba(42, 75, 109, 0.1);
}

#loginform.show-password-fields label {
    display: block;
    color: var(--vad-gray-700);
    font-weight: 500;
    margin-bottom: 8px;
    font-size: 14px;
}

#loginform.show-password-fields .submit #wp-submit {
    width: 100%;
    padding: 14px 20px;
    background: var(--vad-accent);
    color: white;
    border: none;
    border-radius: calc(var(--vad-radius) * 3);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--vad-transition);
    height: auto;
    margin-top: 10px;
}

#loginform.show-password-fields .submit #wp-submit:hover {
    background: var(--vad-primary);
    transform: translateY(-2px);
    box-shadow: var(--vad-shadow);
}

/* ==========================================================================
   Success Panel
   ========================================================================== */

.magic-success-panel {
    padding: 40px 30px;
    text-align: center;
    animation: slideIn 0.4s ease;
}

.magic-success-panel .success-icon {
    font-size: 64px;
    margin-bottom: 20px;
}

.magic-success-panel h3 {
    color: var(--vad-success);
    font-size: 24px;
    margin: 0 0 15px 0;
}

.magic-success-panel .success-message {
    color: var(--vad-gray-600);
    margin-bottom: 10px;
}

.magic-success-panel .email-display {
    background: var(--vad-gray-100);
    padding: 10px 20px;
    border-radius: var(--vad-radius);
    margin: 15px 0;
    word-break: break-all;
}

.magic-success-panel .email-display strong {
    color: var(--vad-primary);
    font-size: 16px;
}

.magic-success-panel .success-instruction {
    color: var(--vad-gray-600);
    font-size: 14px;
    margin: 20px 0;
}

.success-actions {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid var(--vad-gray-200);
}

.success-actions .button-secondary {
    background: white;
    color: var(--vad-primary);
    border: 2px solid var(--vad-primary);
    padding:0;
    border-radius: calc(var(--vad-radius) * 2);
    font-weight: 500;
    cursor: pointer;
    transition: var(--vad-transition);
    font-size: 14px;
}

.success-actions .button-secondary:hover {
    background: var(--vad-primary);
    color: white;
}

.success-actions .text-link {
    display: inline-block;
    margin-top: 15px;
    color: var(--vad-gray-600);
    font-size: 13px;
    text-decoration: none;
}

.success-actions .text-link:hover {
    text-decoration: underline;
}

/* ==========================================================================
   Error Messages
   ========================================================================== */

.magic-error-container {
    margin-bottom: 20px;
}

.magic-error-message {
    background: #fee;
    border-left: 4px solid var(--vad-error);
    padding: 12px 15px;
    margin-bottom: 15px;
    border-radius: var(--vad-radius);
    color: var(--vad-error);
    font-size: 14px;
    animation: shake 0.3s ease;
}

@keyframes shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    75% { transform: translateX(5px); }
}

/* ==========================================================================
   Footer
   ========================================================================== */

.vad-login-footer {
    padding: 30px;
    text-align: center;
}

.registration-section {
    margin-bottom: 20px;
}

.registration-section h3 {
    color: var(--vad-gray-700);
    font-size: 16px;
    margin: 20px 0 15px;
    font-weight: 500;
}

.divider {
    border: none;
    border-top: 1px solid var(--vad-gray-300);
    margin: 0 auto 20px;
    width: 60px;
}

.button-outline {
    display: inline-block;
    background: white;
    color: var(--vad-primary);
    border: 2px solid var(--vad-primary);
    padding: 10px 30px;
    border-radius: calc(var(--vad-radius) * 3);
    text-decoration: none;
    font-weight: 500;
    transition: var(--vad-transition);
}

.button-outline:hover {
    background: var(--vad-primary);
    color: white;
}

.legal-links {
    margin-top: 20px;
    font-size: 13px;
}

.legal-links a {
    color: var(--vad-gray-600);
    text-decoration: none;
    margin: 0 10px;
}

.legal-links a:hover {
    text-decoration: underline;
}

.legal-links .separator {
    color: var(--vad-gray-400);
}

/* ==========================================================================
   Animations
   ========================================================================== */

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

@media (max-width: 480px) {
    .vad-login-container {
        padding: 10px;
    }

    #loginform {
        padding: 30px 20px;
    }

    .vad-login-footer {
        padding: 20px;
    }

    .login h1 a {
        font-size: 24px;
    }
}

/* ==========================================================================
   Accessibility
   ========================================================================== */

/* Focus styles */
*:focus-visible {
    outline: 2px solid var(--vad-primary);
    outline-offset: 2px;
}

/* High contrast mode */
@media (prefers-contrast: high) {
    .button-hero,
    .button-outline,
    .button-secondary {
        border: 2px solid currentColor;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Hide WordPress defaults */
#nav,
#backtoblog,
.privacy-policy-page-link,
.language-switcher {
    display: none !important;
}