@charset "UTF-8";
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline
}

:focus {
    outline: 0
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block
}

body {
    line-height: 1
}

ol, ul {
    list-style: none
}

blockquote, q {
    quotes: none
}

blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration, input[type=search]::-webkit-search-results-button, input[type=search]::-webkit-search-results-decoration {
    -webkit-appearance: none;
    -moz-appearance: none
}

input[type=search] {
    -webkit-appearance: none;
    -moz-appearance: none;
    box-sizing: content-box
}

textarea {
    overflow: auto;
    vertical-align: top;
    resize: vertical
}

audio, canvas, video {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    max-width: 100%
}

audio:not([controls]) {
    display: none;
    height: 0
}

[hidden] {
    display: none
}

html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%
}

a:focus {
    outline: thin dotted
}

a:active, a:hover {
    outline: 0
}

img {
    border: 0;
    -ms-interpolation-mode: bicubic
}

figure {
    margin: 0
}

form {
    margin: 0
}

fieldset {
    border: 1px solid silver;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    border: 0;
    padding: 0;
    white-space: normal;
    *margin-left: -7px
}

button, input, select, textarea {
    font-size: 100%;
    margin: 0;
    vertical-align: baseline;
    *vertical-align: middle
}

button, input {
    line-height: normal
}

button, select {
    text-transform: none
}

button, html input[type=button], input[type=reset], input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer;
    *overflow: visible
}

button[disabled], html input[disabled] {
    cursor: default
}

input[type=checkbox], input[type=radio] {
    box-sizing: border-box;
    padding: 0;
    *height: 13px;
    *width: 13px
}

input[type=search] {
    -webkit-appearance: textfield;
    box-sizing: content-box
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

button::-moz-focus-inner, input::-moz-focus-inner {
    border: 0;
    padding: 0
}

textarea {
    overflow: auto;
    vertical-align: top
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

html, button, input, select, textarea {
    color: #222
}

::selection {
    background: #b3d4fc;
    text-shadow: none
}

img {
    vertical-align: middle
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0
}

textarea {
    resize: vertical
}

.chromeframe {
    margin: .2em 0;
    background: #ccc;
    color: #000;
    padding: .2em 0
}

.scroll-wrapper {
    overflow: hidden !important;
    padding: 0 !important;
    position: relative
}

.scroll-wrapper > .scroll-content {
    border: none !important;
    box-sizing: content-box !important;
    height: auto;
    left: 0;
    margin: 0;
    max-height: none;
    max-width: none !important;
    overflow: scroll !important;
    padding: 0;
    position: relative !important;
    top: 0;
    width: auto !important
}

.scroll-wrapper > .scroll-content::-webkit-scrollbar {
    height: 0;
    width: 0
}

.scroll-element {
    display: none
}

.scroll-element, .scroll-element div {
    box-sizing: content-box
}

.scroll-element.scroll-x.scroll-scrollx_visible, .scroll-element.scroll-y.scroll-scrolly_visible {
    display: block
}

.scroll-element .scroll-bar, .scroll-element .scroll-arrow {
    cursor: default
}

.scroll-textarea {
    border: 1px solid #ccc;
    border-top-color: #999
}

.scroll-textarea > .scroll-content {
    overflow: hidden !important
}

.scroll-textarea > .scroll-content > textarea {
    border: none !important;
    box-sizing: border-box;
    height: 100% !important;
    margin: 0;
    max-height: none !important;
    max-width: none !important;
    overflow: scroll !important;
    outline: none;
    padding: 2px;
    position: relative !important;
    top: 0;
    width: 100% !important
}

.scroll-textarea > .scroll-content > textarea::-webkit-scrollbar {
    height: 0;
    width: 0
}

.scrollbar-inner > .scroll-element, .scrollbar-inner > .scroll-element div {
    border: none;
    margin: 0;
    padding: 0;
    position: absolute;
    z-index: 10
}

.scrollbar-inner > .scroll-element div {
    display: block;
    height: 100%;
    left: 0;
    top: 0;
    width: 100%
}

.scrollbar-inner > .scroll-element.scroll-x {
    bottom: 2px;
    height: 8px;
    left: 0;
    width: 100%
}

.scrollbar-inner > .scroll-element.scroll-y {
    height: 100%;
    right: 0;
    top: 0;
    width: 8px
}

.scrollbar-inner > .scroll-element .scroll-element_outer {
    overflow: hidden
}

.scrollbar-inner > .scroll-element .scroll-element_track, .scrollbar-inner > .scroll-element .scroll-bar {
    opacity: 1
}

.scrollbar-inner > .scroll-element .scroll-element_track {
    background-color: #e0e0e0
}

.scrollbar-inner > .scroll-element .scroll-bar {
    background-color: #baa9a8
}

.scrollbar-inner > .scroll-element:hover .scroll-bar {
    background-color: #baa9a8
}

.scrollbar-inner > .scroll-element.scroll-draggable .scroll-bar {
    background-color: #919191
}

.scrollbar-inner > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_track {
    left: -12px
}

.scrollbar-inner > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_track {
    top: -12px
}

.scrollbar-inner > .scroll-element.scroll-x.scroll-scrolly_visible .scroll-element_size {
    left: -12px
}

.scrollbar-inner > .scroll-element.scroll-y.scroll-scrollx_visible .scroll-element_size {
    top: -12px
}

html, body {
    margin: 0;
    height: 100%;
    font-weight: 400;
    font-family: montserrat, sans-serif
}

* {
    box-sizing: border-box
}

a {
    color: #fff;
    text-decoration: none
}

h1, h2 {
    font-weight: 700;
    line-height: 56px
}

h1 span, h2 span {
    display: block
}

.container {
    margin: 0 auto;
    width: 100%
}

.row {
    display: grid;
    grid-template-columns:repeat(12, 1fr);
    grid-gap: 30px;
    margin: 0 auto;
    position: relative
}

.col-1 {
    grid-column: span 1
}

.col-2 {
    grid-column: span 2
}

.col-3 {
    grid-column: span 3
}

.col-4 {
    grid-column: span 4
}

.col-5 {
    grid-column: span 5
}

.col-6 {
    grid-column: span 6
}

.col-7 {
    grid-column: span 7
}

.col-8 {
    grid-column: span 8
}

.col-9 {
    grid-column: span 9
}

.col-10 {
    grid-column: span 10
}

.col-11 {
    grid-column: span 11
}

.col-12 {
    grid-column: span 12
}

.col-to-end {
    grid-column-end: -1 !important
}

.row-2 {
    grid-row: 1/span 2
}

.row-2-2 {
    grid-row: 2/span 1
}

.row-1-2 {
    grid-row: 1/span 1
}

.mobile {
    display: none
}

.desktop {
    display: inherit
}

.hidden_params {
    display: none
}

.flex {
    display: -ms-flexbox;
    display: flex
}

@media (min-width: 1025px) and (max-width: 1180px) {
    .row {
        display: grid;
        grid-template-columns:repeat(12, 1fr);
        max-width: 1180px;
        padding: 0 20px;
        grid-gap: 10px;
        margin: 0 auto;
        position: relative
    }

    .l-col-1 {
        grid-column: span 1
    }

    .l-col-2 {
        grid-column: span 2
    }

    .l-col-3 {
        grid-column: span 3
    }

    .l-col-4 {
        grid-column: span 4
    }

    .l-col-5 {
        grid-column: span 5
    }

    .l-col-6 {
        grid-column: span 6
    }

    .l-col-7 {
        grid-column: span 7
    }

    .l-col-8 {
        grid-column: span 8
    }

    .l-col-9 {
        grid-column: span 9
    }

    .l-col-10 {
        grid-column: span 10
    }

    .l-col-11 {
        grid-column: span 11
    }

    .l-col-12 {
        grid-column: span 12
    }

    .l-col-del {
        display: none
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .row {
        display: grid;
        grid-template-columns:repeat(12, 1fr);
        max-width: 1024px;
        padding: 0 15px;
        grid-gap: 10px;
        margin: 0 auto;
        position: relative
    }

    .m-col-1 {
        grid-column: span 1
    }

    .m-col-2 {
        grid-column: span 2
    }

    .m-col-3 {
        grid-column: span 3
    }

    .m-col-4 {
        grid-column: span 4
    }

    .m-col-5 {
        grid-column: span 5
    }

    .m-col-6 {
        grid-column: span 6
    }

    .m-col-7 {
        grid-column: span 7
    }

    .m-col-8 {
        grid-column: span 8
    }

    .m-col-9 {
        grid-column: span 9
    }

    .m-col-10 {
        grid-column: span 10
    }

    .m-col-11 {
        grid-column: span 11
    }

    .m-col-12 {
        grid-column: span 12
    }

    .m-col-del {
        display: none
    }
}

@media (min-width: 481px) and (max-width: 768px) {
    .mobile {
        display: inherit
    }

    .desktop {
        display: none
    }

    .row {
        display: grid;
        grid-template-columns:repeat(12, 1fr);
        max-width: 1120px;
        grid-gap: 10px;
        margin: 0 auto;
        padding: 0 10px;
        position: relative
    }

    .s-col-1 {
        grid-column: span 1
    }

    .s-col-2 {
        grid-column: span 2
    }

    .s-col-3 {
        grid-column: span 3
    }

    .s-col-4 {
        grid-column: span 4
    }

    .s-col-5 {
        grid-column: span 5
    }

    .s-col-6 {
        grid-column: span 6
    }

    .s-col-7 {
        grid-column: span 7
    }

    .s-col-8 {
        grid-column: span 8
    }

    .s-col-9 {
        grid-column: span 9
    }

    .s-col-10 {
        grid-column: span 10
    }

    .s-col-11 {
        grid-column: span 11
    }

    .s-col-12 {
        grid-column: span 12
    }

    .s-col-del {
        display: none
    }
}

@media (max-width: 480px) {
    .row {
        display: grid;
        grid-template-columns:repeat(12, 1fr);
        max-width: 1120px;
        grid-gap: 10px;
        padding: 0 20px;
        margin: 0 auto;
        position: relative
    }

    .xs-col-1 {
        grid-column: span 1
    }

    .xs-col-2 {
        grid-column: span 2
    }

    .xs-col-3 {
        grid-column: span 3
    }

    .xs-col-4 {
        grid-column: span 4
    }

    .xs-col-5 {
        grid-column: span 5
    }

    .xs-col-6 {
        grid-column: span 6
    }

    .xs-col-7 {
        grid-column: span 7
    }

    .xs-col-8 {
        grid-column: span 8
    }

    .xs-col-9 {
        grid-column: span 9
    }

    .xs-col-10 {
        grid-column: span 10
    }

    .xs-col-11 {
        grid-column: span 11
    }

    .xs-col-12 {
        grid-column: span 12
    }

    .xs-col-del {
        display: none
    }

    .mobile {
        display: inherit
    }

    .desktop {
        display: none
    }
}

a:focus, a:active {
    outline: none
}

.d_f {
    display: -ms-flexbox;
    display: flex
}

.f_c {
    -ms-flex-direction: column;
    flex-direction: column
}

.ta-c {
    text-align: center
}

.w_100 {
    width: 100%
}

.h_100 {
    height: 100%
}

.h_75 {
    height: 75%
}

.h_50 {
    height: 50%
}

.h_25 {
    height: 25%
}

.h_100vh {
    min-height: 100vh;
    height: 100%
}

.w_200 {
    width: 200%
}

.pos_r {
    position: relative
}

.to_ct {
    -webkit-transform-origin: center top;
    transform-origin: center top
}

.bgs_con, .bgs_cov {
    background-position: 50%;
    background-repeat: no-repeat
}

.bgs_con {
    background-size: contain
}

.bgs_cov {
    background-size: cover
}

.sc_105 {
    -webkit-transform: scale(1.05);
    transform: scale(1.05)
}

.to_rb {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom
}

.pos_a, .pos_f {
    top: 0;
    right: auto;
    bottom: auto;
    left: 0;
    position: absolute
}

.c_w {
    color: #fff
}

.ai_c {
    -ms-flex-align: center;
    align-items: center
}

.ai_s {
    -ms-flex-align: start;
    align-items: flex-start
}

.ai_base {
    -ms-flex-align: baseline;
    align-items: baseline
}

.jc_c {
    -ms-flex-pack: center;
    justify-content: center
}

.jc_sb {
    -ms-flex-pack: justify;
    justify-content: space-between
}

.jc_end {
    -ms-flex-pack: end;
    justify-content: flex-end
}

.ml_a {
    margin-left: auto
}

.left-col, .middle-col, .right-col, .full-col {
    height: 100vh;
    margin: 0
}

.width-0 {
    width: 0
}

.width-18 {
    width: 18%
}

.width-28 {
    width: 28%
}

.width-33 {
    width: 33.33%
}

.width-38 {
    width: 38%
}

.width-66 {
    width: 66.66%
}

.width-40 {
    width: 40%
}

.width-45 {
    width: 45%
}

.width-47 {
    width: 47%
}

.width-50 {
    width: 50%
}

.width-53 {
    width: 53%
}

.width-55 {
    width: 55%
}

.width-60 {
    width: 60%
}

.width-62 {
    width: 62%
}

.width-100 {
    width: 100%
}

.oh-wrap {
    overflow: hidden
}

.j_parlxContent {
    padding-left: 30px
}

.pl30 {
    padding-left: 30px
}

.pl80 {
    padding-left: 80px
}

.pl90 {
    padding-left: 90px
}

.pl170 {
    padding-left: 170px
}

.pl_250 {
    padding-left: 250px
}

.pt30 {
    padding-top: 30px
}

.pt5vmax {
    padding-top: 5vmax
}

.pb5vmax {
    padding-bottom: 5vmax
}

.pt45p {
    padding-top: 45%
}

.bg_brown {
    background-color: #493648
}

.bg_lighgray {
    background-color: #d8cbcb
}

.color-1 {
    color: #000
}

.color-2 {
    color: #d2cdcc
}

.hidden {
    visibility: hidden
}

.btn-w a:first-child {
    margin-right: 25px
}

.btn {
    padding: 0 12px;
    display: -ms-inline-flexbox;
    display: inline-flex;
    min-width: 210px;
    height: 60px;
    color: #e24b33;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    border: 2px solid #e24b33;
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 1px;
    position: relative;
    overflow: hidden;
    transition: 1s color
}

.btn > * {
    position: relative
}

.btn:before {
    content: '';
    display: block;
    position: absolute;
    top: 76px;
    left: 0;
    width: 100%;
    height: 76px;
    background-image: url(../images/btnwave.svg);
    background-position: 0% 0%;
    transition: 1s all
}

.btn:hover, .btn.active {
    color: #fff;
    transition: 1s color
}

.btn:hover:before, .btn.active:before {
    top: -19px;
    transition: 1s all;
    background-position: 100% 0%
}

.btn.active:hover {
    color: #e24b33
}

.btn.active:hover:before {
    top: 76px;
    transition: 1s all;
    background-position: 0% 0%
}

.btn.btn-disabled {
    color: #454545;
    border: 2px solid #a7a7a7;
    cursor: default
}

.btn.btn-disabled:hover:before {
    display: none
}

.btn.btn-fill {
    background: #e24b33;
    transition: .3s background-color;
    color: #fff
}

.btn.btn-fill:hover {
    background: rgba(226, 75, 51, .8);
    transition: .3s background-color
}

.btn.btn-fill:hover:before {
    display: none
}

.btn.btn-green {
    background: #649b50;
    border-color: #649b50;
    color: #fff
}

.btn.btn-green .ico {
    width: 24px;
    height: 24px;
    background-size: contain
}

.btn.btn-green:hover {
    background: rgba(100, 155, 80, .8);
    transition: .3s background-color
}

.btn.btn-green:hover:before {
    display: none
}

@-webkit-keyframes btnBg {
    0% {
        background-position-x: 0
    }
    100% {
        background-position-x: 100%
    }
}

@keyframes btnBg {
    0% {
        background-position-x: 0
    }
    100% {
        background-position-x: 100%
    }
}

.mask--brown {
    position: relative
}

.mask--brown:before {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(54, 38, 51, .9)
}

.mask--brown > * {
    position: relative
}

.mask--orange {
    position: relative
}

.mask--orange:before {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(226, 75, 51, .85)
}

.mask--orange > * {
    position: relative
}

.mask--gray {
    position: relative
}

.mask--gray:before {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(186, 169, 168, .8)
}

.mask--gray > * {
    position: relative
}

.slogan {
    color: #fff
}

sup {
    font-size: 50%;
    line-height: 0;
    vertical-align: super
}

.j_parallaxEl {
    -webkit-transform: scale(1.12);
    transform: scale(1.12)
}

.panomap2 .dragger__el {
}

.panomap1 .dragger__el {
    width: 703px;
    height: 552px
}

.dragger__trigger {
    -ms-flex-pack: start;
    justify-content: flex-start;
    display: -ms-flexbox;
    display: flex;
    top: 0;
    bottom: auto;
    position: absolute;
    left: 0;
    right: auto;
    height: 100%;
    width: 100%
}

.dragger__arrow {
    width: 60px;
    height: 60px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-transform-origin: center center;
    transform-origin: center center
}

.dragger__end, .dragger__start {
    width: 3rem;
    height: 3rem;
    border-radius: 100%;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -ms-flex-positive: 0;
    flex-grow: 0
}

.dragger__dash {
    width: 2px;
    height: 2px;
    background-color: #000;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -ms-flex-positive: 0;
    flex-grow: 0;
    transition: .4s
}

.flex_ac {
    -ms-flex-align: center;
    align-items: center
}

.flex_jsb {
    -ms-flex-pack: justify;
    justify-content: space-between
}

.dragger {
    overflow: hidden !important;
    position: relative !important
}

.my-swiper-thumbs {
    position: absolute;
    z-index: 5;
    bottom: 25px;
    right: 25px
}

.my-swiper-thumbs ul {
    display: -ms-flexbox;
    display: flex
}

.my-swiper-thumbs li {
    margin-right: 20px;
    cursor: pointer
}

.my-swiper-thumbs li.active {
    border-bottom: 2px solid green
}

.aparts-pad {
    padding: 25px;
    background: url(../images/pat--leftmenu-wave.svg) repeat #f1f1f1
}

.aparts-pad .swiper-slide {
    padding: 25px
}

.aparts-pad .swiper-slide img {
    max-width: 100%
}

.roza {
    width: 94px;
    height: 97px;
    background: url(../images/roza.svg) 0 0 no-repeat;
    position: absolute;
    left: 5%;
    bottom: 5%
}

.eye-north {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    top: 50px;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: center;
    align-items: center
}

.eye-north svg {
    margin-bottom: 5px
}

.eye-north span {
    color: #858585;
    font-size: 12px
}

.eye-west {
    position: absolute;
    left: 0;
    -webkit-transform: translateY(-50%) rotate(-90deg);
    transform: translateY(-50%) rotate(-90deg);
    top: 50%
}

.eye-west svg {
    margin-left: 5px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.eye-west span {
    color: #858585;
    font-size: 12px
}

.eye-east {
    position: absolute;
    right: 0;
    -webkit-transform: translateY(-50%) rotate(-90deg);
    transform: translateY(-50%) rotate(-90deg);
    top: 50%
}

.eye-east svg {
    margin-left: 5px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg)
}

.eye-east span {
    color: #858585;
    font-size: 12px
}

.fancybox-content.popup {
    background: #493648;
    padding: 35px;
    max-width: 640px;
    color: #fff
}

.fancybox-content.popup h2 {
    color: #fff;
    font-size: 2.5vmax;
    font-weight: 800;
    margin-bottom: 25px;
    padding-right: 50px
}

table {
    max-width: 600px
}

table td {
    border-collapse: collapse;
    padding: 5px;
    border: 1px solid #80687f;
    font-size: 12px
}

.tabs .tabs_header {
    display: -ms-flexbox;
    display: flex
}

.tabs .tabs_header .tab_trigger {
    padding: 12px 15px;
    margin-right: 10px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    font-weight: 800;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #e24b33;
    line-height: 1.2
}

.tabs .tabs_header .tab_trigger span {
    border-bottom: 1px dashed rgba(226, 75, 51, .5)
}

.tabs .tabs_header .tab_trigger.active {
    cursor: default;
    background: #e24b33;
    color: #fff
}

.tabs .tabs_content .tab-content {
    display: none
}

.tabs .tabs_content .tab-content.active {
    display: block
}

.a_b {
    margin-left: 20px
}

.a_b li {
    width: 39px;
    height: 39px;
    color: #fff;
    background: #c5c5c5;
    font-size: 24px;
    font-weight: 600
}

.a_b li.active {
    background: #e24b33
}

.mCSB_dragger_bar {
    background-color: #baa9a8
}

.mCSB_dragger_bar:hover {
    background-color: #baa9a8
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
    background-color: #baa9a8 !important;
    width: 8px !important;
    border-radius: 0 !important
}

.mCSB_scrollTools {
    width: 8px !important
}

.mCSB_inside > .mCSB_container {
    margin-right: 8px !important
}

.mCSB_scrollTools .mCSB_draggerRail {
    width: 8px !important;
    background-color: #fff !important
}

.ico {
    display: inline-block
}

.ico-left {
    margin-right: 10px
}

.ico-right {
    margin-left: 10px
}

.ico-tel-w {
    width: 16px;
    height: 27px;
    background: url(../images/ico-tel-w-16-27.svg) 0 0 no-repeat
}

.ico-chat-w {
    width: 28px;
    height: 26px;
    background: url(../images/ico-chat-w-28-26.svg) 0 0 no-repeat
}

.ico-wt-w {
    width: 26px;
    height: 26px;
    background: url(../images/ico-wt-w-14-14.svg) center center no-repeat;
    background-size: contain
}

.ico-tg-w {
    width: 26px;
    height: 26px;
    background: url(../images/ico-tg-w-15-13.svg) center center no-repeat;
    background-size: contain
}

.ico-ig-w {
    width: 15px;
    height: 15px;
    background: url(../images/ico-ig-w-15-15.svg) 0 0 no-repeat
}

.ico-fb-w {
    width: 8px;
    height: 15px;
    background: url(../images/ico-fb-w-8-15.svg) 0 0 no-repeat
}

.ico-arrowmenu {
    width: 9px;
    height: 14px;
    background: url(../images/ico-arrowmenu.svg) 0 0 no-repeat
}

.form label {
    color: #d2cdcc;
    font-size: 12px
}

.form input[type=submit] {
    background: 0 0;
    width: 210px;
    font-weight: 800
}

.form .form-control {
    margin-bottom: 20px
}

.form-control {
    background: 0 0;
    border: none;
    border-bottom: 1px solid rgba(210, 205, 204, .5);
    font-size: 14px;
    line-height: 1;
    color: #d2cdcc;
    width: 100%;
    height: 40px;
    font-family: inherit;
    padding: 0
}

textarea.form-control {
    padding-top: 10px
}

.cb {
    position: relative;
    cursor: pointer;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center
}

.cb input[type=checkbox] {
    opacity: 0
}

.cb span {
    display: inline-block;
    width: 21px;
    height: 21px;
    border: 2px solid #d2cdcc;
    position: relative
}

.cb:hover span {
    opacity: .9
}

.cb input[type=checkbox]:checked + span:before {
    display: block;
    position: absolute;
    content: '×';
    font-size: 26px;
    line-height: 1;
    color: #d2cdcc;
    left: 1px;
    top: -4px
}

.fancy-form.fancybox-content {
    background: #493648;
    padding: 35px;
    max-width: 640px
}

.fancy-form.fancybox-content h2 {
    color: #fff;
    font-size: 2.5vmax;
    font-weight: 800;
    margin-bottom: 25px
}

.fancy-form.fancybox-content h3 {
    color: #fff;
    font-size: 1.6vmax;
    font-weight: 800;
    margin-bottom: 25px
}

.fancy-form.fancybox-content label {
    margin-top: 20px;
    margin-bottom: 20px
}

.fancy-form.fancybox-content .btn-w .btn:first-child {
    margin-right: 15px
}

.fancybox-close-small {
    width: 43px !important;
    height: 42px !important;
    background: url(../images/fancy-close.svg) 0 0 no-repeat !important
}

.fancybox-close-small svg {
    display: none !important
}

.fancybox-slide--html .fancybox-close-small {
    right: 20px !important;
    top: 20px !important
}

.fancybox-navigation.imgs {
    z-index: 99995;
    position: absolute;
    width: 60px;
    top: 0;
    right: 0;
    bottom: 0
}

.fancybox-button.imgs {
    width: 64px !important;
    height: 64px !important;
    background: #362633 !important
}

.custom-form .wpcf7 form.invalid .wpcf7-response-output, .custom-form .wpcf7 form.unaccepted .wpcf7-response-output {
    color: #fff;
    font-size: 12px;
    padding: 5px
}

.custom-form .wpcf7 form .wpcf7-response-output {
    margin: 10px 0 0;
    max-width: 550px
}

.custom-form .wpcf7 form.sent .wpcf7-response-output {
    color: #fff;
    font-size: 12px;
    padding: 5px
}

.custom-form .wpcf7 .ajax-loader {
    position: absolute;
    right: 0
}

.custom-form .wpcf7-not-valid-tip {
    font-size: 11px;
    display: none !important
}

.custom-form .wpcf7-submit {
    margin-right: 15px
}

.custom-form .form-control.wpcf7-not-valid {
    background: rgba(181, 63, 0, .5)
}

.header {
    background: rgba(0, 0, 0, .5);
    width: 100%;
    height: 75px;
    padding-left: 250px;
    margin-bottom: -75px;
    z-index: 2;
    position: relative
}

.top-menu {
    position: fixed;
    right: 0;
    top: -75px;
    z-index: 999;
    transition: .3s top;
    display: -ms-flexbox;
    display: flex
}

.top-menu.visible {
    top: 0;
    transition: 1s top
}

.top-square {
    width: 75px;
    height: 75px
}

.top-square.msg {
    background-color: #e24b33
}

.top-square.tel {
    background-color: rgba(0, 0, 0, .5)
}

.top_tel {
    font-size: 16px;
    margin-right: 50px
}

.top_contact {
    font-size: 14px;
    background: #e24b33;
    width: 224px;
    height: 75px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center
}

.top_lang {
    width: 80px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    cursor: pointer;
    position: relative;
    height: 100%
}

.top_lang ul {
    transition: opacity .3s;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 75px;
    left: 0;
    width: 80px;
    background: rgba(0, 0, 0, .5)
}

.top_lang ul li {
    height: 80px
}

.top_lang ul li a {
    width: 80px;
    height: 80px
}

.top_lang ul li:hover {
    transition: all .3s;
    background: #2d202c
}

.top_lang:hover ul, .top_lang:focus ul {
    opacity: 1;
    transition: opacity .3s;
    pointer-events: all
}

.arrow {
    position: absolute;
    z-index: 100;
    top: 50%;
    cursor: pointer;
    width: 44px;
    height: 44px
}

#leftArrow, #leftArrow2, .leftarrow {
    right: 0;
    top: calc(50% - 23px);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

#rightArrow, #rightArrow2, .rightarrow {
    right: 0;
    top: calc(50% + 23px)
}

.slide {
    width: 100vw;
    height: 100vh;
    overflow: hidden
}

.slide h1 {
    margin-top: 115px;
    font-size: 3vmax;
    text-align: left;
    line-height: 4.5vmax
}

.slide .j_parlxContent {
    padding-left: 281px
}

.slide .j_parlxContent .desc {
    margin-top: 30px;
    font-size: 22px;
    line-height: 30px
}

.slide .j_parlxContent .desc span {
    display: block
}

.slide.slide2 .slider-square .title {
    font-size: 60px
}

.slide.slide2 .slider-square .title span {
    position: absolute;
    right: -27px;
    top: 2px;
    font-size: 23px
}

.slide.slide2 .slider-square .ss-desc {
    margin-top: 15px
}

.slide.slide3 .slider-square .title {
    font-size: 43px
}

.slide.slide3 .slider-square .title span {
    position: absolute;
    right: -27px;
    top: 2px;
    font-size: 23px
}

.slide.slide3 .slider-square .ss-desc {
    margin-top: 15px
}

.slide.slide4 .slider-square .title {
    font-size: 43px
}

.slide.slide4 .slider-square .title span {
    position: absolute;
    right: -27px;
    top: 2px;
    font-size: 23px
}

.slide.slide4 .slider-square .ss-desc {
    margin-top: 15px
}

.slider-square {
    background: #649b50;
    width: 192px;
    height: 192px;
    right: 110px;
    top: 40%;
    left: auto
}

.slider-square .title {
    font-weight: 500;
    font-size: 82px;
    position: relative
}

.slider-square .title span {
    position: absolute;
    right: -24px;
    top: 5px;
    font-size: 31px
}

.slider-square .title b {
    position: absolute;
    left: -24px;
    top: 5px;
    font-weight: 600;
    font-size: 12px;
    line-height: 15px;
    color: #362633
}

.slider-square .ss-desc {
    text-align: center;
    font-size: 12px;
    line-height: 20px;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 1px
}

.logo-w {
    height: 90px;
    background: #baa9a8;
    position: relative;
    z-index: 2;
    transition: .75s height
}

.logo-w:after {
    content: '';
    display: block;
    width: 257px;
    height: 17px;
    position: absolute;
    bottom: -11px;
    left: 0;
    background: url(../images/leftmenu-wave-top2.svg) 0 0 repeat-x
}

.logo {
    background: url(../images/logo.svg) 0 0 no-repeat;
    width: 130px;
    height: 130px;
    opacity: 0;
    transition: .3s all;
    -webkit-transform: scale(.8);
    transform: scale(.8)
}

.logo-s {
    opacity: 1;
    background: url(../images/logo-s.svg) 0 0 no-repeat;
    width: 59px;
    height: 59px;
    position: absolute;
    right: 17px;
    top: 13px
}

.menu-items {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    position: relative;
    margin-top: 40px
}

.main-menu {
    position: fixed;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-align: center;
    align-items: center;
    top: 0;
    height: 100vh;
    background-color: #362631;
    left: -167px;
    width: 257px;
    z-index: 999;
    transition: .3s all ease-out
}

.main-menu .menu-text {
    color: #d2cdcc;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    transition: opacity 1s;
    opacity: 1;
    position: absolute;
    right: 18px;
    text-transform: uppercase;
    top: 50%
}

.main-menu .menu-text:after {
    content: '';
    display: block;
    position: absolute;
    bottom: -18px;
    left: 50%;
    -webkit-transform: translateX(-50%) rotate(90deg);
    transform: translateX(-50%) rotate(90deg);
    background: url(../images/ico-menu-arr.svg) 0 0 no-repeat;
    width: 9px;
    height: 14px
}

.main-menu ul li {
    margin: 20px 0
}

.main-menu ul li a {
    font-weight: 600;
    text-decoration: none;
    font-size: 12px;
    letter-spacing: 1px;
    text-transform: uppercase;
    position: relative
}

.main-menu ul li a:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 0;
    height: 3px;
    background: #e24b33
}

.main-menu ul li a:hover:before {
    transition: .3s width;
    width: 100%
}

.main-menu.active {
    left: 0;
    background-color: #362631;
    transition: .75s left ease-out
}

.main-menu.active .logo {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    transition: .9s all
}

.main-menu.active .logo-w {
    background: url(../images/pat--leftmenu-wave.svg) 0 0 repeat-y #baa9a8
}

.main-menu.active .logo-s {
    opacity: 0 !important;
    transition: opacity .3s
}

.main-menu.active .menu-text {
    transition: opacity .3s;
    opacity: 0;
    pointer-events: none
}

.main-menu.active .leftmenu--footer {
    transition: opacity 1s;
    opacity: .3
}

.main-menu.active .logo-w {
    height: 216px;
    transition: .75s height
}

.leftside-tel {
    margin-top: auto;
    border-top: 1px solid rgba(255, 255, 255, .3);
    border-bottom: 1px solid rgba(255, 255, 255, .3);
    padding: 15px 0;
    font-size: 16px;
    font-weight: 600;
    width: calc(100% - 50px)
}

.leftmenu--footer {
    padding-bottom: 37px;
    margin-top: auto;
    color: #fff;
    font-size: 10px;
    line-height: 16px;
    transition: opacity .3s;
    opacity: 0
}

.social-btns {
    margin-bottom: 15px
}

.social-btns a {
    width: 26px;
    height: 26px;
    margin: 0 5px
}

@media (max-width: 980px) {
    .main-menu {
        -ms-flex-align: start;
        align-items: flex-start
    }

    .menu-items, .leftside-tel, .leftmenu--footer {
        margin-left: 25px
    }

    .leftmenu--footer {
        margin-top: 20px;
        padding-bottom: 67px
    }
}

#home_screen {
    overflow: hidden
}

#home_screen .j_parallaxEl:after {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.59) 43.16%, rgba(0, 0, 0, 0) 100%)
}

#panelWrap .j_parallaxEl {
    -webkit-transform: scale(1) !important;
    transform: scale(1) !important
}

.main-btn-next {
    position: absolute;
    bottom: 40px;
    left: 292px;
    z-index: 99;
    color: #d2cdcc;
    cursor: pointer
}

.main-btn-next:before, .main-btn-next:after {
    content: '';
    display: block;
    position: absolute
}

.main-btn-next:before {
    background: url(../images/ico-down-1.svg) 0 0 no-repeat;
    width: 22px;
    height: 21px;
    top: -35px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    transition: .3s all;
    -webkit-animation: btnnext-1 1s infinite;
    animation: btnnext-1 1s infinite
}

.main-btn-next:after {
    background: url(../images/ico-down-2.svg) 0 0 no-repeat;
    width: 22px;
    height: 14px;
    top: -20px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    transition: .3s all;
    -webkit-animation: btnnext-2 1s infinite;
    animation: btnnext-2 1s infinite
}

#main-menu .main-btn-next {
    opacity: 0;
    pointer-events: none;
    left: 210px
}

body.leftMenuThin #home_screen .main-btn-next {
    opacity: 0;
    pointer-events: none;
    transition: opacity 1s
}

body.leftMenuThin #main-menu .main-btn-next {
    opacity: 1;
    pointer-events: all;
    transition: opacity 1s
}

body.leftMenuThin #main-menu.active .main-btn-next {
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s
}

@-webkit-keyframes btnnext-1 {
    0% {
        top: -35px
    }
    50% {
        top: -40px
    }
    100% {
        top: -35px
    }
}

@keyframes btnnext-1 {
    0% {
        top: -35px
    }
    50% {
        top: -40px
    }
    100% {
        top: -35px
    }
}

@-webkit-keyframes btnnext-2 {
    0% {
        top: -20px
    }
    50% {
        top: -25px
    }
    100% {
        top: -18px
    }
}

@keyframes btnnext-2 {
    0% {
        top: -20px
    }
    50% {
        top: -25px
    }
    100% {
        top: -18px
    }
}

#section2 .slide {
    width: 100%;
    height: 100%;
    overflow: hidden
}

.mini-sec .title {
    height: 40px;
    text-transform: uppercase;
    font-size: 12px;
    line-height: 20px;
    letter-spacing: 1px
}

.mini-sec .title span {
    display: block
}

.mini-sec .number {
    font-weight: 500;
    font-size: 4vmax
}

.section--bottom {
    padding: 2vmax 4vmax
}

.section--top {
    padding: 2vmax 4vmax
}

.ms--b-left .title {
    padding-left: 30px
}

.ms--b-left .number {
    padding-left: 30px;
    border-left: 1px solid rgba(210, 205, 204, .3)
}

.panomap {
    position: absolute;
    left: 0;
    top: 0;
    right: auto;
    bottom: auto;
    pointer-events: none;
    opacity: 0;
    transition: .3s opacity
}

.panomap.active {
    pointer-events: all;
    opacity: 1;
    transition: .3s opacity
}

.map-logo {
    background: url(../images/logo-map.svg) 0 0 no-repeat;
    width: 90px;
    height: 90px;
    position: absolute
}

.map-point {
    cursor: pointer
}

.map-point:hover, .map-point.active {
    -webkit-animation: .5s hop ease;
    animation: .5s hop ease
}

.map-point:hover svg .bg, .map-point.active svg .bg {
    transition: .3s all;
    fill: #649b50;
    fill-opacity: 1
}

.map-point:hover .popup-info, .map-point.active .popup-info {
    opacity: 1;
    pointer-events: all;
    transition: .3s all
}

@-webkit-keyframes hop {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
    50% {
        -webkit-transform: scale(1.12);
        transform: scale(1.12)
    }
    80% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

@keyframes hop {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
    50% {
        -webkit-transform: scale(1.12);
        transform: scale(1.12)
    }
    80% {
        -webkit-transform: scale(1);
        transform: scale(1)
    }
}

.svg-line {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 0
}

.svg-line.active {
    opacity: 1;
    transition: .3s opacity
}

.line {
    stroke: #baa9a8
}

.line.active {
    stroke: #649b50;
    transition: .3s all
}

.section--pre {
    top: 40px;
    left: 80px;
    color: #e24b33;
    text-transform: uppercase;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px
}

.section--header {
    left: 80px;
    margin-top: 80px;
    font-size: 3vmax;
    line-height: 1.5;
    font-weight: 800
}

.scrolled_block li {
    padding: 19px;
    transition: .3s all;
    border-bottom: 1px solid rgba(54, 38, 51, .2);
    position: relative
}

.scrolled_block li .title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 20px;
    position: relative
}

.scrolled_block li .title:after {
    content: '';
    display: block;
    position: absolute;
    width: 105px;
    height: 1px;
    background: rgba(54, 38, 51, .2);
    left: 0;
    bottom: -10px;
    transition: .3s all
}

.scrolled_block li .ico-w {
    width: 26px;
    text-align: center;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-line-pack: center;
    align-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative
}

.scrolled_block li .time {
    font-size: 30px;
    margin-left: 10px;
    margin-right: 15px
}

.scrolled_block li .desc {
    font-size: 12px
}

.scrolled_block li .desc-w {
    position: relative
}

.scrolled_block li:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 0;
    background: #649b50;
    transition: .3s all ease
}

.scrolled_block li.active, .scrolled_block li:hover {
    color: #fff;
    transition: .1s all
}

.scrolled_block li.active:before, .scrolled_block li:hover:before {
    width: 100%;
    transition: .5s all ease
}

.scrolled_block li.active svg path, .scrolled_block li:hover svg path {
    fill: #fff;
    transition: .1s all
}

.scrolled_block li.active .title:after, .scrolled_block li:hover .title:after {
    background: #fff;
    transition: .1s all
}

.map--legend {
    background: #fff;
    position: absolute;
    left: 80px;
    top: calc(3vw + 120px);
    width: 27vw
}

.j-filter-scrollbar-wrapper {
    height: 30vmax
}

.scrollbar-inner {
    height: 30vmax
}

.switcher-w {
    z-index: 99;
    background: #fff;
    bottom: 0;
    height: 55px;
    position: absolute;
    width: 100%;
    font-size: 12px;
    color: #362633
}

.switcher-w .switcher {
    margin: 0 12px
}

.switcher {
    width: 50px;
    height: 28px;
    background: #e24b33;
    border-radius: 25px;
    cursor: pointer;
    position: relative
}

.switcher:after {
    display: block;
    content: '';
    position: absolute;
    left: 24px;
    top: 3px;
    width: 22px;
    height: 22px;
    background: #fff;
    border-radius: 50%;
    transition: .3s all ease-in
}

.switcher.left:after {
    transition: .3s all ease-in;
    left: 5px
}

.popup-info {
    position: absolute;
    background: #fff;
    width: 245px;
    left: -100px;
    top: 50px;
    opacity: 0;
    pointer-events: none
}

.popup-info .title {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
    position: relative;
    padding: 15px 15px 0
}

.popup-info .title:after {
    content: '';
    display: block;
    position: absolute;
    width: 105px;
    height: 1px;
    background: rgba(54, 38, 51, .2);
    left: 15px;
    bottom: -10px;
    transition: .3s all
}

.popup-info .desc-w {
    padding: 10px 15px 15px
}

.popup-info .ico-w {
    width: 26px;
    text-align: center;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-line-pack: center;
    align-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative
}

.popup-info .time {
    font-size: 30px;
    margin-left: 10px;
    margin-right: 15px
}

.popup-info .desc {
    font-size: 12px
}

.page-header {
    font-size: 3vmax;
    line-height: 3.5vmax;
    font-weight: 800
}

.page-img {
    margin: 2.5vmax 0 1vmax
}

.page-title {
    color: #e24b33;
    text-transform: uppercase;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 1px;
    margin-bottom: 20px
}

.page-desc {
    margin-top: 20px;
    font-size: calc(max(14px, 0.85vmax));
    line-height: calc(max(18px, 1.15vmax));
    max-width: 80%;
    position: relative;
    z-index: 2
}

.page-desc span {
    display: block
}

.page-desc .btn {
    margin-top: 50px
}

.card--bottom {
    background: #e9eaee;
    position: absolute;
    bottom: 0;
    width: calc(100% - 90px);
    height: 3.4rem
}

.card--bottom .ico-svg {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    width: 32px;
    margin-right: 12px
}

.card--bottom .title {
    font-size: 14px;
    font-weight: 600
}

.card--bottom.card-bottom--wave {
    height: 0;
    position: relative
}

.card--bottom.card-bottom--wave:after {
    content: '';
    display: block;
    position: absolute;
    bottom: -1px;
    left: 0;
    width: calc(100% + 90px);
    height: 23px;
    background: url(../images/cards-wave.svg) 0 0 repeat-x
}

.cards:nth-last-of-type(1) {
    z-index: 1;
    background: #d3d4dd
}

.cards:nth-last-of-type(1) .card--bottom {
    background: #d3d4dd
}

.cards:nth-last-of-type(2) {
    height: calc(100vh - 3.4rem);
    z-index: 2;
    background: #e9eaee
}

.cards:nth-last-of-type(2) .card--bottom {
    background: #e9eaee
}

.cards:nth-last-of-type(3) {
    height: calc(100vh - 6.8rem);
    z-index: 3;
    background: #d3d4dd
}

.cards:nth-last-of-type(3) .card--bottom {
    background: #d3d4dd
}

.cards:nth-last-of-type(4) {
    height: calc(100vh - 10.2rem);
    z-index: 4;
    background: #e9eaee
}

.cards:nth-last-of-type(4) .card--bottom {
    background: #e9eaee
}

.cards:nth-last-of-type(5) {
    height: calc(100vh - 13.6rem);
    z-index: 5
}

.cards .swiper-container {
    max-width: 640px
}

.card1 {
    background-color: #e9eaee
}

.card1 .page-title {
    margin-top: 25vh
}

.black-bg {
    background: rgba(0, 0, 0, .25);
    padding: 10px;
    max-width: 486px
}

.black-bg span {
    display: inline
}

.card2:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 83px;
    background: url(../images/cards-det-bg.svg) 0 0 repeat-x
}

.card2 #anim-kind {
    position: absolute;
    bottom: 134px;
    right: 30px
}

.card3:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 83px;
    background: url(../images/cards-spa-bg.svg) 0 0 repeat-x
}

.card3 #anim-spa {
    position: absolute;
    bottom: 134px;
    right: 30px
}

.card4:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 83px;
    background: url(../images/cards-velo-bg.svg) 0 0 repeat-x
}

.card4 #anim-velo {
    position: absolute;
    bottom: 134px;
    right: 30px
}

.card5:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 83px;
    background: url(../images/cards-auto-bg.svg) 0 0 repeat-x
}

.card5 #anim-auto {
    position: absolute;
    bottom: 134px;
    right: 30px
}

.cards .col-left {
    padding-top: 5vmax
}

.cards .col-right {
    padding-top: 5vmax;
    padding-bottom: 3.4rem
}

.cards .col-right img {
    width: auto;
    max-width: 100%;
    max-height: 59vh;
    height: 100%;
    position: relative;
    z-index: 2;
    margin: 0 auto
}

#section6 .col-right:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 83px;
    background: url(../images/section6-bg.svg) 0 0 repeat-x
}

#section6 .btn-w {
    margin-top: 4rem
}

#section7 .col-left:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 89px;
    background: url(../images/section7-bg.svg) 0 0 repeat-x
}

#section8 .col-right:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 3.4rem;
    width: 100%;
    height: 106px;
    background: url(../images/section8-bg.svg) 0 0 repeat-x
}

.rassrochka {
    margin-top: 25px
}

.rassrochka .num {
    font-size: 45px;
    font-weight: 600
}

.rassrochka .srok {
    text-transform: uppercase;
    font-size: 12px;
    color: #362633;
    padding-left: 60px;
    position: relative;
    margin-right: 22px
}

.rassrochka .srok:before {
    content: '';
    display: block;
    position: absolute;
    left: 30px;
    width: 1px;
    height: 44px;
    background: #baa9a8;
    top: -5px
}

.rassrochka .srok span {
    display: block
}

.swiper-process-bottom {
    background: #fff;
    height: 80px;
    position: absolute;
    z-index: 99;
    top: 0;
    width: 100%;
    left: 0;
    padding-right: 140px
}

#leftArrow9 {
    position: relative;
    padding-left: 26px;
    padding-top: 16px;
    cursor: pointer;
    width: 66px;
    height: 75px;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

#leftArrow9.swiper-button-disabled {
    opacity: .4
}

#rightArrow9 {
    position: relative;
    padding-left: 26px;
    padding-top: 16px;
    cursor: pointer;
    width: 66px;
    height: 75px;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

#rightArrow9.swiper-button-disabled {
    opacity: .4
}

.slide-desc .title {
    color: #858585;
    font-size: 14px;
    margin-bottom: 10px
}

.slide-desc ul li {
    text-transform: uppercase;
    font-size: 16px;
    text-align: center;
    font-weight: 600;
    letter-spacing: 1px;
    display: none
}

.slide-desc ul li.active {
    display: inherit
}

.apart-switcher-wrap ul {
    margin: 0;
    padding: 0;
    display: -ms-flexbox;
    display: flex
}

.apart-switcher-wrap ul li {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #fff;
    width: 68px;
    height: 68px;
    margin-right: 1px;
    background: #baa9a8;
    transition: .5s all;
    font-size: 11px;
    line-height: 1.1;
    cursor: pointer
}

.apart-switcher-wrap ul li span {
    font-size: 20px;
    font-weight: 500
}

.apart-switcher-wrap ul li.active {
    background: #649b50
}

.apart-switcher-wrap ul li.active:hover {
    background: rgba(100, 155, 80, .8);
    transition: .5s all
}

.apart-switcher-wrap ul li:hover {
    background: rgba(186, 169, 168, .8);
    transition: .5s all
}

.plan-desc, .plan-img {
    display: none
}

.plan-desc.active, .plan-img.active {
    display: block
}

.plan-nums {
    margin-top: 45px
}

.plan-nums .num {
    font-size: 45px;
    font-weight: 600
}

.plan-nums .pre {
    text-transform: uppercase;
    font-size: 12px;
    line-height: 1;
    color: #362633;
    position: relative;
    margin-right: 9px
}

.plan-nums .pre-w-line {
    padding-left: 60px
}

.plan-nums .pre-w-line:before {
    content: '';
    display: block;
    position: absolute;
    left: 30px;
    width: 1px;
    height: 44px;
    background: #baa9a8;
    top: -5px
}

.plan-nums .pre-w-line span {
    display: block
}

.plan-rooms {
    margin-top: 45px
}

.plan-rooms .ico-w {
    width: 30px;
    height: 25px;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-bottom: 5px;
    margin-right: 8px
}

.plan-rooms ul {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.plan-rooms ul li {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    margin-bottom: 15px
}

#contacts {
    padding-bottom: 60px
}

#contacts .tel {
    margin-bottom: 30px
}

#contacts .tel a {
    font-size: 45px;
    font-weight: 800
}

#contacts .tel .title {
    font-size: 16px;
    color: #d2cdcc;
    margin-top: 10px;
    font-weight: 600;
    letter-spacing: 1px
}

#contacts .btn {
    margin-top: 20px
}

.remont-thumbs {
    margin-top: 25px
}

.remont-thumbs ul {
    display: -ms-flexbox;
    display: flex
}

.remont-thumbs ul li {
    margin-right: 25px;
    cursor: pointer
}

.remont-thumbs ul li div {
    border: 3px solid #c4c4c4;
    margin-bottom: 15px;
    height: 80px
}

.remont-thumbs ul li.active div {
    border-color: #e24b33
}

.remont-thumbs ul li img {
    display: block;
    width: 100%;
    height: 100%
}

.remont-thumbs ul li span {
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 800
}

#section10 .page-header {
    font-size: 2.5vmax;
    line-height: 2vmax;
    margin-bottom: 2vmax
}

#section10 .page-header span {
    display: inline
}

#section10 .swiper-slide img {
    max-height: 70vh;
    height: 100%;
    width: 100%
}

#section10 .swiper-slide a {
    text-decoration: none;
    height: 100%;
    width: 100%;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center
}

#section10 .swiper-slide a:after {
    content: '+';
    font-size: 88px;
    position: absolute;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    opacity: 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #fff;
    background: #e24b33;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    transition: .5s all
}

#section10 .swiper-slide a:hover:after {
    opacity: .8;
    -webkit-transform: translate(-50%, -50%) scale(1.15);
    transform: translate(-50%, -50%) scale(1.15);
    transition: .5s all
}

#section10 .page-desc {
    display: none
}

#section10 .page-desc.active {
    display: inherit
}

#section10 .num .key {
    color: gray;
    font-size: 12px;
    text-transform: uppercase;
    margin-top: 15px;
    letter-spacing: 1px
}

#section10 .page-title ul li {
    cursor: pointer
}

.fancybox-is-open .fancybox-bg {
    background: url(../images/pat--leftmenu-wave.svg) repeat #f1f1f1 !important;
    opacity: 1 !important
}

#uniqPage .gallery a {
    display: -ms-flexbox;
    display: flex;
    position: relative
}

#uniqPage .gallery a:after {
    content: '+';
    font-size: 88px;
    position: absolute;
    width: 140px;
    height: 140px;
    border-radius: 50%;
    opacity: 0;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: #fff;
    background: #e24b33;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%) scale(1);
    transform: translate(-50%, -50%) scale(1);
    transition: .5s all;
    z-index: 2;
    pointer-events: none
}

#uniqPage .gallery a:hover:after {
    opacity: .8;
    -webkit-transform: translate(-50%, -50%) scale(1.15);
    transform: translate(-50%, -50%) scale(1.15);
    transition: .5s all
}

#section6 .col-right .remont-bottoms {
    margin-top: 40px;
    color: #000
}

#section6 .col-right .remont-bottoms a {
    color: #000;
    text-decoration: underline
}

#section6 .col-right .remont-bottoms li {
    display: none
}

#section6 .col-right .remont-bottoms li.active {
    display: block
}

#section7 .tabs {
    margin-top: 30px
}

.logo-f {
    width: 130px;
    height: 130px;
    background: url(../images/logo-f.svg) 0 0 no-repeat
}

#footer {
    background: #2d202c;
    height: 313px
}

#footer .title {
    color: #6c636c;
    text-transform: uppercase;
    font-size: 12px;
    margin-bottom: 6px
}

#footer .text {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
    color: #d2cdcc
}

#footer .text span {
    display: block
}

#footer .line1 {
    padding-top: 57px
}

#footer .line2 {
    font-size: 12px;
    line-height: 1.2;
    color: rgba(255, 255, 255, .3);
    margin-top: 50px
}

#footer .line2 span {
    display: block
}

#footer .line2 > div {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center
}

#footer .line2 .c1, #footer .line2 .c2 {
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: start;
    align-items: flex-start;
    -ms-flex-pack: center;
    justify-content: center
}

#footer .social-btns {
    margin-bottom: 0
}

#footer .social-btns a {
    display: block;
    opacity: .3;
    transition: .8s all
}

#footer .social-btns a:hover {
    opacity: 1;
    transition: .8s all
}

.logo-masshtab {
    width: 137px;
    height: 33px;
    display: block;
    background: url(../images/logo-masshtab.svg) 0 0 no-repeat
}

.mobile-header {
    position: fixed;
    top: 0;
    width: 100%;
    height: 65px;
    z-index: 9998;
    display: -ms-flexbox;
    display: flex
}

.mobile-header .logo-mob {
    width: 65px;
    height: 65px;
    background: url(../images/logo-s.svg) center center no-repeat #baa9a8;
    background-size: 53px 53px;
    display: block
}

.mobile-header .top-square {
    width: 65px;
    height: 65px
}

.mobile-header .menu-trigger {
    width: 65px;
    text-transform: uppercase;
    color: #d2cdcc;
    font-size: 12px;
    margin-right: auto;
    border-right: 1px solid rgba(255, 255, 255, .1);
    cursor: pointer
}

.mobile-header .top_tel {
    width: 65px;
    margin-right: 0;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    border-left: 1px solid rgba(255, 255, 255, .1);
    margin-left: 0
}

.mobile-header .top_tel span {
    margin: 0
}

.mobile-header .top_lang {
    width: 65px
}

.main-menu .layout {
    left: 100%;
    position: fixed;
    transition: .3s all;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: rgba(45, 32, 44, .8)
}

.main-menu.active .layout {
    left: 257px;
    transition: .9s all
}

.cls-btn {
    position: absolute;
    right: -60px;
    top: 11px;
    z-index: 99;
    cursor: pointer
}

.dragger_w {
    width: 60px;
    height: 60px;
    background: #e24b33;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative
}

.dragger_w:before, .dragger_w:after {
    position: absolute;
    display: block;
    content: ''
}

.dragger_w:before {
    width: 8px;
    height: 11px;
    background: url(../images/dragge-la.svg);
    left: 14px;
    top: 10px;
    transition: 1s all;
    -webkit-animation: 2s animArrowL infinite ease-in;
    animation: 2s animArrowL infinite ease-in
}

.dragger_w:after {
    width: 8px;
    height: 11px;
    background: url(../images/dragge-ra.svg);
    right: 0;
    top: 10px;
    transition: 1s all;
    -webkit-animation: 2s animArrowR infinite ease-in;
    animation: 2s animArrowR infinite ease-in
}

.dragger_w .dragger-hand {
    margin-top: 5px;
    width: 23px;
    height: 29px;
    background: url(../images/dragger-hand.svg)
}

.dragger_c {
    padding-right: 1rem;
    padding-left: 1rem;
    position: absolute;
    top: auto;
    bottom: 5%;
    left: 0;
    right: auto;
    width: 100%
}

@-webkit-keyframes animArrowL {
    0% {
        left: 14px
    }
    50% {
        left: 5px
    }
    100% {
        left: 14px
    }
}

@keyframes animArrowL {
    0% {
        left: 14px
    }
    50% {
        left: 5px
    }
    100% {
        left: 14px
    }
}

@-webkit-keyframes animArrowR {
    0% {
        right: 14px
    }
    50% {
        right: 5px
    }
    100% {
        right: 14px
    }
}

@keyframes animArrowR {
    0% {
        right: 14px
    }
    50% {
        right: 5px
    }
    100% {
        right: 14px
    }
}

.dragger__trigger {
    position: relative
}

.dragger__trigger:before {
    bottom: 30px;
    left: 0;
    position: absolute;
    display: block;
    content: '';
    width: 100%;
    height: 3px;
    background-image: linear-gradient(to right, white 22%, rgba(255, 255, 255, 0) 0%);
    background-position: bottom;
    background-size: 15px 3px;
    background-repeat: repeat-x
}

.ico-burger {
    position: relative;
    height: 12px;
    width: 20px;
    padding-top: 5px
}

.ico-burger:before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 20px;
    height: 2px;
    background: #e24b33
}

.ico-burger:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 20px;
    height: 2px;
    background: #e24b33
}

.ico-burger span {
    width: 20px;
    display: block;
    height: 2px;
    background: #e24b33
}

.loc-desktop {
    display: block
}

.loc-mobile {
    display: none
}

@media (max-width: 1550px) {
    .pl80 {
        padding-left: 50px
    }

    .pl170 {
        padding-left: 140px
    }

    .section--header, .section--pre, .map--legend {
        left: 50px
    }

    .slider-square {
    }

    .btn-w a:first-child {
        margin-right: 15px
    }
}

@media (max-width: 1440px) {
    .btn {
        min-width: 170px;
        height: 45px;
        font-size: 11px
    }

    .form input[type=submit] {
        max-width: 170px
    }

    .pl170 {
        padding-left: 110px
    }

    .pl80 {
        padding-left: 30px
    }
}

@media (max-width: 1179px) {
    #locpage {
        min-height: 550px
    }

    .scrolled_block li .title {
        font-size: 17px
    }

    .scrolled_block li .time {
        font-size: 24px
    }

    .scrolled_block li {
        padding: 12px
    }

    .eye-north {
        top: 30px
    }

    .eye-west {
        left: -40px
    }

    .eye-east {
        right: -50px
    }

    .plan-nums .num {
        font-size: 33px
    }

    .plan-nums .pre-w-line:before {
        height: 34px
    }

    .page-desc {
        max-width: 100%;
        padding-right: 20px
    }

    #section10 .width-60 {
        width: 55%
    }

    #section10 .width-40 {
        width: 45%
    }

    .btn-w a:first-child {
        margin-top: 20px
    }

    #contacts {
        padding-right: 20px
    }

    .cb span {
        -ms-flex-positive: 0;
        flex-grow: 0;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        -ms-flex-preferred-size: 21px;
        flex-basis: 21px
    }
}

@media (min-width: 981px) {
    .mobile {
        display: none
    }
}

.slider-square.mobile {
    display: none
}

.slider-square.desktop {
    display: -ms-flexbox;
    display: flex
}

@media (max-width: 980px) {
    .top_lang ul {
        top: 65px;
        width: 65px
    }

    .top_lang ul li {
        height: 65px
    }

    .top_lang ul li a {
        width: 65px;
        height: 65px
    }

    .slide.slide2 .slider-square .title span {
        right: -23px;
        font-size: 19px
    }

    sup {
        font-size: 80%
    }

    .slider-square.mobile {
        display: -ms-flexbox;
        display: flex;
        margin-top: 25px
    }

    .slider-square.desktop {
        display: none
    }

    .btn {
        width: auto;
        min-width: 130px;
        height: 33px;
        font-size: 10px
    }

    .form input[type=submit] {
        width: 130px
    }

    .m--f_c {
        -ms-flex-direction: column;
        flex-direction: column
    }

    .m--h_a {
        height: auto;
        min-height: auto
    }

    .m--h_100vh {
        height: 100%;
        min-height: auto
    }

    h1 span, h2 span {
        display: inline
    }

    #header {
        display: none
    }

    #mobile-header {
        display: -ms-flexbox;
        display: flex;
        background: #362633
    }

    #main-menu {
        left: -257px
    }

    #main-menu.active {
        left: 0
    }

    .col-left, .col-right, .left-col, .right-col {
        width: 100% !important;
        padding-left: 20px;
        padding-right: 20px
    }

    .col-left .swiper-container, .col-right .swiper-container, .left-col .swiper-container, .right-col .swiper-container {
        height: 50vh
    }

    .slide .j_parlxContent {
        padding-left: 20px;
        padding-right: 50px
    }

    .slider-square {
        top: auto;
        bottom: 15%
    }

    .pl170 {
        padding-left: 0
    }

    .pl80 {
        padding-left: 0
    }

    .pl90 {
        padding-left: 0
    }

    #uniqPage > div.pos_a {
        position: relative
    }

    .main-btn-next {
        display: none
    }

    .slide .j_parlxContent .desc {
        font-size: 2.4vmax;
        line-height: 1.3;
        margin-top: 20px
    }

    .slider-square {
        width: 130px;
        height: 130px;
        right: auto;
        left: 20px;
        padding: 5px
    }

    .slider-square .title {
        font-size: 62px
    }

    .slide.slide2 .slider-square .title {
        font-size: 36px
    }

    .slide.slide3 .slider-square .title, .slide.slide4 .slider-square .title {
        font-size: 26px
    }

    .slide.slide3 .slider-square .title b, .slide.slide4 .slider-square .title b {
        left: -19px;
        font-size: 10px
    }

    .slide.slide3 .slider-square .title span, .slide.slide4 .slider-square .title span {
        right: -23px;
        top: 2px;
        font-size: 17px
    }

    .slide.slide3 .slider-square .title sup, .slide.slide4 .slider-square .title sup {
        font-size: 60%
    }

    .slider-square .ss-desc {
        font-size: 10px;
        line-height: 1.4
    }

    #section2 .h_25 {
        min-height: 200px
    }

    #section2 .jc_sb {
        -ms-flex-pack: start;
        justify-content: flex-start
    }

    #section2 .left-col, #section2 .right-col {
        padding: 0
    }

    #section2 .section--bottom, #section2 .section--top {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    #section2 .section--bottom .mini-sec, #section2 .section--top .mini-sec {
        margin-right: 30px
    }

    #section2 .section--bottom .mini-sec .title, #section2 .section--top .mini-sec .title {
        font-size: 10px;
        line-height: 1.2;
        margin-bottom: 5px;
        height: 30px;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column;
        flex-direction: column;
        -ms-flex-pack: end;
        justify-content: flex-end
    }

    #section2 .section--bottom .mini-sec .number, #section2 .section--top .mini-sec .number {
        font-size: 6vmax
    }

    #section2 .section--bottom .mini-sec:last-child > *, #section2 .section--top .mini-sec:last-child > * {
    }

    #section2 .section--top {
        min-height: 120px;
        max-height: 120px
    }

    .page-header {
        font-size: 20px
    }

    .page-desc {
        margin-top: 15px;
        margin-bottom: 20px;
        max-width: 100%
    }

    .page-desc span {
        display: inline
    }

    .page-desc .btn {
        margin-top: 20px
    }

    #section7 > .d_f {
        -ms-flex-flow: column-reverse;
        flex-flow: column-reverse
    }

    #section7 .col-right {
        height: 50vh;
        padding-left: 0;
        padding-right: 0
    }

    #section7 .col-right * {
        height: 350px
    }

    #section7 .col-left {
        padding: 20px 20px 110px;
        height: auto
    }

    #section6 .col-left {
        padding: 0;
        height: 30vh
    }

    #section6 .col-left * {
        height: 30vh
    }

    #section6 .col-right {
        height: auto;
        padding-bottom: 100px
    }

    #section6 .col-right .remont-bottoms {
        margin-top: 22px
    }

    #section6 .col-right:after {
        bottom: 20px
    }

    #section6 .btn-w {
        margin-top: 1rem
    }

    #section6 .col-right:after {
        height: 52px
    }

    #section7 .col-left:after {
        height: 40px
    }

    #section8 .col-left {
        padding: 0;
        height: 50vh
    }

    #section8 .col-right {
        min-height: 40vh;
        padding-bottom: 120px
    }

    #section8 .col-right:after {
        height: 54px;
        background-position-x: -20px
    }

    #section9 .col-left {
        padding: 5vmax 20px 20px
    }

    #uniqPage .cards-wrapper {
        /*height: 0;*/
        max-height: 0;
        overflow: hidden
    }

    #uniqPage .cards.active .cards-desc {
        transition: .3s all
    }

    #uniqPage .card--bottom {
        position: relative;
        width: 100%;
        padding-left: 20px
    }

    #uniqPage .card2 .card--bottom:after, #uniqPage .card3 .card--bottom:after, #uniqPage .card4 .card--bottom:after, #uniqPage .card5 .card--bottom:after {
        display: block;
        content: '';
        position: absolute;
        right: 20px;
        top: 50%;
        -webkit-transform: translateY(-7px) rotate(90deg);
        transform: translateY(-7px) rotate(90deg);
        width: 9px;
        height: 14px;
        background: url(../images/ico-arrowmenu.svg) 0 0 no-repeat
    }

    #uniqPage .card2.active .card--bottom:after, #uniqPage .card3.active .card--bottom:after, #uniqPage .card4.active .card--bottom:after, #uniqPage .card5.active .card--bottom:after {
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg)
    }

    #uniqPage .cards {
        height: auto
    }

    #uniqPage .cards.card1 {
        height: 72.8vh;
        height: calc(var(--vh, 1vh) * 72.8)
    }

    #uniqPage .cards .col-right {
        padding: 0;
        height: 100vw
    }

    #uniqPage .card1 {
        padding: 0
    }

    #uniqPage .card1 .swiper-slide {
        padding: 0 50px 0 20px;
        background-size: cover
    }

    #uniqPage .card-ex.expanded .card--bottom:after {
        -webkit-transform: rotate(270deg);
        transform: rotate(270deg);
        -webkit-transform-origin: 50% 50%;
        transform-origin: 50% 50%
    }

    .cards:after {
        display: none
    }

    .card-bottom--wave {
        margin-left: -20px;
        margin-right: -20px;
        width: calc(100% + 40px)
    }

    #uniqPage .cards .col-right {
        padding-bottom: 0 !important;
        height: auto
    }

    #uniqPage .cards .col-right img {
        height: auto;
        width: auto
    }

    #section5 .col-left {
        padding-top: 40px;
        padding-bottom: 40px
    }

    #section5 .col-right {
        padding: 0
    }

    #section5 .col-right .width-50 {
        padding-top: 20px;
        padding-bottom: 20px
    }

    #section5 #anim-desk {
        width: 165px
    }

    #section5 #anim-cleaning, #section5 #anim-video {
        width: 75%;
        height: 75%
    }

    #section9 .col-right {
        padding: 0
    }

    #section9 .col-right .swiper-slide .h_100vh {
        height: 100%;
        min-height: auto
    }

    #section10 .pl30 {
        padding-left: 0
    }

    #section10 .col-left {
        padding-left: 0;
        padding-right: 0
    }

    #section10 .sc_105 {
        -webkit-transform: scale(1);
        transform: scale(1)
    }

    #section10 .plan-img img {
        width: 100%
    }

    .plan-nums .num {
        font-size: 30px
    }

    .plan-nums .pre-w-line:before {
        height: 25px
    }

    .plan-rooms ul li {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
        align-items: center
    }

    .plan-rooms ul li .ico-w {
        margin-right: 5px
    }

    .plan-rooms {
        margin-top: 25px
    }

    .pb5vmax {
        padding-bottom: 3vmax
    }

    .pt5vmax {
        padding-top: 3vmax
    }

    #contacts {
        padding-bottom: 25px
    }

    #contacts .tel a {
        font-size: 3vmax
    }

    #contacts .tel .title {
        font-size: 2vmax
    }

    #contacts .form {
        padding: 0 20px
    }

    #contacts .form .width-50 {
        width: 100%
    }

    #contacts .form .pl30 {
        padding-left: 0
    }

    #contacts .form .cb span {
        -ms-flex: none;
        flex: none
    }

    #footer {
        height: auto
    }

    #footer .text {
        font-size: 12px
    }

    #footer .line1 {
        padding-top: 20px;
        padding-left: 20px;
        padding-right: 20px;
        -ms-flex-align: start;
        align-items: flex-start;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }

    #footer .line1 .c3, #footer .line1 .c5 {
        display: none
    }

    #footer .line1 .c1, #footer .line1 .c2, #footer .line1 .c4 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%
    }

    #footer .line2 {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 20px;
        margin-top: 25px
    }

    #footer .line2 .c1, #footer .line2 .c2 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
        -ms-flex-direction: column;
        flex-direction: column
    }

    #footer .line2 .c2 {
        padding-left: 20px
    }

    #footer .line2 .c3 {
        display: none
    }

    #footer .line2 .c4, #footer .line2 .c5 {
        -ms-flex-preferred-size: 50%;
        flex-basis: 50%;
        padding-top: 20px
    }

    #footer .line2 .c5 {
        padding-left: 20px
    }

    #footer .width-18 {
        width: 100%
    }

    .form-control {
        font-size: 12px;
        height: 20px
    }

    .fancy-form.fancybox-content h2 {
        font-size: 24px;
        line-height: 1
    }

    .fancy-form.fancybox-content h3 {
        font-size: 20px;
        line-height: 1
    }

    .fancy-form.fancybox-content input[type=submit], .fancy-form.fancybox-content .btn {
        width: auto
    }

    .rassrochka .num {
        font-size: 4vmax
    }

    .section--pre {
        padding: 0 20px
    }

    .section--header {
        padding: 0 20px;
        margin: 0
    }

    .h_25 {
        height: 25vh
    }

    .h_75 {
        height: 75vh
    }

    #locpage {
        padding-top: 25px;
        min-height: auto
    }

    #section2 .right-col {
        height: 100%
    }

    .apart-switcher-wrap ul li {
        height: 40px
    }

    .apart-switcher-wrap ul li span {
        font-size: 14px
    }

    .plan-nums {
        margin-top: 25px
    }

    #section10 .swiper-slide a:after {
        font-size: 58px;
        width: 70px;
        height: 70px
    }

    #section10 .page-desc {
        padding-right: 0
    }

    .eye-west {
        left: -30px
    }

    .eye-east {
        right: -30px
    }

    .remont-thumbs {
        margin-top: 5px
    }

    .remont-thumbs ul li span {
        font-size: 12px
    }

    .eye-north {
        top: 13px;
        width: 100%
    }

    .aparts-pad {
        padding: 45px 25px 0
    }

    .plan-nums .pre {
        margin-top: 6px
    }

    .plan-desc-w sup {
        font-size: 70%
    }

    .map-point svg {
        width: 25px;
        height: 25px
    }

    .map-logo {
        width: 50px;
        height: 50px;
        background-size: contain
    }

    .map--legend {
        position: absolute;
        top: 5px;
        left: 0;
        width: 100%
    }

    .map--legend li {
        display: none
    }

    .map--legend li.active {
        display: -ms-flexbox;
        display: flex;
        background: #649b50;
        color: #fff;
        padding: 10px;
        -ms-flex-direction: column;
        flex-direction: column
    }

    .map--legend li.active .desc-w {
        font-size: 12px;
        margin-top: 5px
    }

    .map--legend li.active .ico-w {
        display: none
    }

    .map--legend li.active .desc br {
        display: none
    }

    .map--legend li.active .time {
        margin-right: 3px
    }

    .loc-desktop {
        display: none
    }

    .loc-mobile {
        display: block
    }

    #card1 .swiper-slide .jc_c {
        -ms-flex-pack: end;
        justify-content: flex-end;
        padding-bottom: 3.5rem
    }

    #section2 .right-col .w_200 {
        width: 119%
    }

    #section2 .right-col .h_75 {
        height: auto
    }

    #card1 .sec-left.width-66 {
        width: 100%;
        padding-left: 20px
    }

    #card1 .sec-right {
        display: none
    }

    .fancybox-content.popup {
        max-width: 100%
    }

    .fancybox-content.popup h2 {
        font-size: 24px;
        line-height: 1
    }

    .swiper-process-bottom {
        padding-right: 0
    }

    .fancybox-close-small {
        width: 32px !important;
        height: 32px !important;
        background-position: center center !important
    }

    .slide h1 {
        font-size: 4vmax
    }
}

@media (max-width: 640px) {
    #section2 .section--bottom .mini-sec:last-child > * {
        padding-left: 0;
        border: none
    }

    #section2 .section--bottom .mini-sec .number, #section2 .section--top .mini-sec .number {
        font-size: 5vmax
    }

    #section2 .left-col .swiper-container {
        height: 30vh
    }

    #section10 .col-left .swiper-container, #section10 .col-right .swiper-container, #section10 .left-col .swiper-container, #section10 .right-col .swiper-container {
        height: 30vh
    }

    .apart-switcher-wrap ul li {
        height: 30px;
        width: 25%;
        -ms-flex-direction: row;
        flex-direction: row
    }

    .apart-switcher-wrap ul li span {
        margin-right: 4px
    }

    .btn-w a:first-child {
        margin-top: 10px
    }

    .roza {
        width: 64px;
        height: 67px;
        left: 9%;
        background-size: contain
    }

    .plan-rooms ul li {
        font-size: 13px
    }

    .plan-rooms .ico-w {
        width: 25px;
        height: 25px
    }

    .slide3 .j_topImage {
        background-position: 39% bottom !important
    }

    .slide4 .j_topImage {
        object-position: 73% bottom !important
    }

    .slide1 .j_topImage {
        background-position: 64% bottom !important
    }

    .slide .j_parlxContent .desc span {
        display: inline
    }

    .arrow {
        width: 54px;
        height: 54px
    }

    #leftArrow, #leftArrow2, .leftarrow {
        top: calc(50% - 53px)
    }

    #rightArrow, #rightArrow2, .rightarrow {
        top: calc(50% + 4px)
    }

    #uniqPage .cards {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse
    }

    .cards .col-left {
        padding-top: 1vmax
    }
}

@media (max-width: 374px) {
    .plan-rooms ul li {
        -ms-flex-preferred-size: 100%;
        flex-basis: 100%
    }
}

@media (max-height: 768px) and (min-width: 980px) {
    .card1 .page-title {
        margin-top: 3vmax
    }

    #section6 .btn-w {
        margin-top: 2rem
    }

    .page-header {
        font-size: 7vh;
        line-height: 7vh
    }
}