/* ============================================================
   LAYOUT UTILITIES
   layout.css
   ============================================================ */

/* ── Container ── */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-px);
  width: 100%;
}

/* ── Sections ── */
.section {
  padding: var(--section-py-desktop) 0;
}

.section--alt {
  background: var(--color-secondary);
}

.section--dark {
  background: var(--color-primary-mid);
}

.section--darkest {
  background: var(--color-primary);
}

/* ── Grid utilities ── */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}

/* ── Flex utilities ── */
.flex         { display: flex; }
.flex-col     { flex-direction: column; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.gap-1  { gap: var(--space-1); }
.gap-2  { gap: var(--space-2); }
.gap-3  { gap: var(--space-3); }
.gap-4  { gap: var(--space-4); }

/* ── Spacing utilities ── */
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }

/* ── Display utilities ── */
.hidden { display: none !important; }
.block  { display: block; }

/* ── Responsive breakpoints ── */
@media (max-width: 1199px) {
  .container {
    padding: 0 var(--space-4);
  }
}

@media (max-width: 1023px) {
  .section {
    padding: var(--section-py-mobile) 0;
  }

  .grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }

  .container {
    padding: 0 var(--space-2);
  }
}

@media (max-width: 479px) {
  .container {
    padding: 0 var(--space-2);
  }
}
