
html, body {
    min-width: 300px;
    font-family: 'Assistant', sans-serif, Arial, Helvetica !important;
    font-weight: 400 !important;
    color: #575757 !important;
    margin: 0;
    padding: 0;
    max-width: 100vw;
}

body {
    max-width: 1800px;
    margin: 0 auto !important;
    padding: 0;
}
body > * {
    max-width: 100vw;
}

body .container {
    padding-left: 25px;
    padding-right: 25px;
}

a {
    color: #0073FF;
}
.text-link {
    font-weight: 700;
    text-decoration: none;
}
.text-link:hover {
    text-decoration: underline;
}
body:not(.home-page) { 
    padding-top: 90px;
}

.hidden {
    display: none;
}

.form-check-input[type=checkbox] {
    border-radius: 0;
    margin-right: 10px;
}
.form-check-input:checked {
    background-color: #0073FF;
    border-color: #0073FF;
}
.form-control {
    color: #575757;
}

.btn.btn-primary {
    background: #00B8FF;
    border: 0;
    padding-top: 13px;
    padding-bottom: 13px;
    font-weight: 700;
    border-radius: 13px;
}
.btn.btn-primary:hover,
.btn.btn-primary:focus {
    background: #0073FF;
}

img {
    max-width: 100%;
    height: auto;
}

h3 {
    font-weight: 700;
    font-size: 44px;
}
h3.small {
    font-size: 26px;
}
h3 span {
    color: #0073FF;
}

.bg-gray {
    background: #FAFAFA;
}

section {
    overflow: hidden;
    padding: 45px 0;
}

.destino {
    margin-bottom: 15px;
    position: relative;
    overflow: hidden;
}
.destino img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    height: 100%;
    width: auto;
    min-width: 100%;
    max-width: 900%;
    z-index: 0;
}
.destino .content {
    position: absolute;
    z-index: 4;
    bottom: 0;
    right: 0;
    background: #FAFAFA;
    width: 80%;
    padding: 15px;
}
.destino h4 {
    font-weight: 700;
    font-size: 24px;
    border-bottom: 1px solid #575757;
}
.destino p {
    font-size: 14px;
}
.destino .go {
    display: block;
    margin: 10px 0 0 auto;
    width: 20px;
    line-height: 1;
    font-size: 18px;
}

.whatsapp-link {
    display: flex;
    position: fixed;
    bottom: 15px;
    right: 30px;
    width: 65px;
    height: 65px;
    background-color: #13bb2d;
    border-radius: 50%;
    line-height: 1;
    color: #fff;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    font-size: 42px;
    z-index: 99999;
}

.regular {
    font-weight: 400 !important;
}
.bold, strong, .strong, b {
    font-weight: 700 !important;
}
.semibold {
    font-weight: 600 !important;
}
.extrabold {
    font-weight: 800 !important;
}

#mainNav {
    padding-top: 0;
    padding-bottom: 0;
    border-bottom: 1px solid #fff;
    position: relative;
    z-index: 100;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
}
#mainNav a.nav-link {
    color: #575757;
    font-weight: 700;
    font-size: 16px;
    letter-spacing: 0;
}
.home-page #mainNav:not(.bg-white):not(.open) a.nav-link {
    color: #fff;
}
#mainNav ul.navbar-nav {
    margin: 0 110px 0 auto;
}
#mainNav .d-flex .btn.btn-primary {
    width: 120px;
    letter-spacing: 0;
}
.navbar-brand {
    padding-top: 0;
    padding-bottom: 0;
}
.navbar-brand img {
    display: block;
    max-width: 200px;
    height: 90px;
}
.navbar-brand img.gray {
    height: 70px;
    margin: 10px 0 10px 20px;
}
.navbar-brand .white {
    display: none;
}
.navbar-toggler {
    border: 0;
    color: #575757;
}
.navbar-toggler:focus {
    box-shadow: none;
}

header {
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    line-height: 1;
    color: #fff;
    height: 330px;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}
header h1 {
    font-weight: 700;
    font-size: 80px;
    text-align: center;
    line-height: 1;
}
.small-header {
    height: 187px;
}
.small-header h1 {
    font-size: 50px;
}

ul.slick-dots {
    position: relative;
    display: flex;
    padding: 0;
    margin: 0 auto;
    width: 95%;
    align-items: center;
    justify-content: center;
    list-style: none;
    z-index: 10;
    margin-top: -30px;
    margin-bottom: 16px;
}
ul.slick-dots li {
    margin: 0 5px;
    padding: 0;
    width: 45px;
    height: 10px;
    border-radius: 10px;
    border: 1px solid #0073FF;
    transition: width ease .2s;
    background-color: #fff;
}
ul.slick-dots li.slick-active {
    width: 69px;
    height: 14px;
    background-color: #0073FF;
}

#mainNav.open {
    border-bottom: 0;
    background: #fff !important;
}
#mainNav .navbar-toggler {
    color: #fff;
}
#mainNav.open .navbar-toggler,
#mainNav.bg-white .navbar-toggler {
    color: #575757;
}

.slick-arrow {
    position: absolute;
    z-index: 20;
    top: calc(50% - 24px);
    line-height: 1;
    width: 21px;
    height: 40px;
}
.slick-arrow.slick-disabled {
    opacity: 0;
}
.slick-prev {
    left: -5%;
}
.slick-next {
    right: -5%;
}

.stars:before,
.stars:after {
    content: '';
    display: inline-block;
    background-size: contain;
    height: 20px;
}
.stars:before {
    background-image: url('../images/icons/star-fill.svg');
    background-repeat: space;
    width: 0;
}
.stars:after {
    background-image: url('../images/icons/star-fill-1.svg');
    background-repeat: space;
    width: 120px;
}
.stars.stars-1:before {
    width: 25px;
}
.stars.stars-1:after {
    width: 97px;
}
.stars.stars-2:before {
    width: 46px;
    margin-right: 2px;
}
.stars.stars-2:after {
    width: 70px;
}
.stars.stars-3:before {
    width: 70px;
    margin-right: 2px;
}
.stars.stars-3:after {
    width: 46px;
}
.stars.stars-4:before {
    width: 97px;
    margin-right: 2px;
}
.stars.stars-4:after {
    width: 25px;
}
.stars.stars-5:before {
    width: 120px;
}
.stars.stars-5:after {
    width: 0;
}

.comment-box {
    background-color: #FAFAFA;
    padding: 35px 20px;
    box-shadow: 0px 3px 0px #d6d6d6;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-end;
}
.comment-box p {
    place-self: flex-start;
    align-self: flex-start;
}
.comment-box .author {
    display: block;
    width: 100%;
    text-align: center;
    color: #0FBFF1;
    font-size: 20px;
    line-height: 1;
    font-weight: 800;
}
.comment-box .stars {
    margin-top: 10px;
}

.home-mapa {
    color: #fff;
    position: relative;
    background-image:url('../images/home/mapa.png');
    background-size: 41%;
    background-repeat: no-repeat;
    background-position: right top;
}
.home-mapa:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: -moz-linear-gradient(90deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 60%, rgba(0,184,255,0) 80%);
    background: -webkit-linear-gradient(90deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 60%, rgba(0,184,255,0) 80%);
    background: linear-gradient(90deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 60%, rgba(0,184,255,0) 80%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#0073ff",endColorstr="#00b8ff",GradientType=1);
}
.home-mapa .container {
    position: relative;
    z-index: 4;
}
.home-mapa h4 {
    font-size: 44px;
    font-weight: 700;
}
.home-mapa p {
    font-size: 32px;
}
.home-mapa .btn.btn-white {
    width: 148px;
    background-color: #fff;
    color: #0073FF;
    padding: 12px 25px;
    border-radius: 13px;
    font-weight: 700;
}

.hoteles-participantes p {
    font-size: 20px;
    margin: 10px 0 30px 0;
    max-width: 450px;
}
.hoteles-participantes .button .btn.btn-primary {
    width: 260px;
}
.hoteles-participantes .left img {
    display: block;
    height: 138px;
}
.hoteles-participantes .right .row {
    height: 100%;
    justify-content: flex-end;
}

.ben {
    background: #FAFAFA;
    border-radius: 10px;
    padding: 10px;
    height: 100%;
    color: #0073FF;
    text-align: center;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    flex-wrap: wrap;
    cursor: pointer;
    transition: background ease .2s;
}
.ben img {
    margin: 2px auto;
    display: block;
    align-self: flex-start;
}
.ben img:not(.blu) {
    display: none;
}
.ben p {
    font-size: 15px;
    font-weight: 700;
    color: #fff;
    width: 100%;
    text-align: center;
    margin: 5px 0;
}
.ben .liine {
    background: #0073FF;
    height: 3px;
    margin: 5px auto 0 auto;
    width: 40px;
    transition: width ease .2s;
}
.ben:not(.open) p {
    color: #575757;
}
.ben:not(.open) p span {
    color: #0073FF;
}
.ben.open {
    background: #0073FF;
}
.ben.open p {
    color: #fff;
}
.ben.open .liine {
    background-color: #fff;
    width: 90%;
}
.ben.open img:not(.blu) {
    display: block;
}
.ben.open img.blu {
    display: none;
}

.image-form-columns h1 {
    font-weight: 700;
    text-align: center;
    font-size: 30px;
    max-width: 353px;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 3px solid #0073FF;
    line-height: 1;
}
.image-form-columns .col-image {
    height: calc(100vh - 187px);
    min-height: 738px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}
.image-form-columns .col-image h2 {
    margin: 0;
    line-height: 1;
    color: #fff;
    width: 100%;
    display: none;
    text-align: center;
    font-size: 35px;
    font-weight: 700;
    max-width: 515px;
}
.image-form-columns form {
    display: block;
    max-width: 350px;
    margin: 20px auto;
}
.image-form-columns form.big,
.image-form-columns form.big h1 {
    max-width: 537px;
}
.image-form-columns label:not(.form-check-label) {
    font-weight: 700;
}
.image-form-columns .pass-olvidada {
    font-size: 14px;
}
.image-form-columns .btn.btn-primary {
    display: block;
    margin: 0 auto;
    width: 200px;
}
.image-form-columns .feedback {
    font-size: 12px;
}

.modal-header {
    border: 0;
    position: relative;
    display: block;
}
.modal-header .modal-title {
    display: block;
    width: 80%;
    text-align: center;
    color: #575757;
    font-weight: 700;
    font-size: 30px;
    margin: 10px auto 0 auto;
    padding-bottom: 10px;
    border-bottom: 3px solid #0073FF;
}
.modal-footer {
    border: 0;
}
.modal-header .btn-close {
    position: absolute;
    right: 15px;
    top: 15px;
}

footer {
    background: #575757 !important;
    color: #fff;
    padding: 0 !important;
}
footer .brand {
    border-bottom: 1px solid #fff;
}
footer .brand img {
    display: block;
    height: 62px;
    margin: 0 auto;
}
footer .legales a {
    color: #fff;
    text-decoration: none;
    display: block;
    margin: 6px 0;
    font-size: 14px;
    font-weight: 700;
}

@media (max-width: 1399px) {
    .ben p {
        font-size: 14px;
    }
}

@media (max-width: 1199px) {
    #mainNav ul.navbar-nav {
        margin: 0 60px 0 auto;
    }
    .home-mapa {
        background-size: 62%;
    }
}
@media (max-width: 991px) {
    body:not(.home-page) {
        padding-top: 66px;
    }

    .navbar-brand img {
        height: 65px;
    }
    .navbar-brand img.gray {
        height: 55px;
        margin: 6px 0 6px 15px;
    }
    #mainNav a.nav-link {
        color: #575757;
    }
    #mainNav ul.navbar-nav {
        margin: 0;
        text-align: center;
    }
    #mainNav .d-flex {
        justify-content: center;
        margin-bottom: 20px;
    }

    header {
        height: 568px;
    }
    header h1 {
        font-size: 49px;
    }

    #conoceSlider {
        width: 85%;
    }

    .clientes-viajaplus-image {
        padding: 0;
    }
    .clientes-viajaplus-image img {
        display: block;
        margin-left: 0;
        width: 100%;
    }
    .clientes-viajaplus {
        padding: 0;
    }
    h3 {
        font-size: 36px;
    }

    .mas-visitados .btn.btn-primary {
        width: 224px;
    }

    .hoteles-participantes p {
        font-size: 16px;
        margin-bottom: 20px;
        max-width: 100%;
    }
    .hoteles-participantes .right {
        margin-bottom: 20px;
    }
    .hoteles-participantes .right img {
        margin-bottom: 10px;
    }
    .hoteles-participantes .button .btn.btn-primary {
        display: block;
        width: 224px;
        margin: 0 auto;
    }

    .beneficios #ben-botones .col-lg-2.col-md-4.col-6 {
        margin-bottom: 15px;
    }

    .image-form-columns form {
        margin-bottom: 40px;
    }
    .image-form-columns .col-image {
        height: auto;
        min-height: 490px;
        padding: 0;
    }
    .image-form-columns .col-image h2 {
        font-size: 20px;
        max-width: 305px;
    }

    .home-mapa {
        background-size: cover;
        background-position: left top;
    }

    .destino img {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        height: auto;
        width: 100%;
    }
    .destino .content {
        position: relative;
        width: 100%;
    }
    .destino h4 {
        font-size: 20px;
    }
    .destino p {
        font-size: 12px;
    }

    .home-mapa h4 {
        font-size: 32px;
    }
    .home-mapa p {
        font-size: 26px;
    }
    .home-mapa .btn.btn-white {
        display: block;
        width: 246px;
        margin: 0 auto 300px auto;
    }
}

@media (max-width: 767px) {
    #sliderDestinos {
        width: 100%;
        margin: 0 auto;
    }
    #sliderDestinos .slick-next,
    #sliderDestinos .slick-prev {
        display: none !important;
    }
    .home-mapa {
        background-position: center bottom;
        background-size: contain;
    }
    .home-mapa:before {
        background: -moz-linear-gradient(180deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 50%, rgba(0,184,255,0) 70%);
        background: -webkit-linear-gradient(180deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 50%, rgba(0,184,255,0) 70%);
        background: linear-gradient(180deg, rgba(0,115,255,1) 0%, rgba(0,184,255,1) 50%, rgba(0,184,255,0) 70%);
        filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#0073ff",endColorstr="#00b8ff",GradientType=1);
    }
}

@media (max-width: 575px) {
    .image-form-columns .col-image {
        margin-left: -13px;
        margin-right: 0;
        width: 100vw;
        max-width: 200%;
    }

    .modal-header .modal-title {
        font-size: 22px;
    }
    .modal-body {
        padding-bottom: 0;
    }
    .modal-body * {
        font-size: 14px;
    }
    .modal-footer .btn.btn-primary {
        font-size: 14px;
    }
}

@media (max-width: 510px) {
    h3 {
        font-size: 28px;
    }
    h3.small {
        font-size: 24px;
    }

    .whatsapp-link {
        width: 55px;
        height: 55px;
        font-size: 36px;
        right: 15px;
    }
}

@media (max-width: 428px) {
    .home-mapa {
        background-size: 140%;
    }
}

@media (max-width: 360px) {
    body .container {
        padding-left: 15px;
        padding-right: 15px;
    }
    .image-form-columns .col-image {
        margin-left: -3px;
    }
}

@media (min-width: 992px) {
    .destino {
        height: 326px;
    }
    .clientes-viajaplus {
        padding: 30px 0;
    }
}
@media (min-width: 1200px) {
    .destino {
        height: 390px;
    }
}
@media (min-width: 1400px) {
    .destino {
        height: 460px;
    }
}
