/* ==========================================================================
   CROSSMAP AUTH MODAL — Premium Login Experience
   Targets: Popup Maker modal + router form + Ultimate Member forms
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* --- 1. POPUP MAKER OVERLAY & CONTAINER --- */

/* Dark cinematic backdrop */
.pum-overlay {
    background: rgba(11, 18, 24, 0.75) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
}

/* The modal card itself */
.pum-container {
    border-radius: 20px !important;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(255,255,255,0.05) !important;
    padding: 0 !important;
    overflow: hidden !important;
    max-width: 420px !important;
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    background: #ffffff !important;
    border: none !important;
    animation: cmModalSlideIn 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;

    /* Force perfect center on screen */
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
    z-index: 100000 !important;
}

@keyframes cmModalSlideIn {
    from {
        opacity: 0;
        transform: translate(-50%, -48%) scale(0.97);
    }
    to {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

/* Inner content area */
.pum-content,
.pum-content + .pum-close {
    font-family: 'Inter', system-ui, -apple-system, sans-serif !important;
}

.pum-content {
    padding: 40px 36px 36px !important;
}


/* --- 2. CLOSE BUTTON — Elegant Circle X --- */

.pum-close,
.pum-close.popmake-close {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    background: #f1f3f5 !important;
    color: #868e96 !important;
    border: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    line-height: 1 !important;
    z-index: 10 !important;
    box-shadow: none !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
}

.pum-close:hover,
.pum-close.popmake-close:hover {
    background: #e9ecef !important;
    color: #495057 !important;
    transform: scale(1.1) !important;
}


/* --- 3. HEADING & SUBTEXT --- */

/* "Enter your email to get started" heading */
.pum-content > h2,
.pum-content > h3,
.pum-content > p:first-of-type,
#router-step-1 > h2,
#router-step-1 > h3 {
    text-align: center !important;
    color: #1a1a2e !important;
    font-weight: 700 !important;
    font-size: 22px !important;
    margin: 0 0 6px 0 !important;
    line-height: 1.3 !important;
    letter-spacing: -0.3px !important;
}

/* Subheading / description text */
.pum-content > p,
#router-step-1 > p {
    text-align: center !important;
    color: #6c757d !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    margin: 0 0 28px 0 !important;
    line-height: 1.5 !important;
}


/* --- 4. INPUT FIELDS — Modern & Clean --- */

/* Label styling */
.pum-content label,
#router-step-1 label,
.um-field-label,
.um-field-label label {
    display: block !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    color: #495057 !important;
    margin-bottom: 8px !important;
    text-transform: none !important;
    letter-spacing: 0.2px !important;
}

/* Input field */
.pum-content input[type="text"],
.pum-content input[type="email"],
.pum-content input[type="password"],
#router-email,
.um-field-area input[type="text"],
.um-field-area input[type="password"],
.um-field-area input[type="email"] {
    width: 100% !important;
    padding: 14px 16px !important;
    background: #f8f9fa !important;
    border: 2px solid #e9ecef !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    color: #212529 !important;
    transition: all 0.2s ease !important;
    box-sizing: border-box !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

/* Focus state — warm red glow */
.pum-content input[type="text"]:focus,
.pum-content input[type="email"]:focus,
.pum-content input[type="password"]:focus,
#router-email:focus,
.um-field-area input:focus {
    background: #ffffff !important;
    border-color: #e50914 !important;
    box-shadow: 0 0 0 4px rgba(229, 9, 20, 0.08) !important;
}

/* Placeholder */
.pum-content input::placeholder,
#router-email::placeholder,
.um-field-area input::placeholder {
    color: #adb5bd !important;
    font-weight: 400 !important;
}


/* --- 5. CONTINUE / SUBMIT BUTTON — Gradient Red --- */

.pum-content button[type="submit"],
.pum-content input[type="submit"],
#router-continue,
.um .um-button {
    width: 100% !important;
    padding: 14px 24px !important;
    background: linear-gradient(135deg, #e50914 0%, #c50710 100%) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.25s ease !important;
    margin-top: 12px !important;
    letter-spacing: 0.2px !important;
    text-transform: none !important;
    box-shadow: 0 2px 8px rgba(229, 9, 20, 0.2) !important;
    line-height: 1.4 !important;
}

.pum-content button[type="submit"]:hover,
.pum-content input[type="submit"]:hover,
#router-continue:hover,
.um .um-button:hover {
    background: linear-gradient(135deg, #d10812 0%, #a8060d 100%) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(229, 9, 20, 0.3) !important;
}

.pum-content button[type="submit"]:active,
#router-continue:active,
.um .um-button:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 6px rgba(229, 9, 20, 0.2) !important;
}


/* --- 6. "OR" SEPARATOR --- */

.um-col-alt-b,
.pum-content hr {
    position: relative !important;
    text-align: center !important;
    margin: 24px 0 !important;
    border: none !important;
    height: auto !important;
}

.um-col-alt-b::before,
.pum-content hr::before {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    left: 0 !important;
    right: 0 !important;
    height: 1px !important;
    background: #e9ecef !important;
}

.um-col-alt-b::after {
    content: 'OR' !important;
    position: relative !important;
    background: #ffffff !important;
    padding: 0 16px !important;
    color: #adb5bd !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
}


/* --- 7. GOOGLE BUTTON — Clean & Professional --- */

div.nsl-container,
div.nsl-container-block {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    text-align: center !important;
    margin: 0 !important;
}

a.nsl-button-default,
a.nsl-button,
div.nsl-button {
    display: flex !important;
    width: 100% !important;
    box-sizing: border-box !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 10px !important;
    background: #ffffff !important;
    border: 2px solid #e9ecef !important;
    border-radius: 12px !important;
    color: #495057 !important;
    padding: 13px 0 !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    box-shadow: none !important;
    text-decoration: none !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
}

a.nsl-button-default:hover,
a.nsl-button:hover,
div.nsl-button:hover {
    background: #f8f9fa !important;
    border-color: #ced4da !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06) !important;
}

/* Google icon and label */
.nsl-button-label-container {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
}

.nsl-button-label-container b {
    margin-left: 0 !important;
    font-weight: 600 !important;
}

/* Google icon sizing */
.nsl-button-svg-container {
    width: 20px !important;
    height: 20px !important;
    display: flex !important;
    align-items: center !important;
}


/* --- 8. ULTIMATE MEMBER FORM OVERRIDES --- */

/* Container */
.um-register,
.um-login {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Inter', system-ui, sans-serif !important;
}

/* Field wrappers */
.um-field {
    margin-bottom: 16px !important;
}

/* UM error messages */
.um-field-error {
    color: #e50914 !important;
    font-size: 12px !important;
    margin-top: 6px !important;
}

/* Password field wrapper - match input styling */
.um-field-password .um-field-area {
    position: relative !important;
}

/* "Forgot password?" link */
.um-forgot-pass-link,
a.um-link {
    color: #e50914 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}

.um-forgot-pass-link:hover,
a.um-link:hover {
    color: #c50710 !important;
    text-decoration: underline !important;
}


/* --- 9. ROUTER STEP CONTAINERS (Login/Register reveal) --- */

#router-step-1,
#router-login-container,
#router-register-container {
    font-family: 'Inter', system-ui, sans-serif !important;
}

#router-login-container,
#router-register-container {
    animation: cmFadeSlideIn 0.3s ease !important;
}

@keyframes cmFadeSlideIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


/* --- 10. RESPONSIVE --- */

@media (max-width: 480px) {
    .pum-container {
        max-width: calc(100vw - 32px) !important;
        border-radius: 16px !important;
        margin: 16px !important;
    }

    .pum-content {
        padding: 32px 24px 28px !important;
    }
}
