/* ── Verdict Color Tokens ─────────────────────────────────── */
:root {
  --verdict-build-now: 142 76% 46%;
  --verdict-this-week: 213 90% 52%;
  --verdict-watchlist: 48 90% 50%;
  --verdict-reject: 0 72% 55%;
}

/* ── Report Stats Banner ─────────────────────────────────── */
.report-stats { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 2rem; padding: 1.25rem 1.5rem; background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 1rem; max-width: 80ch; box-shadow: 0 2px 8px -2px hsl(var(--color-foreground) / 0.08); }
.stat-chip { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.3rem 0.75rem; border-radius: 9999px; font-size: 0.8125rem; font-weight: 600; }
.stat-chip-green { background: hsl(142 76% 90%); color: hsl(142 76% 20%); border: 1px solid hsl(142 76% 70%); }
.stat-chip-blue { background: hsl(213 90% 90%); color: hsl(213 90% 25%); border: 1px solid hsl(213 90% 70%); }
.stat-chip-yellow { background: hsl(48 90% 85%); color: hsl(38 80% 25%); border: 1px solid hsl(48 90% 65%); }
.stat-chip-red { background: hsl(0 72% 90%); color: hsl(0 72% 30%); border: 1px solid hsl(0 72% 70%); }
.stat-count { font-size: 1rem; font-weight: 700; }

/* ── Article Prose ───────────────────────────────────────── */
.prose { max-width: 80ch; margin-left: auto; margin-right: auto; }
.prose h2, .prose h3, .prose h4 { color: hsl(var(--color-foreground)); font-weight: 800; letter-spacing: -0.03em; margin-top: 2.75rem; margin-bottom: 0.875rem; scroll-margin-top: 5rem; }
.prose h2 { font-size: 1.5rem; padding-bottom: 0.625rem; border-bottom: 2px solid hsl(var(--color-border)); }
.prose h3 { font-size: 1.1875rem; font-weight: 700; }
.prose h4 { font-size: 1rem; font-weight: 700; }
.prose p { margin-bottom: 1.25rem; line-height: 1.8; font-size: 0.9375rem; color: hsl(var(--color-muted-foreground)); }
.prose a { color: hsl(var(--color-primary)); text-underline-offset: 3px; }
.prose ul, .prose ol { margin-bottom: 1.25rem; padding-left: 1.5rem; color: hsl(var(--color-muted-foreground)); }
.prose li { margin-bottom: 0.375rem; line-height: 1.7; }
.prose code { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); padding: 0.125rem 0.375rem; border-radius: 0.375rem; font-size: 0.875em; font-family: "JetBrains Mono", monospace; color: hsl(var(--color-foreground)); }
.prose pre { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); border-radius: 0.75rem; padding: 1.25rem; overflow-x: auto; margin-bottom: 1.5rem; }
.prose pre code { background: none; border: none; padding: 0; }
.prose blockquote { background: hsl(var(--color-muted) / 0.3); border-left: 3px solid hsl(var(--color-primary)); border-radius: 0 0.5rem 0.5rem 0; padding: 0.875rem 1.125rem; margin-bottom: 1.25rem; color: hsl(var(--color-muted-foreground)); font-style: normal; line-height: 1.7; }
.prose blockquote strong { color: hsl(var(--color-foreground)); font-weight: 600; }
.prose hr { border-color: hsl(var(--color-border)); margin: 2rem 0; }

/* ── Enhanced numbered lists (Top 3 callouts) ───────────── */
.prose ol { margin-bottom: 1.25rem; padding-left: 0; color: hsl(var(--color-foreground)); }
.prose ol li { margin-bottom: 0.75rem; line-height: 1.65; background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 0.75rem; padding: 1rem 1.25rem 1rem 3.5rem; position: relative; color: hsl(var(--color-foreground)); }
.prose ol li:last-child { margin-bottom: 0; }
.prose ol li::before { content: attr(data-rank); position: absolute; left: 1rem; top: 1rem; width: 1.5rem; height: 1.5rem; border-radius: 50%; background: hsl(var(--color-primary)); color: hsl(var(--color-primary-foreground)); font-weight: 700; font-size: 0.75rem; display: flex; align-items: center; justify-content: center; }
.prose ol li code { background: hsl(var(--color-primary) / 0.1); color: hsl(var(--color-primary)); border: none; padding: 0.1rem 0.4rem; border-radius: 0.25rem; font-size: 0.875em; }
.prose ol li strong { color: hsl(var(--color-foreground)); font-weight: 600; }

/* ── Verdict Badges ──────────────────────────────────────── */
.verdict-badge { display: inline-flex; align-items: center; padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 700; white-space: nowrap; }
.badge-green { background: hsl(142 76% 90%); color: hsl(142 76% 20%); border: 1px solid hsl(142 76% 70%); }
.badge-blue { background: hsl(213 90% 90%); color: hsl(213 90% 25%); border: 1px solid hsl(213 90% 70%); }
.badge-yellow { background: hsl(48 90% 85%); color: hsl(38 80% 25%); border: 1px solid hsl(48 90% 65%); }
.badge-red { background: hsl(0 72% 90%); color: hsl(0 72% 30%); border: 1px solid hsl(0 72% 70%); }

/* ── Opportunity Cards ───────────────────────────────────── */
.opp-cards { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2rem; }
.opp-card { background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 0.875rem; padding: 1.25rem 1.25rem 1.25rem 1.5rem; border-left: 3px solid hsl(var(--color-border)); transition: box-shadow 0.15s ease; }
.opp-card:hover { box-shadow: 0 2px 8px hsl(var(--color-foreground) / 0.06); }
.opp-card[data-verdict="build_now"] { border-left-color: hsl(var(--verdict-build-now)); }
.opp-card[data-verdict="this_week"] { border-left-color: hsl(var(--verdict-this-week)); }
.opp-card[data-verdict="watchlist"] { border-left-color: hsl(var(--verdict-watchlist)); }
.opp-card[data-verdict="reject"] { border-left-color: hsl(var(--verdict-reject)); }
.opp-card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; margin-bottom: 0.5rem; flex-wrap: wrap; }
.opp-card-keyword { font-weight: 700; font-size: 1rem; display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.opp-card-keyword code { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); padding: 0.125rem 0.5rem; border-radius: 0.375rem; font-size: 0.875em; font-family: "JetBrains Mono", monospace; color: hsl(var(--color-foreground)); }
.opp-card-meta { display: flex; gap: 0.5rem; flex-shrink: 0; align-items: center; }
.opp-card-score { background: hsl(var(--color-primary) / 0.15); color: hsl(var(--color-primary)); border: 1px solid hsl(var(--color-primary) / 0.3); padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 700; }
.opp-card-hours { background: hsl(var(--color-muted)); color: hsl(var(--color-muted-foreground)); border: 1px solid hsl(var(--color-border)); padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 600; }
.opp-card-desc { font-size: 0.9rem; color: hsl(var(--color-foreground) / 0.7); line-height: 1.7; margin-bottom: 0.875rem; }
.opp-card-items { display: flex; flex-direction: column; gap: 0.625rem; border-top: 1px solid hsl(var(--color-border)); padding-top: 0.875rem; }
.opp-card-item { display: flex; gap: 0.625rem; font-size: 0.8125rem; line-height: 1.6; }
.opp-card-item-label { color: hsl(var(--color-foreground)); font-weight: 600; flex-shrink: 0; white-space: nowrap; }
.opp-card-item-value { color: hsl(var(--color-muted-foreground)); }

/* ── Enhanced Tables ─────────────────────────────────────── */
.table-wrapper { margin-bottom: 2rem; border: 1px solid hsl(var(--color-border)); border-radius: 0.75rem; overflow: hidden; }
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table-scroll-inner { min-width: max-content; }
.table-controls { padding: 0.5rem 0.75rem; background: hsl(var(--color-muted)); border-top: 1px solid hsl(var(--color-border)); display: flex; justify-content: flex-end; }
.table-toggle-btn { background: none; border: 1px solid hsl(var(--color-border)); border-radius: 0.375rem; padding: 0.375rem 0.75rem; font-size: 0.75rem; color: hsl(var(--color-muted-foreground)); cursor: pointer; font-family: inherit; transition: all 0.12s; min-height: 44px; }
.table-toggle-btn:hover { border-color: hsl(var(--color-primary)); color: hsl(var(--color-primary)); }
.table-toggle-btn:focus-visible { outline: 2px solid hsl(var(--color-primary)); outline-offset: 2px; }
.report-table { width: 100%; border-collapse: collapse; font-size: 0.8125rem; }
.report-table th { background: hsl(var(--color-muted)); color: hsl(var(--color-foreground)); font-weight: 600; padding: 0.5rem 0.625rem; text-align: left; border-bottom: 2px solid hsl(var(--color-border)); white-space: nowrap; position: relative; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.03em; }
.report-table td { padding: 0.625rem 0.625rem; border-bottom: 1px solid hsl(var(--color-border)); color: hsl(var(--color-muted-foreground)); vertical-align: top; line-height: 1.55; }
.report-table td.cell-verbose { min-width: 14rem; max-width: 22rem; white-space: normal; }
.report-table td.cell-narrow { white-space: nowrap; text-align: center; }
.report-table tr:last-child td { border-bottom: none; }
.report-table tr.row-alt td { background: hsl(var(--color-muted) / 0.4); }
.report-table td.sticky-col,
.report-table th.sticky-col { position: sticky; left: 0; z-index: 1; background: inherit; }
.report-table th.sticky-col { background: hsl(var(--color-muted)); z-index: 2; }
.report-table tr.row-alt td.sticky-col { background: hsl(var(--color-muted) / 0.6); }
.report-table td.sticky-col { font-weight: 600; color: hsl(var(--color-foreground)); white-space: nowrap; }

/* ── Card View (mobile) ──────────────────────────────────── */
.card-view .report-table { display: none; }
.card-view .table-cards { display: block !important; }
.table-cards { display: none; }
.table-card { background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 0.625rem; padding: 0.875rem 1rem; margin-bottom: 0.625rem; }
.table-card-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.5rem; margin-bottom: 0.5rem; }
.table-card-keyword { font-weight: 600; color: hsl(var(--color-foreground)); font-size: 0.9375rem; }
.table-card-meta { font-size: 0.75rem; color: hsl(var(--color-muted-foreground)); display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 0.375rem; }
.table-card-meta span { display: inline-flex; align-items: center; gap: 0.2rem; }
.table-card-mvp { margin-top: 0.5rem; font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); line-height: 1.5; }

/* ── Dense Table Cards ───────────────────────────────────── */
.dtc-container { margin-bottom: 2rem; }
.dtc-cards { display: flex; flex-direction: column; gap: 0.875rem; }
.dtc-card { background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 0.875rem; padding: 1.125rem 1.25rem 1.125rem 1.5rem; border-left: 3px solid hsl(var(--color-border)); transition: box-shadow 0.15s ease; }
.dtc-card:hover { box-shadow: 0 2px 8px hsl(var(--color-foreground) / 0.06); }
.dtc-card[data-verdict="build_now"] { border-left-color: hsl(var(--verdict-build-now)); }
.dtc-card[data-verdict="this_week"] { border-left-color: hsl(var(--verdict-this-week)); }
.dtc-card[data-verdict="watchlist"] { border-left-color: hsl(var(--verdict-watchlist)); }
.dtc-card[data-verdict="reject"] { border-left-color: hsl(var(--verdict-reject)); }
.dtc-header { display: flex; justify-content: space-between; align-items: center; gap: 0.75rem; margin-bottom: 0.5rem; flex-wrap: wrap; }
.dtc-keyword { font-weight: 700; font-size: 1rem; display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.dtc-keyword code { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); padding: 0.125rem 0.5rem; border-radius: 0.375rem; font-size: 0.875em; font-family: "JetBrains Mono", monospace; color: hsl(var(--color-foreground)); }
.dtc-score { background: hsl(var(--color-primary) / 0.15); color: hsl(var(--color-primary)); border: 1px solid hsl(var(--color-primary) / 0.3); padding: 0.125rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 700; flex-shrink: 0; }
.dtc-metrics { display: flex; flex-wrap: wrap; gap: 0.375rem; margin-bottom: 0.75rem; }
.dtc-metric { display: inline-flex; align-items: center; gap: 0.25rem; background: hsl(var(--color-muted)); padding: 0.1875rem 0.5rem; border-radius: 0.375rem; font-size: 0.75rem; color: hsl(var(--color-muted-foreground)); }
.dtc-metric-label { font-weight: 600; color: hsl(var(--color-foreground) / 0.7); }
.dtc-details { display: flex; flex-direction: column; gap: 0.5rem; border-top: 1px solid hsl(var(--color-border)); padding-top: 0.75rem; }
.dtc-detail { font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); line-height: 1.6; }
.dtc-detail-label { display: inline-block; font-weight: 600; color: hsl(var(--color-foreground)); margin-right: 0.375rem; }
.dtc-container .table-controls { padding: 0.5rem 0; display: flex; justify-content: flex-end; }

/* ── Red-Team Review Table ───────────────────────────────── */
.rtl-summary { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 1rem; font-size: 0.875rem; color: hsl(var(--color-muted-foreground)); }
.rtl-stat code { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); padding: 0.0625rem 0.375rem; border-radius: 0.25rem; font-size: 0.875em; font-family: "JetBrains Mono", monospace; font-weight: 600; color: hsl(var(--color-foreground)); }
.rtl-table { margin-bottom: 2rem; }
.rtl-row td { border-left: 3px solid transparent; }
.rtl-row[data-verdict="build_now"] td { border-left-color: hsl(var(--verdict-build-now)); background: hsl(142 76% 95%); }
.rtl-row[data-verdict="this_week"] td { border-left-color: hsl(var(--verdict-this-week)); background: hsl(213 90% 95%); }
.rtl-row[data-verdict="watchlist"] td { border-left-color: hsl(var(--verdict-watchlist)); background: hsl(48 90% 95%); }
.rtl-row[data-verdict="reject"] td { border-left-color: hsl(var(--verdict-reject)); background: hsl(0 72% 96%); }
.rtl-row td.sticky-col { background: inherit; }
.rtl-keyword code { background: hsl(var(--color-muted)); border: 1px solid hsl(var(--color-border)); padding: 0.125rem 0.5rem; border-radius: 0.375rem; font-size: 0.875em; font-family: "JetBrains Mono", monospace; color: hsl(var(--color-foreground)); font-weight: 600; }
.rtl-cell { vertical-align: top; }
.rtl-arrow { color: hsl(var(--color-muted-foreground)); margin: 0 0.25rem; }
.rtl-th-kill { min-width: 16rem; }
.rtl-kill { color: hsl(0 72% 30%); font-size: 0.8125rem; line-height: 1.55; }

/* ── Executive Summary ───────────────────────────────────── */
.exec-summary { background: hsl(var(--color-card)); border: 1px solid hsl(var(--color-border)); border-radius: 1rem; padding: 1.5rem; margin-bottom: 2rem; }
.exec-summary-title { font-size: 0.75rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: hsl(var(--color-muted-foreground)); margin-bottom: 1rem; }
.exec-items { display: grid; gap: 0.875rem; }
.exec-item { display: grid; grid-template-columns: 2rem 1fr auto; gap: 0.75rem; align-items: start; }
.exec-rank { width: 1.75rem; height: 1.75rem; border-radius: 50%; background: hsl(var(--color-primary)); color: hsl(var(--color-primary-foreground)); font-weight: 700; font-size: 0.8125rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.exec-item-content { min-width: 0; }
.exec-item-keyword { font-weight: 600; color: hsl(var(--color-foreground)); font-size: 0.9375rem; margin-bottom: 0.25rem; }
.exec-item-mvp { font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); line-height: 1.5; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.exec-item-score { display: flex; flex-direction: column; align-items: flex-end; gap: 0.25rem; flex-shrink: 0; }

/* ── Paywall ─────────────────────────────────────────────── */
.paywall-wrap { position: relative; }
.paywall-fade { position: absolute; bottom: 0; left: 0; right: 0; height: 5rem; background: linear-gradient(to top, hsl(var(--color-background)), transparent); pointer-events: none; }
.paywall-card { margin-top: 2rem; border: 1px solid hsl(var(--color-primary)/0.2); border-radius: 1rem; padding: 3rem 2rem; text-align: center; background: hsl(var(--color-card)); box-shadow: 0 0 0 1px hsl(var(--color-primary)/0.06), 0 8px 32px -8px hsl(var(--color-foreground) / 0.12); }
.paywall-card h3 { font-size: 1.25rem; font-weight: 800; color: hsl(var(--color-foreground)); margin-bottom: 0.5rem; letter-spacing: -0.02em; }
.paywall-card p { color: hsl(var(--color-muted-foreground)); font-size: 0.9375rem; margin-bottom: 1.5rem; line-height: 1.6; }
.paywall-btn { display: inline-block; background: hsl(var(--color-primary)); color: hsl(var(--color-primary-foreground)); font-weight: 600; font-size: 0.9375rem; padding: 0.875rem 2rem; border-radius: 0.625rem; text-decoration: none; transition: all 0.15s; min-height: 44px; box-shadow: 0 4px 14px hsl(var(--color-primary) / 0.3); }
.paywall-btn:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 6px 20px hsl(var(--color-primary) / 0.4); }
.paywall-btn:focus-visible { outline: 2px solid hsl(var(--color-primary)); outline-offset: 2px; }
.paywall-link { display: inline-block; margin-top: 0.75rem; color: hsl(var(--color-muted-foreground)); font-size: 0.875rem; text-decoration: underline; text-underline-offset: 3px; }
.pro-badge { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.75rem; font-weight: 600; padding: 0.125rem 0.625rem; border-radius: 9999px; background: hsl(var(--color-primary)/0.12); color: hsl(var(--color-primary)); border: 1px solid hsl(var(--color-primary)/0.25); }

.article-content { max-width: 80ch; width: 100%; margin-left: auto; margin-right: auto; }
article > header { max-width: 80ch; margin-left: auto; margin-right: auto; }

/* ── Structured callout item layout ──────────────────────── */
.callout-keyword { font-weight: 700; font-size: 1rem; margin-bottom: 0.375rem; display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.callout-score { background: hsl(var(--color-primary) / 0.15); color: hsl(var(--color-primary)); border: 1px solid hsl(var(--color-primary) / 0.3); padding: 0.0625rem 0.5rem; border-radius: 9999px; font-size: 0.75rem; font-weight: 700; }
.callout-signal { font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); margin-bottom: 0.5rem; font-style: italic; }
.callout-desc { font-size: 0.875rem; color: hsl(var(--color-foreground) / 0.8); line-height: 1.65; margin-bottom: 0.5rem; }
.callout-extra { font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); line-height: 1.55; margin-bottom: 0.25rem; }
.callout-extra-label { font-weight: 600; color: hsl(var(--color-foreground)); margin-right: 0.25rem; }
.callout-action { font-size: 0.8125rem; color: hsl(var(--color-muted-foreground)); line-height: 1.6; margin-top: 0.5rem; padding-top: 0.5rem; border-top: 1px solid hsl(var(--color-border)); }
.callout-action-label { display: inline-block; font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; background: hsl(var(--color-muted)); color: hsl(var(--color-foreground)); padding: 0.0625rem 0.375rem; border-radius: 0.25rem; margin-right: 0.375rem; }

/* ── Global focus indicators ─────────────────────────────── */
a:focus-visible,
button:focus-visible {
  outline: 2px solid hsl(var(--color-primary));
  outline-offset: 2px;
  border-radius: 0.25rem;
}

/* ── Skip navigation ─────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  padding: 0.5rem 1rem;
  background: hsl(var(--color-primary));
  color: hsl(var(--color-primary-foreground));
  font-weight: 600;
  font-size: 0.875rem;
  border-radius: 0 0 0.5rem 0.5rem;
  z-index: 9999;
  text-decoration: none;
}
.skip-link:focus {
  top: 0;
}
