﻿html {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body {
    font-family: 'Roboto Flex', Arial, serif;
    font-size: 16px;
    line-height: 1.1875;
    font-weight: normal;
    width: 100%;
    min-width: 300px;
    background: white;
    color: black;
    padding: 0;
    margin: 0;
    letter-spacing: 0.02em;
}


*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.clearfix:before,
.clearfix:after {
    display: table;
    content: " ";
}

.clearfix:after {
    clear: both;
}

.icon:before {
    margin: 0;
}

.strong,
strong,
b {
    color: #505050;
    font-weight: bold;
}

a {
    text-decoration: none;
    cursor: pointer;
    color: black;
}

#content a:not(.btn),
.modal-body a:not(.btn) {
    color: #000;
    text-decoration: underline;
}


label i.icon,
a i.icon {
    margin-right: 0.7em;
}

label i.icon-post,
a i.icon-post {
    margin-left: 0.7em;
    margin-right: 0;
}

a.link {
    text-decoration: underline;
}

.c-gray {
    color: #505050
}

.c-orange {
    color: #F16036;
}

.relative {
    position: relative;
}

.nowrap {
    white-space: nowrap;
}

.d-static {
    position: static;
}

.d-fixed {
    position: fixed;
}

.pt5 {
    padding-top: 5px;
}

.pt22 {
    padding-top: 22px !important;
}

.mt4 {
    margin-top: 4px !important;
}

.mt9 {
    margin-top: 9px !important;
}

.mt13 {
    margin-top: 13px !important;
}

.mt20 {
    margin-top: 20px !important;
}

.mt30 {
    margin-top: 30px !important;
}

.mt40 {
    margin-top: 40px !important;
}

.mt50 {
    margin-top: 50px !important;
}

.mr1em {
    margin-right: 1em;
}

.mr10 {
    margin-right: 10px;
}

.mr20 {
    margin-right: 20px;
}

.mb6 {
    margin-bottom: 6px !important;
}

.mb13 {
    margin-bottom: 13px !important;
}

.fw900 {
    font-weight: 900;
}

.fw-bold {
    font-weight: bold;
}

.fw-normal {
    font-weight: normal;
}

.fs14 {
    font-size: 14px;
    line-height: 17px;
}

.fs30 {
    font-size: 30px;
    line-height: 37px;
}

.fs150 {
    font-size: 150%;
    line-height: 1.233333333333333;
}

.red {
    color: #F93943 !important;
}

.border-top {
    border-top: 1px solid #CCCCCC;
}

.w100p {
    width: 100% !important;
}

.relative {
    position: relative;
}

.float-block {
    display: block;
    padding: 10px 12px;
    background: #FFFFFF;
    color: #171725;
    border-radius: 10px;
}


@media (min-width: 576px) {
    .mb13-sm {
        margin-bottom: 13px !important;
    }

    .mb26-sm {
        margin-bottom: 26px !important;
    }

    .mt0-sm {
        margin-top: 0 !important;
    }

    .mt50-sm {
        margin-top: 50px !important;
    }
}

@media (min-width: 768px) {
    .mt0-md {
        margin-top: 0 !important;
    }

    .mt4-md {
        margin-top: 4px !important;
    }

    .mt30-md {
        margin-top: 30px !important;
    }

    .mt55-md {
        margin-top: 55px !important;
    }

    .mt100-md {
        margin-top: 100px !important;
    }

    .mt180-md {
        margin-top: 180px !important;
    }

    .pt6-md {
        padding-top: 6px !important;
    }
}

@media (min-width: 992px) {
    .pt5-lg {
        padding-top: 5px !important;
    }

    .pt22-lg {
        padding-top: 22px !important;
    }

    .mt40-lg {
        margin-top: 40px !important;
    }

    .mt50-lg {
        margin-top: 50px !important;
    }

    .mt60-lg {
        margin-top: 60px !important;
    }

    .mt180-lg {
        margin-top: 180px !important;
    }

    .mt0-lg {
        margin-top: 0px !important;
    }

    .mt9-lg {
        margin-top: 9px !important;
    }

    .mt250-lg {
        margin-top: 250px !important;
    }

    .mb13-lg {
        margin-bottom: 13px !important;
    }
}

@media (min-width: 1300px) {
    .mt0-xl {
        margin-top: 0 !important;
    }

    .mt100-xl {
        margin-top: 100px !important;
    }

    .mt280-xl {
        margin-top: 280px !important;
    }

    .pt22-xl {
        padding-top: 22px !important;
    }
}

.center {
    text-align: center;
}

.right {
    text-align: right;
}

.underline {
    text-decoration: underline;
}

.fright {
    float: right;
}

.smaller {
    font-size: 80%;
}

.nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0;
    margin: 0;
    list-style: none;
}

ul.nav > li {
    margin-right: 2em;
}

    ul.nav > li:last-child {
        margin-right: 0;
    }

    ul.nav > li > a {
        display: inline-block;
    }

.nav-fill {
    justify-content: space-between;
}

ul.nav-fill > li {
    margin-right: 0;
}


@media (min-width: 1300px) {
    .nav-fill-xl {
        justify-content: space-between;
    }

    ul.nav-fill-xl > li {
        margin-right: 0;
    }
}

.btn {
    display: inline-block;
    font-weight: 600;
    font-size: 12px;
    line-height: 40px;
    height: 40px;
    width: 190px;
    text-align: center;
    vertical-align: middle;
    background: #000;
    /*! border: 2px solid #BDC6CB; */
    color: #FFF;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 200ms ease-in-out;
    -ms-transition: all 200ms ease-in-out;
    transition: all 200ms ease-in-out;
    font-family: 'Roboto Flex', Arial, serif;
    border-radius: 6px;
}

.btn-auto-width {
    width: auto;
    padding-left: 10px;
    padding-right: 10px;
}

.btn:not(span):hover {
    box-shadow: 0px 10px 20px rgba(0, 0, 0, 0.25);
    transform: scale(1.02);
}

.btn-gray {
    background: #C7CDD6;
    border-color: #C7CDD6;
}

    .btn-gray .icon {
        color: inherit;
    }


.btn-80-height {
    line-height: 80px !important;
    height: 80px !important;
}

.btn-tr-wh {
    background: transparent;
    border: 2px solid white;
    color: white;
}

.btn-tr-rd {
    background: transparent;
    border: 2px solid #F93943;
    color: #F93943;
}

    .btn-tr-wh:hover,
    .btn-tr-rd:hover {
        background: #F93943;
        border: 2px solid #F93943;
        color: white;
        box-shadow: none;
    }

.btn-tr-bl {
    background: transparent;
    border: 2px solid #233E70;
    color: #808080;
}

    .btn-tr-bl:hover {
        background: #233E70;
        border: 2px solid #233E70;
        color: white;
        box-shadow: none;
    }

.btn-fs14 {
    font-size: 14px;
    line-height: 40px;
    height: 40px;
}

.form-lang,
.form-logout,
.form-login {
    width: auto;
    display: block;
    font-size: 12px;
    line-height: 40px;
    height: 40px;
    display: inline-block;
    padding-left: 20px;
    padding-right: 20px;
    margin-left: 10px;
}

.form-logout,
.form-login {
    background: #EDEDED;
    color: #F16036;
    border-color: #EDEDED;
}


header {
    position: relative;
    padding-top: 37px;
    padding-bottom: 37px;
}

.uname {
    /* margin-top: 12px; */
    font-size: 14px;
    display: inline-block;
    margin-bottom: 6px;
}

.d-fixed-header header {
    position: fixed;
    left: 0;
    top: 0;
    right: 0;
    background: #FFFFFF;
    z-index: +10000;
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.12);
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    padding-top: 31px;
    padding-bottom: 31px;
}

.d-fixed-header #content {
    padding-top: 100px;
}


header .container-fluid {
    max-width: 1920px;
    margin: 0 auto;
}

header img.logo {
    display: block;
    max-width: 200px;
    width: 100%;
}

.d-fixed-header header img.logo {
    max-width: 170px;
}

#content {
    padding-bottom: 84px;
    padding-top: 35px;
}

.content-no-pad #content {
    padding-bottom: 0 !important;
}


#content .container {
    padding-top: .1px;
    padding-bottom: .1px;
}

    #content .container .container {
        padding: 0;
        width: 100%;
        margin: 20px auto 0 auto;
    }


#content h1 {
    font-weight: bold;
    font-size: 25px;
    line-height: 36px;
    /* color: #F76034; */
    /* margin: 107px 0 27px; */
    text-transform: uppercase;
    margin-bottom: 30px;
}

    #content h1.slogan {
        max-width: 600px;
    }

#content h3,
#content h2 {
    font-weight: normal;
    font-size: 25px;
    line-height: 36px;
    text-transform: none;
    color: #000000;
    margin: 35px 0 23px;
}

    #content h2 strong {
        font-weight: 900;
    }

#content h3 {
    font-size: 20px;
    line-height: 30px;
    margin: 12px 0 20px;
}

#content p,
#content ul {
    margin: 1em 0;
}

    #content ul ul li {
        margin: .5em 0;
    }

#content div div > p:first-child {
    margin-top: 0;
}

#content ul {
    padding-left: 20px;
}

/*#content > .container {
    padding-bottom: 84px;
}*/

#content section {
    margin-top: 50px;
    position: relative;
    padding-top: 1px;
}

section.bg1 {
    background: url(/img/sec_bg_1.svg) 50% 1px no-repeat;
    background-size: 1030px;
}

footer {
    background: #FFFFFF;
    color: black;
    position: relative;
    font-size: 12px;
    line-height: 14px;
    border-top: 1px solid #D9D9D9;
}

    footer .container {
        padding-top: 15px;
        padding-bottom: 15px;
    }

    footer a {
        color: black;
        text-decoration: underline;
    }

.course-image {
    height: 450px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    border-radius: 12px;
}

section.bordered {
    border-top: 2px solid #000000;
}

.course-description {
    word-break: break-word;
}


.course-file-list .ico {
    width: 32px;
    margin-right: 6px;
}

.course-file-list div {
    margin-bottom: 12px;
}

.course-file-list a {
    display: flex;
    align-items: center;
    text-decoration: underline;
}



/* modal */
.modal-open {
    overflow: hidden;
}


.modal {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: +15000;
    display: none;
    overflow: hidden;
    -webkit-overflow-scrolling: touch;
    outline: 0;
    background: url('/img/modal-bg.png') 0 0 repeat;
}

.modal-open .modal {
    overflow-x: hidden;
    overflow-y: auto;
}

.modal-dialog {
    display: -ms-flexbox;
    display: flex;
    position: relative;
    height: auto;
    padding: 0;
    background: white;
    width: 100%;
    max-width: 940px;
    margin: 1.75em auto;
    max-height: calc(100vh - 3.5em);
}

.modal-dialog-scrollable {
}


.modal-dialog .modal-content {
    position: relative;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    outline: 0;
    max-height: calc(100vh - 1rem);
}

.modal-dialog .modal-header {
    padding: 12px 40px 12px 24px;
    position: relative;
}

.modal-dialog h1 {
    padding: 0;
    margin: 0;
    text-align: left;
    font-weight: normal;
    font-size: 22px;
    line-height: 32px;
    color: #505050;
}



.modal-dialog .close {
    position: absolute;
    right: 11px;
    top: 18px;
    font-size: 18px;
    line-height: 15px;
    /*! color: #F16036; */
}

    .modal-dialog .close:hover {
        color: #9a3315;
    }

.modal-dialog .modal-body {
    overflow-y: auto;
    padding: 12px 24px 0;
    font-size: 16px;
    line-height: 19px;
    margin-bottom: 24px;
}

    .modal-dialog .modal-body ul,
    .modal-dialog .modal-body ol {
        padding-left: 1.75em;
    }

    .modal-dialog .modal-body ul,
    .modal-dialog .modal-body ol,
    .modal-dialog .modal-body p {
        margin: 1em 0;
    }

        .modal-dialog .modal-body ul:first-child,
        .modal-dialog .modal-body ol:first-child,
        .modal-dialog .modal-body p:first-child {
            margin-top: 0;
        }

        /*
        .modal-dialog .modal-body ul:last-child,
        .modal-dialog .modal-body ol:last-child,
        .modal-dialog .modal-body p:last-child {
            margin-bottom: 0;
        }
            */


#hotel-dlg .modal-dialog,
#message-dlg .modal-dialog,
#excursion-dlg .modal-dialog,
#transfer-dlg .modal-dialog,
#merch-dlg .modal-dialog {
    max-width: 600px
}


.overlay {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: transparent url('/img/overlay.png') 0 0 repeat;
    z-index: +20000;
}

    .overlay .loader {
        position: absolute;
        left: 0;
        top: 0;
        right: 0;
        bottom: 0;
        background: transparent url('/img/ajax-loader.gif') center center no-repeat;
    }


.hotel-list .item .info,
.excursions-list .item .info,
.transfers-list .info,
.merch-list .info {
    font-size: 80%;
    padding-left: 6px;
    padding-right: 6px;
}

#hotel-dlg .modal-body,
#excursion-dlg .modal-body,
#transfer-dlg .modal-body,
#merch-dlg .modal-body {
    font-size: 80%;
}


.hotel-list .item .photo,
.excursions-list .item .photo,
#hotel-dlg .info .photo,
#excursion-dlg .info .photo {
    border-radius: 6px;
    margin-bottom: 6px;
}

.hotel-list .item .info > *,
.excursions-list .item .info > *,
.transfers-list .info > *,
.merch-list .info > *,
#hotel-dlg .info > *,
#excursion-dlg .info > *,
#transfer-dlg .info > *,
#merch-dlg .info > *,
#hotel-dlg .modal-body > *,
#excursion-dlg .modal-body > *,
#transfer-dlg .modal-body > *,
#merch-dlg .modal-body > * {
    margin-bottom: 6px;
}

.hotel-list .item .title,
.excursions-list .item .title,
#hotel-dlg .info .title,
#excursion-dlg .info .title,
#transfer-dlg .info .title,
#merch-dlg .info .title {
    font-weight: bold;
    margin-bottom: 12px;
    font-size: initial;
    color: #505050;
}


.hotel-list .item .short,
.excursions-list .item .short,
#hotel-dlg .info .short,
#excursion-dlg .info .short {
    font-weight: bold;
    color: #505050;
}

.hotel-list .item .stitle,
.excursions-list .item .stitle,
.transfers-list .info .stitle,
.merch-list .info .stitle {
    font-weight: bold;
    color: #505050;
}

.hotel-list ul.choose-items,
.excursions-list ul.choose-items,
.transfers-list ul.choose-items,
.merch-list ul.choose-items,
.modal ul.payment-types {
    margin: 9px 0 0 0 !important;
    padding: 0 !important;
    list-style-type: none !important;
}

.modal ul.payment-types {
    margin-bottom: 9px !important;
}


    .hotel-list ul.choose-items li,
    .excursions-list ul.choose-items li,
    .transfers-list ul.choose-items li,
    .merch-list ul.choose-items li,
    .modal ul.payment-types li {
        margin-top: 0;
        margin-bottom: 9px;
    }

        .hotel-list ul.choose-items li:last-child,
        .excursions-list ul.choose-items li:last-child,
        .transfers-list ul.choose-items li:last-child,
        .merch-list ul.choose-items li:last-child,
        .modal ul.payment-types li:last-child {
            margin-bottom: 0;
        }



.hotel-list label i.icon {
    margin-right: 2px;
    color: black;
}

.modal .photo-container,
.modal .photo-container {
    margin-left: -6px;
    margin-right: -6px;
}

.excursions-list .description,
#excursion-dlg .info .description {
    border-left: 2px solid #AAA;
    padding-left: 9px;
    margin: 12px 0 !important;
}

.modal .onlinepayment-info div.descr,
.modal .bill-info div.descr,
.modal .booking-info div.descr {
    text-align: center;
}


.modal .sum-info .nights,
.modal .sum-info .dates,
.modal .sum-info .price,
.modal .item-info .title,
.modal .item-info .price {
    font-weight: bold;
    margin-bottom: .5em;
}


#business-program .date-section .descr {
    font-size: 14px;
    line-height: 16px;
    margin-top: 6px;
    padding-left: 25px;
}

    #business-program .date-section .descr ~ .custom-checkbox {
        margin-top: 22px;
    }



@media (max-width: 1299px) {
    #content h1 {
        /* margin: 51px 0 27px; */
    }

    #content section h3 {
        margin: 4px 0 30px 0;
    }

    .course-image {
        height: 400px;
    }
}


@media (max-width: 991px) {

    #content {
        padding-bottom: 62px;
    }

        #content h1 {
            margin: 31px 0 27px;
        }

        #content h4 {
            margin: 20px 0 38px;
        }

    label i.icon,
    a i.icon {
        margin-right: 0.4em;
    }


    /*#content > .container {
        padding-bottom: 62px;
    }*/

    #content section {
        margin-top: 39px;
    }

        #content section h3 {
            margin: 3px 0 23px 0;
        }
}


@media (max-width: 767px) {

    #content {
        font-size: 16px;
    }

        #content h4 {
            font-size: 40px;
            line-height: 49px;
        }
    /*
    .btn {
        text-transform: uppercase;
        font-weight: normal;
        line-height: 57px;
        height: 57px;
        font-size: 18px;
    }
*/
    .short-with-more {
        height: 333px;
    }

    .course-image {
        height: 350px;
        border-radius: 6px
    }
}


@media (max-width: 575px) {

    #content {
        font-size: 16px;
    }

        #content h3,
        #content h2,
        #content h1 {
            font-size: 20px;
            line-height: 24px;
            margin: 24px 0 14px;
        }

            #content h1.slogan {
                max-width: 350px;
            }

        #content h4 {
            font-size: 30px;
            line-height: 37px;
        }

        #content h3 + .description {
            margin: -22px 0 24px;
        }

        #content section h3.head {
            font-size: 14px;
        }

    .short-with-more {
        height: 430px;
    }

    .modal-dialog .modal-body ul,
    .modal-dialog .modal-body ol {
        padding-left: 22px;
    }

    .course-image {
        height: 200px;
    }
}
