/* --- Styles de base --- */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;700&display=swap');

body, html {
    height: 100%;
    margin: 0;
    font-family: 'Montserrat', sans-serif;
    color: #fff;
    padding: 0;
    overflow-x: hidden;
}


/* ======================================================= */
/* 🖥️ STYLES ORDINATEUR (Min 769px) - Les ajustements précis sont ici */
/* ======================================================= */
@media (min-width: 769px) {


    .photo-mentions-legales {
        width: 100%;
        /* Vous pouvez retirer 'height: auto;' car 'width: 100%' combiné
        /* à l'absence de 'height' gardera automatiquement les proportions. */
        /* Cependant, si vous souhaitez être explicite : */
        height: auto;
        /* Assurez-vous qu'il n'y a pas de marge ou de remplissage (padding)
        /* sur le corps (body) ou le conteneur parent (s'il y en a un) qui empêche
        /* l'image de toucher les bords. */
    }

    .photo-mentions-legales-tel {
        display: none;
    }


    

    /* Style pour la section principale du contenu avec l'image de fond */
    /* CORRECTION : Retrait du margin-top: 100vh car le contenu suit la vidéo, il n'est plus fixe */
    .main-content {
        background-image: url('https://i.imgur.com/NMx9fzP.png');
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center center;
        background-attachment: fixed; /* L'image de fond reste fixe pendant le défilement */
        z-index: -1;
        margin-top: 0; /* Changé de 100vh à 0 */
        color: #333; /* Couleur de texte pour les sections à fond blanc */
    }

   

    header {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 70px;
        z-index: 1000;
        padding: 0 clamp(20px, 5vw, 80px);
        background-color: rgba(255, 255, 255, 0.9);
        backdrop-filter: blur(10px);
        display: flex;
        align-items: center;
        box-sizing: border-box;
    }

    /* Nouveaux éléments MOBLIES cachés sur Ordinateur */
    .header-socials-mobile,
    .menu-toggler,
    .main-nav-mobile {
        display: none;
    }

    /* Le bouton hamburger n'est plus utilisé. */
    .hamburger {
        display: none;
    }

/* Le "bloc" de gauche qui contient logo + nom */
    .header-logo-group {
        display: flex;
        align-items: center;
        text-decoration: none;
        gap: 15px; /* L'espace fixe entre logo et nom */
        margin-right: auto; /* <--- C'est ça qui pousse le menu à droite ! */
        flex-shrink: 0;
    }

    .logo-filou3 {
        height: 50px;
        width: auto;
    }

    .header-nom {
        color: #000;
        white-space: nowrap;
        font-size: clamp(10px, 12px, 14px);
        opacity: 0.8;
        opacity: 0.5;
    }

    /* --- 2. Menu de navigation (main-nav-desktop) --- */

    .main-nav-desktop ul {
        display: flex;
        list-style: none;
        gap: clamp(14px, 2vw, 40px);
        margin: 0;
        padding: 0;
    }

    /* Styles des liens d'images de navigation */
    .nav-img-link {
        color: transparent;
        text-decoration: none;
        display: block;
        position: relative;
    
    }


    /* Le bloc de droite (Menu) */
    .main-nav-desktop {
        display: flex;
    } 

    .main-nav-desktop a {
        text-decoration: none;
        color: #000;
        font-size: clamp(10px, 12px, 14px);
        font-weight: 500;
        transition: color 0.3s;
        opacity: 0.5;
    }

    /* 2. On ajoute cette nouvelle règle pour la page active */
    .main-nav-desktop a.active {
        font-weight: bold;
        /* Optionnel : vous pouvez aussi changer la couleur pour la page active */
        /* color: #EB7F2A; */
    }

    /* On retire le <B> du HTML ou on force le reset ici si nécessaire */
    .main-nav-desktop a B {
        font-weight: inherit;
    }

    .main-nav-desktop b {
        font-weight: inherit;
    }

    /* 🖱️ Effet de survol (hover) */
    .main-nav-desktop a:hover {
    
        color: #ca0013;
        opacity: 1;
    }


    /* .titre_photo2 */
    .titre_photo2 {
        display: flex;
        color: #ca0013;
        font-size: 28px; /* Taille réduite pour mobile */
        margin-top: 150px; /* Marge réduite */
        width: 100%;
        justify-content: center;
        align-items: center; 
        text-align: center;
        margin-bottom: 0px;
    }






    :root {
        --primary-color: #ca0013;
        --text-dark: #1a1a1a;
        --text-light: #666;
        --bg-white: #ffffff;
    }

    body {
        margin: 0;
        font-family: 'Montserrat', sans-serif;
        background-color: var(--bg-white);
        
    }

    .page-container-tel {
        display: none; /* Masqué sur PC */
    }

    .page-container {
        width: 100%;
        max-width: 1400px;
        margin: 0 auto;
        padding: 80px 40px;
        box-sizing: border-box;
        margin-top: -210px;
    }

    /* --- DIVISEUR DE SECTION --- */
    .section-divider {
        width: 80px;
        height: 4px;
        background-color: var(--primary-color);
        margin: 100px auto;
        border: none;
        opacity: 0.4;
    }

    /* --- STRUCTURE DES SECTIONS --- */
    .main-content-section {
        display: flex;
        justify-content: space-between;
        align-items: center;
        position: relative;
        padding: 120px 0;
        gap: 80px;
        min-height: 600px;
    }

    /* Alternance : Une section sur deux est inversée */
    .inverse {
        flex-direction: row-reverse;
    }

    /* --- TEXTE DÉFILANT EN ARRIÈRE-PLAN --- */
    .background-text {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 120vw;
        font-size: 16vw;
        font-weight: 900;
        color: var(--primary-color);
        opacity: 0.06;
        white-space: nowrap;
        z-index: -1;
        pointer-events: none;
        display: flex;
    }

    .background-text span {
        display: inline-block;
        animation: scroll-text 520s linear infinite;
    }

    @keyframes scroll-text {
        0% { transform: translateX(0); }
        100% { transform: translateX(-50%); }
    }

    /* --- BLOC INFOS (Texte) --- */
    .info-block {
        flex: 1;
        max-width: 500px;
    }

    .name-title {
        font-size: 3rem;
        font-weight: 900;
        color: var(--primary-color);
        margin-bottom: 30px;
        line-height: 1.1;
        text-transform: uppercase;
    }

    .description-text {
        font-size: 1.1rem;
        line-height: 1.7;
        color: var(--text-dark);
        margin-bottom: 25px;
    }

    .secondary-text {
        font-size: 0.95rem;
        color: var(--text-light);
        line-height: 1.6;
        border-left: 3px solid var(--primary-color);
        padding-left: 20px;
        margin-top: 25px;
    }

    /* --- STATISTIQUES --- */
    .stats-container {
        display: flex;
        gap: 40px;
        margin: 30px 0;
    }

    .stat-item {
        display: flex;
        flex-direction: column;
    }

    .stat-number {
        font-size: 2.2rem;
        font-weight: 800;
        color: var(--primary-color);
    }

    .stat-label {
        font-size: 0.75rem;
        text-transform: uppercase;
        letter-spacing: 1px;
        font-weight: 600;
        color: black;
        opacity: 0.7;
    }

    /* --- GRILLES DE PHOTOS (MODERNE) --- */
    .photo-block-grid {
        flex: 1.2;
        display: grid;
        grid-template-columns: repeat(12, 1fr);
        grid-template-rows: repeat(10, 50px);
        position: relative;
    }

    /* Style Section 1 (Forêt) */
    .forest .img-1 { grid-column: 1 / 9; grid-row: 1 / 9; z-index: 2; }
    .forest .img-2 { grid-column: 7 / 13; grid-row: 5 / 11; z-index: 3; border: 10px solid white; }

    /* Style Section 2 (Dunes) */
    .dunes .img-1 { grid-column: 4 / 13; grid-row: 1 / 10; }
    .dunes .img-2 { grid-column: 1 / 6; grid-row: 3 / 8; z-index: 2; border: 10px solid white; }


    /* Style Section 3 (Far West) */
    .west .img-1 { grid-column: 1 / 7; grid-row: 1 / 11; }
    .west .img-2 { grid-column: 8 / 13; grid-row: 1 / 5; }
    .west .img-3 { grid-column: 8 / 13; grid-row: 6 / 11; }

    .photo-block-grid img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 12px;
        box-shadow: 0 15px 45px rgba(0,0,0,0.1);
        transition: transform 0.4s ease, filter 0.4s ease;
    }

    .photo-block-grid img:hover {
        transform: scale(1.03) translateY(-5px);
        filter: brightness(1.1);
        z-index: 2;
    }










    .cookie-banner {
        position: fixed;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        background: #E8E8E8;
        color: #333; /* Changé en sombre car le fond est gris très clair (#E8E8E8) */
        padding: 20px;
        border-radius: 10px;
        z-index: 1000;
        display: none; 
        box-shadow: 0 4px 20px rgba(0,0,0,0.3);
        
        /* --- AJUSTEMENT DES MARGES --- */
        width: calc(100% - 100px); /* 100% moins 50px de chaque côté */
        max-width: none; /* On retire le max-width pour forcer le respect des 50px sur grand écran */
        /* Si vous voulez quand même une limite sur très grand écran, gardez un max-width élevé */
        
        text-align: center;
    }


    h6 {
        font-size: 18px;
        font-weight: normal;
    }

    .cookie-buttons { margin-top: 15px; display: flex; gap: 10px; justify-content: center; }

    .btn-accept { background: transparent; border: 1px solid orange; color: orange; padding: 10px 20px; cursor: pointer; border-radius: 5px; }
    .btn-refuse { background: transparent; border: 1px solid orange; color: orange; padding: 10px 20px; cursor: pointer; border-radius: 5px; }



    .map-placeholder {
        width: 100%; height: 100%;
        background: #f0f0f0;
        display: flex; align-items: center; justify-content: center;
        text-align: center; padding: 20px;
    }

        /* Style pour le bouton En savoir plus */
    .btn-info {
        font-size: 0.85em;
        color: #144b63; /* Couleur de votre charte */
        text-decoration: none;
        align-self: center; /* Pour bien l'aligner si vous utilisez flex */
        padding: 10px;
        transition: opacity 0.3s;
    }

    .btn-info:hover {
        opacity: 0.7;
        
    }

 






    /* ======================================================= */
    /* 🖥️ FOOTER - VERSION CENTRÉE ET ÉQUILIBRÉE              */
    /* ======================================================= */

    footer {
        width: 100%;
        padding: 30px 20px;
        margin-top: 0; 
        position: relative; 
        z-index: 9999 !important;
        background-color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .main-nav {
        width: 100%;
        max-width: 1200px; /* Largeur maximale pour laisser respirer les éléments */
    }

    .main-nav ul {
        display: flex;
        justify-content: space-between;
        align-items: center;
        list-style: none;
        padding: 0;
        margin: 0;
    }

    /* --- ASTUCE POUR LE CENTRAGE PARFAIT --- */

    /* On donne une largeur égale aux blocs de gauche et de droite */
    .main-nav ul li:first-child, 
    .main-nav ul li:last-child {
        flex: 1; 
    }

    /* On aligne le copyright à gauche */
    .main-nav ul li:first-child {
        text-align: left;
    }

    /* On aligne les mentions légales à droite */
    .main-nav ul li:last-child {
        text-align: right;
    }

    /* Le bloc du milieu (réseaux sociaux) reste au centre */
    .footer-socials {
        flex: 0 0 auto; /* Ne s'étire pas, garde sa taille naturelle */
        display: flex;
        gap: 25px; 
        justify-content: center;
    }

    /* --- STYLES DES LIENS ET TEXTES --- */

    .main-nav a,
    .main-nav span {
        text-decoration: none;
        color: #000000;
        white-space: nowrap;
        font-size: 0.95em;
        transition: all 0.3s ease;
        display: inline-block;
    }

    .footer-socials a {
        font-size: 1.5em; /* Icônes légèrement plus grandes */
    }

    /* Effet au survol */
    .main-nav a:hover {
        color: #ca0013;
        transform: translateY(-3px);
    }

}

































@media (max-width: 768px) {

    /* --- Styles de base --- */
    @import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;700&display=swap');


    /* --- 1. PRÉVENTION DU DÉBORDEMENT GLOBAL --- */
    body, html {
        /* Empêche toute barre de défilement horizontale forcée par un élément enfant */
        overflow-x: hidden; 
        /* Règle la taille de la police de base pour une meilleure lisibilité */
        font-size: 14px;
        font-family: 'Montserrat', sans-serif;
        

    }


    
    /* --- 2. GESTION DE L'EN-TÊTE FIXE --- */
    
    header {
        position: absolute;
        box-sizing: border-box;
        margin: 0;
        top: 0;
        left: 0;
        width: 100%;
        height: auto;
        padding: 10px 20px;
        background-color: rgba(255, 255, 255, 0.5);
        backdrop-filter: blur(5px);
        -webkit-backdrop-filter: blur(5px);
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        z-index: 16000;
        /* Réinitialise les marges desktop qui pourraient causer des débordements */
        
        display: flex; 
        justify-content: space-between; 
        align-items: center;
    }

    /* ... dans le bloc @media (max-width: 768px) ... */

        /* Rendre la vidéo visible sur mobile */
    .video-background {
        display: block; 
        position: relative;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh; /* Force la hauteur à 100% de la fenêtre */
        overflow: hidden;
        z-index: -2;
    }

    .video-background video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* Masquer l'image d'accueil mobile si la vidéo est utilisée */
    .photo-accueil {
        display: none !important;
    }

    /* Ajuster le contenu principal pour qu'il commence APRES la vidéo */
    .main-content {
        /* Retirez la marge-top fixe du header, car la vidéo couvre l'écran entier */
        margin-top: 0 !important; 
    }



    .main-nav-desktop {
        display: none;
    }
    
/* Le "bloc" de gauche qui contient logo + nom */
    .header-logo-group {
        display: flex;
        align-items: center;
        text-decoration: none;
        gap: 15px; /* L'espace fixe entre logo et nom */
        margin-right: auto; /* <--- C'est ça qui pousse le menu à droite ! */
        flex-shrink: 0;
    }

    .logo-filou3 {
        height: 50px;
        width: auto;
    }

    .header-nom {
        color: #000;
        white-space: nowrap;
        font-size: clamp(10px, 1.0vw, 14px);
        opacity: 0.8;
        opacity: 0.5;
    }
    
/* ... dans le bloc @media (max-width: 768px) ... */

    /* Conteneur des barres (le bouton entier) */
    .menu-toggler {
        /* Nous allons utiliser flex pour empiler les barres */
        position: relative;
        display: flex; 
        flex-direction: column;
        justify-content: space-around;
        height: 25px; /* Définissez une hauteur pour l'empilement */
        width: 30px; /* Définissez une largeur pour le bouton */
        padding: 0;
        margin: 0;
        
        /* Enlevez l'ancienne font-size si elle existe, car nous utilisons maintenant des barres */
        font-size: initial; 
        z-index: 1600;
    }

    /* Style commun pour chaque barre */
    .menu-toggler .bar {
        display: block;
        width: 100%;
        height: 3px; /* Épaisseur de la barre */
        background-color: black; /* Couleur de votre bouton */
        transition: all 0.3s ease-in-out; /* Animation pour la transformation */
        transform-origin: center; /* Point de rotation */
        z-index: 1600;

    }

    /* Style de la transformation en croix (lorsque le menu est ouvert) */
    /* Cible l'état lorsque la classe 'open' est appliquée au corps (si vous l'utilisez) 
       OU plus simple, cible l'état lorsque la classe 'open' est appliquée au menu lui-même 
       et utilise l'opérateur adjacent ( + ) */

    /* Si vous utilisez le code JS de la section 1 et que .main-nav-mobile.open est la classe d'ouverture : */
    .main-nav-mobile.open + .menu-toggler .top-bar, /* Si le toggler est après le nav */
    .main-nav-mobile.open ~ .menu-toggler .top-bar, /* Si le toggler n'est pas directement après le nav */
    .main-nav-mobile.open + .menu-toggler .middle-bar,
    .main-nav-mobile.open + .menu-toggler .bottom-bar {
        /* Si le toggler est DANS le header et n'est pas juste après le nav, vous devez 
           adapter ce sélecteur pour cibler .menu-toggler.open .bar si votre JS ajoute 'open' au toggler.
           
           Puisque votre JS ajoute 'open' au .main-nav-mobile, 
           nous allons nous baser sur le body pour un ciblage universel.
        */
        
    }

    /* 🏆 SOLUTION LA PLUS PROPRE : Ajouter la classe 'open' au Toggler en JS */

    /* 1. Mettez à jour votre fonction JS (toggleMenu) pour qu'elle ajoute 'open' au Toggler ET au Nav: */
    /*
    function toggleMenu() {
        document.querySelector('.main-nav-mobile').classList.toggle('open');
        document.querySelector('.menu-toggler').classList.toggle('open'); // 💥 AJOUTEZ CETTE LIGNE
    }
    */

    /* 2. Si le Toggler a la classe 'open' (il est maintenant une croix) */
    .menu-toggler.open .top-bar {
        /* Rotation en diagonale et déplacement */
        transform: rotate(45deg) translate(7px, 7px); 
    }

    .menu-toggler.open .middle-bar {
        /* Disparaît */
        opacity: 0;
    }

    .menu-toggler.open .bottom-bar {
        /* Rotation en diagonale opposée et déplacement */
        transform: rotate(-45deg) translate(5px, -5px);
    }
        
    /* 5. Menu de navigation Mobile (Fenêtre latérale) */
    .main-nav-mobile {
        position: fixed;
        /* top: 0; et left: 0; sont importants pour le positionnement */
        top: 0; 
        left: 0; /* Ancrage à gauche */
        
        /* 💥 MODIFICATION 1 : Cache le menu en le décalant au-dessus */
        top: -105%; 
        
        /* 💥 MODIFICATION 2 : Il prend toute la largeur */
        width: 100%; 
        
        /* 💥 MODIFICATION 3 : Il prend toute la hauteur pour couvrir l'écran */
        height: 100vh; /* Utiliser 100vh (viewport height) */
        
        background-color: rgba(255, 255, 255, 0.5);
        backdrop-filter: blur(5px);
        -webkit-backdrop-filter: blur(5px);
        
        /* 💥 MODIFICATION 4 : La transition porte maintenant sur 'top' */
        transition: top 0.6s ease-in-out; 
        
        z-index: 14990;
        padding-top: 0px;
        display: block; /* Important pour qu'il ne soit pas display: none */
    }

    /* Style pour l'ouverture du menu (Reste inchangé) */
    .main-nav-mobile.open {
        /* 💥 MODIFICATION 5 : Ancre le menu en haut de la fenêtre */
        top: 0; 
    }


   
    .main-nav-mobile .close-btn {
        /* 🔑 CLÉ 1 : Positionne la croix par rapport au coin de son parent (.main-nav-mobile) */
        position: absolute;
   
        /* 🔑 CLÉ 2 : Ancrage en haut à 10px du bord du menu */
        top: 10px;
   
        /* 🔑 CLÉ 3 : Ancrage à droite à 10px du bord du menu */
        right: 10px;
   
        /* SUPPRIMEZ TOUTES LES AUTRES PROPRIÉTÉS DE POSITIONNEMENT OU MARGES */
        margin-top: initial !important;
        margin-left: initial !important;
   
        /* Maintien des autres styles */
        color: #7d7d7d;
        font-size: 1.8em;
        text-decoration: none;
        z-index: 15000; /* Assurez-vous qu'il est cliquable */
    }
   
    /* Structure de la liste (les uns en dessous des autres) */
    .main-nav-mobile ul {
        list-style: none;
        padding: 0;
        margin: 0;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        padding-left: 20px;
        margin-top: 70px;
    }
 
    .main-nav-mobile li {
        margin: 15px 0;
        /* ⭐ MODIFICATION CLÉ 1 : Ajout de la bordure inférieure pour la séparation */
        
        padding-bottom: 35px; /* Pour ajouter de l'espace sous la ligne */
        /* On peut aussi enlever le margin-bottom pour utiliser le padding-bottom pour l'espace */
        margin: 15px 0 0 0; /* Garde la marge du haut, enlève celle du bas pour utiliser le padding */
    }

    /* ⭐ MODIFICATION CLÉ 2 : Retirer la bordure sur le dernier élément */
    /* C'est important pour éviter une ligne inutile sous le dernier lien "Contact" */
    .main-nav-mobile li:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }
 
    .main-nav-mobile a {
        color: black;
        text-decoration: none;
        font-size: 1.8em;
        /* Ajustement du padding pour que le texte soit bien au-dessus de la ligne */
        padding: 0 20px 0 0; /* Réduction du padding car l'espace est géré par le LI */
        display: block;
        transition: color 0.3s;
    }
    .main-nav-mobile a:hover {
        color: #ca0013;
    }

    /* 1. Logo principal */
    .logo-filou32 {
        /* Taille REDUITE */
        height: 180px; /* Taille recommandée pour qu'il tienne dans le header */
        width: auto;
        margin-left: -30px;
        margin-top: -200px;
        margin-bottom: 70px;
       
        z-index: 1560;
    }



    /* .titre_photo2 */
    .titre_photo2 {
        display: flex;
        color: #ca0013;
        font-size: 18px; /* Taille réduite pour mobile */
        margin-top: 122px; /* Marge réduite */
        width: 100%;
        justify-content: center;
        align-items: center; 
        text-align: center;
        margin-bottom: 20px;
    }

    /* style-mobile.css */
    :root {
        --primary-color: #ca0013; /* Ton rouge adrenaline */
        --text-dark: #1a1a1a;
        --text-light: #555;
    }

    body {
        margin: 0;
        padding: 0;
        font-family: 'Montserrat', sans-serif;
        background-color: #fff;
        overflow-x: hidden;
        color: var(--text-dark);
    }

    .page-container {
        display: none;
    }

    .page-container-tel {
        width: 100%;
        padding: 30px 20px;
        box-sizing: border-box;
    }

    /* --- STRUCTURE SECTION --- */
    .main-content-section {
        position: relative;
        padding-bottom: 20px;
        display: flex;
        flex-direction: column;
    }

    /* --- TEXTE DÉFILANT EN FOND --- */
    .background-text {
        position: absolute;
        top: -10px;
        left: 0;
        font-size: 22vw;
        font-weight: 900;
        color: var(--primary-color);
        opacity: 0.07;
        white-space: nowrap;
        z-index: -1;
        pointer-events: none;
        overflow: hidden;
    }

    .background-text span {
        display: inline-block;
        animation: scroll-mobile 60s linear infinite;
    }

    @keyframes scroll-mobile {
        0% { transform: translateX(0); }
        100% { transform: translateX(-50%); }
    }

    /* --- TITRE ET STATS --- */
    .name-title {
        font-size: 2rem;
        font-weight: 900;
        color: var(--primary-color);
        margin: 10px 0 20px 0;
        text-transform: uppercase;
        letter-spacing: -1px;
    }

    .stats-container {
        display: flex;
        gap: 25px;
        margin-bottom: 25px;
    }

    .stat-item {
        display: flex;
        flex-direction: column;
    }

    .stat-number {
        font-size: 1.4rem;
        font-weight: 800;
        color: var(--primary-color);
    }

    .stat-label {
        font-size: 0.7rem;
        text-transform: uppercase;
        font-weight: 600;
        color: #000;
    }

    /* --- GRILLE PHOTOS MOBILE --- */
    .photo-block-grid {
        display: flex;
        flex-direction: column;
        gap: 12px;
        margin-bottom: 25px;
    }

    .photo-block-grid img {
        width: 100%;
        height: 220px;
        object-fit: cover;
        border-radius: 8px;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    }

    /* Style asymétrique mobile : la 2eme photo est plus petite et décalée */
    .photo-block-grid img:nth-child(2) {
        width: 85%;
        height: 160px;
        align-self: flex-end;
    }

    /* --- TEXTES --- */
    .description-text {
        font-size: 1rem;
        line-height: 1.6;
        margin-bottom: 20px;
        font-weight: 400;
    }

    .secondary-text {
        font-size: 0.85rem;
        color: var(--text-light);
        line-height: 1.5;
        background-color: #f9f9f9;
        padding: 15px;
        border-radius: 6px;
        border-left: 4px solid var(--primary-color);
    }

    /* --- DIVISEUR --- */
    .section-divider {
        width: 100%;
        height: 1px;
        background-color: #eee;
        margin: 50px 0;
        position: relative;
    }

    .section-divider::after {
        content: '';
        position: absolute;
        left: 0;
        top: 0;
        width: 40px;
        height: 1px;
        background-color: var(--primary-color);
    }




 









    footer {
        padding: 20px;
        width: 100%;
        box-sizing: border-box;
    }

    .main-nav ul {
        flex-direction: column; 
        align-items: center;
        gap: 10px;
        width: 100%;
    }
    
    .main-nav li {
        text-align: center;
        width: 100%;
    }
    
    .main-nav a, .main-nav span {
        font-size: 0.85em;
        color: #144b63; 
        white-space: normal; /* Permet aux liens longs de se couper si nécessaire */
    }



    .cookie-banner {
        position: fixed;
        bottom: 20px;
        left: 50%;
        transform: translateX(-50%);
        background: #E8E8E8;
        color: #333; /* Changé en sombre car le fond est gris très clair (#E8E8E8) */
        padding: 20px;
        border-radius: 10px;
        z-index: 1000;
        display: none; 
        box-shadow: 0 4px 20px rgba(0,0,0,0.3);
        
        /* --- AJUSTEMENT DES MARGES --- */
        width: calc(100% - 100px); /* 100% moins 50px de chaque côté */
        max-width: none; /* On retire le max-width pour forcer le respect des 50px sur grand écran */
        /* Si vous voulez quand même une limite sur très grand écran, gardez un max-width élevé */
        
        text-align: center;
    }


    h6 {
        font-size: 18px;
        font-weight: normal;
    }

    .cookie-buttons { margin-top: 15px; display: flex; gap: 10px; justify-content: center; }

    .btn-accept { background: transparent; border: 1px solid orange; color: orange; padding: 10px 20px; cursor: pointer; border-radius: 5px; }
    .btn-refuse { background: transparent; border: 1px solid orange; color: orange; padding: 10px 20px; cursor: pointer; border-radius: 5px; }



    .map-placeholder {
        width: 100%; height: 100%;
        background: #f0f0f0;
        display: flex; align-items: center; justify-content: center;
        text-align: center; padding: 20px;
    }

        /* Style pour le bouton En savoir plus */
    .btn-info {
        font-size: 0.85em;
        color: #144b63; /* Couleur de votre charte */
        text-decoration: none;
        align-self: center; /* Pour bien l'aligner si vous utilisez flex */
        padding: 10px;
        transition: opacity 0.3s;
    }

    .btn-info:hover {
        opacity: 0.7;
        
    }



        /*DEBUT FOOTER----------------------------------------------------------------------------------------------------------------------------------------------------------------------------DEBUT FOOTER*/
    /* --- DEBUT FOOTER ADAPTATIF --- */

    footer {
        width: 100%;
        padding: 20px 10px; /* Un peu moins de padding sur mobile */
        background-color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        position: relative;
        z-index: 999;
    }

    .main-nav {
        width: 100%;
        max-width: 1200px;
    }

    .main-nav ul {
        display: flex;
        flex-direction: column; /* On empile les éléments verticalement sur mobile */
        gap: 15px; /* Espace entre le copyright, les logos et les mentions */
        align-items: center;
        list-style: none;
        padding: 0;
        margin: 0;
    }

    /* Style pour le groupe de réseaux sociaux */
    .footer-socials {
        display: flex;
        gap: 20px; /* Espace entre les icônes elles-mêmes */
        justify-content: center;
    }

    .footer-socials a {
        font-size: 1.4em; /* Taille des logos sur mobile */
        color: #000000;
        display: inline-block;
    }

    .main-nav a,
    .main-nav span {
        text-decoration: none;
        color: #000000;
        font-size: 0.85em; /* Texte légèrement plus petit pour mobile */
        text-align: center;
    }


    
}