/* SimpleSuite Identity — Auth & Profile UI
   Theme-aware via CSS custom properties on .ssi-auth-wrapper[data-ssi-theme].
   Admin selects theme in Identity > Settings > General.
   SS spec: no border-radius, inline SVG only.
   Themes: neutral (default), ask, warm, slate
*/

/* ── Neutral (default) ── */
.ssi-auth-wrapper,
.ssi-auth-wrapper[data-ssi-theme="neutral"] {
    --ssi-card-bg:#fff;--ssi-card-border:#e0e3e8;--ssi-card-shadow:rgba(0,0,0,.04);
    --ssi-text:#1a1d23;--ssi-text-muted:#6b7280;--ssi-text-hint:#9ca3af;
    --ssi-accent:#2563eb;--ssi-accent-hover:#1d4ed8;--ssi-accent-ring:rgba(37,99,235,.15);--ssi-accent-text:#fff;
    --ssi-input-border:#cbd5e1;--ssi-input-bg:#fff;
    --ssi-tab-bg:#f4f5f7;--ssi-tab-active-bg:#fff;--ssi-tab-text:#6b7280;--ssi-tab-active-text:#1a1d23;--ssi-tab-border:#e0e3e8;
    --ssi-link:#2563eb;
    --ssi-danger:#dc2626;--ssi-danger-bg:#fef2f2;--ssi-danger-border:#fecaca;
    --ssi-success:#059669;--ssi-success-bg:#ecfdf5;--ssi-success-border:#a7f3d0;
    --ssi-info-bg:#eff6ff;--ssi-info-border:#bfdbfe;--ssi-info-text:#1d4ed8;
    --ssi-avatar-bg:#e0e7ef;--ssi-avatar-text:#475569;
}
/* ── ASK System (dark) ── */
.ssi-auth-wrapper[data-ssi-theme="ask"] {
    --ssi-card-bg:#242a3d;--ssi-card-border:#343b52;--ssi-card-shadow:rgba(0,0,0,.2);
    --ssi-text:#e8eaf0;--ssi-text-muted:#9ca3b8;--ssi-text-hint:#6b7490;
    --ssi-accent:#d4a843;--ssi-accent-hover:#c49a38;--ssi-accent-ring:rgba(212,168,67,.2);--ssi-accent-text:#1a1d23;
    --ssi-input-border:#3e4560;--ssi-input-bg:#1e2438;
    --ssi-tab-bg:#1e2438;--ssi-tab-active-bg:#242a3d;--ssi-tab-text:#6b7490;--ssi-tab-active-text:#e8eaf0;--ssi-tab-border:#343b52;
    --ssi-link:#d4a843;
    --ssi-danger:#f87171;--ssi-danger-bg:#3b1c1c;--ssi-danger-border:#7f1d1d;
    --ssi-success:#34d399;--ssi-success-bg:#1a3329;--ssi-success-border:#065f46;
    --ssi-info-bg:#1e2d42;--ssi-info-border:#1e40af;--ssi-info-text:#93c5fd;
    --ssi-avatar-bg:#343b52;--ssi-avatar-text:#9ca3b8;
}
/* ── Warm ── */
.ssi-auth-wrapper[data-ssi-theme="warm"] {
    --ssi-card-bg:#fff;--ssi-card-border:#e5dfd6;--ssi-card-shadow:rgba(120,90,50,.06);
    --ssi-text:#2c2418;--ssi-text-muted:#7a6e5e;--ssi-text-hint:#a89c8c;
    --ssi-accent:#b45309;--ssi-accent-hover:#92400e;--ssi-accent-ring:rgba(180,83,9,.15);--ssi-accent-text:#fff;
    --ssi-input-border:#d6cfc4;--ssi-input-bg:#fffefb;
    --ssi-tab-bg:#f5f0e8;--ssi-tab-active-bg:#fff;--ssi-tab-text:#a89c8c;--ssi-tab-active-text:#2c2418;--ssi-tab-border:#e5dfd6;
    --ssi-link:#b45309;
    --ssi-danger:#dc2626;--ssi-danger-bg:#fef2f2;--ssi-danger-border:#fecaca;
    --ssi-success:#059669;--ssi-success-bg:#ecfdf5;--ssi-success-border:#a7f3d0;
    --ssi-info-bg:#fef9ee;--ssi-info-border:#fde68a;--ssi-info-text:#92400e;
    --ssi-avatar-bg:#f0e8db;--ssi-avatar-text:#7a6e5e;
}
/* ── Slate ── */
.ssi-auth-wrapper[data-ssi-theme="slate"] {
    --ssi-card-bg:#fff;--ssi-card-border:#cbd5e1;--ssi-card-shadow:rgba(0,0,0,.05);
    --ssi-text:#0f172a;--ssi-text-muted:#64748b;--ssi-text-hint:#94a3b8;
    --ssi-accent:#7c3aed;--ssi-accent-hover:#6d28d9;--ssi-accent-ring:rgba(124,58,237,.15);--ssi-accent-text:#fff;
    --ssi-input-border:#cbd5e1;--ssi-input-bg:#fff;
    --ssi-tab-bg:#f1f5f9;--ssi-tab-active-bg:#fff;--ssi-tab-text:#94a3b8;--ssi-tab-active-text:#0f172a;--ssi-tab-border:#cbd5e1;
    --ssi-link:#7c3aed;
    --ssi-danger:#dc2626;--ssi-danger-bg:#fef2f2;--ssi-danger-border:#fecaca;
    --ssi-success:#059669;--ssi-success-bg:#ecfdf5;--ssi-success-border:#a7f3d0;
    --ssi-info-bg:#f5f3ff;--ssi-info-border:#c4b5fd;--ssi-info-text:#5b21b6;
    --ssi-avatar-bg:#e2e8f0;--ssi-avatar-text:#64748b;
}

/* ═══ CARD ═══ */
/* Specificity-bumped via doubled class to beat block theme width overrides
   (e.g. Twenty Twenty-Four sets width:100% on .wp-block-group descendants).
   Box-sizing + width:100% lets it shrink below 640px on narrow viewports. */
.ssi-auth-wrapper.ssi-auth-wrapper,
.ask-auth-wrapper.ask-auth-wrapper{box-sizing:border-box;width:100%;max-width:640px;margin:2rem auto;background:var(--ssi-card-bg);border:1px solid var(--ssi-card-border);box-shadow:0 2px 10px var(--ssi-card-shadow);color:var(--ssi-text);overflow:hidden}

/* ═══ TABS ═══ */
.ssi-auth-tabs{display:flex;border-bottom:2px solid var(--ssi-tab-border)}
.ssi-auth-tab{flex:1;padding:.9rem 1rem;text-align:center;font-weight:600;font-size:.95rem;letter-spacing:.03em;color:var(--ssi-tab-text);background:var(--ssi-tab-bg);border:none;cursor:pointer;position:relative;transition:color .15s,background .15s}
.ssi-auth-tab:hover{color:var(--ssi-tab-active-text)}
.ssi-auth-tab.active{color:var(--ssi-tab-active-text);background:var(--ssi-tab-active-bg)}
.ssi-auth-tab.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--ssi-accent)}

/* ═══ BODY ═══ */
.ssi-auth-body{padding:1.75rem 2.25rem 2rem}
.ssi-auth-panel{display:none}.ssi-auth-panel.active{display:block}

/* ═══ HEADINGS ═══ */
.ssi-title,.ssi-auth-heading,.ask-title{font-weight:700;letter-spacing:.01em;margin:0 0 .25rem;font-size:1.3rem;line-height:1.3;color:var(--ssi-text)}
.ssi-auth-subtitle{font-size:.9rem;color:var(--ssi-text-muted);margin-bottom:1.5rem;line-height:1.4}

/* ═══ FIELDS ═══ */
.ssi-field{margin-bottom:1.15rem}
.ssi-label{display:block;font-weight:500;margin-bottom:.3rem;color:var(--ssi-text);font-size:.88rem}
.ssi-label .ssi-req{color:var(--ssi-danger);margin-left:2px}
.ssi-input{width:100%;border:1px solid var(--ssi-input-border);padding:.65rem .85rem;font-size:.95rem;line-height:1.3;box-sizing:border-box;background:var(--ssi-input-bg);color:var(--ssi-text);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.ssi-input:focus{outline:none;border-color:var(--ssi-accent);box-shadow:0 0 0 3px var(--ssi-accent-ring)}
.ssi-input-hint{font-size:.78rem;color:var(--ssi-text-hint);margin-top:.25rem}
.ssi-name-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}

/* ═══ PASSWORD ═══ */
.ssi-input-group{display:flex;position:relative}
.ssi-input-group .ssi-input{flex:1;padding-right:2.75rem}
.ssi-pw-toggle{position:absolute;right:0;top:0;bottom:0;width:2.5rem;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--ssi-text-hint);transition:color .15s}
.ssi-pw-toggle:hover{color:var(--ssi-text)}
.ssi-pw-strength{display:flex;gap:3px;margin-top:.4rem}
.ssi-pw-bar{flex:1;height:3px;background:var(--ssi-input-border);transition:background .25s}
.ssi-pw-bar.ssi-str-1{background:#ef4444}.ssi-pw-bar.ssi-str-2{background:#f59e0b}.ssi-pw-bar.ssi-str-3{background:#10b981}.ssi-pw-bar.ssi-str-4{background:#059669}
.ssi-pw-strength-label{font-size:.75rem;margin-top:.15rem;color:var(--ssi-text-hint)}

/* ═══ CHECKBOX ═══ */
.ssi-checkbox{display:flex;align-items:center;gap:.5rem;margin:1rem 0}
.ssi-check-input{width:16px;height:16px;accent-color:var(--ssi-accent)}
.ssi-check-label{font-size:.9rem;color:var(--ssi-text-muted);cursor:pointer}

/* ═══ BUTTONS ═══ */
.ssi-btn{display:inline-block;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;font-size:.95rem;line-height:1.2;text-decoration:none;text-align:center;border:1px solid transparent;transition:background .15s,color .15s,border-color .15s;letter-spacing:.02em}
.ssi-btn-primary{background:var(--ssi-accent);border-color:var(--ssi-accent);color:var(--ssi-accent-text)}
.ssi-btn-primary:hover{background:var(--ssi-accent-hover);border-color:var(--ssi-accent-hover);color:var(--ssi-accent-text);text-decoration:none}
.ssi-btn-outline{background:transparent;border-color:var(--ssi-input-border);color:var(--ssi-text-muted)}
.ssi-btn-outline:hover{background:var(--ssi-tab-bg);color:var(--ssi-text);text-decoration:none}
.ssi-btn-full{width:100%;margin-top:.5rem}
.ssi-btn:disabled{opacity:.55;cursor:not-allowed}
.ssi-btn-group{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap}

/* ═══ LINKS ═══ */
.ssi-auth-links{margin-top:1rem;text-align:center;font-size:.88rem}
.ssi-auth-divider{margin:0 .5rem;opacity:.4}
.ssi-auth-links a{color:var(--ssi-link);text-decoration:none}
.ssi-auth-links a:hover{text-decoration:underline}

/* ═══ ALERTS ═══ */
.ssi-alert{padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4;display:flex;align-items:flex-start;gap:.65rem}
.ssi-alert svg{flex-shrink:0;margin-top:1px}
.ssi-alert-danger{background:var(--ssi-danger-bg);border:1px solid var(--ssi-danger-border);color:var(--ssi-danger)}
.ssi-alert-success{background:var(--ssi-success-bg);border:1px solid var(--ssi-success-border);color:var(--ssi-success)}

/* ═══ RETURNING HINT ═══ */
.ssi-returning-hint{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;margin-bottom:1.15rem;background:var(--ssi-info-bg);border:1px solid var(--ssi-info-border);color:var(--ssi-info-text);font-size:.82rem;line-height:1.35}
.ssi-returning-hint svg{flex-shrink:0}

/* ═══ SESSION EXPIRED ═══ */
.ssi-session-expired{text-align:center;padding:1rem 0 1.25rem;border-bottom:1px solid var(--ssi-card-border);margin-bottom:1.25rem}
.ssi-session-expired svg{margin-bottom:.4rem}
.ssi-session-expired p{font-size:.9rem;color:var(--ssi-text-muted);margin:0;line-height:1.4}

/* ═══ LOGGED-IN STATE ═══ */
.ssi-logged-in-state{text-align:center;padding:1.5rem 0}
.ssi-avatar-circle{width:64px;height:64px;background:var(--ssi-avatar-bg);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.5rem;font-weight:700;color:var(--ssi-avatar-text)}
.ssi-logged-in-state h4{font-size:1.1rem;margin-bottom:.15rem}
.ssi-logged-in-state .ssi-role{font-size:.82rem;color:var(--ssi-text-hint);margin-bottom:1.25rem}

/* ═══ LOGOUT BANNER ═══ */
#ssi-logout-banner{max-width:520px;margin:0 auto 1rem;padding:.75rem 1rem .75rem 14px;background:var(--ssi-info-bg,#eff6ff);border:1px solid var(--ssi-info-border,#bfdbfe);color:var(--ssi-info-text,#1d4ed8);font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem;position:relative}
#ssi-logout-banner-close{position:absolute;right:10px;top:8px;border:0;background:transparent;font-size:18px;line-height:1;cursor:pointer;color:inherit;opacity:.6}
#ssi-logout-banner-close:hover{opacity:1}

/* ═══ HOME LINK (session expired) ═══ */
.ssi-auth-links-home{margin-top:.5rem;padding-top:.65rem;border-top:1px solid var(--ssi-card-border)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:560px){
    .ssi-auth-wrapper.ssi-auth-wrapper,.ask-auth-wrapper.ask-auth-wrapper{max-width:100%;margin:1rem auto}
    .ssi-auth-body{padding:1.25rem 1.25rem 1.5rem}
    .ssi-name-row{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   PROFILE EDITOR (block + shortcode)
   ══════════════════════════════════════════════════════ */
.ssi-profile-editor-block{width:100%;margin:0}
.ssi-completion-banner{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;margin-bottom:1.5rem;background:#fffbeb;border:1px solid #fde68a}
.ssi-completion-banner-icon{flex-shrink:0;color:#d97706;margin-top:1px}
.ssi-completion-banner-body{flex:1;min-width:0}
.ssi-completion-banner-title{font-size:.9rem;font-weight:600;color:#92400e;margin-bottom:.25rem}
.ssi-completion-banner-text{font-size:.85rem;color:#a16207;line-height:1.5}
.ssi-completion-banner-text strong{color:#92400e}
.ssi-completion-meter{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}
.ssi-completion-meter-track{flex:1;height:4px;background:#fde68a;overflow:hidden}
.ssi-completion-meter-fill{height:100%;background:#d97706;transition:width .4s ease}
.ssi-completion-meter-label{font-size:.8rem;font-weight:600;color:#d97706;white-space:nowrap}
.ssi-completion-banner.ssi-complete{background:#ecfdf5;border-color:#a7f3d0}
.ssi-complete .ssi-completion-banner-icon{color:#059669}
.ssi-complete .ssi-completion-banner-title{color:#065f46}
.ssi-complete .ssi-completion-banner-text{color:#047857}
.ssi-complete .ssi-completion-meter-track{background:#a7f3d0}
.ssi-complete .ssi-completion-meter-fill{background:#059669}
.ssi-complete .ssi-completion-meter-label{color:#059669}
.ssi-completion-dismiss{background:none;border:none;font-size:1.1rem;line-height:1;cursor:pointer;color:#a16207;opacity:.6;padding:0;flex-shrink:0}
.ssi-completion-dismiss:hover{opacity:1}
.ssi-complete .ssi-completion-dismiss{color:#047857}
.ssi-info-form{display:flex;flex-direction:column;gap:0}
.ssi-info-section{border:1px solid #e5e7eb;padding:1.5rem;margin-bottom:1rem;background:#fff}
.ssi-info-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}
.ssi-info-section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#64748b;margin:0;padding:0;line-height:1.3}
.ssi-info-identity{display:grid;grid-template-columns:88px 1fr;gap:1.5rem;align-items:start}
@media(max-width:480px){.ssi-info-identity{grid-template-columns:1fr;justify-items:center}.ssi-info-identity-fields{width:100%}}
.ssi-info-avatar{position:relative;width:88px;height:88px;cursor:pointer;flex-shrink:0;overflow:hidden}
.ssi-info-avatar-img{width:100%;height:100%;object-fit:cover;display:block}
.ssi-info-avatar-placeholder{width:100%;height:100%;background:#e2e8f0;display:flex;align-items:center;justify-content:center}
.ssi-info-avatar-placeholder span{font-size:1.75rem;font-weight:700;color:#64748b;line-height:1}
.ssi-info-avatar-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .2s ease}
.ssi-info-avatar:hover .ssi-info-avatar-overlay,.ssi-info-avatar:focus .ssi-info-avatar-overlay{opacity:1}
.ssi-info-avatar-hint{font-size:.75rem;color:#94a3b8;text-align:center;margin-top:.35rem}
.ssi-info-identity-fields{display:flex;flex-direction:column;gap:0}
.ssi-info-name-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:480px){.ssi-info-name-row{grid-template-columns:1fr}}
.ssi-info-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:540px){.ssi-info-row{grid-template-columns:1fr}}
.ssi-field-hint{display:block;margin-top:.2rem;font-size:.78rem;color:#94a3b8;text-align:right}
.ssi-field-error{display:block;margin-top:.2rem;font-size:.82rem;color:#dc2626}
.ssi-textarea{resize:vertical;min-height:72px;font-family:inherit}
.ssi-field-missing .ssi-input{border-color:#fbbf24;background:#fffdf7}
.ssi-field-missing .ssi-label::after{content:" \2014  needed";font-size:.75rem;font-weight:400;color:#d97706;font-style:italic}
.ssi-info-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;cursor:pointer;text-align:left;color:inherit;font:inherit}
.ssi-info-section-toggle:hover .ssi-info-section-title{color:#475569}
.ssi-toggle-indicator{font-size:.9rem;color:#94a3b8;transition:transform .2s ease;display:inline-block}
.ssi-toggle-indicator.ssi-toggle-open{transform:rotate(90deg)}
.ssi-info-pw-body{margin-top:1.25rem}
.ssi-input-action{display:flex;align-items:center;justify-content:center;width:38px;background:#f8fafc;border:1px solid #cbd5e1;border-left:none;cursor:pointer;color:#64748b;padding:0;transition:background .15s,color .15s;flex-shrink:0}
.ssi-input-action:hover{background:#e2e8f0;color:#334155}
.ssi-pw-meter{display:flex;align-items:center;gap:.75rem;margin-top:.4rem}
.ssi-pw-meter-track{flex:1;height:3px;background:#e2e8f0;overflow:hidden}
.ssi-pw-meter-fill{height:100%;transition:width .3s ease,background .3s ease}
.ssi-pw-meter-label{font-size:.78rem;font-weight:600;white-space:nowrap}
.ssi-info-actions{display:flex;justify-content:flex-end;margin-top:.25rem}
.ssi-btn-save{min-width:180px;padding:.65rem 1.5rem;font-size:.95rem}
.ssi-btn-save:disabled{opacity:.6;cursor:not-allowed}
.ssi-info-form .ssi-alert{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}
.ssi-alert-close{background:none;border:none;font-size:1.15rem;line-height:1;cursor:pointer;color:inherit;opacity:.5;padding:0;flex-shrink:0}
.ssi-alert-close:hover{opacity:1}
.ssi-info-loading{display:flex;flex-direction:column;align-items:center;padding:3rem 1rem}
.ssi-info-loading-spinner{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#3b82f6;animation:ssi-spin .7s linear infinite}
@keyframes ssi-spin{to{transform:rotate(360deg)}}
