@charset "utf-8";
@import url("../fonts/Montserrat/font.cb6b773adc77.css");
@import url("../fonts/Inter/font.b95774c904f4.css");

html {
  overflow: auto;
  --top-menu-position: 64px;
  scroll-padding-top: var(--top-menu-position);
}

body {
  padding: 0;
  margin: 0;
  background: var(--color-bg-light);
  font-family: "Inter";
  font-weight: 600;
  overflow-x: clip;
}

body * {
  box-sizing: border-box;
  position: relative;
  font-family: "Inter";
}

:root {
  /* акцентные цвета */
  --color-accent-light: 16, 46, 104;
  --color-accent-dark: 9, 27, 61;
  /* цвет элемента формы в фокусе */
  --color-active-element: 59, 130, 247;
  /* цвет, привлекающий внимание */
  --color-attractive: 255, 204, 0;
  /* Текст */
  /* Обычный */
  --color-text-light: 46, 44, 44;
  --color-text-dark: 250, 250, 250;
  /* Полупрозрачный */
  --color-text-transparency: 0.7;
  /* Фон */
  /* Обычный */
  --color-bg-light: 245, 245, 245;
  --color-bg-dark: 22, 22, 23;
  --color-bg-black: 0, 0, 0;
  --color-bg-white: 255, 255, 255;
  --color-destruction: 254, 83, 53;
  /* Полупрозрачный */
  --color-bg-transparency: 0.7;
  /* Отступы */
  --spacing-level-1: 64px;
  --spacing-level-2: 40px;
  --spacing-level-3: 32px;
  --spacing-level-4: 16px;
  --spacing-level-5: 5px;
  /* Ширина контента для широких экранов */
  --body-container-width: 1200px;
  /* Размеры текста */
  --text-size-header-large: 40px;
  --text-size-header-medium: 32px;
  --text-size-header-small: 20px;
  --text-size-text-large: 18px;
  --text-size-text-medium: 16px;
  --text-size-text-small: 14px;
}

*:active,
*:focus {
  outline: none;
}

*::-moz-focus-inner {
  border: 0;
}

* {
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  appearance: none;
}

a {
  color: inherit;
}

.drag-files-overlay {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  background: rgb(var(--color-active-element), 0.15);
  backdrop-filter: blur(20px);
  z-index: 101;
  gap: var(--spacing-level-4);
  padding: var(--spacing-level-2);
  pointer-events: none;
  opacity: 0;
  transition: all 0.15s ease;
}

.dragging-file .drag-files-overlay {
  opacity: 1;
}

.drag-files-overlay > .icon {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  height: auto;
  width: calc(var(--text-size-header-large) * 3);
  aspect-ratio: 1;
  max-width: 100%;
}

.drag-files-overlay > .icon > svg {
  height: 100%;
  width: 100%;
}

.drag-files-overlay > .icon > svg > * {
  fill: rgb(var(--color-active-element));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: transparent;
  stroke-width: 0;
}

.drag-files-overlay > .text {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-weight: 500;
  font-size: var(--text-size-text-medium);
  color: rgb(var(--color-text-light));
}

.top-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  position: sticky;
  top: 0;
  width: 100%;
  left: 0;
  right: 0;
  z-index: 11;
  background: rgb(var(--color-accent-light));
  --text-color: var(--color-text-dark);
  padding: 0 var(--spacing-level-3);
}

.top-menu.scrollable {
  position: sticky;
  top: -100%;
  background: linear-gradient(
    -90deg,
    rgb(var(--color-accent-dark)) 0% 75%,
    rgb(var(--color-accent-light)) 200%
  );
  z-index: 10;
}

.top-menu.scrollable.banner {
  box-shadow: inset 0px -1px 0 0px rgb(var(--color-text-dark), 0.1);
  max-height: 48px;
  transition: max-height 0.15s ease;
  background: linear-gradient(
    -90deg,
    rgb(var(--color-accent-dark)) 0% 25%,
    rgb(var(--color-accent-light)) 200%
  );

  text-decoration: none;
}

.top-menu.scrollable.banner.hidden,
.top-menu.scrollable.banner.initially-hidden {
  max-height: 0px;
}

.top-menu.scrollable.banner.initially-hidden {
  transition: all 0s;
}

body.before-zoomed-in .top-menu {
  transition: all 0.4s ease;
  transform: translateY(calc(0px - var(--top-menu-position)));
}

body.before-zoomed-out .top-menu {
  transition: all 0.4s ease;
}

.top-menu > .container {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  min-height: 64px;
  width: 100%;
  height: 100%;
  margin: auto;
  padding: 0;
  max-width: var(--body-container-width);
}

.top-menu.banner > .container {
  min-height: 48px;

  align-items: center;
}

.top-menu > .container > .logo {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  height: auto;
  width: auto;
  overflow: hidden;
  position: relative;
  gap: var(--spacing-level-4);
  /* gap: calc(var(--spacing-level-5) * 2); */
  text-decoration: none !important;
  flex-shrink: 0;
  padding: var(--spacing-level-4);
  max-width: 100%;
}

.top-menu.scrollable > .container > .logo {
  padding: var(--spacing-level-3) var(--spacing-level-4);
}

.top-menu > .container > .logo * {
  text-decoration: none !important;
}

.top-menu > .container > .logo > .logos {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-level-5);
}

.top-menu > .container > .logo img {
  width: auto;
  /* height: 16px; */
  height: 20px;
}

.top-menu > .container > .logo > img:not(:first-child) {
  margin-left: calc(0px - var(--spacing-level-5));
}

.top-menu.scrollable > .container > .logo > img {
  height: 24px;
}

.top-menu > .container > .logo > .text {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  max-width: 325px;
  gap: var(--spacing-level-5);
}

.top-menu > .container > .logo > .text > div {
  font-family: "Montserrat";
  font-weight: 500;
  font-size: var(--text-size-text-medium);
  color: rgb(var(--text-color));
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}

.top-menu > .container > .logo > .text > div:not(div:last-child) {
  font-size: calc(var(--text-size-text-small) - 1.75px);
  color: rgb(var(--text-color), var(--color-text-transparency));
  font-family: "Inter";
}

.top-menu.banner > .container > .text {
  height: auto;
  width: auto;
  overflow: hidden;
  position: relative;
  text-decoration: none !important;
  padding: 0px var(--spacing-level-4);
  max-width: 100%;

  font-family: "Inter";
  font-weight: 400;
  font-size: var(--text-size-text-medium);
  color: rgb(var(--text-color));

  white-space: nowrap;
  text-overflow: ellipsis;
}

.top-menu > .container > .open-button,
.top-menu > .container > .back-button {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  height: 64px;
  width: auto;
  overflow: hidden;
  text-decoration: none !important;
  cursor: pointer;
  padding: var(--spacing-level-4);
  margin: 0 calc(0px - var(--spacing-level-4)) 0 0;
  z-index: 3;
  display: none;
}

.top-menu > .container > .back-button {
  flex-grow: 1;
  position: absolute;
  left: 0;
  background: rgb(var(--color-accent-light));
  z-index: 5;
  transition: all 0.15s ease;
  margin: 0 0 0 calc(0px - var(--spacing-level-4));
  width: 100%;
}

.top-menu > .container > .back-button.hidden {
  transform: translateX(-16px);
  opacity: 0;
  pointer-events: none;
}

.top-menu > .container > .open-button > svg,
.top-menu > .container > .back-button > svg {
  height: 20px;
  width: 20px;
}

.top-menu > .container > .open-button > svg > *,
.top-menu > .container > .back-button > svg > * {
  fill: transparent;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--text-color));
  stroke-width: 3px;
  transition: fill 0.3s;
}

.top-menu > .container > .buttons {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  position: relative;
  margin: 0;
  padding: 0;
  z-index: 3;
}

.top-menu > .container > .buttons:not(.right) > .separator {
  display: block;
  height: 1px;
  width: calc(100% - var(--spacing-level-3) * 2);
  max-width: var(--body-container-width);
  position: absolute;
  top: 64px;
  background: rgb(var(--text-color), 0.1);
  padding: 0;
  margin: 0;
  display: none;
}

.top-menu > .container > .buttons.right {
  justify-content: flex-end;
  flex-grow: 1;
}

.top-menu.banner > .container > .buttons.right {
  padding-right: var(--spacing-level-4);
}

.top-menu:not(.banner) > .container > .buttons > * {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: var(--spacing-level-5);
  text-decoration: none;
  padding: var(--spacing-level-4);
  color: rgb(var(--text-color));
  opacity: var(--color-text-transparency);
  font-size: var(--text-size-text-medium);
  font-weight: 400;
  font-family: "Inter";
  overflow: hidden;
  transition: all 0.15s ease-in-out;
  flex-shrink: 0;
  cursor: pointer;
}

.top-menu:not(.banner) > .container > .buttons > *:hover,
.top-menu:not(.banner) > .container > .buttons > .active {
  opacity: 1;
}

.top-menu:not(.banner) > .container > .buttons > *::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  border-radius: 100px 100px 0 0;
  background: rgb(var(--color-active-element));
  height: 4px;
  transition: all 0.15s ease-in-out;
  transform: translateY(100%);
}

.top-menu > .container > .buttons > .active::after,
.top-menu.scrollable > .container > .buttons > :hover::after {
  transform: translateY(0%);
}

.top-menu > .container > .buttons > * > svg {
  height: 20px;
  width: 20px;
}

.top-menu > .container > .buttons > * > svg.filled {
  height: 24px;
  width: 24px;
  margin: -2px;
}

.top-menu > .container > .buttons > * > svg > * {
  fill: transparent;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--text-color));
  stroke-width: 2px;
}

.top-menu > .container > .buttons > * > svg.filled > * {
  fill: rgb(var(--text-color));
  stroke-width: 0;
}

.top-menu > .container > .buttons > *.bvi-open > svg > * {
  stroke: rgb(var(--color-attractive));
}

.top-menu-expanded {
  display: block;
  height: auto;
  padding: 0 var(--spacing-level-3);
  width: 100%;
  position: fixed;
  top: var(--top-menu-position);
  left: 0;
  right: 0;
  z-index: -1;
  opacity: 1;
  background: rgb(var(--color-accent-light));
  max-height: calc(
    var(--vh, 1vh) * 100 - var(--top-menu-position) - var(--spacing-level-1)
  );
  box-shadow: 0 calc(var(--vh, 1vh) * 100) 0 calc(var(--vh, 1vh) * 100)
    rgb(var(--color-bg-black), 0.7);
  overflow: auto;
  animation: top-menu-expanded-appear 0.15s ease-out both;
  will-change: opacity, transform;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.top-menu-expanded.hide {
  animation: top-menu-expanded-disappear 0.15s ease-out both;
}

@keyframes top-menu-expanded-appear {
  0% {
    opacity: 0;
    transform: translateY(-16px);
  }

  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

@keyframes top-menu-expanded-disappear {
  0% {
    opacity: 1;
    transform: translateY(0px);
  }

  100% {
    opacity: 0;
    transform: translateY(-16px);
  }
}

.top-menu-expanded > .container {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  height: auto;
  margin: auto;
  padding: var(--spacing-level-3) 0;
  max-width: var(--body-container-width);
  color: rgb(var(--text-color));
  border-top: 1px solid rgb(var(--text-color), 0.1);
  font-family: "Inter";
  font-weight: 400;
  font-size: var(--text-size-medium);
  transition: all 0.15s ease-out;
  --old-max-height: 100%;
  height: calc(var(--old-max-height) + var(--spacing-level-3) * 2);
}

.top-menu-expanded > .container.resize {
  height: calc(var(--new-max-height) + var(--spacing-level-3) * 2);
  overflow: hidden;
}

.top-menu-expanded > .container > div {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  height: auto;
  gap: var(--spacing-level-3);
  opacity: 0;
  animation: top-menu-submenu-appear 0.15s ease-out both;
  will-change: opacity;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.top-menu-expanded > .container > div.hide {
  position: absolute;
  animation: top-menu-submenu-hide 0.15s ease-in both;
  overflow: hidden;
  max-height: calc(100% - var(--spacing-level-3) * 2);
}

@keyframes top-menu-submenu-appear {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes top-menu-submenu-hide {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

.top-menu-expanded > .container > div:not(.opened) {
  display: none;
}

.top-menu-expanded > .container > div > .group {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  height: auto;
  width: auto;
  gap: var(--spacing-level-4);
}

.top-menu-expanded > .container > div > .group > .title {
  font-family: "Montserrat";
  font-weight: 700;
  font-size: var(--text-size-text-medium);
  color: rgb(var(--text-color), var(--color-text-transparency));
  padding: 0 0 var(--spacing-level-4) 0;
}

.top-menu-expanded > .container > div > .group > a + .title {
  margin-top: calc(var(--spacing-level-3) - var(--spacing-level-5));
}

.top-menu-expanded > .container > div > .group > .title::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -1.5px;
  left: 0;
  height: 3px;
  width: 64px;
  max-width: 100%;
  border-radius: 10px;
  background: rgb(var(--color-active-element));
}

.top-menu-expanded > .container > div > .group > *:not(:hover) {
  text-decoration: none;
}

.section {
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  padding: var(--spacing-level-1);
  background: rgb(var(--color-bg-light));
  --text-color: var(--color-text-light);
  color: rgb(var(--text-color));
  position: relative;
  overflow: hidden;
  z-index: 1;
  max-width: 100% !important;
}

.section.hero {
  /* margin-top: 64px; */
  min-height: calc(var(--vh, 1vh) * 100 - var(--top-menu-position));
}

.section.dark {
  background: linear-gradient(
    90deg,
    rgb(var(--color-accent-dark)) 0% 60%,
    rgb(var(--color-accent-light)) 110%
  );
  --text-color: var(--color-text-dark);
}

.section.horizontal {
  padding: 0;
}

.section.horizontal > .container {
  max-width: calc(var(--body-container-width) * 1.35);
  width: 100%;
  display: flex !important;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.section.horizontal > .container > .content {
  flex-grow: 1;
}

.section.background-white {
  background: rgb(var(--color-bg-white));
}

.section.background-black {
  background: rgb(var(--color-bg-dark));
  --text-color: var(--color-text-dark);
}

.section > .background {
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  overflow: hidden;
  z-index: -2;
  pointer-events: none;
}

.section > .background > img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.section .image {
  /* width: 512px; */
  /* max-width: 40%; */
  height: 512px;
  max-height: calc(100vh - 64px);
  /* height: 100%; */
  flex-shrink: 0;
  width: 50%;
  min-width: 50%;
  max-width: 100%;
  /* aspect-ratio: 1; */
}

.section .image > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.section > .content,
.section > .container > .content {
  display: flex !important;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: flex-start;
  gap: var(--spacing-level-4);
  z-index: 2;
  max-width: var(--body-container-width);
  width: 100%;
}

.section.horizontal .content {
  padding: var(--spacing-level-1) calc(var(--spacing-level-1) * 2);
}

.section > .content.text-align-center,
.section > .container > .content.text-align-center {
  align-items: center;
}

.section > .content.text-align-center > .title,
.section > .container > .content.text-align-center > .title,
.section > .content.text-align-center > .subtitle,
.section > .container > .content.text-align-center > .subtitle,
.section > .content.text-align-center > .description,
.section > .container > .content.text-align-center > .description,
.section.horizontal .content > .text {
  justify-content: center;
  text-align: center;
}

.section > .content > .icons,
.section > .container > .content > .icons {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: var(--spacing-level-5);
}

.section > .content > .icons > svg,
.section > .container > .content > .icons > svg {
  height: 40px;
  width: 40px;
}

.section > .content > .icons > img,
.section > .container > .content > .icons > img {
  width: auto;
  height: auto;
  max-height: 84px;
  max-width: 256px;
  object-fit: contain;
}

.section > .content > .icons > svg > *,
.section > .container > .content > .icons > svg > * {
  fill: rgb(var(--text-color));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--text-color));
  stroke-width: 0;
  transition: fill 0.3s;
}

.section.post > .content > .text-wrapper > p:last-child {
  margin-bottom: 0;
}

.section > .content > .details:not(.card .details),
.section > .container > .content > .details:not(.card .details) {
  font-size: var(--text-size-text-small);
  font-weight: 500;
  color: rgb(var(--text-color), var(--color-text-transparency));
  margin-bottom: calc(0px - var(--spacing-level-4) * 1.5);
  padding-bottom: var(--spacing-level-5);
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: var(--spacing-level-4);
}

.section > .content > .details:not(.card .details) > span,
.section > .content > .details:not(.card .details) > a,
.section > .container > .content > .details:not(.card .details) > span,
.section > .container > .content > .details:not(.card .details) > a {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
}

.section > .content > .details:empty,
.section > .container > .content > .details:empty {
  display: none;
}

.section > .content > .details:not(.card .details) svg,
.section > .container > .content > .details:not(.card .details) svg {
  height: var(--text-size-text-small);
  width: var(--text-size-text-small);
}

.section > .content > .details:not(.card .details) svg > *,
.section > .container > .content > .details:not(.card .details) svg > * {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--text-color), var(--color-text-transparency));
  stroke-width: 2px;
}

.section > .content > .list-with-icons,
.section > .container > .content > .list-with-icons {
  display: grid;
  padding-top: var(--spacing-level-2);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-level-3);
}

.section > .content > .list-with-icons > .item,
.section > .container > .content > .list-with-icons > .item {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: var(--spacing-level-4);
}

.section > .content > .list-with-icons > .item > .text,
.section > .container > .content > .list-with-icons > .item > .text {
  font-family: "Montserrat";
  font-size: var(--text-size-text-large);
  font-weight: 500;
  color: rgb(var(--text-color));
}

.section > .content > .list-with-icons > .item > .icon,
.section > .container > .content > .list-with-icons > .item > .icon {
  height: var(--text-size-header-large);
  min-height: var(--text-size-header-large);
  width: var(--text-size-header-large);
  min-width: var(--text-size-header-large);
}

.section > .content > .list-with-icons > .item > .icon > svg,
.section > .container > .content > .list-with-icons > .item > .icon > svg,
.section > .content > .list-with-icons > .item > .icon > img,
.section > .container > .content > .list-with-icons > .item > .icon > img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}

.section.dark > .content > .list-with-icons > .item > .icon > svg,
.section.dark > .container > .content > .list-with-icons > .item > .icon > svg {
  opacity: var(--color-text-transparency);
}

.section > .content > .list-with-icons > .item > .icon > svg > *,
.section > .container > .content > .list-with-icons > .item > .icon > svg > * {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--color-text-dark));
  stroke-width: 1px;
}

.section.horizontal .content > .text {
  font-family: "Inter";
  font-size: var(--text-size-header-small);
  font-weight: 500;
  max-width: 100%;
  color: rgb(var(--text-color), var(--color-text-transparency));
}

.section.horizontal .content > .text > span {
  color: rgb(var(--text-color));
}

.section > .content > .title,
.section > .container > .content > .title {
  font-family: "Montserrat";
  font-size: var(--text-size-header-large);
  font-weight: 700;
  max-width: 100%;
  color: rgb(var(--text-color));
}

.swiper.hero .content > .title,
.swiper.edgeless .content > .title {
  text-shadow: 2px 2px
    rgb(var(--color-accent-dark), var(--color-text-transparency));
}

.section.post > .content > .title {
  font-size: var(--text-size-header-medium);
  color: rgb(var(--text-color));
}

.section > .content > .subtitle,
.section > .container > .content > .subtitle {
  font-family: "Inter";
  font-size: var(--text-size-header-small);
  font-weight: 400;
  max-width: 100%;
  color: rgb(var(--text-color));
}

.section > .content .description,
.section > .container > .content .description {
  font-size: var(--text-size-text-medium);
  font-weight: 400;
  font-family: "Inter";
  line-height: 1.24;
  color: rgb(var(--text-color));
}

.section a {
  text-decoration: none;
}

.section a:hover {
  text-decoration: underline;
}

.section > .content .description:not(.longtext) a,
.section > .container > .content .description:not(.longtext) a {
  color: rgb(var(--color-active-element));
  text-decoration: none;
}

.section > .content .description:not(.longtext) a:hover,
.section > .container > .content .description:not(.longtext) a:hover {
  text-decoration: underline;
}

.additional-menu {
  --inner-padding: var(--spacing-level-5);
  height: auto;
  width: auto;
  position: fixed;
  top: -100vh;
  background: rgb(var(--color-bg-white));
  box-shadow: 0 25pt 50pt 0pt rgb(var(--color-bg-dark), 0.15);
  max-width: 280px;
  border-radius: 16px;
  cursor: default;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  gap: var(--spacing-level-5);
  overflow: hidden;
  padding: var(--inner-padding);
  z-index: 53;
  max-height: 500px;
  overflow-y: auto;
  transform-origin: top center;
  --text-color: var(--color-text-light);
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.15s ease-out, transform 0.15s ease-out;
  will-change: opacity, transform;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.additional-menu.hidden {
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}

@keyframes document-container-menu {
  0% {
    opacity: 0;
    transform: translateY(-10pt);
  }

  100% {
    opacity: 1;
    transform: translateY(0pt) scale(1);
  }
}

@keyframes document-container-menu-up {
  0% {
    opacity: 1;
    transform: translateY(0pt);
  }

  100% {
    opacity: 0;
    transform: translateY(10pt);
  }
}

.additional-menu > .container {
  width: calc(100% + var(--inner-padding) * 2);
  box-sizing: border-box;
  margin: calc(0px - var(--inner-padding));
  padding: var(--inner-padding);
  background: inherit;
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0;
}

.additional-menu > .container.inline {
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
}

.additional-menu > .container.inline > * {
  width: auto !important;
  flex-grow: 1 !important;
  justify-content: center !important;
  text-align: center !important;
}

.additional-menu > .container > .description,
.additional-menu > .description {
  font-size: var(--text-size-text-small);
  padding: var(--inner-padding) calc(var(--inner-padding) * 3);
  width: calc(100% + var(--inner-padding) * 2);
  box-sizing: border-box;
  margin: calc(0px - var(--inner-padding)) calc(0px - var(--inner-padding)) 0
    calc(0px - var(--inner-padding));
  color: rgb(var(--color-text-light), var(--color-text-transparency));
  font-weight: 400;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  flex-shrink: 0;
  max-width: 240px;
}

.additional-menu > .container > .separator,
.additional-menu > .separator {
  height: 1px;
  width: calc(
    100% - var(--spacing-level-5) * 2 - 20px + var(--spacing-level-4)
  );
  background: rgb(var(--color-text-light), 0.1);
  margin: var(--spacing-level-5) 0;
  margin-left: calc(var(--spacing-level-5) * 2 + 20px);
  content: "";
  flex-shrink: 0;
  border-radius: 100px;
}

.additional-menu > .container > a,
.additional-menu > .container > div:not(.separator),
.additional-menu > a,
.additional-menu > div:not(.separator) {
  height: auto;
  width: 100%;
  background: inherit;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  font-size: var(--text-size-text-medium);
  color: rgb(var(--text-color));
  gap: var(--spacing-level-5);
  overflow: hidden;
  padding: var(--spacing-level-5) var(--spacing-level-4) var(--spacing-level-5)
    var(--spacing-level-5);
  border: 1pt solid rgb(var(--color-text-light), 0);
  line-height: 1;
  cursor: pointer;
  border-radius: 11px;
  transition: all 0.1s ease-in-out;
  flex-shrink: 0;
  z-index: 1;
  text-align: left;
  font-weight: 400;
  text-decoration: none;
}

.additional-menu > .container > a:hover,
.additional-menu > .container > div:not(.separator):hover,
.additional-menu > a:hover,
.additional-menu > div:not(.separator):hover {
  background: rgb(var(--color-bg-light));
  border: 1px solid rgb(var(--color-text-light), 0.1);
}

.additional-menu > .container > a > .head,
.additional-menu > .container > div > .head,
.additional-menu > a > .head,
.additional-menu > div > .head {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  width: 100%;
  line-height: 1.15;
}

.additional-menu > .container > a > .icon,
.additional-menu > .container > div > .icon,
.additional-menu > a > .icon,
.additional-menu > div > .icon {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  color: rgb(var(--color-active-element));
  width: 15pt;
  height: 15pt;
  flex-shrink: 0;
}

.additional-menu > .container > a > .checkmark,
.additional-menu > .container > div > .checkmark,
.additional-menu > a > .checkmark,
.additional-menu > div > .checkmark {
  display: block;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  width: 15pt;
  height: 15pt;
  flex-shrink: 0;
}

.additional-menu > .container > a > .checkmark > *,
.additional-menu > .container > div > .checkmark > *,
.additional-menu > a > .checkmark > *,
.additional-menu > div > .checkmark > * {
  display: block;
  height: 7px;
  width: 7px;
  border-radius: 100px;
  background: transparent;
}

.additional-menu > .container > a.checked > .checkmark > *,
.additional-menu > .container > div.checked > .checkmark > *,
.additional-menu > a.checked > .checkmark > *,
.additional-menu > div.checked > .checkmark > * {
  background: rgb(var(--color-active-element));
}

.additional-menu > .container > a.checked-1 > .checkmark > *,
.additional-menu > .container > div.checked-1 > .checkmark > *,
.additional-menu > a.checked-1 > .checkmark > *,
.additional-menu > div.checked-1 > .checkmark > * {
  background: transparent;
  outline: 1.5pt solid rgb(var(--color-active-element));
  outline-offset: 0;
}

.additional-menu > .container > a > .icon > svg,
.additional-menu > .container > div > .icon > svg,
.additional-menu > a > .icon > svg,
.additional-menu > div > .icon > svg {
  height: 13pt;
  width: 13pt;
}

.additional-menu > .container > a > .icon > svg > *,
.additional-menu > .container > div > .icon > svg > *,
.additional-menu > a > .icon > svg > *,
.additional-menu > div > .icon > svg > * {
  stroke-width: 1.25pt;
  stroke: rgb(var(--color-active-element));
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.additional-menu > .container > .content,
.additional-menu > .content {
  height: auto;
  max-width: 250pt;
  min-width: 150pt;
  width: auto;
  border-radius: 0;
  background: transparent;
  border: none;
  min-height: 28pt;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  font-size: 13pt;
  font-family: Ubuntu;
  font-style: normal;
  font-weight: 300;
  color: rgb(var(--color-gray-1));
  gap: 4pt;
  overflow: hidden;
  padding: 8pt;
  border-bottom: none;
  cursor: default;
}

.additional-menu > .container > .content svg,
.additional-menu > .content svg {
  height: 15pt;
  width: 15pt;
}

.additional-menu > .container > .content svg > *,
.additional-menu > .content svg > * {
  stroke-width: 1pt;
  stroke: rgb(var(--color-gray-1));
}

.additional-menu > .content > .description,
.additional-menu > .container > .content > .description {
  text-align: center;
  font-size: 11pt;
  font-family: Ubuntu;
  font-style: normal;
  font-weight: 400;
}

.swiper.hero {
  height: calc(var(--vh, 1vh) * 100 - var(--top-menu-position)) !important;
  /* padding-top: 64px; */
  --swiper-padding: var(--spacing-level-1);
}

.swiper.employees {
  width: calc(var(--body-container-width) * 0.75);
  height: auto;
  margin: calc(0px - var(--spacing-level-4))
    calc((100% - var(--body-container-width) * 0.75) / 2);
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  user-select: none;
  padding: var(--spacing-level-4);
  background: rgb(var(--color-bg-light));
  border-radius: 36px;
}

.content.wide .swiper.employees {
  width: calc(100% + var(--spacing-level-4) * 2);
  margin: calc(0px - var(--spacing-level-4));
}

.swiper.employees.mini {
  width: 100% !important;
  margin: calc(0px - var(--spacing-level-4)) 0 !important;
  padding: 0;
  border-radius: 0px;
  background: transparent;
}

.swiper.footer {
  width: calc(100% + var(--spacing-level-3) * 2);
  padding: 0 var(--spacing-level-3);
  height: auto;
  margin: var(--spacing-level-4) calc(0px - var(--spacing-level-3));
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  user-select: none;
}

.swiper.footer::before {
  content: "";
  z-index: 10;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  width: var(--spacing-level-3);
  background: linear-gradient(
    to right,
    rgb(var(--color-accent-dark)),
    rgb(var(--color-accent-dark), 0)
  );
}

.swiper.footer::after {
  content: "";
  z-index: 10;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  height: 100%;
  width: var(--spacing-level-3);
  background: linear-gradient(
    to left,
    rgb(var(--color-accent-dark)),
    rgb(var(--color-accent-dark), 0)
  );
}

.swiper.edgeless {
  height: auto;
  aspect-ratio: 2 / 1;
  max-height: 650px;
  overflow: visible !important;
  width: calc(100% - var(--spacing-level-1) * 2);
  --swiper-pagination-bottom: calc(-8px - var(--spacing-level-4));
  margin-top: var(--spacing-level-4);
  margin-bottom: calc(var(--spacing-level-4) + 8px);
}

.swiper-wrapper {
  position: absolute;
  align-items: stretch;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
}

.swiper.hero .swiper-slide {
  padding: calc(var(--swiper-padding) * 2) var(--swiper-padding);
  --text-color: var(--color-text-dark);
  color: rgb(var(--text-color));
  align-items: flex-end;
}

.swiper.employees .swiper-slide {
  height: auto;
  width: 384px;
  aspect-ratio: 1;
  padding: 0px;
  background: rgb(var(--color-accent-dark));
  text-decoration: none;
  border-radius: 20px;
  max-width: 100%;
  overflow: hidden !important;
}

.swiper.footer .swiper-slide {
  height: 64px;
  width: auto;
  opacity: 0.75;
  overflow: hidden;
  border-radius: 8px;
  transition: all 0.15s ease;
  aspect-ratio: 4 / 1;
}

.swiper.footer .swiper-slide:hover {
  opacity: 1;
}

.swiper.footer .swiper-slide > img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}

.swiper.edgeless .swiper-slide {
  --text-color: var(--color-text-dark);
  border-radius: 4px;
}

@keyframes slide-appear {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 0.5;
  }
}

.swiper.edgeless .swiper-slide-active {
  opacity: 1;
}

.swiper.employees .swiper-slide > .background {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
  overflow: hidden !important;
  filter: brightness(1.05) contrast(105%);
}

.swiper.employees .swiper-slide:hover > .background {
  filter: brightness(0.7);
  transform: scale(1.1);
}

.swiper.employees .swiper-slide > .background > svg {
  height: 40px;
  width: 40px;
}

.swiper.employees .swiper-slide > .background > svg > * {
  fill: rgb(var(--color-text-dark));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--color-text-dark));
  stroke-width: 0;
  transition: fill 0.3s;
}

.swiper.hero .swiper-slide > .shadow {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(
    25deg,
    rgb(var(--color-bg-black), 0.5),
    rgb(var(--color-bg-black), 0) 50%
  );
}

.swiper.edgeless .swiper-slide > .shadow {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 35%;
  width: 100%;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(
    to top,
    rgb(var(--color-bg-black), 0.5),
    rgb(var(--color-bg-black), 0)
  );
}

.swiper.edgeless .swiper-slide {
  padding: var(--spacing-level-3) calc(var(--spacing-level-3) * 2);
}

.swiper.edgeless .swiper-slide > .content {
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  transition: 0.3s ease 0.325s;
  transform: translateY(100%);
  opacity: 0;
}

.swiper.edgeless .swiper-slide-active > .content {
  transform: translateY(0%);
  opacity: 1;
}

.swiper.employees .swiper-slide > .content {
  gap: var(--spacing-level-5);
  padding: var(--spacing-level-3);
  width: 100%;
  color: rgb(var(--text-color)) !important;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(
    to top,
    rgb(var(--color-bg-dark), 0.75),
    rgb(var(--color-bg-dark), 0)
  );
  max-height: 100%;
}

.swiper.edgeless .swiper-slide > .content > .title {
  font-size: var(--text-size-header-medium);
  -webkit-line-clamp: 1;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.swiper.employees .swiper-slide > .content > .title {
  font-size: var(--text-size-text-large);
  font-weight: 700;
}

.swiper.employees .swiper-slide:hover > .content > .title {
  text-decoration: underline;
}

.swiper.employees .swiper-slide > .content > .subtitle {
  font-weight: 500;
  font-size: var(--text-size-text-small);
  margin-bottom: calc(0px - var(--spacing-level-4));
}

.swiper.employees .swiper-slide > .content > .description {
  font-size: var(--text-size-text-small);
  color: rgb(217, 219, 222);
  --cropped-height: 17.5px;
  max-height: var(--cropped-height);
  overflow: hidden;
  transition: all 0.3s ease;
  width: 100%;
}

.swiper.employees
  .swiper-slide
  > .content
  > .description:not(.not-resizable)
  > div:not(.cropped) {
  opacity: 0;
  transition: all 0.1s ease;
  margin-top: calc(0px - var(--cropped-height));
}

.swiper.employees
  .swiper-slide
  > .content
  > .description:not(.not-resizable)
  > div.cropped {
  white-space: nowrap;
  text-overflow: ellipsis;
  position: sticky;
  top: 0;
  overflow: hidden;
  display: block;
  width: 100%;
  height: var(--cropped-height);
  transition: all 0.1s ease;
}

.swiper.employees
  .swiper-slide:hover
  > .content
  > .description:not(.not-resizable) {
  max-height: var(--description-height, 75px);
  overflow: auto;
}

.swiper.employees
  .swiper-slide:hover
  > .content
  > .description:not(.not-resizable)
  > div:not(.cropped) {
  opacity: 1;
}

.swiper.employees
  .swiper-slide:hover
  > .content
  > .description:not(.not-resizable)
  > div.cropped {
  opacity: 0;
}

.swiper.employees
  .swiper-slide:hover
  > .content
  > .description:not(.not-resizable) {
  overflow-x: hidden;
  overflow-y: auto;
}

.swiper.employees .swiper-slide > .content > .description {
  scrollbar-width: thin;
  scrollbar-color: transparent transparent;
}

.swiper.employees .swiper-slide > .content > .description::-webkit-scrollbar {
  width: 5px;
  height: 5px;
  background-color: transparent;
  border-radius: 5px;
}

.swiper.employees
  .swiper-slide
  > .content
  > .description::-webkit-scrollbar-thumb {
  background-color: rgb(var(--color-bg-light), 0.5);
  border-radius: 5px;
  border: 1px solid rgba(0, 0, 0, 0);
  background-clip: padding-box;
}

.swiper.hero .swiper-slide > .content > .title,
.swiper.hero .swiper-slide > .content > .subtitle {
  width: 750px;
}

.swiper.hero .swiper-slide > .content > .subtitle > a::after {
  display: inline-block;
  content: "→";
  background-position: center;
  background-repeat: no-repeat;
  margin-left: var(--spacing-level-5);
}

.swiper .swiper-control-btn-container {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  width: auto;
  padding: var(--spacing-level-4);
  cursor: pointer;
  z-index: 10;
  transform: translateX(0%);
  outline: none;
  transition: all 0.15s 0.15s ease;
  opacity: 1;
  overflow: hidden;
}

.swiper > .swiper-control-btn-container.swiper-button-lock,
.swiper > .swiper-control-btn-container.swiper-button-disabled,
body.before-zoomed-in .swiper > .swiper-control-btn-container {
  pointer-events: none;
}

.swiper
  > .swiper-control-btn-container.swiper-button-lock
  > .swiper-control-btn,
.swiper
  > .swiper-control-btn-container.swiper-button-disabled
  > .swiper-control-btn,
body.before-zoomed-in
  .swiper
  > .swiper-control-btn-container
  > .swiper-control-btn {
  transform: translateX(-300%);
  pointer-events: none;
}

.swiper
  > .swiper-control-btn-container.next.swiper-button-lock
  > .swiper-control-btn,
.swiper
  > .swiper-control-btn-container.next.swiper-button-disabled
  > .swiper-control-btn,
body.before-zoomed-in
  .swiper
  > .swiper-control-btn-container.next
  > .swiper-control-btn {
  transform: translateX(300%);
  pointer-events: none;
}

body.before-zoomed-in
  .swiper
  > .swiper-control-btn-container
  > .swiper-control-btn {
  transition: all 0.15s ease;
}

.swiper .swiper-control-btn-container.next {
  left: unset;
  right: 0;
}

.swiper > .swiper-control-btn-container > .swiper-control-btn {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  height: 40px;
  margin: auto;
  width: auto;
  background: rgb(var(--color-bg-dark), 0.5);
  border-radius: 4px;
  cursor: pointer;
  padding: calc(var(--spacing-level-5) * 2) 0;
  backdrop-filter: saturate(180%) blur(20px) brightness(0.75);
  box-shadow: 0 0 16px 0 rgb(var(--color-bg-black), 0.15);
  transition: all 0.15s 0.15s ease;
}

.swiper > .swiper-control-btn-container > .swiper-control-btn > svg {
  height: 16px;
  width: auto;
  opacity: var(--color-text-transparency);
  transition: all 0.15s;
}

.swiper > .swiper-control-btn-container > .swiper-control-btn > svg > * {
  fill: rgb(var(--color-text-dark));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--color-text-dark));
  stroke-width: 3px;
}

.swiper > .swiper-control-btn-container:hover > .swiper-control-btn > svg {
  opacity: 1;
}

.swiper.hero .swiper-pagination {
  position: relative !important;
  left: unset !important;
  top: unset !important;
  right: unset !important;
  bottom: calc((var(--swiper-padding) * 2 + 12px) / 2) !important;
  margin: 0 auto;
  padding: 0 var(--swiper-padding);
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  justify-content: flex-start !important;
  align-items: flex-end !important;
  gap: var(--spacing-level-5) !important;
  max-width: calc(var(--body-container-width) + var(--swiper-padding) * 2);
  width: 100% !important;
  height: 12px !important;
}

.swiper.hero .swiper-pagination > .swiper-pagination-bullet {
  margin: 0 !important;
  width: 40px !important;
  height: 8px !important;
  border-radius: 4px !important;
  background: rgb(var(--color-text-dark)) !important;
  transition: height 0.3s ease-in-out, opacity 0.15s ease-in-out;
  overflow: hidden;
  opacity: 0.5 !important;
}

.swiper.edgeless .swiper-pagination > .swiper-pagination-bullet {
  margin: 0 var(--spacing-level-5) !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 4px !important;
  background: rgb(var(--color-text-light)) !important;
  transition: all 0.15s ease-in-out;
}

.swiper.edgeless .swiper-pagination > .swiper-pagination-bullet-active {
  background: rgb(var(--color-active-element)) !important;
}

.swiper.hero .swiper-pagination > .swiper-pagination-bullet::after {
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgb(var(--color-active-element));
  opacity: 0;
  transition: all 0.15s ease-in-out, transform 1000000000s;
  border-radius: 4px;
  transform: translateX(var(--progress));
}

.swiper.hero .swiper-pagination > .swiper-pagination-bullet-active {
  height: 12px !important;
  opacity: 1 !important;
}

.swiper.hero .swiper-pagination > .swiper-pagination-bullet:hover {
  opacity: 1 !important;
}

.swiper.hero .swiper-pagination > .swiper-pagination-bullet-active::after {
  opacity: 1;
  transition: transform 0.15s;
}

footer {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 100%;
  background: rgb(var(--color-bg-dark));
  --text-color: var(--color-text-dark);
  padding: 0 var(--spacing-level-3);
  background: rgb(var(--color-accent-dark));
}

footer > .container {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 100%;
  margin: auto;
  padding: var(--spacing-level-3) 0;
  max-width: var(--body-container-width);
  z-index: 2;
  --footer-gap: var(--spacing-level-3);
  gap: var(--footer-gap);
  border-top: 1px solid rgb(var(--text-color), 0.1);
}

footer > .container > .breadcrumbs {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  padding-left: 26.33px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  gap: var(--spacing-level-5);
  overflow: auto;
}

footer > .container > .breadcrumbs > * {
  height: auto;
  width: auto;
  font-weight: 400;
  font-size: var(--text-size-text-small);
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  opacity: var(--color-text-transparency);
  flex-shrink: 0;
  font-size: var(--text-size-text-small);
  color: rgb(var(--text-color));
  overflow: visible;
  max-width: 100%;
}

footer > .container > .breadcrumbs > * > span {
  width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 500px;
}

footer > .container > .breadcrumbs > a {
  cursor: pointer;
  text-decoration: none;
}

footer > .container > .breadcrumbs > .home {
  opacity: 1;
  margin-left: -26.33px;
}

footer > .container > .breadcrumbs > a:hover {
  text-decoration: underline;
}

footer > .container > .breadcrumbs > * > img {
  height: 100%;
  width: 100%;
  object-fit: contain;
  max-height: 14px;
}

footer > .container > .breadcrumbs > *:not(.home)::before {
  content: "";
  background-image: url("data:image/svg+xml,%0A%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8.91003 19.9201L15.43 13.4001C16.2 12.6301 16.2 11.3701 15.43 10.6001L8.91003 4.08008' stroke='%23ffffff' stroke-width='2' stroke-miterlimit='10' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
  height: 16px;
  width: 16px;
  min-width: 16px;
  background-position: center;
  background-origin: border-box;
  background-repeat: no-repeat;
  margin: 0 var(--spacing-level-5) 0 0;
  opacity: 0.5;
}

footer > .container > .links {
  display: inline-flex;
  position: relative;
  gap: var(--spacing-level-3);
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
  flex-wrap: wrap;
}

footer > .container > .links > .group {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: flex-start;
  font-weight: 400;
  gap: var(--spacing-level-4);
}

footer > .container > .links > .group *:not(.group) {
  text-decoration: none;
  font-size: var(--text-size-text-small);
  color: rgb(var(--text-color), var(--color-text-transparency));
}

footer > .container > .links > .group *:not(.group):not(.title):hover {
  text-decoration: underline;
}

footer > .container > .links > .group *:not(.group) svg {
  height: auto;
  width: 24px;
}

footer > .container > .links > .group *:not(.group) svg > * {
  fill: rgb(var(--text-color));
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke: rgb(var(--text-color));
  stroke-width: 0px;
}

footer > .container > .links > .group > .title {
  font-weight: 500;
  color: rgb(var(--text-color));
  cursor: text;
}

footer > .container > .links > .group > a + .title {
  margin-top: calc(var(--spacing-level-3) - var(--spacing-level-4));
}

footer > .container > .links > .group > .group {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  width: 100%;
  align-items: center;
  gap: var(--spacing-level-5);
  color: rgb(var(--text-color), var(--color-text-transparency));
}

footer > .container > .links .group.site-footer-metrics > a {
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-level-5);
  padding: calc(var(--spacing-level-4) / 2);
  border-radius: 8px;
  background: rgb(var(--color-accent-dark));
  opacity: var(--color-text-transparency);
}

footer > .container > .links .group.site-footer-metrics > a:hover {
  filter: brightness(1.29);
  opacity: 1;
}

footer > .container > .links .group.site-footer-metrics > a > div {
  max-width: 64px;
  overflow: hidden;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: center;
  border-radius: 4px;
}

footer > .container > .links .group.site-footer-metrics > a > div > img {
  margin: -1.5px -1px -2.5px -1px;
}

footer > .container > .text {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  font-size: 14px;
  font-weight: 400;
  color: rgb(var(--text-color), var(--color-text-transparency));
  font-size: var(--text-size-text-small);
  gap: var(--spacing-level-5);
}

footer > .container > .sepatator {
  width: 100%;
  height: 1px;
  background: rgb(var(--text-color), 0.1);
  margin: calc(0px - var(--footer-gap) + var(--spacing-level-5) * 2) 0;
}

@media (min-width: 951px) {
  .on-mobile {
    display: none !important;
  }
}

@media (max-width: 1024px) {
  .top-menu > .container > .buttons > * {
    font-size: var(--text-size-text-small);
  }
}

@media (max-width: 1350px) {
  .section.horizontal .content {
    padding: var(--spacing-level-1);
  }

  .section > .content > .list-with-icons,
  .section > .container > .content > .list-with-icons {
    padding-top: var(--spacing-level-4);
    grid-template-columns: minmax(0, 1fr);
    gap: var(--spacing-level-4);
  }
}

@media (max-width: 950px) {
  :root {
    /* Отступы */
    --spacing-level-1: 40px;
    --spacing-level-2: 36px;
    --spacing-level-3: 32px;
    --spacing-level-4: 16px;
    --spacing-level-5: 5px;
    /* Размеры текста */
    --text-size-header-large: 28px;
    --text-size-header-medium: 24px;
    --text-size-header-small: 20px;
    --text-size-text-large: 18px;
    --text-size-text-medium: 16px;
    --text-size-text-small: 14px;
  }

  .on-laptop {
    display: none !important;
  }

  .top-menu > .container > .logo {
    z-index: 3;
    padding: var(--spacing-level-4) var(--spacing-level-4)
      var(--spacing-level-4) 0;
  }

  .top-menu.banner > .container > .text {
    padding: 0;
  }

  .top-menu.banner > .container > .buttons.right {
    padding-right: 0;
  }

  .section > .content > .icons > img,
  .section > .container > .content > .icons > img {
    max-width: 192px;
  }

  .top-menu.scrollable > .container > .logo {
    padding: var(--spacing-level-4) 0;
    margin: 0 auto;
  }

  .top-menu > .container > .logo > .text > div {
    font-size: calc(var(--text-size-text-medium) - 2px);
  }

  .top-menu:not(.scrollable) > .container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    background: rgb(var(--color-accent-light));
  }

  .top-menu > .container > .open-button,
  .top-menu > .container > .back-button {
    display: flex;
  }

  .top-menu > .container > .open-button {
    z-index: 5;
  }

  .top-menu > .container > .buttons > * {
    padding: calc(var(--spacing-level-5) * 2);
  }

  .top-menu > .container > .buttons > * > svg {
    height: 16px;
    width: 16px;
  }

  .top-menu > .container > .buttons > * > svg.filled {
    height: 20px;
    width: 20px;
  }

  .top-menu > .container > .buttons > * > svg > * {
    stroke-width: 2.5px;
  }

  .top-menu > .container > .buttons:not(.right) {
    width: 100%;
    height: calc(var(--vh, 1vh) * 100);
    padding: calc(64px + var(--spacing-level-3)) var(--spacing-level-3)
      var(--spacing-level-3) var(--spacing-level-3);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    flex-direction: column;
    justify-content: flex-start;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: 0;
    overflow: auto;
    z-index: 1;
    background: rgb(var(--color-accent-light));
    transform: translateY(-100%);
  }

  .top-menu > .container > .buttons:not(.right) > .separator {
    display: block;
  }

  .top-menu > .container > .buttons:not(.right) > * {
    font-size: var(--text-size-text-large);
    padding-left: 0;
    padding-right: 0;
  }

  .top-menu > .container > .buttons:not(.right) > *::after {
    display: none;
  }

  .top-menu-expanded {
    z-index: 2;
    width: 100%;
    height: 100%;
    max-height: calc(var(--vh, 1vh) * 100 - var(--top-menu-position) - 1px);
    top: calc(var(--top-menu-position) + 1px);
    padding: 0 var(--spacing-level-3);
    box-shadow: calc(var(--vh, 1vh) * 100) calc(var(--vh, 1vh) * 100) 0
      calc(var(--vh, 1vh) * 100) rgb(var(--color-bg-black), 0.7);
  }

  @keyframes top-menu-expanded-appear {
    0% {
      opacity: 0;
      transform: translateX(16px);
      pointer-events: none;
    }

    100% {
      opacity: 1;
      transform: translateX(0px);
      pointer-events: all;
    }
  }

  @keyframes top-menu-expanded-disappear {
    0% {
      opacity: 1;
      transform: translateX(0px);
      pointer-events: none;
    }

    100% {
      opacity: 0;
      transform: translateX(16px);
    }
  }

  .top-menu-expanded > .container {
    height: auto !important;
  }

  .top-menu-expanded > .container > div {
    grid-template-columns: 1fr;
  }

  .top-menu-expanded > .container > div > * {
    gap: var(--spacing-level-5) !important;
  }

  .top-menu-expanded > .container > div > .group > .title {
    padding: 0 0 var(--spacing-level-3) 0;
  }

  .top-menu-expanded > .container > div > .group > .title::after {
    bottom: calc((var(--spacing-level-3) - var(--spacing-level-5)) / 2 - 1.5px);
  }

  .top-menu-expanded > .container > div > * > * {
    padding: var(--spacing-level-5) var(--spacing-level-4);
    font-size: var(--text-size-text-large);
  }

  .section {
    padding: var(--spacing-level-1) var(--spacing-level-3);
  }

  .section.horizontal > .container {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
  }

  .section .image {
    width: 100%;
    max-width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    order: 1;
  }

  .section.horizontal .content {
    padding: calc(var(--spacing-level-1) * 1.5) var(--spacing-level-1);
  }

  .section.horizontal .container > .content,
  .section.horizontal .container > .content > * {
    text-align: left !important;
    align-items: flex-start !important;
  }

  .swiper.hero .swiper-slide > .shadow {
    width: 100%;
    height: 65%;
    top: unset;
    bottom: 0;
    background: linear-gradient(
      to top,
      rgb(var(--color-bg-black), 0.75),
      rgb(var(--color-bg-black), 0)
    );
  }

  .section > .content > .book-cards,
  .section > .container > .content > .book-cards {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    margin-left: calc(0px - var(--spacing-level-3));
    width: calc(100% + var(--spacing-level-3) * 2);
    margin-right: calc(0px - var(--spacing-level-3));
  }

  .swiper.employees {
    width: calc(100% + var(--spacing-level-4) * 2);
    margin: var(--spacing-level-4) calc(0px - var(--spacing-level-4));
  }

  .swiper.edgeless {
    aspect-ratio: 1;
    width: calc(100% + var(--spacing-level-3) * 2);
    margin-left: calc(0px - var(--spacing-level-3));
    margin-right: calc(0px - var(--spacing-level-3));
  }

  .swiper.edgeless .swiper-slide {
    padding: var(--spacing-level-3);
    border-radius: 0;
    opacity: 1;
    transition: all 0s;
    animation: none;
  }

  .swiper.edgeless .swiper-slide > .content > .title {
    font-size: var(--text-size-header-medium);
    -webkit-line-clamp: 3;
  }

  .swiper.edgeless .subtitle {
    display: none;
  }

  footer > .container > .text {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (min-width: 951px) {
  .top-menu > .container > .buttons:not(.right) {
    transform: none !important;
    opacity: 1 !important;
  }

  .top-menu > .container > .buttons:not(.right) > * {
    transform: none !important;
    opacity: var(--color-text-transparency) !important;
  }

  .top-menu > .container > .buttons:not(.right) > *:hover,
  .top-menu > .container > .buttons:not(.right) > *.active {
    opacity: 1 !important;
  }
}

.add-0 {
  margin-top: calc(0px - var(--spacing-level-4)) !important;
}
