/* ================================================================
   Block : textGallery
   Layout full-width : texte dans un container centré, image collée au bord
   ================================================================ */

.block-textGallery {
    overflow: hidden;
}

.text-gallery {
    display: flex;
    align-items: stretch;
    /* Pas de hauteur fixe : c'est la colonne texte qui détermine la hauteur.
       La colonne galerie s'étire grâce à align-items: stretch. */
    min-height: 400px; /* plancher minimum pour éviter un block trop petit */
}

/* ── Colonne texte ── */
.text-gallery__text {
    flex: 0 0 50%;
    display: flex;
    align-items: center;
    /* Pas de padding direct ici : on utilise un inner pour centrer
       le contenu tout en laissant la colonne couvrir exactement 50 %. */
}

.text-gallery__text-inner {
    /* Reproduit le comportement d'un .container côté gauche :
       la marge gauche s'adapte à la largeur du viewport pour
       que le texte reste aligné avec le reste de la page. */
    width: 100%;
    max-width: 640px;
    margin-left: auto;    /* pousse le contenu vers le bord droit de la colonne */
    padding: 60px 60px 60px 40px;
    box-sizing: border-box;
}

.text-gallery__text-inner h2 {
    margin-top: 0;
}

.text-gallery__content {
    margin-top: 16px;
}

/* Boutons */
.text-gallery__buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 32px;
    align-items: center;
}

.text-gallery__buttons .btn-separator {
    opacity: .4;
    user-select: none;
}

/* ── Colonne galerie ── */
.text-gallery__gallery {
    flex: 0 0 50%;
    position: relative; /* contexte de positionnement pour les slides absolues */
    overflow: hidden;
}

/* Toutes les slides sont en position absolute et couvrent le conteneur */
.text-gallery__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.8s ease;
}

.text-gallery__slide.is-active {
    opacity: 1;
}

.text-gallery__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* ── Layout reversed ── */
.text-gallery--reversed {
    flex-direction: row-reverse;
}

.text-gallery--reversed .text-gallery__text-inner {
    margin-left: 0;
    margin-right: auto;
    padding: 60px 40px 60px 60px;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .text-gallery {
        flex-direction: column;
        height: auto;
    }

    .text-gallery--reversed {
        flex-direction: column;
    }

    .text-gallery__text,
    .text-gallery__gallery {
        flex: 0 0 auto;
        width: 100%;
    }

    /* Sur mobile la galerie a une hauteur fixe explicite
       car les slides sont toutes en absolute */
    .text-gallery__gallery {
        height: 300px;
    }

    .text-gallery__text-inner {
        max-width: 100%;
        margin: 0;
        padding: 40px 24px;
    }

    .text-gallery__buttons .btn-separator {
        display: none;
    }
}