/*$transitionEaseOut: cubic-bezier(.16,.65,.24,1);*/
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: inherit;
  font-size: 100%;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

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

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}

q, blockquote {
  quotes: none;
}
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}

a img {
  border: none;
}

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

@font-face {
  font-family: 'ProximaNova';
  src: url(fonts/proximanova-regular.eot);
  src: url(fonts/proximanova-regular.eot?#iefix) format("embedded-opentype"), url(fonts/proximanova-regular.woff2) format("woff2"), url(fonts/proximanova-regular.woff) format("woff"), url(fonts/proximanova-regular.ttf) format("truetype");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'ProximaNova';
  src: url(fonts/proximanova-bold.eot);
  src: url(fonts/proximanova-bold.eot?#iefix) format("embedded-opentype"), url(fonts/proximanova-bold.woff2) format("woff2"), url(fonts/proximanova-bold.woff) format("woff"), url(fonts/proximanova-bold.ttf) format("truetype");
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'ProximaNova';
  src: url(fonts/proximanova-semibold.woff2) format("woff2"), url(fonts/proximanova-semibold.woff) format("woff");
  font-weight: 600;
  font-style: normal;
}
.button {
  display: inline-block;
  text-align: center;
}

.button--blue {
  background-color: #00aeef;
  color: #ffffff;
}

.clearfix::after {
  clear: both;
  content: "";
  display: block;
}

.clickable {
  cursor: pointer;
}

.collapsible {
  position: relative;
}

.google-map {
  height: 100%;
  position: relative;
  top: 0;
  width: 100%;
  z-index: 0;
}

.icon {
  background: transparent no-repeat center / contain;
  display: inline-block;
  height: 1em;
  position: relative;
  width: 1em;
}

.icon-download--blue {
  background-image: url(images/icon-download--blue.png);
  top: 0.3em;
}

.icon-download--black {
  background-image: url(images/icon-download--black.png);
  top: 0.3em;
}

.icon-download--white {
  background-image: url(images/icon-download--white.png);
  top: 0.3em;
}

.icon-grid--blue {
  background-image: url(images/icon-grid--blue.png);
}

.icon-grid--transparent {
  background-image: url(images/icon-grid--transparent.png);
}

.icon-map--blue {
  background-image: url(images/icon-map--blue.png);
}

.icon-map--transparent {
  background-image: url(images/icon-map--transparent.png);
}

.icon-marker--blue {
  background-image: url(images/icon-marker--blue.png);
  height: 1.2em;
}

.icon-pencil--blue {
  background-image: url(images/icon-pencil--blue.png);
}

.icon-phone--blue {
  background-image: url(images/icon-phone--blue.png);
}

.icon-search--black {
  background-image: url(images/icon-search--black.png);
}

.nobr {
  white-space: nowrap;
}

.map-legend {
  background-color: #ffffff;
  bottom: 20px;
  padding: 8px;
  position: absolute;
  right: 20px;
  z-index: 1;
}
.map-legend .map-legend_content {
  border: 1px solid #000000;
  padding: 3px 8px;
}
.map-legend .marker-legend {
  align-items: center;
  display: flex;
  min-height: 30px;
  width: 90px;
}
.map-legend .marker-icon {
  flex: 0 0 15px;
  height: 22px;
}
.map-legend .marker-text {
  flex: 1;
  font-size: 14px;
  line-height: 1;
  margin: 0;
  padding: 0 0 0 5px;
}

.map-zoom {
  background-color: #ffffff;
  height: 102px;
  margin-top: -51px;
  padding: 8px 7px;
  position: absolute;
  right: 42px;
  top: 50%;
  width: 58px;
  z-index: 1;
}

.map-zoom--minus, .map-zoom--plus {
  background: transparent no-repeat center;
  border: 1px solid #000000;
  cursor: pointer;
  display: block;
  height: 44px;
  width: 44px;
}

.map-zoom--minus {
  background-image: url(images/map-zoom--minus.png);
  border-top-color: #cccccc;
}

.map-zoom--plus {
  background-image: url(images/map-zoom--plus.png);
}

.pointer-events_none {
  pointer-events: none;
}

.pswp__button--arrow--left::before,
.pswp__button--arrow--right::before {
  height: 20px;
  top: 40px;
  width: 46px;
}

.pswp__button--arrow--left::before {
  background: transparent url(images/slider-arrows.png) no-repeat left top;
  left: 20px;
}

.pswp__button--arrow--right::before {
  background: transparent url(images/slider-arrows.png) no-repeat right bottom;
  right: 20px;
}

.sticky {
  overflow: visible;
  position: relative;
  position: sticky;
  top: 0px;
  z-index: 10;
}
.sticky.position--fixed .sticky-content {
  position: fixed;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .sticky.position--fixed .sticky-content {
    top: 65px;
  }
}
@media screen and (max-width: 1023px) {
  .sticky.position--fixed .sticky-content {
    top: 9rem;
  }
}

.sticky-content {
  position: relative;
}

.swiper-navigation .swiper-button-next,
.swiper-navigation .swiper-button-prev {
  cursor: pointer;
  height: 20px;
  margin-top: -10px;
  position: absolute;
  top: 50%;
  width: 46px;
}
.swiper-navigation .swiper-button-next {
  background: transparent url(images/slider-arrows.png) no-repeat right bottom;
  right: 30px;
}
.swiper-navigation .swiper-button-prev {
  background: transparent url(images/slider-arrows.png) no-repeat left top;
  left: 30px;
}

.swiper-pagination.swiper-pagination--squares {
  font-size: 0;
}
.swiper-pagination.swiper-pagination--squares .swiper-pagination-bullet {
  background: transparent;
  border-style: solid;
  border-radius: 0;
  opacity: 1;
}
@media screen and (min-width: 1024px) {
  .swiper-pagination.swiper-pagination--squares {
    bottom: 40px;
    height: 12px;
    line-height: 12px;
  }
  .swiper-pagination.swiper-pagination--squares .swiper-pagination-bullet {
    border-width: 1px;
    height: 12px;
    margin: 0 8px;
    width: 12px;
  }
}
@media screen and (max-width: 1023px) {
  .swiper-pagination.swiper-pagination--squares .swiper-pagination-bullet {
    border-width: 0.2rem;
    height: 2.4rem;
    margin: 1rem 1.6rem;
    width: 2.4rem;
  }
}
.swiper-pagination.border-black .swiper-pagination-bullet {
  border-color: #000000;
}
.swiper-pagination.border-white .swiper-pagination-bullet {
  border-color: #ffffff;
}
.swiper-pagination.active-blue .swiper-pagination-bullet:hover,
.swiper-pagination.active-blue .swiper-pagination-bullet-active {
  background-color: #00aeef;
  border-color: #00aeef;
}
.swiper-pagination.active-white .swiper-pagination-bullet:hover,
.swiper-pagination.active-white .swiper-pagination-bullet-active {
  background-color: #ffffff;
  border-color: #ffffff;
}

.tabs .tabs-content .tab {
  position: relative;
}
.tabs .tabs-content .tab--hidden {
  display: none;
}
.tabs .tabs-navigation {
  font-size: 0;
  text-align: center;
  white-space: nowrap;
}
.tabs .tabs-navigation .tab {
  cursor: pointer;
  display: inline-block;
  height: 100%;
  position: relative;
}
.tabs .tabs-navigation .tab::after {
  content: "";
  display: none;
  left: 0;
  position: absolute;
  width: 100%;
}
.tabs .tabs-navigation .tab:hover::after, .tabs .tabs-navigation .tab.tab--active::after {
  display: block;
}
@media screen and (min-width: 1024px) {
  .tabs .tabs-navigation .tab::after {
    bottom: -1px;
    height: 2px;
  }
}
@media screen and (max-width: 1023px) {
  .tabs .tabs-content .tab.block-collapsible {
    display: block;
  }
  .tabs .tabs-navigation .tab::after {
    bottom: -1px;
    height: 3px;
  }
}

.text--bold {
  font-weight: bold;
}

.text--muted {
  color: #626262;
}

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

.ui-selectmenu-button {
  background: none;
  border: none;
  border-radius: 0;
  display: inline-block;
  margin: 0 1.4rem 0 0;
  padding: 0.4rem 0 0.4rem 1.4rem;
  position: relative;
  vertical-align: top;
}
.ui-selectmenu-button .ui-selectmenu-icon {
  background: transparent url(images/icon-dropdown.png) no-repeat right center/4.6rem auto;
  height: 2.2rem;
  margin: 0.5rem 0.5rem 0 0;
  width: 2.2rem;
}
.ui-selectmenu-button.ui-button {
  width: auto;
}
.ui-selectmenu-button:active, .ui-selectmenu-button:focus, .ui-selectmenu-button:hover {
  background: none;
  border: none;
  outline: none;
}
.ui-selectmenu-button:active .ui-selectmenu-icon, .ui-selectmenu-button:focus .ui-selectmenu-icon, .ui-selectmenu-button:hover .ui-selectmenu-icon {
  background-image: url(images/icon-dropdown.png);
}
.ui-selectmenu-button.ui-selectmenu-button-open .ui-selectmenu-icon {
  background: transparent url(images/icon-dropdown.png) no-repeat left center/4.6rem auto;
}

.ui-selectmenu-menu .ui-menu-item {
  font-size: 2.0rem;
  line-height: 2.4rem;
}
.ui-selectmenu-menu .ui-widget-content {
  border-color: #c2c2c2;
}
.ui-selectmenu-menu .ui-widget-content .ui-menu-item-wrapper {
  padding: 1.0rem 1.4rem;
}
.ui-selectmenu-menu .ui-widget-content .ui-state-active {
  background-color: #00aeef;
  border-color: #00aeef;
  color: #ffffff;
}
.ui-selectmenu-menu .ui-widget-content .ui-state-selected {
  color: #00aeef;
}
.ui-selectmenu-menu .ui-widget-content .ui-state-selected.ui-state-active {
  color: #ffffff;
}

.ui-selectmenu-text {
  color: #000000;
  font: normal 2rem/1.6 "ProximaNova", sans-serif;
  margin-right: 5.0rem;
}

@media screen and (max-width: 1023px) {
  .block-map .google-map {
    transition: top 0.3s;
  }
  .block-map.estate-info--visible .google-map {
    top: -35rem;
  }

  .ui-selectmenu-button .ui-selectmenu-icon {
    margin: 0.8rem 1.0rem 0 0;
  }

  .ui-selectmenu-text {
    font-size: 2.4rem;
  }
}
* {
  box-sizing: border-box;
  outline: none;
}
*::after, *::before {
  box-sizing: border-box;
}

a {
  color: #00aeef;
  cursor: pointer;
  text-decoration: none;
}

b, strong {
  font-weight: bold;
}

body {
  background: #171719;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
  line-height: 1;
}

html {
  font-family: "ProximaNova", sans-serif;
  font-size: 10px;
}

img {
  max-width: 100%;
}

p:first-child {
  margin-top: 0;
}

@media screen and (min-width: 1024px) {
  .block-collapsible .content {
    display: block !important;
    height: auto !important;
  }
}
@media screen and (max-width: 1023px) {
  .block-collapsible {
    margin-top: 1rem;
  }
  .block-collapsible .block-collapsible_content {
    display: none;
  }
  .block-collapsible .block-collapsible_title {
    background-color: #f5f5f5;
    padding: 3.3rem 0;
    position: relative;
  }
  .block-collapsible .block-collapsible_title::after {
    background: transparent url(images/collapsible-arrows.png) no-repeat left center/5.2rem auto;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    right: 4.6rem;
    top: 0;
    width: 2.5rem;
  }
  .block-collapsible .block-collapsible_title h3 {
    font-size: 3.2rem;
    font-weight: normal;
    padding-right: 3rem;
  }
  .block-collapsible.block-collapsible--opened .block-collapsible_title {
    background-color: #00aeef;
    color: #ffffff;
  }
  .block-collapsible.block-collapsible--opened .block-collapsible_title::after {
    background-position: right center;
  }
}

.block-filters {
  font-size: 0;
}
.block-filters .separator {
  border-left: 1px solid #c6c6c6;
  display: inline-block;
  width: 1px;
}
@media screen and (min-width: 1024px) {
  .block-filters .separator {
    height: 28px;
    margin: 6px 10px 0;
  }
}
@media screen and (max-width: 1023px) {
  .block-filters .separator {
    height: 4.4rem;
    margin: 0 3.3rem;
  }
}
@media screen and (max-width: 479px) {
  .block-filters .separator {
    margin: 0 1rem;
  }
}

.block-map {
  position: relative;
}
.block-map .map-overlay {
  background: transparent;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.block-paging li {
  display: inline-block;
  line-height: 1;
  text-align: center;
}
.block-paging li a {
  color: #000000;
  text-decoration: none;
}
.block-paging li a:hover {
  color: #00aeef;
}
.block-paging li span {
  color: #00aeef;
}
.block-paging ul {
  display: block;
  font-size: 0;
  line-height: 0;
  text-align: center;
}

.block-top {
  background-color: #000000;
  color: #ffffff;
  display: block;
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.block-top .content {
  padding: 0 10%;
  position: absolute;
  text-shadow: 1px 1px 4px #000000;
  top: 50%;
  width: 100%;
}
.block-top .images {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: -1;
}
.block-top .images .image {
  background: #000000 no-repeat center / cover;
  height: 100%;
  width: 100%;
}
.block-top .link-back {
  background: transparent url(images/section-back.png) no-repeat center/contain;
  cursor: pointer;
  display: block;
  height: 3.5rem;
  position: absolute;
  right: 5rem;
  top: 14rem;
  width: 6rem;
  z-index: 1;
}
.block-top .overlay {
  background: rgba(0, 0, 0, 0.4);
  background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.6) 100%);
  content: "";
  display: block;
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.block--framed-light .content-wrapper {
  border-bottom: 1px solid #eeeeee;
  border-top: 1px solid #eeeeee;
}

.full-height {
  height: 100%;
}

.loading::before {
  background: #000000 url(images/loading.gif) no-repeat center;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  opacity: 0.5;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 99;
}

.no-interaction {
  pointer-events: none;
}

@media screen and (min-width: 1024px) {
  body {
    font-size: 20px;
    line-height: 1.7;
  }

  h1 {
    font-size: 76px;
  }

  h2 {
    font-size: 48px;
  }

  h3 {
    font-size: 36px;
    line-height: 52px;
  }

  p {
    margin-top: 20px;
  }

  .block-map {
    background: #f0f0f0;
    height: 390px;
  }

  .block-paging {
    padding: 15px;
  }
  .block-paging li {
    font-size: 20px;
    width: 32px;
  }

  .block-title {
    font-size: 36px;
    font-weight: bold;
    line-height: 52px;
    margin-bottom: 15px;
  }

  .block-top .content {
    height: 100px;
    margin-top: -50px;
  }
  .block-top .full {
    font-size: 21px;
    margin-top: 17px;
  }
  .block-top .title {
    margin: 17px 0;
  }

  .content-wrapper {
    margin: 0 auto;
    max-width: 1040px;
    width: 100%;
  }
  .content-wrapper::after {
    clear: both;
    content: "";
    display: block;
  }
  .content-wrapper .content-main {
    float: left;
    width: 710px;
  }
  .content-wrapper .content-side {
    float: right;
    padding-left: 40px;
    width: 290px;
  }

  .content-wrapper--right .content-main {
    float: right;
  }
  .content-wrapper--right .content-side {
    float: left;
    padding-left: 0;
  }

  .mobile {
    display: none !important;
  }

  .page .block-top {
    height: 500px;
  }

  .page-title {
    margin-top: 170px;
  }

  .swiper-container .swiper-navigation {
    display: none;
  }
  .swiper-container:hover .swiper-navigation {
    display: block;
  }
}
@media screen and (max-width: 1023px) {
  body {
    font-size: 3.2rem;
    line-height: 1.5;
  }

  h1 {
    font-size: 9.5rem;
  }

  h3 {
    font-size: 4.5rem;
    line-height: 6rem;
  }

  p {
    margin-top: 3rem;
  }

  .content-wrapper {
    padding: 0 6rem 0 5rem;
  }

  .block-map {
    background: #f0f0f0;
    height: 49rem;
  }

  .block-paging {
    padding: 7.5rem 5.0rem;
  }
  .block-paging li {
    font-size: 3.2rem;
    width: 7.8rem;
  }

  .block-top .content {
    padding: 0 5rem;
  }
  .block-top .link-back {
    right: 2.6rem;
    top: 3rem;
  }
  .block-top .title {
    font-size: 9rem;
  }

  .desktop {
    display: none !important;
  }

  .page .block-top {
    height: 69rem;
  }
}
@media screen and (max-width: 639px) {
  html {
    font-size: 7.5px;
  }
}
@media screen and (max-width: 479px) {
  html {
    font-size: 5px;
  }
}
html, body {
  height: 100%;
}

.footer {
  background-color: #000000;
  color: #ffffff;
}
.footer a {
  color: inherit;
}
.footer .logo {
  background: transparent url(../images/logo-footer.png) no-repeat center/auto 100%;
  cursor: pointer;
  display: block;
}
@media screen and (min-width: 1024px) {
  .footer {
    font-size: 18px;
    height: 270px;
    line-height: 28px;
    padding: 56px 0 0;
  }
  .footer .footer-center {
    float: right;
    padding-left: 50px;
    width: 430px;
  }
  .footer .footer-left {
    float: left;
    width: 280px;
  }
  .footer .logo {
    background-position: left center;
    height: 36px;
  }
}
@media screen and (max-width: 1023px) {
  .footer {
    font-size: 2rem;
    height: 43rem;
    line-height: 3rem;
    padding: 3rem 0 0;
    text-align: center;
  }
  .footer .footer-center,
  .footer .footer-left {
    margin-top: 3rem;
  }
  .footer .content-side {
    margin-top: 3rem;
    padding-top: 2.4rem;
  }
  .footer .logo {
    height: 3.7rem;
  }
}

.menu {
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 15;
}
.menu a {
  color: inherit;
}
.menu p {
  line-height: 2.2;
}
.menu .content-wrapper {
  background: rgba(0, 0, 0, 0.85);
  color: #ffffff;
  height: 0vh;
  left: 0;
  max-width: none;
  min-height: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  transition: all 0.6s;
  width: 100%;
}
.menu .content-wrapper .content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  overflow: auto;
  text-align: center;
}
.menu .content-wrapper .content::after, .menu .content-wrapper .content::before {
  content: "";
  display: block;
}
.menu .link-back {
  background-color: #00aeef;
  color: #ffffff;
  display: block;
  height: 100%;
  left: 0;
  overflow: hidden;
  position: absolute;
  top: 0;
  transition: width 0.3s;
}
.menu .link-back .icon-back {
  background: transparent url(images/arrow-back.png) no-repeat left bottom;
  display: inline-block;
  height: 22px;
  vertical-align: middle;
  width: 33px;
}
.menu .link-back.link-back--hidden {
  width: 0px;
}
.menu .logo {
  background: transparent url(images/logo-top.png) no-repeat center/contain;
  cursor: pointer;
  display: block;
  height: 32px;
  margin: 16px auto 0;
  opacity: 1;
  position: relative;
  top: 0;
  transition: all 0.3s;
  transition-delay: 0.3s;
  width: 112px;
}
.menu .menu-button {
  cursor: pointer;
  display: block;
  position: absolute;
  z-index: 0;
}
.menu .menu-button .close {
  background: transparent url(images/button-menu--close.png) no-repeat center bottom;
  bottom: 0;
  content: "";
  display: block;
  height: 0;
  left: 0;
  overflow: hidden;
  position: absolute;
  top: auto;
  transition: height 0.6s linear;
  transition-delay: 0s;
  width: 100%;
  z-index: -1;
}
.menu .menu-button .line {
  background: #ffffff;
  display: block;
  left: 0;
  position: absolute;
  transition: all 0.6s cubic-bezier(0.42, 0.9, 0.7, 1.2);
  width: 100%;
}
.menu .menu-button .line:nth-child(1) {
  transition-delay: 0.1s;
}
.menu .menu-button .line:nth-child(2) {
  transition-delay: 0.2s;
}
.menu .menu-button .line:nth-child(3) {
  transition-delay: 0.5s;
}
.menu .menu-link {
  display: block;
  line-height: 1;
  text-align: center;
}
.menu .menu-link .icon-back {
  background: transparent url(images/arrow-back.png) no-repeat left top/1.5em 2em;
  display: inline-block;
  height: 1em;
  position: relative;
  width: 1.5em;
}
.menu .menu-link.active {
  color: #01aeef;
}
.menu .menu-link:hover {
  background-color: #01aeef;
  color: #ffffff;
}
.menu .menu-link:hover .icon-back {
  background-position: left bottom;
}
.menu .top {
  background-color: #1a1a1a;
  left: 0;
  overflow: hidden;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 10;
}
@media screen and (min-width: 1024px) {
  .menu p {
    font-size: 22px;
  }
  .menu .contact-info {
    font-size: 16px;
    line-height: 22px;
  }
  .menu .content-wrapper .content {
    height: 100vh;
    min-height: 335px;
    padding-top: 65px;
  }
  .menu .link-back {
    font-size: 18px;
    line-height: 21px;
    width: 250px;
  }
  .menu .link-back .icon-back {
    animation: linkBackAnimation 2s 0s infinite;
    background-size: 33px auto;
    height: 22px;
    left: 40px;
    position: absolute;
    top: 22px;
    width: 33px;
  }
  .menu .link-back .link-back_title {
    left: 80px;
    position: absolute;
    top: 22px;
    white-space: nowrap;
    width: 170px;
  }
  .menu .menu-button {
    height: 30px;
    right: 50px;
    top: 18px;
    width: 36px;
  }
  .menu .menu-button .close {
    background-size: 30px 30px;
  }
  .menu .menu-button .line {
    height: 2px;
  }
  .menu .menu-button .line:nth-child(1) {
    top: 4px;
  }
  .menu .menu-button .line:nth-child(2) {
    top: 14px;
  }
  .menu .menu-button .line:nth-child(3) {
    top: 24px;
  }
  .menu .menu-link {
    font-size: 28px;
    padding: 13px 0;
  }
  .menu .menu-link .icon-back {
    top: 5px;
  }
  .menu .menu-link--main {
    font-size: 36px;
    padding: 28px 0;
  }
  .menu .top {
    height: 65px;
  }
}
@media screen and (min-width: 1024px) and (max-height: 600px) {
  .menu .menu-link {
    font-size: 18px;
    padding: 8px 0;
  }
  .menu .menu-link--main {
    font-size: 30px;
    padding: 14px 0;
  }
}
@media screen and (max-width: 1023px) {
  .menu p {
    font-size: 3rem;
  }
  .menu .content-wrapper .content {
    height: 100vh;
    padding-top: 9rem;
  }
  .menu .link-back {
    line-height: 2.6rem;
    width: 12rem;
  }
  .menu .link-back .icon-back {
    background-size: auto 5.2rem;
    height: 2.6rem;
    margin: 3.2rem 4rem 3.2rem 3.8rem;
    width: 4.3rem;
  }
  .menu .logo {
    height: 5.1rem;
    margin-top: 2rem;
    width: 17.8rem;
  }
  .menu .menu-button {
    height: 6rem;
    right: 2.8rem;
    top: 1.5rem;
    width: 7rem;
  }
  .menu .menu-button .close {
    background-size: 6rem 6rem;
  }
  .menu .menu-button .line {
    height: 0.4rem;
  }
  .menu .menu-button .line:nth-child(1) {
    top: 0.8rem;
  }
  .menu .menu-button .line:nth-child(2) {
    top: 2.8rem;
  }
  .menu .menu-button .line:nth-child(3) {
    top: 4.8rem;
  }
  .menu .menu-link {
    font-size: 3rem;
    padding: 2rem 0;
  }
  .menu .menu-link .icon-back {
    top: 0.6rem;
  }
  .menu .menu-link--main {
    font-size: 4.8rem;
    padding: 3.4rem 0;
  }
  .menu .top {
    height: 9rem;
  }
}

.menu--hidden .menu .logo {
  opacity: 0;
  top: -1.6rem;
}
.menu--hidden .menu .menu-button .line {
  width: 0;
}
.menu--hidden .menu .top {
  height: 0;
}

.menu--open {
  overflow: hidden;
}
.menu--open .menu .content-wrapper {
  height: 100vh;
}
.menu--open .menu .menu-button .close {
  background-position: top center;
  bottom: auto;
  height: 100%;
  top: 0;
  transition-delay: 0.2s;
}
.menu--open .menu .menu-button .line {
  left: 50%;
  width: 0;
}
.menu--open .menu .menu-button .line:nth-child(1) {
  transition-delay: 0s;
}
.menu--open .menu .menu-button .line:nth-child(2) {
  transition-delay: 0.2s;
}
.menu--open .menu .menu-button .line:nth-child(3) {
  transition-delay: 0.4s;
}

.page {
  background-color: #ffffff;
  bottom: 0;
  display: none;
  left: 0;
  overflow: hidden;
  position: absolute;
  width: 100%;
  z-index: 0;
}
@media screen and (min-width: 1024px) {
  .page {
    top: 65px;
  }
}
@media screen and (max-width: 1023px) {
  .page {
    top: 9rem;
  }
}

.page_content {
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  position: relative;
  width: 100vw;
}

@keyframes linkBackAnimation {
  0% {
    transform: translateX(0px);
  }
  100% {
    transform: translatex(-20px);
  }
}
.intro {
  background: #171719;
  font-size: 220px;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 20;
  /* 
      &.page--out {
          opacity: 0;
          z-index: -1;
  
          .content {
              transform: scale(0.85, 0.85);
          }
          .logo {
              left: 1rem;
              opacity: 0;
          }
      }*/
}
.intro p {
  color: #ffffff;
  float: left;
  font-weight: 600;
  line-height: 1.1;
  margin-top: 0;
  position: relative;
  top: 1em;
}
.intro .content {
  height: 3.3em;
  left: 0;
  margin-top: -1.65em;
  padding-left: 50px;
  position: absolute;
  top: 50%;
  transform: scale(1, 1);
  width: 100%;
}
.intro .loading-bar {
  background: #015c8b;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
}
.intro .loading-progress {
  background: #000000;
  bottom: 0;
  height: 1rem;
  left: 0;
  position: absolute;
  width: 100%;
  z-index: 1;
}
.intro .logo {
  left: 0;
  opacity: 0;
  padding-left: 50px;
  position: absolute;
  top: 10%;
}
.intro .logo img {
  display: block;
}
.intro .row {
  clear: both;
  float: left;
  height: 1.1em;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 1919px), screen and (max-height: 1199px) {
  .intro {
    font-size: 140px;
  }
}
@media screen and (max-width: 1279px), screen and (max-height: 799px) {
  .intro {
    font-size: 100px;
  }
}
@media screen and (max-width: 1023px), screen and (max-height: 599px) {
  .intro {
    font-size: 70px;
  }
  .intro .content {
    padding-left: 0.57em;
  }
  .intro .logo {
    padding-left: 0.57em;
  }
  .intro .logo img {
    height: 0.71em;
  }
}
@media screen and (max-width: 639px), screen and (max-height: 449px) {
  .intro {
    font-size: 50px;
  }
}
@media screen and (max-width: 479px), screen and (max-height: 329px) {
  .intro {
    font-size: 35px;
  }
}

.page-about .block-about-details .content-main {
  position: relative;
}
.page-about .block-about-details .link-back {
  font-size: 1.8rem;
}
.page-about .block-about-details .link-back .icon {
  background: transparent url(images/arrow-left--blue.png) no-repeat center/3.2rem auto;
  display: inline-block;
  height: 2rem;
  margin-right: 0.5rem;
  position: relative;
  top: 0.5rem;
  width: 3.2rem;
}
.page-about .block-about-details .link-close {
  position: absolute;
  right: 0;
  top: 0;
}
.page-about .block-about-details .link-close .icon {
  background: transparent url(images/icon-close--black.png) no-repeat center/2.1rem auto;
}
.page-about .block-content {
  margin-top: 2rem;
}
.page-about .block-gallery {
  margin-top: 8rem;
}
.page-about .block-gallery .item {
  display: block;
  text-align: center;
}
.page-about .block-gallery .item:hover .item-title {
  color: #1f92bf;
}
.page-about .block-gallery .item-description {
  font-size: 0.72em;
}
.page-about .block-gallery .item-image {
  display: block;
}
.page-about .block-gallery .item-image img {
  display: block;
  height: 100%;
  width: 100%;
}
.page-about .block-gallery .item-title {
  display: block;
  height: 1.4em;
  overflow: hidden;
  text-overflow: ellipsis;
}
.page-about .block-gallery .items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.page-about .block-map {
  margin-top: 80px;
}
.page-about .block--framed-light .content-wrapper {
  padding-bottom: 3.5rem;
  padding-top: 3.5rem;
}
@media screen and (min-width: 1024px) {
  .page-about .block-about-details {
    margin-top: 148px;
  }
  .page-about .block-about-details .content-main {
    padding-left: 60px;
    padding-top: 20px;
    width: 680px;
  }
  .page-about .block-about-details .content-side {
    width: 340px;
  }
  .page-about .block-about-details .person-name {
    font-size: 3.6rem;
    line-height: 4.2rem;
  }
  .page-about .block-gallery .item {
    height: 395px;
    padding: 0 13px;
    width: 346px;
  }
  .page-about .block-gallery .item-description {
    margin-top: 10px;
  }
  .page-about .block-gallery .item-image {
    height: 250px;
    width: 320px;
  }
  .page-about .block-gallery .item-title {
    margin-top: 20px;
  }
}
@media screen and (max-width: 1023px) {
  .page-about .block-about-details .person-name {
    font-size: 5rem;
    line-height: 6rem;
  }
  .page-about .block-gallery .content-wrapper {
    padding-left: 0;
    padding-right: 0;
  }
  .page-about .block-gallery .item {
    font-size: 2rem;
    height: 30rem;
    padding: 0 0.8rem;
    width: 25.6rem;
  }
  .page-about .block-gallery .item-description {
    margin-top: 1rem;
  }
  .page-about .block-gallery .item-image {
    height: 18.8rem;
    width: 24rem;
  }
  .page-about .block-gallery .item-title {
    margin-top: 1rem;
  }
  .page-about .content-side {
    margin-top: 4rem;
  }
  .page-about .page-title {
    margin-top: 6rem;
  }
}

.page-career .block-gallery img {
  display: block;
  height: auto;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .page-career .block-collapsible {
    background-color: #eeeeee;
    margin-top: 2px;
    padding: 36px 0;
  }
  .page-career .block-content {
    padding: 10px 0;
  }
  .page-career .block-gallery {
    padding: 26px 0;
  }
  .page-career .block-gallery .content-wrapper {
    overflow: hidden;
  }
  .page-career .block-gallery .gallery-item {
    cursor: pointer;
    float: left;
    margin: 15px;
    position: relative;
    width: 310px !important;
    z-index: 0;
  }
  .page-career .block-gallery .gallery-item:hover::before {
    background: rgba(0, 0, 0, 0.5) url(images/image-hover-zoom.png) no-repeat center;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
  }
  .page-career .block-gallery .gallery-items {
    display: block !important;
    margin-left: -20px;
    transform: none !important;
    width: 1020px;
  }
  .page-career .footer {
    margin-top: 40px;
  }
}
@media screen and (max-width: 1023px) {
  .page-career .block-collapsible {
    margin-top: 1rem;
  }
  .page-career .block-collapsible .content-main {
    padding-bottom: 0.5rem;
    padding-top: 6.2rem;
  }
  .page-career .block-content {
    margin: 1.7rem 0;
  }
  .page-career .block-gallery {
    margin-top: 3.1rem;
  }
  .page-career .block-gallery .content-wrapper {
    padding: 0 4.5rem 0 3.5rem;
  }
  .page-career .block-gallery .gallery-item {
    padding: 0 1.5rem;
  }
  .page-career .page-title {
    padding-top: 10rem;
  }
}

.page-estates a {
  color: inherit;
}
.page-estates .block-map {
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.page-estates .block-estates {
  overflow: hidden;
  width: 100%;
}
.page-estates .block-estates .estates {
  left: -3px;
  position: relative;
  width: calc(100% + 6px);
}
.page-estates .block-filters {
  background: #ffffff;
  border-bottom: 1px solid #f0f0f0;
  color: #000000;
}
.page-estates .block-filters .icon {
  background: transparent no-repeat left center;
  cursor: pointer;
  vertical-align: top;
}
.page-estates .block-filters .icon.active {
  background-position: right center;
}
.page-estates .block-filters .results {
  color: #9b9b9b;
}
.page-estates .block-filters .separator {
  border-left: 1px solid #c6c6c6;
  position: relative;
  width: 1px;
}
.page-estates .block-views-container {
  position: relative;
}
.page-estates .block-views-container .block-view {
  display: none;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 0;
}
.page-estates .estate {
  display: block;
  float: left;
  line-height: 1.2;
  padding: 0 3px;
  position: relative;
  text-align: center;
}
.page-estates .estate .content {
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  height: 100px;
  justify-content: center;
}
.page-estates .estate .description {
  font-size: 14px;
  margin-top: 10px;
}
.page-estates .estate .image {
  background-color: #000000;
  height: auto;
  overflow: hidden;
  padding-top: 60.66%;
  position: relative;
  width: 100%;
}
.page-estates .estate .image:hover .swiper-slide-active {
  transform: scale(1.1, 1.1);
}
.page-estates .estate .swiper-container {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.page-estates .estate .swiper-slide {
  background: #000000 no-repeat center / cover;
  height: 100%;
  opacity: 0.99;
  position: relative;
  transition: all 0.3s ease-out;
  width: 100%;
  z-index: 0;
}
.page-estates .estate .swiper-slide-active {
  z-index: 1;
}
.page-estates .estate .swiper-wrapper {
  height: 100%;
  width: 100%;
}
.page-estates .estate .title {
  font-size: 20px;
  font-weight: bold;
}
.page-estates .estate:hover {
  color: #00aeef;
}
@media screen and (min-width: 2141px) {
  .page-estates .estate {
    width: 16.66%;
  }
}
@media screen and (max-width: 2140px) {
  .page-estates .estate {
    width: 20.00%;
  }
}
@media screen and (max-width: 1712px) {
  .page-estates .estate {
    width: 25.00%;
  }
}
@media screen and (max-width: 1284px) {
  .page-estates .estate {
    width: 33.33%;
  }
}
@media screen and (max-width: 1023px) {
  .page-estates .estate {
    width: 100.00%;
  }
}
@media screen and (max-width: 680px) {
  .page-estates .estate .description {
    font-size: 12px;
  }
  .page-estates .estate .title {
    font-size: 16px;
  }
}
.page-estates .estate-info {
  background-color: #f0f0f0;
  display: none;
  position: absolute;
  z-index: 10;
}
.page-estates .estate-info .estate {
  padding: 0;
  width: 100%;
}
.page-estates .estate-info .swiper-pagination.swiper-pagination--squares {
  bottom: 1rem;
}
@media screen and (min-width: 1024px) {
  .page-estates .block-estates {
    background-color: #ffffff;
    padding-top: 27px;
    width: 100%;
  }
  .page-estates .block-filters {
    font-size: 0;
    height: 73px;
    padding: 20px 35px 0 32px;
  }
  .page-estates .block-filters .block-filters__left {
    float: left;
  }
  .page-estates .block-filters .block-filters__right {
    float: right;
  }
  .page-estates .block-filters .icon {
    height: 28px;
    margin: 6px 15px 0;
  }
  .page-estates .block-filters .icon-grid-view {
    background-image: url(images/icon-grid-view.png);
    width: 20px;
  }
  .page-estates .block-filters .icon-map-view {
    background-image: url(images/icon-map-view.png);
    width: 19px;
  }
  .page-estates .block-filters .icon-table-view {
    background-image: url(images/icon-table-view.png);
    width: 25px;
  }
  .page-estates .block-filters .separator {
    border-left: 1px solid #c6c6c6;
    display: inline-block;
    height: 2.8rem;
    margin: 0 10px;
    position: relative;
    top: 0.6rem;
    vertical-align: top;
    width: 1px;
  }
  .page-estates .block-filters-wrapper {
    height: 73px;
  }
  .page-estates .block-map {
    background: rgba(255, 255, 0, 0.4);
    height: calc(100vh - 138px);
    max-height: 620px;
    min-height: 200px;
  }
  .page-estates .block-paging {
    padding: 48px 0;
  }
  .page-estates .block-table {
    font-size: 16px;
    line-height: 24px;
    padding: 0 20px;
  }
  .page-estates .block-table .cell {
    float: left;
    padding: 30px 30px 10px;
  }
  .page-estates .block-table .header {
    background-color: #f5f5f5;
    font-size: 20px;
  }
  .page-estates .block-table .header .cell {
    padding-bottom: 17px;
    padding-top: 17px;
  }
  .page-estates .block-table .map {
    height: 400px;
    position: relative;
    width: 690px;
  }
  .page-estates .block-table .map-wrapper {
    clear: both;
    height: 0px;
    overflow: hidden;
    padding: 0 30px;
  }
  .page-estates .block-table .results {
    padding: 30px;
  }
  .page-estates .block-table .row .cell-address {
    width: 30%;
  }
  .page-estates .block-table .row .cell-flayer {
    width: 20%;
  }
  .page-estates .block-table .row .cell-leasing {
    width: 10%;
  }
  .page-estates .block-table .row .cell-location {
    width: 10%;
  }
  .page-estates .block-table .row .cell-property {
    width: 10%;
  }
  .page-estates .block-table .row .cell-square {
    width: 10%;
  }
  .page-estates .block-table .row .cell-tenant {
    width: 10%;
  }
  .page-estates .block-table .row-separator {
    clear: both;
    height: 1px;
    margin-top: 20px;
    padding: 0 30px;
    position: relative;
    width: 100%;
  }
  .page-estates .block-table .row-separator::before {
    background-color: #c2c2c2;
    content: "";
    display: block;
    height: 1px;
    width: 100%;
  }
  .page-estates .block-table .toggle-map {
    border-bottom: 1px dashed #444444;
    display: inline-block;
    font-size: 14px;
  }
  .page-estates .block-table .toggle-map:hover {
    border-color: transparent;
  }
  .page-estates .estate-info {
    bottom: auto !important;
    box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.75);
    left: 45px !important;
    top: 170px !important;
    width: 328px;
  }
  .page-estates .estate-info .content {
    height: 80px;
  }
}
@media screen and (max-width: 1023px) {
  .page-estates .block-estates {
    background-color: #f0f0f0;
    padding: 0 1rem 1rem;
  }
  .page-estates .block-estates .estate {
    margin-top: 1.5rem;
  }
  .page-estates .block-filters {
    font-size: 2.4rem;
    height: 18rem;
  }
  .page-estates .block-filters .block-filters__left {
    align-items: center;
    display: flex;
    height: 9rem;
    justify-content: space-between;
    padding: 0 4rem;
  }
  .page-estates .block-filters .block-filters__right {
    align-items: center;
    border-top: 1px solid #f1f1f1;
    display: flex;
    height: 9rem;
    justify-content: space-between;
    padding: 0 4rem;
  }
  .page-estates .block-filters .block-filters__right .separator {
    display: none;
  }
  .page-estates .block-filters .icon {
    background-size: 8rem auto;
    height: 4.6rem;
    margin-left: 3rem;
    width: 4rem;
  }
  .page-estates .block-filters .icon-grid-view {
    background-image: url(images/icon-grid-view--mobile.png);
  }
  .page-estates .block-filters .icon-map-view {
    background-image: url(images/icon-map-view--mobile.png);
  }
  .page-estates .block-filters .icon-table-view {
    background-image: url(images/icon-table-view--mobile.png);
    background-size: 10rem auto;
    width: 5rem;
  }
  .page-estates .block-filters .separator {
    border-color: #f0f0f0;
    height: 4.8rem;
  }
  .page-estates .block-filters .ui-selectmenu-text {
    font-size: 2.4rem;
  }
  .page-estates .block-filters-wrapper {
    height: 18rem;
  }
  .page-estates .block-map {
    height: calc(100vh - 27rem);
  }
  .page-estates .block-table {
    font-size: 2.6rem;
    line-height: 1.5;
  }
  .page-estates .block-table::before {
    background-color: #f0f0f0;
    box-shadow: inset 0px 11px 8px -10px #cccccc;
    content: "";
    display: block;
    height: 2rem;
    width: 100%;
  }
  .page-estates .block-table .map {
    height: 100%;
    width: 100%;
  }
  .page-estates .block-table .map-back {
    background: transparent url(images/button-map-back.png) no-repeat center/5rem auto;
    display: block;
    height: 3.5rem;
    left: 3rem;
    position: absolute;
    top: 3rem;
    width: 5rem;
    z-index: 1;
  }
  .page-estates .block-table .map-wrapper {
    height: calc(100vh - 9rem) !important;
    left: 100vw;
    position: fixed;
    top: 9rem;
    width: 100vw;
    z-index: 11;
  }
  .page-estates .block-table .row {
    border-bottom: 1px solid #d1d1d1;
    padding: 5rem;
    position: relative;
  }
  .page-estates .block-table .row .cell {
    margin-top: 0.6rem;
  }
  .page-estates .block-table .row .cell-address {
    font-size: 3.2rem;
    margin-bottom: 2rem;
    padding-right: 14rem;
  }
  .page-estates .block-table .row .cell-flayer {
    font-size: 2.4rem;
    margin-top: 30px;
  }
  .page-estates .block-table .row .cell-location {
    color: #9b9b9b;
    max-width: 12rem;
    overflow: hidden;
    position: absolute;
    right: 4.8rem;
    text-overflow: ellipsis;
    top: 5.5rem;
    white-space: nowrap;
  }
  .page-estates .block-table .row .text-separator {
    background-color: #000000;
    display: inline-block;
    height: 1.7rem;
    margin: 0 1.2rem;
    position: relative;
    top: 0.2rem;
    width: 1px;
  }
  .page-estates .estate-info {
    bottom: -100%;
    height: auto;
    left: 0;
    top: auto;
    width: 100%;
    z-index: 1;
  }
  .page-estates .estate-info .drag-element {
    background: rgba(255, 255, 255, 0.6);
    height: 4rem;
    position: relative;
    top: 0 !important;
    width: 100%;
    z-index: 1;
  }
  .page-estates .estate-info .drag-element::before {
    background: #7cd3f5;
    content: "";
    display: block;
    height: 0.6rem;
    left: 50%;
    margin: -0.3rem auto auto -2.6rem;
    position: absolute;
    top: 50%;
    width: 5.2rem;
  }
  .page-estates .estate-info .estate {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .page-estates.mode--map .block-estates {
    display: none;
  }
  .page-estates.mode--map .footer {
    display: none;
  }
}

.browser-msie .page-estates .block-estates .estate .image:hover .swiper-slide-active {
  transform: none;
}

.page-lifestyle .block-content .logo {
  display: block;
}
.page-lifestyle .block-navigation {
  position: relative;
  top: 0;
  z-index: 1;
}
.page-lifestyle .block-slider {
  background-color: #000000;
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 0;
}
.page-lifestyle .block-slider .image {
  background: transparent no-repeat center / cover;
  height: 100%;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .page-lifestyle .block-content {
    padding: 75px 0;
  }
  .page-lifestyle .block-slider {
    height: 616px;
  }
  .page-lifestyle .tabs-navigation {
    height: 60px;
  }
  .page-lifestyle .tabs-navigation .content {
    background-color: #ffffff;
    border-bottom: 1px solid #c2c2c2;
    height: 60px;
    width: 100%;
  }
  .page-lifestyle .tabs-navigation .content .item {
    cursor: pointer;
    display: inline-block;
    font-size: 18px;
    height: 100%;
    line-height: 48px;
    margin: 0 15px;
    padding: 8px 21px 0;
  }
  .page-lifestyle .tabs-navigation .content .items {
    display: block;
    font-size: 0;
    height: 100%;
    text-align: center;
  }
  .page-lifestyle .tabs-navigation .content.fixed {
    left: 0;
    position: fixed;
    top: 65px;
    z-index: 10;
  }
  .page-lifestyle .tabs-navigation .tab.tab--active, .page-lifestyle .tabs-navigation .tab:hover {
    color: #1c8fbf;
  }
  .page-lifestyle .tabs-navigation .tab.tab--active::after, .page-lifestyle .tabs-navigation .tab:hover::after {
    background-color: #00aeef;
    bottom: -2px;
    height: 4px;
  }
}
@media screen and (max-width: 1023px) {
  .page-lifestyle .block-content {
    padding: 7.4rem 0 8rem;
  }
  .page-lifestyle .block-content .title {
    margin-top: 4.4rem;
  }
  .page-lifestyle .block-slider {
    height: 55rem;
  }
  .page-lifestyle .tabs {
    padding-bottom: 8rem;
  }
}

.page-main {
  background: none;
}
.page-main .block-top {
  background: none;
}
.page-main .block-top .content--active {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100vw;
  z-index: 0;
}
.page-main .block-top .content--active .content {
  left: -5%;
  opacity: 0;
}
.page-main .block-top.block--active .content--active .content {
  left: 0%;
  opacity: 1;
  transition: left 0.6s, opacity 0.6s;
}
@media screen and (min-width: 1024px) {
  .page-main .block-top {
    height: 100%;
    position: absolute;
    top: 0;
  }
  .page-main .block-top .content--main .content {
    height: auto;
    left: 0vw;
    opacity: 1;
    padding: 0 3.9vw;
    position: relative;
    top: auto;
    width: 33.33vw;
  }
  .page-main .block-top .content--main .description {
    left: 0;
    top: 100%;
    padding: 0 3.9vw;
    position: absolute;
    width: 100%;
  }
  .page-main .block-top .content--main .subtitle {
    display: block;
    max-height: 0;
    opacity: 0.2;
    overflow: hidden;
    transition: all 0.5s;
  }
  .page-main .block-top .content--main .subtitle p {
    padding-bottom: 36px;
  }
  .page-main .block-top .content--main .title {
    font-size: 46px;
  }
  .page-main .block-top.block-center {
    left: 0;
    width: 100vw;
    z-index: 1;
  }
  .page-main .block-top.block-center .content--main {
    left: 33.33vw;
  }
  .page-main .block-top.block-left {
    left: 0;
    width: 33.33vw;
    z-index: 2;
  }
  .page-main .block-top.block-left .content--main {
    left: 0;
  }
  .page-main .block-top.block-left .images {
    min-width: 33.33vw;
    width: 100%;
  }
  .page-main .block-top.block-right {
    right: 0;
    width: 33.33vw;
    z-index: 2;
  }
  .page-main .block-top.block-right .content--active {
    left: auto;
    right: 0;
  }
  .page-main .block-top.block-right .content--main {
    right: 0;
  }
  .page-main .block-top.block-right .images {
    left: auto;
    min-width: 33.33vw;
    right: 0;
    width: 100%;
  }
  .page-main .block-top:hover .subtitle {
    max-height: 5em;
    opacity: 1;
  }
  .page-main .content-wrapper {
    bottom: 20%;
    max-width: none;
    overflow: visible;
    position: absolute;
    width: 33.33vw;
  }
  .page-main .footer {
    display: none;
  }
  .page-main.block-center--active .block-left,
  .page-main.block-center--active .block-right {
    transition: width 0.6s;
    width: 0vw;
  }
  .page-main.block-left--active .block-left {
    transition: width 0.6s;
    width: 100vw;
    z-index: 3;
  }
  .page-main.block-right--active .block-right {
    transition: width 0.6s;
    width: 100vw;
    z-index: 3;
  }
  .page-main.block-top--active .content--main .content {
    left: 5vw;
    opacity: 0;
    transition: left 0.3s, opacity 0.2s;
  }
}
@media screen and (max-width: 1023px) {
  .page-main .block-top {
    height: 33.33%;
    left: 0;
    position: absolute;
    width: 100%;
    z-index: 0;
  }
  .page-main .block-top .content--main .description {
    font-size: 3.2rem;
    margin-top: 2.1rem;
  }
  .page-main .block-top .content--main .title {
    font-size: 6rem;
  }
  .page-main .block-top .content {
    padding: 0 5rem;
  }
  .page-main .block-top .content-wrapper {
    padding: 0;
  }
  .page-main .block-top-container {
    height: 100%;
    min-height: 129rem;
    position: relative;
    width: 100%;
  }
  .page-main .block-center {
    top: 33.33%;
  }
  .page-main .block-left {
    top: 0%;
  }
  .page-main .block-right {
    top: 66.66%;
  }
  .page-main.block-top--active .block--active {
    height: 100%;
    top: 0;
    transition: height 0.6s, top 0.6s;
    z-index: 1;
  }
  .page-main.block-top--active .block-top-container {
    min-height: 100%;
    transition: min-height 0.6s;
  }
  .page-main.block-top--active .content--main .content {
    left: 5vw;
    opacity: 0;
    transition: left 0.3s, opacity 0.2s;
  }
}

.page-news .news-image img {
  display: block;
}
.page-news .news-info .separator {
  background-color: #000000;
  display: inline-block;
  width: 1px;
}
.page-news .news-item {
  position: relative;
}
.page-news .news-title:hover {
  color: #00aeef;
}
@media screen and (min-width: 1024px) {
  .page-news .footer {
    margin-top: 88px;
  }
  .page-news .news-content {
    margin-top: 20px;
  }
  .page-news .news-image {
    height: 195px;
    left: 0;
    position: absolute;
    top: 12px;
    width: 328px;
  }
  .page-news .news-info {
    font-size: 14px;
    margin-top: 3px;
  }
  .page-news .news-info .separator {
    height: 10px;
    margin: 0;
  }
  .page-news .news-item {
    border-bottom: 1px solid #eeeeee;
    margin-top: 67px;
    min-height: 270px;
    padding: 0 0 0 365px;
  }
  .page-news .news-item:first-child {
    margin-top: 20px;
  }
  .page-news .news-item:last-child {
    border-bottom: none;
  }
}
@media screen and (max-width: 1023px) {
  .page-news .block-filters {
    padding: 0 5.0rem;
  }
  .page-news .news-image img {
    display: block;
    height: auto;
    width: 100%;
  }
  .page-news .news-info {
    font-size: 2.4rem;
    margin-top: 1.5rem;
  }
  .page-news .news-info .separator {
    height: 1.7rem;
    margin: 0 1.4rem;
  }
  .page-news .news-item {
    border-bottom: 1px solid #d1d1d1;
    margin-top: 6.0rem;
    padding: 0 5.7rem 2.8rem 5.0rem;
  }
  .page-news .news-item:first-child {
    margin-top: 4.6rem;
  }
  .page-news .news-title {
    margin-top: 1.2rem;
  }
  .page-news .page-title {
    padding: 10rem 5.0rem 0;
  }
}

.page-object {
  overflow: hidden;
}
.page-object p {
  margin-top: 1rem;
}
.page-object .block-description {
  text-align: center;
}
.page-object .block-gallery {
  position: relative;
}
.page-object .block-gallery .gallery-thumbs {
  background: rgba(0, 0, 0, 0.7);
  bottom: 0;
  height: 106px;
  left: 0;
  opacity: 0;
  overflow: hidden;
  padding: 15px 9px 11px;
  position: absolute;
  transition: opacity 0.5s;
  white-space: nowrap;
  width: 100%;
}
.page-object .block-gallery .gallery-thumbs .thumb {
  background: transparent no-repeat center / cover;
  height: 80px;
  margin: 0 3px;
  position: relative;
  width: 142px;
}
.page-object .block-gallery .gallery-thumbs .thumb:hover::before, .page-object .block-gallery .gallery-thumbs .thumb.active::before {
  border: 1px solid #00aeef;
  box-sizing: border-box;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  position: absolulte;
  top: 0;
  width: 100%;
  z-index: 1;
}
.page-object .block-gallery .gallery-thumbs-wrapper:hover .gallery-thumbs {
  opacity: 1;
}
.page-object .block-gallery .image {
  background: #000000 no-repeat center / cover;
  height: 100%;
  width: 100%;
}
.page-object .block-gallery .images {
  height: 100%;
  position: relative;
  width: 100%;
}
.page-object .block-map {
  position: relative;
}
.page-object .block-schema {
  position: relative;
}
.page-object .block-schema .image {
  background: transparent no-repeat center / contain;
  height: 100%;
  width: 100%;
}
.page-object .block-schema .image-container {
  height: 100%;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.page-object .block-top {
  position: relative;
}
.page-object .block-top .images .image {
  position: relative;
}
.page-object .block-top .info {
  background-color: #000000;
  color: #ffffff;
  position: relative;
  transform: translate3d(0, 0, 0);
}
.page-object .block-top .info .block--icon {
  position: relative;
}
.page-object .block-top .info .block--icon > .icon:first-child {
  left: 0;
  position: absolute;
  top: 0;
}
.page-object .block-top .info .label {
  background-color: #e1194d;
  color: #ffffff;
  position: absolute;
  text-align: center;
}
.page-object .block-top .info .link-map {
  border-bottom: 1px dashed #00aeef;
}
.page-object .block-top .info .link-map:hover {
  border-bottom-color: transparent;
}
.page-object .block-top .info .tabs-navigation {
  border-color: #3f3f3f;
  border-style: solid;
  border-width: 1px 0;
  position: relative;
}
.page-object .block-top .info .tabs-navigation .tab {
  color: #9e9e9e;
  margin: 0 0.5%;
  width: 32%;
}
.page-object .block-top .info .tabs-navigation .tab:hover, .page-object .block-top .info .tabs-navigation .tab.tab--active {
  color: #ffffff;
}
.page-object .block-top .info .tabs-navigation .tab:hover::after, .page-object .block-top .info .tabs-navigation .tab.tab--active::after {
  background-color: #00aeef;
}
.page-object .block-top .info .title {
  line-height: 1;
  width: 100%;
}
.page-object .content-wrapper {
  position: relative;
}
.page-object .gallery-container {
  height: 100%;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .page-object .block-description {
    background-color: #f5f5f5;
    font-size: 20px;
    line-height: 1.7;
    padding: 73px 0;
  }
  .page-object .block-gallery {
    height: 100%;
    min-height: 600px;
  }
  .page-object .block-map {
    height: 515px;
  }
  .page-object .block-map .button {
    font-size: 20px;
    line-height: 25px;
    padding: 13px 26px;
    width: 290px;
  }
  .page-object .block-map .overlay {
    background: rgba(255, 255, 255, 0.7);
    bottom: 0;
    height: 125px;
    left: 0;
    padding-top: 25px;
    position: absolute;
    text-align: center;
    width: 100%;
  }
  .page-object .block-schema {
    font-size: 18px;
    height: 100%;
    line-height: 24px;
    min-height: 600px;
  }
  .page-object .block-schema .bottom {
    padding-left: 50px;
  }
  .page-object .block-schema .content {
    margin: 0 auto;
    max-width: 1180px;
    position: relative;
    width: 100%;
  }
  .page-object .block-schema .content-main {
    height: 480px;
    position: absolute;
    right: 0;
    top: 0;
    width: calc(100% - 400px);
  }
  .page-object .block-schema .content-side {
    padding: 45px 45px 0 50px;
    width: 400px;
  }
  .page-object .block-schema .gallery-container::before, .page-object .block-schema .gallery-container::after {
    content: "";
    display: block;
    height: calc(50% - 240px);
    width: 100%;
  }
  .page-object .block-schema .image-zoom {
    cursor: pointer;
    font-size: 38px;
    line-height: 1;
    height: 38px;
    position: absolute;
    right: 10px;
    top: 0;
    width: 38px;
    z-index: 1;
  }
  .page-object .block-schema .swiper-wrapper {
    height: 400px;
  }
  .page-object .block-schema .title {
    line-height: 1;
    padding-left: 50px;
    width: 400px;
  }
  .page-object .block-top {
    height: 100%;
    min-height: 600px;
  }
  .page-object .block-top .images {
    width: calc(100% - 420px);
  }
  .page-object .block-top .info {
    font-size: 18px;
    height: 100%;
    line-height: 22px;
    padding-top: 40px;
    position: absolute;
    right: 0;
    top: 0;
    width: 420px;
    z-index: 1;
  }
  .page-object .block-top .info .block--icon {
    margin-top: 38px;
    padding-left: 32px;
  }
  .page-object .block-top .info .label {
    font-size: 14px;
    height: 36px;
    left: -20px;
    line-height: 36px;
    top: -2px;
    width: 110px;
  }
  .page-object .block-top .info .link-map {
    display: inline-block;
    font-size: 20px;
  }
  .page-object .block-top .info .padded {
    padding: 0 50px 0 40px;
  }
  .page-object .block-top .info .subtitle {
    margin-top: 2px;
  }
  .page-object .block-top .info .tabs-navigation {
    height: 32px;
    margin-top: 35px;
    padding-left: 92px;
  }
  .page-object .block-top .info .tabs-navigation .tab {
    font-size: 18px;
    line-height: 30px;
  }
}
@media screen and (max-width: 1023px) {
  .page-object .block-description {
    background-color: #f0f0f0;
    padding: 8.7rem 0;
  }
  .page-object .block-gallery {
    height: 55rem;
  }
  .page-object .block-map {
    background-color: #f0f0f0;
    border-top: 1px solid #d8d8d8;
    height: 61.2rem;
  }
  .page-object .block-map .button {
    font-size: 3.2rem;
    line-height: 4.0rem;
    padding: 2rem;
    width: 100%;
  }
  .page-object .block-map .overlay {
    background: rgba(255, 255, 255, 0.7);
    bottom: 0;
    height: 14rem;
    left: 0;
    padding: 3rem 2.5rem;
    position: absolute;
    text-align: center;
    width: 100%;
  }
  .page-object .block-partner {
    background-color: #f0f0f0;
    display: flex;
    flex-direction: column;
    height: 31rem;
    justify-content: space-between;
  }
  .page-object .block-partner::after, .page-object .block-partner::before {
    content: "";
    display: block;
    height: 0;
    overflow: hidden;
  }
  .page-object .block-partner .company {
    background: transparent no-repeat center / contain;
    height: 10rem;
  }
  .page-object .block-partner .title {
    font-size: 2.6rem;
    line-height: 4rem;
    text-align: center;
  }
  .page-object .block-schema {
    font-size: 2.6rem;
    line-height: 4rem;
  }
  .page-object .block-schema .content {
    padding-bottom: 6rem;
  }
  .page-object .block-schema .content-main {
    height: 36rem;
  }
  .page-object .block-schema .content-side {
    border-bottom: 1px solid #d8d8d8;
    padding: 0 5rem 5rem;
  }
  .page-object .block-schema .top {
    border-bottom: 1px solid #d8d8d8;
    padding: 7rem 28rem 3rem 5rem;
    position: relative;
  }
  .page-object .block-schema .top .link {
    display: inline-block;
    font-size: 2.4rem;
    line-height: 4rem;
    position: absolute;
    right: 2.6rem;
    top: 8rem;
  }
  .page-object .block-schema .top .title {
    font-size: 4.5rem;
    line-height: 6rem;
  }
  .page-object .block-top {
    height: auto;
  }
  .page-object .block-top .images {
    height: 44rem;
    position: relative;
  }
  .page-object .block-top .info {
    font-size: 2.6rem;
    padding: 5.5rem 0 6.7rem;
  }
  .page-object .block-top .info p {
    margin-top: 1.2rem;
  }
  .page-object .block-top .info .block--icon {
    margin-top: 3rem;
    padding-left: 4.5rem;
  }
  .page-object .block-top .info .label {
    font-size: 2rem;
    height: 5.2rem;
    left: 5rem;
    line-height: 5.2rem;
    top: -3.5rem;
    width: 16rem;
  }
  .page-object .block-top .info .padded {
    padding: 0 5rem;
  }
  .page-object .block-top .info .subtitle {
    font-size: 2.4rem;
    line-height: 1;
    margin-top: 2.3rem;
  }
  .page-object .block-top .info .tabs-navigation {
    height: 6rem;
    margin-top: 3.6rem;
  }
  .page-object .block-top .info .tabs-navigation .tab {
    font-size: 2.6rem;
    line-height: 6rem;
    width: 33%;
  }
  .page-object .block-top .info .title {
    font-size: 4.5rem;
  }
}

.page-technology .block-content .logo {
  display: block;
}
.page-technology .block-companies {
  border: 0 solid #c4c4c4;
  border-width: 1px 0;
  display: flex;
  flex-wrap: wrap;
  font-size: 0;
  justify-content: center;
  text-align: center;
}
.page-technology .block-companies .company {
  align-items: center;
  display: flex;
  flex-direction: column;
  float: left;
  justify-content: center;
}
.page-technology .block-companies .logo {
  width: 100%;
}
.page-technology .block-companies .logo img {
  max-width: 90%;
}
.page-technology .block-companies .title {
  padding-top: 20px;
}
.page-technology .block-navigation {
  position: relative;
  top: 0;
  z-index: 1;
}
.page-technology .block-slider {
  background-color: #000000;
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 0;
}
.page-technology .block-slider .image {
  background: transparent no-repeat center / cover;
  height: 100%;
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .page-technology .block-companies .company {
    height: 225px;
    width: 25%;
  }
  .page-technology .block-companies .logo img {
    max-height: 160px;
  }
  .page-technology .block-companies .title {
    font-size: 20px;
    line-height: 34px;
  }
  .page-technology .block-content {
    padding: 75px 0;
  }
  .page-technology .block-slider {
    height: 616px;
  }
  .page-technology .tabs-navigation {
    height: 60px;
  }
  .page-technology .tabs-navigation .content {
    background-color: #ffffff;
    border-bottom: 1px solid #c2c2c2;
    height: 60px;
    width: 100%;
  }
  .page-technology .tabs-navigation .content .item {
    cursor: pointer;
    display: inline-block;
    font-size: 18px;
    height: 100%;
    line-height: 48px;
    margin: 0 15px;
    padding: 8px 21px 0;
  }
  .page-technology .tabs-navigation .content .items {
    display: block;
    font-size: 0;
    height: 100%;
    text-align: center;
  }
  .page-technology .tabs-navigation .content.fixed {
    left: 0;
    position: fixed;
    top: 65px;
    z-index: 10;
  }
  .page-technology .tabs-navigation .tab.tab--active, .page-technology .tabs-navigation .tab:hover {
    color: #1c8fbf;
  }
  .page-technology .tabs-navigation .tab.tab--active::after, .page-technology .tabs-navigation .tab:hover::after {
    background-color: #00aeef;
    bottom: -2px;
    height: 4px;
  }
}
@media screen and (max-width: 1023px) {
  .page-technology .block-companies .company {
    height: 25rem;
    width: 50.00%;
  }
  .page-technology .block-companies .logo img {
    max-height: 16rem;
  }
  .page-technology .block-companies .title {
    font-size: 2.4rem;
    line-height: 3.6rem;
    padding: 0 1rem;
  }
  .page-technology .block-content {
    padding: 7.4rem 0 8rem;
  }
  .page-technology .block-content .title {
    margin-top: 4.4rem;
  }
  .page-technology .block-slider {
    height: 55rem;
  }
  .page-technology .tabs {
    padding-bottom: 8rem;
  }
}

.block-gallery .video-container {
  position: relative;
}

.block-gallery .video-container iframe {
  width: 100%;
  height: 100%;
}

.block-gallery .video-container .video-play {
  width: 125px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-right: -50%;
  transform: translate(-50%, -50%);
  cursor: pointer;
}

@media screen and (max-width: 1023px) {
  .block-gallery .video-container .video-play {
    width: 65px;
  }
}
