/* ==========================================================================
   Layout utilities — www.state3.co.nz
   --------------------------------------------------------------------------
   Container and section base. Grid and flex utility classes.
   ========================================================================== */

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

/* At ≥1024px widen the container gutter */
@media (min-width: 1024px) {
  :root { --container-padding: var(--space-8); }
}

/* ---- Flex utilities ---- */
.flex            { display: flex; }
.inline-flex     { display: inline-flex; }
.flex-col        { flex-direction: column; }
.flex-wrap       { flex-wrap: wrap; }
.items-center    { align-items: center; }
.items-start     { align-items: flex-start; }
.items-end       { align-items: flex-end; }
.justify-between { justify-content: space-between; }
.justify-center  { justify-content: center; }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

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

/* ---- Width helpers ---- */
.max-w-prose  { max-width: 65ch; }
.max-w-narrow { max-width: 540px; }
.mx-auto      { margin-inline: auto; }

/* ---- Spacing helpers (margin top) ---- */
.mt-0  { margin-top: 0; }
.mt-2  { margin-top: var(--space-2); }
.mt-4  { margin-top: var(--space-4); }
.mt-6  { margin-top: var(--space-6); }
.mt-8  { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
