/*
Theme Name: Astra Child - Soins Anato V2
Theme URI: https://soinsanato.com
Description: Thème enfant Astra optimisé pour Soins Anato avec responsive mobile complet
Author: AnatoWeb Expert Pro
Author URI: https://soinsanato.com
Template: astra
Version: 2.0.1
Text Domain: astra-child
*/

/* ========================================
   📦 IMPORT DU THÈME PARENT
   ======================================== */
@import url('../astra/style.css');

/* ========================================
   🎨 STYLES GÉNÉRAUX DESKTOP
   ======================================== */

:root {
    --couleur-primaire: #1A3A52;
    --couleur-secondaire: #7FC8A9;
    --couleur-accent: #D4AF37;
    --couleur-texte: #4A5568;
    --couleur-fond: #F9F9F9;
}

body {
    font-family: 'Open Sans', sans-serif;
    color: var(--couleur-texte);
    background: var(--couleur-fond);
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Montserrat', sans-serif;
    color: var(--couleur-primaire);
}

/* ========================================
   📱 RESPONSIVE MOBILE COMPLET
   ======================================== */

/* 🔧 BASE MOBILE : Empêcher le débordement horizontal */
@media (max-width: 921px) {
    html {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
    
    body {
        overflow-x: hidden !important;
        width: 100% !important;
        max-width: 100vw !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    * {
        box-sizing: border-box !important;
    }
    
    /* Empêcher TOUT débordement */
    .site,
    .site-content,
    .ast-container,
    .entry-content {
        overflow-x: hidden !important;
        max-width: 100vw !important;
    }
}

/* ========================================
   1️⃣ HEADER ET MENU MOBILE
   ======================================== */

@media (max-width: 921px) {
    /* Header mobile */
    .site-header {
        padding: 10px 15px !important;
    }
    
    /* CACHER le menu desktop */
    .main-header-bar .ast-desktop-header-content,
    .main-header-bar-navigation,
    .ast-desktop-menu-container,
    #primary-menu {
        display: none !important;
    }
    
    /* AFFICHER le conteneur mobile */
    .ast-mobile-header-wrap {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        width: 100% !important;
    }
    
    /* Logo mobile */
    .site-branding {
        flex: 1 !important;
    }
    
    .site-title,
    .custom-logo-link {
        font-size: 20px !important;
    }
    
    .custom-logo {
        max-height: 50px !important;
        width: auto !important;
    }
    
    /* BOUTON HAMBURGER */
    .ast-mobile-menu-buttons {
        display: flex !important;
        visibility: visible !important;
        opacity: 1 !important;
        z-index: 10000 !important;
    }
    
    .ast-button-wrap,
    .menu-toggle {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 50px !important;
        height: 50px !important;
        background: var(--couleur-primaire) !important;
        border: none !important;
        border-radius: 5px !important;
        cursor: pointer !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    
    /* Les 3 barres du hamburger */
    .menu-toggle .mobile-menu,
    .ast-mobile-menu-buttons button span {
        display: block !important;
        width: 25px !important;
        height: 3px !important;
        background: #fff !important;
        position: relative !important;
        transition: all 0.3s ease !important;
    }
    
    .menu-toggle .mobile-menu::before,
    .menu-toggle .mobile-menu::after {
        content: '' !important;
        display: block !important;
        width: 25px !important;
        height: 3px !important;
        background: #fff !important;
        position: absolute !important;
        left: 0 !important;
        transition: all 0.3s ease !important;
    }
    
    .menu-toggle .mobile-menu::before {
        top: -8px !important;
    }
    
    .menu-toggle .mobile-menu::after {
        bottom: -8px !important;
    }
    
    /* MENU DÉROULANT MOBILE */
    .main-header-menu,
    .ast-mobile-popup-drawer {
        display: none !important;
        position: fixed !important;
        top: 70px !important;
        left: 0 !important;
        width: 100% !important;
        height: calc(100vh - 70px) !important;
        background: #fff !important;
        box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
        z-index: 9999 !important;
        overflow-y: auto !important;
        padding: 20px 0 !important;
    }
    
    /* Menu ouvert (quand on clique sur hamburger) */
    .ast-mobile-menu-buttons.toggled + .main-header-menu,
    .ast-header-break-point .main-header-bar-navigation,
    body.ast-mobile-popup-drawer .main-header-menu {
        display: block !important;
    }
    
    /* Items du menu */
    .main-header-menu ul,
    .ast-mobile-popup-inner ul {
        list-style: none !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    .main-header-menu ul li {
        width: 100% !important;
        border-bottom: 1px solid #eee !important;
    }
    
    .main-header-menu ul li a {
        display: block !important;
        padding: 18px 25px !important;
        color: var(--couleur-primaire) !important;
        text-decoration: none !important;
        font-size: 18px !important;
        font-weight: 600 !important;
        transition: all 0.3s ease !important;
    }
    
    .main-header-menu ul li a:hover,
    .main-header-menu ul li a:focus {
        background: var(--couleur-fond) !important;
        color: var(--couleur-secondaire) !important;
        padding-left: 35px !important;
    }
    
    /* Bouton actif */
    .main-header-menu ul li.current-menu-item a,
    .main-header-menu ul li.current_page_item a {
        background: var(--couleur-primaire) !important;
        color: #fff !important;
    }
}

/* ========================================
   2️⃣ BLOCS HTML PERSONNALISÉS (GUTENBERG)
   ======================================== */

@media (max-width: 768px) {
    /* TOUS les blocs HTML */
    .wp-block-html,
    .wp-block-group,
    .wp-block-columns,
    .wp-block-column,
    .wp-block-cover,
    [class*="wp-block"] {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 15px !important;
        padding-right: 15px !important;
        overflow: hidden !important;
    }
    
    /* Conteneur principal */
    .entry-content,
    .ast-container {
        width: 100% !important;
        max-width: 100% !important;
        padding: 0 15px !important;
        overflow-x: hidden !important;
    }
    
    /* Colonnes Gutenberg */
    .wp-block-columns {
        flex-direction: column !important;
        gap: 20px !important;
    }
    
    .wp-block-column {
        flex-basis: 100% !important;
        width: 100% !important;
        max-width: 100% !important;
    }
    
    /* Groupes et sections */
    .wp-block-group__inner-container {
        padding: 20px 15px !important;
    }
}

/* ========================================
   3️⃣ CARREAUX / CARDS (débordement texte)
   ======================================== */

@media (max-width: 768px) {
    /* Carreaux avec background */
    .wp-block-group.has-background,
    [class*="card"],
    [class*="box"],
    [style*="background"] {
        padding: 25px 20px !important;
        margin: 0 0 25px 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
        word-wrap: break-word !important;
    }
    
    /* Textes dans les carreaux */
    .wp-block-group.has-background h2,
    .wp-block-group.has-background h3,
    .wp-block-group.has-background h4,
    .wp-block-group.has-background p,
    .wp-block-group.has-background li {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        max-width: 100% !important;
        padding: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    
    /* FIX SPÉCIFIQUE : "Recevez une confirmation" */
    .wp-block-group.has-background p strong,
    .wp-block-group.has-background p span {
        display: inline !important;
        white-space: normal !important;
        word-break: break-word !important;
    }
}

/* ========================================
   4️⃣ TEXTES RESPONSIVE
   ======================================== */

@media (max-width: 768px) {
    /* Titres */
    h1, .entry-title {
        font-size: 26px !important;
        line-height: 1.3 !important;
        margin-bottom: 15px !important;
    }
    
    h2 {
        font-size: 22px !important;
        line-height: 1.3 !important;
        margin-bottom: 12px !important;
    }
    
    h3 {
        font-size: 20px !important;
        line-height: 1.4 !important;
        margin-bottom: 10px !important;
    }
    
    h4, h5, h6 {
        font-size: 18px !important;
        line-height: 1.4 !important;
    }
    
    /* Paragraphes */
    p {
        font-size: 16px !important;
        line-height: 1.7 !important;
        margin-bottom: 15px !important;
    }
    
    /* Empêcher TOUT débordement de texte */
    h1, h2, h3, h4, h5, h6, p, li, span, div, a {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
        white-space: normal !important;
        max-width: 100% !important;
    }
}

/* ========================================
   5️⃣ IMAGES ET MÉDIAS
   ======================================== */

@media (max-width: 768px) {
    img,
    figure,
    iframe,
    video,
    embed {
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
        display: block !important;
        margin: 0 auto 20px !important;
    }
    
    .wp-block-image,
    .wp-block-media-text {
        width: 100% !important;
    }
    
    .wp-block-media-text__content {
        padding: 20px 15px !important;
    }
}

/* ========================================
   6️⃣ BOUTONS
   ======================================== */

@media (max-width: 768px) {
    .wp-block-button,
    .wp-block-buttons {
        width: 100% !important;
        margin-bottom: 15px !important;
    }
    
    .wp-block-button__link,
    .wp-element-button,
    a.button,
    button {
        width: 100% !important;
        max-width: 100% !important;
        padding: 15px 25px !important;
        font-size: 16px !important;
        text-align: center !important;
        display: block !important;
        white-space: normal !important;
        word-wrap: break-word !important;
    }
}

/* ========================================
   7️⃣ FORMULAIRES
   ======================================== */

@media (max-width: 768px) {
    form,
    .wp-block-contact-form-7 {
        width: 100% !important;
        padding: 0 !important;
    }
    
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="url"],
    input[type="number"],
    textarea,
    select {
        width: 100% !important;
        max-width: 100% !important;
        padding: 12px 15px !important;
        font-size: 16px !important;
        margin-bottom: 15px !important;
        border-radius: 5px !important;
    }
    
    input[type="submit"],
    .wpcf7-submit {
        width: 100% !important;
        padding: 15px !important;
        font-size: 18px !important;
    }
}

/* ========================================
   8️⃣ FOOTER
   ======================================== */

@media (max-width: 768px) {
    .site-footer {
        padding: 30px 20px !important;
        text-align: center !important;
    }
    
    .footer-widget-area [class*="footer-widget"] {
        width: 100% !important;
        margin-bottom: 30px !important;
        text-align: center !important;
    }
    
    .footer-widget-area ul {
        list-style: none !important;
        padding: 0 !important;
    }
    
    .footer-widget-area ul li {
        margin-bottom: 10px !important;
    }
}

/* ========================================
   9️⃣ ESPACEMENTS MOBILE
   ======================================== */

@media (max-width: 768px) {
    section,
    .wp-block-group {
        padding: 30px 15px !important;
        margin-bottom: 20px !important;
    }
    
    .entry-content > * {
        margin-bottom: 20px !important;
    }
}

/* ========================================
   🔟 NAVIGATION PAGINATION
   ======================================== */

@media (max-width: 768px) {
    .pagination,
    .nav-links {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: center !important;
        gap: 10px !important;
        padding: 20px 0 !important;
    }
    
    .pagination a,
    .pagination span,
    .nav-links a {
        padding: 12px 18px !important;
        font-size: 16px !important;
        min-width: 50px !important;
        text-align: center !important;
        border-radius: 5px !important;
        background: var(--couleur-primaire) !important;
        color: #fff !important;
        text-decoration: none !important;
    }
}

/* ========================================
   ✅ UTILITAIRES MOBILE
   ======================================== */

@media (max-width: 768px) {
    /* Cacher sur mobile */
    .hide-mobile {
        display: none !important;
    }
    
    /* Afficher uniquement sur mobile */
    .show-mobile {
        display: block !important;
    }
    
    /* Texte centré mobile */
    .text-center-mobile {
        text-align: center !important;
    }
    
    /* Espacement mobile */
    .mb-mobile {
        margin-bottom: 20px !important;
    }
}

/* ========================================
   🌿 FOOTER PERSONNALISÉ - SOINS ANATO
   ======================================== */

.social-footer {
    background: linear-gradient(135deg, #1A3A52 0%, #2C5268 100%);
    color: #F9F9F9;
    padding: 60px 20px 30px;
    margin-top: 80px;
}

.social-footer-container {
    max-width: 1200px;
    margin: 0 auto;
}

.social-footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 40px;
    margin-bottom: 40px;
}

/* Colonne À propos */
.footer-about h3 {
    color: #7FC8A9;
    font-size: 1.5rem;
    margin-bottom: 15px;
    font-weight: 600;
}

.footer-about p {
    color: #E0E0E0;
    line-height: 1.7;
    margin-bottom: 20px;
}

.footer-contact p {
    color: #F9F9F9;
    margin: 8px 0;
    display: flex;
    align-items: center;
    gap: 10px;
}

.footer-contact .icon {
    font-size: 1.2rem;
}

/* Colonne Liens rapides */
.footer-links h4 {
    color: #7FC8A9;
    font-size: 1.2rem;
    margin-bottom: 15px;
    font-weight: 600;
}

.footer-links ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links ul li {
    margin-bottom: 10px;
}

.footer-links ul li a {
    color: #E0E0E0;
    text-decoration: none;
    transition: all 0.3s ease;
    display: inline-block;
}

.footer-links ul li a:hover {
    color: #7FC8A9;
    transform: translateX(5px);
}

/* Colonne Réseaux sociaux */
.footer-social h4 {
    color: #7FC8A9;
    font-size: 1.2rem;
    margin-bottom: 15px;
    font-weight: 600;
}

.social-icons {
    display: flex;
    gap: 15px;
    flex-wrap: wrap;
}

.social-icon {
    width: 50px;
    height: 50px;
    background-color: rgba(127, 200, 169, 0.1);
    border: 2px solid #7FC8A9;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #7FC8A9;
    text-decoration: none;
    transition: all 0.3s ease;
}

.social-icon:hover {
    background-color: #7FC8A9;
    color: #1A3A52;
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(127, 200, 169, 0.3);
}

.social-icon svg {
    width: 24px;
    height: 24px;
    fill: currentColor;
}

/* Bas du footer */
.footer-bottom {
    text-align: center;
    padding-top: 30px;
    border-top: 1px solid rgba(127, 200, 169, 0.2);
    color: #B0B0B0;
    font-size: 0.95rem;
}

.footer-bottom p {
    margin: 8px 0;
}

.footer-bottom strong {
    color: #7FC8A9;
}

/* ========================================
   📱 FOOTER RESPONSIVE MOBILE
   ======================================== */

@media (max-width: 768px) {
    .social-footer {
        padding: 40px 20px 20px;
        margin-top: 50px;
    }
    
    .social-footer-content {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    
    .footer-about h3,
    .footer-links h4,
    .footer-social h4 {
        font-size: 1.2rem;
    }
    
    .footer-about p,
    .footer-links ul li a,
    .footer-contact p {
        font-size: 0.95rem;
    }
    
    .social-icons {
        justify-content: center;
    }
    
    .footer-bottom {
        font-size: 0.85rem;
    }
}

@media (max-width: 480px) {
    .social-footer {
        padding: 30px 15px 15px;
    }
    
    .social-icon {
        width: 45px;
        height: 45px;
    }
    
    .social-icon svg {
        width: 20px;
        height: 20px;
    }
}

/* ========================================
   🔥 FIX OVERLAY BLEU MOBILE - PAGE ACCUEIL
   ======================================== */

@media (max-width: 768px) {
    /* Empêcher les images décoratives de déborder */
    .entry-content img[src*="bleu"],
    .entry-content img[src*="circle"],
    .entry-content img[src*="overlay"],
    .entry-content img[src*="decorative"] {
        max-width: 90% !important;
        margin: 0 auto 20px !important;
        display: block !important;
        position: relative !important;
        z-index: 1 !important;
    }
    
    /* Forcer les images à ne pas se superposer */
    .entry-content .wp-block-image img,
    .entry-content figure img {
        position: relative !important;
        z-index: 1 !important;
        max-width: 100% !important;
        height: auto !important;
        margin-bottom: 20px !important;
    }
    
    /* Forcer les boutons CTA au-dessus de tout */
    .entry-content a[href*="rendez-vous"],
    .entry-content .wp-block-button__link,
    .entry-content .button,
    .entry-content .cta-button,
    .entry-content a.wp-element-button {
        position: relative !important;
        z-index: 999 !important;
        pointer-events: auto !important;
        display: inline-block !important;
        clear: both !important;
        margin-top: 20px !important;
    }
    
    /* Empêcher les pseudo-éléments de masquer le contenu */
    .entry-content *::before,
    .entry-content *::after {
        z-index: auto !important;
        position: relative !important;
    }
    
    /* Réinitialiser les éléments en position absolute */
    .entry-content [style*="position: absolute"],
    .entry-content [style*="position:absolute"] {
        position: relative !important;
        z-index: auto !important;
    }
    
    /* Hero section sans chevauchement */
    .hero-section,
    .wp-block-cover,
    .wp-block-group.has-background {
        position: relative !important;
        overflow: visible !important;
        z-index: auto !important;
    }
    
    /* Texte "Bienvenue chez Soins Anato" visible */
    .hero-section h1,
    .wp-block-cover h1,
    .wp-block-group h1 {
        position: relative !important;
        z-index: 10 !important;
        margin-bottom: 20px !important;
        padding: 0 15px !important;
    }
    
    /* Paragraphes visibles */
    .hero-section p,
    .wp-block-cover p,
    .wp-block-group p {
        position: relative !important;
        z-index: 10 !important;
        padding: 0 15px !important;
        margin-bottom: 15px !important;
    }
    
    /* Cacher les éléments décoratifs qui posent problème */
    .entry-content .decorative-overlay,
    .entry-content .background-shape,
    .entry-content [class*="decoration"] {
        display: none !important;
    }
}

/* FIX SPÉCIFIQUE : Élément bleu circulaire */
@media (max-width: 768px) {
    /* Si c'est un SVG ou une image CSS */
    .entry-content svg[class*="circle"],
    .entry-content div[style*="border-radius: 50%"],
    .entry-content div[style*="border-radius:50%"] {
        display: none !important;
    }
    
    /* Si c'est un pseudo-élément */
    .hero-section::before,
    .hero-section::after,
    .wp-block-cover::before,
    .wp-block-cover::after {
        display: none !important;
    }
}

/* FIX: Section "Prendre rendez-vous" toujours cliquable */
@media (max-width: 768px) {
    /* Bouton principal */
    a[href*="prendre-rendez-vous"],
    a[href*="rendez-vous"],
    .prendre-rdv-button {
        position: relative !important;
        z-index: 9999 !important;
        display: block !important;
        width: fit-content !important;
        margin: 20px auto !important;
        padding: 15px 30px !important;
        background: var(--couleur-primaire) !important;
        color: #fff !important;
        text-decoration: none !important;
        border-radius: 8px !important;
        text-align: center !important;
        pointer-events: auto !important;
        touch-action: manipulation !important;
    }
    
    /* Espacement pour éviter le chevauchement */
    .hero-section a[href*="rendez-vous"],
    .wp-block-group a[href*="rendez-vous"] {
        margin-top: 30px !important;
        clear: both !important;
    }
}

/* ========================================
   🍪 BANNIÈRE COOKIES OPTIMISÉE MOBILE
   ======================================== */

@media (max-width: 768px) {
    /* Conteneur principal de la bannière cookies */
    .cli-modal,
    .cli-popupbar,
    .cli-consent-banner,
    #cookie-law-info-bar,
    .cookie-notice,
    [id*="cookie"],
    [class*="cookie-banner"],
    [class*="gdpr-banner"] {
        /* Position en BAS de l'écran (pas au centre) */
        position: fixed !important;
        bottom: 0 !important;
        top: auto !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        
        /* Design moderne */
        background: rgba(26, 58, 82, 0.98) !important;
        border-top: 3px solid #7FC8A9 !important;
        box-shadow: 0 -4px 20px rgba(0,0,0,0.3) !important;
        
        /* Espacement */
        padding: 20px 15px !important;
        margin: 0 !important;
        
        /* Z-index raisonnable (pas au-dessus du menu) */
        z-index: 9998 !important;
        
        /* Animation d'entrée */
        animation: slideUpCookies 0.5s ease-out !important;
    }
    
    /* Animation d'apparition */
    @keyframes slideUpCookies {
        from {
            transform: translateY(100%);
            opacity: 0;
        }
        to {
            transform: translateY(0);
            opacity: 1;
        }
    }
    
    /* Texte de la bannière */
    .cli-modal p,
    .cli-popupbar p,
    .cookie-notice p,
    [class*="cookie-banner"] p {
        color: #FFFFFF !important;
        font-size: 14px !important;
        line-height: 1.5 !important;
        margin-bottom: 15px !important;
        text-align: center !important;
    }
    
    /* Titre de la bannière */
    .cli-modal h3,
    .cli-modal h4,
    .cookie-notice h3 {
        color: #7FC8A9 !important;
        font-size: 16px !important;
        margin-bottom: 10px !important;
        text-align: center !important;
    }
    
    /* Conteneur des boutons */
    .cli-modal-footer,
    .cli-btn-container,
    .cookie-notice-buttons,
    [class*="cookie-buttons"] {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
        margin-top: 15px !important;
    }
    
    /* TOUS les boutons */
    .cli-modal button,
    .cli-btn,
    .cookie-notice button,
    [class*="cookie-btn"],
    [class*="accept"],
    [class*="reject"],
    [class*="save"] {
        width: 100% !important;
        padding: 14px 20px !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        border: none !important;
        border-radius: 8px !important;
        cursor: pointer !important;
        transition: all 0.3s ease !important;
        text-align: center !important;
        display: block !important;
        margin: 0 !important;
    }
    
    /* Bouton ACCEPT ALL (principal - vert) */
    .cli-btn-accept,
    button[data-cli-action="accept"],
    button[class*="accept"],
    #cookie-accept-all {
        background: #7FC8A9 !important;
        color: #1A3A52 !important;
        border: 2px solid #7FC8A9 !important;
        order: 1 !important;
    }
    
    .cli-btn-accept:hover,
    button[data-cli-action="accept"]:hover {
        background: #6AB396 !important;
        transform: translateY(-2px) !important;
        box-shadow: 0 4px 12px rgba(127, 200, 169, 0.4) !important;
    }
    
    /* Bouton SAVE PREFERENCES (secondaire - blanc) */
    .cli-btn-save,
    button[data-cli-action="save"],
    button[class*="save"],
    #cookie-save-preferences {
        background: #FFFFFF !important;
        color: #1A3A52 !important;
        border: 2px solid #FFFFFF !important;
        order: 2 !important;
    }
    
    .cli-btn-save:hover,
    button[data-cli-action="save"]:hover {
        background: #F0F0F0 !important;
    }
    
    /* Bouton REJECT ALL (tertiaire - transparent) */
    .cli-btn-reject,
    button[data-cli-action="reject"],
    button[class*="reject"],
    #cookie-reject-all {
        background: transparent !important;
        color: #FFFFFF !important;
        border: 2px solid rgba(255,255,255,0.3) !important;
        order: 3 !important;
    }
    
    .cli-btn-reject:hover,
    button[data-cli-action="reject"]:hover {
        background: rgba(255,255,255,0.1) !important;
        border-color: rgba(255,255,255,0.6) !important;
    }
    
    /* Liens "Lire plus" / "Privacy Policy" */
    .cli-privacy-readmore,
    a[href*="privacy"],
    a[href*="politique"] {
        color: #7FC8A9 !important;
        text-decoration: underline !important;
        font-size: 13px !important;
        display: block !important;
        text-align: center !important;
        margin-top: 10px !important;
    }
    
    /* Icône de fermeture (X) */
    .cli-modal-close,
    .cookie-notice-close,
    [class*="close-banner"] {
        position: absolute !important;
        top: 10px !important;
        right: 10px !important;
        width: 30px !important;
        height: 30px !important;
        background: rgba(255,255,255,0.2) !important;
        border-radius: 50% !important;
        color: #FFFFFF !important;
        font-size: 20px !important;
        line-height: 30px !important;
        text-align: center !important;
        cursor: pointer !important;
        border: none !important;
    }
    
    .cli-modal-close:hover {
        background: rgba(255,255,255,0.3) !important;
    }
    
    /* Switch toggles (si présents) */
    .cli-switch,
    input[type="checkbox"] {
        transform: scale(1.2) !important;
        margin: 0 10px !important;
    }
    
    /* Ne PAS masquer le contenu en dessous */
    body.cli-modal-open,
    body.cookie-notice-open {
        overflow: auto !important;
    }
}

/* Version DESKTOP : Position en bas aussi */
@media (min-width: 769px) {
    .cli-modal,
    .cli-popupbar,
    #cookie-law-info-bar {
        bottom: 0 !important;
        top: auto !important;
        max-width: 600px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        border-radius: 12px 12px 0 0 !important;
    }
}