/**
 * MedScience Login Page Styles v2.1
 * Premium design matching landing and pricing pages
 */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:wght@600;700&display=swap');

/* CSS Variables */
:root {
    --primary: #192D6B;
    --primary-light: #2a4494;
    --primary-dark: #111f4a;
    --accent: #FF0066;
    --accent-light: #ff3385;
    --accent-bg: #fff0f5;
    --accent-subtle: #ffe6ef;
    --text-dark: #2B2A29;
    --text-muted: #5a5958;
    --text-light: #8a8a8a;
    --white: #ffffff;
    --bg-subtle: #f8f9fc;
    --bg-card: #ffffff;
    --border: #e2e2ea;
    --border-light: #f0f0f5;
    --shadow-sm: 0 2px 8px rgba(25, 45, 107, 0.06);
    --shadow-md: 0 8px 32px rgba(25, 45, 107, 0.1);
    --shadow-lg: 0 20px 60px rgba(25, 45, 107, 0.15);
    --shadow-glow: 0 0 40px rgba(25, 45, 107, 0.12);
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 20px;
    --radius-xl: 28px;
}

/* ========================================
   BASE & RESET
   ======================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    height: 100%;
}

body.login {
    font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    background: linear-gradient(145deg, #f5f7fa 0%, #e8ecf4 40%, #fdf2f6 100%) !important;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px !important;
    margin: 0 !important;
    position: relative;
    overflow-x: hidden;
}

/* Animated Background */
body.login::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: 
        radial-gradient(ellipse 80% 50% at 20% 40%, rgba(25, 45, 107, 0.08) 0%, transparent 50%),
        radial-gradient(ellipse 60% 40% at 80% 60%, rgba(255, 0, 102, 0.06) 0%, transparent 50%),
        radial-gradient(ellipse 40% 30% at 50% 90%, rgba(25, 45, 107, 0.04) 0%, transparent 50%);
    pointer-events: none;
    z-index: 0;
    animation: bgPulse 15s ease-in-out infinite alternate;
}

@keyframes bgPulse {
    0% { opacity: 1; }
    100% { opacity: 0.7; }
}

/* ========================================
   MAIN CONTAINER
   ======================================== */
#login {
    width: 100% !important;
    max-width: 440px !important;
    padding: 0 !important;
    margin: 0 auto !important;
    position: relative;
    z-index: 1;
}

/* ========================================
   TRIAL BADGE
   ======================================== */
#login::before {
    content: '🎉 90 zile GRATUIT – plan Standard pentru utilizatori noi!';
    display: block;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);
    color: var(--white);
    text-align: center;
    padding: 14px 24px;
    border-radius: 100px;
    font-family: 'Outfit', sans-serif;
    font-size: 0.9375rem;
    font-weight: 600;
    margin-bottom: 28px;
    box-shadow: 0 8px 24px rgba(25, 45, 107, 0.25);
    animation: badgePulse 2s ease-in-out infinite;
}

@keyframes badgePulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.02); }
}

/* ========================================
   LOGO
   ======================================== */
#login h1 {
    margin-bottom: 0 !important;
    text-align: center;
}

#login h1 a {
    background-image: url('https://library.medscience.center/wp-content/themes/Avada/assets2/sigla-medscience2.svg') !important;
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    width: 200px !important;
    height: 55px !important;
    margin: 0 auto 20px !important;
    display: block !important;
    text-indent: -9999px !important;
    transition: transform 0.3s ease;
}

#login h1 a:hover {
    transform: scale(1.05);
}

/* ========================================
   SUBTITLE
   ======================================== */
#login h2 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.375rem !important;
    font-weight: 700 !important;
    color: var(--text-dark) !important;
    text-align: center !important;
    margin-bottom: 28px !important;
    line-height: 1.35 !important;
    letter-spacing: -0.02em;
}

/* ========================================
   LOGIN FORM CARD
   ======================================== */
#loginform,
#lostpasswordform,
#registerform,
#resetpassform {
    background: var(--white) !important;
    border: 1px solid var(--border-light) !important;
    border-radius: var(--radius-xl) !important;
    padding: 36px 32px !important;
    box-shadow: var(--shadow-lg), var(--shadow-glow) !important;
    margin: 0 !important;
    position: relative;
    overflow: hidden !important;
}

/* Decorative top accent - clipped by container's overflow:hidden */
#loginform::before,
#lostpasswordform::before,
#registerform::before,
#resetpassform::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--primary), var(--accent), var(--primary));
    background-size: 200% 100%;
    animation: gradientSlide 3s ease infinite;
}

@keyframes gradientSlide {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}

/* ========================================
   FORM ELEMENTS
   ======================================== */

/* Labels */
#login form label {
    font-family: 'Outfit', sans-serif !important;
    font-size: 0.8125rem !important;
    font-weight: 600 !important;
    color: var(--text-dark) !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px !important;
    display: block !important;
}

/* Input Fields */
#login form p {
    margin-bottom: 20px !important;
    position: relative;
}

#login form .input,
#login form input[type="text"],
#login form input[type="password"],
#login form input[type="email"] {
    font-family: 'Outfit', sans-serif !important;
    width: 100% !important;
    padding: 15px 18px !important;
    border: 2px solid var(--border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 1rem !important;
    color: var(--text-dark) !important;
    background: var(--bg-subtle) !important;
    transition: all 0.25s ease !important;
    margin-top: 8px !important;
    margin-bottom: 0 !important;
    box-shadow: none !important;
}

#login form .input:hover,
#login form input[type="text"]:hover,
#login form input[type="password"]:hover,
#login form input[type="email"]:hover {
    border-color: var(--primary-light) !important;
    background: var(--white) !important;
}

#login form .input:focus,
#login form input[type="text"]:focus,
#login form input[type="password"]:focus,
#login form input[type="email"]:focus {
    border-color: var(--primary) !important;
    background: var(--white) !important;
    outline: none !important;
    box-shadow: 0 0 0 4px rgba(25, 45, 107, 0.08) !important;
}

/* ========================================
   PASSWORD FIELD - FIXED TOGGLE BUTTON
   ======================================== */
.user-pass-wrap {
    margin-bottom: 20px !important;
    position: relative !important;
}

.wp-pwd {
    position: relative !important;
    display: block !important;
}

.wp-pwd .input,
.wp-pwd input[type="password"],
.wp-pwd input[type="text"] {
    padding-right: 55px !important;
}

/* Show/Hide Password Button - FIXED */
.wp-hide-pw {
    position: absolute !important;
    right: 12px !important;
    top: auto !important;
    bottom: 12px !important;
    transform: none !important;
    background: transparent !important;
    border: none !important;
    color: var(--text-muted) !important;
    cursor: pointer !important;
    padding: 8px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    transition: all 0.2s ease !important;
    z-index: 10 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
}

.wp-hide-pw:hover {
    color: var(--primary) !important;
    background: rgba(25, 45, 107, 0.08) !important;
}

.wp-hide-pw:focus {
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(25, 45, 107, 0.2) !important;
}

.wp-hide-pw .dashicons {
    font-size: 20px !important;
    width: 20px !important;
    height: 20px !important;
    line-height: 20px !important;
}

/* ========================================
   REMEMBER ME
   ======================================== */
.forgetmenot {
    margin: 0 0 24px 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
}

.forgetmenot input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    border: 2px solid var(--border) !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    accent-color: var(--primary) !important;
    margin: 0 !important;
}

.forgetmenot label {
    font-size: 0.9rem !important;
    color: var(--text-muted) !important;
    font-weight: 500 !important;
    display: inline !important;
    margin: 0 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    cursor: pointer;
}

/* ========================================
   SUBMIT BUTTON
   ======================================== */
#login form .submit {
    margin: 0 !important;
    padding: 0 !important;
}

#login form .button-primary,
#login form input[type="submit"] {
    font-family: 'Outfit', sans-serif !important;
    width: 100% !important;
    padding: 16px 28px !important;
    background: linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%) !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    color: var(--white) !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    text-shadow: none !important;
    box-shadow: 0 6px 20px rgba(25, 45, 107, 0.3) !important;
    position: relative;
    overflow: hidden;
}

#login form .button-primary::before,
#login form input[type="submit"]::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 ease;
}

#login form .button-primary:hover::before,
#login form input[type="submit"]:hover::before {
    left: 100%;
}

#login form .button-primary:hover,
#login form input[type="submit"]:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 10px 30px rgba(25, 45, 107, 0.35) !important;
}

#login form .button-primary:active,
#login form input[type="submit"]:active {
    transform: translateY(-1px) !important;
}

/* ========================================
   MESSAGES & ERRORS
   ======================================== */
#login .message,
#login .success {
    font-family: 'Outfit', sans-serif !important;
    background: linear-gradient(135deg, #f0f7ff 0%, #e8f4fd 100%) !important;
    border: none !important;
    border-left: 4px solid var(--primary) !important;
    border-radius: var(--radius-md) !important;
    padding: 16px 20px !important;
    margin: 0 0 24px 0 !important;
    box-shadow: var(--shadow-sm) !important;
    color: var(--text-dark) !important;
    font-size: 0.9375rem !important;
    line-height: 1.5;
}

#login_error {
    font-family: 'Outfit', sans-serif !important;
    background: linear-gradient(135deg, #fff5f5 0%, #ffe8e8 100%) !important;
    border: none !important;
    border-left: 4px solid #e53935 !important;
    border-radius: var(--radius-md) !important;
    padding: 16px 20px !important;
    margin: 0 0 24px 0 !important;
    box-shadow: var(--shadow-sm) !important;
    color: #c62828 !important;
    font-size: 0.9375rem !important;
}

#login_error a {
    color: #c62828 !important;
    font-weight: 600 !important;
}

/* ========================================
   NAVIGATION LINKS
   ======================================== */
#login #nav,
#login #backtoblog {
    font-family: 'Outfit', sans-serif !important;
    text-align: center !important;
    margin: 20px 0 0 0 !important;
    padding: 0 !important;
}

#login #nav a,
#login #backtoblog a {
    color: var(--primary) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    font-size: 0.9rem !important;
    transition: all 0.3s ease !important;
    padding: 4px 8px;
    border-radius: 6px;
}

#login #nav a:hover,
#login #backtoblog a:hover {
    color: var(--accent) !important;
    background: rgba(255, 0, 102, 0.05);
}

/* ========================================
   REGISTER MESSAGE
   ======================================== */
#login > p.message {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    text-align: center !important;
    margin-top: 24px !important;
    padding: 0 !important;
    font-size: 0.95rem;
    color: var(--text-muted);
}

.inregistreaza {
    color: var(--accent) !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    padding: 4px 12px;
    background: var(--accent-subtle);
    border-radius: 100px;
    transition: all 0.3s ease !important;
    display: inline-block;
}

.inregistreaza:hover {
    color: var(--white) !important;
    background: var(--accent);
    transform: scale(1.05);
}

/* ========================================
   REGISTRATION MODAL - ULTRA COMPACT
   ======================================== */

/* Overlay */
.freg-mask {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(17, 31, 74, 0.8) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    z-index: 9998 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.freg-mask.active {
    opacity: 1 !important;
    visibility: visible !important;
}

/* Modal Container - Two Column Wide */
.form-register {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) scale(0.9) !important;
    background: #ffffff !important;
    background-color: #ffffff !important;
    border-radius: 20px !important;
    padding: 0 !important;
    width: 94% !important;
    max-width: 580px !important;
    max-height: 90vh !important;
    z-index: 9999 !important;
    box-shadow: 
        0 25px 80px rgba(25, 45, 107, 0.35),
        0 0 0 1px rgba(255,255,255,0.1) inset !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
}

.form-register.active {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate(-50%, -50%) scale(1) !important;
}

/* FORCE WHITE BACKGROUND - Override ALL theme styles */
.form-register,
.form-register > *,
.form-register .wpcf7,
.form-register .wpcf7-form,
.form-register form,
.form-register > h3,
div.form-register,
div.form-register.active {
    background-color: #ffffff !important;
    background-image: none !important;
    background: #ffffff !important;
}

/* Make form elements transparent so white shows through */
.form-register .wpcf7-form p,
.form-register .wpcf7-form label,
.form-register .wpcf7-form-control-wrap,
.form-register .wpcf7-form > div {
    background: transparent !important;
    background-color: transparent !important;
}

/* Modal Header - Gradient Bar */
.form-register::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, var(--primary), var(--accent), var(--primary-light));
    background-size: 200% 100%;
    animation: gradientSlide 3s ease infinite;
    flex-shrink: 0;
}

/* Close Button */
.freg-x {
    position: absolute !important;
    top: 12px !important;
    right: 12px !important;
    width: 30px !important;
    height: 30px !important;
    background: var(--bg-subtle) !important;
    border: none !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    z-index: 10;
    font-size: 0 !important;
}

.freg-x::before {
    content: '✕' !important;
    font-size: 13px !important;
    font-weight: 700;
    color: var(--text-muted) !important;
    line-height: 1 !important;
}

.freg-x:hover {
    background: var(--accent) !important;
    transform: rotate(90deg) scale(1.1);
}

.freg-x:hover::before {
    color: var(--white) !important;
}

/* Modal Title - Compact */
.form-register > h3 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.35rem !important;
    font-weight: 700 !important;
    color: var(--text-dark) !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 18px 20px 12px !important;
    flex-shrink: 0;
    background: #ffffff !important;
    background-color: #ffffff !important;
}

.form-register > h3::after {
    content: '🎉 90 zile gratuit';
    display: inline-block;
    font-family: 'Outfit', sans-serif;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--white);
    margin-left: 10px;
    background: linear-gradient(135deg, var(--accent), var(--accent-light));
    padding: 4px 10px;
    border-radius: 100px;
    vertical-align: middle;
}

/* Modal Content Area - Scrollable */
.form-register .wpcf7 {
    margin: 0 !important;
    padding: 0 20px 16px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    flex: 1;
    max-height: calc(90vh - 70px);
    background: #ffffff !important;
    background-color: #ffffff !important;
}


/* Nice scrollbar */
.form-register .wpcf7::-webkit-scrollbar {
    width: 5px;
}

.form-register .wpcf7::-webkit-scrollbar-track {
    background: transparent;
}

.form-register .wpcf7::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 10px;
}

.form-register .wpcf7::-webkit-scrollbar-thumb:hover {
    background: var(--primary-light);
}

/* Screen reader - hide */
.form-register .screen-reader-response {
    display: none !important;
}

/* Form - Two Column Grid */
.form-register .wpcf7-form {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px 14px !important;
    align-items: start !important;
}

/* Individual form paragraphs */
.form-register .wpcf7-form > p {
    margin: 0 !important;
    padding: 0 !important;
}

/* Make message textarea span full width */
.form-register .wpcf7-form > p:nth-last-child(3) {
    grid-column: 1 / -1 !important;
}

/* Make submit button span full width */
.form-register .wpcf7-form > p:nth-last-child(2) {
    grid-column: 1 / -1 !important;
}

/* Response output full width */
.form-register .wpcf7-form > div:last-child,
.form-register .wpcf7-response-output {
    grid-column: 1 / -1 !important;
}

/* Form Labels - Ultra Compact */
.form-register .wpcf7-form label {
    font-family: 'Outfit', sans-serif !important;
    font-size: 0.6875rem !important;
    font-weight: 600 !important;
    color: var(--text-dark) !important;
    display: block !important;
    margin-bottom: 3px !important;
    text-transform: uppercase;
    letter-spacing: 0.4px;
    line-height: 1.3 !important;
}

/* Remove br after label text */
.form-register .wpcf7-form label br {
    display: none !important;
}

/* Form control wrapper */
.form-register .wpcf7-form-control-wrap {
    display: block !important;
    margin-top: 2px !important;
}

/* Form Inputs - Ultra Compact */
.form-register .wpcf7-form input.wpcf7-form-control,
.form-register .wpcf7-form input[type="text"],
.form-register .wpcf7-form input[type="email"],
.form-register .wpcf7-form input[type="tel"],
.form-register .wpcf7-form textarea.wpcf7-form-control,
.form-register .wpcf7-form select {
    font-family: 'Outfit', sans-serif !important;
    width: 100% !important;
    padding: 9px 11px !important;
    border: 1.5px solid var(--border) !important;
    border-radius: 8px !important;
    font-size: 0.8125rem !important;
    color: var(--text-dark) !important;
    background: var(--white) !important;
    transition: all 0.2s ease !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

.form-register .wpcf7-form input:hover,
.form-register .wpcf7-form textarea:hover {
    border-color: var(--primary-light) !important;
}

.form-register .wpcf7-form input:focus,
.form-register .wpcf7-form textarea:focus {
    border-color: var(--primary) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(25, 45, 107, 0.08) !important;
}

/* Input placeholder */
.form-register .wpcf7-form input::placeholder,
.form-register .wpcf7-form textarea::placeholder {
    color: var(--text-light);
    font-size: 0.75rem;
}

/* Textarea - Compact */
.form-register .wpcf7-form textarea.wpcf7-form-control {
    min-height: 50px !important;
    max-height: 70px !important;
    resize: none !important;
    padding: 8px 11px !important;
}

/* Submit Button - Compact */
.form-register .wpcf7-form input.wpcf7-submit,
.form-register .wpcf7-form input[type="submit"] {
    font-family: 'Outfit', sans-serif !important;
    width: 100% !important;
    padding: 12px 20px !important;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 100%) !important;
    border: none !important;
    border-radius: 10px !important;
    color: var(--white) !important;
    font-size: 0.9rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    margin-top: 6px !important;
    box-shadow: 0 4px 16px rgba(255, 0, 102, 0.3) !important;
}

.form-register .wpcf7-form input.wpcf7-submit:hover,
.form-register .wpcf7-form input[type="submit"]:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 24px rgba(255, 0, 102, 0.4) !important;
}

/* Validation messages - Compact */
.form-register .wpcf7-not-valid-tip {
    color: #e53935 !important;
    font-size: 0.65rem !important;
    margin-top: 2px !important;
    display: block !important;
}

/* HIDE everything after submit button */
.form-register .wpcf7-response-output,
.form-register .fusion-alert,
.form-register .wpcf7-form > div:last-child,
.form-register .wpcf7-form > .fusion-alert,
.form-register .alert,
.form-register .wpcf7-spinner,
.form-register .ajax-loader {
    display: none !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    visibility: hidden !important;
}

/* Remove any bottom padding/margin from form */
.form-register .wpcf7-form {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

/* Remove bottom padding from submit button paragraph */
.form-register .wpcf7-form > p:last-of-type {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Tight padding on wpcf7 container */
.form-register .wpcf7 {
    padding-bottom: 16px !important;
}

/* ========================================
   LOGIN FOOTER NOTES
   ======================================== */
.login-footer-notes {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 28px;
    padding: 0 10px;
}

.login-footer-notes .footnote {
    font-family: 'Outfit', sans-serif;
    font-size: 0.75rem;
    color: var(--text-muted);
    background: var(--bg-subtle);
    padding: 6px 14px;
    border-radius: 100px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.login-footer-notes .footnote::before {
    content: '✓';
    color: var(--primary);
    font-weight: 700;
    font-size: 0.7rem;
}

.login-footer-notes .footnote.trial-note {
    background: var(--accent-subtle);
    color: var(--accent);
    font-weight: 600;
}

.login-footer-notes .footnote.trial-note::before {
    content: '🎉';
    font-size: 0.8rem;
}

/* ========================================
   PRIVACY POLICY
   ======================================== */
.privacy-policy-page-link {
    text-align: center !important;
    margin-top: 20px !important;
}

.privacy-policy-page-link a {
    color: var(--text-light) !important;
    font-size: 0.8125rem !important;
    text-decoration: none !important;
    transition: color 0.3s ease;
}

.privacy-policy-page-link a:hover {
    color: var(--primary) !important;
}

/* ========================================
   PASSWORD STRENGTH & HINTS
   ======================================== */
#pass-strength-result {
    font-family: 'Outfit', sans-serif !important;
    background: var(--bg-subtle) !important;
    border: 2px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 14px !important;
    margin-top: 10px !important;
    font-size: 0.8125rem !important;
    font-weight: 500;
}

.description,
.indicator-hint {
    font-family: 'Outfit', sans-serif !important;
    font-size: 0.8125rem !important;
    color: var(--text-light) !important;
    margin-top: 10px !important;
    line-height: 1.5;
}

/* ========================================
   ADMIN EMAIL CONFIRMATION
   ======================================== */
.admin-email-confirm-form {
    background: var(--white) !important;
    border-radius: var(--radius-xl) !important;
    padding: 40px !important;
    box-shadow: var(--shadow-lg) !important;
}

.admin-email__heading {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.5rem !important;
    color: var(--text-dark) !important;
    margin-bottom: 20px !important;
}

.admin-email__details {
    font-family: 'Outfit', sans-serif !important;
    color: var(--text-muted) !important;
    margin-bottom: 16px !important;
    line-height: 1.6;
}

.admin-email__actions {
    margin-top: 28px !important;
}

.admin-email__actions .button {
    font-family: 'Outfit', sans-serif !important;
    padding: 14px 28px !important;
    border-radius: var(--radius-md) !important;
    font-weight: 600 !important;
}

/* ========================================
   SHAKE ANIMATION
   ======================================== */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    10%, 30%, 50%, 70%, 90% { transform: translateX(-8px); }
    20%, 40%, 60%, 80% { transform: translateX(8px); }
}

.shake {
    animation: shake 0.5s ease-in-out !important;
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */
@media (max-width: 600px) {
    body.login {
        padding: 24px 16px !important;
    }
    
    #login {
        max-width: 100% !important;
    }
    
    #login::before {
        font-size: 0.8125rem !important;
        padding: 12px 18px !important;
        margin-bottom: 20px;
    }
    
    #login h1 a {
        width: 160px !important;
        height: 45px !important;
    }
    
    #login h2 {
        font-size: 1.125rem !important;
        margin-bottom: 20px !important;
    }
    
    #loginform,
    #lostpasswordform,
    #registerform,
    #resetpassform {
        padding: 28px 24px !important;
        border-radius: var(--radius-lg) !important;
    }
    
    /* Mobile Modal - Single Column */
    .form-register {
        width: 96% !important;
        max-width: none !important;
        border-radius: 16px !important;
        max-height: 92vh !important;
    }
    
    .form-register > h3 {
        font-size: 1.15rem !important;
        padding: 14px 16px 10px !important;
    }
    
    .form-register > h3::after {
        display: block !important;
        margin-left: 0 !important;
        margin-top: 6px !important;
        font-size: 0.65rem;
    }
    
    .form-register .wpcf7 {
        padding: 0 14px 16px !important;
        max-height: calc(92vh - 80px) !important;
    }
    
    /* Single column on mobile */
    .form-register .wpcf7-form {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }
    
    .form-register .wpcf7-form label {
        font-size: 0.625rem !important;
    }
    
    .form-register .wpcf7-form input.wpcf7-form-control,
    .form-register .wpcf7-form input[type="text"],
    .form-register .wpcf7-form input[type="email"],
    .form-register .wpcf7-form textarea.wpcf7-form-control {
        padding: 8px 10px !important;
        font-size: 0.8rem !important;
    }
    
    .form-register .wpcf7-form input.wpcf7-submit {
        padding: 11px 18px !important;
        font-size: 0.85rem !important;
    }
    
    .freg-x {
        top: 8px !important;
        right: 8px !important;
        width: 26px !important;
        height: 26px !important;
    }
    
    .freg-x::before {
        font-size: 11px !important;
    }
    
    /* Footer notes mobile */
    .login-footer-notes {
        gap: 6px;
        margin-top: 20px;
    }
    
    .login-footer-notes .footnote {
        font-size: 0.65rem;
        padding: 5px 10px;
    }
}

/* ========================================
   LEGACY CLASS OVERRIDES
   ======================================== */
.col-md-8-waveit,
.form-row-waveit,
.form-group {
    width: 100% !important;
    margin: 0 !important;
    text-align: left !important;
}

#login form .submit {
    text-align: center !important;
    margin-top: 4px !important;
    float: none !important;
}

#login form #wp-submit {
    float: none !important;
    margin: 0 !important;
}

/* Hide CF7 default validation styles we don't want */
.wpcf7-form-control-wrap {
    display: block;
}

/* ========================================
   FORM GROUP/ROW LAYOUT FIXES
   ======================================== */
.user-pass-wrap .form-group,
.user-pass-wrap .form-row {
    position: relative;
}

/* Ensure password toggle works with nested divs */
.user-pass-wrap .wp-pwd {
    position: relative !important;
}

.form-row .form-group {
    margin-bottom: 0 !important;
}
