/* START hero */
.hero {
    min-height: 90vh;
    height: auto;
}

.hero .uniformSpacing {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* END hero */


/* START doubleImgText */
.doubleImgText .uniformSpacing {
    display: flex;
    gap: 2.5em;
    align-items: center;
}


.doubleImgText .uniformSpacing > div {
    width: 50%;
}

.doubleImgText .uniformSpacing .introText {
    display: flex;
    flex-direction: column;
    gap: 2em;
}

.doubleImgText .uniformSpacing .introText div {
    display: flex;
    flex-direction: column;

    gap: .5em;
}

.doubleImgText .uniformSpacing .textContainer {
    position: relative;
    height: auto;
    aspect-ratio: 4/3;
}

.doubleImgText .uniformSpacing .textContainer img,
.doubleImgText .uniformSpacing .textContainer span {
    position: absolute;
    object-fit: cover;
}

.doubleImgText .uniformSpacing .textContainer img:first-child,
.doubleImgText .uniformSpacing .textContainer span:first-child {
    top: 0;
    left: 0;
    z-index: 1;
    width: 75%;
    height: 75%;
}

.doubleImgText .uniformSpacing .textContainer img:last-child,
.doubleImgText .uniformSpacing .textContainer span:last-child {
    bottom: 0;
    right: 0;
    width: 65%;
    height: 60%;
    z-index: 1;
    aspect-ratio: 4/3;

}

@media screen and (max-width: 1000px) {
    .doubleImgText .uniformSpacing, .doubleImgText.reverse .uniformSpacing {
        flex-direction: column;
    }

    .doubleImgText .uniformSpacing > div {
        width: 100%;
    }

    .doubleImgText .uniformSpacing .check_list {
        width: 100%;
    }
}

@media screen and (max-width: 500px) {
    .doubleImgText .uniformSpacing .check_list .element {
        width: 100%;
    }
}

/* END doubleImgText */

/* START bandeauSilhouette */
.bandeauSilhouette img {
    width: 100%;
    height: auto;
}

/* END bandeauSilhouette */


/* START reservationProduct */
.reservationProduct .listingProduct .productsContainer .productsContent {
    display: flex;
    flex-wrap: wrap;
    gap: 2.5em;
}

.reservationProduct .listingProduct .product {
    width: calc((100% - 2.5em * 2) / 3);
    display: flex;
    flex-direction: column;
    gap: 1.25em;
}

.reservationProduct .listingProduct .product .cardProduct {
    display: flex;
    flex-direction: column;
    gap: 2em;
    background-color: #F2F2F2;
}

.reservationProduct .listingProduct .product .cardProduct img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText {
    display: flex;
    flex-direction: column;
    gap: .5em;
    padding: 0 1.5em 2.5em 1.5em;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText hr {
    border: none;
    height: 1px;
    width: 100%;
    background-color: #707070;
    margin-bottom: .5em;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText h4 {
    display: flex;
    gap: .5em;
    align-items: center;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText h4 svg {
    width: 1.5em;
    height: 1.5em;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText .equipements {
    display: flex;
    gap: .5em;
    align-items: center;
}

.reservationProduct .listingProduct .product .cardProduct .cardProductText .equipements svg {
    width: 1em;
    height: 1em;
}

.reservationProduct .listingProduct .product .tarifs {
    background-color: #F2F2F2;

}

.reservationProduct .listingProduct .product .tarifs h3 {
    background-color: #E8E8E8;
    padding: 1em 1.5em;
    border-top-right-radius: var(--basicRadius);
    border-top-left-radius: var(--basicRadius);
}


.reservationProduct .listingProduct .product .tarifs .container {
    display: flex;
    flex-direction: column;
    padding: 0 1.5em;

}

.reservationProduct .listingProduct .product .tarifs .container div {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 1px;
    border-bottom: 1px solid #707070;
    padding: .5em 0;
}

.reservationProduct .listingProduct .product .tarifs .container div:last-child {
    padding-bottom: 2.5em;
    border-bottom: 0;
}


.reservationProduct .listingProduct {
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.reservationProduct .reservation {
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.reservationProduct .reservation form {
    background-color: #F2F2F2;
    padding: 1em 1.5em 2.5em 1.5em;
    display: flex;
    flex-wrap: wrap;
    gap: 3em;
}

.reservationProduct .reservation form > div {
    display: flex;
    flex-direction: column;
    gap: .5em;
    width: calc((100% - 3em * 2) / 3);
}

.flatpickr-calendar.open{
    z-index: 9 !important;
}

.reservationProduct .reservation form div select,
.reservationProduct .reservation form div input {
    padding: 1em;
    background-color: var(--basicWhite);
    border: none;
    width: 100%;
}

.reservationProduct .reservation form div.selectWrapper {
    position: relative;
    display: inline-block;
}

.reservationProduct .reservation form div.selectWrapper select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 2.5rem;
    width: 100%;
}

.reservationProduct .reservation form div.selectWrapper::after {
    content: "▼";
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 1rem;
    color: var(--basicColor1);
}

.reservationProduct .reservation form div #date,
.reservationProduct .reservation form div input.flatpickr-input.flatpickr-mobile {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
}

.reservationProduct .reservation form div.option {
    display: flex;
    flex-direction: row;
    gap: 1.5em;
    align-items: flex-end;
}

.reservationProduct .reservation form div.option input {
    width: 1.5em;
    height: 1.5em;
    border-radius: .5em;
}

.reservationProduct .reservation form div.option div {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
}

.reservationProduct .reservation form div.option input[type="checkbox"] {
    display: none;
}

.reservationProduct .reservation form div.option input[type="checkbox"]:checked + span,
.reservationProduct .reservation form div.option input[type="checkbox"].checked + span {
    background: var(--basicColor1);
    border-color: var(--basicColor1);
    transform: rotate(45deg);
}

.reservationProduct .reservation form div.option input[type="checkbox"] + span {
    box-sizing: border-box;
    position: relative;
    display: block;
    width: 24px;
    height: 24px;
    border: 1px solid #ccc;
    border-radius: 3px;
    transition: 0.3s;
}

.reservationProduct .reservation form div.option input[type="checkbox"]:checked + span::after,
.reservationProduct .reservation form div.option input[type="checkbox"].checked + span::after {
    color: var(--basicWhite);
    content: "";
    display: block;
    box-sizing: border-box;
    position: absolute;
    left: 50%;
    top: 50%;
    width: 7px;
    height: 12px;
    border-width: 0 2px 2px 0;
    border-style: solid;
    transform: translate(-50%, -50%);
}

.reservationProduct .reservation form div.submit {
    display: flex;
    justify-content: flex-end;
}

.reservationProduct .reservation form div.submit input {
    width: 100%;
    padding: 1em;
    text-align: center;
    background-color: var(--basicColor1);
}

.reservationProduct .reservation .cgv {
    display: flex;
    gap: .5em;
    align-items: center;
}

.reservationProduct .reservation .cgv a {
    text-decoration: underline;
}

.reservationProduct .reservation .cgv svg {
    width: 1.75em;
    height: auto;
}

.reservationProduct .btnReservation {
    width: 100%;
    display:  flex;
    justify-content: center;
}

.reservationProduct .btnReservation a{
    padding: .5em 1em;
    text-align:  center;
    width: fit-content;
}


.reservationProduct .notes {
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.reservationProduct .notes,
.reservationProduct .notes .littleTitle {
    display: flex;
    flex-direction: column;
    gap: .5em;
}

.reservationProduct .notes .littleTitle h3 {
    padding-left: 2.5em;
    text-decoration: underline;
}


.reservationProduct .notes .littleTitle > div {
    display: flex;
    gap: .5em;
    align-items: center;
}


.reservationProduct .notes .littleTitle > div svg {
    width: 1.5em;
    height: 1.5em;
}

@media screen and (max-width: 1000px) {
    .reservationProduct .listingProduct .productsContainer .productsContent {
        gap: 1em;
    }

    .reservationProduct .listingProduct .product {
        width: calc((100% - 1em * 2) / 3);
    }
}

@media screen and (max-width: 800px) {
    .reservationProduct .listingProduct .product {
        width: 100%;
    }

    .reservationProduct .reservation form > div {
        width: calc((100% - 3em) / 2);
    }
}

@media screen and (max-width: 600px) {
    .reservationProduct .reservation form > div {
        width: 100%;
    }

    .reservationProduct .reservation form {
        gap: 1em;
    }
}


/* END reservationProduct */

/* START lieu */
.lieu .uniformSpacing {
    display: flex;
    gap: 10em;
}

.lieu .uniformSpacing > div {
    width: 50%;
}

.lieu .uniformSpacing .leftContainer .listingImgLieu {
    display: flex;
    flex-wrap: wrap;
    gap: 1em 2em;
}

.lieu .uniformSpacing .leftContainer .listingImgLieu .element {
    display: flex;
    flex-direction: column;
    gap: 1.5em;
    width: calc((100% - 2em) / 2);
}

.lieu .uniformSpacing .leftContainer .listingImgLieu .element img {
    width: 100%;
    height: auto;
    aspect-ratio: 4/3;
    object-fit: cover;
}

.lieu .uniformSpacing .leftContainer .listingImgLieu .element div {
    display: flex;
    gap: .5em;
}

.lieu .uniformSpacing .leftContainer .listingImgLieu .element div svg {
    width: 1em;
    height: 1em;
}

.lieu .uniformSpacing .rightContainer img {
    height: 100%;
    width: 100%;
    max-width: 100%;
    object-fit: contain;
}

@media screen and (max-width: 1200px) {
    .lieu .uniformSpacing {
        gap: 4em;
    }
}

@media screen and (max-width: 800px) {
    .lieu .uniformSpacing {
        flex-direction: column;
    }

    .lieu .uniformSpacing > div {
        width: 100%;
    }
}


/* END lieu */

/* START galery */
.galeryContainer {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 15em;
    gap: 1em;
    grid-auto-flow: row dense;
}

.galeryContainer img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 8px;
}

/* Pattern répétable */
.galeryContainer img:nth-child(4n+1) {
    grid-column: 1;
    grid-row: span 2;
}

.galeryContainer img:nth-child(4n+2) {
    grid-column: 2;
    grid-row: span 1;
}

.galeryContainer img:nth-child(4n+3) {
    grid-column: 1;
    grid-row: span 1;
}

.galeryContainer img:nth-child(4n+4) {
    grid-column: 2;
    grid-row: span 2;
}

@media screen and (max-width: 1500px) {
    .galeryContainer {
        grid-auto-rows: 15vw;
    }
}

/* END galery */

/* START contact */
.contact .uniformSpacing .containerForm {
    display: flex;
    gap: 2.5em;
}

.contact .uniformSpacing .containerForm form{
    display: flex;
    flex-direction: column;
    gap: 1.5em;
}

.contact .uniformSpacing .containerForm form .inputContainer {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5em 2.5em;
}

.contact .uniformSpacing .containerForm form .inputContainer input,
.contact .uniformSpacing .containerForm form .inputContainer textarea {
    padding: 0.75em 1.25em;
    box-shadow: 3px 3px 16px #00000052;
    border: none;
}

.contact .uniformSpacing .containerForm form input {
    width: calc((100% - 2.5em) / 2);
    font-size: 1em;
}

.contact .uniformSpacing .containerForm form .inputContainer textarea {
    font-size: 1em;
    height: 10em;
    width: 100%;
}

.contact .uniformSpacing .containerForm .inputContainer .submitContainer {
    width: 100%;
    display: flex;
    justify-content: flex-end;
}

.contact .uniformSpacing .containerForm .inputContainer .submitContainer button {
    padding: 1em 1.5em;
    text-align: center;
    background: var(--basicColor1);
    color: white;
    border-radius: var(--basicRadius);
    border: none;
}

.contact .uniformSpacing .containerForm .coordonnees {
    min-width: fit-content;
    display: flex;
    flex-direction: column;
    gap: 1em;
}

.contact .uniformSpacing .containerForm .coordonnees .contactData {
    display: flex;
    flex-direction: column;
    gap: .5em;
}


.contact .uniformSpacing .containerForm .coordonnees .contactData > div {
    display: flex;
    gap: .5em;
}

.contact .uniformSpacing .containerForm .coordonnees .contactData div svg {
    width: 1em;
    height: 1em;
}

.contact .uniformSpacing .containerForm .coordonnees .socialContainer svg {
    width: 3em;
    height: 3em;
}

.contact .uniformSpacing .containerForm .coordonnees .socialContainer svg path {
    fill: var(--basicColor1)
}

.contact .uniformSpacing .containerForm .horaires .horaireContainer {
    width: 100%;

}

.contact .uniformSpacing .containerForm .horaires .horaireContainer .element {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1em;
}

.contact .uniformSpacing .containerForm .horaires .horaireContainer .element p {
    min-width: fit-content;
}

.contact .uniformSpacing .containerForm .horaires .horaireContainer .element div {
    width: 100%;
    height: 1px;
    background-color: #707070;
}

@media screen and (max-width: 1000px) {
    .contact .uniformSpacing .containerForm {
        flex-direction: column-reverse;
    }
}

@media screen and (max-width: 700px) {
    .contact .uniformSpacing .containerForm form .inputContainer input,
    .contact .uniformSpacing .containerForm form .inputContainer textarea {
        width: 100%;
    }
}

/* END contact */


/* START map */
.map iframe {
    width: 100%;
    height: 20em
}

.map .uniformSpacing {
    display: flex;
    gap: 1em;
    padding-bottom: 2.5em;
}

.map .uniformSpacing svg {
    width: 1.5em;
    height: 1.5em;
}

/* END map */

/* START certifications*/
.certifications .bigSpacing.introPartenaire {
    padding-bottom: 0;
}

.certifications .sliderWrapper {
    width: 100%;
    padding: 1.5em 0px;
}

.certifications .sliderWrapper div {
    width: 350px;
    display: flex;
    align-items: center;
    aspect-ratio: 5/3;
    border-radius: var(--mediumRadius);
    box-shadow: 3px 3px 16px #00000052;
}

.certifications .sliderWrapper div img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.certifications .btnReserver .uniformSpacing {
    width: 100%;
    display: flex;
    justify-content: center;
}

.certifications .btnReserver .uniformSpacing {
    width: 100%;
    display: flex;
    justify-content: center;
}

.certifications .btnReserver .uniformSpacing a {
    padding: .5em 1em;
    width: 70%;
}


@media screen and (max-width: 1200px) {
    .certifications .sliderWrapper {
        justify-content: initial;
    }
}

@media screen and (max-width: 500px) {
    .certifications .sliderWrapper div {
        width: 250px;
    }
}

/* END certifications*/