:root {
  --color-white: #fff;
  --color-black: #000;
  --color-title: #222121;
  --color-sub: #888;
  --color-accent-main: #EC6446;
  --color-accent-add: #6BB899;
  --bg-sections: #004045;
  --bg: #F5F5F5;
  --border-color: #E8E8E8;
  --title-font: "Aeonik Pro", sans-serif;
  --title-weight: 500;
  --text-font: "Manrope", sans-serif;
  --text: 1.6rem/1.5;
  --big-fz: 13rem;
  --big-lh: 0.85;
  --title-fz-1: 8.8rem;
  --title-lh-1: .8;
  --title-fz-2: 6rem;
  --title-lh-2: .95;
  --title-fz-3: 3rem;
  --title-lh-3: 1.2;
  --title-fz-4: 2.2rem;
  --title-lh-4: 1.3;
  --title-fz-5: 1.8rem;
  --title-lh-5: 1.6;
  --mob-border-color: #2F3841;
  --mob-block-bg: rgba(255, 255, 255, 0.04);
}

/* -------------------------------------
 * Font face
 * ------------------------------------- */
@font-face {
  font-family: "Manrope";
  src: url("../fonts/Manrope-Regular.woff2") format("woff2"), url("../fonts/Manrope-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@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-SemiBold.woff2") format("woff2"), url("../fonts/Manrope-SemiBold.woff") format("woff");
  font-weight: 600;
  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: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Aeonik Pro";
  src: url("../fonts/Aeonik Pro Regular.woff2") format("woff2"), url("../fonts/Aeonik Pro Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Aeonik Pro";
  src: url("../fonts/Aeonik Pro Medium.woff2") format("woff2"), url("../fonts/Aeonik Pro Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
/* -------------------------------------
 * Libs
 * ------------------------------------- */
/* ----- swiper slider ----- */
/**
 * Swiper 8.4.7
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: January 30, 2023
 */
@font-face {
  font-family: "swiper-icons";
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color: #007aff;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  -o-transition-property: transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

.swiper-android .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translate3d(0px, 0, 0);
          transform: translate3d(0px, 0, 0);
}

.swiper-pointer-events {
  -ms-touch-action: pan-y;
      touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
  -ms-touch-action: pan-x;
      touch-action: pan-x;
}

.swiper-slide {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  -o-transition-property: transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  -o-transition-property: transform, height;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform;
}

.swiper-backface-hidden .swiper-slide {
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/* 3D Effects */
.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
  -webkit-perspective: 1200px;
          perspective: 1200px;
}

.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0)));
  background-image: -o-linear-gradient(top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: x mandatory;
      scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: y mandatory;
      scroll-snap-type: y mandatory;
}

.swiper-centered > .swiper-wrapper::before {
  content: "";
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-box-ordinal-group: 10000;
      -ms-flex-order: 9999;
          order: 9999;
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-start: var(--swiper-centered-offset-before);
          margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-before: var(--swiper-centered-offset-before);
          margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}

.swiper-button-prev,
.swiper-button-next {
  position: absolute;
  top: 50%;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  z-index: 10;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}

.swiper-button-prev:after,
.swiper-button-next:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-lock {
  display: none;
}

:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-bullet-size: 8px;
  --swiper-pagination-bullet-width: 8px;
  --swiper-pagination-bullet-height: 8px;
  --swiper-pagination-bullet-inactive-color: #000;
  --swiper-pagination-bullet-inactive-opacity: 0.2;
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-horizontal-gap: 4px;
  --swiper-pagination-bullet-vertical-gap: 6px;
  */
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  -webkit-transition: 300ms opacity;
  -o-transition: 300ms opacity;
  transition: 300ms opacity;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 10px;
  left: 0;
  width: 100%;
}

/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transform: scale(0.33);
      -ms-transform: scale(0.33);
          transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  -webkit-transform: scale(0.66);
      -ms-transform: scale(0.66);
          transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  -webkit-transform: scale(0.33);
      -ms-transform: scale(0.33);
          transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  -webkit-transform: scale(0.66);
      -ms-transform: scale(0.66);
          transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  -webkit-transform: scale(0.33);
      -ms-transform: scale(0.33);
          transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

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

.swiper-vertical > .swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  -webkit-transform: translate3d(0px, -50%, 0);
          transform: translate3d(0px, -50%, 0);
}

.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 8px;
}

.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  -webkit-transition: 200ms top, 200ms -webkit-transform;
  transition: 200ms top, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms top;
  transition: 200ms transform, 200ms top;
  transition: 200ms transform, 200ms top, 200ms -webkit-transform;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms left, 200ms -webkit-transform;
  transition: 200ms left, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms left;
  transition: 200ms transform, 200ms left;
  transition: 200ms transform, 200ms left, 200ms -webkit-transform;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  -webkit-transition: 200ms right, 200ms -webkit-transform;
  transition: 200ms right, 200ms -webkit-transform;
  -o-transition: 200ms transform, 200ms right;
  transition: 200ms transform, 200ms right;
  transition: 200ms transform, 200ms right, 200ms -webkit-transform;
}

/* Progress */
.swiper-pagination-progressbar {
  background: rgba(0, 0, 0, 0.25);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  -webkit-transform-origin: left top;
      -ms-transform-origin: left top;
          transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  -webkit-transform-origin: right top;
      -ms-transform-origin: right top;
          transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-vertical > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

/* Scrollbar */
.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-scrollbar-disabled > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-vertical > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-vertical {
  position: absolute;
  right: 3px;
  top: 1%;
  z-index: 50;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 10px;
  left: 0;
  top: 0;
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}

.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

/* Preloader */
:root {
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  */
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  -webkit-transform-origin: 50%;
      -ms-transform-origin: 50%;
          transform-origin: 50%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  -webkit-animation: swiper-preloader-spin 1s infinite linear;
          animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@-webkit-keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes swiper-preloader-spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
/* a11y */
.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  -webkit-transition-timing-function: ease-out;
       -o-transition-timing-function: ease-out;
          transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  -webkit-transition-timing-function: ease-out;
       -o-transition-timing-function: ease-out;
          transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  -webkit-transition-property: opacity;
  -o-transition-property: opacity;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  -webkit-transform-origin: 100% 0;
      -ms-transform-origin: 100% 0;
          transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev,
.swiper-cube .swiper-slide-next + .swiper-slide {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-slide-shadow-top,
.swiper-cube .swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: "";
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  -webkit-filter: blur(50px);
          filter: blur(50px);
}

.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-flip .swiper-slide-shadow-top,
.swiper-flip .swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
  -webkit-transition-property: opacity, height, -webkit-transform;
  transition-property: opacity, height, -webkit-transform;
  -o-transition-property: transform, opacity, height;
  transition-property: transform, opacity, height;
  transition-property: transform, opacity, height, -webkit-transform;
}

.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  -webkit-transform-origin: center bottom;
      -ms-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}

/* ----- fancybox ----- */
body.compensate-for-scrollbar {
  overflow: hidden;
}

.fancybox-active {
  height: auto;
}

.fancybox-is-hidden {
  left: -9999px;
  margin: 0;
  position: absolute !important;
  top: -9999px;
  visibility: hidden;
}

.fancybox-container {
  -webkit-backface-visibility: hidden;
  height: 100%;
  left: 0;
  outline: none;
  position: fixed;
  -webkit-tap-highlight-color: transparent;
  top: 0;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  width: 100%;
  z-index: 99992;
}
.fancybox-container * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.fancybox-bg, .fancybox-inner, .fancybox-outer, .fancybox-stage {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}

.fancybox-outer {
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
}

.fancybox-bg {
  background: #1e1e1e;
  opacity: 0;
  -webkit-transition-duration: inherit;
       -o-transition-duration: inherit;
          transition-duration: inherit;
  -webkit-transition-property: opacity;
  -o-transition-property: opacity;
  transition-property: opacity;
  -webkit-transition-timing-function: cubic-bezier(0.47, 0, 0.74, 0.71);
       -o-transition-timing-function: cubic-bezier(0.47, 0, 0.74, 0.71);
          transition-timing-function: cubic-bezier(0.47, 0, 0.74, 0.71);
}

.fancybox-is-open .fancybox-bg {
  opacity: 0.9;
  -webkit-transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
       -o-transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
          transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}

.fancybox-caption, .fancybox-infobar, .fancybox-navigation .fancybox-button, .fancybox-toolbar {
  direction: ltr;
  opacity: 0;
  position: absolute;
  -webkit-transition: opacity 0.25s ease, visibility 0s ease 0.25s;
  -o-transition: opacity 0.25s ease, visibility 0s ease 0.25s;
  transition: opacity 0.25s ease, visibility 0s ease 0.25s;
  visibility: hidden;
  z-index: 99997;
}

.fancybox-show-caption .fancybox-caption, .fancybox-show-infobar .fancybox-infobar, .fancybox-show-nav .fancybox-navigation .fancybox-button, .fancybox-show-toolbar .fancybox-toolbar {
  opacity: 1;
  -webkit-transition: opacity 0.25s ease 0s, visibility 0s ease 0s;
  -o-transition: opacity 0.25s ease 0s, visibility 0s ease 0s;
  transition: opacity 0.25s ease 0s, visibility 0s ease 0s;
  visibility: visible;
}

.fancybox-infobar {
  color: #ccc;
  font-size: 13px;
  -webkit-font-smoothing: subpixel-antialiased;
  height: 44px;
  left: 0;
  line-height: 44px;
  min-width: 44px;
  mix-blend-mode: difference;
  padding: 0 10px;
  pointer-events: none;
  top: 0;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.fancybox-toolbar {
  right: 0;
  top: 0;
}

.fancybox-stage {
  direction: ltr;
  overflow: visible;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  z-index: 99994;
}

.fancybox-is-open .fancybox-stage {
  overflow: hidden;
}

.fancybox-slide {
  -webkit-backface-visibility: hidden;
  display: none;
  height: 100%;
  left: 0;
  outline: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 44px;
  position: absolute;
  text-align: center;
  top: 0;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  -o-transition-property: transform, opacity;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform;
  white-space: normal;
  width: 100%;
  z-index: 99994;
}
.fancybox-slide:before {
  content: "";
  display: inline-block;
  font-size: 0;
  height: 100%;
  vertical-align: middle;
  width: 0;
}

.fancybox-is-sliding .fancybox-slide, .fancybox-slide--current, .fancybox-slide--next, .fancybox-slide--previous {
  display: block;
}

.fancybox-slide--image {
  overflow: hidden;
  padding: 44px 0;
}
.fancybox-slide--image:before {
  display: none;
}

.fancybox-slide--html {
  padding: 6px;
}

.fancybox-content {
  background: #fff;
  display: inline-block;
  margin: 0;
  max-width: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 44px;
  position: relative;
  text-align: left;
  vertical-align: middle;
}

.fancybox-slide--image .fancybox-content {
  -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.14, 1);
          animation-timing-function: cubic-bezier(0.5, 0, 0.14, 1);
  -webkit-backface-visibility: hidden;
  background: transparent;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  left: 0;
  max-width: none;
  overflow: visible;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-transform-origin: top left;
      -ms-transform-origin: top left;
          transform-origin: top left;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  -o-transition-property: transform, opacity;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  z-index: 99995;
}

.fancybox-can-zoomOut .fancybox-content {
  cursor: -webkit-zoom-out;
  cursor: zoom-out;
}

.fancybox-can-zoomIn .fancybox-content {
  cursor: -webkit-zoom-in;
  cursor: zoom-in;
}

.fancybox-can-pan .fancybox-content, .fancybox-can-swipe .fancybox-content {
  cursor: -webkit-grab;
  cursor: grab;
}

.fancybox-is-grabbing .fancybox-content {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

.fancybox-container [data-selectable=true] {
  cursor: text;
}

.fancybox-image {
  background: transparent;
  border: 0;
  height: 100%;
  left: 0;
  margin: 0;
  max-height: none;
  max-width: none;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width: 100%;
}

.fancybox-spaceball {
  background: transparent;
  border: 0;
  height: 100%;
  left: 0;
  margin: 0;
  max-height: none;
  max-width: none;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width: 100%;
  z-index: 1;
}

.fancybox-slide--iframe .fancybox-content, .fancybox-slide--map .fancybox-content, .fancybox-slide--pdf .fancybox-content {
  height: 100%;
  overflow: visible;
  padding: 0;
  width: 100%;
}

.fancybox-slide--video .fancybox-content {
  height: 100%;
  overflow: visible;
  padding: 0;
  width: 100%;
  background: #000;
}

.fancybox-slide--map .fancybox-content {
  background: #e5e3df;
}

.fancybox-slide--iframe .fancybox-content {
  background: #fff;
}

.fancybox-iframe, .fancybox-video {
  background: transparent;
  border: 0;
  display: block;
  height: 100%;
  margin: 0;
  overflow: hidden;
  padding: 0;
  width: 100%;
}

.fancybox-iframe {
  left: 0;
  position: absolute;
  top: 0;
}

.fancybox-error {
  background: #fff;
  cursor: default;
  max-width: 400px;
  padding: 40px;
  width: 100%;
}
.fancybox-error p {
  color: #444;
  font-size: 16px;
  line-height: 20px;
  margin: 0;
  padding: 0;
}

.fancybox-button {
  background: rgba(30, 30, 30, 0.6);
  border: 0;
  border-radius: 0;
  -webkit-box-shadow: none;
          box-shadow: none;
  cursor: pointer;
  display: inline-block;
  height: 44px;
  margin: 0;
  padding: 10px;
  position: relative;
  -webkit-transition: color 0.2s;
  -o-transition: color 0.2s;
  transition: color 0.2s;
  vertical-align: top;
  visibility: inherit;
  width: 44px;
  color: #ccc;
}
.fancybox-button:link, .fancybox-button:visited {
  color: #ccc;
}
.fancybox-button:hover {
  color: #fff;
}
.fancybox-button:focus {
  outline: none;
}
.fancybox-button.fancybox-focus {
  outline: 1px dotted;
}
.fancybox-button[disabled] {
  color: #888;
  cursor: default;
  outline: none;
}
.fancybox-button[disabled]:hover {
  color: #888;
  cursor: default;
  outline: none;
}
.fancybox-button div {
  height: 100%;
}
.fancybox-button svg {
  display: block;
  height: 100%;
  overflow: visible;
  position: relative;
  width: 100%;
}

.fancybox-button--fsenter svg:nth-child(2), .fancybox-button--fsexit svg:first-child, .fancybox-button--pause svg:first-child, .fancybox-button--play svg:nth-child(2) {
  display: none;
}

.fancybox-progress {
  background: #ff5268;
  height: 2px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  -webkit-transform: scaleX(0);
      -ms-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: 0;
      -ms-transform-origin: 0;
          transform-origin: 0;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  -o-transition-property: transform;
  transition-property: transform;
  transition-property: transform, -webkit-transform;
  -webkit-transition-timing-function: linear;
       -o-transition-timing-function: linear;
          transition-timing-function: linear;
  z-index: 99998;
}

.fancybox-close-small {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: #ccc;
  cursor: pointer;
  opacity: 0.8;
  padding: 8px;
  position: absolute;
  right: -12px;
  top: -44px;
  z-index: 401;
}
.fancybox-close-small:hover {
  color: #fff;
  opacity: 1;
}

.fancybox-slide--html .fancybox-close-small {
  color: currentColor;
  padding: 10px;
  right: 0;
  top: 0;
}

.fancybox-slide--image.fancybox-is-scaling .fancybox-content {
  overflow: hidden;
}

.fancybox-is-scaling .fancybox-close-small, .fancybox-is-zoomable.fancybox-can-pan .fancybox-close-small {
  display: none;
}

.fancybox-navigation .fancybox-button {
  background-clip: content-box;
  height: 100px;
  opacity: 0;
  position: absolute;
  top: calc(50% - 50px);
  width: 70px;
}
.fancybox-navigation .fancybox-button div {
  padding: 7px;
}
.fancybox-navigation .fancybox-button--arrow_left {
  left: 0;
  left: env(safe-area-inset-left);
  padding: 31px 26px 31px 6px;
}
.fancybox-navigation .fancybox-button--arrow_right {
  padding: 31px 6px 31px 26px;
  right: 0;
  right: env(safe-area-inset-right);
}

.fancybox-caption {
  background: -webkit-gradient(linear, left bottom, left top, color-stop(0, rgba(0, 0, 0, 0.85)), color-stop(50%, rgba(0, 0, 0, 0.3)), color-stop(65%, rgba(0, 0, 0, 0.15)), color-stop(75.5%, rgba(0, 0, 0, 0.075)), color-stop(82.85%, rgba(0, 0, 0, 0.037)), color-stop(88%, rgba(0, 0, 0, 0.019)), to(transparent));
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.85) 0, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.15) 65%, rgba(0, 0, 0, 0.075) 75.5%, rgba(0, 0, 0, 0.037) 82.85%, rgba(0, 0, 0, 0.019) 88%, transparent);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.85) 0, rgba(0, 0, 0, 0.3) 50%, rgba(0, 0, 0, 0.15) 65%, rgba(0, 0, 0, 0.075) 75.5%, rgba(0, 0, 0, 0.037) 82.85%, rgba(0, 0, 0, 0.019) 88%, transparent);
  bottom: 0;
  color: #eee;
  font-size: 14px;
  font-weight: 400;
  left: 0;
  line-height: 1.5;
  padding: 75px 44px 25px;
  pointer-events: none;
  right: 0;
  text-align: center;
  z-index: 99996;
}

.fancybox-caption--separate {
  margin-top: -50px;
}

.fancybox-caption__body {
  max-height: 50vh;
  overflow: auto;
  pointer-events: all;
}

.fancybox-caption a {
  color: #ccc;
  text-decoration: none;
}
.fancybox-caption a:link, .fancybox-caption a:visited {
  color: #ccc;
  text-decoration: none;
}
.fancybox-caption a:hover {
  color: #fff;
  text-decoration: underline;
}

.fancybox-loading {
  -webkit-animation: a 1s linear infinite;
          animation: a 1s linear infinite;
  background: transparent;
  border: 4px solid #888;
  border-bottom-color: #fff;
  border-radius: 50%;
  height: 50px;
  left: 50%;
  margin: -25px 0 0 -25px;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  width: 50px;
  z-index: 99999;
}

@-webkit-keyframes a {
  to {
    -webkit-transform: rotate(1turn);
            transform: rotate(1turn);
  }
}

@keyframes a {
  to {
    -webkit-transform: rotate(1turn);
            transform: rotate(1turn);
  }
}
.fancybox-animated {
  -webkit-transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
       -o-transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
          transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
}

.fancybox-fx-slide.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: translate3d(-100%, 0, 0);
          transform: translate3d(-100%, 0, 0);
}
.fancybox-fx-slide.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: translate3d(100%, 0, 0);
          transform: translate3d(100%, 0, 0);
}
.fancybox-fx-slide.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}

.fancybox-fx-fade.fancybox-slide--next, .fancybox-fx-fade.fancybox-slide--previous {
  opacity: 0;
  -webkit-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
       -o-transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
          transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.fancybox-fx-fade.fancybox-slide--current {
  opacity: 1;
}

.fancybox-fx-zoom-in-out.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: scale3d(1.5, 1.5, 1.5);
          transform: scale3d(1.5, 1.5, 1.5);
}
.fancybox-fx-zoom-in-out.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: scale3d(0.5, 0.5, 0.5);
          transform: scale3d(0.5, 0.5, 0.5);
}
.fancybox-fx-zoom-in-out.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: scaleX(1);
      -ms-transform: scaleX(1);
          transform: scaleX(1);
}

.fancybox-fx-rotate.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: rotate(-1turn);
      -ms-transform: rotate(-1turn);
          transform: rotate(-1turn);
}
.fancybox-fx-rotate.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: rotate(1turn);
      -ms-transform: rotate(1turn);
          transform: rotate(1turn);
}
.fancybox-fx-rotate.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: rotate(0deg);
      -ms-transform: rotate(0deg);
          transform: rotate(0deg);
}

.fancybox-fx-circular.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: scale3d(0, 0, 0) translate3d(-100%, 0, 0);
          transform: scale3d(0, 0, 0) translate3d(-100%, 0, 0);
}
.fancybox-fx-circular.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: scale3d(0, 0, 0) translate3d(100%, 0, 0);
          transform: scale3d(0, 0, 0) translate3d(100%, 0, 0);
}
.fancybox-fx-circular.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: scaleX(1) translateZ(0);
          transform: scaleX(1) translateZ(0);
}

.fancybox-fx-tube.fancybox-slide--previous {
  -webkit-transform: translate3d(-100%, 0, 0) scale(0.1) skew(-10deg);
          transform: translate3d(-100%, 0, 0) scale(0.1) skew(-10deg);
}
.fancybox-fx-tube.fancybox-slide--next {
  -webkit-transform: translate3d(100%, 0, 0) scale(0.1) skew(10deg);
          transform: translate3d(100%, 0, 0) scale(0.1) skew(10deg);
}
.fancybox-fx-tube.fancybox-slide--current {
  -webkit-transform: translateZ(0) scale(1);
          transform: translateZ(0) scale(1);
}

@media (max-height: 576px) {
  .fancybox-slide {
    padding-left: 6px;
    padding-right: 6px;
  }
  .fancybox-slide--image {
    padding: 6px 0;
  }
  .fancybox-close-small {
    right: -6px;
  }
  .fancybox-slide--image .fancybox-close-small {
    background: #4e4e4e;
    color: #f2f4f6;
    height: 36px;
    opacity: 1;
    padding: 6px;
    right: 0;
    top: 0;
    width: 36px;
  }
  .fancybox-caption {
    padding-left: 12px;
    padding-right: 12px;
  }
}
.fancybox-share {
  background: #f4f4f4;
  border-radius: 3px;
  max-width: 90%;
  padding: 30px;
  text-align: center;
}
.fancybox-share h1 {
  color: #222;
  font-size: 35px;
  font-weight: 700;
  margin: 0 0 20px;
}
.fancybox-share p {
  margin: 0;
  padding: 0;
}

.fancybox-share__button {
  border: 0;
  border-radius: 3px;
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  line-height: 40px;
  margin: 0 5px 10px;
  min-width: 130px;
  padding: 0 15px;
  text-decoration: none;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  white-space: nowrap;
}
.fancybox-share__button:link, .fancybox-share__button:visited {
  color: #fff;
}
.fancybox-share__button:hover {
  text-decoration: none;
}

.fancybox-share__button--fb {
  background: #3b5998;
}
.fancybox-share__button--fb:hover {
  background: #344e86;
}

.fancybox-share__button--pt {
  background: #bd081d;
}
.fancybox-share__button--pt:hover {
  background: #aa0719;
}

.fancybox-share__button--tw {
  background: #1da1f2;
}
.fancybox-share__button--tw:hover {
  background: #0d95e8;
}

.fancybox-share__button svg {
  height: 25px;
  margin-right: 7px;
  position: relative;
  top: -1px;
  vertical-align: middle;
  width: 25px;
}
.fancybox-share__button svg path {
  fill: #fff;
}

.fancybox-share__input {
  background: transparent;
  border: 0;
  border-bottom: 1px solid #d7d7d7;
  border-radius: 0;
  color: #5d5b5b;
  font-size: 14px;
  margin: 10px 0 0;
  outline: none;
  padding: 10px 15px;
  width: 100%;
}

.fancybox-thumbs {
  background: #ddd;
  bottom: 0;
  display: none;
  margin: 0;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
  padding: 2px 2px 4px;
  position: absolute;
  right: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  top: 0;
  width: 212px;
  z-index: 99995;
}

.fancybox-thumbs-x {
  overflow-x: auto;
  overflow-y: hidden;
}

.fancybox-show-thumbs .fancybox-thumbs {
  display: block;
}
.fancybox-show-thumbs .fancybox-inner {
  right: 212px;
}

.fancybox-thumbs__list {
  font-size: 0;
  height: 100%;
  list-style: none;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 0;
  position: absolute;
  position: relative;
  white-space: nowrap;
  width: 100%;
}

.fancybox-thumbs-x .fancybox-thumbs__list {
  overflow: hidden;
}

.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar {
  width: 7px;
}
.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar-track {
  background: #fff;
  border-radius: 10px;
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
          box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}
.fancybox-thumbs-y .fancybox-thumbs__list::-webkit-scrollbar-thumb {
  background: #2a2a2a;
  border-radius: 10px;
}

.fancybox-thumbs__list a {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background-color: rgba(0, 0, 0, 0.1);
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: cover;
  cursor: pointer;
  float: left;
  height: 75px;
  margin: 2px;
  max-height: calc(100% - 8px);
  max-width: calc(50% - 4px);
  outline: none;
  overflow: hidden;
  padding: 0;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  width: 100px;
}
.fancybox-thumbs__list a:before {
  border: 6px solid #ff5268;
  bottom: 0;
  content: "";
  left: 0;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
  -webkit-transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -o-transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 99991;
}
.fancybox-thumbs__list a:focus:before {
  opacity: 0.5;
}
.fancybox-thumbs__list a.fancybox-thumbs-active:before {
  opacity: 1;
}

@media (max-width: 576px) {
  .fancybox-thumbs {
    width: 110px;
  }
  .fancybox-show-thumbs .fancybox-inner {
    right: 110px;
  }
  .fancybox-thumbs__list a {
    max-width: calc(100% - 10px);
  }
}
/* ----- simplebar ----- */
[data-simplebar] {
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -ms-flex-line-pack: start;
      align-content: flex-start;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.simplebar-wrapper {
  overflow: hidden;
  width: inherit;
  height: inherit;
  max-width: inherit;
  max-height: inherit;
}

.simplebar-mask {
  direction: inherit;
  position: absolute;
  overflow: hidden;
  padding: 0;
  margin: 0;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  width: auto !important;
  height: auto !important;
  z-index: 0;
}

.simplebar-offset {
  direction: inherit !important;
  -webkit-box-sizing: inherit !important;
          box-sizing: inherit !important;
  resize: none !important;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  padding: 0;
  margin: 0;
  -webkit-overflow-scrolling: touch;
}

.simplebar-content-wrapper {
  direction: inherit;
  -webkit-box-sizing: border-box !important;
          box-sizing: border-box !important;
  position: relative;
  display: block;
  height: 100%;
  width: auto;
  visibility: visible;
  max-width: 100%;
  max-height: 100%;
  scrollbar-width: none;
}
.simplebar-content-wrapper::-webkit-scrollbar {
  display: none;
}

.simplebar-hide-scrollbar::-webkit-scrollbar {
  display: none;
}

.simplebar-content:after, .simplebar-content:before {
  content: " ";
  display: table;
}

.simplebar-placeholder {
  max-height: 100%;
  max-width: 100%;
  width: 100%;
  pointer-events: none;
}

.simplebar-height-auto-observer-wrapper {
  -webkit-box-sizing: inherit !important;
          box-sizing: inherit !important;
  height: 100%;
  width: 100%;
  max-width: 1px;
  position: relative;
  float: left;
  max-height: 1px;
  overflow: hidden;
  z-index: -1;
  padding: 0;
  margin: 0;
  pointer-events: none;
  -webkit-box-flex: inherit;
      -ms-flex-positive: inherit;
          flex-grow: inherit;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 0;
      flex-basis: 0;
}

.simplebar-height-auto-observer {
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
  display: block;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  height: 1000%;
  width: 1000%;
  min-height: 1px;
  min-width: 1px;
  overflow: hidden;
  pointer-events: none;
  z-index: -1;
}

.simplebar-track {
  z-index: 1;
  position: absolute;
  right: 0;
  bottom: 0;
  pointer-events: none;
  overflow: hidden;
}

[data-simplebar].simplebar-dragging .simplebar-content {
  pointer-events: none;
  -moz-user-select: none;
   -ms-user-select: none;
       user-select: none;
  -webkit-user-select: none;
}
[data-simplebar].simplebar-dragging .simplebar-track {
  pointer-events: all;
}

.simplebar-scrollbar {
  position: absolute;
  right: 2px;
  width: 7px;
  min-height: 10px;
}
.simplebar-scrollbar:before {
  position: absolute;
  content: "";
  background: #000;
  border-radius: 7px;
  left: 0;
  right: 0;
  opacity: 0;
  -webkit-transition: opacity 0.2s linear;
  -o-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
.simplebar-scrollbar.simplebar-visible:before {
  opacity: 0.5;
  -webkit-transition: opacity 0s linear;
  -o-transition: opacity 0s linear;
  transition: opacity 0s linear;
}

.simplebar-track.simplebar-vertical {
  top: 0;
  width: 11px;
}
.simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
  top: 2px;
  bottom: 2px;
}
.simplebar-track.simplebar-horizontal {
  left: 0;
  height: 11px;
}
.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
  right: auto;
  left: 0;
  top: 2px;
  height: 7px;
  min-height: 0;
  min-width: 10px;
  width: auto;
}
.simplebar-track.simplebar-horizontal .simplebar-scrollbar:before {
  height: 100%;
  left: 2px;
  right: 2px;
}

[data-simplebar-direction=rtl] .simplebar-track.simplebar-vertical {
  right: auto;
  left: 0;
}

.hs-dummy-scrollbar-size {
  direction: rtl;
  position: fixed;
  opacity: 0;
  visibility: hidden;
  height: 500px;
  width: 500px;
  overflow-y: hidden;
  overflow-x: scroll;
}

.simplebar-hide-scrollbar {
  position: fixed;
  left: 0;
  visibility: hidden;
  overflow-y: scroll;
  scrollbar-width: none;
}

/* -------------------------------------
 * Reset
 * ------------------------------------- */
article, aside, dialog, figcaption, figure, footer, header, main, nav, section, details, menu, picture {
  display: block;
}

@-ms-viewport {
  width: device-width;
}
html {
  font-size: 10px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -ms-overflow-style: scrollbar;
  -webkit-tap-highlight-color: transparent;
}
@media screen and (max-width: 1439px) {
  html {
    font-size: 9px;
  }
}
@media screen and (max-width: 1199px) {
  html {
    font-size: 8px;
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: 10px;
  }
}
@media screen and (max-width: 374px) {
  html {
    font-size: 8px;
  }
}

* {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
  letter-spacing: -0.02em;
}
*::before, *::after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

body {
  margin: 0;
  position: relative;
  font: var(--text) var(--text-font), -apple-system, system-ui, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  text-align: left;
  color: var(--color-title);
  background-color: var(--color-white);
  overflow-x: hidden;
}

h1 {
  font-weight: var(--title-weight);
}

h1, h2, h3, h4, h5, h6, .title {
  font-family: var(--title-font);
  letter-spacing: -0.04em;
}
h1 *, h2 *, h3 *, h4 *, h5 *, h6 *, .title * {
  letter-spacing: -0.04em;
}

h1, h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: 0.5em;
}

h2, h3, h4, h5, h6 {
  font-weight: 400;
}

p {
  margin: 0 0 1.5em;
}
p:last-child {
  margin-bottom: 0;
}

address {
  margin: 0;
  font-style: normal;
  line-height: inherit;
}

ol, ul {
  margin-top: 0;
  margin-bottom: 1rem;
}

ol ol, ul ul, ol ul, ul ol {
  margin-bottom: 0;
}

blockquote {
  margin: 0 0 1rem;
}

b, strong, .fw-600 {
  font-weight: 600;
}

small {
  font-size: 80%;
}

sub, sup {
  font-size: 50%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.9em;
}

a {
  color: inherit;
  text-decoration: none;
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
  -webkit-transition: all 0.1s linear;
  -o-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
a:hover {
  color: inherit;
}
a:focus {
  outline: none;
}
a:hover, a:focus {
  text-decoration: none;
}
a:active, a:hover {
  outline-width: 0;
}
a:not([href]):not([tabindex]) {
  color: inherit;
  text-decoration: none;
}
a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
  color: inherit;
  text-decoration: none;
}
a:not([href]):not([tabindex]):focus {
  outline: 0;
}

figure {
  margin: 0 0 1rem;
}

img {
  font-size: 10px;
  text-transform: uppercase;
  color: var(--color-accent-main);
  vertical-align: middle;
  border-style: none;
}
img::-moz-selection {
  background: none;
}
img::selection {
  background: none;
}

svg:not(:root) {
  overflow: hidden;
}

table {
  width: 100%;
  border-collapse: collapse;
  background-color: transparent;
}

th {
  text-align: inherit;
}

a, area, button, [role=button], input, label, select, summary, textarea {
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}

button {
  padding: 0;
  background-color: transparent;
  border: none;
  border-radius: 0;
  cursor: pointer;
}
button:focus {
  outline: none;
}

button::-moz-focus-inner, [type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

input, button, select, optgroup, textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button, input {
  overflow: visible;
}

button, select {
  text-transform: none;
}

button, html [type=button], [type=reset], [type=submit] {
  -webkit-appearance: button;
}

input[type=radio], input[type=checkbox] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
}
input[type=radio]:disabled, input[type=checkbox]:disabled {
  cursor: not-allowed;
}
input[type=date], input[type=time], input[type=datetime-local], input[type=month] {
  -webkit-appearance: listbox;
}
input[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

label {
  display: block;
  margin: 0;
}

textarea {
  overflow: auto;
  resize: none;
}

[tabindex="-1"]:focus {
  outline: 0 !important;
}

[role=button] {
  cursor: pointer;
}

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
}

[hidden] {
  display: none !important;
}

.swiper-slide * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.swiper-pagination-bullet {
  outline: none;
}

@media screen and (min-width: 1200px) {
  .fancybox-container {
    -webkit-backface-visibility: inherit;
  }
}
.fancybox-bg {
  background-color: rgba(0, 0, 0, 0.4);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
}
.fancybox-is-open .fancybox-bg {
  opacity: 1;
}
.fancybox-slide {
  text-align: right;
}
.fancybox-slide--html {
  padding: 0;
}
.fancybox-slide--video .fancybox-content {
  background: none !important;
}
.fancybox-iframe {
  max-width: 1240px;
  max-height: 700px;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.fancybox-button--close {
  font-size: 6.4rem;
  background-color: var(--bg-sections);
  width: 1em;
  height: 1em;
}
@media screen and (max-width: 767px) {
  .fancybox-button--close {
    font-size: 4.4rem;
  }
}
.fancybox-button--close svg {
  display: none;
}
.fancybox-button--close::after {
  content: "";
  display: block;
  font-size: 2.8rem;
  width: 1em;
  height: 1em;
  position: absolute;
  z-index: 0;
  left: 50%;
  top: 50%;
  margin: -0.5em 0 0 -0.5em;
  background: url("../img/icons/close.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: -webkit-filter 0.1s;
  transition: -webkit-filter 0.1s;
  -o-transition: filter 0.1s;
  transition: filter 0.1s;
  transition: filter 0.1s, -webkit-filter 0.1s;
}
@media screen and (max-width: 767px) {
  .fancybox-button--close::after {
    font-size: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .fancybox-button--close:hover::after {
    -webkit-filter: none;
            filter: none;
  }
}
.fancybox-slide {
  padding: 0;
}
.fancybox-slide--html .fancybox-close-small {
  font-size: 6.4rem;
  width: 1em;
  height: 1em;
  padding: 0;
  opacity: 1;
  background-color: var(--bg-sections);
}
@media screen and (max-width: 767px) {
  .fancybox-slide--html .fancybox-close-small {
    font-size: 4.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .fancybox-slide--html .fancybox-close-small:hover::before {
    -webkit-filter: none;
            filter: none;
  }
}
.fancybox-slide--html .fancybox-close-small svg {
  display: none;
}
.fancybox-slide--html .fancybox-close-small::before {
  content: "";
  display: block;
  font-size: 2.8rem;
  width: 1em;
  height: 1em;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -0.5em 0 0 -0.5em;
  background: url("../img/icons/close.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: -webkit-filter 0.1s;
  transition: -webkit-filter 0.1s;
  -o-transition: filter 0.1s;
  transition: filter 0.1s;
  transition: filter 0.1s, -webkit-filter 0.1s;
}
@media screen and (max-width: 767px) {
  .fancybox-slide--html .fancybox-close-small::before {
    font-size: 2rem;
  }
}
.fancybox-infobar {
  display: none !important;
}
.fancybox-toolbar .fancybox-button--zoom,
.fancybox-toolbar .fancybox-button--play,
.fancybox-toolbar .fancybox-button--thumbs {
  display: none !important;
}
.fancybox-navigation .fancybox-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0;
  font-size: 10px;
  width: 4.8em;
  height: 4.8em;
  top: calc(50% - 2.4em);
  outline: none;
  cursor: pointer;
  border: none;
  background-color: #E8E8E8;
}
.fancybox-navigation .fancybox-button::before {
  content: "";
  display: block;
  width: 1.3em;
  height: 2.2em;
  position: absolute;
  background: url("../img/icons/chevron-right-accent.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
.fancybox-navigation .fancybox-button div {
  display: none;
}
@media screen and (min-width: 1200px) {
  .fancybox-navigation .fancybox-button {
    -webkit-transition: all 0.2s linear;
    -o-transition: all 0.2s linear;
    transition: all 0.2s linear;
  }
  .fancybox-navigation .fancybox-button:hover {
    background-color: var(--color-accent-main);
  }
}
.fancybox-navigation .fancybox-button--arrow_left::before {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.fancybox .fancybox-image {
  max-width: 1240px;
  max-height: 700px;
}

.css-scroll .simplebar-scrollbar::before {
  opacity: 1;
  background-color: var(--bg);
  border: 1px solid var(--border-color);
}

/* -------------------------------------
 * Common styles
 * ------------------------------------- */
.wrapper {
  overflow: hidden;
  position: relative;
  z-index: 1;
}
.wrapper-bg {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  background: var(--color-white);
}

.container {
  width: 100%;
  padding-right: 14px;
  padding-left: 14px;
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 768px) {
  .container {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media (min-width: 1600px) {
  .container {
    max-width: 1600px;
    padding-right: 40px;
    padding-left: 40px;
  }
}

.inner {
  padding-right: 14px;
  padding-left: 14px;
}
@media (min-width: 768px) {
  .inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}
@media (min-width: 1600px) {
  .inner {
    padding-right: 40px;
    padding-left: 40px;
  }
}

@media screen and (max-width: 1023px) {
  .full-lg {
    width: calc(100% + 40px) !important;
    margin-left: -20px;
  }
}

@media screen and (max-width: 767px) {
  .full-md, .full-lg {
    width: calc(100% + 28px) !important;
    margin-left: -14px;
  }
}

@media screen and (min-width: 1200px) {
  .grid-xl-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}

@media screen and (min-width: 1024px) {
  .grid-lg-2, .grid-lg-3 {
    display: grid;
    gap: 20px;
  }
}

@media screen and (min-width: 1024px) {
  .grid-lg-2 {
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (min-width: 1024px) {
  .grid-lg-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media screen and (min-width: 1600px) {
  .grid-xl-2, .grid-lg-2, .grid-lg-3 {
    gap: 40px;
  }
}

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

.flex-center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.img {
  display: block;
  max-width: 100%;
  height: auto;
  max-height: 100%;
}
.img--cover, .img--contain {
  width: 100%;
  height: 100%;
}
.img--cover {
  -o-object-fit: cover;
     object-fit: cover;
}
.img--contain {
  -o-object-fit: contain;
     object-fit: contain;
}

.svg {
  display: block;
  max-width: 100%;
  max-height: 100%;
}

.list, .sub-menu {
  margin: 0;
  padding: 0;
  list-style: none;
}

.bg {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.mt-4 {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .mt-4 {
    margin-top: 2rem;
  }
}

.mb-1 {
  margin-bottom: 1em;
}

.accent {
  color: var(--color-accent-main);
}

.subcolor {
  color: var(--color-sub);
}

.color-black {
  color: var(--color-title);
}

.a-block, .g-block {
  color: var(--color-white);
}

.a-block {
  background-color: var(--color-accent-main);
}

.g-block {
  background-color: var(--color-accent-add);
}

.bg-gray {
  background-color: var(--bg);
}

.bd-gray {
  border: 1px solid var(--border-color);
}

@media screen and (max-width: 1199px) {
  .hide-xl {
    display: none !important;
  }
}

@media screen and (min-width: 1200px) {
  .show-xl {
    display: none !important;
  }
}

@media screen and (max-width: 1023px) {
  .hide-lg {
    display: none !important;
  }
}

@media screen and (min-width: 1024px) {
  .show-lg {
    display: none !important;
  }
}

@media screen and (max-width: 767px) {
  .hide-md {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .show-md {
    display: none !important;
  }
}

.section-head {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 3.6rem;
}
@media screen and (max-width: 767px) {
  .section-head {
    margin-bottom: 2rem;
  }
}
.section-head__title {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
  margin: 0;
}
.section-head .link-all {
  position: relative;
  bottom: 2px;
}
@media screen and (max-width: 767px) {
  .section-head .link-all {
    font-size: 1.4rem;
  }
  .section-head .link-all::after {
    display: none;
  }
}

/* ---------- Titles & text ---------- */
.fz-160 {
  font-size: 16rem;
  line-height: 0.6;
}
@media screen and (max-width: 767px) {
  .fz-160 {
    font-size: 10rem;
  }
}

.fz-130 {
  font-size: var(--big-fz);
  line-height: var(--big-lh);
}
@media screen and (max-width: 1439px) {
  .fz-130 {
    font-size: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .fz-130 {
    font-size: 4.2rem;
    line-height: 0.9;
  }
}

h1, .fz-88 {
  font-size: var(--title-fz-1);
  line-height: var(--title-lh-1);
}
@media screen and (max-width: 767px) {
  h1, .fz-88 {
    font-size: 5.1rem;
    line-height: var(--title-lh-2);
  }
}

.fz-70 {
  font-size: 7rem;
  line-height: 0.9;
}
@media screen and (max-width: 767px) {
  .fz-70 {
    font-size: 3.4rem;
    line-height: var(--title-lh-2);
  }
}

h2, .fz-60 {
  font-size: var(--title-fz-2);
  line-height: var(--title-lh-2);
}
@media screen and (max-width: 767px) {
  h2, .fz-60 {
    font-size: 3.4rem;
  }
}

.fz-54 {
  font-size: 5.4rem;
}
@media screen and (max-width: 767px) {
  .fz-54 {
    font-size: var(--title-fz-3);
    line-height: var(--title-lh-3);
  }
}

.fz-36 {
  font-size: 3.6rem;
}
@media screen and (max-width: 767px) {
  .fz-36 {
    font-size: 3rem;
    line-height: var(--title-lh-3);
  }
}

h3, .fz-30 {
  font-size: var(--title-fz-3);
  line-height: var(--title-lh-3);
}
@media screen and (max-width: 767px) {
  h3, .fz-30 {
    font-size: var(--title-fz-4);
    line-height: 1.15;
  }
}

.fz-26 {
  font-size: 2.6rem;
  line-height: var(--title-lh-3);
}
@media screen and (max-width: 767px) {
  .fz-26 {
    font-size: 2rem;
    line-height: var(--title-lh-4);
  }
}

h4, .fz-22 {
  font-size: var(--title-fz-4);
  line-height: var(--title-lh-4);
}
@media screen and (max-width: 1023px) {
  h4, .fz-22 {
    font-size: 18px;
  }
}

h5, .fz-18 {
  font-size: var(--title-fz-5);
  line-height: var(--title-lh-5);
}
@media screen and (max-width: 767px) {
  h5, .fz-18 {
    font-size: 1.6rem;
    line-height: 1.45;
  }
}

.fz-15 {
  font-size: 1.5rem;
  line-height: 1.6;
}

.fz-14 {
  font-size: 1.4rem;
  line-height: 1.45;
}
@media screen and (max-width: 767px) {
  .fz-14 {
    font-size: 1.2rem;
    line-height: 1.65;
  }
}

@media screen and (max-width: 767px) {
  .fz-md-18 {
    font-size: 1.8rem;
  }
}

.ls-1 {
  letter-spacing: -0.01em;
}
.ls-1 * {
  letter-spacing: -0.01em;
}

.nowrap {
  white-space: nowrap;
}

.fw-500 {
  font-weight: 500;
}

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

.styled-list ul, .styled-list ol, .content ul, .content ol {
  margin: 0;
  padding: 0;
  list-style: none;
}
.styled-list li, .content li {
  position: relative;
  margin-bottom: 0.9em;
  padding-left: 2.8rem;
}
@media screen and (max-width: 767px) {
  .styled-list li, .content li {
    padding-left: 2.4rem;
  }
}
.styled-list ul li::before, .content ul li::before {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  position: absolute;
  z-index: 0;
  left: 0;
  top: 9px;
  background: var(--color-accent-add);
}
.styled-list ol, .content ol {
  counter-reset: li;
}
.styled-list ol li, .content ol li {
  padding-left: 6.1rem;
}
@media screen and (max-width: 767px) {
  .styled-list ol li, .content ol li {
    padding-left: 4.3rem;
  }
}
.styled-list ol li::before, .content ol li::before {
  counter-increment: li;
  content: counter(li) ".";
  font-size: 2.2rem;
  position: absolute;
  top: -0.2em;
  left: 0;
}

/* ----- buttons ----- */
.button {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 5.1rem;
  padding: 1.4rem 3.2rem;
  font: 600 1.6rem/1 var(--text-font);
  border-radius: 100px;
  position: relative;
  z-index: 1;
  cursor: pointer;
  overflow: hidden;
  -webkit-transition: all 0.15s linear;
  -o-transition: all 0.15s linear;
  transition: all 0.15s linear;
}
.button.fw-500 {
  font-weight: 500;
}
.button-accent-bg {
  background-color: var(--color-accent-main);
  color: var(--color-white);
}
.button-accent-bg:hover {
  color: var(--color-white);
}
.button-accent-bg.button-arrow::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
@media screen and (min-width: 1200px) {
  .button-accent-bg:hover {
    background-color: var(--color-accent-add);
  }
}
.button-accent-bg.button-anim {
  background-color: var(--color-accent-add);
}
.button-accent-bg.button-anim::before {
  background: var(--color-accent-main);
}
.button-accent-bd {
  border: 1px solid var(--color-accent-main);
  color: var(--color-accent-main);
}
.button-accent-bd:hover {
  color: var(--color-accent-main);
}
@media screen and (min-width: 1200px) {
  .button-accent-bd:hover {
    background-color: var(--color-accent-main);
    color: #fff;
  }
}
.button-accent-bd.button-anim {
  background-color: var(--color-accent-main);
}
.button-accent-bd.button-anim::before {
  background: var(--color-white);
}
@media screen and (min-width: 1200px) {
  .button-accent-bd.button-anim:hover {
    color: var(--color-white);
  }
}
.button-white-bd {
  border: 1px solid var(--color-white);
  color: var(--color-white);
}
.button-arrow::after {
  content: "";
  display: block;
  width: 8px;
  min-width: 8px;
  height: 14px;
  margin-left: 1.6rem;
  background: url("../img/icons/chevron-right.svg") no-repeat 50% 50%/contain;
}
.button-plus {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: var(--color-white);
}
.button-plus svg {
  fill: none;
  width: 14px;
  height: 14px;
  margin-right: 1.4rem;
}
.button-plus path {
  fill: var(--color-accent-add);
}
@media screen and (min-width: 1200px) {
  .button-plus {
    -webkit-transition: color 0.1s;
    -o-transition: color 0.1s;
    transition: color 0.1s;
  }
  .button-plus path {
    -webkit-transition: fill 0.1s;
    -o-transition: fill 0.1s;
    transition: fill 0.1s;
  }
  .button-plus:hover {
    color: var(--color-accent-main);
  }
  .button-plus:hover path {
    fill: var(--color-accent-main);
  }
}
.button-phone::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url("../img/icons/phone-telephone.svg") no-repeat 50% 50%/contain;
}
.button-anim::before {
  content: "";
  width: 120%;
  left: -10%;
  -webkit-transform: skew(30deg);
      -ms-transform: skew(30deg);
          transform: skew(30deg);
  -webkit-transition: -webkit-transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
  transition: -webkit-transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
  -o-transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
  transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
  transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1), -webkit-transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
  position: absolute;
  z-index: -1;
  top: 0;
  height: 100%;
}
@media screen and (min-width: 1200px) {
  .button-anim:hover::before {
    -webkit-transform: translate3d(100%, 0, 0);
            transform: translate3d(100%, 0, 0);
  }
}

.link-all {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.link-all::after {
  content: "";
  display: block;
  width: 8px;
  min-width: 8px;
  height: 14px;
  margin-left: 2rem;
  background: url("../img/icons/chevron-right-accent.svg") no-repeat 50% 50%/contain;
  -webkit-transition: -webkit-filter 0.1s;
  transition: -webkit-filter 0.1s;
  -o-transition: filter 0.1s;
  transition: filter 0.1s;
  transition: filter 0.1s, -webkit-filter 0.1s;
  -webkit-filter: brightness(0);
          filter: brightness(0);
}
@media screen and (max-width: 767px) {
  .link-all::after {
    margin-left: 1.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .link-all:hover {
    color: var(--color-accent-main);
  }
  .link-all:hover::after {
    -webkit-filter: none;
            filter: none;
  }
}

.bg-section .link-all:not(:hover)::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

.close {
  font-size: 6.4rem;
  width: 1em;
  height: 1em;
  position: absolute;
  z-index: 401;
  top: 0;
  right: 0;
  cursor: pointer;
  -webkit-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
@media screen and (max-width: 767px) {
  .close {
    font-size: 4.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .close:hover::before {
    -webkit-filter: none;
            filter: none;
  }
}
.close::before {
  content: "";
  display: block;
  font-size: 2.8rem;
  width: 1em;
  height: 1em;
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -0.5em 0 0 -0.5em;
  background: url("../img/icons/close.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: -webkit-filter 0.1s;
  transition: -webkit-filter 0.1s;
  -o-transition: filter 0.1s;
  transition: filter 0.1s;
  transition: filter 0.1s, -webkit-filter 0.1s;
}
@media screen and (max-width: 767px) {
  .close::before {
    font-size: 2rem;
  }
}

.button-more {
  min-width: 19.3rem;
}
@media screen and (min-width: 1024px) {
  .button-more {
    margin-top: 3rem;
  }
}

.circle-arrow-blank, .circle-arrow-chevron {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 4.6rem;
  min-width: 4.6rem;
  height: 4.6rem;
  background-color: var(--color-accent-main);
  border-radius: 50%;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
  cursor: pointer;
}
.circle-arrow-blank::before, .circle-arrow-chevron::before {
  content: "";
  display: block;
  background: no-repeat 50% 50%/contain;
}
@media screen and (min-width: 1200px) {
  .circle-arrow-blank:hover, .circle-arrow-chevron:hover {
    background-color: var(--color-accent-add);
  }
}

.circle-arrow-blank::before {
  width: 12px;
  height: 12px;
  background-image: url("../img/icons/arrow-blank.svg");
}

.circle-arrow-chevron::before {
  width: 8px;
  height: 14px;
  background-image: url("../img/icons/chevron-right.svg");
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

.slider-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  margin-top: 3.8rem;
}
@media screen and (max-width: 767px) {
  .slider-nav {
    margin-top: 2.2rem;
  }
}
.slider-nav .slider-arrows {
  position: absolute;
  right: 0;
}
@media screen and (max-width: 1199px) {
  .slider-nav .slider-arrows {
    display: none;
  }
}
.slider-nav .slider-arrow {
  margin-left: 4px;
}
.slider-arrows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.slider-arrows.white .slider-arrow:not(:hover) {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.5);
}
.slider-arrows.white .slider-arrow:not(:hover)::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.slider-arrows.position .slider-arrow {
  position: absolute;
  top: 50%;
  margin-top: -2em;
}
.slider-arrows.position .slider-prev {
  left: -2em;
}
.slider-arrows.position .slider-next {
  right: -2em;
}
.slider-arrow {
  font-size: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 4.6rem;
  min-width: 4.6rem;
  height: 4.6rem;
  outline: none;
  cursor: pointer;
  background-color: var(--color-white);
  border: 1px solid var(--border-color);
  border-radius: 50%;
  -webkit-transition: all 0.2s linear;
  -o-transition: all 0.2s linear;
  transition: all 0.2s linear;
}
.slider-arrow::before {
  content: "";
  display: block;
  width: 8px;
  height: 14px;
  background: url("../img/icons/chevron-right.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (min-width: 1200px) {
  .slider-arrow:hover {
    background-color: var(--color-accent-main);
    border-color: var(--color-accent-main);
  }
  .slider-arrow:hover::before {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
}
.slider-prev::before {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
.slider-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1rem;
}
.slider-dots .swiper-pagination-bullet {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  opacity: 1;
  width: 4.6em;
  height: 4.6em;
  margin: 0 !important;
  background: none;
  border-radius: 50%;
  border: 1px solid transparent;
  -webkit-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}
@media screen and (max-width: 767px) {
  .slider-dots .swiper-pagination-bullet {
    width: 2.4em;
    height: 2.4em;
  }
}
.slider-dots .swiper-pagination-bullet::before {
  content: "";
  display: block;
  width: 6px;
  height: 6px;
  background: #ABABAB;
  border-radius: 50%;
  -webkit-transition: all 0.1s;
  -o-transition: all 0.1s;
  transition: all 0.1s;
}
@media screen and (max-width: 767px) {
  .slider-dots .swiper-pagination-bullet::before {
    width: 4px;
    height: 4px;
  }
}
@media screen and (min-width: 1200px) {
  .slider-dots .swiper-pagination-bullet:hover::before {
    background: var(--color-accent-main);
  }
}
.slider-dots .swiper-pagination-bullet-active {
  background: none;
  border-color: var(--border-color);
}
.slider-dots .swiper-pagination-bullet-active::before {
  background: var(--color-accent-main);
}

.swiper-pagination-lock, .swiper-button-lock {
  display: none !important;
}

.swiper-mobile {
  overflow: visible;
}
@media (min-width: 1200px) {
  .swiper-mobile .swiper-wrapper {
    display: grid;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: auto;
    -webkit-transform: none !important;
        -ms-transform: none !important;
            transform: none !important;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .swiper-mobile .swiper-slide {
    height: auto;
  }
}
@media screen and (max-width: 1199px) {
  .swiper-mobile .swiper-wrapper {
    margin: 0;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }
  .swiper-mobile .swiper-slide {
    height: auto;
    padding: 0;
  }
}

@media screen and (min-width: 1200px) {
  .img-hover .img {
    will-change: transform;
    -webkit-transition: all 0.5s 0.1s linear;
    -o-transition: all 0.5s 0.1s linear;
    transition: all 0.5s 0.1s linear;
  }
  .img-hover:hover .img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-transition-duration: 2s;
         -o-transition-duration: 2s;
            transition-duration: 2s;
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
}

.bg-section {
  background-color: var(--bg-sections);
  color: var(--color-white);
}
.bg-section .slider-dots .swiper-pagination-bullet-active {
  border-color: rgba(239, 239, 239, 0.1);
}

.lang, .geo {
  display: inline-block;
  position: relative;
}
.lang__trigger, .geo__trigger {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1;
  position: relative;
  cursor: pointer;
}
.lang__trigger::after, .geo__trigger::after {
  content: "";
  display: block;
  width: 8px;
  height: 5px;
  position: absolute;
  top: 50%;
  margin-top: -1px;
  background: url("../img/icons/chevron-down-sm.svg") no-repeat 50% 50%/contain;
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  -o-transition: transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}
.lang .list, .geo .list {
  width: 100%;
  position: absolute;
  z-index: 2;
  top: 100%;
  left: 0;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(-20%);
      -ms-transform: translateY(-20%);
          transform: translateY(-20%);
  -webkit-transition: all 0.1s;
  -o-transition: all 0.1s;
  transition: all 0.1s;
}
.lang .list a, .geo .list a {
  display: block;
}

.lang {
  height: 34px;
  background-color: #0D4A4E;
  -webkit-transition: background-color 0.2s;
  -o-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
.lang__trigger {
  min-width: 61px;
  height: 100%;
  padding: 1rem 3.2rem 1rem 1.2rem;
}
.lang__trigger::after {
  right: 1.2rem;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.lang .list {
  background-color: var(--color-accent-main);
}
.lang .list a {
  padding: 1rem 1.2rem;
}
.lang .list a:hover {
  color: var(--color-white);
}
@media screen and (min-width: 1200px) {
  .lang:hover {
    background-color: var(--color-accent-main);
  }
}
.lang.is-open {
  background-color: var(--color-accent-main);
}
.lang.is-open .lang__trigger::after {
  -webkit-transform: rotate(-180deg);
      -ms-transform: rotate(-180deg);
          transform: rotate(-180deg);
}
.lang.is-open .list {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition-duration: 0.3s;
       -o-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

.geo__trigger {
  padding-right: 2rem;
}
.geo__trigger::after {
  right: 0;
}
.geo .list {
  font-size: 1.4rem;
}
.geo .list li {
  margin-top: 1rem;
}
@media screen and (min-width: 1200px) {
  .geo:hover .geo__trigger {
    color: var(--color-accent-main);
  }
  .geo:hover .geo__trigger::after {
    -webkit-transform: rotate(-180deg);
        -ms-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
  .geo:hover .list {
    opacity: 1;
    visibility: visible;
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition-duration: 0.3s;
         -o-transition-duration: 0.3s;
            transition-duration: 0.3s;
  }
  .geo .list a:hover {
    color: var(--color-accent-main);
  }
}

.border-list {
  padding: 3rem 0;
  border-top: 1px solid #E2E5EB;
  border-bottom: 1px solid #E2E5EB;
}
@media screen and (max-width: 1023px) {
  .border-list {
    border-bottom: none;
  }
}
@media screen and (max-width: 767px) {
  .border-list {
    padding: 1.9rem 0;
  }
}
.border-list li {
  margin-bottom: 2.7rem;
  padding-bottom: 2.7rem;
  border-bottom: 1px solid #E2E5EB;
}
@media screen and (max-width: 767px) {
  .border-list li {
    margin-bottom: 1.9rem;
    padding-bottom: 2.1rem;
  }
}
.border-list li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

.download-link {
  display: block;
  width: 100%;
  max-width: 35rem;
  height: 22.8rem;
  padding: 4rem 5rem 8rem 5rem;
  background-color: var(--bg);
  position: relative;
  color: var(--color-title);
}
@media screen and (max-width: 767px) {
  .download-link {
    height: 15.8rem;
    padding: 1.5rem 1.6rem 7rem 1.6rem;
  }
}
@media screen and (min-width: 1200px) {
  .download-link:hover {
    color: var(--color-accent-main);
  }
}
.download-link::before {
  content: "";
  display: block;
  width: 2.5rem;
  height: 3.5rem;
  position: absolute;
  z-index: 0;
  left: 5rem;
  background: url("../img/icons/download-link.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 767px) {
  .download-link::before {
    left: 1.6rem;
  }
}
.download-link .ext {
  position: absolute;
  right: 5rem;
  background-color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .download-link .ext {
    right: 1.6rem;
  }
}
.download-link::before, .download-link .ext {
  bottom: 3.7rem;
}
@media screen and (max-width: 767px) {
  .download-link::before, .download-link .ext {
    bottom: 2.7rem;
  }
}

.download-block {
  max-width: 100%;
  height: 35rem;
}
@media screen and (max-width: 767px) {
  .download-block {
    height: 22rem;
  }
}
.download-block__img {
  width: 15rem;
  height: 9rem;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .download-block__img {
    width: 11.4rem;
    height: 6.8rem;
  }
}

.ext {
  display: inline-block;
  padding: 0.65rem 1.6rem;
  font-weight: 500;
  color: var(--color-sub);
}

.js-tab-content, .js-accordion-content {
  display: none;
}

.js-open-modal, .js-tab, .js-accordion-btn,
.home .header.is-fixed .logo, .home .footer .logo {
  cursor: pointer;
}

.overlay {
  position: fixed;
  background-color: rgba(0, 0, 0, 0.4);
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  visibility: hidden;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
  opacity: 0;
}
.overlay.is-show {
  opacity: 1;
  z-index: 8;
  visibility: visible;
}

.more-container .is-hidden {
  display: none;
}

.quotes {
  display: block;
  font-size: 1rem;
  width: 7.7em;
  height: 5.8em;
  background: url("../img/icons/quotes-green.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 767px) {
  .quotes {
    width: 5.6rem;
    height: 4.2rem;
  }
}

.label-date, .label-type {
  padding: 0.65rem 1.8rem;
  font-weight: 500;
}

.label-date {
  background-color: var(--color-white);
  color: var(--color-sub);
}
.label-date.bg-gray {
  background-color: var(--bg);
}

.label-type {
  background-color: var(--color-accent-add);
  color: var(--color-white);
}

.tag {
  display: inline-block;
  font-size: 1.5rem;
  padding: 0.3em 1.4rem;
  color: #004045;
  border: 1px solid #004045;
}
@media screen and (max-width: 767px) {
  .tag {
    font-size: 1.4rem;
  }
}

.section-text {
  margin: 12.5rem 0;
}
@media screen and (max-width: 767px) {
  .section-text {
    margin: 5.2rem 0;
  }
  .section-text .column {
    margin-bottom: 2.6rem;
  }
  .section-text .column:last-child {
    margin-bottom: 0;
  }
}
.section-text .fw-500 .title {
  font-weight: 400;
}
.section-text .border-list {
  border: none;
  padding: 0;
}
.section-text .border-list li {
  margin-bottom: 1.5rem;
  padding-bottom: 1.2rem;
}
@media screen and (max-width: 767px) {
  .section-text .border-list li {
    margin-bottom: 1.1rem;
  }
}
.section-text__subtitle {
  max-width: 100rem;
  margin-bottom: 1.8em;
}
@media screen and (max-width: 1023px) {
  .section-text__grid {
    display: grid;
    gap: 5rem;
  }
  .section-text__grid .column {
    margin: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-text__grid {
    gap: 3.5rem;
  }
}

.section-title {
  max-width: 74rem;
  margin-bottom: 0.3em;
}
@media screen and (max-width: 767px) {
  .section-title {
    margin-bottom: 0.5em;
  }
}

@media screen and (min-width: 1024px) {
  .grid-reverse > *:first-child {
    grid-column-start: 2;
  }
  .grid-reverse > *:nth-child(2) {
    grid-row-start: 1;
  }
}

.accordion-item {
  margin-bottom: 1.7rem;
  padding-bottom: 2.2rem;
  border-bottom: 1px solid #E2E5EB;
}
@media screen and (max-width: 767px) {
  .accordion-item {
    margin-bottom: 2.1rem;
    padding-bottom: 1.7rem;
  }
}
.accordion-btn {
  position: relative;
  padding-right: 4rem;
}
.accordion-btn::before, .accordion-btn::after {
  content: "";
  display: block;
  width: 22px;
  height: 20px;
  position: absolute;
  z-index: 0;
  right: 0;
  top: 4px;
  background: url("../img/icons/plus-line.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.15s;
  -o-transition: all 0.15s;
  transition: all 0.15s;
}
@media screen and (max-width: 767px) {
  .accordion-btn::before, .accordion-btn::after {
    top: 3px;
  }
}
.accordion-btn::after {
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}
.accordion-btn.is-active::before {
  opacity: 0;
}
.accordion-btn.is-active::after {
  -webkit-transform: rotate(0deg);
      -ms-transform: rotate(0deg);
          transform: rotate(0deg);
}
.accordion-content {
  padding-top: 1rem;
  padding-bottom: 0.5rem;
}

.a-block .accordion-item, .g-block .accordion-item, .bg-section .accordion-item {
  border-bottom-color: var(--color-white) !important;
}
.a-block .accordion-btn::before, .a-block .accordion-btn::after, .g-block .accordion-btn::before, .g-block .accordion-btn::after, .bg-section .accordion-btn::before, .bg-section .accordion-btn::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

/* -------------------------------------
 * modules
 * ------------------------------------- */
/* ----- Forms ----- */
*::-webkit-input-placeholder {
  color: var(--color-title);
  opacity: 1;
  -webkit-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
*::-moz-placeholder {
  color: var(--color-title);
  opacity: 1;
  -moz-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
*:-ms-input-placeholder {
  color: var(--color-title);
  opacity: 1;
  -ms-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
*::-ms-input-placeholder {
  color: var(--color-title);
  opacity: 1;
  -ms-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
*::placeholder {
  color: var(--color-title);
  opacity: 1;
  -webkit-transition: all 0.1s linear;
  -o-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
/*

body input:focus:required:invalid, body textarea:focus:required:invalid,
body input:required:valid, body textarea:required:valid {
  color: var(--color-title);
}

*/
.input {
  display: block;
  width: 100%;
  min-width: 1px;
  height: 42px;
  padding: 0 0 24px;
  background: #FFF;
  border: none;
  border-radius: 0 !important;
  border-bottom: 1px solid #373042;
  color: var(--color-title);
  font-size: 18px;
  letter-spacing: -0.02em;
  -webkit-transition: all 0.1s linear;
  -o-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
@media screen and (max-width: 767px) {
  .input {
    height: 39px;
    padding-bottom: 15px;
    font-size: 16px;
  }
}
.input:hover {
  border-bottom-color: var(--color-accent-add);
}
.input:focus {
  outline: none;
  border-bottom-color: var(--color-accent-add);
}
.input:focus::-webkit-input-placeholder {
  opacity: 0;
}
.input:focus::-moz-placeholder {
  opacity: 0;
}
.input:focus:-ms-input-placeholder {
  opacity: 0;
}
.input:focus::-ms-input-placeholder {
  opacity: 0;
}
.input:focus::placeholder {
  opacity: 0;
}
.input--err {
  border-bottom-color: #E51B1B;
  color: #E51B1B;
}
.input--err ~ .placeholder {
  color: #E51B1B;
}

textarea.input {
  height: 11rem;
  resize: none;
}
@media screen and (max-width: 767px) {
  textarea.input {
    height: 10rem;
  }
}

.input-wrap {
  position: relative;
  z-index: 1;
  background: #FFF;
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 767px) {
  .input-wrap {
    margin-bottom: 2rem;
  }
}
.input-wrap .input {
  background: none;
}
.input-wrap .input:focus, .input-wrap .input.is-populated {
  padding-top: 14px;
  padding-bottom: 10px;
}
.input-wrap .input:focus ~ .placeholder, .input-wrap .input.is-populated ~ .placeholder {
  top: -4px;
  font-size: 12px;
  color: #A2A2A7;
  z-index: 1;
}

.placeholder {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  font-size: 18px;
  line-height: 1;
  color: var(--color-title);
  white-space: nowrap;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (max-width: 767px) {
  .placeholder {
    font-size: 16px;
  }
}

@media screen and (min-width: 768px) {
  .form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 4rem;
  }
}

.wpcf7-acceptance {
  display: block;
  margin: 20px 0;
}
.wpcf7-acceptance label {
  display: block;
  cursor: pointer;
}
.wpcf7-acceptance .wpcf7-list-item-label {
  display: inline-block;
  position: relative;
  padding-left: 31px;
  font-size: 13px;
  color: #A2A2A7;
}
.wpcf7-acceptance .wpcf7-list-item-label::before, .wpcf7-acceptance .wpcf7-list-item-label::after {
  content: "";
  display: block;
  position: absolute;
}
.wpcf7-acceptance .wpcf7-list-item-label::before {
  width: 17px;
  height: 17px;
  background-color: #F6F6F6;
  border-radius: 3px;
  border: none;
  top: 0;
  left: 0;
}
.wpcf7-acceptance .wpcf7-list-item-label::after {
  top: 4px;
  left: 4px;
  width: 9px;
  height: 9px;
  background: var(--color-accent-main);
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  border-radius: 2px;
  will-change: transform;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (min-width: 1200px) {
  .wpcf7-acceptance .wpcf7-list-item-label a:hover, .wpcf7-acceptance .wpcf7-list-item-label span:hover {
    color: var(--color-accent-main);
  }
}
.wpcf7-acceptance input {
  display: none;
}
.wpcf7-acceptance input:checked ~ .wpcf7-list-item-label::after {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.checkbox {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  margin: 0;
}
.checkbox__wrap {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 17px;
  min-width: 17px;
  height: 17px;
  margin-right: 14px;
  background-color: var(--color-white);
  border-radius: 3px;
  -webkit-transition: 0.2s ea -out;
  -o-transition: 0.2s ea -out;
  transition: 0.2s ea -out;
}
.checkbox__wrap::after {
  content: "";
  display: block;
  width: 9px;
  height: 9px;
  background: var(--color-accent-main);
  -webkit-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  border-radius: 2px;
  will-change: transform;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
.checkbox input {
  display: none;
}
.checkbox input:checked ~ .checkbox__wrap::after {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.attachment {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 2rem 0;
  padding: 18px 24px;
  border: 1px dashed #A2A2A7;
  position: relative;
}
@media screen and (max-width: 767px) {
  .attachment {
    padding: 18px 7px 18px 14px;
  }
}
@media screen and (min-width: 1200px) {
  .attachment:hover::before {
    opacity: 1 !important;
  }
}
.attachment::before {
  content: "";
  display: block;
  width: 24px;
  min-width: 24px;
  height: 24px;
  margin-right: 16px;
  background: url("../img/icons/attach.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.15s;
  -o-transition: all 0.15s;
  transition: all 0.15s;
  -webkit-filter: invert(1);
          filter: invert(1);
  opacity: 0.35;
}
@media screen and (max-width: 767px) {
  .attachment::before {
    margin-right: 10px;
  }
}
.attachment .msg {
  font-size: 18px;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .attachment .msg {
    font-size: 16px;
  }
}
.attachment input {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  background: none;
  border: none;
  left: 0;
  top: 0;
  opacity: 0 !important;
  cursor: pointer;
  font-size: 0;
}

.submit {
  margin-top: 1rem;
}
@media screen and (max-width: 767px) {
  .submit {
    width: 100%;
    margin-top: 0.5rem;
  }
}

.select {
  position: relative;
  font-weight: 500;
}
.select__trigger {
  display: block;
  position: relative;
  padding: 1.7rem 40px 1.7rem 18px;
  background: var(--bg);
  border: 1px solid var(--border-color);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  -o-text-overflow: ellipsis;
     text-overflow: ellipsis;
}
@media screen and (max-width: 767px) {
  .select__trigger {
    padding: 1rem 35px 1rem 16px;
  }
}
@media screen and (min-width: 1200px) {
  .select__trigger:hover {
    color: var(--color-accent-main);
  }
}
.select__trigger::after {
  position: absolute;
  display: block;
  content: "";
  width: 8px;
  height: 5px;
  top: 50%;
  right: 26px;
  margin-top: -3px;
  background: url("../img/icons/chevron-down-sm.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .select__trigger::after {
    right: 22px;
  }
}
.select__options {
  position: absolute;
  display: block;
  padding-bottom: 1rem;
  top: 100%;
  left: 0;
  right: 0;
  min-width: 100%;
  background: var(--bg);
  border: 1px solid var(--border-color);
  border-top: none;
  -webkit-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  -webkit-transform: translateY(-10px);
      -ms-transform: translateY(-10px);
          transform: translateY(-10px);
  z-index: 2;
}
.select__option {
  position: relative;
  display: block;
  padding: 0.95rem 18px;
  cursor: pointer;
  -webkit-transition: all 0.2s ease-in-out;
  -o-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .select__option {
    padding: 1rem 16px;
  }
}
@media screen and (min-width: 1200px) {
  .select__option:hover {
    color: var(--color-accent-add);
  }
}
.select__option.is-selected {
  background: var(--color-white);
  color: var(--color-accent-add);
}
.select.is-opened .select__trigger::after {
  -webkit-transform: rotate(-180deg);
      -ms-transform: rotate(-180deg);
          transform: rotate(-180deg);
}
.select.is-opened .select__options {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  -webkit-transform: translateY(-1px);
      -ms-transform: translateY(-1px);
          transform: translateY(-1px);
}

.bg-section .modal-side__subtitle, .bg-section .wpcf7-acceptance .wpcf7-list-item-label {
  color: rgba(255, 255, 255, 0.5);
}
.bg-section .input-wrap {
  background: var(--bg-sections);
}
.bg-section .input, .bg-section .placeholder {
  color: var(--color-white);
}
.bg-section .input {
  border-color: rgba(255, 255, 255, 0.5);
}
.bg-section .wpcf7-acceptance .wpcf7-list-item-label::before {
  background-color: #0D4A4E;
}
.bg-section .attachment {
  border-color: rgba(255, 255, 255, 0.5);
}
.bg-section .attachment::before {
  -webkit-filter: none;
          filter: none;
  opacity: 0.5;
}
.bg-section .attachment .msg {
  opacity: 0.5;
}

.modal {
  display: none;
  width: 100%;
  margin: 0 auto;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.modal-side {
  height: 100%;
  max-width: 80.4rem;
  margin-right: 0;
  padding: 7rem 20px;
}
@media screen and (max-width: 767px) {
  .modal-side {
    min-height: 700px;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 7rem 20px 3rem;
  }
}
@media screen and (min-width: 1024px) {
  .modal-side {
    padding: 4rem 9rem;
  }
}
@media screen and (min-width: 1600px) {
  .modal-side {
    padding: 12rem 9.4rem;
  }
}
@media screen and (max-width: 767px) {
  .modal-side .fancybox-close-small {
    top: 10px;
  }
}
.modal-side .logo {
  position: absolute;
  top: 14px;
  left: 20px;
}
.modal-side .logo img {
  max-width: 10.2rem;
  max-height: 3.7rem;
}
@media screen and (max-width: 767px) {
  .modal-side .logo {
    top: 18px;
    left: 14px;
  }
  .modal-side .logo img {
    max-width: 6.6rem;
    max-height: 2.4rem;
  }
}
@media screen and (min-width: 768px) {
  .modal-side .logo {
    display: none;
  }
}
.modal-side-inner {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.modal-side__title {
  margin-bottom: 1rem;
}
@media screen and (max-width: 1023px) {
  .modal-side__title {
    margin-bottom: 2rem;
  }
}
.modal-side__subtitle {
  margin-bottom: 4rem;
}
@media screen and (min-width: 1024px) {
  .modal-side .form-col {
    width: 50%;
  }
}
.modal-side .input-wrap {
  margin-bottom: 1.8rem;
}
@media screen and (min-width: 1600px) {
  .modal-side .input-wrap {
    margin-bottom: 2.8rem;
  }
}
@media screen and (min-width: 1440px) {
  .modal-side .submit {
    margin-top: 3rem;
  }
}
.modal-ceo {
  max-width: 137.2rem;
}
@media screen and (min-width: 768px) {
  .modal-ceo {
    padding-left: 5rem;
    padding-right: 6rem;
  }
}
@media screen and (min-width: 1200px) {
  .modal-ceo {
    padding-left: 8rem;
    padding-right: 9rem;
  }
}
@media screen and (max-width: 767px) {
  .modal-ceo .modal-side-inner {
    height: auto;
  }
}
.modal-ceo .modal-side__title {
  text-align: center;
}
@media screen and (max-width: 1023px) {
  .modal-ceo .modal-side__title {
    text-align: left;
  }
}
.modal-ceo-grid {
  display: grid;
  gap: 5.8rem;
  grid-template-columns: 7.7rem auto 61.6rem;
  margin-top: 6rem;
}
@media screen and (max-width: 1199px) {
  .modal-ceo-grid {
    gap: 4rem;
  }
}
@media screen and (max-width: 1023px) {
  .modal-ceo-grid {
    display: block;
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .modal-ceo-grid {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .modal-ceo .modal-side__title {
    margin-bottom: 3rem;
  }
}
@media screen and (max-width: 1023px) {
  .modal-ceo .quotes {
    margin-bottom: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .modal-ceo .modal-side__subtitle {
    margin-bottom: 2.4rem;
  }
}
.modal-ceo .submit {
  min-width: 24.8rem;
}
.modal-success {
  text-align: center;
}
.modal-success__img {
  margin-bottom: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.modal-success__subtitle {
  margin-bottom: 2rem;
}
.modal-success__btn .button {
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: var(--color-white);
}
.modal-center-css .fancybox-slide {
  text-align: center;
}

.modal-search {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  pointer-events: none;
  color: var(--color-white);
  opacity: 0;
  -webkit-transition: opacity 0.2s cubic-bezier(0.4, 0, 0.6, 1);
  -o-transition: opacity 0.2s cubic-bezier(0.4, 0, 0.6, 1);
  transition: opacity 0.2s cubic-bezier(0.4, 0, 0.6, 1);
}
.modal-search::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
  -webkit-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
       -o-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
          transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
}
.modal-search__header {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  padding: 2.1rem 0;
}
@media screen and (max-width: 767px) {
  .modal-search__header {
    padding: 1.5rem 0;
  }
}
.modal-search__header .flex {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.modal-search__header .logo img {
  max-width: 10.4rem;
  max-height: 3.8rem;
}
@media screen and (max-width: 767px) {
  .modal-search__header .logo img {
    max-width: 6.6rem;
    max-height: 2.4rem;
  }
}
.modal-search .close {
  opacity: 0;
  -webkit-transition: opacity 0.6s;
  -o-transition: opacity 0.6s;
  transition: opacity 0.6s;
  -webkit-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
       -o-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
          transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
}
.modal-search__inner {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 50%;
  padding: 6rem;
  background: #f0f0f0;
  -webkit-transition: -webkit-transform 0.6s;
  transition: -webkit-transform 0.6s;
  -o-transition: transform 0.6s;
  transition: transform 0.6s;
  transition: transform 0.6s, -webkit-transform 0.6s;
  -webkit-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
       -o-transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
          transition-timing-function: cubic-bezier(0.2, 1, 0.3, 1);
}
@media screen and (max-width: 1199px) {
  .modal-search__inner {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .modal-search__inner {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.modal-search__top {
  -webkit-transform: translate3d(0, -100%, 0);
          transform: translate3d(0, -100%, 0);
  background-color: #004045;
}
@media screen and (max-width: 767px) {
  .modal-search__top {
    height: 45%;
    padding-bottom: 3rem;
  }
}
.modal-search__bottom {
  -webkit-transform: translate3d(0, 100%, 0);
          transform: translate3d(0, 100%, 0);
  background-color: #0D4A4E;
  top: 50%;
}
@media screen and (max-width: 767px) {
  .modal-search__bottom {
    top: 45%;
    height: 55%;
    padding-top: 2rem;
    padding-bottom: 2rem;
  }
}
.modal-search__center {
  width: 100%;
  max-width: 78rem;
  margin: 0 auto;
}
.modal-search .search-form__input .input {
  color: var(--color-white) !important;
  border-bottom-color: var(--color-white);
}
.modal-search .search-form__input .input::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.modal-search .search-form__input .input::-moz-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.modal-search .search-form__input .input:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.modal-search .search-form__input .input::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.modal-search .search-form__input .input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.search-form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.search-form__input {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
  margin-right: 2.8rem;
  height: 8.6rem;
}
@media screen and (max-width: 767px) {
  .search-form__input {
    height: 4.2rem;
    margin-right: 1.4rem;
  }
}
.search-form__input .input {
  height: 100%;
  padding: 0 0 24px;
  background-color: transparent;
  font-size: 6rem;
  border-bottom: 2px solid var(--color-title);
  letter-spacing: -0.04em;
  font-family: var(--title-font);
}
@media screen and (max-width: 767px) {
  .search-form__input .input {
    font-size: 3rem;
    padding: 0 0 12px;
  }
}
.search-form__btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 8.6rem;
  min-width: 8.6rem;
  height: 8.6rem;
  background-color: var(--color-accent-main);
  border-radius: 50%;
  -webkit-transition: background-color 0.2s;
  -o-transition: background-color 0.2s;
  transition: background-color 0.2s;
}
@media screen and (max-width: 767px) {
  .search-form__btn {
    width: 4.2rem;
    min-width: 4.2rem;
    height: 4.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .search-form__btn:hover {
    background-color: var(--color-accent-add);
  }
}
.search-form__btn::before {
  content: "";
  display: block;
  width: 3.4rem;
  height: 3.4rem;
  background: url("../img/icons/search-accent.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
@media screen and (max-width: 767px) {
  .search-form__btn::before {
    width: 2.2rem;
    height: 2.2rem;
  }
}

.search-open {
  overflow: hidden;
}
.search-open .header .menu {
  visibility: hidden;
}
.search-open .modal-search {
  opacity: 1;
  pointer-events: auto;
}
.search-open .modal-search::before, .search-open .modal-search .close {
  opacity: 1;
}
.search-open .modal-search__inner {
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

.search-rec__title {
  margin-bottom: 2rem;
}
.search-rec__list li {
  margin: 0 10px 10px 0;
}
@media screen and (max-width: 767px) {
  .search-rec__list li {
    margin: 0 5px 5px 0;
  }
}
.search-rec__list a {
  padding-left: 2rem;
  padding-right: 2rem;
}
@media screen and (max-width: 767px) {
  .search-rec__list a {
    font-size: 1.4rem;
    padding: 1rem 1.6rem;
    height: auto;
  }
}
.search-rec__list .button-white-bd {
  border-color: rgba(255, 255, 255, 0.1);
}
@media screen and (min-width: 1200px) {
  .search-rec__list .button-white-bd:hover {
    border-color: var(--color-white);
  }
}

/* ----- breadcrumbs ----- */
.breadcrumbs {
  width: 100%;
  margin: 1.4rem 0 2rem;
  font-size: 1.3rem;
  color: #BABABA;
}
@media screen and (max-width: 767px) {
  .breadcrumbs {
    margin: 0.6rem 0 1.5rem;
    font-size: 1.2rem;
  }
}
.breadcrumbs > span, .breadcrumbs > .container > span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.breadcrumbs > span > span:first-child, .breadcrumbs > .container > span > span:first-child {
  display: block;
  width: 1.25em;
  min-width: 1.25em;
  height: 1.25em;
  background: url("../img/icons/home.svg") no-repeat 50% 50%/12px 11px;
  opacity: 0.3;
  -webkit-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
@media screen and (min-width: 1200px) {
  .breadcrumbs > span > span:first-child:hover, .breadcrumbs > .container > span > span:first-child:hover {
    opacity: 1;
  }
}
.breadcrumbs > span > span:first-child a, .breadcrumbs > .container > span > span:first-child a {
  display: block;
  height: 100%;
}
@media screen and (min-width: 1200px) {
  .breadcrumbs a:hover {
    color: var(--color-accent-main);
  }
}
.breadcrumbs__sep {
  display: inline-block;
  font-size: 3px;
  width: 1em;
  min-width: 1em;
  height: 1em;
  margin: 0 1.4rem;
  background-color: #4C797C;
  border-radius: 50%;
  position: relative;
}
@media screen and (max-width: 767px) {
  .breadcrumbs__sep {
    margin: 0 1rem;
  }
}

.hero .breadcrumbs {
  margin-bottom: auto;
  color: rgba(255, 255, 255, 0.3);
}

.pagination {
  margin-top: 5.2rem;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .pagination {
    margin-top: 4rem;
  }
}
.pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.pagination .page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 46px;
  height: 46px;
  padding: 10px;
  border-radius: 50%;
  color: var(--color-title);
}
.pagination .page-numbers.current {
  background-color: var(--bg);
}
@media screen and (min-width: 1200px) {
  .pagination a:hover {
    color: var(--color-accent-main);
  }
}
.pagination .prev, .pagination .next {
  font-size: 0;
  color: transparent;
  border: 1px solid var(--border-color);
}
.pagination .prev::before, .pagination .next::before {
  content: "";
  display: block;
  width: 8px;
  height: 14px;
  background: url("../img/icons/chevron-right.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.1s linear;
  -o-transition: all 0.1s linear;
  transition: all 0.1s linear;
}
@media screen and (min-width: 1200px) {
  .pagination .prev:hover, .pagination .next:hover {
    border-color: var(--color-accent-main);
  }
}
@media screen and (min-width: 768px) {
  .pagination .prev {
    margin-right: 1.8rem;
  }
}
.pagination .prev::before {
  -webkit-transform: rotate(180deg);
      -ms-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
  .pagination .next {
    margin-left: 1.8rem;
  }
}
.pagination .screen-reader-text {
  display: none;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fadeInBottom {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 80px, 0);
            transform: translate3d(0, 80px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@keyframes fadeInBottom {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 80px, 0);
            transform: translate3d(0, 80px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-40px, 0, 0);
            transform: translate3d(-40px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-40px, 0, 0);
            transform: translate3d(-40px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@-webkit-keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(40px, 0, 0);
            transform: translate3d(40px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
@keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(40px, 0, 0);
            transform: translate3d(40px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
  }
}
.animated {
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
}
.animated.infinite {
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}

.fadeIn,
.fadeInBottom,
.fadeInLeft,
.fadeInRight {
  -webkit-animation-duration: 700ms;
          animation-duration: 700ms;
}

.fadeIn {
  -webkit-animation-name: fadeIn;
          animation-name: fadeIn;
}

.fadeInBottom {
  -webkit-animation-name: fadeInBottom;
          animation-name: fadeInBottom;
}

.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
          animation-name: fadeInLeft;
}

.fadeInRight {
  -webkit-animation-name: fadeInRight;
          animation-name: fadeInRight;
}

.fancybox-fx-slide-in-out.fancybox-slide--previous {
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
}

.fancybox-fx-slide-in-out.fancybox-slide--next {
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
}

.fancybox-fx-slide-in-out.fancybox-slide--current {
  -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}

.js-anim-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  opacity: 0;
}
.js-anim-title * {
  letter-spacing: -0.04em;
}
.js-anim-title > * {
  overflow: hidden;
  display: block;
  margin-right: 0.2em;
}
.js-anim-title > * span {
  display: inline-block;
  -webkit-transform: translate3d(0, 100%, 0);
          transform: translate3d(0, 100%, 0);
  -webkit-transition: -webkit-transform 0.3s linear;
  transition: -webkit-transform 0.3s linear;
  -o-transition: transform 0.3s linear;
  transition: transform 0.3s linear;
  transition: transform 0.3s linear, -webkit-transform 0.3s linear;
}
.js-anim-title .br {
  width: 100%;
}
.js-anim-title.animated {
  opacity: 1;
}
.js-anim-title.animated > * span {
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

[class*=hero-anim-] {
  opacity: 0;
  -webkit-transform: translate3d(0, 30px, 0);
          transform: translate3d(0, 30px, 0);
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  transition: all 0.3s linear;
  will-change: opacity, transform;
}

.breadcrumbs {
  opacity: 0;
  -webkit-transition: opacity 0.3s linear;
  -o-transition: opacity 0.3s linear;
  transition: opacity 0.3s linear;
}

.hero-anim-1 {
  -webkit-transition-delay: 0.2s;
       -o-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.hero-anim-2, .breadcrumbs {
  -webkit-transition-delay: 0.3s;
       -o-transition-delay: 0.3s;
          transition-delay: 0.3s;
}

.hero-anim-3 {
  -webkit-transition-delay: 0.4s;
       -o-transition-delay: 0.4s;
          transition-delay: 0.4s;
}

.hero-anim-4 {
  -webkit-transition-delay: 0.5s;
       -o-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.is-ready .header {
  top: 0;
}
.is-ready .breadcrumbs {
  opacity: 1;
}
.is-ready [class*=hero-anim-] {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

/* -------------------------------------
 * sections
 * ------------------------------------- */
/* ----- header ----- */
.header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9;
  color: var(--color-white);
  background: var(--bg-sections);
  -webkit-transition: all 0.3s linear;
  -o-transition: all 0.3s linear;
  transition: all 0.3s linear;
}
.header--transparent {
  background-color: transparent;
}
@media screen and (min-width: 1200px) {
  .header--transparent:hover {
    -webkit-transition-duration: 0.1s;
         -o-transition-duration: 0.1s;
            transition-duration: 0.1s;
    background: var(--bg-sections);
  }
}
@media screen and (max-width: 1199px) {
  .header {
    padding: 2.4rem 0;
    top: -7.8rem;
  }
}
@media screen and (max-width: 767px) {
  .header {
    padding: 1.4rem 0;
    top: -6.1rem;
  }
}
@media screen and (min-width: 1200px) {
  .header {
    top: -8.6rem;
  }
}
.header.is-fixed {
  background: rgba(0, 64, 69, 0.95) !important;
}
@media screen and (min-width: 1200px) {
  .header.is-fixed {
    -webkit-backdrop-filter: blur(10px);
            backdrop-filter: blur(10px);
  }
  .header.is-fixed .menu-list > .menu-item-has-children > .sub-menu {
    background: rgba(0, 64, 69, 0.95);
  }
  .header.is-fixed .menu-list > .menu-item-has-children > .sub-menu::before, .header.is-fixed .menu-list > .menu-item-has-children > .sub-menu::after {
    background: rgba(0, 64, 69, 0.95);
  }
  .header.is-fixed .menu-list > .menu-item-has-children > span {
    padding: 2.4rem 0;
  }
  .header.is-fixed .menu-list > li > a {
    padding: 2.4rem 0;
  }
}
.header__row {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header .logo {
  position: relative;
  top: -3px;
  margin-right: auto;
}
@media screen and (min-width: 1200px) {
  .header .logo {
    margin-right: 2.4rem;
  }
}
@media screen and (min-width: 1440px) {
  .header .logo {
    margin-right: 4.6rem;
  }
}
.header .logo img {
  max-width: 10.4rem;
  max-height: 3.8rem;
}
@media screen and (max-width: 767px) {
  .header .logo img {
    max-width: 6.6rem;
    max-height: 2.4rem;
  }
}
@media screen and (max-width: 1199px) {
  .header .button-plus {
    padding: 1.1rem 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    font-family: var(--title-font);
    color: var(--color-accent-add);
  }
}
@media screen and (min-width: 1200px) {
  .header .geo {
    margin-left: auto;
    margin-right: 3rem;
  }
  .header .geo .menu-item-has-children::after {
    right: -1.6rem;
  }
}
@media screen and (min-width: 1440px) {
  .header .geo {
    margin-right: 5rem;
  }
}
@media screen and (min-width: 1200px) {
  .header .tel {
    margin-right: 2.4rem;
  }
}
@media screen and (min-width: 1440px) {
  .header .tel {
    margin-right: 5.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .header .tel a:hover {
    color: var(--color-accent-main);
  }
}
.header-controls {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 1199px) {
  .header-controls {
    height: 5.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding: 0 14px;
  }
  .header-controls .lang {
    height: auto;
  }
  .header-controls .lang::before, .header-controls .lang::after {
    content: "";
    display: block;
    width: 1px;
    height: 5.4rem;
    font-size: 16px;
    position: absolute;
    z-index: 0;
    top: -1rem;
    background: var(--color-white);
    opacity: 0.05;
  }
  .header-controls .lang::before {
    left: -1em;
  }
  .header-controls .lang::after {
    right: -1em;
  }
  .header-controls .lang .list {
    top: auto;
    bottom: 100%;
  }
  .header-controls .lang:not(.is-open) {
    background-color: transparent;
  }
  .header-controls .lang:not(.is-open) .list {
    -webkit-transform: translateY(20px);
        -ms-transform: translateY(20px);
            transform: translateY(20px);
  }
}
@media screen and (max-width: 1199px) and (max-width: 1199px) {
  .header-controls .lang {
    font-size: 1.5rem;
  }
}
.header-login::before {
  content: "";
  display: block;
  width: 14px;
  min-width: 14px;
  height: 16px;
  background: url("../img/icons/user-accent.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: -webkit-filter 0.15s;
  transition: -webkit-filter 0.15s;
  -o-transition: filter 0.15s;
  transition: filter 0.15s;
  transition: filter 0.15s, -webkit-filter 0.15s;
}
@media screen and (max-width: 1199px) {
  .header-login {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-size: 1.5rem;
  }
  .header-login::before {
    margin-right: 1.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .header-login {
    width: 20px;
    height: 20px;
    margin-right: 2.4rem;
  }
  .header-login::before {
    width: 100%;
    height: 100%;
  }
  .header-login:hover::before {
    -webkit-filter: none;
            filter: none;
  }
}
.header-search {
  width: 20px;
  height: 20px;
}
@media screen and (max-width: 767px) {
  .header-search {
    width: 22px;
    height: 22px;
  }
}
@media screen and (min-width: 1200px) {
  .header-search {
    margin-right: 2.4rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (min-width: 1440px) {
  .header-search {
    margin-right: 4.6rem;
  }
}
@media screen and (min-width: 1200px) {
  .header .theme-toggle {
    margin-left: 2.4rem;
  }
}
@media screen and (min-width: 1440px) {
  .header .theme-toggle {
    margin-left: 3.2rem;
  }
}
.header .button-phone {
  margin-left: 6.8rem;
}
@media screen and (max-width: 767px) {
  .header .button-phone {
    margin-left: 3.4rem;
  }
}

@media screen and (max-width: 1199px) {
  .menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    z-index: 98;
    width: 100%;
    max-width: 50%;
    max-height: 100vh;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 9.6rem 0 0;
    font-size: 2.4rem;
    background: var(--bg-sections);
    will-change: transform;
    -webkit-transform: translate3d(100%, 0, 0);
            transform: translate3d(100%, 0, 0);
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 300ms 0s cubic-bezier(0.4, 0, 0.6, 1);
    -o-transition: all 300ms 0s cubic-bezier(0.4, 0, 0.6, 1);
    transition: all 300ms 0s cubic-bezier(0.4, 0, 0.6, 1);
  }
  .menu-list {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }
  .menu-list > li {
    padding: 1rem 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
  .menu-list > li > a {
    font-family: var(--title-font);
  }
  .menu-list > .menu-item-has-children.is-open {
    background-color: rgba(13, 74, 78, 0.8);
  }
  .menu-list .menu-item-has-children {
    position: relative;
  }
  .menu-list .menu-item-has-children::before {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    position: absolute;
    z-index: 0;
    right: 47px;
    top: 0;
    background: rgba(255, 255, 255, 0.1);
  }
  .menu-list .menu-item-has-children > a, .menu-list .menu-item-has-children span {
    margin-right: 46px;
  }
  .menu-list .menu-item-has-children .title {
    font-family: var(--text-font);
  }
  .menu-list .menu-item-has-children .title .ic {
    display: none;
  }
  .menu-list .menu-item-has-children a {
    display: inline-block;
  }
  .menu-list .menu-item-has-children::after {
    content: "";
    display: block;
    position: absolute;
    right: 19px;
    top: 2.4rem;
    width: 12px;
    height: 6px;
    background: url("../img/icons/chevron-down.svg") no-repeat 50% 50%/contain;
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
  .menu-list .menu-item-has-children.is-open > a {
    color: var(--color-accent-add);
  }
  .menu-list .menu-item-has-children.is-open::after {
    -webkit-transform: rotate(-180deg);
        -ms-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
  .menu-list .menu-item-has-children .menu-item-has-children::before {
    display: none;
  }
  .menu-list .menu-item-has-children .menu-item-has-children::after {
    top: 1rem;
    right: 5px;
    opacity: 0.2;
  }
  .menu-list .menu-item-has-children .sub-menu-serives > .menu-item-has-children > a {
    font-size: 1.8rem;
  }
  .menu-list .menu-item-has-children .sub-menu-serives > .menu-item-has-children .menu-item-has-children::after {
    display: none;
  }
  .menu .geo {
    margin-top: auto;
    border: none;
    font-size: 1.5rem;
  }
  .menu .geo .menu-item-has-children {
    padding: 1.5rem 14px 1.2rem;
  }
  .menu .geo .menu-item-has-children::before {
    display: none;
  }
  .menu .geo .menu-item-has-children span {
    display: block;
    padding-bottom: 0.6rem;
  }
  .menu .geo .menu-item-has-children::after {
    top: 2.4rem;
  }
  .menu .geo .sub-menu {
    padding-left: 0;
  }
}
@media screen and (max-width: 1199px) and (max-width: 767px) {
  .menu {
    max-width: 100%;
    padding: 5.2rem 0 0;
    font-size: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
    max-width: 100%;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-weight: 600;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list > li {
    padding-right: 3rem;
  }
  .menu-list > li > a {
    display: block;
    padding: 3.1rem 0;
  }
}
@media screen and (min-width: 1400px) {
  .menu-list > li {
    padding-right: 3.3rem;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list > .menu-item-has-children > span {
    display: block;
    padding: 3.1rem 0;
    -webkit-transition: padding 0.2s;
    -o-transition: padding 0.2s;
    transition: padding 0.2s;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list > .menu-item-has-children::after {
    content: "";
    display: block;
    position: absolute;
    right: 1.6rem;
    width: 9px;
    height: 9px;
    background: url("../img/icons/chevron-down-sm.svg") no-repeat 50% 50%/contain;
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
  .menu-list > .menu-item-has-children:hover::after {
    -webkit-transform: rotate(-180deg);
        -ms-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
}
@media screen and (min-width: 1200px) {
  .menu-list > .menu-item-has-children > .sub-menu {
    padding-top: 2rem;
    padding-bottom: 4rem;
    background: var(--bg-sections);
  }
  .menu-list > .menu-item-has-children > .sub-menu::before, .menu-list > .menu-item-has-children > .sub-menu::after {
    content: "";
    display: block;
    width: 100vw;
    height: 100%;
    position: absolute;
    z-index: -1;
    top: 0;
    background: var(--bg-sections);
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
  .menu-list > .menu-item-has-children > .sub-menu::before {
    right: 100%;
  }
  .menu-list > .menu-item-has-children > .sub-menu::after {
    left: 100%;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list .menu-item-has-children {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    position: relative;
  }
  .menu-list .menu-item-has-children:hover > a,
  .menu-list .menu-item-has-children._hover > a {
    color: var(--color-accent-main);
  }
  .menu-list .menu-item-has-children:hover > .sub-menu,
  .menu-list .menu-item-has-children._hover > .sub-menu {
    -webkit-transform: none;
        -ms-transform: none;
            transform: none;
    -webkit-transition-duration: 200ms;
         -o-transition-duration: 200ms;
            transition-duration: 200ms;
    opacity: 1;
  }
  .menu-list .menu-item-has-children:hover > .menu-banner,
  .menu-list .menu-item-has-children._hover > .menu-banner {
    display: block;
    opacity: 1;
    visibility: visible;
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
}
@media screen and (min-width: 1200px) {
  .menu-list a:hover {
    color: var(--color-accent-main);
  }
}
.menu-toggle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  margin-left: 6.8rem;
}
.menu-toggle::before {
  content: "";
  display: block;
  font-size: 12px;
  width: 3.3em;
  height: 3.3em;
  background: url("../img/icons/menu-duo.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 767px) {
  .menu-toggle {
    margin-left: 3.4rem;
  }
  .menu-toggle::before {
    font-size: 10px;
  }
}
.menu-banner {
  display: none;
  pointer-events: none;
}
@media screen and (min-width: 1200px) {
  .menu-banner {
    position: fixed;
    width: 100%;
    top: 11rem;
    right: 0;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.2s 0s linear;
    -o-transition: all 0.2s 0s linear;
    transition: all 0.2s 0s linear;
  }
  .menu-banner a {
    display: block;
    font-size: 0.8rem;
    width: 31.5rem;
    height: 27.2rem;
    margin-left: auto;
    padding: 0 !important;
    position: relative;
    pointer-events: all;
  }
}
@media screen and (min-width: 1600px) {
  .menu-banner {
    font-size: 1rem;
  }
}
.menu-banner .title {
  position: absolute;
  left: 3rem;
  bottom: 2rem;
  color: var(--color-white);
}

@media screen and (max-width: 1199px) {
  .sub-menu {
    display: none;
    padding-left: 16px;
    font-size: 1.4rem;
  }
  .sub-menu > li a {
    display: block;
    padding: 0.8rem 0;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu {
    width: 93.8rem;
    position: absolute;
    z-index: 1;
    top: 100%;
    left: 0;
    -webkit-transform: scaleY(0);
        -ms-transform: scaleY(0);
            transform: scaleY(0);
    -webkit-transform-origin: 50% 0;
        -ms-transform-origin: 50% 0;
            transform-origin: 50% 0;
    opacity: 0;
    -webkit-transition: all 0ms cubic-bezier(0.4, 0, 0.6, 1);
    -o-transition: all 0ms cubic-bezier(0.4, 0, 0.6, 1);
    transition: all 0ms cubic-bezier(0.4, 0, 0.6, 1);
    font-size: 1.5rem;
  }
  .sub-menu > li {
    margin-bottom: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu .menu-item-has-children::after {
    content: "";
    display: block;
    margin-left: auto;
    width: 8px;
    min-width: 8px;
    height: 14px;
    background: url("../img/icons/chevron-right-accent.svg") no-repeat 50% 50%/contain;
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
    -webkit-filter: brightness(0) invert(1) opacity(0.2);
            filter: brightness(0) invert(1) opacity(0.2);
  }
  .sub-menu .menu-item-has-children:hover::after,
  .sub-menu .menu-item-has-children._hover::after {
    -webkit-filter: none;
            filter: none;
  }
  .sub-menu .menu-item-has-children:hover > .sub-menu,
  .sub-menu .menu-item-has-children._hover > .sub-menu {
    display: block;
  }
  .sub-menu .menu-item-has-children:hover > .sub-menu.sub-menu-industries,
  .sub-menu .menu-item-has-children._hover > .sub-menu.sub-menu-industries {
    display: grid;
  }
  .sub-menu .menu-item-has-children .menu-item-has-children {
    position: static;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu .title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    font-weight: 500;
  }
  .sub-menu .title .ic {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-right: 1.7rem;
    width: 3rem;
    height: 2.4rem;
    position: relative;
    top: -3px;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu .sub-menu {
    min-height: 100%;
    top: 0;
    left: 100%;
    padding-left: 6rem;
    width: auto;
    display: none;
    -webkit-transform: none;
        -ms-transform: none;
            transform: none;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu-serives {
    min-height: 36.2rem;
    height: var(--menu-services-height, 'auto');
  }
  .sub-menu-serives > li {
    width: 21rem;
    margin-bottom: 3.4rem;
  }
  .sub-menu-serives > li .sub-menu {
    min-width: 38rem;
  }
}
@media screen and (min-width: 1200px) {
  .sub-menu-industries {
    max-width: 48rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 3rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}

.morph-shape {
  position: fixed;
  z-index: -1;
  width: 50%;
  height: 100%;
  top: 0;
  right: 0;
  fill: var(--bg-sections);
  -webkit-transform: scale(-1);
      -ms-transform: scale(-1);
          transform: scale(-1);
  visibility: hidden;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .morph-shape {
    width: 100%;
  }
}

.show-menu .morph-shape {
  opacity: 1;
  visibility: visible;
}

.search-btn {
  width: 20px;
  height: 20px;
  background: url("../img/icons/search-accent.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: -webkit-filter 0.15s;
  transition: -webkit-filter 0.15s;
  -o-transition: filter 0.15s;
  transition: filter 0.15s;
  transition: filter 0.15s, -webkit-filter 0.15s;
}
@media screen and (min-width: 1200px) {
  .search-btn:hover {
    -webkit-filter: none;
            filter: none;
  }
}

.theme-toggle {
  width: 56px;
  min-width: 56px;
  height: 29px;
  cursor: pointer;
}
.theme-toggle__pseudo {
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(13, 74, 78, 0.8);
  border-radius: 100px;
  position: relative;
}
.theme-toggle__pseudo::before {
  content: "";
  display: block;
  width: 21px;
  height: 21px;
  position: absolute;
  z-index: 0;
  left: 5px;
  top: 4px;
  background: url("../img/icons/sun.svg") no-repeat 50% 50%/15px;
  background-color: var(--color-white);
  border-radius: 50%;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
.theme-toggle input {
  display: none;
}
.theme-toggle input:checked ~ .theme-toggle__pseudo::before {
  -webkit-transform: translateX(25px);
      -ms-transform: translateX(25px);
          transform: translateX(25px);
  background-color: #0A1820;
  background-image: url("../img/icons/moon.svg");
}

@media screen and (min-width: 1200px) {
  .compensate-for-scrollbar .header.is-fixed, .search-open .header.is-fixed {
    width: auto;
    right: 17px;
  }
}

.menu-expanded {
  overflow: hidden;
}
.menu-expanded .header .logo {
  z-index: 99;
}
.menu-expanded .menu {
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
  opacity: 1;
  visibility: visible;
  -webkit-transition-delay: 0.4s;
       -o-transition-delay: 0.4s;
          transition-delay: 0.4s;
}
.menu-expanded .overlay {
  opacity: 1;
  z-index: 8;
  visibility: visible;
}

/* ----- footer ----- */
.footer {
  padding: 3.2rem 0 0;
}
@media screen and (max-width: 767px) {
  .footer {
    padding: 2.7rem 0;
  }
}
.footer-anim {
  position: relative;
  z-index: -1;
}
.footer-anim-inner {
  width: 100%;
  height: auto;
  position: fixed;
  z-index: -1;
  left: 0;
  bottom: 0;
  padding: 3.2rem 0;
}
.footer-inner {
  margin-bottom: 5.8rem;
  padding: 5.4rem 5rem 4.1rem;
  background-color: rgba(13, 74, 78, 0.8);
}
@media screen and (max-width: 1023px) {
  .footer-inner {
    margin-bottom: 4.8rem;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .footer-inner {
    margin-bottom: 2rem;
  }
}
.footer-inner__row {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 1023px) {
  .footer-inner__row {
    display: block;
  }
}
@media screen and (max-width: 1023px) {
  .footer-inner__col {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }
  .footer-inner__col:last-child {
    border-bottom: none;
  }
}
@media screen and (min-width: 1024px) {
  .footer-inner__col {
    padding-right: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .footer-inner__col {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}
@media screen and (min-width: 1200px) {
  .footer-inner__col:nth-child(1) {
    max-width: 25rem;
  }
}
@media screen and (min-width: 1600px) {
  .footer-inner__col:nth-child(1) {
    max-width: 32rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer-inner__col:nth-child(5) {
    max-width: 15rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer-inner .title {
    margin-bottom: 1.8rem;
  }
}
.footer-inner a.title {
  display: inline-block;
}
@media screen and (max-width: 1199px) {
  .footer-inner a.title {
    display: block;
  }
}
@media screen and (min-width: 1024px) {
  .footer-inner .list li {
    margin-bottom: 1em;
  }
}
@media screen and (max-width: 1023px) {
  .footer-inner .js-footer-toggle, .footer-inner .list.title a {
    display: block;
    padding: 1rem 5rem 1rem 2rem;
  }
}
@media screen and (max-width: 767px) {
  .footer-inner .js-footer-toggle, .footer-inner .list.title a {
    padding-left: 1.6rem;
  }
}
@media screen and (max-width: 1023px) {
  .footer-inner .list.title a {
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }
  .footer-inner .list.title li:last-child a {
    border-bottom: none;
  }
}
@media screen and (max-width: 1023px) {
  .footer-inner .js-footer-toggle {
    position: relative;
  }
  .footer-inner .js-footer-toggle::before {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    position: absolute;
    z-index: 0;
    right: 46px;
    top: 0;
    background: rgba(255, 255, 255, 0.1);
  }
  .footer-inner .js-footer-toggle::after {
    content: "";
    display: block;
    width: 12px;
    height: 6px;
    position: absolute;
    z-index: 0;
    right: 2.3rem;
    top: 50%;
    margin-top: -3px;
    background: url("../img/icons/chevron-down.svg") no-repeat 50% 50%/contain;
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
  .footer-inner .js-footer-toggle.is-active::after {
    -webkit-transform: rotate(-180deg);
        -ms-transform: rotate(-180deg);
            transform: rotate(-180deg);
  }
}
@media screen and (max-width: 767px) {
  .footer-inner .js-footer-toggle::after {
    right: 1.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .footer-inner .js-footer-nav {
    display: none;
    padding: 0 1.75rem 2rem;
    position: relative;
  }
  .footer-inner .js-footer-nav::before {
    content: "";
    display: block;
    width: 1px;
    height: 100%;
    position: absolute;
    z-index: 0;
    right: 46px;
    top: 0;
    background: rgba(255, 255, 255, 0.1);
  }
  .footer-inner .js-footer-nav li {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 1023px) {
  .footer__row {
    display: block;
    padding-left: 2rem;
    padding-right: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .footer__row {
    padding-left: 1.6rem;
    padding-right: 1.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer__col {
    padding-right: 2rem;
  }
  .footer__col:last-child {
    padding-right: 0;
  }
}
@media screen and (min-width: 1024px) {
  .footer__col:nth-child(1) {
    min-width: 25rem;
  }
}
@media screen and (min-width: 1200px) {
  .footer__col:nth-child(1) {
    min-width: 30rem;
  }
}
@media screen and (min-width: 1600px) {
  .footer__col:nth-child(1) {
    min-width: 37rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer__col:nth-child(2) {
    min-width: 32rem;
  }
}
@media screen and (min-width: 1200px) {
  .footer__col:nth-child(2) {
    min-width: 37rem;
  }
}
@media screen and (min-width: 1400px) {
  .footer__col:nth-child(2) {
    min-width: 38.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer__col:last-child {
    margin-left: auto;
  }
}
.footer__col a.title {
  display: inline-block;
  margin-bottom: 0.1em;
}
@media screen and (max-width: 1023px) {
  .footer .grid, .footer .grid-lg {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .footer .grid .fz-36 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .footer .grid-lg {
    display: block;
  }
}
.footer-label {
  color: rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 767px) {
  .footer-label {
    font-size: 1.3rem;
  }
}
.footer .logo {
  max-width: 15rem;
}
@media screen and (max-width: 1023px) {
  .footer .logo {
    display: none;
  }
}
@media screen and (max-width: 1599px) {
  .footer .fz-36 {
    font-size: 3rem;
  }
}
@media screen and (max-width: 1023px) {
  .footer .address {
    margin-top: 1rem;
  }
}
.footer-btns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 1024px) {
  .footer-btns {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.footer-btns .lang {
  margin-left: 2.4rem;
}
.footer .soc {
  margin-top: 5.8rem;
}
@media screen and (max-width: 1023px) {
  .footer .soc {
    margin-top: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .footer .soc {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (min-width: 1024px) {
  .footer .soc {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.footer .soc li {
  margin-right: 1.3rem;
}
@media screen and (max-width: 767px) {
  .footer .soc li {
    margin-right: 1.1rem;
  }
}
.footer .soc li:last-child {
  margin-right: 0;
}
@media screen and (min-width: 1200px) {
  .footer a:hover {
    color: var(--color-accent-main);
  }
}
.footer__bottom {
  margin-top: 4rem;
  padding-bottom: 7rem;
}
@media screen and (max-width: 1023px) {
  .footer__bottom {
    margin-top: 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .footer__bottom {
    padding-top: 2.5rem;
    padding-bottom: 0;
    position: relative;
  }
  .footer__bottom::before {
    content: "";
    display: block;
    height: 1px;
    position: absolute;
    z-index: 0;
    left: -14px;
    right: -14px;
    top: 0;
    background: var(--color-white);
    opacity: 0.05;
  }
}
@media screen and (max-width: 1023px) {
  .footer__bottom .footer__col {
    margin-bottom: 1rem;
  }
}
.footer__bottom .lang {
  margin-bottom: 1.4rem;
}
@media screen and (min-width: 1200px) {
  .footer__bottom a:hover {
    color: var(--color-white);
  }
}
@media screen and (max-width: 767px) {
  .footer__bottom .footer-label {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .footer .dev {
    text-align: right;
  }
}

.maito {
  height: 34px;
  padding: 8px 1.6rem;
  border: 1px solid var(--color-white);
  line-height: 1;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .maito {
    width: 100%;
    height: auto;
    padding-top: 10px;
    padding-bottom: 11px;
  }
}
@media screen and (min-width: 1200px) {
  .maito:hover {
    background-color: var(--color-accent-main);
    border-color: var(--color-accent-main);
    color: var(--color-white) !important;
  }
}

.soc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.soc a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 4.9rem;
  height: 4.9rem;
  padding: 1.1rem 1rem;
  border: 1px solid rgba(217, 217, 217, 0.2);
  border-radius: 50%;
}
@media screen and (max-width: 767px) {
  .soc a {
    width: 4.2rem;
    height: 4.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .soc a:hover {
    background-color: var(--color-accent-main);
    border-color: var(--color-accent-main);
  }
}

.page-links {
  margin: 9rem 0 5.8rem;
}
@media screen and (max-width: 1023px) {
  .page-links {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .page-links {
    margin: 6.5rem 0 3.5rem;
  }
}
.page-links__title {
  margin-bottom: 0.6em;
}
@media screen and (max-width: 1023px) {
  .page-links-slider {
    overflow: visible;
  }
}
.page-links-slider .swiper-slide {
  height: auto;
}
@media screen and (max-width: 1023px) {
  .page-links-slider .swiper-slide {
    max-width: 32rem;
  }
}
@media screen and (max-width: 767px) {
  .page-links-slider .swiper-slide {
    max-width: 15.4rem;
  }
}
.page-links-slider .page-link {
  height: 100%;
}

.page-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 20.3rem;
  padding: 4.4rem 4.8rem 3.4rem;
}
@media screen and (max-width: 767px) {
  .page-link {
    min-height: 12.2rem;
    padding: 2rem 1.6rem;
    color: var(--color-white);
  }
  .page-link:hover {
    color: var(--color-white);
  }
}
@media screen and (min-width: 1200px) {
  .page-link:hover {
    color: var(--color-accent-main);
  }
}
.page-link__ic {
  width: 7rem;
  height: 4.2rem;
  margin-bottom: 2rem;
}
@media screen and (max-width: 767px) {
  .page-link__ic {
    width: 5rem;
    height: 2.9rem;
  }
}
.page-link__title {
  margin: auto 0 0;
}

.services-link {
  min-height: 23rem;
}
@media screen and (max-width: 767px) {
  .services-link {
    min-height: 14rem;
  }
}

.page-form {
  margin: 10rem 0;
}
@media screen and (max-width: 767px) {
  .page-form {
    margin: 4.4rem 0 5.3rem;
  }
}
.page-form__title {
  margin-bottom: 0.2em;
}
@media screen and (max-width: 767px) {
  .page-form__title {
    margin-bottom: 1.5rem;
  }
}
.page-form__form {
  margin-top: 1rem;
  padding-top: 6rem;
  border-top: 3px solid var(--color-accent-add);
}
@media screen and (max-width: 767px) {
  .page-form__form {
    padding-top: 3rem;
  }
}
.page-form .submit {
  min-width: 22.2rem;
}

.max-width {
  max-width: 142.4rem;
  margin-left: auto;
  margin-right: auto;
}

/* -------------------------------------
 * home
 * ------------------------------------- */
.hero {
  min-height: 38rem;
  padding: 8.6rem 0 4rem;
  background-color: var(--bg-sections);
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .hero {
    min-height: 22.5rem;
    padding: 5.2rem 0 2rem;
  }
}
.hero-home {
  min-height: 86rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 1439px) {
  .hero-home {
    min-height: 76rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-home {
    min-height: 59rem;
    padding-bottom: 4rem;
  }
}
.hero-home__row {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 1023px) {
  .hero-home__row {
    display: block;
  }
}
.hero-home__title {
  font-size: 6.4rem;
  line-height: 1.05;
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
  padding-right: 4rem;
}
@media screen and (max-width: 1023px) {
  .hero-home__title {
    margin-bottom: 0.5em;
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .hero-home__title {
    font-size: 3.4rem;
  }
}
.hero-home__title span {
  display: block;
  font-size: 17.7rem;
  line-height: 0.6;
  position: relative;
  left: -0.05em;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 767px) {
  .hero-home__title span {
    font-size: 8.9rem;
    line-height: 0.75;
  }
}
.hero-home__subtitle {
  max-width: 48.5rem;
  color: rgba(255, 255, 255, 0.4);
}
.hero-home__img {
  margin-top: 5.5rem;
}
@media screen and (max-width: 767px) {
  .hero-home__img {
    height: 19.5rem;
    margin-top: 2.7rem;
  }
}
.hero-title {
  max-width: 113.5rem;
  min-height: 18rem;
  margin-top: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 767px) {
  .hero-title {
    min-height: 12rem;
    margin-top: 2rem;
  }
}
.hero-title .title {
  margin-bottom: 0;
}
.hero-title .fz-54 {
  line-height: 1.05;
}

.home-services {
  margin: 11.8rem 0;
}
@media screen and (max-width: 767px) {
  .home-services {
    margin: 4.5rem 0 5rem;
  }
}
.home-services__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 1023px) {
  .home-services__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) {
  .home-services__title {
    max-width: 60rem;
  }
}
.home-services__title,
.home-services .home-service:nth-child(2),
.home-services .home-service:nth-child(3) {
  grid-column-end: span 2;
}
@media screen and (max-width: 1023px) {
  .home-services .home-service:nth-child(2),
.home-services .home-service:nth-child(3) {
    grid-column-end: span 1;
  }
}
.home-services .home-service:nth-child(2) {
  grid-row-start: 2;
  border-right: none;
}
@media screen and (max-width: 1023px) {
  .home-services .home-service:nth-child(2) {
    border-bottom: none;
  }
}
.home-services .home-service:nth-child(3) {
  border-bottom: none;
}
.home-services .home-service:nth-child(4) {
  border-right: none;
}

.home-service {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 31.8rem;
  padding: 4rem 4.5rem;
  background-color: var(--bg);
  border: 1px solid var(--border-color);
  position: relative;
  z-index: 1;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .home-service {
    min-height: 13.5rem;
    padding: 2.4rem 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  .home-service__title {
    font-size: 1.8rem;
  }
}
.home-service__ic {
  width: 6.1rem;
  height: 4.4rem;
  margin-top: auto;
}
@media screen and (max-width: 767px) {
  .home-service__ic {
    width: 3.4rem;
    height: 2.7rem;
  }
}
.home-service__ic .img {
  -webkit-transition: -webkit-filter 0.2s;
  transition: -webkit-filter 0.2s;
  -o-transition: filter 0.2s;
  transition: filter 0.2s;
  transition: filter 0.2s, -webkit-filter 0.2s;
}
.home-service__bg {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  -webkit-transition: all 0.3s 0.2s linear;
  -o-transition: all 0.3s 0.2s linear;
  transition: all 0.3s 0.2s linear;
}
@media screen and (max-width: 1199px) {
  .home-service__bg {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .home-service:hover {
    color: var(--color-white);
  }
  .home-service:hover .home-service__ic .img {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
  .home-service:hover .home-service__bg {
    opacity: 1;
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
}

.home-cases {
  margin: 5.4rem 0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .home-cases {
    margin: 5em 0 4rem;
  }
}
.home-cases .section-head__title {
  max-width: 57rem;
  margin-right: auto;
}

.cases-2 {
  padding: 6.5rem 0 4.4rem;
  background-color: #E4E3DE;
}
@media screen and (max-width: 767px) {
  .cases-2 {
    padding: 4rem 0;
  }
}

.cases-slider {
  overflow: visible;
}
@media screen and (min-width: 1200px) {
  .cases-slider::after {
    content: "";
    display: block;
    width: 100%;
    position: absolute;
    z-index: 2;
    right: 100%;
    top: -1px;
    bottom: -1px;
    background: var(--color-white);
  }
}
.cases-slider .swiper-slide {
  height: auto;
  max-width: 63.8rem;
}
@media screen and (max-width: 767px) {
  .cases-slider .swiper-slide {
    max-width: 30.4rem;
  }
}
.cases-slider .case-thumb {
  padding: 4.6rem 4.1rem 4.6rem 4.5rem;
}
@media screen and (max-width: 767px) {
  .cases-slider .case-thumb {
    padding: 3.6rem 2.5rem 3rem 2.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .cases-slider .case-thumb {
    cursor: none;
  }
}
@media screen and (min-width: 768px) {
  .cases-slider .case-thumb__col {
    max-width: 24rem;
    padding-bottom: 4rem;
  }
}
@media screen and (min-width: 768px) {
  .cases-slider .case-thumb__title {
    margin-bottom: 2.4rem;
  }
}

.cases-2-slider .swiper-slide {
  height: auto;
}
.cases-2-slider__arrows.white .slider-arrow:not(:hover)::before {
  -webkit-filter: brightness(0) !important;
          filter: brightness(0) !important;
}

.swiper-slide .case-thumb {
  height: 100%;
}

.case-thumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 5.6rem 4rem 3.6rem 4.5rem;
  color: var(--color-white);
  background-color: var(--bg-sections);
  position: relative;
}
.case-thumb:hover {
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .case-thumb {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2.6rem 2.5rem 3rem 2.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .case-thumb {
    cursor: none;
  }
  .case-thumb a {
    cursor: none;
  }
}
.case-thumb.bg-gray {
  background: var(--bg);
  border: 1px solid var(--border-color);
  color: var(--color-title);
}
.case-thumb__col {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .case-thumb__col {
    margin-bottom: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .case-thumb__col {
    max-width: 45rem;
    padding-bottom: 15rem;
  }
}
@media screen and (min-width: 1024px) {
  .case-thumb__col {
    max-width: 29rem;
  }
}
@media screen and (min-width: 1200px) {
  .case-thumb__col {
    max-width: 35rem;
  }
}
.case-thumb .tag {
  margin-bottom: 1em;
}
.case-thumb__title {
  margin-bottom: 1.4rem;
}
@media screen and (max-width: 767px) {
  .case-thumb__title {
    margin-bottom: 1.2rem;
  }
}
.case-thumb__txt {
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .case-thumb__txt {
    font-size: 1.4rem;
  }
}
.case-thumb__img {
  -ms-flex-preferred-size: 20.7rem;
      flex-basis: 20.7rem;
  height: 42.2rem;
}
.case-thumb__img a {
  display: block;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .case-thumb__img {
    max-height: 15.8rem;
    margin-top: auto;
  }
}
.case-thumb__logo {
  height: 3rem;
}
@media screen and (max-width: 767px) {
  .case-thumb__logo {
    margin-top: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .case-thumb__logo {
    position: absolute;
    bottom: 4.6rem;
    left: 4.9rem;
  }
}
.case-thumb__logo-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 19.3rem;
  height: 11.1rem;
  background-color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .case-thumb__logo-box {
    width: 14.9rem;
    height: 9rem;
    margin-top: 2.3rem;
    padding: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .case-thumb__logo-box {
    bottom: 3.6rem;
    left: 4.5rem;
  }
}
.case-thumb .circle-arrow-chevron {
  position: absolute;
  right: 2.5rem;
  bottom: 5rem;
}
.case-thumb-hover {
  display: none;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 17.2rem;
  height: 17.2rem;
  padding: 4rem;
  border-radius: 50%;
  position: absolute;
  z-index: 2;
  background-color: var(--color-accent-main);
  color: var(--color-white);
  font-size: 1.4rem;
  line-height: 1.45;
  font-weight: 500;
  text-align: center;
  -webkit-transform: translate(-50%, -50%) scale(0);
      -ms-transform: translate(-50%, -50%) scale(0);
          transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  visibility: hidden;
  -webkit-transition-duration: 0.1s;
       -o-transition-duration: 0.1s;
          transition-duration: 0.1s;
  -webkit-transition-timing-function: linear;
       -o-transition-timing-function: linear;
          transition-timing-function: linear;
  -webkit-transition-property: opacity, visibility, -webkit-transform;
  transition-property: opacity, visibility, -webkit-transform;
  -o-transition-property: transform, opacity, visibility;
  transition-property: transform, opacity, visibility;
  transition-property: transform, opacity, visibility, -webkit-transform;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
@media screen and (min-width: 1200px) {
  .case-thumb-hover {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }
}
.case-thumb-hover.is-visible {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translate(-50%, -50%) scale(1);
      -ms-transform: translate(-50%, -50%) scale(1);
          transform: translate(-50%, -50%) scale(1);
  -webkit-transition-duration: 0.3s;
       -o-transition-duration: 0.3s;
          transition-duration: 0.3s;
}

.spec {
  margin: 5.4rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .spec {
    margin: 5rem 0;
  }
}
.spec-list {
  position: relative;
}
.spec-list__btn {
  padding: 4.5rem 10rem 4.5rem 5rem;
  -webkit-transition: all 0.1s;
  -o-transition: all 0.1s;
  transition: all 0.1s;
  border: 1px solid var(--border-color);
  margin-bottom: -1px;
  position: relative;
}
.spec-list__btn::before {
  content: "";
  display: block;
  position: absolute;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0s;
  -o-transition: all 0s;
  transition: all 0s;
}
.spec-list__btn::after {
  content: "";
  display: block;
  width: 14px;
  height: 8px;
  position: absolute;
  z-index: 0;
  right: 3rem;
  top: 50%;
  margin-top: -4px;
  background: url("../img/icons/chevron-down.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (max-width: 1023px) {
  .spec-list__btn::before {
    border-top: 2.2rem solid var(--color-accent-main);
    border-left: 2rem solid transparent;
    border-right: 2rem solid transparent;
    top: calc(100% - 1rem);
    left: 50%;
    margin-left: -2rem;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media screen and (max-width: 767px) {
  .spec-list__btn {
    min-height: 8.7rem;
    padding: 1.9rem 3rem 1.9rem 1.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .spec-list__btn span {
    -ms-flex-item-align: center;
        align-self: center;
  }
  .spec-list__btn::after {
    right: 1.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .spec-list__btn {
    width: 50%;
  }
  .spec-list__btn::before {
    border-left: 2.2rem solid var(--color-accent-main);
    border-top: 2rem solid transparent;
    border-bottom: 2rem solid transparent;
    right: -1.5rem;
    top: 50%;
    margin-top: -2rem;
    -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .spec-list__btn::after {
    display: none;
  }
}
.spec-list__btn.is-active {
  background-color: var(--color-accent-main);
  border-color: var(--color-accent-main);
  color: var(--color-white);
}
.spec-list__btn.is-active::before {
  opacity: 1;
  visibility: visible;
  -webkit-transform: none;
      -ms-transform: none;
          transform: none;
  -webkit-transition-duration: 0.2s;
       -o-transition-duration: 0.2s;
          transition-duration: 0.2s;
}
.spec-list__btn.is-active::after {
  -webkit-transform: rotate(-180deg);
      -ms-transform: rotate(-180deg);
          transform: rotate(-180deg);
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.spec-list__item {
  position: relative;
}
@media screen and (max-width: 767px) {
  .spec-list__item {
    padding-bottom: 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .spec-list__item {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
  }
}
.spec-list__item .text {
  display: block;
  padding: 5rem;
  width: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  color: var(--color-white);
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), linear-gradient(111.49deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  -webkit-backdrop-filter: blur(5rem);
          backdrop-filter: blur(5rem);
}
@media screen and (max-width: 767px) {
  .spec-list__item .text {
    font-size: 1.4rem;
    padding: 2.2rem 1.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .spec-list__item .text {
    width: 66%;
  }
}
@media screen and (min-width: 1200px) {
  .spec-list__item .text {
    width: 50%;
  }
}
.spec-list__item .text .link-all {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 2rem;
}
@media screen and (max-width: 767px) {
  .spec-list__item .text .link-all {
    margin-top: 1.5rem;
  }
}
.spec-list__item .text .link-all::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
@media screen and (min-width: 1024px) {
  .spec-list__item .text .link-all::after {
    margin-left: 0;
  }
}
@media screen and (max-width: 1023px) {
  .spec-list__item .bg {
    position: static;
  }
}
@media screen and (max-width: 767px) {
  .spec-list__item .bg {
    min-height: 25rem;
  }
}
@media screen and (min-width: 1024px) {
  .spec-list__item .bg {
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.home-exp {
  margin: 11.6rem 0 9.4rem;
  padding: 6.9rem 0 7.8rem;
}
@media screen and (max-width: 1199px) {
  .home-exp {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .home-exp {
    margin: 5.2rem 0;
    padding: 3.7rem 0;
  }
}
@media screen and (min-width: 1200px) {
  .home-exp__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (min-width: 1200px) {
  .home-exp__head {
    width: 42rem;
    padding-right: 4rem;
  }
}
@media screen and (min-width: 1440px) {
  .home-exp__head {
    width: 46rem;
    padding-right: 5rem;
  }
}
.home-exp__title {
  margin-bottom: 0.4em;
}
@media screen and (max-width: 1199px) {
  .home-exp__title {
    max-width: 60rem;
  }
}
.home-exp__txt {
  color: rgba(255, 255, 255, 0.4);
}
@media screen and (max-width: 1199px) {
  .home-exp__txt {
    margin-bottom: 4.8rem;
  }
}
@media screen and (max-width: 767px) {
  .home-exp__txt {
    margin-bottom: 2.7rem;
  }
}
.home-exp__col {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
}

@media screen and (max-width: 1199px) {
  .exp-slider .swiper-slide {
    max-width: 22rem;
  }
}
@media screen and (max-width: 767px) {
  .exp-slider .swiper-slide {
    max-width: 14.8rem;
  }
}
@media screen and (min-width: 1200px) {
  .exp-slider .swiper-wrapper {
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    max-width: 91rem;
    margin-left: auto;
  }
  .exp-slider .swiper-wrapper::before {
    content: "";
  }
}

.exp {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 19.8rem;
  padding: 2.2rem 2.9rem;
  border: 1px solid rgba(255, 255, 255, 0.1);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .exp {
    height: 15.8rem;
    padding: 2rem 16px;
  }
}
@media screen and (min-width: 1200px) {
  .exp:hover .exp__bg {
    opacity: 1;
    visibility: visible;
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
}
.exp__ic {
  width: 36px;
  height: 36px;
}
.exp__title {
  max-width: 80%;
}
.exp__bg {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.2s 0.2s linear;
  -o-transition: all 0.2s 0.2s linear;
  transition: all 0.2s 0.2s linear;
}
.exp__bg::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: 0;
  left: 0;
  top: 0;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.2)), to(rgba(0, 0, 0, 0.2)));
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2));
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2));
}

.home-news {
  padding-bottom: 1rem;
}
@media screen and (min-width: 1024px) {
  .home-news__row {
    display: grid;
    gap: 20px;
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 1600px) {
  .home-news__row {
    gap: 40px;
  }
}
.home-news__row .news-list {
  height: 100%;
}
.home-news__col {
  overflow: hidden;
}
.home-news .news-thumb {
  background-color: transparent !important;
  border: none;
}

.news-slider .swiper-slide {
  height: auto;
}
@media screen and (min-width: 1200px) {
  .news-slider .swiper-wrapper {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
@media screen and (min-width: 1600px) {
  .news-slider .swiper-wrapper {
    gap: 40px;
  }
}

.news-list {
  border-top: 1px solid #E2E5EB;
  border-bottom: 1px solid #E2E5EB;
}
.news-list li {
  border-bottom: 1px solid #E2E5EB;
}
.news-list li:last-child {
  border: none;
}

.news-thumb {
  display: block;
}
.news-thumb-card {
  height: 100%;
  overflow: hidden;
}
.news-thumb-card__img {
  height: 26.6rem;
}
.news-thumb-card__body {
  height: calc(100% - 22.1rem);
  margin-top: -4.5rem;
  padding: 3rem 3rem 6.8rem;
  background: -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  background: linear-gradient(111.49deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  -webkit-backdrop-filter: blur(50px);
          backdrop-filter: blur(50px);
  position: relative;
}
.news-thumb-card__body .case-thumb-date {
  margin-bottom: 1.6rem;
}
.news-thumb-card__body::after {
  content: "";
  display: block;
  width: 8px;
  height: 14px;
  position: absolute;
  z-index: 0;
  left: 3rem;
  bottom: 3rem;
  background: url("../img/icons/chevron-right.svg") no-repeat 50% 50%/contain;
}
.news-thumb-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 4rem 0;
}
.news-thumb-item .case-thumb-date {
  min-width: 8.9rem;
  margin-right: 3rem;
}
.news-thumb-item .case-thumb-title {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 53rem;
  -webkit-transition: color 0.1s;
  -o-transition: color 0.1s;
  transition: color 0.1s;
}
@media screen and (min-width: 1200px) {
  .news-thumb-item:hover .case-thumb-title {
    color: var(--color-accent-main);
  }
}

.home-partners {
  margin: 9.8rem 0 9.1rem;
}
@media screen and (max-width: 1023px) {
  .home-partners {
    margin-top: 0;
    padding: 9rem 0;
    overflow: hidden;
    background-color: var(--bg);
  }
}
@media screen and (max-width: 767px) {
  .home-partners {
    margin-bottom: 5rem;
    padding: 4rem 0;
  }
}
@media screen and (min-width: 1024px) {
  .home-partners__row {
    padding: 5rem 4.5rem;
    background-color: var(--bg);
  }
}
@media screen and (max-width: 1023px) {
  .home-partners__title {
    margin-bottom: 4.8rem;
  }
}
@media screen and (max-width: 767px) {
  .home-partners__title {
    margin-bottom: 2.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .home-partners__title {
    max-width: 50rem;
  }
}
@media screen and (min-width: 1024px) {
  .home-partners__col {
    overflow: hidden;
  }
}

@media screen and (min-width: 1200px) {
  .partners-slider .swiper-wrapper {
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }
}
@media screen and (max-width: 1199px) {
  .partners-slider .swiper-slide {
    max-width: 22.8rem;
  }
}
@media screen and (max-width: 767px) {
  .partners-slider .swiper-slide {
    max-width: 15rem;
  }
}

.partner-box {
  height: 13rem;
  padding: 3.5rem 5rem;
  background-color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .partner-box {
    height: 10.8rem;
    padding: 3rem 3rem;
  }
}
.partner-box img {
  -webkit-transition: opacity 0.2s;
  -o-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.partner-box img:nth-child(2) {
  opacity: 0;
  position: absolute;
}
@media screen and (min-width: 1200px) {
  .partner-box:hover img:nth-child(1) {
    opacity: 0;
  }
  .partner-box:hover img:nth-child(2) {
    opacity: 1;
  }
}

.banner {
  margin: 9.8rem 0;
}
@media screen and (max-width: 1023px) {
  .banner {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .banner {
    margin: 4rem 0 0;
  }
}
.banner-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  min-height: 45rem;
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
  position: relative;
  z-index: 1;
  color: var(--color-white);
  overflow: hidden;
}
.banner-inner:not(.inner) {
  padding-left: 4.5rem;
  padding-right: 4.5rem;
}
.banner-inner:hover {
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .banner-inner {
    min-height: 21.5rem;
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }
  .banner-inner:not(.inner) {
    padding-left: 14px;
    padding-right: 14px;
  }
}
.banner-inner .link-all::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.banner-title {
  margin-bottom: 1.8rem;
}
@media screen and (max-width: 767px) {
  .banner-title {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 1199px) {
  .banner-bg.bg::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 0;
    left: 0;
    top: 0;
    background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.1)), to(rgba(0, 0, 0, 0.1)));
    background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1));
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1));
  }
}
.banner-wrapper {
  position: relative;
}
.banner-static .banner-inner {
  padding: 0;
}
@media screen and (min-width: 1200px) {
  .banner-static .banner-inner {
    min-height: 53.6rem;
  }
}
@media screen and (max-width: 767px) {
  .banner-static .banner-bg {
    height: 22.8rem;
  }
}
.banner-static__title {
  font-size: 6.4rem;
  line-height: 1;
}
@media screen and (max-width: 1023px) {
  .banner-static__title {
    margin: 4.5rem 0 0;
  }
}
@media screen and (max-width: 767px) {
  .banner-static__title {
    font-size: 3.4rem;
    padding: 0 14px;
  }
}
@media screen and (min-width: 1024px) {
  .banner-static__title {
    max-width: 100rem;
    position: absolute;
    z-index: 1;
    left: 4rem;
    bottom: 6rem;
  }
}
.banner-static__title .big {
  display: inline-block;
  font-size: 17.7rem;
  line-height: 0.6;
}
@media screen and (max-width: 767px) {
  .banner-static__title .big {
    line-height: 0.8;
    font-size: 8.9rem;
  }
}
.banner-download .banner-inner {
  padding: 0;
  height: 56.6rem;
}
@media screen and (max-width: 767px) {
  .banner-download .banner-inner {
    height: 37.9rem;
  }
}
.banner-download__title {
  position: absolute;
  z-index: 1;
  left: 4rem;
  bottom: 6rem;
}
@media screen and (max-width: 1023px) {
  .banner-download__title {
    bottom: auto;
    top: 7rem;
  }
}
@media screen and (max-width: 1023px) {
  .banner-download .download-link {
    width: 100%;
    max-width: 100%;
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  .banner-download .download-link {
    margin-top: 14px;
  }
}
@media screen and (min-width: 1024px) {
  .banner-download .download-link {
    position: absolute;
    z-index: 1;
    right: 5rem;
    bottom: 6rem;
  }
}
.banner-sector {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .banner-sector .bg {
    position: static;
    height: 75vw;
  }
}
.banner-sector .banner-inner {
  min-height: 61.5rem;
  padding: 6.5rem 0;
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .banner-sector .banner-inner {
    min-height: auto;
    padding: 0;
  }
}
.banner-sector .banner-title {
  margin: 0;
  max-width: 70rem;
}
.banner-sector .g-block {
  padding: 7.6rem 4.3rem 3.4rem 4.3rem;
}
@media screen and (max-width: 767px) {
  .banner-sector .g-block {
    width: calc(100% + 28px);
    margin-left: -14px;
    padding: 3.6rem 14px 2.9rem 14px;
  }
}

/* -------------------------------------
 * about
 * ------------------------------------- */
@media screen and (min-width: 1024px) {
  .hero-about {
    padding-bottom: 0;
  }
}
.hero-about__grid {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .hero-about__grid {
    margin-top: 2.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .hero-about__grid {
    display: grid;
    gap: 40px;
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 33rem;
  }
}
.hero-about__img-2 {
  height: 65.6rem;
  grid-row-end: span 2;
}
@media screen and (max-width: 1023px) {
  .hero-about__img-1, .hero-about__img-2 {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .hero-about__img-1, .hero-about__img-2 {
    height: 15.5rem;
    margin-bottom: 14px;
  }
}
.hero-about__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  height: 28.4rem;
}
@media screen and (max-width: 767px) {
  .hero-about__block {
    height: 17.1rem;
  }
}
.hero-about__block .title {
  padding-right: 2rem;
}
@media screen and (max-width: 767px) {
  .hero-about__block .fz-30 {
    font-size: 1.8rem;
  }
}
.hero-about__img-3 {
  width: 27.6rem;
  min-width: 27.6rem;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .hero-about__img-3 {
    width: 16.6rem;
    min-width: 16.6rem;
  }
}

.about {
  margin: 11rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .about {
    margin: 4rem 0;
  }
}
.about__grid {
  margin-top: 2rem;
}
.about__col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .about__col:last-child {
    grid-column-start: 1;
    grid-row-start: 1;
  }
}
.about__col .download-link {
  margin-top: auto;
}
@media screen and (max-width: 1023px) {
  .about__col .download-link {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .about__col .download-link {
    max-width: 100%;
  }
}
.about__sub {
  margin-bottom: 3rem;
  letter-spacing: -0.02em;
}
@media screen and (max-width: 767px) {
  .about__sub {
    margin-bottom: 1.8rem;
  }
}

.mission {
  margin: 12rem 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .mission {
    margin: 3.9rem 0 6.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .mission {
    padding: 5.4rem 0 6rem;
  }
}
.mission-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 5rem 4.7rem;
  background-color: var(--color-accent-add);
  color: var(--color-white);
}
@media screen and (max-width: 1023px) {
  .mission-block {
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .mission-block {
    padding: 4.2rem 14px 3.3rem;
  }
}
@media screen and (min-width: 1024px) {
  .mission-block {
    max-width: 69.2rem;
    min-height: 54rem;
  }
}
.mission-block__title {
  margin-bottom: 5rem;
}
@media screen and (max-width: 1023px) {
  .mission .bg {
    position: static;
  }
}
@media screen and (max-width: 767px) {
  .mission .bg {
    height: 25rem;
  }
}

.nums {
  margin: 16rem 0;
}
@media screen and (max-width: 1199px) {
  .nums {
    overflow: hidden;
    margin: 12rem 0;
    padding-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .nums {
    margin: 4rem 0 5rem;
    padding-top: 3rem;
  }
}
@media screen and (min-width: 1200px) {
  .nums-slider .swiper-wrapper {
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
  }
}
@media screen and (max-width: 1199px) {
  .nums-slider .swiper-slide {
    max-width: 50rem;
  }
}
@media screen and (max-width: 767px) {
  .nums-slider .swiper-slide {
    max-width: 100%;
    width: auto;
  }
  .nums-slider .swiper-slide .num {
    max-width: 26rem;
  }
}
@media screen and (min-width: 1200px) {
  .nums-slider .swiper-slide:nth-child(3), .nums-slider .swiper-slide:nth-child(4) {
    margin-top: 27rem;
  }
  .nums-slider .swiper-slide:nth-child(4) {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}

.num .title {
  margin-bottom: 0.15em;
  font-size: 16rem;
  line-height: 0.5;
}
@media screen and (max-width: 767px) {
  .num .title {
    font-size: 10rem;
    margin-bottom: 0.2em;
  }
}
.num .text {
  max-width: 31rem;
}

.blockquote {
  margin: 13rem 0;
}
@media screen and (max-width: 767px) {
  .blockquote {
    margin: 3.6rem 0 4.9rem;
  }
}
.blockquote--gradient {
  margin-bottom: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(var(--color-white)), color-stop(12%, var(--color-white)), color-stop(12%, var(--bg-sections)), to(var(--bg-sections)));
  background: -o-linear-gradient(top, var(--color-white), var(--color-white) 12%, var(--bg-sections) 12%, var(--bg-sections));
  background: linear-gradient(180deg, var(--color-white), var(--color-white) 12%, var(--bg-sections) 12%, var(--bg-sections));
}
.blockquote-inner {
  padding: 14rem 4em 10rem 50%;
  position: relative;
  z-index: 1;
  background-color: var(--color-accent-main);
  color: var(--color-white);
}
@media screen and (max-width: 1439px) {
  .blockquote-inner {
    padding-left: 46%;
  }
}
@media screen and (max-width: 1023px) {
  .blockquote-inner {
    padding: 8rem 20px 6rem;
  }
}
@media screen and (max-width: 767px) {
  .blockquote-inner {
    padding: 3.6rem 14px 3rem;
  }
}
.blockquote__text {
  max-width: 65rem;
  position: relative;
  text-indent: 4.3em;
  margin-bottom: 3rem;
}
@media screen and (max-width: 1023px) {
  .blockquote__text {
    margin-bottom: 25rem;
    text-indent: 0;
  }
}
@media screen and (max-width: 767px) {
  .blockquote__text {
    max-width: 31rem;
    margin-bottom: 15rem;
  }
}
.blockquote__text::before {
  content: "";
  display: block;
  font-size: 1rem;
  width: 7.7em;
  height: 5.8em;
  position: absolute;
  z-index: 0;
  left: 0;
  top: -2.8rem;
  background: url("../img/icons/quotes.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 1023px) {
  .blockquote__text::before {
    position: static;
    margin-bottom: 3.8em;
  }
}
@media screen and (max-width: 767px) {
  .blockquote__text::before {
    font-size: 0.7rem;
  }
}
@media screen and (max-width: 767px) {
  .blockquote__author {
    max-width: 19rem;
  }
}
.blockquote__img {
  max-width: 39%;
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 13rem;
}
@media screen and (max-width: 1439px) {
  .blockquote__img {
    left: 8rem;
  }
}
@media screen and (max-width: 1023px) {
  .blockquote__img {
    left: auto;
    right: -2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .blockquote__img {
    width: 65%;
    max-width: 37.2rem;
  }
}

.advantages {
  padding: 13rem 0;
}
@media screen and (max-width: 767px) {
  .advantages {
    padding: 5.3rem 0;
  }
}
.advantages__title {
  padding-right: 15rem;
}
.advantages__list {
  padding-top: 1rem;
  position: relative;
  z-index: 2;
}
.advantages__list li {
  margin-bottom: 6.3rem;
}
@media screen and (max-width: 767px) {
  .advantages__list li {
    margin-bottom: 3rem;
  }
}
.advantages__list li:last-child {
  margin-bottom: 0;
}
.advantages__list .title {
  margin-bottom: 1rem;
}

.competence {
  position: relative;
  z-index: 1;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .competence {
    padding: 4rem 0 5rem;
  }
}
.competence::before {
  content: "";
  display: block;
  font-size: 1rem;
  width: 181.9em;
  height: 104.3em;
  position: absolute;
  z-index: -1;
  left: -20em;
  top: -31em;
  background: url("../img/about/competence.jpg") no-repeat 50% 0%/contain;
}
@media screen and (max-width: 1439px) {
  .competence::before {
    font-size: 0.83rem;
  }
}
@media screen and (max-width: 767px) {
  .competence::before {
    font-size: 0.6rem;
    left: -71em;
    top: auto;
    bottom: 0;
  }
}
.competence__title {
  padding-right: 10%;
}
.competence-slider {
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .competence-slider {
    margin-top: 3rem;
  }
}
.competence-slider .swiper-slide {
  height: auto;
  max-width: 39.7rem;
}
@media screen and (max-width: 767px) {
  .competence-slider .swiper-slide {
    max-width: 22.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .competence-slider .swiper-slide {
    min-width: 39.7rem;
  }
}

.competence-item {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 5rem 4rem;
  background: rgba(107, 184, 153, 0.5);
  -webkit-backdrop-filter: blur(5rem);
          backdrop-filter: blur(5rem);
  color: var(--color-white);
}
@media screen and (max-width: 1439px) {
  .competence-item {
    padding: 4rem 4rem 3rem;
  }
}
@media screen and (max-width: 767px) {
  .competence-item {
    padding: 3.4rem 2rem 2.8rem;
  }
}
.competence-item__title {
  margin-bottom: 1.7rem;
  min-height: 14.6rem;
}
@media screen and (max-width: 1439px) {
  .competence-item__title {
    min-height: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .competence-item__title {
    min-height: 2.6rem;
  }
}
.competence-item__txt {
  min-height: 14.4rem;
  margin-bottom: 2.4rem;
}
@media screen and (max-width: 1439px) {
  .competence-item__txt {
    min-height: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .competence-item__txt {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.competence-item__ic {
  width: 6.2rem;
  height: 4.4rem;
  margin-top: auto;
}
@media screen and (max-width: 767px) {
  .competence-item__ic {
    width: 4.2rem;
    height: 2.7rem;
  }
}
.competence-item__ic img {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}

.no-scroll {
  overflow: hidden;
  margin-right: 17px !important;
}
.no-scroll .header {
  width: auto;
  right: 17px;
}

.history {
  padding: 9rem 0 0;
  overflow: hidden;
}
@media screen and (max-width: 1199px) {
  .history {
    margin: 9rem 0;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .history {
    margin: 5rem 0;
  }
}
@media screen and (min-width: 1200px) {
  .history__title {
    margin-bottom: 0;
    max-width: 30rem;
  }
}
.history__row {
  position: relative;
}
@media screen and (min-width: 1200px) {
  .history__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (max-width: 1199px) {
  .history__row .history-progress {
    height: 3px;
    margin: 2.9rem 0 4rem;
  }
}
@media screen and (min-width: 1200px) {
  .history__row .history-progress {
    display: block;
    width: 3px;
    height: 53rem;
    margin: 0;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
.history__row .history-progress .slider-dots {
  background-color: #E9E9E9;
  -webkit-transform: none;
      -ms-transform: none;
          transform: none;
}
@media screen and (min-width: 1200px) {
  .history__row .history-progress .slider-dots {
    height: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.history__row .history-progress .swiper-pagination-bullet {
  height: auto;
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  border-radius: 0;
  border: none;
  background: var(--color-accent-add);
  opacity: 1;
  -webkit-transition: all 0.3s linear !important;
  -o-transition: all 0.3s linear !important;
  transition: all 0.3s linear !important;
}
.history__row .history-progress .swiper-pagination-bullet::before {
  display: none;
  border-radius: 0;
}
@media screen and (max-width: 1199px) {
  .history__row .history-progress .swiper-pagination-bullet {
    height: 100%;
    -webkit-transform-origin: 0 50%;
        -ms-transform-origin: 0 50%;
            transform-origin: 0 50%;
  }
}
@media screen and (min-width: 1200px) {
  .history__row .history-progress .swiper-pagination-bullet {
    width: 100%;
    -webkit-transform: scaleY(1);
        -ms-transform: scaleY(1);
            transform: scaleY(1);
    -webkit-transform-origin: 50% 0;
        -ms-transform-origin: 50% 0;
            transform-origin: 50% 0;
  }
}
@media screen and (max-width: 1199px) {
  .history__row .history-progress .swiper-pagination-bullet-active ~ .swiper-pagination-bullet {
    -webkit-transform: scaleX(0);
        -ms-transform: scaleX(0);
            transform: scaleX(0);
  }
}
@media screen and (min-width: 1200px) {
  .history__row .history-progress .swiper-pagination-bullet-active ~ .swiper-pagination-bullet {
    -webkit-transform: scaleY(0);
        -ms-transform: scaleY(0);
            transform: scaleY(0);
  }
}
.history__years, .history__slider {
  overflow: visible;
}
@media screen and (min-width: 1200px) {
  .history__years, .history__slider {
    height: 80rem;
  }
}
.history__years .siwper-wrapper, .history__slider .siwper-wrapper {
  -webkit-transition-timing-function: linear !important;
       -o-transition-timing-function: linear !important;
          transition-timing-function: linear !important;
}
@media screen and (min-width: 1200px) {
  .history__years .swiper-slide, .history__slider .swiper-slide {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 23rem;
  }
}
@media screen and (max-width: 1199px) {
  .history__years {
    text-align: center;
    position: absolute;
    z-index: -1;
    top: 5rem;
    left: 0;
    width: 100%;
  }
  .history__years .swiper-slide {
    width: auto;
  }
}
@media screen and (min-width: 1200px) {
  .history__years {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 25rem;
            flex: 0 0 25rem;
    max-width: 25rem;
    margin: 0 0 0 auto;
  }
}
.history__years .ye {
  position: absolute;
  right: 100%;
  top: 50%;
  -webkit-transform: translate(-2%, -19%);
      -ms-transform: translate(-2%, -19%);
          transform: translate(-2%, -19%);
  color: var(--color-accent-main);
}
@media screen and (max-width: 1199px) {
  .history__years .ye {
    display: none;
  }
}
.history__years .swiper-slide-active .history-year {
  opacity: 1;
  color: var(--color-accent-main);
}
@media screen and (max-width: 1199px) {
  .history__slider {
    overflow: hidden;
    margin-top: 4.5rem;
  }
  .history__slider .swiper-slide {
    padding-top: 13rem;
  }
}
@media screen and (min-width: 1200px) {
  .history__slider {
    margin: 0;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 76rem;
            flex: 0 0 76rem;
    max-width: 76rem;
    padding-left: 8rem;
    cursor: s-resize;
  }
  .history__slider::before {
    content: "";
    display: block;
    width: 120vw;
    height: 100%;
    position: absolute;
    z-index: 0;
    right: -20vw;
    bottom: 0;
  }
}
@media screen and (min-width: 1300px) {
  .history__slider {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 86rem;
            flex: 0 0 86rem;
    max-width: 86rem;
    padding-left: 12rem;
  }
}
@media screen and (min-width: 1200px) {
  .history__slider .swiper-slide {
    border-bottom: 1px solid rgba(34, 33, 33, 0.1);
  }
}
.history__slider .swiper-slide-active .event__img {
  border-color: var(--color-accent-main);
  -webkit-transition-delay: 0.2s;
       -o-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.history-year, .event {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 1200px) {
  .history-year, .event {
    height: 100%;
  }
}

.history-year {
  opacity: 0.1;
  -webkit-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  padding-top: 7rem;
  padding-bottom: 1rem;
}
@media screen and (max-width: 1199px) {
  .history-year::before {
    content: attr(data-pre);
  }
}
@media screen and (max-width: 767px) {
  .history-year {
    padding: 3rem 0 0;
  }
}

@media screen and (min-width: 1200px) {
  .event {
    padding: 4rem 10rem 4rem 0;
  }
}
.event__img {
  font-size: 1rem;
  width: 11em;
  min-width: 11em;
  height: 11em;
  padding: 1.8rem;
  background-color: #E9E9E9;
  border: 2px solid #E9E9E9;
  border-radius: 50%;
  margin-right: 6rem;
  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  transition: all 0.4s;
}
@media screen and (max-width: 767px) {
  .event__img {
    display: none;
  }
}
.event .fz-18 {
  line-height: 1.45;
}

/* -------------------------------------
 * team
 * ------------------------------------- */
.team-info {
  margin: 9.1rem 0;
}
@media screen and (max-width: 767px) {
  .team-info {
    margin: 6rem 0;
  }
}
.team-info__grid {
  grid-row-gap: 0;
}
.team-info .fz-160 {
  margin-top: 2rem;
}
.team-info__subtitle {
  max-width: 50rem;
  margin-top: 2.1rem;
}
@media screen and (max-width: 1023px) {
  .team-info__subtitle {
    margin-top: 1rem;
  }
}
@media screen and (max-width: 767px) {
  .team-info__subtitle {
    max-width: 25rem;
  }
}
.team-info .fz-60 {
  margin-bottom: 1rem;
}
@media screen and (max-width: 1023px) {
  .team-info .fz-60 {
    margin-top: 3rem;
  }
}
.team-info .green-block {
  padding: 3.5rem 5rem;
  background-color: var(--color-accent-add);
  color: var(--color-white);
}
@media screen and (max-width: 1023px) {
  .team-info .green-block {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .team-info .green-block {
    padding: 2.8rem 2rem 3rem 2rem;
  }
}

.team {
  margin: 15rem 0 9rem;
}
@media screen and (max-width: 767px) {
  .team {
    margin: 7rem 0 6rem;
  }
}
.team__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16rem 8rem;
}
@media screen and (max-width: 1300px) {
  .team__grid {
    -webkit-column-gap: 4rem;
       -moz-column-gap: 4rem;
            column-gap: 4rem;
  }
}
@media screen and (max-width: 1199px) {
  .team__grid {
    grid-template-columns: repeat(3, 1fr);
    row-gap: 12rem;
  }
}
@media screen and (max-width: 767px) {
  .team__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8rem 14px;
  }
}

.member {
  display: block;
}
@media screen and (min-width: 1200px) {
  .member:hover .member__img .bg {
    background-color: var(--color-accent-main);
  }
}
.member__img {
  font-size: 1rem;
  width: 30em;
  height: 30em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 50%;
  margin-bottom: 4rem;
  position: relative;
}
@media screen and (max-width: 1023px) {
  .member__img {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 767px) {
  .member__img {
    font-size: 0.54rem;
    margin-bottom: 2rem;
  }
}
.member__img img {
  max-height: none;
  position: relative;
  top: 2px;
}
.member__img [src*=boytsov] {
  top: 1.4rem;
  left: 0.2rem;
}
@media screen and (max-width: 767px) {
  .member__img [src*=boytsov] {
    top: 0.3rem;
    left: 0.1rem;
  }
}
.member__img .bg {
  height: 30em;
  background-color: var(--bg);
  border-radius: 50%;
  -webkit-transition: background-color 0.4s;
  -o-transition: background-color 0.4s;
  transition: background-color 0.4s;
  top: auto;
  bottom: 0;
}
.member__name {
  margin-bottom: 1.6rem;
}
@media screen and (max-width: 767px) {
  .member__name {
    padding-right: 10px;
  }
}
@media screen and (max-width: 767px) {
  .member__pos {
    padding-right: 10px;
    font-size: 1.5rem;
  }
}
.member .link {
  display: inline-block;
  margin-top: 1rem;
}

/* -------------------------------------
 * career
 * ------------------------------------- */
.hero-career {
  overflow: hidden;
}
.hero-career__inner {
  position: relative;
  z-index: 1;
  padding-bottom: 2rem;
}
@media screen and (max-width: 1023px) {
  .hero-career__inner {
    padding: 64rem 0 0;
  }
}
@media screen and (max-width: 767px) {
  .hero-career__inner {
    padding-top: 36.3rem;
  }
}
.hero-career__block {
  max-width: 116.4rem;
  margin-top: 3.3rem;
  padding: 5.6rem 5rem;
}
@media screen and (max-width: 1199px) {
  .hero-career__block {
    max-width: 82rem;
  }
}
@media screen and (max-width: 1023px) {
  .hero-career__block {
    max-width: 100%;
    margin: 0 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-career__block {
    padding: 2.5rem 16px;
  }
}
.hero-career__block .max-width {
  margin: 0;
  max-width: 70rem;
}
.hero-career__bottom {
  margin-top: 12.9rem;
}
.hero-career__link {
  display: block;
  padding: 3.5rem 4.4rem;
}
.hero-career__link::before {
  content: "";
  display: block;
  font-size: 1rem;
  width: 4.7em;
  height: 4.3em;
  margin-bottom: 4em;
  background: url("../img/career/search.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 767px) {
  .hero-career__link {
    padding: 2.5rem 16px;
  }
  .hero-career__link::before {
    font-size: 0.7rem;
    margin-bottom: 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .hero-career__link {
    position: absolute;
    bottom: 0;
    right: 0;
  }
}
.hero-career__img {
  font-size: 1rem;
  width: 52.4em;
  height: 76.2em;
  position: absolute;
  bottom: -7.2rem;
  right: 15rem;
}
@media screen and (max-width: 1023px) {
  .hero-career__img {
    z-index: -1;
    bottom: 34rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-career__img {
    width: 27.9em;
    height: 40.5em;
    bottom: 24rem;
    right: 4rem;
  }
}
.hero-career__icon {
  font-size: 1rem;
  width: 33.7em;
  height: 28.7em;
  position: absolute;
  right: -2.1rem;
  bottom: 18.4rem;
}
@media screen and (max-width: 1023px) {
  .hero-career__icon {
    z-index: -2;
    right: 2rem;
    bottom: 48rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-career__icon {
    width: 26.8em;
    height: 22.8em;
    right: -6rem;
    bottom: 31rem;
  }
}

.title-big {
  margin: 10.8rem 0 8.5rem;
}
@media screen and (max-width: 767px) {
  .title-big {
    margin: 5rem 0;
  }
}

.facts {
  margin: 8.5rem 0 6.7rem;
}
@media screen and (max-width: 767px) {
  .facts {
    margin: 5rem 0 4.2rem;
  }
}
.facts__inner {
  padding-top: 7.4rem;
  padding-bottom: 7.4rem;
}
@media screen and (max-width: 767px) {
  .facts__inner {
    padding-top: 3.9rem;
    padding-bottom: 4.5rem;
  }
}
.facts__inner .grid-lg-2 {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 1023px) {
  .facts__title {
    margin-bottom: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .facts__title {
    margin-bottom: 3rem;
  }
}
.facts__nums {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6rem 16rem;
}
@media screen and (max-width: 767px) {
  .facts__nums {
    gap: 3rem 14px;
  }
}
@media screen and (min-width: 1200px) {
  .facts__nums {
    padding-right: 5rem;
  }
}
.facts__nums .num .title {
  line-height: 1;
  margin-bottom: 0.04em;
  font-size: 8.7rem;
  color: var(--color-accent-add);
}
@media screen and (max-width: 767px) {
  .facts__nums .num .title {
    font-size: 4.6rem;
  }
}

.blockquote-banner {
  margin: 6.7rem 0;
}
@media screen and (max-width: 767px) {
  .blockquote-banner {
    margin: 4.2rem 0 5.1rem;
  }
}
.blockquote-banner__inner {
  position: relative;
  z-index: 1;
  padding-top: 8rem;
  padding-bottom: 6.5rem;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .blockquote-banner__inner {
    padding-top: 4.8rem;
    padding-bottom: 4.8rem;
  }
}
@media screen and (max-width: 1023px) {
  .blockquote-banner__inner .bg {
    -o-object-position: 47% 50%;
       object-position: 47% 50%;
  }
}
.blockquote-banner__inner .quotes {
  margin-bottom: 8.8rem;
}
@media screen and (max-width: 767px) {
  .blockquote-banner__inner .quotes {
    margin-bottom: 2.7rem;
  }
}
.blockquote-banner__inner .vitmo-news {
  max-width: 14.5rem;
}
.blockquote-banner__txt {
  max-width: 61rem;
  margin-top: 3.6rem;
}
@media screen and (max-width: 1023px) {
  .blockquote-banner__txt {
    max-width: 47rem;
  }
}
@media screen and (max-width: 767px) {
  .blockquote-banner__txt {
    max-width: 69%;
    margin-top: 1.6rem;
  }
}
.blockquote-banner__txt .title {
  margin-bottom: 0.2em;
}
.blockquote-banner__link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 5rem;
}
.blockquote-banner__link .circle-arrow-blank {
  margin-right: 2.2rem;
}
@media screen and (max-width: 767px) {
  .blockquote-banner__link {
    margin-top: 4rem;
  }
  .blockquote-banner__link .circle-arrow-blank {
    margin-right: 1.6rem;
  }
}
@media screen and (min-width: 1200px) {
  .blockquote-banner__link:hover {
    color: var(--color-accent-main);
  }
  .blockquote-banner__link:hover .circle-arrow-blank {
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
  }
}

.values {
  margin: 6rem 0 9.5rem;
}
@media screen and (max-width: 1199px) {
  .values {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .values {
    margin: 5rem 0;
  }
}
@media screen and (min-width: 1200px) {
  .values__title {
    width: 33%;
    margin: 0;
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
  }
}
.values-slider-wrap {
  position: relative;
}
@media screen and (min-width: 1200px) {
  .values-slider .swiper-wrapper {
    grid-template-columns: repeat(3, 1fr);
    padding-bottom: 32rem;
  }
  .values-slider .swiper-wrapper::before {
    content: "";
    display: block;
  }
}
@media screen and (max-width: 1199px) {
  .values-slider .swiper-slide {
    max-width: 50.6rem;
  }
}
@media screen and (max-width: 767px) {
  .values-slider .swiper-slide {
    max-width: 23.8rem;
  }
}
.values-slider .swiper-slide:nth-child(5n+1) .values-item {
  background-color: var(--color-accent-add);
}
.values-slider .swiper-slide:nth-child(5n+2) .values-item {
  background-color: var(--color-accent-main);
}
.values-slider .swiper-slide:nth-child(5n+3) .values-item {
  background-color: #E3A6A3;
}
.values-slider .swiper-slide:nth-child(5n+4) .values-item {
  background-color: #004045;
}
.values-slider .swiper-slide:nth-child(5n+5) .values-item {
  background-color: #3D3333;
}
@media screen and (min-width: 1200px) {
  .values-slider .swiper-slide:nth-child(5n+5) {
    -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
            transform: translateY(100%);
  }
}
.values-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
  min-height: 32rem;
  padding: 2.9em 4.8rem 3.2rem;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .values-item {
    min-height: auto;
    height: 24.8rem;
    padding: 2.9rem 15px;
  }
}
.values-item .title {
  margin-bottom: 1.3rem;
}
@media screen and (max-width: 767px) {
  .values-item .title {
    margin-bottom: 1rem;
  }
}
.values-item .text {
  max-width: 38rem;
}
.values-item .ic {
  font-size: 1rem;
  width: 5.1em;
  height: 4.5em;
  margin-top: auto;
}
@media screen and (max-width: 767px) {
  .values-item .ic {
    font-size: 0.65rem;
  }
}
.values__image {
  height: 32rem;
}
@media screen and (max-width: 1199px) {
  .values__image {
    margin-top: 3.2rem;
  }
}
@media screen and (max-width: 767px) {
  .values__image {
    height: 36.8vw;
    max-height: 32rem;
  }
}
@media screen and (min-width: 1200px) {
  .values__image {
    position: absolute;
  }
}
@media screen and (min-width: 1200px) {
  .values__image-1 {
    bottom: 0;
    left: 0;
    width: 67%;
  }
}
@media screen and (max-width: 1199px) {
  .values__image-2 {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .values__image-2 {
    width: 34%;
    right: 0;
    bottom: 32rem;
  }
}

.opinions {
  margin: 9.5rem 0 13rem;
}
@media screen and (max-width: 1023px) {
  .opinions {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .opinions {
    margin: 4.9rem 0 4.3rem;
  }
}
.opinions__title {
  max-width: 65rem;
}
@media screen and (max-width: 767px) {
  .opinions__title {
    max-width: 34rem;
  }
}
@media screen and (max-width: 1023px) {
  .opinions-slider {
    overflow: visible;
  }
}
.opinions-slider .swiper-slide {
  height: auto;
}
@media screen and (max-width: 1023px) {
  .opinions-slider .swiper-slide {
    max-width: 35rem;
  }
}
@media screen and (max-width: 767px) {
  .opinions-slider .swiper-slide {
    max-width: 30.4rem;
  }
}

.opinion {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 3.3rem 4rem;
}
@media screen and (max-width: 767px) {
  .opinion {
    padding: 3.2rem 16px;
  }
}
.opinion .quotes {
  width: 5.3rem;
  height: 4rem;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .opinion .quotes {
    width: 4.1rem;
    height: 3.1rem;
    margin-bottom: 2.1rem;
  }
}
.opinion__txt {
  margin-bottom: auto;
}
.opinion__author {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 3rem;
}
.opinion__author .author-info {
  margin-right: auto;
  padding-right: 1rem;
}
.opinion__author .author-info .subcolor {
  margin-top: 1.2rem;
}
@media screen and (max-width: 767px) {
  .opinion__author .author-info .subcolor {
    margin-top: 0.2rem;
  }
}
.opinion__author .author-img {
  width: 6.3rem;
  min-width: 6.3rem;
  height: 6.3rem;
}
@media screen and (max-width: 767px) {
  .opinion__author .author-img {
    width: 5.8rem;
    min-width: 5.8rem;
    height: 5.8rem;
  }
}

.author-info__height {
  min-height: 6.1rem;
}
@media screen and (max-width: 1199px) {
  .author-info__height {
    min-height: 4rem;
  }
}

.career-advantages {
  margin-top: 13rem;
  padding: 12.8rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .career-advantages {
    margin-top: 4.3rem;
    padding: 4.6rem 0 5.2rem;
  }
}
.career-advantages__title {
  margin-bottom: 0.7em;
}
@media screen and (max-width: 767px) {
  .career-advantages__title br {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .career-advantages__title {
    margin-bottom: 0.3em;
  }
}
.career-advantages__title .ic {
  display: inline-block;
  width: 7.8rem;
  height: 6.6rem;
  margin-left: 2rem;
  -ms-flex-item-align: end;
      align-self: flex-end;
}
@media screen and (max-width: 767px) {
  .career-advantages__title .ic {
    width: 2.6rem;
    height: 2.3rem;
    margin-left: 0.5rem;
  }
}
.career-advantages__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.2rem 14px;
}
@media screen and (min-width: 768px) {
  .career-advantages__grid {
    gap: 2.2rem 20px;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1600px) {
  .career-advantages__grid {
    gap: 4rem 40px;
  }
}
@media screen and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(2) {
    padding-right: 53%;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(2) {
    grid-column-end: span 2;
  }
}
@media screen and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(2) .career-advantage__img {
    width: calc(50% - 10px);
    height: 100%;
    top: 0;
    right: 0;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(2) .career-advantage__img {
    width: calc(50% - 20px);
  }
}
@media screen and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(3) {
    padding-right: 48%;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(3) {
    min-height: 31rem;
    grid-column-end: span 2;
  }
}
.career-advantages .career-advantage:nth-child(3) .career-advantage__img {
  width: 32.3rem;
  height: 19.2rem;
}
@media screen and (max-width: 767px) {
  .career-advantages .career-advantage:nth-child(3) .career-advantage__img {
    margin: 2.5rem auto 0;
    width: 15.8rem;
    height: 9.4rem;
  }
}
@media screen and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(3) .career-advantage__img {
    right: 4rem;
    top: 50%;
    margin-top: -9.6rem;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(3) .career-advantage__img {
    right: 7rem;
  }
}
@media screen and (max-width: 1023px) and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(4) {
    padding-right: 53%;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(4) {
    grid-row-end: span 2;
  }
}
@media screen and (min-width: 768px) {
  .career-advantages .career-advantage:nth-child(4) .career-advantage__img {
    width: calc(50% - 10px);
    height: 100%;
    top: 0;
    right: 0;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantages .career-advantage:nth-child(4) .career-advantage__img {
    width: 100%;
    height: calc(50% - 2.5rem);
    top: auto;
    right: auto;
    left: 0;
    bottom: 0;
  }
}
@media screen and (min-width: 1200px) {
  .career-advantages .career-advantage:nth-child(4) .career-advantage__img {
    height: calc(50% - 3.6rem);
  }
}

.career-advantage {
  padding: 4rem 4.8rem;
  background-color: rgba(13, 74, 78, 0.8);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1199px) {
  .career-advantage {
    padding: 3rem 2.4rem;
  }
}
@media screen and (max-width: 767px) {
  .career-advantage {
    padding: 2.4rem 15px;
  }
}
@media screen and (min-width: 1024px) {
  .career-advantage {
    min-height: 28rem;
  }
}
.career-advantage .title {
  margin-bottom: 0.6em;
}
@media screen and (min-width: 1200px) {
  .career-advantage .hidden-txt {
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.2s 0.1s;
    -o-transition: all 0.2s 0.1s;
    transition: all 0.2s 0.1s;
  }
}
@media screen and (max-width: 767px) {
  .career-advantage__img {
    width: calc(100% + 30px);
    margin: 3rem 0 -2.4rem -15px;
  }
}
@media screen and (min-width: 768px) {
  .career-advantage__img {
    position: absolute;
    z-index: -1;
  }
}
@media screen and (min-width: 1200px) {
  .career-advantage {
    -webkit-transition: background-color 0.2s 0.1s;
    -o-transition: background-color 0.2s 0.1s;
    transition: background-color 0.2s 0.1s;
  }
  .career-advantage:hover {
    background-color: var(--color-accent-add);
    -webkit-transition-delay: 0s;
         -o-transition-delay: 0s;
            transition-delay: 0s;
  }
  .career-advantage:hover .hidden-txt {
    opacity: 1;
    visibility: visible;
  }
}

.gallery {
  padding: 9.5rem 0;
  background-color: #3D3333;
  color: var(--color-white);
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .gallery {
    padding: 4.2rem 0 3.6rem;
  }
}
.gallery .fz-60 {
  margin-bottom: 0.1em;
}
@media screen and (max-width: 767px) {
  .gallery .fz-60 {
    margin-bottom: 0.35em;
  }
}

.gallery-slider {
  margin-top: 4.5rem;
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .gallery-slider {
    margin-top: 2.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .gallery-slider::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 2;
    right: 100%;
    top: 0;
    background: #3D3333;
  }
}
.gallery-slider .swiper-slide {
  max-width: 63.8rem;
}
@media screen and (max-width: 767px) {
  .gallery-slider .swiper-slide {
    max-width: 31rem;
  }
}
.gallery-slider__dots .swiper-pagination-bullet-active {
  border-color: rgba(255, 255, 255, 0.1);
}

.gallery-item {
  position: relative;
  z-index: 1;
  height: 45.4rem;
}
@media screen and (max-width: 767px) {
  .gallery-item {
    height: auto;
    padding-bottom: 8rem;
  }
}
@media screen and (max-width: 767px) {
  .gallery-item .bg {
    height: 22.6rem;
    position: static;
  }
}
.gallery-item__block {
  min-width: 30.1rem;
  max-width: 37.1rem;
  position: absolute;
  bottom: 0;
  left: 0;
  padding: 2.6rem;
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), linear-gradient(111.49deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  -webkit-backdrop-filter: blur(50px);
          backdrop-filter: blur(50px);
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .gallery-item__block {
    width: 100%;
    max-width: 100%;
    min-height: 10.5rem;
    padding: 1.8rem 16px;
  }
}

.work {
  margin: 9.3rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .work {
    margin: 5.6rem 0 7.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .work__title {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .work__title {
    margin-bottom: 2.5rem;
  }
}
.work .text {
  margin-bottom: 3.2rem;
}
@media screen and (max-width: 767px) {
  .work .text {
    margin-bottom: 2.4rem;
  }
}
.work__bottom {
  margin-top: 10rem;
}
@media screen and (max-width: 1023px) {
  .work__bottom {
    margin-top: 5.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .work__bottom .column:nth-child(2) {
    grid-column-start: 1;
    grid-row-start: 1;
  }
}
@media screen and (max-width: 1023px) {
  .work__bottom .img-pare {
    margin-top: 2rem;
  }
}
.work .a-block {
  padding: 4rem 5rem;
}
@media screen and (max-width: 767px) {
  .work .a-block {
    padding: 1.7rem;
  }
}
.work .a-block .title {
  max-width: 38rem;
}
@media screen and (max-width: 767px) {
  .work .a-block .title {
    max-width: 26rem;
  }
}

.img-pare {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.img-pare .img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 32%;
     object-position: 50% 32%;
}
.work-social {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .img-pare .img {
    max-height: 25rem;
    width: 100%;
  }
}
@media screen and (min-width: 1200px) {
  .img-pare .img {
    height: 36rem;
  }
}
@media screen and (min-width: 1200px) {
  .img-pare .img:nth-child(1) {
    width: calc(57% - 10px);
  }
}
@media screen and (min-width: 1600px) {
  .img-pare .img:nth-child(1) {
    width: calc(57% - 20px);
  }
}
@media screen and (min-width: 1200px) {
  .img-pare .img:nth-child(2) {
    width: calc(43% - 10px);
  }
}
@media screen and (min-width: 1600px) {
  .img-pare .img:nth-child(2) {
    width: calc(43% - 20px);
  }
}

.steps {
  margin: 13.2rem 0 15rem;
}
@media screen and (max-width: 767px) {
  .steps {
    margin: 7.5rem 0 5.4rem;
  }
}
.steps__title {
  max-width: 60rem;
}
.steps-slider {
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .steps-slider {
    margin-top: 3.2rem;
  }
}
.steps-slider .swiper-wrapper {
  counter-reset: k;
}
@media screen and (min-width: 1200px) {
  .steps-slider .swiper-wrapper {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (max-width: 1199px) {
  .steps-slider .swiper-slide {
    max-width: 40rem;
  }
}
@media screen and (max-width: 767px) {
  .steps-slider .swiper-slide {
    max-width: 15rem;
  }
}
.steps-slider .swiper-slide:nth-child(1) .step::after {
  width: 23.8em;
  height: 7.3em;
  background-image: url("../img/career/curve-1.svg");
}
@media screen and (min-width: 768px) {
  .steps-slider .swiper-slide:nth-child(1) .step::after {
    top: -1em;
    right: -12em;
  }
}
.steps-slider .swiper-slide:nth-child(2) .step::after {
  width: 22.6em;
  height: 5.1em;
  background-image: url("../img/career/curve-2.svg");
}
@media screen and (min-width: 768px) {
  .steps-slider .swiper-slide:nth-child(2) .step::after {
    top: 0.4em;
    right: -12.5em;
  }
}
.steps-slider .swiper-slide:nth-child(3) .step::after {
  width: 23em;
  height: 6.3em;
  background-image: url("../img/career/curve-3.svg");
}
@media screen and (min-width: 768px) {
  .steps-slider .swiper-slide:nth-child(3) .step::after {
    top: -1em;
    right: -12em;
  }
}
.steps-slider .swiper-slide:last-child .step::after {
  display: none;
}
.steps-slider .step {
  position: relative;
  z-index: 1;
}
.steps-slider .step::before {
  counter-increment: k;
  content: counter(k) ".";
  display: inline-block;
  margin-bottom: 0.2em;
  font: 500 8.7rem/1 var(--title-font);
  color: var(--color-accent-add);
}
@media screen and (max-width: 767px) {
  .steps-slider .step::before {
    font-size: 4.6rem;
    margin-bottom: 0.4em;
  }
}
.steps-slider .step::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  background: no-repeat 50% 50%/contain;
  font-size: 1rem;
}
@media screen and (max-width: 1439px) {
  .steps-slider .step::after {
    font-size: 0.9rem;
  }
}
@media screen and (max-width: 767px) {
  .steps-slider .step::after {
    font-size: 0.4rem;
  }
}

.step {
  max-width: 22rem;
}
.step a {
  color: var(--color-accent-main);
}
@media screen and (min-width: 1200px) {
  .step a:hover {
    color: var(--color-accent-add);
  }
}

.banner-link {
  margin: 12rem 0;
}
@media screen and (max-width: 767px) {
  .banner-link {
    margin: 5.2rem 0;
  }
}
.banner-link__inner {
  display: block;
  height: 45rem;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .banner-link__inner {
    height: 21.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .banner-link__inner:hover {
    color: var(--color-accent-main);
  }
}
.banner-link__inner .g-block {
  width: 50%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding-bottom: 4.6rem;
  -webkit-transition: color 0.2s;
  -o-transition: color 0.2s;
  transition: color 0.2s;
}
@media screen and (max-width: 767px) {
  .banner-link__inner .g-block {
    background: none;
    padding-bottom: 2.7rem;
  }
}
.banner-link__inner .title {
  max-width: 30rem;
}
@media screen and (max-width: 767px) {
  .banner-link .bg {
    -o-object-position: 60% 50%;
       object-position: 60% 50%;
  }
}

.locations {
  margin: 12rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .locations {
    margin: 5.2rem 0;
  }
}
@media screen and (max-width: 767px) {
  .locations__title {
    margin-bottom: 0.3em;
  }
}
.locations__grid {
  margin-top: 6rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .locations__grid {
    margin-top: 3rem;
  }
}
.locations-slider-wrap {
  position: relative;
  min-width: 0;
}
.locations-slider__arrows {
  position: absolute;
  z-index: 2;
  right: 5.6rem;
  bottom: 3.6rem;
}
.locations-slider__arrows .slider-arrow {
  margin-left: 4px;
}
@media screen and (max-width: 767px) {
  .locations-slider .gallery-item {
    height: 30rem;
  }
}
@media screen and (min-width: 768px) {
  .locations-slider .gallery-item {
    height: 63.9rem;
  }
}
@media screen and (min-width: 768px) {
  .locations-slider .gallery-item__block {
    min-width: 38rem;
  }
}
.locations-other {
  display: grid;
  gap: 20px;
}
@media screen and (max-width: 1023px) {
  .locations-other {
    margin-top: 2.6rem;
  }
}
@media screen and (min-width: 1600px) {
  .locations-other {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .locations-other .gallery-item {
    height: 14.8rem;
  }
}
@media screen and (min-width: 768px) {
  .locations-other .gallery-item:nth-child(1) {
    height: 33rem;
  }
}
@media screen and (min-width: 1600px) {
  .locations-other .gallery-item:nth-child(1) {
    height: 31.5rem;
  }
}
@media screen and (min-width: 768px) {
  .locations-other .gallery-item:nth-child(2) {
    height: 28.6rem;
  }
}
@media screen and (max-width: 767px) {
  .locations .gallery-item {
    padding-bottom: 0;
  }
  .locations .gallery-item .bg {
    height: 100%;
  }
  .locations .gallery-item__block {
    width: auto;
    min-width: 24.4rem;
    min-height: auto;
  }
}

/* -------------------------------------
 * job
 * ------------------------------------- */
.page-row {
  margin: 3.2rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .page-row {
    margin: 2rem 0 6.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .page-row {
    padding-bottom: 9rem;
    border-bottom: 1px solid #E2E5EB;
  }
}
@media screen and (min-width: 1024px) {
  .page-row--has-title .main {
    padding-top: 6.4rem;
  }
}

.main {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
}
@media screen and (max-width: 1023px) {
  .main {
    width: 100%;
  }
}

.job-list li {
  border: 1px solid var(--border-color);
}
.job-list li:not(:first-child) {
  border-top: none;
}

.job-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 2.6rem 4.8rem;
}
@media screen and (max-width: 767px) {
  .job-link {
    display: block;
    padding: 2rem 7.6rem 2rem 16px;
    position: relative;
  }
}
@media screen and (min-width: 1200px) {
  .job-link:hover {
    color: var(--color-accent-main);
  }
}
.job-link__title {
  margin-right: auto;
  padding-right: 3.2rem;
}
@media screen and (max-width: 767px) {
  .job-link__title {
    padding-right: 0;
  }
}
.job-link__city {
  margin-right: 3.2rem;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .job-link__city {
    font-size: 1.4rem;
  }
}
.job-link .slider-arrow {
  background-color: var(--color-accent-main);
  border-color: var(--color-accent-main);
}
.job-link .slider-arrow::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
@media screen and (max-width: 767px) {
  .job-link .slider-arrow {
    position: absolute;
    right: 16px;
    top: 50%;
    margin-top: -2.3rem;
  }
}

.side {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 35rem;
          flex: 0 0 35rem;
  max-width: 35rem;
  margin-right: 40px;
}
@media screen and (max-width: 1023px) {
  .side {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    max-width: 100%;
    margin-bottom: 2.4rem;
  }
}
.side .filter {
  margin-bottom: 8px;
}

.filters-title {
  margin-bottom: 2.8rem;
}
@media screen and (max-width: 1023px) {
  .filters-title {
    margin: 0;
    padding: 18px 8rem 18px 4.8rem;
    background-color: var(--bg);
    font: 500 18px/1 var(--text-font);
    letter-spacing: -0.02em;
    border: 1px solid var(--border-color);
    position: relative;
  }
  .filters-title::after {
    content: "";
    display: block;
    font-size: 14px;
    width: 1.9em;
    height: 1.9em;
    position: absolute;
    z-index: 0;
    right: 4.8rem;
    top: 50%;
    margin-top: -0.9em;
    background: url("../img/icons/setting-config.svg") no-repeat 50% 50%/contain;
  }
}
@media screen and (max-width: 767px) {
  .filters-title {
    font-size: 14px;
    padding: 15px 40px 15px 16px;
  }
  .filters-title::after {
    font-size: 10px;
    right: 16px;
  }
}

@media screen and (max-width: 1023px) {
  .filters {
    display: none;
  }
}

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

.filter-remove {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 15px;
  margin: 0 1.8rem 1.4rem 0;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
.filter-remove::before {
  content: "";
  display: block;
  width: 10px;
  min-width: 10px;
  height: 10px;
  margin-right: 0.8rem;
  background: url("../img/icons/akar-icons_cross.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
  -webkit-filter: brightness(0);
          filter: brightness(0);
}
@media screen and (min-width: 1200px) {
  .filter-remove:hover {
    color: var(--color-accent-main);
  }
  .filter-remove:hover::before {
    -webkit-filter: none;
            filter: none;
  }
}

.filter {
  background-color: var(--bg);
  border: 1px solid var(--border-color);
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  color: var(--color-title);
}
.filter-title {
  padding: 18px 32px;
  position: relative;
  cursor: pointer;
}
.filter-title::after {
  content: "";
  display: block;
  width: 8px;
  height: 5px;
  position: absolute;
  z-index: 0;
  right: 20px;
  top: 50%;
  margin-top: -2px;
  background: url("../img/icons/chevron-down-sm.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
.filter-list {
  display: none;
  padding: 0 32px 20px;
}
.filter-list .checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 3rem;
}
.filter-list .checkbox:last-child {
  margin-bottom: 0;
}
.filter.is-open .filter-title::after {
  -webkit-transform: rotate(-180deg);
      -ms-transform: rotate(-180deg);
          transform: rotate(-180deg);
}

@media screen and (min-width: 1024px) {
  .side .mob-filters {
    display: block !important;
  }
}

@media screen and (max-width: 1023px) {
  .mob-filters {
    width: 100%;
    padding: 0;
    background-color: var(--bg);
  }
  .mob-filters .fancybox-close-small {
    position: fixed;
    right: 10px;
    top: 10px;
    background: none;
  }
  .mob-filters .fancybox-close-small::before {
    -webkit-filter: brightness(0);
            filter: brightness(0);
  }
  .mob-filters .filters-head, .mob-filters .filter, .mob-filters .filters-bottom {
    padding: 20px 20px 10px;
  }
  .mob-filters .filters-head {
    padding-right: 40px;
    font-size: 22px;
  }
}
@media screen and (max-width: 1023px) and (max-width: 767px) {
  .mob-filters .filters-head {
    font-size: 16px;
  }
}
@media screen and (max-width: 1023px) {
  .mob-filters .filter {
    background: none;
    border-top: none;
    border-left: none;
    border-right: none;
  }
}
@media screen and (max-width: 1023px) {
  .mob-filters .filter-title {
    margin-bottom: 1.9rem;
    padding: 0;
    font-weight: 700;
  }
  .mob-filters .filter-title::after {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  .mob-filters .filter-list {
    display: block;
    padding: 0;
  }
  .mob-filters .filter-list .checkbox {
    margin-bottom: 1.9rem;
  }
}
@media screen and (max-width: 1023px) {
  .mob-filters .filters-bottom {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding-bottom: 20px;
  }
  .mob-filters .filters-bottom .button {
    font-size: 16px;
  }
}
@media screen and (max-width: 1023px) {
  .mob-filters .filters-search {
    padding: 20px 20px 0;
    position: relative;
  }
  .mob-filters .filters-search .input {
    background: none;
    font-weight: 500;
    padding-right: 30px;
  }
  .mob-filters .filters-search .submit {
    width: 20px;
    height: 20px;
    position: absolute;
    right: 21px;
    top: 50%;
    margin-top: -10px;
  }
  .mob-filters .filters-search .submit::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url("../img/icons/search-accent.svg") no-repeat 50% 50%/contain;
    -webkit-filter: brightness(0);
            filter: brightness(0);
  }
}

.vacancy {
  margin: 7.5rem 0 9rem;
}
@media screen and (max-width: 1023px) {
  .vacancy {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .vacancy {
    margin: 0 0 5rem;
  }
}
.vacancy__row {
  padding: 5rem 0;
  border-bottom: 1px solid var(--border-color);
}
@media screen and (max-width: 767px) {
  .vacancy__row {
    padding: 3rem 0;
  }
}
@media screen and (min-width: 1024px) {
  .vacancy__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.vacancy__head {
  padding: 0;
  border: none;
}
@media screen and (max-width: 1023px) {
  .vacancy__head {
    padding: 4rem 20px;
    background-color: var(--bg);
    color: var(--color-title);
  }
}
@media screen and (max-width: 767px) {
  .vacancy__head {
    padding: 2.5rem 14px 3rem;
  }
}
@media screen and (min-width: 1024px) {
  .vacancy__head .vacancy__txt {
    background-color: var(--bg);
    padding: 3.6rem 4.5rem 3.6rem 2.8rem;
    color: var(--color-title);
  }
}
@media screen and (max-width: 1023px) {
  .vacancy__title {
    margin-bottom: 0.5em;
  }
  .vacancy__title br {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .vacancy__title {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 37.2rem;
            flex: 0 0 37.2rem;
    max-width: 37.2rem;
    margin-right: 2.2rem;
  }
}
@media screen and (min-width: 1024px) {
  .vacancy__txt {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
    max-width: 100%;
  }
}
.vacancy__txt .column {
  margin-right: auto;
}
@media screen and (max-width: 1023px) {
  .vacancy__txt .column {
    width: 100%;
  }
}
.vacancy__txt .column-title {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 767px) {
  .vacancy__txt .column-title {
    margin-bottom: 0.8em;
  }
}
@media screen and (max-width: 1023px) {
  .vacancy__txt .column-list li {
    margin-bottom: 0.8em;
  }
}
@media screen and (max-width: 767px) {
  .vacancy__txt .button {
    width: 100%;
  }
}

/* -------------------------------------
 * esg
 * ------------------------------------- */
.hero-esg {
  margin-bottom: 16rem;
}
@media screen and (max-width: 1023px) {
  .hero-esg {
    margin-bottom: 20rem;
    padding-bottom: 26rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-esg {
    margin-bottom: 16rem;
  }
}
.hero-esg__banner {
  height: 68.5rem;
  margin-top: 4rem;
  position: relative;
}
@media screen and (max-width: 1023px) {
  .hero-esg__banner .img {
    position: absolute;
    top: 0;
    left: 0;
  }
}
@media screen and (max-width: 767px) {
  .hero-esg__banner {
    height: 30.4rem;
    margin-top: 2rem;
  }
}
.hero-esg__col {
  width: 100%;
  max-width: 69.5rem;
  position: absolute;
  top: 21rem;
  right: 8.5rem;
}
@media screen and (max-width: 1439px) {
  .hero-esg__col {
    right: 40px;
  }
}
@media screen and (max-width: 1199px) {
  .hero-esg__col {
    right: 20px;
  }
}
@media screen and (max-width: 1023px) {
  .hero-esg__col {
    top: auto;
    bottom: -36rem;
    right: 0;
    max-width: 100%;
  }
}
.hero-esg__subtitle {
  padding: 5rem;
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), linear-gradient(111.49deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  -webkit-backdrop-filter: blur(50px);
          backdrop-filter: blur(50px);
}
@media screen and (max-width: 767px) {
  .hero-esg__subtitle {
    padding: 3rem 15px;
  }
}
.hero-esg__txt {
  padding: 5rem;
  background: var(--color-accent-add);
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .hero-esg__txt {
    padding: 2rem 15px;
  }
}

.about-esg {
  margin-bottom: 9.7rem;
}
@media screen and (max-width: 767px) {
  .about-esg {
    margin-bottom: 5rem;
  }
}
.about-esg__title {
  max-width: 110rem;
}
.about-esg .fz-130 {
  line-height: 0.75;
  margin-bottom: 0.1em;
}
@media screen and (max-width: 767px) {
  .about-esg .fz-130 {
    margin-bottom: 0.2em;
  }
}
.about-esg__grid {
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .about-esg__grid {
    margin-top: 4rem;
  }
}
.about-esg .a-block {
  padding: 6rem 8rem 5rem 5rem;
}
@media screen and (max-width: 767px) {
  .about-esg .a-block {
    padding: 2.6rem 14px;
  }
}
.about-esg__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .about-esg__list {
    gap: 20px;
  }
}
@media screen and (min-width: 1024px) {
  .about-esg__list {
    margin-top: 0;
  }
}
@media screen and (min-width: 1200px) {
  .about-esg__list {
    gap: 40px;
  }
}
.about-esg__list .item {
  min-height: 22.9rem;
}
@media screen and (max-width: 767px) {
  .about-esg__list .item {
    min-height: auto;
    height: 11rem;
  }
}
.about-esg__list .ic {
  width: 6.7rem;
  height: 7.8rem;
}
@media screen and (max-width: 767px) {
  .about-esg__list .ic {
    width: 3.2rem;
    height: 3.8rem;
  }
}

.esg-projects {
  margin: 9rem 0 7rem;
}
@media screen and (max-width: 767px) {
  .esg-projects {
    margin: 4.5rem 0 5rem;
  }
}

.esg {
  padding: 9rem 0;
}
@media screen and (max-width: 767px) {
  .esg {
    padding: 6rem 0 5rem;
  }
}
@media screen and (min-width: 1024px) {
  .esg__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.esg__img {
  height: 36.4rem;
}
@media screen and (max-width: 1023px) {
  .esg__img {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .esg__img {
    height: 16.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .esg__img {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 40rem;
            flex: 0 0 40rem;
    max-width: 40rem;
    margin-right: auto;
  }
}
@media screen and (min-width: 1024px) {
  .esg__col {
    width: 74rem;
  }
}
.esg__list .esg-project {
  margin-bottom: 16px;
}
@media screen and (max-width: 1023px) {
  .esg__list .esg-project {
    margin-bottom: 24px;
  }
}
.esg-1 {
  padding-top: 1rem;
}
.esg-2 {
  background-color: var(--color-accent-main);
  color: var(--color-white);
}
@media screen and (min-width: 1200px) {
  .esg-2 .esg-project:hover .esg-project__txt {
    border-top-color: rgba(255, 255, 255, 0.5);
    border-bottom-color: rgba(255, 255, 255, 0.5);
    border-right-color: rgba(255, 255, 255, 0.5);
  }
}
.esg-2 .button-anim {
  background-color: var(--color-white);
}
.esg-2 .button-anim::before {
  background: var(--color-accent-main);
}
@media screen and (min-width: 1200px) {
  .esg-2 .button-anim:hover {
    color: var(--color-title);
  }
}
.esg-3 {
  background-color: #3D3333;
  color: var(--color-white);
}
.esg-3 .bg-gray {
  background-color: rgba(255, 255, 255, 0.1);
}
@media screen and (min-width: 1200px) {
  .esg-3 .esg-project:hover .esg-project__txt {
    border-top-color: rgba(255, 255, 255, 0.1);
    border-bottom-color: rgba(255, 255, 255, 0.1);
    border-right-color: rgba(255, 255, 255, 0.1);
  }
}
.esg-3 .button-anim {
  background-color: var(--color-white);
}
.esg-3 .button-anim::before {
  background: #3D3333;
}
@media screen and (min-width: 1200px) {
  .esg-3 .button-anim:hover {
    color: var(--color-title);
  }
}

.esg-project {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .esg-project {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (min-width: 1024px) {
  .esg-project {
    min-height: 11.1rem;
  }
}
@media screen and (min-width: 1200px) {
  .esg-project:hover .esg-project__txt {
    border-top-color: var(--border-color);
    border-bottom-color: var(--border-color);
    border-right-color: var(--border-color);
  }
}
.esg-project__img {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 19.3rem;
          flex: 0 0 19.3rem;
  max-width: 19.3rem;
  padding: 2.5rem 4rem;
}
@media screen and (max-width: 1023px) {
  .esg-project__img {
    height: 11rem;
  }
}
@media screen and (max-width: 767px) {
  .esg-project__img {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 14.9rem;
            flex: 0 0 14.9rem;
    max-width: 14.9rem;
    height: 9rem;
  }
}
.esg-project__txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
  padding-left: 4rem;
}
@media screen and (max-width: 767px) {
  .esg-project__txt {
    padding-left: 1.8rem;
  }
}
@media screen and (min-width: 1200px) {
  .esg-project__txt {
    border-top: 1px solid transparent;
    border-bottom: 1px solid transparent;
    border-right: 1px solid transparent;
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
}

.esg-modal {
  display: none;
  width: 100%;
  max-width: 115rem;
  padding: 0;
  background-color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .esg-modal__row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}
.esg-modal__img {
  height: 66rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .esg-modal__img {
    height: 28rem;
  }
}
@media screen and (min-width: 768px) {
  .esg-modal__img {
    width: 30%;
  }
}
.esg-modal__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 2rem 3rem;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  background-color: var(--bg-sections);
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .esg-modal__link {
    padding: 1.6rem 16px;
  }
}
.esg-modal__link:hover {
  color: var(--color-white);
}
@media screen and (min-width: 1200px) {
  .esg-modal__link:hover {
    color: var(--color-accent-main);
  }
  .esg-modal__link:hover .circle-arrow-blank {
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
  }
}
.esg-modal__col {
  padding: 2.2rem 16px 3.5rem;
}
@media screen and (min-width: 768px) {
  .esg-modal__col {
    width: 70%;
    padding: 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .esg-modal__col {
    padding: 7rem;
    padding-right: 2.4rem;
  }
}
.esg-modal__title {
  margin-bottom: 0.7em;
}
@media screen and (min-width: 768px) {
  .esg-modal__scroll {
    max-height: 41rem;
    padding-right: 5rem;
  }
}
@media screen and (max-width: 767px) {
  .esg-modal .fancybox-close-small {
    position: fixed;
  }
}

/* -------------------------------------
 * docs
 * ------------------------------------- */
.licenses {
  margin: 8.5rem 0;
}
@media screen and (max-width: 767px) {
  .licenses {
    margin: 3.5rem 0 4.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .licenses .doc {
    min-height: 18.4rem;
  }
}

.docs-grid {
  display: grid;
  gap: 3.5rem 40px;
  grid-template-columns: repeat(4, 1fr);
}
@media screen and (max-width: 1199px) {
  .docs-grid {
    gap: 20px;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 1023px) {
  .docs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .docs-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}
.docs-grid .is-hidden {
  display: none;
}

.doc {
  padding: 3.4rem 4.5rem;
  border: 1px solid var(--border-color);
  position: relative;
}
@media screen and (max-width: 767px) {
  .doc {
    padding: 2.2rem 15px;
  }
}
@media screen and (min-width: 1200px) {
  .doc {
    -webkit-transition: border-color 0.2s;
    -o-transition: border-color 0.2s;
    transition: border-color 0.2s;
  }
  .doc:hover {
    border-color: var(--color-accent-main);
  }
}
.doc__img {
  width: 6.1rem;
  height: 8.5rem;
  margin-bottom: 1.8rem;
}
@media screen and (max-width: 767px) {
  .doc__img {
    width: 4rem;
    height: 5.5rem;
    margin-bottom: 1rem;
  }
}
.doc .ext {
  position: absolute;
  top: 3.4rem;
  right: 4.5rem;
  background-color: var(--bg);
}
@media screen and (max-width: 767px) {
  .doc .ext {
    top: 2.2rem;
    right: 15px;
  }
}

.requisites {
  margin: 8.5rem 0;
  padding: 5.5rem 0 5rem;
}
@media screen and (max-width: 767px) {
  .requisites {
    margin: 5rem 0;
    padding: 4rem 0 5rem;
  }
}
.requisites .table {
  position: relative;
}
@media screen and (min-width: 1200px) {
  .requisites .table-row {
    max-width: 74%;
  }
}
@media screen and (max-width: 767px) {
  .requisites .download-link {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .requisites .download-link {
    height: 18.8rem;
  }
}
@media screen and (min-width: 1200px) {
  .requisites .download-link {
    position: absolute;
    top: 0;
    right: 0;
  }
}

.table-row {
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .table-row {
    margin-bottom: 4rem;
  }
}
@media screen and (min-width: 1024px) {
  .table-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (max-width: 1023px) {
  .table-title {
    margin-bottom: 0.5em;
  }
  .table-title br {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .table-title {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 39rem;
            flex: 0 0 39rem;
    padding-right: 1em;
  }
}
@media screen and (min-width: 1024px) {
  .table-cell {
    max-width: 100%;
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
  }
}

.docs {
  margin: 8.5rem 0 9rem;
}
@media screen and (max-width: 767px) {
  .docs {
    margin: 4rem 0 5rem;
  }
}
@media screen and (max-width: 1023px) {
  .docs .button-more {
    margin-top: 2.4rem;
  }
}

/* -------------------------------------
 * contacts
 * ------------------------------------- */
.contacts {
  margin: 8.5rem 0;
}
@media screen and (max-width: 767px) {
  .contacts {
    margin: 5rem 0 3rem;
  }
}
.contacts-section {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .contacts-section {
    margin-top: 4.8rem;
  }
}
.contacts-section:first-child {
  margin-top: 0;
}
.contacts-block {
  border: 1px solid var(--border-color);
}
.contacts-block__grid {
  padding: 6rem 4.5rem 4.6rem;
}
@media screen and (max-width: 767px) {
  .contacts-block__grid {
    padding: 20px 16px 16px;
  }
}
@media screen and (max-width: 1199px) {
  .contacts-block .address {
    margin-bottom: 1em;
  }
}
@media screen and (max-width: 767px) {
  .contacts-block .address {
    margin-bottom: 0.7em;
  }
}
.contacts-block .title {
  display: inline-block;
  margin-bottom: 0.2em;
}
@media screen and (min-width: 1200px) {
  .contacts-block a:hover {
    color: var(--color-accent-main);
  }
}
.contacts-img {
  height: 31rem;
  position: relative;
  width: calc(100% + 2px);
  left: -1px;
  bottom: -1px;
}
@media screen and (max-width: 767px) {
  .contacts-img {
    height: 20rem;
  }
}
@media screen and (max-width: 1023px) {
  .contacts .map {
    height: 52rem;
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  .contacts .map {
    height: 34rem;
  }
}
@media screen and (max-width: 767px) {
  .contacts .fz-15 {
    font-size: 1.3rem;
    margin-bottom: 0.2em;
  }
}

.map {
  overflow: hidden;
}
.map .ymaps-2-1-79-map-copyrights-promo,
.map .ymaps-2-1-79-copyright {
  display: none;
}
.map .ymaps-2-1-79-ground-pane {
  -webkit-filter: grayscale(0.4);
          filter: grayscale(0.4);
}

.contacts-emails {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 11rem;
  padding: 9rem 0;
}
@media screen and (max-width: 767px) {
  .contacts-emails {
    margin-top: 3rem;
    padding: 2.8rem 0;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
.contacts-emails .column {
  padding: 0 5rem;
}
@media screen and (max-width: 767px) {
  .contacts-emails .column {
    padding: 0 16px;
  }
}
.contacts-emails .subcolor {
  color: inherit;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .contacts-emails .fz-36 {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .contacts-emails a:hover {
    color: var(--color-accent-main);
  }
}

.socials {
  margin: 8.6rem 0;
}
@media screen and (max-width: 767px) {
  .socials {
    margin: 3.3rem 0 5.4rem;
  }
}
.socials__inner {
  text-align: center;
  padding: 7.8rem 0 9.6rem;
}
@media screen and (max-width: 767px) {
  .socials__inner {
    padding: 4.5rem 0;
  }
}
.socials__title {
  margin-bottom: 0.1em;
}
.socials .soc {
  margin-top: 2.7rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .socials .soc {
    margin-top: 1.8rem;
  }
}
.socials .soc li {
  margin: 0 1.4rem;
}
@media screen and (max-width: 767px) {
  .socials .soc li {
    margin: 0 0.7rem;
  }
}
.socials .soc a {
  font-size: 1rem;
  width: 8.4em;
  height: 8.4em;
}
@media screen and (max-width: 767px) {
  .socials .soc a {
    font-size: 0.5rem;
  }
}
.socials .soc a .img {
  font-size: 1em;
  width: 100%;
  height: 100%;
  max-width: 4.1em;
  max-height: 3.2em;
}

/* -------------------------------------
 * services
 * ------------------------------------- */
.hero-services {
  position: relative;
  z-index: 1;
}
.hero-services__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  min-height: 46rem;
  padding-bottom: 3.3rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .hero-services__inner {
    min-height: 40.5rem;
    padding-bottom: 2.2rem;
  }
}
.hero-services .services-ic {
  position: absolute;
  bottom: 3.3rem;
  right: 0;
}
@media screen and (max-width: 767px) {
  .hero-services .bg .img--cover {
    -o-object-position: 35% 50%;
       object-position: 35% 50%;
  }
}

.services {
  margin: 5.5rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .services {
    margin: 2.5rem 0 5rem;
  }
}
.services__head {
  margin: 9rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .services__head {
    margin: 6rem 0 3rem;
  }
}
@media screen and (max-width: 767px) {
  .services__title {
    margin-bottom: 5rem;
  }
}
.services__title .fz-160 {
  margin-top: 2.4rem;
  margin-bottom: 0.07em;
}
@media screen and (max-width: 767px) {
  .services__title .fz-160 {
    margin-bottom: 0.15em;
  }
}
.services-lvl-1 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
  height: 52rem;
  margin-bottom: 4.5rem;
  padding-top: 7.5rem;
  padding-bottom: 5rem;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .services-lvl-1 {
    height: 62vw;
    max-height: 52rem;
    margin-bottom: 3.1rem;
    padding-top: 3.8rem;
    padding-bottom: 15px;
  }
}
@media screen and (min-width: 1200px) {
  .services-lvl-1:hover {
    color: var(--color-accent-main);
  }
}
.services-lvl-1 .services-ic {
  margin-top: auto;
}
.services-ic {
  font-size: 1rem;
  width: 19.2em;
  height: 18.8em;
  padding: 5.6em 4em;
  background-color: var(--bg-sections);
}
@media screen and (max-width: 767px) {
  .services-ic {
    font-size: 0.33rem;
  }
}
.services-list {
  margin-bottom: 3.8rem;
}
@media screen and (max-width: 1023px) {
  .services-list {
    margin-bottom: 3rem;
  }
}
.services-list li {
  border-bottom: 1px solid #E2E5EB;
}
.services-list > li:last-child {
  margin-bottom: 0;
  border: none;
}
@media screen and (max-width: 1023px) {
  .services-list > li {
    margin-bottom: 1.3em;
  }
}
@media screen and (min-width: 1024px) {
  .services-list > li {
    margin-bottom: 2.5rem;
    padding: 1rem 0 2rem;
  }
}
@media screen and (min-width: 1024px) {
  .services-list > li {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}
@media screen and (min-width: 1600px) {
  .services-list > li {
    gap: 40px;
  }
}
@media screen and (max-width: 1023px) {
  .services-list .title {
    padding-bottom: 0.8em;
  }
}
@media screen and (max-width: 1023px) {
  .services-list .list {
    padding-top: 0.8em;
    border-top: 1px solid #E2E5EB;
  }
}
.services-list .list li {
  margin-bottom: 1em;
  padding-bottom: 1em;
}
@media screen and (max-width: 1023px) {
  .services-list .list li {
    margin-bottom: 0.8em;
    padding-bottom: 0.8em;
    padding-left: 1em;
  }
}
.services-list .list li:last-child {
  border: none;
  margin: 0;
}
@media screen and (min-width: 1200px) {
  .services-list a:hover {
    color: var(--color-accent-main);
  }
}
.services-list:last-child > li {
  border-bottom: 1px solid #E2E5EB;
}

.hero-service-2 {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1023px) {
  .hero-service-2 {
    padding-bottom: 0;
  }
}
.hero-service-2__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  min-height: 45rem;
  padding-bottom: 2.7rem;
  position: relative;
}
@media screen and (max-width: 1023px) {
  .hero-service-2__inner {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .hero-service-2__inner {
    min-height: 56rem;
  }
}
@media screen and (min-width: 1024px) {
  .hero-service-2__inner .hero-links {
    bottom: 2.7rem;
  }
}
.hero-service-2__inner .button {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .hero-service-2__inner .button {
    width: 100%;
    margin-top: 2rem;
  }
}
.hero-service-2__col {
  max-width: 72rem;
}
@media screen and (max-width: 1023px) {
  .hero-service-2__col {
    padding-bottom: 4rem;
  }
}
@media screen and (max-width: 1023px) {
  .hero-service-2 .bg {
    height: calc(100% - 7.6rem);
  }
}
@media screen and (max-width: 767px) {
  .hero-service-2 .bg {
    height: calc(100% - 13rem);
  }
}

@media screen and (max-width: 1023px) {
  .hero-links {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .hero-links a {
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  .hero-links {
    display: block;
  }
  .hero-links a {
    width: 100%;
  }
}
@media screen and (min-width: 1024px) {
  .hero-links {
    width: 30.8rem;
    position: absolute;
    right: 0;
  }
  .hero-links a {
    width: 100%;
  }
}
.hero-links .download-link {
  max-width: none;
  padding: 2.1rem 3.2rem 7.7rem;
  height: auto;
}
@media screen and (max-width: 1023px) {
  .hero-links .download-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 2rem;
  }
}
@media screen and (max-width: 767px) {
  .hero-links .download-link {
    padding: 1.5rem 14px;
  }
}
.hero-links .download-link::before, .hero-links .download-link .ext {
  bottom: 2.5rem;
}
.hero-links .download-link::before {
  left: 3.4rem;
}
@media screen and (max-width: 1023px) {
  .hero-links .download-link::before {
    display: none;
  }
}
.hero-links .download-link .ext {
  right: 3rem;
}
@media screen and (max-width: 1023px) {
  .hero-links .download-link .ext {
    position: static;
    margin-left: auto;
  }
}
.hero-links .link-block-blank {
  margin-top: 2.5rem;
}
@media screen and (max-width: 1023px) {
  .hero-links .link-block-blank {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin: 0;
    padding: 2rem;
  }
  .hero-links .link-block-blank::after {
    position: static;
    margin-left: auto;
  }
}
@media screen and (max-width: 767px) {
  .hero-links .link-block-blank {
    padding: 2.1rem 14px;
  }
}

.link-block-blank {
  display: block;
  padding: 1.7rem 7rem 1.7rem 3.2rem;
  position: relative;
}
@media screen and (min-width: 1200px) {
  .link-block-blank:hover {
    background-color: var(--color-accent-main);
  }
}
.link-block-blank::after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  position: absolute;
  top: 2.6rem;
  right: 2.9rem;
  background: url("../img/icons/arrow-blank.svg") no-repeat 50% 50%/contain;
}

.services-nav {
  padding: 2.5rem 0 0.3rem;
}
@media screen and (max-width: 1023px) {
  .services-nav {
    padding: 0 0 0.5rem;
  }
}
@media screen and (max-width: 1023px) {
  .services-nav .list {
    display: block;
  }
}
@media screen and (max-width: 1023px) {
  .services-nav li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
}
@media screen and (min-width: 1024px) {
  .services-nav li {
    margin-bottom: 2.4rem;
    margin-right: 2.4rem;
    padding-right: 2.4rem;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
  }
  .services-nav li:last-child {
    margin-right: 0;
    padding-right: 0;
  }
}
.services-nav li:last-child {
  border: none;
}
.services-nav a {
  display: block;
  padding: 0.4rem 0;
}
@media screen and (max-width: 1023px) {
  .services-nav a {
    padding: 1.5rem 0;
    padding-right: 4rem;
    position: relative;
  }
  .services-nav a::after {
    content: "";
    display: block;
    width: 8px;
    height: 14px;
    position: absolute;
    z-index: 0;
    right: 2rem;
    top: 50%;
    margin-top: -7px;
    background: url("../img/icons/chevron-right.svg") no-repeat 50% 50%/contain;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
}
@media screen and (max-width: 767px) {
  .services-nav a {
    padding: 1rem 0;
    padding-right: 2rem;
  }
  .services-nav a::after {
    right: 0;
  }
}
@media screen and (min-width: 1200px) {
  .services-nav a:hover {
    color: var(--color-accent-main);
  }
}

.section-border {
  padding-bottom: 7rem;
  border-bottom: 1px solid var(--border-color);
}
@media screen and (max-width: 767px) {
  .section-border {
    padding-bottom: 3rem;
  }
}

.service-about {
  margin: 6.7rem 0 7.3rem;
}
@media screen and (max-width: 767px) {
  .service-about {
    margin: 4.7rem 0 5rem;
  }
}
.service-about .styled-list li {
  margin-bottom: 0.7em;
}
@media screen and (max-width: 1023px) {
  .service-about .text {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .service-about .text {
    margin-top: 1.7rem;
  }
  .service-about .text p + ul {
    margin-top: -0.7em;
  }
}

.sevice-advantages-title {
  /*max-width: 67.4rem;*/
  max-width: 90rem;
}
@media screen and (max-width: 767px) {
  .sevice-advantages .advantage .ic {
    margin-bottom: 2rem;
  }
}

.clouds {
  padding: 8rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .clouds {
    padding: 5rem 0 2rem;
  }
}
.clouds .news-thumb {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.1);
}
@media screen and (max-width: 1023px) {
  .clouds .news-thumb {
    margin-bottom: 2.3rem;
  }
}
@media screen and (min-width: 1200px) {
  .clouds .news-thumb .news-thumb__body {
    -webkit-transition: all 0.2s;
    -o-transition: all 0.2s;
    transition: all 0.2s;
  }
  .clouds .news-thumb:hover {
    background-color: transparent;
  }
  .clouds .news-thumb:hover .news-thumb__body {
    background-color: var(--color-white);
    color: var(--color-title);
  }
}
.clouds .news-thumb .circle-arrow-chevron {
  width: 4.6rem !important;
  padding: 0 !important;
}
.clouds .news-thumb .circle-arrow-chevron::before {
  margin: 0 !important;
}

.we {
  padding: 6rem 0 7rem;
}
@media screen and (max-width: 767px) {
  .we {
    padding: 5rem 0 4rem;
  }
}
@media screen and (max-width: 1023px) {
  .we .accordion {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 767px) {
  .we .accordion {
    margin-top: 3rem;
  }
}

.team-section {
  margin: 10rem 0 12rem;
}
@media screen and (max-width: 1023px) {
  .team-section {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .team-section {
    margin: 6rem 0 5rem;
  }
}

.team-slider {
  padding-top: 8rem;
}
@media screen and (max-width: 1023px) {
  .team-slider {
    overflow: visible;
  }
}
@media screen and (max-width: 767px) {
  .team-slider {
    padding-top: 7rem;
  }
}
@media screen and (max-width: 1023px) {
  .team-slider .swiper-slide {
    max-width: 30rem;
  }
}
@media screen and (max-width: 767px) {
  .team-slider .swiper-slide {
    max-width: 18.6rem;
  }
}
.team-slider .member__img {
  margin-bottom: 3rem;
}
.team-slider .member__name, .team-slider .member__pos {
  max-width: 28rem;
}

.indicators {
  margin: 11rem 0 10rem;
  padding: 7rem 0 8rem;
}
@media screen and (max-width: 767px) {
  .indicators {
    padding: 4rem 0;
    margin: 5.5rem 0;
  }
}
.indicators .column {
  padding-top: 4rem;
  border-top-width: 3px;
  border-top-style: solid;
}
@media screen and (max-width: 767px) {
  .indicators .column {
    margin-top: 3.5rem;
    padding-top: 2.2rem;
  }
}
.indicators .column:nth-child(1) {
  border-top-color: var(--color-accent-add);
}
.indicators .column:nth-child(2) {
  border-top-color: var(--color-accent-main);
}

.accordion-section {
  margin: 10rem 0;
}
@media screen and (max-width: 767px) {
  .accordion-section {
    margin: 5rem 0;
  }
}

@media screen and (min-width: 1024px) {
  .column-text-width {
    max-width: 60rem;
  }
}

.tech-banner {
  position: relative;
  z-index: 1;
  padding: 3.6rem 0 4.2rem;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .tech-banner {
    background-color: var(--bg-sections);
    padding: 0 0 2rem;
  }
}
@media screen and (max-width: 767px) {
  .tech-banner .bg {
    position: static;
    height: 75vw;
  }
}
.tech-banner__col {
  max-width: 48rem;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .tech-banner__col {
    max-width: 100%;
    padding-top: 1rem;
  }
}
.tech-banner .border-list {
  border: none;
}
.tech-banner .border-list li {
  border-bottom-color: rgba(226, 229, 235, 0.5);
}
@media screen and (max-width: 767px) {
  .tech-banner .border-list li {
    border-bottom-color: rgba(255, 255, 255, 0.1);
  }
  .tech-banner .border-list li:not(:last-child) {
    padding-bottom: 1.8rem;
  }
}
.tech-banner .title {
  font-size: 8.7rem;
  line-height: 1;
  margin-bottom: -0.06em;
}
@media screen and (max-width: 767px) {
  .tech-banner .title {
    font-size: 5rem;
    margin-bottom: -0.08em;
  }
}

.section {
  margin: 10rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .section {
    margin: 6rem 0 5rem;
  }
}

.partners-services__title {
  max-width: 90rem;
}
@media screen and (max-width: 1023px) {
  .partners-services .partners-service {
    margin-bottom: 2rem;
  }
}

.partners-service {
  padding: 5rem 4.8rem;
}
@media screen and (max-width: 767px) {
  .partners-service {
    padding: 1.8rem 16px 2.4rem;
  }
}
.partners-service__logo {
  background-color: var(--color-white);
  width: 19.6rem;
  height: 11.3rem;
  padding: 4rem;
  margin-bottom: 3.8rem;
}
@media screen and (max-width: 767px) {
  .partners-service__logo {
    width: 14.9rem;
    height: 9rem;
    margin-bottom: 2rem;
    padding: 3rem;
  }
}

.grid-4 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media screen and (min-width: 768px) {
  .grid-4 {
    gap: 20px;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) {
  .grid-4 {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .grid-4 {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (min-width: 1600px) {
  .grid-4 {
    gap: 40px;
  }
}

.section-docs .download-link {
  max-width: 100%;
}

/* -------------------------------------
 * sectors
 * ------------------------------------- */
.sectors {
  margin: 8rem 0 9rem;
}
@media screen and (max-width: 767px) {
  .sectors {
    margin: 4rem 0 6rem;
  }
}
.sectors__title {
  max-width: 76rem;
}
.sectors__grid {
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .sectors__grid {
    margin-top: 5rem;
  }
}
@media screen and (min-width: 1024px) {
  .sectors__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 1023px) {
  .sectors__grid .sector-thumb:not(:last-child) {
    border-bottom: none;
  }
}
@media screen and (min-width: 1024px) {
  .sectors__grid .sector-thumb:not(:nth-child(3n+1)) {
    border-left: none;
  }
  .sectors__grid .sector-thumb:nth-child(3) {
    width: calc(100% + 1px);
    margin-left: -1px;
    border-left: 1px solid var(--border-color);
  }
  .sectors__grid .sector-thumb:nth-child(3) {
    border-bottom: none;
  }
  .sectors__grid .sector-thumb:nth-child(n+7) {
    border-top: none;
  }
}
.sectors-num {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding-bottom: 4.3rem;
  padding-right: 4rem;
}
@media screen and (max-width: 1199px) {
  .sectors-num {
    padding-right: 1rem;
  }
}
@media screen and (max-width: 1023px) {
  .sectors-num {
    margin-bottom: 8rem;
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  .sectors-num {
    margin-bottom: 4.8rem;
  }
}
.sectors-num .fz-160 {
  margin-bottom: 0.25em;
}
@media screen and (max-width: 767px) {
  .sectors-num .fz-160 {
    margin-bottom: 0.15em;
  }
}

.sector-thumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 31.6rem;
  padding: 5.6rem 4rem 4.3rem;
  border: 1px solid var(--border-color);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1023px) {
  .sector-thumb {
    height: auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding: 4rem 20px;
  }
}
@media screen and (max-width: 767px) {
  .sector-thumb {
    padding: 2.4rem 15px;
  }
}
@media screen and (min-width: 1200px) {
  .sector-thumb:hover {
    color: var(--color-white);
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
  .sector-thumb:hover .bg {
    opacity: 1;
    visibility: visible;
    -webkit-transition-delay: 0.1s;
         -o-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
}
.sector-thumb .ic {
  font-size: 1rem;
  width: 5.2em;
  min-width: 5.2em;
  height: 4.7em;
}
@media screen and (max-width: 1023px) {
  .sector-thumb .ic {
    margin-right: 2.2rem;
  }
}
@media screen and (max-width: 767px) {
  .sector-thumb .ic {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-size: 0.55rem;
  }
}
@media screen and (max-width: 1023px) {
  .sector-thumb .title {
    position: relative;
    top: 0.2em;
  }
  .sector-thumb .title br {
    display: none;
  }
}
.sector-thumb .bg {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.2s 0.2s linear;
  -o-transition: all 0.2s 0.2s linear;
  transition: all 0.2s 0.2s linear;
}

.hero-sector {
  position: relative;
  z-index: 1;
}
.hero-sector__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  max-width: 82rem;
  min-height: 44rem;
  padding-bottom: 2.8rem;
}
@media screen and (max-width: 767px) {
  .hero-sector__inner {
    padding-bottom: 2rem;
  }
  .hero-sector__inner .fz-54 {
    margin-bottom: 0.3em;
  }
}
.hero-sector__inner .button {
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .hero-sector__inner .button {
    width: 100%;
    margin-top: 3rem;
  }
}

.sector-about {
  margin: 8.8rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .sector-about {
    margin: 4.5rem 0 6.3rem;
  }
}
.sector-about__grid {
  margin-bottom: 11rem;
}
@media screen and (max-width: 767px) {
  .sector-about__grid {
    margin-bottom: 4.6rem;
  }
}
.sector-about .styled-list li {
  margin-bottom: 1.3em;
}
@media screen and (max-width: 767px) {
  .sector-about .styled-list li {
    margin-bottom: 1.1em;
  }
}

.sector-solutions {
  margin: 12rem 0 10rem;
  padding: 8rem 0 8.9rem;
}
@media screen and (max-width: 767px) {
  .sector-solutions {
    margin: 6.3rem 0 6.5rem;
    padding: 5.3rem 0 6.6rem;
  }
}
.sector-solutions__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4.7rem;
  margin-top: 4rem;
}
@media screen and (max-width: 767px) {
  .sector-solutions__grid {
    margin-top: 2.8rem;
  }
}
@media screen and (min-width: 1024px) {
  .sector-solutions__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
}
@media screen and (min-width: 1200px) {
  .sector-solutions__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (min-width: 1600px) {
  .sector-solutions__grid {
    gap: 40px;
  }
}
.sector-solutions .list {
  margin-top: 2.2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
@media screen and (max-width: 767px) {
  .sector-solutions .list {
    margin-top: 1.1rem;
  }
}
.sector-solutions .list li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.sector-solutions .list a {
  display: block;
  padding: 1em 10px 1em 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .sector-solutions .list a {
    padding-top: 0.8em;
    padding-bottom: 0.8em;
  }
}
.sector-solutions .list a::after {
  content: "";
  display: block;
  width: 8px;
  height: 14px;
  position: absolute;
  z-index: 0;
  right: 0;
  top: 50%;
  margin-top: -7px;
  background: url("../img/icons/chevron-right-accent.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (min-width: 1200px) {
  .sector-solutions .list a:hover {
    color: var(--color-accent-main);
  }
  .sector-solutions .list a:hover::after {
    -webkit-filter: none;
            filter: none;
  }
}

.sector-partners {
  margin: 8rem 0 5.5rem;
}
@media screen and (max-width: 1023px) {
  .sector-partners {
    overflow: hidden;
  }
}
@media screen and (max-width: 767px) {
  .sector-partners {
    margin: 5rem 0 4.7rem;
  }
}
@media screen and (max-width: 1023px) {
  .sector-partners-slider {
    overflow: visible;
  }
}
@media screen and (max-width: 1023px) {
  .sector-partners-slider .swiper-slide {
    max-width: 35rem;
  }
}
@media screen and (max-width: 767px) {
  .sector-partners-slider .swiper-slide {
    max-width: 15rem;
  }
}

.partner-logo {
  height: 20rem;
}
.partner-logo img {
  max-width: 19.4rem;
  max-height: 9.3rem;
}
@media screen and (max-width: 767px) {
  .partner-logo {
    height: 10.8rem;
  }
  .partner-logo img {
    max-width: 8.3rem;
    max-height: 4.8rem;
  }
}

.sector-advantages {
  margin: 5.5rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .sector-advantages {
    margin: 4.7rem 0 5rem;
  }
}

.advantage {
  padding: 4.5rem 4.8rem;
}
@media screen and (max-width: 1199px) {
  .advantage {
    padding: 4rem 2rem;
  }
}
@media screen and (max-width: 1023px) {
  .advantage {
    margin-bottom: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .advantage {
    padding: 2.1rem 16px;
  }
}
.advantage .ic {
  font-size: 1rem;
  width: 4.2em;
  height: 4.2em;
  margin-bottom: 2.3rem;
}
.advantage .ic--margin {
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .advantage .ic {
    font-size: 0.7145rem;
    margin-bottom: 1.2rem;
  }
}
.advantage .mb-1 {
  margin-bottom: 0.5em;
}

/* -------------------------------------
 * news
 * ------------------------------------- */
.news {
  margin: 4.3rem 0 9.3rem;
}
@media screen and (max-width: 767px) {
  .news {
    margin: 1.8rem 0 5rem;
  }
}
.news .select {
  max-width: 13.8rem;
}
@media screen and (max-width: 767px) {
  .news .select {
    max-width: 11.7rem;
  }
}
.news__grid {
  margin-top: 3.5rem;
  row-gap: 6.5rem;
}
@media screen and (max-width: 1023px) {
  .news__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media screen and (max-width: 767px) {
  .news__grid {
    margin-top: 1.8rem;
    grid-template-columns: 1fr;
  }
}
@media screen and (min-width: 768px) {
  .news__grid .news-thumb--big {
    grid-column-end: span 2;
  }
}
@media screen and (max-width: 1023px) and (min-width: 768px) {
  .news__grid .cta-tg {
    grid-column-end: span 2;
  }
}

.news-thumb {
  border: 1px solid var(--border-color);
  background-color: var(--color-white);
  position: relative;
}
@media screen and (max-width: 1023px) {
  .news-thumb--big {
    padding-bottom: 15rem;
  }
}
@media screen and (max-width: 767px) {
  .news-thumb--big {
    padding-bottom: 20rem;
  }
}
.news-thumb--big .news-thumb__img {
  height: 54.4rem;
}
@media screen and (max-width: 1023px) {
  .news-thumb--big .news-thumb__img {
    height: 40rem;
  }
}
@media screen and (max-width: 767px) {
  .news-thumb--big .news-thumb__img {
    height: 27.1rem;
  }
}
.news-thumb--big .news-thumb__body {
  height: auto;
  min-height: 24.7rem;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background: -o-linear-gradient(bottom, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)), -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.4) -8.95%, rgba(255, 255, 255, 0.1) 114%);
  background: linear-gradient(0deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)), linear-gradient(111.49deg, rgba(255, 255, 255, 0.4) -8.95%, rgba(255, 255, 255, 0.1) 114%);
  -webkit-backdrop-filter: blur(50px);
          backdrop-filter: blur(50px);
}
@media screen and (min-width: 768px) {
  .news-thumb--big .news-thumb__body {
    padding-right: 13%;
  }
}
@media screen and (min-width: 1200px) {
  .news-thumb {
    -webkit-transition: background-color 0.2s;
    -o-transition: background-color 0.2s;
    transition: background-color 0.2s;
  }
  .news-thumb:hover {
    background-color: var(--bg);
  }
  .news-thumb:hover .circle-arrow-chevron {
    width: auto;
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--color-white);
    border-radius: 100px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    padding-left: 2.1rem;
    padding-right: 2.1rem;
  }
  .news-thumb:hover .circle-arrow-chevron::before {
    margin-left: 2rem;
  }
}
.news-thumb__img {
  height: 22rem;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .news-thumb__img {
    height: 16rem;
  }
}
.news-thumb__img a {
  display: block;
  height: 100%;
}
.news-thumb__tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  position: absolute;
  top: 2.9rem;
  left: 4.8rem;
}
.news-thumb__tags > * {
  margin: 0 1rem 1rem 0;
}
@media screen and (max-width: 767px) {
  .news-thumb__tags {
    top: 1.3rem;
    left: 1.3rem;
  }
}
.news-thumb__body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding: 3.4rem 4.8rem;
  height: calc(100% - 22rem);
}
@media screen and (max-width: 767px) {
  .news-thumb__body {
    display: block;
    height: auto;
    padding: 2.3rem 15px 2.5rem;
  }
}
.news-thumb__title {
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  .news-thumb__title {
    font-size: 1.6rem;
    line-height: 1.45;
    font-family: var(--text-font);
  }
}
@media screen and (min-width: 1200px) {
  .news-thumb__title a:hover {
    color: var(--color-accent-main);
  }
}
.news-thumb__txt {
  margin-bottom: auto;
}
.news-thumb .circle-arrow-chevron {
  margin-top: 2.8rem;
  font-size: 0;
  color: var(--color-accent-main);
}
@media screen and (max-width: 767px) {
  .news-thumb .circle-arrow-chevron {
    margin-top: 2rem;
  }
}

.cta-tg {
  display: block;
  padding: 5rem 4.8rem 18rem 4.8rem;
  position: relative;
  min-height: 44rem;
}
@media screen and (max-width: 767px) {
  .cta-tg {
    padding: 2.4rem 16px 9rem;
    min-height: 20.4rem;
  }
}
.cta-tg::before, .cta-tg::after {
  content: "";
  display: block;
  position: absolute;
  background: no-repeat 50% 50%/contain;
}
.cta-tg::before {
  font-size: 1rem;
  width: 9.8em;
  height: 9.3em;
  left: 5.1rem;
  bottom: 6.5rem;
  background-image: url("../img/news/tg.svg");
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
  -webkit-transform-origin: 0 100%;
      -ms-transform-origin: 0 100%;
          transform-origin: 0 100%;
}
@media screen and (max-width: 767px) {
  .cta-tg::before {
    width: 5.2rem;
    height: 4.9rem;
    left: 16px;
    bottom: 3.2rem;
  }
}
.cta-tg::after {
  font-size: 1rem;
  width: 100%;
  height: 21.9em;
  left: 0;
  bottom: 11.3rem;
  background-image: url("../img/news/curve.svg");
}
@media screen and (max-width: 767px) {
  .cta-tg::after {
    width: 22.8rem;
    height: 9.2rem;
    left: auto;
    right: 0;
    bottom: 2.4rem;
  }
}
.cta-tg .fz-36 {
  line-height: 1;
}

@media screen and (min-width: 1200px) {
  .cta-tg:hover, .cta-email:hover {
    color: var(--color-white);
  }
  .cta-tg:hover::before, .cta-email:hover::before {
    -webkit-transform: scale(1.2);
        -ms-transform: scale(1.2);
            transform: scale(1.2);
  }
}
@media screen and (max-width: 767px) {
  .cta-tg .fz-36, .cta-email .fz-36 {
    font-size: 2.1rem;
    line-height: 1.25;
  }
}

@media screen and (max-width: 767px) {
  .hero-article .hero-title {
    min-height: 20rem;
    padding-bottom: 1rem;
  }
}

.article {
  margin: 6.1rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .article {
    margin: 0 0 5.2rem;
  }
}
.article-head {
  margin-bottom: 8.7rem;
}
@media screen and (max-width: 1023px) {
  .article-head {
    margin-bottom: 6.1rem;
  }
}
@media screen and (max-width: 767px) {
  .article-head {
    margin-bottom: 3.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .article-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
}
.article-head__img {
  height: 52.5rem;
  position: relative;
}
@media screen and (max-width: 1023px) {
  .article-head__img {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .article-head__img {
    height: 64vw;
    margin-bottom: 15px;
  }
}
@media screen and (min-width: 1024px) {
  .article-head__img {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
    max-width: 100%;
  }
}
.article-head__img .label-date {
  position: absolute;
  left: 0;
  top: calc(100% + 8.7rem);
}
@media screen and (max-width: 1023px) {
  .article-head__img .label-date {
    top: 2.7rem;
    left: 20px;
  }
}
@media screen and (max-width: 767px) {
  .article-head__img .label-date {
    left: 14px;
  }
}
.article-side {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .article-side {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 35rem;
            flex: 0 0 35rem;
    max-width: 35rem;
    margin-left: 20px;
  }
}
@media screen and (min-width: 1600px) {
  .article-side {
    margin-left: 40px;
  }
}
.article-side .cta-tg {
  min-height: auto;
  padding-top: 3.5rem;
  padding-left: 3.5rem;
  padding-bottom: 18rem;
}
@media screen and (max-width: 767px) {
  .article-side .cta-tg {
    padding: 2.4rem 16px 10rem;
  }
}
.article-side .cta-tg::before {
  font-size: 0.64rem;
  left: 3.5rem;
  bottom: 3.7rem;
}
@media screen and (max-width: 767px) {
  .article-side .cta-tg::before {
    left: 16px;
    bottom: 3.2rem;
  }
}
.article-side .cta-tg::after {
  font-size: 0.8rem;
  bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .article-side .cta-tg::after {
    bottom: 2.5rem;
  }
}
.article-side .side-share {
  margin-top: auto;
}
@media screen and (max-width: 1023px) {
  .article-side .side-share {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .article-side .side-share {
    margin-bottom: 12px;
  }
}
@media screen and (min-width: 1024px) {
  .article-side .side-share {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.article .soc li {
  margin-right: 10px;
}
@media screen and (min-width: 1024px) {
  .article-body {
    max-width: 86.6rem;
    margin: 0 auto;
  }
}
.article-share {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .article-share {
    margin-top: 2rem;
    padding-right: 2.2rem;
  }
}
.article-share .subtitle {
  margin-right: 2rem;
}
@media screen and (max-width: 767px) {
  .article-share .subtitle {
    margin-right: auto;
  }
}

.side-share {
  padding: 2.5rem 4rem 2.9rem;
}
@media screen and (max-width: 1023px) {
  .side-share {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 3.5rem;
  }
  .side-share .subtitle {
    margin-right: auto;
  }
}
@media screen and (max-width: 767px) {
  .side-share {
    padding: 2.3rem 7px 2.3rem 16px;
  }
}
@media screen and (min-width: 1024px) {
  .side-share .soc {
    margin-top: 1rem;
  }
}

.soc--white a:not(:hover) {
  background-color: var(--color-white);
  border-color: #EFEFEF;
}
@media screen and (min-width: 1200px) {
  .soc--white a:hover img {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
}

.content h2:first-child, .content h3:first-child {
  margin-top: 0 !important;
}
.content h2 {
  margin-top: 1em;
  margin-bottom: 0.5em;
}
@media screen and (max-width: 767px) {
  .content h2 {
    margin-bottom: 0.5em;
  }
}
.content h3 {
  margin-top: 1.2em;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .content h3 {
    margin-bottom: 0.5em;
  }
}
.content ul, .content ol {
  margin-bottom: 3.5em;
}
@media screen and (max-width: 767px) {
  .content ul, .content ol {
    margin-bottom: 1.7em;
  }
}
.content p, .content li {
  font-weight: 500;
}
.content p {
  margin-bottom: 1.4em;
}
.content li {
  margin-bottom: 1.1em;
}
@media screen and (max-width: 767px) {
  .content li {
    margin-bottom: 0.9em;
  }
}
.content h2 + img, .content h2 + iframe, .content h3 + img, .content h3 + iframe, .content ul + img, .content ul + iframe, .content ol + img, .content ol + iframe, .content p + img, .content p + iframe {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .content h2 + img, .content h2 + iframe, .content h3 + img, .content h3 + iframe, .content ul + img, .content ul + iframe, .content ol + img, .content ol + iframe, .content p + img, .content p + iframe {
    margin-top: 4rem;
  }
}
.content h2 + blockquote, .content h3 + blockquote, .content ul + blockquote, .content ol + blockquote, .content p + blockquote {
  margin-top: 7rem;
}
@media screen and (max-width: 767px) {
  .content h2 + blockquote, .content h3 + blockquote, .content ul + blockquote, .content ol + blockquote, .content p + blockquote {
    margin-top: 3.4rem;
  }
}
.content iframe {
  display: block;
  width: 100%;
  height: 49rem;
  margin-bottom: 5rem;
}
@media screen and (max-width: 767px) {
  .content iframe {
    height: 58.6vw;
    margin-bottom: 4rem;
  }
}
.content img {
  display: block;
  max-width: 100%;
  height: auto;
  margin-bottom: 5rem;
}
.content blockquote {
  display: block;
  margin-bottom: 4rem;
  padding: 3.8rem 4.9rem 5.7rem;
  position: relative;
  font-size: var(--title-fz-4);
  line-height: var(--title-lh-4);
  font-weight: 500;
  background-color: var(--bg-sections);
  color: var(--color-white);
}
@media screen and (max-width: 1023px) {
  .content blockquote {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .content blockquote {
    margin-bottom: 4.4rem;
    padding: 3rem 1.7rem 3.3rem;
  }
}
.content blockquote::before {
  content: "";
  display: block;
  width: 7.7rem;
  height: 5.8rem;
  margin-bottom: 1.8rem;
  background: url("../img/icons/quotes-green.svg") no-repeat 50% 50%/contain;
}
@media screen and (max-width: 767px) {
  .content blockquote::before {
    width: 5.6rem;
    height: 4.2rem;
  }
}
.content blockquote::after {
  content: "";
  display: block;
  width: 6.5rem;
  height: 6.5rem;
  position: absolute;
  z-index: 0;
  left: 0;
  bottom: -4.8rem;
  background: var(--bg-sections);
  -webkit-clip-path: polygon(0 0, 100% 0, 50% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 0, 50% 50%, 0 100%);
}
.content blockquote + p {
  margin-bottom: 6.3rem;
  padding-left: 4.9rem;
}
@media screen and (max-width: 767px) {
  .content blockquote + p {
    margin-bottom: 5.4rem;
    padding-left: 1.5rem;
  }
}
.content hr {
  display: block;
  height: 1px;
  margin: 4rem 0 0rem;
  border: none !important;
  background-color: #E2E5EB;
}
@media screen and (max-width: 767px) {
  .content hr {
    margin: 3rem 0;
  }
}
.content .img-slider {
  margin-top: 5rem;
}
@media screen and (max-width: 767px) {
  .content .img-slider {
    margin-top: 3.5rem;
  }
}
.content .border-block {
  padding: 5.9rem 5.6rem;
  border: 3px solid var(--color-accent-add);
  font-size: 2.2rem;
  line-height: var(--title-lh-4);
}
@media screen and (max-width: 1023px) {
  .content .border-block {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .content .border-block {
    padding: 4rem 16px;
  }
}
.content .border-block *:last-child {
  margin-bottom: 0;
}

.recommended {
  margin-top: 10rem;
  padding: 7.1rem 0 7.6rem;
  background-color: #E4E3DE;
}
@media screen and (max-width: 767px) {
  .recommended {
    margin-top: 6rem;
    padding: 4.6rem 0 4rem;
  }
}
.recommended-news .swiper-slide, .recommended-events .swiper-slide {
  height: auto;
}
.recommended-news .news-thumb, .recommended-events .news-thumb {
  height: 100%;
}
.recommended .slider-arrow:not(:hover) {
  background-color: transparent;
  border-color: #EFEFEF;
}

/* -------------------------------------
 * smi
 * ------------------------------------- */
.smi-row {
  margin-top: 3.6rem;
}
@media screen and (max-width: 767px) {
  .smi-row {
    margin-top: 2.2rem;
  }
}
@media screen and (min-width: 1200px) {
  .smi-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}
.smi-row .side {
  margin: 0;
}
@media screen and (max-width: 1199px) {
  .smi-row .side {
    max-width: 100%;
  }
}
@media screen and (min-width: 1200px) {
  .smi-row .side {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 35rem;
            flex: 0 0 35rem;
    max-width: 35rem;
    margin: 0 0 0 3.4rem;
  }
}
@media screen and (max-width: 1199px) {
  .smi-list {
    margin-top: 3.6rem;
  }
}
@media screen and (max-width: 767px) {
  .smi-list {
    margin-top: 2.4rem;
  }
}
@media screen and (min-width: 1200px) {
  .smi-list {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
    max-width: 100%;
  }
}
.smi-list .smi-thumb:last-child {
  margin-bottom: 0;
}
.smi-thumb {
  margin-bottom: 3.4rem;
}
@media screen and (max-width: 767px) {
  .smi-thumb {
    margin-bottom: 2.6rem;
  }
}
@media screen and (min-width: 768px) {
  .smi-thumb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
.smi-thumb__img {
  background-color: var(--bg);
}
@media screen and (min-width: 768px) {
  .smi-thumb__img {
    height: auto;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 34.9rem;
            flex: 0 0 34.9rem;
  }
}
.smi-thumb__img .flex-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  .smi-thumb__body {
    padding: 4rem 8.5rem 4rem 4rem;
  }
}
@media screen and (min-width: 1600px) {
  .smi-thumb__body {
    padding-right: 11.5rem;
  }
}
.smi-thumb .circle-arrow-blank {
  margin-top: 2.3rem;
}
@media screen and (max-width: 767px) {
  .smi-thumb .circle-arrow-blank {
    margin-top: 2rem;
  }
}
.smi-thumb .quotes {
  position: absolute;
  top: 3rem;
  right: 3.5rem;
  width: 3.4rem;
  height: 2.5rem;
}
@media screen and (max-width: 767px) {
  .smi-thumb .quotes {
    width: 2.6rem;
    height: 1.9rem;
    top: 2.2rem;
    right: 2.2rem;
  }
}

.cta-email {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 3.9rem 4.3rem 5.3rem;
}
@media screen and (max-width: 767px) {
  .cta-email {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    padding: 2.85rem 3rem;
  }
}
.cta-email .fz-36 {
  line-height: 1.2;
}
.cta-email::before {
  content: "";
  display: block;
  font-size: 1rem;
  width: 6em;
  min-width: 6em;
  height: 4.8em;
  margin-top: 5rem;
  background: url("../img/smi/email.svg") no-repeat 50% 50%/contain;
  -webkit-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
  -webkit-transform-origin: 0 50%;
      -ms-transform-origin: 0 50%;
          transform-origin: 0 50%;
}
@media screen and (max-width: 767px) {
  .cta-email::before {
    margin: 0 2.5rem 0 0;
  }
}
@media screen and (min-width: 768px) {
  .cta-email::before {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}

/* -------------------------------------
 * events
 * ------------------------------------- */
.events {
  margin: 5rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .events {
    margin: 2rem 0 4rem;
  }
}
.events-filters {
  margin-bottom: 5rem;
}
.events-filters .select-year {
  min-width: 13.8rem;
}
.events-filters .select-format {
  width: 29%;
}
.events-filters .select-type {
  width: 33%;
}
.events-filters .select-city {
  width: 29%;
}
.events-filters .select:not(.select-year) {
  margin-left: -1px;
}
.events-filters .select:not(.select-year) .select__trigger, .events-filters .select:not(.select-year) .select__option {
  padding-left: 3rem;
}
@media screen and (max-width: 1023px) {
  .events .filters-title {
    margin-bottom: 3rem;
  }
}
.events__grid {
  margin-bottom: 8rem;
}
@media screen and (max-width: 1023px) {
  .events__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-bottom: 4rem;
  }
}
.events__grid.no-margin {
  margin: 0;
}
@media screen and (min-width: 768px) {
  .events-thumb__img {
    height: 33.8rem;
  }
  .events-thumb__body {
    height: calc(100% - 33.8rem);
  }
}

.cta-events {
  margin-top: 8rem;
}
@media screen and (max-width: 1023px) {
  .cta-events {
    margin-top: 5rem;
  }
}
.cta-events::before {
  content: "";
  display: block;
}
.cta-events__col {
  padding-top: 4.8rem;
  border-top: 3px solid var(--color-accent-add);
}
.cta-events__links {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 2rem;
}
.cta-events__links a {
  display: inline-block;
  margin-right: 4rem;
}
@media screen and (max-width: 1023px) {
  .cta-events__links a {
    margin-right: 3rem;
  }
}
@media screen and (max-width: 767px) {
  .cta-events__links a {
    font-size: 2.2rem;
  }
}
.cta-events__links a:last-child {
  margin-right: 0;
}

.event-side .button {
  width: 100%;
}
@media screen and (max-width: 1023px) {
  .event-side .button {
    margin-bottom: 2.5rem;
  }
}
.event-side .side-share {
  -webkit-box-ordinal-group: inherit;
      -ms-flex-order: inherit;
          order: inherit;
}
.event-data {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 22.9rem;
  margin-bottom: auto;
}
@media screen and (max-width: 1023px) {
  .event-data {
    margin-bottom: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  .event-data {
    height: 13.8rem;
  }
}
.event-data .column {
  width: 50%;
  height: 100%;
  padding: 2.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .event-data .column {
    padding: 3rem 16px 2rem;
  }
}
.event-data .ic {
  width: 3.6rem;
  height: 3.2rem;
}
@media screen and (max-width: 767px) {
  .event-data .ic {
    width: 3.3rem;
    height: 3rem;
  }
}
.event-info {
  display: grid;
  gap: 2rem;
}
@media screen and (max-width: 1023px) {
  .event-info {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 767px) {
  .event-info {
    gap: 1.5rem;
    margin-top: 1rem;
  }
}
@media screen and (min-width: 1024px) {
  .event-info {
    position: absolute;
    left: 0;
    top: calc(100% + 8.7rem);
  }
}

/* -------------------------------------
 * cases
 * ------------------------------------- */
@media screen and (max-width: 767px) {
  .cases-info {
    margin-bottom: 2.4rem;
  }
}
@media screen and (min-width: 1024px) {
  .cases-info {
    margin: 6.3rem 0;
  }
  .cases-info .team-info__subtitle {
    margin-top: 1.4rem;
  }
  .cases-info .fz-60 {
    margin-bottom: 1.6rem;
  }
}
.cases-info .green-block {
  margin-top: 6rem;
}
@media screen and (max-width: 767px) {
  .cases-info .green-block {
    margin-top: 2.8rem;
  }
}

.cases {
  margin: 4rem 0 9rem;
}
@media screen and (max-width: 767px) {
  .cases {
    margin: 2.4rem 0 4.8rem;
  }
}
.cases-filters .select:nth-child(1) {
  width: 35rem;
}
.cases-filters .select:nth-child(2) {
  width: 39rem;
  margin-left: -1px;
}
.cases-filters .select__trigger, .cases-filters .select__option {
  padding-left: 4.9rem;
}
.cases-banners-wrap {
  position: relative;
  margin-top: 2.9rem;
}
@media screen and (max-width: 767px) {
  .cases-banners-wrap {
    margin-top: 1.9rem;
  }
}
@media screen and (max-width: 1023px) {
  .cases-banners-wrap .slider-nav .button {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .cases-banners-wrap .slider-nav {
    position: absolute;
    z-index: 1;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 0 4.9rem 3.8rem;
  }
  .cases-banners-wrap .slider-nav .button {
    position: absolute;
    left: 4.9rem;
  }
  .cases-banners-wrap .slider-nav .slider-arrows {
    right: 4.9rem;
  }
}
.cases-banner {
  height: 50rem;
  position: relative;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .cases-banner {
    height: auto;
    padding-bottom: 4.5rem;
  }
}
@media screen and (max-width: 767px) {
  .cases-banner .bg {
    position: static;
    height: 23.7rem;
  }
}
.cases-banner__block {
  max-width: 74rem;
  padding: 2.5rem 4.9rem 5rem;
  background: -o-linear-gradient(bottom, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), -o-linear-gradient(338.51deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1)), linear-gradient(111.49deg, rgba(255, 255, 255, 0.08) -8.95%, rgba(255, 255, 255, 0.002) 114%);
  -webkit-backdrop-filter: blur(50px);
          backdrop-filter: blur(50px);
  color: var(--color-white);
}
@media screen and (max-width: 1023px) {
  .cases-banner__block {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    max-width: 100%;
    padding-right: 20rem;
  }
  .cases-banner__block .circle-arrow-chevron {
    position: absolute;
    bottom: 5rem;
    right: 4.9rem;
  }
}
@media screen and (max-width: 767px) {
  .cases-banner__block {
    padding: 1.6rem 9.8rem 3rem 15px;
  }
  .cases-banner__block .circle-arrow-chevron {
    right: 2.6rem;
    bottom: 3rem;
  }
}
.cases-banner__block .tag {
  border-color: var(--color-white);
  margin-bottom: 2rem;
  color: var(--color-white);
}
@media screen and (max-width: 767px) {
  .cases-banner__block .tag {
    margin-bottom: 1.4rem;
  }
}
.cases__grid {
  margin-top: 5.6rem;
}
@media screen and (max-width: 1023px) {
  .cases__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.3rem;
  }
}
@media screen and (max-width: 767px) {
  .cases__grid {
    margin-top: 3.1rem;
  }
}

.page-filters .flex {
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
}
.page-filters-search {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 0px;
          flex: 1 0 0;
  max-width: 100%;
  position: relative;
}
.page-filters-search .input {
  height: 6rem;
  padding: 1.7rem 18px 1.7rem 4.9rem;
  background-color: var(--bg);
  border: 1px solid var(--border-color);
  border-left: none;
  font-size: 1.6rem;
  font-weight: 500;
}
.page-filters-search .submit {
  width: 20px;
  height: 20px;
  position: absolute;
  right: 24px;
  top: 50%;
  margin-top: -10px;
}
.page-filters-search .submit::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/icons/search-accent.svg") no-repeat 50% 50%/contain;
  -webkit-filter: brightness(0);
          filter: brightness(0);
  -webkit-transition: -webkit-filter 0.2s;
  transition: -webkit-filter 0.2s;
  -o-transition: filter 0.2s;
  transition: filter 0.2s;
  transition: filter 0.2s, -webkit-filter 0.2s;
}
.page-filters-search .submit:hover::before {
  -webkit-filter: none;
          filter: none;
}

@media screen and (max-width: 767px) {
  .hero-case .hero-sector__inner {
    min-height: 39rem;
  }
}

.case {
  margin-top: 8.3rem;
}
@media screen and (max-width: 1023px) {
  .case {
    margin-top: 2.3rem;
  }
}
.case-grid {
  display: grid;
  gap: 20px;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  grid-template-columns: 1fr;
}
@media screen and (min-width: 1024px) {
  .case-grid {
    grid-template-columns: auto 70rem auto;
  }
}
@media screen and (min-width: 1200px) {
  .case-grid {
    grid-template-columns: auto 86.6rem auto;
  }
}
@media screen and (min-width: 1600px) {
  .case-grid {
    gap: 40px;
  }
}
.case .side-share {
  max-width: 100%;
}
@media screen and (min-width: 1024px) {
  .case .side-share {
    grid-column-start: 3;
  }
}
.case-data .event-info {
  position: static;
  grid-template-columns: 1fr;
}
@media screen and (max-width: 1023px) {
  .case-data {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .case-data .event-info {
    margin-top: 0;
    padding-right: 15px;
  }
}
@media screen and (min-width: 1024px) {
  .case-data {
    grid-row-start: 1;
    grid-column-start: 1;
  }
}
.case-logo {
  width: 19.3rem;
  height: 11rem;
  padding: 3rem;
  margin-bottom: 3.4rem;
}
@media screen and (max-width: 1023px) {
  .case-logo {
    margin: 0 0 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .case-logo {
    width: 14.9rem;
    height: 9rem;
    padding: 3rem 2.5rem;
  }
}
.case-category {
  width: 8.2rem;
  height: 7.6rem;
  margin-top: 4.4rem;
  padding: 2rem;
}
.case-category img {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.case-body {
  min-width: 0;
}
@media screen and (max-width: 767px) {
  .case-body {
    padding-top: 3rem;
    border-top: 1px solid #E2E5EB;
  }
}
@media screen and (min-width: 1024px) {
  .case-body {
    grid-row-start: 1;
    grid-column-start: 2;
  }
}
.case-body .content h2 {
  margin-top: 0.7em;
  margin-bottom: 0.4em;
}
.case-body .content h3 {
  margin-top: 0.8em;
}
@media screen and (max-width: 767px) {
  .case-body .content h3 {
    margin-top: 0.6em;
  }
}

.img-slider .img {
  height: 44.6rem;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .img-slider .img {
    height: 63.5vw;
  }
}

.letter {
  margin: 10rem 0;
}
@media screen and (max-width: 767px) {
  .letter {
    margin: 5rem 0;
  }
}
.letter-inner {
  position: relative;
  padding-top: 13.2rem;
}
@media screen and (max-width: 767px) {
  .letter-inner {
    padding-top: 2.2rem;
  }
}
.letter-inner .bg {
  height: 54rem;
}
@media screen and (max-width: 1023px) {
  .letter-inner .bg {
    left: -20px;
    width: calc(100% + 40px);
  }
}
@media screen and (max-width: 767px) {
  .letter-inner .bg {
    width: calc(100% + 28px);
    height: 48rem;
    left: -14px;
  }
}
@media screen and (min-width: 1024px) {
  .letter-grid::before {
    content: "";
    display: block;
    min-width: 16.3rem;
  }
}
.letter-body {
  max-width: 99.4rem;
  margin-left: auto;
  margin-right: auto;
  padding: 5rem 7.5rem;
  background-color: var(--color-white);
  -webkit-box-shadow: 0px 10px 45px 6px rgba(146, 155, 176, 0.1);
          box-shadow: 0px 10px 45px 6px rgba(146, 155, 176, 0.1);
  border-radius: 1px;
}
@media screen and (max-width: 767px) {
  .letter-body {
    padding: 2.9rem 16px;
  }
}
.letter-body .quotes {
  margin-bottom: 2.8rem;
}
@media screen and (max-width: 767px) {
  .letter-body .quotes {
    margin-bottom: 2rem;
  }
}
.letter-author {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 4rem;
  padding-top: 3.2rem;
  border-top: 1px solid #E2E5EB;
}
@media screen and (max-width: 767px) {
  .letter-author {
    display: block;
    margin-top: 2.6rem;
    padding-top: 2.6rem;
  }
}
.letter-author__img {
  width: 63px;
  min-width: 63px;
  height: 63px;
  margin-right: 28px;
  border-radius: 50%;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .letter-author__img {
    width: 58px;
    min-width: 58px;
    height: 58px;
    margin: 0 0 14px;
  }
}
.letter-img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 22.7rem;
  padding: 19px 16px 19px 17px;
  background-color: var(--color-accent-add);
  position: relative;
}
.letter-img::before {
  content: "";
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1rem;
  width: 7em;
  height: 7em;
  position: absolute;
  background: var(--color-accent-main) url("../img/icons/plus-2.svg") no-repeat 50% 50%/2.4rem;
  border-radius: 50%;
  -webkit-transition: all 0.2s;
  -o-transition: all 0.2s;
  transition: all 0.2s;
}
@media screen and (max-width: 1023px) {
  .letter-img {
    width: 100%;
    margin-top: 3.8rem;
    padding: 4rem 16px;
  }
  .letter-img::before {
    display: none;
  }
}
@media screen and (min-width: 1200px) {
  .letter-img:hover::before {
    background-color: var(--color-accent-add);
  }
}
.letter-img img {
  height: 27.4rem;
}

/* -------------------------------------
 * press-center
 * ------------------------------------- */
.press-center-news {
  margin: 9.2rem 0 7.8rem;
}
@media screen and (max-width: 767px) {
  .press-center-news {
    margin: 4.4rem 0 5.3rem;
  }
}
.press-center-events {
  margin: 7.8rem 0 8.6rem;
  padding: 7.5rem 0 7.9rem;
}
@media screen and (max-width: 767px) {
  .press-center-events {
    margin: 5.3rem 0;
    padding: 4.5rem 0 5.6rem;
  }
}
.press-center-events .events__grid {
  margin: 0;
}
.press-center-events .news-thumb {
  color: var(--color-title);
}

.banner-press-kit {
  margin: 9.5rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .banner-press-kit {
    margin: 3.5rem 0 5.4rem;
  }
}
.banner-press-kit .banner-inner {
  background-color: #382E2E;
  color: var(--color-white);
}
@media screen and (max-width: 1023px) {
  .banner-press-kit .banner-inner {
    min-height: 35rem;
  }
}
@media screen and (max-width: 767px) {
  .banner-press-kit .banner-inner {
    min-height: 24rem;
  }
}
.banner-press-kit .banner-bg {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.banner-press-kit .banner-bg .img--contain {
  -o-object-position: 100% 50%;
     object-position: 100% 50%;
}
@media screen and (max-width: 767px) {
  .banner-press-kit .banner-bg .img--contain {
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: 0% 50%;
       object-position: 0% 50%;
  }
}
.banner-press-kit__col {
  max-width: 48.5rem;
  padding-top: 1.5rem;
}
@media screen and (min-width: 1024px) {
  .banner-press-kit__col {
    padding-top: 3.1rem;
  }
}
.banner-press-kit__col .text {
  opacity: 0.4;
}
.banner-press-kit .circle-arrow-chevron {
  margin-top: auto;
  margin-bottom: 0.5rem;
}
@media screen and (min-width: 1024px) {
  .banner-press-kit .circle-arrow-chevron {
    margin-bottom: 2rem;
  }
}

/* -------------------------------------
 * press-kit
 * ------------------------------------- */
.kit {
  margin-top: 2.8rem;
  margin-bottom: 7rem;
}
@media screen and (max-width: 767px) {
  .kit {
    margin-top: 1.5rem;
    margin-bottom: 6rem;
  }
}
.kit .vacancy__row:last-child {
  padding-bottom: 0;
  border: none;
}
.kit .vacancy__title {
  margin-bottom: 1em;
}
.kit .vacancy__txt .fz-30 {
  margin-bottom: 0.6em;
}

.press-nums {
  margin: 7rem 0 8rem;
  padding: 10rem 0 14rem;
}
@media screen and (max-width: 767px) {
  .press-nums {
    margin: 6rem 0 5rem;
    padding: 5rem 0;
  }
}
.press-nums .vacancy__row {
  padding: 0;
  border: none;
}
@media screen and (max-width: 1023px) {
  .press-nums .vacancy__title {
    margin-bottom: 7rem;
  }
}
@media screen and (max-width: 767px) {
  .press-nums .vacancy__title {
    margin-bottom: 3rem;
  }
}
.press-nums-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8rem 4rem;
  padding-top: 1rem;
}
@media screen and (max-width: 1199px) {
  .press-nums-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .press-nums-grid {
    gap: 4rem 1.1rem;
  }
  .press-nums-grid .fz-16 {
    max-width: 90%;
  }
}
@media screen and (min-width: 1600px) {
  .press-nums-grid {
    gap: 9rem 6rem;
  }
}
.press-nums .num .title {
  margin-bottom: 0.2em;
  font-size: 8.7rem;
  line-height: 0.7;
}
@media screen and (max-width: 767px) {
  .press-nums .num .title {
    font-size: 4.6rem;
  }
}

.downloads {
  margin: 8.7rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .downloads {
    margin: 5rem 0;
  }
}
.downloads__title {
  margin-bottom: 3.4rem;
}
@media screen and (max-width: 767px) {
  .downloads__title {
    margin-bottom: 1.4rem;
  }
}
@media screen and (min-width: 768px) {
  .downloads-banner {
    min-height: 45rem;
    margin-bottom: 5.2rem;
    padding: 5rem 5rem 8rem;
    position: relative;
  }
}
@media screen and (max-width: 767px) {
  .downloads-banner .bg {
    display: none;
  }
}
.downloads-banner .download-link {
  margin-bottom: 4rem;
}
@media screen and (max-width: 767px) {
  .downloads-banner .download-link {
    max-width: 100%;
    margin-bottom: 1.9rem;
  }
}
.downloads-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: 5.2rem;
}
@media screen and (max-width: 1023px) {
  .downloads-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .downloads-grid {
    grid-template-columns: 1fr;
    gap: 1.9rem;
    margin-bottom: 1.9rem;
  }
}
@media screen and (min-width: 1600px) {
  .downloads-grid {
    gap: 40px;
  }
}

.member-contact {
  margin: 10rem 0 11rem;
}
@media screen and (max-width: 767px) {
  .member-contact {
    margin: 5rem 0;
  }
}
.member-contact__grid::before {
  content: "";
  display: block;
}
.member-contact__col {
  max-width: 62.8rem;
  border-left: 3px solid var(--color-accent-add);
  padding: 1.4rem 16rem 0.5rem 5rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .member-contact__col {
    padding: 0.2rem 14px 0.2rem 14px;
  }
}
.member-contact .title {
  margin-bottom: 1.6rem;
}
@media screen and (max-width: 767px) {
  .member-contact .title {
    margin-bottom: 2.4rem;
  }
}
.member-contact__txt {
  margin-bottom: 1.6rem;
}
.member-contact__links a {
  display: inline-block;
  margin-right: 1.5rem;
}
@media screen and (min-width: 1200px) {
  .member-contact__links a:hover {
    color: var(--color-accent-add);
  }
}
.member-contact .member__img {
  font-size: 0.35rem;
}
@media screen and (max-width: 767px) {
  .member-contact .member__img {
    font-size: 0.31rem;
  }
}
@media screen and (min-width: 768px) {
  .member-contact .member__img {
    position: absolute;
    right: 0;
    top: 5.8rem;
  }
}

.search-page {
  margin: 5.6rem 0 10rem;
}
@media screen and (max-width: 767px) {
  .search-page {
    margin: 0 0 6.6rem;
  }
}
.search-page__head {
  margin-bottom: 5.3rem;
  padding: 3.9rem 4.5rem;
}
@media screen and (max-width: 767px) {
  .search-page__head {
    margin-bottom: 2.3rem;
    padding: 3.4rem 14px;
  }
}
.search-page .page-row {
  margin: 0;
  padding: 0;
  border: none;
}
.search-page .pagination .nav-links {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.search-page .search-form__input .input {
  padding-bottom: 0;
}

.search-founded {
  margin-top: 2.8rem;
}
@media screen and (max-width: 767px) {
  .search-founded {
    margin-top: 1.6rem;
  }
}

.search-item {
  margin-bottom: 3.2rem;
  padding: 3.8rem 4.8rem;
  border: 1px solid var(--border-color);
}
@media screen and (max-width: 767px) {
  .search-item {
    margin-bottom: 2.1rem;
    padding: 2.8rem 16px;
  }
}
.search-item__title {
  margin-bottom: 0.6em;
}
@media screen and (max-width: 767px) {
  .search-item__title {
    font: 500 1.6rem/1.45 var(--text-font);
  }
}
.search-item__footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 2rem;
}

.highlighted {
  color: var(--color-accent-main);
}

.search-fitlers {
  background: var(--color-accent-add);
  color: var(--color-white);
  font-weight: 700;
}
.search-fitlers li:first-child .search-fitler {
  padding-top: 1.2em;
}
.search-fitlers li:last-child .search-fitler {
  padding-bottom: 1.2em;
}

.search-fitler {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 1em 2.8rem 1em 4.5rem;
  position: relative;
}
.search-fitler .quantity {
  min-width: 6rem;
  margin-left: auto;
}
.search-fitler::after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  position: absolute;
  z-index: 0;
  right: -4px;
  top: 50%;
  margin-top: -12px;
  background: var(--bg-sections);
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.1s;
  -o-transition: all 0.1s;
  transition: all 0.1s;
}
@media screen and (min-width: 1200px) {
  .search-fitler:hover {
    background-color: var(--bg-sections);
  }
}
.search-fitler.is-active {
  background-color: var(--bg-sections);
}
.search-fitler.is-active::after {
  opacity: 1;
  visibility: visible;
}

.error-404 {
  padding: 18.5rem 0 14rem;
  background-color: var(--bg-sections);
  color: var(--color-white);
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .error-404 {
    padding: 12.5rem 0 9rem;
  }
}
.error-404 .row-404 {
  max-width: 120.8rem;
  margin: 0 auto;
}
@media screen and (min-width: 1024px) {
  .error-404 .row-404 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 767px) {
  .error-404__title {
    font-size: 3rem;
    line-height: 1.1;
  }
}
@media screen and (min-width: 1024px) {
  .error-404__title {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 0px;
            flex: 1 0 0;
    max-width: 72rem;
    margin: 0 auto 0 0;
  }
}
@media screen and (min-width: 1200px) {
  .error-404__title .accent:hover {
    color: var(--color-accent-add);
  }
}
.error-404__img {
  font-size: 1rem;
  width: 39.9em;
  height: 35.7em;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1023px) {
  .error-404__img {
    margin: 4rem auto 0;
  }
}
@media screen and (max-width: 767px) {
  .error-404__img {
    font-size: 0.43rem;
  }
}
.error-404__img .four {
  margin: 0;
  font-size: 25rem;
  line-height: 1;
  position: absolute;
  z-index: -1;
  bottom: -0.15em;
  right: -0.1em;
  font-weight: 700;
  letter-spacing: normal;
}
@media screen and (max-width: 767px) {
  .error-404__img .four {
    font-size: 14rem;
  }
}
.error-404__img .four-l {
  left: -0.52em;
}
@media screen and (max-width: 767px) {
  .error-404__img .four-l {
    left: -0.58em;
  }
}
.error-404__img .four-r {
  right: -0.1em;
}
@media screen and (max-width: 767px) {
  .error-404__img .four-r {
    right: -0.43em;
  }
}

@media screen and (max-width: 767px) {
  .hero-privacy-policy h1, .hero-privacy-policy .fz-88 {
    font-size: 3rem;
    line-height: 1.15;
  }
}

.privacy-policy {
  margin: 8rem 0 12rem;
}
@media screen and (max-width: 767px) {
  .privacy-policy {
    margin: 3rem 0 7rem;
  }
}
.privacy-policy__body {
  max-width: 112.8rem;
  counter-reset: j;
  position: relative;
}
@media screen and (min-width: 1024px) {
  .privacy-policy__body {
    padding-left: 26rem;
  }
}
.privacy-policy__body .fz-22 {
  margin-top: 2em;
  margin-bottom: 1em;
}
@media screen and (max-width: 767px) {
  .privacy-policy__body .fz-22 {
    margin-top: 1.8em;
    margin-bottom: 1.3em;
  }
}
.privacy-policy__body ul, .privacy-policy__body ol {
  padding: 0;
  margin: 0;
  list-style: none;
}
.privacy-policy__body ol > li {
  margin-bottom: 1.5em;
}
.privacy-policy__title::before {
  counter-increment: j;
  content: counter(j) ".";
  display: inline-block;
  margin-right: 0.2em;
}
@media screen and (min-width: 1024px) {
  .privacy-policy__title::before {
    position: absolute;
    left: 0;
  }
}

.theme-black {
  background-color: #0A1820;
  color: var(--color-white);
}
.theme-black .slider-dots .swiper-pagination-bullet-active {
  border-color: rgba(255, 255, 255, 0.1);
}
.theme-black .slider-arrow {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.1);
}
@media screen and (min-width: 1200px) {
  .theme-black .slider-arrow:hover {
    background-color: var(--color-accent-main);
    border-color: var(--color-accent-main);
  }
}
.theme-black .slider-arrow::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .link-all:not(:hover)::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .form-white .input-wrap {
  background-color: #0A1820;
}
.theme-black .form-white .input {
  color: var(--color-white);
}
.theme-black .form-white .placeholder {
  color: var(--color-white);
}
.theme-black .form-white .wpcf7-acceptance .wpcf7-list-item-label::before {
  background-color: rgba(246, 246, 246, 0.1);
}
.theme-black .form-white .attachment::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .border-list {
  border-top-color: rgba(226, 229, 235, 0.2);
  border-bottom-color: rgba(226, 229, 235, 0.2);
}
.theme-black .border-list li {
  border-bottom-color: rgba(226, 229, 235, 0.2);
}
.theme-black .bg-gray:not(.case-logo) {
  background-color: var(--mob-block-bg);
}
.theme-black .bd-gray {
  border-color: var(--mob-border-color);
}
.theme-black .download-link {
  background-color: var(--mob-block-bg);
  color: var(--color-white);
}
.theme-black .color-black {
  color: var(--color-white);
}
.theme-black .select__trigger {
  background-color: var(--mob-block-bg);
  border-color: var(--mob-border-color);
}
.theme-black .select__options {
  background: #0A1820;
  border-color: var(--mob-border-color);
}
.theme-black .select__option.is-selected {
  background-color: var(--mob-block-bg);
}
.theme-black .home-service {
  background-color: var(--mob-block-bg);
  border-color: var(--mob-border-color);
}
.theme-black .cases-slider::after {
  background-color: #0A1820;
}
.theme-black .spec-list__btn {
  border-color: var(--mob-border-color);
}
.theme-black .news-list {
  border-top-color: var(--mob-border-color);
  border-bottom-color: var(--mob-border-color);
}
.theme-black .news-list li {
  border-bottom-color: var(--mob-border-color);
}
.theme-black .news-thumb-card__body::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
@media screen and (max-width: 1023px) {
  .theme-black .home-partners {
    background-color: var(--mob-block-bg);
  }
}
@media screen and (min-width: 1024px) {
  .theme-black .home-partners__row {
    background-color: var(--mob-block-bg);
  }
}
.theme-black .partner-box {
  /*background-color: #0A1820;*/
}
.theme-black .history__row .history-progress .slider-dots {
  background-color: var(--mob-block-bg);
}
.theme-black .banner-static .banner-inner {
  color: var(--color-white);
}
.theme-black .member__img .bg {
  background-color: var(--mob-block-bg);
}
@media screen and (max-width: 1023px) {
  .theme-black .filters-title {
    background-color: var(--mob-block-bg);
    border-color: var(--mob-border-color);
  }
  .theme-black .filters-title::after {
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
}
.theme-black .filter {
  background-color: var(--mob-block-bg);
  color: var(--color-white);
  border-color: var(--mob-border-color);
}
.theme-black .filter-remove:not(:hover)::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .mob-filters {
  background-color: #0A1820;
}
.theme-black .mob-filters .fancybox-close-small::before {
  -webkit-filter: none;
          filter: none;
}
.theme-black .mob-filters .filters-bottom .button {
  color: var(--color-white);
}
.theme-black .checkbox__wrap {
  background-color: rgba(246, 246, 246, 0.1);
}
.theme-black .job-list li {
  border-color: var(--mob-border-color);
}
.theme-black .vacancy__row {
  border-bottom-color: var(--mob-border-color);
}
@media screen and (max-width: 1023px) {
  .theme-black .vacancy__head {
    background-color: var(--mob-block-bg);
    color: var(--color-white);
  }
}
@media screen and (min-width: 1024px) {
  .theme-black .vacancy__head .vacancy__txt {
    background-color: var(--mob-block-bg);
    color: var(--color-white);
  }
}
@media screen and (min-width: 1200px) {
  .theme-black .esg-1 .esg-project:hover .esg-project__txt {
    border-top-color: var(--mob-border-color);
    border-bottom-color: var(--mob-border-color);
    border-right-color: var(--mob-border-color);
  }
}
.theme-black .esg-2 .bg-gray {
  background-color: rgba(255, 255, 255, 0.3);
}
.theme-black .esg-modal {
  background-color: #0A1820;
}
.theme-black .banner-download .download-link {
  background-color: #0A1820;
}
.theme-black .doc {
  border-color: var(--mob-border-color);
}
.theme-black .doc .ext {
  background-color: var(--mob-block-bg);
}
.theme-black .contacts-block {
  border-color: var(--mob-border-color);
}
.theme-black .map .ymaps-2-1-79-ground-pane {
  -webkit-filter: grayscale(0.6) invert(1);
          filter: grayscale(0.6) invert(1);
}
.theme-black .steps-slider .step::after {
  -webkit-filter: invert(1);
          filter: invert(1);
}
.theme-black .services-list li {
  border-bottom-color: var(--mob-border-color);
}
@media screen and (max-width: 1023px) {
  .theme-black .services-list .list {
    border-top-color: var(--mob-border-color);
  }
}
.theme-black .section-border {
  border-bottom-color: var(--mob-border-color);
}
.theme-black .accordion-item {
  border-bottom-color: var(--mob-border-color);
}
.theme-black .accordion-btn::before, .theme-black .accordion-btn::after {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .sector-thumb {
  border-color: var(--mob-block-bg);
}
@media screen and (min-width: 1024px) {
  .theme-black .sectors__grid .sector-thumb:nth-child(3) {
    border-left-color: var(--mob-block-bg);
  }
}
.theme-black .partner-logo img {
  /*-webkit-filter: invert(1);*/
  /*        filter: invert(1);*/
}
.theme-black .cases-2 {
  background-color: var(--mob-block-bg);
}
.theme-black .cases-2-slider__arrows.white .slider-arrow:not(:hover)::before {
  -webkit-filter: brightness(0) invert(1) !important;
          filter: brightness(0) invert(1) !important;
}
.theme-black .case-thumb.bg-gray {
  background-color: var(--mob-block-bg);
  border-color: var(--mob-border-color);
  color: var(--color-white);
}
.theme-black .case-thumb__tag {
  color: rgba(255, 255, 255, 0.5);
  border-color: rgba(255, 255, 255, 0.5);
}
.theme-black .case-thumb__logo-box {
  /*background-color: var(--mob-block-bg);*/
}
.theme-black .news-thumb {
  background-color: var(--mob-block-bg);
  border-color: var(--mob-border-color);
}
.theme-black .news-thumb--big .news-thumb__body {
  background: -o-linear-gradient(bottom, rgba(10, 24, 32, 0.5), rgba(10, 24, 32, 0.5)), -o-linear-gradient(338.51deg, rgba(10, 24, 32, 0.4) -8.95%, rgba(10, 24, 32, 0.01) 114%);
  background: linear-gradient(0deg, rgba(10, 24, 32, 0.5), rgba(10, 24, 32, 0.5)), linear-gradient(111.49deg, rgba(10, 24, 32, 0.4) -8.95%, rgba(10, 24, 32, 0.01) 114%);
}
.theme-black .news-thumb--big .news-thumb__txt {
  color: rgba(255, 255, 255, 0.8);
}
.theme-black .pagination .page-numbers:not(:hover) {
  color: var(--color-white);
}
.theme-black .pagination .page-numbers.current {
  color: var(--color-white);
  background-color: var(--mob-block-bg);
}
.theme-black .pagination .prev:not(:hover), .theme-black .pagination .next:not(:hover) {
  border-color: var(--mob-border-color);
}
.theme-black .pagination .prev::before, .theme-black .pagination .next::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .smi-thumb__img {
  background-color: var(--mob-block-bg);
}
.theme-black .smi-thumb__img img {
  /*-webkit-filter: invert(1);*/
  /*        filter: invert(1);*/
}
.theme-black .page-filters .input, .theme-black .mob-filters .filters-search .input {
  background-color: var(--mob-block-bg);
  border-color: var(--mob-border-color);
  color: var(--color-white) !important;
}
.theme-black .page-filters .input::-webkit-input-placeholder, .theme-black .mob-filters .filters-search .input::-webkit-input-placeholder {
  color: var(--color-white);
}
.theme-black .page-filters .input::-moz-placeholder, .theme-black .mob-filters .filters-search .input::-moz-placeholder {
  color: var(--color-white);
}
.theme-black .page-filters .input:-ms-input-placeholder, .theme-black .mob-filters .filters-search .input:-ms-input-placeholder {
  color: var(--color-white);
}
.theme-black .page-filters .input::-ms-input-placeholder, .theme-black .mob-filters .filters-search .input::-ms-input-placeholder {
  color: var(--color-white);
}
.theme-black .page-filters .input::placeholder, .theme-black .mob-filters .filters-search .input::placeholder {
  color: var(--color-white);
}
.theme-black .mob-filters .filters-search .input {
  background: none;
}
.theme-black .page-filters .submit:not(:hover)::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .mob-filters .filters-search .submit::before {
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
}
.theme-black .recommended {
  background-color: var(--mob-block-bg);
}
.theme-black .case-logo img {
  /*-webkit-filter: invert(1);*/
  /*        filter: invert(1);*/
}
@media screen and (max-width: 767px) {
  .theme-black .case-body {
    border-top-color: var(--mob-border-color);
  }
}
.theme-black .content hr {
  opacity: 0.16;
}
.theme-black .letter-body {
  background-color: #0A1820;
  -webkit-box-shadow: 0px 10px 45px rgba(0, 0, 0, 0.1);
          box-shadow: 0px 10px 45px rgba(0, 0, 0, 0.1);
}
.theme-black .letter-author {
  border-top-color: var(--mob-border-color);
}
.theme-black .press-center-events .news-thumb {
  color: var(--color-white);
}
@media screen and (min-width: 768px) {
  .theme-black .downloads-banner .download-link {
    background-color: #0A1820;
  }
}
.theme-black .hero-links .download-link {
  background-color: var(--bg-sections);
}
.theme-black .tag {
  border-color: rgba(255, 255, 255, 0.5);
  color: rgba(255, 255, 255, 0.5);
}
.theme-black .partners-service__logo {
  background-color: var(--mob-block-bg);
}
.theme-black .partners-service__logo img {
  -webkit-filter: invert(1);
          filter: invert(1);
}
.theme-black .search-item {
  border-color: var(--mob-border-color);
}
.theme-black .search-form__input .input {
  color: var(--color-white) !important;
  border-bottom-color: var(--color-white);
}
.theme-black .search-form__input .input::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.theme-black .search-form__input .input::-moz-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.theme-black .search-form__input .input:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.theme-black .search-form__input .input::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.theme-black .search-form__input .input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
/*# sourceMappingURL=styles.css.map */
