/* ============================================
   ELEVATED THOUGHTS — Intelligence Edition
   Newsletter CSS — Command Center Aesthetic
   ============================================ */

/* --- Push content below fixed nav --- */
.intel-classification:first-child {
  margin-top: var(--nav-height);
}

/* --- Classification Banner --- */
.intel-classification {
  background: linear-gradient(90deg, rgba(217, 123, 0, 0.15) 0%, rgba(217, 123, 0, 0.05) 50%, rgba(217, 123, 0, 0.15) 100%);
  border-top: 1px solid var(--accent);
  border-bottom: 1px solid rgba(217, 123, 0, 0.3);
  padding: var(--space-2) 0;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.intel-classification::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(217, 123, 0, 0.1), transparent);
  animation: scanline 4s linear infinite;
}

@keyframes scanline {
  0% { left: -50%; }
  100% { left: 100%; }
}

/* --- Stats Ticker --- */
.intel-ticker {
  background: var(--bg-void);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  padding: var(--space-3) 0;
  position: relative;
}

.intel-ticker__track {
  display: flex;
  gap: var(--space-12);
  animation: ticker 30s linear infinite;
  white-space: nowrap;
  width: max-content;
}

.intel-ticker__item {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}

.intel-ticker__value {
  color: var(--accent-light);
  font-weight: var(--weight-bold);
  font-size: var(--text-base);
}

.intel-ticker__pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22c55e;
  animation: pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}

.intel-ticker__pulse--warn {
  background: #f59e0b;
}

.intel-ticker__pulse--danger {
  background: #ef4444;
}

@keyframes ticker {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}

/* --- Hero: Intelligence Edition --- */
.intel-hero {
  padding-top: calc(var(--nav-height) + var(--space-12));
  padding-bottom: var(--space-12);
  position: relative;
  overflow: hidden;
  text-align: center;
}

.intel-hero::before {
  content: '';
  position: absolute;
  top: -60%;
  left: 50%;
  transform: translateX(-50%);
  width: 140%;
  height: 160%;
  background:
    radial-gradient(ellipse 30% 40% at 50% 30%, rgba(217, 123, 0, 0.12) 0%, transparent 70%),
    radial-gradient(ellipse 60% 30% at 30% 60%, rgba(239, 68, 68, 0.04) 0%, transparent 60%),
    radial-gradient(ellipse 60% 30% at 70% 60%, rgba(59, 130, 246, 0.04) 0%, transparent 60%);
  pointer-events: none;
}

.intel-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(255, 255, 255, 0.008) 2px,
    rgba(255, 255, 255, 0.008) 4px
  );
  pointer-events: none;
  opacity: 0.5;
}

.intel-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(217, 123, 0, 0.1);
  border: 1px solid rgba(217, 123, 0, 0.3);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-6);
}

.intel-hero__badge .pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  animation: pulse 2s ease-in-out infinite;
  box-shadow: 0 0 8px var(--accent-glow);
}

.intel-hero h1 {
  font-size: var(--text-3xl);
  max-width: 18ch;
  margin: 0 auto var(--space-6);
  line-height: 1.05;
  letter-spacing: -0.02em;
  background: linear-gradient(180deg, rgba(255,255,255,0.97) 0%, rgba(255,255,255,0.6) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
  z-index: 1;
}

.intel-hero__sub {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  letter-spacing: var(--tracking-wide);
}

/* --- Section Headers (Intel Style) --- */
.intel-section-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.intel-section-header__line {
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}

.intel-section-header__line--right {
  background: linear-gradient(90deg, transparent, var(--accent));
}

.intel-section-header__label {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  white-space: nowrap;
}

/* Section context descriptions */
.intel-section-context {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
  max-width: 65ch;
}

/* --- Radar Chart --- */
.intel-radar {
  padding: var(--space-12) 0;
  position: relative;
}

.intel-radar__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .intel-radar__container {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--space-12);
  }
}

.intel-radar__chart {
  width: 100%;
  max-width: 420px;
  aspect-ratio: 1;
  flex-shrink: 0;
}

.intel-radar__chart svg {
  width: 100%;
  height: 100%;
  filter: drop-shadow(0 0 20px rgba(217, 123, 0, 0.15));
}

.radar-grid {
  stroke: rgba(255, 255, 255, 0.06);
  fill: none;
  stroke-width: 0.5;
}

.radar-axis {
  stroke: rgba(255, 255, 255, 0.08);
  stroke-width: 0.5;
}

.radar-area {
  fill: rgba(217, 123, 0, 0.12);
  stroke: var(--accent);
  stroke-width: 2;
  stroke-linejoin: round;
  filter: drop-shadow(0 0 6px rgba(217, 123, 0, 0.4));
  transition: all 0.6s var(--ease-out);
}

.radar-point {
  fill: var(--accent);
  stroke: var(--bg-deep);
  stroke-width: 2;
  filter: drop-shadow(0 0 4px rgba(217, 123, 0, 0.6));
}

.radar-label {
  font-family: var(--font-mono);
  font-size: 10px;
  fill: var(--text-secondary);
  text-anchor: middle;
  dominant-baseline: middle;
}

.radar-value {
  font-family: var(--font-mono);
  font-size: 9px;
  fill: var(--accent-light);
  text-anchor: middle;
  dominant-baseline: middle;
}

.intel-radar__legend {
  flex: 1;
  min-width: 0;
}

.intel-radar__legend-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border);
}

.intel-radar__legend-item:last-child {
  border-bottom: none;
}

.intel-radar__legend-name {
  font-size: var(--text-base);
  color: var(--text-secondary);
  font-family: var(--font-body);
}

.intel-radar__legend-bar-wrap {
  flex: 1;
  margin: 0 var(--space-4);
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-full);
  overflow: hidden;
  direction: rtl;
}

.intel-radar__legend-bar {
  height: 100%;
  background: linear-gradient(270deg, var(--accent), var(--accent-light));
  border-radius: var(--radius-full);
  transition: width 1.5s var(--ease-out);
  animation: legendPulse 3s ease-in-out infinite;
}

@keyframes legendPulse {
  0%, 100% { opacity: 0.7; }
  50% { opacity: 1; }
}

.intel-radar__legend-count {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent-light);
  min-width: 3ch;
  text-align: right;
}

.intel-radar__legend-pct {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  min-width: 4ch;
  text-align: right;
  margin-left: var(--space-2);
}

/* --- Threat Cascade Network (HTML Card Flow) --- */
.intel-cascade {
  padding: var(--space-12) 0;
  position: relative;
}

.cascade-flow {
  position: relative;
}

.cascade-flow__headers {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.cascade-flow__header {
  text-align: center;
  padding: var(--space-3);
}

.cascade-flow__header-label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.cascade-flow__header-desc {
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.cascade-flow__header--danger .cascade-flow__header-label { color: #f87171; }
.cascade-flow__header--warn .cascade-flow__header-label { color: #fbbf24; }
.cascade-flow__header--accent .cascade-flow__header-label { color: var(--accent); }
.cascade-flow__header--blue .cascade-flow__header-label { color: #60a5fa; }

.cascade-flow__connectors {
  display: none;
}

.cascade-flow__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
  align-items: start;
}

.cascade-flow__column {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
}

/* Arrow connectors between columns */
.cascade-flow__column:not(:last-child)::after {
  content: '';
  position: absolute;
  right: calc(-1 * var(--space-3) / 2);
  top: 50%;
  transform: translateY(-50%);
  width: var(--space-3);
  height: 2px;
  background: rgba(255, 255, 255, 0.1);
  z-index: 1;
}

/* Cascade cards */
.cascade-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  cursor: pointer;
  transition: all 0.3s var(--ease-out);
  position: relative;
}

.cascade-card:hover,
.cascade-card:focus {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.cascade-card--origin {
  border-color: rgba(239, 68, 68, 0.4);
  background: rgba(239, 68, 68, 0.04);
}
.cascade-card--origin:hover { border-color: rgba(239, 68, 68, 0.7); box-shadow: 0 0 20px rgba(239, 68, 68, 0.15); }

.cascade-card--mid {
  border-color: rgba(245, 158, 11, 0.3);
  background: rgba(245, 158, 11, 0.03);
}
.cascade-card--mid:hover { border-color: rgba(245, 158, 11, 0.6); box-shadow: 0 0 16px rgba(245, 158, 11, 0.12); }

.cascade-card--end {
  border-color: rgba(217, 123, 0, 0.25);
  background: rgba(217, 123, 0, 0.03);
}
.cascade-card--end:hover { border-color: rgba(217, 123, 0, 0.5); box-shadow: 0 0 16px rgba(217, 123, 0, 0.12); }

.cascade-card--you {
  border-color: rgba(59, 130, 246, 0.3);
  background: rgba(59, 130, 246, 0.04);
}
.cascade-card--you:hover { border-color: rgba(59, 130, 246, 0.6); box-shadow: 0 0 16px rgba(59, 130, 246, 0.15); }

.cascade-card__front {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.cascade-card__title {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--text-primary);
  line-height: var(--leading-snug);
}

.cascade-card__subtitle {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.cascade-card__detail {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s var(--ease-out), margin-top 0.3s;
}

.cascade-card__detail p {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.cascade-card--expanded .cascade-card__detail {
  max-height: 200px;
  margin-top: var(--space-3);
}

@media (max-width: 767px) {
  .cascade-flow__headers {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
  }
  .cascade-flow__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
  }
  .cascade-card__title {
    font-size: var(--text-xs);
  }
}

/* --- Source Constellation --- */
.intel-constellation {
  padding: var(--space-12) 0;
}

.intel-constellation__viz {
  background: var(--bg-void);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  min-height: 350px;
}

.intel-constellation__viz::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(217, 123, 0, 0.03) 0%, transparent 70%);
  pointer-events: none;
}

.constellation-svg {
  width: 100%;
  height: 350px;
}

.constellation-star {
  transition: all 0.3s var(--ease-out);
}

.constellation-star--t1 {
  fill: var(--accent);
  filter: drop-shadow(0 0 6px rgba(217, 123, 0, 0.8));
}

.constellation-star--t2 {
  fill: rgba(217, 123, 0, 0.6);
  filter: drop-shadow(0 0 4px rgba(217, 123, 0, 0.4));
}

.constellation-star--unverified {
  fill: rgba(255, 255, 255, 0.15);
}

.constellation-link {
  stroke: rgba(217, 123, 0, 0.06);
  stroke-width: 0.5;
}

.constellation-legend {
  display: flex;
  justify-content: center;
  gap: var(--space-6);
  margin-top: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.constellation-legend__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: var(--space-2);
  vertical-align: middle;
}

/* Constellation tooltip */
.constellation-tooltip {
  display: none;
  position: absolute;
  background: var(--bg-elevated);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-primary);
  pointer-events: none;
  z-index: 10;
  white-space: nowrap;
  box-shadow: var(--shadow-lg);
}

.constellation-tooltip strong {
  color: var(--accent-light);
}

/* Constellation expand button */
.constellation-expand-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  cursor: pointer;
  transition: all 0.2s;
}

.constellation-expand-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.constellation-expand-btn svg {
  transition: transform 0.3s;
}

.constellation-expand-btn--open svg {
  transform: rotate(180deg);
}

/* Constellation detail panel */
.constellation-detail {
  margin-top: var(--space-4);
  animation: fadeIn 0.3s ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

.constellation-detail__grid {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .constellation-detail__grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

.constellation-detail__tier {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}

.constellation-detail__tier h5 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-2);
}

.constellation-detail__desc {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-4);
}

.constellation-detail__source {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border);
}

.constellation-detail__source:last-child {
  border-bottom: none;
}

.constellation-detail__source-name {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.constellation-detail__source-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent-light);
}

/* --- Signal/Noise Indicators --- */
.intel-signal {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text-muted);
}

.intel-signal__bar {
  display: flex;
  gap: 2px;
  align-items: flex-end;
}

.intel-signal__bar span {
  width: 3px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 1px;
  transition: background 0.3s;
}

.intel-signal__bar span.active {
  background: var(--accent);
  box-shadow: 0 0 4px var(--accent-glow);
}

/* --- Status Badges --- */
.intel-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

.intel-status--accelerating {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.intel-status--new-signal {
  background: rgba(245, 158, 11, 0.12);
  color: #fbbf24;
  border: 1px solid rgba(245, 158, 11, 0.3);
}

.intel-status--confirmed {
  background: rgba(34, 197, 94, 0.1);
  color: #4ade80;
  border: 1px solid rgba(34, 197, 94, 0.25);
}

/* --- Watchpoints Timeline --- */
.intel-watchpoints {
  padding: var(--space-12) 0;
}

.watchpoint-timeline {
  position: relative;
  padding-left: var(--space-8);
}

.watchpoint-timeline::before {
  content: '';
  position: absolute;
  left: 11px;
  top: 10px;
  bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--accent), rgba(217, 123, 0, 0.1));
}

.watchpoint {
  position: relative;
  padding-bottom: var(--space-8);
}

.watchpoint:last-child {
  padding-bottom: 0;
}

.watchpoint__marker {
  position: absolute;
  left: calc(-1 * var(--space-8) + 4px);
  top: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--bg-deep);
  border: 2px solid var(--accent);
  box-shadow: 0 0 8px var(--accent-glow);
  z-index: 1;
}

.watchpoint__marker--hot {
  border-color: #ef4444;
  box-shadow: 0 0 12px rgba(239, 68, 68, 0.4);
  animation: pulse 2s ease-in-out infinite;
}

.watchpoint__date {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-1);
}

.watchpoint__title {
  font-family: var(--font-body);
  font-size: var(--text-xl);
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
  margin-bottom: var(--space-2);
  line-height: var(--leading-snug);
}

.watchpoint__desc {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.watchpoint__signal {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: flex-start;
}

.watchpoint__signal-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: 1.4;
}

.watchpoint__signal-pill--bullish {
  background: rgba(74, 222, 128, 0.08);
  border: 1px solid rgba(74, 222, 128, 0.25);
  color: #4ade80;
}

.watchpoint__signal-pill--bearish {
  background: rgba(248, 113, 113, 0.08);
  border: 1px solid rgba(248, 113, 113, 0.25);
  color: #f87171;
}

/* --- Intel Story Cards (enhanced) --- */
.intel-story {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: all 0.3s var(--ease-out);
}

.intel-story:hover {
  border-color: var(--border-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.intel-story__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.intel-story h4 {
  font-size: var(--text-lg);
  color: var(--text-primary);
  line-height: var(--leading-snug);
}

.intel-story p {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  margin-top: var(--space-3);
  font-family: var(--font-body);
}

.intel-story__expand {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  opacity: 0.6;
  transition: opacity 0.2s;
}

.intel-story:hover .intel-story__expand {
  opacity: 1;
}

.intel-story__sources {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.intel-story__source {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-muted);
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all 0.2s;
}

.intel-story__source:hover {
  color: var(--accent);
  border-color: var(--accent);
}

/* --- Story Modal --- */
.intel-modal {
  background: transparent;
  border: none;
  padding: 0;
  max-width: 640px;
  width: 90vw;
  margin: auto;
}

.intel-modal::backdrop {
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(4px);
}

.intel-modal__content {
  background: var(--bg-surface);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  position: relative;
  color: var(--text-primary);
}

.intel-modal__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  background: none;
  border: 1px solid var(--border);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: var(--text-xl);
  color: var(--text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  line-height: 1;
}

.intel-modal__close:hover {
  color: var(--text-primary);
  border-color: var(--accent);
}

.intel-modal__content h3 {
  font-size: var(--text-xl);
  margin: var(--space-4) 0 var(--space-3);
  line-height: var(--leading-snug);
  padding-right: var(--space-8);
}

.intel-modal__summary {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
}

.intel-modal__analysis {
  background: rgba(217, 123, 0, 0.04);
  border: 1px solid rgba(217, 123, 0, 0.15);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}

.intel-modal__analysis h5 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-3);
}

.intel-modal__analysis p {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.intel-modal__sources h5 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-3);
}

.intel-modal__source-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  text-decoration: none;
  transition: all 0.2s;
}

.intel-modal__source-link:hover {
  border-color: var(--accent);
  background: rgba(217, 123, 0, 0.04);
}

.intel-modal__source-name {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.intel-modal__source-type {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
}

/* --- Intro Section (Intel enhanced) --- */
.intel-intro {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  position: relative;
}

.intel-intro::first-line {
  color: var(--text-primary);
}

/* --- Takes Grid (Intel enhanced) --- */
.intel-takes {
  display: grid;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .intel-takes {
    grid-template-columns: 1fr 1fr;
  }
}

.intel-take {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
}

.intel-take--cooper {
  border-top: 3px solid #dc2626;
}

.intel-take--mike {
  border-top: 3px solid #3b82f6;
}

.intel-take__badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
}

.intel-take--cooper .intel-take__badge {
  background: rgba(220, 38, 38, 0.12);
  color: #f87171;
}

.intel-take--mike .intel-take__badge {
  background: rgba(59, 130, 246, 0.12);
  color: #60a5fa;
}

.intel-take__text {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  font-style: italic;
}

/* --- Threat Matrix (small grid) --- */
.threat-matrix {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.threat-cell {
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.threat-cell--critical {
  border-color: rgba(239, 68, 68, 0.3);
}

.threat-cell--critical::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(239, 68, 68, 0.04);
  pointer-events: none;
}

.threat-cell--elevated {
  border-color: rgba(245, 158, 11, 0.3);
}

.threat-cell--elevated::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(245, 158, 11, 0.03);
  pointer-events: none;
}

.threat-cell__value {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  line-height: 1;
}

.threat-cell__label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-muted);
  margin-top: var(--space-2);
}

.threat-cell__delta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  margin-top: var(--space-1);
}

.threat-cell__delta--up {
  color: #ef4444;
}

.threat-cell__delta--down {
  color: #22c55e;
}

/* --- Dominant Narrative Box --- */
.intel-dominant {
  position: relative;
  background: var(--bg-surface);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  overflow: hidden;
  isolation: isolate;
}

.intel-dominant::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-xl);
  padding: 1.5px;
  background: conic-gradient(from 0deg, #ef4444, #f59e0b, var(--accent), #3b82f6, #ef4444);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  animation: borderRotate 6s linear infinite;
  opacity: 0.6;
  z-index: -1;
}

@keyframes borderRotate {
  to {
    --angle: 360deg;
  }
}

@property --angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

.intel-dominant::after {
  content: '';
  position: absolute;
  inset: 1.5px;
  background: var(--bg-surface);
  border-radius: calc(var(--radius-xl) - 1.5px);
  z-index: -1;
}

.intel-dominant__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: #f87171;
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.intel-dominant__text {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--text-primary);
  line-height: var(--leading-snug);
}

/* --- Threat Cell Top Bar Pulse --- */
.threat-cell--critical {
  overflow: hidden;
}

.threat-cell--critical::after {
  content: '';
  position: absolute;
  top: -1px;
  left: 20%;
  right: 20%;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ef4444, transparent);
  animation: threatPulse 3s ease-in-out infinite;
}

@keyframes threatPulse {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 1; }
}

/* --- Weekly Intake Sparkline --- */
.intel-sparkline {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  height: 120px;
  padding: var(--space-4) var(--space-2);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
}

.intel-sparkline__wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  min-width: 0;
  gap: var(--space-2);
  height: 100%;
  justify-content: flex-end;
}

.intel-sparkline__bar {
  width: 100%;
  background: linear-gradient(180deg, var(--accent), rgba(217, 123, 0, 0.2));
  border-radius: 3px 3px 0 0;
  transition: height 1s var(--ease-out);
  min-height: 4px;
  position: relative;
}

.intel-sparkline__bar::after {
  content: attr(data-count);
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--accent-light);
  white-space: nowrap;
}

.intel-sparkline__label {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--text-muted);
  text-align: center;
  flex-shrink: 0;
}

/* --- Closing Section (Intel) --- */
.intel-closing {
  position: relative;
  padding: var(--space-12) 0;
}

.intel-closing blockquote {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  border-left: 3px solid var(--accent);
  padding-left: var(--space-6);
  margin: 0;
  font-style: italic;
}

.intel-closing blockquote footer {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--space-4);
  font-style: normal;
}

/* --- Poll Section (Intel) --- */
.intel-poll {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: left;
}

.intel-poll h4 {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
}

.intel-poll__options {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.intel-poll__option {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  background: var(--bg-elevated);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
}

.intel-poll__option:hover {
  border-color: var(--accent);
  color: var(--text-primary);
  background: rgba(217, 123, 0, 0.04);
}

.intel-poll__option--selected {
  border-color: var(--accent);
  background: rgba(217, 123, 0, 0.08);
  color: var(--text-primary);
}

.intel-poll__radio {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border-hover);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.intel-poll__option--selected .intel-poll__radio {
  border-color: var(--accent);
}

.intel-poll__option--selected .intel-poll__radio::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
}

.intel-poll__bar {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: rgba(217, 123, 0, 0.06);
  transition: width 0.6s var(--ease-out);
  pointer-events: none;
}

.intel-poll__pct {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--accent);
  margin-left: auto;
  opacity: 0;
  transition: opacity 0.3s;
}

.intel-poll--voted .intel-poll__pct {
  opacity: 1;
}

/* --- Grid line background effect --- */
.intel-grid-bg {
  position: relative;
}

.intel-grid-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, black 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 60% 60% at 50% 40%, black 0%, transparent 70%);
}

/* --- Dividers --- */
.intel-divider {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border-hover), transparent);
  margin: var(--space-4) 0;
}

/* --- Responsive --- */
@media (max-width: 479px) {
  .intel-takes {
    grid-template-columns: 1fr;
  }

  .threat-matrix {
    grid-template-columns: repeat(2, 1fr);
  }

  .intel-hero h1 {
    font-size: var(--text-2xl);
  }

  .constellation-svg {
    height: 250px;
  }

  /* Disable glitch effect on mobile — text wraps and pseudo-elements overlap */
  .glitch-text::before,
  .glitch-text::after {
    display: none !important;
  }

  .intel-classification {
    font-size: 0.6rem;
    line-height: 1.4;
    padding: var(--space-2) var(--space-3);
  }
}

/* --- Keyword Cloud --- */
.intel-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  justify-content: center;
  padding: var(--space-4) 0;
}

.intel-keyword {
  font-family: var(--font-mono);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  transition: all 0.2s;
  line-height: 1.4;
}

.intel-keyword--xl {
  font-size: var(--text-lg);
  color: var(--accent);
  border-color: rgba(217, 123, 0, 0.3);
  background: rgba(217, 123, 0, 0.08);
}

.intel-keyword--lg {
  font-size: var(--text-base);
  color: var(--accent-light);
}

.intel-keyword--md {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.intel-keyword--sm {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* --- Next Episode Teaser (Intel) --- */
.intel-next {
  background: linear-gradient(135deg, rgba(217, 123, 0, 0.06) 0%, rgba(217, 123, 0, 0.02) 100%);
  border: 1px solid rgba(217, 123, 0, 0.15);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
}

.intel-next h6 {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-4);
}

.intel-next p {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  max-width: 60ch;
  margin: 0 auto;
}

/* --- Episode Card (Intel) --- */
.intel-episode {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.intel-episode__number {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

.intel-episode h4 {
  font-size: var(--text-lg);
  margin: var(--space-2) 0 var(--space-3);
}

.intel-episode p {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

/* --- Scrolling Keyword Banner --- */
.intel-keyword-scroll {
  overflow: hidden;
  padding: var(--space-6) 0;
  position: relative;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.intel-keyword-scroll::before,
.intel-keyword-scroll::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}

.intel-keyword-scroll::before {
  left: 0;
  background: linear-gradient(90deg, var(--bg-deep), transparent);
}

.intel-keyword-scroll::after {
  right: 0;
  background: linear-gradient(90deg, transparent, var(--bg-deep));
}

.intel-keyword-scroll__track {
  display: flex;
  gap: var(--space-6);
  animation: keywordScroll 40s linear infinite;
  width: max-content;
}

.intel-keyword-scroll__item {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

.intel-keyword-scroll__item .count {
  color: var(--accent);
  font-weight: var(--weight-bold);
}

@keyframes keywordScroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* --- Animated number counters --- */
.counter-value {
  font-variant-numeric: tabular-nums;
  transition: all 0.3s;
}

/* --- Glitch text effect for classification --- */
.glitch-text {
  position: relative;
}

@media (prefers-reduced-motion: no-preference) {
  .glitch-text::before,
  .glitch-text::after {
    content: attr(data-text);
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    overflow: hidden;
  }

  .glitch-text::before {
    color: #ef4444;
    clip-path: inset(0 0 60% 0);
    animation: glitch1 4s infinite linear;
  }

  .glitch-text::after {
    color: #3b82f6;
    clip-path: inset(40% 0 0 0);
    animation: glitch2 4s infinite linear;
  }
}

@keyframes glitch1 {
  0%, 94% { transform: none; }
  95% { transform: translateX(-2px); }
  96% { transform: translateX(2px); }
  97% { transform: none; }
}

@keyframes glitch2 {
  0%, 96% { transform: none; }
  97% { transform: translateX(2px); }
  98% { transform: translateX(-2px); }
  99% { transform: none; }
}
