/* Container */
.container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: 24px;
}

/* Sektions-Basis */
.section {
  padding-block: var(--section-padding-y);
}

.section--creme { background-color: var(--creme); }
.section--white { background-color: var(--weiss); }
.section--petrol-dark { background-color: var(--petrol-dark); }
.section--awards { padding-block: 48px; background-color: var(--creme); }

/* Text-Alignment */
.text-center { text-align: center; }
.text-left { text-align: left; }

/* Farben */
.text-petrol { color: var(--petrol); }
.text-petrol-dark { color: var(--petrol-dark); }
.text-bronze { color: var(--bronze); }
.text-creme { color: var(--creme); }
.text-white { color: var(--weiss); }
.text-mid { color: var(--text-mid); }

/* Flex-Helpers */
.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-col { display: flex; flex-direction: column; }
.gap-sm { gap: 8px; }
.gap-md { gap: 16px; }
.gap-lg { gap: 24px; }
.gap-xl { gap: 48px; }

/* Grid-Helpers */
.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--card-gap);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--card-gap);
}

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--card-gap);
}

/* Sektions-Header */
.section-header {
  text-align: center;
  margin-bottom: 56px;
}

.section-header h2 {
  margin-bottom: 16px;
}

.section-header .sub-headline {
  color: var(--text-mid);
  max-width: 700px;
  margin-inline: auto;
}

/* Spacing-Helpers */
.mt-sm { margin-top: 8px; }
.mt-md { margin-top: 16px; }
.mt-lg { margin-top: 24px; }
.mt-xl { margin-top: 48px; }
.mb-sm { margin-bottom: 8px; }
.mb-md { margin-bottom: 16px; }
.mb-lg { margin-bottom: 24px; }

/* Responsive: Tablet */
@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}

/* Responsive: Mobil */
@media (max-width: 768px) {
  .section { padding-block: var(--section-padding-y-mobile); }
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .container { padding-inline: 16px; }
  .section-header { margin-bottom: 40px; }
}
