/* =============================================================================
   EuroSTAR — Blocks 3 & 4 shared styles
   Respects the existing sponsor-hero / sponsor-value-props palette vocabulary.
   All colors pull from --scheme-* CSS vars so the Tweaks dropdown can swap them.
   ============================================================================= */

:root {
  --es-font: "Google Sans Flex", "Google Sans", "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --es-navy: #141b4d;
  --es-radius-lg: 28px;
  --es-radius-md: 20px;
  --es-radius-sm: 14px;
}

/* ---------- Palette schemes ---------- */
/* Match the sponsor-hero / value-props palette so blocks stack cleanly. */
.es-scheme-sky {
  --es-outer-bg: #c2e7ff;
  --es-inner-bg: #047db7;
  --es-text:     #ffffff;
  --es-muted:    rgba(255,255,255,0.82);
  --es-card-bg:  rgba(255,255,255,0.10);
  --es-card-border: rgba(255,255,255,0.22);
  --es-accent:   #7fcfff;
  --es-accent-2: #141b4d;
  /* slice palette — blues + navy accents */
  --es-slice-1: #ffffff;
  --es-slice-2: #7fcfff;
  --es-slice-3: #c2e7ff;
  --es-slice-4: #141b4d;
  --es-slice-5: #5fa9ff;
  --es-slice-6: #8b5cf6;
  --es-slice-7: #f26e8f;
}

.es-scheme-berry {
  --es-outer-bg: #fedadb;
  --es-inner-bg: #852e43;
  --es-text:     #ffffff;
  --es-muted:    rgba(255,255,255,0.82);
  --es-card-bg:  rgba(255,255,255,0.10);
  --es-card-border: rgba(255,255,255,0.22);
  --es-accent:   #f26e8f;
  --es-accent-2: #141b4d;
  --es-slice-1: #ffffff;
  --es-slice-2: #f26e8f;
  --es-slice-3: #fedadb;
  --es-slice-4: #141b4d;
  --es-slice-5: #d85e7d;
  --es-slice-6: #7fcfff;
  --es-slice-7: #8b5cf6;
}

.es-scheme-mint {
  --es-outer-bg: #7fffd4;
  --es-inner-bg: #138b83;
  --es-text:     #ffffff;
  --es-muted:    rgba(255,255,255,0.82);
  --es-card-bg:  rgba(255,255,255,0.10);
  --es-card-border: rgba(255,255,255,0.22);
  --es-accent:   #06e0b4;
  --es-accent-2: #141b4d;
  --es-slice-1: #ffffff;
  --es-slice-2: #06e0b4;
  --es-slice-3: #7fffd4;
  --es-slice-4: #141b4d;
  --es-slice-5: #1ec9a0;
  --es-slice-6: #f26e8f;
  --es-slice-7: #7fcfff;
}

.es-scheme-navy {
  --es-outer-bg: #0a0f33;
  --es-inner-bg: #141b4d;
  --es-text:     #ffffff;
  --es-muted:    rgba(255,255,255,0.78);
  --es-card-bg:  rgba(255,255,255,0.06);
  --es-card-border: rgba(255,255,255,0.16);
  --es-accent:   #7fcfff;
  --es-accent-2: #f26e8f;
  --es-slice-1: #7fcfff;
  --es-slice-2: #f26e8f;
  --es-slice-3: #06e0b4;
  --es-slice-4: #8b5cf6;
  --es-slice-5: #ffc66b;
  --es-slice-6: #ffffff;
  --es-slice-7: #c2e7ff;
}

/* =============================================================================
   Page chrome (mock site container)
   ============================================================================= */
body {
  margin: 0;
  font-family: var(--es-font);
  background: #ffffff;
  color: var(--es-navy);
  -webkit-font-smoothing: antialiased;
}
.site-container { max-width: 100%; margin: 0 auto; }

/* =============================================================================
   Block 3 — common
   ============================================================================= */

.es-stats {
  background-color: var(--es-outer-bg);
  padding: 80px 0;
  width: 100%;
  font-family: var(--es-font);
}
.es-stats__inner {
  max-width: 1360px;
  width: calc(100% - 40px);
  margin: 0 auto;
  /*background: var(--es-inner-bg);*/
  color: var(--es-text);
  border-radius: var(--es-radius-lg);
  padding: 56px 56px 64px;
  box-sizing: border-box;
}

.es-stats__eyebrow {
  margin: 0 0 12px;
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--es-text);
  opacity: 0.78;
}
.es-stats__heading {
  font-family: var(--es-font);
  margin: 0 0 16px;
  font-size: 46px;
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--es-text);
  max-width: 20ch;
  text-wrap: balance;
}
.es-stats__intro {
  margin: 0;
  font-size: 18px;
  line-height: 1.55;
  color: var(--es-muted);
  max-width: 62ch;
}
.es-stats__intro--side { max-width: 48ch; }

/* shared number style */
.es-stat-num {
  display: inline-flex;
  align-items: baseline;
  font-family: var(--es-font);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--es-text);
  font-variant-numeric: tabular-nums;
  line-height: 0.95;
}
.es-stat-suffix {
  font-size: 0.55em;
  margin-left: 0.04em;
  color: var(--es-accent);
  font-weight: 600;
}

/* ---- Option A: grid ---- */
.es-stats--grid .es-stats__head { margin-bottom: 44px; max-width: 780px; }
.es-stats__grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.es-stat-card {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 28px 26px 26px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 240px;
  opacity: 0;
  transform: translateY(18px);
  animation: es-rise 700ms cubic-bezier(.2,.7,.3,1) forwards;
  animation-delay: inherit;
}
.es-stats--grid .es-stat-card { animation-delay: calc(var(--i, 0) * 80ms); }
.es-stat-card__icon {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  border-radius: 14px;
  background: rgba(255,255,255,0.18);
  color: var(--es-accent);
  margin-bottom: 4px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}
.es-stat-card__label {
  font-size: 20px;
  font-weight: 600;
  margin: 8px 0 0;
  color: var(--es-text);
  line-height: 1.2;
}
.es-stat-card__sub {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--es-muted);
}

/* ---- Option B: editorial ---- */
.es-editorial {
  display: grid;
  grid-template-columns: 1.05fr 1.1fr;
  gap: 48px;
  align-items: center;
  padding-bottom: 40px;
  border-bottom: 1px solid var(--es-card-border);
  margin-bottom: 40px;
}
.es-editorial__left .es-stats__heading { font-size: 56px; max-width: 14ch; }
.es-editorial__hero {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 8px 24px;
  align-items: end;
  position: relative;
}
.es-editorial__hero-icon {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  align-self: start;
  width: 64px; height: 64px;
  display: grid; place-items: center;
  border-radius: 16px;
  background: var(--es-accent);
  color: var(--es-navy);
  box-shadow: 0 4px 18px rgba(0,0,0,0.18);
}
.es-editorial__hero .es-stat-num {
  grid-column: 1 / -1;
  grid-row: 2 / 3;
}
.es-editorial__hero-meta {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  align-self: end;
}
.es-editorial__hero-meta h3 {
  margin: 0 0 4px;
  font-size: 24px;
  font-weight: 600;
  color: var(--es-text);
}
.es-editorial__hero-meta p {
  margin: 0;
  font-size: 15px;
  color: var(--es-muted);
  line-height: 1.5;
}

.es-editorial__row {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.es-editorial__item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-left: 20px;
  border-left: 2px solid var(--es-card-border);
}
.es-editorial__item h3 {
  margin: 6px 0 4px;
  font-size: 18px;
  font-weight: 600;
  color: var(--es-text);
}
.es-editorial__item p {
  margin: 0;
  font-size: 14px;
  color: var(--es-muted);
  line-height: 1.5;
}
.es-editorial__icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: rgba(255,255,255,0.18);
  color: var(--es-accent);
  margin-bottom: 4px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}
.es-ticker__icon {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: 11px;
  background: rgba(255,255,255,0.16);
  color: var(--es-accent);
  flex: 0 0 auto;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12);
}

/* ---- Option C: ticker ---- */
.es-ticker__head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: end;
  margin-bottom: 48px;
}
.es-ticker__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--es-card-border);
}
.es-ticker__cell {
  padding: 28px 28px 24px;
  position: relative;
  border-right: 1px solid var(--es-card-border);
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 260px;
}
.es-ticker__cell:last-child { border-right: none; }
.es-ticker__bar {
  position: absolute;
  top: 0; left: 0; right: 1px;
  height: 4px;
  overflow: hidden;
  background: rgba(255,255,255,0.08);
}
.es-ticker__bar span {
  display: block;
  height: 100%;
  width: 0;
  background: var(--es-accent);
  animation: es-bar 1400ms cubic-bezier(.2,.7,.3,1) forwards;
}
@keyframes es-bar { to { width: 100%; } }

.es-ticker__num { margin-top: 12px; }
.es-ticker__meta {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  color: var(--es-accent);
  margin-top: auto;
}
.es-ticker__meta h3 {
  margin: 0 0 4px;
  font-size: 18px;
  color: var(--es-text);
  font-weight: 600;
}
.es-ticker__meta p {
  margin: 0;
  color: var(--es-muted);
  font-size: 14px;
  line-height: 1.5;
}

@keyframes es-rise {
  to { opacity: 1; transform: translateY(0); }
}

/* =============================================================================
   Block 4 — common
   ============================================================================= */

.es-aud {
  background-color: var(--es-outer-bg);
  padding: 80px 0;
  width: 100%;
  font-family: var(--es-font);
}
.es-aud__inner {
  max-width: 1360px;
  width: calc(100% - 40px);
  margin: 0 auto;
  background: var(--es-inner-bg);
  color: var(--es-text);
  border-radius: var(--es-radius-lg);
  padding: 56px 56px 64px;
  box-sizing: border-box;
}
.es-aud__head { margin-bottom: 48px; max-width: 780px; }
.es-aud__head--wide { max-width: 880px; }
.es-aud__eyebrow {
  margin: 0 0 12px;
  font-size: 14px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  opacity: 0.78;
}
.es-aud__heading {
  margin: 0 0 16px;
  font-size: 46px;
  line-height: 1.05;
  font-weight: 600;
  letter-spacing: 0.01em;
  max-width: 20ch;
  text-wrap: balance;
  color: var(--es-text);
}
.es-aud__intro {
  margin: 0;
  font-size: 18px;
  line-height: 1.55;
  color: var(--es-muted);
  max-width: 62ch;
}
.es-aud__intro--side { max-width: 44ch; }

/* Chart shared */
.es-chart__svg { display: block; width: 100%; height: auto; }
.es-chart__slice { stroke: var(--es-inner-bg); stroke-width: 2; }
.es-chart__center-num {
  font-family: var(--es-font);
  font-size: 24px;
  font-weight: 700;
  fill: var(--es-text);
}
.es-chart__center-lbl {
  font-family: var(--es-font);
  font-size: 11px;
  fill: var(--es-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Legend */
.es-legend {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
/* Override theme's .entry-content ul { margin-left: 40px } which beats .es-legend alone */
.es-aud-outer .es-legend,
.es-stats-outer .es-legend {
  margin-left: 0 !important;
  margin-bottom: 0 !important;
}
.es-legend li {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 10px;
  align-items: center;
  font-size: 14px;
  color: var(--es-muted);
  line-height: 1.3;
}
.es-legend__sw {
  width: 12px; height: 12px;
  border-radius: 3px;
  display: block;
}
.es-legend__lbl { color: var(--es-text); }
.es-legend__pct {
  font-variant-numeric: tabular-nums;
  color: var(--es-muted);
  font-weight: 600;
}
.es-legend--compact li { font-size: 13px; gap: 8px; }

/* Row-card (ticker layout) — slightly tighter legend so labels don't wrap */
.es-row-card .es-legend li {
  font-size: 13px;
  gap: 8px;
}

/* ---- Option A: grid of 4 donuts ---- */
.es-aud__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.es-aud-card {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 24px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.es-aud-card__title {
  margin: 0;
  font-size: 17px;
  font-weight: 600;
  color: var(--es-text);
  line-height: 1.3;
  min-height: 2.6em;
}
.es-aud-card__chart {
  width: 100%;
  display: grid;
  place-items: center;
  padding: 4px 0 8px;
}

/* ---- Option B: editorial (hero + 3 small) ---- */
.es-ed-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
}
.es-ed-hero {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 32px;
  display: grid;
  gap: 20px;
}
.es-ed-hero h3 {
  margin: 0;
  font-size: 22px;
  font-weight: 600;
  color: var(--es-text);
}
.es-ed-hero__chart {
  display: grid;
  place-items: center;
}
.es-ed-rest {
  display: grid;
  gap: 16px;
}
.es-ed-small {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 20px 22px;
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 20px;
  align-items: center;
}
.es-ed-small__chart { width: 160px; }
.es-ed-small h3 {
  margin: 0 0 10px;
  font-size: 16px;
  font-weight: 600;
  color: var(--es-text);
}

/* ---- Option C: horizontal row of semicircle ---- */
.es-row__head {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: end;
  margin-bottom: 48px;
}
.es-row__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.es-row-card {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 22px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.es-row-card__title {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: var(--es-text);
  line-height: 1.25;
}
.es-row-card__chart {
  position: relative;
  display: grid;
  place-items: center;
  padding: 0;
  margin-top: -40px;
}
.es-row-card__chart .es-chart__svg {
  display: block;
  width: 78%;
  max-width: 200px;
  height: auto;
}

/* Stat sits centered inside the semicircle's open base — not below the SVG */
.es-row-card__overlay {
  position: absolute;
  left: 0; right: 0;
  /* The semi SVG viewBox is size x (size * 0.78) and the chart center sits at
     cy = size * 0.72. The overlay is anchored to the chart center so it visually
     drops inside the arc regardless of card width. */
  bottom: 8%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  pointer-events: none;
}
.es-row-card__num {
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 700;
  color: var(--es-text);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.es-row-card__lbl {
  font-size: 10px;
  color: var(--es-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.25;
  text-wrap: balance;
  word-break: break-word;
  hyphens: auto;
  /* Sits below the arch as a standalone element — centred, with a little breathing room */
  display: block;
  text-align: center;
  padding: 4px 8px 0;
  margin-top: -10px;
  margin-bottom: 15px;
}

/* Caption sits between the chart and the legend — the "top segment" name.
   Stays clear of the SVG so long names don't bleed across card edges. */
.es-row-card__caption {
  font-size: 11px;
  font-weight: 600;
  color: var(--es-text);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.3;
  padding: 0 8px;
  margin-top: -10px;
  text-wrap: balance;
  word-break: break-word;
}

/* Variant 2 — semi-tight: stat sits on the base of the semicircle */
.es-row-card--semi .es-row-card__semi-wrap {
  position: relative;
  display: grid;
  place-items: center;
  margin-top: -8px;
}
.es-row-card--semi .es-chart__svg { display: block; width: 100%; height: auto; }
.es-row-card--semi .es-row-card__semi-stat {
  position: absolute;
  left: 0; right: 0;
  bottom: 6px;
  text-align: center;
  display: grid;
  gap: 4px;
  pointer-events: none;
}

/* Variant 3 — split: chart left, stat + legend right */
.es-row-card--stack .es-row-card__split {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 14px;
  align-items: center;
}
.es-row-card--stack .es-row-card__split .es-chart__svg { display: block; width: 100%; height: auto; }
.es-row-card--stack .es-row-card__split-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.es-row-card--stack .es-row-card__split-body .es-legend { margin-top: 6px; }
.es-row-card--stack .es-row-card__split-body .es-row-card__num {
  font-size: clamp(22px, 2vw, 28px);
}

/* =============================================================================
   Option label (small tag above each variation in design canvas)
   ============================================================================= */
.es-option-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--es-navy);
  color: #fff;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  margin: 18px 0 0 28px;
}
.es-option-tag span { opacity: 0.7; }

/* =============================================================================
   Responsive
   ============================================================================= */
@media only screen and (max-width: 1100px) {
  .es-stats__inner, .es-aud__inner { padding: 40px 32px 48px; }
  .es-stats__grid, .es-aud__grid, .es-row__grid { grid-template-columns: repeat(2, 1fr); }
  .es-row-card__chart { margin-top: -24px; }
  .es-row-card--stack .es-row-card__split { grid-template-columns: 110px 1fr; }
  .es-row__head { grid-template-columns: 1fr; gap: 8px; }
  .es-ticker__row { grid-template-columns: repeat(2, 1fr); }
  .es-ticker__cell:nth-child(2) { border-right: none; }
  .es-ticker__cell:nth-child(-n+2) { border-bottom: 1px solid var(--es-card-border); }
  .es-editorial { grid-template-columns: 1fr; gap: 32px; }
  .es-editorial__row { grid-template-columns: 1fr; gap: 20px; }
  .es-ed-layout { grid-template-columns: 1fr; }
}
@media only screen and (max-width: 640px) {
  .es-stats, .es-aud { padding: 40px 0; }
  .es-stats__inner, .es-aud__inner { padding: 28px 20px 36px; border-radius: 20px; }
  .es-stats__heading, .es-aud__heading { font-size: 34px; }
  .es-editorial__left .es-stats__heading { font-size: 38px; }
  .es-stats__grid, .es-aud__grid, .es-row__grid { grid-template-columns: 1fr; }
  .es-row-card__chart { margin-top: -16px; }
  .es-row-card--stack .es-row-card__split { grid-template-columns: 100px 1fr; }
  .es-ticker__row { grid-template-columns: 1fr; }
  .es-ticker__cell { border-right: none; border-bottom: 1px solid var(--es-card-border); }
  .es-ticker__cell:last-child { border-bottom: none; }
  .es-ed-small { grid-template-columns: 1fr; }
}

/* =============================================================================
   Fixes — PHP class names vs prototype CSS reconciliation
   ============================================================================= */

/* --- Full-width breakout — matches sponsor-hero-outer--full technique --- */
.es-stats-outer--full,
.es-aud-outer--full {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
/* Override Genesis .wrap constraints inside full-width blocks */
.es-stats-outer--full > .wrap,
.es-aud-outer--full > .wrap {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  float: none !important;
}

/* --- Suffix accent colour (+ sign after numbers) --- */
.es-stat-suffix {
  font-size: 0.52em;
  margin-left: 0.06em;
  color: var(--es-accent);
  font-weight: 700;
  vertical-align: baseline;
}

/* --- Editorial layout: hero number --- */
.es-editorial__hero-num {
  grid-column: 1 / -1;
  grid-row: 2 / 3;
  font-family: var(--es-font);
  font-size: clamp(80px, 10vw, 140px);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 0.9;
  color: var(--es-text);
  font-variant-numeric: tabular-nums;
}

/* --- Editorial row spans full card width (direct grid child, both columns) --- */
.es-editorial {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}
.es-editorial__row {
  grid-column: 1 / -1;
  border-top: 1px solid var(--es-card-border);
  padding-top: 40px;
  margin-top: 8px;
}

/* --- Editorial layout: supporting stat cells --- */
.es-editorial__cell {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-left: 20px;
  border-left: 2px solid var(--es-card-border);
}
.es-editorial__cell-num {
  font-family: var(--es-font);
  font-size: clamp(36px, 3.5vw, 52px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--es-text);
  font-variant-numeric: tabular-nums;
}
.es-editorial__cell h4 {
  margin: 4px 0 0;
  font-size: 16px;
  font-weight: 600;
  color: var(--es-text);
  line-height: 1.2;
}
.es-editorial__cell p {
  margin: 0;
  font-size: 14px;
  color: var(--es-muted);
  line-height: 1.5;
}

/* --- Ticker layout: number size, label, sub --- */
.es-ticker__num {
  font-family: var(--es-font);
  font-size: clamp(40px, 4vw, 58px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--es-text);
  font-variant-numeric: tabular-nums;
}
.es-ticker__label {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: var(--es-text);
  line-height: 1.2;
}
.es-ticker__sub {
  margin: 0;
  font-size: 14px;
  color: var(--es-muted);
  line-height: 1.5;
}

/* --- Grid layout: stat card number --- */
.es-stat-card__num {
  font-family: var(--es-font);
  font-size: clamp(40px, 4vw, 56px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--es-text);
  font-variant-numeric: tabular-nums;
}

/* --- Legend percentage value --- */
.es-legend__val {
  font-variant-numeric: tabular-nums;
  color: var(--es-muted);
  font-weight: 600;
}

/* --- Block 4 editorial: missing card/body rules --- */
.es-ed-head { margin-bottom: 36px; }
.es-ed-hero__body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.es-ed-small {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: none;
  border: none;
  padding: 0;
  border-radius: 0;
}
.es-ed-small__card {
  background: var(--es-card-bg);
  border: 1px solid var(--es-card-border);
  border-radius: var(--es-radius-md);
  padding: 20px 22px;
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 16px;
  align-items: center;
}
.es-ed-small__card h4 {
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 600;
  color: var(--es-text);
  line-height: 1.3;
}
.es-ed-small__chart { width: 130px; }

@media only screen and (max-width: 640px) {
  .es-editorial__hero-num { font-size: clamp(64px, 16vw, 100px); }
  .es-ed-small__card { grid-template-columns: 1fr; }
  .es-ed-small__chart { width: 100%; max-width: 180px; }

  /* Mobile stat cell — icon + number on row 1, label + sub indented below */
  .es-editorial__cell {
    display: grid;
    grid-template-columns: 44px 1fr;
    column-gap: 14px;
    row-gap: 4px;
    align-items: start;
  }
  .es-editorial__icon {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
  }
  .es-editorial__cell-num {
    grid-column: 2;
    grid-row: 1;
    font-size: 32px;
    align-self: center;
  }
  .es-editorial__cell h4 {
    grid-column: 2;
    grid-row: 2;
    margin-top: 2px;
  }
  .es-editorial__cell p {
    grid-column: 2;
    grid-row: 3;
  }
}
