/* ==========================================================================
   Layout primitives
   ========================================================================== */

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

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

.section {
    padding-block: var(--space-24);
}

.section-sm {
    padding-block: var(--space-16);
}

.section-lg {
    padding-block: var(--space-32);
}

@media (max-width: 600px) {
    .section { padding-block: var(--space-16); }
    .section-lg { padding-block: var(--space-20); }
}

/* ----- Flex/grid utilities — sparse set, just the ones we use often ----- */

.stack {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.stack-lg {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
}

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

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

.grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-6);
}

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

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

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

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