/* =========================
   Layout System – Lardichon
   ========================= */

/* Section standard */
.section {
  padding-block: var(--section-padding);
}

/* Section large */
.section--lg {
  padding-block: calc(var(--section-padding) * 1.5);
}

/* Section compacte */
.section--sm {
  padding-block: calc(var(--section-padding) / 2);
}

/* Plein écran */
.section--full {
  min-height: 100vh;
  display: flex;
}

/* Centrage */
.section--center {
  justify-content: center;
  align-items: center;
}

/* Conteneur principal */
.container {
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--gutter);
  width: 100%;
}

/* Colonne verticale */
.stack {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* Variantes */
.stack--sm { gap: 12px; }
.stack--lg { gap: 48px; }

/* Texte */
.text-center { text-align: center; }
.text-muted { color: var(--color-text-muted); }

/* Largeurs de lecture */
.content { max-width: 640px; }
.content--wide { max-width: 820px; }

/* =========================
   Header
   ========================= */

.site-header {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 100;
  padding: 32px 0;
  background: transparent;
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.site-header__nav .menu {
  display: flex;
  gap: 24px;
}

/* =========================
   Footer
   ========================= */

.site-footer {
  background: var(--color-bg-dark);
  margin-top: var(--section-padding);
}

.site-footer__columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 48px;
  padding: 64px 0;
}

.site-footer__legal {
  padding: 16px;
  text-align: center;
  font-size: 12px;
  color: var(--color-text-muted);
}

/* Footer minimal */
.site-footer--bare {
  background: transparent;
}

.site-footer--bare {
  height: 0;
  padding: 0;
  margin: 0;
}
