@font-face {
  font-family: 'Pragmatica';
  src: local("Pragmatica Book"), local("Pragmatica-Book"), url("../fonts/Pragmatica-Book.woff2") format("woff2"), url("../fonts/Pragmatica-Book.woff") format("woff"), url("../fonts/Pragmatica-Book.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-family: 'Pragmatica';
  src: local("Pragmatica Light"), local("Pragmatica-Light"), url("../fonts/Pragmatica-Light.woff2") format("woff2"), url("../fonts/Pragmatica-Light.woff") format("woff"), url("../fonts/Pragmatica-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
}

@font-face {
  font-family: 'Pragmatica';
  src: local("Pragmatica Bold"), local("Pragmatica-Bold"), url("../fonts/Pragmatica-Bold.woff2") format("woff2"), url("../fonts/Pragmatica-Bold.woff") format("woff"), url("../fonts/Pragmatica-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: 'Helvetica Neue';
  src: local("Helvetica Neue Bold"), local("Helvetica-Neue-Bold"), url("../fonts/HelveticaNeueCyr-Bold.woff2") format("woff2"), url("../fonts/HelveticaNeueCyr-Bold.woff") format("woff"), url("../fonts/HelveticaNeueCyr-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: 'Helvetica Neue';
  src: local("Helvetica Neue Thin"), local("Helvetica-Neue-Thin"), url("../fonts/HelveticaNeueCyr-Thin.woff2") format("woff2"), url("../fonts/HelveticaNeueCyr-Thin.woff") format("woff"), url("../fonts/HelveticaNeueCyr-Thin.ttf") format("truetype");
  font-weight: 100;
  font-style: normal;
}

.container {
  width: 100%;
  padding-left: 5px;
  padding-right: 5px;
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media (min-width: 576px) {
  .container {
    max-width: 100%;
    padding-left: 5px;
    padding-right: 5px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 100%;
    padding-left: 6.66vw;
    padding-right: 6.66vw;
  }
}

@media (min-width: 992px) {
  .container {
    max-width: 100%;
    padding-left: 6.66vw;
    padding-right: 6.66vw;
  }
}

@media (min-width: 1260px) {
  .container {
    max-width: 100%;
    padding-left: 6.66vw;
    padding-right: 6.66vw;
  }
}

.container-fluid {
  width: 100%;
  padding-right: 4vw;
  padding-left: 4vw;
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

body {
  font-family: 'Pragmatica', Arial, sans-serif;
  font-weight: 300;
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #222222;
}

a {
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

.button {
  font-size: 0.93vw;
  line-height: 1.33vw;
  padding: 1vw 2.13vw;
  text-decoration: none;
  background-color: transparent;
  display: inline-block;
  cursor: pointer;
  white-space: nowrap;
}

.button--white {
  color: #FFFFFF;
  border: 2px solid #FFFFFF;
}

.button--white:hover, .button--white:focus {
  background-color: #FFFFFF;
  color: #222222;
}

.button--black {
  color: #222222;
  border: 2px solid #000;
}

.button--black:hover, .button--black:focus {
  background-color: #000;
  color: #FFF;
}

.section-header {
  position: relative;
}

.section-number {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-weight: 100;
  font-size: 2.13vw;
  line-height: 2.4vw;
  font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-weight: 100;
}

.section-title {
  margin: 0;
  font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 2.13vw;
  line-height: 2.53vw;
  color: #222222;
}

.color-black {
  color: #000;
}

.color-white {
  color: #FFF;
}

.slider-box {
  position: relative;
}

.slide {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.arrow {
  display: block;
  position: absolute;
  top: 0;
  width: 4vw;
  height: 100%;
  border: none;
  background-color: rgba(0, 0, 0, 0.39);
  z-index: 1;
  background-size: 18px auto;
  background-repeat: no-repeat;
  background-position: center;
  outline: none;
  cursor: pointer;
}

.arrow:hover, .arrow:focus {
  background-color: rgba(0, 0, 0, 0.6);
}

.arrow-next {
  right: 0;
  background-image: url("../img/right.svg");
}

.arrow-prev {
  z-index: 1;
  background-image: url("../img/left.svg");
}

.header {
  background-color: #222222;
  padding-top: 1.33vw;
  padding-bottom: 4.6vw;
}

.header .burger-menu {
  display: none;
}

.header__row {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 0.5px solid #FFFFFF;
}

.header__logo {
    width: 10.5vw;
    margin-right: 3.9vw;
}

.header__logo img {
  display: block;
  width: 100%;
  height: auto;
}

.header__contact {
  margin-left: auto;
}

.header__nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.header__nav li {
  margin-right: 4.8vw;
}

.header__nav a {
  font-weight: 300;
  font-size: 0.93vw;
  line-height: 1.33vw;
  text-decoration: none;
  color: #A7A7A7;
  display: block;
  padding-bottom: 17px;
  padding-top: 17px;
  position: relative;
}

.header__nav a:hover, .header__nav a:focus {
  color: #FFF;
}

.video-box {
  width: 100%;
}

.header__nav a.active::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0)), color-stop(51.56%, #FFFFFF), to(rgba(255, 255, 255, 0)));
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #FFFFFF 51.56%, rgba(255, 255, 255, 0) 100%);
}

.header__contact-link {
  font-weight: 300;
  font-size: 0.93vw;
  line-height: 1.33vw;
  text-decoration: none;
  color: #A7A7A7;
  margin-right: 3.33vw;
}

.header__contact-link:hover, .header__contact-link:focus {
  color: #FFF;
}

.header__phone {
  font-weight: normal;
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #FFFFFF;
  text-decoration: none;
}

.header__phone:hover, .header__phone:focus {
  color: #A7A7A7;
}

.banner__head {
  position: relative;
}

.banner__slide {
  min-height: 29.33vw;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.banner__title {
  margin: 0;
  position: absolute;
  z-index: 2;
  left: 0;
  top: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  color: #FFF;
  font-weight: 500;
  font-size: 4.26vw;
  line-height: 5.06vw;
}

.banner__text {
  background-color: #222222;
  padding-top: 30px;
  padding-bottom: 30px;
  color: #FFF;
}

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

.banner__row p {
  margin: 0;
  width: 76.46vw;
}

.about {
  padding-top: 49px;
  padding-bottom: 84px;
}

.about__head {
  margin-bottom: 61px;
}

.about__row {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-bottom: 85px;
}

.about__left {
  width: 40.33vw;
}

.about__video {
  width: 100%;
  display: block;
}

.about__right {
  width: 34.53vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.about__preview-box {
  position: relative;
}

.about__preview-box::after {
  content: "";
  display: block;
  width: 50px;
  height: 50px;
  background-image: url("../img/play.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transition-duration: 0.4s;
          transition-duration: 0.4s;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.about__preview-box:hover::after, .about__preview-box:focus::after {
  -webkit-transform: translate(-50%, -50%) scale(1.2);
          transform: translate(-50%, -50%) scale(1.2);
}

.about__preview {
  display: block;
  width: 100%;
  height: auto;
}

.about__text {
  margin: 0;
  margin-bottom: auto;
}

.about__descript-title {
  margin: 0;
  font-weight: 700;
  font-size: 1.33vw;
  line-height: 1.33vw;
  margin-bottom: 1.33vw;
  margin-top: 20px;
}

.about__descript-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.about__descript-list li {
  display: inline;
  margin-bottom: 4px;
}

.about__feature-list {
  margin: 0;
  padding: 0;
  list-style: none;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.about__feature-item {
  width: 31.17%;
  border-bottom: 1px solid #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-bottom: 14px;
  font-weight: normal;
}

.about__icon {
  display: block;
  height: 41px;
  width: auto;
}

.tab-content {
  display: none;
  /* position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  border: 0;
  clip: rect(0 0 0 0) */
}

.tab-content.tab-active {
  display: block;
}


.tabs-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.tab {
  font-weight: 700;
  font-size: 1.33vw;
  line-height: 1.33vw;
  text-transform: uppercase;
  margin-right: 3.66vw;
  padding-bottom: 30px;
  position: relative;
  cursor: pointer;
  white-space: nowrap;
}

.tab:last-child {
  margin-right: 0;
}

.tab.tab-active::after {
  content: "";
  display: block;
  width: 100%;
  height: 3px;
  bottom: -3px;
  left: 0;
  position: absolute;
  background-color: #000;
}

.tabs--black .tab {
  color: #222222;
  opacity: 0.5;
}

.tabs--black .tab:hover, .tabs--black .tab:focus {
  opacity: 1;
}

.tabs--black .tab.tab-active {
  opacity: 1;
}

.tabs--black .tab.tab-active::after {
  background-color: #000;
}

.tabs--white .tab {
  color: #FFF;
  opacity: 1;
}

.tabs--white .tab.tab-active::after {
  background-color: #FFF;
}

.views {
  position: relative;
}

.views__head {
  position: absolute;
  z-index: 10;
  top: 50px;
  left: 0;
  width: 100%;
}

.views__slide {
  height: 45.46vw;
  max-height: 682px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.views__header-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.infra {
  padding-bottom: 580px;
  position: relative;
  padding-top: 50px;
}

.infra__wrap {
  border-bottom: 0.5px solid #000000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  margin-bottom: 74px;
}

.infra__map {
  position: absolute;
  display: block;
  width: 100%;
  height: 580px;
  bottom: 0;
  left: 0;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.infra__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.infra__time {
  font-size: 5.6vw;
  line-height: 4.6vw;
  -ms-flex-item-align: end;
      align-self: flex-end;
  margin-right: 5px;
  color: #222;
  font-weight: normal;
}

.infra__minutes {
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #222;
}

.infra__distance {
  margin-left: 1.73vw;
}

.infra__distance p {
  margin: 0;
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #222;
  margin-top: 0.33vw;
}

.comfort {
  padding-top: 50px;
  padding-bottom: 108px;
  background-color: #222;
  color: #FFF;
}

.comfort__head {
  margin-bottom: 44px;
}

.comfort__descript {
  width: 37vw;
  margin-left: auto;
  margin-bottom: 22px;
}

.comfort .tabs-list {
  border-bottom: 0.5px solid #FFFFFF;
  margin-bottom: 70px;
}

.comfort__list {
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: 1fr 1fr;
      grid-template-rows: 1fr 1fr;
  -ms-grid-columns: 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 70px 2.52%;
}

.comfort__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.comfort__time {
  font-size: 5.6vw;
  line-height: 4.6vw;
  -ms-flex-item-align: end;
      align-self: flex-end;
  margin-right: 5px;
  color: #FFF;
  font-weight: normal;
}

.comfort__minutes {
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #FFF;
}

.comfort__distance {
  margin-left: 1.26vw;
}

.comfort__distance p {
  margin: 0;
  font-size: 0.93vw;
  line-height: 1.33vw;
  color: #FFF;
  margin-top: 0.33vw;
}

.premium {
  padding-top: 50px;
  padding-bottom: 129px;
}

.premium__head {
  margin-bottom: 60px;
}

.premium__image {
  display: block;
  width: 100%;
  height: auto;
}

.gallery {
  background-color: #222222;
  color: #FFF;
  padding-top: 50px;
  padding-bottom: 85px;
}

.gallery__head {
  margin-bottom: 37px;
}

.gallery__content {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 10.2vw;
  margin-bottom: 10.2vw;
}

.gallery__content-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  z-index: 1;
  margin-top: -2vw;
}

.gallery__content-box::before {
  content: "";
  display: block;
  width: 48vw;
  height: 32.93vw;
  border: 1px solid #FFF;
  position: absolute;
  z-index: -1;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.gallery__descript {
  margin: 0;
}

.gallery__image {
  display: block;
  position: relative;
}

.gallery__image:hover::before, .gallery__image:focus::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  background-image: url("../img/zoom.svg");
  background-repeat: no-repeat;
  background-size: 32px auto;
  background-position: center;
}

.gallery__image img {
  display: block;
  height: 100%;
  width: auto;
}

.gallery__image--one {
  height: 23.86vw;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 1;
}

.gallery__image--two {
  position: absolute;
  bottom: calc(100% + 1.33vw);
  height: 10.2vw;
  right: 0;
}

.gallery__image--three {
  position: absolute;
  bottom: calc(100% + 1.33vw);
  height: 6.06vw;
  left: calc(100% + 1.33vw);
}

.gallery__image--four {
  position: absolute;
  top: 0;
  right: calc(100% + 1.33vw);
  height: 9.6vw;
}

.gallery__image--fife {
  position: absolute;
  bottom: 0;
  right: calc(100% + 1.33vw);
  height: 12.93vw;
}

.gallery__image--six {
  position: absolute;
  left: calc(100% + 1.33vw);
  top: 0;
  height: 12.93vw;
}

.gallery__image--seven {
  position: absolute;
  left: calc(100% + 1.33vw);
  bottom: 0;
  height: 9.6vw;
}

.gallery__image--eight {
  position: absolute;
  right: 0;
  top: calc(100% + 1.33vw);
  width: 16.86vw;
}

.gallery__image--eight img {
  width: 100%;
  height: auto;
}

.gallery__image--nine {
  position: absolute;
  top: calc(100% + 1.33vw);
  right: calc(16.86vw + 1.33vw);
  width: 10.6vw;
}

.gallery__image--nine img {
  width: 100%;
  height: auto;
}

.gallery__image--ten {
  position: absolute;
  top: calc(100% + 1.33vw);
  right: calc(28.8vw + 1.33vw);
  width: 7.93vw;
}

.gallery__image--ten img {
  width: 100%;
  height: auto;
}

.plan {
  padding-top: 50px;
  padding-bottom: 66px;
}

.plan__image .plan__slider .owl-nav button{
  display: block;
  position: absolute;
  top: 0;
  width: 4vw;
  height: 100%;
  border: none;
  background-color: rgba(0, 0, 0, 0.39);
  z-index: 1;
  background-size: 18px auto;
  background-repeat: no-repeat;
  background-position: center;
  outline: none;
  cursor: pointer;
  margin: 0;
}
.plan__image .plan__slider .owl-nav button:hover, .plan__image .plan__slider .owl-nav button:focus {
  background-color: rgba(0, 0, 0, 0.6);
  background-repeat: no-repeat;
  background-position: center;
}
.owl-nav button span{
  display: none;
}
.plan__image .plan__slider .owl-nav .owl-next {
  right: 0;
  background-image: url("../img/right.svg");
}

.plan__image .plan__slider .owl-nav .owl-prev {
  left: 0;
  z-index: 1;
  background-image: url("../img/left.svg");
}
.plan__image .plan__slider .owl-nav button{
  width: 25px;
  background-size: 15px auto;
}

.plan__head {
  margin-bottom: 44px;
}

.plan .tabs-list {
  border-bottom: 0.5px solid #000000;
  margin-bottom: 70px;
}

.plan__box {
  background-color: #F3F3F3;
  padding: 11px 37px 47px;
}

.plan__row {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.plan__image {
  width: 41.26vw;
}

.plan__image img {
  display: block;
  width: 100%;
  height: auto;
}

.plan__content {
  width: 28.26vw;
  padding-top: 2vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.plan__text {
  margin: 0;
}

.plan__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: auto;
}

.plan__info p {
  margin: 0;
  margin-top: 5px;
  font-weight: 600;
  font-size: 1.33vw;
  line-height: 1.33vw;
}

.plan__area {
  margin-right: 50px;
}

.plan__price {
  width: 100%;
  margin-top: 32px;
}

.plan__button {
  margin-top: 35px;
  margin-left: auto;
}

.project {
  background-color: #222222;
  padding-top: 50px;
  padding-bottom: 100px;
  color: #FFF;
}

.project__head {
  margin-bottom: 60px;
}

.project__list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  -ms-grid-rows: auto;
      grid-template-rows: auto;
      grid-template-areas: "one one one one one . two two two two two two"
 "one one one one  one . three three three three three three"
 "four four four four four . three three three three three three"
 "fife fife fife fife fife . three three three three three three"
 "fife fife fife fife fife . six six six six six six"
 "eight eight eight eight . seven seven seven seven seven seven seven"
 "nine nine nine nine . seven seven seven seven seven seven seven"
 "nine nine nine nine ten ten ten ten eleven eleven eleven eleven";
}

.project__item {
  margin-bottom: 3.66vw;
}

.project__item--one {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 5;
  grid-area: one;
}

.project__item--two {
  -ms-grid-row: 1;
  -ms-grid-column: 7;
  -ms-grid-column-span: 6;
  grid-area: two;
}

.project__item--three {
  -ms-grid-row: 2;
  -ms-grid-row-span: 3;
  -ms-grid-column: 7;
  -ms-grid-column-span: 6;
  grid-area: three;
}

.project__item--four {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 5;
  grid-area: four;
}

.project__item--fife {
  -ms-grid-row: 4;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 5;
  grid-area: fife;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.project__item--six {
  -ms-grid-row: 5;
  -ms-grid-column: 7;
  -ms-grid-column-span: 6;
  grid-area: six;
}

.project__item--seven {
  -ms-grid-row: 6;
  -ms-grid-row-span: 2;
  -ms-grid-column: 6;
  -ms-grid-column-span: 7;
  grid-area: seven;
}

.project__item--eight {
  -ms-grid-row: 6;
  -ms-grid-column: 1;
  -ms-grid-column-span: 4;
  grid-area: eight;
}

.project__item--nine {
  -ms-grid-row: 7;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 4;
  grid-area: nine;
  padding-right: 3.33vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.project__item--nine .project__image {
  margin-bottom: 0;
}

.project__item--ten {
  -ms-grid-row: 8;
  -ms-grid-column: 5;
  -ms-grid-column-span: 4;
  grid-area: ten;
  padding-left: 15px;
  padding-right: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.project__item--eleven {
  -ms-grid-row: 8;
  -ms-grid-column: 9;
  -ms-grid-column-span: 4;
  grid-area: eleven;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  padding-left: 3.33vw;
}

.project__item--eleven .project__image {
  margin-bottom: 0;
}

.project__image {
  width: 100%;
  height: auto;
}

.project__name, .project__bigtext {
  font-weight: 400;
  margin: 0;
  text-transform: uppercase;
  font-size: 1.33vw;
  line-height: 1.33vw;
  margin-bottom: 2vw;
  position: relative;
  padding-left: 3.33vw;
}

.project__name::before, .project__bigtext::before {
  content: "";
  display: block;
  width: 2vw;
  height: 1px;
  background-color: #fff;
  position: absolute;
  left: 0;
  top: 50%;
}

.project__bigtext {
  margin-bottom: 0;
  margin-top: auto;
}

.project__text {
  margin: 0;
}

.selection__head {
  padding-top: 50px;
  padding-bottom: 60px;
}

.selection__slide {
  height: 550px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.footer {
  background-color: #222222;
}

.footer__row {
  padding-top: 50px;
  padding-bottom: 30px;
  border-bottom: 1px solid #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.footer__copyright {
  padding-top: 34px;
  padding-bottom: 48px;
}

.footer__copyright p {
  margin: 0;
  color: #FFF;
  font-weight: 300;
  font-size: 12px;
  line-height: 20px;
}

.footer__nav--one {
  margin-right: 6.8vw;
  padding-right: 7.73vw;
  border-right: 1px solid #FFF;
}

.footer__nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer__nav li {
  margin-bottom: 16px;
}

.footer__nav a {
  color: #A7A7A7;
  text-decoration: none;
}

.footer__nav a:hover, .footer__nav a:focus {
  color: #FFF;
}

.footer__contact {
  margin-left: auto;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
}

.footer__phone {
  font-weight: 600;
  text-decoration: none;
  color: #FFF;
  margin-bottom: 16px;
}

.footer__phone:hover, .footer__phone:focus {
  color: #A7A7A7;
}

.footer__time {
  color: #FFF;
}

@media (max-width: 1259px) {
  body {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .button {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .header__nav li {
    margin-right: 3vw;
  }
  .header__nav a {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .header__contact-link {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .header__phone {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .header__logo {
    width: 8vw;
    margin-right: 4vw;
  }
  .infra {
    padding-bottom: 480px;
  }
  .infra__map {
    height: 480px;
  }
  .infra__minutes {
    font-size: 1.1vw;
    line-height: 1.4vw;
  }
  .infra__distance p {
    font-size: 1.1vw;
    line-height: 1.4vw;
  }
  .comfort__list {
    -ms-grid-rows: 1fr 1fr 1fr;
        grid-template-rows: 1fr 1fr 1fr;
    -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
  }
  .comfort__minutes {
    font-size: 1.1vw;
    line-height: 1.4vw;
  }
  .comfort__distance p {
    font-size: 1.1vw;
    line-height: 1.4vw;
  }
  .plan__box {
    padding: 2vw 2vw 4vw;
  }
  .plan__text {
    font-size: 1.3vw;
    line-height: 1.6vw;
  }
  .plan__info {
    font-size: 1.3vw;
    line-height: 1.6vw;
    margin-top: 1.5vw;
  }
  .plan__info p {
    font-size: 1.7vw;
    line-height: 2vw;
  }
  .plan__price {
    margin-top: 20px;
  }
  .project__name {
    font-size: 2vw;
    line-height: 2vw;
  }
  .project__text {
    font-size: 1.2vw;
    line-height: 1.5vw;
  }
  .project__item--ten .project__content {
    margin-bottom: 20px;
  }
  .project__bigtext {
    font-size: 2vw;
    line-height: 2vw;
  }
  .selection__slide {
    height: 36.66vw;
  }
  .tab {
    font-size: 1.5vw;
    line-height: 1.5vw;
    margin-right: 3vw;
  }
}

@media (max-width: 991px) {
  body {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .button {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .section-title,
  .section-number {
    font-size: 2.6vw;
    line-height: 3vw;
  }
  .header {
    padding-top: 0;
    position: relative;
    z-index: 1;
    /* HAMBURGER 4 */
  }
  .header__logo {
    width: 12vw;
  }
  .header__contact-link {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .header__phone {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .header__nav {
    display: none;
    position: absolute;
    z-index: -2;
    top: 80%;
    left: 0;
    width: 100%;
    background-color: #222222;
    padding-bottom: 3vw;
  }
  .header__nav li {
    margin-right: 0;
  }
  .header__nav ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .header__nav a {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .header__row {
    padding-top: 2vw;
    padding-bottom: 2vw;
    background-color: #222222;
  }
  .header__contact {
    margin-right: 8vw;
  }
  .header .burger-menu {
    width: 40px;
    height: 40px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .header .hamburger {
    width: 30px;
    height: 26px;
    position: relative;
    cursor: pointer;
  }
  .header .hamburger .bar {
    padding: 0;
    width: 30px;
    height: 3px;
    background-color: #FFF;
    display: block;
    -webkit-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
    position: absolute;
  }
  .header .bar1 {
    top: 0;
  }
  .header .bar2,
  .header .bar3 {
    top: 11px;
  }
  .header .bar3 {
    right: 0;
  }
  .header .bar4 {
    bottom: 0;
  }
  .header .hamburger3 .bar1 {
    -webkit-transform-origin: 5%;
            transform-origin: 5%;
  }
  .header .hamburger3 .bar4 {
    -webkit-transform-origin: 5%;
            transform-origin: 5%;
  }
  .header .burger-active > .bar1 {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    height: 3px;
    width: 36px;
  }
  .header .burger-active > .bar3 {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    height: 3px;
    background-color: transparent;
  }
  .header .burger-active > .bar2 {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
    height: 3px;
    background-color: transparent;
  }
  .header .burger-active > .bar4 {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
    height: 3px;
    width: 36px;
  }
  .header .hamburger3 .bar3 {
    top: 13.5;
  }
  .header--opened {
    z-index: 5;
  }
  .header--opened .header__nav {
    display: block;
    -webkit-animation-name: menuopen;
            animation-name: menuopen;
    -webkit-animation-duration: 0.8s;
            animation-duration: 0.8s;
  }
  @-webkit-keyframes menuopen {
    0% {
      -webkit-transform: translateY(-100%);
              transform: translateY(-100%);
    }
    100% {
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  @keyframes menuopen {
    0% {
      -webkit-transform: translateY(-100%);
              transform: translateY(-100%);
    }
    100% {
      -webkit-transform: translateY(0);
              transform: translateY(0);
    }
  }
  .banner__slide {
    height: 40vw;
  }
  .about__head {
    margin-bottom: 35px;
  }
  .about__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .about__left {
    margin-bottom: 20px;
  }
  .about__right {
    width: 100%;
  }
  .about__descript-title {
    margin-top: 0;
  }
  .about__text {
    margin-bottom: 20px;
  }
  .about__icon {
    height: 30px;
  }
  .views__head {
    top: 30px;
  }
  .infra {
    padding-bottom: 350px;
  }
  .infra__wrap {
    margin-bottom: 45px;
  }
  .infra__map {
    height: 350px;
  }
  .comfort .tabs-list {
    margin-bottom: 45px;
  }
  .comfort__head {
    margin-bottom: 20px;
  }
  .premium__head {
    margin-bottom: 40px;
  }
  .plan .tabs-list {
    margin-bottom: 45px;
  }
  .plan__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .plan__image {
    width: 100%;
  }
  .plan__content {
    width: 100%;
  }
  .plan__text {
    display: block;
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .plan__info {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .plan__info p {
    font-size: 2.2vw;
    line-height: 2.6vw;
  }
  .project__head {
    margin-bottom: 30px;
  }
  .project__text {
    font-size: 1.6vw;
    line-height: 2.1vw;
  }
  .selection__head {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

@media (max-width: 767px) {
  body {
    font-size: 14px;
    line-height: 20px;
  }
  .button {
    font-size: 4vw;
    line-height: 3vw;
    padding: 3vw 3vw;
  }
  .section-title,
  .section-number {
    font-size: 5vw;
    line-height: 5vw;
  }
  .section-title {
    padding-left: 10vw;
  }
  .arrow {
    background-size: 10px auto;
  }
  .tabs-list {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    width: 100%;
  }
  .tab {
    padding-bottom: 10px;
    font-size: 2.8vw;
    line-height: 3.2vw;
  }
  .tab:last-child {
    margin-right: 0;
  }
  .header {
    padding-bottom: 9vw;
  }
  .header__logo {
    width: 100px;
  }
  .header__row {
    padding-top: 10px;
    padding-bottom: 10px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .header__contact {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    margin: 0;
    width: 100%;
    margin-top: 10px;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .header__phone {
    font-size: 14px;
    line-height: 20px;
  }
  .header__contact-link {
    font-size: 14px;
    line-height: 20px;
  }
  .header__nav a {
    font-size: 14px;
    line-height: 20px;
    padding-top: 10px;
    padding-bottom: 10px;
  }
  .banner__title {
    font-size: 7vw;
    line-height: 8vw;
  }
  .banner__slide {
    height: 60vw;
    max-height: 60vw;
  }
  .banner__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .banner__row span {
    margin-top: 20px;
    -ms-flex-item-align: end;
        align-self: flex-end;
  }
  .about__left {
    width: 100%;
  }
  .about__descript-title {
    font-size: 18px;
    line-height: 22px;
  }
  .about__feature-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .about__feature-item {
    width: 100%;
    margin-bottom: 30px;
  }
  .views__slide {
    height: 70vw;
  }
  .infra__head {
    margin-bottom: 20px;
  }
  .infra__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border-bottom: none;
    margin-bottom: 20px;
  }
  .infra .tabs-list {
    margin-bottom: 20px;
    width: 100%;
    border-bottom: 1px solid #000;
  }
  .infra__time {
    font-size: 11vw;
    line-height: 9vw;
    -ms-flex-item-align: end;
        align-self: flex-end;
  }
  .infra__minutes {
    font-size: 3.3vw;
    line-height: 4.2vw;
  }
  .infra__distance {
    margin-left: 15px;
  }
  .infra__distance p {
    font-size: 3.3vw;
    line-height: 4.2vw;
  }
  .comfort {
    padding-bottom: 50px;
  }
  .comfort__descript {
    width: 100%;
  }
  .comfort__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .comfort__item {
    width: 100%;
    margin-bottom: 35px;
  }
  .comfort__time {
    font-size: 11vw;
    line-height: 9vw;
    -ms-flex-item-align: end;
        align-self: flex-end;
  }
  .comfort__minutes {
    font-size: 3.3vw;
    line-height: 4.2vw;
  }
  .comfort__distance {
    margin-left: 15px;
  }
  .comfort__distance p {
    font-size: 3.3vw;
    line-height: 4.2vw;
  }
  .premium {
    padding-bottom: 60px;
  }
  .gallery {
    padding-bottom: 60px;
  }
  .gallery__head {
    margin-bottom: 20px;
  }
  .gallery__descript {
    margin-bottom: 0;
  }
  .gallery__descript br {
    display: none;
  }
  .gallery__image:hover::before, .gallery__image:focus::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    background-image: url("../img/zoom.svg");
    background-repeat: no-repeat;
    background-size: 22px auto;
    background-position: center;
  }
  .gallery__content {
    margin-top: 20vw;
    margin-bottom: 20vw;
  }
  .plan__text {
    font-size: 14px;
    line-height: 20px;
  }
  .plan__info {
    font-size: 14px;
    line-height: 20px;
    margin-top: 30px;
  }
  .plan__info p {
    font-size: 18px;
    line-height: 22px;
  }
  .project__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .project__name, .project__bigtext {
    font-size: 16px;
    line-height: 20px;
    padding-left: 30px;
  }
  .project__name::before, .project__bigtext::before {
    width: 22px;
  }
  .project__text {
    font-size: 14px;
    line-height: 20px;
  }
  .project__item {
    padding-left: 0;
    padding-right: 0;
  }
  .selection__slide {
    height: 65vw;
  }
  .footer__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    text-align: center;
  }
  .footer__contact {
    margin-left: 0;
    margin-top: 30px;
  }
  .footer__nav--one {
    padding-right: 0;
    margin-right: 0;
    padding-bottom: 20px;
    margin-bottom: 30px;
    border-right: 0;
    border-bottom: 1px solid #FFF;
  }
}

.modal {
  position: fixed;
  display: none;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-color: #fff;
  z-index: 11;
  padding: 30px;
}

.modal form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.modal__title {
  margin: 0;
  margin-bottom: 20px;
  font-size: 26px;
  line-height: 30px;
}

.modal__close {
  position: absolute;
  width: 25px;
  height: 25px;
  right: 10px;
  top: 10px;
  background-image: url("../img/close-button.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  cursor: pointer;
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

.modal__close:hover, .modal__close:focus {
  opacity: 0.6;
}

.modal__input {
  width: 340px;
  height: 55px;
  padding-left: 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-bottom: 15px;
  border: 1px solid #ccc;
}

.modal__button {
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
  font-size: 16px;
  line-height: 20px;
  padding: 17px 20px;
  margin-top: 15px;
}

.modal__bg {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 10;
}

.thankyou {
  display: block;
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 150;
  background: #FFF;
  padding: 30px;
  width: 300px;
  text-align: center;
  display: none;
}

.thankyou__text {
  margin: 0;
  font-size: 20px;
  line-height: 26px;
}

.thankyou__close {
  position: absolute;
  width: 25px;
  height: 25px;
  right: 5px;
  top: 5px;
  background-image: url("../img/close-button.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  cursor: pointer;
}

.thankyou__close:hover, .thankyou__close:focus {
  opacity: 0.7;
}

.thankyou-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 100;
  display: none;
}

@media (max-width: 767px) {
  .modal {
    width: 90%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .modal__title {
    font-size: 22px;
  }
  .modal__input {
    width: 100%;
    height: 45px;
  }
  .modal__button {
    padding: 12px 20px;
  }
}