/* Benefits */

.benefits > div {
  display: grid;
  gap: var(--gap-block);
  grid-template-columns: 1fr;
}

@media (min-width: 45rem) {
  .benefits > div {
    /* auto-fit statt fester 3 Spalten: trägt beliebig viele Benefits,
       Spaltenzahl ergibt sich aus Breite (kein Abschneiden bei >3). */
    grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
    gap: var(--gap-section);
  }
}

.benefits article {
  display: grid;
  grid-template-columns: var(--section-icon-col) 1fr;
  column-gap: var(--gap-inline);
  align-items: start;
}

.benefits article > svg {
  grid-row: span 2;
  color: var(--color-primary);
  transition: transform var(--transition);
}

.benefits article:hover > svg {
  transform: scale(1.08);
}

.benefits article:hover h3 {
  color: var(--color-primary);
}

.benefits article h3 {
  font-size: var(--text-base);
  font-family: var(--font-body), sans-serif;
  font-weight: 600;
  margin-block-end: var(--space-1);
  transition: color var(--transition-slow);
}

.benefits article p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
