@font-face {

    font-family: 'AvenirLTStd-Book';

    src: url('../../fonts/AvenirLTStd-Book.otf') format('opentype');

    font-weight: normal;

    font-style: normal;

}



* {

    font-family: 'AvenirLTStd-Book', sans-serif;



}



:root {

    --color-primary: #ac7747;

    --shadow-to-bottom: box-shadow: 0 0 14px -12px #a5a5a5;

    ;

    --shadow-to-top: box-shadow: 0 0 14px -12px #a5a5a5;

    ;

}







.mdi::before {

    color: var(--color-primary) !important;

    font-size: 25px !important;

}



/* Header Section */



.header-reservation-tete {

    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-image: url(../images/back-header-reservation.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    height: 25rem;
    position: relative;
    z-index: 1;

}



.header-reservation-tete::before {

    top: 0;

    left: 0;

    content: "";

    height: 100%;

    width: 100%;

    background-color: rgba(0, 0, 0, 0.5);

    position: absolute;

    z-index: -1;

}




.title-header-reservation-tete {

    color: white;

    font-size: 70px;

    z-index: 1;

}

.social-media-icons a {
    padding: 0 7px;
}


.infos-contact-header {

    font-size: 18px;

    margin: 0 22px 0 6px;

}







/* Check Chambre Section */

.check-chambre {

    position: relative;
    width: 100%;

}

.check-chambre2 {
    width: 80%;
    margin: auto;
}





/*  calendrie    */



/* Styles personnalisés pour le calendrier */

#calendar {

    max-width: 900px;

    margin: 0 auto;

}



.fc-content {

    background-color: var(--color-primary);

    color: white;

    height: 35px;

    display: flex;

    align-items: center;

    justify-content: center;

    border-radius: 0px !important;

}



.fc-widget-content {

    background-color: #fcf8e3;

}



.fc-right {

    display: flex;

    align-items: center;

}



.fc-today-button {

    background: transparent !important;

    box-shadow: none !important;

    font-size: 20px !important;

    border: solid 1px var(--color-primary) !important;

    color: var(--color-primary) !important;

}



.fc-today-button:disabled {

    color: var(--color-primary);

    font-size: 20px !important;

    background-color: transparent !important;

    border: none !important;

    text-decoration: underline;

    text-underline-offset: 5px;

}





.fc-prev-button,

.fc-next-button {

    margin: 0 1rem !important;

    border-radius: 50% !important;

    width: 3rem !important;

    height: 3rem !important;

}



.fc-today {

    background-color: rgb(255, 234, 148) !important;

}



.fc-title {

    font-size: 16px;

}



.fc-time {

    font-size: 14px;

}



.fc-event {

    border: none;

}



.fc-event:hover {

    border: none;

}



.fc-day-header {

    font-size: 14px;

    font-weight: bold;

}



.fc-day-top {

    text-align: center;

}



.fc-event-container {

    padding: 10px;

    margin: 10px;

    border-radius: 5px;

}



.fc-event,

.fc-event-dot {

    background-color: transparent !important;

}



.fc-event,

.fc-event-dot:hover {

    border: none !important;

}







.fc-toolbar {

    margin-bottom: 20px;

}







/*   end calendar  */





/* Footer Section */

.footer {

    margin-top: 6rem;

}



/* Card Chambre Check Section */

.card-chamber-check {

    position: relative;

    display: flex;

    flex-direction: column;

    justify-content: space-evenly;

}



/* All Chambre Disponible Section */

.option-disponible-chambre div a {

    font-size: 18px;

    margin-right: 1rem;

}



.option-disponible-chambre div a span::before {

    font-size: 28px;

    font-weight: 100;

}



.masque {

    position: relative;

    width: 100%;

    height: 290px;

    overflow: hidden;

    margin: 5px;

    border-radius: 8px 0px 0px 8px;

}



.carousel-item {

    height: 340px;

    background-size: cover;

    background-position: center;

}



.carousel-item.active,

.carousel-item-next,

.carousel-item-prev {

    display: block;

}



.carousel-container {

    display: flex;

    flex-direction: column;

    justify-content: center;

    height: 100%;

}



.all-chambre-disponible {

    display: flex;

    flex-direction: column;

    align-items: center;

    position: relative;

    bottom: 68px;

}





.all-chambre-disponible .main-body {

    width: 100%;

    position: relative;

    display: flex;

    align-items: center;

    justify-content: center;

    z-index: 1;

}



.all-chambre-disponible .main-body .layout-content {

    width: 100%;

    background-color: #fff;

    border: solid 1px #CECECE;

}



/* Chambre Disponible Section */





.form-check-chambreDisponible {

    border-radius: 8px;

    width: 100%;

    background: rgba(0, 0, 0, 0.59);

    padding: 5px;

    backdrop-filter: blur(3px);

}



.date_arrive {

    padding-right: 10px !important;

}



.date_depart {

    padding-right: 10px !important;

    padding-left: 10px !important;

}



.date_arrive .form-input-control,

.date_depart .form-input-control {

    height: 4rem;

}



.date_depart .form-input-control {

    border-radius: 5px !important;

}



.btn-search-chambre {

    padding: 21px 0rem;

    margin: 0px 2px 0px 0px;

    border-radius: 5px;

    font-size: 14px;

}



.chambre-disponible {

    overflow: hidden;

    position: relative;

    border-radius: 8px;

    border: solid 1px #D6D6D6;

    padding: 0rem !important;

    margin: 1rem 0 2rem 0;

}





.title-card-chambre {

    font-size: 24px;

}



.description-card-chambre {

    color: #4E4E4E;

    font-size: 16px;

}



.surface-chambre {

    font-size: 17px;

    color: var(--color-primary);

    font-weight: 500;

}



.reserve-btn {


    padding: 12px 32px;
    position: relative;
    bottom: 20px;
    border-radius: 8px;
    font-size: 16px;
    color: var(--color-primary);
    border: solid 1px var(--color-primary);
    background-color: transparent;
    text-transform: none;

}



.reserve-btn:hover {

    background-color: var(--color-primary) !important;

    color: white !important;

}



.option-chambre-disponible {

    display: flex;

    flex-direction: column;

    justify-content: space-between;

    align-items: end;

    padding-right: 20px;

}





.prix-chambre-disponble {

    background-color: var(--color-primary);

    color: white;
    font-weight: bold;

    padding: 20px 12px;

    text-align: center;

    font-size: 14px;

    border-radius: 0px 0px 8px 8px;

}



.prix-chambre-disponble span {

    font-size: 24px;
    font-family: 'Bellefair';
    font-weight: 500;


}



.btn-reserve {

    border-radius: 8px 8px 0px 0px !important;

}



/* Offcanvas Section */



.backdrop {

    position: fixed;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    background-color: rgba(0, 0, 0, 0.25);

    z-index: 1040;

    display: none;

}



.offcanvas {

    display: flex;

    justify-content: space-between;

}



.offcanvas-body {

    height: 100%;

}





/* List Filter Section */

.list-fliter {

    display: flex;

    justify-content: space-around;

    align-items: center;

    border: none;

}



.btn-flitre {

    padding: 1rem 2rem !important;

    width: 8rem !important;



}



.btn-flitre.active {

    background: var(--color-primary) !important;

    color: white !important;

    text-decoration: none !important;

}



/* List Group Item Equipement Section */

.list-group-item-equipement span {

    margin: 0rem 9px;

    font-size: 14px;

    font-weight: 900;

    margin-right: 10px;

}



.list-group-item-equipement {

    border: solid 0px var(--color-primary) !important;

    border-radius: 0 !important;

    font-size: 16px !important;

    text-transform: uppercase;
    padding-left: 0;
    padding-top: 0;

}



/* Infos Card Chambre Check Section */

.infos-card-chambre-check {

    display: flex;

    border: solid 1.5px rgba(214, 214, 214, 1) !important;





}





.nb-personne {

    display: flex;

    justify-content: space-between;

}



.nb-personne p span::before {

    font-size: 34px !important;

    color: #484848 !important;

}



.chekout-btn {

    display: flex;

    flex-direction: column;

    justify-content: space-between;

    align-items: end;

}



.chekout-btn div {

    text-align: right;

}





.badget-prix {

    background-color: var(--color-primary) !important;

    padding: 20px 10px;

    text-align: center;

    border-radius: 0px 0px 8px 8px;

}



.btn-chosir-price {

    padding: 12px 20px;
    position: relative;
    border-radius: 6px;
    bottom: 14px;
    font-size: 14px;
    color: var(--color-primary);
    border: solid 1.5px var(--color-primary);
    background-color: transparent;
    text-transform: none;
    box-shadow: none !important;

}

.btn-chosir-price:hover {
    background-color: var(--color-primary);
    color: white;
}



/* DETAILS CHAMBRES */



.gallery-chambre {

    display: flex;

    justify-content: center;

    align-items: center;

    margin: 5rem 0;

    padding: 0 45px;

}



.gallery-chambre .row {

    display: flex;

    width: 100%;

    gap: 15px;

}



.image-primary,

.image-secondary {

    width: 50%;

}



.image-primary {

    display: flex;

    margin-right: -25px;

}



.image-primary img {

    width: 100%;

    height: auto;

    border-radius: 16px;

}



.image-secondary {

    display: flex;

    flex-wrap: wrap;

    justify-content: space-between;

    align-content: flex-start;

}



.image-secondary div {

    position: relative;

    margin-bottom: 15px;

}



.image-secondary img {

    width: 96%;

    height: auto;

    border-radius: 8px;

}



.nombre-image-masque {

    position: absolute;

    bottom: 30%;

    left: 30%;

    color: white;

    padding: 5px 10px;

    border-radius: 5px;

    font-size: 23px;

    font-weight: 500;

    z-index: 1;

}



.nombre-image-masque span {

    font-weight: 800;

}



.dernier-image-secondary::after {

    content: "";

    position: absolute;

    top: 0;

    left: 0;

    width: 96%;

    height: 100%;

    background-color: rgba(0, 0, 0, 0.2);

    border-radius: 8px;

    z-index: 0;

}





.title-infos-chambre {

    font-family: 'Bellefair';

    font-style: normal;

    font-weight: 400;

    font-size: 44px;

    line-height: 50px;

    text-transform: uppercase;

    color: #484848;

}



.all-equipement-infos-chambre div svg {

    width: 45px;

    height: 45px;

}



.equipement-infos-chambre {

    margin: 2rem 0rem;

}



.equipement-infos-chambre span {

    width: 160px;

    padding: 2rem;
    margin: 3px 0px;

    background: rgba(255, 247, 239, 1) !important;

    border-radius: 8px;

    font-family: 'Avenir';

    font-style: normal;

    font-weight: 500;

    font-size: 16px;

    color: #484848;

    box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);

}

.equipement-infos-chambre span svg{
    width: 25px;
    height: 25px;
}




.description-infos-chambre {



    margin: 2rem 0rem !important;


    font-style: normal;

    font-weight: 400;


    line-height: 30px;

    color: #585858;



}



.infos-chambre-details {



    display: flex;

    flex-direction: column;

    align-items: center;

    box-sizing: border-box;

    height: 100%;

    background: #FFFFFF;

    border: 1px solid #D1D1D1;

    border-radius: 10px;



}



.infos-chambre-details h3 {



    margin: 2rem 0rem;

    font-family: 'Avenir';

    font-style: normal;

    font-weight: 800;

    font-size: 28px;

    line-height: 38px;

    text-align: center;

    color: #484848;

}



.btn-booking-infos-chambre {

    padding: 1rem 5rem;

    background: var(--color-primary);

    border-radius: 8px;

    font-family: 'Montserrat';

    font-style: normal;

    font-weight: 700;

    font-size: 15px;

    color: #FFFFFF;



}

.btn-booking-infos-chambre:hover {
    background-color: #c88b51;
    color: white;
}



.infos-chambre-details {



    font-family: 'Avenir';

    font-style: normal;

    font-weight: 900;

    font-size: 15px;

    color: #5E5E5E;

}



@keyframes bounce {

    0% {

        transform: scale(0);

    }



    100% {

        transform: scale(1);

    }

}



.modal-gallerie-chambre {

    display: none;

    padding: 0;

    justify-content: center;

    align-items: center;

    position: fixed;

    top: 0;

    left: 0;

    width: 100%;

    height: 100%;

    background: rgba(0, 0, 0, 0.5);

    z-index: 11111;

}



.modal-gallerie-chambre.active {

    display: flex;

}



.modal-gallerie-chambre .modal-dialog {

    background: white;

    width: 60%;

    max-width: 60rem;

    height: auto;

    max-height: 90%;

    overflow-y: auto;

    animation: bounce 1s forwards;

    box-shadow: 0 0 7px rgb(255 255 255 / 76%);



}



.all-image-galleries {

    display: flex;

    flex-wrap: wrap;

    overflow-y: scroll;

}





.all-image-galleries::-webkit-scrollbar {

    width: 8px;

}



.all-image-galleries::-webkit-scrollbar-track {

    background: transparent;

}



.all-image-galleries::-webkit-scrollbar-thumb {

    background: rgba(0, 0, 0, 0.2);

    border-radius: 10px;

}



.all-image-galleries {

    scrollbar-width: thin;

    scrollbar-color: rgba(0, 0, 0, 0.2) transparent;

}





.all-image-galleries .column {

    flex: 25%;

    max-width: 25%;

    padding: 0 4px;

}



.all-image-galleries .column img {

    margin-top: 8px;

    vertical-align: middle;

    width: 100%;

}



@media screen and (max-width: 800px) {

    .all-image-galleries .column {

        flex: 50%;

        max-width: 50%;

    }

}



@media screen and (max-width: 600px) {

    .all-image-galleries .column {

        flex: 100%;

        max-width: 100%;

    }

}



@keyframes opacity {

    0% {

        opacity: 0;

    }



    100% {

        opacity: 1;

    }

}



.close-galerie {

    position: absolute;

    z-index: 1;

    right: 18%;

    top: 3%;



    background-color: white;

    border-radius: 22px;

    animation: opacity 3.5s;

}









/* Prix Chambres Section */

.prix-chambres {

    display: flex;

    flex-direction: column;

    align-items: center;

    position: relative;

    bottom: 68px;

}



.price-chambre-content {

    width: 100%;

    border: solid 1.5px rgba(214, 214, 214, 1);

    align-items: flex-start;

}



.card-body nav {

    line-height: 6rem;

}




.chambre-infos {

    margin: 3rem 1rem;
    padding: 16px;
    border: solid 1.5px rgba(214, 214, 214, 1);

}

.price-chambre {
    padding-left: 15px;
}


.description-chambre {

    text-align: justify;

}



/* Legacy .room-details styles - now consolidated in reservation-flow.css */



.carousel-chambre {

    border-radius: 15px;

}



/* Breadcrumb Section */



.container-breadcrumb {

    display: flex;

    width: 100% !important;

}



.breadcrumb {

    display: flex;

    overflow: hidden;

    margin: auto;

    text-align: center;

    width: 100%;

    height: 4.25rem;

    z-index: 1;

    background-color: #fffaf5;

    font-size: 14px;

    transition: top 0.3s, box-shadow 0.3s;

    border-radius: 8px 8px 0px 0px;

}



.breadcrumb__title {

    font-size: 16px;

    font-weight: 800;

}



.breadcrumb a {

    position: relative;

    display: flex;

    flex-grow: 1;

    text-decoration: none;

    margin: auto;

    height: 100%;

    padding-left: 1.5rem;

    padding-right: 0;

    color: black;

}



.breadcrumb a:first-child {

    padding-left: 0.6rem;

}



.breadcrumb a:last-child {

    padding-right: 0.6rem;

}



.breadcrumb a:after {

    content: "";

    position: absolute;

    display: inline-block;

    width: 5.25rem;

    height: 5.25rem;

    top: -7px;

    right: -2.333rem;

    background-color: #fffaf5;

    border-top-right-radius: 5px;

    transform: scale(0.707) rotate(45deg);

    box-shadow: 1px -1px rgba(0, 0, 0, 0.25);

    z-index: 1;

}



.breadcrumb a:last-child:after {

    content: none;

}



.breadcrumb__inner {

    display: flex;

    flex-direction: column;

    margin: auto;

    z-index: 2;

}



.breadcrumb a.active {

    background: var(--color-primary);

    color: white;

}

a:not([href]):hover {
    color: initial !important;
}

.breadcrumb a.active:hover {

    color: white !important;

}



.breadcrumb a.active:after {

    color: white;

    background: var(--color-primary);

    border: none;

    box-shadow: none;

}






/* Carousel Images Section */

.chambre .carousel-inner .carousel-item img {

    height: 300px;

    object-fit: cover;

}









/* Gallery Section */
/* 
.gallery {

    width: min(90vw, 550px);

    list-style-type: none;

    display: grid;

    grid-template-columns: repeat(5, 1fr);

    grid-auto-rows: 13vmin;

    gap: 5px;

    padding: 0;

    margin: 0 auto;

}



.gallery .item {

    position: relative;

    overflow: hidden;

    display: flex;

    align-items: center;

    justify-content: center;

}



.gallery .item img {

    width: 100%;

    height: auto;

    object-fit: cover;

}



.gallery .item:hover:not([data-pos="1"]) {

    cursor: pointer;

}



li[data-pos="1"] {

    grid-column: 1 / 6;

    grid-row: 1 / 6;

}



::view-transition-group(*) {

    animation-duration: 0.5s;

    animation-timing-function: ease-in-out;

}

 */

/* Extras Section */



.page-extras {

    display: flex;

    flex-direction: column;

    align-items: center;

    position: relative;

    bottom: 68px;

}



.extras-chambres {

    width: 100%;

}





.extras-chambres .chambre {



    border: solid 1.5px rgb(224, 224, 224) !important;

}


/* Legacy styles - now consolidated in reservation-flow.css */
.list-group-item-extras {
    border: none;
}



.blog-btn-check-extras {

    text-align: right;

}



.btn-check-extras {



    color: white;

    display: flex;

    align-items: center;

    padding: 1rem 2rem;

}



.exclure {

    background-color: #bd1c00;

}



/* Cart Section */

.cart {

    top: 0;

    right: -100%;

    width: 100%;

    overflow-y: auto;

    overflow-x: hidden;

    background-color: transparent;

    z-index: 100;

}



.cart-active {

    right: 0;

    transition: 0.5s;

}



.cart-title {

    text-align: left;

    font-size: 1rem;

    font-weight: 500;

    padding-bottom: 20px;

}



.extras-box {

    display: flex;

    align-items: center;

    justify-content: space-between;

    gap: 1rem;

    margin-top: 1rem;

    border-bottom: 1px solid rgba(0, 0, 0, 0.1);

    padding-bottom: 10px;

}



.cart-img {

    width: 75px;

    height: 75px;

    object-fit: cover;

    border: 2px solid rgba(0, 0, 0, 0.1);

    padding: 5px;

}



.detail-box {

    display: grid;

    row-gap: 0.5rem;

}



.price-box {

    display: flex;

    justify-content: end;

}



.extras-title {

    font-size: 1rem;

    text-transform: uppercase;

    color: var(--color-primary);

    font-weight: 500;

}



.Extras-prix {

    font-weight: 500;

}



.extras-remove::before {

    font-size: 24px;

    color: red;

    cursor: pointer;

}



.total {

    display: flex;

    justify-content: flex-end;

    margin-top: 1.5rem;

}



.total-title {

    font-size: 1rem;

    font-weight: 600;

}



.total-price {

    margin-left: 0.5rem;

}



.btn-buy {

    padding: 12px 20px;

    background-color: #2f3542;

    color: #fff;

    border: none;

    font-size: 1rem;

    font-weight: 500;

    cursor: pointer;

}



#cart-close {

    position: absolute;

    top: 1rem;

    right: 0.8rem;

    font-size: 2rem;

    cursor: pointer;

}



/* Checkout Reservation */



.title-infos-client {

    font-family: 'Avenir';

    font-size: 24px;

    font-weight: 800;

    position: relative;

    display: inline-block;

}



.title-infos-client::after {

    content: '';

    position: absolute;

    bottom: -4px;

    left: 0;

    width: 50%;

    height: 2px;

    background-color: var(--color-primary);

}



.checkout-reservation {

    display: flex;

    flex-direction: column;

    align-items: center;

    position: relative;

    bottom: 64px;

}



.checkout-reservation-content {

    display: flex;

    flex-wrap: wrap;

    width: 100%;

    padding: 1rem 0rem;

}



.form-client form {

    border: solid 1.5px rgba(214, 214, 214, 1);

    background-color: white;

    padding: 20px;

    width: 100%;

    margin-bottom: 20px;

}





.form-contact .form-control {

    border-radius: 5px;
    padding: 10px;
}

.contact-infos {
    font-family: "avenir", sans-serif !important;
}



.payment-methods .category {

    margin-top: 20px;

}



.payment-methods label {

    padding: 10px;

    border-radius: 5px;

    margin-bottom: 10px;

    cursor: pointer;

}



.payment-form {

    padding: 20px;

    border-radius: 10px;

    margin-top: 10px;

}



.payment-form .form-label {

    font-weight: bold;

}


/* Legacy .room-details cart styles - consolidated in modern design in reservation-flow.css */
.cart-img {
    height: auto;
}





.payment-form {

    padding: 30px;

    background: #f8f8f8;

    border-radius: 10px;


    margin: 4rem 1rem;

    width: 100%;

}



/* Category Section */

.category label {

    margin: 0.5rem 0rem;

    padding: 10px;

}



/* Payment Checkbox */

.check-payement:checked {

    background-color: var(--color-primary);

    border-color: var(--color-primary);

}



.check-payement:focus {

    border-color: var(--color-primary);

    box-shadow: none !important;

}



.masque {

    position: relative;

    width: 100%;

    height: 350px;

    overflow: hidden;

    margin: 5px;

}



.masque img {

    width: 100%;

    height: 100%;

    object-fit: cover;

}



.carousel-indicators button {

    background-color: #000;

}



.carousel-item {

    height: 280px;

    background-size: cover;

    background-position: center;

}