@charset "UTF-8";

@import url("reset.css");
@import url("fonts.css");
@import url("swiper-bundle.min.css");

:root {
  --app-height: 100vh;
  --headroom-height: auto;

  --c0: #f5f5f5;
  --c1: #1f1132;
  --c2: #ffffff;
  --c3: #e6efff;
  --c4: #0166ff;

  --c5: color-mix(in srgb, currentColor 60%, transparent);
  --c6: color-mix(in srgb, currentColor 50%, transparent);
  --c7: color-mix(in srgb, currentColor 10%, transparent);
  --c8: color-mix(in srgb, currentColor 70%, transparent);
  --c9: color-mix(in srgb, currentColor 5%, transparent);
  --c10: color-mix(in srgb, currentColor 20%, transparent);
  --c11: #67e3d6;

  --cb1: rgba(0, 0, 0, 0.2);
  --cb2: rgba(0, 0, 0, 1);
  --cb3: rgba(0, 0, 0, 0.4);
  --cb4: rgba(0, 0, 0, 0.03);

  --wr: 30rem;
  --awr: calc(-1 * var(--wr));

  --gap: 25rem;
  --sl: max(1px, 1rem);

  --br1: 24rem;
  --br2: 16rem;
  --br3: 12rem;

  --btn: max(44px, 56rem);

  --f-s: max(14px, 16rem);
  --f-d: max(14px, 18rem);
  --f-m: max(14px, 20rem);
  --f-b: max(14px, 24rem);
  --f-l: max(14px, 28rem);
  --f-xl: max(14px, 32rem);
  --f-xl1: max(14px, 40rem);
  --f-xxl: max(14px, 48rem);
  --f-xxxl: max(14px, 54rem);
  --f-xxxxl: max(14px, 72rem);
  --f-num: max(14px, 84rem);

  --mw: 16000px;

  --swiper-pagination-color: var(--c1);
}

/* globals */

@media screen {
  html {
    font-size: 0.0625vw;
    background-color: var(--c0);
    scroll-margin: var(--headroom-height);
  }

  .lenis {
    scroll-behavior: auto;
  }

  .document {
    font-weight: 500;
    font-family: "Montserrat", sans-serif;
    font-size: var(--f-d);
    line-height: 1.3;
    color: var(--c1);
    background-color: var(--c0);
    letter-spacing: -0.06em;
  }

  .popup-active {
  }

  .wrapper {
    width: 100%;
    margin: 0 auto;
    padding: 0 var(--wr);
    max-width: var(--mw);
  }

  .preloader {
    background-color: var(--c0);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    visibility: hidden;
    opacity: 0;
    transition: all 0.25s 1s;
    display: flex;
    color: var(--c1);
    will-change: transform;
  }

  .loading {
    pointer-events: none;
  }
  .loading .preloader {
    transition-duration: 0s;
    opacity: 1;
    visibility: visible;
  }

  .icon {
    display: flex;
    max-height: 100%;
    align-items: center;
    justify-content: center;
    line-height: 0;
    max-width: 100%;
    width: auto;
    height: auto;
  }
  .cover,
  .contain {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-position: center;
    pointer-events: none;
  }
  .cover {
    object-fit: cover;
  }
  .contain {
    object-fit: contain;
  }
  .fill::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
  }

  .button {
    display: inline-flex;
    justify-content: center;
    max-width: 100%;
    user-select: none;
    cursor: pointer;
    align-items: center;
    z-index: 1;
    position: relative;
    background-clip: padding-box;
  }
  .button:not(.fill) {
    overflow: hidden;
    position: relative;
  }
  .button-text {
    overflow-y: clip;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
    position: relative;
    z-index: 2;
    min-width: 0;
    line-height: normal;
  }
  .button-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: none;
  }

  .button__default {
    background-color: var(--c4);
    color: var(--c2);
    border-radius: 999rem;
    padding: 0 30rem;
    height: var(--btn);
    min-width: 220rem;
  }
  .button__default .button-text:only-child {
  }
  .button__default .button-icon {
    width: max(20px, 24rem);
    height: max(20px, 24rem);
    margin: 0 10rem;
  }
  .button__default .button-icon:first-child {
    margin-left: -5rem;
  }
  .button__default .button-icon:last-child {
    margin-right: -5rem;
  }
  .button__secondary {
    color: var(--c4);
    border-radius: 999rem;
    padding: 0 30rem;
    border: var(--sl) solid var(--c10);
    height: var(--btn);
  }

  .button__inl .button-text {
    line-height: 1.2;
    margin: 0 1em;
  }
  .button__inl .button-text:first-child {
    margin-left: 0;
  }
  .button__inl .button-text:last-child {
    margin-right: 0;
  }
  .button__inl .button-icon {
    width: max(40px, 48rem);
    height: max(40px, 48rem);
    background-color: var(--c2);
    color: var(--c1);
    padding: 15rem;
    border-radius: 50%;
  }

  .button__wide {
    width: 100%;
  }

  .letter-wrap {
    position: relative;
    display: inline-block;
    min-width: 0.3em;
    text-align: left;
  }
  .letter-wrap::after {
    content: attr(data-letter);
    position: absolute;
    top: 100%;
    left: 0;
  }

  .title {
    line-height: 1.1;
    width: 100%;
    letter-spacing: -0.06em;
  }
  .title__medium {
    font-size: var(--f-xxl);
  }
  .title__default {
    font-size: var(--f-xxxl);
  }
  .title__large {
    font-size: var(--f-xxxxl);
  }

  .container {
    display: flex;
    flex-direction: column;
    min-height: var(--app-height);
  }

  .header {
    position: sticky;
    top: calc(-1 * var(--headroom-height));
    left: 0;
    width: 100%;
    z-index: 99;
    transition: all 0.25s;
    border-radius: 0 0 var(--br1) var(--br1);
    overflow-x: clip;
  }

  .topbar {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    grid-gap: var(--gap);
    align-items: center;
    padding: 25rem 0;
    position: relative;
  }
  .topbar-logo {
    max-width: 160rem;
    background-image: url(../img/match-logo-white.svg);
    background-size: contain;
    background-repeat: no-repeat;
  }
  .topbar-logo img {
    transition: opacity 0.25s;
  }
  .topbar-left,
  .topbar-right {
    display: flex;
    min-height: 100%;
    align-items: center;
  }
  .topbar-right {
    margin-left: auto;
  }
  .topbar-nav {
    display: grid;
    grid-auto-flow: column;
    grid-gap: 15rem;
    align-self: stretch;
  }
  .topbar-nav-menu {
    display: flex;
  }
  .topbar-nav-menu ul {
    display: grid;
    grid-auto-flow: column;
    grid-gap: 25rem;
  }
  .topbar-nav-menu li {
    display: flex;
    align-items: center;
  }

  .topbar-search {
    position: relative;
    display: flex;
  }

  .topbar-lang {
    position: relative;
    display: flex;
    padding: 10rem 0;
  }
  .topbar-lang-select {
    position: absolute;
    top: 100%;
    right: 0;
    min-width: 100%;
    z-index: 1;
    border-radius: var(--br1);
    padding: 10rem;
    background-color: var(--c2);
    box-shadow: 0 0 20rem var(--c9);
    cursor: default;
  }
  .topbar-lang-select ul {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .topbar-lang-select li {
    padding: 15rem 15rem;
    white-space: nowrap;
    position: relative;
    border-radius: var(--br3);
    background-color: var(--c7);
  }
  .topbar-lang-select li.active {
    color: var(--c6);
    pointer-events: none;
  }

  .topbar-lang:not(.active) .topbar-lang-select {
    visibility: hidden;
    opacity: 0;
  }
  .topbar-lang.active .topbar-action-icon {
    transform: scaleY(-1);
  }

  .topbar-action {
    margin: auto 0;
    padding: 15rem 25rem;
    border-radius: 999rem;
    display: flex;
    align-items: center;
    background-color: var(--c9);
    cursor: pointer;
    backdrop-filter: blur(200px);
  }
  .topbar-action-title {
    position: relative;
    overflow-y: clip;
  }
  .topbar-action-icon {
    flex: none;
    width: 1em;
    height: 1em;
    margin-left: 0.5em;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .dropdown-chevron {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
    margin-left: 5rem;
    flex: none;
  }

  .topbar-left .topbar-nav-menu li:first-child .dropdown {
    position: static;
  }
  .topbar-left .topbar-nav-menu li:first-child .dropdown-list {
    left: 0;
    transform: none;
    width: 100%;
    max-width: none;
  }

  .header.init:not(.static) {
    background-color: var(--c0);
    color: var(--c1);
  }

  .header.contrast.static {
    color: var(--c2);
  }

  .header.contrast.static .topbar-lang-select {
    backdrop-filter: blur(200px);
    background-color: var(--c9);
  }

  .header.contrast.static .topbar-action {
    background-color: var(--cb1);
  }

  .header.contrast.static .topbar-logo img {
    opacity: 0;
  }
  .header.active {
    top: 0;
  }

  .menu-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: flex-start;
    grid-gap: var(--gap);
  }
  .menu {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 30rem;
  }
  .menu:only-child {
    grid-column: 1/-1;
  }
  .menu-item {
    position: relative;
    min-height: 2em;
    padding-left: 3em;
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    max-width: 280rem;
  }
  .menu-item-icon {
    color: var(--c4);
    background-color: var(--c9);
    border-radius: 0.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 0;
    top: 0;
    padding: 0.35em;
    width: 2em;
    height: 2em;
  }
  .menu-item-subtitle {
    font-size: var(--f-s);
    margin-top: 5rem;
    color: var(--c5);
  }
  .menu-cards {
    grid-column: 2/-1;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: var(--gap);
  }
  .menu-cards .card-6 {
    border-radius: var(--br2);
  }
  .menu-cards .card-6 .card-content {
    padding: 15rem;
    border-radius: var(--br3);
  }
  .menu-cards .card-6 .card-title {
    font-size: var(--f-d);
  }

  .main {
    margin-top: 0;
    flex: auto;
    display: flex;
    flex-direction: column;
    overflow-x: clip;
  }

  .section {
    position: relative;
    z-index: 1;
    margin-bottom: 220rem;
  }
  .section:last-child {
    flex: auto;
  }

  .section__contrast:first-child {
    margin-top: calc(-1 * var(--headroom-height));
  }

  .section-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: flex-start;
    grid-gap: var(--gap);
  }
  .section-header:not(:last-child) {
    margin-bottom: 65rem;
  }
  .section-header-title .subtitle {
    margin-top: 25rem;
    font-size: var(--f-m);
    max-width: 580rem;
  }
  .section-header-aside {
    display: flex;
    flex-direction: column;
  }
  .section-header-subtitle {
    font-size: var(--f-m);
    max-width: 580rem;
  }
  .section-header-action:only-child {
    margin: auto 0 auto auto;
  }
  .section-header-action:not(:first-child) {
    margin-top: 30rem;
  }

  .footer {
    margin-top: 0;
    background-color: var(--c4);
    padding: var(--br1) 0 30rem;
    border-radius: var(--br1) var(--br1) 0 0;
    overflow: clip;
    color: var(--c2);
    background-image: url(../img/footer-bg.svg);
    background-position: left;
    background-size: cover;
    background-repeat: no-repeat;
  }

  .footer-grid {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 0 100rem;
    grid-template-areas: ". f1" "f2 f3" "f4 f4";
    overflow-x: clip;
    padding-top: 20rem;
  }
  .f1 {
    grid-area: f1;
    margin-bottom: 30rem;
    display: flex;
    align-items: center;
  }
  .f1-2 {
    margin-left: 20rem;
  }
  .f1-2 .tag {
    background-color: var(--cb1);
  }
  .f1-2 .tag-icon {
    color: var(--c2);
  }
  .f2 {
    grid-area: f2;
  }
  .f3 {
    grid-area: f3;
  }
  .f4 {
    grid-area: f4;
    margin-top: 125rem;
    margin-bottom: -3.375%;
    margin-left: -1%;
  }

  .footer-nav {
    display: flex;
    align-items: flex-start;
    margin: 0 -50rem;
  }
  .footer-item {
    flex: auto;
    margin: 0 50rem;
  }
  .footer-item-title {
    margin-bottom: 20rem;
    color: var(--c8);
  }
  .footer-item-title:empty::before {
    content: "\a0";
  }
  .footer-item-list ul {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0.5em;
  }

  .bottombar-author {
    display: flex;
    align-items: baseline;
    color: var(--c8);
  }
  .bottombar-author a {
    color: var(--c2);
  }

  .dd-icon {
    width: 1em;
    height: 1.2em;
    margin: 0 0.3em;
    opacity: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--c2);
  }
  .dd-icon .icon {
    width: 100%;
  }

  .page-header:not(:last-child) {
    margin-bottom: 70rem;
  }
  .page-header-inner {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .page-header-pretitle {
    margin-bottom: 25rem;
    overflow: hidden;
  }
  .page-header-title {
    max-width: 1200rem;
  }
  .page-header-subtitle {
    margin-top: 30rem;
    max-width: 580rem;
    font-size: var(--f-m);
  }
  .page-header-subtitle:has(a) {
    color: var(--c5);
  }
  .page-header-subtitle a {
    color: var(--c1);
  }
  .page-header-action {
    margin-top: 30rem;
  }
  .page-header-media {
    position: relative;
    width: 100%;
    display: flex;
    border-radius: var(--br1);
    overflow: hidden;
    margin-top: 70rem;
  }
  .page-header-media::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 40%;
  }
  .page-header-cards {
    margin-top: 70rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
    width: 100%;
  }

  .page-header-carousel {
    width: 100%;
    margin-top: 15rem;
    mask-image: linear-gradient(90deg, transparent, black, transparent);
  }
  .page-header-carousel .swiper {
    margin: 0 var(--awr);
  }
  .page-header-carousel .swiper-wrapper {
    transition-timing-function: linear !important;
  }
  .page-header-carousel .swiper-slide {
    width: 150rem;
    height: 150rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40rem;
    opacity: 0.3;
  }

  .page-header:has(.page-header-media):not(:last-child) {
    margin-bottom: 220rem;
  }
  .page-header:has(.page-header-media)
    + .section
    .section-header-title:only-child {
    text-align: center;
    grid-column: 1/-1;
  }

  .breadcrumbs {
    margin-bottom: 100rem;
    overflow: hidden;
  }
  .breadcrumbs ul {
    display: flex;
    flex-wrap: wrap;
    margin: -0.25em;
  }
  .breadcrumbs li {
    margin: 0.25em;
    display: flex;
    align-items: baseline;
  }
  .breadcrumbs li:not(:last-child) {
    color: var(--c5);
  }
  .breadcrumbs li:not(:last-child)::after {
    content: "/";
    padding-left: 0.5em;
  }
  .breadcrumbs li:last-child {
    pointer-events: none;
  }

  .expand-list {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .expand {
    padding: 25rem 0;
    border-top: var(--sl) solid var(--c7);
  }
  .expand:last-child {
    border-bottom: var(--sl) solid var(--c7);
  }
  .expand-title {
    font-size: var(--f-m);
    cursor: pointer;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
    align-items: center;
  }
  .expand-title-name {
  }
  .expand-title-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.2em;
    height: 1.2em;
  }
  .expand-content {
    overflow: hidden;
    height: 0;
    opacity: 0;
  }

  .textbox h3 {
    font-size: var(--f-xxl);
    line-height: 1.2;
    margin: 1.5em 0 1em;
  }
  .textbox h4 {
    font-size: var(--f-xl);
    line-height: 1.25;
    margin: 1.5em 0 1em;
  }
  .textbox h3:first-child,
  .textbox h4:first-child {
    margin-top: 0;
  }

  .textbox ul,
  .textbox ol {
    margin: 1em 0;
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0.5em;
    counter-reset: index;
  }
  .textbox ol {
    counter-reset: index;
  }
  .textbox ul:first-child,
  .textbox ol:first-child {
    margin-top: 0;
  }
  .textbox ul:last-child,
  .textbox ol:last-child {
    margin-bottom: 0;
  }
  .textbox li {
    position: relative;
    padding-left: 1.5em;
  }
  .textbox ul li::before {
    content: "\2022";
    position: absolute;
    top: 0;
    left: 0;
    width: 1.5em;
    text-align: center;
  }
  .textbox ol li::before {
    content: counter(index) ".";
    position: absolute;
    top: 0;
    left: 0;
    width: 1.5em;
    text-align: center;
    counter-increment: index;
  }

  .textbox img {
    margin: 30rem 0 50rem;
    border-radius: var(--br1);
    overflow: hidden;
  }
  .textbox img:first-child {
    margin-top: 0;
  }
  .textbox img:last-child {
    margin-bottom: 0;
  }

  .textbox a:not(.button) {
    text-decoration: underline;
  }

  .flaticon {
    width: max(72px, 84rem);
    height: max(72px, 84rem);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24rem;
    color: var(--c4);
    position: relative;
    background-color: var(--c9);
  }

  .player {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .player-holder {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
  }
  .player-button {
    flex: none;
    width: max(80px, 96rem);
    height: max(80px, 96rem);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--cb2);
    color: var(--c2);
    padding: 30rem;
    cursor: pointer;
  }

  .tags {
    display: flex;
    flex-wrap: wrap;
    margin: -5rem;
  }
  .tag {
    background-color: var(--c2);
    color: var(--c1);
    border-radius: 999rem;
    min-width: max(40px, 48rem);
    height: max(40px, 48rem);
    display: flex;
    align-items: center;
    text-align: center;
    margin: 5rem;
    justify-content: center;
    line-height: 1.2;
    position: relative;
    overflow: hidden;
  }
  .tag-name {
    flex: auto;
    text-align: center;
    padding: 0 30rem;
    white-space: nowrap;
  }
  .tag-icon {
    flex: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.5em;
    height: 1.5em;
    line-height: 1;
  }

  .share-caption {
    margin-bottom: 15rem;
    font-size: var(--f-m);
    color: var(--c6);
  }

  .linkedin-widget {
    border-radius: var(--br1);
    display: flex;
    overflow: hidden;
    background-color: var(--c2);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
  .linkedin-widget::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }

  .filters {
    overflow: hidden;
  }
  .filters-wrapper {
    display: flex;
    flex-wrap: wrap;
    margin: -10rem;
  }
  .filter {
    margin: 10rem;
    max-width: 200rem;
  }

  .selector {
    position: relative;
    background-color: var(--c2);
    color: var(--c1);
    border-radius: 999rem;
  }
  .selector-holder {
    display: flex;
    align-items: center;
    cursor: pointer;
    padding: 0 30rem;
    user-select: none;
    text-align: left;
    height: var(--btn);
  }
  .selector-holder-input {
    flex: auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    pointer-events: none;
  }
  .selector-holder-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
    flex: none;
    margin-left: 20rem;
  }
  .selector-list {
    position: absolute;
    z-index: 99;
    background-color: var(--c2);
    width: 100%;
    border-radius: var(--br1);
    color: var(--c1);
    padding: 15rem 0;
    margin-top: 10rem;
  }
  .selector-option {
    position: relative;
    padding: 15rem 30rem;
    cursor: pointer;
    z-index: 1;
    color: var(--c1);
  }
  .selector-option.active {
    color: var(--c4);
  }
  .selector-option-inner {
  }

  .selector.active {
  }
  .selector.active .selector-holder-icon {
    transform: scaleY(-1);
  }

  .selector-list:not(.active) {
    display: none;
  }

  .pagination {
    display: inline-grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    grid-gap: 15rem;
    margin: 0 auto;
  }
  .pagination-nav {
    user-select: none;
  }
  .pagination-nav ul {
    display: flex;
    flex-wrap: wrap;
    margin: -5rem;
  }
  .pagination-arrow,
  .pagination-nav li {
    position: relative;
    z-index: 1;
    min-width: var(--btn);
    height: var(--btn);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin: 5rem;
    border-radius: var(--br3);
    overflow: hidden;
    background-color: var(--c2);
  }
  .pagination-nav li a {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 5rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .pagination-nav li.current a {
    background-color: var(--c4);
    color: var(--c2);
    pointer-events: none;
    border-color: var(--c4);
  }
  .pagination-arrow.disabled {
    pointer-events: none;
    opacity: 0.6;
  }
  .pagination-arrow a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
  }

  .carousel-buttons {
    display: inline-grid;
    grid-auto-flow: column;
    grid-gap: 10rem;
  }
  .carousel-button {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15rem;
    border-radius: var(--br3);
    background-color: var(--c2);
    width: var(--btn);
    height: var(--btn);
  }

  .num-carousel {
    position: relative;
    overflow: hidden;
    font-size: var(--f-num);
    font-weight: 600;
    line-height: 1;
    mask-image: linear-gradient(transparent, black, black, transparent);
  }
  .num-carousel-prev,
  .num-carousel-next {
    user-select: none;
    opacity: 0.3;
  }
  .num-carousel-prev {
    margin-top: -0.35em;
  }
  .num-carousel-next {
    margin-bottom: -0.35em;
  }

  .char {
    width: 100%;
    display: flex;
    height: 50rem;
    color: var(--c11);
  }
  .char::after {
    content: "";
    flex: auto;
    border-radius: 8rem;
    color: var(--c11);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='500' height='500' viewBox='0 0 500 500'%3E%3Cdefs%3E%3Cpattern id='pattern1' width='15' height='15' patternUnits='userSpaceOnUse' patternTransform='rotate(-45)' %3E%3Cline x1='0' y1='0' x2='500' y2='0' stroke='%2367E3D6' stroke-width='5' /%3E%3C/pattern%3E%3C/defs%3E%3Crect x='0' y='0' width='500' height='500' fill='url(%23pattern1)' /%3E%3C/svg%3E");
    background-size: 150rem;
    background-color: var(--c7);
  }
  .char-active {
    flex: none;
    width: 0;
    border-radius: 8rem;
    background-color: currentColor;
    margin-right: 5rem;
  }

  .pie {
    width: 100%;
    max-width: 180rem;
    border-radius: 50%;
    display: flex;
    color: var(--c1);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='500' height='500' viewBox='0 0 500 500'%3E%3Cdefs%3E%3Cpattern id='pattern1' width='15' height='15' patternUnits='userSpaceOnUse' patternTransform='rotate(-45)' %3E%3Cline x1='0' y1='0' x2='500' y2='0' stroke='%231F1132' stroke-width='3' /%3E%3C/pattern%3E%3C/defs%3E%3Crect x='0' y='0' width='500' height='500' fill='url(%23pattern1)' /%3E%3C/svg%3E");
    background-size: cover;
    background-color: var(--c7);
    position: relative;
  }
  .pie::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
    position: relative;
  }
  .pie-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }

  .tabs-wrapper {
    display: flex;
    justify-content: center;
    width: 100%;
  }
  .tabs {
    background-color: var(--c2);
    border-radius: 999rem;
    overflow: hidden;
    padding: 5rem;
  }
  .tabs ul {
    display: flex;
    flex-wrap: wrap;
    height: var(--btn);
    overflow: hidden;
  }
  .tabs li {
    white-space: nowrap;
    padding: 0 30rem;
    display: flex;
    align-items: center;
    height: var(--btn);
    border-radius: 999rem;
    position: relative;
  }
  .tabs li.current {
    background-color: var(--c4);
    color: var(--c2);
    pointer-events: none;
  }

  .searchbox {
    background-color: var(--c2);
    color: var(--c1);
    border-radius: 999rem;
    overflow: hidden;
    padding: 0 25rem;
    display: flex;
    align-items: center;
  }
  .searchbox-input {
    flex: auto;
    min-width: 0;
    text-overflow: ellipsis;
    padding: 15rem 0;
  }
  .searchbox-icon {
    width: 1em;
    height: 1em;
    margin-left: 25rem;
    flex: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .search-result {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    margin: -10rem;
    padding: 10rem;
    border-radius: var(--br2);
    background-color: var(--cb4);
  }
  .search-result-media {
    position: relative;
    overflow: hidden;
    width: max(72px, 84rem);
    height: max(72px, 84rem);
    border-radius: var(--br2);
    padding: 25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--c4);
    background-color: var(--c9);
    flex: none;
    margin-right: 30rem;
  }
  .search-result-content {
    flex: auto;
  }
  .search-result-title {
    font-size: var(--f-b);
    white-space: nowrap;
    text-overflow: ellipsis;
    max-width: 900rem;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .search-result-subtitle {
    margin-top: 5rem;
    color: var(--c6);
  }

  .section__contrast *::-moz-selection,
  .footer *::-moz-selection {
    background-color: var(--c2);
    color: var(--c1);
    -webkit-text-fill-color: var(--c1);
  }

  .section__contrast *::selection,
  .footer *::selection {
    background-color: var(--c2);
    color: var(--c1);
    -webkit-text-fill-color: var(--c1);
  }
}

/* cards */

@media screen {
  .card {
    position: relative;
    overflow: hidden;
    display: flex;
    min-height: 100%;
    flex-direction: column;
    width: 100%;
  }

  .card-1 {
    border-radius: var(--br1);
  }
  .card-1 .card-inner {
    display: flex;
    width: 100%;
    position: relative;
    align-items: flex-end;
    padding: 15rem;
    z-index: 1;
    flex: auto;
  }
  .card-1 .card-inner::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 120%;
  }
  .card-1 .card-header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
  }
  .card-1 .card-content {
    background-color: var(--cb1);
    border-radius: var(--br2);
    padding: 25rem;
    color: var(--c2);
    backdrop-filter: blur(200px);
    width: 100%;
  }
  .card-1 .card-title {
    font-size: var(--f-l);
    max-width: 360rem;
  }
  .card-1 .card-subtitle {
    color: var(--c8);
    margin-top: 10rem;
  }

  .card-2 {
    padding: 35rem;
    border-radius: var(--br1);
    background-color: var(--c2);
  }
  .card-2 .card-header {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 0;
    align-items: center;
    margin-bottom: 90rem;
  }
  .card-2 .card-header-pretitle {
    grid-column: 1/-1;
    margin-bottom: 15rem;
    font-size: var(--f-m);
    color: var(--c6);
  }
  .card-2 .card-header-title {
    font-size: var(--f-l);
    max-width: 400rem;
  }
  .card-2 .card-header-icon:not(:first-child) {
    margin-left: var(--gap);
  }
  .card-2 .card-content {
    max-width: 460rem;
  }
  .card-2 .card-text {
    color: var(--c5);
  }
  .card-2 .card-action:not(:first-child) {
    margin-top: 25rem;
  }
  .card-2
    .card-header:has(.card-header-icon:only-child)
    ~ .card-content
    .card-text {
    color: var(--c1);
  }
  .card-2 .card-footer {
    margin-top: auto;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 0;
    align-items: center;
  }
  .card-2 .card-footer-icon:not(:first-child) {
    margin-left: var(--gap);
  }

  .card-3 {
    padding: 70rem 100rem;
    border-radius: var(--br1);
    background-color: var(--c2);
  }
  .card-3 .card-media {
    position: relative;
    min-height: 60rem;
  }

  .card-4 .card-header {
    display: flex;
    width: 100%;
    position: relative;
    border-radius: var(--br1);
    overflow: hidden;
  }
  .card-4 .card-header::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }
  .card-4 .card-content {
    margin-top: 25rem;
    padding-right: 80rem;
  }
  .card-4 .card-title {
    font-size: var(--f-b);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .card-4 .card-subtitle {
    font-size: var(--f-m);
    margin-top: 10rem;
    color: var(--c8);
  }

  .card-5 {
    padding: 35rem;
    border-radius: var(--br1);
    background-color: var(--c2);
  }
  .card-5 .card-inner {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    width: 100%;
  }
  .card-5 .card-header {
    margin-top: auto;
    display: grid;
    align-items: center;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
  }
  .card-5 .card-title {
    display: flex;
    align-items: center;
    font-size: var(--f-xl);
  }
  .card-5 .card-title-icon {
    flex: none;
    margin-left: 5rem;
    width: 1em;
    height: 1em;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity 0.25s;
    opacity: 0;
  }
  .card-5 .card-media {
    width: max(72px, 84rem);
    height: max(72px, 84rem);
    border-radius: 50%;
    position: relative;
    background-color: var(--c5);
    overflow: hidden;
  }
  .card-5 .card-content {
    max-width: 460rem;
    margin-top: 50rem;
    color: var(--c5);
  }

  .card-6 {
    border-radius: var(--br1);
  }
  .card-6 .card-inner {
    display: flex;
    width: 100%;
    position: relative;
    align-items: flex-end;
    padding: 15rem;
    z-index: 1;
    flex: auto;
  }
  .card-6 .card-inner::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }
  .card-6 .card-header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
  }
  .card-6 .card-content {
    background-color: var(--cb1);
    border-radius: var(--br2);
    padding: 25rem;
    color: var(--c2);
    width: 100%;
  }
  .card-6 .card-title {
    font-size: var(--f-l);
    max-width: 360rem;
  }

  .card-7 {
    border-radius: var(--br1);
    background-color: var(--c2);
    padding: 75rem;
  }
  .card-7 .card-content {
    max-width: 290rem;
  }
  .card-7 .card-title {
    color: var(--c4);
  }
  .card-7 .card-title .title {
    font-weight: 600;
  }
  .card-7 .card-subtitle {
    margin-top: 15rem;
    color: var(--c8);
  }

  .card-8 {
    border-radius: var(--br1);
  }
  .card-8 .card-inner {
    display: flex;
    width: 100%;
    position: relative;
    align-items: flex-end;
    padding: 20rem;
    z-index: 1;
    flex: auto;
  }
  .card-8 .card-inner::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 95%;
  }
  .card-8 .card-header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
  }
  .card-8 .card-content {
    background-color: var(--cb1);
    border-radius: var(--br2);
    padding: 25rem;
    color: var(--c2);
    backdrop-filter: blur(200px);
    width: 100%;
  }
  .card-8 .card-title {
    font-size: var(--f-m);
  }
  .card-8 .card-subtitle {
    color: var(--c8);
    margin-top: 5rem;
  }
  .card-8 .card-text {
    margin-top: 25rem;
    font-size: var(--f-b);
  }
}

/* sections */

@media screen {
  .s1-1 {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    grid-gap: var(--gap);
    align-items: flex-start;
  }
  .s1-2 {
    grid-column: 1/3;
    position: sticky;
    top: 50rem;
    z-index: 1;
    display: grid;
    grid-template-columns: auto;
    grid-gap: 30rem;
  }
  .s1-2 ul {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0.25em;
  }
  .s1-2 li:not(.current) {
    color: var(--c6);
  }
  .s1-3 {
    grid-column: 4/8;
    margin: 0 calc(-1 * var(--gap));
  }
  .s1-3-1 {
    margin-bottom: 70rem;
    margin-right: calc((100% - var(--gap)) / -4 + var(--gap));
  }
  .s1-3-3 {
    margin-bottom: 50rem;
  }
  .s1-3-4 {
    margin-top: 50rem;
  }
  .s1-4 {
    grid-column: 9/11;
    margin: auto 0 0 auto;
  }
  .s1-5-1 {
    margin-bottom: 10rem;
    font-size: var(--f-m);
  }
  .s1-5-2:not(:first-child) {
    padding-left: 20rem;
  }

  .s2-1 {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-gap: var(--gap);
  }
  .s2-1-1 {
    grid-column-end: span 2;
  }
  .s2-1-2 {
    grid-column-end: span 3;
  }
  .s2-2 {
    margin-bottom: 35rem;
  }
  .s2-3 {
    margin-top: 35rem;
    display: flex;
    justify-content: center;
  }

  .s3-1 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
  }
  .s3-2 {
    grid-column: 2/3;
  }
  .s3-2-1 {
    position: relative;
  }
  .s3-2-1::after {
    content: "";
    position: absolute;
    top: 0;
    left: 100%;
    width: 50vw;
    height: 100%;
    z-index: 1;
    background-color: var(--c0);
    opacity: 0.5;
  }
  .s3-2 .swiper-slide {
    opacity: 0;
    transform: scale(1.5) translateX(-50%);
    filter: blur(20px);
    transition: all 1s;
    pointer-events: none;
    overflow: visible;
  }
  .s3-2 .swiper-slide-active {
    pointer-events: all;
  }
  .s3-2 .swiper-slide-active,
  .s3-2 .swiper-slide-active ~ .swiper-slide {
    opacity: 1;
    transform: scale(1) translateX(0%);
    filter: blur(0);
  }

  .s4-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: flex-start;
    grid-gap: var(--gap);
  }
  .s4-2 {
    overflow: hidden;
    border-radius: var(--br1);
    display: flex;
    position: relative;
  }
  .s4-2::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 80%;
  }
  .s4-4 {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s4-5 {
    margin-top: 25rem;
  }
  .s4-6 {
    background-color: var(--c2);
    border-radius: var(--br1);
    padding: 25rem;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 5rem var(--gap);
    align-items: center;
  }
  .s4-7 {
    order: 1;
  }
  .s4-8 {
    max-width: 450rem;
  }
  .s4-8-1 {
    font-size: var(--f-b);
  }
  .s4-8-2 {
    margin-top: 5rem;
    color: var(--c5);
  }

  .s5-1 {
    display: grid;
    align-items: flex-start;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .s5-2-2 {
    margin-top: 25rem;
    font-size: var(--f-m);
    max-width: 580rem;
  }
  .s5-4 {
    margin: 0 var(--awr);
    overflow: hidden;
    position: relative;
    border-radius: var(--br1);
    display: flex;
  }
  .s5-4:not(:first-child) {
    margin-top: 50rem;
  }
  .s5-4::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 37.5%;
  }
  .s5-5 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
    align-items: flex-start;
  }
  .s5-5:not(:first-child) {
    margin-top: 50rem;
  }
  .s5-6 {
    border-radius: var(--br1);
    background-color: var(--c2);
    padding: 50rem 50rem 25rem;
  }
  .s5-7-2 {
    margin-top: 25rem;
    font-size: var(--f-m);
    max-width: 450rem;
  }
  .s5-8 {
    margin-top: 50rem;
    display: grid;
    grid-template-columns: auto;
    grid-gap: 15rem;
  }
  .s5-9 {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
    align-items: center;
    padding-top: 15rem;
    border-top: var(--sl) solid var(--c7);
  }
  .s5-9-1 {
    max-width: 450rem;
    font-size: var(--f-b);
  }

  .s6-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 0 var(--gap);
    align-items: flex-start;
  }
  .s6-2 {
    margin-bottom: 65rem;
  }
  .s6-3 {
    grid-column: 1/2;
    margin-right: 160rem;
  }
  .s6-3-1 {
    overflow: hidden;
    border-radius: var(--br1);
  }
  .s6-3-2 {
    margin-top: 25rem;
    font-size: var(--f-m);
    color: var(--c5);
  }
  .s6-4 {
    grid-column: 2/3;
    max-width: 580rem;
    font-size: var(--f-b);
  }

  .s7-1 {
    margin: 0 var(--awr);
    overflow: hidden;
    position: relative;
    display: flex;
    border-radius: var(--br1);
    color: var(--c2);
    background-color: var(--cb2);
    padding: 50rem var(--wr);
  }
  .s7-1::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 50%;
    max-height: var(--app-height);
  }
  .s7-2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.6;
  }
  .s7-3 {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 580rem;
    margin: auto;
  }
  .s7-3-2 {
    margin-top: 25rem;
  }
  .s7-3-3 {
    margin-top: 30rem;
  }
  .s7-3-3 .button {
    background-color: var(--cb3);
    backdrop-filter: blur(200px);
  }

  .s8-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .s8-2 {
    border-radius: var(--br1);
    overflow: hidden;
    position: relative;
    display: flex;
  }
  .s8-2::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 50%;
  }

  .s9-1 {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    grid-gap: 0 var(--gap);
    align-items: flex-start;
    grid-template-rows: auto auto 1fr;
  }
  .s9-2 {
    grid-column: 1/5;
  }
  .s9-2-2 {
    margin-top: 15rem;
    font-size: var(--f-b);
  }
  .s9-3 {
    grid-column: 7/11;
    grid-row: 1/4;
    position: relative;
    overflow: hidden;
    border-radius: var(--br1);
    display: flex;
    order: -1;
    position: sticky;
    top: var(--headroom-height);
  }
  .s9-3::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 105%;
  }
  .s9-3 img {
    object-position: top;
  }
  .s9-4 {
    grid-column: 1/5;
    margin-top: 25rem;
  }
  .s9-5 {
    grid-column: 1/5;
    margin-top: 65rem;
    font-size: var(--f-m);
  }

  .s10-1 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
  }
  .s10-2 {
    grid-column: 1/-1;
  }
  .s10-2 .swiper {
    overflow: hidden;
    margin: calc(var(--gap) / -2);
  }
  .s10-2 .swiper-slide {
    padding: calc(var(--gap) / 2);
  }
  .s10-3 {
    display: flex;
    justify-content: center;
    margin-top: 30rem;
    grid-column: 1/-1;
    position: relative;
  }
  .s10-3 .carousel-pagination {
    position: absolute;
  }

  .s11-1 {
    display: grid;
    grid-template-columns: repeat(10, 1fr);
    grid-gap: var(--gap);
    align-items: flex-start;
  }
  .s11-2 {
    grid-column: 4/8;
    margin: 0 calc(-1 * var(--gap));
  }
  .s11-3 {
    margin-bottom: 70rem;
  }
  .s11-4 {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 65rem;
  }
  .s11-5-1 {
    margin-bottom: 40rem;
  }
  .s11-5-2 ul {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0.5em;
    font-size: var(--f-b);
  }
  .s11-5-2 a {
    text-decoration: underline;
  }

  .s12-1 {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 10rem;
    position: relative;
    z-index: 2;
  }
  .s12-2 {
    background-color: var(--c2);
    border-radius: var(--br1);
    padding: 25rem;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-gap: var(--gap);
    align-items: center;
  }
  .s12-3 {
    grid-column: 1/4;
    font-size: var(--f-b);
  }
  .s12-4 {
    grid-column: 6/7;
    order: 1;
    display: flex;
  }
  .s12-4-1 {
    margin-left: auto;
    background-color: var(--c0);
    padding: 10rem 25rem;
    border-radius: var(--br2);
  }
  .s12-5 {
    grid-column: 4/6;
    position: relative;
    z-index: 1;
    pointer-events: none;
  }
  .s12-5-1 {
    position: absolute;
    overflow: hidden;
    display: flex;
    align-items: flex-start;
    padding: 30rem 50rem;
    background-color: var(--c2);
    width: 100%;
    max-width: 350rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--br2);
    box-shadow: 0 0 20rem var(--c9);
    top: 50%;
    transform: translate(-50%, -50%);
    left: 50%;
  }
  .s12-5-1::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 75%;
  }
  .s12-6 {
    margin-top: 35rem;
    display: flex;
    justify-content: center;
  }

  .s13-1 {
  }
  .s13-2 {
    min-height: var(--app-height);
    position: sticky;
    top: 0;
    border-radius: var(--br1);
    overflow: hidden;
    padding: 65rem var(--wr);
    margin: 0 var(--awr);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: var(--gap);
    background-color: var(--cb2);
    color: var(--c2);
  }
  .s13-3 {
    position: relative;
    z-index: 1;
    padding-bottom: var(--app-height);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 15rem var(--gap);
  }
  .s13-4 {
    grid-column: 3/4;
    border-radius: var(--br1);
    background-color: var(--cb1);
    color: var(--c2);
    backdrop-filter: blur(200px);
    display: flex;
    padding: 30rem;
  }
  .s13-4::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 70%;
  }
  .s13-5 {
    display: flex;
    flex-direction: column;
    max-width: 400rem;
  }
  .s13-5-1 {
    margin-bottom: auto;
    font-size: var(--f-xl);
  }
  .s13-5-2 {
    margin-top: 50rem;
  }
  .s13-6 {
    grid-column: 1/3;
  }
  .s13-6-1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    opacity: 0.8;
  }
  .s13-6-2 {
    position: relative;
    z-index: 1;
  }

  .s14-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
    align-items: center;
  }
  .s14-2 {
    max-width: 580rem;
  }
  .s14-2-2 {
    margin-top: 25rem;
    font-size: var(--f-m);
  }
  .s14-3 {
    position: relative;
    overflow: hidden;
    border-radius: var(--br1);
    display: flex;
  }
  .s14-3::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 55%;
  }

  .s15-1 {
    display: grid;
    position: relative;
    overflow: hidden;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-gap: var(--gap);
    align-items: flex-end;
    border-radius: var(--br1);
    background-color: var(--cb2);
    color: var(--c2);
    padding: 35rem;
    width: 100%;
  }
  .s15-2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  .s15-2 .swiper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .s15-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 0 var(--gap);
    align-items: flex-start;
    padding: 35rem;
  }
  .s15-3-1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
    opacity: 0.8;
  }
  .s15-3-2 {
    grid-column: 1/2;
  }
  .s15-3-3 {
    grid-column: 1/2;
    color: var(--c8);
    margin-top: 15rem;
    font-size: var(--f-m);
  }
  .s15-4 {
    position: relative;
    z-index: 1;
    grid-column: 2/3;
    background-color: var(--cb1);
    border-radius: var(--br2);
    padding: 25rem;
    margin-left: auto;
    max-width: 580rem;
  }
  .s15-5 {
    font-size: var(--f-b);
  }
  .s15-6 {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
    align-items: center;
    margin-top: 50rem;
    color: var(--c6);
  }
  .s15-6-1 {
    font-size: var(--f-b);
    display: flex;
  }
  .s15-6-1 .carousel-button {
    width: 1em;
    height: 1em;
    padding: 0;
    border-radius: 0;
    background-color: transparent;
  }
  .s15-7 {
    display: flex;
    width: 100%;
  }
  .s15-7::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 45%;
  }

  .s16-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
    align-items: center;
  }
  .s16-2 {
    max-width: 660rem;
  }
  .s16-2-1 {
    margin-bottom: 20rem;
    font-size: var(--f-b);
    color: var(--c6);
  }
  .s16-2-3 {
    margin-top: 30rem;
  }
  .s16-3 {
    display: flex;
    width: 100%;
    background-color: var(--c2);
    border-radius: var(--br1);
    padding: 120rem;
  }
  .s16-3::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 75%;
  }
  .s16-3-1 {
    position: relative;
    overflow: hidden;
    width: 100%;
  }

  .s17-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
    grid-template-rows: auto;
  }
  .s17-2 {
    display: flex;
  }
  .s17-2 .card-1 .card-inner::before {
    padding-top: 80%;
  }
  .s17-3 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .s17-4 {
    font-size: var(--f-s);
    text-align: center;
    color: var(--c5);
    grid-column: 2/3;
  }
  .s17-5 {
    background-color: var(--c2);
    border-radius: var(--br1);
    padding: 35rem;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 50rem var(--gap);
    align-items: center;
    grid-template-rows: 1fr 1fr;
  }
  .s17-5-1 {
    font-size: var(--f-xl1);
    font-weight: 600;
  }
  .s17-5-3 {
    grid-column: 1/-1;
    color: var(--c5);
    margin-bottom: auto;
  }

  .s18-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .s18-2 {
    background-color: var(--c2);
    border-radius: var(--br1);
    display: grid;
    padding: 30rem 35rem;
    grid-template-columns: auto;
    grid-template-rows: 1fr auto 1fr;
    text-align: center;
    grid-gap: 20rem;
  }
  .s18-2::before {
    content: "";
    height: 50rem;
  }
  .s18-3 {
    display: flex;
    align-items: center;
    flex-direction: column;
    width: 100%;
    max-width: 420rem;
    margin: 0 auto;
  }
  .s18-3-1 {
    font-size: var(--f-xl);
  }
  .s18-3-1 b {
    font-size: var(--f-xl1);
    font-weight: 600;
    color: var(--c4);
  }
  .s18-3-2 {
    font-size: var(--f-xl);
  }
  .s18-3-3 {
    color: var(--c8);
    margin-top: 15rem;
  }
  .s18-4 {
    font-size: var(--f-s);
    color: var(--c5);
  }

  .s19-1 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .s19-2 {
    border-radius: var(--br1);
    background-color: var(--c2);
    padding: 25rem;
    display: flex;
    flex-direction: column;
  }
  .s19-3 {
    font-size: var(--f-s);
    text-align: center;
    color: var(--c5);
    grid-column: 2/3;
  }
  .s19-4 {
    color: var(--c6);
    font-size: var(--f-m);
    margin-bottom: 30rem;
  }
  .s19-5 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 15rem;
    width: 100%;
    flex: auto;
    grid-template-rows: repeat(6, 1fr);
  }
  .s19-6 {
    background-color: var(--c0);
    border-radius: var(--br1);
    padding: 25rem;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 0 var(--gap);
    align-items: center;
    grid-template-rows: auto 1fr auto;
  }
  .s19-6-1 {
    font-size: var(--f-xl);
    font-weight: 600;
  }
  .s19-6-3 {
    margin-top: auto;
    grid-column: 1/-1;
    color: var(--c5);
    padding-top: var(--gap);
  }
  .s19-6-4 {
    grid-column: 1/-1;
    margin-top: 20rem;
    margin-bottom: 20rem;
    display: flex;
    justify-content: center;
  }
  .s19-6-5 {
    grid-column: 1/-1;
    margin-top: 20rem;
    margin-bottom: 20rem;
  }
  .s19-7 {
    background-color: var(--c4);
    color: var(--c2);
    border-radius: var(--br1);
    padding: 25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .s19-7-1 {
    flex: auto;
    overflow: hidden;
  }
  .s19-7-2 {
    margin-top: var(--gap);
    color: var(--c8);
  }

  .s20-1 {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-gap: 0 var(--gap);
    grid-template-rows: auto 1fr;
    align-items: flex-start;
  }
  .s20-2 {
    background-color: var(--c2);
    padding: 5rem;
    border-radius: 999rem;
    overflow: clip;
  }
  .s20-3 {
    grid-column: 1/4;
    max-width: 580rem;
  }
  .s20-3-2 {
    margin-top: 30rem;
    font-size: var(--f-m);
  }
  .s20-3-3 {
    margin-top: 30rem;
  }
  .s20-4 {
    order: -1;
    grid-column: 4/6;
    grid-row: 1/3;
    margin: 0;
    transform: translateX(var(--gap));
  }
  .s20-5 {
    position: relative;
    padding-top: 100%;
    width: 100%;
  }
  .s20-5::after {
    content: "";
    position: absolute;
    top: 0;
    left: 100%;
    width: 100%;
    height: 100%;
    z-index: 1;
    background-color: var(--c0);
    opacity: 0.5;
  }
  .s20-5-1 {
    display: flex;
    position: absolute;
    border-radius: var(--br1);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  .s20-6 {
    grid-column: 1/4;
    margin-bottom: 60rem;
    width: 100%;
    max-width: 620rem;
  }

  .s21-1 {
    display: flex;
    flex-direction: column;
  }
  .s21-2 {
    position: sticky;
    width: 100%;
    height: var(--app-height);
    top: 0;
    overflow: hidden;
    border-radius: 0;
    background-color: var(--cb2);
    color: var(--c2);
    border-radius: 0 0 var(--br1) var(--br1);
  }
  .s21-3 {
    display: flex;
    flex-direction: column;
    flex: none;
    width: 0;
    margin-top: 0;
    overflow: hidden;
  }
  .s21-3-1 {
    flex: none;
    height: 30vh;
    scroll-snap-stop: always;
  }
  .s21-4 {
    padding: var(--headroom-height) var(--wr) 70rem;
    flex-direction: column;
    min-height: 100%;
    height: var(--app-height);
    display: flex;
    position: relative;
    z-index: 1;
    will-change: transform;
    transition: all 1s;
  }
  .s21-4-1 {
    margin: 0 var(--awr);
  }
  .s21-4-2 {
    text-align: center;
    margin-top: auto;
  }
  .s21-5 {
    padding: var(--headroom-height) var(--wr) 70rem;
    flex-direction: column;
    min-height: 100%;
    height: var(--app-height);
    display: flex;
    position: relative;
  }
  .s21-5 .swiper {
    height: 100%;
  }
  .s21-6 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    opacity: 0.8;
    will-change: transform;
    transition: transform 0.3s;
  }
  .s21-7 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }
  .s21-7 .swiper-slide {
    overflow: hidden;
    display: flex;
  }
  .s21-8 {
    position: relative;
    z-index: 1;
    margin-top: auto;
    background-color: var(--cb1);
    border-radius: 999rem;
    backdrop-filter: blur(200px);
    will-change: transform;
    transition: transform 0.3s;
  }
  .s21-8 .swiper {
    mask-image: linear-gradient(
      90deg,
      transparent,
      black,
      black,
      black,
      transparent
    );
  }
  .s21-8 .swiper-slide {
    width: auto !important;
    padding: 15rem 30rem;
    white-space: nowrap;
    border-radius: 999rem;
    cursor: pointer;
    pointer-events: all !important;
  }
  .s21-8 .swiper-slide-active {
    background-color: var(--c2);
    color: var(--c1);
    pointer-events: none;
  }
  .s21-9 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: scale(1.1);
    transition: transform 0.5s;
    will-change: transform;
  }
  .s21-10 {
    position: relative;
    z-index: 1;
  }
  .s21-10-2 {
    margin-top: 25rem;
    font-size: var(--f-b);
    max-width: 580rem;
  }
  .s21-11 {
    width: 100%;
    min-height: 100%;
    position: relative;
    z-index: 1;
    padding: var(--headroom-height) var(--wr) 70rem;
  }

  .s21-2 .swiper-slide:not(.swiper-slide-active) .s21-4 {
    transform: translateY(-50%);
    filter: blur(200px);
  }
  .s21-2 .swiper-slide:not(.swiper-slide-active) .s21-6 {
    transform: scale(1.1);
  }
  .s21-2 .swiper-slide:not(.swiper-slide-active) .s21-8 {
    transform: translateY(100%);
  }
  .s21-2 .carousel-container-inner:not(.swiper-slide-active) .s21-9 {
    transform: scale(1);
  }
  .s21-7 .swiper-slide {
    transition-delay: 1s;
  }
  .s21-7 .swiper-slide-active {
    z-index: 2;
    transition-delay: 0s;
  }
  .s21-7 .swiper-slide .s21-11 {
    transition: clip-path 1s 0s;
    clip-path: inset(0% 0 0% 0);
  }
  .s21-7 .swiper-slide:not(.swiper-slide-active) .s21-11 {
    transition: clip-path 0s 1s;
    clip-path: inset(100% 0 0% 0);
  }
  .s21-7 .swiper-slide .s21-10 {
    transition: all 1s 0.5s;
  }
  .s21-7 .swiper-slide:not(.swiper-slide-active) .s21-10 {
    filter: blur(200px);
    transform: translateY(300rem);
    opacity: 0;
  }

  .s22-1 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
  }
  .s22-2 {
    grid-column: 2/3;
    max-width: 350rem;
    margin: 0 auto;
    width: 100%;
  }
  .s22-2 .swiper {
    overflow: visible;
  }
  .s22-2 .swiper-slide {
    transform-origin: bottom;
    background-color: var(--c2);
    overflow: hidden;
    border-radius: var(--br1);
  }
  .s22-2-1 {
    display: flex;
    position: relative;
    width: 100%;
    transition: transform 0.3s;
    color: var(--c2);
  }
  .s22-2-1::before {
    content: "";
    flex: none;
    width: 0;
  }
  .s22-2-1::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--cb2);
    opacity: 0.1;
    transition: opacity 0.3s;
  }
  .s22-2-1 rect {
    transition: all 0.3s;
  }

  .s22-2 .swiper-slide:not(.swiper-slide-active) .s22-2-1 {
    color: var(--c1);
  }
  .s22-2 .swiper-slide-active .s22-2-1::after {
    opacity: 0;
  }
  .s22-2 .swiper-slide:not(.swiper-slide-active) .s22-2-1 rect {
    fill: transparent;
  }

  .s23-1 {
    min-height: var(--app-height);
    overflow: hidden;
    margin: 0 var(--awr);
    position: relative;
    border-radius: 0 0 var(--br1) var(--br1);
    padding: var(--headroom-height) var(--wr) 0;
    display: flex;
    align-items: flex-end;
    color: var(--c2);
    background-color: var(--cb2);
  }
  .s23-2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    opacity: 0.7;
  }
  .s23-3 {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    margin-top: auto;
    padding: 90rem 0;
    text-align: center;
    align-items: center;
    width: 100%;
  }
  .s23-4 {
    margin-bottom: 10rem;
    width: max(60px, 80rem);
    height: max(60px, 80rem);
    position: relative;
    border-radius: 50%;
    overflow: hidden;
    background-color: var(--cb1);
    backdrop-filter: blur(200px);
  }
  .s23-4 .swiper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .s23-4-1 {
    color: var(--c2);
  }
  .s23-4-1 rect {
    fill: transparent;
  }
  .s23-5 {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .s23-5-2 {
    margin-top: 25rem;
    font-size: var(--f-l);
  }

  .s24-2 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
  }
  .s24-3 {
    position: relative;
    display: flex;
    padding: 15rem;
  }
  .s24-3::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }
  .s24-4 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    overflow: hidden;
    border-radius: var(--br1);
  }
  .s24-5 {
    background-color: var(--cb3);
    border-radius: var(--br2);
    padding: 25rem 50rem;
    color: var(--c2);
    width: 100%;
    z-index: 1;
    position: relative;
    margin-top: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .s24-6 {
    margin-bottom: 10rem;
  }
  .s24-7 {
    font-size: var(--f-b);
  }
  .s24-8 {
    margin-bottom: 65rem;
    flex-direction: column;
    display: flex;
  }
  .s24-9 {
  }
  .s24-10 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    min-height: 100%;
    z-index: 2;
    padding: var(--headroom-height) var(--wr) 50rem;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: 100rem var(--gap);
    color: var(--c2);
    grid-template-rows: 1fr auto;
    opacity: 1;
    user-select: none;
    pointer-events: none;
  }
  .s24-11 {
    grid-column: 1/-1;
    max-width: 550rem;
  }
  .s24-12 {
    position: relative;
    margin: 0 var(--awr);
    padding: 0 var(--wr);
  }
  .s24-13 {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
  }
  .s24-14 {
    position: absolute;
    top: 0;
    left: 0;
    border-radius: var(--br1);
    overflow: hidden;
    min-width: 100%;
    min-height: 100%;
  }
  .s24-15 {
    position: absolute;
    top: var(--app-height);
    opacity: 0;
    pointer-events: none;
    height: 100%;
    width: 100%;
    opacity: 0;
  }

  .s24-10 .s24-3 {
    padding: 0;
  }
  .s24-10 .s24-5 {
    align-items: flex-start;
    text-align: left;
    padding: 25rem;
  }
  .s24-10 .s24-6 .tags {
    margin: 0;
  }
  .s24-10 .s24-6 .tag {
    margin: 0;
  }
  .s24-10 .s24-6 .tag:not(:first-child) {
    margin-left: -10rem;
  }
  .s24-10 .s24-7 {
    margin: 0 0 90rem;
    order: -1;
  }

  .s24-9.active {
    overflow: hidden;
    position: relative;
    border-radius: var(--br1);
  }
  .s24-9.active .s24-2 {
    pointer-events: none;
  }
  .s24-9.active .s24-2 .s24-4 {
    opacity: 0;
  }
  .s24-9.active .s24-2 .s24-5 {
    opacity: 0;
  }
  .s24-9.active .s24-8 {
    opacity: 0;
  }
  .s24-9.active .s24-10 {
    opacity: 1;
    pointer-events: all;
    user-select: all;
  }

  .s25-1 {
    position: sticky;
    min-height: var(--app-height);
    display: flex;
    flex-direction: column;
    padding: var(--headroom-height) 0 90rem;
    top: 0;
  }
  .s25-2 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
  }
  .s25-3 {
    width: 100%;
    min-height: 100%;
  }
  .s25-3 .swiper {
    min-height: 100%;
    overflow: visible;
  }
  .s25-3 .swiper-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
  }
  .s25-3 .swiper-slide {
    user-select: all;
    display: flex;
  }
  .s25-4 {
    display: flex;
    flex-direction: column;
    margin: auto 0;
  }
  .s25-4-1 {
    font-size: var(--f-l);
  }
  .s25-4-2 {
    margin-top: 15rem;
    max-width: 350rem;
    font-size: var(--f-m);
    color: var(--c8);
  }
  .s25-4-3 {
    margin-top: 25rem;
  }
  .s25-6 {
    grid-column: 2/3;
    position: relative;
  }
  .s25-6 .swiper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .s25-7 {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 100rem;
  }
  .s25-7-2 {
    margin-top: 25rem;
    font-size: var(--f-m);
    max-width: 500rem;
  }
  .s25-8 {
    flex: auto;
    position: relative;
    width: 100%;
    display: flex;
  }
  .s25-9 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: var(--gap);
    width: 100%;
    transition: all 0.5s;
    transform: translateY(300rem);
  }
  .s25-11 {
    padding-bottom: 30vh;
    pointer-events: none;
    user-select: none;
    visibility: hidden;
  }
  .s25-11-1:not(:first-child) {
    height: 40vh;
  }

  .s25-3 .swiper-slide-prev .s25-9 {
    transform: translateY(-300rem);
  }
  .s25-3 .swiper-slide-active .s25-9 {
    transform: translateY(0);
  }

  .s26-1 {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .s26-2 {
    text-align: center;
  }
  .s26-3 {
    margin-top: 35rem;
    width: 100%;
    max-width: 710rem;
  }
  .s26-4 {
    text-align: center;
    margin-top: 15rem;
    font-size: var(--f-s);
    color: var(--c6);
  }
  .s26-4:empty {
    display: none;
  }
  .s26-5 {
    margin-top: 65rem;
    display: grid;
    grid-template-columns: auto;
    grid-gap: 35rem;
    width: 100%;
  }
  .s26-6 {
    border-bottom: var(--sl) solid var(--c7);
    padding-bottom: 35rem;
  }
  .s26-7 {
    margin-bottom: 25rem;
    color: var(--c5);
  }
  .s26-8 {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 25rem;
  }
  .s26-9 {
    display: flex;
    justify-content: center;
    margin-top: 35rem;
  }

  .s404-1 {
    min-height: calc(var(--app-height) - var(--headroom-height));
    display: flex;
  }
  .s404-2 {
    margin: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: center;
  }
  .s404-2-1 {
    font-size: 200rem;
  }
  .s404-2-2 {
    margin-top: 10rem;
    font-size: var(--f-m);
  }
  .s404-2-3 {
    margin-top: 30rem;
  }
}

@media screen and (max-width: 1023.98px) {
  :root {
    --wr: 16rem;
    --gap: 16rem;

    --br1: 16rem;
    --br2: 12rem;
    --br3: 8rem;

    --btn: 44rem;

    --f-xs: 12rem;
    --f-s: 14rem;
    --f-d: 16rem;
    --f-m: 18rem;

    --f-b: 24rem;
    --f-l: 28rem;

    --f-xl: 24rem;
    --f-xl1: 20rem;
    --f-xxl: 24rem;
    --f-xxxl: 28rem;
    --f-xxxxl: 40rem;

    --f-num: 64rem;

    --mw: 640rem;
  }

  html {
    font-size: 1px;
  }

  .desktop {
    display: none !important;
  }

  .button-text {
    font-size: var(--f-s);
  }

  .button__default {
    min-width: 0;
  }
  .button__secondary {
    padding: 0 25rem;
  }

  .title {
    line-height: 1.2;
  }
  .title__large {
    line-height: 1.05;
  }

  .title br {
  }

  .header {
    z-index: 999;
  }

  .topbar {
    grid-template-columns: 1fr auto;
    padding: 25rem 0;
  }
  .topbar-nav {
    grid-gap: 5rem;
  }
  .topbar-left,
  .topbar-nav-menu,
  .topbar-search {
    display: none;
  }
  .topbar-action-title {
    font-size: var(--f-s);
  }

  .topbar-logo {
    max-width: 115rem;
  }
  .topbar-action {
    padding: 0 25rem;
    height: var(--btn);
  }

  .topbar-lang {
    padding: 0;
  }
  .topbar-lang-select {
    padding: 10rem 0;
    margin-top: 10rem;
  }
  .topbar-lang-select li {
    background-color: transparent;
    padding: 10rem 25rem;
  }

  .topbar-menu {
    margin: auto 0;
    padding: 10rem;
    border-radius: 50%;
    display: flex;
    background-color: var(--c9);
    backdrop-filter: blur(200px);
    height: var(--btn);
    width: var(--btn);
  }
  .topbar-menu-inner {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .topbar-menu-inner::before,
  .topbar-menu-inner::after {
    content: "";
    left: 0;
    right: 0;
    height: 1.5rem;
    background-color: currentColor;
    position: absolute;
    margin: 0 3rem;
    transition: all 0.25s;
  }
  .topbar-menu-inner::before {
    margin-top: -5rem;
  }
  .topbar-menu-inner::after {
    margin-top: 5rem;
  }

  .breadcrumbs {
    margin-bottom: 70rem;
  }

  .textbox {
    font-size: var(--f-s);
  }
  .textbox img {
    margin: 30rem 0;
  }
  .textbox h2,
  .textbox h3,
  .textbox h4 {
    line-height: 1.2;
  }

  .tag {
    min-width: 40rem;
    height: 40rem;
  }
  .tag-icon {
    width: 16rem;
    height: 16rem;
  }
  .tag-name {
    padding: 0 25rem;
    font-size: var(--f-s);
  }

  .footer {
    padding: 60rem 0 15rem;
  }
  .footer-grid {
    grid-template-areas: "f4 ." "f2 f2" "f3 f1";
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0;
    grid-gap: calc(3 * var(--gap)) var(--gap);
  }
  .f1 {
    margin: 0;
    flex-direction: column;
    align-items: flex-start;
  }
  .f1-1 {
    margin-bottom: 1em;
  }
  .f1-2 {
    margin: 0;
  }
  .f2 {
    margin: 0;
  }
  .f3 {
    margin: 0;
  }
  .f4 {
    margin: 0;
  }
  .footer-nav {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: calc(2 * var(--gap)) var(--gap);
    margin: 0;
    grid-template-rows: auto auto 1fr;
  }
  .footer-item {
    margin: 0;
  }
  .footer-item:only-child {
    grid-column: 1/-1;
    grid-row: 1/4;
  }
  .footer-item:nth-child(3) {
    order: 2;
  }
  .footer-item:nth-child(4) {
    order: 3;
  }
  .footer-item:nth-child(4) .footer-item-title {
    margin-bottom: 0.3em;
  }
  .footer-item:nth-child(5) {
    order: 1;
    grid-row-end: span 2;
  }
  .footer-item-title {
    margin-bottom: 1em;
  }

  .bottombar {
    margin-top: 50rem;
  }

  .searchbox-input {
    font-size: var(--f-s);
  }
  .searchbox-icon {
    font-size: var(--f-m);
  }

  .share-caption {
    margin-bottom: 10rem;
    font-size: var(--f-s);
  }

  .flaticon,
  .player-button {
    padding: 12rem;
    width: 48rem;
    height: 48rem;
  }

  .carousel-button {
    padding: 12rem;
  }

  .search-result {
    border-radius: 0;
    padding: 0;
    margin: 0;
    background-color: transparent;
  }
  .search-result-media {
    width: 50rem;
    height: 50rem;
    margin-right: 15rem;
    padding: 15rem;
    border-radius: var(--br3);
  }
  .search-result-content {
    overflow: hidden;
  }
  .search-result-title {
    max-width: 100%;
    font-size: var(--f-d);
  }
  .search-result-subtitle {
    font-size: var(--f-s);
  }

  .filters-wrapper {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-gap: var(--gap);
    margin: 0;
    display: grid;
  }
  .filter {
    margin: 0;
  }

  .pagination {
    margin: 0;
    width: 100%;
  }
  .pagination-nav {
    margin: 0 auto;
  }
  .pagination-nav ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 5rem;
    margin: 0;
  }
  .pagination-arrow,
  .pagination-nav li {
    margin: 0;
  }

  .page-header:not(:last-child) {
    margin-bottom: 65rem;
  }
  .page-header:has(.page-header-media):not(:last-child) {
    margin-bottom: 100rem;
  }
  .page-header-inner .page-header-title:only-child {
    text-align: left;
  }
  .page-header-pretitle {
    margin-bottom: 15rem;
  }
  .page-header-subtitle {
    margin-top: 25rem;
    font-size: var(--f-s);
  }
  .page-header-media {
    margin-top: 50rem;
  }
  .page-header-media::before {
    padding-top: 100%;
  }
  .page-header-media:has(.player)::before {
    padding-top: 56.25%;
  }
  .page-header-carousel {
    margin: 0;
  }
  .page-header-carousel .swiper-slide {
    padding: 30rem;
    width: 100rem;
    height: 100rem;
  }
  .page-header-cards {
    margin-top: 50rem;
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 10rem;
  }

  .card-1 .card-content {
    padding: 15rem;
  }
  .card-1 .card-title {
    font-size: var(--f-xl1);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
  .card-1 .card-subtitle {
    font-size: var(--f-s);
  }

  .card-2 {
    padding: 25rem;
  }
  .card-2 .card-header {
    margin-bottom: 70rem;
  }
  .card-2 .card-header-pretitle {
    margin-bottom: 10rem;
    font-size: var(--f-s);
  }
  .card-2 .card-header-title {
    font-size: var(--f-xl1);
  }
  .card-2 .card-text {
    font-size: var(--f-s);
  }

  .card-3 {
    padding: 50rem 100rem;
  }

  .card-4 .card-content {
    padding-right: 60rem;
    margin-top: 15rem;
  }
  .card-4 .card-title {
    font-size: var(--f-m);
  }
  .card-4 .card-subtitle {
    margin-top: 5rem;
    font-size: var(--f-s);
  }

  .card-5 {
    padding: 25rem;
  }
  .card-5 .card-media {
    width: 65rem;
    height: 65rem;
  }
  .card-5 .card-title {
    font-size: var(--f-xl1);
  }
  .card-5 .card-content {
    margin-top: 35rem;
  }
  .card-5 .card-text {
    font-size: var(--f-s);
  }

  .card-6 .card-content {
    padding: 15rem;
  }
  .card-6 .card-title {
    font-size: var(--f-m);
  }

  .card-7 {
    padding: 60rem 35rem;
  }
  .card-7 .card-subtitle {
    font-size: var(--f-s);
    max-width: 265rem;
  }

  .card-8 .card-inner {
    padding: 200rem 15rem 15rem;
  }
  .card-8 .card-content {
    padding: 15rem;
  }
  .card-8 .card-title {
    font-size: var(--f-s);
  }
  .card-8 .card-subtitle {
    font-size: var(--f-xs);
  }
  .card-8 .card-text {
    margin-top: 15rem;
    font-size: var(--f-d);
  }

  .section-header {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 0;
  }
  .section-header:not(:last-child) {
    margin-bottom: 30rem;
  }
  .section-header-subtitle,
  .section-header-title .subtitle {
    margin-top: 15rem;
    font-size: var(--f-s);
    max-width: 320rem;
  }
  .section-header-action,
  .section-header-action:not(:first-child) {
    margin: 25rem 0 0;
  }
  .section-header-action:only-child {
    margin: 15rem 0 0;
  }

  .section {
    margin-bottom: 100rem;
  }

  .page-header:has(.page-header-media):not(:last-child) + .s1 .s1-2 {
    margin-top: -75rem;
  }

  .s1-1 {
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .s1-2 {
    margin-bottom: 100rem;
  }
  .s1-3 {
    grid-column: auto;
    margin: 0;
  }
  .s1-3-1 {
    margin: 0 0 65rem;
  }
  .s1-3-3 {
    margin-bottom: 30rem;
  }
  .s1-4 {
    display: none;
  }
  .s1-5 {
    display: none;
  }

  .s2-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 10rem;
  }
  .s2-1-1,
  .s2-1-2 {
    grid-column: auto;
  }
  .s2-1-1:not(:first-child) .card-4,
  .s2-1-2:not(:first-child) .card-4 {
    margin-top: 25rem;
  }
  .s2-2 {
    margin-bottom: 25rem;
  }
  .s2-3 {
    margin-top: 30rem;
  }

  .s3-2 {
    grid-column: 1/-1;
    max-width: 270rem;
  }
  .s3-2-1 .card-1 .card-title {
    font-size: var(--f-m);
  }
  .s3-2-1 .card-1 .card-subtitle {
    font-size: var(--f-xs);
    margin-top: 5rem;
  }

  .s4-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s4-5 {
    margin-top: 30rem;
  }
  .s4-6 {
    grid-template-columns: auto;
    grid-gap: 25rem;
  }
  .s4-7 {
    order: -1;
  }
  .s4-8 {
    padding-right: 20rem;
  }
  .s4-8-1 {
    font-size: var(--f-m);
  }
  .s4-8-2 {
    font-size: var(--f-s);
  }

  .s5-1 {
    grid-template-columns: auto;
    grid-gap: 30rem;
  }
  .s5-2-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
  }
  .s5-4::before {
    padding-top: 75%;
  }
  .s5-4:not(:first-child) {
    margin-top: 30rem;
  }
  .s5-5 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s5-5:not(:first-child) {
    margin-top: 30rem;
  }
  .s5-6 {
    padding: 30rem 25rem;
  }
  .s5-7-2 {
    margin-top: 10rem;
    font-size: var(--f-s);
  }
  .s5-8 {
    margin-top: 25rem;
    grid-gap: 25rem;
  }
  .s5-9 {
    padding-top: 25rem;
    grid-template-columns: auto;
    padding-right: 15rem;
  }
  .s5-9-1 {
    font-size: var(--f-m);
    order: 1;
  }

  .s6-1 {
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .s6-2 {
    margin-bottom: 0;
  }
  .s6-3 {
    grid-column: auto;
    margin: 30rem 0 0;
    order: 1;
  }
  .s6-3-2 {
    margin-top: 10rem;
    font-size: var(--f-xs);
  }
  .s6-4 {
    grid-column: auto;
    margin-top: 15rem;
    font-size: var(--f-s);
  }

  .s7-1 {
    min-height: var(--app-height);
  }
  .s7-3-2 {
    font-size: var(--f-s);
    margin-top: 15rem;
    max-width: 320rem;
  }
  .s7-3-3 {
    margin-top: 25rem;
  }

  .s8-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s8-2 {
    order: 1;
  }
  .s8-2::before {
    padding-top: 80%;
  }

  .s9-1 {
    grid-template-columns: auto;
    grid-gap: 0;
    grid-template-rows: auto;
  }
  .s9-2 {
    grid-column: auto;
    grid-row: auto;
    margin: 0;
    order: -1;
  }
  .s9-2-2 {
    font-size: var(--f-d);
  }
  .s9-3 {
    grid-column: auto;
    grid-row: auto;
    margin: 30rem 0 0;
    position: relative;
    top: auto;
  }
  .s9-4 {
    grid-column: auto;
    grid-row: auto;
    margin: 15rem 0 0;
  }
  .s9-5 {
    grid-column: auto;
    grid-row: auto;
    margin: 30rem 0 0;
  }

  .s10-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 0;
  }
  .s10-2 .swiper {
    overflow: visible;
    margin: 0 calc(var(--gap) / -4);
  }
  .s10-2 .swiper-slide {
    padding: 0 calc(var(--gap) / 4);
  }
  .s10-4 {
    margin-top: 30rem;
    display: flex;
    justify-content: center;
  }

  .s11-1 {
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .s11-2 {
    margin: 0;
    grid-column: auto;
  }
  .s11-3 {
    margin-bottom: 65rem;
  }
  .s11-4 {
    grid-gap: 50rem;
  }
  .s11-5-1 {
    margin-bottom: 15rem;
  }
  .s11-5-2 ul {
    font-size: var(--f-s);
  }

  .s12-2 {
    grid-template-columns: auto;
    grid-gap: 0;
    padding-bottom: 10rem;
  }
  .s12-3 {
    grid-column: auto;
    margin: 15rem 0 0;
    font-size: var(--f-xl1);
    padding-right: 65rem;
  }
  .s12-4 {
    grid-column: auto;
    margin: 0;
    order: -1;
  }
  .s12-4-1 {
    margin: 0;
    font-size: var(--f-xs);
    padding: 10rem 15rem;
  }
  .s12-5 {
    grid-column: auto;
    margin: 0;
  }
  .s12-5-1 {
    position: relative;
    transform: none;
    left: auto;
    top: auto;
    box-shadow: none;
    margin: 30rem -15rem 0;
    background-color: var(--c0);
    width: auto;
    max-width: none;
    padding: 15rem 50rem;
  }
  .s12-6 {
    margin-top: 30rem;
  }

  .s13-1 {
    position: relative;
    overflow: hidden;
    border-radius: var(--br1);
    display: grid;
    grid-template-rows: 1fr auto;
    grid-gap: 30rem;
    min-height: var(--app-height);
    padding: 65rem var(--wr) 15rem;
    margin: 0 var(--awr);
    background-color: var(--cb2);
  }
  .s13-2 {
    position: static;
    grid-template-columns: auto;
    grid-gap: 0;
    padding: 0;
    min-height: 0;
    top: auto;
    background-color: transparent;
    margin: 0;
    border-radius: 0;
    max-width: 320rem;
  }
  .s13-3 {
    grid-template-columns: auto;
    grid-auto-flow: column;
    grid-gap: 10rem;
    overflow: auto;
    padding: 0 var(--wr);
    margin: 0 var(--awr);
    overflow: -moz-scrollbars-none !important;
    scrollbar-width: none;
    scroll-snap-type: x mandatory;
    scroll-padding: var(--gap);
  }
  .s13-3::-webkit-scrollbar {
    display: none;
  }
  .s13-4 {
    grid-column: auto;
    width: 312rem;
    scroll-snap-align: start;
  }
  .s13-5-1 {
    font-size: var(--f-xl1);
  }
  .s13-5-2 {
    font-size: var(--f-s);
  }
  .s13-6 {
    grid-column: auto;
  }

  .s14-1 {
    grid-template-columns: auto;
    grid-gap: 30rem;
  }
  .s14-2-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
    max-width: 320rem;
  }

  .s15-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 30rem;
    grid-template-rows: 1fr 1fr;
    padding: 25rem;
  }
  .s15-2 {
  }
  .s15-3 {
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .s15-3-2 {
    grid-column: auto;
  }
  .s15-3-3 {
    grid-column: auto;
    max-width: 265rem;
    font-size: var(--f-xs);
    margin-top: 0.5em;
  }
  .s15-4 {
    grid-column: auto;
    grid-row: 2/3;
    max-width: none;
    margin: auto -10rem -10rem;
    padding: 15rem;
    backdrop-filter: blur(200px);
  }
  .s15-5 {
    font-size: var(--f-d);
  }
  .s15-6-1 {
    font-size: var(--f-xl1);
  }
  .s15-6-1 .carousel-button {
    padding: 0;
  }

  .s16-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 30rem;
  }
  .s16-2-1 {
    font-size: var(--f-s);
    margin-bottom: 15rem;
  }
  .s16-2-2 {
    max-width: 320rem;
  }
  .s16-2-3 {
    margin-top: 25rem;
  }
  .s16-3 {
    order: -1;
    padding: 50rem 65rem;
  }

  .s17-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s17-2 .card-1 .card-inner::before {
    padding-top: 100%;
  }
  .s17-3 {
    grid-template-columns: auto;
  }
  .s17-4 {
    grid-column: auto;
    max-width: 250rem;
    font-size: var(--f-xs);
    margin: 0 auto;
  }
  .s17-5 {
    padding: 25rem;
  }
  .s17-5-1 {
    font-size: var(--f-xxxl);
  }
  .s17-5-3 {
    font-size: var(--f-s);
    margin: auto 0 0;
  }

  .s18 .section-header.center .section-header-title {
    text-align: center;
  }
  .s18-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s18-2 {
    padding: 50rem 35rem;
    grid-template-rows: auto;
    grid-gap: 30rem;
  }
  .s18-2::before {
    display: none;
  }
  .s18-3-1 b {
    font-size: var(--f-xxxl);
  }
  .s18-3-3 {
    font-size: var(--f-s);
  }
  .s18-4 {
    font-size: var(--f-xs);
  }

  .s19-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s19-2 {
    padding: 25rem 35rem 10rem;
  }
  .s19-3 {
    grid-column: auto;
    margin: 0 auto;
    max-width: 250rem;
    font-size: var(--f-xs);
  }
  .s19-4 {
    margin-bottom: 25rem;
    font-size: var(--f-s);
  }
  .s19-5 {
    grid-template-columns: auto;
    grid-template-rows: auto;
    width: auto;
    margin: 0 -25rem;
  }
  .s19-6 {
    border-radius: var(--br2);
  }
  .s19-6-1 {
    font-size: var(--f-xxxl);
  }
  .s19-6-3 {
    padding-top: 50rem;
    font-size: var(--f-s);
  }
  .s19-6-4 {
    margin-bottom: 0;
  }
  .s19-7 {
    border-radius: var(--br2);
  }
  .s19-7-2 {
    font-size: var(--f-s);
    margin: 20rem auto 0;
    max-width: 250rem;
  }

  .s20-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 0;
    grid-template-rows: auto;
  }
  .s20-2 {
    border-radius: 0;
    background-color: transparent;
  }
  .s20-2-1 {
    text-align: center;
    color: var(--c5);
  }
  .s20-3 {
    grid-column: auto;
    order: -2;
    margin-bottom: 30rem;
  }
  .s20-3-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
    max-width: 320rem;
  }
  .s20-3-3 {
    margin-top: 25rem;
  }
  .s20-4 {
    grid-column: auto;
    grid-row: auto;
    transform: none;
  }
  .s20-4 .swiper {
    overflow: visible;
    margin: 0 calc(var(--wr) / -2);
  }
  .s20-4 .swiper-slide {
    padding: 0 calc(var(--wr) / 2);
  }
  .s20-5::after {
    display: none;
  }
  .s20-6 {
    grid-column: auto;
    margin: 25rem 0 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    grid-gap: var(--gap);
  }

  .s21-3-1:first-child {
    height: 10vh;
  }
  .s21-4 {
    padding-bottom: 35rem;
  }
  .s21-5 {
    padding-bottom: 35rem;
    padding-top: 25rem;
  }
  .s21-10-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
    max-width: 320rem;
  }

  .s22 .section-header.center .section-header-title {
    text-align: center;
  }
  .s22 .section-header.center .section-header-title .subtitle {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
  .s22-1 {
    grid-template-columns: minmax(0, 1fr);
    max-width: 190rem;
    margin: 0 auto;
  }
  .s22-2 {
    grid-column: auto;
  }

  .s23-3 {
    padding: 50rem 0;
  }
  .s23-4 {
    margin-bottom: 15rem;
    width: 48rem;
    height: 48rem;
  }
  .s23-5-2 {
    margin-top: 15rem;
    font-size: var(--f-d);
    max-width: 300rem;
  }

  .s24-2 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s24-3::before {
    padding-top: 100%;
  }
  .s24-5 {
    padding: 15rem 35rem;
  }
  .s24-6 .tag {
    width: 48rem;
    height: 48rem;
  }
  .s24-6 .tag-icon {
    width: 20rem;
    height: 20rem;
  }
  .s24-7 {
    font-size: var(--f-d);
  }
  .s24-8 {
    margin-bottom: 30rem;
    align-items: center;
    text-align: center;
  }
  .s24-9 {
    padding-bottom: 0;
  }
  .s24-10 {
    grid-template-columns: auto;
    grid-gap: 10rem;
    grid-template-rows: 1fr auto auto auto;
    padding-top: 65rem;
    padding-bottom: 15rem;
  }
  .s24-11 {
    margin-bottom: 100rem;
  }
  .s24-10 .s24-3::before {
    display: none;
  }
  .s24-10 .s24-7 {
    margin-bottom: 50rem;
    font-size: var(--f-m);
  }
  .s24-15 {
    display: none;
  }

  .s24-9 {
    height: auto !important;
  }
  .s24-9:not(.active) .s24-10 {
    display: none;
  }
  .s24-9.active {
    margin: 0 var(--awr);
  }
  .s24-9.active .s24-3,
  .s24-9.active .s24-13 {
    position: static;
  }
  .s24-9.active .s24-5 {
    backdrop-filter: blur(200px);
    background-color: var(--cb1);
  }

  .s25-1 {
    padding: 30rem 0;
  }
  .s25-2 {
    position: relative;
    height: auto;
  }
  .s25-3 {
    flex: none;
    margin-top: 25rem;
  }
  .s25-4 {
    grid-column: 1/-1;
    margin: 0 auto;
    text-align: center;
    align-items: center;
  }
  .s25-4-1 {
    font-size: var(--f-xl1);
  }
  .s25-4-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
  }
  .s25-4-3 {
    margin-top: 25rem;
  }
  .s25-7 {
    margin-bottom: 50rem;
  }
  .s25-7-2 {
    margin-top: 15rem;
    font-size: var(--f-s);
  }
  .s25-6 {
    grid-column: 1/-1;
    display: flex;
  }
  .s25-6::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }
  .s25-8 {
    flex-direction: column;
  }
  .s25-9 {
    transform: translateY(25rem);
  }

  .s25-3 .swiper-slide-prev .s25-9 {
    transform: translateY(-25rem);
  }

  .s26-3 {
    margin-top: 25rem;
  }
  .s26-4 {
    margin-top: 10rem;
    font-size: var(--f-xs);
  }
  .s26-5 {
    grid-gap: 25rem;
  }
  .s26-6 {
    padding-bottom: 25rem;
  }
  .s26-7 {
    margin-bottom: 15rem;
    font-size: var(--f-s);
  }
  .s26-8 {
    grid-gap: 10rem;
    grid-template-columns: minmax(0, 1fr);
  }
  .s26-9 {
    margin-top: 25rem;
  }

  .s404-2-1 {
    font-size: 130rem;
  }
  .s404-2-2 {
    font-size: var(--f-s);
  }

  .mainmenu {
    background-color: var(--c4);
    color: var(--c2);
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 99;
    background-image: url(../img/menu-bg.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: cover;
    transform: translateY(-100%);
    will-change: transform;
    transition: transform 0.5s;
    overflow: auto;
  }
  .mainmenu-inner {
    overflow: auto;
    min-height: var(--app-height);
    display: flex;
    flex-direction: column;
    padding: var(--headroom-height) 0 30rem;
  }

  .mainmenu-search {
    margin-bottom: 40rem;
  }
  .mainmenu-search .searchbox {
    background-color: var(--cb1);
    backdrop-filter: blur(200px);
    color: var(--c2);
  }

  .mainmenu-list ul {
    display: grid;
    grid-template-columns: auto;
    font-size: var(--f-xxl);
    grid-gap: 15rem;
  }
  .mainmenu-list li {
    transition: color 0s;
  }
  .mainmenu-list li:not(.active) .dropdown-list {
    display: none;
  }
  .mainmenu-list li.active .dropdown-chevron {
    transform: scaleY(-1);
  }

  .mainmenu-list:has(li.active) > ul > li {
    color: var(--c6);
  }
  .mainmenu-list:has(li.active) > ul > li.active {
    color: var(--c2);
  }

  .dropdown {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-gap: 0;
    align-items: center;
  }
  .dropdown-list {
    grid-column: 1/-1;
    padding: 10rem 15rem;
  }
  .dropdown-list ul {
    font-size: var(--f-xl1);
    grid-gap: 5rem;
  }

  .menu-active {
    overflow: hidden;
  }
  .menu-active .mainmenu {
    transform: translateY(0);
  }
  .menu-active .header {
    top: 0 !important;
    background-color: transparent !important;
    color: var(--c2) !important;
  }
  .menu-active .topbar-logo img {
    opacity: 0 !important;
  }
  .menu-active .topbar-menu-inner::before {
    margin-top: 0;
    transform: rotate(45deg);
  }
  .menu-active .topbar-menu-inner::after {
    margin-top: 0;
    transform: rotate(-45deg);
  }
  .menu-active .topbar-lang-select {
    backdrop-filter: blur(200px);
    background-color: var(--c9) !important;
  }
}

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

  .dropdown {
    display: inline-flex;
    align-items: center;
    position: relative;
    min-height: calc(100% + 25rem);
    padding-bottom: 25rem;
    margin-bottom: -25rem;
  }
  .dropdown-list {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--c2);
    padding: 30rem;
    border-radius: var(--br1);
    color: var(--c1);
    width: max-content;
    max-width: 380rem;
    box-shadow: 0 0 20rem var(--c9);
  }

  .section-header.center .section-header-title:only-child {
    text-align: center;
    grid-column: 1/-1;
  }
  .section-header.center .section-header-title:only-child .subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .card-2 .card-header:has(.card-header-icon:only-child) {
    margin-bottom: 0;
  }
  .card-2 .card-header:has(.card-header-icon:only-child) ~ .card-content {
    margin-top: 70rem;
  }

  .s2-1-2 .card-1 .card-inner::before {
    padding-top: 60%;
  }
  .s2-1-2 .card-1 .card-title {
    font-size: var(--f-b);
  }

  .s17-2 .card-1 .card-title {
    font-size: var(--f-b);
  }

  .s19-6 {
    grid-row-end: span 2;
  }
  .s19-2:nth-child(1) .s19-6:nth-child(1),
  .s19-2:nth-child(1) .s19-6:nth-child(4) {
    grid-row-end: span 3;
  }

  .s19-2:nth-child(2) .s19-7 {
    grid-row-end: span 3;
  }
  .s19-2:nth-child(2) .s19-6:nth-child(3) {
    grid-row-end: span 4;
  }
  .s19-2:nth-child(2) .s19-6:nth-child(4) {
    grid-row-end: span 3;
  }

  .s19-6-2 .flaticon {
    width: var(--btn);
    height: var(--btn);
    padding: 15rem;
  }

  .s20-2-1 {
    padding: 0 30rem;
    height: var(--btn);
    cursor: pointer;
    border-radius: 999rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .s20-2 .swiper {
    overflow: visible;
  }
  .s20-2 .swiper-slide-active .s20-2-1 {
    background-color: var(--c4);
    color: var(--c2);
  }
  .s20-4 .swiper-slide {
    opacity: 0;
    transform: scale(1.5) translateX(-50%);
    filter: blur(20px);
    transition: all 1s;
    pointer-events: none;
    overflow: visible;
  }
  .s20-4 .swiper-slide-active {
    pointer-events: all;
  }
  .s20-4 .swiper-slide-active,
  .s20-4 .swiper-slide-active ~ .swiper-slide {
    opacity: 1;
    transform: scale(1) translateX(0%);
    filter: blur(0);
  }

  .s24-12:has(.s24-15) {
    height: 250vh;
    margin-top: calc(-1 * var(--headroom-height));
    overflow: clip;
  }
  .s24-12:has(.s24-15) .s24-3:nth-child(2) {
    z-index: 2;
  }
  .s24-12:has(.s24-15) .s24-9 {
    position: sticky;
    top: 0;
    padding-top: var(--headroom-height);
    min-height: var(--app-height);
  }
  .s24-14 {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100vw;
    height: 150vh;
  }

  .s25-3 .swiper-slide:nth-child(even) .s25-4 {
    grid-column: 3/4;
  }
}

@media screen and (min-width: 16000px) {
  html {
    font-size: 1px;
  }
}

/* hover animations */

@media (hover: hover) and (pointer: fine) and (min-width: 1024px) {
  .card-5:hover .card-title-icon {
    opacity: 1;
  }

  .dropdown-list,
  .topbar-lang-select {
    transition: all 0.25s;
  }

  .dropdown:not(:hover) .dropdown-list {
    visibility: hidden;
    opacity: 0;
  }
  .dropdown:hover .dropdown-chevron {
    transform: scaleY(-1);
  }

  .topbar-nav-menu li {
    transition: color 0.15s;
  }

  .topbar.hovered .topbar-nav-menu li:not(:hover) {
    color: var(--c5);
  }

  .letter-wrap {
    will-change: transform;
  }

  .button:not(:hover) .letter-wrap,
  .topbar-search:not(:hover) .letter-wrap {
    transition-delay: 0s !important;
  }

  .button:hover .letter-wrap,
  .topbar-search:hover .letter-wrap {
    transform: translateY(-100%);
    transition: transform 0.25s;
  }

  .search-result,
  .topbar-lang-select li {
    transition: background-color 0.25s;
  }
  .search-result:not(:hover),
  .topbar-lang-select li:not(:hover) {
    background-color: transparent;
  }

  .s12-3,
  .s12-4 {
    transition: color 0.25s;
  }
  .s12-5 {
    transition: all 0.25s;
  }

  .s12-2:not(:hover) .s12-3 {
    color: var(--c6);
  }
  .s12-2:not(:hover) .s12-4 {
    color: var(--c6);
  }
  .s12-2:not(:hover) .s12-5 {
    opacity: 0;
    transform: scale(0.5);
  }

  .card-1 .card-media {
    will-change: transform;
    transition: transform 0.25s;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .card-1:hover .card-media {
    transform: scale(1.05);
  }

  .card-3 .card-media,
  .card-5 .card-inner {
    transition: opacity 0.25s;
  }

  .s2-1:has(.card-3),
  .s2-1:has(.card-5) {
    pointer-events: none;
  }
  .s2-1 .card-3,
  .s2-1 .card-5 {
    pointer-events: all;
  }
  .s2-1:has(.card-3):hover .card-3:not(:hover) .card-media,
  .s2-1:has(.card-5):hover .card-5:not(:hover) .card-inner {
    opacity: 0.4;
  }

  .card-5:hover .card-title-icon {
    opacity: 1;
  }

  .pie-image {
    transition: transform 0.25s;
    will-change: transform;
  }

  .s19-6:hover .pie-image {
    transform: scale(1.1);
  }

  .char-active {
    transition: box-shadow 0.25s;
  }

  .s19-6:hover .char-active {
    box-shadow: 0 0 20rem var(--c11);
  }

  .s19-6-5 {
    transition: opacity 0.25s;
  }
  .s19-6:has(.s19-6-5) .s19-6-2 {
    transition: all 0.25s;
    will-change: transform;
  }

  .s19-6:has(.s19-6-5):hover .s19-6-2 {
    transform: translateY(50%);
    opacity: 0;
  }
  .s19-6:not(:hover) .s19-6-5 {
    opacity: 0;
  }
}
