/* ==========================================
   LAYOUT.CSS – Container, grid, spacing
   ========================================== */

.container {
  width: 100%;
  max-width: var(--container-w);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-px);
  padding-right: var(--container-px);
}

/* Section base padding */
.section {
  padding-block: var(--sp-24);
}

@media (max-width: 768px) {
  .section {
    padding-block: var(--sp-16);
  }
}

/* Utility */
.w-full { width: 100%; }

/* Grid helpers */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-6);
}

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

@media (max-width: 900px) {
  .grid-2, .grid-3 { grid-template-columns: 1fr; }
}

/* Feature split layout */
.feature-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.feature-split--reverse .feature-content { order: 2; }
.feature-split--reverse .feature-visual  { order: 1; }

@media (max-width: 900px) {
  .feature-split {
    grid-template-columns: 1fr;
    gap: var(--sp-10);
  }
  .feature-split--reverse .feature-content { order: 0; }
  .feature-split--reverse .feature-visual  { order: 0; }
}
