/* Mission Control v3 — Supliful Brand Redesign */

:root {
  /* === FONT === */
  --font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* === EMERALD (Primary Brand) === */
  --color-emerald-50: #ecfdf5;
  --color-emerald-100: #d1fae5;
  --color-emerald-200: #a7f3d0;
  --color-emerald-300: #6ee7b7;
  --color-emerald-400: #34d399;
  --color-emerald-500: #10b981;
  --color-emerald-600: #059669;
  --color-emerald-700: #047857;
  --color-emerald-800: #065f46;
  --color-emerald-900: #064e3b;

  /* === GRAY (Neutrals) === */
  --color-gray-50: #f9fafb;
  --color-gray-100: #f3f4f6;
  --color-gray-200: #e5e7eb;
  --color-gray-300: #d1d5db;
  --color-gray-400: #9ca3af;
  --color-gray-500: #6b7280;
  --color-gray-600: #4b5563;
  --color-gray-700: #374151;
  --color-gray-800: #1f2937;
  --color-gray-900: #111827;

  /* === STATUS COLORS === */
  --color-blue-50: #eff6ff;
  --color-blue-500: #3b82f6;
  --color-blue-600: #2563eb;

  --color-purple-50: #faf5ff;
  --color-purple-500: #a855f7;
  --color-purple-600: #9333ea;

  --color-orange-50: #fff7ed;
  --color-orange-500: #f97316;
  --color-orange-600: #ea580c;

  --color-red-50: #fef2f2;
  --color-red-500: #ef4444;
  --color-red-600: #dc2626;

  /* === GRADIENTS === */
  --gradient-emerald: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  --gradient-blue: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
  --gradient-purple: linear-gradient(135deg, #f3e8ff 0%, #e9d5ff 100%);
  --gradient-orange: linear-gradient(135deg, #ffedd5 0%, #fed7aa 100%);

  /* === SPACING === */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;

  /* === BORDER RADIUS === */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* === SHADOWS === */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);

  /* === TRANSITIONS === */
  --transition-fast: 150ms ease;
  --transition-default: 300ms ease;

  /* === FOCUS === */
  --focus-ring: 0 0 0 3px rgba(16, 185, 129, 0.3);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font-family);
  background: var(--color-gray-50);
  color: var(--color-gray-700);
  min-height: 100vh;
}

/* ── Layout ── */

#app-layout {
  display: flex;
  min-height: 100vh;
}

/* ── Sidebar (Light Brand) ── */

#sidebar {
  width: 260px;
  background: #fff;
  color: var(--color-gray-700);
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  overflow-y: auto;
  z-index: 100;
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--color-gray-200);
}

.sidebar-header {
  padding: var(--space-4) var(--space-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--color-gray-200);
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.sidebar-logo {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
}

.sidebar-header h1 {
  font-size: 15px;
  font-weight: 700;
  color: var(--color-gray-900);
  white-space: nowrap;
}

.sidebar-status {
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
}

.sidebar-user {
  padding: var(--space-2) var(--space-5);
}

.sidebar-nav {
  flex: 1;
  padding: var(--space-3) 0;
}

.sidebar-section-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-gray-400);
  padding: var(--space-4) var(--space-5) var(--space-2);
}

.sidebar-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  background: none;
  border: none;
  color: var(--color-gray-600);
  font-family: var(--font-family);
  font-size: 14px;
  font-weight: 500;
  text-align: left;
  padding: 10px var(--space-5);
  cursor: pointer;
  transition: all var(--transition-default);
  text-decoration: none;
  border-radius: 0;
}

.sidebar-item:hover {
  color: var(--color-gray-900);
  background: var(--color-gray-100);
}

.sidebar-item.active {
  color: var(--color-emerald-700);
  background: var(--color-emerald-50);
  font-weight: 600;
  border-right: 3px solid var(--color-emerald-500);
}

.sidebar-item.disabled {
  color: var(--color-gray-400);
  cursor: default;
  pointer-events: none;
}

.sidebar-item i {
  font-size: 20px;
  width: 20px;
  text-align: center;
}

.sidebar-agent-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  background: none;
  border: none;
  color: var(--color-gray-700);
  font-family: var(--font-family);
  font-size: 14px;
  font-weight: 600;
  text-align: left;
  padding: 10px var(--space-5);
  cursor: pointer;
  transition: all var(--transition-default);
}

.sidebar-agent-toggle:hover { color: var(--color-gray-900); background: var(--color-gray-50); }

.sidebar-agent-toggle i {
  font-size: 20px;
  width: 20px;
  text-align: center;
  color: var(--color-gray-500);
}

.sidebar-agent-toggle .toggle-arrow {
  font-size: 10px;
  transition: transform var(--transition-fast);
  width: 12px;
  color: var(--color-gray-400);
}

.sidebar-agent-toggle .toggle-arrow.collapsed {
  transform: rotate(-90deg);
}

.sidebar-agent-children {
  overflow: hidden;
  transition: max-height 0.2s ease;
}

.sidebar-agent-children .sidebar-item {
  padding-left: 52px;
  font-size: 13px;
}

.sidebar-footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.sidebar-footer .user-display {
  font-size: 13px;
  color: var(--color-gray-500);
}

.sidebar-footer .logout-btn {
  background: transparent;
  color: var(--color-gray-500);
  border: 1px solid var(--color-gray-200);
  padding: 6px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 12px;
  font-family: var(--font-family);
  font-weight: 500;
  transition: all var(--transition-default);
}

.sidebar-footer .logout-btn:hover {
  color: var(--color-gray-700);
  border-color: var(--color-gray-300);
  background: var(--color-gray-50);
}

/* ── Mobile menu button ── */

.mobile-menu-btn {
  display: none;
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 300;
  background: var(--color-emerald-500);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  padding: 8px 12px;
  font-size: 20px;
  cursor: pointer;
  transition: background var(--transition-default);
}

.mobile-menu-btn:hover {
  background: var(--color-emerald-600);
}

/* ── Main content ── */

#main-content {
  margin-left: 260px;
  flex: 1;
  min-height: 100vh;
  padding: var(--space-8) var(--space-6);
  max-width: 1100px;
}

.container {
  max-width: 960px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-4);
}

/* ── Login ── */

.login-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  background: url('/static/assets/backgrounds/background.webp') center/cover no-repeat;
  position: relative;
}

.login-wrapper::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
}

.login-card {
  background: #fff;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  padding: 48px 40px;
  width: 100%;
  max-width: 400px;
  text-align: center;
  position: relative;
  z-index: 1;
}

.login-logo {
  height: 32px;
  margin-bottom: var(--space-3);
}

.login-subtitle {
  color: var(--color-gray-500);
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: var(--space-8);
}

.login-card .form-input {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  font-size: 1rem;
  font-family: var(--font-family);
  color: var(--color-gray-900);
  margin-bottom: var(--space-4);
  transition: all var(--transition-fast);
}

.login-card .form-input::placeholder {
  color: var(--color-gray-400);
}

.login-card .form-input:focus {
  outline: none;
  border-color: var(--color-emerald-500);
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.2);
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  width: 100%;
  padding: 12px var(--space-6);
  background: var(--color-emerald-500);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-family);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-default);
}

.btn-primary:hover { background: var(--color-emerald-600); }
.btn-primary:focus { outline: none; box-shadow: var(--focus-ring); }

/* ── Error banner ── */

.error-banner {
  background: #fef2f2;
  color: #dc2626;
  border: 1px solid #fecaca;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 14px;
  display: none;
}

/* ── Shared UI ── */

.page-subtitle {
  font-size: 1.125rem;
  color: var(--color-gray-500);
  margin-bottom: var(--space-4);
}

.empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--color-gray-400);
  font-size: 1rem;
}

/* Badges */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: 500;
}

.badge-green { background: var(--color-emerald-50); color: #047857; }
.badge-yellow { background: #fef9c3; color: #854d0e; }
.badge-red { background: var(--color-red-50); color: #b91c1c; }
.badge-blue { background: var(--color-blue-50); color: #1d4ed8; }
.badge-angle { background: var(--color-purple-50); color: #7c3aed; }
.badge-gray { background: var(--color-gray-100); color: var(--color-gray-700); }
.badge-orange { background: var(--color-orange-50); color: #c2410c; }

/* Sequence card */
.seq-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: box-shadow 0.15s;
  border: 1px solid var(--color-gray-200);
}

.seq-card:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.1); }
.seq-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 8px; }
.seq-company { font-size: 18px; font-weight: 600; }
.seq-email { font-size: 13px; color: var(--color-gray-500); margin-bottom: 10px; }
.seq-meta { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.seq-date { font-size: 12px; color: var(--color-gray-400); }

/* Detail view */
.detail-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-emerald-600);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  margin-bottom: 20px;
  background: none;
  border: none;
  font-family: var(--font-family);
  transition: color var(--transition-default);
}

.detail-back:hover { text-decoration: underline; }

.detail-header {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 16px;
  border: 1px solid var(--color-gray-200);
}

.detail-header h2 { font-size: 22px; margin-bottom: 4px; }
.detail-info { font-size: 13px; color: var(--color-gray-500); margin-bottom: 12px; }
.detail-info span { margin-right: 16px; }

/* Research toggle */
.research-toggle {
  background: none;
  border: none;
  color: var(--color-emerald-600);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  margin-top: 8px;
  font-family: var(--font-family);
  transition: color var(--transition-default);
}
.research-toggle:hover { color: var(--color-emerald-700); }

.research-content {
  font-size: 14px;
  color: var(--color-gray-600);
  line-height: 1.6;
  margin-top: 8px;
  white-space: pre-wrap;
}

/* Timeline */
.timeline {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 16px 0;
  padding: 0 20px;
}

.timeline-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-emerald-500);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.timeline-line { flex: 1; height: 2px; background: var(--color-gray-300); }
.timeline-label { font-size: 11px; color: var(--color-gray-400); text-align: center; margin-top: 4px; }
.timeline-step { display: flex; flex-direction: column; align-items: center; }

/* Email card */
.email-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 12px;
  border: 1px solid var(--color-gray-200);
}

.email-card-header {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-gray-500);
  margin-bottom: 12px;
}

.email-field-label { font-size: 12px; color: var(--color-gray-400); font-weight: 600; text-transform: uppercase; margin-bottom: 4px; }

.email-subject {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 12px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: var(--radius-md);
}

.email-subject:hover { background: var(--color-gray-50); }

.email-body {
  font-size: 14px;
  line-height: 1.6;
  color: var(--color-gray-700);
  white-space: pre-wrap;
  cursor: pointer;
  padding: 8px;
  border-radius: var(--radius-md);
}

.email-body:hover { background: var(--color-gray-50); }

/* Email body rendering - restore paragraph spacing */
.email-body p,
.email-preview p {
  margin-bottom: 0.75em;
}
.email-body p:last-child {
  margin-bottom: 0;
}

/* Editing */
.edit-input {
  width: 100%;
  padding: 10px 12px;
  border: 2px solid var(--color-emerald-500);
  border-radius: var(--radius-md);
  font-size: 15px;
  font-family: var(--font-family);
  margin-bottom: 8px;
}

.edit-textarea {
  width: 100%;
  padding: 10px 12px;
  border: 2px solid var(--color-emerald-500);
  border-radius: var(--radius-md);
  font-size: 14px;
  font-family: var(--font-family);
  line-height: 1.6;
  min-height: 200px;
  resize: vertical;
  margin-bottom: 8px;
}

.edit-actions { display: flex; gap: 8px; align-items: center; }

.btn-save {
  padding: 8px 20px;
  background: var(--color-emerald-500);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-family);
  cursor: pointer;
  transition: background var(--transition-default);
}

.btn-save:hover { background: var(--color-emerald-600); }

.btn-cancel {
  padding: 8px 20px;
  background: var(--color-gray-50);
  color: var(--color-gray-500);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 13px;
  cursor: pointer;
}
.btn-cancel:hover { background: var(--color-gray-100); color: var(--color-gray-700); }

/* Action bar */
.action-bar {
  position: sticky;
  bottom: 0;
  background: #fff;
  border-top: 1px solid var(--color-gray-200);
  padding: 16px 24px;
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.05);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  margin-top: 20px;
}

.btn-approve {
  padding: 12px 28px;
  background: #16a34a;
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}

.btn-approve:hover { background: #15803d; }

.btn-reject {
  padding: 12px 28px;
  background: #fff;
  color: #dc2626;
  border: 2px solid #dc2626;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
}

.btn-reject:hover { background: #fef2f2; }

/* Modal */
.modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.4);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 200;
}

.modal {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 28px;
  width: 90%;
  max-width: 480px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.15);
}

.modal h3 { font-size: 18px; margin-bottom: 12px; }
.modal p { font-size: 14px; color: var(--color-gray-600); margin-bottom: 20px; line-height: 1.5; }

.modal textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 14px;
  font-family: inherit;
  min-height: 80px;
  resize: vertical;
  margin-bottom: 16px;
}

.modal-actions { display: flex; gap: 10px; justify-content: flex-end; }

.btn-modal-cancel {
  padding: 10px 20px;
  background: var(--color-gray-50);
  color: var(--color-gray-500);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 14px;
  cursor: pointer;
}

.btn-modal-confirm {
  padding: 10px 20px;
  border: none;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  color: #fff;
}

.btn-modal-confirm.green { background: #16a34a; }
.btn-modal-confirm.green:hover { background: #15803d; }
.btn-modal-confirm.red { background: #dc2626; }
.btn-modal-confirm.red:hover { background: #b91c1c; }

/* Tables */
.data-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-gray-200);
}

.data-table th {
  text-align: left;
  padding: 12px 16px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-gray-400);
  background: var(--color-gray-50);
  border-bottom: 1px solid var(--color-gray-200);
}

.data-table td {
  padding: 12px 16px;
  font-size: 14px;
  border-bottom: 1px solid var(--color-gray-100);
}

.data-table tr:last-child td { border-bottom: none; }
.data-table tr.clickable { cursor: pointer; }
.data-table tr.clickable:hover { background: var(--color-gray-50); }

/* Filter bar */
.filter-bar {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
  align-items: center;
}

.filter-bar select {
  padding: 8px 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 14px;
  background: #fff;
}

/* Prompt editor */
.prompt-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
}

.prompt-editor-area {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  border: 1px solid var(--color-gray-200);
}

.prompt-editor-area textarea {
  width: 100%;
  min-height: 400px;
  padding: 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 13px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  line-height: 1.6;
  resize: vertical;
}

.prompt-editor-area textarea:focus { outline: none; border-color: var(--color-emerald-500); box-shadow: 0 0 0 2px rgba(16,185,129,0.2); }

.prompt-editor-area textarea[readonly] {
  background: var(--color-gray-50);
  color: var(--color-gray-500);
}

.prompt-sidebar {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  border: 1px solid var(--color-gray-200);
  max-height: 600px;
  overflow-y: auto;
}

.prompt-sidebar h3 { font-size: 14px; font-weight: 600; margin-bottom: 12px; }

.history-item {
  padding: 10px 12px;
  border-radius: var(--radius-md);
  cursor: pointer;
  margin-bottom: 4px;
  font-size: 13px;
  border: 1px solid transparent;
}

.history-item:hover { background: var(--color-gray-50); }
.history-item.active-version { border-color: var(--color-emerald-500); background: var(--color-emerald-50); }
.history-item .version-label { font-weight: 600; }
.history-item .version-meta { color: var(--color-gray-400); font-size: 12px; margin-top: 2px; }

.prompt-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 12px;
  cursor: pointer;
  border: 1px solid var(--color-gray-200);
  transition: box-shadow 0.15s;
}

.prompt-card:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.1); }
.prompt-card-title { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.prompt-card-meta { font-size: 13px; color: var(--color-gray-400); }

/* Dashboard */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.stat-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5);
  border: 1px solid var(--color-gray-200);
  transition: box-shadow var(--transition-default);
}

.stat-card:hover {
  box-shadow: var(--shadow-md);
}

.stat-card-label { font-size: 0.75rem; color: var(--color-gray-500); font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: var(--space-1); }
.stat-card-value { font-size: 1.875rem; font-weight: 700; color: var(--color-gray-900); }
.stat-card-sub { font-size: 0.875rem; color: var(--color-gray-500); margin-top: var(--space-1); }
.stat-section { margin-bottom: var(--space-6); }
.stat-section h3 { font-size: 1rem; font-weight: 600; color: var(--color-gray-900); margin-bottom: var(--space-3); }

.stat-bar {
  height: 8px;
  background: var(--color-gray-200);
  border-radius: 4px;
  overflow: hidden;
  margin-top: 8px;
}

.stat-bar-fill { height: 100%; border-radius: 4px; transition: width 0.3s; }

.cron-row {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-gray-100);
  font-size: 14px;
}

.cron-row:last-child { border-bottom: none; }

/* Channel form */
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--color-gray-600); margin-bottom: 4px; }

.form-group input, .form-group select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 14px;
}

.form-group input:focus, .form-group select:focus { outline: none; border-color: var(--color-emerald-500); box-shadow: 0 0 0 2px rgba(16,185,129,0.2); }

.form-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 24px;
  border: 1px solid var(--color-gray-200);
  max-width: 560px;
}

/* Reports */
.reports-stats-bar {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.reports-stat-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  text-align: center;
  border: 1px solid var(--color-gray-200);
}

.reports-stat-value { font-size: 28px; font-weight: 700; color: var(--color-gray-900); }
.reports-stat-label { font-size: 12px; color: var(--color-gray-400); margin-top: 4px; }

.reports-filters {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.reports-filters select, .reports-filters input {
  padding: 8px 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 13px;
  background: #fff;
}

.reports-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--color-gray-200);
  margin-bottom: 16px;
}

.reports-tab {
  padding: 10px 20px;
  border: none;
  background: none;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-gray-400);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}

.reports-tab:hover { color: var(--color-gray-900); }
.reports-tab.active { color: var(--color-emerald-600); border-bottom-color: var(--color-emerald-500); }

.reports-actions {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}

.btn-sync {
  padding: 8px 18px;
  background: var(--color-emerald-500);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-family);
  cursor: pointer;
  transition: background var(--transition-default);
}

.btn-sync:hover { background: var(--color-emerald-600); }

.btn-export {
  padding: 8px 18px;
  background: #fff;
  color: var(--color-gray-900);
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 13px;
  cursor: pointer;
}

.btn-export:hover { background: var(--color-gray-50); }

.funnel-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  font-size: 13px;
}

.funnel-table th {
  background: var(--color-gray-100);
  padding: 10px 12px;
  text-align: left;
  font-weight: 600;
  color: var(--color-gray-600);
  border-bottom: 2px solid var(--color-gray-200);
  white-space: nowrap;
}

.funnel-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--color-gray-100);
  vertical-align: middle;
}

.funnel-table tr:hover td { background: var(--color-gray-50); }
.funnel-table .rate { font-size: 11px; color: var(--color-gray-400); display: block; }
.funnel-table .rate-good { color: #16a34a; }
.funnel-table .rate-bad { color: #dc2626; }

.source-row { cursor: pointer; }
.source-row:hover td { background: var(--color-emerald-50); }

.velocity-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  border: 1px solid var(--color-gray-200);
}

.velocity-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 16px;
}

.velocity-stage {
  text-align: center;
  padding: 16px;
  background: var(--color-gray-100);
  border-radius: var(--radius-md);
}

.velocity-days { font-size: 32px; font-weight: 700; color: var(--color-emerald-600); }
.velocity-label { font-size: 12px; color: var(--color-gray-400); margin-top: 4px; }

/* Loading */
.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-gray-200);
  border-top-color: var(--color-emerald-500);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

.loading-center { text-align: center; padding: 40px; }

/* ── System Health ── */

.health-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.health-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  border: 1px solid var(--color-gray-200);
}

.health-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.health-dot { font-size: 16px; }

.health-card-meta {
  font-size: 13px;
  color: var(--color-gray-400);
  margin-top: 4px;
}

.registry-service-card {
  cursor: pointer;
  transition: box-shadow 0.15s;
}

.registry-service-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}

/* Alerts */
.alert-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  margin-bottom: 12px;
  border: 1px solid var(--color-gray-200);
}

.alert-resolved {
  opacity: 0.7;
}

.alert-card-header {
  display: flex;
  align-items: center;
  margin-bottom: 8px;
}

.alert-card-message {
  font-size: 14px;
  color: var(--color-gray-700);
  margin-bottom: 8px;
  line-height: 1.5;
}

.alert-card-meta {
  font-size: 12px;
  color: var(--color-gray-400);
  margin-bottom: 8px;
}

.alert-card-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

/* ── Build Log ── */

.build-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px 20px;
  margin-bottom: 12px;
  border: 1px solid var(--color-gray-200);
}

.build-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}

.build-card-header .toggle-arrow {
  font-size: 10px;
  transition: transform 0.15s;
  color: var(--color-gray-400);
}

.build-card-header .toggle-arrow.collapsed {
  transform: rotate(-90deg);
}

.build-card-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
}

.build-card-summary {
  font-size: 14px;
  color: var(--color-gray-500);
  margin-top: 8px;
  line-height: 1.5;
}

.build-card-detail {
  margin-top: 16px;
  border-top: 1px solid var(--color-gray-100);
  padding-top: 16px;
}

.build-detail-section {
  margin-bottom: 16px;
}

.build-detail-section h4 {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-gray-600);
  margin-bottom: 8px;
}

.build-detail-section ul {
  padding-left: 20px;
  font-size: 14px;
  color: var(--color-gray-600);
  line-height: 1.6;
}

.build-change-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.build-change-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}

/* ── Command Center Dashboard ── */

.cmd-agent-card {
  transition: box-shadow 0.15s;
}

.cmd-agent-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}

.cmd-stat-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  font-size: 14px;
  border-bottom: 1px solid var(--color-gray-100);
}

.cmd-stat-row:last-child {
  border-bottom: none;
}

.cmd-health-card {
  transition: box-shadow 0.15s;
}

.cmd-health-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
}

/* ── Audrey Overview ── */

.overview-hero {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 24px;
  margin-bottom: 24px;
  border: 1px solid var(--color-gray-200);
}

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

.overview-subagent-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.overview-subagent {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  border: 1px solid var(--color-gray-200);
}

.overview-pipeline-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 24px;
  border: 1px solid var(--color-gray-200);
}

.overview-pipeline-flow {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
  row-gap: 12px;
}

.overview-pipeline-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 70px;
}

.overview-pipeline-dot {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
}

.overview-pipeline-label {
  font-size: 11px;
  color: var(--color-gray-500);
  text-align: center;
  max-width: 80px;
  min-height: 2.4em;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  line-height: 1.2;
}

.overview-pipeline-arrow {
  font-size: 18px;
  color: var(--color-gray-300);
  padding: 0 6px;
  margin-top: 10px;
}

.overview-systems-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
}

.overview-system {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 16px;
  border: 1px solid var(--color-gray-200);
}

.overview-config-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.overview-config-item {
  padding: 8px 0;
}

.overview-config-label {
  font-size: 12px;
  color: var(--color-gray-400);
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.overview-config-value {
  font-size: 14px;
  color: var(--color-gray-900);
  word-break: break-word;
}

.overview-desc {
  margin-top: 12px;
  line-height: 1.6;
  color: var(--color-gray-600);
}

.overview-meta {
  margin-top: 12px;
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--color-gray-500);
}

.overview-subagent-desc {
  font-size: 13px;
  color: var(--color-gray-600);
  line-height: 1.5;
  margin-bottom: 8px;
}

.overview-system-role {
  font-size: 13px;
  color: var(--color-gray-500);
}

.overview-pipeline-outcomes {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-top: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--color-gray-100);
}

.reports-totals-row {
  font-weight: 700;
  background: var(--color-gray-100);
}

/* ── Dark Mode Toggle ── */

.dark-toggle {
  background: transparent;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
  padding: 6px 10px;
  font-size: 18px;
  cursor: pointer;
  line-height: 1;
  color: var(--color-gray-500);
  display: flex;
  align-items: center;
  transition: all var(--transition-default);
}

.dark-toggle:hover { border-color: var(--color-gray-300); color: var(--color-gray-700); }

body.dark .dark-toggle {
  border-color: #333;
  color: #888;
}

body.dark .dark-toggle:hover {
  border-color: #555;
  color: #fff;
}

/* ── Dark Mode ── */

body.dark {
  background: #111118;
  color: #e0e0e8;
}

body.dark #sidebar {
  background: #0d0d14;
  border-right: 1px solid #1e1e2e;
}

body.dark .sidebar-header {
  border-bottom-color: #1e1e2e;
}

body.dark .sidebar-header h1 {
  color: #fff;
}

body.dark .sidebar-item {
  color: #aaa;
}

body.dark .sidebar-item:hover {
  color: #fff;
  background: rgba(255,255,255,0.05);
}

body.dark .sidebar-item.active {
  background: rgba(16, 185, 129, 0.15);
  color: var(--color-emerald-400);
  border-right-color: var(--color-emerald-500);
}

body.dark .sidebar-agent-toggle {
  color: #ccc;
}

body.dark .sidebar-agent-toggle:hover {
  color: #fff;
  background: rgba(255,255,255,0.03);
}

body.dark .sidebar-agent-toggle i {
  color: #888;
}

body.dark .sidebar-footer {
  border-top-color: #1e1e2e;
}

body.dark .sidebar-footer .logout-btn {
  color: #888;
  border-color: #333;
}

body.dark .sidebar-footer .logout-btn:hover {
  color: #fff;
  border-color: #555;
  background: rgba(255,255,255,0.05);
}

body.dark #main-content {
  background: #111118;
}

/* Cards & containers */
body.dark .stat-card,
body.dark .seq-card,
body.dark .health-card,
body.dark .alert-card,
body.dark .build-card,
body.dark .email-card,
body.dark .detail-header,
body.dark .prompt-card,
body.dark .prompt-editor-area,
body.dark .prompt-sidebar,
body.dark .form-card,
body.dark .velocity-card,
body.dark .overview-hero,
body.dark .overview-subagent,
body.dark .overview-pipeline-card,
body.dark .overview-system {
  background: #1e1e2e;
  border-color: #2a2a3e;
  box-shadow: 0 1px 6px rgba(0,0,0,0.3);
}

body.dark .seq-card:hover,
body.dark .prompt-card:hover,
body.dark .registry-service-card:hover,
body.dark .cmd-agent-card:hover,
body.dark .cmd-health-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
}

/* Text colors */
body.dark .seq-company,
body.dark .stat-card-value,
body.dark .reports-stat-value,
body.dark .prompt-card-title,
body.dark .build-card-title,
body.dark .detail-header h2,
body.dark .overview-config-value {
  color: #e0e0e8;
}

body.dark .stat-card-label,
body.dark .stat-card-sub,
body.dark .seq-date,
body.dark .seq-email,
body.dark .health-card-meta,
body.dark .alert-card-meta,
body.dark .detail-info,
body.dark .prompt-card-meta,
body.dark .reports-stat-label,
body.dark .build-card-summary,
body.dark .overview-config-label,
body.dark .overview-pipeline-label {
  color: #888;
}

body.dark .alert-card-message,
body.dark .research-content,
body.dark .email-body,
body.dark .build-detail-section ul {
  color: #ccc;
}

body.dark h2, body.dark h3, body.dark h4 {
  color: #e0e0e8;
}

body.dark .page-subtitle {
  color: #999;
}

body.dark .empty-state {
  color: #666;
}

/* Tables */
body.dark .data-table,
body.dark .funnel-table {
  background: #1e1e2e;
  border-color: #2a2a3e;
  box-shadow: 0 1px 6px rgba(0,0,0,0.3);
}

body.dark .data-table th,
body.dark .funnel-table th {
  background: #16162a;
  border-bottom-color: #2a2a3e;
  color: #999;
}

body.dark .data-table td,
body.dark .funnel-table td {
  border-bottom-color: #252540;
  color: #ccc;
}

body.dark .data-table tr.clickable:hover,
body.dark .funnel-table tr:hover td {
  background: #252540;
}

/* Inputs & selects */
body.dark .form-group input,
body.dark .form-group select,
body.dark .filter-bar select,
body.dark .reports-filters select,
body.dark .reports-filters input,
body.dark .login-card input,
body.dark .edit-input,
body.dark .edit-textarea,
body.dark .prompt-editor-area textarea,
body.dark .modal textarea {
  background: #16162a;
  border-color: #3a3a4e;
  color: #e0e0e8;
}

body.dark .form-group input:focus,
body.dark .form-group select:focus,
body.dark .edit-input:focus,
body.dark .edit-textarea:focus,
body.dark .prompt-editor-area textarea:focus {
  border-color: var(--color-emerald-500);
}

body.dark .prompt-editor-area textarea[readonly] {
  background: #12122a;
  color: #888;
}

/* Buttons */
body.dark .btn-export {
  background: #1e1e2e;
  border-color: #3a3a4e;
  color: #ccc;
}

body.dark .btn-export:hover {
  background: #252540;
}

body.dark .btn-cancel {
  background: #1e1e2e;
  border-color: #3a3a4e;
  color: #ccc;
}

body.dark .btn-modal-cancel {
  background: #1e1e2e;
  border-color: #3a3a4e;
  color: #ccc;
}

body.dark .btn-reject {
  border-color: #dc2626;
  background: transparent;
}

body.dark .btn-reject:hover {
  background: #2a1a1a;
}

body.dark .sidebar-footer .logout-btn {
  border-color: #3a3a4e;
}

/* Reports tabs */
body.dark .reports-tab {
  color: #888;
}

body.dark .reports-tab:hover {
  color: #e0e0e8;
}

body.dark .reports-tab.active {
  color: var(--color-emerald-400);
}

body.dark .reports-stats-bar .reports-stat-card {
  background: #1e1e2e;
  border-color: #2a2a3e;
  box-shadow: 0 1px 6px rgba(0,0,0,0.3);
}

/* History / version items */
body.dark .history-item:hover {
  background: #252540;
}

body.dark .history-item.active-version {
  border-color: var(--color-emerald-500);
  background: rgba(16, 185, 129, 0.1);
}

/* Velocity */
body.dark .velocity-stage {
  background: #16162a;
}

body.dark .velocity-label {
  color: #888;
}

/* Timeline */
body.dark .timeline-line {
  background: #3a3a4e;
}

/* Cron rows */
body.dark .cron-row {
  border-bottom-color: #252540;
}

body.dark .cmd-stat-row {
  border-bottom-color: #252540;
}

/* Email hover */
body.dark .email-subject:hover,
body.dark .email-body:hover {
  background: #252540;
}

/* Modal */
body.dark .modal-overlay {
  background: rgba(0,0,0,0.6);
}

body.dark .modal {
  background: #1e1e2e;
  box-shadow: 0 8px 30px rgba(0,0,0,0.4);
}

body.dark .modal h3 {
  color: #e0e0e8;
}

body.dark .modal p {
  color: #999;
}

/* Login */
body.dark .login-wrapper {
  background: #111118;
}

body.dark .login-card {
  background: #1e1e2e;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4);
}

body.dark .login-card p {
  color: #888;
}

/* Error banner */
body.dark .error-banner {
  background: #2a1a1a;
  border-color: #5a2a2a;
}

/* Action bar */
body.dark .action-bar {
  background: #1e1e2e;
  border-top-color: #2a2a3e;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.3);
}

/* Stat bar */
body.dark .stat-bar {
  background: #2a2a3e;
}

/* Mobile */
body.dark .mobile-menu-btn {
  background: #0d0d18;
}

/* Alert resolved */
body.dark .alert-resolved {
  opacity: 0.6;
}

/* Section labels in sidebar */
body.dark .sidebar-section-label {
  color: #555;
}

/* Research toggle */
body.dark .research-toggle {
  color: var(--color-emerald-400);
}

/* Detail back */
body.dark .detail-back {
  color: var(--color-emerald-400);
}

/* Overview dark overrides */
body.dark .overview-desc {
  color: #bbb;
}

body.dark .overview-meta {
  color: #999;
}

body.dark .overview-subagent-desc {
  color: #aaa;
}

body.dark .overview-system-role {
  color: #999;
}

body.dark .overview-pipeline-outcomes {
  border-top-color: #2a2a3e;
}

/* Reports totals dark override */
body.dark .reports-totals-row {
  background: #16162a;
}

body.dark .reports-totals-row td {
  color: #e0e0e8;
}

/* Badges dark override */
body.dark .badge-green { background: #16352a; color: #4ade80; }
body.dark .badge-yellow { background: #332b10; color: #facc15; }
body.dark .badge-red { background: #351a1a; color: #f87171; }
body.dark .badge-blue { background: #1a2540; color: #60a5fa; }
body.dark .badge-angle { background: #251a40; color: #a78bfa; }
body.dark .badge-gray { background: #2a2a3e; color: #aaa; }
body.dark .badge-orange { background: #332210; color: #fb923c; }

/* ── Intelligence Pages ── */

.intel-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}

.intel-service-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  border: 1px solid var(--color-gray-200);
}

.intel-service-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.intel-service-name {
  font-size: 16px;
}

.intel-service-desc {
  font-size: 13px;
  color: var(--color-gray-600);
  line-height: 1.5;
  margin-bottom: 12px;
}

.intel-service-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.intel-meta-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.intel-meta-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--color-gray-400);
  min-width: 80px;
}

/* Contact Lookup */

.intel-lookup-bar {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.intel-lookup-input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 15px;
}

.intel-lookup-input:focus {
  outline: none;
  border-color: var(--color-emerald-500);
}

/* Profile Card */

.intel-profile-card {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 24px;
  border: 1px solid var(--color-gray-200);
  margin-bottom: 16px;
}

.intel-profile-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 16px;
}

.intel-profile-name {
  font-size: 20px;
  font-weight: 600;
  margin: 0 0 4px;
}

.intel-profile-company {
  font-size: 14px;
  color: var(--color-gray-500);
}

/* Engagement Stats Grid */

.intel-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
  padding: 16px;
  background: var(--color-gray-100);
  border-radius: var(--radius-md);
}

.intel-stat {
  text-align: center;
}

.intel-stat-label {
  font-size: 11px;
  color: var(--color-gray-400);
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.intel-stat-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-gray-900);
}

/* Topic Tags */

.intel-topics {
  margin-bottom: 12px;
}

.intel-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.intel-tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-lg);
  font-size: 12px;
  font-weight: 500;
}

.intel-tag-green {
  background: #dcfce7;
  color: #166534;
}

.intel-tag-red {
  background: #fef2f2;
  color: #dc2626;
}

/* AI Summary */

.intel-summary {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--color-gray-100);
}

.intel-summary-text {
  font-size: 14px;
  line-height: 1.7;
  color: var(--color-gray-700);
  margin-top: 8px;
  white-space: pre-wrap;
}

/* Interaction Timeline */

.intel-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.intel-timeline-item {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--color-gray-100);
}

.intel-timeline-item:last-child {
  border-bottom: none;
}

.intel-timeline-dot {
  flex-shrink: 0;
}

.intel-timeline-content {
  flex: 1;
}

.intel-timeline-subject {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 4px;
}

.intel-timeline-summary {
  font-size: 13px;
  color: var(--color-gray-600);
  line-height: 1.5;
}

.intel-timeline-date {
  font-size: 12px;
  color: var(--color-gray-400);
  margin-top: 4px;
}

/* ── Cron Execute Now Button ── */

.cron-execute-btn {
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 500;
  background: transparent;
  color: var(--color-emerald-500);
  border: 1px solid var(--color-emerald-500);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.cron-execute-btn:hover {
  background: var(--color-emerald-500);
  color: #fff;
}

.cron-execute-btn:disabled {
  opacity: 0.6;
  cursor: default;
}

.cron-execute-btn .spinner {
  width: 12px;
  height: 12px;
  border-width: 2px;
}

.cron-execute-btn.success {
  border-color: #16a34a;
  color: #16a34a;
  background: rgba(22, 163, 74, 0.08);
}

.cron-execute-btn.error {
  border-color: #dc2626;
  color: #dc2626;
  background: rgba(220, 38, 38, 0.08);
}

/* ── Intelligence Dark Mode ── */

body.dark .intel-service-card,
body.dark .intel-profile-card {
  background: #1e1e2e;
  border-color: #2a2a3e;
  box-shadow: 0 1px 6px rgba(0,0,0,0.3);
}

body.dark .intel-service-desc {
  color: #aaa;
}

body.dark .intel-profile-company {
  color: #999;
}

body.dark .intel-stats-grid {
  background: #16162a;
}

body.dark .intel-stat-value {
  color: #e0e0e8;
}

body.dark .intel-stat-label {
  color: #888;
}

body.dark .intel-summary {
  border-top-color: #2a2a3e;
}

body.dark .intel-summary-text {
  color: #ccc;
}

body.dark .intel-timeline-item {
  border-bottom-color: #252540;
}

body.dark .intel-timeline-subject {
  color: #e0e0e8;
}

body.dark .intel-timeline-summary {
  color: #aaa;
}

body.dark .intel-timeline-date {
  color: #888;
}

body.dark .intel-tag-green {
  background: #16352a;
  color: #4ade80;
}

body.dark .intel-tag-red {
  background: #351a1a;
  color: #f87171;
}

body.dark .intel-lookup-input {
  background: #16162a;
  border-color: #3a3a4e;
  color: #e0e0e8;
}

body.dark .intel-lookup-input:focus {
  border-color: var(--color-emerald-500);
}

body.dark .intel-service-name,
body.dark .intel-profile-name {
  color: #e0e0e8;
}

/* Cron Execute Dark Mode */

body.dark .cron-execute-btn {
  color: var(--color-emerald-400);
  border-color: var(--color-emerald-400);
}

body.dark .cron-execute-btn:hover {
  background: var(--color-emerald-500);
  color: #fff;
}

body.dark .cron-execute-btn.success {
  border-color: #4ade80;
  color: #4ade80;
  background: rgba(74, 222, 128, 0.1);
}

body.dark .cron-execute-btn.error {
  border-color: #f87171;
  color: #f87171;
  background: rgba(248, 113, 113, 0.1);
}

/* Utility */
.hidden { display: none !important; }

/* Responsive */
@media (max-width: 768px) {
  .reports-stats-bar { grid-template-columns: repeat(2, 1fr); }
  .velocity-grid { grid-template-columns: repeat(2, 1fr); }
  .prompt-grid { grid-template-columns: 1fr; }

  #sidebar {
    transform: translateX(-100%);
    transition: transform 0.2s;
    z-index: 200;
  }

  #sidebar.open {
    transform: translateX(0);
  }

  #main-content {
    margin-left: 0;
  }

  .mobile-menu-btn {
    display: block !important;
  }

  .mobile-overlay {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.4);
    z-index: 150;
  }
}

@media (min-width: 769px) {
  .mobile-menu-btn { display: none !important; }
}

@media (max-width: 640px) {
  .container { padding: 16px 12px; }
  .action-bar { flex-direction: column; }
  .btn-approve, .btn-reject { width: 100%; text-align: center; }
  .seq-meta { flex-direction: column; align-items: flex-start; }
  .timeline { padding: 0; }
}

/* ================================================================
   WIKI STYLES
   ================================================================ */

/* Filter bar */
.wiki-filter-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  align-items: center;
}

.wiki-filter-bar select,
.wiki-filter-bar input[type="text"] {
  padding: 8px 12px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 13px;
  background: #fff;
}

.wiki-filter-bar input[type="text"] {
  min-width: 200px;
}

/* Section headers */
.wiki-section-header {
  font-size: 12px;
  font-weight: 700;
  color: var(--color-gray-400);
  letter-spacing: 0.5px;
  margin: 20px 0 10px;
}

/* Card grid */
.wiki-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 12px;
}

/* Cards */
.wiki-card {
  background: #fff;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  cursor: pointer;
  transition: box-shadow 0.15s, border-color 0.15s;
}

.wiki-card:hover {
  box-shadow: 0 2px 10px rgba(0,0,0,0.08);
  border-color: var(--color-gray-300);
}

.wiki-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.wiki-card-title {
  font-weight: 600;
  font-size: 14px;
  color: var(--color-gray-900);
}

.wiki-card-meta {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.wiki-card-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--color-gray-400);
}

.wiki-card-counts {
  display: flex;
  gap: 10px;
}

.wiki-card-links {
  margin-top: 6px;
}

.wiki-hs-link {
  font-size: 12px;
  color: var(--color-emerald-500);
}

/* Pinned section */
.wiki-pinned-section {
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--radius-lg);
  padding: 12px 16px;
  margin-bottom: 16px;
}

.wiki-pinned-section .wiki-section-header {
  margin-top: 0;
  color: #92400e;
}

/* Doc type badges */
.wiki-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

.wiki-badge-blue { background: #dbeafe; color: #1e40af; }
.wiki-badge-green { background: #dcfce7; color: #166534; }
.wiki-badge-purple { background: #ede9fe; color: #5b21b6; }
.wiki-badge-indigo { background: #e0e7ff; color: #3730a3; }
.wiki-badge-red { background: #fef2f2; color: #dc2626; }
.wiki-badge-orange { background: #fff3e0; color: #e65100; }
.wiki-badge-teal { background: #ccfbf1; color: #0f766e; }
.wiki-badge-gray { background: var(--color-gray-100); color: var(--color-gray-700); }
.wiki-badge-yellow { background: #fef9c3; color: #854d0e; }
.wiki-badge-cyan { background: #cffafe; color: #0e7490; }

/* Status badges */
.wiki-status {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

.wiki-status-active { background: #dcfce7; color: #166534; }
.wiki-status-draft { background: var(--color-gray-100); color: var(--color-gray-500); }
.wiki-status-review { background: #fef9c3; color: #854d0e; }
.wiki-status-archived { background: var(--color-gray-100); color: var(--color-gray-400); text-decoration: line-through; }
.wiki-status-deprecated { background: #fef2f2; color: #dc2626; text-decoration: line-through; }

/* Role tags */
.wiki-role-tag {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 11px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
}

/* Detail view */
.wiki-detail {
  max-width: 900px;
}

.wiki-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.wiki-detail-meta {
  margin-top: 8px;
  font-size: 13px;
  color: var(--color-gray-400);
}

/* Tabs */
.wiki-tabs {
  display: flex;
  border-bottom: 2px solid var(--color-gray-200);
  margin-bottom: 16px;
  gap: 0;
}

.wiki-tab {
  padding: 8px 16px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-gray-400);
  transition: color 0.15s, border-color 0.15s;
}

.wiki-tab:hover {
  color: var(--color-gray-700);
}

.wiki-tab.active {
  color: var(--color-emerald-600);
  border-bottom-color: var(--color-emerald-500);
}

.wiki-tab-panel {
  min-height: 100px;
}

/* Markdown content */
.wiki-markdown-content {
  line-height: 1.7;
  font-size: 14px;
}

.wiki-markdown-content h1 { font-size: 1.6em; margin: 20px 0 10px; }
.wiki-markdown-content h2 { font-size: 1.35em; margin: 18px 0 8px; }
.wiki-markdown-content h3 { font-size: 1.15em; margin: 16px 0 6px; }
.wiki-markdown-content p { margin: 8px 0; }
.wiki-markdown-content ul, .wiki-markdown-content ol { padding-left: 24px; margin: 8px 0; }
.wiki-markdown-content li { margin: 4px 0; }

.wiki-markdown-content code {
  background: var(--color-gray-100);
  padding: 2px 5px;
  border-radius: 3px;
  font-size: 13px;
}

.wiki-markdown-content pre {
  background: var(--color-gray-100);
  padding: 12px 16px;
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin: 12px 0;
}

.wiki-markdown-content pre code {
  background: none;
  padding: 0;
}

.wiki-markdown-content blockquote {
  border-left: 3px solid var(--color-gray-300);
  padding-left: 12px;
  margin: 12px 0;
  color: var(--color-gray-500);
}

.wiki-markdown-content table {
  border-collapse: collapse;
  margin: 12px 0;
  width: 100%;
}

.wiki-markdown-content th,
.wiki-markdown-content td {
  border: 1px solid var(--color-gray-200);
  padding: 8px 12px;
  text-align: left;
  font-size: 13px;
}

.wiki-markdown-content th {
  background: var(--color-gray-50);
  font-weight: 600;
}

/* Linked entries */
.wiki-linked-entries {
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--color-gray-200);
}

.wiki-link-item {
  padding: 6px 8px;
  cursor: pointer;
  border-radius: var(--radius-md);
  font-size: 13px;
}

.wiki-link-item:hover {
  background: var(--color-gray-100);
}

/* Form */
.wiki-form {
  max-width: 900px;
}

.wiki-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.wiki-form-full {
  grid-column: 1 / -1;
}

.wiki-form-group label {
  display: block;
  font-weight: 600;
  font-size: 13px;
  margin-bottom: 4px;
  color: var(--color-gray-700);
}

.wiki-form-group input[type="text"],
.wiki-form-group select,
.wiki-form-group textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--color-gray-300);
  border-radius: var(--radius-md);
  font-size: 14px;
  box-sizing: border-box;
}

.wiki-checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
}

.wiki-checkbox-label {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 400 !important;
  cursor: pointer;
}

/* ================================================================
   WIKI DARK MODE
   ================================================================ */

body.dark .wiki-card {
  background: #1e1e2e;
  border-color: #2a2a3e;
}

body.dark .wiki-card:hover {
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
  border-color: #3a3a4e;
}

body.dark .wiki-card-title {
  color: #e0e0e8;
}

body.dark .wiki-card-footer,
body.dark .wiki-card-date,
body.dark .wiki-detail-meta {
  color: #888;
}

body.dark .wiki-pinned-section {
  background: #2a2518;
  border-color: #4a3f1e;
}

body.dark .wiki-pinned-section .wiki-section-header {
  color: #c9a22e;
}

body.dark .wiki-section-header {
  color: #999;
}

body.dark .wiki-role-tag {
  background: #252540;
  color: #aaa;
}

body.dark .wiki-filter-bar select,
body.dark .wiki-filter-bar input[type="text"] {
  background: #16162a;
  border-color: #3a3a4e;
  color: #e0e0e8;
}

body.dark .wiki-tabs {
  border-bottom-color: #2a2a3e;
}

body.dark .wiki-tab {
  color: #888;
}

body.dark .wiki-tab:hover {
  color: #e0e0e8;
}

body.dark .wiki-tab.active {
  color: var(--color-emerald-400);
  border-bottom-color: var(--color-emerald-400);
}

body.dark .wiki-markdown-content {
  color: #ccc;
}

body.dark .wiki-markdown-content code {
  background: #252540;
  color: #ccc;
}

body.dark .wiki-markdown-content pre {
  background: #16162a;
}

body.dark .wiki-markdown-content blockquote {
  border-left-color: #3a3a4e;
  color: #999;
}

body.dark .wiki-markdown-content th {
  background: #16162a;
  color: #999;
  border-color: #2a2a3e;
}

body.dark .wiki-markdown-content td {
  border-color: #2a2a3e;
  color: #ccc;
}

body.dark .wiki-linked-entries {
  border-top-color: #2a2a3e;
}

body.dark .wiki-link-item:hover {
  background: #252540;
}

body.dark .wiki-form-group label {
  color: #ccc;
}

body.dark .wiki-form-group input[type="text"],
body.dark .wiki-form-group select,
body.dark .wiki-form-group textarea {
  background: #16162a;
  border-color: #3a3a4e;
  color: #e0e0e8;
}

/* EasyMDE dark mode */
body.dark .EasyMDEContainer .CodeMirror {
  background: #16162a;
  color: #e0e0e8;
  border-color: #3a3a4e;
}

body.dark .EasyMDEContainer .editor-toolbar {
  background: #1e1e2e;
  border-color: #3a3a4e;
}

body.dark .EasyMDEContainer .editor-toolbar button {
  color: #ccc !important;
}

body.dark .EasyMDEContainer .editor-toolbar button:hover,
body.dark .EasyMDEContainer .editor-toolbar button.active {
  background: #252540;
}

body.dark .EasyMDEContainer .editor-preview {
  background: #16162a;
  color: #ccc;
}

body.dark .EasyMDEContainer .editor-preview-side {
  background: #16162a;
  color: #ccc;
  border-color: #3a3a4e;
}

body.dark .EasyMDEContainer .CodeMirror-cursor {
  border-left-color: #e0e0e8;
}

/* Wiki — Version history */
.wiki-version-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.wiki-version-card {
  padding: 12px 16px;
  border: 1px solid var(--border, var(--color-gray-200));
  border-radius: var(--radius-md);
  background: var(--card-bg, #fff);
}

.wiki-version-current {
  border-color: #10b981;
  background: #f0fdf4;
}

body.dark .wiki-version-card {
  background: #1e1e2e;
  border-color: #2a2a3e;
}

body.dark .wiki-version-current {
  border-color: #10b981;
  background: #0f2a1e;
}

/* Wiki — Attachments */
.wiki-attachment-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.wiki-attachment-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--border, var(--color-gray-200));
  border-radius: var(--radius-md);
}

body.dark .wiki-attachment-row {
  border-color: #2a2a3e;
}

/* Wiki — Modal overlay (for version view) */
.wiki-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.wiki-modal {
  background: var(--card-bg, #fff);
  border-radius: var(--radius-lg);
  padding: 24px;
  max-width: 800px;
  width: 90%;
  max-height: 80vh;
  overflow: auto;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}

body.dark .wiki-modal {
  background: #1e1e2e;
}

/* Wiki — Comments */
.wiki-comment-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.wiki-comment {
  padding: 12px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border, var(--color-gray-200));
}

.wiki-comment-open {
  border-left: 3px solid #f59e0b;
}

.wiki-comment-resolved {
  border-left: 3px solid #10b981;
  opacity: 0.7;
}

body.dark .wiki-comment {
  border-color: #2a2a3e;
}

body.dark .wiki-comment-open {
  border-left-color: #f59e0b;
}

body.dark .wiki-comment-resolved {
  border-left-color: #10b981;
}

/* Wiki — Needs review banner */
.wiki-review-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  margin-bottom: 16px;
  background: #fef3c7;
  border: 1px solid #f59e0b;
  border-radius: var(--radius-md);
  color: #92400e;
  font-size: 14px;
}

body.dark .wiki-review-banner {
  background: #422006;
  border-color: #f59e0b;
  color: #fef3c7;
}

/* ============================================================
   Collapsible sidebar sections (Session 28)
   ============================================================ */

.nav-section-header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-gray-400);
  padding: var(--space-4) var(--space-5) var(--space-2);
  cursor: pointer;
  user-select: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color var(--transition-default);
}

.nav-section-header:hover {
  color: var(--color-gray-600);
}

body.dark .nav-section-header {
  color: #666;
}

.nav-section-items {
  overflow: hidden;
  transition: max-height 0.2s ease, opacity 0.2s ease;
  max-height: 600px;
  opacity: 1;
}

.nav-section-items.collapsed {
  max-height: 0;
  opacity: 0;
}

.chevron {
  font-style: normal;
  font-size: 10px;
  transition: transform 0.2s ease;
  display: inline-block;
}

.chevron.collapsed {
  transform: rotate(-90deg);
}

/* ================================================================
   REPORTS V2 STYLES (Session 41)
   ================================================================ */

.rpt-header { margin-bottom: 0; }

.rpt-sync-bar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 16px; padding: 10px 16px;
  background: var(--color-gray-50); border-radius: var(--radius-lg); border: 1px solid var(--color-gray-200);
}
.rpt-sync-info { font-size: 13px; color: var(--color-gray-600); display: flex; align-items: center; gap: 6px; }
.rpt-sync-actions { display: flex; gap: 4px; }
.rpt-action-btn {
  width: 32px; height: 32px; border: 1px solid var(--color-gray-200); border-radius: var(--radius-md);
  background: #fff; color: var(--color-gray-600); cursor: pointer; display: flex; align-items: center;
  justify-content: center; font-size: 16px; transition: var(--transition-fast);
}
.rpt-action-btn:hover { background: var(--color-emerald-50); color: var(--color-emerald-600); border-color: var(--color-emerald-200); }

.rpt-stats-bar {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; margin-bottom: 16px;
}
.rpt-stat-card {
  display: flex; align-items: center; gap: 8px; padding: 10px 12px;
  background: #fff; border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
}
.rpt-stat-icon { font-size: 20px; color: var(--color-emerald-500); }
.rpt-stat-value { font-size: 20px; font-weight: 700; color: var(--color-gray-900); }
.rpt-stat-label { font-size: 12px; color: var(--color-gray-500); }
.rpt-stat-wow { margin-left: auto; }

.rpt-filter-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin-bottom: 12px; padding: 10px 14px;
  background: #fff; border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg);
}
.rpt-filter-bar select, .rpt-filter-bar input {
  padding: 6px 10px; border: 1px solid var(--color-gray-300); border-radius: var(--radius-md);
  font-size: 13px; font-family: inherit; background: #fff;
}
.rpt-date-range {
  display: flex; align-items: center; gap: 4px;
  border: 1px solid var(--color-gray-300); border-radius: var(--radius-md);
  padding: 0 4px; background: #fff;
}
.rpt-date-range input { border: none; padding: 5px 4px; width: 130px; font-size: 13px; background: transparent; accent-color: var(--color-emerald-500); color-scheme: light; }
.rpt-date-range input:focus { outline: none; }
.rpt-date-range input::-webkit-calendar-picker-indicator { cursor: pointer; }
.rpt-date-range input::-webkit-datetime-edit-week-field:focus,
.rpt-date-range input::-webkit-datetime-edit-year-field:focus { background: var(--color-emerald-100); color: var(--color-emerald-800); }
.rpt-date-sep { color: var(--color-gray-400); font-size: 12px; }
.rpt-clear-btn {
  width: 24px; height: 24px; border: none; background: transparent; color: var(--color-gray-400);
  cursor: pointer; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-sm);
  font-size: 14px; transition: var(--transition-fast);
}
.rpt-clear-btn:hover { background: var(--color-red-50); color: var(--color-red-500); }

.rpt-track-toggle {
  display: flex; background: var(--color-gray-100); border-radius: var(--radius-full); padding: 2px;
}
.rpt-track-btn {
  padding: 5px 14px; border: none; background: transparent; border-radius: var(--radius-full);
  font-size: 13px; font-weight: 500; cursor: pointer; color: var(--color-gray-600); transition: var(--transition-fast);
}
.rpt-track-btn:hover { color: var(--color-gray-900); }
.rpt-track-btn.active {
  background: var(--color-emerald-500); color: #fff; box-shadow: var(--shadow-sm);
}

.rpt-tabs {
  display: flex; gap: 0; border-bottom: 1px solid var(--color-gray-200); margin-bottom: 20px;
}
.rpt-tab {
  padding: 10px 16px; border: none; background: none; cursor: pointer;
  font-size: 14px; font-weight: 500; color: var(--color-gray-500);
  border-bottom: 2px solid transparent; display: flex; align-items: center; gap: 6px;
  transition: var(--transition-fast);
}
.rpt-tab:hover { color: var(--color-gray-800); }
.rpt-tab.active { color: var(--color-emerald-600); border-bottom-color: var(--color-emerald-500); }

.rpt-section { margin-bottom: 24px; }
.rpt-section h3 { font-size: 16px; font-weight: 600; color: var(--color-gray-800); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }

.rpt-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.rpt-table thead th {
  padding: 10px 12px; text-align: left; font-size: 11px; font-weight: 600;
  color: var(--color-gray-500); text-transform: uppercase; letter-spacing: 0.5px;
  background: var(--color-gray-50); border-bottom: 1px solid var(--color-gray-200);
  white-space: nowrap;
}
.rpt-table tbody td {
  padding: 10px 12px; border-bottom: 1px solid var(--color-gray-100); vertical-align: top;
}
.rpt-table tbody tr:hover { background: var(--color-gray-50); }
.rpt-table .num-col { text-align: right; }
.rpt-table .totals-row td { border-top: 2px solid var(--color-gray-300); background: var(--color-gray-50); }
.rpt-table .current-period-row { background: var(--color-emerald-50); }
.rpt-table .current-period-row:hover { background: #d1fae5; }
.rpt-table .top-performer { background: var(--color-emerald-50); }

.cell-value { font-weight: 600; color: var(--color-gray-900); }
.cell-rate { font-size: 11px; color: var(--color-gray-400); margin-top: 2px; }
.cell-wow { margin-top: 2px; }

.clickable-cell { cursor: pointer; }
.clickable-cell:hover { background: var(--color-emerald-50); border-radius: 4px; }

.cohort-label { font-weight: 600; white-space: nowrap; }
.current-period-badge { color: var(--color-orange-500); font-size: 14px; vertical-align: middle; }

.wow-badge {
  display: inline-flex; align-items: center; gap: 3px; font-size: 11px; font-weight: 600;
  padding: 1px 6px; border-radius: var(--radius-full);
}
.wow-positive { color: var(--color-emerald-700); background: var(--color-emerald-50); }
.wow-negative { color: var(--color-red-600); background: var(--color-red-50); }
.wow-neutral { color: var(--color-gray-400); }

/* Source comparison */
.rpt-subtable { width: 100%; border-collapse: collapse; font-size: 12px; margin: 8px 0; }
.rpt-subtable th { padding: 6px 10px; font-size: 10px; text-transform: uppercase; color: var(--color-gray-400); border-bottom: 1px solid var(--color-gray-200); text-align: left; }
.rpt-subtable td { padding: 6px 10px; border-bottom: 1px solid var(--color-gray-100); }
.rpt-subtable .num-col { text-align: right; }
.campaign-expansion { background: var(--color-gray-50); }
.expansion-cell { padding: 0 12px 12px 32px !important; }
.expansion-empty { padding: 16px; text-align: center; color: var(--color-gray-400); font-size: 13px; }
.unmapped-badge { font-size: 10px; color: var(--color-orange-600); background: var(--color-orange-50); padding: 1px 6px; border-radius: var(--radius-full); margin-left: 6px; }
.unmapped-row { border-left: 3px solid var(--color-orange-300); }

/* Pipeline snapshot */
.rpt-pipeline-snapshot {
  background: #fff; border: 1px solid var(--color-gray-200); border-radius: var(--radius-lg); padding: 20px;
}
.pipeline-bars {
  display: flex; align-items: flex-end; gap: 8px; height: 140px; margin: 16px 0;
}
.pipeline-bar-item {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; height: 100%;
}
.pipeline-bar-fill {
  width: 100%; background: var(--color-emerald-400); border-radius: 4px 4px 0 0; min-height: 4px;
  transition: height 0.4s ease;
}
.pipeline-bar-count { font-size: 14px; font-weight: 700; color: var(--color-gray-900); margin-top: 6px; }
.pipeline-bar-label { font-size: 11px; color: var(--color-gray-500); text-align: center; white-space: nowrap; }
.pipeline-bottleneck .pipeline-bar-fill { background: var(--color-orange-400); }
.pipeline-warning {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  background: var(--color-orange-50); border: 1px solid var(--color-orange-200);
  border-radius: var(--radius-md); color: var(--color-orange-700); font-size: 13px; font-weight: 500;
}

/* UTM Manager */
.type-badge {
  font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: var(--radius-full);
  background: var(--color-gray-100); color: var(--color-gray-600);
}
.utm-editable { cursor: pointer; min-width: 120px; }
.utm-editable:hover { background: var(--color-emerald-50); border-radius: 4px; }
.edit-placeholder { color: var(--color-gray-300); font-style: italic; font-size: 12px; }
.utm-edit-input {
  width: 100%; padding: 4px 8px; border: 2px solid var(--color-emerald-500);
  border-radius: var(--radius-md); font-size: 13px; font-family: inherit;
  outline: none;
}
.utm-manager-table { table-layout: fixed; width: 100%; }
.utm-raw { font-family: monospace; font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 180px; }

/* Info box */
.rpt-info-box {
  padding: 16px 20px; background: var(--color-blue-50); border: 1px solid #bfdbfe;
  border-radius: var(--radius-lg); color: var(--color-blue-600); font-size: 14px;
  display: flex; align-items: flex-start; gap: 10px; margin-bottom: 16px;
}

/* Badges */
.badge-emerald { background: var(--color-emerald-50); color: var(--color-emerald-700); padding: 2px 8px; border-radius: var(--radius-full); font-size: 11px; font-weight: 600; }
.badge-blue { background: var(--color-blue-50); color: var(--color-blue-600); padding: 2px 8px; border-radius: var(--radius-full); font-size: 11px; font-weight: 600; }
.badge-gray { background: var(--color-gray-100); color: var(--color-gray-500); padding: 2px 8px; border-radius: var(--radius-full); font-size: 11px; font-weight: 600; }

/* Drill-down modal */
.rpt-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 1000;
  display: flex; align-items: center; justify-content: center; padding: 24px;
}
.rpt-modal {
  background: #fff; border-radius: var(--radius-xl); box-shadow: var(--shadow-xl);
  width: 100%; max-width: 800px; max-height: 80vh; overflow: hidden;
  display: flex; flex-direction: column;
}
.rpt-modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 24px; border-bottom: 1px solid var(--color-gray-200);
}
.rpt-modal-header h3 { margin: 0; font-size: 16px; }
.rpt-modal-body { overflow-y: auto; padding: 16px 24px; }

/* Dark mode */
body.dark .rpt-sync-bar { background: var(--color-gray-800); border-color: var(--color-gray-700); }
body.dark .rpt-sync-info { color: var(--color-gray-300); }
body.dark .rpt-stat-card { background: var(--color-gray-800); border-color: var(--color-gray-700); }
body.dark .rpt-stat-value { color: var(--color-gray-100); }
body.dark .rpt-filter-bar { background: var(--color-gray-800); border-color: var(--color-gray-700); }
body.dark .rpt-filter-bar select, body.dark .rpt-filter-bar input { background: var(--color-gray-700); border-color: var(--color-gray-600); color: var(--color-gray-200); }
body.dark .rpt-track-toggle { background: var(--color-gray-700); }
body.dark .rpt-track-btn { color: var(--color-gray-400); }
body.dark .rpt-track-btn.active { background: var(--color-emerald-600); }
body.dark .rpt-tabs { border-color: var(--color-gray-700); }
body.dark .rpt-tab { color: var(--color-gray-400); }
body.dark .rpt-tab.active { color: var(--color-emerald-400); border-bottom-color: var(--color-emerald-500); }
body.dark .rpt-table thead th { background: var(--color-gray-800); color: var(--color-gray-400); border-color: var(--color-gray-700); }
body.dark .rpt-table tbody td { border-color: var(--color-gray-800); }
body.dark .rpt-table tbody tr:hover { background: var(--color-gray-800); }
body.dark .rpt-table .totals-row td { background: var(--color-gray-800); border-color: var(--color-gray-600); }
body.dark .rpt-table .current-period-row { background: rgba(16,185,129,0.08); }
body.dark .cell-value { color: var(--color-gray-100); }
body.dark .rpt-pipeline-snapshot { background: var(--color-gray-800); border-color: var(--color-gray-700); }
body.dark .rpt-modal { background: var(--color-gray-800); }
body.dark .rpt-modal-header { border-color: var(--color-gray-700); }

/* Responsive */
@media (max-width: 768px) {
  .rpt-stats-bar { grid-template-columns: repeat(2, 1fr); }
  .rpt-filter-bar { flex-direction: column; align-items: stretch; }
  .rpt-track-toggle { justify-content: center; }
  .rpt-tabs { overflow-x: auto; }
  .rpt-tab { white-space: nowrap; padding: 8px 12px; font-size: 13px; }
}
