*,
*::before,
*::after {
  box-sizing: border-box;
}
ul[class],
ol[class] {
  padding: 0;
}
body,
h1,
h2,
h3,
h4,
h5,
h6 p,
li,
figure,
figcaption,
blockquote,
dl,
dd,
span,
p {
  margin: 0;
  line-height: initial;
}
span {
  display: block;
}
a {
  display: block;
  text-decoration: none;
}
label,
input {
  display: block;
}
ul[class],
ol[class] {
  list-style: none;
}
a:not([class]) {
  -webkit-text-decoration-skip: ink;
  text-decoration-skip-ink: auto;
  display: inline;
}
img {
  max-width: 100%;
  display: block;
}
article > * + * {
  margin-top: 1em;
}
input,
button,
textarea,
select {
  font: inherit;
}
input:focus,
button:focus,
textarea:focus,
select:focus {
  outline: none;
}
@font-face {
  font-family: "normalidad";
  src: url("../fonts/normalidad-light-var.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "normalidad";
  src: url("../fonts/normalidad-regular-var.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "normalidad";
  src: url("../fonts/normalidad-medium-var.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
html {
  width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  font-family: "normalidad";
  height: 100%;
}
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
  padding: 0;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100dvh;
}
body.ready {
  height: calc(100vh + 1px);
}
@keyframes fromOpacity {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes rotateWhell {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes showCar {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(82%);
  }
}
@keyframes showCarTablet {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(22%);
  }
}
@keyframes showCarMobile {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(1%);
  }
}
@keyframes transformElems {
  from {
    transform: translateX(0%);
  }
  to {
    transform: translateX(-150vw);
  }
}
@keyframes rotatePlane {
  from {
    transform: rotate(0deg) translateY(0);
  }
  to {
    transform: rotate(-13deg) translateY(-80vh);
  }
}
.whell {
  position: absolute;
  left: 0;
  bottom: 1%;
  width: 4vw;
  height: 4vw;
}
.whell img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: center;
  object-position: center;
}
.whell[data-whell="1"] {
  left: 86.8%;
}
.whell[data-whell="2"] {
  left: 63.4%;
}
.whell[data-whell="3"] {
  left: 23%;
}
.whell[data-whell="4"] {
  left: 9.5%;
}
.logo {
  position: absolute;
  left: 6%;
  top: 4%;
  z-index: 2;
  width: 15%;
  height: 4%;
  z-index: 5;
}
.logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}
.header-content-inner {
  opacity: 0;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.header-content-inner::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, #528fe9 0%, rgba(255, 255, 255, 0) 100%);
}
.header-content {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 4;
}
.header-content__title {
  position: absolute;
  left: 6%;
  font-size: 5.6vw;
  line-height: 90%;
  color: #fff;
  top: 23%;
  font-weight: 500;
}
.header-content__descr {
  position: absolute;
  left: 6%;
  font-size: 2vw;
  line-height: 120%;
  color: #fff;
  top: 62%;
  font-weight: 400;
}
body.loaded .interactive__car {
  animation: showCar 3s ease-in-out forwards;
}
@media (max-width: 992px) {
  body.loaded .interactive__car {
    animation: showCarTablet 3s ease-in-out forwards;
  }
}
@media (max-width: 576px) {
  body.loaded .interactive__car {
    animation: showCarMobile 3s ease-in-out forwards;
  }
}
body.loaded .whell {
  animation: rotateWhell 3s ease-in-out forwards;
}
body.loaded .header-content-inner {
  animation: fromOpacity 1s ease-in-out forwards 3s;
}
body.scrolled .interactive__car-inner,
body.scrolled .interactive__bg,
body.scrolled .header-content {
  animation: transformElems 4s ease-in-out forwards 0.5s;
}
body.scrolled .interactive__plane {
  animation: rotatePlane 4s ease-in-out forwards 0.5s;
}
body.ready-next {
  height: auto;
}
body.full-complite .interactive__car-inner,
body.full-complite .interactive__bg,
body.full-complite .header-content,
body.full-complite .interactive__plane {
  animation: none;
}
.header {
  height: 100vh;
  width: 100vw;
  position: relative;
  overflow: hidden;
}
.elems-wrapper {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.interactive__car-inner {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.interactive__car {
  transform: translateX(-100%);
  position: absolute;
  left: 0;
  bottom: 18%;
  width: 45vw;
  height: 10.5vw;
}
.interactive__car .interactive__car-el {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: top center;
  object-position: top center;
}
.interactive__plane {
  z-index: 2;
  position: absolute;
  right: 2%;
  bottom: 39%;
  width: 53vw;
  height: 15vw;
}
.interactive__plane img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: center;
  object-position: center;
}
.interactive__bg {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: -moz-max-content;
  width: max-content;
}
.interactive__bg img {
  transform: translateX(-9vw);
  width: auto;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: left;
  object-position: left;
  display: block;
  margin: 0;
}
.interactive__bg .mobile {
  display: none;
}
.container {
  max-width: 1280px;
  margin: auto;
  padding: 0px 20px;
}
.second-section {
  padding: 80px 0;
  background: #f4f8ff;
}
.second-section__title {
  color: #041327;
  font-size: 32px;
  font-style: normal;
  font-weight: 500;
  line-height: 120%;
  margin-bottom: 40px;
}
.second-section__descr {
  color: #041327;
  font-size: 22px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
}
.section-content {
  max-width: 920px;
}
.third-section {
  padding: 80px 0;
  background: #fff;
}
.section-title {
  color: #041327;
  font-size: 54px;
  font-style: normal;
  font-weight: 500;
  line-height: 120%;
  text-transform: uppercase;
  margin-bottom: 40px;
}
.third-section__descr {
  color: #041327;
  font-size: 22px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  margin-bottom: 40px;
}
.car__image {
  width: 100%;
  height: 0;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  padding-top: 46.4%;
}
.car__image .car__image__wrapper {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.car__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.marker-item {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg width='13' height='13' viewBox='0 0 13 13' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M7.7832 0.226562H5.7832V5.22656H0.783203V7.22656H5.7832V12.2266H7.7832V7.22656H12.7832V5.22656H7.7832V0.226562Z' fill='white'/%3e%3c/svg%3e ");
  position: absolute;
  width: 3.76%;
  height: 8.11%;
  border-radius: 50%;
  background-repeat: no-repeat;
  background-size: 12px;
  background-position: center;
  background-color: #f50;
  cursor: pointer;
  z-index: 2;
}
.marker-item:hover ~ .dark-bg {
  opacity: 1;
  visibility: visible;
}
.marker-item[data-item="1"] {
  left: 31%;
  top: 54%;
}
.marker-item[data-item="1"]:hover ~ [data-modal="3"] {
  opacity: 1;
  visibility: visible;
}
.marker-item[data-item="2"] {
  left: 40%;
  top: 65%;
}
.marker-item[data-item="2"]:hover ~ [data-modal="2"] {
  opacity: 1;
  visibility: visible;
}
.marker-item[data-item="3"] {
  left: 62%;
  top: 73%;
}
.marker-item[data-item="3"]:hover ~ [data-modal="1"] {
  opacity: 1;
  visibility: visible;
}
.marker-item[data-item="4"] {
  left: 67%;
  top: 68%;
}
.marker-item[data-item="4"]:hover ~ [data-modal="4"] {
  opacity: 1;
  visibility: visible;
}
.marker-item[data-item="5"] {
  left: 76%;
  top: 32%;
}
.marker-item[data-item="5"]:hover ~ [data-modal="5"] {
  opacity: 1;
  visibility: visible;
}
.four-section {
  padding: 80px 0;
  background: #f4f8ff;
}
.orange-block {
  margin-bottom: 40px;
  border-radius: 10px;
  background: #90b750;
  padding: 40px 50px;
  padding-right: 360px;
  background-image: url(../img/orange-bg.svg);
  background-repeat: no-repeat;
  background-size: 240px;
  background-position: right 50px center;
  color: #fff;
  font-size: 28px;
  font-style: normal;
  font-weight: 500;
  line-height: 120%;
}
.orange-block span {
  font-size: 14px;
  display: inline;
}
.five-section {
  padding: 80px 0;
  background-color: #fff;
}
.five-section__video {
  margin-bottom: 40px;
  position: relative;
  height: 0;
  padding-top: 54.85%;
}
.five-section__video .video__wrapper {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.five-section__video .video__wrapper video {
  cursor: pointer;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.six-section {
  padding: 80px 0;
  background: #f4f8ff;
}
.six-section .swiper-slide {
  border-radius: 10px;
  overflow: hidden;
}
.six-section .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}
.gallery-slider__main {
  position: relative;
  height: 0;
  padding-top: 55%;
  margin-bottom: 20px;
}
.mySwiper2 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
}
.gallery-slider__thumbs {
  position: relative;
  height: 0;
  padding-top: 11.3%;
}
.gallery-slider__thumbs .mySwiper {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
}
.gallery-slider__thumbs .swiper-slide {
  cursor: pointer;
  border: 2px solid #fff;
}
.gallery-slider__thumbs .swiper-slide.swiper-slide-thumb-active {
  border: 2px solid #f50;
}
.six-section .section-title {
  width: -moz-fit-content;
  width: fit-content;
  position: relative;
}
.six-section .section-title::before {
  transform: translateX(110%);
  position: absolute;
  right: 0;
  top: -10px;
  content: "";
  width: 544px;
  height: 115px;
  background-image: url(../img/title-plane.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}
.dark-bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
}
.marker-modal {
  z-index: 2;
  color: #fff;
  font-size: clamp(1px, 2.3vw, 28px);
  font-style: normal;
  font-weight: 500;
  line-height: 120%;
  border-radius: 10px;
  background: #f50;
  padding: clamp(1px, 2.4vw, 30px);
  position: absolute;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
}
.marker-modal[data-modal="1"] {
  left: 19%;
  top: 25%;
  width: 43%;
}
.marker-modal[data-modal="2"] {
  left: 14%;
  top: 22%;
  width: 26%;
}
.marker-modal[data-modal="3"] {
  left: 8%;
  top: 37%;
  width: 23%;
}
.marker-modal[data-modal="4"] {
  left: 29%;
  top: 10%;
  width: 38%;
}
.marker-modal[data-modal="5"] {
  left: 22%;
  top: 37%;
  width: 54%;
}
.footer {
  padding: 50px 0;
  background: #f4f8ff;
}
.footer__btns {
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}
.footer__btn {
  cursor: pointer;
  padding: 7px 20px;
  border-radius: 64px;
  background: #003ca6;
  color: #fff;
  font-size: 24px;
  font-weight: 507;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.footer__btn:last-child {
  background: #f50;
}
.footer__btn span {
  line-height: 100%;
}
.footer__btn .ico {
  width: 37px;
  height: 37px;
}
.footer__btn .ico svg {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: center;
  object-position: center;
}
@media (max-width: 1024px) {
  .six-section .section-title::before {
    display: none;
  }
  .marker-modal {
    font-size: 20px;
  }
}
.mob-descr {
  display: none;
  font-size: 14px;
  color: #041327;
  font-weight: 500;
  line-height: 120%;
  background: #f4f8ff;
  padding: 0 20px;
  padding-bottom: 10px;
  margin: 0px -20px;
}
.mob-descr span {
  display: inline-block;
  color: red;
  font-size: 18px;
  height: 10px;
  vertical-align: text-top;
}
.mob-descr p {
  margin-bottom: 10px;
}
@media (max-width: 992px) {
  .mob-descr {
    display: block;
  }
  .third-section__car {
    background-image: url(../img/mob-car-info.jpg);
    height: 158vw;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    margin-right: -20px;
    margin-left: -20px;
  }
  .car__image {
    display: none;
  }
  .header-content-inner {
    padding: 20px;
    padding-top: 10vh;
  }
  .header-content__title {
    font-size: 8vw;
    margin-bottom: 5vh;
    margin-top: 3vh;
  }
  .header-content__descr {
    font-size: 2.5vw;
  }
  .header-content__title,
  .header-content__descr {
    position: static;
  }
  .header-content-inner::before {
    /* z-index: -1;
    background: linear-gradient(
      180deg,
      #528fe9 10%,
      rgba(255, 255, 255, 0) 50%
    ); */
    display: none;
  }

  .interactive__bg::before {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: linear-gradient(
      180deg,
      #528fe9 10%,
      rgba(255, 255, 255, 0) 50%
    );
    z-index: 2;
  }

  .logo {
    left: 50%;
    transform: translateX(-50%);
    width: 200px;
    height: 50px;
  }
  .interactive__plane {
    right: 4%;
    bottom: 39%;
    width: 77vw;
    height: 23vw;
  }
  .interactive__car {
    transform: translateX(-120%);
    bottom: 18%;
    width: 74vw;
    height: 17.7vw;
  }
  .whell {
    width: 7vw;
    height: 7vw;
  }
  .whell[data-whell="1"] {
    left: 86.65%;
  }
}
@media (max-width: 768px) {
  .orange-block {
    padding: 30px;
    font-size: 22px;
    background-image: none;
  }
  .footer__btns {
    flex-direction: column;
  }
  .footer__btn {
    width: 100%;
    justify-content: space-between;
  }
}
@media (max-width: 576px) {
  .footer__btn {
    font-size: 18px;
  }
  .interactive__bg .desctop {
    display: none;
  }
  .interactive__bg .mobile {
    display: block;
  }
  .interactive__car {
    bottom: 26%;
    width: 98vw;
    height: 24vw;
  }
  .whell {
    width: 9vw;
    height: 9vw;
    bottom: 5%;
  }
  .interactive__plane {
    right: 2%;
    bottom: 41%;
    width: 99vw;
    height: 30vw;
  }
  .header-content__title {
    font-size: 10vw;
  }
  .header-content__descr {
    font-size: 5vw;
  }
  .header-content__descr br {
    display: none;
  }
  .logo {
    top: 2%;
  }
  .six-section,
  .five-section,
  .four-section,
  .third-section,
  .second-section {
    padding: 30px 0;
  }
  .second-section__title {
    font-size: 26px;
  }
  .second-section__descr,
  .third-section__descr {
    font-size: 18px;
  }
  .section-title {
    font-size: 32px;
    margin-bottom: 20px;
  }
  .orange-block {
    font-size: 20px;
    padding: 15px;
    margin-bottom: 20px;
    margin-top: 40px;
  }
  .gallery-slider__thumbs {
    padding-top: 18%;
  }
  .gallery-slider__main {
    margin-bottom: 10px;
  }

  .four-section .third-section__descr:last-child,
  .five-section__video {
    margin-bottom: 0;
  }
}

.nameplate-description {
  font-size: clamp(1px, 1.21vw, 16px);
  font-style: italic;
  display: inline-block;
  margin-top: clamp(1px, 0.8vw, 10px);
}
