@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  /* Light corporate palette */
  --bg: #f4f5f7;
  --bg-page: #ffffff;
  --bg-card: #ffffff;
  --bg-card-hover: #f8f9fb;
  --bg-subtle: #f0f1f4;
  --bg-muted: #e8eaed;

  --text: #1a1a2e;
  --text-secondary: #3d3d56;
  --text-muted: #6b6b80;
  --text-light: #9898ab;

  --accent: #0d9464;
  --accent-bg: rgba(13,148,100,.08);
  --cobalt: #1A59B3;
  --cobalt-bg: rgba(26,89,179,.08);
  --purple: #7c3aed;
  --purple-bg: rgba(124,58,237,.08);
  --orange: #d97706;
  --orange-bg: rgba(217,119,6,.08);
  --red: #dc2626;
  --red-bg: rgba(220,38,38,.06);
  --cyan: #0891b2;

  --border: #e0e2e8;
  --border-strong: #c8cbd2;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.08);

  --font-display: 'Outfit', sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --ease: cubic-bezier(.16,1,.3,1);
  --radius: 14px;
  --radius-sm: 10px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  line-height: 1.6;
}

/* ============================================
   NAV TOC
   ============================================ */
.toc-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  background: rgba(255,255,255,.88);
  border-bottom: 1px solid var(--border);
  padding: 0 32px;
  display: flex; align-items: center; height: 52px; gap: 8px;
  transition: transform .4s var(--ease);
}
.toc-nav.hidden { transform: translateY(-100%); }
.toc-logo {
  font-family: var(--font-display); font-weight: 800; font-size: .95rem;
  color: var(--accent); margin-right: 20px; letter-spacing: -.03em; flex-shrink: 0;
}
.toc-links { display: flex; gap: 2px; overflow-x: auto; flex: 1; }
.toc-links::-webkit-scrollbar { display: none; }
.toc-link {
  font-size: .72rem; font-weight: 500; color: var(--text-muted);
  text-decoration: none; padding: 6px 12px; border-radius: 8px;
  white-space: nowrap; transition: all .25s;
}
.toc-link:hover { color: var(--text); background: var(--bg-subtle); }
.toc-link.active { color: var(--accent); background: var(--accent-bg); font-weight: 600; }

/* ============================================
   SLIDE SYSTEM
   ============================================ */
.slide {
  width: 794px; height: 1123px; max-height: 1123px;
  display: flex; flex-direction: column; justify-content: flex-start;
  padding: 48px 52px 52px;
  position: relative; overflow: hidden;
  background: var(--bg-page);
  margin: 0 auto;
}
.slide + .slide { border-top: 1px solid var(--border); }

.slide-number {
  position: absolute; bottom: 24px; right: 48px;
  font-family: var(--font-display); font-size: .82rem; font-weight: 600;
  color: var(--text-light); letter-spacing: .12em;
}

.slide-brand {
  position: absolute; bottom: 24px; left: 48px;
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-size: .82rem; font-weight: 700;
  color: var(--text-light); letter-spacing: -.02em;
}
.slide-brand::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}

/* Grid bg — subtle dots on light */
.grid-bg {
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(0,0,0,.03) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
  pointer-events: none;
}

/* Orbs — light accents */
.orb {
  position: absolute; border-radius: 50%; filter: blur(100px); pointer-events: none;
  animation: float 25s ease-in-out infinite;
}
.orb-accent { background: radial-gradient(circle, rgba(13,148,100,.06) 0%, transparent 70%); width: 500px; height: 500px; }
.orb-purple { background: radial-gradient(circle, rgba(124,58,237,.05) 0%, transparent 70%); width: 400px; height: 400px; }
.orb-cobalt { background: radial-gradient(circle, rgba(26,89,179,.05) 0%, transparent 70%); width: 450px; height: 450px; }

@keyframes float {
  0%, 100% { transform: translateY(0) scale(1); }
  50% { transform: translateY(-20px) scale(1.03); }
}

/* ============================================
   TYPOGRAPHY
   ============================================ */
.slide-label {
  font-family: var(--font-body); font-size: .82rem; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase; color: var(--accent);
  display: flex; align-items: center; gap: 12px; margin-bottom: 12px;
}
.slide-label::before { content: ''; width: 28px; height: 2px; background: var(--accent); border-radius: 1px; }
.slide-label i { font-size: .72rem; }

.slide-title {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 800; letter-spacing: -.04em; line-height: 1.15;
  color: var(--text); margin-bottom: 10px;
}
.slide-title .accent { color: var(--accent); }
.slide-title .cobalt { color: var(--cobalt); }
.slide-title .purple { color: var(--purple); }
.slide-title .orange { color: var(--orange); }

.slide-subtitle {
  font-size: 1rem; font-weight: 400; color: var(--text-muted);
  line-height: 1.65; max-width: 700px;
}

.gradient-text {
  background: linear-gradient(135deg, var(--cobalt), var(--accent));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ============================================
   CARDS
   ============================================ */
.glass-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: clamp(16px, 2vw, 28px);
  box-shadow: var(--shadow-sm);
  transition: all .35s var(--ease);
  position: relative;
}
.glass-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.card-accent-bar {
  position: absolute; left: 0; top: 16px; bottom: 16px;
  width: 3px; border-radius: 0 3px 3px 0;
}
.card-accent-bar.blue { background: var(--cobalt); }
.card-accent-bar.green { background: var(--accent); }
.card-accent-bar.orange { background: var(--orange); }
.card-accent-bar.red { background: var(--red); }
.card-accent-bar.purple { background: var(--purple); }

/* ============================================
   STAT BADGES
   ============================================ */
.stat-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 6px;
  font-size: .82rem; font-weight: 600;
}
.stat-badge i { font-size: .68rem; }
.stat-badge.green { background: var(--accent-bg); color: var(--accent); }
.stat-badge.blue { background: var(--cobalt-bg); color: var(--cobalt); }
.stat-badge.orange { background: var(--orange-bg); color: var(--orange); }
.stat-badge.red { background: var(--red-bg); color: var(--red); }
.stat-badge.purple { background: var(--purple-bg); color: var(--purple); }

/* ============================================
   CLUSTER BADGES
   ============================================ */
.cluster-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 12px; border-radius: 100px;
  font-size: .82rem; font-weight: 600;
}
.cluster-badge i { font-size: .68rem; }
.cluster-badge.stars { background: var(--cobalt-bg); color: var(--cobalt); }
.cluster-badge.workers { background: var(--orange-bg); color: var(--orange); }
.cluster-badge.risk { background: var(--red-bg); color: var(--red); }
.cluster-badge.founder { background: var(--purple-bg); color: var(--purple); }

/* ============================================
   GRIDS
   ============================================ */
.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }

/* ============================================
   MEMBER CARDS
   ============================================ */
.member-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px 14px 14px 20px;
  position: relative; overflow: hidden;
  transition: all .3s var(--ease);
}
.member-card:hover {
  border-color: var(--border-strong); transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.member-card.compact { padding: 10px 10px 10px 16px; border-radius: 10px; }
.member-card.compact .member-header { margin-bottom: 3px; gap: 6px; }
.member-card.compact .member-id { font-size: 1rem; }
.member-card.compact .member-cluster { font-size: .74rem; }
.member-card.compact .member-role { font-size: .78rem; margin-bottom: 3px; gap: 4px; }
.member-card.compact .member-role i { font-size: .62rem; }
.member-card.compact .member-desc { font-size: .78rem; line-height: 1.45; }
.member-card.compact .member-scores { margin-top: 5px; gap: 3px; }
.member-card.compact .stat-badge { padding: 2px 6px; font-size: .72rem; border-radius: 4px; }
.member-card.compact .stat-badge i { font-size: .56rem; }
.member-card.compact .card-accent-bar { top: 8px; bottom: 8px; width: 3px; }

.member-header { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.member-id {
  font-family: var(--font-display); font-size: 1.3rem; font-weight: 900;
  letter-spacing: -.04em; color: var(--text);
}
.member-cluster { font-size: .84rem; font-weight: 600; }
.member-role {
  display: flex; align-items: center; gap: 5px;
  font-size: .84rem; font-weight: 600; color: var(--text-muted); margin-bottom: 4px;
}
.member-role i { font-size: .68rem; }
.member-desc { font-size: .86rem; color: var(--text-secondary); line-height: 1.5; }
.member-scores { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 6px; }

/* ============================================
   SCATTER PLOT
   ============================================ */
.scatter-container {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 24px;
  box-shadow: var(--shadow-sm);
}

/* ============================================
   ROLE TABLE
   ============================================ */
.role-row {
  display: flex; align-items: stretch;
  border-bottom: 1px solid var(--border); transition: background .2s;
}
.role-row:last-child { border-bottom: none; }
.role-row:hover { background: var(--bg-subtle); }
.role-color { width: 3px; flex-shrink: 0; border-radius: 3px; margin: 8px 0; }
.role-name {
  width: 240px; flex-shrink: 0; padding: 11px 16px;
  font-weight: 700; font-size: .94rem; color: var(--text);
  display: flex; align-items: center; gap: 7px;
}
.role-name i { font-size: .75rem; color: var(--text-light); }
.role-desc { flex: 1; padding: 11px 16px; color: var(--text-secondary); font-size: .9rem; line-height: 1.5; }

/* ============================================
   MINI BARS
   ============================================ */
.mini-bar { display: flex; align-items: center; gap: 6px; margin-top: 3px; }
.mini-bar-track { flex: 1; height: 5px; background: var(--bg-muted); border-radius: 4px; overflow: hidden; }
.mini-bar-fill { height: 100%; border-radius: 4px; transition: width .8s var(--ease); }

/* ============================================
   RADAR & METRICS
   ============================================ */
.radar-wrap { display: flex; flex-direction: row; align-items: flex-start; gap: 14px; }
.radar-wrap .scatter-container { width: 52%; min-width: 0; flex-shrink: 0; }
.radar-metrics { display: grid; grid-template-columns: 1fr 1fr; gap: 5px; flex: 1; min-width: 0; }
.metric-card {
  display: flex; flex-direction: column; gap: 2px;
  padding: 8px 10px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  transition: all .25s; position: relative;
}
.metric-card:hover { background: var(--bg-subtle); box-shadow: var(--shadow-sm); }
.metric-card .icon-wrap {
  width: 26px; height: 26px; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: .68rem; flex-shrink: 0;
}
.metric-card .metric-header { display: flex; align-items: center; gap: 6px; }
.metric-card .metric-info { flex: 1; min-width: 0; }
.metric-card .label { font-size: .72rem; font-weight: 700; color: var(--text); line-height: 1.2; }
.metric-card .note { font-size: .58rem; color: var(--text-light); margin-top: 1px; line-height: 1.3; }
.metric-card .value {
  font-family: var(--font-display); font-size: 1.3rem;
  font-weight: 800; letter-spacing: -.04em; flex-shrink: 0;
  position: absolute; top: 6px; right: 10px;
}
.score-green { color: var(--accent); }
.score-blue { color: var(--cobalt); }
.score-orange { color: var(--orange); }
.score-red { color: var(--red); }

/* ============================================
   BELBIN ROLES
   ============================================ */
.belbin-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; }
.belbin-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px;
  box-shadow: var(--shadow-sm);
}
.belbin-category {
  font-size: .78rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase;
  color: var(--text-light); margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
}
.belbin-category i { font-size: .65rem; }
.belbin-role { font-weight: 700; color: var(--text); font-size: .94rem; margin-bottom: 2px; }
.belbin-count { font-family: var(--font-display); font-size: 1.3rem; font-weight: 800; }

/* ============================================
   DRIVERS / DEFICITS
   ============================================ */
.dd-card { padding: 20px 22px; border-radius: 12px; border: 1px solid var(--border); }
.dd-card.drivers { background: rgba(13,148,100,.03); border-color: rgba(13,148,100,.15); }
.dd-card.deficits { background: rgba(220,38,38,.03); border-color: rgba(220,38,38,.12); }
.dd-card h3 {
  font-family: var(--font-display); font-weight: 700; font-size: 1.05rem;
  margin-bottom: 8px; display: flex; align-items: center; gap: 7px;
}
.dd-card h3 i { font-size: .85rem; }
.dd-card.drivers h3 { color: var(--accent); }
.dd-card.deficits h3 { color: var(--red); }
.dd-card ul { list-style: none; }
.dd-card li {
  color: var(--text-secondary); font-size: .9rem; line-height: 1.65;
  margin-bottom: 4px; display: flex; align-items: baseline; gap: 6px;
}
.dd-card li i { font-size: .68rem; flex-shrink: 0; width: 12px; text-align: center; }

/* ============================================
   CONCLUSION BOX
   ============================================ */
.conclusion-box {
  margin-top: 14px; padding: 14px 18px;
  background: var(--accent-bg); border: 1px solid rgba(13,148,100,.18);
  border-radius: 12px; color: var(--accent);
  font-weight: 500; font-size: .92rem; line-height: 1.6;
  display: flex; align-items: flex-start; gap: 10px;
}
.conclusion-box i { margin-top: 3px; flex-shrink: 0; }

/* ============================================
   INSIGHT CARDS
   ============================================ */
.insight-card {
  display: flex; gap: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; overflow: hidden;
  transition: all .3s var(--ease);
  box-shadow: var(--shadow-sm);
}
.insight-card:hover { transform: translateX(4px); box-shadow: var(--shadow-md); }
.insight-bar { width: 4px; flex-shrink: 0; }
.insight-icon {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: .85rem;
}
.insight-content { padding: 12px 16px; flex: 1; }
.insight-header { display: flex; align-items: center; gap: 10px; margin-bottom: 5px; }
.insight-title { font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--text); }
.insight-text { font-size: .9rem; color: var(--text-secondary); line-height: 1.6; }

/* ============================================
   COVER
   ============================================ */
/* ============================================
   COVER V2 — Landing-page style
   ============================================ */
.cover-slide-v2 {
  display: flex; flex-direction: column; align-items: stretch; justify-content: flex-start;
  background: #f4f5f7;
  padding: 0 !important; position: relative;
}

/* Grid lines background */
.cover-grid {
  position: absolute; inset: 0; z-index: 0;
  background-image:
    linear-gradient(rgba(0,0,0,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,.04) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 20%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 20%, transparent 100%);
}

/* Gradient orbs */
.cover-orb {
  position: absolute; border-radius: 50%; pointer-events: none; z-index: 0;
}
.cover-orb-green {
  width: 340px; height: 340px; bottom: -80px; right: -60px;
  background: radial-gradient(circle, rgba(13,148,100,.12) 0%, transparent 70%);
  filter: blur(60px);
}
.cover-orb-blue {
  width: 280px; height: 280px; top: 40px; left: -40px;
  background: radial-gradient(circle, rgba(26,89,179,.08) 0%, transparent 70%);
  filter: blur(50px);
}
.cover-orb-purple {
  width: 200px; height: 200px; top: 60%; right: 10%;
  background: radial-gradient(circle, rgba(124,58,237,.06) 0%, transparent 70%);
  filter: blur(40px);
}

/* Decorative dots */
.cover-dot { position: absolute; border-radius: 50%; z-index: 1; }

/* Top bar */
.cover-top {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: 28px 48px 0;
}
.cover-logo {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 800; font-size: 1.1rem;
  color: var(--text); letter-spacing: -.03em;
}
.cover-logo-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--accent);
}
.cover-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-body); font-size: .62rem; font-weight: 600;
  letter-spacing: .16em; color: var(--text-muted); text-transform: uppercase;
}

/* Hero heading */
.cover-hero {
  position: relative; z-index: 2;
  flex: 1; display: flex; flex-direction: column;
  align-items: flex-start; justify-content: center;
  padding: 0 48px;
}
.cover-heading {
  font-family: var(--font-display);
  font-size: 4.6rem; font-weight: 900;
  line-height: 1.02; letter-spacing: -.06em;
  color: var(--text); margin: 0;
}
.cover-heading em {
  font-style: normal; color: var(--accent);
}
.cover-sub {
  font-family: var(--font-body); font-size: 1.05rem;
  color: var(--text-muted); line-height: 1.6;
  margin-top: 18px; font-weight: 400;
}

/* Client metadata bar */
.cover-meta {
  position: absolute; bottom: 80px; left: 48px; right: 48px; z-index: 2;
  padding: 0; margin-bottom: 0;
}
.cover-meta-row {
  display: flex; align-items: stretch; gap: 0;
  background: #fff; border: 1px solid var(--border);
  border-radius: 14px; padding: 18px 0;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.cover-meta-item {
  flex: 1; text-align: center;
}
.cover-meta-label {
  font-size: .62rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: .14em; color: var(--text-light); margin-bottom: 4px;
}
.cover-meta-value {
  font-family: var(--font-display); font-weight: 800;
  font-size: .92rem; color: var(--text); letter-spacing: -.02em;
}
.cover-meta-divider {
  width: 1px; background: var(--border); margin: 2px 0;
}

/* Bottom bar */
.cover-bottom {
  position: absolute; bottom: 22px; left: 48px; right: 48px; z-index: 2;
  display: flex; justify-content: space-between; align-items: center;
}
.cover-bottom-left {
  font-family: var(--font-body); font-size: .72rem;
  color: var(--text-light); font-weight: 500;
}
.cover-bottom-center {
  font-family: var(--font-body); font-size: .58rem;
  font-weight: 600; letter-spacing: .18em; color: var(--text-light); text-transform: uppercase;
}
.cover-bottom-right {
  font-family: var(--font-body); font-size: .72rem;
  color: var(--text-light); font-weight: 400;
}

/* Legacy cover-tag support for non-cover slides */
.cover-tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 22px; border: 1px solid var(--border);
  border-radius: 100px; font-size: .75rem; font-weight: 500;
  color: var(--text-muted); margin-top: 28px; letter-spacing: .04em;
}
.cover-tag i { font-size: .6rem; color: var(--accent); }

/* ============================================
   SUMMARY STRIP
   ============================================ */
.summary-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; margin-top: 14px; }
.summary-item {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 12px;
  display: flex; align-items: center; gap: 10px;
  transition: all .25s; box-shadow: var(--shadow-sm);
  min-height: 60px;
}
.summary-item:hover { box-shadow: var(--shadow-md); }
.summary-item .s-icon {
  width: 36px; height: 36px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; flex-shrink: 0;
}
.summary-item .s-val {
  font-family: var(--font-display); font-weight: 800;
  font-size: 1.2rem; letter-spacing: -.03em; line-height: 1.1;
}
.summary-item .s-label { font-size: .68rem; color: var(--text-light); line-height: 1.3; }

/* ============================================
   DECODE GRID
   ============================================ */
.decode-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.decode-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px;
  transition: all .25s; box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
}
.decode-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.decode-card .scale-icon {
  width: 30px; height: 30px; border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: .68rem; margin-bottom: 7px;
}
.decode-card .scale-name { font-weight: 700; font-size: .8rem; color: var(--text); margin-bottom: 3px; }
.decode-card .scale-desc { font-size: .7rem; color: var(--text-muted); line-height: 1.45; }
.decode-card .decode-card-footer { margin-top: auto; }

/* ============================================
   HEATMAP TABLE
   ============================================ */
.heatmap-table { width:100%; border-collapse:separate; border-spacing:0; font-size:.64rem; border-radius:12px; overflow:hidden; border:1px solid var(--border); table-layout:fixed; }
.heatmap-table th { background:var(--bg-subtle); color:var(--text-muted); font-weight:600; padding:6px 3px; text-align:center; font-size:.62rem; letter-spacing:.02em; text-transform:uppercase; border-bottom:1px solid var(--border); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.heatmap-table th:first-child { text-align:left; padding-left:10px; width:42px; }
.heatmap-table th:nth-child(2) { text-align:left; padding-left:6px; width:72px; }
.heatmap-table td { padding:5px 3px; text-align:center; font-weight:600; font-family:var(--font-display); border-bottom:1px solid rgba(0,0,0,.04); transition:all .2s; font-size:.74rem; }
.heatmap-table td:first-child { text-align:left; font-family:var(--font-body); font-weight:700; padding-left:10px; color:var(--text); font-size:.76rem; }
.heatmap-table td:nth-child(2) { text-align:left; padding-left:6px; font-size:.66rem; }
.heatmap-table tr:last-child td { border-bottom:none; }
.heatmap-table tr:hover { background:var(--bg-subtle); }
.heatmap-table .cell-hi { color:var(--accent); background:rgba(13,148,100,.06); }
.heatmap-table .cell-mid { color:var(--cobalt); background:rgba(26,89,179,.04); }
.heatmap-table .cell-warn { color:var(--orange); background:rgba(217,119,6,.06); }
.heatmap-table .cell-low { color:var(--red); background:rgba(220,38,38,.06); }
.heatmap-table .row-avg { background:var(--bg-subtle); }
.heatmap-table .row-avg td { font-weight:800; font-size:.68rem; border-top:2px solid var(--border-strong); }
.heatmap-table .cluster-dot { display:inline-block; width:7px; height:7px; border-radius:50%; margin-right:3px; vertical-align:middle; }

/* ============================================
   EXEC KPI STRIP
   ============================================ */
.kpi-strip { display:grid; gap:10px; }
.kpi-card { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; padding:14px 12px; text-align:center; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; min-width:0; }
.kpi-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.kpi-card.kpi-green::before { background:var(--accent); }
.kpi-card.kpi-blue::before { background:var(--cobalt); }
.kpi-card.kpi-orange::before { background:var(--orange); }
.kpi-card.kpi-red::before { background:var(--red); }
.kpi-card.kpi-purple::before { background:var(--purple); }
.kpi-val { font-family:var(--font-display); font-size:2rem; font-weight:800; letter-spacing:-.04em; line-height:1; }
.kpi-label { font-size:.78rem; color:var(--text-muted); margin-top:4px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.kpi-delta { font-size:.72rem; font-weight:600; margin-top:3px; display:inline-flex; align-items:center; gap:3px; padding:2px 6px; border-radius:4px; }
.kpi-delta.up { color:var(--accent); background:var(--accent-bg); }
.kpi-delta.down { color:var(--red); background:var(--red-bg); }
.kpi-delta.neutral { color:var(--orange); background:var(--orange-bg); }

/* ============================================
   METHODOLOGY PIPELINE
   ============================================ */
.pipeline { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; position:relative; padding:24px 0 8px; }
.pipeline::before { display:none; }
.pipe-step { text-align:center; position:relative; z-index:1; background:var(--bg-card); border:1px solid var(--border); border-radius:14px; padding:16px 8px 14px; box-shadow:var(--shadow-sm); transition:transform .2s; }
.pipe-step:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.pipe-num { width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--cobalt),#2d7be5); border:none; display:inline-flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:800; font-size:1rem; color:#fff; margin-bottom:10px; box-shadow:0 4px 12px rgba(26,89,179,.3); }
.pipe-title { font-weight:700; font-size:.82rem; color:var(--text); margin-bottom:4px; line-height:1.3; }
.pipe-desc { font-size:.7rem; color:var(--text-muted); line-height:1.45; max-width:160px; margin:0 auto; }

/* ============================================
   COGNITIVE DNA
   ============================================ */
.dna-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.dna-card { background:var(--bg-card); border:1px solid var(--border); border-radius:12px; padding:14px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.dna-card .dna-header { display:flex; align-items:center; gap:8px; margin-bottom:6px; }
.dna-card .dna-icon { width:32px; height:32px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:.78rem; flex-shrink:0; }
.dna-card .dna-name { font-weight:700; font-size:.88rem; color:var(--text); }
.dna-card .dna-val { font-family:var(--font-display); font-weight:800; font-size:1.5rem; letter-spacing:-.03em; }
.dna-card .dna-unit { font-size:.72rem; color:var(--text-light); font-weight:400; margin-left:2px; }
.dna-card .dna-desc { font-size:.78rem; color:var(--text-muted); line-height:1.4; margin-top:4px; }
.dna-card .dna-bar { margin-top:auto; padding-top:6px; }

/* ============================================
   RISK MATRIX
   ============================================ */
.risk-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.risk-item { display:flex; align-items:flex-start; gap:10px; padding:12px 14px; background:var(--bg-card); border:1px solid var(--border); border-radius:10px; }
.risk-icon { width:36px; height:36px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.82rem; flex-shrink:0; }
.risk-title { font-weight:700; font-size:.92rem; color:var(--text); margin-bottom:2px; }
.risk-text { font-size:.82rem; color:var(--text-muted); line-height:1.45; }
.risk-badge { display:inline-flex; padding:2px 6px; border-radius:4px; font-size:.72rem; font-weight:600; margin-top:3px; }

/* ============================================
   ACTION PLAN TABLE
   ============================================ */
.action-table { width:100%; border-collapse:separate; border-spacing:0; border-radius:12px; overflow:hidden; border:1px solid var(--border); }
.action-table th { background:var(--bg-subtle); color:var(--text-muted); font-weight:600; padding:10px 12px; text-align:left; font-size:.82rem; letter-spacing:.04em; text-transform:uppercase; border-bottom:1px solid var(--border); }
.action-table td { padding:10px 12px; font-size:.88rem; color:var(--text-secondary); border-bottom:1px solid rgba(0,0,0,.04); vertical-align:top; line-height:1.5; }
.action-table tr:last-child td { border-bottom:none; }
.action-table tr:hover { background:var(--bg-subtle); }
.action-table .priority-tag { display:inline-flex; padding:2px 8px; border-radius:4px; font-size:.72rem; font-weight:600; }
.action-table .priority-tag.critical { background:var(--red-bg); color:var(--red); }
.action-table .priority-tag.high { background:var(--orange-bg); color:var(--orange); }
.action-table .priority-tag.medium { background:var(--cobalt-bg); color:var(--cobalt); }

/* ============================================
   GAUGE RINGS (SVG)
   ============================================ */
.gauge-wrap { display:flex; flex-direction:column; align-items:center; }
.gauge-ring { position:relative; width:90px; height:90px; }
.gauge-ring svg { transform:rotate(-90deg); }
.gauge-ring .gauge-label { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.gauge-ring .gauge-val { font-family:var(--font-display); font-weight:800; font-size:1.4rem; line-height:1; }
.gauge-ring .gauge-unit { font-size:.68rem; color:var(--text-light); }
.gauge-name { font-size:.82rem; font-weight:600; color:var(--text-secondary); margin-top:4px; text-align:center; }

/* ============================================
   HORIZONTAL BAR CHART
   ============================================ */
.hbar-chart { display:flex; flex-direction:column; gap:6px; }
.hbar-row { display:flex; align-items:center; gap:8px; }
.hbar-label { width:110px; font-size:.84rem; font-weight:600; color:var(--text-secondary); text-align:right; flex-shrink:0; }
.hbar-track { flex:1; height:20px; background:var(--bg-subtle); border-radius:4px; overflow:hidden; position:relative; }
.hbar-fill { height:100%; border-radius:4px; transition:width .6s var(--ease); display:flex; align-items:center; justify-content:flex-end; padding-right:6px; }
.hbar-val { font-size:.72rem; font-weight:700; color:#fff; white-space:nowrap; }
.hbar-val-out { font-size:.78rem; font-weight:700; margin-left:6px; flex-shrink:0; width:32px; }

/* ============================================
   STAT COMPARISON ROW
   ============================================ */
.stat-compare { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; width:100%; }
.stat-compare-item { text-align:center; padding:10px 8px; background:var(--bg-card); border:1px solid var(--border); border-radius:10px; min-width:0; overflow:hidden; }
.stat-compare-item .sc-val { font-family:var(--font-display); font-weight:800; font-size:1.6rem; line-height:1; }
.stat-compare-item .sc-label { font-size:.72rem; color:var(--text-muted); margin-top:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.stat-compare-item .sc-bar { margin-top:5px; }

/* ============================================
   DONUT CHART (inline SVG)
   ============================================ */
.donut-row { display:flex; gap:16px; justify-content:center; align-items:flex-start; flex-wrap:wrap; }
.donut-item { display:flex; flex-direction:column; align-items:center; }
.donut-chart { position:relative; width:72px; height:72px; }
.donut-chart svg { transform:rotate(-90deg); }
.donut-chart .donut-center { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-weight:800; font-size:1.15rem; }
.donut-label { font-size:.78rem; font-weight:600; color:var(--text-secondary); margin-top:3px; text-align:center; max-width:80px; }

/* ============================================
   TEAM COMPOSITION STRIP
   ============================================ */
.composition-strip { display:flex; height:24px; border-radius:6px; overflow:hidden; }
.composition-strip .cs-seg { display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:700; color:#fff; }

/* ============================================
   PRINT
   ============================================ */
@page { size: 210mm 297mm; margin: 0; }
@media print {
  /* ── Global color enforcement ── */
  *, *::before, *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }

  /* ── Hide nav ── */
  .toc-nav { display: none !important; }

  /* ── Body reset ── */
  html, body {
    margin: 0 !important; padding: 0 !important;
    width: 210mm !important;
    background: transparent !important;
    -webkit-font-smoothing: antialiased !important;
  }

  /* ── CRITICAL: Each slide = exactly one A4 page ── */
  .slide {
    display: flex !important;
    flex-direction: column !important;
    width: 210mm !important;
    height: 297mm !important;
    max-height: 297mm !important;
    min-height: 297mm !important;
    padding: 36px 40px 40px !important;
    margin: 0 !important;
    box-shadow: none !important;
    border: none !important;
    overflow: hidden !important;
    position: relative !important;
    /* Page break control — both old and new syntax */
    page-break-after: always !important;
    break-after: page !important;
    page-break-inside: avoid !important;
    break-inside: avoid !important;
    border-top: none !important;
  }
  .slide:last-child {
    page-break-after: auto !important;
    break-after: auto !important;
  }

  /* ── Cover slide: clean gradient background for print ── */
  .cover-slide-v2 {
    background: linear-gradient(160deg, #f4f5f7 0%, #eef0f4 40%, #f0f4f2 100%) !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    padding: 0 !important;
  }
  .cover-grid {
    display: none !important;
  }
  .cover-orb {
    display: none !important;
  }
  .cover-meta-row {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* ── Preserve all colored elements ── */
  .glass-card, .member-card, .insight-card, .metric-card, .decode-card,
  .pipe-step, .conclusion-box, .summary-item, .stat-compare-item,
  .belbin-col, .role-row, .cover-meta-row, .grid-bg,
  .scatter-container, .card-accent-bar, .stat-badge, .composition-strip,
  .bar, .kpi-ring, .donut-chart, .orb, .cover-orb {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* ── GLOBAL: Kill ALL shadows for clean PDF ── */
  *, *::before, *::after {
    box-shadow: none !important;
    text-shadow: none !important;
  }

  /* ── Disable hover states ── */
  .glass-card:hover, .member-card:hover, .insight-card:hover,
  .pipe-step:hover, .decode-card:hover, .metric-card:hover,
  .summary-item:hover, .decode-card:hover {
    transform: none !important;
    box-shadow: none !important;
  }

  /* ── Force grid layouts ── */
  .decode-grid { grid-template-columns: repeat(4,1fr) !important; }
  .grid-2 { grid-template-columns: 1fr 1fr !important; }
  .grid-3 { grid-template-columns: repeat(3,1fr) !important; }
  .radar-wrap { flex-direction: row !important; gap: 12px !important; align-items: flex-start !important; }
  .radar-wrap .scatter-container { width: 50% !important; flex-shrink: 0 !important; margin: 0 !important; }
  .radar-metrics { flex: 1 !important; min-width: 0 !important; grid-template-columns: 1fr 1fr !important; }
  .metric-card .note:last-child { display: none !important; }
  .metric-card .value { font-size: 1.1rem !important; }

  /* ── SVG rendering ── */
  svg, svg * {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  /* ── Orbs & grids — hide decorative elements ── */
  .orb { display: none !important; }
  .grid-bg { display: none !important; }
  .cover-orb { display: none !important; }

  /* ── Prevent breaks inside cards ── */
  .glass-card, .member-card, .insight-card, .metric-card,
  .decode-card, .conclusion-box {
    break-inside: avoid !important;
    page-break-inside: avoid !important;
  }

  /* ── Kill all animations ── */
  *, *::before, *::after {
    animation: none !important;
    transition: none !important;
  }
}

@media (max-width: 1024px) {
  .slide { padding: 72px 20px 48px; }
  .toc-nav { padding: 0 14px; }
  .grid-2, .grid-3, .belbin-grid, .decode-grid, .summary-strip { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: repeat(2,1fr); }
  .radar-wrap { flex-direction: column; }
  .role-name { width: 160px; }
}