@charset "UTF-8";

:root {
    --font-primary: Lexend, sans-serif;
    --font-secondary: "Libre Caslon Text", Georgia, serif;
    --text-base-size: 1rem;
    --text-scale-ratio: 1.2;
    --text-unit: var(--text-base-size);
    --body-line-height: 1.4;
    --heading-line-height: 1.2;
    --font-primary-capital-letter: 1;
    --font-secondary-capital-letter: 1;
}

:root,
[data-theme=default] {
    --color-primary-darker-h: 250;
    --color-primary-darker-s: 84%;
    --color-primary-darker-l: 38%;
    --color-primary-darker: hsl(var(--color-primary-darker-h), var(--color-primary-darker-s), var(--color-primary-darker-l));
    --color-primary-dark-h: 250;
    --color-primary-dark-s: 84%;
    --color-primary-dark-l: 46%;
    --color-primary-dark: hsl(var(--color-primary-dark-h), var(--color-primary-dark-s), var(--color-primary-dark-l));
    --color-primary-h: 250;
    --color-primary-s: 84%;
    --color-primary-l: 54%;
    --color-primary: hsl(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l));
    --color-primary-light-h: 250;
    --color-primary-light-s: 84%;
    --color-primary-light-l: 60%;
    --color-primary-light: hsl(var(--color-primary-light-h), var(--color-primary-light-s), var(--color-primary-light-l));
    --color-primary-lighter-h: 250;
    --color-primary-lighter-s: 84%;
    --color-primary-lighter-l: 67%;
    --color-primary-lighter: hsl(var(--color-primary-lighter-h), var(--color-primary-lighter-s), var(--color-primary-lighter-l));
    --color-accent-darker-h: 342;
    --color-accent-darker-s: 89%;
    --color-accent-darker-l: 38%;
    --color-accent-darker: hsl(var(--color-accent-darker-h), var(--color-accent-darker-s), var(--color-accent-darker-l));
    --color-accent-dark-h: 342;
    --color-accent-dark-s: 89%;
    --color-accent-dark-l: 43%;
    --color-accent-dark: hsl(var(--color-accent-dark-h), var(--color-accent-dark-s), var(--color-accent-dark-l));
    --color-accent-h: 342;
    --color-accent-s: 89%;
    --color-accent-l: 48%;
    --color-accent: hsl(var(--color-accent-h), var(--color-accent-s), var(--color-accent-l));
    --color-accent-light-h: 342;
    --color-accent-light-s: 89%;
    --color-accent-light-l: 56%;
    --color-accent-light: hsl(var(--color-accent-light-h), var(--color-accent-light-s), var(--color-accent-light-l));
    --color-accent-lighter-h: 342;
    --color-accent-lighter-s: 89%;
    --color-accent-lighter-l: 62%;
    --color-accent-lighter: hsl(var(--color-accent-lighter-h), var(--color-accent-lighter-s), var(--color-accent-lighter-l));
    --color-black-h: 0;
    --color-black-s: 0%;
    --color-black-l: 0%;
    --color-black: hsl(var(--color-black-h), var(--color-black-s), var(--color-black-l));
    --color-white-h: 0;
    --color-white-s: 0%;
    --color-white-l: 100%;
    --color-white: hsl(var(--color-white-h), var(--color-white-s), var(--color-white-l));
    --color-warning-darker-h: 35;
    --color-warning-darker-s: 79%;
    --color-warning-darker-l: 48%;
    --color-warning-darker: hsl(var(--color-warning-darker-h), var(--color-warning-darker-s), var(--color-warning-darker-l));
    --color-warning-dark-h: 35;
    --color-warning-dark-s: 79%;
    --color-warning-dark-l: 56%;
    --color-warning-dark: hsl(var(--color-warning-dark-h), var(--color-warning-dark-s), var(--color-warning-dark-l));
    --color-warning-h: 35;
    --color-warning-s: 79%;
    --color-warning-l: 66%;
    --color-warning: hsl(var(--color-warning-h), var(--color-warning-s), var(--color-warning-l));
    --color-warning-light-h: 35;
    --color-warning-light-s: 79%;
    --color-warning-light-l: 74%;
    --color-warning-light: hsl(var(--color-warning-light-h), var(--color-warning-light-s), var(--color-warning-light-l));
    --color-warning-lighter-h: 35;
    --color-warning-lighter-s: 79%;
    --color-warning-lighter-l: 82%;
    --color-warning-lighter: hsl(var(--color-warning-lighter-h), var(--color-warning-lighter-s), var(--color-warning-lighter-l));
    --color-success-darker-h: 170;
    --color-success-darker-s: 78%;
    --color-success-darker-l: 26%;
    --color-success-darker: hsl(var(--color-success-darker-h), var(--color-success-darker-s), var(--color-success-darker-l));
    --color-success-dark-h: 170;
    --color-success-dark-s: 78%;
    --color-success-dark-l: 31%;
    --color-success-dark: hsl(var(--color-success-dark-h), var(--color-success-dark-s), var(--color-success-dark-l));
    --color-success-h: 170;
    --color-success-s: 78%;
    --color-success-l: 36%;
    --color-success: hsl(var(--color-success-h), var(--color-success-s), var(--color-success-l));
    --color-success-light-h: 170;
    --color-success-light-s: 78%;
    --color-success-light-l: 42%;
    --color-success-light: hsl(var(--color-success-light-h), var(--color-success-light-s), var(--color-success-light-l));
    --color-success-lighter-h: 170;
    --color-success-lighter-s: 78%;
    --color-success-lighter-l: 47%;
    --color-success-lighter: hsl(var(--color-success-lighter-h), var(--color-success-lighter-s), var(--color-success-lighter-l));
    --color-error-darker-h: 342;
    --color-error-darker-s: 89%;
    --color-error-darker-l: 38%;
    --color-error-darker: hsl(var(--color-error-darker-h), var(--color-error-darker-s), var(--color-error-darker-l));
    --color-error-dark-h: 342;
    --color-error-dark-s: 89%;
    --color-error-dark-l: 43%;
    --color-error-dark: hsl(var(--color-error-dark-h), var(--color-error-dark-s), var(--color-error-dark-l));
    --color-error-h: 342;
    --color-error-s: 89%;
    --color-error-l: 48%;
    --color-error: hsl(var(--color-error-h), var(--color-error-s), var(--color-error-l));
    --color-error-light-h: 342;
    --color-error-light-s: 89%;
    --color-error-light-l: 56%;
    --color-error-light: hsl(var(--color-error-light-h), var(--color-error-light-s), var(--color-error-light-l));
    --color-error-lighter-h: 342;
    --color-error-lighter-s: 89%;
    --color-error-lighter-l: 62%;
    --color-error-lighter: hsl(var(--color-error-lighter-h), var(--color-error-lighter-s), var(--color-error-lighter-l));
    --color-bg-darker-h: 240;
    --color-bg-darker-s: 4%;
    --color-bg-darker-l: 90%;
    --color-bg-darker: hsl(var(--color-bg-darker-h), var(--color-bg-darker-s), var(--color-bg-darker-l));
    --color-bg-dark-h: 240;
    --color-bg-dark-s: 4%;
    --color-bg-dark-l: 95%;
    --color-bg-dark: hsl(var(--color-bg-dark-h), var(--color-bg-dark-s), var(--color-bg-dark-l));
    --color-bg-h: 0;
    --color-bg-s: 0%;
    --color-bg-l: 100%;
    --color-bg: hsl(var(--color-bg-h), var(--color-bg-s), var(--color-bg-l));
    --color-bg-light-h: 0;
    --color-bg-light-s: 0%;
    --color-bg-light-l: 100%;
    --color-bg-light: hsl(var(--color-bg-light-h), var(--color-bg-light-s), var(--color-bg-light-l));
    --color-bg-lighter-h: 0;
    --color-bg-lighter-s: 0%;
    --color-bg-lighter-l: 100%;
    --color-bg-lighter: hsl(var(--color-bg-lighter-h), var(--color-bg-lighter-s), var(--color-bg-lighter-l));
    --color-contrast-lower-h: 240;
    --color-contrast-lower-s: 4%;
    --color-contrast-lower-l: 85%;
    --color-contrast-lower: hsl(var(--color-contrast-lower-h), var(--color-contrast-lower-s), var(--color-contrast-lower-l));
    --color-contrast-low-h: 240;
    --color-contrast-low-s: 4%;
    --color-contrast-low-l: 65%;
    --color-contrast-low: hsl(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l));
    --color-contrast-medium-h: 225;
    --color-contrast-medium-s: 4%;
    --color-contrast-medium-l: 47%;
    --color-contrast-medium: hsl(var(--color-contrast-medium-h), var(--color-contrast-medium-s), var(--color-contrast-medium-l));
    --color-contrast-high-h: 230;
    --color-contrast-high-s: 7%;
    --color-contrast-high-l: 23%;
    --color-contrast-high: hsl(var(--color-contrast-high-h), var(--color-contrast-high-s), var(--color-contrast-high-l));
    --color-contrast-higher-h: 230;
    --color-contrast-higher-s: 13%;
    --color-contrast-higher-l: 9%;
    --color-contrast-higher: hsl(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l));
}

.grid-auto-xs,
.grid-auto-sm,
.grid-auto-md,
.grid-auto-lg,
.grid-auto-xl {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--col-min-width), 1fr));
}

.grid-auto-xs {
    --col-min-width: 8rem;
}

.grid-auto-sm {
    --col-min-width: 10rem;
}

.grid-auto-md {
    --col-min-width: 15rem;
}

.grid-auto-lg {
    --col-min-width: 20rem;
}

.grid-auto-xl {
    --col-min-width: 25rem;
}

@media (min-width:32rem) {
    .grid-auto-xs\@xs {
        --col-min-width: 8rem;
    }

    .grid-auto-sm\@xs {
        --col-min-width: 10rem;
    }

    .grid-auto-md\@xs {
        --col-min-width: 15rem;
    }

    .grid-auto-lg\@xs {
        --col-min-width: 20rem;
    }

    .grid-auto-xl\@xs {
        --col-min-width: 25rem;
    }
}

@media (min-width:48rem) {
    .grid-auto-xs\@sm {
        --col-min-width: 8rem;
    }

    .grid-auto-sm\@sm {
        --col-min-width: 10rem;
    }

    .grid-auto-md\@sm {
        --col-min-width: 15rem;
    }

    .grid-auto-lg\@sm {
        --col-min-width: 20rem;
    }

    .grid-auto-xl\@sm {
        --col-min-width: 25rem;
    }
}

@media (min-width:64rem) {
    .grid-auto-xs\@md {
        --col-min-width: 8rem;
    }

    .grid-auto-sm\@md {
        --col-min-width: 10rem;
    }

    .grid-auto-md\@md {
        --col-min-width: 15rem;
    }

    .grid-auto-lg\@md {
        --col-min-width: 20rem;
    }

    .grid-auto-xl\@md {
        --col-min-width: 25rem;
    }
}

@media (min-width:80rem) {
    .grid-auto-xs\@lg {
        --col-min-width: 8rem;
    }

    .grid-auto-sm\@lg {
        --col-min-width: 10rem;
    }

    .grid-auto-md\@lg {
        --col-min-width: 15rem;
    }

    .grid-auto-lg\@lg {
        --col-min-width: 20rem;
    }

    .grid-auto-xl\@lg {
        --col-min-width: 25rem;
    }
}

@media (min-width:90rem) {
    .grid-auto-xs\@xl {
        --col-min-width: 8rem;
    }

    .grid-auto-sm\@xl {
        --col-min-width: 10rem;
    }

    .grid-auto-md\@xl {
        --col-min-width: 15rem;
    }

    .grid-auto-lg\@xl {
        --col-min-width: 20rem;
    }

    .grid-auto-xl\@xl {
        --col-min-width: 25rem;
    }
}

.tabs__control {
    text-decoration: none;
    color: var(--color-contrast-medium);
}

.tabs__control:focus {
    outline: 2px solid hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
    outline-offset: 2px;
}

.tabs__control:hover {
    color: var(--color-contrast-high);
}

.tabs__control[aria-selected=true] {
    color: var(--color-contrast-high);
    text-decoration: underline;
}

:root {
    --dropdown-item-padding: var(--space-2xs) var(--space-sm);
}

.dropdown {
    position: relative;
}

.dropdown__menu {
    width: 200px;
    border-radius: var(--radius-md);
    padding: var(--space-3xs) 0;
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    z-index: var(--z-index-popover, 5);
    position: absolute;
    left: 0;
    top: 100%;
    font-size: 1rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0s 0.2s;
}

@media (pointer:fine) {

    .dropdown__wrapper:hover>.dropdown__menu,
    .dropdown__sub-wrapper:hover>.dropdown__menu {
        opacity: 1;
        visibility: visible;
        transition: opacity 0.2s;
    }

    .dropdown__sub-wrapper:hover>.dropdown__menu {
        left: 100%;
    }
}

@media not all and (pointer:fine) {
    .dropdown__trigger-icon {
        display: none;
    }
}

.dropdown__item {
    display: block;
    text-decoration: none;
    color: var(--color-contrast-high);
    padding: var(--dropdown-item-padding);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: 0.2s;
}

.dropdown__item:hover,
.dropdown__item.dropdown__item--hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
}

.dropdown__separator {
    height: 1px;
    background-color: var(--color-contrast-lower);
    margin: var(--dropdown-item-padding);
}

.dropdown__sub-wrapper {
    position: relative;
}

.dropdown__sub-wrapper>.dropdown__item {
    position: relative;
    padding-right: calc(var(--space-sm) + 12px);
}

.dropdown__sub-wrapper>.dropdown__item .icon {
    position: absolute;
    display: block;
    width: 12px;
    height: 12px;
    right: var(--space-2xs);
    top: calc(50% - 6px);
}

.dropdown__sub-wrapper>.dropdown__menu {
    top: calc(var(--space-2xs) * -1);
    box-shadow: var(--inner-glow), var(--shadow-md);
}

.dropdown__menu {
    top: calc(100% + 4px);
}

.dropdown__sub-wrapper .dropdown__menu {
    top: calc(var(--space-2xs) * -1);
}

@media (pointer:fine) {
    .dropdown__menu--is-visible {
        opacity: 1;
        visibility: visible;
        transition: opacity 0.2s;
    }
}

.dropdown__menu--hide {
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s, visibility 0s 0.2s;
}

.dropdown__sub-wrapper>.dropdown__menu--is-visible,
.dropdown__sub-wrapper>.dropdown__menu--hide {
    left: 100%;
}

.dropdown__sub-wrapper>.dropdown__menu--is-visible.dropdown__menu--left,
.dropdown__sub-wrapper>.dropdown__menu--hide.dropdown__menu--left {
    left: -100%;
}

:root {
    --mega-nav-height: 50px;
    --mega-nav-content-max-width: var(--max-width-lg);
}

@media (min-width:64rem) {
    :root {
        --mega-nav-height: 70px;
    }
}

.mega-nav {
    height: var(--mega-nav-height);
    width: 100%;
    z-index: var(--z-index-header, 3);
    box-shadow: inset 0px -1px 0px hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
}

.mega-nav--expanded {
    background-color: var(--color-bg);
}

.mega-nav__container {
    width: calc(100% - 2 * var(--space-md));
    height: 100%;
    max-width: var(--mega-nav-content-max-width);
    margin-left: auto;
    margin-right: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.mega-nav__logo {
    display: block;
    width: 104px;
    height: 30px;
}

.mega-nav__logo>* {
    width: inherit;
    height: inherit;
}

.mega-nav__icon-btns {
    display: flex;
    align-items: center;
}

.mega-nav__icon-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    font-size: 24px;
    color: var(--color-contrast-high);
    cursor: pointer;
    transition: 0.2s;
}

.mega-nav__icon-btn .icon {
    display: block;
}

.mega-nav__icon-btn .icon__group {
    stroke-width: 1px;
}

.mega-nav__icon-btn .icon__group>* {
    transition: transform 0.3s var(--ease-in-out), stroke-dashoffset 0.3s, opacity 0.3s;
}

.mega-nav__icon-btn--menu .icon__group>* {
    stroke-dasharray: 24;
}

.mega-nav__icon-btn--menu .icon__group>*:nth-child(1) {
    transform-origin: 12px 6px;
}

.mega-nav__icon-btn--menu .icon__group>*:nth-child(2) {
    stroke-dashoffset: 0;
}

.mega-nav__icon-btn--menu .icon__group>*:nth-child(3) {
    transform-origin: 12px 18px;
}

.mega-nav__icon-btn--menu.mega-nav__icon-btn--state-b .icon__group>*:nth-child(1) {
    transform: translateY(6px) rotate(-45deg);
}

.mega-nav__icon-btn--menu.mega-nav__icon-btn--state-b .icon__group>*:nth-child(2) {
    stroke-dashoffset: 24;
}

.mega-nav__icon-btn--menu.mega-nav__icon-btn--state-b .icon__group>*:nth-child(3) {
    transform: translateY(-6px) rotate(45deg);
}

.mega-nav__icon-btn--search .icon__group {
    transform-origin: 12px 12px;
    transform: rotate(0deg);
    transition: transform 0.3s var(--ease-out);
}

.mega-nav__icon-btn--search .icon__group>*:nth-child(1) {
    stroke-dashoffset: 34;
    stroke-dasharray: 24;
}

.mega-nav__icon-btn--search .icon__group>*:nth-child(2) {
    stroke-dashoffset: 24;
    stroke-dasharray: 24;
}

.mega-nav__icon-btn--search .icon__group>*:nth-child(3) {
    transform-origin: 9.5px 9.5px;
    transform: rotate(45deg);
    stroke-dashoffset: 84;
    stroke-dasharray: 42;
    opacity: 1;
}

.mega-nav__icon-btn--search.mega-nav__icon-btn--state-b .icon__group {
    transform: rotate(-90deg);
}

.mega-nav__icon-btn--search.mega-nav__icon-btn--state-b .icon__group>*:nth-child(1) {
    stroke-dashoffset: 48;
}

.mega-nav__icon-btn--search.mega-nav__icon-btn--state-b .icon__group>*:nth-child(2) {
    stroke-dashoffset: 48;
}

.mega-nav__icon-btn--search.mega-nav__icon-btn--state-b .icon__group>*:nth-child(3) {
    stroke-dashoffset: 42;
    opacity: 0;
}

.mega-nav__arrow-icon {
    font-size: 16px;
    color: currentColor;
    transition: color 0.2s;
}

.mega-nav__arrow-icon .icon {
    display: block;
}

.mega-nav__arrow-icon .icon__group {
    stroke-width: 1px;
    will-change: transform;
    transform-origin: 8px 8px;
    transition: transform 0.3s var(--ease-out);
}

.mega-nav__arrow-icon .icon__group>* {
    stroke-dasharray: 17;
    transform-origin: 8px 8px;
    transform: translateY(3px);
    transition: transform 0.3s, stroke-dashoffset 0.3s;
    transition-timing-function: var(--ease-out);
}

.mega-nav__arrow-icon .icon__group>*:first-child {
    stroke-dashoffset: 8.5;
}

.mega-nav__arrow-icon .icon__group>*:last-child {
    stroke-dashoffset: 8.5;
}

.mega-nav__label {
    color: var(--color-contrast-medium);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: var(--text-xs);
}

.mega-nav__card img {
    transition: opacity 0.3s;
}

.mega-nav__card img:hover {
    opacity: 0.85;
}

.mega-nav__card-title {
    color: var(--color-contrast-higher);
    text-decoration: none;
}

.mega-nav__card-title:hover {
    text-decoration: underline;
}

.mega-nav--mobile {}

.mega-nav--mobile .mega-nav__icon-btns--desktop {
    display: none;
}

.mega-nav--mobile .mega-nav__nav,
.mega-nav--mobile .mega-nav__search {
    display: none;
    position: absolute;
    top: var(--mega-nav-height);
    left: 0;
    width: 100%;
    height: calc(100vh - var(--mega-nav-height) - var(--mega-nav-offset-y, 0px));
    overflow: auto;
    -webkit-overflow-scrolling: touch;
    background-color: var(--color-bg);
    box-shadow: var(--shadow-lg);
}

.mega-nav--mobile .mega-nav__nav--is-visible,
.mega-nav--mobile .mega-nav__search--is-visible {
    display: block;
}

.mega-nav--mobile .mega-nav__nav--is-visible>*,
.mega-nav--mobile .mega-nav__search--is-visible>* {
    animation: mega-nav-entry-animation 0.5s var(--ease-out);
}

.mega-nav--mobile .mega-nav__nav-inner,
.mega-nav--mobile .mega-nav__search-inner {
    padding: var(--space-md) 0;
    width: calc(100% - 2 * var(--space-md));
    max-width: var(--mega-nav-content-max-width);
    margin-left: auto;
    margin-right: auto;
}

.mega-nav--mobile .mega-nav__label {
    margin: var(--space-lg) 0 var(--space-xs);
}

.mega-nav--mobile .mega-nav__item {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.mega-nav--mobile .mega-nav__control {
    display: flex;
    align-items: center;
    width: 100%;
    font-size: var(--text-md);
    text-align: left;
    padding: var(--space-sm) 0;
    color: var(--color-contrast-higher);
    text-decoration: none;
    cursor: pointer;
}

.mega-nav--mobile a[aria-current=page] {
    color: var(--color-primary);
}

.mega-nav--mobile .mega-nav__arrow-icon {
    margin-left: auto;
    margin-right: 12px;
}

.mega-nav--mobile .mega-nav__btn {
    width: 100%;
    margin: var(--space-sm) 0;
    font-size: var(--text-md);
}

.mega-nav--mobile .mega-nav__sub-nav-wrapper {
    display: none;
    padding: 0 var(--space-md) var(--space-lg);
    overflow: hidden;
}

.mega-nav--mobile .mega-nav__sub-items {}

.mega-nav--mobile .mega-nav__sub-items:not(:last-child) {
    margin-bottom: var(--space-lg);
}

.mega-nav--mobile .mega-nav__sub-item {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.mega-nav--mobile .mega-nav__sub-link {
    display: block;
    color: var(--color-contrast-higher);
    text-decoration: none;
    padding: var(--space-2xs) 0;
}

.mega-nav--mobile .mega-nav__quick-link {
    display: block;
    color: var(--color-contrast-higher);
    text-decoration: none;
    border-bottom: 1px solid var(--color-contrast-lower);
    padding: var(--space-xs) 0;
}

.mega-nav--mobile .mega-nav__sub-nav--layout-1 {}

.mega-nav--mobile .mega-nav__sub-nav--layout-1 .mega-nav__sub-items {
    margin-bottom: 0;
}

.mega-nav--mobile .mega-nav__sub-nav--layout-1 .mega-nav__tabs {
    display: none;
}

.mega-nav--mobile .mega-nav__sub-nav--layout-3 {
    padding-top: var(--space-md);
    display: grid;
    gap: var(--space-md);
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

.mega-nav--mobile .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group {}

.mega-nav--mobile .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group>*:first-child {
    transform: translateY(-3px) rotate(-90deg);
}

.mega-nav--mobile .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group>*:last-child {
    transform: translateY(-3px) rotate(90deg);
}

.mega-nav--mobile .mega-nav__item--expanded .mega-nav__sub-nav-wrapper {
    display: block;
}

.mega-nav--mobile .mega-nav__item--expanded .mega-nav__sub-nav-wrapper>* {
    animation: mega-nav-entry-animation 0.5s var(--ease-out);
}

.mega-nav--desktop {}

.mega-nav--desktop .mega-nav__icon-btns--mobile,
.mega-nav--desktop .mega-nav__sub-nav-wrapper,
.mega-nav--desktop .mega-nav__search,
.mega-nav--desktop .mega-nav__label {
    display: none;
}

.mega-nav--desktop .mega-nav__logo {
    flex-shrink: 0;
    margin-right: var(--space-sm);
}

.mega-nav--desktop .mega-nav__nav {
    flex-grow: 1;
    height: 100%;
}

.mega-nav--desktop .mega-nav__nav-inner {
    height: 100%;
    display: flex;
    justify-content: space-between;
}

.mega-nav--desktop .mega-nav__items {
    display: flex;
    height: 100%;
}

.mega-nav--desktop .mega-nav__item {
    display: flex;
    align-items: center;
}

.mega-nav--desktop .mega-nav__control {
    position: relative;
    display: flex;
    align-items: center;
    padding: 0 var(--space-md);
    height: 100%;
    font-size: var(--text-sm);
    color: var(--color-contrast-higher);
    text-decoration: none;
    transition: 0.2s;
}

.mega-nav--desktop .mega-nav__control::after {
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--color-contrast-higher);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.2s;
}

.mega-nav--desktop .mega-nav__control .mega-nav__arrow-icon {
    margin-left: var(--space-2xs);
}

.mega-nav--desktop .mega-nav__control:hover {
    cursor: pointer;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.05);
}

.mega-nav--desktop .mega-nav__sub-nav-wrapper,
.mega-nav--desktop .mega-nav__search {
    position: absolute;
    top: var(--mega-nav-height);
    left: 0;
    width: 100%;
    background-color: var(--color-bg);
    box-shadow: var(--shadow-lg);
    max-height: calc(100vh - var(--mega-nav-height) - var(--mega-nav-offset-y, 0px));
    overflow: auto;
}

.mega-nav--desktop .mega-nav__sub-nav,
.mega-nav--desktop .mega-nav__search-inner {
    width: calc(100% - 2 * var(--space-md));
    margin: 0 auto;
    padding: var(--space-xl) 0;
}

.mega-nav--desktop .mega-nav__sub-nav .mega-nav__label,
.mega-nav--desktop .mega-nav__search-inner .mega-nav__label {
    display: block;
}

.mega-nav--desktop .mega-nav__sub-nav {
    max-width: var(--mega-nav-content-max-width);
}

.mega-nav--desktop .mega-nav__search-inner {
    max-width: var(--max-width-xs);
}

.mega-nav--desktop .mega-nav__label {
    margin-bottom: var(--space-md);
}

.mega-nav--desktop .mega-nav__sub-item:not(:last-child) {
    margin-bottom: var(--space-2xs);
}

.mega-nav--desktop .mega-nav__sub-link {
    font-size: var(--text-sm);
    color: var(--color-contrast-higher);
    text-decoration: none;
}

.mega-nav--desktop .mega-nav__sub-link:hover {
    text-decoration: underline;
}

.mega-nav--desktop .mega-nav__quick-link {
    display: inline-block;
    margin-bottom: var(--space-2xs);
    font-size: var(--text-sm);
    color: var(--color-contrast-higher);
    text-decoration: none;
}

.mega-nav--desktop .mega-nav__quick-link:hover {
    text-decoration: underline;
}

.mega-nav--desktop .mega-nav__btn {
    font-size: var(--text-sm);
    margin-left: var(--space-sm);
}

.mega-nav--desktop .mega-nav__sub-nav--layout-1 {}

.mega-nav--desktop .mega-nav__sub-nav--layout-1 .mega-nav__sub-items {
    display: none;
}

.mega-nav--desktop .mega-nav__sub-nav--layout-1 .mega-nav__tabs {
    display: flex;
}

.mega-nav--desktop .mega-nav__sub-nav--layout-2 {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-sm);
}

.mega-nav--desktop .mega-nav__sub-nav--layout-3 {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-md);
}

.mega-nav--desktop .mega-nav__sub-nav--layout-4 {
    text-align: center;
}

.mega-nav--desktop .mega-nav__sub-nav--layout-4 .mega-nav__sub-link {
    font-size: var(--text-lg);
}

.mega-nav--desktop .mega-nav__tabs-controls>*:not(:last-child) {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.mega-nav--desktop .mega-nav__tabs-control {
    display: block;
    width: 100%;
    padding: var(--space-xs);
    overflow: hidden;
    color: var(--color-contrast-higher);
    text-decoration: none;
    cursor: pointer;
    transition: 0.2s;
}

.mega-nav--desktop .mega-nav__tabs-control .icon {
    opacity: 0;
    transform: translateX(-10px);
    transition: transform 0.5s var(--ease-out), opacity 0.5s;
}

.mega-nav--desktop .mega-nav__tabs-control:hover,
.mega-nav--desktop .mega-nav__tabs-control[aria-selected=true] {
    color: var(--color-primary);
}

.mega-nav--desktop .mega-nav__tabs-control[aria-selected=true] .icon {
    opacity: 1;
    transform: translateX(0px);
}

.mega-nav--desktop .mega-nav__tabs-img {
    display: block;
    overflow: hidden;
    border-radius: var(--radius-lg);
    transition: opacity 0.3s;
}

.mega-nav--desktop .mega-nav__tabs-img:hover {
    opacity: 0.85;
}

.mega-nav--desktop .mega-nav__item--expanded .mega-nav__control {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.05);
}

.mega-nav--desktop .mega-nav__item--expanded .mega-nav__control::after {
    opacity: 1;
}

.mega-nav--desktop .mega-nav__item--expanded .mega-nav__sub-nav-wrapper {
    display: block;
}

.mega-nav--desktop .mega-nav__item--expanded .mega-nav__sub-nav {
    animation: mega-nav-entry-animation 0.5s var(--ease-out);
}

.mega-nav--desktop:not([data-hover=on]) .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group {
    transform: rotate(-90deg);
}

.mega-nav--desktop:not([data-hover=on]) .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group>*:first-child,
.mega-nav--desktop:not([data-hover=on]) .mega-nav__item--expanded .mega-nav__arrow-icon .icon__group *:last-child {
    stroke-dashoffset: 0;
    transform: translateY(0px);
}

.mega-nav--desktop .mega-nav__icon-btn {
    border-radius: 50%;
    margin-left: var(--space-4xs);
}

.mega-nav--desktop .mega-nav__icon-btn:hover,
.mega-nav--desktop .mega-nav__icon-btn--state-b {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.05);
}

.mega-nav--desktop .mega-nav__search--is-visible {
    display: block;
}

.mega-nav--desktop .mega-nav__search--is-visible .mega-nav__search-inner {
    animation: mega-nav-entry-animation 0.5s var(--ease-out);
}

@keyframes mega-nav-entry-animation {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0px);
    }
}

[class*=mega-nav--desktop]::before {
    display: none;
    content: "mobile";
}

@media (min-width:32rem) {
    .mega-nav--desktop\@xs::before {
        content: "desktop";
    }
}

@media (min-width:48rem) {
    .mega-nav--desktop\@sm::before {
        content: "desktop";
    }
}

@media (min-width:64rem) {
    .mega-nav--desktop\@md::before {
        content: "desktop";
    }
}

@media (min-width:80rem) {
    .mega-nav--desktop\@lg::before {
        content: "desktop";
    }
}

@media (min-width:90rem) {
    .mega-nav--desktop\@xl::before {
        content: "desktop";
    }
}

.intro {
    padding-top: var(--mega-nav-height);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

:root {
    --diagonal-section-offset: 50px;
}

.diagonal-section,
.diagonal-section-top,
.diagonal-section-bottom {
    position: relative;
    z-index: 1;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}

@supports ((-webkit-clip-path:inset(50%)) or (clip-path:inset(50%))) {

    .diagonal-section,
    .diagonal-section-top.diagonal-section-bottom {
        padding-top: calc(var(--diagonal-section-offset) / 2);
        padding-bottom: calc(var(--diagonal-section-offset) / 2);
        -webkit-clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
        clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
    }

    .diagonal-section--flip-x {
        -webkit-clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
        clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
    }

    .diagonal-section-top {
        padding-top: calc(var(--diagonal-section-offset) / 2);
        -webkit-clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% 100%, 0% 100%);
        clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% 100%, 0% 100%);
    }

    .diagonal-section-top--flip-x {
        -webkit-clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% 100%, 0% 100%);
        clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% 100%, 0% 100%);
    }

    .diagonal-section-top--flip-x.diagonal-section-bottom {
        -webkit-clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
        clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
    }

    .diagonal-section-bottom {
        padding-bottom: calc(var(--diagonal-section-offset) / 2);
        -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
        clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% calc(100% - var(--diagonal-section-offset)));
    }

    .diagonal-section-bottom--flip-x {
        -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
        clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
    }

    .diagonal-section-bottom--flip-x.diagonal-section-top {
        -webkit-clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
        clip-path: polygon(0% 0%, 100% var(--diagonal-section-offset), 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
    }

    .diagonal-section-top--flip-x.diagonal-section-bottom--flip-x {
        -webkit-clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
        clip-path: polygon(0% var(--diagonal-section-offset), 100% 0%, 100% calc(100% - var(--diagonal-section-offset)), 0% 100%);
    }
}

.main-footer__logo {
    display: inline-block;
}

.main-footer__logo svg,
.main-footer__logo img {
    display: block;
}

.main-footer__link {
    color: var(--color-white);
    text-decoration: none;
}

.main-footer__link:hover {
    color: var(--color-white);
    text-decoration: underline;
}

.main-footer__social {
    text-decoration: none;
    display: inline-block;
    color: var(--color-contrast-medium);
}

.main-footer__social:hover {
    color: var(--color-contrast-high);
}

.main-footer__social .icon {
    font-size: 1.2em;
}

@media (min-width:64rem) {
    .main-footer__social .icon {
        font-size: 1em;
    }
}

.card--link {
    text-decoration: none;
    display: block;
    color: inherit;
    transition: 0.2s;
}

.card--link:hover {
    background-color: transparent;
    box-shadow: none;
}

.card--link:hover .card__img-wrapper::after {
    opacity: 1;
}

.card--link .card__img-wrapper {
    position: relative;
}

.feature-v5 {
    --feature-media-offset: var(--space-3xl);
    --feature-content-media-gap: var(--space-lg);
}

.feature-v5__content {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), var(--bg-opacity, 1));
    padding-bottom: calc(var(--feature-content-media-gap) + var(--feature-media-offset));
}

.feature-v5__media {
    margin-top: calc(-1 * var(--feature-media-offset));
}

:root {
    --carousel-grid-gap: var(--space-xs);
    --carousel-item-auto-size: 260px;
    --carousel-transition-duration: 0.5s;
}

.carousel {
    position: relative;
}

.carousel__list {
    display: flex;
    flex-wrap: nowrap;
    will-change: transform;
}

.carousel__item {
    flex-shrink: 0;
    width: var(--carousel-item-auto-size);
    margin-right: var(--carousel-grid-gap);
    margin-bottom: var(--carousel-grid-gap);
}

.carousel__list--animating {
    transition-property: transform;
    transition-duration: var(--carousel-transition-duration);
    transition-timing-function: var(--ease-out);
}

.carousel__item {
    opacity: 0;
    margin-bottom: 0;
}

.carousel--loaded .carousel__item {
    opacity: 1;
}

.carousel:not(.carousel--is-dragging) .carousel__list:not(.carousel__list--animating) .carousel__item[tabindex="-1"]>* {
    visibility: hidden;
}

.carousel[data-drag=on] .carousel__item {
    -webkit-user-select: none;
    user-select: none;
}

.carousel[data-drag=on] .carousel__item img {
    pointer-events: none;
}

.carousel__control {
    --size: 40px;
    width: 40px;
    height: 40px;
    display: flex;
    background-color: var(--color-bg-light);
    border-radius: 50%;
    box-shadow: var(--inner-glow), var(--shadow-sm);
    z-index: 1;
    transition: 0.2s;
}

.carousel__control:active {
    transform: translateY(1px);
}

.carousel__control:hover {
    background-color: var(--color-bg-lighter);
    box-shadow: var(--inner-glow), var(--shadow-md);
}

.carousel__control[disabled] {
    pointer-events: none;
    opacity: 0.5;
    box-shadow: none;
}

.carousel__control .icon {
    --size: 20px;
    display: block;
    margin: auto;
}

.carousel__navigation {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fit, 10px);
    gap: var(--space-xs);
    justify-content: center;
    align-items: center;
    margin-top: var(--space-sm);
}

.carousel__nav-item {
    display: inline-block;
    margin: 0 var(--space-3xs);
}

@supports (grid-area:auto) {
    .carousel__nav-item {
        margin: 0;
    }
}

.carousel__nav-item button {
    display: block;
    position: relative;
    font-size: 10px;
    height: 1em;
    width: 1em;
    border-radius: 50%;
    background-color: var(--color-contrast-high);
    opacity: 0.4;
    cursor: pointer;
    transition: background 0.3s;
}

.carousel__nav-item button::before {
    content: "";
    position: absolute;
    top: calc(50% - 0.5em);
    left: calc(50% - 0.5em);
    font-size: 16px;
    height: 1em;
    width: 1em;
    border-radius: inherit;
    border: 1px solid var(--color-contrast-high);
    opacity: 0;
    transform: scale(0);
    transition: 3s;
}

.carousel__nav-item button:focus {
    outline: none;
}

.carousel__nav-item button:focus::before {
    opacity: 1;
    transform: scale(1);
}

.carousel__nav-item--selected button {
    opacity: 1;
}

.carousel__navigation--pagination {
    grid-template-columns: repeat(auto-fit, 24px);
}

.carousel__navigation--pagination .carousel__nav-item button {
    width: 24px;
    height: 24px;
    color: var(--color-bg);
    font-size: 12px;
    line-height: 24px;
    border-radius: var(--radius-md);
    text-align: center;
}

.carousel__navigation--pagination .carousel__nav-item button:focus {
    outline: 1px solid var(--color-primary);
    outline-offset: 2px;
}

.carousel--hide-controls .carousel__navigation,
.carousel--hide-controls .carousel__control {
    display: none;
}

.carousel-v2 {
    --carousel-grid-gap: var(--space-md);
    --carousel-item-auto-size: 320px;
    --carousel-transition-duration: 0.5s;
}

.carousel-v2 .carousel__wrapper:hover .carousel-v2__control {
    opacity: 1;
}

.carousel-v2__control {
    --size: 60px;
    height: var(--size);
    width: var(--size);
    border-radius: 50%;
    background-color: hsla(var(--color-white-h), var(--color-white-s), var(--color-white-l), 0.7);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    pointer-events: auto;
    cursor: pointer;
    margin: 0 var(--space-2xs);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.2s;
}

.carousel-v2__control:hover {
    background-color: hsla(var(--color-white-h), var(--color-white-s), var(--color-white-l), 0.9);
}

.carousel-v2__control[disabled] {
    display: none;
}

.carousel-v2__control:active {
    transform: translateY(2px);
}

.carousel-v2__control .icon {
    --size: 20px;
    display: block;
    color: var(--color-black);
}

@media (min-width:64rem) {
    .carousel-v2__control {
        opacity: 0;
    }
}

.carousel-v2__navigation {
    display: none;
    grid-template-columns: repeat(auto-fit, 52px);
    grid-gap: var(--space-xs);
    justify-content: center;
    align-items: center;
    margin-top: var(--space-sm);
}

@media (min-width:64rem) {
    .carousel-v2__navigation {
        display: grid;
    }
}

.carousel-v2__navigation-item {
    display: inline-block;
    margin: 0 var(--space-3xs);
}

@supports (grid-area:auto) {
    .carousel-v2__navigation-item {
        margin: 0;
    }
}

.carousel-v2__navigation-item:not(.carousel-v2__navigation-item--selected) button {
    cursor: pointer;
}

.carousel-v2__navigation-item button {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 52px;
    height: 24px;
}

.carousel-v2__navigation-item button::before {
    content: "";
    display: block;
    width: 100%;
    height: 2px;
    background-color: hsla(var(--color-contrast-high-h), var(--color-contrast-high-s), var(--color-contrast-high-l), 0.2);
}

.carousel-v2__navigation-item:not(.carousel-v2__navigation-item--selected) button:hover::before {
    background-color: hsla(var(--color-contrast-high-h), var(--color-contrast-high-s), var(--color-contrast-high-l), 0.4);
    transition: 0.2s;
}

.carousel-v2__navigation-item--selected button::before {
    background-color: hsla(var(--color-contrast-high-h), var(--color-contrast-high-s), var(--color-contrast-high-l), 1);
}

:root {
    --reveal-fx-duration: 0.6s;
    --reveal-fx-timing-function: var(--ease-out);
}

.reveal-fx {
    opacity: 0;
    transition: opacity, transform var(--reveal-fx-timing-function);
    transition-duration: var(--reveal-fx-duration);
}

.reveal-fx::before {
    display: none;
    content: "reveal-fx";
}

.reveal-fx--translate,
.reveal-fx--translate-up {
    transform: translateY(50px);
}

.reveal-fx--translate-right {
    transform: translateX(-50px);
}

.reveal-fx--translate-left {
    transform: translateX(50px);
}

.reveal-fx--translate-down {
    transform: translateY(-50px);
}

.reveal-fx--scale {
    transform: scale(0.8);
}

.reveal-fx--scale-up {
    transform: translateY(50px) scale(0.8);
}

.reveal-fx--scale-right {
    transform: translateX(-50px) scale(0.8);
}

.reveal-fx--scale-left {
    transform: translateX(50px) scale(0.8);
}

.reveal-fx--scale-down {
    transform: translateY(-50px) scale(0.8);
}

.reveal-fx--rotate,
.reveal-fx--rotate-down,
.reveal-fx--rotate-right,
.reveal-fx--rotate-left,
.reveal-fx--rotate-up {
    perspective: 1000px;
}

.reveal-fx--rotate>*,
.reveal-fx--rotate-down>*,
.reveal-fx--rotate-right>*,
.reveal-fx--rotate-left>*,
.reveal-fx--rotate-up>* {
    transition: transform var(--reveal-fx-duration) var(--reveal-fx-timing-function);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.reveal-fx--rotate>*,
.reveal-fx--rotate-down>* {
    transform-origin: top;
    transform: rotateX(-45deg);
}

.reveal-fx--rotate-right>* {
    transform-origin: left center;
    transform: rotateY(45deg);
}

.reveal-fx--rotate-left>* {
    transform-origin: right center;
    transform: rotateY(-45deg);
}

.reveal-fx--rotate-up>* {
    transform-origin: bottom;
    transform: rotateX(45deg);
}

.reveal-fx--text-mask {
    overflow: hidden;
}

.reveal-fx--text-mask>* {
    display: inline-block;
    transform: translateY(100%);
    transition: transform var(--reveal-fx-duration) var(--reveal-fx-timing-function);
    will-change: transform;
}

[class*=reveal-fx--translate],
[class*=reveal-fx--scale] {
    will-change: opacity, transform;
}

.reveal-fx--text-mask>*,
[class*=reveal-fx--rotate]>* {
    will-change: transform;
}

.reveal-fx--clip-x>*,
.reveal-fx--clip-y>* {
    transition: opacity, -webkit-clip-path var(--ease-out);
    transition: opacity, clip-path var(--ease-out);
    transition: opacity, clip-path var(--ease-out), -webkit-clip-path var(--ease-out);
    transition-duration: var(--reveal-fx-duration);
}

.reveal-fx--clip-x>* {
    -webkit-clip-path: polygon(10% 0%, 90% 0%, 90% 100%, 10% 100%);
    clip-path: polygon(10% 0%, 90% 0%, 90% 100%, 10% 100%);
}

.reveal-fx--clip-y>* {
    -webkit-clip-path: polygon(0% 50%, 100% 50%, 100% 100%, 0% 100%);
    clip-path: polygon(0% 50%, 100% 50%, 100% 100%, 0% 100%);
}

.reveal-fx--is-visible {
    opacity: 1;
}

.reveal-fx--is-visible[class*=reveal-fx--translate],
.reveal-fx--is-visible[class*=reveal-fx--scale],
.reveal-fx--is-visible[class*=reveal-fx--rotate]>*,
.reveal-fx--is-visible.reveal-fx--text-mask>* {
    transform: translate(0);
}

.reveal-fx--is-visible.reveal-fx--clip-x>*,
.reveal-fx--is-visible.reveal-fx--clip-y>* {
    opacity: 1;
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.story-v4 {
    position: relative;
    z-index: 1;
}

.story-v4__title {
    color: var(--color-contrast-higher);
    -webkit-text-decoration-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.2);
    text-decoration-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.2);
    transition: 0.2s;
}

.story-v4__title:hover {
    -webkit-text-decoration-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 1);
    text-decoration-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 1);
}

.story-v4__img-link {
    display: block;
}

.story-v4__img-link img {
    display: block;
    width: 100%;
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    transition: 0.3s var(--ease-out);
}

.story-v4__img-link:hover img {
    -webkit-clip-path: polygon(2% 2%, 98% 2%, 98% 98%, 2% 98%);
    clip-path: polygon(2% 2%, 98% 2%, 98% 98%, 2% 98%);
}

.story__img {
    display: block;
    transition: opacity 0.2s;
    overflow: hidden;
    margin-bottom: var(--space-xs);
}

.story__img:hover {
    opacity: 0.85;
}

.story__img img {
    display: block;
    width: 100%;
}

.story__category {
    display: inline-flex;
    align-items: center;
    color: var(--color-contrast-higher);
    line-height: 1;
    text-decoration: none;
    font-size: var(--text-sm);
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
    padding: var(--space-2xs);
    border-radius: var(--radius-md);
    transition: background-color 0.2s;
}

.story__category:hover {
    text-decoration: underline;
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.3);
}

.story__title a {
    color: var(--color-contrast-higher);
    text-decoration: none;
}

.story__title a:hover {
    text-decoration: underline;
}

.story__author {
    --author-img-size: 50px;
    display: grid;
    grid-template-columns: var(--author-img-size) 1fr;
    align-items: center;
    gap: var(--space-xs);
}

.story__author img {
    display: block;
    width: var(--author-img-size);
    height: var(--author-img-size);
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: 50%;
}

.story__author-name {
    margin-bottom: var(--space-4xs);
}

.story__author-name a {
    text-decoration: none;
    color: var(--color-contrast-higher);
}

.story__author-name a:hover {
    text-decoration: underline;
}

.story__meta {
    font-size: var(--text-sm);
    color: var(--color-contrast-medium);
}

@media (min-width:64rem) {
    .story--featured {
        display: grid;
        grid-template-columns: 3fr 2fr;
        grid-gap: var(--space-md);
        align-items: center;
    }

    .story--featured .story__img {
        margin: 0;
    }

    .story--featured .story__title {
        font-size: var(--text-2xl);
    }
}

.back-to-top {
    --size: 50px;
    width: var(--size);
    height: var(--size);
    display: flex;
    position: fixed;
    right: var(--space-md);
    bottom: var(--space-md);
    z-index: var(--z-index-fixed-element, 10);
    border-radius: 50%;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.9);
    transition: 0.2s;
    visibility: hidden;
    opacity: 0;
    mix-blend-mode: difference;
}

.back-to-top:hover {
    background-color: var(--color-contrast-higher);
}

.back-to-top .icon {
    --size: 20px;
    display: block;
    margin: auto;
    color: var(--color-bg);
}

.back-to-top--is-visible {
    visibility: visible;
    opacity: 1;
}

.socials__btns a {
    --size: 2.5em;
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-contrast-high);
    transition: 0.3s;
}

.socials__btns a .icon {
    font-size: 1.25em;
    color: var(--color-bg);
    transition: color 0.3s, transform 0.3s var(--ease-out-back);
}

.socials__btns a:hover {
    background-color: var(--color-contrast-medium);
}

.socials__btns a:hover .icon {
    transform: scale(1.2);
    color: var(--color-white);
}

.btn-fx-1 {
    --border-radius: 0.25em;
    --transition-duration: .3s;
    position: relative;
    display: inline-block;
    border-radius: var(--border-radius);
    line-height: 1;
    text-decoration: none;
    color: var(--color-primary);
    transition: var(--transition-duration);
    cursor: pointer;
}

.btn-fx-1 span,
.btn-fx-1 .btn-fx-1__icon-wrapper {
    position: relative;
    z-index: 2;
}

.btn-fx-1 .icon {
    display: block;
    will-change: transform;
    transition: var(--transition-duration);
}

.btn-fx-1 .icon:first-child {
    color: var(--color-primary);
}

.btn-fx-1 .icon:last-child {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    color: var(--color-white);
    transform: translateY(100%);
}

.btn-fx-1:hover {
    color: var(--color-white);
}

.btn-fx-1:hover .icon:first-child {
    opacity: 0;
    transform: translateY(-100%);
}

.btn-fx-1:hover .icon:last-child {
    opacity: 1;
    transform: translateY(0);
}

.btn-fx-1:hover .btn-fx-1__inner::after {
    transform: skewY(0deg) scaleY(2);
}

.btn-fx-1:focus {
    outline: none;
    box-shadow: 0 0 0 1px var(--color-bg), 0 0 0 3px var(--color-primary);
}

.btn-fx-1__inner {
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.15);
    overflow: hidden;
    -webkit-clip-path: inset(0% 0% 0% 0% round var(--border-radius));
    clip-path: inset(0% 0% 0% 0% round var(--border-radius));
}

.btn-fx-1__inner::after {
    content: "";
    position: absolute;
    z-index: 1;
    top: 50%;
    left: -5%;
    width: 110%;
    height: 100%;
    background-color: var(--color-primary);
    transform-origin: center bottom;
    transform: skewY(10deg) scaleY(0);
    transition: transform var(--transition-duration);
}

.btn-fx-2 {
    position: relative;
    line-height: 1;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-decoration: none;
}

.btn-fx-2 span {
    position: relative;
    display: inline-flex;
    -webkit-clip-path: inset(0%);
    clip-path: inset(0%);
}

.btn-fx-2 em {
    display: inline-flex;
}

.btn-fx-2 em * {
    color: var(--color-primary);
    padding: 0.25em 0;
    will-change: transform;
    transition: transform 0.3s;
}

.btn-fx-2 em:last-child {
    position: absolute;
    top: 0;
    left: 0;
}

.btn-fx-2 em:last-child * {
    transform: translateY(100%);
}

.btn-fx-2::before,
.btn-fx-2::after {
    content: "";
    position: absolute;
    bottom: 0;
    height: 2px;
    left: 0;
    width: 100%;
}

.btn-fx-2::before {
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.btn-fx-2::after {
    background-color: var(--color-primary);
    transform: scaleX(0);
    transition: transform 0.3s;
    transform-origin: right center;
}

.btn-fx-2:hover em *:nth-child(2) {
    transition-delay: 0.05s;
}

.btn-fx-2:hover em *:nth-child(3) {
    transition-delay: 0.1s;
}

.btn-fx-2:hover em *:nth-child(4) {
    transition-delay: 0.15s;
}

.btn-fx-2:hover em *:nth-child(5) {
    transition-delay: 0.2s;
}

.btn-fx-2:hover em *:nth-child(6) {
    transition-delay: 0.25s;
}

.btn-fx-2:hover em *:nth-child(7) {
    transition-delay: 0.3s;
}

.btn-fx-2:hover em *:nth-child(8) {
    transition-delay: 0.35s;
}

.btn-fx-2:hover em *:nth-child(9) {
    transition-delay: 0.4s;
}

.btn-fx-2:hover em *:nth-child(10) {
    transition-delay: 0.45s;
}

.btn-fx-2:hover em:first-child * {
    transform: translateY(-100%);
}

.btn-fx-2:hover em:last-child * {
    transform: translateY(0);
}

.btn-fx-2:hover::after {
    transform: scaleX(1);
    transform-origin: left center;
}

.btn-fx-3 {
    --transition-duration: 0.3s;
    position: relative;
    display: inline-block;
    color: var(--color-bg);
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
    will-change: transform;
    transition: transform var(--transition-duration);
}

.btn-fx-3 span {
    will-change: transform;
    transition: opacity var(--transition-duration), transform var(--transition-duration) var(--ease-out);
}

.btn-fx-3::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-contrast-higher);
    border-radius: inherit;
    will-change: transform;
    transition: transform var(--transition-duration) var(--ease-out-back), box-shadow var(--transition-duration);
}

.btn-fx-3:active {
    transform: scale(0.9);
}

.btn-fx-3:hover span {
    opacity: 0;
    transform: scale(0.5);
}

.btn-fx-3:hover::before {
    transform: scale(1.1);
}

.btn-fx-3:hover .btn-fx-3__icon-wrapper {
    transform: translateY(0);
}

.btn-fx-3:focus {
    outline: none;
}

.btn-fx-3:focus::before {
    box-shadow: var(--shadow-sm), 0 0 0 3px hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.15);
}

.btn-fx-3__inner {
    position: relative;
    z-index: 2;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    -webkit-clip-path: inset(0%);
    clip-path: inset(0%);
}

.btn-fx-3__icon-wrapper {
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    will-change: transform;
    transform: translateY(100%);
    transition: transform var(--transition-duration) var(--ease-out);
}

.btn-fx-3__icon-wrapper .icon {
    margin: auto;
}

.btn-fx-4 {
    --transition-duration: .3s;
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-contrast-higher);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
    line-height: 1;
    text-decoration: none;
    color: var(--color-bg);
    transition: var(--transition-duration);
}

.btn-fx-4 span {
    position: relative;
    z-index: 2;
}

.btn-fx-4::before {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: hsla(var(--color-bg-h), var(--color-bg-s), var(--color-bg-l), 0.25);
    will-change: transform;
    transform: skewX(-15deg) translate(calc(-100% - 0.5em));
    pointer-events: none;
}

.btn-fx-4:hover::before {
    transform: skewX(-15deg) translate(calc(100% + 0.5em));
    transition: transform var(--transition-duration);
}

.btn-fx-4:focus {
    outline: none;
    box-shadow: var(--shadow-sm), 0 0 0 3px hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.15);
}

@media (min-width:64rem) {
    .adv-gallery-v3__title {
        border-top: 1px solid var(--color-contrast-lower);
        padding-top: var(--space-xs);
    }
}

.adv-gallery-v3__img-link {
    position: relative;
    display: block;
    text-decoration: none;
    color: inherit;
}

.adv-gallery-v3__img-link::before,
.adv-gallery-v3__img-link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 48px;
    height: 48px;
}

.adv-gallery-v3__img-link::before {
    -webkit-clip-path: polygon(100% 0%, 100% 0%, 100% 0%, 100% 0%);
    clip-path: polygon(100% 0%, 100% 0%, 100% 0%, 100% 0%);
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.9);
    transition: -webkit-clip-path 0.2s var(--ease-out);
    transition: clip-path 0.2s var(--ease-out);
    transition: clip-path 0.2s var(--ease-out), -webkit-clip-path 0.2s var(--ease-out);
}

.adv-gallery-v3__img-link::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpolyline points='4 2 14 2 14 12' fill='none' stroke='%23FFF' stroke-miterlimit='10' stroke-width='2'/%3E%3Cline x1='14' y1='2' x2='2' y2='14' fill='none' stroke='%23FFF' stroke-miterlimit='10' stroke-width='2'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    transform: scale(0.5) translateX(-5px) translateY(5px);
    will-change: transform;
    opacity: 0;
    transition: opacity 0.2s, transform 0.2s var(--ease-out);
}

.adv-gallery-v3__img-link:hover::before {
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
    clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.adv-gallery-v3__img-link:hover::after {
    transform: scale(1) translateX(0) translateY(0);
    opacity: 1;
}

:root {
    --author-img-size: 4em;
}

.author {
    display: grid;
    grid-template-columns: var(--author-img-size) 1fr;
    grid-gap: var(--space-sm);
}

.author__img-wrapper {
    display: inline-block;
    border-radius: 50%;
    width: var(--author-img-size);
    height: var(--author-img-size);
    overflow: hidden;
    transition: transform 0.3s var(--ease-out-back);
}

.author__img-wrapper:hover {
    transform: scale(1.1);
}

.author__img-wrapper img {
    display: block;
    width: inherit;
    height: inherit;
    -o-object-fit: cover;
    object-fit: cover;
}

.author__content a {
    color: inherit;
}

.author__content a:hover {
    color: inherit;
}

.author--meta {
    --author-img-size: 3em;
    align-items: center;
    grid-gap: var(--space-xs);
}

.author--minimal {
    --author-img-size: 2.4em;
    align-items: center;
    grid-gap: var(--space-xxs);
}

.author--featured {
    --author-img-size: 6em;
    grid-template-columns: 1fr;
    justify-content: center;
    text-align: center;
}

.author--featured .author__img-wrapper {
    margin-left: auto;
    margin-right: auto;
}

.author__social {
    --size: 40px;
    width: var(--size);
    height: var(--size);
    display: flex;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
    border-radius: 50%;
    transition: 0.2s;
}

.author__social .icon {
    --size: 16px;
    display: block;
    margin: auto;
    color: var(--color-contrast-higher);
    transition: color 0.2s;
}

.author__social:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
}

.author__social:hover .icon {
    color: var(--color-primary);
}

.pn-links {
    border-top: 1px solid var(--color-contrast-lower);
    border-bottom: 1px solid var(--color-contrast-lower);
}

.pn-links__item:first-child .pn-links__link {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.pn-links__link {
    display: flex;
    align-items: center;
    height: 100%;
    color: inherit;
    text-decoration: none;
    padding: var(--space-md);
}

.pn-links__link:hover {
    text-decoration: underline;
}

.pn-links__link:hover .pn-links__icon line:nth-child(1) {
    transform: rotate(180deg);
}

.pn-links__link:hover .pn-links__icon line:nth-child(2) {
    transform: rotate(-180deg);
}

.pn-links__link:hover .pn-links__icon line:nth-child(3) {
    stroke-dashoffset: 14;
}

.pn-links__icon {
    flex-shrink: 0;
}

.pn-links__icon line:nth-child(1),
.pn-links__icon line:nth-child(2) {
    transition: transform 0.3s var(--ease-out);
}

.pn-links__icon line:nth-child(1) {
    transform-origin: 42px 19px;
}

.pn-links__icon line:nth-child(2) {
    transform-origin: 42px 29px;
}

.pn-links__icon line:nth-child(3) {
    stroke-dasharray: 48;
    transition: stroke-dashoffset 0.3s var(--ease-out);
}

@media (min-width:64rem) {
    .pn-links__item:first-child .pn-links__link {
        border-bottom: none;
        border-right: 1px solid var(--color-contrast-lower);
    }
}

.sharebar__btn {
    --size: 60px;
    width: var(--size);
    height: var(--size);
    display: flex;
    background: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
    border-radius: 50%;
    transition: 0.2s;
}

.sharebar__btn .icon {
    --size: 24px;
    display: block;
    margin: auto;
    color: var(--color-contrast-high);
    transition: color 0.2s;
}

.sharebar__btn:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
    box-shadow: var(--shadow-sm);
}

.sharebar__btn:hover .icon {
    color: var(--color-contrast-higher);
}

.pagination__list>li {
    display: inline-block;
}

.pagination--split .pagination__list {
    width: 100%;
}

.pagination--split .pagination__list>*:first-child {
    margin-right: auto;
}

.pagination--split .pagination__list>*:last-child {
    margin-left: auto;
}

.pagination__item {
    display: inline-block;
    display: inline-flex;
    height: 100%;
    align-items: center;
    padding: var(--space-xs) calc(1.355 * var(--space-xs));
    white-space: nowrap;
    line-height: 1;
    border-radius: var(--radius-md);
    border-radius: 0;
    text-decoration: none;
    color: var(--color-contrast-high);
    will-change: transform;
    transition: 0.2s;
}

.pagination__item:hover:not(.pagination__item--selected):not(.pagination__item--ellipsis) {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
}

.pagination__item:active {
    transform: translateY(2px);
}

.pagination__item--selected {
    background-color: var(--color-contrast-higher);
    color: var(--color-bg);
    box-shadow: var(--shadow-sm);
    box-shadow: none;
}

.pagination__item--disabled {
    opacity: 0.5;
    pointer-events: none;
}

.pagination__jumper .form-control {
    width: 3em;
    margin-right: var(--space-xs);
}

.pagination__jumper em {
    flex-shrink: 0;
    white-space: nowrap;
}

.reading-progressbar {
    position: fixed;
    z-index: var(--z-index-fixed-element, 10);
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    color: var(--color-primary);
    pointer-events: none;
    display: none;
    transition: transform 0.2s;
}

.reading-progressbar--is-out {
    transform: translateY(-100%);
}

.reading-progressbar--is-active {
    display: block;
}

.reading-progressbar::-webkit-progress-bar {
    background-color: transparent;
}

.reading-progressbar::-webkit-progress-value {
    background-color: #000;
}

.reading-progressbar::-moz-progress-bar {
    background-color: #000;
}

.reading-progressbar__fallback {
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    background-color: #000;
}

:root {
    --drop-cap-lines: 3;
}

.drop-cap::first-letter {
    float: left;
    line-height: 1;
    font-size: calc(1em * var(--drop-cap-lines) * 1.4);
    padding: 0 0.125em 0 0;
    text-transform: uppercase;
    color: var(--color-contrast-higher);
}

.input-group {
    display: flex;
}

.input-group>* {
    position: relative;
}

.input-group>*:not(:last-child):not(:first-child) {
    border-radius: 0;
}

.input-group>*:first-child {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group>*:first-child .select__input {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.input-group>*:last-child {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input-group>*:last-child .select__input {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.input-group>*:focus,
.input-group *:focus-within {
    z-index: 1;
}

.input-group__tag {
    display: flex;
    align-items: center;
    padding: 0 var(--space-sm);
    background-color: var(--color-bg);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-contrast-lower);
    white-space: nowrap;
    color: var(--color-contrast-medium);
}

.input-group__tag:first-child {
    border-right-width: 0px;
}

.input-group__tag:last-child {
    border-left-width: 0px;
}

.input-group .select {
    --select-icon-size: 16px;
    --select-icon-right-margin: var(--space-sm);
    --select-text-icon-gap: var(--space-3xs);
}

.input-group .select .input-group__tag:focus {
    outline: 2px solid var(--color-primary);
}

:root {
    --switch-width: 64px;
    --switch-height: 32px;
    --switch-padding: 3px;
    --switch-animation-duration: 0.2s;
}

.switch {
    position: relative;
    display: inline-flex;
    flex-shrink: 0;
    align-items: center;
    width: var(--switch-width);
    height: var(--switch-height);
    border-radius: 50em;
    padding: var(--switch-padding) 0;
}

.switch__input,
.switch__label {
    position: absolute;
    left: 0;
    top: 0;
}

.switch__input {
    margin: 0;
    padding: 0;
    opacity: 0;
    height: 0;
    width: 0;
    pointer-events: none;
}

.switch__input:checked+.switch__label {
    background-color: var(--color-primary);
}

.switch__input:checked+.switch__label+.switch__marker {
    left: calc(100% - var(--switch-height) + var(--switch-padding));
}

.switch__input:focus+.switch__label,
.switch__input:active+.switch__label {
    box-shadow: 0 0 0 2px hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.2);
}

.switch__input:checked:focus+.switch__label,
.switch__input:checked:active+.switch__label {
    box-shadow: 0 0 0 2px hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.switch__label {
    width: 100%;
    height: 100%;
    color: transparent;
    -webkit-user-select: none;
    user-select: none;
    background-color: var(--color-bg-darker);
    border-radius: inherit;
    z-index: 1;
    transition: var(--switch-animation-duration);
    overflow: hidden;
}

.switch__marker {
    position: relative;
    background-color: var(--color-white);
    width: calc(var(--switch-height) - var(--switch-padding) * 2);
    height: calc(var(--switch-height) - var(--switch-padding) * 2);
    border-radius: 50%;
    z-index: 2;
    pointer-events: none;
    box-shadow: var(--shadow-xs);
    left: var(--switch-padding);
    transition: left var(--switch-animation-duration);
    will-change: left;
}

:root {
    --checkbox-radio-size: 18px;
    --checkbox-radio-gap: var(--space-2xs);
    --checkbox-radio-border-width: 1px;
    --checkbox-radio-line-height: 1.4;
    --radio-marker-size: 8px;
    --checkbox-marker-size: 12px;
    --checkbox-radius: 4px;
}

.radio,
.checkbox {
    position: absolute;
    padding: 0;
    margin: 0;
    margin-top: calc((1em * var(--checkbox-radio-line-height) - var(--checkbox-radio-size)) / 2);
    opacity: 0;
    height: var(--checkbox-radio-size);
    width: var(--checkbox-radio-size);
    pointer-events: none;
}

.radio+label,
.checkbox+label {
    display: inline-block;
    line-height: var(--checkbox-radio-line-height);
    -webkit-user-select: none;
    user-select: none;
    cursor: pointer;
    padding-left: calc(var(--checkbox-radio-size) + var(--checkbox-radio-gap));
}

.radio+label::before,
.checkbox+label::before {
    content: "";
    box-sizing: border-box;
    display: inline-block;
    position: relative;
    vertical-align: middle;
    top: -0.1em;
    margin-left: calc(-1 * (var(--checkbox-radio-size) + var(--checkbox-radio-gap)));
    flex-shrink: 0;
    width: var(--checkbox-radio-size);
    height: var(--checkbox-radio-size);
    background-color: var(--color-bg);
    border-width: var(--checkbox-radio-border-width);
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 0.65);
    border-style: solid;
    box-shadow: var(--shadow-xs);
    background-repeat: no-repeat;
    background-position: center;
    margin-right: var(--checkbox-radio-gap);
    transition: transform 0.2s, border 0.2s;
}

.radio:not(:checked):not(:focus)+label:hover::before,
.checkbox:not(:checked):not(:focus)+label:hover::before {
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 1);
}

.radio+label::before {
    border-radius: 50%;
}

.checkbox+label::before {
    border-radius: var(--checkbox-radius);
}

.radio:checked+label::before,
.checkbox:checked+label::before {
    background-color: var(--color-primary);
    box-shadow: var(--shadow-xs);
    border-color: var(--color-primary);
    transition: transform 0.2s;
}

.radio:active+label::before,
.checkbox:active+label::before {
    transform: scale(0.8);
    transition: transform 0.2s;
}

.radio:checked:active+label::before,
.checkbox:checked:active+label::before {
    transform: none;
    transition: none;
}

.radio:checked+label::before {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cg class='nc-icon-wrapper' fill='%23ffffff'%3E%3Ccircle cx='8' cy='8' r='8' fill='%23ffffff'%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
    background-size: var(--radio-marker-size);
}

.checkbox:checked+label::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpolyline points='1 6.5 4 9.5 11 2.5' fill='none' stroke='%23FFFFFF' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/svg%3E");
    background-size: var(--checkbox-marker-size);
}

.radio:checked:active+label::before,
.checkbox:checked:active+label::before,
.radio:focus+label::before,
.checkbox:focus+label::before {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.radio--bg+label,
.checkbox--bg+label {
    padding: var(--space-4xs) var(--space-3xs);
    padding-left: calc(var(--checkbox-radio-size) + var(--checkbox-radio-gap) + var(--space-3xs));
    border-radius: var(--radius-md);
    transition: background 0.2s;
}

.radio--bg+label:hover,
.checkbox--bg+label:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
}

.radio--bg:active+label,
.checkbox--bg:active+label,
.radio--bg:focus+label,
.checkbox--bg:focus+label {
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.1);
}

:root {
    --custom-checkbox-size: 20px;
    --custom-checkbox-radius: 4px;
    --custom-checkbox-border-width: 1px;
    --custom-checkbox-marker-size: 18px;
}

.custom-checkbox {
    position: relative;
    z-index: 1;
    display: inline-block;
    font-size: var(--custom-checkbox-size);
}

.custom-checkbox__input {
    position: relative;
    margin: 0;
    padding: 0;
    opacity: 0;
    height: 1em;
    width: 1em;
    display: block;
    z-index: 1;
}

.custom-checkbox__control {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1;
    pointer-events: none;
    transition: transform 0.2s;
    color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 0.65);
}

.custom-checkbox__control::before,
.custom-checkbox__control::after {
    content: "";
    position: absolute;
}

.custom-checkbox__control::before {
    width: 160%;
    height: 160%;
    background-color: currentColor;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
    border-radius: 50%;
    will-change: transform;
    transition: transform 0.2s;
}

.custom-checkbox__control::after {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-bg);
    border-radius: var(--custom-checkbox-radius);
    box-shadow: inset 0 0 0 var(--custom-checkbox-border-width) currentColor, var(--shadow-xs);
}

.custom-checkbox__input:checked~.custom-checkbox__control::after,
.custom-checkbox__input:indeterminate~.custom-checkbox__control::after {
    background-color: currentColor;
    background-repeat: no-repeat;
    background-position: center;
    background-size: var(--custom-checkbox-marker-size);
    box-shadow: none;
}

.custom-checkbox__input:checked~.custom-checkbox__control {
    color: #4A4A49;
}

.custom-checkbox__input:checked~.custom-checkbox__control::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpolyline points='2.5 8 6.5 12 13.5 3' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5'/%3E%3C/svg%3E");
}

.custom-checkbox__input:indeterminate~.custom-checkbox__control::after {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cline x1='2' y1='8' x2='14' y2='8' fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2'/%3E%3C/svg%3E");
}

.custom-checkbox__input:active~.custom-checkbox__control {
    transform: scale(0.9);
}

.custom-checkbox__input:checked:active~.custom-checkbox__control,
.custom-checkbox__input:indeterminate:active~.custom-checkbox__control {
    transform: scale(1);
}

.custom-checkbox__input:focus~.custom-checkbox__control::before {
    opacity: 0.2;
    transform: translate(-50%, -50%) scale(1);
}

.custom-checkbox--icon {
    --custom-checkbox-size: 32px;
}

.custom-checkbox--icon .custom-checkbox__control::after {
    display: none;
}

.custom-checkbox--icon .icon {
    display: block;
    color: inherit;
    position: relative;
    z-index: 1;
}

.swipe-content {
    height: 280px;
    width: 280px;
    background-color: var(--color-contrast-low);
    border-radius: var(--radius-md);
    cursor: default;
    transition: background 0.2s;
}

.swipe-content:active {
    background-color: var(--color-contrast-medium);
}

:root {
    --slideshow-height: 280px;
    --slideshow-fade-transition-duration: 0.25s;
    --slideshow-slide-transition-duration: 0.35s;
    --slideshow-prx-transition-duration: 0.5s;
    --slideshow-btn-width: 1.6em;
    --slideshow-btn-height: 3.2em;
    --slideshow-btn-icon-size: 1.6em;
    --slideshow-btn-offset: var(--space-xs);
}

@media (min-width:48rem) {
    :root {
        --slideshow-height: 380px;
    }
}

@media (min-width:64rem) {
    :root {
        --slideshow-height: 480px;
    }
}

@media (min-width:80rem) {
    :root {
        --slideshow-height: 580px;
    }
}

.slideshow__item {
    display: flex;
    align-items: center;
    justify-content: center;
    height: var(--slideshow-height);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.slideshow__item:focus {
    outline: none;
}

.slideshow--ratio-16\:9 .slideshow__item {
    height: 0;
    padding-bottom: 56.25%;
}

.slideshow--ratio-4\:3 .slideshow__item {
    height: 0;
    padding-bottom: 75%;
}

.slideshow--ratio-1\:1 .slideshow__item {
    height: 0;
    padding-bottom: 100%;
}

.slideshow {
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.slideshow__content {
    overflow: hidden;
}

.slideshow__item {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    visibility: hidden;
}

.slideshow__item--selected {
    position: relative;
    z-index: 3;
    visibility: visible;
}

.slideshow--transition-fade .slideshow__item {
    opacity: 0;
    transition: opacity 0s var(--slideshow-fade-transition-duration), visibility 0s var(--slideshow-fade-transition-duration);
}

.slideshow--transition-fade .slideshow__item--selected {
    opacity: 1;
    transition: opacity var(--slideshow-fade-transition-duration);
}

.slideshow--transition-slide .slideshow__item {
    animation-duration: var(--slideshow-slide-transition-duration);
    animation-fill-mode: forwards;
    animation-timing-function: var(--ease-out);
}

.slideshow--transition-slide .slideshow__item>* {
    visibility: hidden;
}

.slideshow--transition-slide .slideshow__item:not(.slideshow__item--selected) * {
    transition: none;
}

.slideshow--transition-slide .slideshow__item--selected>* {
    visibility: visible;
}

.slideshow--transition-slide .slideshow__item--slide-in-left {
    animation-name: slide-in-left;
}

.slideshow--transition-slide .slideshow__item--slide-in-right {
    animation-name: slide-in-right;
}

.slideshow--transition-slide .slideshow__item--slide-out-left {
    animation-name: slide-out-left;
}

.slideshow--transition-slide .slideshow__item--slide-out-right {
    animation-name: slide-out-right;
}

.slideshow--transition-slide .slideshow__item--slide-out-left,
.slideshow--transition-slide .slideshow__item--slide-out-right {
    z-index: 2;
}

.slideshow--transition-slide .slideshow__item--slide-out-left.slideshow__item--selected,
.slideshow--transition-slide .slideshow__item--slide-out-right.slideshow__item--selected {
    z-index: 3;
}

.slideshow--transition-slide .slideshow__item--slide-out-left>*,
.slideshow--transition-slide .slideshow__item--slide-out-right>* {
    visibility: visible;
}

@keyframes slide-in-left {
    0% {
        visibility: visible;
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes slide-in-right {
    0% {
        visibility: visible;
        transform: translateX(100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes slide-out-left {
    0% {
        visibility: visible;
        transform: translateX(0);
    }

    100% {
        transform: translateX(100%);
    }
}

@keyframes slide-out-right {
    0% {
        visibility: visible;
        transform: translateX(0);
    }

    100% {
        transform: translateX(-100%);
    }
}

.slideshow--transition-prx .slideshow__item {
    animation-duration: var(--slideshow-prx-transition-duration);
    animation-fill-mode: forwards;
    animation-timing-function: var(--ease-out);
}

.slideshow--transition-prx .slideshow__item>* {
    visibility: hidden;
}

.slideshow--transition-prx .slideshow__item--selected>* {
    visibility: visible;
}

.slideshow--transition-prx .slideshow__item--prx-in-left {
    animation-name: prx-in-left;
}

.slideshow--transition-prx .slideshow__item--prx-in-right {
    animation-name: prx-in-right;
}

.slideshow--transition-prx .slideshow__item--prx-out-left {
    animation-name: prx-out-left;
}

.slideshow--transition-prx .slideshow__item--prx-out-right {
    animation-name: prx-out-right;
}

.slideshow--transition-prx .slideshow__item--prx-out-left,
.slideshow--transition-prx .slideshow__item--prx-out-right {
    z-index: 2;
}

.slideshow--transition-prx .slideshow__item--prx-out-left.slideshow__item--selected,
.slideshow--transition-prx .slideshow__item--prx-out-right.slideshow__item--selected {
    z-index: 3;
}

.slideshow--transition-prx .slideshow__item--prx-out-left>*,
.slideshow--transition-prx .slideshow__item--prx-out-right>* {
    visibility: visible;
}

@keyframes prx-in-left {
    0% {
        visibility: visible;
        transform: translateX(-100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes prx-in-right {
    0% {
        visibility: visible;
        transform: translateX(100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes prx-out-left {
    0% {
        opacity: 1;
        visibility: visible;
        transform: translateX(0);
    }

    100% {
        opacity: 0.3;
        transform: translateX(40%);
    }
}

@keyframes prx-out-right {
    0% {
        opacity: 1;
        visibility: visible;
        transform: translateX(0);
    }

    100% {
        opacity: 0.3;
        transform: translateX(-40%);
    }
}

.slideshow[data-swipe=on] .slideshow__content {
    -webkit-user-select: none;
    user-select: none;
}

.slideshow[data-swipe=on] .slideshow__content img {
    pointer-events: none;
}

.slideshow__control {
    display: none;
}

.slideshow[data-controls=hover] .slideshow__control {
    opacity: 0;
    transition: opacity 0.3s;
}

.slideshow[data-controls=hover]:hover .slideshow__control {
    opacity: 1;
}

.slideshow[data-swipe=on] .slideshow__control {
    display: none;
}

.slideshow__control {
    display: block;
    position: absolute;
    z-index: 4;
    top: 50%;
    transform: translateY(-50%);
}

.slideshow__control:first-of-type {
    left: var(--slideshow-btn-offset);
}

.slideshow__control:last-of-type {
    right: var(--slideshow-btn-offset);
}

@media (min-width:64rem) {
    .slideshow[data-swipe=on] .slideshow__control {
        display: block;
    }
}

.slideshow__btn {
    display: block;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.75);
    height: var(--slideshow-btn-height);
    width: var(--slideshow-btn-width);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}

.slideshow__btn:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.85);
}

.slideshow__btn:hover .icon {
    color: var(--color-bg);
}

.slideshow:not(.slideshow--is-animating) .slideshow__btn:active {
    transform: translateY(2px);
}

.slideshow__btn .icon {
    display: block;
    width: var(--slideshow-btn-icon-size);
    height: var(--slideshow-btn-icon-size);
    margin: 0 auto;
    transition: color 0.2s;
    color: var(--color-white);
}

@supports (grid-area:auto) {
    .slideshow__btn {
        background-color: transparent;
    }

    .slideshow__btn .icon {
        color: var(--color-contrast-higher);
    }
}

.slideshow__navigation {
    position: absolute;
    z-index: 4;
    bottom: 0;
    width: 100%;
    height: 32px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: transparent;
}

.slideshow__nav-item {
    display: inline-block;
    margin: 0 var(--space-3xs);
}

.slideshow__nav-item button {
    display: block;
    position: relative;
    font-size: 8px;
    color: var(--color-contrast-high);
    height: 1em;
    width: 1em;
    border-radius: 50%;
    background-color: currentColor;
    opacity: 0.4;
    cursor: pointer;
    transition: background 0.3s;
}

.slideshow__nav-item button::before {
    content: "";
    position: absolute;
    top: calc(50% - 0.5em);
    left: calc(50% - 0.5em);
    height: 1em;
    width: 1em;
    font-size: 14px;
    border-radius: inherit;
    border: 1px solid var(--color-contrast-high);
    opacity: 0;
    transform: scale(0);
    transition: 0.3s;
}

.slideshow__nav-item button:focus {
    outline: none;
}

.slideshow__nav-item button:focus::before {
    opacity: 1;
    transform: scale(1);
}

.slideshow__nav-item--selected button {
    opacity: 1;
}

@media (min-width:64rem) {
    .slideshow__navigation {
        height: 40px;
    }

    .slideshow__nav-item button {
        font-size: 10px;
    }

    .slideshow__nav-item button::before {
        font-size: 16px;
    }
}

.modal {
    position: fixed;
    z-index: var(--z-index-overlay, 15);
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
    visibility: hidden;
}

.modal:not(.modal--is-visible) {
    pointer-events: none;
    background-color: transparent;
}

.modal--is-visible {
    opacity: 1;
    visibility: visible;
}

.modal__close-btn {
    display: flex;
    flex-shrink: 0;
    border-radius: 50%;
    transition: 0.2s;
}

.modal__close-btn .icon {
    display: block;
    margin: auto;
}

.modal__close-btn--outer {
    --size: 48px;
    width: var(--size);
    height: var(--size);
    position: fixed;
    top: var(--space-sm);
    right: var(--space-sm);
    z-index: var(--z-index-fixed-element, 10);
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.9);
    transition: 0.2s;
}

.modal__close-btn--outer .icon {
    color: var(--color-white);
    transition: transform 0.3s var(--ease-out-back);
}

.modal__close-btn--outer:hover {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 1);
}

.modal__close-btn--outer:hover .icon {
    transform: scale(1.1);
}

.modal__close-btn--inner {
    --size: 32px;
    width: var(--size);
    height: var(--size);
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    transition: 0.2s;
}

.modal__close-btn--inner .icon {
    color: inherit;
}

.modal__close-btn--inner:hover {
    background-color: var(--color-bg-lighter);
    box-shadow: var(--inner-glow), var(--shadow-md);
}

:root {
    --modal-transition-duration: 0.2s;
}

@media (prefers-reduced-motion:no-preference) {
    .modal--animate-fade {
        --modal-transition-duration: 0.2s;
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration);
    }

    .modal--animate-fade.modal--is-visible {
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s;
    }

    .modal--animate-scale,
    .modal--animate-translate-up,
    .modal--animate-translate-down,
    .modal--animate-translate-right,
    .modal--animate-translate-left {
        --modal-transition-duration: 0.2s;
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration);
    }

    .modal--animate-scale .modal__content,
    .modal--animate-translate-up .modal__content,
    .modal--animate-translate-down .modal__content,
    .modal--animate-translate-right .modal__content,
    .modal--animate-translate-left .modal__content {
        will-change: transform;
        transition: transform var(--modal-transition-duration) var(--ease-out);
    }

    .modal--animate-scale.modal--is-visible,
    .modal--animate-translate-up.modal--is-visible,
    .modal--animate-translate-down.modal--is-visible,
    .modal--animate-translate-right.modal--is-visible,
    .modal--animate-translate-left.modal--is-visible {
        transition: opacity var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s;
    }

    .modal--animate-scale.modal--is-visible .modal__content,
    .modal--animate-translate-up.modal--is-visible .modal__content,
    .modal--animate-translate-down.modal--is-visible .modal__content,
    .modal--animate-translate-right.modal--is-visible .modal__content,
    .modal--animate-translate-left.modal--is-visible .modal__content {
        transform: scale(1);
    }

    .modal--animate-slide-up,
    .modal--animate-slide-down,
    .modal--animate-slide-right,
    .modal--animate-slide-left {
        --modal-transition-duration: 0.3s;
        transition: opacity 0s var(--modal-transition-duration), background-color var(--modal-transition-duration), visibility 0s var(--modal-transition-duration);
    }

    .modal--animate-slide-up .modal__content,
    .modal--animate-slide-down .modal__content,
    .modal--animate-slide-right .modal__content,
    .modal--animate-slide-left .modal__content {
        will-change: transform;
        transition: transform var(--modal-transition-duration) var(--ease-out);
    }

    .modal--animate-slide-up.modal--is-visible,
    .modal--animate-slide-down.modal--is-visible,
    .modal--animate-slide-right.modal--is-visible,
    .modal--animate-slide-left.modal--is-visible {
        transition: background-color var(--modal-transition-duration), visibility 0s;
    }

    .modal--animate-slide-up.modal--is-visible .modal__content,
    .modal--animate-slide-down.modal--is-visible .modal__content,
    .modal--animate-slide-right.modal--is-visible .modal__content,
    .modal--animate-slide-left.modal--is-visible .modal__content {
        transform: scale(1);
    }

    .modal--animate-scale .modal__content {
        transform: scale(0.95);
    }

    .modal--animate-translate-up .modal__content {
        transform: translateY(40px);
    }

    .modal--animate-translate-down .modal__content {
        transform: translateY(-40px);
    }

    .modal--animate-translate-right .modal__content {
        transform: translateX(-40px);
    }

    .modal--animate-translate-left .modal__content {
        transform: translateX(40px);
    }

    .modal--animate-slide-up .modal__content {
        transform: translateY(100%);
    }

    .modal--animate-slide-down .modal__content {
        transform: translateY(-100%);
    }

    .modal--animate-slide-right .modal__content {
        transform: translateX(-100%);
    }

    .modal--animate-slide-left .modal__content {
        transform: translateX(100%);
    }
}

.modal--is-loading .modal__content {
    visibility: hidden;
}

.modal--is-loading .modal__loader {
    display: flex;
}

.modal__loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    display: none;
    pointer-events: none;
}

.modal-img-btn {
    position: relative;
    cursor: pointer;
}

.modal-img-btn::after {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0);
    transition: background 0.2s;
}

.modal-img-btn:hover::after {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.7);
}

.modal-img-btn:hover .modal-img-btn__icon-wrapper {
    opacity: 1;
}

.modal-img-btn__icon-wrapper {
    position: absolute;
    z-index: 2;
    top: calc(50% - 24px);
    left: calc(50% - 24px);
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.7);
    opacity: 0;
    transition: opacity 0.2s;
}

.modal-img-btn__icon-wrapper .icon {
    color: var(--color-white);
}

.menu {
    --menu-vertical-gap: 4px;
    --menu-item-padding: var(--space-3xs) var(--space-xs);
    list-style: none;
    -webkit-user-select: none;
    user-select: none;
    position: fixed;
    z-index: var(--z-index-popover, 5);
    width: 220px;
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-md);
    padding: var(--space-2xs) 0;
    border-radius: var(--radius-md);
    margin-top: var(--menu-vertical-gap);
    margin-bottom: var(--menu-vertical-gap);
    overflow: auto;
    font-size: 1rem;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.2s, opacity 0.2s;
}

.menu--is-visible {
    visibility: visible;
    opacity: 1;
    transition: visibility 0s, opacity 0.2s;
}

.menu--overlay {
    z-index: var(--z-index-overlay, 15);
}

.menu__content {
    display: flex;
    align-items: center;
    padding: var(--menu-item-padding);
    text-decoration: none;
    color: var(--color-contrast-high);
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: 0.2s;
}

.menu__content:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
}

.menu__content:focus {
    outline: none;
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.15);
}

.menu__label {
    padding: var(--menu-item-padding);
    font-size: 0.8125rem;
    color: var(--color-contrast-medium);
}

.menu__separator {
    height: 1px;
    background-color: var(--color-contrast-lower);
    margin: var(--menu-item-padding);
}

.menu__icon {
    color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.5);
    margin-right: var(--space-2xs);
}

:root {
    --menu-bar-button-size: 2.5em;
    --menu-bar-icon-size: 1em;
    --menu-bar-horizontal-gap: var(--space-2xs);
    --menu-bar-vertical-gap: 4px;
    --menu-bar-label-size: var(--text-xs);
}

.menu-bar {
    list-style: none;
    display: inline-flex;
    align-items: center;
}

.menu-bar__item {
    position: relative;
    display: inline-block;
    display: flex;
    align-items: center;
    justify-content: center;
    height: var(--menu-bar-button-size);
    width: var(--menu-bar-button-size);
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.2s;
}

.menu-bar__item:not(:last-child) {
    margin-right: var(--menu-bar-horizontal-gap);
}

.menu-bar__item:hover,
.menu-bar__item.menu-control--active {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
}

.menu-bar__item:hover>.menu-bar__icon,
.menu-bar__item.menu-control--active>.menu-bar__icon {
    color: var(--color-contrast-higher);
}

.menu-bar__item:hover>.menu-bar__label,
.menu-bar__item.menu-control--active>.menu-bar__label {
    clip: auto;
    -webkit-clip-path: none;
    clip-path: none;
    height: auto;
    width: auto;
}

.menu-bar__item:focus {
    outline: none;
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.1);
}

.menu-bar__item:active {
    background-color: var(--color-contrast-low);
}

.menu-bar__item:focus:active {
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.menu-bar__item--trigger {
    display: none;
}

.menu-bar__icon {
    display: block;
    color: var(--color-contrast-high);
    font-size: var(--menu-bar-icon-size);
    transition: color 0.2s;
}

.menu-bar__label {
    position: absolute;
    z-index: var(--z-index-popover, 5);
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
    width: 1px;
    height: 1px;
    overflow: hidden;
    white-space: nowrap;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(var(--menu-bar-vertical-gap));
    padding: var(--space-2xs) var(--space-xs);
    color: var(--color-bg);
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.95);
    border-radius: var(--radius-md);
    font-size: var(--menu-bar-label-size);
    pointer-events: none;
    -webkit-user-select: none;
    user-select: none;
}

.menu-bar--collapsed .menu-bar__item--hide {
    display: none;
}

.menu-bar--collapsed .menu-bar__item--trigger {
    display: inline-block;
    display: flex;
}

.menu-bar {
    opacity: 0;
}

.menu-bar::before {
    display: none;
    content: "collapsed";
}

.menu-bar--loaded {
    opacity: 1;
}

@media (min-width:32rem) {
    .menu-bar--expanded\@xs::before {
        content: "expanded";
    }
}

@media (min-width:48rem) {
    .menu-bar--expanded\@sm::before {
        content: "expanded";
    }
}

@media (min-width:64rem) {
    .menu-bar--expanded\@md::before {
        content: "expanded";
    }
}

@media (min-width:80rem) {
    .menu-bar--expanded\@lg::before {
        content: "expanded";
    }
}

@media (min-width:90rem) {
    .menu-bar--expanded\@xl::before {
        content: "expanded";
    }
}

:root {
    --exp-gallery-animation-duration: 0.3s;
}

.exp-gallery-item-hidden {
    opacity: 0;
}

.exp-lightbox {
    transition: background var(--exp-gallery-animation-duration);
}

.exp-lightbox .menu-bar {
    --menu-bar-button-size: 2.2em;
    --menu-bar-icon-size: 1.2em;
    --menu-bar-horizontal-gap: var(--space-2xs);
    --menu-bar-vertical-gap: 4px;
    --menu-bar-label-size: var(--text-xs);
}

.exp-lightbox .slideshow {
    --slideshow-btn-width: 1.6em;
    --slideshow-btn-height: 3.2em;
    --slideshow-btn-icon-size: 1.6em;
    --slideshow-btn-offset: var(--space-md);
}

.exp-lightbox .slideshow__content {
    position: relative;
}

.exp-lightbox:not(.modal--is-visible) {
    background-color: transparent;
}

.exp-lightbox__content {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
}

.exp-lightbox__header {
    position: relative;
    z-index: 2;
    flex-shrink: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-xs) var(--space-md) 0;
}

.exp-lightbox__title {
    font-size: var(--text-md);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: var(--space-sm);
}

.exp-lightbox__body {
    position: relative;
    z-index: 1;
    flex-grow: 1;
    padding: var(--space-md);
}

@media (min-width:64rem) {
    .exp-lightbox__body {
        padding-top: var(--space-xs);
        padding-bottom: var(--space-xs);
        padding-right: calc(var(--space-xs) + var(--slideshow-btn-width) + var(--slideshow-btn-offset));
        padding-left: calc(var(--space-xs) + var(--slideshow-btn-width) + var(--slideshow-btn-offset));
    }
}

.exp-lightbox {
    --slideshow-height: 100%;
}

.exp-lightbox .slideshow {
    display: flex;
    align-items: stretch;
}

.exp-lightbox .slideshow__content {
    flex-grow: 1;
}

.exp-lightbox--no-transition .slideshow__content * {
    transition: none !important;
    animation: none !important;
}

.exp-lightbox__media {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    max-height: 100%;
    max-width: 100%;
}

.exp-lightbox__media-outer {
    position: relative;
    width: 100%;
    flex-grow: 1;
}

.slideshow__content--hide .exp-lightbox__media-outer {
    opacity: 0;
}

.exp-lightbox__media-inner {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.exp-lightbox__media-inner img {
    display: inline-block;
    height: auto;
    width: auto;
    max-height: 100%;
}

.exp-lightbox.modal--is-visible .slideshow[data-swipe=on] .exp-lightbox__media-inner img {
    pointer-events: auto;
    -webkit-user-select: none;
    user-select: none;
}

.exp-lightbox__caption {
    flex-shrink: 0;
    text-align: center;
    max-width: 600px;
    margin-top: var(--space-xs);
    font-size: var(--text-sm);
}

.exp-lightbox__media-outer {
    min-height: 200px;
}

@supports (display:flex) {
    .exp-lightbox__media-outer {
        min-height: 0;
    }
}

.exp-lightbox__clone-img-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--z-index-overlay, 15);
    pointer-events: none;
    visibility: hidden;
    opacity: 0;
    transform-origin: top left;
    transition: transform var(--exp-gallery-animation-duration) var(--ease-out);
    will-change: transform;
}

.exp-lightbox__clone-img-wrapper svg,
.exp-lightbox__clone-img-wrapper rect,
.exp-lightbox__clone-img-wrapper image {
    height: 100%;
    width: 100%;
}

.exp-lightbox__clone-img-wrapper--is-visible {
    visibility: visible;
    opacity: 1;
}

.exp-lightbox__body[data-zoom=on] .exp-lightbox__media-inner img {
    cursor: zoom-in;
}

.exp-lightbox__zoom {
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 3;
    overflow: auto;
    background-color: var(--color-bg);
    cursor: zoom-out;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0s 0.3s, visibility 0s 0.3s;
}

.exp-lightbox__zoom img {
    display: block;
    width: 100%;
    max-width: none;
    transform-origin: top left;
    transition: transform 0.3s;
}

.exp-lightbox__zoom--no-transition img {
    transition: none;
}

.exp-lightbox__zoom--is-visible {
    opacity: 1;
    visibility: visible;
    transition: none;
}

.exp-gallery img {
    display: block;
    width: 100%;
    transition: opacity 0.3s;
}

.exp-gallery img:hover {
    cursor: pointer;
    opacity: 0.85;
}

.sticky-banner {
    position: fixed;
    top: -1px;
    left: 0;
    width: 100%;
    z-index: var(--z-index-fixed-element, 10);
    transform: translateY(-100%);
    transition: transform 0.3s;
}

.sticky-banner--bottom {
    top: auto;
    bottom: -1px;
    transform: translateY(100%);
}

.sticky-banner--visible {
    transform: translateY(0);
}

.sticky-banner:not(.sticky-banner--visible) {
    box-shadow: none;
}

.hero-video-bg__video {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
    z-index: 1;
}

.hero-video-bg__video video {
    position: relative;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    min-height: 100%;
    min-width: 100%;
    height: auto;
    width: auto;
    max-width: none;
}

@supports ((-o-object-fit:cover) or (object-fit:cover)) {
    .hero-video-bg__video video {
        -o-object-fit: cover;
        object-fit: cover;
        height: 100%;
        width: 100%;
    }
}

@supports ((-o-object-fit:cover) or (object-fit:cover)) and (-ms-ime-align:auto) {
    .hero-video-bg__video video {
        height: auto;
        width: auto;
    }
}

.hero-video-bg__video img {
    display: none;
}

@media (prefers-reduced-motion:reduce) {
    .hero-video-bg__video video {
        visibility: hidden;
    }

    .hero-video-bg__video img {
        display: block;
        position: absolute;
        -o-object-fit: cover;
        object-fit: cover;
        height: 100%;
        width: 100%;
    }
}

.hero-video-bg__play-btn {
    --btn-size: 80px;
    width: var(--btn-size);
    height: var(--btn-size);
    display: inline-flex;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.85);
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s;
}

.hero-video-bg__play-btn .icon {
    display: block;
    margin: auto;
    color: var(--color-bg);
    font-size: 32px;
    transition: transform 0.3s var(--ease-out-back);
}

.hero-video-bg__play-btn:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 1);
}

.hero-video-bg__play-btn:hover .icon {
    transform: scale(1.2);
}

.hero-overlay {
    position: relative;
    overflow: hidden;
}

.hero-overlay::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1;
}

.video-card__modal-control {
    display: block;
    color: inherit;
    text-decoration: none;
    position: relative;
    margin-bottom: var(--space-sm);
}

.video-card__modal-control:hover .video-card__preview {
    filter: contrast(110%);
    box-shadow: var(--shadow-md);
}

.video-card__modal-control:hover .video-card__play-btn::before {
    transform: scale(1.2);
}

.video-card__preview {
    display: block;
    width: 100%;
    aspect-ratio: 4/3;
    -o-object-fit: cover;
    object-fit: cover;
    border-radius: var(--radius-lg);
    border-radius: 0;
    box-shadow: var(--shadow-sm);
    box-shadow: none;
    transition: filter 0.3s, box-shadow 0.3s;
}

.video-card__play-btn {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.video-card__play-btn .icon {
    position: relative;
    z-index: 1;
}

.video-card__play-btn::before {
    content: "";
    position: absolute;
    width: 60px;
    height: 60px;
    top: calc(50% - 30px);
    left: calc(50% - 30px);
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.8);
    border-radius: 50%;
    transition: transform 0.3s var(--ease-out-back);
}

:root {
    --select-icon-size: 16px;
    --select-icon-right-margin: var(--space-sm);
    --select-text-icon-gap: var(--space-3xs);
}

.select {
    position: relative;
}

.select__input {
    width: 100%;
    height: 100%;
    padding-right: calc(var(--select-icon-size) + var(--select-icon-right-margin) + var(--select-text-icon-gap)) !important;
    -webkit-user-select: none;
    user-select: none;
}

.select__icon {
    width: var(--select-icon-size);
    height: var(--select-icon-size);
    pointer-events: none;
    position: absolute;
    right: var(--select-icon-right-margin);
    top: 50%;
    transform: translateY(-50%);
}

:root {
    --select-dropdown-gap: 4px;
}

.select__button {
    width: 100%;
}

.select__button[aria-expanded=true] {}

.select__dropdown {
    position: absolute;
    left: 0;
    top: 100%;
    min-width: 200px;
    max-height: 1px;
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-md);
    padding: var(--space-3xs) 0;
    border-radius: var(--radius-md);
    z-index: var(--z-index-popover, 5);
    margin-top: var(--select-dropdown-gap);
    margin-bottom: var(--select-dropdown-gap);
    overflow: auto;
    font-size: 1rem;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.2s, opacity 0.2s;
}

.select__dropdown--right {
    right: 0;
    left: auto;
}

.select__dropdown--up {
    bottom: 100%;
    top: auto;
}

.select__button[aria-expanded=true]+.select__dropdown {
    visibility: visible;
    opacity: 1;
    transition: visibility 0s, opacity 0.2s;
}

.select__list {
    list-style: none !important;
}

.select__list:not(:first-of-type) {
    padding-top: var(--space-2xs);
}

.select__list:not(:last-of-type) {
    border-bottom: 1px solid hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.1);
    padding-bottom: var(--space-2xs);
}

.select__item {
    display: flex;
    align-items: center;
    padding: var(--space-2xs) var(--space-sm);
    color: var(--color-contrast-high);
    width: 100%;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.select__item--optgroup {
    font-size: 0.8125rem;
    color: var(--color-contrast-medium);
}

.select__item--option {
    cursor: pointer;
    transition: 0.2s;
}

.select__item--option:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.075);
}

.select__item--option:focus {
    outline: none;
    background-color: hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.15);
}

.select__item--option[aria-selected=true] {
    background-color: var(--color-primary);
    color: var(--color-white);
    position: relative;
}

.select__item--option[aria-selected=true]::after {
    content: "";
    display: block;
    height: 1em;
    width: 1em;
    margin-left: auto;
    background-color: currentColor;
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpolyline stroke-width='2' stroke='%23ffffff' fill='none' stroke-linecap='round' stroke-linejoin='round' points='1,9 5,13 15,3 '/%3E%3C/svg%3E");
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpolyline stroke-width='2' stroke='%23ffffff' fill='none' stroke-linecap='round' stroke-linejoin='round' points='1,9 5,13 15,3 '/%3E%3C/svg%3E");
}

.select__item--option[aria-selected=true]:focus {
    box-shadow: inset 0 0 0 2px var(--color-primary-dark);
}

.select__item--option[disabled] {
    opacity: 0.5;
    cursor: not-allowed;
}

:root {
    --drawer-width: 400px;
}

.drawer {
    position: fixed;
    z-index: var(--z-index-overlay, 15);
    height: 100%;
    width: 100%;
    max-width: var(--drawer-width);
    top: 0;
    right: 0;
    visibility: hidden;
    transition: visibility 0s 0.3s;
}

.drawer:focus {
    outline: none;
}

.drawer--is-visible {
    visibility: visible;
    transition: none;
}

.drawer--open-left {
    right: auto;
    left: 0;
}

.drawer__content {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    transform: translateX(100%);
    transition: transform 0.3s;
    transition-timing-function: var(--ease-in-out);
}

.drawer--open-left .drawer__content {
    transform: translateX(-100%);
}

.drawer--is-visible .drawer__content {
    transform: translateX(0);
}

.drawer__body {
    height: 100%;
    overflow: auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
}

.drawer__close-btn {
    --size: 32px;
    width: var(--size);
    height: var(--size);
    flex-shrink: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background-color: hsla(var(--color-bg-light-h), var(--color-bg-light-s), var(--color-bg-light-l), 0.95);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    transition: 0.2s;
}

.drawer__close-btn:hover {
    background-color: var(--color-bg-lighter);
    box-shadow: var(--inner-glow), var(--shadow-md);
}

.drawer__close-btn .icon {
    display: block;
    color: var(--color-contrast-high);
}

.drawer--modal {
    max-width: none;
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0);
    transition: background-color 0.3s, visibility 0s 0.3s;
}

.drawer--modal.drawer--is-visible {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.75);
    transition: background-color 0.3s;
}

.drawer--modal.drawer--open-left .drawer__content {
    right: auto;
    left: 0;
}

.drawer--modal .drawer__content {
    max-width: var(--drawer-width);
}

.dr-cart__product {
    display: grid;
    grid-template-columns: 80px 1fr auto;
    grid-gap: var(--space-xs);
    align-items: start;
    padding: var(--space-sm) 0;
}

.dr-cart__product:not(:last-child) {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.dr-cart__img {
    display: block;
    overflow: hidden;
    border-radius: var(--radius-md);
    transition: 0.2s;
}

.dr-cart__img img {
    display: block;
}

.dr-cart__img:hover {
    opacity: 0.85;
}

.dr-cart__select {
    --select-icon-size: 0.85em;
    --select-icon-right-margin: var(--space-2xs);
    font-size: 0.875em;
    width: 3.6em;
}

.dr-cart__select .select__input {
    padding: var(--space-4xs) var(--space-3xs);
}

.dr-cart__remove-btn {
    font-size: var(--text-sm);
    color: var(--color-primary);
    cursor: pointer;
}

.dr-cart__remove-btn:hover {
    text-decoration: underline;
}

.dr-cart__remove-btn:focus {
    outline: 2px solid hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
    outline-offset: 2px;
}

:root {
    --cart-product-image-size: 96px;
}

@media (min-width:64rem) {
    :root {
        --cart-product-image-size: 128px;
    }
}

.cart {
    position: relative;
    z-index: 1;
}

.cart__product {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.cart__product:first-child {
    border-top: 1px solid var(--color-contrast-lower);
}

.cart__product-img {
    width: var(--cart-product-image-size);
    flex-shrink: 0;
}

.cart__product-img a,
.cart__product-img img {
    display: block;
    width: 100%;
}

.cart__product-img a {
    overflow: hidden;
    transition: opacity 0.2s;
}

.cart__product-img a:hover {
    opacity: 0.85;
}

.cart__product-info {
    flex-grow: 1;
    display: grid;
    grid-gap: var(--space-xs);
}

.cart__product-tot {
    display: grid;
    grid-gap: var(--space-xs);
}

.cart__select {
    --select-icon-size: 12px;
    --select-icon-right-margin: var(--space-sm);
    --select-text-icon-gap: var(--space-3xs);
    font-size: var(--text-sm);
    width: 6em;
}

.cart__remove-btn {
    font-size: var(--text-sm);
    color: var(--color-primary);
    cursor: pointer;
}

.cart__remove-btn:hover {
    text-decoration: underline;
}

.cart__remove-btn:focus {
    outline: 2px solid hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
    outline-offset: 2px;
}

.cart__gift-message {
    width: 100%;
    margin-top: var(--space-2xs);
    margin-bottom: var(--space-sm);
    display: none;
}

.cart__gift .radio:checked~.cart__gift-message {
    display: block;
}

@media (min-width:32rem) {
    .cart__product-info {
        grid-template-columns: 1fr auto;
        grid-gap: var(--space-md);
        justify-content: space-between;
        align-items: start;
    }

    .cart__product-tot {
        text-align: right;
    }

    .cart__select {
        margin-left: auto;
    }
}

@media (min-width:48rem) {

    .cart__product,
    .cart__product-info {
        align-items: center;
    }

    .cart__product-tot {
        grid-template-columns: auto minmax(6em, auto);
        grid-gap: var(--space-sm);
    }

    .cart__select {
        align-self: start;
    }
}

@media (min-width:64rem) {
    .cart__subtotal {
        position: sticky;
        top: var(--space-md);
        background-color: var(--color-bg-light);
        box-shadow: var(--inner-glow), var(--shadow-sm);
        border-radius: var(--radius-md);
        padding: var(--space-sm);
    }
}

:root {
    --choice-accordion-border-width: 1px;
    --choice-accordion-border-radius: var(--radius-md);
    --choice-accordion-input-size: 20px;
    --choice-accordion-input-icon-size: 16px;
    --choice-accordion-input-border-width: 1px;
    --choice-accordion-input-margin-right: var(--space-2xs);
}

.choice-accordion {
    border-width: var(--choice-accordion-border-width);
    border-color: var(--color-contrast-lower);
    border-style: solid;
    border-radius: var(--choice-accordion-border-radius);
    overflow: hidden;
}

.choice-accordion__btn {
    display: grid;
    grid-template-columns: var(--choice-accordion-input-size) 1fr;
    grid-gap: var(--choice-accordion-input-margin-right);
    align-items: center;
    cursor: pointer;
    background-color: var(--color-bg-light);
    border-top-width: var(--choice-accordion-border-width);
    border-style: solid;
    border-color: var(--color-contrast-lower);
}

.choice-accordion__item:first-child .choice-accordion__btn {
    border-top: none;
}

.choice-accordion__panel {
    position: relative;
    background-color: var(--color-bg-dark);
    overflow: hidden;
    will-change: height;
    transform: translateZ(0px);
}

.choice-accordion__panel::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: var(--choice-accordion-border-width);
    background-color: var(--color-contrast-lower);
    pointer-events: none;
}

.choice-accordion__input {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-bg-light);
    width: var(--choice-accordion-input-size);
    height: var(--choice-accordion-input-size);
    border-width: var(--choice-accordion-input-border-width);
    border-style: solid;
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 0.65);
    box-shadow: var(--shadow-xs);
    transition: 0.2s;
}

.choice-accordion__input .icon {
    color: var(--color-white);
    font-size: var(--choice-accordion-input-icon-size);
}

.choice-accordion__btn:hover .choice-accordion__input {
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 1);
}

.choice-accordion__btn--checked .choice-accordion__input,
.choice-accordion__btn--focus .choice-accordion__input,
.choice-accordion__btn--checked:hover .choice-accordion__input,
.choice-accordion__btn--focus:hover .choice-accordion__input {
    border-color: var(--color-primary);
}

.choice-accordion__btn--checked .choice-accordion__input {
    background-color: var(--color-primary);
}

.choice-accordion__btn--focus .choice-accordion__input {
    box-shadow: var(--shadow-xs), 0 0 0 3px hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.choice-accordion__input--checkbox {
    border-radius: 4px;
}

.choice-accordion__input--checkbox .icon>* {
    transition: stroke-dashoffset 0.3s;
    stroke-dasharray: 18;
    stroke-dashoffset: 18;
}

.choice-accordion__btn--checked .choice-accordion__input--checkbox .icon>* {
    stroke-dasharray: 18;
    stroke-dashoffset: 0;
}

.choice-accordion__input--radio {
    border-radius: 50%;
}

.choice-accordion__input--radio .icon {
    transition: transform 0.3s var(--ease-out-back);
    transform: scale(0);
}

.choice-accordion__btn--checked .choice-accordion__input--radio .icon {
    transform: scale(1);
}

.choice-accordion__fallback {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
}

:root {
    --choice-btn-border-width: 1px;
    --choice-btn-border-radius: var(--radius-md);
    --choice-btn-align-items: center;
    --choice-btn-input-size: 20px;
    --choice-btn-input-icon-size: 16px;
    --choice-btn-input-border-width: 1px;
    --choice-btn-input-margin-right: var(--space-sm);
    --choice-btn-input-translate-y: 0em;
}

.choice-btn__grid {
    display: none;
}

.choice-btn__fallback {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
}

.choice-btn {
    position: relative;
    background-color: var(--color-bg-light);
    border-radius: var(--choice-btn-border-radius);
    box-shadow: 0 0 0 var(--choice-btn-border-width) var(--color-contrast-lower);
    -webkit-user-select: none;
    user-select: none;
    cursor: pointer;
    transition: 0.2s;
}

.choice-btn.choice-btn--focus,
.choice-btn.choice-btn--checked,
.choice-btn:active {
    box-shadow: 0 0 0 2px var(--color-primary);
}

.choice-btn.choice-btn--focus,
.choice-btn:active {
    box-shadow: 0 0 0 2px var(--color-primary), 0 0 0 4px hsla(var(--color-primary-h), var(--color-primary-s), var(--color-primary-l), 0.2);
}

.choice-btn__grid {
    display: block;
    display: grid;
    grid-template-columns: var(--choice-btn-input-size) 1fr;
    grid-gap: var(--choice-btn-input-margin-right);
    align-items: var(--choice-btn-align-items);
}

.choice-btn__input {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-bg-light);
    width: var(--choice-btn-input-size);
    height: var(--choice-btn-input-size);
    border-width: var(--choice-btn-input-border-width);
    border-style: solid;
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 0.65);
    box-shadow: var(--shadow-xs);
    position: relative;
    top: var(--choice-btn-input-translate-y);
    transition: 0.2s;
}

.choice-btn__input .icon {
    color: var(--color-white);
    font-size: var(--choice-btn-input-icon-size);
}

.choice-btn:hover:not(.choice-btn--checked) .choice-btn__input {
    border-color: hsla(var(--color-contrast-low-h), var(--color-contrast-low-s), var(--color-contrast-low-l), 1);
}

.choice-btn--checked .choice-btn__input {
    border-color: var(--color-primary);
    background-color: var(--color-primary);
}

.choice-btn__input--checkbox {
    border-radius: 4px;
}

.choice-btn__input--checkbox .icon>* {
    transition: stroke-dashoffset 0.3s;
    stroke-dasharray: 18;
    stroke-dashoffset: 18;
}

.choice-btn--checked .choice-btn__input--checkbox .icon>* {
    stroke-dasharray: 18;
    stroke-dashoffset: 0;
}

.choice-btn__input--radio {
    border-radius: 50%;
}

.choice-btn__input--radio .icon {
    transition: transform 0.3s var(--ease-out-back);
    transform: scale(0);
}

.choice-btn--checked .choice-btn__input--radio .icon {
    transform: scale(1);
}

:root {
    --order-summary-img-size: 3.6em;
    --order-summary-img-margin-right: var(--space-xs);
}

.order-summary__header {
    border-radius: inherit;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
}

.order-summary__footer {
    border-radius: inherit;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
}

.order-summary__item {
    display: grid;
    grid-template-columns: var(--order-summary-img-size) 1fr;
    grid-gap: var(--order-summary-img-margin-right);
    align-items: center;
}

.order-summary__img {
    display: block;
    width: var(--order-summary-img-size);
    height: var(--order-summary-img-size);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: 0.2s;
}

.order-summary__img img {
    display: block;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
}

.order-summary__img:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

.checkout {
    position: relative;
    z-index: 1;
}

.checkout__billing-checkbox {
    display: none;
}

@media (min-width:80rem) {
    .checkout .order-summary {
        position: sticky;
        top: var(--space-sm);
        max-height: calc(100vh - var(--space-sm));
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
}

.checkout__billing-checkbox {
    display: block;
}

.checkout__billing-info {
    display: none;
}

.table {
    position: relative;
    z-index: 1;
}

.table:not(.table--expanded) {
    border-collapse: separate;
    border-spacing: 0 var(--space-md);
    margin-top: calc(-2 * var(--space-md));
}

.table:not(.table--expanded) .table__header {
    position: absolute;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(50%);
    clip-path: inset(50%);
}

.table:not(.table--expanded) .table__row .table__cell:first-child {
    border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.table:not(.table--expanded) .table__row .table__cell:last-child {
    border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.table:not(.table--expanded) .table__row .table__cell:last-child::after {
    display: none;
}

.table:not(.table--expanded) .table__cell {
    position: relative;
    display: flex;
    justify-content: space-between;
    width: 100%;
    text-align: right;
    padding: var(--space-md);
    background-color: var(--color-bg-light);
}

.table:not(.table--expanded) .table__cell::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: var(--space-md);
    width: calc(100% - 2 * var(--space-md));
    height: 1px;
    background-color: var(--color-contrast-lower);
}

.table:not(.table--expanded) .table__label {
    font-weight: bold;
    text-align: left;
    color: var(--color-contrast-higher);
    margin-right: var(--space-md);
}

.table--expanded {
    border-bottom: 1px solid var(--color-contrast-lower);
}

.table--expanded .table__header .table__cell {
    position: relative;
    z-index: 10;
    background-color: var(--color-bg);
    border-bottom: 1px solid var(--color-contrast-lower);
    font-weight: bold;
    color: var(--color-contrast-higher);
}

.table--expanded .table__body .table__row:nth-child(odd) {
    background-color: hsla(var(--color-bg-dark-h), var(--color-bg-dark-s), var(--color-bg-dark-l), 0.85);
}

.table--expanded .table__cell {
    padding: var(--space-sm);
}

.table--expanded .table__label {
    display: none;
}

.table--expanded .table__header--sticky .table__cell {
    position: sticky;
    top: 0;
}

.table {
    opacity: 0;
}

.table--loaded {
    opacity: 1;
}

[class*=table--expanded]::before {
    display: none;
}

.table--expanded\@xs::before {
    content: "collapsed";
}

@media (min-width:32rem) {
    .table--expanded\@xs::before {
        content: "expanded";
    }
}

.table--expanded\@sm::before {
    content: "collapsed";
}

@media (min-width:48rem) {
    .table--expanded\@sm::before {
        content: "expanded";
    }
}

.table--expanded\@md::before {
    content: "collapsed";
}

@media (min-width:64rem) {
    .table--expanded\@md::before {
        content: "expanded";
    }
}

.table--expanded\@lg::before {
    content: "collapsed";
}

@media (min-width:80rem) {
    .table--expanded\@lg::before {
        content: "expanded";
    }
}

.table--expanded\@xl::before {
    content: "collapsed";
}

@media (min-width:90rem) {
    .table--expanded\@xl::before {
        content: "expanded";
    }
}

.sidenav-v2::after {
    content: "";
    display: table;
    clear: both;
}

.sidenav-v2__control {
    width: 100%;
    padding: var(--space-sm);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sidenav-v2__control-text {
    position: relative;
}

.sidenav-v2__control-text>* {
    display: inline-block;
    transition: opacity 0.4s, transform 0.4s var(--ease-out);
}

.sidenav-v2__control-text>*:last-child {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-10px);
}

.sidenav-v2__icon-arrow .icon__group {
    will-change: transform;
    transform-origin: 8px 8px;
    transition: transform 0.3s var(--ease-out);
}

.sidenav-v2__icon-arrow .icon__group>* {
    transform-origin: 8px 8px;
    stroke-dasharray: 17;
    transform: translateY(3px);
    transition: transform 0.3s, stroke-dashoffset 0.3s;
    transition-timing-function: var(--ease-out);
}

.sidenav-v2__icon-arrow .icon__group>*:first-child {
    stroke-dashoffset: 8.5;
}

.sidenav-v2__icon-arrow .icon__group>*:last-child {
    stroke-dashoffset: 8.5;
}

.sidenav-v2__list:not(:last-child) {
    margin-bottom: var(--space-sm);
}

.sidenav-v2__label {
    margin-bottom: var(--space-4xs);
}

.sidenav-v2__label>* {
    color: var(--color-contrast-medium);
    font-size: var(--text-sm);
}

.sidenav-v2__link {
    display: flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-contrast-high);
    transition: 0.2s;
}

.sidenav-v2__link:hover {
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.05);
}

.sidenav-v2__link[aria-current=page] {
    background-color: var(--color-contrast-higher);
    color: var(--color-bg);
}

.sidenav-v2__link-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-right: var(--space-3xs);
}

.sidenav-v2__counter {
    display: inline-flex;
    background-color: hsla(var(--color-contrast-higher-h), var(--color-contrast-higher-s), var(--color-contrast-higher-l), 0.15);
    font-size: var(--text-xs);
    padding: var(--space-4xs) var(--space-2xs);
    border-radius: 50em;
    margin-left: auto;
}

.sidenav-v2:not(.sidenav-v2--static) {
    border-radius: var(--radius-md);
    background-color: var(--color-bg-light);
    box-shadow: var(--inner-glow), var(--shadow-sm);
    transition: 0.3s;
}

.sidenav-v2:not(.sidenav-v2--static):hover {
    box-shadow: var(--inner-glow), var(--shadow-md);
}

.sidenav-v2:not(.sidenav-v2--static) .sidenav-v2__nav {
    display: none;
    margin: var(--space-2xs) 0;
}

.sidenav-v2:not(.sidenav-v2--static) .sidenav-v2__label {
    padding-left: var(--space-sm);
}

.sidenav-v2:not(.sidenav-v2--static) .sidenav-v2__link {
    padding: var(--space-2xs) var(--space-sm);
}

.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__control-text>*:first-child {
    transform: translateY(10px);
    opacity: 0;
    pointer-events: none;
}

.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__control-text>*:last-child {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__nav {
    display: block;
    animation: sidenav-v2-entry-animation 0.4s var(--ease-out);
}

.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__icon-arrow .icon__group {
    transform: rotate(-90deg);
}

.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__icon-arrow .icon__group>*:first-child,
.sidenav-v2:not(.sidenav-v2--static).sidenav-v2--expanded .sidenav-v2__icon-arrow .icon__group *:last-child {
    stroke-dashoffset: 0;
    transform: translateY(0px);
}

.sidenav-v2--static .sidenav-v2__control {
    display: none;
}

.sidenav-v2--static .sidenav-v2__link {
    padding: var(--space-2xs) var(--space-xs);
    border-radius: var(--radius-md);
}

.sidenav-v2--static .sidenav-v2__link[aria-current=page] {
    box-shadow: var(--shadow-sm);
}

@keyframes sidenav-v2-entry-animation {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0px);
    }
}

[class*=sidenav-v2--static]::before {
    display: none;
    content: "collapsed";
}

@media (min-width:32rem) {
    .sidenav-v2--static\@xs::before {
        content: "static";
    }
}

@media (min-width:48rem) {
    .sidenav-v2--static\@sm::before {
        content: "static";
    }
}

@media (min-width:64rem) {
    .sidenav-v2--static\@md::before {
        content: "static";
    }
}

@media (min-width:80rem) {
    .sidenav-v2--static\@lg::before {
        content: "static";
    }
}

@media (min-width:90rem) {
    .sidenav-v2--static\@xl::before {
        content: "static";
    }
}

.counter {
    background-color: var(--color-contrast-lower);
    padding: var(--space-3xs) var(--space-2xs);
    border-radius: 50em;
    font-size: var(--text-xs);
    line-height: 1;
}

.counter--primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.counter--critical {
    background-color: var(--color-error);
    color: var(--color-white);
}

.counter--light {
    background-color: hsla(var(--color-white-h), var(--color-white-s), var(--color-white-l), 0.9);
    color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.85);
}

.counter--dark {
    background-color: hsla(var(--color-black-h), var(--color-black-s), var(--color-black-l), 0.8);
    color: hsla(var(--color-white-h), var(--color-white-s), var(--color-white-l), 0.9);
}

.counter--docked {
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(50%, -50%);
}

:root {
    --password-btn-width: 3.5em;
    --password-icon-size: 1.5em;
}

.password {
    position: relative;
}

.password__input {
    height: 100%;
}

.password__btn {
    position: absolute;
    z-index: 1;
    top: 0;
    right: 0;
    height: 100%;
    width: var(--password-btn-width);
    background-color: rgba(255, 255, 255, 0);
    justify-content: center;
    align-items: center;
    display: none;
}

.password__btn:focus {
    color: var(--color-primary);
}

.password__btn-label:last-child {
    display: none;
}

.password__btn-label .icon {
    width: var(--password-icon-size);
    height: var(--password-icon-size);
}

.password--text-is-visible .password__btn-label:first-child {
    display: none;
}

.password--text-is-visible .password__btn-label:last-child {
    display: inline-block;
}

.password__input {
    padding-right: calc(var(--space-sm) + var(--password-btn-width));
}

.password__input::-ms-reveal {
    display: none;
}

.password__btn {
    display: flex;
}

body {
    background: linear-gradient(to bottom, white 99%, black 1%);
}

@media (min-width:64rem) {
    :root {
        --mega-nav-height: 150px;
    }

    .mega-nav__logo {
        display: block;
        width: 260px;
        height: 105px;
    }
}

.mega-nav__control {
    text-transform: uppercase;
}

.mega-nav--desktop .mega-nav__control {
    padding: 0 var(--space-sm);
}

.mega-nav--desktop {
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    -webkit-box-shadow: none;
}

.mega-nav--desktop .mega-nav__search--is-visible {
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
    -webkit-box-shadow: none;
}

.current a {
    font-weight: bold;
}

.mega-nav--mobile a[aria-current=page] {
    color: var(--color-black);
}

.btn--primary-subtle-white {
    background: transparent;
    color: var(--color-white);
    border: 1px solid white;
}

.font-secondary {
    font-family: var(--font-secondary);
}

.color-black {
    color: var(--color-black);
}

.boxed-title {
    display: inline-block;
    padding: 8px 20px;
    border: 1px solid #000;
}

html.lenis,
html.lenis body {
    height: auto;
}

.lenis.lenis-smooth {
    scroll-behavior: auto !important;
}

.lenis.lenis-smooth [data-lenis-prevent] {
    overscroll-behavior: contain;
}

.lenis.lenis-stopped {
    overflow: hidden;
}

.lenis.lenis-smooth iframe {
    pointer-events: none;
}