/*
  Microsite styles. Editorial, data-viz first.
  Applied when body has .surface-microsite.
*/

/* ============================================================
   Top nav
   ============================================================ */
/* ---- Nav: fixed + adaptive light/dark ---- */
.site-nav {
  --nav-h: 57px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: var(--sp-4) 0;
  background: rgba(248, 249, 250, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(13, 15, 26, 0.08);
  transition: background 200ms ease, border-color 200ms ease;
}

.site-nav.nav--dark {
  background: rgba(25, 25, 36, 0.92);
  border-bottom-color: rgba(255, 255, 255, 0.06);
}

/* Compensate for fixed nav height */
body.surface-microsite {
  padding-top: var(--nav-h, 57px);
}

.site-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-6);
}

@media (max-width: 480px) {
  .site-nav__inner {
    flex-direction: column;
    align-items: center;
    gap: var(--sp-3);
    padding-block: var(--sp-3);
  }
}

.site-nav__brand {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  letter-spacing: var(--letter-snug);
}

.site-nav__brand-logo {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  flex-shrink: 0;
  object-fit: cover;
}

.site-nav__brand-text {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
}

.site-nav__brand strong {
  font-weight: 700;
}

.site-nav__brand .publisher {
  font-family: var(--font-body);
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
}

@media (max-width: 640px) {
  .site-nav__brand-text .publisher { display: none; }
}

.site-nav__links {
  display: flex;
  gap: var(--sp-6);
  font-size: var(--fs-body-sm);
}

/* Light nav state */
.site-nav__links a {
  color: rgba(13, 15, 26, 0.55);
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color var(--dur-quick) var(--ease-out);
}

.site-nav__links a:hover {
  color: #0D0F1A;
}

.site-nav__links a[aria-current="page"] {
  color: #4C2FB9;
  border-bottom-color: #4C2FB9;
}

/* Dark nav state */
.site-nav.nav--dark .site-nav__links a {
  color: #A6AEBA;
}

.site-nav.nav--dark .site-nav__links a:hover {
  color: #F8F9FA;
}

.site-nav.nav--dark .site-nav__links a[aria-current="page"] {
  color: #FF7E4A;
  border-bottom-color: #FF7E4A;
}

/* Nav brand text: light vs dark state */
.site-nav .site-nav__brand strong {
  color: #0D0F1A;
  transition: color 200ms ease;
}

.site-nav .site-nav__brand .publisher {
  color: rgba(13, 15, 26, 0.45);
  transition: color 200ms ease;
}

.site-nav.nav--dark .site-nav__brand strong {
  color: #F8F9FA;
}

.site-nav.nav--dark .site-nav__brand .publisher {
  color: #727379;
}

/* ============================================================
   Hero
   ============================================================ */
.hero {
  background: #F8F9FA;
  padding: var(--sp-10) 0 var(--sp-9);
  border-bottom: 1px solid rgba(13, 15, 26, 0.08);
  position: relative;
  overflow: hidden;
}

/* Orange aurora — bottom left */
.hero::before {
  content: "";
  position: absolute;
  bottom: -30px;
  left: -60px;
  width: 360px;
  height: 240px;
  background: radial-gradient(ellipse,
    rgba(255, 126, 74, 0.10) 0%,
    transparent 65%);
  pointer-events: none;
}

/* Violet aurora — top right */
.hero::after {
  content: "";
  position: absolute;
  top: -80px;
  right: -100px;
  width: 500px;
  height: 400px;
  background: radial-gradient(ellipse,
    rgba(139, 108, 255, 0.14) 0%,
    rgba(76, 47, 185, 0.06) 45%,
    transparent 70%);
  pointer-events: none;
}

.hero__eyebrow {
  margin-bottom: var(--sp-5);
  color: #8B6CFF;
}

.hero__headline {
  font-family: var(--font-display);
  font-size: var(--fs-display-xl);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  font-weight: 400;
  max-width: 18ch;
  margin-bottom: var(--sp-6);
}

.hero__headline em {
  font-style: normal;
  font-weight: 700;
  background: linear-gradient(90deg, #FF7E4A 0%, #BB7AFF 50%, #EBB9FF 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero__dek {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--text-muted);
  max-width: 60ch;
  margin-bottom: var(--sp-7);
}

.hero__byline {
  display: flex;
  gap: var(--sp-5);
  font-size: var(--fs-body-sm);
  color: var(--text-subtle);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--rule);
}

.hero__byline dt {
  color: rgba(13, 15, 26, 0.35);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  font-size: var(--fs-caption);
  margin-bottom: 2px;
}

.hero__byline dd {
  color: rgba(13, 15, 26, 0.60);
  font-size: var(--fs-body-sm);
}

.hero__byline > div {
  min-width: 10ch;
}

/* ============================================================
   Huge stat display
   ============================================================ */
.stat-display {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--rule);
}

.stat-display__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-8);
}

.big-number {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.big-number__value {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
}

/* Range variant: scales down so "$60.5B to $108.5B" fits cleanly, with the connector styled editorially. */
.big-number__value--range {
  font-size: clamp(1.875rem, 3vw, 2.75rem);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.05em;
}

.big-number__to-group {
  display: inline-flex;
  align-items: baseline;
  gap: 0.35em;
  white-space: nowrap;
}

.big-number__sep {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.55em;
  color: var(--text-muted);
  font-weight: 400;
  letter-spacing: 0;
}

.big-number__label {
  font-size: var(--fs-body);
  color: var(--text-muted);
  line-height: var(--lh-snug);
  max-width: 32ch;
}

.big-number__context {
  font-size: var(--fs-caption);
  color: #8B6CFF;
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  margin-top: var(--sp-2);
}

/* ============================================================
   Section scaffolding
   ============================================================ */
.section {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--rule);
}

.section__head {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-bottom: var(--sp-7);
  max-width: 60ch;
}

.section__title {
  font-family: var(--font-display);
  font-size: var(--fs-display-md);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  font-weight: 400;
}

.section__dek {
  color: var(--text-muted);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
}

/* Dark section typography overrides */
.section--dark .eyebrow {
  color: #ADABE9;
}

.section--dark .section__title,
.section--dark .proto__title {
  color: #F8F9FA;
}

.section--dark .section__dek,
.section--dark .proto__dek {
  color: rgba(248, 249, 250, 0.60);
}

.section--dark .section__dek strong,
.section--dark .proto__dek strong {
  color: #F8F9FA;
}

/* ============================================================
   Industry row / bar chart
   ============================================================ */
.industry-bars {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.industry-bar {
  display: grid;
  grid-template-columns: 180px 1fr 150px;
  align-items: center;
  gap: var(--sp-5);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--rule);
  font-size: var(--fs-body-sm);
}

.industry-bar:last-child {
  border-bottom: none;
}

.industry-bar__label {
  color: var(--text);
  font-weight: 500;
}

.industry-bar__track {
  height: 8px;
  background: var(--bg-sunken);
  border-radius: 0;
  position: relative;
  overflow: hidden;
}

.industry-bar__fill {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: var(--accent);
  transform-origin: left;
  transition: transform var(--dur-slow) var(--ease-out);
}

.industry-bar__fill--range {
  background: var(--accent-muted);
  border-right: 2px solid var(--accent);
}

.industry-bar__value {
  text-align: right;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum", "ss01";
}

@media (max-width: 640px) {
  .industry-bar {
    grid-template-columns: 1fr;
    gap: var(--sp-2);
  }
  .industry-bar__value {
    text-align: left;
  }
}

/* ============================================================
   Top-10 companies table
   ============================================================ */
.company-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-body-sm);
}

.company-table thead th {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 2px solid var(--rule-strong);
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
  font-weight: 500;
}

.company-table tbody td {
  padding: var(--sp-4);
  border-bottom: 1px solid var(--rule);
  vertical-align: baseline;
}

.company-table .num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum", "ss01";
}

.company-table .rank {
  color: var(--text-subtle);
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
}

.company-table .name {
  font-weight: 500;
}

.company-table .industry-tag {
  color: var(--text-muted);
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
}

.company-table tr:hover td {
  background: var(--bg-sunken);
}

/* ============================================================
   CTA callouts
   ============================================================ */
.cta-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--sp-5);
  padding: var(--sp-9) 0;
}

.cta-card {
  padding: var(--sp-7);
  border: 1px solid var(--rule);
  background: var(--bg-elevated);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}

.cta-card:hover {
  border-color: rgba(139, 108, 255, 0.3);
  transform: translateY(-2px);
}

.cta-card__kicker {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: #8B6CFF;
}

.cta-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-display-sm);
  line-height: var(--lh-snug);
  letter-spacing: var(--letter-snug);
  margin-top: var(--sp-2);
}

.cta-card__body {
  color: var(--text-muted);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  flex: 1;
}

.cta-card__arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  color: #8B6CFF;
  font-weight: 500;
  font-size: var(--fs-body-sm);
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
  align-self: flex-start;
  margin-top: var(--sp-3);
}

.cta-card__arrow::after {
  content: "→";
  transition: transform var(--dur-quick) var(--ease-out);
}

.cta-card:hover .cta-card__arrow::after {
  transform: translateX(4px);
}

/* ============================================================
   Primary CTA section (between pull-quote and methodology card)
   ============================================================ */
.primary-cta-section {
  padding: var(--sp-9) 0;
}

.primary-cta {
  padding: var(--sp-8) var(--sp-7);
  background: var(--accent-muted);
  border: 1px solid rgba(139, 108, 255, 0.18);
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-4);
}

.primary-cta__kicker {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
  margin: 0;
}

.primary-cta__title {
  font-size: var(--fs-display-md);
  line-height: 1.1;
  letter-spacing: var(--letter-tight);
  margin: 0;
  color: var(--text);
}

.primary-cta__dek {
  font-size: var(--fs-body);
  line-height: 1.6;
  color: var(--text-muted);
  margin: 0;
  max-width: 52ch;
}

.primary-cta__button {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
  padding: var(--sp-4) var(--sp-6);
  background: #4b2fb9;
  color: #FFFFFF;
  font-weight: 600;
  font-size: var(--fs-body);
  letter-spacing: var(--letter-normal);
  text-decoration: none;
  border-radius: 60px;
  transition: background var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}

.primary-cta__button:hover {
  background: var(--accent);
  color: #000000;
  transform: translateY(-2px);
}

.primary-cta__arrow {
  transition: transform var(--dur-quick) var(--ease-out);
  display: inline-block;
}

.primary-cta__button:hover .primary-cta__arrow {
  transform: translateX(4px);
}

/* ============================================================
   Footer
   ============================================================ */
.site-footer {
  padding: var(--sp-8) 0;
  border-top: none;
  color: var(--text-subtle);
  font-size: var(--fs-body-sm);
}

.site-footer__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-6);
}

.site-footer__col h4 {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text);
  font-family: var(--font-body);
  font-weight: 500;
  margin-bottom: var(--sp-3);
}

.site-footer__col ul {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.site-footer__col a {
  color: var(--text-muted);
}

.site-footer__col a:hover {
  color: var(--text);
}

.site-footer__legal {
  margin-top: var(--sp-7);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--rule);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
  font-size: var(--fs-caption);
}

/* ============================================================
   Explorer: controls
   ============================================================ */
.explorer-controls {
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--rule);
  background: var(--bg);
  position: sticky;
  top: var(--nav-h, 57px);
  z-index: 9;
  backdrop-filter: saturate(1.2) blur(8px);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
}

.explorer-controls__row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-6);
  align-items: center;
  justify-content: space-between;
}

.callout-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  font-size: var(--fs-body-sm);
}

.callout-tabs button {
  border-bottom: 1px solid transparent;
  padding: var(--sp-2) 0;
  color: var(--text-muted);
  font-weight: 500;
  letter-spacing: var(--letter-snug);
  transition: color var(--dur-quick) var(--ease-out), border-color var(--dur-quick) var(--ease-out);
}

.callout-tabs button:hover {
  color: var(--text);
}

.callout-tabs button[aria-pressed="true"] {
  color: var(--text);
  border-bottom-color: var(--text);
}

.callout-tabs .count {
  font-variant-numeric: tabular-nums;
  color: var(--text-subtle);
  font-size: var(--fs-caption);
  margin-left: var(--sp-2);
  letter-spacing: var(--letter-caps);
}

.explorer-filters {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  font-size: var(--fs-body-sm);
}

.explorer-filters label {
  color: var(--text-subtle);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  font-size: var(--fs-caption);
}

.select-bare {
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--rule-strong);
  padding: var(--sp-2) var(--sp-5) var(--sp-2) 0;
  font-family: var(--font-body);
  font-size: var(--fs-body-sm);
  color: var(--text);
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='7' viewBox='0 0 12 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230E0E10' stroke-width='1.2'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right center;
}

.select-bare:focus {
  outline: none;
  border-bottom-color: var(--text);
}

/* ============================================================
   Explorer: callout header (when a callout is selected)
   ============================================================ */
.callout-header {
  padding: var(--sp-7) 0 var(--sp-6);
  border-bottom: 1px solid var(--rule);
}

.callout-header__title {
  font-family: var(--font-display);
  font-size: var(--fs-display-md);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  font-weight: 400;
  margin-bottom: var(--sp-3);
}

.callout-header__summary {
  color: var(--text-muted);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  max-width: 64ch;
}

.callout-header__stats {
  display: flex;
  gap: var(--sp-7);
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--rule);
  flex-wrap: wrap;
}

.callout-header__stats dt {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: var(--sp-1);
}

.callout-header__stats dd {
  font-family: var(--font-display);
  font-size: var(--fs-display-sm);
  font-variant-numeric: tabular-nums;
  color: var(--text);
}

/* ============================================================
   Explorer: ranked company list
   ============================================================ */
.company-list {
  display: flex;
  flex-direction: column;
}

.company-row {
  display: grid;
  grid-template-columns: 60px minmax(180px, 1.2fr) 160px 120px 1fr 160px;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--rule);
  text-decoration: none;
  color: inherit;
  transition: background var(--dur-quick) var(--ease-out);
}

.company-row:hover {
  background: var(--bg-sunken);
}

.company-row:hover .company-row__name {
  color: var(--accent);
}

.company-row__rank {
  font-family: var(--font-display);
  font-size: var(--fs-body);
  color: var(--text-subtle);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--letter-caps);
}

.company-row__name {
  font-size: var(--fs-body-lg);
  font-weight: 500;
  line-height: var(--lh-snug);
  transition: color var(--dur-quick) var(--ease-out);
}

.company-row__ticker {
  font-size: var(--fs-caption);
  color: var(--text-subtle);
  letter-spacing: var(--letter-caps);
  margin-left: var(--sp-2);
}

.company-row__industry {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-muted);
}

.company-row__employees {
  font-size: var(--fs-body-sm);
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
  text-align: right;
}

.company-row__bar {
  position: relative;
  height: 10px;
  background: var(--bg-sunken);
  overflow: hidden;
}

.company-row__bar-range {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: var(--accent-muted);
}

.company-row__bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: var(--accent);
}

.company-row__impact {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body-sm);
  color: var(--text);
}

.company-row__impact-context {
  display: block;
  font-size: var(--fs-caption);
  color: var(--text-subtle);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  margin-top: 2px;
}

.company-row__tags {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-top: var(--sp-1);
}

.callout-tag {
  font-size: 0.6875rem;
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent-muted);
  padding: 2px var(--sp-2);
  background: var(--accent-muted);
  line-height: 1.4;
}

@media (max-width: 900px) {
  .company-row {
    grid-template-columns: 40px 1fr 140px;
    grid-template-areas:
      "rank name impact"
      ". industry ."
      ". bar bar"
      ". employees employees";
    row-gap: var(--sp-2);
  }
  .company-row__rank { grid-area: rank; }
  .company-row__name { grid-area: name; }
  .company-row__industry { grid-area: industry; }
  .company-row__bar { grid-area: bar; }
  .company-row__employees { grid-area: employees; text-align: left; }
  .company-row__impact { grid-area: impact; }
}

/* ============================================================
   Explorer: results summary strip
   ============================================================ */
.results-summary {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--sp-5) 0;
  border-bottom: 1px solid var(--rule);
  color: var(--text-muted);
  font-size: var(--fs-body-sm);
  flex-wrap: wrap;
  gap: var(--sp-4);
}

.results-summary__count {
  font-family: var(--font-display);
  font-size: var(--fs-display-sm);
  color: var(--text);
  letter-spacing: var(--letter-tight);
}

.results-summary__total {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.results-summary__meta {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
}

/* ============================================================
   Per-company page
   ============================================================ */
.company-page__breadcrumb {
  padding: var(--sp-5) 0 0;
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
}

.company-page__breadcrumb a {
  color: var(--text-muted);
  border-bottom: 1px solid transparent;
}

.company-page__breadcrumb a:hover {
  color: var(--text);
  border-bottom-color: currentColor;
}

.company-page__header {
  padding: var(--sp-6) 0 var(--sp-8);
  border-bottom: 1px solid var(--rule);
}

.company-page__name {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  font-weight: 400;
  margin-bottom: var(--sp-3);
}

.company-page__rank {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--text-subtle);
  font-size: var(--fs-body-lg);
  margin-left: var(--sp-3);
}

.company-page__meta {
  display: flex;
  gap: var(--sp-6);
  margin-top: var(--sp-5);
  flex-wrap: wrap;
  font-size: var(--fs-body-sm);
  color: var(--text-muted);
}

.company-page__meta dt {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
  margin-bottom: 2px;
}

.company-page__meta dd {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

.company-page__hero-impact {
  margin-top: var(--sp-7);
  padding-top: var(--sp-7);
  border-top: 1px solid var(--rule);
}

.company-page__hero-impact .big-number__value {
  font-size: clamp(3.5rem, 8vw, 6rem);
}

.company-page__hero-impact .big-number__label {
  max-width: 48ch;
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--text);
}

/* Two-model comparison */
.model-comparison {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-6);
  padding: var(--sp-8) 0;
}

.model-card {
  padding: var(--sp-6);
  border: 1px solid var(--rule);
  background: var(--bg-elevated);
}

.model-card__label {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
}

.model-card__source {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-body);
  color: var(--text-muted);
  margin-top: var(--sp-1);
}

.model-card__value {
  font-family: var(--font-display);
  font-size: var(--fs-display-md);
  line-height: var(--lh-tight);
  letter-spacing: var(--letter-tight);
  font-variant-numeric: tabular-nums;
  color: var(--accent);
  margin: var(--sp-4) 0 var(--sp-2);
  font-weight: 400;
}

.model-card__detail {
  display: flex;
  justify-content: space-between;
  padding: var(--sp-3) 0;
  border-top: 1px solid var(--rule);
  font-size: var(--fs-body-sm);
}

.model-card__detail:first-of-type {
  margin-top: var(--sp-4);
}

.model-card__detail dt {
  color: var(--text-muted);
}

.model-card__detail dd {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

/* Formula section */
.formula {
  padding: var(--sp-6);
  background: var(--bg-sunken);
  border-left: 3px solid var(--accent);
  font-family: var(--font-body);
  font-size: var(--fs-body-sm);
  line-height: var(--lh-relaxed);
  color: var(--text);
  margin: var(--sp-5) 0;
}

.formula code {
  font-family: "JetBrains Mono", "SF Mono", Consolas, monospace;
  background: var(--bg-elevated);
  padding: 2px 6px;
  font-size: 0.8125rem;
  color: var(--accent);
}

/* ============================================================
   Press kit / methodology
   ============================================================ */
.press-section {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--rule);
}

.press-grid {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--sp-7);
  align-items: start;
}

@media (max-width: 720px) {
  .press-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
}

.press-grid__aside {
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
  position: sticky;
  top: 100px;
}

.press-grid__body {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--text);
  max-width: 68ch;
}

.press-grid__body p {
  margin-bottom: var(--sp-5);
  color: var(--text-muted);
}

.press-grid__body p strong,
.press-grid__body p em {
  color: var(--text);
}

.press-grid__body h3 {
  font-family: var(--font-display);
  font-size: var(--fs-display-sm);
  line-height: var(--lh-snug);
  letter-spacing: var(--letter-snug);
  margin: var(--sp-6) 0 var(--sp-3);
  color: var(--text);
}

.citation {
  padding: var(--sp-5);
  border: 1px solid var(--rule);
  background: var(--bg-elevated);
  margin: var(--sp-5) 0;
  font-size: var(--fs-body-sm);
  line-height: var(--lh-relaxed);
}

.citation__source {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-body);
  color: var(--text);
  margin-bottom: var(--sp-2);
}

.citation__meta {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
  padding-top: var(--sp-3);
  margin-top: var(--sp-3);
  border-top: 1px solid var(--rule);
  font-size: var(--fs-caption);
  letter-spacing: var(--letter-caps);
  text-transform: uppercase;
  color: var(--text-subtle);
}

.citation a {
  color: var(--accent);
  border-bottom: 1px solid currentColor;
}

.formula-block {
  padding: var(--sp-6);
  background: var(--bg-sunken);
  border-left: 3px solid var(--accent);
  margin: var(--sp-5) 0;
}

.formula-block code {
  font-family: "JetBrains Mono", "SF Mono", Consolas, monospace;
  font-size: 0.875rem;
  color: var(--text);
  display: block;
  padding: var(--sp-2) 0;
}

.formula-block code .op { color: var(--text-subtle); }
.formula-block code .lit { color: var(--accent); }

/* ============================================================
   Pull quote / editorial aside
   ============================================================ */
.pull-quote-section {
  padding: var(--sp-10) 0;
}

.pull-quote {
  font-family: var(--font-display);
  font-size: var(--fs-display-md);
  line-height: var(--lh-snug);
  letter-spacing: var(--letter-tight);
  font-weight: 700;
  color: var(--text);
  max-width: 32ch;
  margin: 0 auto;
  padding: 0 var(--sp-5) 0 var(--sp-8);
  text-align: left;
  border-left: 2px solid rgba(255, 126, 74, 0.5);
}

.section--dark .pull-quote {
  background: linear-gradient(90deg, #FF7E4A 0%, #BB7AFF 50%, #EBB9FF 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* -- Human-layer section ------------------------------------------------- */
.human-layer__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-5);
  margin-top: var(--sp-6);
}

.human-layer__card {
  margin: 0;
  padding: var(--sp-5) var(--sp-5) var(--sp-6);
  background: var(--bg-subtle, rgba(187, 122, 255, 0.06));
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-sm, 4px);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.human-layer__stat {
  font-family: var(--font-display, inherit);
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  line-height: 1;
  color: var(--accent);
  letter-spacing: -0.02em;
}

.human-layer__card figcaption {
  color: var(--text-muted);
  font-size: var(--fs-body);
  line-height: 1.55;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.human-layer__card figcaption strong {
  color: var(--text);
  font-weight: 600;
}

.human-layer__card cite {
  display: block;
  margin-top: var(--sp-2);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--rule);
  font-size: var(--fs-caption);
  font-style: normal;
  color: var(--text-subtle);
  letter-spacing: 0.02em;
}

.human-layer__card cite sup {
  color: var(--accent);
  font-weight: 500;
}

.human-layer__note {
  margin-top: var(--sp-6);
  color: var(--text-muted);
  font-style: italic;
  font-size: var(--fs-body);
  max-width: 60ch;
}
