body{
    font-size: 16px;
    font-family: 'MessinaSans', sans-serif;
    color: #222;
    font-weight: 300;
}

a, button, input, select, textarea{
    text-decoration: none !important;
    outline: none !important;
}
a, button{
    transition: all ease-in-out 300ms;
}

h1, h2, h3, h4, h5, h6{
    font-weight: 700 !important;
}
b, strong{
    font-weight: 700;
}
p{
    font-weight: 300;
}

.back-to-top {
    border-radius: 5px;
    text-align: center;
    background: #000;
    color: #fff;
    display: none;
    width: 40px;
    height: 40px;
    line-height: 40px;
    font-size: 12px;
    position: fixed;
    right: 20px;
    bottom: 20px;
    opacity: 0.4;
    filter: alpha(opacity=40);
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
    cursor: pointer;
    z-index: 9999;
}
.back-to-top i {
    position: relative;
    top: 2px;
}
.back-to-top:hover {
    opacity: 1;
    filter: alpha(opacity=100);
}
.hiding {
    opacity: 0;
}
.visible {
    opacity: 1;
}

.bg-cover{
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}
.banner{
    position: relative;
    min-height: 100vh;
}
.logo{
    display: block;
    max-width: 100%;
    height: auto;
}
video#bgvid {
    width: 100%;
}
.banner.bg-cover img.logo {
    position: absolute;
    top: 55px;
    left: 55px;
}
.banner-btn{
    position: fixed;
    top: 0;
    right: 0;
    padding: 30px;
    display: block;
    background: #9da3a8;
    color: #fff !important;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: 1px;
    z-index: 999999;
}
.notice{
    font-size: 10px;
    position: absolute;
    bottom: 0;
    right: 0;
    padding: 15px;
    line-height: 1.12;
    color: #fff;
}

.intro{
    padding-top: 90px;
    padding-bottom: 90px;
}
.intro h1{
    font-size: 35px;
    font-family: 'Domaine Disp', sans-serif;
    font-weight: normal !important;
    margin-bottom: 15px;
}
.intro h1 strong{
    font-weight: 500 !important;
    color: #808d76;
}

.btn{
    padding: 22px 30px;
    background: #bdb9b6;
    color: #fff !important;
    border-radius: 0;
    line-height: 1.12;
    letter-spacing: 1px;
    box-shadow: none !important;
    font-size: 12px;
}
.sales-link{
    display: inline-block;
    padding: 10px 15px;
    color: #fff !important;
    background: #bdb9b6;
    line-height: 1.12;
    letter-spacing: 1px;
    font-size: 12px;
    margin-left: 5px;
    margin-right: 5px;
}
.sales-link i{
    font-size: 25px;
    margin-right: 5px;
    display: inline-block;
    vertical-align: middle;
}
.sales-link.wa-btn{
    background: #42a837;
}

.separator{
    height: 4px;
    border-top: 1px solid #ebebeb;
    border-bottom: 1px solid #ebebeb;
    margin-top: 40px;
    margin-bottom: 35px;
}
.intro h2{
    font-size: 16px;
    color: #414a33;
    text-transform: uppercase;
}

.area-carousel-wrapper{
    position: relative;
}
.area-carousel img{
    display: block;
    width: 100%;
    height: auto;
}
.area-carousel .caption{
    padding: 30px 170px 30px 70px;
    background: #a6adb2;
    color: #fff;
    font-size: 12px;
    line-height: 1.12;
}
.area-carousel-wrapper .control{
    position: absolute;
    bottom: 24px;
    right: 0;
    width: 170px;
    text-align: center;
    z-index: 9;
}
.area-arrow{
    border: 0;
    background: none;
    padding: 0;
    margin-left: 8px;
    margin-right: 8px;
}
.area-carousel-wrapper .slides-number{
    position: absolute;
    bottom: 27px;
    left: 40px;
    text-align: right;
    z-index: 9;
    font-size: 12px;
    color: #fff;
}

.destination{
    padding-top: 120px;
    padding-bottom: 120px;
    position: relative;
}
.destination h2{
    font-size: 35px;
    font-family: 'Domaine Disp', sans-serif;
    font-weight: normal !important;
    margin-bottom: 50px;
    line-height: 1;
}
.destination h2 span{
    color: #7f8385;
}
.map-wrapper{
    position: static;
}

.aerial{
    padding-top: 50px;
}
.aerial h3{
    font-size: 15px;
    margin-bottom: 20px;
}
.aerial table{
    margin-bottom: 60px;
}
.aerial table tr td{
    padding-right: 15px;
}
.aerial-gallery{
    position: relative;
}
.aerial-gallery img{
    display: block;
    width: 100%;
    height: auto;
}
.aerial-gallery>a:after{
    content: '+';
    display: block;
    width: 50px;
    height: 50px;
    text-align: center;
    line-height: 50px;
    color: #fff;
    font-size: 16px;
    background: rgba(166, 173, 178, 0.75);
    position: absolute;
    bottom: 0;
    right: 0;
}
.direction{
    display: block;
    padding: 30px 15px;
    line-height: 1.12;
    font-family: 'Domaine Disp', sans-serif;
    font-weight: normal;
    font-style: italic;
    border-top: 1px solid #e1e1e1;
    border-bottom: 1px solid #e1e1e1;
    max-width: 280px;
    width: 100%;
    margin-bottom: 30px;
    color: #222224 !important;
}
.direction i{
    margin-left: 15px;
}

.destination-boxes{
    padding-top: 150px;
}
.winter-box, .summer-box{
    padding-left: 15px;
    padding-right: 15px;
}
.winter-box{
    background: #dee3e8;
}
.summer-box{
    background: #e6ead2;
}
.destination-boxes .db-wrapper>div{
    padding-left: 0;
    padding-right: 0;
}
.db-carousel img{
    display: block;
    width: 100%;
    height: auto;
}
.db-wrapper .content{
    padding: 30px;
    text-align: center;
}
.db-wrapper .control{
    padding-top: 20px;
}
.db-wrapper .control>*{
    display: inline-block;
    vertical-align: middle;
    margin-left: 5px;
    margin-right: 5px;
}
.db-wrapper .control .slide-numbers{
    font-size: 12px;
    font-weight: 700;
}
.db-wrapper .control .slide-numbers span{
    padding-left: 2px;
    padding-right: 2px;
}
.db-wrapper .control button{
    padding: 0;
    border: 0;
    background: none;
}
.db-wrapper h4{
    font-family: 'Domaine Disp', sans-serif;
    font-weight: normal !important;
    font-size: 31px;
    margin-bottom: 15px;
}
.img-fw{
    display: block;
    width: 100%;
    height: auto;
}

.design{
    padding-top: 185px;
    padding-bottom: 180px;
    background: #a3a8a9;
    color: #fff;
}
.design-image{
    position: relative;
    margin-bottom: 15px;
}
.design-image img{
    display: block;
    width: 100%;
    height: auto;
}
.design h2{
    font-family: 'Domaine Disp', sans-serif;
    font-weight: normal !important;
    font-size: 35px;
    margin-bottom: 20px;
}

.design-image .control{
    padding-top: 20px;
    text-align: center;
}
.design-image .control>*{
    display: inline-block;
    vertical-align: middle;
    margin-left: 5px;
    margin-right: 5px;
}
.design-image .control .slide-numbers{
    font-size: 12px;
    font-weight: 700;
    color: #000;
}
.design-image .control i{
    font-size: 17px;
}
.design-image .control .slide-numbers span{
    padding-left: 2px;
    padding-right: 2px;
}
.design-image .control button{
    padding: 0;
    border: 0;
    background: none;
}

#footer{
    background: #242424;
    padding-top: 25px;
    padding-bottom: 25px;
    color: #fff;
    font-size: 15px;
}


@media(min-width: 992px){
    .lg-text-right{
        text-align: right;
    }
    .map-image{
        position: absolute;
        top: 20px;
        right: 0;
    }
    .design-image .caption{
        position: absolute;
        top: 0;
        left: -75px;
        transform: rotate(-90deg);
        transform-origin: top right;
    }
}
@media(max-width: 991px){
    .copyright{
        padding-top: 10px;
    }
    .design{
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .destination{
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .destination-boxes{
        padding-top: 60px;
    }
}

@media(min-width: 768px) and (max-width: 1200px){
    .banner{
        min-height: 55vh;
        background-position: center left;
    }
    .logo{
        max-width: 360px;
    }
}

@media(max-width: 767px){
    .banner.bg-cover img.logo {
        position: absolute;
        top: 35px;
        left: 35px;
        width: 80%;
    }
    .banner {
        position: relative;
        min-height: auto;
    }
    .banner-btn{
        padding: 20px;
        top: auto;
        bottom: 45px;
    }
    .area-carousel-wrapper .control{
        width: 100px;
        bottom: 40px;
    }
    .area-carousel-wrapper .control img{
        width: 30px;
    }
    .area-carousel-wrapper .slides-number{
        bottom: 41px;
    }
}
.new-btn {
    margin-bottom: 10px;
}
.new-btn a {
    width: 100%;
    max-width: 185px;
    text-align: center;
    margin-bottom: 10px;
    text-transform: uppercase;
    font-size: 12px;
}
#myModal .modal-content {
    padding: 15px 15px;
}
#myModal button.close {
    text-align: right;
    font-size: 33px;
    margin-bottom: 5px;
}
video#bgvid {
    margin-bottom: -5px !important;
}

body {
    font-size: 16px !important;
    font-family: 'MessinaSans', sans-serif !important;
    color: #222 !important;
    font-weight: 300 !important; 
}