/* ============================================================ */
/* ===== PAGE GALERIE — thème lavandes (violet), grille mosaïque + lightbox ===== */
/* Lié APRÈS styles.css. N'altère jamais styles.css. */

/* ===== HERO galerie ===== */
/* Pas d'overflow:hidden : il coupait l'ombre portée de l'image .gh-b (bas droite).
   Le scroll horizontal est déjà neutralisé par body{overflow-x:hidden}. */
.g-hero{position:relative;padding:clamp(40px,7vh,84px) 0 clamp(48px,6vh,80px)}
.g-hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,78px);align-items:center}
.g-hero h1{font-family:'Londrina Solid',serif;font-weight:400;font-size:clamp(40px,5.4vw,86px);line-height:1.0;letter-spacing:-.005em;margin:0 0 24px;max-width:15ch}
.g-hero h1 .h1-main{display:block}
.g-hero h1 .h1-sub{display:block;font-family:'Parkinsans',sans-serif;font-weight:700;font-size:.3em;line-height:1.22;letter-spacing:.004em;opacity:.8;margin-top:.4em}
.g-hero .g-lead{font-family:'Parkinsans',sans-serif;font-weight:300;font-size:clamp(17px,1.35vw,21px);line-height:1.6;max-width:56ch;margin:0 0 16px}
.g-hero .g-lead.is-small{font-size:clamp(15px,1.05vw,17px);opacity:.92}
.g-hero-ctas{display:flex;flex-wrap:wrap;gap:14px 30px;margin-top:30px;align-items:center}
.g-hero-ctas .btn-line{margin-top:0}
/* Visuel du hero : composition de 2 images décalées, arrondies (écho au hero Mariage) */
.g-hero-media{position:relative;aspect-ratio:1/1}
.g-hero-media .gh-img{position:absolute;border-radius:24px;overflow:hidden;box-shadow:0 40px 90px -50px rgba(40,10,80,.55)}
.g-hero-media .gh-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.3s cubic-bezier(.2,.6,.2,1)}
.g-hero-media .gh-img:hover img{transform:scale(1.05)}
.g-hero-media .gh-a{top:0;left:0;width:62%;aspect-ratio:4/5;border-radius:200px 200px 24px 24px;z-index:2}
.g-hero-media .gh-b{bottom:0;right:0;width:54%;aspect-ratio:4/3;z-index:1}
@media(max-width:880px){
  .g-hero-grid{grid-template-columns:1fr;gap:34px}
  .g-hero-media{aspect-ratio:4/3;max-width:520px}
}

/* ===== Barre d'onglets (filtres de catégorie) ===== */
.g-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto clamp(34px,4.5vh,52px)}
.g-filter{
  font-family:'Parkinsans',sans-serif;font-weight:500;
  font-size:13px;letter-spacing:.06em;
  padding:10px 20px;border-radius:999px;
  color:var(--fg);
  border:1.5px solid color-mix(in srgb,var(--fg) 26%,transparent);
  background:transparent;
  transition:background .25s ease,color .25s ease,border-color .25s ease,transform .25s ease;
}
.g-filter:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--fg) 50%,transparent)}
.g-filter.is-active{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* ===== Grille mosaïque (masonry CSS via grid dense + spans) ===== */
.g-mosaic{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:14px;          /* unité de hauteur ; le span ajuste les tuiles */
  gap:16px;
}
.g-tile{
  position:relative;
  margin:0;
  border-radius:18px;overflow:hidden;
  background:color-mix(in srgb,var(--fg) 8%,transparent);
  cursor:zoom-in;
  transform:translateZ(0);
  box-shadow:0 24px 60px -44px rgba(40,10,80,.55);
}
.g-tile img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s cubic-bezier(.2,.6,.2,1),filter .5s ease;
}
.g-tile:hover img{transform:scale(1.06)}
/* Voile au survol */
.g-tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(29,0,54,.55));
  opacity:0;transition:opacity .4s ease;
}
.g-tile:hover::after{opacity:1}
/* Petite loupe en coin */
.g-tile .g-zoom{
  position:absolute;top:14px;right:14px;z-index:2;
  width:38px;height:38px;border-radius:999px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.92);color:#1d0036;
  opacity:0;transform:scale(.8);
  transition:opacity .35s ease,transform .35s ease;
}
.g-tile:hover .g-zoom{opacity:1;transform:scale(1)}
.g-tile .g-zoom svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Tailles variées (tuiles span) — composent la mosaïque */
.g-tile.is-tall{grid-row:span 26}     /* portrait haut */
.g-tile.is-wide{grid-column:span 2;grid-row:span 17}  /* paysage large */
.g-tile.is-big{grid-column:span 2;grid-row:span 30}   /* grande tuile carrée-ish */
.g-tile.is-std{grid-row:span 19}      /* standard */

/* Masquage par filtre */
.g-tile.is-hidden{display:none}

@media(max-width:880px){
  .g-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:12px;gap:12px}
  .g-tile.is-wide,.g-tile.is-big{grid-column:span 2}
  .g-tile.is-tall{grid-row:span 24}
  .g-tile.is-std{grid-row:span 17}
  .g-tile.is-wide{grid-row:span 14}
  .g-tile.is-big{grid-row:span 24}
}
@media(max-width:520px){
  .g-mosaic{grid-template-columns:1fr;grid-auto-rows:10px}
  .g-tile.is-wide,.g-tile.is-big,.g-tile.is-tall,.g-tile.is-std{grid-column:span 1;grid-row:span 22}
  .g-tile .g-zoom{opacity:1}  /* toujours visible (pas de hover tactile) */
  .g-tile::after{opacity:.35}
}

/* ===== Section "Découvrir le domaine en vrai" — placée DANS l'outro (image de fond + footer),
   comme la section finale des autres pages. Gros padding-haut pour laisser respirer la photo. ===== */
.s-visite{position:relative;padding:clamp(150px,19vh,230px) 0 clamp(40px,5vh,60px)}
.s-visite .s-body{text-shadow:0 1px 16px rgba(0,0,0,.25)}
.s-visite .visite-grid{
  display:grid;grid-template-columns:1.5fr auto;
  gap:clamp(28px,4vw,56px);align-items:center;
}
.s-visite .btn-line{margin-top:0;flex-shrink:0}
.s-visite .visite-links{
  display:flex;flex-wrap:wrap;gap:14px 28px;
  margin-top:clamp(28px,3.5vh,40px);
}
.s-visite .visite-links .btn-line{margin-top:0}
@media(max-width:760px){.s-visite .visite-grid{grid-template-columns:1fr}}

/* ===== LIGHTBOX ===== */
.lb{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,56px);
  background:rgba(13,2,30,.92);
  backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;
  transition:opacity .35s ease,visibility .35s ease;
}
.lb.is-open{opacity:1;visibility:visible}
.lb-stage{
  position:relative;
  max-width:1180px;width:100%;max-height:100%;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
.lb-figure{margin:0;max-width:100%;max-height:80vh;display:flex;align-items:center;justify-content:center}
.lb-figure img{
  max-width:100%;max-height:80vh;width:auto;height:auto;
  border-radius:14px;object-fit:contain;
  box-shadow:0 40px 120px -40px rgba(0,0,0,.7);
}
.lb-caption{
  color:#f3eede;font-family:'Parkinsans',sans-serif;font-weight:400;
  font-size:14px;letter-spacing:.02em;text-align:center;opacity:.92;
  min-height:1.2em;
}
.lb-caption .lb-count{opacity:.55;margin-left:10px;font-size:12px;letter-spacing:.1em}
/* Boutons */
.lb-btn{
  position:absolute;z-index:3;
  width:54px;height:54px;border-radius:999px;
  display:grid;place-items:center;
  background:rgba(255,255,255,.1);color:#fff;
  border:1px solid rgba(255,255,255,.22);
  transition:background .25s ease,transform .25s ease;
}
.lb-btn:hover{background:rgba(255,255,255,.22);transform:scale(1.06)}
.lb-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.lb-close{top:clamp(-4px,2vh,8px);right:0}
.lb-prev{left:clamp(2px,1vw,12px);top:50%;transform:translateY(-50%)}
.lb-next{right:clamp(2px,1vw,12px);top:50%;transform:translateY(-50%)}
.lb-prev:hover,.lb-next:hover{transform:translateY(-50%) scale(1.06)}
@media(max-width:680px){
  .lb-prev{left:6px}.lb-next{right:6px}
  .lb-btn{width:46px;height:46px}
  .lb-close{top:-6px}
}

@media(prefers-reduced-motion: reduce){
  .g-tile img,.g-hero-media .gh-img img{transition:none}
}
