/* ==========================================================================
   Custom WC Auth UI — Premium Edition
   Version: 5.0.0

   Design: Luxury-refined, frosted glass card on animated mesh gradient.
   Fonts: Playfair Display (headings) + DM Sans (body/UI)
   ========================================================================== */

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

:root {
    /* ── Brand ── */
    --cwcaui-primary:        #009898;
    --cwcaui-primary-dark:   #007a7a;
    --cwcaui-primary-light:  #00c2c2;
    --cwcaui-primary-glow:   rgba(0, 152, 152, .18);
    --cwcaui-primary-ultra:  rgba(0, 152, 152, .06);
    --cwcaui-secondary:      #ff6633;
    --cwcaui-secondary-dark: #e55a2b;

    /* ── Teal tints ── */
    --cwcaui-teal-5:  rgba(0, 152, 152, .05);
    --cwcaui-teal-10: rgba(0, 152, 152, .10);
    --cwcaui-teal-15: rgba(0, 152, 152, .15);
    --cwcaui-teal-25: rgba(0, 152, 152, .25);
    --cwcaui-teal-40: rgba(0, 152, 152, .40);

    /* ── Status ── */
    --cwcaui-success:      #10b981;
    --cwcaui-success-bg:   #ecfdf5;
    --cwcaui-success-text: #065f46;
    --cwcaui-error:        #ef4444;
    --cwcaui-error-bg:     #fef2f2;
    --cwcaui-error-text:   #991b1b;

    /* ── Neutrals ── */
    --cwcaui-white:    #ffffff;
    --cwcaui-gray-50:  #f9fafb;
    --cwcaui-gray-100: #f3f4f6;
    --cwcaui-gray-200: #e5e7eb;
    --cwcaui-gray-300: #d1d5db;
    --cwcaui-gray-400: #9ca3af;
    --cwcaui-gray-500: #6b7280;
    --cwcaui-gray-600: #4b5563;
    --cwcaui-gray-700: #374151;
    --cwcaui-gray-800: #1f2937;
    --cwcaui-black:    #111827;

    /* ── Typography ── */
    --cwcaui-font-display: 'Inter', system-ui, -apple-system, sans-serif;
    --cwcaui-font:         'Inter', system-ui, -apple-system, sans-serif;

    /* ── Radius ── */
    --cwcaui-radius:    6px;
    --cwcaui-radius-lg: 16px;
    --cwcaui-radius-xl: 10px;

    /* ── Shadows ── */
    --cwcaui-shadow-sm:   0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --cwcaui-shadow:      0 4px 16px rgba(0,0,0,.07), 0 2px 6px rgba(0,0,0,.05);
    --cwcaui-shadow-lg:   0 24px 64px rgba(0,0,0,.09), 0 8px 24px rgba(0,0,0,.06);
    --cwcaui-shadow-teal: 0 8px 32px rgba(0,152,152,.22);

    /* ── Transitions ── */
    --cwcaui-ease:     cubic-bezier(.4, 0, .2, 1);
    --cwcaui-spring:   cubic-bezier(.34, 1.56, .64, 1);
    --cwcaui-duration: .3s;
}

/* ── Reset ──────────────────────────────────────────────────────────────── */
.cwcaui-auth-wrapper,
.cwcaui-auth-wrapper *,
.cwcaui-auth-wrapper *::before,
.cwcaui-auth-wrapper *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

/* ==========================================================================
   WRAPPER — Animated mesh-gradient canvas
   ========================================================================== */
.cwcaui-auth-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    min-height: 100vh;
    font-family: var(--cwcaui-font);
    color: var(--cwcaui-gray-800);
    line-height: 1.6;
    padding: 52px 24px 72px !important;
    position: relative;
    overflow-x: hidden;
    background-color: #edf5f5;
    background-image:
        radial-gradient(ellipse 80% 55% at 8% -8%,   rgba(0,152,152,.14) 0%, transparent 55%),
        radial-gradient(ellipse 60% 40% at 95%  4%,  rgba(0,194,194,.09) 0%, transparent 45%),
        radial-gradient(ellipse 70% 65% at 50% 110%, rgba(0,152,152,.10) 0%, transparent 60%),
        radial-gradient(ellipse 40% 30% at 78% 78%,  rgba(0,122,122,.08) 0%, transparent 50%),
        linear-gradient(162deg, #eef9f9 0%, #f5fbfb 42%, #fafffe 70%, #eef6f6 100%);
}

/* Floating ambient orbs */
.cwcaui-auth-wrapper::before,
.cwcaui-auth-wrapper::after {
    content: '';
    position: fixed;
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.cwcaui-auth-wrapper::before {
    width: 700px;
    height: 700px;
    top: -220px;
    left: -220px;
    background: radial-gradient(circle, rgba(0,152,152,.07) 0%, transparent 70%);
    animation: cwcaui-orb 14s ease-in-out infinite;
}

.cwcaui-auth-wrapper::after {
    width: 560px;
    height: 560px;
    bottom: -160px;
    right: -160px;
    background: radial-gradient(circle, rgba(0,194,194,.06) 0%, transparent 70%);
    animation: cwcaui-orb 18s ease-in-out infinite reverse;
}

@keyframes cwcaui-orb {
    0%, 100% { transform: translate(0,   0)    scale(1);    }
    33%       { transform: translate(25px,-25px) scale(1.05); }
    66%       { transform: translate(-18px,18px) scale(.96); }
}

/* ── Logged-in fallback ─────────────────────────────────────────────────── */
.cwcaui-logged-in {
    font-family: var(--cwcaui-font);
    text-align: center;
    padding: 60px 24px;
    font-size: 16px;
    color: var(--cwcaui-gray-600);
}

.cwcaui-logged-in a { color: var(--cwcaui-primary); font-weight: 600; text-decoration: none; }
.cwcaui-logged-in a:hover { text-decoration: underline; }

/* ==========================================================================
   FORM CARD — Frosted glass panel
   ========================================================================== */
.cwcaui-form-card {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 456px;
    background: rgba(255, 255, 255, .84);
    backdrop-filter: blur(28px) saturate(1.5);
    -webkit-backdrop-filter: blur(28px) saturate(1.5);
    border: 1px solid rgba(255, 255, 255, .92);
    border-radius: var(--cwcaui-radius-xl);
    box-shadow:
        var(--cwcaui-shadow-lg),
        0 0 0 1px rgba(0,152,152,.07),
        inset 0 1px 0 rgba(255,255,255,.96);
    padding: 44px 48px 48px;
    text-align: center;
    animation: cwcaui-cardIn .6s var(--cwcaui-ease) both;
}

@keyframes cwcaui-cardIn {
    from { opacity: 0; transform: translateY(28px) scale(.975); }
    to   { opacity: 1; transform: translateY(0)    scale(1);    }
}

/* Decorative teal accent bar at top */
.cwcaui-form-card::before {
    content: '';
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    width: 60%; height: 3px;
    background: linear-gradient(90deg, var(--cwcaui-primary-light), var(--cwcaui-primary));
    border-radius: 0 0 4px 4px;
}

/* Subtle inner bottom glow */
.cwcaui-form-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 50%;
    transform: translateX(-50%);
    width: 80%; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(0,152,152,.15), transparent);
}

/* Transparent WC wrappers */
.cwcaui-auth-wrapper .woocommerce,
.cwcaui-auth-wrapper .woocommerce-form,
.cwcaui-auth-wrapper .woocommerce-form-login,
.cwcaui-auth-wrapper .woocommerce-form-register,
.cwcaui-auth-wrapper .woocommerce-ResetPassword,
.cwcaui-auth-wrapper form {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    width: 100% !important;
}

/* ── Logo Area ──────────────────────────────────────────────────────────── */
.cwcaui-logo-area {
    margin-bottom: 30px;
    text-align: center;
}

.cwcaui-logo-link {
    display: inline-block;
    transition: opacity .22s var(--cwcaui-ease);
}

.cwcaui-logo-link:hover { opacity: .8; }

.cwcaui-logo {
    max-height: 46px;
    width: auto;
}

.cwcaui-site-title {
    font-family: var(--cwcaui-font-display);
    font-size: 30px;
    font-weight: 600;
    letter-spacing: -.5px;
    color: var(--cwcaui-primary);
}

/* ── Notices ─────────────────────────────────────────────────────────────── */
.cwcaui-notices {
    margin-bottom: 0;
    text-align: left;
    width: 100%;
}

.cwcaui-notices:empty,
.cwcaui-notices:has(> :empty) { display: none; }

.cwcaui-notices .woocommerce-message,
.cwcaui-notices .woocommerce-info,
.cwcaui-notices .woocommerce-error {
    padding: 13px 16px 13px 46px !important;
    font-size: 13.5px;
    line-height: 1.5;
    border-radius: var(--cwcaui-radius);
    margin: 0 0 22px 0 !important;
    position: relative;
    border: none !important;
    box-shadow: var(--cwcaui-shadow-sm);
}

.cwcaui-notices .woocommerce-message {
    background: var(--cwcaui-success-bg) !important;
    color: var(--cwcaui-success-text) !important;
    border-left: 3px solid var(--cwcaui-success) !important;
}

.cwcaui-notices .woocommerce-message::before {
    content: "";
    position: absolute; left: 15px; top: 14px;
    width: 18px; height: 18px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23065f46' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center/contain;
}

.cwcaui-notices .woocommerce-info {
    background: rgba(0,152,152,.07) !important;
    color: var(--cwcaui-primary-dark) !important;
    border-left: 3px solid var(--cwcaui-primary) !important;
}

.cwcaui-notices .woocommerce-info::before {
    content: "";
    position: absolute; left: 15px; top: 14px;
    width: 18px; height: 18px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23009898' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='16' x2='12' y2='12'/%3E%3Cline x1='12' y1='8' x2='12.01' y2='8'/%3E%3C/svg%3E") no-repeat center/contain;
}

.cwcaui-notices .woocommerce-error {
    background: var(--cwcaui-error-bg) !important;
    color: var(--cwcaui-error-text) !important;
    border-left: 3px solid var(--cwcaui-error) !important;
    list-style: none !important;
}

.cwcaui-notices .woocommerce-error::before {
    content: "";
    position: absolute; left: 15px; top: 14px;
    width: 18px; height: 18px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23991b1b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='15' y1='9' x2='9' y2='15'/%3E%3Cline x1='9' y1='9' x2='15' y2='15'/%3E%3C/svg%3E") no-repeat center/contain;
}

.cwcaui-notices .woocommerce-error li,
.cwcaui-notices ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* ── Form Sections ──────────────────────────────────────────────────────── */
.cwcaui-form-section {
    display: none;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity var(--cwcaui-duration) var(--cwcaui-ease),
                transform var(--cwcaui-duration) var(--cwcaui-ease);
    will-change: opacity, transform;
    text-align: left;
}

.cwcaui-form-section--active {
    display: block;
    opacity: 1;
    transform: translateY(0);
    width: 100%;
}

/* ── Form Header ────────────────────────────────────────────────────────── */
.cwcaui-form-header {
    text-align: center;
    margin-bottom: 30px;
}

.cwcaui-form-title {
    font-family: var(--cwcaui-font-display);
    font-size: 25px;
    font-weight: 600;
    color: var(--cwcaui-black);
    letter-spacing: -.2px;
    margin-bottom: 0;
    line-height: 1.25;
}

.cwcaui-form-subtitle {
    font-size: 14px;
    color: var(--cwcaui-gray-500);
    font-weight: 400;
    margin-top: 8px;
    line-height: 1.6;
}

/* Teal underline accent after title block */
.cwcaui-form-header::after {
    content: '';
    display: block;
    width: 28px; height: 2px;
    background: linear-gradient(90deg, var(--cwcaui-primary), var(--cwcaui-primary-light));
    border-radius: 2px;
    margin: 14px auto 0;
}

/* ── Field Groups ───────────────────────────────────────────────────────── */
.cwcaui-field-group {
    margin-bottom: 16px;
    position: relative;
    width: 100%;
}

#cwcaui-auth-wrapper .cwcaui-input-wrapper {
    position: relative !important;
    width: 100% !important;
    display: block !important;
}

/* Labels */
.cwcaui-label {
    display: block;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .65px;
    text-transform: uppercase;
    color: var(--cwcaui-gray-500);
    margin-bottom: 7px;
}

/* ── Inputs ─────────────────────────────────────────────────────────────── */
#cwcaui-auth-wrapper .cwcaui-input {
    width: 100% !important;
    padding: 13px 18px;
    font-family: var(--cwcaui-font);
    font-size: 15px;
    font-weight: 400;
    letter-spacing: .1px;
    color: var(--cwcaui-gray-800);
    background: rgba(255, 255, 255, .72);
    border: 1.5px solid var(--cwcaui-gray-200);
    border-radius: var(--cwcaui-radius);
    outline: none;
    transition: border-color .2s var(--cwcaui-ease),
                box-shadow .2s var(--cwcaui-ease),
                background .2s var(--cwcaui-ease);
    -webkit-appearance: none;
    appearance: none;
    margin: 0 !important;
}

#cwcaui-auth-wrapper .cwcaui-input-wrapper .cwcaui-input,
#cwcaui-auth-wrapper input[type="password"] {
    padding-right: 48px !important;
}

.cwcaui-input::placeholder {
    color: var(--cwcaui-gray-400);
    font-weight: 400;
}

.cwcaui-input:hover {
    border-color: var(--cwcaui-gray-300);
    background: rgba(255, 255, 255, .92);
}

.cwcaui-input:focus,
.cwcaui-input:focus-visible {
    border-color: var(--cwcaui-primary);
    box-shadow: 0 0 0 3px rgba(0, 152, 152, .12);
    background: rgba(255, 255, 255, 1);
    outline: none;
}

.cwcaui-input.cwcaui-invalid {
    border-color: var(--cwcaui-error);
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .10);
}

.cwcaui-input.cwcaui-valid {
    border-color: var(--cwcaui-success);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, .08);
}

.cwcaui-error-msg {
    display: block;
    font-size: 12px;
    font-weight: 500;
    color: var(--cwcaui-error-text);
    margin-top: 6px;
    opacity: 0;
    transition: opacity .2s var(--cwcaui-ease);
    padding-left: 2px;
}

.cwcaui-error-msg--visible { opacity: 1; }

/* ── Field Helper ───────────────────────────────────────────────────────── */
.cwcaui-field-helper {
    margin-top: 8px;
    text-align: right;
}

.cwcaui-field-helper .cwcaui-link {
    font-size: 12.5px;
    opacity: .9;
}

.cwcaui-field-helper .cwcaui-link:hover { opacity: 1; }

/* ── Step Containers ────────────────────────────────────────────────────── */
.cwcaui-step {
    display: none;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity var(--cwcaui-duration) var(--cwcaui-ease),
                transform var(--cwcaui-duration) var(--cwcaui-ease);
    will-change: opacity, transform;
}

.cwcaui-step--active {
    display: block;
    opacity: 1;
    transform: translateY(0);
    animation: cwcaui-fadeIn .3s var(--cwcaui-ease) both;
    width: 100%;
}

.cwcaui-step-email-display {
    font-size: 14px;
    color: var(--cwcaui-primary);
    font-weight: 500;
    margin-top: 4px;
    word-break: break-all;
}

/* ── Action Row ─────────────────────────────────────────────────────────── */
#cwcaui-auth-wrapper .cwcaui-action-row {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    margin-top: 22px !important;
    gap: 10px !important;
    width: 100% !important;
}

#cwcaui-auth-wrapper #cwcaui-step-password .cwcaui-action-row {
    justify-content: space-between !important;
}

/* ── Checkbox ───────────────────────────────────────────────────────────── */
.cwcaui-checkbox-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13.5px;
    color: var(--cwcaui-gray-600);
    cursor: pointer;
    white-space: nowrap;
}

.cwcaui-checkbox-label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--cwcaui-primary);
    cursor: pointer;
}

/* ── Back / "Not me" button ────────────────────────────────────────────── */
.cwcaui-back-link {
    background: transparent !important;
    color: var(--cwcaui-gray-500) !important;
    font-family: var(--cwcaui-font) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    transition: color .2s var(--cwcaui-ease) !important;
}

.cwcaui-back-link:hover {
    color: var(--cwcaui-primary) !important;
    text-decoration: none !important;
}

/* ── CTA Buttons ────────────────────────────────────────────────────────── */
.cwcaui-btn {
    font-family: var(--cwcaui-font);
    font-size: 14.5px;
    font-weight: 600;
    letter-spacing: .25px;
    border: none;
    border-radius: var(--cwcaui-radius);
    cursor: pointer;
    transition: all .22s var(--cwcaui-ease);
    text-align: center;
    line-height: 1;
    -webkit-appearance: none;
    appearance: none;
    position: relative;
    overflow: hidden;
}

/* Shimmer on hover */
.cwcaui-btn--primary::after {
    content: '';
    position: absolute;
    top: 0; left: -100%;
    width: 55%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
    transition: left .5s var(--cwcaui-ease);
    pointer-events: none;
}

.cwcaui-btn--primary:hover::after { left: 160%; }

/* Primary */
#cwcaui-auth-wrapper .cwcaui-btn--primary {
    padding: 13px 36px !important;
    background: linear-gradient(135deg, var(--cwcaui-primary) 0%, var(--cwcaui-primary-dark) 100%) !important;
    color: #ffffff !important;
    min-width: 110px !important;
    width: fit-content !important;
    box-shadow:
        0 4px 18px rgba(0,152,152,.28),
        0 1px 4px rgba(0,0,0,.08) !important;
    border: none !important;
}

#cwcaui-auth-wrapper .cwcaui-btn--primary:hover {
    background: linear-gradient(135deg, #00aaaa 0%, var(--cwcaui-primary) 100%) !important;
    box-shadow:
        0 6px 22px rgba(0,152,152,.36),
        0 2px 6px rgba(0,0,0,.10) !important;
    transform: translateY(-2px) !important;
}

#cwcaui-auth-wrapper .cwcaui-btn--primary:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 8px rgba(0,152,152,.2) !important;
}

/* Full-width variant */
.cwcaui-btn--wide {
    width: 100%;
    padding: 14px 28px;
    background: linear-gradient(135deg, var(--cwcaui-primary), var(--cwcaui-primary-dark));
    color: #ffffff;
    margin-top: 24px;
    box-shadow: 0 4px 16px rgba(0,152,152,.24);
}

.cwcaui-btn--wide:hover {
    background: linear-gradient(135deg, #00aaaa, var(--cwcaui-primary));
    box-shadow: 0 6px 20px rgba(0,152,152,.34);
    transform: translateY(-2px);
}

/* Loading / disabled */
.cwcaui-btn--loading,
.cwcaui-btn:disabled {
    opacity: .52;
    cursor: not-allowed;
    transform: none !important;
    box-shadow: none !important;
}

/* ── WooCommerce button overrides ──────────────────────────────────────── */
.cwcaui-auth-wrapper .woocommerce-button,
.cwcaui-auth-wrapper button[type="submit"],
.cwcaui-auth-wrapper input[type="submit"] {
    font-family: var(--cwcaui-font) !important;
    font-size: 14.5px !important;
    font-weight: 600 !important;
    letter-spacing: .25px !important;
    border-radius: var(--cwcaui-radius) !important;
    cursor: pointer !important;
    transition: all .22s var(--cwcaui-ease) !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    background: linear-gradient(135deg, var(--cwcaui-primary), var(--cwcaui-primary-dark)) !important;
    color: #ffffff !important;
    border: none !important;
}

.cwcaui-auth-wrapper .woocommerce-button:hover,
.cwcaui-auth-wrapper button[type="submit"]:hover,
.cwcaui-auth-wrapper input[type="submit"]:hover {
    background: linear-gradient(135deg, #00aaaa, var(--cwcaui-primary)) !important;
    transform: translateY(-2px) !important;
}

/* ── Password Strength Meter ─────────────────────────────────────────── */
.woocommerce-password-strength {
    text-align: left;
    font-size: 12px;
    margin-top: 8px;
    padding: 8px 12px;
    border-radius: var(--cwcaui-radius);
    font-weight: 500;
}

.woocommerce-password-strength.short,
.woocommerce-password-strength.bad {
    background-color: var(--cwcaui-error-bg) !important;
    color: var(--cwcaui-error-text) !important;
    border-left: 3px solid var(--cwcaui-error);
}

.woocommerce-password-strength.good {
    background-color: rgba(0,152,152,.08) !important;
    color: var(--cwcaui-primary-dark) !important;
    border-left: 3px solid var(--cwcaui-primary);
}

.woocommerce-password-strength.strong {
    background-color: var(--cwcaui-success-bg) !important;
    color: var(--cwcaui-success-text) !important;
    border-left: 3px solid var(--cwcaui-success);
}

.woocommerce-password-hint {
    font-size: 12px;
    color: var(--cwcaui-gray-400);
    margin-top: 6px;
    display: block;
    line-height: 1.4;
}

/* ── Hide WC native password toggle ───────────────────────────────────── */
.cwcaui-auth-wrapper .show-password-input,
.cwcaui-auth-wrapper .wp-hide-pw,
.cwcaui-auth-wrapper .woocommerce-form-login .show-password-input {
    display: none !important;
}

/* ── Links ──────────────────────────────────────────────────────────────── */
.cwcaui-auth-wrapper a,
.cwcaui-link {
    font-size: 13.5px;
    font-weight: 500;
    color: var(--cwcaui-primary) !important;
    text-decoration: none !important;
    transition: color .2s var(--cwcaui-ease);
}

.cwcaui-auth-wrapper a:hover,
.cwcaui-link:hover,
.cwcaui-link:focus-visible {
    color: var(--cwcaui-primary-dark) !important;
    text-decoration: underline !important;
}

/* ── Info Text ──────────────────────────────────────────────────────────── */
.cwcaui-info-text {
    margin-top: 26px;
    font-size: 13.5px;
    color: var(--cwcaui-gray-500);
    line-height: 1.6;
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid rgba(0,0,0,.07);
}

/* ── Form Footer ────────────────────────────────────────────────────────── */
.cwcaui-form-footer {
    text-align: center;
    margin-top: 22px;
    font-size: 13.5px;
    color: var(--cwcaui-gray-500);
    padding-top: 20px;
    border-top: 1px solid rgba(0,0,0,.07);
}

/* ── Privacy Policy ─────────────────────────────────────────────────────── */
.cwcaui-privacy-policy {
    font-size: 12.5px;
    color: var(--cwcaui-gray-400);
    margin-bottom: 16px;
    line-height: 1.6;
    text-align: center;
    background: var(--cwcaui-gray-50);
    border-radius: var(--cwcaui-radius);
    padding: 10px 14px;
}

.cwcaui-privacy-policy:empty { display: none; }
.cwcaui-privacy-policy a { color: var(--cwcaui-primary); text-decoration: underline; }

/* ── Password Toggle Icon ───────────────────────────────────────────────── */
#cwcaui-auth-wrapper .cwcaui-pw-toggle {
    position: absolute !important;
    right: 14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin: 0 !important;
    color: var(--cwcaui-gray-400) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: color .18s var(--cwcaui-ease) !important;
    width: 22px !important;
    height: 22px !important;
    z-index: 10 !important;
}

#cwcaui-auth-wrapper .cwcaui-pw-toggle:hover {
    color: var(--cwcaui-primary) !important;
}

.cwcaui-eye-icon {
    display: block;
    width: 18px !important;
    height: 18px !important;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 600px) {
    .cwcaui-auth-wrapper {
        padding: 28px 16px 44px !important;
    }

    .cwcaui-form-card {
        max-width: 100%;
        padding: 32px 24px 36px;
        border-radius: var(--cwcaui-radius-lg);
    }

    .cwcaui-logo { max-height: 40px; }
    .cwcaui-form-title { font-size: 22px; }

    .cwcaui-input {
        padding: 13px 16px;
        font-size: 15px;
    }

    .cwcaui-field-helper { text-align: center; margin-top: 10px; }

    .cwcaui-action-row {
        flex-direction: column;
        align-items: stretch !important;
        gap: 12px;
    }

    #cwcaui-auth-wrapper .cwcaui-btn,
    #cwcaui-auth-wrapper .woocommerce-button,
    #cwcaui-auth-wrapper button[type="submit"],
    #cwcaui-auth-wrapper .cwcaui-btn--primary,
    #cwcaui-auth-wrapper .cwcaui-input {
        display: block !important;
        box-sizing: border-box !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 auto !important;
        float: none !important;
    }

    .cwcaui-back-link { width: auto !important; align-self: center !important; }
}

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */
@keyframes cwcaui-fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0);   }
}

.cwcaui-form-section--active {
    animation: cwcaui-fadeIn .35s var(--cwcaui-ease) both;
}

/* Staggered field entry */
.cwcaui-form-section--active .cwcaui-field-group {
    animation: cwcaui-fadeIn .32s var(--cwcaui-ease) both;
}
.cwcaui-form-section--active .cwcaui-field-group:nth-child(1) { animation-delay: .04s; }
.cwcaui-form-section--active .cwcaui-field-group:nth-child(2) { animation-delay: .09s; }
.cwcaui-form-section--active .cwcaui-field-group:nth-child(3) { animation-delay: .14s; }
.cwcaui-form-section--active .cwcaui-field-group:nth-child(4) { animation-delay: .18s; }

/* ==========================================================================
   ACCESSIBILITY — Reduced Motion
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    .cwcaui-auth-wrapper::before,
    .cwcaui-auth-wrapper::after { animation: none !important; }
    .cwcaui-form-card            { animation: none !important; }
    .cwcaui-form-section,
    .cwcaui-step,
    .cwcaui-input,
    .cwcaui-btn,
    .cwcaui-link,
    .cwcaui-error-msg { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

/* ── Hide WC account navigation on login page ───────────────────────────── */
.woocommerce-account .cwcaui-auth-wrapper ~ .woocommerce-MyAccount-navigation,
.woocommerce-account .cwcaui-auth-wrapper ~ .woocommerce-MyAccount-content {
    display: none;
}

/* ── Focus ring ─────────────────────────────────────────────────────────── */
.cwcaui-auth-wrapper :focus-visible {
    outline: 2px dashed var(--cwcaui-primary);
    outline-offset: 3px;
}
