/* ==========================
   Monument aux morts – CSS propre
   ========================== */

/* Grille */
.mm-grid{
  display:grid;
  grid-template-columns: 1fr;        /* mobile d'abord : 1 colonne */
  gap: var(--g-gap, 16px);
  align-items: stretch;              /* les items s'étirent en hauteur */
}

/* Desktop : 2 colonnes */
@media (min-width: 980px){
  .mm-grid{ grid-template-columns: 1fr 1fr; }
}

/* --- Colonne image (article.g--portrait) --- */
.g--portrait{
  background:#f6f6f6;
  overflow:hidden;
}

/* Mobile/tablette : garder tout le visuel sans coupe */
@media (max-width: 979px){
  .g--portrait{ aspect-ratio: 3 / 4; }  /* adapte si besoin */
  .g--portrait .g1418-media{
    width:100%;
    height:auto;
    object-fit: contain;
    display:block;
  }
}

/* Desktop : image = même hauteur que la colonne texte */
@media (min-width: 980px){
  .g--portrait .g1418-media{
    width:100%;
    height:100%;
    object-fit: cover; /* remplit (légère coupe possible), garantit l’alignement bas */
    display:block;
  }
}

/* --- Colonne texte --- */
/* 1) le conteneur de cellule (article) devient flex pour que l'intérieur puisse s'étirer */
.mm-grid > .g1418-box{ display:flex; }

/* 2) le bloc visuel (la "carte") remplit toute la hauteur de la cellule */
.mm-note{
  flex:1;                            /* ← prend toute la hauteur dispo */
  display:flex; flex-direction:column;
  padding:12px 14px;
  border-radius: var(--r, 12px);
  background: var(--sable, #f4efe8);
  border:1px solid rgba(0,0,0,.08);
  box-shadow: var(--shadow, 0 6px 18px rgba(0,0,0,.08));
  font-size: clamp(1rem, 0.3vw + 1rem, 1.1rem);
  line-height:1.55;
}
.mm-note p{ margin:0 0 .7em; }
.mm-note > *:last-child{ margin-bottom:0; }

.mm-h2{
  margin:.2em 0 .35em;
  font-size: clamp(1.05rem, 0.4vw + 1rem, 1.25rem);
  line-height:1.25;
  font-family:"EB Garamond", serif;
}

/* --- Ligne 2 : 3 photos + légendes --- */
.mm-row-3{
  grid-column: 1 / -1;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--g-gap, 16px);
  margin-top:4px;
}
.mm-photo{
  margin:0;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: var(--r, 12px);
  box-shadow: var(--shadow, 0 6px 18px rgba(0,0,0,.06));
  overflow:hidden;
}
.mm-photo > img{
  width:100%;
  aspect-ratio:4 / 3;   /* ajuste si tes visuels sont plus verticaux */
  object-fit:cover;
  display:block;
}
.mm-photo > figcaption{
  padding:8px 10px 10px;
  font-size:.95rem;
  line-height:1.35;
  color:#333;
  background:#fafafa;
  border-top:1px solid rgba(0,0,0,.06);
}

/* Responsive pour la ligne 2 */
@media (max-width: 900px){ .mm-row-3{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .mm-row-3{ grid-template-columns: 1fr; } }

/* ===== Grille 2×2 de photos ===== */
.mm-photos{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--g-gap, 16px);
  margin-top: 4px;
}

.mm-photo{
  margin: 0;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r, 12px);
  box-shadow: var(--shadow, 0 6px 18px rgba(0,0,0,.06));
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.mm-photo > img{
  width: 100%;
  aspect-ratio: 4 / 3;     /* par défaut : cadrage “paysage” agréable */
  object-fit: cover;       /* remplit le cadre (peut rogner un peu) */
  display: block;
}

.mm-photo > figcaption{
  padding: 8px 10px 10px;
  font-size: .95rem;
  line-height: 1.35;
  color: #333;
  background: #fafafa;
  border-top: 1px solid rgba(0,0,0,.06);
}

/* Responsive : 1 colonne en mobile */
@media (max-width: 700px){
  .mm-photos{ grid-template-columns: 1fr; }
}

/* Modificateurs utiles (optionnels) :
   - Ajoute .is-portrait sur <img> verticales
   - Ajoute .fit-contain si tu veux zéro recadrage sur une image précise */
.mm-photo > img.is-portrait{ aspect-ratio: 3 / 4; }
.mm-photo > img.fit-contain{ object-fit: contain; background:#fff; }

/* ===== Lexique en bas de page ===== */
.mm-lexique{
  grid-column: 1 / -1;                 /* pleine largeur de la grille */
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: var(--g-gap, 16px);
  margin-top: 10px;
}

.lex-card{
  background: var(--sable, #f4efe8);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r, 12px);
  box-shadow: var(--shadow, 0 6px 18px rgba(0,0,0,.08));
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
}

.lex-title{
  margin: 0 0 .5em;
  font-family: "EB Garamond", serif;
  font-weight: 600;
  font-size: clamp(1.05rem, 0.4vw + 1rem, 1.25rem);
  line-height: 1.25;
}

/* Liste définition */
.lex-dl{
  margin: 0;
}
.lex-dl dt{
  font-weight: 600;
  margin-top: .35em;
}
.lex-dl dd{
  margin: .15em 0 .4em 0;
  line-height: 1.45;
}

/* Mobile : 1 seule colonne */
@media (max-width: 700px){
  .mm-lexique{ grid-template-columns: 1fr; }
}

/* Sous-titre pleine largeur (mm-intro) : plus grand et plus sombre */
.g1418-page .mm-intro p{
  font-size: clamp(1.1rem, 0.55vw + 1rem, 1.35rem); /* > texte du bloc dessous */
  line-height: 1.5;
  color: #222;                                      /* plus sombre */
  font-weight: 500;                                 /* un poil plus “présent” */
  margin: 0;
}

/* Option : resserrer un peu sous le H1 */
.g1418-header + .g1418-section .mm-intro{ 
  margin-top: 4px; 
}

/* Légendes plus lisibles */
.mm-photos .mm-photo > figcaption{
  font-size: clamp(1rem, 0.35vw + 0.95rem, 1.15rem);
  line-height: 1.45;
  color: #1a1a1a;        /* plus sombre */
  background: #fff;      /* contraste meilleur que #fafafa */
  font-weight: 500;      /* un peu plus “présent” */
}
.mm-photos .mm-photo > figcaption .cap-titre{ font-weight:600; }

/*(et dans le HTML : <figcaption><span class="cap-titre">Face A</span> — Inscriptions…</figcaption>)*/

/* ===== Bloc lettre (pleine largeur) ===== */
.mm-lettre{
  grid-column: 1 / -1;
  margin-top: 20px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r,12px);
  box-shadow: var(--shadow,0 6px 18px rgba(0,0,0,.08));
  overflow: hidden;
  background: #f8f8f8;
}
.mm-lettre-cap{
  margin: 0;
  padding: 10px 12px;
  font-size: 1rem;
  line-height: 1.4;
  color: #1a1a1a;
  background: #fff;                   /* bande titre au-dessus */
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.mm-lettre img{
  width: 100%;
  height: auto;
  display: block;
}
.mm-lettre-title{
  grid-column: 1 / -1;
  margin-top: 20px;
  padding: 10px 12px;
  font-size: clamp(1.05rem, 0.4vw + 1rem, 1.25rem);
  font-family: "EB Garamond", serif;
  font-weight: 600;
  color: #222;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--r,12px);
  box-shadow: var(--shadow,0 6px 18px rgba(0,0,0,.08));
}
.mm-lettre--no-cap{ margin-top: 8px; } /* petit écart après le titre */

/* Bande-titre du document (au-dessus de l'image) */
.mm-lettre-title{
  text-align: center;                          /* centrage */
  font-size: clamp(1.2rem, 0.8vw + 1rem, 1.6rem); /* un peu plus grand */
  line-height: 1.35;
  font-weight: 650;                            /* un poil plus dense */
  letter-spacing: .2px;                        /* léger confort de lecture */
  padding: 12px 14px;                          /* un soupçon plus d'air */
}

.mm-lettre-title{
  background:#fff;
  outline:1px solid rgba(0,0,0,.08);
  border-left: 6px solid #9a7b4f;       /* accent (bronze) */
  border-radius: var(--r,12px);
  box-shadow: var(--shadow,0 6px 18px rgba(0,0,0,.08));
  color:#222;
}


/* Option : équilibre automatique des lignes si le titre passe sur 2 lignes (navigateurs récents) */
@supports (text-wrap: balance){
  .mm-lettre-title{ text-wrap: balance; }
}

html {
  scroll-behavior: smooth;
}
.u-anchor {
  color: #003366;
  text-decoration: underline;
}
.u-anchor:hover {
  color: #000;
}

/* Plein bord pour la lettre */
.mm-lettre{
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}
.mm-lettre img{
  display:block;
  width:100%;
  height:auto;
}
/* Lettre : annuler les marges horizontales du <figure> */
.mm-lettre{
  margin: 20px 0 0 0;   /* top 20px, gauche/droite 0 */
}

/* Variante pour les visuels qui ne doivent pas être recadrés */
.mm-photo--contain { overflow: visible; }               /* on ne coupe rien */
.mm-photo--contain > img {
  width: 100%;
  height: auto;                                        /* pas de hauteur forcée */
  aspect-ratio: auto;                                  /* annule le 4/3 hérité */
  object-fit: contain;                                 /* affiche tout l’ensemble */
  background: #fff;                                    /* pas de bandes grises */
}

/* Optionnel : si tu veux garder la même “carte” visuelle */
.mm-photo--contain > figcaption {
  background: #fafafa;
  border-top: 1px solid rgba(0,0,0,.06);
}

.mm-dl dt { font-weight: 700; }

/* === Variante : photo unique pleine largeur === */
.mm-photos.is-full {
  grid-template-columns: 1fr;   /* une seule colonne */
  max-width: var(--page-max-w, 1400px);
  margin: 1rem auto 1rem;
}

.mm-photos.is-full .mm-photo > img {
  aspect-ratio: auto;           /* on annule le 4/3 forcé */
  object-fit: contain;          /* montre tout sans recadrer */
  width: 100%;
  height: auto;
}

/* === Variante : lexique unique centré === */
.mm-lexique.is-single {
  grid-template-columns: 1fr;   /* une seule colonne */
  justify-items: center;        /* centrage horizontal */
  margin-top: 0.1rem;           /* espace harmonieux au-dessus */
}

.mm-lexique.is-single .lex-card {
  max-width: 900px;
  background: #f7f5ef;
  padding: 18px 20px;          /* un peu plus d’air interne */
  font-size: clamp(1.05rem, 0.45vw + 1rem, 1.25rem); /* caractères plus grands */
  line-height: 1.55;
}
.mm-lexique.is-single .lex-title {
  font-size: clamp(1.2rem, 0.6vw + 1rem, 1.4rem);
  margin-bottom: 0.6em;
}
.mm-lexique.is-single .lex-dl dt {
  font-weight: 600;
  margin-top: .4em;
}

.mm-lexique.is-single .lex-dl dd {
  margin: .2em 0 .5em;
}

/* === Forcer l’alignement en hauteur des 2 cadres ligne 1 === */
@media (min-width: 980px) {
  .mm-grid {
    align-items: stretch;   /* étire les cellules verticalement */
  }
  .mm-grid > .g1418-box {
    display: flex;
    flex-direction: column;
  }
  .mm-grid > .g1418-box > * {
    flex: 1;                /* le contenu occupe toute la hauteur */
  }
}

/* ==========================
   Ajustements spécifiques : page Maisons sur l'Agout
   ========================== */

@media (min-width: 980px) {

  /* 1) Chaque cellule de la grille devient un conteneur flex qui s'étire */
  .agout-page .mm-grid > .g1418-box {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  /* 2) Le contenu interne (note ou image) occupe toute la hauteur */
  .agout-page .mm-grid > .g1418-box > * {
    flex: 1;
  }

  /* 3) Côté image : remplir la colonne en hauteur */
  .agout-page .g--portrait {
    display: flex;
  }

  .agout-page .g--portrait .g1418-media {
    width: 100%;
    height: 100%;
    object-fit: cover;   /* bien remplir la carte, quitte à rogner un poil */
    display: block;
  }

  /* 4) Côté texte : la “carte” mm-note remplit aussi toute la cellule */
  .agout-page .g1418-note.mm-note {
    display: flex;
    flex-direction: column;
    height: 100%;
  }
}

/* Maisons sur l’Agout – réduire l’espace sous le h3 "Principales professions" */
@media (min-width: 980px) {
  .agout-page .g1418-note h3 {
    margin-top: 0.1em;
    margin-bottom: 0.1em;
  }

  .agout-page .g1418-note h3 + ul {
    margin-top: 0.1em;   /* espace plus petit sous le sous-titre */
  }
}


