/**
 * Glesner - Text + Image Sections
 */

/* ============================================
   SECTION TEXT-IMAGE STANDARD
   ============================================ */
.text-image-section {
    width: 100%;
    padding: 100px 0;
}

/* Première section text-image après hero-page sur les pages secondaires : retirer padding-top */
.hero-page-section + .text-image-section {
    padding: 0 0 40px 0;
}

/* Exception pour la page contact : garder padding-bottom 100px */
body.page-template-page-contact .hero-page-section + .text-image-section {
    padding: 0 0 100px 0;
}

/* Première section text-image après hero-home : visible dès l'arrivée */
.hero-home-section + .text-image-section {
    margin-top: 0;
    padding-top: 0;
}

.text-image-section-black {
    background: #16161A;
}

.text-image-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 80px;
}

.text-image-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

.text-image-grid-reverse {
    direction: rtl;
}

.text-image-grid-reverse > * {
    direction: ltr;
}

/* Image */
.text-image-image {
    width: 100%;
}

.text-image-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    border-radius: 0;
}

/* Contenu texte */
.text-image-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* H3 harmonisé - style global dans glesner.css */

.text-image-text {
    font-size: 1.125rem;
    line-height: 1.8;
    letter-spacing: 0;
    color: rgba(255, 255, 255, 0.9);
    margin: 0 0 40px 0;
}

.text-image-text p {
    margin: 0 0 20px 0;
    letter-spacing: 0;
}

.text-image-text p:last-child {
    margin-bottom: 0;
}

/* Bouton */
@media (max-width: 1200px) {
    .text-image-content h3 {
        font-size: 1.6rem;
    }
    
}

.text-image-button .cta-button {
    display: inline-block;
    padding: 16px 32px;
    background: transparent;
    color: #FFFFFF;
    border: 1px solid #FCCE2D;
    border-radius: 50px;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0;
    text-decoration: none;
    text-transform: none;
    transition: all 0.3s ease;
    cursor: pointer;
}

.text-image-button .cta-button:hover {
    background: #FCCE2D;
    color: #16161A;
}

/* ============================================
   VARIANTE FOND BLANC
   ============================================ */
.text-image-section-white {
    background: #FFFFFF;
}

.text-image-section-white .text-image-content h2 {
    color: #16161A;
}

.text-image-section-white .text-image-text {
    color: #666666;
}

.text-image-section-white .text-image-button .cta-button {
    color: #16161A;
    border-color: #16161A;
}

.text-image-section-white .text-image-button .cta-button:hover {
    background: #16161A;
    color: #FFFFFF;
}

/* ============================================
   VARIANTE ALT - IMAGE COLLÉE AU BORD
   ============================================ */
.text-image-section-alt {
    background: #f9f9f9;
    padding: 0;
}

.text-image-section-alt .text-image-container {
    max-width: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}

.text-image-section-alt .text-image-grid {
    display: contents;
}

.text-image-section-alt .text-image-image {
    margin: 0;
    padding: 0;
}

.text-image-section-alt .text-image-img {
    width: 100%;
    height: 100%;
    min-height: 600px;
    object-fit: cover;
    border-radius: 0;
    display: block;
}

.text-image-section-alt .text-image-content {
    max-width: 700px;
    margin: 0 auto;
    padding: 60px 80px;
}

/* H3 sur fond clair : couleur sombre */
.text-image-section-white .text-image-content h3,
.text-image-section-alt .text-image-content h3 {
    color: #16161A;
}

.text-image-section-alt .text-image-text {
    color: #666666;
}

.text-image-section-alt .text-image-button .cta-button {
    background: #FFFFFF;
    color: #16161A;
}

.text-image-section-alt .text-image-button .cta-button:hover {
    background: #FCCE2D;
    color: #16161A;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1200px) {
    .text-image-container {
        padding: 0 60px;
    }
    
    .text-image-grid {
        gap: 60px;
    }
    
    .text-image-content h3 {
        font-size: 2.25rem;
    }
    
    .text-image-section-alt .text-image-content {
        padding: 80px 60px;
    }
}

@media (max-width: 768px) {
    .text-image-section {
        padding: 60px 0;
    }

    /* Uniquement la première text-image de la page d'accueil */
    .hero-home-section + .text-image-section {
        /* padding: 60px 0; */
    }

    /* Première section après hero-page : garder padding-bottom en responsive */
    .hero-page-section + .text-image-section {
        padding: 0 0 60px 0;
    }
    
    .text-image-container {
        padding: 0 30px;
    }
    
    .text-image-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    
    .text-image-grid-reverse {
        direction: ltr;
    }
    
    .text-image-content h2 {
        font-size: 1.875rem;
        margin-bottom: 20px;
    }
    
    .text-image-text {
        font-size: 1rem;
        margin-bottom: 30px;
    }

    .text-image-section-alt .text-image-container {
        grid-template-columns: 1fr;
    }
    
    .text-image-section-alt .text-image-img {
        min-height: 300px;
    }
    
    .text-image-section-alt .text-image-content {
        padding: 40px 30px;
    }
}

@media (max-width: 480px) {
    .text-image-container {
        padding: 0 20px;
    }
    
    /* H3 harmonisé - taille responsive gérée globalement */
    
    .text-image-section-alt .text-image-content {
        padding: 30px 20px;
    }
}
