/* ===================================================================
   Card Research — Dawn Aurora Theme v2 (cr-theme.css)
   card-research.org
   Light-base sibling of card-prices.com's galaxy theme.
   White primary, GE rainbow PROMINENT secondary.
   Academic credibility + real personality.
   Loaded AFTER site.css + inline <style>, overrides both.
   =================================================================== */


/* ==================================================================
   0. DESIGN TOKENS
   ================================================================== */

:root {
  /* ---- Base surfaces ---- */
  --cr-bg:             #f7f8fb;
  --cr-bg-warm:        #fefefe;
  --cr-surface:        #ffffff;
  --cr-surface-glass:  rgba(255, 255, 255, 0.84);
  --cr-border:         rgba(0, 0, 0, 0.08);
  --cr-border-hover:   rgba(0, 0, 0, 0.16);

  /* ---- GE accent palette (light-mode adapted) ---- */
  --cr-cyan:           #0891b2;
  --cr-cyan-bright:    #00d4ff;
  --cr-cyan-dim:       rgba(8, 145, 178, 0.08);
  --cr-cyan-glow:      rgba(0, 212, 255, 0.28);
  --cr-orange:         #ea580c;
  --cr-orange-dim:     rgba(234, 88, 12, 0.07);
  --cr-teal:           #0d9488;
  --cr-teal-dim:       rgba(13, 148, 136, 0.07);
  --cr-blue:           #1e40af;
  --cr-blue-dim:       rgba(30, 64, 175, 0.06);
  --cr-blue-light:     #dbeafe;
  --cr-gold:           #b45309;
  --cr-gold-dim:       rgba(180, 83, 9, 0.06);
  --cr-violet:         #7c3aed;
  --cr-violet-dim:     rgba(124, 58, 237, 0.06);
  --cr-pink:           #db2777;
  --cr-pink-dim:       rgba(219, 39, 119, 0.06);

  /* ---- Rainbow gradients -- GE signature (matches --holo-gradient) ---- */
  --cr-rainbow: linear-gradient(90deg,
    #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700, #ff6a00);
  --cr-rainbow-vertical: linear-gradient(180deg,
    #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700, #ff6a00);
  --cr-rainbow-wide: linear-gradient(90deg,
    #ff6a00 0%, #ff3cac 16%, #6a5acd 33%, #00bfff 50%,
    #00f5cc 66%, #ffd700 83%, #ff6a00 100%);

  /* ---- Text hierarchy ---- */
  --cr-text:           #0f172a;
  --cr-text-secondary: #334155;
  --cr-text-muted:     #64748b;
  --cr-text-faint:     #78879a;

  /* ---- Functional colors ---- */
  --cr-success:        #16a34a;
  --cr-success-dim:    rgba(5, 150, 105, 0.09);
  --cr-warning:        #d97706;
  --cr-warning-dim:    rgba(217, 119, 6, 0.09);
  --cr-planned:        #7c3aed;
  --cr-planned-dim:    rgba(124, 58, 237, 0.07);
  --cr-error:          #dc2626;

  /* ---- Stat pill accent colors (per-card unique) ---- */
  --cr-stat-1: #0891b2;   /* cyan */
  --cr-stat-2: #ea580c;   /* orange */
  --cr-stat-3: #b45309;   /* gold */
  --cr-stat-4: #7c3aed;   /* violet */

  /* ---- Shadows -- warm with subtle color tint ---- */
  --cr-shadow-sm:    0 1px 4px rgba(0,0,0,0.05), 0 0 10px rgba(0,212,255,0.05);
  --cr-shadow-md:    0 4px 20px rgba(0,0,0,0.07), 0 0 28px rgba(0,212,255,0.07);
  --cr-shadow-lg:    0 8px 40px rgba(0,0,0,0.09), 0 0 50px rgba(0,212,255,0.08);
  --cr-shadow-card:  0 2px 14px rgba(0,0,0,0.06), 0 1px 4px rgba(0,0,0,0.08);
  --cr-shadow-glow:  0 4px 24px rgba(8,145,178,0.12), 0 0 40px rgba(255,60,172,0.05);

  /* ---- Typography ---- */
  --cr-serif:     'Source Serif 4', 'Georgia', serif;
  --cr-display:   'Cinzel', serif;
  --cr-display2:  'Cinzel Decorative', cursive;
  --cr-mono:      'IBM Plex Mono', 'Menlo', monospace;
  --cr-radius:    10px;

  /* ====== GE variable remapping for light theme ====== */
  --neon-cyan: #0891b2;
  --neon-orange: #ea580c;
  --neon-yellow: #b45309;
  --neon-pink: #db2777;
  --neon-violet: #7c3aed;
  --text-muted: #64748b;
  --text-dim: #78879a;
  --text-light: #0f172a;
  --abyss: #f8fafc;
  --navy: #f8fafc;
  --deep-navy: #f8fafc;
  --neon-cyan-soft: rgba(8, 145, 178, 0.4);
  --holo-gradient: linear-gradient(90deg,
    #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700, #ff6a00);
}


/* ==================================================================
   1. KEYFRAMES
   ================================================================== */

@keyframes holo-shimmer {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

@keyframes holo-shimmer-slow {
  0%   { background-position: 0% 50%; }
  100% { background-position: 300% 50%; }
}

@keyframes dawn-breathe {
  0%, 100% { opacity: 0.7; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.02); }
}

@keyframes aurora-drift {
  0%   { transform: translate(0, 0) rotate(0deg); }
  33%  { transform: translate(30px, -20px) rotate(1deg); }
  66%  { transform: translate(-20px, 15px) rotate(-0.5deg); }
  100% { transform: translate(0, 0) rotate(0deg); }
}

@keyframes dot-pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 6px rgba(22,163,74,0.45); }
  50%      { opacity: 0.5; box-shadow: 0 0 3px rgba(22,163,74,0.2); }
}

@keyframes label-border-shimmer {
  0%   { border-color: rgba(0,191,255,0.4); box-shadow: 0 0 14px rgba(0,191,255,0.10), 0 0 28px rgba(255,60,172,0.04); }
  25%  { border-color: rgba(255,60,172,0.35); box-shadow: 0 0 14px rgba(255,60,172,0.08), 0 0 28px rgba(106,90,205,0.04); }
  50%  { border-color: rgba(106,90,205,0.35); box-shadow: 0 0 14px rgba(106,90,205,0.08), 0 0 28px rgba(255,215,0,0.04); }
  75%  { border-color: rgba(255,215,0,0.35); box-shadow: 0 0 14px rgba(255,215,0,0.08), 0 0 28px rgba(0,191,255,0.04); }
  100% { border-color: rgba(0,191,255,0.4); box-shadow: 0 0 14px rgba(0,191,255,0.10), 0 0 28px rgba(255,60,172,0.04); }
}

@keyframes stat-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}


/* ==================================================================
   2. BASE -- Background with Visible Aurora Washes
   ================================================================== */

html {
  scroll-behavior: smooth !important;
  scroll-padding-top: 120px !important;
}

body {
  background: var(--cr-bg) !important;
  color: var(--cr-text) !important;
  font-family: var(--cr-serif) !important;
  line-height: 1.7 !important;
  -webkit-font-smoothing: antialiased !important;
  min-height: 100vh !important;
}

/* ---- Dawn aurora nebula -- PROMINENT pastel cloud washes ---- */
body::before {
  content: '' !important;
  position: fixed !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
  background:
    /* Top-center cyan aurora -- large, vivid */
    radial-gradient(ellipse 130% 55% at 50% -8%,
      rgba(0, 191, 255, 0.18) 0%,
      rgba(0, 212, 255, 0.08) 25%,
      transparent 50%),
    /* Left violet cloud -- bold */
    radial-gradient(ellipse 85% 65% at 5% 18%,
      rgba(124, 58, 237, 0.14) 0%,
      rgba(106, 90, 205, 0.05) 35%,
      transparent 60%),
    /* Right orange/pink cloud -- warm sunrise */
    radial-gradient(ellipse 75% 60% at 95% 8%,
      rgba(255, 106, 0, 0.13) 0%,
      rgba(255, 60, 172, 0.06) 30%,
      transparent 55%),
    /* Mid-left gold wash */
    radial-gradient(ellipse 65% 50% at 20% 45%,
      rgba(255, 215, 0, 0.09) 0%,
      rgba(255, 215, 0, 0.03) 35%,
      transparent 55%),
    /* Mid-right teal wash */
    radial-gradient(ellipse 70% 50% at 80% 50%,
      rgba(0, 245, 204, 0.10) 0%,
      rgba(0, 245, 204, 0.03) 35%,
      transparent 55%),
    /* Bottom center pink/violet haze */
    radial-gradient(ellipse 110% 45% at 50% 100%,
      rgba(255, 60, 172, 0.10) 0%,
      rgba(124, 58, 237, 0.05) 30%,
      transparent 55%),
    /* Center cyan pulse -- breathing heart */
    radial-gradient(ellipse 55% 35% at 55% 35%,
      rgba(0, 191, 255, 0.07) 0%,
      transparent 50%),
    /* Lower-left green accent */
    radial-gradient(ellipse 50% 40% at 15% 75%,
      rgba(0, 245, 204, 0.06) 0%,
      transparent 45%) !important;
  animation: dawn-breathe 18s ease-in-out infinite !important;
  opacity: 1 !important;
}

/* Second aurora layer -- drifting for parallax depth */
body::after {
  content: '' !important;
  position: fixed !important;
  inset: -10% !important;
  pointer-events: none !important;
  z-index: 0 !important;
  background:
    radial-gradient(ellipse 60% 40% at 70% 20%,
      rgba(255, 60, 172, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse 50% 35% at 30% 65%,
      rgba(0, 191, 255, 0.05) 0%, transparent 45%),
    radial-gradient(ellipse 45% 30% at 85% 70%,
      rgba(255, 215, 0, 0.05) 0%, transparent 40%) !important;
  animation: aurora-drift 25s ease-in-out infinite !important;
  opacity: 0.8 !important;
}

/* ---- Kill dark theme decorative elements from site.css ---- */
.stars,
.stars::before,
.stars::after,
.pokeballs,
.pkb,
.shooting-star {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* ---- Scrollbar -- light theme ---- */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--cr-bg); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #94a3b8, #cbd5e1);
  border-radius: 5px;
  border: 2px solid var(--cr-bg);
}
::-webkit-scrollbar-thumb:hover { background: #64748b; }

/* Firefox scrollbar */
* {
  scrollbar-width: thin;
  scrollbar-color: #94a3b8 var(--cr-bg);
}


/* ==================================================================
   3. NAVBAR -- White glass + rainbow bottom border
   ================================================================== */

.cr-nav {
  position: fixed !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 56px !important;
  z-index: 200 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 28px !important;
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(24px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(150%) !important;
  border-bottom: none !important;
  box-shadow: 0 1px 8px rgba(0,0,0,0.06) !important;
}
.cr-nav::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 6s linear infinite !important;
  box-shadow: 0 1px 8px rgba(0,191,255,0.10) !important;
}
.cr-nav-logo {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
}
.cr-nav-logo:hover { filter: brightness(0.8) !important; }
.cr-nav-logo-text {
  font-family: var(--cr-display) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--cr-text) !important;
  letter-spacing: 0.04em !important;
}
.cr-nav-links {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.cr-nav-links a {
  font-family: 'Cinzel', serif !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--cr-text-muted) !important;
  text-decoration: none !important;
  padding: 6px 14px !important;
  background: rgba(0, 0, 0, 0.03) !important;
  border: 1px solid rgba(0, 0, 0, 0.06) !important;
  border-radius: 6px !important;
  transition: all 0.25s ease !important;
}
.cr-nav-links a:hover {
  color: var(--cr-text) !important;
  background: rgba(0, 0, 0, 0.06) !important;
  border-color: rgba(0, 0, 0, 0.12) !important;
}
.cr-nav-hamburger {
  display: none !important;
  width: 44px !important;
  height: 44px !important;
  align-items: center !important;
  justify-content: center !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 0 !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.cr-nav-hamburger span {
  display: block !important;
  width: 18px !important;
  height: 2px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 4s linear infinite !important;
  border-radius: 2px !important;
}
.cr-mobile-nav {
  display: none !important;
  position: fixed !important;
  top: 56px !important;
  left: 0 !important; right: 0 !important;
  flex-direction: column !important;
  padding: 12px 0 !important;
  background: rgba(255, 255, 255, 0.97) !important;
  backdrop-filter: blur(24px) !important;
  -webkit-backdrop-filter: blur(24px) !important;
  border-bottom: 3px solid transparent !important;
  border-image: var(--cr-rainbow) 1 !important;
  z-index: 199 !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.08) !important;
}
.cr-mobile-nav.open { display: flex !important; }
.cr-mobile-nav a {
  display: flex !important;
  align-items: center !important;
  padding: 12px 28px !important;
  font-family: 'Cinzel', serif !important;
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--cr-text-muted) !important;
  text-decoration: none !important;
  transition: all 0.2s !important;
  border-left: 2px solid transparent !important;
}
.cr-mobile-nav a:hover {
  color: var(--cr-cyan) !important;
  background: var(--cr-cyan-dim) !important;
  border-left-color: var(--cr-cyan) !important;
}

.cr-nav-toggle { display: none !important; }

@media (max-width: 768px) {
  .cr-nav-hamburger { display: flex !important; }
  .cr-nav-links { display: none !important; }
}

/* Hide the GE dark navbar if site.css injects one */
body > nav:not(.cr-nav) {
  display: none !important;
}
.nav-cta {
  display: none !important;
}


/* ==================================================================
   4. RESEARCH WRAPPER
   ================================================================== */

.research-wrap {
  position: relative !important;
  z-index: 1 !important;
  max-width: 1400px !important;
  margin: 0 auto !important;
  padding: clamp(60px, 10vw, 80px) clamp(16px, 4vw, 48px) clamp(40px, 6vw, 80px) !important;
}


/* ==================================================================
   5. HEADER -- Gradient title + premium feel
   ================================================================== */

.research-header {
  text-align: center !important;
  margin-bottom: 40px !important;
  padding: 64px 24px 56px !important;
  position: relative !important;
  overflow: visible !important;
}

/* Kill the dark ambient glow from inline styles */
.research-header::before {
  display: none !important;
}

/* Header divider -- full-width rainbow shimmer line */
.research-header::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 6s linear infinite !important;
  border-radius: 2px !important;
  opacity: 1 !important;
  box-shadow:
    0 0 12px rgba(0,191,255,0.18),
    0 0 24px rgba(255,60,172,0.10),
    0 0 40px rgba(106,90,205,0.06) !important;
}

/* ---- Research label badge -- dark fill + rainbow stroke (card-prices style) ---- */
.research-label {
  font-family: var(--cr-mono) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: var(--cr-cyan) !important;
  margin-bottom: 24px !important;
  display: inline-block !important;
  padding: 7px 22px !important;
  border: 1.5px solid rgba(0,191,255,0.35) !important;
  border-radius: 20px !important;
  background: rgba(15, 23, 42, 0.04) !important;
  animation: label-border-shimmer 6s ease-in-out infinite !important;
  position: relative !important;
}

/* ---- Title -- animated holo gradient text fill ---- */
.research-title {
  font-family: var(--cr-display2) !important;
  font-size: clamp(1.8rem, 4vw, 2.8rem) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  margin-bottom: 24px !important;
  letter-spacing: 0.01em !important;
  position: relative !important;
  /* Holo gradient text fill -- animated */
  background: linear-gradient(135deg,
    #0891b2 0%, #7c3aed 18%, #ea580c 35%,
    #db2777 50%, #00bfff 65%, #b45309 80%, #0891b2 100%) !important;
  background-size: 200% 100% !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  animation: holo-shimmer 8s linear infinite !important;
  text-shadow: none !important;
}

.research-subtitle {
  font-family: var(--cr-serif) !important;
  font-size: clamp(1rem, 1.8vw, 1.15rem) !important;
  color: var(--cr-text-muted) !important;
  line-height: 1.7 !important;
  max-width: 1200px !important;
  margin: 0 auto 40px !important;
  font-weight: 400 !important;
}


/* ==================================================================
   6. STATS BAR -- White pills + bold colored top borders + glass
   ================================================================== */

.research-stats {
  display: flex !important;
  justify-content: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin: 0 auto 40px !important;
  max-width: min(960px, 100%) !important;
}

.research-stat {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding: 16px 24px 14px !important;
  background: var(--cr-surface-glass) !important;
  border: 1px solid var(--cr-border) !important;
  border-top: 4px solid var(--cr-stat-1) !important;
  border-radius: var(--cr-radius) !important;
  min-width: 115px !important;
  box-shadow: var(--cr-shadow-sm) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  transition: box-shadow 0.3s, border-color 0.3s, transform 0.25s !important;
  position: relative !important;
}
.research-stat:hover {
  border-color: var(--cr-border-hover) !important;
  box-shadow: var(--cr-shadow-md) !important;
  transform: translateY(-3px) !important;
}
/* Retain colored top-border on hover */
.research-stat:nth-child(1),
.research-stat:nth-child(1):hover { border-top-color: var(--cr-stat-1) !important; }
.research-stat:nth-child(2),
.research-stat:nth-child(2):hover { border-top-color: var(--cr-stat-2) !important; }
.research-stat:nth-child(3),
.research-stat:nth-child(3):hover { border-top-color: var(--cr-stat-3) !important; }
.research-stat:nth-child(4),
.research-stat:nth-child(4):hover { border-top-color: var(--cr-stat-4) !important; }

.research-stat .stat-val {
  font-family: var(--cr-mono) !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: var(--cr-stat-1) !important;
  letter-spacing: -0.01em !important;
  line-height: 1 !important;
}
.research-stat:nth-child(2) .stat-val { color: var(--cr-stat-2) !important; }
.research-stat:nth-child(3) .stat-val { color: var(--cr-stat-3) !important; }
.research-stat:nth-child(4) .stat-val { color: var(--cr-stat-4) !important; }

.research-stat .stat-lbl {
  font-family: var(--cr-mono) !important;
  font-size: 0.58rem !important;
  color: var(--cr-text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  margin-top: 6px !important;
}


/* ==================================================================
   7. RESEARCHER CARD -- Premium glass + rainbow left bar
   ================================================================== */

.researcher-card {
  display: inline-flex !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 28px 36px 28px 44px !important;
  background: var(--cr-surface-glass) !important;
  border: 1px solid var(--cr-border) !important;
  border-left: none !important;
  border-radius: 4px 14px 14px 4px !important;
  text-align: left !important;
  backdrop-filter: blur(14px) saturate(130%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
  box-shadow: var(--cr-shadow-lg) !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Rainbow left bar -- animated vertical shimmer */
.researcher-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 5px !important;
  background: linear-gradient(180deg,
    #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700, #ff6a00) !important;
  background-size: 100% 300% !important;
  animation: holo-shimmer 4s linear infinite !important;
  border-radius: 2px 0 0 2px !important;
}

/* Kill the dark ambient glow orb from inline styles */
.researcher-card::after {
  display: none !important;
}

/* Photo -- rainbow ring glow */
.researcher-photo {
  flex-shrink: 0 !important;
  width: 72px !important;
  height: 72px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  object-position: center top !important;
  border: 2.5px solid var(--cr-cyan) !important;
  box-shadow:
    0 0 0 4px rgba(8,145,178,0.12),
    0 0 18px rgba(0,212,255,0.14),
    0 0 36px rgba(255,60,172,0.06) !important;
}

.researcher-role {
  font-family: var(--cr-mono) !important;
  font-size: 0.56rem !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--cr-cyan) !important;
  display: inline-block !important;
  padding: 3px 10px !important;
  border: 1px solid rgba(8, 145, 178, 0.25) !important;
  border-radius: 3px !important;
  background: var(--cr-cyan-dim) !important;
  margin-bottom: 6px !important;
}

.researcher-card .name {
  font-family: var(--cr-display) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: var(--cr-text) !important;
  letter-spacing: 0.04em !important;
}

.researcher-card .affil {
  font-family: var(--cr-serif) !important;
  font-size: 0.8rem !important;
  color: var(--cr-blue) !important;
  margin-top: 4px !important;
}

.researcher-card .dept {
  font-family: var(--cr-mono) !important;
  font-size: 0.68rem !important;
  color: var(--cr-text-muted) !important;
  margin-top: 3px !important;
}

.researcher-card .researcher-links {
  display: flex !important;
  gap: 14px !important;
  align-items: center !important;
  margin-top: 8px !important;
  flex-wrap: wrap !important;
}
.researcher-card .researcher-links a {
  font-family: var(--cr-mono) !important;
  font-size: 0.66rem !important;
  color: var(--cr-cyan) !important;
  text-decoration: none !important;
  opacity: 0.8 !important;
  transition: opacity 0.2s, color 0.2s !important;
}
.researcher-card .researcher-links a:hover {
  opacity: 1 !important;
  color: var(--cr-blue) !important;
}
.researcher-card .researcher-links .link-sep {
  color: var(--cr-text-faint) !important;
  font-size: 0.5rem !important;
  user-select: none !important;
}


/* ==================================================================
   8. PAPER STATUS -- Green accent badge
   ================================================================== */

.paper-status {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  margin: 20px auto 0 !important;
  padding: 8px 18px !important;
  background: var(--cr-success-dim) !important;
  border: 1px solid rgba(5, 150, 105, 0.22) !important;
  border-radius: 8px !important;
  font-family: var(--cr-mono) !important;
  font-size: 0.68rem !important;
  color: var(--cr-text-secondary) !important;
  letter-spacing: 0.04em !important;
}

.paper-status .ps-dot {
  width: 7px !important;
  height: 7px !important;
  border-radius: 50% !important;
  background: var(--cr-success) !important;
  box-shadow: 0 0 6px rgba(22,163,74,0.40) !important;
  animation: dot-pulse 2s ease-in-out infinite !important;
}

.paper-status .ps-label {
  color: var(--cr-success) !important;
  font-weight: 600 !important;
}

.research-updated {
  font-family: var(--cr-mono) !important;
  font-size: 0.6rem !important;
  color: var(--cr-text-faint) !important;
  letter-spacing: 0.08em !important;
  margin-top: 14px !important;
  opacity: 1 !important;
}


/* ==================================================================
   9. TOC BAR -- Frosted white, rainbow active indicator
   ================================================================== */

.research-toc-bar {
  position: sticky !important;
  top: 56px !important;
  z-index: 20 !important;
  display: flex !important;
  gap: 0 !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: none !important;
  background: rgba(255, 255, 255, 0.92) !important;
  backdrop-filter: blur(16px) saturate(130%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(130%) !important;
  border-bottom: 1px solid var(--cr-border) !important;
  border-top: none !important;
  margin: 0 -48px 40px !important;
  padding: 0 48px !important;
  font-family: var(--cr-mono) !important;
  font-size: 0.68rem !important;
  box-shadow: 0 1px 6px rgba(0,0,0,0.04) !important;
}
.research-toc-bar::-webkit-scrollbar { display: none !important; }

.research-toc-bar a {
  flex-shrink: 0 !important;
  padding: 12px 16px !important;
  color: var(--cr-text-muted) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  border-bottom: 2px solid transparent !important;
  transition: color 0.2s, border-color 0.2s !important;
  letter-spacing: 0.04em !important;
  position: relative !important;
}
.research-toc-bar a:hover {
  color: var(--cr-cyan) !important;
}

/* Active TOC state -- rainbow underline indicator */
.research-toc-bar a.toc-active {
  color: var(--cr-text) !important;
  font-weight: 600 !important;
  border-bottom: none !important;
}
.research-toc-bar a.toc-active::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 4px !important;
  right: 4px !important;
  height: 3px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 4s linear infinite !important;
  border-radius: 1px !important;
}


/* ==================================================================
   10. SECTION CARDS -- White glass + prominent rainbow top border
   ================================================================== */

.research-section {
  margin-bottom: 64px !important;
  padding: 40px 44px !important;
  background: var(--cr-surface-glass) !important;
  border: 1px solid var(--cr-border) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  position: relative !important;
  box-shadow: var(--cr-shadow-card) !important;
  transition: box-shadow 0.3s, transform 0.2s !important;
  overflow: hidden !important;
}
.research-section:hover {
  box-shadow: var(--cr-shadow-md) !important;
  transform: translateY(-1px) !important;
}

/* Top rainbow border -- 4px, PROMINENT, animated shimmer with glow */
.research-section::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 6s linear infinite !important;
  opacity: 1 !important;
  border-radius: 16px 16px 0 0 !important;
  box-shadow: 0 2px 12px rgba(0,191,255,0.10), 0 2px 20px rgba(255,60,172,0.05) !important;
}

/* Section number accent -- faint rainbow watermark */
.research-section[data-num]::after {
  content: attr(data-num) !important;
  position: absolute !important;
  top: 28px !important;
  right: 32px !important;
  font-family: var(--cr-display2) !important;
  font-size: 3.2rem !important;
  font-weight: 700 !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
  -webkit-text-fill-color: transparent !important;
  opacity: 0.10 !important;
  line-height: 1 !important;
  pointer-events: none !important;
  animation: holo-shimmer-slow 12s linear infinite !important;
}

/* ---- h2 -- Cinzel + FULL rainbow gradient underline ---- */
.research-section h2 {
  font-family: var(--cr-display) !important;
  font-size: clamp(1.15rem, 2.2vw, 1.5rem) !important;
  font-weight: 700 !important;
  color: var(--cr-text) !important;
  margin-bottom: 24px !important;
  padding-bottom: 14px !important;
  border-bottom: none !important;
  letter-spacing: 0.04em !important;
  position: relative !important;
  display: inline-block !important;
}
/* Rainbow underline on every h2 -- prominent width, visible, animated */
.research-section h2::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: clamp(60px, 30%, 140px) !important;
  height: 3px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 5s linear infinite !important;
  border-radius: 2px !important;
  box-shadow: 0 1px 6px rgba(0,191,255,0.08) !important;
}

/* ---- h3 -- cyan color + rainbow-accent left border ---- */
.research-section h3 {
  font-family: var(--cr-display) !important;
  font-size: clamp(0.92rem, 1.8vw, 1.1rem) !important;
  font-weight: 600 !important;
  color: var(--cr-cyan) !important;
  margin: 32px 0 14px !important;
  padding-left: 16px !important;
  border-left: 3px solid transparent !important;
  border-image: linear-gradient(180deg, var(--cr-orange), var(--cr-pink), var(--cr-violet)) 1 !important;
  border-image-slice: 1 !important;
}

/* ---- Body text ---- */
.research-section p,
.research-section li {
  font-family: var(--cr-serif) !important;
  font-size: clamp(0.88rem, 1.4vw, 1.02rem) !important;
  color: var(--cr-text-secondary) !important;
  line-height: 1.85 !important;
  margin-bottom: 16px !important;
}

.research-section ul,
.research-section ol {
  padding-left: 28px !important;
  margin-bottom: 20px !important;
}
.research-section li {
  margin-bottom: 10px !important;
  padding-left: 4px !important;
}
.research-section li::marker {
  color: var(--cr-cyan) !important;
}
.research-section ol li::marker {
  color: var(--cr-orange) !important;
  font-weight: 700 !important;
}

/* ---- Links ---- */
.research-section a {
  color: var(--cr-cyan) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}
.research-section a:hover {
  color: var(--cr-blue) !important;
  text-decoration: underline !important;
}

/* ---- Strong/em ---- */
.research-section strong {
  color: var(--cr-text) !important;
}
.research-section em {
  color: var(--cr-text-secondary) !important;
  font-style: italic !important;
}


/* ==================================================================
   11. HIGHLIGHT BOXES -- Rainbow gradient wash + left accent
   ================================================================== */

.research-highlight {
  background: linear-gradient(135deg,
    rgba(8,145,178,0.06),
    rgba(124,58,237,0.04),
    rgba(255,106,0,0.03)) !important;
  border-left: 4px solid transparent !important;
  border-image: linear-gradient(180deg, var(--cr-cyan), var(--cr-violet), var(--cr-orange)) 1 !important;
  border-image-slice: 1 !important;
  border-right: 1px solid rgba(8, 145, 178, 0.10) !important;
  border-top: 1px solid rgba(8, 145, 178, 0.08) !important;
  border-bottom: 1px solid rgba(8, 145, 178, 0.08) !important;
  padding: 24px 28px !important;
  margin: 28px 0 !important;
  border-radius: 0 12px 12px 0 !important;
  box-shadow: 0 2px 18px rgba(8, 145, 178, 0.07) !important;
}
.research-highlight p {
  margin-bottom: 0 !important;
  font-size: 0.92rem !important;
}


/* ==================================================================
   12. DATA TABLES -- Colored header tint + hover accents
   ================================================================== */

.research-table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  margin: 20px 0 28px !important;
  font-family: var(--cr-mono) !important;
  font-size: 0.78rem !important;
  border-radius: var(--cr-radius) !important;
  overflow: hidden !important;
  border: 1px solid var(--cr-border) !important;
  box-shadow: var(--cr-shadow-sm) !important;
}

/* Header row -- visible rainbow tint background */
.research-table th {
  text-align: left !important;
  padding: 13px 16px !important;
  background: linear-gradient(135deg,
    rgba(8,145,178,0.08),
    rgba(124,58,237,0.04),
    rgba(255,106,0,0.03)) !important;
  color: var(--cr-text-secondary) !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  font-size: 0.68rem !important;
  border-bottom: 2px solid rgba(8,145,178,0.14) !important;
}

.research-table td {
  padding: 12px 16px !important;
  color: var(--cr-text-secondary) !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.04) !important;
  background: var(--cr-surface) !important;
  transition: background 0.2s !important;
}

/* Alternating row tint */
.research-table tbody tr:nth-child(even) td {
  background: rgba(248, 250, 252, 0.7) !important;
}

.research-table tbody tr:hover td {
  background: rgba(8, 145, 178, 0.05) !important;
}


/* ==================================================================
   13. STATUS BADGES
   ================================================================== */

.status {
  display: inline-block !important;
  padding: 3px 10px !important;
  border-radius: 4px !important;
  font-size: 0.64rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

.status-active {
  background: rgba(5, 150, 105, 0.10) !important;
  color: #047857 !important;
  border: 1px solid rgba(5, 150, 105, 0.25) !important;
}

.status-pending {
  background: rgba(217, 119, 6, 0.10) !important;
  color: #b45309 !important;
  border: 1px solid rgba(217, 119, 6, 0.25) !important;
}

.status-planned {
  background: rgba(124, 58, 237, 0.08) !important;
  color: #6d28d9 !important;
  border: 1px solid rgba(124, 58, 237, 0.25) !important;
}


/* ==================================================================
   14. TIMELINE -- Rainbow spine + colored dot markers
   ================================================================== */

.timeline {
  position: relative !important;
  padding-left: 36px !important;
  margin: 24px 0 !important;
}

/* Rainbow gradient spine -- visible, with glow */
.timeline::before {
  content: '' !important;
  position: absolute !important;
  left: 10px !important;
  top: 4px !important;
  bottom: 4px !important;
  width: 3px !important;
  background: linear-gradient(180deg,
    #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700) !important;
  border-radius: 2px !important;
  box-shadow: 0 0 8px rgba(0,191,255,0.12), 0 0 16px rgba(255,60,172,0.06) !important;
}

.timeline-item {
  position: relative !important;
  margin-bottom: 28px !important;
  padding: 14px 20px !important;
  background: var(--cr-surface) !important;
  border-radius: 8px !important;
  border: 1px solid var(--cr-border) !important;
  transition: all 0.25s !important;
  box-shadow: var(--cr-shadow-sm) !important;
}
.timeline-item:hover {
  border-color: rgba(8, 145, 178, 0.20) !important;
  box-shadow: var(--cr-shadow-md) !important;
  transform: translateX(3px) !important;
}

/* Timeline dots -- hollow by default */
.timeline-item::before {
  content: '' !important;
  position: absolute !important;
  left: -32px !important;
  top: 16px !important;
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  background: var(--cr-bg) !important;
  border: 2.5px solid var(--cr-cyan) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.85), 0 0 8px rgba(8,145,178,0.18) !important;
}

/* Completed timeline items -- filled with glow */
.timeline-item.done::before {
  background: var(--cr-cyan) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.85), 0 0 12px rgba(8,145,178,0.35) !important;
}
/* Color rotation for completed dots */
.timeline-item.done:nth-child(2)::before {
  background: var(--cr-orange) !important;
  border-color: var(--cr-orange) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.85), 0 0 12px rgba(234,88,12,0.30) !important;
}
.timeline-item.done:nth-child(3)::before {
  background: var(--cr-violet) !important;
  border-color: var(--cr-violet) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.85), 0 0 12px rgba(124,58,237,0.30) !important;
}
.timeline-item.done:nth-child(4)::before {
  background: var(--cr-gold) !important;
  border-color: var(--cr-gold) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.85), 0 0 12px rgba(180,83,9,0.30) !important;
}

.timeline-date {
  font-family: var(--cr-mono) !important;
  font-size: 0.7rem !important;
  color: var(--cr-cyan) !important;
  opacity: 1 !important;
  font-weight: 600 !important;
}

.timeline-desc {
  font-family: var(--cr-serif) !important;
  font-size: 0.9rem !important;
  color: var(--cr-text-secondary) !important;
  line-height: 1.6 !important;
  margin-top: 4px !important;
}


/* ==================================================================
   15. CITATION BLOCK -- Code-block with rainbow left accent
   ================================================================== */

.cite-block {
  background: linear-gradient(135deg, #f0f4f8, #eef2f7) !important;
  border: 1px solid rgba(8,145,178,0.14) !important;
  border-left: 4px solid transparent !important;
  border-image: linear-gradient(180deg, var(--cr-cyan), var(--cr-violet)) 1 !important;
  border-image-slice: 1 !important;
  border-radius: 0 8px 8px 0 !important;
  padding: 22px 26px !important;
  margin: 24px 0 !important;
  position: relative !important;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.03), var(--cr-shadow-sm) !important;
}

.cite-block pre {
  font-family: var(--cr-mono) !important;
  font-size: 0.72rem !important;
  color: var(--cr-text-secondary) !important;
  line-height: 1.7 !important;
  white-space: pre-wrap !important;
  word-break: break-all !important;
  margin: 0 !important;
}

.cite-block .cite-copy {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  background: var(--cr-surface) !important;
  border: 1px solid var(--cr-border) !important;
  color: var(--cr-cyan) !important;
  font-family: var(--cr-mono) !important;
  font-size: 0.6rem !important;
  padding: 4px 10px !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  letter-spacing: 0.06em !important;
}
.cite-block .cite-copy:hover {
  background: var(--cr-cyan-dim) !important;
  border-color: rgba(8, 145, 178, 0.25) !important;
  color: var(--cr-cyan) !important;
  box-shadow: 0 0 10px rgba(8,145,178,0.12) !important;
}


/* ==================================================================
   16. PLATFORM GRID -- Cards with colored regions + accent hover
   ================================================================== */

.platform-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)) !important;
  gap: 12px !important;
  margin: 20px 0 28px !important;
}

.platform-card {
  padding: 16px 20px !important;
  background: var(--cr-surface) !important;
  border: 1px solid var(--cr-border) !important;
  border-left: 3px solid transparent !important;
  border-radius: 4px 8px 8px 4px !important;
  transition: all 0.25s !important;
  position: relative !important;
}
.platform-card:hover {
  border-left-color: var(--cr-orange) !important;
  border-color: rgba(234, 88, 12, 0.18) !important;
  border-left-color: var(--cr-orange) !important;
  box-shadow: var(--cr-shadow-md), 0 0 0 1px rgba(234, 88, 12, 0.06) !important;
  transform: translateY(-2px) !important;
}

/* Color-cycle left border by position */
.platform-card:nth-child(3n+1):hover { border-left-color: var(--cr-cyan) !important; }
.platform-card:nth-child(3n+2):hover { border-left-color: var(--cr-orange) !important; }
.platform-card:nth-child(3n+3):hover { border-left-color: var(--cr-violet) !important; }

/* Region label -- colored badge */
.platform-card .pc-region {
  font-family: var(--cr-mono) !important;
  font-size: 0.58rem !important;
  color: var(--cr-orange) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
  padding: 2px 8px !important;
  background: var(--cr-orange-dim) !important;
  border-radius: 3px !important;
  display: inline-block !important;
}

.platform-card .pc-name {
  font-family: var(--cr-serif) !important;
  font-size: 0.88rem !important;
  color: var(--cr-text) !important;
  margin-bottom: 3px !important;
  font-weight: 600 !important;
}

.platform-card .pc-type {
  font-family: var(--cr-mono) !important;
  font-size: 0.6rem !important;
  color: var(--cr-text-muted) !important;
}


/* ==================================================================
   17. PIPELINE FLOW DIAGRAM -- Inline style overrides for light bg
   ================================================================== */

/* Pipeline stage cards -- override dark backgrounds from inline styles */
.research-section div[style*="border-radius:8px"] {
  background: var(--cr-surface) !important;
  border-color: var(--cr-border) !important;
}

/* Pipeline stage descriptions -- override white/light text for dark bg */
.research-section div[style*="color:rgba(255,255,255"] {
  color: var(--cr-text-muted) !important;
}

/* Arrow characters between stages */
.research-section div[style*="display:flex"] > span[style] {
  opacity: 0.9 !important;
}

/* Pipeline stage labels with inline color -- keep them visible */
.research-section div[style*="border-radius:8px"] div[style*="color:var(--neon-cyan)"],
.research-section div[style*="border-radius:8px"] div[style*="color:var(--neon-orange)"],
.research-section div[style*="border-radius:8px"] div[style*="color:var(--neon-yellow)"],
.research-section div[style*="border-radius:8px"] div[style*="color:#4ade80"],
.research-section div[style*="border-radius:8px"] div[style*="color:#a5b4fc"],
.research-section div[style*="border-radius:8px"] div[style*="color:rgba(255,255,255,0.5)"] {
  font-weight: 600 !important;
}

/* Override the final archive stage text color */
.research-section div[style*="border-radius:8px"] div[style*="color:rgba(255,255,255,0.5)"] {
  color: var(--cr-text-muted) !important;
}

/* Pipeline stage description text */
.research-section div[style*="border-radius:8px"] div[style*="font-family:'Source Serif 4'"][style*="color:rgba(255,255,255"] {
  color: var(--cr-text-secondary) !important;
}


/* ==================================================================
   18. INLINE STYLE OVERRIDES (from HTML)
   ================================================================== */

/* Links with inline color:var(--neon-cyan) */
.research-section a[style*="neon-cyan"],
.research-section a[style*="color:var"] {
  color: var(--cr-cyan) !important;
}
.research-section a[style*="neon-cyan"]:hover,
.research-section a[style*="color:var"]:hover {
  color: var(--cr-blue) !important;
}

/* Override any inline white text from dark-theme markup */
div[style*="color:rgba(255,255,255"] {
  color: var(--cr-text-muted) !important;
}

/* Pipeline background overrides -- turn dark fill to light tint */
div[style*="background:rgba(0,245,255,0.06)"] {
  background: rgba(8,145,178,0.06) !important;
  border-color: rgba(8,145,178,0.18) !important;
}
div[style*="background:rgba(255,106,0,0.06)"] {
  background: rgba(234,88,12,0.06) !important;
  border-color: rgba(234,88,12,0.18) !important;
}
div[style*="background:rgba(255,215,0,0.06)"] {
  background: rgba(180,83,9,0.06) !important;
  border-color: rgba(180,83,9,0.18) !important;
}
div[style*="background:rgba(74,222,128,0.06)"] {
  background: rgba(22,163,74,0.06) !important;
  border-color: rgba(22,163,74,0.18) !important;
}
div[style*="background:rgba(106,90,205,0.06)"] {
  background: rgba(124,58,237,0.06) !important;
  border-color: rgba(124,58,237,0.18) !important;
}
div[style*="background:rgba(255,255,255,0.03)"] {
  background: rgba(100,116,139,0.06) !important;
  border-color: rgba(100,116,139,0.18) !important;
}


/* ==================================================================
   19. FOOTER -- Light bg + rainbow top border
   ================================================================== */

/* Hide GE dark footer if present */
body > footer:not(.cr-footer) {
  display: none !important;
}
.research-wrap + footer {
  margin-top: 0 !important;
}

.cr-footer {
  background: #f0f3f8 !important;
  border-top: none !important;
  padding: clamp(24px, 4vw, 40px) clamp(16px, 4vw, 48px) !important;
  text-align: center !important;
  font-family: var(--cr-serif) !important;
  color: var(--cr-text-muted) !important;
  position: relative !important;
}

/* Rainbow top border on footer -- PROMINENT with glow */
.cr-footer::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: var(--cr-rainbow) !important;
  background-size: 200% 100% !important;
  animation: holo-shimmer 6s linear infinite !important;
  box-shadow:
    0 0 10px rgba(0,191,255,0.12),
    0 0 20px rgba(255,60,172,0.06) !important;
}

.cr-footer-inner {
  max-width: 1100px !important;
  margin: 0 auto !important;
}

.cr-footer-title {
  font-family: var(--cr-display) !important;
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: var(--cr-text) !important;
  margin-bottom: 4px !important;
  letter-spacing: 0.03em !important;
}

.cr-footer-byline {
  font-size: 0.8rem !important;
  color: var(--cr-text-muted) !important;
  margin-bottom: 16px !important;
}

.cr-footer-links {
  display: flex !important;
  justify-content: center !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  margin-bottom: 16px !important;
}

.cr-footer-links a {
  font-family: var(--cr-mono) !important;
  font-size: 0.72rem !important;
  color: var(--cr-cyan) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}
.cr-footer-links a:hover {
  color: var(--cr-blue) !important;
  text-decoration: underline !important;
}

.cr-footer-sep {
  color: #cbd5e1 !important;
  font-size: 0.6rem !important;
  user-select: none !important;
}

.cr-footer-copy {
  font-family: var(--cr-mono) !important;
  font-size: 0.64rem !important;
  color: var(--cr-text-faint) !important;
}


/* ==================================================================
   20. GLOBAL LINK STYLE
   ================================================================== */

a {
  color: var(--cr-cyan);
}
a:hover {
  color: var(--cr-blue);
}


/* ==================================================================
   21. SELECTION HIGHLIGHT
   ================================================================== */

::selection {
  background: rgba(8, 145, 178, 0.20) !important;
  color: var(--cr-text) !important;
}
::-moz-selection {
  background: rgba(8, 145, 178, 0.20) !important;
  color: var(--cr-text) !important;
}


/* ==================================================================
   22. FOCUS VISIBLE -- Double-ring pattern (matches Card Prices)
   ================================================================== */

:focus-visible {
  outline: none !important;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--cr-cyan) !important;
}


/* ==================================================================
   22b. PIPELINE FLOW DIAGRAM -- Responsive grid layout
   ================================================================== */

.pipeline-flow {
  display: flex !important;
  justify-content: center !important;
  margin: clamp(16px, 3vw, 28px) 0 !important;
}

.pipeline-stages {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: clamp(4px, 1vw, 8px) !important;
  align-items: center !important;
  justify-content: center !important;
}

.pipeline-stage {
  padding: clamp(8px, 1.5vw, 10px) clamp(10px, 2vw, 16px) !important;
  border-radius: 8px !important;
  text-align: center !important;
}

.pipeline-stage-label {
  font-family: var(--cr-mono) !important;
  font-size: clamp(0.55rem, 1vw, 0.65rem) !important;
  letter-spacing: 0.08em !important;
}

.pipeline-stage-desc {
  font-family: var(--cr-serif) !important;
  font-size: clamp(0.68rem, 1.2vw, 0.78rem) !important;
  color: var(--cr-text-muted) !important;
  margin-top: 2px !important;
}

.pipeline-arrow {
  font-size: clamp(0.9rem, 1.5vw, 1.2rem) !important;
}

@media (max-width: 768px) {
  .pipeline-stages {
    flex-direction: column !important;
  }
  .pipeline-arrow {
    transform: rotate(90deg) !important;
  }
}


/* ==================================================================
   22c. PLATFORM CARD STATUS -- Responsive styling
   ================================================================== */

.pc-status {
  font-family: var(--cr-mono) !important;
  font-size: clamp(0.6rem, 1.2vw, 0.7rem) !important;
  color: var(--cr-orange) !important;
  margin-top: 4px !important;
}


/* ==================================================================
   23. RESPONSIVE -- 1024px
   ================================================================== */

@media (max-width: 1024px) {
  /* research-wrap and footer padding handled by clamp() in base rules */
  .cr-nav-inner { padding: 0 clamp(16px, 3vw, 32px) !important; }
}


/* ==================================================================
   24. RESPONSIVE -- 768px (Tablet / Large phone)
   ================================================================== */

@media (max-width: 768px) {
  /* research-wrap padding handled by clamp() in base rule */

  .research-header {
    padding: clamp(24px, 5vw, 36px) clamp(4px, 1vw, 8px) clamp(28px, 5vw, 40px) !important;
  }

  .research-title {
    font-size: clamp(1.4rem, 5vw, 2rem) !important;
  }

  .research-stats {
    gap: 6px !important;
    padding: 0 4px !important;
    flex-wrap: nowrap !important;
  }
  .research-stat {
    min-width: 0 !important;
    flex: 1 1 0 !important;
    padding: 10px 4px 8px !important;
    border-top-width: 3px !important;
  }
  .research-stat .stat-val { font-size: 0.88rem !important; }
  .research-stat .stat-lbl { font-size: clamp(0.55rem, 1.2vw, 0.58rem) !important; letter-spacing: 0.06em !important; }

  .research-toc-bar {
    margin: 0 -16px 32px !important;
    padding: 0 16px !important;
    font-size: 0.62rem !important;
  }
  .research-toc-bar a { padding: 10px 12px !important; }

  .research-section {
    padding: clamp(20px, 4vw, 28px) clamp(16px, 3vw, 24px) !important;
    margin-bottom: clamp(28px, 5vw, 40px) !important;
    overflow: visible !important;
  }

  /* Researcher card -- stack vertically on mobile */
  .researcher-card {
    flex-direction: column !important;
    text-align: center !important;
    padding: 24px 20px !important;
    border-left: 1px solid var(--cr-border) !important;
    border-radius: 14px !important;
    border-top: none !important;
    border-image: none !important;
  }
  /* Rainbow bar moves to top on mobile */
  .researcher-card::before {
    top: 0 !important;
    left: 15% !important;
    right: 15% !important;
    bottom: auto !important;
    width: auto !important;
    height: 4px !important;
    background: linear-gradient(90deg,
      #ff6a00, #ff3cac, #6a5acd, #00bfff, #00f5cc, #ffd700) !important;
    background-size: 200% 100% !important;
    animation: holo-shimmer 5s linear infinite !important;
    border-radius: 0 0 2px 2px !important;
  }

  .researcher-photo { width: 56px !important; height: 56px !important; }

  .research-table { font-size: 0.65rem !important; }
  .research-table th,
  .research-table td { padding: 8px 10px !important; }

  .research-section[data-num]::after { display: none !important; }

  .timeline { padding-left: 28px !important; }
  .timeline-item { padding: 10px 14px !important; }

  /* ---- Navbar mobile ---- */
  .cr-nav-inner { padding: 0 16px !important; }
  .cr-nav-toggle { display: block !important; }
  .cr-nav-links {
    display: none !important;
    position: absolute !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    flex-direction: column !important;
    background: rgba(255,255,255,0.97) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    border-bottom: 1px solid #e2e8f0 !important;
    padding: 8px 0 !important;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08) !important;
  }
  .cr-nav-links.cr-nav-open { display: flex !important; }
  .cr-nav-links a { padding: 12px 24px !important; border-radius: 0 !important; }

  /* Footer padding handled by clamp() in base rule */

  /* ---- Platform grid -- single column ---- */
  .platform-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  /* Aurora washes -- slightly reduced on mobile for perf */
  body::after {
    opacity: 0.5 !important;
  }
}


/* ==================================================================
   25. RESPONSIVE -- 480px (Small phone)
   ================================================================== */

@media (max-width: 600px) {
  /* research-wrap padding handled by clamp() in base rule */
  input, select, textarea { font-size: 16px !important; }
}
@media (max-width: 480px) {
  /* Header, section, card padding handled by clamp() in 768px breakpoint */
  .research-title { font-size: clamp(1.2rem, 4vw, 1.3rem) !important; }
  .research-highlight { padding: clamp(14px, 3vw, 18px) clamp(16px, 3vw, 20px) !important; }
  .research-stat .stat-val { font-size: clamp(0.7rem, 2vw, 0.78rem) !important; }

  /* Reduce aurora bloom on small screens */
  body::before {
    opacity: 0.8 !important;
  }
  body::after {
    display: none !important;
  }
}


/* ==================================================================
   26. PRINT STYLESHEET
   ================================================================== */

@media print {
  /* Kill all ambient effects */
  body::before,
  body::after,
  .stars,
  .pokeballs,
  .shooting-star {
    display: none !important;
  }

  body {
    background: #fff !important;
    color: #000 !important;
    font-size: 11pt !important;
  }

  /* Hide navigation, TOC, footer */
  .cr-nav,
  .research-toc-bar,
  .cr-footer {
    display: none !important;
  }

  /* Wrapper -- full width */
  .research-wrap {
    max-width: 100% !important;
    padding: 0 !important;
  }

  /* Section cards -- no shadow, clean borders, page-break control */
  .research-section {
    box-shadow: none !important;
    border: 1px solid #ccc !important;
    border-radius: 0 !important;
    break-inside: avoid !important;
    page-break-inside: avoid !important;
    margin-bottom: 24px !important;
    padding: 20px 24px !important;
    backdrop-filter: none !important;
    overflow: visible !important;
    transform: none !important;
  }

  /* Title -- solid dark for print */
  .research-title {
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    color: #000 !important;
    -webkit-text-fill-color: #000 !important;
    animation: none !important;
  }

  /* Rainbow dividers -- hide for print */
  .research-section::before,
  .research-header::after,
  .cr-footer::before,
  .cr-nav::after {
    display: none !important;
  }

  /* h2 underline -- solid black for print */
  .research-section h2::after {
    background: #000 !important;
    height: 2px !important;
    animation: none !important;
    box-shadow: none !important;
  }

  /* All text -- black */
  .research-section h2,
  .research-section h3,
  .research-section p,
  .research-section li,
  .research-subtitle,
  .researcher-card .name,
  .researcher-card .affil,
  .researcher-card .dept,
  .timeline-desc,
  .cite-block pre,
  .research-table td,
  .platform-card .pc-name {
    color: #000 !important;
  }

  /* Subheads */
  .research-section h3 {
    color: #333 !important;
    border-left-color: #666 !important;
    border-image: none !important;
  }

  /* Links -- show URL */
  a[href^="http"]::after {
    content: " (" attr(href) ")" !important;
    font-size: 0.7em !important;
    color: #666 !important;
  }
  a {
    color: #000 !important;
    text-decoration: underline !important;
  }

  /* Researcher card */
  .researcher-card {
    box-shadow: none !important;
    border: 1px solid #ccc !important;
    break-inside: avoid !important;
    backdrop-filter: none !important;
  }
  .researcher-card::before { display: none !important; }

  /* Tables */
  .research-table {
    border: 1px solid #999 !important;
    box-shadow: none !important;
  }
  .research-table th {
    background: #eee !important;
    color: #000 !important;
    border-bottom: 1px solid #999 !important;
  }
  .research-table td {
    border-bottom: 1px solid #ddd !important;
  }

  /* Timeline */
  .timeline::before {
    background: #999 !important;
    box-shadow: none !important;
  }
  .timeline-item {
    box-shadow: none !important;
    transform: none !important;
  }
  .timeline-item::before {
    border-color: #666 !important;
    background: #fff !important;
    box-shadow: none !important;
  }
  .timeline-item.done::before {
    background: #666 !important;
    box-shadow: none !important;
  }
  .timeline-date {
    color: #333 !important;
  }

  /* Status badges -- high contrast B&W */
  .status-active {
    background: #e6f9f0 !important;
    color: #000 !important;
    border-color: #999 !important;
  }
  .status-pending {
    background: #fff8e6 !important;
    color: #000 !important;
    border-color: #999 !important;
  }
  .status-planned {
    background: #f3f0ff !important;
    color: #000 !important;
    border-color: #999 !important;
  }

  /* Highlight boxes */
  .research-highlight {
    background: #f5f5f5 !important;
    border-left: 3px solid #666 !important;
    border-image: none !important;
    box-shadow: none !important;
  }

  /* Citation block */
  .cite-block {
    background: #f5f5f5 !important;
    border: 1px solid #ccc !important;
    border-left: 3px solid #666 !important;
    border-image: none !important;
    box-shadow: none !important;
  }
  .cite-block .cite-copy { display: none !important; }

  /* Platform cards */
  .platform-card {
    border: 1px solid #ccc !important;
    break-inside: avoid !important;
    transform: none !important;
  }

  /* Paper status */
  .paper-status .ps-dot {
    background: #333 !important;
    box-shadow: none !important;
    animation: none !important;
  }

  /* Kill all animations */
  *,
  *::before,
  *::after {
    animation: none !important;
    transition: none !important;
  }

  /* Photo */
  .researcher-photo {
    border: 1px solid #999 !important;
    box-shadow: none !important;
  }

  /* Label badge */
  .research-label {
    border-color: #999 !important;
    color: #333 !important;
    background: transparent !important;
    animation: none !important;
    box-shadow: none !important;
  }

  /* Section number watermark */
  .research-section[data-num]::after {
    display: none !important;
  }

  /* Stat pills */
  .research-stat {
    border: 1px solid #ccc !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }
  .research-stat .stat-val {
    color: #000 !important;
  }
}


/* ==================================================================
   27. ACCESSIBILITY -- Reduced Motion
   ================================================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }

  /* Title falls back to static dark text */
  .research-title {
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    color: var(--cr-text) !important;
    -webkit-text-fill-color: var(--cr-text) !important;
  }

  /* Rainbow bars become static (still visible, no shimmer) */
  .research-section::before,
  .research-header::after,
  .cr-nav::after,
  .cr-footer::before,
  .research-section h2::after,
  .research-toc-bar a.toc-active::after {
    animation: none !important;
    background-size: 100% 100% !important;
  }

  /* Aurora clouds become static */
  body::before {
    animation: none !important;
    opacity: 0.85 !important;
  }
  body::after {
    animation: none !important;
    opacity: 0.6 !important;
  }

  /* Section watermark static */
  .research-section[data-num]::after {
    animation: none !important;
  }
}


/* ==================================================================
   28. HIGH CONTRAST / FORCED COLORS
   ================================================================== */

@media (forced-colors: active) {
  /* Borders use system color */
  .research-section,
  .researcher-card,
  .research-stat,
  .timeline-item,
  .platform-card,
  .cite-block,
  .research-highlight,
  .cr-nav,
  .cr-footer {
    border: 1px solid ButtonText !important;
  }

  /* Rainbow lines become solid system color */
  .research-section h2::after,
  .research-header::after,
  .research-section::before,
  .cr-nav::after,
  .cr-footer::before,
  .research-toc-bar a.toc-active::after {
    background: ButtonText !important;
    box-shadow: none !important;
  }

  /* Title uses system color */
  .research-title {
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    color: ButtonText !important;
    -webkit-text-fill-color: ButtonText !important;
  }

  /* Label badge uses system color */
  .research-label {
    border-color: ButtonText !important;
    color: ButtonText !important;
    box-shadow: none !important;
  }

  /* Timeline spine uses system color */
  .timeline::before {
    background: ButtonText !important;
    box-shadow: none !important;
  }

  /* Timeline dots */
  .timeline-item::before {
    border-color: ButtonText !important;
    box-shadow: none !important;
  }
  .timeline-item.done::before {
    background: ButtonText !important;
    box-shadow: none !important;
  }

  /* Stats */
  .research-stat {
    border-color: ButtonText !important;
    box-shadow: none !important;
  }

  /* Status badges */
  .status {
    border-color: ButtonText !important;
  }

  /* Kill aurora washes */
  body::before,
  body::after {
    display: none !important;
  }

  /* Links */
  a {
    color: LinkText !important;
  }

  /* Photo */
  .researcher-photo {
    border-color: ButtonText !important;
    box-shadow: none !important;
  }

  /* Researcher card left bar */
  .researcher-card::before {
    background: ButtonText !important;
  }

  /* h3 left border */
  .research-section h3 {
    border-image: none !important;
    border-left-color: ButtonText !important;
  }

  /* Highlight boxes */
  .research-highlight {
    border-image: none !important;
    border-left-color: ButtonText !important;
  }

  /* Citation block */
  .cite-block {
    border-image: none !important;
    border-left-color: ButtonText !important;
  }
}
