/* ═══════════════════════════════════════════════════════════════════════════════
   DASHBOARD — Performance dashboard module cards
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── GRID ──────────────────────────────────────────────────────────────────── */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* ── MODULE CARD ───────────────────────────────────────────────────────────── */
.dash-module {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08),0 1px 4px rgba(0,0,0,0.04);
  overflow: hidden;
  position: relative;
  animation: dashFadeInUp 0.5s ease backwards;
  display: flex;
  flex-direction: column;
}
.dash-module::after {
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 4%,transparent) 0%,transparent 35%);
  opacity:0;transition:opacity 0.25s ease;pointer-events:none;z-index:0;
}
.dash-module-body { flex: 1; min-height: 0; }
.dash-module:hover::after { opacity:1; }
.dash-module:hover { box-shadow: 0 6px 28px rgba(0,0,0,0.12),0 2px 6px rgba(0,0,0,0.06); border-color: var(--border2); }
.dash-module.full-width { grid-column: 1 / -1; }

@keyframes dashFadeInUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dash-module:nth-child(1){animation-delay:0.05s}
.dash-module:nth-child(2){animation-delay:0.11s}
.dash-module:nth-child(3){animation-delay:0.17s}
.dash-module:nth-child(4){animation-delay:0.23s}
.dash-module:nth-child(5){animation-delay:0.29s}
.dash-module:nth-child(6){animation-delay:0.35s}
.dash-module:nth-child(7){animation-delay:0.41s}

/* Drag handle */
.dash-drag-handle {
  position: absolute; bottom: 10px; left: 14px;
  width: 20px; height: 20px; cursor: grab;
  opacity: 0.18; transition: opacity 0.2s;
  color: var(--text3); display: flex; align-items: center; justify-content: center;
}
.dash-module:hover .dash-drag-handle { opacity: 0.5; }
.dash-module:hover .dash-drag-handle:hover { opacity: 1; }
.dash-drag-handle svg { width: 14px; height: 14px; }

/* Resize button */
.dash-resize-btn {
  background: none; border: none; cursor: pointer; padding: 4px;
  color: var(--text3); opacity: 0.2; transition: opacity 0.2s, color 0.15s;
  display: flex; align-items: center; justify-content: center;
}
.dash-module-header .dash-resize-btn:last-child { margin-left: auto; }
.dash-module-meta ~ .dash-resize-btn { margin-left: 0; }
.dash-module:hover .dash-resize-btn { opacity: 0.55; }
.dash-module:hover .dash-resize-btn:hover { opacity: 1; color: var(--accent); }
.dash-resize-btn svg { width: 14px; height: 14px; }

/* ── Drag: ghost (the lifted module) ── */
.dash-module.drag-ghost {
  position: fixed !important;
  z-index: 1000;
  pointer-events: none;
  opacity: 0.92;
  transform: scale(1.03);
  box-shadow: 0 20px 60px rgba(0,0,0,0.35), 0 4px 16px rgba(0,0,0,0.15);
  transition: transform 0.18s cubic-bezier(0.34,1.18,0.64,1), opacity 0.18s ease;
  cursor: grabbing;
}
.dash-module.drag-ghost.drop-settle {
  transition: left 0.22s cubic-bezier(0.34,1.18,0.64,1),
              top 0.22s cubic-bezier(0.34,1.18,0.64,1),
              transform 0.22s cubic-bezier(0.34,1.18,0.64,1),
              opacity 0.22s ease;
  transform: scale(1);
  opacity: 1;
}

/* ── Drag: placeholder (holds grid slot) ── */
.dash-placeholder {
  background: color-mix(in oklch, var(--accent) 8%, transparent);
  border: 2px dashed var(--accent);
  border-radius: var(--radius-lg);
  pointer-events: none;
  min-height: 80px;
}
.dash-placeholder.full-width { grid-column: 1 / -1; }

/* ── Auto-refresh pulse after optimisation ── */
.dash-grid.dash-refreshed .dash-module { animation: dashRefreshPulse 0.8s ease; }
@keyframes dashRefreshPulse {
  0%   { border-color: var(--border); }
  30%  { border-color: var(--green); box-shadow: 0 0 8px color-mix(in srgb, var(--green) 20%, transparent); }
  100% { border-color: var(--border); }
}

/* ── Drag: grid state ── */
.dash-grid.dragging { overflow: visible; }

/* ── FLIP animation for modules shifting during drag ── */
.dash-module.flip-animate {
  transition: transform 0.28s cubic-bezier(0.2, 0, 0, 1);
}

/* Module header */
.dash-module-header {
  display: flex; align-items: center; gap: 8px;
  padding: 18px 22px 0;
}
.dash-module-title {
  font-family: var(--font-display); font-size: 13px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--accent2);
}
.dash-module-meta { font-size: 10px; color: var(--text3); font-weight: 500; margin-left: auto; }
.dash-module-body { padding: 14px 22px 22px; }

/* ── CUSTOM SELECT DROPDOWN ────────────────────────────────────────────────── */
.dash-select-wrap { position: relative; display: inline-flex; }
.dash-select-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 10px 5px 8px; border-radius: 10px;
  border: 1px solid var(--border); background: var(--surface);
  font-family: var(--font-ui); font-size: 11px; font-weight: 600;
  color: var(--text); cursor: pointer; transition: all 0.15s;
  white-space: nowrap;
}
.dash-select-btn:hover { border-color: var(--border2); background: var(--surface2); }
.dash-select-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.dash-select-chevron {
  width: 10px; height: 10px; color: var(--text3); flex-shrink: 0;
  transition: transform 0.2s;
}
.dash-select-wrap.open .dash-select-chevron { transform: rotate(180deg); }

.dash-select-menu {
  position: absolute; top: calc(100% + 4px); left: 0; min-width: 160px;
  background: color-mix(in srgb, var(--modal-bg) 96%, transparent); border: 1px solid color-mix(in srgb, var(--border) 78%, transparent);
  border-radius: 14px; box-shadow: var(--shadow-xl);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  z-index: 50; padding: 4px;
  opacity: 0; transform: translateY(-4px); pointer-events: none;
  transition: opacity 0.15s, transform 0.15s;
}
.dash-select-wrap.open .dash-select-menu {
  opacity: 1; transform: translateY(0); pointer-events: all;
}
.dash-select-option {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 6px;
  font-size: 11px; font-weight: 500; color: var(--text2);
  cursor: pointer; transition: background 0.1s, color 0.1s;
}
.dash-select-option:hover { background: var(--surface2); color: var(--text); }
.dash-select-option.active { background: var(--accent-bg); color: var(--accent2); font-weight: 600; }
.dash-select-check { width: 14px; margin-left: auto; color: var(--accent2); opacity: 0; }
.dash-select-option.active .dash-select-check { opacity: 1; }

/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 1: PLATFORM OVERVIEW
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-platforms { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }

.dash-platform-card {
  background: var(--panel-bg); border: 1px solid var(--panel-border);
  border-radius: var(--radius); padding: 16px 18px;
  box-shadow: var(--panel-inset); position: relative; overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.dash-platform-card:hover { border-color: var(--border); box-shadow: var(--shadow); }

.dash-platform-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
}
.dash-platform-card.google::before { background: linear-gradient(90deg, #4285f4, #34a853, #fbbc05, #ea4335); }
.dash-platform-card.microsoft::before { background: linear-gradient(90deg, #00a4ef, #7fba00, #f25022, #ffb900); }
.dash-platform-card.meta::before { background: linear-gradient(90deg, #0668E1, #00C2FF); }

.dash-platform-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.dash-platform-id { display: flex; align-items: center; gap: 8px; }
.dash-platform-logo { width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; }
.dash-platform-logo svg { width: 18px; height: 18px; }
.dash-platform-name { font-size: 12px; font-weight: 600; color: var(--text); }
.dash-platform-status {
  width: 7px; height: 7px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 6px var(--green);
  animation: dashPulse 2.5s ease-in-out infinite;
}
@keyframes dashPulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 4px var(--green); }
  50% { opacity: 0.6; box-shadow: 0 0 8px var(--green); }
}

.dash-platform-kpis { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; }
.dash-platform-kpi-label {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--text3); margin-bottom: 2px;
}
.dash-platform-kpi-value {
  font-family: var(--font-mono); font-size: 15px; font-weight: 500;
  color: var(--text); display: flex; align-items: center; gap: 6px;
}

.dash-delta {
  font-family: var(--font-ui); font-size: 9px; font-weight: 600;
  padding: 1px 5px; border-radius: 4px; white-space: nowrap;
}
.dash-delta-up { color: var(--green); background: var(--green-bg); }
.dash-delta-down { color: var(--red); background: var(--red-bg); }

.dash-sparkline-wrap { margin-top: 14px; height: 32px; }
.dash-sparkline-wrap svg { width: 100%; height: 32px; }
.dash-spark-line { fill: none; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.dash-platform-card.google .dash-spark-line { stroke: #4285f4; }
.dash-platform-card.microsoft .dash-spark-line { stroke: #00a4ef; }
.dash-platform-card.meta .dash-spark-line { stroke: #0668E1; }
.dash-spark-area { opacity: 0.12; }
.dash-platform-card.google .dash-spark-area { fill: #4285f4; }
.dash-platform-card.microsoft .dash-spark-area { fill: #00a4ef; }
.dash-platform-card.meta .dash-spark-area { fill: #0668E1; }

.dash-platform-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 18px 0; color: var(--text3); font-size: 11px; font-weight: 500;
  gap: 4px; opacity: 0.6;
}
.dash-platform-empty-icon { font-size: 18px; opacity: 0.4; margin-bottom: 2px; }

/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 2: MOVERS & SHAKERS
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-movers-list { display: flex; flex-direction: column; gap: 4px; }
.dash-mover-row {
  display: grid;
  grid-template-columns: 18px 1fr 60px 64px 56px;
  gap: 8px; align-items: center;
  padding: 8px 12px; border-radius: 8px;
  transition: background 0.12s;
}
.dash-mover-row:nth-child(odd) { background: var(--panel-bg); }
.dash-mover-row:hover { background: var(--surface2); }

.dash-mover-rank {
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  color: var(--text3); text-align: center;
}
.dash-mover-info { min-width: 0; }
.dash-mover-name-row { display: flex; align-items: center; gap: 5px; min-width: 0; }
.dash-mover-platform-icon {
  width: 12px; height: 12px; border-radius: 3px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.dash-mover-platform-icon svg { width: 10px; height: 10px; }
.dash-mover-name {
  font-size: 12px; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dash-mover-type { font-size: 9px; color: var(--text3); font-weight: 500; margin-top: 1px; }

.dash-mover-spark { height: 20px; }
.dash-mover-spark svg { width: 100%; height: 20px; }
.dash-mover-spark-line {
  fill: none; stroke-width: 1.2; stroke-linecap: round; stroke-linejoin: round;
}
.dash-mover-spark-line.up { stroke: var(--green); }
.dash-mover-spark-line.down { stroke: var(--red); }

.dash-mover-change {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  text-align: right; padding: 2px 6px; border-radius: 5px;
}
.dash-mover-change.up { color: var(--green); background: var(--green-bg); }
.dash-mover-change.down { color: var(--red); background: var(--red-bg); }

.dash-mover-roas {
  font-family: var(--font-mono); font-size: 11px; color: var(--text2); text-align: right;
}

.dash-movers-empty {
  padding: 24px 0; text-align: center;
  color: var(--text3); font-size: 11px; font-weight: 500; opacity: 0.6;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 3: OPTIMISER RUNS
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-opt-summary { display: flex; flex-direction: column; gap: 14px; }
.dash-opt-top-row { display: flex; align-items: center; justify-content: space-between; }
.dash-opt-status-badge {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 6px;
  font-size: 10px; font-weight: 600; letter-spacing: 0.03em;
}
.dash-opt-status-badge.success { background: var(--green-bg); color: var(--green); }
.dash-opt-status-badge.staged { background: var(--accent-bg); color: var(--accent); }
.dash-opt-status-badge.none { background: var(--panel-bg); color: var(--text3); }
.dash-opt-status-dot { width: 6px; height: 6px; border-radius: 50%; }
.dash-opt-status-badge.success .dash-opt-status-dot { background: var(--green); box-shadow: 0 0 4px var(--green); }
.dash-opt-status-badge.staged .dash-opt-status-dot { background: var(--accent); box-shadow: 0 0 4px var(--accent); }
.dash-opt-status-badge.none .dash-opt-status-dot { background: var(--text3); }
.dash-opt-status-time { font-size: 11px; color: var(--text3); }

/* ── Day tiles (7-day timeline) ── */
.dash-opt-daytiles {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
  padding: 6px 0;
}
.dash-opt-daytile {
  display: flex; flex-direction: column; align-items: center; gap: 1px;
  padding: 5px 2px 4px; border-radius: 6px;
  border: 1px solid var(--border); background: var(--surface2);
  font: inherit; cursor: default; transition: all 0.15s;
  position: relative;
}
.dash-opt-daytile.has-runs {
  cursor: pointer; background: color-mix(in srgb, var(--green) 8%, var(--surface));
  border-color: color-mix(in srgb, var(--green) 25%, var(--border));
}
.dash-opt-daytile.has-runs:hover {
  border-color: var(--green); background: color-mix(in srgb, var(--green) 14%, var(--surface));
}
.dash-opt-daytile.active {
  border-color: var(--green); background: color-mix(in srgb, var(--green) 18%, var(--surface));
  box-shadow: 0 0 0 1px var(--green);
}
.dash-opt-daytile.today { border-style: solid; border-width: 1.5px; }
.dash-opt-daytile-dow {
  font-size: 8px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--text3); line-height: 1;
}
.dash-opt-daytile-num {
  font-family: var(--font-mono); font-size: 13px; font-weight: 600;
  color: var(--text2); line-height: 1.1;
}
.dash-opt-daytile.has-runs .dash-opt-daytile-num { color: var(--green); }
.dash-opt-daytile.active .dash-opt-daytile-num { color: var(--green); font-weight: 700; }
.dash-opt-daytile-dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--green); position: absolute; bottom: 2px;
}

.dash-opt-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.dash-opt-stat {
  background: var(--panel-bg); border: 1px solid var(--panel-border);
  border-radius: 8px; padding: 10px 12px; text-align: center;
}
.dash-opt-stat-icon { font-size: 12px; margin-bottom: 2px; display: block; }
.dash-opt-stat-value {
  font-family: var(--font-mono); font-size: 18px; font-weight: 500; color: var(--text);
}
.dash-opt-stat-label {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text3); margin-top: 2px;
}

.dash-opt-log-list { display: flex; flex-direction: column; gap: 3px; }
.dash-opt-log-entry {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 6px 10px; border-radius: 6px;
  font-size: 11px; color: var(--text2); line-height: 1.4;
}
.dash-opt-log-icon { width: 16px; text-align: center; font-size: 10px; flex-shrink: 0; margin-top: 1px; }
.dash-opt-log-entry.warn { background: var(--amber-bg); color: var(--amber); }
.dash-opt-log-entry.info { background: var(--panel-bg); }

.dash-opt-empty {
  padding: 24px 0; text-align: center;
  color: var(--text3); font-size: 11px; font-weight: 500; opacity: 0.6;
}

/* Urgent flags in optimiser runs module */
.dash-opt-flags{display:flex;flex-direction:column;gap:4px;margin:8px 0}
.dash-opt-flag{
  display:flex;align-items:center;gap:6px;
  font-size:10.5px;color:var(--text2);
  padding:4px 8px;border-radius:6px;
  background:var(--surface3);
}
.dash-opt-flag.urgent{background:rgba(var(--red-ch),0.08);color:var(--red)}
.dash-opt-flag.important{background:rgba(var(--amber-ch),0.08);color:var(--amber)}
.dash-opt-flag-dot{
  width:5px;height:5px;border-radius:50%;flex-shrink:0;
  background:currentColor;
}

/* ── Expandable run entries ────────────────────────────────────────────────── */
.dash-optr-list { display: flex; flex-direction: column; gap: 2px; }
.dash-optr-entry { border-radius: 6px; overflow: hidden; }
.dash-optr-entry.open { background: var(--panel-bg); }

.dash-optr-header {
  display: flex; align-items: center; gap: 6px;
  width: 100%; padding: 6px 8px; border: none; background: none;
  font: inherit; font-size: 11px; color: var(--text2);
  cursor: pointer; border-radius: 6px;
  transition: background 0.15s;
}
.dash-optr-header:hover { background: var(--surface3); }
.dash-optr-entry.open .dash-optr-header { background: none; }

.dash-optr-chevron {
  flex-shrink: 0; color: var(--text3);
  transition: transform 0.2s ease;
}
.dash-optr-chevron.open { transform: rotate(90deg); }

.dash-optr-port {
  font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 120px;
}

.dash-optr-source {
  flex-shrink: 0; padding: 1px 6px; border-radius: 4px;
  font-size: 9px; font-weight: 600; letter-spacing: 0.03em;
  text-transform: uppercase;
}
.dash-optr-source.manual { background: color-mix(in srgb, var(--text3) 12%, transparent); color: var(--text3); }
.dash-optr-source.scheduled { background: color-mix(in srgb, var(--blue) 12%, transparent); color: var(--blue); }

.dash-optr-count {
  flex-shrink: 0; font-size: 10px; color: var(--text3);
  font-variant-numeric: tabular-nums;
}

.dash-optr-time {
  margin-left: auto; flex-shrink: 0;
  font-size: 10px; color: var(--text3);
  font-family: var(--font-mono);
}

.dash-optr-body { overflow: hidden; }
.dash-optr-body-inner { padding: 0 8px 10px; }

.dash-optr-table-wrap { max-height: 172px; overflow-y: auto; border-radius: 4px; }
.dash-optr-table {
  width: 100%; border-collapse: collapse; font-size: 10.5px;
}
.dash-optr-table th {
  text-align: left; padding: 4px 6px; font-size: 9px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.04em; color: var(--text3);
  border-bottom: 1px solid var(--border); background: transparent;
}
.dash-optr-table td {
  padding: 4px 6px; border-bottom: 1px solid var(--panel-border);
  color: var(--text2); vertical-align: middle;
}
.dash-optr-table tbody tr:last-child td { border-bottom: none; }
.dash-optr-cam-name {
  max-width: 130px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dash-optr-cam-budget { white-space: nowrap; font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.dash-optr-cam-tags { display: flex; flex-wrap: wrap; gap: 3px; }
.dash-optr-cam-tags .optlog-tag { font-size: 8.5px; padding: 1px 4px; }

.dash-optr-more {
  text-align: center; font-size: 10px; color: var(--text3);
  padding: 4px 0; font-weight: 500;
}

.dash-optr-view-all {
  display: block; width: 100%; padding: 6px 0; margin-top: 4px;
  border: none; background: none; cursor: pointer;
  font: inherit; font-size: 10.5px; font-weight: 600; color: var(--accent2);
  text-align: center; border-radius: 6px;
  transition: background 0.15s;
}
.dash-optr-view-all:hover { background: var(--surface3); }

.dash-optr-reasoning {
  margin-top: 6px; font-size: 10.5px; color: var(--text3);
  font-style: italic; line-height: 1.4;
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}


/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 4: PERFORMANCE TREND
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-chart-controls {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.dash-chart-dropdowns { display: flex; align-items: center; gap: 6px; }
.dash-chart-axis-label {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text3);
}
.dash-chart-dd-sep { font-size: 10px; color: var(--border2); margin: 0 2px; }

.dash-chart-compare-toggle {
  display: flex; align-items: center; gap: 6px;
  font-size: 10px; color: var(--text3); cursor: pointer; user-select: none;
}
.dash-chart-compare-toggle input { accent-color: var(--accent); }

.dash-chart-wrap {
  position: relative;
  background: var(--panel-bg); border: 1px solid var(--panel-border);
  border-radius: var(--radius); overflow: hidden;
}
.dash-chart-inner {
  position: relative;
}
.dash-chart-wrap canvas {
  display: block; width: 100%; height: 240px;
}
.dash-trend-crosshair-svg {
  position: absolute; top: 0; left: 0; width: 100%; height: 240px;
  pointer-events: none; z-index: 2;
}
.dash-trend-tooltip {
  position: absolute; display: none;
  background: var(--surface); border: 1px solid var(--border2);
  border-radius: 8px; padding: 8px 12px;
  box-shadow: var(--shadow-lg); pointer-events: none;
  font-size: 11px; z-index: 5; min-width: 140px;
}
.dash-tt-date { font-weight: 600; color: var(--text); margin-bottom: 4px; font-size: 11px; }
.dash-tt-row { display: flex; align-items: center; gap: 6px; line-height: 1.5; }
.dash-tt-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.dash-tt-label { color: var(--text3); font-size: 10px; }
.dash-tt-val { font-family: var(--font-mono); font-weight: 500; margin-left: auto; }

.dash-chart-legend { display: flex; gap: 16px; padding: 8px 12px 4px; justify-content: center; }
.dash-chart-legend-item { display: flex; align-items: center; gap: 5px; font-size: 10px; color: var(--text3); font-weight: 500; }
.dash-chart-legend-swatch { width: 14px; height: 3px; border-radius: 2px; }
.dash-legend-dotted {
  height: 0; border-top: 2px dotted; background: none !important; opacity: 0.5;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 5: BUDGET PACING
   ═══════════════════════════════════════════════════════════════════════════════ */
/* Pacing module body fills available height */
[data-module="pacing"] .dash-module-body { display: flex; flex-direction: column; }
.dash-pacing-overview { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 14px; }
.dash-pacing-main { display: flex; align-items: center; gap: 20px; flex-shrink: 0; }
.dash-pacing-projection { flex-shrink: 0; }

.dash-pacing-gauge { width: 120px; height: 120px; position: relative; flex-shrink: 0; }
.dash-pacing-gauge svg { width: 100%; height: 100%; }
.dash-gauge-bg { fill: none; stroke: var(--surface3); stroke-width: 8; stroke-linecap: round; }
.dash-gauge-fill { fill: none; stroke-width: 8; stroke-linecap: round; transition: stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1); }
.dash-gauge-ideal-tick { stroke-width: 2.5; stroke-linecap: round; }

.dash-pacing-gauge-label {
  position: absolute; top: 46%; left: 50%;
  transform: translate(-50%, -50%); text-align: center;
}
.dash-pacing-gauge-pct { font-family: var(--font-mono); font-size: 24px; font-weight: 500; color: var(--text); line-height: 1; }
.dash-pacing-gauge-sub { font-size: 9px; color: var(--text3); margin-top: 2px; }

.dash-pacing-stats { flex: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.dash-pacing-stat {
  padding: 10px 12px; background: var(--panel-bg); border: 1px solid var(--panel-border); border-radius: 8px;
}
.dash-pacing-stat-label {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text3); margin-bottom: 2px;
}
.dash-pacing-stat-value { font-family: var(--font-mono); font-size: 13px; font-weight: 500; color: var(--text); }

.dash-pacing-projection {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; border-radius: 8px;
  background: var(--panel-bg); border: 1px solid var(--panel-border);
  font-size: 11px; color: var(--text2);
}
.dash-pacing-projection-label { font-weight: 600; color: var(--text3); }
.dash-pacing-projection-value { font-family: var(--font-mono); font-weight: 500; color: var(--text); }

.dash-pacing-portfolio-list { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: 5px; overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--text3) transparent; }
.dash-pacing-portfolio-list::-webkit-scrollbar { width: 4px; }
.dash-pacing-portfolio-list::-webkit-scrollbar-track { background: transparent; }
.dash-pacing-portfolio-list::-webkit-scrollbar-thumb { background: var(--text3); border-radius: 2px; opacity: 0.4; }
.dash-pacing-port-row {
  display: grid; grid-template-columns: 1fr auto 100px 50px;
  gap: 8px; align-items: center;
  padding: 7px 10px; border-radius: 8px;
  font-size: 11px; background: var(--panel-bg); border: 1px solid var(--panel-border);
}
.dash-pacing-port-name { font-weight: 500; color: var(--text); }
.dash-pacing-port-status {
  font-size: 9px; font-weight: 600; padding: 2px 7px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.dash-pacing-port-status.on-track { color: var(--green); background: var(--green-bg); }
.dash-pacing-port-status.hot { color: var(--red); background: var(--red-bg); }
.dash-pacing-port-status.cold { color: var(--amber); background: var(--amber-bg); }

.dash-pacing-port-bar-wrap {
  height: 6px; border-radius: 3px; background: var(--surface3);
  overflow: visible; position: relative;
}
.dash-pacing-port-bar { height: 100%; border-radius: 3px; transition: width 0.6s ease; }
.dash-pacing-port-bar.on-track { background: var(--green); }
.dash-pacing-port-bar.hot { background: var(--red); }
.dash-pacing-port-bar.cold { background: var(--amber); }
.dash-pacing-port-bar-wrap::after {
  content: ''; position: absolute; top: -2px; bottom: -2px;
  width: 2px; background: var(--text); opacity: 0.2;
  border-radius: 1px; left: var(--ideal);
}

.dash-pacing-port-pct { font-family: var(--font-mono); font-size: 10px; font-weight: 600; text-align: right; }
.dash-pacing-port-pct.on-track { color: var(--green); }
.dash-pacing-port-pct.hot { color: var(--red); }
.dash-pacing-port-pct.cold { color: var(--amber); }

/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 6: SPEND HEATMAP
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-heatmap-wrap { display: flex; flex-direction: column; gap: 6px; }
.dash-heatmap-month-label { font-family: var(--font-display); font-size: 12px; font-weight: 600; color: var(--text); margin-bottom: 4px; }

.dash-heatmap-dow-labels { display: grid; grid-template-columns: 32px repeat(7, 1fr); gap: 3px; margin-bottom: 2px; }
.dash-heatmap-dow { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text3); text-align: center; }

.dash-heatmap-grid { display: grid; grid-template-columns: 32px repeat(7, 1fr); gap: 3px; }
.dash-heatmap-week-label {
  font-family: var(--font-mono); font-size: 9px; color: var(--text3);
  display: flex; align-items: center; justify-content: center;
}

.dash-heatmap-day {
  aspect-ratio: 1; border-radius: 5px; cursor: pointer;
  position: relative; transition: transform 0.15s, box-shadow 0.15s;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 8px; color: var(--text3);
  font-weight: 500; min-height: 28px;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.08);
}
.dash-heatmap-day.l4, .dash-heatmap-day.l5 { color: rgba(255,255,255,0.85); }
.dash-heatmap-day:hover {
  transform: scale(1.18); box-shadow: 0 3px 10px rgba(0,0,0,0.3);
  z-index: 2; font-size: 9px;
}
.dash-heatmap-day.empty { background: transparent; cursor: default; box-shadow: none; }
.dash-heatmap-day.empty:hover { transform: none; box-shadow: none; }
.dash-heatmap-day.future { background: var(--surface2); opacity: 0.3; cursor: default; box-shadow: none; }
.dash-heatmap-day.future:hover { transform: none; box-shadow: none; }
.dash-heatmap-day.today { outline: 2px solid var(--accent); outline-offset: 1px; }

.dash-heatmap-day.l0 { background: var(--surface3); }
.dash-heatmap-day.l1 { background: color-mix(in srgb, var(--accent) 18%, var(--surface3)); }
.dash-heatmap-day.l2 { background: color-mix(in srgb, var(--accent) 35%, var(--surface3)); }
.dash-heatmap-day.l3 { background: color-mix(in srgb, var(--accent) 52%, var(--surface3)); }
.dash-heatmap-day.l4 { background: color-mix(in srgb, var(--accent) 72%, var(--surface2)); }
.dash-heatmap-day.l5 { background: var(--accent); box-shadow: inset 0 1px 2px rgba(0,0,0,0.15), 0 0 6px var(--accent-glow); }

.dash-heatmap-legend { display: flex; align-items: center; gap: 4px; margin-top: 8px; justify-content: flex-end; }
.dash-heatmap-legend-label { font-size: 9px; color: var(--text3); margin-right: 4px; }
.dash-heatmap-legend-box { width: 12px; height: 12px; border-radius: 3px; }

/* Heatmap tooltip */
.dash-hm-tooltip {
  position: fixed; background: var(--surface); border: 1px solid var(--border2);
  border-radius: 10px; padding: 10px 14px; box-shadow: var(--shadow-xl);
  pointer-events: none; z-index: 999; min-width: 140px;
  transition: opacity 0.15s; opacity: 0;
}
.dash-hm-tooltip.visible { opacity: 1; }
.dash-hm-tooltip-date { font-weight: 600; color: var(--text); font-size: 11px; margin-bottom: 4px; }
.dash-hm-tooltip-row { display: flex; justify-content: space-between; gap: 12px; font-size: 10px; }
.dash-hm-tooltip-label { color: var(--text3); font-weight: 500; }
.dash-hm-tooltip-val { font-family: var(--font-mono); font-weight: 500; color: var(--text); }
.dash-hm-tooltip-val.dash-hm-active-metric { font-weight: 700; }

/* ── Heatmap spend/revenue toggle ──────────────────────────────────────────── */
.dash-heatmap-top-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.dash-hm-toggle {
  display: flex; border: 1px solid var(--border); border-radius: 6px; overflow: hidden;
}
.dash-hm-toggle-btn {
  padding: 2px 8px; border: none; background: none;
  font: inherit; font-size: 9px; font-weight: 600; letter-spacing: 0.02em;
  color: var(--text3); cursor: pointer; transition: all 0.15s;
}
.dash-hm-toggle-btn:first-child { border-right: 1px solid var(--border); }
.dash-hm-toggle-btn.active { background: var(--accent-bg); color: var(--accent2); }


/* ═══════════════════════════════════════════════════════════════════════════════
   MODULE 7: PLATFORM STATS
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-pstats-wrap {
  display: flex; flex-direction: column; width: 100%;
}

.dash-pstats-row {
  display: grid;
  grid-template-columns: 100px 1fr 1fr 68px 68px;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--border);
  gap: 4px;
}
.dash-pstats-row:last-child { border-bottom: none; }

/* Header row */
.dash-pstats-head { padding: 0 0 6px; border-bottom: 1px solid var(--border2); }
.dash-pstats-head .dash-pstats-col-val {
  font-size: 10px; font-weight: 600; color: var(--text3);
  text-transform: uppercase; letter-spacing: 0.06em;
}

/* Platform cell */
.dash-pstats-platform {
  display: flex; align-items: center; gap: 7px; min-width: 0;
}
.dash-pstats-logo { width: 16px; height: 16px; flex-shrink: 0; display: flex; }
.dash-pstats-logo svg { width: 16px; height: 16px; }
.dash-pstats-platname {
  font-size: 12px; font-weight: 600; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dash-pstats-col-plat { /* same column as platform */ }

/* Value cells */
.dash-pstats-col-val {
  display: flex; flex-direction: column; gap: 1px; align-items: flex-end;
}
.dash-pstats-val {
  font-size: 12px; font-weight: 600; color: var(--text);
  font-variant-numeric: tabular-nums; white-space: nowrap;
}
.dash-pstats-delta {
  font-size: 10px; font-weight: 600; font-variant-numeric: tabular-nums;
}
.dash-pstats-delta.pos { color: var(--green); }
.dash-pstats-delta.neg { color: var(--red); }

/* Totals row */
.dash-pstats-totals { border-top: 1px solid var(--border2); border-bottom: none; padding-top: 8px; margin-top: 2px; }
.dash-pstats-totals .dash-pstats-val { color: var(--text); font-weight: 700; }
.dash-pstats-totals-label {
  font-size: 11px; font-weight: 700; color: var(--text3);
  text-transform: uppercase; letter-spacing: 0.04em;
}

/* Empty state (reused) */
.dash-revshare-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  height: 100%; min-height: 120px; color: var(--text3); font-size: 11px; font-weight: 500;
  gap: 4px; opacity: 0.6;
}
.dash-revshare-empty-icon { font-size: 18px; opacity: 0.4; margin-bottom: 2px; }

/* ═══════════════════════════════════════════════════════════════════════════════
   CUSTOMISE POPOVER
   ═══════════════════════════════════════════════════════════════════════════════ */
.dash-customise-popover {
  position: absolute; top: 100%; right: 0; z-index: 50;
  margin-top: 6px; min-width: 200px;
  background: var(--surface); border: 1px solid var(--border2);
  border-radius: var(--radius); box-shadow: var(--shadow-xl);
  padding: 8px;
}
.dash-customise-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px; border-radius: 6px; cursor: pointer;
  font-size: 11px; font-weight: 500; color: var(--text2);
  transition: background 0.1s;
}
.dash-customise-row:hover { background: var(--surface2); color: var(--text); }
.dash-customise-row input[type="checkbox"] { accent-color: var(--accent); width: 14px; height: 14px; flex-shrink: 0; margin: 0; }

/* ═══════════════════════════════════════════════════════════════════════════════
   PACING GRAPH (daily bar chart)
   ═══════════════════════════════════════════════════════════════════════════════ */
/* Outer layout: chart (flex:1) + hero card (fixed width) */
.dpg-outer {
  display: flex; gap: 16px; align-items: stretch;
  margin: -6px -8px 0;
}
.dpg-chart-side { flex: 1; min-width: 0; }
.dpg-hero-side { width: 210px; flex-shrink: 0; padding-right: 6px; display: flex; flex-direction: column; }

.dpg-wrap { position: relative; }

/* Hero card — matches portfolio monthly budget card */
.dpg-hero-card {
  position: relative; flex: 1; overflow: hidden;
  background: linear-gradient(160deg, color-mix(in srgb, var(--accent) 8%, var(--surface)) 0%, var(--surface) 55%);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 20px 18px 18px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08), 0 1px 4px rgba(0,0,0,0.04);
  display: flex; flex-direction: column;
}
.dpg-hero-glow {
  position: absolute; top: -50px; right: -50px;
  width: 180px; height: 180px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--accent) 14%, transparent) 0%, transparent 70%);
  pointer-events: none;
}
.dpg-hero-label {
  font-family: var(--font-ui); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.09em;
  color: var(--text3); margin-bottom: 8px; position: relative;
}
.dpg-hero-value {
  font-family: var(--font-mono); font-size: 28px; font-weight: 700;
  font-variant-numeric: tabular-nums; line-height: 1;
  color: var(--text); margin-bottom: 6px; position: relative;
}
.dpg-hero-subtitle {
  font-size: 11px; color: var(--text3); line-height: 1.4;
  margin-bottom: auto; padding-bottom: 12px; position: relative;
}
.dpg-hero-side .stat-pacing { margin-top: 0; }

.dpg-legend {
  display: flex; gap: 14px; justify-content: flex-end;
  padding: 0 8px 6px; font-size: 9px; font-weight: 600;
  color: var(--text3); text-transform: uppercase; letter-spacing: 0.06em;
}
.dpg-legend-item { display: flex; align-items: center; gap: 5px; }
.dpg-legend-swatch { width: 12px; height: 8px; border-radius: 2px; }
.dpg-legend-swatch.actual    { background: var(--accent); }
.dpg-legend-swatch.projected { background: var(--accent); opacity: 0.32; }
.dpg-legend-swatch.plan      { background: var(--text2); height: 2px; opacity: 0.75; }

.dpg-bar { transition: filter 0.15s; }

/* Tooltip */
.dpg-tip {
  display: none; position: fixed; pointer-events: none; z-index: 9999;
  background: var(--surface); border: 1px solid var(--border2);
  border-radius: 8px; padding: 8px 12px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.35); min-width: 160px;
}
.dpg-tip-date {
  font-size: 11px; font-weight: 600; color: var(--text);
  margin-bottom: 6px; letter-spacing: 0.01em;
}
.dpg-tip-row {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px; margin-bottom: 2px;
}
.dpg-tip-label { font-size: 10px; color: var(--text3); font-weight: 500; }
.dpg-tip-value { font-size: 12px; font-weight: 600; color: var(--text); font-family: var(--font-mono); }
.dpg-tip-delta {
  font-size: 10px; font-weight: 600; margin-top: 2px;
  font-family: var(--font-mono);
}
.dpg-tip-delta.tip-delta-green { color: var(--green); }
.dpg-tip-delta.tip-delta-amber { color: var(--amber); }
.dpg-tip-delta.tip-delta-red   { color: var(--red); }

.dpg-tip-divider {
  height: 1px; background: var(--border); margin: 6px 0;
}
.dpg-tip-deviators-label {
  font-size: 9px; font-weight: 600; color: var(--text3);
  text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px;
}
.dpg-tip-dev-row {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 8px; margin-bottom: 1px;
}
.dpg-tip-dev-name {
  font-size: 10px; color: var(--text2); font-weight: 500;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 120px;
}
.dpg-tip-dev-delta {
  font-size: 10px; font-weight: 600; font-family: var(--font-mono); flex-shrink: 0;
}
.dpg-tip-dev-delta.tip-delta-green { color: var(--green); }
.dpg-tip-dev-delta.tip-delta-amber { color: var(--amber); }
.dpg-tip-dev-delta.tip-delta-red   { color: var(--red); }

/* ── REVENUE OPPORTUNITIES ─────────────────────────────────────────────────── */

.ws-wrap {
  display: flex; flex-direction: column; gap: 16px; padding: 2px 0;
}

/* Hero */
.ws-hero { display: flex; flex-direction: column; gap: 3px; }
.ws-hero-val {
  font-size: 30px; font-weight: 700; line-height: 1;
  color: var(--red); font-variant-numeric: tabular-nums; letter-spacing: -0.02em;
}
.ws-hero-mo {
  font-size: 16px; font-weight: 500; margin-left: 2px; opacity: 0.7;
}
.ws-hero-label {
  font-size: 12px; color: var(--text3); font-weight: 500;
}

/* Source rows */
.ws-sources { display: flex; flex-direction: column; gap: 10px; }
.ws-source-block { display: flex; flex-direction: column; gap: 5px; }
.ws-source-row {
  display: grid;
  grid-template-columns: 8px 1fr auto 52px;
  align-items: start; gap: 8px;
}
.ws-source-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 3px;
}
.ws-dot-budget { background: var(--amber); }
.ws-dot-rank   { background: #8b5cf6; }
.ws-source-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.ws-source-label {
  font-size: 12px; color: var(--text); font-weight: 600; white-space: nowrap;
}
.ws-source-desc {
  font-size: 11px; color: var(--text3); line-height: 1.4;
}
.ws-source-bar-wrap {
  height: 5px; background: var(--border); border-radius: 3px; overflow: hidden;
  margin-top: 6px; width: 60px; flex-shrink: 0;
}
.ws-source-bar {
  height: 100%; border-radius: 3px; min-width: 4px;
  transition: width 0.4s cubic-bezier(0.34, 1.18, 0.64, 1);
}
.ws-bar-budget { background: var(--amber); }
.ws-bar-rank   { background: #8b5cf6; }
.ws-source-amt {
  font-size: 13px; font-weight: 700; font-variant-numeric: tabular-nums;
  text-align: right; white-space: nowrap; flex-shrink: 0;
}
.ws-amt-budget { color: var(--amber); }
.ws-amt-rank   { color: #8b5cf6; }

/* Campaign list */
.ws-campaigns { display: flex; flex-direction: column; gap: 0; }
.ws-campaigns-label {
  font-size: 10px; font-weight: 600; color: var(--text3);
  text-transform: uppercase; letter-spacing: 0.06em;
  margin-bottom: 6px;
}
.ws-cam-row {
  display: grid;
  grid-template-columns: 16px 1fr auto 48px;
  align-items: center; gap: 8px;
  padding: 5px 0;
  border-top: 1px solid var(--border);
}
.ws-cam-row:last-child { border-bottom: 1px solid var(--border); }
.ws-cam-platform { display: flex; align-items: center; }
.ws-cam-platform svg { width: 14px; height: 14px; display: block; }
.ws-cam-info { min-width: 0; }
.ws-cam-name {
  font-size: 12px; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ws-cam-portfolio {
  font-size: 10px; color: var(--text3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ws-badge {
  font-size: 10px; font-weight: 600; padding: 2px 6px; border-radius: 4px;
  white-space: nowrap; flex-shrink: 0;
}
.ws-badge-budget {
  background: color-mix(in srgb, var(--amber) 14%, transparent);
  color: var(--amber);
}
.ws-badge-rank {
  background: color-mix(in srgb, #8b5cf6 14%, transparent);
  color: #8b5cf6;
}
.ws-cam-amt {
  font-size: 12px; font-weight: 600; color: var(--text);
  font-variant-numeric: tabular-nums; text-align: right;
}

/* Action hints */
.ws-actions { display: flex; flex-direction: column; gap: 6px; padding-top: 2px; }
.ws-action {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 10px; border-radius: 8px; border: none; cursor: pointer;
  font-size: 12px; font-weight: 600; text-align: left;
  transition: opacity 0.15s;
}
.ws-action:hover { opacity: 0.8; }
.ws-action svg { width: 13px; height: 13px; flex-shrink: 0; }
.ws-action-budget {
  background: color-mix(in srgb, var(--amber) 12%, transparent);
  color: var(--amber);
}
.ws-action-note {
  display: flex; align-items: flex-start; gap: 6px;
  padding: 7px 10px; border-radius: 8px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
}
.ws-action-note svg { width: 12px; height: 12px; flex-shrink: 0; margin-top: 1px; }
.ws-action-note-rank {
  background: color-mix(in srgb, #8b5cf6 10%, transparent);
  color: #8b5cf6;
}

/* Empty state */
.ws-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; padding: 32px 16px; color: var(--text3);
}
.ws-empty svg {
  width: 28px; height: 28px; opacity: 0.4;
}
.ws-empty span {
  font-size: 12px; text-align: center; max-width: 200px;
}

/* ── Account Health dashboard card (.ah-*) ──────────────────────────────── */

.ah-wrap{padding:4px 0}
.ah-empty{display:flex;align-items:center;justify-content:center;min-height:120px}
.ah-empty-msg{font-size:12px;color:var(--text3);text-align:center}

/* Score row */
.ah-score-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ah-score{font-size:32px;font-weight:700;font-variant-numeric:tabular-nums;font-family:var(--font-display);color:var(--text);line-height:1}
.ah-grade{font-size:12px;font-weight:700;padding:2px 7px;border-radius:5px;line-height:1.3}
.ah-grade-a{background:color-mix(in srgb,var(--green) 15%,transparent);color:var(--green)}
.ah-grade-b{background:color-mix(in srgb,var(--green) 12%,transparent);color:var(--green)}
.ah-grade-c{background:color-mix(in srgb,var(--amber) 15%,transparent);color:var(--amber)}
.ah-grade-d{background:color-mix(in srgb,var(--red) 15%,transparent);color:var(--red)}

/* Health bar */
.ah-bar-col{flex:1;min-width:0}
.ah-bar-track{height:6px;border-radius:3px;background:color-mix(in srgb,var(--text3) 12%,transparent);overflow:hidden}
.ah-bar-fill{height:100%;border-radius:3px;transition:width .6s ease-out}
.ah-bar-fill.ah-grade-a,.ah-bar-fill.ah-grade-b{background:var(--green)}
.ah-bar-fill.ah-grade-c{background:var(--amber)}
.ah-bar-fill.ah-grade-d{background:var(--red)}

/* Per-platform rows */
.ah-platforms{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.ah-platform-row{display:flex;align-items:center;gap:8px;font-size:12px}
.ah-platform-icon{display:flex;align-items:center;flex-shrink:0}
.ah-platform-icon svg{width:16px;height:16px}
.ah-platform-name{color:var(--text2);min-width:64px}
.ah-platform-pills{display:flex;gap:4px;margin-left:auto}
.ah-pill{font-size:10px;font-weight:700;padding:1px 6px;border-radius:4px;font-variant-numeric:tabular-nums}
.ah-pill-critical{background:color-mix(in srgb,var(--red) 12%,transparent);color:var(--red)}
.ah-pill-warning{background:color-mix(in srgb,var(--amber) 12%,transparent);color:var(--amber)}
.ah-pill-info{background:color-mix(in srgb,var(--text3) 10%,transparent);color:var(--text3)}

/* CTA */
.ah-cta{width:100%;font-size:12px;margin-top:4px}

/* ── Account Health Score (full-width hero) ────────────────────────────────── */

.ahs-wrap{display:flex;gap:1.5rem;padding:0.25rem 0;min-height:185px;align-items:stretch}

/* Left — score column */
.ahs-score-col{flex:0 0 100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.ahs-score-num{font-size:2.75rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums;font-family:var(--font-display),var(--font-sans);color:var(--text1)}
.ahs-grade{font-size:13px;font-weight:700;padding:2px 10px;border-radius:6px;letter-spacing:0.04em}
.ahs-grade-a{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green)}
.ahs-grade-b{background:color-mix(in srgb,var(--green) 14%,transparent);color:var(--green)}
.ahs-grade-c{background:color-mix(in srgb,var(--amber) 14%,transparent);color:var(--amber)}
.ahs-grade-d{background:color-mix(in srgb,var(--red) 14%,transparent);color:var(--red)}
.ahs-bar-track{width:80px;height:5px;border-radius:3px;background:var(--surface3);overflow:hidden}
.ahs-bar-fill{height:100%;border-radius:3px;transition:width 0.5s ease}

/* Centre — dimension rows */
.ahs-dims{flex:1;display:flex;flex-direction:column;justify-content:center;gap:6px}
.ahs-dim-row{display:flex;align-items:center;gap:8px}
.ahs-dim-label{font-size:12px;color:var(--text2);width:150px;flex-shrink:0;cursor:help;border-bottom:1px dotted var(--border2)}

/* Tooltip — portaled to body, escapes overflow:hidden */
.ahs-tooltip{
  width:280px;padding:10px 12px;
  font-size:11px;line-height:1.55;font-weight:400;color:var(--text2);
  background:var(--modal-bg);border:1px solid var(--border2);border-radius:10px;
  box-shadow:var(--shadow-lg);backdrop-filter:blur(16px);
  pointer-events:none;
  animation:ahsTooltipIn 0.15s ease both;
}
@keyframes ahsTooltipIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.ahs-dim-weight{font-size:10px;color:var(--text3);width:28px;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0}
.ahs-dim-bar-track{flex:1;height:6px;border-radius:3px;background:var(--surface3);overflow:hidden;min-width:80px}
.ahs-dim-bar-fill{height:100%;border-radius:3px;transition:width 0.5s ease}
.ahs-bar-a{background:var(--green)}
.ahs-bar-b{background:var(--green)}
.ahs-bar-c{background:var(--amber)}
.ahs-bar-d{background:var(--red)}
.ahs-bar-na{background:var(--surface3);opacity:0.5}
.ahs-dim-score{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;width:32px;text-align:right;flex-shrink:0;color:var(--text1)}
.ahs-dim-na{color:var(--text3);font-weight:400;font-size:11px}

/* Right — action items */
.ahs-actions-col{flex:0 0 200px;display:flex;flex-direction:column;gap:6px;justify-content:center}
.ahs-actions-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:2px}
.ahs-action-card{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:all 0.15s ease;text-align:left;font-family:inherit}
.ahs-action-card:hover{background:var(--surface2);border-color:var(--border2);box-shadow:var(--shadow)}
.ahs-action-critical{border-left:3px solid var(--red)}
.ahs-action-warn{border-left:3px solid var(--amber)}
.ahs-action-info{border-left:3px solid var(--accent)}
.ahs-action-label{font-size:12px;color:var(--text2);line-height:1.3}
.ahs-action-score{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text3);flex-shrink:0}

/* Loading & empty states */
.ahs-loading{display:flex;align-items:center;justify-content:center;width:100%;min-height:0;flex:1}
.ahs-empty-msg{color:var(--text3);font-size:13px;text-align:center}
.ahs-skeleton{display:flex;gap:1.5rem;width:100%;align-items:center}
.ahs-skel-score{width:100px;height:80px;border-radius:12px;background:var(--surface2);animation:pulse 1.5s ease-in-out infinite}
.ahs-skel-dims{flex:1;display:flex;flex-direction:column;gap:6px}
.ahs-skel-row{height:17px;border-radius:4px;background:var(--surface2);animation:pulse 1.5s ease-in-out infinite}

/* ── Mission Control ───────────────────────────────────────────────────────── */

.mc-wrap{display:flex;flex-direction:column;gap:14px}

/* Hero strip */
.mc-hero{
  display:flex;align-items:center;gap:20px;
  padding:12px 18px;border-radius:var(--radius-lg);
  background:
    linear-gradient(135deg,color-mix(in srgb,var(--accent2) 8%,transparent),transparent 50%),
    var(--panel-bg);
  border:1px solid var(--panel-border);box-shadow:var(--panel-inset);
}
.mc-hero-stat{display:flex;align-items:baseline;gap:6px}
.mc-hero-stat--secondary{opacity:0.6}
.mc-hero-num{font-size:26px;font-weight:800;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}
.mc-hero-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}
.mc-hero-platforms{display:flex;align-items:center;gap:6px;margin-left:auto}
.mc-hero-refresh{display:flex;align-items:center;gap:10px;margin-left:8px}
.mc-hero-error{font-size:10px;color:var(--red);max-width:160px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}

/* Platform status dots (now buttons — clickable platform filter) */
.mc-dot{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:999px;border:2px solid transparent;
  background:transparent;padding:0;
  cursor:pointer;transition:border-color 0.15s,transform 0.15s,background 0.15s;
}
.mc-dot svg{width:14px;height:14px}
.mc-dot--fresh{border-color:var(--green)}
.mc-dot--stale{border-color:var(--amber)}
.mc-dot--down{border-color:var(--border);opacity:0.4}
.mc-dot:hover{transform:scale(1.12)}
.mc-dot--active{background:color-mix(in srgb,var(--accent2) 14%,transparent);border-color:var(--accent2)!important;opacity:1}
.mc-dot-hint{font-size:10px;color:var(--text3);font-style:italic}

.mc-dot-tooltip{
  padding:10px 14px;border-radius:12px;
  background:var(--modal-bg);border:1px solid var(--border2);
  box-shadow:var(--shadow-xl);backdrop-filter:blur(18px);
  display:flex;flex-direction:column;gap:4px;
  transform:translateX(-50%);font-size:11px;color:var(--text2);
  pointer-events:none;
}
.mc-dot-tooltip strong{font-size:12px;font-weight:700;color:var(--text)}
.mc-dot-status{font-weight:600}
.mc-dot-status--fresh{color:var(--green)}
.mc-dot-status--stale{color:var(--amber)}
.mc-dot-status--down{color:var(--red)}
.mc-dot-sync,.mc-dot-issues{font-size:10px;color:var(--text3)}

/* Progress bar (inline in hero) */
.mc-progress{display:flex;align-items:center;gap:8px;min-width:120px}
.mc-progress-bar{flex:1;height:5px;border-radius:999px;background:var(--surface3);overflow:hidden}
.mc-progress-fill{
  height:100%;border-radius:inherit;transition:width 0.25s ease;
  background:linear-gradient(90deg,var(--accent2),color-mix(in srgb,var(--green) 70%,var(--accent2)));
}
.mc-progress-pct{font-size:10px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text2);min-width:28px;text-align:right}

/* Filter bar */
.mc-filters{display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.mc-filter-count{margin-left:auto;font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}

/* Segmented control */
.mc-seg{display:inline-flex;border-radius:999px;border:1px solid var(--border);overflow:hidden;background:var(--surface)}
.mc-seg-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 12px;font:inherit;font-size:11px;font-weight:600;
  color:var(--text2);background:transparent;border:none;cursor:pointer;
  transition:all 0.15s ease;
}
.mc-seg-btn:not(:last-child){border-right:1px solid var(--border)}
.mc-seg-btn:hover{background:var(--surface2)}
.mc-seg-btn--active{background:var(--accent-bg);color:var(--accent2)}
.mc-seg-count{
  min-width:16px;padding:1px 5px;border-radius:999px;
  background:var(--surface3);font-size:9px;font-weight:700;color:var(--text3);
}
.mc-seg-btn--active .mc-seg-count{background:color-mix(in srgb,var(--accent2) 14%,transparent);color:var(--accent2)}

/* Dropdown button + menu */
.mc-dropdown-wrap{position:relative}
.mc-dropdown-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface);color:var(--text2);font:inherit;font-size:11px;font-weight:600;
  cursor:pointer;transition:all 0.15s ease;
}
.mc-dropdown-btn:hover{border-color:var(--border2);background:var(--surface2)}
.mc-dropdown-btn--active{background:var(--accent-bg);border-color:color-mix(in srgb,var(--accent2) 30%,var(--border));color:var(--accent2)}
.mc-dropdown-backdrop{position:fixed;inset:0;z-index:9998}
.mc-dropdown-menu{
  position:fixed;z-index:9999;min-width:180px;
  padding:6px;border-radius:12px;
  background:var(--modal-bg);border:1px solid var(--border2);
  box-shadow:var(--shadow-xl);backdrop-filter:blur(18px);
}
.mc-dropdown-item{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  width:100%;padding:7px 10px;border-radius:8px;border:none;
  background:transparent;color:var(--text);font:inherit;font-size:11px;font-weight:500;
  cursor:pointer;text-align:left;transition:background 0.12s ease;
}
.mc-dropdown-item:hover{background:var(--surface2)}
.mc-dropdown-item--active{font-weight:700;color:var(--accent2)}
.mc-dropdown-item span{font-size:10px;font-weight:600;color:var(--text3)}

/* Groups */
.mc-groups{display:flex;flex-direction:column;gap:14px}
.mc-groups--scrollable{max-height:560px;overflow-y:auto;scrollbar-width:thin;padding-right:4px}
.mc-show-toggle{
  display:block;width:100%;padding:8px;border:1px dashed var(--border2);border-radius:10px;
  background:transparent;color:var(--accent2);font:inherit;font-size:11px;font-weight:700;
  cursor:pointer;text-align:center;transition:all 0.15s ease;
}
.mc-show-toggle:hover{background:var(--accent-bg);border-color:color-mix(in srgb,var(--accent2) 30%,var(--border))}
.mc-group{display:flex;flex-direction:column;gap:2px}
.mc-group-head{display:flex;align-items:center;gap:8px;padding:4px 0}
.mc-group-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em}
.mc-group-count{
  min-width:18px;padding:2px 6px;border-radius:999px;
  background:var(--surface2);font-size:10px;font-weight:700;color:var(--text3);text-align:center;
}

/* Accordion row */
.mc-row{
  border-radius:12px;border:1px solid var(--border);
  background:var(--surface);transition:all 0.15s ease;
  overflow:hidden;
}
.mc-row:hover{border-color:var(--border2);box-shadow:var(--shadow);background:color-mix(in srgb,var(--accent2) 3%,var(--surface))}
.mc-row--open{border-color:var(--border2);box-shadow:var(--shadow-lg)}
.mc-row--busy{opacity:0.65;pointer-events:none}
.mc-row--blocked{border-color:color-mix(in srgb,var(--amber) 24%,var(--border))}

/* Collapsed summary — CSS grid matching mc-table-header */
.mc-row-summary{
  display:grid;grid-template-columns:var(--mc-row-grid);align-items:center;
  gap:0 8px;
  width:100%;padding:10px 14px;cursor:pointer;color:var(--text);
  user-select:none;
}

/* Inline action button cell */
.mc-row-action-col{display:flex;align-items:center;justify-content:center}
.mc-row-action-btn{padding:4px 10px!important;font-size:11px!important;white-space:nowrap}

/* Inline dismiss × */
.mc-row-dismiss-x{
  display:flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:6px;border:none;
  background:transparent;color:var(--text3);font-size:18px;font-weight:300;line-height:1;
  cursor:pointer;transition:background 0.15s,color 0.15s;
}
.mc-row-dismiss-x:hover{background:var(--red-bg);color:var(--red)}

/* Priority tier pill */
.mc-row-tier{
  display:inline-flex;align-items:center;justify-content:center;
  padding:3px 8px;border-radius:999px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;
  white-space:nowrap;
}
.mc-row-tier--critical{background:var(--red-bg);color:var(--red)}
.mc-row-tier--warn{background:var(--amber-bg);color:var(--amber)}
.mc-row-tier--info{background:var(--accent-bg);color:var(--accent2)}

/* Platform */
.mc-row-platform{display:flex;align-items:center;justify-content:center}
.mc-row-platform svg{width:14px;height:14px}

/* Title */
.mc-row-title{min-width:0;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Category cell with colored dot */
.mc-row-cat-cell{display:flex;align-items:center;gap:5px;min-width:0;overflow:hidden}
.mc-row-cat-label{font-size:11px;font-weight:600;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mc-cat-dot{
  flex-shrink:0;width:6px;height:6px;border-radius:50%;
}
.mc-cat-dot--budget{background:var(--amber)}
.mc-cat-dot--keywords{background:var(--accent2)}
.mc-cat-dot--creative{background:color-mix(in srgb,var(--amber) 55%,var(--accent2) 45%)}
.mc-cat-dot--bidding{background:var(--green)}
.mc-cat-dot--quality{background:color-mix(in srgb,var(--green) 70%,var(--accent2) 30%)}
.mc-cat-dot--structure{background:var(--text3)}
.mc-cat-dot--tracking{background:var(--red)}
.mc-cat-dot--connectivity{background:color-mix(in srgb,var(--red) 55%,var(--amber) 45%)}

/* Source */
.mc-row-source{font-size:11px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Actionability */
.mc-row-actionability{
  font-size:11px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.mc-row-actionability--actionable{color:var(--green)}
.mc-row-actionability--advisory{color:var(--accent2)}
.mc-row-actionability--blocked{color:var(--amber)}

/* Impact mini-bars (2 vertical bars) */
.mc-impact-bars{display:flex;align-items:flex-end;justify-content:center;gap:3px;height:18px}
.mc-impact-track{
  width:6px;height:100%;border-radius:3px;
  background:var(--surface3);position:relative;overflow:hidden;
}
.mc-impact-fill{
  position:absolute;bottom:0;left:0;right:0;border-radius:3px;
  transition:height 0.4s ease;
}
.mc-impact-fill--impact{background:var(--green)}
.mc-impact-fill--confidence{background:var(--accent2)}

/* Age + chevron */
.mc-row-age{font-size:10px;color:var(--text3);white-space:nowrap;text-align:right}
.mc-row-chevron{display:flex;align-items:center;justify-content:center;color:var(--text3);transition:transform 0.3s cubic-bezier(0.34,1.18,0.64,1)}
.mc-row-chevron--open{transform:rotate(180deg)}

/* Platform filter clear pill */
.mc-platform-clear{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent2) 30%,var(--border));
  background:color-mix(in srgb,var(--accent2) 10%,transparent);
  color:var(--accent2);font:inherit;font-size:11px;font-weight:600;
  cursor:pointer;transition:all 0.15s;
}
.mc-platform-clear:hover{background:color-mix(in srgb,var(--accent2) 18%,transparent)}

/* Category dot in dropdown */
.mc-dropdown-item-cat{display:flex;align-items:center;gap:6px}

/* Expandable body */
.mc-row-body-wrap{
  overflow:hidden;
  transition:height 0.35s cubic-bezier(0.34,1.18,0.64,1);
}
.mc-row-body{
  padding:0 14px 14px;display:flex;flex-direction:column;gap:8px;
  border-top:1px solid var(--border);
}
.mc-row-desc{font-size:12px;color:var(--text2);line-height:1.6;margin-top:10px}
.mc-row-context{font-size:11px;color:var(--text3)}
.mc-row-note{
  padding:6px 10px;border-radius:8px;
  background:color-mix(in srgb,var(--accent2) 10%,transparent);
  color:var(--accent2);font-size:11px;font-weight:600;
}
.mc-row-alert{padding:6px 10px;border-radius:8px;font-size:11px;font-weight:600;line-height:1.5}
.mc-row-alert--error{background:var(--red-bg);color:var(--red)}
.mc-row-alert--warn{background:var(--amber-bg);color:var(--amber)}
.mc-row-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}

/* Confirm portal */
.mc-confirm-backdrop{position:fixed;inset:0;z-index:9998;background:rgba(0,0,0,0.18);backdrop-filter:blur(1px)}
.mc-confirm{
  z-index:9999;
  padding:14px;border-radius:14px;border:1px solid var(--border2);
  background:var(--modal-bg);box-shadow:var(--shadow-xl);backdrop-filter:blur(18px);
}
.mc-confirm-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}
.mc-confirm-desc{font-size:11px;color:var(--text2);line-height:1.5}
.mc-confirm-body{margin-top:10px}
.mc-confirm-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}
.mc-snooze-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}

/* Loading skeleton */
.mc-loading{display:flex;flex-direction:column;gap:8px;padding:8px 0}
.mc-skel{height:40px;border-radius:12px;background:var(--surface2);animation:pulse 1.4s ease-in-out infinite}
.mc-skel--short{width:65%}

/* Empty states */
.mc-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;min-height:200px;padding:24px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent2) 6%,transparent),transparent 40%);
  border:1px dashed var(--border2);text-align:center;
}
.mc-empty--slim{min-height:120px}
.mc-empty-title{font-size:15px;font-weight:700;color:var(--text)}
.mc-empty-sub{max-width:400px;font-size:12px;color:var(--text3);line-height:1.5}

/* ── Mission Control tab panel ────────────────────────────────────────────── */
:root{--mc-row-grid:12px 82px 70px minmax(0,1fr) 120px 80px 120px 52px 90px 80px 28px}
.mct-inner{display:flex;flex-direction:column;gap:20px}
.mct-header{display:flex;flex-direction:column;gap:10px}
.mct-title-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.mct-title-block{display:flex;flex-direction:column;gap:2px}
.mct-header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}

/* Combined action bar: view filter buttons (left) + category/group dropdowns (right) */
.mct-action-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.mct-right-filters{display:flex;align-items:center;gap:4px;margin-left:auto}

/* View filter strip (replaces mc-seg + stats strip) */
.mct-view-strip{display:flex;align-items:center;gap:2px}
.mc-view-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;padding:1px 5px;border-radius:999px;
  background:var(--surface3);font-size:9px;font-weight:700;color:var(--text3);
  font-variant-numeric:tabular-nums;
}
.mc-view-count--active{background:color-mix(in srgb,var(--accent2) 16%,transparent);color:var(--accent2)}

/* Tracking health bar */
.mc-health-wrap{height:4px;border-radius:999px;background:var(--surface3);overflow:hidden}
.mc-health-bar{height:100%;border-radius:999px;transition:width 0.5s ease}
.mc-health-bar--good{background:var(--green)}
.mc-health-bar--warn{background:var(--amber)}
.mc-health-bar--poor{background:var(--red)}

/* Last run indicator */
.mc-last-run{font-size:11px;color:var(--text3);white-space:nowrap}

/* Column header row — sticky below global app header */
.mc-table-header{
  position:sticky;top:56px;z-index:10;
  display:grid;grid-template-columns:var(--mc-row-grid);align-items:center;
  gap:0 8px;padding:6px 14px;
  background:var(--bg);border-bottom:1px solid var(--border);
  margin-bottom:4px;
}
.mc-th{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-th--center{text-align:center}
.mc-th--right{text-align:right}

/* ── Dashboard summary card (condensed) ──────────────────────────────────── */
.mc-summary{display:flex;flex-direction:column;gap:14px}
.mc-summary-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;min-height:160px;padding:20px;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,color-mix(in srgb,var(--accent2) 6%,transparent),transparent 40%);
  border:1px dashed var(--border2);text-align:center;
}
.mc-summary-top{display:flex;align-items:center;justify-content:space-between;gap:16px}
.mc-summary-stats{display:flex;align-items:baseline;gap:14px}
.mc-summary-stat{display:flex;align-items:baseline;gap:6px}
.mc-summary-stat--muted{opacity:0.6}
.mc-summary-num{font-size:28px;font-weight:800;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}
.mc-summary-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.06em}
.mc-summary-divider{width:1px;height:22px;background:var(--border2);align-self:center}

/* Priority bar */
.mc-summary-bar-wrap{display:flex;flex-direction:column;gap:6px}
.mc-summary-bar{display:flex;height:6px;border-radius:999px;overflow:hidden;gap:2px}
.mc-summary-bar-seg{border-radius:999px;transition:flex 0.3s ease}
.mc-summary-bar-seg--critical{background:var(--red)}
.mc-summary-bar-seg--warn{background:var(--amber)}
.mc-summary-bar-seg--info{background:var(--surface3)}
.mc-summary-bar-legend{display:flex;gap:10px}
.mc-summary-bar-label{font-size:10px;font-weight:600;color:var(--text3)}
.mc-summary-bar-label--critical{color:var(--red)}
.mc-summary-bar-label--warn{color:var(--amber)}

/* Category chips */
.mc-summary-cats{display:flex;flex-wrap:wrap;gap:6px}
.mc-summary-cat{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface2);font-size:11px;font-weight:600;color:var(--text2);
}
.mc-summary-cat-count{
  min-width:16px;padding:1px 5px;border-radius:999px;
  background:var(--surface3);font-size:9px;font-weight:700;color:var(--text3);text-align:center;
}

/* Footer + CTA */
.mc-summary-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:2px}
.mc-summary-loading{font-size:11px;color:var(--text3)}
.mc-summary-cta{display:inline-flex;align-items:center;gap:6px}

/* Responsive — stack on narrow viewports */
@media(max-width:720px){
  .ahs-wrap{flex-direction:column;align-items:stretch}
  .ahs-score-col{flex:none;flex-direction:row;gap:12px}
  .ahs-dim-label{width:110px}
  .ahs-actions-col{flex:none;flex-direction:row;flex-wrap:wrap;gap:6px}
  .ahs-action-card{flex:1;min-width:140px}
  .mc-hero{flex-wrap:wrap}
  .mc-hero-platforms{margin-left:0}
  .mc-hero-refresh{margin-left:0;flex:1;justify-content:flex-end}
  /* Audit grid — collapse to 6 columns: chevron | tier | platform | title | category | actionability */
  :root{--mc-row-grid:12px 56px 52px minmax(0,1fr) 100px 90px}
  .mc-row-source,.mc-impact-bars,.mc-row-age,.mc-row-action-col,.mc-row-dismiss-x{display:none}
  .mc-table-header span:nth-child(6),
  .mc-table-header span:nth-child(8),
  .mc-table-header span:nth-child(9),
  .mc-table-header span:nth-child(10),
  .mc-table-header span:nth-child(11){display:none}
}

/* ── SYSTEM STATUS STRIP ────────────────────────────────────────────────────── */

.dss-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

/* ── Card ── */
.dss-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  padding: 16px;
  gap: 10px;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.2s ease, border-color 0.2s ease;
  animation: dashFadeInUp 0.45s ease backwards;
}
.dss-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(160deg, color-mix(in srgb, var(--accent) 5%, transparent) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.25s ease;
  pointer-events: none;
}
.dss-card:hover { box-shadow: var(--shadow-lg); border-color: var(--border2); }
.dss-card:hover::after { opacity: 1; }
.dss-card:nth-child(1) { animation-delay: 0.02s }
.dss-card:nth-child(2) { animation-delay: 0.07s }
.dss-card:nth-child(3) { animation-delay: 0.12s }
.dss-card:nth-child(4) { animation-delay: 0.17s }
.dss-card:nth-child(5) { animation-delay: 0.22s }

/* ── Card head: icon + badge ── */
.dss-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

.dss-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* ── Status badge ── */
.dss-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 3px 7px;
  border-radius: 5px;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: flex-start;
}
.dss-badge--ok {
  background: color-mix(in srgb, var(--green) 14%, transparent);
  color: var(--green);
}
.dss-badge--warn {
  background: color-mix(in srgb, var(--amber) 14%, transparent);
  color: var(--amber);
}
.dss-badge--error {
  background: color-mix(in srgb, var(--red) 14%, transparent);
  color: var(--red);
}
.dss-badge--info {
  background: color-mix(in srgb, var(--text3) 14%, transparent);
  color: var(--text2);
}
.dss-badge--running {
  background: color-mix(in srgb, var(--text3) 14%, transparent);
  color: var(--text2);
  animation: dssPulse 1.6s ease-in-out infinite;
}
@keyframes dssPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.55; }
}

/* ── Card content ── */
.dss-card-content { flex: 1; display: flex; flex-direction: column; gap: 4px; }

.dss-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text1);
  line-height: 1.2;
}

.dss-body {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Divider ── */
.dss-divider {
  height: 1px;
  background: var(--border);
  margin: 0 -16px;
}

/* ── Footer ── */
.dss-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 22px;
}

.dss-tags {
  font-size: 11px;
  color: var(--text3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

.dss-cta {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 3px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity 0.15s ease;
}
.dss-cta:hover { opacity: 0.75; }

/* ── Customise popover additions ── */
.dash-customise-row--strip { font-weight: 600; }
.dash-customise-sep {
  height: 1px;
  background: var(--border);
  margin: 6px 0;
}

/* ── Responsive ── */
@media (max-width: 1280px) {
  .dss-strip { grid-template-columns: repeat(3, 1fr); }
  .dss-card:nth-child(4),
  .dss-card:nth-child(5) { grid-column: span 1; }
}
@media (max-width: 860px) {
  .dss-strip { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .dss-strip { grid-template-columns: 1fr; }
}
