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

/* Rank One Tutorial Dashboard */
:root {
  --navy: #1e3160;
  --navy-light: #2a4a8a;
  --navy-dark: #141f3a;
  --crimson: #ab1d37;
  --crimson-dark: #8a1629;
  --cream: #e8edf5;
  --smoke: #0c1220;
  --bg: #0e1525;
  --surface: #151e30;
  --border: #243352;
  --text: #c8d2e4;
  --text-dim: #6b7d9a;
  --success: #4a9;
  --danger: #ab1d37;
  /* Aliases for existing references */
  --amber: #4a8bd4;
  --rust: #ab1d37;
  --bark: #1e3160;
}

/* =========================================================
   REDESIGN TOKENS — Phase 1
   ========================================================= */

/* Theme-agnostic scale tokens */
:root {
  /* Spacing (4px base) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-7: 32px;
  --s-8: 48px;

  /* Radii */
  --r-xs: 6px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-pill: 999px;

  /* Typography sizes */
  --t-xs: 11px;
  --t-sm: 12px;
  --t-md: 14px;
  --t-lg: 16px;
  --t-xl: 20px;
  --t-2xl: 28px;
  --t-3xl: 36px;

  /* Easing */
  --ease: cubic-bezier(.4, .0, .2, 1);
  --ease-out: cubic-bezier(.2, .8, .2, 1);
}

/* DARK MODE TOKENS */
:root[data-theme="dark"],
:root:not([data-theme="light"]) {
  --crimson-light: #c93b56;
  --amber-light: #6ba6e8;

  --ok: #2dd4a7;
  --ok-bg: rgba(45, 212, 167, 0.12);
  --warn: #f5b454;
  --warn-bg: rgba(245, 180, 84, 0.12);
  --err: #ef5d75;
  --err-bg: rgba(239, 93, 117, 0.12);
  --info: #4a8bd4;
  --info-bg: rgba(74, 139, 212, 0.12);

  --bg-soft: #0e1628;
  --surface-2: #1a2540;
  --surface-3: #202d4d;
  --border-strong: rgba(255, 255, 255, 0.12);

  --text-soft: #b4c0d6;
  --text-faint: #4a5673;

  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.25);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.35);
  --shadow-lg: 0 12px 40px rgba(0, 0, 0, 0.45);
  --shadow-glow: 0 0 0 1px rgba(74, 139, 212, 0.4), 0 8px 32px rgba(74, 139, 212, 0.18);

  --grad-navy: linear-gradient(135deg, #1e3160 0%, #2a4a8a 100%);
  --grad-crimson: linear-gradient(135deg, #ab1d37 0%, #d8425e 100%);
  --grad-amber: linear-gradient(135deg, #4a8bd4 0%, #2dd4a7 100%);
  --grad-warm: linear-gradient(135deg, #ab1d37 0%, #f5b454 100%);
}

/* LIGHT MODE REDESIGN TOKENS */
:root[data-theme="light"] {
  --crimson-light: #c93b56;
  --amber-light: #3b82f6;

  --ok: #059669;
  --ok-bg: rgba(5, 150, 105, 0.10);
  --warn: #d97706;
  --warn-bg: rgba(217, 119, 6, 0.10);
  --err: #dc2626;
  --err-bg: rgba(220, 38, 38, 0.10);
  --info: #2563eb;
  --info-bg: rgba(37, 99, 235, 0.10);

  --bg-soft: #eef2f8;
  --surface-2: #f9fbff;
  --surface-3: #eff3fa;
  --border-strong: rgba(15, 30, 60, 0.16);

  --text-soft: #2a3a5c;
  --text-faint: #94a0bc;

  --shadow-sm: 0 1px 2px rgba(15, 30, 60, 0.06);
  --shadow-md: 0 4px 16px rgba(15, 30, 60, 0.08);
  --shadow-lg: 0 12px 40px rgba(15, 30, 60, 0.12);
  --shadow-glow: 0 0 0 1px rgba(37, 99, 235, 0.3), 0 8px 32px rgba(37, 99, 235, 0.15);

  --grad-navy: linear-gradient(135deg, #1e3160 0%, #4a6fa5 100%);
  --grad-crimson: linear-gradient(135deg, #ab1d37 0%, #d8425e 100%);
  --grad-amber: linear-gradient(135deg, #2563eb 0%, #059669 100%);
  --grad-warm: linear-gradient(135deg, #ab1d37 0%, #f5b454 100%);
}

/* ─── Light Mode ─── */
[data-theme="light"] {
  --bg: #f4f6f9;
  --surface: #ffffff;
  --border: #d8dde6;
  --text: #1e2a3a;
  --text-dim: #5f6d7e;
  --cream: #1e2a3a;
  --smoke: #ffffff;
  --navy-dark: #ebeef3;
}
[data-theme="light"] .dash-header {
  box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
[data-theme="light"] .user-menu-btn {
  border-color: #d8dde6;
  color: #1e2a3a;
}
[data-theme="light"] .user-menu-btn:hover {
  background: rgba(74,139,212,0.06);
  border-color: #c5cdd8;
}
[data-theme="light"] .topbar-search-box {
  background: #f4f6f9;
  border-color: #d8dde6;
}
[data-theme="light"] .topbar-search-input {
  color: #1e2a3a;
}
[data-theme="light"] .user-dropdown {
  box-shadow: 0 10px 32px rgba(0,0,0,0.12);
}
[data-theme="light"] .btn {
  color: #fff;
}
[data-theme="light"] .btn:hover {
  color: #fff;
}
[data-theme="light"] .btn-ghost {
  background: var(--surface);
  color: var(--text-dim);
  border-color: var(--border-strong);
}
[data-theme="light"] .btn-ghost:hover {
  color: var(--text);
  background: var(--surface-2);
  border-color: var(--info);
}
[data-theme="light"] .badge-draft {
  background: rgba(0,0,0,0.06);
  color: #5f6d7e;
}
[data-theme="light"] .badge-published {
  background: rgba(68,170,153,0.1);
}
[data-theme="light"] .badge-archived {
  background: rgba(204,68,68,0.08);
}
[data-theme="light"] .badge-cat {
  background: rgba(74,139,212,0.08);
}
[data-theme="light"] .alert-error {
  background: rgba(204,68,68,0.06);
  border-color: rgba(204,68,68,0.2);
  color: #b91c1c;
}
/* Light mode inputs */
[data-theme="light"] input[type="text"],
[data-theme="light"] input[type="email"],
[data-theme="light"] input[type="password"],
[data-theme="light"] input[type="number"],
[data-theme="light"] input[type="search"],
[data-theme="light"] input[type="url"],
[data-theme="light"] textarea,
[data-theme="light"] select,
[data-theme="light"] .int-input,
[data-theme="light"] .block-input,
[data-theme="light"] .block-textarea {
  background: #fff;
  border-color: #d0d5dd;
  color: #1e2a3a;
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder {
  color: #9ca3af;
}
[data-theme="light"] input:focus,
[data-theme="light"] textarea:focus,
[data-theme="light"] select:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 2px rgba(74,139,212,0.15);
}
/* Light mode cards and surfaces */
[data-theme="light"] .hub-card,
[data-theme="light"] .product-card,
[data-theme="light"] .tutorial-card,
[data-theme="light"] .integration-card {
  background: #fff;
  border-color: #e2e6ed;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
[data-theme="light"] .hub-card:hover,
[data-theme="light"] .product-card:hover {
  border-color: #c5cdd8;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
/* Light mode sidebar styling */
[data-theme="light"] .settings-sidebar,
[data-theme="light"] .hub-sidebar,
[data-theme="light"] .docs-sidebar,
[data-theme="light"] .kb-sidebar,
[data-theme="light"] .intel-sidebar {
  background: #fff;
  border-color: #e2e6ed;
}
[data-theme="light"] .settings-nav-item:hover {
  background: rgba(74,139,212,0.06);
}
[data-theme="light"] .settings-nav-item.active {
  background: rgba(74,139,212,0.1);
}
/* Light mode tables */
[data-theme="light"] table th {
  background: #f0f2f5;
  color: #374151;
  border-color: #e2e6ed;
}
[data-theme="light"] table td {
  border-color: #e2e6ed;
}
[data-theme="light"] table tr:hover td {
  background: #f8f9fb;
}
/* Light mode integration status */
[data-theme="light"] .integration-status[data-status="connected"] {
  background: rgba(68,170,153,0.1);
}
[data-theme="light"] .integration-message.success {
  background: rgba(68,170,153,0.06);
  border-color: rgba(68,170,153,0.2);
}
[data-theme="light"] .integration-message.error {
  background: rgba(204,68,68,0.06);
  border-color: rgba(204,68,68,0.2);
}
/* Light mode scrollbar */
[data-theme="light"] * {
  scrollbar-color: #c5cdd8 transparent;
}
[data-theme="light"] *::-webkit-scrollbar-thumb {
  background: #c5cdd8;
}
[data-theme="light"] *::-webkit-scrollbar-thumb:hover {
  background: #9ca3af;
}
/* Light mode chat bubble */
[data-theme="light"] .chat-bubble-panel {
  background: #fff;
  border-color: #d8dde6;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
}
[data-theme="light"] .chat-bubble-header {
  background: var(--navy);
}
[data-theme="light"] .msg-ai {
  background: #f0f2f5;
  color: #1e2a3a;
}
[data-theme="light"] .chat-bubble-title { color: #fff; }
[data-theme="light"] .chat-bubble-input {
  background: #fff;
  border-color: #d0d5dd;
  color: #1e2a3a;
}
[data-theme="light"] .todo-save-btn { color: #fff; background: var(--amber); }
/* Light mode mobile nav — keep dark to match sidebar */
[data-theme="light"] .mobile-nav-panel {
  background: #0D1A30;
}
[data-theme="light"] .mobile-nav-item {
  color: rgba(255,255,255,0.75);
}
[data-theme="light"] .mobile-nav-item:hover {
  background: rgba(255,255,255,0.04);
  color: #fff;
}
[data-theme="light"] .mobile-nav-item.active {
  background: rgba(171,29,55,0.12);
  color: #fff;
  border-left-color: #AB1D37;
}
/* Light mode media picker */
[data-theme="light"] .media-picker-panel {
  background: #fff;
  border-color: #e2e6ed;
  box-shadow: 0 10px 40px rgba(0,0,0,0.15);
}
[data-theme="light"] .media-picker-card {
  background: #f8f9fb;
}
/* Light mode code/pre blocks */
[data-theme="light"] pre,
[data-theme="light"] code {
  background: #f0f2f5;
}
[data-theme="light"] .api-code-block {
  background: #f6f7f9;
  border-color: #e2e6ed;
  color: #1e2a3a;
}
[data-theme="light"] .api-endpoint-box {
  background: #f6f7f9;
  border-color: #e2e6ed;
}
[data-theme="light"] .api-option-card {
  background: #f8f9fb;
  border-color: #e2e6ed;
}
[data-theme="light"] .api-portal-row {
  background: #f8f9fb;
  border-color: #e2e6ed;
}
/* Light mode toast */
[data-theme="light"] .toast {
  background: #1e2a3a;
  color: #fff;
}
/* Light mode dropdown-item colors stay readable */
[data-theme="light"] .user-dropdown-item {
  color: var(--text);
}
[data-theme="light"] .user-dropdown-item:hover {
  background: rgba(74,139,212,0.06);
}
/* Light mode misc overrides */
/* Light mode: header is now light bg — breadcrumbs need dark text */
[data-theme="light"] .breadcrumb-item { color: #5f6d7e; }
[data-theme="light"] a.breadcrumb-item:hover { color: #1e2a3a; }
[data-theme="light"] .breadcrumb-current { color: #1e2a3a; }
[data-theme="light"] .breadcrumb-sep { color: #9ca3af; }
[data-theme="light"] .user-menu-name { color: #1e2a3a; }
[data-theme="light"] .caret { color: #5f6d7e; }

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

/* Global scrollbar — thin, subtle, matches dark theme */
* {
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
*::-webkit-scrollbar { width: 6px; height: 6px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: var(--border); border-radius: 6px; }
*::-webkit-scrollbar-thumb:hover { background: var(--text-dim); }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
}

a { color: var(--amber); text-decoration: none; }
a:hover { text-decoration: underline; }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: var(--s-2, 8px);
  padding: 9px var(--s-4, 16px);
  background: var(--grad-amber);
  color: #fff;
  border: none; border-radius: var(--r-sm, 8px);
  font-size: var(--t-md, 14px); font-weight: 600;
  cursor: pointer; transition: all 150ms var(--ease, ease);
  text-decoration: none; line-height: 1.4;
}
.btn:hover {
  box-shadow: var(--shadow-glow);
  filter: brightness(1.1);
  color: #fff; text-decoration: none;
  transform: translateY(-1px);
}
.btn:active { transform: translateY(0); filter: brightness(0.95); }
.btn-primary { background: var(--grad-amber); color: #fff; border: none; }
.btn-primary:hover { box-shadow: var(--shadow-glow); filter: brightness(1.1); color: #fff; }
.btn-sm { padding: 6px 12px; font-size: var(--t-sm, 12px); border-radius: var(--r-xs, 6px); }
.btn-ghost {
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border-strong, var(--border));
  font-weight: 500;
}
.btn-ghost:hover {
  background: var(--surface-2, var(--surface));
  color: var(--text); border-color: var(--info, var(--amber));
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.btn-danger {
  background: var(--err-bg, rgba(239,93,117,0.12));
  color: var(--err, #ef5d75);
  border: 1px solid var(--err, #ef5d75);
}
.btn-danger:hover {
  background: var(--err, #ef5d75); color: #fff;
  border-color: var(--err, #ef5d75);
  box-shadow: 0 4px 12px rgba(239,93,117,0.3);
  filter: none; transform: translateY(-1px);
}
.btn-disabled { opacity: 0.35; cursor: default; pointer-events: none; }

/* Alerts */
.alert { padding: 10px 14px; border-radius: 4px; margin-bottom: 16px; font-size: 0.85rem; }
.alert-error { background: rgba(204,68,68,0.15); color: #f88; border: 1px solid rgba(204,68,68,0.3); }

/* Badges */
.badge { display: inline-block; padding: 2px 8px; border-radius: 3px; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em; }
.badge-draft { background: rgba(255,255,255,0.08); color: var(--text-dim); }
.badge-published { background: rgba(68,170,153,0.15); color: var(--success); }
.badge-archived { background: rgba(204,68,68,0.15); color: var(--danger); }
.badge-cat { background: rgba(74,139,212,0.12); color: var(--amber); }

/* Header */
.dash-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 200;
  margin-left: 240px;
}
.nav-left { display: flex; align-items: center; gap: 12px; }
.nav-right { display: flex; align-items: center; gap: 12px; }
/* Breadcrumb navigation */
.breadcrumbs { display: flex; align-items: center; gap: 0; flex-wrap: nowrap; overflow: hidden; }
.breadcrumb-item { color: var(--text-dim); font-size: 0.78rem; text-decoration: none; white-space: nowrap; }
a.breadcrumb-item:hover { color: var(--cream); }
.breadcrumb-current { color: var(--cream); font-weight: 600; }
.breadcrumb-sep { color: var(--text-dim); font-size: 0.72rem; margin: 0 6px; opacity: 0.5; }
/* Topbar search */
.topbar-search-box {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  padding: 5px 10px; width: 200px; cursor: text;
}
.topbar-search-box svg { width: 13px; height: 13px; color: var(--text-dim); flex-shrink: 0; }
.topbar-search-input {
  background: transparent; border: none; outline: none;
  color: var(--text); font-size: 0.78rem; width: 100%; font-family: inherit;
}
.topbar-search-input::placeholder { color: var(--text-dim); }
/* User menu dropdown */
.user-menu { position: relative; }
.user-menu-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 12px 4px 4px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text);
  font-size: 0.82rem; font-weight: 600;
  cursor: pointer; transition: background 0.2s, border-color 0.2s;
}
.user-menu-btn:hover {
  background: rgba(74,139,212,0.06);
  border-color: var(--text-dim);
}
.user-menu-avatar {
  display: flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 50%;
  background: linear-gradient(135deg, #4A6BB0, #1E3160); color: #fff;
  font-size: 0.72rem; font-weight: 700;
}
.user-menu-name { max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.user-dropdown {
  display: none; position: absolute; top: 100%; right: 0;
  margin-top: 8px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; min-width: 200px;
  box-shadow: 0 10px 32px rgba(0,0,0,0.4);
  overflow: hidden; z-index: 300;
}
.user-dropdown.open { display: block; }
.user-dropdown-header {
  padding: 14px 18px 10px;
  border-bottom: 1px solid var(--border);
}
.user-dropdown-display { font-size: 0.85rem; font-weight: 600; color: var(--text); }
.user-dropdown-email { font-size: 0.72rem; color: var(--text-dim); margin-top: 2px; }
.user-dropdown-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 18px;
  color: var(--text); text-decoration: none;
  font-size: 0.84rem;
  transition: background 0.15s;
}
.user-dropdown-item:hover { background: rgba(74,139,212,0.08); text-decoration: none; }
.user-dropdown-item.active { background: rgba(74,139,212,0.15); color: var(--amber); font-weight: 600; }
.user-dropdown-item svg { opacity: 0.5; flex-shrink: 0; }
.user-dropdown-item:hover svg { opacity: 0.8; }
.user-dropdown-divider { height: 1px; background: var(--border); margin: 2px 0; }
.user-dropdown-logout { color: var(--text-dim); }
.user-dropdown-logout:hover { color: var(--danger); }

.caret { font-size: 0.6rem; opacity: 0.7; }

/* Editor subheader */
.editor-subheader {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  margin-left: 240px;
}

/* Hub page — two-column layout */
.hub-layout { display: flex; height: calc(100vh - 47px); overflow: hidden; margin-left: 240px; }
.hub-left { flex: 1; overflow-y: auto; padding: 40px 32px; }
.hub-right {
  width: 360px; flex-shrink: 0;
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
}
.hub-main { max-width: 720px; margin: 0 auto; padding: 60px 24px; }
.hub-welcome { margin-bottom: 32px; }
.hub-welcome h2 { font-size: 1.4rem; color: var(--cream); font-weight: 600; margin-bottom: 4px; }
.hub-welcome p { color: var(--text-dim); font-size: 0.88rem; font-weight: 400; }
.hub-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.hub-card {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 18px 22px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
  transition: box-shadow 0.2s, border-color 0.2s, transform 0.15s;
  text-decoration: none;
}
.hub-card:hover {
  border-color: rgba(74,139,212,0.35);
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  transform: translateY(-1px);
  text-decoration: none;
}
.hub-card-disabled {
  opacity: 0.45; cursor: default;
  border-style: dashed;
}
.hub-card-icon {
  flex-shrink: 0; width: 36px; height: 36px;
  margin-top: 2px;
}
.hub-card-icon svg { width: 100%; height: 100%; }
.hub-card-body { flex: 1; min-width: 0; }
.hub-card-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.hub-card h3 { color: var(--cream); font-size: 1rem; font-weight: 600; margin: 0; }
.hub-card-arrow {
  font-size: 1.1rem; color: var(--text-dim);
  transition: color 0.2s, transform 0.2s;
}
.hub-card:hover .hub-card-arrow { color: var(--amber); transform: translateX(3px); }
.hub-card-badge {
  font-size: 0.68rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-dim); background: rgba(255,255,255,0.05);
  padding: 2px 8px; border-radius: 4px;
}
.hub-card p { color: var(--text-dim); font-size: 0.82rem; line-height: 1.6; margin-bottom: 0; }
.hub-card-stats {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.75rem; color: var(--text-dim);
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid var(--border);
}
.hub-stat-dot {
  width: 3px; height: 3px; border-radius: 50%;
  background: var(--text-dim); display: inline-block;
}

/* Dashboard layout */
.dash-layout { display: flex; min-height: 100vh; margin-left: 240px; }
.sidebar {
  width: 240px; padding: 0;
  background: #0D1A30;
  border-right: none;
  display: flex; flex-direction: column;
  color: #fff;
  position: fixed; top: 0; left: 0; height: 100vh; z-index: 250;
}
aside.sidebar { height: 100vh; }
/* Sidebar brand header */
.sidebar-brand {
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.sidebar-brand-link {
  display: flex; align-items: center; text-decoration: none;
}
.sidebar-logo-img {
  height: 26px; width: auto;
}
/* Sidebar nav scrollable area */
.sidebar-nav-scroll { flex: 1; overflow-y: auto; padding-bottom: 16px; }
.sidebar-nav-scroll::-webkit-scrollbar { width: 3px; }
.sidebar-nav-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
/* Sidebar sections */
.sidebar-section { padding: 14px 0 6px; }
.sidebar-section-label {
  padding: 0 20px 6px;
  font-family: 'Oswald', sans-serif; font-weight: 500; font-size: 10px;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: rgba(255,255,255,0.35);
}
/* Nav items */
.sidebar .nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 20px; font-size: 13px;
  color: rgba(255,255,255,0.7); text-decoration: none;
  border-left: 2px solid transparent;
  transition: all 0.15s ease; cursor: pointer;
}
.sidebar .nav-item:hover {
  background: rgba(255,255,255,0.04); color: #fff;
}
.sidebar .nav-item.active {
  background: rgba(171,29,55,0.12);
  border-left-color: #AB1D37;
  color: #fff; font-weight: 600;
}
.sidebar .nav-item svg {
  width: 15px; height: 15px; flex-shrink: 0; opacity: 0.85;
}
.sidebar .nav-item.active svg { opacity: 1; }
/* Child nav items (sub-menu) */
.sidebar .nav-item-child {
  padding-left: 45px; font-size: 12px;
}
.sidebar .nav-item-badge {
  margin-left: auto; background: rgba(255,255,255,0.1);
  border-radius: 10px; padding: 1px 7px;
  font-family: monospace; font-size: 10px; font-weight: 500;
}
.sidebar .nav-item.active .nav-item-badge { background: #AB1D37; }
/* Sub-sidebars (training, marketing, etc.) — not fixed, flow with content */
.sub-sidebar {
  width: 220px; padding: 0;
  background: var(--surface); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; flex-shrink: 0;
  position: sticky; top: 47px; height: calc(100vh - 47px); overflow-y: auto;
}
.sub-sidebar-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 8px; background: transparent;
  color: var(--text); text-decoration: none; margin: 1px 4px;
  transition: background 0.15s; font-size: 0.8rem; font-weight: 500;
}
.sub-sidebar-item:hover { background: rgba(255,255,255,0.04); }
.sub-sidebar-item.active { background: rgba(74,139,212,0.12); color: var(--cream); }
.tool-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
/* Legacy sidebar styles kept for sub-sidebars */
.sidebar h3 { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(255,255,255,0.4); margin-bottom: 10px; }
.sidebar h3:not(:first-child) { margin-top: 20px; }
.sidebar-select {
  width: 100%; padding: 8px 10px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.85rem; font-family: inherit;
  cursor: pointer; margin-bottom: 6px;
  appearance: auto;
}
.sidebar-select:focus { outline: none; border-color: var(--amber); }
.cat-list { list-style: none; }
.cat-list li a { display: block; padding: 6px 10px; border-radius: 4px; font-size: 0.85rem; color: var(--text); }
.cat-list li a:hover, .cat-list li a.active { background: rgba(74,139,212,0.1); color: var(--amber); text-decoration: none; }
.dash-main { flex: 1; padding: 24px; }
.empty { color: var(--text-dim); font-style: italic; padding: 40px 0; text-align: center; }

/* Product grid */
.product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; margin-top: 16px; }
.product-card {
  display: block; padding: 24px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 6px;
  transition: border-color 0.2s;
}
.product-card:hover { border-color: var(--amber); text-decoration: none; }
.product-card h3 { color: var(--cream); margin-bottom: 8px; }
.product-stats { display: flex; gap: 16px; font-size: 0.82rem; color: var(--text-dim); }

/* Tutorial list */
.list-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; gap: 16px; }
.list-header-actions { display: flex; align-items: center; gap: 10px; }
.search-bar { position: relative; }
.search-input {
  padding: 7px 12px; width: 220px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.85rem; font-family: inherit;
}
.search-input:focus { outline: none; border-color: var(--amber); }
.search-input::placeholder { color: var(--text-dim); }
.tutorial-list { display: flex; flex-direction: column; gap: 8px; }
.tutorial-card {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px;
  background: var(--surface); border: 1px solid var(--border); border-radius: 4px;
}
.tutorial-info { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; flex: 1; min-width: 0; }
.tutorial-info h4 { color: var(--cream); }
.meta { font-size: 0.78rem; color: var(--text-dim); }
.tutorial-actions { display: flex; gap: 6px; align-items: center; flex-wrap: nowrap; margin-left: auto; }
.tutorial-tags { display: flex; gap: 4px; flex-wrap: wrap; margin-right: 4px; }

/* Tag pills */
.tag-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 10px;
  background: rgba(74,139,212,0.1);
  border: 1px solid rgba(74,139,212,0.2);
  border-radius: 12px;
  font-size: 0.7rem; color: var(--amber);
  white-space: nowrap;
}
.tag-removable .tag-remove {
  background: none; border: none; color: var(--text-dim);
  font-size: 0.85rem; cursor: pointer; padding: 0 2px; line-height: 1;
}
.tag-removable .tag-remove:hover { color: var(--danger); }

/* Editor meta bar (category + tags) */
.editor-meta-bar {
  display: flex; gap: 12px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--border);
  align-items: flex-start;
}
.meta-field { display: flex; flex-direction: column; gap: 3px; }
.meta-field label {
  font-size: 0.7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text);
}
.meta-field select.block-input { width: auto; min-width: 140px; padding: 5px 8px; font-size: 0.8rem; }
.meta-field-tags { flex: 1; }
.tags-container {
  display: flex; flex-wrap: wrap; gap: 5px; align-items: center;
  padding: 4px 8px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 3px;
  min-height: 32px;
}
.tag-input {
  border: none; background: none; color: var(--text);
  font-size: 0.8rem; font-family: inherit;
  outline: none; min-width: 80px; flex: 1;
  padding: 2px 0;
}
.tag-input::placeholder { color: var(--text-dim); }

/* Editor layout */
.editor-layout { display: flex; height: calc(100vh - 47px - 37px); padding-bottom: 52px; margin-left: 240px; }
.editor-nav { display: flex; align-items: center; gap: 12px; }

/* Left panel — tabs + block editor + chat */
.editor-left { width: 50%; display: flex; flex-direction: column; border-right: 1px solid var(--border); }

.editor-tabs {
  display: flex; border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.tab-btn {
  flex: 1; padding: 10px 16px;
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-dim); font-size: 0.82rem; font-weight: 600;
  cursor: pointer; transition: all 0.2s;
}
.tab-btn:hover { color: var(--text); }
.tab-btn.active { color: var(--amber); border-bottom-color: var(--amber); }

.tab-panel { display: none; flex: 1; flex-direction: column; overflow: hidden; }
.tab-panel.active { display: flex; }

/* Title bar */
.title-bar {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
}
.title-bar label {
  display: block;
  font-size: 0.7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text-dim);
  margin-bottom: 3px;
}
.title-bar .block-input {
  font-size: 1rem; font-weight: 600;
  color: var(--cream);
}

/* Block editor */
.blocks-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.toolbar-label { font-size: 0.75rem; color: var(--text-dim); margin-right: 4px; }

.blocks-container {
  flex: 1; overflow-y: auto; padding: 12px;
  display: flex; flex-direction: column; gap: 8px;
}

/* Block cards */
.block-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.block-card:hover { border-color: rgba(74,139,212,0.3); }
.block-card.dragging { opacity: 0.4; }
.block-card.drag-over { border-color: var(--amber); box-shadow: 0 0 0 1px var(--amber); }

.block-header {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  border-bottom: 1px solid var(--border);
  font-size: 0.75rem;
}

.block-grip {
  cursor: grab; padding: 2px 4px;
  color: var(--text-dim); font-size: 0.9rem;
  user-select: none;
}
.block-grip:active { cursor: grabbing; }

.block-type-label {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: var(--text-dim);
  flex: 1;
}

.block-step .block-type-label { color: var(--amber); }
.block-tip .block-header { border-bottom-color: rgba(30,49,96,0.3); }
.block-warning .block-header { border-bottom-color: rgba(171,29,55,0.3); }
.block-part-heading .block-type-label { color: #8a9ba2; }

.step-num-display {
  font-size: 0.72rem; font-weight: 700;
  color: var(--amber); opacity: 0.7;
}

.block-actions { display: flex; gap: 2px; margin-left: auto; }
.block-btn {
  background: none; border: 1px solid transparent; border-radius: 3px;
  color: var(--text-dim); font-size: 0.85rem;
  cursor: pointer; padding: 1px 6px; line-height: 1.2;
}
.block-btn:hover { background: var(--bg); border-color: var(--border); color: var(--text); }
.block-delete:hover { color: var(--danger); border-color: var(--danger); }

.block-body { padding: 10px; }

.field-row { margin-bottom: 8px; }
.field-row:last-child { margin-bottom: 0; }
.field-row label {
  display: block;
  font-size: 0.7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text);
  margin-bottom: 3px;
}

.block-input {
  width: 100%; padding: 6px 10px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 3px;
  font-family: inherit; font-size: 0.85rem;
}
.block-input:focus { outline: none; border-color: var(--amber); }

.block-textarea {
  width: 100%; padding: 6px 10px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 3px;
  font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
  font-size: 0.78rem; line-height: 1.5;
  resize: vertical;
}
.block-textarea:focus { outline: none; border-color: var(--amber); }

/* Screenshots in blocks */
.screenshot-preview { display: flex; flex-direction: column; gap: 6px; }
.screenshot-preview img {
  max-width: 200px; max-height: 140px;
  object-fit: contain; border: 1px solid var(--border);
  border-radius: 4px; background: #fff;
}
/* Global: images in contenteditable areas are always responsive */
[contenteditable] img { max-width: 100%; height: auto; }

.img-resize-bar {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.72rem; color: var(--text-dim); padding: 2px 0;
}
.img-resize-bar label { font-weight: 600; white-space: nowrap; }
.img-resize-bar input[type=range] { width: 140px; accent-color: var(--accent); }
.img-resize-bar .img-size-pct { min-width: 32px; text-align: right; }
.screenshot-controls { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.screenshot-controls .block-input { flex: 1; min-width: 120px; }
.screenshot-add-btn { cursor: pointer; }
.screenshot-btn-label { cursor: pointer; color: #fff; }

/* Chat panel (inside tab) */
.chat-messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.msg { padding: 10px 14px; border-radius: 6px; font-size: 0.85rem; line-height: 1.5; max-width: 90%; }
.msg-system { background: rgba(74,139,212,0.08); color: var(--text-dim); font-style: italic; align-self: center; max-width: 100%; text-align: center; }
.msg-user { background: var(--amber); color: var(--smoke); align-self: flex-end; border-radius: 6px 6px 2px 6px; }
.msg-ai { background: var(--surface); border: 1px solid var(--border); align-self: flex-start; border-radius: 6px 6px 6px 2px; }

.chat-input { display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); }
.chat-input textarea {
  flex: 1; padding: 8px 12px; resize: none;
  background: var(--surface); color: var(--text); border: 1px solid var(--border); border-radius: 4px;
  font-family: inherit; font-size: 0.85rem;
}
.chat-input textarea:focus { outline: none; border-color: var(--amber); }
.chat-actions { display: flex; gap: 8px; padding: 8px 16px; border-top: 1px solid var(--border); }

/* Preview panel */
.preview-panel { flex: 1; display: flex; flex-direction: column; }
.preview-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.preview-header h3 { font-size: 0.85rem; }
.preview-actions { display: flex; gap: 6px; }
#preview-frame { flex: 1; border: none; background: #fff; }

/* Toast notifications */
.toast {
  position: fixed; bottom: 70px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 8px 20px; font-size: 0.85rem;
  opacity: 0; transition: opacity 0.3s, transform 0.3s;
  z-index: 1000;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast-error { border-color: var(--danger); color: #f88; }

/* Empty state / PDF conversion */
.empty-state {
  padding: 40px 24px;
  text-align: center;
}
.empty-state h3 { font-size: 1.2rem; margin-bottom: 8px; color: var(--cream); }
.empty-state > p { color: var(--text-dim); margin-bottom: 28px; }

.empty-options {
  display: flex; flex-direction: column; gap: 16px;
  max-width: 400px; margin: 0 auto;
  text-align: left;
}
.empty-option {
  padding: 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
}
.empty-option h4 { font-size: 0.9rem; color: var(--cream); margin-bottom: 4px; }
.empty-option p { font-size: 0.8rem; color: var(--text-dim); margin-bottom: 10px; line-height: 1.5; }

.convert-status {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 24px;
  color: var(--amber); font-size: 0.9rem;
}
.convert-spinner {
  width: 20px; height: 20px;
  border: 2px solid var(--border);
  border-top-color: var(--amber);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Editor footer */
.editor-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 24px;
  background: var(--surface);
  border-top: 1px solid var(--border);
  height: 52px;
  position: fixed;
  bottom: 0;
  left: 240px;
  right: 0;
  z-index: 100;
}
.footer-left, .footer-right { display: flex; gap: 8px; align-items: center; }
.upload-btn { cursor: pointer; }

/* Dialogs */
dialog {
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 24px; max-width: 400px; width: 90%;
}
dialog::backdrop { background: rgba(0,0,0,0.6); }
dialog h3 { margin-bottom: 16px; }
dialog label { display: block; font-size: 0.78rem; color: var(--text-dim); margin: 12px 0 4px; }
dialog input, dialog select {
  width: 100%; padding: 8px 12px;
  background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.85rem;
}
.dialog-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }

/* Login page */
.login-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: linear-gradient(135deg, #1e3160 0%, #ab1d37 100%); }
.login-card { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 40px; width: 340px; border-top: 3px solid var(--crimson); }
.login-card .login-logo { display: block; margin: 0 auto 16px; height: 36px; }
.login-card h1 { font-size: 1.5rem; letter-spacing: 0.08em; text-align: center; margin-bottom: 4px; }
.login-subtitle { text-align: center; color: var(--text-dim); font-size: 0.82rem; margin-bottom: 24px; }
.login-card label { display: block; font-size: 0.78rem; color: var(--text-dim); margin: 14px 0 4px; }
.login-card input {
  width: 100%; padding: 10px 12px;
  background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.9rem;
}
.login-card input:focus { outline: none; border-color: var(--amber); }
.login-card button { width: 100%; margin-top: 20px; padding: 10px; }

/* Public pages */
.public-page { background: #fafafa; color: #333; }
.public-header { padding: 32px 24px; text-align: center; background: var(--smoke); color: var(--cream); }
.public-main { max-width: 800px; margin: 0 auto; padding: 32px 24px; }
.public-main h2 { margin: 24px 0 12px; font-size: 1.1rem; color: #555; }
.tutorial-directory { list-style: none; }
.tutorial-directory li { padding: 8px 0; border-bottom: 1px solid #eee; }
.tutorial-directory a { color: var(--bark); font-size: 0.95rem; }

/* Change History Panel */
.change-history-panel {
  position: fixed; bottom: 52px; right: 0;
  width: 340px; max-height: 320px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px 0 0 0;
  display: flex; flex-direction: column;
  z-index: 100;
  box-shadow: -2px -2px 12px rgba(0,0,0,0.3);
}
.change-history-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.change-history-header h4 {
  font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--text-dim);
}
.change-history-list {
  flex: 1; overflow-y: auto; padding: 4px 0;
}
.change-history-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(58,47,36,0.5);
}
.change-history-item:last-child { border-bottom: none; }
.change-history-desc {
  font-size: 0.82rem; color: var(--cream);
}
.change-history-meta {
  font-size: 0.72rem; color: var(--text-dim);
}

/* Version select styled as dropdown */
#version-select { max-width: 240px; }

/* ═══════════════════════════════════════
   Loading Indicator (global)
   ═══════════════════════════════════════ */

.ro-loading {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 14px;
  padding: 48px 24px; min-height: 120px;
}

/* Spinner ring */
.ro-loading-spinner { position: relative; width: 36px; height: 36px; }
.ro-loading-ring {
  width: 36px; height: 36px; border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--amber);
  animation: roSpin 0.9s linear infinite;
}
@keyframes roSpin { to { transform: rotate(360deg); } }

/* Message text with fade */
.ro-loading-msg {
  font-size: 0.85rem; color: var(--text-dim);
  transition: opacity 0.2s ease;
  text-align: center;
}

/* Progress bar */
.ro-loading-bar {
  width: 180px; height: 3px; border-radius: 2px;
  background: var(--border); overflow: hidden;
}
.ro-loading-bar-fill {
  width: 35%; height: 100%; border-radius: 2px;
  background: linear-gradient(90deg, var(--amber), var(--crimson));
  animation: roSlide 1.8s ease-in-out infinite;
}
@keyframes roSlide {
  0% { transform: translateX(-100%); }
  50% { transform: translateX(200%); }
  100% { transform: translateX(500%); }
}

/* Inline loading (compact) */
.ro-loading-inline {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.82rem; color: var(--text-dim);
}

/* Dot pulse animation */
.ro-loading-dot-pulse {
  display: inline-flex; gap: 3px; align-items: center;
}
.ro-loading-dot-pulse::before,
.ro-loading-dot-pulse::after,
.ro-loading-dot-pulse {
  position: relative;
}
.ro-loading-dot-pulse::before { content: ''; }
.ro-loading-dot-pulse::after { content: ''; }

/* Simple 3-dot bounce */
@keyframes roDotPulse {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
  40% { transform: scale(1); opacity: 1; }
}
.ro-loading-dot-pulse {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--amber);
  animation: roDotPulse 1.2s infinite ease-in-out both;
  animation-delay: 0.16s;
}
.ro-loading-dot-pulse::before,
.ro-loading-dot-pulse::after {
  content: ''; position: absolute; top: 0;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--amber);
  animation: roDotPulse 1.2s infinite ease-in-out both;
}
.ro-loading-dot-pulse::before { left: -10px; animation-delay: 0s; }
.ro-loading-dot-pulse::after { left: 10px; animation-delay: 0.32s; }

/* Button loading state */
.ro-btn-loading {
  display: inline-flex; align-items: center; gap: 8px;
}
.ro-btn-spinner {
  width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  animation: roSpin 0.7s linear infinite;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════
   Integrations Page
   ═══════════════════════════════════════ */

.integrations-page { max-width: 800px; margin: 0 auto; padding: 40px 24px; }
.integrations-header { margin-bottom: 32px; }
.integrations-header h2 { font-size: 1.5rem; color: var(--cream); margin-bottom: 4px; }
.integrations-header p { color: var(--text-dim); font-size: 0.9rem; }

.integrations-grid { display: flex; flex-direction: column; gap: 16px; }

.integration-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.integration-card-header {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}

.integration-icon { width: 36px; height: 36px; flex-shrink: 0; }
.integration-icon svg { width: 100%; height: 100%; }

.integration-info { flex: 1; }
.integration-info h3 { font-size: 1rem; color: var(--cream); margin-bottom: 2px; }
.integration-info p { font-size: 0.8rem; color: var(--text-dim); }

.integration-status {
  font-size: 0.72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.05em;
  padding: 4px 10px; border-radius: 12px;
}
.integration-status[data-status="connected"] { background: rgba(68,170,153,0.15); color: var(--success); }
.integration-status[data-status="disconnected"] { background: rgba(255,255,255,0.06); color: var(--text-dim); }
.integration-status[data-status="error"] { background: rgba(204,68,68,0.15); color: var(--danger); }

.integration-card-body { padding: 16px 20px; }

.field-group { margin-bottom: 12px; }
.field-group label {
  display: block; font-size: 0.72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-dim); margin-bottom: 4px;
}
.int-input {
  width: 100%; padding: 8px 12px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.85rem; font-family: inherit;
}
.int-input:focus { outline: none; border-color: var(--amber); }

.integration-message {
  font-size: 0.8rem; padding: 8px 12px; border-radius: 4px; margin-bottom: 12px;
}
.integration-message.success { background: rgba(68,170,153,0.1); color: var(--success); }
.integration-message.error { background: rgba(204,68,68,0.1); color: #f88; }

.integration-actions { display: flex; gap: 8px; }

/* ═══════════════════════════════════════
   AI Chat Page
   ═══════════════════════════════════════ */

.chat-page {
  display: flex;
  height: calc(100vh - 47px);
  margin-left: 240px;
}

.chat-sidebar {
  width: 220px; padding: 16px;
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  overflow: hidden;
}

.chat-history-list {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column; gap: 2px;
}

.chat-history-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: 10px 12px;
  border-radius: 6px;
  color: var(--text); text-decoration: none;
  font-size: 0.82rem;
  transition: background 0.15s;
}
.chat-history-item:hover { background: rgba(74,139,212,0.08); text-decoration: none; }
.chat-history-item.active { background: rgba(74,139,212,0.15); color: var(--amber); }
.chat-history-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.chat-history-date { font-size: 0.7rem; color: var(--text-dim); }
.chat-empty-hint { color: var(--text-dim); font-size: 0.8rem; font-style: italic; padding: 12px; text-align: center; }

.chat-main {
  flex: 1;
  display: flex; flex-direction: column;
  min-width: 0;
}

.chat-page .chat-messages {
  flex: 1; overflow-y: auto;
  padding: 24px; max-width: 800px; width: 100%;
  margin: 0 auto;
  display: flex; flex-direction: column; gap: 12px;
}

.chat-page .msg {
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 0.88rem;
  line-height: 1.6;
  max-width: 85%;
  word-wrap: break-word;
}
.chat-page .msg-user {
  background: var(--amber);
  color: var(--smoke);
  align-self: flex-end;
  border-radius: 10px 10px 2px 10px;
}
.chat-page .msg-assistant {
  background: var(--surface);
  border: 1px solid var(--border);
  align-self: flex-start;
  border-radius: 10px 10px 10px 2px;
}
.chat-page .msg-content { white-space: pre-wrap; overflow-wrap: break-word; word-break: break-word; }
.chat-page .msg-content code {
  background: rgba(74,139,212,0.12);
  padding: 1px 5px; border-radius: 3px;
  font-size: 0.82rem;
}
.chat-page .msg-content strong { color: var(--cream); }

.chat-error { color: #f88; font-style: italic; }

/* Chat links (inline references) */
.ro-chat-link {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 1px 7px; margin: 1px 2px;
  background: rgba(74,139,212,0.1);
  border: 1px solid rgba(74,139,212,0.2);
  border-radius: 4px;
  color: var(--amber); text-decoration: none;
  font-size: 0.82em; font-weight: 500;
  transition: all 0.15s;
  white-space: nowrap;
  max-width: 100%; overflow: hidden; text-overflow: ellipsis;
}
.ro-chat-link:hover {
  background: rgba(74,139,212,0.2);
  border-color: var(--amber);
  text-decoration: none;
}
.ro-link-icon { font-size: 0.85em; }

/* Typing dots */
.typing-dots span {
  animation: typingBounce 1.4s infinite both;
  font-size: 1.8rem; line-height: 0.5;
  color: var(--text-dim);
}
.typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.typing-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBounce {
  0%, 60%, 100% { opacity: 0.3; }
  30% { opacity: 1; }
}

/* Chat welcome */
.chat-welcome {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; flex: 1;
  text-align: center; padding: 40px;
}
.chat-welcome-icon { width: 56px; height: 56px; margin-bottom: 16px; opacity: 0.6; }
.chat-welcome-icon svg { width: 100%; height: 100%; }
.chat-welcome h3 { font-size: 1.3rem; color: var(--cream); margin-bottom: 8px; }
.chat-welcome p { color: var(--text-dim); font-size: 0.9rem; max-width: 420px; margin-bottom: 24px; }

.chat-suggestions {
  display: flex; flex-wrap: wrap; gap: 8px;
  justify-content: center; max-width: 500px;
}
.suggestion-chip {
  padding: 8px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 20px;
  color: var(--text);
  font-size: 0.8rem; font-family: inherit;
  cursor: pointer;
  transition: all 0.15s;
}
.suggestion-chip:hover {
  border-color: var(--amber);
  color: var(--amber);
  background: rgba(74,139,212,0.06);
}

/* Chat input */
.chat-input-area {
  padding: 16px 24px 20px;
  border-top: 1px solid var(--border);
  max-width: 800px; width: 100%;
  margin: 0 auto;
}
.chat-input-row {
  display: flex; gap: 8px; align-items: flex-end;
}
.chat-input-row textarea {
  flex: 1; padding: 10px 14px; resize: none;
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border); border-radius: 10px;
  font-family: inherit; font-size: 0.88rem;
  line-height: 1.4;
  max-height: 160px;
}
.chat-input-row textarea:focus { outline: none; border-color: var(--amber); }

.chat-send-btn {
  width: 40px; height: 40px;
  padding: 0; display: flex; align-items: center; justify-content: center;
  border-radius: 10px; flex-shrink: 0;
}

.chat-input-hint {
  font-size: 0.72rem; color: var(--text-dim);
  margin-top: 6px; text-align: center;
}

/* ═══════════════════════════════════════
   Jira Page
   ═══════════════════════════════════════ */

.jira-page { display: flex; flex-direction: column; height: calc(100vh - 47px); margin-left: 240px; }

/* Project bar */
.jira-project-bar {
  display: flex; align-items: center; gap: 20px;
  padding: 12px 24px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.jira-project-selector { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.jira-project-selector label {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-dim); font-weight: 600;
}
.jira-project-selector select {
  padding: 6px 10px; background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 4px;
  font-size: 0.85rem; font-family: inherit; cursor: pointer;
}

/* Stats bar (inside project bar) */
.jira-stats-bar {
  display: flex; gap: 14px; flex: 1;
  overflow-x: auto; align-items: center;
}
.jira-stat-card {
  display: flex; align-items: baseline; gap: 5px;
  padding: 0; background: none; border: none; flex-shrink: 0;
}
.jira-stat-card.accent {}
.jira-stat-number { font-size: 1rem; font-weight: 700; color: var(--cream); }
.jira-stat-card.accent .jira-stat-number { color: var(--success); }
.jira-stat-label {
  font-size: 0.65rem; color: var(--text-dim); text-transform: uppercase;
  letter-spacing: 0.03em; white-space: nowrap;
}
.jira-stat-shimmer { font-size: 0.8rem; color: var(--text-dim); padding: 8px; }

/* Layout */
.jira-layout { display: flex; flex: 1; overflow: hidden; }

/* Browser panel */
.jira-browser {
  width: 280px; display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
  flex-shrink: 0;
}
.jira-browser-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.jira-browser-header h3 { font-size: 0.88rem; color: var(--cream); }
.jira-browser-filters { display: flex; gap: 4px; }

.jira-filter-select {
  padding: 4px 6px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 3px;
  font-size: 0.72rem; font-family: inherit;
  cursor: pointer;
}
.jira-filter-select:focus { outline: none; border-color: var(--amber); }

.jira-ticket-list { flex: 1; overflow-y: auto; }

.jira-ticket-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}
.jira-ticket-item:hover { background: rgba(74,139,212,0.05); }
.jira-ticket-item.selected { background: rgba(74,139,212,0.1); border-left: 3px solid var(--amber); }

.jira-ticket-top { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; }
.jira-ticket-key { font-size: 0.7rem; font-weight: 700; color: var(--amber); }
.jira-ticket-summary { font-size: 0.8rem; color: var(--cream); line-height: 1.35; margin-bottom: 4px; }
.jira-ticket-bottom { display: flex; align-items: center; gap: 6px; }
.jira-ticket-assignee { font-size: 0.68rem; color: var(--text-dim); margin-left: auto; }

/* Type badges */
.jira-ticket-type {
  font-size: 0.6rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; padding: 1px 5px; border-radius: 3px;
}
.jira-type-story { background: rgba(68,170,153,0.15); color: var(--success); }
.jira-type-bug { background: rgba(204,68,68,0.15); color: #f88; }
.jira-type-epic { background: rgba(138,100,200,0.15); color: #b89cdf; }
.jira-type-task { background: rgba(74,139,212,0.12); color: var(--amber); }

/* Priority badges */
.jira-ticket-priority {
  font-size: 0.6rem; font-weight: 600; padding: 1px 5px; border-radius: 3px;
}
.jira-pri-highest { background: rgba(204,40,40,0.2); color: #f66; }
.jira-pri-high { background: rgba(220,100,40,0.15); color: #f90; }
.jira-pri-medium { background: rgba(200,180,60,0.12); color: #cc8; }
.jira-pri-low { background: rgba(74,139,212,0.12); color: var(--amber); }
.jira-pri-lowest { background: rgba(255,255,255,0.05); color: var(--text-dim); }

/* Status badges */
.jira-ticket-status {
  font-size: 0.6rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; padding: 2px 6px; border-radius: 10px;
  background: rgba(255,255,255,0.06); color: var(--text-dim);
}

.jira-loading { padding: 30px; text-align: center; color: var(--text-dim); font-size: 0.82rem; }

/* ─── AI Workspace ─── */
.jira-workspace {
  flex: 1; display: flex; flex-direction: column; overflow: hidden;
}

.jira-workspace-tabs {
  display: flex; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
}
.jira-tab {
  padding: 10px 18px;
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-dim); font-size: 0.8rem; font-weight: 600;
  font-family: inherit; cursor: pointer; transition: all 0.2s;
}
.jira-tab:hover { color: var(--text); }
.jira-tab.active { color: var(--amber); border-bottom-color: var(--amber); }

.jira-tab-panel { display: none; flex: 1; overflow: hidden; }
.jira-tab-panel.active { display: flex; }

/* AI Panel (reusable inside tabs) */
.jira-ai-panel { display: flex; flex-direction: column; flex: 1; overflow: hidden; }
.jira-ai-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.jira-ai-header h3 { font-size: 1rem; color: var(--cream); }
.jira-ai-content { flex: 1; overflow-y: auto; padding: 20px; }
.jira-ai-hint { font-size: 0.82rem; color: var(--text-dim); margin-bottom: 16px; line-height: 1.5; }
.jira-ai-welcome { text-align: center; padding: 40px 20px; }
.jira-ai-welcome p { color: var(--text-dim); font-size: 0.88rem; line-height: 1.6; }

.jira-form-row { display: flex; gap: 12px; margin-bottom: 4px; }
.jira-form-row .field-group { flex: 1; }
.jira-form-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 16px; }

/* Summary output */
.jira-summary-output {
  font-size: 0.88rem; line-height: 1.7; color: var(--text);
}
.jira-summary-output h2, .jira-summary-output h3, .jira-summary-output h4 {
  color: var(--cream); margin: 16px 0 8px;
}
.jira-summary-output h2 { font-size: 1.1rem; }
.jira-summary-output h3 { font-size: 0.95rem; }
.jira-summary-output h4 { font-size: 0.88rem; }
.jira-summary-output p { margin-bottom: 4px; }
.jira-summary-output ul, .jira-summary-output ol { margin: 2px 0; padding-left: 18px; }
.jira-summary-output li { margin-bottom: 1px; line-height: 1.5; }
.jira-summary-output strong { color: var(--cream); }
.jira-summary-output code {
  background: rgba(74,139,212,0.12); padding: 1px 5px; border-radius: 3px;
  font-size: 0.82rem;
}

/* Ticket preview */
.ticket-preview-banner {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; margin-bottom: 16px;
  background: rgba(74,139,212,0.08);
  border: 1px solid rgba(74,139,212,0.2);
  border-radius: 6px;
  font-size: 0.82rem; color: var(--amber);
}
.ticket-preview-meta { display: flex; gap: 8px; margin-bottom: 14px; }
.ticket-preview-meta .badge { padding: 4px 10px; font-size: 0.72rem; }

/* Document output */
.doc-output-header {
  display: flex; align-items: center; justify-content: space-between;
  margin: 20px 0 10px;
  padding-bottom: 8px; border-bottom: 1px solid var(--border);
}
.doc-output-header h4 { font-size: 0.88rem; color: var(--cream); }
.doc-output-content {
  font-size: 0.88rem; line-height: 1.7; color: var(--text);
  max-height: 500px; overflow-y: auto;
  padding: 16px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.doc-output-content h2, .doc-output-content h3, .doc-output-content h4 { color: var(--cream); margin: 10px 0 4px; }
.doc-output-content p { margin-bottom: 4px; }
.doc-output-content ul, .doc-output-content ol { margin: 2px 0; padding-left: 18px; }
.doc-output-content li { margin-bottom: 1px; line-height: 1.5; }
.doc-output-content strong { color: var(--cream); }

/* Release notes */
.release-ticket-selector { margin-bottom: 12px; }
.release-selector-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.release-selector-header label {
  font-size: 0.72rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--text-dim);
}
.release-ticket-list {
  max-height: 240px; overflow-y: auto;
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  padding: 4px 0;
}
.release-ticket-check {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 12px; cursor: pointer;
  font-size: 0.8rem; transition: background 0.1s;
}
.release-ticket-check:hover { background: rgba(74,139,212,0.05); }
.release-ticket-check input { cursor: pointer; }
.release-ticket-summary { color: var(--text); flex: 1; }

.release-output-section { margin-top: 16px; }
.release-output-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
}
.release-output-header h4 { font-size: 0.85rem; color: var(--cream); }
.char-count { font-size: 0.72rem; color: var(--text-dim); font-weight: 400; margin-left: 8px; }
.release-text {
  padding: 14px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; font-size: 0.82rem; line-height: 1.6;
  color: var(--text); white-space: pre-wrap; font-family: inherit;
  max-height: 300px; overflow-y: auto;
}

/* ═══════════════════════════════════════
   Mailchimp Page
   ═══════════════════════════════════════ */

.mc-page { display: flex; flex-direction: column; height: calc(100vh - 47px); margin-left: 240px; }

.mc-workspace-tabs {
  display: flex; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
}
.mc-tab {
  padding: 10px 20px;
  background: none; border: none; border-bottom: 2px solid transparent;
  color: var(--text-dim); font-size: 0.82rem; font-weight: 600;
  font-family: inherit; cursor: pointer; transition: all 0.2s;
}
.mc-tab:hover { color: var(--text); }
.mc-tab.active { color: var(--amber); border-bottom-color: var(--amber); }

.mc-tab-panel { display: none; flex: 1; overflow: hidden; flex-direction: column; }
.mc-tab-panel.active { display: flex; }

.mc-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mc-panel-header h2 { font-size: 1rem; color: var(--cream); }
.mc-filter-row { display: flex; gap: 8px; }

/* Campaigns split layout */
.mc-campaigns-layout { display: flex; flex: 1; overflow: hidden; }
.mc-campaigns-left { width: 420px; flex-shrink: 0; display: flex; flex-direction: column; overflow: hidden; border-right: 1px solid var(--border); }
.mc-campaigns-left .mc-table { font-size: 0.72rem; }
.mc-campaigns-left .mc-table th { padding: 6px 8px; }
.mc-campaigns-left .mc-table td { padding: 7px 8px; }
.mc-campaigns-right { flex: 1; overflow-y: auto; }

/* Campaign list table */
.mc-campaign-list, .mc-analytics-list { flex: 1; overflow-y: auto; padding: 0; }

.mc-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.8rem;
}
#campaign-list .mc-table { table-layout: fixed; }
#campaign-list .mc-table th:nth-child(1) { width: 60%; }
#campaign-list .mc-table th:nth-child(2) { width: 20%; }
#campaign-list .mc-table th:nth-child(3) { width: 20%; }
.mc-table thead { position: sticky; top: 0; z-index: 1; }
.mc-table th {
  background: var(--surface); color: var(--text-dim);
  font-size: 0.68rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
  padding: 8px 12px; text-align: left;
  border-bottom: 1px solid var(--border);
}
.mc-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}
.mc-table tr:hover td { background: rgba(74,139,212,0.03); }
.mc-td-title { color: var(--cream); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mc-td-subject { color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mc-td-segment { font-size: 0.72rem; color: var(--text-dim); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mc-td-num { text-align: right; white-space: nowrap; }
.mc-td-from { font-size: 0.75rem; color: var(--text-dim); }
.mc-td-date { font-size: 0.75rem; white-space: nowrap; }

.mc-status {
  font-size: 0.62rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em;
  padding: 2px 8px; border-radius: 10px; white-space: nowrap;
}
.mc-sent { background: rgba(68,170,153,0.15); color: var(--success); }
.mc-scheduled { background: rgba(74,139,212,0.12); color: var(--amber); }
.mc-draft { background: rgba(255,255,255,0.06); color: var(--text-dim); }

.mc-clickable-row { cursor: pointer; }
.mc-clickable-row:hover td { background: rgba(74,139,212,0.06) !important; }

.mc-load-more { padding: 12px; text-align: center; display: flex; gap: 8px; justify-content: center; }

.mc-refresh-indicator {
  padding: 4px 12px;
  text-align: center;
  font-size: 0.7rem;
  color: var(--text-dim);
  background: rgba(74,139,212,0.06);
  border-bottom: 1px solid rgba(74,139,212,0.1);
  animation: mc-pulse 1.5s ease-in-out infinite;
}
@keyframes mc-pulse { 0%,100% { opacity: .5; } 50% { opacity: 1; } }

.mc-fetch-error {
  padding: 6px 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  color: #e8927c;
  background: rgba(232,146,124,0.08);
  border-bottom: 1px solid rgba(232,146,124,0.15);
}

.mc-retry-wrap { padding: 10px; text-align: center; }

/* Loading bar animation */
.mc-loading-bar {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 40px 24px;
}
.mc-loading-bar span { font-size: 0.82rem; color: var(--text-dim); }
.mc-loading-fill {
  width: 200px; height: 4px; border-radius: 2px;
  background: var(--border); overflow: hidden; position: relative;
}
.mc-loading-fill::after {
  content: ''; position: absolute; left: -40%; top: 0;
  width: 40%; height: 100%; border-radius: 2px;
  background: var(--amber);
  animation: loadSlide 1.2s ease-in-out infinite;
}
@keyframes loadSlide {
  0% { left: -40%; }
  100% { left: 100%; }
}

/* Campaign detail panel */
.mc-detail-content { padding: 20px; }
.mc-detail-header { margin-bottom: 16px; }
.mc-detail-header h2 { font-size: 1rem; color: var(--cream); margin: 6px 0 4px; }
.mc-detail-subject { font-size: 0.82rem; color: var(--text-dim); }
.mc-detail-subject strong { color: var(--text); }

.mc-detail-meta-grid {
  display: flex; flex-direction: column; gap: 6px;
  padding: 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  margin-bottom: 14px; font-size: 0.8rem;
}
.mc-detail-meta-item { display: flex; gap: 8px; }
.mc-detail-meta-item .jira-meta-label { min-width: 70px; }
.mc-detail-meta-item > span:last-child { color: var(--text); }

.mc-detail-stats {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 8px;
  margin-bottom: 14px;
}
.mc-detail-stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 10px 8px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.mc-detail-stat-num { font-size: 1.1rem; font-weight: 700; color: var(--cream); }
.mc-detail-stat-label { font-size: 0.62rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.mc-detail-stat-pct { font-size: 0.75rem; font-weight: 600; color: var(--success); margin-top: 2px; }

.mc-detail-actions { display: flex; gap: 8px; margin-bottom: 14px; }
.mc-detail-preview-label {
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-dim); font-weight: 600; margin-bottom: 6px;
}
.mc-detail-preview-frame {
  width: 100%; height: 500px; border: 1px solid var(--border);
  border-radius: 4px; background: #fff;
}

.mc-campaigns-right .jira-detail-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%;
  color: var(--text-dim); gap: 12px; text-align: center;
}
.mc-campaigns-right .jira-detail-empty svg { opacity: 0.4; }
.mc-campaigns-right .jira-detail-empty p { font-size: 0.85rem; }

.mc-total { font-size: 0.68rem; color: var(--text-dim); }

/* Analytics bars */
.mc-bar-cell { display: flex; align-items: center; gap: 6px; min-width: 100px; }
.mc-bar {
  height: 6px; border-radius: 3px; min-width: 2px;
}
.mc-bar-open { background: var(--success); }
.mc-bar-click { background: var(--amber); }
.mc-bar-cell span { font-size: 0.75rem; font-weight: 600; white-space: nowrap; }

/* Create email layout */
.mc-create-layout { display: flex; flex: 1; overflow: hidden; }

.mc-create-form {
  width: 50%; display: flex; flex-direction: column;
  border-right: 1px solid var(--border);
}
.mc-form-content { flex: 1; overflow-y: auto; padding: 20px; }

.mc-create-preview {
  width: 50%; display: flex; flex-direction: column;
}
.mc-preview-header {
  padding: 10px 16px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.mc-preview-header h3 { font-size: 0.85rem; color: var(--cream); }
.mc-preview-iframe { flex: 1; border: none; background: #f4f5f7; }

/* Template picker */
.mc-template-picker { display: flex; gap: 10px; }
.mc-template-option { cursor: pointer; flex: 1; }
.mc-template-option input { display: none; }
.mc-template-card {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 14px 10px;
  background: var(--bg); border: 2px solid var(--border); border-radius: 8px;
  transition: all 0.15s; text-align: center;
}
.mc-template-option.selected .mc-template-card,
.mc-template-option:hover .mc-template-card {
  border-color: var(--amber);
}
.mc-template-card span { font-size: 0.78rem; font-weight: 600; color: var(--cream); }
.mc-template-card small { font-size: 0.68rem; color: var(--text-dim); }
.mc-tpl-icon {
  font-size: 1.4rem; font-weight: 700; color: var(--amber); opacity: 0.7;
  width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
}

/* Mini template previews */
.mc-tpl-icon-img {
  width: 40px; height: 44px; display: flex; flex-direction: column; gap: 3px;
  padding: 3px;
}
.mc-tpl-bar { height: 6px; background: var(--navy); border-radius: 1px; }
.mc-tpl-img-block { height: 10px; background: rgba(74,139,212,0.15); border-radius: 1px; }
.mc-tpl-lines { height: 3px; background: rgba(255,255,255,0.1); border-radius: 1px; margin-top: 1px; }
.mc-tpl-lines.short { width: 60%; }
.mc-tpl-btn-block { height: 5px; width: 50%; background: var(--crimson); border-radius: 1px; margin: 1px auto 0; opacity: 0.6; }

/* Success panel */
.mc-success-panel { text-align: center; padding: 20px; }
.mc-success-icon {
  font-size: 2rem; color: var(--success);
  width: 56px; height: 56px; line-height: 56px;
  background: rgba(68,170,153,0.1); border-radius: 50%;
  margin: 0 auto 12px;
}
.mc-success-panel h3 { color: var(--cream); margin-bottom: 6px; }
.mc-success-panel code { background: rgba(74,139,212,0.12); padding: 2px 8px; border-radius: 3px; }

/* ═══════════════════════════════════════
   Settings Page
   ═══════════════════════════════════════ */

.settings-page { display: flex; height: calc(100vh - 47px); margin-left: 240px; }

.settings-sidebar {
  width: 220px; padding: 20px 16px;
  background: var(--surface); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 2px;
}
.settings-sidebar h3 {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--text-dim); margin-bottom: 12px;
}
.settings-nav-item {
  display: block; padding: 8px 12px; border-radius: 4px;
  font-size: 0.85rem; color: var(--text); text-decoration: none;
}
.settings-nav-item:hover { background: rgba(74,139,212,0.08); text-decoration: none; }
.settings-nav-item.active { background: rgba(74,139,212,0.12); color: var(--amber); font-weight: 600; }

.settings-content {
  flex: 1; overflow-y: auto; padding: 32px;
}

.settings-section { display: none; max-width: 800px; }
.settings-section.active { display: block; }
#section-media.active { max-width: none; }

.btn-tiny { background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: 0.72rem; padding: 0 4px; opacity: 0.6; }
.btn-tiny:hover { opacity: 1; color: var(--text); }
.settings-section h2 { font-size: 1.2rem; color: var(--cream); margin-bottom: 4px; }

/* Asset groups */
.settings-asset-group { margin-top: 24px; }
.settings-asset-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.settings-asset-header h3 { font-size: 0.9rem; color: var(--cream); }

.settings-asset-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px;
}
.settings-asset-card {
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  overflow: hidden; position: relative;
}
.settings-asset-card img {
  width: 100%; height: 80px; object-fit: contain;
  background: #fff; padding: 8px;
}
.settings-asset-info { padding: 8px; }
.settings-asset-name {
  display: block; font-size: 0.72rem; color: var(--text-dim);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  margin-bottom: 4px;
}
.settings-asset-actions { display: flex; gap: 4px; align-items: center; }
.settings-asset-actions .block-delete { margin-left: auto; }

/* Document list */
.settings-doc-list { display: flex; flex-direction: column; gap: 4px; margin-top: 8px; }
.settings-doc-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 4px;
}
.settings-doc-name { flex: 1; font-size: 0.85rem; color: var(--cream); }
.settings-doc-size { font-size: 0.72rem; color: var(--text-dim); }

/* Role cards */
.settings-role-card {
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  padding: 14px; margin-bottom: 12px;
}
.settings-role-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 4px;
}
.settings-role-header strong { color: var(--cream); font-size: 0.9rem; }
.settings-role-desc { font-size: 0.75rem; color: var(--text-dim); }
.settings-role-card .mc-table { margin-top: 8px; }
.settings-role-card .mc-table td, .settings-role-card .mc-table th { padding: 4px 8px; }
.settings-role-card input[type="checkbox"] { cursor: pointer; }

/* ═══════════════════════════════════════
   Document Builder
   ═══════════════════════════════════════ */

.docs-page { display: flex; height: calc(100vh - 47px); margin-left: 240px; }

.docs-sidebar {
  width: 220px; padding: 16px;
  background: var(--surface); border-right: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
}
.docs-filter { margin-bottom: 8px; }
.docs-list { flex: 1; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }

.docs-list-item {
  padding: 10px 12px; border-radius: 6px; cursor: pointer;
  transition: background 0.15s;
}
.docs-list-item:hover { background: rgba(74,139,212,0.06); }
.docs-list-item.active { background: rgba(74,139,212,0.12); }
.docs-list-title { font-size: 0.82rem; color: var(--cream); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.docs-list-meta { display: flex; justify-content: space-between; font-size: 0.68rem; color: var(--text-dim); margin-top: 2px; }

.docs-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
#docs-create-panel { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }

/* Create panel */
.docs-create-header {
  padding: 14px 24px; border-bottom: 1px solid var(--border);
}
.docs-create-header h2 { font-size: 1rem; color: var(--cream); }
.docs-create-content { padding: 24px; overflow-y: auto; max-width: 700px; flex: 1; min-height: 0; }

/* Editor Header — refined two-row layout */
.docs-editor-header {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; border-bottom: 1px solid var(--border);
  flex-shrink: 0; background: var(--surface);
}
.docs-title-input {
  flex: 1; padding: 7px 12px; font-size: 1.05rem; font-weight: 700;
  background: transparent; color: var(--cream); border: 1px solid transparent;
  border-radius: 6px; font-family: inherit; min-width: 0;
  letter-spacing: -0.01em;
}
.docs-title-input:focus { outline: none; border-color: var(--border); background: var(--bg); }
.docs-editor-status { flex-shrink: 0; }
.docs-editor-actions {
  display: flex; gap: 3px; flex-shrink: 0; align-items: center;
}
.docs-editor-actions .docs-action-sep {
  width: 1px; height: 20px; background: var(--border); margin: 0 6px;
}
/* Icon-only toolbar buttons */
.docs-icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 6px; border: 1px solid transparent;
  background: none; color: var(--text-dim); cursor: pointer;
  transition: all 0.15s var(--ease); position: relative;
}
.docs-icon-btn:hover { background: var(--surface-2); color: var(--text); border-color: var(--border); }
.docs-icon-btn:active { transform: scale(0.95); }
.docs-icon-btn svg { width: 16px; height: 16px; }
.docs-icon-btn.danger:hover { color: var(--err); background: var(--err-bg); border-color: rgba(220,53,69,0.2); }
.docs-icon-btn[data-tooltip]::after {
  content: attr(data-tooltip); position: absolute; bottom: -28px; left: 50%;
  transform: translateX(-50%); padding: 3px 8px; border-radius: 4px;
  background: var(--bg); color: var(--text-soft); font-size: 0.65rem;
  white-space: nowrap; pointer-events: none; opacity: 0; transition: opacity 0.15s;
  border: 1px solid var(--border); z-index: 10;
}
.docs-icon-btn[data-tooltip]:hover::after { opacity: 1; }

#docs-editor-panel { display: flex; flex-direction: column; flex: 1; overflow: hidden; }

.docs-editor-toolbar-row {
  display: flex; align-items: center; flex-wrap: wrap;
  padding: 4px 8px; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0; gap: 2px 6px;
}
.wysiwyg-toolbar-struct {
  border-top: 1px solid var(--border); padding-top: 3px; width: 100%;
}

.docs-editor-body {
  flex: 1; display: flex; flex-direction: column;
  overflow: hidden; min-height: 0; position: relative;
}

.docs-html-editor {
  flex: 1; padding: 16px 24px; resize: none;
  background: var(--bg); color: var(--text);
  border: none; font-family: 'SF Mono', 'Fira Code', Consolas, monospace;
  font-size: 0.78rem; line-height: 1.5;
  overflow-y: auto; min-height: 0;
}
.docs-html-editor:focus { outline: none; }

/* WYSIWYG editor */
.docs-wysiwyg-editor {
  flex: 1; padding: 32px 48px; overflow-y: auto;
  background: #fff; color: #333;
  font-family: -apple-system, sans-serif; font-size: 15px; line-height: 1.7;
  min-height: 0; outline: none;
  max-width: 100%;
}
.docs-wysiwyg-editor h1 { color: #1e3160; font-size: 22px; border-bottom: 2px solid #1e3160; padding-bottom: 6px; margin: 16px 0 10px; }
.docs-wysiwyg-editor h2 { color: #1e3160; font-size: 17px; margin: 20px 0 8px; border-bottom: 1px solid #ddd; padding-bottom: 3px; }
.docs-wysiwyg-editor h3 { font-size: 14px; margin: 16px 0 6px; }
.docs-wysiwyg-editor p { margin: 0 0 10px; }
.docs-wysiwyg-editor ul, .docs-wysiwyg-editor ol { margin: 4px 0 10px; padding-left: 22px; }
.docs-wysiwyg-editor li { margin-bottom: 3px; }
.docs-wysiwyg-editor strong { color: #1e3160; font-weight: 700; }
.docs-wysiwyg-editor a { color: #4a8bd4; }
.docs-wysiwyg-editor table { width: 100%; border-collapse: collapse; margin: 10px 0; }
.docs-wysiwyg-editor th, .docs-wysiwyg-editor td { padding: 6px 10px; border: 1px solid #ddd; }
.docs-wysiwyg-editor th { background: #f5f5f5; font-weight: 600; }
.docs-wysiwyg-editor img { max-width: 100%; height: auto; border-radius: 4px; margin: 8px 0; }

/* WYSIWYG toolbar */
.wysiwyg-toolbar { display: flex; gap: 2px; align-items: center; flex-wrap: nowrap; }
.wysiwyg-btn {
  padding: 2px 6px; background: none; border: 1px solid transparent;
  border-radius: 3px; color: var(--text); font-size: 0.7rem; font-family: inherit;
  cursor: pointer; transition: all 0.15s; white-space: nowrap; flex-shrink: 0;
}
.wysiwyg-btn:hover { background: var(--bg); border-color: var(--border); }
.wysiwyg-sep { width: 1px; height: 14px; background: var(--border); margin: 0 3px; flex-shrink: 0; }
.wysiwyg-label { font-size: 0.65rem; color: var(--text-dim); font-weight: 600; margin-right: 2px; text-transform: uppercase; letter-spacing: 0.03em; flex-shrink: 0; }
.wysiwyg-select {
  padding: 2px 4px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 3px; color: var(--text); font-size: 0.68rem; font-family: inherit;
  cursor: pointer; flex-shrink: 0;
}
.wysiwyg-select:focus { outline: none; border-color: var(--accent); }
.wysiwyg-color-wrap { position: relative; cursor: pointer; display: inline-flex; align-items: center; gap: 2px; }
.wysiwyg-color-indicator { display: inline-block; width: 12px; height: 3px; border-radius: 1px; background: #1e3160; margin-top: 1px; }

/* Preview dialog */
.docs-preview-dialog {
  width: 90%; max-width: 800px; height: 85vh;
  padding: 0; border-radius: 10px; overflow: hidden;
}
.docs-preview-dialog-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; border-bottom: 1px solid var(--border);
}
.docs-preview-dialog-header h3 { font-size: 0.9rem; color: var(--cream); }
.docs-preview-dialog-frame {
  width: 100%; height: calc(100% - 44px); border: none; background: #fff;
}

/* Sidebar status dots */
.docs-list-item { display: flex; align-items: flex-start; gap: 8px; }
.docs-list-info { flex: 1; min-width: 0; }
.docs-status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 6px;
}
.docs-status-dot.draft { background: var(--text-dim); }
.docs-status-dot.published { background: var(--success); }

/* Doc upload */
.doc-upload-row { display: flex; gap: 8px; align-items: flex-start; }
.doc-upload-row textarea { flex: 1; }
.doc-upload-btn { flex-shrink: 0; align-self: flex-start; margin-top: 4px; }
.doc-upload-status { font-size: 0.78rem; margin-top: 4px; padding: 4px 8px; border-radius: 3px; }
.doc-upload-status.success { color: var(--success); }
.doc-upload-status.error { color: #f88; }

/* ─── Branded Document Template Styles ─── */

/* Shared structured doc styles */
.doc-h1 {
  color: #1e3160; font-size: 22px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.03em; margin: 0 0 16px; padding-bottom: 6px;
  border-bottom: 3px solid #1e3160;
}
.doc-section-header {
  background: #1e3160; color: #fff; font-size: 0.82rem; font-weight: 600;
  padding: 5px 10px; margin: 20px 0 8px; border-radius: 2px;
}
.doc-info-table {
  width: 100%; border-collapse: collapse; margin: 0 0 12px; border: 1px solid #ccc;
}
.doc-info-table th {
  text-align: left; padding: 6px 10px; font-weight: 600; font-size: 0.82rem;
  color: #333; background: #f5f5f5; border: 1px solid #ccc; width: 180px;
}
.doc-info-table td {
  padding: 6px 10px; font-size: 0.82rem; color: #333; border: 1px solid #ccc;
}
.doc-data-table {
  width: 100%; border-collapse: collapse; margin: 0 0 12px; border: 1px solid #ccc;
}
.doc-data-table thead th {
  background: #f5f5f5; font-weight: 600; font-size: 0.78rem; color: #333;
  padding: 6px 10px; border: 1px solid #ccc; text-align: left;
}
.doc-data-table tbody th {
  font-weight: 600; font-size: 0.82rem; color: #333;
  padding: 6px 10px; border: 1px solid #ccc; background: #fafafa; width: 140px;
}
.doc-data-table td {
  padding: 6px 10px; font-size: 0.82rem; color: #333; border: 1px solid #ccc;
}
.doc-field-label {
  font-size: 0.85rem; font-weight: 600; color: #1e3160; margin: 14px 0 4px;
}
.doc-field-hint {
  font-size: 0.78rem; color: #888; font-weight: 400; font-style: italic;
}
.doc-field-content {
  font-size: 0.85rem; color: #333; line-height: 1.6; min-height: 24px;
  padding: 4px 0; margin-bottom: 12px;
}

/* AI toolbar row */
.wysiwyg-toolbar-ai {
  border-top: 1px solid var(--border); padding-top: 3px; width: 100%;
}
.wysiwyg-btn-ai { color: var(--accent); font-weight: 600; }
.doc-ai-target {
  font-size: 0.63rem; color: var(--text-dim); font-style: italic;
  max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Section hover highlight in editor */
.docs-wysiwyg-editor .doc-field-content:hover {
  outline: 1px dashed rgba(74, 139, 212, 0.3); outline-offset: 2px; border-radius: 2px;
}

/* Placeholder highlights */
.doc-placeholder {
  background: #fff3a3; color: #7a5c00; padding: 1px 4px; border-radius: 2px;
  border-bottom: 1px dashed #c9a800; font-style: italic; font-size: inherit;
  cursor: text;
}
.doc-placeholder:hover { background: #ffe566; }
.doc-placeholder:focus { background: #fff; color: #333; border-bottom-color: #1e3160; outline: none; font-style: normal; }

/* Press Release styles */
.doc-pr-banner {
  font-size: 0.82rem; font-weight: 700; color: #333; letter-spacing: 0.05em;
  margin-bottom: 12px;
}
.doc-pr-contact {
  font-size: 0.82rem; color: #555; margin-bottom: 20px; line-height: 1.5;
}
.doc-pr-contact p { margin: 0 0 4px; }
.doc-pr-headline {
  font-size: 1.2rem; font-weight: 700; color: #1e3160; line-height: 1.3;
  margin: 0 0 8px; border: none; padding: 0;
}
.doc-pr-subhead {
  font-size: 0.92rem; color: #555; margin: 0 0 16px; line-height: 1.5;
}
.doc-pr-dateline {
  font-size: 0.88rem; color: #333; line-height: 1.6; margin: 0 0 12px;
}
.doc-pr-body {
  font-size: 0.88rem; color: #333; line-height: 1.6; margin-bottom: 16px;
}
.doc-pr-body p { margin: 0 0 10px; }
.doc-pr-bullets {
  margin: 8px 0 16px; padding-left: 20px; font-size: 0.88rem; color: #333;
}
.doc-pr-bullets li { margin-bottom: 4px; line-height: 1.5; }
.doc-pr-bullets li::marker { content: "\2014\00a0"; color: #1e3160; }
.doc-pr-quote {
  margin: 12px 0 12px 20px; padding: 10px 16px;
  border-left: 3px solid #1e3160; background: #f8f9fb; font-size: 0.88rem;
}
.doc-pr-quote p {
  color: #333; font-style: italic; line-height: 1.6; margin: 0 0 6px;
}
.doc-pr-quote cite {
  display: block; font-style: normal; font-size: 0.82rem; color: #666;
}
.doc-pr-about {
  margin: 16px 0 8px; font-size: 0.85rem; color: #333; line-height: 1.6;
}
.doc-pr-about p { margin: 0 0 6px; }
.doc-pr-endmark {
  text-align: center; font-size: 1rem; font-weight: 700; color: #333;
  margin: 24px 0 8px; letter-spacing: 0.1em;
}
.doc-pr-footer {
  text-align: center; font-size: 0.78rem; color: #888; margin-top: 4px;
}

/* ─── Structured Intake Form ─── */
.doc-intake-form { padding: 24px; overflow-y: auto; max-width: 780px; }
.doc-intake-description {
  font-size: 0.82rem; color: var(--text-dim); margin-bottom: 16px;
  padding: 10px 14px; background: rgba(74,139,212,0.06); border-radius: 4px;
  border-left: 3px solid var(--amber);
}
.doc-intake-section {
  margin-bottom: 6px;
}
.doc-intake-section > label {
  display: block; font-size: 0.8rem; font-weight: 600; color: var(--cream);
  margin-bottom: 4px;
}
.doc-intake-section > label .required-star { color: var(--danger); margin-left: 2px; }
.doc-intake-hint {
  font-size: 0.72rem; color: var(--text-dim); font-weight: 400; margin-left: 4px;
}

/* Intake toggle */
.doc-intake-details { margin-top: 16px; }
.doc-intake-toggle {
  font-size: 0.85rem; font-weight: 600; color: var(--cream); cursor: pointer;
  padding: 8px 0; list-style: none; display: flex; align-items: center; gap: 6px;
  user-select: none;
}
.doc-intake-toggle::before { content: '\25B6'; font-size: 0.6rem; transition: transform 0.2s; }
.doc-intake-details[open] > .doc-intake-toggle::before { transform: rotate(90deg); }
.doc-intake-toggle::-webkit-details-marker { display: none; }

/* Row-type fields (dynamic table builder) */
.doc-rows-table {
  width: 100%; border-collapse: collapse; margin-bottom: 4px;
}
.doc-rows-table th {
  font-size: 0.72rem; color: var(--text-dim); text-align: left;
  padding: 3px 6px; border-bottom: 1px solid var(--border); font-weight: 500;
}
.doc-rows-table td { padding: 2px 4px; }
.doc-rows-table input {
  width: 100%; padding: 4px 6px; font-size: 0.8rem;
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: 3px; font-family: inherit;
}
.doc-rows-table input:focus { outline: none; border-color: var(--amber); }
.doc-row-remove {
  background: none; border: none; color: var(--text-dim); cursor: pointer;
  font-size: 0.85rem; padding: 2px 6px; opacity: 0.6;
}
.doc-row-remove:hover { opacity: 1; color: var(--danger); }
.doc-add-row-btn {
  font-size: 0.72rem; color: var(--amber); background: none; border: none;
  cursor: pointer; padding: 4px 0; font-family: inherit;
}
.doc-add-row-btn:hover { text-decoration: underline; }

/* ─── Sources Card (Jira, uploads, KB refs) ─── */
.doc-sources-card {
  margin-top: 16px; padding: 14px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 6px;
}
.doc-sources-card h4 {
  font-size: 0.82rem; color: var(--cream); margin: 0 0 10px;
  display: flex; align-items: center; gap: 6px;
}
.doc-sources-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
@media (max-width: 700px) { .doc-sources-grid { grid-template-columns: 1fr; } }
.doc-source-section { margin-bottom: 12px; }
.doc-source-section:last-child { margin-bottom: 0; }
.doc-source-label {
  font-size: 0.72rem; color: var(--text-dim); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px;
}

/* Chip list (for Jira keys, KB refs, files) */
.doc-chip-list { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.doc-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; font-size: 0.75rem; border-radius: 3px;
  background: rgba(74,139,212,0.12); color: var(--cream);
}
.doc-chip-remove {
  background: none; border: none; color: var(--text-dim);
  cursor: pointer; font-size: 0.8rem; padding: 0 2px; line-height: 1;
}
.doc-chip-remove:hover { color: var(--danger); }

/* Typeahead / autocomplete */
.doc-typeahead-wrap { position: relative; }
.doc-typeahead-input {
  width: 100%; padding: 5px 8px; font-size: 0.8rem;
  background: var(--bg); color: var(--text); border: 1px solid var(--border);
  border-radius: 3px; font-family: inherit;
}
.doc-typeahead-input:focus { outline: none; border-color: var(--amber); }
.doc-typeahead-dropdown {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 0 0 4px 4px; max-height: 200px; overflow-y: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3); display: none;
}
.doc-typeahead-dropdown.open { display: block; }
.doc-typeahead-item {
  padding: 6px 10px; cursor: pointer; font-size: 0.8rem; color: var(--text);
  border-bottom: 1px solid rgba(255,255,255,0.03);
}
.doc-typeahead-item:hover { background: rgba(74,139,212,0.08); color: var(--cream); }
.doc-typeahead-item .ta-key { color: var(--amber); font-weight: 600; margin-right: 6px; }
.doc-typeahead-item .ta-summary { color: var(--text-dim); }
.doc-typeahead-item .ta-status { font-size: 0.68rem; color: var(--text-dim); float: right; }
.doc-typeahead-empty {
  padding: 8px 10px; font-size: 0.78rem; color: var(--text-dim); font-style: italic;
}

/* Multi-file upload area */
.doc-multi-upload {
  border: 1px dashed var(--border); border-radius: 4px; padding: 12px;
  text-align: center; cursor: pointer; transition: border-color 0.2s;
}
.doc-multi-upload:hover { border-color: var(--amber); }
.doc-multi-upload.dragover { border-color: var(--amber); background: rgba(74,139,212,0.04); }
.doc-multi-upload-label {
  font-size: 0.78rem; color: var(--text-dim);
}
.doc-file-list { margin-top: 6px; display: flex; flex-direction: column; gap: 3px; }
.doc-file-item {
  display: flex; align-items: center; gap: 6px; font-size: 0.78rem;
  padding: 4px 8px; background: rgba(255,255,255,0.03); border-radius: 3px;
}
.doc-file-item .doc-file-name { flex: 1; color: var(--cream); }
.doc-file-item .doc-file-status { font-size: 0.68rem; color: var(--text-dim); }
.doc-file-item .doc-file-status.done { color: var(--success); }
.doc-file-item .doc-file-status.error { color: var(--danger); }

/* ─── Custom Modal (replaces native prompt/confirm) ─── */
.doc-modal-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.6); z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.15s; pointer-events: none;
}
.doc-modal-overlay.open { opacity: 1; pointer-events: auto; }
.doc-modal {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; padding: 24px; min-width: 380px; max-width: 500px;
  width: 90%; max-height: 80vh; overflow-y: auto;
  box-shadow: 0 12px 48px rgba(0,0,0,0.5);
}
/* Expanded modal variant for diff review */
.doc-modal.diff-modal {
  max-width: 820px; width: 94%; padding: 0; display: flex; flex-direction: column;
  max-height: 88vh; overflow: hidden; border-radius: 12px;
}
.doc-modal h3 { font-size: 0.95rem; color: var(--cream); margin: 0 0 8px; }
.doc-modal p { font-size: 0.82rem; color: var(--text-dim); margin: 0 0 16px; }
.doc-modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 20px; }
.doc-modal-actions .btn { font-size: 0.8rem; }
.doc-modal .btn-danger { background: var(--danger); color: #fff; }
.doc-modal .btn-danger:hover { background: #c44; }

/* Publish to KB modal */
.doc-kb-category-list { display: flex; flex-direction: column; gap: 4px; margin: 12px 0; }
.doc-kb-category-option {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 4px; cursor: pointer; transition: all 0.15s;
}
.doc-kb-category-option:hover { border-color: var(--amber); background: rgba(74,139,212,0.04); }
.doc-kb-category-option.selected { border-color: var(--amber); background: rgba(74,139,212,0.08); }
.doc-kb-category-option input[type="radio"] { accent-color: var(--amber); }
.doc-kb-cat-info { flex: 1; }
.doc-kb-cat-name { font-size: 0.85rem; color: var(--cream); font-weight: 500; }
.doc-kb-cat-desc { font-size: 0.72rem; color: var(--text-dim); margin-top: 2px; }
.doc-kb-cat-count { font-size: 0.68rem; color: var(--text-dim); flex-shrink: 0; }

/* AI Edit Bar */
.doc-ai-edit-bar {
  padding: 10px 20px; border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface), var(--surface-2));
}
.doc-ai-edit-input-wrap { display: flex; gap: 10px; align-items: center; }
.doc-ai-edit-input {
  flex: 1; font-size: 0.82rem; padding: 8px 14px; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg);
  color: var(--text); transition: border-color 0.15s;
}
.doc-ai-edit-input:focus { border-color: var(--amber); outline: none; box-shadow: 0 0 0 3px rgba(74,139,212,0.12); }

/* ─── Diff Review (AI Edit Modal) ─── */
.diff-modal-header {
  padding: 20px 24px 16px; border-bottom: 1px solid var(--border);
  display: flex; align-items: flex-start; justify-content: space-between; flex-shrink: 0;
}
.diff-modal-header-left { flex: 1; min-width: 0; }
.diff-modal-header h3 {
  font-size: 1rem; font-weight: 700; color: var(--cream); margin: 0 0 6px;
  display: flex; align-items: center; gap: 8px;
}
.diff-modal-header h3 svg { flex-shrink: 0; }
.diff-modal-instruction {
  font-size: 0.78rem; color: var(--text-dim); margin: 0;
  padding: 6px 10px; background: var(--bg); border-radius: 6px;
  border-left: 3px solid var(--amber); display: inline-block;
}
.diff-modal-close {
  width: 28px; height: 28px; border: none; background: none; color: var(--text-dim);
  cursor: pointer; border-radius: 6px; display: grid; place-items: center;
  font-size: 1.1rem; transition: all 0.12s; flex-shrink: 0;
}
.diff-modal-close:hover { background: var(--surface-2); color: var(--text); }
.diff-stats-bar {
  display: flex; gap: 16px; padding: 10px 24px; border-bottom: 1px solid var(--border);
  font-size: 0.75rem; color: var(--text-dim); align-items: center; flex-shrink: 0;
  background: var(--surface-2);
}
.diff-stat { display: inline-flex; align-items: center; gap: 5px; }
.diff-stat-dot { width: 8px; height: 8px; border-radius: 50%; }
.diff-stat-dot.added { background: #51cf66; }
.diff-stat-dot.removed { background: #ff6b6b; }
.diff-stat-dot.modified { background: var(--amber); }
.diff-select-actions { margin-left: auto; display: flex; gap: 8px; }
.diff-select-actions button {
  padding: 3px 10px; border-radius: 4px; border: 1px solid var(--border);
  background: none; color: var(--text-dim); cursor: pointer; font-size: 0.72rem;
  font-family: inherit; transition: all 0.12s;
}
.diff-select-actions button:hover { border-color: var(--text-dim); color: var(--text); }
.diff-container {
  flex: 1; overflow-y: auto; font-family: -apple-system, sans-serif; font-size: 0.82rem;
  min-height: 0;
}
/* Change group — pairs removed+added blocks together */
.diff-change-group {
  border-bottom: 1px solid var(--border); transition: background 0.12s;
}
.diff-change-group:last-child { border-bottom: none; }
.diff-change-group:hover { background: rgba(255,255,255,0.015); }
.diff-change-header {
  display: flex; align-items: center; gap: 10px; padding: 8px 16px;
  cursor: pointer; user-select: none;
}
.diff-change-check {
  width: 18px; height: 18px; border-radius: 4px; border: 2px solid var(--border);
  background: none; cursor: pointer; display: grid; place-items: center;
  transition: all 0.12s; flex-shrink: 0; accent-color: var(--amber);
}
.diff-change-check:checked { border-color: var(--amber); background: var(--amber); }
.diff-change-label {
  font-size: 0.75rem; font-weight: 600; color: var(--text-soft);
  flex: 1; min-width: 0;
}
.diff-change-tag {
  padding: 2px 8px; border-radius: 10px; font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.03em; text-transform: uppercase; flex-shrink: 0;
}
.diff-change-tag.tag-added { background: rgba(40,167,69,0.15); color: #51cf66; }
.diff-change-tag.tag-removed { background: rgba(220,53,69,0.15); color: #ff6b6b; }
.diff-change-tag.tag-modified { background: rgba(74,139,212,0.12); color: var(--amber); }
.diff-change-body { padding: 0 16px 12px 44px; }
.diff-line {
  padding: 5px 12px; border-radius: 4px; margin: 2px 0;
  white-space: pre-wrap; word-break: break-word; line-height: 1.55;
  font-size: 0.78rem;
}
.diff-line.diff-equal { color: var(--text-dim); padding: 4px 12px; margin: 0; border-radius: 0; }
.diff-line.diff-removed {
  background: rgba(220, 53, 69, 0.1); color: #ff8a8a;
  text-decoration: line-through; text-decoration-color: rgba(255,107,107,0.4);
}
.diff-line.diff-added {
  background: rgba(40, 167, 69, 0.1); color: #73d88b;
}
/* Unchanged context blocks (collapsed) */
.diff-context-block {
  padding: 6px 16px 6px 44px; color: var(--text-faint); font-size: 0.75rem;
  border-bottom: 1px solid var(--border); font-style: italic;
}
.diff-modal-footer {
  padding: 16px 24px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
  background: var(--surface);
}
.diff-modal-footer-info { font-size: 0.75rem; color: var(--text-dim); }
.diff-modal-footer-actions { display: flex; gap: 8px; }
/* Legacy compat */
.diff-legend { display: flex; gap: 16px; margin: 8px 0; font-size: 0.75rem; color: var(--text-dim); }
.diff-legend-item { display: flex; align-items: center; gap: 4px; }
.diff-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.diff-dot-added { background: rgba(40, 167, 69, 0.5); }
.diff-dot-removed { background: rgba(220, 53, 69, 0.5); }

/* Version History */
.doc-version-list { display: flex; flex-direction: column; gap: 4px; margin: 12px 0; max-height: 400px; overflow-y: auto; }
.doc-version-item { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px; }
.doc-version-item:hover { border-color: var(--accent); }
.doc-version-info { flex: 1; min-width: 0; }
.doc-version-date { font-size: 0.82rem; color: var(--cream); font-weight: 500; }
.doc-version-desc { font-size: 0.75rem; color: var(--text-dim); margin-top: 2px; }
.doc-version-author { font-size: 0.7rem; color: var(--text-dim); margin-top: 1px; }
.doc-version-actions { display: flex; gap: 4px; flex-shrink: 0; }

/* User management */
.user-list { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.user-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.user-card-info { flex: 1; }
.user-card-name { font-size: 0.88rem; color: var(--cream); font-weight: 500; }
.user-card-meta { font-size: 0.72rem; color: var(--text-dim); }
.user-card-actions { display: flex; gap: 6px; align-items: center; }
.user-role-select {
  padding: 3px 8px; font-size: 0.75rem;
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border); border-radius: 3px; font-family: inherit;
}

/* Hub chat widget (right column) */
.hub-chat {
  display: flex; flex-direction: column; flex: 1;
  background: var(--surface); overflow: hidden;
}
.hub-chat-header {
  padding: 12px 18px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px; flex-shrink: 0;
}
.hub-chat-header h3 { font-size: 0.88rem; color: var(--cream); }
.hub-chat-messages {
  flex: 1; overflow-y: auto;
  padding: 16px; display: flex; flex-direction: column; gap: 8px;
  overflow-x: hidden;
}
.hub-chat-messages .msg-ai { overflow-wrap: break-word; word-break: break-word; }
.hub-chat-input {
  display: flex; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border);
}
.hub-chat-input input {
  flex: 1; padding: 8px 12px;
  background: var(--bg); color: var(--text); border: 1px solid var(--border); border-radius: 8px;
  font-family: inherit; font-size: 0.85rem;
}
.hub-chat-input input:focus { outline: none; border-color: var(--amber); }

/* ═══════════════════════════════════════
   Presentation Editor
   ═══════════════════════════════════════ */

.pres-editor { display: flex; height: calc(100vh - 47px); margin-left: 240px; }

/* Sidebar */
.pres-sidebar {
  width: 220px; display: flex; flex-direction: column;
  background: var(--surface); border-right: 1px solid var(--border);
}
.pres-sidebar-header {
  display: flex; gap: 6px; padding: 10px;
  border-bottom: 1px solid var(--border);
}
.pres-sidebar-footer { padding: 10px; border-top: 1px solid var(--border); }
.pres-slide-list { flex: 1; overflow-y: auto; padding: 6px; display: flex; flex-direction: column; gap: 4px; }

.pres-slide-thumb {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 6px; cursor: pointer;
  transition: background 0.15s; border: 1px solid transparent;
}
.pres-slide-thumb:hover { background: rgba(74,139,212,0.06); }
.pres-slide-thumb.active { background: rgba(74,139,212,0.12); border-color: var(--amber); }
.pres-slide-thumb.dragging { opacity: 0.4; }
.pres-slide-thumb.drag-over { border-color: var(--amber); }
.pres-thumb-num { font-size: 0.72rem; font-weight: 700; color: var(--amber); min-width: 18px; }
.pres-thumb-info { flex: 1; min-width: 0; }
.pres-thumb-title { display: block; font-size: 0.78rem; color: var(--cream); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pres-thumb-layout { font-size: 0.65rem; color: var(--text-dim); text-transform: uppercase; }

/* Edit area */
.pres-edit-area { flex: 1; display: flex; flex-direction: column; border-right: 1px solid var(--border); }
.pres-edit-toolbar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px; border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.pres-edit-actions { margin-left: auto; display: flex; gap: 6px; }
.pres-edit-form { flex: 1; overflow-y: auto; padding: 20px; }

.pres-ai-section {
  margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border);
}

/* Preview */
.pres-preview { width: 420px; display: flex; flex-direction: column; flex-shrink: 0; }
.pres-preview-header {
  padding: 8px 16px; border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.pres-preview-stage {
  flex: 1; display: flex; align-items: center; justify-content: center;
  padding: 20px; overflow: hidden;
}

.pres-preview-slide {
  width: 100%; aspect-ratio: 16/9; border-radius: 6px; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}

/* Dark theme preview */
.pres-dark .pres-preview-slide {
  background: linear-gradient(165deg, #1e3160 0%, #0d1a30 45%, #080e1c 100%);
  color: #fff; padding: 24px;
  border-top: 3px solid #ab1d37;
}
.pres-dark h1 { font-size: 1.3rem; font-weight: 700; margin-bottom: 8px; }
.pres-dark h2 { font-size: 1rem; font-weight: 600; margin-bottom: 8px; }
.pres-dark .prev-subtitle { color: rgba(255,255,255,0.6); font-size: 0.82rem; }
.pres-dark .prev-body { font-size: 0.75rem; color: rgba(255,255,255,0.8); line-height: 1.5; }

/* Light theme preview */
.pres-light .pres-preview-slide {
  background: linear-gradient(165deg, #f0f4f8 0%, #ffffff 45%, #f8f9fb 100%);
  color: #333; padding: 24px;
  border: 1px solid #d0d8e4;
  border-top: 3px solid #1e3160;
}
.pres-light h1 { font-size: 1.3rem; color: #1e3160; font-weight: 700; margin-bottom: 8px; }
.pres-light h2 { font-size: 1rem; color: #1e3160; font-weight: 600; margin-bottom: 8px; }
.pres-light .prev-subtitle { color: #5a6a7e; font-size: 0.82rem; }
.pres-light .prev-body { font-size: 0.75rem; color: #444; line-height: 1.5; }
.pres-light .prev-slide ul { color: #444; }
.pres-light .prev-placeholder { background: rgba(30,49,96,0.06); border-color: rgba(30,49,96,0.2); color: #6b7d9a; }

/* Slide layouts */
.prev-slide { height: 100%; display: flex; flex-direction: column; }
.prev-title { justify-content: center; align-items: center; text-align: center; }
.prev-closing { justify-content: center; align-items: center; text-align: center; }
.prev-content-image { flex-direction: row; gap: 16px; }
.prev-text-col { flex: 1; overflow: hidden; }
.prev-image-col { width: 40%; display: flex; align-items: center; }
.prev-image-col img { width: 100%; height: auto; border-radius: 4px; }
.prev-placeholder {
  width: 100%; height: 100%; background: rgba(74,139,212,0.1);
  border: 1px dashed rgba(74,139,212,0.3); border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-dim); font-size: 0.75rem;
}
.prev-slide ul { padding-left: 16px; margin: 4px 0; }
.prev-slide li { margin-bottom: 2px; }
.prev-feature-grid .prev-grid-body { flex: 1; overflow: hidden; }

/* Status badge in editor toolbar */
.pres-status-badge {
  display: inline-block; padding: 2px 10px; border-radius: 10px;
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px;
}
.pres-status-badge.badge-draft { background: rgba(74,139,212,0.15); color: #4a8bd4; }
.pres-status-badge.badge-published { background: rgba(68,170,153,0.15); color: #4a9; }
.pres-status-badge.badge-archived { background: rgba(107,125,154,0.15); color: #6b7d9a; }

/* Template notice banner */
.pres-template-notice {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 10px 20px; background: rgba(74,139,212,0.1);
  border-bottom: 1px solid rgba(74,139,212,0.2);
  font-size: 0.8rem; color: #4a8bd4;
}

/* New Presentation Modal */
.pres-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
}
.pres-modal {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; width: 420px; max-width: 90vw;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.pres-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.pres-modal-header h3 { font-size: 1rem; color: var(--cream); }
.pres-modal-close {
  background: none; border: none; color: var(--text-dim); font-size: 1.4rem;
  cursor: pointer; padding: 0 4px; line-height: 1;
}
.pres-modal-close:hover { color: var(--cream); }
.pres-modal-body { padding: 20px; }
.pres-modal-footer {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 12px 20px; border-top: 1px solid var(--border);
}

/* ═══════════════════════════════════════
   Knowledge Base
   ═══════════════════════════════════════ */

.kb-page { display: flex; height: calc(100vh - 47px); margin-left: 240px; }

/* Sidebar */
.kb-sidebar {
  width: 220px; display: flex; flex-direction: column;
  background: var(--surface); border-right: 1px solid var(--border);
  position: sticky; top: 47px; height: calc(100vh - 47px); overflow-y: auto;
}
.kb-search { padding: 12px; border-bottom: 1px solid var(--border); }
.kb-search .int-input { width: 100%; padding: 7px 10px; font-size: 0.82rem; }
.kb-categories { flex: 1; overflow-y: auto; padding: 8px; display: flex; flex-direction: column; gap: 1px; }
.kb-cat-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 12px; border-radius: 4px;
  font-size: 0.82rem; color: var(--text); text-decoration: none;
}
.kb-cat-item:hover { background: rgba(74,139,212,0.06); text-decoration: none; }
.kb-cat-item.active { background: rgba(74,139,212,0.12); color: var(--amber); font-weight: 600; }
.kb-cat-count { font-size: 0.68rem; color: var(--text-dim); background: var(--bg); padding: 1px 6px; border-radius: 8px; }
.kb-sidebar-footer { padding: 10px; border-top: 1px solid var(--border); }

/* Main */
.kb-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-height: 0; }
.kb-panel {
  flex: 1; flex-direction: column; overflow: hidden; min-height: 0;
  display: none;
}
.kb-panel.kb-active { display: flex; }

.kb-list-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.kb-list-header h2 { font-size: 1rem; color: var(--cream); }
.kb-list-actions { display: flex; gap: 6px; }

.kb-doc-list { flex: 1; overflow-y: auto; padding: 8px 16px; }

.kb-doc-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background 0.15s;
}
.kb-doc-card:hover { background: rgba(74,139,212,0.04); }
.kb-doc-card-main { flex: 1; min-width: 0; }
.kb-doc-card h3 { font-size: 0.88rem; color: var(--cream); margin-bottom: 4px; }
.kb-doc-card-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.kb-doc-card-right { flex-shrink: 0; text-align: right; }
.kb-doc-author { display: block; font-size: 0.72rem; color: var(--text-dim); }
.kb-doc-date { font-size: 0.68rem; color: var(--text-dim); }

.kb-sync-badge {
  font-size: 0.68rem; color: var(--amber);
  background: rgba(74,139,212,0.1); padding: 1px 6px; border-radius: 3px;
}

/* View mode */
.kb-view-header {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 24px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.kb-view-meta { flex: 1; display: flex; gap: 8px; align-items: center; }
.kb-meta-text { font-size: 0.75rem; color: var(--text-dim); }
.kb-view-actions { display: flex; gap: 6px; }

.kb-view-body {
  flex: 1; overflow-y: auto; padding: 32px 48px;
  background: #fff; color: #333;
  font-family: -apple-system, sans-serif; line-height: 1.7;
  min-height: 0;
}
.kb-view-body h1 { color: #1e3160; font-size: 24px; border-bottom: 2px solid #1e3160; padding-bottom: 8px; margin-bottom: 20px; }
.kb-view-content h2 { color: #1e3160; font-size: 18px; margin-top: 24px; border-bottom: 1px solid #ddd; padding-bottom: 4px; }
.kb-view-content h3 { font-size: 15px; margin-top: 18px; }
.kb-view-content p { margin: 0 0 12px; font-size: 15px; }
.kb-view-content ul, .kb-view-content ol { margin: 4px 0 12px; padding-left: 24px; }
.kb-view-content li { margin-bottom: 4px; }
.kb-view-content strong { color: #1e3160; font-weight: 700; }
.kb-view-content a { color: #4a8bd4; }
.kb-view-content table { width: 100%; border-collapse: collapse; margin: 12px 0; }
.kb-view-content th, .kb-view-content td { padding: 8px 12px; border: 1px solid #ddd; font-size: 14px; }
.kb-view-content th { background: #f5f5f5; font-weight: 600; }

/* Edit mode */
.kb-edit-header {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.kb-edit-actions { display: flex; gap: 4px; margin-left: auto; }
.kb-edit-toolbar {
  padding: 4px 8px; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
}
.kb-edit-body {
  flex: 1; overflow-y: auto; padding: 32px 48px;
  background: #fff; color: #333;
  font-family: -apple-system, sans-serif; font-size: 15px; line-height: 1.7;
  outline: none;
}
.kb-edit-body h1 { color: #1e3160; font-size: 22px; }
.kb-edit-body h2 { color: #1e3160; font-size: 17px; margin-top: 20px; border-bottom: 1px solid #ddd; padding-bottom: 3px; }
.kb-edit-body p { margin: 0 0 10px; }
.kb-edit-body ul, .kb-edit-body ol { margin: 4px 0 10px; padding-left: 22px; }
.kb-edit-body strong { color: #1e3160; font-weight: 700; }

/* Confluence sync */
.kb-confluence-list { padding: 0 16px; overflow-y: auto; flex: 1; min-height: 0; }
.kb-confluence-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background 0.1s;
}
.kb-confluence-item:hover { background: rgba(74,139,212,0.04); }
.kb-confluence-item input[type="checkbox"] { flex-shrink: 0; cursor: pointer; }
.kb-confluence-info { flex: 1; min-width: 0; }
.kb-confluence-info h4 { font-size: 0.82rem; color: var(--cream); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kb-confluence-actions { display: flex; gap: 6px; flex-shrink: 0; }

.kb-confluence-panel {
  display: flex; flex-direction: column; flex: 1; overflow: hidden;
}
.kb-confluence-panel.kb-hidden { display: none !important; }

/* ═══════════════════════════════════════
   Competitive Intelligence
   ═══════════════════════════════════════ */

.intel-page { display: flex; height: calc(100vh - 47px); margin-left: 240px; }

.intel-sidebar {
  width: 220px; display: flex; flex-direction: column;
  background: var(--surface); border-right: 1px solid var(--border);
}
.intel-sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 14px; border-bottom: 1px solid var(--border);
}
.intel-sidebar-header h3 { font-size: 0.88rem; color: var(--cream); }
.intel-comp-list { flex: 1; overflow-y: auto; padding: 4px 6px; display: flex; flex-direction: column; gap: 2px; }

.intel-sidebar-disabled .intel-comp-list { opacity: 0.35; pointer-events: none; }
.intel-sidebar-disabled .intel-sidebar-header::after {
  content: 'Not used on this tab';
  font-size: 0.65rem; color: var(--text-dim); font-style: italic;
  position: absolute; bottom: 4px; left: 14px;
}
.intel-sidebar-disabled .intel-sidebar-header {
  position: relative; padding-bottom: 20px;
}

.intel-comp-item {
  padding: 10px 12px; border-radius: 6px; cursor: pointer;
  transition: background 0.15s; border: 1px solid transparent;
}
.intel-comp-item:hover { background: rgba(74,139,212,0.05); }
.intel-comp-item.active { background: rgba(74,139,212,0.12); border-color: var(--amber); }
.intel-comp-name { font-size: 0.85rem; color: var(--cream); font-weight: 500; }
.intel-comp-meta { font-size: 0.68rem; color: var(--text-dim); margin-top: 1px; }

.intel-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }

.intel-tabs {
  display: flex; border-bottom: 1px solid var(--border);
  background: var(--surface); flex-shrink: 0;
}
.intel-tab {
  padding: 10px 16px; background: none; border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-dim); font-size: 0.78rem; font-weight: 600;
  font-family: inherit; cursor: pointer; transition: all 0.2s;
}
.intel-tab:hover { color: var(--text); }
.intel-tab.active { color: var(--amber); border-bottom-color: var(--amber); }

.intel-panel { display: none; flex-direction: column; flex: 1; overflow: hidden; }
.intel-panel.active { display: flex; }

.intel-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px; border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.intel-panel-header h2 { font-size: 1rem; color: var(--cream); }

.intel-panel-body { flex: 1; overflow-y: auto; padding: 20px; }

.intel-empty { text-align: center; color: var(--text-dim); padding: 40px 20px; font-size: 0.88rem; }

.intel-meta-line { font-size: 0.72rem; color: var(--text-dim); margin-bottom: 12px; }

/* Overview */
.intel-summary {
  padding: 14px 18px; background: rgba(74,139,212,0.06);
  border-left: 3px solid var(--amber); border-radius: 0 6px 6px 0;
  margin-bottom: 16px; font-size: 0.88rem; line-height: 1.6; color: var(--text);
}

.intel-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; margin-bottom: 16px; }
.intel-card {
  padding: 14px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.intel-card h4 { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-dim); margin-bottom: 6px; }
.intel-card p { font-size: 0.82rem; color: var(--text); line-height: 1.5; margin: 0; }
.intel-card ul { padding-left: 16px; margin: 4px 0 0; }
.intel-card li { font-size: 0.8rem; color: var(--text); margin-bottom: 2px; }

.intel-section { margin-bottom: 14px; }
.intel-section h3 { font-size: 0.88rem; color: var(--cream); margin-bottom: 6px; }
.intel-section ul { padding-left: 18px; }
.intel-section li { font-size: 0.82rem; color: var(--text); margin-bottom: 2px; }
.intel-section p { font-size: 0.82rem; color: var(--text); line-height: 1.5; }

.intel-actions-row { margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--border); }

/* News Feed */
.intel-news-item {
  display: flex; gap: 12px; padding: 12px 0;
  border-bottom: 1px solid var(--border);
}
.intel-news-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.intel-news-content { flex: 1; min-width: 0; }
.intel-news-top { display: flex; gap: 8px; align-items: center; margin-bottom: 3px; flex-wrap: wrap; }
.intel-news-comp { font-size: 0.72rem; font-weight: 600; color: var(--amber); }
.intel-news-type { font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.04em; font-weight: 600; }
.intel-news-date { font-size: 0.68rem; color: var(--text-dim); }
.intel-news-title { font-size: 0.85rem; color: var(--cream); font-weight: 500; margin-bottom: 2px; }
.intel-news-summary { font-size: 0.78rem; color: var(--text); line-height: 1.4; }
.intel-news-link { font-size: 0.72rem; color: var(--amber); margin-top: 2px; display: inline-block; }

/* Pricing */
.intel-pricing-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; margin-bottom: 12px; }
.intel-pricing-card {
  padding: 16px; background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  text-align: center;
}
.intel-pricing-tier { font-size: 0.88rem; font-weight: 600; color: var(--cream); margin-bottom: 4px; }
.intel-pricing-price { font-size: 1.2rem; font-weight: 700; color: var(--amber); margin-bottom: 2px; }
.intel-pricing-billing { font-size: 0.68rem; color: var(--text-dim); margin-bottom: 8px; }
.intel-pricing-card ul { text-align: left; padding-left: 16px; margin: 0; }
.intel-pricing-card li { font-size: 0.75rem; color: var(--text); margin-bottom: 2px; }

.intel-feature-cat { margin-bottom: 12px; }
.intel-feature-cat h4 { font-size: 0.82rem; color: var(--cream); margin-bottom: 4px; }
.intel-feature-note { font-size: 0.72rem; color: var(--text-dim); }

/* Research */
.intel-research-form { max-width: 600px; }
.intel-divider { height: 1px; background: var(--border); margin: 16px 0; }
.intel-research-output {
  font-size: 0.88rem; color: var(--text); line-height: 1.7;
}
.intel-research-output strong { color: var(--cream); }
.intel-research-output code { background: rgba(74,139,212,0.1); padding: 1px 4px; border-radius: 2px; }

/* Auto-update label */
.intel-auto-label {
  font-size: 0.68rem; color: var(--text-dim);
  background: var(--bg); padding: 3px 8px; border-radius: 10px;
  border: 1px solid var(--border);
}

/* News toolbar */
.intel-news-toolbar {
  display: flex; gap: 6px; align-items: center;
  padding: 8px 20px; border-bottom: 1px solid var(--border);
  flex-shrink: 0; flex-wrap: wrap;
}

/* Company profile card */
.intel-profile-card {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-dark) 100%);
  border: 1px solid var(--border); border-radius: 10px;
  padding: 20px 24px; margin-bottom: 16px;
}
.intel-profile-main h2 { font-size: 1.3rem; color: #fff; margin-bottom: 2px; }
.intel-profile-url { font-size: 0.78rem; color: var(--amber); }
.intel-profile-stats {
  display: flex; gap: 24px; margin-top: 14px; flex-wrap: wrap;
}
.intel-stat { display: flex; flex-direction: column; }
.intel-stat strong { font-size: 1rem; color: #fff; }
.intel-stat span { font-size: 0.65rem; color: rgba(255,255,255,0.5); text-transform: uppercase; letter-spacing: 0.04em; }

/* Strengths/Weaknesses side-by-side */
.intel-sw-row { display: flex; gap: 12px; margin-bottom: 14px; }
.intel-sw-col {
  flex: 1; padding: 14px; border-radius: 6px;
}
.intel-sw-col h3 { font-size: 0.82rem; margin-bottom: 6px; }
.intel-sw-col ul { padding-left: 16px; margin: 0; }
.intel-sw-col li { font-size: 0.8rem; margin-bottom: 3px; }
.intel-strengths { background: rgba(68,170,153,0.06); border: 1px solid rgba(68,170,153,0.15); }
.intel-strengths h3 { color: var(--success); }
.intel-strengths li { color: var(--text); }
.intel-weaknesses { background: rgba(204,68,68,0.06); border: 1px solid rgba(204,68,68,0.15); }
.intel-weaknesses h3 { color: var(--danger); }
.intel-weaknesses li { color: var(--text); }

/* Data confidence notice */
.intel-notice {
  padding: 10px 14px; margin-bottom: 12px;
  background: rgba(200,160,60,0.08); border: 1px solid rgba(200,160,60,0.2);
  border-radius: 6px; font-size: 0.82rem; color: #db6;
}
.intel-notice p { color: var(--text); margin: 4px 0 0; font-size: 0.78rem; }

/* Populating state */
.intel-populating { padding: 40px; }

/* Edit button on competitor items */
.intel-comp-item { display: flex; align-items: center; gap: 4px; position: relative; }
.intel-comp-row { flex: 1; display: flex; align-items: center; gap: 8px; cursor: pointer; min-width: 0; }
.intel-comp-info { flex: 1; min-width: 0; }
.intel-comp-edit {
  opacity: 0; background: none; border: none; color: var(--text-dim);
  font-size: 0.82rem; cursor: pointer; padding: 4px 6px; transition: opacity 0.15s;
  flex-shrink: 0;
}
.intel-comp-item:hover .intel-comp-edit { opacity: 1; }
.intel-comp-edit:hover { color: var(--amber); }

/* Map legend */
.intel-map-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; }
.intel-legend-item { display: flex; align-items: center; gap: 5px; font-size: 0.78rem; color: var(--text); }
.intel-legend-dot { width: 10px; height: 10px; border-radius: 50%; }

/* State grid */
.intel-state-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 8px; }
.intel-state-card {
  padding: 12px; background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.intel-state-card h4 { font-size: 0.85rem; color: var(--cream); margin-bottom: 6px; }
.intel-state-comps { display: flex; flex-wrap: wrap; gap: 4px; }
.intel-state-comp {
  font-size: 0.7rem; padding: 2px 8px; border-radius: 10px;
  border: 1px solid; background: rgba(255,255,255,0.03);
  color: var(--text);
}
.intel-state-details { display: flex; flex-direction: column; gap: 4px; }
.intel-state-row { display: flex; justify-content: space-between; align-items: center; }
.intel-state-comp-name { font-size: 0.78rem; color: var(--text); }
.intel-state-strength { font-size: 0.68rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.intel-state-note { font-size: 0.68rem; color: var(--text-dim); margin-left: 8px; }

/* ═══ Market Map Edit Mode ═══ */
.intel-state-card.editable { cursor: pointer; transition: border-color 0.2s; }
.intel-state-card.editable:hover { border-color: var(--amber); }
.intel-map-toolbar { display: flex; gap: 8px; align-items: center; margin-bottom: 12px; }
.intel-state-comp.manual {
  border-style: dashed !important;
  position: relative;
}
.intel-state-comp.manual::before {
  content: '✎';
  font-size: 0.6rem;
  margin-right: 3px;
  opacity: 0.7;
}
.intel-state-row .manual-badge {
  font-size: 0.6rem; color: var(--amber); opacity: 0.7;
  margin-left: 4px; font-style: italic;
}
.intel-state-row .remove-manual {
  font-size: 0.7rem; color: var(--danger); cursor: pointer;
  margin-left: 6px; opacity: 0.6; background: none; border: none; padding: 0;
}
.intel-state-row .remove-manual:hover { opacity: 1; }

/* Partnerships */
.intel-partnerships-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 8px; }
.intel-partnership-card { padding: 10px 14px; background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 6px; }
.intel-partnership-type { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; padding: 2px 8px; border-radius: 10px; color: var(--bg); }

/* ═══ Dashboard Custom Widgets ═══ */
.hub-widgets {
  padding: 0;
  margin-top: 36px;
  border-top: 1px solid var(--border);
  padding-top: 28px;
}
.hub-widgets-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 18px;
}
.hub-widgets-header h3 { font-size: 0.88rem; color: var(--text-dim); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; }
.hub-widget-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
@media (max-width: 1200px) { .hub-widget-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 800px) { .hub-widget-grid { grid-template-columns: 1fr; } }
.hub-widget {
  background: var(--surface); border: 1px solid var(--border); border-radius: 10px;
  overflow: hidden; transition: box-shadow 0.25s, border-color 0.25s;
}
.hub-widget:hover {
  border-color: rgba(74,139,212,0.2);
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}
.hub-widget-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px 12px; border-bottom: none;
}
.hub-widget-title { font-size: 0.78rem; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.04em; }
.hub-widget-body {
  padding: 0 18px 18px; max-height: 300px; overflow-y: auto;
}
.hub-widget-empty { color: var(--text-dim); font-size: 0.82rem; text-align: center; padding: 24px 0; }
.hub-widget-empty a { color: var(--amber); }
.hub-widget-item {
  padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 0.82rem;
}
.hub-widget-item:first-child { padding-top: 0; }
.hub-widget-item:last-child { border-bottom: none; padding-bottom: 0; }
.hub-widget-item .widget-item-title { color: var(--cream); font-weight: 500; font-size: 0.83rem; line-height: 1.4; }
.hub-widget-item .widget-item-meta { color: var(--text-dim); font-size: 0.72rem; margin-top: 3px; }
.hub-widget-item .widget-item-stat { color: var(--amber); font-weight: 600; }
.hub-chart-container { position: relative; width: 100%; height: 160px; }
.hub-chart-container canvas { width: 100% !important; height: 100% !important; }
.hub-chart-summary { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 14px; }
.hub-chart-big { font-size: 2rem; font-weight: 700; color: var(--cream); line-height: 1; letter-spacing: -0.02em; }
.hub-chart-label { font-size: 0.7rem; color: var(--text-dim); margin-top: 3px; text-transform: uppercase; letter-spacing: 0.03em; }
.hub-chart-change { font-size: 0.72rem; font-weight: 600; padding: 3px 10px; border-radius: 12px; }
.hub-chart-change.up { color: #4a9; background: rgba(68,170,153,0.12); }
.hub-chart-change.down { color: #f66; background: rgba(255,102,102,0.12); }
.hub-chart-change.neutral { color: var(--text-dim); background: rgba(255,255,255,0.05); }
.widget-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; flex-shrink: 0; margin-right: 5px; }
.hub-widget-period { font-size: 0.65rem; color: var(--text-dim); background: rgba(255,255,255,0.04); padding: 2px 8px; border-radius: 8px; font-weight: 500; }

/* ─── Site-wide Chat Bubble ─── */
#chat-bubble-widget { position: fixed; bottom: 20px; right: 20px; z-index: 900; }

.chat-bubble-btn {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--amber); color: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  transition: transform 0.2s, box-shadow 0.2s;
}
.chat-bubble-btn:hover { transform: scale(1.08); box-shadow: 0 6px 24px rgba(0,0,0,0.4); }

.chat-bubble-panel {
  position: absolute; bottom: 64px; right: 0;
  width: 380px; height: 500px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  display: flex; flex-direction: column; overflow: hidden;
  opacity: 0; transform: translateY(12px) scale(0.95);
  pointer-events: none; transition: opacity 0.2s, transform 0.2s;
}
.chat-bubble-panel.open {
  opacity: 1; transform: translateY(0) scale(1); pointer-events: auto;
}

.chat-bubble-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.chat-bubble-title { font-size: 0.88rem; font-weight: 600; color: var(--cream); }
.chat-bubble-header-actions { display: flex; align-items: center; gap: 8px; }
.chat-bubble-expand {
  color: var(--text-dim); display: flex; align-items: center;
  text-decoration: none; padding: 2px;
}
.chat-bubble-expand:hover { color: var(--cream); }
.chat-bubble-close-btn {
  background: none; border: none; color: var(--text-dim);
  font-size: 1.2rem; cursor: pointer; padding: 0 2px; line-height: 1;
}
.chat-bubble-close-btn:hover { color: var(--cream); }

.chat-bubble-messages {
  flex: 1; overflow-y: auto; padding: 12px 14px;
  display: flex; flex-direction: column; gap: 8px;
}
.chat-bubble-messages .msg {
  border-radius: 8px; font-size: 0.82rem; line-height: 1.5;
  max-width: 90%; word-break: break-word;
}
.chat-bubble-messages .msg-user {
  align-self: flex-end; background: rgba(74,139,212,0.15);
  color: var(--cream); padding: 8px 12px;
}
.chat-bubble-messages .msg-ai {
  align-self: flex-start; background: var(--bg);
  color: var(--text); padding: 10px 14px;
}
.chat-bubble-messages .msg-ai a { color: var(--amber); }
.chat-bubble-messages .msg-ai strong { color: var(--cream); }
.chat-bubble-messages .msg-ai code {
  background: rgba(255,255,255,0.06); padding: 1px 4px;
  border-radius: 3px; font-size: 0.78rem;
}

.chat-bubble-input-row {
  display: flex; gap: 6px; padding: 10px 14px;
  border-top: 1px solid var(--border); flex-shrink: 0;
}
.chat-bubble-input {
  flex: 1; padding: 8px 12px; font-size: 0.82rem;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border); border-radius: 6px;
  font-family: inherit; outline: none;
}
.chat-bubble-input:focus { border-color: var(--amber); }
.chat-bubble-send {
  background: var(--amber); color: #fff; border: none;
  border-radius: 6px; padding: 6px 10px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.chat-bubble-send:hover { background: #d4a84a; }

@media (max-width: 480px) {
  .chat-bubble-panel { width: calc(100vw - 24px); right: -8px; height: 60vh; }
}

/* ─── Shared Dashboard Sidebar (hub + tasks + announcements) ─── */
.hub-columns { display: flex; min-height: calc(100vh - 47px); padding: 0; gap: 0; box-sizing: border-box; margin-left: 240px; }
.hub-col-left-scroll { flex: 1; overflow-y: auto; padding-right: 4px; }
.hub-col-left-scroll::-webkit-scrollbar { width: 3px; }
.hub-col-left-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 2px; }
.hub-welcome-compact h2 { color: var(--cream); font-size: 0.95rem; font-weight: 600; margin: 0 0 2px; }
.hub-welcome-compact p { color: var(--text-dim); font-size: 0.7rem; margin: 0 0 14px; text-transform: uppercase; letter-spacing: 0.8px; }
.hub-content-area { flex: 1; min-width: 0; display: flex; flex-direction: column; }
/* ─── Mobile hamburger button (hidden on desktop) ─── */
.mobile-menu-btn {
  display: none; background: none; border: none; color: rgba(255,255,255,0.8);
  cursor: pointer; padding: 4px; border-radius: 4px; flex-shrink: 0;
}
.mobile-menu-btn:hover { color: #fff; background: rgba(255,255,255,0.1); }

/* ─── Mobile nav overlay ─── */
.mobile-nav-overlay {
  display: none; position: fixed; inset: 0; z-index: 9000; background: rgba(0,0,0,0.5);
}
.mobile-nav-overlay.open { display: block; }
.mobile-nav-panel {
  position: absolute; top: 0; left: 0; bottom: 0; width: 280px;
  background: #0D1A30; color: #fff; display: flex; flex-direction: column;
  box-shadow: 4px 0 20px rgba(0,0,0,0.3);
  transform: translateX(-100%); transition: transform 0.25s ease;
}
.mobile-nav-overlay.open .mobile-nav-panel { transform: translateX(0); }
.mobile-nav-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mobile-nav-user { display: flex; align-items: center; gap: 10px; }
.mobile-nav-close {
  background: none; border: none; color: var(--text-dim); font-size: 1.5rem;
  cursor: pointer; padding: 4px 8px;
}
.mobile-nav-close:hover { color: var(--cream); }
.mobile-nav-links { flex: 1; overflow-y: auto; padding: 8px 0; }
.mobile-nav-item {
  display: block; padding: 12px 20px; color: rgba(255,255,255,0.75); text-decoration: none;
  font-size: 0.88rem; transition: background 0.15s; border-left: 3px solid transparent;
}
.mobile-nav-item:hover { background: rgba(255,255,255,0.04); color: #fff; }
.mobile-nav-item.active { color: #fff; background: rgba(171,29,55,0.12); border-left-color: #AB1D37; font-weight: 600; }
.mobile-nav-footer { border-top: 1px solid rgba(255,255,255,0.08); padding: 8px 0; }

/* ─── Mobile responsive ─── */
@media (max-width: 768px) {
  .mobile-menu-btn { display: flex; }
  .breadcrumbs { display: none; }
  .topbar-search-box { display: none; }
  .user-menu-name { display: none; }
  .caret { display: none; }
  .user-menu-btn { padding: 2px; background: none; border: none; }
  .dash-header { padding: 10px 12px; margin-left: 0; }

  /* Hide all desktop sidebars */
  .hub-columns > aside.sidebar,
  aside.sidebar,
  .sidebar,
  .kb-sidebar,
  .intel-sidebar,
  .sub-sidebar { display: none !important; }

  /* Remove sidebar offset on mobile */
  .hub-columns,
  .dash-layout,
  .hub-layout,
  .jira-page,
  .mc-page,
  .settings-page,
  .docs-page,
  .pres-editor,
  .kb-page,
  .intel-page,
  .chat-page,
  .gt-layout,
  .editor-subheader,
  .editor-layout,
  .auto-page,
  .task-page,
  .run-page,
  .review-page { margin-left: 0; }

  .editor-footer { left: 0; }

  /* Make main content full width */
  .hub-columns,
  .dash-layout,
  .kb-page,
  .intel-page { flex-direction: column; }

  .hub-content-area,
  .docs-main,
  .kb-main,
  .intel-main { width: 100%; min-width: 0; }

  /* Training pages */
  .gt-layout { flex-direction: column; }
  .gt-main { padding: 12px; }
  .training-page { padding: 16px; }

  /* Chat bubble adjustments */
  .chat-bubble-panel { width: calc(100vw - 16px) !important; right: -4px !important; }
}
/* =========================================================
   PAGE HERO — Unified page header pattern
   Used across all pages for consistent H1 + subtitle + actions
   ========================================================= */
.page-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--s-4, 16px);
  flex-wrap: wrap;
  margin-bottom: var(--s-5, 20px);
  padding: 0;
}
.page-hero-text h1 {
  font-size: var(--t-2xl, 28px);
  letter-spacing: -0.02em;
  margin: 0 0 4px;
  color: var(--text);
  font-weight: 600;
  line-height: 1.2;
}
.page-hero-text h1 .accent {
  background: var(--grad-warm);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.page-hero-text h1 .accent-blue {
  background: var(--grad-amber);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.page-hero-text h1 .accent-love {
  background: var(--grad-love, var(--grad-warm));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.page-hero-text p {
  margin: 0;
  color: var(--text-dim);
  font-size: var(--t-md, 14px);
}
.page-hero-actions {
  display: flex;
  gap: var(--s-2, 8px);
  align-items: center;
}
@media (max-width: 640px) {
  .page-hero { flex-direction: column; align-items: flex-start; }
  .page-hero-text h1 { font-size: var(--t-xl, 20px); }
}

/* =========================================================
   REDESIGN COMPONENTS — Phase 1
   Append this block to public/css/dashboard.css after the
   tokens.css block. All classes are NEW (prefixed where
   they could conflict) so existing styles are unaffected.

   Where this file uses existing site tokens (--bg, --surface,
   --text, --text-dim, --navy, --crimson, --amber, --border),
   it relies on what the live site already defines.

   Where it uses new tokens (--ok, --warn, --err, --info,
   --surface-2, --surface-3, --text-soft, --text-faint,
   --bg-soft, --border-strong, --shadow-*, --grad-*, --s-*,
   --r-*, --t-*, --ease, --ease-out), those come from
   tokens.css.
   ========================================================= */

/* ============== HERO STRIP ============== */
.dh-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--s-4);
  flex-wrap: wrap;
}
.dh-hero-greet h1 {
  font-size: var(--t-2xl);
  letter-spacing: -0.02em;
  margin: 0 0 6px;
  color: var(--text);
  font-weight: 600;
}
.dh-hero-greet h1 .accent {
  background: var(--grad-warm);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.dh-hero-greet p {
  margin: 0;
  color: var(--text-dim);
  font-size: var(--t-md);
}
.dh-hero-actions {
  display: flex;
  gap: var(--s-2);
}

/* ============== BUTTONS (v2) ============== */
.dh-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: 9px var(--s-4);
  border-radius: var(--r-sm);
  border: 1px solid var(--border-strong);
  background: var(--surface);
  color: var(--text);
  font-weight: 500;
  font-size: var(--t-md);
  cursor: pointer;
  transition: all 150ms var(--ease);
  text-decoration: none;
}
.dh-btn:hover {
  background: var(--surface-2);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.dh-btn-primary {
  background: var(--grad-amber);
  border-color: transparent;
  color: #fff;
  font-weight: 600;
}
.dh-btn-primary:hover {
  background: var(--grad-amber);
  color: #fff;
  box-shadow: var(--shadow-glow);
  filter: brightness(1.1);
}

/* ============== KPI ROW ============== */
.dh-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
}
.dh-kpi {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  position: relative;
  overflow: hidden;
  transition: all 200ms var(--ease);
  cursor: pointer;
}
.dh-kpi:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--border-strong);
}
.dh-kpi-head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.dh-kpi-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--r-md);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.dh-kpi-icon.amber { background: var(--info-bg); color: var(--info); }
.dh-kpi-icon.success { background: var(--ok-bg); color: var(--ok); }
.dh-kpi-icon.warning { background: var(--warn-bg); color: var(--warn); }
.dh-kpi-icon.crimson { background: var(--err-bg); color: var(--err); }
.dh-kpi-label {
  font-size: var(--t-sm);
  color: var(--text-dim);
  font-weight: 500;
}
.dh-kpi-value {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
  margin-bottom: var(--s-3);
}
.dh-kpi-value .num {
  font-size: var(--t-3xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text);
  font-feature-settings: 'tnum';
}
.dh-kpi-spark {
  position: relative;
  height: 36px;
  margin: 0 -8px -8px;
}
.dh-kpi-spark canvas {
  position: absolute;
  inset: 0;
}

/* ============== DELTA / CHIP ============== */
.dh-delta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--t-xs);
  font-weight: 600;
  padding: 3px var(--s-2);
  border-radius: var(--r-pill);
}
.dh-delta.up { background: var(--ok-bg); color: var(--ok); }
.dh-delta.down { background: var(--err-bg); color: var(--err); }
.dh-delta.flat { background: var(--surface-3); color: var(--text-dim); }

.dh-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  font-size: var(--t-xs);
  font-weight: 500;
  background: var(--surface-3);
  color: var(--text-soft);
}
.dh-chip.urgent { background: var(--err-bg); color: var(--err); }
.dh-chip.due-soon { background: var(--warn-bg); color: var(--warn); }
.dh-chip.due-ok { background: var(--info-bg); color: var(--info); }

.dh-badge-new {
  font-size: 9px;
  letter-spacing: 0.08em;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: var(--r-pill);
  background: var(--crimson);
  color: #fff;
  text-transform: uppercase;
}

/* ============== GRID HELPERS ============== */
.dh-grid { display: grid; gap: var(--s-4); }
.dh-grid > * { min-width: 0; }
.dh-grid.two-thirds { grid-template-columns: 2fr 1fr; }
.dh-grid.two-thirds-rev { grid-template-columns: 1fr 2fr; }
.dh-grid.thirds { grid-template-columns: repeat(3, 1fr); }
.dh-grid.halves { grid-template-columns: 1fr 1fr; }

/* ============== CARD SHELL (widget) ============== */
.dh-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: all 200ms var(--ease);
}
.dh-card:hover { box-shadow: var(--shadow-md); }
.dh-card-head {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.dh-card-head h3 {
  margin: 0;
  font-size: var(--t-md);
  font-weight: 600;
  color: var(--text);
}
.dh-head-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--r-sm);
  display: grid;
  place-items: center;
  background: var(--info-bg);
  color: var(--info);
  flex-shrink: 0;
}
.dh-head-icon.crimson { background: var(--err-bg); color: var(--err); }
.dh-head-icon.success { background: var(--ok-bg); color: var(--ok); }
.dh-head-icon.warning { background: var(--warn-bg); color: var(--warn); }
.dh-head-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.dh-card-link {
  font-size: var(--t-xs);
  color: var(--amber);
  font-weight: 500;
  text-decoration: none;
}
.dh-card-link:hover { text-decoration: underline; }
.dh-card-body { padding: var(--s-5); flex: 1; }
.dh-card-body.flush { padding: 0; }
.dh-card-body.flush { max-height: 440px; overflow-y: auto; }
.dh-card-body.flush::-webkit-scrollbar { width: 3px; }
.dh-card-body.flush::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* Segmented control (e.g. 7d/30d/90d) */
.dh-seg {
  display: flex;
  gap: 2px;
  background: var(--bg-soft);
  padding: 3px;
  border-radius: var(--r-sm);
  font-size: var(--t-xs);
}
.dh-seg button {
  background: transparent;
  border: 0;
  padding: 4px 10px;
  border-radius: 5px;
  color: var(--text-dim);
  cursor: pointer;
  font-weight: 500;
}
.dh-seg button.on {
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow-sm);
}

/* ============== HERO CHART (chart + headline) ============== */
.dh-hero-chart {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding: var(--s-5) var(--s-5) 0;
}
.dh-hero-chart-row {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.dh-hero-chart .num {
  font-size: var(--t-3xl);
  font-weight: 700;
  letter-spacing: -0.03em;
  font-feature-settings: 'tnum';
  color: var(--text);
}
.dh-hero-chart .sub {
  color: var(--text-dim);
  font-size: var(--t-sm);
}
/* Canvas wrapper — REQUIRED for Chart.js. See CHARTJS-FIX.md */
.dh-chart-wrap {
  position: relative;
  height: 240px;
  margin: var(--s-3) -4px 0;
  padding-bottom: var(--s-4);
}
.dh-chart-wrap canvas {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: var(--s-4);
}

/* ============== TASK LIST (v2) ============== */
.dh-task-list { display: flex; flex-direction: column; }
.dh-task {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-5);
  border-left: 3px solid transparent;
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
  cursor: pointer;
}
.dh-task:last-child { border-bottom: 0; }
.dh-task:hover { background: var(--surface-2); }
.dh-task.p-high { border-left-color: var(--err); }
.dh-task.p-med { border-left-color: var(--warn); }
.dh-task.p-low { border-left-color: var(--ok); }
.dh-check {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  border: 2px solid var(--text-faint);
  flex-shrink: 0;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 150ms var(--ease);
}
.dh-check:hover { border-color: var(--amber); }
.dh-task.done .dh-check {
  background: var(--ok);
  border-color: var(--ok);
}
.dh-task.done .dh-check::after {
  content: '';
  width: 10px;
  height: 6px;
  border: 2px solid #fff;
  border-top: 0;
  border-right: 0;
  transform: rotate(-45deg) translate(1px, -1px);
}
.dh-task.done .dh-task-title {
  text-decoration: line-through;
  color: var(--text-dim);
}
.dh-task-body { flex: 1; min-width: 0; }
.dh-task-title {
  font-size: var(--t-md);
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dh-task-meta {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-top: 3px;
  font-size: var(--t-xs);
  color: var(--text-dim);
}
.dh-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--grad-navy);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border: 1px solid var(--border-strong);
}
.dh-avatar.lg { width: 36px; height: 36px; font-size: var(--t-sm); }

/* ============== ANNOUNCEMENTS (v2) ============== */
.dh-announce {
  display: flex;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 120ms var(--ease);
}
.dh-announce:last-child { border-bottom: 0; }
.dh-announce:hover { background: var(--surface-2); }
.dh-announce-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--r-md);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  background: var(--info-bg);
  color: var(--info);
}
.dh-announce-icon.celebrate { background: var(--warn-bg); color: var(--warn); }
.dh-announce-icon.alert { background: var(--err-bg); color: var(--err); }
.dh-announce-body { flex: 1; min-width: 0; }
.dh-announce-title {
  font-size: var(--t-md);
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: var(--s-2);
}
.dh-announce-snippet {
  font-size: var(--t-sm);
  color: var(--text-dim);
  margin-top: 3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dh-announce-meta {
  font-size: var(--t-xs);
  color: var(--text-faint);
  margin-top: 6px;
}

/* ============== TIMELINE (activity) ============== */
.dh-timeline {
  padding: var(--s-2) var(--s-5) var(--s-5);
}
.dh-tl-item {
  display: flex;
  gap: var(--s-4);
  padding: var(--s-3) 0;
  position: relative;
}
.dh-tl-item::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 30px;
  bottom: -10px;
  width: 2px;
  background: var(--border);
}
.dh-tl-item:last-child::before { display: none; }
.dh-tl-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  background: var(--surface-3);
  color: var(--text-soft);
  border: 3px solid var(--surface);
  box-shadow: 0 0 0 1px var(--border);
  position: relative;
  z-index: 1;
}
.dh-tl-dot.amber { background: var(--info-bg); color: var(--info); }
.dh-tl-dot.success { background: var(--ok-bg); color: var(--ok); }
.dh-tl-dot.crimson { background: var(--err-bg); color: var(--err); }
.dh-tl-dot.warning { background: var(--warn-bg); color: var(--warn); }
.dh-tl-content { flex: 1; min-width: 0; padding-top: 2px; }
.dh-tl-content p {
  margin: 0;
  font-size: var(--t-sm);
  color: var(--text-soft);
}
.dh-tl-content p b { color: var(--text); font-weight: 600; }
.dh-tl-time {
  font-size: var(--t-xs);
  color: var(--text-faint);
  margin-top: 2px;
}

/* ============== AI CARD (featured) ============== */
.dh-ai-card {
  background: var(--grad-navy);
  color: #fff;
  border: 0;
  position: relative;
  overflow: hidden;
  height: 430px;
}
.dh-ai-card .dh-card-body {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.dh-ai-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(245, 180, 84, 0.2), transparent 50%);
  pointer-events: none;
}
.dh-ai-card .dh-card-head {
  background: transparent;
  border-bottom-color: rgba(255, 255, 255, 0.1);
}
.dh-ai-card .dh-card-head h3 { color: #fff; }
.dh-ai-card .dh-head-icon {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}
.dh-ai-card .dh-card-link { color: rgba(255, 255, 255, 0.85); }
.dh-ai-card .dh-card-body { color: rgba(255, 255, 255, 0.85); }
.dh-ai-card .dh-card-body p { color: rgba(255, 255, 255, 0.85); margin: 0; }
[data-theme="light"] .dh-ai-card { background: var(--grad-navy); color: #fff; border: 0; }
[data-theme="light"] .dh-ai-card .dh-card-head { background: transparent; border-bottom-color: rgba(255,255,255,0.1); }
[data-theme="light"] .dh-ai-card .dh-card-head h3 { color: #fff; }
[data-theme="light"] .dh-ai-card .dh-head-icon { background: rgba(255,255,255,0.15); color: #fff; }
[data-theme="light"] .dh-ai-card .dh-card-link { color: rgba(255,255,255,0.85); }
[data-theme="light"] .dh-ai-card .dh-card-body { color: rgba(255,255,255,0.85); }
[data-theme="light"] .dh-ai-card .dh-card-body p { color: rgba(255,255,255,0.85); }
[data-theme="light"] .dh-ai-card .dh-ai-prompt { background: rgba(0,0,0,0.2); border-color: rgba(255,255,255,0.1); }
[data-theme="light"] .dh-ai-card .dh-ai-prompt input { color: #fff; background: transparent; }
[data-theme="light"] .dh-ai-card .dh-ai-prompt input::placeholder { color: rgba(255,255,255,0.5); }
[data-theme="light"] .dh-ai-card .dh-ai-prompt input:focus { border-color: transparent; box-shadow: none; outline: none; }
[data-theme="light"] .dh-ai-card .dh-ai-suggestions .pill { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.15); color: #fff; }
.dh-ai-prompt {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--r-md);
  padding: 12px var(--s-4);
  margin-top: var(--s-3);
}
.dh-ai-prompt input {
  flex: 1;
  background: transparent;
  border: 0;
  color: #fff;
  outline: none;
  box-shadow: none;
  font: inherit;
}
.dh-ai-prompt input:focus { outline: none; box-shadow: none; border: 0; }
.dh-ai-prompt input::placeholder { color: rgba(255, 255, 255, 0.5); }
.dh-ai-send {
  width: 32px;
  height: 32px;
  border-radius: var(--r-sm);
  background: var(--grad-warm);
  color: #fff;
  border: 0;
  display: grid;
  place-items: center;
  cursor: pointer;
}
.dh-ai-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-3);
}
.dh-ai-suggestions .pill {
  font-size: var(--t-xs);
  padding: 5px var(--s-3);
  border-radius: var(--r-pill);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: #fff;
  cursor: pointer;
  transition: background 150ms var(--ease);
  text-decoration: none;
}
.dh-ai-suggestions .pill:hover { background: rgba(255, 255, 255, 0.18); }

/* ============== AI CHAT MESSAGES ============== */
#hub-ai-intro { flex: 1; }
.hub-ai-messages {
  display: none;
  flex-direction: column;
  gap: var(--s-2);
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  margin-bottom: var(--s-3);
  padding-right: var(--s-1);
}
.dh-ai-prompt { flex-shrink: 0; }
.hub-ai-messages::-webkit-scrollbar { width: 3px; }
.hub-ai-messages::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 2px; }
.hub-ai-msg {
  padding: var(--s-2) var(--s-3);
  border-radius: var(--r-md);
  font-size: var(--t-sm);
  line-height: 1.5;
  word-break: break-word;
}
.hub-ai-msg-user {
  background: rgba(255,255,255,0.12);
  color: #fff;
  align-self: flex-end;
  max-width: 85%;
  border-bottom-right-radius: var(--r-xs);
}
.hub-ai-msg-ai {
  background: rgba(0,0,0,0.15);
  color: rgba(255,255,255,0.92);
  align-self: flex-start;
  max-width: 90%;
  border-bottom-left-radius: var(--r-xs);
}
.hub-ai-msg-ai a { color: rgba(255,255,255,0.85); text-decoration: underline; }
.hub-ai-msg-ai code { background: rgba(255,255,255,0.08); padding: 1px 4px; border-radius: 3px; font-size: 0.9em; }
.hub-ai-msg-ai p { margin: 0 0 var(--s-2); }
.hub-ai-msg-ai p:last-child { margin-bottom: 0; }
.hub-ai-msg-ai ul, .hub-ai-msg-ai ol { margin: var(--s-1) 0 var(--s-2) var(--s-5); padding: 0; }
[data-theme="light"] .hub-ai-messages::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); }
[data-theme="light"] .hub-ai-msg-user { background: rgba(255,255,255,0.15); color: #fff; }
[data-theme="light"] .hub-ai-msg-ai { background: rgba(0,0,0,0.12); color: rgba(255,255,255,0.95); }

/* ============== INTEL FEED ============== */
.dh-intel-item {
  display: flex;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 120ms var(--ease);
}
.dh-intel-item:last-child { border-bottom: 0; }
.dh-intel-item:hover { background: var(--surface-2); }
.dh-intel-source {
  width: 28px;
  height: 28px;
  border-radius: var(--r-sm);
  background: var(--surface-3);
  color: var(--text-soft);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-weight: 700;
  font-size: var(--t-xs);
}
.dh-intel-body { flex: 1; min-width: 0; }
.dh-intel-title {
  font-size: var(--t-sm);
  font-weight: 500;
  color: var(--text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dh-intel-meta {
  font-size: var(--t-xs);
  color: var(--text-faint);
  margin-top: 3px;
}

/* ============== EMPTY STATE ============== */
.dh-empty {
  padding: var(--s-7) var(--s-5);
  text-align: center;
  color: var(--text-dim);
  font-size: var(--t-sm);
}

/* ============== DASHBOARD CONTAINER ============== */
.dh-content {
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  padding: var(--s-6);
  max-width: 1500px;
  margin: 0 auto;
  width: 100%;
}

/* ============== ANIMATIONS ============== */
@keyframes dh-fadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.dh-content > * {
  animation: dh-fadeUp 400ms var(--ease-out) backwards;
}
.dh-content > *:nth-child(1) { animation-delay: 0ms; }
.dh-content > *:nth-child(2) { animation-delay: 60ms; }
.dh-content > *:nth-child(3) { animation-delay: 120ms; }
.dh-content > *:nth-child(4) { animation-delay: 180ms; }
.dh-content > *:nth-child(5) { animation-delay: 240ms; }
.dh-content > *:nth-child(6) { animation-delay: 300ms; }

/* ============== RESPONSIVE ============== */
@media (max-width: 1100px) {
  .dh-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .dh-grid.two-thirds,
  .dh-grid.two-thirds-rev,
  .dh-grid.halves,
  .dh-grid.thirds { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .dh-content { padding: var(--s-4); }
  .dh-hero-greet h1 { font-size: var(--t-xl); }
  .dh-kpi-row { grid-template-columns: 1fr 1fr; gap: var(--s-3); }
  .dh-kpi { padding: var(--s-4); }
  .dh-kpi-value .num { font-size: var(--t-2xl); }
  .dh-card-head, .dh-card-body { padding-left: var(--s-4); padding-right: var(--s-4); }
  .dh-task, .dh-announce, .dh-intel-item { padding-left: var(--s-4); padding-right: var(--s-4); }
}
@media (max-width: 480px) {
  .dh-kpi-row { grid-template-columns: 1fr; }
}
/* =========================================================
   SUPPORT REDESIGN TOKENS — additive
   Paste this block into public/css/dashboard.css after the
   existing redesign tokens (from the previous handoff).
   These are purely additive and do not override anything.
   ========================================================= */

/* DARK MODE additions */
:root[data-theme="dark"],
:root:not([data-theme="light"]) {
  /* Age/urgency scale — visual progression from fresh to critical */
  --age-fresh: #2dd4a7;
  --age-fresh-bg: rgba(45, 212, 167, 0.10);
  --age-aging: #f5b454;
  --age-aging-bg: rgba(245, 180, 84, 0.12);
  --age-old: #f97a3e;
  --age-old-bg: rgba(249, 122, 62, 0.14);
  --age-critical: #ef5d75;
  --age-critical-bg: rgba(239, 93, 117, 0.16);
  --age-critical-glow: rgba(239, 93, 117, 0.35);

  /* Collaboration — customer gratitude + peer kudos */
  --love: #ec4899;
  --love-bg: rgba(236, 72, 153, 0.12);
  --kudos: #a855f7;
  --kudos-bg: rgba(168, 85, 247, 0.12);

  /* Additional gradients */
  --grad-fire: linear-gradient(135deg, #f97a3e 0%, #f5b454 100%);
  --grad-success: linear-gradient(135deg, #2dd4a7 0%, #4a8bd4 100%);
  --grad-love: linear-gradient(135deg, #ec4899 0%, #f97a3e 100%);
  --grad-kudos: linear-gradient(135deg, #a855f7 0%, #4a8bd4 100%);

  /* Celebration glow (for close-ticket toast) */
  --shadow-celebrate: 0 0 0 1px rgba(45, 212, 167, 0.4), 0 12px 40px rgba(45, 212, 167, 0.25);
}

/* LIGHT MODE additions */
:root[data-theme="light"] {
  --age-fresh: #059669;
  --age-fresh-bg: rgba(5, 150, 105, 0.08);
  --age-aging: #d97706;
  --age-aging-bg: rgba(217, 119, 6, 0.10);
  --age-old: #ea580c;
  --age-old-bg: rgba(234, 88, 12, 0.10);
  --age-critical: #dc2626;
  --age-critical-bg: rgba(220, 38, 38, 0.12);
  --age-critical-glow: rgba(220, 38, 38, 0.25);

  --love: #db2777;
  --love-bg: rgba(219, 39, 119, 0.10);
  --kudos: #9333ea;
  --kudos-bg: rgba(147, 51, 234, 0.10);

  --grad-fire: linear-gradient(135deg, #ea580c 0%, #d97706 100%);
  --grad-success: linear-gradient(135deg, #059669 0%, #2563eb 100%);
  --grad-love: linear-gradient(135deg, #db2777 0%, #ea580c 100%);
  --grad-kudos: linear-gradient(135deg, #9333ea 0%, #2563eb 100%);

  --shadow-celebrate: 0 0 0 1px rgba(5, 150, 105, 0.3), 0 12px 40px rgba(5, 150, 105, 0.18);
}

/* =========================================================
   STRATEGY NOTES
   =========================================================
   - These additions do NOT redefine any existing token.
   - The new semantic tokens (--love, --kudos, --age-*) use
     names that don't exist anywhere in the live CSS.
   - Other pages of the site are unaffected.
   - If any of these names DO collide with something you find
     in the live dashboard.css (search before pasting),
     rename the additions with a "sp-" prefix on the variable
     and update components.css to match.
   ========================================================= */
/* =========================================================
   SUPPORT REDESIGN COMPONENTS — additive
   Append to public/css/dashboard.css after tokens.css.
   All classes prefixed .sp- to prevent collisions.
   Where existing dashboard handoff classes (.dh-*) are
   appropriate, they are reused; no duplicates here.
   ========================================================= */

/* ============== TICKET CARD (used on every support page) ============== */
.sp-tkt-list { display: flex; flex-direction: column; }
.sp-tkt {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  align-items: center;
  border-bottom: 1px solid var(--border);
  border-left: 2px solid var(--age-fresh, var(--ok));
  cursor: pointer;
  transition: all 150ms var(--ease);
  position: relative;
}
.sp-tkt:last-child { border-bottom: 0; }
.sp-tkt:hover { background: var(--surface-2); }
.sp-tkt-bar { display: none; }
.sp-tkt.aging { border-left-color: var(--age-aging, var(--warn)); background: linear-gradient(90deg, var(--age-aging-bg, var(--warn-bg)), transparent 60%); }
.sp-tkt.aging:hover { background: linear-gradient(90deg, var(--age-aging-bg, var(--warn-bg)), var(--surface-2) 80%); }
.sp-tkt.old { border-left-color: var(--age-old, #f97316); background: linear-gradient(90deg, var(--age-old-bg, rgba(249,115,22,0.08)), transparent 60%); }
.sp-tkt.old:hover { background: linear-gradient(90deg, var(--age-old-bg, rgba(249,115,22,0.08)), var(--surface-2) 80%); }
.sp-tkt.critical { border-left-color: var(--age-critical, var(--err)); }
@keyframes sp-pulse-bar {
  0%, 100% { box-shadow: 0 0 12px var(--age-critical-glow); }
  50% { box-shadow: 0 0 20px var(--age-critical-glow), 0 0 4px var(--age-critical); }
}
.sp-tkt.critical { background: linear-gradient(90deg, var(--age-critical-bg), transparent 60%); }
.sp-tkt.critical:hover { background: linear-gradient(90deg, var(--age-critical-bg), var(--surface-2) 80%); }

/* Customer type badge — unified across all ticket lists */
.sp-tkt-customer {
  width: 36px; height: 36px; border-radius: var(--r-md);
  background: var(--surface-2); color: var(--text-dim);
  font-weight: 600; font-size: var(--t-sm);
  display: grid; place-items: center; flex-shrink: 0;
  border: 1px solid var(--border-strong);
}
.sp-tkt-customer svg { width: 18px; height: 18px; }
/* Customer type variants */
.sp-tkt-customer.type-parent { background: linear-gradient(135deg, #2a4a8a, #1e3160); color: #fff; }
.sp-tkt-customer.type-school { background: linear-gradient(135deg, #059669, #047857); color: #fff; }
.sp-tkt-customer.type-sales { background: linear-gradient(135deg, #f59e0b, #d97706); color: #fff; }
.sp-tkt-customer.type-app { background: linear-gradient(135deg, #6366f1, #4f46e5); color: #fff; }
.sp-tkt-customer.type-tech { background: linear-gradient(135deg, #64748b, #475569); color: #fff; }
.sp-tkt-customer.type-billing { background: linear-gradient(135deg, #06b6d4, #0891b2); color: #fff; }
.sp-tkt-customer.type-spam { background: linear-gradient(135deg, #ef4444, #dc2626); color: #fff; }
.sp-tkt-customer.type-commerce { background: linear-gradient(135deg, #8b5cf6, #7c3aed); color: #fff; }
.sp-tkt-customer.type-travel { background: linear-gradient(135deg, #f97316, #ea580c); color: #fff; }
.sp-tkt-customer.type-law { background: linear-gradient(135deg, #ec4899, #db2777); color: #fff; }
.sp-tkt-customer.type-advertising { background: linear-gradient(135deg, #14b8a6, #0d9488); color: #fff; }
.sp-tkt-customer.type-medoutreach { background: linear-gradient(135deg, #e11d48, #be123c); color: #fff; }
.sp-tkt-customer.type-unknown {
  background: transparent;
  color: var(--text-faint);
  border: 1.5px dashed var(--border-strong, var(--border));
}
/* Legacy color variants — kept for backwards compat */
.sp-tkt-customer.c-1 { background: linear-gradient(135deg, #2a4a8a, #1e3160); color: #fff; }
.sp-tkt-customer.c-2 { background: linear-gradient(135deg, #ab1d37, #8a1629); color: #fff; }
.sp-tkt-customer.c-3 { background: linear-gradient(135deg, #4a8bd4, #2a4a8a); color: #fff; }
.sp-tkt-customer.c-4 { background: linear-gradient(135deg, #2dd4a7, #4a8bd4); color: #fff; }
.sp-tkt-customer.c-5 { background: linear-gradient(135deg, #f5b454, #f97a3e); color: #fff; }
.sp-tkt-customer.c-6 { background: linear-gradient(135deg, #6b46c1, #4a8bd4); color: #fff; }
.sp-tkt-customer.c-7 { background: linear-gradient(135deg, #ec4899, #a855f7); color: #fff; }
.sp-tkt-customer.c-8 { background: linear-gradient(135deg, #06b6d4, #4a8bd4); color: #fff; }

.sp-tkt-body { min-width: 0; }
.sp-tkt-title-row { display: flex; align-items: center; gap: var(--s-2); margin-bottom: 4px; }
.sp-tkt-title {
  font-size: var(--t-sm); font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1; min-width: 0;
}
.sp-tkt-id { font-size: var(--t-xs); color: var(--text-faint); font-weight: 500; font-family: 'SF Mono', Menlo, monospace; }
.sp-tkt-meta {
  display: flex; align-items: center; gap: var(--s-3);
  font-size: var(--t-xs); color: var(--text-dim);
  flex-wrap: wrap;
}
.sp-tkt-customer-name { color: var(--text-soft); font-weight: 500; }

/* State pill — compact 2-letter state code */
.sp-state {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 1px 5px; border-radius: var(--r-sm);
  font-size: 10px; font-weight: 700; letter-spacing: 0.04em;
  font-family: 'SF Mono', Menlo, monospace;
  background: var(--info-bg); color: var(--info);
  border: 1px solid rgba(74,139,212,0.2);
  flex-shrink: 0; line-height: 1.4;
}
.sp-state.dim { opacity: 0.5; }
/* Customer info in ticket meta */
.sp-tkt-customer-info {
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--text-dim); font-size: var(--t-xs);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 220px;
}
.sp-tkt-customer-info b { color: var(--text-soft); font-weight: 500; }

/* Age badge — the urgency indicator */
.sp-age {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: var(--r-pill);
  font-size: var(--t-xs); font-weight: 600;
  font-feature-settings: 'tnum';
}
.sp-age.fresh { background: var(--age-fresh-bg); color: var(--age-fresh); }
.sp-age.aging { background: var(--age-aging-bg); color: var(--age-aging); }
.sp-age.old { background: var(--age-old-bg); color: var(--age-old); }
.sp-age.critical {
  background: var(--age-critical-bg); color: var(--age-critical);
  font-weight: 700;
  box-shadow: 0 0 0 1px rgba(239,93,117,0.25), 0 0 8px var(--age-critical-glow);
}
.sp-age.critical svg { animation: sp-shake 0.6s ease-in-out infinite alternate; }
@keyframes sp-shake { from { transform: rotate(-3deg); } to { transform: rotate(3deg); } }

.sp-tkt-right { display: flex; align-items: center; gap: var(--s-3); flex-shrink: 0; }
.sp-priority-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sp-priority-dot.high { background: var(--err); box-shadow: 0 0 8px var(--err); }
.sp-priority-dot.med { background: var(--warn); }
.sp-priority-dot.low { background: var(--text-faint); }

.sp-tkt-action {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft);
  display: grid; place-items: center;
  cursor: pointer; transition: all 150ms var(--ease);
}
.sp-tkt-action:hover { background: var(--surface-3); color: var(--text); transform: scale(1.05); }
.sp-tkt-action.close-action:hover {
  background: var(--ok-bg); color: var(--ok);
  border-color: var(--ok);
  box-shadow: 0 0 0 3px rgba(45,212,167,0.15);
}

/* Customer-thanked inline indicator */
.sp-thanked {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: var(--t-xs); font-weight: 600;
  color: var(--love);
  padding: 2px 6px; border-radius: var(--r-pill);
  background: var(--love-bg);
}

/* ============== HERO STRIP (My Queue) ============== */
.sp-hero { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--s-4); }
.sp-hero-greet {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-5) var(--s-6);
  position: relative; overflow: hidden;
}
.sp-hero-greet::before {
  content: ''; position: absolute; right: -20px; top: -20px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(245,180,84,0.18), transparent 70%);
  pointer-events: none;
}
.sp-hero-greet h1 { font-size: var(--t-2xl); margin: 0 0 4px; letter-spacing: -0.02em; color: var(--text); font-weight: 600; }
.sp-hero-greet h1 .accent {
  background: var(--grad-warm);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sp-hero-greet p { margin: 0 0 var(--s-4); color: var(--text-dim); font-size: var(--t-md); }
.sp-progress-row { display: flex; align-items: center; gap: var(--s-3); margin-top: var(--s-2); }
.sp-progress-label { font-size: var(--t-sm); color: var(--text-soft); font-weight: 500; }
.sp-progress { flex: 1; height: 8px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; }
.sp-progress-fill {
  height: 100%; background: var(--grad-success);
  border-radius: var(--r-pill);
  box-shadow: 0 0 12px rgba(45,212,167,0.4);
  transition: width 600ms var(--ease-out);
  position: relative;
}
.sp-progress-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.18), transparent);
  animation: sp-shimmer 2s linear infinite;
}
@keyframes sp-shimmer { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
.sp-progress-num { font-size: var(--t-sm); color: var(--text); font-weight: 600; font-feature-settings: 'tnum'; min-width: 60px; text-align: right; }

.sp-stat-tile {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--s-4) var(--s-5);
  display: flex; align-items: center; gap: var(--s-4);
  transition: all 200ms var(--ease); cursor: pointer;
}
.sp-stat-tile:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.sp-stat-tile-icon {
  width: 52px; height: 52px; border-radius: var(--r-md);
  display: grid; place-items: center; flex-shrink: 0;
  font-size: 24px; position: relative;
}
.sp-stat-tile-icon.fire {
  background: var(--grad-fire); color: #fff;
  box-shadow: 0 0 24px rgba(249,122,62,0.35);
  animation: sp-flame 2s ease-in-out infinite alternate;
}
@keyframes sp-flame { from { transform: scale(1) rotate(-2deg); } to { transform: scale(1.05) rotate(2deg); } }
.sp-stat-tile-icon.level { background: var(--grad-amber); color: #fff; box-shadow: 0 0 24px rgba(74,139,212,0.3); }
.sp-stat-tile-body { min-width: 0; flex: 1; }
.sp-stat-tile-label { font-size: var(--t-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); font-weight: 600; margin-bottom: 2px; }
.sp-stat-tile-value { display: flex; align-items: baseline; gap: var(--s-2); }
.sp-stat-tile-value .num { font-size: var(--t-xl); font-weight: 700; letter-spacing: -0.02em; color: var(--text); font-feature-settings: 'tnum'; }
.sp-stat-tile-value .unit { font-size: var(--t-sm); color: var(--text-dim); font-weight: 500; }
.sp-stat-tile-meta { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; }
.sp-level-progress { margin-top: 6px; height: 4px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; }
.sp-level-progress-fill { height: 100%; background: var(--grad-amber); border-radius: var(--r-pill); }

@media (max-width: 1100px) { .sp-hero { grid-template-columns: 1fr; } }

/* ============== COMPACT KPI ROW (override of .dh-kpi-row) ============== */
.dh-kpi-row.compact { gap: var(--s-3); }
.dh-kpi-row.compact .dh-kpi { padding: var(--s-3) var(--s-4); }
.dh-kpi-row.compact .dh-kpi-head { margin-bottom: var(--s-2); gap: var(--s-2); }
.dh-kpi-row.compact .dh-kpi-icon { width: 30px; height: 30px; border-radius: var(--r-sm); }
.dh-kpi-row.compact .dh-kpi-icon svg { width: 14px; height: 14px; }
.dh-kpi-row.compact .dh-kpi-label { font-size: var(--t-xs); }
.dh-kpi-row.compact .dh-kpi-value { gap: 6px; margin-bottom: 4px; }
.dh-kpi-row.compact .dh-kpi-value .num { font-size: var(--t-xl); }
.dh-kpi-row.compact .dh-kpi-spark { height: 24px; margin: 0 -4px -4px; }

/* ============== HEAD ICON COLOR EXTENSIONS ============== */
.dh-head-icon.sp-fire { background: var(--age-critical-bg); color: var(--age-critical); }
.dh-head-icon.sp-love { background: var(--love-bg); color: var(--love); }
.dh-head-icon.sp-kudos { background: var(--kudos-bg); color: var(--kudos); }

.dh-kpi-icon.sp-love { background: var(--love-bg); color: var(--love); }
.dh-kpi-icon.sp-kudos { background: var(--kudos-bg); color: var(--kudos); }

.dh-chip.sp-love { background: var(--love-bg); color: var(--love); }
.dh-chip.sp-kudos { background: var(--kudos-bg); color: var(--kudos); }

/* ============== UP FOR GRABS (unassigned, claimable) ============== */
.sp-grab-banner {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-3) var(--s-5);
  background: linear-gradient(90deg, rgba(245,180,84,0.12), transparent 70%);
  border-bottom: 1px solid var(--border);
  font-size: var(--t-sm);
}
.sp-grab-banner-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--grad-fire); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
  box-shadow: 0 0 20px rgba(249,122,62,0.4);
  animation: sp-flame 2s ease-in-out infinite alternate;
}
.sp-grab-banner-text { flex: 1; color: var(--text-soft); }
.sp-grab-banner-text b { color: var(--text); }
.sp-grab-bonus {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--grad-warm); color: #fff;
  font-size: var(--t-xs); font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 0 12px rgba(245,180,84,0.3);
}

.sp-grab-row {
  display: grid;
  grid-template-columns: 36px 1fr auto auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
  position: relative;
}
.sp-grab-row:last-child { border-bottom: 0; }
.sp-grab-row:hover { background: var(--surface-2); }
.sp-grab-row.hot::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--age-fresh);
  box-shadow: 0 0 8px var(--age-fresh);
}
.sp-grab-body { min-width: 0; }
.sp-grab-title { font-size: var(--t-sm); font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-grab-meta { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap; }
.sp-grab-meta b { color: var(--text-soft); font-weight: 600; }
.sp-just-in {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 7px; border-radius: var(--r-pill);
  background: var(--ok-bg); color: var(--ok);
  font-size: 10px; font-weight: 700; letter-spacing: 0.04em;
}
.sp-just-in.hot {
  background: var(--grad-fire); color: #fff;
  animation: sp-glow-pulse 2s ease-in-out infinite;
}
@keyframes sp-glow-pulse {
  0%, 100% { box-shadow: 0 0 8px rgba(249,122,62,0.4); }
  50% { box-shadow: 0 0 16px rgba(249,122,62,0.7); }
}
.sp-claim-btn {
  padding: 8px 16px; border-radius: var(--r-sm);
  background: var(--grad-amber); border: 0;
  color: #fff; font-weight: 700; font-size: var(--t-sm);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 2px 12px rgba(74,139,212,0.3);
  transition: all 150ms var(--ease);
}
.sp-claim-btn:hover { transform: translateY(-1px) scale(1.02); box-shadow: 0 4px 24px rgba(74,139,212,0.5); }
.sp-claim-btn:active { transform: scale(0.97); }
.sp-claim-btn.hot { background: var(--grad-fire); box-shadow: 0 2px 12px rgba(249,122,62,0.4); }
.sp-claim-btn.hot:hover { box-shadow: 0 4px 24px rgba(249,122,62,0.6); }
.sp-claim-btn.claimed { background: var(--ok-bg); color: var(--ok); box-shadow: none; pointer-events: none; }
.sp-grab-filter {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; font-size: var(--t-xs);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text-soft);
  cursor: pointer; font-weight: 500;
}
.sp-grab-filter:hover { border-color: var(--border-strong); }
.sp-grab-filter.on { background: var(--info-bg); color: var(--info); border-color: var(--info); }

/* ============== WAITING ON CONTACT (nudge) ============== */
.sp-nudge-row {
  display: grid;
  grid-template-columns: 36px 1fr 110px auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
}
.sp-nudge-row:last-child { border-bottom: 0; }
.sp-nudge-row:hover { background: var(--surface-2); }
.sp-nudge-body { min-width: 0; }
.sp-nudge-title { font-size: var(--t-sm); font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-nudge-sub { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap; }
.sp-nudge-sub b { color: var(--text-soft); font-weight: 600; }
.sp-since {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: var(--r-pill);
  font-size: var(--t-xs); font-weight: 600;
  font-feature-settings: 'tnum';
}
.sp-since.short { background: var(--age-fresh-bg); color: var(--age-fresh); }
.sp-since.medium { background: var(--age-aging-bg); color: var(--age-aging); }
.sp-since.long { background: var(--age-old-bg); color: var(--age-old); }
.sp-since.very-long { background: var(--age-critical-bg); color: var(--age-critical); font-weight: 700; }
.sp-nudge-template {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 10px; font-size: var(--t-xs);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text-soft);
  cursor: pointer; max-width: 200px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: all 150ms var(--ease);
}
.sp-nudge-template:hover { background: var(--surface-3); color: var(--text); border-color: var(--border-strong); }
.sp-nudge-template svg { color: var(--text-faint); flex-shrink: 0; }
.sp-nudge-send {
  padding: 7px 14px; border-radius: var(--r-sm);
  background: var(--grad-amber); border: 0; color: #fff;
  font-weight: 600; font-size: var(--t-sm);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 2px 12px rgba(74,139,212,0.25);
  transition: all 150ms var(--ease);
}
.sp-nudge-send:hover { box-shadow: 0 4px 20px rgba(74,139,212,0.4); transform: translateY(-1px); }
.sp-nudge-send.sent { background: var(--ok-bg); color: var(--ok); box-shadow: none; pointer-events: none; }
.sp-nudge-banner {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-3) var(--s-5);
  background: linear-gradient(90deg, var(--info-bg), transparent);
  border-bottom: 1px solid var(--border);
  font-size: var(--t-sm); color: var(--text-soft);
}
.sp-nudge-banner svg { color: var(--info); flex-shrink: 0; }
.sp-nudge-banner b { color: var(--text); }
.sp-nudge-banner-actions { margin-left: auto; display: flex; gap: var(--s-2); }

/* ============== LEADERBOARD + CHEER ============== */
.sp-leader {
  display: grid;
  grid-template-columns: 28px 36px 1fr auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
}
.sp-leader:last-child { border-bottom: 0; }
.sp-leader:hover { background: var(--surface-2); }
.sp-leader.you { background: linear-gradient(90deg, var(--info-bg), transparent); }
.sp-leader-rank { font-size: var(--t-md); font-weight: 700; color: var(--text-dim); text-align: center; font-feature-settings: 'tnum'; }
.sp-leader-rank.gold { color: #f5b454; }
.sp-leader-rank.silver { color: #c0c8d8; }
.sp-leader-rank.bronze { color: #cd7f32; }
.sp-leader-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  color: #fff; font-weight: 600; font-size: var(--t-sm);
  display: grid; place-items: center;
  border: 2px solid var(--border-strong);
}
.sp-leader-name { font-size: var(--t-sm); font-weight: 600; color: var(--text); }
.sp-leader-stats { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; }
.sp-leader-stats .pts { color: var(--ok); font-weight: 600; }
.sp-leader-points { font-size: var(--t-md); font-weight: 700; color: var(--text); font-feature-settings: 'tnum'; text-align: right; }
.sp-leader-points .lvl { font-size: var(--t-xs); color: var(--text-dim); font-weight: 500; }
.sp-cheer-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft);
  display: grid; place-items: center;
  cursor: pointer; font-size: 16px;
  transition: all 200ms var(--ease);
}
.sp-cheer-btn:hover {
  background: var(--kudos-bg); color: var(--kudos);
  border-color: var(--kudos);
  transform: scale(1.15) rotate(-8deg);
  box-shadow: 0 0 12px rgba(168,85,247,0.3);
}
.sp-cheer-btn.given { background: var(--kudos-bg); color: var(--kudos); border-color: var(--kudos); }

/* ============== ACHIEVEMENTS ============== */
.sp-ach-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-3); padding: var(--s-5); }
.sp-ach {
  display: flex; flex-direction: column; align-items: center;
  padding: var(--s-3) var(--s-2); border-radius: var(--r-md);
  background: var(--surface-2); border: 1px solid var(--border);
  transition: all 200ms var(--ease); cursor: pointer;
  text-align: center; position: relative; overflow: hidden;
}
.sp-ach:hover { transform: translateY(-2px); border-color: var(--border-strong); }
.sp-ach.locked { opacity: 0.4; filter: grayscale(0.6); }
.sp-ach.earned::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 50% 0%, rgba(245,180,84,0.15), transparent 60%);
  pointer-events: none;
}
.sp-ach-icon {
  width: 44px; height: 44px; border-radius: 50%;
  display: grid; place-items: center;
  font-size: 22px; margin-bottom: var(--s-2);
  box-shadow: var(--shadow-sm);
}
.sp-ach-icon.fire { background: var(--grad-fire); }
.sp-ach-icon.bolt { background: var(--grad-amber); }
.sp-ach-icon.medal { background: var(--grad-warm); }
.sp-ach-icon.shield { background: var(--grad-success); }
.sp-ach-icon.heart { background: var(--grad-love); }
.sp-ach-icon.star { background: var(--grad-kudos); }
.sp-ach-icon.locked { background: var(--surface-3); color: var(--text-faint); }
.sp-ach-name { font-size: var(--t-xs); font-weight: 600; color: var(--text); margin-bottom: 2px; }
.sp-ach-meta { font-size: 10px; color: var(--text-dim); }

/* ============== CUSTOMER LOVE ============== */
.sp-love-card { padding: var(--s-4) var(--s-5); display: flex; gap: var(--s-3); border-bottom: 1px solid var(--border); }
.sp-love-card:last-child { border-bottom: 0; }
.sp-love-quote {
  flex: 1; min-width: 0;
  font-style: italic; color: var(--text-soft);
  font-size: var(--t-sm); position: relative;
  padding-left: var(--s-3);
  border-left: 3px solid var(--love);
}
.sp-love-quote-meta {
  font-style: normal; font-size: var(--t-xs);
  color: var(--text-dim); margin-top: 6px;
  display: flex; align-items: center; gap: var(--s-2);
}
.sp-love-quote-meta b { color: var(--text); font-weight: 600; }
.sp-love-actions { display: flex; align-items: center; gap: var(--s-2); }
.sp-pin-btn {
  width: 28px; height: 28px; border-radius: 50%;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
  transition: all 150ms var(--ease);
}
.sp-pin-btn:hover { background: var(--love-bg); color: var(--love); border-color: var(--love); }

/* ============== TODAY'S WINS / CLOSED FEED ============== */
.sp-closed-row {
  display: grid;
  grid-template-columns: 28px 1fr auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
}
.sp-closed-row:last-child { border-bottom: 0; }
.sp-closed-check { width: 28px; height: 28px; border-radius: 50%; background: var(--ok-bg); color: var(--ok); display: grid; place-items: center; flex-shrink: 0; }
.sp-closed-body { min-width: 0; }
.sp-closed-title { font-size: var(--t-sm); color: var(--text-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-closed-title b { color: var(--text); font-weight: 600; }
.sp-closed-meta { font-size: var(--t-xs); color: var(--text-faint); margin-top: 2px; display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap; }
.sp-closed-pts { font-size: var(--t-xs); font-weight: 700; color: var(--ok); font-feature-settings: 'tnum'; }
.sp-kudos-btn {
  width: 28px; height: 28px; border-radius: 50%;
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center; font-size: 13px;
  transition: all 200ms var(--ease);
}
.sp-kudos-btn:hover { background: var(--kudos-bg); color: var(--kudos); border-color: var(--kudos); transform: scale(1.15); }
.sp-kudos-btn.given { background: var(--kudos-bg); color: var(--kudos); border-color: var(--kudos); }

/* ============== CELEBRATION TOAST + CONFETTI + FLOAT-PTS ============== */
.sp-toast {
  position: fixed; top: var(--s-5); right: var(--s-5); z-index: 1000;
  background: var(--surface); border: 1px solid var(--ok);
  border-radius: var(--r-lg); padding: var(--s-4) var(--s-5);
  box-shadow: var(--shadow-celebrate);
  display: flex; align-items: center; gap: var(--s-3);
  min-width: 320px;
  animation: sp-toastIn 500ms var(--ease-bounce, cubic-bezier(0.34, 1.56, 0.64, 1));
}
@keyframes sp-toastIn {
  from { opacity: 0; transform: translateX(120%) scale(0.9); }
  to { opacity: 1; transform: translateX(0) scale(1); }
}
.sp-toast.kudos-toast { border-color: var(--kudos); box-shadow: 0 0 0 1px var(--kudos), 0 12px 40px rgba(168,85,247,0.25); }
.sp-toast-icon {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--grad-success); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
  box-shadow: 0 0 24px rgba(45,212,167,0.5);
}
.sp-toast.kudos-toast .sp-toast-icon { background: var(--grad-kudos); box-shadow: 0 0 24px rgba(168,85,247,0.5); }
.sp-toast-body { flex: 1; }
.sp-toast-title { font-size: var(--t-md); font-weight: 700; color: var(--text); }
.sp-toast-sub { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; }
.sp-toast-points { font-size: var(--t-lg); font-weight: 700; color: var(--ok); font-feature-settings: 'tnum'; margin-left: auto; }
.sp-toast.kudos-toast .sp-toast-points { color: var(--kudos); }
.sp-toast-close {
  width: 24px; height: 24px; border-radius: 50%;
  background: transparent; border: 0;
  color: var(--text-dim); cursor: pointer;
  display: grid; place-items: center;
}
.sp-toast-close:hover { background: var(--surface-3); color: var(--text); }

.sp-confetti {
  position: fixed; pointer-events: none; z-index: 999;
  top: 0; left: 0; width: 100%; height: 100%; overflow: hidden;
}
.sp-confetti-piece {
  position: absolute; width: 8px; height: 12px;
  top: -20px;
  animation: sp-fall 3s ease-in forwards;
}
@keyframes sp-fall {
  0% { transform: translateY(0) rotate(0); opacity: 1; }
  100% { transform: translateY(110vh) rotate(720deg); opacity: 0; }
}
.sp-float-pts {
  position: fixed; z-index: 1100;
  font-size: var(--t-2xl); font-weight: 700;
  color: var(--ok);
  text-shadow: 0 0 12px rgba(45,212,167,0.6);
  pointer-events: none;
  animation: sp-float-up 1.4s var(--ease-out) forwards;
}
@keyframes sp-float-up {
  0% { opacity: 0; transform: translateY(0) scale(0.5); }
  20% { opacity: 1; transform: translateY(-30px) scale(1.2); }
  100% { opacity: 0; transform: translateY(-120px) scale(1); }
}

/* ============== TICKET PANEL (slide-in right) ============== */
.sp-panel-backdrop {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity 200ms var(--ease);
}
.sp-panel-backdrop.open { opacity: 1; pointer-events: auto; }
.sp-ticket-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(640px, 100vw); z-index: 101;
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  transform: translateX(110%);
  transition: transform 320ms var(--ease-out);
  display: flex; flex-direction: column; overflow: hidden;
}
.sp-ticket-panel.open { transform: translateX(0); }

.sp-tp-head {
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: flex-start; gap: var(--s-3);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.sp-tp-customer-badge {
  width: 44px; height: 44px; border-radius: var(--r-md);
  display: grid; place-items: center;
  color: #fff; font-weight: 600; flex-shrink: 0;
  border: 1px solid var(--border-strong);
}
.sp-tp-title-block { flex: 1; min-width: 0; }
.sp-tp-title { font-size: var(--t-lg); font-weight: 600; color: var(--text); line-height: 1.3; }
.sp-tp-sub { display: flex; align-items: center; gap: var(--s-2); font-size: var(--t-xs); color: var(--text-dim); margin-top: 4px; flex-wrap: wrap; }
.sp-tp-sub b { color: var(--text-soft); font-weight: 600; }
.sp-tp-close {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
}
.sp-tp-close:hover { background: var(--surface-3); color: var(--text); }

.sp-tp-tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
  padding: 0 var(--s-5);
  background: var(--surface);
}
.sp-tp-tab {
  padding: var(--s-3) var(--s-4);
  background: transparent; border: 0;
  color: var(--text-dim); cursor: pointer;
  font-weight: 500; font-size: var(--t-sm);
  position: relative;
  transition: color 150ms var(--ease);
}
.sp-tp-tab:hover { color: var(--text); }
.sp-tp-tab.on { color: var(--text); }
.sp-tp-tab.on::after {
  content: ''; position: absolute;
  left: var(--s-4); right: var(--s-4); bottom: -1px;
  height: 2px; background: var(--amber); border-radius: 2px;
}
.sp-tp-tab .tab-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px;
  padding: 0 5px; margin-left: 6px;
  border-radius: var(--r-pill);
  background: var(--surface-3); color: var(--text-dim);
  font-size: 10px; font-weight: 700;
}

.sp-tp-body {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-5);
}

/* Initial request block (original ticket body, visible by default) */
.sp-tp-initial {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.sp-tp-initial-head {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  background: linear-gradient(180deg, var(--surface-2), transparent);
  border-bottom: 1px solid var(--border);
}
.sp-tp-initial-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--love);
  padding: 2px 8px; border-radius: var(--r-pill);
  background: var(--love-bg);
}
.sp-tp-initial-from { font-size: var(--t-xs); color: var(--text-dim); }
.sp-tp-initial-from b { color: var(--text-soft); font-weight: 600; }
.sp-tp-initial-when { margin-left: auto; font-size: var(--t-xs); color: var(--text-faint); }
.sp-tp-initial-body {
  padding: var(--s-4);
  font-size: var(--t-sm); color: var(--text-soft); line-height: 1.6;
}
.sp-tp-initial-body p { margin: 0 0 var(--s-2); }
.sp-tp-initial-body p:last-child { margin-bottom: 0; }
.sp-tp-initial-body pre {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--s-2) var(--s-3);
  font-family: 'SF Mono', Menlo, monospace;
  font-size: var(--t-xs); color: var(--text);
  overflow-x: auto; margin: var(--s-2) 0;
}
.sp-tp-initial-attach {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  margin-top: var(--s-2);
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-size: var(--t-xs); color: var(--text-soft);
  cursor: pointer;
  transition: all 150ms var(--ease);
}
.sp-tp-initial-attach:hover { background: var(--surface-3); border-color: var(--border-strong); }

/* AI suggestion bar */
.sp-tp-ai {
  background: linear-gradient(135deg, rgba(74,139,212,0.10), rgba(45,212,167,0.08));
  border: 1px solid rgba(74,139,212,0.3);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  display: flex; gap: var(--s-3); align-items: flex-start;
}
.sp-tp-ai-icon {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: var(--grad-amber); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.sp-tp-ai-body { flex: 1; min-width: 0; }
.sp-tp-ai-label { font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--info); font-weight: 700; }
.sp-tp-ai-title { font-size: var(--t-sm); color: var(--text); margin-top: 2px; font-weight: 500; }
.sp-tp-ai-actions { display: flex; gap: 6px; margin-top: var(--s-2); }
.sp-tp-ai-actions button {
  padding: 4px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text); cursor: pointer; font-weight: 500;
}
.sp-tp-ai-actions button.primary {
  background: var(--grad-amber); border-color: transparent; color: #fff; font-weight: 600;
}

/* Conversation thread */
.sp-tp-msg { display: flex; gap: var(--s-3); padding-bottom: var(--s-3); }
.sp-tp-msg-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  color: #fff; font-weight: 600; font-size: var(--t-sm);
  display: grid; place-items: center; flex-shrink: 0;
}
.sp-tp-msg-body { flex: 1; min-width: 0; }
.sp-tp-msg-head { display: flex; align-items: center; gap: var(--s-2); margin-bottom: 4px; flex-wrap: wrap; }
.sp-tp-msg-name { font-size: var(--t-sm); font-weight: 600; color: var(--text); }
.sp-tp-msg-tag {
  font-size: 10px; font-weight: 600;
  padding: 2px 6px; border-radius: var(--r-pill);
  background: var(--surface-3); color: var(--text-dim);
  letter-spacing: 0.04em; text-transform: uppercase;
}
.sp-tp-msg-tag.you { background: var(--info-bg); color: var(--info); }
.sp-tp-msg-tag.customer { background: var(--love-bg); color: var(--love); }
.sp-tp-msg-time { font-size: var(--t-xs); color: var(--text-faint); margin-left: auto; }
.sp-tp-msg-bubble {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  font-size: var(--t-sm); color: var(--text-soft);
  line-height: 1.55;
}
.sp-tp-msg.from-customer .sp-tp-msg-bubble {
  background: var(--love-bg);
  border-color: rgba(236,72,153,0.25);
}
.sp-tp-msg-positive {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; color: var(--love); font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  margin-bottom: 6px;
}

/* Edit fields */
.sp-tp-fields { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
.sp-tp-field { display: flex; flex-direction: column; gap: 4px; }
.sp-tp-field label { font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); font-weight: 600; }
.sp-tp-field select, .sp-tp-field input {
  padding: 7px 10px; font-size: var(--t-sm);
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
}

/* Composer */
.sp-tp-foot {
  border-top: 1px solid var(--border);
  padding: var(--s-4) var(--s-5);
  background: var(--surface);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.sp-tp-composer {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  min-height: 80px;
  display: flex; flex-direction: column; gap: var(--s-2);
}
.sp-tp-composer-tabs { display: flex; gap: var(--s-2); }
.sp-tp-composer-tabs button {
  font-size: var(--t-xs); padding: 4px 10px;
  border-radius: var(--r-pill);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-dim); cursor: pointer;
}
.sp-tp-composer-tabs button.on { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-tp-composer-tabs button.note.on { background: var(--warn-bg); color: var(--warn); border-color: var(--warn); }
.sp-tp-composer textarea {
  width: 100%; border: 0; background: transparent;
  color: var(--text); resize: none; outline: none;
  font-family: var(--font, system-ui); font-size: var(--t-sm);
  min-height: 60px;
}
.sp-tp-foot-actions { display: flex; align-items: center; gap: var(--s-2); }
.sp-template-pick {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--surface-3); border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
}
.sp-template-pick:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-ask-help {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--kudos-bg); border: 1px solid rgba(168,85,247,0.3);
  color: var(--kudos); cursor: pointer; font-weight: 600;
}
.sp-ask-help:hover { background: rgba(168,85,247,0.18); border-color: var(--kudos); }
.sp-send-btn {
  margin-left: auto;
  padding: 8px 16px; border-radius: var(--r-sm);
  background: var(--grad-success); border: 0; color: #fff;
  font-weight: 600; cursor: pointer;
  box-shadow: 0 2px 12px rgba(45,212,167,0.3);
}
.sp-send-btn:hover { box-shadow: 0 4px 20px rgba(45,212,167,0.5); transform: translateY(-1px); }

/* ============== INSIGHTS (Lead Dashboard) ============== */
.sp-insights-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s-3); padding: var(--s-5);
}
.sp-ins {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-left: 4px solid var(--info);
  border-radius: 0;
  padding: var(--s-3) var(--s-4);
  display: flex; gap: var(--s-3); align-items: flex-start;
  transition: all 200ms var(--ease);
  position: relative;
}
.sp-ins:hover { border-color: var(--border-strong); }
.sp-ins.critical { border-left-color: var(--err); background: linear-gradient(90deg, var(--err-bg), var(--surface-2) 40%); }
.sp-ins.warn { border-left-color: var(--warn); }
.sp-ins.opportunity { border-left-color: var(--kudos); }
.sp-ins.positive { border-left-color: var(--ok); }
.sp-ins-icon {
  width: 36px; height: 36px; border-radius: var(--r-md);
  display: grid; place-items: center; flex-shrink: 0;
  font-size: 18px;
  background: var(--info-bg); color: var(--info);
}
.sp-ins.critical .sp-ins-icon { background: var(--err-bg); color: var(--err); }
.sp-ins.warn .sp-ins-icon { background: var(--warn-bg); color: var(--warn); }
.sp-ins.opportunity .sp-ins-icon { background: var(--kudos-bg); color: var(--kudos); }
.sp-ins.positive .sp-ins-icon { background: var(--ok-bg); color: var(--ok); }
.sp-ins-body { min-width: 0; flex: 1; }
.sp-ins-tag { font-size: 10px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--info); }
.sp-ins.critical .sp-ins-tag { color: var(--err); }
.sp-ins.warn .sp-ins-tag { color: var(--warn); }
.sp-ins.opportunity .sp-ins-tag { color: var(--kudos); }
.sp-ins.positive .sp-ins-tag { color: var(--ok); }
.sp-ins-title { font-size: var(--t-sm); font-weight: 600; color: var(--text); margin: 2px 0 4px; line-height: 1.3; }
.sp-ins-desc { font-size: var(--t-xs); color: var(--text-dim); line-height: 1.5; margin-bottom: var(--s-2); }
.sp-ins-desc b { color: var(--text-soft); font-weight: 600; }
.sp-ins-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.sp-ins-actions button {
  padding: 4px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text-soft); cursor: pointer;
  transition: all 150ms var(--ease); font-weight: 500;
}
.sp-ins-actions button:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-ins-actions button.primary { background: var(--grad-amber); border-color: transparent; color: #fff; font-weight: 600; }
.sp-ins-dismiss {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px; border-radius: 50%;
  background: transparent; border: 0;
  color: var(--text-faint); cursor: pointer;
  display: grid; place-items: center;
  opacity: 0; transition: all 150ms var(--ease);
}
.sp-ins:hover .sp-ins-dismiss { opacity: 1; }
.sp-ins-dismiss:hover { background: var(--surface-3); color: var(--err); }
.sp-ins-dismissing { animation: sp-dismissOut 250ms var(--ease) forwards; }
@keyframes sp-dismissOut { to { opacity: 0; transform: scale(0.95); margin-top: -50%; margin-bottom: -50%; } }

/* Collapsible card variant */
.dh-card.sp-collapsible .dh-card-body { transition: max-height 300ms var(--ease), padding 300ms var(--ease); }
.dh-card.sp-collapsible.collapsed .dh-card-body { max-height: 0; overflow: hidden; padding: 0; opacity: 0; }
.sp-collapse-btn {
  width: 30px; height: 30px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
  transition: all 150ms var(--ease);
}
.sp-collapse-btn:hover { background: var(--surface-3); color: var(--text); }
.sp-collapse-btn svg { transition: transform 250ms var(--ease); }
.dh-card.sp-collapsible.collapsed .sp-collapse-btn svg { transform: rotate(-90deg); }
.sp-collapsed-summary { display: none; font-size: var(--t-xs); color: var(--text-dim); margin-left: var(--s-2); }
.dh-card.sp-collapsible.collapsed .sp-collapsed-summary { display: inline; }

/* ============== PAGE TABS (Lead Dashboard, Templates) ============== */
.sp-page-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); }
.sp-page-tab {
  padding: var(--s-3) var(--s-4);
  background: transparent; border: 0;
  color: var(--text-dim); cursor: pointer;
  font-weight: 500; font-size: var(--t-md);
  position: relative;
  display: inline-flex; align-items: center; gap: var(--s-2);
}
.sp-page-tab:hover { color: var(--text); }
.sp-page-tab.on { color: var(--text); }
.sp-page-tab.on::after {
  content: ''; position: absolute;
  left: var(--s-4); right: var(--s-4); bottom: -1px;
  height: 2px; background: var(--amber); border-radius: 2px;
}
.sp-page-tab .pill-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 20px; height: 18px; padding: 0 6px;
  border-radius: var(--r-pill);
  background: var(--surface-3); color: var(--text-dim);
  font-size: 10px; font-weight: 700;
}
.sp-page-tab.on .pill-count { background: var(--info-bg); color: var(--info); }
.sp-tab-pane { display: none; }
.sp-tab-pane.on { display: flex; flex-direction: column; gap: var(--s-6); }

/* ============== LEVELS EDITOR (Lead Settings) ============== */
.sp-level-row {
  display: grid;
  grid-template-columns: 60px 1fr 1fr 120px 28px;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
}
.sp-level-row.head {
  background: var(--surface-2);
  font-size: var(--t-xs); color: var(--text-dim);
  font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
}
.sp-level-row:last-child { border-bottom: 0; }
.sp-level-badge {
  width: 44px; height: 44px; border-radius: 50%;
  display: grid; place-items: center;
  color: #fff; font-weight: 700;
  font-size: var(--t-md);
  box-shadow: var(--shadow-sm);
}
.sp-level-badge.l1 { background: linear-gradient(135deg, #94a3b8, #64748b); }
.sp-level-badge.l2 { background: linear-gradient(135deg, #38bdf8, #0284c7); }
.sp-level-badge.l3 { background: linear-gradient(135deg, #2dd4a7, #059669); }
.sp-level-badge.l4 { background: linear-gradient(135deg, #a855f7, #7c3aed); }
.sp-level-badge.l5 { background: var(--grad-warm); }
.sp-level-row input {
  padding: 6px 10px; font-size: var(--t-sm);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
  width: 100%;
  font-feature-settings: 'tnum';
}

/* ============== SCHEDULE GRID (Lead Schedule tab) ============== */
.sp-week-grid {
  display: grid; grid-template-columns: 80px repeat(7, 1fr);
  border-top: 1px solid var(--border);
}
.sp-week-grid .wg-cell {
  padding: var(--s-3);
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  min-height: 100px;
  display: flex; flex-direction: column; gap: 6px;
}
.sp-week-grid .wg-cell:last-child { border-right: 0; }
.sp-week-grid .wg-day-head {
  padding: var(--s-3);
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--surface-2);
  font-size: var(--t-xs); font-weight: 600; color: var(--text-dim);
  letter-spacing: 0.04em; text-transform: uppercase;
  text-align: center;
}
.sp-week-grid .wg-day-head .day-num {
  display: block; font-size: var(--t-lg); font-weight: 700; color: var(--text); margin-top: 4px;
  letter-spacing: 0;
}
.sp-week-grid .wg-day-head.today { background: var(--info-bg); }
.sp-week-grid .wg-day-head.today .day-num { color: var(--info); }
.sp-week-grid .wg-row-label {
  padding: var(--s-3); background: var(--surface-2);
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  font-size: var(--t-xs); font-weight: 700;
  color: var(--text-dim);
  letter-spacing: 0.04em; text-transform: uppercase;
  display: flex; align-items: center;
}
.sp-wg-assign {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 6px; border-radius: var(--r-sm);
  background: var(--info-bg);
  font-size: var(--t-xs);
}
.sp-wg-assign .sp-leader-avatar {
  width: 22px; height: 22px; font-size: 10px;
  border: 1px solid var(--border-strong);
}
.sp-wg-assign .role { color: var(--info); font-weight: 600; }
.sp-wg-assign .who { color: var(--text); font-weight: 600; flex: 1; }
.sp-wg-assign.backup { background: var(--surface-3); }
.sp-wg-assign.backup .role { color: var(--text-dim); }
.sp-wg-off {
  display: flex; align-items: center; gap: 6px;
  padding: 4px 6px; border-radius: var(--r-sm);
  background: var(--warn-bg);
  font-size: var(--t-xs);
  color: var(--warn); font-weight: 600;
}
.sp-wg-coverage-row {
  grid-column: span 8;
  display: grid; grid-template-columns: 80px repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
}
.sp-wg-coverage-cell {
  padding: var(--s-2) var(--s-3);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  border-right: 1px solid var(--border);
  text-align: center;
}
.sp-wg-coverage-cell.full { background: var(--ok-bg); color: var(--ok); }
.sp-wg-coverage-cell.light { background: var(--warn-bg); color: var(--warn); }
.sp-wg-coverage-cell.gap { background: var(--err-bg); color: var(--err); }

.sp-season-banner {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  background: linear-gradient(90deg, rgba(245,180,84,0.15), transparent);
  border: 1px solid var(--warn);
  border-radius: var(--r-md);
}
.sp-season-banner svg { color: var(--warn); flex-shrink: 0; }
.sp-forecast-wrap { position: relative; height: 240px; margin: 0 -4px; }
.sp-forecast-wrap canvas { position: absolute; inset: 0; }

/* ============== REPORTS TAB ============== */
.sp-compare-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s-3); padding: var(--s-5); }
.sp-compare {
  padding: var(--s-4);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-md);
  display: flex; flex-direction: column; gap: 6px;
}
.sp-compare-label { font-size: var(--t-xs); color: var(--text-dim); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }
.sp-compare-now { font-size: var(--t-2xl); font-weight: 700; color: var(--text); letter-spacing: -0.02em; font-feature-settings: 'tnum'; }
.sp-compare-now .unit { font-size: 0.5em; color: var(--text-dim); font-weight: 500; margin-left: 2px; }
.sp-compare-vs { display: flex; align-items: center; gap: 6px; font-size: var(--t-xs); color: var(--text-dim); }
.sp-compare-vs .arrow { font-size: var(--t-md); font-weight: 700; }
.sp-compare-vs .arrow.up { color: var(--ok); }
.sp-compare-vs .arrow.down { color: var(--err); }
.sp-compare-vs .arrow.good-down { color: var(--ok); }
.sp-compare-prev { color: var(--text-faint); }
.sp-compare-mini-chart { position: relative; height: 40px; margin: 0 -8px -8px; }
.sp-compare-mini-chart canvas { position: absolute; inset: 0; }

.sp-achievements-bar {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--s-3); padding: var(--s-5);
}
.sp-ach-unlocked {
  padding: var(--s-3);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-md);
  display: flex; gap: var(--s-3); align-items: center;
  position: relative; overflow: hidden;
}
.sp-ach-unlocked::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 0% 0%, rgba(245,180,84,0.15), transparent 60%);
  pointer-events: none;
}
.sp-ach-unlocked-icon {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  font-size: 20px; box-shadow: var(--shadow-sm); flex-shrink: 0;
}
.sp-ach-unlocked-body { min-width: 0; }
.sp-ach-unlocked-title { font-size: var(--t-sm); font-weight: 600; color: var(--text); }
.sp-ach-unlocked-meta { font-size: 10px; color: var(--text-dim); margin-top: 2px; }

/* ============== BRAIN: PROCESSES, PATTERNS, KB, CHAT ============== */
.sp-proc-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--s-3); padding: var(--s-5); }
.sp-proc {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--s-4);
  display: flex; flex-direction: column; gap: var(--s-2);
  transition: all 200ms var(--ease);
  position: relative; overflow: hidden;
}
.sp-proc:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.sp-proc-head { display: flex; align-items: center; justify-content: space-between; }
.sp-proc-icon {
  width: 40px; height: 40px; border-radius: var(--r-md);
  display: grid; place-items: center;
  background: var(--info-bg); color: var(--info);
  transition: all 250ms var(--ease);
}
.sp-proc.running .sp-proc-icon {
  background: var(--grad-amber); color: #fff;
  box-shadow: 0 0 16px rgba(74,139,212,0.4);
  animation: sp-pulse-icon 2s ease-in-out infinite;
}
@keyframes sp-pulse-icon { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
.sp-proc-status {
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: var(--r-pill);
  letter-spacing: 0.05em; text-transform: uppercase;
  background: var(--surface-3); color: var(--text-dim);
}
.sp-proc-status.idle { background: var(--surface-3); color: var(--text-dim); }
.sp-proc-status.running { background: var(--info-bg); color: var(--info); }
.sp-proc-status.success { background: var(--ok-bg); color: var(--ok); }
.sp-proc-status.error { background: var(--err-bg); color: var(--err); }
.sp-proc-name { font-size: var(--t-sm); font-weight: 600; color: var(--text); margin-top: 2px; }
.sp-proc-stat { display: flex; align-items: baseline; gap: 4px; margin-top: 2px; }
.sp-proc-stat .num { font-size: var(--t-lg); font-weight: 700; color: var(--text); font-feature-settings: 'tnum'; }
.sp-proc-stat .unit { font-size: var(--t-xs); color: var(--text-dim); }
.sp-proc-meta { font-size: var(--t-xs); color: var(--text-dim); }
.sp-proc-bar { height: 4px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; margin-top: var(--s-2); }
.sp-proc-bar-fill {
  height: 100%; border-radius: var(--r-pill);
  background: var(--grad-amber);
  width: 0; transition: width 400ms var(--ease);
  position: relative;
}
.sp-proc.running .sp-proc-bar-fill { box-shadow: 0 0 8px rgba(74,139,212,0.6); }
.sp-proc.running .sp-proc-bar-fill::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  animation: sp-shimmer-bar 1.4s linear infinite;
}
@keyframes sp-shimmer-bar { from { transform: translateX(-100%); } to { transform: translateX(100%); } }
.sp-proc-run {
  flex: 1; margin-top: var(--s-2);
  padding: 6px var(--s-3); font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text); cursor: pointer; font-weight: 600;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  transition: all 150ms var(--ease);
}
.sp-proc-run:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-proc.running .sp-proc-run { background: var(--info-bg); color: var(--info); border-color: var(--info); cursor: not-allowed; opacity: 0.7; }

/* Patterns */
.sp-pattern { padding: var(--s-4) var(--s-5); border-bottom: 1px solid var(--border); cursor: pointer; transition: background 120ms var(--ease); }
.sp-pattern:last-child { border-bottom: 0; }
.sp-pattern:hover { background: var(--surface-2); }
.sp-pattern-head { display: flex; align-items: center; gap: var(--s-3); margin-bottom: 6px; }
.sp-pattern-icon {
  width: 36px; height: 36px; border-radius: var(--r-md);
  display: grid; place-items: center; flex-shrink: 0;
  background: var(--info-bg); color: var(--info);
  font-size: 16px;
}
.sp-pattern-icon.bug { background: var(--err-bg); color: var(--err); }
.sp-pattern-icon.q { background: var(--info-bg); color: var(--info); }
.sp-pattern-icon.req { background: var(--warn-bg); color: var(--warn); }
.sp-pattern-name { flex: 1; min-width: 0; font-size: var(--t-md); font-weight: 600; color: var(--text); }
.sp-pattern-freq-bar { height: 6px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; margin-top: 6px; }
.sp-pattern-freq-fill { height: 100%; border-radius: var(--r-pill); background: var(--grad-amber); }
.sp-pattern-desc {
  font-size: var(--t-sm); color: var(--text-dim); line-height: 1.4;
  margin-top: 4px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sp-pattern-tags { display: flex; gap: 4px; margin-top: 6px; flex-wrap: wrap; }

/* KB cards */
.sp-kb-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-3); padding: var(--s-5); }
.sp-kb-card {
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--s-4);
  transition: all 200ms var(--ease); cursor: pointer;
}
.sp-kb-card:hover { transform: translateY(-2px); border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.sp-kb-cat {
  display: inline-block;
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: var(--r-pill);
  letter-spacing: 0.04em; text-transform: uppercase;
  background: var(--info-bg); color: var(--info);
  margin-bottom: var(--s-2);
}
.sp-kb-cat.product { background: var(--ok-bg); color: var(--ok); }
.sp-kb-cat.process { background: var(--warn-bg); color: var(--warn); }
.sp-kb-cat.policy { background: var(--err-bg); color: var(--err); }
.sp-kb-cat.troubleshoot { background: var(--info-bg); color: var(--info); }
.sp-kb-cat.customer { background: var(--love-bg); color: var(--love); }
.sp-kb-title { font-size: var(--t-md); font-weight: 600; color: var(--text); margin-bottom: 6px; line-height: 1.3; }
.sp-kb-body {
  font-size: var(--t-sm); color: var(--text-dim); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 3;
  -webkit-box-orient: vertical; overflow: hidden;
}
.sp-kb-foot {
  display: flex; align-items: center; gap: var(--s-2);
  margin-top: var(--s-3);
  font-size: var(--t-xs); color: var(--text-faint);
}
.sp-kb-foot .upvotes { display: inline-flex; align-items: center; gap: 4px; color: var(--ok); font-weight: 600; }

/* Compact chat (Ask The Brain) */
.sp-chat-snap {
  display: grid; grid-template-columns: 44px 1fr;
  min-height: 480px;
  transition: grid-template-columns 220ms var(--ease);
}
.sp-chat-snap.expanded { grid-template-columns: 220px 1fr; }
.sp-chat-conv-list {
  border-right: 1px solid var(--border);
  padding: var(--s-2);
  overflow-y: auto; overflow-x: hidden;
  display: flex; flex-direction: column; gap: 2px;
}
.sp-chat-conv-toggle {
  width: 28px; height: 28px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft);
  display: grid; place-items: center;
  cursor: pointer; align-self: center;
  margin-bottom: var(--s-2);
  transition: all 150ms var(--ease);
}
.sp-chat-conv-toggle:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-chat-snap.expanded .sp-chat-conv-toggle { transform: rotate(180deg); }
.sp-chat-snap:not(.expanded) .sp-chat-conv-text { display: none; }
.sp-chat-conv {
  display: flex; align-items: center; gap: var(--s-2);
  padding: 6px; border-radius: var(--r-sm); cursor: pointer;
}
.sp-chat-conv:hover { background: var(--surface-2); }
.sp-chat-conv.on { background: var(--info-bg); }
.sp-chat-conv-dot {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-3); color: var(--text-dim);
  display: grid; place-items: center; flex-shrink: 0;
  font-size: 12px; font-weight: 600;
}
.sp-chat-conv.on .sp-chat-conv-dot { background: var(--info); color: #fff; }
.sp-chat-conv-text { min-width: 0; flex: 1; }
.sp-chat-conv-title { font-size: var(--t-sm); color: var(--text); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-chat-conv-meta { font-size: 10px; color: var(--text-dim); margin-top: 1px; }
.sp-chat-conv-new {
  display: flex; align-items: center; gap: var(--s-2);
  padding: 6px; border-radius: var(--r-sm);
  cursor: pointer; background: transparent;
  border: 1px dashed var(--border-strong);
  color: var(--text-dim);
  justify-content: center; margin-bottom: 4px;
}
.sp-chat-conv-new:hover { color: var(--info); border-color: var(--info); }
.sp-chat-area {
  display: flex; flex-direction: column;
  padding: var(--s-4); gap: var(--s-3); min-height: 0;
}
.sp-chat-msgs { flex: 1; min-height: 0; overflow-y: auto; display: flex; flex-direction: column; gap: var(--s-3); }
.sp-chat-msg { display: flex; gap: var(--s-2); align-items: flex-start; }
.sp-chat-msg.user { flex-direction: row-reverse; }
.sp-chat-bubble {
  max-width: 85%;
  padding: var(--s-3); border-radius: var(--r-md);
  background: var(--surface-2); border: 1px solid var(--border);
  color: var(--text-soft); font-size: var(--t-sm); line-height: 1.5;
}
.sp-chat-msg.user .sp-chat-bubble { background: var(--info-bg); border-color: rgba(74,139,212,0.3); color: var(--text); }
.sp-chat-input-row {
  margin-top: auto; padding-top: var(--s-3);
  display: flex; gap: var(--s-2);
  border-top: 1px solid var(--border);
}
.sp-chat-input-row input {
  flex: 1; padding: 9px 12px;
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
  font-size: var(--t-sm);
}
.sp-chat-input-row input:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px rgba(74,139,212,0.15); }
.sp-chat-input-row .send {
  width: 36px; height: 36px; border-radius: var(--r-sm);
  background: var(--grad-amber); border: 0; color: #fff;
  display: grid; place-items: center; cursor: pointer;
}

/* ============== TEMPLATE CARD + LINK ANALYTICS ============== */
.sp-tpl-grid {
  display: flex; flex-direction: column;
  gap: 0; padding: 0;
}
.sp-tpl-card {
  background: var(--surface-2); border-bottom: 1px solid var(--border);
  padding: var(--s-3) var(--s-5);
  display: flex; flex-direction: row; align-items: center; gap: var(--s-4);
  transition: background 150ms var(--ease); cursor: pointer;
  position: relative; overflow: hidden;
}
.sp-tpl-card:hover { background: var(--surface-3); }
.sp-tpl-card.active::before {
  content: ''; position: absolute;
  left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--grad-success);
  box-shadow: 0 0 12px var(--ok);
}
.sp-tpl-card.inactive { opacity: 0.6; }
.sp-tpl-card-head { display: flex; align-items: center; gap: var(--s-3); flex: 1; min-width: 0; }
.sp-tpl-card-head h4 { font-size: var(--t-md); font-weight: 600; color: var(--text); flex: 1; min-width: 0; line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-tpl-subject {
  font-size: var(--t-xs); color: var(--text-dim);
  padding: 4px var(--s-2);
  background: var(--bg-soft); border-radius: var(--r-sm);
  font-family: 'SF Mono', Menlo, monospace;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1; min-width: 0; max-width: 300px;
}
.sp-tpl-stats {
  display: flex; gap: var(--s-4); align-items: center;
  flex-shrink: 0;
}
.sp-tpl-stats > div { text-align: center; }
.sp-tpl-stat-num { font-size: var(--t-md); font-weight: 700; color: var(--text); font-feature-settings: 'tnum'; }
.sp-tpl-stat-label { font-size: 10px; color: var(--text-dim); letter-spacing: 0.04em; text-transform: uppercase; font-weight: 600; margin-top: 2px; }
.sp-tpl-foot { display: flex; gap: 4px; flex-shrink: 0; }
.sp-tpl-foot button {
  padding: 5px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  transition: all 150ms var(--ease);
}
.sp-tpl-foot button:hover { background: var(--surface-3); color: var(--text); }
.sp-tpl-foot button.primary:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }
.sp-tpl-foot button.danger:hover { background: var(--err-bg); color: var(--err); border-color: var(--err); }

.sp-link-row {
  display: grid;
  grid-template-columns: 1fr 1fr 90px 90px 110px;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
}
.sp-link-row.head {
  background: var(--surface-2);
  font-size: var(--t-xs); color: var(--text-dim);
  font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
}
.sp-link-row:last-child { border-bottom: 0; }
.sp-link-row .link-url { font-family: 'SF Mono', Menlo, monospace; font-size: var(--t-sm); color: var(--info); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-link-row .tpl-ref { font-size: var(--t-sm); color: var(--text-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-link-row .num { font-feature-settings: 'tnum'; color: var(--text); font-weight: 600; }
.sp-link-row .ctr { display: flex; align-items: center; gap: 6px; }
.sp-link-row .ctr-bar { flex: 1; height: 4px; background: var(--surface-3); border-radius: var(--r-pill); overflow: hidden; }
.sp-link-row .ctr-fill { height: 100%; background: var(--ok); border-radius: var(--r-pill); }

.sp-top-link {
  padding: var(--s-3) var(--s-5);
  display: grid; grid-template-columns: 28px 1fr auto;
  gap: var(--s-3); align-items: center;
  border-bottom: 1px solid var(--border);
}
.sp-top-link:last-child { border-bottom: 0; }
.sp-top-link-rank { font-size: var(--t-md); font-weight: 700; color: var(--text-dim); text-align: center; font-feature-settings: 'tnum'; }
.sp-top-link-rank.gold { color: #f5b454; }
.sp-top-link-body { min-width: 0; }
.sp-top-link-url { font-family: 'SF Mono', Menlo, monospace; font-size: var(--t-sm); color: var(--info); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-top-link-meta { font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px; }
.sp-top-link-clicks { font-size: var(--t-md); font-weight: 700; color: var(--ok); font-feature-settings: 'tnum'; }

/* ============== AUTOMATION CARD + RULE BUILDER ============== */
.sp-auto {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--s-4) var(--s-5);
  display: grid;
  grid-template-columns: 24px auto 1fr auto auto auto;
  gap: var(--s-4); align-items: center;
  transition: all 200ms var(--ease);
  margin-bottom: var(--s-3);
}
.sp-auto:hover { transform: translateY(-1px); border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.sp-auto.inactive { opacity: 0.5; }
.sp-auto-icon {
  width: 44px; height: 44px; border-radius: var(--r-md);
  display: grid; place-items: center;
  background: var(--info-bg); color: var(--info);
  flex-shrink: 0;
}
.sp-auto-icon.template { background: var(--kudos-bg); color: var(--kudos); }
.sp-auto-icon.status { background: var(--ok-bg); color: var(--ok); }
.sp-auto-icon.reassign { background: var(--warn-bg); color: var(--warn); }
.sp-auto-icon.escalate { background: var(--err-bg); color: var(--err); }
.sp-auto-body { min-width: 0; }
.sp-auto-name { font-size: var(--t-md); font-weight: 600; color: var(--text); margin-bottom: 6px; }
.sp-auto-flow { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; font-size: var(--t-xs); }
.sp-auto-flow .when { color: var(--text-dim); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; padding-right: 4px; }
.sp-cond-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: var(--r-sm);
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-soft);
  font-family: 'SF Mono', Menlo, monospace;
  font-size: 11px;
}
.sp-cond-chip b { color: var(--text); font-weight: 600; }
.sp-auto-arrow { color: var(--text-faint); }
.sp-action-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--r-pill);
  background: var(--grad-amber);
  color: #fff;
  font-size: 11px; font-weight: 600;
}
.sp-action-chip.status { background: var(--grad-success); }
.sp-action-chip.reassign { background: var(--grad-warm); }
.sp-auto-stats { text-align: center; min-width: 80px; }
.sp-auto-stats .num { font-size: var(--t-lg); font-weight: 700; color: var(--text); font-feature-settings: 'tnum'; }
.sp-auto-stats .label { font-size: 10px; color: var(--text-dim); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 600; }

.sp-builder { display: flex; flex-direction: column; gap: var(--s-3); }
.sp-builder-row {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3); background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--r-sm);
  flex-wrap: wrap;
}
.sp-builder-row select, .sp-builder-row input {
  padding: 7px 10px; font-size: var(--t-sm);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
}
.sp-builder-row .when {
  font-size: var(--t-xs); font-weight: 700; color: var(--info);
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 4px 8px; background: var(--info-bg);
  border-radius: var(--r-pill);
}
.sp-builder-row .and {
  font-size: var(--t-xs); font-weight: 700; color: var(--text-dim);
  padding: 4px 10px; background: var(--surface-3);
  border-radius: var(--r-pill);
  letter-spacing: 0.05em; text-transform: uppercase;
}
.sp-add-cond {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 12px; font-size: var(--t-sm);
  border-radius: var(--r-sm);
  background: transparent; border: 1px dashed var(--border-strong);
  color: var(--text-dim); cursor: pointer;
}
.sp-add-cond:hover { color: var(--info); border-color: var(--info); }
.sp-arrow-down {
  align-self: center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--surface-2);
  border: 1px solid var(--border);
  display: grid; place-items: center;
  color: var(--text-dim);
  margin: var(--s-1) 0;
}
.sp-action-block {
  padding: var(--s-4); background: var(--surface);
  border: 2px solid var(--info);
  border-radius: var(--r-md);
  display: flex; align-items: center; gap: var(--s-3);
  flex-wrap: wrap;
}
.sp-action-block .then {
  font-size: var(--t-xs); font-weight: 700; color: var(--info);
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 4px 10px; background: var(--info-bg);
  border-radius: var(--r-pill);
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1100px) {
  .sp-hero { grid-template-columns: 1fr; }
  .sp-insights-grid { grid-template-columns: 1fr; }
  .sp-compare-row { grid-template-columns: repeat(2, 1fr); }
  .sp-proc-grid { grid-template-columns: repeat(3, 1fr); }
  .sp-kb-grid { grid-template-columns: 1fr; }
}
@media (max-width: 820px) {
  .sp-tkt { grid-template-columns: 32px 1fr auto; gap: var(--s-3); padding: var(--s-3) var(--s-4); }
  .sp-ach-grid { grid-template-columns: repeat(3, 1fr); padding: var(--s-3); }
  .sp-proc-grid { grid-template-columns: repeat(2, 1fr); }
  .sp-compare-row { grid-template-columns: 1fr; }
  .sp-tpl-grid { flex-direction: column; }
  .sp-tpl-card { flex-direction: column; align-items: stretch; }
  .sp-tpl-subject { max-width: none; }
  .sp-auto { grid-template-columns: 24px auto 1fr; gap: var(--s-3); }
  .sp-week-grid { font-size: var(--t-xs); }
  .sp-ticket-panel { width: 100vw; }
}
/* =========================================================
   MARKETING REDESIGN TOKENS — minimal additions
   The dashboard + support handoffs already provide everything
   needed. Marketing only adds gradient definitions for the
   platform badges and content-channel colors.

   Paste this block into public/css/dashboard.css after the
   support tokens block. These are purely additive.
   ========================================================= */

/* Platform brand gradients — theme-agnostic (brands have one color) */
:root {
  /* Platform brand colors as gradients */
  --grad-pf-instagram: linear-gradient(135deg, #f97a3e, #ec4899 50%, #a855f7);
  --grad-pf-facebook: linear-gradient(135deg, #2563eb, #1e40af);
  --grad-pf-linkedin: linear-gradient(135deg, #0a66c2, #084d8e);
  --grad-pf-x: linear-gradient(135deg, #1f2937, #000);
  --grad-pf-tiktok: linear-gradient(135deg, #000, #ec4899);

  /* Mailchimp brand color (used in the sync callout) */
  --mc-yellow: #ffe01b;
}

/* No new color tokens needed — all marketing semantic colors
   reuse existing tokens:
   - Email channel       → --info
   - Social channel      → --love
   - Blog channel        → --ok
   - AI / suggestion     → --kudos
   - Status: Draft       → --info
   - Status: In review   → --kudos
   - Status: Approved    → --ok
   - Status: Scheduled   → --warn
   - Status: Published   → --love
   ========================================================= */
/* =========================================================
   MARKETING REDESIGN COMPONENTS — additive
   Append to public/css/dashboard.css after tokens.css.
   All classes prefixed .mk-* (and .cal-*, .camp-*, .pipe-*
   where pre-existing in the live code may already use those
   names — check before applying).
   ========================================================= */

/* ============== PLATFORM BADGES (used everywhere) ============== */
.mk-pf {
  width: 18px; height: 18px; border-radius: 50%;
  display: grid; place-items: center;
  color: #fff; flex-shrink: 0;
  box-shadow: 0 1px 2px rgba(0,0,0,0.2);
}
.mk-pf.email { background: var(--grad-navy); }
.mk-pf.instagram { background: var(--grad-pf-instagram); }
.mk-pf.facebook { background: var(--grad-pf-facebook); }
.mk-pf.linkedin { background: var(--grad-pf-linkedin); }
.mk-pf.x { background: var(--grad-pf-x); }
.mk-pf.tiktok { background: var(--grad-pf-tiktok); }
.mk-pf.blog { background: var(--grad-success); }

/* Channel icon badge (square, larger, used in pipeline rows + panel header) */
.mk-channel-ico {
  width: 28px; height: 28px; border-radius: var(--r-sm);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.mk-channel-ico.email { background: var(--info-bg); color: var(--info); }
.mk-channel-ico.social { background: var(--love-bg); color: var(--love); }
.mk-channel-ico.blog { background: var(--ok-bg); color: var(--ok); }

/* ============== STATUS PILLS ============== */
.mk-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: var(--r-pill);
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
}
.mk-status::before { content: ''; width: 6px; height: 6px; border-radius: 50%; }
.mk-status.ideation { background: var(--surface-3); color: var(--text-dim); }
.mk-status.ideation::before { background: var(--text-faint); }
.mk-status.draft, .mk-status.drafting { background: var(--info-bg); color: var(--info); }
.mk-status.draft::before, .mk-status.drafting::before { background: var(--info); }
.mk-status.review { background: var(--kudos-bg); color: var(--kudos); }
.mk-status.review::before { background: var(--kudos); }
.mk-status.approved { background: var(--ok-bg); color: var(--ok); }
.mk-status.approved::before { background: var(--ok); }
.mk-status.scheduled { background: var(--warn-bg); color: var(--warn); }
.mk-status.scheduled::before { background: var(--warn); }
.mk-status.published { background: var(--love-bg); color: var(--love); }
.mk-status.published::before { background: var(--love); }

/* Channel chip (separate from icon badge; text-only) */
.mk-channel-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: var(--r-pill);
  font-size: var(--t-xs); font-weight: 600;
  background: var(--surface-3); color: var(--text-soft);
}
.mk-channel-chip.email { background: var(--info-bg); color: var(--info); }
.mk-channel-chip.social { background: var(--love-bg); color: var(--love); }
.mk-channel-chip.blog { background: var(--ok-bg); color: var(--ok); }

/* ============== HUB: PIPELINE MINI WIDGET ============== */
.mk-pipe-mini { display: flex; flex-direction: column; }
.mk-pipe-mini-row {
  display: grid; grid-template-columns: 10px 1fr auto;
  gap: var(--s-3); align-items: center;
  padding: 9px var(--s-5);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 120ms var(--ease);
  font-size: var(--t-sm);
}
.mk-pipe-mini-row:last-child { border-bottom: 0; }
.mk-pipe-mini-row:hover { background: var(--surface-2); }
.mk-pipe-mini-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.mk-pipe-mini-row.ideation .mk-pipe-mini-dot { background: var(--text-faint); }
.mk-pipe-mini-row.draft .mk-pipe-mini-dot { background: var(--info); }
.mk-pipe-mini-row.review .mk-pipe-mini-dot { background: var(--kudos); }
.mk-pipe-mini-row.approved .mk-pipe-mini-dot { background: var(--ok); }
.mk-pipe-mini-row.scheduled .mk-pipe-mini-dot { background: var(--warn); }
.mk-pipe-mini-row.published .mk-pipe-mini-dot { background: var(--love); }
.mk-pipe-mini-name { color: var(--text-soft); font-weight: 500; }
.mk-pipe-mini-num {
  color: var(--text); font-weight: 700;
  font-feature-settings: 'tnum';
  font-size: var(--t-md);
}

/* ============== HUB: UPCOMING CONTENT ROW ============== */
.mk-upcoming-row {
  display: grid;
  grid-template-columns: 60px 1fr auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
  cursor: pointer;
}
.mk-upcoming-row:last-child { border-bottom: 0; }
.mk-upcoming-row:hover { background: var(--surface-2); }
.mk-date-block {
  display: flex; flex-direction: column; align-items: center;
  padding: 6px 0;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  min-width: 56px;
}
.mk-date-block.today { background: var(--info-bg); border-color: var(--info); }
.mk-date-block.tomorrow { background: var(--warn-bg); border-color: var(--warn); }
.mk-date-month {
  font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-dim);
  font-weight: 600;
}
.mk-date-block.today .mk-date-month { color: var(--info); }
.mk-date-block.tomorrow .mk-date-month { color: var(--warn); }
.mk-date-day {
  font-size: var(--t-xl); font-weight: 700;
  color: var(--text); line-height: 1;
  margin: 2px 0;
  font-feature-settings: 'tnum';
}
.mk-date-time { font-size: 10px; color: var(--text-dim); font-weight: 500; }
.mk-upcoming-body { min-width: 0; }
.mk-upcoming-title {
  font-size: var(--t-md); font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 4px;
}
.mk-upcoming-meta {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-xs); color: var(--text-dim);
  flex-wrap: wrap;
}
.mk-upcoming-meta b { color: var(--text-soft); font-weight: 600; }
.mk-platforms { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }

/* ============== HUB: AI SUGGESTIONS ============== */
.mk-sug {
  padding: var(--s-3) var(--s-5);
  display: grid; grid-template-columns: 32px 1fr auto;
  gap: var(--s-3); align-items: flex-start;
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease);
  cursor: pointer;
}
.mk-sug:last-child { border-bottom: 0; }
.mk-sug:hover { background: var(--surface-2); }
.mk-sug-icon {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: var(--grad-amber); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.mk-sug-body { min-width: 0; }
.mk-sug-title {
  font-size: var(--t-sm); font-weight: 600; color: var(--text);
  margin-bottom: 4px; line-height: 1.3;
}
.mk-sug-brief {
  font-size: var(--t-xs); color: var(--text-dim);
  line-height: 1.4; margin-bottom: 6px;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.mk-sug-meta {
  display: flex; align-items: center; gap: var(--s-2);
  flex-wrap: wrap; font-size: 10px; color: var(--text-faint);
}
.mk-sug-reason {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: var(--r-pill);
  background: var(--kudos-bg); color: var(--kudos);
  font-size: 10px; font-weight: 600;
}
.mk-sug-edit {
  padding: 6px 10px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  font-size: var(--t-xs); font-weight: 500;
  display: inline-flex; align-items: center; gap: 4px;
}
.mk-sug-edit:hover { background: var(--info-bg); color: var(--info); border-color: var(--info); }

/* ============== HUB: WHAT WE SHARED OVERVIEW ============== */
.mk-overview-stats {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
  padding: 0 var(--s-5) var(--s-4);
}
.mk-overview-stat {
  padding: var(--s-3);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.mk-overview-stat .label {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--text-dim); margin-bottom: 6px;
}
.mk-overview-stat .num {
  font-size: var(--t-xl); font-weight: 700;
  color: var(--text); letter-spacing: -0.02em;
  font-feature-settings: 'tnum';
}
.mk-channel-breakdown {
  padding: 0 var(--s-5) var(--s-4);
  display: flex; flex-direction: column; gap: 8px;
}
.mk-cb-row {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-xs);
}
.mk-cb-row .mk-pf { width: 20px; height: 20px; }
.mk-cb-name { color: var(--text-soft); font-weight: 500; min-width: 90px; }
.mk-cb-bar {
  flex: 1; height: 6px; background: var(--surface-3);
  border-radius: var(--r-pill); overflow: hidden;
}
.mk-cb-fill { height: 100%; border-radius: var(--r-pill); }
.mk-cb-num {
  color: var(--text); font-weight: 600;
  min-width: 30px; text-align: right;
  font-feature-settings: 'tnum';
}
.mk-top-piece {
  margin: 0 var(--s-5) var(--s-4);
  padding: var(--s-3); border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--love-bg), transparent);
  border: 1px solid rgba(236,72,153,0.25);
  display: flex; align-items: center; gap: var(--s-3);
}
.mk-top-piece-icon {
  width: 36px; height: 36px; border-radius: var(--r-md);
  background: var(--grad-love); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.mk-top-piece-body { flex: 1; min-width: 0; }
.mk-top-piece-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--love);
}
.mk-top-piece-title {
  font-size: var(--t-sm); font-weight: 600; color: var(--text);
  margin-top: 2px;
}
.mk-top-piece-meta {
  font-size: var(--t-xs); color: var(--text-dim); margin-top: 2px;
}

/* ============== HUB: QUICK LINKS ============== */
.mk-links {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 6px; padding: var(--s-3);
}
.mk-link {
  display: flex; align-items: center; gap: var(--s-2);
  padding: 8px var(--s-3);
  border-radius: var(--r-sm);
  background: transparent; border: 1px solid transparent;
  color: var(--text-soft); cursor: pointer;
  text-decoration: none;
  transition: all 150ms var(--ease);
  font-size: var(--t-sm); font-weight: 500;
}
.mk-link:hover {
  background: var(--surface-2); border-color: var(--border);
  color: var(--text);
}
.mk-link-icon {
  width: 24px; height: 24px; border-radius: var(--r-sm);
  display: grid; place-items: center;
  background: var(--surface-3); color: var(--text-dim);
  flex-shrink: 0;
}
.mk-link:hover .mk-link-icon { background: var(--info-bg); color: var(--info); }

/* ============== HUB: ACTIVITY TIMELINE ============== */
.mk-activity { padding: var(--s-2) var(--s-5) var(--s-5); }
.mk-activity-item {
  display: flex; gap: var(--s-4); padding: var(--s-2) 0;
  position: relative;
}
.mk-activity-item::before {
  content: ''; position: absolute;
  left: 11px; top: 24px; bottom: -8px;
  width: 2px; background: var(--border);
}
.mk-activity-item:last-child::before { display: none; }
.mk-activity-dot {
  width: 24px; height: 24px; border-radius: 50%;
  flex-shrink: 0; display: grid; place-items: center;
  background: var(--surface-3); color: var(--text-soft);
  border: 3px solid var(--surface);
  box-shadow: 0 0 0 1px var(--border);
  position: relative; z-index: 1;
}
.mk-activity-dot.published { background: var(--love-bg); color: var(--love); }
.mk-activity-dot.scheduled { background: var(--warn-bg); color: var(--warn); }
.mk-activity-dot.approved { background: var(--ok-bg); color: var(--ok); }
.mk-activity-dot.draft { background: var(--info-bg); color: var(--info); }
.mk-activity-content { flex: 1; min-width: 0; padding-top: 2px; }
.mk-activity-content p { margin: 0; font-size: var(--t-sm); color: var(--text-soft); }
.mk-activity-content p b { color: var(--text); font-weight: 600; }
.mk-activity-time {
  font-size: var(--t-xs); color: var(--text-faint); margin-top: 2px;
}

/* ============== PIPELINE: CONTENT ROW (list view) ============== */
.content-row {
  display: grid;
  grid-template-columns: 4px 28px 1fr auto auto auto auto;
  gap: var(--s-3); align-items: center;
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 120ms var(--ease);
  position: relative;
}
.content-row:last-child { border-bottom: 0; }
.content-row:hover { background: var(--surface-2); }
.content-status-bar {
  align-self: stretch; width: 4px; border-radius: 4px; margin: 0 auto;
}
.content-row.ideation .content-status-bar { background: var(--text-faint); }
.content-row.drafting .content-status-bar { background: var(--info); }
.content-row.review .content-status-bar {
  background: var(--kudos);
  box-shadow: 0 0 10px rgba(168,85,247,0.4);
}
.content-row.approved .content-status-bar { background: var(--ok); }
.content-row.scheduled .content-status-bar { background: var(--warn); }
.content-row-body { min-width: 0; }
.content-row-title {
  font-size: var(--t-md); font-weight: 600;
  color: var(--text); line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-bottom: 4px;
}
.content-row-meta {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-xs); color: var(--text-dim);
  flex-wrap: wrap;
}
.content-row-meta b { color: var(--text-soft); font-weight: 600; }
.content-row-platforms { display: flex; gap: 2px; flex-shrink: 0; }
.content-row-platforms .mk-pf { width: 18px; height: 18px; }
.content-row-platforms .mk-pf svg { width: 10px; height: 10px; }
.content-row-due {
  font-size: var(--t-xs); font-weight: 600;
  color: var(--text-soft);
  font-feature-settings: 'tnum';
  min-width: 70px; text-align: right;
}
.content-row-due.soon { color: var(--warn); }
.content-row-due.overdue { color: var(--err); }
.content-row-owner {
  width: 24px; height: 24px; border-radius: 50%;
  color: #fff; font-weight: 600; font-size: 10px;
  display: grid; place-items: center; flex-shrink: 0;
  border: 1px solid var(--border-strong);
}
.content-row-approval-chip {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 10px; font-weight: 700;
  color: var(--ok);
  padding: 2px 6px;
  background: var(--ok-bg);
  border-radius: var(--r-pill);
}
.content-row-approval-chip.warn { color: var(--warn); background: var(--warn-bg); }

/* ============== PIPELINE: AWAITING APPROVAL CARD ============== */
.approve-row {
  padding: var(--s-3) var(--s-4);
  display: flex; flex-direction: column; gap: 6px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 120ms var(--ease);
  position: relative;
}
.approve-row:last-child { border-bottom: 0; }
.approve-row:hover { background: var(--surface-2); }
.approve-row::before {
  content: ''; position: absolute;
  left: 0; top: 12px; bottom: 12px; width: 3px;
  background: var(--kudos);
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(168,85,247,0.3);
}
.approve-row-top {
  display: flex; align-items: center; gap: 6px;
}
.approve-row-title {
  font-size: var(--t-sm); font-weight: 600;
  color: var(--text); line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2;
  -webkit-box-orient: vertical; overflow: hidden;
}
.approve-row-meta {
  font-size: var(--t-xs); color: var(--text-dim);
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
}
.approve-row-actions {
  display: flex; gap: 6px; margin-top: 4px;
}
.approve-quick {
  flex: 1; padding: 6px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--grad-success); border: 0;
  color: #fff; font-weight: 700; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  box-shadow: 0 2px 8px rgba(45,212,167,0.25);
}
.approve-quick:hover {
  box-shadow: 0 4px 14px rgba(45,212,167,0.45);
  transform: translateY(-1px);
}
.approve-quick.approved {
  background: var(--ok-bg); color: var(--ok);
  box-shadow: none; pointer-events: none;
}
.approve-preview {
  padding: 6px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border-strong);
  color: var(--text-soft); cursor: pointer;
  font-weight: 500;
}
.approver-avatars {
  display: flex; align-items: center; gap: 0;
}
.approver-avatars .av {
  width: 18px; height: 18px; border-radius: 50%;
  color: #fff; font-weight: 600; font-size: 8px;
  display: grid; place-items: center;
  border: 2px solid var(--surface);
  margin-left: -4px;
}
.approver-avatars .av:first-child { margin-left: 0; }
.approver-avatars .av.pending {
  background: var(--surface-3); color: var(--text-dim);
  border-style: dashed; border-width: 1px;
}

/* ============== CALENDAR ============== */
.cal-wrap {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
}
.cal-head {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.cal-month {
  font-size: var(--t-lg); font-weight: 700; color: var(--text);
  letter-spacing: -0.01em;
}
.cal-nav-btn {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
}
.cal-today-btn {
  padding: 6px 12px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer; font-weight: 500;
}
.cal-weekdays {
  display: grid; grid-template-columns: repeat(7, 1fr);
  border-bottom: 1px solid var(--border);
}
.cal-weekday {
  padding: 10px var(--s-3);
  font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; font-weight: 700;
  color: var(--text-dim); text-align: center;
  border-right: 1px solid var(--border);
}
.cal-weekday:last-child { border-right: 0; }
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  grid-auto-rows: 130px;
}
.cal-day {
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 8px;
  display: flex; flex-direction: column; gap: 4px;
  position: relative;
  transition: background 120ms var(--ease);
  cursor: pointer;
  overflow: hidden;
  min-height: 0;
}
.cal-day:nth-child(7n) { border-right: 0; }
.cal-day:hover { background: var(--surface-2); }
.cal-day.other-month { background: var(--bg-soft); }
.cal-day.other-month .cal-day-num { color: var(--text-faint); }
.cal-day.today { background: var(--info-bg); }
.cal-day.today .cal-day-num { color: var(--info); font-weight: 700; }
.cal-day-num {
  font-size: var(--t-sm); font-weight: 600; color: var(--text-soft);
  font-feature-settings: 'tnum';
}
.cal-day-num.weekend { color: var(--text-dim); }
.cal-add-btn {
  position: absolute; top: 6px; right: 6px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--grad-amber); color: #fff;
  border: 0; cursor: pointer;
  display: grid; place-items: center;
  opacity: 0; transform: scale(0.7);
  transition: all 180ms var(--ease);
  box-shadow: 0 2px 8px rgba(74,139,212,0.4);
  z-index: 2;
}
.cal-day:hover .cal-add-btn { opacity: 1; transform: scale(1); }
.cal-event {
  display: flex; align-items: center; gap: 4px;
  padding: 3px 6px;
  border-radius: var(--r-xs);
  font-size: 10px; font-weight: 600;
  color: var(--text);
  background: var(--info-bg);
  cursor: pointer;
  border-left: 2px solid var(--info);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: all 120ms var(--ease);
}
.cal-event:hover { transform: translateX(2px); }
.cal-event.email { background: var(--info-bg); border-left-color: var(--info); }
.cal-event.social { background: var(--love-bg); border-left-color: var(--love); }
.cal-event.blog { background: var(--ok-bg); border-left-color: var(--ok); }
.cal-event-time { font-size: 9px; color: var(--text-dim); font-weight: 500; }
.cal-event-title { font-size: 10px; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.cal-event-pfs { display: flex; gap: 1px; flex-shrink: 0; }
.cal-event-pfs .mk-pf { width: 12px; height: 12px; }
.cal-event-pfs .mk-pf svg { width: 7px; height: 7px; }
.cal-more {
  font-size: 9px; color: var(--text-dim);
  padding: 2px 6px;
  cursor: pointer; font-weight: 600;
  letter-spacing: 0.03em;
}
.cal-filters {
  display: flex; align-items: center; gap: var(--s-2);
  margin-left: auto;
  flex-wrap: wrap;
}
.cal-filter-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 10px; font-size: var(--t-xs);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-pill);
  color: var(--text-soft); cursor: pointer; font-weight: 500;
}
.cal-filter-chip.on { background: var(--info-bg); color: var(--info); border-color: var(--info); }

/* ============== CAMPAIGNS ============== */
.camp-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 0; overflow: hidden;
  transition: all 200ms var(--ease);
  cursor: pointer;
}
.camp-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}
.camp-card.active { border-color: rgba(45,212,167,0.4); }
.camp-card-head {
  padding: var(--s-4) var(--s-5);
  display: flex; align-items: flex-start; gap: var(--s-3);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.camp-status {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 3px 8px; border-radius: var(--r-pill);
}
.camp-status.live { background: var(--ok-bg); color: var(--ok); }
.camp-status.live::before {
  content:''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok); box-shadow: 0 0 6px var(--ok);
  animation: camp-pulseDot 1.6s ease-in-out infinite;
}
@keyframes camp-pulseDot { 50% { opacity: .5; } }
.camp-status.planning { background: var(--info-bg); color: var(--info); }
.camp-status.scheduled { background: var(--warn-bg); color: var(--warn); }
.camp-status.completed { background: var(--surface-3); color: var(--text-dim); }
.camp-info { flex: 1; min-width: 0; }
.camp-name {
  font-size: var(--t-lg); font-weight: 700;
  color: var(--text); letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.camp-desc { font-size: var(--t-sm); color: var(--text-dim); line-height: 1.5; }
.camp-dates {
  font-size: var(--t-xs); color: var(--text-faint);
  margin-top: 8px;
  display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap;
}
.camp-progress {
  display: flex; flex-direction: column; gap: 4px;
  min-width: 160px;
}
.camp-progress-label {
  font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--text-dim); font-weight: 700;
}
.camp-progress-bar {
  height: 6px; background: var(--surface-3);
  border-radius: var(--r-pill); overflow: hidden;
}
.camp-progress-fill {
  height: 100%; border-radius: var(--r-pill);
  background: var(--grad-success);
}
.camp-progress-meta { font-size: var(--t-xs); color: var(--text-soft); }
.camp-progress-meta b { color: var(--text); font-weight: 600; }
.camp-body {
  padding: var(--s-4) var(--s-5);
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: var(--s-4);
}
.camp-stat-label {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--text-dim);
}
.camp-stat-value {
  font-size: var(--t-xl); font-weight: 700;
  color: var(--text); letter-spacing: -0.02em;
  font-feature-settings: 'tnum';
  margin-top: 4px;
}
.camp-stat-meta { font-size: var(--t-xs); color: var(--text-dim); margin-top: 4px; }

.camp-channels {
  padding: var(--s-3) var(--s-5);
  display: flex; align-items: center; gap: var(--s-3);
  border-top: 1px solid var(--border);
  background: var(--surface-2);
  flex-wrap: wrap;
}
.camp-pieces {
  display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap;
}
.camp-piece {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-pill);
  font-size: var(--t-xs); color: var(--text-soft);
  font-weight: 500;
}
.camp-piece-count {
  color: var(--text); font-weight: 700;
  font-feature-settings: 'tnum';
}

.camp-toggle-content {
  display: flex; align-items: center; gap: var(--s-2);
  padding: 10px var(--s-5);
  width: 100%;
  background: var(--surface-2);
  border: 0; border-top: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  font-size: var(--t-xs); font-weight: 600;
}
.camp-toggle-content:hover { background: var(--surface-3); color: var(--text); }
.camp-toggle-content svg { transition: transform 200ms var(--ease); }
.camp-card.expanded .camp-toggle-content svg { transform: rotate(180deg); }
.camp-content-list {
  display: none;
  border-top: 1px solid var(--border);
}
.camp-card.expanded .camp-content-list { display: block; }
.camp-content-row {
  display: grid;
  grid-template-columns: 4px 28px 1fr auto auto auto;
  gap: var(--s-3); align-items: center;
  padding: 10px var(--s-5);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
}
.camp-content-row:last-child { border-bottom: 0; }
.camp-content-row:hover { background: var(--surface-2); }
.camp-content-bar {
  align-self: stretch; width: 4px; border-radius: 4px; margin: 0 auto;
}
.camp-content-row.draft .camp-content-bar { background: var(--info); }
.camp-content-row.review .camp-content-bar {
  background: var(--kudos);
  box-shadow: 0 0 8px rgba(168,85,247,0.4);
}
.camp-content-row.approved .camp-content-bar { background: var(--ok); }
.camp-content-row.scheduled .camp-content-bar { background: var(--warn); }
.camp-content-row.published .camp-content-bar { background: var(--love); }
.camp-add-content {
  display: flex; align-items: center; justify-content: center;
  gap: 6px;
  padding: 12px var(--s-5);
  background: transparent; border: 0;
  border-top: 1px dashed var(--border-strong);
  color: var(--text-dim);
  cursor: pointer;
  font-size: var(--t-xs); font-weight: 600;
  width: 100%;
}
.camp-add-content:hover { color: var(--info); background: var(--surface-2); }

/* ============== SLIDE-OUT CONTENT PANEL (see SLIDE-OUT-PANEL.md) ============== */
.mk-panel-backdrop {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity 200ms var(--ease);
}
.mk-panel-backdrop.open { opacity: 1; pointer-events: auto; }
.mk-create-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(680px, 100vw); z-index: 101;
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  transform: translateX(110%);
  transition: transform 320ms var(--ease-out);
  display: flex; flex-direction: column; overflow: hidden;
}
.mk-create-panel.open { transform: translateX(0); }

/* Header (simplified, consistent across pages) */
.mk-cp-head {
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: var(--s-3);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.mk-cp-badge {
  width: 36px; height: 36px; border-radius: var(--r-sm);
  display: grid; place-items: center; flex-shrink: 0;
  transition: all 200ms var(--ease);
}
.mk-cp-badge.social { background: var(--love-bg); color: var(--love); }
.mk-cp-badge.email { background: var(--info-bg); color: var(--info); }
.mk-cp-badge.blog { background: var(--ok-bg); color: var(--ok); }
.mk-cp-badge.neutral { background: var(--grad-amber); color: #fff; }
.mk-cp-title-block { flex: 1; min-width: 0; }
.mk-cp-title {
  font-size: var(--t-md); font-weight: 600; color: var(--text);
  line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mk-cp-context-row {
  display: flex; align-items: center; gap: var(--s-2);
  margin-top: 3px; flex-wrap: wrap;
}
.mk-cp-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 2px 7px; border-radius: var(--r-pill);
  color: var(--kudos);
  background: var(--kudos-bg);
}
.mk-cp-tag.new { color: var(--ok); background: var(--ok-bg); }
.mk-cp-tag.ai { color: var(--kudos); background: var(--kudos-bg); }
.mk-cp-tag.editing { color: var(--info); background: var(--info-bg); }
.mk-cp-tag.status-draft { color: var(--info); background: var(--info-bg); }
.mk-cp-tag.status-review { color: var(--kudos); background: var(--kudos-bg); }
.mk-cp-tag.status-approved { color: var(--ok); background: var(--ok-bg); }
.mk-cp-tag.status-scheduled { color: var(--warn); background: var(--warn-bg); }
.mk-cp-context-meta { font-size: var(--t-xs); color: var(--text-dim); }
.mk-cp-context-meta b { color: var(--text-soft); font-weight: 600; }
.mk-cp-close {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
}

/* Body */
.mk-cp-body {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-3);
}
.mk-cp-input, .mk-cp-textarea, .mk-cp-select {
  width: 100%; padding: 9px var(--s-3);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
  font-family: inherit;
  transition: all 150ms var(--ease);
}
.mk-cp-input:focus, .mk-cp-textarea:focus, .mk-cp-select:focus {
  outline: none; border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(74,139,212,0.15);
}
.mk-cp-title-input {
  font-size: var(--t-md); font-weight: 600;
  padding: 10px var(--s-3) !important;
}

/* Channel toggle */
.mk-cp-channel-toggle {
  display: flex; gap: 4px;
  background: var(--bg-soft); padding: 4px;
  border-radius: var(--r-sm);
}
.mk-cp-channel-toggle button {
  flex: 1; padding: 8px var(--s-3);
  background: transparent; border: 0;
  color: var(--text-dim); cursor: pointer;
  border-radius: var(--r-xs);
  font-weight: 600; font-size: var(--t-sm);
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
}
.mk-cp-channel-toggle button.on {
  background: var(--surface); color: var(--text);
  box-shadow: var(--shadow-sm);
}

/* Platform grid */
.mk-cp-platform-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: var(--s-2);
}
.mk-cp-platform {
  display: flex; align-items: center; gap: 8px;
  padding: 8px var(--s-3);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer; font-size: var(--t-sm);
}
.mk-cp-platform.on { background: var(--info-bg); border-color: var(--info); }
.mk-cp-platform input { display: none; }
.mk-cp-platform .name { color: var(--text); font-weight: 500; }

/* Compact meta row (no labels) */
.mk-cp-meta-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.9fr 1.1fr;
  gap: var(--s-2);
}
.mk-cp-meta-row .mk-cp-input, .mk-cp-meta-row .mk-cp-select {
  padding: 8px 10px; font-size: var(--t-sm);
}

/* Rich text editor */
.mk-cp-rte {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-soft);
  overflow: hidden;
  transition: all 150ms var(--ease);
}
.mk-cp-rte:focus-within {
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(74,139,212,0.15);
}
.mk-cp-rte-toolbar {
  display: flex; align-items: center; gap: 1px;
  padding: 5px 6px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.mk-cp-rte-tool {
  width: 28px; height: 28px;
  border-radius: var(--r-xs);
  background: transparent; border: 0;
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
}
.mk-cp-rte-tool:hover { background: var(--surface-2); color: var(--text); }
.mk-cp-rte-divider {
  width: 1px; height: 18px; background: var(--border); margin: 0 4px;
}
.mk-cp-rte-format {
  background: transparent; border: 0;
  color: var(--text-soft); cursor: pointer;
  font-size: var(--t-xs); font-weight: 500;
  padding: 0 8px; height: 28px; border-radius: var(--r-xs);
}
.mk-cp-rte-content {
  padding: var(--s-3) var(--s-4);
  min-height: 220px; max-height: 380px;
  color: var(--text); font-size: var(--t-md);
  line-height: 1.6; outline: none;
  overflow-y: auto;
}
.mk-cp-rte-content p { margin: 0 0 var(--s-2); }
.mk-cp-rte-content b, .mk-cp-rte-content strong {
  color: var(--text); font-weight: 700;
}
.mk-cp-rte-content a { color: var(--amber); }

/* Simple content area (social) */
.mk-cp-content-simple {
  width: 100%;
  min-height: 220px; max-height: 380px;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-soft); border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text); font-size: var(--t-md);
  line-height: 1.6; font-family: inherit;
  resize: vertical;
}
.mk-cp-content-simple:focus {
  outline: none; border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(74,139,212,0.15);
}

/* AI generation bar */
.mk-cp-ai-bar {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  background: linear-gradient(90deg, var(--info-bg), transparent);
  border: 1px solid rgba(74,139,212,0.3);
  border-radius: var(--r-sm);
  font-size: var(--t-xs); color: var(--text-soft);
}
.mk-cp-ai-bar svg { color: var(--info); flex-shrink: 0; }
.mk-cp-ai-actions { margin-left: auto; display: flex; gap: 6px; }
.mk-cp-ai-actions button {
  padding: 4px 10px; font-size: var(--t-xs);
  border-radius: var(--r-sm);
  background: var(--surface); border: 1px solid var(--border-strong);
  color: var(--text); cursor: pointer; font-weight: 600;
}

/* AI image gen panel */
.mk-cp-aigen {
  margin-top: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: linear-gradient(135deg, rgba(168,85,247,0.10), rgba(74,139,212,0.06));
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: var(--r-md);
  display: flex; flex-direction: column; gap: var(--s-2);
}

/* AI reason card (when from AI suggestion) */
.mk-cp-reason {
  display: flex; gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: linear-gradient(135deg, rgba(168,85,247,0.10), rgba(74,139,212,0.06));
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: var(--r-md);
}
.mk-cp-reason-icon {
  width: 28px; height: 28px; border-radius: var(--r-sm);
  background: var(--grad-kudos); color: #fff;
  display: grid; place-items: center; flex-shrink: 0;
}
.mk-cp-reason-body p {
  margin: 0; font-size: var(--t-sm); color: var(--text-soft); line-height: 1.5;
}
.mk-cp-reason-body p b { color: var(--text); font-weight: 600; }

/* Footer */
.mk-cp-foot {
  border-top: 1px solid var(--border);
  padding: var(--s-4) var(--s-5);
  background: var(--surface);
  display: flex; align-items: center; gap: var(--s-2);
}
.mk-cp-save-draft {
  padding: 9px var(--s-4); border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border-strong);
  color: var(--text); cursor: pointer; font-weight: 500;
}
.mk-cp-schedule {
  padding: 9px var(--s-4); border-radius: var(--r-sm);
  background: var(--grad-amber); border: 0; color: #fff;
  font-weight: 600; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 2px 12px rgba(74,139,212,0.25);
}

/* Channel-aware visibility (the magic that switches editor type) */
.show-for-social, .show-for-email, .show-for-blog { display: none; }
.mk-create-panel.channel-social .show-for-social { display: block; }
.mk-create-panel.channel-email .show-for-email { display: block; }
.mk-create-panel.channel-blog .show-for-blog { display: block; }

/* ============== PIPELINE PREVIEW/APPROVE PANEL ============== */
.mk-preview-panel {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(680px, 100vw); z-index: 101;
  background: var(--bg);
  border-left: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  transform: translateX(110%);
  transition: transform 320ms var(--ease-out);
  display: flex; flex-direction: column; overflow: hidden;
}
.mk-preview-panel.open { transform: translateX(0); }
.mk-pp-head {
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: var(--s-3);
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.mk-pp-channel-ico {
  width: 36px; height: 36px; border-radius: var(--r-sm);
  display: grid; place-items: center; flex-shrink: 0;
}
.mk-pp-channel-ico.social { background: var(--love-bg); color: var(--love); }
.mk-pp-channel-ico.email { background: var(--info-bg); color: var(--info); }
.mk-pp-channel-ico.blog { background: var(--ok-bg); color: var(--ok); }
.mk-pp-title-block { flex: 1; min-width: 0; }
.mk-pp-title {
  font-size: var(--t-md); font-weight: 600; color: var(--text);
  line-height: 1.3;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mk-pp-context-row {
  display: flex; align-items: center; gap: var(--s-2);
  margin-top: 3px; flex-wrap: wrap;
}
.mk-pp-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase;
  padding: 2px 7px; border-radius: var(--r-pill);
}
.mk-pp-tag.draft { color: var(--info); background: var(--info-bg); }
.mk-pp-tag.review { color: var(--kudos); background: var(--kudos-bg); }
.mk-pp-tag.approved { color: var(--ok); background: var(--ok-bg); }
.mk-pp-tag.scheduled { color: var(--warn); background: var(--warn-bg); }
.mk-pp-tag.published { color: var(--love); background: var(--love-bg); }
.mk-pp-context-meta { font-size: var(--t-xs); color: var(--text-dim); }
.mk-pp-context-meta b { color: var(--text-soft); font-weight: 600; }
.mk-pp-close {
  width: 32px; height: 32px; border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border);
  color: var(--text-soft); cursor: pointer;
  display: grid; place-items: center;
}
.mk-pp-actions {
  display: flex; align-items: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.mk-pp-approve-btn {
  padding: 9px var(--s-4); border-radius: var(--r-sm);
  background: var(--grad-success); border: 0;
  color: #fff; font-weight: 700; font-size: var(--t-sm);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  box-shadow: 0 2px 12px rgba(45,212,167,0.3);
}
.mk-pp-approve-btn.approved {
  background: var(--ok-bg); color: var(--ok);
  box-shadow: none; pointer-events: none;
}
.mk-pp-action-btn {
  padding: 9px var(--s-4); border-radius: var(--r-sm);
  background: transparent; border: 1px solid var(--border-strong);
  color: var(--text); cursor: pointer; font-weight: 500; font-size: var(--t-sm);
  display: inline-flex; align-items: center; gap: 6px;
}
.mk-pp-action-btn.primary {
  background: var(--grad-amber); border-color: transparent; color: #fff;
  font-weight: 600;
}
.mk-pp-body {
  flex: 1; min-height: 0; overflow-y: auto;
  padding: var(--s-5);
  display: flex; flex-direction: column; gap: var(--s-5);
}
.mk-pp-approvals {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-4) var(--s-5);
}
.mk-pp-approval-list { display: flex; flex-direction: column; gap: 8px; }
.mk-pp-approval-row {
  display: flex; align-items: center; gap: var(--s-2);
  font-size: var(--t-sm);
}
.mk-pp-approval-row .av {
  width: 24px; height: 24px; border-radius: 50%;
  color: #fff; font-weight: 600; font-size: 10px;
  display: grid; place-items: center;
  border: 1px solid var(--border-strong);
}
.mk-pp-approval-row .av.pending {
  background: var(--surface-3); color: var(--text-dim);
  border: 1px dashed var(--border-strong);
}
.mk-pp-approval-row .name { color: var(--text); font-weight: 500; flex: 1; }
.mk-pp-approval-row .when { font-size: var(--t-xs); color: var(--text-dim); }

/* Rendered content preview (email mockup) */
.preview-email {
  background: #fff;
  color: #1f2937;
  border-radius: 8px;
  padding: 24px;
  font-family: -apple-system, sans-serif;
  max-height: 400px;
  overflow-y: auto;
}
.preview-email .subject { font-size: 18px; font-weight: 700; color: #0f1e3c; margin-bottom: 4px; }
.preview-email .from { font-size: 12px; color: #5b6b8a; margin-bottom: 20px; }
.preview-email .body { font-size: 14px; line-height: 1.6; color: #2a3a5c; }
.preview-email .body p { margin: 0 0 12px; }
.preview-email .cta {
  display: inline-block;
  background: linear-gradient(135deg, #2563eb, #1e40af);
  color: #fff !important;
  padding: 10px 20px; border-radius: 6px;
  font-weight: 600; text-decoration: none;
  margin: 12px 0;
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1100px) {
  .camp-body { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 820px) {
  .mk-cp-meta-row { grid-template-columns: 1fr 1fr; }
  .mk-create-panel, .mk-preview-panel { width: 100vw; }
  .cal-day { min-height: 80px; }
  .camp-body { grid-template-columns: 1fr; }
  .camp-content-row { grid-template-columns: 4px 24px 1fr auto auto; gap: var(--s-2); }
}

/* ============== MARKETING ACTION BAR ============== */
.mk-cp-action-bar {
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--border);
  display: flex;
  gap: var(--s-2);
  align-items: center;
  background: linear-gradient(180deg, var(--surface-2), transparent);
}
.mk-cp-action-bar .mk-cp-action-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 7px var(--s-3); border-radius: var(--r-sm);
  border: 1px solid var(--border-strong); background: var(--surface);
  color: var(--text); font-size: var(--t-sm); font-weight: 500;
  cursor: pointer; transition: all 150ms var(--ease);
}
.mk-cp-action-bar .mk-cp-action-btn:hover { background: var(--surface-2); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.mk-cp-action-bar .mk-cp-action-btn.approve { background: var(--grad-success); border-color: transparent; color: #fff; font-weight: 600; }
.mk-cp-action-bar .mk-cp-action-btn.approve:hover { box-shadow: var(--shadow-glow); }
.mk-cp-action-bar .mk-cp-action-btn.reject { border-color: rgba(239,93,117,0.3); color: var(--err); }
.mk-cp-action-bar .mk-cp-action-btn.reject:hover { background: var(--err-bg); }
.mk-cp-tag.status-rejected { background: var(--err-bg); color: var(--err); }
.mk-cp-tag.status-rejected::before { background: var(--err); }
