/* ============================================================
   KPI6 — Site-specific layout CSS
   Builds on kpi6-foundations.css. Section-by-section composition.
   ============================================================ */

/* ============================================================ */
/*  Header                                                        */
/* ============================================================ */
.kpi-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: rgba(244, 244, 241, 0.85);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--kpi-dur-base) var(--kpi-ease),
              background var(--kpi-dur-base) var(--kpi-ease);
}
.kpi-header.is-scrolled {
  border-bottom-color: var(--kpi-line);
  background: rgba(244, 244, 241, 0.92);
}
/* Push page content below the fixed header */
body { padding-top: 88px; }
.kpi-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  height: 88px;
}
.kpi-logo img {
  height: 44px;
  width: auto;
  display: block;
}
.kpi-nav {
  display: flex;
  align-items: center;
  gap: 36px;
}
.kpi-nav-link {
  font-size: 14px;
  font-weight: 500;
  color: var(--kpi-fg-2);
  letter-spacing: -0.005em;
  transition: color var(--kpi-dur-fast) var(--kpi-ease);
  position: relative;
}
.kpi-nav-link:hover { color: var(--kpi-fg); }
.kpi-nav-link::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -22px;
  height: 1px;
  background: var(--kpi-accent);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--kpi-dur-base) var(--kpi-ease);
}
.kpi-nav-link:hover::after { transform: scaleX(1); }

.kpi-btn-sm {
  padding: 10px 16px;
  font-size: 13px;
}
.kpi-header-cta { display: flex; }
.kpi-burger { display: none; }

@media (max-width: 900px) {
  .kpi-nav, .kpi-header-cta { display: none; }
  .kpi-burger {
    display: flex; flex-direction: column; gap: 4px;
    width: 36px; height: 36px; align-items: center; justify-content: center;
  }
  .kpi-burger span {
    width: 20px; height: 1.5px; background: var(--kpi-ink);
    transition: transform var(--kpi-dur-base) var(--kpi-ease);
  }
  .kpi-mobile-menu {
    display: flex; flex-direction: column;
    gap: 20px;
    padding: 24px clamp(20px, 4vw, 56px) 32px;
    background: var(--kpi-paper);
    border-bottom: 1px solid var(--kpi-line);
  }
  .kpi-mobile-menu .kpi-nav-link { font-size: 18px; }
}

/* ============================================================ */
/*  Hero — bi-tonal split                                         */
/* ============================================================ */
.kpi-hero {
  position: relative;
  isolation: isolate;
}
.kpi-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  min-height: calc(100vh - 88px);
  min-height: calc(100dvh - 88px);
}.kpi-hero-paper {
  background: var(--kpi-paper);
  display: flex;
  align-items: center;
  padding: clamp(48px, 7vw, 120px) clamp(24px, 5vw, 96px) clamp(48px, 7vw, 120px) clamp(24px, 5vw, 96px);
  position: relative;
}
.kpi-hero-paper-inner {
  max-width: 720px;
  width: 100%;
}
.kpi-hero-h1 {
  font-size: clamp(44px, 5.8vw, 84px);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.028em;
  color: var(--kpi-fg);
  margin: 28px 0 0;
  text-wrap: balance;
}
.kpi-hero-h1 em {
  font-style: italic;
  font-weight: 500;
  color: var(--kpi-accent);
}
.kpi-hero-sub {
  margin-top: 28px;
  max-width: 56ch;
  color: var(--kpi-fg-2);
}
.kpi-hero-ctas {
  display: flex;
  gap: 12px;
  margin-top: 36px;
  flex-wrap: wrap;
}
.kpi-hero-micro {
  margin-top: 36px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--kpi-fg-3);
}
.kpi-tick {
  width: 6px; height: 6px;
  background: var(--kpi-accent);
  border-radius: 999px;
  display: inline-block;
}

/* Ink (right) side */
.kpi-hero-ink {
  background: var(--kpi-ink);
  position: relative;
  overflow: hidden;
  padding: clamp(48px, 6vw, 80px) clamp(24px, 4vw, 64px);
  display: flex;
}
/* Subtle hairline grid inside the navy panel */
.kpi-hero-ink::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: calc(100% / 6) 100%;
  pointer-events: none;
}
/* Decorative gradient orb echoing the "6" logo gradient */
.kpi-hero-ink::after {
  content: "";
  position: absolute;
  right: -120px; bottom: -120px;
  width: 380px; height: 380px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--kpi-accent-light), var(--kpi-accent-deep) 70%);
  opacity: 0.30;
  filter: blur(40px);
  pointer-events: none;
  transition: opacity var(--kpi-dur-slow) var(--kpi-ease);
}
.no-hero-orb .kpi-hero-ink::after,
.no-hero-orb .kpi-finalcta::after { opacity: 0; }

.show-grid .kpi-section:not(.on-ink) .kpi-container {
  background-image: linear-gradient(to right, rgba(15,24,40,0.06) 1px, transparent 1px);
  background-size: calc(100% / 12) 100%;
}
.kpi-hero-ink-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  gap: 48px;
}
.kpi-hero-ink-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  color: var(--kpi-on-ink-3);
}
.kpi-hero-ink-stack {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.kpi-hero-stat .kpi-numbered { color: var(--kpi-on-ink-4); }
.kpi-hero-stat-from {
  font-size: clamp(56px, 8vw, 120px);
  font-weight: 500;
  line-height: 0.95;
  letter-spacing: -0.03em;
  color: var(--kpi-on-ink-3);
  text-decoration: line-through;
  text-decoration-color: var(--kpi-accent-light);
  text-decoration-thickness: 3px;
}
.kpi-hero-stat-to {
  font-size: clamp(72px, 11vw, 160px);
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: -0.035em;
  color: var(--kpi-on-ink);
}
.kpi-hero-stat-divider {
  width: 32px; height: 1px;
  background: var(--kpi-accent-light);
  margin: 4px 0;
}
.kpi-hero-modes {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 24px;
  border-top: 1px solid var(--kpi-ink-line);
}
.kpi-hero-mode {
  font-size: 14px;
  color: var(--kpi-on-ink-2);
  display: flex;
  gap: 16px;
  align-items: baseline;
}
.kpi-hero-mode .kpi-mono { color: var(--kpi-accent-light); }

@media (max-width: 1024px) {
  .kpi-hero-grid { grid-template-columns: 1fr; }
  .kpi-hero-ink { min-height: 540px; }
}

/* ============================================================ */
/*  Section heads                                                 */
/* ============================================================ */
.kpi-section-head {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: clamp(24px, 5vw, 80px);
  margin-bottom: clamp(48px, 6vw, 80px);
}
.kpi-section-head-meta {
  padding-top: 12px;
}
.kpi-section-head-text h2 em {
  font-style: italic;
  font-weight: 500;
  color: var(--kpi-accent);
}
.on-ink .kpi-section-head-text h2 em { color: var(--kpi-accent-light); }
.kpi-section-head-stacked {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: clamp(48px, 6vw, 80px);
}
.kpi-section-head-stacked h2 em {
  font-style: italic;
  font-weight: 500;
  color: var(--kpi-accent);
}

@media (max-width: 760px) {
  .kpi-section-head { grid-template-columns: 1fr; gap: 16px; }
}

/* ============================================================ */
/*  2. THE SHIFT                                                  */
/* ============================================================ */
.kpi-shift-points {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--kpi-line);
  border-bottom: 1px solid var(--kpi-line);
}
.kpi-shift-point {
  padding: 40px 32px 40px 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-right: 1px solid var(--kpi-line);
}
.kpi-shift-point:last-child { border-right: 0; padding-right: 0; }
.kpi-shift-point:not(:first-child) { padding-left: 32px; }
.kpi-shift-point-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 8px;
}
.kpi-shift-point-num {
  color: var(--kpi-accent);
  font-size: 13px;
  padding-top: 8px;
}
.kpi-shift-point-title { margin: 0; }
.kpi-shift-point-body  { margin: 0; color: var(--kpi-fg-3); max-width: 36ch; }
@media (max-width: 900px) {
  .kpi-shift-points { grid-template-columns: 1fr; }
  .kpi-shift-point { border-right: 0; border-bottom: 1px solid var(--kpi-line); padding-left: 0 !important; }
  .kpi-shift-point:last-child { border-bottom: 0; }
}

/* ============================================================ */
/*  3. WHAT WE DO — mode cards on navy                           */
/* ============================================================ */
.kpi-modes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.kpi-mode-card {
  display: flex;
  flex-direction: column;
  min-height: 420px;
}
.kpi-mode-card-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 32px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--kpi-ink-line);
}
.kpi-mode-num {
  font-family: var(--kpi-font-mono);
  font-size: 14px;
  color: var(--kpi-accent-light);
}
.kpi-mode-card-title {
  margin: 0 0 20px 0;
  color: var(--kpi-on-ink);
}
.kpi-mode-card-body {
  flex: 1;
  margin: 0;
  color: var(--kpi-on-ink-2);
}
.kpi-mode-card-link {
  margin-top: 32px;
  align-self: flex-start;
}
@media (max-width: 900px) {
  .kpi-modes-grid { grid-template-columns: 1fr; }
  .kpi-mode-card { min-height: 0; }
}

/* ============================================================ */
/*  4. RESEARCH                                                   */
/* ============================================================ */
.kpi-research-title em { font-style: italic; font-weight: 500; color: var(--kpi-accent); }
.kpi-research-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--kpi-line);
}
.kpi-research-item {
  padding: 40px 0;
  border-bottom: 1px solid var(--kpi-line);
  padding-right: 40px;
}
.kpi-research-item:nth-child(odd) { border-right: 1px solid var(--kpi-line); padding-right: 40px; }
.kpi-research-item:nth-child(even) { padding-left: 40px; padding-right: 0; }
.kpi-research-tag {
  font-family: var(--kpi-font-mono);
  font-size: 12px;
  color: var(--kpi-accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 16px;
}
.kpi-research-item-title { margin: 0 0 8px; }
.kpi-research-item-body { margin: 0; color: var(--kpi-fg-3); max-width: 44ch; }
@media (max-width: 760px) {
  .kpi-research-grid { grid-template-columns: 1fr; }
  .kpi-research-item, .kpi-research-item:nth-child(odd) { border-right: 0; padding-left: 0 !important; padding-right: 0 !important; }
}

/* ============================================================ */
/*  5. PRODUCTS — monogram tiles on navy                          */
/* ============================================================ */
.kpi-products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.kpi-product-card {
  background: var(--kpi-ink-2);
  border: 1px solid var(--kpi-ink-line);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--kpi-dur-base) var(--kpi-ease),
              background var(--kpi-dur-base) var(--kpi-ease);
  min-height: 240px;
}
.kpi-product-card:hover {
  border-color: var(--kpi-accent-light);
  background: var(--kpi-ink-3);
}
.kpi-product-mono {
  width: 56px; height: 56px;
  flex-shrink: 0;
  background: var(--kpi-ink);
  border: 1px solid var(--mono-accent, var(--kpi-accent-light));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--kpi-font-sans);
  font-weight: 500;
  font-size: 20px;
  color: var(--mono-accent, var(--kpi-on-ink));
  letter-spacing: -0.01em;
}
.kpi-product-body {
  flex: 1;
  min-width: 0;
  width: 100%;
}
.kpi-product-name { margin: 0 0 4px; color: var(--kpi-on-ink); }
.kpi-product-headline {
  font-size: 15px;
  color: var(--kpi-on-ink-2);
  line-height: 1.45;
  margin-bottom: 12px;
}
.kpi-product-replaces {
  font-family: var(--kpi-font-mono);
  font-size: 12px;
  color: var(--kpi-on-ink-4);
  letter-spacing: 0;
}
/* 8th tile — placeholder next-frontier slot */
.kpi-product-card-next {
  background: transparent;
  border-style: dashed;
  border-color: var(--kpi-ink-line);
}
.kpi-product-card-next:hover {
  background: var(--kpi-ink-2);
  border-style: solid;
}
.kpi-product-mono-next {
  border-color: var(--kpi-on-ink-4);
  color: var(--kpi-on-ink-3);
  font-size: 24px;
  font-weight: 400;
}
.kpi-product-card-next .kpi-product-name { color: var(--kpi-on-ink-2); }
.kpi-product-card-next .kpi-product-headline { color: var(--kpi-on-ink-3); }
.kpi-product-card-next .kpi-product-replaces { color: var(--kpi-accent-light); }

.kpi-products-footer {
  margin-top: 48px;
  display: flex;
  justify-content: center;
}
@media (max-width: 1180px) {
  .kpi-products-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 880px) {
  .kpi-products-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .kpi-products-grid { grid-template-columns: 1fr; }
}

/* ============================================================ */
/*  6. TRAINING                                                   */
/* ============================================================ */
.kpi-training-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(40px, 8vw, 120px);
  align-items: start;
}
.kpi-training-title em { font-style: italic; font-weight: 500; color: var(--kpi-accent); }
.kpi-training-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.kpi-training-item {
  padding: 28px 0;
  border-top: 1px solid var(--kpi-line);
}
.kpi-training-item:last-child { border-bottom: 1px solid var(--kpi-line); }
.kpi-training-item-head {
  display: flex;
  gap: 24px;
  align-items: baseline;
  margin-bottom: 8px;
}
.kpi-training-item-head .kpi-mono { color: var(--kpi-accent); }
@media (max-width: 900px) {
  .kpi-training-grid { grid-template-columns: 1fr; }
}

/* ============================================================ */
/*  7. WHY KPI6                                                   */
/* ============================================================ */
.kpi-why-title em { font-style: italic; font-weight: 500; color: var(--kpi-accent); }
.kpi-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 24px;
}
.kpi-why-item {
  padding-top: 24px;
  position: relative;
}
.kpi-why-rule {
  width: 48px;
  height: 2px;
  background: var(--kpi-accent);
  margin-bottom: 24px;
}
.kpi-why-item-title { margin: 0 0 8px; }
.kpi-why-item-body { margin: 0; color: var(--kpi-fg-3); max-width: 36ch; }
@media (max-width: 760px) {
  .kpi-why-grid { grid-template-columns: 1fr; }
}

/* ============================================================ */
/*  8. FINAL CTA                                                  */
/* ============================================================ */
.kpi-finalcta {
  background: var(--kpi-ink);
  position: relative;
  overflow: hidden;
}
.kpi-finalcta::after {
  content: "";
  position: absolute;
  right: -180px; top: -180px;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, var(--kpi-accent-light), var(--kpi-accent-deep) 70%);
  opacity: 0.22;
  filter: blur(60px);
  pointer-events: none;
}
.kpi-finalcta-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 32px;
  max-width: 880px;
}
.kpi-finalcta-title {
  margin: 0;
  text-wrap: balance;
}
.kpi-finalcta-title em { font-style: italic; font-weight: 500; color: var(--kpi-accent-light); }
.kpi-finalcta-actions {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}

/* ============================================================ */
/*  9. FOOTER                                                     */
/* ============================================================ */
.kpi-footer {
  background: var(--kpi-ink);
  padding: clamp(56px, 7vw, 96px) 0 32px;
  border-top: 1px solid var(--kpi-ink-line);
}
.kpi-footer-top {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 3fr);
  gap: clamp(40px, 6vw, 96px);
  margin-bottom: 64px;
}
.kpi-footer-mark img {
  height: 56px;
  width: auto;
  margin-bottom: 24px;
}
.kpi-footer-tag {
  color: var(--kpi-on-ink-3);
  max-width: 28ch;
}
.kpi-footer-cols {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.kpi-footer-col-title {
  color: var(--kpi-on-ink-3);
  margin-bottom: 20px;
}
.kpi-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.kpi-footer-link {
  color: var(--kpi-on-ink-2);
  font-size: 14px;
  transition: color var(--kpi-dur-fast) var(--kpi-ease);
}
.kpi-footer-link:hover { color: var(--kpi-on-ink); }
.kpi-footer-rule { border-top-color: var(--kpi-ink-line); margin-bottom: 32px; }
.kpi-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 32px;
  flex-wrap: wrap;
}
.kpi-footer-legal { color: var(--kpi-on-ink-3); }
.kpi-footer-legal-meta { color: var(--kpi-on-ink-4); }
@media (max-width: 900px) {
  .kpi-footer-top { grid-template-columns: 1fr; }
  .kpi-footer-cols { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .kpi-footer-cols { grid-template-columns: 1fr; }
}

/* ============================================================ */
/*  Accent-variant overrides driven by Tweaks                     */
/* ============================================================ */
[data-accent="navy"] {
  --kpi-accent:        #1A2B4A;
  --kpi-accent-deep:   #0F1828;
  --kpi-accent-light:  #5F708C;
}
[data-accent="slate"] {
  --kpi-accent:        #3A5B8C;
  --kpi-accent-deep:   #1A2B4A;
  --kpi-accent-light:  #7B92BD;
}
[data-accent="ocra"] {
  --kpi-accent:        #B47318;
  --kpi-accent-deep:   #7A4D0F;
  --kpi-accent-light:  #D69E45;
}
[data-accent="emerald"] {
  --kpi-accent:        #2F7D5B;
  --kpi-accent-deep:   #1A4A36;
  --kpi-accent-light:  #5FAE85;
}

/* Palette variants */
[data-palette="paper"] { /* default — already set */ }
[data-palette="warm"] {
  --kpi-paper:      #F1ECE2;
  --kpi-paper-2:    #E8E3D8;
  --kpi-paper-3:    #DDD7C8;
  --kpi-line:       #CFC9BA;
}
[data-palette="cool"] {
  --kpi-paper:      #EEF0F2;
  --kpi-paper-2:    #E5E7EA;
  --kpi-paper-3:    #D9DCE0;
  --kpi-line:       #C8CCD2;
}

/* ============================================================ */
/*  DIAGRAMS                                                      */
/*  Mono-stroke research artifacts living inside the sections.    */
/* ============================================================ */

/* --- Hero constellation (navy panel ambient layer) ---------- */
.kpi-hero-constellation {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 0.85;
  pointer-events: none;
}
.kpi-hero-anchor-ring {
  transform-origin: center;
  transform-box: fill-box;
  animation: kpi-anchor-ripple 4.4s ease-out infinite;
}
.kpi-hero-anchor-ring-2 { animation-delay: 2.2s; }
@keyframes kpi-anchor-ripple {
  0%   { r: 2.2; opacity: 0.9; }
  100% { r: 12;  opacity: 0; }
}
/* Lift the hero content above the constellation */
.kpi-hero-ink-inner { z-index: 2; }
.kpi-hero-ink::before { z-index: 0; }
.kpi-hero-ink::after  { z-index: 1; }
@media (prefers-reduced-motion: reduce) {
  .kpi-hero-anchor-ring { animation: none; opacity: 0; }
}

/* --- Shift section — weeks → hours typographic moment ------ */
.kpi-shift-timeline-wrap {
  margin-top: clamp(56px, 8vw, 96px);
  padding-top: clamp(40px, 6vw, 64px);
  border-top: 1px solid var(--kpi-line);
}
.kpi-shift-collapse {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: clamp(24px, 5vw, 64px);
  max-width: 880px;
  margin-inline: auto;
}
.kpi-shift-collapse-from,
.kpi-shift-collapse-to {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.kpi-shift-collapse-to { align-items: flex-end; text-align: right; }
.kpi-shift-collapse-num {
  font-family: var(--kpi-font-sans);
  font-weight: 500;
  font-size: clamp(56px, 8vw, 104px);
  line-height: 0.95;
  letter-spacing: -0.035em;
  color: var(--kpi-fg);
  font-feature-settings: "ss01", "tnum";
}
.kpi-shift-collapse-num-from {
  color: var(--kpi-fg-3);
  text-decoration: line-through;
  text-decoration-color: var(--kpi-line-2);
  text-decoration-thickness: 2px;
}
.kpi-shift-collapse-num-to { color: var(--kpi-fg); }
.kpi-shift-arc-svg {
  width: 100%;
  height: 60px;
  display: block;
  overflow: visible;
}
.kpi-shift-arc {
  transition: stroke-dashoffset 2000ms var(--kpi-ease-out);
}
.kpi-shift-timeline-wrap.is-visible .kpi-shift-arc {
  stroke-dashoffset: 0;
}
@media (prefers-reduced-motion: reduce) {
  .kpi-shift-arc { stroke-dashoffset: 0; transition: none; }
}
@media (max-width: 640px) {
  .kpi-shift-collapse { grid-template-columns: 1fr 1fr; }
  .kpi-shift-arc-svg { display: none; }
}

/* --- Research item diagrams ---------------------------------- */
.kpi-research-item-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 16px;
}
.kpi-research-item-head .kpi-research-tag { margin-bottom: 0; padding-top: 4px; }
.kpi-diag {
  width: 96px;
  height: auto;
  flex-shrink: 0;
  display: block;
}

/* Subtle motion on the listening pings & audience arc when visible */
.kpi-research-item.is-visible .kpi-diag-listening circle:nth-of-type(2),
.kpi-research-item.is-visible .kpi-diag-listening circle:nth-of-type(3),
.kpi-research-item.is-visible .kpi-diag-listening circle:nth-of-type(4) {
  animation: kpi-ping 3.6s ease-in-out infinite;
}
.kpi-research-item.is-visible .kpi-diag-listening circle:nth-of-type(3) { animation-delay: 0.4s; }
.kpi-research-item.is-visible .kpi-diag-listening circle:nth-of-type(4) { animation-delay: 0.8s; }
@keyframes kpi-ping {
  0%, 100% { opacity: 0.4; }
  50%      { opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .kpi-diag-listening circle { animation: none !important; }
}

