@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: #000000;
  --c1: #ffffff;
  --c2: #d9331d;
  --c3: rgba(240, 240, 240, 0.6);
  --c4: #1b1b1b;

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

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

  --br1: 10rem;
  --br2: 20rem;

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

  --f-s: max(14px, 16rem);
  --f-d: max(14px, 18rem);
  --f-m: max(14px, 20rem);
  --f-b: max(14px, 24rem);
  --f-l: max(14px, 36rem);
  --f-xl: max(14px, 48rem);
  --f-xxl: max(14px, 64rem);

  --mw: 192000px;
}

/* globals */

@media screen {
  html {
    font-size: 0.052vw;
    background-color: var(--c0);
  }

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

  .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;
    transform: scale(1.05);
  }
  .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;
    border-radius: var(--br1);
    background-clip: padding-box;
  }
  .button:not(.fill) {
    overflow: hidden;
    z-index: 1;
    position: relative;
  }
  .button-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
    position: relative;
    z-index: 2;
    min-width: 0;
    padding: 0 0.1em;
  }
  .button-icon {
    width: 1em;
    height: 1em;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 10rem;
  }
  .button-icon:first-child {
    margin-left: 0;
  }
  .button-icon:last-child {
    margin-right: 0;
  }

  .button__default {
    background-color: var(--c2);
    color: var(--c1);
    height: var(--btn);
    border-radius: 999rem;
    padding: 0 30rem;
    border: var(--sl) solid var(--c2);
  }
  .button__default .button-text {
    font-size: var(--f-m);
  }
  .button__contrast {
    background-color: var(--c1);
    color: var(--c2);
    border: var(--sl) solid var(--c1);
  }
  .button__wide {
    width: 100%;
  }

  .title {
    line-height: 1;
    font-weight: 500;
    width: 100%;
  }

  .title__medium {
    font-size: var(--f-l);
  }
  .title__default {
    font-size: var(--f-xl);
  }
  .title__large {
    font-size: var(--f-xxl);
  }

  .textfield {
    overflow: hidden;
    border: var(--sl) solid var(--c3);
    border-radius: 18rem;
  }
  .textfield-input {
    min-width: 0;
    text-overflow: ellipsis;
    padding: 25rem;
    font-size: var(--f-m);
    width: 100%;
  }

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

  .header {
    position: sticky;
    top: 0;
    z-index: 99;
    display: flex;
    align-items: flex-start;
    height: 0;
  }

  .topbar-container {
    width: 100%;
    display: flex;
  }
  .topbar {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
    align-items: center;
    flex: none;
    width: 100%;
    transition: all 0.5s 1.5s;
    background-color: rgba(255, 255, 255, 0.05);
    backdrop-filter: blur(10px);
    margin: 20rem 0;
    padding: 20rem 20rem 20rem 35rem;
    border-radius: 999rem;
  }
  .topbar-main {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: var(--gap);
    align-items: center;
  }
  .topbar-logo {
    max-width: 220rem;
  }

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

  .section {
    position: relative;
    z-index: 1;
    margin-bottom: 200rem;
  }
  .section:first-child {
    z-index: 2;
  }
  .section:last-child {
    margin-bottom: 0;
  }
  .section:only-child {
    flex: auto;
  }

  .section-header {
    display: flex;
    flex-direction: column;
  }
  .section-header:not(:last-child) {
    margin-bottom: 40rem;
  }
  .section-header-pretitle {
    margin-bottom: 20rem;
  }
  .section-header-title {
    max-width: 800rem;
  }

  .section-footer {
    display: flex;
    justify-content: center;
    margin-top: 40rem;
  }

  .footer {
    overflow: hidden;
    padding: 200rem 0 20rem;
  }
  .footer-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-gap: 0 var(--gap);
    display: grid;
    align-items: flex-start;
  }
  .f1 {
    grid-column: 1/3;
  }
  .f2 {
    grid-column: 4/6;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: var(--gap);
  }
  .f3 {
    grid-column: 1/-1;
    margin: 200rem 0 calc(-1 * var(--f-s));
    color: var(--c1);
    position: relative;
    transition: color 0.25s;
  }
  .f3.active {
    color: var(--c2);
  }
  .f4 {
    grid-column: 1/3;
  }
  .f5 {
    grid-column: 4/6;
  }
  .f6 {
    grid-column: 6/7;
    text-align: right;
  }
  .f7 {
    display: none;
  }

  .f4,
  .f5,
  .f6 {
    text-transform: uppercase;
    font-size: var(--f-s);
    position: relative;
    z-index: 1;
  }

  .footer-nav-caption {
    margin-bottom: 40rem;
    font-size: var(--f-b);
    font-weight: 500;
    opacity: 0.6;
  }
  .footer-nav-list {
    font-size: var(--f-b);
  }
  .footer-nav-list ul {
    display: grid;
    grid-template-columns: auto;
    grid-gap: 0.5em;
  }

  .footer-form-title {
    margin-bottom: 20rem;
  }
  .footer-form-input {
    max-width: 460rem;
  }
  .footer-form-footer {
    margin-top: 20rem;
  }

  .bottombar-author {
    display: flex;
    align-items: baseline;
  }

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

  .tag {
    border-radius: 999rem;
    font-size: var(--f-m);
    padding: 10rem 20rem;
    position: relative;
    z-index: 1;
    display: inline-flex;
  }
  .tag::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: inherit;
    border: var(--sl) solid;
    opacity: 0.4;
    z-index: -1;
  }

  .carousel-buttons {
    display: inline-grid;
    grid-gap: 10rem;
    grid-auto-flow: column;
  }
  .carousel-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: max(40px, 48rem);
    height: max(40px, 48rem);
    position: relative;
    cursor: pointer;
    border-radius: 4rem;
    background-color: var(--c0);
  }
  .carousel-button::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: inherit;
    border: var(--sl) solid;
    opacity: 0.2;
    z-index: 1;
  }

  .imgcols {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .imgcols-inner {
    display: grid;
    transform: translate(-50%, -50%);
    position: absolute;
    top: 50%;
    left: 50%;
    grid-auto-flow: column;
    grid-gap: var(--gap);
    align-items: flex-start;
  }
  .imgcols-col {
    position: relative;
    display: grid;
    grid-template-columns: auto;
    align-items: flex-start;
    width: 300rem;
    grid-gap: var(--gap);
  }
  .imgcols-item {
    position: relative;
    overflow: hidden;
    width: 100%;
    display: flex;
  }
  .imgcols-item::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 125%;
  }
  .imgcols-item:nth-child(4n + 4)::before {
    padding-top: 100%;
  }
  .imgcols-item img {
  }
}

/* cards */

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

  .card-1 {
    flex-direction: row;
  }
  .card-1::before {
    content: "";
    flex: none;
    width: 0;
    padding-top: 100%;
  }
  .card-1 .card-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 50rem;
    padding: 30rem;
    align-items: flex-end;
    grid-template-rows: 1fr auto 1fr;
    position: relative;
    z-index: 1;
    border-radius: var(--br2);
  }
  .card-1 .card-inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    border: var(--sl) solid;
    z-index: -1;
    opacity: 0.2;
  }
  .card-1 .card-header {
    margin-bottom: auto;
  }
  .card-1 .card-header .tag {
    font-size: var(--f-s);
  }
  .card-1 .card-content {
    grid-column: 1/-1;
    margin-bottom: auto;
  }
  .card-1 .card-footer {
    opacity: 0.7;
  }

  .card-2 {
    border-radius: var(--br2);
  }
  .card-2 .card-media {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.7;
    transition: opacity 0.5s 0.15s;
  }
  .card-2 .card-inner {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    min-height: 500rem;
    border-radius: var(--br2);
    padding: 30rem;
  }
  .card-2 .card-inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    border: var(--sl) solid;
    z-index: -1;
    opacity: 0.2;
  }
  .card-2 .card-header {
    display: flex;
    align-items: flex-start;
    width: 100%;
  }
  .card-2 .card-content {
    display: flex;
    overflow: hidden;
    align-items: center;
    margin: 40rem 0;
    width: 100%;
    flex: auto;
    transition: transform 0.35s 0.15s;
  }
  .card-2 .card-text {
    flex: none;
    width: 425rem;
    transition: opacity 0.5s 0.15s;
  }
  .card-2 .card-title {
    flex: 1;
    transition: all 0.5s;
    margin: 0 auto;
    white-space: nowrap;
  }
  .card-2 .card-subtitle {
    flex: none;
    display: flex;
    max-width: 50%;
    overflow: hidden;
    transition:
      opacity 0.5s 0.15s,
      transform 0.5s 0.15s;
    will-change: transform;
    flex-wrap: wrap;
    margin: -5rem 0;
    justify-content: flex-end;
  }
  .card-2 .card-subtitle .tag {
    margin: 5rem 0 5rem 10rem;
  }

  .card-3 {
    border-radius: var(--br2);
  }
  .card-3 .card-media {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.7;
    transition: opacity 0.5s 0s;
  }
  .card-3 .card-inner {
    display: grid;
    min-height: 500rem;
    border-radius: var(--br2);
    padding: 30rem;
    grid-template-rows: 1fr auto 1fr;
    grid-gap: 40rem;
  }
  .card-3 .card-inner::before {
    content: "(" counter(index, decimal-leading-zero) ")";
    font-size: var(--f-b);
    position: relative;
    z-index: 1;
  }
  .card-3 .card-title {
    position: relative;
    z-index: 1;
  }
  .card-3 .card-text {
    margin-top: auto;
    position: relative;
    z-index: 1;
  }
}

/* sections */

@media screen {
  .s1-1 {
    display: flex;
    align-items: center;
    margin: 0 var(--awr);
    padding: 100rem 0;
    min-height: var(--app-height);
    transition: opacity 1s 2s;
  }
  .s1-2 {
    flex: 1;
    text-align: center;
    text-transform: uppercase;
    font-size: 300rem;
    position: relative;
    z-index: 2;
    pointer-events: none;
    mix-blend-mode: difference;
  }
  .s1-3,
  .s1-4,
  .s1-6 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .s1-4 {
    display: flex;
    transition: all 0s 2.5s;
  }
  .s1-5 {
    flex: 1;
    position: relative;
    display: flex;
    justify-content: flex-end;
    padding: 75rem var(--wr);
    align-items: center;
    flex-direction: column;
    text-align: center;
    overflow: hidden;
  }
  .s1-5-1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1;
  }
  .s1-5-2 {
    border: var(--sl) solid;
    border-radius: 999rem;
    font-size: var(--f-b);
    padding: 5rem 20rem;
  }
  .s1-5-3 {
    margin-top: 24rem;
  }

  .loading .topbar {
    transform: translateY(-100%);
    opacity: 0;
    transition-duration: 0s;
  }
  .loading .s1-1 {
    opacity: 0;
    transition-duration: 0s;
  }
  .loading .s1-4 {
    visibility: hidden;
    transition-duration: 0s;
  }

  .s2-1 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    opacity: 0.4;
  }
  .s2-1 .imgcols {
    transform: rotate(20deg);
  }
  .s2-1 .imgcols-col:nth-child(4n + 1) {
    margin-top: -300rem;
  }
  .s2-1 .imgcols-col:nth-child(4n + 2) {
    margin-top: -100rem;
  }
  .s2-1 .imgcols-col:nth-child(4n + 3) {
    margin-top: -200rem;
  }
  .s2-2 {
    min-height: var(--app-height);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    justify-content: center;
    padding: calc(var(--headroom-height) + 80rem) 0 80rem;
    grid-column: 2/4;
  }
  .s2-2-2 {
    margin-top: 25rem;
    max-width: 500rem;
    font-size: var(--f-b);
  }
  .s2-2-3 {
    margin-top: 30rem;
  }
  .s2-3 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: var(--gap);
    position: relative;
    z-index: 1;
  }

  .s3 .section-header {
    align-items: center;
    text-align: center;
  }
  .s3-1 {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-gap: var(--gap);
  }
  .s3-2 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 0;
    grid-column: 3/11;
    counter-reset: index;
  }
  .s3-3 {
    padding: 0 30rem;
    counter-increment: index;
  }
  .s3-3:nth-child(1) .card-3 {
    background-color: var(--c1);
    color: var(--c0);
  }
  .s3-3:nth-child(2) .card-3 {
    background-color: var(--c2);
    color: var(--c1);
  }
  .s3-3:nth-child(3) .card-3 {
    background-color: var(--c4);
    color: var(--c1);
  }

  .s4-1 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-gap: 40rem;
    align-items: flex-end;
    overflow: hidden;
    margin: 0 var(--awr);
    padding: 0 var(--wr);
  }
  .s4-2 .section-header-title {
    max-width: none;
  }
  .s4-4 {
    grid-column: 1/-1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-gap: var(--gap);
  }
  .s4-4 .swiper {
    overflow: visible;
  }
  .s4-4 .swiper-slide {
    padding: 0 calc(var(--gap) / 2);
    transition: all 0.25s;
    display: flex;
    height: auto;
  }
  .s4-5 {
    grid-column: 1/-1;
    margin: 0 -40rem;
  }
  .s4-5 .swiper {
    overflow: visible;
  }
  .s4-5 .swiper-slide {
    padding: 0 40rem;
    transition: opacity 0.15s;
    cursor: pointer;
  }
  .s4-5 .swiper-slide:not(.swiper-slide-active):not(:hover) {
    opacity: 0.2;
  }
  .s4-6 {
    height: 100rem;
  }
  .s4-6-1 {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
  }
  .s4-7 {
    grid-column: 2/-1;
    margin: 0 calc(var(--gap) / -2);
  }
  .s4-8 {
    transition: all 0.25s;
    overflow: hidden;
  }

  .s5-1 {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-gap: 40rem;
    align-items: flex-end;
  }
  .s5-2 .section-header-title {
    max-width: none;
  }
  .s5-4 {
    grid-column: 1/-1;
    border-radius: var(--br2);
    position: relative;
    display: flex;
    overflow: hidden;
    min-height: 600rem;
  }

  .s6 .section-header {
    align-items: center;
    text-align: center;
  }
  .s6-1 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: var(--gap);
  }

  .s7::before,
  .s7::after {
    content: "";
    display: block;
    background-color: var(--c0);
    overflow: hidden;
    height: 100rem;
  }
  .s7::before {
    border-radius: 0 0 100rem 100rem;
  }
  .s7::after {
    border-radius: 100rem 100rem 0 0;
  }

  .s7-1 {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 100%;
    z-index: -1;
    margin: 0 var(--wr);
    overflow: hidden;
    padding: 0 var(--wr);
  }
  .s7-1 .imgcols-inner {
    transform: none;
    left: 0;
    top: 0;
    grid-template-columns: repeat(6, 1fr);
    width: 100%;
    height: 100%;
  }
  .s7-1 .imgcols-col {
    width: auto;
  }
  .s7-1 .imgcols-col:nth-child(2),
  .s7-1 .imgcols-col:nth-child(3) {
    margin-top: -100rem;
  }
  .s7-1 .imgcols-col:nth-child(n + 5) {
    display: none;
  }
  .s7-1 .imgcols-item {
    border-radius: var(--br2);
  }
  .s7-2 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: var(--gap);
    padding: var(--gap) 0;
  }
  .s7-3 {
    grid-column: 2/3;
    background-color: var(--c1);
    color: var(--c0);
    min-height: 660rem;
    border-radius: var(--br2);
    padding: 20rem 80rem;
    display: grid;
    grid-template-columns: auto;
    grid-template-rows: 1fr auto 1fr;
    grid-gap: 30rem;
  }
  .s7-3-1 {
    margin: 0 auto;
  }
  .s7-3-2 {
    margin: 0 auto;
    text-align: center;
  }
  .s7-3-3 {
    margin: 0 auto;
  }
}

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

    --gap: 20rem;

    --btn: 36rem;

    --br2: 16rem;

    --f-s: 14rem;
    --f-d: 16rem;
    --f-m: 16rem;
    --f-b: 18rem;
    --f-l: 24rem;
    --f-xl: 32rem;
    --f-xxl: 48rem;

    --mw: 192000px;
  }

  html {
    font-size: 1px;
  }

  .desktop {
    display: none !important;
  }

  .button__default {
    padding: 0 20rem;
  }

  .title br {
    display: none;
  }

  .topbar-container {
    margin: 0 var(--awr);
    width: auto;
  }
  .topbar {
    padding: 12rem var(--wr);
    margin: 0;
    border-radius: 0;
  }
  .topbar-main {
    grid-template-columns: auto;
    grid-gap: 2rem;
  }
  .topbar-logo {
    max-width: 120rem;
  }

  .footer {
    padding: 75rem 0 25rem;
  }
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    align-items: baseline;
    grid-gap: 10rem var(--gap);
  }
  .f1 {
    grid-column: 1/-1;
  }
  .f2 {
    grid-column: 1/-1;
    margin-top: 60rem;
  }
  .f3 {
    grid-column: 1/-1;
    margin: 60rem 0 10rem;
  }
  .f4 {
    grid-column: auto;
    order: 1;
    text-transform: none;
    text-align: right;
    opacity: 0.6;
  }
  .f5 {
    grid-column: auto;
    text-transform: none;
    text-align: left;
  }
  .f6 {
    grid-column: auto;
    text-transform: none;
    text-align: left;
  }
  .f7 {
    display: flex;
    font-size: var(--f-s);
    text-align: right;
    justify-content: flex-end;
  }

  .footer-form-title {
    margin-bottom: 15rem;
  }
  .footer-form-footer {
    margin-top: 15rem;
  }

  .footer-nav-caption {
    margin-bottom: 25rem;
  }

  .imgcols-inner {
    grid-gap: 10rem;
  }
  .imgcols-col {
    grid-gap: 10rem;
  }

  .textfield {
    border-radius: var(--br2);
  }
  .textfield-input {
    padding: 20rem;
  }

  .section {
    margin-bottom: 100rem;
  }

  .section-header {
    align-items: center;
    text-align: center;
  }
  .section-header-pretitle {
    margin-bottom: 15rem;
  }

  .card-1::before {
    display: none;
  }
  .card-1 .card-inner {
    padding: 25rem;
    grid-gap: 0 20rem;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto;
    align-items: flex-start;
  }
  .card-1 .card-footer {
    order: -1;
  }
  .card-1 .card-content {
    margin-top: 30rem;
  }
  .card-1 .card-action {
    margin-top: 25rem;
    grid-column: 1/-1;
  }

  .card-2 .card-inner {
    min-height: 350rem;
    padding: 25rem;
  }
  .card-2 .card-content {
    align-items: flex-end;
    margin: 25rem 0;
  }
  .card-2 .card-text {
    width: 100%;
  }
  .card-2 .card-subtitle {
    margin: -2rem;
  }
  .card-2 .card-subtitle .tag {
    margin: 2rem;
  }

  .card-3 .card-media {
    display: none;
  }
  .card-3 .card-inner {
    min-height: 250rem;
    grid-template-rows: 1fr auto;
    grid-template-columns: 1fr auto;
    padding: 25rem;
  }
  .card-3 .card-inner::before {
    font-size: var(--f-s);
  }
  .card-3 .card-title {
    order: -1;
  }
  .card-3 .card-text {
    grid-column: 1/-1;
  }

  .s1-1 {
    margin: 0;
  }
  .s1-2 {
    font-size: 80rem;
  }
  .s1-2:not(.active) {
    mix-blend-mode: normal;
    opacity: 0.3;
  }
  .s1-5 {
    height: 100%;
    text-align: left;
    align-items: flex-start;
    padding-bottom: 32rem;
  }
  .s1-5-3 {
    margin-top: 12rem;
    max-width: 200rem;
  }
  .s1-6 .swiper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  .s2-2 {
    grid-column: auto;
  }
  .s2-3 {
    grid-template-columns: auto;
  }

  .s3-1 {
    grid-template-columns: auto;
    grid-gap: 0;
  }
  .s3-2 {
    grid-column: auto;
    grid-template-columns: auto;
    grid-gap: 10rem;
  }
  .s3-3 {
    padding: 0;
  }

  .s4-1 {
    grid-template-columns: minmax(0, 1fr);
    grid-gap: 0;
  }
  .s4-2 {
    margin-bottom: 40rem;
  }
  .s4-3 {
    order: 1;
    line-height: 0;
    display: flex;
    align-items: flex-end;
    height: 0;
    position: relative;
    z-index: 2;
  }
  .s4-3 .carousel-buttons {
    grid-template-columns: 1fr auto;
    width: 100%;
    pointer-events: none;
  }
  .s4-3 .carousel-button {
    pointer-events: all;
  }
  .s4-4 {
    grid-template-columns: minmax(0, 1fr);
  }
  .s4-5 {
    margin-top: 15rem;
  }
  .s4-6 {
    height: 48rem;
    padding: 0 60rem;
  }
  .s4-6-1 {
    margin: 0;
  }
  .s4-7 {
    grid-column: auto;
  }

  .s5-1 {
    grid-template-columns: auto;
  }
  .s5-3 {
    order: 1;
    display: flex;
    justify-content: center;
  }
  .s5-4 {
    min-height: 300rem;
  }

  .s6-1 {
    grid-template-columns: auto;
    grid-gap: 10rem;
  }

  .s7::before,
  .s7::after {
    height: 25rem;
  }
  .s7::before {
    border-radius: 0 0 25rem 25rem;
  }
  .s7::after {
    border-radius: 25rem 25rem 0 0;
  }
  .s7-1 {
    margin: 0;
  }
  .s7-1 .imgcols-inner {
    grid-template-columns: 1fr 1fr;
    grid-gap: 10rem;
  }
  .s7-1 .imgcols-col:nth-child(n + 3) {
    display: none;
  }
  .s7-1 .imgcols-item {
    border-radius: 10rem;
  }
  .s7-2 {
    grid-template-columns: auto;
    grid-gap: 0;
    padding: 150rem 0;
  }
  .s7-3 {
    grid-column: auto;
    min-height: 350rem;
    padding: 30rem;
    grid-template-rows: 1fr auto auto;
    grid-gap: 25rem;
  }
}

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

  .s4-4 .swiper-slide-prev {
    transform: translateX(calc(-100% - var(--gap) / 2));
    opacity: 0;
  }
  .s4-4 .swiper-slide-active .s4-8 {
    width: calc(200% + var(--gap));
    margin-left: calc(-100% - var(--gap));
  }

  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 {
    pointer-events: none;
  }
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-text,
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-media,
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-subtitle {
    opacity: 0;
    transition-delay: 0s;
    transition-duration: 0.25s;
  }
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-subtitle {
    width: 0;
    transform: translateY(-20rem);
  }
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-content {
    transition-delay: 0s;
    transition-duration: 0.25s;
    transform: translateX(40rem);
  }
  .s4-4 .swiper-slide:not(.swiper-slide-active) .card-2 .card-title {
    transition-delay: 0s;
    transition-duration: 0.25s;
    flex: 0;
  }

  .s7-1 .imgcols-col:nth-child(3) {
    grid-column-start: 5;
  }
  .s7-1 .imgcols-col:nth-child(4) {
    grid-column-start: 6;
  }
}

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

/* buttons hide */

@media screen {
  .f5,
  .f6,
  .section-footer,
  .s2-2-3 .button,
  .s4-8 .button,
  .s5-3 .button,
  .s6-2 .button,
  .s7-3-3 .button {
    display: none;
  }

  .f4 {
    text-align: left;
  }
  .f7 {
    order: 1;
  }
}

/* hover animations */

@media (hover: hover) and (pointer: fine) and (min-width: 1024px) {
  .button {
    transition: all 0.15s;
  }
  .button__default:hover {
    background-color: var(--c1);
    color: var(--c2);
    border-color: var(--c1);
  }

  .contrast .button__default:hover {
    border-color: var(--c2);
  }

  .carousel-button {
    transition: all 0.15s;
  }
  .carousel-button:hover {
    background-color: var(--c1);
    color: var(--c0);
  }

  .card-1 .card-inner {
    transition: background-color 0.15s;
  }
  .card-1 .card-inner:hover {
    background-color: var(--c2);
  }

  .card-1 .card-action,
  .card-2 .card-action {
    transition: opacity 0.15s;
  }
  .card-1:not(:hover) .card-action,
  .card-2:not(:hover) .card-action {
    opacity: 0;
  }

  .card-3:not(:hover) .card-media {
    opacity: 0;
  }

  .card-3:hover .card-title {
    mix-blend-mode: difference;
  }

  .s3-3 .card-3 {
    transition:
      background-color 0.5s,
      color 0.5s,
      transform 0.5s;
  }
  .s3-3 .card-3:hover {
    background-color: var(--c0);
    color: var(--c1);
    transform: scale(1.1);
  }

  .f5 a,
  .f6 a,
  .footer-nav-list a {
    background-size: 0 var(--sl);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-image: linear-gradient(currentColor, currentColor);
    display: inline;
    transition:
      background-size 0.5s cubic-bezier(0.2, 1, 0.3, 1),
      opacity 0.25s;
  }

  .f5 a:hover,
  .f6 a:hover,
  .footer-nav-list a:hover {
    background-size: 100% var(--sl);
    background-position: left bottom;
    opacity: 1;
  }

  .s1-5 {
    transition: opacity 0.25s;
    opacity: 0;
  }
  .s1-5-1 {
    will-change: transform;
    transition: transform 0.5s;
  }

  .s1-5:hover {
    opacity: 1;
  }
  .s1-5:hover .s1-5-1 {
    transform: scale(1.05);
  }
}
