/*
Theme Name: Avada Child Theme - Optitude
Theme URI: https://www.optitude.fr
Description: Thème enfant Avada pour Optitude - Opticiens
Author: Optitude
Author URI: https://www.optitude.fr
Template: Avada
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: avada-child-optitude
*/

/* ==========================================================================
   Personnalisations Optitude
   ========================================================================== */
/* Style bouton sans bordure visible */
.fusion-button.button-flat,
.post-content .fusion-button,
.fusion-blog-shortcode .fusion-button {
    position: relative !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 15px 40px !important;
    margin: 8px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    transition: all 0.3s ease !important;
    box-shadow: none !important;
}

/* Premier rectangle - décalé vers le haut et la gauche */
.fusion-button.button-flat::before,
.post-content .fusion-button::before,
.fusion-blog-shortcode .fusion-button::before {
    content: '' !important;
    position: absolute !important;
    top: -4px !important;
    left: 4px !important;
    right: -4px !important;
    bottom: 4px !important;
    border: 1px solid #c6ab66 !important;
    border-radius: 0 !important;
    pointer-events: none !important;
    transition: all 0.3s ease !important;
}

/* Deuxième rectangle - décalé vers le bas et la droite */
.fusion-button.button-flat::after,
.post-content .fusion-button::after,
.fusion-blog-shortcode .fusion-button::after {
    content: '' !important;
    position: absolute !important;
    top: 4px !important;
    left: -4px !important;
    right: 4px !important;
    bottom: -4px !important;
    border: 1px solid #c6ab66 !important;
    border-radius: 0 !important;
    pointer-events: none !important;
    transition: all 0.3s ease !important;
    z-index: -1 !important;
}

/* Hover - les deux rectangles se rejoignent */
.fusion-button.button-flat:hover::before,
.post-content .fusion-button:hover::before,
.fusion-blog-shortcode .fusion-button:hover::before {
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
}

.fusion-button.button-flat:hover::after,
.post-content .fusion-button:hover::after,
.fusion-blog-shortcode .fusion-button:hover::after {
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
}

/* S'assurer que le texte reste visible */
.fusion-button.button-flat .fusion-button-text,
.post-content .fusion-button .fusion-button-text,
.fusion-blog-shortcode .fusion-button .fusion-button-text {
    color: inherit !important;
    position: relative !important;
    z-index: 1 !important;
}
/* ==========================================================================
   Filtres des marques
   ========================================================================== */
.marques-filters-wrapper {
    margin: 0;
    padding: 0;
    background: transparent;
    border-radius: 8px;
    cursor: default !important;
    pointer-events: auto !important;
}

.marques-filters-wrapper * {
    cursor: default !important;
    pointer-events: auto !important;
}

.marques-filter-group {
    margin-bottom: 15px;
    display: flex !important;
    align-items: center !important;
    gap: 15px !important;
    flex-wrap: wrap !important;
}

.marques-filter-group:last-of-type {
    margin-bottom: 10px;
}

.marques-filter-label {
    font-weight: 600 !important;
    font-size: 16px !important;
    margin-bottom: 0 !important;
    color: #ffffff !important;
    cursor: default !important;
    pointer-events: none !important;
    flex-shrink: 0 !important;
}

.marques-filter-buttons {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

.marques-filter-btn {
    padding: 8px 16px !important;
    background: transparent !important;
    border: 2px solid #c6ab66 !important;
    border-radius: 30px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #c6ab66 !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
    display: inline-block !important;
    pointer-events: auto !important;
}

.marques-filter-btn:hover {
    color: #e5d292 !important;
    border-color: #e5d292 !important;
    text-decoration: none !important;
}

.marques-filter-btn.active {
    background: #c6ab66 !important;
    border-color: #c6ab66 !important;
    color: #fff !important;
}

.marques-filter-btn.active:hover {
    background: #e5d292 !important;
    border-color: #e5d292 !important;
    color: #fff !important;
}

.marques-filter-reset {
    padding: 8px 16px !important;
    background: transparent !important;
    border: 2px solid #aaa !important;
    border-radius: 30px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #aaa !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    text-decoration: none !important;
    display: inline-block !important;
    margin-top: 10px !important;
    pointer-events: auto !important;
}

.marques-filter-reset:hover {
    background: #ddd !important;
    border-color: #ddd !important;
    color: #333 !important;
    text-decoration: none !important;
}

.marques-filter-counter {
    margin-top: 25px;
    text-align: center;
    font-size: 15px;
    color: #666;
    font-weight: 500;
}

.marques-filter-counter .no-results {
    color: #c6ab66;
    font-weight: 600;
}

@media (max-width: 768px) {
    .marques-filters-wrapper {
        padding: 0;
    }

    .marques-filter-group {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 10px !important;
    }

    .marques-filter-buttons {
        gap: 6px;
    }

    .marques-filter-btn {
        padding: 6px 14px;
        font-size: 13px;
    }

    .marques-filter-reset {
        padding: 6px 14px;
        font-size: 13px;
    }
}

/* ==========================================================================
   Pills taxonomies marques (réutilise les styles des filtres)
   ========================================================================== */
.marque-pills-wrapper {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    margin: 10px 0;
}

.marque-pills-wrapper .marques-filter-btn {
    cursor: default !important;
    pointer-events: none !important;
}

@media (max-width: 768px) {
    .marque-pills-wrapper {
        gap: 6px !important;
    }

    .marque-pills-wrapper .marques-filter-btn {
        padding: 6px 14px;
        font-size: 13px;
    }
}

/* ==========================================================================
   Footer - Titres liens en blanc
   ========================================================================== */
.fusion-footer-widget-area h1 a,
.fusion-footer-widget-area h2 a,
.fusion-footer-widget-area h3 a,
.fusion-footer-widget-area h4 a,
.fusion-footer-widget-area h5 a,
.fusion-footer-widget-area h6 a {
    color: #ffffff !important;
}

/* ==========================================================================
   Slider/Carousel magasin - Hauteur adaptée à la colonne voisine
   ========================================================================== */

/* Carousel magasin : hauteur forcée via JS (voir optitude_fix_carousel_init) */
.magasin-carousel {
    width: 100% !important;
    margin-bottom: 0 !important;
}

.magasin-carousel .awb-swiper-carousel {
    position: relative !important;
    overflow: hidden !important;
    border-radius: 20px !important;
    /* height est setté via JS après mesure de la carte */
}

.magasin-carousel .swiper-wrapper {
    align-items: stretch !important;
}

.magasin-carousel .swiper-slide,
.magasin-carousel .fusion-carousel-item-wrapper,
.magasin-carousel .fusion-image-wrapper {
    height: 100% !important;
}

/* Images : cover pour zoomer selon le format */
.magasin-carousel .swiper-slide img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
}

/* Dots : en overlay en bas de l'image */
.magasin-carousel .swiper-pagination {
    position: absolute !important;
    bottom: 12px !important;
    left: 0 !important;
    width: 100% !important;
    z-index: 2;
}
/* ==========================================================================
   Galerie d'images avec overlay doré animé
   Usage: [optitude_galerie_images] ... [/optitude_galerie_images]
   ========================================================================== */

.optitude-galerie {
    display: flex;
    flex-direction: column;
    gap: var(--galerie-gap, 8px);
    width: 100%;
    cursor: default;
}

/* Ligne = conteneur flex horizontal */
.optitude-galerie__row {
    display: flex;
    gap: var(--galerie-gap, 8px);
    width: 100%;
    cursor: default;
    /* Pas de hauteur fixe : le ratio 16/9 du petit item pilote la hauteur */
}

/* Item de base - stretch par défaut pour remplir la ligne */
.optitude-galerie__item {
    position: relative;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    display: flex !important;
    align-items: center;
    text-decoration: none !important;
    cursor: pointer !important;
    /* pas de height : flex align-items:stretch (défaut) gère l'étirement */
}

/* Petit item : ratio 16/9 — sa hauteur naturelle pilote la ligne */
.optitude-galerie__item--small {
    flex: 0 0 calc((100% - var(--galerie-gap, 8px)) * 0.4); /* 40% de la largeur totale */
    aspect-ratio: 16 / 9;
}

/* Grand item : prend le reste */
.optitude-galerie__item--large {
    flex: 1; /* Prend tout l'espace restant */
    aspect-ratio: auto;
}

/* Vidéo / YouTube en fond */
.optitude-galerie__video {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    z-index: 0;
    border: none !important;
}

/* iframe YouTube / Complianz : remplir le conteneur */
.optitude-galerie__item iframe.optitude-galerie__video,
.optitude-galerie__item iframe.cmplz-iframe {
    width: 100% !important;
    height: 100% !important;
    border: none !important;
    pointer-events: none;
}

/* Pas de curseur pointer sur les items vidéo sans lien */
.optitude-galerie__item--video {
    cursor: default;
}

/* Overlay doré - base commune */
.optitude-galerie__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translateX(-40%);
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 2;
    pointer-events: none;
}

/* 4 trapèzes qui se croisent */
.optitude-galerie__overlay--a {
    background: rgba(198, 171, 102, 0.45);
    clip-path: polygon(0 0, 72% 0, 42% 100%, 0 100%);
}

.optitude-galerie__overlay--b {
    background: rgba(198, 171, 102, 0.35);
    clip-path: polygon(0 0, 42% 0, 72% 100%, 0 100%);
    transition-delay: 0.08s;
}

.optitude-galerie__overlay--a2 {
    background: rgba(198, 171, 102, 0.3);
    clip-path: polygon(0 0, 52% 0, 22% 100%, 0 100%);
    transition-delay: 0.14s;
}

.optitude-galerie__overlay--b2 {
    background: rgba(198, 171, 102, 0.25);
    clip-path: polygon(0 0, 22% 0, 52% 100%, 0 100%);
    transition-delay: 0.2s;
}

/* Animation au hover */
.optitude-galerie__item:hover .optitude-galerie__overlay {
    transform: translateX(0);
}

/* Titre en overlay */
.fusion-body .optitude-galerie .optitude-galerie__item .optitude-galerie__titre,
.optitude-galerie a.optitude-galerie__item span.optitude-galerie__titre,
.optitude-galerie .optitude-galerie__item .optitude-galerie__titre {
    position: relative !important;
    z-index: 10 !important;
    color: #ffffff !important;
    font-size: clamp(22px, 2.5vw, 32px) !important;
    font-weight: 400 !important;
    font-family: 'Open Sans', sans-serif !important;
    text-shadow: 0 2px 10px rgba(0,0,0,0.4); !important;
    text-transform: uppercase !important;
    letter-spacing: 4px !important;
    padding-left: 30px !important;
    max-width: 60% !important;
    line-height: 1.4 !important;
    display: inline-block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    width: auto !important;
    overflow: visible !important;
    clip: auto !important;
    -webkit-text-fill-color: #ffffff !important;
    cursor: pointer !important;
}

/* Responsive mobile */
@media (max-width: 768px) {
    .optitude-galerie__row {
        flex-direction: column;
        height: auto;
    }

    .optitude-galerie__item--small,
    .optitude-galerie__item--large {
        flex: 1 1 auto;
        aspect-ratio: 16 / 9;
        width: 100%;
    }

    .optitude-galerie__titre {
        font-size: 15px !important;
        padding-left: 20px !important;
        max-width: 80% !important;
    }
}