/* ================================================================
   Womenmatic — Login / Register page (wm-brand styling)
   ================================================================
   Scope: logged-OUT visitors to /mein-konto/ (form-login.php).
   Account-page CSS (sidebar shell etc.) is NOT loaded when logged-out,
   so this file styles the auth form standalone. Rules scoped to
   #customer_login to avoid leaking to checkout / other forms.
   ================================================================ */

/* ── 0. Ancestor wrapper fix ─────────────────────────────────── */
/* /mein-konto/ (page-id-131) is rendered by Elementor Pro's          */
/* "WooCommerce My Account" widget (elementor-widget-woocommerce-     */
/* my-account). The widget wraps our login form in its own container  */
/* stack that includes .e-con-full (min-height:800px), .e-my-account- */
/* tab__dashboard, .woocommerce-form-wrapper, etc. These ancestors    */
/* paint their own background/border/padding and sometimes constrain  */
/* height — making the login form look like it "falls out" of the     */
/* Elementor widget template frame.                                   */
/* Fix: force ALL ancestors (including Elementor v3 container classes */
/* like .e-con / .e-con-full / .e-con-inner / .e-flex / .e-parent)    */
/* to shrink/grow with content and to paint no visuals. Only our      */
/* .wm-auth-card (#customer_login) defines the visible frame.          */

/* CSS is enqueued ONLY when !is_user_logged_in() (see functions.php        */
/* wm_enqueue_login_register_styles), so all rules below are implicitly    */
/* scoped to logged-out visitors. No need for :not(.logged-in) qualifier.  */

body.woocommerce-account .entry-content,
body.woocommerce-account .entry-content-wrap,
body.woocommerce-account article.hentry,
body.woocommerce-account .site-main,
body.woocommerce-account .content-area,
body.woocommerce-account .woocommerce,
body.woocommerce-account .woocommerce-notices-wrapper,
body.woocommerce-account .woocommerce-form-wrapper,
body.woocommerce-account .elementor-section,
body.woocommerce-account .elementor-container,
body.woocommerce-account .elementor-column,
body.woocommerce-account .elementor-widget-wrap,
body.woocommerce-account .elementor-widget-container,
body.woocommerce-account .elementor-widget-shortcode,
body.woocommerce-account .elementor-widget-woocommerce-my-account,
body.woocommerce-account .elementor-shortcode,
body.woocommerce-account .e-con,
body.woocommerce-account .e-con-full,
body.woocommerce-account .e-con-inner,
body.woocommerce-account .e-flex,
body.woocommerce-account .e-parent,
body.woocommerce-account .e-my-account-tab,
body.woocommerce-account [class*="e-my-account-tab__"] {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    flex: 0 0 auto !important;
}

/* Kill any stale background/border that parent containers might paint  */
/* BEHIND our login card — we want the page to look like a single       */
/* centered card, not nested frames.                                    */
body.woocommerce-account .entry-content,
body.woocommerce-account .entry-content-wrap,
body.woocommerce-account article.hentry,
body.woocommerce-account .elementor-widget-shortcode,
body.woocommerce-account .elementor-widget-container,
body.woocommerce-account .elementor-widget-woocommerce-my-account,
body.woocommerce-account .elementor-shortcode,
body.woocommerce-account .woocommerce,
body.woocommerce-account .woocommerce-form-wrapper,
body.woocommerce-account .e-con,
body.woocommerce-account .e-con-full,
body.woocommerce-account .e-con-inner,
body.woocommerce-account .e-my-account-tab,
body.woocommerce-account [class*="e-my-account-tab__"] {
    background: transparent !important;
    background-color: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Extra-aggressive inner-wrapper reset — kill ALL visual styling on the   */
/* div that wraps the register <form>, plus the form itself and our        */
/* .womenmatic-extra-fields wrapper. This is what appears as the "inner    */
/* card" in user screenshots (image copy 17/18 — visible border around     */
/* email+vorname+nachname+telefon).                                        */
body.woocommerce-account #customer_login .woocommerce-form-wrapper,
body.woocommerce-account #customer_login #login-tab > .woocommerce-form-wrapper,
body.woocommerce-account #customer_login #register-tab > .woocommerce-form-wrapper,
body.woocommerce-account #customer_login form.woocommerce-form,
body.woocommerce-account #customer_login form.woocommerce-form-login,
body.woocommerce-account #customer_login form.woocommerce-form-register,
body.woocommerce-account #customer_login .womenmatic-extra-fields,
body.woocommerce-account #customer_login .wc-tab-panel {
    background: transparent !important;
    background-color: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible !important;
    max-height: none !important;
    min-height: 0 !important;
    height: auto !important;
}

/* Re-assert .womenmatic-extra-fields grid (was wiped by reset above)      */
body.woocommerce-account #customer_login .womenmatic-extra-fields {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin: 0 0 16px 0 !important;
}

@media (max-width: 560px) {
    body.woocommerce-account #customer_login .womenmatic-extra-fields {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }
}

/* Re-assert gap/margin between form rows that the reset above wiped       */
body.woocommerce-account #customer_login form.woocommerce-form > p.form-row,
body.woocommerce-account #customer_login form.woocommerce-form > .form-row {
    margin: 0 0 16px 0 !important;
}

/* Neutralize Elementor widget's forced margin/padding on widget-container    */
body.woocommerce-account .elementor-element > .elementor-widget-container {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}

/* ── 1. Outer card ───────────────────────────────────────────── */

body.woocommerce-account #customer_login {
    max-width: 520px;
    margin: 40px auto;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 14px;
    padding: 32px 36px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.05);
    font-family: 'Lato', sans-serif;
    color: var(--wm-text, #4C4842);
    overflow: visible !important;
    height: auto !important;
    min-height: 0 !important;
    box-sizing: border-box;
}

/* ── 2. Tabs ─────────────────────────────────────────────────── */

#customer_login ul.wc-tabs {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0 0 24px 0 !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    gap: 0;
    background: transparent;
}

#customer_login ul.wc-tabs li.tab-link {
    padding: 12px 22px;
    cursor: pointer;
    font-weight: 500;
    font-size: 15px;
    color: var(--wm-text-muted, #7A7470);
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    background: transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
    list-style: none;
}

#customer_login ul.wc-tabs li.tab-link::before,
#customer_login ul.wc-tabs li.tab-link::after {
    display: none !important;
}

#customer_login ul.wc-tabs li.tab-link:hover {
    color: var(--wm-text, #4C4842);
}

#customer_login ul.wc-tabs li.tab-link.active {
    color: var(--wm-primary, #4685A5);
    border-bottom-color: var(--wm-primary, #4685A5);
    font-weight: 700;
}

/* Panels */
#customer_login .wc-tab-panel {
    display: none;
}

#customer_login .wc-tab-panel.active {
    display: block;
}

/* ── 3. Form headings ────────────────────────────────────────── */

#customer_login .woocommerce-form-wrapper > h2 {
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--wm-text, #4C4842) !important;
    margin: 0 0 20px 0 !important;
    letter-spacing: -0.01em !important;
    font-family: 'Lato', sans-serif !important;
}

/* ── 4. Form layout ──────────────────────────────────────────── */

#customer_login form {
    margin: 0;
}

/* Kill float-based layout of .form-row-first / .form-row-last  */
/* in favor of a stable grid so Firmenname + checkbox + submit   */
/* can't fall out of the form wrapper.                            */
#customer_login .womenmatic-extra-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 0;
    clear: both;
}

#customer_login .womenmatic-extra-fields > .form-row-first,
#customer_login .womenmatic-extra-fields > .form-row-last,
#customer_login .womenmatic-extra-fields > .form-row-wide,
#customer_login .womenmatic-extra-fields > .form-row {
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
}

#customer_login .womenmatic-extra-fields > .form-row-first {
    grid-column: 1;
}

#customer_login .womenmatic-extra-fields > .form-row-last {
    grid-column: 2;
}

#customer_login .womenmatic-extra-fields > .form-row-wide,
#customer_login .womenmatic-extra-fields > .form-row.form-row-wide {
    grid-column: 1 / -1;
}

/* Same grid behavior for the non-extra form rows               */
#customer_login form > .form-row,
#customer_login form > p.form-row {
    margin: 0 0 16px 0 !important;
    padding: 0 !important;
    float: none !important;
    width: 100% !important;
    clear: both;
}

/* ── 5. Inputs & labels ──────────────────────────────────────── */

#customer_login label {
    display: block;
    margin-bottom: 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--wm-text, #4C4842);
    line-height: 1.3;
}

#customer_login label .required {
    color: #C94A4A;
    margin-left: 2px;
}

#customer_login input[type="text"],
#customer_login input[type="email"],
#customer_login input[type="tel"],
#customer_login input[type="password"],
#customer_login input.input-text,
#customer_login input.woocommerce-Input {
    width: 100% !important;
    padding: 11px 14px !important;
    border: 1px solid rgba(0, 0, 0, 0.14) !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-family: 'Lato', sans-serif !important;
    color: var(--wm-text, #4C4842) !important;
    background: #fff !important;
    box-sizing: border-box !important;
    line-height: 1.4 !important;
    min-height: 44px !important;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

#customer_login input:hover {
    border-color: rgba(0, 0, 0, 0.22) !important;
}

#customer_login input:focus,
#customer_login input:focus-visible {
    outline: none !important;
    border-color: var(--wm-primary, #4685A5) !important;
    box-shadow: 0 0 0 3px rgba(70, 133, 165, 0.15) !important;
}

/* ── 6. Info paragraph (password-generation notice) ──────────── */

#customer_login form > p:not(.form-row):not(.lost_password):not(.woocommerce-LostPassword) {
    font-size: 13px;
    color: var(--wm-text-muted, #7A7470);
    margin: -8px 0 16px 0;
    line-height: 1.5;
}

/* ── 7. Checkbox row (privacy policy + rememberme) ───────────── */

#customer_login .woocommerce-form__label-for-checkbox,
#customer_login label.woocommerce-form-login__rememberme {
    display: inline-flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: var(--wm-text, #4C4842) !important;
    cursor: pointer;
    line-height: 1.4;
    margin: 0 !important;
}

#customer_login input[type="checkbox"] {
    width: 18px !important;
    min-height: 0 !important;
    height: 18px !important;
    margin: 2px 0 0 0 !important;
    padding: 0 !important;
    accent-color: var(--wm-primary, #4685A5);
    flex-shrink: 0;
    cursor: pointer;
}

#customer_login .woocommerce-form__label-for-checkbox a {
    color: var(--wm-primary, #4685A5);
    text-decoration: underline;
}

/* ── 8. Submit button ────────────────────────────────────────── */

/* Tightly scoped to the ACTUAL submit buttons only (by name attribute).   */
/* Excludes Germanized's show-password <button> toggle which is also       */
/* rendered inside the form but shouldn't be restyled.                     */
body.woocommerce-account #customer_login button[name="login"],
body.woocommerce-account #customer_login button[name="register"],
body.woocommerce-account #customer_login .woocommerce-form-login__submit,
body.woocommerce-account #customer_login .woocommerce-form-register__submit {
    background: var(--wm-primary, #4685A5) !important;
    background-color: var(--wm-primary, #4685A5) !important;
    color: #fff !important;
    border: none !important;
    padding: 12px 28px !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    font-family: 'Lato', sans-serif !important;
    letter-spacing: 0.2px !important;
    cursor: pointer !important;
    min-height: 48px !important;
    text-transform: none !important;
    box-shadow: 0 1px 3px rgba(70, 133, 165, 0.2) !important;
    transition: background 0.2s ease, transform 0.15s ease, box-shadow 0.2s ease !important;
    margin: 0 !important;
    width: auto !important;
    line-height: 1.4 !important;
}

body.woocommerce-account #customer_login button[name="login"]:hover,
body.woocommerce-account #customer_login button[name="register"]:hover,
body.woocommerce-account #customer_login .woocommerce-form-login__submit:hover,
body.woocommerce-account #customer_login .woocommerce-form-register__submit:hover {
    background: #3A6E88 !important;
    background-color: #3A6E88 !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(70, 133, 165, 0.3) !important;
}

/* Germanized / WC show-password toggle — keep it small + ghost style.     */
/* This button sits next to the password input and was being caught by     */
/* broader button[type="submit"] rules causing it to render full-size.     */
body.woocommerce-account #customer_login .show-password-input,
body.woocommerce-account #customer_login button.show-password-input,
body.woocommerce-account #customer_login .password-input .show-password-input,
body.woocommerce-account #customer_login [class*="show-password"],
body.woocommerce-account #customer_login .password-input button,
body.woocommerce-account #customer_login button:not([name="login"]):not([name="register"]):not([name="save_address"]):not([name="save_account_details"]) {
    all: unset;
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px !important;
    height: 32px !important;
    min-height: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: var(--wm-text-muted, #7A7470) !important;
    cursor: pointer;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 1 !important;
    font-size: 14px !important;
    opacity: 0.6;
    transition: opacity 0.15s ease;
}

body.woocommerce-account #customer_login .password-input,
body.woocommerce-account #customer_login .input-wrap-password {
    position: relative;
}

body.woocommerce-account #customer_login .show-password-input:hover {
    opacity: 1;
}

#customer_login button[type="submit"]:active {
    transform: translateY(0);
}

/* Submit row (login form only): remember-me + button side by side         */
/* Targeted selector: .form-row WITHOUT form-row-wide = the submit row.    */
/* No :has() — works on all evergreen browsers.                            */
#customer_login form.woocommerce-form-login .form-row:not(.form-row-wide):not(.form-row-first):not(.form-row-last) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
}

/* Register form's submit row (no wide/first/last qualifiers either)       */
#customer_login form.woocommerce-form-register .form-row:not(.form-row-wide):not(.form-row-first):not(.form-row-last) {
    display: block;
}

/* ── 9. Lost password link ───────────────────────────────────── */

#customer_login .woocommerce-LostPassword,
#customer_login p.lost_password {
    margin: 16px 0 0 0 !important;
    padding: 12px 0 0 0 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    font-size: 13px;
    text-align: center;
}

#customer_login .woocommerce-LostPassword a,
#customer_login p.lost_password a {
    color: var(--wm-primary, #4685A5);
    text-decoration: none;
}

#customer_login .woocommerce-LostPassword a:hover {
    text-decoration: underline;
}

/* ── 10. WC notices (errors / info) above the form ───────────── */

body.woocommerce-account .woocommerce-notices-wrapper:has(+ div #customer_login),
body.woocommerce-account .woocommerce > .woocommerce-notices-wrapper {
    max-width: 520px;
    margin: 40px auto 0 auto;
    padding: 0 8px;
    box-sizing: border-box;
}

body.woocommerce-account ul.woocommerce-error,
body.woocommerce-account .woocommerce-message,
body.woocommerce-account .woocommerce-info {
    border-radius: 10px !important;
    padding: 14px 18px !important;
    font-size: 14px !important;
    font-family: 'Lato', sans-serif !important;
    margin: 0 0 16px 0 !important;
}

body.woocommerce-account ul.woocommerce-error {
    background: rgba(201, 74, 74, 0.06) !important;
    border: 1px solid rgba(201, 74, 74, 0.25) !important;
    color: #8A3535 !important;
    list-style: none !important;
}

body.woocommerce-account ul.woocommerce-error li {
    list-style: none !important;
    margin: 0 !important;
    padding: 2px 0 !important;
}

/* ── 11. Mobile ──────────────────────────────────────────────── */

@media (max-width: 560px) {
    body.woocommerce-account #customer_login {
        margin: 16px 12px;
        padding: 22px 18px;
        border-radius: 12px;
        max-width: calc(100% - 24px);
        box-sizing: border-box;
    }

    #customer_login .womenmatic-extra-fields {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    #customer_login .womenmatic-extra-fields > .form-row-first,
    #customer_login .womenmatic-extra-fields > .form-row-last {
        grid-column: 1;
    }

    #customer_login ul.wc-tabs {
        margin-bottom: 20px !important;
    }

    #customer_login ul.wc-tabs li.tab-link {
        padding: 10px 14px;
        font-size: 14px;
        flex: 1;
        text-align: center;
    }

    #customer_login button[type="submit"] {
        width: 100% !important;
        padding: 12px 20px !important;
    }

    /* Login submit row: stack rememberme + button on narrow viewports      */
    #customer_login form.woocommerce-form-login .form-row:not(.form-row-wide):not(.form-row-first):not(.form-row-last) {
        flex-direction: column;
        align-items: stretch;
        gap: 14px;
    }

    #customer_login .woocommerce-form-wrapper > h2 {
        font-size: 20px !important;
        margin-bottom: 16px !important;
    }

    #customer_login input[type="text"],
    #customer_login input[type="email"],
    #customer_login input[type="tel"],
    #customer_login input[type="password"],
    #customer_login input.input-text {
        font-size: 16px !important; /* prevents iOS zoom on focus */
        padding: 10px 12px !important;
    }

    #customer_login .woocommerce-form__label-for-checkbox {
        font-size: 13px !important;
        line-height: 1.4;
    }
}

/* Very narrow (iPhone SE ~320px) */
@media (max-width: 360px) {
    body.woocommerce-account #customer_login {
        margin: 12px 8px;
        padding: 18px 14px;
        max-width: calc(100% - 16px);
    }

    #customer_login ul.wc-tabs li.tab-link {
        padding: 10px 8px;
        font-size: 13px;
    }

    #customer_login .woocommerce-form-wrapper > h2 {
        font-size: 18px !important;
    }
}
