/* ──────────────────────────────────────────────────────────────────────────
   Layout — containers, grids, helpers
   ────────────────────────────────────────────────────────────────────────── */

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

.container--narrow {
  max-width: var(--container-narrow);
}

.container--prose {
  max-width: var(--container-prose);
}

.container--full {
  max-width: var(--container-full);
}

.container--bleed {
  max-width: 100%;
  padding-inline: 0;
}

/* — Sections ─────────────────────────────────────────────────────────── */
.section {
  position: relative;
  padding-block: var(--section-y);
}

.section--deep {
  padding-block: var(--section-y-deep);
}

.section--tight {
  padding-block: clamp(2.5rem, 5vw, 4.5rem);
}

.section--inverse {
  background: var(--bg-section-deep);
  color: var(--text-on-deep);
}

.section--inverse h1,
.section--inverse h2,
.section--inverse h3 {
  color: var(--text-on-deep);
}

.section--inverse .eyebrow,
.section--inverse .handwritten,
.section--inverse .roman {
  color: var(--color-ochre-soft);
}

.section--alt {
  background: var(--bg-section-alt);
}

.section--bleed {
  padding-inline: 0;
}

/* — Layout primitives ────────────────────────────────────────────────── */
.stack > * + * { margin-top: var(--space-md); }
.stack--sm > * + * { margin-top: var(--space-sm); }
.stack--lg > * + * { margin-top: var(--space-lg); }
.stack--xl > * + * { margin-top: var(--space-xl); }

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  align-items: center;
}

.center {
  text-align: center;
  margin-inline: auto;
}

.flow > * + * { margin-top: 1em; }

/* — Grids ────────────────────────────────────────────────────────────── */
.grid {
  display: grid;
  gap: var(--space-lg);
}

.grid--auto {
  grid-template-columns: repeat(auto-fit, minmax(min(20rem, 100%), 1fr));
}

.grid--2 {
  grid-template-columns: 1fr;
}

.grid--3 {
  grid-template-columns: 1fr;
}

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

/* — Aspect ratios pour figures ───────────────────────────────────────── */
.figure {
  position: relative;
  display: block;
  margin: 0;
}

.figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.figure--portrait { aspect-ratio: 4 / 5; }
.figure--landscape { aspect-ratio: 16 / 10; }
.figure--square { aspect-ratio: 1 / 1; }
.figure--tall { aspect-ratio: 3 / 4; }

.figure figcaption {
  margin-top: var(--space-sm);
  font-family: var(--font-body);
  font-style: italic;
  font-size: var(--fs-small);
  color: var(--text-soft);
  letter-spacing: 0.01em;
}

/* — Skip link ────────────────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -110%);
  background: var(--color-aubergine);
  color: var(--color-paper);
  padding: var(--space-sm) var(--space-md);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  z-index: var(--z-modal);
  font-family: var(--font-body);
  font-weight: var(--fw-body-md);
  background-image: none;
}

.skip-link:focus {
  transform: translate(-50%, 0);
  background-image: none;
  background: var(--color-aubergine);
  color: var(--color-paper);
}
