@charset "UTF-8";
/* stylelint-disable  -- mixins support is somewhat bad*/

@font-face {
  font-family: "Roboto";
  src: url("../fonts/Roboto/RobotoVariable.ttf") format("truetype");
}
@font-face {
  font-family: "Rubik";
  src: url("../fonts/Rubik/RubikVariable.ttf") format("truetype");
}

html {
  box-sizing: content-box;
  height: 100%;
  color: #2b2a29;
  font-family: Roboto, sans-serif;
  /* font-weight: 300; */
  font-size: 16px;
  font-smooth: always;
  -webkit-font-smoothing: subpixel-antialiased;
  font-synthesis: style !important;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus {
  box-shadow: 0 0 0 1000px #fff inset !important;
}

button {
  margin: 0;
  outline: none;
  border: none;
  background: none;
  padding: 0;
  user-select: none;
}

span.bold {
  font-weight: 500;
}

main {
  width: 100%;
}

input,
textarea {
  border: 0;
  padding: 0;
}
input:active,
textarea:active {
  outline: 0;
  border: 0;
}
input:focus,
textarea:focus {
  outline: 0;
  border: 0;
}

#page-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  transition: opacity 0.2s ease-in-out;
  height: 100%;
  font-weight: 300;
  -webkit-tap-highlight-color: transparent;
}
body::-webkit-scrollbar {
  width: 0;
}
body.dialog {
  overflow: hidden;
}
body.active {
  overflow: hidden;
}

.backdrop.active {
  position: fixed;
  inset: 0;
  z-index: 110;
  background-color: rgba(0, 0, 0, 0.3);
  cursor: pointer;
}

[id$=anchor] {
  scroll-margin-top: 150px !important;
}
@media screen and (width <= 768px) {
  [id$=anchor] {
    scroll-margin-top: 75px !important;
  }
}

section {
  display: flex;
  align-self: center;
  margin-bottom: 100px;
  width: 100%;
  max-width: 1300px;
}
@media screen and (width <= 1280px) {
  section {
    margin-bottom: 60px;
    padding: 0 24px;
  }
}
@media screen and (width <= 768px) {
  section {
    margin-bottom: 70px;
    padding: 0 16px;
  }
}

*,
*::after,
*::before {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  scroll-behavior: smooth;
}

pre {
  height: fit-content;
  font: 300 1.0625rem/160% Roboto, sans-serif;
}

ul {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
}

.error-heading {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
  justify-content: center;
  margin-bottom: 60px;
}
@media screen and (width <= 680px) {
  .error-heading {
    margin-bottom: 40px;
  }
}

.main-page {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  padding: 0 24px;
  max-width: 1348px;
}
.main-page .bottom-spacer {
  width: 100%;
  min-height: 75px;
}
@media screen and (width <= 768px) {
  .main-page .bottom-spacer {
    min-height: 40px;
  }
}
@media screen and (width <= 1280px) {
  .main-page {
    padding: 0;
  }
}

.hero-section {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  height: 544px;
  min-height: 544px;
  color: white;
}
.hero-section .registration-call {
  display: flex;
  flex-direction: column;
  flex-shrink: 1.52;
  border-radius: 30px;
  background-color: #2b2a29;
  padding: 45px 45px 50px;
  width: 42%;
  height: 100%;
}
.hero-section .registration-call__header {
  display: flex;
  flex-direction: column;
}
.hero-section .registration-call__header span {
  font: 350 3.125rem/120% Roboto, sans-serif;
}
.hero-section .registration-call__header .grayed {
  opacity: 0.6;
}
@media screen and (width <= 1280px) {
  .hero-section .registration-call__header span {
    line-height: 120%;
    font-size: 2.5rem;
  }
}
.hero-section .registration-call__content {
  margin-top: auto;
  margin-bottom: 28px;
  white-space: pre;
  font: 300 1.0625rem/160% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
@media screen and (width <= 1280px) {
  .hero-section .registration-call__content {
    width: 100%;
    white-space: unset;
    font-size: 1rem;
    white-space-collapse: unset;
  }
}
@media screen and (width <= 768px) {
  .hero-section .registration-call__content {
    white-space: initial;
  }
}
.hero-section .registration-call__footer .button-container {
  letter-spacing: 0.02em;
}
@media screen and (width <= 1280px) {
  .hero-section .registration-call__footer .button-container {
    width: 100%;
  }
}
@media screen and (width <= 1280px) {
  .hero-section .registration-call {
    flex-shrink: unset;
    border-radius: 20px;
    padding: 25px;
    width: 50%;
  }
}
.hero-section .community-banner {
  display: flex;
  position: relative;
  flex-direction: column;
  border-radius: 30px;
  /* Картинки обрезать не нужно, все уже подготовлено, просто грузите прямоугольной */
  background-image: url("../img/hero-image.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  width: 58%;
  height: 100%;
}
.hero-section .community-banner__decor {
  display: flex;
  width: fit-content;
  height: fit-content;
}
.hero-section .community-banner__top-left-round, .hero-section .community-banner__top-right-round {
  position: absolute;
  overflow: hidden;
}
.hero-section .community-banner__top-left-round {
  top: 146px;
}
@media screen and (width <= 1280px) {
  .hero-section .community-banner__top-left-round {
    top: 72px;
  }
}
@media screen and (width <= 768px) {
  .hero-section .community-banner__top-left-round {
    top: 72px;
  }
}
.hero-section .community-banner__top-right-round {
  left: 157px;
}
@media screen and (width <= 1280px) {
  .hero-section .community-banner__top-right-round {
    left: 77px;
  }
}
.hero-section .community-banner__action {
  display: flex;
  align-items: center;
  margin: 0 0 45px 45px;
  margin-top: auto;
}
.hero-section .community-banner__action .button-container {
  font-weight: 400;
}
@media screen and (width <= 1280px) {
  .hero-section .community-banner__action {
    margin: auto 25px 25px;
  }
  .hero-section .community-banner__action .button-container {
    width: 100%;
  }
}
.hero-section .community-banner .img-container {
  border-radius: 30px;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.hero-section .community-banner .img-container img {
  object-fit: contain;
}
.hero-section .community-banner__decor-container {
  display: flex;
  position: absolute;
  align-items: center;
  justify-content: center;
  z-index: 1;
  border-bottom-right-radius: 50%;
  background-color: white;
  padding-right: 10px;
  padding-bottom: 10px;
}
.hero-section .community-banner__decor-container svg {
  width: 147px;
  height: 136px;
}
@media screen and (width <= 1280px) {
  .hero-section .community-banner__decor-container svg {
    width: 67px;
    height: 62px;
  }
}
@media screen and (width <= 1280px) {
  .hero-section .community-banner {
    width: 50%;
  }
}
@media screen and (width <= 1280px) {
  .hero-section {
    gap: 15px;
    height: 382px;
    min-height: 382px;
  }
}
@media screen and (width <= 768px) {
  .hero-section {
    flex-direction: column;
    height: unset;
    min-height: unset;
  }
  .hero-section .registration-call {
    width: 100%;
  }
  .hero-section .registration-call__content {
    padding-top: 20px;
  }
  .hero-section .community-banner {
    width: 100%;
    height: 350px;
    min-height: 350px;
  }
}
@media screen and (width <= 1280px) {
  .hero-section {
    margin-bottom: 60px;
  }
}
@media screen and (width <= 768px) {
  .hero-section {
    margin-bottom: 40px;
  }
}
@media screen and (width <= 540px) {
  .hero-section .registration-call {
    width: 100%;
    height: 100%;
  }
  .hero-section .community-banner {
    width: 100%;
    height: 250px;
    min-height: 250px;
  }
}

.statistics-section {
  display: grid;
  grid-template-columns: 2.4fr 1fr;
  gap: 100px;
  margin-bottom: 100px;
  height: fit-content;
  color: black;
}
.statistics-section .info-banner {
  display: flex;
  flex-direction: column;
  border-radius: 30px;
  background-color: #f6f6f6;
  background-image: url("../img/svg/statistics-decor.svg");
  background-position: 85% 50px;
  background-repeat: no-repeat;
  background-size: 284px 425px;
  padding: 50px;
  width: 100%;
  height: 510px;
}
.statistics-section .info-banner__header {
  display: flex;
  flex-direction: column;
  gap: 3px;
  width: 50%;
  color: #2b2a29;
}
.statistics-section .info-banner__header__title {
  font: 500 2.5rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .statistics-section .info-banner__header__title {
    font-size: 1.875rem;
  }
}
.statistics-section .info-banner__header__text {
  white-space: pre;
  font: 350 1.4375rem/160% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
@media screen and (width <= 1280px) {
  .statistics-section .info-banner__header__text {
    font-size: 1.25rem;
  }
}
@media screen and (width <= 768px) {
  .statistics-section .info-banner__header__text {
    white-space: inherit;
    white-space-collapse: initial;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section .info-banner__header {
    width: 100%;
  }
}
.statistics-section .info-banner__footer {
  margin-top: auto;
  color: #f00;
  font: 600 6rem/135% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .statistics-section .info-banner__footer {
    font: 600 3.75rem/135% Roboto, sans-serif;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section .info-banner {
    border-radius: 20px;
    padding: 25px;
    height: 100%;
  }
}
@media screen and (width <= 1024px) {
  .statistics-section .info-banner {
    background-position: 120% 113%;
    background-size: 252px 376px;
  }
}
@media screen and (width <= 640px) {
  .statistics-section .info-banner {
    background-position: 120% 113%;
    background-size: 169px 252px;
    height: 382px;
  }
}
.statistics-section .statistics {
  display: flex;
  gap: 40px;
  height: 100%;
}
.statistics-section .statistics__decor {
  display: grid;
  position: relative;
  grid-template-rows: 1.7fr 1.8fr 1fr;
  grid-template-columns: 23px;
  grid-auto-flow: column;
  padding-top: 32px;
  width: 23px;
}
.statistics-section .statistics__decor-circle {
  z-index: 1;
  border-radius: 50%;
  background-color: #2b2a29;
  width: 23px;
  height: 23px;
}
.statistics-section .statistics__decor-circle.highlight {
  background-color: #f00;
}
.statistics-section .statistics__decor-line {
  position: absolute;
  top: 40px;
  left: 50%;
  border-right: 1.5px dashed #2b2a29;
  width: 0;
  height: calc(100% - 40px);
  overflow: visible;
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics__decor {
    grid-template-rows: 1.55fr 1.7fr 1fr;
  }
}
.statistics-section .statistics__info-container {
  display: flex;
  flex-direction: column;
  gap: 48px;
  justify-content: space-between;
}
.statistics-section .statistics__info-container .statistics_info {
  display: flex;
  flex-direction: column;
  gap: 15px;
  border-radius: 30px;
  padding: 0 25px 0 35px;
  width: 100%;
}
.statistics-section .statistics__info-container .statistics_info .header {
  display: flex;
  flex-direction: column;
}
.statistics-section .statistics__info-container .statistics_info .header .subtle {
  opacity: 0.4;
  color: #2b2a29;
  font: 350 1rem/120% Roboto, sans-serif;
}
.statistics-section .statistics__info-container .statistics_info .header .number {
  color: #2b2a29;
  font: 600 2.5rem/135% Roboto, sans-serif;
}
.statistics-section .statistics__info-container .statistics_info .header .subtitle {
  color: #2b2a29;
  font: 600 1.0625rem/130% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics__info-container .statistics_info .header .subtle {
    line-height: 160%;
  }
  .statistics-section .statistics__info-container .statistics_info .header .number {
    font: 600 1.875rem/135% Roboto, sans-serif;
  }
}
.statistics-section .statistics__info-container .statistics_info.highlight {
  background-color: #2b2a29;
  padding: 35px 55px 35px 35px;
}
.statistics-section .statistics__info-container .statistics_info.highlight .number {
  color: white;
}
.statistics-section .statistics__info-container .statistics_info.highlight .subtitle {
  color: white;
}
.statistics-section .statistics__info-container .statistics_info.highlight .subtle {
  opacity: 0.4;
  color: white;
}
.statistics-section .statistics__info-container .statistics_info.highlight .content {
  color: white;
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics__info-container .statistics_info.highlight {
    padding: 25px;
  }
}
.statistics-section .statistics__info-container .statistics_info .content {
  opacity: 0.7;
  white-space: pre;
  color: #2b2a29;
  font: 400 1.0625rem/130% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
@media (min-device-pixel-ratio: 2), (resolution >= 192dpi) {
  .statistics-section .statistics__info-container .statistics_info .content {
    font-weight: 350;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics__info-container .statistics_info {
    border-radius: 20px;
    padding-left: 25px;
  }
}
@media screen and (width <= 768px) {
  .statistics-section .statistics__info-container .statistics_info {
    font-weight: 350;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics__info-container {
    gap: 30px;
    width: 100%;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section .statistics {
    gap: 30px;
  }
}
@media screen and (width >= 640px) and (width <= 700px) {
  .statistics-section .statistics {
    gap: 5px;
  }
}
@media screen and (width <= 1280px) {
  .statistics-section {
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-bottom: 70px;
  }
}
@media screen and (width >= 640px) and (width <= 700px) {
  .statistics-section {
    gap: 5px;
  }
}
@media screen and (width <= 640px) {
  .statistics-section {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }
}

.about-section {
  display: flex;
  flex-direction: column;
  height: fit-content;
  color: black;
}
.about-section .section-header {
  display: flex;
  flex-direction: column;
  margin-bottom: 30px;
}
.about-section .section-header__title {
  margin-bottom: 3px;
  color: #2b2a29;
  font: 500 2.5rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .about-section .section-header__title {
    margin-bottom: 10px;
    font: 500 1.875rem/115% Roboto, sans-serif;
  }
}
.about-section .section-header__subtitle {
  color: #2b2a29;
  font: 400 1.4375rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .about-section .section-header__subtitle {

    white-space-collapse: preserve-breaks;
    font: 400 1.25rem/160% Roboto, sans-serif;
  }
}
@media (min-device-pixel-ratio: 2), (resolution >= 192dpi) {
  .about-section .section-header__subtitle {
    font-weight: 350;
  }
}
.about-section .employee-card-list {
  display: flex;
  flex-direction: column;
  gap: 55px;
}
.about-section .employee-card-list-mobile {
  display: none;
}
@media screen and (width <= 1280px) {
  .about-section .employee-card-list {
    display: none;
  }
  .about-section .employee-card-list-mobile {
    display: flex;
  }
  .about-section .employee-card-list-mobile .swiper-slide {
    width: 327px;
  }
}

#community-anchor {
  scroll-margin-top: 150px;
}
@media screen and (width < 768px) {
  #community-anchor {
    scroll-margin-top: 100px;
  }
}

.community-section {
  display: flex;
  flex-direction: column;
  height: fit-content;
  overflow: hidden;
  color: #2b2a29;
  /* черная магия, цифры подобраны на глаз, по идее должно быть 16px - размер левого отступа, 
  но почему-то так остается небольшое дергание  */
}
.community-section .section-header {
  display: flex;
  flex-direction: column;
  margin-bottom: 30px;
}
.community-section .section-header__title {
  margin-bottom: 3px;
  color: #2b2a29;
  font: 500 2.5rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .community-section .section-header__title {
    margin-bottom: 10px;
    font: 500 1.875rem/115% Roboto, sans-serif;
  }
}
.community-section .section-header__features-container {
  display: flex;
  gap: 20px;
}
.community-section .section-header__features-container .features {
  display: flex;
  flex-wrap: nowrap;
  gap: 40px;
  align-items: center;
  justify-content: space-between;
  width: max-content;
  width: 100%;
  overflow: auto;
}
.community-section .section-header__features-container .features.features-double {
  display: none;
}
.community-section .section-header__features-container .features .feature {
  position: relative;
  opacity: 0.7;
  min-width: max-content;
  overflow: visible;
  color: #2b2a29;
  font: 400 1rem/160% Roboto, sans-serif;
}
.community-section .section-header__features-container .features .feature::before {
  position: absolute;
  top: 50%;
  left: -10px;
  transform: translateY(-50%) translateX(-100%);
  border-radius: 50%;
  background-color: #f00;
  width: 8px;
  height: 8px;
  content: "";
}
.community-section .section-header__features-container .features .feature.main {
  margin-right: 20px;
}
.community-section .section-header__features-container .features .feature.main::after {
  display: flex;
  position: absolute;
  top: 50%;
  right: -10px;
  align-items: center;
  transform: translateY(-50%) translateX(100%);
  width: 8px;
  height: 10px;
  content: url("../img/svg/small-arrow.svg");
}
.community-section .section-header__features-container .features .feature.main::before {
  display: none;
}
@media (min-device-pixel-ratio: 2), (resolution >= 192dpi) {
  .community-section .section-header__features-container .features .feature {
    font-weight: 350;
  }
}
/*@media screen and (width <= 768px) {*/
  .community-section .section-header__features-container .features.features-double {
    display: flex;
    padding-right: 150px;
    width: max-content;
  }
/*}*/
/*@media screen and (width <= 768px) {*/
  .community-section .section-header__features-container {
    display: flex;
    flex-wrap: nowrap;
    width: fit-content;
    width: max-content;
    width: max-content;
    overflow: visible;
    animation: feature-animation 10s linear infinite;
  }
  .community-section .section-header__features-container .features {
    width: fit-content;
    width: max-content;
    width: max-content;
    overflow: visible;
  }
/*}*/
.community-section .community-block {
  display: flex;
  gap: 20px;
  height: 465px;
}
.community-section .community-block__video {
  position: relative;
  border-radius: 30px;
  width: 72%;
  height: 100%;
  overflow: hidden;
}
.community-section .community-block__video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.community-section .community-block__video .overlay {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  transition: 0.1s;
  z-index: 10;
  background-color: transparent;
  cursor: pointer;
  width: 100%;
  height: 100%;
  backdrop-filter: brightness(0.9);
}
.community-section .community-block__video .overlay:hover .svg-container {
  opacity: 1;
}
.community-section .community-block__video .overlay.hidden {
  display: none;
}
.community-section .community-block__video .overlay .svg-container {
  transition: 0.2s;
  opacity: 0.7;
  width: 75px;
  height: 75px;
}
@media screen and (width <= 1280px) {
  .community-section .community-block__video {
    border-radius: 20px;
    width: 66%;
  }
}
@media screen and (width <= 768px) {
  .community-section .community-block__video {
    width: 100%;
  }
}
.community-section .community-block__info {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-between;
  height: 100%;
  border-radius: 30px;
  background-color: #222;
  padding: 30px;
  padding-bottom: 40px;
  width: 28%;
}
.community-section .community-block__info .icon-button {
  display: none;
  position: absolute;
  bottom: 30px;
  right: 30px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: rgba(255, 255, 255, 0.14);
  cursor: pointer;
  width: 40px;
  height: 40px;
}
.community-section .community-block__info .icon-button:hover {
  background-color: rgba(255, 255, 255, 0.2);
}
@media screen and (width <= 1280px) {
  .community-section .community-block__info .icon-button {
    bottom: 25px;
    right: 25px;
  }
}
.community-section .community-block__info .info-footer {
  display: flex;
  flex-direction: column;
  gap: 15px;
  align-items: flex-end;
  width: 90%;
  text-align: end;
  color: white;
}
.community-section .community-block__info .info-footer .number {
  display: flex;
  gap: 8px;
  align-items: center;
  height: 28px;
  font: 500 2.5rem/100% Roboto, sans-serif;
}
.community-section .community-block__info .info-footer .number .subtle {
  opacity: 0.3;
}
@media screen and (width <= 1280px) {
  .community-section .community-block__info .info-footer .number {
    font: 500 1.875rem/100% Roboto, sans-serif;
  }
}
.community-section .community-block__info .info-footer .info-text {
  white-space-collapse: preserve-breaks;
  font: 350 1.0625rem/135% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .community-section .community-block__info .info-footer {
    align-items: start;
    text-align: start;
  }
}
@media screen and (width <= 1280px) {
  .community-section .community-block__info {
    align-items: start;
    border-radius: 20px;
    padding: 25px;
    width: 33%;
    text-align: start;
  }
}
@media screen and (width <= 768px) {
  .community-section .community-block__info {
    width: 100%;
  }
}
@media screen and (width <= 1280px) {
  .community-section .community-block {
    min-height: 368px;
    max-height: 368px;
  }
}
@media screen and (width <= 1024px) {
  .community-section .community-block {
    min-height: 268px;
    max-height: 268px;
  }
  .community-section .community-block__info .icon-button {
    display: flex;
    top: 25px;
    right: 25px;
  }
  .community-section .community-block__info .footer-button {
    display: none;
  }
  .community-section .community-block__info {
    height: fit-content;
  }
}
@media screen and (width <= 768px) {
  .community-section .community-block {
    flex-direction: column;
    gap: 15px;
    width: 100%;
    min-height: unset;
    max-height: unset;
  }
}
@keyframes feature-animation {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.socials-section {
  display: flex;
  flex-direction: column;
  height: fit-content;
  color: #2b2a29;
}
.socials-section .section-header .tag-line {
  margin-bottom: 6px;
}
@media screen and (width <= 1280px) {
  .socials-section .section-header .tag-line {
    margin-bottom: 15px;
  }
}
.socials-section .social-block {
  display: flex;
}
.socials-section .social-block__socials {
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: space-between;
}
.socials-section .social-block__socials .title {
  letter-spacing: 0;
  font: 500 2.5rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__socials .title {
    font: 500 1.875rem/115% Roboto, sans-serif;
  }
}
.socials-section .social-block__socials .socials {
  display: flex;
  gap: 20px;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__socials .socials {
    gap: 12px;
  }
}
.socials-section .social-block__socials svg,
.socials-section .social-block__socials a > svg {
  width: 90px;
  height: 90px;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__socials {
    width: min-content;
  }
  .socials-section .social-block__socials svg,
  .socials-section .social-block__socials a > svg {
    width: 58px;
    height: 58px;
  }
}
@media screen and (width <= 768px) {
  .socials-section .social-block__socials {
    gap: 30px;
    width: 100%;
  }
}
.socials-section .social-block .spacer {
  opacity: 0.7;
  margin: auto;
  margin-top: auto;
  margin-bottom: 0;
  background-color: #bfbfbf;
  width: 2px;
  height: 210px;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block .spacer {
    height: 156px;
  }
}
@media screen and (width <= 768px) {
  .socials-section .social-block .spacer {
    display: none;
  }
}
.socials-section .social-block__partnership {
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: space-between;
  padding-right: 20px;
}
.socials-section .social-block__partnership .partnerships {
  display: flex;
  gap: 20px;
}
.socials-section .social-block__partnership .partnerships .svg-container {
  border-radius: 10px;
  width: 106px;
  height: 106px;
  overflow: hidden;
}
.socials-section .social-block__partnership .partnerships .svg-container svg {
  width: inherit;
  height: inherit;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__partnership .partnerships .svg-container {
    width: 85px;
    height: 85px;
  }
}
.socials-section .social-block__partnership .title {
  letter-spacing: 0;
  font: 500 2.5rem/160% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__partnership .title {
    font: 500 1.875rem/115% Roboto, sans-serif;
  }
}
@media screen and (width <= 1280px) {
  .socials-section .social-block__partnership {
    padding-right: 40px;
  }
}
@media screen and (width <= 768px) {
  .socials-section .social-block__partnership {
    gap: 20px;
  }
}
@media screen and (width <= 768px) {
  .socials-section .social-block {
    flex-direction: column;
    gap: 30px;
  }
}
@media screen and (width <= 768px) {
  .socials-section {
    margin-bottom: 40px;
  }
}

.projects-section {
  display: flex;
  flex-direction: column;
  height: fit-content;
  color: #2b2a29;
}
.projects-section__header {
  margin-bottom: 65px;
  font: 500 2.5rem/125% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .projects-section__header {
    margin-bottom: 30px;
    font: 500 1.875rem/115% Roboto, sans-serif;
  }
}
.projects-section__content {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: space-between;
}
.projects-section__content .project-container {
  display: flex;
  align-items: center;
  justify-content: center;
}
.projects-section__content .project-container .svg-container {
  width: 150px;
  height: 160px;
}
.projects-section__content .project-container .svg-container svg {
  width: inherit;
  height: inherit;
}
.projects-section__content .project-container .img-container {
  width: 130px;
  height: 170px;
}
.projects-section__content .project-container .img-container img {
  width: inherit;
  height: inherit;
  object-fit: fill;
}
.projects-section__content .project-container .project-name {
  display: flex;
  white-space: pre;
  white-space-collapse: preserve-breaks;
  color: black;
  font: 400 1.125rem/120% Roboto, sans-serif;
}
@media (min-device-pixel-ratio: 2), (resolution >= 192dpi) {
  .projects-section__content .project-container .project-name {
    font-weight: 350;
  }
}
@media screen and (width >= 1280px) {
  .projects-section__content .project-container .project-name {
    width: 0%;
    overflow: hidden;
  }
}
@media screen and (width >= 1280px) {
  .projects-section__content .project-container:hover .project-name {
    overflow: visible;
    animation: project-name-animation 0.5s ease-in-out;
    animation-fill-mode: forwards;
  }
}
@media screen and (width <= 1280px) and (width >= 768px) {
  .projects-section__content .project-container .svg-container {
    width: 103px;
    height: 112px;
  }
  .projects-section__content .project-container .svg-container svg {
    width: inherit;
    height: inherit;
  }
  .projects-section__content .project-container .img-container {
    width: 103px;
    height: 126px;
  }
  .projects-section__content .project-container .img-container img {
    width: inherit;
    height: inherit;
    object-fit: fill;
  }
}
@media screen and (width <= 768px) {
  .projects-section__content .project-container .svg-container,
  .projects-section__content .project-container .img-container {
    width: 144px;
    height: 157px;
  }
}
@media screen and (width <= 1280px) {
  .projects-section__content .project-container {
    gap: 15px;
  }
}
@media screen and (width >= 1280px) {
  .projects-section__content {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    align-items: center;
  }
}
@media screen and (width <= 768px) {
  .projects-section__content {
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
  }
}

@keyframes project-name-animation {
  from {
    opacity: 0;
    width: 0;
  }
  to {
    opacity: 1;
    width: 120px;
  }
}
.employee-card {
  display: flex;
  gap: 20px;
}
.employee-card:nth-child(2n) {
  flex-direction: row-reverse;
}
.employee-card span.bold {
  display: contents;
  font-weight: 700;
}
.employee-card .employee-intro {
  display: flex;
  gap: 35px;
  border-radius: 30px;
  background-color: #2b2a29;
  padding: 30px 20px 30px 30px;
  width: 49%;
  height: 100%;
  min-height: 540px;
}
.employee-card .employee-intro .img-container {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  width: 50%;
  overflow: hidden;
}
.employee-card .employee-intro .img-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.employee-card .employee-intro__info {
  display: flex;
  flex-direction: column;
  width: 50%;
}
.employee-card .employee-intro__info .info-header {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.employee-card .employee-intro__info .info-header svg {
  width: 48px;
  height: 44px;
}
.employee-card .employee-intro__info .info-header .header-name {
  white-space: pre;
  color: white;
  font: 500 1.6875rem/135% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
.employee-card .employee-intro__info .info-footer {
  display: flex;
  position: relative;
  align-items: flex-end;
  margin-top: auto;
  padding-top: 22px;
}
.employee-card .employee-intro__info .info-footer::before {
  position: absolute;
  top: 0;
  background-color: #f00;
  width: 50px;
  height: 1px;
  content: "";
}
.employee-card .employee-intro__info .info-footer .footer-title {
  color: white;
  font: 300 1.0625rem/145% Roboto, sans-serif;
  font-style: italic;
}
.employee-card .card-info {
  display: flex;
  flex-direction: column;
  border-radius: 30px;
  background-color: #f6f6f6;
  padding: 30px 35px 30px 30px;
  width: 52%;
  max-height: 540px;
  color: #2b2a29;
}
.employee-card .card-info__header {
  margin-bottom: 23px;
  font: 700 1.6875rem/135% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
.employee-card .card-info__content {
  display: flex;
  flex-direction: column;
  gap: 17px;
  max-height: 450px;
  overflow: visible;
  white-space: pre;
  font: 400 1.0625rem/160% Roboto, sans-serif;
  white-space-collapse: preserve-breaks;
}
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .employee-card .card-info__content {
    font-weight: 350;
  }
}
@media screen and (width <= 1280px) {
  .employee-card .card-info__content {
    white-space: initial;
    white-space-collapse: initial;
  }
}
.employee-card .card-info__footer {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}
.employee-card .card-info__footer .footer-tag {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 21px;
  background-color: #2b2a29;
  padding: 5px 13px;
  color: white;
  font: 300 0.9375rem/160% Roboto, sans-serif;
}
.employee-card .card-info__footer .footer-button {
  font-size: 0.875rem;
}
.employee-card .expand-card {
  display: none;
  bottom: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;
  background-color: #f6f6f6;
  width: 100%;
  height: 33px;
  min-height: 33px;
}
.employee-card .expand-card.active {
  display: flex;
}
@media screen and (width <= 1280px) {
  .employee-card {
    flex-direction: column;
    gap: 0;
    width: 327px;
  }
  .employee-card.expanded .card-info {
    max-height: unset;
  }
  .employee-card.expanded .expand-card svg {
    rotate: 180deg;
  }
  .employee-card.rtl {
    flex-direction: column;
  }
  .employee-card .employee-intro {
    gap: 15px;
    border-radius: 20px;
    padding: 25px;
    width: 100%;
    height: 275px;
    min-height: unset;
  }
  .employee-card .employee-intro .img-container {
    border-radius: 10px;
    width: 100%;
    max-width: 132px;
    height: 100%;
  }
  .employee-card .employee-intro__info .info-header {
    display: flex;
    flex-direction: column;
    gap: 15px;
  }
  .employee-card .employee-intro__info .info-header svg {
    width: 35px;
    height: 35px;
  }
  .employee-card .employee-intro__info .info-header .header-name {
    font: 500 1.25rem/135% Roboto, sans-serif;
  }
  .employee-card .employee-intro__info .info-footer {
    padding-top: 10px;
  }
  .employee-card .employee-intro__info .info-footer .footer-title {
    font: 300 0.9375rem/145% Roboto, sans-serif;
    font-style: italic;
  }
  .employee-card .card-info {
    display: flex;
    position: relative;
    border-radius: 20px;
    padding: 25px;
    width: 100%;
    height: 100%;
    min-height: 620px;
    max-height: 620px;
    overflow: auto;
  }
  .employee-card .card-info__header {
    margin-bottom: 15px;
    white-space: unset;
    font: 700 1.25rem/135% Roboto, sans-serif;
    white-space-collapse: unset;
  }
}
@media screen and (width <= 1280px) and (-webkit-min-device-pixel-ratio: 2), screen and (width <= 1280px) and (min-resolution: 192dpi) {
  .employee-card .card-info__header {
    font-weight: 600;
  }
}
@media screen and (width <= 1280px) {
  .employee-card .card-info__content {
    font: 400 1rem/160% Roboto, sans-serif;
  }
}
@media screen and (width <= 1280px) {
  .employee-card .card-info__footer {
    display: flex;
    margin-top: auto;
    padding-top: 20px;
  }
  .employee-card .card-info__footer.hidden {
    display: none;
  }
}

.employee-modal {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 300;
  border-radius: 20px;
  background-color: white;
  padding: 40px;
  width: 100%;
  max-width: 500px;
  height: auto;
}
.employee-modal__close {
  position: absolute;
  top: 0;
  right: -24px;
  transform: translateX(100%);
  cursor: pointer;
  width: 24px;
  height: 24px;
}
.employee-modal__close svg {
  width: 100%;
  height: 100%;
  fill: white;
}
.employee-modal__close svg path {
  fill: white;
}
.employee-modal.active {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.employee-modal__form {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
  margin: 10px 0;
}
.employee-modal__form-input {
  display: flex;
}
.employee-modal__form-input.select {
  width: 100%;
}
.employee-modal__submit {
  margin-top: 30px;
  border-radius: 10px;
  background-color: #f00;
  width: 100%;
  height: 56px;
  color: #000;
}
@media screen and (width <= 768px) {
  .employee-modal {
    padding: 40px;
  }
  .employee-modal__close {
    top: 16px;
    right: 36px;
    width: 16px;
    height: 16px;
  }
  .employee-modal__close svg {
    width: 16px;
    height: 16px;
    stroke: #2b2a29;
    fill: #2b2a29;
  }
  .employee-modal__close svg path {
    stroke: #2b2a29;
    fill: #2b2a29;
  }
}
@media screen and (width <= 540px) {
  .employee-modal {
    padding: 40px 20px 20px;
    width: calc(100% - 40px);
  }
}

.event-modal {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  flex-direction: column;
  transform: translate(-50%, -50%);
  z-index: 300;
  border-radius: 10px;
  background-color: white;
  width: max-content;
  max-width: 930px;
  height: auto;
  max-height: 90svh;
}
.event-modal.dark {
  background-color: #2b2a29;
}
.event-modal.dark .event-modal__body .event-title {
  color: white;
}
.event-modal.dark .event-modal__body .event-subtitle {
  color: white;
}
.event-modal.dark .event-modal__body .event-info {
  color: white;
}
.event-modal__img {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  width: 100%;
  height: 472px;
  overflow: hidden;
}
.event-modal__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.event-modal__close {
  position: absolute;
  top: 0;
  right: -24px;
  transform: translateX(100%);
  cursor: pointer;
  width: 24px;
  height: 24px;
}
.event-modal__close svg {
  width: 100%;
  height: 100%;
  fill: white;
}
.event-modal__close svg path {
  fill: white;
}
.event-modal__body {
  display: flex;
  flex-direction: column;
  padding: 40px 48px;
  width: 100%;
  overflow: auto;
  max-height: 450px;
}
.event-modal__body::-webkit-scrollbar {
  width: 0;
}
.event-modal__body--title {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 32px;
}
.event-modal__body--title .event-title {
  font: 600 2.5rem/100% Rubik, sans-serif;
}
@media screen and (width <= 768px) {
  .event-modal__body--title .event-title {
    font-size: 1.75rem;
    line-height: 110%;
  }
}
.event-modal__body--title .event-subtitle {
  color: #7e8184;
  font: 600 1.25rem/140% Rubik, sans-serif;
}
@media screen and (width <= 768px) {
  .event-modal__body--title .event-subtitle {
    font-size: 1rem;
  }
}
.event-modal__body--title .event-info {
  display: flex;
  gap: 17px;
  color: #7e8184;
  font: 500 1.25rem/140% Rubik, sans-serif;
}
.event-modal__body--title .event-info > * {
  position: relative;
}
.event-modal__body--title .event-info > *::after {
  position: absolute;
  top: 50%;
  right: -8.5px;
  transform: translateY(-50%);
  background-color: #7e8184;
  width: 1px;
  height: 22px;
  content: "";
}
.event-modal__body--title .event-info > *:last-child::after {
  display: none;
}
@media screen and (width <= 768px) {
  .event-modal__body--title .event-info {
    font-size: 1rem;
  }
}
@media screen and (width <= 768px) {
  .event-modal__body {
    padding: 20px 24px;
  }
}
.event-modal.active {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.event-modal__form {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
}
.event-modal__form-input {
  display: flex;
}
.event-modal__form-input.select {
  width: 100%;
}
.event-modal .submit {
  margin-top: 32px;
  border-radius: 4px;
  background-color: #f00;
  padding: 17px 40px;
  height: 56px;
}

@media screen and (width <= 992px) {
  .event-modal {
    max-width: 90%;
  }
  .event-modal__close {
    display: flex;
    top: 10px;
    right: 10px;
    align-items: center;
    justify-content: center;
    transform: translate(0, 0);
    border-radius: 50%;
    background-color: rgba(0, 0, 0, 0.4);
    padding: 10px;
    width: 36px;
    height: 36px;
    z-index: 300;
  }
}

@media screen and (width <= 768px) {
  .event-modal {
    max-height: unset;
  }
  .event-modal__img {
    border-radius: 0;
    height: 100%;
    min-height: 30svh;
    max-height: 40svh;
  }
  .event-modal__body {
    height: 100%;
  }
  .event-modal__form {
    height: 100%;
  }

  .event-modal .submit {
    margin-top: auto;
    width: 100%;
  }
}

.form-container.dark .form-input {
  background-color: #2b2a29;
  color: white;
}
.form-container.dark .form-input .is-invalid {
  transition: box-shadow 0.2s ease-in;
  margin-bottom: 2px;
  box-shadow: 0 0 1px 2px rgb(218, 80, 99);
}
.form-container.dark .form-input input {
  color: white;
}
.form-container.dark .form-input input::placeholder {
  color: white;
}
.form-container.dark .select-input {
  background-color: #2b2a29;
}
.form-container.dark .phone-input {
  background-color: #2b2a29;
}
.form-container.dark .phone-input .iti__country-container::after {
  background-color: #2b2a29;
}
.form-container.dark .file-input label {
  background-color: #2b2a29;
}

.form-input-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.form-input-group .disclaimer {
  color: rgba(43, 42, 41, 0.5);
  font: 300 12px/140% Rubik, sans-serif;
}

.form-error,
.just-validate-error-label {
  color: red;
  font: 300 12px/140% Rubik, sans-serif;
}
.form-error.is-invalid,
.just-validate-error-label.is-invalid {
  display: flex;
  align-items: center;
  justify-content: center;
}

.form-input {
  display: flex;
  gap: 6px;
  transition: 0.2s;
  border: 1px solid #e0e3e7;
  border-radius: 4px;
  padding: 17px 16px;
  width: 100%;
  color: #000;
  font: 300 1rem/140% Rubik, sans-serif;
}
.form-input:active, .form-input:focus-within {
  border: 1px solid #999;
}
.form-input.is-invalid {
  border: 1px solid red;
}
.form-input .rtl {
  flex-direction: row-reverse;
}

input::placeholder {
  opacity: 0.7;
  color: #2b2a29;
  font: 300 1rem/140% Rubik, sans-serif;
}

select {
  display: none;
}

.select-input {
  border: 1px solid #e0e3e7;
  border-radius: 4px;
  padding: 17px 16px;
  width: 100%;
  height: auto;
  font: 300 1rem/140% Rubik, sans-serif;
}
.select-input::after {
  position: absolute;
  top: calc(50% - 12px);
  right: 16px;
  transform: rotate(0);
  transform-origin: center;
  margin-top: 0;
  border: none;
  background-color: transparent;
  width: 24px;
  height: 24px;
  content: url("../img/svg/select-arrow.svg");
}
.select-input.is-invalid + div.form-input {
  border: 1px solid red;
}
.select-input.nice-select.open::after {
  transform: rotate(0) translateY(0);
  rotate: 180deg;
}
.select-input option {
  font: 300 1rem/140% Rubik, sans-serif;
}
.select-input .current {
  font: 300 1rem/140% Rubik, sans-serif;
}
.select-input .nice-select-dropdown {
  z-index: 10;
  border: 1px solid #e0e3e7;
  border-radius: 4px;
  padding: 17px 16px;
  width: 100%;
  height: auto;
}
.select-input .nice-select-dropdown .list li {
  color: #7e8184;
  font-family: Rubik, sans-serif;
  font-size: 1rem;
}

.phone-input {
  border: 0;
  padding: 0;
}
.phone-input .iti {
  border: 1px solid #e0e3e7;
  border-radius: 4px;
  padding: 17px 16px;
  width: 100%;
}
.phone-input .iti__country-container {
  padding: 0;
}
.phone-input .iti__country-container::after {
  position: absolute;
  top: 50%;
  right: -2px;
  transform: translateY(-50%);
  z-index: 1;
  border-right: 1px solid #e0e3e7;
  border-left: 1px solid #e0e3e7;
  background-color: white;
  width: 4px;
  height: 104%;
  content: "";
}
.phone-input .iti__country-container .iti__selected-country[aria-expanded=true] .iti__selected-country-primary::after {
  transform: rotate(180deg);
}
.phone-input .iti__country-container .iti__selected-country-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 14px;
}
.phone-input .iti__country-container .iti__selected-country-primary::after {
  display: flex;
  align-items: baseline;
  justify-content: center;
  margin-left: 4px;
  width: 24px;
  height: 24px;
  content: url("../img/svg/select-arrow.svg");
}
.phone-input .iti__country-container .iti__selected-country-primary .iti__arrow {
  display: none;
}
.phone-input .iti__tel-input {
  padding-left: 80px !important;
  color: #7e8184;
  font: 300 1rem/140% Rubik, sans-serif;
}

.file-input {
  display: flex;
  position: relative;
  align-items: center;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}
.file-input .label {
  width: calc(100% - 48px);
  color: #7e8184;
  font: 300 1rem/140% Rubik, sans-serif;
}
.file-input .label.active {
  color: #2b2a29;
}
.file-input .file-icon {
  position: absolute;
  top: 0;
  right: 0;
  border-radius: 4px;
  background-color: #f00;
  cursor: pointer;
  padding: 14px;
  width: 48px;
  height: 100%;
}
.file-input .file-icon:hover {
  background-color: #cc0000;
}
.file-input .file-icon svg {
  width: 100%;
  height: 100%;
}

.iti {
  --iti-path-flags-1x: url("../img/flags.webp");
  --iti-path-flags-2x: url("../img/flags.webp");
  --iti-path-globe-1x: url("../img/svg/globe.svg");
  --iti-path-globe-2x: url("../img/svg/globe.svg");
}

.header-outer {
  display: flex;
  position: sticky;
  top: 33px;
  align-items: center;
  justify-content: center;
  z-index: 100;
  margin-right: 20px;
  margin-bottom: 53px;
  margin-left: 20px;
  border-radius: 30px;
  background-color: #f6f6f6;
  width: 100%;
  max-width: 1300px;
  height: 98px;
  min-height: 98px;
  overflow: visible;
  color: white;
}
.header-outer .backdrop {
  position: absolute;
  top: -33px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  border-bottom-left-radius: 40px;
  border-bottom-right-radius: 40px;
  background-color: white;
  width: 101%;
  height: calc(33px + 100%);
}
@media screen and (width <= 1280px) {
  .header-outer .backdrop {
    top: -15px;
    height: calc(15px + 100%);
  }
}
@media screen and (width <= 768px) {
  .header-outer .backdrop {
    top: -10px;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    height: calc(10px + 100%);
  }
}
.header-outer .header-inner {
  z-index: 100;
  border-radius: 30px;
  box-shadow: 1px 1px 2px 1px #e1e1e1;
  background-color: #f6f6f6;
  padding: 0 35px;
  width: 100%;
  height: 100%;
}
@media screen and (width <= 1280px) {
  .header-outer .header-inner {
    border-radius: 20px;
  }
}
.header-outer .header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  justify-content: center;
  justify-content: space-between;
  z-index: 1;
  margin: 0 auto;
  background-color: #f6f6f6;
  width: 100%;
  height: 100%;
}
.header-outer .header svg {
  fill: white;
  stroke: white;
}
.header-outer .header__login {
  display: none;
  stroke: white;
}
.header-outer .header__login circle {
  fill: none;
}
@media screen and (width <= 680px) {
  .header-outer .header__login {
    display: flex;
  }
}
.header-outer .header__logo {
  display: flex;
  margin-right: 42px;
  cursor: pointer;
  width: 46px;
  height: 43px;
}
.header-outer .header__logo svg {
  width: inherit;
  height: inherit;
  fill: white;
  stroke: none;
}
@media screen and (width <= 1280px) {
  .header-outer .header__logo {
    width: 35px;
    height: 35px;
  }
}
@media screen and (width <= 680px) {
  .header-outer .header__logo {
    margin: unset;
  }
}
.header-outer .header__menu {
  display: none;
  gap: 13px;
  align-items: center;
  justify-content: flex-end;
}
.header-outer .header__menu .contact,
.header-outer .header__menu .menu {
  transition: 0.2s;
  width: 32px;
  height: 32px;
}
.header-outer .header__menu .contact svg,
.header-outer .header__menu .menu svg {
  transition: 0.2s;
  stroke: #2b2a29;
}
.header-outer .header__menu .contact {
  rotate: 0deg;
}
.header-outer .header__menu .contact:hover {
  rotate: -20deg;
}
.header-outer .header__menu .contact:hover svg {
  stroke: #f00;
}
.header-outer .header__menu .menu.active svg, .header-outer .header__menu .menu:active svg {
  stroke: #f00;
}
@media screen and (width >= 768px) {
  .header-outer .header__menu .menu:hover svg {
    stroke: #f00;
  }
}
@media screen and (width <= 1280px) {
  .header-outer .header__menu {
    display: flex;
  }
}
.header-outer .header__links {
  display: flex;
  gap: 32px;
  align-items: center;
  justify-content: center;
  opacity: 0.8;
}
.header-outer .header__links a {
  position: relative;
  color: #2b2a29;
  font: 450 1.125rem/120% Roboto, sans-serif;
}
.header-outer .header__links a::before {
  position: absolute;
  right: 0;
  bottom: -2px;
  left: 0;
  transition: width 0.1s ease-in;
  background-color: #f00;
  width: 0%;
  height: 2px;
  content: "";
}
.header-outer .header__links a:not(.selected) {
  color: rgba(43, 42, 41, 0.6);
}
.header-outer .header__links a:not(.selected):hover {
  transition: color 0.1s linear;
  color: #2b2a29;
}
.header-outer .header__links a:not(.selected):hover::before {
  width: 100%;
}
.header-outer .header__links a.selected::before {
  width: 100%;
}
@media screen and (width <= 1280px) {
  .header-outer .header__links {
    display: none;
  }
}
.header-outer .header__additional {
  display: flex;
  gap: 15px;
  justify-content: flex-end;
}
.header-outer .header__additional .button-container {
  letter-spacing: 0.02em;
}
@media screen and (width <= 768px) {
  .header-outer .header__additional {
    display: none;
  }
}
@media screen and (width <= 768px) {
  .header-outer .header {
    grid-template-columns: 1fr 1fr;
  }
}
.header-outer .mobile-menu {
  display: none;
  position: absolute;
  right: 0;
  bottom: -5px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  transform: translateY(100%);
  z-index: 1000;
  border-radius: 20px;
  box-shadow: 1px 1px 2px 1px #e1e1e1;
  background-color: #f6f6f6;
  padding: 30px 25px;
  width: 340px;
  animation: 0.4s both slidein-horizontal;
}
.header-outer .mobile-menu .additional {
  display: none;
  gap: 10px;
  margin-bottom: 20px;
  font: 300 0.875rem/120% Rubik, sans-serif;
}
@media screen and (width <= 768px) {
  .header-outer .mobile-menu .additional {
    display: flex;
    width: 100%;
  }
  .header-outer .mobile-menu .additional .button-container {
    width: 100%;
  }
}
.header-outer .mobile-menu.active {
  display: flex;
}
.header-outer .mobile-menu .links {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 65px;
  width: 100%;
}
.header-outer .mobile-menu .links a {
  position: relative;
  color: rgba(43, 42, 41, 0.8);
  font: 450 1.25rem/160% Roboto, sans-serif;
}
.header-outer .mobile-menu .links a::before {
  position: absolute;
  right: 0;
  bottom: -2px;
  left: 0;
  transition: width 0.1s ease-in;
  background-color: #f00;
  width: 0%;
  height: 2px;
  content: "";
}
.header-outer .mobile-menu .links a:not(.selected) {
  color: rgba(43, 42, 41, 0.6);
}
.header-outer .mobile-menu .links a:not(.selected):hover {
  transition: color 0.1s linear;
  color: #2b2a29;
}
.header-outer .mobile-menu .links a:not(.selected):hover::before {
  width: 100%;
}
.header-outer .mobile-menu .links a.selected::before {
  width: 100%;
}
.header-outer .mobile-menu .footer-sns {
  display: flex;
  gap: 20px;
}
.header-outer .mobile-menu .footer-sns .sn-link-container {
  width: 24px;
  height: 24px;
}
.header-outer .mobile-menu .footer-sns .sn-link-container svg {
  width: inherit;
  height: inherit;
}
@media screen and (width <= 540px) {
  .header-outer .mobile-menu {
    width: 100%;
  }
}
@media screen and (width >= 1280px) {
  .header-outer .mobile-menu {
    display: none !important;
  }
}
@media screen and (width <= 1280px) {
  .header-outer {
    top: 15px;
    margin-bottom: 30px;
    border-radius: 20px;
    width: calc(100% - 48px);
    height: 55px;
    min-height: 55px;
  }
}
@media screen and (width <= 768px) {
  .header-outer {
    top: 10px;
    margin-bottom: 25px;
    width: calc(100% - 32px);
  }
}

@keyframes slidein-horizontal {
  0% {
    right: -500px;
  }
  100% {
    right: 0;
  }
}
.button-base, .button-container {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  cursor: pointer;
  padding: 9.5px 12px;
}

.button-container {
  transition: all 0.2s ease-in-out;
  background-color: #2b2a29;
  width: fit-content;
  min-width: fit-content;
  color: white;
  font: 300 1rem/140% Rubik, sans-serif;
  user-select: none;
}
.button-container:disabled {
  background-color: #111110;
  cursor: not-allowed;
  color: black;
}
.button-container:hover {
  background-color: black;
}
.button-container:active {
  background-color: black;
}
.button-container:active span {
  font-family: Montserrat, sans-serif;
  font-weight: 500;
}
.button-container.small {
  font: 300 0.875rem/120% Rubik, sans-serif;
}
.button-container.full {
  width: 100%;
}
.button-container.xl {
  padding: 17px 40px;
}
.button-container.main {
  background-color: #f00;
}
.button-container.main:hover {
  background-color: #de0000;
}
.button-container.white {
  background-color: white;
  color: #2b2a29;
}
.button-container.white:hover {
  background-color: #e6e6e6;
}

.footer {
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: center;
  margin-top: auto;
  border-radius: 30px;
  background-color: #2b2a29;
  padding: 51px 138px;
  width: 100%;
  color: white;
}
.footer .footer-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.footer .footer-content .logo {
  margin-bottom: 20px;
}
.footer .footer-content .logo svg {
  width: 46px;
  height: 42px;
}
.footer .footer-content .disclaimer {
  opacity: 0.4;
  margin-bottom: 30px;
  font: 300 0.8125rem/120% Roboto, sans-serif;
}
@media screen and (width <= 1280px) {
  .footer .footer-content {
    flex-direction: row;
    gap: 30px;
    margin-bottom: 30px;
  }
  .footer .footer-content .logo,
  .footer .footer-content .disclaimer {
    margin-bottom: 0;
  }
}
@media screen and (width <= 768px) {
  .footer .footer-content {
    flex-direction: column;
    gap: 30px;
    align-items: center;
    margin-bottom: 30px;
  }
  .footer .footer-content .logo,
  .footer .footer-content .disclaimer {
    margin-bottom: 0;
  }
}
.footer .links {
  display: grid;
  flex-wrap: wrap;
  grid-template-columns: 1fr 1.57fr 1fr;
  gap: 2px 4px;
  align-items: center;
  justify-content: center;
}
.footer .links .file-link {
  display: flex;
  position: relative;
  align-items: center;
  background-color: #2b2a29;
  height: 35px;
  font: 300 0.8125rem/120% Roboto, sans-serif;
}
.footer .links .file-link:nth-child(n) {
  justify-content: start;
}
.footer .links .file-link:nth-child(n)::after {
  position: absolute;
  top: 4px;
  right: -4px;
  background-color: rgba(255, 255, 255, 0.1);
  width: 2px;
  height: 27px;
  content: "";
}
.footer .links .file-link:nth-child(3n)::after {
  display: none;
}
.footer .links .file-link:nth-child(3n+2) {
  justify-content: center;
}
.footer .links .file-link:nth-child(3n+3) {
  justify-content: end;
}
@media screen and (width <= 1280px) and (width > 768px) {
  .footer .links .file-link {
    width: fit-content;
  }
  .footer .links .file-link:nth-child(n) {
    justify-content: start;
    padding-right: 33px;
  }
  .footer .links .file-link:nth-child(3n+2), .footer .links .file-link:nth-child(3n+3) {
    padding-left: 33px;
  }
}
@media screen and (width <= 768px) {
  .footer .links .file-link {
    align-items: flex-start;
    height: fit-content;
  }
  .footer .links .file-link::after, .footer .links .file-link::before {
    display: none;
  }
}
@media screen and (width <= 1280px) and (width > 768px) {
  .footer .links {
    display: flex;
    width: fit-content;
  }
}
@media screen and (width <= 768px) {
  .footer .links {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: flex-start;
  }
}
.footer .spacer {
  margin: 30px 0;
  margin-bottom: 27px;
  background-color: rgba(255, 255, 255, 0.1);
  width: 100%;
  height: 2px;
}
@media screen and (width <= 1280px) {
  .footer .spacer {
    margin: 30px 0 25px;
  }
}
.footer .additional-info {
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.footer .additional-info .judical {
  display: flex;
  align-items: center;
  opacity: 0.4;
  font: 300 0.9375rem/120% Roboto, sans-serif;
}
.footer .additional-info .footer-sns {
  display: flex;
  gap: 20px;
  align-items: center;
}
.footer .additional-info .footer-sns .sn-link-container {
  width: 24px;
  height: 24px;
}
.footer .additional-info .footer-sns .sn-link-container svg {
  width: inherit;
  height: inherit;
}
@media screen and (width <= 1280px) {
  .footer .additional-info {
    flex-direction: column-reverse;
    gap: 30px;
    align-items: center;
  }
}
@media screen and (width <= 1400px) {
  .footer {
    width: calc(100% - 40px);
  }
}
@media screen and (width <= 1280px) {
  .footer {
    border-radius: 20px;
    padding: 30px 25px;
  }
}
@media screen and (width <= 768px) {
  .footer {
    width: calc(100% - 32px);
  }
}

.toast-container {
  display: flex;
  position: fixed;
  right: 0;
  bottom: 20px;
  left: 0;
  gap: 10px;
  justify-content: center;
  z-index: 1001;
  margin: auto;
  margin-right: auto;
  margin-left: auto;
  border-radius: 2px;
  background: #2b2a29;
  padding: 10px 20px;
  width: fit-content;
  min-width: 300px;
  animation: 3s 1 alternate slidein;
  color: white;
}
@keyframes slidein {
  0% {
    bottom: -100px;
  }
  10% {
    bottom: 2vh;
  }
  90% {
    bottom: 2vh;
  }
  100% {
    bottom: -100px;
  }
}
.toast-container svg {
  width: 45px;
  height: 45px;
}
@media screen and (max-width: 680px) {
  .toast-container {
    gap: 10px;
    border-radius: 28px;
    padding: 10px 20px;
    min-width: unset;
  }
  .toast-container .text-container {
    gap: 10px;
    width: 100%;
  }
}

.contacts-fab {
  display: flex;
  position: fixed;
  right: 50px;
  bottom: 60px;
  align-items: center;
  justify-content: center;
  transition: 0.2s ease-in;
  z-index: 2000;
  border-radius: 50%;
  background-color: #f00;
  width: 74px;
  height: 74px;
  overflow: hidden;
}
.contacts-fab:hover {
  background-color: #cc0000;
}
.contacts-fab .svg-container {
  width: 56px;
  height: 56px;
}
.contacts-fab .svg-container svg {
  transition: 0.2s ease-in;
  fill: #2b2a29;
  width: 100%;
  height: 100%;
}
.contacts-fab .svg-container svg:hover {
  transition: 0.2s ease-in;
}
@media screen and (width <= 768px) {
  .contacts-fab {
    right: 15px;
    bottom: 10px;
    width: 56px;
    height: 56px;
  }
  .contacts-fab .svg-container {
    width: 38px;
    height: 38px;
  }
}

.tag-line {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  margin-bottom: 6px;
  overflow: auto;
}
.tag-line__tag {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background-color: #f6f6f6;
  padding: 6px 15px;
  color: rgba(43, 42, 41, 0.7);
  font: 400 1.0625rem/160% Roboto, sans-serif;
}
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .tag-line__tag {
    font-weight: 350;
  }
}
@media screen and (width <= 1280px) {
  .tag-line {
    margin-bottom: 15px;
  }
}

/*
@include mixins.font-face(
  MBold,
  "/assets/fonts/Montserrat/Montserrat-Bold/Montserrat-Bold",
  null,
  null,
  woff2
);
@include mixins.font-face(
  MLight,
  "/assets/fonts/Montserrat/Montserrat-Light/Montserrat-Light",
  null,
  null,
  woff2
);
@include mixins.font-face(
  MMedium,
  "/assets/fonts/Montserrat/Montserrat-Medium/Montserrat-Medium",
  null,
  null,
  woff2
);
@include mixins.font-face(
  MRegular,
  "/assets/fonts/Montserrat/Montserrat-Regular/Montserrat-Regular",
  null,
  null,
  woff2
);
@include mixins.font-face(
  MSemibold,
  "/assets/fonts/Montserrat/Montserrat-SemiBold/Montserrat-SemiBold",
  null,
  null,
  woff2
);
@include mixins.font-face(
  BNRegular,
  "/assets/fonts/BonaNova/BonaNova-Regular/BonaNova-Regular",
  null,
  null,
  woff2
);

@include mixins.font-face(
  RLight,
  "/assets/fonts/Roboto/Roboto-Light",
  null,
  null,
  ttf
);
@include mixins.font-face(
  RBold,
  "/assets/fonts/Roboto/Roboto-Bold",
  null,
  null,
  ttf
);
@include mixins.font-face(
  RMedium,
  "/assets/fonts/Roboto/Roboto-Medium",
  null,
  null,
  ttf
);
*/


.bx-core-window select {
  display: block !important;
}

#panel {
  position: relative;
  z-index: 1199 !important;
}

.bx-component-opener {
  z-index: 99999999999999999; !important;
}

.event-modal__form_container {
  display: none;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
#back_btn {
  position: absolute;
  left: 40px;
  top: 40px;
  z-index: 1;
}

.event-modal__list_item_img {
  width: 255px;
  height: 192px;
  border-radius: 12px;
  overflow: hidden;
}

.event-modal__list_item_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.event-modal__list {
  display: flex;
  flex-direction: column;
  gap: 0;

  width: 100%;
  max-height: 800px;
  overflow: auto;
}

.event-modal__list_item {
  cursor: pointer;
  display: grid;
  grid-template-columns: 255px 60%;
  grid-column-gap: 4%;
  grid-row-gap: 25px;
  padding: 0 40px;
  padding-bottom: 40px;
}

.event-modal__list .section-header__title {
  color: #2b2a29;
  padding: 40px;
  font: 500 2.5rem / 160% Roboto, sans-serif;
}

.event-modal__list::-webkit-scrollbar {
  width: 0;
}

.event-modal__list::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 200px;
  border-radius: 10px;
  background: linear-gradient(180deg,rgba(42, 123, 155, 0) 0%, rgba(255, 255, 255, 1) 50%);
  z-index: 1;
}
.event-modal__list._hide-after::after {
  opacity: 0;
  pointer-events: none;
}

@media screen and (width <= 992px) {
  .event-modal__list .event-modal__list_item {
    grid-template-columns: 100%;
    grid-row-gap: 25px;
  }
  .event-modal__list .event-modal__list_item_img {
    order: 2;
    width: 100%;
    height: 219px;
  }
  .event-modal__list .event-modal__body--title {
    margin-bottom: 0;
  }
}

@media screen and (width <= 480px) {
  .event-modal__list .event-modal__list_item_img {
    height: 150px;
  }
  .event-modal__list .section-header__title {
    font: 800 2rem / 120% Roboto, sans-serif;
  }
}


.form-note {
  display: flex;
  flex-direction: column;
  gap: 25px;
}

.form_success_mess {
  display: flex;
  max-width: 400px;
}

.form_success .main {
  width: 100%;
  padding-top: 17px;
  padding-bottom: 17px;
}

.hidden {
  display: none;
}

.background_black {
  background: #020202;
  border-radius: 10px;
}

.background_black .event-info,
.background_black .event-title,
.background_black .event-subtitle {
  color: #ffffff;
}

.iti--allow-dropdown {
  background: #fff;
}

.background_black .phone-input .iti__country-container::after {
  background: #020202;
  border-right: 1px solid #020202;
  border-left: 1px solid #020202;
}

.background_black .form_success {
  color: #ffffff;
}

.background_black_input {
  background: #020202;
  border-radius: 10px;
}

.background_black_input .phone-input .iti__country-container::after {
  background: #020202;
  border-right: 1px solid gray;
  border-left: 1px solid gray;
}

.background_black_input .iti--allow-dropdown,
.background_black_input input {
  background: #020202;
}

.background_black_input .iti {
  border-color: gray;
  color: gray;
}

.background_black_input input {
  border-color: gray;
  color: #ffffff;
}

.background_black_input .iti__tel-input {
  color: #ffffff;
}

.background_black_input input::placeholder {
  color: gray;
}

.background_black_input .form_success {
  color: #ffffff;
}

.background_black_input .event-info,
.background_black_input .event-title,
.background_black_input .event-subtitle {
  color: #ffffff;
}

.form-input-error {
  border: 1px solid red !important;
}
.form-error {
  color: rgb(184, 17, 17);
  font: 300 12px / 140% Rubik, sans-serif;
}

.bitrix-loader, #wait_form, .loader {
  display: none !important;
}

.form-input-group-file {
  order: 9;
}
.employee-modal__submit {
  order: 10;
}
