/* Second Opinion — Org-wide Code Health Dashboard
   "Because one perspective is never enough."
   Aesthetic: Medical telemetry station meets premium fintech terminal.
   ECG traces, vital-sign readouts, layered glass, scan-line ambience. */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,300&family=Geist+Mono:wght@400;500;600;700&family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;0,9..144,700;0,9..144,800;1,9..144,300&display=swap');

/* ============================================
   Design Tokens
   ============================================ */
:root {
  /* Brand Palette — deep medical tones */
  --so-teal: #4a7c7e;
  --so-teal-bright: #5ec2c6;
  --so-blue: #6b9d9f;
  --so-gold: #e8b563;
  --so-coral: #d97b7b;
  --so-purple: #8b7ec8;
  --so-emerald: #5b9a6f;

  /* Project Colors */
  --color-ypc: #4a7c7e;
  --color-curbside: #e8b563;
  --color-the-wire: #6b9d9f;

  /* Dark Theme (default) — deep medical blacks with teal undertones */
  --bg-void: #050810;
  --bg-primary: #080c18;
  --bg-secondary: #0d1324;
  --bg-tertiary: #121a30;
  --bg-card: rgba(13, 19, 36, 0.75);
  --bg-card-hover: rgba(18, 26, 48, 0.88);
  --bg-glass: rgba(255, 255, 255, 0.025);
  --bg-glass-hover: rgba(255, 255, 255, 0.055);
  --border-glass: rgba(255, 255, 255, 0.06);
  --border-glass-hover: rgba(255, 255, 255, 0.12);
  --border-accent: rgba(94, 194, 198, 0.2);

  --text-primary: #e8edf5;
  --text-secondary: #8b97b0;
  --text-muted: #505d78;
  --text-bright: #ffffff;

  /* Gradients */
  --gradient-hero: radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 124, 126, 0.08) 0%, transparent 70%),
                   radial-gradient(ellipse 80% 60% at 80% 20%, rgba(139, 126, 200, 0.04) 0%, transparent 60%),
                   linear-gradient(180deg, #080c18 0%, #0a0f1e 100%);
  --gradient-card: linear-gradient(135deg, rgba(255,255,255,0.025) 0%, rgba(255,255,255,0.005) 100%);
  --gradient-accent: linear-gradient(135deg, var(--so-teal) 0%, var(--so-teal-bright) 100%);
  --gradient-gold: linear-gradient(135deg, #e8b563 0%, #f0d090 100%);
  --gradient-scanline: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(94, 194, 198, 0.015) 2px,
    rgba(94, 194, 198, 0.015) 4px
  );

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 12px 40px rgba(0, 0, 0, 0.6);
  --shadow-xl: 0 24px 60px rgba(0, 0, 0, 0.7);
  --shadow-glow-teal: 0 0 30px rgba(94, 194, 198, 0.12), 0 0 60px rgba(94, 194, 198, 0.04);
  --shadow-glow-gold: 0 0 30px rgba(232, 181, 99, 0.12);
  --shadow-glow-coral: 0 0 30px rgba(217, 123, 123, 0.12);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.04);

  /* Spacing */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;
  --space-4xl: 96px;

  /* Radii */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;

  /* Typography */
  --font-display: 'Fraunces', Georgia, serif;
  --font-heading: 'DM Sans', system-ui, -apple-system, sans-serif;
  --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;
  --font-mono: 'Geist Mono', 'JetBrains Mono', 'SF Mono', monospace;

  /* Grade Colors — vivid on dark */
  --grade-a-plus: #34d399;
  --grade-a: #34d399;
  --grade-a-minus: #6ee7b7;
  --grade-b-plus: #fbbf24;
  --grade-b: #f59e0b;
  --grade-b-minus: #d97706;
  --grade-c-plus: #fb923c;
  --grade-c: #f97316;
  --grade-c-minus: #ea580c;
  --grade-d: #f87171;
  --grade-f: #ef4444;
  --grade-na: #64748b;

  /* Transitions */
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --transition-fast: 150ms var(--ease-out-expo);
  --transition-base: 300ms var(--ease-out-expo);
  --transition-slow: 500ms var(--ease-out-expo);
  --transition-glacial: 800ms var(--ease-out-expo);
}

/* Light Theme */
[data-theme="light"] {
  --bg-void: #f0f3f7;
  --bg-primary: #f5f7fa;
  --bg-secondary: #ffffff;
  --bg-tertiary: #f0f2f5;
  --bg-card: rgba(255, 255, 255, 0.92);
  --bg-card-hover: rgba(255, 255, 255, 1);
  --bg-glass: rgba(0, 0, 0, 0.02);
  --bg-glass-hover: rgba(0, 0, 0, 0.04);
  --border-glass: rgba(0, 0, 0, 0.07);
  --border-glass-hover: rgba(0, 0, 0, 0.13);
  --border-accent: rgba(74, 124, 126, 0.15);

  --text-primary: #111827;
  --text-secondary: #4b5563;
  --text-muted: #9ca3af;
  --text-bright: #000000;

  --gradient-hero: radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 124, 126, 0.05) 0%, transparent 70%),
                   linear-gradient(180deg, #f5f7fa 0%, #eef1f5 100%);
  --gradient-card: linear-gradient(135deg, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0.7) 100%);
  --gradient-scanline: none;

  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.07);
  --shadow-lg: 0 12px 40px rgba(0, 0, 0, 0.08);
  --shadow-xl: 0 24px 60px rgba(0, 0, 0, 0.1);
  --shadow-glow-teal: 0 0 30px rgba(74, 124, 126, 0.06);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.8);

  --grade-a-plus: #059669;
  --grade-a: #059669;
  --grade-a-minus: #10b981;
  --grade-b-plus: #d97706;
  --grade-b: #b45309;
  --grade-b-minus: #92400e;
  --grade-c-plus: #ea580c;
  --grade-c: #c2410c;
  --grade-c-minus: #9a3412;
  --grade-d: #dc2626;
  --grade-f: #b91c1c;
}

/* ============================================
   Base Reset
   ============================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: var(--font-body);
  font-weight: 400;
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Ambient background — the void with scan lines */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--gradient-hero);
  z-index: -2;
  pointer-events: none;
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--gradient-scanline);
  z-index: -1;
  pointer-events: none;
  opacity: 0.5;
}

a {
  color: var(--so-teal-bright);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover { color: var(--so-gold); }

a:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 3px;
  border-radius: 2px;
}

::selection {
  background: rgba(94, 194, 198, 0.25);
  color: var(--text-bright);
}

/* Skip nav for a11y */
.skip-nav {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--so-teal);
  color: #fff;
  padding: var(--space-sm) var(--space-md);
  z-index: 200;
  border-radius: 0 0 var(--radius-sm) 0;
  font-weight: 600;
  font-size: 0.85rem;
}
.skip-nav:focus { top: 0; }

/* ============================================
   Top Navigation — command bar
   ============================================ */
.topnav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(8, 12, 24, 0.7);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--border-glass);
  transition: background var(--transition-base);
}

[data-theme="light"] .topnav {
  background: rgba(245, 247, 250, 0.8);
}

.topnav .inner {
  max-width: 1360px;
  margin: 0 auto;
  padding: 10px var(--space-lg);
  display: flex;
  gap: var(--space-md);
  align-items: center;
}

.brand {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  letter-spacing: -0.2px;
  text-decoration: none;
}

.brand:hover { color: var(--text-primary); }

.brand .spark {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: var(--gradient-accent);
  border-radius: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0;
  overflow: hidden;
}

/* Sweep animation on the brand icon */
.brand .spark::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  animation: brand-sweep 4s ease-in-out infinite;
}

@keyframes brand-sweep {
  0%, 85% { left: -100%; }
  100% { left: 100%; }
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  flex: 1;
}

.navlink {
  position: relative;
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  font-weight: 500;
  font-size: 0.82rem;
  color: var(--text-secondary);
  transition: background var(--transition-fast), color var(--transition-fast);
  white-space: nowrap;
}

.navlink:hover {
  background: var(--bg-glass-hover);
  color: var(--text-primary);
}

.navlink[aria-current="page"] {
  color: var(--text-primary);
  font-weight: 600;
}

.navlink[aria-current="page"]::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 14px;
  right: 14px;
  height: 2px;
  background: var(--gradient-accent);
  border-radius: 2px;
}

.nav-right {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.project-selector {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.8rem;
  font-family: var(--font-body);
  cursor: pointer;
  transition: border-color var(--transition-fast);
}

.project-selector:hover {
  border-color: var(--border-glass-hover);
}

.project-selector:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 2px;
}

.theme-toggle {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  color: var(--text-secondary);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  font-size: 0.78rem;
  font-family: var(--font-body);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.theme-toggle:hover {
  background: var(--bg-glass-hover);
  color: var(--text-primary);
  border-color: var(--border-glass-hover);
}

.theme-toggle:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 2px;
}

/* ============================================
   Page Layout
   ============================================ */
.page-container {
  max-width: 1360px;
  margin: 0 auto;
  padding: var(--space-xl) var(--space-lg);
}

.page-header {
  margin-bottom: var(--space-2xl);
}

.page-title {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 700;
  font-style: normal;
  letter-spacing: -1px;
  margin-bottom: var(--space-sm);
  color: var(--text-primary);
}

.page-subtitle {
  color: var(--text-secondary);
  font-size: 1rem;
  max-width: 640px;
  line-height: 1.7;
}

/* Section Headers */
.section-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.section-title {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
}

.section-line {
  flex: 1;
  height: 1px;
  background: var(--border-glass);
}

/* ============================================
   Hero Section — Dashboard landing
   ============================================ */
.hero {
  text-align: center;
  padding: var(--space-3xl) 0 var(--space-2xl);
  position: relative;
}

.hero-brand {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 800;
  letter-spacing: -2px;
  line-height: 1.1;
  margin-bottom: var(--space-md);
  color: var(--text-primary);
}

.hero-brand .accent {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-tagline {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--text-secondary);
  max-width: 500px;
  margin: 0 auto var(--space-lg);
  line-height: 1.7;
  font-weight: 300;
}

.hero-tagline em {
  font-style: italic;
  color: var(--so-teal-bright);
  font-weight: 400;
}

[data-theme="light"] .hero-tagline em {
  color: var(--so-teal);
}

/* Org badge */
.org-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: var(--radius-full);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-bottom: var(--space-xl);
}

.org-badge .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--so-teal-bright);
  animation: pulse-dot 2s ease-in-out infinite;
}

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

/* ============================================
   Glass Cards — the core building block
   ============================================ */
.glass-card {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow-sm), var(--shadow-inset);
  transition:
    border-color var(--transition-base),
    box-shadow var(--transition-base),
    transform var(--transition-base),
    background var(--transition-base);
}

.glass-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--gradient-card);
  pointer-events: none;
  z-index: 0;
}

.glass-card > * {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
   Hover Tier System (RFS DNA)
   --------------------------------------------------------------------------
   Tier 1 – Subtle:    translateY(-1px)                    [info elements]
   Tier 2 – Standard:  translateY(-2px) + enhanced shadow  [interactive cards]
   Tier 3 – Prominent: translateY(-3px) + scale(1.01) + glow [primary CTAs]
   ========================================================================== */

.glass-card:hover {
  border-color: var(--border-glass-hover);
  box-shadow: var(--shadow-md), var(--shadow-inset);
  transform: translateY(-2px);
}

.glass-card--clickable {
  cursor: pointer;
  text-decoration: none;
  display: block;
  color: inherit;
  will-change: transform;
  transition:
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.3s ease,
    border-color var(--transition-base),
    background var(--transition-base);
}

.glass-card--clickable:hover {
  color: inherit;
  box-shadow: var(--shadow-lg), var(--shadow-glow-teal);
  border-color: var(--border-accent);
  transform: translateY(-3px) scale(1.005);
}

/* Staggered entrance animation */
.glass-card {
  animation: card-enter 0.6s var(--ease-out-expo) backwards;
}

@keyframes card-enter {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
}

/* ============================================
   Buttons & Inputs — the control panel
   ============================================ */

/* Shared button base */
.btn-primary,
.btn-ghost,
.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-lg);
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  border: none;
  will-change: transform;
  transition:
    background 0.2s var(--ease-out-expo),
    box-shadow 0.3s ease,
    border-color 0.2s var(--ease-out-expo),
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.btn-primary:disabled,
.btn-ghost:disabled,
.btn-danger:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

.btn-primary:focus-visible,
.btn-ghost:focus-visible,
.btn-danger:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 2px;
}

/* Active press state — all buttons */
.btn-primary:active:not(:disabled),
.btn-ghost:active:not(:disabled),
.btn-danger:active:not(:disabled) {
  transform: translateY(1px) scale(0.98);
  transition-duration: 0.1s;
}

/* Primary — teal gradient with glass highlight */
.btn-primary {
  background: var(--gradient-accent);
  color: #fff;
  box-shadow: var(--shadow-inset), 0 1px 3px rgba(0, 0, 0, 0.3);
}

.btn-primary:hover:not(:disabled) {
  box-shadow: var(--shadow-inset), var(--shadow-glow-teal);
  transform: translateY(-1px);
}

/* Ghost — transparent, glass border */
.btn-ghost {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-glass);
}

.btn-ghost:hover:not(:disabled) {
  background: rgba(94, 194, 198, 0.06);
  border-color: var(--so-teal-bright);
  transform: translateY(-1px);
}

/* Danger — coral with glass highlight */
.btn-danger {
  background: var(--so-coral);
  color: #fff;
  box-shadow: var(--shadow-inset), 0 1px 3px rgba(0, 0, 0, 0.3);
}

.btn-danger:hover:not(:disabled) {
  box-shadow: var(--shadow-inset), var(--shadow-glow-coral);
  transform: translateY(-1px);
}

/* Input fields */
.input {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 0.9rem;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.input::placeholder {
  color: var(--text-muted);
}

.input:hover {
  border-color: var(--border-glass-hover);
}

.input:focus-visible {
  outline: none;
  border-color: var(--so-teal-bright);
  box-shadow: 0 0 0 2px rgba(94, 194, 198, 0.25);
}

.input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ============================================
   Grade Badges — the vital signs
   ============================================ */
.grade-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 10px;
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: -0.5px;
  position: relative;
  overflow: hidden;
}

/* Grade draw-in animation */
.grade-badge {
  animation: grade-draw 0.8s var(--ease-out-expo) backwards;
}

@keyframes grade-draw {
  from {
    opacity: 0;
    transform: scale(0.7);
    filter: blur(4px);
  }
  to {
    opacity: 1;
    transform: scale(1);
    filter: blur(0px);
  }
}

.grade-badge--sm {
  min-width: 34px;
  height: 34px;
  font-size: 0.85rem;
  border-radius: var(--radius-sm);
}

.grade-badge--lg {
  min-width: 72px;
  height: 72px;
  font-size: 2rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

/* Grade colors via data attribute */
[data-grade^="A"] {
  background: rgba(52, 211, 153, 0.1);
  color: var(--grade-a);
  border: 1px solid rgba(52, 211, 153, 0.25);
}
[data-grade="A+"] { color: var(--grade-a-plus); }
[data-grade="A-"] { color: var(--grade-a-minus); }

[data-grade^="B"] {
  background: rgba(251, 191, 36, 0.08);
  color: var(--grade-b);
  border: 1px solid rgba(251, 191, 36, 0.25);
}
[data-grade="B+"] { color: var(--grade-b-plus); }
[data-grade="B-"] { color: var(--grade-b-minus); }

[data-grade^="C"] {
  background: rgba(249, 115, 22, 0.08);
  color: var(--grade-c);
  border: 1px solid rgba(249, 115, 22, 0.25);
}
[data-grade="C+"] { color: var(--grade-c-plus); }
[data-grade="C-"] { color: var(--grade-c-minus); }

[data-grade^="D"], [data-grade="F"] {
  background: rgba(248, 113, 113, 0.08);
  color: var(--grade-d);
  border: 1px solid rgba(248, 113, 113, 0.25);
}

[data-grade="N/A"] {
  background: rgba(100, 116, 139, 0.08);
  color: var(--grade-na);
  border: 1px solid rgba(100, 116, 139, 0.2);
}

/* Large grade glow effect */
.grade-badge--lg[data-grade^="A"] {
  box-shadow: 0 0 24px rgba(52, 211, 153, 0.15), 0 0 48px rgba(52, 211, 153, 0.05);
}
.grade-badge--lg[data-grade^="B"] {
  box-shadow: 0 0 24px rgba(251, 191, 36, 0.12), 0 0 48px rgba(251, 191, 36, 0.04);
}
.grade-badge--lg[data-grade^="C"] {
  box-shadow: 0 0 24px rgba(249, 115, 22, 0.12);
}
.grade-badge--lg[data-grade^="D"],
.grade-badge--lg[data-grade="F"] {
  box-shadow: 0 0 24px rgba(248, 113, 113, 0.15);
}

/* Trend indicators */
.trend { font-size: 0.82rem; margin-left: 6px; font-weight: 600; }
.trend--up { color: var(--grade-a); }
.trend--down { color: var(--grade-d); }
.trend--flat { color: var(--text-muted); }
.trend--new { color: var(--so-purple); }

/* ============================================
   KPI Strip — vital signs readout
   ============================================ */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
}

.kpi-card {
  position: relative;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
  transition:
    border-color var(--transition-fast),
    box-shadow 0.3s ease,
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  overflow: hidden;
}

.kpi-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gradient-accent);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.kpi-card:hover {
  border-color: var(--border-accent);
  box-shadow: var(--shadow-sm), var(--shadow-inset);
  transform: translateY(-1px);
}

.kpi-card:hover::before {
  opacity: 1;
}

.kpi-value {
  font-family: var(--font-mono);
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
  letter-spacing: -1px;
  line-height: 1.2;
}

.kpi-label {
  font-size: 0.68rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1.2px;
  font-weight: 600;
}

/* KPI entrance animation */
.kpi-card {
  animation: kpi-count 0.5s var(--ease-out-expo) backwards;
}

.kpi-card:nth-child(1) { animation-delay: 0.05s; }
.kpi-card:nth-child(2) { animation-delay: 0.1s; }
.kpi-card:nth-child(3) { animation-delay: 0.15s; }
.kpi-card:nth-child(4) { animation-delay: 0.2s; }
.kpi-card:nth-child(5) { animation-delay: 0.25s; }

@keyframes kpi-count {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.97);
  }
}

/* ============================================
   Finance Panels
   ============================================ */
.finance-panel {
  position: relative;
  overflow: hidden;
  margin-bottom: var(--space-xl);
}

.finance-panel::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-accent);
  z-index: 2;
}

.finance-panel[data-budget-status="healthy"]::after {
  background: linear-gradient(90deg, rgba(52, 211, 153, 0.9), rgba(94, 194, 198, 0.75));
}

.finance-panel[data-budget-status="watch"]::after {
  background: linear-gradient(90deg, rgba(251, 191, 36, 0.9), rgba(232, 181, 99, 0.75));
}

.finance-panel[data-budget-status="over"]::after {
  background: linear-gradient(90deg, rgba(248, 113, 113, 0.9), rgba(217, 123, 123, 0.75));
}

.finance-panel__header {
  display: flex;
  justify-content: space-between;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
  align-items: flex-start;
}

.finance-panel__intro {
  max-width: 760px;
}

.finance-panel__eyebrow {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--so-teal-bright);
  margin-bottom: var(--space-xs);
}

.finance-panel__title {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 6px;
}

.finance-panel__summary {
  color: var(--text-secondary);
  font-size: 0.88rem;
  line-height: 1.65;
}

.finance-panel__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-sm);
  min-width: 180px;
}

.finance-panel__meta-copy {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--text-muted);
  text-align: right;
}

.finance-panel__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-glass);
}

.finance-panel__footer-copy {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-width: 700px;
}

.finance-panel__footer-title {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
}

.finance-panel__footer-note {
  color: var(--text-muted);
  font-size: 0.84rem;
  line-height: 1.6;
}

.finance-panel__cta {
  flex-shrink: 0;
  text-decoration: none;
  white-space: nowrap;
}

.finance-source-callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: var(--space-lg);
  padding: 12px 14px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
}

.finance-source-callout--sample {
  border-color: rgba(94, 194, 198, 0.18);
  background: rgba(94, 194, 198, 0.08);
}

.finance-source-callout--estimated {
  border-color: rgba(251, 191, 36, 0.18);
  background: rgba(251, 191, 36, 0.08);
}

.finance-source-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.finance-source-chip--sample {
  color: var(--so-teal-bright);
  border-color: rgba(94, 194, 198, 0.2);
  background: rgba(94, 194, 198, 0.14);
}

.finance-source-chip--estimated {
  color: var(--grade-b-plus);
  border-color: rgba(251, 191, 36, 0.22);
  background: rgba(251, 191, 36, 0.14);
}

.finance-source-callout__copy {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.8rem;
  line-height: 1.6;
}

.finance-status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border-glass);
  background: var(--bg-glass);
  color: var(--text-secondary);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}

.finance-status-chip--healthy {
  color: var(--grade-a);
  border-color: rgba(52, 211, 153, 0.22);
  background: rgba(52, 211, 153, 0.1);
}

.finance-status-chip--watch {
  color: var(--grade-b-plus);
  border-color: rgba(251, 191, 36, 0.24);
  background: rgba(251, 191, 36, 0.08);
}

.finance-status-chip--over {
  color: var(--grade-d);
  border-color: rgba(248, 113, 113, 0.24);
  background: rgba(248, 113, 113, 0.1);
}

.finance-progress {
  margin-bottom: var(--space-lg);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
}

.finance-progress__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-md);
  margin-bottom: 12px;
}

.finance-progress__label {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  margin-bottom: 3px;
}

.finance-progress__detail {
  color: var(--text-muted);
  font-size: 0.78rem;
}

.finance-progress__pct {
  font-family: var(--font-mono);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
}

.finance-progress__track {
  height: 12px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.04);
  overflow: hidden;
}

.finance-progress__fill {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(94, 194, 198, 0.78), rgba(74, 124, 126, 0.95));
  box-shadow: 0 0 20px rgba(94, 194, 198, 0.18);
}

.finance-progress__fill--watch {
  background: linear-gradient(90deg, rgba(251, 191, 36, 0.82), rgba(232, 181, 99, 0.95));
  box-shadow: 0 0 20px rgba(251, 191, 36, 0.16);
}

.finance-progress__fill--over {
  background: linear-gradient(90deg, rgba(248, 113, 113, 0.85), rgba(217, 123, 123, 0.98));
  box-shadow: 0 0 20px rgba(248, 113, 113, 0.2);
}

.finance-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-sm);
}

.finance-metric {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-glass);
}

.finance-metric__label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin-bottom: 8px;
}

.finance-metric__value {
  font-family: var(--font-mono);
  font-size: 1.02rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.finance-metric__value--healthy {
  color: var(--grade-a);
}

.finance-metric__value--over {
  color: var(--grade-d);
}

.finance-metric__value--empty {
  color: var(--text-muted);
}

.finance-metric__hint {
  margin-top: 6px;
  color: var(--text-muted);
  font-size: 0.74rem;
  line-height: 1.5;
}

.finance-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-md);
  margin-top: var(--space-lg);
}

.finance-detail-card {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
}

.finance-detail-card__label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 10px;
}

.finance-detail-card__body {
  color: var(--text-secondary);
  font-size: 0.82rem;
  line-height: 1.65;
}

.finance-targets,
.finance-note-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.finance-target {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border-glass);
  background: rgba(255, 255, 255, 0.03);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--text-secondary);
}

.finance-note-meta {
  margin-bottom: 10px;
}

.finance-note-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(94, 194, 198, 0.16);
  background: rgba(94, 194, 198, 0.08);
  color: var(--so-teal-bright);
  font-size: 0.72rem;
  font-weight: 600;
}

.finance-note-chip--confidence {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-secondary);
}

.finance-breakdown {
  margin-top: var(--space-lg);
}

.finance-line-item-groups {
  display: grid;
  gap: var(--space-md);
}

.finance-line-item-group {
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-glass);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01)),
    rgba(255, 255, 255, 0.012);
}

.finance-line-item-group__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

.finance-line-item-group__title {
  font-family: var(--font-heading);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.finance-line-item-group__description {
  color: var(--text-muted);
  font-size: 0.76rem;
  line-height: 1.55;
  max-width: 560px;
}

.finance-line-item-group__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  min-height: 34px;
  padding: 0 10px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 700;
}

.finance-breakdown__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-lg);
  margin-bottom: var(--space-md);
}

.finance-breakdown__title {
  font-family: var(--font-heading);
  font-size: 0.98rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.finance-breakdown__subtitle {
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.6;
  max-width: 620px;
}

.finance-breakdown__summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-sm);
}

.finance-breakdown__summary-card {
  min-width: 86px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-glass);
  text-align: right;
}

.finance-breakdown__summary-label {
  display: block;
  margin-bottom: 4px;
  color: var(--text-muted);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.finance-breakdown__summary-value {
  font-family: var(--font-mono);
  font-size: 0.94rem;
  color: var(--text-primary);
}

.finance-line-items {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-sm);
}

.finance-line-item {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--border-glass);
}

.finance-line-item__top {
  display: flex;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: 10px;
}

.finance-line-item__identity {
  min-width: 0;
}

.finance-line-item__title {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
  margin-bottom: 4px;
}

.finance-line-item__provider {
  color: var(--text-muted);
  font-size: 0.74rem;
  line-height: 1.5;
  margin-bottom: 8px;
}

.finance-line-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.finance-line-item__pill,
.finance-line-item__state {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: var(--radius-full);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.finance-line-item__pill {
  border: 1px solid var(--border-glass);
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-secondary);
}

.finance-line-item__state {
  border: 1px solid transparent;
}

.finance-line-item__state--active {
  color: var(--grade-a);
  background: rgba(52, 211, 153, 0.1);
  border-color: rgba(52, 211, 153, 0.2);
}

.finance-line-item__state--planned {
  color: var(--grade-b-plus);
  background: rgba(251, 191, 36, 0.1);
  border-color: rgba(251, 191, 36, 0.18);
}

.finance-line-item__state--free-tier {
  color: var(--so-teal-bright);
  background: rgba(94, 194, 198, 0.1);
  border-color: rgba(94, 194, 198, 0.18);
}

.finance-line-item__state--pending-amount,
.finance-line-item__state--pending-provider-confirmation {
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.08);
}

.finance-line-item__amount {
  font-family: var(--font-mono);
  font-size: 0.96rem;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
}

.finance-line-item__note {
  color: var(--text-muted);
  font-size: 0.78rem;
  line-height: 1.6;
}

.finance-panel--empty {
  padding-top: var(--space-xl);
  padding-bottom: var(--space-xl);
}

.budget-page-header__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
  margin: var(--space-md) 0;
}

.budget-page-header__updated {
  color: var(--text-muted);
  font-size: 0.8rem;
  font-family: var(--font-mono);
}

.budget-history-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-md);
}

.budget-history-card {
  padding: var(--space-md);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-glass);
}

.budget-history-card__top,
.budget-history-card__foot {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  align-items: center;
}

.budget-history-card__month {
  font-family: var(--font-heading);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
}

.budget-history-card__metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-sm);
  margin: var(--space-md) 0;
}

.budget-history-card__metrics span,
.budget-coverage__metrics span,
.budget-provenance__meta span {
  display: block;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}

.budget-history-card__metrics strong,
.budget-coverage__metrics strong,
.budget-provenance__meta strong {
  color: var(--text-primary);
  font-family: var(--font-mono);
  font-size: 0.92rem;
}

.budget-history-card__track {
  height: 10px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.06);
  overflow: hidden;
  margin-bottom: var(--space-sm);
}

.budget-history-card__fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(94, 194, 198, 0.78), rgba(74, 124, 126, 0.95));
}

.budget-history-card__foot {
  color: var(--text-muted);
  font-size: 0.76rem;
}

.budget-trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-md);
}

.budget-coverage__status {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-sm);
}

.budget-coverage__metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.budget-provenance__meta {
  margin-bottom: var(--space-sm);
}

.budget-provenance__sources {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.finance-empty__title {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
}

.finance-empty__description {
  color: var(--text-muted);
  font-size: 0.84rem;
  line-height: 1.65;
  max-width: 640px;
}

[data-theme="light"] .finance-progress__track {
  background: rgba(15, 23, 42, 0.05);
  border-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .finance-metric,
[data-theme="light"] .finance-detail-card,
[data-theme="light"] .finance-target {
  background: rgba(15, 23, 42, 0.025);
}

/* --- Finance: light-theme visibility fixes --- */

[data-theme="light"] .finance-source-callout {
  background: rgba(15, 23, 42, 0.025);
  border-color: rgba(15, 23, 42, 0.08);
}

[data-theme="light"] .finance-source-callout--sample {
  background: rgba(20, 184, 166, 0.06);
  border-color: rgba(20, 184, 166, 0.15);
}

[data-theme="light"] .finance-source-callout--estimated {
  background: rgba(245, 158, 11, 0.06);
  border-color: rgba(245, 158, 11, 0.15);
}

[data-theme="light"] .finance-source-chip {
  background: rgba(15, 23, 42, 0.04);
  border-color: rgba(15, 23, 42, 0.08);
  color: rgba(15, 23, 42, 0.7);
}

[data-theme="light"] .finance-source-chip--sample {
  background: rgba(20, 184, 166, 0.08);
  border-color: rgba(20, 184, 166, 0.2);
  color: rgba(13, 148, 136, 0.9);
}

[data-theme="light"] .finance-source-chip--estimated {
  background: rgba(245, 158, 11, 0.08);
  border-color: rgba(245, 158, 11, 0.2);
  color: rgba(217, 119, 6, 0.9);
}

[data-theme="light"] .finance-line-item-group {
  background: rgba(15, 23, 42, 0.015);
  border-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .finance-line-item {
  background: rgba(15, 23, 42, 0.02);
  border-color: rgba(15, 23, 42, 0.05);
}

[data-theme="light"] .finance-line-item:hover {
  background: rgba(15, 23, 42, 0.035);
}

[data-theme="light"] .finance-line-item__state--pending-amount,
[data-theme="light"] .finance-line-item__state--pending-provider-confirmation {
  background: rgba(245, 158, 11, 0.06);
  border-color: rgba(245, 158, 11, 0.12);
}

[data-theme="light"] .budget-history-card {
  background: rgba(15, 23, 42, 0.02);
  border-color: rgba(15, 23, 42, 0.06);
}

[data-theme="light"] .budget-history-card:hover {
  background: rgba(15, 23, 42, 0.035);
  border-color: rgba(15, 23, 42, 0.08);
}

@media (max-width: 900px) {
  .finance-panel__header {
    flex-direction: column;
  }

  .finance-panel__meta {
    align-items: flex-start;
  }

  .finance-panel__meta-copy {
    text-align: left;
  }

  .finance-panel__footer {
    flex-direction: column;
    align-items: flex-start;
  }

  .finance-panel__cta {
    width: 100%;
  }

  .finance-source-callout {
    flex-direction: column;
  }

  .finance-breakdown__header {
    flex-direction: column;
  }

  .finance-breakdown__summary {
    justify-content: flex-start;
  }

  .finance-line-item-group__header {
    flex-direction: column;
  }

  .finance-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .finance-progress__top {
    flex-direction: column;
    align-items: flex-start;
  }

  .finance-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .finance-line-items {
    grid-template-columns: 1fr;
  }

  .finance-line-item__top {
    flex-direction: column;
  }

  .project-card__finance-grid {
    grid-template-columns: 1fr;
  }

  .project-card__finance-foot {
    flex-direction: column;
  }
}

/* ============================================
   Project Grid — per-project identity cards
   ============================================ */
.project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

.project-card {
  position: relative;
  overflow: hidden;
  padding-top: calc(var(--space-lg) + 4px);
  box-shadow: var(--shadow-sm), var(--shadow-inset), 0 0 20px 4px rgba(var(--project-color-rgb, 74,124,126), 0.04);
  animation: ambient-breathe 4s ease-in-out infinite;
  transition:
    box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes ambient-breathe {
  0%, 100% { box-shadow: var(--shadow-sm), var(--shadow-inset), 0 0 20px 4px rgba(var(--project-color-rgb, 74,124,126), 0.03); }
  50%      { box-shadow: var(--shadow-sm), var(--shadow-inset), 0 0 24px 6px rgba(var(--project-color-rgb, 74,124,126), 0.05); }
}

.project-card:hover {
  box-shadow: var(--shadow-lg), var(--shadow-inset), 0 0 32px 8px rgba(var(--project-color-rgb, 74,124,126), 0.12);
  animation: none;
}

/* Project identity stripe — thicker, with glow */
.project-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--project-color, var(--so-teal));
  z-index: 2;
  transition: height var(--transition-fast), box-shadow var(--transition-fast);
}

.project-card:hover::after {
  height: 4px;
  box-shadow: 0 2px 20px color-mix(in srgb, var(--project-color, var(--so-teal)) 30%, transparent);
}

/* Subtle ambient glow from project color on hover */
.project-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 80px;
  background: radial-gradient(ellipse at top, color-mix(in srgb, var(--project-color, var(--so-teal)) 6%, transparent), transparent 80%);
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
  transition: opacity var(--transition-base);
}

.project-card:hover::before {
  opacity: 1;
}

.project-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  gap: var(--space-md);
}

.project-card__name {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.3px;
}

.project-card__desc {
  color: var(--text-secondary);
  font-size: 0.85rem;
  margin-bottom: var(--space-lg);
  line-height: 1.6;
}

.project-card__finance {
  margin-bottom: var(--space-lg);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border-glass);
}

.project-card__finance-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.project-card__finance-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.project-card__finance-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-sm);
}

.project-card__finance-metric {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.project-card__finance-key {
  font-size: 0.68rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.project-card__finance-value {
  color: var(--text-primary);
  font-family: var(--font-mono);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.project-card__finance-value--empty {
  color: var(--text-muted);
}

.project-card__finance-foot {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px solid var(--border-glass);
  color: var(--text-muted);
  font-size: 0.72rem;
}

.project-card__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm) var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-glass);
}

.project-card__stat {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

.project-card__stat strong {
  display: block;
  color: var(--text-primary);
  font-family: var(--font-mono);
  font-size: 0.95rem;
  font-weight: 600;
  text-transform: none;
  letter-spacing: -0.3px;
  margin-bottom: 1px;
}

/* Project card stagger */
.project-card:nth-child(1) { animation-delay: 0.1s; }
.project-card:nth-child(2) { animation-delay: 0.2s; }
.project-card:nth-child(3) { animation-delay: 0.3s; }
.project-card:nth-child(4) { animation-delay: 0.4s; }

/* ============================================
   Auditor Badges — who graded what
   ============================================ */
.auditor-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  font-size: 0.65rem;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: 0.3px;
  white-space: nowrap;
}

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

/* ============================================
   Category Grid (12 dimensions) — expanded detail cards
   ============================================ */
.category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
}

.category-card {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-lg);
  cursor: default;
}

.category-card__info {
  flex: 1;
  min-width: 0;
}

.category-card__name {
  font-family: var(--font-heading);
  font-size: 0.88rem;
  font-weight: 600;
  margin-bottom: 4px;
  letter-spacing: -0.2px;
}

.category-card__summary {
  font-size: 0.78rem;
  color: var(--text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
}

.category-card__auditor {
  margin-top: 6px;
}

/* Category card stagger */
.category-card:nth-child(1) { animation-delay: 0.05s; }
.category-card:nth-child(2) { animation-delay: 0.1s; }
.category-card:nth-child(3) { animation-delay: 0.15s; }
.category-card:nth-child(4) { animation-delay: 0.2s; }
.category-card:nth-child(5) { animation-delay: 0.25s; }
.category-card:nth-child(6) { animation-delay: 0.3s; }
.category-card:nth-child(7) { animation-delay: 0.35s; }
.category-card:nth-child(8) { animation-delay: 0.4s; }
.category-card:nth-child(9) { animation-delay: 0.45s; }
.category-card:nth-child(10) { animation-delay: 0.5s; }
.category-card:nth-child(11) { animation-delay: 0.55s; }
.category-card:nth-child(12) { animation-delay: 0.6s; }

/* ============================================
   Report Card Header — hero grade display
   ============================================ */
.rc-hero {
  display: flex;
  align-items: center;
  gap: var(--space-xl);
  margin-bottom: var(--space-2xl);
  padding: var(--space-2xl) 0;
}

.rc-hero__grade-ring {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 120px;
  flex-shrink: 0;
}

/* Animated ring around large grade */
.rc-hero__grade-ring::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid var(--border-glass);
  animation: ring-pulse 3s ease-in-out infinite;
}

.rc-hero__grade-ring::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 1px solid transparent;
  border-top-color: var(--so-teal-bright);
  animation: ring-rotate 8s linear infinite;
  opacity: 0.4;
}

@keyframes ring-pulse {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.7; }
}

@keyframes ring-rotate {
  to { transform: rotate(360deg); }
}

.rc-hero__info {
  flex: 1;
  min-width: 0;
}

.rc-hero__project-name {
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -1px;
  margin-bottom: var(--space-xs);
}

.rc-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-md);
  margin-bottom: var(--space-md);
  align-items: center;
}

.rc-hero__meta-item {
  font-size: 0.82rem;
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.rc-hero__summary {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 700px;
}

/* Repo link */
.rc-header__repo-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.82rem;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
  margin-top: var(--space-sm);
}

.rc-header__repo-link:hover {
  color: var(--so-teal-bright, #5ec2c6);
}

.rc-hero__meta .rc-header__repo-link {
  margin-top: 0;
}

/* Audit sources indicator */
.audit-sources {
  display: flex;
  gap: 6px;
  margin-top: var(--space-md);
}

.audit-source {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  font-family: var(--font-mono);
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  transition: all var(--transition-fast);
}

.audit-source--active {
  border-color: var(--border-accent);
  color: var(--so-teal-bright);
  background: rgba(94, 194, 198, 0.06);
}

.audit-source:hover {
  transform: translateY(-1px);
}

/* ============================================
   Red Flags Table — alert readout
   ============================================ */
.flags-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
}

.flags-table th {
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  color: var(--text-muted);
  font-weight: 600;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 1px solid var(--border-glass);
}

.flags-table td {
  padding: 10px var(--space-md);
  border-bottom: 1px solid var(--border-glass);
  color: var(--text-secondary);
  vertical-align: middle;
}

.flags-table tr {
  transition: background var(--transition-fast);
}

.flags-table tbody tr:hover {
  background: var(--bg-glass);
}

.flags-table tr:last-child td { border-bottom: none; }

.severity-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.severity-badge--critical {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.2);
  animation: severity-pulse 2s ease-in-out infinite;
}

.severity-badge--high {
  background: rgba(249, 115, 22, 0.1);
  color: #fb923c;
  border: 1px solid rgba(249, 115, 22, 0.2);
}

.severity-badge--medium {
  background: rgba(251, 191, 36, 0.08);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.2);
}

.severity-badge--low {
  background: rgba(100, 116, 139, 0.08);
  color: #94a3b8;
  border: 1px solid rgba(100, 116, 139, 0.15);
}

@keyframes severity-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.7; }
}

[data-theme="light"] .severity-badge--critical {
  background: rgba(239, 68, 68, 0.08);
  color: #dc2626;
  border-color: rgba(239, 68, 68, 0.15);
}

[data-theme="light"] .severity-badge--high {
  background: rgba(249, 115, 22, 0.07);
  color: #c2410c;
}

/* ============================================
   Red Flags Cards — stacked alert cards
   ============================================ */
.red-flags-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.red-flag-item {
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-left: 3px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  backdrop-filter: blur(8px);
  box-shadow: var(--shadow-inset);
  transition:
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1),
    border-left-width 0.2s var(--ease-out-expo),
    box-shadow 0.3s ease,
    background 0.2s var(--ease-out-expo);
  animation: red-flag-enter 0.4s var(--ease-out-expo) backwards;
}

/* Staggered entrance */
.red-flag-item:nth-child(1) { animation-delay: 0.05s; }
.red-flag-item:nth-child(2) { animation-delay: 0.1s; }
.red-flag-item:nth-child(3) { animation-delay: 0.15s; }
.red-flag-item:nth-child(4) { animation-delay: 0.2s; }
.red-flag-item:nth-child(5) { animation-delay: 0.25s; }
.red-flag-item:nth-child(n+6) { animation-delay: 0.3s; }

@keyframes red-flag-enter {
  from {
    opacity: 0;
    transform: translateX(-8px);
  }
}

.red-flag-item:hover {
  transform: translateX(4px);
  border-left-width: 5px;
  background: var(--bg-glass-hover);
}

.red-flag-item--critical { border-left-color: var(--so-coral); }
.red-flag-item--high     { border-left-color: var(--so-gold); }
.red-flag-item--medium   { border-left-color: var(--so-teal); }
.red-flag-item--low      { border-left-color: var(--text-muted); }

/* Critical: pulsing glow + ambient coral shadow */
.red-flag-item--critical {
  animation: red-flag-pulse 3s ease-in-out infinite, red-flag-enter 0.4s var(--ease-out-expo) backwards;
  box-shadow: var(--shadow-inset), 0 0 16px 2px rgba(217, 123, 123, 0.06);
}

.red-flag-item--critical:hover {
  box-shadow: var(--shadow-inset), 0 0 24px 4px rgba(217, 123, 123, 0.12);
}

@keyframes red-flag-pulse {
  0%, 100% { border-left-color: var(--so-coral); }
  50% { border-left-color: rgba(255, 107, 107, 0.4); }
}

.red-flag-item__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-xs);
  flex-wrap: wrap;
}

.red-flag-item__category {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: var(--text-muted);
  background: var(--bg-tertiary);
  padding: 2px 8px;
  border-radius: var(--radius-full);
}

.red-flag-item__status {
  font-size: 0.72rem;
  text-transform: capitalize;
  color: var(--text-muted);
  margin-left: auto;
}

.red-flag-item__desc {
  color: var(--text-primary);
  font-size: 0.85rem;
  font-weight: 500;
  line-height: 1.5;
  display: flex;
  align-items: baseline;
  gap: var(--space-sm);
}

.red-flag-item__dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  top: -1px;
}

.red-flag-item__dot--critical { background: var(--so-coral); box-shadow: 0 0 6px var(--so-coral); }
.red-flag-item__dot--high     { background: var(--so-gold); box-shadow: 0 0 6px var(--so-gold); }
.red-flag-item__dot--medium   { background: var(--so-teal); }
.red-flag-item__dot--low      { background: var(--text-muted); }

/* ============================================
   SVG Charts — medical telemetry feel
   ============================================ */
.chart-container {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  position: relative;
  overflow: hidden;
}

.chart-container--empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  min-height: 200px;
}

.chart-empty-state__img {
  opacity: 0.5;
  margin-bottom: 0.75rem;
}

.chart-empty-state__label {
  font-size: 0.8rem;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}

/* Subtle grid overlay on charts */
.chart-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(94, 194, 198, 0.02) 1px, transparent 1px),
    linear-gradient(0deg, rgba(94, 194, 198, 0.02) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
  border-radius: inherit;
}

.chart-container::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url('../images/pattern-grid.png') repeat;
  opacity: 0.03;
  pointer-events: none;
  z-index: 0;
  border-radius: inherit;
}

.chart-container > * {
  position: relative;
  z-index: 1;
}

.chart-title {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: var(--space-md);
  text-transform: uppercase;
  letter-spacing: 1px;
  position: relative;
  z-index: 1;
}

/* Charts row — side by side on wider screens */
.charts-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
}

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

/* ============================================
   Tech Stack Tags
   ============================================ */
.tech-tag {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-full);
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--text-secondary);
  transition: all var(--transition-fast);
}

.tech-tag:hover {
  border-color: var(--border-glass-hover);
  color: var(--text-primary);
}

/* ============================================
   Loading / Empty States
   ============================================ */
.loading-skeleton {
  background: linear-gradient(
    90deg,
    var(--bg-glass) 25%,
    var(--bg-glass-hover) 37%,
    var(--bg-glass) 63%
  );
  background-size: 400% 100%;
  animation: shimmer 1.8s ease-in-out infinite;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-glass);
}

@keyframes shimmer {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

.empty-state {
  text-align: center;
  padding: var(--space-3xl) var(--space-xl);
  color: var(--text-muted);
}

.empty-state__icon {
  font-size: 2.5rem;
  margin-bottom: var(--space-md);
  opacity: 0.4;
}

.empty-state__title {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: var(--space-sm);
}

/* ============================================
   Collapsible Sections
   ============================================ */
.collapsible-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  padding: var(--space-sm) 0;
  user-select: none;
}

.collapsible-header:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 4px;
}

.collapsible-icon {
  transition: transform var(--transition-fast);
  color: var(--text-muted);
  font-size: 0.8rem;
}

.collapsible-header[aria-expanded="true"] .collapsible-icon {
  transform: rotate(90deg);
}

.collapsible-body {
  overflow: hidden;
  transition: max-height var(--transition-slow), opacity var(--transition-base);
  max-height: 0;
  opacity: 0;
}

.collapsible-body[aria-hidden="false"] {
  max-height: 2000px;
  opacity: 1;
}

/* ============================================
   Dimension Bars — sub-grade visualization
   ============================================ */
.dimension-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-md);
}

.dimension-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: 0.78rem;
  padding: 4px 0;
}

.dimension-name {
  flex: 1;
  color: var(--text-secondary);
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dimension-score {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.75rem;
  min-width: 28px;
  text-align: center;
}

/* ============================================
   Footer — understated
   ============================================ */
.site-footer {
  border-top: 1px solid var(--border-glass);
  padding: var(--space-2xl) var(--space-lg);
  text-align: center;
  color: var(--text-muted);
  font-size: 0.78rem;
  margin-top: var(--space-3xl);
  line-height: 1.8;
}

.site-footer em {
  color: var(--text-secondary);
  font-style: italic;
}

.site-footer kbd {
  display: inline-block;
  padding: 1px 6px;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  line-height: 1.4;
  vertical-align: 1px;
}

/* ============================================
   Status Indicator dots (for evidence)
   ============================================ */
.status-pass {
  color: var(--grade-a);
}

.status-fail {
  color: var(--grade-d);
}

.status-warn {
  color: var(--grade-b);
}

/* ============================================
   Evidence KPI variation — with status indicators
   ============================================ */
.evidence-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: var(--space-sm);
}

.evidence-card {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-sm);
  text-align: center;
  transition:
    border-color var(--transition-fast),
    box-shadow 0.3s ease,
    transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.evidence-card:hover {
  border-color: var(--border-glass-hover);
  box-shadow: var(--shadow-sm), var(--shadow-inset);
  transform: translateY(-1px);
}

.evidence-value {
  font-family: var(--font-mono);
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
  letter-spacing: -0.5px;
}

.evidence-label {
  font-size: 0.65rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
}

/* ============================================
   Project Detail Cards (project.html)
   ============================================ */
.project-detail-card {
  margin-bottom: var(--space-lg);
}

.project-detail-card .project-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  gap: var(--space-md);
  flex-wrap: wrap;
}

.project-detail-card .project-name {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -0.5px;
}

.project-detail-card .project-repo {
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.78rem;
}

.project-detail-card .project-desc {
  color: var(--text-secondary);
  font-size: 0.9rem;
  margin-bottom: var(--space-lg);
  line-height: 1.6;
}

.project-detail-card .tech-stack {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
}

.project-detail-card .card-actions {
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-glass);
}

.card-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--so-teal-bright);
  transition: all var(--transition-fast);
  padding: 6px 0;
}

.card-link:hover {
  color: var(--so-gold);
  gap: 10px;
}

.card-link:focus-visible {
  outline: 2px solid var(--so-teal-bright);
  outline-offset: 4px;
}

[data-theme="light"] .card-link {
  color: var(--so-teal);
}

/* ============================================
   Keyboard Shortcuts Toast
   ============================================ */
#so-kbd-toast {
  position: fixed;
  right: 16px;
  bottom: 16px;
  padding: 12px 20px;
  background: rgba(8, 12, 24, 0.94);
  color: var(--text-primary);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  z-index: 9999;
  font: 500 0.78rem/1.6 var(--font-body);
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-lg);
  transition: opacity 0.4s var(--ease-out-expo);
  max-width: 90vw;
}

[data-theme="light"] #so-kbd-toast {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(0,0,0,0.1);
  color: var(--text-primary);
}

/* ============================================
   Utility: Visually Hidden (a11y)
   ============================================ */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================
   Print Styles
   ============================================ */
@media print {
  body::before,
  body::after,
  .topnav,
  .theme-toggle,
  .skip-nav,
  .site-footer,
  .project-selector,
  .org-badge .dot,
  .rc-hero__grade-ring::before,
  .rc-hero__grade-ring::after {
    display: none !important;
    animation: none !important;
  }

  body {
    background: #fff !important;
    color: #111 !important;
  }

  .glass-card {
    border: 1px solid #ddd !important;
    box-shadow: none !important;
    background: #fff !important;
    backdrop-filter: none !important;
    transform: none !important;
    animation: none !important;
  }

  .page-title, .hero-brand, .rc-hero__project-name {
    color: #111 !important;
    -webkit-text-fill-color: #111 !important;
  }

  .hero-brand .accent {
    -webkit-text-fill-color: #4a7c7e !important;
  }

  .grade-badge {
    border: 2px solid currentColor !important;
    animation: none !important;
  }

  .grade-badge--lg {
    box-shadow: none !important;
  }

  .kpi-card,
  .category-card,
  .project-card,
  .chart-container {
    animation: none !important;
    break-inside: avoid;
  }

  .project-grid,
  .category-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }

  .kpi-strip {
    grid-template-columns: repeat(4, 1fr) !important;
  }

  a[href]:after {
    content: none !important;
  }
}

/* ============================================
   Responsive
   ============================================ */
@media (max-width: 1024px) {
  .project-grid {
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  }

  .category-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  }

  .rc-hero {
    gap: var(--space-lg);
  }

  .rc-hero__grade-ring {
    width: 96px;
    height: 96px;
  }
}

@media (max-width: 768px) {
  .topnav .inner {
    padding: var(--space-sm) var(--space-md);
  }

  .page-container {
    padding: var(--space-md);
  }

  .hero {
    padding: var(--space-xl) 0 var(--space-lg);
  }

  .hero-brand {
    font-size: 2rem;
    letter-spacing: -1px;
  }

  .page-title, .rc-hero__project-name {
    font-size: 1.5rem;
  }

  .project-grid {
    grid-template-columns: 1fr;
  }

  .category-grid {
    grid-template-columns: 1fr;
  }

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

  .brand span:not(.spark) {
    display: none;
  }

  .rc-hero {
    flex-direction: column;
    text-align: center;
    gap: var(--space-lg);
  }

  .rc-hero__meta {
    justify-content: center;
  }

  .rc-hero__summary {
    text-align: left;
  }

  .audit-sources {
    justify-content: center;
  }

  .flags-table {
    font-size: 0.75rem;
  }

  .flags-table th,
  .flags-table td {
    padding: var(--space-sm);
  }

  /* Hide less critical table columns on mobile */
  .flags-table .col-category {
    display: none;
  }

  /* Nav: horizontal scroll with teal-tinted fade mask */
  .nav-links {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    mask-image: linear-gradient(to right, transparent 0, black 20px, black calc(100% - 20px), transparent 100%);
    -webkit-mask-image: linear-gradient(to right, transparent 0, black 20px, black calc(100% - 20px), transparent 100%);
  }

  .nav-links::-webkit-scrollbar {
    display: none;
  }

  /* Touch targets: min 44x44px with active feedback */
  .navlink {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
  }

  .navlink:active {
    background: var(--bg-glass-hover);
    transition-duration: 0.05s;
  }

  .theme-toggle,
  .project-selector,
  .nav-signout {
    min-width: 44px;
    min-height: 44px;
  }

  .theme-toggle:active,
  .project-selector:active,
  .nav-signout:active {
    background: var(--bg-glass-hover);
  }

  /* Grade badge --lg: smaller on mobile */
  .grade-badge--lg {
    min-width: 56px;
    height: 56px;
    font-size: 1.5rem;
  }

  /* Command row: single column */
  .command-row {
    grid-template-columns: 1fr;
  }

  /* Disable scan-line for GPU savings */
  body::after {
    display: none;
  }
}

@media (max-width: 480px) {
  .kpi-strip {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-sm);
  }

  .kpi-value {
    font-size: 1.4rem;
  }

  .nav-links {
    gap: 0;
  }

  .navlink {
    padding: 6px 10px;
    font-size: 0.78rem;
    min-height: 44px;
  }

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

/* ============================================
   Reduced Motion
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  html {
    scroll-behavior: auto;
  }
}

/* ============================================
   Org Hero (Executive Dashboard)
   ============================================ */
.org-hero {
  display: flex;
  align-items: center;
  gap: var(--space-2xl);
  padding: var(--space-2xl) var(--space-xl);
  margin-bottom: var(--space-xl);
  position: relative;
  overflow: hidden;
}

.org-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    url('../images/hero-banner.png') center / cover no-repeat,
    radial-gradient(ellipse 60% 80% at 10% 50%, rgba(94, 194, 198, 0.06) 0%, transparent 70%);
  opacity: 0.04;
  pointer-events: none;
  z-index: 0;
}

[data-theme="light"] .org-hero::before {
  opacity: 0.06;
}

.org-hero__grade-ring {
  position: relative;
  flex-shrink: 0;
  z-index: 1;
}

.grade-ring-pulse {
  position: absolute;
  inset: -12px;
  border-radius: 50%;
  border: 2px solid rgba(94, 194, 198, 0.15);
  animation: ring-pulse 3s ease-in-out infinite;
  will-change: opacity;
}

.grade-ring-pulse[data-grade^="A"] { border-color: rgba(52, 211, 153, 0.2); }
.grade-ring-pulse[data-grade^="B"] { border-color: rgba(251, 191, 36, 0.2); }
.grade-ring-pulse[data-grade^="C"] { border-color: rgba(249, 115, 22, 0.2); }

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

.org-hero__info {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}

.org-hero__title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 var(--space-sm);
}

.org-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
  margin-bottom: var(--space-sm);
}

.org-hero__meta-item {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--text-muted);
}

.org-hero__tagline {
  font-size: 0.82rem;
  color: var(--text-secondary);
  font-style: italic;
  margin: 0;
}

/* ============================================
   Dimension Grid (12 Dimensions)
   ============================================ */
.dimension-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.dimension-card {
  padding: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  animation: fadeSlideIn 0.5s ease both;
}

.dimension-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
}

.dimension-card__name {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Heatmap coloring based on grade */
.dimension-card[data-grade^="A"] { border-left: 3px solid var(--grade-a); }
.dimension-card[data-grade^="B"] { border-left: 3px solid var(--grade-b); }
.dimension-card[data-grade^="C"] { border-left: 3px solid var(--grade-c); }
.dimension-card[data-grade^="D"] { border-left: 3px solid var(--grade-d, #ef4444); }
.dimension-card[data-grade="F"] { border-left: 3px solid var(--grade-f, #dc2626); }
.dimension-card[data-grade="N/A"] { border-left: 3px solid var(--border-glass); }

/* ============================================
   Org Stats Strip (Bloomberg Terminal Vibes)
   ============================================ */
.org-stats-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
}

.org-stat-card {
  padding: var(--space-md) var(--space-lg);
  text-align: center;
}

.org-stat-value {
  font-family: var(--font-mono);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--so-teal-bright);
  letter-spacing: -0.5px;
}

.org-stat-label {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: var(--space-xs);
}

.org-stat-sub {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--text-muted);
  margin-top: 2px;
}

/* ============================================
   Nav User Controls (Clerk)
   ============================================ */
.nav-user {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-left: var(--space-md);
}

.nav-user-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--border-glass);
  object-fit: cover;
}

.nav-signout {
  background: transparent;
  border: 1px solid var(--border-glass);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.2s ease;
}

.nav-signout:hover {
  border-color: var(--border-glass-hover);
  color: var(--text-secondary);
  background: var(--bg-glass);
}

/* ============================================
   Responsive: Org Dashboard
   ============================================ */
@media (max-width: 640px) {
  .org-hero {
    flex-direction: column;
    text-align: center;
    gap: var(--space-lg);
    padding: var(--space-xl) var(--space-md);
  }

  .org-hero__meta {
    justify-content: center;
  }

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

  .org-stats-strip {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ============================================
   High Contrast Mode
   ============================================ */
@media (forced-colors: active) {
  .glass-card {
    border: 2px solid CanvasText;
  }

  .grade-badge {
    border: 2px solid currentColor;
  }

  .severity-badge {
    border: 1px solid currentColor;
  }
}

/* ============================================
   COMMAND CENTER: Radar Chart — 12 Dimensions
   Interactive SVG spider/radar with project overlays
   ============================================ */
.radar-section {
  margin-bottom: var(--space-2xl);
}

.radar-container {
  position: relative;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  overflow: hidden;
}

.radar-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(94, 194, 198, 0.015) 1px, transparent 1px),
    linear-gradient(0deg, rgba(94, 194, 198, 0.015) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  border-radius: inherit;
}

.radar-container::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 48%, rgba(94,194,198,0.06) 0%, transparent 55%);
  pointer-events: none;
  border-radius: inherit;
}

.radar-layout {
  display: flex;
  gap: var(--space-xl);
  align-items: flex-start;
  position: relative;
  z-index: 1;
}

.radar-chart-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.radar-chart-wrap svg {
  width: 100%;
  max-width: 520px;
  height: auto;
}

.radar-controls {
  width: 200px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.radar-controls__title {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
}

.radar-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: transparent;
  border: 1px solid var(--border-glass);
  cursor: pointer;
  transition: all var(--transition-fast);
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text-secondary);
  width: 100%;
  text-align: left;
}

.radar-toggle:hover {
  background: var(--bg-glass-hover);
  border-color: var(--border-glass-hover);
  color: var(--text-primary);
}

.radar-toggle[aria-pressed="true"] {
  border-color: var(--project-toggle-color, var(--so-teal-bright));
  background: rgba(94, 194, 198, 0.06);
  color: var(--text-primary);
}

.radar-toggle__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.radar-toggle[aria-pressed="true"] .radar-toggle__dot {
  transform: scale(1.2);
  box-shadow: 0 0 8px currentColor;
}

.radar-toggle__grade {
  margin-left: auto;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.78rem;
}

/* Radar hover tooltip */
.radar-tooltip {
  position: absolute;
  pointer-events: none;
  z-index: 10;
  background: rgba(8, 12, 24, 0.92);
  border: 1px solid var(--border-glass-hover);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--text-primary);
  white-space: nowrap;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.15s ease, transform 0.15s ease;
  backdrop-filter: blur(12px);
}

[data-theme="light"] .radar-tooltip {
  background: rgba(255, 255, 255, 0.95);
  border-color: rgba(0, 0, 0, 0.12);
}

.radar-tooltip.visible {
  opacity: 1;
  transform: translateY(0);
}

.radar-tooltip__dim {
  font-weight: 600;
  color: var(--so-teal-bright);
  margin-bottom: 4px;
}

[data-theme="light"] .radar-tooltip__dim {
  color: var(--so-teal);
}

.radar-tooltip__row {
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.6;
}

.radar-tooltip__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Radar polygon draw animation */
.radar-polygon {
  stroke-dasharray: var(--poly-len, 2000);
  stroke-dashoffset: var(--poly-len, 2000);
  animation: radar-draw 1.2s var(--ease-out-expo) forwards;
  animation-delay: var(--poly-delay, 0s);
}

@keyframes radar-draw {
  to { stroke-dashoffset: 0; }
}

/* Radar axis hover highlight */
.radar-axis-label {
  cursor: pointer;
  font-size: 11px;
  letter-spacing: 0.3px;
  transition: fill var(--transition-fast), text-shadow var(--transition-fast);
}

.radar-axis-label:hover {
  fill: var(--so-teal-bright);
  text-shadow: 0 0 8px rgba(94,194,198,0.3);
}

[data-theme="light"] .radar-axis-label:hover {
  fill: var(--so-teal);
}

/* Radar vertex idle breathing */
@keyframes vertex-idle {
  0%, 100% { r: 3.5; }
  50% { r: 4.5; }
}

.radar-vertex {
  animation: vertex-idle 3s ease-in-out infinite;
}

/* Radar dot pulse on hover */
.radar-vertex:hover {
  r: 6;
  filter: drop-shadow(0 0 6px currentColor);
  animation: none;
}

@media (max-width: 768px) {
  .radar-layout {
    flex-direction: column;
  }

  .radar-controls {
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
  }

  .radar-controls__title {
    width: 100%;
  }

  .radar-toggle {
    flex: 1;
    min-width: 140px;
  }
}

/* ============================================
   COMMAND CENTER: Red Flag Heatmap
   Dimension x Severity matrix with project dots
   ============================================ */
.heatmap-section {
  margin-bottom: var(--space-2xl);
}

.heatmap-container {
  position: relative;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  overflow: hidden;
}

.heatmap-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(217, 123, 123, 0.01) 1px, transparent 1px),
    linear-gradient(0deg, rgba(217, 123, 123, 0.01) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  border-radius: inherit;
}

.heatmap-grid {
  display: grid;
  grid-template-columns: 140px repeat(4, 1fr);
  gap: 3px;
  position: relative;
  z-index: 1;
}

.heatmap-header {
  font-family: var(--font-heading);
  font-size: 0.68rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  padding: var(--space-sm) var(--space-sm);
  text-align: center;
}

.heatmap-header:first-child {
  text-align: left;
}

.heatmap-header--critical { color: #f87171; }
.heatmap-header--high { color: #fb923c; }
.heatmap-header--medium { color: #fbbf24; }
.heatmap-header--low { color: #94a3b8; }

.heatmap-row-label {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--text-secondary);
  padding: var(--space-sm);
  display: flex;
  align-items: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.heatmap-cell {
  position: relative;
  min-height: 42px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  transition: all var(--transition-fast);
  border: 1px solid transparent;
}

.heatmap-cell:hover {
  transform: scale(1.05);
  z-index: 2;
  border-color: var(--border-glass-hover);
}

.heatmap-cell[data-active="true"] {
  border-color: var(--so-teal-bright);
  box-shadow: 0 0 12px rgba(94, 194, 198, 0.2);
}

/* Heat intensity backgrounds */
.heatmap-cell--0 {
  background: rgba(100, 116, 139, 0.04);
}
.heatmap-cell--1 {
  background: rgba(251, 191, 36, 0.06);
}
.heatmap-cell--2 {
  background: rgba(249, 115, 22, 0.1);
  border-color: rgba(248,113,113,0.15);
}
.heatmap-cell--3 {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(248,113,113,0.25);
  box-shadow: inset 0 0 12px rgba(248,113,113,0.15);
}
.heatmap-cell--4 {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(248,113,113,0.30);
  box-shadow: inset 0 0 12px rgba(248,113,113,0.15);
}
.heatmap-cell--5plus {
  background: rgba(239, 68, 68, 0.25);
  border-color: rgba(248,113,113,0.35);
  box-shadow: inset 0 0 12px rgba(248,113,113,0.15);
  animation: heat-pulse 2.5s ease-in-out infinite;
}

@keyframes heat-pulse {
  0%, 100% { background-color: rgba(239, 68, 68, 0.25); }
  50% { background-color: rgba(239, 68, 68, 0.35); }
}

.heatmap-count {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text-muted);
}

.heatmap-cell--0 .heatmap-count { color: var(--text-muted); opacity: 0.4; }
.heatmap-cell--1 .heatmap-count { color: #fbbf24; }
.heatmap-cell--2 .heatmap-count { color: #fb923c; }
.heatmap-cell--3 .heatmap-count { color: #f87171; }
.heatmap-cell--4 .heatmap-count { color: #ef4444; }
.heatmap-cell--5plus .heatmap-count { color: #ef4444; font-size: 1rem; }

.heatmap-dots {
  display: flex;
  gap: 2px;
  position: absolute;
  bottom: 3px;
  left: 50%;
  transform: translateX(-50%);
}

.heatmap-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
}

/* Heatmap cell entrance animation */
.heatmap-cell {
  animation: heatmap-pop 0.3s var(--ease-out-expo) backwards;
}

@keyframes heatmap-pop {
  from {
    opacity: 0;
    transform: scale(0.8);
  }
}

/* Heatmap summary bar */
.heatmap-summary {
  display: flex;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding-top: var(--space-md);
  border-top: 1px solid var(--border-glass);
  position: relative;
  z-index: 1;
}

.heatmap-summary__item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: var(--text-muted);
}

.heatmap-summary__count {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.85rem;
}

.heatmap-summary__item--critical .heatmap-summary__count { color: #f87171; }
.heatmap-summary__item--high .heatmap-summary__count { color: #fb923c; }
.heatmap-summary__item--medium .heatmap-summary__count { color: #fbbf24; }
.heatmap-summary__item--low .heatmap-summary__count { color: #94a3b8; }

@media (max-width: 640px) {
  .heatmap-grid {
    grid-template-columns: 100px repeat(4, 1fr);
  }

  .heatmap-row-label {
    font-size: 0.68rem;
  }

  .heatmap-header {
    font-size: 0.6rem;
  }
}

/* ============================================
   COMMAND CENTER: Project Comparison Bars
   Animated horizontal bars with grade-colored fills
   ============================================ */
.comparison-section {
  margin-bottom: var(--space-2xl);
}

.comparison-container {
  position: relative;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  overflow: hidden;
}

.comparison-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(139, 126, 200, 0.015) 1px, transparent 1px),
    linear-gradient(0deg, rgba(139, 126, 200, 0.015) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  border-radius: inherit;
}

.comparison-controls {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  position: relative;
  z-index: 1;
}

.comparison-tab {
  padding: 6px 14px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-glass);
  background: transparent;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: 0.78rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}

.comparison-tab:hover {
  background: var(--bg-glass-hover);
  color: var(--text-primary);
  border-color: var(--border-glass-hover);
}

.comparison-tab[aria-selected="true"] {
  background: rgba(94, 194, 198, 0.08);
  border-color: var(--so-teal-bright);
  color: var(--so-teal-bright);
  font-weight: 600;
}

[data-theme="light"] .comparison-tab[aria-selected="true"] {
  color: var(--so-teal);
  border-color: var(--so-teal);
  background: rgba(74, 124, 126, 0.06);
}

.comparison-bars {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  position: relative;
  z-index: 1;
}

.comparison-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.comparison-label {
  width: 100px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: right;
  flex-shrink: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.comparison-bar-track {
  flex: 1;
  height: 32px;
  background: rgba(100, 116, 139, 0.06);
  border-radius: var(--radius-full);
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border-glass);
}

.comparison-bar-fill {
  height: 100%;
  border-radius: var(--radius-full);
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 10px;
  transition: width 1s var(--ease-out-expo);
  width: 0;
}

/* Per-project gradient fills */
.comparison-bar-fill[data-project="ypc"] {
  background: linear-gradient(90deg, #4a7c7e 0%, #5ec2c6 100%) !important;
  box-shadow: 0 0 12px rgba(74,124,126,0.2);
}
.comparison-bar-fill[data-project="curbside"] {
  background: linear-gradient(90deg, #d4a04e 0%, #f0d090 100%) !important;
  box-shadow: 0 0 12px rgba(212,160,78,0.2);
}
.comparison-bar-fill[data-project="the-wire"] {
  background: linear-gradient(90deg, #5a8d8f 0%, #8cc3c5 100%) !important;
  box-shadow: 0 0 12px rgba(90,141,143,0.2);
}
.comparison-bar-fill[data-project="second-opinion"] {
  background: linear-gradient(90deg, #7b6eb8 0%, #a99de0 100%) !important;
  box-shadow: 0 0 12px rgba(123,110,184,0.2);
}

.comparison-bar-fill.animate {
  width: var(--bar-width, 0%);
}

.comparison-bar-value {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--text-bright);
  white-space: nowrap;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
}

[data-theme="light"] .comparison-bar-value {
  color: #fff;
}

.comparison-grade {
  width: 44px;
  flex-shrink: 0;
  text-align: center;
}

@media (max-width: 640px) {
  .comparison-label {
    width: 60px;
    font-size: 0.72rem;
  }

  .comparison-controls {
    flex-wrap: wrap;
  }
}

/* ============================================
   COMMAND CENTER: Auditor Agreement Network
   Node-link visualization of consensus
   ============================================ */
.agreement-section {
  margin-bottom: var(--space-2xl);
}

.agreement-container {
  position: relative;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  overflow: hidden;
}

.agreement-container::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 30% 40%, rgba(94, 194, 198, 0.03) 0%, transparent 70%),
    radial-gradient(ellipse 40% 50% at 70% 60%, rgba(232, 181, 99, 0.02) 0%, transparent 70%);
  pointer-events: none;
  border-radius: inherit;
}

.agreement-layout {
  display: flex;
  gap: var(--space-xl);
  align-items: flex-start;
  position: relative;
  z-index: 1;
}

.agreement-chart-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 280px;
}

.agreement-chart-wrap svg {
  width: 100%;
  max-width: 400px;
  height: auto;
}

.agreement-sidebar {
  width: 240px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.agreement-stat {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
}

.agreement-stat__indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.agreement-stat__indicator--unanimous { background: #34d399; }
.agreement-stat__indicator--consensus { background: #5ec2c6; }
.agreement-stat__indicator--contested { background: #fbbf24; }

.agreement-stat__label {
  font-size: 0.78rem;
  color: var(--text-secondary);
  flex: 1;
}

.agreement-stat__value {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text-primary);
}

/* Auditor node hover effects in SVG */
.auditor-node {
  cursor: pointer;
  transition: filter 0.2s ease;
}

.auditor-node:hover {
  filter: drop-shadow(0 0 12px currentColor);
}

/* Agreement connection draw animation */
.agreement-link {
  stroke-dasharray: var(--link-len, 200);
  stroke-dashoffset: var(--link-len, 200);
  animation: agreement-draw 0.8s var(--ease-out-expo) forwards;
  animation-delay: var(--link-delay, 0s);
}

@keyframes agreement-draw {
  to { stroke-dashoffset: 0; }
}

/* Auditor node entrance */
.auditor-node-circle {
  animation: node-enter 0.5s var(--ease-spring) backwards;
}

@keyframes node-enter {
  from {
    r: 0;
    opacity: 0;
  }
}

@media (max-width: 768px) {
  .agreement-layout {
    flex-direction: column;
  }

  .agreement-sidebar {
    width: 100%;
    flex-direction: row;
    flex-wrap: wrap;
  }

  .agreement-stat {
    flex: 1;
    min-width: 140px;
  }
}

/* ============================================
   Command Center: Section Dividers
   ============================================ */
.command-section {
  margin-bottom: var(--space-2xl);
}

.command-section .section-header {
  margin-bottom: var(--space-lg);
}

/* ============================================
   Command Center: Row Layout (2-up)
   ============================================ */
.command-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

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

/* ============================================
   Command Center: Chart Title inside containers
   ============================================ */
.chart-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-md);
  position: relative;
  z-index: 1;
}

.chart-header__title {
  font-family: var(--font-heading);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
}

.chart-header__subtitle {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--text-muted);
}

/* ============================================
   Print: Command Center additions
   ============================================ */
@media print {
  .radar-container,
  .heatmap-container,
  .comparison-container,
  .agreement-container {
    background: #fff !important;
    border: 1px solid #ddd !important;
    backdrop-filter: none !important;
    break-inside: avoid;
  }

  .radar-container::before,
  .heatmap-container::before,
  .comparison-container::before,
  .agreement-container::before {
    display: none !important;
  }

  .comparison-bar-fill,
  .radar-polygon,
  .agreement-link {
    animation: none !important;
  }

  .command-row {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ============================================
   Reduced Motion: Command Center
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  .radar-polygon,
  .agreement-link,
  .heatmap-cell,
  .comparison-bar-fill {
    animation: none !important;
    transition: none !important;
    stroke-dashoffset: 0 !important;
  }

  .radar-vertex {
    animation: none !important;
  }

  .so-loader::before,
  .so-loader::after {
    animation: none !important;
  }

  .comparison-bar-fill {
    width: var(--bar-width, 0%) !important;
  }
}

/* ============================================
   Branded Loading Spinner
   ============================================ */
.so-loader {
  width: 48px;
  height: 48px;
  position: relative;
}

.so-loader::before,
.so-loader::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid var(--so-teal-bright);
  border-radius: 50%;
  animation: so-pulse 1.8s var(--ease-out-expo) infinite;
}

.so-loader::after {
  animation-delay: 0.6s;
}

@keyframes so-pulse {
  0% { transform: scale(0.3); opacity: 1; }
  100% { transform: scale(1.2); opacity: 0; }
}

/* ============================================
   About / Methodology Page
   ============================================ */

.about-intro {
  color: var(--text-secondary);
  line-height: 1.7;
  max-width: 720px;
  margin-bottom: var(--space-xl);
}

/* --- Auditor Grid --- */
.auditor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-3xl);
}

.auditor-card {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.auditor-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  flex-wrap: wrap;
}

.auditor-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--text-primary);
}

.auditor-card__badge {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 3px 10px;
  border-radius: var(--radius-full);
}

.auditor-card__badge--technical {
  background: rgba(94, 194, 198, 0.12);
  color: var(--so-teal-bright);
  border: 1px solid rgba(94, 194, 198, 0.2);
}

.auditor-card__badge--legal {
  background: rgba(232, 181, 99, 0.12);
  color: var(--so-gold);
  border: 1px solid rgba(232, 181, 99, 0.2);
}

.auditor-card__badge--research {
  background: rgba(139, 126, 200, 0.12);
  color: var(--so-purple);
  border: 1px solid rgba(139, 126, 200, 0.2);
}

.auditor-card__badge--synthesis {
  background: rgba(99, 179, 232, 0.12);
  color: var(--so-blue);
  border: 1px solid rgba(99, 179, 232, 0.2);
}

.auditor-card__model {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--text-muted);
}

.auditor-card__desc {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.6;
  margin: 0;
}

/* --- Dimension Grid --- */
.dimension-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-3xl);
}

.dimension-card {
  padding: var(--space-lg);
  position: relative;
}

.dimension-card__num {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--so-teal-bright);
  opacity: 0.6;
  letter-spacing: 0.05em;
}

.dimension-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.98rem;
  color: var(--text-primary);
  margin: var(--space-xs) 0 var(--space-sm);
}

.dimension-card__desc {
  color: var(--text-secondary);
  font-size: 0.85rem;
  line-height: 1.6;
  margin: 0;
}

/* --- Principle Grid --- */
.principle-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-3xl);
}

.principle-card {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.principle-card__num {
  font-family: var(--font-mono);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--so-teal-bright);
  opacity: 0.25;
  line-height: 1;
}

.principle-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.05rem;
  color: var(--text-primary);
  margin: 0;
}

.principle-card__rule {
  color: var(--text-secondary);
  font-size: 0.88rem;
  line-height: 1.6;
  margin: 0;
}

.principle-card__scale {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-top: var(--space-xs);
}

.scale-tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  color: var(--text-muted);
}

.scale-tag--good {
  background: rgba(94, 194, 198, 0.1);
  border-color: rgba(94, 194, 198, 0.2);
  color: var(--so-teal-bright);
}

.scale-tag--bad {
  background: rgba(217, 123, 123, 0.1);
  border-color: rgba(217, 123, 123, 0.2);
  color: var(--so-coral);
}

/* --- Rubric Table --- */
.rubric-table-wrap {
  overflow-x: auto;
  margin-bottom: var(--space-3xl);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-glass);
  background: var(--bg-card);
  backdrop-filter: blur(12px);
}

.rubric-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.rubric-table thead th {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  padding: var(--space-md) var(--space-lg);
  text-align: left;
  border-bottom: 1px solid var(--border-glass);
}

.rubric-table tbody td {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid rgba(255, 255, 255, 0.03);
  vertical-align: top;
}

.rubric-table tbody td:first-child {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.95rem;
  white-space: nowrap;
  width: 60px;
}

.rubric-table tbody td:last-child {
  color: var(--text-secondary);
  line-height: 1.5;
}

.rubric-row--a td:first-child { color: var(--grade-a); }
.rubric-row--b td:first-child { color: var(--grade-b); }
.rubric-row--c td:first-child { color: var(--grade-c); }
.rubric-row--d td:first-child { color: var(--grade-d, #ef4444); }
.rubric-row--f td:first-child { color: var(--grade-f, #dc2626); }

/* --- Process Flow --- */
.process-flow {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: var(--space-3xl);
}

.process-step {
  display: flex;
  align-items: flex-start;
  gap: var(--space-lg);
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg) var(--space-xl);
  backdrop-filter: blur(12px);
}

.process-step__num {
  font-family: var(--font-mono);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--so-teal-bright);
  min-width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: rgba(94, 194, 198, 0.1);
  border: 1px solid rgba(94, 194, 198, 0.2);
  flex-shrink: 0;
}

.process-step__content {
  flex: 1;
}

.process-step__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
  margin: 0 0 var(--space-xs);
}

.process-step__content p {
  color: var(--text-secondary);
  font-size: 0.88rem;
  line-height: 1.6;
  margin: 0;
}

.process-arrow {
  width: 2px;
  height: 20px;
  background: rgba(94, 194, 198, 0.15);
  margin-left: 38px;
  flex-shrink: 0;
}

/* ============================================
   Competitive Landscape — market intelligence
   ============================================ */

/* Competitor Card Grid */
.competitor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

.competitor-card {
  background: var(--gradient-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}

.competitor-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-scanline);
  pointer-events: none;
  opacity: 0.3;
}

.competitor-card:hover {
  border-color: var(--border-glass-hover);
  background: var(--bg-card-hover);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.competitor-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.competitor-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
  margin: 0;
}

.competitor-card__name a {
  color: inherit;
  text-decoration: none;
}

.competitor-card__name a:hover {
  color: var(--so-teal-bright);
}

.competitor-card__desc {
  font-size: 0.8rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: var(--space-md);
}

.competitor-card__meta {
  display: flex;
  gap: var(--space-md);
  font-size: 0.72rem;
  color: var(--text-muted);
  font-family: var(--font-mono);
  margin-bottom: var(--space-md);
}

/* Threat Level Badges — reuses severity-badge pattern */
.threat-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

.threat-badge--critical {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.2);
  animation: severity-pulse 2s ease-in-out infinite;
}

.threat-badge--high {
  background: rgba(249, 115, 22, 0.1);
  color: #fb923c;
  border: 1px solid rgba(249, 115, 22, 0.2);
}

.threat-badge--moderate {
  background: rgba(251, 191, 36, 0.08);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.2);
}

.threat-badge--low {
  background: rgba(100, 116, 139, 0.08);
  color: #94a3b8;
  border: 1px solid rgba(100, 116, 139, 0.15);
}

.threat-badge--watch {
  background: rgba(139, 126, 200, 0.08);
  color: #a5b4fc;
  border: 1px solid rgba(139, 126, 200, 0.15);
}

[data-theme="light"] .threat-badge--critical {
  background: rgba(239, 68, 68, 0.08);
  color: #dc2626;
  border-color: rgba(239, 68, 68, 0.15);
}

[data-theme="light"] .threat-badge--high {
  background: rgba(249, 115, 22, 0.07);
  color: #c2410c;
  border-color: rgba(249, 115, 22, 0.15);
}

[data-theme="light"] .threat-badge--moderate {
  background: rgba(217, 119, 6, 0.07);
  color: #92400e;
  border-color: rgba(217, 119, 6, 0.12);
}

[data-theme="light"] .threat-badge--low {
  background: rgba(100, 116, 139, 0.06);
  color: #475569;
  border-color: rgba(100, 116, 139, 0.12);
}

[data-theme="light"] .threat-badge--watch {
  background: rgba(139, 126, 200, 0.06);
  color: #6366f1;
  border-color: rgba(139, 126, 200, 0.12);
}

/* Trait Pills — strengths and weaknesses */
.trait-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
}

.trait-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 0.62rem;
  font-weight: 500;
  line-height: 1.6;
}

.trait-pill--strength {
  background: rgba(52, 211, 153, 0.08);
  color: #6ee7b7;
  border: 1px solid rgba(52, 211, 153, 0.15);
}

.trait-pill--weakness {
  background: rgba(251, 191, 36, 0.06);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.12);
}

[data-theme="light"] .trait-pill--strength {
  background: rgba(5, 150, 105, 0.06);
  color: #059669;
  border-color: rgba(5, 150, 105, 0.15);
}

[data-theme="light"] .trait-pill--weakness {
  background: rgba(217, 119, 6, 0.06);
  color: #92400e;
  border-color: rgba(217, 119, 6, 0.12);
}

/* Feature Matrix Table */
.feature-matrix-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: var(--space-2xl);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-glass);
}

.feature-matrix {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.82rem;
  min-width: 600px;
}

.feature-matrix th {
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  color: var(--text-muted);
  font-weight: 600;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 1px solid var(--border-glass);
  white-space: nowrap;
}

.feature-matrix td {
  padding: 10px var(--space-md);
  border-bottom: 1px solid var(--border-glass);
  color: var(--text-secondary);
  vertical-align: middle;
}

.feature-matrix tr {
  transition: background var(--transition-fast);
}

.feature-matrix tbody tr:hover {
  background: var(--bg-glass);
}

.feature-matrix tr:last-child td { border-bottom: none; }

/* Feature status indicators */
.feature-status {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 600;
  font-family: var(--font-mono);
}

.feature-status--shipped { color: #34d399; }
.feature-status--shipped::before { content: '\2713 '; }

.feature-status--in-progress { color: #fbbf24; }
.feature-status--in-progress::before { content: '\25CB '; }

.feature-status--planned { color: #94a3b8; }
.feature-status--planned::before { content: '\2026 '; }

.feature-status--not-planned { color: var(--text-muted); }
.feature-status--not-planned::before { content: '\2014 '; }

.feature-status--unknown { color: var(--text-muted); }
.feature-status--unknown::before { content: '? '; }

.feature-status--n-a { color: var(--text-muted); }

[data-theme="light"] .feature-status--shipped { color: #059669; }
[data-theme="light"] .feature-status--in-progress { color: #d97706; }

/* Gaps & Opportunities Grid */
.gaps-opps-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}

.gaps-opps-grid__section-title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.82rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--space-md);
}

.gap-card,
.opp-card {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-sm);
  transition: border-color var(--transition-fast);
}

.gap-card:hover,
.opp-card:hover {
  border-color: var(--border-glass-hover);
  transform: translateY(-2px);
}

.gap-card {
  border-left: 3px solid var(--so-coral);
}

.opp-card {
  border-left: 3px solid var(--so-emerald);
}

.gap-card__title,
.opp-card__title {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.gap-card__desc,
.opp-card__desc {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: var(--space-sm);
}

.gap-card__meta,
.opp-card__meta {
  display: flex;
  gap: var(--space-sm);
  font-size: 0.65rem;
  font-family: var(--font-mono);
  color: var(--text-muted);
}

/* Competitive Freshness Indicator */
.competitive-freshness {
  font-size: 0.72rem;
  font-family: var(--font-mono);
  color: var(--text-muted);
  margin-bottom: var(--space-lg);
}

.competitive-freshness--stale {
  color: var(--so-coral);
}

.market-workspace {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.market-mode-tabs {
  display: inline-flex;
  gap: var(--space-sm);
  padding: 6px;
  align-self: flex-start;
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-full);
  background: rgba(7, 12, 24, 0.55);
  backdrop-filter: blur(18px);
}

.market-mode-tab {
  border: none;
  background: transparent;
  color: var(--text-muted);
  padding: 10px 18px;
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: 0.84rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

.market-mode-tab:hover {
  color: var(--text-primary);
  transform: translateY(-1px);
}

.market-mode-tab[aria-selected="true"] {
  background: linear-gradient(135deg, rgba(94, 194, 198, 0.16) 0%, rgba(123, 110, 184, 0.22) 100%);
  color: var(--text-bright);
  box-shadow: inset 0 0 0 1px rgba(94, 194, 198, 0.24);
}

.market-panel {
  display: none;
}

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

.vision-board {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.vision-board__hero {
  display: grid;
  gap: var(--space-lg);
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.95fr);
  padding: clamp(1.35rem, 1rem + 1vw, 2rem);
  background:
    radial-gradient(circle at top right, rgba(123, 110, 184, 0.24), transparent 35%),
    radial-gradient(circle at bottom left, rgba(94, 194, 198, 0.16), transparent 42%),
    var(--gradient-card);
}

.vision-board__eyebrow {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--so-teal-bright);
  margin-bottom: var(--space-sm);
}

.vision-board__title {
  margin: 0 0 var(--space-sm);
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 1.3rem + 1.4vw, 2.8rem);
  line-height: 1.04;
  color: var(--text-bright);
}

.vision-board__viewer {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.7rem;
  margin-bottom: var(--space-md);
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-family: var(--font-mono);
}

.vision-board__message {
  margin: 0;
  max-width: 66ch;
  font-size: 0.98rem;
  line-height: 1.7;
  color: var(--text-primary);
}

.vision-board__mantras {
  display: grid;
  gap: var(--space-sm);
}

.vision-board__mantra {
  padding: var(--space-md);
  border: 1px solid rgba(94, 194, 198, 0.14);
  border-radius: var(--radius-md);
  background: rgba(7, 12, 24, 0.42);
  color: var(--text-primary);
  font-size: 0.88rem;
  line-height: 1.6;
}

.vision-board__tracks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-md);
}

.vision-track {
  padding: var(--space-lg);
  border-left: 3px solid var(--so-amber);
}

.vision-track__title {
  font-family: var(--font-heading);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-xs);
}

.vision-track__prompt {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.82rem;
  line-height: 1.6;
}

.vision-company-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--space-lg);
}

.vision-company {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: clamp(1rem, 0.9rem + 0.5vw, 1.4rem);
}

.vision-company__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md);
}

.vision-company__label {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-bright);
}

.vision-company__subhead {
  margin-top: 0.25rem;
  color: var(--text-muted);
  font-size: 0.8rem;
  line-height: 1.5;
}

.vision-company__copy {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.84rem;
  line-height: 1.65;
}

.vision-company__copy strong {
  color: var(--text-primary);
}

.vision-leader-grid {
  display: grid;
  gap: var(--space-sm);
}

.vision-leader {
  padding: var(--space-md);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-glass);
  background: rgba(255, 255, 255, 0.025);
}

.vision-leader__head {
  display: flex;
  gap: var(--space-md);
  align-items: center;
}

.vision-leader__avatar {
  width: 60px;
  height: 60px;
  border-radius: 18px;
  object-fit: cover;
  object-position: center;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.04);
}

.vision-leader__avatar--fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-bright);
  background: linear-gradient(135deg, rgba(94, 194, 198, 0.3) 0%, rgba(123, 110, 184, 0.35) 100%);
}

.vision-leader__identity {
  min-width: 0;
}

.vision-leader__name {
  color: var(--text-primary);
  font-weight: 600;
  line-height: 1.3;
}

.vision-leader__role-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.45rem;
}

.vision-role-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.24rem 0.58rem;
  border-radius: var(--radius-full);
  background: rgba(94, 194, 198, 0.1);
  color: var(--so-teal-bright);
  font-size: 0.69rem;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.vision-leader__title {
  margin-top: var(--space-sm);
  color: var(--text-secondary);
  font-size: 0.8rem;
  line-height: 1.55;
}

.vision-leader__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  margin-top: var(--space-sm);
  font-size: 0.72rem;
  font-family: var(--font-mono);
}

.vision-leader__meta a {
  color: var(--so-teal-bright);
  text-decoration: none;
}

.vision-leader__meta a:hover {
  text-decoration: underline;
}

.vision-confidence {
  padding: 0.22rem 0.5rem;
  border-radius: var(--radius-full);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--text-muted);
}

.vision-confidence--high {
  color: var(--so-emerald);
}

.vision-confidence--medium {
  color: var(--so-amber);
}

.vision-confidence--low {
  color: var(--so-coral);
}

.vision-company__questions {
  display: grid;
  gap: var(--space-xs);
}

.vision-company__question {
  padding: 0.72rem 0.82rem;
  border-radius: var(--radius-sm);
  background: rgba(217, 123, 123, 0.06);
  border: 1px solid rgba(217, 123, 123, 0.12);
  color: var(--text-secondary);
  font-size: 0.78rem;
  line-height: 1.55;
}

.vision-project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-lg);
}

.vision-project-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: clamp(1rem, 0.9rem + 0.5vw, 1.35rem);
}

.vision-project-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-md);
}

.vision-project-card__name {
  font-family: var(--font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-bright);
}

.vision-project-card__status {
  margin-top: 0.32rem;
  color: var(--so-teal-bright);
  font-size: 0.74rem;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.vision-project-card__copy {
  margin: 0;
  color: var(--text-secondary);
  font-size: 0.84rem;
  line-height: 1.65;
}

.vision-project-card__copy strong {
  color: var(--text-primary);
}

.vision-project-card__actions {
  margin-top: auto;
}

/* Competitive Landscape Responsive */
@media (max-width: 768px) {
  .competitor-grid {
    grid-template-columns: 1fr;
  }

  .gaps-opps-grid {
    grid-template-columns: 1fr;
  }

  .feature-matrix-wrapper {
    margin-left: calc(-1 * var(--space-md));
    margin-right: calc(-1 * var(--space-md));
    border-radius: 0;
    border-left: none;
    border-right: none;
  }

  .market-mode-tabs {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .vision-board__hero {
    grid-template-columns: 1fr;
  }

  .vision-company-grid {
    grid-template-columns: 1fr;
  }

  .vision-project-grid {
    grid-template-columns: 1fr;
  }
}

/* --- Stakes Grid (In Their Own Words) --- */
.stakes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.stakes-card {
  padding: var(--space-lg);
  border-left: 3px solid var(--so-teal);
  position: relative;
}

.stakes-card--critical {
  border-left-color: var(--so-coral);
  background: linear-gradient(135deg, rgba(217, 123, 123, 0.04) 0%, transparent 60%), var(--gradient-card);
}

.stakes-quote {
  font-family: var(--font-body);
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--text-primary);
  font-style: normal;
  margin: 0 0 var(--space-md) 0;
}

.stakes-quote em {
  color: var(--so-teal-bright);
  font-style: italic;
}

.stakes-source {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
}

.stakes-source__agent {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.75rem;
  color: var(--so-teal-bright);
}

.stakes-source__file {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--text-muted);
  opacity: 0.7;
}

[data-theme="light"] .stakes-card--critical {
  background: linear-gradient(135deg, rgba(217, 123, 123, 0.03) 0%, transparent 60%), var(--gradient-card);
}

/* --- Transparency Section --- */
.about-transparency {
  margin-bottom: var(--space-2xl);
}

/* --- About Page Responsive --- */
@media (max-width: 640px) {
  .stakes-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .auditor-grid,
  .dimension-grid,
  .principle-grid {
    grid-template-columns: 1fr;
  }

  .process-step {
    padding: var(--space-md);
  }

  .rubric-table tbody td,
  .rubric-table thead th {
    padding: var(--space-sm) var(--space-md);
  }
}

/* --- About Page Light Theme --- */
[data-theme="light"] .rubric-table-wrap {
  background: var(--bg-card);
}

[data-theme="light"] .scale-tag {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .scale-tag--good {
  background: rgba(74, 124, 126, 0.08);
  border-color: rgba(74, 124, 126, 0.18);
}

[data-theme="light"] .scale-tag--bad {
  background: rgba(217, 123, 123, 0.08);
  border-color: rgba(217, 123, 123, 0.18);
}

/* ============================================
   Project Sub-Navigation Tabs
   ============================================ */
.project-subnav {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: var(--space-sm) var(--space-lg);
  margin: 0 auto var(--space-lg);
  max-width: 1360px;
  border-bottom: 1px solid var(--border-glass);
}

.project-subnav > .project-selector {
  margin-right: var(--space-md);
}

.subnav-tab {
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  font-weight: 500;
  font-size: 0.82rem;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast);
  white-space: nowrap;
}

.subnav-tab:hover {
  background: var(--bg-glass-hover);
  color: var(--text-primary);
}

.subnav-tab--active {
  color: var(--text-primary);
  font-weight: 600;
  background: var(--bg-glass-hover);
  border-bottom: 2px solid var(--so-teal-bright);
}

/* ============================================
   Tech Stack Pills
   ============================================ */
.tech-stack-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  padding: var(--space-md) 0;
}

.tech-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--so-teal-bright);
  transition: all var(--transition-fast);
}

.tech-pill:hover {
  background: var(--bg-glass-hover);
  border-color: var(--border-glass-hover);
}

/* ============================================
   Architecture Doc Sections (expandable)
   ============================================ */
.arch-doc-section {
  margin-bottom: var(--space-md);
  padding: var(--space-lg);
}

.arch-doc-section__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.arch-doc-section__title::-webkit-details-marker { display: none; }

.arch-doc-section__title::before {
  content: '\25b6';
  font-size: 0.65rem;
  color: var(--text-muted);
  transition: transform var(--transition-fast);
}

.arch-doc-section[open] > .arch-doc-section__title::before {
  transform: rotate(90deg);
}

/* ============================================
   Diagram Grid
   ============================================ */
.diagram-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: var(--space-lg);
}

.diagram-card {
  padding: var(--space-lg);
  overflow: hidden;
}

.diagram-card__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  text-transform: capitalize;
}

.diagram-card__content {
  display: flex;
  justify-content: center;
  overflow-x: auto;
}

.diagram-card__content img {
  max-width: 100%;
  height: auto;
}

.diagram-card__content .mermaid {
  width: 100%;
}

/* ============================================
   Mockup Embed (Features page)
   ============================================ */
.mockup-embed {
  position: relative;
  width: 100%;
  padding-top: 66.67%; /* 3:2 aspect ratio */
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  box-shadow: var(--shadow-lg);
}

.mockup-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* ============================================
   Feature Guide Cards
   ============================================ */
.feature-guide-card {
  padding: var(--space-lg);
  margin-bottom: var(--space-md);
}

.feature-guide-card h3 {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1rem;
  color: var(--text-primary);
  margin-bottom: var(--space-md);
  text-transform: capitalize;
}

/* ============================================
   Docs Browser Layout
   ============================================ */
.docs-layout {
  display: flex;
  gap: var(--space-xl);
  min-height: 60vh;
}

.docs-sidebar {
  width: 260px;
  flex-shrink: 0;
  position: sticky;
  top: 80px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  padding-right: var(--space-md);
}

.docs-nav-group {
  margin-bottom: var(--space-lg);
}

.docs-nav-group__title {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  padding: var(--space-xs) var(--space-sm);
  margin-bottom: var(--space-xs);
}

.docs-nav-item {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: 6px var(--space-sm);
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-size: 0.82rem;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-transform: capitalize;
}

.docs-nav-item:hover {
  background: var(--bg-glass-hover);
  color: var(--text-primary);
}

.docs-nav-item--active {
  background: var(--bg-glass-hover);
  color: var(--so-teal-bright);
  font-weight: 500;
  border-left: 2px solid var(--so-teal-bright);
}

.docs-content {
  flex: 1;
  min-width: 0;
}

/* ============================================
   Markdown Content Styling
   ============================================ */
.markdown-content {
  font-family: var(--font-body);
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--text-secondary);
}

.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4 {
  font-family: var(--font-heading);
  color: var(--text-primary);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-md);
}

.markdown-content h1 { font-size: 1.4rem; font-weight: 700; }
.markdown-content h2 { font-size: 1.15rem; font-weight: 600; border-bottom: 1px solid var(--border-glass); padding-bottom: var(--space-sm); }
.markdown-content h3 { font-size: 1rem; font-weight: 600; }
.markdown-content h4 { font-size: 0.9rem; font-weight: 600; color: var(--text-secondary); }

.markdown-content p {
  margin-bottom: var(--space-md);
}

.markdown-content ul,
.markdown-content ol {
  margin-bottom: var(--space-md);
  padding-left: var(--space-xl);
}

.markdown-content li {
  margin-bottom: var(--space-xs);
}

.markdown-content code {
  font-family: var(--font-mono);
  font-size: 0.82em;
  background: var(--bg-tertiary);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--so-teal-bright);
}

.markdown-content pre {
  background: var(--bg-tertiary);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  overflow-x: auto;
  margin-bottom: var(--space-md);
}

.markdown-content pre code {
  background: none;
  padding: 0;
  font-size: 0.8rem;
  color: var(--text-primary);
}

.markdown-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-md);
  font-size: 0.85rem;
}

.markdown-content th,
.markdown-content td {
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-glass);
  text-align: left;
}

.markdown-content th {
  background: var(--bg-tertiary);
  font-weight: 600;
  color: var(--text-primary);
}

.markdown-content blockquote {
  border-left: 3px solid var(--so-teal);
  padding-left: var(--space-md);
  margin: var(--space-md) 0;
  color: var(--text-muted);
  font-style: italic;
}

.markdown-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
}

.markdown-content hr {
  border: none;
  border-top: 1px solid var(--border-glass);
  margin: var(--space-xl) 0;
}

/* ============================================
   Prose — enhanced markdown for docs/arch pages
   ============================================ */
.prose {
  font-family: var(--font-body);
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--text-secondary);
}

.prose h1, .prose h2, .prose h3, .prose h4 {
  font-family: var(--font-heading);
  color: var(--text-primary);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-md);
}

.prose h1 { font-size: 1.4rem; font-weight: 700; }
.prose h2 { font-size: 1.15rem; font-weight: 600; border-bottom: 1px solid var(--border-glass); padding-bottom: var(--space-sm); }
.prose h3 { font-size: 1rem; font-weight: 600; }
.prose h4 { font-size: 0.9rem; font-weight: 600; color: var(--text-secondary); }

.prose p { margin-bottom: var(--space-md); }

.prose ul, .prose ol {
  margin-bottom: var(--space-md);
  padding-left: var(--space-xl);
}

.prose li {
  margin-bottom: var(--space-xs);
}

.prose li::marker {
  color: var(--so-teal-bright);
}

.prose a {
  color: var(--so-teal-bright);
  text-decoration: none;
}

.prose a:hover {
  text-decoration: underline;
}

.prose code {
  font-family: var(--font-mono);
  font-size: 0.82em;
  background: var(--bg-tertiary);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--so-teal-bright);
}

.prose pre {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: calc(var(--space-xl) + 4px) var(--space-md) var(--space-md);
  overflow-x: auto;
  margin-bottom: var(--space-md);
  backdrop-filter: blur(8px);
  box-shadow: var(--shadow-inset);
}

/* Code block top bar */
.prose pre::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 28px;
  background: var(--bg-tertiary);
  border-bottom: 1px solid var(--border-glass);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
}

/* Language label pill */
.prose pre::after {
  content: attr(data-lang);
  position: absolute;
  top: 6px;
  left: var(--space-sm);
  font-family: var(--font-mono);
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  background: var(--bg-glass);
  padding: 1px 8px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border-glass);
  z-index: 1;
}

/* Copy button area placeholder */
.prose pre[data-lang]::before {
  /* Top bar already set above, just ensure language label shows */
}

.prose pre code {
  background: none;
  padding: 0;
  font-size: 0.8rem;
  color: var(--text-primary);
}

.prose blockquote {
  border-left: 3px solid var(--so-teal-bright);
  padding: var(--space-md) var(--space-md) var(--space-md) var(--space-lg);
  margin: var(--space-md) 0;
  color: var(--text-muted);
  font-style: italic;
  background: rgba(94, 194, 198, 0.03);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.prose table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space-md);
  font-size: 0.85rem;
  background: var(--bg-card);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--border-glass);
}

.prose th, .prose td {
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--border-glass);
  text-align: left;
}

.prose th {
  background: var(--bg-tertiary);
  font-weight: 600;
  color: var(--text-primary);
}

.prose tr:nth-child(even) td {
  background: rgba(255, 255, 255, 0.015);
}

[data-theme="light"] .prose tr:nth-child(even) td {
  background: rgba(0, 0, 0, 0.02);
}

.prose img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
}

.prose hr {
  border: none;
  border-top: 1px solid var(--border-glass);
  margin: var(--space-xl) 0;
}

/* Staggered entrance for prose elements */
.prose > h1, .prose > h2, .prose > h3, .prose > h4,
.prose > p, .prose > ul, .prose > ol,
.prose > pre, .prose > blockquote, .prose > table {
  animation: prose-enter 0.5s var(--ease-out-expo) backwards;
}

.prose > :nth-child(1) { animation-delay: 0.05s; }
.prose > :nth-child(2) { animation-delay: 0.08s; }
.prose > :nth-child(3) { animation-delay: 0.11s; }
.prose > :nth-child(4) { animation-delay: 0.14s; }
.prose > :nth-child(5) { animation-delay: 0.17s; }
.prose > :nth-child(n+6) { animation-delay: 0.2s; }

@keyframes prose-enter {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
}

/* Shared empty hints */
.empty-hint {
  color: var(--text-muted);
  font-size: 0.85rem;
  padding: var(--space-md) 0;
}

/* ============================================
   Responsive: Docs Sidebar
   ============================================ */
@media (max-width: 768px) {
  .docs-layout {
    flex-direction: column;
  }

  .docs-sidebar {
    width: 100%;
    position: static;
    max-height: none;
    padding-right: 0;
    border-bottom: 1px solid var(--border-glass);
    padding-bottom: var(--space-md);
    margin-bottom: var(--space-md);
  }

  .docs-nav-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    margin-bottom: var(--space-sm);
  }

  .docs-nav-group__title {
    width: 100%;
  }

  .diagram-grid {
    grid-template-columns: 1fr;
  }

  .project-subnav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* ============================================
   Hero Card Background Image Treatment
   ============================================ */
.project-card__hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.06;
  mask-image: linear-gradient(to bottom, black 0%, transparent 80%);
  -webkit-mask-image: linear-gradient(to bottom, black 0%, transparent 80%);
  pointer-events: none;
  transition: opacity 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

[data-theme="light"] .project-card__hero-bg {
  opacity: 0.08;
}

.project-card:hover .project-card__hero-bg {
  opacity: 0.10;
}

@media (prefers-reduced-motion: reduce) {
  .project-card__hero-bg {
    transition: none;
  }
}

/* Ensure card content sits above hero background */
.project-card__header,
.project-card__desc,
.project-card__finance,
.project-card__stats,
.project-card > .trend {
  position: relative;
  z-index: 1;
}

/* ============================================
   Header Sigils (decorative sub-page icons)
   ============================================ */
.header-sigil {
  width: 36px;
  height: 36px;
  opacity: 0.30;
  flex-shrink: 0;
  filter: grayscale(0.3);
  transition: opacity 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

[data-theme="light"] .header-sigil {
  opacity: 0.22;
}

.rc-header:hover .header-sigil,
.rc-hero:hover .header-sigil {
  opacity: 0.45;
}

@media (prefers-reduced-motion: reduce) {
  .header-sigil {
    transition: none;
  }
}
