:root {
    font-size: 10px;

    --font-family-body: "Inter", sans-serif;
    --font-family-heading: "Chiswick Sans", "Nirand", sans-serif;
    --font-family-accent: "Chiswick Sans Text", "Nirand", sans-serif;

    --font-weight-light: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-body: var(--font-weight-regular);
    --font-weight-heading: var(--font-weight-light);
    --font-weight-accent: var(--font-weight-regular);

    --line-height-xs: 1;
    --line-height-sm: 1.3;
    --line-height-md: 1.5;
    --line-height-normal: normal;

    --font-size-3xs: 0.8rem;
    --font-size-2xs: 1rem;
    --font-size-xs: 1.2rem;
    --font-size-sm: 1.4rem;
    --font-size-md: 1.6rem;
    --font-size-lg: 1.8rem;
    --font-size-xl: 2rem;

    --font-size-h3: clamp(2.4rem, 2.2222222222vw, 3.2rem);
    --line-height-h3: var(--line-height-sm);
    --font-size-h2: clamp(2.8rem, 3.4722222222vw, 5rem);
    --line-height-h2: var(--line-height-sm);
    --font-size-h1: clamp(4rem, 5vw, 7.2rem);
    --line-height-h1: var(--line-height-xs);

    --font-size-body: var(--font-size-sm);
    --font-size-body-sm: var(--font-size-xs);
    --line-height-body: var(--line-height-md);

    --font-size-topic: var(--font-size-h3);
    --line-height-topic: var(--line-height-h3);

    --icon-size: var(--font-size-xl);
    --icon-size-sm: var(--font-size-2xs);

    --letter-spacing: 0.28rem;

    --text-decoration-thickness: 1px;
    --text-underline-offset: calc(var(--text-decoration-thickness) * 2);

    --color-black: #000000;
    --color-black-rgb: 0, 0, 0;
    --color-black-filter: brightness(0);

    --color-white: #ffffff;
    --color-white-rgb: 255, 255, 255;
    --color-white-filter: brightness(0) invert(1);

    --color-red: #ff0000;
    --color-red-rgb: 255, 0, 0;
    --color-red-filter: brightness(0) saturate(100%) invert(17%) sepia(100%) saturate(7058%) hue-rotate(9deg) brightness(98%) contrast(121%);

    --color-gray: #9c9c9c;
    --color-gray-rgb: 156, 156, 156;
    --color-gray-filter: brightness(0) saturate(100%) invert(70%) sepia(0%) saturate(0%) hue-rotate(143deg) brightness(91%) contrast(83%);

    --color-gray-light: #e4e4e4;
    --color-gray-light-rgb: 228, 228, 228;
    --color-gray-light-filter: brightness(0) saturate(100%) invert(99%) sepia(13%) saturate(435%) hue-rotate(197deg) brightness(119%) contrast(79%);

    --color-gray-bright: #f6f6f6;
    --color-gray-bright-rgb: 246, 246, 246;
    --color-gray-bright-filter: brightness(0) saturate(100%) invert(99%) sepia(5%) saturate(63%) hue-rotate(261deg) brightness(113%) contrast(93%);

    --color-primary: #605cff;
    --color-primary-rgb: 96, 92, 255;
    --color-primary-filter: brightness(0) saturate(100%) invert(30%) sepia(96%) saturate(2829%) hue-rotate(233deg) brightness(107%) contrast(101%);

    --color-secondary: #ff99fa;
    --color-secondary-rgb: 255, 153, 250;
    --color-secondary-filter: brightness(0) saturate(100%) invert(91%) sepia(7%) saturate(6893%) hue-rotate(272deg) brightness(105%) contrast(102%);

    --color-tertiary: #f0f0ff;
    --color-tertiary-rgb: 240, 240, 255;
    --color-tertiary-filter: brightness(0) saturate(100%) invert(87%) sepia(81%) saturate(4000%) hue-rotate(180deg) brightness(108%) contrast(104%);

    --color-background: var(--color-black);
    --color-background-rgb: var(--color-black-rgb);
    --color-background-filter: var(--color-black-filter);

    --rgb: var(--color-white-rgb);
    --rgb-couple: var(--color-black-rgb);
    --filter: var(--color-white-filter);
    --filter-couple: var(--color-black-filter);
    --color-link-hover: rgba(var(--rgb), 1);
    --color-link-active: rgba(var(--rgb), 1);

    --spacing-xl: 6rem;
    --spacing-lg: 4.8rem;
    --spacing-md: 3.6rem;
    --spacing-sm: 2rem;
    --spacing-xs: 1.5rem;
    --spacing-2xs: 1rem;
    --spacing-3xs: 0.5rem;
    --spacing-container: var(--spacing-sm);
    --spacing-section: var(--spacing-xl);
    --spacing-section-sm: var(--spacing-lg);
    --spacing-row: var(--spacing-md);
    --spacing-column: var(--spacing-sm);
    --spacing-content: var(--spacing-sm);
    --spacing-content-sm: var(--spacing-2xs);
    --spacing-content-xs: var(--spacing-3xs);

    --logo-height: 9rem;
    --logo-height-lg: 23.6rem;
    --header-navi-height: calc(var(--logo-height) + var(--spacing-container) * 2);
    --header-height: var(--header-navi-height);

    --border-width: 1px;
    --border-style: solid;
    --border-color: var(--color-secondary);
    --border: var(--border-width) var(--border-style) var(--border-color);
    --border-radius: 0.8rem;
    --border-radius-x2: 1.6rem;
    --border-radius-x3: 2.4rem;

    --input-height: 4.4rem;
    --input-spacing-y: 0.3em;
    --input-spacing-x: var(--spacing-xs);
    --input-color-border: var(--color-gray-light);
    --input-color-background: transparent;
    --input-color-text: var(--color-primary);
    --input-border: var(--border-width) var(--border-style) var(--input-color-border);
    --input-border-radius: 0px;

    --button-height: 4rem;
    --button-spacing-y: 0.3em;
    --button-spacing-x: var(--spacing-xs);
    --button-color-background: var(--color-white);
    --button-color-border: var(--color-white);
    --button-color-text: var(--color-black);
    --button-gradient-text: linear-gradient(90deg, #000 0%, #bcbcbc 73%, #f8f8f8 87%, #666 100%);
    --button-border-radius: 0px;

    --link-underline: 0 1px 0 0 currentColor;
    --link-underline-secondary: 0 1px 0 0 var(--color-secondary);

    --opacity: 0.5;
    --opacity-light: 0.2;
    --opacity-overlay: 0.6;

    --duration: 0.5s;
    --duration-slow: 1s;
    --duration-slower: 1.5s;
    --duration-fast: 200ms;
    --easing: ease;
    --easing-strong: cubic-bezier(0.165, 0.84, 0.44, 1);

    --padding-top-header: var(--header-height);
    --padding-bottom-header: var(--header-height);
}

/*FIX====================*/
.bg-black {
    --color-background: var(--color-black);
    --color-background-rgb: var(--color-black-rgb);
    --color-background-filter: var(--color-black-filter);
    background-color: rgba(var(--color-background-rgb), 1) !important;
}
.bg-white {
    --color-background: var(--color-white);
    --color-background-rgb: var(--color-white-rgb);
    --color-background-filter: var(--color-white-filter);
    background-color: rgba(var(--color-background-rgb), 1) !important;
}
.bg-primary {
    --color-background: var(--color-primary);
    --color-background-rgb: var(--color-primary-rgb);
    --color-background-filter: var(--color-primary-filter);
    background-color: rgba(var(--color-background-rgb), 1) !important;
}
.bg-secondary {
    --color-background: var(--color-secondary);
    --color-background-rgb: var(--color-secondary-rgb);
    --color-background-filter: var(--color-secondary-filter);
    background-color: rgba(var(--color-background-rgb), 1) !important;
}
.bg-body {
    background-color: var(--color-background) !important;
}

.c-black {
    --rgb: var(--color-black-rgb);
    --rgb-couple: var(--color-white-rgb);
    --filter: var(--color-black-filter);
    --filter-couple: var(--color-white-filter);
    --color-link-hover: rgba(var(--rgb), 1);
    --color-link-active: rgba(var(--rgb), 1);
    --button-color-background: var(--color-black);
    --button-color-border: var(--color-black);
    --button-color-text: var(--color-white);
    --button-gradient-text: linear-gradient(90deg, #fff 18%, #292929 77%, #666 91%, #f8f8f8 100%);
    color: rgba(var(--rgb), 1) !important;
}
.c-white {
    --rgb: var(--color-white-rgb);
    --rgb-couple: var(--color-black-rgb);
    --filter: var(--color-white-filter);
    --filter-couple: var(--color-black-filter);
    --color-link-hover: rgba(var(--rgb), 1);
    --color-link-active: rgba(var(--rgb), 1);
    --button-color-background: var(--color-white);
    --button-color-border: var(--color-white);
    --button-color-text: var(--color-black);
    --button-gradient-text: linear-gradient(90deg, #000 0%, #bcbcbc 73%, #f8f8f8 87%, #666 100%);
    color: rgba(var(--rgb), 1) !important;
}
.c-primary {
    --rgb: var(--color-primary-rgb);
    --rgb-couple: var(--color-white-rgb);
    --filter: var(--color-primary-filter);
    --filter-couple: var(--color-white-filter);
    --color-link-hover: rgba(var(--rgb), 1);
    --color-link-active: rgba(var(--rgb), 1);
    color: rgba(var(--rgb), 1) !important;
}
.c-secondary {
    --rgb: var(--color-secondary-rgb);
    --rgb-couple: var(--color-black-rgb);
    --filter: var(--color-secondary-filter);
    --filter-couple: var(--color-black-filter);
    --color-link-hover: rgba(var(--rgb), 1);
    --color-link-active: rgba(var(--rgb), 1);
    color: rgba(var(--rgb), 1) !important;
}

.filter-black {
    -webkit-filter: var(--color-black-filter) !important;
    filter: var(--color-black-filter) !important;
}
.filter-white {
    -webkit-filter: var(--color-white-filter) !important;
    filter: var(--color-white-filter) !important;
}
.filter-primary {
    -webkit-filter: var(--color-primary-filter) !important;
    filter: var(--color-primary-filter) !important;
}

.align-left {
    text-align: left !important;
}
.align-right {
    text-align: right !important;
}
.align-center {
    text-align: center !important;
}

.text-uppercase {
    text-transform: uppercase !important;
}
.text-capitalize {
    text-transform: capitalize !important;
}
.text-nowrap {
    white-space: nowrap !important;
}

.overflow-hidden {
    overflow: hidden !important;
}
.overflow-visible {
    overflow: visible !important;
}
.overflow-clip {
    overflow: clip !important;
}

.z-index-0 {
    z-index: 0 !important;
}
.z-index-1 {
    z-index: 1 !important;
}

.display-inline-block {
    display: inline-block !important;
}
.display-none {
    display: none !important;
}

.padding-0 {
    padding: 0 !important;
}
.padding-top-0 {
    padding-top: 0 !important;
}
.padding-bottom-0 {
    padding-bottom: 0 !important;
}
.padding-y-header {
    padding-top: var(--padding-top-header) !important;
    padding-bottom: var(--padding-bottom-header) !important;
}
.padding-top-header {
    padding-top: var(--padding-top-header) !important;
}
.padding-bottom-header {
    padding-bottom: var(--padding-bottom-header) !important;
}

.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}
.alignwide {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.pointer-events-none {
    pointer-events: none !important;
}
.pointer-events-auto {
    pointer-events: auto !important;
}

.no-select {
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
    user-select: none !important;
}

.visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/*RESET====================*/
*,
*::before,
*::after {
    box-sizing: border-box;
}
::-webkit-scrollbar {
    width: 0px;
    overflow: hidden;
}
::-moz-selection {
    background: var(--color-black);
    color: var(--color-white);
}
::selection {
    background: var(--color-black);
    color: var(--color-white);
}

html {
    font-family: sans-serif;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
    margin: 0;
    position: relative;
    background: var(--color-background);
    color: rgba(var(--rgb), 1);
    -webkit-animation-name: pageAnimation;
    animation-name: pageAnimation;
    -webkit-animation-duration: var(--duration-slower);
    animation-duration: var(--duration-slower);
    -webkit-animation-timing-function: var(--easing);
    animation-timing-function: var(--easing);
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}
@-webkit-keyframes pageAnimation {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
@keyframes pageAnimation {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

article,
aside,
figcaption,
figure,
picture,
footer,
header,
hgroup,
main,
nav,
section {
    margin: 0;
    display: block;
}
h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    line-height: inherit;
    word-break: break-word;
}
p {
    margin: 0;
}
small {
    font-size: 87.5%;
}
address {
    font-style: normal;
}
ul,
ol {
    list-style: none;
}
ul,
ol,
li {
    margin: 0;
    padding: 0;
}
a {
    color: inherit;
}
a,
a:hover,
a:focus {
    outline: 0;
    text-decoration: none;
    box-shadow: none;
}
a[href^="tel"] {
    white-space: nowrap;
}
a[href^="mailto"] {
    word-break: break-word;
}
a,
button,
[role="button"] {
    cursor: pointer;
}
button,
input,
textarea,
select {
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    box-shadow: none;
    border-radius: 0;
    border: 0;
    background: none;
    padding: 0;
    margin: 0;
    min-width: unset;
    font-family: inherit;
    font-style: inherit;
    font-weight: inherit;
    font-size: inherit;
    line-height: normal;
    text-transform: inherit;
    text-align: inherit;
    letter-spacing: inherit;
    text-indent: inherit;
    color: inherit;
}
fieldset {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: none !important;
}
img {
    border: 0;
    outline: 0;
    height: auto;
    width: auto;
    max-width: 100%;
    vertical-align: middle;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}
th,
td {
    padding: 0;
    font-weight: inherit;
}
hr {
    margin: 0;
    border: 0;
    display: block;
    width: 100%;
    height: 1px;
    background-color: currentColor;
}
iframe {
    border: 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
[tabindex="-1"]:focus {
    outline: 0 !important;
}
:focus-visible {
    outline: 0 !important;
}
script {
    margin: 0 !important;
}

/*TEXT====================*/
body {
    font-family: var(--font-family-body);
    font-weight: var(--font-weight-body);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
    letter-spacing: normal;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
strong,
b {
    font-weight: var(--font-weight-medium);
}

.font-family-body {
    font-family: var(--font-family-body) !important;
    font-weight: var(--font-weight-body);
}
.font-family-heading {
    font-family: var(--font-family-heading) !important;
    font-weight: var(--font-weight-heading);
}

.font-weight-regular {
    font-weight: var(--font-weight-regular) !important;
}
.font-weight-medium {
    font-weight: var(--font-weight-medium) !important;
}
.font-weight-light {
    font-weight: var(--font-weight-light) !important;
}

.font-size-3xs {
    font-size: var(--font-size-3xs) !important;
}
.font-size-2xs {
    font-size: var(--font-size-2xs) !important;
}
.font-size-xs {
    font-size: var(--font-size-xs) !important;
}
.font-size-sm {
    font-size: var(--font-size-sm) !important;
}
.font-size-md {
    font-size: var(--font-size-md) !important;
}
.font-size-lg {
    font-size: var(--font-size-lg) !important;
}
.font-size-xl {
    font-size: var(--font-size-xl) !important;
    line-height: var(--line-height-sm);
}
.font-size-h3 {
    font-size: var(--font-size-h3) !important;
    line-height: var(--line-height-h3);
}
.font-size-h2 {
    font-size: var(--font-size-h2) !important;
    line-height: var(--line-height-h2);
}
.font-size-h1 {
    font-size: var(--font-size-h1) !important;
    line-height: var(--line-height-h1);
}
.font-size-body {
    font-size: var(--font-size-body) !important;
    line-height: var(--line-height-body) !important;
}
.font-size-body-sm {
    font-size: var(--font-size-body-sm) !important;
    line-height: var(--line-height-body) !important;
}

/*TRANSITION====================*/
a,
button,
[role="button"],
img,
video,
input,
textarea,
select {
    transition: var(--duration) var(--easing);
}

/*CTA====================*/
:is(a, button):hover {
    color: var(--color-link-hover);
}
:is(a, button).active {
    color: var(--color-link-active);
}
.c-white :is(a, button):is(:hover, .active) {
    color: inherit;
}

.js-link-hover.link-hover a:hover {
    color: inherit;
}
.js-link-hover.link-hover a:not(:hover) {
    opacity: var(--opacity);
}

.link-wrap {
    display: inline-flex;
    align-items: center;
    grid-gap: 0 var(--spacing-content-sm);
}

.link-overlay {
    font-size: 0 !important;
    box-shadow: none !important;
    text-decoration: none !important;
    background: none !important;
    opacity: 0 !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    z-index: 2 !important;
    top: 0 !important;
    left: 0 !important;
    pointer-events: auto !important;
}

*[class*="link-underline"] *:is(a, button, u) {
    display: inline;
    text-decoration: none;
    background: none;
    box-shadow: none;
}
.link-underline *:is(a, button, u):hover,
.link-underline-hover a:hover {
    box-shadow: var(--link-underline);
}
.link-underline *:is(a, button, u),
.link-underline-active a.active {
    box-shadow: var(--link-underline-secondary);
}

.link-explore {
    text-decoration: none;
    box-shadow: none;
    background: none;
    border: 0;
    outline: none;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-accent);
    font-size: var(--font-size-body);
    letter-spacing: var(--letter-spacing);
    line-height: normal;
    color: inherit;
    padding: 0;
    overflow: hidden;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.link-explore > span {
    display: inline-block;
    vertical-align: top;
    background-image: var(--button-gradient-text);
    background-size: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: initial;
    color: inherit;
    transition: var(--duration) var(--easing);
    transition-property: color, background-position;
}
.link-explore:is(:hover, .active) > span {
    color: transparent;
}
.link-explore:is(.disabled) {
    pointer-events: none;
}

*:is(.button, .wp-element-button, .wp-block-button__link) {
    text-decoration: none !important;
    box-shadow: none !important;
    background: none !important;
    margin: 0;
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    grid-gap: var(--spacing-content-sm);
    vertical-align: top;
    white-space: normal;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    min-width: 0;
    max-width: 100%;
    height: var(--button-height);
    min-height: 0;
    max-height: none;
    padding: var(--button-spacing-y) var(--button-spacing-x) !important;
    color: var(--button-color-text) !important;
    background-color: var(--button-color-background) !important;
    border: var(--border-width) var(--border-style) var(--button-color-border) !important;
    border-radius: var(--button-border-radius) !important;
    opacity: 1 !important;
    overflow: hidden;
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-accent);
    font-size: var(--font-size-body);
    line-height: normal;
    letter-spacing: normal;
    text-transform: uppercase;
    text-align: center;
    transition: var(--duration) var(--easing);
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
*:is(.button, .wp-element-button, .wp-block-button__link).min-width {
    min-width: 16rem;
}
*:is(.button, .wp-element-button, .wp-block-button__link) > span {
    display: inline-block;
    vertical-align: top;
    background-image: var(--button-gradient-text);
    background-size: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: initial;
    color: inherit;
    transition: var(--duration) var(--easing);
    transition-property: color, background-position;
}
*:is(.button, .wp-element-button, .wp-block-button__link):is(:hover, .active) > span {
    color: transparent;
}
*:is(.button, .wp-element-button, .wp-block-button__link):is(:disabled, .disabled) {
    pointer-events: none;
}

.button-stars {
    --button-stars-star-1-opacity: 1;
    --button-stars-star-1-scale: 1;
    --button-stars-star-2-opacity: 1;
    --button-stars-star-2-scale: 1;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    cursor: pointer;
    inset: 0;
    outline: none;
    opacity: 1;
    margin: 0;
    position: relative;
    z-index: 1;
    display: inline-flex;
    vertical-align: top;
    align-items: center;
    justify-content: center;
    grid-gap: var(--spacing-content-sm);
    min-width: 0;
    max-width: 100%;
    min-height: 0;
    max-height: none;
    width: auto;
    height: var(--button-height);
    overflow: hidden;
    padding: var(--button-spacing-y) var(--button-spacing-x);
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-accent);
    font-size: var(--font-size-body);
    line-height: normal;
    letter-spacing: var(--letter-spacing);
    text-transform: uppercase;
    text-align: center;
    text-decoration: none;
    white-space: normal;
    border-radius: 0;
    border: 0;
    background: linear-gradient(0deg, #605cff 7.5%, #3a3799 91.25%);
    color: rgba(255, 255, 255, 1);
    transition: var(--duration) var(--easing);
}
.button-stars::before {
    content: "";
    position: absolute;
    z-index: 1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 100%;
    pointer-events: none;
    border: 1px solid rgba(171, 168, 255, 1);
    border-image-slice: 1;
    border-image-source: linear-gradient(to right, rgba(171, 168, 255, 1) 72%, rgba(255, 255, 255, 1));
}
.button-stars > span {
    position: relative;
    z-index: 1;
}
.button-stars > svg {
    display: block;
    overflow: visible;
    pointer-events: none;
}
.button-stars > svg.icon {
    width: 18px;
    height: 22px;
    fill: currentColor;
}
.button-stars > svg.icon path:nth-child(1) {
    opacity: var(--button-stars-star-1-opacity);
    transform: scale(var(--button-stars-star-1-scale));
    transform-origin: 25% 15%;
}
.button-stars > svg.icon path:nth-child(2) {
    opacity: var(--button-stars-star-2-opacity);
    transform: scale(var(--button-stars-star-2-scale));
    transform-origin: 25% 50%;
}
.button-stars > .stroke {
    inset: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 2;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
    mix-blend-mode: hard-light;
}
.button-stars > .stroke svg {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    min-width: 100%;
    min-height: 100%;
    fill: none;
    stroke-width: 1px;
    stroke: rgba(var(--color-tertiary-rgb), 1);
    stroke-dasharray: 1.5 14;
    stroke-dashoffset: 22;
    opacity: 0;
}
.button-stars > .stroke svg:nth-child(2) {
    stroke-opacity: 0.5;
    -webkit-filter: blur(3px);
    filter: blur(3px);
}
.button-stars:hover > .stroke svg {
    -webkit-animation: buttonStroke 2s linear infinite;
    animation: buttonStroke 2s linear infinite;
}
@-webkit-keyframes buttonStroke {
    0% {
        opacity: 0;
    }
    25%,
    75% {
        opacity: 1;
    }
    95%,
    100% {
        opacity: 0;
        stroke-dashoffset: 6;
    }
}
@keyframes buttonStroke {
    0% {
        opacity: 0;
    }
    25%,
    75% {
        opacity: 1;
    }
    95%,
    100% {
        opacity: 0;
        stroke-dashoffset: 6;
    }
}

/*GENERAL====================*/
.container {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-container);
    padding-right: var(--spacing-container);
}

*[block-width] {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
}

*:is(.ic, .ic-text) {
    display: inline-block;
}
.ic img {
    display: inline-block;
    vertical-align: top;
    width: auto;
    min-width: 1em;
    height: 1em;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
}
.ic::before {
    display: block;
}
.ic-youtube {
    padding-left: 0.1em !important;
    padding-right: 0.1em !important;
}
.ic-youtube::before {
    transform: scale(1.1);
}

.ic-wrap {
    display: inline-flex;
    vertical-align: top;
    align-items: center;
    grid-gap: var(--spacing-3xs);
}
.ic-wrap > * {
    display: block;
}
.ic-wrap > .ic {
    font-size: var(--icon-size);
}
.ic-wrap > img {
    width: var(--icon-size);
    height: auto;
    aspect-ratio: 1/1;
    overflow: hidden;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
}

.brand {
    text-decoration: none !important;
    box-shadow: none !important;
    background: none !important;
    opacity: 1 !important;
    display: inline-block;
    vertical-align: top;
    line-height: 1;
}
.brand .logo {
    display: inline-block;
    vertical-align: top;
    width: auto;
    height: var(--logo-height);
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
    transition-property: width, height;
}

*:is(.object, .object-fit) {
    text-decoration: none;
    box-shadow: none;
    background: none;
    position: relative;
    display: block;
    width: 100%;
    overflow: hidden;
}
*:is(.object, .object-fit) > *:is(img, video, iframe) {
    display: block;
    margin: 0 auto;
    width: 100%;
    height: auto;
}
.object-fit > *:is(img, video, iframe) {
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}
.object-fit.contain > *:is(img, video, iframe) {
    -o-object-fit: contain;
    object-fit: contain;
}
.object-fit::before {
    content: "";
    display: block;
    width: 100%;
}
.object-svg {
    display: block;
    overflow: hidden;
    position: relative;
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.object-svg > svg {
    outline: 0;
    border: 0;
    display: block;
    height: auto;
    width: 100%;
    max-width: 100%;
}

.ratio-1-1 {
    aspect-ratio: 1/1;
}
.ratio-9-16 {
    aspect-ratio: 9/16;
}
.ratio-16-9 {
    aspect-ratio: 16/9;
}

.object-overlay {
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.social,
.social-text {
    display: inline-flex;
    vertical-align: top;
    align-items: center;
    grid-gap: var(--spacing-sm);
}
.social a {
    display: block;
    text-decoration: none;
    background: none;
    box-shadow: none;
}
.social .ic {
    display: block;
    font-size: var(--icon-size);
}
.social img {
    display: block;
    width: 1em;
    height: 1em;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
}

.social-text {
    grid-gap: var(--spacing-2xs) var(--spacing-md);
}

.map-container {
    width: 100%;
    position: relative;
    overflow: hidden;
}
.map-container::before {
    content: "";
    display: block;
    width: 100%;
}
.map-container iframe {
    outline: 0;
    border: 0;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.map-container .design {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    cursor: pointer;
}
.map-container .design,
.map-container .design img {
    display: block;
    width: calc(100% + 2px);
    height: calc(100% + 2px);
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
}

/*CONTENT====================*/
.entry-content {
    --wp--preset--font-size--normal: var(--font-size-body);
    --wp--preset--font-size--small: var(--font-size-body-sm);
    --wp--preset--font-size--medium: var(--font-size-md);
    --wp--preset--font-size--large: var(--font-size-lg);
    --wp--preset--font-size--x-large: var(--font-size-xl);
    --wp--preset--font-size--xx-large: var(--font-size-h3);
    --wp--preset--font-size--huge: var(--font-size-h3);

    --wp--style--unstable-gallery-gap: var(--spacing-column);
}
.entry-content .is-layout-flex {
    display: flex;
    flex-wrap: wrap;
}
.entry-content :is(h1, h2, h3, h4, h5, h6) {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
}
.entry-content :is(h1, h2) {
    font-family: var(--font-family-heading);
}
.entry-content .has-small-font-size {
    font-size: var(--wp--preset--font-size--small) !important;
}
.entry-content :is(.has-normal-font-size, .has-regular-font-size) {
    font-size: var(--wp--preset--font-size--normal) !important;
}
.entry-content :is(h3, .has-medium-font-size) {
    font-size: var(--wp--preset--font-size--medium) !important;
}
.entry-content :is(.has-large-font-size, .has-larger-font-size) {
    font-size: var(--wp--preset--font-size--large) !important;
}
.entry-content :is(.has-x-large-font-size) {
    font-size: var(--wp--preset--font-size--x-large) !important;
    line-height: var(--line-height-sm);
}
.entry-content :is(h2, .has-xx-large-font-size) {
    font-size: var(--wp--preset--font-size--xx-large) !important;
    line-height: var(--line-height-sm);
}
.entry-content :is(h1, .has-huge-font-size) {
    font-size: var(--wp--preset--font-size--huge) !important;
    line-height: var(--line-height-sm);
}
.entry-content p {
    margin: 0;
    font-family: inherit;
    font-weight: inherit;
    font-size: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
}
.entry-content ul,
.entry-content .wp-block-list {
    margin: 0;
    padding: 0;
    list-style-type: disc;
    padding-left: 1.2em;
}
.entry-content ol,
.entry-content .wp-block-list {
    margin: 0;
    padding: 0;
    list-style-type: decimal;
    list-style-position: inside;
}

.entry-content :is(.wp-block-image, .wp-block-video) :is(img, video) {
    margin: 0;
    height: auto;
    max-height: none;
    max-width: 100%;
    vertical-align: top;
    border-radius: 0;
    overflow: hidden;
}
.entry-content :is(.wp-block-image, .wp-block-video).size-thumbnail :is(img, video) {
    width: clamp(20.8333333333vw, 300px, 100%);
}
.entry-content :is(.wp-block-image, .wp-block-video).size-medium :is(img, video) {
    width: clamp(27.7777777778vw, 400px, 100%);
}
.entry-content :is(.wp-block-image, .wp-block-video).size-large :is(img, video) {
    width: clamp(52.08333333333vw, 750px, 100%);
}

.entry-content .wp-block-embed .wp-block-embed__wrapper {
    position: relative;
}
.entry-content .wp-block-embed .wp-block-embed__wrapper::before {
    content: "";
    display: block;
    width: 100%;
    padding-bottom: 56.25%;
}
.entry-content .wp-block-embed .wp-block-embed__wrapper > * {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
    position: absolute;
    top: 0;
    left: 0;
}

.entry-content [class*="wp-block"] figcaption {
    font-style: normal;
    font-size: var(--font-size-body-sm);
    line-height: var(--line-height-body);
    color: inherit;
}

.entry-content > *,
.entry-content :is([class*="wp-block-"], figcaption) {
    margin: 0;
}
.entry-content > *:not(:first-child),
*:is(.wp-block-group, .wp-block-column, .wp-block-quote) > *:not(:first-child) {
    margin-top: var(--spacing-content);
}
[class*="wp-block-"]:not(.wp-block-heading, .wp-block-list, .wp-block-column) + *:not(:first-child),
* + [class*="wp-block-"]:not(.wp-block-heading, .wp-block-list, .wp-block-column):not(:first-child) {
    margin-top: var(--spacing-section);
}
.entry-content li:not(:first-child) {
    margin-top: 0;
}
.entry-content :is(h1, h2, h3, h4, h5, h6, p) + :is(ul, ol, .wp-block-list):not(:first-child),
.entry-content br + *:not(:first-child),
.entry-content [class*="wp-block-"] br + *:not(:first-child),
.entry-content [class*="wp-block-"] figcaption:not(:first-child) {
    margin-top: var(--spacing-content-xs);
}

.entry-content .wp-block-columns {
    grid-gap: var(--spacing-row) var(--spacing-column);
}
.entry-content .wp-block-columns > * {
    margin: 0;
}

.entry-content .wp-block-gallery {
    gap: 0;
    grid-gap: var(--spacing-row) var(--wp--style--unstable-gallery-gap);
}
.entry-content .wp-block-gallery.has-nested-images figure.wp-block-image {
    flex-grow: 0;
}
.entry-content [class*="wp-block"].aligncenter {
    margin-left: auto;
    margin-right: auto;
}

.entry-header > *:not(:first-child) {
    margin-top: var(--spacing-content);
}

.entry-category,
.entry-publish {
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-body-sm);
    line-height: var(--line-height-body);
}

.entry-contact {
    width: 100%;
    display: flex;
    flex-direction: column;
    grid-gap: var(--spacing-content-sm);
}

/*UNUSED_FORM====================*/

/*UNUSED_FORM:UPLOAD FILE====================*/

/*PLUGIN:LENIS====================*/
.lenis {
    height: auto;
}
.lenis.lenis-smooth {
    scroll-behavior: auto !important;
}
.lenis.lenis-smooth [data-lenis-prevent] {
    -ms-scroll-chaining: none;
    overscroll-behavior: contain;
}
.lenis.lenis-stopped {
    overflow: hidden;
}
.lenis.lenis-scrolling iframe {
    pointer-events: none;
}

/*PLUGIN:SPLITTING====================*/
[data-splitting] {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
[data-splitting] :is(.word, .char) {
    position: relative;
    display: inline-block;
    vertical-align: top;
    overflow: hidden;
    white-space: nowrap;
}

/*PLUGIN:MARQUEE====================*/
*[data-limarquee].mWrap {
    transition: height var(--duration) var(--easing);
}
*[data-limarquee].mWrap .mMove,
*[data-limarquee].mWrap .mItem {
    width: auto !important;
}
*[data-limarquee] .cloneContent {
    padding: 0 !important;
}

/*UNUSED_PLUGIN:SLIDER====================*/

/*UNUSED_FUNCTION:TAB====================*/

/*UNUSED_FUNCTION:CLIPBOARD====================*/

/*UNUSED_HAMBURGER====================*/

/*UNUSED_LANGUAGE====================*/

/*UNUSED_FUNCTION:DROPDOWN====================*/

/*PAGE====================*/
#page {
    position: relative;
    min-height: 100svh;
    display: grid;
    grid-template-rows: 1fr auto;
    grid-template-columns: 100%;
    overflow: clip;
}

/*HEADER====================*/
#header {
    width: 100%;
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
#header-height {
    width: 100%;
    height: var(--header-height);
    opacity: 0;
    position: fixed;
    z-index: -1;
    top: 0;
    left: 0;
    pointer-events: none;
}

.header-navi {
    position: relative;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    width: 100%;
    height: var(--header-navi-height);
    background-color: transparent;
    color: rgba(var(--rgb), 1);
    grid-gap: var(--spacing-container);
    padding: 0 var(--spacing-container);
    font-size: var(--font-size-body-sm);
    transition: var(--duration) var(--easing);
}
.header-navi :is(a, button, form) {
    pointer-events: auto;
}

.header-brand {
    grid-row: 1;
    grid-column: 2;
    justify-self: center;
    align-self: center;
    line-height: 1;
}

.header-system {
    grid-row: 1;
    grid-column: 3;
    justify-self: flex-end;
    align-self: flex-start;
    line-height: 1;
    padding-top: calc(var(--spacing-container) * 1.5);
}
.header-system .tools {
    display: flex;
    grid-gap: var(--spacing-container);
}
.header-system .tool {
    position: relative;
    display: flex;
    align-items: center;
}
.header-system .tool .ctrl {
    display: inline-flex;
    vertical-align: top;
    align-items: center;
    line-height: 1;
}
.header-system .tool .ic {
    margin: 0 !important;
    display: block;
    color: inherit;
    font-size: var(--icon-size);
}

html.main-end .header-navi {
    transform: translateY(-100%);
}
html.main-end .header-navi :is(a, button, form) {
    pointer-events: none;
}

/*FOOTER====================*/
#footer {
    position: relative;
    width: 100%;
    height: auto;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.footer-navi {
    width: 100%;
    height: auto;
    margin: -1px auto;
    padding: var(--spacing-container);
    font-family: var(--font-family-body);
    font-weight: var(--font-weight-body);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: var(--spacing-row) var(--spacing-column);
}
.footer-navi :is(.entry-title, .directory, .agent) {
    font-family: var(--font-family-accent);
    font-weight: var(--font-weight-accent);
    font-size: var(--font-size-body);
    line-height: var(--line-height-body);
}
.footer-navi :is(.directory, .information, .utilities) {
    display: flex;
    flex-direction: column;
    grid-gap: var(--spacing-content-sm);
}
.footer-navi .entry-content > *:not(:first-child) {
    margin-top: var(--spacing-content-sm);
}
.footer-navi .utilities > .social + * {
    margin-top: calc((var(--line-height-body) * 1em) / 2);
}
.footer-navi .legal {
    font-size: var(--font-size-body-sm);
    color: rgba(var(--rgb), var(--opacity));
}

/*INTRO====================*/
#intro {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    pointer-events: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
html.has-intro #page {
    grid-template-rows: auto 1fr auto;
}
html.has-intro #header .header-brand :is(.brand, .logo) {
    transition: none;
    will-change: transform, opacity;
}

/*MAIN====================*/
#main {
    position: relative;
    width: 100%;
}

section {
    position: relative;
    width: 100%;
}

.sc-link {
    padding: 0 !important;
    margin: 0 !important;
    opacity: 0 !important;
    font-size: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    position: absolute !important;
    z-index: 2 !important;
    top: 0 !important;
    left: 0 !important;
}

.sc-inner {
    position: relative;
    z-index: 0;
    width: 100%;
    padding-top: var(--spacing-section);
    padding-bottom: var(--spacing-section);
}
.sc-inner.padding-sm {
    padding-top: var(--spacing-section-sm);
    padding-bottom: var(--spacing-section-sm);
}
.sc-inner.padding-container {
    padding-top: var(--spacing-container);
    padding-bottom: var(--spacing-container);
}
.sc-inner.padding-y-header {
    padding-top: calc(var(--header-height) + var(--spacing-section)) !important;
    padding-bottom: calc(var(--header-height) + var(--spacing-section)) !important;
}
.sc-inner.padding-top-header {
    padding-top: calc(var(--header-height) + var(--spacing-section)) !important;
}
.sc-inner.padding-bottom-header {
    padding-bottom: calc(var(--header-height) + var(--spacing-section)) !important;
}

.sc-container + .sc-container {
    margin-top: var(--spacing-section);
}

*:is(.sc-container) > *:not(:first-child) {
    margin-top: var(--spacing-row);
}
*:is(.sc-content, .sc-group, .sc-grid, .sc-sidebar, .sc-main) > *:not(:first-child) {
    margin-top: var(--spacing-content);
}
*:is(.sc-desc, .sc-explore) > *:not(:first-child) {
    margin-top: var(--spacing-content);
}
*:is(.sc-headline) > *:not(:first-child) {
    margin-top: var(--spacing-content-sm);
}

.margin-top-section:not(:first-child) {
    margin-top: var(--spacing-section) !important;
}

.sc-cover {
    position: relative;
    overflow: hidden;
}

.sc-grid-row {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
    transition: min-height var(--duration) var(--easing);
}
.sc-grid-row.h-vh {
    min-height: 100vh;
}
.sc-grid-row.h-lvh {
    min-height: 100lvh;
}
.sc-grid-row.h-svh {
    min-height: 100svh;
}
.sc-grid-row.h-dvh {
    min-height: 100dvh;
}
.sc-grid-row > .sc-inner {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 3;
}
.sc-grid-row > .sc-inner > .sc-container {
    flex: 1;
    display: grid;
    grid-template-columns: 100%;
    grid-template-rows: 1fr auto 1fr;
    grid-gap: var(--spacing-row) 0;
}
.sc-grid-row > .sc-inner > .sc-container > * {
    position: relative;
}
.sc-grid-row > .sc-inner > .sc-container > *:not(:first-child) {
    margin-top: 0;
}
.sc-grid-row > .sc-inner > .sc-container > *[data-row="top"] {
    grid-row: 1;
    align-self: flex-start;
}
.sc-grid-row > .sc-inner > .sc-container > *[data-row="middle"] {
    grid-row: 2;
    align-self: center;
}
.sc-grid-row > .sc-inner > .sc-container > *[data-row="bottom"] {
    grid-row: 3;
    align-self: flex-end;
}
.sc-grid-row > .sc-inner > .sc-container > *[data-row="bottom"] .animated {
    -webkit-animation-delay: 0s !important;
    animation-delay: 0s !important;
}
.sc-grid-row > .sc-inner > .sc-container[data-row-total="1"] {
    grid-template-rows: 1fr;
    grid-gap: 0;
}
.sc-grid-row > .sc-inner > .sc-container[data-row-total="1"] > * {
    grid-row: auto;
}
.sc-grid-row > .sc-inner > .sc-container[data-row-align="center"] {
    grid-template-rows: unset;
    align-items: center;
}
.sc-grid-row > .sc-inner > .sc-container[data-row-align="center"] > * {
    grid-row: unset;
    align-self: unset;
}

.sc-billboard {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
.sc-billboard > * {
    width: 100%;
}
.sc-billboard > *:is(.sc-inner, .sc-grid-row) {
    width: 100%;
    position: relative;
    z-index: 2;
    pointer-events: none;
}
.sc-billboard > *:is(.sc-inner, .sc-grid-row) *:is(a, button, form, iframe) {
    pointer-events: auto;
}
.sc-billboard > .sc-cover {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: hidden;
}
.sc-billboard > .sc-cover,
.sc-billboard > .sc-cover .object-fit,
.sc-billboard > .sc-cover .object-fit::before,
.sc-billboard > .sc-cover *:is(.swiper, .swiper-wrapper, .swiper-slide) {
    height: 100%;
}
.sc-billboard > .sc-cover .object-fit:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: 1;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    pointer-events: none;
}
.sc-billboard.fade .sc-cover .object-fit:after {
    background-color: rgba(var(--color-background-rgb), var(--opacity-overlay));
}
.sc-billboard.fade-bottom .sc-cover .object-fit:after {
    background: linear-gradient(180deg, rgba(var(--color-background-rgb), 0) 0%, rgba(var(--color-background-rgb), var(--opacity-overlay)) 100%);
}
.sc-billboard > .sc-cover .object-overlay {
    padding: var(--spacing-container);
    text-align: right;
}

.sc-billboard > .sc-cover *:is(.animation-expand-wrapper, .pin-spacer-animation-expand) {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100% !important;
    max-height: 100% !important;
    overflow: hidden;
}
.sc-billboard > .sc-cover .animation-expand-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.sc-billboard > .sc-cover .animation-expand {
    width: 100%;
    height: 100%;
    position: relative;
    transition: none;
    will-change: width, height, transform;
}

.sc-billboard > .sc-cover .logo {
    display: inline-block;
    vertical-align: top;
}
.sc-billboard > .sc-cover .logo > * {
    display: block;
    width: auto;
    height: 55px;
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
}

.sc-billboard-half {
    position: relative;
    overflow: clip;
}
.sc-billboard-half > .sc-billboard {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}

.sc-billboard-show {
    position: relative;
    overflow: clip;
}
.sc-billboard-show > .sc-billboard {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}

/*MODULES====================*/
.card {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: column;
    grid-gap: var(--spacing-content-sm);
    position: relative;
    color: rgba(var(--rgb), 1);
    text-align: left;
    white-space: normal;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    cursor: default;
}
.card .ellipsis {
    max-width: 100%;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 5;
    line-clamp: 5;
    padding: 0.08em 0;
    overflow: hidden;
}
.card .caption {
    display: flex;
    flex-direction: column;
    grid-gap: var(--spacing-content-xs);
}
.card .caption,
.card .cover {
    width: 100%;
    position: relative;
    z-index: 3;
    pointer-events: none;
}
.card .cover :is(.object, .object-fit) > * {
    transition: var(--duration-slow) var(--easing);
}
.card:hover .cover :is(.object, .object-fit) > * {
    transform: scale(1.02);
}
.card *:is(a, button):not(.link-overlay) {
    position: relative;
    z-index: 3;
    pointer-events: auto;
}

.card-marquee {
    display: inline-grid;
    grid-auto-flow: column;
    grid-auto-columns: -webkit-max-content;
    grid-auto-columns: max-content;
    vertical-align: top;
}
.card-marquee > .card {
    margin-right: var(--spacing-x);
}

.card-container {
    --spacing-x: 0px;
    --spacing-y: 0px;
    --column: 1;
    position: relative;
}

.card-container[data-layout="grid"] {
    display: grid;
    grid-gap: var(--spacing-y) var(--spacing-x);
    grid-template-columns: repeat(var(--column), calc((100% - (var(--spacing-x) * (var(--column) - 1))) / var(--column)));
    grid-auto-flow: dense;
}

.card-container[data-layout="flex"] {
    --card-width: calc((100% - (var(--spacing-x) * (var(--column) - 1))) / var(--column));
    display: flex;
    flex-wrap: wrap;
    grid-gap: var(--spacing-y) var(--spacing-x);
}
.card-container[data-layout="flex"] > .card {
    width: var(--card-width);
}

.card-container[data-layout="marquee"] .card {
    width: 100%;
    max-width: 100%;
}

.card-container[data-layout="slider"] .entry-swiper {
    margin-left: calc((var(--spacing-x) * -1) / 2);
    margin-right: calc((var(--spacing-x) * -1) / 2);
}
.card-container[data-layout="slider"] .swiper-slide {
    width: calc(100% / var(--column)) !important;
    padding-left: calc(var(--spacing-x) / 2);
    padding-right: calc(var(--spacing-x) / 2);
}
.card-container[data-layout="slider"] .swiper-pagination {
    padding-left: calc(var(--spacing-x) / 2);
    padding-right: calc(var(--spacing-x) / 2);
}
.card-container[data-layout="slider"] .swiper-button-prev {
    left: calc(var(--spacing-x) / 2);
}
.card-container[data-layout="slider"] .swiper-button-next {
    right: calc(var(--spacing-x) / 2);
}

/* Ticket */
[data-card="ticket"] {
    --spacing-x: var(--spacing-container);
    --spacing-y: var(--spacing-row);
    --column: 1;
}
[data-card="ticket"] .card .cover .object-fit::before {
    padding-bottom: 128.1944444444%;
    background-color: rgba(var(--rgb-couple), 1);
}
[data-card="ticket"] .card .cover .object-fit:not(:last-child) > * {
    opacity: var(--opacity-overlay);
}
[data-card="ticket"] .card .cover .object-overlay > .caption {
    width: 100%;
    height: 100%;
    padding: var(--spacing-content-sm);
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    text-align: center;
}
[data-card="ticket"] .card .cover .object-overlay > .caption > .entry-title {
    grid-row: 2;
    align-self: center;
}
[data-card="ticket"] .card .cover .object-overlay > .caption > .entry-explore {
    grid-row: 3;
    align-self: flex-end;
}
[data-card="ticket"][data-layout="marquee"] .card {
    width: clamp(20.9722222222vw, 215px, 55.1282051282vw);
}

/* Highlight */
[data-section="highlight"] {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
[data-section="highlight"] .highlight-text {
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-heading);
    font-size: 11.1111111111vw;
    line-height: 0.8;
    background-color: var(--color-background);
    padding: 0.08em var(--spacing-container);
    margin: -1px auto;
}
[data-section="highlight"] .highlight-text .gradient-text {
    display: inline-block;
    vertical-align: top;
    background-color: transparent;
    background-image: linear-gradient(86deg, #6b6b6b 6.75%, #f6f6f6 13.45%, #efefef 34.69%, #424242 52.39%, #303030 62.48%, #6b6b6b 70.64%, #fefefe 77.95%, #fefefe 99.6%);
    background-size: 300% auto;
    background-position: 100% center;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-animation: gradientText 10s var(--easing) infinite;
    animation: gradientText 10s var(--easing) infinite;
}
@-webkit-keyframes gradientText {
    0% {
        background-position: 100% center;
    }
    100% {
        background-position: -200% center;
    }
}
@keyframes gradientText {
    0% {
        background-position: 100% center;
    }
    100% {
        background-position: -200% center;
    }
}

/* Overview */
[data-section="overview"] .sc-overview {
    display: flex;
    flex-direction: column;
    grid-gap: var(--spacing-section);
    padding: var(--spacing-section) 0;
}
[data-section="overview"] .sc-overview > .sc-group {
    width: 440px;
    min-width: 30.5555555556vw;
    max-width: calc(100% - var(--spacing-container) * 2);
    position: relative;
    z-index: 1;
}
[data-section="overview"] .sc-overview > .sc-group::before {
    content: "";
    height: auto;
    aspect-ratio: 1/1;
    background: radial-gradient(50% 50% at 50% 50%, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 100%);
    position: absolute;
    z-index: -1;
    pointer-events: none;
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(odd) {
    margin-left: 0;
    margin-right: auto;
    text-align: left;
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(even) {
    margin-left: auto;
    margin-right: 0;
    text-align: right;
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 1)::before {
    width: 33.05555555556vw;
    top: 0;
    left: 0;
    transform: translate(-5vw, 5vw);
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 2)::before {
    width: 42.6388888889vw;
    top: 50%;
    right: 0;
    transform: translate(7vw, -50%);
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 3)::before {
    width: 27.7777777778vw;
    background: radial-gradient(50% 50% at 50% 50%, rgba(95, 85, 255, 0.3) 0%, rgba(95, 85, 255, 0) 100%);
    top: 0;
    left: 0;
    transform: translate(5vw, 0%);
}
[data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 4)::before {
    width: 38.8888888889vw;
    top: 50%;
    right: 0;
    transform: translate(-7vw, -50%);
}
[data-section="overview"] .sc-overview > .sc-group:is(:nth-child(4n + 1), :nth-child(4n + 3)) {
    width: 100%;
    max-width: 100%;
}
[data-section="overview"] .sc-overview > .sc-group:is(:nth-child(4n + 1), :nth-child(4n + 3)) .sc-heading {
    width: 534px;
    min-width: 37.08333333333vw;
    max-width: 100%;
}
[data-section="overview"] .sc-overview > .sc-group:is(:nth-child(4n + 1), :nth-child(4n + 3)) :is(.sc-desc, .sc-explore) {
    width: 324px;
    min-width: 22.5vw;
    max-width: 100%;
}

/*ANIMATE====================*/
.animate {
    -webkit-animation-duration: var(--duration-slower);
    animation-duration: var(--duration-slower);
    -webkit-animation-timing-function: var(--easing);
    animation-timing-function: var(--easing);
}
.animated {
    -webkit-animation-delay: 0.1s;
    animation-delay: 0.1s;
}

.animate.fadeIn {
    will-change: opacity;
}

.staggerFadeWord .word {
    will-change: opacity;
}

*:is(.animation-expand-wrapper, .pin-spacer-animation-expand) {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100% !important;
    max-height: 100% !important;
    overflow: hidden;
}
.animation-expand-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}
.animation-expand {
    width: 100%;
    height: 100%;
    position: relative;
    transition: none;
    will-change: transform;
}

/*MEDIA QUERIES:MIN====================*/
@media (min-width: 600px) {
    .visible-mobile-sm {
        display: none !important;
    }
    .visible-mobile-sm:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }
}

@media (min-width: 768px) {
    .visible-mobile {
        display: none !important;
    }
    .visible-mobile:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    /* CTAs */
    .button-stars {
        --button-height: 4.8rem;
    }

    /* Footer */
    .footer-navi {
        display: grid;
        grid-template-columns: repeat(3, 1fr) auto;
        grid-auto-rows: -webkit-max-content;
        grid-auto-rows: max-content;
        grid-auto-flow: dense;
        grid-gap: var(--spacing-row) var(--spacing-column);
    }
    .footer-navi > .information {
        grid-column: unset;
    }
    .footer-navi > .utilities {
        grid-column: 4;
        justify-self: flex-end;
        align-items: flex-end;
        justify-content: space-between;
    }
    .footer-navi > .legal {
        grid-column: 1 / span 4;
        width: 100%;
        display: flex;
        grid-gap: 0 var(--spacing-container);
    }
    .footer-navi > .legal > .copyright {
        margin-left: auto;
        margin-right: 0;
    }
}

@media (min-width: 992px) {
    .visible-device-sm {
        display: none !important;
    }
    .visible-device-sm:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    :root {
        --container-sm: 650px;
    }

    /* General */
    .container.width-sm {
        max-width: calc(var(--container-sm) + (var(--spacing-container) * 2));
    }

    .float-left {
        margin-left: 0 !important;
        margin-right: auto !important;
    }
    .float-right {
        margin-left: auto !important;
        margin-right: 0 !important;
    }

    /* Section */
    .sc-billboard-half > .sc-billboard {
        width: 50%;
    }
    .sc-billboard-half:not(.rtl) > .sc-billboard:nth-child(even),
    .sc-billboard-half:is(.rtl) > .sc-billboard:nth-child(odd) {
        margin-left: auto;
        margin-right: 0;
    }

    /* Ticket */
    [data-card="ticket"] {
        --spacing-x: var(--spacing-md);
    }

    /* Highlight */
    [data-section="highlight"] .highlight-text {
        padding-bottom: var(--spacing-section);
    }

    /* Overview */
    [data-section="overview"] .sc-billboard > .sc-cover .object-fit > * {
        -o-object-fit: contain;
        object-fit: contain;
    }
    [data-section="overview"] .sc-billboard.fade > .sc-cover .object-fit:after {
        opacity: 0;
    }
    [data-section="overview"] .sc-overview {
        padding-top: calc(var(--spacing-section) * 2);
    }
    [data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 1) :is(.sc-desc, .sc-explore) {
        --left: 8.9743589744vw;
        margin-left: var(--left);
        max-width: calc(100% - var(--left));
    }
    [data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 1) :is(.sc-desc, .sc-explore),
    [data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 3) .sc-heading {
        --left: 11.8055555556vw;
        margin-left: var(--left);
        max-width: calc(100% - var(--left));
    }
    [data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 3) :is(.sc-desc, .sc-explore) {
        --left: 4.1666666667vw;
        margin-left: var(--left);
        max-width: calc(100% - var(--left));
    }
}

@media (min-width: 1200px) {
    .visible-device {
        display: none !important;
    }
    .visible-device:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }
}

/*MEDIA QUERIES:MAX====================*/
@media (max-width: 1199px) {
    .hidden-device {
        display: none !important;
    }
    .hidden-device:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    .overflow-hidden-device {
        overflow: hidden !important;
    }
    .overflow-visible-device {
        overflow: visible !important;
    }

    .alignwide-device {
        width: 100% !important;
    }
    .alignfull-device {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(50% - 50vw) !important;
        margin-right: calc(50% - 50vw) !important;
    }
}

@media (max-width: 991px) {
    .hidden-device-sm {
        display: none !important;
    }
    .hidden-device-sm:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    .overflow-hidden-device-sm {
        overflow: hidden !important;
    }
    .overflow-visible-device-sm {
        overflow: visible !important;
    }

    .alignwide-device-sm {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .alignfull-device-sm {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(50% - 50vw) !important;
        margin-right: calc(50% - 50vw) !important;
    }

    /* Gutenberg */
    .entry-content .wp-block-columns {
        flex-wrap: wrap !important;
    }
    .entry-content .wp-block-columns > * {
        flex-basis: unset !important;
        flex-grow: unset !important;
        width: 100% !important;
    }
    .entry-content .wp-block-gallery {
        grid-row-gap: var(--spacing-container);
    }
    .entry-content .wp-block-gallery > * {
        width: 100% !important;
    }

    /* Section */
    .sc-grid-row {
        --h-md: 112.5vw;
    }
    .sc-grid-row.re-h-md {
        min-height: var(--h-md);
    }

    /* Overview */
    [data-section="overview"] .sc-overview {
        grid-row-gap: calc(var(--spacing-section) * 2);
    }
    [data-section="overview"] .sc-overview > .sc-group:nth-child(4n + 1) :is(.sc-desc, .sc-explore) {
        --left: 8.9743589744vw;
        margin-left: var(--left);
        max-width: calc(100% - var(--left));
    }
}

@media (max-width: 781px) {
    /* Gutenberg */
    .wp-block-columns > .wp-block-column:empty {
        display: none !important;
    }
}

@media (max-width: 767px) {
    :root {
        --spacing-container: var(--spacing-xs);
        --logo-height: 7rem;
        --logo-height-lg: 16.4rem;
    }

    .hidden-mobile {
        display: none !important;
    }
    .hidden-mobile:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    .overflow-hidden-mobile {
        overflow: hidden !important;
    }
    .overflow-visible-mobile {
        overflow: visible !important;
    }

    .alignwide-mobile {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .alignfull-mobile {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(50% - 50vw) !important;
        margin-right: calc(50% - 50vw) !important;
    }

    /* Footer */
    .footer-navi > * {
        grid-column: 1 / span 2;
    }

    /* Highlight */
    [data-section="highlight"] .highlight-text {
        font-size: 15.3846153846vw;
    }
    [data-section="highlight"] .highlight-text .words {
        display: flex;
        flex-direction: column;
    }
    [data-section="highlight"] .highlight-text .words > .word:nth-child(even) {
        margin-left: auto;
    }
}

@media (max-width: 599px) {
    .hidden-mobile-sm {
        display: none !important;
    }
    .hidden-mobile-sm:first-child + *:not(:first-child) {
        margin-top: 0 !important;
    }

    .overflow-hidden-mobile-sm {
        overflow: hidden !important;
    }
    .overflow-visible-mobile-sm {
        overflow: visible !important;
    }

    .alignwide-mobile-sm {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .alignfull-mobile-sm {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: calc(50% - 50vw) !important;
        margin-right: calc(50% - 50vw) !important;
    }
}

@media (max-width: 414px) {
    :root {
        font-size: min(2.4154589372vw, 10px);
    }
}
