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

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

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

:root {
  --theme-color: var(--akcent);
  --text-color: var(--chernyy);
  --background-color: var(--fon);
  accent-color: var(--theme-color);
  --wrapper-size: 1220px;
  --wrapper-padding: 15px;
  --section-margin: 40px;
  --chernyy: #070808;
  --asfalt: #2e3e49;
  --belyy: #f5f8fa;
  --fon: #edf1f5;
  --akcent: #f99e1e;
  --akcent-2: #ff1744;
  --font-family: "Manrope", sans-serif;
  --second-family: "Adderley", sans-serif;
}

html {
  height: 100%;
  scrollbar-gutter: stable;
  scroll-behavior: smooth;
}

body {
  display: flex;
  flex-direction: column;
  font-family: var(--font-family);
  min-height: 100%;
  min-width: 320px;
  background-color: var(--background-color);
  color: var(--text-color);
}

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

body::-webkit-scrollbar-thumb {
  background-color: var(--theme-color);
}

::selection {
  background-color: var(--theme-color);
  color: #fff;
}

body.z-index::before {
  z-index: 150;
}

body.scroll-lock,
body.menu-open {
  overflow: hidden;
}

.mob-tel {
  display: none;
}

.mob-mini-tel {
  display: none;
}

.main {
  flex-grow: 1;
}

.wrapper {
  width: min(
    var(--wrapper-size),
    calc(100% - (var(--wrapper-padding) + var(--wrapper-padding)))
  );
  margin-inline: auto;
}

.wrapper-padding {
  padding-left: max(
    var(--wrapper-padding),
    calc((100% - var(--wrapper-size)) / 2)
  );
  padding-right: max(
    var(--wrapper-padding),
    calc((100% - var(--wrapper-size)) / 2)
  );
}

.wrapper-padding.scroll-table::-webkit-scrollbar,
.wrapper-padding.scroll-phone {
  display: none;
}

.menu-burger {
  display: none;
}

[data-modal] {
  cursor: pointer;
}

.modal {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transform: translate(0px, -100%);
  z-index: 151;
}

.modal.popup-active {
  transform: translate(0px, 0%);
}

.modal__main {
  width: 100%;
  overflow-y: auto;
  height: 100%;
  overflow-x: hidden;
}

.modal__fade {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  transition: background-color 0.3s ease 0s;
}

.modal .wrapper {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  height: 100%;
  padding-top: 15px;
  padding-bottom: 15px;
}

.modal .wrapper::-webkit-scrollbar,
.modal__main::-webkit-scrollbar {
  display: none;
}

.modal__body {
  width: 100%;
  position: relative;
  max-width: 643px;
  background: var(--akcent);
  color: var(--belyy);
  display: flex;
  flex-direction: column;
  margin-top: auto;
  margin-bottom: auto;
  opacity: 0;
  padding: 50px;
  transition: 0.3s ease 0s;
  translate: 0px 20px;
}

.pp-animate .modal__body {
  opacity: 1;
  translate: 0px 0px;
}

.pp-animate .modal__fade {
  background-color: rgba(24, 24, 27, 0.88);
}

.modal-close::before {
  transform: rotate(-45deg);
  top: calc(50% - 3px);
}

.modal-close::after {
  transform: rotate(45deg);
  bottom: calc(50% - 1px);
}

.pp-unanimate .modal__body {
  opacity: 0;
  translate: 0px 20px;
}

.modal-close {
  padding: 7px 7px;
  display: flex;
  position: relative;
  align-self: center;
  background-color: #ffffff00;
  width: 45px;
  height: 45px;
  z-index: 12;
  cursor: pointer;
}

.modal-close {
  position: absolute;
  right: 43px;
  top: 43px;
  transition: 0.2s ease 0s;
}

.modal-close:hover {
  opacity: 0.8;
}

.modal-close::before,
.modal-close::after {
  content: "";
  transition: all 0.3s ease 0s;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  position: absolute;
  width: calc(100% - 15px);
  height: 5px;
  background-color: var(--belyy);
}

.scroll-up-container {
  position: fixed;
  right: 0;
  color: var(--belyy);
  bottom: 0;
  z-index: 50;
  pointer-events: none;
  width: 100%;
  padding: 30px 80px 30px 80px;
}

.scroll-up-container .wrapper {
  display: flex;
  justify-content: flex-end;
}

.scroll-up {
  box-shadow: 0 0px 10px 0px rgba(0, 0, 0, 0.3);
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  width: 50px;
  height: 50px;
  background-color: var(--theme-color);
  transition: 0.3s ease 0s;
  z-index: 100;
}

.scroll-up_v2 {
  position: fixed;
  right: 30px;
  bottom: 30px;
}

.scroll-up.active {
  opacity: 1;
  pointer-events: all;
}

.scroll-up svg,
.scroll-up img {
  transition: 0.2s ease 0s;
}

.scroll-up:hover {
  background: #f2b347;
}

.swiper-button-next,
.swiper-button-prev {
  margin-top: 0px;
  top: 50%;
  translate: 0px -50%;
}

.swiper-slide {
  height: auto;
}

.swiper-button-next svg,
.swiper-button-next img,
.swiper-button-prev svg,
.swiper-button-prev img {
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
}

.swiper-button-next::after,
.swiper-button-prev::after {
  display: none;
}

.drop-menu {
  position: relative;
}

.drop-menu ul {
  padding: 10px 15px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.drop-menu ul a {
  border-bottom: none !important;
}

.drop-menu span {
  position: relative;
  transition: 0.2s ease 0s;
  cursor: pointer;
  margin-right: 14px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.drop-menu span::after {
  content: "";
  height: 4px;
  background: url(../img/icons/arrow.svg) center / contain no-repeat;
  position: absolute;
  width: 7px;
  left: calc(100% + 8px);
  transition: 0.2s ease 0s;
  top: 6px;
}

.drop-menu ul::-webkit-scrollbar {
  width: 4px;
}

.drop-menu ul::-webkit-scrollbar-thumb {
  background-color: var(--theme-color);
}

.modal-cookie {
  position: fixed;
  pointer-events: none;
  bottom: 0;
  width: 100%;
  left: 0;
  padding: 0px 15px;
  translate: 0px calc(100% + 35px);
  z-index: 200;
  animation: cookieVisible 1s ease 2s forwards;
}

.modal-cookie .button-border {
  border-color: var(--chernyy);
  color: var(--chernyy);
}

.modal-cookie .wrapper {
  display: flex;
  justify-content: center;
}

.modal-cookie__body {
  pointer-events: all;
  box-shadow: 0 16px 29px -16px rgba(2, 54, 113, 0.3);
  background: #fff;
  translate: 0px calc(0% - 30px);
  overflow: hidden;
  padding: 24px;
  max-width: 450px;
  text-align: center;
  font-weight: 500;
  font-size: 14px;
  line-height: 150%;
  text-align: center;
  color: var(--dark);
  transition: 0.4s ease 0s;
}

.modal-cookie__body button {
  flex-grow: 1;
  width: calc((100% - 16px) / 2);
  font-size: 14px;
  padding: 10px !important;
}

@keyframes cookieVisible {
  0% {
    translate: 0px 200px;
  }

  100% {
    translate: 0px 0px;
  }
}

.modal-cookie.hidden-modal .modal-cookie__body {
  opacity: 0;
}

.modal-cookie__bottom {
  display: flex;
  gap: 16px;
}

.modal-cookie a {
  color: var(--theme-color);
}

.modal-cookie__text {
  margin-bottom: 15px;
}

.burger-menu {
  display: none;
}

/* ==================================== */

@media (max-width: 1230px) {
  :root {
    --wrapper-size: 992px;
  }
}

@media (max-width: 1024px) {
  :root {
    --wrapper-size: 828px;
    --section-margin: 30px;
  }

  .wrapper-padding.scroll-table {
    overflow: auto;
    scroll-snap-type: x mandatory;
  }

  .wrapper-padding.scroll-table .scroll-el {
    scroll-snap-align: center;
  }

  .modal-cookie.hidden-modal .modal-cookie__body {
    opacity: 0;
  }

  .modal-cookie__body {
    padding: 20px;
    font-size: 14px;
    transition: 0.4s ease 0s;
  }
}

@media (max-width: 768px) {
  .mob-tel {
    display: block;
  }

  .wrapper-padding.scroll-phone {
    overflow: auto;
    scroll-snap-type: x mandatory;
  }

  .modal-cookie__body button {
    height: 40px;
    font-size: 14px;
    width: calc((100% - 10px) / 2);
  }

  .modal-cookie__bottom {
    gap: 10px;
  }

  .wrapper-padding.scroll-phone .scroll-el {
    scroll-snap-align: center;
  }

  .scroll-up {
    width: 45px;
    height: 45px;
    padding: 5px;
    right: 15px;
    bottom: 15px;
    margin-bottom: -45px;
  }

  .scroll-up.active {
    margin-bottom: 0;
  }

  :root {
    --wrapper-size: 520px;
    --section-margin: 25px;
  }
}

@media (max-width: 480px) {
  .mob-mini-tel {
    display: block;
  }
  .modal-cookie__body button {
    min-height: 45px;
  }
  .modal-cookie__text br {
    display: none;
  }

  .modal-cookie {
    padding: 0px 10px;
  }

  .modal-cookie__body {
    padding: 10px;
  }

  .modal-cookie__text {
    font-size: 12px;
  }

  .modal-cookie__body {
    translate: 0px calc(0% - 15px);
  }

  .modal-cookie__body button {
    height: 35px;
    font-size: 12px;
  }

  :root {
    --wrapper-size: 350px;
    --wrapper-padding: 10px;
    --section-margin: 20px;
  }
}

/* ==================================== */

.footer {
  background: var(--asfalt);
  color: var(--belyy);
  padding: 35px 0px;
}

.footer__top {
  display: flex;
  margin-bottom: 38px;
  padding-bottom: 35px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  gap: 43px;
}

.logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 15px;
}

.logo img {
  flex-shrink: 0;
  width: 120px;
}
@media (max-width: 768px) {
  .logo img {
    width: 70px;
  }
}
.logo span {
  font-weight: 400;
  font-size: 14px;
  opacity: 0.5;
  line-height: 150%;
  color: var(--belyy);
}

.logo__name {
  font-weight: 700;
  font-size: 20px;
  line-height: 150%;
  color: var(--belyy);
}
.footer__top-main {
  gap: 25px;
  align-items: center;
  justify-content: space-between;
  display: flex;
}

.adress-header svg {
  flex-shrink: 0;
}

.footer .adress-header {
  max-width: 257px;
  width: 100%;
}

.adress-header {
  font-size: 14px;
  line-height: 150%;
  align-items: center;
  display: flex;
  gap: 10px;
  color: #d6dde4;
}
.mail-header {
  font-size: 14px;
  line-height: 150%;
  display: flex;
  transition: 0.3s ease 0s;
  gap: 10px;
  align-items: center;
  color: #d6dde4;
}

.mail-header svg {
  flex-shrink: 0;
}

.mail-header:hover {
  color: var(--akcent);
}

.socials {
  display: flex;
  gap: 12px;
}
.socials__link {
  width: 38px;
  border: 1px solid #d6dde4;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  opacity: 0.5;
  flex-shrink: 0;
  transition: 0.3s ease 0s;
}

.contacts_v2 .socials__link {
  border: 1px solid #070808;
  color: #070808;
}

.socials__link:hover {
  opacity: 1;
}

.search-button {
  flex-shrink: 0;
  transition: 0.3s ease 0s;
  width: 24px;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 24px;
}

.search-button:hover {
  color: var(--akcent);
}

.footer__top-main {
  flex-grow: 1;
}

.header-telephones span {
  font-size: 14px;
  display: block;
  width: 100%;
  line-height: 150%;
  text-align: center;
  opacity: 0.5;
}

.header-telephones__body {
  display: flex;
  position: relative;
  gap: 10px;
  padding-bottom: 10px;
  margin-bottom: -10px;
  align-items: center;
  flex-direction: column;
  margin-top: 10px;
}

.header-telephones__body svg {
  transition: 0.3s ease 0s;
}

.header-telephones__body:hover svg {
  rotate: 180deg;
}

.header-telephones__body:hover .header-telephones__list {
  opacity: 1;
  pointer-events: all;
  translate: 0px 0px;
}

.header-telephones__tel {
  font-weight: 700;
  font-size: 18px;
  transition: 0.3s ease 0s;
  line-height: 150%;
  text-align: left;
  color: #d6dde4;
}

.header-telephones__tel:hover {
  color: var(--akcent);
}

.header-telephones__list {
  position: absolute;
  width: 310px;
  display: flex;
  align-items: flex-start;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s ease 0s;
  translate: 0px 10px;
  flex-direction: column;
  gap: 5px;
  top: 100%;
  background: #fff;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--chernyy);
  padding: 30px;
  right: 0;
}
.header-telephones__list-title {
  padding-bottom: 5px;
  font-weight: 700;
  font-size: 16px;
  line-height: 150%;
  color: var(--chernyy);
}
.footer__main {
  display: flex;
  gap: 20px;
}
.footer__lists {
  display: flex;
  gap: 20px;
}

.footer__lists ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 290px;
}

.footer__lists ul li a {
  font-weight: 400;
  font-size: 16px;
  opacity: 0.5;
  transition: 0.3s ease 0s;
  line-height: 150%;
  color: var(--belyy);
}

.footer__lists ul li a:hover {
  color: var(--akcent);
  opacity: 1;
}

.footer__lists ul li:first-child {
  margin-bottom: 5px;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--belyy);
}

.footer__main-right {
  margin-left: auto;
}

.footer__main-right ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--belyy);
  opacity: 0.5;
  margin-bottom: 40px;
}
.footer__sub-title {
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  margin-bottom: 20px;
  color: var(--belyy);
}

.footer__main-right .button {
  margin-bottom: 20px;
  width: 100%;
}

.footer__main-right .button-border {
  width: 100%;
}

.button,
a.button {
  transition: 0.3s ease 0s;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 150%;
  min-height: 60px;
  text-align: center;
  padding: 15px 30px;
  background: var(--akcent);
  color: var(--belyy);
}

.button:hover {
  background: #f2b347;
}

.button-border,
a.button-border {
  font-weight: 400;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  min-height: 60px;
  transition: 0.3s ease 0s;
  border: 1px solid var(--belyy);
  padding: 15px 30px;
  line-height: 150%;
  text-align: center;
  color: var(--belyy);
}

.button-border:hover {
  color: var(--chernyy);
  background: var(--belyy);
}

.footer__bottom {
  margin-top: 80px;
  padding-top: 35px;
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  display: flex;
  justify-content: space-between;
}

.footer__bottom a {
  opacity: 0.2;
  font-size: 14px;
  line-height: 150%;
  transition: 0.3s ease 0s;
}

.footer__bottom a:hover {
  opacity: 1;
  color: var(--akcent);
}

.footer__requisits {
  display: none;
}

@media (max-width: 1230px) {
  .footer .adress-header {
    max-width: 103px;
    width: 100%;
  }

  .footer__top {
    gap: 20px;
  }

  .footer__top-main {
    gap: 14px;
  }

  .footer__main {
    flex-wrap: wrap;
  }
}

@media (max-width: 1024px) {
  .footer {
    padding: 40px 0px;
  }

  .footer__main-right {
    margin-left: auto;
    width: 100%;
    margin-right: auto;
  }

  .footer__requisits {
    display: flex;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    text-align: center;
    padding-top: 40px;
    flex-direction: column;
    align-items: center;
  }

  .footer__requisits ul {
    display: flex;
    gap: 10px;
    opacity: 0.5;
    flex-direction: column;
  }

  .footer__top {
    align-items: center;
    flex-direction: column;
    gap: 40px;
  }

  .footer__top-main {
    flex-direction: column;
    gap: 40px;
  }

  .footer__logo {
    display: flex;
    flex-direction: column;
    text-align: center;
    padding-bottom: 40px;
    align-items: center;
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }

  .footer__top-main .adress-header {
    order: 3;
  }
  .footer__top-main .mail-header {
    order: 2;
  }

  .footer__top-main .socials {
    order: 4;
  }

  .footer .mail-header svg {
    display: none;
  }

  .footer__main-right .button {
    margin-bottom: 10px;
    min-height: 80px;
  }

  .footer__lists {
    gap: 40px;
  }

  .footer__lists ul {
    width: 100%;
    gap: 15px;
  }

  .footer__bottom {
    text-align: center;
    gap: 40px;
    align-items: center;
    margin-top: 40px;
    flex-direction: column;
    padding-top: 40px;
  }

  .footer__lists ul:not(:last-child) {
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  }

  .footer__lists ul li {
    text-align: center;
  }

  .footer__main {
    gap: 40px;
  }

  .footer__main-right .button-border {
    min-height: 80px;
  }

  .footer__top {
    margin-bottom: 40px;
    padding-bottom: 40px;
  }

  .footer__main-right {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    padding-bottom: 40px;
  }

  .footer__main-right .footer__sub-title {
    display: none;
  }

  .footer__main-right ul {
    display: none;
  }

  .footer__main {
    flex-direction: column-reverse;
  }

  .footer__lists {
    flex-direction: column;
  }

  .footer .adress-header {
    text-align: center;
  }

  .footer .adress-header svg {
    display: none;
  }

  .footer__top-main .search-button {
    order: 5;
  }

  .footer__top-main .header-telephones {
    order: 1;
  }
}

/* ==================================== */

.form-section {
  background: var(--akcent);
  color: var(--belyy);
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}

h2,
.h2 {
  font-family: var(--second-family);
  font-weight: 700;
  font-size: 70px;
  line-height: 95%;
  text-transform: uppercase;
  margin-bottom: 30px;
}

.form__sub-title {
  font-size: 20px;
  line-height: 150%;
}

h2 + .sub-title {
  margin-top: -20px;
}

.sub-title {
  font-size: 20px;
  line-height: 150%;
}

.form-section .sub-title {
  max-width: 320px;
}

.form-section .wrapper {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}

.form-section__form {
  max-width: 600px;
}

.form__sub-title {
  margin-bottom: 20px;
}

.radios-socials {
  display: flex;
  margin-bottom: 40px;
  gap: 14px;
}
.radio-socials__radio {
  width: calc((100% - 28px) / 3);
}

.radio-socials__radio-body {
  width: 100%;
  font-weight: 400;
  transition: 0.3s ease 0s;
  min-height: 60px;
  display: flex;
  border: 1px solid var(--belyy);
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 16px;
  line-height: 150%;
}

.radio-socials__radio input {
  display: none;
}

.radio-socials__radio input:checked + .radio-socials__radio-body {
  background-color: var(--belyy);
  color: var(--chernyy);
}

.form {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.form .input {
  margin-bottom: 40px;
}

.input {
  display: flex;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 15px;
  border-bottom: 1px solid var(--belyy);
  cursor: text;
}

.input::placeholder {
  color: var(--belyy);
}

.button.button_black {
  background: var(--asfalt);
  min-height: 80px;
}

.button.button_black:hover {
  color: var(--chernyy);
  background-color: var(--belyy);
}

.checkbox {
  display: block;
  margin-top: 20px;
  position: relative;
}

.checkbox b {
  font-weight: 500;
  font-size: 16px;
  line-height: 150%;
}

.checkbox span {
  display: flex;
  gap: 15px;
  align-items: flex-start;
}

.checkbox i {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-top: 4px;
  justify-content: center;
  width: 25px;
  height: 25px;
  border: 1px solid var(--belyy);
}

.checkbox i svg {
  transition: 0.2s ease 0s;
  width: 70%;
  opacity: 0;
  color: var(--belyy);
}

.checkbox input:checked + span svg {
  opacity: 1;
}

.checkbox a {
  text-decoration: underline;
  text-decoration-skip-ink: none;
}

.checkbox input {
  position: absolute;
  left: 0;
  opacity: 0;
  pointer-events: none;
  top: 0;
}

@media (max-width: 1230px) {
  .form-section__form {
    max-width: 500px;
  }

  .sub-title {
    font-size: 18px;
  }
}
@media (max-width: 1024px) {
  .form-section .wrapper {
    flex-direction: column;
  }

  .socials__link {
    width: 52px;
    height: 52px;
  }

  .socials__link svg {
    width: 50%;
  }

  .form-section .form {
    max-width: 100%;
  }

  .input input {
    font-size: 26px;
  }

  h2,
  .h2 {
    font-size: 55px;
  }
}
@media (max-width: 768px) {
  .input input {
    font-size: 20px;
  }

  .input {
    text-align: center;
  }

  .form-section .wrapper {
    gap: 30px;
  }

  .radios-socials {
    flex-direction: column;
  }

  .radio-socials__radio {
    width: 100%;
  }

  .form-section__left h2 {
    text-align: center;
  }

  .form-section__left .sub-title {
    text-align: center;
    max-width: 300px;
    margin-inline: auto;
  }

  .form__sub-title {
    font-size: 18px;
    text-align: center;
  }

  .sub-title {
    font-size: 16px;
  }

  h2,
  .h2 {
    font-size: 50px;
  }

  .input {
    gap: 10px;
  }

  .form .button {
    margin-top: 0px;
  }
}
@media (max-width: 480px) {
  h2,
  .h2 {
    font-size: 40px;
  }

  .radios-socials {
    gap: 10px;
  }

  .checkbox b {
    font-size: 14px;
  }

  .form-section__left .sub-title {
    max-width: 248px;
  }

  .form__sub-title {
    font-size: 16px;
  }

  .sub-title {
    font-size: 16px;
  }
}
/* ==================================== */

.contacts__main {
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
  background: var(--asfalt);
  color: var(--belyy);
}

.contacts_v2 .contacts__main {
  background: none;
  padding-top: 0px;
  color: var(--chernyy);
}

.contacts_v2 .socials__link:hover {
  border-color: var(--chernyy);
}

.blocks-section_why-us + .partners {
  margin-top: var(--section-margin);
}

[class*="ymaps-2"][class*="-ground-pane"] {
  filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale");
  -webkit-filter: grayscale(100%);
}

.contacts__columns {
  display: flex;
  gap: 30px;
  flex-wrap: wrap;
}

.contacts__column {
  width: calc((100% - 30px) / 2);
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.contacts__column .socials {
  margin-top: -10px;
}

.contacts__column p {
  font-weight: 400;
  font-size: 20px;
  line-height: 150%;
}

.map {
  height: 600px;
}

@media (max-width: 1230px) {
  .contacts__column p {
    font-size: 18px;
  }
}

@media (max-width: 1024px) {
  .map {
    height: 420px;
  }
}

@media (max-width: 768px) {
  .contacts__column {
    width: 100%;
  }

  .contacts__column p {
    font-size: 16px;
  }

  .map {
    height: 320px;
  }
}

@media (max-width: 480px) {
  .map {
    height: 220px;
  }
}
/* ==================================== */

.reviews {
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}

.reviews__body {
  gap: 20px;
  margin-top: 50px;
  display: flex;
  flex-wrap: wrap;
}
.reviews__block {
  padding: 40px;
  width: calc((100% - 20px) / 2);
  background: var(--belyy);
}
.reviews__block-top {
  display: flex;
  padding-bottom: 13px;
  border-bottom: 1px solid rgba(7, 8, 8, 0.2);
  gap: 16px;
  align-items: center;
}

.reviews__block-top div {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.reviews__block-top span {
  font-weight: 400;
  font-size: 14px;
  line-height: 150%;
  color: var(--chernyy);
}

.reviews__block-top b {
  font-size: 20px;
  font-weight: 500;
}

.reviews__top-image {
  width: 76px;
  flex-shrink: 0;
  height: 76px;
  border-radius: 50%;
  overflow: hidden;
}
.reviews__top-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.reviews__block-text {
  margin-top: 21px;
}
.reviews__block-title {
  font-weight: 500;
  margin-bottom: 10px;
  font-size: 20px;
  line-height: 150%;
}

.reviews__block p {
  line-height: 150%;
  opacity: 0.6;
}

.reviews__bottom {
  display: flex;
  margin-top: 30px;
}
.reviews__bottom .button {
  width: 100%;
  min-height: 80px;
}

a.card__title {
  transition: 0.4s ease 0s;
}

.news-single a,
.news-single__right a,
.text-section a {
  color: var(--akcent);
  text-decoration: underline;
}

a.card__title:hover {
  color: var(--theme-color);
}

@media (max-width: 1024px) {
  .reviews__block {
    padding: 30px;
  }

  .reviews__block-title {
    font-size: 18px;
  }

  .reviews__block-top b {
    font-size: 18px;
  }

  .reviews__body {
    margin-top: 40px;
  }
}

@media (max-width: 768px) {
  .reviews__block-title {
    font-size: 16px;
  }

  .reviews__block-text p {
    font-size: 14px;
  }

  .reviews .sub-title br {
    display: none;
  }

  .reviews__block-top b {
    font-size: 16px;
  }

  .reviews__top-image {
    width: 66px;
    height: 66px;
  }

  .reviews__block {
    width: 100%;
  }

  .reviews__bottom {
    margin-top: 20px;
  }

  .reviews__bottom .button {
    min-height: 60px;
    font-size: 14px;
  }

  .reviews__body {
    margin-top: 30px;
  }
}

@media (max-width: 480px) {
  .reviews__block-title {
    font-size: 14px;
  }

  .reviews .sub-title {
    max-width: 340px;
  }

  .reviews__body {
    margin-top: 20px;
  }

  .reviews__block-top span {
    font-size: 12px;
  }

  .reviews__block {
    padding: 20px;
  }

  .reviews__top-image {
    width: 50px;
    height: 50px;
  }

  .reviews__block-text p {
    font-size: 12px;
  }

  .reviews__block-top b {
    font-size: 12px;
  }
}
/* ==================================== */

.faq {
  z-index: 1;
  position: relative;
  color: var(--belyy);
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}
.faq__background {
  z-index: -1;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  background-color: #070808;
  height: 100%;
}

.faq__background img {
  width: 100%;
  opacity: 0.3;
  height: 100%;
  object-fit: cover;
}

.accordion__body {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 60px;
  gap: 21px;
}
.accordion__tab {
  transition: background-color 0.5s ease 0s;
  cursor: pointer;
  padding: 30px 30px 0px 30px;
  background: var(--asfalt);
  width: calc((100% - 21px) / 2);
}

.accordion__tab-top {
  min-height: 90px;
}

.accordion__tab.accordion-active {
  color: var(--chernyy);
  background: var(--belyy);
}

.swiper-new .card {
  height: auto;
  display: flex !important;
  flex-direction: column;
}

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

.accordion__tab.accordion-active .accordion__tab-icon svg {
  rotate: 180deg;
}

.accordion__tab-top {
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  display: flex;
  padding-bottom: 30px;
}
.accordion__tab-title {
  font-size: 20px;
  line-height: 150%;
}
.accordion__tab-icon {
  width: 71px;
  flex-shrink: 0;
  border-left: 2px solid var(--belyy);
  height: 37px;
  display: flex;
  justify-content: flex-end;
}

.accordion__tab-icon svg {
  transition: 0.3s ease 0s;
}

/* .accordion__tab-body {
  display: none;
} */

.accordion__tab-body {
  margin-top: -10px;
  padding-bottom: 30px;
}

.accordion__tab.accordion-active .accordion__tab-icon {
  border-left: 2px solid var(--chernyy);
}

.accordion__tab-text {
  max-width: 373px;
  font-weight: 400;
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 16px;
  line-height: 150%;
}

@media (max-width: 1024px) {
  .accordion__tab {
    width: 100%;
  }

  .accordion__body {
    margin-top: 30px;
  }

  .accordion__body {
    gap: 10px;
  }

  .accordion__tab-top {
    min-height: 0px;
  }
}

@media (max-width: 768px) {
  .accordion__tab-title {
    font-size: 16px;
    font-weight: 700;
  }

  .accordion__tab-text {
    font-size: 14px;
    max-width: 300px;
  }

  .accordion__tab-icon {
    width: 44px;
  }

  .accordion__tab {
    padding: 20px 20px 0px 20px;
  }

  .accordion__tab-body {
    margin-top: -5px;
    padding-bottom: 20px;
  }

  .accordion__tab-top {
    padding-bottom: 20px;
  }

  .accordion__tab-icon svg {
    width: 20px;
  }

  .accordion__tab-text {
    font-weight: 500;
  }
}

@media (max-width: 480px) {
  .accordion__tab-title {
    font-size: 12px;
  }

  .accordion__tab-text {
    font-size: 12px;
  }
}
/* ==================================== */

.partners {
  color: var(--belyy);
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
  background: var(--akcent);
}

.partners__body {
  display: flex;
  flex-wrap: wrap;
  margin-top: 50px;
  gap: 20px;
}

.partners__block {
  width: calc((100% - 60px) / 4);
}

@media (max-width: 768px) {
  .partners__body {
    margin-top: 30px;
  }
  .partners__block {
    width: calc((100% - 20px) / 2);
  }

  .partners .sub-title {
    max-width: 350px;
  }
}

/* ==================================== */

.blocks-section {
  padding: var(--section-margin) 0px;
}
.blocks-section_services {
  background: var(--asfalt);
  color: var(--belyy);
  margin-top: var(--section-margin);

  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}

.blocks-section__body {
  flex-wrap: wrap;
  margin-top: 50px;
  display: flex;
  gap: 20px;
}
.blocks-section__block,
a.blocks-section__block {
  color: var(--chernyy);
  width: calc((100% - 40px) / 3);
  transition: 0.3s ease 0s;
  position: relative;
  background: var(--belyy);
  display: flex;
  flex-direction: column;
  min-height: 350px;
  padding: 30px;
}
.blocks-section__block-title {
  font-family: var(--second-family);
  padding-bottom: 10px;
  font-weight: 700;
  font-size: 40px;
  margin-bottom: auto;
  line-height: 100%;
}
a.blocks-section__block:hover,
[data-modal].blocks-section__block:hover {
  background-color: var(--akcent);
  color: var(--belyy);
}

@media (max-width: 1230px) {
  .blocks-section__block-title {
    font-size: 36px;
  }
}

@media (max-width: 1024px) {
  .blocks-section__block-title {
    font-size: 28px;
  }

  .blocks-section__block,
  a.blocks-section__block {
    width: calc((100% - 20px) / 2);
  }

  .blocks-section__body {
    margin-top: 30px;
  }
}

@media (max-width: 768px) {
  .blocks-section__block-title {
    font-size: 22px;
  }

  .blocks-section__block p {
    font-size: 14px;
  }

  .blocks-section__block,
  a.blocks-section__block {
    padding: 20px;
  }

  .blocks-section__block,
  a.blocks-section__block {
    min-height: 280px;
  }
}

@media (max-width: 480px) {
  .blocks-section__block-title {
    font-size: 18px;
  }

  .blocks-section__block,
  a.blocks-section__block {
    min-height: 220px;
  }

  .blocks-section__block,
  a.blocks-section__block {
    padding: 10px;
  }

  .blocks-section__block p {
    font-size: 12px;
  }
}
/* ==================================== */

.blocks-section_why-us .blocks-section__block {
  min-height: 250px;
}

.blocks-section__block-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blocks-section_why-us .sub-title {
  max-width: 1060px;
}

.blocks-section__bottom {
  margin-top: 30px;
  display: flex;
}

.blocks-section__bottom .button,
.blocks-section__bottom .button-border {
  min-height: 100px;
  width: 100%;
  font-size: 20px;
}

@media (max-width: 1024px) {
  .blocks-section__bottom .button {
    min-height: 80px;
    font-size: 18px;
  }
}

@media (max-width: 768px) {
  .blocks-section__bottom .button,
  .blocks-section__bottom .button-border {
    min-height: 60px;
    font-size: 16px;
  }

  .blocks-section__block p {
    font-weight: 500;
  }
}

@media (max-width: 480px) {
  .blocks-section_why-us .blocks-section__block {
    min-height: 220px;
  }
}
/* ==================================== */

.scroll-block {
  padding-bottom: var(--section-margin);
}
.scroll-block__body {
  position: relative;
}

.scroll-block__block {
  position: sticky;
  text-align: center;
  top: 0;
  z-index: 2;
  color: var(--belyy);
  left: 0;
}

.scroll-block__block .sub-title {
  max-width: 682px;
  font-size: 30px;
  text-align: center;
}

.scroll-block__block .button {
  margin-top: 40px;
  max-width: 400px;
  width: 100%;
}

.scroll-block__image {
  position: absolute;
  z-index: -5;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.scroll-block__image::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
}

.scroll-block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.scroll-block__block .wrapper {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: flex-end;
  position: relative;
  z-index: 2;
  height: 100vh;
  padding-top: calc(var(--section-margin) + var(--section-margin));
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
  align-items: center;
}

.blocks-section_how-work {
  padding-top: calc(var(--section-margin) + var(--section-margin));
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.blocks-section_how-work .blocks-section__block {
  width: calc((100% - 60px) / 4);
  min-height: 290px;
}

.blocks-section_how-work {
  color: var(--belyy);
  background: var(--akcent);
}

@media (max-width: 1230px) {
  .blocks-section_how-work .blocks-section__block {
    width: calc((100% - 20px) / 2);
  }
}

@media (max-width: 1024px) {
  .scroll-block__block .sub-title {
    font-size: 24px;
    max-width: 520px;
  }

  .blocks-section_how-work .blocks-section__body {
    flex-wrap: nowrap;
    overflow: auto;
    scroll-snap-type: x mandatory;
  }

  .blocks-section_how-work .blocks-section__body::-webkit-scrollbar {
    display: none;
  }

  .blocks-section_how-work .blocks-section__block {
    width: calc((100% - 50px) / 2.5);

    scroll-snap-align: center;
    flex-shrink: 0;
    min-height: 290px;
  }
}

@media (max-width: 768px) {
  .scroll-block__block .sub-title {
    font-size: 22px;
  }

  .blocks-section_how-work .blocks-section__block {
    width: calc((100% - 30px) / 1.5);
    min-height: 290px;
    padding: 25px;
  }

  .blocks-section_how-work .blocks-section__block-title {
    font-size: 40px;
  }

  .blocks-section_how-work .blocks-section__block p {
    font-size: 16px;
  }
}

@media (max-width: 480px) {
  .scroll-block__block .sub-title {
    font-size: 20px;
  }

  .blocks-section_how-work .blocks-section__block {
    width: calc((100% - 25px) / 1.2);
  }

  .scroll-block__block .button {
    margin-top: 30px;
  }
}
/* ==================================== */

.header {
  position: relative;
  z-index: 50;
  padding: 35px 0px 35px 0px;
  background: var(--asfalt);
  color: var(--belyy);
}

.header__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.header__bottom {
  margin-top: 35px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding-top: 35px;
  border-top: 1px solid rgba(245, 248, 250, 0.2);
}
.catalog-button {
  z-index: 20;
}

.catalog-button__button {
  background: var(--akcent);
  padding: 10px 40px;
  min-height: 60px;
  display: flex;
  align-items: center;
  cursor: pointer;
  justify-content: center;
}

.catalog-button__text {
  display: flex;
  gap: 15px;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  text-align: center;
  color: var(--belyy);
}

.catalog-button__text svg {
  flex-shrink: 0;
  transition: 0.3s ease 0s;
}

.header__bottom-left {
  display: flex;
  align-items: center;
  width: 73%;
  justify-content: space-between;
  gap: 20px;
  position: relative;
}

.catalog-button__drop {
  position: absolute;
  width: 100%;
  left: 0;
  padding-top: 10px;
  opacity: 0;
  transition: 0.3s ease 0s;
  pointer-events: none;
  top: 100%;
}

.catalog-button__drop-body {
  background: var(--belyy);
  display: flex;
  flex-direction: column;
  height: 306px;
  overflow: auto;
  gap: 30px;
  flex-wrap: wrap;
  padding: 30px 40px;
}

.catalog-button__drop-body p {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: -20px;
  color: var(--chernyy);
}

.catalog-button__drop-body a {
  font-weight: 500;
  transition: 0.3s ease 0s;
  font-size: 14px;
  color: var(--chernyy) !important;
  opacity: 0.5;
}

.catalog-button__drop-body ul {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.catalog-button__drop-body a:hover {
  opacity: 1;
}

.header__nav ul {
  display: flex;
  gap: 45px;
}

.header__nav ul a {
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  text-align: center;
  color: var(--belyy);
  transition: 0.3s ease 0s;
}

.header__nav ul a:hover {
  color: var(--theme-color);
}

.button-border_v2 {
  border-color: var(--theme-color);
}

.button-border_v2:hover {
  background-color: var(--theme-color);
  color: var(--belyy);
}

.burger-menu {
  color: var(--asfalt);
}

.burger-menu__top {
  padding: 25px 0px;
  margin-bottom: 20px;
  background: var(--asfalt);
}

.burger-menu__body .wrapper {
  position: relative;
}

.burger-menu__top .wrapper {
  display: flex;
  gap: 15px;
  justify-content: space-between;
}

.burger-menu__top .logo div {
  display: none;
}

.burger-menu__row {
  margin-top: 15px;
}
.burger-menu__row-button {
  padding: 18px 20px;
  background: var(--akcent);
  font-weight: 400;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  font-size: 16px;
  line-height: 150%;
  color: var(--belyy);
  transition: 0.3s ease 0s;
}

.burger-menu__row-button.active {
  border: 1px solid var(--akcent);
  background: none;
}

.burger-menu__row-button.active svg {
  rotate: 0deg;
}
.burger-menu__row-button svg {
  flex-shrink: 0;
  rotate: 180deg;
}

.burger-menu__row-button.active {
  margin-bottom: 15px;
  color: var(--chernyy);
}

.burger-menu__row ul {
  display: none !important;
}

.burger-menu__row-button.active + ul {
  display: flex !important;
}

.burger-menu__menu,
.burger-menu__row ul {
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--asfalt);
  gap: 20px;
}
.burger-menu__menu {
  padding-top: 15px;
}

.burger-menu__bottom {
  padding: 20px 0px;
  margin-top: 20px;
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  left: 0;
  border-top: 1px solid rgba(7, 8, 8, 0.2);
  background: var(--fon);
  bottom: 0;
  width: 100%;
}
.burger-menu__contacts {
  display: flex;
  flex-direction: column;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--chernyy);
}

.intro {
  background: var(--chernyy);
  color: var(--belyy);
  z-index: 10;
  padding-bottom: 105px;
  position: relative;
}

.intro__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  pointer-events: none;
  z-index: -2;

  /* важно: НЕ используем visibility:hidden */
  opacity: 0;
  transition: opacity 0.25s ease;
}
.intro__video.is-ready {
  opacity: 1;
}

/* Кавер перекрывает всё, пока видео не пошло */
.intro__cover {
  z-index: -2;
  position: absolute;
  inset: 0;
  z-index: 1;
  background: var(--chernyy) center/cover no-repeat;
  /* необязательно, но красиво: используем тот же постер */
  /* background-image:url('/assets/videos/video-poster.jpg'); */
  transition: opacity 0.25s ease;
}
.intro__cover.is-hide {
  opacity: 0;
  pointer-events: none;
}
h1 {
  font-weight: 700;
  font-size: 100px;
  line-height: 90%;
  text-transform: uppercase;
  font-family: var(--second-family);
}

.intro__sub-title {
  font-weight: 500;
  font-size: 30px;
  margin-top: 15px;
  line-height: 120%;
}

.intro__buttons {
  display: flex;
  gap: 20px;
  margin-top: 50px;
}

.intro__buttons .button {
  min-height: 80px;
}

.intro__body {
  padding-top: 40px;
  min-height: 634px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.intro {
  position: relative;
}

.intro__buttons {
  max-width: 560px;
  width: 100%;
  display: flex;
  gap: 20px;
}

.intro__buttons .button,
.intro__buttons .button-border {
  width: calc((100% - 20px) / 2);
}

.intro__main {
  max-width: 832px;
}

.intro::before {
  content: "";
  position: absolute;
  z-index: -1;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 263px;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000 100%);
}

.intro .header {
  background: none;
}

@media (hover: hover) {
  .catalog-button:hover .catalog-button__drop {
    opacity: 1;
    pointer-events: all;
  }

  .catalog-button:hover .catalog-button__text svg {
    rotate: 180deg;
  }
}

.catalog-button.active .catalog-button__drop {
  opacity: 1;
  pointer-events: all;
}

.catalog-button.active .catalog-button__text svg {
  rotate: 180deg;
}

@media (min-width: 1024px) {
  .intro__fade::before {
    content: "";
    position: absolute;
    right: 0;
    top: 0;
    width: 30%;
    z-index: -1;
    height: 100%;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, var(--chernyy) 65%);
  }
  .intro__fade::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 30%;
    height: 100%;
    z-index: -1;
    background: linear-gradient(
      270deg,
      rgba(0, 0, 0, 0) 0%,
      var(--chernyy) 65%
    );
  }
}
@media (max-width: 1230px) {
  .intro {
    padding-bottom: 85px;
  }

  h1 {
    font-size: 88px;
  }

  .intro__sub-title {
    font-size: 26px;
  }

  .intro__buttons {
    margin-top: 30px;
  }

  .intro__buttons .button {
    min-height: 80px;
  }

  .intro__body {
    padding-top: 80px;
    min-height: 594px;
  }

  .intro__buttons {
    max-width: 480px;
    gap: 20px;
  }

  .intro__buttons .button,
  .intro__buttons .button-border {
    width: calc((100% - 20px) / 2);
  }

  .intro__main {
    max-width: 682px;
  }

  .intro::before {
    height: 203px;
  }

  .header__top {
    gap: 10px;
  }

  .header__nav ul {
    gap: 20px;
  }
}

@media (max-width: 1024px) {
  .intro {
    padding-bottom: 70px;
  }

  h1 {
    font-size: 70px;
  }

  .intro__sub-title {
    font-size: 22px;
  }

  .intro__buttons .button {
    min-height: 70px;
  }

  .intro__body {
    padding-top: 80px;
    min-height: 494px;
  }

  .intro__buttons {
    max-width: 460px;
    gap: 10px;
  }

  .intro__buttons .button,
  .intro__buttons .button-border {
    width: calc((100% - 10px) / 2);
  }

  .intro__main {
    max-width: 632px;
  }

  .intro::before {
    height: 163px;
  }

  .header {
    padding: 25px 0px;
  }

  .header__bottom {
    display: none;
  }

  .header__top {
    position: relative;
  }

  .header__top .header-telephones {
    margin-left: auto;
  }

  .header__top .adress-header {
    display: none;
  }

  .header__top .mail-header {
    display: none;
  }

  .header__top .search-button {
    display: none;
  }

  .header__top .socials {
    display: none;
  }

  .burger-menu {
    display: block;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    background: var(--fon);
    z-index: 200;
    overflow: auto;
    transition: 0.8s ease 0s;
    translate: 100% 0%;
  }

  .menu-burger {
    padding: 0px 10px;
    display: flex;
    position: relative;
    align-self: center;
    background-color: #ffffff00;
    width: 60px;
    height: 30px;
    margin: 0px -10px;
    z-index: 12;
  }

  .menu-burger span,
  .menu-burger::before,
  .menu-burger::after {
    content: "";
    transition: all 0.4s ease 0s;
    left: 50%;
    translate: -50% 0%;
    position: absolute;
    width: calc(100% - 20px);
    height: 5px;
    background-color: var(--theme-color);
  }

  .menu-burger::before {
    top: 0px;
  }

  .menu-burger::after {
    bottom: 0px;
  }

  .menu-burger span {
    top: calc(50% - 2px);
  }

  body.menu-open .menu-burger span {
    transform: scale(0);
  }

  body.menu-open .menu-burger::before {
    transform: rotate(-45deg);
    top: calc(50% - 3px);
  }

  body.menu-open .menu-burger::after {
    transform: rotate(45deg);
    bottom: calc(50% - 2px);
  }

  body.menu-open .burger-menu {
    translate: 0px 0px;
  }

  .burger-menu {
    display: block;
  }

  .burger-menu::-webkit-scrollbar {
    display: none;
  }
}

@media (max-width: 768px) {
  h1 {
    font-size: 60px;
  }

  .intro__cover.is-hide {
    opacity: 1 !important;
  }

  .intro__cover {
    background: url("../videos/video-poster.jpg") var(--chernyy) center/cover
      no-repeat;
    /* необязательно, но красиво: используем тот же постер */
    /* background-image:url('/assets/videos/video-poster.jpg'); */
    z-index: -1;
    transition: 0.3s ease 0s;
    opacity: 1 !important;
  }

  .intro__video {
    opacity: 0 !important;
    display: none !important;
  }

  .header {
    transition: 0.3s ease 0s;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 500;
  }

  .header.fixed.hidden {
    transform: translateY(-100%);
  }
  .header.fixed {
    transform: translateY(0);
  }

  .header.fixed {
    background: var(--asfalt);
  }

  .intro__main {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
  }

  .intro {
    padding-bottom: 50px;
  }

  .intro__body {
    padding-top: 35px;
    justify-content: flex-start;
    min-height: 610px;
  }

  .intro__buttons {
    max-width: 100%;
    flex-direction: column;
    margin-top: auto;
  }

  .intro__sub-title {
    font-size: 18px;
  }

  .intro__buttons .button,
  .intro__buttons .button-border {
    width: 100%;
    min-height: 60px;
  }

  .scroll-up-container {
    transition: 0.3s ease 0s;
    padding: 15px 60px 15px 60px;
  }

  .scroll-up_v2 ~ .scroll-up-container {
    padding-right: 0px;
  }
  .scroll-up_v2.active ~ .scroll-up-container {
    padding-right: 60px;
  }

  .header__top .header-telephones {
    display: none;
  }

  .burger-menu__top {
    padding: 20px 0px;
  }

  .header__top .logo div {
    display: none;
  }

  .header {
    padding: 20px 0px;
  }
}

@media (max-width: 480px) {
  h1 {
    font-size: 50px;
  }

  .intro__sub-title {
    font-size: 16px;
  }

  .menu-burger {
    width: 50px;
    height: 25px;
  }

  .intro {
    padding-bottom: 40px;
  }

  .burger-menu__top {
    padding: 10px 0px;
  }

  .header__top .catalog-button {
    margin-right: -10px;
  }

  .header {
    padding: 10px 0px;
  }
}
/* ==================================== */

.task {
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}

.task .sub-title {
  max-width: 576px;
}
.task__body {
  margin-top: 50px;
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.task__block {
  transition: 0.3s ease 0s;
  width: calc((100% - 60px) / 4);
}

.task__image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  transition: 0.3s ease 0s;
  height: 100%;
  object-fit: cover;
}

.task__image {
  overflow: hidden;
  padding-top: 100%;
  position: relative;
}
.task__block-text {
  font-weight: 500;
  margin-top: 10px;
  font-size: 20px;
  line-height: 150%;
  transition: 0.3s ease 0s;
  color: var(--chernyy);
}

.task__block-text span {
  opacity: 0.3;
}

.task__bottom {
  margin-top: 50px;
}
.task__bottom .button {
  min-height: 100px;
  font-size: 20px;
}

.task__block:hover .task__block-text {
  color: var(--akcent);
}

.task__block:hover .task__image img {
  scale: 1.1;
}

@media (max-width: 1230px) {
  .task__block-text {
    font-size: 18px;
  }
}

@media (max-width: 1024px) {
  .task__block-text {
    font-size: 16px;
  }

  .task__bottom .button {
    min-height: 80px;
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  .task__body {
    margin-top: 30px;
  }

  .task__bottom .button {
    min-height: 60px;
    font-size: 14px;
  }

  .task__bottom {
    margin-top: 30px;
  }

  .task__block {
    width: calc((100% - 20px) / 2);
  }
}

@media (max-width: 480px) {
  .task__block-text {
    font-size: 14px;
  }

  .task .sub-title br {
    display: none;
  }
}
/* ==================================== */

.recommendations {
  position: relative;
  color: var(--belyy);
  overflow: hidden;
  background: var(--chernyy);
  z-index: 2;
  padding: calc(var(--section-margin) + var(--section-margin)) 0px;
}
.recommendations__bg {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
}

.recommendations__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 1594px;
  opacity: 0.3;
}

.recommendations__buttons {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 50px;
  gap: 10px;
}

.recommendations__btn-tab {
  border-radius: 100px;
}

.recommendations__btn-tab.tab-active {
  background-color: var(--theme-color);
}

.recommendations__tab {
  translate: 0px 20px;
  opacity: 0;
  animation: Up 1s ease 0s forwards;
}

.recommendations__tab-body {
  flex-wrap: wrap;
  display: flex;
  gap: 20px;
  width: 100%;
}

@keyframes Up {
  0% {
    opacity: 0;
    translate: 0px 20px;
  }

  100% {
    opacity: 1;
    translate: 0px 0px;
  }
}

.recommendations__card {
  display: none;
  width: calc((100% - 60px) / 4);
}
.card.d-block {
  display: flex;
  flex-direction: column;
}

.card__body {
  flex-grow: 1;
}

.card .card__swiper {
  max-width: 100%;
}

.recommendations__bottom {
  margin-top: 50px;
}

.recommendations__bottom .button {
  min-height: 100px;
  width: 100%;
  font-size: 20px;
}

.card-slide {
  padding-top: 100%;
  position: relative;
}

.card-slide img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper-pagination {
  justify-content: center;
  display: flex;
  gap: 5px !important;
  padding: 0px 12px;
  left: 0 !important;
  bottom: 5px !important;
}

.swiper-pagination-bullet {
  margin: 0px !important;
  background: var(--fon);
  transition: 0.3s ease 0s;
  height: 7px;
  border-radius: 0px;
  opacity: 1;
  flex-grow: 1;
}

.swiper-pagination-bullet-active {
  background-color: var(--theme-color);
}

.card__body {
  padding: 20px;
  color: var(--chernyy);
  background: var(--belyy);
}

.card__title {
  display: block;
  margin-bottom: 20px;
}

.card__title,
.card__price {
  font-family: var(--second-family);
  font-weight: 700;
  font-size: 30px;
  line-height: 100%;
  color: var(--chernyy);
}

.card__list ul {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.card__list li {
  display: flex;
  justify-content: space-between;
  gap: 5px;
  font-size: 14px;
  line-height: 150%;
  color: var(--chernyy);
}

.card__list li span:first-child {
  opacity: 0.5;
}

.card__price {
  display: flex;
  margin-top: auto;
  padding-top: 20px;
  flex-direction: column;
}
.card .button {
  font-size: 14px;
  min-height: 51px;
}

.card .button:hover {
  color: var(--belyy);
  background-color: var(--akcent);
}

.card__list {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.swiper-button-next {
  right: 0px;
  width: 40px;
  height: 40px;
  transition: 0.3s ease 0s;
  background-color: var(--akcent);
}
.swiper-button-prev {
  transition: 0.3s ease 0s;
  left: 0px;
  width: 40px;
  height: 40px;
  background-color: var(--akcent);
}

.swiper-new {
  padding: 0px 19px;
  width: calc(100% + 38px);
  margin: 0px -19px;
}

.recommendations + .complex {
  padding-top: calc(var(--section-margin) + var(--section-margin));
}

.section {
  padding: var(--section-margin) 0px;
}

.title-tag {
  padding: 5px 20px;
  font-size: 18px;
  color: #fff;
  font-weight: 600;
  display: inline-flex;
  background-color: var(--akcent);
  margin-bottom: 30px;
}

.complex__body {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
  gap: 20px;
}

.complex__block {
  border-left: 4px solid var(--akcent);
  padding: 15px 15px 15px 20px;
  background-color: var(--belyy);
  width: calc((100% - 60px) / 4);
}

.complex__block-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 10px;
}

.complex__block p {
  font-size: 14px;
  line-height: 1.4;
}

.card__swiper {
  width: 100% !important;
}

.swiper-button-next svg {
  rotate: 90deg;
}

.swiper-button-prev svg {
  rotate: -90deg;
}

.card__swiper {
  position: relative;
}

h2 span,
.h2 span {
  color: var(--akcent);
}

.new {
  position: absolute;
  left: 10px;
  z-index: 10;
  top: 10px;
  background-color: var(--akcent);
  padding: 5px 20px;
  font-size: 14px;
}

.garantii__body {
  display: flex;
  gap: 20px;
}

.garantii + .recommendations {
  margin-top: var(--section-margin);
}

.garantii__left,
.garantii__right {
  width: calc((100% - 20px) / 2);
}

.garantii__right {
  position: relative;
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.2);
}

.garantii__blocks {
  display: flex;
  margin-top: 20px;
  flex-direction: column;
  gap: 15px;
}

.garantii__block {
  position: relative;
  padding: 15px 15px 15px 50px;
  background-color: var(--belyy);
}

.garantii__icon {
  position: absolute;
  left: 15px;
  top: 20px;
  background-color: var(--akcent);
  border-radius: 50%;
  color: #fff;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.garantii__block p {
  font-size: 16px;
}

.garantii__block-title {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 5px;
}

.garantii__icon svg {
  width: 50%;
}

.garantii__right-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.garantii__right .title-tag {
  z-index: 5;
  position: absolute;
  right: 15px;
  margin-bottom: 0px;
  bottom: 15px;
}

.garantii h2 {
  padding-right: 10px;
}

.garantii__right-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.garantii__bottom {
  display: flex;
  gap: 15px;
  margin-top: 30px;
  align-items: center;
}

.garantii__bottom span {
  font-size: 14px;
  font-style: italic;
}

@media (max-width: 1230px) {
  .card__title,
  .card__price {
    font-size: 26px;
  }
  .card__list li {
    font-size: 12px;
  }
}

@media (max-width: 1024px) {
  .garantii__body {
    flex-direction: column;
  }

  .garantii__left,
  .garantii__right {
    width: 100%;
  }
  .garantii__right {
    height: 400px;
  }

  .complex__block {
    width: calc((100% - 20px) / 2);
  }

  .recommendations__card {
    width: calc((100% - 40px) / 3);
  }
}

@media (max-width: 768px) {
  .recommendations__card {
    width: calc((100% - 20px) / 2);
  }

  .title-tag {
    padding: 5px 15px;
    font-size: 16px;
    margin-bottom: 20px;
  }

  .card__title,
  .card__price {
    font-size: 22px;
  }

  .card__list li {
    gap: 0px;
    flex-direction: column;
  }

  .card__title {
    margin-bottom: 10px;
  }

  .card__price {
    margin-top: 10px;
  }

  .recommendations__bottom .button {
    min-height: 60px;
    font-size: 16px;
  }

  .recommendations__bottom {
    margin-top: 30px;
  }

  .recommendations__buttons {
    flex-wrap: nowrap;
    margin-bottom: 30px;
    overflow: auto;
    scroll-snap-type: x mandatory;
  }
  .recommendations__buttons::-webkit-scrollbar {
    display: none;
  }

  .recommendations__btn-tab {
    scroll-snap-align: center;
  }

  .recommendations__btn-tab {
    flex-shrink: 0;
    min-height: 58px;
    padding: 0px 20px;
    font-size: 14px;
  }

  .recommendations h2 {
    margin-bottom: 10px;
  }
}

@media (max-width: 480px) {
  .card__title,
  .card__price {
    font-size: 18px;
  }

  .garantii__block-title {
    font-size: 16px;
  }

  .garantii__block p {
    font-size: 14px;
  }

  .garantii__icon {
    left: 15px;
    top: 18px;
    width: 20px;
    height: 20px;
  }

  .garantii__right {
    height: 320px;
  }

  .garantii__block {
    padding: 15px 15px 15px 45px;
  }

  .garantii__bottom .button {
    width: 100%;
  }

  .garantii__bottom {
    flex-direction: column;
    align-items: center;
  }

  .complex__block {
    width: 100%;
  }

  .title-tag {
    padding: 5px 12px;
    font-size: 14px;
  }

  .complex__body {
    gap: 10px;
    margin-top: 20px;
  }

  .swiper-button-next {
    right: 10px;
    width: 40px;
    height: 40px;
  }
  .swiper-button-prev {
    left: 10px;
    width: 40px;
    height: 40px;
  }

  .swiper-new .swiper-button-prev {
    top: 25%;
  }

  .swiper-new .swiper-button-next {
    top: 25%;
  }

  .recommendations__btn-tab {
    min-height: 48px;
    font-size: 12px;
  }

  .card__body {
    padding: 10px;
  }

  .swiper-pagination {
    padding: 0px 10px;
  }

  .swiper-pagination-bullet {
    height: 3px;
  }

  .card .button {
    font-size: 12px;
    min-height: 40px;
  }
}
/* ==================================== */

.modal__title {
  font-family: var(--second-family);
  font-weight: 700;
  font-size: 40px;
  line-height: 100%;
  margin-bottom: 22px;
  padding-right: 78px;
}
.modal__sub-title {
  padding-right: 20px;
  font-size: 20px;
  line-height: 150%;
  margin-bottom: 50px;
}

.breadcrumbs {
  padding: 50px 0px;
}

.breadcrumbs ul {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.breadcrumbs a {
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  transition: 0.3s ease 0s;
  text-align: center;
  color: var(--chernyy);
}

.breadcrumbs li:not(:last-child)::after {
  content: "/";
}

.breadcrumbs li a:hover {
  color: var(--theme-color);
}

.breadcrumbs li:last-child a {
  color: var(--theme-color);
  pointer-events: none;
}

.breadcrumbs__link {
  display: none;
}

.task__sub-title {
  font-family: var(--second-family);
  font-weight: 700;
  font-size: 40px;
  line-height: 100%;
  color: var(--chernyy);
}

.task_v2 h1 {
  margin-bottom: 50px;
}

.task_v2 .task__body {
  margin-top: 20px;
}

.task_v2 .task__body:not(:last-child) {
  margin-bottom: calc(var(--section-margin) + var(--section-margin));
}

.task__footer {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 907px;
  gap: 30px;
}

.task__footer .button {
  min-height: 50px;
}

.task__footer .button:hover {
  color: var(--belyy);
  background-color: var(--theme-color);
}

.modal-search .modal__body {
  margin-top: 15px;
  max-width: 100%;
  background: none;
  border-radius: none;
  padding: 0px;
}

.modal-search-body {
  width: 100%;
  margin-top: 50px;
  padding: 0px 50px;
  color: var(--asfalt);
}

.modal-search-body input {
  min-height: 65px;
  background-color: #fff;
  width: 100%;
  padding: 15px 20px;
}

.modal-search #ajax-search-results {
  margin-top: 20px;
}

.modal-search #ajax-search-results ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.modal-search #ajax-search-results li {
  width: calc((100% - 20px) / 2);
}

.modal-search #ajax-search-results li a {
  background-color: var(--theme-color);
  transition: 0.2s ease 0s;
  padding: 20px 50px 20px 30px;
  font-size: 18px;
  display: flex;
  width: 100%;
  position: relative;
}

.modal-search #ajax-search-results li a:hover {
  background-color: var(--sec-purple-1);
}

.modal-search #ajax-search-results li a::after {
  position: absolute;
  right: 30px;
  top: 22px;
  content: "";
  width: 20px;
  height: 20px;
  background: url(../img/icons/arrow-weblnk2.svg) center / contain no-repeat;
}

.modal-search .modal-close {
  right: 0;
  top: 0;
}

@media (max-width: 1024px) {
  .task__footer br {
    display: none;
  }
}
@media (max-width: 768px) {
  .breadcrumbs ul {
    display: none;
  }

  .modal-search #ajax-search-results {
    margin-top: 10px;
  }

  .modal-search #ajax-search-results ul {
    gap: 10px;
  }

  .modal-search #ajax-search-results li {
    width: calc((100% - 10px) / 2);
    min-width: 260px;
    flex-grow: 1;
  }

  .modal-search #ajax-search-results li a {
    padding: 10px 35px 10px 20px;
    font-size: 15px;
  }

  .modal-search #ajax-search-results li a:hover {
    background-color: var(--sec-purple-1);
  }

  .modal-search #ajax-search-results li a::after {
    position: absolute;
    right: 15px;
    top: 14px;
    width: 14px;
    height: 14px;
  }

  .modal-search-body {
    margin-top: 40px;
    padding: 0px 15px;
  }

  .modal-search-body input {
    min-height: 55px;
  }

  .task__bottom.mob-tel {
    display: flex;
    margin-bottom: var(--section-margin);
  }

  .task__bottom .button {
    width: 100%;
  }

  .task__footer .button {
    width: 100%;
  }

  .task__footer {
    padding-top: var(--section-margin);
  }

  .breadcrumbs__link {
    display: flex;
    gap: 15px;
    align-items: center;
    font-size: 14px;
    line-height: 150%;
    text-align: center;
    color: var(--chernyy);
  }

  .breadcrumbs {
    padding: 40px 0px;
  }

  .modal__title {
    text-align: center;
    margin-bottom: 10px;
    padding-right: 0px;
  }
  .modal__sub-title {
    font-size: 16px;
    padding-right: 0px;
    text-align: center;
    margin-bottom: 30px;
  }

  .modal__body {
    padding: 70px 20px 40px 20px;
  }

  .modal-close {
    right: 10px;
    top: 10px;
  }

  .mob-none {
    display: none !important;
  }

  .scroll-up-container.mob-tel {
    display: flex !important;
  }

  .task__sub-title {
    font-size: 28px;
  }

  .task_v2 h1 {
    margin-bottom: 40px;
  }
}

@media (max-width: 480px) {
  .task__sub-title {
    font-size: 18px;
  }

  .modal-search-body input {
    min-height: 45px;
    font-size: 14px;
    padding: 10px;
  }
}
/* ==================================== */

.privacy-policy {
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.privacy-policy .privacy-policy {
  overflow: hidden;
}

.privacy-policy h1 {
  margin-bottom: 30px;
}

.h1-small {
  font-size: 70px;
}

.privacy-policy p:not(:last-child) {
  margin-bottom: 10px;
}

.privacy-policy p + h3 {
  margin-top: 30px;
}

.privacy-policy h1 + p {
  margin-bottom: 30px;
}

h3,
.h3,
.news-single_v2 h2 {
  font-family: var(--second-family);
  font-weight: 700;
  margin-bottom: 10px;
  font-size: 40px;
  line-height: 100%;
  color: var(--chernyy);
}

.intro.intro_spasibo {
  padding-top: 80px;
  padding-bottom: 80px;
  background: none !important;
  color: var(--chernyy);
}

.intro_spasibo .intro__sub-title {
  max-width: 789px;
}

.intro_spasibo .button-border {
  border-color: var(--chernyy);
  color: var(--chernyy);
}

.intro_spasibo .button-border:hover {
  background-color: var(--akcent);
  color: var(--belyy);
  border-color: var(--akcent);
}

.intro_spasibo::before {
  display: none !important;
}

.news-single a {
  color: var(--theme-color);
}

.news-single__body {
  position: relative;
  align-items: flex-start;
  display: flex;
  overflow: hidden;
  gap: 50px;
}

.news-single__right * {
  margin-top: 20px;
}

.news-single__right *:first-child {
  margin-top: 0px;
}

.news-single__form {
  color: #fff;
  margin-top: 30px;
  padding: 30px;
  background-color: var(--theme-color);
}

.news-single__form .checkbox a {
  color: #fff;
}

.news-single__left {
  /* position: sticky;
	top: 10px; */
  max-width: 600px;
  width: 100%;
}

.news-single .news-single-swiper .swiper-slide {
  padding-top: 80%;
  position: relative;
}

.news-single .news-single-swiper .swiper-pagination {
  display: none;
}

.news-single .swiper-thumbs .swiper-slide img {
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  object-fit: cover;
  height: 100%;
}

.news-single__right {
  flex-shrink: 0;
  max-width: 570px;
}

.news-single .swiper-thumbs {
  margin-top: 20px;
}

.news-single .swiper-thumbs .swiper-slide {
  padding-top: 18%;
  cursor: pointer;
  position: relative;
}

.news-single .news-single-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  object-fit: cover;
  top: 0;
}

@media (max-width: 1230px) {
  .news-single__left {
    max-width: 442px;
  }

  .news-single__right {
    max-width: 500px;
  }
}

@media (max-width: 1024px) {
  .news-single__left {
    max-width: 350px;
  }

  .news-single__form {
    margin-top: 20px;
    padding: 20px;
  }

  .news-single__body {
    gap: 30px;
    justify-content: space-between;
  }

  .news-single__right {
    max-width: 100%;
    flex-grow: 1;
    flex-shrink: 1;
  }

  .intro.intro_spasibo {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .intro_spasibo .intro__buttons {
    max-width: 480px;
  }

  .intro_spasibo .intro__sub-title {
    max-width: 559px;
  }

  .h1-small {
    font-size: 60px;
  }
}

@media (max-width: 768px) {
  h3,
  .h3,
  .news-single_v2 h3 {
    font-size: 35px;
  }

  .news-single__left {
    position: static;
  }

  .news-single__body {
    flex-direction: column;
  }

  .news-single__left {
    max-width: 100%;
    width: 100%;
  }

  .news-single__left .swiper {
    width: 100%;
  }

  .news-single .wrapper {
    display: flex;
    flex-direction: column;
  }

  .news-single h1 {
    order: -2;
  }

  .news-single__banner {
    order: -1;
  }

  .news-single h1 {
    margin-bottom: 40px;
  }

  .news-single__banner {
    margin-bottom: 40px;
  }

  .h1-small {
    font-size: 50px;
  }

  .intro_spasibo .intro__buttons {
    max-width: 100%;
    margin-top: 30px;
  }

  .intro_spasibo.intro {
    padding-top: 0px;
    padding-bottom: 40px;
  }
}

@media (max-width: 480px) {
  .h1-small {
    font-size: 40px;
  }

  h3,
  .h3,
  .news-single_v2 h3 {
    font-size: 30px;
  }
}
/* ==================================== */

.prices {
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.prices__text {
  padding-top: var(--section-margin);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 30px;
  margin-bottom: var(--section-margin);
}

.prices__text p {
  max-width: 842px;
}

.button {
}
.prices__text .button_black {
  min-height: 50px;
  padding: 10px 55px;
}

.prices__text .button_black:hover {
  background-color: var(--akcent);
  color: var(--belyy);
}

.prices__table-wrap {
}
.prices__table-top {
  font-family: var(--second-family);
  font-weight: 700;
  font-size: 40px;
  background: var(--akcent);
  min-height: 90px;
  padding: 10px 30px;
  display: flex;
  align-items: center;
  line-height: 100%;
  color: var(--belyy);
}
.prices__table {
  font-size: 12px;
  line-height: 150%;
  border-spacing: 0px;
}

table [data-show-el] {
  display: none;
}

.prices__bottom {
  margin-top: 30px;
}

.prices__bottom .button {
  min-width: 250px;
}

table [data-show-el].d-block {
  display: table-row;
}

.prices__table th,
.prices__table td {
  height: 38px;
  font-weight: 400;
  text-align: center;
  padding: 10px 2px;
  table-layout: auto; /* важное отличие */
}

.prices__table th:first-child,
.prices__table td:first-child {
  width: 30%;
  text-align: center;
}

.prices__table tbody td:first-child {
  text-align: left;
}

.prices__table thead tr:first-child th {
  background: var(--asfalt);
  height: 50px;
  color: var(--belyy);
  width: 16.6%;
  padding: 10px 10px;
  text-align: left;
}
.prices__table thead tr:first-child th:first-child {
  padding: 10px 19px;
}

.prices__table thead tr:last-child th {
  background: #e3e7eb;
}

.prices__table tbody td:first-child {
  padding: 10px 19px;
}

.prices__table tbody tr:nth-child(even) td {
  background: #e3e7eb;
}

.prices__swiper {
  display: none;
}

.menu-open .scroll-up {
  display: none;
}

[data-show-el].prices__table-wrap {
  display: none;
}
[data-show-el].prices__table-wrap.d-block {
  display: block;
}

@media (max-width: 1230px) {
  .prices__table th:first-child,
  .prices__table td:first-child {
    width: 20%;
  }
}

@media (max-width: 1024px) {
  .prices__table-top {
    font-size: 30px;
    min-height: 70px;
    padding: 10px 30px;
  }
}

@media (max-width: 768px) {
  .prices__tables {
    overflow: hidden;
  }

  .prices__table {
    min-width: 900px;
  }

  .prices__table-wrap {
    overflow: auto;
  }

  .prices__table-wrap::-webkit-scrollbar {
    display: none;
  }

  .prices__swiper {
    display: block;
  }
  .prices__table-top {
    min-width: 900px;
  }

  .prices__text {
    gap: 20px;
  }

  .prices__text p {
    max-width: 350px;
  }

  .prices__table-wrap:first-child {
    padding-top: var(--section-margin);
  }

  .prices .card__title {
    background: var(--asfalt);
    color: var(--belyy);
    min-height: 82px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-family: var(--font-family);
    font-weight: 500;
    font-size: 14px;
    padding: 10px 40px;
    line-height: 150%;
    text-align: center;
    margin-bottom: 0px;
  }

  .prices .card__section {
    padding: 20px;
    background: #fff;
  }

  .prices .card__section + .card__section {
    padding-top: 0px;
    margin-top: -5px;
  }

  .prices .card__section-title {
    font-weight: 700;
    font-size: 16px;
    line-height: 150%;
    color: var(--chernyy);
    margin-bottom: 10px;
  }

  .prices .card__list {
    gap: 0px;
  }

  .prices .card__list li {
    flex-direction: row;
    gap: 5px;
    font-weight: 500;
  }

  .prices__swiper .swiper-button-next,
  .prices__swiper .swiper-button-prev {
    top: 27px;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    color: var(--belyy);
    justify-content: center;
    translate: 0px 0px;
  }

  .prices__swiper .swiper-button-prev {
    rotate: 180deg;
  }

  .prices .card__list li b {
    font-weight: 500;
  }

  .prices .card__list li span,
  .prices .card__list li b {
    width: calc((100% - 5px) / 2);
  }
}

/* ==================================== */

.mini-intro {
  padding-bottom: var(--section-margin);
}
.mini-intro .sub-title {
  margin-top: 30px;
}

.vakansii {
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.vakansii__section:not(:last-child) {
  margin-bottom: var(--section-margin);
}

.vakansii__main {
  padding: 40px;
  background: var(--belyy);
}
.vakansii__columns {
  margin-top: 30px;
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.vakansii__column {
  width: calc((100% - 60px) / 4);
}

.vakansii__column ul {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
  color: var(--chernyy);
}

.vakansii__column:last-child h5 {
  color: var(--theme-color);
}

h5 {
  font-weight: 700;
  font-size: 20px;
  line-height: 150%;
  margin-bottom: 15px;
  color: var(--chernyy);
}

.vakansii__bottom {
  margin-top: 20px;
  display: flex;
}
.vakansii__bottom .button {
  width: 100%;
  min-height: 100px;
  font-size: 20px;
}

.reviews_v2 {
  padding-top: 0px;
}

.reviews_v2 .reviews__body {
  margin-top: 0px;
}

[data-show-more] .reviews__block {
  display: none;
}

[data-show-el] {
  animation: Up 1s ease 0s forwards;
}

[data-show-more] .reviews__block.d-block {
  display: block;
}

@media (max-width: 1024px) {
  .vakansii__column {
    width: calc((100% - 20px) / 2);
  }

  .vakansii__bottom .button {
    min-height: 80px;
    font-size: 18px;
  }
}

@media (max-width: 768px) {
  .vakansii__bottom .button {
    min-height: 70px;
    font-size: 16px;
  }

  .vakansii__column ul {
    font-size: 14px;
  }

  .vakansii__section:not(:last-child) {
    margin-bottom: 40px;
  }
}

@media (max-width: 480px) {
  .vakansii__bottom .button {
    min-height: 60px;
    font-size: 14px;
  }

  .vakansii .wrapper {
    width: 100%;
  }

  .vakansii__bottom {
    padding: 0px 15px;
  }

  .vakansii__main {
    padding: 30px 20px;
  }

  .vakansii__column ul {
    font-size: 12px;
  }

  h5 {
    margin-bottom: 10px;
  }
}
/* ==================================== */

.news {
  margin-top: -10px;
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.news__section:not(:last-child) {
  margin-bottom: 80px;
}

.news__button {
  margin-top: 30px;
  font-size: 20px;
  min-height: 100px;
  width: 100%;
}

.news__body {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding-top: 10px;
}

.news__body .card {
  width: calc((100% - 60px) / 4);
}

.news__block {
  background: var(--belyy);
  min-height: 475px;
  display: flex;
  flex-direction: column;
  width: calc((100% - 40px) / 3);
}

[data-show-el].news__block {
  display: none;
}

[data-show-el].news__block.d-block {
  display: flex;
}

.news__block-body {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: 20px;
}

.news__block.d-block {
  display: flex;
  flex-direction: column;
}

.news__block-image {
  position: relative;
  padding-top: 70%;
}

[data-fancybox] .news__block-image img {
  filter: grayscale(100%) contrast(90%) brightness(50%);
}

[data-show-el].news__block:hover .news__block-image img {
  filter: grayscale(0%);
}

.news__block-image svg {
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
}

.news__block:hover .news__block-title {
  text-decoration: underline;
  text-decoration-skip-ink: none;
  color: var(--akcent);
}

.news__block-image {
  color: #6d0000;
}
.news__block-image svg path {
  transition: 0.3s ease 0s;
}

.news__block-image svg {
  transition: 0.3s ease 0s;
}

.news__block-image svg path {
  fill: #878a8c;
}

[data-show-el].news__block:hover .news__block-image {
  color: var(--akcent);
}

[data-show-el].news__block:hover .news__block-image svg path {
  fill: var(--belyy);
}

.news__block-image img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  transition: 0.3s ease 0s;
  object-fit: cover;
}

.news__block-title {
  font-weight: 500;
  font-size: 20px;
  transition: 0.3s ease 0s;
  margin-bottom: 10px;
  line-height: 150%;
}
.news__block-text {
  font-weight: 500;
  font-size: 14px;
  max-width: 284px;
  line-height: 150%;
}
.news__block-data {
  font-weight: 500;
  font-size: 14px;
  padding-top: 10px;
  line-height: 150%;
  color: var(--chernyy);
  opacity: 0.5;
  margin-top: auto;
}

.news-single {
  padding-bottom: var(--section-margin);
}

.news-single__banner {
  width: 100%;
  height: 415px;
  margin-bottom: 30px;
}

.news-single__banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-single h1 {
  margin-bottom: 30px;
}

.news-single p {
  font-size: 16px;
  line-height: 150%;
}

.news-single p ~ p,
.news-single ul {
  margin-top: 10px;
}

.news-single img {
  margin-bottom: 10px;
}

.news-single .wp-block-columns {
  margin-top: 10px;
}

.news-single__content * {
  margin-top: 10px;
}

.news-single ul li {
  margin-top: 5px;
}

.news-single ul {
  padding-left: 20px;
}

.news-single ol {
  padding-left: 20px;
}

.news-single ul li {
  list-style: disc;
}

.news-single p + h3,
.news-single p + h2 {
  margin-top: 30px;
}

.about-section {
  overflow: hidden;
  padding: 0px 0px var(--section-margin) 0px;
}

.about-section__body {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 55px;
}
.about-section__text {
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
}

.about-section__text p:not(:last-child) {
  margin-bottom: 10px;
}

.about-section__image {
  max-width: 600px;
  width: 100%;
  flex-shrink: 0;
}

.about-section__image img {
  width: 100%;
  object-fit: cover;
}

.news__button.button {
  min-height: 100px;
}

@media (max-width: 1230px) {
  .news__section:not(:last-child) {
    margin-bottom: 70px;
  }

  .news__button.button {
    min-height: 90px;
  }

  .about-section__image {
    max-width: 460px;
  }

  .about-section__body {
    gap: 30px;
  }
}

@media (max-width: 1024px) {
  .news__section:not(:last-child) {
    margin-bottom: 60px;
  }

  .news__button.button {
    min-height: 80px;
  }

  .about-section__image {
    max-width: 100%;
  }

  .about-section__body {
    flex-direction: column;
  }

  .news__button {
    font-size: 18px;
    min-height: 80px;
  }

  .news__body .card {
    width: calc((100% - 40px) / 3);
  }
}

@media (max-width: 768px) {
  .news__button {
    font-size: 14px;
    min-height: 60px;
  }

  .news__button.button {
    min-height: 60px;
  }

  .news-single__banner {
    height: 400px;
  }

  .news {
    margin-top: 0px;
  }

  .news__block,
  .news__body .card {
    width: calc((100% - 20px) / 2);
  }

  .news__section:not(:last-child) .wrapper {
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(7, 8, 8, 0.2);
  }

  .news__section:not(:last-child) {
    margin-bottom: 40px;
  }

  .header-padding-top {
    padding-top: 100px;
  }
}

@media (max-width: 480px) {
  .news__block {
    width: 100%;
  }

  .news__button.button {
    min-height: 50px;
  }

  .header-padding-top {
    padding-top: 80px;
  }

  .news-single__banner {
    height: 350px;
  }
}
/* ==================================== */

.catalog-single {
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.catalog-single .h1-small {
  margin-bottom: 30px;
}

.catalog-single .recommendations__bottom {
  margin-top: 30px;
}

.catalog-single__tags {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
  gap: 10px;
  margin-bottom: var(--section-margin);
}
.catalog-single__tag {
  min-height: 50px;
  font-weight: 500;
  font-size: 14px;
  line-height: 150%;
  min-height: 50px;
  display: flex;
  transition: 0.3s ease 0s;
  align-items: center;
  justify-content: center;
  text-align: center;
  border: 1px solid var(--akcent);
  border-radius: 100px;
  padding: 10px 30px;
  color: var(--chernyy);
}

.catalog-single__tag.active,
.catalog-single__tag:hover {
  background-color: var(--akcent);
  color: var(--belyy);
}

.filter-button {
  display: none;
}
.catalog-single .recommendations {
  padding-top: 0px;
  /* max-width: 910px; */
}

.catalog-single .recommendations {
  width: 100%;
}

.catalog-single__body {
  display: flex;
  gap: 20px;
  justify-content: space-between;
  align-items: flex-start;
}

/* .catalog-single .card {
  width: calc((100% - 40px) / 3);
} */

.burger-filter {
  flex-shrink: 0;
  max-width: 245px;
}
.burger-filter__top {
  display: none;
}

.burger-filter__body {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.burger-filter__section {
}
.burger-filter__title {
  font-weight: 700;
  margin-bottom: 20px;
  font-size: 20px;
  line-height: 150%;
}

.burger-filter__title svg {
  display: none;
}

.burger-filter__checkboxes {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 12px;
}
.checkbox-custom {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  font-weight: 400;
  font-size: 16px;
  line-height: 150%;
}

.checkbox-custom span {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.checkbox-custom span::before {
  content: "";
  align-self: center;
  width: 20px;
  border: 1px solid var(--chernyy);
  flex-shrink: 0;
  height: 20px;
  transition: 0.3s ease 0s;
}

.checkbox-custom input:checked + span::before {
  border-color: var(--akcent);
  color: var(--belyy);
  background: var(--akcent) url(../img/icons/checkbox-icon.svg) center / 10px
    10px no-repeat;
}

.checkbox-custom input {
  display: none;
}

.catalog-single .recommendations {
  background: none;
}

.catalog-single .recommendations__bottom .button-border {
  width: 100%;
  max-width: 100%;
}

.catalog-single .recommendations__bottom .button-border {
  color: var(--chernyy);
  min-height: 51px;
}

.catalog-single .recommendations__bottom .button-border:hover {
  color: var(--belyy);
}

.catalog-single .recommendations {
  padding-bottom: 0px;
}

.burger-filter .wrapper {
  width: 100%;
}

.burger-filter__nav {
  display: none;
}

.burger-filter__top .modal-close {
  position: relative;
  right: 0;
  top: 0;
}

.burger-filter__top .modal-close::after,
.burger-filter__top .modal-close::before {
  background-color: var(--akcent);
}

.burger-filter__top .button {
  margin-right: -10px;
}

.text-section {
  font-weight: 500;
  font-size: 20px;
  line-height: 150%;
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.text-section ul,
.text-section ol {
  padding-left: 22px;
}

.text-section h3 {
  margin-bottom: 20px;
}

.text-section p + h3,
.text-section ul + h3,
.text-section ol + h3 {
  margin-top: 50px;
}

.text-section ul li {
  list-style: disc;
}

.tel-icon {
  display: none;
}

@media (max-width: 1024px) {
  .burger-filter {
    position: fixed;
    top: 0;
    right: 0;
    translate: 100% 0%;
    width: 100%;
    height: 100%;
    max-width: 100%;
    transition: 0.8s ease 0s;
    overflow: auto;
    z-index: 200;
    background-color: #fff;
  }

  .text-section {
    font-size: 18px;
  }

  .burger-filter__button {
    min-height: 80px;
  }

  .burger-filter__nav {
    display: flex;
    justify-content: space-between;
    gap: 10px;
  }

  .burger-filter__close {
    display: flex;
    gap: 15px;
    align-items: center;
    font-weight: 500;
    font-size: 14px;
    line-height: 150%;
  }

  .burger-filter__reset {
    font-weight: 500;
    font-size: 14px;
    line-height: 150%;
    text-align: center;
    color: var(--akcent);
  }

  .burger-filter__title {
    font-weight: 400;
    font-size: 16px;
    background: var(--asfalt);
    line-height: 150%;
    color: var(--belyy);
    padding: 18px 20px;
    margin-bottom: 15px;
    display: flex;
    justify-content: space-between;
  }

  .burger-filter__title svg {
    flex-shrink: 0;
    display: block;
  }

  .burger-filter__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--asfalt);
    padding: 25px 15px;
  }

  .burger-filter__body {
    padding: 40px 15px 20px 15px;
  }

  .burger-filter__top .logo {
    max-width: 40px;
    width: 100%;
  }

  .burger-filter__top .logo div {
    display: none;
  }

  .menu-open-filter {
    overflow: hidden;
  }

  .menu-open-filter .burger-filter {
    translate: 0px 0px;
  }

  .catalog-single__tags {
    overflow: visible;
    overflow: auto;
    flex-wrap: nowrap;
    scroll-snap-type: x mandatory;
  }

  .catalog-single .wrapper-padding::-webkit-scrollbar {
    display: none;
  }

  .catalog-single__tag {
    flex-shrink: 0;
    scroll-snap-align: center;
  }

  .catalog-single .wrapper-padding {
    overflow: visible;
    overflow: auto;
    flex-wrap: nowrap;
  }

  .filter-button {
    display: flex;
    margin-bottom: 30px;
    max-width: 157px;
    margin-left: auto;
    font-weight: 500;
    font-size: 14px;
    line-height: 150%;
    color: var(--chernyy);
    gap: 10px;
  }

  .filter-button div {
    display: flex;
    align-items: center;
    gap: 5px;
  }

  .filter-button div span {
    color: var(--akcent);
  }

  .burger-filter__body {
    gap: 15px;
  }

  .burger-filter__title + .burger-filter__checkboxes {
    display: none;
  }

  .burger-filter__title {
    margin-bottom: 0px;
  }

  .burger-filter__title.active svg {
    rotate: 180deg;
  }

  .burger-filter__title.active + .burger-filter__checkboxes {
    display: flex;
    margin-top: 15px;
  }

  .burger-filter__nav {
    margin-bottom: 20px;
  }
}

@media (max-width: 768px) {
  .catalog-single .card {
    width: calc((100% - 20px) / 2);
  }
  .tel-icon {
    display: flex;
    color: var(--akcent);
    margin-left: auto;
    margin-right: 10px;
    width: 30px;
    height: 30px;
    flex-shrink: 0;
  }

  .tel-icon svg {
    width: 100%;
  }

  .catalog-button {
    translate: 30px 0px;
    margin-left: auto;
  }

  .catalog-single .h1-small {
    margin-bottom: 20px;
  }

  .catalog-single__tags {
    margin-bottom: 30px !important;
  }

  .text-section {
    font-weight: 400;
    font-size: 16px;
  }

  .text-section p + h3,
  .text-section ul + h3,
  .text-section ol + h3 {
    margin-top: 30px;
  }

  .text-section h3 {
    margin-bottom: 10px;
  }

  .burger-filter__top {
    padding: 20px 15px;
  }
}

@media (max-width: 480px) {
  .burger-filter__top {
    padding: 10px 15px;
  }

  .tel-icon {
    margin-right: 5px;
    width: 24px;
    height: 24px;
  }

  .catalog-button {
    translate: 12px 0px;
  }

  .catalog-button .catalog-button__button {
    padding: 10px 15px;
    min-height: 50px;
  }
  .catalog-button .catalog-button__text {
    font-size: 14px;
  }

  .modal-cookie ~ .scroll-up,
  .modal-cookie ~ .scroll-up-container {
    bottom: 180px;
    padding-bottom: 0px;
  }
}

.portfolio-page {
  padding-bottom: calc(var(--section-margin) + var(--section-margin));
}

.text-top {
  padding-bottom: var(--section-margin);
  font-size: 18px;
  line-height: 1.4;
}

.portfolio-page__body {
  display: flex;
  gap: 30px;
  flex-wrap: wrap;
}

.portfolio-page__block-body {
  flex-direction: column;
  align-items: center;
  display: flex;
  justify-content: center;
}

.portfolio-page__block {
  height: 300px;
  position: relative;
  z-index: 1;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: calc((100% - 90px) / 4);
}

.portfolio-page__block::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.4;
  background-color: #000;
  transition: 0.3s ease 0s;
}

.portfolio-page__block:hover::before {
  opacity: 0.6;
}

.portfolio-page__block:hover .portfolio-page__block-icon {
  opacity: 1;
}

.portfolio-page__block-icon {
  opacity: 0;
  margin-top: -55px;
  margin-bottom: 30px;
  transition: opacity 0.3s ease 0s;
}

.portfolio-page__block-text {
  color: #fff;
  text-align: center;
  font-weight: 500;
  font-size: 18px;
}

.portfolio-page__block .portfolio-page__poster {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: -2;
  height: 100%;
  object-fit: cover;
}

.portfolio-page__block-body {
  position: relative;
  z-index: 1;
}

.text-section * {
  margin-bottom: 15px;
}

/* ==================================== */

@media (max-width: 1230px) {
  .portfolio-page__body {
    gap: 20px;
  }

  .portfolio-page__block {
    height: 240px;
    padding: 20px;
    width: calc((100% - 60px) / 4);
  }

  .portfolio-page__block-icon {
    margin-top: -45px;
    margin-bottom: 20px;
  }

  .portfolio-page__block-text {
    font-size: 16px;
  }
}

@media (max-width: 1024px) {
  .portfolio-page__block {
    width: calc((100% - 40px) / 3);
  }

  .text-top {
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  .portfolio-page__block {
    width: calc((100% - 20px) / 2);
  }

  .text-top {
    font-size: 14px;
  }

  .portfolio-page__block-icon {
    width: 25px;
  }

  .portfolio-page__block-text {
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .portfolio-page__block {
    height: 200px;
  }
}

/* ==================================== */

.tabs-content {
  display: none;
}

.d-block {
  display: block;
}

.none {
  display: none;
}

[class*="copyrights-pane"] {
  display: none !important;
}

.animate__animated,
.animate__ {
  opacity: 0;
  animation-fill-mode: forwards !important;
  animation-delay: 0.2s !important;
}

.animate__delay-1s {
  animation-delay: 0.8s !important;
}

.animate__delay-2s {
  animation-delay: 1.2s !important;
}

.animate__delay-2s.button {
  animation-delay: 1.4s !important;
}

.intro__main {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.intro__buttons {
  margin-top: auto;
}

.intro__bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

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