/* --- 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) {


    /* Style de la vidéo en haut de page */
    /* CORRECTION : Retrait de 'fixed' pour que la vidéo ne couvre que la première section et non tout l'écran en permanence */
    .video-background {
        position: relative; /* Changé de 'fixed' à 'relative' */
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh; /* La vidéo prend 100% de la hauteur de la fenêtre */
        overflow: hidden;
        z-index: -2;
    }

    .video-background video {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .photo-accueil {
        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;
    }


/* debut 7 sections--------------------------------------------------------------------------------------------------------------------------- debut 7 sections*/

    /* .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;
    }

     /* Nouveau style pour les conteneurs de lignes */
    .content-row2 {
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        margin-bottom: 0px;
        gap: 20px;
        flex-wrap: wrap;
        max-width: 1200px; /* Ajout d'une largeur maximale pour les cartes */
        margin: 40px auto; /* Centre les cartes */

    }

    .content-row2.first-row2 {
        /* Le décalage vers le haut de 200px n'est plus nécessaire car le header n'est plus fixe */
        margin-top: 0px; /* Ajustement de la marge supérieure après le changement de header */
        /* DÉFINIT LA MARGE DE 40PX ENTRE LA PREMIÈRE ET LA DEUXIÈME LIGNE DE CARTES */
        margin-bottom: 0px;
    }

    /* NOUVELLE RÈGLE : pour la dernière ligne de cartes, écrase la marge inférieure de 40px */
    .content-row2.last-row2 {
        /* Ancienne valeur : margin-bottom: 250px; */
        margin-bottom: 20px; /* Espace de base entre les cartes et la vidéo */
    }

    .content-section2 {
        display: flex;
        flex-direction: column;
        align-items: center;
        padding: 30px;
        flex: 1 1 200px;
        background-color: #eeebe3;
        border-radius: 8px;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        text-align: center;
        height: 320px;

        opacity: 0;
        filter: blur(15px); /* Flou un peu plus prononcé au départ */
        transform: scale(0.9) translateY(20px); /* Ajout d'un léger effet de dézoom */
        transition: 
            opacity 0.6s ease-in-out, 
            filter 0.6s ease-in-out, 
            transform 0.6s ease-in-out;
        will-change: filter, opacity; /* Optimise les performances du flou *//
    }

    /* État quand la carte est visible */
    .content-section2.is-visible {
        opacity: 1;
        filter: blur(0);
        transform: scale(1) translateY(0);
    }



    .content-text {
        padding: 0;
        margin-bottom: 20px;
    }

    .content-text h2 {
        color: black;
        margin-top: 0;
    }

    .content-image {
        width: 100%;
    }

    .content-image img {
        max-width: 100%;
        height: auto;
        border-radius: 8px;
    }

    /* Boutons CTA */
    .cta-button {
        display: inline-block;
        padding: 10px 20px;
        margin-top: 20px;
        background-color: #5cb85c;
        color: #fff;
        text-decoration: none;
        border-radius: 5px;
        font-weight: bold;
        transition: background-color 0.3s ease;
    }

    .cta-button:hover {
        background-color: #4cae4c;
    }

    /* Styles pour les logos des 7 conteneurs d'informations */
    .logo_cible_rose, .logo_coupe_rose, .logo_verre_rose, .logo_gun_rose, .logo_horloge_rose, .logo_terrains_rose, .logo_mains_rose {
        width: 120px;
    }

    p {
        color: black;
    }


/* fin 7 sections--------------------------------------------------------------------------------------------------------------------------- fin 7 sections*/


    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) {
    
    /* --- 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;
    }



/* debut 7 sections-------------------------------------------------------------------------------------------------------------------------------------------------------  debut 7 sections*/

    /* .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;
    }

   
/* 1. Le conteneur parent avec une marge de sécurité de chaque côté */
    .content-row2 {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important; /* 2 colonnes égales */
        gap: 12px !important; /* Espace entre les cartes */
        padding: 0 15px !important; /* Marge de 15px par rapport aux bords de l'écran */
        width: 100% !important;
        box-sizing: border-box !important; /* Très important pour inclure le padding dans le calcul */
        margin: 20px 0 !important;
    }

    /* 2. Les sections individuelles */
    .content-section2 {
        width: 100% !important;
        box-sizing: border-box !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        padding: 20px 10px !important;
        height: auto !important;
        min-height: 240px !important; /* Ajuste selon la longueur de ton texte */
        background-color: #eeebe3 !important;
        border-radius: 8px !important;
        opacity: 0;
        filter: blur(15px); /* Flou un peu plus prononcé au départ */
        transform: scale(0.9) translateY(20px); /* Ajout d'un léger effet de dézoom */
        transition: 
            opacity 0.6s ease-in-out, 
            filter 0.6s ease-in-out, 
            transform 0.6s ease-in-out;
        will-change: filter, opacity; /* Optimise les performances du flou */
    }

    .content-section2.is-visible {
        opacity: 1;
        filter: blur(0);
        transform: scale(1) translateY(0);
    }

    /* 3. Le Texte (Visibilité maximale) */
    .content-text {
        display: block !important;
        width: 100% !important;
    }

    .content-text h2 {
        display: block !important;
        color: #000000 !important; /* Noir pur */
        font-size: 1rem !important;
        margin: 10px 0 !important;
        line-height: 1.2 !important;
    }

    .content-text p {
        display: block !important;
        color: #333333 !important; /* Gris très foncé */
        font-size: 0.85rem !important;
        line-height: 1.4 !important;
        margin: 0 !important;
        padding: 0 5px !important;
    }

    /* 4. Les Images / Logos */
    .content-image, [class^="logo_"] {
        display: block !important;
        width: 60px !important;
        height: auto !important;
        margin: 0 auto 10px auto !important;
    }

    /* 5. La dernière section en bas */
    .content-row2.last-row2 .content-section2:last-child {
        grid-column: span 2 !important;
        width: 100% !important;
    }


    /* --- STYLES COMMUNS ET ÉTAT INITIAL (ANIMATIONS) --- */
    .terrains-section {
        background-color: var(--beige);
        position: relative;
        width: 100%;
        display: flex;
        align-items: center;
        overflow: hidden;
    }

    /* Le bandeau photo passe en fond ou en haut */
    .full-height-banner {
        position: relative;
        width: 100%;
        height: 250px; /* Taille réduite pour mobile */
        order: -1; /* Place la photo tout en haut */
        transform: translateY(20px); /* Ajustement pour l'animation */
    }

    .main-container {
        grid-template-columns: 1fr; /* Une seule colonne */
        padding: 20px;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    /* Préparation de l'effet d'apparition (flou + mouvement) */
    .massive-title, .img-map-natural, .cta-box, .full-height-banner {
        opacity: 0;
        filter: blur(12px);
        transition: all 0.8s ease-out;
        color: black;
    }

    .desc-box {
        width: 100%;
        text-align: center;
        margin-top: 20px;
    }

    .line-red.s, .line-red.f {
        width: 40%;
        margin: 15px auto; /* Centre les lignes rouges */
    }

    .txt-right {
        text-align: center;
    }

    /* La Map */
    .col-interactive {
        right: 0;
        margin-top: 40px;
        width: 100%;
    }

    .img-map-natural {
        width: 90%; /* Prend presque toute la largeur */
        margin: 0 auto 20px auto;
    }

    /* Le bloc bouton et liste */
    .cta-box {
        width: 100%;
        margin-right: 0; /* On annule le gros décalage PC */
        margin-top: 20px;
        align-items: center; /* Centre tout sur mobile */
        text-align: center;
    }

    .btn-venez {
        font-size: 2.2rem;
        text-align: center;
    }

    .list-container {
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .list-container li {
        width: 200px; /* Plus petit sur mobile */
        text-align: center;
    }

    .total-terrains {
        margin-top: 40px;
        text-align: center;
    }

/* fin 7 sections------------------------------------------------------------------------------------------------------------------------------------------------------- fin 7 sections*/
    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;
    }

}