@font-face {
    font-family: 'NotoSans';
    src: url("/fonts/NotoSans.ttf") format('ttf');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Roboto-italic';
    src: url("../public/fonts/Roboto-Italic.ttf") format('ttf');
    font-weight: normal;
    font-style: italic;
}

body, html{
    scroll-padding-top: 100px;
}

a {
    color: var(--primary-color) !important;
    text-decoration: none !important;
}

h1, h2, h5, p, span {
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

h1 {
    font-weight: 200 !important;
    font-size: 2rem !important;
}

h5 {
    font-size: 1rem !important;
}

.toast-header {
    background-color: var(--primary-color) !important;
    color: white !important;
}

.form-check-input:checked {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;

    &#all-geos{
        border: white solid 2px!important;
    }
}

.form-check-input:focus {
    box-shadow: none !important;
}

.btn-geo {
    color: white !important;

    &.active {
        color: var(--primary-color) !important;
        background-color: white !important;
    }
}

.btn-outline-primary {
    color: var(--primary-color) !important;
    --bs-border-color: var(--primary-color);
}

.btn-check:checked + .btn-outline-primary {
    background-color: var(--primary-color) !important;
    color: white !important;
}

.btn-outline-primary:hover {
    filter: opacity(50%);
}

.btn-outline-dark {
    background-color: white !important;
}

.btn-outline-dark:hover, .btn-outline-dark.active {
    background-color: black !important;
}

.form-range::-webkit-slider-thumb {
    background: var(--primary-color) !important;
}

.form-range:hover::-webkit-slider-thumb {
    background: color-mix(in srgb, var(--primary-color), white 50%) !important;
}

.form-range:focus::-webkit-slider-thumb {
    box-shadow: 0 0 0 8px color-mix(in srgb, var(--primary-color), white 50%) !important;
    outline: solid 2px white;
}

.bg-primary-color {
    background-color: var(--primary-color) !important;
}

.primary-color {
    color: var(--primary-color) !important;
}

.btn-primary, .btn-white {
    border: 1px var(--primary-color) solid !important;
    transition: all .5s ease !important;
}

.btn-primary, .btn-white:hover {
    background-color: var(--primary-color) !important;
    color: white !important;
}

.btn-primary:hover, .btn-white {
    background-color: white !important;
    color: var(--primary-color) !important;
}

.btn-light {
    background-color: white !important;
    border: none !important;
}

.btn-azureva-tablet {
    background-color: var(--primary-color) !important;
    color: white !important;
    border-radius: 0 0 25px 0 !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.btn-azureva, .btn-azureva-invert {
    transition: all .3s ease;
}

.btn-azureva, .btn-azureva-invert:hover {
    background-color: var(--primary-color) !important;
    color: white !important;
    border: 1px var(--primary-color) solid !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.btn-azureva-invert, .btn-azureva:hover {
    background-color: white !important;
    color: var(--primary-color) !important;
    border: 1px var(--primary-color) solid !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.btn-azureva-black {
    background-color: black !important;
    color: white !important;
    border: black 2px solid !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
    transition: all .3s ease;
}

.btn-azureva-black:hover {
    background-color: white !important;
    color: black !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.btn-azureva-gray {
    background-color: var(--gray-color) !important;
    color: white !important;
    border: 1px var(--gray-color) solid !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.btn-azureva-white {
    background-color: white !important;
    color: black !important;
    border-radius: 25px !important;
    padding: .5rem 3rem !important;
    font-family: 'NotoSans', 'Noto Sans', serif !important;
    border: 2px solid black !important;
    transition: all .3s ease;
}

.btn-danger {
    background-color: var(--primary-color) !important;
    border: none !important;
    color: white !important;
}
.btn-close-sidebar .btn-close {
    background-image: none;
    font-size: 50px;
    font-weight: 700;
    color: #3D3D3D !important;
    opacity: 1 !important;
    position: relative;
    width: 60px;
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0;
    filter: none !important;
}

.btn-close-sidebar .btn-close::before {
    content: '×';
    font-size: 50px;
    font-weight: 700;
    color: #3D3D3D !important;
    opacity: 1 !important;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(calc(-50% + 15px), calc(-50% + 10px));
    filter: none !important;
}

.bg-grey-light {
    background-color: var(--gray-light-color) !important;
}

.filter-pill {
    background-color: var(--gray-light-color) !important;
    transition: all ease 0.25s;

    &::after {
        content: "×";
        margin-left: 0.5em;
    }

    &:hover {
        color: white !important;
        background-color: var(--gray-color) !important;
    }
}

.text-gray {
    color: var(--gray-color) !important;
}

.text-gray-light {
    color: var(--gray-light-color) !important;
}

.btn-danger.active {
    background-color: white !important;
    color: var(--primary-color) !important; /* Optionnel : changer aussi la couleur du texte */
}

.ellipsis {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
}

.ellipsis-1 {
    -webkit-line-clamp: 1;
    line-clamp: 1;
}

.ellipsis-2 {
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.ellipsis-3 {
    -webkit-line-clamp: 3;
    line-clamp: 3;
}

.ellipsis-4 {
    -webkit-line-clamp: 4;
    line-clamp: 4;
}

.ellipsis-5 {
    -webkit-line-clamp: 5;
    line-clamp: 5;
}

.grid-7 {
    grid-template-columns: repeat(7, 1fr);
}

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

.grid-3 {
    grid-template-columns: repeat(3, 1fr);
}

.ratio-3x2 {
    aspect-ratio: 3/2;
}

header {
    z-index: 2;

    @media (min-width: 992px) {
        .offcanvas-body {
            height: 100%;
        }
    }

    & > div {
        display: grid;
        grid-template-columns: auto 1fr auto auto;
        z-index: 2;
        font-family: "Noto Sans", sans-serif;
        font-size: 13px;
    }

    .logo {
        height: 2rem;
        object-fit: contain;
    }

    a {
        color: var(--gray-color) !important;
    }

    .navbar-nav:first-of-type .nav-item {
        padding-top: 22px;

        & > a {
            transition: color ease 0.25s;
            text-transform: uppercase;
        }

        &:hover > a {
            color: var(--primary-color) !important;
        }

        svg {
            rotate: -90deg;
        }

        .dropdown-toggle svg {
            rotate: 0deg;
            transition: rotate ease .25s;
        }

        &.dropdown .dropdown-menu {
            &:not(.show) {
                margin-top: 22px !important;
            }

            a {
                color: var(--primary-color) !important;
                font-size: 13px;
                transition: all ease 0.25s;
                padding: 15px;

                &:hover {
                    color: white !important;
                    background-color: var(--gray-color) !important;
                }
            }
        }

        @media (min-width: 992px) {
            &.dropdown:hover .dropdown-menu {
                display: block;
            }
        }

        li:hover a {
            background-color: transparent !important;
            color: var(--primary-color) !important;
        }
    }

    .list-unstyled li > span:first-of-type {
        height: 2em;
        aspect-ratio: 1 / 1;
        display: grid;
        place-items: center;
    }
}

footer {
    #socials {
        a {
            line-height: 1em;
        }

        svg {
            aspect-ratio: 1/1;
        }
    }

    #payments img {
        height: 2em;
    }

    a {
        color: var(--gray-color) !important;

        &:hover {
            color: var(--primary-color) !important;
        }
    }

    summary {
        list-style: none;
        pointer-events: none;
    }
}

#newsletter-form {
    display: grid;
    grid-template-columns: 1fr auto;

    input {
        box-shadow: none !important;
    }
}

/* Home */
#hero {
    display: grid;
    height: 35vh;

    & > * {
        grid-area: 1/1;
        width: 100%;
        height: 100%
    }

    img {
        z-index: -1;
        object-fit: cover;
        height: 35vh;
        filter: brightness(75%);
    }

    h1 {
        font-size: 2.5rem !important;

        span {
            font-weight: 1000;
        }
    }
}

/** search **/
#search-form {
    margin-top: -45px !important;
}

#or {
    right: 0;
    top: 50%;
    transform: translate(50%, -50%);
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    box-shadow: 0 0 10px #00000040;
    z-index: 1;
}

.btn:first-child:active {
    border: none !important;
}

.dropdown-menu {
    width: 550px !important;
}

.search-activity-card {
    aspect-ratio: 1/1;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-size: cover !important;
    background-blend-mode: darken;
    border-radius: 25px !important;
    position: relative !important;
    cursor: pointer;
}

.search-activities:has(input:checked) .search-activity-card {
    outline: solid 5px var(--primary-color);
}

.search-activity-card-text {
    position: absolute !important;
    bottom: 15px !important;
}

#search_participants, #search_children, #search_babies {
    width: 40% !important;
    height: 40px !important;
    padding-left: 18px !important;
}

#search_startDate, #search_endDate, #search_participants, #search_children, #search_babies,
#search_promotion_startDate, #search_promotion_endDate, #search_promotion_participants, #search_promotion_children, #search_promotion_babies {
    border: none !important;
}

.search-date {
    position: relative;
}

.search-date .text-start .bi-arrow-right {
    position: absolute;
    right: -25px;
    top: 50%;
    transform: translateY(-50%);
}

.destination-search {
    position: relative;
}

.destination-search::before {
    content: "Où ?";
    position: absolute;
    top: -20px;
    left: 50px;
    background-color: #fff;
    border: solid 1px var(--primary-color) !important;
    color: var(--primary-color) !important;
    padding: .2rem .7rem;
    border-radius: 20px;
}

.date-arriver {
    position: relative;
    padding-left: 2.5rem !important;
}

.date-arriver::before {
    content: "Quand ?";
    position: absolute;
    top: -24px;
    left: 60px;
    background-color: #fff;
    border: solid 1px var(--primary-color) !important;
    color: var(--primary-color) !important;
    padding: .2rem .7rem;
    border-radius: 20px;
}

.user {
    position: relative;
}

.user::before {
    content: "Qui ?";
    position: absolute;
    top: -20px;
    left: 50px;
    background-color: #fff;
    border: solid 1px var(--primary-color) !important;
    color: var(--primary-color) !important;
    padding: .2rem .7rem;
    border-radius: 20px;
}

/********checkbox/radio button********/
.form-check-input {
    border: solid 1px black !important;
}

.form-check-input:checked {
    background-color: var(--primary-color) !important;
    border: solid 1px var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

/********calendar********/
.flatpickr-day.today {
    border: none;
}

.flatpickr-calendar.open {
    padding: .5rem 0;
}

.btn-decrement, .btn-increment {
    border: 1px solid grey !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
}

#dateOfBirth > div {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.search-label {
    font-family: 'NotoSans', 'Noto Sans', serif !important;
}

.search-sub-label, #search_startDate, #search_endDate {
    font-family: 'NotoSans', 'Noto Sans', serif !important;
    font-weight: 200 !important;
    font-size: 13px !important;
    margin-top: 3px !important;
    margin-bottom: 0 !important;
    color: black !important;
}

#search_startDate::placeholder, #search_endDate::placeholder {
    color: gray !important;
    opacity: 1 !important;
}

.list-geo {
    background-color: var(--primary-color) !important;
    color: white !important;
}

.date-depart {
    padding-left: 2.5rem !important;
}

/* New Search */
.vr-text {
    position: relative;
    opacity: 1 !important;
    background-color: rgba(33, 37, 41, 0.25) !important;

    span {
        display: block;
        background-color: white;
        color: var(--primary-color) !important;
        position: absolute;

        top: 50%;
        right: 0;
        translate: 50% -50%;
    }
}

#thematics {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    @media (max-width: 767px) {
        grid-template-columns: 1fr 1fr;
    }
    max-width: 87vw;

    & > * {
        aspect-ratio: 1/1;
        background-position: center;
        background-size: cover;
        background-blend-mode: darken;
        cursor: pointer;

        &:has(input:checked) {
            outline: solid 5px var(--primary-color);
        }
    }
}

#dates-block > div {
    position: relative;

    &::after {
        content: "→";
        position: absolute;
        top: 50%;
        left: 40%;
        translate: -50% -50%;
    }

    @media (min-width: 768px) {
        &::after {
            left: 45%;
        }
    }

    @media (min-width: 992px) {
        &::after {
            left: 40%;
        }
    }
}

.rounded-else-3 {
    border-radius: var(--bs-border-radius-lg)!important;
}
.rounded-else-end-3{
    border-top-right-radius: var(--bs-border-radius-lg)!important;
    border-bottom-right-radius: var(--bs-border-radius-lg)!important;
}
.rounded-else-end-pill{
    border-top-right-radius: var(--bs-border-radius-pill)!important;
    border-bottom-right-radius: var(--bs-border-radius-pill)!important;
}
.rounded-else-5{
    border-radius:var(--bs-border-radius-xxl)!important;
}
@media (min-width:768px) {
    .rounded-md-end-0{
        border-top-right-radius: 0!important;
        border-bottom-right-radius: 0!important;
    }
}
@media (min-width:992px) {
    .rounded-lg-pill{
        border-radius:var(--bs-border-radius-pill)!important;
    }
}
@media (max-width: 767px) {
    .rounded-sm-bottom-0{
        border-bottom-left-radius: 0!important;
        border-bottom-right-radius: 0!important;
    }
}


/** Destination listing **/
#destination-row {
    height: 100vh;
    overflow-y: scroll;

    & > div {
        display: grid;
        grid-template-columns: repeat(3, 1fr);

        & > * {
            height: 100%;

            & > a {
                color: black !important;
            }
        }
    }
}

/* Tooltip to show all equipments */
.tooltip-equipment {
    display: none !important;
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    max-width: 200px;
    border-radius: 12px !important;

    li {
        line-height: 14px;
    }

    & + small {
        cursor: pointer;
    }

    &:has(+ small:hover) {
        display: flex !important;
    }
}

/** Include icon heat **/
.icon-heart {
    width: 30px;
}

.icon-heart:hover {
    cursor: pointer;
}

/* Equipments */
#equipments-tab-pane.active {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

/* Filter close button */
li:has(#close-tab) {
    translate: -54px;
    z-index: -1;
    transition: translate .25s ease;
}

ul:has(button.active:not(#close-tab)) li:has(#close-tab) {
    translate: 0;
    z-index: 0;
}

#close-tab {
    display: grid;
    place-items: center;
    padding: 0;
    border: none;
    outline: none;
    background-color: transparent;
    height: 100%;
    aspect-ratio: 1/1;
}

/*****steptwo*****/
.card-option {
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.bandeau-infos-top {
    border-top-right-radius: 2rem;
    border-top-left-radius: 2rem;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
}

.footer-card-result {
    border-bottom-right-radius: 2rem;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.img-destination-result {
    border-bottom-left-radius: 2rem;
    border-top-left-radius: 2rem;
}

/***step Three form***/
#informations-container .nav-link.active {
    color: var(--primary-color) !important;
    background-color: transparent !important;
    font-weight: 700 !important;
    transition: all .4s ease-in-out;
}

#informations-container .nav-link:hover {
    color: var(--primary-color) !important;
    transition: all .4s ease-in-out;
}

#informations-container .nav-tabs, #informations-container .nav-link {
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    font-weight: 400 !important;
}

#informations-container .nav-link {
    border-bottom: solid 1px #EAEAEA;
    position: relative;
}

#informations-container .nav-link::before {
    position: absolute;
    content: "";
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    background-color: var(--primary-color) !important;
    height: 5px;
    width: 0%;
    opacity: 0;
    transition: all .4s ease-in-out;
}

#informations-container .nav-link:hover::before {
    width: 100%;
    opacity: 1;
    transition: all .4s ease-in-out;
}

#informations-container .nav-link.active::before {
    width: 80%;
    opacity: 1;
}

#informations-container ul.nav-tabs {
    justify-content: center;
    display: flex;
    border-bottom: 0;
}

#informations-container input:focus:user-invalid {
    border-color: red;
}

.modal-accomodation .modal-content {
    padding: 5rem;
}

.modal-accomodation .modal-content .content-img-destination img {
    height: 100%;
}

.div-img-title-card .overlay {
    border-bottom-left-radius: 2rem;
    border-top-left-radius: 2rem;
}

.card-account {
    border-radius: 2rem !important;
}

.card-account .div-img-title-card .card-img-top, .card-account .div-img-title-card .overlay {
    border-top-left-radius: 2rem;
    border-top-right-radius: 2rem;
    border-bottom-left-radius: 0;
}

.card-account #destination-name-card-cart {
    width: 100%;
}

.favorite-account {
    border-radius: 2rem;
}

.destination-search .dropdown-menu .list-geo .geo button {
    padding-right: 3rem;
}

#speed-login .modal-dialog .modal-content .modal-body label {
    text-align: left;
    width: 100%;
}

#speed-login .modal-dialog .modal-content .modal-body #login_form h1 {
    text-align: left;
}

#speed-login .modal-dialog .modal-content .modal-body p.text-gray {
    text-align: center;
}

.leaflet-popup-content-wrapper {
    background: transparent;
    box-shadow: 0 3px 14px rgba(0, 0, 0, .2);
}

.dropdown-menu {
    z-index: 1 !important;
}

.btn-search .btn:hover {
    background-color: var(--primary-color) !important;
}

#map {
    z-index: 1;
}

.content-date-price .price {
    font-size: 2rem !important;
}

.modal-fullscreen .img-destination-result-modal {
    object-fit: cover;
}

.btn-azureva-white {
    cursor: pointer;
}

.btn-azureva-white:hover {
    color: #fff !important;
    background-color: #000 !important;
}

.modal-fullscreen .modal-content {
    padding: 1rem 4rem;
}

@media (max-width: 767.98px) {
    .modal-fullscreen .modal-content {
        padding: 1rem;
    }

    #other-destination .col-1 {
        padding: 0 2px;
    }

    .user-form-edit > .row > .col-12 h2 {
        text-align: center;
        margin-top: 1rem;
    }

    #map {
        height: 70vh !important;
    }

    #speed-login .modal-dialog .modal-content .modal-body p.text-gray {
        padding: 0 1.5rem;
    }

    /****popup map****/
    .leaflet-popup-content-wrapper {
        box-shadow: none;
    }

    .leaflet-popup-content {
        width: 100% !important;
    }

    .leaflet-popup-content .price {
        font-size: 1.8rem !important;
    }

    .leaflet-popup-content .card > span {
        width: 30px !important;
    }

    .leaflet-container a.leaflet-popup-close-button {
        top: 2px;
        right: 8px;
    }

    .img-stay {
        width: 100% !important;
        height: 200px !important;
        margin-bottom: 1rem;
    }

    .date-arriver .search-date {
        padding-left: 0.8rem;
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
        position: relative;
    }

    .date-arriver .search-date::before {
        content: "";
        position: absolute;
        right: 10px;
        top: 10px;
        height: 70%;
        background-color: #a8a8a8;
        width: 1px;
    }

    .date-depart .search-date {
        padding-left: 0.8rem;
        border-top-right-radius: 5px;
        border-bottom-right-radius: 5px;
    }

    .footer-card-tablet {
        display: none;
    }

    .activities .dropdown-menu, .user .dropdown-menu {
        transform: translate3d(0px, 27.6667px, 0px) !important;
    }

    .services .dropdown-menu {
        transform: translate3d(0px, 27.6667px, 0px) !important;
    }

    .activities .dropdown-menu h3 {
        font-size: 18px;
    }

    .activities .dropdown-menu::before, .user .dropdown-menu::before, .services .dropdown-menu::before {
        content: "";
        position: absolute;
        display: inline-block;
        width: 0;
        height: 0;
        border-style: solid;
        left: 50%;
        top: -17px;
        transform: translateX(-50%);
        border-width: 0px 10px 17.3px 10px;
        border-color: transparent transparent #c3c3c3 transparent;
    }

    .user .dropdown-menu, .services .dropdown-menu {
        width: 100% !important;
    }

    .search-activity-card {
        background-size: cover !important;
        width: 100% !important;
        height: 130px !important;
    }

    .search-date .text-start .bi-arrow-right {
        display: none;
    }

    .heart {
        margin-top: 10px;
    }

    .img-destination-result {
        height: 200px;
        object-fit: cover;
    }

    .content-date-price .btn-azureva {
        width: 70%;
        margin: 0 auto;
    }

    .person, .bedroom, .superficie {
        font-size: 14px;
    }

    .content-img-destination {
        height: 250px;
    }

    .content-img-destination img {
        object-fit: cover;
    }

    .bandeau-infos-top {
        border-top-right-radius: 0;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .footer-card-result {
        border-bottom-left-radius: 2rem;
        border-top-left-radius: 0;
        border-bottom-right-radius: 2rem;
    }

    .img-destination-result {
        border-bottom-left-radius: 0;
        border-top-left-radius: 2rem;
        border-top-right-radius: 2rem;
    }

    .filter-list .btn-dark {
        width: 100%;
    }

    .content-search {
        border-radius: 10px !important;
        padding-bottom: 1rem;
    }

    .activities, .date-depart, .date-arriver, .services, .user, .destination-search {
        padding-top: .5rem !important;
        padding-bottom: .5rem !important;
    }

    .btn-search {
        background-color: transparent !important;
        margin-bottom: 1rem;
        border-bottom-right-radius: 20px !important;
        border-top-right-radius: 20px !important;
        border-radius: 20px;
        margin-top: -88px !important;
        margin-left: auto;
        margin-right: auto;
    }

    .date-arriver {
        padding-left: 1.5rem !important;
    }

    .btn-search .btn {
        background-color: var(--primary-color);
        border-radius: 22px;
        width: 95% !important;
        margin: 0 auto;
    }

    .content-search .dropdown .btn-light {
        background-color: #ededed !important;
        width: 100% !important;
        padding: .5rem;
    }

    .content-search .dropdown img {
        width: 60% !important;
        margin: 0 auto !important;
    }

    .user::before, .date-arriver::before, .destination-search::before {
        display: none;
    }

    .content-search .border-end {
        border-right: none !important;
    }

    .date-arriver {
        padding-right: 0 !important;
    }

    .date-arriver .search-date, .date-depart .search-date {
        background-color: #ededed;
        padding: .5rem 0 .5rem .3rem;
    }

    .date-arriver .search-date img, .date-depart .search-date img {
        height: 40px;
    }

    .date-arriver .search-date input, .date-depart .search-date input {
        background-color: transparent;
    }

    .date-depart {
        padding-left: 1.5rem !important;
        padding-right: 0 !important;
    }

    .content-search {
        background-color: transparent !important;
        box-shadow: none !important;
    }

    .content-search .wrapper-search {
        background-color: #fff;
        border-radius: 8px;
        padding-bottom: 4rem;
        box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    }

    .icon-geo {
        display: none;
    }

    /*******stepone******/
    .select-logement .form-bg {
        width: 100%;
    }

    .more-detail {
        width: 100%;
    }

    #btn-description-hidden {
        width: 100%;
    }

    /*******steptwo******/
    .option-logement .infos-option img {
        width: 60px;
        margin: 0 auto 15px auto;
    }

    .card-option {
        box-shadow: none !important;
        border: solid 1px #c5c5c5;
    }

    /*****Stepthree*****/
    .form_account div {
        padding-right: 0;
    }

    .btn-azureva {
        width: 100%;
        text-align: center;
    }

    #login_form {
        margin-top: 1rem;
    }

    .modal-accomodation .modal-content {
        padding: 1rem;
    }

    .destination-search .dropdown-menu {
        width: 100% !important;
        transform: translate3d(0px, 31.6667px, 0px) !important;
        position: relative;
    }

    .destination-search .dropdown-menu .list-geo, .destination-search .dropdown-menu .geos-container {
        width: 50%;
    }

    .destination-search .dropdown-menu .list-geo .geo button {
        font-size: 14px;
        padding: 5px;
        padding-right: 4rem;
    }

    .destination-search .dropdown-menu .list-geo .form-check {
        font-size: 13px;
        padding-left: 1.2rem;
    }

    .destination-search .dropdown-menu .geos-container .geo label {
        font-size: 13px;
    }

    .destination-search .dropdown-menu::before {
        content: "";
        position: absolute;
        display: inline-block;
        width: 0;
        height: 0;
        border-style: solid;
        left: 50%;
        top: -17px;
        transform: translateX(-50%);
        border-width: 0px 10px 17.3px 10px;
        border-color: transparent transparent #f93c64 transparent;
    }

    .flatpickr-calendar {
        left: 12px !important;
        width: 94% !important;
    }

    .flatpickr-rContainer {
        margin: 0 auto;
    }

    /***modal-partir fast***/
    #nextWeekModal .modal-dialog .modal-content .modal-body input {
        text-align: center;
    }

    .next-week button {
        width: 94%;
        text-align: center;
    }

    /** Destination listing **/
    #destination-row {
        height: fit-content;

        & > div {
            width: max-content;
            display: flex;
            flex-wrap: nowrap;
            padding-bottom: 16px;

            & > * {
                width: 90vw;
            }
        }
    }

    /***Account***/
    .nav-account .nav-link {
        width: 16%;
        display: flex;
        align-items: center;
        justify-content: center;
        background-color: transparent !important;
    }

    .nav-account .nav-link .icon-tabs-account {
        padding-right: 5px;
        padding-left: 5px;
        width: 60px;
        margin: 0 auto;
    }

    .nav-account .nav-link p {
        display: none;
    }

    #img-connexion {
        height: 200px !important;
    }

    .div-img-title-card {
        height: 200px !important;
        width: 100%;
    }

    .div-img-title-card img {
        height: 200px !important;
        width: 100%;
        object-fit: cover;
    }

    .img-account-cart {
        height: 200px;
    }

    .div-img-title-card .img-destination-result {
        border-bottom-left-radius: 0;
        border-top-left-radius: 2rem;
        border-top-right-radius: 2rem;
    }

    .overlay {
        border-bottom-left-radius: 0;
        border-top-left-radius: 2rem;
        border-top-right-radius: 2rem;
    }

    .card {
        border-bottom-left-radius: 2rem !important;
        border-top-left-radius: 2rem !important;
        border-bottom-right-radius: 2rem !important;
        border-top-right-radius: 2rem !important;
    }

    #destination-name-card-cart {
        bottom: 70px !important;
    }

    .row-listing-housing-category-cart {
        height: auto !important;
        overflow-y: inherit !important;
    }

    .invalid-tooltip {
        position: inherit !important;
    }

    .destination-search .dropdown-menu .list-geo .geo button {
        padding-right: 1rem;
    }
}

@media (min-width: 768px) and (max-width: 1199.98px) {
    .modal-fullscreen .modal-content {
        padding: 1rem 2rem;
    }

    .destination-search::before, .date-arriver::before, .user::before {
        display: none;
    }

    .date-depart, .date-arriver {
        padding-left: 2rem !important;
    }

    .activities {
        border-right: none !important;
    }

    .main-content-search {
        border-radius: 30px !important;
    }

    .img-stay {
        width: 100% !important;
    }

    .btn-search {
        border-top-right-radius: 0px !important;
        border-bottom-left-radius: 30px !important;
        border-bottom-right-radius: 30px !important;
    }

    .div-img-title-card {
        height: 200px !important;
        width: 100%;
    }

    .div-img-title-card img {
        height: 200px !important;
        width: 100%;
        object-fit: cover;
    }

    .img-account-cart {
        height: 200px;
    }

    /** Destinations listing **/
    #destination-row > div {
        grid-template-columns: repeat(2, 1fr);
    }

    #destination-name-card-cart {
        bottom: 70px !important;
    }

    .modal-accomodation .modal-content {
        padding: 7rem 3rem 3rem 3rem;
    }

    .nav-account .nav-link p {
        font-size: 14px;
    }

    .account-nav .container {
        max-width: 98%;
    }

    .div-img-title-card .img-destination-result {
        border-bottom-left-radius: 0;
        border-top-left-radius: 2rem;
        border-top-right-radius: 2rem;
    }

    .overlay {
        border-bottom-left-radius: 0;
        border-top-left-radius: 2rem;
        border-top-right-radius: 2rem;
    }

    .card {
        border-bottom-left-radius: 2rem !important;
        border-top-left-radius: 2rem !important;
        border-bottom-right-radius: 2rem !important;
        border-top-right-radius: 2rem !important;
    }

    #img-connexion {
        height: 400px !important;
    }

    .services {
        padding-right: 0 !important;
    }

    .favorite-account img {
        height: 100% !important;
    }
}

.main-content-search {
    border-radius: 50px;
}

.main-content-search .activities {
    border-right: solid 1px #dee2e6;
}

.btn-search {
    border-top-right-radius: 50px;
    border-bottom-right-radius: 50px;
}

/******reassurance******/
.reassurance {
    background-color: #F0F0F0;

    * {
        font-size: 13px !important;
    }

    .picto {
        height: 60px;
        width: 60px;
    }
}

/** input / Radio button / Checkbox **/
.form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    /*border-color: #c82a4c;*/
}

.flatpickr-day.today:hover, .flatpickr-day.today:focus {
    border-color: var(--primary-color) !important;
    background: var(--primary-color) !important;
}

.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange, .flatpickr-day.selected.inRange, .flatpickr-day.startRange.inRange, .flatpickr-day.endRange.inRange, .flatpickr-day.selected:focus, .flatpickr-day.startRange:focus, .flatpickr-day.endRange:focus, .flatpickr-day.selected:hover, .flatpickr-day.startRange:hover, .flatpickr-day.endRange:hover, .flatpickr-day.selected.prevMonthDay, .flatpickr-day.startRange.prevMonthDay, .flatpickr-day.endRange.prevMonthDay, .flatpickr-day.selected.nextMonthDay, .flatpickr-day.startRange.nextMonthDay, .flatpickr-day.endRange.nextMonthDay {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
}

.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
    -webkit-box-shadow: -10px 0 0 #f4f4f4 !important;
    box-shadow: -10px 0 0 #f4f4f4 !important;
}

form[name="user"] {
    .form-control, .form-select{
        &:focus {
            box-shadow: none!important;

            &:user-invalid {
                box-shadow: 0 0 0 5px var(--transparent-primary-color)!important;
            }
        }

        &:valid {
            border-color: yellowgreen;
        }
    }
}


#user_civility {
    padding-top: 2px;
    padding-inline: 5px;
    border-radius: 50em;

    &:has(*:focus:user-invalid) {
        box-shadow: 0 0 0 5px var(--transparent-primary-color)!important;
    }
}

/** Results destinations **/
.header {
    height: 200px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.img-destination-result {
    overflow: hidden;

    img {
        object-fit: cover;
    }
}

.price {
    line-height: .75em;
    font-size: 2.3rem !important;
}

.sub-label-price-card-result {
    font-size: .8rem;
    font-family: 'NotoSans', 'Noto Sans', serif;
}

.formule {
    font-size: .7rem;
}

.footer-card-result {
    background: linear-gradient(to right, white 75%, var(--gray-light-color) 100%);
    font-size: .9rem;
    font-weight: 200;

}

.description-card-search {
    font-size: .9rem;
}

/** show destination **/
.icon-star {
    width: 37px;
}

.carousel-item img {
    object-fit: cover;
}

/** Housing category description **/
.icon-housing-category {
    width: 35px;
}

.old-price {
    text-decoration: line-through;
}

.housing-category-bg {
    background-color: #f5f4f0;
    min-height: 465px;
}

.icon-housing-category-description {
    width: 14%;
}

/** cart step one **/
.row-listing-housing-category-cart {
    height: 90vh;
    overflow-y: scroll;
}

.title-cart-housing-category {
    font-size: 1.5rem !important;
}

.img-stay {
    object-fit: cover;
    object-position: center;
    width: 330px;
    height: 330px;
}

.cart-housing-category-description {
    font-size: .8rem !important;
}

.price-cart {
    font-size: 1.6rem !important;
}

.date-housing-category-cart {
    font-size: .8rem !important;
}

.form-bg {
    background-color: #f5f4f0;
}

/** cart **/
.container-cart {
    margin-top: 80px;
}

.div-img-title-card {
    position: relative;
    width: 100%;
    z-index: 1;
    height: auto;
}

.card-img-top {
    width: 100%;
    height: 100px;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.4);
    z-index: 5;
}

#destination-name-card-cart {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    z-index: 10;
    text-align: center;
}

.destination-name-cart, .geo-name-cart {
    margin: 0;
    font-size: 1.2rem;
    font-weight: bold;
}

.geo-name-cart {
    font-size: 1rem;
}

/** cart options **/
.card-option {
    min-height: 200px;
}

.price-option strong {
    font-size: 1.4rem;
}

.price-option small {
    display: block;
}

.check-label-option {
    display: inline-block;
    max-width: 90%;
    overflow-wrap: break-word;
    word-wrap: break-word;
    white-space: normal;
}

.checkbox-option-card {
    margin-top: 12px !important;
}

.add-option-unite {
    width: 36px !important;
    height: 40px !important;
    padding-left: 15px !important;
}

.text-date-option-cart {
    font-size: 10px;
    text-decoration: underline;
    cursor: pointer;
}

.row-border-button {
    border-bottom: 2px solid black;
}

/** cart payment  **/
#listing-payments .accordion-header {
    border: 1px solid #f3f2f2 !important;
}

#listing-payments .accordion-button::after {
    content: none !important;
}

#listing-payments .accordion-button:not(.collapsed) {
    background-color: white !important;
}

#listing-payments button:focus:not(:focus-visible) {
    border: none !important;
    box-shadow: none !important;
}

#listing-payments .accordion-body {
    display: flex;
    gap: 10px;
    justify-content: center;
}

#listing-payments .accordion-body > div {
    display: inline-flex;
}

#listing-payments .accordion-body button.button-link-logo span {
    margin-left: 8px;
}

#listing-payments .accordion-body button.button-link-logo span {
    margin-left: 8px;
}

#listing-payments .accordion-body button.button-link-logo {
    height: 7.4rem;
    margin: 1rem;
    width: 13rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px;
    font-size: 14px;
    cursor: pointer;
    background-color: white;
    border: 1px solid #f3f2f2;
    border-radius: 25px;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);;
}

#listing-payments .accordion-body button.button-link-logo figure {
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 65px;
    height: 40px;
    display: block;
    margin-bottom: 5px;
}

#listing-payments .CB figure {
    background-image: url("/images/cb.png");
}

#listing-payments .AMEX figure {
    background-image: url("/images/amex.png");
}

#listing-payments .E_CV figure {
    background-image: url("/images/ancvConnect.png");
}

#listing-payments .accordion-body button.CB.button-link-logo span {
    text-align: center; /* Centre le texte sous l'image */
}

/** User new **/
#user_form input, #user_form select, #login_form input, #login_form select, .form_account input, .form_account select, .form_account .select2-selection {
    padding: 20px 10px;
    width: 100%;
}

.form_account {
    .select2-selection {
        height: fit-content !important;

        .select2-selection__rendered {
            line-height: unset !important;
            padding-left: 0 !important;
        }

        .select2-selection__arrow {
            top: 20px !important;
            right: 10px !important;
        }
    }

    li {
        font-size: 0.75em;

        &::before {
            content: "✓";
            display: grid;
            place-items: center;
            height: 1.5em;
            aspect-ratio: 1/1;
            border-width: 1px;
            border-style: solid;
            border-radius: 100%;
            color: white;
        }

        &:not(.valid) {
            color: var(--gray-color);

            &::before {
                border-color: var(--gray-color);
            }
        }

        &.valid {
            color: limegreen;

            &::before {
                border-color: limegreen;
                background-color: limegreen;
            }
        }
    }
}

#img-connexion {
    object-fit: cover;
    object-position: center;
    width: 100%;
    height: 500px;
    /*aspect-ratio: 1/1;*/
    border-radius: 25px;
}

.icons-avantage {
    width: 25px;
    margin-right: 10px;
}

/** Account **/
.nav-link.active {
    color: white !important;
    background-color: var(--primary-color) !important;
    font-weight: 400 !important;
}

.nav-link {
    color: black !important;
    font-weight: 700 !important;
}

.icon-tabs-account {
    padding-right: 15px;
    width: 80px;
}

.nav-pills .nav-link {
    background-color: #FCFCFC;
}

/** account profil edit **/
#personal-information {
    height: 80vh;
    overflow-y: scroll;
}

/** account family **/
#family .form-family {
    display: none;
}

.icon-listing-family {
    width: 20px;
}

/** account reservations **/
.reservation-destination-segment {
    font-size: .8rem;
}

.btn-reservation {
    font-size: .7rem;
}

.img-reservation {
    min-height: 216px;
}

/** Account agreement **/
.account_logo_agreement {
    height: auto !important;
    width: 100% !important;
}

/** Account cart **/
.img-account-cart {
    height: 71vh !important;
    object-fit: cover;
}

#destination-name-card-cart-account {
    top: 40px !important;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    z-index: 10;
    text-align: center;
}

.delete-texte {
    color: black !important;
    text-decoration-line: underline !important;
}

.text-tel {
    font-size: 12px;
}

/** Pub **/
#pub {
    position: fixed;
    bottom: 0;
    width: 100%;

}

#pub .alert {
    /*margin-bottom: 0 !important;*/
}

#promotions > div > div {
    background-size: cover;
    background-position: center;
    min-height: 310px;
    background-blend-mode: darken;
}

@media (max-width: 992px) {
    header {
        font-weight: bold;

        & > div {
            grid-template-columns: auto 1fr auto auto;
        }

        nav {
            grid-row: 1;
            grid-column: unset;
        }

        .navbar-nav:first-of-type .nav-item {
            padding-top: 0;

            & > a {
                font-size: 20px;
                border: none;
                text-transform: none;
                padding: 15px 20px;
                background-color: #F0F0F0;
            }

            &.dropdown .dropdown-menu {
                margin-top: 0 !important;
                position: static;

                a {
                    border: solid #F0F0F0;
                    border-width: 1px 2px;
                    color: var(--gray-color) !important;

                    &:hover {
                        background-color: transparent !important;
                        color: var(--primary-color) !important;
                    }
                }
            }

            .dropdown-toggle {
                &.show {
                    color: var(--primary-color) !important;

                    svg {
                        rotate: 180deg;
                    }
                }

                &:after {
                    display: none;
                }
            }
        }
    }

    footer {
        .logo {
            height: 4em;
        }

        summary {
            pointer-events: unset;
            border-top: 1px black solid;
            border-bottom: 1px black solid;
            list-style-position: inside;

            svg {
                z-index: -1;
                rotate: 0deg;
                transition: all .3s ease;
            }
        }

        details[open] > summary > svg {
            rotate: 180deg;
        }

        details:not(details:first-of-type) > summary {
            margin-top: -1px;
        }
    }

    #newsletter-form .btn-azureva-black {
        font-size: 0.75em;
        padding: 0.5em 1.5em !important;
    }
}

/** modal partner **/
.sub-title-modal-partner {
    font-size: 1rem;
}

.text-modal-partner {
    font-size: .8rem;
}

.promo-date:not(.flatpickr-disabled,.startRange,.endRange,.today) {
    color: blue !important;
}

header {
    z-index: 2 !important;
}

.leaflet-bottom, .leaflet-top {
    position: absolute;
    z-index: 999;
    pointer-events: none;
}

.custom-loader {
    max-height: 80px;
}

.fs-15 {
    font-size: 15px !important;
}

.fs-14 {
    font-size: 14px !important;
}

.fs-13 {
    font-size: 13px !important;
}

.offcanvas-lg{
    max-width: 95% !important;
}