/* Stats */

.stats {
  text-align: center;
  overflow: hidden;
}

/* Flex statt festem Grid: trägt beliebig viele Werte (X), bleibt als Gruppe
   mittig und bricht bei vielen/engen Viewports sauber um. */
.stats > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--gap-block);
}

@media (min-width: 45rem) {
  .stats > div {
    gap: var(--gap-section);
  }
}

.stats dl {
  margin: 0;
  padding: 0;
  /* gleichmäßige Mindestbreite, inhaltsbasiert — sonst zerfasern die Spalten */
  flex: 0 0 auto;
  min-width: 7rem;
}

/* Override globale dl > div-Styles aus 02-base.css (border-bottom, flex row,
   space-between passen für Property-Tabellen, nicht für Stats). */
.stats dl > div {
  display: flex;
  flex-direction: column-reverse;  /* dt zuerst im DOM, dd visuell oben */
  align-items: center;
  justify-content: initial;
  gap: var(--space-1);
  padding: 0;
  border: 0;
  margin: 0;
}

.stats dl > div:hover {
  background: transparent;
}

.stats dd {
  font-family: var(--font-heading), serif;
  font-size: var(--text-4xl);
  font-weight: 400;
  color: var(--color-primary);
  line-height: 1;
  margin: 0;
  text-align: center;
}

.stats dt {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: 400;
}
