@import 'header.css';
@import "footer.css";


*::before, *::after {
    box-sizing: inherit;
}

:any-link {
    cursor: pointer;
}


* {
    margin: 0;
    padding: 0;
}

body {
    font-family: "Poppins", sans-serif;
    background-color: #fff;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.5;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media (max-width: 767px) {
    body {
        font-size: 12px;
    }
}

*:focus {
    outline: none;
}


a {
    color: #004580;
    font-weight: 500;
    text-decoration: none;
}

.h-100 {
    height: 100%
}

label {
    font-weight: 400;
    font-size: 15px;
}

.form-control {
    height: 42px;
    width: 100%;
    box-shadow: none;
    font-size: 14px;
    font-weight: 400;
    color: #959595;
    padding: 6px 12px 6px 40px;
    line-height: 1.42857143;
    background-color: #fff;
    background-image: none;
    border-radius: 4px;
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    border: 1px solid #ccc;
}

.form-control:focus {
    border-color: #BDE7C3;
    outline: 0;
    box-shadow: none;
}


@media (min-width: 768px) and (max-width: 991px) {
    .form-control {
        width: 100%;
        height: 50px;
        font-size: 14px !important;
    }
}

@media (max-width: 767px) {
    .form-control {
        width: 100%;
        height: 50px;
        font-size: 14px !important;
    }
}


.margin-top-25 {
    margin-top: 25px;
}


.no-margin {
    margin: 0 !important;
}

.no-padding {
    padding: 0 !important;
}

.label-filtre {
    top: 36px;
    position: relative;
    left: 40px;
    z-index: 1;
    font-size: 15px;
    color: #000000;
    font-weight: 500;
}

#number-night .label-filtre {
    left: 10px;
}

#nuitees {
    padding-left: 10px;
}

.input-icon {
    position: relative;
}

.input-icon input {
    position: relative;
    color: #3c3c3c;
    padding-top: 30px;
}

@media (min-width: 768px) and (max-width: 991px) {
    .input-icon:before {
        height: 50px;
        line-height: 50px;
    }
}

@media (max-width: 767px) {
    .input-icon:before {
        height: 50px;
        line-height: 50px;
    }
}

.bg-input {
    background-color: #ffffff !important;
    border-radius: 4px;
    height: 65px;
    border-color: transparent;

}

.scrolltop-btn {
    position: fixed;
    right: 30px;
    bottom: 30px;
    width: 40px;
    height: 40px;
    text-align: center;
    font-size: 18px !important;
    background-color: #F5AF33;
    color: #fff;
    padding: 10px !important;
    z-index: 999;
    display: none;
    border-radius: 4px !important;
}

.scrolltop-btn:hover {
    opacity: .8;
}


.button-banniere::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: #dff1fc36;
    background-position: left center;
    transition-delay: 0.1s;
    transition-timing-function: ease-in-out;
    transition-duration: 0.5s;
    transition-property: all;
    transform-origin: left;
    transform-style: preserve-3d;
    transform: scaleX(0);
    z-index: -1;
}


.button-banniere::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: #074b84;
    transform: scaleY(0);
    transform-style: preserve-3d;
    transition: all 0.6s linear;
    transform-origin: right center;
    z-index: -1;
}

#btnSearch {
    font-weight: 500;
    height: 65px;
    font-size: 18px;
    color: #fff;
    text-transform: uppercase;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 4px;
}

#btnSearch:hover {
    border-radius: 8px 8px 8px 0;
    background: #016628;
    box-shadow: 0 20px 30px rgb(76 175 80 / 31%);

}

.close:hover, .close:focus, .close {
    opacity: 1;
    color: red;
}

#vjs-advanced-search h5 {
    color: var(--color-grey);
}

.btn-demander, .btn-ajouter {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-green);
}

.btn-ajouter {
    color: var(--color-red);
}

.dropdown-menu > .active > a, .dropdown-menu > .active > a:hover, .dropdown-menu > .active > a:focus {
    background-color: #f0fcf3;
    color: #000000;
}

@media (max-width: 767px) {
    .advanced-search .form-group {
        margin-bottom: 13px !important;
    }
    .advanced-search .btn {
        font-weight: 400;
        font-size: 12px;
    }
}


.bootstrap-select {
    width: 100% !important
}

.bootstrap-select .btn.btn-default {
    border: 1px solid #ccc;
    color: #959595;
    font-size: 14px;
    text-transform: none;
    height: 42px;
    background-color: #fff;
    font-weight: 400
}

.bootstrap-select .btn.btn-default:focus, .bootstrap-select .btn.btn-default.focus,
.bootstrap-select .btn.btn-default:hover {
    background-color: #fff
}


@media (min-width: 768px) and (max-width: 991px) {
    .bootstrap-select .btn.btn-default {
        height: 50px;
        font-size: 14px
    }
}

@media (max-width: 767px) {
    .bootstrap-select .btn.btn-default {
        height: 50px;
        font-size: 14px
    }
}

.bootstrap-select > .dropdown-toggle {
    padding: 0 25px 0 15px
}

.bootstrap-select.open .btn.btn-default {
    background-color: #fff;
    box-shadow: none
}

.advanced-search .form-control {
    box-shadow: none;
}

.search-expandable div[class^="col-"] {
    padding-right: 5px;
    padding-left: 5px;
}

.search-expandable .row {
    margin-left: -5px;
    margin-right: -5px;
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
}

.search .typeahead.dropdown-menu > li > a {
    padding: 8px 20px;
    font-size: 15px;
    clear: both;
    font-weight: 500;
    line-height: 1.5;
}

.search-expandable .advanced-search {
    padding: 0 15px 5px;
    width: 100%;
    box-shadow: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);
    border-radius: 8px;
    background-color: #f0fcf3;
    /*  min-height: 106px;*/
}

.fa-trash-alt {
    color: red;
}

.figure-block img {
    width: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    transition: all .5s ease;
}


.item-body p {
    margin: 0;
}


.houzez-taber-wrap .houzez-tabs {
    width: 100%;
    display: flex;
    justify-content: center;
    gap: 15px;
    table-layout: fixed;
    font-size: 0;
    margin: 0 0 20px 0;
}

@media (max-width: 767px) {

    .houzez-taber-wrap .houzez-tabs {
        width: 100%;
        display: flex;
        justify-content: start;
        gap: 15px;
        table-layout: fixed;
        font-size: 0;
        padding: 0 0 20px 0;
        flex-wrap: nowrap;
        overflow-x: auto;
    }
}


.nav-tabs {
    border-bottom: none;
}

.houzez-taber-wrap .houzez-tabs li {
    text-align: center;
    position: relative;
}

.houzez-taber-wrap .houzez-tabs li a {
    display: block;
    background-color: #fff;
}

.houzez-taber-wrap .nav-tabs > li.active > a, .houzez-taber-wrap .nav-tabs > li.active > a:hover, .houzez-taber-wrap .nav-tabs > li.active > a:focus {
    color: #fff;
    border-radius: 4px;
    background-color: var(--color-red);
}

.houzez-taber-wrap .nav-tabs > li > a {
    border-radius: 4px;
    border: 1px solid var(--color-red);
    color: var(--color-red);
    font-size: 15px;
    font-weight: 600;
    white-space: nowrap;
}

.position-relative {
    position: relative;
}

.overflow-hidden {
    overflow: hidden;
}

.houzez-taber-wrap .houzez-tabs li.active:before {
    background-color: transparent;
}

.houzez-taber-body {
    padding: 15px 0;
}

.houzez-taber-body .row {
    margin-left: -5px;
    margin-right: -5px;
}

.houzez-taber-body div[class*="col-"] {
    padding-left: 5px;
    padding-right: 5px;
}


.team-caption-inner {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 1rem;
    border-radius: 0 0 8px 8px;
    z-index: 99;
    background: linear-gradient(to bottom, rgba(0, 59, 149, 0) 0% 5%, rgb(13 104 82 / 89%) 100%);


}

.team-description {
    color: #fff;
    margin: 4px 0 4px;
    font-size: 25px;
    font-weight: 700;
}


.header-media {
    position: relative;
}

.banner-module {
    position: relative;
    padding: 0;
}


#banner-slider {
    margin-bottom: -100px;
}


.text-white {
    color: #fff !important;
}


.sub-heading {
    font-size: 16px;
    line-height: 24px;
    margin: 0;
    font-weight: 300;
    text-transform: inherit;
    text-align: inherit;
}

@media (max-width: 767px) {
    .sub-heading {
        font-size: 14px;
        line-height: 20px;
    }
}

.btn {
    padding: 10px 12px;
    display: inline-block;
    white-space: nowrap;
    vertical-align: middle;
    -ms-touch-action: manipulation;
    touch-action: manipulation;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    background-image: none;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    border-radius: 4px;
    border: none;
    font-size: 14px;
    line-height: 1.42857;
    font-weight: 500;
    text-transform: inherit;
    text-align: center;
    background: var(--color-green);
    color: #fff;
    width: 100%;
    margin: 5px 0;
    position: relative;
}

.btn:hover, .btn:focus {

    background: var(--color-green);
}

.menu-header .py-2 {
    padding: 4px 0;
}

p.descrption {
    font-size: 15px;
    font-weight: 400;
    color: #fff;
    margin: 0;
    line-height: normal;
}

.card-etiquette {
    position: absolute;
    top: 10px;
    left: 0;
    z-index: 5;
}

.card-etiquette .badge {
    background: #F5AF33;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 15px;
}

.owl-dots {
    margin: 0 0 10px 0;
}

#blog-omra .des-omra {
    font-size: 15px;
    line-height: normal;
    margin: 0;
    color: #383838;
    font-weight: 600;
    text-transform: inherit;
    text-align: inherit;
}


.m-0 {
    margin: 0;
}


.mt-4 {
    margin-top: 1.5rem !important;
}

.mb-1 {
    margin-bottom: 0.25rem !important;
}

.justify-content-center {
    -webkit-box-pack: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
}

.d-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
}

.d-flex .col {
    flex: 50%
}

.justify-content-between {
    justify-content: space-between !important;
}

@media (max-width: 767px) {
    .mob-rasion {
        padding: 0 0;
    }
}


.card-img-overlay {
    position: absolute;
    top: 10px;
    right: 10px;
    left: auto;
    padding: 0;
    border-radius: 0;
    z-index: 50000;
}

.card-img-overlay .badge {
    background: var(--color-red);
    padding: 6px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 500;
}

h3 {
    font-size: 20px;
    line-height: 26px;
    margin: 0 0 20px 0;
    font-weight: 500;
    text-transform: inherit;
    text-align: inherit;
}

@media (min-width: 768px) and (max-width: 991px) {
    h3 {
        font-size: 18px;
        line-height: 24px;
        margin-bottom: 15px;
    }
}

@media (max-width: 767px) {
    h3 {
        font-size: 16px;
        line-height: 22px;
        margin-bottom: 10px;
    }
}

.account-action {
    list-style: none;
    margin: 0;
}


section {
    padding: 50px 0;
}

section:nth-child(2n) {
    background-color: #f0fcf3;
}

.bg-cyan {
    background-color: #ffffff !important;
}

.border-right {
    border-right: 1px solid #fff;
}


.bottom-ratings {
    color: #f8b42b;
    display: inline-block;
    overflow: hidden;
    position: relative;
    vertical-align: top;
    font-size: 10px
}

.porperty-item {
    border: 1px solid #C6C6C6;
}

.input-search:before {
    content: "";
    background-image: url(../img/map_icon.svg);
    background-repeat: no-repeat;
    width: 30px;
}

.input-calendar:before {
    content: "";
    background-image: url(../img/calendar_icon.svg);
    background-repeat: no-repeat;
    width: 30px;
}

.input-room:before {
    content: "";
    background-image: url(../img/chambre_icon.svg);
    background-repeat: no-repeat;
    width: 35px;
}

.input-icon:before {
    color: #004580;
    text-align: center;
    height: 43px;
    line-height: 43px;
    position: absolute;
    left: 5px;
    top: 45px;
    z-index: 1;
}

.banner-slider .owl-dots {
    position: absolute;
    left: unset;
    top: 20px;
    right: 20px;
    margin: 0;
    transform: unset;
}

@media only screen and (min-width: 992px) {
    .search-expandable {
        position: relative;
        z-index: 2;
        top: -50px;

    }
}

@media only screen and (max-width: 991.99px) {
    .search-expandable {
        position: relative;
        z-index: 2;
        margin-top: 85px;
    }
}

.section-title {
    color: var(--color-green);
    position: relative;
    font-style: normal;
    font-weight: 600;
    font-size: 32px;
    margin-top: 0;


}

@-webkit-keyframes shine {
    from {
        -webkit-mask-position: 150%;
    }

    to {
        -webkit-mask-position: -50%;
    }
}

.section-title span {
    color: var(--color-red);
    -webkit-text-stroke-width: 0;
    -webkit-text-stroke-color: #ffff;

    -webkit-mask-image: linear-gradient(-75deg, rgb(211 25 25) 25%, #231717 25%, rgb(218 105 60 / 12%) 100%);
    -webkit-mask-size: 200%;
    animation: shine 3s infinite;
    transition: .5s;

    transform: translateY(-107%);

}

.sub-heading {
    color: #3c3c3c;
    margin-top: 4px;
    margin-bottom: 10px;
    font-style: normal;
    font-weight: 400;
    font-size: 16px;
}

.benner-tab {
    position: relative;
    overflow: hidden;
    box-shadow: 0 0 0 0 rgb(0 0 0 / 12%), 3px 3px 8px rgb(0 0 0 / 18%);
}

.banners-mask {
    height: 100%;
    padding: 24px 28px;
    position: absolute;
    text-align: center;
    top: 0;
    right: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-pack: distribute;
    justify-content: space-around
}

.banners-mask::before {
    background-color: #fff;
    content: "";
    height: 100%;
    position: absolute;
    top: 0;
    -webkit-transform: skewX(-13deg);
    transform: skewX(-13deg);
    width: 112%;
    right: -10%
}

.titre-banniere {
    font-weight: 500;
    color: #000000;
    max-width: 156px;
    position: relative
}

.button-banniere {
    background-color: transparent;
    border: 1px solid var(--color-green);
    color: var(--color-green);
    font-size: 16px;
    font-weight: 500;
    padding: 10px 16px;
    position: relative;
    text-transform: uppercase;
    border-radius: 4px;
    display: inline-block;
    vertical-align: middle;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: none !important;


}

.button-banniere:hover {
    /*color: #fff;*/
    border-radius: 8px 8px 8px 0;
    /*background: #016628;*/
    box-shadow: 0 20px 30px rgb(76 175 80 / 31%);
}

.img-banner {
    width: 100%;
    max-height: 150px;
    object-fit: cover;
    border-radius: 4px;
}

@media (max-width: 991px) {
    .section-title {
        font-size: 30px;
    }

    .banners-mask {
        padding: 8px;
    }
}

.team-block {
    position: relative;
    overflow: hidden;
    margin: 10px 0;
    border-radius: 8px;
}


.card-img {
    width: 100%;
    object-fit: cover;
    height: 400px;
    border-radius: 8px;
    transition: all .5s ease;
}

.team-block:hover .card-img {
    transform: scale(1.05);
    border-radius: 8px;
    box-shadow: rgba(0, 0, 0, 0.25) 0 0.0625em 0.0625em, rgba(0, 0, 0, 0.25) 0 0.125em 0.5em, rgba(255, 255, 255, 0.1) 0 0 0 1px inset;
}

.card-title {
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    text-transform: uppercase;
    margin-bottom: 8px;
    z-index: 500000;

}


.padding-15 {
    padding: 10px 20px;
}


#services .box-service {
    padding: 20px
}

#services .icon-service {
    -webkit-transition: all 0.35s;
    transition: all 0.35s;
    border-radius: 50%;
    height: 100px;
    width: 100px;
    justify-content: center;
    display: flex;
    align-items: center;
    position: relative;
    margin: 0 auto;
    background: #e7e4e4;
    z-index: 1;
}

#services .icon-service::before {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: #e7e4e4;
    content: "";
    position: absolute;
    top: -6px;
    left: -6px;
    z-index: -100;
    -webkit-transition: all 0.35s;
    transition: all 0.35s;

}

#services .icon-service::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background-color: #ffffff;
    z-index: -5;
    -webkit-transition: all 0.35s;
    transition: all 0.35s;
}

#services .item-service:hover .icon-service::after, #services .item-service:hover .icon-service::before {
    top: -9px;
    left: -9px;
}

#services .serv h5 {
    font-size: 17px;
    font-weight: 500;
    color: #000000;

}

#services .serv p {
    font-size: 15px;
    font-weight: 400;
    color: #565656;
}


.img-hotel {
    height: 270px !important;
    object-fit: cover;
    /*transition: all 2s cubic-bezier(0.3, 1, 0.35, 1) 0s;*/
    border-radius: 8px 8px 0 0
}

.property-item {
    border-radius: 8px;
    background: #f7f7f7e6;

}
.team-block:hover,
.property-item:hover{

    box-shadow: rgb(0 136 52 / 7%) -10px -10px 0 0;

}
.property-item figure.item-thumb {
    position: relative;
    display: block;
    overflow: hidden;
    border-radius: 8px 8px 0 0
}

.property-item:hover figure.item-thumb img {
    transform: scale(1.05);
}


.property-item:hover .btn.btn-details {
    border-radius: 8px 8px 8px 0;
    background: #016628;
    box-shadow: 0 20px 30px rgb(76 175 80 / 31%);
}

.property-item .item-body {
    padding: 10px 12px 10px 12px;
    display: block;
    width: 100%;
    border-radius: 0 0 8px 8px
}


.item-body .property-title {
    font-size: 18px;
    line-height: 23px;
    margin: 0;
    text-transform: capitalize;
    text-align: inherit;
    color: #000000;
    font-weight: 600;
}

.rating {
    font-size: 13px;
    line-height: 13px;
    margin: 0;
    font-weight: 400;
    text-transform: inherit;
    text-align: left;
    display: inline;
}

.item-body .property-location {
    font-size: 14px;
    margin: 0;
    text-transform: inherit;
    text-align: inherit;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 30px;
    color: #808080;
    font-weight: 400;
}

.item-foot {

    position: relative;
    border-top: 1px solid #E5E4F0;
    display: flex;
    align-items: center;
    justify-content: space-between;


}

.item-foot-left h3 {
    color: var(--color-red);
    font-weight: 700;
    margin: 0;
    font-size: 24px;
}

.item-foot-left {
    padding-top: 5px;
}

.item-foot p {
    font-size: 14px;
    color: #808080;
    font-weight: 400;
    text-transform: inherit;
    text-align: inherit;
}

.item-foot .item-foot-right {
    float: right;
}

.circuits-img {
    height: 300px;
    object-fit: cover;

}


.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 {
    border-radius: 4px;
    background: var(--color-red);
    border-color: var(--color-red);
}

.text-end {
    display: inline-flex;
    justify-content: end;
}

.tab-content {
    display: flex;
    flex-direction: column;
}


.tab-content > .tab-pane {
    display: block !important;
    height: 0;
}


.tab-content > .active {
    display: block !important;
    height: auto;
}


/*owl carousel**/
.owl-theme .owl-nav {
    margin-top: 0;
}

.owl-prev,
.owl-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    padding: 0 !important;
    background: #fff !important;
    width: 50px;
    height: 50px;
    margin: 0 !important;
}

.owl-theme .owl-nav [class*="owl-"]:hover {

    color: var(--color-green);
    border: 1px solid var(--color-green)
}

.owl-prev {
    left: 0
}

.owl-next {
    right: 0
}


.owl-theme .owl-dots .owl-dot.active span, .owl-theme .owl-dots .owl-dot:hover span {

    background: var(--color-green);
}

.owl-theme .owl-dots .owl-dot span {

    width: 15px;
    height: 15px;
    margin: 5px;
}

.padding-carousel {
    padding: 10px 0
}