.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

section {
  padding: var(--section-padding);
  position: relative;
}

/* ---- Section spacing & visual divider ---- */
/* Extra breathing room between non-hero sections */
section:not(.hero) + section:not(.hero) {
  margin-top: var(--section-gap);
}

/* Thin accent-tinted rule between non-hero sections */
section:not(.hero) + section:not(.hero)::before {
  content: '';
  position: absolute;
  top: calc(var(--section-gap) * -0.5 + 1px);
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent-color), transparent);
  opacity: 0.35;
}

/* Footer gets a clean top separator */
footer {
  margin-top: var(--section-gap);
}

/* ---- Grids ---- */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4rem;
}

@media (min-width: 768px) {
  .grid-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.grid-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

@media (min-width: 768px) {
  .grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}
