/* =============================================================================
   GENESIS LEGAL AI — styles.css
   Clean consolidated production build
============================================================================= */

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

/* =============================================================================
   1. VARIABLES
============================================================================= */
:root {
  --navy:        #1a2a6c;
  --navy-mid:    #1a2a6c;
  --navy-light:  #667eea;
  --gold:        #764ba2;
  --gold-light:  #9b6fd4;
  --gold-pale:   #f3eeff;
  --slate:       #555;
  --slate-light: #888;
  --slate-pale:  #f8f9fc;
  --white:       #ffffff;
  --cream:       #f8f9fc;
  --border:      #e5e7eb;
  --border-med:  #d1d5db;
  --green:       #10b981;
  --green-pale:  #d1fae5;
  --red:         #ef4444;
  --red-pale:    #fee2e2;
  --amber:       #f59e0b;
  --amber-pale:  #fef3c7;
  --blue:        #3b82f6;
  --blue-pale:   #dbeafe;
  --purple:      #764ba2;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --shadow-md:   0 4px 16px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.06);
  --shadow-lg:   0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.08);
  --shadow-xl:   0 24px 60px rgba(0,0,0,.18);
  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --transition:  all 0.2s cubic-bezier(0.4,0,0.2,1);
}

/* =============================================================================
   2. RESET
============================================================================= */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { height:100%; }

/* =============================================================================
   3. BODY & ANIMATIONS
============================================================================= */
body {
  font-family: 'Poppins', 'Inter', sans-serif;
  color: var(--navy);
  background: linear-gradient(-45deg, #667eea, #764ba2, #6b8cff, #6541ad);
  background-size: 300% 300%;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("https://www.segalmccambridge.com/wp-content/uploads/2018/06/Legal-Malpractice.jpg") center / cover no-repeat;
  opacity: 0.15;
  z-index: -1;
}

@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes fadeIn {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes floatIn { to { opacity:1; transform:translateY(0); } }
@keyframes spin { to { transform:rotate(360deg); } }

/* =============================================================================
   4. LOGIN SCREEN
============================================================================= */
#login-container {
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.login-card {
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  background: rgba(255,255,255,0.15);
  border-radius: 24px;
  padding: 4rem 3.5rem;
  width: 100%;
  max-width: 520px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.2), inset 0 1px 1px rgba(255,255,255,0.4);
  border: 1px solid rgba(255,255,255,0.3);
  animation: floatIn 0.8s ease-out forwards;
  opacity: 0;
  transform: translateY(30px);
}

.login-logo { text-align:center; margin-bottom:32px; }

.login-logo .logo-icon {
  width:60px; height:60px;
  margin: 0 auto 1rem;
  background: linear-gradient(135deg, #330c42, #854cbd);
  color: #fff;
  font-size: 20px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.login-logo h2, #form-title {
  font-size: 1.5rem;
  color: #333;
  font-weight: 600;
  text-align: center;
  margin-bottom: 0;
}

.login-logo p { font-size:0.88rem; color:#fff; }

.login-form { display:flex; flex-direction:column; gap:16px; }
.input-group { display:flex; flex-direction:column; gap:6px; }

.input-group label {
  font-size: 0.875rem;
  font-weight: 600;
  color: rgba(0,0,0,0.92);
  letter-spacing: .01em;
}

.input-group input {
  padding: 12px 16px;
  border: 1px solid rgba(255,255,255,0.35);
  border-radius: var(--radius-md);
  font-size: 1rem;
  font-family: 'Poppins', sans-serif;
  color: #222;
  background: rgba(255,255,255,0.93);
  transition: var(--transition);
  outline: none;
}

.input-group input:focus {
  border-color: #667eea;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(102,126,234,0.2);
}

.btn-login {
  padding: 14px;
  background: linear-gradient(90deg, #667eea, #764ba2);
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: 1rem;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  margin-top: 4px;
}
.btn-login:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(118,75,162,.4); }
.btn-login:disabled { opacity:0.6; cursor:default; transform:none; }

.form-footer { text-align:center; font-size:0.9rem; color:#000; }
.signup-link, .form-footer a { color:#000; font-weight:700; text-decoration:none; }
.signup-link:hover { text-decoration:underline; }

#error-msg {
  background: rgba(239,68,68,0.15);
  color: #fca5a5;
  border: 1px solid rgba(239,68,68,0.3);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 0.875rem;
  display: none;
}

/* =============================================================================
   5. ROLE SELECTION SCREEN
============================================================================= */
#role-selection-screen {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  z-index: 9998;
  display: none;
  flex-direction: column;
  overflow-y: auto;
}

.role-header-bar {
  position: fixed;
  top:0; left:0; right:0;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(10px);
  padding: 15px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);
  z-index: 10000;
}

.role-brand { font-size:1.3rem; font-weight:700; color:#1a2a6c; display:flex; align-items:center; gap:10px; }
.role-brand span { font-weight:400; color:#666; font-size:1rem; }
.role-user-area { display:flex; align-items:center; gap:16px; }
.role-user-name { color:#666; font-size:0.9rem; }
.role-user-name strong { color:#1a2a6c; }

.btn-role-logout {
  background: linear-gradient(135deg, #667eea, #764ba2);
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: var(--radius-md);
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  font-family: 'Poppins', sans-serif;
}
.btn-role-logout:hover { transform:scale(1.05); }

.role-body { flex:1; padding:100px 40px 80px; max-width:1400px; margin:0 auto; width:100%; }
.role-hero { text-align:center; margin-bottom:50px; }
.role-hero h1 { font-size:clamp(2rem,4vw,2.8rem); color:#fff; margin-bottom:14px; font-weight:700; text-shadow:0 2px 10px rgba(0,0,0,0.3); }
.role-hero h1 em { font-style:italic; }
.role-hero p { font-size:1.1rem; color:rgba(255,255,255,0.92); max-width:560px; margin:0 auto; line-height:1.7; }

.role-cards { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-bottom:60px; }
@media (max-width:1100px) { .role-cards { grid-template-columns:repeat(2,1fr); } }
@media (max-width:640px)  { .role-cards { grid-template-columns:1fr; } }

.role-card {
  background: #fff;
  border-radius: 20px;
  padding: 35px 28px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s;
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
  border-top: 5px solid transparent;
}
.role-card:hover { transform:translateY(-8px); box-shadow:0 20px 50px rgba(0,0,0,0.2); }
.role-card.legal { border-top-color:#eeaa2b; }
.role-card.tax   { border-top-color:#f093fb; }
.role-card.audit { border-top-color:#4facfe; }
.role-card.acc   { border-top-color:#43e97b; }
.role-icon { font-size:3.8rem; margin-bottom:18px; display:block; }
.role-card h3 { font-size:1.3rem; color:#1a2a6c; margin-bottom:10px; font-weight:700; }
.role-card p { font-size:0.875rem; color:#666; line-height:1.6; margin-bottom:22px; min-height:50px; }

.role-enter-btn {
  width: 100%;
  padding: 12px;
  background: linear-gradient(135deg, #667eea, #764ba2);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: all 0.3s;
}
.role-enter-btn:hover { transform:scale(1.04); box-shadow:0 5px 15px rgba(102,126,234,0.4); }
.role-enter-btn.coming-soon { background:#e5e7eb; color:#999; cursor:not-allowed; }
.role-enter-btn.coming-soon:hover { transform:none; box-shadow:none; }

.privacy-section { background:rgba(255,255,255,0.95); border-radius:20px; padding:40px; margin-bottom:40px; box-shadow:0 10px 40px rgba(0,0,0,0.15); }
.privacy-section h2 { text-align:center; color:#1a2a6c; font-size:2rem; margin-bottom:36px; }
.privacy-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.privacy-item { background:#fff; border-radius:12px; padding:24px; border-left:4px solid #7e57c2; box-shadow:0 2px 10px rgba(0,0,0,0.05); }
.privacy-item h3 { font-size:1rem; font-weight:700; color:#1a2a6c; margin-bottom:10px; }
.privacy-item p { font-size:0.875rem; color:#444; line-height:1.7; }

/* FAQ */
.faq-section { max-width:1200px; margin:60px auto 0; padding:40px; background:rgba(255,255,255,0.95); border-radius:20px; box-shadow:0 10px 40px rgba(0,0,0,0.15); }
.faq-section h2 { text-align:center; color:#1a2a6c; margin-bottom:40px; font-size:2.2rem; }
.faq-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(320px,1fr)); gap:30px; }
.faq-item { background:#fff; padding:25px; border-radius:12px; border-left:4px solid #7e57c2; box-shadow:0 2px 10px rgba(0,0,0,0.05); }
.faq-item h3 { color:#1a2a6c; margin-bottom:12px; font-size:1.15rem; font-weight:700; }
.faq-item p { color:#444; line-height:1.8; font-size:0.93rem; }
.faq-item strong { color:#7e57c2; }
.faq-trust-badge { margin-top:40px; padding:25px; background:linear-gradient(135deg,rgba(126,87,194,0.1),rgba(171,71,188,0.1)); border-radius:12px; text-align:center; }
.faq-trust-badge p { font-size:1rem; color:#1a2a6c; line-height:1.8; margin:0; }
.faq-trust-badge strong { font-size:1.2rem; display:block; margin-bottom:8px; color:#1a2a6c; }

/* Role footer */
.role-footer { max-width:1200px; margin:40px auto 0; padding:30px; text-align:center; color:rgba(255,255,255,0.8); }
.role-footer-links { display:flex; justify-content:center; gap:30px; margin-bottom:20px; flex-wrap:wrap; }
.role-footer-links a { color:rgba(255,255,255,0.9); text-decoration:none; font-size:0.95rem; transition:color 0.3s; }
.role-footer-links a:hover { color:#fff; }
.role-footer p { font-size:0.9rem; margin:0; opacity:0.7; }

/* =============================================================================
   6. APP HEADER
============================================================================= */
#app-header {
  display: none;
  position: fixed;
  top:0; left:0; right:0;
  z-index: 100;
  background: #fff;
  padding: 0 30px;
  height: 62px;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  border-bottom: 1px solid #e5e7eb;
}

.header-brand { display:flex; align-items:center; gap:12px; }

#workspace-back-btn {
  background: rgba(102,126,234,0.1);
  color: #667eea;
  border: 2px solid rgba(102,126,234,0.2);
  padding: 7px 15px;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  display: none;
}
#workspace-back-btn:hover { background:rgba(102,126,234,0.2); transform:translateX(-3px); }

.header-logo-text { font-size:1.2rem; color:#764ba2; font-weight:700; }
.header-logo-text span { color:#aaa; font-weight:300; font-size:0.9rem; margin-left:6px; }
.header-user { display:flex; align-items:center; gap:14px; font-size:0.875rem; color:#666; }
.header-user strong { color:#1a2a6c; }

#btn-logout {
  padding: 7px 18px;
  border: 1px solid #ff4d4d;
  color: #ff4d4d;
  background: transparent;
  border-radius: 20px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
}
#btn-logout:hover { background:#ff4d4d; color:#fff; }

/* Sidebar toggle button in header */
#sb-toggle-btn {
  background: transparent;
  border: none;
  color: #888;
  font-size: 1rem;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: 6px;
  transition: var(--transition);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 4px;
}
#sb-toggle-btn:hover { background:#f3f4f6; color:#1a2a6c; }

/* =============================================================================
   7. WORKSPACE LAYOUT & SIDEBAR
============================================================================= */
#workspace {
  display: flex !important;
  padding-top: 62px;
  height: 100vh;
  overflow: hidden;
}

/* Hidden original tab nav — kept in DOM for JS */
#workspace > .tab-navigation { display:none !important; }

/* Content area */
#workspace > .tab-content-wrapper {
  flex: 1;
  overflow-y: auto;
  height: 100%;
  padding: 28px 28px 60px !important;
}

/* Sidebar */
#app-sidebar {
  width: 200px;
  min-width: 200px;
  height: 100%;
  background: #0f1e3c;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
  transition: width 0.2s cubic-bezier(0.4,0,0.2,1), min-width 0.2s;
}

#app-sidebar.sb-collapsed { width:0 !important; min-width:0 !important; }

.sb-nav { padding:12px 8px; flex:1; }

.sb-item {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 8px;
  font-size: 0.84rem;
  font-weight: 500;
  color: rgba(255,255,255,0.48);
  background: transparent;
  border: none;
  cursor: pointer;
  text-align: left;
  font-family: 'Poppins','Inter',sans-serif;
  transition: all 0.15s;
  margin-bottom: 2px;
  white-space: nowrap;
}
.sb-item i { width:18px; text-align:center; font-size:0.85rem; flex-shrink:0; transition:color 0.15s; }
.sb-item:hover { background:rgba(255,255,255,0.07); color:rgba(255,255,255,0.85); }
.sb-item.active { background:rgba(255,255,255,0.11); color:#fff; font-weight:600; }
.sb-item.active i { color:#c9a84c; }

.sb-footer {
  padding: 14px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-size: 0.7rem;
  color: rgba(255,255,255,0.22);
  display: flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
  overflow: hidden;
}

/* Tab nav (hidden but functional) */
.tab-navigation {
  background: #fff;
  border-bottom: 2px solid #e5e7eb;
  display: flex;
  gap: 0;
  padding: 0 30px;
  position: fixed;
  top:62px; left:0; right:0;
  z-index: 90;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  overflow-x: auto;
}
.tab-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 22px;
  height: 52px;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  color: #888;
  font-size: 0.875rem;
  font-weight: 500;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
  margin-bottom: -2px;
}
.tab-btn:hover { color:#764ba2; background:rgba(118,75,162,0.05); }
.tab-btn.active { color:#764ba2; border-bottom-color:#764ba2; font-weight:700; background:rgba(118,75,162,0.06); }
.tab-icon { font-size:1.1rem; }

/* Tab content */
.tab-content { display:none; animation:fadeIn 0.35s ease; }
.tab-content.active { display:block; }
.tab-content-wrapper { min-height:100vh; background:linear-gradient(135deg,#f8f9fc 0%,#fdfeff 100%); }

/* =============================================================================
   8. PAGE HEADERS
============================================================================= */
.page-header {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 12px;
}
.page-header-text h1 { font-size:1.75rem; color:#1a2a6c; margin-bottom:4px; }
.page-header-text p  { color:#888; font-size:0.9rem; }

/* Cases page — tighter gap before search bar */
#cases-container .page-header { margin-bottom:12px !important; padding-bottom:14px !important; }

/* Cases count inline white override */
#cases-container .page-header p[style*="color: white"],
#cases-container .page-header p[style*="color:white"] { color:#888 !important; }

/* =============================================================================
   9. CASES GRID & CARDS
============================================================================= */
.cases-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }

.case-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4,0,0.2,1);
  position: relative;
  overflow: hidden;
}
.case-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,#667eea,#764ba2); }
.case-card:hover { border-color:rgba(102,126,234,0.3); box-shadow:0 8px 25px rgba(102,126,234,0.18); transform:translateY(-4px); }
.case-card-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }

.case-status-badge { padding:3px 12px; border-radius:20px; font-size:0.75rem; font-weight:700; letter-spacing:.03em; }
.status-active   { background:var(--green-pale); color:#059669; }
.status-closed   { background:#f3f4f6; color:#666; }
.status-archived { background:var(--amber-pale); color:#d97706; }

.case-card h3 { font-size:1.1rem; color:#1a2a6c; margin-bottom:6px; font-weight:700; }
.case-meta { font-size:0.82rem; color:#888; display:flex; flex-wrap:wrap; gap:10px; margin-bottom:16px; }

.case-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; padding:14px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); margin-bottom:14px; }
.case-stat { text-align:center; }
.case-stat-num { font-size:1.3rem; font-weight:700; color:#764ba2; }
.case-stat-label { font-size:0.7rem; color:#888; margin-top:2px; }
.case-card-footer { display:flex; justify-content:space-between; align-items:center; font-size:0.8rem; }

/* =============================================================================
   10. CASE DETAIL
============================================================================= */
.case-detail-header {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  margin-bottom: 20px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
}

.case-actions-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:10px; margin-bottom:24px; }

.case-action-btn {
  padding: 13px 10px;
  border: none;
  border-radius: var(--radius-md);
  font-weight: 600;
  font-size: 0.875rem;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  color: #fff;
  text-align: center;
}
.case-action-btn:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }

.case-section { background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); border:1px solid var(--border); margin-bottom:16px; overflow:hidden; }

.case-section-header {
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
  background: #f8fafc;
}
.case-section-header h3 { font-size:0.78rem; font-weight:700; color:#1a2a6c; margin:0; text-transform:uppercase; letter-spacing:.05em; }
.case-section-body { padding:18px 22px; }

/* =============================================================================
   11. ITEM ROWS
============================================================================= */
.item-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 11px 16px;
  background: #f8f9fc;
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  border: 1px solid transparent;
  transition: var(--transition);
}
.item-row:hover { border-color:var(--border); background:#fff; box-shadow:var(--shadow-sm); }
.item-row-icon  { font-size:1.6rem; flex-shrink:0; }
.item-row-info  { flex:1; min-width:0; }
.item-row-title { font-size:0.9rem; font-weight:600; color:#1a2a6c; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.item-row-meta  { font-size:0.77rem; color:#888; margin-top:2px; display:flex; gap:8px; flex-wrap:wrap; }
.item-row-actions { display:flex; gap:6px; flex-shrink:0; }

/* =============================================================================
   12. BUTTONS
============================================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 0.84rem;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}
.btn-primary { background:linear-gradient(135deg,#764ba2,#667eea); color:#fff; }
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 5px 15px rgba(102,126,234,0.35); }
.btn-gold    { background:linear-gradient(135deg,#667eea,#764ba2); color:#fff; }
.btn-gold:hover { transform:translateY(-1px); }
.btn-green   { background:var(--green); color:#fff; }
.btn-green:hover { background:#059669; }
.btn-danger  { background:var(--red-pale); color:var(--red); border:1px solid #fca5a5; }
.btn-danger:hover { background:#fee2e2; }
.btn-ghost   { background:#f1f5f9; color:#1a2a6c; border:1px solid var(--border); }
.btn-ghost:hover { background:#e2e8f0; }
.btn-sm { padding:6px 12px; font-size:0.8rem; }
.btn-lg { padding:13px 28px; font-size:1rem; border-radius:var(--radius-md); }

.btn-new-case {
  background: linear-gradient(135deg, #667eea, #764ba2);
  color: #fff;
  border: none;
  padding: 12px 24px;
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-weight: 700;
  font-family: 'Poppins', sans-serif;
  cursor: pointer;
  transition: var(--transition);
  box-shadow: 0 3px 12px rgba(102,126,234,0.3);
}
.btn-new-case:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(102,126,234,0.4); }

/* =============================================================================
   13. EMPTY STATE
============================================================================= */
.empty-state { text-align:center; padding:60px 20px; }
.empty-icon  { font-size:4rem; margin-bottom:16px; opacity:0.4; display:block; }
.empty-state h3 { font-size:1.4rem; color:#1a2a6c; margin-bottom:10px; }
.empty-state p  { color:#888; margin-bottom:24px; line-height:1.6; }

/* =============================================================================
   14. MODALS
============================================================================= */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(10,18,40,0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  padding: 20px;
  backdrop-filter: blur(3px);
  animation: fadeIn 0.2s ease;
}
.modal-box { background:#fff; border-radius:var(--radius-xl); padding:40px; width:100%; max-width:600px; max-height:90vh; overflow-y:auto; position:relative; box-shadow:var(--shadow-xl); }
.modal-box.modal-lg { max-width:900px; }
.modal-close { position:absolute; top:16px; right:20px; background:#f3f4f6; border:none; width:32px; height:32px; border-radius:50%; font-size:1.2rem; cursor:pointer; color:#666; display:flex; align-items:center; justify-content:center; transition:var(--transition); }
.modal-close:hover { background:#e5e7eb; color:#1a2a6c; }
.modal-title    { font-size:1.5rem; color:#1a2a6c; margin-bottom:6px; padding-right:32px; }
.modal-subtitle { color:#888; font-size:0.9rem; margin-bottom:24px; }
.modal-footer   { display:flex; gap:10px; margin-top:24px; flex-wrap:wrap; }

/* =============================================================================
   15. FORMS
============================================================================= */
.form-group { margin-bottom:18px; }
.form-group label { display:block; font-size:0.875rem; font-weight:600; color:#555; margin-bottom:6px; }
.form-group label .req { color:var(--red); margin-left:2px; }
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 11px 14px;
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-family: 'Poppins', sans-serif;
  color: #1a2a6c;
  background: #fff;
  transition: var(--transition);
  outline: none;
  box-sizing: border-box;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:#667eea; box-shadow:0 0 0 3px rgba(102,126,234,0.12); }
.form-group textarea { resize:vertical; line-height:1.5; }
.form-grid-2  { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-actions { display:flex; gap:10px; margin-top:28px; }
.form-actions .btn-lg { flex:1; }

/* =============================================================================
   16. RESEARCH / SEARCH BAR
============================================================================= */
.search-bar { display:flex; gap:12px; background:#fff; padding:10px; border-radius:15px; box-shadow:0 4px 15px rgba(0,0,0,0.08); margin-bottom:24px; }
.search-bar input { flex:1; padding:13px 18px; border:none; font-size:1rem; font-family:'Poppins',sans-serif; outline:none; background:transparent; color:#1a2a6c; }

.case-scope-badge { background:linear-gradient(135deg,#eef2ff,#f0fdf4); border:2px solid #667eea; border-radius:12px; padding:12px 18px; margin-bottom:20px; font-size:0.9rem; font-weight:600; color:#1a2a6c; display:flex; align-items:center; gap:8px; }

#search-results { background:#fff; padding:30px; border-radius:16px; box-shadow:var(--shadow-sm); min-height:300px; }
.research-result { background:#f8f9fc; border:1px solid var(--border); border-radius:var(--radius-md); padding:18px 22px; margin-bottom:12px; transition:var(--transition); }
.research-result:hover { border-color:#667eea; box-shadow:var(--shadow-sm); }
.research-result h4 { color:#1a2a6c; font-size:1rem; margin-bottom:6px; }
.research-result p  { color:#666; font-size:0.875rem; line-height:1.6; }

/* Case search bar */
#case-search-bar { position:relative; margin-bottom:14px; }
#case-search-bar i { position:absolute; left:13px; top:50%; transform:translateY(-50%); color:#9ca3af; font-size:0.82rem; pointer-events:none; }
#case-search-input { width:100%; padding:10px 14px 10px 36px; border:1px solid var(--border); border-radius:var(--radius-md); font-size:0.875rem; font-family:inherit; background:#fff; color:#1a2a6c; outline:none; box-shadow:var(--shadow-sm); transition:var(--transition); }
#case-search-input:focus { border-color:#667eea; box-shadow:0 0 0 3px rgba(102,126,234,0.12); }
#case-search-input::placeholder { color:#9ca3af; }

/* =============================================================================
   17. AI CHAT
============================================================================= */
.chat-container { background:#fff; border-radius:15px; box-shadow:0 4px 15px rgba(0,0,0,0.08); height:700px; display:flex; flex-direction:column; }
.chat-messages  { flex:1; padding:30px; overflow-y:auto; }

.suggestion-chips { display:flex; flex-wrap:wrap; gap:8px; }
.suggestion-chips span { padding:8px 15px; background:#fff; border:1px solid #e5e7eb; border-radius:20px; font-size:0.85rem; cursor:pointer; transition:all 0.3s; }
.suggestion-chips span:hover { background:#764ba2; color:#fff; border-color:#764ba2; }

.chat-avatar { width:36px; height:36px; background:#1a2a6c; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.9rem; flex-shrink:0; color:#fff; }

.message-bubble { max-width:74%; padding:14px 18px; border-radius:var(--radius-lg); line-height:1.65; font-size:0.925rem; background:#f5f7fa; }
.message-bubble.user { background:#1a2a6c; color:#fff; margin-left:auto; }

.chat-input-area { padding:16px 20px; border-top:1px solid var(--border); display:flex; gap:10px; background:#fff; }
.chat-input-area input, #chat-input { flex:1; padding:12px 16px; border:2px solid var(--border); border-radius:var(--radius-md); font-size:0.95rem; font-family:'Poppins',sans-serif; outline:none; transition:var(--transition); color:#1a2a6c; }
.chat-input-area input:focus, #chat-input:focus { border-color:#764ba2; box-shadow:0 0 0 3px rgba(118,75,162,0.1); }

.btn-send { padding:12px 18px; background:linear-gradient(135deg,#764ba2,#667eea); color:#fff; border:none; border-radius:var(--radius-md); cursor:pointer; font-size:1.1rem; transition:var(--transition); display:flex; align-items:center; justify-content:center; }
.btn-send:hover { transform:scale(1.06); box-shadow:0 5px 15px rgba(118,75,162,0.4); }

/* =============================================================================
   18. ANALYTICS
============================================================================= */
.analytics-stats { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:16px; margin-bottom:24px; }
.analytics-stat-card { background:#fff; border-radius:var(--radius-lg); padding:22px 18px; box-shadow:var(--shadow-sm); border:1px solid var(--border); text-align:center; border-top:4px solid #667eea; }
.analytics-stat-num   { font-size:2.2rem; font-weight:700; color:#667eea; }
.analytics-stat-label { font-size:0.8rem; color:#888; margin-top:4px; font-weight:500; }
.analytics-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
@media (max-width:900px) { .analytics-grid { grid-template-columns:1fr; } }
.analytics-card { background:#fff; border-radius:var(--radius-lg); padding:24px; box-shadow:var(--shadow-sm); border:1px solid var(--border); }
.analytics-card h3 { font-size:1rem; font-weight:700; color:#1a2a6c; margin-bottom:16px; }
.status-bar      { height:8px; border-radius:4px; background:var(--border); overflow:hidden; margin-top:6px; }
.status-bar-fill { height:100%; background:linear-gradient(90deg,#667eea,#764ba2); border-radius:4px; transition:width 1s ease; }

.analytics-recent-name { font-weight:600; color:#1a2a6c; font-size:0.9rem; }
.analytics-recent-meta, .analytics-recent-date { font-size:0.78rem; color:#888; }

.chart-range-btns { display:flex; gap:4px; }
.chart-range-btn { padding:4px 10px; font-size:0.75rem; font-weight:600; font-family:'Poppins','Inter',sans-serif; border:1px solid var(--border-med,#d1d5db); border-radius:6px; background:transparent; color:#64748b; cursor:pointer; transition:all 0.15s; }
.chart-range-btn:hover  { border-color:#667eea; color:#667eea; }
.chart-range-btn.active { background:#667eea; border-color:#667eea; color:#fff; }

.analytics-stat-count { font-weight:700; color:#1a2a6c; font-size:0.95rem; }
.analytics-type-label { font-weight:600; color:#1a2a6c; }
.analytics-type-count { color:#64748b; }

/* =============================================================================
   19. BADGES
============================================================================= */
.section-badge { display:inline-flex; align-items:center; gap:5px; padding:2px 10px; border-radius:12px; font-size:0.75rem; font-weight:700; }
.badge-analysis { background:#ede9fe; color:#6d28d9; }
.badge-draft    { background:#fef3c7; color:#d97706; }
.badge-depo     { background:#fee2e2; color:#dc2626; }
.badge-timeline { background:#d1fae5; color:#059669; }
.badge-compare  { background:#e0e7ff; color:#4338ca; }

/* =============================================================================
   20. LOADING / SPINNER
============================================================================= */
.loading-state { text-align:center; padding:40px 20px; }
.loading-state p { color:#888; margin-top:12px; font-size:0.9rem; }
.spinner { width:38px; height:38px; border:3px solid #e5e7eb; border-top-color:#764ba2; border-radius:50%; animation:spin 0.8s linear infinite; margin:20px auto; }

/* =============================================================================
   21. DOCUMENT VIEWER PANEL
============================================================================= */
.doc-viewer-panel { position:fixed; top:0; right:0; width:650px; max-width:95vw; height:100vh; background:#fff; box-shadow:-8px 0 40px rgba(0,0,0,0.18); z-index:9500; display:flex; flex-direction:column; transform:translateX(100%); transition:transform 0.35s cubic-bezier(0.4,0,0.2,1); }
.doc-viewer-panel.open { transform:translateX(0); }
.doc-viewer-header { display:flex; align-items:center; justify-content:space-between; padding:18px 24px; border-bottom:1px solid var(--border); background:#1a2a6c; flex-shrink:0; }
.doc-viewer-title { font-size:0.95rem; font-weight:700; color:#fff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:440px; }
.doc-viewer-close { background:rgba(255,255,255,0.2); border:none; color:#fff; width:32px; height:32px; border-radius:50%; font-size:1.1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:var(--transition); }
.doc-viewer-close:hover { background:rgba(255,255,255,0.35); }
.doc-viewer-toolbar { padding:10px 16px; background:#f8f9fc; border-bottom:1px solid var(--border); display:flex; gap:8px; flex-wrap:wrap; flex-shrink:0; }
.doc-viewer-body { flex:1; overflow-y:auto; padding:28px; line-height:1.8; color:#333; }

.panel-backdrop { position:fixed; inset:0; background:rgba(10,18,40,0.4); z-index:9499; display:none; cursor:pointer; }
.panel-backdrop.visible { display:block; }

/* =============================================================================
   22. RENDERED CONTENT
============================================================================= */
.rendered-content { font-family:'Poppins',sans-serif; font-size:0.95rem; line-height:1.8; color:#2d3748; }
.rendered-content h1 { font-size:1.5rem; color:#1a2a6c; margin:24px 0 12px; padding-bottom:8px; border-bottom:2px solid #667eea; }
.rendered-content h2 { font-size:1.25rem; color:#1a2a6c; margin:18px 0 10px; }
.rendered-content h3 { font-size:1.05rem; color:#764ba2; margin:14px 0 8px; font-weight:700; }
.rendered-content p  { margin-bottom:12px; }
.rendered-content ul, .rendered-content ol { margin:10px 0 14px 22px; }
.rendered-content li { margin-bottom:6px; }
.rendered-content strong { color:#1a2a6c; font-weight:700; }
.rendered-content em { font-style:italic; color:#666; }
.rendered-content code { background:#f0f0f8; padding:2px 6px; border-radius:4px; font-size:0.88rem; }
.rendered-content pre { background:#f8f9fc; border:1px solid var(--border); border-radius:var(--radius-md); padding:16px; overflow-x:auto; margin:12px 0; }

/* =============================================================================
   23. NOTIFICATIONS
============================================================================= */
.notification { position:fixed; bottom:24px; right:24px; background:#fff; border-radius:var(--radius-md); padding:14px 18px; box-shadow:var(--shadow-lg); font-size:0.875rem; font-weight:600; color:#1a2a6c; z-index:99999; display:flex; align-items:center; gap:10px; max-width:380px; transform:translateX(calc(100% + 30px)); transition:transform 0.3s cubic-bezier(0.4,0,0.2,1); border-left:4px solid #764ba2; }
.notification.show    { transform:translateX(0); }
.notification.success { border-left-color:var(--green); }
.notification.error   { border-left-color:var(--red); }
.notification.info    { border-left-color:#667eea; }

/* =============================================================================
   24. UPLOAD ZONE
============================================================================= */
.upload-zone { border:2px dashed var(--border-med); border-radius:var(--radius-lg); padding:40px 24px; text-align:center; cursor:pointer; transition:var(--transition); background:#fff; }
.upload-zone:hover, .upload-zone.drag-over { border-color:#764ba2; background:rgba(118,75,162,0.04); }
.upload-zone p { color:#888; font-size:0.9rem; margin-top:10px; }

/* =============================================================================
   25. SAVED ITEMS
============================================================================= */
.saved-tabs { display:flex; gap:4px; background:#fff; border-radius:var(--radius-lg); padding:6px; box-shadow:var(--shadow-sm); border:1px solid var(--border); margin-bottom:24px; flex-wrap:wrap; }
.saved-tab-btn { padding:9px 18px; background:transparent; border:none; border-radius:var(--radius-md); font-size:0.875rem; font-weight:600; font-family:'Poppins',sans-serif; cursor:pointer; color:#888; transition:var(--transition); white-space:nowrap; }
.saved-tab-btn:hover  { color:#1a2a6c; background:#f3f4f6; }
.saved-tab-btn.active { background:linear-gradient(135deg,#667eea,#764ba2); color:#fff; }

.saved-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:16px; }
.saved-card { background:#fff; border-radius:var(--radius-lg); border:1px solid var(--border); padding:22px; box-shadow:var(--shadow-sm); transition:var(--transition); }
.saved-card:hover { box-shadow:var(--shadow-md); border-color:#c4b5fd; }
.saved-card-icon    { font-size:2rem; margin-bottom:12px; }
.saved-card-type    { font-size:0.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:#888; margin-bottom:4px; }
.saved-card-title   { font-size:0.95rem; font-weight:700; color:#1a2a6c; margin-bottom:6px; line-height:1.4; }
.saved-card-preview { font-size:0.82rem; color:#888; line-height:1.6; margin-bottom:12px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.saved-card-date    { font-size:0.75rem; color:#aaa; margin-bottom:14px; }
.saved-card-actions { display:flex; gap:6px; flex-wrap:wrap; }

/* =============================================================================
   26. TIMELINE
============================================================================= */
.timeline-container { position:relative; padding-left:32px; }
.timeline-event { position:relative; margin-bottom:24px; }
.timeline-event::before { content:''; position:absolute; left:-24px; top:6px; width:10px; height:10px; border-radius:50%; background:#764ba2; box-shadow:0 0 0 3px rgba(118,75,162,0.2); }
.timeline-event::after  { content:''; position:absolute; left:-20px; top:16px; width:2px; background:linear-gradient(180deg,#764ba2,transparent); bottom:-24px; }
.timeline-event:last-child::after { display:none; }
.timeline-event-card  { background:#fff; border:1px solid var(--border); border-radius:var(--radius-md); padding:14px 18px; border-left:3px solid #764ba2; }
.timeline-event-date  { font-size:0.8rem; font-weight:700; color:#764ba2; margin-bottom:4px; }
.timeline-event-title { font-size:0.95rem; font-weight:600; color:#1a2a6c; margin-bottom:4px; }
.timeline-event-desc  { font-size:0.85rem; color:#666; line-height:1.5; }

/* =============================================================================
   27. COMPARISON & ANALYSIS
============================================================================= */
.compare-docs-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:20px; }
@media (max-width:700px) { .compare-docs-grid { grid-template-columns:1fr; } }
.compare-doc-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius-md); padding:18px; border-top:3px solid #667eea; }
.compare-doc-card h4 { color:#1a2a6c; margin-bottom:10px; font-size:0.95rem; }
.analysis-section { background:#f8f9fc; border-radius:var(--radius-md); padding:16px 18px; margin-bottom:14px; border-left:4px solid #667eea; }
.analysis-section h4 { color:#1a2a6c; margin-bottom:8px; font-size:0.95rem; }
.analysis-section ul  { margin-left:18px; }
.analysis-section li  { margin-bottom:6px; font-size:0.875rem; color:#666; }
.analysis-section p   { font-size:0.875rem; color:#666; line-height:1.6; }

/* =============================================================================
   28. SCROLLBAR
============================================================================= */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:#f3f4f6; }
::-webkit-scrollbar-thumb { background:#c4b5fd; border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:#764ba2; }

/* =============================================================================
   29. THEME TOGGLE
============================================================================= */
.theme-toggle-float { position:fixed; top:18px; right:22px; z-index:99999; display:flex; align-items:center; gap:8px; cursor:pointer; user-select:none; background:rgba(255,255,255,0.18); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,0.35); border-radius:50px; padding:7px 14px 7px 12px; transition:background 0.3s,box-shadow 0.3s; box-shadow:0 4px 15px rgba(0,0,0,0.15); }
.theme-toggle-float:hover { background:rgba(255,255,255,0.28); box-shadow:0 6px 20px rgba(0,0,0,0.2); }
.toggle-float-label { font-size:0.78rem; font-weight:700; color:rgba(255,255,255,0.95); letter-spacing:.04em; text-transform:uppercase; transition:color 0.3s; }

.theme-toggle-wrap { display:flex; align-items:center; gap:8px; cursor:pointer; user-select:none; padding:4px 0; }
.theme-toggle-label { font-size:0.75rem; font-weight:600; color:#999; letter-spacing:.03em; text-transform:uppercase; transition:color 0.3s; min-width:28px; text-align:right; }

.theme-toggle { position:relative; width:52px; height:27px; background:#d1d5db; border-radius:50px; transition:background 0.4s cubic-bezier(0.4,0,0.2,1); flex-shrink:0; box-shadow:inset 0 1px 3px rgba(0,0,0,0.12); cursor:pointer; }
.theme-toggle-thumb { position:absolute; top:3px; left:3px; width:21px; height:21px; background:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; line-height:1; transition:transform 0.38s cubic-bezier(0.34,1.56,0.64,1),background 0.3s; box-shadow:0 2px 5px rgba(0,0,0,0.22); pointer-events:none; }

/* =============================================================================
   30. FONT AWESOME ICON HELPERS
============================================================================= */
.role-icon i  { font-size:2rem; }
.tab-icon i   { font-size:1rem; }
.chat-avatar i { font-size:1.1rem; }
.empty-icon i  { font-size:3rem; opacity:0.5; }
.header-logo-text > i { font-size:1.1rem; margin-right:4px; }
.role-brand > i { font-size:1.1rem; margin-right:4px; }
.logo-icon i { font-size:1.5rem; }
.faq-trust-badge i { color:#c9a84c; }
.theme-toggle-thumb i { font-size:0.75rem; line-height:1; }
.item-row-icon i { font-size:1.1rem; }
.btn i, button i { margin-right:4px; }
.btn-send i { margin-right:0; }
.case-section-header span i { font-size:1.1rem; }
.saved-card-icon i { font-size:1.5rem; }
.notification span i { font-size:0.85rem; vertical-align:middle; }

/* =============================================================================
   31. RESPONSIVE
============================================================================= */
@media (max-width:768px) {
  #workspace > .tab-content-wrapper { padding:16px 14px 40px !important; }
  #app-sidebar { width:0; min-width:0; }
  .modal-box        { padding:28px 22px; }
  .analytics-grid   { grid-template-columns:1fr; }
  .case-actions-row { grid-template-columns:repeat(2,1fr); }
  .form-grid-2      { grid-template-columns:1fr; }
  .doc-viewer-panel { width:100vw; }
  .role-body        { padding:90px 20px 60px; }
  .role-cards       { grid-template-columns:1fr; }
}

/* =============================================================================
   32. DARK MODE — Deep Navy + Gold palette
============================================================================= */
html.dark-mode, body.dark-mode {
  background: linear-gradient(135deg, #0d1836 0%, #0f1c3f 60%, #0a1228 100%) !important;
  color: #d4dbe8;
}
html.dark-mode body::before, body.dark-mode::before { opacity:0.05; }

/* Theme toggle */
html.dark-mode .theme-toggle-label, body.dark-mode .theme-toggle-label { color:#c9a84c; }
html.dark-mode .theme-toggle-float, body.dark-mode .theme-toggle-float { background:rgba(15,28,63,0.75); border-color:rgba(201,168,76,0.35); }
html.dark-mode .toggle-float-label, body.dark-mode .toggle-float-label { color:#c9a84c; }
html.dark-mode .theme-toggle, body.dark-mode .theme-toggle { background:linear-gradient(135deg,#1e3a5f,#0f1c3f); box-shadow:inset 0 1px 3px rgba(0,0,0,0.4),0 0 6px rgba(201,168,76,0.25); }
html.dark-mode .theme-toggle-thumb, body.dark-mode .theme-toggle-thumb { transform:translateX(25px); background:linear-gradient(135deg,#c9a84c,#e8c97a); box-shadow:0 2px 8px rgba(201,168,76,0.55); }

/* Header toggle btn */
body.dark-mode #sb-toggle-btn, html.dark-mode #sb-toggle-btn { color:#c9a84c; }
body.dark-mode #sb-toggle-btn:hover, html.dark-mode #sb-toggle-btn:hover { background:rgba(201,168,76,0.1); color:#e8c97a; }

/* Sidebar */
body.dark-mode #app-sidebar, html.dark-mode #app-sidebar { background:#07102a; }
body.dark-mode .sb-item.active, html.dark-mode .sb-item.active { background:rgba(201,168,76,0.12); color:#e8c97a; }
body.dark-mode .sb-item.active i, html.dark-mode .sb-item.active i { color:#e8c97a; }
body.dark-mode .sb-item:hover, html.dark-mode .sb-item:hover { background:rgba(255,255,255,0.05); }

/* Login */
html.dark-mode .login-card, body.dark-mode .login-card { background:rgba(10,20,55,0.82); border-color:rgba(201,168,76,0.22); box-shadow:0 20px 60px rgba(0,0,0,0.55),inset 0 1px 1px rgba(201,168,76,0.12); }
html.dark-mode .login-logo h2, body.dark-mode .login-logo h2,
html.dark-mode #form-title, body.dark-mode #form-title { color:#e2e8f0; }
html.dark-mode .login-logo p, body.dark-mode .login-logo p { color:rgba(201,168,76,0.75); }
html.dark-mode .input-group label, body.dark-mode .input-group label { color:rgba(226,232,240,0.8); }
html.dark-mode .input-group input, body.dark-mode .input-group input { background:rgba(20,35,80,0.85); border-color:rgba(201,168,76,0.2); color:#e2e8f0; }
html.dark-mode .input-group input::placeholder, body.dark-mode .input-group input::placeholder { color:#3d5080; }
html.dark-mode .input-group input:focus, body.dark-mode .input-group input:focus { border-color:#c9a84c; background:rgba(20,35,80,1); box-shadow:0 0 0 3px rgba(201,168,76,0.15); }
html.dark-mode .btn-login, body.dark-mode .btn-login { background:linear-gradient(135deg,#1a2f5e,#304b84); box-shadow:0 4px 15px rgba(0,0,0,0.4); }
html.dark-mode .form-footer, body.dark-mode .form-footer,
html.dark-mode .signup-link, body.dark-mode .signup-link,
html.dark-mode .form-footer a, body.dark-mode .form-footer a { color:rgba(201,168,76,0.8); }
body.dark-mode .login-logo .logo-icon, html.dark-mode .login-logo .logo-icon { background:linear-gradient(135deg,#1a0a2e,#4a1d8a); border:1px solid rgba(201,168,76,0.3); box-shadow:0 0 20px rgba(133,76,189,0.3); }

/* Role screen */
html.dark-mode #role-selection-screen, body.dark-mode #role-selection-screen { background:linear-gradient(135deg,#0f1c3f 0%,#1a2f5e 60%,#0a1228 100%); }
html.dark-mode .role-header-bar, body.dark-mode .role-header-bar { background:rgba(10,18,48,0.98); border-bottom:1px solid rgba(201,168,76,0.18); box-shadow:0 2px 20px rgba(0,0,0,0.5); }
html.dark-mode .role-brand, body.dark-mode .role-brand { color:#e2e8f0; }
html.dark-mode .role-brand span, body.dark-mode .role-brand span { color:#c9a84c; }
html.dark-mode .role-user-name, body.dark-mode .role-user-name { color:rgba(226,232,240,0.6); }
html.dark-mode .role-user-name strong, body.dark-mode .role-user-name strong { color:#e2e8f0; }
html.dark-mode .btn-role-logout, body.dark-mode .btn-role-logout { background:rgba(201,168,76,0.12); color:#e8c97a; border:1px solid rgba(201,168,76,0.25); }
html.dark-mode .role-card, body.dark-mode .role-card { background:rgba(18,34,80,0.92); box-shadow:0 10px 30px rgba(0,0,0,0.5); }
html.dark-mode .role-card h3, body.dark-mode .role-card h3 { color:#e2e8f0; }
html.dark-mode .role-card p, body.dark-mode .role-card p { color:rgba(226,232,240,0.55); }
html.dark-mode .role-card.legal, body.dark-mode .role-card.legal { border-top-color:#c9a84c; }
html.dark-mode .role-card.tax,   body.dark-mode .role-card.tax   { border-top-color:#9f7aea; }
html.dark-mode .role-card.audit, body.dark-mode .role-card.audit { border-top-color:#4299e1; }
html.dark-mode .role-card.acc,   body.dark-mode .role-card.acc   { border-top-color:#48bb78; }
html.dark-mode .role-enter-btn, body.dark-mode .role-enter-btn { background:linear-gradient(135deg,#1a2f5e,#304b84); }
html.dark-mode .role-enter-btn.coming-soon, body.dark-mode .role-enter-btn.coming-soon { background:rgba(255,255,255,0.05); color:#3d5080; }

/* FAQ dark */
html.dark-mode .faq-section, body.dark-mode .faq-section { background:rgba(18,32,75,0.96) !important; }
html.dark-mode .faq-section h2, body.dark-mode .faq-section h2 { color:#e8c97a !important; }
html.dark-mode .faq-item, body.dark-mode .faq-item { background:rgba(25,45,95,0.9) !important; border-left-color:#c9a84c !important; }
html.dark-mode .faq-item h3, body.dark-mode .faq-item h3 { color:#c9a84c !important; }
html.dark-mode .faq-item p, body.dark-mode .faq-item p { color:rgba(210,220,240,0.82) !important; }
html.dark-mode .faq-item strong, body.dark-mode .faq-item strong { color:#e8c97a !important; }
html.dark-mode .faq-trust-badge, body.dark-mode .faq-trust-badge { background:rgba(201,168,76,0.08) !important; border:1px solid rgba(201,168,76,0.2); }
html.dark-mode .faq-trust-badge p, body.dark-mode .faq-trust-badge p { color:rgba(210,220,240,0.85) !important; }
html.dark-mode .faq-trust-badge strong, body.dark-mode .faq-trust-badge strong { color:#c9a84c !important; }

/* App header */
html.dark-mode #app-header, body.dark-mode #app-header { background:#0c1838; border-bottom:1px solid rgba(201,168,76,0.18); box-shadow:0 2px 20px rgba(0,0,0,0.45); }
html.dark-mode .header-logo-text, body.dark-mode .header-logo-text { color:#c9a84c; }
html.dark-mode .header-logo-text span, body.dark-mode .header-logo-text span { color:rgba(201,168,76,0.4); }
html.dark-mode .header-user, body.dark-mode .header-user { color:rgba(226,232,240,0.55); }
html.dark-mode .header-user strong, body.dark-mode .header-user strong { color:#e2e8f0; }
html.dark-mode #workspace-back-btn, body.dark-mode #workspace-back-btn { background:rgba(201,168,76,0.1); color:#c9a84c; border-color:rgba(201,168,76,0.22); }
html.dark-mode #btn-logout, body.dark-mode #btn-logout { border-color:rgba(201,168,76,0.35); color:#c9a84c; }
html.dark-mode #btn-logout:hover, body.dark-mode #btn-logout:hover { background:rgba(201,168,76,0.12); }

/* Content */
html.dark-mode .tab-content-wrapper, body.dark-mode .tab-content-wrapper { background:linear-gradient(135deg,#0d1836 0%,#0f1c3f 100%); }
html.dark-mode .page-header, body.dark-mode .page-header { border-bottom-color:rgba(201,168,76,0.12); }
html.dark-mode .page-header-text h1, body.dark-mode .page-header-text h1 { color:#d4dbe8; }
html.dark-mode .page-header-text p, body.dark-mode .page-header-text p { color:rgba(212,219,232,0.45); }
body.dark-mode #cases-container .page-header p[style*="color: white"], html.dark-mode #cases-container .page-header p[style*="color: white"] { color:rgba(212,219,232,0.5) !important; }
body.dark-mode #cases-container h3, html.dark-mode #cases-container h3 { color:#d4dbe8 !important; }

/* Case cards */
html.dark-mode .case-card, body.dark-mode .case-card { background:#152348; border-color:#1c3060; }
html.dark-mode .case-card::before, body.dark-mode .case-card::before { background:linear-gradient(90deg,#c9a84c,#e8c97a); }
html.dark-mode .case-card:hover, body.dark-mode .case-card:hover { border-color:rgba(201,168,76,0.28); box-shadow:0 8px 25px rgba(0,0,0,0.45); }
html.dark-mode .case-card h3, body.dark-mode .case-card h3 { color:#d4dbe8; }
html.dark-mode .case-meta, body.dark-mode .case-meta { color:rgba(212,219,232,0.45); }
html.dark-mode .case-stat-num, body.dark-mode .case-stat-num { color:#c9a84c; }
html.dark-mode .case-stat-label, body.dark-mode .case-stat-label { color:rgba(212,219,232,0.38); }
html.dark-mode .case-stats, body.dark-mode .case-stats { border-color:rgba(201,168,76,0.1); }
html.dark-mode .case-card-footer, body.dark-mode .case-card-footer { color:rgba(212,219,232,0.45); }
html.dark-mode .status-active,   body.dark-mode .status-active   { background:rgba(72,187,120,0.14); color:#68d391; }
html.dark-mode .status-closed,   body.dark-mode .status-closed   { background:rgba(255,255,255,0.05); color:#5a7080; }
html.dark-mode .status-archived, body.dark-mode .status-archived { background:rgba(246,173,85,0.12); color:#f6ad55; }

/* Case detail */
html.dark-mode .case-detail-header, body.dark-mode .case-detail-header { background:#152348; border-color:#1c3060; }
html.dark-mode .case-detail-header h2, body.dark-mode .case-detail-header h2 { color:#d4dbe8; }
html.dark-mode .case-section, body.dark-mode .case-section { background:#152348; border-color:#1c3060; }
html.dark-mode .case-section-header, body.dark-mode .case-section-header { background:linear-gradient(90deg,#122040,#1a3060); border-bottom-color:rgba(201,168,76,0.12); }
html.dark-mode .case-section-header h3, body.dark-mode .case-section-header h3 { color:#c9a84c !important; }
html.dark-mode .case-section-body, body.dark-mode .case-section-body { color:#c8d4e8; }
html.dark-mode .case-detail-header p, html.dark-mode .case-detail-header span, body.dark-mode .case-detail-header p, body.dark-mode .case-detail-header span { color:rgba(200,212,232,0.6); }

/* Item rows */
html.dark-mode .item-row, body.dark-mode .item-row { background:rgba(10,22,55,0.6); border-color:transparent; }
html.dark-mode .item-row:hover, body.dark-mode .item-row:hover { background:rgba(22,42,88,0.85); border-color:rgba(201,168,76,0.14); }
html.dark-mode .item-row-title, body.dark-mode .item-row-title { color:#d4dbe8; }
html.dark-mode .item-row-meta, body.dark-mode .item-row-meta { color:rgba(212,219,232,0.4); }
html.dark-mode .item-row-info, body.dark-mode .item-row-info { color:#c8d4e8; }

/* Buttons */
html.dark-mode .btn-primary, body.dark-mode .btn-primary { background:linear-gradient(135deg,#b8940a,#c9a84c); color:#0a1225; }
html.dark-mode .btn-gold, body.dark-mode .btn-gold { background:linear-gradient(135deg,#c9a84c,#e8c97a); color:#0a1225; }
html.dark-mode .btn-ghost, body.dark-mode .btn-ghost { background:rgba(201,168,76,0.1); color:#c9a84c; border:1px solid rgba(201,168,76,0.2); }
html.dark-mode .btn-ghost:hover, body.dark-mode .btn-ghost:hover { background:rgba(201,168,76,0.16); }
html.dark-mode .btn-new-case, body.dark-mode .btn-new-case { background:linear-gradient(135deg,#1a2f5e,#304b84); color:#c9a84c; border:1px solid rgba(201,168,76,0.18); }

/* Empty state */
html.dark-mode .empty-state h3, body.dark-mode .empty-state h3 { color:#d4dbe8; }
html.dark-mode .empty-state p, body.dark-mode .empty-state p { color:rgba(212,219,232,0.45); }

/* Modals */
html.dark-mode .modal-box, body.dark-mode .modal-box { background:#152348; color:#d4dbe8; }
html.dark-mode .modal-title, body.dark-mode .modal-title { color:#d4dbe8; }
html.dark-mode .modal-subtitle, body.dark-mode .modal-subtitle { color:rgba(212,219,232,0.5); }
html.dark-mode .modal-close, body.dark-mode .modal-close { background:rgba(255,255,255,0.05); color:rgba(212,219,232,0.65); }
html.dark-mode .modal-body label, body.dark-mode .modal-body label { color:rgba(200,212,232,0.8); }

/* Forms */
html.dark-mode .form-group label, body.dark-mode .form-group label { color:rgba(212,219,232,0.72); }
html.dark-mode .form-group input, html.dark-mode .form-group select, html.dark-mode .form-group textarea,
body.dark-mode .form-group input, body.dark-mode .form-group select, body.dark-mode .form-group textarea { background:rgba(10,20,55,0.75); border-color:#1c3060; color:#d4dbe8; }
html.dark-mode .form-group input:focus, html.dark-mode .form-group select:focus, html.dark-mode .form-group textarea:focus,
body.dark-mode .form-group input:focus, body.dark-mode .form-group select:focus, body.dark-mode .form-group textarea:focus { border-color:#c9a84c; box-shadow:0 0 0 3px rgba(201,168,76,0.1); }

/* Search */
html.dark-mode .search-bar, body.dark-mode .search-bar { background:#152348; box-shadow:0 4px 15px rgba(0,0,0,0.35); }
html.dark-mode .search-bar input, body.dark-mode .search-bar input { color:#d4dbe8; }
html.dark-mode .search-bar input::placeholder, body.dark-mode .search-bar input::placeholder { color:#3d5280; }
html.dark-mode .case-scope-badge, body.dark-mode .case-scope-badge { background:rgba(10,20,55,0.75); border-color:rgba(201,168,76,0.28); color:#c9a84c; }
html.dark-mode #search-results, body.dark-mode #search-results { background:#152348; }
html.dark-mode .research-result, body.dark-mode .research-result { background:rgba(10,20,55,0.6); border-color:#1c3060; }
html.dark-mode .research-result:hover, body.dark-mode .research-result:hover { border-color:#c9a84c; }
html.dark-mode .research-result h4, body.dark-mode .research-result h4 { color:#d4dbe8; }
html.dark-mode .research-result p, body.dark-mode .research-result p { color:rgba(212,219,232,0.52); }
html.dark-mode #search-results p, body.dark-mode #search-results p { color:rgba(200,212,232,0.55); }

/* Case search bar */
body.dark-mode #case-search-input, html.dark-mode #case-search-input { background:#152348 !important; border-color:rgba(201,168,76,0.3) !important; color:#d4dbe8 !important; box-shadow:none !important; }
body.dark-mode #case-search-input:focus, html.dark-mode #case-search-input:focus { border-color:#c9a84c !important; box-shadow:0 0 0 3px rgba(201,168,76,0.15) !important; }
body.dark-mode #case-search-input::placeholder, html.dark-mode #case-search-input::placeholder { color:#3d5280 !important; }
body.dark-mode #case-search-bar i, html.dark-mode #case-search-bar i { color:#c9a84c !important; }

/* Chat */
html.dark-mode .chat-container, body.dark-mode .chat-container { background:#152348; border-color:#1c3060; box-shadow:0 4px 15px rgba(0,0,0,0.35); }
html.dark-mode .chat-messages, body.dark-mode .chat-messages { background:#152348; }
html.dark-mode .message-bubble, body.dark-mode .message-bubble { background:rgba(10,20,55,0.75); color:#d4dbe8; }
html.dark-mode .message-bubble.ai, body.dark-mode .message-bubble.ai { background:rgba(205,160,0,0.389); border-color:#1c3060; color:#d4dbe8; }
html.dark-mode .message-bubble.user, body.dark-mode .message-bubble.user { background:linear-gradient(135deg,#1a2f5e,#304b84); color:#d4dbe8; }
html.dark-mode .message-bubble p, body.dark-mode .message-bubble p { color:#d4dbe8; }
html.dark-mode .chat-input-area, body.dark-mode .chat-input-area { background:#102040; border-top-color:rgba(201,168,76,0.12); }
html.dark-mode .chat-input-area input, html.dark-mode #chat-input,
body.dark-mode .chat-input-area input, body.dark-mode #chat-input { background:rgba(10,20,55,0.75); border-color:#1c3060; color:#d4dbe8; }
html.dark-mode #chat-input::placeholder, body.dark-mode #chat-input::placeholder { color:#3d5280; }
html.dark-mode #chat-input:focus, body.dark-mode #chat-input:focus { border-color:#c9a84c; box-shadow:0 0 0 3px rgba(201,168,76,0.1); }
html.dark-mode .btn-send, body.dark-mode .btn-send { background:linear-gradient(135deg,#1a2f5e,#304b84); border:1px solid rgba(201,168,76,0.18); }
html.dark-mode .suggestion-chips button, body.dark-mode .suggestion-chips button { background:rgba(201,168,76,0.12); border:1px solid rgba(201,168,76,0.22); color:#c9a84c; }
html.dark-mode .suggestion-chips button:hover, body.dark-mode .suggestion-chips button:hover { background:#c9a84c; color:#0a1225; border-color:#c9a84c; }
html.dark-mode .suggestion-chips span, body.dark-mode .suggestion-chips span { background:rgba(201,168,76,0.1); border-color:rgba(201,168,76,0.2); color:#c9a84c; }
html.dark-mode .suggestion-chips span:hover, body.dark-mode .suggestion-chips span:hover { background:#c9a84c; color:#0a1225; border-color:#c9a84c; }

/* Analytics */
html.dark-mode .analytics-stat-card, body.dark-mode .analytics-stat-card { background:#152348; border-color:#1c3060; border-top-color:#c9a84c; }
html.dark-mode .analytics-stat-num, body.dark-mode .analytics-stat-num { color:#c9a84c; }
html.dark-mode .analytics-stat-label, body.dark-mode .analytics-stat-label { color:rgba(212,219,232,0.45); }
html.dark-mode .analytics-card, body.dark-mode .analytics-card { background:#152348; border-color:#1c3060; }
html.dark-mode .analytics-card h3, body.dark-mode .analytics-card h3 { color:#d4dbe8; }
html.dark-mode .analytics-card p, body.dark-mode .analytics-card p { color:rgba(200,212,232,0.55); }
html.dark-mode .status-bar, body.dark-mode .status-bar { background:rgba(255,255,255,0.07); }
html.dark-mode .status-bar-fill, body.dark-mode .status-bar-fill { background:linear-gradient(90deg,#c9a84c,#e8c97a); }
html.dark-mode #analytics-status-list, body.dark-mode #analytics-status-list,
html.dark-mode #analytics-case-types, body.dark-mode #analytics-case-types,
html.dark-mode #analytics-recent-activity, body.dark-mode #analytics-recent-activity { color:#c8d4e8; }
body.dark-mode .analytics-recent-name, html.dark-mode .analytics-recent-name { color:#e2e8f0; }
body.dark-mode .analytics-recent-meta, html.dark-mode .analytics-recent-meta,
body.dark-mode .analytics-recent-date, html.dark-mode .analytics-recent-date { color:#94a3b8; }
body.dark-mode .analytics-stat-count, html.dark-mode .analytics-stat-count,
body.dark-mode .analytics-type-label, html.dark-mode .analytics-type-label { color:#e2e8f0; }
body.dark-mode .analytics-type-count, html.dark-mode .analytics-type-count { color:#94a3b8; }
body.dark-mode .chart-range-btn, html.dark-mode .chart-range-btn { border-color:rgba(255,255,255,0.15); color:#94a3b8; }
body.dark-mode .chart-range-btn:hover, html.dark-mode .chart-range-btn:hover { border-color:#667eea; color:#667eea; }
body.dark-mode .chart-range-btn.active, html.dark-mode .chart-range-btn.active { background:#667eea; border-color:#667eea; color:#fff; }

/* Badges */
html.dark-mode .badge-analysis, body.dark-mode .badge-analysis { background:rgba(109,40,217,0.2); color:#b4a0ff; }
html.dark-mode .badge-draft,    body.dark-mode .badge-draft    { background:rgba(217,119,6,0.15); color:#fbbf24; }
html.dark-mode .badge-depo,     body.dark-mode .badge-depo     { background:rgba(220,38,38,0.15); color:#f87171; }
html.dark-mode .badge-timeline, body.dark-mode .badge-timeline { background:rgba(5,150,105,0.15); color:#34d399; }
html.dark-mode .badge-compare,  body.dark-mode .badge-compare  { background:rgba(67,56,202,0.15); color:#a5b4fc; }

/* Spinner */
html.dark-mode .spinner, body.dark-mode .spinner { border-color:rgba(255,255,255,0.07); border-top-color:#c9a84c; }
html.dark-mode .loading-state p, body.dark-mode .loading-state p { color:rgba(212,219,232,0.45); }

/* Doc viewer */
html.dark-mode .doc-viewer-panel, body.dark-mode .doc-viewer-panel { background:#152348; }
html.dark-mode .doc-viewer-header, body.dark-mode .doc-viewer-header { background:linear-gradient(135deg,#0c1838,#1a2f5e); border-bottom-color:rgba(201,168,76,0.18); }
html.dark-mode .doc-viewer-toolbar, body.dark-mode .doc-viewer-toolbar { background:rgba(10,20,55,0.75); border-bottom-color:#1c3060; }
html.dark-mode .doc-viewer-body, body.dark-mode .doc-viewer-body { color:#d4dbe8; }
html.dark-mode .doc-viewer-body p, html.dark-mode .doc-viewer-body span, html.dark-mode .doc-viewer-body li,
body.dark-mode .doc-viewer-body p, body.dark-mode .doc-viewer-body span, body.dark-mode .doc-viewer-body li { color:#c8d4e8; }

/* Rendered content */
html.dark-mode .rendered-content, body.dark-mode .rendered-content { color:#c8d0e0; }
html.dark-mode .rendered-content h1, body.dark-mode .rendered-content h1 { color:#d4dbe8; border-bottom-color:#c9a84c; }
html.dark-mode .rendered-content h2, body.dark-mode .rendered-content h2 { color:#d4dbe8; }
html.dark-mode .rendered-content h3, body.dark-mode .rendered-content h3 { color:#c9a84c; }
html.dark-mode .rendered-content strong, body.dark-mode .rendered-content strong { color:#d4dbe8; }
html.dark-mode .rendered-content code, body.dark-mode .rendered-content code { background:rgba(10,20,55,0.8); color:#e8c97a; }
html.dark-mode .rendered-content pre, body.dark-mode .rendered-content pre { background:rgba(10,20,55,0.8); border-color:#1c3060; }

/* Notifications */
html.dark-mode .notification, body.dark-mode .notification { background:#152348; color:#d4dbe8; border-left-color:#c9a84c; }

/* Upload zone */
html.dark-mode .upload-zone, body.dark-mode .upload-zone { background:rgba(10,20,55,0.45); border-color:rgba(201,168,76,0.22); }
html.dark-mode .upload-zone:hover, body.dark-mode .upload-zone:hover { border-color:#c9a84c; background:rgba(201,168,76,0.05); }
html.dark-mode .upload-zone p, body.dark-mode .upload-zone p { color:rgba(212,219,232,0.38); }

/* Saved items */
html.dark-mode .saved-tabs, body.dark-mode .saved-tabs { background:#152348; border-color:#1c3060; }
html.dark-mode .saved-tab-btn, body.dark-mode .saved-tab-btn { color:rgba(212,219,232,0.42); }
html.dark-mode .saved-tab-btn:hover, body.dark-mode .saved-tab-btn:hover { background:rgba(201,168,76,0.08); color:#c9a84c; }
html.dark-mode .saved-tab-btn.active, body.dark-mode .saved-tab-btn.active { background:linear-gradient(135deg,#1a2f5e,#304b84); color:#c9a84c; }
html.dark-mode .saved-card, body.dark-mode .saved-card { background:#152348; border-color:#1c3060; }
html.dark-mode .saved-card:hover, body.dark-mode .saved-card:hover { border-color:rgba(201,168,76,0.28); }
html.dark-mode .saved-card-type, body.dark-mode .saved-card-type { color:rgba(212,219,232,0.38); }
html.dark-mode .saved-card-title, body.dark-mode .saved-card-title { color:#d4dbe8; }
html.dark-mode .saved-card-preview, body.dark-mode .saved-card-preview { color:rgba(212,219,232,0.48); }
html.dark-mode .saved-card-date, body.dark-mode .saved-card-date { color:rgba(212,219,232,0.32); }

/* Timeline */
html.dark-mode .timeline-event::before, body.dark-mode .timeline-event::before { background:#c9a84c; box-shadow:0 0 0 3px rgba(201,168,76,0.15); }
html.dark-mode .timeline-event-card, body.dark-mode .timeline-event-card { background:rgba(10,20,55,0.7); border-color:#1c3060; border-left-color:#c9a84c; }
html.dark-mode .timeline-event-date, body.dark-mode .timeline-event-date { color:#c9a84c; }
html.dark-mode .timeline-event-title, body.dark-mode .timeline-event-title { color:#d4dbe8; }
html.dark-mode .timeline-event-desc, body.dark-mode .timeline-event-desc { color:rgba(212,219,232,0.58); }

/* Comparison */
html.dark-mode .compare-doc-card, body.dark-mode .compare-doc-card { background:rgba(10,20,55,0.7); border-color:#1c3060; border-top-color:#c9a84c; }
html.dark-mode .compare-doc-card h4, body.dark-mode .compare-doc-card h4 { color:#d4dbe8; }
html.dark-mode .analysis-section, body.dark-mode .analysis-section { background:rgba(10,20,55,0.65); border-left-color:#c9a84c; }
html.dark-mode .analysis-section h4, body.dark-mode .analysis-section h4 { color:#d4dbe8; }
html.dark-mode .analysis-section li, html.dark-mode .analysis-section p,
body.dark-mode .analysis-section li, body.dark-mode .analysis-section p { color:rgba(212,219,232,0.58); }

/* Scrollbar */
html.dark-mode ::-webkit-scrollbar-track, body.dark-mode ::-webkit-scrollbar-track { background:#0a1428; }
html.dark-mode ::-webkit-scrollbar-thumb, body.dark-mode ::-webkit-scrollbar-thumb { background:rgba(201,168,76,0.28); }
html.dark-mode ::-webkit-scrollbar-thumb:hover, body.dark-mode ::-webkit-scrollbar-thumb:hover { background:#c9a84c; }

/* Panel backdrop */
html.dark-mode .panel-backdrop, body.dark-mode .panel-backdrop { background:rgba(5,10,30,0.6); }

/* Welcome toast */
html.dark-mode #welcome-toast, body.dark-mode #welcome-toast { background:#152348; color:#d4dbe8; border:1px solid rgba(201,168,76,0.2); }

/* Inline style overrides for JS-generated HTML in dark mode */
html.dark-mode [style*="color:#1a2a6c"], body.dark-mode [style*="color:#1a2a6c"],
html.dark-mode [style*="color: #1a2a6c"], body.dark-mode [style*="color: #1a2a6c"] { color:#d4dbe8 !important; }
html.dark-mode [style*="color:#666"], body.dark-mode [style*="color:#666"],
html.dark-mode [style*="color: #666"], body.dark-mode [style*="color: #666"] { color:rgba(200,212,232,0.55) !important; }
html.dark-mode [style*="color:#aaa"], body.dark-mode [style*="color:#aaa"],
html.dark-mode [style*="color: #aaa"], body.dark-mode [style*="color: #aaa"] { color:rgba(200,212,232,0.45) !important; }
html.dark-mode [style*="color:#555"], body.dark-mode [style*="color:#555"] { color:rgba(200,212,232,0.6) !important; }
html.dark-mode [style*="color:#888"], body.dark-mode [style*="color:#888"],
html.dark-mode [style*="color: #888"], body.dark-mode [style*="color: #888"] { color:rgba(200,212,232,0.55) !important; }
html.dark-mode [style*="background:#fff"], body.dark-mode [style*="background:#fff"],
html.dark-mode [style*="background: #fff"], body.dark-mode [style*="background: #fff"],
html.dark-mode [style*="background:white"], body.dark-mode [style*="background:white"],
html.dark-mode [style*="background: white"], body.dark-mode [style*="background: white"] { background:#152348 !important; }
html.dark-mode [style*="background:#f8f9fc"], body.dark-mode [style*="background:#f8f9fc"],
html.dark-mode [style*="background: #f8f9fc"], body.dark-mode [style*="background: #f8f9fc"] { background:rgba(10,20,55,0.6) !important; }
html.dark-mode [style*="border-bottom: 1px solid #e5e7eb"], body.dark-mode [style*="border-bottom: 1px solid #e5e7eb"],
html.dark-mode [style*="border-bottom:1px solid #e5e7eb"], body.dark-mode [style*="border-bottom:1px solid #e5e7eb"] { border-bottom-color:rgba(201,168,76,0.1) !important; }