body {
    font-family: 'Inter', sans-serif;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    background: white;
    max-width: 100vw;
    min-height: 100vh;

}

html {
    scroll-behavior: smooth;
  }

.hide {
    display: none;
  }

.non-style{
    text-decoration: none;
}

header .pdp, h1  .pdp, div .pdp{
    border-radius: 50%;
    height: 5vh;
    width: auto;
    margin-right: 1vw;
}

/* Custom Colors */
.bg-custom-grey {
    background-color: #D9D9D9;
}

.justifier{
text-align: justify;
}

.espace-gauche {
    margin-left: 0.6vw;
}

.bg-custom-button {
    background-color: #A1894B;
    color: black;
    border: none;
    border-radius: 0;
    font-family: 'Times New Roman', serif;
    font-weight: 400;
}

.bg-custom-yellow {
    background-color: #D5C596;
}

.text-custom-yellow {
    color: #A1894B;
}


header {
    width: 100%;
    min-height: 80px;
    background: #D5C596;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 0 20px;
}


.header-logo {
    position: absolute;
    left: 30px;
    top: -50px;
    z-index: 10;
}

.navbar-nav .nav-link {
    color: black !important;
    font-size: 24px;
    font-family: 'Times New Roman', serif;
    font-weight: 400;
    text-decoration: none;
    margin-right: 40px;
}

.navbar-nav .nav-link.active {
    text-decoration: underline;
}

.social-icon-header {
    width: 42px;
    height: 42px;
    transform: rotate(180deg);
    margin-left: 10px;
}

main {
    padding-top: 0;
}

.section-border {
    border: 1px black solid;
}


h1, h2, h3 {
    font-family: 'Grenze Gotisch', cursive;
    color: black;
}


.section-intro .display-4 {
    font-size: 32px;
}

.section-intro .lead {
    font-family: 'Grenze Gotisch', cursive;
    font-size: 32px;
    line-height: 35px;
}

.image-placeholder {
    background: #D9D9D9;
    border: 1px black solid;
}

/* Testimonial Section */
.testimonial-block {
    background: #D9D9D9;
    border: 1px solid #ccc; 
    padding: 20px;
    height: 224px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.testimonial-block p {
    font-size: 24px;
    font-family: 'Times New Roman', serif;
    font-weight: 400;
    text-align: center;
    line-height: 28px;
    color: black;
}
.tdesc{
    text-align: justify;
}

/* Circles and Rotated Lines Section */
.circle-placeholder {
    background: #A7A7A7;
    border: 1px #000 solid;
}

.rotated-line-90deg {
    width: 1px;
    height: 200px;
    background-color: black;
    transform: rotate(90deg);
    margin: 0 50px;
}
/* --- HERO BANNER FIXES --- */
.hero-banner-section {
    position: relative;
    overflow: hidden;
min-width: 100vw;
max-width: 100vw;
    border-bottom: 2%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.hero-banner-section img.background-image {
    position: absolute;
    top: 0;
    left: 0;
    min-width: 100vw;
    max-width: 100vw;
    object-fit: cover;
    z-index: 1;
}


/* Footer */
footer {
    background: #D5C596;
    color: black;
    bottom: 0%;
}

footer h5 {
    font-family: 'Times New Roman', serif;
    font-size: 24px;
    font-weight: 400;
}

footer ul {
    padding: 0;
}

footer ul li a {
    color: black;
    text-decoration: none;
    font-size: 18px;
}

    .inscription-page {
        background-color: white;
    }

    .form-control-custom {
        background-color: #E5D6AC;
        border: 3px solid #A1894B;
        border-radius: 0;
        height: 68px;
        font-family: 'Inter', sans-serif;
        font-size: 1.25rem;
        color: black;
        padding: 0.375rem 0.75rem;
    }

    .form-control-custom::placeholder {
        color: #6c757d;
        opacity: 0.7;
    }

    .form-control-custom:focus {
        border-color: #8c733f;
        box-shadow: 0 0 0 0.25rem rgba(161, 137, 75, 0.25);
        background-color: #E5D6AC;
    }

    /* Specific height for textarea */
    textarea.form-control-custom {
        height: auto;
        min-height: 200px;
    }
.imgpicto{
    width: 60px;
}
.bg-custom-button {
    background-color: transparent;
    color: #A1894B;
    border: 3px solid #A1894B;
    border-radius: 20px;
    font-family: 'Times New Roman', serif;
    font-weight: 400;
    transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;

    padding: 15px 35px;
    font-size: 1.25rem;
    line-height: 1.5;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.bg-custom-button:hover {
    background-color: #A1894B;
    color: black;
    border-color: #A1894B;
}


    .bg-custom-button:hover {
        background-color: #8c733f;
        color: white;
    }

/* --- Styles pour la page Contact --- */
.contact-page-wrapper {
    position: relative;
    min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

.contact-container {
    position: relative;
    z-index: 10;
    max-width: 868px;
    width: 90%;
    margin: 60px auto;
    padding: 40px;
    background-color: #D9D9D9;
    border: 1px solid black;
    box-shadow: 5px 5px 0px rgba(0, 0, 0, 0.2);
    text-align: center;
    box-sizing: border-box;
}

.contact-container h1 {
    font-family: 'Grenze Gotisch', cursive;
    color: black;
    margin-bottom: 40px;
    font-size: clamp(2rem, 5vw, 3.5rem);
    line-height: 1.2;
}

.contact-container form {
    display: flex;
    flex-direction: column;
    gap: 25px;
    align-items: center;
}

/* Styles pour les labels */
.form-label-contact {
    display: block;
    align-self: flex-start;
    width: 100%;
    text-align: left;
    color: black;
    font-size: 24px;
    font-family: 'Inter', sans-serif;
    font-weight: 400;
    margin-bottom: -15px;
    margin-left: 5px;
}

/* Styles spécifiques pour les inputs et textarea */
.contact-container input[type="text"],
.contact-container input[type="email"],
.contact-container input[type="password"],
.contact-container textarea {
    width: 100%;
    max-width: 868px;
    box-sizing: border-box;
    background-color: #E5D6AC;
    border: 3px solid #A1894B;
    border-radius: 0;
    height: 78px;
    font-family: 'Inter', sans-serif;
    font-size: 1.25rem;
    color: black;
    padding: 0.375rem 0.75rem;
}

/* Styles spécifiques pour les inputs et textarea */
.form-control-custom {
    background-color: #E5D6AC;
    border: 3px solid #A1894B;
    border-radius: 0;
    height: 68px;
    font-family: 'Inter', sans-serif;
    color: black;
     padding: 0.375rem 0.75rem;
    font-size: 1.25rem;
}

textarea.form-control-custom {
    height: 310px; 
    min-height: 200px;
    resize: vertical;
}


.contact-submit-button {
    width: 338px;
    height: 78px;
    padding: 0;
    font-size: 24px;
    font-family: 'Times New Roman', serif;
    font-weight: 400;
    line-height: 78px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* --- Styles pour les images décoratives de Figma --- */
.contact-decor-images img {
    position: absolute;
    opacity: 0.90;
    z-index: 1;
    display: none;
}

/* Spécifiques à chaque image pour leur positionnement */
.img-rotated-corner {
    top: 0;
    left: 0;
    transform: rotate(-90deg) translateX(-100%);
    transform-origin: top left;
    width: clamp(800px, 100vw, 1942.18px);
    height: auto;
    max-width: none;
    display: block;
}

.img-side-top {
    top: 0;
    right: 0;
    width: clamp(400px, 50vw, 1134px);
    height: auto;
    display: block;
}

.img-side-bottom {
    bottom: 0;
    right: 0;
    width: clamp(600px, 60vw, 1645px);
    height: auto;
    display: block;
}

.img-bottom-banner {
    bottom: 0;
    left: 0;
    width: clamp(800px, 100vw, 1920px);
    height: auto;
    display: block;
}

.fond_contact {
    background-color: #c5b689;
}

.profile-container {
    max-width: 800px;
    margin: 60px auto;
    padding: 30px;
    background-color: #D9D9D9;
    border: 3px solid #A1894B;
    box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2);
    position: relative;
}

.profile-container h1 {
    text-align: center;
    color: black; /* S'assure que le titre est bien noir */
    margin-bottom: 40px; /* Plus d'espace sous le titre principal */
    font-size: clamp(2rem, 5vw, 3.5rem); /* Taille de police responsive pour le titre H1 */
}

.profile-container h2 {
    font-family: 'Times New Roman', serif; /* Utilise la police de tes liens de nav */
    font-size: clamp(1.2rem, 2.5vw, 1.8rem); /* Taille de police responsive pour les H2 */
    color: black;
    margin-bottom: 20px; /* Espace entre chaque information */
    padding-left: 20px; /* Indentation pour la liste des infos */
    border-left: 5px solid #A1894B; /* Petite barre décorative à gauche */
    line-height: 1.4;
}

/* Rendre le texte des informations utilisateur un peu plus visible */
.profile-container h2 span {
    font-weight: 700; /* Met en gras la valeur de l'information (l'email, le nom, etc.) */
    color: #333; /* Une couleur un peu plus sombre pour la valeur */
}

.profile-container .pdp {
    width: 180px; /* Augmenté de 150px à 180px */
    height: 180px; /* Augmenté de 150px à 180px */
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid #A1894B;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
    margin: 0 auto 30px auto; /* Centrage horizontal via margin: auto */
    display: block; /* Nécessaire pour que margin: auto fonctionne pour le centrage horizontal */
}

.banner-top {
    background-image: url('https://placehold.co/1920x300/E5D6AC/E5D6AC'); /* Remplace par l'image de fond réelle */
    background-size: cover;
    background-position: center;
    position: relative;
    height: 300px; /* Ajuste la hauteur selon le Figma */
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden; /* Cache les débordements des éléments positionnés */
    margin-bottom: 2rem; /* Espace après la bannière */
}

.banner-top .banner-content {
    position: relative;
    text-align: center;
    color: black; /* Couleur du texte si tu en mets un */
    z-index: 2; /* Pour s'assurer que le contenu est au-dessus de l'image d'overlay */
}

.banner-top .banner-overlay-img {
    position: absolute;
    top: 50%; /* Centre verticalement */
    left: 50%; /* Centre horizontalement */
    transform: translate(-50%, -50%); /* Ajuste pour un centrage parfait */
    width: 250px; /* Ajuste la taille de l'image Sherlock Holmes */
    height: auto;
    opacity: 0.8; /* Ajuste l'opacité si elle est semi-transparente */
    z-index: 1; /* Derrière le texte si tu en as */
}

.banner-top .banner-title {
    font-family: 'Grenze Gotisch', cursive; /* Ou la police de ton titre */
    font-size: 3rem; /* Ajuste la taille du titre */
    color: black; /* Couleur du titre */
    position: relative;
    z-index: 3; /* Au-dessus de l'image d'overlay */
}


/* --- Styles pour les bannières intermédiaires (rubans) --- */
.info-banner {
    position: relative;
    width: 100%;
    top: 3rem; /* Espacement au-dessus de la bannière */
    margin-bottom: 3rem; /* Espacement en dessous de la bannière */
    height: 60px; /* Hauteur de la zone de la bannière */
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: transparent; /* Pas de fond direct sur la section */
}

.info-banner .banner-ribbon {
    background-color: #E5D6AC; /* Couleur de la bannière beige clair */
    color: black;
    font-family: 'Inter', sans-serif; /* Ou la police des titres des rubans */
    font-size: 1.5rem; /* Taille du texte du ruban */
    font-weight: bold;
    padding: 0.8rem 2.5rem; /* Padding interne */
    position: relative;
    z-index: 1; /* Au-dessus des pseudo-éléments */
    text-align: center;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* Ombre pour donner du relief */
    border: 2px solid #A1894B; /* Bordure foncée */
}

/* Pseudo-éléments pour les bords "pointus" du ruban */
.info-banner .banner-ribbon::before,
.info-banner .banner-ribbon::after {
    content: '';
    position: absolute;
    top: 0;
    width: 0;
    height: 0;
    border-top: 30px solid transparent; /* Moitié de la hauteur de .banner-ribbon */
    border-bottom: 30px solid transparent; /* Moitié de la hauteur de .banner-ribbon */
}

.info-banner .banner-ribbon::before {
    border-right: 20px solid #E5D6AC; /* Point à gauche, même couleur que le fond */
    left: -20px;
}

.info-banner .banner-ribbon::after {
    border-left: 20px solid #E5D6AC; /* Point à droite, même couleur que le fond */
    right: -20px;
}

/* Pour que les pseudo-éléments aient la même bordure foncée */
.info-banner .banner-ribbon::before {
    border-right-color: #A1894B; /* Pointe à gauche */
    border-right-width: 20px;
    border-right-style: solid;
    border-top-color: transparent;
    border-bottom-color: transparent;
    left: -20px;
    z-index: 0; /* Derrière le texte du ruban */
}

.info-banner .banner-ribbon::after {
    border-left-color: #A1894B; /* Pointe à droite */
    border-left-width: 20px;
    border-left-style: solid;
    border-top-color: transparent;
    border-bottom-color: transparent;
    right: -20px;
    z-index: 0; /* Derrière le texte du ruban */
}

/* Ajustement des bannières pour les fonds */
.info-banner {
    background-color: transparent; /* Le fond général de la section est transparent */
    padding: 0; /* Pas de padding pour cette section */
}

/* --- Styles pour les blocs "CALENDRIER" et "PLAN" --- */
.content-block {
    background-color: #D9D9D9; /* Couleur de fond des blocs (gris clair) */
    height: 300px; /* Hauteur fixe comme sur l'image */
    border: 3px solid #A1894B; /* Bordure foncée */
    position: relative; /* Pour positionner le bouton 'M' */
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* Ombre pour du relief */
}

.content-block h2 {
    font-family: 'Inter', sans-serif; /* Police de "CALENDRIER" et "PLAN" */
    font-size: 2.5rem;
    color: black;
    text-align: center;
    margin: 0;
}

/* --- Styles pour le tableau des tarifs --- */
.custom-table {
    border-collapse: collapse; /* Pour des bordures nettes */
    background-color: #D9D9D9; /* Fond du tableau */
    border: 3px solid #A1894B; /* Bordure extérieure du tableau */
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.custom-table th,
.custom-table td {
    border: 1px solid #A1894B; /* Bordures des cellules */
    padding: 1rem;
    text-align: left;
    font-family: 'Inter', sans-serif;
    font-size: 1.1rem;
    color: black;
}

.custom-table th {
    background-color: #E5D6AC; /* Fond de l'en-tête */
    font-weight: bold;
    text-transform: uppercase;
}

/* --- Styles pour la section des icônes d'informations complémentaires --- */
.icon-info-section .icon-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start; /* Aligne le contenu en haut du bloc */
    height: 100%; /* S'assure que le bloc prend toute la hauteur disponible dans sa colonne */
    padding: 1rem;
    /* Si tu veux un fond comme les blocs "Pourquoi nous choisir ?" */
    /* background-color: #D9D9D9; */
    /* border: 2px solid #A1894B; */
}

.icon-info-section .icon-block img {
    width: 80px; /* Ajuste la taille des icônes */
    height: 80px;
    border-radius: 50%; /* Si les icônes sont rondes */
    object-fit: cover;
    margin-bottom: 0.5rem; /* Espacement sous l'icône */
}

.icon-info-section .icon-block .icon-label {
    font-family: 'Inter', sans-serif;
    font-size: 1rem;
    color: black;
    text-align: center;
    line-height: 1.3;
}

/* --- Styles pour la sélection d'avatar dans le formulaire d'inscription --- */

/* Conteneur des avatars pour le flexbox et l'espacement */
.avatar-selection-group {
    gap: 15px; /* Espacement entre les avatars */
    margin-top: 20px; /* Espace au-dessus du groupe d'avatars */
    margin-bottom: 20px; /* Espace en dessous */
}

/* Styles par défaut pour chaque option d'avatar (le label) */
.avatar-option {
    cursor: pointer;
    border: 3px solid transparent; /* Bordure transparente par défaut */
    border-radius: 50%; /* Si tu veux que l'encadrement soit rond */
    padding: 5px; /* Espacement entre la bordure et l'image */
    transition: border-color 0.2s ease-in-out; /* Animation douce pour le changement de bordure */
    display: block; /* S'assure que le label se comporte comme un bloc */
}

/* Styles pour l'image de l'avatar à l'intérieur du label */
.avatar-option img {
    width: 80px; /* Taille désirée pour l'avatar */
    height: 80px; /* Assure une forme carrée ou ronde selon le border-radius */
    object-fit: cover; /* Recadre l'image si elle ne correspond pas exactement */
    border-radius: 50%; /* Pour rendre l'image ronde */
    display: block; /* Supprime l'espace sous l'image */
}

/* Style de la bordure bleue lorsque l'input radio est sélectionné */
.avatar-option input[type="radio"]:checked + img {
    border: 3px solid #007bff; /* Bordure bleue de Bootstrap, ou toute autre couleur que tu veux */
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25); /* Un léger halo bleu */
}

/* Une règle pour le survol (hover) pour indiquer que l'image est cliquable */
.avatar-option:hover {
    border-color: #A1894B; /* Couleur de survol, par exemple ta couleur jaune personnalisée */
}

.map-responsive {
    overflow: hidden;
    padding-bottom: 56.25%; /* Ratio 16:9 */
    position: relative;
    height: 0;
    border: 3px solid #A1894B; /* Bordure autour de la carte */
    box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* Légère ombre pour la carte */
    background-color: #E5D6AC; /* Couleur de fond en cas de non chargement */
}

.map-responsive iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    position: absolute;
}

/* Ajustements pour le content-block contenant la carte */
.content-block.map-block {
    height: auto; /* Supprime la hauteur fixe précédente pour laisser la carte décider */
    padding: 20px; /* Ajoute un padding autour de la carte et du texte */
    display: block; /* S'assure que le bloc est un bloc pour que la carte s'étende */
}
.image-gallery-section {
    padding-top: 30px; /* Ajoute de l'espace au-dessus de la galerie */
    padding-bottom: 30px; /* Ajoute de l'espace en dessous de la galerie */
}

.gallery-image {
    border: 2px solid #A1894B; /* Bordure autour de chaque image */
    box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.15); /* Ombre légère */
    border-radius: 8px; /* Coins légèrement arrondis */
    transition: transform 0.3s ease-in-out; /* Animation au survol */
    max-width: 100%; /* S'assurer qu'elle respecte son conteneur */
    height: auto; /* Maintient le ratio de l'image */
}

.gallery-image:hover {
    transform: translateY(-5px); /* Léger soulèvement au survol */
    box-shadow: 6px 6px 12px rgba(0, 0, 0, 0.25); /* Ombre plus prononcée au survol */
}

.message-view-container {
    max-width: 900px; /* Largeur maximale du conteneur du message */
    margin: 60px auto; /* Centre le conteneur horizontalement et ajoute de l'espace vertical */
    padding: 30px;
    background-color: #D9D9D9; /* Ton gris clair existant */
    border: 3px solid #A1894B; /* Bordure prononcée avec ta couleur personnalisée */
    box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); /* Ombre marquée pour un effet de profondeur */
    text-align: center; /* Centre les titres */
    position: relative;
}

.message-view-container h1 {
    font-family: 'Grenze Gotisch', cursive; /* Police de tes titres principaux */
    font-size: clamp(2.2rem, 4vw, 3rem); /* Taille de police responsive pour le titre du message */
    color: black;
    margin-bottom: 30px; /* Espace sous le titre du message */
    text-align: center;
}

.message-view-container .message-details-block {
    text-align: left; /* Alignement du texte à gauche pour les détails et le contenu */
    margin-bottom: 40px; /* Espace sous le bloc de détails */
    padding: 20px;
    background-color: rgba(229, 214, 172, 0.5); /* Couleur beige semi-transparente pour le fond des détails */
    border: 1px solid #A1894B;
    box-shadow: inset 2px 2px 5px rgba(0, 0, 0, 0.1); /* Ombre interne discrète */
}

.message-view-container .message-details-block h2 {
    font-family: 'Inter', sans-serif; /* Police pour les labels d'information (De, À) */
    font-size: clamp(1rem, 2vw, 1.2rem); /* Taille de police responsive */
    color: black;
    margin-bottom: 10px; /* Espacement entre les lignes de détails */
    padding-left: 15px; /* Indentation */
    position: relative;
}

/* Petite barre décorative à gauche de chaque information de détail */
.message-view-container .message-details-block h2::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px; /* Largeur de la barre */
    height: 70%; /* Hauteur de la barre */
    background-color: #A1894B; /* Couleur de ta marque */
    border-radius: 3px; /* Coins arrondis pour la barre */
}

/* Style pour les valeurs (expéditeur, destinataire) */
.message-view-container .message-details-block h2 span {
    font-weight: bold; /* Met en gras la valeur */
    color: #333; /* Couleur légèrement plus foncée pour la valeur */
    font-family: 'Times New Roman', serif; /* Police distinctive pour les valeurs */
    font-size: clamp(1.1rem, 2.2vw, 1.3rem); /* Ajuste la taille de la valeur */
}

.message-view-container .message-content-label {
    font-family: 'Inter', sans-serif;
    font-size: clamp(1.1rem, 2.2vw, 1.4rem);
    color: black;
    margin-top: 25px; /* Espace au-dessus du label "Message :" */
    margin-bottom: 10px;
    padding-left: 15px; /* Aligné avec les autres labels */
    position: relative; /* Pour la barre décorative */
    text-align: left;
}

/* Barre décorative pour le label "Message :" */
.message-view-container .message-content-label::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 70%;
    background-color: #A1894B;
    border-radius: 3px;
}


.message-view-container .message-content-text {
    font-family: 'Times New Roman', serif; /* Police pour le contenu du message */
    font-size: clamp(1rem, 1.8vw, 1.15rem); /* Taille de police pour le contenu */
    color: #333; /* Couleur de texte sombre mais pas noir absolu */
    line-height: 1.6; /* Meilleure lisibilité pour les paragraphes */
    white-space: pre-wrap; /* Préserve les espaces et retours à la ligne du HTML */
    text-align: justify; /* Justifie le texte du message */
    padding-left: 15px; /* Pour aligner le contenu avec les barres des titres */
    padding-right: 15px;
    margin-bottom: 20px;
}


/* Style du bouton "Répondre" */
.message-view-container .btn {
    /* Utilise tes classes .bg-custom-button pour la couleur, police, etc. */
    margin-top: 30px; /* Espace au-dessus du bouton */
    border: 3px solid #A1894B; /* Bordure du bouton */
    border-radius: 0; /* Coins carrés */
    padding: 12px 30px; /* Ajuste le padding pour une taille agréable */
    font-size: 1.3rem; /* Taille de police du bouton */
}
/* Styles pour le conteneur global du formulaire */
#reservationForm {
    max-width: 600px; /* Largeur maximale du formulaire */
    margin: 60px auto; /* Centre le formulaire horizontalement et ajoute de l'espace vertical */
    padding: 40px; /* Espacement interne */
    background-color: #D9D9D9; /* Couleur de fond gris clair */
    border: 3px solid #A1894B; /* Bordure prononcée avec ta couleur personnalisée */
    box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.2); /* Ombre marquée pour un effet de profondeur */
    border-radius: 5px; /* Légers coins arrondis pour le formulaire */
    text-align: left; /* Alignement du texte par défaut */
}

/* Style du titre du formulaire */
#reservationForm h1 {
    font-family: 'Grenze Gotisch', cursive; /* Police de tes titres principaux, si disponible */
    font-size: clamp(2.2rem, 4vw, 3rem); /* Taille de police responsive */
    color: black; /* Couleur du titre */
    margin-bottom: 30px; /* Espacement sous le titre */
    text-align: center; /* Centre le titre */
}

/* Styles pour les groupes de formulaire (labels et inputs) */
.form-group {
    margin-bottom: 20px; /* Espacement entre les groupes de champs */
}

.form-group label {
    font-family: 'Inter', sans-serif; /* Police pour les labels, comme tes info-blocks */
    font-size: 1.1rem; /* Taille de police pour les labels */
    color: #333; /* Couleur de texte plus foncée pour la lisibilité */
    margin-bottom: 8px; /* Espacement entre le label et l'input */
    display: block; /* Assure que le label prend sa propre ligne */
    font-weight: bold; /* Met les labels en gras */
}

/* Styles pour les champs de texte (email) */
.form-control {
    width: 100%; /* Le champ prend toute la largeur disponible */
    padding: 12px 15px; /* Padding interne pour le confort de saisie */
    border: 2px solid #A1894B; /* Bordure de la même couleur que ta marque */
    border-radius: 5px; /* Coins légèrement arrondis pour l'input */
    background-color: white; /* Fond blanc pour le champ */
    font-family: 'Times New Roman', serif; /* Police pour le texte saisi */
    font-size: 1rem; /* Taille de police pour le texte saisi */
    color: #333; /* Couleur du texte saisi */
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1); /* Ombre interne discrète */
    transition: border-color 0.3s ease, box-shadow 0.3s ease; /* Transition douce pour le focus */
}

.form-control:focus {
    border-color: #7a6839; /* Couleur de bordure légèrement plus foncée au focus */
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1), 0 0 0 0.25rem rgba(161, 137, 75, 0.25); /* Ombre pour le focus */
    outline: none; /* Supprime l'outline par défaut du navigateur */
}

/* Styles pour les cases radio et leurs labels */
.form-check {
    margin-bottom: 10px; /* Espacement entre les options radio */
    display: flex; /* Utilise flexbox pour aligner la case et le texte */
    align-items: flex-start; /* Aligne le début du texte avec la case */
}

.form-check-input[type="radio"] {
    /* Cache l'input radio par défaut et le remplace par un style personnalisé */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 20px; /* Taille de la case radio personnalisée */
    height: 20px;
    border: 2px solid #A1894B; /* Bordure de la case */
    border-radius: 50%; /* Forme circulaire */
    background-color: white; /* Fond blanc */
    margin-top: 4px; /* Alignement vertical avec le texte */
    flex-shrink: 0; /* Empêche la case de rétrécir */
    transition: background-color 0.2s ease, border-color 0.2s ease;
    cursor: pointer;
}

.form-check-input[type="radio"]:checked {
    background-color: #A1894B; /* Couleur de fond quand coché */
    border-color: #A1894B; /* Bordure de la même couleur */
    /* Petite ombre pour un effet "enfoncé" */
    box-shadow: inset 0 0 0 4px white; /* Cercle blanc au centre */
}

.form-check-input[type="radio"]:focus {
    outline: none;
    box-shadow: 0 0 0 0.25rem rgba(161, 137, 75, 0.25); /* Anneau de focus */
}

.form-check-label {
    font-family: 'Times New Roman', serif; /* Police pour le texte des options */
    font-size: 1rem; /* Taille de police pour le texte des options */
    color: #444; /* Couleur de texte */
    margin-left: 10px; /* Espacement entre la case et le texte */
    cursor: pointer;
}

/* Styles pour le bouton de soumission */
#submitButton {
    width: auto; /* Largeur automatique */
    min-width: 200px; /* Largeur minimale pour le bouton */
    padding: 12px 25px; /* Padding ajusté pour ta taille */
    font-size: 1.2rem; /* Taille de police du bouton */
    font-weight: bold;
    text-transform: uppercase; /* Texte en majuscules pour le bouton */
    letter-spacing: 1px; /* Espacement des lettres */
    display: block; /* Prend toute la largeur si pas de max-width */
    margin: 40px auto 0; /* Centre le bouton */
    cursor: pointer;
}

/* Style spécifique pour le bouton désactivé */
#submitButton:disabled {
    background-color: #cccccc; /* Couleur de fond gris clair */
    color: #666666; /* Couleur de texte gris foncé */
    border-color: #999999; /* Bordure gris */
    cursor: not-allowed; /* Curseur "interdit" */
    box-shadow: none; /* Pas d'ombre */
    transform: none; /* Pas d'animation au survol */
    transition: none; /* Pas de transition pour le disabled */
}

  @media (max-width: 992px) {

     .contact-container {
        padding: 30px;
        max-width: 90%; /* Plus de largeur sur les tablettes */
    }

    .form-control-custom {
        height: 60px; /* Un peu plus petit sur les tablettes */
    }

    textarea.form-control-custom {
        height: 250px;
    }

    textarea#subject-textarea.form-control-custom {
    height: 68px; /* Applique la même hauteur fixe que le select et les inputs */
    min-height: 68px; /* Empêche qu'il soit plus petit si 'rows' le rendait plus petit */
    resize: none; /* Désactive le redimensionnement par l'utilisateur pour maintenir la hauteur fixe */
    overflow-y: hidden; /* Cache la scrollbar si le texte dépasse (pour les petites hauteurs) */
}

    .contact-submit-button {
        width: 280px;
        height: 60px;
        font-size: 20px;
        line-height: 60px;
    }

    /* Ajuster la visibilité et la taille des images pour les tablettes */
    .img-rotated-corner, .img-side-top, .img-side-bottom, .img-bottom-banner {
        opacity: 0.5; /* Moins d'opacité pour ne pas surcharger */
    }

    .img-rotated-corner {
        width: clamp(600px, 80vw, 1200px);
    }
    .img-side-top {
        width: clamp(300px, 40vw, 700px);
    }
    .img-side-bottom {
        width: clamp(400px, 50vw, 900px);
    }
    .img-bottom-banner {
        width: clamp(600px, 80vw, 1200px);
    }
}

  
/* Responsive adjustments */
@media (max-width: 768px) {
    /* ... (Tes styles existants) ... */

    .navbar-collapse {
        position: static !important;
        background-color: #D5C596;
        padding-bottom: 15px;
    }

    .navbar-nav {
        flex-direction: column;
        align-items: center;
        width: 100%;
    }

    .navbar-nav .nav-link {
        margin: 10px 0;
        font-size: 20px;
    }

    .navbar-brand {
        margin-right: auto;
    }

    .navbar-brand .imgpicto { /* Cibler le logo du navbar-brand */
    width: 40px; /* Taille par défaut si tu veux */
    height: 40px; /* Taille par défaut si tu veux */
    border-radius: 50%; /* Si ce n'est pas déjà fait et que tu veux un logo rond */
    object-fit: cover;
}

    .hero-banner-section {
        height: auto; /* Let the padding-bottom determine height primarily */ /* Smaller min-height for smaller screens */
    }
 .contact-container {
        margin: 30px 15px;
        padding: 20px;
    }

    .form-label-contact {
        font-size: 20px;
        margin-bottom: -10px;
    }

    .form-control-custom {
        height: 55px;
        font-size: 1rem;
    }

    textarea.form-control-custom {
        height: 200px;
    }

    .contact-submit-button {
        width: 100%; /* Bouton prend toute la largeur sur mobile */
        height: 50px;
        font-size: 18px;
        line-height: 50px;
    }

    /* Masquer certaines images sur les petits écrans si elles gênent trop */
    .img-rotated-corner, .img-side-bottom {
        display: none;
    }
    .img-side-top, .img-bottom-banner {
        opacity: 0.3; /* Encore moins d'opacité */
    }
    .img-side-top {
        width: clamp(200px, 30vw, 400px);
    }
    .img-bottom-banner {
        width: clamp(400px, 60vw, 800px);
    }

    .banner-top {
        height: 200px; /* Plus petite hauteur sur mobile */
    }
    .banner-top .banner-overlay-img {
        width: 150px; /* Plus petite image sur mobile */
    }
    .banner-top .banner-title {
        font-size: 2rem;
    }
    .info-banner .banner-ribbon {
        font-size: 1.2rem;
        padding: 0.6rem 2rem;
    }
    .info-banner .banner-ribbon::before,
    .info-banner .banner-ribbon::after {
        border-top: 25px solid transparent;
        border-bottom: 25px solid transparent;
        border-right: 15px solid #E5D6AC;
        border-left: 15px solid #E5D6AC;
    }
    .info-banner .banner-ribbon::before { left: -15px; }
    .info-banner .banner-ribbon::after { right: -15px; }

    .content-block {
        height: 200px;
    }
    .content-block h2 {
        font-size: 1.8rem;
    }
    .custom-table th,
    .custom-table td {
        font-size: 0.9rem;
        padding: 0.8rem;
    }
    .icon-info-section .icon-block img {
        width: 60px;
        height: 60px;
    }
    .icon-info-section .icon-block .icon-label {
        font-size: 0.9rem;
    }

        .profile-container .pdp {
        width: 140px; /* Ajusté pour mobile */
        height: 140px; /* Ajusté pour mobile */
        margin-bottom: 20px;
    }
    .pdp { /* Pour l'image de profil de l'utilisateur connecté */
    width: 40px; /* Taille par défaut */
    height: 40px; /* Taille par défaut */
    border-radius: 50%; /* Pour la rendre ronde */
    object-fit: cover; /* Assure que l'image remplit le cercle */
    border: 2px solid #A1894B; /* Bordure, comme sur les commentaires */
}

      .gallery-image {
        max-width: 90%; /* Réduit la largeur sur mobile pour laisser un peu d'espace */
    }
.message-view-container {
        margin: 30px 15px;
        padding: 20px;
    }
    .message-view-container h1 {
        font-size: 1.8rem;
    }
    .message-view-container .message-details-block {
        padding: 15px;
    }
    .message-view-container .message-details-block h2 {
        font-size: 0.9rem;
        padding-left: 10px;
    }
    .message-view-container .message-details-block h2 span {
        font-size: 1rem;
    }
    .message-view-container .message-content-label {
        font-size: 1rem;
        margin-top: 15px;
        padding-left: 10px;
    }
    .message-view-container .message-content-text {
        font-size: 0.95rem;
        padding-left: 10px;
        padding-right: 10px;
    }
    .message-view-container .btn {
        padding: 10px 25px;
        font-size: 1.1rem;
    }
    
    #reservationForm {
        margin: 30px 15px; /* Marges réduites sur mobile */
        padding: 25px; /* Padding interne réduit */
    }

    #reservationForm h1 {
        font-size: clamp(1.8rem, 6vw, 2.5rem); /* Taille de titre ajustée */
        margin-bottom: 25px;
    }

    .form-group label {
        font-size: 1rem;
    }

    .form-control {
        padding: 10px 12px;
        font-size: 0.95rem;
    }

    .form-check-input[type="radio"] {
        width: 18px;
        height: 18px;
        margin-top: 3px;
    }

    .form-check-label {
        font-size: 0.9rem;
        margin-left: 8px;
    }

    #submitButton {
        min-width: unset; /* Supprime le min-width */
        width: 100%; /* Prend toute la largeur sur mobile */
        padding: 10px 20px;
        font-size: 1rem;
        margin-top: 30px;
    }
}

@media (max-width: 576px) {
    .header-logo {
        width: 150px;
        height: auto;
        top: -20px;
        left: 5px;
    }

    .d-flex.align-items-center > .navbar-text,
    .d-flex.align-items-center > .btn {
        font-size: 0.9em;
        margin-right: 5px !important;
        margin-left: 5px !important;
    }

    .d-flex.align-items-center {
        flex-wrap: wrap;
        justify-content: center;
        margin-top: 10px;
        width: 100%;
    }

    .rounded-circle.border,
    .rotated-line-42deg,
    .img-fluid.img-rotated-180 {
        display: none !important;
    }

    .navbar-toggler {
        margin-left: auto;
    }
        .profile-container {
        margin: 30px 15px;
        padding: 20px;
    }
    .profile-container h2 {
        padding-left: 10px;
        font-size: clamp(1rem, 3.5vw, 1.5rem);
    }

     .contact-container {
        padding: 15px;
    }

    .contact-container h1 {
        font-size: clamp(1.8rem, 8vw, 2.5rem);
        margin-bottom: 30px;
    }

    .form-label-contact {
        font-size: 18px;
        margin-bottom: -5px;
    }
    .img-side-top, .img-bottom-banner {
        display: none;
    }

    .container p{
        margin:0 5%;
    }
     .navbar-collapse .d-flex.align-items-md-center {
        /* Cela cible le conteneur du nom d'utilisateur, photo, et boutons */
        /* Flexbox pour centrer ses éléments enfants */
        display: flex;
        flex-direction: column; /* Empile verticalement */
        align-items: center; /* Centre horizontalement les éléments empilés */
        width: 100%; /* Prend toute la largeur disponible dans le menu responsive */
    }

    /* Ajustement spécifique pour l'image de profil (pdp) */
    .navbar-collapse .d-flex.align-items-md-center .pdp {
        width: 60px; /* Taille plus grande sur mobile */
        height: 60px; /* Taille plus grande sur mobile */
        margin-bottom: 10px; /* Ajoute un peu d'espace sous l'image de profil */
        margin-right: 0 !important; /* Annule la marge droite si elle était définie */
        margin-left: 0 !important; /* Annule la marge gauche si elle était définie */
    }

    /* Ajustement des autres éléments autour de la photo de profil si nécessaire */
    .navbar-collapse .navbar-text.fs-5 { /* Nom d'utilisateur */
        margin-bottom: 10px !important; /* Espace sous le nom */
        text-align: center; /* Centre le texte du nom */
    }

    .navbar-collapse .d-flex.flex-column.flex-sm-row { /* Conteneur des boutons Messagerie/Déconnexion */
        flex-direction: column !important; /* Force l'empilement vertical des boutons */
        align-items: center; /* Centre les boutons */
        width: 100%; /* Prend toute la largeur */
    }

    .navbar-collapse .d-flex.flex-column.flex-sm-row .btn {
        width: 80%; /* Pour que les boutons ne soient pas trop larges sur mobile */
        max-width: 200px; /* Largeur maximale pour les boutons */
        margin-right: 0 !important; /* Enlève les marges horizontales entre boutons sur mobile */
        margin-bottom: 10px !important; /* Ajoute un espace vertical entre les boutons */
    }
}