.background-foreground {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    position: relative;
    width: 100%
}

.background-foreground .background-wrapper {
    height: 100%;
    transition: scale 1s ease-out;
    width: 100%;
    will-change: transform
}

.background-foreground .background-wrapper div {
    height: 100%;
    width: 100%
}

.background-foreground .background-wrapper img {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%
}

.background-foreground .background-wrapper iframe {
    --video-height: 100%
}

.background-foreground .foreground-wrapper {
    align-items: center;
    display: flex;
    height: 100%;
    justify-content: center;
    max-height: 100vh;
    max-width: 100vw;
    position: absolute;
    transition: scale .5s ease-out;
    width: 100%;
    will-change: transform;
    z-index: 1
}

.background-foreground .foreground-wrapper>div {
    align-items: center;
    display: flex;
    height: 66%;
    justify-content: center;
    max-width: calc(var(--cols)*8 - var(--gutter));
    width: 75%
}

.background-foreground .foreground-wrapper img {
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    width: 100%
}

.background-foreground .foreground-wrapper iframe {
    --video-width: 100%
}

.background-foreground .video {
    height: 100%;
    width: 100%
}

.module-text {
    position: relative
}

@media (min-width:900px) {
    .module-text .prefix {
        position: absolute;
        right: calc(100% + var(--grid-gap));
        white-space: nowrap
    }
}

.module-custom-message {
    position: relative
}

:where(.module-media) {
    width: 100%
}

.module-media {
    align-self: baseline;
    display: flex;
    gap: var(--grid-gap)
}

.module-media.align-h-right {
    align-self: end
}

.module-media.align-h-center {
    align-self: center
}

.module-media {
    margin-bottom: var(--mbm-media);
    margin-top: var(--mtm-media);
    padding-bottom: var(--pbm-media);
    padding-top: var(--ptm-media)
}

@media (min-width:900px) {
    .module-media {
        margin-bottom: var(--mbd-media);
        margin-top: var(--mtd-media);
        padding-bottom: var(--pbd-media);
        padding-top: var(--ptd-media)
    }
}

.case-teaser-container {
    container-type: inline-size
}

.case-teaser-element {
    --text-color: var(--color-white)
}

.case-teaser-element.dark-text {
    --text-color: var(--color-black)
}

.case-teaser-element {
    color: hsl(var(--text-color));
    padding: .6rem
}

.case-teaser-element,
.case-teaser-element .content {
    display: flex;
    height: 100%;
    position: relative;
    width: 100%
}

.case-teaser-element .content {
    align-content: space-between;
    aspect-ratio: 1/1.25;
    flex-wrap: wrap;
    gap: .6rem;
    justify-content: space-between;
    max-height: 56vmax;
    max-width: calc(var(--cols)*12 - var(--gutter));
    pointer-events: none;
    -webkit-transform: translateZ(1px);
    z-index: 2
}

/* .case-teaser-element::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 10%;
    z-index: 1;
    background-color: rgba(0, 0, 0, .3);
} */

@container (min-width: 95vw) {
    .case-teaser-element .content {
        margin-left: calc(var(--grid-margin) - .6rem)
    }

    @media (max-width:899px) {
        .case-teaser-element .content {
            aspect-ratio: 5/9;
            max-height: none
        }
    }
}

@container (max-width: 20vw) {
    .case-teaser-element .content .tags {
        height: 1.6rem
    }

    .case-teaser-element .content .tags .tag {
        align-items: center;
        display: flex
    }
}

.case-teaser-element .content .title {
    margin-bottom: .1rem
}

.case-teaser-element .content .tags {
    overflow: hidden
}

@media (max-width:899px) {
    .case-teaser-element .content .tags {
        display: none
    }
}

.case-teaser-element .content .is-hidden {
    overflow: hidden !important
}

.case-teaser-element .background {
    border-radius: var(--br)
}

@container (min-width: 90vw) {

    .case-teaser-element .background,
    .case-teaser-element .background video {
        border-radius: 0
    }
}

.case-teaser-element .background {
    display: flex;
    height: 100%;
    left: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
    width: 100%
}

.module-entry.align-h-right {
    align-self: end
}

.module-entry.align-h-center {
    align-self: center
}

.module-entry.align-v-center {
    margin-bottom: auto;
    margin-top: auto
}

.module-entry.align-v-bottom {
    margin-top: auto
}

:where(.module-entry) {
    width: 100%
}

.module-column.only .module-entry {
    margin-left: auto
}

.module-awards {
    width: 100%;
    --fill: hsl(var(--text-color))
}

.module-awards .title {
    opacity: .75
}

.module-awards .item {
    align-items: center;
    border-bottom: 1px solid hsla(var(--text-color)/.2);
    display: flex;
    gap: 1rem;
    justify-content: space-between;
    padding: .75rem 0
}

.module-awards .media {
    height: 1.2rem;
    max-width: 1.5rem
}

.module-awards path {
    fill: currentColor
}

.fat-ass-headline .ts-h2 {
    font-family: var(--sans-serif);
    text-transform: none
}

.module-icons {
    display: flex;
    flex-direction: column;
    gap: 2rem var(--grid-gap);
    width: 100%
}

.module-icons__list {
    display: grid;
    gap: var(--grid-gap);
    grid-template-columns: repeat(6, 1fr)
}

.module-icons__item {
    align-items: center;
    display: flex;
    justify-content: center
}

.module-icons__icon {
    max-width: 2.5rem
}

@media (max-width:899px) {
    .ts-body-m {
        font-size: 12px;
        line-height: 115%
    }

    .ts-body-xs {
        font-size: 10px;
        line-height: 110%
    }
}

.module-profile {
    aspect-ratio: 275/350;
    border-radius: .25rem;
    color: var(--white);
    display: flex;
    max-height: 40rem;
    overflow: hidden;
    padding: .5rem;
    position: relative;
    width: 100%
}

.module-profile__content {
    align-items: flex-start;
    color: var(--color-white);
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    gap: .3rem;
    justify-content: flex-end;
    z-index: 2
}

.module-profile__background {
    border-radius: .2rem;
    display: flex;
    height: 100%;
    left: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
    width: 100%
}

.module-profile__background__overlay {
    background: linear-gradient(1turn, rgba(0, 0, 0, 0.37) 10%, transparent 100%);
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    z-index: 1;
    width: 100%
}

.module-profile__background img {
    filter: grayscale(1);
}

.module-profile:hover .module-profile__video {
    opacity: 1;
}

.module-profile__video {
    position: absolute;
    inset: 0;    
    z-index: 1;
    filter: grayscale(1);
    opacity: 0;
    transition: opacity .2s ease-in;
}

.module-profile__video video {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.module-nested-column {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    position: relative
}

@media (max-width:899px) {
    .module-nested-column.no-children {
        display: none
    }
}

:where(.module-nested-column) {
    width: 100%
}

.module-nested-row {
    display: flex;
    flex-direction: row;
    gap: var(--grid-gap);
    height: 100%;
    width: 100%;
    --pl: var(--grid-margin);
    --pr: var(--grid-margin);
    padding-left: var(--pl);
    padding-right: var(--pr)
}

@media (min-width:900px) {
    .module-nested-row {
        --pr: var(--sidebar-width);
        --gap: var(--grid-gap)
    }
}

.module-nested-row.bleed-none {
    --pl: 0;
    --pr: 0
}

.module-nested-row.bleed-left {
    --pr: 0
}

.module-nested-row {
    margin-bottom: var(--mbm-row);
    margin-top: var(--mtm-row)
}

@media (min-width:900px) {
    .module-nested-row {
        margin-bottom: var(--mbd-row);
        margin-top: var(--mtd-row)
    }
}

.newsletter {
    gap: 2rem
}

.newsletter,
.newsletter .email,
.newsletter .fullname {
    display: flex;
    flex-direction: column;
    position: relative;
    width: 100%
}

.newsletter .email,
.newsletter .fullname {
    gap: .65rem
}

.newsletter .fullname input {
    opacity: .5
}

.newsletter .plusone {
    display: flex;
    gap: .35rem
}

.newsletter .message {
    margin-top: 1rem
}

.newsletter .border {
    border: 1px solid hsla(var(--text-color)/.3);
    border-radius: var(--br);
    bottom: 0;
    height: 1.2rem;
    left: 0;
    -webkit-mask-image: linear-gradient(transparent 50%, #000 0);
    mask-image: linear-gradient(transparent 50%, #000 0);
    position: absolute;
    width: 100%
}

.newsletter .link {
    --line-size: 0%;
    align-items: center;
    display: flex;
    gap: .7rem;
    position: relative
}

.newsletter .link svg {
    transition: transform .2s
}

.newsletter .link {
    width: -moz-fit-content;
    width: fit-content
}

.newsletter .link a {
    text-decoration: none
}

@media (max-width:899px) {
    .newsletter .link .link-title {
        --line-size: 100%
    }
}

.newsletter .link .link-title {
    background: linear-gradient(hsla(var(--text-color)), hsla(var(--text-color))) 0 100% no-repeat;
    background-size: var(--line-size) .75px;
    display: inline;
    transition: background-size .5s
}

.newsletter .link:hover {
    --line-size: 100%
}

.newsletter .link:hover svg {
    transform: scale(1.2)
}

.newsletter .link a:before {
    content: "";
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    position: absolute
}

.newsletter .content {
    display: flex;
    flex-direction: column
}

input[type=email],
input[type=text] {
    background-color: transparent;
    border: none;
    color: hsla(var(--text-color));
    cursor: text;
    padding: 0 .35rem;
    text-decoration: none;
    z-index: 1
}

input[type=email]:focus,
input[type=text]:focus {
    outline: none
}

.custom-checkbox {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: transparent;
    border: 1px solid hsla(var(--text-color)/.3);
    cursor: pointer;
    height: 14px;
    position: relative;
    width: 14px
}

.custom-checkbox:checked {
    background-color: hsla(var(--text-color)/.2)
}

.custom-checkbox:checked:before {
    color: hsla(var(--text-color));
    content: "X";
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%)
}

.module-column {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 1.5rem var(--grid-gap);
    justify-content: flex-start
}

@media (max-width:899px) {
    .module-column.no-children {
        display: none
    }
}

:where(.module-column) {
    width: 100%
}

.coming-soon .top {
    padding-bottom: 3rem
}

@media (min-width:900px) {
    .coming-soon .top {
        align-items: flex-end;
        display: flex;
        gap: 1.5rem;
        padding-bottom: 5rem
    }
}

.coming-soon .title {
    display: inline
}

@media (min-width:900px) {
    .coming-soon .title {
        display: block
    }
}

.coming-soon .number {
    display: inline;
    margin-bottom: .5em;
    margin-left: 1em;
    white-space: nowrap
}

@media (min-width:900px) {
    .coming-soon .number {
        display: block;
        margin-bottom: .8em;
        margin-left: 0
    }
}

.coming-soon ul {
    display: grid;
    gap: 1.5rem
}

@media (min-width:900px) {
    .coming-soon ul {
        gap: 1rem
    }
}

.coming-soon li {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    position: relative
}

@media (min-width:900px) {
    .coming-soon li {
        align-items: flex-end;
        flex-direction: row;
        gap: 1rem
    }
}

.coming-soon .trumpet {
    margin-bottom: .5em
}

.module-background-foreground {
    width: 100%
}

.module-background-foreground .background-foreground {
    height: 100vw
}

@media (min-width:900px) {
    .module-background-foreground .background-foreground {
        height: 90vh
    }
}

.module-background-foreground .background-foreground .foreground {
    max-height: 800px
}

.ts-label-m {
    opacity: .75
}

.carousel-controls {
    display: flex;
    flex-direction: column;
    position: relative
}

.carousel-controls__top {
    display: flex;
    justify-content: space-between;
    margin-bottom: 1.5rem
}

.carousel-controls__controls {
    align-self: end;
    display: flex;
    flex-direction: row;
    gap: 1rem;
    position: relative
}

.carousel-controls__controls-left {
    transform: rotate(-135deg)
}

.carousel-controls__controls-right {
    transform: rotate(45deg)
}

@font-face {
    font-family: swiper-icons;
    font-style: normal;
    font-weight: 400;
    src: url(data:application/font-woff;charset=utf-8;base64,\ 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)
}

:root {
    --swiper-theme-color: #007aff
}

:host {
    display: block;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    z-index: 1
}

.swiper {
    display: block;
    list-style: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    padding: 0;
    position: relative;
    z-index: 1
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    box-sizing: content-box;
    display: flex;
    height: 100%;
    position: relative;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    width: 100%;
    z-index: 1
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
    transform: translateZ(0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    display: block;
    flex-shrink: 0;
    height: 100%;
    position: relative;
    transition-property: transform;
    width: 100%
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    backface-visibility: hidden;
    transform: translateZ(0)
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow,
.swiper-3d .swiper-slide {
    transform-style: preserve-3d
}

.swiper-css-mode>.swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: start start
}

.swiper-css-mode.swiper-horizontal>.swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-css-mode.swiper-vertical>.swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper {
    scroll-snap-type: none
}

.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: none
}

.swiper-css-mode.swiper-centered>.swiper-wrapper:before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop: always
}

.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before {
    height: 100%;
    min-height: 1px;
    width: var(--swiper-centered-offset-after)
}

.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before {
    height: var(--swiper-centered-offset-after);
    min-width: 1px;
    width: 100%
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top {
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: #00000026
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(270deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(90deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(0deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(180deg, rgba(0, 0, 0, .5), transparent)
}

.swiper-lazy-preloader {
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top: 4px solid transparent;
    box-sizing: border-box;
    height: 42px;
    left: 50%;
    margin-left: -21px;
    margin-top: -21px;
    position: absolute;
    top: 50%;
    transform-origin: 50%;
    width: 42px;
    z-index: 10
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s linear infinite
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0)
    }

    to {
        transform: rotate(1turn)
    }
}

.module-carousel {
    display: flex;
    flex-direction: column-reverse;
    padding-left: var(--grid-margin);
    position: relative;
    width: 100vw
}

.module-carousel .swiper-wrapper {
    width: 100%
}

.module-carousel .swiper-slide {
    width: calc(var(--cols)*5 - var(--gutter))
}

@media (min-width:900px) {
    .module-carousel .swiper-slide {
        opacity: .3;
        transition: opacity .5s ease-in-out;
        width: calc(var(--cols)*6 - var(--gutter))
    }
}

.module-carousel .swiper-slide {
    height: auto;
    margin-right: var(--grid-gap)
}

.module-carousel .swiper-slide-prev {
    opacity: 0;
    transition: opacity .5s ease-in-out;
    transition-delay: 1s
}

.module-carousel .swiper-slide-active,
.module-carousel .swiper-slide-next {
    opacity: 1;
    transition: opacity .5s ease-in-out
}

.module-carousel__controls {
    padding-right: var(--grid-margin)
}

@media (min-width:900px) {
    .module-carousel__controls {
        padding-right: var(--sidebar-width)
    }
}

.module-carousel__controls-hidden {
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    width: calc(var(--grid-margin)*3)
}

@media (min-width:900px) {
    .module-carousel__controls-hidden {
        width: var(--sidebar-width)
    }
}

.module-carousel__controls-hidden {
    z-index: 2
}

.module-hero-image {
    height: 100vh;
    position: relative;
    width: 100vw
}

@media (min-width:900px) {
    .module-hero-image {
        aspect-ratio: 16/9;
        height: 100%
    }
}

.module-hero-image .title {
    -webkit-hyphens: auto;
    hyphens: auto;
    word-break: break-word
}

.module-hero-image .media {
    height: inherit;
    width: 100%
}

.module-hero-image .content {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: flex-end;
    max-height: 100vh;
    padding: var(--grid-margin);
    position: absolute;
    z-index: 1
}

@media (max-width:899px) {
    .module-hero-image .content {
        padding-bottom: 7.5rem
    }
}

@media (min-width:900px) {
    .module-hero-image .content {
        padding-right: var(--sidebar-width)
    }
}

:where(.module-spline) {
    width: 100%
}

.module-spline {
    align-self: baseline;
    display: flex;
    gap: var(--grid-gap)
}

.module-spline.align-h-right {
    align-self: end
}

.module-spline.align-h-center {
    align-self: center
}

.module-spline {
    margin-bottom: var(--mbm-media);
    margin-top: var(--mtm-media);
    padding-bottom: var(--pbm-media);
    padding-top: var(--ptm-media)
}

@media (min-width:900px) {
    .module-spline {
        margin-bottom: var(--mbd-media);
        margin-top: var(--mtd-media);
        padding-bottom: var(--pbd-media);
        padding-top: var(--ptd-media)
    }
}

.module-overlayed-item {
    display: flex;
    flex-direction: column;
    left: 0;
    margin-left: var(--ml);
    margin-right: var(--mr);
    pointer-events: none;
    position: absolute;
    top: 0;
    z-index: 2
}

.module-overlayed-item .media:not(.is-seen) {
    opacity: 1
}

.module-overlayed-item.align-v-center {
    align-self: center;
    top: auto
}

.module-overlayed-item.align-v-bottom {
    bottom: 0;
    top: auto
}

.module-overlayed-item.placement-right {
    left: auto;
    right: 0
}

.module-overlayed-item[class*=placement-] {
    --ml: var(--grid-margin)
}

@media (min-width:900px) {
    .module-overlayed-item[class*=placement-] {
        left: calc(var(--cols)*(min(var(--grid-cols), var(--at-position))))
    }
}

.module-overlayed-item.placement-1 {
    --at-position: 0
}

.module-overlayed-item.placement-2 {
    --at-position: 1
}

.module-overlayed-item.placement-3 {
    --at-position: 2
}

.module-overlayed-item.placement-4 {
    --at-position: 3
}

.module-overlayed-item.placement-5 {
    --at-position: 4
}

.module-overlayed-item.placement-6 {
    --at-position: 5
}

.module-overlayed-item.placement-7 {
    --at-position: 6
}

.module-overlayed-item.placement-8 {
    --at-position: 7
}

.module-overlayed-item.placement-9 {
    --at-position: 8
}

.module-overlayed-item.placement-10 {
    --at-position: 9
}

.module-overlayed-item.placement-11 {
    --at-position: 10
}

.module-overlayed-item.placement-12 {
    --at-position: 11
}

.module-overlayed-item[class*=placement-mobile-] {
    --ml: var(--grid-margin)
}

@media (max-width:899px) {
    .module-overlayed-item[class*=placement-mobile-] {
        left: calc(var(--cols)*(min(var(--grid-cols), var(--at-position-mobile))))
    }
}

.module-overlayed-item.placement-mobile-1 {
    --at-position-mobile: 0
}

.module-overlayed-item.placement-mobile-2 {
    --at-position-mobile: 1
}

.module-overlayed-item.placement-mobile-3 {
    --at-position-mobile: 2
}

.module-overlayed-item.placement-mobile-4 {
    --at-position-mobile: 3
}

.module-overlayed-item.placement-mobile-5 {
    --at-position-mobile: 4
}

.module-overlayed-item.placement-mobile-6 {
    --at-position-mobile: 5
}

.module-overlayed-item.is-background {
    z-index: -1
}

.module-overlayed-item.is-spline {
    pointer-events: all
}

.module-link-list {
    display: grid;
    gap: 1.5rem
}

@media (min-width:900px) {
    .module-link-list {
        gap: 1.5rem
    }
}

.module-link-list .section-title {
    opacity: .75
}

.module-link-list .list {
    display: grid;
    gap: 10px;
    list-style: none;
    margin: 0;
    padding: 0
}

@media (min-width:900px) {
    .module-link-list .list {
        gap: .75rem
    }
}

.module-link-list .link {
    align-items: baseline;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    text-decoration: none;
    transition: transform .2s
}

@media (min-width:900px) {
    .module-link-list .link {
        flex-direction: row;
        gap: 1rem
    }
}

.module-link-list .link:hover {
    transform: translate(.5rem)
}


.swiper-pagination {
    position: absolute;
    text-align: center;
    transform: translateZ(0);
    transition: opacity .3s;
    z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled>.swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
    display: none !important
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: var(--swiper-pagination-bottom, 8px);
    left: 0;
    top: var(--swiper-pagination-top, auto);
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    font-size: 0;
    overflow: hidden
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    position: relative;
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(.33)
}

.swiper-pagination-bullet {
    background: var(--swiper-pagination-bullet-inactive-color, #000);
    border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
    display: inline-block;
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    opacity: var(--swiper-pagination-bullet-inactive-opacity, .2);
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px))
}

button.swiper-pagination-bullet {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    box-shadow: none;
    margin: 0;
    padding: 0
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none !important
}

.swiper-pagination-bullet-active {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    opacity: var(--swiper-pagination-bullet-opacity, 1)
}

.swiper-pagination-vertical.swiper-pagination-bullets,
.swiper-vertical>.swiper-pagination-bullets {
    left: var(--swiper-pagination-left, auto);
    right: var(--swiper-pagination-right, 8px);
    top: 50%;
    transform: translate3d(0, -50%, 0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
    display: block;
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: transform .2s, top .2s
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translate(-50%);
    white-space: nowrap
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: transform .2s, left .2s
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: transform .2s, right .2s
}

.swiper-pagination-fraction {
    color: var(--swiper-pagination-fraction-color, inherit)
}

.swiper-pagination-progressbar {
    background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, .25));
    position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    transform: scale(0);
    transform-origin: left top;
    width: 100%
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    height: var(--swiper-pagination-progressbar-size, 4px);
    left: 0;
    top: 0;
    width: 100%
}

.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-vertical>.swiper-pagination-progressbar {
    height: 100%;
    left: 0;
    top: 0;
    width: var(--swiper-pagination-progressbar-size, 4px)
}

.swiper-pagination-lock {
    display: none
}

.image-slider {
    height: 100%;
    position: relative;
    width: 100%
}

.image-slider span.swiper-pagination-bullet.swiper-pagination-bullet-active {
    background-color: hsl(var(--theme-text-color));
    opacity: 1
}

.image-slider .swiper-pagination-bullet {
    background-color: hsl(var(--theme-background-color));
    opacity: 1
}

.product-card {
    border: 1px solid hsl(var(--color-black)/.2);
    border-radius: var(--br);
    overflow: hidden;
    position: relative
}

.product-card .media {
    aspect-ratio: 570/400;
    background-color: var(--white);
    max-height: 66vh
}

.product-card .content {
    color: hsl(var(--background-color));
    display: flex;
    flex-direction: column;
    top: .5rem;
    right: .5rem;
    bottom: .5rem;
    left: .5rem;
    pointer-events: none;
    position: absolute;
    z-index: 3
}

.product-card .content .buy-button {
    background: hsl(var(--text-color));
    border-radius: var(--br);
    margin-left: auto;
    margin-top: auto;
    padding: .25rem .55rem;
    pointer-events: all
}

.product-card .added-to-cart {
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border: 1px solid hsla(var(--text-color)/.2);
    border-radius: var(--br);
    left: 50%;
    opacity: 0;
    padding: .7rem;
    position: fixed;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: opacity .3s ease-out, visibility .3s ease-out;
    visibility: hidden;
    z-index: 150
}

.product-card .added-to-cart.is-added {
    opacity: 1;
    visibility: visible
}

.products-slider {
    display: flex;
    flex-direction: column-reverse;
    padding-left: var(--grid-margin);
    position: relative;
    width: 100vw
}

.products-slider .swiper-wrapper {
    width: 100%
}

.products-slider .swiper-slide {
    width: calc(var(--cols)*5 - var(--gutter))
}

@media (min-width:900px) {
    .products-slider .swiper-slide {
        opacity: .3;
        transition: opacity .5s ease-in-out;
        width: calc(var(--cols)*6 - var(--gutter))
    }
}

.products-slider .swiper-slide {
    height: auto;
    margin-right: var(--grid-gap)
}

.products-slider .swiper-slide-prev {
    opacity: 0;
    transition: opacity .5s ease-in-out;
    transition-delay: 1s
}

.products-slider .swiper-slide-active,
.products-slider .swiper-slide-next {
    opacity: 1;
    transition: opacity .5s ease-in-out
}

.products-slider__controls {
    padding-right: var(--grid-margin)
}

@media (min-width:900px) {
    .products-slider__controls {
        padding-right: var(--sidebar-width)
    }
}

.products-slider__controls-hidden {
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    width: calc(var(--grid-margin)*3)
}

@media (min-width:900px) {
    .products-slider__controls-hidden {
        width: var(--sidebar-width)
    }
}

.products-slider__controls-hidden {
    z-index: 2
}

.shopify-products:not(:has(.products-slider)) {
    display: grid;
    gap: var(--grid-margin);
    overflow: hidden;
    position: relative
}

.shopify-products>.content {
    align-items: flex-start;
    display: grid;
    gap: var(--grid-gap);
    padding: var(--grid-margin)
}

@media (min-width:900px) {
    .shopify-products>.content {
        grid-template-columns: calc(var(--cols)*6 - var(--gutter)) calc(var(--cols)*6 - var(--gutter))
    }
}

.shopify-products>.content .media {
    max-width: 6.5rem
}

.shopify-products>.products-normal {
    display: grid;
    gap: var(--grid-gap)
}

@media (min-width:900px) {
    .shopify-products>.products-normal {
        grid-template-columns: calc(var(--cols)*6 - var(--gutter)) calc(var(--cols)*6 - var(--gutter))
    }
}

.shopify-products>.products-normal {
    padding: var(--grid-margin)
}

.shopify-products>.products-slider {
    padding: 0;
    position: relative
}

.shopify-products .background-media {
    filter: blur(150px);
    position: absolute;
    z-index: -1
}

.module-hero-content {
    display: flex;
    padding: calc(var(--header-height) + 2rem) var(--grid-margin) 3rem;
    position: relative
}

@media (min-width:900px) {
    .module-hero-content {
        padding-bottom: 6rem;
        padding-right: var(--sidebar-width)
    }
}

.module-hero-content.moving {
    padding-left: 0
}

.module-hero-content.moving .module-hero-content__wrapper {
    padding-left: var(--grid-margin);
    width: calc(100vw - var(--grid-margin))
}

@media (min-width:900px) {
    .module-hero-content.moving .module-hero-content__wrapper {
        padding-right: 0;
        width: 100vw
    }
}

.module-hero-content.moving .module-hero-content__wrapper {
    --start: calc(100% - var(--sidebar-width))
}

@media (min-width:900px) {
    .module-hero-content.moving .module-hero-content__wrapper {
        -webkit-mask-image: linear-gradient(90deg, #000 var(--start), rgba(0, 0, 0, .4) calc(var(--start) + var(--sidebar-width)*.2), transparent 90%);
        mask-image: linear-gradient(90deg, #000 var(--start), rgba(0, 0, 0, .4) calc(var(--start) + var(--sidebar-width)*.2), transparent 90%)
    }
}

.module-hero-content.moving .headline .animated-headline-simple {
    height: var(--ts-h1-lh)
}

.module-hero-content.moving .headline .title-bar {
    height: var(--ts-h1-lh);
    white-space: pre
}

.module-hero-content.moving .headline .title-bar+.title-bar {
    position: absolute
}

.module-hero-content.moving .content {
    padding-right: var(--grid-margin);
    width: calc(100vw - var(--grid-margin))
}

@media (min-width:900px) {
    .module-hero-content.moving .content {
        padding-right: 0;
        width: 100vw
    }
}

.module-hero-content__wrapper {
    margin-bottom: var(--mbm-hero-content);
    margin-top: var(--mtm-hero-content);
    padding-bottom: var(--pbm-hero-content);
    padding-top: var(--ptm-hero-content)
}

@media (min-width:900px) {
    .module-hero-content__wrapper {
        margin-bottom: var(--mbd-hero-content);
        margin-top: var(--mtd-hero-content);
        padding-bottom: var(--pbd-hero-content);
        padding-top: var(--ptd-hero-content)
    }
}

.module-hero-content__wrapper .headline {
    margin-bottom: 1.5rem
}

@media (min-width:900px) {
    .module-hero-content__wrapper .headline {
        margin-bottom: 3rem
    }
}

.module-hero-content__wrapper .content {
    display: grid;
    gap: 3rem
}

@media (min-width:900px) {
    .module-hero-content__wrapper .content {
        gap: var(--grid-gap);
        grid-template-columns: calc(var(--cols)*6 - var(--gutter)) calc(var(--cols)*6 - var(--gutter))
    }
}

.module-hero-content__wrapper .content-left {
    flex: 1
}

.module-hero-content__wrapper .content-left-img {
    height: 15rem;
    margin-top: 3.25rem
}

.module-hero-content__wrapper .content-right {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 3rem
}

@media (min-width:900px) {
    .module-hero-content__wrapper .content-right {
        flex-direction: row
    }
}

.module-hero-content__wrapper .text {
    display: grid;
    gap: 1.5rem
}

@media (min-width:900px) {
    .module-hero-content__wrapper .text {
        display: flex;
        flex-direction: column
    }
}

.module-hero-big-bang {
    display: flex;
    padding: 3rem var(--grid-margin);
    position: relative
}

@media (min-width:900px) {
    .module-hero-big-bang {
        padding: var(--grid-margin);
        padding-right: var(--sidebar-width);
        padding-top: 5rem
    }
}

.module-hero-big-bang__wrapper {
    width: calc(var(--cols)*var(--grid-cols) - var(--gutter))
}

@media (max-width:899px) {
    .module-hero-big-bang__wrapper {
        --media-mobile-margin-top: calc(max(0, var(--mt))/2);
        --media-mobile-margin-bottom: calc(max(0, var(--mb))/2)
    }
}

.module-hero-big-bang__wrapper {
    margin-bottom: var(--media-mobile-margin-bottom, var(--mb));
    margin-top: var(--media-mobile-margin-top, var(--mt))
}

.module-hero-big-bang .content {
    padding-bottom: 0;
    position: relative
}

@media (min-width:900px) {
    .module-hero-big-bang .content {
        padding-bottom: 5rem
    }
}

.module-hero-big-bang .title {
    padding: 4rem 0 2rem
}

@media (min-width:900px) {
    .module-hero-big-bang .title {
        padding: 0
    }
}

.module-hero-big-bang .entry {
    height: calc(var(--cols)*6*1.25 - var(--gutter)*1.25);
    opacity: 1;
    width: calc(var(--cols)*6 - var(--gutter));
    z-index: 3
}

@media (min-width:900px) {
    .module-hero-big-bang .entry {
        bottom: 8.5rem;
        max-height: 750px;
        max-width: 600px;
        opacity: .8;
        position: absolute;
        right: 0;
        transition: opacity .3s ease-in-out
    }
}

.module-hero-big-bang .entry:hover {
    opacity: 1
}