.header__left-col {
    width: 210px;
    display: inline-block;
    vertical-align: bottom;
    position: relative;
}

.header__r-col {
    width: calc(100% - 215px);
    display: inline-block;
    vertical-align: middle;
    position: relative;
}

.header__bottom {
    background-color: #96bcdc;
    padding: 15px 25px;
}

.header .header__abs-notif {
    position: absolute;
    left: 212px;
    padding-top: 0;
    font-size: 14px;
    z-index: 100;
    top: 5px;
}

.header .header__logo img {
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: left;
    object-position: left;
}

.header__top {
    position: relative;
    padding: 12px 25px 12px 25px;
}

.header__subsection::before {
    font-family: "Font Awesome 5 Free";
    margin-right: 3px;
    font-size: 13px;
}

.header__subsections {
    display: inline-block;
    vertical-align: middle;
}

.header__subsection.active {
    background-color: #ffffff;
}

.header__subsections .header__subsection:not(:first-child) {
    margin-left: 10px;
}

.header__subsection:hover .hint {
    display: block;
    top: -35px;
    font-size: 14px;
    padding: 3px 10px;
    border-radius: 7px;
    background: #ffffff;
}

a.header__subsection:hover {
    background: #ffffff !important;
}

.header .header__subsection.disabled {
    cursor: inherit;
    background: rgba(255, 255, 255, 0.78) !important;
}

.header .header__subsection.disabled, .header .header__subsection.disabled *:not(.hint) {
    color: #999999 !important;
}

.header .header__subsection {
    height: 35px;
    background: #eef4fa center/15px no-repeat;
    text-align: center;
    white-space: nowrap;
    line-height: 35px;
    border: none;
    border-radius: 5px;
    width: 60px;
    color: #475669;
    display: inline-block;
    vertical-align: top;
    font-weight: bold;
    font-size: 14px;
    font-style: normal;
    position: relative;
    font-family: 'apercu_pro', sans-serif;
}


.header__search::before {
    content: "";
    position: absolute;
    right: 10px;
    top: 0;
    height: 100%;
    width: 40px;
    background: url(/i/menu.svg) center/19px no-repeat;
}

.header__search {
    position: relative;
    background: #ffffff;
    border-radius: 5px;
    cursor: pointer;
    height: 50px;
    display: inline-block;
    width: calc(100% - 382px);
    vertical-align: middle;
    margin-right: 23px;
}

.header__search-lbl {
    color: #999999;
    position: absolute;
    top: 15px;
    font-size: 14px;
    left: 65px;
}

.header__buttons .lsfw-flag {
    margin-left: 9px;
}

.header__button-wrap.disabled .header__button {
    color: #cccccc;
    border-color: #cccccc;
    cursor: inherit;
    background: #ffffff !important;
}

.header__button-wrap.active .header__button,
.header__button:hover {
    background: #96bcdc;
}

.header__button-wrap:hover .hint {
    top: 40px !important;
}

.header__buttons {
    text-align: right;
    margin-bottom: 5px;
}

.header__button-wrap {
    display: inline-block;
    vertical-align: middle;
    position: relative;
}

.header__buttons .header__button-wrap:not(:first-child) {
    margin-left: 10px;
}

.header__button::before {
    font-weight: bold;
    font-family: "Font Awesome 5 Free";
    line-height: 33px;
    display: block;
}

.header .header__ul:hover {
    background: #cae0f3;
}

.header .header__ul.header__ul--grey {
    background: #eeeeee;
    color: #999999;
}

.header .header__ul {
    color: #215f86;
    position: absolute;
    top: 7px;
    left: 10px;
    height: 35px;
    font-size: 20px;
    text-align: center;
    width: 40px;
    line-height: 38px;
    background: #d4e4f2;
    border-radius: 3px;
    z-index: 2;
}

.header__button {
    height: 35px;
    background: transparent center/15px no-repeat;
    text-align: center;
    white-space: nowrap;
    line-height: 35px !important;
    border-radius: 5px;
    width: 60px;
    border: 2px solid #96bcdc;
    color: #215f86;
    display: block;
    font-weight: bold;
    cursor: pointer;
    font-size: 18px;
    font-style: normal;
    position: relative;
    font-family: 'apercu_pro', sans-serif;
}

.header__search-inp-cut {
    max-width: calc(100% - 100px);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
    vertical-align: bottom;
}

.header__search-inp {
    width: 100%;
    text-transform: uppercase;
    height: 100%;
    border: none;
    display: block;
    border-radius: 5px;
    padding: 12px 10px 11px 65px;
    font-size: 18px;
    color: #475669;
    font-weight: bold;
    font-family: 'apercu_pro', sans-serif;
}

.header__user-ava img {
    border-radius: 2px;
}

.header__key::after {
    width: 30px;
    height: 30px;
    content: '';
    background: url(https://tophotels.ru/csstx/i/key-white.svg) center/26px no-repeat;
    position: absolute;
    bottom: 0;
    right: 0;
    top: 0;
    left: 0;
    margin: auto;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.header__key:hover {
    background: #db7a39;
}

.header__key {
    border-radius: 2px;
    width: 100px;
    border: 2px solid white;
    cursor: pointer;
    height: 50px;
    position: relative;
    transition: 0.3s;
    display: block;
    background: #ff8e41;
}

.header__user-ava {
    border-radius: 2px;
    width: 50px;
    border: 2px solid #ffffff;
    height: 50px;
    display: inline-block;
    background-color: #ffffff;
    vertical-align: middle;
    margin-right: 12px;
    cursor: pointer;
}

.header__sms::before {
    content: '';
    position: absolute;
    border-left: 19px solid transparent;
    border-right: 7px solid transparent;
    border-bottom: 13px solid #e03a3a;
    right: 32px;
    top: 15px;
}

.header__sms:hover {
    background-color: #c42e2e;
}

.header__sms:hover::before {
    border-bottom-color: #c42e2e;
}

.header__sms:hover .hint {
    display: block;
    left: 0;
    right: auto;
    top: -35px;
    font-size: 14px;
    padding: 3px 10px;
    border-radius: 7px;
    background: #ffffff;
}

.header__sms {
    display: inline-block;
    position: absolute;
    left: 60px;
    top: 0;
    font-weight: bold;
    line-height: 40px;
    vertical-align: top;
    font-family: 'apercu_pro', sans-serif;
    font-size: 17px;
    width: 40px;
    height: 40px;
    border-radius: 29px;
    text-align: center;
    margin-left: 16px;
    background-color: #e03a3a;
    margin-top: 4px;
    color: white !important;
}

.header__nav-link::before {
    display: none;
}

.header__nav-link.active {
    color: #e03a3a !important;
}

.header__nav .header__nav-link {
    margin-right: 45px;
}

.header__nav-link a {
    color: inherit;
    font: inherit;
}

.header__nav-link {
    font-family: 'apercu_pro', sans-serif;
    text-decoration: none;
    font-size: 19px;
    font-weight: bold;
    color: #215f86;
    line-height: 19px;
    text-transform: uppercase;
    display: inline-block;
    vertical-align: middle;
    position: relative;
}

.header__burger {
    display: none;
}

.pp-lang__ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.pp-lang__ul .pp-lang__ul-li.pp-lang__ul-li--disabled:hover {
    background: #eeeeee !important;
    cursor: auto;
}

.pp-lang__ul .pp-lang__ul-li.pp-lang__ul-li--disabled {
    color: #bebdbd;
}

.pp-lang__ul li {
    width: 200px;
    -webkit-transition: 0.1s;
    -o-transition: 0.1s;
    transition: 0.1s;
    cursor: pointer;
    font-size: 13px;
    text-transform: uppercase;
    margin-bottom: 5px;
    border-radius: 5px;
    padding: 5px;
    font-weight: normal;
}


.pp-lang.pp-lang--short {
    width: 260px;
    min-width: auto;
}

.pp-lang.pp-lang--short .pp-lang__ul {
    display: block;
}

.pp-lang__ul li > * {
    display: inline-block;
    vertical-align: middle;
}

.pp-lang__ul li.pp-lang__ul-li--active, .pp-lang__ul li:hover {
    background: #eef4fa;
}

.mobile-navigator, .header__nav-link-hotel {
    display: none;
}

.header a.header__fast-link:hover {
    background: #3c6587;
}

.header.header--disabled .header__fast-link, .header .header__fast-link.disabled {
    background: #cecece !important;
    cursor: inherit;
}

.header .header__fast-link.active {
    background: #cccccc !important;
}

.header__fast-link {
    color: #ffffff !important;
    font-size: 13px;
    width: 220px;
    white-space: nowrap;
    text-align: center;
    display: block;
    line-height: 25px;
    border-radius: 5px;
    background: #2b455a;
    position: absolute;
    left: 0;
    bottom: 0;
}


.header-notification.bg-light-orange {
    padding-right: 10px !important;
    background-color: #fff2cd !important;
}

.header-notification.bg-light-red .header-notification__icon {
    color: #e03a3a;
}


.header-notification.v2 .header-notification__icon {
    top: 10px;
}

.header-notification.v2 {
    border-radius: 5px;
    color: #e03a3a;
    margin-top: 20px;
    padding: 13px 25px 13px 50px;
}

.header-notification {
    font-size: 17px;
    position: relative;
    display: block;
    border-radius: 0 0 3px 3px;
    padding: 10px 55px 10px 55px;
}

.header-notification__icon {
    position: absolute;
    left: 10px;
    font-size: 15px;
    background: #ffffff;
    width: 30px;
    height: 30px;
    top: 7px;
    line-height: 30px;
    border-radius: 3px;
    text-align: center;
}

.header-notification__cross {
    background: url(https://css.tophotels.ru/i/cross-thin.svg) center/15px no-repeat;
    width: 40px;
    height: 100%;
    right: 0;
    top: 0;
    cursor: pointer;
    display: inline-block;
    position: absolute;
}


.header-notification a {
    color: #475669;
}

.header-mobile-only {
    display: none;
}

@media screen and (min-width: 1023px) {
    .header .header__buttons .lsfw-popup-wrap::before {
        content: '';
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 100;
        position: fixed;
        background-color: rgba(0, 0, 0, 0.56);
    }

    .pp-lang {
        width: 660px;
    }

    .header .header__buttons .lsfw-popup {
        z-index: 101;
    }

    .header .lsfw-form-control__currencies {
        white-space: nowrap;
    }

    .header .header__buttons .lsfw-popup-wrap {
        position: absolute;
        width: auto;
        height: auto;
        background: transparent;
        display: block;
        padding-top: 60px;
        left: auto;
        right: 0;
    }
}

@media screen and (max-width: 1150px) {
    .header .header__ul {
        display: none;
    }

    .header .header__search-inp {
        padding-left: 15px;
    }

    .header .header__search-lbl {
        left: 15px;
    }

    .header .header__r-col {
        width: calc(100% - 214px);
    }

    .header .header__left-col {
        min-width: 190px;
    }
}

@media screen and (max-width: 1023px) {
    .header-notification .header-notification__icon {
        font-size: 13px;
        width: 25px;
        height: 25px;
        top: 7px;
        line-height: 25px;
    }

    .header .header__abs-notif {
        left: 0;
        font-size: 9px;
        top: 0;
    }

    .big-horizont-loader {
        height: 180px !important;
    }

    .header .header__fast-link {
        min-width: 175px;
    }

    .header .header__fast-link span {
        display: none;
    }

    .header .header__logo img {
        max-height: 40px;
    }

    .header-notification {
        font-size: 14px;
        padding: 10px 40px 10px 50px;
    }

    .header .header__left-col {
        min-width: 300px;
        width: auto;
    }

    .header__buttons {
        margin: 0;
    }

    .header__burger {
        display: inline-block;
        width: 42px;
        height: 25px;
        position: relative;
        margin: 0 15px 0 0;
        background: #215f86;
        border: none;
        border-radius: 3px;
    }

    .header__burger i {
        width: 20px;
        display: block;
        position: absolute;
        border-radius: 19px;
        -o-transition: 0.4s;
        -webkit-transition: 0.4s;
        transition: 0.4s;
        left: 11px;
        overflow: hidden;
        height: 2px;
        border-bottom: 2px solid #ffffff;
    }

    .header__burger i:nth-of-type(1) {
        top: 6px;
        -moz-transition: top 0.25s ease 0.25s, -moz-transform 0.25s ease-out 0.1s;
        -o-transition: top 0.25s ease 0.25s, -o-transform 0.25s ease-out 0.1s;
        -webkit-transition: top 0.25s ease, -webkit-transform 0.25s ease-out;
        -webkit-transition-delay: 0.25s, 0.1s;
        transition: top 0.25s ease 0.25s, -webkit-transform 0.25s ease-out 0.1s;
        -webkit-transition: top 0.25s ease 0.25s, -webkit-transform 0.25s ease-out 0.1s;
        -o-transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s;
        transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s;
        transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s, -webkit-transform 0.25s ease-out 0.1s;
    }

    .header__burger i:nth-of-type(2) {
        top: 11.5px;
        -moz-transition: ease 0.2s 0.2s;
        -o-transition: ease 0.2s 0.2s;
        -webkit-transition: ease 0.2s;
        -webkit-transition-delay: 0.2s;
        -webkit-transition: ease 0.2s 0.2s;
        transition: ease 0.2s 0.2s;
    }

    .header__burger i:nth-of-type(3) {
        top: 17px;
        -moz-transition: top 0.25s ease 0.25s, -moz-transform 0.25s ease-out 0.1s;
        -o-transition: top 0.25s ease 0.25s, -o-transform 0.25s ease-out 0.1s;
        -webkit-transition: top 0.25s ease, -webkit-transform 0.25s ease-out;
        -webkit-transition-delay: 0.25s, 0.1s;
        transition: top 0.25s ease 0.25s, -webkit-transform 0.25s ease-out 0.1s;
        -webkit-transition: top 0.25s ease 0.25s, -webkit-transform 0.25s ease-out 0.1s;
        -o-transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s;
        transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s;
        transition: top 0.25s ease 0.25s, transform 0.25s ease-out 0.1s, -webkit-transform 0.25s ease-out 0.1s;
    }

    .header .header__burger.active i:nth-of-type(1) {
        top: 11px;
        -ms-transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
        -moz-transition: top 0.25s ease 0.1s, -moz-transform 0.25s ease-out 0.25s;
        -o-transition: top 0.25s ease 0.1s, -o-transform 0.25s ease-out 0.25s;
        -webkit-transition: top 0.25s ease, -webkit-transform 0.25s ease-out;
        -webkit-transition-delay: 0.1s, 0.25s;
        transition: top 0.25s ease 0.1s, -webkit-transform 0.25s ease-out 0.25s;
        -webkit-transition: top 0.25s ease 0.1s, -webkit-transform 0.25s ease-out 0.25s;
        -o-transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s;
        transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s;
        transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s, -webkit-transform 0.25s ease-out 0.25s;
    }

    .header .header__burger.active i:nth-of-type(2) {
        opacity: 0;
    }

    .header .header__burger.active i:nth-of-type(3) {
        top: 11px;
        -ms-transform: rotate(-45deg);
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        -moz-transition: top 0.25s ease 0.1s, -moz-transform 0.25s ease-out 0.25s;
        -o-transition: top 0.25s ease 0.1s, -o-transform 0.25s ease-out 0.25s;
        -webkit-transition: top 0.25s ease, -webkit-transform 0.25s ease-out;
        -webkit-transition-delay: 0.1s, 0.25s;
        transition: top 0.25s ease 0.1s, -webkit-transform 0.25s ease-out 0.25s;
        -webkit-transition: top 0.25s ease 0.1s, -webkit-transform 0.25s ease-out 0.25s;
        -o-transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s;
        transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s;
        transition: top 0.25s ease 0.1s, transform 0.25s ease-out 0.25s, -webkit-transform 0.25s ease-out 0.25s;
    }


    .header.header--disabled .header__key {
        background-size: 20px;
        background-color: #ffff;
        border-color: #cccccc;
    }

    .header__key::after {
        background-size: 16px;
    }

    .header .header__bottom .header__r-col {
        width: 100%;
    }

    .header .header__subsection::before {
        font-size: 11px;
    }

    .header .header__subsections .header__subsection:not(:first-child) {
        margin-left: 5px;
    }

    .header .header__ul {
        display: none;
    }

    .header .header__search-lbl {
        left: 15px;
    }

    .header .header__search {
        margin-right: 20px;
        width: calc(100% - 310px);
    }

    .header .header__subsection {
        width: 50px;
        font-size: 13px;
    }

    .header .header__bottom .header__left-col {
        top: auto;
        bottom: 15px;
        right: auto;
        position: absolute;
        left: 15px;
        min-width: auto;
        margin: 0;
        z-index: 10;
    }


    .header {
        position: relative;
    }

    .header .header__buttons .lsfw-flag {
        margin-left: 3px;
    }

    .header .header__button {
        width: 50px;
    }

    .header__key, .header .header__user-ava {
        width: 35px;
        border-radius: 3px;
        margin: 0;
        border: none;
        overflow: hidden;
        height: 35px;
    }

    .header .header__top {
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end;
        display: flex;
        padding: 12px 15px;
    }

    .header__bottom {
        padding: 15px;
    }

    .header .header__search {
        width: 100%;
        margin: 0 0 15px 0;
    }

    .header .header__subsections {
        display: block;
        padding-left: 40px;
        text-align: right;
    }

    .header__sms {
        line-height: 30px;
        font-size: 14px;
        width: 30px;
        left: 40px;
        height: 30px;
        top: -1px;
    }

    .header__sms::before {
        content: '';
        position: absolute;
        border-left: 11px solid transparent;
        border-right: 3px solid transparent;
        border-bottom: 10px solid #e05c00;
        right: 26px;
        top: 13px;
    }

}

@media screen and (max-width: 767px) {
    .header .header__fast-link {
        display: none;
    }

    .header__key, .header .header__user-ava {
        width: 30px;
        height: 30px;
    }

    .header-mobile-only .header__fast-link {
        width: 245px !important;
        position: static;
    }

    .header-mobile-only {
        display: block;
        padding: 10px;
        background-color: #eeeeee;
        position: relative;
    }

    .header__sms {
        left: 35px;
        top: -5px;
    }
}

@media screen and (max-width: 750px) {
    .header .header__search-voice {
        font-size: 15px;
        right: 0;
        top: 1px;
    }

    .header__search-inp {
        font-size: 13px;
        padding: 15px;
    }

    .header-notification {
        padding: 10px 15px 15px 15px;
    }

    .header-notification .header-notification__icon {
        position: static;
        float: right;
        margin-left: 10px;
    }

    .header .header__subsection:hover .hint {
        left: 0;
        right: auto;
    }

    .header .header__buttons {
        margin: 0;
    }

    .header__search::before {
        background-size: 15px;
        width: 30px;
    }

    .header .header__top {
        position: static;
        min-height: 60px;
    }

    .header .header__buttons .header__button-wrap:not(:first-of-type) {
        margin: 0 0 0 5px;
    }

    .header .header__button {
        width: 40px;
        height: 30px;
        font-size: 15px;
        line-height: 21px;
    }

    .header .header__subsection {
        padding: 0 5px;
        line-height: 30px;
        width: calc(20% - 7px);
        height: 30px;
        font-size: 11px;
        background: #ffffff;
        max-width: 60px;
    }

    .header .header__subsections .header__subsection:not(:first-child) {
        margin-left: 2px;
    }

    .header .header__subsection::before {
        font-size: 9px;
        display: inline-block;
        margin-right: 5px;
    }

    .page .header .header__button .lsfw-flag {
        width: 25px !important;
        background-position-x: 0 !important;
        height: 16px !important;
        margin: 6px 0;
    }

    .header .header__left-col {
        min-width: auto;
        margin: 0;
    }

    .header .header__logo img {
        max-height: 35px;
    }
}

@media screen and (max-width: 475px) {
    .header__sms {
        top: -6px;
        font-size: 9px;
        width: 15px;
        height: 15px;
        line-height: 15px;
        margin: 0;
        right: -8px;
        left: auto;
    }

    .header__sms::before {
        display: none;
    }
}

@media screen and (max-width: 370px) {
    .header .header__subsection::before {
        margin-right: 1px;
    }

    .header .header__subsection {
        font-size: 10px;
        width: calc(20% - 5px);
    }
}

@media screen and (max-width: 333px) {
    .header .header__button {
        width: 34px;
    }
}