* {
   padding: 0;
   margin: 0;
   border: 0;
   -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
   -webkit-tap-highlight-color: transparent;
   scrollbar-color: #fdce2a #f1f1f1;
   scrollbar-width: thin
}

::-webkit-scrollbar-thumb {
   background-color: #fdce2a
}

::-webkit-scrollbar-track {
   background-color: #f1f1f1
}

::-webkit-scrollbar-button {
   display: none;
   background-color: #fdce2a
}

::-webkit-scrollbar {
   width: 8px
}

*,
:after,
:before {
   box-sizing: border-box
}

:active,
:focus {
   outline: 0
}

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

aside,
footer,
header,
nav {
   display: block
}

body,
html {
   height: 100%;
   width: 100%;
   font-size: 100%;
   -ms-text-size-adjust: 100%;
   -moz-text-size-adjust: 100%;
   -webkit-text-size-adjust: 100%
}

input::-ms-clear {
   display: none
}

button {
   cursor: pointer
}

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

a,
a:visited {
   text-decoration: none
}

a:hover {
   text-decoration: none
}

a,
button {
   -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
   -webkit-tap-highlight-color: transparent;
   background: 0 0;
   font-family: inherit
}

ul li {
   list-style: none
}

img {
   vertical-align: top;
   max-width: 100%
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Black.woff2) format("woff2"), url(../fonts/Gilroy-Black.woff) format("woff");
   font-weight: 900;
   font-style: normal
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Bold.woff2) format("woff2"), url(../fonts/Gilroy-Bold.woff) format("woff");
   font-weight: 700;
   font-style: normal
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Extrabold.woff2) format("woff2"), url(../fonts/Gilroy-Extrabold.woff) format("woff");
   font-weight: 800;
   font-style: normal
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Medium.woff2) format("woff2"), url(../fonts/Gilroy-Medium.woff) format("woff");
   font-weight: 500;
   font-style: normal
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Regular.woff2) format("woff2"), url(../fonts/Gilroy-Regular.woff) format("woff");
   font-weight: 400;
   font-style: normal
}

@font-face {
   font-family: HelveticaNeueCyr;
   font-display: swap;
   src: url(../fonts/HelveticaNeueCyr-Medium.woff2) format("woff2"), url(../fonts/HelveticaNeueCyr-Medium.woff) format("woff");
   font-weight: 500;
   font-style: normal
}

@font-face {
   font-family: HelveticaNeueCyr;
   font-display: swap;
   src: url(../fonts/HelveticaNeueCyr-Regular.woff2) format("woff2"), url(../fonts/HelveticaNeueCyr-Regular.woff) format("woff");
   font-weight: 400;
   font-style: normal
}

@font-face {
   font-family: Gilroy;
   font-display: swap;
   src: url(../fonts/Gilroy-Semibold.woff2) format("woff2"), url(../fonts/Gilroy-Semibold.woff) format("woff");
   font-weight: 600;
   font-style: normal
}

@font-face {
   font-family: TacticSansExd;
   font-display: swap;
   src: url(../fonts/TacticSansExd-Black.woff2) format("woff2"), url(../fonts/TacticSansExd-Black.woff) format("woff");
   font-weight: 900;
   font-style: normal
}

@font-face {
   font-family: TacticSansExd;
   font-display: swap;
   src: url(../fonts/TacticSansExd-Medium.woff2) format("woff2"), url(../fonts/TacticSansExd-Medium.woff) format("woff");
   font-weight: 500;
   font-style: normal
}

@font-face {
   font-family: TacticSansExd;
   font-display: swap;
   src: url(../fonts/TacticSansExd-Bold.woff2) format("woff2"), url(../fonts/TacticSansExd-Bold.woff) format("woff");
   font-weight: 700;
   font-style: normal
}

.button {
   border-radius: 100px;
   display: flex;
   align-items: center;
   justify-content: center;
   background: #fdce2a;
   padding: 10px;
   height: 90px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   line-height: 140%;
   gap: 10px;
   width: -moz-max-content;
   width: max-content;
   min-width: 214px;
   transition: all .3s ease 0s;
   border: 2px solid transparent
}

.button-icon {
   width: 36px;
   height: 36px;
   border-radius: 50%;
   background: #2f282e;
   display: inline-flex;
   justify-content: center;
   align-items: center;
   transition: all .3s ease 0s
}

.button-icon svg {
   width: 16px;
   height: 16px;
   -o-object-fit: contain;
   object-fit: contain;
   color: #fff
}

section.element-animation .container {
   transition: all .8s ease 0s;
   opacity: 0;
   transform: translateY(20px)
}

section.element-animation.element-show .container {
   opacity: 1;
   transform: translateY(0)
}

.title {
   font-family: TacticSansExd;
   font-weight: 700;
   line-height: 120%;
   text-transform: uppercase;
   font-size: 48px
}

.title.element-animation {
   transition: all .5s ease 0s;
   opacity: 0;
   transform: translateY(20px)
}

.title.element-animation.element-show {
   opacity: 1;
   transform: translateY(0)
}

.title-grey {
   color: #959194
}

.title-line {
   flex: 1;
   width: 100%;
   border-bottom: 1px solid #2f282e
}

.slider-next,
.slider-prev {
   width: 66px;
   height: 66px;
   border-radius: 50%;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 33px;
   border: 1px solid #2f282e;
   -webkit-user-select: none;
   -moz-user-select: none;
   user-select: none;
   cursor: pointer
}

.slider-next svg,
.slider-prev svg {
   width: 20px;
   height: 20px;
   -o-object-fit: contain;
   object-fit: contain;
   transition: all .3s ease 0s
}

.slider-next.swiper-button-disabled,
.slider-prev.swiper-button-disabled {
   opacity: 0
}

.slider-prev svg {
   color: #2f282e
}

.slider-next {
   background: #2f282e
}

.slider-next svg {
   color: #fff
}

.switch {
   position: relative;
   display: inline-block;
   width: 63px;
   height: 24px
}

.switch input {
   opacity: 0;
   width: 0;
   height: 0
}

.switch__slider {
   position: absolute;
   cursor: pointer;
   top: 0;
   left: 0;
   right: 0;
   bottom: 0;
   background-color: #ccc;
   transition: .4s;
   border-radius: 25px
}

.switch__slider::before {
   content: "";
   position: absolute;
   height: 20px;
   width: 20px;
   left: 2px;
   bottom: 2px;
   background-color: #fff;
   transition: .4s;
   border-radius: 50%
}

input:checked+.switch__slider {
   background-color: #8bc34a
}

input:checked+.switch__slider:before {
   transform: translateX(39px)
}

html {
   scroll-behavior: smooth
}

body {
   height: 100%;
   font-family: Gilroy;
   font-size: 16px;
   line-height: 140%;
   color: #2f282e
}

.wrapper {
   min-height: 100%;
   display: flex;
   flex-direction: column;
   background: #fff;
   overflow-x: hidden
}

main {
   flex: 1 1 auto
}

.container {
   width: calc(100% - 140px);
   margin-inline: auto
}

.menu {
   border-radius: 100px;
   background: #eaeaea
}

.menu__icon {
   display: none
}

.menu__body {
   display: flex;
   align-items: center;
   gap: 30px;
   justify-content: space-between;
   padding: 12px
}

.menu__body-logo {
   display: none
}

.menu__body-close {
   display: none
}

.menu__list {
   max-width: 415px;
   flex: 1;
   display: flex;
   align-items: center;
   justify-content: space-between;
   width: 100%;
   gap: 20px;
   margin-left: 33px
}

.menu__link {
   white-space: nowrap;
   color: #1d212c;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   line-height: 140%;
   transition: all .3s ease 0s
}

.menu__tel a {
   color: #1d212c;
   font-family: Gilroy;
   font-size: 24px;
   font-weight: 600;
   line-height: 140%;
   white-space: nowrap;
   transition: all .3s ease 0s
}

.menu__socials {
   display: flex;
   align-items: center;
   gap: 10px
}

.menu__social {
   width: 50px;
   height: 50px;
   border-radius: 50%;
   background: #2f282e;
   display: flex;
   align-items: center;
   justify-content: center
}

.menu__social svg {
   width: 24px;
   height: 24px;
   -o-object-fit: contain;
   object-fit: contain;
   color: #fff;
   transition: all .3s ease 0s
}

.hero {
   background: #f1f1f1;
   border-radius: 0 0 75px 75px
}

.hero__body {
   padding: 30px;
   display: flex;
   height: 100vh;
   min-height: 700px;
   max-height: 1080px;
   position: relative
}

.hero__logo-bg {
   position: absolute;
   bottom: 0;
   left: 50%;
   transform: translateX(-58%);
   width: 50%;
   height: auto;
   z-index: 0
}

.hero__logo-bg svg {
   width: 100%;
   -o-object-fit: contain;
   object-fit: contain;
   color: #e7e7e7;
   max-height: 10vh
}

.hero__logo-bg.element-animation {
   transition: all 2s ease .5s;
   filter: blur(20px);
   opacity: 0
}

.hero__logo-bg.element-animation.element-show {
   opacity: 1;
   filter: blur(0)
}

.hero__image {
   flex: 0 0 46%;
   position: relative;
   overflow: hidden;
   border-radius: 35px
}

.hero__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.hero__logo {
   position: absolute;
   top: 30px;
   left: 0;
   border-radius: 0 50px 50px 0;
   -webkit-backdrop-filter: blur(15px);
   backdrop-filter: blur(15px);
   background: rgba(0, 0, 0, .2);
   text-align: center;
   padding: 19px
}

.hero__logo img {
   max-width: 189px
}

.hero__info {
   flex: 0 0 54%;
   background: #fff;
   display: flex;
   flex-direction: column;
   justify-content: start;
   padding: 20px 20px 20px 112px;
   border-radius: 35px
}

.hero__title {
   margin-top: 60px;
   margin-left: 10px;
   font-size: 2.5vw
}

.hero__subtitle {
   max-width: 346px;
   color: #2f282e;
   font-family: TacticSansExd;
   font-size: 20px;
   font-weight: 400;
   line-height: 130%;
   margin-left: auto;
   background: #fff;
   margin-top: -20px;
   z-index: 2;
   padding-left: 10px
}

.hero__benefits {
   margin-bottom: 30px
}

.hero__benefit {
   width: -moz-max-content;
   width: max-content;
   padding: 10px 30px;
   border: 1px solid #000;
   border-radius: 50px;
   position: relative;
   color: #1d212c;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 400;
   line-height: 140%;
   text-align: left
}

.hero__benefit:not(:last-child) {
   margin-bottom: 10px
}

.hero__att {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 700;
   line-height: 130%;
   margin-bottom: 27px;
   max-width: 703px
}

.hero__buttons {
   position: relative;
   z-index: 3;
   display: flex;
   align-items: center;
   gap: 10px
}

.works {
   background: #fff
}

.works__body {
   padding: 90px 0 45px
}

.works__title {
   display: flex;
   gap: 10px;
   justify-content: space-between;
   margin-bottom: 80px
}

.works__title span:nth-child(3) {
   display: inline-block;
   transform: translateY(60px);
   text-align: right
}

.works__title span:nth-child(3) b {
   font-size: 1.65em
}

.works__content {
   border-radius: 35px;
   background: #f1f1f1;
   overflow: hidden
}

.works__slide {
   padding: 30px;
   display: flex;
   gap: 30px
}

.works__values {
   border-radius: 25px;
   background: #fff;
   padding: 12px 48px 18px;
   display: flex;
   align-items: center
}

.works__values-wrapper {
   display: flex;
   align-items: center;
   width: 100%
}

.works__value {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   line-height: 140%;
   flex: 0 0 50%
}

.works__value span {
   display: block;
   color: #60575e;
   font-size: 16px;
   font-weight: 400
}

.works__value:nth-child(2) span {
   font-size: 24px;
   font-weight: 700
}

.works__images {
   flex: 0 1 63%;
   display: flex;
   width: 100%
}

.works__image {
   flex: 0 0 50%;
   position: relative;
   width: 100%;
   height: 100%;
   border-radius: 25px;
   overflow: hidden
}

.works__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.works__image:nth-child(2) .works__images-label {
   background: #fdce2a
}

.works__images-label {
   position: absolute;
   top: 20px;
   left: 20px;
   z-index: 2;
   border-radius: 15px;
   background: #fff;
   padding: 6px 15px;
   color: #2f282e;
   font-family: TacticSansExd;
   font-size: 18px;
   font-weight: 700;
   line-height: 120%;
   text-transform: uppercase
}

.works__details {
   position: relative;
   flex: 0 1 37%
}

.works__text {
   border-radius: 25px;
   background: #fff;
   margin-bottom: 5px;
   padding: 46px 48px
}

.works__text-item {
   color: #484146;
   font-family: Gilroy;
   font-size: 16px;
   font-weight: 400;
   line-height: 140%
}

.works__text-item:not(:last-child) {
   margin-bottom: 11px
}

.works__text-title {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 22px;
   font-weight: 600;
   line-height: 140%;
   margin-bottom: 3px
}

.works__slide-buttons {
   position: absolute;
   bottom: 0;
   right: 0;
   display: flex;
   align-items: center;
   justify-content: end;
   gap: 5px
}

.calculation__body {
   padding: 45px 0 90px
}

.calculation__title {
   margin-bottom: 10px
}

.calculation__items {
   display: flex;
   gap: 30px
}

.calculation__item {
   flex: 0 1 33.333%;
   padding: 10px 30px;
   border-radius: 20px;
   position: relative
}

.calculation__item:nth-child(1) {
   background: #2f282e;
   color: #fff
}

.calculation__item:nth-child(2) span,
.calculation__item:nth-child(3) span {
   display: inline-block;
   margin-top: auto
}

.calculation__bg {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%
}

.calculation__bg img {
   width: 100%;
   height: 100%;
   -o-object-fit: fill;
   object-fit: fill
}

.calculation__text {
   font-size: 24px;
   font-weight: 500;
   line-height: 140%
}

.calculation__link {
   display: flex;
   justify-content: space-between;
   gap: 20px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 24px;
   font-weight: 500;
   line-height: 140%;
   height: 100%;
   width: 81%;
   padding-top: 6px;
   z-index: 2;
   position: relative
}

.calculation__link svg {
   width: 24px;
   height: 24px;
   -o-object-fit: contain;
   object-fit: contain;
   transition: all .3s ease 0s
}

.calculation__link span {
   transition: all .3s ease 0s
}

.calculation__icon {
   position: absolute;
   top: 0;
   right: 0;
   border-radius: 20px;
   display: flex;
   align-items: center;
   justify-content: center;
   height: 80%;
   width: auto;
   aspect-ratio: 1/1;
   z-index: 2
}

.calculation__icon svg {
   width: 38px;
   height: 38px;
   -o-object-fit: contain;
   object-fit: contain;
   color: #fdce2a;
   transition: all .3s ease 0s
}

.get {
   background: #f1f1f1;
   border-radius: 75px 75px 0 0
}

.get__body {
   padding: 70px 0
}

.get__cards {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   grid-template-rows: repeat(3, 1fr);
   gap: 30px
}

.get__card {
   border-radius: 35px;
   background: #fff;
   position: relative;
   overflow: hidden;
   padding: 40px
}

.get__card:nth-child(1) {
   grid-column: span 2;
   display: flex;
   flex-direction: column;
   background: 0 0;
   padding: 0;
   border-radius: 0
}

.get__card:nth-child(2) {
   grid-row: span 2
}

.get__card:nth-child(2) .get__card-image img {
   -o-object-position: top;
   object-position: top
}

.get__card:nth-child(5) {
   display: flex;
   flex-direction: column
}

.get__card:nth-child(5) p {
   font-weight: 700;
   line-height: 120%;
   font-size: calc(16px + 14 * ((100vw - 320px)/ 1600))
}

.get__card:nth-child(5) p:nth-child(2) {
   margin-top: auto;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.get__card:nth-child(2) p {
   font-size: calc(16px + 14 * ((100vw - 320px)/ 1600));
   font-weight: 700
}

.get__subtitle {
   margin-top: auto
}

.get__card-descr {
   position: relative;
   z-index: 2;
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 500;
   line-height: 140%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.get__card-image {
   position: absolute;
   top: 0;
   left: 0;
   inset: 0
}

.get__card-image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.get__icon {
   width: 50px;
   height: 50px;
   border-radius: 10px;
   background: #fdce2a;
   display: flex;
   align-items: center;
   justify-content: center;
   margin-bottom: 20px;
   z-index: 2;
   position: relative
}

.get__icon svg {
   width: 26px;
   height: 26px
}

.get__procente {
   position: absolute;
   top: 50%;
   right: 20px;
   transform: translateY(-50%);
   height: 80%
}

.get__procente img {
   height: 100%;
   width: auto;
   -o-object-fit: contain;
   object-fit: contain
}

.gallery {
   background: #f1f1f1
}

.gallery__body {
   position: relative;
   padding: 20px 0;
   width: calc(100% - 75px);
   margin-left: auto;
   max-height: 870px
}

.gallery__slide {
   width: 40%;
   height: auto
}

.gallery__slide img {
   width: 100%;
   height: 100%;
   border-radius: 35px;
   -o-object-fit: cover;
   object-fit: cover;
   cursor: pointer;
   transition: all .3s ease 0s
}

.gallery__slide.gallery__slide-group {
   width: 50%;
   display: flex;
   grid-template-columns: 1fr 1fr
}

.gallery__slide.gallery__slide-group img {
   display: block;
   width: 100%;
   height: auto;
   aspect-ratio: 1/1;
   -o-object-fit: contain;
   object-fit: contain
}

.gallery__slide.gallery__slide-group picture:nth-child(1),
.gallery__slide.gallery__slide-group img:nth-child(1) {
   -o-object-position: top;
   object-position: top;
   margin-bottom: auto
}

.gallery__slide.gallery__slide-group picture:nth-child(2),
.gallery__slide.gallery__slide-group img:nth-child(2) {
   margin-top: auto;
   -o-object-position: bottom;
   object-position: bottom
}

.gallery__slider-prev {
   position: absolute;
   top: 50%;
   left: 0;
   translate: -50% 0;
   z-index: 2
}

.gallery__slider-next {
   position: absolute;
   top: 50%;
   right: 0;
   translate: -50% 0;
   z-index: 2
}

.steps {
   background: #f1f1f1;
   padding-top: 150px
}

.steps__body .title {
   margin-bottom: 40px
}

.steps__wrapper {
   background: #fff;
   border-radius: 75px
}

.steps__item {
   padding: 35px 0;
   display: flex;
   gap: 20px;
   position: relative
}

.steps__item:not(:last-child) {
   border-bottom: 1px solid #959194
}

.steps__item:nth-child(2) .steps__item-image {
   left: 10%
}

.steps__item:nth-child(3) .steps__item-image {
   left: 15%
}

.steps__item:nth-child(1) .steps__item-image {
   left: 20%
}

.steps__item-num {
   color: #2f282e;
   font-family: TacticSansExd;
   font-size: 30px;
   font-weight: 400;
   line-height: 120%;
   flex: 1;
   transition: all .3s ease 0s
}

.steps__item-image {
   position: absolute;
   left: 10%;
   bottom: 0;
   opacity: 0;
   transform: scale(.5);
   transition: all .8s ease 0s
}

.steps__item-image img {
   border-radius: 35px
}

.steps__item-text {
   flex: 0 0 50%
}

.steps__item-name {
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 600;
   line-height: 140%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600));
   margin-bottom: 12px
}

.steps__item-descr {
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 400;
   line-height: 140%;
   font-size: calc(14px + 4 * ((100vw - 320px)/ 1600))
}

.steps__item-buttons {
   display: flex;
   align-items: center;
   gap: 10px;
   margin-top: 30px
}

.agit {
   background: #f1f1f1
}

.agit__body {
   padding: 90px 0;
   display: flex;
   align-items: center;
   gap: 30px
}

.agit__image {
   flex: 0 1 30%
}

.agit__text {
   flex: 0 1 70%
}

.agit .title {
   font-size: 28px;
   margin-bottom: 20px
}

.agit__subtitle {
   margin-bottom: 80px;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.agit .calculation__item {
   flex: 0 1 50%;
   height: 66px
}

.agit .calculation__icon {
   margin-right: 5px
}

.about {
   background: #f1f1f1
}

.about__body {
   padding: 90px 0;
   display: flex;
   gap: 32px
}

.about__info {
   flex: 0 1 62.5%;
   display: flex;
   flex-direction: column;
   justify-content: space-between;
   gap: 20px
}

.about__details {
   display: flex;
   align-items: end
}

.about__att {
   flex: 0 1 75%
}

.about__att span {
   color: #2f282e;
   font-family: TacticSansExd;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600));
   font-weight: 400;
   line-height: 120%;
   text-transform: uppercase;
   display: flex;
   align-items: end;
   gap: 10px
}

.about__att span img {
   width: 60%
}

.about__descr {
   margin-top: 130px;
   max-width: 70%;
   color: #2f282e;
   font-family: Gilroy;
   font-size: calc(16px + 4 * ((100vw - 320px)/ 1600));
   font-weight: 500;
   line-height: 140%
}

.about__att-image {
   flex: 0 1 25%
}

.about__image {
   flex: 0 1 37.5%;
   width: 100%
}

.about__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   border-radius: 35px
}

.calculator {
   background: #f1f1f1
}

.calculator__wrapper {
   background: #fff;
   border-radius: 75px
}

.calculator__body {
   padding: 70px 0
}

.calculator__title {
   text-align: center;
   margin-bottom: 20px
}

.calculator__progress {
   border-radius: 10px;
   background: #d9d9d9;
   width: 100%;
   height: 4px;
   max-width: 870px;
   margin-inline: auto;
   position: relative;
   transition: all .5s ease 0s;
   margin-bottom: 30px
}

.calculator__progress-thumb {
   position: absolute;
   top: 0;
   left: 0;
   transform-origin: left;
   background: #fdce2a;
   width: 33.333%;
   height: 100%;
   z-index: 2;
   transition: all .5s ease 0s
}

.calculator__subtitles {
   margin-bottom: 40px
}

.calculator__subtitle {
   display: none;
   width: -moz-max-content;
   width: max-content;
   position: relative;
   margin-inline: auto;
   text-align: center;
   border-radius: 50px;
   background: #fdce2a;
   padding: 10px 30px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: calc(18px + 6 * ((100vw - 320px)/ 1600));
   font-weight: 600
}

.calculator__subtitle::after {
   content: "";
   position: absolute;
   top: 100%;
   left: 50%;
   transform: translateX(-50%);
   width: 0;
   height: 0;
   border-top: 10px solid #fdce2a;
   border-left: 10px solid transparent;
   border-right: 10px solid transparent;
   border-bottom: 10px solid transparent
}

.calculator__subtitle.active {
   display: block
}

.calculator__steps {
   position: relative;
   min-height: 260px
}

.calculator__step {
   display: none
}

.calculator__step.active {
   display: block
}

.calculator__types {
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 20px;
   max-width: 690px;
   margin-inline: auto;
   margin-top: 60px
}

.calculator__types-input {
   display: none
}

.calculator__type {
   width: 130px;
   height: 130px;
   border: 1px solid transparent;
   border-radius: 25px;
   display: flex;
   align-items: center;
   justify-content: center;
   flex-direction: column;
   padding: 5px;
   transition: all .3s ease 0s;
   cursor: pointer
}

.calculator__type.active {
   border-color: #fdce2a
}

.calculator__type.active .calculator__type-icon {
   transform: scale(1)
}

.calculator__type.active .calculator__type-icon svg {
   color: #fdce2a
}

.calculator__type.active .calculator__type-name {
   color: #2f282e
}

.calculator__type-icon {
   width: 100%;
   height: auto;
   transition: all .3s ease 0s;
   transform: scale(.9)
}

.calculator__type-icon svg {
   width: 100%;
   height: 100%;
   max-height: 50px;
   -o-object-fit: contain;
   object-fit: contain;
   color: #999
}

.calculator__type-name {
   color: #999;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 500;
   line-height: 140%;
   text-align: center
}

.calculator__buttons {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 10px;
   margin-top: 30px
}

.calculator__button {
   display: flex;
   align-items: center;
   gap: 10px;
   width: -moz-max-content;
   width: max-content;
   padding: 10px 30px;
   box-sizing: border-box;
   border: 1px solid #2f282e;
   border-radius: 100px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   transition: all .3s ease 0s
}

.calculator__button:first-child {
   border: 1px solid #959194
}

.calculator__button:first-child .calculator__button-icon {
   background: #959194
}

.calculator__button:first-child .calculator__button-icon svg {
   color: #fff
}

.calculator__button-icon {
   flex: 0 0 36px;
   width: 36px;
   height: 36px;
   border-radius: 50%;
   background: #fdce2a;
   display: flex;
   align-items: center;
   justify-content: center
}

.calculator__button-icon svg {
   width: 14px;
   height: 14px
}

.calculator__loader {
   display: none;
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   width: 40px;
   height: 40px;
   border: 4px solid rgba(255, 255, 255, .3);
   border-top: 4px solid #fdce2a;
   border-right: 4px solid #fdce2a;
   border-bottom: 4px solid #fdce2a;
   border-radius: 50%;
   animation: spin .8s linear infinite;
   z-index: 10
}

@keyframes spin {
   0% {
      transform: translate(-50%, -50%) rotate(0)
   }

   100% {
      transform: translate(-50%, -50%) rotate(360deg)
   }
}

.loading .calculator__loader {
   display: block
}

.loading .calculator__step {
   display: none
}

.calculator__details {
   display: flex;
   justify-content: end;
   position: relative
}

.calculator__details-car {
   flex: 1;
   display: flex;
   justify-content: center
}

.calculator__details-items {
   position: absolute;
   top: 0;
   left: 70%;
   max-height: 400px;
   overflow-y: auto
}

.calculator__details-item {
   padding: 5px 30px 5px 40px;
   border: 1px solid #959194;
   border-radius: 50px;
   width: -moz-max-content;
   width: max-content;
   gap: 10px;
   position: relative;
   display: none;
   margin-bottom: 8px;
   -moz-column-break-inside: avoid;
   break-inside: avoid-column
}

.calculator__details-item.active {
   display: flex
}

.calculator__details-item::before {
   content: "";
   position: absolute;
   top: 3px;
   left: 5px;
   width: 26px;
   height: 26px;
   border-radius: 50%;
   background-image: url(../img/icons/icon-check.svg);
   background-size: 12px 12px;
   background-position: center center;
   background-repeat: no-repeat;
   background-color: #fdce2a;
   z-index: 2
}

.detail-path {
   transition: all .3s ease 0s;
   fill: #d3d3d3
}

.detail-path.active {
   fill: #fdce2a
}

.calculator__results-summ {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 12px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: calc(16px + 4 * ((100vw - 320px)/ 1600));
   font-weight: 700;
   line-height: 140%;
   text-align: left;
   margin-bottom: 20px
}

.calculator__results-summ span {
   line-height: 140%;
   font-size: calc(18px + 14 * ((100vw - 320px)/ 1600))
}

.calculator__results-att {
   border-radius: 10px;
   background: #2f282e;
   padding: 10px;
   color: #fff;
   font-size: 18px;
   font-weight: 700;
   line-height: 140%;
   text-align: center;
   text-wrap: balance;
   margin-bottom: 30px
}

.calculator__results-buttons {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 10px
}

.result-table {
   margin-bottom: 23px
}

.result-table__body-row,
.result-table__head-row {
   display: flex;
   align-items: center;
   justify-content: space-between
}

.result-table__body-cell,
.result-table__head-cell {
   flex: 0 1 15.666%;
   text-align: center;
   padding: 12px;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 500;
   line-height: 140%
}

.result-table__body-cell:nth-child(1),
.result-table__head-cell:nth-child(1) {
   flex: 0 1 6%
}

.result-table__body-row {
   border-radius: 10px;
   background: #f4f4f4
}

.result-table__body-row:not(:last-child) {
   margin-bottom: 4px
}

.result-table__body-cell {
   display: flex;
   flex-direction: column;
   align-items: center;
   gap: 14px
}

.result-table__body-cell:nth-child(2) {
   font-weight: 700
}

.result-table__body-cell button {
   transition: all .3s ease 0s
}

.infocards {
   background: #f1f1f1
}

.infocards__items {
   display: flex;
   gap: 30px
}

.infocards__item {
   flex: 0 1 25%;
   position: relative;
   width: 100%;
   height: auto;
   aspect-ratio: 1/1;
   display: flex;
   align-items: end
}

.infocards__item img {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%
}

.infocards__item:not(:first-child, :nth-child(3)) .infocards__item-descr {
   width: 80%
}

.infocards__item:nth-child(2) .infocards__item-descr {
   margin-left: auto
}

.infocards__item:nth-child(4) .infocards__item-descr {
   margin-right: auto
}

.infocards__item-num {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   color: #2f282e;
   font-family: TacticSansExd;
   font-weight: 400;
   text-transform: uppercase;
   font-size: calc(28px + 36 * ((100vw - 320px)/ 1600))
}

.infocards__item-descr {
   z-index: 2;
   text-wrap: balance;
   padding: calc(15px + 15 * ((100vw - 320px)/ 1600))
}

.team {
   background: #f1f1f1;
   border-radius: 0 0 75px 75px;
   padding-top: 90px;
   padding-bottom: 60px;
   position: relative
}

.team__body {
   display: flex;
   gap: 30px
}

.team__text {
   flex: 0 1 30%;
   display: flex;
   flex-direction: column;
   justify-content: space-between
}

.team__text svg {
   color: #dcdcdc;
   width: 100%;
   height: auto
}

.team__content {
   flex: 0 1 70%;
   width: 70%
}

.team__slider {
   width: 100%;
   height: 600px;
   position: relative
}

.team__slider-wrapper {
   display: flex;
   align-items: center
}

.team__slider-wrapper.transform-disabled {
   transform: none !important
}

.team__slide {
   width: 120px;
   transition: all 1s ease 0s
}

.team__slide-image {
   width: 100%;
   height: 80%;
   position: relative
}

.team__slide-image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   border-radius: 35px
}

.team__slide-name {
   position: absolute;
   bottom: 37px;
   left: 37px;
   color: #fff;
   color: #fff;
   font-weight: 600;
   line-height: 120%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600));
   transition: all 1s ease 0s;
   white-space: nowrap;
   text-shadow: 0 0 4px #000
}

.team__slide-info {
   transition: all .5s ease 0s;
   margin-top: -23px;
   z-index: 3;
   position: relative
}

.team__slide-quality {
   width: -moz-max-content;
   width: max-content;
   border-radius: 35px 35px 35px 0;
   background: #fdce2a;
   padding: 12px 30px;
   text-align: center;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 500;
   margin-bottom: 16px
}

.team__slide-descr {
   padding-inline: 25px
}

.team__slider-prev {
   position: absolute;
   top: 40%;
   left: 0;
   z-index: 3
}

.team__slider-next {
   position: absolute;
   top: 40%;
   right: 0;
   z-index: 3
}

.workshop__body {
   padding: 90px 0 90px
}

.workshop__body .works__title {
   flex-direction: column;
   margin: 0
}

.workshop__body .works__title p {
   display: flex
}

.workshop__body .works__title p+span {
   max-width: 90%;
   text-align: right;
   margin-left: auto
}

.workshop__blocks {
   display: grid;
   grid-template-columns: repeat(4, 1fr);
   grid-template-rows: repeat(4, 1fr);
   gap: 30px
}

.workshop__block {
   position: relative
}

.workshop__block:not(:first-child) {
   border-radius: 50px;
   overflow: hidden
}

.workshop__block:nth-child(1) {
   grid-column: span 2
}

.workshop__block:nth-child(2) {
   grid-column: span 2;
   grid-row: span 3
}

.workshop__block:nth-child(3) {
   grid-column: span 2;
   grid-row: span 3
}

.workshop__benefits {
   position: absolute;
   left: 0;
   bottom: 8px;
   z-index: 2
}

.workshop__benefits-items li {
   border-radius: 0 50px 50px 0;
   background: #fff;
   color: #1d212c;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 400;
   line-height: 140%;
   padding: 10px 30px;
   width: -moz-max-content;
   width: max-content
}

.workshop__benefits-items li:not(:last-child) {
   margin-bottom: 8px
}

.workshop__image {
   width: 100%;
   height: 100%
}

.workshop__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.workshop__card {
   position: absolute;
   top: 20px;
   left: 20px;
   border-radius: 25px;
   -webkit-backdrop-filter: blur(20px);
   backdrop-filter: blur(20px);
   background: rgba(255, 255, 255, .75);
   padding: 24px;
   width: 80%;
   max-width: 343px
}

.workshop__card-name {
   color: #2f282e;
   font-family: TacticSansExd;
   font-size: calc(16px + 4 * ((100vw - 320px)/ 1600));
   font-weight: 400;
   line-height: 140%;
   margin-bottom: 7px
}

.workshop__card-num {
   color: #2f282e;
   font-family: TacticSansExd;
   font-weight: 400;
   line-height: 100%;
   font-size: calc(20px + 12 * ((100vw - 320px)/ 1600));
   margin-bottom: calc(10px + 75 * ((100vw - 320px)/ 1600))
}

.cooperation {
   background: #f1f1f1;
   border-radius: 75px 75px 0 0
}

.cooperation__wrapper {
   border-radius: 75px;
   background: #2f282e
}

.cooperation__body {
   padding: 90px 0
}

.cooperation__body .title {
   flex-direction: column;
   margin-bottom: 0;
   font-size: 36px
}

.cooperation__body .title span:nth-child(3) {
   transform: none
}

.cooperation__cards {
   display: grid;
   grid-template-columns: repeat(4, 1fr);
   grid-template-rows: repeat(3, 1fr);
   gap: 30px
}

.cooperation__card {
   border-radius: 50px;
   background: #fff;
   overflow: hidden;
   padding: 40px
}

.cooperation__card:nth-child(1) {
   grid-column: span 2;
   grid-row: span 3
}

.cooperation__card:nth-child(2) {
   grid-column: span 2
}

.cooperation__card:nth-child(3) {
   grid-column: span 2;
   grid-row: span 2
}

.cooperation__info-image {
   max-width: 50%;
   margin-top: -50px;
   border-radius: 25px;
   overflow: hidden
}

.cooperation__info-image img {
   width: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.cooperation__conditions-title {
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 900;
   line-height: 120%;
   font-size: calc(18px + 14 * ((100vw - 320px)/ 1600));
   margin-bottom: 16px
}

.cooperation__conditions-descr {
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 500;
   line-height: 140%;
   font-size: calc(15px + 5 * ((100vw - 320px)/ 1600))
}

.application__title {
   color: #959194;
   font-family: TacticSansExd;
   font-size: calc(18px + 14 * ((100vw - 320px)/ 1600));
   font-weight: 700;
   line-height: 120%;
   text-transform: uppercase;
   margin-bottom: 30px;
   text-align: center
}

.application__form {
   display: flex;
   flex-direction: column;
   gap: 15px
}

.application__form button {
   width: 100%
}

.application__form-area {
   width: 100%
}

.application__form-area input {
   border: 1px solid #959194;
   border-radius: 100px;
   padding: 20px 30px;
   width: 100%;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 400;
   line-height: 140%;
   letter-spacing: 0;
   text-align: left;
   transition: all .3s ease 0s
}

.application__form-area input::-moz-placeholder {
   color: #6b6469
}

.application__form-area input::placeholder {
   color: #6b6469
}

.application__form-area input:focus {
   border-color: #fdce2a
}

.application__form-area input:user-invalid {
   border-color: red
}

.benefits {
   background: #f1f1f1
}

.benefits__body {
   padding: 90px 0
}

.benefits__cards {
   display: grid;
   grid-template-columns: repeat(4, 1fr);
   gap: 30px
}

.benefits__card {
   width: 100%;
   border-radius: 35px;
   background: #fff;
   overflow: hidden
}

.benefits__card:not(:nth-child(4), :nth-child(7)) {
   padding: 40px
}

.no-webp .benefits__card:nth-child(2) {
   background-image: url(../img/guarantee.png)
}

.benefits__card:nth-child(2) {
   background-size: cover;
   background-repeat: no-repeat;
   background-position: 0 50%
}

.benefits__card-icon {
   width: 50px;
   height: 50px;
   border-radius: 10px;
   display: flex;
   align-items: center;
   justify-content: center;
   margin-bottom: 20px
}

.benefits__card-icon svg {
   width: 30px;
   height: 30px
}

.benefits__card-icon:not(:empty) {
   background: #fdce2a
}

.benefits__card-name {
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 700;
   line-height: 140%;
   margin-bottom: 20px;
   font-size: calc(16px + 4 * ((100vw - 320px)/ 1600))
}

.benefits__card-descr {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 500;
   line-height: 140%
}

.benefits__card-image {
   width: 100%;
   height: 100%
}

.benefits__card-image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.photoreport {
   background: #f1f1f1
}

.photoreport__body {
   border-radius: 50px;
   background: #fff;
   display: flex;
   overflow: hidden
}

.photoreport__image {
   flex: 0 1 33%
}

.photoreport__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   border-radius: 50px
}

.photoreport__info {
   flex: 1;
   display: flex;
   gap: 50px;
   padding: 50px 27px 60px;
   align-items: end
}

.photoreport__text {
   flex: 0 1 60%;
   height: 100%;
   display: flex;
   flex-direction: column
}

.photoreport__title {
   margin-bottom: 22px
}

.photoreport p {
   margin-top: auto;
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 500;
   line-height: 140%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.photoreport .application__form {
   flex: 0 1 40%
}

.blog {
   background: #f1f1f1;
   padding: 90px 0
}

.blog__wrapper {
   border-radius: 75px;
   background: #fff
}

.blog__body {
   padding: 70px 0
}

.blog__head {
   display: flex;
   align-items: end;
   justify-content: space-between;
   margin-bottom: 40px
}

.blog__titles {
   flex: 1
}

.blog__title {
   margin-bottom: 20px
}

.blog__subtitle {
   font-family: TacticSansExd;
   font-size: 32px;
   font-weight: 700;
   line-height: 120%;
   text-transform: uppercase;
   width: 100%;
   text-wrap: balance
}

.blog__description {
   flex: 0 1 40%;
   max-width: 570px;
   margin-left: auto;
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 500;
   line-height: 140%;
   font-size: calc(15px + 5 * ((100vw - 320px)/ 1600))
}

.blog__content {
   position: relative
}

.blog__slider {
   -webkit-user-select: none;
   -moz-user-select: none;
   user-select: none
}

.blog__slide {
   height: auto
}

.blog__slide-img {
   width: 100%;
   border-radius: 15px;
   overflow: hidden
}

.blog__slide-img img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   border-radius: 15px;
   transition: all .3s ease 0s
}

.blog__slide-name {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 16px;
   font-weight: 800;
   line-height: 140%;
   max-width: 100%;
   overflow: hidden;
   text-overflow: ellipsis;
   white-space: nowrap;
   margin-top: 10px;
   transition: color .3s ease 0s
}

.blog__slide-info {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 15px;
   font-weight: 500;
   line-height: 140%;
   display: inline-flex;
   gap: 6px
}

.blog__slide-prev {
   position: absolute;
   top: 45%;
   left: 0;
   z-index: 2;
   transform: translateX(-50%);
   border-color: #2f282e;
   background: #2f282e
}

.blog__slide-prev svg {
   color: #fff
}

.blog__slide-next {
   position: absolute;
   top: 45%;
   right: 0;
   z-index: 2
}

.blog__att {
   margin-top: 60px;
   color: #2f282e;
   font-family: TacticSansExd;
   font-weight: 700;
   line-height: 120%;
   text-align: center;
   text-transform: uppercase;
   font-size: calc(18px + 30 * ((100vw - 320px)/ 1600));
   margin-bottom: 40px
}

.blog__att span {
   padding: 0 5px;
   border-radius: 10px;
   background: #fdce2a
}

.blog__socials {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 10px;
   max-width: 614px;
   margin-inline: auto;
   margin-bottom: 20px
}

.blog__social {
   flex: 0 1 25%;
   transition: transform .3s ease 0s;
   will-change: transform
}

.blog__end {
   text-align: center
}

.reviews {
   background: #f1f1f1
}

.reviews__head {
   display: flex;
   align-items: end;
   gap: 30px
}

.reviews__title {
   flex: 0 1 50%
}

.reviews__yandex {
   flex: 0 1 50%;
   border: 1px solid #e7e7e7;
   border-radius: 10px;
   background: #fff;
   padding: 10px 30px
}

.reviews__yandex-company {
   color: #1f232c;
   font-family: HelveticaNeueCyr;
   font-size: 20px;
   font-weight: 550;
   line-height: 140%;
   letter-spacing: 0;
   text-align: left;
   margin-bottom: 10px
}

.reviews__yandex-rating {
   display: flex;
   align-items: start;
   justify-content: space-between;
   gap: 12px
}

.reviews__yandex-info {
   display: flex;
   align-items: center;
   gap: 10px
}

.reviews__yandex-rating-value {
   color: #1f232c;
   font-family: HelveticaNeueCyr;
   font-size: 48px;
   font-weight: 550;
   line-height: 1;
   white-space: nowrap
}

.reviews__yandex-rating-value svg {
   width: 34px;
   height: 34px;
   color: #fc3f1d
}

.reviews__yandex-rating-details {
   color: #989898
}

.reviews__yandex-rating-details a {
   color: #989898;
   font-family: HelveticaNeueCyr;
   font-size: 15px;
   font-weight: 400;
   line-height: 120%
}

.reviews__yandex-rating-stars {
   line-height: 1
}

.reviews__yandex-rating-stars svg {
   width: 15px;
   height: 15px
}

.reviews__yandex-link {
   color: #4779e9;
   font-family: HelveticaNeueCyr;
   font-size: 15px;
   font-weight: 400;
   line-height: 120%
}

.reviews__content {
   padding: 60px 0 40px
}

.reviews__slide-buttons {
   display: flex;
   align-items: center;
   justify-content: end;
   gap: 10px;
   margin-top: 30px
}

.review {
   border-radius: 10px;
   background: #fff;
   padding: 25px;
   height: auto
}

.review__author {
   display: flex;
   align-items: center;
   gap: 14px;
   margin-bottom: 26px
}

.review__author-image {
   width: 40px;
   height: 40px;
   border-radius: 50%;
   overflow: hidden;
   display: flex;
   align-items: center;
   justify-content: center;
   background: #b37db3;
   color: #fff;
   font-size: 20px;
   font-weight: 500
}

.review__author-image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.review__author-name {
   color: #2f282e;
   font-family: HelveticaNeueCyr;
   font-size: 18px;
   font-weight: 550
}

.review__author-date {
   color: #989898;
   font-family: HelveticaNeueCyr;
   font-size: 15px;
   font-weight: 400
}

.review__rating {
   margin-bottom: 10px
}

.review__rating svg {
   width: 15px;
   height: 15px
}

.review__body {
   font-family: HelveticaNeueCyr;
   font-size: 16px;
   font-weight: 400;
   line-height: 120%
}

.review__text {
   display: inline-block;
   line-height: 20px;
   font-size: 16px;
   max-height: 160px;
   overflow: hidden;
   transition: max-height .3s ease
}

.review__text-toggle {
   color: #959194;
   display: none;
   transition: all .3s ease 0s;
   cursor: pointer
}

.recomended {
   background: #f1f1f1
}

.recomended__body {
   display: flex;
   padding-bottom: 90px
}

.recomended__text {
   flex: 0 1 50%
}

.recomended__text svg {
   display: inline-block;
   color: #dcdcdc;
   width: 102%;
   height: auto;
   -o-object-fit: contain;
   object-fit: contain
}

.recomended__title {
   margin-bottom: 42px;
   position: relative;
   z-index: 4
}

.recomended__videos {
   flex: 0 1 50%;
   display: flex;
   gap: 30px
}

.recomended__video-card {
   width: 100%;
   flex: 0 1 50%
}

.recomended__video {
   flex: 0 1 50%;
   width: 100%;
   aspect-ratio: 4/2.6;
   position: relative;
   border-radius: 35px;
   overflow: hidden;
   cursor: pointer
}

.recomended__video video {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover;
   z-index: 1
}

.recomended__video-cover {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   z-index: 2
}

.recomended__video-cover img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.recomended__video-play {
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   z-index: 3;
   width: 90px;
   height: 90px;
   border-radius: 50%;
   background: rgba(0, 0, 0, .75);
   display: flex;
   align-items: center;
   justify-content: center;
   cursor: pointer;
   transition: background-color .2s ease 0s
}

.recomended__video-play svg {
   width: 28px;
   height: 28px;
   -o-object-fit: contain;
   object-fit: contain;
   color: #fff;
   transform: translateX(2px);
   transition: all .2s ease 0s
}

.recomended__video-info {
   padding: 15px 30px
}

.recomended__video-name {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 16px;
   font-weight: 800;
   line-height: 140%
}

.recomended__video-date {
   color: #959194;
   font-family: Gilroy;
   font-size: 15px;
   font-weight: 500;
   line-height: 140%
}

.faq {
   background: #f1f1f1
}

.faq__wrapper {
   border-radius: 75px;
   background: #fff
}

.faq__body {
   padding: 70px 0
}

.faq__body .works__title {
   margin-bottom: 70px
}

.faq__items {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 20px 30px
}

.faq__item.active .faq__question-icon {
   transform: rotate(-45deg)
}

.faq__item.active .faq__question-icon svg {
   color: #fdce2a
}

.faq__item.active .faq__answer {
   padding-top: 30px
}

.faq__question {
   border: 1px solid #2f282e;
   border-radius: 12px;
   display: flex;
   align-items: center;
   justify-content: space-between;
   gap: 20px;
   padding: 35px;
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 700;
   line-height: 120%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600));
   cursor: pointer;
   transition: all .3s ease 0s
}

.faq__question div {
   display: flex
}

.faq__question-num {
   color: #fdce2a;
   font-family: Gilroy;
   font-weight: 900;
   margin-right: 20px;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.faq__question-icon {
   flex: 0 0 36px;
   width: 36px;
   height: 36px;
   transition: all .3s linear 0s
}

.faq__question-icon svg {
   width: 100%;
   height: 100%
}

.faq__answer {
   max-height: 0;
   overflow: hidden;
   transition: all .3s linear 0s;
   width: calc(100% - 85px);
   margin-left: auto
}

.faq__item-add .button {
   width: 100%;
   height: 100%;
   border-radius: 12px;
   padding: 35px;
   color: #2f282e;
   font-family: Gilroy;
   font-weight: 700;
   line-height: 120%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600));
   justify-content: space-between
}

.swiper {
   -webkit-user-select: none;
   -moz-user-select: none;
   user-select: none
}

.bonuses {
   background: #f1f1f1
}

.bonuses__body {
   padding: 90px 0
}

.bonuses__body .title {
   width: -moz-max-content;
   width: max-content;
   margin-bottom: 40px;
   flex-wrap: wrap
}

.bonuses__body .title span {
   transform: none
}

.bonuses__body .title .title-line {
   width: 178px
}

.bonuses__content {
   position: relative
}

.bonuses__slide {
   width: 100%;
   height: auto;
   border-radius: 25px;
   background: #fff;
   overflow: hidden
}

.bonuses__slide-image {
   width: 100%;
   height: auto;
   max-height: 300px;
   position: relative
}

.bonuses__slide-image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.bonuses__slide-label {
   position: absolute;
   top: 20px;
   left: 20px;
   width: -moz-max-content;
   width: max-content;
   white-space: nowrap;
   padding: 10px;
   min-width: 180px;
   background: #fdce2a;
   z-index: 2;
   border-radius: 50px;
   text-align: center;
   color: #2f282e;
   font-size: 16px;
   font-weight: 800
}

.bonuses__slide-info {
   padding: 20px 30px
}

.bonuses__slide-name {
   color: #2f282e;
   font-weight: 700;
   line-height: 140%;
   font-size: calc(18px + 2 * ((100vw - 320px)/ 1600));
   margin-bottom: 10px
}

.bonuses__slide-descr {
   color: #2f282e;
   font-size: 18px;
   font-weight: 500;
   line-height: 140%
}

.bonuses__slide-prev {
   position: absolute;
   top: 50%;
   left: 0;
   transform: translate(-25%, -50%);
   z-index: 2;
   border-color: #2f282e;
   background: #2f282e
}

.bonuses__slide-prev svg {
   color: #fff
}

.bonuses__slide-next {
   position: absolute;
   top: 50%;
   right: 0;
   transform: translate(25%, -50%);
   z-index: 2
}

.price {
   background: #f1f1f1;
   padding-bottom: 80px
}

.price__body {
   display: flex
}

.price__body .title {
   padding-right: 20px;
   flex-direction: column;
   margin-bottom: 40px
}

.price__body .title .title-grey {
   flex: 0 0 50%;
   font-size: 24px;
   line-height: 120%
}

.price__body .title span:last-child {
   flex: 0 0 50%;
   margin-left: auto;
   transform: none;
   text-align: left
}

.price__info {
   flex: 0 0 50%;
   border-radius: 75px;
   background: #2f282e;
   color: #fff;
   padding: 57px 0 57px 75px;
   z-index: 2
}

.price__tab {
   display: flex;
   align-items: center;
   justify-content: space-between;
   cursor: pointer
}

.price__tab:not(:last-child) {
   margin-bottom: 15px
}

.price__tab.active .price__tab-icon {
   background: #fdce2a
}

.price__tab.active .price__tab-icon svg {
   color: #000
}

.price__tab.active .price__tab-arrow svg {
   transform: translateX(5px)
}

.price__tab.active .price__tab-name {
   color: #fdce2a
}

.price__tab.active .price__tab-arrow {
   opacity: 1
}

.price__tab-name {
   display: flex;
   align-items: center;
   gap: 40px;
   transition: all .2s ease 0s;
   color: #c9c5c8;
   font-weight: 500;
   line-height: 140%;
   font-size: calc(16px + 8 * ((100vw - 320px)/ 1600))
}

.price__tab-icon {
   flex: 0 0 70px;
   width: 70px;
   height: 70px;
   border-radius: 20px;
   background: rgba(255, 255, 255, .1);
   display: flex;
   align-items: center;
   justify-content: center
}

.price__tab-icon svg {
   width: 54px;
   height: 54px;
   color: #959194;
   transition: all .2s ease 0s
}

.price__tab-arrow {
   width: 112px;
   height: 28px;
   background: #fdce2a;
   border-radius: 33px 0 0 33px;
   display: flex;
   align-items: center;
   justify-content: center;
   transition: all .2s ease 0s;
   opacity: 0
}

.price__tab-arrow svg {
   width: 16px;
   height: 16px;
   color: #000;
   transform: translateX(-5px);
   transition: all .3s ease 0s
}

.price__values {
   flex: 0 0 50%;
   display: flex;
   flex-direction: column
}

.price__values-logo {
   width: 80%;
   margin-inline: auto;
   margin-top: auto;
   transform: translateY(50%)
}

.price__values-logo svg {
   width: 100%;
   height: auto;
   color: #dcdcdc
}

.price__values-block {
   border-radius: 75px;
   background: #fff;
   width: calc(100% + 75px);
   margin-left: -75px;
   z-index: 1;
   padding: 57px 75px 57px 175px;
   margin-top: auto;
   margin-bottom: -80px;
   max-height: 763px
}

.price__values-list {
   margin-bottom: 80px
}

.price__value {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 500;
   line-height: 100%;
   text-align: left;
   display: flex
}

.price__value:not(:last-child) {
   margin-bottom: 26px
}

.price__value .dots {
   flex: 1;
   width: 100%;
   border-bottom: 2px dotted #000
}

.price__att {
   padding: 10px;
   border: 2px dashed #959194;
   border-radius: 25px;
   color: #2f282e;
   font-size: 20px;
   font-weight: 500;
   line-height: 140%;
   text-align: center;
   margin-bottom: 20px
}

.price__buttons {
   display: flex;
   align-items: center;
   gap: 10px
}

.price__buttons .button {
   text-align: center;
   flex: 0 1 50%
}

.callback {
   background: #f1f1f1;
   padding: 90px 0
}

.callback__body {
   display: flex;
   gap: 30px
}

.no-webp .callback__info {
   background-image: url(../img/form.png)
}

.callback__info {
   flex: 0 1 50%;
   border-radius: 50px;
   background-position: 0 0;
   background-size: cover;
   background-repeat: no-repeat;
   padding: 40px
}

.callback__title {
   color: #fff;
   display: block;
   width: auto;
   margin-bottom: 50px
}

.callback__title span {
   color: #fdce2a
}

.callback__subtitle {
   color: #fff;
   font-weight: 500;
   line-height: 140%;
   text-align: left;
   font-size: calc(15px + 5 * ((100vw - 320px)/ 1600))
}

.callback__form {
   flex: 0 1 50%;
   border-radius: 50px;
   background: #fff;
   padding: 50px;
   text-align: center
}

.callback__form-title {
   color: #959194;
   font-family: TacticSansExd;
   font-size: calc(18px + 14 * ((100vw - 320px)/ 1600));
   font-weight: 400;
   line-height: 120%;
   text-align: center;
   text-transform: uppercase;
   margin-bottom: 40px
}

.footer {
   background: #f1f1f1;
   overflow: hidden;
   padding-bottom: 30px
}

.footer__wrapper {
   border-radius: 100px;
   background: #2f282e
}

.footer__main {
   padding: 86px 0 100px;
   border-bottom: 1px solid rgba(255, 255, 255, .2)
}

.footer__main-body {
   display: flex;
   justify-content: space-between;
   gap: 100px
}

.footer__main-contact:not(:last-child) {
   margin-bottom: 60px
}

.footer__main-contact-label {
   color: rgba(255, 255, 255, .5);
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 400;
   line-height: 100%;
   text-align: left;
   margin-bottom: 18px
}

.footer__main-contact-link {
   display: block;
   color: #fff;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 400;
   line-height: 100%
}

.footer__tel {
   color: #fff;
   font-family: Gilroy;
   font-weight: 500;
   line-height: 100%;
   font-size: calc(24px + 62 * ((100vw - 320px)/ 1600));
   margin-bottom: 40px;
   transition: all .3s ease 0s;
   white-space: nowrap
}

.footer__mail {
   color: #fff;
   font-family: Gilroy;
   font-size: calc(20px + 16 * ((100vw - 320px)/ 1600));
   font-weight: 500;
   line-height: 100%;
   text-decoration-line: underline;
   transition: all .3s ease 0s
}

.footer__main-info {
   flex: 0 1 50%
}

.footer__main-subtitle {
   color: #959194;
   font-family: TacticSansExd;
   font-weight: 400;
   line-height: 120%;
   text-transform: uppercase;
   font-size: calc(18px + 14 * ((100vw - 320px)/ 1600));
   transform: translateX(calc(100vw - (100vw - 70px)))
}

.footer__main-socials {
   display: flex;
   color: #fff;
   font-family: Gilroy;
   font-size: 20px;
   font-weight: 500;
   line-height: 140%;
   text-align: left;
   margin-bottom: 50px;
   transform: translateX(calc(100vw - (100vw - 70px)));
   padding-right: 20px
}

.footer__main-socials p {
   margin-right: 100px
}

.footer__main-social {
   width: 100px;
   height: 40px;
   border-radius: 100px;
   display: inline-flex;
   align-items: center;
   justify-content: center;
   transition: all .3s ease 0s;
   will-change: transform
}

.footer__main-social svg {
   width: 16px;
   height: 16px;
   will-change: transform;
   color: #fff
}

.footer__main-social:nth-child(2) {
   background: #00ca54;
   margin-right: 6px
}

.footer__main-social:last-child {
   background: #03a8fb
}

.footer__map {
   border-radius: 100px 0 0 100px;
   background: #d9d9d9;
   transform: translateX(calc(100vw - (100vw - 70px)));
   overflow: hidden;
   min-height: 330px
}

.footer__map iframe {
   width: 100%;
   height: 330px
}

.footer__bottom-body {
   padding: 62px 0 68px;
   display: flex;
   align-items: center;
   justify-content: space-between
}

.footer__bottom-copyright,
.footer__bottom-policy button {
   color: #9c9eaf;
   font-family: Gilroy;
   font-size: 16px;
   font-weight: 400;
   line-height: 100%
}

.policy-popup {
   position: fixed;
   top: 0;
   left: 0;
   inset: 0;
   max-height: 100vh;
   overflow-y: auto;
   -webkit-backdrop-filter: blur(15px);
   backdrop-filter: blur(15px);
   background: #2f282e;
   grid-template-columns: 1fr;
   z-index: 55;
   display: none;
   transition-behavior: allow-discrete;
   opacity: 0;
   transition-duration: .5s
}

.policy-popup.opened {
   display: grid;
   opacity: 1
}

.policy-popup__title {
   padding: 60px 20px 50px;
   border-bottom: 1px solid #ddd;
   color: rgba(0, 0, 0, .9);
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 700;
   text-align: center;
   text-transform: uppercase
}

.policy-popup__subtitle {
   font-size: 20px;
   font-weight: 700
}

.policy-popup__text {
   padding: 30px 80px;
   color: rgba(0, 0, 0, .9);
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 400
}

.policy-popup__text div:not(:first-child) {
   margin: 50px 0
}

.policy-popup__text p:not(:last-child) {
   margin-bottom: 20px
}

.policy-popup__close {
   position: absolute;
   top: -40px;
   right: -40px;
   cursor: pointer
}

.policy-popup__close img {
   transition: all .3s ease 0s
}

.form-popup {
   position: fixed;
   top: 0;
   left: 0;
   inset: 0;
   z-index: 66;
   background: rgba(47, 40, 46, .9);
   grid-template-columns: 1fr;
   align-items: center;
   transition: all 0.3s ease 0s;
   justify-content: center;
   display: none;
   opacity: 0;
   transition-behavior: allow-discrete;

   @starting-style {
      opacity: 0;
   }
}


.form-popup.opened {
   display: grid;
   opacity: 1;

   @starting-style {
      opacity: 0;
   }
}

.form-popup__body {
   width: min(100% - 40px, 1270px);
   margin-inline: auto;
   background: #fff;
   border-radius: 50px;
   display: flex;
   overflow: hidden;
   position: relative;
}

.form-popup__body .title {
   font-size: 24px;
   flex-direction: column;
   margin-bottom: 32px
}

.form-popup__body .title span:last-child {
   text-align: right
}

.form-popup__body.loading .loading-icon {
   display: block
}

.form-popup__body.loaded .loading-icon {
   display: none
}

.form-popup__body.loaded .form-popup__thanks {
   opacity: 1;
   pointer-events: all
}

.form-popup__image {
   flex: 0 1 50%;
   width: 100%;
   height: auto
}

.form-popup__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.form-popup__application {
   padding: 58px 50px;
   position: relative;
   flex: 0 1 50%;
   background: #fff;
}

.form-popup__thanks {
   position: absolute;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   z-index: 2;
   display: flex;
   background: #fff;
   opacity: 0;
   pointer-events: none;
   transition: all .3s ease 0s
}

.form-popup__image {
   flex: 0 1 50%;
   width: 100%
}

.form-popup__image img {
   width: 100%;
   height: 100%;
   -o-object-fit: cover;
   object-fit: cover
}

.form-popup__message {
   flex: 0 1 50%;
   position: relative
}

.form-popup__message-title {
   padding: 58px 50px;
   text-align: center;
   margin-bottom: 40px;
   border-bottom: 1px solid #d0d0d0
}

.form-popup__message-subtitle {
   color: #2f282e;
   font-family: TacticSansExd;
   font-weight: 700;
   line-height: 120%;
   text-align: center;
   text-transform: uppercase;
   font-size: calc(18px + 18 * ((100vw - 320px)/ 1600));
   margin-bottom: 40px
}

.form-popup__tel {
   margin-bottom: 36px
}

.form-popup__tel p {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   line-height: 120%;
   text-align: center
}

.form-popup__tel a {
   display: block;
   text-align: center;
   color: #2f282e;
   font-family: Gilroy;
   font-size: 48px;
   font-weight: 600;
   line-height: 120%;
   text-align: center;
   font-size: calc(20px + 28 * ((100vw - 320px)/ 1600));
   transition: all .3s ease 0s
}

.form-popup__socials p {
   color: #2f282e;
   font-family: Gilroy;
   font-size: 18px;
   font-weight: 600;
   line-height: 140%;
   text-align: center
}

.form-popup__socials div {
   display: flex;
   align-items: center;
   justify-content: center;
   gap: 10px;
   margin-top: 10px
}

.form-popup__socials a {
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 100px;
   background: #00ca54;
   width: 100px;
   height: 40px;
   transition: all .3s ease 0s;
   will-change: transform
}

.form-popup__socials a svg {
   width: 16px;
   height: 16px;
   color: #fff
}

.form-popup__socials a:nth-child(1) {
   background: #00ca54
}

.form-popup__socials a:nth-child(2) {
   background: #03a8fb
}

.form-popup__bg {
   position: absolute;
   bottom: 0;
   left: 0;
   width: 100%;
   height: auto
}

.form-popup__bg svg {
   width: 100%;
   max-height: 81px;
   height: auto;
   color: #e7e7e7
}

.loading-icon {
   width: 40px;
   height: 40px;
   border-radius: 50%;
   border-top: 4px solid #fdce2a;
   border-bottom: 4px solid #fdce2a;
   border-right: 4px solid #fdce2a;
   border-left: 4px solid transparent;
   animation: loading 2s ease infinite;
   position: absolute;
   top: calc(50% - 20px);
   left: calc(50% - 20px);
   z-index: 5;
   display: none
}

@keyframes loading {
   to {
      transform: rotate(360deg)
   }
}

@media (max-width:1800px) {
   .title {
      font-size: 40px
   }

   .hero__logo-bg {
      width: 40%;
      max-height: 9vh;
      transform: translateX(-59%)
   }

   .hero__info {
      padding: 20px 20px 20px 40px
   }

   .hero__title {
      margin-top: 30px;
      font-size: 2vw
   }

   .hero__subtitle {
      max-width: unset;
      font-size: 16px;
      margin-top: 10px;
      margin-bottom: 20px;
      text-wrap: balance
   }

   .hero__att {
      font-size: 16px
   }

   .works__text {
      padding: 32px
   }

   .works__text-title {
      font-size: 18px
   }

   .calculation__text {
      font-size: 20px
   }

   .calculation__link {
      font-size: 20px
   }

   .calculation__icon svg {
      width: 30px;
      height: 30px
   }

   .calculator__body {
      padding: 50px 0
   }

   .cooperation__info-image {
      margin-top: 16px
   }

   .cooperation__conditions-descr {
      font-size: 16px
   }

   .benefits__cards {
      gap: 20px
   }

   .benefits__card-descr {
      font-size: 16px
   }
}

@media (max-width:1620px) {
   .works__slide {
      padding: 20px
   }
}

@media (max-width:1600px) {

   .slider-next,
   .slider-prev {
      width: 40px;
      height: 40px
   }

   .slider-next svg,
   .slider-prev svg {
      width: 16px;
      height: 16px
   }

   .menu__list {
      gap: 14px;
      margin-left: 26px
   }

   .menu__link {
      font-size: 16px
   }

   .menu__tel a {
      font-size: 18px
   }

   .menu__socials {
      gap: 6px
   }

   .hero__body {
      padding: 20px
   }

   .hero__benefit {
      font-size: 16px;
      padding: 6px 20px
   }

   .works__values {
      padding: 12px 24px
   }

   .works__value {
      font-size: 16px
   }

   .works__value:nth-child(2) span {
      font-size: 20px;
      font-weight: 700
   }

   .works__text {
      padding: 24px
   }

   .calculation__items {
      gap: 15px
   }

   .price__info {
      padding: 40px 0 40px 40px
   }

   .price__tab-name {
      gap: 20px
   }

   .price__values-block {
      padding: 40px 40px 40px 100px
   }

   .footer__main-socials p {
      margin-right: 20px
   }
}

@media (max-width:1500px) {
   .calculation__text {
      font-size: 18px
   }
}

@media (max-width:1480px) {
   .benefits__card:not(:nth-child(4), :nth-child(7)) {
      padding: 20px
   }

   .benefits__card-icon {
      margin-bottom: 10px
   }

   .benefits__card-name {
      margin-bottom: 6px
   }

   .benefits__card-descr {
      font-size: 14px
   }

   .photoreport__info {
      gap: 20px
   }

   .recomended__video-play {
      width: 60px;
      height: 60px
   }

   .recomended__video-play svg {
      width: 20px;
      height: 20px
   }
}

@media (max-width:1460px) {
   .works__values-wrapper {
      flex-direction: column;
      align-items: start
   }

   .works__value:nth-child(2) span {
      font-size: 16px;
      font-weight: 400
   }

   .works__slide-buttons {
      position: static;
      justify-content: center
   }

   .cooperation__body .title {
      font-size: 32px
   }

   .cooperation__card {
      padding: 30px
   }
}

@media (max-width:1420px) {
   .button {
      height: auto
   }

   .menu__body {
      gap: 16px
   }

   .menu__list {
      margin-left: 16px
   }
}

@media (max-width:1400px) {
   .title {
      font-size: 32px
   }

   .get__cards {
      gap: 16px
   }
}

@media (max-width:1380px) {
   .steps__item-button {
      font-size: 14px
   }
}

@media (max-width:1370px) {
   .infocards__item-num {
      font-size: 40px
   }

   .infocards__item-descr {
      font-size: 14px
   }
}

@media (max-width:1360px) {
   .calculation__items {
      display: grid;
      grid-template-columns: 1fr 1fr
   }

   .calculation__item:nth-child(2),
   .calculation__item:nth-child(3) {
      height: 96px
   }

   .agit .calculation__items span:empty {
      display: none
   }

   .agit .calculation__link {
      font-size: 16px
   }

   .agit .calculation__icon {
      margin-right: 0
   }
}

@media (max-width:1300px) {
   .reviews__yandex-rating {
      flex-direction: column
   }

   .price__info {
      border-radius: 50px
   }

   .price__values-logo {
      transform: none
   }

   .price__values-block {
      width: 100%;
      margin-left: 0;
      padding: 40px;
      margin-bottom: 0;
      border-radius: 0 0 50px 50px;
      margin-top: -40px;
      padding-top: 80px
   }

   .callback {
      padding: 0 0 45px 0
   }
}

@media (max-width:1200px) {
   .container {
      width: calc(100% - 80px)
   }

   .menu {
      width: 40px;
      height: 40px;
      display: flex;
      align-items: center;
      margin-left: auto
   }

   .menu__icon {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-left: auto;
      width: 40px;
      height: 40px
   }

   .menu__icon svg {
      width: 26px;
      height: 26px;
      color: #2f282e
   }

   .menu__body {
      position: fixed;
      z-index: 99;
      top: 0;
      right: 0;
      transform: translateX(100%);
      transition: all .3s ease 0s;
      background: #fff;
      width: min(100% - 40px, 500px);
      height: 100dvh;
      border-radius: 30px 0 0 30px;
      flex-direction: column;
      padding: 40px 24px
   }

   .menu__body.active {
      transform: translateX(0);
      box-shadow: -4px 0 20px rgba(0, 0, 0, .2)
   }

   .menu__body-logo {
      display: block;
      max-width: 200px;
      width: 100%
   }

   .menu__body-logo svg {
      width: 100%;
      -o-object-fit: contain;
      object-fit: contain
   }

   .menu__body-close {
      display: block;
      position: absolute;
      top: 20px;
      right: 20px;
      width: 50px;
      height: 50px;
      background: #f1f1f1;
      border-radius: 16px;
      display: flex;
      align-items: center;
      justify-content: center
   }

   .menu__body-close svg {
      width: 30px;
      height: 30px;
      z-index: 2;
      rotate: 45deg
   }

   .menu__list {
      flex-direction: column;
      justify-content: start;
      gap: 20px
   }

   .menu__link {
      font-size: 22px
   }

   .menu__tel a {
      font-size: 24px
   }

   .hero__logo-bg {
      display: none
   }

   .works__slide {
      gap: 10px
   }

   .get__card {
      padding: 24px;
      border-radius: 24px
   }

   .agit__body {
      flex-direction: column;
      align-items: stretch
   }

   .agit .calculation__icon {
      margin-right: 8px
   }

   .calculator__subtitle {
      width: 100%;
      text-align: center
   }

   .cooperation__cards {
      gap: 20px
   }

   .cooperation__conditions-title {
      font-size: 20px
   }

   .cooperation__conditions-descr {
      font-size: 14px
   }

   .photoreport__info {
      flex-direction: column;
      align-items: stretch
   }

   .bonuses__body .title {
      display: block;
      width: 100%
   }

   .bonuses__slide-info {
      padding: 20px
   }

   .bonuses__slide-prev {
      transform: translate(-25%, -50%)
   }

   .bonuses__slide-next {
      transform: translate(25%, -50%)
   }

   .price__tab-arrow {
      width: 50px
   }

   .price__att {
      font-size: 18px
   }

   .footer__main-subtitle {
      margin-bottom: 16px
   }

   .footer__main-socials {
      display: block
   }

   .footer__main-socials p {
      margin-bottom: 10px
   }
}

@media (max-width:1100px) {

   .calculation__item:nth-child(2),
   .calculation__item:nth-child(3) {
      height: 70px
   }

   .infocards__items {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px
   }

   .infocards__item-num {
      font-size: 62px
   }

   .infocards__item-descr {
      font-size: 24px
   }
}

@media (max-width:1000px) {
   .menu {
      position: absolute;
      top: 60px;
      right: 30px
   }

   .hero__body {
      flex-direction: column;
      gap: 0;
      height: auto
   }

   .hero__image {
      height: 400px;
      flex: 0 1 400px
   }

   .hero__image img {
      -o-object-position: center 30%;
      object-position: center 30%
   }

   .hero__image.element-animation {
      transition: all 2s ease .5s;
      transform: translateY(-50%)
   }

   .hero__image.element-animation.element-show {
      transform: translateY(0)
   }

   .hero__info {
      position: static;
      margin-top: -100px;
      z-index: 2
   }

   .hero__title {
      font-size: 28px;
      text-wrap: balance;
      margin-bottom: 20px
   }

   .works__slide {
      flex-direction: column-reverse;
      background: #f1f1f1
   }

   .team__body {
      flex-direction: column
   }

   .team__text {
      z-index: 2
   }

   .team__text svg {
      position: absolute;
      top: 0;
      left: 0;
      z-index: -1
   }

   .team__content {
      width: 100%;
      flex: 1;
      position: relative;
      z-index: 5
   }

   .workshop__body .works__title {
      margin-bottom: 22px
   }

   .workshop__body .works__title p {
      display: inline
   }

   .workshop__blocks {
      gap: 10px;
      grid-template-columns: repeat(2, 1fr);
      grid-template-rows: auto
   }

   .workshop__block:not(:first-child) {
      border-radius: 30px
   }

   .cooperation__body .title {
      display: block;
      margin-bottom: 22px;
      font-size: 26px
   }

   .cooperation__body .title br {
      display: none
   }

   .cooperation__body .title span {
      display: inline
   }

   .cooperation__body {
      padding: 40px 0
   }

   .cooperation__cards {
      grid-template-columns: 1fr;
      grid-template-rows: auto
   }

   .cooperation__card {
      border-radius: 30px
   }

   .benefits__cards {
      grid-template-columns: repeat(3, 1fr);
      gap: 10px
   }

   .recomended__body {
      flex-direction: column;
      padding-bottom: 45px
   }

   .recomended__text {
      position: relative
   }

   .recomended__text svg {
      position: absolute;
      bottom: 0;
      right: 0;
      z-index: 0;
      max-height: 50px;
      width: auto
   }

   .faq__items {
      grid-template-columns: 1fr
   }

   .price__body .title {
      display: block;
      width: 100%
   }

   .price__body .title br {
      display: none
   }

   .price__body {
      flex-direction: column
   }

   .price__tab-name {
      font-size: 18px
   }

   .price__tab-icon {
      flex: 0 0 50px;
      width: 50px;
      height: 50px;
      border-radius: 8px
   }

   .price__tab-icon svg {
      width: 40px;
      height: 40px
   }

   .price__tab-arrow {
      width: 100px
   }

   .price__tab-arrow svg {
      rotate: 90deg
   }

   .price__values-logo {
      display: none
   }

   .footer__wrapper {
      border-radius: 60px
   }

   .footer__main {
      padding: 50px 0
   }

   .footer__main-body {
      flex-direction: column;
      gap: 40px
   }

   .footer__mail {
      font-size: 20px
   }

   .footer__main-subtitle {
      transform: none
   }

   .footer__main-socials {
      transform: none;
      padding-right: 0
   }

   .footer__main-socials p {
      margin-right: 20px
   }

   .footer__map {
      transform: none;
      border-radius: 50px
   }

   .footer__bottom-body {
      display: grid;
      grid-template-columns: 1fr 1fr
   }

   .footer__bottom-logo {
      grid-column: span 2;
      margin-bottom: 10px
   }

   .form-popup__image {
      display: none
   }

   .form-popup__application {
      padding: 40px 30px;
      flex: 1;
      width: 100%
   }

   .form-popup__message {
      flex: 1;
      width: 100%
   }

   .form-popup__bg {
      display: none
   }
}

@media (max-width:980px) {
   .title {
      font-size: 26px;
      line-height: 140%
   }

   .title-line {
      display: none
   }

   .works__title {
      display: block;
      margin-bottom: 30px
   }

   .works__title span {
      display: inline !important;
      transform: none
   }

   .works__title br {
      display: none
   }

   .works__title b {
      font-size: 1em !important
   }

   .works__values-wrapper {
      flex-direction: row;
      justify-self: start
   }

   .works__value {
      flex: 1 1 auto
   }

   .calculation__item:nth-child(2),
   .calculation__item:nth-child(3) {
      height: auto
   }

   .calculation__link {
      font-size: 16px
   }

   .calculation__link svg {
      width: 16px;
      height: 16px
   }

   .calculation__icon svg {
      width: 22px;
      height: 22px;
      margin-right: 10px
   }

   .get__card {
      padding: 16px
   }

   .get__card-descr {
      font-size: 16px !important
   }

   .steps {
      padding-top: 100px
   }

   .steps__wrapper {
      border-radius: 50px
   }

   .steps__item-num {
      flex: 0
   }

   .steps__item-image {
      position: static;
      opacity: 1;
      transform: scale(1)
   }

   .steps__item-buttons {
      flex-direction: column;
      align-items: start
   }

   .agit__subtitle {
      margin-bottom: 20px
   }

   .agit .calculation__icon {
      margin-right: 0
   }

   .about__body {
      gap: 16px
   }

   .about__att {
      flex: 1
   }

   .about__descr {
      max-width: 96%;
      margin-top: 20px;
      font-size: 16px
   }

   .about__att-image {
      display: none
   }

   .about__image {
      flex: 0 1 50%
   }

   .calculator__wrapper {
      border-radius: 50px
   }

   .calculator__types {
      justify-content: center
   }

   .calculator__details-item {
      padding: 3px 18px 3px 36px
   }

   .calculator__details-item::before {
      top: 4px;
      left: 9px;
      width: 20px;
      height: 20px;
      background-size: 9px 9px
   }

   .calculator__details-item {
      font-size: 14px
   }

   .calculator__results-att {
      font-size: 14px;
      font-weight: 400
   }

   .result-table__body-cell,
   .result-table__head-cell {
      font-size: 14px;
      padding: 10px 6px
   }

   .result-table__body-cell {
      gap: 4px
   }

   .team {
      padding-bottom: 40px;
      border-radius: 0 0 50px 50px
   }

   .cooperation__wrapper {
      border-radius: 50px
   }

   .photoreport__body {
      flex-direction: column
   }

   .photoreport__image {
      max-width: 250px;
      margin-inline: auto;
      margin-top: 40px
   }

   .photoreport__image img {
      border-radius: 30px
   }

   .blog__wrapper {
      border-radius: 50px
   }

   .blog__body {
      padding: 50px 0
   }

   .blog__head {
      flex-direction: column;
      gap: 20px;
      margin-bottom: 22px
   }

   .blog__subtitle {
      font-size: 22px
   }

   .reviews__yandex-company {
      font-size: 16px;
      margin-bottom: 4px
   }

   .reviews__yandex-rating-value {
      font-size: 34px
   }

   .reviews__yandex-rating-value svg {
      width: 24px;
      height: 24px
   }

   .reviews__content {
      padding: 30px 0
   }

   .recomended__title {
      margin-bottom: 22px
   }

   .faq__wrapper {
      border-radius: 50px
   }

   .faq__body {
      padding: 50px 0
   }

   .faq__body .works__title {
      margin-bottom: 50px
   }

   .faq__question {
      padding: 20px 35px
   }

   .faq__answer {
      width: calc(100% - 45px)
   }

   .faq__item-add .button {
      padding: 20px 35px
   }

   .callback__body {
      flex-direction: column;
      gap: 20px
   }

   .policy-popup__body {
      margin: 60px auto;
      width: 90%
   }

   .policy-popup__title {
      padding: 40px 20px
   }

   .policy-popup__text {
      padding: 30px
   }

   .policy-popup__close {
      right: -20px
   }
}

@media (max-width:800px) {
   .agit .calculation__item {
      height: 60px
   }
}

@media (max-width:767px) {
   .title {
      font-size: 20px
   }

   .container {
      width: calc(100% - 40px)
   }

   .menu {
      top: 22px;
      right: 22px
   }

   .hero {
      border-radius: 0 0 25px 25px
   }

   .hero__body {
      padding: 10px
   }

   .hero__image {
      border-radius: 24px
   }

   .hero__logo {
      max-width: 140px;
      padding: 14px;
      display: flex;
      align-items: center;
      top: 13px;
      height: 40px
   }

   .hero__info {
      padding: 32px 22px 32px;
      border-radius: 24px
   }

   .hero__title {
      margin: 0;
      font-size: 20px
   }

   .hero__subtitle {
      font-size: 14px;
      text-align: right
   }

   .hero__benefit {
      width: 100%;
      font-size: 14px;
      line-height: 120%
   }

   .works__body {
      padding: 45px 0
   }

   .works__title {
      margin-bottom: 24px
   }

   .works__content {
      border-radius: 24px
   }

   .works__slide {
      padding: 16px
   }

   .works__values {
      align-items: end;
      padding: 10px 18px 12px;
      border-radius: 18px
   }

   .works__values-wrapper {
      flex-direction: column;
      gap: 8px
   }

   .works__image {
      border-radius: 18px
   }

   .works__images-label {
      padding: 4px 12px;
      font-size: 14px;
      top: 10px;
      left: 10px
   }

   .works__text {
      border-radius: 18px;
      padding: 18px
   }

   .works__text-item {
      font-size: 14px
   }

   .calculation__body {
      padding: 0 0 45px
   }

   .calculation__items {
      grid-template-columns: 1fr
   }

   .calculation__item:nth-child(2),
   .calculation__item:nth-child(3) {
      width: 100%;
      max-width: 344px;
      justify-self: center
   }

   .calculation__text {
      font-size: 16px
   }

   .calculation__icon svg {
      width: 18px;
      height: 18px
   }

   .get {
      border-radius: 25px 25px 0 0
   }

   .get__body {
      padding: 32px 0
   }

   .get__cards {
      grid-template-columns: 1fr 1fr;
      grid-template-rows: auto;
      gap: 10px
   }

   .get__card:nth-child(1) {
      grid-column: span 2
   }

   .get__card:nth-child(2) {
      grid-row: span 3 !important
   }

   .get__title {
      margin-bottom: 12px
   }

   .get__title br {
      display: none
   }

   .gallery__body {
      width: calc(100% - 20px)
   }

   .steps {
      padding-top: 50px
   }

   .steps__body .title {
      margin-bottom: 24px
   }

   .steps__wrapper {
      border-radius: 25px
   }

   .agit__body {
      padding: 45px 0
   }

   .about__body {
      padding: 45px 0
   }

   .calculator__wrapper {
      border-radius: 25px
   }

   .calculator__body {
      padding: 30px 0
   }

   .calculator__progress {
      margin-bottom: 20px
   }

   .calculator__subtitles {
      margin-bottom: 30px
   }

   .calculator__subtitle {
      border-radius: 20px;
      font-size: 18px
   }

   .calculator__types {
      flex-direction: column
   }

   .calculator__button {
      font-size: 14px;
      padding: 6px 10px;
      border-radius: 18px;
      gap: 5px
   }

   .calculator__details {
      flex-direction: column
   }

   .calculator__details-items {
      position: static;
      gap: 12px;
      max-height: 120px
   }

   .calculator__results-summ {
      font-size: 18px
   }

   .calculator__results-att {
      margin-bottom: 20px;
      font-size: 12px
   }

   .calculator__results-buttons {
      flex-direction: column
   }

   .result-table__head {
      display: none
   }

   .result-table__body-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      position: relative
   }

   .result-table__body-row:not(:last-child) {
      margin-bottom: 10px
   }

   .result-table__body-cell span {
      font-weight: 700;
      line-height: 1;
      font-size: 16px;
      padding-top: 6px
   }

   .result-table__body-cell:nth-child(1) {
      position: absolute;
      top: 5px;
      right: 10px
   }

   .result-table__body-cell:nth-child(2) {
      font-size: 18px;
      padding-bottom: 12px;
      grid-column: span 2
   }

   .result-table__body-cell:last-child {
      grid-column: span 2;
      display: block;
      font-size: 16px;
      font-weight: 700
   }

   .result-table__body-cell:last-child span {
      font-weight: 400
   }

   .infocards__item-num {
      font-size: 40px
   }

   .infocards__item-descr {
      font-size: 18px
   }

   .team {
      padding-bottom: 20px;
      border-radius: 0 0 25px 25px
   }

   .team__body {
      gap: 22px
   }

   .team__slide-quality {
      margin-bottom: 8px
   }

   .workshop__body {
      padding: 45px 0
   }

   .cooperation__wrapper {
      border-radius: 25px
   }

   .benefits__body {
      padding: 45px 0
   }

   .benefits__cards {
      grid-template-columns: repeat(2, 1fr)
   }

   .photoreport__info {
      padding: 30px 20px
   }

   .blog {
      padding: 45px 0
   }

   .blog__title {
      margin-bottom: 0
   }

   .blog__att {
      margin: 30px 0 20px
   }

   .reviews__head {
      flex-direction: column;
      gap: 22px
   }

   .faq__wrapper {
      border-radius: 24px
   }

   .faq__body {
      padding: 30px 0
   }

   .faq__body .works__title {
      margin-bottom: 22px
   }

   .bonuses__slide-label {
      min-width: unset;
      font-size: 12px;
      top: 10px;
      left: 10px;
      padding: 6px 10px
   }

   .bonuses__slide-descr {
      font-size: 16px
   }

   .price {
      padding-bottom: 45px
   }

   .price__body .title {
      font-size: 20px;
      margin-bottom: 22px
   }

   .price__body .title .title-grey {
      font-size: 20px
   }

   .price__info {
      border-radius: 25px;
      padding: 30px 0 30px 30px
   }

   .price__tab-icon {
      flex: 0 0 36px;
      width: 36px;
      height: 36px
   }

   .price__tab-icon svg {
      width: 26px;
      height: 26px
   }

   .price__values-block {
      border-radius: 0 0 25px 25px;
      padding: 70px 20px 30px 20px
   }

   .price__values-list {
      margin-bottom: 40px
   }

   .price__value {
      font-size: 14px
   }

   .price__value:not(:last-child) {
      margin-bottom: 20px
   }

   .price__att {
      font-size: 14px
   }

   .price__buttons {
      flex-direction: column
   }

   .callback__info {
      border-radius: 25px;
      padding: 24px
   }

   .callback__title {
      margin-bottom: 22px
   }

   .callback__form {
      border-radius: 25px;
      padding: 24px 24px 34px 24px
   }

   .callback__form-title {
      margin-bottom: 20px
   }

   .footer__wrapper {
      border-radius: 40px
   }

   .footer__bottom-body {
      padding: 30px 0;
      grid-template-columns: 1fr
   }

   .footer__bottom-logo {
      grid-column: span 1;
      text-align: center;
      margin-bottom: 20px
   }

   .footer__bottom-copyright,
   .footer__bottom-policy button {
      text-align: center
   }

   .footer__bottom-policy {
      margin-bottom: 10px
   }

   .footer__bottom-policy button {
      display: block;
      text-align: center;
      width: 100%
   }
}

@media (max-width:601px) {
   .blog__slide-prev {
      transform: translateX(-25%)
   }

   .blog__slide-next {
      transform: translateX(25%)
   }
}

@media (max-width:600px) {
   .button {
      font-size: 16px;
      padding: 8px 10px
   }

   .button-icon {
      width: 30px;
      height: 30px
   }

   .button-icon svg {
      width: 14px;
      height: 14px
   }

   .hero__att {
      font-size: 14px
   }

   .hero__buttons {
      flex-direction: column
   }

   .hero__button {
      width: 100%
   }

   .get__cards {
      grid-template-columns: 1fr
   }

   .get__card {
      border-radius: 18px
   }

   .get__card:nth-child(1) {
      grid-column: span 1 !important
   }

   .get__card:nth-child(2) {
      grid-row: span 1 !important
   }

   .gallery__slide {
      width: 80%
   }

   .gallery__slide.gallery__slide-group {
      height: auto;
      gap: 10px;
      flex-direction: column
   }

   .gallery__slide.gallery__slide-group img {
      width: auto;
      height: 100%;
      aspect-ratio: unset
   }

   .steps__item {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px 15px;
      padding: 20px 0 30px
   }

   .steps__item-num {
      grid-column: span 2
   }

   .steps__item-image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      border-radius: 18px
   }

   .steps__item-name {
      margin-bottom: 6px;
      line-height: 120%
   }

   .steps__item-buttons {
      margin-top: 15px;
      gap: 5px
   }

   .steps__item-button {
      min-width: unset;
      width: 100%
   }

   .steps__item-button .button-icon {
      width: 26px;
      height: 26px
   }

   .agit .title {
      font-size: 20px;
      margin-bottom: 12px
   }

   .agit .calculation__item {
      height: 56px
   }

   .agit .calculation__icon {
      transform: translateX(3px)
   }

   .about__body {
      flex-direction: column
   }

   .about__body .title {
      margin-bottom: 10px
   }

   .about__att span {
      font-size: 14px
   }

   .calculator__results-button {
      width: 100%
   }

   .infocards__items {
      gap: 10px
   }

   .infocards__item-num {
      font-size: 24px;
      top: 30%
   }

   .infocards__item-descr {
      font-size: 12px;
      line-height: 120%
   }

   .workshop__block:not(:first-child) {
      border-radius: 18px
   }

   .workshop__benefits-items li {
      width: auto;
      font-size: 14px;
      padding: 6px 10px
   }

   .workshop__card {
      padding: 16px;
      border-radius: 18px;
      top: 10px;
      left: 10px;
      width: 60%;
      font-size: 14px
   }

   .workshop__card-name {
      font-size: 14px;
      margin-bottom: 6px
   }

   .workshop__card-num {
      font-size: 18px;
      margin-bottom: 6px
   }

   .cooperation__body .title {
      font-size: 22px
   }

   .cooperation__cards {
      gap: 10px
   }

   .cooperation__card {
      border-radius: 18px;
      padding: 30px 20px
   }

   .cooperation__info-image {
      max-width: 100%;
      width: 100%;
      height: auto;
      aspect-ratio: 1/1
   }

   .cooperation__conditions-title {
      margin-bottom: 8px
   }

   .application__title {
      margin-bottom: 20px
   }

   .application__form-area input {
      padding: 12px 20px;
      font-size: 16px;
      border-radius: 18px
   }

   .benefits__card {
      border-radius: 20px
   }

   .benefits__card:nth-child(2) {
      background: #fdce2a
   }

   .benefits__card-icon {
      width: 40px;
      height: 40px;
      margin-inline: auto
   }

   .benefits__card-icon svg {
      width: 20px;
      height: 20px
   }

   .benefits__card-name {
      line-height: 120%;
      text-align: center
   }

   .benefits__card-descr {
      line-height: 120%;
      text-align: center
   }

   .photoreport__body {
      border-radius: 26px
   }

   .photoreport__image {
      max-width: 100%;
      margin: 0;
      border-radius: 20px
   }

   .blog__wrapper {
      border-radius: 25px
   }

   .blog__body {
      padding: 40px 0
   }

   .blog__head {
      gap: 10px
   }

   .blog__subtitle {
      font-size: 20px;
      text-wrap: unset
   }

   .blog__slide-info {
      font-size: 14px
   }

   .blog__end {
      font-size: 14px
   }

   .reviews__yandex {
      flex: 1;
      width: 100%
   }

   .reviews__content {
      padding: 20px 0 40px
   }

   .reviews__slide-buttons {
      margin-top: 12px
   }

   .review {
      padding: 20px
   }

   .review__author {
      margin-bottom: 8px
   }

   .review__body {
      font-size: 14px
   }

   .review__text {
      font-size: 14px
   }

   .recomended__videos {
      flex-direction: column;
      gap: 15px
   }

   .recomended__video {
      border-radius: 20px
   }

   .recomended__video-info {
      padding: 10px 20px
   }

   .faq__item.active .faq__answer {
      padding-top: 15px
   }

   .faq__question {
      padding: 10px 20px
   }

   .faq__question-icon {
      flex: 0 0 24px;
      width: 24px;
      height: 24px
   }

   .faq__answer {
      width: calc(100% - 25px);
      font-size: 14px;
      line-height: 120%
   }

   .faq__item-add .button {
      padding: 10px 20px
   }

   .bonuses__body {
      padding: 45px 0
   }

   .bonuses__body .title {
      margin-bottom: 22px
   }

   .bonuses__slide {
      border-radius: 18px
   }

   .bonuses__slide-name {
      font-size: 16px;
      line-height: 120%;
      margin-bottom: 6px
   }

   .bonuses__slide-descr {
      font-size: 15px;
      line-height: 120%
   }

   .bonuses__slide-prev {
      display: none
   }

   .bonuses__slide-next {
      display: none
   }

   .price__tab-name {
      font-size: 16px;
      gap: 10px;
      line-height: 120%
   }

   .price__tab-arrow {
      width: 60px
   }

   .footer {
      padding-bottom: 0
   }

   .footer__main-contact:not(:last-child) {
      margin-bottom: 30px
   }

   .footer__main-contact-label {
      font-size: 16px;
      margin-bottom: 10px
   }

   .footer__main-contact-link {
      font-size: 16px
   }

   .footer__tel {
      font-size: 24px;
      margin-bottom: 20px
   }

   .footer__main-subtitle {
      margin-bottom: 10px
   }

   .footer__main-socials {
      display: flex;
      flex-wrap: wrap
   }

   .footer__main-socials p {
      width: 100%;
      font-size: 16px;
      margin-bottom: 10px
   }

   .footer__map {
      border-radius: 40px
   }

   .policy-popup__body {
      border-radius: 16px;
      width: 94%
   }

   .policy-popup__subtitle {
      font-size: 18px
   }

   .policy-popup__text {
      padding: 20px;
      font-size: 14px
   }

   .policy-popup__text div:not(:first-child) {
      margin: 30px 0
   }

   .policy-popup__text p:not(:last-child) {
      margin-bottom: 15px
   }

   .policy-popup__close {
      width: 30px;
      height: 30px;
      top: -40px;
      right: -10px
   }

   .form-popup__body .title {
      font-size: 20px
   }

   .form-popup__body {
      border-radius: 25px
   }

   .form-popup__message-title {
      padding: 30px
   }
}

@media (max-width:399px) {
   .calculator__button {
      font-size: 12px
   }
}

@media (max-width:390px) {
   .price__value {
      font-size: 13px
   }
}

@media (max-width:379px) {
   .blog__slide-info {
      font-size: 12px;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
      max-width: 100%
   }
}

@media (max-width:374px) {
   .benefits__cards {
      grid-template-columns: 1fr;
      grid-template-rows: auto
   }

   .benefits__card-icon:empty {
      display: none
   }
}

@media (max-width:369px) {
   .form-popup__application {
      padding: 20px
   }
}

@media (max-width:359px) {
   .calculation__link {
      font-size: 12px
   }

   .steps__item {
      display: flex;
      flex-direction: column
   }

   .agit .calculation__item {
      height: 45px
   }

   .agit .calculation__link {
      font-size: 12px
   }

   .form-popup__body .title {
      font-size: 18px
   }
}

@media (max-width:350px) {
   .infocards__item-num {
      font-size: 20px;
      top: 20%
   }

   .infocards__item-descr {
      padding: 12px;
      word-wrap: break-word;
      text-wrap: unset;
      font-size: 11px
   }
}

@media (min-width:600px) and (max-width:800px) {
   .agit .calculation__icon {
      transform: translateX(6px)
   }
}

@media (min-width:768px) and (max-width:1360px) {
   .calculation__item:nth-child(1) {
      grid-column: span 2
   }
}

@media (min-width:768px) and (max-width:1000px) {
   .footer__bottom-policy {
      order: 1;
      text-align: right
   }
}

@media (min-width:768px) {
   .works__title i {
      display: none
   }
}

@media (min-width:1000px) and (max-width:1200px) {
   .works__title .title-line {
      width: 100%;
      flex: 1 0 200px
   }

   .cooperation__body .title .title-line {
      width: auto;
      flex: 1
   }

   .benefits__body span {
      flex: 1
   }

   .benefits__body .title-line {
      width: 100%;
      flex: 0 1 250px
   }

   .price__values-block {
      max-height: 830px
   }

   .price__buttons {
      flex-direction: column
   }
}

@media (min-width:1000px) {
   .hero__image.element-animation {
      transition: all 1s ease .5s;
      opacity: 0
   }

   .hero__image.element-animation.element-show {
      opacity: 1
   }

   .hero__info.element-animation {
      opacity: 0;
      transition: all 1s ease .5s
   }

   .hero__info.element-animation.element-show {
      opacity: 1
   }
}

@media (min-width:1001px) and (max-width:1200px) and (max-width:1800px) {
   .team__slide.swiper-slide-active {
      width: 360px !important
   }
}

@media (min-width:1001px) and (max-width:1200px) {
   .hero__body {
      max-height: 700px
   }

   .team__slide.swiper-slide-active {
      width: 420px !important
   }

   .team__slide.swiper-slide-active .team__slide-name {
      opacity: 1
   }

   .team__slide.swiper-slide-active .team__slide-info {
      opacity: 1
   }
}

@media (min-width:1001px) {
   .team__text {
      padding: 60px 0
   }

   .team__slide-name {
      opacity: 0
   }

   .team__slide-info {
      opacity: 0
   }
}

@media (min-width:1201px) and (max-width:1800px) {

   .team__slide.swiper-slide-active,
   .team__slide.swiper-slide-next {
      width: 360px !important
   }
}

@media (min-width:1201px) and (max-width:1420px) {
   .menu__social {
      width: 36px;
      height: 36px
   }

   .menu__social svg {
      width: 16px;
      height: 16px
   }
}

@media (min-width:1201px) {

   .team__slide.swiper-slide-active,
   .team__slide.swiper-slide-next {
      width: 420px !important
   }

   .team__slide.swiper-slide-active .team__slide-name,
   .team__slide.swiper-slide-next .team__slide-name {
      opacity: 1
   }

   .team__slide.swiper-slide-active .team__slide-info,
   .team__slide.swiper-slide-next .team__slide-info {
      opacity: 1
   }
}

@media (min-width:1801px) {
   .get__card {
      min-height: 314px
   }
}

@media (min-width:1900px) {
   .calculation__icon {
      transform: translateX(-4px)
   }
}

@media (hover:hover) {
   .button:hover {
      border-color: #000
   }

   .button:hover .button-icon {
      transform: translateX(3px)
   }

   .slider-prev:hover svg {
      transform: translateX(-3px)
   }

   .slider-next:hover svg {
      transform: translateX(3px)
   }

   .menu__link:hover {
      color: #fdce2a
   }

   .menu__tel a:hover {
      color: #fdce2a
   }

   .menu__social:hover svg {
      color: #fdce2a
   }

   .calculation__item:nth-child(2):hover .calculation__link svg,
   .calculation__item:nth-child(3):hover .calculation__link svg {
      transform: rotate(45deg)
   }

   .calculation__item:nth-child(2):hover .calculation__link span,
   .calculation__item:nth-child(3):hover .calculation__link span {
      transform: translateY(-6px)
   }

   .calculation__item:nth-child(2):hover .calculation__icon svg,
   .calculation__item:nth-child(3):hover .calculation__icon svg {
      transform: scale(1.1)
   }

   .gallery__slide img:hover {
      transform: scale(1.05)
   }

   .steps__item:hover .steps__item-image {
      opacity: 1;
      transform: scale(1)
   }

   .steps__item:hover .steps__item-num {
      color: #fdce2a
   }

   .calculator__type:not(.active):hover {
      border-color: #fdce2a
   }

   .calculator__type:not(.active):hover .calculator__type-icon {
      transform: scale(1)
   }

   .calculator__button:hover {
      background: #fdce2a
   }

   .calculator__button:hover .calculator__button-icon {
      transform: translateX(3px)
   }

   .calculator__button:first-child:hover .calculator__button-icon {
      transform: translateX(-3px);
      background: #fdce2a
   }

   .detail-path:hover {
      fill: #fdce2a;
      cursor: pointer
   }

   .result-table__body-cell button:hover {
      filter: brightness(.5)
   }

   .application__form-area input:hover {
      border-color: #fdce2a
   }

   .blog__slide:hover .blog__slide-img {
      overflow: hidden
   }

   .blog__slide:hover .blog__slide-img img {
      transform: scale(1.05)
   }

   .blog__slide:hover .blog__slide-name {
      color: #fdce2a
   }

   .blog__social:hover {
      transform: scale(1.05)
   }

   .reviews__yandex-rating-details a:hover {
      text-decoration: underline
   }

   .reviews__yandex-link:hover {
      text-decoration: underline
   }

   .review__text-toggle:hover {
      color: #000
   }

   .recomended__video:hover .recomended__video-play {
      background: rgba(0, 0, 0, .85)
   }

   .recomended__video:hover svg {
      color: #fdce2a
   }

   .recomended__video-play:hover svg {
      color: #fdce2a
   }

   .faq__question:hover {
      border-color: #fdce2a
   }

   .price__tab:hover .price__tab-name {
      color: #fff
   }

   .footer__tel:hover {
      color: #fdce2a
   }

   .footer__mail:hover {
      color: #fdce2a
   }

   .footer__main-social:hover {
      transform: scale(1.05)
   }

   .policy-popup__close:hover img {
      transform: rotate(-90deg)
   }

   .form-popup__tel a:hover {
      color: #fdce2a
   }

   .form-popup__socials a:hover {
      transform: scale(1.05)
   }
}

.webp .benefits__card:nth-child(2) {
   background-image: url(../img/guarantee.webp)
}

.webp .callback__info {
   background-image: url(../img/form.webp)
}