/* ============================================
   DREAM 100 DASHBOARD — Layout & Components
   ============================================ */

/* --- App Shell --- */
.app-shell {
  display: flex;
  min-height: 100vh;
  position: relative;
  z-index: 1;
}

/* --- Sidebar --- */
.sidebar {
  width: 220px;
  background: rgba(16, 18, 34, 0.97);
  border-right: 1px solid var(--border-main);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 3px; /* below data stream */
  left: 0;
  bottom: 0;
  z-index: 50;
  backdrop-filter: blur(12px);
}

.sidebar-brand {
  padding: 1.25rem 1rem;
  border-bottom: 1px solid var(--border-main);
}

.sidebar-brand h1 {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.06em;
  text-shadow: 0 0 15px rgba(0, 255, 247, 0.3);
}

.sidebar-brand p {
  font-size: 0.65rem;
  color: var(--text-dim);
  margin-top: 0.2rem;
}

.sidebar-nav {
  flex: 1;
  padding: 0.75rem 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.65rem 1rem;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
  border-left: 3px solid transparent;
  user-select: none;
}

.nav-item:hover {
  color: #e0e4f0;
  background: rgba(100, 100, 200, 0.1);
}

.nav-item.active {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.04);
  border-left-color: var(--glow-cyan);
}

.nav-item .nav-icon {
  font-size: 1rem;
  width: 1.2rem;
  text-align: center;
}

.sidebar-footer {
  padding: 1rem;
  border-top: 1px solid var(--border-main);
  font-size: 0.6rem;
  color: #556;
}

/* --- Main Content --- */
.main-content {
  flex: 1;
  margin-left: 220px;
  padding: 1.5rem 2rem 2rem;
  min-height: 100vh;
}

.tab-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border-main);
}

.tab-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.05em;
}

.tab-subtitle {
  font-size: 0.7rem;
  color: var(--text-body);
  margin-top: 0.15rem;
}

.tab-actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

/* --- Tab Panel (each tab content) --- */
.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

/* --- KPI Cards (Command Center) --- */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.kpi-card {
  background: var(--bg-card);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-main);
  border-radius: 0.75rem;
  padding: 1.1rem 1rem;
  transition: border-color 0.3s;
}

.kpi-card:hover { border-color: rgba(0, 255, 247, 0.25); box-shadow: 0 0 15px rgba(0, 255, 247, 0.06); }

.kpi-value {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--text-body);
  line-height: 1;
}

.kpi-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.7rem;
  color: var(--text-dim);
  margin-top: 0.35rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.kpi-change {
  font-size: 0.6rem;
  margin-top: 0.3rem;
}

/* --- Section Headers --- */
.section-header {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin: 1.5rem 0 0.75rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--border-main);
}

/* --- Person Grid (Dream 100) --- */
.person-grid-controls {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.filter-group {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.filter-label {
  font-size: 0.6rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.filter-select {
  background: var(--bg-card-solid);
  color: #c8c8d8;
  border: 1px solid var(--border-main);
  border-radius: 0.4rem;
  padding: 0.35rem 0.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  cursor: pointer;
  outline: none;
}

.filter-select:focus {
  border-color: var(--glow-cyan);
}

.person-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.75rem;
}

.person-card {
  background: var(--bg-card);
  backdrop-filter: blur(8px);
  border: 1px solid var(--border-main);
  border-radius: 0.75rem;
  padding: 1rem;
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  min-height: 180px;
}

.person-card:hover {
  border-color: rgba(0, 255, 247, 0.35);
  box-shadow: 0 0 25px rgba(0, 255, 247, 0.1);
  transform: translateY(-2px);
}

.person-card-top {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.person-avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1c2040 0%, #2a2f55 100%);
  border: 2px solid rgba(0, 255, 247, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--glow-cyan);
  flex-shrink: 0;
  overflow: hidden;
  box-shadow: 0 0 12px rgba(0, 255, 247, 0.08);
}

.person-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.person-info { flex: 1; min-width: 0; }

.person-name {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-body);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.person-platforms {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.3rem;
  flex-wrap: wrap;
}

.platform-chip {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 0.15rem 0.4rem;
  border-radius: 9999px;
  background: rgba(100, 100, 200, 0.08);
  border: 1px solid rgba(100, 100, 200, 0.15);
  color: var(--text-body);
}

.person-card-badges {
  position: absolute;
  top: 0.65rem;
  right: 0.65rem;
  display: flex;
  gap: 0.3rem;
}

.tier-badge, .warmth-badge {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.15rem 0.45rem;
  border-radius: 9999px;
}

.person-card-bio {
  font-size: 0.68rem;
  color: var(--text-body);
  line-height: 1.5;
  margin-top: 0.5rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  opacity: 0.85;
}

.person-card-stats {
  display: flex;
  gap: 1rem;
  margin-top: 0.65rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(100, 100, 200, 0.1);
}

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

.person-stat-value {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.85rem;
  color: var(--text-body);
}

.person-stat-label {
  font-size: 0.55rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* --- Dossier Slideout --- */
.dossier-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 99;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}

.dossier-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.dossier-panel {
  position: fixed;
  top: 3px;
  right: 0;
  bottom: 0;
  width: 560px;
  max-width: 90vw;
  background: rgba(14, 16, 32, 0.98);
  border-left: 1px solid var(--border-main);
  z-index: 100;
  transform: translateX(100%);
  transition: transform 0.3s ease;
  overflow-y: auto;
  backdrop-filter: blur(16px);
}

.dossier-panel.open {
  transform: translateX(0);
}

.dossier-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  z-index: 2;
}

.dossier-close:hover {
  border-color: var(--glow-red);
  color: var(--glow-red);
}

.dossier-header {
  padding: 1.25rem 1.25rem 1rem;
  border-bottom: 1px solid var(--border-main);
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.dossier-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--bg-card-solid);
  border: 2px solid var(--glow-cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--glow-cyan);
  flex-shrink: 0;
  overflow: hidden;
  box-shadow: 0 0 15px rgba(0, 255, 247, 0.15);
}

.dossier-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dossier-identity h2 {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-body);
}

.dossier-identity .dossier-badges {
  display: flex;
  gap: 0.4rem;
  margin-top: 0.35rem;
  flex-wrap: wrap;
}

.dossier-identity .dossier-location {
  font-size: 0.7rem;
  color: var(--text-dim);
  margin-top: 0.25rem;
}

/* Dossier sections */
.dossier-body {
  padding: 0.5rem 1.25rem 2rem;
}

.dossier-section {
  margin-top: 1.25rem;
}

.dossier-section-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 0.6rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid rgba(100, 100, 200, 0.08);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

.dossier-section-title .section-icon {
  font-size: 0.8rem;
}

.dossier-empty {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: rgba(138, 154, 180, 0.5);
  font-style: italic;
  padding: 0.75rem;
  background: rgba(100, 100, 200, 0.03);
  border: 1px dashed rgba(100, 100, 200, 0.1);
  border-radius: 0.5rem;
  text-align: center;
}

/* Profile list in dossier */
.dossier-profiles {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.dossier-profile-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.65rem;
  background: rgba(100, 100, 200, 0.04);
  border: 1px solid rgba(100, 100, 200, 0.08);
  border-radius: 0.5rem;
}

.dossier-profile-platform {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  min-width: 2rem;
  text-align: center;
}

.dossier-profile-username {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.8rem;
  color: var(--glow-cyan);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dossier-profile-followers {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: var(--text-body);
  white-space: nowrap;
}

.dossier-profile-scraped {
  font-size: 0.6rem;
  color: var(--text-dim);
  white-space: nowrap;
}

/* Bio section */
.dossier-bio {
  font-size: 0.8rem;
  color: var(--text-body);
  line-height: 1.6;
}

.dossier-credentials {
  margin-top: 0.4rem;
  font-size: 0.7rem;
  color: var(--glow-amber);
}

.dossier-website {
  margin-top: 0.25rem;
}

.dossier-website a {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
}

/* Intel tags/pills */
.intel-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.intel-pill {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  padding: 0.2rem 0.5rem;
  border-radius: 9999px;
  background: rgba(0, 255, 247, 0.06);
  border: 1px solid rgba(0, 255, 247, 0.15);
  color: var(--text-body);
}

/* Intel key-value rows */
.intel-rows {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.intel-row {
  display: flex;
  gap: 0.5rem;
  font-size: 0.75rem;
  padding: 0.3rem 0;
}

.intel-row-key {
  color: var(--text-dim);
  min-width: 100px;
  flex-shrink: 0;
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.intel-row-value {
  color: var(--text-body);
  flex: 1;
}

/* SWOT grid */
.swot-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

.swot-box {
  background: rgba(100, 100, 200, 0.04);
  border: 1px solid rgba(100, 100, 200, 0.1);
  border-radius: 0.5rem;
  padding: 0.6rem;
}

.swot-box-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 0.3rem;
}

.swot-box ul {
  list-style: none;
  padding: 0;
}

.swot-box li {
  font-size: 0.7rem;
  color: var(--text-body);
  padding: 0.15rem 0;
  padding-left: 0.6rem;
  position: relative;
}

.swot-box li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.45rem;
  width: 4px;
  height: 4px;
  border-radius: 50%;
}

.swot-strengths .swot-box-title { color: var(--glow-green); }
.swot-strengths li::before { background: var(--glow-green); }
.swot-weaknesses .swot-box-title { color: var(--glow-red); }
.swot-weaknesses li::before { background: var(--glow-red); }
.swot-opportunities .swot-box-title { color: var(--glow-cyan); }
.swot-opportunities li::before { background: var(--glow-cyan); }
.swot-threats .swot-box-title { color: var(--glow-amber); }
.swot-threats li::before { background: var(--glow-amber); }

/* Warmth tracker */
.warmth-tracker {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.warmth-current {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.warmth-level-badge {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  padding: 0.3rem 0.75rem;
  border-radius: 9999px;
}

.warmth-update-form {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  align-items: center;
}

.warmth-select {
  background: var(--bg-card-solid);
  color: #c8c8d8;
  border: 1px solid var(--border-main);
  border-radius: 0.4rem;
  padding: 0.35rem 0.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  cursor: pointer;
  outline: none;
}

.warmth-note-input {
  background: var(--bg-card-solid);
  color: #c8c8d8;
  border: 1px solid var(--border-main);
  border-radius: 0.4rem;
  padding: 0.35rem 0.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  flex: 1;
  min-width: 120px;
  outline: none;
}

.warmth-note-input:focus,
.warmth-select:focus {
  border-color: var(--glow-cyan);
}

.warmth-btn {
  background: rgba(0, 255, 247, 0.1);
  color: var(--glow-cyan);
  border: 1px solid rgba(0, 255, 247, 0.25);
  border-radius: 0.4rem;
  padding: 0.35rem 0.65rem;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: all 0.2s;
}

.warmth-btn:hover {
  background: rgba(0, 255, 247, 0.18);
  box-shadow: 0 0 10px rgba(0, 255, 247, 0.15);
}

.warmth-history {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  max-height: 150px;
  overflow-y: auto;
}

.warmth-history-entry {
  display: flex;
  gap: 0.5rem;
  font-size: 0.65rem;
  padding: 0.25rem 0;
}

.warmth-history-date {
  color: var(--text-dim);
  white-space: nowrap;
  min-width: 5.5rem;
  font-family: 'Share Tech Mono', monospace;
}

.warmth-history-action {
  color: var(--text-body);
}

/* --- Kanban (Content Lab) --- */
.kanban-wrapper {
  display: flex;
  gap: 0.75rem;
  overflow-x: auto;
  padding-bottom: 1rem;
}

.kanban-column {
  min-width: 220px;
  flex: 1;
  background: rgba(28, 30, 48, 0.3);
  border: 1px solid var(--border-main);
  border-radius: 0.75rem;
  padding: 0.75rem;
}

.kanban-column-header {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--border-main);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.kanban-count {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: var(--glow-cyan);
}

.kanban-cards {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-height: 60px;
}

.kanban-card {
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.65rem;
  cursor: pointer;
  transition: border-color 0.2s;
}

.kanban-card:hover {
  border-color: rgba(0, 255, 247, 0.2);
}

.kanban-card-preview {
  font-size: 0.7rem;
  color: var(--text-body);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.kanban-card-meta {
  display: flex;
  gap: 0.4rem;
  margin-top: 0.4rem;
  align-items: center;
}

.kanban-empty {
  font-size: 0.65rem;
  color: rgba(138, 154, 180, 0.4);
  text-align: center;
  padding: 1rem 0.5rem;
  font-style: italic;
}

/* --- Analytics Tables --- */
.analytics-table-wrap {
  overflow-x: auto;
  margin-top: 0.5rem;
}

.analytics-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}

.analytics-table th {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
  text-align: left;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--border-main);
}

.analytics-table td {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid rgba(100, 100, 200, 0.06);
  color: var(--text-body);
}

.analytics-table tr:hover td {
  background: rgba(100, 100, 200, 0.04);
}

/* Bar chart (CSS-only) */
.bar-chart {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.bar-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.bar-label {
  font-size: 0.65rem;
  color: var(--text-dim);
  min-width: 80px;
  text-align: right;
}

.bar-track {
  flex: 1;
  height: 18px;
  background: rgba(100, 100, 200, 0.06);
  border-radius: 3px;
  overflow: hidden;
}

.bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
  display: flex;
  align-items: center;
  padding: 0 0.4rem;
  font-size: 0.6rem;
  font-family: 'Share Tech Mono', monospace;
  color: #fff;
  white-space: nowrap;
}

.bar-fill-cyan { background: linear-gradient(90deg, rgba(0,255,247,0.3), rgba(0,255,247,0.6)); }
.bar-fill-green { background: linear-gradient(90deg, rgba(57,255,20,0.3), rgba(57,255,20,0.6)); }
.bar-fill-amber { background: linear-gradient(90deg, rgba(255,184,0,0.3), rgba(255,184,0,0.6)); }
.bar-fill-magenta { background: linear-gradient(90deg, rgba(255,44,241,0.3), rgba(255,44,241,0.6)); }
.bar-fill-purple { background: linear-gradient(90deg, rgba(180,74,255,0.3), rgba(180,74,255,0.6)); }

/* --- System Health --- */
.health-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 0.5rem;
}

.health-card {
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.health-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.health-dot.green {
  background: var(--glow-green);
  box-shadow: 0 0 8px rgba(57, 255, 20, 0.4);
}

.health-dot.amber {
  background: var(--glow-amber);
  box-shadow: 0 0 8px rgba(255, 184, 0, 0.4);
}

.health-dot.red {
  background: var(--glow-red);
  box-shadow: 0 0 8px rgba(255, 51, 51, 0.4);
}

.health-dot.grey {
  background: #445;
}

.health-info { flex: 1; }

.health-name {
  font-size: 0.75rem;
  color: var(--text-body);
}

.health-detail {
  font-size: 0.6rem;
  color: var(--text-dim);
  margin-top: 0.1rem;
}

/* --- Activity Feed --- */
.activity-feed {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.activity-item {
  display: flex;
  gap: 0.6rem;
  padding: 0.4rem 0.5rem;
  font-size: 0.7rem;
  border-left: 2px solid var(--border-main);
}

.activity-time {
  font-family: 'Share Tech Mono', monospace;
  color: var(--text-dim);
  white-space: nowrap;
  min-width: 4.5rem;
  font-size: 0.65rem;
}

.activity-text {
  color: var(--text-body);
}

/* --- Utility --- */
.text-center { text-align: center; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }

/* --- Responsive --- */
@media (max-width: 900px) {
  .sidebar { width: 56px; }
  .sidebar-brand h1, .sidebar-brand p, .nav-item span, .sidebar-footer { display: none; }
  .nav-item { justify-content: center; padding: 0.75rem; border-left: none; }
  .main-content { margin-left: 56px; padding: 1rem; }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .dossier-panel { width: 100vw; max-width: 100vw; }
}

@media (max-width: 600px) {
  .person-grid { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: 1fr 1fr; }
}


/* ============================================
   CONTENT LAB — Trend Engine UI
   ============================================ */

/* --- Stats Line --- */
.cl-stats-line {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 0.75rem;
  margin: 0.75rem 0;
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: var(--text-dim);
  flex-wrap: wrap;
}

.cl-stat-item {
  font-weight: 600;
  letter-spacing: 0.06em;
}

.cl-stat-hot { color: var(--glow-red); }
.cl-stat-warm { color: var(--glow-amber); }
.cl-stat-cold { color: var(--glow-blue); }
.cl-stat-saved { color: var(--glow-green); }
.cl-stat-used { color: var(--glow-magenta); }

.cl-stat-sep {
  color: rgba(100, 100, 200, 0.25);
  font-size: 0.65rem;
}

/* --- Trend Table Enhancements --- */
.cl-trend-row:hover td {
  background: rgba(0, 255, 247, 0.04);
}

.cl-trend-active td {
  background: rgba(0, 255, 247, 0.08) !important;
  border-color: rgba(0, 255, 247, 0.15);
}

.cl-trend-pillar {
  font-weight: 600;
  color: var(--text-body);
}

.cl-trend-person {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.7rem;
}

.cl-trend-tag {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.12rem 0.45rem;
  border-radius: 9999px;
  display: inline-block;
}

.cl-trend-rising {
  color: var(--glow-green);
  background: rgba(57, 255, 20, 0.08);
  border: 1px solid rgba(57, 255, 20, 0.25);
}

.cl-trend-stable {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  border: 1px solid rgba(0, 255, 247, 0.2);
}

.cl-trend-declining {
  color: var(--glow-red);
  background: rgba(255, 51, 51, 0.08);
  border: 1px solid rgba(255, 51, 51, 0.25);
}

.cl-trend-new {
  color: var(--glow-magenta);
  background: rgba(255, 44, 241, 0.08);
  border: 1px solid rgba(255, 44, 241, 0.25);
}

.cl-trend-fatigued {
  color: var(--text-dim);
  background: rgba(100, 100, 200, 0.06);
  border: 1px solid rgba(100, 100, 200, 0.15);
}

/* --- Idea Cards --- */
.cl-ideas-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
  overflow: hidden;
  max-width: 100%;
}

.cl-idea-card {
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.65rem;
  transition: border-color 0.2s, box-shadow 0.2s;
  overflow: hidden;
}

.cl-idea-card:hover {
  border-color: rgba(0, 255, 247, 0.2);
}

.cl-idea-expanded {
  border-color: rgba(0, 255, 247, 0.3);
  box-shadow: 0 0 20px rgba(0, 255, 247, 0.06);
}

.cl-idea-header {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.85rem 1rem;
  cursor: pointer;
  overflow: hidden;
}

.cl-idea-row1 {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.cl-idea-row2 {
  font-size: 0.92rem;
  font-weight: 500;
  color: #e0e4f0;
  line-height: 1.45;
  padding-left: 0.1rem;
}

.cl-idea-row3 {
  display: flex;
  gap: 0.3rem;
  flex-wrap: wrap;
  padding-left: 0.1rem;
}

.cl-signal-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.cl-signal-label {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.cl-signal-hot-text { color: var(--glow-red); }
.cl-signal-warm-text { color: var(--glow-amber); }
.cl-signal-cold-text { color: var(--glow-blue); }
.cl-signal-no_data-text { color: var(--text-dim); }

.cl-signal-hot {
  background: var(--glow-red);
  box-shadow: 0 0 8px rgba(255, 51, 51, 0.5);
  animation: pulseDot 1.5s ease-in-out infinite;
}

.cl-signal-warm {
  background: var(--glow-amber);
  box-shadow: 0 0 6px rgba(255, 184, 0, 0.4);
}

.cl-signal-cold {
  background: var(--glow-blue);
  box-shadow: 0 0 6px rgba(74, 158, 255, 0.3);
}

.cl-signal-no_data {
  background: #445;
}

@keyframes pulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.3); }
}

.cl-idea-score {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--glow-cyan);
  min-width: 2rem;
  text-align: center;
  text-shadow: 0 0 8px rgba(0, 255, 247, 0.3);
}

.cl-idea-actions {
  display: flex;
  gap: 0.3rem;
  flex-shrink: 0;
  margin-left: auto;
}

/* Tag pills */
.cl-pill {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 0.18rem 0.5rem;
  border-radius: 9999px;
  background: rgba(0, 255, 247, 0.06);
  border: 1px solid rgba(0, 255, 247, 0.15);
  color: var(--text-body);
}

.cl-pill-pillar {
  border-color: rgba(255, 184, 0, 0.25);
  color: var(--glow-amber);
  background: rgba(255, 184, 0, 0.06);
}

.cl-pill-platform {
  border-color: rgba(0, 255, 247, 0.25);
  color: var(--glow-cyan);
}

.cl-pill-person {
  border-color: rgba(180, 74, 255, 0.25);
  color: var(--glow-purple);
  background: rgba(180, 74, 255, 0.06);
}

.cl-action-btn {
  background: none;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  width: 26px;
  height: 26px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.cl-action-btn:hover {
  border-color: var(--glow-cyan);
  color: var(--glow-cyan);
}

.cl-btn-save.active {
  color: var(--glow-amber);
  border-color: var(--glow-amber);
  background: rgba(255, 184, 0, 0.1);
}

.cl-btn-use.active {
  color: var(--glow-green);
  border-color: var(--glow-green);
  background: rgba(57, 255, 20, 0.1);
}

.cl-btn-dismiss.active {
  color: var(--glow-red);
  border-color: var(--glow-red);
  background: rgba(255, 51, 51, 0.1);
}

/* --- Idea Body (expanded) --- */
.cl-idea-body {
  padding: 0 0.85rem 0.85rem;
  border-top: 1px solid var(--border-main);
}

.cl-idea-section {
  margin-top: 0.75rem;
}

.cl-idea-section-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 0.35rem;
}

.cl-idea-section-text {
  font-size: 0.88rem;
  color: var(--text-body);
  line-height: 1.65;
  white-space: pre-wrap;
}

/* --- Pulse Check --- */
.cl-pulse-toggle {
  cursor: pointer;
  transition: color 0.2s;
}

.cl-pulse-toggle:hover {
  color: var(--glow-cyan);
}

.cl-expand-arrow {
  font-size: 0.6rem;
  margin-left: 0.3rem;
}

.cl-pulse-detail {
  padding: 0.5rem 0;
}

.cl-pulse-source-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--glow-cyan);
  margin: 0.5rem 0 0.25rem;
  text-transform: uppercase;
}

.cl-pulse-item {
  font-size: 0.72rem;
  padding: 0.3rem 0.5rem;
  margin-bottom: 0.2rem;
  background: rgba(100, 100, 200, 0.04);
  border-radius: 0.3rem;
  border-left: 2px solid var(--border-main);
  color: var(--text-body);
  line-height: 1.4;
}

.cl-pulse-author {
  color: var(--glow-purple);
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
}

.cl-pulse-score {
  color: var(--glow-amber);
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
}

/* --- Source Cards --- */
.cl-source-card {
  background: rgba(28, 30, 48, 0.4);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.65rem;
  margin-bottom: 0.35rem;
  transition: border-color 0.2s;
}

.cl-source-card:hover {
  border-color: rgba(0, 255, 247, 0.15);
}

.cl-source-top {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
  margin-bottom: 0.35rem;
}

.cl-source-person {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-body);
}

.cl-source-body {
  font-size: 0.72rem;
  color: var(--text-body);
  line-height: 1.5;
  opacity: 0.85;
}

.cl-source-eng {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
  color: var(--glow-cyan);
  margin-top: 0.3rem;
}

.cl-source-relevance {
  font-size: 0.65rem;
  color: var(--text-dim);
  margin-top: 0.2rem;
  font-style: italic;
}

.cl-source-link {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--glow-cyan);
  margin-top: 0.25rem;
  display: inline-block;
}

.cl-source-link:hover {
  color: #fff;
  text-decoration: underline;
}

/* --- Responsive --- */
@media (max-width: 900px) {
  .cl-idea-header { flex-direction: column; align-items: flex-start; }
  .cl-idea-tags { margin-top: 0.3rem; }
  .cl-idea-actions { margin-left: 0; margin-top: 0.3rem; }
}


/* ============================================
   CONTENT LAB — Sub-tab system
   ============================================ */

/* Sub-tab pills */
.cl-sub-tabs {
  display: flex;
  gap: 0.25rem;
  background: rgba(100, 100, 200, 0.06);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.2rem;
}

.cl-sub-tab {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
}

.cl-sub-tab:hover {
  color: #e0e4f0;
  background: rgba(100, 100, 200, 0.1);
}

.cl-sub-tab.active {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  box-shadow: 0 0 10px rgba(0, 255, 247, 0.08);
}

/* Sub-tab panels */
.cl-subtab-panel {
  display: none;
}

.cl-subtab-panel.active {
  display: block;
}

/* Discover filters row */
.cl-discover-filters {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
}

/* ============================================
   CONTENT LAB — Active Brief (CREATE tab)
   ============================================ */

.cl-active-brief {
  background: var(--bg-card);
  border: 1px solid rgba(0, 255, 247, 0.25);
  border-radius: 0.75rem;
  padding: 0.85rem;
  margin-bottom: 1rem;
  box-shadow: 0 0 20px rgba(0, 255, 247, 0.06);
  position: relative;
}

.cl-brief-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}

.cl-brief-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-body);
}

.cl-brief-close {
  background: none;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.cl-brief-close:hover {
  border-color: var(--glow-red);
  color: var(--glow-red);
}

.cl-brief-tags {
  display: flex;
  gap: 0.25rem;
  flex-wrap: wrap;
  margin-bottom: 0.5rem;
}

.cl-brief-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

.cl-brief-col {
  min-width: 0;
}

.cl-brief-text {
  font-size: 0.75rem;
  color: var(--text-body);
  line-height: 1.6;
  white-space: pre-wrap;
}

.cl-brief-sources {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 0.35rem;
  margin-top: 0.3rem;
}

@media (max-width: 900px) {
  .cl-brief-body { grid-template-columns: 1fr; }
  .cl-brief-sources { grid-template-columns: 1fr; }
}


/* ============================================
   CONTENT LAB — Leaderboard (Trending Now)
   ============================================ */

.cl-leaderboard {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  margin-top: 0.5rem;
}

.cl-lb-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.6rem 0.75rem;
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: all 0.2s;
  overflow: hidden;
  max-width: 100%;
}

.cl-lb-row:hover {
  border-color: rgba(0, 255, 247, 0.25);
  background: rgba(30, 34, 58, 0.9);
}

.cl-lb-top3 {
  border-color: rgba(255, 184, 0, 0.15);
}

.cl-lb-top3:hover {
  border-color: rgba(255, 184, 0, 0.35);
  box-shadow: 0 0 15px rgba(255, 184, 0, 0.06);
}

.cl-lb-active {
  border-color: rgba(0, 255, 247, 0.4) !important;
  background: rgba(0, 255, 247, 0.04) !important;
  box-shadow: 0 0 18px rgba(0, 255, 247, 0.08);
}

.cl-lb-rank {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 1.1rem;
  font-weight: 700;
  min-width: 1.8rem;
  text-align: center;
  flex-shrink: 0;
}

.cl-lb-main {
  flex: 1;
  min-width: 0;
}

.cl-lb-pillar {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  color: #e0e4f0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 0.3rem;
}

.cl-lb-bar-wrap {
  width: 100%;
  height: 4px;
  background: rgba(100, 100, 200, 0.08);
  border-radius: 2px;
  overflow: hidden;
}

.cl-lb-bar {
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s ease;
  box-shadow: 0 0 6px currentColor;
  opacity: 0.7;
}

.cl-lb-meta {
  flex-shrink: 0;
}

.cl-lb-stats {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 1;
  min-width: 0;
}

.cl-lb-stat {
  text-align: center;
  min-width: 2.5rem;
}

.cl-lb-stat-val {
  display: block;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.78rem;
  color: var(--text-body);
  line-height: 1.2;
}

.cl-lb-stat-lbl {
  display: block;
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.45rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-top: 0.1rem;
}

.cl-lb-vel .cl-lb-stat-val {
  font-weight: 700;
}

.cl-lb-creator {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 0;
  flex-shrink: 1;
  max-width: 6rem;
}

.cl-lb-creator-label {
  font-size: 0.4rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
}

.cl-lb-creator-name {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.68rem;
  color: var(--glow-purple);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 7rem;
}

.cl-lb-platform {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  min-width: 2.5rem;
  text-align: center;
  flex-shrink: 0;
}

@media (max-width: 900px) {
  .cl-lb-row { flex-wrap: wrap; }
  .cl-lb-stats { gap: 0.5rem; }
  .cl-lb-creator { display: none; }
  .cl-lb-platform { display: none; }
}


/* Firefox overflow fix */
.cl-subtab-panel {
  overflow-x: hidden;
  max-width: 100%;
}

.cl-leaderboard {
  overflow: hidden;
  max-width: 100%;
}

.cl-idea-card {
  max-width: 100%;
  overflow: hidden;
}

/* Responsive: hide less important leaderboard columns earlier */
@media (max-width: 1100px) {
  .cl-lb-creator { display: none; }
}

@media (max-width: 950px) {
  .cl-lb-platform { display: none; }
  .cl-lb-stats { gap: 0.35rem; }
  .cl-lb-stat { min-width: 2rem; }
}


/* Pulse engagement inline metrics */
.cl-pulse-eng {
  display: inline-block;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.58rem;
  color: var(--text-dim);
  margin-left: 0.5rem;
  white-space: nowrap;
}

.cl-pulse-item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.25rem;
}

/* ============================================
   RUN LOGS TABLE
   ============================================ */
.run-logs-table {
  font-size: 0.78rem;
}

.run-logs-table th {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.run-logs-table td {
  padding: 0.45rem 0.5rem;
  vertical-align: middle;
}

.run-status-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  font-size: 0.7rem;
  font-weight: 700;
}

.run-status-dot.green {
  background: rgba(0, 255, 128, 0.12);
  color: #4ade80;
}

.run-status-dot.red {
  background: rgba(255, 80, 80, 0.12);
  color: #f87171;
}

.run-status-dot.amber {
  background: rgba(255, 184, 0, 0.12);
  color: #ffb800;
  animation: pulse-amber 1.5s infinite;
}

.run-status-dot.grey {
  background: rgba(100, 100, 140, 0.12);
  color: #8a9ab4;
}

@keyframes pulse-amber {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.run-skill {
  font-family: 'Chakra Petch', sans-serif;
  font-weight: 600;
  font-size: 0.76rem;
  letter-spacing: 0.03em;
}

.run-type {
  color: var(--text-dim);
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.72rem;
}

.run-person {
  color: #c084fc;
  font-size: 0.74rem;
}

.run-time {
  color: var(--text-dim);
  font-size: 0.72rem;
  white-space: nowrap;
}

.run-duration {
  font-family: 'Share Tech Mono', monospace;
  color: var(--glow-cyan);
  font-size: 0.74rem;
}

.run-api {
  font-family: 'Share Tech Mono', monospace;
  color: #8a9ab4;
  font-size: 0.74rem;
  cursor: help;
}

.run-new {
  color: #4ade80;
  font-size: 0.74rem;
}

.run-errors {
  font-family: 'Share Tech Mono', monospace;
  color: #556;
  font-size: 0.74rem;
}

.run-errors.has-errors {
  color: #f87171;
  font-weight: 700;
}

.run-error {
  color: #f87171;
  font-size: 0.72rem;
}

.run-details {
  color: #8a9ab4;
  font-size: 0.72rem;
  max-width: 250px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.run-row.run-failed {
  background: rgba(255, 80, 80, 0.03);
}

.run-row:hover {
  background: rgba(100, 100, 200, 0.06);
}

/* Responsive: hide less important columns on smaller screens */
@media (max-width: 1100px) {
  .run-person { display: none; }
  .run-details { max-width: 150px; }
}

@media (max-width: 900px) {
  .run-api { display: none; }
  .run-new { display: none; }
}

/* ── Leaderboard Table ── */
.leaderboard-wrap {
  overflow-x: auto;
  margin-bottom: 1rem;
}
.leaderboard-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.75rem;
}
.leaderboard-table thead th {
  padding: 0.5rem 0.6rem;
  text-align: left;
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-dim, #6b7a94);
  border-bottom: 1px solid rgba(100,120,180,0.15);
  white-space: nowrap;
}
.leaderboard-row {
  cursor: pointer;
  transition: background 0.15s;
}
.leaderboard-row:hover {
  background: rgba(100,120,200,0.06);
}
.leaderboard-row td {
  padding: 0.45rem 0.6rem;
  border-bottom: 1px solid rgba(100,120,180,0.06);
  white-space: nowrap;
}
.lb-rank {
  font-weight: 700;
  color: var(--glow-cyan, #00fff7);
  font-size: 0.85rem;
  width: 2rem;
  text-align: center;
}
.lb-person-inner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.lb-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(100,120,200,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.55rem;
  font-weight: 600;
  color: var(--text-dim, #6b7a94);
  flex-shrink: 0;
}
.lb-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lb-score {
  font-weight: 700;
  color: var(--glow-green, #39ff14);
  font-size: 0.85rem;
}
.lb-component {
  color: var(--text-body, #c5d0e0);
  font-size: 0.7rem;
}
.lb-followers {
  color: var(--text-dim, #6b7a94);
  font-size: 0.7rem;
}

/* ── Toggle Pill (on/off switch) ── */
.toggle-pill {
  width: 32px;
  height: 18px;
  border-radius: 9px;
  background: rgba(85,85,85,0.4);
  border: 1px solid rgba(85,85,85,0.5);
  position: relative;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
  display: inline-block;
}
.toggle-pill.active {
  background: rgba(57,255,20,0.2);
  border-color: rgba(57,255,20,0.5);
}
.toggle-pill-knob {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #555;
  position: absolute;
  top: 2px;
  left: 2px;
  transition: transform 0.2s, background 0.2s;
}
.toggle-pill.active .toggle-pill-knob {
  transform: translateX(14px);
  background: #39ff14;
}
.toggle-pill:hover {
  border-color: rgba(200,200,200,0.4);
}

/* ── Inactive states ── */
.lb-inactive {
  opacity: 0.4;
}
.card-inactive {
  opacity: 0.45;
}
.card-inactive:hover {
  opacity: 0.7;
}

/* ── D100 Sub-tabs (mirrors Content Lab pattern) ── */
.d100-sub-tabs {
  display: flex;
  gap: 0.25rem;
  background: rgba(100, 100, 200, 0.06);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.2rem;
}
.d100-sub-tab {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
}
.d100-sub-tab:hover {
  color: #e0e4f0;
  background: rgba(100, 100, 200, 0.1);
}
.d100-sub-tab.active {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  box-shadow: 0 0 10px rgba(0, 255, 247, 0.08);
}
.d100-subtab-panel {
  display: none;
}
.d100-subtab-panel.active {
  display: block;
}

/* ── System Sub-tabs (mirrors Content Lab pattern) ── */
.sys-sub-tabs {
  display: flex;
  gap: 0.25rem;
  background: rgba(100, 100, 200, 0.06);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.2rem;
}
.sys-sub-tab {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
}
.sys-sub-tab:hover {
  color: #e0e4f0;
  background: rgba(100, 100, 200, 0.1);
}
.sys-sub-tab.active {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  box-shadow: 0 0 10px rgba(0, 255, 247, 0.08);
}
.sys-subtab-panel {
  display: none;
}
.sys-subtab-panel.active {
  display: block;
}
/* ── Cron/Config Table ── */
.cron-table .cron-name {
  color: #fff;
  font-weight: 600;
  font-size: 0.8rem;
}
.cron-table .cron-desc {
  color: var(--text-dim, #6b7a94);
  font-size: 0.65rem;
  margin-top: 0.15rem;
}
.cron-schedule {
  font-family: "Share Tech Mono", monospace;
  color: var(--glow-cyan, #00fff7);
  font-size: 0.75rem;
}
.cron-badge-off {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  border-radius: 0.2rem;
  background: rgba(255,68,68,0.15);
  color: #ff6b6b;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-left: 0.4rem;
  vertical-align: middle;
}
.cron-row.cron-disabled {
  opacity: 0.4;
}
.cron-row.cron-disabled:hover {
  opacity: 0.6;
}

/* ── Leaderboard Movement Indicators ── */
.lb-move-cell {
  width: 3rem;
  text-align: center;
  padding: 0.45rem 0.3rem !important;
}
.lb-movement {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.35rem;
  border-radius: 3px;
  white-space: nowrap;
}
.lb-rising {
  color: var(--glow-green);
  background: rgba(57, 255, 20, 0.08);
  border: 1px solid rgba(57, 255, 20, 0.2);
}
.lb-falling {
  color: var(--glow-red);
  background: rgba(255, 51, 51, 0.08);
  border: 1px solid rgba(255, 51, 51, 0.2);
}
.lb-stable {
  color: var(--text-dim);
  font-size: 0.7rem;
}
.lb-new {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  border: 1px solid rgba(0, 255, 247, 0.2);
  font-size: 0.55rem;
  letter-spacing: 0.1em;
}

/* ============================================
   DISTRIBUTION ENGINE TAB
   ============================================ */

/* --- Layout --- */
.dist-layout {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (max-width: 900px) {
  .dist-layout {
    grid-template-columns: 1fr;
  }
}

.dist-left {
  display: flex;
  flex-direction: column;
}

.dist-right {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* --- Flywheel Container --- */
.flywheel-container {
  position: relative;
  width: 340px;
  height: 340px;
  margin: 0 auto;
}

.flywheel-svg {
  position: absolute;
  top: 0;
  left: 0;
}

.flywheel-nodes {
  position: absolute;
  top: 0;
  left: 0;
  width: 340px;
  height: 340px;
  pointer-events: none;
}

/* --- Flow path animation --- */
.flow-path {
  animation: flowDash 2s linear infinite;
}

@keyframes flowDash {
  to { stroke-dashoffset: -16; }
}

/* --- Center ring pulse --- */
.center-ring {
  animation: centerPulse 4s ease-in-out infinite;
}

@keyframes centerPulse {
  0%, 100% { stroke-opacity: 0.15; }
  50% { stroke-opacity: 0.4; }
}

/* --- Flywheel Nodes --- */
.fw-node {
  position: absolute;
  width: 64px;
  height: 64px;
  margin-left: -32px;
  margin-top: -32px;
  border-radius: 12px;
  background: rgba(16, 18, 34, 0.95);
  border: 1px solid rgba(0, 255, 247, 0.15);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  pointer-events: all;
  transition: all 0.3s ease;
  z-index: 2;
}

.fw-node:hover {
  border-color: var(--node-color, var(--glow-cyan));
  box-shadow: 0 0 16px color-mix(in srgb, var(--node-color, var(--glow-cyan)) 30%, transparent);
  transform: scale(1.08);
}

.fw-node.selected {
  border-color: var(--node-color, var(--glow-cyan));
  box-shadow: 0 0 24px color-mix(in srgb, var(--node-color, var(--glow-cyan)) 40%, transparent);
  background: rgba(16, 18, 34, 1);
}

.fw-node.pulse {
  animation: nodePulse 1.5s ease-out;
}

@keyframes nodePulse {
  0% { box-shadow: 0 0 0 0 rgba(0, 255, 247, 0.5); }
  50% { box-shadow: 0 0 20px 4px rgba(0, 255, 247, 0.3); border-color: var(--glow-cyan); }
  100% { box-shadow: 0 0 0 0 rgba(0, 255, 247, 0); }
}

.fw-node-icon {
  font-size: 1.2rem;
  line-height: 1;
  margin-bottom: 0.15rem;
}

.fw-node-label {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  text-transform: uppercase;
}

.fw-node:hover .fw-node-label,
.fw-node.selected .fw-node-label {
  color: var(--node-color, var(--glow-cyan));
}

/* --- Flywheel Tooltip --- */
.fw-tooltip {
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  background: rgba(16, 18, 34, 0.97);
  border: 1px solid rgba(0, 255, 247, 0.2);
  border-radius: 8px;
  padding: 0.6rem 0.8rem;
  min-width: 200px;
  z-index: 10;
  backdrop-filter: blur(8px);
}

.fw-tooltip-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 0.35rem;
}

.fw-tooltip-stat {
  font-size: 0.65rem;
  color: var(--text-body);
  line-height: 1.6;
}

.fw-tooltip-stat::before {
  content: '\25B8 ';
  color: var(--text-dim);
}

/* --- Flywheel Status --- */
.fw-status {
  position: absolute;
  bottom: -36px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 0.6rem;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}

.fw-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #555;
}

.fw-status-dot.active {
  background: var(--glow-green);
  box-shadow: 0 0 6px var(--glow-green);
  animation: dotBlink 2s ease-in-out infinite;
}

@keyframes dotBlink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.fw-status-sep {
  color: #444;
}

/* --- Metric Cards --- */
.dist-card {
  background: rgba(16, 18, 34, 0.6);
  border: 1px solid rgba(100, 120, 180, 0.1);
  border-radius: 8px;
  padding: 0.75rem 1rem;
}

.dist-card-highlight {
  border-color: rgba(0, 255, 247, 0.15);
  background: rgba(0, 255, 247, 0.02);
}

.dist-card-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 0.6rem;
}

/* --- Metric Rows --- */
.dist-metrics-grid {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.dist-metric-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.2rem 0;
}

.dist-metric-label {
  font-size: 0.68rem;
  color: var(--text-body);
}

.dist-metric-right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dist-metric-value {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: #fff;
  font-weight: 600;
}

.dist-money {
  color: var(--glow-green);
  font-size: 0.9rem;
}

.dist-highlight-val {
  color: var(--glow-cyan);
}

.dist-trend-up {
  font-size: 0.55rem;
  color: var(--glow-green);
  white-space: nowrap;
}

.dist-trend-neutral {
  font-size: 0.55rem;
  color: var(--text-dim);
  white-space: nowrap;
}

/* --- Funnel --- */
.dist-funnel {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.dist-funnel-stage {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
}

.dist-funnel-bar {
  height: 20px;
  background: linear-gradient(90deg, rgba(0,255,247,0.15), rgba(0,255,247,0.06));
  border-radius: 3px;
  border: 1px solid rgba(0,255,247,0.12);
  min-width: 16px;
  transition: width 0.6s ease;
}

.dist-funnel-label {
  font-size: 0.62rem;
  color: var(--text-body);
  white-space: nowrap;
  min-width: 120px;
}

.dist-funnel-value {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.72rem;
  color: #fff;
  font-weight: 600;
  margin-left: auto;
}

/* --- Pillar Bar Chart --- */
.dist-bar-chart {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.dist-pillar-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dist-pillar-label {
  font-size: 0.6rem;
  color: var(--text-body);
  min-width: 130px;
  white-space: nowrap;
}

.dist-pillar-track {
  flex: 1;
  height: 8px;
  background: rgba(100, 120, 180, 0.08);
  border-radius: 4px;
  overflow: hidden;
}

.dist-pillar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--glow-cyan), rgba(0,255,247,0.4));
  border-radius: 4px;
  transition: width 0.8s ease;
}

.dist-pillar-pct {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  min-width: 28px;
  text-align: right;
}

/* --- Activity Feed --- */
.dist-feed-wrap {
  max-height: 320px;
  overflow-y: auto;
  padding-right: 0.5rem;
}

.dist-feed-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.4rem 0;
  border-bottom: 1px solid rgba(100, 120, 180, 0.05);
}

.dist-feed-item:last-child {
  border-bottom: none;
}

.dist-feed-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 0.3rem;
}

.dist-feed-time {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  min-width: 55px;
  flex-shrink: 0;
}

.dist-feed-text {
  font-size: 0.68rem;
  color: var(--text-body);
  line-height: 1.4;
}

/* --- mt-1 utility --- */
.mt-1 { margin-top: 0.5rem; }

/* ===== IDEA TYPE BADGES + TIMESTAMPS ===== */
.cl-idea-type-badge {
  display: inline-block;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.12rem 0.4rem;
  border-radius: 3px;
  margin-right: 0.4rem;
  white-space: nowrap;
  vertical-align: middle;
}
.cl-idea-time {
  font-size: 0.55rem;
  color: var(--text-dim);
  margin-left: auto;
  padding-left: 0.5rem;
  white-space: nowrap;
  opacity: 0.7;
}
.cl-idea-row1 {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  flex-wrap: nowrap;
}



/* ===== INTELLIGENCE TAB v2 ===== */
.intel-stats-bar {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.intel-stat-card {
  flex: 1;
  min-width: 75px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 0.55rem 0.4rem;
  text-align: center;
}
.intel-stat-value {
  font-size: 1.3rem;
  font-weight: 700;
  font-family: 'JetBrains Mono', 'Share Tech Mono', monospace;
  letter-spacing: -0.02em;
}
.intel-stat-label {
  font-size: 0.45rem;
  color: var(--text-dim);
  letter-spacing: 0.1em;
  margin-top: 0.15rem;
}

/* Grid: Feed LEFT, Mind Map RIGHT */
.intel-grid {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 0.75rem;
}
@media (max-width: 960px) {
  .intel-grid { grid-template-columns: 1fr; }
}
.intel-col-feed, .intel-col-map {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.intel-panel {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 0.75rem;
}
.intel-panel-header {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  margin-bottom: 0.6rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.intel-panel-badge {
  font-size: 0.45rem;
  background: rgba(0,255,247,0.08);
  color: var(--glow-cyan);
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  border: 1px solid rgba(0,255,247,0.15);
  letter-spacing: 0.06em;
  font-weight: 600;
}

/* Mind Map */
.intel-mm-wrap {
  position: relative;
  width: 100%;
}
.intel-mm-wrap canvas {
  width: 100%;
  display: block;
}
#intel-mm-tooltip {
  position: absolute;
  background: rgba(20,24,44,0.95);
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  padding: 0.35rem 0.5rem;
  font-size: 0.55rem;
  color: #ccc;
  pointer-events: none;
  z-index: 10;
  display: none;
  line-height: 1.4;
  max-width: 220px;
}
#intel-mm-tooltip b {
  color: #fff;
}
.intel-mm-legend {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.4rem;
  flex-wrap: wrap;
  justify-content: center;
}
.intel-legend-item {
  font-size: 0.5rem;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
.intel-legend-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.intel-mm-clear {
  font-size: 0.4rem;
  color: var(--glow-red);
  cursor: pointer;
  padding: 0.1rem 0.3rem;
  border: 1px solid rgba(255,51,51,0.3);
  border-radius: 3px;
  letter-spacing: 0.08em;
  transition: background 0.2s;
}
.intel-mm-clear:hover {
  background: rgba(255,51,51,0.15);
}
.intel-mm-popbtn {
  font-size: 0.4rem;
  color: var(--glow-cyan);
  cursor: pointer;
  margin-left: auto;
  padding: 0.1rem 0.35rem;
  border: 1px solid rgba(0,255,247,0.2);
  border-radius: 3px;
  letter-spacing: 0.08em;
  transition: background 0.2s, color 0.2s;
}
.intel-mm-popbtn:hover {
  background: rgba(0,255,247,0.12);
  color: #fff;
}

/* Popout floating window */
.intel-mm-popout {
  position: fixed;
  z-index: 900;
  width: 480px;
  min-height: 200px;
  border-radius: 8px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.6), 0 0 1px rgba(0,255,247,0.3);
  resize: both;
  overflow: auto;
}
.intel-mm-popout .intel-panel {
  border-radius: 8px;
  margin: 0;
}
.intel-mm-popout .intel-mm-draghandle {
  cursor: grab;
  user-select: none;
}
.intel-mm-popout .intel-mm-draghandle:active {
  cursor: grabbing;
}

/* Feed */
.intel-feed-panel {
  display: flex;
  flex-direction: column;
  min-height: 460px;
}
.intel-feed-filters {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
  flex-wrap: wrap;
}
.intel-feed-filters .filter-select {
  font-size: 0.55rem;
  flex: 1;
  min-width: 90px;
}
.intel-feed-scroll {
  flex: 1;
  max-height: 580px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border-subtle) transparent;
}
.intel-empty {
  color: var(--text-dim);
  font-size: 0.65rem;
  text-align: center;
  padding: 2rem 0;
}

/* Signal Card — bigger fonts */
.isig-card {
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-subtle);
  border-radius: 5px;
  padding: 0.55rem 0.65rem;
  margin-bottom: 0.4rem;
  transition: border-color 0.2s;
}
.isig-card:hover {
  border-color: rgba(0,255,247,0.3);
  background: rgba(255,255,255,0.035);
}
.isig-row1 {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  margin-bottom: 0.25rem;
  flex-wrap: wrap;
}
.isig-src {
  font-size: 0.52rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.08rem 0.3rem;
  border: 1px solid;
  border-radius: 3px;
}
.isig-warmth {
  font-size: 0.46rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.06rem 0.25rem;
  border-radius: 3px;
  color: #000;
}
.isig-vel {
  font-size: 0.58rem;
  font-weight: 700;
  font-family: 'Share Tech Mono', monospace;
  color: var(--glow-cyan);
}
.isig-eng {
  font-size: 0.52rem;
  color: var(--glow-green);
  font-family: 'Share Tech Mono', monospace;
}
.isig-seen {
  font-size: 0.46rem;
  color: var(--glow-pink);
  font-weight: 600;
}
.isig-time {
  font-size: 0.48rem;
  color: var(--text-dim);
  margin-left: auto;
}
.isig-title {
  font-size: 0.72rem;
  color: var(--text-main, #e0e0e0);
  line-height: 1.4;
  margin-bottom: 0.3rem;
}
.isig-tags {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  align-items: center;
}
.isig-keyword {
  font-size: 0.48rem;
  color: var(--glow-cyan);
  background: rgba(0,255,247,0.06);
  border: 1px solid rgba(0,255,247,0.12);
  padding: 0.08rem 0.3rem;
  border-radius: 3px;
  font-family: 'Share Tech Mono', monospace;
}
.isig-pillar {
  font-size: 0.48rem;
  color: var(--glow-amber);
  border: 1px solid rgba(255,184,0,0.2);
  padding: 0.08rem 0.25rem;
  border-radius: 3px;
}
.isig-cn {
  font-size: 0.44rem;
  color: var(--glow-pink);
  border: 1px solid rgba(255,110,180,0.25);
  padding: 0.06rem 0.25rem;
  border-radius: 3px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

/* River */
.intel-river-wrap {
  width: 100%;
  overflow: hidden;
}
.intel-river-wrap canvas {
  width: 100%;
  display: block;
}
/* Pipeline Timeline Visualization */
.pipe-section { margin-bottom: 16px; }
.pipe-section-title { font-size: 0.78rem; font-weight: 700; color: #e2e8f0; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.pipe-tz { font-size: 0.58rem; color: #64748b; font-weight: 400; letter-spacing: 0; }

/* Timeline bar area */
.pipe-timeline { position: relative; background: rgba(15,23,42,0.6); border: 1px solid rgba(100,116,139,0.2); border-radius: 8px; padding: 32px 16px 12px; margin-bottom: 16px; overflow-x: auto; min-height: 80px; }
.pipe-axis { position: relative; height: 20px; margin-bottom: 8px; }
.pipe-tick { position: absolute; transform: translateX(-50%); font-size: 0.5rem; color: #64748b; font-family: 'Share Tech Mono', monospace; white-space: nowrap; }
.pipe-tick::after { content: ''; position: absolute; left: 50%; top: 14px; width: 1px; height: 6px; background: rgba(100,116,139,0.3); }

.pipe-bars { position: relative; height: 44px; }
.pipe-bar { position: absolute; top: 0; height: 100%; border-radius: 4px; display: flex; align-items: center; gap: 6px; padding: 0 8px; cursor: default; transition: opacity 0.2s; overflow: hidden; }
.pipe-bar:hover { opacity: 0.85; }
.pipe-bar-label { font-size: 0.56rem; font-weight: 700; font-family: 'Share Tech Mono', monospace; white-space: nowrap; }
.pipe-bar-name { font-size: 0.5rem; color: #94a3b8; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.pipe-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.pipe-dot.green { background: #00ff88; box-shadow: 0 0 6px #00ff8866; }
.pipe-dot.amber { background: #ffb800; box-shadow: 0 0 6px #ffb80066; }
.pipe-dot.red { background: #ff4444; box-shadow: 0 0 6px #ff444466; }
.pipe-dot.grey { background: #475569; }
.pipe-dot.pulse { animation: dotPulse 1.5s infinite; }
@keyframes dotPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }

/* Card list */
.pipe-cards { display: flex; flex-direction: column; gap: 4px; }
.pipe-cards-sys { margin-top: 4px; }

.pipe-card { background: rgba(15,23,42,0.5); border: 1px solid rgba(100,116,139,0.15); border-radius: 6px; cursor: pointer; transition: border-color 0.2s, background 0.2s; overflow: hidden; }
.pipe-card:hover { border-color: rgba(100,116,139,0.35); background: rgba(15,23,42,0.7); }
.pipe-card.expanded { border-color: rgba(0,212,255,0.3); background: rgba(15,23,42,0.8); }

.pipe-card-head { display: flex; align-items: center; gap: 10px; padding: 8px 12px; }
.pipe-card-status { flex-shrink: 0; width: 14px; display: flex; justify-content: center; }
.pipe-sdot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.pipe-sdot.green { background: #00ff88; box-shadow: 0 0 6px #00ff8844; }
.pipe-sdot.amber { background: #ffb800; box-shadow: 0 0 6px #ffb80044; }
.pipe-sdot.red { background: #ff4444; box-shadow: 0 0 6px #ff444444; }
.pipe-sdot.grey { background: #475569; }
.pipe-sdot.pulse { animation: dotPulse 1.5s infinite; }

.pipe-card-info { flex: 1; min-width: 0; }
.pipe-card-name { font-size: 0.72rem; font-weight: 600; color: #e2e8f0; display: flex; align-items: center; gap: 6px; }
.pipe-card-desc { font-size: 0.56rem; color: #64748b; margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.pipe-phase { font-size: 0.5rem; font-weight: 700; font-family: 'Share Tech Mono', monospace; background: rgba(0,212,255,0.15); color: #00d4ff; padding: 1px 5px; border-radius: 3px; }
.pipe-eod { font-size: 0.44rem; font-weight: 600; background: rgba(255,107,107,0.15); color: #ff6b6b; padding: 1px 4px; border-radius: 3px; text-transform: uppercase; letter-spacing: 0.04em; }

.pipe-card-meta { text-align: right; flex-shrink: 0; min-width: 100px; }
.pipe-card-time { font-size: 0.62rem; color: #94a3b8; font-family: 'Share Tech Mono', monospace; }
.pipe-card-dur { font-size: 0.54rem; color: #64748b; margin-top: 1px; }
.pipe-est { color: #475569; }
.pipe-card-ago { font-size: 0.5rem; color: #475569; margin-top: 1px; }

.pipe-card-arrow { font-size: 0.6rem; color: #475569; transition: transform 0.2s; flex-shrink: 0; margin-left: 4px; }
.pipe-card.expanded .pipe-card-arrow { transform: rotate(180deg); color: #00d4ff; }

.pipe-detail { max-height: 0; overflow: hidden; transition: max-height 0.3s ease, padding 0.3s ease; }
.pipe-card.expanded .pipe-detail { max-height: 300px; padding: 0 12px 10px 36px; }
.pipe-detail-text { font-size: 0.6rem; color: #94a3b8; line-height: 1.6; }
/* Enhanced Run Logs */
.run-filters { display: flex; gap: 6px; margin-bottom: 12px; }
.run-filter-btn { background: rgba(15,23,42,0.6); border: 1px solid rgba(100,116,139,0.2); border-radius: 4px; color: #94a3b8; font-size: 0.62rem; padding: 4px 10px; cursor: pointer; transition: all 0.2s; font-family: 'Share Tech Mono', monospace; }
.run-filter-btn:hover { border-color: rgba(100,116,139,0.4); color: #e2e8f0; }
.run-filter-btn.active { background: rgba(0,212,255,0.12); border-color: rgba(0,212,255,0.3); color: #00d4ff; }

.run-row.has-events { cursor: pointer; }
.run-row.has-events:hover { background: rgba(15,23,42,0.5); }
.run-expand-icon { margin-right: 4px; font-size: 0.5rem; color: #475569; }
.run-row.has-events:hover .run-expand-icon { color: #00d4ff; }

.run-status-dot.red-amber { background: linear-gradient(135deg, #ff4444, #ffb800); }
.run-status-dot.blue { background: #3b82f6; box-shadow: 0 0 6px #3b82f644; }
.run-status-dot.blue.pulse { animation: dotPulse 1.5s infinite; }

.run-warn-badge { background: rgba(255,184,0,0.15); color: #ffb800; padding: 1px 5px; border-radius: 3px; font-size: 0.56rem; font-weight: 700; font-family: 'Share Tech Mono', monospace; }
.run-err-badge { background: rgba(255,68,68,0.15); color: #ff4444; padding: 1px 5px; border-radius: 3px; font-size: 0.56rem; font-weight: 700; font-family: 'Share Tech Mono', monospace; }
.run-or-badge { background: rgba(178,102,255,0.15); color: #b366ff; padding: 1px 5px; border-radius: 3px; font-size: 0.56rem; font-weight: 700; font-family: 'Share Tech Mono', monospace; }

.run-events-row td { padding: 0 !important; }
.run-events-panel { background: rgba(10,15,30,0.8); border-top: 1px solid rgba(100,116,139,0.15); padding: 10px 16px; max-height: 300px; overflow-y: auto; }
.run-events-loading, .run-events-empty { font-size: 0.6rem; color: #475569; padding: 8px; }

.run-events-timeline { display: flex; flex-direction: column; gap: 3px; }
.evt-row { display: flex; align-items: center; gap: 8px; padding: 3px 0; font-size: 0.58rem; }
.evt-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.evt-info .evt-dot { background: #3b82f6; }
.evt-warn .evt-dot { background: #ffb800; box-shadow: 0 0 4px #ffb80044; }
.evt-error .evt-dot { background: #ff4444; box-shadow: 0 0 4px #ff444444; }
.evt-time { color: #475569; font-family: 'Share Tech Mono', monospace; font-size: 0.52rem; min-width: 65px; }
.evt-cat { background: rgba(100,116,139,0.15); color: #94a3b8; padding: 1px 5px; border-radius: 3px; font-size: 0.5rem; font-family: 'Share Tech Mono', monospace; white-space: nowrap; }
.evt-msg { color: #cbd5e1; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.evt-warn .evt-msg { color: #ffb800; }
.evt-error .evt-msg { color: #ff4444; }
.evt-meta { color: #475569; font-size: 0.48rem; font-family: 'Share Tech Mono', monospace; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Intelligence Sub-tabs ── */
.intel-sub-tabs {
  display: flex;
  gap: 0.25rem;
  background: rgba(100, 100, 200, 0.06);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  padding: 0.2rem;
}
.intel-sub-tab {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.4rem 1rem;
  border: none;
  border-radius: 0.35rem;
  background: transparent;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
}
.intel-sub-tab:hover {
  color: #e0e4f0;
  background: rgba(100, 100, 200, 0.1);
}
.intel-sub-tab.active {
  color: var(--glow-cyan);
  background: rgba(0, 255, 247, 0.08);
  box-shadow: 0 0 10px rgba(0, 255, 247, 0.08);
}
.intel-subtab-panel {
  display: none;
}
.intel-subtab-panel.active {
  display: block;
}

/* ── Knowledge Graph ── */
.kg-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.5rem;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.kg-stats {
  display: flex;
  gap: 0.75rem;
}
.kg-stat {
  font-size: 0.62rem;
  color: var(--text-dim);
  font-family: 'Share Tech Mono', monospace;
}
.kg-stat b {
  color: var(--glow-cyan);
  font-size: 0.72rem;
  margin-right: 0.2rem;
}
.kg-search {
  background: rgba(15, 20, 40, 0.8);
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  color: #c8cdd8;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.62rem;
  padding: 0.35rem 0.6rem;
  width: 220px;
  outline: none;
  transition: border-color 0.2s;
}
.kg-search:focus {
  border-color: rgba(0, 255, 247, 0.4);
}
.kg-search::placeholder {
  color: #445;
}
.kg-canvas-wrap {
  position: relative;
  width: 100%;
  background: rgba(16, 17, 26, 0.6);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  overflow: hidden;
}
.kg-canvas-wrap canvas {
  display: block;
  cursor: grab;
}
.kg-canvas-wrap canvas:active {
  cursor: grabbing;
}
.kg-tooltip {
  position: absolute;
  background: rgba(20, 24, 44, 0.95);
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  padding: 0.4rem 0.55rem;
  font-size: 0.58rem;
  color: #ccc;
  pointer-events: none;
  z-index: 10;
  display: none;
  line-height: 1.5;
  max-width: 240px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.kg-tooltip b {
  color: #fff;
  font-size: 0.65rem;
}
.kg-tip-stat {
  color: var(--glow-cyan);
  font-family: 'Share Tech Mono', monospace;
}
.kg-tip-plats {
  color: #8a9ab4;
  font-size: 0.5rem;
}
.kg-tip-rank {
  color: var(--glow-pink);
  font-weight: 700;
}
.kg-legend {
  display: flex;
  gap: 1.5rem;
  margin-top: 0.6rem;
  padding: 0.5rem 0.75rem;
  background: rgba(16, 17, 26, 0.4);
  border: 1px solid var(--border-subtle);
  border-radius: 4px;
  flex-wrap: wrap;
  justify-content: center;
}
.kg-legend-section {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.kg-legend-title {
  font-size: 0.45rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  margin-right: 0.2rem;
}
.kg-legend-item {
  font-size: 0.5rem;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
.kg-legend-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.kg-legend-hex {
  width: 7px;
  height: 7px;
  display: inline-block;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

/* ── Next Run Countdown ── */
.pipe-next-run {
  font-size: 0.56rem;
  font-weight: 700;
  font-family: 'Share Tech Mono', monospace;
  margin-top: 2px;
  letter-spacing: 0.04em;
}
.pipe-next-soon {
  color: #00ff88;
  text-shadow: 0 0 6px rgba(0, 255, 136, 0.3);
}
.pipe-next-imminent {
  color: #ffb800;
  animation: dotPulse 1.5s infinite;
}
.pipe-next-normal {
  color: #64748b;
}
.pipe-next-disabled {
  color: #334;
  font-style: italic;
  font-weight: 400;
}

/* ── Growth + Heat Columns ── */
.lb-growth-th, .lb-heat-th { text-align:center; font-size:0.55rem; color:var(--text-dim); min-width:32px; padding:0.3rem 0.15rem !important; }
.lb-growth-cell, .lb-heat-cell { text-align:center; padding:0.15rem 0.2rem !important; vertical-align:middle; }
.trend-growth { font-size:0.6rem; font-weight:600; letter-spacing:0.02em; white-space:nowrap; }
.trend-new { color:#ff2cf1; font-size:0.55rem; font-weight:700; }
.trend-rising { color:#39ff14; }
.trend-falling { color:#ff3333; }
.trend-stable { color:#555; font-size:0.55rem; }
.trend-heat { font-size:0.6rem; letter-spacing:0.02em; white-space:nowrap; }
.trend-heat-hot { color:#ff4444; text-shadow:0 0 4px rgba(255,68,68,0.5); }
.trend-heat-warm { color:#ffb800; }
.trend-heat-cold { color:#3b82f6; }
.trend-heat-none { color:#444; font-size:0.55rem; }

/* ========================================
   CORPUS EXPLORER
   ======================================== */
.corpus-stats-row {
  display:flex; gap:12px; margin-bottom:16px; flex-wrap:wrap;
}
.corpus-stat-card {
  background:var(--bg-card, #1a1a2e); border:1px solid rgba(255,255,255,0.06);
  border-radius:8px; padding:12px 16px; min-width:90px; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:4px;
}
.corpus-stat-card.corpus-stat-total {
  border-color:var(--glow-cyan, #00d4ff); background:rgba(0,212,255,0.05);
}
.corpus-stat-num { font-size:1.4rem; font-weight:700; color:#fff; }
.corpus-stat-label { font-size:0.7rem; text-transform:uppercase; color:#888; letter-spacing:0.04em; }
.corpus-stat-sub { font-size:0.65rem; color:#555; }
.corpus-type-icon {
  display:inline-block; padding:2px 6px; border-radius:4px; font-size:0.6rem;
  font-weight:700; color:#fff; letter-spacing:0.04em; margin-bottom:2px;
}
.corpus-filter-bar {
  display:flex; gap:10px; margin-bottom:16px; align-items:center; flex-wrap:wrap;
}
.corpus-filter-bar .filter-select { min-width:120px; }
.filter-search {
  background:var(--bg-card, #1a1a2e); border:1px solid rgba(255,255,255,0.1);
  border-radius:6px; padding:6px 10px; color:#ccc; font-size:0.8rem; flex:1; min-width:150px;
}
.filter-search:focus { outline:none; border-color:var(--glow-cyan, #00d4ff); }
.corpus-add-btn {
  background:rgba(0,212,255,0.1); border:1px solid rgba(0,212,255,0.3);
  color:var(--glow-cyan, #00d4ff); padding:6px 14px; border-radius:6px;
  cursor:pointer; font-size:0.8rem; font-weight:600; white-space:nowrap;
}
.corpus-add-btn:hover { background:rgba(0,212,255,0.2); }
.corpus-list { max-height:600px; overflow-y:auto; }
.corpus-count { font-size:0.7rem; color:#555; margin-bottom:8px; }
.corpus-empty { color:#555; font-size:0.85rem; padding:20px; text-align:center; }
.corpus-entry {
  background:var(--bg-card, #1a1a2e); border:1px solid rgba(255,255,255,0.06);
  border-radius:8px; padding:14px 16px; margin-bottom:8px;
  transition:border-color 0.2s, box-shadow 0.2s;
}
.corpus-entry:hover { border-color:rgba(255,255,255,0.12); }
.corpus-entry.expanded {
  border-color:rgba(0,212,255,0.2);
  box-shadow:0 0 12px rgba(0,212,255,0.05);
}
.corpus-entry-title {
  font-size:0.8rem; color:var(--glow-cyan, #00d4ff); margin-bottom:8px;
  font-weight:600; letter-spacing:0.02em;
}
.corpus-entry-header {
  display:flex; align-items:center; gap:6px; margin-bottom:8px; flex-wrap:wrap;
}
.corpus-type-badge {
  display:inline-block; padding:2px 8px; border-radius:4px; font-size:0.6rem;
  font-weight:600; color:#fff; letter-spacing:0.03em; text-transform:uppercase;
}
.corpus-platform {
  font-size:0.65rem; color:#777; background:rgba(255,255,255,0.04);
  padding:2px 6px; border-radius:3px;
}
.corpus-words { font-size:0.6rem; color:#555; }
.corpus-expand-btn {
  font-size:0.6rem; color:var(--glow-cyan, #00d4ff); background:rgba(0,212,255,0.06);
  border:1px solid rgba(0,212,255,0.25); border-radius:4px; padding:3px 10px;
  cursor:pointer; transition:all 0.15s; font-weight:500; letter-spacing:0.02em;
}
.corpus-expand-btn:hover {
  background:rgba(0,212,255,0.15); border-color:rgba(0,212,255,0.5);
}
/* Collapsed body — single line preview */
.corpus-entry-body {
  font-size:0.78rem; color:#999; line-height:1.5;
  word-break:break-word;
}
.corpus-ellipsis { color:#555; }
/* Expanded body — scrollable reader pane */
.corpus-entry-body.corpus-body-expanded {
  max-height:400px; overflow-y:auto; color:#ccc;
  padding:12px 16px; margin-top:4px;
  background:rgba(0,0,0,0.2); border-radius:6px;
  border:1px solid rgba(255,255,255,0.04);
  scrollbar-width:thin; scrollbar-color:rgba(0,212,255,0.2) transparent;
}
.corpus-body-expanded::-webkit-scrollbar { width:5px; }
.corpus-body-expanded::-webkit-scrollbar-track { background:transparent; }
.corpus-body-expanded::-webkit-scrollbar-thumb {
  background:rgba(0,212,255,0.2); border-radius:3px;
}
.corpus-para {
  margin:0 0 10px 0; text-indent:0; line-height:1.65;
}
.corpus-para:last-child { margin-bottom:0; }
.corpus-entry-tags { display:flex; gap:4px; flex-wrap:wrap; }
.corpus-tag {
  font-size:0.55rem; padding:1px 6px; border-radius:3px;
  background:rgba(255,255,255,0.04); color:#666; border:1px solid rgba(255,255,255,0.06);
}
.corpus-add-form { margin-top:16px; }
.corpus-form-inner {
  background:var(--bg-card, #1a1a2e); border:1px solid rgba(0,212,255,0.2);
  border-radius:8px; padding:16px;
}
.corpus-form-row { margin-bottom:12px; }
.corpus-form-row label {
  display:block; font-size:0.7rem; color:#888; margin-bottom:4px;
  text-transform:uppercase; letter-spacing:0.04em;
}
.corpus-textarea {
  width:100%; background:rgba(0,0,0,0.3); border:1px solid rgba(255,255,255,0.1);
  border-radius:6px; padding:8px; color:#ccc; font-size:0.8rem; resize:vertical;
  font-family:inherit; box-sizing:border-box;
}
.corpus-textarea:focus { outline:none; border-color:var(--glow-cyan, #00d4ff); }
.corpus-form-actions { display:flex; gap:10px; justify-content:flex-end; }
.corpus-cancel-btn {
  background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1);
  color:#888; padding:6px 14px; border-radius:6px; cursor:pointer; font-size:0.8rem;
}
.corpus-cancel-btn:hover { background:rgba(255,255,255,0.1); }
.corpus-save-btn {
  background:rgba(0,212,255,0.15); border:1px solid rgba(0,212,255,0.4);
  color:var(--glow-cyan, #00d4ff); padding:6px 14px; border-radius:6px;
  cursor:pointer; font-size:0.8rem; font-weight:600;
}
.corpus-save-btn:hover { background:rgba(0,212,255,0.25); }

/* =============================================
   KANBAN ENHANCEMENTS — Generating Cards, QA Badges, Platform Picker
   ============================================= */

/* Generating card in draft column */
.kanban-card-generating {
  background: rgba(0, 255, 247, 0.03);
  border: 1px solid rgba(0, 255, 247, 0.25);
  border-radius: 0.5rem;
  padding: 0.65rem;
  animation: kanban-gen-pulse 2s ease-in-out infinite;
}
@keyframes kanban-gen-pulse {
  0%, 100% { border-color: rgba(0, 255, 247, 0.25); box-shadow: 0 0 0 0 rgba(0, 255, 247, 0); }
  50% { border-color: rgba(0, 255, 247, 0.5); box-shadow: 0 0 12px 0 rgba(0, 255, 247, 0.1); }
}
.kanban-gen-header {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.4rem;
}
.kanban-gen-spinner {
  width: 10px; height: 10px;
  border: 2px solid rgba(0, 255, 247, 0.3);
  border-top-color: var(--glow-cyan);
  border-radius: 50%;
  animation: kanban-spin 0.8s linear infinite;
}
@keyframes kanban-spin {
  to { transform: rotate(360deg); }
}
.kanban-gen-label {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--glow-cyan);
}
.kanban-gen-body {
  font-size: 0.65rem;
  line-height: 1.4;
}
.kanban-gen-phase {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: 0.2rem;
}
.kanban-gen-message {
  color: var(--text-body);
  font-size: 0.65rem;
}
.kanban-gen-counter {
  display: inline-block;
  font-size: 0.55rem;
  color: var(--text-dim);
  margin-top: 0.2rem;
  margin-right: 0.5rem;
}
.kanban-gen-score {
  display: inline-block;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  font-weight: 700;
  margin-top: 0.2rem;
}
.kanban-gen-preview {
  margin-top: 0.35rem;
  padding: 0.35rem;
  background: rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  font-size: 0.6rem;
  color: var(--text-dim);
  max-height: 3em;
  overflow: hidden;
  font-style: italic;
}

/* QA score badge on kanban cards */
.kanban-qa-badge {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  font-weight: 700;
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  border: 1px solid;
  background: rgba(0, 0, 0, 0.2);
}

/* Time on kanban cards */
.kanban-card-time {
  font-size: 0.5rem;
  color: var(--text-dim);
}

/* Copy button on kanban cards */
.kanban-copy-btn {
  background: none;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 3px;
  color: var(--text-dim);
  cursor: pointer;
  font-size: 0.55rem;
  padding: 0.1rem 0.3rem;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
}
.kanban-card:hover .kanban-copy-btn { opacity: 1; }
.kanban-copy-btn:hover { color: var(--glow-cyan); border-color: rgba(0, 255, 247, 0.3); }

/* Posted link */
.kanban-posted-link {
  font-size: 0.5rem;
  color: var(--glow-cyan);
  text-decoration: none;
}
.kanban-posted-link:hover { text-decoration: underline; }

/* Platform picker (inline on idea cards) */
.cl-platform-picker {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.5rem 0.75rem;
  background: rgba(0, 0, 0, 0.3);
  border-top: 1px solid var(--border-main);
  flex-wrap: wrap;
}
.cl-picker-label {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--text-dim);
  margin-right: 0.25rem;
}
.cl-picker-btn {
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  border: 1px solid;
  background: rgba(0, 0, 0, 0.2);
  cursor: pointer;
  font-size: 0.6rem;
  font-weight: 600;
  transition: background 0.15s;
}
.cl-picker-btn:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* QA details in modal */
.km-qa-details {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

/* --- Generation Sources Panel (Kanban Modal) --- */
.km-sources-details {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background: rgba(0, 0, 0, 0.15);
  border-radius: 6px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}
.km-sources-summary {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--glow-cyan);
  cursor: pointer;
  padding: 0.25rem 0;
}
.km-sources-summary:hover { color: #fff; }
.km-src-section {
  margin-top: 0.6rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}
.km-src-section:first-child { margin-top: 0.3rem; border-top: none; }
.km-src-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 0.35rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.km-src-count {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.5rem;
  font-weight: 400;
  color: rgba(138, 154, 180, 0.5);
  letter-spacing: 0;
}
.km-src-item {
  font-size: 0.6rem;
  color: var(--text-body);
  padding: 0.15rem 0;
  line-height: 1.45;
}
.km-src-label {
  font-weight: 600;
  color: var(--text-dim);
  margin-right: 0.25rem;
}
.km-src-card {
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 5px;
  padding: 0.45rem;
  margin-bottom: 0.3rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem;
}
.km-src-card-title {
  font-size: 0.6rem;
  font-weight: 600;
  color: #ddd;
}
.km-src-card-body {
  width: 100%;
  font-size: 0.58rem;
  color: rgba(200, 210, 225, 0.7);
  line-height: 1.45;
  margin-top: 0.15rem;
}
.km-src-card-eng {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.5rem;
  color: var(--glow-green);
}
.km-src-badge {
  font-size: 0.45rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  white-space: nowrap;
}
.km-src-badge-voice {
  background: rgba(180, 74, 255, 0.15);
  color: #b44aff;
}
.km-src-badge-corpus {
  background: rgba(59, 130, 246, 0.15);
  color: #3b82f6;
}
.km-src-badge-brand {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
}
.km-src-badge-d100 {
  background: rgba(0, 255, 247, 0.1);
  color: var(--glow-cyan);
}
.km-src-badge-source {
  background: rgba(57, 255, 20, 0.1);
  color: var(--glow-green);
}
/* ============================================
   COMMENT OPS — FB Group Engagement Pipeline
   ============================================ */

/* Scrape bar */
.co-scrape-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.75rem;
  margin: 0.75rem 0 0;
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.co-scrape-active {
  border-color: rgba(0,255,247,0.25);
  animation: co-pulse 2s ease-in-out infinite;
}
.co-scrape-done {
  border-color: rgba(57,255,20,0.3);
  box-shadow: 0 0 8px rgba(57,255,20,0.08);
}
.co-scrape-error {
  border-color: rgba(255,51,51,0.3);
  box-shadow: 0 0 8px rgba(255,51,51,0.08);
}
.co-btn-scrape {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.4rem 0.85rem;
  border: 1px solid rgba(255,184,0,0.35);
  border-radius: 0.35rem;
  background: rgba(255,184,0,0.08);
  color: var(--glow-amber);
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  flex-shrink: 0;
}
.co-btn-scrape:hover { background: rgba(255,184,0,0.16); }
.co-btn-scrape:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  border-color: rgba(0,255,247,0.25);
  color: var(--glow-cyan);
  background: rgba(0,255,247,0.06);
}
.co-scrape-status {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
  color: var(--text-dim);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.co-scrape-phase {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.1rem 0.4rem;
  border-radius: 3px;
  margin-right: 0.4rem;
}
.co-scrape-phase-scanning { color: var(--glow-cyan); background: rgba(0,255,247,0.1); }
.co-scrape-phase-comments { color: var(--glow-purple); background: rgba(162,89,255,0.1); }
.co-scrape-phase-scoring { color: var(--glow-amber); background: rgba(255,184,0,0.1); }
.co-scrape-phase-done { color: var(--glow-green); background: rgba(57,255,20,0.1); }
.co-scrape-phase-error { color: var(--glow-red); background: rgba(255,51,51,0.1); }

/* Stats bar */
.co-stats-bar {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 0.75rem;
  margin: 0.75rem 0;
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.5rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.75rem;
  color: var(--text-dim);
  flex-wrap: wrap;
}
.co-stat { font-weight: 600; letter-spacing: 0.06em; }
.co-stat-hot { color: #ff8c00; text-shadow: 0 0 6px rgba(255,140,0,0.4); }
.co-stat-engage { color: var(--glow-green); }
.co-stat-drafted { color: var(--glow-cyan); }
.co-stat-posted { color: var(--glow-magenta); }
.co-stat-total { color: var(--text-dim); }
.co-stat-sep { color: rgba(100, 100, 200, 0.25); font-size: 0.65rem; }

/* Filters */
.co-filters {
  display: flex;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
  align-items: center;
  flex-wrap: wrap;
}
.co-filter-btn {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.35rem 0.75rem;
  border: 1px solid var(--border-main);
  border-radius: 0.35rem;
  background: transparent;
  color: var(--text-dim);
  cursor: pointer;
  transition: all 0.2s;
}
.co-filter-btn:hover { color: #e0e4f0; background: rgba(100,100,200,0.1); }
.co-filter-btn.active {
  color: var(--glow-cyan);
  background: rgba(0,255,247,0.08);
  border-color: rgba(0,255,247,0.25);
}
.co-group-select {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.7rem;
  background: var(--bg-card);
  color: #c8c8d8;
  border: 1px solid var(--border-main);
  border-radius: 0.35rem;
  padding: 0.35rem 0.5rem;
  margin-left: 0.5rem;
  cursor: pointer;
  outline: none;
}
.co-group-select:focus { border-color: rgba(0,255,247,0.4); }

/* Header actions */
.co-header-actions { display: flex; gap: 0.5rem; }
.co-btn-refresh {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.35rem 0.75rem;
  border: 1px solid rgba(0,255,247,0.25);
  border-radius: 0.35rem;
  background: rgba(0,255,247,0.06);
  color: var(--glow-cyan);
  cursor: pointer;
  transition: all 0.2s;
}
.co-btn-refresh:hover { background: rgba(0,255,247,0.12); }

/* Split container */
.co-container {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}
.co-inbound { flex: 6; min-width: 0; }
.co-outbox { flex: 4; min-width: 0; }
.co-section-title {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 0.5rem;
}
.co-outbox-count {
  font-family: 'Share Tech Mono', monospace;
  color: var(--glow-cyan);
  margin-left: 0.3rem;
}
.co-mt-1 { margin-top: 1rem; }

/* Thread cards */
.co-thread-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.co-thread-card {
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.65rem;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.co-thread-card:hover { border-color: rgba(0,255,247,0.2); }
.co-generating {
  border-color: rgba(0,255,247,0.3);
  animation: co-pulse 2s ease-in-out infinite;
}
@keyframes co-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0,255,247,0); }
  50% { box-shadow: 0 0 15px 0 rgba(0,255,247,0.1); }
}

.co-card-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid var(--border-main);
  flex-wrap: wrap;
}
.co-card-group {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.72rem;
  font-weight: 600;
  color: #e0e4f0;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.co-score-badge {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.8rem;
  font-weight: 700;
  min-width: 2rem;
  text-align: center;
}
.co-score-high { color: var(--glow-green); text-shadow: 0 0 6px rgba(57,255,20,0.3); }
.co-score-mid { color: var(--glow-amber); }
.co-score-low { color: var(--text-dim); }

.co-verdict-tag {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 0.12rem 0.45rem;
  border-radius: 9999px;
}
.co-verdict-hot {
  color: #ff8c00;
  background: rgba(255,140,0,0.12);
  border: 1px solid rgba(255,140,0,0.4);
  animation: co-hot-pulse 2s ease-in-out infinite;
}
.co-hot-icon { font-size: 0.65rem; }
@keyframes co-hot-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,140,0,0); }
  50% { box-shadow: 0 0 8px 0 rgba(255,140,0,0.3); }
}
.co-verdict-engage { color: var(--glow-green); background: rgba(57,255,20,0.08); border: 1px solid rgba(57,255,20,0.25); }
.co-verdict-maybe { color: var(--glow-amber); background: rgba(255,184,0,0.08); border: 1px solid rgba(255,184,0,0.25); }
.co-verdict-skip { color: var(--text-dim); background: rgba(100,100,200,0.06); border: 1px solid rgba(100,100,200,0.15); }

.co-card-time {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  margin-left: auto;
}

.co-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.45rem;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  opacity: 0.6;
  display: block;
  line-height: 1;
  margin-bottom: 0.1rem;
}
.co-card-popout {
  font-size: 1rem;
  color: var(--text-dim);
  text-decoration: none;
  opacity: 0.5;
  transition: opacity 0.15s, color 0.15s;
  line-height: 1;
  flex-shrink: 0;
}
.co-card-popout:hover { opacity: 1; color: var(--glow-cyan); }
.co-card-author {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  padding: 0 0.75rem 0.2rem;
}
.co-card-category {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  font-weight: 600;
  color: var(--glow-purple);
  letter-spacing: 0.06em;
}

.co-card-body { padding: 0.6rem 0.75rem; }
.co-card-text {
  font-size: 0.78rem;
  color: var(--text-body);
  line-height: 1.5;
  margin-bottom: 0.4rem;
}
.co-card-meta {
  display: flex;
  gap: 0.75rem;
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
}
.co-card-angle {
  font-size: 0.65rem;
  color: var(--glow-cyan);
  margin-top: 0.35rem;
  font-style: italic;
}

/* Hot candidate card */
.co-card-hot {
  border-color: rgba(255,140,0,0.35);
  box-shadow: 0 0 12px rgba(255,140,0,0.08);
}
.co-card-hot:hover { border-color: rgba(255,140,0,0.5); }
.co-early-mover {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
  font-weight: 700;
  color: #ff8c00;
  margin-top: 0.4rem;
  padding: 0.3rem 0.5rem;
  background: rgba(255,140,0,0.06);
  border: 1px solid rgba(255,140,0,0.15);
  border-radius: 0.3rem;
  letter-spacing: 0.04em;
}
.co-member-count {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.6rem;
  color: var(--text-dim);
  font-weight: 400;
}

/* HOT filter button accent */
.co-filter-btn[data-verdict="hot_candidate"] {
  color: #ff8c00;
  border-color: rgba(255,140,0,0.25);
}
.co-filter-btn[data-verdict="hot_candidate"]:hover {
  background: rgba(255,140,0,0.1);
  border-color: rgba(255,140,0,0.4);
}
.co-filter-btn[data-verdict="hot_candidate"].active {
  color: #ff8c00;
  background: rgba(255,140,0,0.12);
  border-color: rgba(255,140,0,0.4);
  box-shadow: 0 0 8px rgba(255,140,0,0.1);
}

/* Progress bar */
.co-progress {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border-top: 1px solid var(--border-main);
  background: rgba(0,0,0,0.15);
}
.co-progress-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  animation: co-dot-pulse 1.2s ease-in-out infinite;
}
@keyframes co-dot-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.3); }
}
.co-progress-text {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
  letter-spacing: 0.03em;
}

/* Phase colors */
.co-phase-init .co-progress-dot { background: var(--text-dim); }
.co-phase-init .co-progress-text { color: var(--text-dim); }
.co-phase-intel .co-progress-dot { background: var(--glow-cyan); box-shadow: 0 0 6px rgba(0,255,247,0.5); }
.co-phase-intel .co-progress-text { color: var(--glow-cyan); }
.co-phase-drafting .co-progress-dot { background: var(--glow-magenta); box-shadow: 0 0 6px rgba(255,44,241,0.5); }
.co-phase-drafting .co-progress-text { color: var(--glow-magenta); }
.co-phase-qa .co-progress-dot { background: var(--glow-amber); box-shadow: 0 0 6px rgba(255,184,0,0.5); }
.co-phase-qa .co-progress-text { color: var(--glow-amber); }
.co-phase-polishing .co-progress-dot { background: var(--glow-green); box-shadow: 0 0 6px rgba(57,255,20,0.5); }
.co-phase-polishing .co-progress-text { color: var(--glow-green); }

/* Card actions */
.co-card-actions {
  display: flex;
  gap: 0.35rem;
  padding: 0.5rem 0.75rem;
  border-top: 1px solid var(--border-main);
}
.co-btn-generate, .co-btn-expand, .co-btn-skip {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.35rem 0.65rem;
  border-radius: 0.35rem;
  cursor: pointer;
  transition: all 0.2s;
}
.co-btn-generate {
  background: rgba(57,255,20,0.1);
  border: 1px solid rgba(57,255,20,0.3);
  color: var(--glow-green);
}
.co-btn-generate:hover { background: rgba(57,255,20,0.2); }
.co-btn-generate:disabled { opacity: 0.5; cursor: not-allowed; }
.co-btn-expand {
  background: rgba(0,255,247,0.06);
  border: 1px solid rgba(0,255,247,0.2);
  color: var(--glow-cyan);
}
.co-btn-expand:hover { background: rgba(0,255,247,0.12); }
.co-btn-skip {
  background: transparent;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  margin-left: auto;
}
.co-btn-skip:hover { border-color: rgba(255,51,51,0.3); color: var(--glow-red); }

/* Comments section */
.co-comments-section {
  padding: 0.5rem 0.75rem;
  border-top: 1px solid var(--border-main);
  background: rgba(0,0,0,0.1);
  max-height: 200px;
  overflow-y: auto;
}
.co-comment {
  padding: 0.3rem 0;
  border-bottom: 1px solid rgba(100,100,200,0.06);
  font-size: 0.7rem;
}
.co-comment:last-child { border-bottom: none; }
.co-comment-author {
  font-weight: 600;
  color: var(--glow-purple);
  margin-right: 0.4rem;
  font-size: 0.65rem;
}
.co-comment-text { color: var(--text-body); line-height: 1.4; }
.co-comment-reactions {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  color: var(--text-dim);
  margin-left: 0.3rem;
}
.co-comments-loading, .co-comments-empty {
  font-size: 0.65rem;
  color: var(--text-dim);
  padding: 0.5rem 0.75rem;
  text-align: center;
  font-style: italic;
}

/* Draft cards */
.co-outbox-drafts, .co-outbox-posted {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.co-draft-card {
  background: var(--bg-card);
  border: 1px solid var(--border-main);
  border-radius: 0.65rem;
  overflow: hidden;
}
.co-draft-card:hover { border-color: rgba(0,255,247,0.2); }
.co-fade-in {
  animation: co-slide-in 0.3s ease-out;
}
@keyframes co-slide-in {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

.co-draft-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.65rem;
  border-bottom: 1px solid var(--border-main);
  flex-wrap: wrap;
}
.co-draft-ref {
  font-size: 0.65rem;
  color: var(--text-dim);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.co-qa-badge {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 0.1rem 0.4rem;
  border-radius: 3px;
  border: 1px solid;
}
.co-qa-good { color: var(--glow-green); border-color: rgba(57,255,20,0.3); background: rgba(57,255,20,0.08); }
.co-qa-mid { color: var(--glow-amber); border-color: rgba(255,184,0,0.3); background: rgba(255,184,0,0.08); }
.co-qa-low { color: var(--glow-red); border-color: rgba(255,51,51,0.3); background: rgba(255,51,51,0.08); }
.co-draft-words {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  color: var(--text-dim);
}

.co-draft-body {
  padding: 0.65rem;
  font-size: 0.78rem;
  color: var(--text-body);
  line-height: 1.6;
  white-space: pre-wrap;
}

.co-draft-actions {
  display: flex;
  gap: 0.35rem;
  padding: 0.5rem 0.65rem;
  border-top: 1px solid var(--border-main);
}
.co-btn-copy, .co-btn-posted, .co-btn-regen {
  font-family: 'Chakra Petch', sans-serif;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.6rem;
  border-radius: 0.35rem;
  cursor: pointer;
  transition: all 0.2s;
}
.co-btn-copy {
  background: rgba(0,255,247,0.06);
  border: 1px solid rgba(0,255,247,0.2);
  color: var(--glow-cyan);
}
.co-btn-copy:hover { background: rgba(0,255,247,0.12); }
.co-btn-copy.co-copied { background: rgba(57,255,20,0.15); border-color: rgba(57,255,20,0.3); color: var(--glow-green); }
.co-btn-posted {
  background: rgba(57,255,20,0.1);
  border: 1px solid rgba(57,255,20,0.3);
  color: var(--glow-green);
}
.co-btn-posted:hover { background: rgba(57,255,20,0.2); }
.co-btn-regen {
  background: transparent;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
}
.co-btn-regen:hover { border-color: rgba(255,184,0,0.3); color: var(--glow-amber); }

/* Sources toggle */
.co-sources-toggle {
  border-top: 1px solid var(--border-main);
  padding: 0;
}
.co-sources-summary {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--glow-cyan);
  padding: 0.4rem 0.75rem;
  cursor: pointer;
  user-select: none;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.co-sources-summary::-webkit-details-marker { display: none; }
.co-sources-summary::before {
  content: '\25B6';
  font-size: 0.45rem;
  transition: transform 0.15s;
  color: var(--text-dim);
}
.co-sources-toggle[open] .co-sources-summary::before { transform: rotate(90deg); }
.co-sources-summary:hover { color: #fff; }
.co-sources-body {
  padding: 0 0.75rem 0.5rem;
  max-height: 200px;
  overflow-y: auto;
}
.co-src-group { margin-bottom: 0.4rem; }
.co-src-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  margin-bottom: 0.15rem;
}
.co-src-item {
  font-size: 0.6rem;
  line-height: 1.45;
  color: var(--text-body);
  padding: 0.2rem 0 0.2rem 0.5rem;
  border-left: 2px solid rgba(100,100,200,0.15);
  margin-bottom: 0.15rem;
  word-break: break-word;
}
.co-src-web { border-left-color: rgba(0,255,247,0.25); }
.co-src-x { border-left-color: rgba(74,158,255,0.3); }

/* Posted cards */
.co-posted-card {
  background: rgba(57,255,20,0.03);
  border: 1px solid rgba(57,255,20,0.15);
  border-radius: 0.5rem;
  padding: 0.5rem 0.65rem;
}
.co-posted-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.25rem;
}
.co-posted-group {
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--glow-green);
}
.co-posted-time {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.55rem;
  color: var(--text-dim);
}
.co-posted-text {
  font-size: 0.7rem;
  color: var(--text-body);
  opacity: 0.7;
}

/* Empty states */
.co-empty {
  font-size: 0.7rem;
  color: rgba(138,154,180,0.5);
  text-align: center;
  padding: 1.5rem 0.5rem;
  font-style: italic;
}

/* Responsive */
@media (max-width: 900px) {
  .co-container { flex-direction: column; }
  .co-inbound, .co-outbox { flex: 1; width: 100%; }
}

/* Service Health Monitor */
.svc-restart-warn { color: #ffb800; font-weight: 600; }
.svc-restart-crit { color: #ff4444; font-weight: 700; }
.svc-error-line { font-family: 'Share Tech Mono', monospace; font-size: 0.65rem; color: #ff6b6b; }
.svc-crit-badge { font-size: 0.55rem; padding: 0.1rem 0.35rem; border-radius: 0.2rem; background: rgba(255,68,68,0.12); color: #ff6b6b; border: 1px solid rgba(255,68,68,0.25); margin-left: 0.4rem; letter-spacing: 0.05em; }
.svc-row-failed { background: rgba(255,68,68,0.04); }
.svc-row-failed td { border-bottom-color: rgba(255,68,68,0.15); }

/* Comment Ops — Draft post reference line */
.co-draft-post-ref {
  font-size: 0.65rem;
  color: var(--text-dim);
  padding: 0.35rem 0.65rem 0;
  line-height: 1.4;
  opacity: 0.7;
}

/* Comment Ops — Posted card post reference */
.co-posted-post-ref {
  font-size: 0.6rem;
  color: var(--text-dim);
  padding: 0 0.5rem;
  margin-bottom: 0.25rem;
  opacity: 0.6;
  line-height: 1.3;
}

/* Verdict tags in outbox cards — smaller inline version */
.co-draft-header .co-verdict-tag,
.co-posted-header .co-verdict-tag {
  font-size: 0.55rem;
  padding: 0.1rem 0.4rem;
  flex-shrink: 0;
}

/* ── Comment Ops: Outbox Tabs ── */
.co-outbox-tabs {
  display: flex;
  gap: 0;
  margin: 0.5rem 0;
  border-bottom: 1px solid var(--border-main);
}
.co-outbox-tab {
  background: none;
  border: none;
  color: var(--text-dim);
  font-family: "Share Tech Mono", monospace;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 0.4rem 0.8rem;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all 0.15s;
}
.co-outbox-tab:hover { color: var(--text-body); }
.co-outbox-tab.active {
  color: #fff;
  border-bottom-color: var(--accent, #6366f1);
}

/* ── Draft Status Badges ── */
.co-draft-status-badge {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.55rem;
  font-weight: 700;
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  flex-shrink: 0;
}
.co-status-draft {
  background: rgba(99,102,241,0.2);
  color: #818cf8;
}
.co-status-revised {
  background: rgba(251,191,36,0.2);
  color: #fbbf24;
}

/* ── Draft Post Reference Line ── */
.co-draft-post-ref {
  font-size: 0.65rem;
  color: var(--text-dim);
  padding: 0.35rem 0.65rem 0;
  line-height: 1.4;
  opacity: 0.7;
}

/* ── Inline Edit ── */
.co-edit-area {
  padding: 0.5rem 0.65rem;
}
.co-edit-textarea {
  width: 100%;
  min-height: 120px;
  background: rgba(0,0,0,0.3);
  border: 1px solid var(--accent, #6366f1);
  border-radius: 4px;
  color: #fff;
  font-family: inherit;
  font-size: 0.75rem;
  line-height: 1.5;
  padding: 0.5rem;
  resize: vertical;
  outline: none;
}
.co-edit-textarea:focus {
  border-color: #818cf8;
  box-shadow: 0 0 0 1px rgba(129,140,248,0.3);
}
.co-edit-actions {
  display: flex;
  gap: 0.4rem;
  margin-top: 0.4rem;
}
.co-btn-save-edit {
  background: var(--accent, #6366f1);
  color: #fff;
  border: none;
  padding: 0.3rem 0.7rem;
  font-family: "Share Tech Mono", monospace;
  font-size: 0.6rem;
  font-weight: 700;
  border-radius: 3px;
  cursor: pointer;
}
.co-btn-save-edit:hover { background: #818cf8; }
.co-btn-cancel-edit {
  background: rgba(255,255,255,0.05);
  color: var(--text-dim);
  border: 1px solid var(--border-main);
  padding: 0.3rem 0.7rem;
  font-family: "Share Tech Mono", monospace;
  font-size: 0.6rem;
  font-weight: 700;
  border-radius: 3px;
  cursor: pointer;
}
.co-btn-cancel-edit:hover { color: #fff; }

/* ── Draft Action Buttons (updated) ── */
.co-btn-edit, .co-btn-open-post, .co-btn-mark-sent, .co-btn-skip-draft {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  padding: 0.25rem 0.5rem;
  font-family: "Share Tech Mono", monospace;
  font-size: 0.6rem;
  font-weight: 700;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.15s;
}
.co-btn-edit:hover { color: #818cf8; border-color: #818cf8; }
.co-btn-open-post:hover { color: #60a5fa; border-color: #60a5fa; }
.co-btn-mark-sent {
  background: rgba(34,197,94,0.1);
  border-color: rgba(34,197,94,0.3);
  color: #4ade80;
}
.co-btn-mark-sent:hover { background: rgba(34,197,94,0.2); border-color: #4ade80; }
.co-btn-skip-draft:hover { color: #f87171; border-color: #f87171; }
.co-btn-mark-sent:disabled, .co-btn-edit:disabled,
.co-btn-open-post:disabled, .co-btn-skip-draft:disabled {
  opacity: 0.3;
  cursor: default;
}

/* ── Sent Card ── */
.co-sent-card {
  background: var(--card-bg, rgba(255,255,255,0.02));
  border: 1px solid var(--border-main);
  border-radius: 6px;
  margin-bottom: 0.5rem;
  overflow: hidden;
}
.co-sent-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.65rem;
  border-bottom: 1px solid var(--border-main);
  flex-wrap: wrap;
}
.co-sent-badge {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.55rem;
  font-weight: 700;
  padding: 0.1rem 0.35rem;
  border-radius: 3px;
  background: rgba(34,197,94,0.2);
  color: #4ade80;
  flex-shrink: 0;
}
.co-norev-badge {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.5rem;
  font-weight: 700;
  padding: 0.1rem 0.3rem;
  border-radius: 3px;
  background: rgba(99,102,241,0.15);
  color: rgba(129,140,248,0.7);
  flex-shrink: 0;
}
.co-revised-badge {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.5rem;
  font-weight: 700;
  padding: 0.1rem 0.3rem;
  border-radius: 3px;
  background: rgba(251,191,36,0.15);
  color: #fbbf24;
  flex-shrink: 0;
}
.co-sent-group {
  font-size: 0.65rem;
  color: var(--text-dim);
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.co-sent-time {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.55rem;
  color: var(--text-dim);
}
.co-sent-post-ref {
  font-size: 0.6rem;
  color: var(--text-dim);
  padding: 0.35rem 0.65rem 0;
  opacity: 0.6;
  line-height: 1.3;
}
.co-sent-text {
  font-size: 0.7rem;
  color: var(--text-body);
  padding: 0.35rem 0.65rem 0.5rem;
  line-height: 1.5;
}

/* ── Revision History ── */
.co-revision-history {
  border-top: 1px solid var(--border-main);
}
.co-revision-summary {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.55rem;
  font-weight: 700;
  color: var(--text-dim);
  padding: 0.4rem 0.65rem;
  cursor: pointer;
  user-select: none;
}
.co-revision-summary:hover { color: #fff; }
.co-revision-list {
  padding: 0 0.65rem 0.5rem;
}
.co-revision-item {
  border-left: 2px solid var(--border-main);
  padding: 0.3rem 0 0.3rem 0.5rem;
  margin-bottom: 0.3rem;
}
.co-revision-meta {
  display: flex;
  gap: 0.4rem;
  align-items: center;
  margin-bottom: 0.15rem;
}
.co-revision-ver {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.55rem;
  font-weight: 700;
  color: var(--text-dim);
}
.co-revision-source {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.5rem;
  font-weight: 700;
  padding: 0 0.25rem;
  border-radius: 2px;
}
.co-rev-src-ai {
  background: rgba(99,102,241,0.15);
  color: #818cf8;
}
.co-rev-src-user {
  background: rgba(251,191,36,0.15);
  color: #fbbf24;
}
.co-revision-qa {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.5rem;
  color: var(--text-dim);
}
.co-revision-time {
  font-family: "Share Tech Mono", monospace;
  font-size: 0.5rem;
  color: rgba(138,154,180,0.5);
}
.co-revision-text {
  font-size: 0.6rem;
  color: var(--text-dim);
  line-height: 1.4;
  max-height: 80px;
  overflow-y: auto;
  opacity: 0.7;
}

/* ── Outbox Verdict Tags (smaller) ── */
.co-draft-header .co-verdict-tag,
.co-sent-header .co-verdict-tag {
  font-size: 0.55rem;
  padding: 0.1rem 0.4rem;
  flex-shrink: 0;
}

/* ── Posted Post Ref (keep for compat) ── */
.co-posted-post-ref {
  font-size: 0.6rem;
  color: var(--text-dim);
  padding: 0 0.5rem;
  margin-bottom: 0.25rem;
  opacity: 0.6;
  line-height: 1.3;
}

/* ═══════════════════════════════════════════════════════════
   COMMENT OPS — KANBAN BOARD + MODAL
   ═══════════════════════════════════════════════════════════ */

/* ── Comment Ops Modal (overlay) ── */
.co-modal {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.75);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.co-modal-content {
  background: var(--bg-card, #1a1a2e);
  border: 1px solid var(--border, rgba(255,255,255,0.1));
  border-radius: 12px;
  padding: 1.5rem;
  max-width: 680px;
  width: 92%;
  max-height: 85vh;
  overflow-y: auto;
  position: relative;
}
.co-modal-close {
  position: absolute;
  top: 0.75rem; right: 0.75rem;
  background: none; border: none;
  color: var(--text-dim, #888);
  font-size: 1.5rem;
  cursor: pointer; line-height: 1;
}
.co-modal-close:hover { color: #fff; }

/* ── Kanban Board Layout ── */
.co-kanban-board {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.75rem;
  margin-top: 1rem;
}

.cok-column {
  background: rgba(0,0,0,0.2);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  padding: 0.5rem;
  min-height: 200px;
  display: flex;
  flex-direction: column;
}

.cok-column-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.4rem 0.5rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.cok-column-label {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.cok-column-count {
  font-size: 0.55rem;
  color: var(--text-dim, #888);
  background: rgba(255,255,255,0.06);
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  font-weight: 600;
}

.cok-cards {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  max-height: 500px;
}

/* ── Kanban Card ── */
.cok-card {
  background: var(--bg-card, #1a1a2e);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  padding: 0.5rem 0.6rem;
  cursor: pointer;
  transition: all 0.15s ease;
}
.cok-card:hover {
  border-color: rgba(0,255,247,0.25);
  background: rgba(0,255,247,0.03);
  transform: translateY(-1px);
}
.cok-card-hot {
  border-color: rgba(255,140,0,0.3);
  background: rgba(255,140,0,0.04);
}
.cok-card-hot:hover {
  border-color: rgba(255,140,0,0.5);
  background: rgba(255,140,0,0.08);
}

.cok-card-group {
  font-size: 0.5rem;
  color: var(--glow-cyan, #00fff7);
  font-weight: 600;
  letter-spacing: 0.03em;
  margin-bottom: 0.25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cok-card-preview {
  font-size: 0.6rem;
  color: var(--text-body, #c8ccd4);
  line-height: 1.4;
  margin-bottom: 0.3rem;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cok-card-footer {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  flex-wrap: wrap;
}

.cok-card-time {
  font-size: 0.45rem;
  color: var(--text-dim, #888);
  margin-left: auto;
}

/* ── Generating Card ── */
.cok-card-generating {
  border-color: rgba(57,255,20,0.2);
  background: rgba(57,255,20,0.03);
}
.cok-gen-bar {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0;
}
.cok-gen-dot {
  width: 6px; height: 6px;
  background: var(--glow-green, #39ff14);
  border-radius: 50%;
  animation: cok-pulse 1.2s ease-in-out infinite;
}
@keyframes cok-pulse {
  0%, 100% { opacity: 0.3; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.2); }
}
.cok-gen-text {
  font-size: 0.55rem;
  color: var(--glow-green, #39ff14);
  font-style: italic;
}

/* ── Revision Badge ── */
.cok-rev-badge {
  font-size: 0.4rem;
  padding: 0.05rem 0.3rem;
  border-radius: 3px;
  background: rgba(162,89,255,0.12);
  color: var(--glow-purple, #a259ff);
  border: 1px solid rgba(162,89,255,0.25);
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* ── Empty Column ── */
.cok-empty {
  font-size: 0.55rem;
  color: var(--text-dim, #888);
  text-align: center;
  padding: 1.5rem 0.5rem;
  opacity: 0.5;
  font-style: italic;
}

/* ── Modal Sections ── */
.cok-modal-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 0.75rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.cok-modal-group {
  font-size: 0.65rem;
  color: var(--text-body, #c8ccd4);
  font-weight: 600;
}

.cok-modal-words {
  font-size: 0.5rem;
  color: var(--text-dim, #888);
  padding: 0.1rem 0.3rem;
  background: rgba(255,255,255,0.04);
  border-radius: 3px;
}

.cok-modal-link {
  font-size: 0.6rem;
  color: var(--glow-cyan, #00fff7);
  text-decoration: none;
  margin-left: auto;
  font-weight: 600;
}
.cok-modal-link:hover { text-decoration: underline; }

.cok-modal-section {
  margin-bottom: 0.75rem;
  padding: 0.6rem 0.7rem;
  background: rgba(0,0,0,0.2);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.04);
}

.cok-modal-section-title {
  font-size: 0.5rem;
  color: var(--text-dim, #888);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}

.cok-modal-post-text {
  font-size: 0.7rem;
  color: var(--text-body, #c8ccd4);
  line-height: 1.5;
  white-space: pre-wrap;
  max-height: 150px;
  overflow-y: auto;
}

.cok-modal-post-meta {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.4rem;
  font-size: 0.5rem;
  color: var(--text-dim, #888);
}

.cok-modal-angle {
  margin-top: 0.4rem;
  font-size: 0.55rem;
  color: var(--glow-amber, #ffb800);
  font-weight: 600;
}

.cok-modal-draft-text {
  font-size: 0.75rem;
  color: #e0e4f0;
  line-height: 1.6;
  white-space: pre-wrap;
  max-height: 250px;
  overflow-y: auto;
}

/* ── Modal Details (Sources / Revisions) ── */
.cok-modal-details {
  margin-top: 0.5rem;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 6px;
  overflow: hidden;
}
.cok-modal-details-summary {
  font-size: 0.5rem;
  color: var(--text-dim, #888);
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.4rem 0.6rem;
  cursor: pointer;
  background: rgba(0,0,0,0.15);
  user-select: none;
}
.cok-modal-details-summary:hover { color: var(--text-body, #c8ccd4); }
.cok-modal-details-body {
  padding: 0.5rem 0.6rem;
}

/* ── Modal Action Buttons ── */
.cok-modal-actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.75rem;
  padding-top: 0.6rem;
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* ── Stage Badges ── */
.cok-stage-badge {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  border-radius: 4px;
  font-size: 0.55rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.cok-stage-pending {
  background: rgba(255,184,0,0.15);
  color: #ffb800;
  border: 1px solid rgba(255,184,0,0.3);
}
.cok-stage-ready {
  background: rgba(0,255,247,0.15);
  color: #00fff7;
  border: 1px solid rgba(0,255,247,0.3);
}
.cok-stage-sent {
  background: rgba(57,255,20,0.15);
  color: #39ff14;
  border: 1px solid rgba(57,255,20,0.3);
}

/* ── Kanban Section Label ── */
.co-kanban-section {
  margin-top: 1.5rem;
}
.co-kanban-section .co-section-header {
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--text-heading, #e0e4f0);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

/* ── Responsive: Stack columns on narrow screens ── */
@media (max-width: 900px) {
  .co-kanban-board {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  .cok-column {
    min-height: 100px;
  }
  .cok-cards {
    max-height: 300px;
  }
}

/* ── Inbound feed scroll cap ── */
.co-thread-list {
  max-height: 600px;
  overflow-y: auto;
}

/* ── Pending Card Actions (inline GENERATE + SKIP) ── */
.cok-pending-actions {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.35rem;
}
.cok-btn-gen {
  flex: 1;
  padding: 0.25rem 0.4rem;
  border-radius: 5px;
  border: 1px solid rgba(57,255,20,0.3);
  background: rgba(57,255,20,0.1);
  color: var(--glow-green, #39ff14);
  cursor: pointer;
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  transition: all 0.15s;
}
.cok-btn-gen:hover { background: rgba(57,255,20,0.2); }
.cok-btn-gen:disabled { opacity: 0.5; cursor: not-allowed; }
.cok-btn-skip-inline {
  padding: 0.25rem 0.4rem;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.03);
  color: var(--text-dim, #888);
  cursor: pointer;
  font-size: 0.5rem;
  font-weight: 600;
  transition: all 0.15s;
}
.cok-btn-skip-inline:hover { border-color: rgba(255,51,51,0.3); color: var(--glow-red, #ff3333); }

/* ── Pending card cursor ── */
.cok-card-pending { cursor: pointer; }

/* ═══ Sidebar Collapse Toggle ═══ */
.sidebar {
  transition: width 0.25s ease;
  overflow: hidden;
}
.main-content {
  transition: margin-left 0.25s ease;
}
.sidebar-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.6rem;
  cursor: pointer;
  border: none;
  background: rgba(0,255,247,0.04);
  border-top: 1px solid var(--border-main, rgba(255,255,255,0.06));
  color: var(--text-dim, #888);
  font-size: 0.9rem;
  transition: all 0.2s;
  width: 100%;
}
.sidebar-toggle:hover {
  background: rgba(0,255,247,0.08);
  color: var(--glow-cyan, #00fff7);
}
.sidebar-toggle .toggle-label {
  font-size: 0.55rem;
  margin-left: 0.5rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: 'Chakra Petch', sans-serif;
  font-weight: 600;
}

/* Collapsed state */
.sidebar.sidebar-collapsed {
  width: 56px;
}
.sidebar.sidebar-collapsed .sidebar-brand h1,
.sidebar.sidebar-collapsed .sidebar-brand p,
.sidebar.sidebar-collapsed .nav-item span:not(.nav-icon),
.sidebar.sidebar-collapsed .sidebar-footer,
.sidebar.sidebar-collapsed .toggle-label {
  display: none;
}
.sidebar.sidebar-collapsed .nav-item {
  justify-content: center;
  padding: 0.75rem;
  border-left: none;
}
.sidebar.sidebar-collapsed .sidebar-brand {
  padding: 0.75rem 0.5rem;
  text-align: center;
}
.sidebar.sidebar-collapsed + .main-content,
.sidebar-collapsed ~ .main-content {
  margin-left: 56px;
}
/* Also handle via JS class on main-content */
.main-content.sidebar-is-collapsed {
  margin-left: 56px;
}

/* ═══ Card Metrics Line ═══ */
.cok-card-metrics {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin: 0.2rem 0;
  font-size: 0.45rem;
  font-family: 'Share Tech Mono', monospace;
  color: var(--text-dim, #888);
}
.cok-card-metrics span {
  white-space: nowrap;
}
.cok-metric-score {
  color: var(--glow-cyan, #00fff7);
  font-weight: 700;
}
.cok-metric-em {
  color: var(--glow-amber, #ffb800);
  font-weight: 700;
}

/* ═══ Modal Metrics Grid ═══ */
.cok-modal-metrics-grid {
  padding: 0.5rem 0.7rem;
}
.cok-metrics-row {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.cok-metric-box {
  flex: 1;
  min-width: 60px;
  text-align: center;
  padding: 0.4rem 0.3rem;
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 6px;
}
.cok-metric-val {
  font-family: 'Share Tech Mono', monospace;
  font-size: 0.85rem;
  font-weight: 700;
  color: #e0e4f0;
  line-height: 1;
}
.cok-metric-lbl {
  font-size: 0.4rem;
  color: var(--text-dim, #888);
  letter-spacing: 0.08em;
  font-weight: 600;
  margin-top: 0.2rem;
  text-transform: uppercase;
}
.cok-metric-hot .cok-metric-val {
  color: var(--glow-amber, #ffb800);
}

/* ═══ Sent Timestamp on Cards ═══ */
.cok-sent-stamp {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin: 0.2rem 0;
  font-size: 0.45rem;
  font-family: 'Share Tech Mono', monospace;
  color: var(--glow-green, #39ff14);
}
.cok-sent-label {
  font-weight: 700;
  font-size: 0.4rem;
  letter-spacing: 0.08em;
  padding: 0.05rem 0.25rem;
  border-radius: 3px;
  background: rgba(57,255,20,0.1);
  border: 1px solid rgba(57,255,20,0.2);
}
.cok-sent-abs {
  color: var(--text-dim, #888);
  font-size: 0.4rem;
}

/* ── Source Indicators on Cards ── */
.cok-card-sources {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  margin: 0.15rem 0;
}
.cok-src-tag {
  font-size: 0.4rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 0.05rem 0.3rem;
  border-radius: 3px;
  font-family: 'Share Tech Mono', monospace;
}
.cok-src-web {
  background: rgba(0,255,247,0.1);
  color: var(--glow-cyan, #00fff7);
  border: 1px solid rgba(0,255,247,0.2);
}
.cok-src-x {
  background: rgba(162,89,255,0.1);
  color: var(--glow-purple, #a259ff);
  border: 1px solid rgba(162,89,255,0.2);
}
.cok-src-none {
  font-size: 0.4rem;
  color: var(--text-dim, #888);
  opacity: 0.4;
  font-style: italic;
}

/* Run error detail panel */
.run-error-detail { background: rgba(255,59,48,0.08); border-left: 3px solid #ff3b30; padding: 0.5rem 0.75rem; margin-bottom: 0.5rem; font-family: monospace; font-size: 0.7rem; color: #ff6b6b; white-space: pre-wrap; word-break: break-word; max-height: 200px; overflow-y: auto; }

/* === API Health Cards === */
.ahc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 0.75rem; margin-bottom: 1rem; }
.ahc-card { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 8px; padding: 0.75rem; transition: border-color 0.2s; }
.ahc-card.ahc-ok { border-left: 3px solid #00ff88; }
.ahc-card.ahc-warn { border-left: 3px solid #ffb800; }
.ahc-card.ahc-fail { border-left: 3px solid #ff4444; background: rgba(255,68,68,0.05); }
.ahc-card.ahc-critical .ahc-name::after { content: 'CRITICAL'; font-size: 0.5rem; margin-left: 0.4rem; padding: 0.1rem 0.3rem; border-radius: 3px; background: rgba(255,68,68,0.2); color: #ff4444; vertical-align: middle; }
.ahc-card-header { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.5rem; }
.ahc-icon { font-size: 1.1rem; }
.ahc-ok .ahc-icon { color: #00ff88; }
.ahc-warn .ahc-icon { color: #ffb800; }
.ahc-fail .ahc-icon { color: #ff4444; }
.ahc-name { font-weight: 700; font-size: 0.8rem; color: #fff; text-transform: uppercase; letter-spacing: 0.05em; }
.ahc-card-body { font-size: 0.7rem; color: var(--text-dim, #aaa); }
.ahc-latency { margin-bottom: 0.25rem; }
.ahc-credits { color: var(--glow-cyan, #00fff7); font-size: 0.65rem; }
.ahc-model { color: var(--glow-purple, #a259ff); font-size: 0.65rem; font-family: monospace; }
.ahc-error { color: #ff6b6b; font-size: 0.6rem; margin-top: 0.25rem; word-break: break-word; }
.ahc-card-footer { font-size: 0.6rem; color: var(--text-dim, #666); margin-top: 0.5rem; border-top: 1px solid rgba(255,255,255,0.05); padding-top: 0.35rem; }
/* Alerts */
.ahc-alerts { display: flex; flex-direction: column; gap: 0.35rem; }
.ahc-alert { display: flex; gap: 0.5rem; font-size: 0.7rem; padding: 0.4rem 0.6rem; border-radius: 4px; border-left: 3px solid #ffb800; background: rgba(255,184,0,0.05); }
.ahc-sev-crit { border-left-color: #ff4444; background: rgba(255,68,68,0.05); }
.ahc-alert-resolved { opacity: 0.5; }
.ahc-alert-time { color: var(--text-dim, #888); white-space: nowrap; min-width: 60px; }
.ahc-alert-msg { color: #ddd; word-break: break-word; }



/* ===== Media Lab v3 ===== */
.ml-subtab-panel { display:none; }
.ml-subtab-panel.active { display:block; }
.ml-filters { display:flex; gap:10px; padding:12px 0 6px; flex-wrap:wrap; }
.ml-select { background:#1a2332; color:#c8d6e5; border:1px solid #2d3a4a; padding:8px 12px; border-radius:6px; font-family:'Share Tech Mono',monospace; font-size:12px; cursor:pointer; }
.ml-select:hover { border-color:#00d4aa; }
.ml-results-count { color:#6b7b8d; font-size:12px; padding:2px 0 8px; font-family:'Share Tech Mono',monospace; }
.ml-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:16px; }
.ml-card { background:#141e2b; border:1px solid #2d3a4a; border-radius:10px; padding:16px; transition:border-color .2s; }
.ml-card:hover { border-color:#00d4aa44; }
.ml-card-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.ml-creator { color:#00d4aa; font-weight:600; font-size:14px; }
.ml-platform { font-weight:700; font-size:14px; }
.ml-card-stats { display:flex; align-items:center; gap:8px; margin-bottom:12px; font-family:'Share Tech Mono',monospace; font-size:12px; color:#8a9ab4; }
.ml-stat-big { color:#fff; font-weight:600; font-size:14px; }
.ml-stat { color:#8a9ab4; }
.ml-stat-sep { color:#2d3a4a; }

/* Thumbnail media card */
.ml-media-link { text-decoration:none; display:block; }
.ml-media-card { position:relative; border-radius:8px; overflow:hidden; margin-bottom:12px; background:#0a0f18; cursor:pointer; }
.ml-thumb { width:100%; height:auto; display:block; max-height:420px; object-fit:cover; transition:opacity .2s; }
.ml-media-card:hover .ml-thumb { opacity:.85; }
.ml-thumb-err .ml-thumb { display:none; }
.ml-thumb-err { display:flex; align-items:center; justify-content:center; min-height:120px; }
.ml-play-overlay { position:absolute; top:0; left:0; right:0; bottom:0; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,.25); transition:background .2s; }
.ml-media-card:hover .ml-play-overlay { background:rgba(0,0,0,.4); }
.ml-play-circle { width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 2px 12px rgba(0,0,0,.4); transition:transform .2s; }
.ml-media-card:hover .ml-play-circle { transform:scale(1.1); }
.ml-play-tri { color:#fff; font-size:22px; margin-left:4px; }
.ml-media-badge { position:absolute; top:8px; right:8px; background:rgba(0,0,0,.6); padding:2px 8px; border-radius:4px; font-size:12px; font-weight:700; }
.ml-media-noimg { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:30px; border:1px solid #2d3a4a; }
.ml-media-label { color:#c8d6e5; font-family:'Share Tech Mono',monospace; font-size:13px; }

.ml-badges { display:flex; gap:8px; margin-bottom:8px; flex-wrap:wrap; }
.ml-badge { padding:3px 10px; border-radius:4px; font-size:10px; font-family:'Share Tech Mono',monospace; font-weight:600; }
.ml-hook { background:#0a0f18; border-left:3px solid #00d4aa; padding:10px 14px; margin-bottom:10px; border-radius:0 6px 6px 0; font-size:13px; color:#c8d6e5; line-height:1.5; }
.ml-viral { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:8px; }
.ml-viral-tag { background:#1a2332; color:#ffb74d; border:1px solid #ffb74d33; padding:2px 8px; border-radius:4px; font-size:10px; font-family:'Share Tech Mono',monospace; text-transform:capitalize; }
.ml-details { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }
.ml-pill { background:#1a2332; color:#8a9ab4; border:1px solid #2d3a4a; padding:2px 8px; border-radius:4px; font-size:10px; font-family:'Share Tech Mono',monospace; text-transform:capitalize; }
.ml-recipe-toggle { cursor:pointer; color:#4fc3f7; font-size:12px; padding:4px 0; font-family:'Share Tech Mono',monospace; }
.ml-recipe-toggle:hover { color:#00d4aa; }
.ml-recipe { background:#0a0f18; padding:12px; border-radius:6px; font-size:12px; color:#8a9ab4; line-height:1.6; white-space:pre-wrap; margin-top:6px; }

/* Format Breakdown */
.ml-section-title { color:#00d4aa; font-size:14px; font-weight:700; font-family:'Chakra Petch',sans-serif; padding:16px 0 10px; border-bottom:1px solid #2d3a4a; margin-bottom:12px; }
.ml-format-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; margin-bottom:24px; }
.ml-format-card { background:#141e2b; border:1px solid #2d3a4a; border-radius:10px; padding:16px; }
.ml-format-name { font-size:15px; font-weight:700; color:#fff; margin-bottom:4px; font-family:'Chakra Petch',sans-serif; }
.ml-format-count { font-size:12px; color:#6b7b8d; margin-bottom:10px; }
.ml-format-stats { display:flex; flex-direction:column; gap:4px; margin-bottom:10px; }
.ml-format-stats div { display:flex; justify-content:space-between; }
.ml-stat-label { color:#6b7b8d; font-size:12px; }
.ml-stat-val { color:#fff; font-weight:600; font-size:13px; }
.ml-format-creators { font-size:11px; color:#8a9ab4; }
.ml-creator-chip { display:inline-block; background:#0a0f18; padding:2px 8px; border-radius:4px; margin:2px 4px 2px 0; font-size:11px; }
.ml-plat-row { display:flex; gap:14px; margin-bottom:24px; flex-wrap:wrap; }
.ml-plat-card { background:#141e2b; border:1px solid #2d3a4a; border-radius:10px; padding:16px; flex:1; min-width:140px; text-align:center; }
.ml-plat-name { font-weight:700; font-size:14px; color:#fff; margin-bottom:4px; }
.ml-plat-count { font-size:12px; color:#6b7b8d; }
.ml-plat-avg { font-size:14px; color:#00d4aa; font-weight:600; margin-top:6px; }
.ml-caps-row { display:flex; gap:10px; margin-bottom:24px; flex-wrap:wrap; }
.ml-caps-card { background:#141e2b; border:1px solid #2d3a4a; border-radius:8px; padding:12px; flex:1; min-width:120px; text-align:center; }
.ml-caps-type { color:#fff; font-weight:600; font-size:13px; text-transform:capitalize; }
.ml-caps-count { color:#6b7b8d; font-size:11px; }
.ml-caps-avg { color:#00d4aa; font-weight:600; font-size:13px; margin-top:4px; }
.ml-matrix-wrap { overflow-x:auto; margin-bottom:24px; }
.ml-matrix { width:100%; border-collapse:collapse; font-size:12px; font-family:'Share Tech Mono',monospace; }
.ml-matrix th,.ml-matrix td { padding:8px 10px; border:1px solid #2d3a4a; text-align:center; }
.ml-matrix th { background:#1a2332; color:#8a9ab4; text-transform:capitalize; font-size:11px; }
.ml-matrix td { color:#fff; }
.ml-matrix-label { text-align:left!important; color:#c8d6e5; text-transform:capitalize; font-weight:600; }
.ml-matrix-empty { color:#3a4a5a; }
.ml-hooks-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(360px,1fr)); gap:16px; }
.ml-hook-card { background:#141e2b; border:1px solid #2d3a4a; border-radius:10px; padding:16px; }
.ml-hook-card:hover { border-color:#00d4aa44; }
.ml-hook-text { font-size:15px; color:#fff; line-height:1.5; margin-bottom:10px; font-style:italic; }
.ml-hook-meta { display:flex; align-items:center; gap:10px; font-size:12px; color:#8a9ab4; margin-bottom:10px; flex-wrap:wrap; }
.ml-hook-watch { color:#4fc3f7; text-decoration:none; font-weight:600; font-size:12px; }
.ml-hook-watch:hover { color:#00d4aa; }

/* Media Lab v6 — gradient video cards */
.ml-video-card {
  position: relative;
  border-radius: 10px;
  border: 1px solid;
  overflow: hidden;
  margin-bottom: 12px;
  cursor: pointer;
  transition: transform .2s, box-shadow .2s;
}
.ml-video-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
.ml-video-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  gap: 12px;
}
.ml-video-glow {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 1;
  pointer-events: none;
}
.ml-plat-logo {
  width: 36px;
  height: 36px;
  opacity: .6;
}
.ml-play-btn {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,.5);
  transition: transform .2s, box-shadow .2s;
}
.ml-video-card:hover .ml-play-btn {
  transform: scale(1.12);
  box-shadow: 0 6px 24px rgba(0,0,0,.6);
}
.ml-play-btn svg {
  margin-left: 3px;
}
.ml-video-label {
  font-family: 'Share Tech Mono', monospace;
  font-size: 12px;
  color: #5a6a7e;
  letter-spacing: 1px;
  text-transform: uppercase;
}
