/* Layout : container, grille 12 col, cadre de page. */

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

.container-fluid { width: 100%; padding-inline: var(--side-margin); }

.section { padding-block: clamp(4rem, 8vw + 2rem, 9rem); position: relative; }

.section-tight { padding-block: clamp(3rem, 5vw + 1rem, 5rem); }

/* Grille 12 colonnes */
.grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: var(--gutter);
}

.grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--gutter); }
.grid-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--gutter); }
.grid-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--gutter); }

@media (max-width: 1023px) {
    .grid-3 { grid-template-columns: 1fr; }
    .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 639px) {
    .grid-2, .grid-4 { grid-template-columns: 1fr; }
}

/* Spans */
.col-12 { grid-column: span 12; }
.col-8 { grid-column: span 8; }
.col-6 { grid-column: span 6; }
.col-5 { grid-column: span 5; }
.col-4 { grid-column: span 4; }
.col-3 { grid-column: span 3; }
.col-7 { grid-column: span 7; }

@media (max-width: 1023px) {
    .col-md-12 { grid-column: span 12; }
}

/* Stack utilities */
.stack { display: flex; flex-direction: column; gap: var(--sp-4); }
.stack-sm { gap: var(--sp-2); }
.stack-lg { gap: var(--sp-6); }
.row { display: flex; flex-direction: row; align-items: center; gap: var(--sp-4); flex-wrap: wrap; }
.row-between { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); flex-wrap: wrap; }

/* Cadre de page : filet 1px à 24px du viewport */
.page-frame {
    position: fixed;
    inset: var(--frame-inset);
    border: 1px solid var(--obsidian-500);
    pointer-events: none;
    z-index: var(--z-frame);
}

@media (max-width: 639px) {
    .page-frame { inset: 12px; }
    :root { --frame-inset: 12px; }
}

/* Numérotation de section : « 01 — Catalogue » */
.section-number {
    font-family: var(--font-mono);
    font-size: var(--fs-mono);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--paper-dim);
    margin-bottom: var(--sp-5);
}
.section-number .num { color: var(--copper); margin-right: var(--sp-2); }

/* Page wrapper */
.page-main { position: relative; min-height: 100svh; }

/* Vertical rhythm helpers */
.mt-0 { margin-top: 0; }
.mt-2 { margin-top: var(--sp-2); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }
.mt-6 { margin-top: var(--sp-6); }
.mt-7 { margin-top: var(--sp-7); }
.mt-8 { margin-top: var(--sp-8); }
.mt-9 { margin-top: var(--sp-9); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }
.mb-5 { margin-bottom: var(--sp-5); }
.mb-6 { margin-bottom: var(--sp-6); }

/* Surfaces */
.surface-900 { background: var(--obsidian-900); }
.surface-700 { background: var(--obsidian-700); }
