/*
 * Galerie Photo Logement — ACDM v2
 * Univers graphique : Au Creux des Montagnes
 * Polices : Cormorant (titres) + Raleway (corps)
 * Palette : #f3f2ee · #090b0b · #828070 · #909b7e · #fff
 */

/* ============================================================
   Accessibilité — Screen Reader Only
   ============================================================ */
.galerie-sr-announce {
    position:   absolute;
    width:      1px;
    height:     1px;
    padding:    0;
    overflow:   hidden;
    clip:       rect(0, 0, 0, 0);
    white-space: nowrap;
    border:     0;
}

/* ============================================================
   Accessibilité — Focus visible
   Les styles focus-visible garantissent un contour visible
   pour les utilisateurs au clavier, sans affecter la souris.
   ============================================================ */

.galerie-filtre-btn:focus-visible {
    outline:        2px solid var(--clr-dark);
    outline-offset: 2px;
    z-index:        1;
}

.galerie-masonry-item:focus-visible {
    outline:        2px solid var(--clr-dark);
    outline-offset: 0;
    z-index:        1;
}

.galerie-btn-more:focus-visible {
    outline:        2px solid var(--clr-dark);
    outline-offset: 3px;
}

.galerie-lb-close:focus-visible,
.galerie-lb-nav:focus-visible {
    outline:        2px solid rgba(243, 242, 238, 0.9);
    outline-offset: 2px;
}

/* Fallback pour les navigateurs ne supportant pas :focus-visible */
.galerie-filtre-btn:focus:not(:focus-visible)  { outline: none; }
.galerie-masonry-item:focus:not(:focus-visible) { outline: none; }
.galerie-btn-more:focus:not(:focus-visible)     { outline: none; }
.galerie-lb-close:focus:not(:focus-visible),
.galerie-lb-nav:focus:not(:focus-visible)       { outline: none; }


/* ============================================================
   Variables
   ============================================================ */
.galerie-logements-section {
    --clr-bg:        #f3f2ee;
    --clr-dark:      #090b0b;
    --clr-muted:     #828070;
    --clr-border:    #909b7e;
    --clr-white:     #ffffff;
    --clr-warm:      #edd3b0;
    --font-serif:    "Cormorant", Georgia, serif;
    --font-sans:     "Raleway", sans-serif;
    --pad-h:         8.3333vw;
    --gap:           0.5555vw;
}


/* ============================================================
   Section wrapper
   ============================================================ */
.galerie-logements-section {
    background-color: var(--clr-bg);
    padding-bottom: 6.9444vw;
    overflow: hidden;
}


/* ============================================================
   En-tête
   ============================================================ */
.galerie-header {
    padding: 5.5555vw var(--pad-h) 2.7777vw;
    text-align: center;
}

.galerie-titre {
    font-family:    var(--font-serif);
    font-size:      4.1666vw;
    font-weight:    400;
    font-style:     italic;
    color:          var(--clr-dark);
    line-height:    1;
    text-transform: none;
    letter-spacing: 0;
    margin: 0;
    display:        block;
    margin-top: 5rem;
}

.galerie-titre span {
    font-style:     normal;
    font-weight:    500;
    text-transform: uppercase;
}

.galerie-sous-titre {
    font-family:    var(--font-sans);
    font-size:      0.9027vw;
    font-weight:    400;
    color:          var(--clr-muted);
    letter-spacing: 0.125vw;
    text-transform: uppercase;
    margin-top:     1.1111vw;
    display:        block;
}


/* ============================================================
   Filtres
   ============================================================ */
.galerie-filtres {
    padding:         0 var(--pad-h) 2.7777vw;
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    gap:             1.3888vw;
    flex-wrap:       wrap;
    border-bottom:   0.0694vw solid rgba(130, 128, 112, 0.3);
    margin-bottom:   2.7777vw;
}

.galerie-filtres-scroll {
    display:    flex;
    align-items: center;
    flex-wrap:   wrap;
    gap:         0.6944vw;
    flex:        1;
}

.galerie-filtre-group {
    display:    flex;
    align-items: center;
    flex-wrap:   wrap;
    gap:         0.2777vw;
}

.galerie-filtre-sep {
    display:          block;
    width:            0.0694vw;
    height:           1.3888vw;
    background-color: var(--clr-muted);
    opacity:          0.4;
    margin:           0 0.6944vw;
    flex-shrink:      0;
}

/* Bouton filtre */
.galerie-filtre-btn {
    display:        inline-flex;
    align-items:    center;
    gap:            0.4166vw;
    padding:        0.6944vw 1.1111vw;
    font-family:    var(--font-sans);
    font-size:      0.7638vw;
    font-weight:    600;
    letter-spacing: 0.0833vw;
    text-transform: uppercase;
    color:          var(--clr-muted);
    background:     transparent;
    border:         0.0694vw solid rgba(130, 128, 112, 0.4);
    cursor:         pointer;
    transition:     all 0.3s ease;
    white-space:    nowrap;
    line-height:    normal;
}

.galerie-filtre-btn:hover {
    color:            var(--clr-dark);
    border-color:     var(--clr-dark);
}

.galerie-filtre-btn.active {
    color:            var(--clr-white);
    background-color: var(--clr-dark);
    border-color:     var(--clr-dark);
}

.galerie-filtre-btn.hidden {
    display: none;
}

/* Badge compteur */
.galerie-count {
    font-size:        0.6250vw;
    font-weight:      400;
    color:            inherit;
    opacity:          0.7;
    letter-spacing:   0;
}

/* Compteur total */
.galerie-total-wrap {
    font-family:    var(--font-sans);
    font-size:      0.7638vw;
    font-weight:    400;
    color:          var(--clr-muted);
    letter-spacing: 0.0416vw;
    white-space:    nowrap;
    flex-shrink:    0;
}

#galerie-total-count {
    font-weight: 600;
    color:       var(--clr-dark);
}


/* ============================================================
   Grille Masonry (CSS columns)
   ============================================================ */
.galerie-grid-wrapper {
    padding: 0 var(--pad-h);
}

.galerie-masonry {
    column-count: 3;
    column-gap:   var(--gap);
}

.galerie-masonry-item {
    break-inside:  avoid;
    display:       block;
    margin-bottom: var(--gap);
    overflow:      hidden;
    cursor:        pointer;
    position:      relative;
    role:          listitem;
}

.galerie-masonry-item img {
    display:    block;
    width:      100%;
    height:     auto;
    object-fit: cover;
    transition: transform 0.6s ease, opacity 0.4s ease;
    opacity:    0;
}

.galerie-masonry-item img.loaded {
    opacity: 1;
}

.galerie-masonry-item:hover img {
    transform: scale(1.03);
}

/* Overlay hover */
.galerie-masonry-item::after {
    content:    '';
    position:   absolute;
    inset:      0;
    background: rgba(9, 11, 11, 0);
    transition: background 0.4s ease;
    pointer-events: none;
}

.galerie-masonry-item:hover::after {
    background: rgba(9, 11, 11, 0.18);
}

/* Info caption */
.galerie-masonry-caption {
    position:   absolute;
    bottom:     0;
    left:       0;
    right:      0;
    padding:    0.8333vw 1.1111vw;
    background: linear-gradient(to top, rgba(9,11,11,0.7) 0%, transparent 100%);
    opacity:    0;
    transition: opacity 0.3s ease;
    pointer-events: none;
}

.galerie-masonry-item:hover .galerie-masonry-caption {
    opacity: 1;
}

.galerie-masonry-caption-logement {
    font-family:    var(--font-sans);
    font-size:      0.6944vw;
    font-weight:    600;
    letter-spacing: 0.0833vw;
    text-transform: uppercase;
    color:          #f3f2ee;
    display:        block;
}

.galerie-masonry-caption-cat {
    font-family: var(--font-serif);
    font-size:   0.9027vw;
    font-style:  italic;
    font-weight: 400;
    color:       rgba(243, 242, 238, 0.8);
    display:     block;
}


/* ============================================================
   Skeleton loader
   ============================================================ */
.galerie-skeleton {
    column-count: 3;
    column-gap:   var(--gap);
}

.galerie-skeleton-item {
    break-inside:     avoid;
    margin-bottom:    var(--gap);
    background:       linear-gradient(90deg, #e8e7e3 25%, #f0efeb 50%, #e8e7e3 75%);
    background-size:  200% 100%;
    animation:        galerie-shimmer 1.4s infinite;
    display:          block;
}

.galerie-skeleton-item:nth-child(1)  { height: 18vw; }
.galerie-skeleton-item:nth-child(2)  { height: 13vw; }
.galerie-skeleton-item:nth-child(3)  { height: 16vw; }
.galerie-skeleton-item:nth-child(4)  { height: 22vw; }
.galerie-skeleton-item:nth-child(5)  { height: 14vw; }
.galerie-skeleton-item:nth-child(6)  { height: 19vw; }
.galerie-skeleton-item:nth-child(7)  { height: 15vw; }
.galerie-skeleton-item:nth-child(8)  { height: 20vw; }
.galerie-skeleton-item:nth-child(9)  { height: 12vw; }

@keyframes galerie-shimmer {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}


/* ============================================================
   État vide
   ============================================================ */
.galerie-empty {
    padding:      5.5555vw var(--pad-h);
    text-align:   center;
    font-family:  var(--font-serif);
    font-size:    2.0833vw;
    font-style:   italic;
    color:        var(--clr-muted);
    column-span:  all;
}


/* ============================================================
   Bouton "Charger plus"
   ============================================================ */
.galerie-loadmore-wrap {
    padding:        2.7777vw var(--pad-h) 0;
    display:        flex;
    justify-content: center;
}

.galerie-btn-more {
    display:        inline-flex;
    align-items:    center;
    gap:            0.6944vw;
    padding:        1.1111vw 2.7777vw;
    font-family:    var(--font-sans);
    font-size:      0.9027vw;
    font-weight:    600;
    letter-spacing: 0.125vw;
    text-transform: uppercase;
    color:          var(--clr-dark);
    background:     transparent;
    border:         0.0694vw solid var(--clr-dark);
    cursor:         pointer;
    transition:     all 0.3s ease;
}

.galerie-btn-more:hover {
    color:       var(--clr-white);
    background:  var(--clr-dark);
}

/* Dots loader inline */
.galerie-btn-more-loader {
    display:    inline-flex;
    align-items: center;
    gap:        0.2777vw;
}

.galerie-btn-more-loader span {
    display:          block;
    width:            0.2777vw;
    height:           0.2777vw;
    background:       currentColor;
    border-radius:    50%;
    animation:        galerie-dots 1s infinite ease-in-out;
}

.galerie-btn-more-loader span:nth-child(2) { animation-delay: 0.15s; }
.galerie-btn-more-loader span:nth-child(3) { animation-delay: 0.3s;  }

@keyframes galerie-dots {
    0%, 80%, 100% { transform: scale(0.6); opacity: 0.4; }
    40%           { transform: scale(1);   opacity: 1;   }
}


/* ============================================================
   Lightbox
   ============================================================ */
.galerie-lightbox {
    position:   fixed;
    inset:      0;
    z-index:    99999;
    display:    flex;
    align-items: center;
    justify-content: center;
}

.galerie-lightbox[aria-hidden="true"] {
    display: none;
}

.galerie-lb-backdrop {
    position:   absolute;
    inset:      0;
    background: rgba(9, 11, 11, 0.92);
    cursor:     pointer;
}

.galerie-lb-inner {
    position:    relative;
    z-index:     1;
    display:     flex;
    align-items: center;
    justify-content: center;
    width:       100%;
    height:      100%;
    padding:     4.1666vw 6.9444vw;
}

/* Image */
.galerie-lb-img-wrap {
    position:    relative;
    max-width:   80vw;
    max-height:  85vh;
    display:     flex;
    align-items: center;
    justify-content: center;
}

#galerie-lb-img {
    display:    block;
    max-width:  80vw;
    max-height: 85vh;
    width:      auto;
    height:     auto;
    object-fit: contain;
    transition: opacity 0.25s ease;
}

#galerie-lb-img.loading {
    opacity: 0;
}

/* Spinner chargement image */
.galerie-lb-img-loader {
    position:      absolute;
    inset:         0;
    display:       flex;
    align-items:   center;
    justify-content: center;
    pointer-events: none;
    opacity:       0;
    transition:    opacity 0.2s ease;
}

.galerie-lb-img-loader.visible {
    opacity: 1;
}

.galerie-lb-img-loader::after {
    content:     '';
    width:       2vw;
    height:      2vw;
    border:      0.1388vw solid rgba(243,242,238,0.3);
    border-top-color: #f3f2ee;
    border-radius: 50%;
    animation:   galerie-spin 0.7s linear infinite;
}

@keyframes galerie-spin {
    to { transform: rotate(360deg); }
}

/* Bouton fermer */
.galerie-lb-close {
    position:    absolute;
    top:         2.0833vw;
    right:       2.0833vw;
    width:       2.0833vw;
    height:      2.0833vw;
    display:     flex;
    align-items: center;
    justify-content: center;
    background:  none;
    border:      none;
    cursor:      pointer;
    color:       #f3f2ee;
    transition:  transform 0.4s ease, opacity 0.3s ease;
    opacity:     0.8;
    z-index:     2;
}

.galerie-lb-close:hover {
    transform: rotate(90deg);
    opacity:   1;
}

.galerie-lb-close svg {
    width:  1.3888vw;
    height: 1.3888vw;
}

/* Boutons navigation */
.galerie-lb-nav {
    position:    absolute;
    top:         50%;
    transform:   translateY(-50%);
    width:       3.4722vw;
    height:      3.4722vw;
    display:     flex;
    align-items: center;
    justify-content: center;
    background:  rgba(243, 242, 238, 0.08);
    border:      0.0694vw solid rgba(243, 242, 238, 0.2);
    cursor:      pointer;
    color:       #f3f2ee;
    transition:  all 0.3s ease;
    z-index:     2;
}

.galerie-lb-nav:hover {
    background:  rgba(243, 242, 238, 0.2);
    border-color: rgba(243, 242, 238, 0.5);
}

.galerie-lb-prev { left:  2.0833vw; }
.galerie-lb-next { right: 2.0833vw; }

.galerie-lb-nav svg {
    width:  1.3888vw;
    height: 1.3888vw;
}

/* Footer lightbox */
.galerie-lb-footer {
    position:   absolute;
    bottom:     2.0833vw;
    left:       50%;
    transform:  translateX(-50%);
    display:    flex;
    align-items: center;
    gap:        2.0833vw;
    white-space: nowrap;
}

.galerie-lb-meta {
    display:    flex;
    align-items: center;
    gap:        0.6944vw;
}

.galerie-lb-logement {
    font-family:    var(--font-sans);
    font-size:      0.6944vw;
    font-weight:    600;
    letter-spacing: 0.0833vw;
    text-transform: uppercase;
    color:          #f3f2ee;
}

.galerie-lb-cat {
    font-family:  var(--font-serif);
    font-size:    0.9027vw;
    font-style:   italic;
    font-weight:  400;
    color:        rgba(243, 242, 238, 0.7);
}

.galerie-lb-cat:not(:empty)::before {
    content: '— ';
}

.galerie-lb-counter {
    font-family:    var(--font-sans);
    font-size:      0.6944vw;
    font-weight:    400;
    color:          rgba(243, 242, 238, 0.5);
    letter-spacing: 0.0416vw;
}

/* Transition entrée/sortie lightbox */
.galerie-lightbox.is-opening .galerie-lb-backdrop,
.galerie-lightbox.is-opening .galerie-lb-inner {
    animation: galerie-lb-fadein 0.3s ease forwards;
}

.galerie-lightbox.is-closing .galerie-lb-backdrop,
.galerie-lightbox.is-closing .galerie-lb-inner {
    animation: galerie-lb-fadeout 0.25s ease forwards;
}

@keyframes galerie-lb-fadein {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes galerie-lb-fadeout {
    from { opacity: 1; }
    to   { opacity: 0; }
}


/* ============================================================
   Responsive — Tablette (760px → 1024px)
   ============================================================ */
@media (max-width: 1024px) {
    .galerie-logements-section {
        --pad-h: 5.3333vw;
        --gap: 1.0666vw;
    }

    .galerie-titre         { font-size: 7vw; }
    .galerie-sous-titre    { font-size: 1.7333vw; letter-spacing: 0.2666vw; }
    .galerie-masonry       { column-count: 2; }
    .galerie-skeleton      { column-count: 2; }
    .galerie-filtre-btn    { font-size: 1.3333vw; padding: 1.0666vw 1.6vw; }
    .galerie-count         { font-size: 1.0666vw; }
    .galerie-total-wrap    { font-size: 1.3333vw; }
    .galerie-btn-more      { font-size: 1.6vw; letter-spacing: 0.2666vw; padding: 2.1333vw 4.2666vw; }

    .galerie-masonry-caption-logement { font-size: 1.0666vw; }
    .galerie-masonry-caption-cat      { font-size: 1.6vw; }

    .galerie-lb-close { width: 4vw; height: 4vw; top: 4vw; right: 4vw; }
    .galerie-lb-close svg { width: 2.6666vw; height: 2.6666vw; }
    .galerie-lb-nav   { width: 6.4vw; height: 6.4vw; }
    .galerie-lb-nav svg { width: 2.6666vw; height: 2.6666vw; }
    .galerie-lb-prev  { left: 2.6666vw; }
    .galerie-lb-next  { right: 2.6666vw; }
    .galerie-lb-logement { font-size: 1.0666vw; }
    .galerie-lb-cat      { font-size: 1.6vw; }
    .galerie-lb-counter  { font-size: 1.0666vw; }
    #galerie-lb-img { max-width: 88vw; max-height: 80vh; }
    .galerie-lb-img-wrap { max-width: 88vw; max-height: 80vh; }
    .galerie-lb-img-loader::after { width: 4vw; height: 4vw; border-width: 0.2666vw; }
}


/* ============================================================
   Responsive — Mobile (< 760px)
   ============================================================ */
@media (max-width: 760px) {
    .galerie-logements-section {
        --pad-h: 5.3333vw;
        --gap:   1.6vw;
    }

    .galerie-header { padding: 21.3333vw var(--pad-h) 8vw; }
    .galerie-titre    { font-size: 10.6666vw; }
    .galerie-sous-titre { font-size: 3.2vw; letter-spacing: 0.48vw; margin-top: 4.2666vw; }

    .galerie-filtres {
        padding:    0 var(--pad-h) 6.4vw;
        flex-direction: column;
        align-items: flex-start;
        gap:        4.2666vw;
        border-bottom: 0.2666vw solid rgba(130, 128, 112, 0.3);
        margin-bottom: 6.4vw;
    }

    .galerie-filtres-scroll {
        overflow-x: auto;
        overflow-y: hidden;
        flex-wrap:  nowrap;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 1.0666vw;
        gap:        1.6vw;
        width:      calc(100% + 5.3333vw * 2);
        margin-left: calc(-1 * var(--pad-h));
        padding-left: var(--pad-h);
        padding-right: var(--pad-h);
        scrollbar-width: none;
    }

    .galerie-filtres-scroll::-webkit-scrollbar { display: none; }

    .galerie-filtre-group { flex-wrap: nowrap; gap: 1.6vw; }

    .galerie-filtre-sep {
        width:  0.2666vw;
        height: 5.3333vw;
        margin: 0 1.6vw;
    }

    .galerie-filtre-btn {
        font-size:   2.9333vw;
        padding:     2.1333vw 3.2vw;
        letter-spacing: 0.2666vw;
        border-width: 0.2666vw;
        white-space: nowrap;
    }

    .galerie-count   { font-size: 2.4vw; }
    .galerie-total-wrap { font-size: 2.9333vw; }

    .galerie-masonry  { column-count: 2; }
    .galerie-skeleton { column-count: 2; }

    .galerie-skeleton-item:nth-child(1) { height: 32vw; }
    .galerie-skeleton-item:nth-child(2) { height: 24vw; }
    .galerie-skeleton-item:nth-child(3) { height: 28vw; }
    .galerie-skeleton-item:nth-child(4) { height: 40vw; }
    .galerie-skeleton-item:nth-child(5) { height: 26vw; }
    .galerie-skeleton-item:nth-child(6) { height: 34vw; }
    .galerie-skeleton-item:nth-child(7) { height: 28vw; }
    .galerie-skeleton-item:nth-child(8) { height: 38vw; }
    .galerie-skeleton-item:nth-child(9) { height: 22vw; }

    .galerie-masonry-caption { padding: 3.2vw 4.2666vw; }
    .galerie-masonry-caption-logement { font-size: 2.1333vw; }
    .galerie-masonry-caption-cat      { font-size: 3.2vw; }

    .galerie-loadmore-wrap  { padding: 6.4vw var(--pad-h) 0; }
    .galerie-btn-more       { font-size: 3.2vw; letter-spacing: 0.48vw; padding: 4.2666vw 8.5333vw; border-width: 0.2666vw; }
    .galerie-btn-more-loader span { width: 1.0666vw; height: 1.0666vw; }

    /* Lightbox mobile */
    .galerie-lb-inner   { padding: 5.3333vw; }
    .galerie-lb-img-wrap { max-width: 100%; max-height: 70vh; }
    #galerie-lb-img     { max-width: 100%; max-height: 70vh; }

    .galerie-lb-close   { top: 5.3333vw; right: 5.3333vw; width: 8vw; height: 8vw; }
    .galerie-lb-close svg { width: 5.3333vw; height: 5.3333vw; }

    .galerie-lb-nav     { width: 10.6666vw; height: 10.6666vw; }
    .galerie-lb-nav svg { width: 5.3333vw; height: 5.3333vw; }
    .galerie-lb-prev    { left: 0; }
    .galerie-lb-next    { right: 0; }

    .galerie-lb-footer  { bottom: 5.3333vw; flex-direction: column; gap: 2.1333vw; align-items: center; }
    .galerie-lb-logement { font-size: 2.9333vw; letter-spacing: 0.2666vw; }
    .galerie-lb-cat     { font-size: 3.7333vw; }
    .galerie-lb-counter { font-size: 2.4vw; }

    .galerie-lb-img-loader::after { width: 8vw; height: 8vw; border-width: 0.5333vw; }
}


/* ============================================================
   MOBILE UX — Barre de filtres sticky (visible uniquement sur mobile)
   ============================================================ */

/* Cachée sur desktop — affichée en mobile */
.galerie-mobile-bar {
    display: none;
}

@media (max-width: 760px) {

    /* Cacher la barre de filtres desktop */
    .galerie-filtres {
        display: none !important;
    }

    /* Barre mobile sticky */
    .galerie-mobile-bar {
        display:          flex;
        align-items:      center;
        justify-content:  space-between;
        gap:              2.6666vw;
        padding:          3.2vw var(--pad-h);
        position:         sticky;
        top:              0;
        z-index:          500;
        background:       var(--clr-bg);
        border-bottom:    0.2666vw solid rgba(130, 128, 112, 0.2);
        min-height:       13.3333vw;
    }

    /* Zone des chips de filtres actifs */
    .galerie-active-chips {
        display:    flex;
        align-items: center;
        gap:        2.1333vw;
        flex:       1;
        min-width:  0;
        overflow-x: auto;
        scrollbar-width: none;
    }
    .galerie-active-chips::-webkit-scrollbar { display: none; }

    /* Chip individuel */
    .galerie-active-chip {
        display:        inline-flex;
        align-items:    center;
        gap:            1.6vw;
        padding:        1.6vw 2.6666vw;
        background:     var(--clr-dark);
        color:          var(--clr-white);
        font-family:    var(--font-sans);
        font-size:      2.9333vw;
        font-weight:    600;
        letter-spacing: 0.2vw;
        text-transform: uppercase;
        border:         none;
        cursor:         pointer;
        white-space:    nowrap;
        flex-shrink:    0;
        transition:     background 0.2s ease;
    }

    .galerie-active-chip:active {
        background: rgba(9, 11, 11, 0.8);
    }

    .galerie-chip-x {
        width:  2.6666vw;
        height: 2.6666vw;
        opacity: 0.7;
    }

    /* Bouton "Filtrer" */
    .galerie-mobile-filter-btn {
        display:        inline-flex;
        align-items:    center;
        gap:            2.1333vw;
        padding:        2.1333vw 3.7333vw;
        background:     transparent;
        color:          var(--clr-dark);
        border:         0.2666vw solid var(--clr-dark);
        font-family:    var(--font-sans);
        font-size:      2.9333vw;
        font-weight:    600;
        letter-spacing: 0.2666vw;
        text-transform: uppercase;
        cursor:         pointer;
        flex-shrink:    0;
        transition:     all 0.25s ease;
    }

    .galerie-mobile-filter-btn svg {
        width:  4vw;
        height: 3.2vw;
    }

    .galerie-mobile-filter-btn.has-filter {
        background: var(--clr-dark);
        color:      var(--clr-white);
    }

    /* Badge compteur de filtres actifs */
    .galerie-filter-badge {
        display:         inline-flex;
        align-items:     center;
        justify-content: center;
        width:           4.8vw;
        height:          4.8vw;
        background:      #f3f2ee;
        color:           var(--clr-dark);
        font-size:       2.4vw;
        font-weight:     700;
        border-radius:   50%;
        line-height:     1;
    }
}


/* ============================================================
   MOBILE UX — Bottom Sheet Filtre
   ============================================================ */
.galerie-filter-sheet {
    display:  none;
    position: fixed;
    inset:    0;
    z-index:  100000;
}

.galerie-filter-sheet.is-open {
    display: block;
}

/* Fond semi-transparent */
.galerie-sheet-backdrop {
    position:   absolute;
    inset:      0;
    background: rgba(9, 11, 11, 0.5);
    animation:  galerie-backdrop-in 0.25s ease forwards;
}

@keyframes galerie-backdrop-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.galerie-filter-sheet.is-closing .galerie-sheet-backdrop {
    animation: galerie-backdrop-out 0.25s ease forwards;
}

@keyframes galerie-backdrop-out {
    from { opacity: 1; }
    to   { opacity: 0; }
}

/* Panneau coulissant */
.galerie-sheet-panel {
    position:         absolute;
    bottom:           0;
    left:             0;
    right:            0;
    background:       #f3f2ee;
    padding:          0 5.3333vw env(safe-area-inset-bottom, 5.3333vw);
    max-height:       85vh;
    overflow-y:       auto;
    -webkit-overflow-scrolling: touch;
    animation:        galerie-sheet-up 0.35s cubic-bezier(0.32, 0.72, 0, 1) forwards;
    border-top:       0.2666vw solid rgba(130, 128, 112, 0.2);
    box-shadow:       0 -4px 24px rgba(9, 11, 11, 0.12);
}

@keyframes galerie-sheet-up {
    from { transform: translateY(100%); }
    to   { transform: translateY(0); }
}

.galerie-filter-sheet.is-closing .galerie-sheet-panel {
    animation: galerie-sheet-down 0.28s ease forwards;
}

@keyframes galerie-sheet-down {
    from { transform: translateY(0); }
    to   { transform: translateY(100%); }
}

/* Poignée drag */
.galerie-sheet-handle {
    width:         10.6666vw;
    height:        1.0666vw;
    background:    rgba(130, 128, 112, 0.35);
    border-radius: 0.5333vw;
    margin:        3.2vw auto 4.2666vw;
}

/* En-tête du panneau */
.galerie-sheet-header {
    display:         flex;
    align-items:     center;
    justify-content: space-between;
    padding-bottom:  4.2666vw;
    border-bottom:   0.2666vw solid rgba(130, 128, 112, 0.2);
    margin-bottom:   4.2666vw;
}

.galerie-sheet-title {
    font-family:    var(--font-serif);
    font-size:      5.3333vw;
    font-style:     italic;
    font-weight:    400;
    color:          var(--clr-dark);
}

.galerie-sheet-reset {
    font-family:    var(--font-sans);
    font-size:      3.2vw;
    font-weight:    600;
    letter-spacing: 0.2666vw;
    text-transform: uppercase;
    color:          var(--clr-muted);
    background:     none;
    border:         none;
    cursor:         pointer;
    padding:        0;
    text-decoration: underline;
}

/* Sections logement / catégorie */
.galerie-sheet-section {
    margin-bottom: 6.4vw;
}

.galerie-sheet-label {
    display:        block;
    font-family:    var(--font-sans);
    font-size:      2.6666vw;
    font-weight:    600;
    letter-spacing: 0.2666vw;
    text-transform: uppercase;
    color:          var(--clr-muted);
    margin-bottom:  3.2vw;
}

/* Groupe de boutons dans le sheet */
.galerie-sheet-group {
    display:   flex;
    flex-wrap: wrap;
    gap:       2.1333vw;
}

.galerie-sheet-btn {
    display:        inline-flex;
    align-items:    center;
    gap:            1.6vw;
    padding:        2.6666vw 4.2666vw;
    font-family:    var(--font-sans);
    font-size:      3.2vw;
    font-weight:    600;
    letter-spacing: 0.1333vw;
    text-transform: uppercase;
    color:          var(--clr-muted);
    background:     transparent;
    border:         0.2666vw solid rgba(130, 128, 112, 0.4);
    cursor:         pointer;
    transition:     all 0.2s ease;
    white-space:    nowrap;
}

.galerie-sheet-btn.active {
    color:       var(--clr-white);
    background:  var(--clr-dark);
    border-color: var(--clr-dark);
}

.galerie-sheet-count {
    font-size:   2.4vw;
    font-weight: 400;
    opacity:     0.7;
}

/* Bouton "Voir les photos" */
.galerie-sheet-footer {
    padding:    4.2666vw 0 2.1333vw;
    position:   sticky;
    bottom:     0;
    background: linear-gradient(to bottom, rgba(243, 242, 238, 0) 0%, #f3f2ee 30%);
}

.galerie-sheet-apply {
    width:          100%;
    padding:        4.2666vw;
    background:     var(--clr-dark);
    color:          var(--clr-white);
    font-family:    var(--font-sans);
    font-size:      3.4666vw;
    font-weight:    600;
    letter-spacing: 0.48vw;
    text-transform: uppercase;
    border:         none;
    cursor:         pointer;
    display:        flex;
    align-items:    center;
    justify-content: center;
    gap:            2.1333vw;
    transition:     opacity 0.2s ease;
}

.galerie-sheet-apply:active {
    opacity: 0.85;
}

#galerie-sheet-apply-count {
    font-size:   3.2vw;
    font-weight: 400;
    opacity:     0.7;
}


/* ============================================================
   MOBILE UX — Lightbox redesignée
   ============================================================ */
@media (max-width: 760px) {

    /* Cache les flèches desktop */
    .galerie-lb-nav-desktop {
        display: none !important;
    }

    /* Image prend toute la hauteur disponible */
    .galerie-lb-img-wrap {
        max-width:   100vw;
        max-height:  calc(100vh - 32vw); /* réserve la barre du bas */
        width:       100vw;
    }

    #galerie-lb-img {
        max-width:   100vw;
        max-height:  calc(100vh - 32vw);
        width:       100%;
    }

    /* Contenu lightbox en colonne */
    .galerie-lb-inner {
        flex-direction: column;
        align-items:    center;
        justify-content: flex-start;
        padding:        0;
    }

    /* Indicateur swipe-down */
    .galerie-lb-swipe-hint {
        width:       100%;
        display:     flex;
        justify-content: center;
        padding:     3.2vw 0 2.1333vw;
        flex-shrink: 0;
    }

    .galerie-lb-swipe-hint span {
        display:       block;
        width:         10.6666vw;
        height:        1.0666vw;
        background:    rgba(243, 242, 238, 0.3);
        border-radius: 0.5333vw;
        transition:    background 0.2s ease;
    }

    /* Quand l'utilisateur commence à swipper vers le bas */
    .galerie-lightbox.is-swiping-down .galerie-lb-swipe-hint span {
        background: rgba(243, 242, 238, 0.7);
    }

    /* Fermer : repositionné en haut à droite, taille agrandie */
    .galerie-lb-close {
        position:  fixed;
        top:       4vw;
        right:     4vw;
        width:     11.7333vw;
        height:    11.7333vw;
        background: rgba(9, 11, 11, 0.5);
    }

    .galerie-lb-close svg {
        width:  4.8vw;
        height: 4.8vw;
    }

    /* Barre du bas : infos + flèches dans la zone de pouce */
    .galerie-lb-bottom {
        position:         fixed;
        bottom:           0;
        left:             0;
        right:            0;
        display:          flex;
        flex-direction:   column;
        align-items:      center;
        gap:              0;
        background:       linear-gradient(to top, rgba(9,11,11,0.85) 0%, transparent 100%);
        padding:          8vw var(--pad-h) env(safe-area-inset-bottom, 5.3333vw);
        z-index:          2;
    }

    .galerie-lb-footer {
        display:        flex;
        flex-direction: column;
        align-items:    center;
        gap:            1.6vw;
        position:       static;
        transform:      none;
        margin-bottom:  4.2666vw;
    }

    .galerie-lb-logement { font-size: 2.6666vw; letter-spacing: 0.2666vw; }
    .galerie-lb-cat      { font-size: 3.7333vw; }
    .galerie-lb-counter  { font-size: 2.4vw; }

    /* Flèches mobile dans la zone de pouce */
    .galerie-lb-nav-mobile {
        display:        flex;
        align-items:    center;
        justify-content: center;
        gap:            16vw;
    }

    .galerie-lb-nav-mob-btn {
        width:           13.3333vw;
        height:          13.3333vw;
        background:      rgba(243, 242, 238, 0.1);
        border:          0.2666vw solid rgba(243, 242, 238, 0.25);
        cursor:          pointer;
        color:           #f3f2ee;
        display:         flex;
        align-items:     center;
        justify-content: center;
        transition:      all 0.2s ease;
        border-radius:   50%;
        -webkit-tap-highlight-color: transparent;
    }

    .galerie-lb-nav-mob-btn:active {
        background: rgba(243, 242, 238, 0.25);
    }

    .galerie-lb-nav-mob-btn svg {
        width:  5.3333vw;
        height: 5.3333vw;
    }

    /* Animation swipe-down sur l'image */
    .galerie-lb-inner.is-dragging {
        transition: none;
    }

    .galerie-lb-inner.is-dragging .galerie-lb-img-wrap {
        transition: transform 0.05s linear;
    }
}

/* Sur desktop : cacher les éléments mobile */
@media (min-width: 761px) {
    .galerie-mobile-bar     { display: none !important; }
    .galerie-filter-sheet   { display: none !important; }
    .galerie-lb-nav-mobile  { display: none; }
    .galerie-lb-swipe-hint  { display: none; }
    .galerie-lb-bottom      { position: absolute; }
}

