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

.header .header__r-col {
    width: calc(100% - 215px);
    display: inline-block;
    vertical-align: middle;
    margin-left: auto;
}

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

html body .topline-fixed-button.fixed, .header__bottom-wrap {
    background: #f1ebd3;
}

.header__key:hover {
    background: #db7a39;
}

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

.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__sms:hover {
    background-color: #cb5400;
}

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

.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: 100%;
    text-align: center;
    margin-left: 16px;
    background: #e05c00 center/25px no-repeat;
    margin-top: 4px;
    color: white !important;
}

.header .header__bottom {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-top: 15px;
    padding-bottom: 15px;
}

.header .header__top {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-top: 12px;
    padding-bottom: 12px;
}

.header__fast-link:hover {
    background: #5f975a;
}

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

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

.header__fast-link.header__fast-link--blue {
    background: #318cc6 !important;
}

.header__fast-link.header__fast-link--blue:hover {
    background: #3c6587 !important;
}

.header__fast-link {
    color: #ffffff !important;
    font-size: 13px;
    margin-left: 3.5px;
    min-width: 250px;
    white-space: nowrap;
    display: block;
    text-align: center;
    -ms-flex-item-align: end;
    align-self: flex-end;
    line-height: 25px;
    border-radius: 5px;
    background: #499642;
}

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

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

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

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

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

.header .header__subsection {
    height: 35px;
    background: #fff6ec 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;
    cursor: pointer;
    font-size: 14px;
    font-style: normal;
    position: relative;
    font-family: 'apercu_pro', sans-serif;
}


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

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

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

.header .header__button:hover {
    background: #f1ebd3;
}

.header .header__buttons {
    text-align: right;
}


.header .header__big-hint .header__big-hint-cross:hover {
    background-image: url(https://tophotels.ru/csstx/i/cross-thin.svg);
}

.header .header__big-hint .header__big-hint-cross {
    top: 0;
    right: 3px;
    width: 40px;
    position: absolute;
    z-index: 1;
    cursor: pointer;
    height: 45px;
    background: url(https://tophotels.ru/csstx/i/cross-thin-grey.svg) center/12px no-repeat;
}

.header .header__big-hint::before {
    content: "";
    position: absolute;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 10px solid #ffffff;
    top: -7px;
    right: 50px;
}

.header .header__big-hint {
    width: 202px;
    color: #333333;
    border-radius: 10px;
    right: -30px;
    position: absolute;
    font-family: 'apercu_pro', sans-serif;
    font-size: 16px;
    background: #ffffff;
    top: 50px;
    padding: 5px 10px 7px 15px;
    -webkit-box-shadow: 1px -1px 20px 5px rgba(0, 0, 0, 0.3);
    box-shadow: 1px -1px 20px 5px rgba(0, 0, 0, 0.3);
    z-index: 10;
    text-align: left;
    line-height: 26px;
    -webkit-touch-callout: none; /* iOS Safari */
    -webkit-user-select: none; /* Safari */
    -khtml-user-select: none; /* Konqueror HTML */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
    user-select: none;
}

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

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

.header .header__button::before {
    font-weight: bold;
    font-family: "Font Awesome 5 Free";
    display: block;
}

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

.header .header__search-voice:hover {
    color: #f58234;
}

.header .header__ul::before {
    content: '';
    background-color: #f58234;
    -webkit-mask: url(https://tophotels.ru/csstx/i/search-list.svg) no-repeat center/20px;
    mask: url(https://tophotels.ru/csstx/i/search-list.svg) no-repeat center/20px;
    width: 100%;
    height: 100%;
    display: block;
}

.header .header__ul {
    position: absolute;
    top: 7px;
    left: 10px;
    height: 35px;
    width: 40px;
    border-radius: 3px;
    z-index: 2;
    background: #f1ebd3;
}

.header .header__ul:hover {
    background-color: #fff6ec;
}

.header .header__search-voice {
    position: absolute;
    top: 0;
    right: 2px;
    cursor: pointer;
    height: 100%;
    color: #cccccc;
    font-size: 20px;
    text-align: center;
    width: 50px;
    line-height: 50px;
}

.header .header__search-inp {
    width: 100%;
    height: 100%;
    border: none;
    display: block;
    border-radius: 5px;
    position: relative;
    z-index: 1;
    padding: 10px 10px 11px 60px;
    font-size: 16px;
    color: #475669;
    font-weight: bold;
    font-family: 'apercu_pro', sans-serif;
}

.header .header__user-ava img {
    border-radius: inherit;
}

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

.header .header__logo {
    display: block;
}

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

.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;
}

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

.image-poly {
    font-family: 'object-fit: contain;';
}

.big-horizont-loader {
    border-radius: 5px;
    background: #d8e1e6;
    height: 240px;
    -webkit-animation: bhLoader 3s infinite;
    animation: bhLoader 3s infinite;
}

.container .big-horizont-loader {
    margin-top: 15px;
}

.index-chooser__bh .big-horizont-loader {
    margin-top: 0;
    height: 240px !important;
    overflow: hidden;
}

.add-review {
    display: none;
}

@-webkit-keyframes bhLoader {
    0% {
        background-color: #d8e1e6;
    }
    50% {
        background-color: #d1dee5;
    }
    100% {
        background-color: #d8e1e6;
    }
}

@keyframes bhLoader {
    0% {
        background-color: #d8e1e6;
    }
    50% {
        background-color: #d1dee5;
    }
    100% {
        background-color: #d8e1e6;
    }
}


.header__burger {
    display: none;
}

.header.header--disabled .header__key {
    background: #faf6e5 url(https://tophotels.ru/csstx/i/key-broken.png) center/25px no-repeat;
}

.header.header--disabled .header__key::after {
    display: none;
}

.header.header--disabled .header__ul::before {
    background: #999999;
}

.header.header--disabled .header__ul {
    background: #faf6e5;
}

.header.header--disabled .header__subsection {
    color: #999999 !important;
    background: #faf6e5 !important;
    cursor: inherit;
}

.header.header--disabled .header__button {
    border-color: #eeeeee;
    color: #8e8e8e !important;
    cursor: inherit;
    background: #ffffff !important;
}

@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;
    }

    .menu .menu__link:not(:last-child) {
        margin-right: 65px;
    }

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

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

@media screen and (max-width: 1023px) {

    .header .header__big-hint {
        font-size: 13px;
        width: 170px;
        line-height: 20px;
        top: 45px;
    }

    .header .header__big-hint::before {
        right: 37px;
    }

    .header .header__big-hint .header__big-hint-cross {
        width: 30px;
        background-size: 10px;
        height: 30px;
        right: 4px;
        top: 4px;
    }

    .header .header__bottom {
        display: block;
    }

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

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

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

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

    .header__fast-link {
        font-size: 11px;
    }

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

    .header .header__left-col {
        margin-left: 10px;
    }

    .header__burger {
        display: block;
        width: 42px;
        min-width: 42px;
        height: 25px;
        position: relative;
        margin: 0 15px 0 0;
        background: #f48d48;
        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__r-col {
        width: auto;
    }

    .header .header__ul {
        display: none;
    }

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

    .header .header__search-inp {
        padding-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;
    }

    .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;
        border: none;
        overflow: hidden;
        height: 35px;
    }

    .header .header__top {
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end;
    }

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

    .header .header__subsections {
        display: block;
        padding-left: 40px;
        white-space: nowrap;
        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 !important;
    }

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

    .add-review .header__fast-link {
        width: 245px !important;
    }

    .add-review {
        display: block;
        padding: 10px;
        background-color: #eeeeee;
        position: relative;
    }

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

@media screen and (max-width: 750px) {
    .header .header__top .header__button-wrap:not(.header__button-wrap--mobile) {
        display: none;
    }

    .header .header__search-voice {
        font-size: 15px;
        right: 0;
        top: 1px;
    }

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


    .header .header__buttons {
        margin: 0;
    }

    .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: 35px;
        height: 30px;
        font-size: 13px;
        line-height: 26px;
    }

    .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: 374px) {
    .header__burger {
        width: 30px;
        min-width: 30px;
    }

    .header .header__button.header__currency, .header .header__button.fas {
        width: 25px;
    }

    .header__burger i {
        left: 7px;
        width: 15px;
    }

    .header .header__logo img {
        width: 135px;
    }
}

