:root {
    --spacing-2xs-mobile: 6;
    --spacing-2xs-desktop: 10;
    --spacing-xs-mobile: 12;
    --spacing-xs-desktop: 16;
    --spacing-sm-mobile: 22;
    --spacing-sm-desktop: 32;
    --spacing-md-mobile: 32;
    --spacing-md-desktop: 56;
    --spacing-lg-mobile: 48;
    --spacing-lg-desktop: 96;
    --spacing-xl-mobile: 64;
    --spacing-xl-desktop: 128;
    --spacing-2xl-mobile: 96;
    --spacing-2xl-desktop: 176;
    --spacing-3xl-mobile: 150;
    --spacing-3xl-desktop: 240
}

:root {
    --grid-columns: 4;
    --grid-gutter: 1.5rem;
    --header-height: 4.75rem
}

@media(max-width: 699px) {
    :root {
        --grid-margin: 18px
    }
}

@media(min-width: 700px) {
    :root {
        --grid-margin: clamp(18px, 0.0857142857 * calc(100 * var(--vw, 1vw)), 120px);
        --grid-columns: 12;
        --grid-gutter: 1.5rem
    }
}



:root {
    --swiper-theme-color: #007aff
}

:host {
    position: relative;
    display: block;
    margin-left: auto;
    margin-right: auto;
    z-index: 1
}

.swiper {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1;
    display: block
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    box-sizing: content-box
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
    transform: translate3d(0px, 0, 0)
}

.swiper-horizontal {
    touch-action: pan-y
}

.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform;
    display: block
}

.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 {
    transform: translateZ(0);
    backface-visibility: hidden
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-slide,
.swiper-3d .swiper-cube-shadow {
    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 {
    width: 100%;
    min-width: 1px;
    height: var(--swiper-centered-offset-after)
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: rgba(0, 0, 0, .15)
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: rgba(0, 0, 0, 0)
}

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0deg)
    }

    100% {
        transform: rotate(360deg)
    }
}

html.lenis {
    height: auto
}

.lenis.lenis-smooth {
    scroll-behavior: auto
}

.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain
}

.lenis.lenis-stopped {
    overflow: hidden
}

.lenis.lenis-scrolling iframe {
    pointer-events: none
}

*,
*:after,
*:before {
    box-sizing: border-box
}

html {
    -moz-text-size-adjust: none;
    -webkit-text-size-adjust: none;
    text-size-adjust: none
}

p,
h1,
h2,
h3,
h4,
h5,
h6,
dl,
dd,
figure,
blockquote {
    margin-block: unset
}

ul[class],
ol[class] {
    margin: 0;
    padding: 0;
    list-style: none
}

html {
    line-height: 1.5
}

body {
    margin: unset
}

h1,
h2,
h3,
h4,
h5,
h6,
input,
label,
button {
    line-height: 1.1
}

a[class] {
    color: inherit;
    text-decoration: none
}

img,
svg,
canvas,
picture {
    display: block;
    max-inline-size: 100%;
    block-size: auto
}

input,
button,
select,
textarea {
    font: inherit
}

textarea:not([rows]) {
    min-height: 10em
}

:target {
    scroll-margin-block: 1rlh
}

button {
    display: inline-block;
    overflow: visible;
    margin: 0;
    padding: 0;
    outline: 0;
    border: 0;
    background: none rgba(0, 0, 0, 0);
    color: inherit;
    vertical-align: middle;
    text-align: center;
    text-decoration: none;
    text-transform: none;
    font: inherit;
    line-height: normal;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none
}



html {
    min-height: 100%;
    line-height: 1.5;
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    color: #241c18;
    scrollbar-gutter: stable;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

@media(max-width: 699px) {
    html {
        font-size: 14px
    }
}

@media(min-width: 700px)and (max-width: 1199px) {
    html {
        font-size: 15px
    }
}

@media(min-width: 1200px)and (max-width: 1599px) {
    html {
        font-size: 16px
    }
}

@media(min-width: 1600px)and (max-width: 1799px) {
    html {
        font-size: 17px
    }
}

@media(min-width: 1800px) {
    html {
        font-size: 18px
    }
}

html.is-loading {
    cursor: wait
}

html.has-modal-open,
html.has-menu-open {
    overflow: hidden
}

::-moz-selection {
    background-color: #241c18;
    color: #fff;
    text-shadow: none
}

::selection {
    background-color: #241c18;
    color: #fff;
    text-shadow: none
}

*:focus-visible:not(input):not(textarea):not(select) {
    outline: 2px auto currentColor;
    outline-offset: var(--focus-outline-offset, 5px)
}

html.is-safari *:focus-visible:not(input):not(textarea):not(select) {
    outline-style: dotted;
    outline-width: 4px
}

input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: var(--input-focus-outline-width) auto var(--color-theme-dark);
    outline-offset: 0px
}

html.is-safari input:focus-visible,
html.is-safari select:focus-visible,
html.is-safari textarea:focus-visible {
    outline-style: dotted;
    outline-width: 4px
}

button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
    outline: 2px auto currentColor;
    outline-offset: var(--focus-outline-offset, 5px)
}

html.is-safari button:-moz-focusring,
html.is-safari [type=button]:-moz-focusring,
html.is-safari [type=reset]:-moz-focusring,
html.is-safari [type=submit]:-moz-focusring {
    outline-style: dotted;
    outline-width: 4px
}

a {
    color: currentColor;
    text-decoration: none
}

#page-heading {
    scroll-margin-top: calc(var(--header-height) + 20px)
}

.o-container {
    margin-right: auto;
    margin-left: auto;
    padding-left: var(--grid-margin);
    padding-right: var(--grid-margin)
}

.o-ratio {
    position: relative;
    display: block;
    overflow: hidden
}

.o-ratio:before {
    display: block;
    padding-bottom: 100%;
    width: 100%;
    content: ""
}

.o-ratio_content,
.o-ratio>img,
.o-ratio>iframe,
.o-ratio>embed,
.o-ratio>object {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%
}

:root {
    --icon-width: 1rem;
    --icon-ratio: 1
}

.o-icon {
    display: inline-block;
    vertical-align: middle
}

.o-icon svg {
    --icon-height: calc(var(--icon-width) * (1 / (var(--icon-ratio))));
    display: block;
    width: var(--icon-width);
    height: var(--icon-height)
}

:root {
    --icon-width-logo: 16.75rem;
    --icon-ratio-logo: 268/47
}

.svg-logo {
    --icon-width: var(--icon-width-logo);
    --icon-ratio: var(--icon-ratio-logo)
}

:root {
    --icon-width-close: 0.75rem;
    --icon-ratio-close: 1
}

.svg-close {
    --icon-width: var(--icon-width-close);
    --icon-ratio: var(--icon-ratio-close)
}

:root {
    --icon-width-play: 0.9375rem
}

.svg-play,
.svg-pause {
    --icon-width: var(--icon-width-play)
}

:root {
    --icon-width-plus: 1.0625rem;
    --icon-width-minus: 1.0625rem
}

.svg-plus {
    --icon-width: var(--icon-width-plus);
    --icon-ratio: var(--icon-ratio-plus)
}

.svg-minus {
    --icon-width: var(--icon-width-minus);
    --icon-ratio: var(--icon-ratio-minus)
}

:root {
    --icon-width-dropdown: 0.6875rem
}

.svg-dropdown {
    --icon-width: var(--icon-width-dropdown)
}

:root {
    --icon-width-error: calc(calc(100 * var(--vw, 1vw)) - 2 * var(--grid-margin));
    --icon-ratio-error: 1429/752
}

.svg-error {
    --icon-width: var(--icon-width-error);
    --icon-ratio: var(--icon-ratio-error)
}

.o-grid {
    display: grid;
    width: 100%
}

.o-grid:is(ul, ol) {
    margin: 0;
    padding: 0;
    list-style: none
}

.o-grid.-cols {
    grid-template-columns: repeat(var(--grid-columns), 1fr)
}

.o-grid.-col-12 {
    grid-template-columns: repeat(12, 1fr)
}

.o-grid.-col-4 {
    grid-template-columns: repeat(4, 1fr)
}

.o-grid.-col-2 {
    grid-template-columns: repeat(2, 1fr)
}

@media(min-width: 1000px) {
    .o-grid.-col-12\@from-md {
        grid-template-columns: repeat(12, 1fr)
    }
}

.o-grid.-gutters {
    gap: var(--grid-gutter);
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter)
}

.o-grid.-full-height {
    height: 100%
}

.o-grid.-top-items {
    align-items: start
}

.o-grid.-right-items {
    justify-items: end
}

.o-grid.-bottom-items {
    align-items: end
}

.o-grid.-left-items {
    justify-items: start
}

.o-grid.-center-items {
    align-items: center;
    justify-items: center
}

.o-grid.-center-items-x {
    justify-items: center
}

.o-grid.-center-items-y {
    align-items: center
}

.o-grid.-stretch-items {
    align-items: stretch;
    justify-items: stretch
}

.o-grid.-top-cells {
    align-content: start
}

.o-grid.-right-cells {
    justify-content: end
}

.o-grid.-bottom-cells {
    align-content: end
}

.o-grid.-left-cells {
    justify-content: start
}

.o-grid.-center-cells {
    align-content: center;
    justify-content: center
}

.o-grid.-center-cells-x {
    justify-content: center
}

.o-grid.-center-cells-y {
    align-content: center
}

.o-grid.-stretch-cells {
    align-content: stretch;
    justify-content: stretch
}

.o-grid.-space-around-cells {
    align-content: space-around;
    justify-content: space-around
}

.o-grid.-space-around-cells-x {
    justify-content: space-around
}

.o-grid.-space-around-cells-y {
    align-content: space-around
}

.o-grid.-space-between-cells {
    justify-content: space-between;
    align-content: space-between
}

.o-grid.-space-between-cells-x {
    justify-content: space-between
}

.o-grid.-space-between-cells-y {
    align-content: space-between
}

.o-grid.-space-evenly-cells {
    justify-content: space-evenly;
    align-content: space-evenly
}

.o-grid.-space-evenly-cells-x {
    justify-content: space-evenly
}

.o-grid.-space-evenly-cells-y {
    align-content: space-evenly
}

.o-grid_item {
    grid-column-start: var(--gc-start, 1);
    grid-column-end: var(--gc-end, -1)
}

.o-grid_item.-align-end {
    align-self: end
}

.o-loadable {
    position: relative
}

.o-loadable_inner {
    position: absolute;
    top: 0;
    left: calc(-1*var(--grid-margin));
    width: calc(100% + 2*var(--grid-margin));
    height: 100%;
    opacity: 0;
    pointer-events: none;
    z-index: 100;
    transition: opacity .3s
}

.o-loadable.is-loading .o-loadable_inner,
.o-loadable.is-leaving .o-loadable_inner {
    pointer-events: auto;
    opacity: 1
}

.o-loadable_spinner {
    position: sticky;
    top: 0;
    width: 100%;
    height: calc(var(--vh, 1vh)*100);
    display: flex;
    align-items: center;
    justify-content: center
}

.o-loadable_spinner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #fff;
    opacity: .7
}

.o-loadable_spinner::after {
    content: "";
    display: block;
    width: 1rem;
    height: 1rem;
    margin-top: -0.5rem;
    margin-left: -0.5rem;
    border: 2px solid rgba(0, 0, 0, 0);
    border-top-color: currentColor;
    border-left-color: currentColor;
    border-radius: 50%;
    animation: loadableSectionSpinner linear .3s infinite
}

@keyframes loadableSectionSpinner {
    0% {
        transform: rotate(0deg)
    }

    100% {
        transform: rotate(360deg)
    }
}

:root {
    --font-size-h1: clamp(40px, 0.08 * calc(100 * var(--vw, 1vw)), 96px);
    --font-size-h2: clamp(40px, 0.0533333333 * calc(100 * var(--vw, 1vw)), 64px);
    --font-size-h3: clamp(22px, 0.0266666667 * calc(100 * var(--vw, 1vw)), 32px)
}

.c-heading {
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol
}

.c-heading.-h1 {
    font-size: var(--font-size-h1);
    font-weight: 250;
    line-height: .9
}

.c-heading.-h2 {
    font-size: var(--font-size-h2);
    font-weight: 250;
    line-height: .9
}

.c-heading.-h3 {
    font-size: var(--font-size-h3);
    font-weight: 300;
    line-height: 1.2
}

:root {
    --font-size-body-medium: clamp(18px, 0.0166666667 * calc(100 * var(--vw, 1vw)), 20px);
    --font-size-body-regular: clamp(13px, 0.0133333333 * calc(100 * var(--vw, 1vw)), 16px);
    --font-size-body-small: clamp(13px, 0.0108333333 * calc(100 * var(--vw, 1vw)), 13px)
}

.c-text {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400
}

.c-text.-body-medium {
    font-size: var(--font-size-body-medium);
    line-height: 1.2
}

@media(min-width: 1400px) {
    .c-text.-body-medium {
        font-size: calc(1.2*var(--font-size-body-medium))
    }
}

.c-text.-body-regular {
    font-size: var(--font-size-body-regular);
    line-height: 1.2
}

@media(min-width: 1400px) {
    .c-text.-body-regular {
        font-size: calc(1.2*var(--font-size-body-regular))
    }
}

.c-text.-body-small {
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-text.-body-small {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-text.-italic {
    font-style: italic
}

:root {
    --button-text-color: #241c18;
    --button-radius: 36px;
    --button-padding: calc(0.45 * var(--button-height));
    --button-gap: 8px
}

@media(hover: hover) {
    :root {
        --button-height: 36px;
        --button-medium-height: 48px;
        --button-small-height: 26px
    }
}

@media(hover: none)and (min-width: 700px) {
    :root {
        --button-height: 42px;
        --button-medium-height: 48px;
        --button-small-height: 30px
    }
}

@media(hover: none)and (max-width: 699px) {
    :root {
        --button-height: 38px;
        --button-medium-height: 42px;
        --button-small-height: 32px
    }
}

.c-button {
    display: inline-flex;
    box-sizing: border-box
}

.c-button.-stroke {
    --button-stroke-color: currentColor;
    --button-stroke-color-hover: #ebebeb;
    --button-background-color: white
}

.c-button.-stroke-light {
    --button-stroke-color: #ebebeb;
    --button-stroke-color-hover: #241c18;
    --button-background-color: white
}

.c-button.-background {
    --button-stroke-color: #241c18;
    --button-stroke-color-hover: #241c18;
    --button-background-color: #241c18;
    --button-background-color-hover: white;
    --button-text-color: white;
    --button-text-color-hover: #241c18
}

.c-button.-small {
    --button-height: var(--button-small-height)
}

.c-button.-medium {
    --button-height: var(--button-medium-height)
}

.c-button.-icon {
    --button-padding: 0
}

.c-button[disabled],
.c-button:disabled,
.c-button.is-disabled {
    pointer-events: none;
    opacity: .5
}

.c-button_inner {
    position: relative;
    display: inline-flex;
    -moz-column-gap: var(--button-gap);
    column-gap: var(--button-gap);
    justify-content: center;
    align-items: center;
    width: 100%;
    color: var(--button-text-color, currentColor);
    height: var(--button-height);
    padding: 0 var(--button-padding);
    pointer-events: none;
    z-index: 0
}

.c-button_inner::before,
.c-button_inner::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border-radius: var(--button-radius)
}

.c-button_inner::before {
    background-color: var(--button-background-color, transparent);
    border: 1px solid var(--button-stroke-color, transparent);
    z-index: -2
}

.c-button.-icon .c-button_inner {
    width: var(--button-height);
    justify-content: center
}

.c-button.-reverse .c-button_inner {
    flex-direction: row-reverse
}

@media(hover: hover) {
    .c-button_inner::before {
        transition: border-color .5s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-button_inner::after {
        border: 1px solid var(--button-stroke-color-hover, transparent);
        transition: clip-path .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        clip-path: polygon(100% 0, 100% 0, 0% 100%, 0% 100%);
        opacity: 0;
        z-index: -1
    }

    .c-button:hover .c-button_inner {
        color: var(--button-text-color-hover, var(--button-text-color))
    }

    .c-button:hover .c-button_inner::before {
        background-color: var(--button-background-color-hover, var(--button-background-color));
        border-color: rgba(0, 0, 0, 0)
    }

    .c-button:hover .c-button_inner::after {
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
        opacity: 1
    }
}

.c-button_label {
    position: relative;
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-button_label {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-button.-icon .c-button_label {
    position: absolute !important;
    overflow: hidden;
    clip: rect(0 0 0 0);
    margin: 0;
    padding: 0;
    width: 1px;
    height: 1px;
    border: 0
}

.c-button_icon {
    position: relative;
    z-index: 1;
    margin-right: calc(-1*var(--button-padding)/3)
}

.c-form_item {
    position: relative;
    margin-bottom: 1.875rem
}

.c-form_label,
.c-form_checkboxLabel,
.c-form_radioLabel {
    display: block;
    margin-bottom: .625rem
}

.c-form_input,
.c-form_textarea,
.c-form_select_input {
    padding: .625rem;
    border: 1px solid #d3d3d3;
    background-color: #fff
}

.c-form_input:hover,
.c-form_textarea:hover,
.c-form_select_input:hover {
    border-color: #a9a9a9
}

.c-form_input:focus,
.c-form_textarea:focus,
.c-form_select_input:focus {
    border-color: dimgray
}

.c-form_input::-moz-placeholder,
.c-form_textarea::-moz-placeholder,
.c-form_select_input::-moz-placeholder {
    color: gray
}

.c-form_input::placeholder,
.c-form_textarea::placeholder,
.c-form_select_input::placeholder {
    color: gray
}

.c-form_checkboxLabel,
.c-form_radioLabel {
    position: relative;
    display: inline-block;
    margin-right: .625rem;
    margin-bottom: 0;
    padding-left: 1.75rem;
    cursor: pointer
}

.c-form_checkboxLabel::before,
.c-form_radioLabel::before,
.c-form_checkboxLabel::after,
.c-form_radioLabel::after {
    position: absolute;
    top: 50%;
    left: 0;
    display: inline-block;
    margin-top: -0.5625rem;
    padding: 0;
    width: 1.125rem;
    height: 1.125rem;
    content: ""
}

.c-form_checkboxLabel::before,
.c-form_radioLabel::before {
    background-color: #fff;
    border: 1px solid #d3d3d3
}

.c-form_checkboxLabel::after,
.c-form_radioLabel::after {
    border-color: rgba(0, 0, 0, 0);
    background-color: rgba(0, 0, 0, 0);
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20x%3D%220%22%20y%3D%220%22%20width%3D%2213%22%20height%3D%2210.5%22%20viewBox%3D%220%200%2013%2010.5%22%20enable-background%3D%22new%200%200%2013%2010.5%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpath%20fill%3D%22%23424242%22%20d%3D%22M4.8%205.8L2.4%203.3%200%205.7l4.8%204.8L13%202.4c0%200-2.4-2.4-2.4-2.4L4.8%205.8z%22%2F%3E%3C%2Fsvg%3E");
    background-position: center;
    background-size: .75rem;
    background-repeat: no-repeat;
    opacity: 0
}

.c-form_checkboxLabel:hover::before,
.c-form_radioLabel:hover::before {
    border-color: #a9a9a9
}

.c-form_checkbox:focus+.c-form_checkboxLabel::before,
.c-form_radio:focus+.c-form_checkboxLabel::before,
.c-form_checkbox:focus+.c-form_radioLabel::before,
.c-form_radio:focus+.c-form_radioLabel::before {
    border-color: dimgray
}

.c-form_checkbox:checked+.c-form_checkboxLabel::after,
.c-form_radio:checked+.c-form_checkboxLabel::after,
.c-form_checkbox:checked+.c-form_radioLabel::after,
.c-form_radio:checked+.c-form_radioLabel::after {
    opacity: 1
}

.c-form_checkbox,
.c-form_radio {
    position: absolute;
    width: 0;
    opacity: 0
}

.c-form_radioLabel::before,
.c-form_radioLabel::after {
    border-radius: 50%
}

.c-form_radioLabel::after {
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20x%3D%220%22%20y%3D%220%22%20width%3D%2213%22%20height%3D%2213%22%20viewBox%3D%220%200%2013%2013%22%20enable-background%3D%22new%200%200%2013%2013%22%20xml%3Aspace%3D%22preserve%22%3E%3Ccircle%20fill%3D%22%23424242%22%20cx%3D%226.5%22%20cy%3D%226.5%22%20r%3D%226.5%22%2F%3E%3C%2Fsvg%3E");
    background-size: .375rem
}

.c-form_select {
    position: relative;
    cursor: pointer
}

.c-form_select::after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    width: 2.5rem;
    background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20x%3D%220%22%20y%3D%220%22%20width%3D%2213%22%20height%3D%2211.3%22%20viewBox%3D%220%200%2013%2011.3%22%20enable-background%3D%22new%200%200%2013%2011.3%22%20xml%3Aspace%3D%22preserve%22%3E%3Cpolygon%20fill%3D%22%23424242%22%20points%3D%226.5%2011.3%203.3%205.6%200%200%206.5%200%2013%200%209.8%205.6%20%22%2F%3E%3C%2Fsvg%3E");
    background-position: center;
    background-size: .5rem;
    background-repeat: no-repeat;
    content: "";
    pointer-events: none
}

.c-form_select_input {
    position: relative;
    z-index: 1;
    padding-right: 2.5rem;
    cursor: pointer
}

.c-form_textarea {
    min-height: 12.5rem
}

.c-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 1.25rem;
    z-index: 200;
    pointer-events: none;
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0s;
    transition-delay: .4s
}

html.has-showreel-open .c-header {
    transform: translate3d(0, -100%, 0);
    transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .75s;
    visibility: hidden
}

.c-header_inner {
    display: flex;
    justify-content: space-between;
    width: 100%
}

.c-header_main {
    display: flex
}

.c-header_logo {
    display: inline-block;
    margin-right: .5rem;
    pointer-events: auto
}

.c-header_tools {
    display: flex;
    align-items: center
}

.c-header-tools_item {
    pointer-events: auto
}

.c-header-tools_item+.c-header-tools_item {
    margin-left: .5rem
}

.c-footer {
    color: #fff;
    background-color: #3d3c44;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem
}

.c-footer_top {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter)
}

@media(max-width: 999px) {
    .c-footer_top {
        margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-2xl-desktop)));
        margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-2xl-desktop)))
    }
}

@media(min-width: 1000px) {
    .c-footer_top {
        grid-template-columns: 1fr 1fr
    }
}

@media(min-width: 1000px) {
    .c-footer_nav {
        grid-column: 2/3
    }
}

.c-footer_bottom {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter);
    align-items: flex-end;
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-2xl-desktop)))
}

@media(max-width: 999px) {
    .c-footer_bottom {
        margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)))
    }
}

@media(min-width: 1000px) {
    .c-footer_bottom {
        grid-template-columns: 1fr 1fr
    }
}

@media(max-width: 699px) {
    .c-footer_logo {
        --icon-width-logo: calc(100 * var(--vw, 1vw))
    }
}

@media(max-width: 999px) {
    .c-footer_logo {
        grid-row: 2/3;
        margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)))
    }
}

@media(min-width: 1000px) {
    .c-footer_logo {
        grid-column: 1/2;
        grid-row: 1/3
    }
}

.c-footer_logo_link {
    display: inline-block
}

@media(min-width: 1000px) {
    .c-footer_logo_link {
        margin-left: calc(-1*var(--grid-margin) + 1.25rem)
    }
}

.c-footer_subnav {
    display: flex
}

@media(max-width: 999px) {
    .c-footer_subnav {
        grid-row: 1/2
    }
}

@media(min-width: 1000px) {
    .c-footer_subnav {
        grid-column: 2/3;
        grid-row: 1/2
    }
}

.c-footer_subnav_list {
    width: calc((100% - var(--grid-gutter))/2)
}

.c-footer_subnav_list+.c-footer_subnav_list {
    margin-left: var(--grid-gutter)
}

.c-footer_subnav_item {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-footer_subnav_item {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-footer_subnav_link {
    display: inline-flex;
    align-items: center
}

.c-footer_subnav_icon {
    margin-left: .2em
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-footer_subnav_icon {
        opacity: 0;
        transition: opacity .25s
    }

    .c-footer_subnav_link:hover .c-footer_subnav_icon {
        opacity: 1
    }
}

.c-footer_legal {
    padding-top: 1.25rem;
    margin-top: 1.25rem;
    border-top: 1px solid rgba(255, 255, 255, .2)
}

@media(max-width: 999px) {
    .c-footer_legal {
        grid-row: 3/4
    }
}

@media(min-width: 1000px) {
    .c-footer_legal {
        grid-column: 2/3;
        grid-row: 2/3
    }
}

.c-footer_legal_item {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-footer_legal_item {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-submark {
    --type-color: white;
    --type-color-hover: #241c18;
    --background-color: #241c18;
    width: calc(var(--button-height) + 5px);
    height: calc(var(--button-height) + 5px)
}

.c-submark #background-idle {
    fill: var(--background-color);
    clip-path: polygon(0% 0%, 0 100%, 50% 100%, 50% 50%, 50% 50%, 50% 50%, 50% 50%, 50% 100%, 100% 100%, 100% 0%)
}

.c-submark #background-hover {
    fill: var(--type-color)
}

.c-menu .c-submark #background-hover {
    display: none
}

.c-submark #type {
    fill: var(--type-color)
}

html.is-first-loaded .c-submark #type {
    transition: fill .15s linear
}

html.is-first-loaded .c-submark #background-idle {
    transition: clip-path .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-menu .c-submark,
html.has-menu-open .c-submark {
    --type-color: #241c18;
    --type-color-hover: white;
    --background-color: white
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-submark:hover #background-idle {
        clip-path: polygon(0% 0%, 0% 100%, 1px 100%, 1px 1px, calc(100% - 1px) 1px, calc(100% - 1px) calc(100% - 1px), 0% calc(100% - 1px), 1px 100%, 100% 100%, 100% 0%)
    }

    .c-submark:hover #type {
        fill: var(--type-color-hover)
    }
}

.c-burger {
    --button-stroke-color: rgba(255, 255, 255, 0.4);
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    pointer-events: auto;
    color: #241c18
}

html.has-menu-open .c-burger {
    --button-stroke-color: rgba(255, 255, 255, 0.2);
    --button-stroke-color-hover: white;
    --button-background-color: transparent;
    --button-background-color-hover: transparent;
    --button-text-color: white
}

.c-menu .c-burger {
    --button-text-color: white;
    --button-background-color: transparent
}

.c-burger_icon {
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

html.has-menu-open .c-burger_icon,
.c-menu .c-burger_icon {
    transform: rotate(135deg)
}

.c-burger_icon::before,
.c-burger_icon::after {
    content: "";
    display: block;
    width: .9375rem;
    height: 1px;
    background-color: currentColor;
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-burger_icon::after {
    margin-top: .1875rem
}

html.has-menu-open .c-burger_icon::before,
.c-menu .c-burger_icon::before {
    transform: translate3d(0, 0.125rem, 0)
}

html.has-menu-open .c-burger_icon::after,
.c-menu .c-burger_icon::after {
    transform: translate3d(0, -0.125rem, 0) rotate(90deg)
}

.c-menu {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100dvh;
    color: #fff;
    visibility: hidden
}

@media(max-width: 999px) {
    html.is-first-loaded .c-menu {
        transition: transform .25s cubic-bezier(0.77, 0, 0.175, 1), opacity .25s, visibility .25s
    }
}

@media(min-width: 1000px) {
    html.is-first-loaded .c-menu {
        transition: transform .75s cubic-bezier(0.38, 0.005, 0.215, 1), visibility .75s
    }
}

html.has-menu-open .c-menu {
    visibility: visible;
    transform: translate3d(0, 0, 0)
}

@media(max-width: 999px) {
    html.has-menu-open .c-menu {
        opacity: 1;
        transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .15s, visibility 0s
    }
}

@media(min-width: 1000px) {
    html.has-menu-open .c-menu {
        transition: transform 1s cubic-bezier(0.23, 1, 0.32, 1), visibility 0s
    }
}

@media(max-width: 999px) {
    .c-menu {
        opacity: 0;
        transform: translate3d(0, 6.25rem, 0);
        z-index: 201
    }
}

@media(min-width: 1000px) {
    .c-menu {
        transform: translate3d(-100%, 0, 0);
        z-index: 199
    }
}

.c-menu_container {
    max-width: 100%;
    height: 100%;
    background-color: rgba(62, 62, 67, .65);
    -webkit-backdrop-filter: blur(50px);
    backdrop-filter: blur(50px);
    overflow-y: auto
}

@media(max-width: 999px) {
    .c-menu_container {
        padding: .5rem;
        clip-path: inset(0.5rem round 2.5rem)
    }
}

@media(min-width: 1000px) {
    .c-menu_container {
        padding: .5rem 0 .5rem .5rem;
        clip-path: inset(0.5rem 0 0.5rem 0.5rem round 0.75rem)
    }
}

@media(min-width: 1000px)and (max-width: 1399px) {
    .c-menu_container {
        width: calc(calc(0.75 * (calc(100 * var(--vw, 1vw)) - 2 * var(--grid-margin, 0px)) - (1 - 0.75) * var(--grid-gutter, 0px) + 0 * var(--grid-gutter, 0px)) + var(--grid-margin))
    }
}

@media(min-width: 1400px) {
    .c-menu_container {
        width: calc(calc(0.5833333333 * (calc(100 * var(--vw, 1vw)) - 2 * var(--grid-margin, 0px)) - (1 - 0.5833333333) * var(--grid-gutter, 0px) + 0 * var(--grid-gutter, 0px)) + var(--grid-margin))
    }
}

.c-menu_grid {
    display: grid;
    min-height: 100%
}

@media(max-width: 999px) {
    .c-menu_grid {
        grid-template-rows: 1fr auto 1fr;
        grid-gap: 1.875rem
    }
}

@media(min-width: 1000px) {
    .c-menu_grid {
        grid-template-areas: "head content" "head bottom";
        grid-template-rows: 1fr auto;
        grid-template-columns: calc(var(--grid-margin) + calc(0.1666666667 * (calc(100 * var(--vw, 1vw)) - 2 * var(--grid-margin, 0px)) - (1 - 0.1666666667) * var(--grid-gutter, 0px) + 0 * var(--grid-gutter, 0px)) - 0.5rem) auto;
        padding: 1rem 0
    }
}

.c-menu_head {
    position: relative
}

@media(min-width: 1000px) {
    .c-menu_head {
        grid-area: head
    }

    .c-menu_head::before {
        content: "";
        position: absolute;
        top: 0;
        right: -1px;
        height: 100%;
        width: 1px;
        background-color: currentColor;
        opacity: .2
    }
}

@media(max-width: 999px) {
    .c-menu_head_inner {
        display: flex;
        justify-content: center;
        align-items: center;
        height: 100%;
        padding: 2.5rem 0
    }
}

@media(min-width: 1000px) {
    .c-menu_head_inner {
        display: none
    }
}

.c-menu_logo {
    margin-right: .5rem
}

.c-menu_content {
    padding-right: var(--grid-gutter)
}

@media(max-width: 999px) {
    .c-menu_content {
        text-align: center
    }
}

@media(min-width: 1000px) {
    .c-menu_content {
        grid-area: content
    }
}

@media(min-width: 1000px) {
    .c-menu_primary-container {
        padding-bottom: 2.5rem;
        clip-path: inset(-1rem 0 0 0)
    }
}

.c-menu_primary {
    position: relative
}

@media(min-width: 1000px) {
    .c-menu_primary::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 1px;
        height: var(--item-height, 0px);
        transform: translate3d(0, var(--item-offset, 0px), 0);
        clip-path: inset(50% 0%);
        transition: transform .75s cubic-bezier(0.23, 1, 0.32, 1), clip-path .75s cubic-bezier(0.23, 1, 0.32, 1);
        background-color: currentColor
    }

    .c-menu.has-active-item .c-menu_primary::before {
        clip-path: inset(0% 0%)
    }

    .c-menu_primary:hover::before {
        clip-path: inset(0% 0%)
    }
}

.c-menu_primary_item {
    display: block
}

@media(max-width: 999px) {
    .c-menu_primary_item {
        --master-delay: 0s;
        opacity: 0;
        transform: translate3d(0, 100%, 0)
    }
}

@media(min-width: 1000px) {
    .c-menu_primary_item {
        --master-delay: 0s;
        transform: translate3d(-100%, 0, 0)
    }
}

html.is-first-loaded .c-menu_primary_item {
    transition-duration: 0s;
    transition-delay: .5s
}

html.has-menu-open .c-menu_primary_item {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-duration: 1s;
    transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-delay: calc(var(--item-index, 0)*.05s + var(--master-delay))
}

@media(max-width: 999px) {
    html.has-menu-open .c-menu_primary_item {
        transition-property: transform, opacity
    }
}

@media(min-width: 1000px) {
    html.has-menu-open .c-menu_primary_item {
        transition-property: transform
    }
}

.c-menu_bottom {
    display: grid;
    align-items: flex-end;
    grid-template-columns: 1fr 1fr;
    padding: 0 var(--grid-gutter);
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter)
}

@media(min-width: 1000px) {
    .c-menu_bottom {
        grid-area: bottom;
        margin-top: 5rem
    }
}

@media(max-width: 999px) {
    .c-menu_bottom {
        padding: 2.5rem
    }
}

.c-hero {
    --negative-margin: calc(15 * var(--svh, 1svh));
    --hero-height: 90vh
}

.c-hero.-small {
    --hero-height: 70vh
}

.c-hero.-full-height {
    --hero-height: 100vh
}

.c-hero.-full-height .c-hero_container {
    height: calc(100*var(--svh, 1svh))
}

.c-next-project .c-hero.-full-height .c-hero_container {
    height: 100vh
}

.c-hero_inner {
    display: grid;
    width: 100%;
    text-align: center;
    height: var(--hero-height);
    min-height: 30rem
}

.c-hero.-project .c-hero_inner {
    grid-template-rows: 1fr auto 1fr
}

.c-hero.-project .c-hero_suptitle {
    grid-row: 1/2;
    align-self: flex-end;
    opacity: 0
}

html.is-first-loaded .c-hero.-project .c-hero_suptitle {
    transition: opacity .3s
}

html.is-ready .c-hero.-project .c-hero_suptitle {
    opacity: 1
}

.c-hero.-project .c-hero_subtitle {
    grid-row: 3/4;
    align-self: flex-start;
    opacity: 0
}

html.is-first-loaded .c-hero.-project .c-hero_subtitle {
    transition: opacity .3s
}

html.is-ready .c-hero.-project .c-hero_subtitle {
    opacity: 1
}

@media(max-width: 699px) {
    .c-hero.-project .c-hero_subtitle {
        margin-top: 1.875rem
    }
}

.c-hero.-full-height .c-hero_after {
    margin-top: calc(-1*var(--negative-margin))
}

.c-hero_scaling {
    width: 100%
}

@media(max-width: 999px) {
    .c-hero_scaling {
        height: calc(80*var(--svh, 1svh))
    }
}

@media(min-width: 1000px) {
    .c-hero_scaling {
        height: calc(120*var(--svh, 1svh))
    }
}

@media(min-width: 700px)and (hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-hero_scaling {
        clip-path: inset(calc((1 - var(--anim-progress, 1)) * var(--negative-margin)) calc(20% * (1 - var(--anim-progress, 1)) + (1 - var(--scroll-progress, 1)) * 30%) 0 calc(20% * (1 - var(--anim-progress, 1)) + (1 - var(--scroll-progress, 1)) * 30%))
    }
}

@media(max-width: 699px) {
    .c-hero_scaling {
        padding-right: var(--grid-margin);
        padding-left: var(--grid-margin)
    }
}

@media(min-width: 700px)and (hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-hero_scaling_img {
        transform-origin: 50% 0%;
        transform: scale(calc(0.85 + 0.15 * var(--scroll-progress, 0)), calc(0.85 + 0.15 * var(--scroll-progress, 0)))
    }
}

.c-hero_title-container {
    display: grid
}

.c-hero.-project .c-hero_title-container {
    grid-row: 2/3
}

@media(max-width: 699px) {
    .c-hero_title-container {
        grid-template-rows: auto auto;
        justify-content: center
    }
}

@media(min-width: 700px) {
    .c-hero_title-container {
        grid-template-columns: 1fr auto 1fr;
        -moz-column-gap: 6.25rem;
        column-gap: 6.25rem;
        align-items: center
    }
}

.c-hero_title {
    margin: calc(12*var(--svh, 1svh)) 0;
    align-self: center
}

@media(min-width: 700px) {
    .c-hero_title {
        grid-column: 2/3
    }
}

.c-hero_progress {
    position: relative;
    width: 100%;
    max-width: 17.5rem;
    background-color: #ebebeb;
    height: 1px;
    display: none;
    opacity: 0
}

html.is-first-loaded .c-hero_progress {
    transition: opacity .3s
}

html.is-ready .c-hero_progress {
    opacity: 1
}

.c-next-project .c-hero_progress {
    display: block
}

.c-hero_progress::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #241c18;
    transform: scaleX(var(--progress, 0))
}

.c-hero_progress.-left::before {
    transform-origin: top right
}

@media(max-width: 699px) {
    .c-hero_progress.-left {
        display: none
    }
}

@media(min-width: 700px) {
    .c-hero_progress.-left {
        grid-column: 1/2;
        margin-left: auto
    }
}

@media(max-width: 699px) {
    .c-hero_progress.-right {
        justify-self: center;
        min-width: 12.5rem
    }

    .c-hero_progress.-right::before {
        transform-origin: top center
    }
}

@media(min-width: 700px) {
    .c-hero_progress.-right {
        grid-column: 3/4
    }

    .c-hero_progress.-right::before {
        transform-origin: top left
    }
}

.c-image {
    position: relative
}

.c-image.-cover,
.c-image.-contain {
    width: 100%;
    height: 100%
}

@media(max-width: 999px) {
    .c-image.-fullheight {
        aspect-ratio: 1/1
    }
}

@media(min-width: 1000px) {
    .c-image.-fullheight {
        height: calc(100svh - var(--header-height))
    }
}

.c-image.-fullwidth {
    width: 100%
}

.c-image.-parallax {
    overflow: hidden
}

.c-image.-lazy-load .c-image_inner {
    background-color: #ebebeb
}

.c-image.-cover .c-image_inner,
.c-image.-contain .c-image_inner {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%
}

html:not(.is-mobile) .c-image.-parallax .c-image_inner {
    transform: scale3d(var(--parallax-scale), var(--parallax-scale), 1)
}

.c-image.-overlay .c-image_inner {
    position: relative
}

.c-image.-overlay .c-image_inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #241c18;
    opacity: .1;
    z-index: 2
}

.c-image_parallax {
    width: 100%;
    height: 100%
}

.c-image_img {
    width: 100%
}

.c-image.-cover .c-image_img {
    -o-object-fit: cover;
    object-fit: cover;
    height: 100%;
    width: 100%
}

.c-image.-contain .c-image_img {
    -o-object-fit: contain;
    object-fit: contain;
    height: 100%;
    width: 100%
}

html:not(.is-mobile) .c-image.-parallax .c-image_img {
    transform: scale3d(var(--parallax-scale), var(--parallax-scale), 1)
}

.c-image.-lazy-load .c-image_img {
    opacity: 0;
    transition: opacity .25s linear
}

.c-image.-lazy-load .c-image_img.is-loaded {
    opacity: 1
}

.c-carousel_inner {
    overflow: hidden;
    background-color: #f5f5f5
}

.c-carousel_nav {
    display: flex;
    justify-content: space-between;
    align-items: center
}

@media(max-width: 999px) {
    .c-carousel_nav {
        padding-top: 1.625rem
    }
}

@media(min-width: 1000px) {
    .c-carousel_nav {
        padding-top: 1.5rem
    }
}

.c-carousel_controls {
    display: flex;
    -moz-column-gap: .5rem;
    column-gap: .5rem
}

.c-carousel_item {
    max-height: 100vh
}

@media(max-width: 499px) {
    .c-carousel_item {
        aspect-ratio: 3/4
    }
}

@media(min-width: 500px)and (max-width: 999px) {
    .c-carousel_item {
        aspect-ratio: 3/2
    }
}

@media(min-width: 1000px) {
    .c-carousel_item {
        aspect-ratio: 16/9
    }
}

.c-carousel.is-dragging .c-carousel_item {
    pointer-events: none
}

.c-carousel_image {
    height: 100%
}

.c-carousel_index {
    position: relative;
    display: flex;
    align-items: flex-start;
    -moz-column-gap: .2em;
    column-gap: .2em;
    overflow: hidden;
    height: 1.2em
}

.c-carousel_index_item.-current {
    display: flex;
    flex-direction: column;
    transform: translate3d(0, calc(-100% * var(--progress, 0) * (1 - 1 / var(--length))), 0);
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-contact {
    padding-top: calc(clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) + var(--header-height))
}

.c-contact_hero {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter);
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop)))
}

@media(min-width: 1000px) {
    .c-contact_hero {
        grid-template-columns: repeat(4, 1fr);
        align-items: flex-end
    }
}

@media(min-width: 1000px) {
    .c-contact_title {
        grid-column: 1/2
    }
}

.c-contact_primary {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

@media(max-width: 999px) {
    .c-contact_primary {
        margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-3xl-desktop)))
    }
}

@media(min-width: 700px) {
    .c-contact_primary {
        grid-column: 2/-1
    }
}

.c-contact_main_link {
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol
}

@media(max-width: 999px) {
    .c-contact_main_link {
        font-size: var(--font-size-h3);
        font-weight: 300;
        line-height: 1.2
    }
}

@media(min-width: 1000px) {
    .c-contact_main_link {
        font-size: var(--font-size-h2);
        font-weight: 250;
        line-height: .9
    }

    .c-contact_main_link+.c-contact_main_link {
        margin-top: 1.25rem
    }
}

.c-contact_grid {
    --inner-padding: 1.5rem;
    border-top: 1px solid #f5f5f5;
    padding-top: var(--inner-padding)
}

@media(max-width: 999px) {
    .c-contact_grid {
        row-gap: 2.5rem
    }
}

@media(min-width: 1000px) {
    .c-contact_grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter)
    }
}

.c-contact_offices {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter);
    row-gap: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop)));
    padding: var(--inner-padding) 0
}

@media(max-width: 699px) {
    .c-contact_offices {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(max-width: 999px) {
    .c-contact_offices {
        margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-3xl-desktop)))
    }
}

@media(min-width: 700px) {
    .c-contact_offices {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media(min-width: 1000px) {
    .c-contact_offices {
        grid-column: 1/4;
        border-right: 1px solid #f5f5f5
    }
}

.c-contact_offices_title {
    margin-bottom: .75rem
}

@media(max-width: 699px) {
    .c-contact_offices_title {
        font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-size: var(--font-size-h3);
        font-weight: 300;
        line-height: 1.2
    }
}

@media(min-width: 700px) {
    .c-contact_offices_title {
        font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-weight: 400;
        font-size: var(--font-size-body-medium);
        line-height: 1.2
    }
}

@media(min-width: 700px)and (min-width: 1400px) {
    .c-contact_offices_title {
        font-size: calc(1.2*var(--font-size-body-medium))
    }
}

.c-contact_offices_address {
    font-style: normal
}

@media(min-width: 700px) {
    .c-contact_others {
        grid-column: 4/-1
    }
}

.c-contact_secondary {
    padding: var(--inner-padding) 0
}

@media(max-width: 699px) {
    .c-contact_secondary {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(max-width: 999px) {
    .c-contact_secondary {
        display: grid;
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter);
        width: 100%;
        border-top: 1px solid #f5f5f5
    }
}

@media(min-width: 700px)and (max-width: 999px) {
    .c-contact_secondary {
        grid-template-columns: repeat(3, 1fr)
    }
}

@media(min-width: 1000px) {
    .c-contact_secondary {
        display: flex;
        flex-direction: column
    }
}

@media(min-width: 1000px) {
    .c-contact_secondary_group+.c-contact_secondary_group {
        padding-top: var(--inner-padding);
        margin-top: var(--inner-padding);
        border-top: 1px solid #f5f5f5
    }
}

.c-contact_secondary_title {
    margin-bottom: .75rem
}

@media(max-width: 699px) {
    .c-contact_secondary_title {
        font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-size: var(--font-size-h3);
        font-weight: 300;
        line-height: 1.2
    }
}

@media(min-width: 700px) {
    .c-contact_secondary_title {
        font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-weight: 400;
        font-size: var(--font-size-body-medium);
        line-height: 1.2
    }
}

@media(min-width: 700px)and (min-width: 1400px) {
    .c-contact_secondary_title {
        font-size: calc(1.2*var(--font-size-body-medium))
    }
}

@media(max-width: 699px) {
    .c-link-listing_group+.c-link-listing_group {
        margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-2xl-desktop)))
    }
}

@media(min-width: 700px) {
    .c-link-listing_group {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter);
        border-top: 1px solid #ebebeb
    }
}

.c-link-listing_group_title {
    padding-top: 2rem
}

@media(min-width: 700px) {
    .c-link-listing_group_title {
        font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-size: var(--font-size-h3);
        font-weight: 300;
        line-height: 1.2
    }
}

@media(max-width: 699px) {
    .c-link-listing_group_title {
        font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
        font-weight: 400;
        font-size: var(--font-size-body-regular);
        line-height: 1.2;
        margin-bottom: 2.5rem
    }
}

@media(max-width: 699px)and (min-width: 1400px) {
    .c-link-listing_group_title {
        font-size: calc(1.2*var(--font-size-body-regular))
    }
}

.c-link-listing_item {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 2rem 0;
    border-top: 1px solid #ebebeb
}

@media(min-width: 700px) {
    .c-link-listing_item:first-child {
        border-top: none
    }
}

.c-link-listing_item {
    overflow: hidden
}

.c-link-listing_title {
    position: relative
}

@media(hover: hover)and (prefers-reduced-motion: reduce) {
    .c-link-listing_item:hover .c-link-listing_title-label {
        text-decoration: underline;
        text-decoration-thickness: 2px;
        text-underline-offset: .07em
    }
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-link-listing_title-label {
        display: inline-block;
        transition: transform .4s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-link-listing_item:hover .c-link-listing_title-label {
        transform: translate3d(1em, 0, 0)
    }
}

.c-link-listing_title-icon {
    --icon-width: .7em;
    position: absolute;
    top: 0;
    right: 100%;
    width: 1em;
    height: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-link-listing_title-icon {
        transition: transform .4s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-link-listing_item:hover .c-link-listing_title-icon {
        transform: translate3d(1em, 0, 0);
        transition-delay: .08s
    }
}

.c-link-listing_link {
    margin-left: var(--grid-gutter)
}

.c-link-listing_link::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block
}

@media(min-width: 700px) {
    .c-link-listing_link {
        opacity: .5
    }
}

@media(min-width: 700px) {
    .c-link-listing_label-container {
        clip-path: inset(0)
    }
}

.c-link-listing_label {
    display: inline-block
}

@media(min-width: 700px)and (hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-link-listing_label {
        transform: translate3d(0, 100%, 0);
        transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-link-listing_link:hover .c-link-listing_label,
    .c-link-listing_link:focus .c-link-listing_label {
        transform: translate3d(0, 0, 0)
    }

    .c-link-listing_link:hover .c-link-listing_label {
        transition-delay: .2s
    }
}

@media(max-width: 699px) {
    .c-link-listing_label_inner {
        display: none
    }
}

.c-story-block_heading {
    display: grid
}

@media(max-width: 699px) {
    .c-story-block_heading {
        row-gap: 2rem
    }
}

@media(min-width: 700px) {
    .c-story-block_heading {
        grid-template-columns: 1fr 1fr;
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter)
    }
}

.c-story-block_inner {
    display: grid;
    row-gap: 2rem;
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)))
}

@media(max-width: 699px) {
    .c-story-block_inner {
        grid-template-columns: 1fr;
        grid-template-areas: "textTop" "image" "textLeft" "textRight"
    }
}

@media(min-width: 700px) {
    .c-story-block_inner {
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter)
    }
}

@media(min-width: 700px)and (max-width: 999px) {
    .c-story-block_inner {
        grid-template-columns: repeat(2, 1fr);
        grid-template-areas: ". textTop" "image image" "textLeft textRight"
    }
}

@media(min-width: 1000px) {
    .c-story-block_inner {
        grid-template-columns: repeat(4, 1fr);
        grid-template-rows: 1fr auto;
        grid-template-areas: "image image textTop ." "image image textLeft textRight"
    }
}

.c-story-block_image {
    grid-area: image;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #f5f5f5;
    padding: 35% 25%;
    height: -moz-fit-content;
    height: fit-content
}

.c-story-block_text.-top {
    grid-area: textTop
}

.c-story-block_text.-left {
    grid-area: textLeft
}

.c-story-block_text.-right {
    grid-area: textRight
}

.c-poem {
    --initial-height: 200px;
    --controls-spacing: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center
}

@media(min-width: 700px)and (max-width: 999px) {
    .c-poem {
        padding: 0 calc(0.1666666667*(calc(100 * var(--vw, 1vw)) - 2*var(--grid-margin, 0px)) - (1 - 0.1666666667)*var(--grid-gutter, 0px) + 1*var(--grid-gutter, 0px))
    }
}

@media(min-width: 1000px) {
    .c-poem {
        padding: 0 calc(0.25*(calc(100 * var(--vw, 1vw)) - 2*var(--grid-margin, 0px)) - (1 - 0.25)*var(--grid-gutter, 0px) + 1*var(--grid-gutter, 0px))
    }
}

.c-poem_heading {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)))
}

.c-poem_subtitle {
    margin-top: .5rem;
    opacity: .5
}

.c-poem_container {
    position: relative
}

.c-poem:not(.is-open) .c-poem_inner {
    max-height: var(--initial-height);
    -webkit-mask-image: -webkit-linear-gradient(90deg, rgba(0, 0, 0, 0) 10%, rgb(0, 0, 0) 90%)
}

.c-poem.is-open .c-poem_inner {
    -webkit-mask-image: -webkit-linear-gradient(90deg, rgba(0, 0, 0, 0) -90%, rgb(0, 0, 0) 0%);
    padding-bottom: calc(var(--button-height) + var(--controls-spacing))
}

.c-poem_button-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    padding-top: var(--initial-height)
}

.c-poem.is-open .c-poem_text {
    -webkit-mask-image: var(--mask-image);
    mask-image: var(--mask-image)
}

.c-poem_button-spacer {
    flex-grow: 1
}

.c-poem_button-sticky {
    position: sticky;
    bottom: var(--controls-spacing);
    margin-top: var(--controls-spacing)
}

html.is-first-loaded .c-poem_button {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0s
}

.c-poem.is-open .c-poem_button {
    visibility: hidden;
    opacity: 0;
    transform: translate3d(0, 2.5rem, 0);
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .5s
}

.c-poem_controls-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    pointer-events: none
}

.c-poem_controls {
    display: flex;
    align-items: center;
    color: #fff;
    background-color: #000;
    height: var(--button-height);
    clip-path: inset(0 round var(--button-height));
    visibility: hidden;
    opacity: 0;
    transform: translate3d(0, calc(var(--button-height) + 1.5rem), 0);
    pointer-events: none
}

html.is-first-loaded .c-poem_controls {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .5s
}

.c-poem.is-open .c-poem_controls {
    visibility: visible;
    opacity: 1;
    transform: translate3d(0, 0, 0);
    pointer-events: auto;
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0s
}

.c-poem_controls_pause {
    position: relative;
    width: var(--button-height);
    height: var(--button-height)
}

.c-poem_controls_pause::before {
    content: "";
    position: absolute;
    top: calc(50% - 9px);
    right: 0;
    width: 1px;
    height: 18px;
    background-color: currentColor;
    opacity: .2
}

.c-poem_controls_pause_icon {
    position: absolute;
    top: calc(50% - .5*var(--icon-width));
    left: calc(50% - .5*var(--icon-width));
    animation: controlIconSwitch .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-poem.is-paused .c-poem_controls_pause_icon.-pause {
    display: none
}

.c-poem:not(.is-paused) .c-poem_controls_pause_icon.-play {
    display: none
}

.c-poem_controls_title {
    margin: 0 1rem
}

.c-poem_controls_time {
    opacity: .75;
    margin: 0 .5rem 0 1rem;
    min-width: 3.2em
}

.c-poem_controls_close {
    display: flex;
    justify-content: center;
    align-items: center;
    width: var(--button-height);
    height: var(--button-height)
}

.c-listing {
    position: relative
}

@media(min-width: 700px)and (max-width: 999px) {
    .c-listing.-col-4 {
        --columns: 2
    }
}

@media(min-width: 1000px) {
    .c-listing.-col-4 {
        --columns: 4
    }
}

@media(max-width: 699px) {
    .c-listing.-col-6 {
        --columns: 2
    }
}

@media(min-width: 700px)and (max-width: 999px) {
    .c-listing.-col-6 {
        --columns: 4
    }
}

@media(min-width: 1000px) {
    .c-listing.-col-6 {
        --columns: 6
    }
}

.c-listing.-publications,
.c-listing.-books {
    --image-ratio: 3/4
}

.c-listing_heading {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter);
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop)))
}

@media(max-width: 999px) {
    .c-listing_heading {
        grid-template-areas: "title title title filter" "description description description description"
    }
}

@media(min-width: 1000px) {
    .c-listing_heading {
        grid-template-areas: "title title description filter";
        grid-template-columns: repeat(4, 1fr)
    }
}

@media(min-width: 700px) {
    .c-listing.-included-heading .c-listing_heading {
        position: absolute;
        top: 0;
        left: 0;
        width: calc((100% + var(--grid-gutter))/12*12/var(--columns, 12) - var(--grid-gutter));
        aspect-ratio: var(--image-ratio, 1);
        margin-bottom: 0
    }
}

.c-listing_title {
    grid-area: title
}

@media(min-width: 1000px) {
    .c-listing.-publications .c-listing_title {
        display: grid;
        grid-template-columns: 1fr 1fr;
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter)
    }
}

@media(max-width: 999px) {
    .c-listing_count {
        margin-left: 1em
    }
}

.c-listing_description {
    grid-area: description
}

@media(max-width: 999px) {
    .c-listing_description {
        margin-top: 2rem
    }
}

.c-listing_filter-container {
    grid-area: filter;
    justify-self: flex-end;
    align-self: flex-start;
    display: flex;
    align-items: center;
    -moz-column-gap: .5rem;
    column-gap: .5rem
}

.c-listing_list {
    display: grid;
    -moz-column-gap: var(--grid-gutter);
    column-gap: var(--grid-gutter);
    row-gap: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop)));
    grid-template-columns: repeat(var(--columns, 1), 1fr);
    transition: opacity .3s
}

.c-listing_item {
    animation: slideInUp .5s cubic-bezier(0.165, 0.84, 0.44, 1) both, forwards;
    animation-delay: calc(var(--index)*.01s)
}

@media(min-width: 700px) {
    .c-listing.-included-heading .c-listing_item:nth-child(1) {
        grid-column-start: 2
    }
}

.c-listing_view-more {
    text-align: left
}

.c-listing_view-more::before {
    content: attr(data-remaining);
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-size: var(--font-size-h3);
    font-weight: 300;
    line-height: 1.2;
    display: flex;
    justify-content: center;
    align-items: center;
    aspect-ratio: var(--image-ratio, 1);
    background-color: #f5f5f5;
    margin-bottom: 1rem
}

@media(hover: hover) {
    .c-listing_view-more::before {
        clip-path: inset(0);
        transition: clip-path .3s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-listing_view-more:hover::before {
        clip-path: inset(0.3125rem)
    }
}

.c-listing_view-more_label {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400
}

.c-listing.-staff .c-listing_view-more_label {
    font-size: var(--font-size-body-regular);
    line-height: 1.2
}

@media(min-width: 1400px) {
    .c-listing.-staff .c-listing_view-more_label {
        font-size: calc(1.2*var(--font-size-body-regular))
    }
}

.c-listing.-publications .c-listing_view-more_label {
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-listing.-publications .c-listing_view-more_label {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-listing_reset {
    --icon-width-close: 0.625rem
}

.c-tile-publication {
    position: relative
}

.c-tile-publication_image {
    width: 100%;
    aspect-ratio: var(--image-ratio, 1)
}

.c-tile-publication_title {
    margin-top: 1rem
}

.c-tile-publication_link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media(hover: hover) {
    .c-tile-publication_image {
        clip-path: inset(0)
    }

    .c-tile-publication_image::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1;
        background-color: rgba(36, 28, 24, .08);
        opacity: 0
    }

    html.is-first-loaded .c-tile-publication_image {
        transition: clip-path .5s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    html.is-first-loaded .c-tile-publication_image::before {
        transition: opacity .3s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-tile-publication:hover .c-tile-publication_image {
        clip-path: inset(0.3125rem)
    }

    .c-tile-publication:hover .c-tile-publication_image::before {
        opacity: 1
    }
}

.c-tile-team {
    position: relative
}

.c-tile-team_image {
    width: 100%;
    aspect-ratio: var(--image-ratio, 1)
}

.c-tile-team_title {
    display: block;
    margin-top: 1rem
}

.c-tile-team_title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

@media(hover: hover) {
    .c-tile-team_image {
        clip-path: inset(0)
    }

    .c-tile-team_image::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1;
        background-color: rgba(36, 28, 24, .08);
        opacity: 0
    }

    html.is-first-loaded .c-tile-team_image {
        transition: clip-path .5s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    html.is-first-loaded .c-tile-team_image::before {
        transition: opacity .3s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-tile-team:hover .c-tile-team_image {
        clip-path: inset(0.3125rem)
    }

    .c-tile-team:hover .c-tile-team_image::before {
        opacity: 1
    }
}

.c-tile-team_link_label {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-tile-team_link_label {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-tile-team_link_label {
    opacity: .5;
    margin-top: .3em
}

@media(hover: hover) {
    .c-tile-team_link_label {
        transition: opacity .25s
    }

    .c-tile-team:hover .c-tile-team_link_label {
        opacity: 1
    }
}

.c-modal-filters {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100dvh;
    max-width: inherit;
    max-height: 100lvh;
    margin: 0;
    padding: 0;
    background: rgba(0, 0, 0, 0);
    border: none;
    visibility: hidden;
    pointer-events: none;
    transition: visibility .5s;
    z-index: 300;
    overflow: hidden
}

.c-modal-filters[open] {
    pointer-events: auto;
    visibility: visible;
    transition-duration: 0s
}

.c-modal-filters_backdrop {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(36, 28, 24, .2);
    opacity: 0;
    z-index: -1;
    transition: opacity .25s
}

.c-modal-filters[open] .c-modal-filters_backdrop {
    opacity: 1
}

.c-modal-filters_scroll {
    height: 100%;
    overflow: auto;
    pointer-events: none
}

.c-modal-filters_inner {
    display: flex;
    align-items: flex-start;
    justify-content: flex-end;
    padding: 1.5rem
}

.c-modal-filters_form {
    display: flex;
    flex-wrap: wrap;
    gap: .375rem
}

@media(min-width: 1000px) {
    .c-modal-filters_form {
        max-width: 22.5rem;
        justify-content: flex-end
    }
}

.c-modal-filters_item {
    display: none;
    pointer-events: auto
}

@media(prefers-reduced-motion: no-preference) {
    .c-modal-filters_item {
        animation: slideInUp .5s cubic-bezier(0.165, 0.84, 0.44, 1) both, forwards;
        animation-delay: calc(var(--index)*.008s)
    }
}

.c-modal-filters[open] .c-modal-filters_item {
    display: block
}

.c-modal-filters_close {
    position: sticky;
    top: 1.5rem;
    margin-left: 1rem;
    pointer-events: auto
}

.c-filter {
    position: relative;
    min-height: var(--button-small-height)
}

.c-filter_input {
    position: absolute;
    width: 0;
    opacity: 0;
    margin: 0
}

.c-filter_label {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-filter_label {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-filter_label {
    display: flex;
    align-items: center;
    padding: 0 var(--button-padding);
    color: #241c18;
    height: 100%;
    background-color: #fff;
    border: 1px solid #ebebeb;
    border-radius: 1.875rem;
    cursor: pointer;
    transition-property: background-color, border-color, color;
    transition-duration: .25s
}

.c-filter_input:focus-visible+.c-filter_label {
    outline: 2px auto currentColor;
    outline-offset: 2px
}

html.is-safari .c-filter_input:focus-visible+.c-filter_label {
    outline-style: dotted;
    outline-width: 4px
}

.c-filter_input:checked+.c-filter_label {
    color: #fff;
    background-color: #3d3c44;
    border-color: rgba(0, 0, 0, 0)
}

.c-dialog {
    position: fixed;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100dvh;
    max-width: inherit;
    max-height: 100lvh;
    margin: 0;
    padding: 0;
    background: rgba(0, 0, 0, 0);
    border: none;
    overflow: hidden
}

.c-dialog:not([open]) {
    pointer-events: none;
    visibility: hidden;
    transition: visibility .3s
}

.c-dialog_backdrop {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: default;
    pointer-events: none;
    transition-property: opacity;
    transition-duration: .3s;
    background-color: rgba(36, 28, 24, .2);
    z-index: 1
}

.c-dialog[open] .c-dialog_backdrop {
    opacity: 1;
    pointer-events: auto;
    transition-duration: .25s
}

.c-dialog_inner {
    position: relative;
    display: flex;
    justify-content: flex-end;
    overflow: hidden;
    pointer-events: none;
    height: 100%;
    z-index: 2
}

.c-dialog_content {
    position: relative;
    overflow: auto;
    max-width: 100%;
    color: #241c18;
    background-color: #fff;
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    pointer-events: auto
}

@media(max-width: 699px) {
    .c-dialog:not([open]) .c-dialog_content {
        transform: translate3d(0, 100%, 0)
    }
}

@media(min-width: 700px) {
    .c-dialog:not([open]) .c-dialog_content {
        transform: translate3d(100%, 0, 0)
    }
}

@media(max-width: 699px) {
    .c-dialog_content {
        padding: 0 var(--grid-margin);
        width: 100%
    }
}

@media(min-width: 700px) {
    .c-dialog_content {
        padding: 1.5rem var(--grid-margin) 1.5rem 1.5rem;
        width: calc(calc(0.75 * (calc(100 * var(--vw, 1vw)) - 2 * var(--grid-margin, 0px)) - (1 - 0.75) * var(--grid-gutter, 0px) + 1 * var(--grid-gutter, 0px)) + var(--grid-margin))
    }
}

.c-dialog_close {
    position: fixed;
    display: flex;
    pointer-events: auto;
    opacity: 0;
    transition: opacity .1s
}

@media(max-width: 699px) {
    .c-dialog_close {
        bottom: 1.75rem;
        left: calc(50% - 1.5625rem);
        justify-content: center
    }
}

@media(min-width: 700px) {
    .c-dialog_close {
        top: 1.5rem;
        right: 1.5rem
    }
}

.c-dialog[open] .c-dialog_close {
    opacity: 1;
    transition-delay: .3s;
    transition-duration: .3s
}

@media(max-width: 699px) {
    .c-dialog_close.c-button {
        --button-height: 3.125rem;
        --button-background-color: #241c18;
        --button-stroke-color: #241c18;
        --button-text-color: white;
        --icon-width-close: 1.25rem
    }
}

@media(min-width: 700px) {
    .c-publication_layout {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 1fr auto;
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter);
        grid-template-areas: "thumbnail heading heading" "thumbnail subtitle author" "thumbnail content content"
    }
}

@media(max-width: 699px) {
    .c-publication_thumbnail {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: var(--header-height) clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)));
        min-height: 50svh;
        margin-left: calc(-1*var(--grid-margin));
        margin-right: calc(-1*var(--grid-margin));
        background-color: #ebebeb
    }
}

@media(min-width: 700px) {
    .c-publication_thumbnail {
        grid-area: thumbnail
    }
}

.c-publication_thumbnail_img {
    position: relative
}

.c-publication_thumbnail_img[style] {
    aspect-ratio: var(--width)/var(--height);
    height: auto
}

@media(max-width: 699px) {
    .c-publication_thumbnail_img {
        max-width: 25rem
    }
}

@media(min-width: 700px) {
    .c-publication_thumbnail_img {
        position: sticky;
        top: 1.25rem
    }

    .c-dialog .c-publication_thumbnail_img {
        top: 0
    }
}

.c-publication_heading {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-md-desktop)))
}

@media(min-width: 700px) {
    .c-publication_heading {
        grid-area: heading
    }
}

@media(max-width: 699px) {
    .c-publication_title {
        margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-md-desktop)))
    }
}

@media(max-width: 699px) {
    .c-publication_button {
        margin-top: 1.5rem
    }
}

@media(min-width: 700px) {
    .c-publication_button {
        margin-top: 2rem
    }
}

@media(min-width: 700px) {
    .c-publication_subtitle {
        grid-area: subtitle
    }
}

.c-publication_author {
    display: flex;
    justify-content: flex-end
}

@media(max-width: 999px) {
    .c-publication_author {
        display: none
    }
}

@media(min-width: 1000px) {
    .c-publication_author {
        grid-area: author
    }
}

@media(min-width: 700px) {
    .c-publication_content {
        grid-area: content
    }
}

@media(min-width: 700px) {
    .c-publication_samples {
        position: relative
    }
}

.c-publication_samples_title {
    margin-bottom: calc(clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop)))*1)
}

@media(max-width: 699px) {
    .c-team-member#modal {
        padding-bottom: 6.25rem
    }
}

@media(min-width: 700px) {
    .c-team-member#modal {
        display: grid;
        grid-template-rows: auto 1fr;
        min-height: 100%
    }
}

@media(min-width: 700px) {
    .c-team-member_layout {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 1fr auto;
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter);
        grid-template-areas: "thumbnail heading heading" "thumbnail offices email" "thumbnail content content"
    }
}

@media(max-width: 699px) {
    .c-team-member_thumbnail {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: var(--header-height) clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-xl-desktop)));
        min-height: 50svh;
        margin-left: calc(-1*var(--grid-margin));
        margin-right: calc(-1*var(--grid-margin));
        background-color: #ebebeb
    }
}

@media(min-width: 700px) {
    .c-team-member_thumbnail {
        grid-area: thumbnail
    }
}

@media(max-width: 699px) {
    .c-team-member_thumbnail_img {
        max-width: 25rem
    }
}

@media(min-width: 700px) {
    .c-team-member_thumbnail_img {
        position: sticky;
        top: 1.25rem
    }

    .c-dialog .c-team-member_thumbnail_img {
        top: 0
    }
}

.c-team-member_heading {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-md-desktop)))
}

@media(min-width: 700px) {
    .c-team-member_heading {
        grid-area: heading
    }
}

@media(max-width: 699px) {
    .c-team-member_title {
        margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-md-desktop)))
    }
}

@media(max-width: 699px) {
    .c-team-member_button {
        margin-top: 1.5rem
    }
}

@media(min-width: 700px) {
    .c-team-member_button {
        margin-top: 2rem
    }
}

@media(min-width: 700px) {
    .c-team-member_offices {
        grid-area: offices
    }
}

@media(min-width: 1000px) {
    .c-team-member_email {
        grid-area: email;
        display: flex;
        justify-content: flex-end
    }
}

@media(min-width: 700px) {
    .c-team-member_content {
        grid-area: content
    }
}

.c-team-member_quote {
    display: flex;
    align-items: center
}

@media(min-width: 700px) {
    .c-team-member_about {
        position: relative;
        grid-row-start: 2;
        margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop)))
    }
}

.c-team-member_about_title {
    margin-bottom: calc(clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop)))*1)
}

.c-quote {
    text-align: center;
    margin: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-lg-desktop))) 0 0 0
}

.c-quote_text {
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-size: var(--font-size-h3);
    font-weight: 300;
    line-height: 1.2
}

.c-quote_text {
    margin: 0;
    width: 100%
}

.c-quote_author {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-quote_author {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-quote_author {
    display: block;
    margin-top: 1.25rem;
    color: #a1a1a1
}

.c-map {
    position: relative;
    width: 100%
}

.c-map_container {
    width: 100%
}

@media(max-width: 999px) {
    .c-map_container {
        aspect-ratio: 3/4;
        min-height: 520px;
        max-height: 900px
    }
}

@media(min-width: 1000px) {
    .c-map_container {
        aspect-ratio: 9/5;
        min-height: 800px;
        max-height: 1100px
    }
}

.c-map_controls {
    position: absolute;
    top: 50%;
    right: 1.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    transform: translateY(-50%)
}

.c-map_controls_item {
    --button-background-color: white
}

.c-map_controls_item+.c-map_controls_item {
    margin-top: .3125rem
}

.c-map_marker {
    width: 0;
    height: 0;
    border: 8px solid #3d3c44;
    border-left-color: rgba(0, 0, 0, 0);
    border-right-color: rgba(0, 0, 0, 0);
    border-bottom-color: rgba(0, 0, 0, 0);
    transform: translateY(8px)
}

.c-map_marker::before {
    content: "";
    position: absolute;
    top: -16px;
    right: -12px;
    bottom: -8px;
    left: -12px
}

.c-map_infobox {
    position: absolute;
    color: #fff;
    background-color: #3d3c44;
    text-align: center;
    padding: 1rem 2rem;
    max-width: 12.5rem;
    clip-path: inset(100% 10% 0 10%);
    transition: clip-path .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: translate3d(-50%, calc(-100% - 8px), 0)
}

.c-map_infobox.is-visible {
    clip-path: inset(0 0 0 0)
}

.c-map_infobox_close {
    position: absolute;
    top: .375rem;
    right: .375rem;
    width: .75rem;
    height: .75rem;
    transform: rotate(-45deg)
}

.c-map_infobox_close::before,
.c-map_infobox_close::after {
    content: "";
    position: absolute;
    top: .375rem;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: currentColor
}

.c-map_infobox_close::after {
    transform: rotate(90deg)
}

.c-hero-home {
    position: relative;
    color: #fff;
    z-index: -1
}

@media(min-width: 700px)and (hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-hero-home {
        height: 190vh;
        margin-bottom: -100vh
    }
}

.c-hero-home_sticky {
    width: 100%
}

@media(max-width: 699px) {
    .c-hero-home_sticky {
        height: 90svh
    }
}

@media(min-width: 700px) {
    .c-hero-home_sticky {
        height: 100svh
    }
}

@media(min-width: 700px)and (hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-hero-home_sticky {
        position: sticky;
        top: 0;
        left: 0
    }
}

.c-hero-home_background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.c-hero-home_image,
.c-hero-home_video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.c-hero-home_inner {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%
}

.c-video {
    -o-object-fit: cover;
    object-fit: cover
}

.c-showreel {
    position: relative;
    display: flex;
    align-items: center;
    background-color: #fff;
    backface-visibility: visible;
    z-index: 2
}

@media(min-width: 700px)and (hover: hover) {
    .c-showreel {
        height: 100svh
    }

    .c-showreel::before {
        content: "";
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #fff;
        z-index: 1000
    }
}

@media(max-width: 699px), (hover: none) {
    .c-showreel {
        flex-direction: column;
        margin-top: calc(clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop)))*1)
    }
}

.c-showreel_title {
    display: flex;
    align-items: center;
    width: 100%
}

@media(min-width: 700px)and (hover: hover) {
    .c-showreel_title {
        justify-content: space-between
    }
}

@media(max-width: 699px), (hover: none) {
    .c-showreel_title {
        flex-direction: column;
        row-gap: .5em;
        margin-bottom: calc(clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop)))*1)
    }
}

.c-showreel_container {
    z-index: 1
}

@media(min-width: 700px)and (hover: hover) {
    .c-showreel_container {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%
    }
}

@media(max-width: 699px), (hover: none) {
    .c-showreel_container {
        position: relative;
        width: 100%;
        aspect-ratio: 8/5;
        max-width: 43.75rem
    }
}

.c-showreel_thumbnail {
    transition: opacity .25s, visibility 0s
}

.c-showreel.is-open .c-showreel_thumbnail {
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s, visibility .25s;
    pointer-events: none
}

@media(min-width: 700px)and (hover: hover) {
    .c-showreel_thumbnail {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%
    }
}

@media(max-width: 699px), (hover: none) {
    .c-showreel_thumbnail {
        position: relative;
        width: 100%;
        height: 100%
    }
}

.c-showreel_thumbnail_image,
.c-showreel_thumbnail_video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.c-showreel_button {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    z-index: 2;
    transition: opacity .25s, visibility 0s
}

.c-showreel_button::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
    z-index: 2
}

.c-showreel.is-open .c-showreel_button {
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s, visibility .25s;
    pointer-events: none
}

.c-showreel_button:focus-visible .c-showreel_button_container {
    outline: 2px auto currentColor;
    outline-offset: var(--focus-outline-offset, 5px)
}

html.is-safari .c-showreel_button:focus-visible .c-showreel_button_container {
    outline-style: dotted;
    outline-width: 4px
}

.c-showreel_button_inner {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-showreel_button_inner {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-showreel_button_inner {
    position: relative;
    padding: 1.75rem;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    clip-path: inset(calc(50% - var(--button-height) / 2) 0 round 50%);
    background-color: rgba(36, 28, 24, .35);
    z-index: 1
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-showreel_button_inner {
        transition: clip-path .5s cubic-bezier(0.23, 1, 0.32, 1)
    }

    .c-showreel_button:hover .c-showreel_button_inner {
        clip-path: inset(0 0 round 50%)
    }
}

.c-showreel_button_label-container {
    position: relative;
    height: 1.5em;
    clip-path: inset(0)
}

.c-showreel_button_label {
    display: inline-block
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-showreel_button_label {
        transition: transform .5s cubic-bezier(0.23, 1, 0.32, 1);
        transition-delay: .1s
    }

    .c-showreel_button:hover .c-showreel_button_label {
        transform: translate3d(0, -100%, 0);
        transition-delay: 0s
    }
}

.c-showreel_button_icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    transform: translate3d(0, 100%, 0)
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-showreel_button_icon {
        transition: transform .5s cubic-bezier(0.23, 1, 0.32, 1)
    }

    .c-showreel_button:hover .c-showreel_button_icon {
        transform: translate3d(0, 0, 0);
        transition-delay: .1s
    }
}

.c-showreel_close {
    position: absolute;
    top: 0;
    right: 0;
    padding: 30px;
    z-index: 1
}

@media(max-width: 999px) {
    .c-showreel_close {
        top: 10px;
        right: 10px;
        padding: 10px;
        border-radius: 8px
    }
}

.c-showreel_close_inner {
    position: relative;
    display: block;
    width: 24px;
    height: 24px
}

.c-showreel_close_icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.c-showreel_close_icon:nth-child(1) {
    --extra-delay: 0.2s;
    transform: rotate(-45deg)
}

.c-showreel_close_icon:nth-child(2) {
    --extra-delay: 0s;
    transform: rotate(-135deg)
}

@media(hover: none), (prefers-reduced-motion: reduce) {
    .c-showreel_close_icon:nth-child(2) {
        display: none
    }
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    html.is-first-loaded .c-showreel_close_icon {
        transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1) var(--extra-delay, 0s)
    }

    .c-showreel_close:hover .c-showreel_close_icon:nth-child(1) {
        --extra-delay: 0s;
        transform: rotate(45deg)
    }

    .c-showreel_close:hover .c-showreel_close_icon:nth-child(2) {
        --extra-delay: 0.2s;
        transform: rotate(-45deg)
    }
}

.c-showreel_close_line {
    position: absolute
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    html.is-first-loaded .c-showreel_close_line {
        transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1) calc(var(--line-delay, 0s) + var(--extra-delay, 0s))
    }
}

.c-showreel_close_line::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: currentColor;
    transform-origin: top left;
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition-delay: calc(var(--item-delay, 0s) + var(--extra-delay, 0s))
}

.c-showreel_close_line:nth-child(1) {
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px
}

.c-showreel_close_line:nth-child(2) {
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-showreel_close_icon:nth-child(1) .c-showreel_close_line:nth-child(1) {
        --line-delay: 0.1s;
        transform-origin: top right
    }

    .c-showreel_close_icon:nth-child(1) .c-showreel_close_line:nth-child(2) {
        transform-origin: bottom left
    }

    .c-showreel_close:hover .c-showreel_close_icon:nth-child(1) .c-showreel_close_line:nth-child(1) {
        transform: scale3d(0, 1, 1)
    }

    .c-showreel_close:hover .c-showreel_close_icon:nth-child(1) .c-showreel_close_line:nth-child(2) {
        transform: scale3d(1, 0, 1)
    }

    .c-showreel_close_icon:nth-child(2) .c-showreel_close_line:nth-child(1) {
        --line-delay: 0.1s;
        transform-origin: top right;
        transform: scale3d(0, 1, 1)
    }

    .c-showreel_close_icon:nth-child(2) .c-showreel_close_line:nth-child(2) {
        transform-origin: top left;
        transform: scale3d(1, 0, 1)
    }

    .c-showreel_close:hover .c-showreel_close_icon:nth-child(2) .c-showreel_close_line {
        transform: scale3d(1, 1, 1)
    }
}

.c-showreel_modal {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    color: #fff;
    background-color: #000;
    visibility: hidden;
    z-index: -1
}

html.is-first-loaded .c-showreel_modal {
    transition: visibility .3s
}

.c-showreel.is-open .c-showreel_modal {
    visibility: visible;
    transition: visibility 0s
}

.c-showreel_player {
    width: 100%;
    height: 100%
}

.c-logo {
    position: relative;
    width: 100%;
    aspect-ratio: 1200/210;
    overflow: visible
}

.c-logo_svg {
    fill: none
}

.c-logo_path {
    fill: currentColor
}

@media(prefers-reduced-motion: no-preference) {
    .c-logo_path {
        opacity: 0;
        transform: translate3d(0, 40%, 0)
    }

    html.is-first-loaded .c-logo_path {
        transition: transform 1000ms cubic-bezier(0.165, 0.84, 0.44, 1), opacity 1000ms cubic-bezier(0.165, 0.84, 0.44, 1);
        transition-delay: calc(var(--index)*.04s + 100ms)
    }

    html.is-ready .c-logo_path {
        opacity: 1;
        transform: translate3d(0, 0, 0)
    }
}

.c-projects-list_item {
    position: relative;
    text-align: center
}

.c-projects-list_item+.c-projects-list_item {
    margin-top: -1px
}

@media(hover: hover)and (prefers-reduced-motion: no-preference)and (min-width: 1000px) {

    .c-projects-list_item::before,
    .c-projects-list_item::after {
        content: "";
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #ebebeb;
        transform: scale(0, 1)
    }

    html.is-first-loaded .c-projects-list_item::before,
    html.is-first-loaded .c-projects-list_item::after {
        transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-projects-list_item::before {
        top: 0
    }

    .c-projects-list_item::after {
        bottom: 0
    }

    .c-projects-list_item:hover::before,
    .c-projects-list_item:hover::after {
        transform: scale(1, 1)
    }
}

@media(min-width: 1000px) {
    .c-projects-list_item {
        display: grid;
        grid-template-columns: minmax(100px, 1fr) auto minmax(100px, 1fr);
        grid-template-areas: "images title .";
        -moz-column-gap: var(--grid-gutter);
        column-gap: var(--grid-gutter);
        align-items: center
    }
}

.c-projects-list_title sup {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-projects-list_title sup {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-projects-list_title sup {
    vertical-align: top
}

@media(min-width: 1000px) {
    .c-projects-list_title {
        grid-area: title
    }
}

@media(prefers-reduced-motion: reduce) {
    .c-projects-list_item:hover .c-projects-list_title {
        text-decoration: underline;
        text-underline-offset: .07em;
        text-decoration-thickness: 2px
    }
}

.c-projects-list_link {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center
}

@media(hover: none), (max-width: 999px) {
    .c-projects-list_label {
        display: none
    }
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-projects-list_label {
        transition: opacity .25s, transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .25s
    }

    .c-projects-list_link:not(:hover) .c-projects-list_label {
        opacity: 0;
        transform: translate3d(0, -1.25rem, 0);
        visibility: hidden
    }

    .c-projects-list_link:hover .c-projects-list_label {
        transition: opacity .25s, transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .25s
    }
}

.c-projects-list_images {
    display: none
}

@media(min-width: 1200px)and (hover: hover) {
    .c-projects-list_images {
        grid-area: images;
        display: flex;
        align-items: flex-start;
        padding: .5rem 0
    }
}

.c-projects-list_image {
    aspect-ratio: 3/2;
    max-width: 1.2em;
    background-color: #f5f5f5
}

.c-projects-list_image+.c-projects-list_image {
    margin-left: .5rem
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-projects-list_image {
        opacity: 0;
        transform: scale(0.8);
        transition: opacity .3s, transform .5s cubic-bezier(0.165, 0.84, 0.44, 1);
        transition-delay: calc(var(--index, 0)*.04s)
    }

    .c-projects-list_item:hover .c-projects-list_image {
        transform: scale(1);
        opacity: 1
    }
}

@media(hover: hover)and (prefers-reduced-motion: reduce) {
    .c-projects-list_image {
        opacity: 0
    }

    .c-projects-list_item:hover .c-projects-list_image {
        opacity: 1
    }
}

.c-player {
    position: relative;
    color: #fff
}

.c-player::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100px;
    background-color: rgba(0, 0, 0, .6);
    -webkit-mask-image: -webkit-linear-gradient(bottom, rgb(0, 0, 0), rgba(0, 0, 0, 0))
}

.c-player_video {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    cursor: pointer
}

.c-player_controls {
    position: absolute;
    bottom: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 1.25rem;
    pointer-events: none;
    z-index: 1
}

.c-player.has-native-controls .c-player_controls {
    display: none
}

.c-player_controls_item {
    margin: 0 .25rem;
    pointer-events: auto
}

.c-player_button {
    position: relative;
    width: 40px;
    height: 40px
}

.c-player_button_inner {
    display: block;
    width: 100%;
    height: 100%
}

.c-player_button_icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    animation: controlIconSwitch .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-player.is-playing .c-player_button_icon.-play {
    display: none
}

.c-player:not(.is-playing) .c-player_button_icon.-pause {
    display: none
}

.c-player.is-muted .c-player_button_icon.-mute {
    display: none
}

.c-player:not(.is-muted) .c-player_button_icon.-unmute {
    display: none
}

@keyframes controlIconSwitch {
    0% {
        transform: scale(0.5);
        opacity: 0
    }

    100% {
        transform: scale(1);
        opacity: 1
    }
}

.c-player_timeline {
    position: relative;
    width: 300px
}

.c-player_timeline_input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: rgba(0, 0, 0, 0);
    cursor: pointer;
    width: 100%;
    margin: 0
}

.c-player_timeline_input:focus {
    outline: none
}

.c-player_timeline_input::-webkit-slider-runnable-track {
    background-color: rgba(0, 0, 0, 0);
    border-radius: 0rem;
    height: 100%
}

.c-player_timeline_input::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    margin-top: 0px;
    background-color: rgba(0, 0, 0, 0);
    border-radius: 0rem;
    height: 100%;
    width: 2px
}

.c-player_timeline_input:focus::-webkit-slider-thumb {
    outline: 3px solid rgba(0, 0, 0, 0);
    outline-offset: .125rem
}

.c-player_timeline_input::-moz-range-track {
    background-color: rgba(0, 0, 0, 0);
    border-radius: 0rem;
    height: 100%
}

.c-player_timeline_input::-moz-range-thumb {
    background-color: rgba(0, 0, 0, 0);
    border: none;
    border-radius: 0rem;
    height: 100%;
    width: 2px
}

.c-player_timeline_input:focus::-moz-range-thumb {
    outline: 3px solid rgba(0, 0, 0, 0);
    outline-offset: .125rem
}

.c-player_timeline_bar {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    height: 28px;
    pointer-events: none;
    overflow: hidden;
    padding: 8px 6px
}

.c-player_timeline_progress {
    position: absolute;
    top: 50%;
    left: 6px;
    width: calc(100% - 12px);
    height: 1px;
    background-color: rgba(255, 255, 255, .3);
    transform: translateY(-50%)
}

@media(hover: hover) {
    .c-player_timeline_progress {
        transition: height .25s cubic-bezier(0.165, 0.84, 0.44, 1)
    }

    .c-player_timeline:hover .c-player_timeline_progress {
        height: 3px
    }
}

.c-player_timeline_progress::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform-origin: top left;
    transform: scale(var(--progress, 0), 1);
    background-color: #fff
}

.c-player_timeline_handle-container {
    width: 100%;
    height: 12px
}

.c-player_timeline_handle {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    transform: translate3d(calc((1 - var(--progress, 0)) * -100%), 0, 0)
}

.c-player_timeline_handle::after {
    content: "";
    width: 12px;
    height: 12px;
    margin-right: -6px;
    background-color: #ebebeb;
    border-radius: 6px;
    transform: scale(0, 0);
    transition: transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

@media(hover: hover) {
    .c-player_timeline:hover .c-player_timeline_handle::after {
        transform: scale(1, 1)
    }
}

.c-player_timeline_input:focus-visible+.c-player_timeline_bar .c-player_timeline_handle::after {
    transform: scale(1, 1);
    outline: 2px auto currentColor;
    outline-offset: var(--focus-outline-offset, 5px)
}

html.is-safari .c-player_timeline_input:focus-visible+.c-player_timeline_bar .c-player_timeline_handle::after {
    outline-style: dotted;
    outline-width: 4px
}

.c-mute-cta {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center
}

.c-mute-cta_line {
    position: relative;
    width: 2px;
    height: 10px;
    margin-top: -8px
}

.c-mute-cta_line:not(:last-of-type) {
    margin-right: 2px
}

.c-mute-cta_line::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: currentColor
}

.c-mute-cta_line_moving {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform-origin: bottom left;
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-mute-cta_line_moving::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 2px;
    left: 0;
    width: 100%;
    transform-origin: bottom left;
    background-color: currentColor;
    animation: soundTogglerLines 1.2s linear infinite
}

.c-mute-cta_line:nth-child(1) .c-mute-cta_line_moving::before {
    animation-delay: .2s
}

.c-mute-cta_line:nth-child(3) .c-mute-cta_line_moving::before {
    animation-delay: .4s
}

.c-mute-cta.-muted .c-mute-cta_line_moving::before {
    animation-play-state: paused
}

.c-player.is-muted .c-mute-cta_line_moving::before,
.c-player:not(.is-playing) .c-mute-cta_line_moving::before {
    animation-play-state: paused
}

.c-player.is-muted .c-mute-cta_line_moving {
    transform: scaleY(0.2)
}

@keyframes soundTogglerLines {
    0% {
        transform: scaleY(0.2)
    }

    50% {
        transform: scaleY(1)
    }

    100% {
        transform: scaleY(0.2)
    }
}

.c-projects-menu {
    position: fixed;
    left: 0;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    justify-content: center;
    pointer-events: none;
    text-align: center;
    z-index: 100;
    visibility: hidden
}

html.is-first-loaded .c-projects-menu,
html.is-ready.is-next-project-visible .c-projects-menu {
    transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), visibility .75s
}

html.is-ready .c-projects-menu {
    transition: transform .75s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0s
}

html.is-ready:not(.is-next-project-visible) .c-projects-menu {
    transform: translate3d(0, 0, 0);
    visibility: visible
}

@media(max-width: 699px) {
    .c-projects-menu {
        bottom: 1.75rem;
        align-items: flex-end;
        padding: 0 calc(var(--grid-margin) + 1rem);
        transform: translate3d(0, calc(var(--header-height) + 1.75rem), 0)
    }
}

@media(min-width: 700px) {
    .c-projects-menu {
        top: 1.25rem;
        align-items: flex-start;
        transform: translate3d(0, calc(-1 * var(--header-height) - 1.25rem), 0)
    }
}

.c-projects-menu_prev,
.c-projects-menu_next {
    display: flex
}

.c-projects-menu_prev {
    grid-column: 1/2;
    grid-row: 1/2;
    justify-content: flex-end
}

.c-projects-menu_next {
    grid-column: 3/4;
    grid-row: 1/2;
    justify-content: flex-start
}

.c-projects-menu_prev_btn,
.c-projects-menu_next_btn {
    pointer-events: auto
}

@media(max-width: 999px) {

    .c-projects-menu_prev_btn .c-button_label,
    .c-projects-menu_next_btn .c-button_label {
        display: none
    }

    .c-projects-menu_prev_btn .c-button_icon,
    .c-projects-menu_next_btn .c-button_icon {
        margin: 0
    }

    .c-projects-menu_prev_btn .c-button_inner,
    .c-projects-menu_next_btn .c-button_inner {
        padding: 0;
        width: var(--button-height)
    }
}

@media(min-width: 1000px) {

    .c-projects-menu_prev_btn,
    .c-projects-menu_next_btn {
        min-width: 11.25rem
    }
}

.c-projects-menu_wrap {
    position: relative;
    grid-column: 2/3;
    grid-row: 1/2
}

@media(min-width: 700px) {
    .c-projects-menu_wrap {
        min-width: 23.75rem
    }
}

.c-projects-menu_wrap ::-webkit-scrollbar {
    width: 3px
}

.c-projects-menu_wrap ::-webkit-scrollbar-track {
    margin-top: calc(var(--button-height)/2);
    margin-bottom: calc(var(--button-height)/2)
}

.c-projects-menu_wrap ::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0);
    border-radius: 2px
}

html.has-projects-menu-open .c-projects-menu_wrap ::-webkit-scrollbar-thumb {
    background: #241c18
}

html.is-first-loaded .c-projects-menu_wrap {
    transition: opacity .3s;
    opacity: 1
}

html.is-first-loaded.is-projects-menu-hidden .c-projects-menu_wrap {
    opacity: 0;
    visibility: hidden;
    transition: opacity .3s, visibility .3s
}

.c-projects-menu_current {
    position: absolute;
    left: 0;
    width: 100%;
    display: flex;
    align-items: center;
    -moz-column-gap: .5rem;
    column-gap: .5rem;
    height: var(--button-height);
    transition: opacity .25s, visibility 0s;
    z-index: 1
}

@media(max-width: 699px) {
    .c-projects-menu_current {
        bottom: 0
    }
}

@media(min-width: 700px) {
    .c-projects-menu_current {
        top: 0
    }
}

html.has-projects-menu-open .c-projects-menu_current {
    visibility: hidden;
    opacity: 0;
    transition: opacity .25s, visibility .25s
}

.c-projects-menu_current::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ebebeb;
    clip-path: inset(0 calc((1 - var(--progress, 0)) * (100% - var(--index-width, var(--button-height)))) 0 0 round calc(var(--index-width, var(--button-height)) / 2));
    z-index: -1
}

.c-projects-menu_index {
    padding: 0 .5rem;
    min-width: var(--button-height)
}

.c-projects-menu_title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1 1 auto
}

.c-projects-menu_icon {
    display: flex;
    justify-content: center;
    flex: 0 0 var(--button-height)
}

@media(max-width: 699px) {
    .c-projects-menu_icon {
        transform: rotate(180deg)
    }
}

.c-projects-menu_toggler {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    z-index: 1;
    pointer-events: auto
}

.c-projects-menu_container {
    position: relative;
    pointer-events: none;
    padding: 1px 3px;
    z-index: 0
}

.c-projects-menu_container::before {
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: calc(var(--button-height)/2);
    transition: height .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    z-index: -2
}

html:not(.has-projects-menu-open) .c-projects-menu_container::before {
    height: var(--button-height)
}

@media(max-width: 699px) {
    .c-projects-menu_container::before {
        bottom: 0
    }
}

@media(min-width: 700px) {
    .c-projects-menu_container::before {
        top: 0
    }
}

.c-projects-menu_container::after {
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 100%;
    border: 1px solid #ebebeb;
    background-color: #fff;
    border-radius: calc(var(--button-height)/2);
    transition: height .3s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow .3s cubic-bezier(0.165, 0.84, 0.44, 1), background-color .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    box-shadow: 0px 502px 141px 0px rgba(36, 28, 24, 0), 0px 321px 129px 0px rgba(36, 28, 24, .01), 0px 181px 108px 0px rgba(36, 28, 24, .03), 0px 80px 80px 0px rgba(36, 28, 24, .05), 0px 20px 44px 0px rgba(36, 28, 24, .06);
    z-index: -1
}

html:not(.has-projects-menu-open) .c-projects-menu_container::after {
    height: var(--button-height);
    box-shadow: none;
    background-color: rgba(255, 255, 255, .35)
}

@media(max-width: 699px) {
    .c-projects-menu_container::after {
        bottom: 0
    }
}

@media(min-width: 700px) {
    .c-projects-menu_container::after {
        top: 0
    }
}

.c-projects-menu_inner {
    position: relative;
    pointer-events: none;
    max-height: calc(100svh - 4.75rem);
    scrollbar-gutter: both-edges;
    overflow: auto
}

html.is-first-loaded .c-projects-menu_inner {
    transition: clip-path .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

html.has-projects-menu-open .c-projects-menu_inner {
    pointer-events: auto;
    clip-path: inset(0 0 0 0 round calc(var(--button-height) / 2))
}

@media(max-width: 699px) {
    .c-projects-menu_inner {
        clip-path: inset(calc(100% - var(--button-height)) 0 0 0 round calc(var(--button-height) / 2))
    }
}

@media(min-width: 700px) {
    .c-projects-menu_inner {
        clip-path: inset(0 0 calc(100% - var(--button-height)) 0 round calc(var(--button-height) / 2))
    }
}

.c-projects-menu_list {
    position: relative;
    display: flex;
    flex-direction: column;
    background-color: #fff;
    transition: opacity .3s cubic-bezier(0.165, 0.84, 0.44, 1);
    padding: 1rem .5rem !important;
    overflow: hidden;
    opacity: 0;
    z-index: 0
}

.c-projects-menu_list::before {
    content: "";
    position: absolute;
    top: 0;
    left: .5rem;
    width: calc(100% - 1rem);
    height: var(--item-height, 0px);
    background-color: #241c18;
    transform: translate3d(0, var(--item-offset, 0px), 0);
    clip-path: inset(0 round calc(var(--button-height) / 2));
    z-index: -1
}

html.is-first-loaded .c-projects-menu_list::before {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), height .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

html.has-projects-menu-open .c-projects-menu_list {
    opacity: 1
}

.c-projects-menu_item {
    width: 100%;
    text-align: center;
    transform: translate3d(0, 1em, 0);
    mix-blend-mode: difference;
    color: #fff;
    opacity: 0
}

html.is-first-loaded .c-projects-menu_item {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

html.has-projects-menu-open .c-projects-menu_item {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-delay: calc(var(--index, 0)*.02s + var(--extra-delay, 0s))
}

@media(max-width: 699px) {
    .c-projects-menu_item {
        --extra-delay: 0.1s
    }
}

.c-projects-menu_link {
    display: block
}

.c-projects-menu_item {
    text-align: center
}

.c-cinemagraph {
    position: relative;
    height: 500vh;
    min-height: 100svh;
    margin-top: -100svh;
    margin-bottom: -100svh
}

.c-cinemagraph_sticky {
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden
}

.c-cinemagraph_background {
    position: relative;
    width: 100%;
    height: 110%;
    background-color: #241c18
}

.c-cinemagraph_video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.c-audio-toggler {
    --button-background-color: white
}

html.is-first-loaded .c-audio-toggler {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.c-audio-toggler[disabled] {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
    transition-timing-function: cubic-bezier(0.895, 0.03, 0.685, 0.22)
}

.c-audio-toggler_icon {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 0;
    opacity: .3;
    transition: opacity .3s
}

.c-audio-toggler:not([disabled]) .c-audio-toggler_icon {
    opacity: 1
}

.c-audio-toggler_svg {
    width: 25px;
    height: 25px
}

.c-audio-toggler_svg path {
    stroke: #000;
    stroke-width: 1.5;
    stroke-linecap: round;
    fill: none
}

.c-next-project {
    position: relative
}

.c-next-project_image-container {
    height: calc(100*var(--svh, 1svh))
}

.c-next-project_image-sticky {
    position: sticky;
    top: 0;
    width: 100%;
    height: calc(100*var(--svh, 1svh))
}

.c-next-project_image-sticky::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(36, 28, 24, .8);
    opacity: var(--progress, 0);
    z-index: 1
}

.c-next-project_wrapper {
    position: relative;
    background-color: #fff;
    height: calc(250*var(--svh, 1svh));
    z-index: 1
}

.c-next-project_hero {
    position: sticky;
    top: 0
}

.c-nav {
    line-height: 0
}

@media(hover: hover) {
    .c-nav {
        pointer-events: none
    }
}

.c-menu_primary_item {
    padding: .1em var(--grid-gutter) .2em var(--grid-gutter)
}

.c-nav_link {
    --focus-outline-offset: 1px;
    display: inline-block;
    pointer-events: auto
}

@media(hover: hover)and (prefers-reduced-motion: no-preference) {
    .c-nav_link {
        display: inline-block;
        transform: translate3d(0, 0, 0);
        backface-visibility: visible;
        transition: opacity .3s
    }

    .c-nav:hover .c-nav_link:not(:hover) {
        opacity: .4
    }
}

@media(hover: hover)and (prefers-reduced-motion: reduce) {
    .c-nav_link:hover {
        text-decoration: underline;
        text-decoration-thickness: 2px;
        text-underline-offset: .07em
    }
}

.c-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding: 1.25rem;
    background-color: #fff;
    transition: opacity .3s;
    opacity: 1;
    z-index: 500
}

html.is-loaded .c-loader {
    opacity: 0;
    pointer-events: none
}

.c-loader_spinner {
    display: block;
    width: 16px;
    height: 16px;
    border: 2px solid;
    border-radius: 50%;
    border-top-color: rgba(0, 0, 0, 0);
    border-left-color: rgba(0, 0, 0, 0);
    animation: spin .3s linear infinite
}

html.is-ready .c-loader_spinner {
    animation-play-state: paused
}

.c-wysiwyg {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-wysiwyg {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-wysiwyg>*+* {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop)/14.4*1vw, calc(0.0625rem * var(--spacing-md-desktop)))
}

.c-wysiwyg-first-element,
.c-wysiwyg>:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important
}

.c-wysiwyg-last-element,
.c-wysiwyg>:last-child {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important
}

.c-wysiwyg h1,
.c-wysiwyg h2,
.c-wysiwyg h3,
.c-wysiwyg h4,
.c-wysiwyg h5,
.c-wysiwyg h6 {
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    margin-top: 1.5em;
    margin-bottom: 1em
}

.c-wysiwyg h1,
.c-wysiwyg h2,
.c-wysiwyg h3,
.c-wysiwyg h4,
.c-wysiwyg h5,
.c-wysiwyg h6 {
    font-size: var(--font-size-h3);
    font-weight: 300;
    line-height: 1.2
}

.c-wysiwyg ul,
.c-wysiwyg ol {
    list-style: none;
    padding-left: 0
}

.c-wysiwyg ul>li,
.c-wysiwyg ol>li {
    position: relative;
    padding-left: 1.5em
}

.c-wysiwyg ul>li::before {
    content: "";
    position: absolute;
    left: 0;
    top: calc(50% - 3px);
    width: 6px;
    height: 6px;
    background-color: currentColor;
    border-radius: 50%
}

.c-wysiwyg ol {
    counter-reset: counter
}

.c-wysiwyg ol>li {
    counter-increment: counter
}

.c-wysiwyg ol>li::before {
    content: counter(counter);
    position: absolute;
    left: 0
}

.c-wysiwyg a {
    color: #241c18;
    text-decoration: underline;
    text-decoration-color: rgba(36, 28, 24, .2);
    text-decoration-thickness: 2px
}

.c-wysiwyg a:focus-visible {
    text-decoration-color: #241c18
}

@media(hover: hover) {
    .c-wysiwyg a {
        transition: text-decoration-color .25s
    }

    .c-wysiwyg a:hover {
        text-decoration-color: #241c18
    }
}

.c-wysiwyg img {
    width: 100%
}

.c-wysiwyg iframe {
    display: block;
    margin-left: auto;
    margin-right: auto
}

.c-wysiwyg iframe:not([width]) {
    width: 100%
}

.c-wysiwyg iframe:not([height]) {
    height: auto
}

.c-wysiwyg table {
    width: 100%
}

.c-wysiwyg caption {
    font-family: "Canela Text", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-weight: 400;
    font-size: var(--font-size-body-small);
    line-height: 1.5
}

@media(min-width: 1400px) {
    .c-wysiwyg caption {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

.c-wysiwyg caption {
    margin: 1em 0
}

.c-wysiwyg blockquote {
    font-family: "Canela", Iowan Old Style, Apple Garamond, Baskerville, Times New Roman, Droid Serif, Times, Source Serif Pro, serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol;
    font-size: var(--font-size-h3);
    font-weight: 300;
    line-height: 1.2
}

.c-wysiwyg blockquote {
    quotes: "“" "”" "’" "’";
    padding: 0
}

.c-wysiwyg blockquote p::before {
    content: open-quote
}

.c-wysiwyg blockquote p::after {
    content: close-quote
}

.c-wysiwyg blockquote+p {
    padding-top: 0
}

.c-404 {
    position: relative;
    display: grid;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: calc(100*var(--svh, 1svh));
    padding: 1.875rem var(--grid-margin)
}

@media(max-width: 999px) {
    .c-404 {
        grid-template-rows: 1fr auto 1fr;
        row-gap: 3.75rem
    }
}

.c-404_inner {
    max-width: 15rem;
    margin: 0 auto
}

@media(max-width: 999px) {
    .c-404_inner {
        height: 100%;
        grid-row: 2/3
    }
}

.c-404_visual {
    width: 100%;
    height: 100%
}

@media(min-width: 1000px) {
    .c-404_visual {
        position: absolute;
        top: 0;
        left: 0;
        padding: 1.25rem;
        z-index: -1
    }
}

@media(max-width: 999px) {
    .c-404_visual {
        display: flex;
        align-items: flex-end;
        grid-row: 3/4
    }
}

.c-404_svg {
    width: 100%
}

@media(min-width: 1000px) {
    .c-404_svg {
        height: 100%
    }
}

@media(min-width: 1000px) {
    .c-404_svg svg {
        width: 100%;
        height: 100%;
        -o-object-fit: contain;
        object-fit: contain
    }
}

.c-404_button {
    min-width: 11.25rem
}

.c-skip-link {
    position: fixed;
    top: calc(clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop)))*1);
    left: 50%;
    opacity: 0;
    transform: translate3d(-50%, -100%, 0);
    z-index: 200;
    white-space: nowrap;
    pointer-events: none
}

.c-skip-link.-absolute {
    position: absolute;
    z-index: 1;
    top: 0
}

html.is-first-loaded .c-skip-link {
    transition: opacity .3s cubic-bezier(0.165, 0.84, 0.44, 1), transform .3s cubic-bezier(0.165, 0.84, 0.44, 1)
}

@media(prefers-reduced-motion) {
    html.is-first-loaded .c-skip-link {
        transition: none
    }
}

.c-skip-link:focus-within {
    pointer-events: all;
    opacity: 1;
    transform: translate3d(-50%, 0, 0)
}

@media(max-width: 699px) {
    .c-skip-link {
        font-size: var(--font-size-body-small);
        line-height: 1.5
    }
}

@media(max-width: 699px)and (min-width: 1400px) {
    .c-skip-link {
        font-size: calc(1.2*var(--font-size-body-small))
    }
}

#cc-main {}

#cc-main .cm {
    box-shadow: none !important;
    border: 1px solid #ebebeb
}

.c-link_label {
    position: relative;
    display: inline-block
}

.c-link_label::before {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: currentColor;
    transform: scaleX(0);
    transform-origin: right center
}

html.is-first-loaded .c-link_label::before {
    transition: transform .3s cubic-bezier(0.23, 1, 0.32, 1)
}

a:hover .c-link_label::before,
button:hover .c-link_label::before,
.c-link:hover .c-link_label::before {
    transform: scaleX(1);
    transform-origin: left center
}

.c-copy-clipboard {
    position: fixed;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    padding: 1rem;
    z-index: 350;
    pointer-events: none
}

.c-copy-clipboard_inner {
    position: relative;
    display: flex;
    align-items: center;
    color: #fff;
    background-color: #241c18;
    padding: 1rem;
    min-height: 3.75rem;
    border-radius: 4px;
    box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, .1);
    transform: translate3d(0, calc(100% + var(--grid-margin) + 1px), 0);
    visibility: hidden
}

html.is-first-loaded .c-copy-clipboard_inner {
    transition: transform .75s cubic-bezier(0.77, 0, 0.175, 1), visibility .75s
}

html.has-copied-to-clipboard .c-copy-clipboard_inner {
    visibility: visible;
    transform: translate3d(0, 0, 0);
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0s
}

.c-copy-clipboard_icon {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 1.5rem;
    padding-right: 1rem;
    margin-right: 1rem;
    border-right: 1px solid rgba(255, 255, 255, .1)
}

.u-2\:1::before {
    padding-bottom: 50%
}

.u-4\:3::before {
    padding-bottom: 75%
}

.u-16\:9::before {
    padding-bottom: 56.25%
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

@media(min-width: 700px) {
    .u-gc-1\/2\@from-sm {
        --gc-start: 1;
        --gc-end: 2
    }
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

@media(min-width: 700px) {
    .u-gc-2\/3\@from-sm {
        --gc-start: 2;
        --gc-end: 3
    }
}

@media(min-width: 700px) {
    .u-gc-2\/12\@from-sm {
        --gc-start: 2;
        --gc-end: 12
    }
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

@media(min-width: 1000px) {
    .u-gc-1\/2\@from-md {
        --gc-start: 1;
        --gc-end: 2
    }
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

@media(min-width: 1000px) {
    .u-gc-2\/3\@from-md {
        --gc-start: 2;
        --gc-end: 3
    }
}

@media(min-width: 1000px) {
    .u-gc-4\/10\@from-md {
        --gc-start: 4;
        --gc-end: 10
    }
}

@media(min-width: 1000px) {
    .u-gc-4\/13\@from-md {
        --gc-start: 4;
        --gc-end: 13
    }
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-gc-1\/6 {
    --gc-start: 1;
    --gc-end: 6
}

.u-gc-1\/7 {
    --gc-start: 1;
    --gc-end: 7
}

.u-gc-7\/13 {
    --gc-start: 7;
    --gc-end: 13
}

.u-gc-8\/13 {
    --gc-start: 8;
    --gc-end: 13
}

.u-max-w280 {
    max-width: 17.5rem
}

.u-max-w350 {
    max-width: 21.875rem
}

.u-max-w380 {
    max-width: 23.75rem
}

.u-opacity-50 {
    opacity: .5
}

.u-text-center {
    text-align: center
}

.u-text-right {
    text-align: right
}

.u-background-light {
    background-color: #fff
}

.u-background-dark {
    background-color: #241c18
}

.u-screen-reader-text {
    position: absolute !important;
    overflow: hidden;
    clip: rect(0 0 0 0);
    margin: 0;
    padding: 0;
    width: 1px;
    height: 1px;
    border: 0
}

@media not print {
    .u-screen-reader-text\@screen {
        position: absolute !important;
        overflow: hidden;
        clip: rect(0 0 0 0);
        margin: 0;
        padding: 0;
        width: 1px;
        height: 1px;
        border: 0
    }
}

.u-screen-reader-text.-focusable:focus,
.u-screen-reader-text.-focusable:active {
    clip: auto;
    width: auto;
    height: auto
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

@media(min-width: 1000px) {
    .u-padding-top-header\@from-md {
        padding-top: var(--header-height) !important
    }
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-padding-top-2xl {
    padding-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-2xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-padding-bottom-3xl {
    padding-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-top-2xs {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xs-mobile)), var(--spacing-2xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xs-desktop))) !important
}

.u-margin-top-md {
    margin-top: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-top-lg {
    margin-top: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-top-xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-xl-mobile)), var(--spacing-xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xl-desktop))) !important
}

.u-margin-top-2xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-top-3xl {
    margin-top: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

.u-margin-bottom-xs {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-xs-mobile)), var(--spacing-xs-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-xs-desktop))) !important
}

.u-margin-bottom-sm {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-sm-mobile)), var(--spacing-sm-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-sm-desktop))) !important
}

.u-margin-bottom-md {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-md-mobile)), var(--spacing-md-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-md-desktop))) !important
}

.u-margin-bottom-lg {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-lg-mobile)), var(--spacing-lg-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-lg-desktop))) !important
}

.u-margin-bottom-2xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-2xl-mobile)), var(--spacing-2xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-2xl-desktop))) !important
}

.u-margin-bottom-3xl {
    margin-bottom: clamp(calc(0.0625rem * var(--spacing-3xl-mobile)), var(--spacing-3xl-desktop) / 14.4 * 1vw, calc(0.0625rem * var(--spacing-3xl-desktop))) !important
}

html:not(.to-seemless) .u-anim-text .u-anim-text_char {
    opacity: 0;
    transform: translate3d(0, 0.5em, 0) rotate3d(1, 0, 0.05, 20deg)
}

html.is-first-loaded:not(.to-seemless) .u-anim-text .u-anim-text_char {
    transform-origin: 0% 30%;
    transition: transform 1.2s cubic-bezier(0.23, 1, 0.32, 1), opacity 1.2s cubic-bezier(0.23, 1, 0.32, 1);
    transition-delay: calc(var(--char-index)*var(--stagger, 0.006s) + var(--extra-delay, 0s))
}

html.is-ready:not(.to-seemless) .u-anim-text.is-inview .u-anim-text_char {
    opacity: 1;
    transform: translate3d(0, 0, 0) rotate3d(1, 0, 0, 0deg)
}

.u-anim-ready {
    opacity: 0;
    transform: translate3d(0, 5rem, 0)
}

html.is-first-loaded .u-anim-ready {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

html.is-ready .u-anim-ready {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-delay: calc(var(--index, 0)*.05s + var(--extra-delay, 0s))
}

.u-anim-inview {
    opacity: 0;
    transform: translate3d(0, 5rem, 0)
}

html.is-first-loaded .u-anim-inview {
    transition: transform .5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity .5s cubic-bezier(0.165, 0.84, 0.44, 1)
}

.is-inview .u-anim-inview {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-delay: calc(var(--index, 0)*.05s + var(--extra-delay, 0s))
}

html.is-changing:not(.to-seemless) .u-anim-page {
    transition: opacity .3s;
    opacity: 1
}

html.is-leaving:not(.to-seemless) .u-anim-page {
    transition: opacity .25s
}

html.is-animating:not(.to-seemless) .u-anim-page {
    opacity: 0
}

#listing.is-changing {
    transition: opacity t(normal)
}

#listing.is-leaving {
    transition: opacity t(fast)
}

#listing.is-animating {
    opacity: .2
}

#modal.is-changing {
    transition: opacity 100ms
}

#modal.is-animating {
    opacity: 0
}

@keyframes slideInUp {
    0% {
        transform: translate3d(0, 5rem, 0);
        opacity: 0
    }

    100% {
        transform: translate3d(0, 0, 0);
        opacity: 1
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg) translate3d(0, 0, 0)
    }

    100% {
        transform: rotate(360deg) translate3d(0, 0, 0)
    }
}