/* WordPress Login Dark Theme - Based on NTM Dashboard */

body.login {
    background: linear-gradient(135deg, #0d1117 0%, #161b22 50%, #21262d 100%) !important;
    color: #e6edf3 !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Noto Sans', Helvetica, Arial, sans-serif !important;
    min-height: 100vh;
    position: relative;
    overflow: hidden;
}

/* Animated background particles */
body.login::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: 
        radial-gradient(circle at 20% 50%, rgba(88, 166, 255, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(88, 166, 255, 0.05) 0%, transparent 50%),
        radial-gradient(circle at 40% 80%, rgba(88, 166, 255, 0.08) 0%, transparent 50%);
    animation: float 20s ease-in-out infinite;
    z-index: -1;
}

@keyframes float {
    0%, 100% { transform: translateY(0px) rotate(0deg); }
    33% { transform: translateY(-20px) rotate(1deg); }
    66% { transform: translateY(10px) rotate(-1deg); }
}

#login {
    width: 400px !important;
    padding: 40px 0 !important;
    margin: 0 auto;
    position: relative;
    z-index: 10;
}

#loginform, #registerform, #lostpasswordform, #resetpassform {
    background: linear-gradient(135deg, #161b22 0%, #21262d 100%) !important;
    border: 1px solid #30363d !important;
    border-radius: 16px !important;
    box-shadow: 
        0 20px 60px rgba(0, 0, 0, 0.4), 
        0 8px 32px rgba(88, 166, 255, 0.1) !important;
    padding: 40px !important;
    position: relative;
    overflow: hidden;
    backdrop-filter: blur(10px);
}

#loginform::before, #registerform::before, #lostpasswordform::before, #resetpassform::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #58a6ff 0%, #1f6feb 100%);
    border-radius: 16px 16px 0 0;
}

.login h1 {
    text-align: center !important;
    margin-bottom: 30px !important;
}

.login h1 a {
    background-image: none !important;
    background: linear-gradient(135deg, #58a6ff 0%, #1f6feb 100%) !important;
    color: #ffffff !important;
    width: 80px !important;
    height: 80px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 2em !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    margin: 0 auto !important;
    transition: all 0.3s cubic-bezier(0.3, 0, 0.5, 1) !important;
    box-shadow: 0 8px 25px rgba(88, 166, 255, 0.3) !important;
}

.login h1 a::before {
    content: '🔐';
    font-size: 1.2em;
}

.login h1 a:hover {
    transform: translateY(-2px) scale(1.05) !important;
    box-shadow: 0 12px 35px rgba(88, 166, 255, 0.4) !important;
}

.login form .input, .login input[type="text"], .login input[type="password"], .login input[type="email"] {
    background: #0d1117 !important;
    border: 1px solid #30363d !important;
    border-radius: 8px !important;
    color: #e6edf3 !important;
    font-size: 16px !important;
    padding: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: all 0.2s ease !important;
    margin-bottom: 16px !important;
    font-family: inherit !important;
}

.login form .input:focus, .login input[type="text"]:focus, .login input[type="password"]:focus, .login input[type="email"]:focus {
    outline: none !important;
    border-color: #58a6ff !important;
    box-shadow: 0 0 0 2px rgba(88, 166, 255, 0.2), 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    background: #161b22 !important;
    transform: translateY(-1px) !important;
}

.login form .input:hover, .login input[type="text"]:hover, .login input[type="password"]:hover, .login input[type="email"]:hover {
    border-color: #58a6ff !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
}

.login form .input::placeholder {
    color: #7d8590 !important;
    font-style: italic !important;
}

.wp-core-ui .button-primary {
    background: linear-gradient(135deg, #58a6ff 0%, #1f6feb 100%) !important;
    border: none !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    padding: 16px 32px !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.3, 0, 0.5, 1) !important;
    text-shadow: none !important;
    box-shadow: 0 4px 12px rgba(88, 166, 255, 0.3) !important;
    position: relative !important;
    overflow: hidden !important;
}

.wp-core-ui .button-primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.wp-core-ui .button-primary:hover::before {
    left: 100%;
}

.wp-core-ui .button-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(88, 166, 255, 0.4) !important;
    background: linear-gradient(135deg, #1f6feb 0%, #58a6ff 100%) !important;
}

.wp-core-ui .button-primary:active {
    transform: translateY(0) !important;
}

/* Custom Register Button Styles */
.register-separator {
    text-align: center;
    margin: 30px 0 20px 0;
    position: relative;
}

.register-separator::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, #30363d, transparent);
}

.register-separator span {
    background: linear-gradient(135deg, #0d1117 0%, #161b22 50%, #21262d 100%);
    color: #7d8590;
    padding: 0 20px;
    font-size: 14px;
    font-weight: 500;
    position: relative;
    z-index: 1;
}

.custom-register-container {
    text-align: center;
    margin-bottom: 30px;
}

.custom-register-btn {
    display: inline-block !important;
    background: linear-gradient(135deg, #238636 0%, #2ea043 100%) !important;
    border: none !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    padding: 16px 32px !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.3, 0, 0.5, 1) !important;
    text-shadow: none !important;
    box-shadow: 0 4px 12px rgba(46, 160, 67, 0.3) !important;
    position: relative !important;
    overflow: hidden !important;
    min-width: 200px;
}

.custom-register-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.custom-register-btn:hover::before {
    left: 100%;
}

.custom-register-btn:hover {
    color: #ffffff !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(46, 160, 67, 0.4) !important;
    background: linear-gradient(135deg, #2ea043 0%, #238636 100%) !important;
    text-decoration: none !important;
}

.custom-register-btn:active {
    transform: translateY(0) !important;
}

.register-icon {
    margin-right: 8px;
    font-size: 1.1em;
}

.login #nav {
    text-align: center !important;
    margin-top: 24px !important;
}

.login #nav a {
    color: #58a6ff !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: all 0.2s ease !important;
    padding: 8px 16px !important;
    border-radius: 6px !important;
    display: inline-block !important;
    margin: 0 8px !important;
}

.login #nav a:hover {
    color: #ffffff !important;
    background: rgba(88, 166, 255, 0.2) !important;
    transform: translateY(-1px) !important;
}

.login #backtoblog {
    text-align: center !important;
    margin-top: 16px !important;
}

.login #backtoblog a {
    color: #7d8590 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    transition: all 0.2s ease !important;
}

.login #backtoblog a:hover {
    color: #58a6ff !important;
}

.login .message, .login .success {
    background: linear-gradient(135deg, #2ea043 0%, #238636 100%) !important;
    border: 1px solid #3fb950 !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    padding: 16px !important;
    margin: 16px 0 !important;
    box-shadow: 0 4px 12px rgba(46, 160, 67, 0.3) !important;
}

.login .message a, .login .success a {
    color: #ffffff !important;
    text-decoration: underline !important;
}

.login #login_error {
    background: linear-gradient(135deg, #f85149 0%, #da3633 100%) !important;
    border: 1px solid #f85149 !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    padding: 16px !important;
    margin: 16px 0 !important;
    box-shadow: 0 4px 12px rgba(248, 81, 73, 0.3) !important;
}

.login #login_error a {
    color: #ffffff !important;
    text-decoration: underline !important;
}

.login .forgetmenot {
    margin: 20px 0 !important;
}

.login .forgetmenot input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: #58a6ff !important;
    margin-right: 8px !important;
    border-radius: 4px !important;
}

.login .forgetmenot label {
    color: #e6edf3 !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* Password strength indicator */
.login .pw-weak {
    color: #f85149 !important;
}

.login .pw-good {
    color: #f0883e !important;
}

.login .pw-strong {
    color: #2ea043 !important;
}

/* Password reset form specific styles */
#resetpassform p {
    color: #e6edf3 !important;
    margin-bottom: 16px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

#resetpassform .description {
    color: #7d8590 !important;
    font-style: italic !important;
    margin-bottom: 20px !important;
}

/* Lost password form styles */
#lostpasswordform p {
    color: #e6edf3 !important;
    margin-bottom: 16px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

#lostpasswordform .description {
    color: #7d8590 !important;
    font-style: italic !important;
    margin-bottom: 20px !important;
}

/* Form labels */
.login label {
    color: #e6edf3 !important;
    font-weight: 500 !important;
    margin-bottom: 8px !important;
    display: block !important;
}

/* User login field label */
.login .user-pass-wrap label {
    color: #e6edf3 !important;
}

/* Password visibility toggle */
.login .wp-pwd {
    position: relative !important;
}

.login .wp-pwd .button.wp-hide-pw {
    background: #30363d !important;
    border: 1px solid #30363d !important;
    color: #e6edf3 !important;
    padding: 8px 12px !important;
    border-radius: 6px !important;
    position: absolute !important;
    right: 8px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 14px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.login .wp-pwd .button.wp-hide-pw:hover {
    background: #58a6ff !important;
    border-color: #58a6ff !important;
    color: #ffffff !important;
}

/* Password confirmation field */
.login .user-pass1-wrap {
    margin-bottom: 16px !important;
}

.login .user-pass2-wrap {
    margin-bottom: 20px !important;
}

/* Loading animation */
.login .spinner {
    background: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="45" fill="none" stroke="%2358a6ff" stroke-width="8" stroke-dasharray="70 30" stroke-linecap="round"><animateTransform attributeName="transform" type="rotate" values="0 50 50;360 50 50" dur="1s" repeatCount="indefinite"/></circle></svg>') no-repeat !important;
    background-size: 20px 20px !important;
    width: 20px !important;
    height: 20px !important;
}

/* Success messages styling */
.login .message {
    background: linear-gradient(135deg, #2ea043 0%, #238636 100%) !important;
    border: 1px solid #3fb950 !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    padding: 16px !important;
    margin: 16px 0 !important;
    box-shadow: 0 4px 12px rgba(46, 160, 67, 0.3) !important;
    font-weight: 500 !important;
}

.login .message a {
    color: #ffffff !important;
    text-decoration: underline !important;
    font-weight: 600 !important;
}

.login .message a:hover {
    color: #ffffff !important;
    text-decoration: none !important;
}

/* Email sent confirmation message */
.login .message.reset-email-sent {
    background: linear-gradient(135deg, #58a6ff 0%, #1f6feb 100%) !important;
    border: 1px solid #58a6ff !important;
    box-shadow: 0 4px 12px rgba(88, 166, 255, 0.3) !important;
}

/* Responsive design */
@media (max-width: 480px) {
    #login {
        width: 90% !important;
        padding: 20px 0 !important;
    }
    
    #loginform, #registerform, #lostpasswordform, #resetpassform {
        padding: 30px 20px !important;
    }
    
    .login h1 a {
        width: 60px !important;
        height: 60px !important;
        font-size: 1.5em !important;
    }
    
    .custom-register-btn {
        min-width: auto !important;
        width: 100% !important;
        padding: 14px 24px !important;
        font-size: 15px !important;
    }
    
    .login form .input, .login input[type="text"], .login input[type="password"], .login input[type="email"] {
        font-size: 16px !important; /* Prevent zoom on iOS */
        padding: 14px !important;
    }
}

/* Smooth transitions for all elements */
* {
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
}

/* Custom scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: #161b22;
}

::-webkit-scrollbar-thumb {
    background: #30363d;
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: #58a6ff;
}

/* Selection styling */
::selection {
    background: rgba(88, 166, 255, 0.3);
    color: #ffffff;
}

/* Fix for WordPress core styles that might interfere */
.login form {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

/* Ensure form containers have proper styling */
.login div.message {
    margin: 16px 0 20px 0 !important;
}

/* Additional password reset form fixes */
.login .wp-pwd input[type="password"] {
    padding-right: 50px !important; /* Make room for show/hide button */
}

/* Form validation messages */
.login .validation-message {
    background: linear-gradient(135deg, #f0883e 0%, #e85d04 100%) !important;
    border: 1px solid #f0883e !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    padding: 12px 16px !important;
    margin: 12px 0 !important;
    font-size: 14px !important;
    box-shadow: 0 4px 12px rgba(240, 136, 62, 0.3) !important;
}

/* WordPress admin notice fixes for login page */
.login .notice {
    background: linear-gradient(135deg, #58a6ff 0%, #1f6feb 100%) !important;
    border: 1px solid #58a6ff !important;
    border-radius: 8px !important;
    color: #ffffff !important;
    padding: 16px !important;
    margin: 16px 0 !important;
    box-shadow: 0 4px 12px rgba(88, 166, 255, 0.3) !important;
}

.login .notice a {
    color: #ffffff !important;
    text-decoration: underline !important;
}

/* Privacy text styling */
.login .privacy-policy-page-link {
    text-align: center !important;
    margin-top: 20px !important;
}

.login .privacy-policy-page-link a {
    color: #7d8590 !important;
    font-size: 12px !important;
    text-decoration: none !important;
}

.login .privacy-policy-page-link a:hover {
    color: #58a6ff !important;
    text-decoration: underline !important;
}