/* Reepost Post Gallery - grille, survol, overlay titre, coming soon, vidéo, filtres (variables CSS) */
.reepost-post-gallery-root .reepost-gallery-grid {
    display: grid;
    grid-template-columns: repeat(var(--reepost-pg-cols-d, 3), 1fr);
    width: 100%;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item {
    aspect-ratio: var(--reepost-pg-aspect-d, 16/9);
}

/* Variantes responsives pilotées par classes JS (is-tablet / is-mobile) */
.reepost-post-gallery-root.is-tablet .reepost-gallery-grid {
    grid-template-columns: repeat(var(--reepost-pg-cols-t, 2), 1fr);
}
.reepost-post-gallery-root.is-tablet .reepost-gallery-grid .reepost-gallery-item {
    aspect-ratio: var(--reepost-pg-aspect-t, 16/9);
}

.reepost-post-gallery-root.is-mobile .reepost-gallery-grid {
    grid-template-columns: repeat(var(--reepost-pg-cols-m, 1), 1fr);
}
.reepost-post-gallery-root.is-mobile .reepost-gallery-grid .reepost-gallery-item {
    aspect-ratio: var(--reepost-pg-aspect-m, 16/9);
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item {
    position: relative;
    display: block;
    overflow: hidden;
    cursor: pointer;
    text-decoration: none;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: filter 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.6s ease;
    will-change: transform, filter;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item:hover .gallery-img {
    filter: blur(var(--reepost-pg-blur-d, 2.5px)) brightness(var(--reepost-pg-brightness, 0.7));
    transform: scale(var(--reepost-pg-zoom, 1.02));
}

.reepost-post-gallery-root.is-tablet .reepost-gallery-grid .reepost-gallery-item:hover .gallery-img {
    filter: blur(var(--reepost-pg-blur-t, 2.5px)) brightness(var(--reepost-pg-brightness, 0.7));
}

.reepost-post-gallery-root.is-mobile .reepost-gallery-grid .reepost-gallery-item:hover .gallery-img {
    filter: blur(var(--reepost-pg-blur-m, 2.5px)) brightness(var(--reepost-pg-brightness, 0.7));
}

/* Vignetage (optionnel, désactivé si --reepost-pg-vignette-opacity: 0) */
.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(ellipse at center, transparent var(--reepost-pg-vignette-start, 30%), rgba(var(--reepost-pg-vignette-rgb, 0, 0, 0), var(--reepost-pg-vignette-opacity, 0)) var(--reepost-pg-vignette-end, 80%));
    opacity: 0;
    transition: opacity 0.6s ease;
    pointer-events: none;
    z-index: var(--reepost-z-overlay);
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item:hover::after {
    opacity: 1;
}

/* Titre au survol */
.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-title-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) translateY(20px) scale(0.9);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--reepost-pg-title-duration, 0.6s) cubic-bezier(0.4, 0, 0.2, 1) var(--reepost-pg-title-delay, 0s), visibility var(--reepost-pg-title-duration, 0.6s) cubic-bezier(0.4, 0, 0.2, 1) var(--reepost-pg-title-delay, 0s), transform var(--reepost-pg-title-duration, 0.6s) cubic-bezier(0.4, 0, 0.2, 1) var(--reepost-pg-title-delay, 0s);
    z-index: var(--reepost-z-content);
    text-align: center;
    width: 90%;
    max-width: 90%;
    background: none !important;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-title-overlay {
    text-shadow: var(--reepost-pg-title-shadow, 0 2px 10px rgba(0,0,0,0.4));
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item:hover .gallery-title-overlay {
    opacity: 1;
    visibility: visible;
    transform: translate(-50%, -50%) translateY(0) scale(1);
}

/* Titre toujours visible (data-attr sur le root) */
.reepost-post-gallery-root[data-title-always-visible-desktop="1"] .reepost-gallery-item .gallery-title-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate(-50%, -50%) translateY(0) scale(1) !important;
}

.reepost-post-gallery-root.is-tablet[data-title-always-visible-tablet="1"] .reepost-gallery-item .gallery-title-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate(-50%, -50%) translateY(0) scale(1) !important;
}
.reepost-post-gallery-root.is-tablet[data-title-always-visible-tablet="0"] .reepost-gallery-item .gallery-title-overlay,
.reepost-post-gallery-root.is-tablet:not([data-title-always-visible-tablet]) .reepost-gallery-item .gallery-title-overlay {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(20px) scale(0.9);
}
.reepost-post-gallery-root.is-tablet[data-title-always-visible-tablet="0"] .reepost-gallery-item:hover .gallery-title-overlay,
.reepost-post-gallery-root.is-tablet:not([data-title-always-visible-tablet]) .reepost-gallery-item:hover .gallery-title-overlay {
    opacity: 1;
    transform: translate(-50%, -50%) translateY(0) scale(1);
}

.reepost-post-gallery-root.is-mobile[data-title-always-visible-mobile="1"] .reepost-gallery-item .gallery-title-overlay {
    opacity: 1 !important;
    visibility: visible !important;
    transform: translate(-50%, -50%) translateY(0) scale(1) !important;
}
.reepost-post-gallery-root.is-mobile[data-title-always-visible-mobile="0"] .reepost-gallery-item .gallery-title-overlay,
.reepost-post-gallery-root.is-mobile:not([data-title-always-visible-mobile]) .reepost-gallery-item .gallery-title-overlay {
    opacity: 0;
    transform: translate(-50%, -50%) translateY(20px) scale(0.9);
}
.reepost-post-gallery-root.is-mobile[data-title-always-visible-mobile="0"] .reepost-gallery-item:hover .gallery-title-overlay,
.reepost-post-gallery-root.is-mobile:not([data-title-always-visible-mobile]) .reepost-gallery-item:hover .gallery-title-overlay {
    opacity: 1;
    transform: translate(-50%, -50%) translateY(0) scale(1);
}

/* Overlay Coming Soon */
.reepost-post-gallery-root .coming-soon-overlay {
    position: absolute;
    text-align: center;
    z-index: var(--reepost-z-content);
    opacity: 1;
    transition: opacity 0.4s ease, transform 0.4s ease;
    pointer-events: none;
    white-space: normal;
    word-break: break-word;
    display: flex;
    align-items: center;
    justify-content: center;
}

.reepost-post-gallery-root .coming-soon-overlay {
    text-shadow: var(--reepost-pg-coming-soon-shadow, 0 2px 10px rgba(0,0,0,0.4));
}

.reepost-post-gallery-root .coming-soon-overlay.no-bg {
    background: none !important;
    width: 80% !important;
    height: auto !important;
    padding: 12px 10px !important;
    border-radius: 0 !important;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item:hover .coming-soon-overlay {
    opacity: 0;
}

/* Vidéo au survol */
.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item[data-video-type] .gallery-img {
    transition: filter 0.6s cubic-bezier(0.4, 0, 0.2, 1), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.6s ease;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item[data-video-type]:hover .gallery-img {
    opacity: 0;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-video-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: var(--reepost-z-media);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.6s ease;
    overflow: hidden;
    background: transparent;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item[data-video-type]:hover .gallery-video-container {
    opacity: 1;
    pointer-events: auto;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-video-container:empty {
    display: none !important;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item:not([data-video-type]) .gallery-video-container {
    display: none !important;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-video-container video,
.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item .gallery-video-container iframe {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
    background: transparent;
}

/* Toolbar fusionnée - style par défaut élégant */
.reepost-post-gallery-root .reepost-gallery-toolbar.reepost-gallery-toolbar-merged {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 16px;
    width: 100%;
    padding: 12px 0;
}

/* Annule width:100% pour afficher recherche et filtres côte à côte */
.reepost-post-gallery-root .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-gallery-search-wrapper {
    flex: 1 1 auto;
    min-width: 180px;
    max-width: 100%;
    width: auto;
    margin: 0;
}

.reepost-post-gallery-root .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper,
.reepost-post-gallery-root .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-buttons {
    flex: 0 1 auto;
    width: auto;
    margin: 0;
}

.reepost-post-gallery-root .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
}

/* Toolbar fusionnée : mode mobile (dropdown filtre) - recherche alignée en HAUT avec "Filtrer" */
.reepost-post-gallery-root.reepost-filter-bp-767.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-tablet .reepost-gallery-toolbar.reepost-gallery-toolbar-merged {
    align-items: flex-start;
}

.reepost-post-gallery-root.reepost-filter-bp-767.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-tablet .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper {
    flex: 0 0 auto;
}

.reepost-post-gallery-root.reepost-filter-bp-767.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-tablet .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons {
    min-width: 0;
    width: 0;
    overflow: hidden;
}

/* Toggle "Filtrer" en barre fusionnée : largeur pour que text-align fonctionne */
.reepost-post-gallery-root.reepost-filter-bp-767.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-tablet .reepost-gallery-toolbar.reepost-gallery-toolbar-merged > .reepost-filter-wrapper {
    min-width: 100px;
}

.reepost-post-gallery-root.reepost-filter-bp-767.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-button.reepost-filter-toggle,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-mobile .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-button.reepost-filter-toggle,
.reepost-post-gallery-root.reepost-filter-bp-1024.is-tablet .reepost-gallery-toolbar.reepost-gallery-toolbar-merged .reepost-filter-button.reepost-filter-toggle {
    width: 100%;
    min-width: 0;
    flex-shrink: 0;
    text-align: var(--reepost-filter-dropdown-align, left);
}


/* Recherche - style par défaut élégant et moderne */
.reepost-post-gallery-root .reepost-gallery-search-wrapper {
    display: flex;
    width: 100%;
}

.reepost-post-gallery-root .reepost-gallery-search-input {
    appearance: none;
    -webkit-appearance: none;
    width: 100%;
    min-height: 42px;
    padding: 10px 16px;
    font-size: 0.9375rem;
    line-height: 1.4;
    color: #ffffff;
    background-color: #131313;
    border: none;
    border-radius: 24px;
    outline: none;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

.reepost-post-gallery-root .reepost-gallery-search-input::placeholder {
    color: rgba(255, 255, 255, 0.7);
}

.reepost-post-gallery-root .reepost-gallery-search-input:hover {
    background-color: #1a1a1a;
}

.reepost-post-gallery-root .reepost-gallery-search-input:focus {
    outline: none;
    background-color: #1f1f1f;
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.15);
}

/* Message "Aucun résultat" - caché par défaut, affiché via JS quand 0 résultats */
.reepost-post-gallery-root .reepost-gallery-no-results {
    display: none;
    grid-column: 1 / -1;
}

.reepost-post-gallery-root .reepost-gallery-grid.is-empty .reepost-gallery-no-results {
    display: block;
}

/* Filtres utilisateur - style par défaut harmonisé avec la recherche */
.reepost-post-gallery-root .reepost-filter-wrapper,
.reepost-post-gallery-root ~ .reepost-filter-wrapper {
    display: block;
    width: 100%;
}

.reepost-filter-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.reepost-filter-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 18px;
    font-size: 0.9375rem;
    line-height: 1.4;
    font-weight: 500;
    color: #ffffff;
    background-color: #131313;
    border: none;
    border-radius: 24px;
    cursor: pointer;
    transition: background-color 0.2s ease;
    outline: none;
    text-decoration: none;
    user-select: none;
}

.reepost-filter-button.reepost-filter-toggle {
    display: none;
}

.reepost-filter-button:hover {
    color: #ffffff;
    background-color: #1a1a1a;
}

.reepost-filter-button.active {
    color: #ffffff;
    background-color: #2a2a2a;
}

.reepost-filter-button.active:hover {
    background-color: #333333;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item {
    transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 1;
    transform: scale(1);
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item.filter-hiding {
    opacity: 0 !important;
    transform: scale(0.85) !important;
    pointer-events: none;
    overflow: hidden;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item.filter-hidden {
    display: none !important;
}

.reepost-post-gallery-root .reepost-gallery-grid .reepost-gallery-item.filter-showing {
    animation: reepostFilterShow 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes reepostFilterShow {
    from { opacity: 0; transform: scale(0.85); }
    to { opacity: 1; transform: scale(1); }
}

/* Dropdown filtre : style harmonisé pour le bouton "Filtrer" */
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-button.reepost-filter-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 18px;
    font-size: 0.9375rem;
    font-weight: 500;
    color: #ffffff;
    background-color: #131313;
    border: none;
    border-radius: 24px;
    width: 100%;
    text-align: var(--reepost-filter-dropdown-align, left);
    transition: background-color 0.2s ease;
}
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-button.reepost-filter-toggle:hover {
    color: #ffffff;
    background-color: #1a1a1a;
}
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-wrapper:not(.is-collapsed) .reepost-filter-buttons {
    margin-top: var(--reepost-filter-dropdown-toggle-gap, 10px);
}
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-wrapper .reepost-filter-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: var(--reepost-filter-dropdown-gap, 10px);
    background-color: var(--reepost-filter-dropdown-bg, transparent);
    overflow: hidden;
    max-height: 2000px;
    opacity: 1;
    transform: translateY(0);
    transition: max-height 0.35s ease, opacity 0.25s ease, transform 0.25s ease;
    will-change: max-height, opacity, transform;
}
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-wrapper .reepost-filter-button {
    width: 100%;
    text-align: var(--reepost-filter-dropdown-align, left);
}
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-767 .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons {
    max-height: 0;
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
}

.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-button.reepost-filter-toggle,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-button.reepost-filter-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 10px 18px;
    font-size: 0.9375rem;
    font-weight: 500;
    color: #ffffff;
    background-color: #131313;
    border: none;
    border-radius: 24px;
    width: 100%;
    text-align: var(--reepost-filter-dropdown-align, left);
    transition: background-color 0.2s ease;
}
.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-button.reepost-filter-toggle:hover,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-button.reepost-filter-toggle:hover {
    color: #ffffff;
    background-color: #1a1a1a;
}
.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-wrapper:not(.is-collapsed) .reepost-filter-buttons,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-wrapper:not(.is-collapsed) .reepost-filter-buttons {
    margin-top: var(--reepost-filter-dropdown-toggle-gap, 10px);
}
.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-wrapper .reepost-filter-buttons,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-wrapper .reepost-filter-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: var(--reepost-filter-dropdown-gap, 10px);
    background-color: var(--reepost-filter-dropdown-bg, transparent);
    overflow: hidden;
    max-height: 2000px;
    opacity: 1;
    transform: translateY(0);
    transition: max-height 0.35s ease, opacity 0.25s ease, transform 0.25s ease;
    will-change: max-height, opacity, transform;
}
.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-wrapper .reepost-filter-button,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-wrapper .reepost-filter-button {
    width: 100%;
    text-align: var(--reepost-filter-dropdown-align, left);
}
.reepost-post-gallery-root.is-tablet.reepost-filter-bp-1024 .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons,
.reepost-post-gallery-root.is-mobile.reepost-filter-bp-1024 .reepost-filter-wrapper.is-collapsed .reepost-filter-buttons {
    max-height: 0;
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
}
