/* --- 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;
    }




    /* --- Styles du Formulaire de Contact --- */

    .form-page-container {
        padding: 50px 0; /* Espace vertical autour du formulaire */
        background-color: var(--light-grey); /* Couleur de fond pour le formulaire */
        /* Ces propriétés assurent que le formulaire est centré horizontalement */
        display: flex;
        justify-content: center; /* CENTRE LE CONTENU HORIZONTALEMENT */
        width: 100%;
        margin-top: 0px;
    }

    /* REMARQUE : J'ai renommé la classe .container en .container-form dans le code ci-dessous
       pour éviter les conflits avec vos styles existants, comme discuté précédemment. */
    .container-form {
        display: flex;
        max-width: 1100px; /* Largeur maximale du formulaire */
        width: 90%; /* Prend 90% de la largeur du .form-page-container (donc centré) */
        background-color: var(--background-color);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
        border-radius: 8px;
        overflow: hidden;
    }

    /* Partie gauche (Menu) */
    .left-side-form {
        flex: 1; /* Prend une part de l'espace, ajustez si nécessaire */
        padding: 50px;
        background-color: var(--background-color); /* Couleur de fond pour cette colonne */
        text-align: left;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: flex-start;
    }

    .logo-placeholder {
        /* Styles pour l'image/logo */
        width: 60px;
        height: 60px;
        margin-bottom: 20px;
        /* Remplacer cette image SVG par votre logo réel si besoin */
    }


    .left-side-form h1 {
        
        font-size: 3em;
        font-weight: bold;
        color: #666666;
        margin-top: 0;
        margin-bottom: 20px;
        letter-spacing: 1px;

    }

    .left-side-form p {
        margin-bottom: 10px;
        line-height: 1.5;
    }

    .reservation-section {
        margin-top: 40px;
        padding-top: 20px;
        border-top: 1px solid lightgrey; /* Séparateur léger */
    }

    .reserve-button {
        background-color: var(--primary-color);
        color: white;
        border: none;
        padding: 10px 25px;
        font-size: 1em;
        font-weight: bold;
        text-transform: uppercase;
        cursor: pointer;
        border-radius: 4px;
        margin-top: 15px;
        display: flex;
        align-items: center;
        transition: background-color 0.3s;
    }

    .reserve-button:hover {
        background-color: #d14a7e; /* Teinte plus foncée au survol */
    }

    .reserve-button i {
        margin-right: 10px;
        font-size: 1.2em;
    }

    /* Partie droite (Formulaire) */
    .right-side-form {
        flex: 2; /* Prend plus d'espace, ajustez si nécessaire */
        padding: 50px;
        background-color: var(--background-color);
        border-left: 1px solid var(--border-color); /* Séparateur visuel */
    }

    .contact-form {
        display: flex;
        flex-direction: column;
    }

    .form-group, .form-group-inline {
        margin-bottom: 20px;
    }

    /* Style des champs en ligne (Nom/Prénom, E-mail/Téléphone) */
    .form-group-inline {
        display: flex;
        gap: 20px;
    }

    .input-container {
        flex: 1;
        display: flex;
        flex-direction: column;
    }

    label {
        font-weight: bold;
        margin-bottom: 5px;
        display: block;
        font-size: 0.9em;
        color: #666666;
    }

    input[type="text"],
    input[type="email"],
    input[type="tel"],
    textarea {
        width: 100%;
        padding: 10px;
        border: 1px solid lightgrey;
        border-radius: 4px;
        box-sizing: border-box; /* Assure que le padding n'augmente pas la largeur totale */
    }

    textarea {
        resize: vertical; /* Permet uniquement le redimensionnement vertical */
    }

    /* Change la couleur du contour quand on clique dans le champ */
    input:focus, 
    textarea:focus {
        outline: none; /* Enlève le contour orange par défaut */
        border: 1px solid #ca0013; /* Ajoute une bordure rouge à la place */
        box-shadow: 0 0 5px rgba(202, 0, 19, 0.2); /* Optionnel : ajoute une légère lueur rouge */
    }

    .required {
        color: red;
    }

    /* Styles pour les cases à cocher */
    .checkbox-group {
        display: flex;
        flex-direction: column;
        margin-top: 10px;
    }

    .checkbox-group label {
        font-weight: normal;
        margin-bottom: 5px;
        display: flex;
        align-items: center;
    }

    .privacy-check label {
        font-weight: normal;
        display: flex;
        align-items: center;
        font-size: 0.9em;
    }

    .privacy-check label {
        /* Ajout de cette ligne pour empêcher le saut de ligne à l'intérieur du label */
        white-space: nowrap;
        /* Assurez-vous que l'affichage est au moins inline-block pour bien contenir le contenu */
        display: inline-block;
    }

    /* Votre CSS existant pour le lien (optionnel, mais bon pour la propreté) */
    .privacy-link {
        color: #ca0013;
        text-decoration: none;
        border-bottom: 1px dashed var(--primary-color);
    }

    .privacy-link:hover {
        border-bottom: 1px solid var(--primary-color);
    }

    /* Bouton d'envoi */
    .submit-button {
        background-color: #eeebe3;
        color: white;
        border: none;
        padding: 15px 30px;
        font-size: 1.2em;
        font-weight: bold;
        text-transform: uppercase;
        cursor: pointer;
        border-radius: 4px;
        margin-top: 20px;
        transition: background-color 0.3s;
    }

    .submit-button:hover {
        background-color: #ca0013;
    }



    p {
        color: #ca0013;
        font-size: 16px;
        text-align: center;
    }

    p2 {
        color: #666666;
        font-size: 16px;

        margin-left: auto;
        margin-right: auto;
       
        /* Maintien du centrage du texte à l'intérieur du bloc */
        text-align: center;
    }

    h1 {
        color: #666666;
    }

        /* Style pour l'ensemble du texte informative */
    .rgpd-info {
        font-size: 0.85em;      /* Texte un peu plus petit pour la discrétion */
        color: #666666;         /* Gris foncé (change la couleur ici) */
        line-height: 1.4;       /* Espace entre les lignes pour la lisibilité */
        display: block;         /* Pour que les marges s'appliquent bien */
        margin-top: 10px;
        font-weight: normal;
    }

    /* Style spécifique pour le lien "Mentions légales" à l'intérieur */
    .rgpd-info a {
        text-decoration: none;  /* ENLÈVE LE SOULIGNAGE */
        color: #ca0013;         /* Ta couleur rouge (ou #144b63 pour le bleu) */
        font-weight: normal;      /* Met le lien en gras pour qu'on le voie quand même */
    }

    /* Optionnel : Remettre le soulignage seulement au survol de la souris */
    .rgpd-info a:hover {
        text-decoration: underline;
        opacity: 0.8;
    }

    /* --- Nouveau Design interne "Avis Google" --- */
    .google-reviews-wrapper {
        text-align: center;
        width: 100%;
    }

    .google-logo-img {
        width: 100px;
        margin-bottom: 10px;
    }

    /* Couleur de base pour toutes les étoiles (Or Google) */
    .google-stars {
        color: #f1c40f;
        font-size: 28px;
        margin-bottom: 5px;
        display: inline-block;
    }

    /* Style spécifique pour l'étoile à moitié remplie */
    .star-half {
        position: relative;
        display: inline-block;
        color: #dadce0; /* Couleur du fond de l'étoile (Gris clair) */
    }

    .star-half::before {
        content: "★";
        position: absolute;
        left: 0;
        top: 0;
        width: 50%; /* Remplit exactement la moitié */
        overflow: hidden;
        color: #f1c40f; /* Couleur de remplissage (Or) */
    }

    .google-rating-text {
        color: #666 !important;
        font-size: 0.9em;
        font-weight: bold;
        text-align: center !important; /* Force le centrage par rapport à ton p global */
    }

    .google-body h3 {
        font-size: 1.5em;
        color: #1a1a1a;
        margin-top: 30px;
        margin-bottom: 15px;
    }

    .google-body p {
        color: #666 !important;
        font-size: 1em;
        line-height: 1.5;
        margin-bottom: 30px !important;
        text-align: center !important;
    }

    /* Bouton moderne */
    .google-cta-button {
        display: inline-flex;
        align-items: center;
        gap: 12px;
        background-color: white;
        color: #3c4043;
        text-decoration: none;
        padding: 15px 25px;
        border-radius: 4px; /* Gardé carré pour aller avec ton design original */
        font-weight: bold;
        font-size: 0.9em;
        border: 1px solid #dadce0;
        box-shadow: 0 2px 4px rgba(0,0,0,0.05);
        transition: all 0.3s ease;
    }

    .google-cta-button:hover {
        background-color: #f8f9fa;
        border-color: #ca0013;
        color: #ca0013;
        transform: translateY(-2px);
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    }

    .google-footer-info {
        margin-top: 20px;
        font-size: 0.8em;
        color: #aaa;
        font-style: italic;
    }

    /* Tes balises p et p2 originales */

    p2 { color: #666666; font-size: 16px; display: block; text-align: center; }











    .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 - 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;
    }


    /* 1. RESET DE SÉCURITÉ */
    * {
        box-sizing: border-box !important;
        text-decoration: none !important; /* Enlève tout soulignement par défaut */
    }

    :root {
        --primary-color: #ca0013;
        --background-color: #ffffff;
        --light-grey: #eeebe3;
        --border-color: lightgrey;
    }

    /* 2. CONTENEUR PRINCIPAL */
    .form-page-container {
        padding: 20px 10px;
        background-color: #fff;
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 100%;
        margin-bottom: 50px;
    }

    .container-form {
        display: flex;
        flex-direction: column; /* GAUCHE en haut, DROITE en bas */
        width: 100%;
        max-width: 100%;
        background-color: var(--background-color);
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
        border-radius: 8px;
        overflow: hidden;
    }

    /* 3. PARTIE GAUCHE (INFOS DU HAUT) */
    .left-side-form {
        width: 100% !important;
        padding: 30px 15px;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .left-side-form h1 {
        font-size: 1.8rem; /* Taille réduite pour ne pas déborder */
        font-weight: bold;
        color: #666666;
        margin: 0 0 15px 0;
        word-wrap: break-word;
    }

    .left-side-form p {
        color: #ca0013;
        line-height: 1.4;
        margin-bottom: 10px;
        text-align: center;
    }

    .reservation-section {
        width: 100%;
        margin-top: 20px;
        padding-top: 20px;
        border-top: 1px solid var(--border-color);
    }

    .reserve-button {
        width: 100%;
        background-color: var(--primary-color);
        color: white;
        padding: 15px;
        font-weight: bold;
        text-transform: uppercase;
        border-radius: 4px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /* 4. PARTIE DROITE (FORMULAIRE DU BAS) */
    .right-side-form {
        width: 100% !important;
        padding: 30px 15px;
        border-top: 1px solid var(--border-color);
        border-left: none !important;
    }

    .form-group-inline {
        display: flex;
        flex-direction: column !important; /* Force l'un sous l'autre */
        gap: 0;
    }

    .input-container {
        width: 100% !important;
        margin-bottom: 15px;
    }

    label {
        font-weight: normal;
        font-size: 0.9em;
        color: #666666;
        margin-bottom: 5px;
    }

    input[type="text"],
    input[type="email"],
    input[type="tel"],
    textarea {
        width: 100% !important;
        padding: 12px;
        border: 1px solid lightgrey;
        border-radius: 4px;
        font-size: 16px; /* Évite le zoom auto sur smartphone */
    }

    /* 5. TEXTES RGPD ET LIENS (SÉCURITÉ DÉBORDEMENT) */
    .privacy-check label {
        display: flex !important;
        align-items: flex-start;
        white-space: normal !important; /* Autorise le retour à la ligne */
        text-align: left;
        font-size: 0.85em;
        gap: 10px;
        width: 100%;
    }

    .rgpd-info {
        font-size: 0.8em;
        color: #666666;
        line-height: 1.4;
        display: block;
        margin-top: 15px;
        word-wrap: break-word;
    }

    .rgpd-info a, .privacy-link {
        color: #ca0013;
        text-decoration: none !important;
    }

    /* 6. BOUTON ENVOI */
    .submit-button {
        width: 100%;
        background-color: #ca0013;
        color: white;
        padding: 16px;
        font-size: 1.1em;
        font-weight: bold;
        border: none;
        border-radius: 4px;
        margin-top: 10px;
    }

    /* 7. AVIS GOOGLE */
    .google-reviews-wrapper {
        text-align: center;
        width: 100%;
        margin-top: 30px;
    }

    /* 1. Taille globale et couleur de base (Or) pour les étoiles entières */
    .google-stars {
        color: #f1c40f; /* Or Google */
        font-size: 22px; /* TAILLE RÉDUITE POUR MOBILE */
        margin-bottom: 5px;
        display: inline-block;
    }

    /* 2. Style spécifique pour l'étoile à moitié remplie */
    .star-half {
        position: relative;
        display: inline-block;
        color: #dadce0 !important; /* Couleur du fond de l'étoile (Gris clair) - Force l'override */
    }

    /* 3. Le pseudo-élément qui crée le remplissage à 50% (Or) */
    .star-half::before {
        content: "★";
        position: absolute;
        left: 0;
        top: 0;
        width: 50%; /* Remplit exactement la moitié */
        overflow: hidden;
        color: #f1c40f !important; /* Couleur de remplissage (Or) - Force l'override */
    }

    .google-cta-button {
        width: 100%;
        display: flex;
        justify-content: center;
        background: white;
        border: 1px solid #dadce0;
        padding: 12px;
        color: #3c4043;
        font-weight: bold;
    }

    /* Éléments divers */
    .logo-placeholder, .google-logo-img {
        max-width: 100%;
        height: auto;
        margin: 0 auto 15px auto;
    }

    p2 {
        color: #666666;
        display: block;
        text-align: center;
        width: 100%;
    }

    p {
        color: black;
        opacity: 0.7;
    }

    .google-footer-info {
        color: black;
        opacity: 0.5;
    }








    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;
    }


    
}