.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}
.container--narrow { max-width: var(--container-narrow); }

.section {
  padding-block: var(--section-y);
  position: relative;
}
.section--lg { padding-block: var(--section-y-lg); }
.section--soft { background: var(--color-bg-elev); }
.section--gradient {
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-elev) 100%);
}

.section-header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-8);
}
.section-header--left {
  text-align: left;
  margin-inline: 0;
}

.eyebrow {
  display: inline-block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-brand);
  margin-bottom: var(--space-4);
  padding: var(--space-2) var(--space-4);
  background: var(--color-brand-soft);
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-brand-ring);
}

.grid { display: grid; gap: var(--space-6); }
.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid--auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.grid--gap-lg { gap: var(--space-7); }

.split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--space-8);
  align-items: center;
}
.split--reverse > :first-child { order: 2; }

.stack { display: flex; flex-direction: column; }
.stack > * + * { margin-top: var(--gap, var(--space-4)); }
.stack--lg { --gap: var(--space-6); }
.stack--sm { --gap: var(--space-2); }

.row { display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.row--between { justify-content: space-between; }
.row--center { justify-content: center; }

.text-center { text-align: center; }
.text-muted { color: var(--color-text-muted); }
.text-brand { color: var(--color-brand); }

@media (max-width: 960px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .split { grid-template-columns: 1fr; gap: var(--space-7); }
  .split--reverse > :first-child { order: 0; }
}
@media (max-width: 600px) {
  .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}
