/* Component-specific CSS variables (scoped to .report-preview) */
.report-preview {
  --bg-deep: hsl(248, 44%, 7%);
  --bg-card: hsl(248, 38%, 12%);
  --border-subtle: hsl(0, 0%, 100%, 0.08);
  --border-focus: hsl(258, 100%, 75%, 0.35);
  --text-primary: hsl(258, 52%, 95%);
  --text-secondary: hsl(258, 52%, 95%, 0.6);
  --text-muted: hsl(258, 52%, 95%, 0.4);
  --accent-purple: hsl(258, 100%, 75%);
  --accent-green: hsl(158, 64%, 52%);
  --accent-green-dim: hsl(158, 64%, 52%, 0.15);
  --accent-blue: hsl(213, 94%, 68%);
  --accent-red: hsl(0, 91%, 71%);
  --accent-red-dim: hsl(0, 91%, 71%, 0.10);
  --accent-gold: hsl(45, 90%, 61%);
  --accent-gold-dim: hsl(45, 90%, 61%, 0.10);
  --accent-blue-dim: hsl(213, 94%, 68%, 0.10);
  --accent-purple-dim: hsl(258, 100%, 75%, 0.10);
  --shadow-card: 0 8px 32px hsl(0, 0%, 0%, 0.4), 0 1px 0 hsl(0, 0%, 100%, 0.04) inset;
  --radius-lg: 16px;
  --radius-sm: 8px;
}

/* Demo page specific styles (only applied when .preview-wrapper exists) */
.preview-wrapper {
  width: 100%;
  max-width: 420px;
  margin: 0 auto;
}

/* ── Demo switcher (remove in production) ── */
.demo-label {
  font-size: 11px;
  color: var(--text-muted);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.demo-switcher {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
}

.demo-switcher button {
  flex: 1;
  padding: 8px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.demo-switcher button:hover {
  border-color: var(--border-focus);
  color: var(--text-primary);
}

.demo-switcher button.active {
  background: var(--accent-purple-dim);
  border-color: var(--accent-purple);
  color: var(--accent-purple);
}


/* ═══════════════════════════════════════════════
   REPORT PREVIEW — TIER-AWARE COMPONENT
   ═══════════════════════════════════════════════ */

.report-preview {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

/* ── Header ── */
.report-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-subtle);
  display: flex;
  align-items: center;
  gap: 12px;
}

.report-icon-wrap {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--accent-purple-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.report-header-text h4 {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}
.report-header-text p {
  font-size: 12px;
  font-weight: 500;
  margin-top: 1px;
}

/* ── Tier badge (next to subtitle) ── */
.tier-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px 2px 6px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  vertical-align: middle;
}
.tier-badge.launch {
  background: var(--accent-green-dim);
  color: var(--accent-green);
}
.tier-badge.growth {
  background: var(--accent-purple-dim);
  color: var(--accent-purple);
}
.tier-badge.scale {
  background: var(--accent-gold-dim);
  color: var(--accent-gold);
}

/* ── Intro ── */
.report-intro {
  padding: 14px 20px 6px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* ── Unlock Items ── */
.unlock-list {
  padding: 10px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.unlock-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: hsl(0, 0%, 100%, 0.02);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  transition: all 0.25s ease;
  animation: itemEnter 0.35s ease-out both;
}
.unlock-item:nth-child(1) { animation-delay: 0.05s; }
.unlock-item:nth-child(2) { animation-delay: 0.10s; }
.unlock-item:nth-child(3) { animation-delay: 0.15s; }
.unlock-item:nth-child(4) { animation-delay: 0.20s; }

@keyframes itemEnter {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.unlock-item:hover {
  border-color: var(--border-focus);
}

.unlock-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.unlock-icon.green { background: var(--accent-green-dim); }
.unlock-icon.blue { background: var(--accent-blue-dim); }
.unlock-icon.gold { background: var(--accent-gold-dim); }
.unlock-icon.red { background: var(--accent-red-dim); }

.unlock-text {
  flex: 1;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
  line-height: 1.4;
}
.unlock-text strong {
  color: var(--text-primary);
  font-weight: 600;
}

/* ── Footer ── */
.report-footer {
  padding: 12px 20px 14px;
  border-top: 1px solid var(--border-subtle);
  background: hsl(258, 100%, 75%, 0.03);
  text-align: center;
}
.report-footer p {
  font-size: 11px;
  color: var(--text-muted);
  font-style: italic;
}
.report-footer strong {
  color: var(--accent-purple);
  font-weight: 600;
  font-style: normal;
}
