/**
 * NSTeaSet Account Style
 * v1.0.35
 *
 * Guest-only login/LINE styles. Logged-in WooCommerce my-account stays native.
 */

:root {
    --ns-login-brand: #31573a;
    --ns-login-brand-dark: #24472f;
    --ns-login-line: #06c755;
    --ns-login-ink: #243029;
    --ns-login-clay: #a56543;
    --ns-login-paper: #fffdf8;
    --ns-login-bg: #f5efe5;
    --ns-login-border: #dfd2c0;
    --ns-login-muted: #7a7065;
    --ns-login-radius: 6px;
    --ns-login-shadow: 0 18px 44px rgba(35, 42, 36, 0.12);
}

.nsl-button-google,
.nsl-container .nsl-button-google,
.nsl-container [data-provider="google"] {
    display: none !important;
}

.ns-social-login-row {
    box-sizing: border-box;
    margin: 0 auto 24px;
    width: 100%;
}

.ns-social-login-row .nsl-container,
.ns-social-login-row .nsl-container-buttons {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
}

.ns-social-login-row .nsl-button-line,
.ns-social-login-row .ns-liff-login-button {
    align-items: center !important;
    background: var(--ns-login-line) !important;
    border: 1px solid var(--ns-login-line) !important;
    border-radius: var(--ns-login-radius) !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
    color: #fff !important;
    display: inline-flex !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    gap: 10px !important;
    justify-content: center !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    min-height: 48px !important;
    padding: 0 22px !important;
    text-decoration: none !important;
    text-transform: none !important;
    width: 100% !important;
}

.ns-social-login-row .nsl-button-line::before,
.ns-social-login-row .ns-liff-login-button::before {
    background: #fff;
    border-radius: 50%;
    color: var(--ns-login-line);
    content: "LINE";
    display: inline-grid;
    flex: 0 0 24px;
    font-size: 9px;
    font-weight: 800;
    height: 24px;
    letter-spacing: 0;
    line-height: 1;
    place-items: center;
    width: 24px;
}

.ns-social-login-row .nsl-button-label-container {
    background: transparent !important;
    color: inherit !important;
    flex: 0 1 auto !important;
    font: inherit !important;
    margin: 0 !important;
    padding: 0 !important;
    text-shadow: none !important;
    white-space: nowrap !important;
}

body.woocommerce-account:not(.logged-in) .page-wrapper.my-account {
    background:
        linear-gradient(180deg, rgba(255, 253, 248, 0.88), rgba(245, 239, 229, 0.94)),
        var(--ns-login-bg);
}

body.woocommerce-account:not(.logged-in) .my-account-header {
    background:
        linear-gradient(135deg, rgba(49, 87, 58, 0.08), rgba(165, 101, 67, 0.06)),
        var(--ns-login-paper);
    border-bottom: 1px solid rgba(49, 87, 58, 0.1);
}

body.woocommerce-account:not(.logged-in) .account-container {
    max-width: 960px;
}

body.woocommerce-account:not(.logged-in) .account-container > .woocommerce > .ns-social-login-row,
body.woocommerce-account:not(.logged-in) .account-container > .ns-social-login-row {
    max-width: 560px;
}

body.woocommerce-account:not(.logged-in) #customer_login {
    align-items: stretch;
    display: grid !important;
    gap: 28px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.woocommerce-account:not(.logged-in) #customer_login > .col {
    border-left: 0 !important;
    box-sizing: border-box;
    flex-basis: auto !important;
    max-width: none !important;
    padding: 0 !important;
    width: auto !important;
}

body.woocommerce-account:not(.logged-in) .account-login-inner,
body.woocommerce-account:not(.logged-in) .account-register-inner {
    background: var(--ns-login-paper);
    border: 1px solid var(--ns-login-border);
    border-radius: var(--ns-login-radius);
    box-shadow: var(--ns-login-shadow);
    box-sizing: border-box;
    height: 100%;
    padding: 30px;
}

body.woocommerce-account:not(.logged-in) #customer_login h2,
#login-form-popup #customer_login h2 {
    border: 0;
    color: var(--ns-login-ink);
    font-size: 26px !important;
    font-weight: 700;
    letter-spacing: 0 !important;
    line-height: 1.2;
    margin: 0 0 24px;
    padding: 0 0 0 15px;
    position: relative;
    text-transform: none !important;
}

body.woocommerce-account:not(.logged-in) #customer_login h2::before,
#login-form-popup #customer_login h2::before {
    background: var(--ns-login-brand);
    bottom: 2px;
    content: "";
    left: 0;
    position: absolute;
    top: 2px;
    width: 3px;
}

body.woocommerce-account:not(.logged-in) #customer_login .col-2 h2::before,
#login-form-popup #customer_login .col-2 h2::before {
    background: var(--ns-login-clay);
}

body.woocommerce-account:not(.logged-in) .form-row label,
#login-form-popup .form-row label {
    color: var(--ns-login-ink);
    font-size: 14px;
    font-weight: 650;
    margin-bottom: 8px;
}

body.woocommerce-account:not(.logged-in) input.input-text,
#login-form-popup input.input-text {
    background: #fffefb !important;
    border: 1px solid var(--ns-login-border) !important;
    border-radius: var(--ns-login-radius) !important;
    box-shadow: none !important;
    color: var(--ns-login-ink) !important;
    font-size: 16px !important;
    min-height: 48px;
}

body.woocommerce-account:not(.logged-in) input.input-text:focus,
#login-form-popup input.input-text:focus {
    border-color: var(--ns-login-brand) !important;
    box-shadow: 0 0 0 3px rgba(49, 87, 58, 0.12) !important;
    outline: none !important;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit,
#login-form-popup .woocommerce-form-login__submit,
#login-form-popup .woocommerce-form-register__submit {
    background: var(--ns-login-brand) !important;
    border: 1px solid var(--ns-login-brand) !important;
    border-radius: var(--ns-login-radius) !important;
    box-shadow: none !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    min-height: 48px;
    text-transform: none !important;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit,
#login-form-popup .woocommerce-form-register__submit {
    background: var(--ns-login-clay) !important;
    border-color: var(--ns-login-clay) !important;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit:hover,
#login-form-popup .woocommerce-form-login__submit:hover {
    background: var(--ns-login-brand-dark) !important;
    border-color: var(--ns-login-brand-dark) !important;
}

body.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme,
#login-form-popup .woocommerce-form-login__rememberme {
    align-items: center;
    color: var(--ns-login-muted);
    display: inline-flex;
    gap: 8px;
}

body.woocommerce-account:not(.logged-in) input[type="checkbox"],
#login-form-popup input[type="checkbox"] {
    accent-color: var(--ns-login-brand);
}

body.woocommerce-account:not(.logged-in) .lost_password a,
body.woocommerce-account:not(.logged-in) .woocommerce-privacy-policy-text a,
#login-form-popup .lost_password a,
#login-form-popup .woocommerce-privacy-policy-text a {
    color: var(--ns-login-brand);
    font-weight: 650;
    text-decoration: none;
}

body.woocommerce-account:not(.logged-in) .woocommerce-privacy-policy-text,
#login-form-popup .woocommerce-privacy-policy-text {
    background: rgba(241, 233, 222, 0.76);
    border: 0;
    border-left: 3px solid rgba(165, 101, 67, 0.3);
    border-radius: var(--ns-login-radius);
    color: var(--ns-login-muted);
    font-size: 13px;
    line-height: 1.7;
    margin-top: 14px;
    padding: 12px 14px;
}

#login-form-popup {
    --ns-login-radius: 6px;
}

#login-form-popup.lightbox-content {
    background:
        linear-gradient(90deg, rgba(49, 87, 58, 0.07), transparent 20%, transparent 80%, rgba(165, 101, 67, 0.07)),
        var(--ns-login-paper) !important;
    border: 1px solid rgba(49, 87, 58, 0.16) !important;
    border-radius: var(--ns-login-radius) !important;
    box-shadow: 0 22px 56px rgba(16, 23, 18, 0.28) !important;
    max-width: 940px !important;
    overflow: hidden;
    width: min(940px, calc(100vw - 40px)) !important;
}

#login-form-popup .account-container.lightbox-inner {
    background: transparent !important;
    box-sizing: border-box;
    padding: 32px 44px 38px !important;
}

#login-form-popup .ns-social-login-row {
    max-width: 560px;
}

#login-form-popup #customer_login {
    column-gap: 64px;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
    position: relative;
}

#login-form-popup #customer_login::before {
    background: linear-gradient(180deg, transparent, rgba(49, 87, 58, 0.2), transparent);
    bottom: 0;
    content: "";
    left: 50%;
    position: absolute;
    top: 0;
    width: 1px;
}

#login-form-popup #customer_login > .col {
    border-left: 0 !important;
    box-sizing: border-box;
    flex-basis: auto !important;
    max-width: none !important;
    min-width: 0;
    padding: 0 !important;
    width: auto !important;
}

#login-form-popup .account-login-inner,
#login-form-popup .account-register-inner {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
}

#login-form-popup .woocommerce-form-login .form-row:not(.form-row-wide) {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

#login-form-popup .woocommerce-form-login__submit {
    width: 100%;
}

@media (max-width: 849px) {
    .ns-social-login-row,
    body.woocommerce-account:not(.logged-in) .account-container > .woocommerce > .ns-social-login-row,
    body.woocommerce-account:not(.logged-in) .account-container > .ns-social-login-row,
    #login-form-popup .ns-social-login-row {
        max-width: none;
    }

    body.woocommerce-account:not(.logged-in) #customer_login,
    #login-form-popup #customer_login {
        display: grid !important;
        gap: 26px;
        grid-template-columns: minmax(0, 1fr);
    }

    body.woocommerce-account:not(.logged-in) .account-login-inner,
    body.woocommerce-account:not(.logged-in) .account-register-inner {
        padding: 24px 20px;
    }

    #login-form-popup.lightbox-content {
        max-height: calc(100vh - 24px);
        overflow: auto;
        width: calc(100vw - 24px) !important;
    }

    #login-form-popup .account-container.lightbox-inner {
        padding: 24px 20px 28px !important;
    }

    #login-form-popup #customer_login::before {
        display: none;
    }

    #login-form-popup #customer_login > .col-2 {
        border-top: 1px solid rgba(49, 87, 58, 0.14) !important;
        padding-top: 26px !important;
    }
}


/* 隱藏空的 WC 隱私權說明區塊 — 避免登入/註冊頁註冊按鈕下方顯示空白米色橫條 */
.woocommerce-privacy-policy-text:empty {
    display: none !important;
}


/* 統一登入 / 註冊按鈕為滿版寬度，視覺平衡 */
body.woocommerce-account:not(.logged-in) .woocommerce-form-login__submit,
body.woocommerce-account:not(.logged-in) .woocommerce-form-register__submit,
#login-form-popup .woocommerce-form-login__submit,
#login-form-popup .woocommerce-form-register__submit {
    width: 100% !important;
    display: block !important;
}
