.elementor-1823 .elementor-element.elementor-element-65041ee1{--display:flex;--min-height:90vh;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;}.elementor-1823 .elementor-element.elementor-element-983d3c5{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;border-style:solid;--border-style:solid;border-width:2px 2px 2px 2px;--border-top-width:2px;--border-right-width:2px;--border-bottom-width:2px;--border-left-width:2px;--border-radius:23px 23px 23px 23px;box-shadow:5px 5px 0px 0px #000000;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1823 .elementor-element.elementor-element-983d3c5:not(.elementor-motion-effects-element-type-background), .elementor-1823 .elementor-element.elementor-element-983d3c5 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-e81ac6c );}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-1823 .elementor-element.elementor-element-128f8fa{background-color:var( --e-global-color-fab9060 );padding:6px 19px 6px 0px;border-style:solid;border-width:0px 0px 2px 0px;border-radius:22px 22px 0px 0px;text-align:right;}.elementor-1823 .elementor-element.elementor-element-128f8fa .elementor-heading-title{font-family:"Red Hat Text", Sans-serif;font-size:28px;font-weight:500;color:var( --e-global-color-primary );}.elementor-1823 .elementor-element.elementor-element-36e3d14{background-color:#99D1AE5E;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:5px 0px 02px 020px;z-index:100;border-style:solid;border-width:0px 0px 02px 0px;}.elementor-1823 .elementor-element.elementor-element-36e3d14 .elementor-heading-title{font-family:"Teko", Sans-serif;font-size:36px;font-weight:400;letter-spacing:0.2px;}.elementor-1823 .elementor-element.elementor-element-9d3ca54{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 30px;padding:0px 0px 0px 0px;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-1823 .elementor-element.elementor-element-65041ee1{--content-width:565px;}.elementor-1823 .elementor-element.elementor-element-983d3c5{--width:98%;}}/* Start custom CSS *//* ================================
   LOGIN PAGE - CUSTOM STYLING
   ================================ */

/* Remove Default PMPro Card Styling - LOCK HEIGHT */
.pmpro_card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 30px !important;
    min-height: 400px !important;
}

/* HIDE the PMPro "Log In" title (since you have one in Elementor) */
.pmpro_card_title {
    display: none !important;
}

/* Input Labels - BIGGER with LEFT PADDING */
.pmpro_login_wrap label {
    font-family: 'Nunito', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #333 !important;
    display: block !important;
    margin-bottom: 0px !important;
    padding-left: 5px !important;
}

/* Input Fields */
.pmpro_login_wrap input[type="text"],
.pmpro_login_wrap input[type="password"] {
    width: 100% !important;
    padding: 12px 15px !important;
    padding-right: 45px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 15px !important;
    background: white !important;
    border: 2px solid #333 !important;
    border-radius: 10px !important;
    box-shadow: 3px 3px 0px #333 !important;
    transition: all 0.2s ease !important;
}

.pmpro_login_wrap input[type="text"]:focus,
.pmpro_login_wrap input[type="password"]:focus {
    outline: none !important;
    transform: translateY(-2px) !important;
    box-shadow: 4px 4px 0px #333 !important;
}

/* Remember Me Checkbox - ALIGNED and THICKER BORDER */
.login-remember {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin: 20px 0 0 0 !important;
}

.login-remember label {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #333 !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    padding-left: 0 !important;
    cursor: pointer !important;
    margin: 0 !important;
}

.login-remember input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin-top: -1px !important;
    margin-bottom: 0 !important;
    accent-color: #ED8CBF !important;
    border: 3.5px solid #333 !important;
    cursor: pointer !important;
}

/* Submit Button */
#wp-submit {
    width: 100% !important;
    padding: 14px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: black !important;
    background: #ED8CBF !important;
    border: 2px solid #333 !important;
    border-radius: 10px !important;
    box-shadow: 4px 4px 0px #333 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-top: 30px !important;
    margin-bottom: 0 !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    display: block !important;
    position: relative !important;
    z-index: 1 !important;
}

#wp-submit::before,
#wp-submit::after {
    display: none !important;
    content: none !important;
}

.login-submit {
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
}

.login-submit::before,
.login-submit::after {
    display: none !important;
    content: none !important;
}

.login-submit ~ * {
    border-top: none !important;
}

#wp-submit:focus {
    outline: none !important;
    box-shadow: 4px 4px 0px #333 !important;
}

#wp-submit:hover {
    background: #f5a8d3 !important;
    transform: translateY(-2px) !important;
    box-shadow: 5px 5px 0px #333 !important;
    outline: none !important;
}

#wp-submit:active {
    transform: translateY(0px) !important;
    box-shadow: 2px 2px 0px #333 !important;
    outline: none !important;
}

/* Password Toggle Button */
.pmpro_form_field-password-toggle {
    position: absolute !important;
    right: 25px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    margin-bottom: -5px;
    margin-top: 40px !important;
}

.login-password {
    position: relative !important;
}

#pmpro_btn-password-toggle-1 {
    background: transparent !important;
    border: none !important;
    padding: 0px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    pointer-events: auto !important;
    outline: none !important;
}

#pmpro_btn-password-toggle-1:focus {
    outline: none !important;
    box-shadow: none !important;
}

.pmpro_icon svg {
    stroke: #ED8CBF !important;
}

.pmpro_icon svg:hover {
    stroke: #d47aab !important;
}

.pmpro_form_field-password-toggle-state {
    display: none !important;
}

/* Forgot Password Link */
.pmpro_card_actions {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    border: none !important;
    border-top: none !important;
    background: transparent !important;
    box-shadow: none !important;
}

.pmpro_card_actions::before,
.pmpro_card_actions::after {
    display: none !important;
    content: none !important;
}

.pmpro_actions_nav {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    line-height: 1 !important;
}

.pmpro_actions_nav a {
    font-family: 'Nunito', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: #333 !important;
    text-decoration: none !important;
    margin: 0 !important;
    padding: 0 !important;
    transition: color 0.2s ease !important;
    line-height: 1 !important;
    display: inline-block !important;
}

.pmpro_actions_nav a:hover {
    color: #ED8CBF !important;
    text-decoration: underline !important;
}

.pmpro_actions_nav a {
    font-size: 0 !important;
}

.pmpro_actions_nav a::after {
    content: "Forgot Password?" !important;
    font-size: 14px !important;
    line-height: 1 !important;
}

/* Card Content Spacing */
.pmpro_card_content {
    padding: 0 !important;
}

.login-username,
.login-password {
    margin-bottom: 18px !important;
}

/* PREVENT LAYOUT SHIFT ON LOAD */
.pmpro_card_actions {
    visibility: hidden !important;
}

.pmpro_card_actions.loaded {
    visibility: visible !important;
}

/* Smooth transitions for everything */
.pmpro_login_wrap * {
    will-change: transform, opacity;
}


/* ================================
   FORGOT PASSWORD SLIDE ANIMATION
   ================================ */

.auth-container {
    width: 100%;
    position: relative;
}

.auth-form-wrapper {
    padding: 0 30px 20px 30px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.auth-title {
    font-family: 'Nunito', sans-serif;
    font-size: 28px;
    font-weight: 800;
    color: #333;
    text-align: center;
    margin-bottom: 10px;
}

.auth-subtitle {
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    color: #666;
    text-align: center;
    margin-bottom: 25px;
    line-height: 1.5;
}

/* Slide Animations - SIMPLIFIED */
.slide-out-left {
    animation: slideOutLeft 0.4s ease-in-out forwards;
}

.slide-in-right {
    animation: slideInRight 0.4s ease-in-out forwards;
}

.slide-out-right {
    animation: slideOutRight 0.4s ease-in-out forwards;
}

.slide-in-left {
    animation: slideInLeft 0.4s ease-in-out forwards;
}

@keyframes slideOutLeft {
    0% {
        transform: translateX(0);
        opacity: 1;
    }
    100% {
        transform: translateX(-100%);
        opacity: 0;
    }
}

@keyframes slideInRight {
    0% {
        transform: translateX(100%);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slideOutRight {
    0% {
        transform: translateX(0);
        opacity: 1;
    }
    100% {
        transform: translateX(100%);
        opacity: 0;
    }
}

@keyframes slideInLeft {
    0% {
        transform: translateX(-100%);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

/* Prevent scrollbars during animation */
.page-id-1823 .e-con-inner {
    overflow-x: hidden !important;
}

/* Form Styling */
#forgot-password-container .form-group {
    margin-bottom: 60px;
}

#forgot-password-container .form-group label {
    font-family: 'Nunito', sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: #333;
    display: block;
    margin-bottom: 8px;
    padding-left: 5px;
    margin-top: -20px;
}

#forgot-password-container input[type="email"] {
    width: 100%;
    padding: 12px 15px;
    font-family: 'Nunito', sans-serif;
    font-size: 15px;
    background: white;
    border: 2px solid #333;
    border-radius: 10px;
    box-shadow: 3px 3px 0px #333;
    transition: all 0.2s ease;
}

#forgot-password-container input[type="email"]:focus {
    outline: none;
    transform: translateY(-2px);
    box-shadow: 4px 4px 0px #333;
}

#forgot-password-container .submit-btn {
    width: 100%;
    padding: 12px;
    font-family: 'Nunito', sans-serif;
    font-size: 16px;
    font-weight: 800;
    color: #333;
    background: #ED8CBF;
    border: 2px solid #333;
    border-radius: 10px;
    box-shadow: 4px 4px 0px #333;
    cursor: pointer;
    transition: all 0.2s ease;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 5px;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}

#forgot-password-container .submit-btn:hover {
    background: #f5a8d3;
    transform: translateY(-2px);
    box-shadow: 5px 5px 0px #333;
}

#forgot-password-container .submit-btn:active {
    transform: translateY(0px);
    box-shadow: 2px 2px 0px #333;
}

#forgot-password-container .submit-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Back to Login Link - WITH NEGATIVE MARGIN RESTORED */
.back-to-login {
    text-align: center;
    margin: 35px -30px 0 -30px !important;
    padding: 20px 30px 0 30px;
    border-top: 2px solid #333;
}

.back-to-login a {
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #333;
    text-decoration: none;
    transition: color 0.2s ease;
}

.back-to-login a:hover {
    color: #ED8CBF;
}

/* Messages */
#forgot-password-messages {
    margin-bottom: 20px;
}

.reset-message {
    padding: 12px 15px;
    border-radius: 10px;
    border: 2px solid #333;
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 15px;
}

.reset-message.success {
    background: #99D1AE;
    color: #333;
}

.reset-message.error {
    background: #FFB6C1;
    color: #333;
}

/* Hide login form when showing forgot password */
body.showing-forgot-password .pmpro_login_wrap {
    display: none;
}

body.showing-forgot-password #forgot-password-container {
    display: block;
}

/* HIDE FOOTER SECTION when showing forgot password */
body.showing-forgot-password .login-footer-section {
    display: none !important;
}

/* Hide forgot password container by default */
#forgot-password-container {
    border: none !important;
    background: transparent !important;
    min-height: 400px !important;
    display: none !important;
    flex-direction: column !important;
    justify-content: center !important;
}

/* Show it only when active */
body.showing-forgot-password #forgot-password-container {
    display: flex !important;
}

/* Footer positioning */
.login-footer-section {
    margin: -135px 0 0 0 !important;
    padding: 0 !important;
}

.login-footer-section .terms-text {
    padding: 0 10px;
    margin-bottom: 20px;
}

.login-footer-section .signup-link-section {
    padding: 20px 10px 0 10px;
    margin: 0 -30px !important;
    border-top: 2px solid #333;
}

/* ================================
   LOGIN FOOTER - Terms & Sign Up
   ================================ */

.login-footer-section {
    width: 100%;
    margin-top: -85px !important;
}

/* Terms of Service & Privacy Policy */
.terms-text {
    font-family: 'Nunito', sans-serif;
    font-size: 13px;
    color: #666;
    text-align: center;
    line-height: 1.6;
    margin-bottom: 25px;
    padding: 0 10px;
}

.terms-text a {
    color: #ED8CBF;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}

.terms-text a:hover {
    color: #d47aab;
    text-decoration: underline;
}

/* Sign Up Link Section */
.signup-link-section {
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
    color: #666;
    text-align: center;
    padding-top: 25px;
    border-top: 2px solid grey;
    font-weight: 500;
}

.signup-link-section a {
    color: #ED8CBF;
    text-decoration: none;
    font-weight: 700;
    transition: color 0.2s ease;
}

.signup-link-section a:hover {
    color: #d47aab;
    text-decoration: underline;
}

/* Mobile Responsive */
@media (max-width: 768px) {
    .auth-form-wrapper {
        padding: 0 25px 20px 25px;
    }
    
    .auth-title {
        font-size: 24px;
    }
    
    .back-to-login {
        margin: 35px -25px 0 -25px !important;
        padding: 20px 25px 0 25px;
    }
    
    .login-footer-section .signup-link-section {
        margin: 0 -25px !important;
    }
    
    .pmpro_card {
        padding: 25px !important;
    }
    
    .pmpro_card_title {
        font-size: 24px !important;
    }
    
    .terms-text {
        font-size: 11px;
    }
    
    .signup-link-section {
        font-size: 13px;
        padding-top: 15px;
    }
}




/* ================================
   PASSWORD RESET FORM STYLING
   ================================ */

/* Hide footer when showing password reset */
body.showing-password-reset .login-footer-section {
    display: none !important;
}

/* Change Password Header */
.change-password-title {
    font-family: 'Nunito', sans-serif !important;
    font-size: 28px !important;
    font-weight: 800 !important;
    color: #333 !important;
    text-align: center !important;
    margin-bottom: 20px !important;
    margin-top: -10px !important;
    padding-bottom: 20px !important;
}

/* Reset form styling */
#resetpassform {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}



/* Make password field containers relative for positioning */
#resetpassform .pmpro_form_field-pass1,
#resetpassform .pmpro_form_field-pass2 {
    position: relative !important;
    margin-top: 3px !important;
    margin-bottom: 0px !important;
}

/* Style password input fields - PREVENT CHANGES WHEN TYPE CHANGES */
#resetpassform input[type="password"],
#resetpassform input[type="text"] {
    width: 100% !important;
    padding: 12px 45px 12px 15px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 15px !important;
    background: white !important;
    border: 2px solid #333 !important;
    border-radius: 10px !important;
    box-shadow: 3px 3px 0px #333 !important;
    transition: all 0.2s ease !important;
}

#resetpassform input[type="password"]:focus,
#resetpassform input[type="text"]:focus {
    outline: none !important;
    transform: translateY(-2px) !important;
    box-shadow: 4px 4px 0px #333 !important;
}

/* Override any PMPro text input styling */
#resetpassform #pass1,
#resetpassform #pass2 {
    width: 100% !important;
    padding: 12px 45px 12px 15px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 15px !important;
    background: white !important;
    border: 2px solid #333 !important;
    border-radius: 10px !important;
    box-shadow: 3px 3px 0px #333 !important;
}

/* Labels - HIGHER WITH MORE LEFT PADDING */
#resetpassform label {
    font-family: 'Nunito', sans-serif !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: #333 !important;
    display: block !important;
    margin-bottom: 8px !important;
    margin-top: 5px !important;
    padding-left: 10px !important;
}

/* Custom password toggle positioning */
#resetpassform .custom-password-toggle {
    position: absolute !important;
    right: 12px !important;
    top: 40px !important;
    z-index: 10 !important;
}

/* Custom toggle buttons */
#resetpassform .custom-toggle-btn {
    background: transparent !important;
    border: none !important;
    padding: 9px !important;
    cursor: pointer !important;
    box-shadow: none !important;
    display: flex !important;
    align-items: center !important;
}

#resetpassform .custom-toggle-btn:focus {
    outline: none !important;
    box-shadow: none !important;
}

#resetpassform .toggle-icon svg {
    stroke: #ED8CBF !important;
    display: block !important;
}

#resetpassform .custom-toggle-btn:hover .toggle-icon svg {
    stroke: #d47aab !important;
}

/* Password mismatch error message */
.password-error-message {
    font-family: 'Nunito', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #e74c3c !important;
    margin-top: -10px !important;
    padding-left: 10px !important;
}

/* Hide password hint and strength indicator */
#resetpassform .pmpro_form_hint,
#resetpassform #pass-strength-result {
    display: none !important;
}

/* Submit button */
#resetpassform .pmpro_btn-submit {
    width: 100% !important;
    padding: 14px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: black !important;
    background: #ED8CBF !important;
    border: 2px solid #333 !important;
    border-radius: 10px !important;
    box-shadow: 4px 4px 0px #333 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    margin-top: 35px !important;
}

#resetpassform .pmpro_btn-submit:hover:not(:disabled) {
    background: #f5a8d3 !important;
    transform: translateY(-2px) !important;
    box-shadow: 5px 5px 0px #333 !important;
}

#resetpassform .pmpro_btn-submit:active:not(:disabled) {
    transform: translateY(0px) !important;
    box-shadow: 2px 2px 0px #333 !important;
}

#resetpassform .pmpro_btn-submit:disabled {
    opacity: 0.5 !important;
    cursor: not-allowed !important;
}

/* Two column layout for password fields */
#resetpassform .pmpro_cols-2 {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}

#resetpassform .pmpro_cols-2 > div {
    flex: 1;
    min-width: 250px;
}/* End custom CSS */