/*
Theme Name: Ugpa
Theme URI: 
Author: UGPA
Author URI:
Description: Scada template
Requires at least: 6.7
Tested up to: 6.7
Requires PHP: 7.2
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ugpa
Tags: 
*/
@font-face {
  font-display: swap;
  font-family: 'PT-Sans';
  font-style: normal;
  font-weight: normal;
  /* font-display: swap; */
  src: url('./fonts/PT-Sans/PT-Sans_Regular.ttf');
}

@font-face {
  font-display: swap;
  font-family: 'PT-Sans';
  font-style: normal;
  font-weight: bold;
  /* font-display: swap; */
  src: url('./fonts/PT-Sans/PT-Sans_Bold.ttf');
}

/* variables */

:root {
  --bg-white: #FFFFFF;
  --bg-gray: #EEEEEF;
  --bg-black: #0C171F;
  --text-black: #0C171F;
  --text-black-secondary: #0C171FBD;
  --text-white-secondary: #FFFFFFB2;
  --black-stroke: #0C171F1A;
  --white-stroke: #FFFFFF1A;
  --primary: #02A750;
}

html {
  scroll-behavior: smooth;
  /* scroll-snap-type: y proximity;
  scroll-padding-top: 100px; */
}

/* Reset and base styles  */
* {
  padding: 0px;
  margin: 0px;
  border: none;
}

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

/* Links */
a {
  transition: .3s ease;
  text-decoration-skip-ink: none;
}
a:link,
a:visited {
  text-decoration: none;
  color: inherit;
}

a:hover {
  text-decoration: underline;
  /* text-decoration: none; */
}
a.button:hover {
  text-decoration: none;
}
a.modal-form--file {
  text-decoration: none;
}

/* Common */

aside,
nav,
footer,
header,
section,
main {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
  font-size: inherit;
  font-weight: inherit;
}

ul,
ul li {
  list-style: none;
}

img {
  vertical-align: top;
}

img,
svg {
  max-width: 100%;
  height: auto;
}

address {
  font-style: normal;
}

/* Form */

input,
textarea,
button,
select {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
  background-color: transparent;
}

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

button,
input[type="submit"] {
  /* display: inline-block !important; */
  box-shadow: none;
  background-color: transparent;
  background: none;
  cursor: pointer;
  font-family: 'PT-Sans';
}

input:focus,
input:active,
button:focus,
button:active {
  outline: none;
}

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

label {
  cursor: pointer;
}

legend {
  display: block;
}

/* anim svg */

@-webkit-keyframes animate-svg-stroke-1 {
  0% {
    stroke-dashoffset: 69.94157409667969px;
    stroke-dasharray: 69.94157409667969px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 69.94157409667969px;
  }
}

@keyframes animate-svg-stroke-1 {
  0% {
    stroke-dashoffset: 69.94157409667969px;
    stroke-dasharray: 69.94157409667969px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 69.94157409667969px;
  }
}

.scroll-mouse-1 {
  -webkit-animation: animate-svg-stroke-1 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s both;
  animation: animate-svg-stroke-1 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0s both;
}

@-webkit-keyframes animate-svg-stroke-2 {
  0% {
    stroke-dashoffset: 7px;
    stroke-dasharray: 7px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 7px;
  }
}

@keyframes animate-svg-stroke-2 {
  0% {
    stroke-dashoffset: 7px;
    stroke-dasharray: 7px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 7px;
  }
}

.scroll-mouse-2 {
  -webkit-animation: animate-svg-stroke-2 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s both;
  animation: animate-svg-stroke-2 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.12s both;
}

@-webkit-keyframes animate-svg-stroke-3 {
  0% {
    stroke-dashoffset: 20px;
    stroke-dasharray: 20px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 20px;
  }
}

@keyframes animate-svg-stroke-3 {
  0% {
    stroke-dashoffset: 20px;
    stroke-dasharray: 20px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 20px;
  }
}

.scroll-mouse-3 {
  -webkit-animation: animate-svg-stroke-3 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.24s both;
  animation: animate-svg-stroke-3 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.24s both;
}

@-webkit-keyframes animate-svg-stroke-4 {
  0% {
    stroke-dashoffset: 21.10497283935547px;
    stroke-dasharray: 21.10497283935547px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 21.10497283935547px;
  }
}

@keyframes animate-svg-stroke-4 {
  0% {
    stroke-dashoffset: 21.10497283935547px;
    stroke-dasharray: 21.10497283935547px;
  }

  100% {
    stroke-dashoffset: 0;
    stroke-dasharray: 21.10497283935547px;
  }
}

.scroll-mouse-4 {
  -webkit-animation: animate-svg-stroke-4 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.36s both;
  animation: animate-svg-stroke-4 1s cubic-bezier(0.47, 0, 0.745, 0.715) 0.36s both;
}


.main,
.scrollable-right {
  will-change: transform;
  backface-visibility: hidden;
}

/* elements */

h1,
h2,
h3,
h4 {
  font-weight: bold;
  letter-spacing: 1%;
  text-align: center;
}

h1 {
  font-size: 44px;
  line-height: 100%;
}

h2 {
  font-size: 40px;
  line-height: 100%;
}

h3 {
  font-size: 32px;
  line-height: 114%;
}

h4 {
  font-size: 24px;
  line-height: 130%;
}

.text-L,
.text-S {
  font-weight: normal;
  letter-spacing: 1%;
}

.text-L {
  font-size: 16px;
  line-height: 140%;
}

.text-S {
  font-size: 14px;
  line-height: 155%;
}

.text-bold {
  font-weight: bold;
}

@media (max-width: 374px) {
  h1 {
    font-size: 37px;
  }
  h2 {
    font-size: 34px;
  }
  h3 {
    font-size: 28px;
  }
}

@media (min-width: 1080px) {
  h1 {
    font-size: 80px;
  }

  h2 {
    font-size: 70px;
  }

  h3 {
    font-size: 36px;
  }

  h4 {
    font-size: 24px;
  }

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

  .text-S {
    font-size: 16px;
  }
}

@media (min-width: 1920px) {
  h1 {
    font-size: 100px;
  }

  h2 {
    font-size: 90px;
  }

  h3 {
    font-size: 54px;
  }

  h4 {
    font-size: 30px;
  }

  .text-L {
    font-size: 20px;
  }

  .text-S {
    font-size: 16px;
  }
}

@media (min-width: 2560px) {
  h1 {
    font-size: 130px;
  }

  h2 {
    font-size: 110px;
  }

  h3 {
    font-size: 64px;
  }

  h4 {
    font-size: 40px;
  }

  .text-L {
    font-size: 24px;
  }

  .text-S {
    font-size: 20px;
  }
}

video::-webkit-media-controls {
  display: none;
}

.text-gradient {
  display: inline-block;
  background: linear-gradient(130.24deg, #01BBF0 10.46%, #B3CE34 88.87%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  position: relative;
  z-index: 1;
  color: transparent !important; /* Резервное решение */
}

.button {
  border-radius: 10px;
  padding: 10px 24px;
  color: white;
  background-color: var(--primary);
  font-size: 16px;
  line-height: 140%;
  letter-spacing: 1%;
  transition: .3s ease;
  overflow: hidden;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  user-select: none;
}

.button::before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  text-align: center;
  color: white;
  transition: all 0.3s ease;
  opacity: 0;
  transform: translateY(20px);
}

.button span {
  display: block;
  transition: all 0.3s ease;
}

.button:hover {
  background-color: #039C4B;
}

.button:hover span {
  transform: translateY(-140%);
  opacity: 0;
}

.button:hover::before {
  transform: translateY(-140%);
  opacity: 1;
}

.button-gray {
  background: rgba(12, 23, 31, 0.1);
  border: 2px solid var(--primary);
  backdrop-filter: blur(1.5px);
}

.button-gray:hover {
  background: rgba(12, 23, 31, 0.1);
}

.button-white {
  background: rgba(255, 255, 255, 0.01);
  border: 2px solid var(--primary);
  backdrop-filter: blur(1.1px);
  color: var(--text-black);
  opacity: 0.6;
}

.button-white.button::before {
  color: var(--text-black);
}

.button-white:hover {
  opacity: 1;
  background: rgba(255, 255, 255, 0.01);
  color: var(--text-black) !important;
  backdrop-filter: blur(2.2px);
}

.swiper-button-prev,
.swiper-button-next {
  background-color: #0000000F;
  border-radius: 100%;
  width: 56px;
  height: 56px;
}

.wpcf7-spinner {
  display: none;
}

.wpcf7-submit {
  width: 100%;
  font-weight: 400;
}

.gradient-border-button {
  display: inline-block;
  padding: 15px 30px;
  font-size: 16px;
  font-weight: bold;
  color: white;
  text-align: center;
  text-decoration: none;
  border: 3px solid transparent;
  border-radius: 30px;
  background: transparent;
  position: relative;
  overflow: hidden;
}

/* Градиентная граница с mask */
.gradient-border-button::before {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(130.24deg, #01BBF0 10.46%, #B3CE34 88.87%);
  border-radius: 30px;
  z-index: -1;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  padding: 3px;
}

/* Эффект при наведении */
.gradient-border-button:hover {
  background: rgba(255, 255, 255, 0.1);
}

/* Эффект при нажатии */
.gradient-border-button:active {
  transform: translateY(1px);
}

.button-gradient {
  background: transparent;
  border: 2px solid var(--primary);
}

.swiper-button-next,
.swiper-button-next {
  user-select: none;
}

ul.list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

ul.list li {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
  /* border-bottom: 1px solid #eee; */
}

ul.list li::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: var(--primary);
  border-radius: 50%;
  grid-column: 1;
  margin-top: 8px;
}

.number {
  background: transparent;
  width: 48px;
  height: 48px;
  max-width: 48px;
  max-height: 48px;
  min-width: 48px;
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  border: 1px solid var(--black-stroke);
  color: var(--text-black);
  font-weight: bold;
  font-size: 16px;
  flex-grow: 1;
}

@media (min-width: 1080px) {
  .button {
    padding: 10px 32px;
    font-size: 20px;
  }
}

.wrapper {
  max-width: 1760px;
  width: 100%;
  margin: 0 auto;
}

/* body */
.body {
  font-family: 'PT-Sans';
  background-color: var(--bg-gray);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.body.open {
  overflow: hidden;
}

.body.body-no-scroll {
  overflow: hidden;
  padding-right: var(--scrollbar-width);
}

/* header */

.header {
  color: var(--bg-black);
  padding: 16px;
  position: sticky;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  background-color: white;
  transition: all 0.3s ease-in-out;
  border-bottom: 2px solid #0C171F1A;
}

.header.hide {
  opacity: 0;
  /* transform: translateY(-100%); */
}

.header.show {
  opacity: 1;
  /* transform: translateY(0); */
}

.header__wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header__logo img {
  width: 120px;
  height: 35px;
}

.header__logo p {
  display: none;
}

.header__burger {
  height: 26px;
  min-width: 32px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  order: 1;
}

.header__burger.open .header__burger__line1 {
  transform: translateY(7px) rotate(45deg);
}

.header__burger.open .header__burger__line3 {
  transform: translateY(-7px) rotate(-45deg);
}

.header__burger.open+.header__menu-items {
  opacity: 1;
}

.header__menu-items {
  position: fixed;
  left: 0;
  top: 0;
  height: 0;
  width: 0;
  visibility: hidden;
  opacity: 0;
  transform: translateX(350px);
  font-size: 24px;
}

.header__menu-items a {
  transition: opacity .3s ease;
  display: block;
}

.header__menu-items .panel {
  max-height: 0;
  overflow: hidden;
  transition: all 0.2s ease-out;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.header__menu-items .accordion-menu {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  transition: .3s ease;
  width: 100%;
  font-size: 24px;
  font-weight: bold;
  text-align: left;
}

.header__menu-items .accordion-menu.active {
  color: var(--primary);
}

.header__menu-items .accordion-menu.active+.submenu > .panel {
  padding: 24px 0;
}

.header__menu-items .submenu .accordion-menu:hover .accordion-description{
  color: #0C171F;
}

.header__menu-item.active-link {
  color: var(--primary);
}
.header__menu-item:not(.active-link) {
  color: #0C171F;
} 


.header__menu-items .accordion-menu::after {
  content: url('./images/menu-gray.svg');
  display: flex;
  width: 12px;
  height: 6px;
  justify-content: center;
  align-items: center;
  margin-bottom: 4px;
  margin-top: 0;
  transition: .3s ease;
  transform-origin: center;
}

.header__menu-items .accordion-menu.active::after {
  transform: rotate(-180deg);
  color: var(--primary);
  margin-bottom: 0px;
  margin-top: 4px;
}
.header__menu-items a {
  transition: .3s ease;
}
.header__menu-items a.active-link {
  color: var(--primary);
}
.header__menu-items .panel .panel li a:hover {
  color: white;
  background-color: #02A750;
  text-decoration: none;
}
.header__menu-items .panel .panel li a.active-link {
  color: white;
  background-color: #02A750;
}


.header__menu-items .submenu .accordion-menu {
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 8px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  text-decoration: none;
}

.header__menu-items .submenu .accordion-menu .accordion-description {
  text-align: left;
  color: var(--text-black-secondary);
  font-weight: normal;
  transition: .3s ease;
}

.header__menu-items .submenu .accordion-menu::after {
  position: absolute;
  right: 0;
}

.header__menu-items .panel .panel .menu-item-description{
  display: none;
}
.header__menu-items .panel .panel li {
  color: var(--text-black-secondary);
}
.header__menu-items .panel .panel li a{
  padding: 12px 20px;
  border: 1px solid #0C171F1A;
  border-radius: 6px;
  font-weight: normal;
  font-size: 14px;
  position: relative;
  display: flex;
  flex-direction: row;
  gap: 10px;
  align-items: center;
}

.header__menu-item.disabled {
  cursor: not-allowed;
  opacity: .7;
}

.header__menu-item.disabled a {
  pointer-events: none;
  cursor: not-allowed;
}

/* .header__menu-items .panel .panel li a::after {
  content: '';
  position: static;
  width: 24px;
  height: 24px; 
  background-image: url('./images/question.svg');
  background-size: contain;
  background-repeat: no-repeat;
} */
/* .header__menu-items .panel .panel li a::after:hover{
  
} */

.header__menu-items .panel .panel {
  max-height: 0;
  display: grid;
  grid-template-columns: repeat(2, max-content); /* Всегда 2 колонки */
  gap: 6px 8px;
  width: 100% !important;
}

.body.open .header__menu-items {
  visibility: visible;
  overflow: scroll;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 48px;
  min-height: calc(100vh - 80px - 48px);
  width: calc(100% - 32px);
  background-color: var(--bg-gray);
  transform: translateX(0);
  transition: transform 0.3s ease-in-out;
  z-index: 1000;
  padding: 16px;
  margin: 48px 16px;
  border-radius: 10px;
  border: 1px solid #0C171F1A;
}

.header__menu-item {
  position: relative;
  width: 100%;
  padding: 24px 0;
  border-bottom: 1px solid #0C171F1A;
  font-size: 24px;
  font-weight: bold;
}

.panel .header__menu-item {
  border: 0;
  padding: 0;
}

.panel .header__menu-item a {
  font-size: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.panel .header__menu-item a .menu-item-description {
  color: var(--text-black-secondary);
  font-weight: normal;
}

.header__burger__line {
  display: block;
  height: 4px;
  width: 24px;
  border-radius: 10px;
  background: var(--bg-black);
}

.header__burger__line1 {
  transform-origin: center;
  transition: transform 0.4s ease-in-out;
}

.header__burger__line3 {
  transform-origin: center;
  transition: transform 0.4s ease-in-out;
}

.submenu .submenu-title {
  display: none;
}

.submenu .accordion-description {
  /* position: absolute;
  top: 40px;
  text-align: left; */
}

@media (min-width: 1080px) {
  .header {
    position: fixed;
    align-items: center;
    /* background: transparent; */
    padding: 24px 40px;
    background: white;
    color: var(--bg-black);
  }

  .header.hide {
    opacity: 0;
    transform: translateY(-100%);
  }

  .header.show {
    opacity: 1;
    transform: translateY(0);
  }

  .header__wrapper {
    position: relative !important;
    /* Добавьте это */
    max-width: 1760px;
    margin: 0 auto;
    align-items: center;
  }

  .header__logo {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .header__logo svg {
    width: 160px;
    height: 40px;
  }

  .header__logo img {
    width: 200px;
    height: 50px;
  }

  .header__logo p {
    display: block;
    max-width: 340px;
  }

  .header__burger {
    display: none;
  }

  .header__menu-items {
    position: relative;
    z-index: 1;
    height: auto;
    width: auto;
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    display: flex;
    align-items: center;
    gap: 40px;
    font-size: 20px;
  }

  .header__menu-items .panel {
    width: 100%;
    max-height: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(253px, 1fr));
    gap: 32px;
    overflow-x: hidden;
    overflow-y: auto;
  }

  .header__menu-items .accordion-menu.active+.submenu > .panel {
    padding: 0 0 120px;
  }

  .header__menu-items .panel::after {
    display: none;
  }

  .header__menu-items .panel li {
    color: black;
    width: auto;
    /* Изменено с фиксированной ширины */
    padding: 0;
    /* Добавлено отступов для элементов */
    max-width: 610px;
  }

  .header__menu-items .panel li a {
    font-size: 18px;
  }

  .header__menu-items .panel .panel {
    position: absolute;
    top: 88px !important;
    left: 0 !important;
    background: #EEEEEF;
    z-index: 1;
  }

  .header__menu-items .accordion-menu.active .panel {
    display: flex;
    /* Показываем при активации */
    opacity: 1;
    padding: 40px;
  }
  .submenu .header__menu-item {
    position: relative;
  }
  .header__menu-item {
    position: static;
    display: flex;
    flex-direction: column;
    padding: 0;
    border: 0;
    font-size: 18px;
    width: auto;
    font-weight: normal;
  }

  .header__menu-item .accordion-menu {
    align-self: flex-end;
    justify-content: flex-start;
    font-weight: normal;
    font-size: 18px;
    gap: 10px;
  }

  .submenu {
    position: absolute;
    top: calc(100% + 64px);
    max-width: 1760px;
    max-height: 0px;
    opacity: 0;
    transition: all .5s ease;
    overflow: hidden;
    background-color: #EEEEEF;
    color: var(--bg-black);
    padding: 40px;
    border-radius: 10px;
    display: flex;
    gap: 32px;
    transform: translateY(-400px);
    border: 1px solid #0C171F1A;
    box-shadow: 4px 4px 31.5px rgba(0, 0, 0, 0.1);
  }

  .accordion-menu:hover {
    color: var(--primary);
    text-decoration: underline;
  }

  .header__menu-items a:hover {
    color: var(--primary);
    text-decoration: underline;
  }

  .header__menu-items .accordion-menu.active+.submenu {
    opacity: 1;
    transform: translateY(0);
  }

  .submenu .submenu-title {
    font-size: 24px;
    line-height: 130%;
    font-weight: bold;
    display: flex;
    flex-direction: column-reverse;
    justify-content: space-between;
    min-width: 80px;
    gap: 80px;
  }

  .submenu .submenu-title .submenu-logo {
    width: 70px;
    height: 58px;
    background-image: url(./images/submenu-logo.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
  }

  .submenu .submenu-divider {
    width: 1px;
    height: auto;
    background-color: #0C171F1A;
  }

  .submenu .panel>li>a {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-weight: bold;
    text-decoration: none;
  }

  .submenu .panel>li .menu-item-description {
    color: var(--text-black-secondary);
    transition: .3s ease;
    font-weight: normal;
  }

  .header__menu-items a:hover .menu-item-description {
    color: var(--bg-black);
  }

  .header__menu-items .accordion-menu::after {
    content: url('./images/menu-black.svg');
  }

  /* .header__menu-items .accordion-menu:hover::after{
    content: url('./images/menu-green.svg');
  } */

  .header__menu-items .submenu .accordion-menu {
    font-size: 18px;
  }

  .header__menu-items .panel .panel li a{
    padding: 10px 24px;
    border-radius: 10px;
    font-size: 18px;
    display: flex;
  }
  .submenu-title-text {
    max-width: 260px;
  } 
}
@media (min-width: 1400px) {
  .header__menu-items .panel {
    grid-template-columns: repeat(3, minmax(253px, 1fr));
  }
}
@media (min-width: 1920px) {
  .header {
    padding: 24px 80px;
  }

  .header__logo svg {
    width: 200px;
    height: 50px;
  }

  .header__menu-items .panel {
    grid-template-columns: repeat(3, minmax(410px, 1fr));
  }

  .header__menu-items .accordion-menu.active+.submenu > .panel {
    padding: 0;
  }

  .header__menu-item .accordion-menu {
    font-size: 20px;
  }

  .header__menu-item {
    font-size: 20px;
  }

  .submenu .submenu-title {
    font-size: 30px;
  }

  .header__menu-items .panel li a {
    font-size: 20px;
  }
  .header__menu-items .submenu .accordion-menu {
    font-size: 20px;
  }

  .header__menu-items .panel .panel li a{
    font-size: 20px;
  }
  .submenu-title-text {
    max-width: 320px;
  } 
}

@media (min-width: 2560px) {
  .header {
    padding: 24px 160px;
  }

  .header__wrapper {
    max-width: 2240px;
  }

  .header__logo svg {
    width: 240px;
    height: 60px;
  }

  .header__menu-items .panel .panel {
    top: 112px !important;
  }

  .submenu {
    max-width: 2240px;
  }

  .header__menu-items .panel {
    grid-template-columns: repeat(3, minmax(510px, 1fr));
    gap: 48px;
  }

  .header__menu-item .accordion-menu {
    font-size: 24px;
  }

  .header__menu-item {
    font-size: 24px;
  }

  .submenu .submenu-title {
    font-size: 40px;
  }

  .header__menu-items .panel li a {
    font-size: 24px;
  }
  .header__menu-items .submenu .accordion-menu {
    font-size: 24px;
  }

  .header__menu-items .panel .panel li a{
    font-size: 24px;
  }
}

/* content */
.main {
  position: relative;
}

.content {
  position: relative;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.main video {
  display: none;
  object-fit: cover;
  object-position: center;
  background-size: cover;
  width: 100%;
  height: calc(100vh - 70px);
  min-height: 700px;
  border-radius: 0;
}

.main img {
  display: block;
  object-fit: cover;
  object-position: center;
  background-size: cover;
  width: 100%;
  height: calc(100vh - 70px);
  min-height: 700px;
  border-radius: 0;
}

.shadow {
  z-index: 1;
  background: black;
  opacity: .6;
  height: calc(100vh - 70px);
  min-height: 700px;
  top: 0;
  left: 0;
  width: 100%;
  position: absolute;
}

/* automation */
.automation {
  color: white;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: absolute;
  z-index: 3;
  top: 0;
}

.automation h1 {
  text-align: left;
  margin-bottom: 40px;
}

.automation__buttons {
  display: flex;
  flex-direction: row;
  gap: 8px;
}
.automation__buttons .button {
  min-width: 185px;
}

@media (max-width: 419px) {
  .automation__buttons {
    flex-direction: column;
    align-self: flex-start;
  }
}

.scroll-down {
  display: none;
}

@media (min-width: 1080px) {
  .main video {
    height: 100vh;
    display: block;
  }

  .main img {
    display: none;
  }

  .shadow {
    height: 100vh;
  }

  .automation {
    align-items: flex-start;
    max-width: 600px;
    text-align: left;
    margin-top: 0;
    top: 50%;
    transform: translateY(-50%);
    left: 40px;
  }

  .automation h1 {
    width: 600px;
    text-align: left;
    margin-bottom: 32px;
  }
}

@media (min-width: 1280px) {
  .scroll-down {
    display: block;
    position: absolute;
    top: 50%;
    left: -100px;
    transform: translateY(-50%);
    z-index: 3;
  }
}

@media (min-width: 1920px) {
  .automation h1 {
    margin-bottom: 60px;
  }
}
/* statistic */
.statistic {
  margin: 60px 0px;
  display: flex;
  flex-direction: column;
  color: white;
  gap: 24px;
  position: absolute;
  /* top: 300px; */
  z-index: 2;
  left: 20px;
}

.statistic__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  gap: 8px;
}

.statistic__item h1,
.statistic__item h2 {
  font-weight: bold;
  text-align: left;
}

.statistic__item p {
  text-align: left;
  max-width: 346px;
}

@media (min-width: 1080px) {
  .statistic {
    right: 70px;
    left: auto;
    top: 240px;
    gap: 40px;
  }

  .statistic__item p {
    text-align: left;
    max-width: 300px;
  }

  .statistic__item h1,
  .statistic__item h2 {
    text-align: left;
  }

  .statistic__item {
    align-items: baseline;
  }
}

@media (min-width: 1280px) {
  .statistic {
    position: relative;
    top: auto;
    left: auto;
    right: 0;
    max-width: 600px;
    margin: 0 80px 140px auto;
    width: 100%;
    align-items: end;
  }

  .statistic__item h1,
  .statistic__item h2 {
    min-width: 250px;
    text-align: left;
  }
}

@media (min-width: 1920px) {
  .statistic {
    gap: 50px;
  }
  .statistic__item {
    width: 389px;
  }
  .statistic__item p {
    max-width: 389px;
  }
}

/* solution */
.solution-wrapper {
  position: relative;
  width: 100%;
  background-color: var(--bg-gray);
}

.solution {
  padding: 100px 20px;
  background-color: var(--bg-gray);
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.solution h2+p,
.solution h3+p {
  text-align: center;
  margin-bottom: 24px;
  color: var(--text-black-secondary);
}

.solution__examples {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.solution__examples-card {
  height: 300px;
  color: white;
  border-radius: 10px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  padding: 16px;
  display: flex;
  flex-direction: column;
  position: relative;
}

.solution__examples-card--text {
  position: absolute;
  z-index: 1;
  left: 16px;
  top: 16px;
}

.solution__examples-card h3,
.solution__examples-card h4 {
  text-align: left;
  margin-bottom: 20px;
}

.solution__examples-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 100%;
  background: linear-gradient(360deg, rgba(0, 0, 0, 0) 15%, #000000 85%);
  z-index: 0;
  opacity: .55;
  border-radius: 10px;
}

.solution__examples-card.metro {
  background-image: url(./images/metro-mobile.jpg);
}

.solution__examples-card.urban {
  background-image: url(./images/urban-mobile.jpg);
}

.solution__examples-card.railway {
  background-image: url(./images/railway-mobile.jpg);
}

.solution__examples-card.energy {
  background-image: url(./images/energy-mobile.jpg);
}

@media (min-width: 1080px) {
  .solution {
    max-width: 1760px;
    width: 100%;
    margin: 100px auto;
    gap: 24px;
    padding: 0 40px;
  }

  .solution__examples-card--text {
    position: absolute;
    z-index: 1;
    left: 48px;
    top: 40px;
  }

  .solution__examples-card::after {
    background: linear-gradient(360deg, rgba(0, 0, 0, 0) 55%, #000000 85%);
  }

  .solution__examples-card.metro {
    background-image: url(./images/metro.jpg);
  }

  .solution__examples-card.urban {
    background-image: url(./images/urban.jpg);
  }

  .solution__examples-card.railway {
    background-image: url(./images/railway.jpg);
  }

  .solution__examples-card.energy {
    background-image: url(./images/energy.jpg);
  }

  .solution__examples {
    flex-wrap: wrap;
    flex-direction: row;
    gap: 30px;
    margin-top: 56px;
  }

  .solution__examples-card {
    height: 450px;
    padding: 50px;
    min-width: calc(50% - 15px);
  }

  .solution__examples-card.urban {
    max-width: calc(50% - 15px);
  }

  .solution__examples-card.railway {
    max-width: calc(50% - 15px);
  }

  .solution__examples-card.metro {
    justify-content: start;
    flex-grow: 1;
    width: 100%;
  }

  .solution__examples-card.energy {
    flex-grow: 1;
  }

  .solution__examples-card h3,
  .solution__examples-card h4,
  .solution__examples-card p {
    max-width: 492px;
  }
}

@media (min-width: 1400px) {
  .solution__examples-card {
    height: 550px;
  }
}

@media (min-width: 1920px) {
  .solution {
    padding: 0;
    margin: 140px auto;
  }
}

@media (min-width: 2560px) {
  .solution {
    max-width: 2240px;
    margin: 180px auto;
  }
}


/* scada */
.scada {
  background-color: var(--bg-black);
  color: white;
  display: flex;
  flex-direction: column;
  padding: 100px 20px;
  gap: 24px;
}

.scada__logo {
  width: 80px;
  height: 80px;
  align-self: center;
}

.scada__subtitle {
  margin-bottom: 32px;
  max-width: 272px;
  align-self: center;
  text-align: center;
}

.scada__content {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.scada__content-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 40px;
}

.scada__content-text__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.scada__content-text__item h3,
.scada__content-text__item h4 {
  text-align: left;
}

.scada__content-text__item p {
  color: var(--text-white-secondary);
}

.scada__content-image {
  display: block;
  order: -1;
}

.scada .button {
  width: 136px;
}

@media (min-width: 1080px) {
  .scada {
    max-width: 1760px;
    width: 100%;
    margin: 100px auto;
    padding: 0 40px;
    gap: 24px;
  }

  .scada__logo {
    width: 140px;
    height: 140px;
  }

  .scada__subtitle {
    margin-bottom: 80px;
  }

  .scada__content {
    justify-content: space-between;
    flex-direction: row;
    align-items: center;
  }

  .scada__content-text {
    gap: 30px;
    align-items: flex-start;
    max-width: 500px;
  }

  .scada .button {
    margin-top: 30px;
    width: 164px;
  }

  .scada__content-image {
    display: block;
    order: 0;
    height: 350px;
  }

  .scada__content-image img {
    height: 350px;
  }

  .scada .button {
    margin-top: 30px;
    align-self: flex-start;
  }
}

@media (min-width: 1920px) {
  .scada {
    padding: 0;
    margin: 140px auto;
  }

  .scada__content-text__item {
    min-height: 111px;
  }

  .scada__content-image img {
    height: 428px;
  }

  .scada__content-image {
    height: 428px;
  }

  .scada__content-text {
    gap: 50px;
    max-width: 600px;
  }

  .scada .button {
    margin-top: 60px;
    align-self: flex-start;
  }
}

@media (min-width: 2560px) {
  .scada {
    padding: 0;
    margin: 180px auto;
    max-width: 2240px;
  }
  .scada__subtitle  {
    max-width: 320px;
  }
}

/* design */
.design {
  padding: 100px 20px;
  background-color: var(--bg-gray);
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.design h3{
  text-align: left;
}

.design .swiper {
  width: 100%;
  padding-bottom: 56px;
  /* height: 590px; */
}

.design__swiper {
  position: relative;
}

.design__swiper .swiper-wrapper {
  display: flex;
  align-items: stretch;
  /* Выравнивание слайдов по высоте */
}

.design__swiper .swiper-slide {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
  max-width: 480px;
  height: auto;
  flex-shrink: 0;
  /* Важно для корректной работы Swiper */
  box-sizing: border-box;
  cursor: pointer;
}

.design__swiper .swiper-slide h4 {
  transition: .3s ease;
}

.design__swiper .swiper-slide:hover h4 {
  text-decoration: underline;
}

.design__swiper h3,
.design__swiper h4 {
  text-align: left;
  transition: .3s ease;
}

@media (max-width: 374px) {
  .design__swiper h4 {
    font-size: 20px;
  }
}

.design__swiper .swiper-slide img {
  width: 100%;
  height: auto;
  max-width: 480px;
  max-height: 480px;
  aspect-ratio: 1/1;
  /* Сохраняет пропорции */
  object-fit: cover;
  /* Заполнение области */
  border-radius: 10px;
}

.design__swiper .swiper-slide p {
  font-size: 14px;
  color: var(--text-black-secondary);
}

.design__swiper .divider {
  height: 2px;
  width: calc(100% - 138px);
  background-color: #0000001A;
  position: absolute;
  bottom: 28px;
  left: 0;
  border-radius: 10px;
}

.design__swiper .swiper-scrollbar-drag {
  background: #02A750;
}

.design__swiper .design__swiper-button-next,
.design__swiper .design__swiper-button-prev {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: auto;
  bottom: 0px;
}

.design__swiper .design__swiper-button-next {
  right: 0px;
}

.design__swiper .design__swiper-button-prev {
  right: 72px;
  left: auto;
}

.design__swiper [class^="swiper-button-"]::after {
  content: "";
}

@media (min-width: 1080px) {
  .design {
    margin: 100px auto;
    width: 100%;
    padding: 0px 40px;
    gap: 80px;
  }

  .design__swiper .swiper-slide img {
    width: 480px;
    height: 480px;
  }

  .design h2,
  .design h3 {
    text-align: left;
  }

  .design__swiper .swiper-slide p {
    font-size: 20px;
  }
}

@media (min-width: 1400px) {
  .design__swiper .swiper-slide {
    margin-bottom: 60px;
  }
}

@media (min-width: 1920px) {
  .design {
    max-width: 1760px;
    padding: 0;
    margin: 140px auto;
  }
}

@media (min-width: 2560px) {
    .design {
      max-width: 2240px;
      padding: 0;
      margin: 100px auto;
    }
	.design__swiper .swiper-slide {
      max-width: 600px;
    }
    .design__swiper .swiper-slide img {
      width: 600px;
      height: 600px;
      max-width: 600px;
      max-height: 600px;
    }
}

/* production */
.production {
  padding: 100px 20px;
  background-color: var(--bg-gray);
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.production h3 {
  text-align: left;
}

.production h3 + p {
  color: hsla(205, 44%, 8%, 0.74);
}

.production p {
  text-align: left;
  padding-bottom: 24px;
}

.production .swiper {
  width: 100%;
  padding-bottom: 80px;
}

.production__swiper {
  position: relative;
}

.production__swiper .swiper-slide {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 480px;
}

.production__swiper .swiper-slide img {
  width: 100%;
  height: auto;
  max-width: 480px;
  max-height: 480px;
  aspect-ratio: 1/1;
  /* Сохраняет пропорции */
  object-fit: cover;
  /* Заполнение области */
  border-radius: 10px;
}

.production__swiper .divider {
  height: 2px;
  width: calc(100% - 138px);
  background-color: #0000001A;
  position: absolute;
  bottom: 28px;
  left: 0;
  border-radius: 10px;
}

.production__swiper .swiper-scrollbar-drag {
  background: #02A750;
}

.production__swiper .production__swiper-button-next,
.production__swiper .production__swiper-button-prev {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: auto;
  bottom: 0px;
}

.production__swiper .production__swiper-button-next {
  right: 0px;
}

.production__swiper .production__swiper-button-prev {
  right: 72px;
  left: auto;
}

.production__swiper [class^="swiper-button-"]::after {
  content: "";
}

@media (min-width: 1080px) {
  .production {
    width: 100%;
    margin: 100px auto;
    padding: 0 40px;
  }

  .production h2,
  .production h3,
  .production p {
    text-align: left;
    max-width: 1070px;
  }
}
@media (min-width: 1579px) {
  .production__swiper .production__swiper-button-prev,
  .production__swiper .production__swiper-button-next   {
    display: none;
  }
}

@media (min-width: 1920px) {
  .production {
    max-width: 1760px;
    margin: 140px auto;
    padding: 0;
  }
}

@media (min-width: 2560px) {
  .production {
    max-width: 2240px;
    margin: 180px auto;
  }
}

/* cycle */
.cycle {
  color: white;
  padding: 100px 20px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

@media (max-width: 374px) {
  .cycle  {
    overflow-x: hidden;
  }
}

.cycle__image {
  text-align: center;
  background-image: url('./images/cycle.png');
  width: 350px;
  height: 292px;
  align-self: self-start;
  background-image: url('./images/cycle.png');
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  background-size: 340px 282px;
}

.cycle__image-text {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.cycle__stages {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cycle__stages-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 8px;
  align-items: start;
}

.cycle__stages-item__number {
  background: transparent;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  border: 1px solid var(--white-stroke);
  color: white;
  font-weight: bold;
  font-size: 16px;
  flex-grow: 1;
}

.cycle__stages-item__card {
  max-width: 350px;
  border: 1px solid var(--white-stroke);
  border-radius: 10px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cycle__stages-item__card h3,
.cycle__stages-item__card h4 {
  text-align: left;
}

.cycle__stages-item__card-subtitle {
  color: white;
}

.cycle__stages-item__card-text {
  color: var(--text-white-secondary);
}

.cycle__stages-item__card a {
  color: #B3CE34;
  font-size: 12px;
}

.cycle__stages-item__card a:visited {
  color: #B3CE34;
}

.cycle h2,
.cycle h3,
.cycle h4 {
  text-align: left;
}

@media (min-width: 720px) {
  .cycle__stages-item {
    justify-content: center;
  }
}

@media (min-width: 1080px) {
  .cycle {
    max-width: 1760px;
    width: 100%;
    margin: 100px auto;
    padding: 0 40px;
    flex-direction: row;
    justify-content: space-between;
  }

  .cycle h2,
  .cycle h3,
  .cycle h4 {
    text-align: left;
  }

  .cycle__image {
    width: 430px;
    height: 400px;
    align-self: self-start;
    background-image: url('./images/cycle.png');
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    background-size: 400px 340px;
    position: sticky;
    top: 100px;
  }

  .cycle__image-text {
    display: flex;
    flex-direction: column;
    gap: 35px;
    text-align: left;
  }

  .cycle__stages {
    flex-direction: column;
    gap: 24px;
  }

  .cycle__stages-item__number {
    width: 48px;
    height: 48px;
    font-size: 20px;
  }

  .cycle__stages-item__card {
    max-width: 520px;
    padding: 32px;
    gap: 16px;
  }
}

@media (min-width: 1400px) {
  .cycle__image {
    width: 534px;
    height: 500px;
    background-size: 534px 447px;
  }

  .cycle__stages-item__card {
    max-width: 736px;
  }
}

@media (min-width: 1920px) {
  .cycle {
    margin: 140px auto;
    padding: 0;
  }
}
@media (min-width: 2560px) {
  .cycle {
    max-width: 2240px;
    margin: 180px auto;
  }
}

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

.white {
  background-color: white;
}

/* sertification */
.sertification {
  background-color: var(--bg-gray);
  padding: 100px 20px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.sertification h3 {
  text-align: left;
}

.sertification__content--wrapper {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.sertification__content--wrapper > p {
  color: var(--text-black-secondary);
  text-align: left;
  margin-bottom: 40px;
}

.sertification__swiper--wrapper {
  background-color: #0000000F;
  border-radius: 16px;
  padding: 100px 38px;
  max-width: 626px;
  overflow: hidden;
}

.sertification__swiper {
  width: 240px;
  height: 370px;
  user-select: none;
}

.sertification__swiper .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
}

.sertification__swiper .swiper-slide img {
  width: 230px;
  height: 360px;
}

.sertification__swiper .image-card {
  height: 360px;
  width: 240px;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sertification__info {
  display: flex;
  flex-direction: column;
  gap: 24px;
  border: 1px solid var(--black-stroke);
  border-radius: 10px;
  padding: 24px;
  max-width: 472px;
  margin-bottom: 40px;
}

.sertification__info-icon {
  width: 36px;
  height: 36px;
  background-color: #2EB049;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
}

.sertification__info-icon img {
  width: 14px;
  height: 14px;
}

.sertification__info-text {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.sertification__info-text h4 {
  text-align: left;
  font-size: 20px;
}

.sertification__info-text p {
  text-align: left;
  max-width: 408px;
  color: var(--text-black-secondary);
}

@media (min-width: 1080px) {
  .sertification {
    max-width: 1760px;
    margin: 100px auto;
    padding: 0 40px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }

  .sertification h2,
  .sertification h3 {
    text-align: left;
  }

  .sertification__content--wrapper>p {
    margin-bottom: 56px;
    max-width: 472px;
  }

  .sertification__info {
    justify-content: center;
  }

  .sertification__info-text {
    width: 600px;
  }

  .sertification__info-text h4 {
    font-size: 20px;
  }

  .sertification__swiper--wrapper {
    min-width: 500px;
    padding: 150px 38px;
  }

  .sertification__swiper {
    width: 280px;
    height: 408px;
    margin-bottom: 40px;
  }

  .sertification__swiper .swiper-slide img {
    width: 270px;
    height: 400px;
  }

  .sertification__swiper .image-card {
    height: 408px;
    width: 280px;
  }
}

@media (min-width: 1400px) {
  .sertification__swiper--wrapper {
    min-width: 626px;

  }

  .sertification__content--wrapper>p {
    max-width: 700px;
  }
}

@media (min-width: 1920px) {
  .sertification {
    padding: 0;
    margin: 140px auto;
  }
}
@media (min-width: 2560px) {
  .sertification {
    max-width: 2240px;
    margin: 180px auto;
  }
}

/* about */
.about {
  width: 100%;
  padding: 100px 20px;
  background-color: var(--bg-gray);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

.about h2,
.about h3 {
  text-align: left;
}

.about__contacts {
  display: flex;
  flex-direction: column;
  gap: 48px;
  width: 100%;
}

.about__contacts--left {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.about__contacts-info {
  color: var(--text-black-secondary);
}
.about__contacts--right {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.about__contacts-label {
  color: var(--text-black-secondary);
}

.about__contacts-number {
  font-size: 22px;
  font-weight: bold;
}

.about__form {
  background-color: white;
  border-radius: 10px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 2px 4px 10px rgba(0, 0, 0, 0.25);
}

.about__form .button {
  width: 131px;
  background-color: var(--primary) !important;
}

.about__form-field {
  display: flex;
}

.about__form-field p {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 20px;
}

.about__form-field input {
  border: 1px solid var(--bg-gray);
  border-radius: 3px;
  width: 100%;
  height: 46px;
  padding: 16px;
  transition: .3s ease;
  font-size: 18px;
}

.about__form-field textarea {
  width: 100%;
  padding: 12px;
  resize: none;
}

.about__form-field input:focus {
  border-color: var(--bg-black);
}

.wpcf7-form br {
  display: none !important;
}
.about__contacts--item {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.about__contacts--item p {
  display: flex;
  gap: 20px;
}

@media (min-width: 1080px) {
  .about {
    margin: 100px auto;
    padding: 0 40px;
    max-width: 1760px;
    flex-direction: row;
    justify-content: space-between;
  }

  .about__contacts {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    /* align-items: center; */
    gap: 20px;
  }

  .about__form {
    width: 500px;
    padding: 40px;
  }

  .about__form .button {
    width: 157px;
    background-color: var(--primary) !important;
  }

  .about__contacts-label {
    /* margin-bottom: 15px; */
  }

  .about__contacts-number {
    font-style: 32px;
    line-height: 42px;
    display: flex;
    gap: 20px;
  }
  

  .about__contacts-info {
    width: 450px;
  }
  .about__contacts--right {
    width: 40%;
  }
}

@media (min-width: 1920px) {
  .about {
    margin: 140px auto;
    padding: 0;
  }
  .about__contacts-info {
    width: 500px;
  }
}
@media (min-width: 2560px) {
  .about {
    max-width: 2240px;
    margin: 180px auto;
  }
}

/* footer */
.footer {
  padding: 100px 20px 48px;
  color: white;
  background-color: var(--bg-black);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.footer__logo {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer__logo img {
  width: 120px;
  height: 35px;
}

.footer__links {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 32px;
}

.footer__link {
  min-width: calc(50% - 16px);
}

.footer__link p {
  margin-bottom: 24px;
}

.footer__link ul {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.footer__link ul li .text-L {
  color: var(--text-white-secondary);
}

.footer_copyright {
  text-align: left;
  color: var(--text-white-secondary);
}

.footer__privacy-policy {
  padding: 0 20px 48px;
}
.footer__privacy-policy {
  color: var(--text-white-secondary);
}
.footer-menu-item.disabled {
  cursor: not-allowed;
}
.footer-menu-item.disabled a {
  cursor: not-allowed;
  pointer-events: none;
  opacity: .7;
}

@media (min-width: 1080px) {
  .footer {
    margin: 100px auto 60px;
    padding: 0 40px;
    flex-direction: row;
    justify-content: space-between;
    /* gap: 200px; */
  }

  .footer__logo {
    min-width: 290px;
  }
  .footer__link.is-grid {
    min-width: 290px;
  }
  .footer__link.is-grid-2 {
    min-width: 263px;
  }
  .footer__link.is-grid ul{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr; /* Три равные колонки */
    gap: 6px 24px; 
  }
  .footer__link.is-grid-2 ul {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Три равные колонки */
    gap: 6px 24px; 
  }

  .footer__logo img {
    width: 200px;
    height: 50px;
  }

  .footer__links {
    display: grid;
    grid-template-columns: auto auto auto;
    gap: 100px;
  }
  .footer__privacy-policy {
    padding: 0 40px 48px;
  }
}

@media (min-width: 1920px) {
  .footer {
    margin: 140px auto 60px;
    padding: 0;
  }
  .footer__link.is-grid ul{
    gap: 8px 32px; 
  }
  .footer__link ul {
    gap: 8px;
  }
  .footer__privacy-policy {
    padding: 0 0 48px;
  }
}


@media (min-width: 2560px) {
  .footer {
    max-width: 2240px;
    margin: 180px auto 60px;
  }
  .footer__link.is-grid ul{
    gap: 8px 48px; 
  }
}

/* privacy */
.privacy-policy {
  padding: 40px 20px 100px;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.privacy-policy__header {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.privacy-policy__header h3 {
  text-align: left;
}
.privacy-policy__content h4{
  text-align: left;
  margin-bottom: 16px;
}

.privacy-policy__content a {
  color: #02A750;
}

@media (min-width: 1080px) {
  .privacy-policy {
    margin: 100px 0 0;
    padding: 60px 40px 100px;
  }
}
@media (min-width: 1920px) {
  .privacy-policy {
    max-width: 1760px;
    margin: 160px auto 140px;
    padding: 0;
  }
  
}
@media (min-width: 2560px) {
  .privacy-policy {
    max-width: 2240px;
    margin: 200px auto 190px;
  }
}

/* cookies */

.cookie {
  display: none;
  position: fixed;
  top: auto;
  bottom: 24px;
  left: 0;
  right: 0;
  z-index: 9999999;
  animation: fadeInUp 0.5s ease-out;
  margin: 0 20px 24px;
}

.cookie a{
  color: #02A750;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(100px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.cookie__wrapper {
  max-width: 1760px;
  margin: 0 auto;
  background: white;
  border-radius: 10px;
  padding: 24px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}
.cookie__wrapper .text-L {
  max-width: 1000px;
}
.cookie__wrapper .button {
  min-width: 120px;
}

@media (min-width: 1080px) {
  .cookie {
    margin: 0 40px;
  }

  .cookie__wrapper {
    padding: 24px 40px;
  }
}
@media (min-width: 2560px) {
  .cookie__wrapper {
    max-width: 2240px;
  }
}


/* fix bugs IOS swiper */

.swiper-wrapper {
  /* transform: translate3d(0, 0, 0) !important; */
  /* backface-visibility: hidden; */

  -webkit-transform-style: preserve-3d; /* Фикс для iOS */
  -webkit-backface-visibility: hidden; /* Предотвращает артефакты */
}

/* modal */

.modal {
  display: none;
  position: fixed;
  z-index: 9999;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.7);
  align-items: center; /* Вертикальное центрирование */
  justify-content: center;
}

.modal-content {
  background-color: #EEEEEF;
  padding: 24px 12px;
  width: 80%;
  max-width: 840px;
  border-radius: 10px;
  position: relative;
  max-height: 80vh;
  overflow-y: auto;
}
.modal-content h4 {
  text-align: left;
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.modal-content .close {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
}

.modal-form {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.modal-form--item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.modal-form--files {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.modal-form--file {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
}

.modal-form--file {
  border: 1px solid #0C171F1A;
  padding: 10px 24px;
  border-radius: 10px;
  color: #0C171FBD;
  position: relative;
  transition: .3s ease;
}
.modal-form--file.downloaded {
  background-color: var(--primary);
  color: white;
}
.modal-form--file:hover {
  color: white;
  background-color: var(--primary);
}
.modal-form--file.downloaded .text-L {
  color: white;
}
.modal-form--file:hover .text-L {
  color: white;
}

.modal-form--file .text-L {
  color: #0C171FBD;
}

.modal-form--file__icon {
  width: 24px;
  height: 24px;
}
.modal-form--file__icon:hover + .modal-form--file__description {
  display: block;
  color: #0C171FBD;
}
.modal-form--file__description {
  display: none;
  position: absolute;
  background-color: #FFFFFF;
  padding: 4px 16px;
  text-align: center;
  top: 60px;
  border-radius: 10px;
  border: 1px solid #0C171F1A;
  z-index: 1;
}

@media (min-width: 1080px) {
  .modal-content {
    padding: 40px;
  }
}

/* soon */

.soon {
  min-height: calc(100vh - 70px);
  padding: 24px 16px 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.soon__content {
  display: flex;
  flex-direction: column;
  gap: 100px;
}
.soon__left {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.soon__left h3 {
  text-align: left;
}

.soon__left .button {
  align-self: flex-start;
}

.soon__blocks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  overflow: hidden;
}

.soon__block {
  background: #D8D8D8;
  border-radius: 4px;
  height: 14px;
  position: relative;
  overflow: hidden;
  transition: all 0.5s ease;
  opacity: 0;
  /* transform: translateY(10px); */
  animation: fadeIn 0.5s forwards;
}

.soon__block.soon__block-3 {
  width: 139px;
  animation-delay: 0.6s;
}
.soon__block.soon__block-2 {
  width: 179px;
  animation-delay: 0.4s;
}
.soon__block.soon__block-1 {
  width: 262px;
  animation-delay: 0.2s;
}

@keyframes fadeIn {
  to {
    opacity: 1;
    /* transform: translateY(0); */
  }
}

/* Анимация бегущего луча */
.soon__block::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 20%;
  height: 100%;
  background: linear-gradient(90deg, 
              rgba(255,255,255,0) 0%, 
              rgba(255,255,255,0.4) 50%, 
              rgba(255,255,255,0) 100%);
  transform: skewX(-20deg);
  opacity: 0;
}

/* Последовательная анимация для каждого блока */
.soon__block-1::after {
  animation: shine 3s infinite;
}
.soon__block-2::after {
  animation: shine 3s infinite 1s;
}
.soon__block-3::after {
  animation: shine 3s infinite 2s;
}

@keyframes shine {
  0% { 
    left: -100%;
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% { 
    left: 100%;
    opacity: 0;
  }
}

.soon__right {
  border-radius: 10px;
  background-color: #0000000F;
  width: 100%;
  height: 229px;
  display: flex;
  align-items: flex-end;
}

.soon__circles {
  display: flex;
  gap: 7px;
  padding: 24px;
}

.soon__circle {
  height: 14px;
  width: 14px;
  background-color: #0000001A;
  border-radius: 50%;
    animation: pulse 1.5s infinite ease-in-out;
  transform: scale(1);
  opacity: 0.6;
}
/* Последовательная анимация для каждого круга */
.soon__circle:nth-child(1) {
  animation-delay: 0s;
}
.soon__circle:nth-child(2) {
  animation-delay: 0.5s;
}
.soon__circle:nth-child(3) {
  animation-delay: 1s;
}

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.6;
    background-color: #0000001A;
  }
  50% {
    transform: scale(1.3);
    opacity: 1;
    background-color: #00000033;
  }
}

.soon__slides {
  display: flex;
  gap: 8px;
  justify-content: space-between;
}

.soon__slide {
  width: 100%;
  height: 50px;
  background-color: #0000000F;
  border-radius: 8px;
}

@media (min-width: 1080px) {
  .soon {
    margin: 104px auto 0;
    padding: 24px 40px 40px;
    gap: 24px;
    max-width: 1760px;
  }
  .soon__content {
    flex-direction: row;
    align-items: center;
  }
  .soon__right {
    min-width: 550px;
    height: 483px;
  }
  .soon__slide {
    height: 173px;
  }
}

@media (min-width: 1920px) {
  .soon {
    margin: 114px auto 0;
    padding: 24px 0 40px;
  }
  .soon__content {
    gap: 200px;
  }
  .soon__right {
    height: 708px;
  }
}

@media (min-width: 2560px) {
  .soon {
    max-width: 2240px;
  }
  .soon__right {
    height: 1055px;
  }
}

/* error-404 */
.error-404 {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 16px;
}
.error-404 svg {
  width: 100%;
  max-width: 100%;
}

.error-404 p {
  color: #0C171FBD;
  text-align: center;
}
.error-404__2560 {
  display: none;
}

@media (min-width: 1080px) {
  .error-404__mobile {
    display: none;
  }
  .error-404__2560 {
    display: block;
  }
}

/* notifications */

.notification {
  display: none;
  position: fixed;
  top: auto;
  bottom: 24px;
  left: 0;
  right: 0;
  z-index: 9999;
  animation: fadeInUp 0.5s ease-out;
  margin: 0 20px 24px;
  pointer-events: none;
}

.notification__wrapper {
  max-width: 1760px;
  margin: 0 auto;
  background: white;
  border-radius: 10px;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.notification.visible {
  opacity: 1;
  transform: translateY(0);
}

@media (min-width: 1080px) {
  .notification {
    margin: 0 40px;
  }

  .notification__wrapper {
    padding: 24px 40px;
  }
}
@media (min-width: 2560px) {
  .notification__wrapper {
    max-width: 2240px;
  }
}