@font-face {
    font-family: "Shadow Muse Display";
    src: url("../fonts/ArizonaFlare-Light.otf") format("opentype");
    font-display: swap;
    font-weight: 400;
}

@font-face {
    font-family: "Shadow Muse Display";
    src: url("../fonts/ArizonaFlare-Thin.otf") format("opentype");
    font-display: swap;
    font-weight: 300;
}

@font-face {
    font-family: "Shadow Muse Sans";
    src: url("../fonts/Diatype-Regular.ttf") format("truetype");
    font-display: swap;
    font-weight: 400;
}

@font-face {
    font-family: "Shadow Muse Sans";
    src: url("../fonts/Diatype-Light.ttf") format("truetype");
    font-display: swap;
    font-weight: 300;
}

@font-face {
    font-family: "Shadow Muse Sans";
    src: url("../fonts/Diatype-Medium.ttf") format("truetype");
    font-display: swap;
    font-weight: 500;
}

html.shadow-muse-template {
    background: #050505;
}

body.shadow-muse-cms {
    --shadow-bg: #1c242a;
    --shadow-black: #111;
    --shadow-cream: #efd9cd;
    --shadow-gold: #ffd6aa;
    --shadow-gold-soft: rgba(255, 214, 170, 0.34);
    --shadow-cream-soft: rgba(239, 217, 205, 0.82);
    --shadow-ease: cubic-bezier(0.4, 0, 0.2, 1);
    --shadow-luxury-ease: cubic-bezier(0.16, 1, 0.3, 1);
    margin: 0;
    background:
        radial-gradient(circle at 22% 18%, rgba(17, 17, 17, 0.88) 0 12%, transparent 36%),
        radial-gradient(circle at 82% 74%, rgba(17, 17, 17, 0.74) 0 16%, transparent 42%),
        linear-gradient(125deg, #1c242a 0%, #111 24%, #1c242a 46%, #111 68%, #1c242a 100%);
    background-size: 170% 170%, 190% 190%, 240% 240%;
    color: var(--shadow-cream);
    font-family: "Shadow Muse Sans", Arial, sans-serif;
    font-size: 16px;
    line-height: 1.66;
    letter-spacing: 0.1em;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    overflow-x: clip;
    animation: shadowMusePageGradient 28s ease-in-out infinite alternate;
}

body.shadow-muse-cms::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 9998;
    background: #050505;
    opacity: 0;
    pointer-events: none;
    transition: opacity 920ms cubic-bezier(0.22, 1, 0.36, 1);
}

html.shadow-muse-page-entering body.shadow-muse-cms::before {
    opacity: 1;
}

body.shadow-muse-cms.pp-vault-access-modal-open::before {
    opacity: 0 !important;
}

body.shadow-muse-cms.shadow-muse-menu-open {
    overflow: hidden;
}

.shadow-muse-shell,
.shadow-muse-shell * {
    box-sizing: border-box;
}

.shadow-muse-shell img {
    display: block;
    width: 100%;
    height: auto;
}

.shadow-muse-shell a {
    color: inherit;
    text-decoration: none;
}

.shadow-muse-shell button {
    background: transparent;
    color: inherit;
    cursor: pointer;
}

.shadow-muse-skip-link {
    position: fixed;
    top: 1rem;
    left: 1rem;
    z-index: 1000;
    padding: 0.65rem 0.9rem;
    background: var(--shadow-cream);
    color: var(--shadow-black);
    transform: translateY(-150%);
}

.shadow-muse-skip-link:focus {
    transform: translateY(0);
}

.content-page__header {
    position: absolute;
    top: 30px;
    right: 0;
    left: 0;
    z-index: 40;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 1.25rem;
    width: min(100% - clamp(3rem, 6vw, 7rem), 1440px);
    margin: 0 auto;
}

.shadow-muse-home-page .content-page__book-button,
.shadow-muse-home-page .content-page__menu-toggle {
    display: none;
}

.shadow-muse-home-page .content-page__header {
    display: flex;
    justify-content: center;
    pointer-events: none;
}

.shadow-muse-home-page .content-page__logo-link {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition:
        opacity 0.9s var(--shadow-ease),
        transform 0.9s var(--shadow-ease);
}

.shadow-muse-home-page.home-logo-visible .content-page__logo-link {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.content-page__logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    justify-self: center;
    width: auto;
    color: rgba(239, 217, 205, 0.88);
    line-height: 1;
}

.content-page__logo {
    font-family: "Shadow Muse Display", Georgia, serif;
    font-size: clamp(1.6rem, 2.2vw, 3rem);
    font-weight: 300;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
}

.content-page__logo-image {
    display: block;
    width: clamp(180px, 18vw, 320px);
    max-width: 42vw;
    max-height: 78px;
    object-fit: contain;
}

.content-page__book-button,
.content-page__book-spacer {
    justify-self: start;
}

.content-page__book-button,
.content-page__menu-toggle {
    color: var(--shadow-gold);
    font-size: 0.75rem;
    font-weight: 300;
    letter-spacing: 0.22em;
    line-height: 1;
    text-transform: uppercase;
    border: none;
}

.content-page__book-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 0.42rem;
    transition: color 0.35s var(--shadow-ease);
}

.content-page__book-button::before,
.template-credit-link::after {
    content: "";
    position: absolute;
    right: 0.22em;
    bottom: 0;
    left: 0;
    height: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.58s cubic-bezier(0.22, 1, 0.36, 1);
}

.content-page__book-button:hover,
.content-page__book-button:focus-visible,
.content-page__menu-toggle:hover,
.content-page__menu-toggle:focus-visible {
    color: var(--shadow-cream);
}

.content-page__book-button:hover::before,
.content-page__book-button:focus-visible::before,
.template-credit-link:hover::after,
.template-credit-link:focus-visible::after {
    transform: scaleX(1);
}

.content-page__menu-toggle {
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 0.9rem;
    min-height: 2.9rem;
    padding: 0;
}

.content-page__menu-icon {
    position: relative;
    display: inline-flex;
    width: 2.15rem;
    height: 0.9rem;
}

.content-page__menu-icon span {
    position: absolute;
    right: 0;
    width: 100%;
    height: 1px;
    background: currentColor;
    transform-origin: center;
    transition:
        top 0.42s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.42s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.24s var(--shadow-ease);
}

.content-page__menu-icon span:first-child {
    top: 0.18rem;
}

.content-page__menu-icon span:last-child {
    top: 0.72rem;
}

.shadow-muse-menu-open .content-page__menu-icon span:first-child {
    top: 0.45rem;
    transform: rotate(42deg);
}

.shadow-muse-menu-open .content-page__menu-icon span:last-child {
    top: 0.45rem;
    transform: rotate(-42deg);
}

.content-page__menu-panel {
    position: fixed;
    top: 0;
    right: 0;
    left: 50vw;
    z-index: 25;
    display: grid;
    align-items: center;
    min-height: 100svh;
    padding: clamp(8rem, 16vh, 13rem) clamp(4rem, 7vw, 8rem) clamp(4rem, 8vh, 6rem);
    background-color: rgba(17, 17, 17, 0.5);
    background:
        linear-gradient(180deg, rgba(28, 36, 42, 0.32), rgba(17, 17, 17, 0.46)),
        radial-gradient(circle at 16% 58%, rgba(255, 214, 170, 0.085), transparent 42%),
        radial-gradient(circle at 22% 18%, rgba(17, 17, 17, 0.42) 0 12%, transparent 36%),
        radial-gradient(circle at 82% 74%, rgba(17, 17, 17, 0.36) 0 16%, transparent 42%),
        linear-gradient(125deg, rgba(28, 36, 42, 0.7) 0%, rgba(17, 17, 17, 0.58) 24%, rgba(28, 36, 42, 0.64) 46%, rgba(17, 17, 17, 0.56) 68%, rgba(28, 36, 42, 0.68) 100%);
    background-size: auto, auto, 170% 170%, 190% 190%, 240% 240%;
    box-shadow: -34px 0 90px rgba(0, 0, 0, 0.32);
    opacity: 0;
    pointer-events: none;
    transform: translateX(100%);
    transition:
        transform 0.82s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.5s var(--shadow-ease);
    animation: shadowMusePageGradient 28s ease-in-out infinite alternate;
    backdrop-filter: blur(26px) saturate(1.12);
    -webkit-backdrop-filter: blur(26px) saturate(1.12);
}

.content-page__menu-panel::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 1px;
    background: linear-gradient(
        180deg,
        rgba(255, 214, 170, 0.08),
        rgba(255, 214, 170, 0.34) 28%,
        rgba(255, 214, 170, 0.22) 72%,
        rgba(255, 214, 170, 0.06)
    );
    opacity: 0;
    pointer-events: none;
    transform: scaleY(0);
    transform-origin: center center;
    transition:
        transform 1.65s var(--shadow-luxury-ease),
        opacity 0.7s var(--shadow-ease);
}

.shadow-muse-menu-open .content-page__menu-panel {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
}

.shadow-muse-menu-open .content-page__menu-panel::before {
    opacity: 1;
    transform: scaleY(1);
    transition-delay: 0.72s, 0.72s;
}

.content-page__menu-nav {
    position: relative;
    z-index: 1;
    display: grid;
    gap: clamp(1.25rem, 2.6vh, 2rem);
    justify-items: start;
}

.content-page__menu-nav a {
    position: relative;
    color: var(--shadow-cream);
    font-family: "Shadow Muse Display", Georgia, serif;
    font-size: clamp(1.45rem, 2vw, 2.2rem);
    font-weight: 300;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
    opacity: 0;
    transform: translateX(24px);
    transition:
        color 0.35s var(--shadow-ease),
        opacity 0.72s var(--shadow-ease),
        transform 0.82s cubic-bezier(0.22, 1, 0.36, 1);
}

.content-page__menu-nav a::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -0.42rem;
    left: 0;
    height: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.56s cubic-bezier(0.22, 1, 0.36, 1);
}

.content-page__menu-nav a:hover,
.content-page__menu-nav a:focus-visible,
.content-page__menu-nav a.is-active {
    color: var(--shadow-gold);
}

.content-page__menu-nav a:hover::after,
.content-page__menu-nav a:focus-visible::after,
.content-page__menu-nav a.is-active::after {
    transform: scaleX(1);
}

.shadow-muse-menu-open .content-page__menu-nav a {
    opacity: 1;
    transform: translateX(0);
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(1) {
    transition-delay: 0.18s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(2) {
    transition-delay: 0.26s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(3) {
    transition-delay: 0.34s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(4) {
    transition-delay: 0.42s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(5) {
    transition-delay: 0.5s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(6) {
    transition-delay: 0.58s;
}

.shadow-muse-menu-open .content-page__menu-nav a:nth-child(n+7) {
    transition-delay: 0.66s;
}

.hero {
    position: relative;
    min-height: 100svh;
    background: var(--shadow-bg);
    color: var(--shadow-gold);
    overflow: clip;
}

.hero__media {
    position: absolute;
    inset: 0;
    filter: brightness(0.74);
}

.hero__media--desktop {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero__media--mobile {
    display: none;
}

.hero__column {
    position: relative;
}

.hero__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 2.5s var(--shadow-ease);
    mix-blend-mode: screen;
}

.hero__slide::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to bottom, rgba(28, 36, 42, 0.2), rgba(28, 36, 42, 0.45)),
        radial-gradient(circle at center, rgba(255, 214, 170, 0.08), transparent 55%);
}

.hero__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.hero__slide.is-active {
    opacity: 1;
}

.hero__overlay {
    position: relative;
    z-index: 2;
    display: grid;
    min-height: 100svh;
    padding: 1.75rem 1.5rem;
}

.hero__overlay--home {
    grid-template-rows: 1fr;
}

.hero__content {
    position: relative;
    display: grid;
    place-items: center;
    text-align: center;
}

.hero__intro {
    grid-area: 1 / 1;
    display: grid;
    place-items: center;
    transition:
        opacity 0.9s var(--shadow-ease),
        transform 0.9s var(--shadow-ease);
}

.hero__intro--logo {
    opacity: 1;
    transform: translateY(0);
}

.hero__intro--statement {
    opacity: 0;
    transform: translateY(24px);
}

.hero__content.is-statement .hero__intro--logo {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-24px);
}

.hero__content.is-statement .hero__intro--statement {
    opacity: 1;
    transform: translateY(0);
}

.hero__lockup {
    display: grid;
    gap: 1rem;
}

.hero__eyebrow,
.content-page__kicker {
    margin: 0;
    color: var(--shadow-gold);
    font-size: 0.74rem;
    font-weight: 300;
    letter-spacing: 0.24em;
    line-height: 1;
    text-transform: uppercase;
}

.hero__title {
    margin: 0;
    font-family: "Shadow Muse Display", Georgia, serif;
    font-size: clamp(4.5rem, 13vw, 10rem);
    font-weight: 300;
    letter-spacing: -5px;
    line-height: 1.02;
    text-transform: uppercase;
}

.hero__statement-wrap {
    display: grid;
    gap: 1rem;
    max-width: 26ch;
    font-family: "Shadow Muse Display", Georgia, serif;
    font-size: clamp(1.9rem, 4vw, 3rem);
    font-weight: 300;
    line-height: 1.16;
    letter-spacing: 0.01em;
    text-transform: uppercase;
}

.hero__statement-wrap > * {
    margin: 0;
}

.hero__enter {
    position: absolute;
    left: 50%;
    bottom: 28vh;
    z-index: 3;
    display: inline-flex;
    padding-bottom: 0.45rem;
    color: var(--shadow-gold);
    font-size: 0.82rem;
    font-weight: 300;
    letter-spacing: 0.34em;
    line-height: 1;
    text-transform: uppercase;
    transform: translateX(-50%);
}

.hero__enter::after {
    content: "";
    position: absolute;
    right: 0.34em;
    bottom: 0;
    left: 0;
    height: 1px;
    background: currentColor;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.72s cubic-bezier(0.22, 1, 0.36, 1);
}

.hero__enter:hover::after,
.hero__enter:focus-visible::after {
    transform: scaleX(1);
}

.pp-homepage-banners {
    position: absolute;
    right: 1.5rem;
    bottom: 1.5rem;
    left: 1.5rem;
    z-index: 4;
}

.content-page__layout {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 50vw) minmax(0, 1fr);
    min-height: 100svh;
}

.content-page__media {
    position: relative;
    min-height: 100svh;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(0, 0, 28, 0.82), rgba(0, 36, 42, 0.58)),
        #4a3418
}

.content-page__media--empty {
    background:
        radial-gradient(circle at 50% 45%, rgba(239, 217, 205, 0.035), transparent 36%),
        linear-gradient(135deg, #151515, #0d0d0d 58%, #050505);
}

.content-page__media picture,
.content-page__media img {
    width: 100%;
    height: 100%;
    min-height: 100svh;
}

.content-page__media img {
    object-fit: cover;
    filter: saturate(0.94) contrast(1.03) brightness(0.94);
    opacity: 0.88;
}

.content-page__media::before,
.content-page__media::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.content-page__media::before {
    z-index: 1;
    background:
        radial-gradient(circle at 42% 28%, rgba(167, 111, 43, 0.42), transparent 48%),
        linear-gradient(135deg, rgba(128, 84, 31, 0.34), rgba(17, 17, 17, 0.18));
    mix-blend-mode: color;
}

.content-page__media::after {
    z-index: 2;
    background:
        linear-gradient(180deg, rgba(28, 36, 42, 0.04), rgba(17, 17, 17, 0.2)),
        linear-gradient(90deg, rgba(17, 17, 17, 0.06), rgba(28, 36, 42, 0.22));
}

.content-page__media--empty::before,
.content-page__media--empty::after {
    display: none;
}

.content-page__panel {
    position: relative;
    display: grid;
    align-items: center;
    min-height: 100svh;
    padding: clamp(9rem, 15vh, 14rem) clamp(3rem, 7vw, 8rem) clamp(8rem, 14vh, 11rem);
}

.content-page__panel::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(28, 36, 42, 0.04), rgba(17, 17, 17, 0.26)),
        radial-gradient(circle at 16% 58%, rgba(255, 214, 170, 0.035), transparent 42%);
    pointer-events: none;
}

.content-page__article {
    position: relative;
    z-index: 1;
    width: min(100%, 40rem);
}

.content-page__kicker {
    margin-bottom: 1.45rem;
}

.content-page__article h1,
.gallery-page__intro h1,
.shadow-muse-gallery-album__header h2 {
    margin: 0;
    color: var(--shadow-cream);
    font-family: "Shadow Muse Display", Georgia, serif;
    font-weight: 300;
    text-transform: uppercase;
}

.content-page__article h1 {
    max-width: 14ch;
    font-size: clamp(2rem, 3.6vw, 4rem);
    letter-spacing: 0.01em;
    line-height: 0.98;
}

.content-page__copy {
    display: grid;
    gap: 1.35rem;
    width: min(100%, 36rem);
    margin-top: clamp(2rem, 4vw, 3rem);
    color: var(--shadow-cream-soft);
    font-size: clamp(0.9rem, 1vw, 1.03rem);
    font-weight: 300;
    letter-spacing: 0.035em;
    line-height: 1.42;
}

.content-page__copy > * {
    margin: 0;
}

.content-page__copy h2,
.content-page__copy h3 {
    margin-top: 0.4rem;
    color: var(--shadow-cream);
    font-family: "Shadow Muse Display", Georgia, serif;
    font-weight: 300;
    line-height: 1.05;
    text-transform: uppercase;
}

.content-page__copy h2 {
    font-size: clamp(1.55rem, 2.7vw, 2.7rem);
}

.content-page__copy h3 {
    font-size: clamp(1.2rem, 1.5vw, 1.5rem);
}

.content-page__copy ul,
.content-page__copy ol {
    display: grid;
    gap: 0.65rem;
    padding-left: 1.2rem;
}

.content-page__copy a:not(.shadow-muse-action-link) {
    text-decoration: underline;
    text-underline-offset: 0.2em;
}

.shadow-muse-action-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 3.15rem;
    margin-top: 0.75rem;
    padding: 0.98rem 1.45rem 0.9rem;
    border: 1px solid rgba(255, 226, 196, 0.48);
    border-radius: 5px;
    background:
        linear-gradient(110deg, rgba(255, 244, 229, 0.24) 0%, rgba(255, 214, 170, 0.42) 28%, rgba(151, 103, 64, 0.24) 54%, rgba(255, 226, 196, 0.34) 78%, rgba(255, 244, 229, 0.18) 100%),
        linear-gradient(180deg, rgba(35, 24, 19, 0.76), rgba(12, 10, 9, 0.82));
    background-position: 0% 50%, 50% 50%;
    background-size: 220% 100%, 100% 100%;
    color: rgba(255, 244, 229, 0.96);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 2px;
    line-height: 1;
    overflow: hidden;
    text-transform: uppercase;
    transition:
        background-position 0.95s cubic-bezier(0.22, 1, 0.36, 1),
        border-color 0.65s var(--shadow-ease),
        box-shadow 0.65s var(--shadow-ease),
        color 0.65s var(--shadow-ease),
        transform 0.65s var(--shadow-ease);
}

.shadow-muse-action-link::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(105deg, transparent 0%, rgba(255, 248, 238, 0.14) 42%, transparent 72%);
    opacity: 0.42;
    pointer-events: none;
    transition:
        opacity 0.72s var(--shadow-ease),
        transform 1.05s cubic-bezier(0.22, 1, 0.36, 1);
}

.shadow-muse-action-link:hover,
.shadow-muse-action-link:focus-visible {
    border-color: rgba(255, 236, 216, 0.72);
    background-position: 100% 50%, 50% 50%;
    color: #fff7ee;
    box-shadow:
        inset 0 1px 0 rgba(255, 248, 238, 0.24),
        0 18px 40px rgba(0, 0, 0, 0.22),
        0 0 28px rgba(255, 214, 170, 0.08);
    transform: translateY(-1px);
}

.shadow-muse-action-link:hover::after,
.shadow-muse-action-link:focus-visible::after {
    opacity: 0.62;
    transform: translateX(28%);
}

.gallery-page {
    position: relative;
    min-height: 100svh;
    padding: clamp(9rem, 15vh, 13rem) 0 clamp(7rem, 12vh, 10rem);
}

.gallery-page::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 24% 18%, rgba(255, 214, 170, 0.055), transparent 32%),
        linear-gradient(180deg, rgba(28, 36, 42, 0.02), rgba(17, 17, 17, 0.32));
    pointer-events: none;
}

.gallery-page__inner {
    position: relative;
    z-index: 1;
    width: min(1600px, calc(100% - clamp(2rem, 6vw, 8rem)));
    margin: 0 auto;
    padding-bottom: clamp(4rem, 8vw, 7rem);
}

.gallery-page__intro {
    display: grid;
    justify-items: center;
    width: min(920px, 100%);
    margin: 0 auto clamp(3rem, 6vw, 5rem);
    text-align: center;
}

.gallery-page__intro h1 {
    max-width: 14ch;
    font-size: clamp(2.2rem, 4vw, 6rem);
    letter-spacing: 0.01em;
    line-height: 0.95;
}

.gallery-page__copy {
    justify-items: center;
    position: relative;
    padding-bottom: 50px;
    text-align: center;
}

.gallery-page__copy::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    width: min(580px, 100%);
    height: 1px;
    background: #444;
    transform: translateX(-50%);
}

.shadow-muse-gallery-albums {
    display: grid;
    gap: clamp(4rem, 7vw, 7rem);
}

.shadow-muse-gallery-album__header {
    display: grid;
    gap: 0.95rem;
    width: min(760px, 100%);
    margin: 0 auto 1.8rem;
    text-align: center;
}

.shadow-muse-gallery-album__header h2 {
    font-size: 18px;
    line-height: 0.88;
    letter-spacing: 10px;
}

.shadow-muse-gallery-album__header p {
    margin: 0;
    color: var(--shadow-cream-soft);
    font-size: 0.95rem;
    font-weight: 300;
    letter-spacing: 0.04em;
    line-height: 1.55;
}

.shadow-muse-gallery-grid {
    display: grid;
    grid-template-columns: repeat(var(--gallery-columns, 4), minmax(0, 1fr));
    gap: 25px;
}

.shadow-muse-gallery-item {
    position: relative;
    display: block;
    aspect-ratio: var(--thumbnail-aspect-ratio, 1 / 1);
    overflow: hidden;
    background: rgba(239, 217, 205, 0.08);
}

.shadow-muse-gallery-item::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 62%;
    background: linear-gradient(180deg, transparent, rgba(17, 17, 17, 0.72));
    opacity: 0;
    transform: translateY(30%);
    transition:
        opacity 360ms var(--shadow-ease),
        transform 420ms var(--shadow-ease);
}

.shadow-muse-gallery-item:hover::after,
.shadow-muse-gallery-item:focus-visible::after {
    opacity: 1;
    transform: translateY(0);
}

.shadow-muse-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.shadow-muse-gallery-item video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    background: #050505;
}

.shadow-muse-video-thumb .media-preview-play {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    place-items: center;
    pointer-events: none;
}

.shadow-muse-video-thumb .media-preview-play::before {
    width: 0;
    height: 0;
    margin-left: 5px;
    border-top: 14px solid transparent;
    border-bottom: 14px solid transparent;
    border-left: 22px solid rgba(239, 217, 205, 0.92);
    content: "";
    filter: drop-shadow(0 10px 20px rgba(0, 0, 0, 0.55));
}

.shadow-muse-vault-album .shadow-muse-gallery-album__header h2 {
    color: rgba(239, 217, 205, 0.96);
}

.shadow-muse-vault-card {
    display: grid;
    gap: 1.2rem;
    width: min(420px, 100%);
    margin: 0 auto;
    padding: 0;
    color: rgba(239, 217, 205, 0.88);
    font: inherit;
    text-align: center;
    background: transparent;
    border: 0;
    cursor: pointer;
}

.shadow-muse-vault-card__media {
    position: relative;
    display: block;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: rgba(239, 217, 205, 0.08);
}

.shadow-muse-vault-card__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 50% 45%, transparent 0 24%, rgba(17, 17, 17, 0.08) 46%),
        linear-gradient(180deg, rgba(17, 17, 17, 0.18), rgba(17, 17, 17, 0.74));
    pointer-events: none;
}

.shadow-muse-vault-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.48) saturate(0.78);
    transform: scale(1.01);
    transition:
        filter 420ms var(--shadow-ease),
        transform 520ms var(--shadow-ease);
}

.shadow-muse-vault-card:hover .shadow-muse-vault-card__media img,
.shadow-muse-vault-card:focus-visible .shadow-muse-vault-card__media img {
    filter: brightness(0.62) saturate(0.95);
    transform: scale(1.045);
}

.shadow-muse-vault-card__lock {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    place-items: center;
    color: rgba(239, 217, 205, 0.92);
}

.shadow-muse-vault-card__lock svg {
    display: block;
    width: clamp(42px, 16%, 68px);
    height: auto;
    filter: drop-shadow(0 14px 30px rgba(0, 0, 0, 0.58));
}

.shadow-muse-vault-card__text {
    color: var(--shadow-gold);
    font-size: 0.76rem;
    font-weight: 300;
    letter-spacing: 0.24em;
    line-height: 1;
    text-transform: uppercase;
}

.shadow-muse-vault-card:focus-visible {
    outline: 1px solid rgba(239, 217, 205, 0.72);
    outline-offset: 8px;
}

.content-page__footer {
    position: absolute;
    bottom: clamp(1.45rem, 3vw, 2.25rem);
    left: 50%;
    z-index: 35;
    width: min(100% - 3rem, 46rem);
    color: rgba(239, 217, 205, 0.68);
    font-size: 0.72rem;
    font-weight: 300;
    letter-spacing: 0.035em;
    line-height: 1.5;
    text-align: center;
    transform: translateX(-50%);
    transition:
        color 0.35s var(--shadow-ease),
        opacity 0.35s var(--shadow-ease);
}

.shadow-muse-menu-open .content-page__footer {
    color: rgba(239, 217, 205, 0.78);
}

.content-page__footer p {
    margin: 0;
}

.template-credit-link {
    position: relative;
    color: inherit;
}

.template-credit-link::after {
    right: 0;
}

@media (prefers-reduced-motion: no-preference) {
    .template-page-shell {
        animation: shadowMusePageIn 620ms cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    html.shadow-muse-page-leaving body.shadow-muse-cms::before {
        opacity: 1;
        transition-duration: 620ms;
        transition-timing-function: cubic-bezier(0.76, 0, 0.24, 1);
    }

    html.shadow-muse-page-leaving .template-page-shell {
        opacity: 0.28;
        transform: translateY(4px);
        transition:
            opacity 560ms ease,
            transform 560ms ease;
    }
}

@keyframes shadowMusePageIn {
    from {
        opacity: 0;
        transform: translateY(8px);
    }

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

@keyframes shadowMusePageGradient {
    0% {
        background-position: 0% 40%, 100% 60%, 0% 50%;
    }

    50% {
        background-position: 55% 28%, 45% 88%, 74% 42%;
    }

    100% {
        background-position: 100% 64%, 0% 36%, 100% 58%;
    }
}

@media (prefers-reduced-motion: reduce) {
    body.shadow-muse-cms::before {
        opacity: 0;
        transition-duration: 1ms;
    }

    body.shadow-muse-cms,
    .content-page__menu-panel {
        animation: none;
    }

    .hero__slide,
    .hero__intro,
    .content-page__menu-panel,
    .content-page__menu-nav a,
    .content-page__menu-panel::before {
        transition-duration: 1ms;
    }
}

@media (max-width: 1023px) {
    .content-page__header {
        top: 1.6rem;
        width: calc(100% - 2rem);
    }

    .hero__enter {
        bottom: 26vh;
    }

    .hero__media--desktop {
        display: none;
    }

    .hero__media--mobile {
        display: block;
    }

    .content-page__menu-panel {
        left: 0;
        padding: clamp(7rem, 15vh, 10rem) 2rem 4rem;
    }

    .content-page__layout {
        grid-template-columns: 1fr;
    }

    .content-page__media,
    .content-page__media picture,
    .content-page__media img {
        min-height: 54svh;
    }

    .content-page__media::after {
        background:
            linear-gradient(180deg, rgba(28, 36, 42, 0.08), rgba(17, 17, 17, 0.28)),
            linear-gradient(180deg, transparent 52%, rgba(28, 36, 42, 0.42));
    }

    .content-page__panel {
        min-height: auto;
        padding: clamp(4.5rem, 12vw, 7rem) 2rem;
    }

    .content-page__article {
        margin: 0 auto;
    }

    .content-page__footer {
        position: relative;
        bottom: auto;
        left: auto;
        width: calc(100% - 3rem);
        margin: 1.75rem auto 1.5rem;
        transform: none;
    }

    .shadow-muse-gallery-grid {
        grid-template-columns: repeat(var(--gallery-tablet-columns, 3), minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    body.shadow-muse-cms {
        font-size: 14px;
    }

    .content-page__header {
        grid-template-columns: 1fr auto 1fr;
        gap: 0.7rem;
    }

    .content-page__logo {
        max-width: 54vw;
        overflow-wrap: anywhere;
        font-size: clamp(1.25rem, 6.2vw, 2rem);
        letter-spacing: 0.06em;
        text-align: center;
        white-space: normal;
    }

    .content-page__logo-image {
        width: min(46vw, 240px);
        max-width: 46vw;
        max-height: 58px;
    }

    .content-page__book-button {
        font-size: 0.66rem;
        letter-spacing: 0.16em;
    }

    .content-page__menu-label {
        display: none;
    }

    .content-page__menu-icon {
        width: 1.8rem;
    }

    .hero__overlay {
        padding-inline: 1.25rem;
    }

    .hero__title {
        max-width: 92vw;
        font-size: clamp(3.6rem, 18vw, 5.8rem);
        letter-spacing: -3px;
    }

    .hero__statement-wrap {
        max-width: 20ch;
    }

    .content-page__article h1 {
        font-size: clamp(2.6rem, 12vw, 4rem);
    }

    .gallery-page__inner {
        width: calc(100% - 2rem);
    }

    .shadow-muse-gallery-grid {
        grid-template-columns: repeat(var(--gallery-mobile-columns, 2), minmax(0, 1fr));
    }
}
