.button {
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.1111111111vw;
  background: #ffffff;
  height: 3.6111111111vw;
  padding: 1.1111111111vw 2.2222222222vw;
  cursor: pointer;
  transition: 0.25s ease;
  transition-property: color, border, background;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .button {
    font-size: 3.8888888889vw;
  }
}
.button {
  font-weight: 700;
}
@media (hover: hover) {
  .button:hover {
    background: #1B1B1A;
    color: #ffffff;
  }
}
@media screen and (max-width: 1023px) {
  .button {
    gap: 3.3333333333vw;
    height: 12.2222222222vw;
    padding: 3.8888888889vw 6.6666666667vw;
  }
}
.button svg {
  width: 1.3888888889vw;
  height: 1.3888888889vw;
}
@media screen and (max-width: 1023px) {
  .button svg {
    width: 4.4444444444vw;
    height: 4.4444444444vw;
  }
}
.button-outline {
  background: #ffffff;
  border: 1px solid #1B1B1A;
  color: #1B1B1A;
}
@media (hover: hover) {
  .button-outline:hover {
    background: #1B1B1A;
    color: #ffffff;
  }
}
.button-secondary {
  background: #1B1B1A;
  color: #ffffff;
}
@media (hover: hover) {
  .button-secondary:hover {
    background: #077761;
    color: #ffffff;
  }
}
.button-primary {
  background: #077761;
  color: #ffffff;
}
@media (hover: hover) {
  .button-primary:hover {
    background: #084E41;
    color: #ffffff;
  }
}
.button-header {
  color: #1B1B1A;
  background: transparent;
  width: 1.3888888889vw;
  height: 1.3888888889vw;
  padding: 0;
  border: 0;
  cursor: pointer;
}
@media screen and (max-width: 1023px) {
  .button-header {
    width: 6.6666666667vw;
    height: 6.6666666667vw;
  }
}
.button-header svg {
  width: 1.3888888889vw;
  height: 1.3888888889vw;
}
@media screen and (max-width: 1023px) {
  .button-header svg {
    width: 6.6666666667vw;
    height: 6.6666666667vw;
  }
}

[hidden] {
  display: none !important;
}

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

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

.pagination {
  margin: 2.7777777778vw 0;
}
@media screen and (max-width: 1023px) {
  .pagination {
    margin-top: 13.3333333333vw 0;
  }
}
.pagination-block {
  display: flex;
  align-items: center;
  background: #ffffff;
  padding: 0.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .pagination-block {
    padding: 1.1111111111vw;
  }
}
.pagination-list {
  position: relative;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  gap: 0.2777777778vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .pagination-list {
    gap: 1.1111111111vw;
  }
}
.pagination-list li {
  overflow: hidden;
  position: relative;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  width: 2.4305555556vw;
  height: 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .pagination-list li {
    width: 7.5vw;
    height: 8.8888888889vw;
  }
}
.pagination-list li a {
  overflow: hidden;
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  width: 100%;
  height: 100%;
  transition: all 0.2s ease;
  border-bottom: 1px solid transparent;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .pagination-list li a {
    font-size: 3.8888888889vw;
  }
}
.pagination-list li a {
  font-weight: 700;
}
.pagination-list li a:focus-visible {
  color: #ffffff;
  background: #077761;
}
.pagination-list li a span {
  position: relative;
  z-index: 3;
}
@media (hover: hover) {
  .pagination-list li a:hover {
    color: #1B1B1A;
    background: #fbde98;
  }
  .pagination-list li a:hover svg {
    color: #1B1B1A;
  }
}
.pagination-list li.active a {
  background: transparent;
  color: #1B1B1A;
  border-bottom: 1px solid #077761;
}
.pagination-list li.active a::before {
  display: none;
}
.pagination-list li.disabled {
  pointer-events: none;
}
.pagination-list li.disabled span {
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: #8F9090;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .pagination-list li.disabled span {
    font-size: 3.8888888889vw;
  }
}
.pagination-list li.disabled span {
  font-weight: 700;
}
.pagination-list li.arrow {
  width: 2.7777777778vw;
  height: 2.7777777778vw;
  background: #077761;
  color: #ffffff;
}
@media screen and (max-width: 1023px) {
  .pagination-list li.arrow {
    width: 8.8888888889vw;
    height: 8.8888888889vw;
  }
}
.pagination-list li.arrow svg {
  color: #ffffff;
  width: 1.1111111111vw;
  height: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .pagination-list li.arrow svg {
    width: 3.8888888889vw;
    height: 3.8888888889vw;
  }
}
.pagination-list li.arrow.disabled {
  border: 1px solid #077761;
  background: #ffffff;
}
.pagination-list li.arrow.disabled svg {
  color: #077761;
}
.tabs {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 1023px) {
  .tabs {
    overflow: auto;
    justify-content: center;
    flex-wrap: nowrap;
    width: 100%;
    padding: 0 5.5555555556vw;
  }
}

.tab, .tab_d {
  overflow: hidden;
  text-overflow: ellipsis;
  text-wrap: nowrap;
  text-transform: uppercase;
  text-align: center;
  display: inline-block;
  align-items: center;
  justify-content: center;
  background: transparent;
  padding: 0.9722222222vw 1.6666666667vw;
  border-top: 1px solid #1B1B1A;
  border-right: 1px solid #1B1B1A;
  border-bottom: 1px solid #1B1B1A;
  transition: all 0.2s ease;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .tab, .tab_d {
    font-size: 3.8888888889vw;
  }
}
.tab:first-child, .tab_d:first-child {
  border-left: 1px solid #1B1B1A;
}
@media (hover: hover) {
  .tab:hover, .tab_d:hover {
    background: #fbde98;
  }
}
@media screen and (max-width: 1023px) {
  .tab, .tab_d {
    flex-shrink: 0;
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.tab.active {
  background: #1B1B1A;
  color: #ffffff;
}
.tab_d.disabled {
    color: #999;
    background: #eee;
    cursor: default;
}
[data-tab-item] {
  display: none;
  transition: opacity 0.25s ease;
}
[data-tab-item].active {
  display: flex;
}

.dropdown {
  position: relative;
  z-index: 10;
  min-width: 27.7777777778vw;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.dropdown-btn {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #ffffff;
  gap: 1.3888888889vw;
  padding: 0.8333333333vw 1.6666666667vw;
  border: 1px solid #077761;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .dropdown-btn {
    font-size: 5vw;
  }
}
@media screen and (max-width: 1023px) {
  .dropdown-btn {
    gap: 5.5555555556vw;
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.dropdown-btn {
  line-height: 140%;
}
@media (hover: hover) {
  .dropdown-btn:hover {
    color: #ffffff;
    background: #077761;
  }
}
.dropdown-btn.active svg {
  transform: rotate(180deg);
}
.dropdown-btn-text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dropdown-btn svg {
  flex-shrink: 0;
  width: 1.6666666667vw;
  height: 1.6666666667vw;
  transition: transform 0.2s ease;
}
@media screen and (max-width: 1023px) {
  .dropdown-btn svg {
    width: 5.5555555556vw;
    height: 5.5555555556vw;
  }
}
.dropdown-list {
  position: absolute;
  z-index: 2;
  bottom: 0;
  left: 0;
  transform: translate(0, 95%);
  background: #ffffff;
  width: 100%;
  border-bottom: 1px solid #077761;
  border-right: 1px solid #077761;
  border-left: 1px solid #077761;
  opacity: 0;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: 0.25s ease;
  transition-property: opacity, transform;
}
.dropdown-list.active {
  opacity: 1;
  pointer-events: all;
  transform: translate(0, 100%);
}
.dropdown-list ul {
  overflow: auto;
  max-height: 13.5416666667vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .dropdown-list ul {
    max-height: 44.4444444444vw;
  }
}
.dropdown-list ul li {
  list-style: none;
}
.dropdown-list ul li:nth-child(2n) {
  background: #F7F7F8;
}
.dropdown-list ul li a {
  display: flex;
  padding: 0.8333333333vw 1.1111111111vw;
  transition: 0.2s ease;
  transition-property: color, background;
  color: #003154;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .dropdown-list ul li a {
    font-size: 5vw;
  }
}
@media screen and (max-width: 1023px) {
  .dropdown-list ul li a {
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.dropdown-list ul li a {
  line-height: 140%;
}
@media (hover: hover) {
  .dropdown-list ul li a:hover {
    color: #ffffff;
    background: #077761;
  }
}
.dropdown-list ul li.active {
  background: #fbde98;
}
.dropdown-list ul li.active a {
  color: #1B1B1A;
  background: #fbde98;
}

@font-face {
  font-family: "Oswald";
  src: url("../fonts/Oswald/Oswald-Variable.ttf");
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Onest";
  src: url("../fonts/Onest/Onest-Variable.ttf");
  font-style: normal;
  font-display: swap;
}
* {
  box-sizing: border-box;
  margin: 0;
  font-variant-numeric: lining-nums;
  -moz-osx-font-smoothing: grayscale;
  /* Firefox */
  -webkit-font-smoothing: antialiased;
  /* WebKit  */
  font-synthesis: none !important;
  -webkit-text-size-adjust: 100%;
  text-decoration: none;
  hyphens: manual;
}

html {
  scrollbar-gutter: stable;
}

body {
  overflow-x: hidden;
  background: #ffffff;
  -webkit-font-smoothing: antialiased;
  font-optical-sizing: none;
  font-family: "Onest", sans-serif, sans-serif;
}
body.lock {
  overflow: hidden;
}
@media screen and (max-width: 1023px) {
  body.lock-m {
    overflow: hidden;
  }
}

a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 2px solid #0085fe !important;
}

img,
video {
  max-width: 100%;
}

img[parse-svg] {
  opacity: 0;
}

.container {
  width: 100%;
  max-width: 100%;
  padding: 0 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .container {
    padding: 0 5.5555555556vw;
  }
}

.page {
  background: #ffffff;
  min-height: 60vh;
  padding-top: 10.6944444444vw;
}
@media screen and (max-width: 1023px) {
  .page {
    padding-top: 28.3333333333vw;
  }
}
.page-main {
  padding-top: 0;
}

.header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  padding: 0.5555555556vw 0;
  transition: 0.3s ease;
  transition-property: transform, padding;
}
@media screen and (max-width: 1023px) {
  .header {
    padding: 0 0;
  }
  .header .container {
    padding: 0 4.4444444444vw;
  }
}
.header.hidden {
  transform: translate(0, -110%);
}
.header.scroll {
  padding: 0 0;
}
.header-wrapper {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 1023px) {
  .header-wrapper {
    justify-content: space-between;
    padding-top: 6.1111111111vw;
  }
}
.header-block {
  position: relative;
  display: flex;
  min-width: 71.5277777778vw;
  padding: 2.7777777778vw 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .header-block {
    width: 100%;
    padding: 6.6666666667vw 5.5555555556vw;
  }
}
.header-block::before, .header-block::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  background: #fbde98;
  width: 100%;
  height: 4.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .header-block::before, .header-block::after {
    height: 12.2222222222vw;
    left: 17.7777777778vw;
    width: auto;
    right: 0;
  }
}
.header-block::after {
  background: transparent;
  z-index: 2;
  left: 0.2777777778vw;
  right: 0.2777777778vw;
  width: auto;
  height: 3.75vw;
  border: 0.0694444444vw solid #084E41;
}
@media screen and (max-width: 1023px) {
  .header-block::after {
    left: 17.7777777778vw;
    right: 1.1111111111vw;
    height: 10vw;
    border: 0.2777777778vw solid #084E41;
  }
}
.header-logo {
  position: absolute;
  z-index: 5;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 1023px) {
  .header-logo {
    left: 1.6666666667vw;
    transform: translate(0, -50%);
  }
}
.header-nav {
  display: flex;
  align-items: center;
  height: 4.4444444444vw;
  width: 100%;
}
.header-nav ul {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 2.5vw;
  width: 100%;
  padding: 0;
}
.header-nav ul li {
  list-style: none;
}
.header-nav ul li:nth-child(4) {
  margin-left: auto;
}
.header-nav ul li:nth-child(3) {
  margin-right: auto;
}
.header-nav ul li a {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .header-nav ul li a {
    font-size: 5vw;
  }
}
.header-nav ul li a span {
  position: relative;
  transition: color 0.2s ease;
}
.header-nav ul li a span::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #077761;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .header-nav ul li a span:hover {
    color: #077761 !important;
  }
  .header-nav ul li a span:hover::after {
    background: #077761;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.header-btn {
  position: relative;
  z-index: 4;
  display: flex;
  align-items: center;
  margin-left: auto;
}

.burger {
  position: fixed;
  z-index: 900;
  top: 0;
  right: -105vw;
  background: #fbde98;
  width: 100%;
  height: 100%;
  display: none;
  transition: right 0.25s ease;
  overscroll-behavior: contain;
}
.burger.active {
  right: 0;
}
@media screen and (max-width: 1023px) {
  .burger {
    display: block;
  }
}
.burger-wrapper {
  overflow: auto;
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 6.6666666667vw 5.5555555556vw 13.8888888889vw;
}
.burger-top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding-right: 4.4444444444vw;
}
.burger-top::after {
  content: "";
  position: absolute;
  z-index: -1;
  left: 11.1111111111vw;
  right: 0;
  top: 50%;
  transform: translate(0, -50%);
  border: 0.2777777778vw solid #084E41;
  height: 10vw;
}
.burger-logo {
  position: relative;
  z-index: 3;
}
.burger-list {
  margin: 17.7777777778vw 0;
}
.burger-list ul {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0;
}
.burger-list ul li {
  list-style: none;
  margin-top: 6.6666666667vw;
}
.burger-list ul li:first-child {
  margin-top: 0;
}
.burger-list ul li a {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.9444444444vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .burger-list ul li a {
    font-size: 5vw;
  }
}
.burger-contacts {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.2222222222vw;
  margin-top: auto;
}
.burger-contacts a {
  color: #077761;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .burger-contacts a {
    font-size: 6.6666666667vw;
  }
}
.burger-socials {
  margin-top: 4.4444444444vw;
}
.burger-socials a {
  color: #077761 !important;
}

.footer {
  position: relative;
  background: linear-gradient(21.46deg, #084E41 -13.13%, #077761 65.86%);
  margin-top: 8.3333333333vw;
  padding: 3.8888888889vw 0;
}
@media screen and (max-width: 1023px) {
  .footer {
    margin-top: 27.7777777778vw;
    padding: 69.4444444444vw 0 11.1111111111vw 0;
  }
}
.footer-bg {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 50%;
  bottom: 0;
  transform: translate(-50%, 0);
  width: 27.0833333333vw;
}
@media screen and (max-width: 1023px) {
  .footer-bg {
    width: 100%;
    height: 58.3333333333vw;
    left: 0;
    bottom: unset;
    transform: translate(0, 0);
  }
}
.footer-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.footer-logo {
  position: absolute;
  z-index: 3;
  top: -4.7222222222vw;
  left: 50%;
  transform: translate(-50%, 0);
}
@media screen and (max-width: 1023px) {
  .footer-logo {
    top: -13.3333333333vw;
  }
}
.footer .container {
  position: relative;
  z-index: 2;
}
.footer-wrapper {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 1023px) {
  .footer-wrapper {
    flex-direction: column;
  }
}
.footer-left, .footer-right {
  display: flex;
  flex-direction: column;
  gap: 1.6666666667vw;
  width: 28.4722222222vw;
}
@media screen and (max-width: 1023px) {
  .footer-left, .footer-right {
    width: 100%;
    gap: 6.6666666667vw;
    text-align: center;
    align-items: center;
  }
}
.footer-right {
  align-items: flex-end;
  gap: 2.2222222222vw;
}
@media screen and (max-width: 1023px) {
  .footer-right {
    align-items: center;
    gap: 6.6666666667vw;
    margin-top: 11.1111111111vw;
  }
}
.footer-info {
  display: flex;
  flex-direction: column;
  gap: 0.2777777778vw;
  max-width: 21.3888888889vw;
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .footer-info {
    font-size: 3.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .footer-info {
    max-width: 100%;
    gap: 3.3333333333vw;
  }
}
.footer-contacts {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.2777777778vw;
  margin-top: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .footer-contacts {
    align-items: center;
    gap: 1.1111111111vw;
    margin-top: 3.3333333333vw;
  }
}
.footer-contacts a {
  color: #fbde98;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .footer-contacts a {
    font-size: 5vw;
  }
}
.footer-contacts a {
  position: relative;
  transition: color 0.2s ease;
}
.footer-contacts a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fbde98;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .footer-contacts a:hover {
    color: #fbde98 !important;
  }
  .footer-contacts a:hover::after {
    background: #fbde98;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.footer-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.8333333333vw;
  margin-top: auto;
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .footer-block {
    font-size: 3.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .footer-block {
    align-items: center;
    gap: 3.3333333333vw;
  }
}
.footer-dev {
  color: #fbde98;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .footer-dev {
    font-size: 3.8888888889vw;
  }
}
.footer-dev {
  position: relative;
  transition: color 0.2s ease;
}
.footer-dev::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fbde98;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .footer-dev:hover {
    color: #fbde98 !important;
  }
  .footer-dev:hover::after {
    background: #fbde98;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.footer-text {
  text-align: end;
  max-width: 23.6111111111vw;
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .footer-text {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .footer-text {
    text-align: center;
    max-width: 100%;
  }
}
.footer-links {
  width: 23.6111111111vw;
}
.footer-links ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.1111111111vw 1.6666666667vw;
  padding: 0;
}
.footer-links ul li {
  display: flex;
  justify-content: flex-end;
  list-style: none;
}
.footer-links ul li a {
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .footer-links ul li a {
    font-size: 6.6666666667vw;
  }
}
.footer-links ul li a {
  position: relative;
  transition: color 0.2s ease;
}
.footer-links ul li a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #ffffff;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .footer-links ul li a:hover {
    color: #ffffff !important;
  }
  .footer-links ul li a:hover::after {
    background: #ffffff;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.footer-policy {
  margin-top: auto;
}
.footer-policy ul {
  display: flex;
  flex-direction: column;
  gap: 0.8333333333vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .footer-policy ul {
    gap: 2.2222222222vw;
  }
}
.footer-policy ul li {
  display: flex;
  justify-content: flex-end;
  list-style: none;
}
@media screen and (max-width: 1023px) {
  .footer-policy ul li {
    justify-content: center;
  }
}
.footer-policy ul li a {
  color: #fbde98;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .footer-policy ul li a {
    font-size: 3.8888888889vw;
  }
}
.footer-policy ul li a {
  position: relative;
  transition: color 0.2s ease;
}
.footer-policy ul li a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fbde98;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .footer-policy ul li a:hover {
    color: #fbde98 !important;
  }
  .footer-policy ul li a:hover::after {
    background: #fbde98;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}

.logo {
  display: flex;
  width: 14.6527777778vw;
  height: 9.5833333333vw;
  -o-object-fit: cover;
     object-fit: cover;
}
.logo img {
  transition: transform 0.25s ease;
}
@media (hover: hover) {
  .logo:hover img {
    transform: scale(1.05);
  }
}
@media screen and (max-width: 1023px) {
  .logo {
    width: 29.4444444444vw;
    height: 19.1666666667vw;
  }
}
.logo-big {
  width: 31.8055555556vw;
  height: 20.8333333333vw;
}
@media screen and (max-width: 1023px) {
  .logo-big {
    width: 91.6666666667vw;
    height: 60vw;
  }
}

.socials {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8333333333vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .socials {
    gap: 3.3333333333vw;
  }
}
.socials li {
  list-style: none;
}
.socials li a {
  color: #fbde98;
  transition: color 0.25s ease;
}
@media (hover: hover) {
  .socials li a:hover {
    color: #E2A207;
  }
}
.socials li a svg {
  width: 2.7777777778vw;
  height: 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .socials li a svg {
    width: 11.1111111111vw;
    height: 11.1111111111vw;
  }
}

.page-header {
  margin: 2.7777777778vw 0;
}
@media screen and (max-width: 1023px) {
  .page-header {
    margin: 11.1111111111vw 0;
  }
}
.page-header span, .page-header time {
  display: block;
  text-align: center;
  text-transform: uppercase;
  color: #8F9090;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .page-header span, .page-header time {
    font-size: 3.8888888889vw;
  }
}
.page-header h1 {
  text-align: center;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 900;
  font-size: 5.5555555556vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .page-header h1 {
    font-size: 13.3333333333vw;
  }
}
.page-header h1 {
  line-height: 100%;
}
.page-header p {
  margin-top: 1.6666666667vw;
  text-align: center;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .page-header p {
    font-size: 5.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .page-header p {
    margin-top: 6.6666666667vw;
  }
}
.page-header-detail {
  margin: 2.7777777778vw 0 2.2222222222vw;
}
@media screen and (max-width: 1023px) {
  .page-header-detail {
    margin: 11.1111111111vw 0 6.6666666667vw;
  }
}
.page-header-detail span, .page-header-detail time {
  max-width: 61.1111111111vw;
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .page-header-detail span, .page-header-detail time {
    max-width: 100%;
    margin: 0;
  }
}
.page-header-detail h1 {
  max-width: 61.1111111111vw;
  margin: 0 auto;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.3333333333vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .page-header-detail h1 {
    font-size: 6.6666666667vw;
  }
}
@media screen and (max-width: 1023px) {
  .page-header-detail h1 {
    max-width: 100%;
    margin: 0.8333333333vw 0 0;
  }
}
.page-header-detail p {
  max-width: 61.1111111111vw;
  margin: 1.6666666667vw auto;
}
@media screen and (max-width: 1023px) {
  .page-header-detail p {
    max-width: 100%;
    margin: 5.5555555556vw 0 0;
  }
}

.main-banner {
  position: relative;
  display: flex;
  width: 100%;
  aspect-ratio: 16/9;
}
@media screen and (max-width: 1023px) {
  .main-banner {
    min-height: 177.7777777778vw;
  }
}
.main-banner-bg {
  overflow: hidden;
  display: flex;
  background: #084E41;
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.main-banner-bg img, .main-banner-bg video {
  width: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .main-banner-bg img, .main-banner-bg video {
    height: 100%;
  }
}
.main-banner-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
}
@media screen and (max-width: 1023px) {
  .main-banner-content {
    padding: 33.3333333333vw 5.5555555556vw 13.3333333333vw;
  }
}
.main-banner-content p {
  text-align: center;
  max-width: 40.2777777778vw;
  margin-top: 4.4444444444vw;
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .main-banner-content p {
    font-size: 5.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .main-banner-content p {
    max-width: 100%;
    margin-top: 11.1111111111vw;
  }
}
.main-banner-title {
  text-align: center;
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 11.1111111111vw;
  line-height: 90%;
}
@media screen and (max-width: 1023px) {
  .main-banner-title {
    font-size: 18.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .main-banner-title {
    font-size: 18.3333333333vw;
  }
}
.main-banner-title span {
  display: inline-block;
  margin-top: 0.5555555556vw;
}

.section-about {
  background: linear-gradient(21.46deg, #084E41 -13.13%, #077761 65.86%);
  padding: 2.7777777778vw 0 5vw;
}
@media screen and (max-width: 1023px) {
  .section-about {
    padding: 20vw 0 13.3333333333vw;
  }
}
.section-about-top {
  position: relative;
  display: flex;
  justify-content: center;
}
.section-about-top h2 {
  text-align: center;
  text-transform: uppercase;
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 11.1111111111vw;
  line-height: 90%;
}
@media screen and (max-width: 1023px) {
  .section-about-top h2 {
    font-size: 18.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-about-top h2 {
    font-size: 18.3333333333vw;
  }
}
.section-about-top img {
  position: absolute;
  top: 2.9166666667vw;
  right: 1.8055555556vw;
  width: 18.75vw;
  height: 9.0972222222vw;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .section-about-top img {
    z-index: 2;
    top: 58.3333333333vw;
    right: 0;
    width: 37.5vw;
    height: 18.0555555556vw;
  }
}
.section-about-block {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: 8.0555555556vw;
  padding: 0 2.0833333333vw;
}
@media screen and (max-width: 1023px) {
  .section-about-block {
    justify-content: center;
    margin-top: 50vw;
    padding: 0;
  }
}
.section-about-block p {
  text-align: end;
  max-width: 37.5vw;
  color: #fbde98;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .section-about-block p {
    font-size: 8.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-about-block p {
    text-align: center;
    max-width: 100%;
    color: #fbde98;
    font-family: "Onest", sans-serif;
    font-weight: 400;
    font-size: 1.3888888889vw;
    line-height: 140%;
  }
}
@media screen and (max-width: 1023px) and (max-width: 1023px) {
  .section-about-block p {
    font-size: 5.5555555556vw;
  }
}
.section-about-block-img {
  overflow: hidden;
  position: absolute;
  top: -10.0694444444vw;
  left: 1.3888888889vw;
  width: 35.7638888889vw;
  height: 20vw;
}
@media screen and (max-width: 1023px) {
  .section-about-block-img {
    top: -52.7777777778vw;
    left: 0;
    width: 58.8888888889vw;
    height: 32.7777777778vw;
  }
}
.section-about-block img {
  width: 100%;
  height: 120%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .section-about-block img {
    height: 100%;
  }
}
.section-about-marquee {
  width: 100vw;
  margin: 6.6666666667vw 0 0 -2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .section-about-marquee {
    margin: 12.2222222222vw 0 0 -5.5555555556vw;
  }
}

.marquee .swiper-wrapper {
  transition-timing-function: linear !important;
}
.marquee-list {
  position: relative;
  padding: 0;
}
.marquee li {
  list-style: none;
}
.marquee li div {
  display: flex;
  flex-direction: column;
  margin-top: 1.1111111111vw;
  max-width: 26.3888888889vw;
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.0833333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .marquee li div {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 1023px) {
  .marquee li div {
    margin-top: 4.4444444444vw;
    max-width: 44.4444444444vw;
  }
}
.marquee li div:first-child {
  margin-top: 0;
  color: #fbde98;
  font-family: "Oswald", sans-serif;
  font-weight: 900;
  font-size: 8.3333333333vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .marquee li div:first-child {
    font-size: 16.1111111111vw;
  }
}
.marquee li div:first-child span {
  color: #fbde98;
  font-family: "Oswald", sans-serif;
  font-weight: 900;
  font-size: 3.0555555556vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .marquee li div:first-child span {
    font-size: 6.1111111111vw;
  }
}

.section {
  margin: 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .section {
    margin: 15.5555555556vw 0;
  }
}
.section h2 {
  text-align: center;
  text-transform: uppercase;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 11.1111111111vw;
  line-height: 90%;
}
@media screen and (max-width: 1023px) {
  .section h2 {
    font-size: 18.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .section h2 {
    font-size: 15.5555555556vw;
  }
}

.section-advantages {
  margin: 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .section-advantages {
    margin: 17.7777777778vw 0;
  }
}
.section-advantages-top {
  display: flex;
  justify-content: flex-end;
}
@media screen and (max-width: 1023px) {
  .section-advantages-top {
    justify-content: flex-start;
  }
}
.section-advantages-top h2 {
  text-align: end;
  text-transform: uppercase;
  max-width: 50%;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 900;
  font-size: 5.5555555556vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .section-advantages-top h2 {
    font-size: 13.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-advantages-top h2 {
    font-size: 12.2222222222vw;
    max-width: 100%;
  }
}
.section-advantages-top h2 span {
  color: #077761;
}
.section-advantages-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.7777777778vw 8.3333333333vw;
  margin-top: 2.7777777778vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .section-advantages-list {
    display: flex;
    overflow: auto;
    gap: 6.6666666667vw;
    width: 100vw;
    margin-top: 17.7777777778vw;
    margin-left: -5.5555555556vw;
    padding: 0 5.5555555556vw;
  }
}
.section-advantages-item {
  position: relative;
  list-style: none;
}
@media (hover: hover) {
  .section-advantages-item:hover img {
    transform: scale(1.1);
  }
  .section-advantages-item:hover h3, .section-advantages-item:hover h4 {
    color: #E2A207;
  }
}
@media screen and (max-width: 1023px) {
  .section-advantages-item {
    flex-shrink: 0;
    width: 85%;
  }
}
.section-advantages-item:nth-child(1), .section-advantages-item:nth-child(3n+1) {
  margin-top: 5.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item:nth-child(1), .section-advantages-item:nth-child(3n+1) {
    margin-top: 0;
  }
}
.section-advantages-item:nth-child(3), .section-advantages-item:nth-child(3n) {
  margin-top: 8.3333333333vw;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item:nth-child(3), .section-advantages-item:nth-child(3n) {
    margin-top: 0;
  }
}
.section-advantages-item-img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16/9;
  -o-object-fit: cover;
     object-fit: cover;
}
.section-advantages-item img {
  width: 100%;
  height: 120%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.section-advantages-item h3, .section-advantages-item h4 {
  margin-top: 1.3888888889vw;
  transition: color 0.3s ease;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item h3, .section-advantages-item h4 {
    font-size: 5.5555555556vw;
  }
}
.section-advantages-item h3, .section-advantages-item h4 {
  font-weight: 700;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item h3, .section-advantages-item h4 {
    margin-top: 5.5555555556vw;
  }
}
.section-advantages-item p {
  max-width: 18.0555555556vw;
  margin-top: 0.8333333333vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item p {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-advantages-item p {
    max-width: 100%;
    margin-top: 3.3333333333vw;
    padding-right: 5.5555555556vw;
  }
}
.section-advantages-item span {
  display: block;
  margin-top: 0.8333333333vw;
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-advantages-item span {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-advantages-item span {
    margin-top: 2.2222222222vw;
  }
}
.section-advantages-item-link {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.section-productions-slider {
  position: relative;
  width: 100vw;
  margin-top: 2.7777777778vw;
  margin-left: -2.7777777778vw !important;
  padding: 0 2.7777777778vw !important;
}
@media screen and (max-width: 1023px) {
  .section-productions-slider {
    margin-top: 17.7777777778vw;
    margin-left: -5.5555555556vw !important;
    padding: 0 5.5555555556vw !important;
  }
}
.section-productions-slider-btn {
  position: absolute;
  z-index: 10;
  top: 50%;
  transform: translate(0, -50%);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #077761;
  width: 2.7777777778vw;
  height: 2.7777777778vw;
  padding: 0;
  border: 1px solid #077761;
  cursor: pointer;
  transition: background 0.25s ease;
}
@media (hover: hover) {
  .section-productions-slider-btn:hover {
    background: #084E41;
  }
}
@media screen and (max-width: 1023px) {
  .section-productions-slider-btn {
    display: none;
  }
}
.section-productions-slider-btn svg {
  width: 1.1111111111vw;
  height: 1.1111111111vw;
}
.section-productions-slider-btn-next {
  right: 1.3888888889vw;
}
.section-productions-slider-btn-prev {
  left: 1.3888888889vw;
}
.section-productions-slider-btn.swiper-button-disabled {
  background: #ffffff;
  color: #077761;
  cursor: auto;
}
.section-productions-slider-btn.swiper-button-lock {
  display: none;
}
.section-productions-list {
  padding: 0;
}
.section-productions-list .swiper-slide:last-child li {
  border-right: 1px solid #077761;
}
.section-productions-list li {
  list-style: none;
  border-top: 1px solid #077761;
  border-left: 1px solid #077761;
  border-bottom: 1px solid #077761;
}
@media screen and (max-width: 1023px) {
  .section-productions-list li {
    flex-shrink: 0;
  }
}

.section-service-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100vw;
  margin-top: 2.7777777778vw;
  margin-left: -2.7777777778vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .section-service-list {
    grid-template-columns: 1fr;
    width: 100%;
    margin-top: 10vw;
    margin-left: 0;
  }
}
.section-service-list li {
  list-style: none;
}

.section-news-tabs {
  display: flex;
  justify-content: center;
  margin-top: 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .section-news-tabs {
    width: 100vw;
    margin-left: -5.5555555556vw;
    margin-top: 6.6666666667vw;
  }
}
.section-news-items {
  margin-top: 3.8888888889vw;
}
@media screen and (max-width: 1023px) {
  .section-news-items {
    width: 100vw;
    margin-top: 11.1111111111vw;
    margin-left: -5.5555555556vw;
  }
}
.section-news-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.1111111111vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .section-news-list {
    overflow: auto;
    display: flex;
    gap: 4.4444444444vw;
    width: 100%;
    padding: 0 5.5555555556vw;
  }
}
.section-news-list li {
  list-style: none;
}
@media screen and (max-width: 1023px) {
  .section-news-list li {
    flex-shrink: 0;
    width: 85%;
  }
}

.card {
  transition: background 0.25s ease;
}
@media (hover: hover) {
  .card:hover {
    background: #fbde98;
  }
  .card:hover img {
    opacity: 0;
  }
  .card:hover img:nth-child(2) {
    opacity: 1;
  }
  .card:hover h3 {
    color: #077761;
  }
}
.card-img {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.6666666667vw 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .card-img {
    padding: 5.5555555556vw 3.8888888889vw;
  }
}
.card-img img {
  width: 100%;
  max-width: 21.3888888889vw;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.35s ease;
  transition-property: opacity, transform;
}
@media screen and (max-width: 1023px) {
  .card-img img {
    max-width: 100%;
  }
}
.card-img img:nth-child(2) {
  position: absolute;
  top: 1.6666666667vw;
  left: 50%;
  z-index: 2;
  transform: translate(-50%, 0);
  opacity: 0;
}
.card-info {
  padding: 0 1.6666666667vw 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .card-info {
    padding: 0 5.5555555556vw 3.8888888889vw;
  }
}
.card-info h3 {
  transition: color 0.25s ease;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .card-info h3 {
    font-size: 8.8888888889vw;
  }
}
.card-info dl {
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .card-info dl {
    margin-top: 5.5555555556vw;
  }
}
.card-info dl div {
  display: flex;
  justify-content: space-between;
  gap: 1.3888888889vw;
  border-top: 1px solid rgba(217, 217, 217, 0.4);
  padding: 0.6944444444vw 0;
}
.card-info dl div:first-child {
  border-top: 0;
  padding-top: 0;
}
.card-info dl div dt, .card-info dl div dd {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-info dl div dt, .card-info dl div dd {
    font-size: 3.8888888889vw;
  }
}
.card-info dl div dt, .card-info dl div dd {
  line-height: 158%;
}
.card-link {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.card-1 {
  overflow: hidden;
  position: relative;
}
@media (hover: hover) {
  .card-1:hover img {
    transform: scale(1.1);
  }
}
.card-1-img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 4/5;
}
@media screen and (max-width: 1023px) {
  .card-1-img {
    aspect-ratio: 16/10;
  }
}
.card-1-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.card-1 h3 {
  position: absolute;
  z-index: 2;
  top: 3.125vw;
  left: 2.9166666667vw;
  right: 2.9166666667vw;
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .card-1 h3 {
    font-size: 6.6666666667vw;
  }
}
@media screen and (max-width: 1023px) {
  .card-1 h3 {
    top: 6.6666666667vw;
    left: 5.5555555556vw;
    right: 5.5555555556vw;
  }
}
.card-1 h3 {
  line-height: 120%;
  font-weight: 700;
}
.card-1-link {
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.card-2 {
  position: relative;
  transition: background 0.25s ease;
}
@media (hover: hover) {
  .card-2:hover img {
    transform: scale(1.1);
  }
  .card-2:hover h3 {
    color: #E2A207;
  }
}
.card-2-img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16/9;
}
.card-2-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.25s ease;
}
.card-2-info {
  padding: 1.3888888889vw 1.6666666667vw 2.2222222222vw;
}
@media screen and (max-width: 1023px) {
  .card-2-info {
    padding: 3.3333333333vw 3.3333333333vw 5.5555555556vw;
  }
}
.card-2-info h3 {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-top: 0.5555555556vw;
  transition: color 0.25s ease;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-2-info h3 {
    font-size: 5.5555555556vw;
  }
}
.card-2-info h3 {
  font-size: 1.4583333333vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .card-2-info h3 {
    margin-top: 2.2222222222vw;
    font-size: 5.5555555556vw;
  }
}
.card-2-info p {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-top: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-2-info p {
    font-size: 3.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .card-2-info p {
    margin-top: 2.2222222222vw;
  }
}
.card-2-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.card-2-tags span {
  color: #404040;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-2-tags span {
    font-size: 3.3333333333vw;
  }
}
.card-2-tags time {
  color: #8F9090;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-2-tags time {
    font-size: 3.3333333333vw;
  }
}
.card-2-tags span, .card-2-tags time {
  display: flex;
  align-items: center;
  margin-left: 0.4166666667vw;
}
@media screen and (max-width: 1023px) {
  .card-2-tags span, .card-2-tags time {
    margin-left: 1.6666666667vw;
  }
}
.card-2-tags span::before, .card-2-tags time::before {
  content: "";
  width: 3px;
  height: 3px;
  background: #404040;
  border-radius: 50%;
  margin-right: 0.4166666667vw;
}
@media screen and (max-width: 1023px) {
  .card-2-tags span::before, .card-2-tags time::before {
    margin-right: 1.6666666667vw;
  }
}
.card-2-tags span:first-child, .card-2-tags time:first-child {
  margin-left: 0;
}
.card-2-tags span:first-child::before, .card-2-tags time:first-child::before {
  display: none;
}
.card-2-tags span:last-child::before, .card-2-tags time:last-child::before {
  background: #8F9090;
}
.card-2-link {
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.card-3 {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.6666666667vw;
  padding: 1.1111111111vw 1.6666666667vw;
  border: 1px solid #1B1B1A;
  transition: 0.25s ease;
  transition-property: color, background, border;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .card-3 {
    font-size: 4.4444444444vw;
  }
}
@media (hover: hover) {
  .card-3:hover {
    background: #077761;
    color: #ffffff;
    border: 1px solid #084E41;
  }
}
@media screen and (max-width: 1023px) {
  .card-3 {
    gap: 4.4444444444vw;
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.card-3-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  background: #077761;
  width: 2.7777777778vw;
  height: 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .card-3-icon {
    width: 8.8888888889vw;
    height: 8.8888888889vw;
  }
}
.card-3-icon svg {
  width: 1.6666666667vw;
  height: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .card-3-icon svg {
    width: 4.4444444444vw;
    height: 4.4444444444vw;
  }
}
.card-3-link {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

.catalog {
  margin: 3.3333333333vw 0;
}
.catalog-tabs {
  display: flex;
  justify-content: center;
}
.catalog-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2.7777777778vw 1.1111111111vw;
  margin-top: 1.3888888889vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .catalog-list {
    grid-template-columns: 1fr;
    gap: 6.6666666667vw;
    margin-top: 11.1111111111vw;
  }
}
.catalog-list li {
  list-style: none;
}
.catalog-2 {
  margin: 3.3333333333vw 0;
}
.catalog-2-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100vw;
  margin-top: 1.3888888889vw;
  margin-left: -2.7777777778vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .catalog-2-list {
    grid-template-columns: 1fr;
    width: 100%;
    margin-top: 11.1111111111vw;
    margin-left: 0;
  }
}
.catalog-2-list li {
  list-style: none;
}
.catalog-3-list {
  display: grid;
  grid-template-columns: repeat(3, 33%);
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .catalog-3-list {
    grid-template-columns: 1fr;
  }
}
.catalog-3-list li {
  list-style: none;
  border-right: 1px solid #077761;
  border-bottom: 1px solid #077761;
}
@media screen and (max-width: 1023px) {
  .catalog-3-list li {
    border-left: 1px solid #077761;
    border-right: 1px solid #077761;
    border-bottom: 1px solid #077761;
  }
}
.catalog-3-list li:nth-child(-n+3) {
  border-top: 1px solid #077761;
}
@media screen and (max-width: 1023px) {
  .catalog-3-list li:nth-child(-n+3) {
    border-top: 0;
  }
}
.catalog-3-list li:nth-child(3n+1) {
  border-left: 1px solid #077761;
}
@media screen and (max-width: 1023px) {
  .catalog-3-list li:first-child {
    border-top: 1px solid #077761;
  }
}

.contacts {
  padding: 3.75vw 0;
}
@media screen and (max-width: 1023px) {
  .contacts {
    padding: 4.4444444444vw 0;
  }
}
.contacts-row {
  display: flex;
  gap: 9.7222222222vw;
}
@media screen and (max-width: 1023px) {
  .contacts-row {
    flex-direction: column;
    gap: 11.1111111111vw;
  }
}
.contacts-left {
  display: flex;
  flex-direction: column;
  gap: 2.7777777778vw;
  flex-shrink: 0;
  width: 23.6111111111vw;
}
@media screen and (max-width: 1023px) {
  .contacts-left {
    text-align: center;
    align-items: center;
    gap: 11.1111111111vw;
    width: 100%;
  }
}
.contacts-info {
  display: flex;
  flex-direction: column;
  gap: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .contacts-info {
    gap: 6.6666666667vw;
  }
}
.contacts-info h3 {
  text-transform: uppercase;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-info h3 {
    font-size: 6.6666666667vw;
  }
}
.contacts-info h3 {
  line-height: 100%;
  font-weight: 700;
}
.contacts-contact {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .contacts-contact {
    align-items: center;
    gap: 2.2222222222vw;
  }
}
.contacts-contact a {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-contact a {
    font-size: 5vw;
  }
}
.contacts-contact a {
  position: relative;
  transition: color 0.2s ease;
}
.contacts-contact a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #077761;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .contacts-contact a:hover {
    color: #077761 !important;
  }
  .contacts-contact a:hover::after {
    background: #077761;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.contacts-socials {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .contacts-socials {
    gap: 4.4444444444vw;
  }
}
.contacts-socials a {
  display: flex;
  align-items: center;
  gap: 1.1111111111vw;
  padding: 0.2777777778vw 1.1111111111vw;
  border: 1px solid #077761;
  transition: 0.25s ease;
  transition-property: color, background;
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-socials a {
    font-size: 5vw;
  }
}
@media screen and (max-width: 1023px) {
  .contacts-socials a {
    gap: 4.4444444444vw;
    padding: 1.1111111111vw 4.4444444444vw;
  }
}
.contacts-socials a svg {
  width: 2.7777777778vw;
  height: 2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .contacts-socials a svg {
    width: 8.8888888889vw;
    height: 8.8888888889vw;
  }
}
@media (hover: hover) {
  .contacts-socials a:hover {
    color: #ffffff;
    background: #077761;
  }
}
.contacts-address {
  display: flex;
  flex-direction: column;
  gap: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .contacts-address {
    gap: 4.4444444444vw;
  }
}
.contacts-address h3 {
  text-transform: uppercase;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-address h3 {
    font-size: 6.6666666667vw;
  }
}
.contacts-address h3 {
  line-height: 100%;
  font-weight: 700;
}
.contacts-address p {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-address p {
    font-size: 5vw;
  }
}
.contacts-address a {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-address a {
    font-size: 5vw;
  }
}
.contacts-address a {
  position: relative;
  transition: color 0.2s ease;
}
.contacts-address a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #077761;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .contacts-address a:hover {
    color: #077761 !important;
  }
  .contacts-address a:hover::after {
    background: #077761;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.contacts-map {
  height: 100%;
  width: 100%;
  min-height: 26.3888888889vw;
}
@media screen and (max-width: 1023px) {
  .contacts-map {
    min-height: 105.5555555556vw;
  }
}
.contacts-map .map-ymaps {
  width: 100%;
  height: 100%;
  min-height: 26.3888888889vw;
}
@media screen and (max-width: 1023px) {
  .contacts-map .map-ymaps {
    min-height: 105.5555555556vw;
  }
}
.contacts-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.7777777778vw 10vw;
  margin-top: 3.8888888889vw;
  padding-top: 3.8888888889vw;
  border-top: 2px solid #077761;
}
@media screen and (max-width: 1023px) {
  .contacts-list {
    grid-template-columns: 1fr;
    gap: 11.1111111111vw;
    margin-top: 11.1111111111vw;
    padding-top: 11.1111111111vw;
  }
}
@media screen and (max-width: 1023px) {
  .contacts-item {
    text-align: center;
  }
}
.contacts-item h4 {
  text-transform: uppercase;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-item h4 {
    font-size: 6.6666666667vw;
  }
}
.contacts-item h4 {
  line-height: 100%;
  font-weight: 700;
}
.contacts-item-contact {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5555555556vw;
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .contacts-item-contact {
    align-items: center;
    gap: 2.2222222222vw;
    margin-top: 6.6666666667vw;
  }
}
.contacts-item-contact a {
  color: #084E41;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .contacts-item-contact a {
    font-size: 5vw;
  }
}
.contacts-item-contact a {
  position: relative;
  transition: color 0.2s ease;
}
.contacts-item-contact a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #077761;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .contacts-item-contact a:hover {
    color: #077761 !important;
  }
  .contacts-item-contact a:hover::after {
    background: #077761;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}

.documents {
  padding: 1.6666666667vw 0 8.3333333333vw;
}
@media screen and (max-width: 1023px) {
  .documents {
    padding: 6.6666666667vw 0 17.7777777778vw;
  }
}
.documents-dropdown {
  position: relative;
  z-index: 10;
  display: flex;
  justify-content: center;
}
.documents-dropdown .dropdown {
  max-width: 27.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .documents-dropdown .dropdown {
    max-width: 100%;
  }
}
.documents-items {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 3.3333333333vw;
}
.documents-item {
  margin-top: 3.3333333333vw;
  width: 75vw;
}
.documents-item:first-child {
  margin-top: 0;
}
@media screen and (max-width: 1023px) {
  .documents-item {
    width: 100%;
    margin-top: 11.1111111111vw;
  }
}
.documents-item h2 {
  text-align: center;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.3333333333vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .documents-item h2 {
    font-size: 6.6666666667vw;
  }
}
.documents-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.6666666667vw 2.7777777778vw;
  margin-top: 1.6666666667vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .documents-list {
    grid-template-columns: 1fr;
    gap: 6.6666666667vw;
    margin-top: 6.6666666667vw;
  }
}
.documents-list li {
  list-style: none;
}

.detail {
  padding: 1.6666666667vw 0 4.4444444444vw 0;
}
@media screen and (max-width: 1023px) {
  .detail {
    padding: 6.6666666667vw 0 17.7777777778vw;
  }
}
.detail-wrapper {
  max-width: 61.1111111111vw;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .detail-wrapper {
    max-width: 100%;
  }
}
.detail-preview {
  width: 100%;
}
@media screen and (max-width: 1023px) {
  .detail-preview {
    width: 100vw;
    margin-left: -5.5555555556vw;
  }
}
.detail-preview img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.detail-content {
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .detail-content {
    margin-top: 5.5555555556vw;
  }
}
.detail-content:first-child {
  margin-top: 0;
}
.detail-content figure {
  margin: 1.6666666667vw 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .detail-content figure {
    margin: 6.6666666667vw 0 0 -5.5555555556vw;
    width: 100vw;
  }
}
.detail-content figure:first-child {
  margin-top: 0;
}
.detail-content figure a {
  cursor: pointer;
}
.detail-content figure img, .detail-content figure video, .detail-content figure iframe {
  display: block;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.detail-content figure video, .detail-content figure iframe {
  aspect-ratio: 16/9;
}
.detail-content figure figcaption {
  margin: 0 5.5555555556vw;
  margin-top: 0.8333333333vw;
  color: #8F9090;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content figure figcaption {
    font-size: 3.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .detail-content figure figcaption {
    margin: 0 5.5555555556vw;
    margin-top: 2.7777777778vw;
  }
}
.detail-content h1, .detail-content h2, .detail-content h3, .detail-content h4, .detail-content h5, .detail-content h6 {
  margin: 0 5.5555555556vw;
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .detail-content h1, .detail-content h2, .detail-content h3, .detail-content h4, .detail-content h5, .detail-content h6 {
    margin: 0;
    margin-top: 5.5555555556vw;
  }
}
.detail-content h1:first-child, .detail-content h2:first-child, .detail-content h3:first-child, .detail-content h4:first-child, .detail-content h5:first-child, .detail-content h6:first-child {
  margin-top: 0;
}
.detail-content h1, .detail-content h2 {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .detail-content h1, .detail-content h2 {
    font-size: 8.8888888889vw;
  }
}
.detail-content h1, .detail-content h2 {
  font-weight: 700;
}
.detail-content h3 {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.9444444444vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .detail-content h3 {
    font-size: 7.7777777778vw;
  }
}
.detail-content h3 {
  font-weight: 700;
}
.detail-content h4, .detail-content h5 {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .detail-content h4, .detail-content h5 {
    font-size: 6.6666666667vw;
  }
}
.detail-content h4, .detail-content h5 {
  font-weight: 700;
}
.detail-content h6 {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content h6 {
    font-size: 5.5555555556vw;
  }
}
.detail-content h6 {
  font-weight: 700;
}
.detail-content p {
  margin: 0 5.5555555556vw;
  margin-top: 1.3888888889vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content p {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .detail-content p {
    margin: 0;
    margin-top: 5.5555555556vw;
  }
}
.detail-content p:first-child {
  margin-top: 0;
}
.detail-content strong {
  font-weight: 700;
}
.detail-content a {
  text-decoration: underline;
  transition: color 0.25s ease;
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content a {
    font-size: 4.4444444444vw;
  }
}
@media (hover: hover) {
  .detail-content a:hover {
    color: #084E41;
    text-decoration: none;
  }
}
.detail-content ol, .detail-content ul {
  margin: 0 5.5555555556vw;
  margin-top: 1.3888888889vw;
  padding-left: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .detail-content ol, .detail-content ul {
    margin: 0;
    padding-left: 6.6666666667vw;
    margin-top: 5.5555555556vw;
  }
}
.detail-content ol:first-child, .detail-content ul:first-child {
  margin-top: 0;
}
.detail-content ol li, .detail-content ul li {
  margin-top: 0.9722222222vw;
  padding-left: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content ol li, .detail-content ul li {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .detail-content ol li, .detail-content ul li {
    margin-top: 2.2222222222vw;
    padding-left: 1.6666666667vw;
  }
}
.detail-content ol li:first-child, .detail-content ul li:first-child {
  margin-top: 0;
}
.detail-content ol li::marker, .detail-content ul li::marker {
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content ol li::marker, .detail-content ul li::marker {
    font-size: 4.4444444444vw;
  }
}
.detail-content ol li::marker, .detail-content ul li::marker {
  font-weight: 600;
}
.detail-content ol ol, .detail-content ol ul, .detail-content ul ol, .detail-content ul ul {
  margin: 0 1.6666666667vw;
  margin-top: 1.3888888889vw;
}
@media screen and (max-width: 1023px) {
  .detail-content ol ol, .detail-content ol ul, .detail-content ul ol, .detail-content ul ul {
    margin: 0;
    margin-top: 5.5555555556vw;
  }
}
.detail-content blockquote {
  background: #ffffff;
  margin: 1.6666666667vw 5.5555555556vw 0;
  padding: 1.6666666667vw 1.9444444444vw;
  border: 2px solid #077761;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content blockquote {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .detail-content blockquote {
    width: 100%;
    margin: 5.5555555556vw 0 0;
    padding: 5.5555555556vw;
  }
}
.detail-content blockquote > * {
  margin-left: 0;
  margin-right: 0;
}
.detail-content blockquote:first-child {
  margin-top: 0;
}
.detail-content blockquote :first-child {
  margin-top: 0;
}
.detail-content table {
  background: #ffffff;
  margin-top: 1.6666666667vw;
  width: 100%;
  border-spacing: 0;
  border: 1px solid #077761;
}
@media screen and (max-width: 1023px) {
  .detail-content table {
    overflow: auto;
    margin-top: 5.5555555556vw;
  }
}
.detail-content table:first-child {
  margin-top: 0;
}
.detail-content table td, .detail-content table th {
  padding: 1.3888888889vw 1.6666666667vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content table td, .detail-content table th {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .detail-content table td, .detail-content table th {
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.detail-content table td a, .detail-content table th a {
  transition: color 0.25s ease;
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .detail-content table td a, .detail-content table th a {
    font-size: 4.4444444444vw;
  }
}
@media (hover: hover) {
  .detail-content table td a:hover, .detail-content table th a:hover {
    color: #084E41;
  }
}
.detail-content table tr td {
  border-bottom: 1px solid #077761;
  border-right: 1px solid #077761;
}
.detail-content table tr td strong, .detail-content table tr td b {
  font-weight: 500;
}
.detail-content table tr td svg {
  width: 24px;
  height: 24px;
}
.detail-content table tr td:first-child {
  border-left: none;
}
.detail-content table tr td:last-child {
  border-right: none;
}
.detail-content table tr:last-child td {
  border-bottom: none;
  border-right: 1px solid #077761 !important;
}
.detail-content table tr:last-child td:last-child {
  border-right: none !important;
}
.detail-table {
  overflow: auto;
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .detail-table {
    width: 100vw;
    margin-left: -5.5555555556vw;
    margin-top: 6.6666666667vw;
  }
}
.detail-table:first-child {
  margin-top: 0;
}

.section-paragraph {
  padding: 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .section-paragraph {
    padding: 6.6666666667vw 0 17.7777777778vw;
  }
}
.section-paragraph-wrapper {
  display: flex;
  flex-direction: column;
  gap: 2.7777777778vw;
  max-width: 51.3888888889vw;
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .section-paragraph-wrapper {
    gap: 6.6666666667vw;
    max-width: 100%;
    margin: 0;
  }
}
.section-paragraph p {
  text-align: center;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-paragraph p {
    font-size: 5.5555555556vw;
  }
}

.section-media {
  background: #077761;
}
.section-media figure {
  display: flex;
  width: 100%;
  height: 44.4444444444vw;
  overflow: hidden;
}
.section-media img, .section-media video {
  width: 100%;
  height: 120%;
  -o-object-fit: cover;
     object-fit: cover;
}

.section-brands {
  margin: 5.5555555556vw 0 11.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .section-brands {
    margin: 17.7777777778vw 0 33.3333333333vw;
  }
}
.section-brands-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3.3333333333vw;
  padding: 3.3333333333vw;
}
@media screen and (max-width: 1023px) {
  .section-brands-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 5.5555555556vw;
    padding: 0;
  }
}
.section-brands-list li {
  list-style: none;
}
.section-brands-item {
  position: relative;
  padding-left: 1.1111111111vw;
  border-left: 1px solid #E1E1E1;
  transition: border 0.25s ease;
}
@media screen and (max-width: 1023px) {
  .section-brands-item {
    padding-left: 3.3333333333vw;
  }
}
.section-brands-item-img svg {
  width: 12.5vw;
  height: 3.3333333333vw;
  transition: opacity 0.25s ease;
  color: #1B1B1A;
  opacity: 0.6;
}
@media screen and (max-width: 1023px) {
  .section-brands-item-img svg {
    width: 38.8888888889vw;
    height: 10.5555555556vw;
  }
}
.section-brands-item p {
  transition: color 0.25s ease;
  margin-top: 0.5555555556vw;
  color: #696969;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-brands-item p {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-brands-item p {
    margin-top: 2.2222222222vw;
  }
}
.section-brands-item a {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
@media (hover: hover) {
  .section-brands-item:hover {
    border-left: 1px solid #084E41;
  }
  .section-brands-item:hover svg {
    opacity: 1;
  }
  .section-brands-item:hover p {
    color: #084E41;
  }
}

.section-info {
  margin: 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .section-info {
    margin: 17.7777777778vw 0;
  }
}
.section-info-wrapper {
  display: flex;
  align-items: center;
  gap: 2.2222222222vw;
}
@media screen and (max-width: 1023px) {
  .section-info-wrapper {
    gap: 8.8888888889vw;
    flex-direction: column;
  }
}
.section-info-wrapper-reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 1023px) {
  .section-info-wrapper-reverse {
    flex-direction: column;
  }
}
.section-info-block {
  width: 100%;
  padding: 5.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .section-info-block {
    padding: 0;
  }
}
.section-info-top span {
  color: #696969;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-info-top span {
    font-size: 3.8888888889vw;
  }
}
.section-info-top h2 {
  margin-top: 1.6666666667vw;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.3333333333vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .section-info-top h2 {
    font-size: 6.6666666667vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-info-top h2 {
    margin-top: 3.3333333333vw;
    color: #1B1B1A;
    font-family: "Oswald", sans-serif;
    font-weight: 400;
    font-size: 2.2222222222vw;
    line-height: 120%;
  }
}
@media screen and (max-width: 1023px) and (max-width: 1023px) {
  .section-info-top h2 {
    font-size: 8.8888888889vw;
  }
}
.section-info-top h2 {
  font-weight: 700;
}
.section-info-content {
  margin-top: 4.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .section-info-content {
    margin-top: 11.1111111111vw;
  }
}
.section-info-content :first-child {
  margin-top: 0;
}
.section-info-content h3 {
  margin-top: 1.6666666667vw;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .section-info-content h3 {
    font-size: 8.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-info-content h3 {
    margin-top: 6.6666666667vw;
    color: #1B1B1A;
    font-family: "Oswald", sans-serif;
    font-weight: 400;
    font-size: 1.6666666667vw;
    line-height: 120%;
  }
}
@media screen and (max-width: 1023px) and (max-width: 1023px) {
  .section-info-content h3 {
    font-size: 6.6666666667vw;
  }
}
.section-info-content h3 {
  font-weight: 700;
}
.section-info-content h3:first-child {
  margin-top: 0;
}
.section-info-content p {
  margin-top: 0.4166666667vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-info-content p {
    font-size: 5.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-info-content p {
    margin-top: 1.6666666667vw;
    color: #1B1B1A;
    font-family: "Onest", sans-serif;
    font-weight: 400;
    font-size: 1.25vw;
    line-height: 120%;
  }
}
@media screen and (max-width: 1023px) and (max-width: 1023px) {
  .section-info-content p {
    font-size: 5vw;
  }
}
.section-info-content ol, .section-info-content ul {
  margin-top: 1.3888888889vw;
  padding-left: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .section-info-content ol, .section-info-content ul {
    margin: 0;
    padding-left: 6.6666666667vw;
    margin-top: 5.5555555556vw;
  }
}
.section-info-content ol:first-child, .section-info-content ul:first-child {
  margin-top: 0;
}
.section-info-content ol li, .section-info-content ul li {
  margin-top: 1.6666666667vw;
  padding-left: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-info-content ol li, .section-info-content ul li {
    font-size: 5.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .section-info-content ol li, .section-info-content ul li {
    margin-top: 3.3333333333vw;
    padding-left: 1.6666666667vw;
    color: #1B1B1A;
    font-family: "Onest", sans-serif;
    font-weight: 400;
    font-size: 1.25vw;
    line-height: 120%;
  }
}
@media screen and (max-width: 1023px) and (max-width: 1023px) {
  .section-info-content ol li, .section-info-content ul li {
    font-size: 5vw;
  }
}
.section-info-content ol li:first-child, .section-info-content ul li:first-child {
  margin-top: 0;
}
.section-info-content ol li::marker, .section-info-content ul li::marker {
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .section-info-content ol li::marker, .section-info-content ul li::marker {
    font-size: 5.5555555556vw;
  }
}
.section-info-content ol li::marker, .section-info-content ul li::marker {
  font-weight: 600;
}
.section-info-img {
  flex-shrink: 0;
  overflow: hidden;
  width: 46.3888888889vw;
  height: 61.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .section-info-img {
    width: 100%;
    height: auto;
  }
}
.section-info-img img, .section-info-img video {
  width: 100%;
  height: 120%;
  -o-object-fit: cover;
     object-fit: cover;
}

.product .container {
  transition: opacity 0.25s ease;
}
.product.loading > .container {
  opacity: 0.4;
}
.product.loading .product-loading {
  opacity: 1;
  pointer-events: all;
}
.product-loading {
  position: fixed;
  z-index: 20;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 13.8888888889vw;
  background: rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(4px);
  transition: opacity 0.25s ease;
  pointer-events: none;
  opacity: 0;
}
@media screen and (max-width: 1023px) {
  .product-loading {
    padding: 33.3333333333vw 5.5555555556vw;
  }
}
.product-loading svg {
  width: 4.4444444444vw;
  height: 4.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .product-loading svg {
    width: 13.3333333333vw;
    height: 13.3333333333vw;
  }
}
.product-wrapper {
  display: flex;
  gap: 3.8888888889vw;
}
@media screen and (max-width: 1023px) {
  .product-wrapper {
    flex-direction: column;
    gap: 6.6666666667vw;
  }
}
.product-left {
  flex-shrink: 0;
  position: relative;
  width: 47.2222222222vw;
}
@media screen and (max-width: 1023px) {
  .product-left {
    width: 100vw;
    margin-left: -5.5555555556vw;
    padding-bottom: 3.3333333333vw;
  }
}
.product-left-info {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .product-left-info {
    left: 5.5555555556vw;
    gap: 2.2222222222vw;
  }
}
.product-left-info-item {
  position: relative;
  display: flex;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.product-left-info-item img {
  width: 5.9027777778vw;
  height: 9.0277777778vw;
}
@media screen and (max-width: 1023px) {
  .product-left-info-item img {
    width: 15.2777777778vw;
    height: 25vw;
  }
}
.product-left-info-item span {
  position: absolute;
  top: 5.1388888889vw;
  left: 50%;
  transform: translate(-50%, 0);
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-left-info-item span {
    font-size: 3.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-left-info-item span {
    top: 14.4444444444vw;
    font-size: 2.7777777778vw;
  }
}
.product-left-info-item-2 span {
  top: 4.5138888889vw;
}
@media screen and (max-width: 1023px) {
  .product-left-info-item-2 span {
    top: 12.5vw;
  }
}
.product-slider {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 1023px) {
  .product-slider {
    aspect-ratio: auto;
    padding-bottom: 6.6666666667vw !important;
  }
}
.product-slider a {
  cursor: pointer;
}
.product-slider a img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.product-slider-bottom {
  position: absolute;
  z-index: 4;
  bottom: 0.8333333333vw;
  right: 0;
  display: flex;
  align-items: center;
  gap: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .product-slider-bottom {
    bottom: 0;
    justify-content: center;
    gap: 4.4444444444vw;
    width: 100%;
  }
}
.product-slider-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  background: transparent;
  height: 1.6666666667vw;
  width: 1.6666666667vw;
  padding: 0;
  border: 0;
  cursor: pointer;
  transition: all 0.25s ease;
}
@media screen and (max-width: 1023px) {
  .product-slider-btn {
    height: 5.5555555556vw;
    width: 5.5555555556vw;
  }
}
@media (hover: hover) {
  .product-slider-btn:hover {
    color: #084E41;
  }
}
.product-slider-btn svg {
  height: 1.1111111111vw;
  width: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .product-slider-btn svg {
    height: 4.4444444444vw;
    width: 4.4444444444vw;
  }
}
.product-right {
  min-width: 39.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .product-right {
    width: 100%;
  }
}
.product-right h1 {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 900;
  font-size: 2.7777777778vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .product-right h1 {
    font-size: 11.1111111111vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-right h1 {
    text-align: center;
  }
}
.product-config {
  display: flex;
  margin-top: 0.8333333333vw;
}
@media screen and (max-width: 1023px) {
  .product-config {
    flex-direction: column;
    margin-top: 11.1111111111vw;
  }
}
.product-tabs {
  max-width: 18.8888888889vw;
  margin: 2.7777777778vw 0 0 0;
}
@media screen and (max-width: 1023px) {
  .product-tabs {
    max-width: 100%;
    margin: 8.8888888889vw 0 0 0;
  }
}
.product-tabs:first-child {
  margin: 0;
}
@media screen and (max-width: 1023px) {
  .product-tabs .tabs {
    padding: 0;
  }
}
.product-tabs-2 .tab {
  width: 50%;
}
.product-tabs-3 .tab {
  width: 33%;
}
.product-tabs-title {
  display: block;
  margin-bottom: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-tabs-title {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-tabs-title {
    margin-bottom: 3.3333333333vw;
  }
}
.product-tabs-title {
  font-weight: 700;
}
.product-tabs-text {
  display: block;
  margin-top: 0.5555555556vw;
  color: #747474;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-tabs-text {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-tabs-text {
    margin-top: 3.3333333333vw;
  }
}
.product-price {
  display: flex;
  flex-direction: column;
  background: #fbde98;
  width: 100%;
  max-width: 18.4722222222vw;
  margin-left: 2.0833333333vw;
  padding: 1.6666666667vw 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .product-price {
    max-width: 100%;
    margin-left: 0;
    margin-top: 8.8888888889vw;
    padding: 4.4444444444vw;
  }
}
.product-price-title {
  display: block;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .product-price-title {
    font-size: 8.8888888889vw;
  }
}
.product-price-title {
  font-weight: 900;
}
@media screen and (max-width: 1023px) {
  .product-price-title {
    font-size: 11.1111111111vw;
  }
}
.product-price-text {
  display: block;
  margin-top: 0.4166666667vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-price-text {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-price-text {
    margin-top: 1.1111111111vw;
  }
}
.product-price-text {
  font-weight: 500;
}
.product-price-bottom {
  margin-top: auto;
}
@media screen and (max-width: 1023px) {
  .product-price-bottom {
    margin-top: 6.6666666667vw;
  }
}
.product-price-sign {
  display: block;
  margin-bottom: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-price-sign {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-price-sign {
    margin-bottom: 3.3333333333vw;
  }
}
.product-price-contact {
  display: flex;
  align-items: center;
  gap: 0.5555555556vw;
  margin-top: 0.4166666667vw;
}
@media screen and (max-width: 1023px) {
  .product-price-contact {
    gap: 2.2222222222vw;
    margin-top: 2.2222222222vw;
  }
}
.product-price-contact svg {
  width: 1.1111111111vw;
  height: 1.1111111111vw;
}
@media screen and (max-width: 1023px) {
  .product-price-contact svg {
    width: 5vw;
    height: 5vw;
  }
}
.product-price-contact a {
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-price-contact a {
    font-size: 3.8888888889vw;
  }
}
.product-price-contact a {
  position: relative;
  transition: color 0.2s ease;
}
.product-price-contact a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #077761;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .product-price-contact a:hover {
    color: #077761 !important;
  }
  .product-price-contact a:hover::after {
    background: #077761;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.product-price-contact a {
  line-height: 100%;
}
.product-advantages {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9722222222vw;
  margin-top: 2.7777777778vw;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .product-advantages {
    overflow: auto;
    flex-wrap: nowrap;
    gap: 4.4444444444vw;
    width: 100vw;
    margin-top: 8.8888888889vw;
    margin-left: -5.5555555556vw;
    padding: 0 5.5555555556vw;
  }
}
.product-advantages li {
  list-style: none;
}
.product-advantages-item {
  width: 12.5vw;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item {
    flex-shrink: 0;
    width: 85%;
  }
}
.product-advantages-item-img {
  overflow: hidden;
  width: 12.5vw;
  aspect-ratio: 16/9;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item-img {
    width: 100%;
  }
}
.product-advantages-item-img img {
  width: 100%;
  height: 120%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item-img img {
    height: 100%;
  }
}
.product-advantages-item h3 {
  margin-top: 1.3888888889vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.3888888889vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item h3 {
    font-size: 5.5555555556vw;
  }
}
.product-advantages-item h3 {
  font-weight: 700;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item h3 {
    margin-top: 5.5555555556vw;
  }
}
.product-advantages-item p {
  margin-top: 0.5555555556vw;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item p {
    font-size: 3.3333333333vw;
  }
}
.product-advantages-item p {
  font-size: 0.9027777778vw;
}
@media screen and (max-width: 1023px) {
  .product-advantages-item p {
    font-size: 3.6111111111vw;
    max-width: 90%;
    margin-top: 2.2222222222vw;
  }
}
.product-info {
  margin: 2.7777777778vw 0 5.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .product-info {
    margin: 8.8888888889vw 0 17.7777777778vw;
  }
}
.product-info-tabs {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 1023px) {
  .product-info-tabs {
    width: 100vw;
    margin-left: -5.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-info-tabs .tabs {
    flex-direction: column;
  }
}
@media screen and (max-width: 1023px) {
  .product-info-tabs .tabs .tab {
    border-top: 0;
    border-left: 1px solid #1B1B1A;
  }
  .product-info-tabs .tabs .tab:first-child {
    border-top: 1px solid #1B1B1A;
  }
}
.product-info-items {
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-info-items {
    margin-top: 6.6666666667vw;
  }
}
.product-info-item {
  flex-direction: column;
}
.product-info-title {
  text-align: center;
  text-transform: uppercase;
  margin-bottom: 1.6666666667vw;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.8888888889vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .product-info-title {
    font-size: 10.5555555556vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-info-title {
    margin-bottom: 6.6666666667vw;
  }
}
.product-content {
  width: 100%;
  max-width: 61.1111111111vw;
  margin: 0 auto;
}
@media screen and (max-width: 1023px) {
  .product-content {
    max-width: 100%;
  }
}
.product-downloads {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.6666666667vw 2.7777777778vw;
  width: 100%;
  max-width: 75vw;
  margin: 0 auto;
  padding: 0;
}
@media screen and (max-width: 1023px) {
  .product-downloads {
    grid-template-columns: 1fr;
    gap: 6.6666666667vw;
    max-width: 100%;
  }
}
.product-downloads li {
  list-style: none;
}
.product-specifications dl {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-specifications dl {
    grid-template-columns: 1fr;
    gap: 2.2222222222vw;
  }
}
.product-specifications dl div {
  display: flex;
  gap: 2.2222222222vw;
  padding: 1.25vw 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-specifications dl div {
    flex-direction: column;
    gap: 2.2222222222vw;
    padding: 3.3333333333vw 4.4444444444vw;
  }
}
.product-specifications dl div:nth-child(4n+1), .product-specifications dl div:nth-child(4n+2) {
  background: rgba(251, 222, 152, 0.161);
}
@media screen and (max-width: 1023px) {
  .product-specifications dl div:nth-child(4n+1), .product-specifications dl div:nth-child(4n+2) {
    background: white;
  }
}
@media screen and (max-width: 1023px) {
  .product-specifications dl div:nth-child(odd) {
    background: rgba(251, 222, 152, 0.161);
  }
}
.product-specifications dl div dt, .product-specifications dl div dd {
  width: 50%;
  color: #1B1B1A;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.0416666667vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-specifications dl div dt, .product-specifications dl div dd {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-specifications dl div dt, .product-specifications dl div dd {
    width: 100%;
  }
}
.product-specifications dl div dd {
  font-weight: 600;
}
.product-gallery {
  width: 100vw;
  margin-top: 5.5555555556vw;
  margin-left: -2.7777777778vw;
}
@media screen and (max-width: 1023px) {
  .product-gallery {
    margin-top: 17.7777777778vw;
    margin-left: -5.5555555556vw;
  }
}
.product-gallery h2 {
  text-transform: uppercase;
  text-align: center;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.8888888889vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .product-gallery h2 {
    font-size: 10.5555555556vw;
  }
}
.product-gallery-slider {
  position: relative;
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-gallery-slider {
    margin-top: 6.6666666667vw;
  }
}
.product-gallery-slider a {
  display: flex;
}
.product-gallery-slider img, .product-gallery-slider video, .product-gallery-slider iframe {
  width: 100%;
  height: 56.25vw;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .product-gallery-slider img, .product-gallery-slider video, .product-gallery-slider iframe {
    height: 66.6666666667vw;
  }
}
.product-gallery-btn {
  position: absolute;
  z-index: 10;
  top: 0;
  bottom: 0;
  width: 8.3333333333vw;
  background: transparent;
  padding: 0;
  border: 0;
  cursor: pointer;
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn {
    cursor: auto;
    width: 16.6666666667vw;
  }
}
.product-gallery-btn::before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: opacity 0.25s ease;
}
.product-gallery-btn svg {
  position: absolute;
  z-index: 2;
  top: 50%;
  transform: translate(0, -50%);
  width: 2.7777777778vw;
  height: 2.7777777778vw;
  padding: 0.5555555556vw;
  color: #ffffff;
  transition: color 0.25s ease;
  transition-property: color, background;
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn svg {
    width: 7.7777777778vw;
    height: 7.7777777778vw;
    padding: 1.1111111111vw;
  }
}
@media (hover: hover) {
  .product-gallery-btn:hover svg {
    background: #ffffff;
    color: #077761;
  }
  .product-gallery-btn:hover::before {
    opacity: 0.7;
  }
}
.product-gallery-btn.swiper-button-disabled {
  opacity: 0;
  pointer-events: none;
}
.product-gallery-btn.swiper-button-lock {
  display: none;
}
.product-gallery-btn-prev {
  left: 0;
}
.product-gallery-btn-prev::before {
  background: linear-gradient(to right, #1B1B1A 0%, transparent 90%);
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn-prev::before {
    background: linear-gradient(to right, #1B1B1A 0%, transparent 70%);
  }
}
.product-gallery-btn-prev svg {
  left: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn-prev svg {
    left: 1.6666666667vw;
  }
}
.product-gallery-btn-next {
  right: 0;
}
.product-gallery-btn-next::before {
  background: linear-gradient(to left, #1B1B1A 0%, transparent 90%);
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn-next::before {
    background: linear-gradient(to left, #1B1B1A 0%, transparent 70%);
  }
}
.product-gallery-btn-next svg {
  right: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-gallery-btn-next svg {
    right: 1.6666666667vw;
  }
}
.product-description {
  position: relative;
  width: 100vw;
  margin-left: -2.7777777778vw;
  padding: 5.5555555556vw 0;
}
@media screen and (max-width: 1023px) {
  .product-description {
    margin-left: -5.5555555556vw;
    padding: 13.3333333333vw 0;
  }
}
.product-description-bg {
  overflow: hidden;
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.product-description-bg img, .product-description-bg video {
  width: 100%;
  height: 100%;
}
.product-description .container {
  position: relative;
  z-index: 2;
}
.product-description-item {
  display: flex;
  min-height: 37.8472222222vw;
  background: #077761;
  margin-top: 5.5555555556vw;
}
@media screen and (max-width: 1023px) {
  .product-description-item {
    flex-direction: column;
    margin-top: 13.3333333333vw;
  }
}
.product-description-item:first-child {
  margin-top: 0;
}
.product-description-item:nth-child(2n) {
  flex-direction: row-reverse;
}
@media screen and (max-width: 1023px) {
  .product-description-item:nth-child(2n) {
    flex-direction: column;
  }
}
.product-description-item-img {
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: flex-end;
  width: 47.2222222222vw;
  background: #ffffff;
}
@media screen and (max-width: 1023px) {
  .product-description-item-img {
    width: 100%;
  }
}
.product-description-item-img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .product-description-item-img img {
    height: 100%;
  }
}
.product-description-item-content {
  width: 100%;
  padding: 2.2222222222vw 4.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content {
    padding: 6.6666666667vw 5.5555555556vw;
  }
}
.product-description-item-content span {
  display: inline-block;
  margin-bottom: 0.8333333333vw;
  color: #fbde98;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.8333333333vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content span {
    font-size: 3.3333333333vw;
  }
}
@media screen and (max-width: 1023px) {
  .product-description-item-content span {
    margin-bottom: 3.3333333333vw;
  }
}
.product-description-item-content h1, .product-description-item-content h2 {
  text-transform: uppercase;
  margin-bottom: 1.6666666667vw;
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 3.8888888889vw;
  line-height: 100%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h1, .product-description-item-content h2 {
    font-size: 10.5555555556vw;
  }
}
.product-description-item-content h1, .product-description-item-content h2 {
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h1, .product-description-item-content h2 {
    margin-top: 6.6666666667vw;
  }
}
.product-description-item-content h3 {
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h3 {
    font-size: 8.8888888889vw;
  }
}
.product-description-item-content h3 {
  line-height: 160%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h3 {
    max-width: 100%;
  }
}
.product-description-item-content h4, .product-description-item-content h5 {
  color: #ffffff;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 1.6666666667vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h4, .product-description-item-content h5 {
    font-size: 6.6666666667vw;
  }
}
.product-description-item-content h4, .product-description-item-content h5 {
  line-height: 160%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h4, .product-description-item-content h5 {
    max-width: 100%;
  }
}
.product-description-item-content h6 {
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.25vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h6 {
    font-size: 5vw;
  }
}
.product-description-item-content h6 {
  line-height: 160%;
  font-weight: 700;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content h6 {
    max-width: 100%;
  }
}
.product-description-item-content p {
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content p {
    font-size: 3.8888888889vw;
  }
}
.product-description-item-content p {
  line-height: 160%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content p {
    max-width: 100%;
  }
}
.product-description-item-content a {
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content a {
    font-size: 3.8888888889vw;
  }
}
.product-description-item-content a {
  position: relative;
  transition: color 0.2s ease;
}
.product-description-item-content a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #ffffff;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.7, 0, 0.2, 1);
  transform-origin: 100% 50%;
  transform: scale3d(0, 1, 1);
}
@media (hover: hover) {
  .product-description-item-content a:hover {
    color: #ffffff !important;
  }
  .product-description-item-content a:hover::after {
    background: #ffffff;
    transform-origin: 0% 50%;
    transform: scale3d(1, 1, 1);
  }
}
.product-description-item-content ul, .product-description-item-content ol {
  padding-left: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content ul, .product-description-item-content ol {
    max-width: 100%;
    padding-left: 6.6666666667vw;
  }
}
.product-description-item-content ul li, .product-description-item-content ol li {
  color: #ffffff;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 0.9722222222vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .product-description-item-content ul li, .product-description-item-content ol li {
    font-size: 3.8888888889vw;
  }
}
.product-description-item-content ul li, .product-description-item-content ol li {
  line-height: 160%;
}
.product .section-advantages .container, .product .section-productions .container {
  padding: 0;
}

.error-page-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: 4.4444444444vw;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper {
    padding: 8.8888888889vw 0;
  }
}
.error-page-wrapper h1 {
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: 11.1111111111vw;
  line-height: 90%;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper h1 {
    font-size: 18.8888888889vw;
  }
}
.error-page-wrapper h1 {
  font-size: 13.8888888889vw;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper h1 {
    font-size: 38.8888888889vw;
  }
}
.error-page-wrapper p {
  text-align: center;
  max-width: 38.8888888889vw;
  margin-top: 1.1111111111vw;
  color: #1B1B1A;
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  font-size: 2.2222222222vw;
  line-height: 120%;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper p {
    font-size: 8.8888888889vw;
  }
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper p {
    max-width: 90%;
    margin-top: 4.4444444444vw;
  }
}
.error-page-wrapper span {
  text-align: center;
  display: block;
  max-width: 38.8888888889vw;
  margin: 1.3888888889vw 0;
  color: #077761;
  font-family: "Onest", sans-serif;
  font-weight: 400;
  font-size: 1.1111111111vw;
  line-height: 140%;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper span {
    font-size: 4.4444444444vw;
  }
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper span {
    max-width: 100%;
    margin: 4.4444444444vw 0;
  }
}
.error-page-wrapper a {
  margin-top: 1.6666666667vw;
}
@media screen and (max-width: 1023px) {
  .error-page-wrapper a {
    margin-top: 3.3333333333vw;
  }
}