/* ============================================================
   MADEMOISELLE TRÉSORS — GALERIE
   Grille éditoriale déstructurée (12 colonnes · flux dense).
   Adaptée du design Claude Design, branchée sur les tokens --mt-*.
   Tout est scopé sous .mt-root (module Code Divi).
   ============================================================ */

/* ---------- intro / hero galerie ---------- */
.mt-root .gal-hero {
  position: relative;
  padding: clamp(60px,8vw,110px) 0 clamp(40px,6vw,72px);
  border-bottom: 1px solid var(--mt-line-soft);
  overflow: hidden;
}
.mt-root .gal-hero::before {
  content: "\2726";
  position: absolute; right: -2%; top: 8%;
  font-family: 'Abril Fatface', Georgia, serif;
  font-size: clamp(14rem,30vw,32rem); line-height: 1;
  color: rgba(229,192,104,.05);
  pointer-events: none; z-index: 0;
}
.mt-root .gal-hero .wrap { position: relative; z-index: 2; }
.mt-root .gal-head {
  display: grid; grid-template-columns: 1.5fr .9fr;
  gap: clamp(28px,5vw,70px); align-items: end;
}
.mt-root .gal-head h1 {
  font-family: 'Abril Fatface', Georgia, serif; font-weight: 400; color: #fff;
  font-size: clamp(3.2rem,10vw,7.4rem); line-height: .92; margin: 22px 0 0; letter-spacing: .005em;
}
.mt-root .gal-head h1 em { font-style: normal; color: var(--mt-gold); }
.mt-root .gal-head .lede {
  color: #b7b2a8; font-size: clamp(.98rem,1.4vw,1.12rem); line-height: 1.75;
  max-width: 42ch; padding-bottom: 8px;
}
.mt-root .gal-head .lede b { color: #e9e4da; font-weight: 600; }

.mt-root .gal-stats {
  display: flex; align-items: center; gap: 26px; flex-wrap: wrap;
  margin-top: clamp(34px,4vw,52px); padding-top: 26px; border-top: 1px solid var(--mt-line);
}
.mt-root .gal-stats .gs { display: flex; align-items: baseline; gap: 11px; }
.mt-root .gal-stats .gs b { font-family: 'Abril Fatface', Georgia, serif; font-weight: 400; color: var(--mt-gold); font-size: 1.7rem; line-height: 1; }
.mt-root .gal-stats .gs span { font-size: .72rem; letter-spacing: .22em; text-transform: uppercase; color: #9a958b; }
.mt-root .gal-stats .gs-line { flex: 1; height: 1px; background: var(--mt-line-soft); min-width: 30px; }

/* ============================================================
   GRILLE DÉSTRUCTURÉE — 12 colonnes · auto-rows · flux dense
   ============================================================ */
.mt-root .gal-grid {
  display: grid;
  grid-template-columns: repeat(12,1fr);
  grid-auto-rows: 34px;
  grid-auto-flow: dense;
  gap: clamp(12px,1.4vw,20px);
  padding: clamp(48px,7vw,96px) 0 clamp(70px,9vw,120px);
}
/* la tuile */
.mt-root .tile {
  position: relative; overflow: hidden;
  border: 1px solid var(--mt-line-soft);
  background: #101013;
  isolation: isolate;
}
/* l'image remplit la tuile */
.mt-root .tile img,
.mt-root .tile .gal-img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transition: transform 1.1s var(--mt-ease);
}
.mt-root .tile:hover img { transform: scale(1.06); }
/* placeholder visuel si pas encore d'image */
.mt-root .tile:empty::before,
.mt-root .tile img[src^="REMPLACER"] { background: #0e0e12; }
/* numéro éditorial */
.mt-root .tile .tnum {
  position: absolute; top: 12px; left: 14px; z-index: 3;
  font-family: 'Montserrat', sans-serif; font-weight: 600; font-size: .66rem; letter-spacing: .26em;
  color: #f3eee4; mix-blend-mode: difference; pointer-events: none;
}
/* cadre or au survol */
.mt-root .tile::after {
  content: ""; position: absolute; inset: 0; z-index: 2; pointer-events: none;
  border: 1px solid transparent; transition: border-color .5s var(--mt-ease), box-shadow .5s var(--mt-ease);
}
.mt-root .tile:hover::after { border-color: var(--mt-gold); box-shadow: inset 0 0 60px rgba(0,0,0,.35); }

/* tailles — composition déstructurée */
.mt-root .t-feat { grid-column: span 6; grid-row: span 13; } /* grand portrait vedette */
.mt-root .t-tall { grid-column: span 3; grid-row: span 11; } /* portrait haut */
.mt-root .t-port { grid-column: span 3; grid-row: span 9;  } /* portrait */
.mt-root .t-land { grid-column: span 6; grid-row: span 7;  } /* paysage large */
.mt-root .t-med  { grid-column: span 4; grid-row: span 8;  } /* moyen */
.mt-root .t-sq   { grid-column: span 3; grid-row: span 6;  } /* carré-ish */
.mt-root .t-wide { grid-column: span 5; grid-row: span 6;  } /* large */
.mt-root .t-drop { margin-top: clamp(18px,3vw,46px); }        /* décalage rythmique */

/* ---------- légende / CTA ---------- */
.mt-root .gal-note {
  display: flex; align-items: center; gap: 16px; justify-content: center; flex-wrap: wrap;
  padding: 0 0 clamp(70px,9vw,110px); color: #7c776e; font-size: .82rem; letter-spacing: .04em;
}
.mt-root .gal-note .star { color: var(--mt-gold); }
.mt-root .gal-note a { color: var(--mt-gold); text-decoration: underline; text-underline-offset: 3px; }

/* ---------- responsive ---------- */
@media (max-width: 1024px) {
  .mt-root .gal-head { grid-template-columns: 1fr; align-items: start; gap: 24px; }
  .mt-root .gal-grid { grid-template-columns: repeat(8,1fr); grid-auto-rows: 30px; }
  .mt-root .t-feat { grid-column: span 5; grid-row: span 12; }
  .mt-root .t-tall { grid-column: span 3; grid-row: span 10; }
  .mt-root .t-port { grid-column: span 3; grid-row: span 9;  }
  .mt-root .t-land { grid-column: span 5; grid-row: span 7;  }
  .mt-root .t-med  { grid-column: span 4; grid-row: span 8;  }
  .mt-root .t-sq   { grid-column: span 3; grid-row: span 6;  }
  .mt-root .t-wide { grid-column: span 4; grid-row: span 6;  }
}
@media (max-width: 680px) {
  .mt-root .gal-grid { grid-template-columns: repeat(2,1fr); grid-auto-rows: 26px; gap: 12px; }
  .mt-root .t-feat { grid-column: span 2; grid-row: span 13; }
  .mt-root .t-tall { grid-column: span 1; grid-row: span 11; }
  .mt-root .t-port { grid-column: span 1; grid-row: span 10; }
  .mt-root .t-land { grid-column: span 2; grid-row: span 9;  }
  .mt-root .t-med  { grid-column: span 1; grid-row: span 11; }
  .mt-root .t-sq   { grid-column: span 1; grid-row: span 9;  }
  .mt-root .t-wide { grid-column: span 1; grid-row: span 10; }
  .mt-root .t-drop { margin-top: 0; }
}
