/* ============================================================================
   REI9 — UNIFIED THEME STYLESHEET
   Loaded after style.css and any module <style> blocks. Scoped under
   body.theme-rei9 so it never affects mls9.com (different per-site copies).

   Strategy: override CSS custom properties at body level. Higher specificity
   than the modules' :root tokens, so every component that reads from those
   vars (header, footer, community, dashboard, login, etc.) reskins instantly.
   ============================================================================ */

/* ============================================================================
   1. DESIGN TOKENS — single source of truth for the REI9 brand
   ============================================================================ */
body.theme-rei9 {

    /* --- REI9 brand palette --- */
    --r9-violet:    #7c3aed;
    --r9-violet-2:  #a855f7;
    --r9-violet-d:  #6d28d9;
    --r9-pink:      #ec4899;
    --r9-cyan:      #22d3ee;
    --r9-orange:    #f97316;
    --r9-amber:     #fbbf24;
    --r9-green:     #22c55e;
    --r9-lime:      #84cc16;
    --r9-red:       #ef4444;
    --r9-ink:       #0f172a;
    --r9-text:      #1e293b;
    --r9-muted:     #64748b;
    --r9-faint:     #94a3b8;
    --r9-bg:        #f8fafc;
    --r9-bg-2:      #f1f5f9;
    --r9-surface:   #ffffff;
    --r9-border:    #e2e8f0;
    --r9-border-2:  #cbd5e1;

    /* --- Gradients --- */
    --r9-grad-primary: linear-gradient(120deg, #7c3aed 0%, #ec4899 100%);
    --r9-grad-cool:    linear-gradient(120deg, #06b6d4 0%, #7c3aed 100%);
    --r9-grad-warm:    linear-gradient(120deg, #f97316 0%, #fbbf24 100%);
    --r9-grad-hero:    linear-gradient(135deg, #4c1d95 0%, #1e1b4b 60%, #0f172a 100%);

    /* --- Geometry & motion --- */
    --r9-radius-sm:  10px;
    --r9-radius:     14px;
    --r9-radius-lg:  18px;
    --r9-radius-xl:  24px;
    --r9-shadow-sm:  0 2px 6px rgba(15,23,42,0.04);
    --r9-shadow:     0 6px 16px rgba(15,23,42,0.07);
    --r9-shadow-lg:  0 18px 36px rgba(15,23,42,0.10);
    --r9-shadow-glow: 0 8px 24px rgba(124,58,237,0.30);

    /* --- Override style.css tokens --- */
    --primary:           var(--r9-violet);
    --primary-dark:      var(--r9-violet-d);
    --primary-soft:      #f5f3ff;
    --secondary:         var(--r9-bg);
    --secondary-hover:   var(--r9-bg-2);
    --secondary-border:  var(--r9-border);
    --on-secondary:      var(--r9-ink);
    --on-secondary-muted:var(--r9-muted);
    --text-main:         var(--r9-ink);
    --text-muted:        var(--r9-muted);
    --bg-body:           var(--r9-bg);
    --bg-card:           var(--r9-surface);
    --border:            var(--r9-border);
    --success:           var(--r9-green);
    --warning:           var(--r9-amber);
    --danger:            var(--r9-red);
    --radius:            var(--r9-radius);
    --shadow:            var(--r9-shadow);

    /* --- Override header tokens --- */
    --hdr-brand:  var(--r9-violet);
    --hdr-brand-2:var(--r9-pink);
    --hdr-soft:   #f5f3ff;
    --hdr-ink:    var(--r9-ink);
    --hdr-muted:  var(--r9-muted);

    /* --- Override community module's --c-* tokens --- */
    --c-bg:             var(--r9-bg);
    --c-surface:        var(--r9-surface);
    --c-surface-2:      var(--r9-bg);
    --c-surface-3:      var(--r9-bg-2);
    --c-surface-hover:  var(--r9-bg-2);
    --c-border:         var(--r9-border);
    --c-border-soft:    #eef2f7;
    --c-text:           var(--r9-ink);
    --c-text-2:         var(--r9-text);
    --c-text-muted:     var(--r9-faint);
    --c-primary:        var(--r9-violet);
    --c-primary-hover:  var(--r9-violet-d);
    --c-primary-soft:   #f5f3ff;
    --c-primary-softer: #faf5ff;
    --c-success:        var(--r9-green);
    --c-success-soft:   #dcfce7;
    --c-warning:        var(--r9-orange);
    --c-warning-soft:   #fff7ed;
    --c-danger:         var(--r9-red);
    --c-danger-soft:    #fef2f2;
    --c-heart:          var(--r9-pink);
    --c-purple:         var(--r9-violet);
    --c-purple-soft:    #f5f3ff;
    --c-amber-soft:     #fffbeb;
    --c-radius-sm:      10px;
    --c-radius:         14px;
    --c-radius-lg:      18px;
    --c-shadow-sm:      var(--r9-shadow-sm);
    --c-shadow:         var(--r9-shadow);
    --c-shadow-lg:      var(--r9-shadow-lg);
}

/* ============================================================================
   2. PAGE BASELINE
   ============================================================================ */
body.theme-rei9 {
    background: var(--r9-bg);
    color: var(--r9-ink);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
    font-feature-settings: "cv02","cv03","cv04","cv11";
}
body.theme-rei9 h1,
body.theme-rei9 h2,
body.theme-rei9 h3,
body.theme-rei9 h4,
body.theme-rei9 h5 {
    letter-spacing: -0.01em;
}
body.theme-rei9 a { color: var(--r9-violet); }
body.theme-rei9 a:hover { color: var(--r9-violet-d); }

/* Selection */
body.theme-rei9 ::selection { background: rgba(124, 58, 237, 0.20); color: var(--r9-ink); }

/* ============================================================================
   3. HEADER — make it feel like part of the new REI9 product
   ============================================================================ */
body.theme-rei9 .site-header,
body.theme-rei9 header.site-header {
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    border-bottom: 1px solid var(--r9-border);
    box-shadow: 0 1px 0 rgba(15,23,42,.03);
}

/* Brand wordmark + logo treatment */
body.theme-rei9 .logo-link,
body.theme-rei9 .brand,
body.theme-rei9 .header-brand {
    background: var(--r9-grad-primary);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    font-weight: 900;
    letter-spacing: -0.02em;
}
/* If logo link contains an <img>, leave the gradient off — only style the wordmark */
body.theme-rei9 .logo-link:has(img) { background: none; -webkit-text-fill-color: initial; color: initial; }

/* Top icon links — pill hover */
body.theme-rei9 .nav-icon-link {
    border-radius: 12px;
    transition: background .15s, color .15s, transform .15s;
    color: var(--r9-text);
}
body.theme-rei9 .nav-icon-link:hover {
    background: var(--hdr-soft);
    color: var(--r9-violet);
    transform: translateY(-1px);
}

/* User avatar button gets a subtle gradient ring on hover */
body.theme-rei9 .user-avatar-btn {
    border-radius: 50%;
    transition: box-shadow .15s, transform .15s;
}
body.theme-rei9 .user-avatar-btn:hover {
    transform: scale(1.04);
    box-shadow: 0 0 0 3px rgba(124,58,237,.18);
}

/* Dropdown menu polish */
body.theme-rei9 .dropdown-menu {
    border-radius: var(--r9-radius-lg);
    border: 1px solid var(--r9-border);
    box-shadow: var(--r9-shadow-lg);
    overflow: hidden;
    padding: 8px;
}
body.theme-rei9 .dropdown-item {
    border-radius: 10px;
    transition: background .12s, color .12s;
    font-weight: 600;
    padding: 10px 12px;
}
body.theme-rei9 .dropdown-item:hover {
    background: var(--hdr-soft);
    color: var(--r9-violet);
}
body.theme-rei9 .dropdown-item i { transition: transform .15s; }
body.theme-rei9 .dropdown-item:hover i { transform: scale(1.12); }

/* ============================================================================
   4. BUTTONS — unify all CTAs across pages to pill+gradient
   ============================================================================ */
body.theme-rei9 .c-btn,
body.theme-rei9 .btn-primary,
body.theme-rei9 .hdr-auth-signup,
body.theme-rei9 button.primary,
body.theme-rei9 input[type="submit"]:not([class*="ghost"]):not([class*="secondary"]) {
    background: var(--r9-grad-primary);
    color: #fff;
    border: 0;
    border-radius: 999px;
    font-weight: 800;
    padding: 11px 22px;
    cursor: pointer;
    box-shadow: var(--r9-shadow-glow);
    transition: transform .15s, box-shadow .2s, filter .15s;
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 8px;
    font-size: .95rem;
}
body.theme-rei9 .c-btn:hover,
body.theme-rei9 .btn-primary:hover,
body.theme-rei9 .hdr-auth-signup:hover,
body.theme-rei9 button.primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 26px rgba(124,58,237,.40);
    filter: brightness(1.06);
}

/* Ghost / secondary buttons */
body.theme-rei9 .c-btn.c-btn-ghost,
body.theme-rei9 .btn-secondary,
body.theme-rei9 .hdr-auth-login {
    background: var(--r9-surface);
    color: var(--r9-violet);
    border: 1.5px solid var(--r9-border);
    box-shadow: none;
    border-radius: 999px;
    font-weight: 700;
    padding: 10px 20px;
    transition: background .15s, border-color .15s, color .15s;
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 8px;
}
body.theme-rei9 .c-btn.c-btn-ghost:hover,
body.theme-rei9 .btn-secondary:hover,
body.theme-rei9 .hdr-auth-login:hover {
    background: var(--hdr-soft);
    border-color: var(--r9-violet);
    color: var(--r9-violet-d);
}

/* ============================================================================
   5. CARDS / SURFACES — consistent radius, shadow, border across modules
   ============================================================================ */
body.theme-rei9 .c-card,
body.theme-rei9 .c-hero,
body.theme-rei9 .card,
body.theme-rei9 .panel,
body.theme-rei9 .module-card {
    border-radius: var(--r9-radius);
    border: 1px solid var(--r9-border);
    background: var(--r9-surface);
    box-shadow: var(--r9-shadow-sm);
    transition: transform .2s, box-shadow .2s, border-color .2s;
}

/* Community hero strip — give it a subtle gradient treatment */
body.theme-rei9 .c-hero {
    background:
        linear-gradient(120deg, rgba(124,58,237,0.06), rgba(236,72,153,0.04)),
        var(--r9-surface);
    border-radius: var(--r9-radius-lg);
    border: 1px solid var(--r9-border);
}
body.theme-rei9 .c-hero .brand {
    background: var(--r9-grad-primary);
    -webkit-background-clip: initial; background-clip: initial;
    -webkit-text-fill-color: initial; color: #fff;
    box-shadow: var(--r9-shadow-glow);
}

/* ============================================================================
   6. TABS — community module + any other tabbed UIs
   ============================================================================ */
body.theme-rei9 .c-tabs {
    background: var(--r9-surface);
    padding: 6px;
    border-radius: var(--r9-radius);
    border: 1px solid var(--r9-border);
    gap: 4px;
    box-shadow: var(--r9-shadow-sm);
}
body.theme-rei9 .c-tab {
    border-radius: 10px;
    font-weight: 700;
    transition: all .15s;
    color: var(--r9-text);
}
body.theme-rei9 .c-tab.active {
    background: var(--r9-grad-primary);
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(124,58,237,.30);
}
body.theme-rei9 .c-tab.active i { color: #fff !important; }
body.theme-rei9 .c-tab:not(.active):hover {
    background: var(--hdr-soft);
    color: var(--r9-violet);
}

/* ============================================================================
   7. PILLS / CHIPS / BADGES
   ============================================================================ */
body.theme-rei9 .c-pill {
    border-radius: 999px;
    padding: 4px 12px;
    font-weight: 700;
    font-size: .76rem;
    background: var(--hdr-soft);
    color: var(--r9-violet);
    border: 0;
}

/* ============================================================================
   8. AVATARS — soft consistent ring
   ============================================================================ */
body.theme-rei9 .c-avatar {
    box-shadow: 0 0 0 2px var(--r9-surface), 0 0 0 4px var(--r9-border);
    border: 0;
}
body.theme-rei9 .c-avatar.lg {
    box-shadow: 0 0 0 3px var(--r9-surface), 0 0 0 6px var(--hdr-soft);
}

/* ============================================================================
   9. FORMS — login / register / settings / community composer
   ============================================================================ */
body.theme-rei9 input[type="text"],
body.theme-rei9 input[type="email"],
body.theme-rei9 input[type="password"],
body.theme-rei9 input[type="search"],
body.theme-rei9 input[type="tel"],
body.theme-rei9 input[type="number"],
body.theme-rei9 input[type="url"],
body.theme-rei9 textarea,
body.theme-rei9 select {
    border: 1.5px solid var(--r9-border);
    border-radius: 12px;
    padding: 12px 14px;
    transition: border-color .15s, box-shadow .15s, background .15s;
    font-family: inherit;
    font-size: .95rem;
    background: var(--r9-surface);
    color: var(--r9-ink);
    width: 100%;
    box-sizing: border-box;
}
body.theme-rei9 input:focus,
body.theme-rei9 textarea:focus,
body.theme-rei9 select:focus {
    outline: 0;
    border-color: var(--r9-violet);
    box-shadow: 0 0 0 3px rgba(124,58,237,.15);
}
body.theme-rei9 label {
    font-weight: 700;
    color: var(--r9-text);
    margin-bottom: 6px;
    display: inline-block;
    font-size: .88rem;
}

/* Login/register pages have their own form containers — give them the panel look */
body.theme-rei9 .auth-card,
body.theme-rei9 .auth-shell,
body.theme-rei9 form.login-form,
body.theme-rei9 form.register-form {
    background: var(--r9-surface);
    border: 1px solid var(--r9-border);
    border-radius: var(--r9-radius-lg);
    box-shadow: var(--r9-shadow);
    padding: 28px;
}

/* ============================================================================
   10. AI / ASK MODULE PAGES — common containers many of them use
   ============================================================================ */
body.theme-rei9 .ask-shell,
body.theme-rei9 .coach-shell,
body.theme-rei9 .sim-shell,
body.theme-rei9 .learn-shell {
    max-width: 1100px;
    margin: 24px auto;
    padding: 0 20px;
}
body.theme-rei9 .ask-card,
body.theme-rei9 .coach-card,
body.theme-rei9 .sim-card,
body.theme-rei9 .chat-card {
    background: var(--r9-surface);
    border: 1px solid var(--r9-border);
    border-radius: var(--r9-radius-lg);
    box-shadow: var(--r9-shadow-sm);
    padding: 24px;
}

/* Chat-style messages (used in coach/ask) — common patterns */
body.theme-rei9 .chat-bubble.user,
body.theme-rei9 .msg.user,
body.theme-rei9 .message-user {
    background: var(--r9-grad-primary);
    color: #fff;
    border-radius: 18px 18px 4px 18px;
    padding: 12px 16px;
    box-shadow: 0 4px 12px rgba(124,58,237,.20);
}
body.theme-rei9 .chat-bubble.ai,
body.theme-rei9 .chat-bubble.assistant,
body.theme-rei9 .msg.ai,
body.theme-rei9 .message-ai {
    background: var(--r9-bg);
    color: var(--r9-ink);
    border: 1px solid var(--r9-border);
    border-radius: 18px 18px 18px 4px;
    padding: 12px 16px;
}

/* ============================================================================
   11. NOTIFICATIONS / TOASTS / FLASH MESSAGES
   ============================================================================ */
body.theme-rei9 .alert,
body.theme-rei9 .flash-message,
body.theme-rei9 .notice {
    border-radius: var(--r9-radius);
    padding: 14px 18px;
    font-weight: 600;
    border: 1px solid transparent;
}
body.theme-rei9 .alert-success,
body.theme-rei9 .flash-success { background: #dcfce7; color: #166534; border-color: #bbf7d0; }
body.theme-rei9 .alert-error,
body.theme-rei9 .alert-danger,
body.theme-rei9 .flash-error   { background: #fef2f2; color: #991b1b; border-color: #fecaca; }
body.theme-rei9 .alert-warning,
body.theme-rei9 .flash-warning { background: #fff7ed; color: #9a3412; border-color: #fed7aa; }
body.theme-rei9 .alert-info,
body.theme-rei9 .flash-info    { background: #f5f3ff; color: var(--r9-violet-d); border-color: #ddd6fe; }

/* ============================================================================
   12. FOOTER — match the page surface, no dark contrast jump
   ============================================================================ */
body.theme-rei9 .site-footer,
body.theme-rei9 footer.site-footer {
    background: linear-gradient(180deg, var(--r9-surface) 0%, var(--r9-bg) 100%);
    border-top: 1px solid var(--r9-border);
    color: var(--r9-text);
}
body.theme-rei9 .site-footer a {
    color: var(--r9-text);
    transition: color .12s;
}
body.theme-rei9 .site-footer a:hover { color: var(--r9-violet); }

/* ============================================================================
   13. TABLES (settings, billing, etc.)
   ============================================================================ */
body.theme-rei9 table {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    background: var(--r9-surface);
    border-radius: var(--r9-radius);
    overflow: hidden;
    border: 1px solid var(--r9-border);
}
body.theme-rei9 table th {
    background: var(--r9-bg);
    text-align: left;
    padding: 12px 16px;
    font-weight: 800;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--r9-muted);
    border-bottom: 1px solid var(--r9-border);
}
body.theme-rei9 table td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--r9-border);
    color: var(--r9-text);
}
body.theme-rei9 table tr:last-child td { border-bottom: 0; }
body.theme-rei9 table tr:hover td { background: var(--r9-bg); }

/* ============================================================================
   14. SCROLLBAR — small touch but ties everything together visually
   ============================================================================ */
body.theme-rei9 ::-webkit-scrollbar { width: 10px; height: 10px; }
body.theme-rei9 ::-webkit-scrollbar-track { background: transparent; }
body.theme-rei9 ::-webkit-scrollbar-thumb {
    background: var(--r9-border-2);
    border-radius: 999px;
    border: 2px solid var(--r9-bg);
}
body.theme-rei9 ::-webkit-scrollbar-thumb:hover { background: var(--r9-violet-2); }

/* ============================================================================
   15. SUBTLE ENTRANCE ANIMATION FOR MAIN CONTENT
   ============================================================================ */
@keyframes r9PageIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}
body.theme-rei9 main,
body.theme-rei9 .c-shell,
body.theme-rei9 .ask-shell,
body.theme-rei9 .coach-shell,
body.theme-rei9 .sim-shell {
    animation: r9PageIn .35s ease-out;
}

/* ============================================================================
   16. UTILITY HELPERS the homepage / dashboard already use — make sure they
       work everywhere if reused
   ============================================================================ */
body.theme-rei9 .r9-grad-text {
    background: var(--r9-grad-primary);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    font-weight: 900;
}

/* ============================================================================
   17. AUTH PAGES (login.php, register.php) — override hardcoded #006AFF blue
   ============================================================================ */

/* Logo wordmark gradient */
body.theme-rei9 .logo-text {
    background: var(--r9-grad-primary);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 900;
    letter-spacing: -0.02em;
    text-decoration: none;
}
body.theme-rei9 .logo-text:hover { opacity: .9; }

/* Sign in / Sign up button */
body.theme-rei9 .btn-auth {
    background: var(--r9-grad-primary) !important;
    border-radius: 999px !important;
    font-weight: 800 !important;
    box-shadow: var(--r9-shadow-glow) !important;
    transition: transform .15s, box-shadow .2s, filter .15s !important;
    border: 0 !important;
}
body.theme-rei9 .btn-auth:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 12px 26px rgba(124,58,237,.40) !important;
    filter: brightness(1.06) !important;
}

/* Auth footer links */
body.theme-rei9 .auth-footer a { color: var(--r9-violet) !important; }

/* Auth banner background — light violet overlay for REI9 */
body.theme-rei9 .auth-banner {
    background-blend-mode: multiply;
    background-color: rgba(76,29,149,0.80) !important;
}

/* ============================================================================
   18. ASK / CHAT MODULE — override ask.php's inline hardcoded colours.
       ask.php sets body{background:#fff!important} and uses #0f172a navy for
       sidebar + coaching panel. We reskin to REI9 violet-dark so the chat
       experience matches the rest of the site.
   ============================================================================ */

/* Beat ask.php's `body { background-color:#fff !important }` */
body.theme-rei9 {
    background: var(--r9-bg) !important;
}

/* ── Sidebar — violet-dark instead of cold navy ── */
body.theme-rei9 .ask-sidebar {
    background: linear-gradient(180deg, #2d1b69 0%, #1a0a38 100%) !important;
    border-right-color: rgba(124,58,237,0.25) !important;
}
body.theme-rei9 .ask-new-chat-btn {
    border-color: rgba(124,58,237,0.35) !important;
    color: #e9d5ff !important;
}
body.theme-rei9 .ask-new-chat-btn:hover {
    background: rgba(124,58,237,0.25) !important;
}
body.theme-rei9 .thread-item { color: #c4b5fd !important; }
body.theme-rei9 .thread-item:hover { background: rgba(124,58,237,0.20) !important; }
body.theme-rei9 .thread-item.active {
    background: rgba(124,58,237,0.30) !important;
    color: #fff !important;
    border-left-color: var(--r9-violet-2) !important;
}
body.theme-rei9 .ask-thread-list::-webkit-scrollbar-thumb { background: rgba(124,58,237,0.35); }

/* ── Send button — gradient instead of navy ── */
body.theme-rei9 .send-btn {
    background: var(--r9-grad-primary) !important;
    box-shadow: 0 4px 12px rgba(124,58,237,0.35) !important;
    transition: transform .15s, box-shadow .2s, filter .15s !important;
}
body.theme-rei9 .send-btn:hover {
    transform: scale(1.06);
    box-shadow: 0 6px 18px rgba(124,58,237,0.50) !important;
}
body.theme-rei9 .send-btn:disabled { background: var(--r9-border) !important; box-shadow: none !important; }

/* ── Input box focus — violet ring ── */
body.theme-rei9 .input-box-container:focus-within {
    border-color: var(--r9-violet) !important;
    box-shadow: 0 10px 30px -10px rgba(124,58,237,0.20) !important;
}

/* ── Pill suggestion buttons — violet accent ── */
body.theme-rei9 .pill-btn {
    color: var(--r9-violet) !important;
    border-color: #ddd6fe !important;
}
body.theme-rei9 .pill-btn:hover {
    border-color: var(--r9-violet) !important;
    background: #f5f3ff !important;
}

/* ── Funnel cards — violet left-border accent on hover ── */
body.theme-rei9 .funnel-card:hover {
    border-color: #ddd6fe !important;
}
body.theme-rei9 .funnel-card-link:hover { color: var(--r9-violet) !important; background: #f5f3ff !important; }

/* ── Inline search card button ── */
body.theme-rei9 .inline-search-box button {
    background: var(--r9-violet) !important;
}
body.theme-rei9 .inline-search-box button:hover {
    background: var(--r9-violet-d) !important;
}
body.theme-rei9 .inline-search-box input:focus {
    border-color: var(--r9-violet) !important;
}

/* ── Coaching panel — violet-dark instead of cold navy ── */
body.theme-rei9 #coaching-panel {
    background: linear-gradient(180deg, #2d1b69 0%, #1a0a38 100%) !important;
    border-left-color: rgba(124,58,237,0.25) !important;
}
body.theme-rei9 .coaching-panel-header {
    border-bottom-color: rgba(124,58,237,0.25) !important;
}
body.theme-rei9 .coaching-panel-title { color: var(--r9-violet-2) !important; }
body.theme-rei9 .coach-empty { color: rgba(196,181,253,0.60) !important; }
body.theme-rei9 .coach-card {
    background: rgba(45,27,105,0.60) !important;
    border-left-color: rgba(124,58,237,0.35) !important;
}
body.theme-rei9 .coach-card.latest { border-left-color: var(--r9-violet-2) !important; }
body.theme-rei9 .coach-card-exchange { color: rgba(196,181,253,0.50) !important; }
body.theme-rei9 .coach-score-bar-bg { background: rgba(124,58,237,0.25) !important; }
body.theme-rei9 .coaching-panel-body::-webkit-scrollbar-thumb { background: rgba(124,58,237,0.35); }
body.theme-rei9 .end-session-btn { background: var(--r9-grad-primary) !important; }
body.theme-rei9 .end-session-btn:hover { filter: brightness(1.1) !important; }
body.theme-rei9 .end-session-btn:disabled { background: rgba(124,58,237,0.30) !important; }

/* ── Session launch overlay ── */
body.theme-rei9 .session-launch-card {
    background: linear-gradient(135deg, #2d1b69 0%, #1a0a38 100%) !important;
    border-color: rgba(124,58,237,0.40) !important;
}
body.theme-rei9 .session-launch-btn {
    background: var(--r9-grad-primary) !important;
}
body.theme-rei9 .session-launch-btn:hover { filter: brightness(1.08) !important; }
body.theme-rei9 .session-launch-title { color: #f5f3ff !important; }
body.theme-rei9 .session-launch-desc { color: #c4b5fd !important; }
body.theme-rei9 .session-launch-text-btn { color: #a78bfa !important; }

/* ── Audio bar — REI9 tint ── */
body.theme-rei9 #audio-bar {
    background: #f5f3ff !important;
    border-bottom-color: #ddd6fe !important;
}

/* ── AI prose list marker ── */
body.theme-rei9 .ai-prose .ai-ul li::marker { color: var(--r9-violet) !important; }

/* ── Mic recording state ── */
body.theme-rei9 #mic-btn.recording { background: #fdf2f8 !important; color: var(--r9-pink) !important; }

/* ── Resp action buttons ── */
body.theme-rei9 .resp-btn-topic {
    background: #f5f3ff !important;
    border-color: #ddd6fe !important;
    color: var(--r9-violet-d) !important;
}
body.theme-rei9 .resp-btn-topic:hover { background: #ede9fe !important; }
