.membership-login-wrap {
    min-height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 20px;
    background: linear-gradient(135deg, #f6f7ff 0%, #eef6ff 100%);
}

.membership-login-card {
    width: 100%;
    max-width: 430px;
    padding: 32px;
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .12);
}

.membership-login-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 22px;
}

.membership-login-brand span {
    display: inline-flex;
    width: 54px;
    height: 54px;
    border-radius: 18px;
    background: #3858e9;
    color: #fff;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 24px;
}

.membership-login-brand h1 {
    margin: 0 0 4px;
    font-size: 28px;
    line-height: 1.1;
}

.membership-login-brand p {
    margin: 0;
    color: #646970;
}

.membership-login-card label {
    display: block;
    margin-bottom: 7px;
    font-weight: 650;
}

.membership-login-card input[type="text"],
.membership-login-card input[type="password"] {
    width: 100%;
    min-height: 46px;
    padding: 10px 12px;
    border: 1px solid #dcdcde;
    border-radius: 10px;
    box-sizing: border-box;
}

.membership-login-card .login-remember label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 500;
}

.membership-login-card .button,
.membership-login-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 18px;
    border-radius: 10px;
    border: 1px solid #3858e9;
    background: #3858e9;
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    cursor: pointer;
}

.membership-login-card .button:hover,
.membership-login-button:hover {
    color: #fff;
    opacity: .92;
}

.membership-login-button-secondary {
    background: #fff;
    color: #3858e9;
}

.membership-login-button-secondary:hover {
    color: #3858e9;
}

.membership-login-message {
    padding: 12px 14px;
    border-radius: 10px;
    margin-bottom: 16px;
    font-weight: 650;
}

.membership-login-message-error {
    background: #fcf0f1;
    color: #8a2424;
}

.membership-login-message-success {
    background: #edfaef;
    color: #0a6b28;
}

.membership-login-links,
.membership-login-actions {
    margin-bottom: 0;
}

.membership-product-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
    margin: 18px 0;
}
.membership-product-actions-column { flex-direction: column; align-items: stretch; }
.membership-actions-title { width: 100%; font-weight: 700; margin-bottom: 2px; }
.membership-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: var(--membership-button-radius, 10px);
    border: 1px solid var(--membership-buy-bg, #3858e9);
    background: var(--membership-buy-bg, #3858e9);
    color: var(--membership-buy-text, #fff) !important;
    text-decoration: none !important;
    font-weight: 700;
    cursor: pointer;
    line-height: 1;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, opacity .18s ease;
}
.membership-action-btn:hover,
.membership-action-btn:focus {
    opacity: 1;
    background: var(--membership-buy-hover-bg, #2746d8);
    border-color: var(--membership-buy-hover-bg, #2746d8);
    color: var(--membership-buy-hover-text, #fff) !important;
}
.membership-quote-open {
    background: var(--membership-quote-bg, #fff);
    color: var(--membership-quote-text, #3858e9) !important;
    border-color: var(--membership-quote-border, #3858e9);
}
.membership-quote-open:hover,
.membership-quote-open:focus {
    background: var(--membership-quote-hover-bg, #3858e9);
    border-color: var(--membership-quote-hover-border, #3858e9);
    color: var(--membership-quote-hover-text, #fff) !important;
}
.membership-quote-modal { display: none; position: fixed; inset: 0; z-index: 999999; }
.membership-quote-modal.is-open { display: block; }
.membership-quote-backdrop { position: absolute; inset: 0; background: rgba(0, 0, 0, .55); }
.membership-quote-dialog {
    position: relative;
    width: min(560px, calc(100% - 32px));
    max-height: calc(100vh - 48px);
    overflow: auto;
    margin: 24px auto;
    background: #fff;
    border-radius: 18px;
    padding: 28px;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .28);
}
.membership-quote-close {
    position: absolute;
    top: 14px;
    right: 16px;
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 50%;
    background: #f0f0f1;
    cursor: pointer;
    font-size: 24px;
    line-height: 1;
}
.membership-quote-dialog h3 { margin: 0 40px 8px 0; font-size: 24px; }
.membership-quote-form { display: grid; gap: 14px; margin-top: 18px; }
.membership-quote-form label { display: grid; gap: 6px; font-weight: 700; }
.membership-quote-form input,
.membership-quote-form select,
.membership-quote-form textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid #dcdcde;
    border-radius: var(--membership-button-radius, 10px);
    padding: 9px 12px;
    box-sizing: border-box;
}
.membership-quote-form textarea { min-height: 100px; }
.membership-quote-form small { color: #646970; font-weight: 500; }
.membership-quote-response { display: none; padding: 11px 13px; border-radius: 10px; font-weight: 650; }
.membership-quote-response.is-success { display: block; background: #edfaef; color: #0a6b28; }
.membership-quote-response.is-error { display: block; background: #fcf0f1; color: #8a2424; }
.membership-quote-submit { width: 100%; }
body.membership-quote-modal-open { overflow: hidden; }


body.membership-is-member-product .single_add_to_cart_button,
body.membership-is-member-product .elementor-add-to-cart .single_add_to_cart_button {
    display: none !important;
}

body.membership-is-member-product .membership-product-actions .membership-action-btn {
    display: inline-flex !important;
}

.membership-actions-qty-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}
.membership-actions-qty {
    width: 74px;
    min-height: 44px;
    padding: 8px 10px;
    border-radius: var(--membership-button-radius, 10px);
    border: 1px solid var(--membership-qty-border, #dcdcde);
    background: var(--membership-qty-bg, #ffffff);
    color: var(--membership-qty-text, #111827);
    font-weight: 700;
    text-align: center;
    box-sizing: border-box;
}
.membership-buy-direct-form {
    margin: 0 !important;
    padding: 0 !important;
    display: inline-flex;
}
.membership-buy-direct-form .membership-action-btn {
    width: auto;
}
.membership-quote-form input[readonly] {
    background: #f6f7f7;
    color: #1d2327;
    cursor: not-allowed;
}
