:root {
    --color-bg: #fbe7dc;
    --color-bg-rgb: 251, 231, 220;
    --color-ivory: #fff4ed;
    --color-ivory-rgb: 255, 244, 237;
    --color-sand: #f6dace;
    --color-tan: #f2c5b2;
    --color-amber: #eda98d;
    --color-copper: #de8a66;
    --color-brown: #b96a48;
    --color-deep: #54362c;
    --color-deep-rgb: 84, 54, 44;
    --color-white: #ffffff;
    --color-muted: rgba(84, 54, 44, 0.58);
    --color-accent-rgb: 222, 138, 102;
    --color-accent-strong-rgb: 191, 100, 63;
    --color-accent-soft-rgb: 243, 199, 178;
    --color-accent-light-rgb: 250, 224, 209;
    --color-error: #e03131;
    --color-error-rgb: 224, 49, 49;
    --color-header-light-rgb: 243, 209, 190;
    --color-header-rich-rgb: 217, 123, 76;
    --gradient-primary: linear-gradient(90deg, #b8583e 0%, #ffd8bc 100%);
    --hero-card-gradient: linear-gradient(154deg,
            rgba(249, 223, 209, 0.98) 0%,
            rgba(223, 139, 103, 0.96) 50%,
            rgba(181, 96, 66, 0.9) 100%);
    --hero-card-foreground: rgba(255, 255, 255, 0.96);
    --color-men-base: #5b3b33;
    --color-men-base-rgb: 91, 59, 51;
    --color-men-highlight: #a86a55;
    --color-men-highlight-rgb: 168, 106, 85;
    --color-men-light-rgb: 233, 196, 176;
    --ink-strong: rgba(var(--color-deep-rgb), 0.88);
    --ink-medium: rgba(var(--color-deep-rgb), 0.66);
    --ink-muted: rgba(var(--color-deep-rgb), 0.52);
    --ink-soft: rgba(var(--color-deep-rgb), 0.36);
    --max-width: 1500px;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    background: var(--gradient-primary);
    color: var(--color-deep);
    line-height: 1.65;
    position: relative;
}

body.nav-open {
    overflow: hidden;
    touch-action: none;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -2;
    background: radial-gradient(circle at 18% 16%, rgba(255, 215, 198, 0.42), transparent 54%),
                radial-gradient(circle at 82% 12%, rgba(255, 191, 164, 0.34), transparent 48%),
                linear-gradient(198deg, rgba(255, 244, 236, 0.5) 0%, transparent 72%);
}

body::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    background-image: linear-gradient(135deg, rgba(255, 222, 204, 0.35) 0%, rgba(255, 240, 228, 0.2) 55%, rgba(255, 255, 255, 0.32) 100%);
    background-size: 140% 140%;
    background-position: 0% 50%;
    animation: bg-shimmer 28s ease-in-out infinite alternate;
    mix-blend-mode: soft-light;
    filter: saturate(1.08);
    pointer-events: none;
}

body,
body::before,
body::after {
    transition: background 1.4s ease-in-out, background-image 1.6s ease-in-out, filter 1.4s ease-in-out;
}

.hero,
.events,
.menu-bubbles {
    transition: background 1.4s ease-in-out, background-image 1.6s ease-in-out;
}

body.theme-vip {
    --gradient-primary: linear-gradient(90deg, #7f4a23 0%, #ae937d 100%);
}

body.theme-vip::before {
    background: radial-gradient(circle at 22% 18%, rgba(255, 208, 173, 0.42), transparent 55%),
                radial-gradient(circle at 78% 22%, rgba(208, 149, 115, 0.4), transparent 52%),
                linear-gradient(210deg, rgba(255, 241, 229, 0.45) 0%, transparent 72%);
}

body.theme-vip::after {
    background-image: linear-gradient(135deg, rgba(255, 233, 214, 0.32) 0%, rgba(211, 166, 132, 0.42) 55%, rgba(142, 90, 52, 0.35) 100%);
    filter: saturate(1.05);
}

body.theme-stylebar {
    --gradient-primary: linear-gradient(90deg, #cda189 0%, #ebd1c8 100%);
}

body.theme-stylebar::before {
    background: radial-gradient(circle at 18% 20%, rgba(242, 206, 188, 0.45), transparent 56%),
                radial-gradient(circle at 82% 26%, rgba(217, 166, 136, 0.38), transparent 52%),
                linear-gradient(200deg, rgba(255, 236, 226, 0.55) 0%, transparent 72%);
}

body.theme-stylebar::after {
    background-image: linear-gradient(135deg, rgba(248, 228, 218, 0.35) 0%, rgba(220, 176, 145, 0.32) 55%, rgba(208, 150, 117, 0.35) 100%);
    filter: saturate(1.08);
}

a {
    color: inherit;
    text-decoration: none;
}

a:hover {
    color: var(--color-copper);
}

img {
    max-width: 100%;
    display: block;
}

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

.container {
    width: min(var(--max-width), 88%);
    margin: 0 auto;
}

.hero .container {
    width: min(var(--max-width), 100%);
    max-width: var(--max-width);
}

@media (min-width: 900px) and (max-width: 1200px) and (orientation: landscape) {
    .hero .container {
        width: min(var(--max-width), 90%);
    }

    .hero-visual {
        align-items: flex-end;
        padding-inline-start: clamp(0.6rem, 2vw, 1.2rem);
        padding-inline-end: clamp(1.2rem, 3vw, 2.6rem);
    }

    .hero-card-stage {
        justify-content: flex-end;
        gap: clamp(1rem, 2.4vw, 1.8rem);
        margin-left: auto;
        max-width: 94%;
    }

    .hero-card-carousel {
        flex: 0 1 clamp(320px, 46vw, 620px);
        width: min(620px, 85%);
        min-height: clamp(520px, 52vw, 700px);
    }

    .hero-card-carousel > .hero-frame {
        min-height: clamp(520px, 52vw, 700px);
    }
}

.section-block {
    position: relative;
    padding: 6.5rem 0;
}

.section-block::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    width: 1px;
    height: 68px;
    background: linear-gradient(180deg, rgba(var(--color-accent-rgb), 0.55), rgba(var(--color-accent-rgb), 0));
    transform: translateX(-50%);
}

.section-soft {
    background: transparent;
}

.section-emphasis {
    background: transparent;
    border-top: none;
    border-bottom: none;
}

.header {
    position: sticky;
    top: 0;
    z-index: 30;
    background-image: linear-gradient(110deg, rgba(var(--color-header-light-rgb), 0.78), rgba(var(--color-header-rich-rgb), 0.92)), url("../images/backgrounds/header-marble.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-blend-mode: soft-light;
    backdrop-filter: blur(8px);
    border-bottom: 1px solid rgba(var(--color-header-rich-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.92);
    transform: translateZ(0);
    transition: transform 0.28s ease, opacity 0.28s ease;
    will-change: transform;
}

.header--hidden {
    transform: translateY(-100%);
    opacity: 0;
    pointer-events: none;
}

.header .container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.4rem 0;
}

.header .logo {
    color: rgba(var(--color-deep-rgb), 0.96);
    text-shadow: 0 2px 12px rgba(255, 255, 255, 0.48);
}

.header .nav a {
    color: rgba(var(--color-deep-rgb), 0.95);
    font-weight: 500;
    text-shadow: 0 2px 14px rgba(255, 255, 255, 0.52);
}

.header .nav a:hover,
.header .nav a:focus-visible {
    color: rgba(var(--color-deep-rgb), 1);
    text-shadow: 0 3px 16px rgba(255, 255, 255, 0.6);
}

.header .btn-outline {
    background: rgba(255, 255, 255, 0.32);
    color: rgba(var(--color-deep-rgb), 0.95);
    border-color: rgba(255, 255, 255, 0.58);
    box-shadow: 0 10px 24px rgba(var(--color-header-rich-rgb), 0.16);
    backdrop-filter: blur(14px);
}

.header .btn-outline:hover,
.header .btn-outline:focus-visible {
    background: rgba(255, 255, 255, 0.52);
    color: rgba(var(--color-deep-rgb), 0.98);
    border-color: rgba(255, 255, 255, 0.82);
}

.logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    font-family: "Playfair Display", serif;
    font-weight: 600;
    font-size: 1.4rem;
    color: rgba(var(--color-deep-rgb), 0.9);
    text-decoration: none;
    line-height: 1;
}

.logo-text {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

.logo-text--kr {
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    font-size: 1.05rem;
    letter-spacing: 0.12rem;
    font-weight: 500;
    text-transform: none;
}

.logo-text--latin {
    font-size: 1.32rem;
    letter-spacing: 0.32rem;
    text-transform: uppercase;
}

.logo-divider {
    width: 1px;
    height: 1.6rem;
    background: currentColor;
    opacity: 0.35;
}

.logo--footer {
    color: var(--color-white);
    gap: 0.5rem;
}

.logo--footer .logo-divider {
    opacity: 0.45;
}

.logo--footer .logo-text--latin {
    letter-spacing: 0.28rem;
}

.nav {
    display: flex;
    gap: 1.8rem;
    font-size: 0.95rem;
    letter-spacing: 0.08rem;
}

.nav a {
    position: relative;
    padding-bottom: 0.35rem;
    color: rgba(var(--color-deep-rgb), 0.78);
    transition: color 0.25s ease;
}

.header .nav a:hover {
    color: rgba(var(--color-deep-rgb), 0.96);
}

.nav a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: var(--color-copper);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.35s ease;
}

.nav a:hover::after {
    transform: scaleX(1);
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.9rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.94), rgba(var(--color-accent-rgb), 0.96));
    color: var(--color-white);
    border: 1px solid transparent;
    font-size: 0.95rem;
    letter-spacing: 0.12rem;
    text-transform: uppercase;
    transition: all 0.35s ease;
    cursor: pointer;
}

.btn:hover {
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.98), rgba(var(--color-accent-strong-rgb), 0.98));
    color: var(--color-white);
}

.btn-ghost {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.72rem 1.6rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.42);
    background: rgba(255, 255, 255, 0.82);
    color: rgba(var(--color-deep-rgb), 0.78);
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    font-size: 0.82rem;
    transition: transform 0.28s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    backdrop-filter: blur(14px);
    will-change: transform;
}

.btn-ghost:hover {
    background: rgba(255, 255, 255, 0.96);
    border-color: rgba(var(--color-accent-strong-rgb), 0.55);
    color: rgba(var(--color-deep-rgb), 0.88);
    transform: translateY(-4px) scale(1.06);
}

.btn-ghost--secondary {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.28);
    color: rgba(var(--color-deep-rgb), 0.72);
}

.btn-ghost--secondary:hover,
.btn-ghost--secondary:focus-visible {
    background: rgba(255, 255, 255, 0.32);
    border-color: rgba(var(--color-accent-strong-rgb), 0.5);
    color: rgba(var(--color-deep-rgb), 0.9);
}

.btn-ghost:active {
    transform: translateY(-1px) scale(1.02);
}

.btn__spinner {
    width: 1.05em;
    height: 1.05em;
    border: 2px solid currentColor;
    border-top-color: transparent;
    border-radius: 999px;
    margin-right: 0.55rem;
    animation: button-spinner 0.75s linear infinite;
    display: inline-block;
    flex-shrink: 0;
}

.btn__spinner[hidden] {
    display: none !important;
}

.btn.is-loading,
.btn-ghost.is-loading {
    cursor: progress;
}

.btn.is-loading .btn__label,
.btn-ghost.is-loading .btn__label {
    opacity: 0.85;
}

@keyframes button-spinner {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.btn-outline {
    background: transparent;
    color: var(--color-deep);
    border: 1px solid rgba(var(--color-deep-rgb), 0.28);
}

.btn-question {
    position: relative;
    background: linear-gradient(125deg, rgba(var(--color-accent-soft-rgb), 0.92) 0%, rgba(var(--color-accent-rgb), 0.98) 55%, rgba(var(--color-accent-strong-rgb), 0.96) 100%);
    background-size: 180% 180%;
    color: #ffffff;
    border: 1px solid rgba(var(--color-accent-rgb), 0.45);
    box-shadow: 0 18px 36px -18px rgba(var(--color-accent-rgb), 0.6), 0 12px 30px -16px rgba(var(--color-accent-soft-rgb), 0.45);
    overflow: hidden;
    isolation: isolate;
    letter-spacing: 0.16rem;
    backdrop-filter: blur(10px);
    transition: transform 0.32s ease, box-shadow 0.32s ease, filter 0.32s ease, background-position 0.6s ease;
    z-index: 0;
}

.btn-question::before {
    content: "";
    position: absolute;
    inset: -65% -30%;
    background: linear-gradient(120deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.85), rgba(255, 255, 255, 0));
    animation: btn-gleam 3.6s ease-in-out infinite;
    mix-blend-mode: screen;
    opacity: 0.85;
    pointer-events: none;
    z-index: -1;
}

.btn-question:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.9);
    outline-offset: 4px;
}

.btn-question:hover {
    transform: translateY(-3px) scale(1.04);
    background-position: 100% 50%;
    box-shadow: 0 26px 44px -20px rgba(var(--color-accent-rgb), 0.72), 0 16px 36px -18px rgba(var(--color-accent-soft-rgb), 0.54);
    filter: saturate(1.12);
}

.btn-question:hover::before {
    animation-duration: 2.2s;
    opacity: 1;
}

.btn-outline:hover {
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.94), rgba(var(--color-accent-rgb), 0.96));
    color: var(--color-white);
    border-color: transparent;
}

@keyframes btn-gleam {
    0% {
        transform: rotate(18deg) translateX(-160%);
    }
    48% {
        transform: rotate(18deg) translateX(0%);
    }
    62% {
        transform: rotate(18deg) translateX(110%);
    }
    100% {
        transform: rotate(18deg) translateX(200%);
    }
}

.nav-toggle {
    display: none;
    flex-direction: column;
    gap: 0.3rem;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0.25rem;
}

.nav-toggle span {
    width: 24px;
    height: 2px;
    background: var(--color-deep);
    transition: transform 0.35s ease, opacity 0.35s ease;
}

.nav-toggle.open span:nth-child(1) {
    transform: translateY(8px) rotate(45deg);
}

.nav-toggle.open span:nth-child(2) {
    opacity: 0;
}

.nav-toggle.open span:nth-child(3) {
    transform: translateY(-8px) rotate(-45deg);
}

.hero {
    position: relative;
    z-index: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: clamp(3.2rem, 6vw, 4.8rem);
    padding-bottom: clamp(5.4rem, 8.8vw, 7.4rem);
    min-height: clamp(540px, 90vh, 720px);
    background: var(--gradient-primary);
    color: rgba(255, 255, 255, 0.95);
    overflow: hidden;
    transition: background 0.9s ease-in-out, background-image 1.1s ease-in-out;
}

@media (min-width: 1025px) {
    .hero {
        background: var(--gradient-primary) !important;
    }

    .hero::before,
    .hero::after {
        display: none;
    }
}


.events {
    padding-top: clamp(8.1rem, 17.5vw, 12.3rem);
    padding-bottom: clamp(8rem, 18vw, 12rem);
    margin-bottom: clamp(6rem, 16vw, 11rem);
    background: var(--gradient-primary);
    color: rgba(255, 255, 255, 0.92);
}

.events.section-block::before {
    display: none;
}

.menu-bubbles {
    position: relative;
    margin-top: 0;
    padding: clamp(0.4rem, 1.2vw, 0.8rem) min(6vw, 4rem) clamp(8rem, 16vw, 13rem);
    background: var(--gradient-primary);
    color: rgba(255, 255, 255, 0.96);
    text-align: center;
    overflow: hidden;
    transition: background 0.9s ease-in-out, background-image 1.1s ease-in-out;
}


.menu-bubbles__inner {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.04rem, 0.24vw, 0.32rem);
    margin: 0 auto;
    width: min(1300px, 92%);
    z-index: 1;
}

.menu-bubbles__supertitle {
    margin: 0;
    font-size: clamp(1.08rem, 2.88vw, 1.44rem);
    letter-spacing: 1.26rem;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.68);
    font-weight: 300;
    line-height: 1;
}

.menu-bubbles__title {
    margin: 0;
    font-size: clamp(3.6rem, 8.4vw, 5.28rem);
    letter-spacing: 4.212rem;
    text-transform: uppercase;
    font-weight: 100;
    color: #ffffff;
    line-height: 0.98;
}

.menu-bubbles__title::before {
    content: "";
    display: inline-block;
    width: 4.212rem;
}

.menu-bubbles__subtitle {
    margin: 0;
    font-size: clamp(1.1rem, 2.8vw, 1.32rem);
    letter-spacing: 0.08rem;
    text-transform: uppercase;
    color: #ffffff;
    font-weight: 300;
}

.menu-bubbles__cloud {
    position: relative;
    width: min(900px, 83%);
    aspect-ratio: 1 / 1;
    margin: clamp(-0.4rem, 0.6vw, 0.2rem) auto 0;
    transition: background 0.9s ease-in-out, transform 0.4s ease, width 0.4s ease;
}

.menu-bubble {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    border-radius: 50%;
    background: linear-gradient(130deg, #ffd8bc 0%, #b2644f 100%);
    color: #ffffff;
    text-transform: uppercase;
    letter-spacing: 0.18rem;
    padding: clamp(1.62rem, 3.6vw, 2.34rem);
    box-shadow: 0 26px 52px -34px rgba(97, 36, 20, 0.55);
    transition: transform 0.35s ease, box-shadow 0.35s ease, opacity 0.35s ease, background 0.8s ease;
    text-decoration: none;
    cursor: pointer;
    font-weight: 300;
    border: none;
    appearance: none;
    --bubble-translate-x: -50%;
    --bubble-translate-y: -50%;
    --bubble-scale: 1;
    --bubble-float-distance: 30px;
    --bubble-float-duration: 7s;
    --bubble-float-delay: 0s;
    --bubble-start-shift: 0px;
    transform: translate(var(--bubble-translate-x), calc(var(--bubble-translate-y) + var(--bubble-start-shift))) scale(var(--bubble-scale));
    animation: bubbleFloat var(--bubble-float-duration) ease-in-out infinite alternate;
    animation-delay: var(--bubble-float-delay);
    will-change: transform;
}

body.theme-vip .menu-bubble {
    background: linear-gradient(135deg, #d6c3ae 0%, #5d3d29 100%);
    box-shadow: 0 28px 56px -32px rgba(55, 34, 23, 0.56);
    color: #ffffff;
}

body.theme-vip .menu-bubble:hover,
body.theme-vip .menu-bubble:focus-visible {
    box-shadow: 0 36px 68px -30px rgba(55, 34, 23, 0.62);
}

body.theme-stylebar .menu-bubble {
    background: linear-gradient(135deg, #f1d9cc 0%, #c88a6a 100%);
    box-shadow: 0 28px 56px -34px rgba(143, 82, 49, 0.52);
    color: #fff8f4;
}

body.theme-stylebar .menu-bubble:hover,
body.theme-stylebar .menu-bubble:focus-visible {
    box-shadow: 0 36px 68px -30px rgba(143, 82, 49, 0.58);
}

@keyframes bubbleFloat {
    0% {
        transform: translate(var(--bubble-translate-x), calc(var(--bubble-translate-y) + var(--bubble-start-shift))) scale(var(--bubble-scale));
    }
    100% {
        transform: translate(var(--bubble-translate-x), calc(var(--bubble-translate-y) + var(--bubble-start-shift) - var(--bubble-float-distance))) scale(var(--bubble-scale));
    }
}

@media (prefers-reduced-motion: reduce) {
    .menu-bubble {
        animation: none !important;
        animation-delay: 0s !important;
        --bubble-scale: 1;
        transform: translate(var(--bubble-translate-x), calc(var(--bubble-translate-y) + var(--bubble-start-shift)));
    }
}

.menu-bubble:hover,
.menu-bubble:focus-visible {
    --bubble-scale: 1.06;
    box-shadow: 0 34px 64px -30px rgba(97, 36, 20, 0.65);
    animation-play-state: paused;
    outline: none;
}

.menu-bubble[aria-disabled="true"] {
    cursor: not-allowed;
    opacity: 0.68;
}

.menu-bubble[aria-disabled="true"]:hover,
.menu-bubble[aria-disabled="true"]:focus-visible {
    --bubble-scale: 1;
    animation-play-state: running;
    box-shadow: 0 26px 52px -34px rgba(97, 36, 20, 0.55);
}

.menu-bubble__title {
    font-size: clamp(1.08rem, 2.7vw, 1.37rem);
    letter-spacing: 0.2rem;
    font-weight: 300;
    line-height: 1.15;
}

.menu-bubble__subtitle {
    font-size: clamp(0.79rem, 2.16vw, 0.97rem);
    letter-spacing: 0.08rem;
    text-transform: none;
    color: #ffffff;
    font-weight: 300;
    line-height: 1.2;
}

.menu-bubble--xl {
    width: clamp(228px, 35.2vw, 331.2px);
    height: clamp(228px, 35.2vw, 331.2px);
}

.menu-bubble--lg {
    width: clamp(176px, 29vw, 248.4px);
    height: clamp(176px, 29vw, 248.4px);
}

.menu-bubble--md {
    width: clamp(145px, 24.8vw, 207px);
    height: clamp(145px, 24.8vw, 207px);
}

.menu-bubble--sm {
    width: clamp(124.2px, 20.7vw, 176px);
    height: clamp(124.2px, 20.7vw, 176px);
}

.menu-bubble--center {
    top: 36%;
    left: 50%;
    --bubble-float-distance: 38px;
    --bubble-float-duration: 6.6s;
    --bubble-float-delay: -1.4s;
    --bubble-start-shift: -10px;
}

.menu-bubble--design {
    top: 26%;
    left: 10%;
    --bubble-float-distance: 30px;
    --bubble-float-duration: 5.6s;
    --bubble-float-delay: -0.8s;
    --bubble-start-shift: 12px;
}

.menu-bubble--about {
    top: 56%;
    left: 6%;
    --bubble-float-distance: 32px;
    --bubble-float-duration: 5.4s;
    --bubble-float-delay: -2s;
    --bubble-start-shift: -18px;
}

.menu-bubble--pricing {
    top: 20%;
    left: 90%;
    --bubble-float-distance: 34px;
    --bubble-float-duration: 6s;
    --bubble-float-delay: -3s;
    --bubble-start-shift: 8px;
}

.menu-bubble--instagram {
    top: 72%;
    left: 34%;
    width: clamp(144px, 26.2vw, 209.5px);
    height: clamp(144px, 26.2vw, 209.5px);
    --bubble-float-distance: 33px;
    --bubble-float-duration: 5.8s;
    --bubble-float-delay: -4.2s;
    --bubble-start-shift: -6px;
}

.menu-bubble--schedule {
    top: 50%;
    left: 92%;
    --bubble-float-distance: 31px;
    --bubble-float-duration: 5.2s;
    --bubble-float-delay: -1.5s;
    --bubble-start-shift: 14px;
}

.menu-bubble--kakao {
    top: 68%;
    left: 68%;
    width: clamp(130.5px, 21.8vw, 188.1px);
    height: clamp(130.5px, 21.8vw, 188.1px);
    --bubble-float-distance: 32px;
    --bubble-float-duration: 5.7s;
    --bubble-float-delay: -2.6s;
    --bubble-start-shift: -14px;
}

.menu-bubbles__note {
    margin-top: clamp(2rem, 4vw, 3rem);
    font-size: clamp(0.78rem, 1.8vw, 0.92rem);
    letter-spacing: 0.05rem;
    color: rgba(255, 255, 255, 0.7);
}

.menu-bubble:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.5);
    outline-offset: 6px;
}

@media (max-width: 1024px) {
    .menu-bubbles__cloud {
        width: min(864px, 92%);
    }

    .menu-bubble--xl {
        width: clamp(209px, 32.3vw, 303.4px);
        height: clamp(209px, 32.3vw, 303.4px);
    }

    .menu-bubble--lg {
        width: clamp(161px, 26.6vw, 227px);
        height: clamp(161px, 26.6vw, 227px);
    }

    .menu-bubble--md {
        width: clamp(133px, 22.7vw, 189.9px);
        height: clamp(133px, 22.7vw, 189.9px);
    }

    .menu-bubble--sm {
        width: clamp(114px, 19vw, 161.2px);
        height: clamp(114px, 19vw, 161.2px);
    }

    .menu-bubble--center {
        top: 38%;
        left: 50%;
    }

    .menu-bubble--design {
        top: 22%;
        left: 18%;
    }

    .menu-bubble--about {
        top: 60%;
        left: 16%;
    }

    .menu-bubble--pricing {
        left: 84%;
        top: 32%;
    }

    .menu-bubble--schedule {
        left: 80%;
        top: 58%;
    }

    .menu-bubble--instagram {
        top: 74%;
        left: 36%;
        width: clamp(132px, 24vw, 191.5px);
        height: clamp(132px, 24vw, 191.5px);
    }

    .menu-bubble--kakao {
        top: 70%;
        left: 68%;
        width: clamp(119px, 20vw, 172.4px);
        height: clamp(119px, 20vw, 172.4px);
    }
}

@media (max-width: 900px) and (orientation: portrait) {
    .hero-brand {
        min-height: clamp(220px, 34vh, 320px);
        gap: clamp(0.6rem, 1.8vw, 1.2rem);
    }

    .hero-visual {
        align-items: center;
        padding-block-start: clamp(1.8rem, 6vw, 2.6rem);
        padding-block-end: clamp(2.8rem, 8vw, 4.6rem);
    }

    .hero-card-stage {
        max-width: min(600px, 100%);
    }

    .hero-card-carousel {
        min-height: clamp(540px, 120vw, 700px);
    }

    .hero-card-carousel > .hero-frame,
    .hero-frame {
        min-height: clamp(540px, 120vw, 700px);
    }

    .menu-bubbles__cloud {
        width: min(1100px, 100%);
    }

    .menu-bubble--xl {
        width: clamp(185px, 28.6vw, 253px);
        height: clamp(185px, 28.6vw, 253px);
    }

    .menu-bubble--lg {
        width: clamp(138px, 21.2vw, 184px);
        height: clamp(138px, 21.2vw, 184px);
    }

    .menu-bubble--md {
        width: clamp(115px, 18.2vw, 155px);
        height: clamp(115px, 18.2vw, 155px);
    }

    .menu-bubble--sm {
        width: clamp(101px, 15.4vw, 132px);
        height: clamp(101px, 15.4vw, 132px);
    }

    .menu-bubble--center {
        top: 42%;
    }

    .menu-bubble--design {
        left: 16%;
        top: 24%;
    }

    .menu-bubble--about {
        left: 10%;
        top: 60%;
    }

    .menu-bubble--pricing {
        left: 86%;
        top: 28%;
    }

    .menu-bubble--schedule {
        left: 84%;
        top: 58%;
    }

    .menu-bubble--instagram {
        width: clamp(108px, 19.2vw, 162px);
        height: clamp(108px, 19.2vw, 162px);
        left: 32%;
    }

    .menu-bubble--kakao {
        width: clamp(96px, 16vw, 138px);
        height: clamp(96px, 16vw, 138px);
        left: 58%;
        top: 76%;
    }
}

.hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 38%), radial-gradient(circle at 82% 14%, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0) 36%), radial-gradient(circle at 62% 82%, rgba(255, 255, 255, 0.22), rgba(255, 255, 255, 0) 40%);
    pointer-events: none;
    opacity: 0.88;
    transition: opacity 0.9s ease-in-out;
}

.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 6% 12%, rgba(255, 250, 243, 0.12), rgba(255, 250, 243, 0) 40%), radial-gradient(circle at 82% 62%, rgba(249, 232, 222, 0.18), rgba(255, 255, 255, 0) 40%);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.9s ease-in-out;
}

.hero-content {
    --hero-column-top: clamp(0.8rem, 2.6vw, 1.6rem);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: clamp(2.2rem, 6vw, 6rem);
    row-gap: clamp(1.6rem, 5vw, 3.2rem);
    flex-wrap: nowrap;
}

.hero-brand {
    flex: 1 1 clamp(320px, 42vw, 640px);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: clamp(1.1rem, 2.6vw, 1.9rem);
    min-height: clamp(260px, 38vh, 360px);
}

.hero-brand__logo-slot {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.hero-brand__logo {
    display: block;
    width: clamp(320px, 60vw, 960px);
    max-width: 100%;
    height: auto;
}

.hero-brand__word {
    font-family: "Playfair Display", serif;
    font-size: clamp(3.8rem, 10vw, 8.6rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.95);
    text-align: center;
    pointer-events: none;
}

.hero-card-stage {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(1.25rem, 3vw, 2.2rem);
    flex-wrap: nowrap;
    width: 100%;
    max-width: min(860px, 100%);
    margin-inline: auto;
    z-index: 1;
}

.hero-card-carousel {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    flex: 1 1 clamp(360px, 54vw, 700px);
    width: min(700px, 100%);
    min-height: clamp(560px, 58vw, 760px);
    padding-inline: clamp(0.8rem, 1.6vw, 1.6rem);
    overflow: hidden;
}

@media (max-width: 960px) {
    .hero-content {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .hero-brand {
        align-items: center;
    }

    .hero-card-stage {
        max-width: min(720px, 100%);
    }

    .hero-card-carousel {
        flex-basis: clamp(320px, 82vw, 680px);
        width: 100%;
        padding-inline: clamp(0.6rem, 2.4vw, 1.4rem);
    }
}

@media (max-width: 720px) {
    .menu-bubbles {
        margin-top: 0;
        padding: clamp(4rem, 12vw, 6rem) clamp(1rem, 7vw, 3.4rem);
    }

    .menu-bubbles::after {
        inset: clamp(1.2rem, 4.8vw, 2.4rem);
    }

    .menu-bubbles__cloud {
        position: relative;
        width: min(520px, 94vw);
        aspect-ratio: 3 / 4;
        margin: clamp(2.2rem, 7vw, 3.6rem) auto 0;
        transform: translateX(-6%);
    }

    .menu-bubble {
        position: absolute;
        width: clamp(92px, 26vw, 130px);
        height: clamp(92px, 26vw, 130px);
        padding: clamp(0.92rem, 3.1vw, 1.3rem);
        --bubble-float-distance: 22px;
        --bubble-float-duration: 6.2s;
    }

    .menu-bubble--xl {
        width: clamp(123px, 34vw, 160px);
        height: clamp(123px, 34vw, 160px);
    }

    .menu-bubble--lg {
        width: clamp(106px, 31vw, 143px);
        height: clamp(106px, 31vw, 143px);
    }

    .menu-bubble--md {
        width: clamp(95px, 28vw, 132px);
        height: clamp(95px, 28vw, 132px);
    }

    .menu-bubble--sm {
        width: clamp(86px, 24vw, 119px);
        height: clamp(86px, 24vw, 119px);
    }

    .menu-bubble--center {
        top: 48%;
        left: 50%;
        --bubble-start-shift: -6px;
        --bubble-float-distance: 26px;
    }

    .menu-bubble--design {
        top: 20%;
        left: 20%;
        --bubble-start-shift: 10px;
    }

    .menu-bubble--pricing {
        top: 22%;
        left: 76%;
        --bubble-start-shift: -8px;
    }

    .menu-bubble--schedule {
        top: 58%;
        left: 82%;
        --bubble-start-shift: 12px;
    }

    .menu-bubble--about {
        top: 56%;
        left: 12%;
        width: clamp(104px, 31.7vw, 154px);
        height: clamp(104px, 31.7vw, 154px);
        --bubble-start-shift: -16px;
    }

    .menu-bubble--instagram {
        top: 85%;
        left: 26%;
        --bubble-start-shift: -12px;
    }

    .menu-bubble--kakao {
        top: 82%;
        left: 62%;
        --bubble-start-shift: -10px;
    }

    .menu-bubble__title {
        font-size: clamp(0.76rem, 1.9vw, 0.96rem);
        letter-spacing: 0.14rem;
    }

    .menu-bubble__subtitle {
        font-size: clamp(0.55rem, 1.52vw, 0.68rem);
        letter-spacing: 0.056rem;
    }

    .menu-bubble:hover,
    .menu-bubble:focus-visible {
        --bubble-scale: 1.06;
        animation-play-state: paused;
        transform: translate(var(--bubble-translate-x), calc(var(--bubble-translate-y) + var(--bubble-start-shift))) scale(var(--bubble-scale));
    }
}

@media (max-width: 480px) {
    .menu-bubbles__supertitle {
        display: none;
    }

    .menu-bubbles__title {
        letter-spacing: 1.35rem;
        margin-left: clamp(0.52rem, 2.6vw, 1.5rem);
    }

    .menu-bubbles__title::before {
        display: none;
        width: 0;
    }

    .menu-bubbles__cloud {
        grid-template-columns: repeat(2, minmax(108px, 1fr));
        transform: translateX(-4%);
    }

    .menu-bubble {
        gap: 0.18rem;
        padding: clamp(0.7rem, 3.5vw, 1.12rem);
    }

    .menu-bubble__title {
        font-size: clamp(0.783rem, 1.96vw, 0.989rem);
        letter-spacing: 0.12rem;
    }

    .menu-bubble__subtitle {
        font-size: clamp(0.567rem, 1.57vw, 0.70rem);
    }
}

.events {
    position: relative;
    overflow: hidden;
    padding: clamp(9rem, 15vw, 12.75rem) 0 clamp(8rem, 18vw, 12rem);
    margin-bottom: 0;
    background: var(--gradient-primary);
    color: rgba(255, 255, 255, 0.92);
    transition: background 0.9s ease-in-out, background-image 1.1s ease-in-out;
}

.events__background {
    display: none;
}

.events__background::before {
    display: none;
}

.events__container {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(1.5rem, 3vw, 2.3rem);
    width: min(1100px, 90%);
    margin: 0 auto;
    text-align: center;
}

.events__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.18rem, 0.6vw, 0.35rem);
    letter-spacing: 0.24em;
}

.events__eyebrow {
    font-family: "Pretendard", "Noto Sans KR", sans-serif;
    font-weight: 200;
    font-size: clamp(1.1rem, 2.2vw, 1.35rem);
    text-transform: uppercase;
    opacity: 0.82;
    letter-spacing: 0.55em;
    line-height: 1;
    display: block;
    margin: 0;
}

.events__headline {
    margin: 0;
    font-family: "Pretendard", "Noto Sans KR", sans-serif;
    font-weight: 200;
    font-size: clamp(2.8rem, 6.4vw, 4.1rem);
    letter-spacing: 0.32em;
    text-transform: uppercase;
    line-height: 1.04;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(0.35rem, 0.8vw, 0.55rem);
}

.events__divider {
    font-size: 0.22em;
    font-weight: 300;
    line-height: 1;
    transform: translateY(-0.02em);
    opacity: 0.8;
}

.hero-content {
    --hero-column-top: clamp(0.8rem, 2.6vw, 1.6rem);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: clamp(2.2rem, 6vw, 6rem);
    row-gap: clamp(1.6rem, 5vw, 3.2rem);
    flex-wrap: nowrap;
}

.hero-brand {
    flex: 1 1 clamp(320px, 42vw, 640px);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: clamp(1.1rem, 2.6vw, 1.9rem);
    min-height: clamp(260px, 38vh, 360px);
}

.hero-brand__logo-slot {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.hero-brand__logo {
    display: block;
    width: clamp(320px, 60vw, 960px);
    max-width: 100%;
    height: auto;
}

.hero-brand__word {
    font-family: "Playfair Display", serif;
    font-size: clamp(3.8rem, 10vw, 8.6rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.95);
    text-align: center;
    pointer-events: none;
}

.hero-card-stage {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(1.25rem, 3vw, 2.2rem);
    flex-wrap: nowrap;
    width: 100%;
    max-width: min(860px, 100%);
    margin-inline: auto;
    z-index: 1;
}

.hero-card-carousel {
    position: relative;
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    flex: 1 1 clamp(360px, 54vw, 700px);
    width: min(700px, 100%);
    min-height: clamp(560px, 58vw, 760px);
    padding-inline: clamp(0.8rem, 1.6vw, 1.6rem);
    overflow: hidden;
}

.hero-card-carousel > .hero-frame {
    grid-area: 1 / 1;
    opacity: 0;
    visibility: hidden;
    transform: translateX(12%);
    pointer-events: none;
    transition: opacity 0.36s ease-out, transform 0.48s cubic-bezier(0.26, 0.86, 0.4, 1);
    will-change: opacity, transform;
}

.hero-card-carousel > .hero-frame.is-active,
.hero-card-carousel > .hero-frame.is-entering-left,
.hero-card-carousel > .hero-frame.is-entering-right,
.hero-card-carousel > .hero-frame.is-exiting-left,
.hero-card-carousel > .hero-frame.is-exiting-right {
    visibility: visible;
}

.hero-card-carousel > .hero-frame.is-active {
    opacity: 1;
    transform: translateX(0);
    pointer-events: auto;
    z-index: 2;
}

.hero-card-carousel > .hero-frame.is-entering-left {
    opacity: 0.68;
    transform: translateX(-6%);
    z-index: 1;
}

.hero-card-carousel > .hero-frame.is-entering-right {
    opacity: 0.68;
    transform: translateX(6%);
    z-index: 1;
}

.hero-card-carousel > .hero-frame.is-exiting-left {
    opacity: 0;
    transform: translateX(-12%);
    z-index: 1;
}

.hero-card-carousel > .hero-frame.is-exiting-right {
    opacity: 0;
    transform: translateX(12%);
    z-index: 1;
}

@media (max-width: 960px) {
    .hero-card-stage {
        max-width: min(720px, 100%);
    }

    .hero-card-carousel {
        flex-basis: clamp(320px, 82vw, 680px);
        width: 100%;
        padding-inline: clamp(0.6rem, 2.4vw, 1.4rem);
    }
}

@media (max-width: 600px) {
    .hero-card-carousel {
        min-height: clamp(780px, 200vw, 980px);
        padding-inline: clamp(0.8rem, 3vw, 1.4rem);
    }
}



.hero-card-nav {
    width: clamp(36px, 5.6vw, 45px);
    height: clamp(36px, 5.6vw, 45px);
    flex: 0 0 clamp(36px, 5.6vw, 45px);
    padding: 0;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.45);
    background: rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(12px);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.9);
    box-shadow: none;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background 0.3s ease, color 0.3s ease;
}

.hero-card-nav:not([disabled]):hover,
.hero-card-nav:not([disabled]):focus-visible {
    transform: translateY(-3px);
    background: rgba(255, 255, 255, 0.26);
    border-color: rgba(255, 255, 255, 0.68);
    color: rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 36px -24px rgba(0, 0, 0, 0.45);
    outline: none;
}

.hero-card-nav[disabled] {
    opacity: 0.45;
    cursor: not-allowed;
    box-shadow: none;
}

.hero-card-nav__icon {
    font-size: clamp(0.9rem, 2.2vw, 1.2rem);
    line-height: 1;
}

.hero-card-nav-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(0.35rem, 1.5vw, 0.75rem);
    min-width: clamp(48px, 7vw, 68px);
}

.hero-card-nav-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.04rem, 0.6vw, 0.18rem);
    text-transform: uppercase;
    letter-spacing: 0.22rem;
    text-align: center;
    color: rgba(255, 255, 255, 0.88);
    font-family: "Playfair Display", serif;
}

.hero-card-nav-label__title {
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    font-size: clamp(0.6rem, 1.8vw, 0.82rem);
    font-weight: 300;
    line-height: 1;
}

.hero-card-nav-label__subtitle {
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    font-size: clamp(0.48rem, 1.6vw, 0.7rem);
    letter-spacing: 0.08rem;
    line-height: 1.1;
    color: rgba(255, 255, 255, 0.74);
    font-weight: 300;
}

.hero-card-nav-group--prev .hero-card-nav-label,
.hero-card-nav-group--next .hero-card-nav-label {
    pointer-events: auto;
}

.hero-card-nav-label[data-hero-nav-proxy] {
    cursor: pointer;
    pointer-events: auto;
    transition: color 0.3s ease;
}

.hero-card-nav-label[data-hero-nav-proxy]:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.58);
    outline-offset: 4px;
}

.hero-card-nav-label[data-hero-nav-proxy][aria-disabled="true"] {
    cursor: default;
    pointer-events: none;
    opacity: 0.68;
}


@media (max-width: 960px) {
    .hero-content {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
    }

    .hero-brand {
        flex: 1 1 100%;
        align-items: center;
        text-align: center;
    }
}

@media (max-width: 720px) {
    .hero-brand {
        align-items: center;
        text-align: center;
    }

    .hero-visual {
        padding-top: clamp(0.2rem, 1.2vw, 0.8rem);
        padding-bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(2rem, 6vw, 3rem));
    }

    .hero-card-stage {
        --hero-nav-capsule-bg: rgba(255, 255, 255, 0.46);
        --hero-nav-capsule-border: rgba(255, 255, 255, 0.82);
        --hero-nav-capsule-shadow: 0 26px 44px -30px rgba(186, 88, 62, 0.32);
        --hero-nav-label-color: rgba(120, 52, 32, 0.9);
        --hero-nav-subtitle-color: rgba(120, 52, 32, 0.68);
        --hero-nav-focus-outline: rgba(255, 214, 198, 0.58);
        --hero-nav-button-bg: linear-gradient(135deg, #f0946d 0%, #d4572b 100%);
        --hero-nav-button-bg-hover: linear-gradient(135deg, #f6aa86 0%, #de6236 100%);
        --hero-nav-button-border: rgba(255, 255, 255, 0.92);
        --hero-nav-button-border-hover: rgba(255, 255, 255, 1);
        --hero-nav-button-icon: rgba(255, 255, 255, 0.98);
        --hero-nav-button-icon-hover: rgba(255, 255, 255, 1);
        --hero-nav-button-shadow: 0 18px 34px -26px rgba(186, 88, 62, 0.36);
        --hero-nav-button-shadow-hover: 0 22px 38px -26px rgba(186, 88, 62, 0.42);
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: auto auto;
        column-gap: clamp(0.4rem, 3vw, 0.8rem);
        row-gap: clamp(0.35rem, 2vw, 0.65rem);
        justify-items: center;
        align-items: end;
        width: 100%;
        max-width: clamp(336px, 96vw, 390px);
        margin-inline: auto;
        padding-inline: clamp(0.15rem, 1.4vw, 0.5rem);
        padding-bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(1.1rem, 4vw, 1.6rem));
        transform: none;
    }

    .hero-card-stage[data-hero-active-theme="primary"] {
        --hero-nav-button-bg: rgba(255, 255, 255, 0.32);
        --hero-nav-button-bg-hover: rgba(255, 255, 255, 0.48);
        --hero-nav-button-border: rgba(255, 255, 255, 0.6);
        --hero-nav-button-border-hover: rgba(255, 255, 255, 0.78);
        --hero-nav-button-icon: rgba(132, 68, 44, 0.72);
        --hero-nav-button-icon-hover: rgba(132, 68, 44, 0.88);
        --hero-nav-button-shadow: 0 20px 34px -26px rgba(132, 68, 44, 0.26);
        --hero-nav-button-shadow-hover: 0 22px 38px -26px rgba(132, 68, 44, 0.33);
    }

    .hero-card-stage[data-hero-active-theme="stylebar"] {
        --hero-nav-capsule-bg: rgba(255, 255, 255, 0.72);
        --hero-nav-capsule-border: rgba(235, 209, 200, 0.58);
        --hero-nav-capsule-shadow: 0 22px 36px -26px rgba(182, 140, 118, 0.32);
        --hero-nav-label-color: rgba(122, 78, 60, 0.9);
        --hero-nav-subtitle-color: rgba(122, 78, 60, 0.68);
        --hero-nav-focus-outline: rgba(205, 161, 137, 0.45);
        --hero-nav-button-bg: linear-gradient(135deg, #cda189 0%, #ebd1c8 100%);
        --hero-nav-button-bg-hover: linear-gradient(135deg, #d7b19c 0%, #f5ded4 100%);
        --hero-nav-button-border: rgba(255, 255, 255, 0.92);
        --hero-nav-button-border-hover: rgba(255, 255, 255, 1);
        --hero-nav-button-icon: rgba(96, 60, 44, 0.88);
        --hero-nav-button-icon-hover: rgba(78, 48, 34, 0.92);
        --hero-nav-button-shadow: 0 18px 32px -24px rgba(168, 126, 102, 0.28);
        --hero-nav-button-shadow-hover: 0 22px 36px -24px rgba(168, 126, 102, 0.34);
    }

    .hero-card-stage[data-hero-active-theme="vip"] {
        --hero-nav-capsule-bg: rgba(10, 8, 6, 0.75);
        --hero-nav-capsule-border: rgba(199, 160, 108, 0.42);
        --hero-nav-capsule-shadow: 0 24px 42px -26px rgba(0, 0, 0, 0.75);
        --hero-nav-label-color: rgba(244, 212, 168, 0.9);
        --hero-nav-subtitle-color: rgba(229, 196, 150, 0.74);
        --hero-nav-focus-outline: rgba(229, 196, 150, 0.6);
        --hero-nav-button-bg: linear-gradient(135deg, #2d1c12 0%, #3f2617 100%);
        --hero-nav-button-bg-hover: linear-gradient(135deg, #3a2516 0%, #4a2d1b 100%);
        --hero-nav-button-border: rgba(199, 160, 108, 0.48);
        --hero-nav-button-border-hover: rgba(222, 183, 131, 0.62);
        --hero-nav-button-icon: rgba(245, 214, 160, 0.92);
        --hero-nav-button-icon-hover: rgba(252, 229, 182, 0.98);
        --hero-nav-button-shadow: 0 18px 36px -24px rgba(0, 0, 0, 0.6);
        --hero-nav-button-shadow-hover: 0 22px 40px -26px rgba(0, 0, 0, 0.7);
    }

    .hero-card-nav-label {
        color: var(--hero-nav-label-color);
    }

    .hero-card-nav-label__subtitle {
        color: var(--hero-nav-subtitle-color);
    }

    .hero-card-nav-label[data-hero-nav-proxy]:focus-visible {
        outline: 2px solid var(--hero-nav-focus-outline);
    }

    .hero-card-nav-label[data-hero-nav-proxy][aria-disabled="true"] {
        color: var(--hero-nav-subtitle-color);
    }

    .hero .container {
        width: 100%;
        padding-inline: clamp(0.6rem, 3vw, 1.2rem);
    }

    .hero-card-carousel {
        grid-column: 1 / -1;
        grid-row: 1;
        width: 100%;
        padding-inline: clamp(0.15rem, 1.4vw, 0.5rem);
        margin-bottom: clamp(0.65rem, 2.4vw, 1rem);
        overflow: visible;
    }

    .hero-card-carousel > .hero-frame {
        width: min(100%, clamp(336px, 96vw, 390px));
        margin-inline: auto;
    }

    .hero-card-nav-group {
        grid-row: 2;
        justify-self: stretch;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-start;
        gap: clamp(0.45rem, 3.2vw, 0.85rem);
        width: 100%;
        max-width: clamp(170px, 44vw, 220px);
        margin-top: clamp(0.45rem, 3vw, 1.05rem);
        padding: clamp(0.45rem, 2.6vw, 0.75rem) clamp(0.75rem, 3.6vw, 1.2rem);
        background: var(--hero-nav-capsule-bg);
        border: 1px solid var(--hero-nav-capsule-border);
        border-radius: clamp(18px, 12vw, 28px);
        backdrop-filter: blur(18px);
        box-shadow: var(--hero-nav-capsule-shadow);
        color: var(--hero-nav-label-color);
        transition: box-shadow 0.3s ease, border-color 0.3s ease, background 0.3s ease, color 0.3s ease;
    }

    .hero-card-nav-group--prev {
        grid-column: 1;
        justify-self: start;
        margin-right: clamp(0.2rem, 1.6vw, 0.45rem);
    }

    .hero-card-nav-group--next {
        grid-column: 2;
        justify-self: end;
        flex-direction: row-reverse;
        margin-left: clamp(0.2rem, 1.6vw, 0.45rem);
    }

    .hero-card-nav-group .hero-card-nav-label {
        align-items: flex-start;
        text-align: left;
        gap: clamp(0.08rem, 0.8vw, 0.18rem);
    }

    .hero-card-nav-group--next .hero-card-nav-label {
        align-items: flex-end;
        text-align: right;
    }

    .hero-card-nav {
        width: clamp(42px, 11vw, 52px);
        height: clamp(42px, 11vw, 52px);
        flex: 0 0 clamp(42px, 11vw, 52px);
        border-radius: clamp(10px, 6vw, 16px);
        border: none;
        background: var(--hero-nav-button-bg);
        box-shadow: var(--hero-nav-button-shadow);
        color: var(--hero-nav-button-icon);
    }

    .hero-card-nav:not([disabled]):hover,
    .hero-card-nav:not([disabled]):focus-visible {
        transform: translateY(-2px);
        background: var(--hero-nav-button-bg-hover);
        color: var(--hero-nav-button-icon-hover);
        box-shadow: var(--hero-nav-button-shadow-hover);
    }
}

.hero-text {
    display: flex;
    flex-direction: column;
    align-self: stretch;
    min-height: 100%;
    padding-top: var(--hero-column-top);
    gap: clamp(0.8rem, 2vw, 1.4rem);
}

.hero-promo {
    margin: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    background: transparent;
    gap: clamp(9.6rem, 16.5vw, 13.8rem);
    transition: box-shadow 0.35s ease, transform 0.35s ease;
}

.hero-promo__toggle {
    all: unset;
}

.events-stack {
    position: relative;
    width: 100%;
    --events-card-width: min(960px, 92vw);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(1rem, 2.6vw, 1.9rem);
    padding: clamp(1.6rem, 3.4vw, 2.8rem) 0 clamp(0.45rem, 0.75vw, 0.6rem);
}

.events-stack::before,
.events-stack__halo {
    display: none;
}

.events-stack__carousel {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    gap: clamp(0.4rem, 1vw, 0.7rem);
    --events-controls-offset: clamp(2.1rem, 4.6vw, 3.1rem);
    padding-bottom: calc(var(--events-controls-offset) + clamp(0.9rem, 2vw, 1.3rem));
    isolation: isolate;
}

.events-stack__stage {
    position: relative;
    width: var(--events-card-width);
    aspect-ratio: 4 / 1;
    height: auto;
    pointer-events: none;
}

.events-stack__progress {
    position: absolute;
    top: calc(100% + var(--events-controls-offset));
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-flex;
    align-items: center;
    gap: clamp(0.3rem, 1vw, 0.6rem);
    z-index: 4;
}

.events-stack__toggle {
    position: relative;
    z-index: 10;
    display: inline-flex;
    align-items: center;
    justify-items: center;
    justify-content: center;
    margin-top: clamp(2.2rem, 4.6vw, 3.4rem);
    padding: clamp(1.2rem, 2.6vw, 1.6rem) clamp(3.6rem, 8.6vw, 4.8rem);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.28);
    color: rgba(255, 255, 255, 0.92);
    font-weight: 600;
    font-size: clamp(0.98rem, 2.6vw, 1.12rem);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    align-self: flex-start;
}

@media (min-width: 601px) {
    .events-stack__toggle {
        align-self: center;
    }
}

.events-stack__toggle:hover,
.events-stack__toggle:focus-visible {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.4);
    transform: translateY(-2px);
}

.events-stack__toggle:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.65);
    outline-offset: 5px;
}

.events-stack__toggle-label {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    pointer-events: none;
    text-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
    letter-spacing: 0.14em;
}

.events-stack__toggle-label::after {
    content: "↘";
    font-size: 1.1rem;
    line-height: 1;
    opacity: 0.68;
    transform: translateY(-1px);
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.events-stack__toggle:hover .events-stack__toggle-label::after,
.events-stack__toggle:focus-visible .events-stack__toggle-label::after {
    transform: translate(4px, -1px);
    opacity: 0.9;
}

.hero-promo.is-expanded .events-stack__toggle {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.32) 0%, rgba(255, 255, 255, 0.22) 100%);
    border-color: rgba(255, 255, 255, 0.55);
}

.hero-promo.is-expanded .events-stack__toggle-label::after {
    transform: rotate(90deg);
    opacity: 1;
}

.hero-promo__image {
    position: relative;
    isolation: isolate;
}

.hero-promo__image img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.hero-promo__carousel {
    position: relative;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    isolation: isolate;
}

.hero-promo__slides {
    position: relative;
    width: 100%;
    height: 100%;
}


.hero-promo__slide {
    position: absolute;
    top: 50%;
    left: 50%;
    width: var(--events-card-width);
    aspect-ratio: 4 / 1;
    height: auto;
    transform-origin: center;
    border-radius: clamp(18px, 3.2vw, 26px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.05));
    box-shadow: 0 32px 80px -48px rgba(17, 6, 4, 0.54);
    transform: translate(-50%, -68%) scale(0.68);
    opacity: 0;
    filter: blur(20px);
    transition: transform 0.7s cubic-bezier(0.22, 0.82, 0.26, 1), opacity 0.6s ease, filter 0.7s ease, box-shadow 0.7s ease;
    pointer-events: none;
    z-index: 10;
}

.hero-promo__slide img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center;
    transition: transform 0.8s ease, filter 0.6s ease;
}

.hero-promo__slide.is-front,
.hero-promo__slide.is-active {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
    filter: blur(0);
    z-index: 40;
    pointer-events: auto;
    box-shadow: 0 58px 120px -52px rgba(18, 6, 4, 0.62), 0 32px 68px -46px rgba(206, 108, 72, 0.45);
}

.hero-promo__slide.is-front img,
.hero-promo__slide.is-active img {
    transform: none;
}

.hero-promo__slide.is-middle {
    transform: translate(-50%, -56%) scale(0.88);
    opacity: 0.74;
    filter: blur(10px);
    z-index: 30;
    box-shadow: 0 42px 90px -60px rgba(18, 6, 4, 0.5);
}

.hero-promo__slide.is-back {
    transform: translate(-50%, -62%) scale(0.78);
    opacity: 0.52;
    filter: blur(16px);
    z-index: 20;
}

.hero-promo__slide.is-hidden {
    transform: translate(-50%, -70%) scale(0.68);
    opacity: 0;
    filter: blur(22px);
    z-index: 10;
}

.hero-promo__slide.is-exiting {
    transform: translate(-50%, -30%) scale(0.88);
    opacity: 0;
    filter: blur(18px);
    z-index: 15;
}

.hero-promo__nav {
    position: absolute;
    top: calc(100% + var(--events-controls-offset));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: clamp(2.3rem, 4.6vw, 2.8rem);
    height: clamp(2.3rem, 4.6vw, 2.8rem);
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.28);
    background: rgba(255, 255, 255, 0.14);
    color: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(14px);
    box-shadow: 0 18px 42px -26px rgba(0, 0, 0, 0.5);
    cursor: pointer;
    transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
    z-index: 4;
    --nav-translate-x: 0;
    transform: translate(var(--nav-translate-x), -50%);
}

.hero-promo__nav--prev {
    left: calc(50% - clamp(100px, 18vw, 160px));
    --nav-translate-x: -50%;
}

.hero-promo__nav--next {
    right: calc(50% - clamp(100px, 18vw, 160px));
    --nav-translate-x: 50%;
}

.hero-promo__nav:hover,
.hero-promo__nav:focus-visible {
    background: rgba(255, 255, 255, 0.22);
    border-color: rgba(255, 255, 255, 0.46);
    transform: translate(var(--nav-translate-x), calc(-50% - 4px));
    box-shadow: 0 24px 50px -28px rgba(0, 0, 0, 0.56);
}

.hero-promo__nav:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.7);
    outline-offset: 4px;
}

.hero-promo__nav[disabled] {
    opacity: 0;
    pointer-events: none;
}

.hero-promo__nav-icon {
    font-size: clamp(1.2rem, 2.8vw, 1.6rem);
    line-height: 1;
    font-weight: 300;
    letter-spacing: -0.04em;
    color: inherit;
}

.hero-promo__progress {
    display: inline-flex;
    align-items: center;
    gap: clamp(0.4rem, 1.4vw, 0.7rem);
    z-index: 4;
}

.hero-promo__dot {
    width: clamp(0.45rem, 1.6vw, 0.65rem);
    height: clamp(0.45rem, 1.6vw, 0.65rem);
    border-radius: 50%;
    border: none;
    background: rgba(255, 255, 255, 0.5);
    padding: 0;
    cursor: pointer;
    transition: transform 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.hero-promo__dot:hover,
.hero-promo__dot:focus-visible {
    transform: translateY(-2px) scale(1.1);
    background: rgba(255, 255, 255, 0.76);
}

.hero-promo__dot:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.45);
    outline-offset: 2px;
}

.hero-promo__dot.is-active {
    background: rgba(255, 255, 255, 0.96);
    transform: translateY(-2px) scale(1.2);
    box-shadow: 0 12px 24px -16px rgba(0, 0, 0, 0.4);
}


.hero-promo__carousel:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.52);
    outline-offset: -4px;
}

@media (max-width: 820px) {
    .events-stack {
        --events-card-width: min(760px, 90vw);
        gap: clamp(0.6rem, 2vw, 1.2rem);
        padding: clamp(2rem, 6vw, 3rem) 0 clamp(0.34rem, 0.75vw, 0.5rem);
    }

    .events-stack__carousel {
        gap: clamp(0.6rem, 2vw, 1.2rem);
        --events-controls-offset: clamp(1.9rem, 5.5vw, 2.8rem);
        padding-bottom: calc(var(--events-controls-offset) + clamp(1.6rem, 4vw, 2.4rem));
    }

    .hero-promo__nav--prev {
        left: calc(50% - clamp(120px, 24vw, 200px));
    }

    .hero-promo__nav--next {
        right: calc(50% - clamp(120px, 24vw, 200px));
    }
}

@media (max-width: 640px) {
    .events__headline {
        letter-spacing: 0.2em;
    }

    .hero-promo {
        gap: clamp(6.6rem, 18vw, 9.3rem);
    }

    .events-stack {
        --events-card-width: min(520px, 94vw);
        gap: clamp(0.5rem, 2vw, 1rem);
        padding: clamp(1.4rem, 7vw, 2.8rem) 0 clamp(0.28rem, 1vw, 0.42rem);
    }

    .events-stack__carousel {
        gap: clamp(0.5rem, 2.6vw, 1.2rem);
        --events-controls-offset: clamp(1.8rem, 7vw, 2.8rem);
        padding-bottom: calc(var(--events-controls-offset) + clamp(1.4rem, 5vw, 2.2rem));
    }

    .events-stack__toggle {
        margin-left: 0;
        transform: none;
        align-self: center;
    }

    .hero-promo__nav--prev {
        left: calc(50% - clamp(140px, 42vw, 210px));
    }

    .hero-promo__nav--next {
        right: calc(50% - clamp(140px, 42vw, 210px));
    }
}

@media (max-width: 440px) {
    .events-stack {
        --events-card-width: 100%;
        gap: clamp(0.4rem, 2.4vw, 0.9rem);
        padding: clamp(1.2rem, 12vw, 2rem) 0 clamp(0.23rem, 1.25vw, 0.31rem);
    }

    .events-stack__carousel {
        gap: clamp(0.4rem, 3.6vw, 1.1rem);
        --events-controls-offset: clamp(1.6rem, 12vw, 2.6rem);
        padding-bottom: calc(var(--events-controls-offset) + clamp(1.2rem, 5.5vw, 1.8rem));
    }

    .events-stack__toggle {
        margin-left: 0;
        transform: none;
        align-self: center;
    }

    .hero-promo__nav {
        width: clamp(2.2rem, 13vw, 2.7rem);
        height: clamp(2.2rem, 13vw, 2.7rem);
    }

    .hero-promo__nav--prev {
        left: calc(50% - clamp(90px, 40vw, 130px));
    }

    .hero-promo__nav--next {
        right: calc(50% - clamp(90px, 40vw, 130px));
    }
}


.events-stack__detail-surface {
    width: 100%;
    display: flex;
    justify-content: center;
    margin-top: clamp(0.6rem, 2vw, 1rem);
    padding-bottom: clamp(2.4rem, 6vw, 3.6rem);
}

.hero-promo__details {
    width: min(960px, 92vw);
    padding: 0 clamp(1.3rem, 3vw, 1.9rem);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(255, 243, 233, 0.85));
    border: 1px solid rgba(var(--color-ivory-rgb), 0.55);
    border-radius: clamp(1.4rem, 4vw, 1.9rem);
    backdrop-filter: blur(18px);
    box-shadow: 0 24px 64px -36px rgba(0, 0, 0, 0.28);
    display: flex;
    flex-direction: column;
    gap: clamp(0.65rem, 1.8vw, 0.9rem);
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transition: max-height 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.35s ease, padding 0.35s ease, margin-top 0.35s ease, box-shadow 0.35s ease;
    margin-top: 0;
}

.hero-promo__detail {
    display: flex;
    flex-direction: column;
    gap: clamp(0.65rem, 1.8vw, 0.9rem);
}

.hero-promo__detail[hidden] {
    display: none;
}

.hero-promo__lead {
    font-size: 0.98rem;
    font-weight: 600;
    color: rgba(var(--color-deep-rgb), 0.78);
    letter-spacing: 0.02em;
}

.hero-promo__list {
    margin: 0;
    padding-left: 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    color: rgba(var(--color-deep-rgb), 0.7);
    font-size: 0.9rem;
    line-height: 1.6;
}

.hero-promo__list strong {
    font-weight: 600;
    letter-spacing: 0.02em;
}

.hero-promo__note {
    margin: 0;
    font-size: 0.82rem;
    color: rgba(var(--color-deep-rgb), 0.54);
    line-height: 1.5;
}

.hero-promo__label {
    display: inline-block;
    margin-right: 0.35rem;
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.48);
}

.hero-promo__list li {
    position: relative;
}

.hero-promo__price {
    font-weight: 600;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
}

.hero-promo__discount {
    font-weight: 600;
    color: rgba(var(--color-accent-strong-rgb), 0.86);
}

.hero-promo__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.88rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    text-decoration: none;
    transition: color 0.25s ease, transform 0.25s ease;
}

.hero-promo__cta::after {
    content: "→";
    font-size: 0.95rem;
    line-height: 1;
}

.hero-promo__cta:hover,
.hero-promo__cta:focus-visible {
    color: rgba(var(--color-accent-strong-rgb), 1);
    transform: translateX(2px);
}

.hero-promo__cta:focus-visible {
    outline: 2px solid rgba(var(--color-accent-strong-rgb), 0.35);
    outline-offset: 3px;
}

.hero-promo.is-expanded {
    width: 100%;
    box-shadow: none;
    transform: none;
}


.hero-promo.is-expanded .hero-promo__details {
    max-height: clamp(320px, 52vw, 520px);
    padding: clamp(1.1rem, 2.6vw, 1.8rem) clamp(1.6rem, 3.8vw, 2.6rem) clamp(1.6rem, 3.8vw, 2.4rem);
    opacity: 1;
    pointer-events: auto;
    margin-top: clamp(0.6rem, 2vw, 1rem);
}

.hero-text-top {
    display: flex;
    flex-direction: column;
}

.hero-text-bottom {
    margin-top: clamp(0.35rem, 1.4vw, 0.7rem);
    padding-top: clamp(0.35rem, 1.3vw, 0.7rem);
    display: flex;
    flex-direction: column;
    gap: clamp(0.6rem, 2vw, 1rem);
    align-items: flex-start;
}

.hero-location {
    font-style: normal;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    padding: 0.65rem 0.85rem;
    border-radius: 1.1rem;
    background: rgba(255, 255, 255, 0.52);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75), 0 18px 28px -26px rgba(var(--color-deep-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.68);
    font-size: clamp(0.85rem, 2.1vw, 0.95rem);
    line-height: 1.55;
}

.hero-location__label {
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.46);
    font-weight: 600;
}

.hero-location__text {
    display: block;
    font-weight: 600;
    color: rgba(var(--color-deep-rgb), 0.82);
}

.hero-location__meta {
    display: block;
    margin-top: 0.3rem;
    color: rgba(var(--color-deep-rgb), 0.64);
    line-height: 1.5;
}

.hero-text-bottom .hero-cta,
.hero-text-bottom .hero-question-panel {
    margin-top: 0;
}

.hero-sub--tagline {
    margin-top: 1.1rem;
    max-width: 520px;
    line-height: 1.7;
    letter-spacing: 0.06rem;
    color: rgba(var(--color-deep-rgb), 0.6);
}

.hero-sub--tagline br {
    display: block;
}

.hero-sub {
    font-size: 1.02rem;
    max-width: 480px;
    color: var(--color-muted);
    margin: 0.8rem 0 0;
}


.hero-title {
    display: inline-flex;
    align-items: center;
    gap: clamp(1.4rem, 2.6vw, 2.4rem);
    font-family: "Playfair Display", serif;
    font-size: clamp(2.4rem, 4.6vw, 3.3rem);
    letter-spacing: 0.12rem;
    text-transform: uppercase;
    color: var(--color-brown);
    margin: clamp(0.5rem, 1.8vw, 0.9rem) 0 0;
}

.hero-title .hero-word {
    display: inline-flex;
    align-items: center;
    line-height: 1;
    letter-spacing: 0.16rem;
    font-weight: 500;
}

.hero-title .hero-word--latin {
    letter-spacing: 0.32rem;
}

.hero-divider {
    display: inline-block;
    width: 1px;
    height: clamp(32px, 6vw, 46px);
    background: linear-gradient(180deg, rgba(var(--color-accent-strong-rgb), 0.48), rgba(var(--color-accent-soft-rgb), 0.18));
}

.hero-eyebrow {
    margin: 0.35rem 0 0;
    text-transform: uppercase;
    letter-spacing: 0.38rem;
    font-size: 0.68rem;
    color: rgba(var(--color-deep-rgb), 0.32);
}

.hero-meta {
    display: inline-flex;
    align-items: center;
    gap: 1.2rem;
    margin-top: 1.4rem;
    font-size: 0.75rem;
    letter-spacing: 0.35rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.5);
}

.hero-meta .separator {
    width: 42px;
    height: 1px;
    background: rgba(var(--color-deep-rgb), 0.26);
    display: inline-block;
}

.hero-address {
    max-width: 480px;
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    color: rgba(var(--color-deep-rgb), 0.46);
    line-height: 1.6;
}

.hero-address__line {
    display: block;
}

.hero-address__line + .hero-address__line {
    margin-top: 0.25rem;
}

.hero-address__line--access {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.35rem 0.6rem;
}

.hero-address br {
    display: block;
    margin: 0.35rem 0 0;
}

.hero-address__parking {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.42rem 1.12rem;
    border-radius: 999px;
    border: 1px solid rgba(var(--color-deep-rgb), 0.14);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.68), rgba(255, 255, 255, 0.4));
    color: rgba(var(--color-deep-rgb), 0.64);
    font-size: 0.74rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 16px 36px -22px rgba(var(--color-deep-rgb), 0.55);
    cursor: pointer;
    transition: background 0.35s ease, color 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, transform 0.35s ease;
}

.hero-address__parking:hover,
.hero-address__parking:focus-visible {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.6));
    border-color: rgba(var(--color-deep-rgb), 0.28);
    color: rgba(var(--color-deep-rgb), 0.8);
    box-shadow: 0 24px 44px -20px rgba(var(--color-deep-rgb), 0.5);
    transform: translateY(-1px);
}

.hero-address__parking:focus-visible {
    outline: 2px solid rgba(var(--color-deep-rgb), 0.28);
    outline-offset: 3px;
}

.hero-address__parking.is-active {
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.7), rgba(var(--color-accent-rgb), 0.5));
    border-color: rgba(var(--color-accent-rgb), 0.4);
    color: rgba(var(--color-deep-rgb), 0.95);
    box-shadow: 0 24px 48px -20px rgba(var(--color-accent-rgb), 0.48);
}

.hero-parking {
    width: 100%;
    margin-top: clamp(0.6rem, 1.8vw, 0.9rem);
    perspective: 1100px;
}

.hero-parking[hidden] {
    display: none;
}

.hero-parking__surface {
    position: relative;
    border-radius: clamp(1.1rem, 3vw, 1.6rem);
    background: rgba(255, 255, 255, 0.86);
    box-shadow: 0 32px 60px -32px rgba(var(--color-deep-rgb), 0.55);
    overflow: hidden;
    transform-origin: top;
    transform: rotateX(-14deg) translateY(-18px) scale(0.96);
    opacity: 0;
    transition: transform 0.7s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.45s ease;
    pointer-events: none;
}

.hero-parking.is-visible .hero-parking__surface {
    transform: rotateX(0deg) translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
}

.hero-parking__surface::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0));
    pointer-events: none;
}

.hero-parking__surface img {
    display: block;
    width: 100%;
    height: auto;
}

.hero-parking__close {
    position: absolute;
    bottom: clamp(0.5rem, 1.8vw, 0.8rem);
    right: clamp(0.6rem, 2vw, 1rem);
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    border: none;
    background: rgba(0, 0, 0, 0.6);
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.3s ease;
}

.hero-parking__close:hover,
.hero-parking__close:focus-visible {
    background: rgba(0, 0, 0, 0.78);
    transform: translateY(-1px);
}

.hero-parking__close:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.8);
    outline-offset: 3px;
}

.hero-cta {
    margin-top: clamp(0.75rem, 2.1vw, 1.2rem);
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

.hero-question-panel {
    margin-top: 2.2rem;
    border-radius: 28px;
    background: linear-gradient(135deg, rgba(var(--color-ivory-rgb), 0.92), rgba(var(--color-accent-soft-rgb), 0.88));
    border: 1px solid rgba(var(--color-accent-rgb), 0.28);
    box-shadow: 0 34px 78px -46px rgba(var(--color-deep-rgb), 0.28);
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translateY(-12px);
    transition: max-height 0.75s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.45s ease, transform 0.65s ease;
    pointer-events: none;
}

.hero-question-panel.is-open {
    max-height: 1600px;
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.hero-question-inner {
    padding: clamp(1.8rem, 3vw, 2.6rem) clamp(1.6rem, 3.2vw, 2.8rem);
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    color: rgba(var(--color-deep-rgb), 0.68);
    line-height: 1.72;
    position: relative;
}

.hero-question-inner::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(var(--color-accent-soft-rgb), 0.24), transparent 55%), radial-gradient(circle at bottom left, rgba(var(--color-accent-rgb), 0.16), transparent 50%);
    pointer-events: none;
    mix-blend-mode: multiply;
}

.hero-question-inner > * {
    position: relative;
    z-index: 1;
}

.hero-question-lead {
    font-size: 1.05rem;
    font-weight: 500;
    color: rgba(var(--color-deep-rgb), 0.86);
    letter-spacing: 0.03rem;
}

.hero-question-heading {
    font-weight: 600;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
    font-size: 0.82rem;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    margin-top: 0.3rem;
}

@media (max-width: 720px) {
    .hero-question-inner {
        padding: 1.6rem 1.5rem 1.8rem;
        gap: 1rem;
    }

    .hero-question-heading {
        letter-spacing: 0.08rem;
        font-size: 0.78rem;
    }
}

.hero-visual {
    position: relative;
    flex: 1 1 clamp(420px, 56vw, 760px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(1.6rem, 3.6vw, 2.6rem);
    padding: var(--hero-column-top) clamp(0.6rem, 2.2vw, 1.8rem) clamp(2.2rem, 5.6vw, 3.4rem);
}

.hero-frame {
    position: relative;
    width: min(100%, 640px);
    min-height: clamp(600px, 58vw, 780px);
    background: var(--hero-card-gradient);
    border-radius: clamp(16px, 2.4vw, 24px);
    padding: clamp(3.4rem, 5.6vw, 4rem) clamp(1.8rem, 4.2vw, 3.2rem) clamp(2.8rem, 6vw, 3.8rem);
    display: grid;
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-auto-rows: max-content;
    align-content: center;
    justify-content: center;
    justify-items: stretch;
    gap: 1.3rem;
    color: var(--hero-card-foreground);
    overflow: hidden;
    box-shadow: 0 40px 80px -48px rgba(var(--color-deep-rgb), 0.42);
    transition: width 0.45s ease, min-height 0.45s ease, padding 0.45s ease,
        opacity 0.6s ease, transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
    align-self: flex-start;
    z-index: 0;
    pointer-events: none;
}

.hero-frame > :not(.hero-frame-glow):not(.booking-success) {
    position: relative;
    z-index: 1;
}

.hero-frame.expanded {
    display: flex;
    flex-direction: column;
    width: min(620px, 100%);
    min-height: 620px;
    padding: clamp(2.2rem, 4.4vw, 3rem) clamp(1.4rem, 3.6vw, 2.6rem) clamp(2.6rem, 5.6vw, 3.6rem);
    overflow: hidden;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.85rem;
    transform: translateY(-8px);
}

.hero-frame.expanded::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--hero-card-gradient);
    opacity: 0;
    transition: opacity 0.45s ease;
}

.hero-frame.expanded .hero-frame-head {
    min-height: 0;
    margin-bottom: 0;
    padding-bottom: 0;
    gap: 0.4rem;
}

.hero-frame.expanded .hero-title-anchor {
    min-height: calc(3.3rem + 40px);
}

.hero-frame.expanded .hero-logo,
.hero-frame.expanded .hero-caption {
    opacity: 0;
    transform: translateY(-12px);
    max-height: 0;
    margin: 0;
    pointer-events: none;
}

.hero-frame .hero-logo,
.hero-frame .hero-caption {
    transition: opacity 0.4s ease, transform 0.4s ease, max-height 0.4s ease, margin 0.4s ease;
    will-change: opacity, transform, max-height;
}

.hero-frame-head {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    min-height: var(--hero-frame-head, 140px);
}

.hero-frame .hero-logo {
    width: min(360px, 88%);
    max-width: 100%;
    height: auto;
    border-radius: clamp(10px, 2vw, 20px);
    filter: drop-shadow(0 20px 34px rgba(0, 0, 0, 0.18));
}

.hero-caption-group {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.42rem;
    text-align: center;
}

.hero-frame .hero-caption {
    max-height: 36px;
    display: inline-flex;
    gap: 0.42rem;
    align-items: baseline;
}

.hero-caption__light {
    font-family: "Noto Sans KR", sans-serif;
    font-weight: 200;
    letter-spacing: 0.32rem;
    text-transform: uppercase;
    opacity: 0.82;
}

.hero-booking-gate {
    width: 100%;
    display: grid;
    gap: 1rem;
    margin-top: 1.1rem;
}

.hero-booking-gate__field {
    gap: 0.2rem;
}

.hero-booking-gate__field input {
    background: rgba(255, 255, 255, 0.3);
    border-color: rgba(255, 255, 255, 0.4);
    color: rgba(var(--color-deep-rgb), 0.88);
    font-weight: 500;
}

.hero-booking-gate__field input::placeholder {
    color: rgba(var(--color-deep-rgb), 0.65);
    letter-spacing: 0.08rem;
    text-transform: uppercase;
}

.hero-booking-gate__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.hero-booking-gate__actions .btn {
    flex: 1 1 140px;
    min-width: 0;
}

.hero-booking-gate__feedback {
    min-height: 0.3rem;
    font-size: 0.78rem;
    letter-spacing: 0.08rem;
    color: rgba(255, 255, 255, 0.65);
    transition: color 0.25s ease;
}

.hero-booking-gate__feedback.is-error {
    color: rgba(255, 112, 112, 0.9);
}

.hero-booking-gate__feedback.is-success {
    color: rgba(181, 255, 208, 0.92);
}

.hero-frame--quick {
    padding-top: clamp(4.4rem, 8.2vw, 5.8rem);
    gap: clamp(0.48rem, 1.3vw, 0.82rem);
}

@media (max-width: 720px) {
    .hero-frame--quick {
        padding-top: clamp(3.2rem, 11vw, 4.6rem);
        gap: clamp(0.56rem, 2vw, 0.96rem);
    }
}

.hero-frame--quick .hero-quick-code-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.35rem, 1.4vw, 0.55rem);
    margin-top: clamp(0.28rem, 1vw, 0.6rem);
    margin-bottom: clamp(0.32rem, 1.1vw, 0.68rem);
    width: 100%;
}

.hero-frame--quick .hero-quick-code-toggle {
    all: unset;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.09rem, 0.7vw, 0.22rem);
    cursor: pointer;
    color: rgba(255, 255, 255, 0.6);
    font-size: clamp(0.62rem, 1.45vw, 0.74rem);
    line-height: 1.2;
    text-align: center;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.3em;
    transition: color 0.25s ease;
}

.hero-frame--quick .hero-quick-code-toggle:hover,
.hero-frame--quick .hero-quick-code-toggle:focus-visible,
.hero-frame--quick .hero-quick-code-toggle.is-active {
    color: rgba(255, 255, 255, 0.9);
}

.hero-frame--quick .hero-quick-code-toggle:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.35);
    outline-offset: 3px;
}

.hero-frame--quick .hero-quick-code-toggle__hint {
    font-size: clamp(0.52rem, 1.1vw, 0.63rem);
    font-weight: 300;
    color: rgba(255, 255, 255, 0.65);
}

.hero-frame--quick .hero-quick-code-collapse {
    display: flex;
    flex-direction: column;
    gap: clamp(0.24rem, 0.9vw, 0.48rem);
    width: 100%;
    padding-top: 0;
}

.hero-frame--quick .hero-quick-code-collapse[hidden] {
    display: none !important;
}

.hero-frame--quick .hero-quick-code-group {
    display: flex;
    flex-direction: column;
    gap: clamp(0.08rem, 0.42vw, 0.16rem);
    align-items: flex-start;
    width: min(100%, clamp(280px, 88vw, 340px));
    margin: 0 auto;
}

.hero-frame--quick .hero-quick-code-label {
    font-size: clamp(0.78rem, 1.6vw, 0.92rem);
    font-weight: 300;
    color: rgba(72, 54, 44, 0.7);
    letter-spacing: 0.02em;
}

.hero-frame--quick .hero-quick-code-row {
    width: min(100%, clamp(280px, 88vw, 340px));
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(0.18rem, 0.6vw, 0.32rem);
    align-items: center;
    margin-top: clamp(0.12rem, 0.5vw, 0.24rem);
}

.hero-frame--quick .hero-quick-code-input {
    width: 100%;
    padding: clamp(0.62rem, 1.6vw, 0.88rem);
    border-radius: 16px;
    border: 1px solid rgba(214, 192, 175, 0.55);
    background: rgba(255, 255, 255, 0.46);
    color: rgba(62, 42, 34, 0.88);
    letter-spacing: 0.18rem;
    text-align: center;
    font-size: clamp(0.82rem, 1.8vw, 1rem);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.hero-frame--quick .hero-quick-code-input::placeholder {
    color: rgba(115, 95, 82, 0.5);
    letter-spacing: 0.04rem;
}

.hero-frame--quick .hero-quick-code-input:focus {
    outline: none;
    border-color: rgba(198, 162, 130, 0.75);
    box-shadow: 0 0 0 4px rgba(198, 162, 130, 0.18);
    background: rgba(255, 255, 255, 0.68);
}

.hero-frame--quick .hero-quick-code-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: clamp(0.56rem, 1.4vw, 0.78rem) clamp(1rem, 2.6vw, 1.36rem);
    border-radius: 14px;
    border: 1px solid rgba(214, 192, 175, 0.6);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0.46));
    color: rgba(74, 52, 42, 0.88);
    font-weight: 500;
    font-size: clamp(0.78rem, 1.6vw, 0.92rem);
    letter-spacing: 0.06rem;
    cursor: pointer;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.hero-frame--quick .hero-quick-code-button:hover,
.hero-frame--quick .hero-quick-code-button:focus-visible {
    transform: translateY(-1px);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.68));
    border-color: rgba(198, 162, 130, 0.8);
}

.hero-frame--quick .hero-quick-code-button:focus-visible {
    outline: 2px solid rgba(198, 162, 130, 0.6);
    outline-offset: 2px;
}

.hero-frame--quick .hero-quick-code-status {
    min-height: 1.1rem;
    font-size: clamp(0.68rem, 1.4vw, 0.8rem);
    text-align: center;
    color: rgba(88, 66, 54, 0.7);
    letter-spacing: 0.02em;
}

.hero-frame--quick .hero-quick-code-status.is-error {
    color: rgba(214, 92, 82, 0.92);
}

.hero-frame--quick .hero-quick-code-status.is-success {
    color: rgba(58, 120, 92, 0.92);
}

.hero-frame--quick .hero-quick-code-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}


.hero-frame--quick .hero-quick-code-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: rgba(88, 189, 151, 0.15);
    color: rgba(35, 130, 96, 0.95);
    font-size: clamp(0.6rem, 1.2vw, 0.74rem);
    letter-spacing: 0.06em;
    font-weight: 600;
}

.hero-frame--quick .hero-quick-code-reset {
    font-size: clamp(0.6rem, 1.2vw, 0.72rem);
    color: rgba(255, 255, 255, 0.7);
}

.hero-frame--quick .hero-quick-code-reset:hover,
.hero-frame--quick .hero-quick-code-reset:focus-visible {
    color: rgba(255, 255, 255, 0.95);
}

.switch {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: clamp(0.62rem, 1.1vw, 0.72rem);
    color: rgba(62, 42, 34, 0.82);
    cursor: pointer;
}

.switch input {
    appearance: none;
    width: 42px;
    height: 22px;
    border-radius: 999px;
    background: rgba(198, 162, 130, 0.35);
    position: relative;
    transition: background 0.2s ease;
    cursor: pointer;
}

.switch input::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
    transition: transform 0.2s ease;
}

.switch input:checked {
    background: linear-gradient(135deg, rgba(88, 189, 151, 0.75), rgba(62, 154, 124, 0.9));
}

.switch input:checked::after {
    transform: translateX(20px);
}

.switch__label {
    letter-spacing: 0.02em;
}

.hero-frame--quick .hero-quick-code-extra {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: min(100%, clamp(280px, 88vw, 340px));
    margin: clamp(0.15rem, 0.6vw, 0.28rem) auto 0;
    gap: clamp(0.3rem, 1vw, 0.6rem);
}

.hero-frame--quick .hero-quick-edit-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: clamp(0.6rem, 1.1vw, 0.72rem);
    color: rgba(255, 255, 255, 0.85);
    letter-spacing: 0.03em;
}

.hero-frame--quick .hero-quick-edit-toggle input {
    width: 18px;
    height: 18px;
    accent-color: rgba(198, 162, 130, 0.85);
}

.hero-frame--quick .hero-quick-code-reset {
    font-size: clamp(0.6rem, 1.1vw, 0.72rem);
    color: rgba(255, 255, 255, 0.8);
}

.hero-frame--quick .hero-quick-code-reset:hover,
.hero-frame--quick .hero-quick-code-reset:focus-visible {
    color: rgba(255, 255, 255, 1);
}

@media (max-width: 560px) {
    .hero-frame--quick .hero-quick-code-row {
        grid-template-columns: 1fr;
    }

    .hero-frame--quick .hero-quick-code-button {
        width: 100%;
    }
}

.hero-caption-sub {
    font-size: 0.66rem;
    letter-spacing: 0.14rem;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.78);
}

.hero-frame--stylebar {
    --hero-card-gradient: linear-gradient(135deg, rgba(235, 209, 200, 0.96) 0%, rgba(205, 161, 137, 0.98) 100%);
    --hero-card-foreground: rgba(72, 48, 38, 0.92);
    --stylebar-gap: clamp(0.48rem, 1.3vw, 0.82rem);
    background: var(--hero-card-gradient);
    color: var(--hero-card-foreground);
    box-shadow: 0 40px 84px -48px rgba(134, 80, 49, 0.38);
    padding-top: clamp(4.4rem, 8.2vw, 5.8rem);
    gap: var(--stylebar-gap);
}

@media (max-width: 720px) {
    .hero-frame--stylebar {
        padding-top: clamp(3.2rem, 11vw, 4.6rem);
        gap: clamp(0.56rem, 2vw, 0.96rem);
    }
}

.hero-frame--stylebar .hero-frame-glow {
    display: none !important;
}

.hero-frame--stylebar .hero-caption {
    color: rgba(72, 48, 38, 0.88);
}

.hero-frame--stylebar .hero-caption__light {
    color: rgba(144, 92, 62, 0.9);
}

.hero-frame--stylebar .hero-caption-sub {
    color: rgba(108, 74, 54, 0.65);
}

@media (max-width: 1024px) and (min-width: 601px) {
    .hero-frame--stylebar .hero-caption,
    .hero-frame--stylebar .hero-caption span {
        white-space: nowrap;
    }
}

.hero-frame--stylebar .btn-ghost {
    background: rgba(255, 255, 255, 0.75);
    border-color: rgba(207, 163, 141, 0.4);
    color: rgba(72, 48, 38, 0.82);
}

.hero-frame--stylebar .btn-ghost:hover,
.hero-frame--stylebar .btn-ghost:focus-visible {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(184, 122, 94, 0.56);
    color: rgba(72, 48, 38, 0.92);
}

.hero-frame--stylebar .booking-stepper__item {
    background: rgba(255, 255, 255, 0.6);
    border-color: rgba(207, 163, 141, 0.38);
    color: rgba(108, 74, 54, 0.72);
}

.hero-frame--stylebar .booking-stepper__item.is-active {
    background: rgba(255, 255, 255, 0.95);
    border-color: rgba(184, 122, 94, 0.5);
    color: rgba(72, 48, 38, 0.92);
}

.hero-frame--stylebar .booking-stepper__item.is-complete {
    background: rgba(255, 255, 255, 0.72);
    border-color: rgba(207, 163, 141, 0.4);
    color: rgba(98, 66, 48, 0.78);
}

.hero-frame--stylebar .booking-stepper__number {
    background: rgba(204, 147, 114, 0.24);
    color: rgba(72, 48, 38, 0.85);
}

.hero-frame--stylebar .booking-stepper__item.is-complete .booking-stepper__number {
    background: rgba(204, 147, 114, 0.38);
    color: rgba(72, 48, 38, 0.9);
}

.hero-frame--stylebar .booking-stepper__item.is-active .booking-stepper__number {
    background: rgba(176, 112, 79, 0.92);
    color: #ffffff;
}

.hero-frame--stylebar .booking-success__surface {
    background: rgba(255, 253, 251, 0.92);
    color: rgba(72, 48, 38, 0.9);
}

.hero-frame--stylebar .booking-success__title,
.hero-frame--stylebar .booking-success__message {
    color: rgba(72, 48, 38, 0.9);
}

.hero-frame--stylebar .booking-success__service-label {
    color: rgba(95, 64, 46, 0.78);
}

.hero-frame--stylebar .booking-success__service-price {
    color: rgba(176, 112, 79, 0.9);
}

.hero-frame--stylebar .booking-alert {
    display: grid;
    gap: 0.5rem;
    margin-bottom: 1rem;
    margin-top: 0;
    padding: 0;
    background: none;
    border: none;
    color: inherit;
    border-radius: 0;
    box-shadow: none;
}

.hero-frame--stylebar .booking-alert__label {
    color: inherit;
}

.hero-frame--stylebar .booking-notice {
    margin: 0;
    padding: 1rem 1.2rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.26);
    color: rgba(var(--color-deep-rgb), 0.8);
    font-size: 0.86rem;
    line-height: 1.68;
    letter-spacing: 0.02rem;
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.28);
    backdrop-filter: blur(20px);
}

.hero-frame--stylebar .booking-notice__icon {
    flex: 0 0 auto;
    font-weight: 600;
    font-size: 1.05rem;
    line-height: 1;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    transform: translateY(0.1rem);
    text-shadow: 0 8px 18px rgba(var(--color-deep-rgb), 0.2);
}

.hero-frame--stylebar .booking-confirm {
    margin-top: 0.45rem;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 1.4rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.32);
    background: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.85rem;
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.28s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 20px 40px -28px rgba(var(--color-deep-rgb), 0.32);
    backdrop-filter: blur(18px);
}

.hero-frame--stylebar .booking-confirm.is-checked {
    background: rgba(255, 255, 255, 0.85);
    border-color: rgba(181, 96, 66, 0.52);
    box-shadow: 0 24px 44px -26px rgba(181, 96, 66, 0.38);
    color: rgba(181, 96, 66, 0.92);
}

.hero-frame--stylebar .booking-location {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.2rem 1.3rem;
    margin-top: 0.85rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(12px);
}

.hero-frame--stylebar .booking-location-note {
    margin: 0;
    font-size: 0.86rem;
    line-height: 1.6;
    color: rgba(var(--color-deep-rgb), 0.78);
    letter-spacing: 0.01rem;
}

.hero-frame--stylebar .booking-location-link {
    align-self: flex-start;
    padding-inline: 1.8rem;
}

.hero-frame--stylebar .booking-location-link.btn-ghost--secondary {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(var(--color-deep-rgb), 0.68);
}

.hero-frame--stylebar .booking-location-link.btn-ghost--secondary:hover,
.hero-frame--stylebar .booking-location-link.btn-ghost--secondary:focus-visible {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(var(--color-accent-strong-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.86);
}

.hero-frame--stylebar .hero-stylebar-code-group {
    display: grid;
    gap: clamp(0.08rem, 0.42vw, 0.16rem);
    margin: clamp(0.14rem, 0.5vw, 0.28rem) 0 0;
}

.hero-frame--stylebar .hero-stylebar-code-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(0.18rem, 0.6vw, 0.32rem);
    margin-top: clamp(0.12rem, 0.5vw, 0.24rem);
    align-items: center;
}

.hero-frame--stylebar .hero-stylebar-code-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.35rem, 1.4vw, 0.55rem);
    margin-top: clamp(0.28rem, 1vw, 0.6rem);
    margin-bottom: clamp(0.32rem, 1.1vw, 0.68rem);
    width: 100%;
}

.hero-frame--stylebar .hero-stylebar-code-toggle {
    all: unset;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.12rem, 0.6vw, 0.24rem);
    cursor: pointer;
    color: rgba(72, 48, 38, 0.6);
    font-size: clamp(0.62rem, 1.5vw, 0.78rem);
    line-height: 1.1;
    letter-spacing: 0.02em;
    text-align: center;
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 0.28em;
    padding: clamp(0.14rem, 0.45vw, 0.28rem) 0;
    transition: color 0.2s ease;
}

.hero-frame--stylebar .hero-stylebar-code-toggle:hover,
.hero-frame--stylebar .hero-stylebar-code-toggle:focus-visible,
.hero-frame--stylebar .hero-stylebar-code-toggle.is-active {
    color: rgba(72, 48, 38, 0.85);
}

.hero-frame--stylebar .hero-stylebar-code-toggle__primary {
    font-weight: 500;
}

.hero-frame--stylebar .hero-stylebar-code-toggle__hint {
    font-size: clamp(0.5rem, 1vw, 0.6rem);
    font-weight: 300;
    color: rgba(72, 48, 38, 0.55);
}

.hero-frame--stylebar .hero-stylebar-code-collapse {
    display: flex;
    flex-direction: column;
    gap: clamp(0.24rem, 0.9vw, 0.48rem);
    padding: 0;
}

.hero-frame--stylebar .hero-stylebar-code-collapse[hidden] {
    display: none !important;
}

@media (max-width: 720px) {
    .hero-frame--stylebar .hero-stylebar-code-toggle__primary,
    .hero-frame--stylebar .hero-stylebar-code-toggle__hint {
        text-align: center;
    }
}

@media (max-width: 540px) {
    .hero-frame--stylebar .hero-stylebar-code-row {
        grid-template-columns: 1fr;
        gap: clamp(0.24rem, 1.4vw, 0.48rem);
        margin-top: clamp(0.28rem, 1.8vw, 0.58rem);
    }

    .hero-frame--stylebar .hero-stylebar-code-group {
        gap: clamp(0.12rem, 0.8vw, 0.24rem);
        margin-top: clamp(0.24rem, 1.6vw, 0.48rem);
    }
}

@media (max-width: 480px) {
    .hero-card-stage {
        transform: none;
    }

    .hero-card-carousel > .hero-frame {
        width: min(100%, 340px);
    }

    .hero-frame .hero-logo {
        width: min(50vw, 154px);
        border-radius: clamp(10px, 2vw, 20px);
    }

    .hero-frame--vip {
        --vip-card-bottom-gap: clamp(0.68rem, 2.6vw, 1.08rem);
    }

    .hero-frame--stylebar {
        --stylebar-gap: clamp(0.32rem, 2vw, 0.6rem);
    }

    .hero-card-carousel > .hero-frame--vip {
        min-height: clamp(450px, 118vw, 520px);
    }
}

.hero-frame--stylebar .hero-stylebar-code-hint {
    margin: 0;
    font-size: clamp(0.66rem, 1.3vw, 0.78rem);
    font-weight: 300;
    line-height: 1.18;
    color: rgba(82, 52, 38, 0.6);
    letter-spacing: 0.01em;
}

.hero-frame--stylebar .hero-stylebar-code-input {
    width: 100%;
    padding: clamp(0.56rem, 1.6vw, 0.82rem);
    border: 1px solid rgba(201, 148, 118, 0.4);
    border-radius: 14px;
    background-color: rgba(255, 255, 255, 0.36);
    backdrop-filter: blur(10px);
    font-size: clamp(0.95rem, 2.4vw, 1.05rem);
    letter-spacing: 0.28rem;
    text-transform: none;
    text-align: center;
    color: rgba(72, 48, 38, 0.9);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.hero-frame--stylebar .hero-stylebar-code-input::placeholder {
    letter-spacing: normal;
    color: rgba(120, 86, 70, 0.38);
}

.hero-frame--stylebar .hero-stylebar-code-input:focus {
    background-color: rgba(255, 255, 255, 0.62);
    border-color: rgba(171, 110, 78, 0.72);
    box-shadow: 0 0 0 4px rgba(201, 148, 118, 0.18);
    outline: none;
}

.hero-frame--stylebar .hero-stylebar-code-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: clamp(0.46rem, 1.4vw, 0.68rem) clamp(0.92rem, 2.2vw, 1.12rem);
    border-radius: 12px;
    border: 1px solid rgba(201, 148, 118, 0.46);
    background: linear-gradient(125deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.18));
    color: rgba(82, 52, 38, 0.86);
    font-weight: 500;
    font-size: clamp(0.74rem, 1.5vw, 0.88rem);
    letter-spacing: 0.08rem;
    text-transform: uppercase;
    backdrop-filter: blur(8px);
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
}

.hero-frame--stylebar .hero-stylebar-code-button:hover,
.hero-frame--stylebar .hero-stylebar-code-button:focus-visible {
    background: linear-gradient(125deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.5));
    color: rgba(82, 52, 38, 0.95);
    border-color: rgba(171, 110, 78, 0.78);
    transform: translateY(-1px);
}

.hero-frame--stylebar .hero-stylebar-code-button:focus-visible {
    outline: 2px solid rgba(171, 110, 78, 0.6);
    outline-offset: 2px;
}

.hero-frame--stylebar .hero-stylebar-code-button:disabled {
    opacity: 0.68;
    cursor: not-allowed;
    border-color: rgba(201, 148, 118, 0.28);
    background: rgba(255, 255, 255, 0.32);
}

.hero-frame--stylebar .hero-stylebar-code-status {
    margin: 0;
    min-height: 1.2em;
    font-size: clamp(0.62rem, 1.3vw, 0.78rem);
    color: rgba(82, 52, 38, 0.6);
    letter-spacing: 0.01em;
}

.hero-frame--stylebar .hero-stylebar-code-status.is-success {
    color: rgba(46, 102, 81, 0.92);
}

.hero-frame--stylebar .hero-stylebar-code-status.is-error {
    color: rgba(176, 70, 58, 0.9);
}

.hero-frame--stylebar .hero-stylebar-code-status.is-loading {
    color: rgba(82, 52, 38, 0.72);
}

.hero-frame--stylebar::before,
.hero-frame--stylebar::after {
    content: none !important;
    display: none !important;
}

.hero-frame--vip {
    --hero-card-gradient: linear-gradient(135deg, rgba(174, 147, 125, 0.95) 0%, rgba(127, 74, 35, 0.95) 100%);
    --hero-card-foreground: rgba(255, 247, 238, 0.95);
    --hero-frame-head: clamp(150px, 36vw, 196px);
    --vip-card-bottom-gap: clamp(3.6rem, 8.5vw, 5.4rem);
    background: var(--hero-card-gradient);
    color: var(--hero-card-foreground);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: clamp(0.85rem, 2vw, 1.1rem);
    padding-top: clamp(5.4rem, 8.4vw, 7.2rem);
    padding-bottom: var(--vip-card-bottom-gap);
}

.hero-frame--vip .hero-frame-head {
    margin-top: clamp(1.2rem, 2vw, 2rem);
}

.hero-frame--vip .hero-booking-gate {
    margin-top: clamp(0.32rem, 1.4vw, 0.9rem);
    width: 100%;
    display: grid;
    gap: clamp(0.22rem, 0.9vw, 0.4rem);
    padding-top: clamp(0.62rem, 1.8vw, 1.2rem);
}

@media (max-width: 720px) {
    .hero-frame--vip {
        --hero-frame-head: clamp(115px, 44vw, 140px);
        --vip-card-bottom-gap: clamp(0.6rem, 2.4vw, 1.05rem);
        padding-top: clamp(2.4rem, 6.2vw, 2.9rem);
    }

    .hero-frame--vip .hero-frame-head {
        margin-top: clamp(0.18rem, 0.8vw, 0.44rem);
    }

    .hero-frame--vip .hero-booking-gate {
        margin-top: clamp(0.24rem, 1.2vw, 0.6rem);
        gap: clamp(0.2rem, 0.85vw, 0.36rem);
        padding-top: clamp(0.54rem, 1.6vw, 0.9rem);
    }

    .hero-card-carousel > .hero-frame--vip {
        min-height: clamp(480px, 110vw, 560px);
    }
}

@media (max-width: 600px) {
    .hero-frame--vip .hero-booking-gate {
        margin-top: clamp(0.18rem, 1vw, 0.5rem);
        gap: clamp(0.16rem, 0.72vw, 0.34rem);
        padding-top: clamp(0.42rem, 1.4vw, 0.68rem);
    }
}

.hero-frame--vip .hero-booking-gate__field {
    display: grid;
    gap: clamp(0.18rem, 0.7vw, 0.32rem);
}

.hero-frame--vip .hero-code-input-label {
    display: inline-block;
    font-size: clamp(0.7rem, 2vw, 0.82rem);
    letter-spacing: 0.42rem;
    text-transform: uppercase;
    color: rgba(255, 247, 238, 0.7);
    margin-bottom: clamp(0.12rem, 0.6vw, 0.32rem);
    justify-self: center;
    text-align: center;
}

.hero-frame--vip .hero-code-input-grid {
    display: grid;
    grid-template-columns: minmax(42px, 1.6fr) minmax(60px, 3.6fr) minmax(60px, 3.6fr) minmax(54px, 2.6fr);
    align-items: stretch;
    gap: clamp(0.14rem, 0.6vw, 0.28rem);
}

.hero-frame--vip .hero-code-input-grid input {
    width: 100%;
    min-width: 0;
    padding: clamp(0.72rem, 1.8vw, 0.98rem);
    letter-spacing: 0.16rem;
    text-align: center;
    font-size: clamp(0.82rem, 1.9vw, 1rem);
    border-radius: 10px;
}

.hero-frame--vip .hero-booking-gate__actions .btn {
    width: min(100%, clamp(200px, 62%, 280px));
    white-space: nowrap;
}

@media (max-width: 560px) {
    .hero-frame--vip .hero-code-input-grid {
        grid-template-columns: minmax(40px, 1.6fr) minmax(54px, 3.4fr) minmax(54px, 3.4fr) minmax(50px, 2.6fr);
        gap: clamp(0.1rem, 1vw, 0.22rem);
    }

    .hero-frame--vip .hero-code-input-grid input {
        font-size: clamp(0.78rem, 2.1vw, 0.94rem);
        padding: clamp(0.56rem, 1.6vw, 0.72rem);
        letter-spacing: 0.08rem;
    }

    .hero-frame--vip .hero-booking-gate__actions .btn {
        width: 100%;
        white-space: nowrap;
    }
}

.hero-frame--vip .hero-booking-gate__actions {
    justify-content: center;
    margin-top: clamp(0.24rem, 1.2vw, 0.6rem);
    margin-bottom: 0;
}

.hero-frame--vip .hero-booking-gate__actions .btn {
    flex: 0 1 auto;
    width: min(100%, clamp(200px, 62%, 280px));
}

.hero-frame--vip.expanded {
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.85rem;
    padding-top: clamp(2.2rem, 4.6vw, 3rem);
    padding-bottom: clamp(2.6rem, 5vw, 3.4rem);
}

.hero-frame--vip.expanded .booking-form {
    margin-top: clamp(0.9rem, 3.2vw, 1.2rem);
}

@media (max-width: 720px) {
    .hero-frame--vip.expanded {
        gap: clamp(0.28rem, 1.2vw, 0.38rem);
        padding-top: clamp(0.08rem, 0.8vw, 0.18rem);
        padding-bottom: clamp(1.8rem, 4.6vw, 2.4rem);
    }

    .hero-frame--vip.expanded .booking-form {
        margin-top: clamp(0.16rem, 1vw, 0.26rem);
    }
}

.hero-frame--vip.expanded .hero-frame-head {
    display: none;
}

.hero-caption-sub span {
    display: block;
}

.hero-frame.expanded .hero-booking-gate {
    display: none;
}

.hero-frame.expanded .hero-booking-toggle {
    display: none;
}

.hero-frame::before,
.hero-frame::after {
    content: none !important;
    display: none !important;
}

.hero-frame.expanded::after {
    display: none !important;
}

.hero-frame--vip {
    --hero-card-gradient: linear-gradient(135deg, rgba(174, 147, 125, 0.95) 0%, rgba(127, 74, 35, 0.95) 100%);
    --hero-card-foreground: rgba(255, 247, 238, 0.95);
    background: var(--hero-card-gradient);
    color: var(--hero-card-foreground);
    box-shadow: 0 44px 90px -46px rgba(50, 28, 16, 0.55);
}

.hero-frame--vip .hero-frame-glow {
    display: none !important;
}

.hero-frame--vip::before,
.hero-frame--vip::after {
    content: none !important;
    display: none !important;
}

.vip-pass {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: clamp(1.8rem, 4vw, 3.2rem);
    align-items: center;
}

.vip-pass__hero {
    grid-column: 1 / span 6;
    display: flex;
    flex-direction: column;
    gap: clamp(0.7rem, 2vw, 1.4rem);
}

.vip-pass__eyebrow {
    font-size: 0.78rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: rgba(255, 247, 238, 0.6);
}

.vip-pass__wordmark {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: clamp(4rem, 12vw, 7rem);
    letter-spacing: 0.24em;
}

.vip-pass__tagline {
    margin: 0;
    font-size: 1.05rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(255, 247, 238, 0.72);
}

.vip-pass__description {
    margin: 0;
    max-width: 420px;
    font-size: 0.98rem;
    line-height: 1.75;
    color: rgba(255, 247, 238, 0.76);
}

.vip-pass__perks {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.45rem;
    font-size: 0.92rem;
    color: rgba(255, 247, 238, 0.8);
}

.vip-pass__perks li {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.vip-pass__perks li::before {
    content: "•";
    color: rgba(255, 247, 238, 0.8);
    font-size: 0.9em;
}

.vip-pass__panel {
    grid-column: 7 / -1;
    display: flex;
    justify-content: center;
}

.vip-pass__card {
    width: min(320px, 100%);
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: clamp(1.5rem, 3.6vw, 2rem);
    border-radius: 28px;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.05) 100%);
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: 0 28px 64px -36px rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(22px);
    color: rgba(255, 247, 238, 0.92);
}

.vip-pass__artwork {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 18px 42px -28px rgba(0, 0, 0, 0.45);
}

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

.vip-pass__meta {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    font-size: 0.75rem;
    color: rgba(255, 247, 238, 0.74);
}

.vip-pass__badge {
    font-weight: 500;
}

.vip-pass__channel {
    font-size: 0.88rem;
    letter-spacing: 0.28em;
    color: rgba(255, 247, 238, 0.86);
}

.vip-pass__field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.82rem;
}

.vip-pass__field span {
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(255, 247, 238, 0.68);
}

.vip-pass__field input {
    border: 1px solid rgba(255, 255, 255, 0.32);
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 247, 238, 0.94);
    border-radius: 18px;
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    letter-spacing: 0.08em;
}

.vip-pass__field input::placeholder {
    color: rgba(255, 247, 238, 0.55);
}

.vip-pass__actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.6rem;
}

.vip-pass__btn {
    border: none;
    border-radius: 999px;
    padding: 0.72rem 1.2rem;
    font-size: 0.9rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease, color 0.3s ease;
}

.vip-pass__btn--ghost {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 247, 238, 0.85);
    border: 1px solid rgba(255, 255, 255, 0.28);
}

.vip-pass__btn--solid {
    background: linear-gradient(135deg, rgba(255, 207, 188, 0.95) 0%, rgba(223, 162, 126, 0.95) 100%);
    color: rgba(103, 52, 24, 0.92);
    box-shadow: 0 18px 42px -28px rgba(0, 0, 0, 0.5);
}

.vip-pass__btn:hover,
.vip-pass__btn:focus-visible {
    transform: translateY(-3px);
    box-shadow: 0 20px 42px -20px rgba(0, 0, 0, 0.45);
    outline: none;
}

.vip-pass__note {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.6;
    color: rgba(255, 247, 238, 0.64);
}


.hero-frame.expanded .hero-frame-glow {
    display: none !important;
}

.hero-frame.success-mode {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    min-height: auto;
    width: min(520px, 94%);
    padding: clamp(1.6rem, 4vw, 2.3rem) clamp(1.4rem, 4vw, 2rem);
    margin-inline: auto;
}

@media (min-width: 1024px) {
    .hero-frame {
        width: min(460px, 34vw);
        min-height: clamp(600px, 51vw, 740px);
        aspect-ratio: 2 / 3;
        padding: 4.1rem 3.2rem 3.9rem;
        gap: 1.55rem;
    }

    .hero-frame.hero-frame--vip {
        padding-top: clamp(5.4rem, 6.6vw, 6.8rem);
    }

    .hero-frame .hero-logo {
        width: min(300px, 72%);
    }

    .hero-frame .hero-caption {
        max-height: none;
        font-size: 1.05rem;
        letter-spacing: 0.48rem;
    }

    .hero-caption-sub {
        font-size: 0.78rem;
        letter-spacing: 0.24rem;
    }

    .hero-frame .btn-ghost {
        min-height: 64px;
        font-size: 1.12rem;
        letter-spacing: 0.36rem;
    }

    .hero-frame.expanded {
        width: min(640px, 54vw);
        min-height: clamp(700px, 56vw, 840px);
        aspect-ratio: auto;
        padding: 2.6rem 3.2rem 3.5rem;
    }

    .hero-frame.success-mode {
        width: min(520px, 40vw);
        min-height: clamp(640px, 48vw, 780px);
        aspect-ratio: auto;
    }
}

.hero-frame.success-mode > *:not(.booking-success) {
    display: none !important;
}

.hero-frame.success-mode .booking-success {
    position: static;
    inset: auto;
    width: 100%;
    padding: 0;
    opacity: 0;
    transform: translateY(12px);
    pointer-events: none;
    transition: opacity 0.32s ease, transform 0.36s ease;
}

.hero-frame.success-mode .booking-success.is-visible {
    opacity: 1;
    transform: none;
    pointer-events: auto;
}

.hero-frame.success-mode .booking-success__surface {
    width: min(420px, 100%);
    padding: clamp(1.5rem, 3.6vw, 2.1rem);
    border-radius: 28px;
    gap: 0.95rem;
    margin: 0 auto;
}

.hero-frame-glow {
    display: none !important;
}

.hero-logo {
    width: 210px;
    height: auto;
    max-width: 100%;
    filter: drop-shadow(0 18px 32px rgba(0, 0, 0, 0.26));
}

.hero-caption {
    font-size: 0.86rem;
    letter-spacing: 0.42rem;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.9);
}

.hero-frame .btn-ghost {
    width: 100%;
    justify-content: center;
    min-height: 52px;
    border-radius: 28px;
    font-size: 0.95rem;
    letter-spacing: 0.32rem;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(var(--color-accent-light-rgb), 0.48));
    color: rgba(var(--color-deep-rgb), 0.78);
    border-color: rgba(var(--color-accent-rgb), 0.32);
    box-shadow: 0 24px 48px -30px rgba(var(--color-deep-rgb), 0.32);
    backdrop-filter: blur(18px);
}

.hero-frame .btn-ghost:hover,
.hero-frame .btn-ghost:focus-visible {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(var(--color-accent-light-rgb), 0.62));
    border-color: rgba(var(--color-accent-strong-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.92);
    transform: translateY(-4px) scale(1.04);
}

.hero-frame .btn-ghost.btn-ghost--mini {
    min-height: 44px;
    font-size: 0.78rem;
    letter-spacing: 0.22rem;
}

.booking-success {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(1.6rem, 3vw, 3rem);
    pointer-events: none;
    opacity: 0;
    transform: scale(0.96);
    transition: opacity 0.38s ease, transform 0.4s ease;
    z-index: 6;
}

.booking-success.is-visible {
    opacity: 1;
    transform: scale(1);
    pointer-events: auto;
}

.booking-success__surface {
    width: min(100%, 480px);
    padding: clamp(1.6rem, 3.6vw, 2.4rem);
    border-radius: 30px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.35);
    background: linear-gradient(140deg, rgba(var(--color-ivory-rgb), 0.92), rgba(var(--color-accent-soft-rgb), 0.55));
    backdrop-filter: blur(22px);
    box-shadow: 0 42px 88px -46px rgba(var(--color-deep-rgb), 0.32);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1.05rem;
    text-align: center;
    color: var(--ink-strong);
    outline: none;
}

.hero-frame .booking-success__surface {
    color: var(--ink-strong);
}

.booking-success__icon {
    width: clamp(64px, 12vw, 88px);
    height: clamp(64px, 12vw, 88px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.booking-success__check {
    width: 100%;
    height: 100%;
}

.booking-success__title {
    font-size: clamp(1.1rem, 2.4vw, 1.4rem);
    letter-spacing: 0.04rem;
    text-transform: none;
}

.booking-success__message {
    font-size: clamp(0.9rem, 2.2vw, 1rem);
    line-height: 1.55;
    color: var(--ink-medium);
    max-width: 360px;
    text-align: center;
}

.booking-success__message--lead {
    margin-top: -0.15rem;
}

.booking-success__summary {
    width: 100%;
    margin-top: 1.1rem;
    padding: 1rem 1.35rem;
    border-radius: 24px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.32);
    background: linear-gradient(150deg, rgba(var(--color-ivory-rgb), 0.88), rgba(var(--color-accent-soft-rgb), 0.45));
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.booking-success__summary-value {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    min-height: 1.2rem;
}

.booking-success__summary-row {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 0.35rem 1.4rem;
}

.booking-success__summary-row + .booking-success__summary-row {
    padding-top: 0.45rem;
    border-top: 1px solid rgba(var(--color-accent-rgb), 0.16);
}

@media (max-width: 560px) {
    .booking-success__summary-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }

    .booking-success__summary-value {
        text-align: left;
        font-size: 0.88rem;
        padding-left: 0.1rem;
        word-break: break-word;
    }
}

.booking-success__summary-label {
    font-size: 0.78rem;
    letter-spacing: 0.08rem;
    color: var(--ink-muted);
    white-space: nowrap;
}

.booking-success__summary-value {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    font-size: 0.92rem;
    font-weight: 600;
    letter-spacing: 0.04rem;
    color: var(--ink-strong);
    text-align: right;
    word-break: keep-all;
    min-height: 1.3rem;
}

.booking-success__account {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    padding: 1rem 1.35rem;
    border-radius: 24px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.34);
    background: linear-gradient(150deg, rgba(var(--color-ivory-rgb), 0.9), rgba(var(--color-accent-soft-rgb), 0.5));
    margin-top: 1.1rem;
}

.booking-success__service {
    width: 100%;
    margin-top: 0.9rem;
    padding: 0.95rem 1.2rem;
    border-radius: 22px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    background: linear-gradient(160deg, rgba(var(--color-ivory-rgb), 0.9), rgba(var(--color-accent-soft-rgb), 0.38));
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.booking-success__service-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
}

.booking-success__service-label {
    font-size: 0.78rem;
    letter-spacing: 0.08rem;
    color: var(--ink-muted);
}

.booking-success__service-value,
.booking-success__service-price {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--ink-strong);
    letter-spacing: 0.04rem;
    text-align: right;
    word-break: keep-all;
}

.booking-success__kakao {
    margin-top: 1rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: center;
    padding: 0.52rem clamp(1rem, 3.2vw, 1.45rem);
    border: 1px solid rgba(var(--color-accent-rgb), 0.42);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    color: rgba(var(--color-deep-rgb), 0.8);
    box-shadow: 0 18px 40px -30px rgba(var(--color-deep-rgb), 0.26);
    font-size: clamp(0.62rem, 1.6vw, 0.74rem);
    letter-spacing: clamp(0.04rem, 0.4vw, 0.07rem);
    text-transform: none;
    white-space: nowrap;
    width: auto;
    max-width: 100%;
}

.booking-success__kakao:hover,
.booking-success__kakao:focus-visible {
    border-color: rgba(var(--color-accent-strong-rgb), 0.55);
    background: rgba(255, 255, 255, 0.96);
    color: rgba(var(--color-deep-rgb), 0.9);
}


.booking-success__account-text {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.booking-success__copy {
    align-self: flex-start;
    margin-top: 0.2rem;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.booking-success__copy.is-copied {
    background: rgba(var(--color-accent-strong-rgb), 0.88);
    color: #fff;
    border-color: rgba(var(--color-accent-strong-rgb), 0.88);
}

.booking-success__bank {
    font-size: 0.82rem;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    color: var(--ink-muted);
}

.booking-success__number {
    font-size: clamp(1.02rem, 2.2vw, 1.18rem);
    letter-spacing: 0.18rem;
    font-weight: 600;
    color: var(--ink-strong);
    white-space: nowrap;
}

.booking-success__holder {
    font-size: 0.84rem;
    color: var(--ink-medium);
    letter-spacing: 0.08rem;
}

.booking-success__actions {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.2rem;
}

.booking-success__actions .btn-link {
    color: rgba(var(--color-deep-rgb), 0.72);
    letter-spacing: 0.14rem;
}

.booking-success__actions .btn-link:hover {
    color: rgba(var(--color-deep-rgb), 0.9);
}

.booking-success__close {
    margin-top: 0.3rem;
    color: rgba(var(--color-deep-rgb), 0.68);
    letter-spacing: 0.12rem;
}

.booking-success__close:hover,
.booking-success__close:focus-visible,
.booking-success__return:hover,
.booking-success__return:focus-visible {
    color: rgba(var(--color-deep-rgb), 0.88);
}

@media (max-width: 560px) {
    .booking-success__surface {
        border-radius: 28px;
        padding: clamp(1.4rem, 6vw, 2.1rem);
    }

    .booking-success__summary,
    .booking-success__account,
    .booking-success__service {
        padding: 0.85rem 0.95rem;
        gap: 0.65rem;
    }

    .booking-success__summary-row,
    .booking-success__service-item {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.18rem;
    }

    .booking-success__summary-value,
    .booking-success__service-value,
    .booking-success__service-price {
        font-size: 0.84rem;
        justify-content: flex-start;
        text-align: left;
    }

    .booking-success__summary-label,
    .booking-success__service-label {
        font-size: 0.74rem;
        letter-spacing: 0.06rem;
        white-space: normal;
    }

    .booking-success__kakao {
        width: auto;
        max-width: 100%;
    }

    .booking-success__actions {
        gap: 0.35rem;
    }
}

.btn-link {
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.85rem;
    letter-spacing: 0.12rem;
    text-transform: uppercase;
    cursor: pointer;
    padding: 0.4rem 0.6rem;
    transition: color 0.3s ease;
}

.btn-link:hover {
    color: #ffffff;
}

.booking-form {
    display: none;
    width: 100%;
    margin-top: 1.6rem;
    color: var(--ink-strong);
    gap: 1.4rem;
}

.booking-alert {
    display: grid;
    gap: 0.5rem;
    margin-bottom: 1rem;
    margin-top: 0;
}

.booking-location {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.2rem 1.3rem;
    margin-top: 0.85rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(12px);
}

.booking-location-note {
    margin: 0;
    font-size: 0.86rem;
    line-height: 1.6;
    color: rgba(var(--color-deep-rgb), 0.78);
    letter-spacing: 0.01rem;
}

.booking-location-note br {
    content: "";
    display: block;
    margin-block: 0.35rem;
}

.booking-location-link {
    align-self: flex-start;
    padding-inline: 1.8rem;
}

.booking-location-link.btn-ghost--secondary {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.2);
    color: rgba(var(--color-deep-rgb), 0.68);
}

.booking-location-link.btn-ghost--secondary:hover,
.booking-location-link.btn-ghost--secondary:focus-visible {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(var(--color-accent-strong-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.86);
}

.booking-alert__label {
    font-size: 0.9rem;
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    color: var(--ink-medium);
}

.booking-consents {
    margin-top: 1.2rem;
    padding: 1.05rem 1.35rem;
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.14);
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    color: var(--ink-strong);
    backdrop-filter: blur(20px);
    box-shadow: 0 24px 42px -28px rgba(var(--color-deep-rgb), 0.28);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.booking-consents.field-error {
    border-color: rgba(var(--color-error-rgb), 0.82);
    box-shadow: 0 0 0 4px rgba(var(--color-error-rgb), 0.2), 0 28px 48px -28px rgba(var(--color-deep-rgb), 0.3);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-consents__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 0.3rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}

.booking-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 0.48rem;
    font-size: 0.72rem;
    line-height: 1.4;
    color: rgba(var(--color-deep-rgb), 0.78);
    letter-spacing: 0.001rem;
    cursor: pointer;
}

.booking-checkbox span {
    font-size: 0.72rem;
    letter-spacing: 0.01rem;
    color: rgba(var(--color-deep-rgb), 0.8);
}

.booking-checkbox input {
    flex: 0 0 auto;
    width: 1.02rem;
    height: 1.02rem;
    margin-top: 0.12rem;
    border-radius: 6px;
    border: 1px solid rgba(var(--color-deep-rgb), 0.32);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 10px 18px -18px rgba(var(--color-deep-rgb), 0.36);
    accent-color: rgba(var(--color-accent-strong-rgb), 0.92);
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.booking-checkbox input.field-error {
    border-color: rgba(var(--color-error-rgb), 0.8);
    box-shadow: 0 0 0 4px rgba(var(--color-error-rgb), 0.2);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-checkbox.field-error span {
    color: rgba(var(--color-error-rgb), 0.9);
}

.booking-checkbox input:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.7);
    outline-offset: 3px;
}

.booking-checkbox--master {
    padding: 1.05rem 1.35rem;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.24);
    border: 1px solid rgba(255, 255, 255, 0.32);
    font-weight: 600;
    font-size: 1.45rem;
    letter-spacing: 0.036rem;
    box-shadow: 0 24px 42px -28px rgba(var(--color-deep-rgb), 0.32);
}

.booking-consents__list {
    display: grid;
    gap: 0.7rem;
}

.booking-consents__item {
    padding: 0.65rem 0.85rem 0.75rem;
    border-radius: 18px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(18px);
    box-shadow: 0 18px 30px -24px rgba(var(--color-deep-rgb), 0.26);
    display: grid;
    gap: 0.45rem;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}

.booking-consents__item.field-error {
    border-color: rgba(var(--color-error-rgb), 0.7);
    background: rgba(255, 239, 239, 0.18);
    box-shadow: 0 0 0 3px rgba(var(--color-error-rgb), 0.15), 0 22px 40px -28px rgba(var(--color-deep-rgb), 0.32);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-consents__item-header {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.3rem;
}

.booking-consents__title {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    flex-wrap: wrap;
}

.booking-consents__title em {
    font-style: normal;
    font-size: 0.68em;
    letter-spacing: 0.07rem;
    color: rgba(var(--color-deep-rgb), 0.58);
    white-space: nowrap;
}

.booking-consent-toggle {
    align-self: flex-start;
    background: none;
    border: none;
    padding: 0;
    font-size: 0.41rem;
    letter-spacing: 0.05rem;
    color: rgba(var(--color-accent-strong-rgb), 0.9);
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.16rem;
    transition: color 0.2s ease;
}

.booking-consent-toggle::after {
    content: "";
    width: 0.45rem;
    height: 0.45rem;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translateY(-1px);
    transition: transform 0.2s ease;
}

.booking-consent-toggle:hover,
.booking-consent-toggle:focus-visible {
    color: rgba(var(--color-accent-strong-rgb), 1);
}

.booking-consent-toggle:focus-visible {
    outline: 2px solid rgba(var(--color-accent-strong-rgb), 0.45);
    outline-offset: 3px;
}

.booking-consent-toggle[aria-expanded="true"]::after {
    transform: rotate(225deg) translateY(-1px);
}

.booking-consents__highlight {
    margin: 0;
    margin-top: -0.28rem;
    padding: 0.52rem 0.7rem;
    border-radius: 16px;
    font-size: 0.72rem;
    line-height: 1.55;
    letter-spacing: 0.008rem;
    color: rgba(var(--color-deep-rgb), 0.88);
    background: rgba(var(--color-deep-rgb), 0.08);
    border: 1px solid rgba(var(--color-deep-rgb), 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
    font-weight: 600;
}

.booking-consents[data-consent-collapsed="true"] .booking-consents__header {
    border-bottom: none;
    padding-bottom: 0;
}

.booking-consents[data-consent-collapsed="true"] .booking-consent-toggle {
    display: none;
}

.booking-consents[data-consent-collapsed="true"] .booking-consents__list {
    display: none;
}

.booking-consents__item-body {
    font-size: 0.8rem;
    line-height: 1.68;
    letter-spacing: 0.01rem;
    color: rgba(var(--color-deep-rgb), 0.76);
    display: grid;
    gap: 0.5rem;
}

.booking-consents__item-body p {
    margin: 0;
}

.booking-consents__item-body strong {
    color: rgba(var(--color-deep-rgb), 0.92);
}

.booking-consents__item-body[hidden] {
    display: none;
}

.booking-confirm {
    margin-top: 0.45rem;
    align-self: flex-start;
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.6rem 1.4rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.32);
    background: rgba(255, 255, 255, 0.2);
    color: rgba(255, 255, 255, 0.88);
    font-size: 0.85rem;
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: transform 0.28s ease, background 0.3s ease, border-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 20px 40px -28px rgba(var(--color-deep-rgb), 0.32);
    backdrop-filter: blur(18px);
}

.booking-confirm__icon {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    background: rgba(255, 255, 255, 0.18);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
    color: rgba(255, 255, 255, 0.85);
    transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

.booking-confirm:focus-visible {
    outline: 2px solid rgba(255, 255, 255, 0.65);
    outline-offset: 4px;
}

.booking-confirm:hover {
    background: rgba(255, 255, 255, 0.3);
    border-color: rgba(255, 255, 255, 0.6);
    color: rgba(181, 96, 66, 0.92);
    transform: translateY(-2px);
}

.booking-confirm.is-checked {
    background: rgba(255, 255, 255, 0.85);
    border-color: rgba(181, 96, 66, 0.52);
    box-shadow: 0 24px 44px -26px rgba(181, 96, 66, 0.38);
    color: rgba(181, 96, 66, 0.92);
}

.booking-confirm.is-checked .booking-confirm__icon {
    background: rgba(181, 96, 66, 0.12);
    border-color: rgba(181, 96, 66, 0.6);
    color: rgba(181, 96, 66, 0.92);
    box-shadow: 0 6px 16px -8px rgba(181, 96, 66, 0.35);
}

.booking-confirm.field-error {
    border-color: rgba(var(--color-error-rgb), 0.88);
    border-width: 2px;
    background: rgba(var(--color-error-rgb), 0.12);
    color: rgba(var(--color-error-rgb), 0.92);
    box-shadow: 0 0 0 4px rgba(var(--color-error-rgb), 0.22), 0 24px 48px -28px rgba(var(--color-deep-rgb), 0.32);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-confirm.field-error .booking-confirm__icon {
    border-color: rgba(var(--color-error-rgb), 0.8);
    background: rgba(var(--color-error-rgb), 0.16);
    color: rgba(var(--color-error-rgb), 0.9);
    box-shadow: 0 0 0 3px rgba(var(--color-error-rgb), 0.2);
}

.booking-confirm__icon::before {
    content: "";
    display: inline-block;
    transform: scale(0);
    transition: transform 0.2s ease;
}

.booking-confirm.is-checked .booking-confirm__icon::before {
    content: "\2713";
    transform: scale(1);
}

.booking-notice {
    margin: 0;
    padding: 1rem 1.2rem;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.26);
    color: rgba(var(--color-deep-rgb), 0.8);
    font-size: 0.86rem;
    line-height: 1.68;
    letter-spacing: 0.02rem;
    box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.28);
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    backdrop-filter: blur(20px);
}

.booking-notice__icon {
    flex: 0 0 auto;
    font-weight: 600;
    font-size: 1.05rem;
    line-height: 1;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    transform: translateY(0.1rem);
    text-shadow: 0 8px 18px rgba(var(--color-deep-rgb), 0.2);
}

.booking-notice__text {
    flex: 1 1 auto;
    display: block;
}

.booking-notice strong {
    color: rgba(var(--color-deep-rgb), 0.92);
}

.hero-frame.expanded .booking-form {
    display: flex;
    flex-direction: column;
    animation: bookingFadeIn 0.45s ease forwards;
}

@keyframes bookingFadeIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.booking-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem 1rem;
}

.booking-stepper {
    display: flex;
    justify-content: center;
    margin-bottom: 1.2rem;
}

.booking-stepper__list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    list-style: none;
    margin: 0;
    padding: 0;
    flex-wrap: wrap;
}

.booking-stepper__item {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.65rem 1rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.26);
    color: rgba(var(--color-deep-rgb), 0.6);
    text-transform: uppercase;
    letter-spacing: 0.14rem;
    font-size: 0.7rem;
    box-shadow: 0 20px 36px -28px rgba(var(--color-deep-rgb), 0.24);
    backdrop-filter: blur(18px);
    transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

.booking-stepper__item.is-active {
    background: rgba(255, 255, 255, 0.9);
    border-color: rgba(255, 255, 255, 0.72);
    color: rgba(var(--color-deep-rgb), 0.9);
    box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.32);
}

.booking-stepper__item.is-complete {
    background: rgba(255, 255, 255, 0.32);
    border-color: rgba(255, 255, 255, 0.32);
    color: rgba(var(--color-deep-rgb), 0.72);
}

.booking-stepper__number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    background: rgba(var(--color-accent-soft-rgb), 0.3);
    color: rgba(var(--color-deep-rgb), 0.78);
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.02rem;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.35);
    flex-shrink: 0;
}

.booking-stepper__item.is-complete .booking-stepper__number {
    background: rgba(var(--color-accent-soft-rgb), 0.5);
    color: rgba(var(--color-deep-rgb), 0.86);
}

.booking-stepper__item.is-active .booking-stepper__number {
    background: rgba(var(--color-accent-strong-rgb), 0.9);
    color: #ffffff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

.booking-stepper__label {
    letter-spacing: 0.08rem;
}

.stylebar-affiliate-badge {
    margin: 0 0 1.2rem;
    padding: 0.75rem 1rem;
    border-radius: 14px;
    background: rgba(184, 131, 103, 0.12);
    color: #8a5a3b;
    font-weight: 600;
    font-size: 0.95rem;
    line-height: 1.45;
    letter-spacing: -0.005em;
}

.theme-stylebar .stylebar-affiliate-badge {
    background: rgba(184, 131, 103, 0.18);
    color: #6f3f26;
}

.booking-steps {
    display: grid;
    gap: 1.6rem;
    margin-top: 1.4rem;
}

.booking-step {
    display: none;
    gap: 1.35rem;
}

.booking-step.is-active {
    display: grid;
    animation: stepFade 0.4s ease;
}

@keyframes stepFade {
    from {
        opacity: 0;
        transform: translateY(12px);
    }

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

.booking-policy {
    display: grid;
    gap: 0.65rem;
    margin-bottom: 1.1rem;
    padding: 1.05rem 1.25rem;
    border-radius: 22px;
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.2), rgba(var(--color-accent-strong-rgb), 0.08));
    border: 1px solid rgba(255, 255, 255, 0.26);
    color: rgba(var(--color-deep-rgb), 0.82);
    backdrop-filter: blur(20px);
    box-shadow: 0 26px 48px -32px rgba(var(--color-deep-rgb), 0.3);
}

.booking-policy__label {
    font-size: 0.74rem;
    letter-spacing: 0.2rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.64);
}

.booking-policy__text {
    font-size: 0.84rem;
    line-height: 1.62;
    letter-spacing: 0.01rem;
}

.booking-actions {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.05rem;
}

.booking-form:not(.is-final-step) [data-step-submit],
.booking-form:not(.is-final-step) [data-step-note] {
    display: none !important;
}

.booking-form.is-final-step [data-step-next] {
    display: none !important;
}

.booking-actions__buttons {
    display: flex;
    align-items: stretch;
    gap: 0.75rem;
}

.booking-step-prev {
    flex: 0 0 150px;
    min-width: 140px;
    justify-content: center;
}

.booking-step-next,
.booking-submit {
    flex: 1 1 auto;
}

.booking-actions .btn-link {
    align-self: center;
}

.booking-fieldset {
    position: relative;
    border: 1px solid rgba(255, 255, 255, 0.24);
    border-radius: 20px;
    padding: 2.7rem 1.6rem 1.6rem;
    display: grid;
    gap: 1rem;
    background: rgba(255, 255, 255, 0.42);
    backdrop-filter: blur(20px);
    box-shadow: 0 24px 48px -30px rgba(var(--color-deep-rgb), 0.26);
}

.booking-fieldset legend {
    position: absolute;
    top: 0.75rem;
    left: 1.6rem;
    margin: 0;
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.9rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(var(--color-accent-light-rgb), 0.4));
    box-shadow: 0 12px 28px -20px rgba(var(--color-deep-rgb), 0.24);
    font-size: 0.82rem;
    letter-spacing: 0.18rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.68);
    z-index: 2;
}

.booking-toggle {
    display: flex;
    padding: 0.3rem;
    margin-top: 1rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.24);
    gap: 0.35rem;
    box-shadow: 0 20px 36px -28px rgba(var(--color-deep-rgb), 0.26);
    backdrop-filter: blur(18px);
}

.booking-payment {
    margin-top: 1.6rem;
    display: grid;
    gap: 1.2rem;
}

.booking-payment__toggle {
    margin-top: 1.6rem;
}

.booking-payment__details {
    display: grid;
    gap: 0.8rem;
}

.booking-payment__prepay {
    display: grid;
    gap: 0.8rem;
}

.booking-payment__details.is-hidden,
.booking-payment__prepay.is-hidden {
    display: none !important;
}

.booking-payment__note {
    margin: 0;
    padding: 0.95rem 1.15rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.26);
    box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.28);
    color: rgba(var(--color-deep-rgb), 0.78);
    font-size: 0.84rem;
    line-height: 1.65;
    backdrop-filter: blur(20px);
}

.booking-field-group {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.booking-service-controls {
    margin-top: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.booking-service-controls [data-extension-group-field] {
    order: 9;
}

.booking-service-controls [data-service-option-field] {
    order: 10;
}

.booking-service-controls [data-service-summary-field] {
    order: 11;
}

.booking-service-controls [data-dry-detail-field] {
    order: 12;
}

.hero-frame--stylebar .booking-service-controls [data-service-summary-field] > span,
.hero-frame[data-hero-card='quick'] .booking-service-controls [data-service-summary-field] > span {
    display: none;
}

.hero-frame--stylebar .booking-service-controls [data-service-summary-field] .field-description,
.hero-frame[data-hero-card='quick'] .booking-service-controls [data-service-summary-field] .field-description {
    margin-top: 0.35rem;
    font-size: 0.82rem;
    color: var(--ink-primary);
}

.field-description {
    margin-top: 0.4rem;
    font-size: 0.78rem;
    line-height: 1.5;
    color: var(--ink-muted);
}

.booking-service-controls [data-collapsible] {
    display: none;
    opacity: 0;
    transform: translateY(-8px);
    transform-origin: top;
    transition: opacity 0.28s ease, transform 0.28s ease;
    gap: 0.35rem;
}

.booking-service-controls [data-collapsible].is-visible {
    display: block;
    opacity: 1;
    transform: translateY(0);
}

.booking-service-controls [data-service-summary-field] .field-description {
    margin: 0;
    color: var(--ink-medium);
}

.booking-service-pricing {
    margin-top: 1rem;
    padding: 1rem 1.2rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.25);
    box-shadow: 0 24px 44px -34px rgba(var(--color-deep-rgb), 0.28);
}

.booking-service-pricing.booking-field {
    gap: 0.6rem;
}

.booking-service-pricing__label {
    font-size: 0.75rem;
    letter-spacing: 0.14rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.68);
}

.booking-service-pricing__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.25rem;
}

.booking-service-pricing__item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    padding: 0.3rem 0;
    color: var(--ink-medium);
}

.booking-service-pricing__item:first-child {
    padding-top: 0;
}

.booking-service-pricing__item:last-child {
    padding-bottom: 0;
}

.booking-service-pricing__label-text {
    font-size: 0.82rem;
    letter-spacing: 0.08rem;
    color: var(--ink-muted);
    text-transform: none;
}

.booking-service-pricing__item--base .booking-service-pricing__label-text {
    color: var(--ink-medium);
}

.booking-service-pricing__item--discount .booking-service-pricing__label-text {
    color: rgba(var(--color-accent-strong-rgb), 0.78);
}

.booking-service-pricing__value {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
    gap: 0.18rem;
}

.booking-service-pricing__value-amount {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--ink-strong);
}

.booking-service-pricing__item--discount .booking-service-pricing__value-amount {
    color: rgba(var(--color-accent-strong-rgb), 0.88);
}

.booking-service-pricing__item--total {
    border-top: 1px solid rgba(var(--color-deep-rgb), 0.12);
    margin-top: 0.6rem;
    padding-top: 0.9rem;
}

.booking-service-pricing__item--total .booking-service-pricing__value-amount {
    font-size: 1.06rem;
    color: rgba(var(--color-deep-rgb), 0.95);
}

.booking-service-pricing__value-meta {
    font-size: 0.75rem;
    letter-spacing: 0.04rem;
    color: var(--ink-muted);
}

.booking-service-pricing__item--discount .booking-service-pricing__value-meta {
    color: rgba(var(--color-accent-rgb), 0.82);
}

.booking-service-pricing__item--affiliate {
    margin-top: 0.45rem;
    padding: 0.55rem 0.6rem;
    border-radius: 0.75rem;
    background: rgba(var(--color-accent-light-rgb), 0.32);
}

.booking-service-pricing__item--affiliate .booking-service-pricing__label-text {
    color: rgba(var(--color-accent-strong-rgb), 0.92);
    font-weight: 600;
}

.booking-service-pricing__item--affiliate .booking-service-pricing__value-amount {
    color: rgba(var(--color-deep-rgb), 0.96);
}

.booking-service-pricing__item--affiliate .booking-service-pricing__value-meta {
    color: rgba(var(--color-accent-rgb), 0.78);
}

.booking-service-pricing__item--loading {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding: 0.9rem 1.1rem;
    min-height: 3rem;
    color: rgba(var(--color-accent-strong-rgb), 0.92);
}

.booking-service-pricing__loader {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.booking-service-pricing__loader span {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background-color: currentColor;
    opacity: 0.35;
    animation: bookingServicePricingDots 0.9s ease-in-out infinite;
}

.booking-service-pricing__loader span:nth-child(2) {
    animation-delay: 0.12s;
}

.booking-service-pricing__loader span:nth-child(3) {
    animation-delay: 0.24s;
}

.booking-service-pricing__loader-text {
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: -0.01em;
}

@keyframes bookingServicePricingDots {
    0%,
    100% {
        transform: translateY(0);
        opacity: 0.35;
    }
    50% {
        transform: translateY(-4px);
        opacity: 1;
    }
}

@media (max-width: 640px) {
    .booking-service-controls {
        gap: 0.9rem;
    }

    .booking-service-pricing__item {
        flex-direction: column;
        gap: 0.35rem;
        align-items: flex-start;
    }

    .booking-service-pricing__value {
        align-items: flex-start;
    }
}

body.pricing-page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    position: relative;
    overflow-x: hidden;
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    font-weight: 300;
}

body.pricing-page :where(div, h1, h2, h3, h4, h5, h6, p, span, a, li, button, label, small, strong, em, th, td) {
    font-family: inherit !important;
}

body.pricing-page strong,
body.pricing-page b {
    font-weight: 600 !important;
}

.pricing-header {
    position: sticky;
    top: 0;
    z-index: 20;
    backdrop-filter: blur(18px);
    background-image: linear-gradient(110deg, rgba(var(--color-header-light-rgb), 0.78), rgba(var(--color-header-rich-rgb), 0.92)), url("../images/backgrounds/header-marble.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-blend-mode: soft-light;
    border-bottom: 1px solid rgba(var(--color-header-rich-rgb), 0.45);
    color: rgba(var(--color-deep-rgb), 0.92);
    box-shadow: 0 12px 24px rgba(var(--color-deep-rgb), 0.08);
}

.pricing-header__inner {
    width: min(1120px, 92%);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.2rem 0.4rem;
    gap: 1.2rem;
}

.pricing-header__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    font-size: 0.78rem;
    color: rgba(var(--color-deep-rgb), 0.88);
    text-shadow: 0 2px 12px rgba(255, 255, 255, 0.48);
    transition: color 0.25s ease;
}

.pricing-header__brand:hover,
.pricing-header__brand:focus-visible {
    color: rgba(var(--color-deep-rgb), 1);
}

.pricing-header__logo {
    font-weight: 600;
    font-size: 0.92rem;
}

.pricing-header__nav {
    display: flex;
    gap: clamp(0.6rem, 2vw, 1.2rem);
    flex-wrap: wrap;
    justify-content: flex-end;
}

.pricing-header__nav a {
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-decoration: none;
    color: rgba(var(--color-deep-rgb), 0.75);
    padding: 0.2rem 0.1rem;
    position: relative;
    text-shadow: 0 2px 12px rgba(255, 255, 255, 0.45);
    transition: color 0.25s ease;
}

.pricing-header__nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -0.3rem;
    height: 1.5px;
    background: rgba(var(--color-deep-rgb), 0.82);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.25s ease;
}

.pricing-header__nav a:hover,
.pricing-header__nav a:focus-visible {
    color: rgba(var(--color-deep-rgb), 1);
}

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

.pricing-main {
    width: min(1120px, 92%);
    margin: 0 auto;
    padding: clamp(4.2rem, 9vw, 6.2rem) 0 clamp(5rem, 12vw, 8rem);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: clamp(3.6rem, 8vw, 5.6rem);
}

.pricing-hero {
    position: relative;
    text-align: center;
    padding: clamp(3.8rem, 8vw, 5.8rem) clamp(1rem, 4vw, 2.4rem);
    border-radius: clamp(28px, 4vw, 38px);
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(255, 255, 255, 0.52);
    box-shadow: 0 32px 60px -40px rgba(var(--color-deep-rgb), 0.35);
    backdrop-filter: blur(26px);
    color: rgba(var(--color-deep-rgb), 0.9);
    overflow: hidden;
}

.pricing-hero::before {
    content: "";
    position: absolute;
    inset: -30% -15% 10% -15%;
    background: linear-gradient(145deg, rgba(var(--color-accent-light-rgb), 0.35) 0%, rgba(var(--color-accent-rgb), 0.18) 45%, rgba(255, 255, 255, 0.35) 100%);
    opacity: 0.65;
    mix-blend-mode: screen;
    pointer-events: none;
    filter: blur(18px);
}

.pricing-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0.1) 100%);
    opacity: 0.7;
    pointer-events: none;
}

.pricing-hero__halo {
    position: absolute;
    inset: -50% -30% -30% -30%;
    background: radial-gradient(circle at 45% 45%, rgba(255, 255, 255, 0.55), transparent 68%);
    opacity: 0.6;
    filter: blur(30px);
    pointer-events: none;
}

.pricing-hero__eyebrow {
    position: relative;
    margin: 0 0 0.8rem;
    letter-spacing: 0.42em;
    text-transform: uppercase;
    font-size: 0.74rem;
    opacity: 0.76;
    color: rgba(var(--color-deep-rgb), 0.72);
}

.pricing-hero__title {
    position: relative;
    margin: 0.4rem 0 1.4rem;
    font-size: clamp(2.4rem, 6vw, 3.6rem);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.88);
    text-shadow: 0 6px 18px rgba(255, 255, 255, 0.4);
}

.pricing-hero__description {
    position: relative;
    margin: 0 auto;
    max-width: 640px;
    font-size: 0.98rem;
    line-height: 1.7;
    color: rgba(var(--color-deep-rgb), 0.68);
}

.pricing-section {
    display: flex;
    flex-direction: column;
    gap: clamp(1.6rem, 4vw, 2.4rem);
}

.pricing-section__header {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.pricing-section__header h2 {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: clamp(1.9rem, 4.5vw, 2.6rem);
    letter-spacing: 0.02em;
    color: rgba(var(--color-deep-rgb), 0.88);
}

.pricing-section__header p {
    margin: 0;
    font-size: 0.95rem;
    color: rgba(var(--color-deep-rgb), 0.64);
}

.pricing-section__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 0.75rem;
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    background: rgba(var(--color-accent-rgb), 0.16);
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.7);
}

.pricing-grid {
    display: grid;
    gap: clamp(1.4rem, 3.6vw, 2.4rem);
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.pricing-grid--three {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.pricing-card {
    padding: clamp(1.6rem, 3.2vw, 2.4rem);
    border-radius: clamp(20px, 3vw, 28px);
    background: rgba(255, 255, 255, 0.75);
    border: 1px solid rgba(255, 255, 255, 0.5);
    box-shadow: 0 28px 60px -40px rgba(var(--color-deep-rgb), 0.32);
    display: flex;
    flex-direction: column;
    gap: clamp(1.1rem, 2.5vw, 1.6rem);
    backdrop-filter: blur(16px);
}

.pricing-card--wide {
    display: grid;
    gap: clamp(1.4rem, 3vw, 2.2rem);
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.pricing-card__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.6rem;
}

.pricing-card__header h3 {
    margin: 0;
    font-size: clamp(1.2rem, 3.2vw, 1.6rem);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.8);
}

.pricing-item-group {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    padding: 0.6rem;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.48);
    border: 1px solid rgba(255, 255, 255, 0.4);
}

.pricing-card--wide .pricing-item-group {
    background: rgba(255, 255, 255, 0.6);
}

.pricing-item-group__title {
    margin: 0 0 0.4rem;
    font-size: 0.9rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.62);
}

.pricing-item {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    padding: 0.2rem 0;
}

.pricing-item__name {
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: rgba(var(--color-deep-rgb), 0.86);
}

.pricing-item__tiers {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 0.28rem;
}

.pricing-item__tiers li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    color: rgba(var(--color-deep-rgb), 0.7);
    background: rgba(255, 255, 255, 0.5);
    border-radius: 12px;
    padding: 0.45rem 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.6);
}

.pricing-item__tiers li strong {
    font-weight: 600;
    color: rgba(var(--color-deep-rgb), 0.82);
}

.pricing-notes {
    padding: clamp(1.8rem, 4vw, 2.6rem);
    border-radius: clamp(20px, 3vw, 28px);
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(255, 255, 255, 0.46);
    box-shadow: 0 20px 48px -35px rgba(var(--color-deep-rgb), 0.32);
}

.pricing-notes__title {
    margin: 0 0 1rem;
    font-family: "Playfair Display", serif;
    font-size: clamp(1.4rem, 3.6vw, 1.9rem);
    color: rgba(var(--color-deep-rgb), 0.84);
}

.pricing-notes__list {
    margin: 0;
    padding-left: 1.2rem;
    display: grid;
    gap: 0.6rem;
    font-size: 0.95rem;
    color: rgba(var(--color-deep-rgb), 0.68);
}

.pricing-cta {
    position: relative;
    display: grid;
    gap: 1.4rem;
    padding: clamp(2rem, 4.8vw, 3rem);
    border-radius: clamp(24px, 3.6vw, 34px);
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.52);
    box-shadow: 0 28px 60px -42px rgba(var(--color-deep-rgb), 0.3);
    backdrop-filter: blur(20px);
    color: rgba(var(--color-deep-rgb), 0.9);
    align-items: center;
    overflow: hidden;
}

.pricing-cta::before {
    content: "";
    position: absolute;
    inset: -40% -20% -20% -20%;
    background: radial-gradient(circle at 25% 25%, rgba(255, 255, 255, 0.6), transparent 65%),
                radial-gradient(circle at 80% 30%, rgba(var(--color-accent-light-rgb), 0.28), transparent 68%);
    opacity: 0.65;
    pointer-events: none;
    filter: blur(20px);
}

.pricing-cta::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0.12) 100%);
    mix-blend-mode: soft-light;
    pointer-events: none;
}

.pricing-cta__content {
    position: relative;
    display: grid;
    gap: 0.6rem;
    z-index: 1;
}

.pricing-cta__content h2 {
    margin: 0;
    font-size: clamp(1.6rem, 3.6vw, 2.2rem);
    letter-spacing: 0.06em;
    color: rgba(var(--color-deep-rgb), 0.88);
    text-shadow: 0 6px 18px rgba(255, 255, 255, 0.35);
}

.pricing-cta__content p {
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.7;
    color: rgba(var(--color-deep-rgb), 0.68);
}

.pricing-cta__actions {
    position: relative;
    display: flex;
    gap: clamp(0.6rem, 2.4vw, 1.2rem);
    flex-wrap: wrap;
    z-index: 1;
}

.pricing-cta .btn {
    min-width: 200px;
    justify-content: center;
}

.pricing-footer {
    text-align: center;
    padding: 2.4rem 0;
    font-size: 0.78rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.48);
}

@media (max-width: 860px) {
    .pricing-header__inner {
        flex-direction: column;
        align-items: flex-start;
    }

    .pricing-header__nav {
        justify-content: flex-start;
    }

    .pricing-hero__description {
        font-size: 0.94rem;
    }
}

@media (max-width: 600px) {
    .pricing-header {
        position: static;
    }

    .pricing-header__inner {
        padding: 1rem 0;
    }

    .pricing-hero {
        padding: 3.2rem 1.2rem;
    }

    .pricing-card__header h3 {
        letter-spacing: 0.08em;
    }

    .pricing-item__tiers li {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.2rem;
    }

    .pricing-cta__actions .btn {
        width: 100%;
    }
}

.booking-payment.field-error {
    border-color: rgba(var(--color-error-rgb), 0.78);
    border-width: 2px;
    box-shadow: 0 0 0 4px rgba(var(--color-error-rgb), 0.2), 0 20px 40px -26px rgba(var(--color-deep-rgb), 0.3);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-payment__note strong {
    color: rgba(var(--color-deep-rgb), 0.92);
    font-weight: 600;
    margin-right: 0.35rem;
}

.booking-payment__note--warning {
    color: #ff1744;
    font-weight: 700;
}

.booking-toggle label {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    cursor: pointer;
    font-size: 0.85rem;
    letter-spacing: 0.12rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.55);
}

.booking-toggle label span {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.45rem 0;
    border-radius: 999px;
    transition: background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
    min-height: 42px;
    letter-spacing: 0.2rem;
    background: rgba(255, 255, 255, 0.22);
    color: rgba(var(--color-deep-rgb), 0.7);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.booking-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.booking-toggle input:checked + span {
    background: rgba(255, 255, 255, 0.92);
    color: rgba(var(--color-deep-rgb), 0.88);
    box-shadow: 0 24px 40px -28px rgba(var(--color-deep-rgb), 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.booking-field {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    font-size: 0.85rem;
    letter-spacing: 0.05rem;
    transition: color 0.3s ease;
}

.booking-field span {
    text-transform: uppercase;
    letter-spacing: 0.16rem;
    font-size: 0.7rem;
    color: rgba(var(--color-deep-rgb), 0.7);
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.booking-field span em {
    font-style: normal;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    font-size: 0.9em;
    letter-spacing: 0;
    line-height: 1;
}

.btn-ghost--mini {
    padding: 0.5rem 1.2rem;
    font-size: 0.74rem;
    letter-spacing: 0.16rem;
}

.date-inline {
    display: grid;
    gap: 0.8rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: end;
}

.booking-field--compact {
    min-width: 0;
}

.booking-field--compact input,
.booking-field--compact select {
    width: 100%;
}

.booking-field--compact input[type="number"] {
    -moz-appearance: textfield;
}

.booking-field--compact input[type="number"]::-webkit-outer-spin-button,
.booking-field--compact input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.booking-field--wide select {
    width: 100%;
}

@media (max-width: 840px) {
    .date-inline {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    }
}

@media (max-width: 560px) {
    .date-inline {
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    }
}

@media (max-width: 480px) {
    .date-inline {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.6rem;
    }

    .date-inline .booking-field--compact span {
        font-size: 0.75rem;
        letter-spacing: 0.02em;
    }

    .date-inline .booking-field--compact input,
    .date-inline .booking-field--compact select {
        padding: 0.62rem 0.7rem;
        text-align: center;
    }

    .booking-cash-receipt__toggle {
        gap: 0.32rem;
        padding: 0.28rem;
    }

    .booking-cash-receipt__toggle label {
        padding: 0.36rem 0.65rem;
        font-size: 0.74rem;
        letter-spacing: 0.08rem;
    }

    .booking-cash-receipt__toggle label span {
        white-space: nowrap;
    }

    .booking-cash-receipt__toggle label input:checked + span {
        padding: 0.36rem 0.65rem;
    }

    .booking-actions__buttons {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.6rem;
        align-items: stretch;
    }

    .booking-actions__buttons > * {
        min-width: 0;
        width: 100%;
        flex: initial;
    }

    .booking-actions__buttons .booking-step-prev {
        grid-column: 1;
    }

    .booking-actions__buttons .booking-step-next,
    .booking-actions__buttons .booking-submit {
        grid-column: 2;
    }

    .booking-actions__buttons > *:only-child {
        grid-column: 1 / -1;
    }
}

.booking-field input,
.booking-field select,
.booking-field textarea {
    width: 100%;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.26);
    background: rgba(255, 255, 255, 0.22);
    color: rgba(var(--color-deep-rgb), 0.88);
    font-size: 0.9rem;
    padding: 0.78rem 1.05rem;
    font-family: "Noto Sans KR", "Pretendard", sans-serif;
    outline: none;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease;
    letter-spacing: 0.02rem;
    -webkit-appearance: none;
    box-shadow: 0 22px 40px -30px rgba(var(--color-deep-rgb), 0.26);
    backdrop-filter: blur(20px);
}

.booking-cash-receipt {
    align-items: end;
}

.booking-cash-receipt__toggle {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.4rem;
    padding: 0.32rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.26);
    background: rgba(255, 255, 255, 0.18);
    box-shadow: 0 18px 36px -28px rgba(var(--color-deep-rgb), 0.28);
    backdrop-filter: blur(18px);
}

.booking-cash-receipt__toggle label {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.42rem 0.9rem;
    border-radius: 999px;
    color: rgba(var(--color-deep-rgb), 0.62);
    font-size: 0.78rem;
    letter-spacing: 0.14rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

.booking-cash-receipt__toggle label input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.booking-cash-receipt__toggle label span {
    pointer-events: none;
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.booking-cash-receipt__toggle label input:checked + span {
    background: rgba(255, 255, 255, 0.94);
    color: rgba(var(--color-deep-rgb), 0.88);
    box-shadow: 0 22px 42px -28px rgba(var(--color-deep-rgb), 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.7);
    padding: 0.42rem 0.9rem;
    border-radius: 999px;
}

.booking-cash-receipt.is-hidden,
[data-cash-receipt-id].is-hidden {
    display: none !important;
}

.booking-field select option {
    background: #fde4d5;
    color: rgba(var(--color-deep-rgb), 0.85);
    font-weight: 500;
}

.booking-field select option:disabled {
    color: rgba(var(--color-deep-rgb), 0.4);
    background: #f2c8b7;
}

.booking-field input:focus,
.booking-field select:focus,
.booking-field textarea:focus {
    border-color: rgba(var(--color-accent-strong-rgb), 0.6);
    background: rgba(255, 255, 255, 0.32);
    box-shadow: 0 0 0 4px rgba(var(--color-accent-rgb), 0.18), 0 24px 44px -28px rgba(var(--color-deep-rgb), 0.32);
}

.booking-field input::placeholder,
.booking-field textarea::placeholder {
    color: rgba(var(--color-deep-rgb), 0.5);
}

.booking-field textarea {
    resize: vertical;
    min-height: 90px;
}

.booking-field.full {
    grid-column: 1 / -1;
}

@keyframes fieldErrorPulse {
    0% {
        box-shadow: 0 0 0 0 rgba(var(--color-error-rgb), 0);
    }
    45% {
        box-shadow: 0 0 0 6px rgba(var(--color-error-rgb), 0.28);
    }
    100% {
        box-shadow: 0 0 0 2px rgba(var(--color-error-rgb), 0.18);
    }
}

.booking-field .field-error,
.booking-field input.field-error,
.booking-field select.field-error,
.booking-field textarea.field-error {
    border-color: rgba(var(--color-error-rgb), 0.92) !important;
    border-width: 2px;
    background: rgba(255, 239, 239, 0.92);
    box-shadow: 0 0 0 4px rgba(var(--color-error-rgb), 0.22), 0 18px 32px -22px rgba(var(--color-error-rgb), 0.25);
    animation: fieldErrorPulse 0.48s ease;
}

.booking-field.field-error > span {
    color: rgba(var(--color-error-rgb), 0.9);
}

.booking-field.field-error > span em {
    color: rgba(var(--color-error-rgb), 0.95);
}

.booking-consent {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem;
    padding: 0.78rem 1.45rem;
    width: 100%;
    border-radius: 22px;
    border: 1px solid rgba(var(--color-accent-rgb), 0.34);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(var(--color-accent-light-rgb), 0.46));
    box-shadow: 0 22px 42px -28px rgba(var(--color-deep-rgb), 0.3);
    font-size: 0.82rem;
    letter-spacing: 0.06rem;
    color: rgba(var(--color-deep-rgb), 0.7);
    flex-wrap: wrap;
    cursor: pointer;
    transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease, transform 0.3s ease;
}

.booking-consent:hover,
.booking-consent:focus-within {
    border-color: rgba(var(--color-accent-strong-rgb), 0.52);
    box-shadow: 0 26px 54px -28px rgba(var(--color-deep-rgb), 0.36);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(var(--color-accent-light-rgb), 0.58));
    transform: translateY(-1px);
}

.booking-consent input {
    appearance: none;
    width: 22px;
    height: 22px;
    border-radius: 7px;
    border: 1.5px solid rgba(var(--color-accent-rgb), 0.45);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(var(--color-accent-light-rgb), 0.46));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 10px 22px -16px rgba(var(--color-deep-rgb), 0.32);
    display: grid;
    place-items: center;
    cursor: pointer;
    transition: border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease;
}

.booking-consent input::after {
    content: "";
    width: 10px;
    height: 6px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(-45deg) scale(0);
    transform-origin: center;
    transition: transform 0.2s ease;
}

.booking-consent input:checked {
    border-color: rgba(var(--color-accent-strong-rgb), 0.65);
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.95), rgba(var(--color-accent-strong-rgb), 0.92));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8), 0 12px 26px -16px rgba(var(--color-deep-rgb), 0.34);
}

.booking-consent input:checked::after {
    transform: rotate(-45deg) scale(1);
}

.booking-consent span {
    flex: 1 1 auto;
    min-width: 180px;
    color: rgba(var(--color-deep-rgb), 0.8);
    font-size: 0.84rem;
    letter-spacing: 0.08rem;
}

.booking-consent .privacy-link {
    flex: 0 0 auto;
    color: rgba(var(--color-deep-rgb), 0.78);
    text-decoration: underline;
    text-decoration-color: rgba(var(--color-accent-rgb), 0.5);
    font-size: 0.78rem;
    font-weight: 600;
}

.booking-consent .privacy-link:hover {
    color: rgba(var(--color-deep-rgb), 0.92);
    text-decoration-color: rgba(var(--color-accent-strong-rgb), 0.7);
}

.booking-actions {
    display: flex;
    gap: 0.8rem;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}

.booking-note {
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.85);
    letter-spacing: 0.08rem;
    margin: 0.4rem 0 0;
}

.booking-feedback {
    margin-top: 1.2rem;
    font-size: 0.85rem;
    letter-spacing: 0.04rem;
    text-align: center;
    color: var(--ink-strong);
    min-height: 1.2rem;
}

.hero-frame:not(.expanded) .booking-feedback {
    display: none;
}

.hero-frame.expanded .booking-feedback {
    display: block;
    margin-top: 1rem;
}
.hero-ribbon {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(var(--color-accent-rgb), 0.4);
    box-shadow: 0 26px 55px -32px rgba(var(--color-deep-rgb), 0.3);
    backdrop-filter: blur(14px);
    font-size: 0.78rem;
    letter-spacing: 0.26rem;
    text-transform: uppercase;
    color: var(--ink-medium);
    margin-top: 0.6rem;
}

.hero-ribbon span {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 500;
}

.section-header {
    text-align: center;
    margin-bottom: 3.2rem;
}

.pricing .section-header {
    width: min(100%, 560px);
    margin-inline: auto;
}

.section-eyebrow {
    display: inline-block;
    font-size: 0.75rem;
    letter-spacing: 0.35rem;
    text-transform: uppercase;
    color: var(--ink-muted);
}

.section-header h2 {
    margin-top: 0.7rem;
    font-size: clamp(1.9rem, 4vw, 2.7rem);
    font-family: "Playfair Display", serif;
    color: var(--color-brown);
    letter-spacing: 0.12rem;
}

.section-header h2 .heading-thin {
    font-family: "Pretendard", "Noto Sans KR", sans-serif;
    font-weight: 300;
    letter-spacing: 0.16rem;
    color: inherit;
}

.section-header p {
    max-width: 620px;
    margin: 0.9rem auto 0;
    color: var(--ink-medium);
}

.section-header .pricing-lead {
    font-weight: 500;
    color: var(--ink-strong);
}

.brand-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 2rem;
}

.brand-card {
    background: linear-gradient(150deg, rgba(var(--color-ivory-rgb), 0.9), rgba(var(--color-accent-soft-rgb), 0.95));
    border: 1px solid rgba(var(--color-accent-rgb), 0.45);
    border-radius: 22px;
    padding: 2.2rem;
    box-shadow: 0 28px 60px -48px rgba(var(--color-deep-rgb), 0.24);
    backdrop-filter: blur(14px);
}

.about {
    background: linear-gradient(140deg, rgba(var(--color-ivory-rgb), 0.96) 0%, rgba(var(--color-accent-light-rgb), 0.48) 48%, rgba(var(--color-accent-soft-rgb), 0.34) 100%);
    overflow: hidden;
}

.about::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 18% 12%, rgba(255, 255, 255, 0.65), transparent 65%),
                radial-gradient(circle at 86% 92%, rgba(var(--color-accent-strong-rgb), 0.22), transparent 75%);
    pointer-events: none;
    opacity: 0.9;
    z-index: 0;
}

.about .container {
    position: relative;
    z-index: 1;
}

.about-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
    gap: clamp(2.8rem, 6vw, 4.2rem);
    align-items: start;
}

.about-overview {
    display: grid;
    gap: clamp(1.4rem, 3vw, 2rem);
}

.about-title {
    font-size: clamp(2.1rem, 4.5vw, 3rem);
    font-family: "Pretendard", "Noto Sans KR", sans-serif;
    font-weight: 300;
    letter-spacing: 0.08rem;
    color: rgba(var(--color-deep-rgb), 0.72);
    margin: 0;
}

.about-lead {
    margin: 0;
    color: var(--ink-medium);
    font-size: 1.05rem;
    line-height: 1.9;
}

.about-story {
    display: grid;
    gap: 1.1rem;
    color: var(--ink-medium);
}

.about-story-group {
    padding: 1.4rem 1.6rem;
    background: rgba(255, 255, 255, 0.64);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.42);
    border-radius: 20px;
    box-shadow: 0 22px 46px -36px rgba(var(--color-deep-rgb), 0.35);
}

.about-story-group h3 {
    margin: 0 0 0.6rem;
    font-size: 1.08rem;
    font-weight: 600;
    color: var(--color-brown);
    letter-spacing: 0.08rem;
}

.about-signature {
    display: grid;
    gap: 1.6rem;
    background: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.35);
    border-radius: clamp(28px, 6vw, 40px);
    padding: clamp(1.9rem, 4vw, 2.6rem);
    box-shadow: 0 34px 68px -44px rgba(var(--color-deep-rgb), 0.35);
    backdrop-filter: blur(16px);
}

.about-brand-card {
    display: grid;
    gap: 0.8rem;
}

.about-brand-label {
    font-size: 0.82rem;
    letter-spacing: 0.24rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.45);
}

.about-brand-name {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 1.9rem;
    color: rgba(var(--color-deep-rgb), 0.88);
}

.about-brand-meta {
    margin: 0;
    font-size: 0.92rem;
    color: rgba(var(--color-deep-rgb), 0.58);
    letter-spacing: 0.08rem;
}

.about-brand-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.5rem;
}

.about-brand-list li {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    color: var(--ink-medium);
    font-size: 0.96rem;
}

.about-brand-list li::before {
    content: "•";
    color: rgba(var(--color-accent-strong-rgb), 0.72);
    font-size: 1.2rem;
    line-height: 1;
}

.about-details {
    margin: 0;
    display: grid;
    gap: 0.8rem;
}

.about-details div {
    display: flex;
    justify-content: space-between;
    gap: 1.4rem;
    font-size: 0.94rem;
    color: var(--ink-medium);
}

.about-details dt {
    font-weight: 600;
    letter-spacing: 0.08rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.58);
}

.about-details dd {
    margin: 0;
}

.about-cta {
    justify-self: start;
}

.services {
    background: linear-gradient(180deg, rgba(var(--color-ivory-rgb), 0.95) 0%, rgba(var(--color-accent-soft-rgb), 0.32) 100%);
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: clamp(1.8rem, 4vw, 2.6rem);
    margin-top: clamp(2.6rem, 5vw, 3.6rem);
}

.service-card {
    position: relative;
    display: grid;
    gap: 1.1rem;
    padding: clamp(1.9rem, 4.6vw, 2.4rem);
    border-radius: 26px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.88) 0%, rgba(var(--color-accent-soft-rgb), 0.3) 100%);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.46);
    box-shadow: 0 32px 70px -46px rgba(var(--color-deep-rgb), 0.32);
    backdrop-filter: blur(16px);
}

.service-card__icon {
    width: 54px;
    height: 54px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(var(--color-accent-strong-rgb), 0.18);
    color: rgba(var(--color-accent-strong-rgb), 0.88);
    font-size: 1.4rem;
}

.service-card__title {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 1.36rem;
    color: var(--color-brown);
}

.service-card__desc {
    margin: 0;
    color: var(--ink-medium);
    font-size: 0.98rem;
    line-height: 1.7;
}

.service-card__list {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.45rem;
    color: var(--ink-muted);
    font-size: 0.92rem;
}

.service-promise {
    margin-top: clamp(3.2rem, 6vw, 4.4rem);
    padding: clamp(2rem, 5vw, 3rem);
    border-radius: 32px;
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.32), rgba(var(--color-accent-rgb), 0.24));
    border: 1px solid rgba(var(--color-accent-rgb), 0.3);
    box-shadow: 0 32px 70px -44px rgba(var(--color-deep-rgb), 0.32);
    text-align: center;
    display: grid;
    gap: 1.2rem;
}

.service-promise h3 {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: clamp(1.6rem, 3.5vw, 2.1rem);
    color: rgba(var(--color-deep-rgb), 0.86);
}

.service-promise p {
    margin: 0 auto;
    max-width: 640px;
    color: var(--ink-medium);
}

.service-promise__actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
    flex-wrap: wrap;
}

.pricing {
    position: relative;
    background: linear-gradient(180deg, rgba(var(--color-ivory-rgb), 0.96) 0%, rgba(var(--color-accent-light-rgb), 0.38) 55%, rgba(var(--color-accent-soft-rgb), 0.2) 100%);
    overflow: hidden;
}

.pricing::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 20% 12%, rgba(255, 255, 255, 0.65), transparent 70%),
                radial-gradient(circle at 82% 88%, rgba(var(--color-accent-strong-rgb), 0.18), transparent 75%);
    pointer-events: none;
    opacity: 0.85;
}

.pricing .container {
    position: relative;
    z-index: 1;
}

.pricing-header {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: clamp(2.2rem, 5vw, 3.6rem);
    align-items: stretch;
    justify-content: center;
    justify-items: center;
}

.pricing-gallery {
    margin-top: clamp(2.4rem, 5vw, 3.4rem);
    margin-bottom: clamp(1.8rem, 4vw, 2.6rem);
    transition: opacity 0.45s ease;
}

.pricing-gallery__surface {
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    padding: clamp(0.8rem, 1.8vw, 1.4rem) 0;
    background: linear-gradient(135deg, rgba(var(--color-accent-light-rgb), 0.24), rgba(var(--color-accent-soft-rgb), 0.18));
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.32);
    box-shadow: 0 36px 76px -48px rgba(var(--color-deep-rgb), 0.26);
    backdrop-filter: blur(12px);
}

.pricing-gallery__surface::before,
.pricing-gallery__surface::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: clamp(60px, 10vw, 160px);
    z-index: 2;
    pointer-events: none;
}

.pricing-gallery__surface::before {
    left: 0;
    background: linear-gradient(90deg, rgba(var(--color-ivory-rgb), 0.86), rgba(var(--color-ivory-rgb), 0));
}

.pricing-gallery__surface::after {
    right: 0;
    background: linear-gradient(270deg, rgba(var(--color-ivory-rgb), 0.86), rgba(var(--color-ivory-rgb), 0));
}

.pricing-gallery__track {
    display: flex;
    gap: clamp(1.1rem, 2vw, 1.8rem);
    width: max-content;
    animation: pricing-gallery-scroll var(--pricing-gallery-duration, 70s) linear infinite;
    will-change: transform;
}

.pricing-gallery__item {
    flex: 0 0 clamp(180px, 18vw, 220px);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 26px 46px -30px rgba(var(--color-deep-rgb), 0.26);
    background: rgba(255, 255, 255, 0.32);
}

.pricing-gallery__item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

@keyframes pricing-gallery-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@media (max-width: 960px) {
    .pricing-gallery {
        margin-top: clamp(2rem, 6vw, 3rem);
        margin-bottom: clamp(1.4rem, 4vw, 2.2rem);
    }

    .pricing-gallery__surface {
        border-radius: 26px;
        padding: 0.8rem 0;
    }

    .pricing-gallery__item {
        flex: 0 0 clamp(160px, 40vw, 200px);
    }
}

@media (max-width: 640px) {
    .pricing-gallery__surface::before,
    .pricing-gallery__surface::after {
        width: clamp(40px, 18vw, 80px);
    }

    .pricing-gallery__item {
        flex: 0 0 clamp(140px, 58vw, 180px);
        border-radius: 20px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .pricing-gallery__track {
        animation: none;
    }
}

.pricing-highlight {
    background: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.4);
    border-radius: 30px;
    padding: clamp(1.8rem, 4vw, 2.5rem);
    box-shadow: 0 32px 70px -46px rgba(var(--color-deep-rgb), 0.28);
    backdrop-filter: blur(12px);
    width: min(100%, 560px);
}

.pricing-highlight h3 {
    margin: 0 0 1rem;
    font-family: "Playfair Display", serif;
    font-size: 1.4rem;
    color: var(--color-brown);
}

.pricing-highlight ul {
    margin: 0;
    padding-left: 1.2rem;
    color: var(--ink-medium);
    display: grid;
    gap: 0.5rem;
    font-size: 0.95rem;
}

.pricing-highlight__note {
    margin: 1.2rem 0 0;
    color: rgba(var(--color-accent-strong-rgb), 0.82);
    font-weight: 500;
}

.pricing-info {
    margin-top: clamp(2.2rem, 5vw, 3.2rem);
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: clamp(1.4rem, 3vw, 2.4rem);
}

.pricing-info__card {
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.36);
    border-radius: 28px;
    padding: clamp(1.6rem, 4vw, 2.2rem);
    box-shadow: 0 28px 60px -44px rgba(var(--color-deep-rgb), 0.28);
    backdrop-filter: blur(10px);
    height: 100%;
}

.pricing-info__card h3 {
    margin: 0 0 0.8rem;
    font-size: 1.2rem;
    font-family: "Playfair Display", serif;
    color: var(--color-brown);
}

.pricing-info__list {
    margin: 0;
    padding-left: 1.1rem;
    display: grid;
    gap: 0.45rem;
    color: var(--ink-medium);
    font-size: 0.97rem;
}

.pricing-men-services {
    margin-top: clamp(2.6rem, 5vw, 3.6rem);
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.34);
    border-radius: 28px;
    padding: clamp(1.8rem, 4vw, 2.4rem);
    box-shadow: 0 30px 64px -46px rgba(var(--color-deep-rgb), 0.3);
    backdrop-filter: blur(10px);
}

.pricing-men-services h3 {
    margin: 0;
    font-family: "Playfair Display", serif;
    font-size: 1.25rem;
    color: var(--color-brown);
}

.pricing-men-services__lead {
    margin: 0.6rem 0 0;
    color: var(--ink-medium);
}

.pricing-men-services__list {
    margin: 1.2rem 0 0;
    padding: 0;
    list-style: none;
    column-width: 220px;
    column-gap: 1.6rem;
    color: var(--ink-medium);
}

.pricing-men-services__list li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 0.35rem;
    break-inside: avoid;
}

.pricing-men-services__list li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0;
    color: rgba(var(--color-accent-strong-rgb), 0.8);
}

.pricing-discount {
    margin-top: clamp(2.4rem, 5vw, 3.4rem);
    background: linear-gradient(135deg, rgba(var(--color-accent-light-rgb), 0.28), rgba(255, 255, 255, 0.85));
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.38);
    border-radius: 28px;
    padding: clamp(1.8rem, 4vw, 2.4rem);
    box-shadow: 0 32px 68px -48px rgba(var(--color-deep-rgb), 0.3);
    backdrop-filter: blur(10px);
}

.pricing-discount h3 {
    margin: 0 0 1rem;
    font-family: "Playfair Display", serif;
    font-size: 1.25rem;
    color: var(--color-brown);
}

.pricing-discount__list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.65rem;
}

.pricing-discount__item-name {
    font-weight: 600;
    color: var(--color-brown);
}

.pricing-discount__item-price {
    font-weight: 500;
    color: var(--ink-medium);
    display: inline-block;
    margin-left: 0.6rem;
}

.pricing-discount__item-price strong {
    color: rgba(var(--color-accent-strong-rgb), 0.95);
}

.service-promise__lead {
    margin: 0.4rem 0 1.2rem;
    font-weight: 500;
    color: var(--ink-medium);
}

.service-promise__list {
    margin: 0 0 1.8rem;
    padding-left: 1.1rem;
    color: var(--ink-medium);
    display: grid;
    gap: 0.55rem;
    font-size: 0.97rem;
}

@media (max-width: 640px) {
    .pricing-info {
        grid-template-columns: 1fr;
    }

    .pricing-men-services__list {
        column-count: 1;
        column-width: auto;
    }
}

.contact {
    background: linear-gradient(180deg, rgba(var(--color-ivory-rgb), 0.92) 0%, rgba(var(--color-accent-light-rgb), 0.4) 60%, rgba(var(--color-accent-soft-rgb), 0.32) 100%);
}

.contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
    gap: clamp(2.4rem, 6vw, 3.6rem);
}

.contact-panel,
.contact-aside {
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(var(--color-accent-soft-rgb), 0.4);
    border-radius: 30px;
    padding: clamp(2rem, 5vw, 2.8rem);
    box-shadow: 0 30px 70px -48px rgba(var(--color-deep-rgb), 0.3);
    backdrop-filter: blur(14px);
}

.contact-panel h2 {
    margin-top: 0.6rem;
    font-size: clamp(1.9rem, 4vw, 2.6rem);
    font-family: "Playfair Display", serif;
    color: var(--color-brown);
}

.contact-panel p {
    color: var(--ink-medium);
}

.contact-list {
    margin: 1.4rem 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 1rem;
}

.contact-label {
    display: block;
    font-size: 0.78rem;
    letter-spacing: 0.24rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.45);
    margin-bottom: 0.35rem;
}

.contact-list a {
    color: var(--color-brown);
    font-weight: 600;
    text-decoration: none;
}

.contact-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 2rem;
}

.contact-highlight-card {
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.46), rgba(var(--color-accent-rgb), 0.3));
    border-radius: 24px;
    padding: clamp(1.6rem, 4vw, 2.2rem);
    color: rgba(var(--color-deep-rgb), 0.85);
    display: grid;
    gap: 0.9rem;
}

.contact-highlight-title {
    font-size: 0.84rem;
    letter-spacing: 0.28rem;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.94);
}

.contact-highlight-list {
    margin: 0;
    padding-left: 1.2rem;
    color: rgba(255, 255, 255, 0.9);
    display: grid;
    gap: 0.5rem;
    font-size: 0.95rem;
}

.contact-highlight-list li::marker {
    color: rgba(255, 255, 255, 0.9);
}

.contact-avail {
    margin-top: clamp(1.6rem, 4vw, 2.4rem);
    display: grid;
    gap: 0.8rem;
    color: var(--ink-medium);
}

.contact-avail h3 {
    margin: 0;
    font-family: "Playfair Display", serif;
    color: var(--color-brown);
}

.contact-avail .btn {
    justify-self: start;
}

@media (max-width: 1024px) {
    .about-grid,
    .pricing-header,
    .contact-grid {
        grid-template-columns: 1fr;
    }

    .pricing-highlight,
    .contact-aside,
    .about-signature {
        justify-self: stretch;
    }
}

@media (max-width: 720px) {
    .service-promise__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .about-details div {
        flex-direction: column;
        align-items: flex-start;
    }
}

.price-card {
    position: relative;
    display: grid;
    gap: clamp(0.75rem, 1.8vw, 1rem);
    padding: clamp(1.9rem, 3vw, 2.2rem) clamp(1.5rem, 2.6vw, 1.9rem);
    border-radius: 26px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.16);
    box-shadow: 0 36px 72px -40px rgba(var(--color-deep-rgb), 0.32);
    backdrop-filter: blur(14px);
    overflow: hidden;
    isolation: isolate;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.price-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.26) 0%, rgba(255, 255, 255, 0.12) 54%, rgba(0, 0, 0, 0.14) 100%);
    mix-blend-mode: screen;
    pointer-events: none;
    opacity: 0.6;
}

.price-card::after {
    content: "";
    position: absolute;
    inset: 14px;
    border-radius: calc(26px - 14px);
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.32), transparent 72%);
    pointer-events: none;
    opacity: 0.7;
}

.price-card > * {
    position: relative;
    z-index: 1;
}

.price-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 46px 90px -38px rgba(var(--color-deep-rgb), 0.36);
}

.price-card header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}

.price-card h3 {
    margin: 0;
    font-size: 1.08rem;
    letter-spacing: 0.02rem;
}

.price-card .badge {
    font-size: 0.78rem;
    padding: 0.32rem 0.9rem;
    border-radius: 999px;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
    font-weight: 600;
}

.price-card .time {
    font-size: 0.82rem;
    letter-spacing: 0.12rem;
    text-transform: uppercase;
}

.price-card .price {
    display: flex;
    gap: clamp(0.65rem, 1.6vw, 0.9rem);
    align-items: baseline;
}

.price-card .price-original {
    text-decoration: line-through;
    font-size: 0.95rem;
}

.price-card .price-current {
    font-size: 1.42rem;
    font-weight: 600;
    letter-spacing: 0.04rem;
}

.price-card .desc {
    font-size: 0.95rem;
    line-height: 1.55;
}

.price-card[data-group="men"] {
    background: linear-gradient(162deg, rgba(22, 29, 48, 0.98) 0%, rgba(32, 43, 68, 0.96) 48%, rgba(46, 62, 96, 0.94) 100%);
    border: 1px solid rgba(92, 118, 168, 0.5);
    box-shadow: 0 40px 88px -46px rgba(9, 14, 26, 0.65);
    color: rgba(230, 237, 255, 0.95);
}

.price-card[data-group="men"]::before {
    opacity: 0.68;
    background: linear-gradient(155deg, rgba(255, 255, 255, 0.28) 0%, rgba(255, 255, 255, 0.12) 54%, rgba(43, 62, 98, 0.22) 100%);
}

.price-card[data-group="men"] h3 {
    color: rgba(240, 244, 255, 0.98);
}

.price-card[data-group="men"] .badge {
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.85), rgba(183, 203, 247, 0.65));
    color: rgba(24, 34, 58, 0.88);
    border: 1px solid rgba(183, 203, 247, 0.6);
    box-shadow: 0 18px 32px -22px rgba(9, 14, 26, 0.5);
}

.price-card[data-group="men"] .time {
    color: rgba(198, 208, 234, 0.74);
}

.price-card[data-group="men"] .price-original {
    color: rgba(210, 220, 240, 0.45);
}

.price-card[data-group="men"] .price-current {
    color: #f2f6ff;
    text-shadow: 0 14px 26px rgba(6, 11, 22, 0.45);
}

.price-card[data-group="men"] .desc {
    color: rgba(210, 220, 240, 0.84);
}

.price-card[data-group="women"] {
    background: linear-gradient(162deg, rgba(255, 224, 213, 0.98) 0%, rgba(246, 181, 156, 0.96) 46%, rgba(231, 139, 114, 0.94) 100%);
    border: 1px solid rgba(231, 139, 114, 0.45);
    box-shadow: 0 38px 88px -48px rgba(190, 103, 74, 0.42);
    color: rgba(94, 44, 30, 0.9);
}

.price-card[data-group="women"] h3 {
    color: rgba(94, 44, 30, 0.92);
}

.price-card[data-group="women"] .badge {
    background: linear-gradient(135deg, rgba(255, 245, 240, 0.88), rgba(248, 202, 186, 0.6));
    color: rgba(133, 55, 38, 0.8);
    border: 1px solid rgba(248, 202, 186, 0.7);
    box-shadow: 0 18px 32px -22px rgba(167, 87, 60, 0.32);
}

.price-card[data-group="women"] .time {
    color: rgba(117, 62, 45, 0.58);
}

.price-card[data-group="women"] .price-original {
    color: rgba(117, 62, 45, 0.4);
}

.price-card[data-group="women"] .price-current {
    color: rgba(171, 74, 50, 0.98);
    text-shadow: 0 14px 28px rgba(171, 74, 50, 0.28);
}

.price-card[data-group="women"] .desc {
    color: rgba(117, 62, 45, 0.72);
}

/* Marble background treatments for men's pricing cards */
#pricing-men .price-card {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#pricing-men .price-card:nth-child(1) {
    background: linear-gradient(162deg, rgba(10, 24, 36, 0.82) 0%, rgba(18, 46, 54, 0.76) 46%, rgba(28, 62, 66, 0.84) 100%),
        url("../images/textures/men-01.jpg") center / cover no-repeat;
}

#pricing-men .price-card:nth-child(2) {
    background: linear-gradient(164deg, rgba(12, 26, 38, 0.82) 0%, rgba(24, 52, 58, 0.78) 44%, rgba(36, 68, 72, 0.88) 100%),
        url("../images/textures/men-02.jpg") center / cover no-repeat;
}

#pricing-men .price-card:nth-child(3) {
    background: linear-gradient(164deg, rgba(10, 26, 36, 0.82) 0%, rgba(22, 54, 64, 0.78) 48%, rgba(34, 70, 78, 0.86) 100%),
        url("../images/textures/men-03.jpg") center / cover no-repeat;
}

#pricing-men .price-card:nth-child(4) {
    background: linear-gradient(166deg, rgba(12, 24, 36, 0.82) 0%, rgba(24, 46, 58, 0.78) 44%, rgba(32, 62, 72, 0.86) 100%),
        url("../images/textures/men-04.jpg") center / cover no-repeat;
}

#pricing-men .price-card:nth-child(5) {
    background: linear-gradient(168deg, rgba(10, 22, 34, 0.82) 0%, rgba(20, 48, 56, 0.76) 40%, rgba(30, 66, 72, 0.88) 100%),
        url("../images/textures/men-05.jpg") center / cover no-repeat;
}

#pricing-women .price-card {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

#pricing-women .price-card:nth-child(1) {
    background: linear-gradient(162deg, rgba(255, 238, 230, 0.92) 0%, rgba(255, 215, 199, 0.88) 46%, rgba(241, 176, 150, 0.8) 100%),
        url("../images/textures/women-01.jpg") center / cover no-repeat;
}

#pricing-women .price-card:nth-child(2) {
    background: linear-gradient(164deg, rgba(255, 236, 226, 0.92) 0%, rgba(255, 212, 196, 0.88) 44%, rgba(240, 172, 148, 0.8) 100%),
        url("../images/textures/women-02.jpg") center / cover no-repeat;
}

#pricing-women .price-card:nth-child(3) {
    background: linear-gradient(164deg, rgba(255, 234, 224, 0.92) 0%, rgba(255, 209, 195, 0.88) 48%, rgba(238, 170, 148, 0.8) 100%),
        url("../images/textures/women-03.jpg") center / cover no-repeat;
}

#pricing-women .price-card:nth-child(4) {
    background: linear-gradient(166deg, rgba(255, 234, 224, 0.92) 0%, rgba(255, 208, 192, 0.86) 44%, rgba(236, 168, 146, 0.8) 100%),
        url("../images/textures/women-04.jpg") center / cover no-repeat;
}

#pricing-women .price-card:nth-child(5) {
    background: linear-gradient(168deg, rgba(255, 234, 224, 0.92) 0%, rgba(255, 210, 194, 0.86) 40%, rgba(238, 172, 152, 0.8) 100%),
        url("../images/textures/women-05.jpg") center / cover no-repeat;
}

.brand-card h3 {
    font-size: 1.22rem;
    font-family: "Playfair Display", serif;
    color: var(--color-brown);
    margin-bottom: 0.9rem;
}

.brand-card ul,
.brand-card p {
    margin: 0;
    color: var(--ink-medium);
}

.brand-card ul {
    padding-left: 1.2rem;
    display: grid;
    gap: 0.45rem;
}

.service-columns {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 2.4rem;
}

.pricing-gallery-toggle {
    display: flex;
    justify-content: center;
    margin-top: clamp(1.8rem, 4vw, 2.4rem);
}

.portfolio-toggle-btn {
    appearance: none;
    border: 1px solid transparent;
    padding: 1rem 3rem;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(68, 42, 34, 0.92), rgba(136, 90, 70, 0.88));
    color: #fff8f1;
    font-size: 0.95rem;
    letter-spacing: 0.12rem;
    text-transform: uppercase;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 22px 44px -30px rgba(var(--color-deep-rgb), 0.48);
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease, color 0.25s ease, filter 0.25s ease;
    width: min(100%, 360px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
}

.portfolio-toggle-btn:hover {
    transform: translateY(-1px);
    filter: brightness(1.02);
}

.portfolio-toggle-btn:focus-visible {
    outline: 2px solid rgba(var(--color-accent-strong-rgb), 0.5);
    outline-offset: 4px;
}

.portfolio-toggle-btn.is-collapsed {
    background: rgba(255, 255, 255, 0.88);
    color: rgba(var(--color-deep-rgb), 0.72);
    box-shadow: 0 18px 40px -30px rgba(var(--color-deep-rgb), 0.38);
    border-color: rgba(var(--color-accent-strong-rgb), 0.2);
}

.portfolio-toggle-btn.is-collapsed:hover {
    filter: brightness(1.05);
}

.portfolio-toggle-btn:disabled {
    cursor: not-allowed;
    opacity: 0.6;
    transform: none;
    filter: none;
}

.pricing-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 0.55rem;
    border-radius: 999px;
    width: min(100%, 640px);
    margin: clamp(2rem, 4vw, 2.6rem) auto 0;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(var(--color-accent-strong-rgb), 0.18);
    box-shadow: 0 18px 40px -28px rgba(var(--color-deep-rgb), 0.24);
    backdrop-filter: blur(8px);
}

.toggle-btn {
    flex: 1 1 50%;
    border: none;
    padding: 1rem 0;
    border-radius: 999px;
    background: transparent;
    color: rgba(var(--color-deep-rgb), 0.6);
    font-size: 0.95rem;
    letter-spacing: 0.22rem;
    text-transform: uppercase;
    cursor: pointer;
    transition: color 0.25s ease, background 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
    position: relative;
    isolation: isolate;
    font-weight: 600;
}

.toggle-btn:not(.active)::after {
    content: "";
    position: absolute;
    left: calc(100% - 1px);
    top: 22%;
    height: 56%;
    width: 1px;
    background: linear-gradient(180deg, rgba(var(--color-accent-strong-rgb), 0.16), rgba(var(--color-accent-strong-rgb), 0.04));
    pointer-events: none;
}

.toggle-btn:last-child::after {
    display: none;
}

.toggle-btn:hover {
    color: rgba(var(--color-deep-rgb), 0.7);
}

.toggle-btn:focus-visible {
    outline: 2px solid rgba(var(--color-accent-strong-rgb), 0.4);
    outline-offset: 4px;
}

.toggle-btn.active {
    transform: translateY(-1px);
    color: #fff8ef;
}

.toggle-btn[data-target="men"].active {
    background: linear-gradient(135deg, #1a2340, #24345a);
    box-shadow: 0 22px 40px -24px rgba(11, 16, 30, 0.55);
    color: rgba(240, 245, 255, 0.98);
}

.toggle-btn[data-target="women"].active {
    background: linear-gradient(135deg, #f5c6b3, #e4957b);
    color: rgba(85, 41, 28, 0.92);
    box-shadow: 0 22px 40px -24px rgba(193, 108, 76, 0.4);
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: clamp(1.8rem, 4vw, 2.4rem);
    margin-top: clamp(2.4rem, 5vw, 3rem);
}

.pricing-note {
    margin-top: 2.4rem;
    text-align: center;
    font-size: 0.9rem;
    color: rgba(var(--color-deep-rgb), 0.58);
}


.hidden {
    display: none;
}

.contact-layout {
    display: block;
}

.contact-brand {
    margin-bottom: 3.4rem;
}

.contact-logo {
    max-width: 220px;
    width: 100%;
    height: auto;
    display: block;
    margin: 0 0 1.6rem;
    border-radius: 14px;
    box-shadow: 0 24px 40px -30px rgba(var(--color-deep-rgb), 0.28);
}

.contact-brand .section-eyebrow {
    display: inline-block;
    margin-bottom: 0.9rem;
}

.contact-brand > h2 {
    margin: 0;
}

.contact-brand > p {
    margin: 1rem 0 2.2rem;
    color: var(--ink-medium);
}

.contact-info .section-header {
    text-align: left;
    margin-bottom: 1.8rem;
}

.contact-tagline {
    font-size: 1rem;
    color: rgba(var(--color-deep-rgb), 0.5);
    margin-bottom: 1.4rem;
}

.contact-highlight {
    display: grid;
    gap: 0.35rem;
    background: linear-gradient(135deg, rgba(var(--color-accent-soft-rgb), 0.58), rgba(var(--color-ivory-rgb), 0.42));
    padding: 1.4rem 1.6rem;
    border-radius: 18px;
    border: 1px solid rgba(var(--color-accent-strong-rgb), 0.25);
    margin-bottom: 2rem;
}

.contact-highlight-title {
    font-size: 0.92rem;
    letter-spacing: 0.38rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.58);
}

.contact-highlight-note {
    font-size: 0.9rem;
    color: rgba(var(--color-deep-rgb), 0.4);
}

.contact-list {
    list-style: none;
    padding: 0;
    margin: 1.6rem 0;
    display: grid;
    gap: 1.2rem;
}

.contact-label {
    display: block;
    font-size: 0.75rem;
    letter-spacing: 0.26rem;
    text-transform: uppercase;
    color: rgba(var(--color-deep-rgb), 0.32);
    margin-bottom: 0.35rem;
}

.contact-list a {
    font-size: 1.05rem;
    color: var(--color-copper);
    text-decoration: underline;
    text-decoration-color: rgba(var(--color-accent-strong-rgb), 0.35);
}

.contact-note {
    font-size: 0.9rem;
    color: rgba(var(--color-deep-rgb), 0.42);
}

.contact-actions {
    margin-top: 2.4rem;
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}


.footer {
    background: rgba(var(--color-deep-rgb), 0.94);
    color: var(--color-white);
    padding: 3.8rem 0;
}

.footer-content {
    display: grid;
    gap: 1.6rem;
    text-align: center;
}

.footer-brand .logo {
    color: var(--color-white);
    justify-content: center;
    margin: 0 auto 1.2rem;
}


.footer-links {
    display: flex;
    justify-content: center;
    gap: 1.8rem;
    flex-wrap: wrap;
}

.footer-links a {
    color: rgba(var(--color-accent-soft-rgb), 0.78);
    font-size: 0.95rem;
    letter-spacing: 0.08rem;
}

.footer-links a:hover {
    color: var(--color-white);
}

.footer-copy {
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.55);
}

@keyframes bg-shimmer {
    0% {
        background-position: 0% 50%;
        filter: saturate(1);
    }

    50% {
        background-position: 60% 52%;
        filter: saturate(1.05);
    }

    100% {
        background-position: 120% 48%;
        filter: saturate(1);
    }
}

@keyframes hero-shimmer {
    0% {
        opacity: 0;
        transform: rotate(22deg) translateX(-80%);
    }

    20% {
        opacity: 0.22;
    }

    40% {
        opacity: 0.48;
        transform: rotate(22deg) translateX(0%);
    }

    55% {
        opacity: 0.18;
        transform: rotate(22deg) translateX(70%);
    }

    75% {
        opacity: 0;
    }

    100% {
        opacity: 0;
        transform: rotate(22deg) translateX(80%);
    }
}

.fade-in {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity 0.9s ease, transform 0.9s ease;
    transition-delay: var(--delay, 0s);
}

.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (max-width: 1024px) {
    .hero::after {
        display: none;
    }
}

@media (max-width: 960px) {
    .nav {
        position: fixed;
        inset: 0;
        background: rgba(249, 246, 243, 0.97);
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 2.2rem;
        padding: clamp(5rem, 18vw, 7rem) clamp(2.4rem, 10vw, 5rem);
        transform: translateY(-100%);
        opacity: 0;
        pointer-events: none;
        transition: transform 0.45s ease, opacity 0.3s ease;
        font-size: 1.1rem;
        text-align: center;
        z-index: 999;
        overflow-y: auto;
    }

    .nav.active {
        transform: translateY(0);
        opacity: 1;
        pointer-events: auto;
    }

    .nav-toggle {
        display: flex;
        position: relative;
        z-index: 1000;
    }

    .header .btn-outline {
        display: none;
    }

    .header .container {
        padding: 1.1rem 0;
    }

    .hero {
        padding-top: 6.4rem;
    }
}

@media (max-width: 720px) {
    .hero-cta {
        flex-direction: column;
        align-items: flex-start;
    }

    .hero-title {
        font-size: clamp(1.9rem, 6.2vw, 2.6rem);
        gap: 1.1rem;
        letter-spacing: 0.08rem;
    }

    .hero-title .hero-word--latin {
        letter-spacing: 0.18rem;
    }

    .hero-divider {
        height: 34px;
    }

    .hero-visual {
        gap: 1.8rem;
        padding-bottom: 2.4rem;
    }

    .hero-frame {
        width: min(100%, clamp(336px, 94vw, 378px));
        min-height: auto;
        padding: clamp(2.4rem, 6.4vw, 2.9rem) clamp(1.3rem, 4.8vw, 2rem) clamp(2.4rem, 6.2vw, 2.9rem);
        gap: clamp(0.36rem, 2.2vw, 0.75rem);
        align-content: flex-start;
        overflow: hidden;
    }

    .hero-frame.expanded {
        width: min(100%, clamp(336px, 94vw, 378px));
        min-height: auto;
        padding: clamp(2.2rem, 6vw, 2.7rem) clamp(1.1rem, 4.4vw, 1.8rem) clamp(2.2rem, 6vw, 2.7rem);
        overflow: hidden;
    }

    .hero-frame .hero-logo {
        width: min(48vw, 168px);
        border-radius: clamp(10px, 2vw, 20px);
        filter: none;
        box-shadow: 0 14px 28px rgba(0, 0, 0, 0.18);
    }

    .hero-frame .btn-ghost {
        font-size: clamp(0.74rem, 2.6vw, 0.84rem);
        letter-spacing: 0.12rem;
    }

    .hero-frame.hero-frame--vip {
        padding: clamp(2.4rem, 6.4vw, 2.9rem) clamp(1.3rem, 4.8vw, 2rem);
        padding-bottom: var(--vip-card-bottom-gap);
        gap: clamp(0.22rem, 1.32vw, 0.45rem);
        --vip-card-bottom-gap: clamp(0.78rem, 3vw, 1.28rem);
    }

    .hero-frame.hero-frame--vip .hero-frame-head {
        margin-top: clamp(0.14rem, 0.7vw, 0.32rem);
        min-height: clamp(110px, 44vw, 140px);
    }

    .hero-frame.hero-frame--vip .hero-booking-gate {
        gap: clamp(0.45rem, 1.6vw, 0.7rem);
        margin-top: clamp(0.3rem, 1.4vw, 0.8rem);
        padding-top: clamp(0.85rem, 2.6vw, 1.35rem);
    }

    .booking-grid {
        grid-template-columns: 1fr;
    }

    .booking-actions {
        flex-direction: column;
        align-items: stretch;
        gap: 0.6rem;
    }

    .hero-ribbon {
        flex-direction: column;
        gap: 0.6rem;
        padding: 0.9rem 1.3rem;
        text-align: center;
        width: 100%;
        justify-content: center;
    }

    .section-block::before {
        height: 42px;
    }

    .pricing-toggle {
        width: 100%;
    }

    .toggle-btn {
        flex: 1;
    }

    .contact-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .footer-links {
        flex-direction: column;
        gap: 1rem;
    }

    .booking-stepper__list {
        flex-direction: column;
        align-items: stretch;
        gap: clamp(0.5rem, 2.4vw, 0.75rem);
    }

    .booking-stepper__item {
        width: 100%;
        justify-content: flex-start;
        gap: clamp(0.55rem, 2.2vw, 0.75rem);
        text-align: left;
    }

    .booking-stepper__label {
        letter-spacing: 0.05rem;
    }

    .booking-actions__buttons {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: clamp(0.55rem, 2vw, 0.75rem);
        align-items: stretch;
    }

    .booking-actions__buttons .booking-submit {
        grid-column: 2;
    }

    .booking-actions__buttons .booking-step-prev {
        grid-column: 1;
    }

    .booking-actions__buttons .booking-step-prev,
    .booking-actions__buttons .booking-step-next,
    .booking-actions__buttons .booking-submit {
        min-width: 0;
        width: 100%;
        justify-content: center;
        flex: initial;
    }

    .booking-step-prev,
    .booking-step-next,
    .booking-submit {
        width: 100%;
        min-width: 0;
    }

    .booking-actions__buttons > *:only-child {
        grid-column: 1 / -1;
    }

    .hero-frame--stylebar .hero-stylebar-code-row {
        grid-template-columns: 1fr;
        gap: clamp(0.4rem, 2.6vw, 0.75rem);
    }

    .hero-frame--stylebar .hero-stylebar-code-button {
        width: 100%;
        justify-content: center;
    }

    .hero-frame.hero-frame--vip {
        padding-top: clamp(2.2rem, 6vw, 2.8rem);
    }

    .hero-frame.hero-frame--vip .hero-frame-head {
        margin-top: clamp(0.18rem, 0.8vw, 0.4rem);
    }
}

@media (max-width: 600px) {
    .container {
        width: min(var(--max-width), 92%);
    }

    .section-block {
        padding: 4.2rem 0;
    }

    .hero.section-block {
        padding-top: 0;
        padding-bottom: clamp(3rem, 9vw, 4.2rem);
    }

    .header .container {
        padding: 0.95rem 0;
        gap: 0.75rem;
    }

    .logo {
        font-size: 1.18rem;
        gap: 0.45rem;
    }

    .logo-text--kr {
        font-size: 0.92rem;
        letter-spacing: 0.08rem;
    }

    .logo-text--latin {
        letter-spacing: 0.22rem;
    }

    .nav {
        font-size: 1.05rem;
        gap: 1.6rem;
    }

    .hero {
        padding-top: calc(env(safe-area-inset-top, 0px) + clamp(0.32rem, 2.4vw, 0.78rem));
        padding-bottom: clamp(3.2rem, 10vw, 4.4rem);
        min-height: auto;
        align-items: flex-start;
    }

    .hero-content {
        gap: clamp(0.22rem, 1vw, 0.32rem);
        display: flex;
        flex-direction: column;
        align-items: center;
    }

    .hero-visual {
        align-self: center;
        width: 100%;
        padding-inline: clamp(0.4rem, 2.4vw, 0.8rem);
    }

    .hero-brand {
        width: 100%;
        min-height: auto;
        justify-content: center;
        align-items: center;
        text-align: center;
        gap: clamp(0.4rem, 1.6vw, 0.7rem);
        padding-inline: clamp(0.4rem, 2.4vw, 0.8rem);
    }

    .hero-brand__logo {
        width: clamp(240px, 80vw, 310px);
    }

    .hero-visual {
        margin-top: 0;
        order: 1;
        padding-top: 0;
        padding-bottom: clamp(0.25rem, 1.6vw, 0.5rem);
    }

    .hero-text {
        order: 2;
        margin-top: 1.1rem;
        min-height: auto;
    }

    .hero-text-bottom {
        margin-top: clamp(1.2rem, 7vw, 1.8rem);
        padding-top: clamp(1rem, 5vw, 1.4rem);
    }

    .hero-eyebrow {
        font-size: 0.62rem;
        letter-spacing: 0.24rem;
    }

    .hero-title {
        gap: 0.85rem;
        font-size: clamp(1.82rem, 8vw, 2.4rem);
    }

    .hero-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
        letter-spacing: 0.16rem;
        font-size: 0.72rem;
    }

    .hero-meta .separator {
        display: none;
    }

    .hero-cta {
        gap: 0.65rem;
        width: 100%;
    }

    .hero-cta .btn,
    .hero-cta .btn-outline,
    .hero-cta .btn-question {
        width: 100%;
    }

    .hero-question-panel {
        border-radius: 20px;
    }

    .hero-question-inner {
        padding: 1.45rem 1.3rem 1.6rem;
        gap: 0.9rem;
    }

    .hero-question-lead {
        font-size: 0.96rem;
        line-height: 1.6;
    }

    .hero-question-heading {
        font-size: 0.72rem;
        letter-spacing: 0.06rem;
    }

    .hero-frame {
        min-height: clamp(620px, 165vw, 820px);
        aspect-ratio: auto;
        padding: clamp(1.45rem, 4.8vw, 2.1rem) clamp(1.05rem, 5.2vw, 1.75rem) clamp(2.05rem, 6.2vw, 2.6rem);
        gap: clamp(1rem, 3.2vw, 1.48rem);
        align-content: flex-start;
        justify-content: flex-start;
        background: var(--hero-card-gradient);
        box-shadow: 0 40px 80px -48px rgba(var(--color-deep-rgb), 0.42);
        color: var(--hero-card-foreground);
        overflow: visible;
    }

    .hero-frame-head {
        min-height: 108px;
        gap: 0.6rem;
    }

    .hero-frame.expanded {
        min-height: clamp(780px, 205vw, 980px);
        aspect-ratio: auto;
        padding: clamp(1.85rem, 5.6vw, 2.35rem) clamp(1.2rem, 5.6vw, 2rem) clamp(2.45rem, 7vw, 3.1rem);
        background: var(--hero-card-gradient);
        box-shadow: 0 40px 80px -48px rgba(var(--color-deep-rgb), 0.42);
        color: var(--hero-card-foreground);
    }

    .hero-frame.success-mode {
        aspect-ratio: auto;
        min-height: clamp(720px, 190vw, 940px);
        background: var(--hero-card-gradient);
        color: var(--hero-card-foreground);
    }

    .hero-frame .hero-logo {
        width: clamp(150px, 58vw, 260px);
    }

    .hero-caption {
        font-size: 0.96rem;
        letter-spacing: 0.4rem;
        color: rgba(255, 255, 255, 0.92);
    }

    .hero-caption-sub {
        font-size: 0.74rem;
        letter-spacing: 0.2rem;
        color: rgba(255, 255, 255, 0.82);
    }

    .hero-frame .btn-ghost {
        font-size: 0.88rem;
        letter-spacing: 0.24rem;
        min-height: 52px;
    }

    .booking-fieldset {
        padding: 2.45rem 1.15rem 1.3rem;
        background: rgba(255, 255, 255, 0.42);
        backdrop-filter: blur(20px);
        border: 1px solid rgba(255, 255, 255, 0.24);
        box-shadow: 0 24px 48px -30px rgba(var(--color-deep-rgb), 0.26);
    }


    .booking-fieldset legend {
        left: 1.15rem;
        top: 0.6rem;
        padding: 0.3rem 0.75rem;
        font-size: 0.76rem;
        letter-spacing: 0.14rem;
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(var(--color-ivory-rgb), 0.7));
        color: rgba(var(--color-deep-rgb), 0.7);
        box-shadow: 0 12px 24px -18px rgba(var(--color-deep-rgb), 0.2);
    }

    .booking-alert {
        gap: 0.6rem;
        margin-bottom: 0.9rem;
        margin-top: 0.05rem;
        padding: 0;
        border-radius: 0;
        background: transparent;
        border: none;
        box-shadow: none;
        color: var(--ink-strong);
    }

    .booking-alert__label {
        font-size: 0.82rem;
        letter-spacing: 0.16rem;
        color: rgba(var(--color-deep-rgb), 0.6);
    }

    .booking-notice {
        font-size: 0.78rem;
        padding: 0.95rem 1.15rem;
        border-radius: 18px;
        gap: 0.65rem;
        background: rgba(255, 255, 255, 0.18);
        border: 1px solid rgba(255, 255, 255, 0.26);
        color: rgba(var(--color-deep-rgb), 0.8);
        box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.28);
    }

    .booking-notice__icon {
        font-size: 0.9rem;
        transform: translateY(0.06rem);
        color: rgba(var(--color-accent-strong-rgb), 0.8);
    }

    .booking-consents {
        padding: 1.2rem 1.25rem;
        border-radius: 24px;
        gap: 1rem;
        background: rgba(255, 255, 255, 0.18);
        border: 1px solid rgba(255, 255, 255, 0.24);
        box-shadow: 0 24px 44px -30px rgba(var(--color-deep-rgb), 0.28);
    }

    .booking-consents__header {
        padding-bottom: 0.55rem;
    }

    .booking-checkbox--master {
        width: 100%;
        justify-content: flex-start;
    }

    .booking-checkbox {
        font-size: 0.9rem;
    }

    .booking-consents__item {
        padding: 0.6rem 0.75rem 0.7rem;
        border-radius: 16px;
    }

    .booking-consents__item-header {
        flex-direction: row;
        align-items: center;
        gap: 0.45rem;
    }

    .booking-consents__item-body {
        font-size: 0.76rem;
        line-height: 1.62;
    }

    .booking-confirm__icon {
        border-color: rgba(255, 255, 255, 0.4);
        color: rgba(181, 96, 66, 0.86);
        background: rgba(255, 255, 255, 0.95);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
    }

    .booking-field input,
    .booking-field select,
    .booking-field textarea {
        background: rgba(255, 255, 255, 0.22);
        border: 1px solid rgba(255, 255, 255, 0.26);
        color: rgba(var(--color-deep-rgb), 0.88);
        box-shadow: 0 22px 40px -30px rgba(var(--color-deep-rgb), 0.26);
        backdrop-filter: blur(20px);
    }

    .booking-stepper {
        margin-bottom: 1rem;
    }

    .booking-stepper__list {
        flex-direction: column;
        align-items: stretch;
        gap: 0.55rem;
    }

    .booking-stepper__item {
        justify-content: space-between;
        padding: 0.6rem 0.95rem;
    }

    .booking-actions__buttons {
        flex-direction: column;
    }

    .booking-step-prev,
    .booking-step-next,
    .booking-submit {
        flex: 1 1 auto;
        min-width: unset;
        width: 100%;
    }

    .booking-actions .btn-link {
        align-self: stretch;
        text-align: center;
    }

    .booking-policy {
        padding: 0.95rem 1.1rem;
    }

    .booking-field input::placeholder,
    .booking-field textarea::placeholder {
        color: rgba(var(--color-deep-rgb), 0.5);
    }

    .booking-confirm {
        padding: 0.58rem 1.25rem;
        font-size: 0.78rem;
        letter-spacing: 0.16rem;
        background: rgba(255, 255, 255, 0.2);
        border: 1px solid rgba(255, 255, 255, 0.32);
        color: rgba(255, 255, 255, 0.88);
        box-shadow: 0 20px 40px -28px rgba(var(--color-deep-rgb), 0.32);
    }

    .booking-fieldset legend {
        top: 0.45rem;
        left: 1.15rem;
        font-size: 0.72rem;
        letter-spacing: 0.12rem;
        padding: 0.28rem 0.65rem;
    }

    .booking-toggle {
        flex-direction: row;
        flex-wrap: wrap;
        padding: 0.45rem;
        margin-top: 0.95rem;
        gap: 0.45rem;
        background: rgba(255, 255, 255, 0.12);
        border: 1px solid rgba(255, 255, 255, 0.24);
        box-shadow: 0 20px 36px -28px rgba(var(--color-deep-rgb), 0.26);
        backdrop-filter: blur(18px);
    }

    .booking-toggle label {
        flex: 1 1 calc(50% - 0.45rem);
    }

    .booking-toggle label span {
        min-height: 44px;
        letter-spacing: 0.18rem;
        background: rgba(255, 255, 255, 0.22);
        color: rgba(var(--color-deep-rgb), 0.7);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
    }

    .booking-actions {
        gap: 0.5rem;
    }

    .hero-ribbon {
        padding: 0.8rem 1.1rem;
        gap: 0.45rem;
        letter-spacing: 0.18rem;
    }

    .section-header {
        margin-bottom: 2.4rem;
    }

    .section-header h2 {
        font-size: clamp(1.7rem, 6.8vw, 2.2rem);
        letter-spacing: 0.1rem;
    }

    .section-header p {
        font-size: 0.95rem;
    }

    .pricing-toggle {
        padding: 0.3rem;
        border-radius: 20px;
    }

    .toggle-btn {
        font-size: 0.82rem;
        padding: 0.65rem 0.9rem;
    }

    .pricing-grid {
        gap: 1.5rem;
    }

    .price-card {
        padding: 1.25rem 1.15rem 1.4rem;
        display: grid;
        grid-template-areas:
            "badge badge"
            "title title"
            "time time"
            "price price"
            "desc desc";
        row-gap: 0.4rem;
        align-items: start;
        background: linear-gradient(160deg, rgba(255, 250, 244, 0.98), rgba(255, 232, 210, 0.92));
        border: 1px solid rgba(var(--color-accent-strong-rgb), 0.18);
        box-shadow: 0 16px 36px -28px rgba(var(--color-deep-rgb), 0.24);
        color: rgba(var(--color-deep-rgb), 0.82);
        min-height: auto;
    }

    .price-card header {
        grid-area: title;
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
        width: 100%;
    }

    .price-card header::after {
        display: none;
    }

    .price-card .badge {
        grid-area: badge;
        justify-self: flex-start;
        color: rgba(var(--color-deep-rgb), 0.78) !important;
        background: rgba(var(--color-accent-soft-rgb), 0.68) !important;
        letter-spacing: 0.14rem;
    }

    .price-card .time {
        grid-area: time;
        color: var(--ink-muted) !important;
        letter-spacing: 0.1rem;
        font-size: 0.78rem;
    }

    .price {
        grid-area: price;
        flex-direction: row;
        gap: 0.45rem;
        align-items: baseline;
        width: 100%;
    }

    .price-card .price-current {
        color: rgba(var(--color-accent-strong-rgb), 0.95) !important;
    }

    .price-card .price-original {
        color: rgba(var(--color-deep-rgb), 0.35) !important;
    }

    .price-card .desc {
        grid-area: desc;
        font-size: 0.88rem;
        line-height: 1.45;
        margin-top: 0.35rem;
        color: var(--ink-medium) !important;
    }

    .price-card::after {
        inset: 5px;
        border-radius: 16px;
        border: 1px solid rgba(var(--color-accent-strong-rgb), 0.1);
        background: radial-gradient(circle at 12% 0%, rgba(255, 180, 120, 0.18), transparent 70%);
    }

    .price-card[data-group="men"] {
        background: linear-gradient(168deg, rgba(16, 22, 36, 0.98) 0%, rgba(30, 40, 63, 0.96) 44%, rgba(48, 66, 102, 0.94) 100%);
        border: 1px solid rgba(92, 118, 168, 0.52);
        box-shadow: 0 36px 82px -48px rgba(6, 10, 20, 0.62);
        color: rgba(230, 237, 255, 0.96);
    }

    .price-card[data-group="men"] h3 {
        color: rgba(240, 244, 255, 0.98) !important;
    }

    .price-card[data-group="men"] .badge {
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.88), rgba(183, 203, 247, 0.66)) !important;
        color: rgba(20, 28, 48, 0.88) !important;
        border: 1px solid rgba(183, 203, 247, 0.6);
        box-shadow: 0 18px 32px -22px rgba(7, 12, 24, 0.5);
    }

    .price-card[data-group="men"] .time {
        color: rgba(198, 208, 234, 0.76) !important;
    }

    .price-card[data-group="men"] .price-original {
        color: rgba(210, 220, 240, 0.45) !important;
    }

    .price-card[data-group="men"] .price-current {
        color: #f2f6ff !important;
        text-shadow: 0 14px 28px rgba(6, 11, 22, 0.42);
    }

    .price-card[data-group="men"] .desc {
        color: rgba(210, 220, 240, 0.84) !important;
    }

    .price-card[data-group="women"] {
        background: linear-gradient(168deg, rgba(255, 224, 213, 0.98) 0%, rgba(244, 163, 132, 0.96) 48%, rgba(224, 124, 96, 0.94) 100%);
        border: 1px solid rgba(231, 139, 114, 0.52);
        box-shadow: 0 36px 82px -48px rgba(186, 103, 74, 0.42);
        color: rgba(94, 44, 30, 0.92);
    }

    .price-card[data-group="women"] h3 {
        color: rgba(96, 44, 30, 0.94) !important;
    }

    .price-card[data-group="women"] .badge {
        background: linear-gradient(135deg, rgba(255, 245, 240, 0.9), rgba(248, 202, 186, 0.62)) !important;
        color: rgba(138, 58, 42, 0.82) !important;
        border: 1px solid rgba(248, 202, 186, 0.68);
        box-shadow: 0 18px 32px -22px rgba(167, 87, 60, 0.32);
    }

    .price-card[data-group="women"] .time {
        color: rgba(117, 62, 45, 0.6) !important;
    }

    .price-card[data-group="women"] .price-original {
        color: rgba(117, 62, 45, 0.4) !important;
    }

    .price-card[data-group="women"] .price-current {
        color: rgba(171, 74, 50, 0.98) !important;
        text-shadow: 0 14px 28px rgba(171, 74, 50, 0.28);
    }

    .price-card[data-group="women"] .desc {
        color: rgba(117, 62, 45, 0.74) !important;
    }

    .pricing-note {
        font-size: 0.85rem;
        margin-top: 1.6rem;
        color: rgba(var(--color-deep-rgb), 0.58);
    }

}

@media (max-width: 480px) {
    body {
        background: var(--gradient-primary);
        color: rgba(var(--color-deep-rgb), 0.9);
    }

    body::before {
        background: radial-gradient(circle at 16% 18%, rgba(var(--color-accent-light-rgb), 0.46), transparent 52%),
                    radial-gradient(circle at 82% 12%, rgba(var(--color-accent-rgb), 0.34), transparent 46%),
                    linear-gradient(205deg, rgba(255, 255, 255, 0.78) 0%, transparent 74%);
    }

    body::after {
        background-image: linear-gradient(145deg, rgba(var(--color-accent-soft-rgb), 0.32) 0%, rgba(255, 255, 255, 0.48) 100%);
        filter: saturate(1.2);
    }

    .hero {
        padding-top: 0.6rem;
        padding-bottom: clamp(6.8rem, 24vw, 9.6rem);
    }

    .hero-visual {
        padding-top: clamp(0.09rem, 0.9vw, 0.32rem);
        padding-bottom: calc(env(safe-area-inset-bottom, 0px) + clamp(2.2rem, 8vw, 3.6rem));
    }

    .hero-frame[data-hero-card="quick"] .hero-caption-sub {
        display: none;
    }

    .events-stack__toggle {
        margin-top: clamp(4rem, 12vw, 5.8rem);
    }

    .hero-brand {
        min-height: clamp(140px, 42vw, 210px);
        gap: clamp(0.48rem, 3vw, 0.9rem);
        margin-top: clamp(0.65rem, 2.4vw, 1.1rem);
    }

    .hero-title {
        font-size: clamp(2rem, 10vw, 2.5rem);
        letter-spacing: 0.12rem;
    }

    .hero-meta {
        font-size: 0.76rem;
        letter-spacing: 0.18rem;
        color: rgba(var(--color-deep-rgb), 0.68);
    }

    .hero-frame {
        min-height: 360px;
        padding: 2.35rem 1.2rem 1.85rem;
        background: var(--hero-card-gradient);
        box-shadow: 0 26px 62px -38px rgba(var(--color-deep-rgb), 0.34);
        color: var(--hero-card-foreground);
    }

    .hero-frame.expanded {
        min-height: 560px;
        padding: 2.35rem 1.1rem 1.8rem;
        background: var(--hero-card-gradient);
        color: var(--hero-card-foreground);
    }

    .hero-frame::before {
        border: 1px solid rgba(255, 255, 255, 0.42);
    }

    .hero-frame::after {
        opacity: 0.28;
    }

    .hero-card-nav-group {
        margin-top: clamp(1.1rem, 5.8vw, 2.2rem);
        padding: clamp(0.72rem, 3.8vw, 0.95rem) clamp(0.9rem, 5vw, 1.35rem);
    }

    .hero-card-nav {
        width: clamp(32px, 16vw, 38px);
        height: clamp(32px, 16vw, 38px);
    }

    .booking-consents {
        padding: 1rem 1rem;
        border-radius: 20px;
        gap: 0.8rem;
    }

    .booking-consents__item {
        padding: 0.7rem 0.85rem;
        border-radius: 18px;
        gap: 0.5rem;
    }

    .booking-consents__item-header {
        flex-direction: row;
        align-items: center;
        gap: 0.5rem;
        flex-wrap: wrap;
    }

    .booking-consents__title {
        width: auto;
        flex: 1 1 auto;
        justify-content: flex-start;
        gap: 0.45rem;
    }

    .booking-consent-toggle {
        margin-left: auto;
        font-size: 0.5rem;
        padding-left: 0.3rem;
    }

    .booking-consents__highlight {
        font-size: 0.72rem;
        line-height: 1.52;
        padding: 0.45rem 0.55rem;
    }

    .booking-consents__item-body {
        font-size: 0.74rem;
        line-height: 1.6;
    }

    .hero-caption-sub {
        font-size: 0.72rem;
        letter-spacing: 0.16rem;
    }

    .booking-fieldset {
        padding: 2.6rem 1.1rem 1.4rem;
        background: rgba(255, 255, 255, 0.42);
        border: 1px solid rgba(255, 255, 255, 0.24);
        backdrop-filter: blur(20px);
        box-shadow: 0 26px 60px -36px rgba(var(--color-deep-rgb), 0.28);
    }

    .booking-fieldset legend {
        top: 0.58rem;
        left: 1.05rem;
        font-size: 0.84rem;
        letter-spacing: 0.18rem;
        padding: 0.32rem 0.85rem;
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(var(--color-accent-soft-rgb), 0.68));
        color: rgba(var(--color-deep-rgb), 0.76);
    }

    .booking-toggle {
        background: rgba(255, 255, 255, 0.12);
        border: 1px solid rgba(255, 255, 255, 0.24);
        box-shadow: 0 20px 36px -28px rgba(var(--color-deep-rgb), 0.26);
        margin-top: 1.05rem;
        gap: 0.5rem;
        flex-wrap: wrap;
    }

    .booking-toggle label {
        font-size: 0.95rem;
        letter-spacing: 0.2rem;
        flex: 1 1 calc(50% - 0.5rem);
    }

    .booking-toggle label span {
        min-height: 46px;
        padding: 0.6rem 0.2rem;
        background: rgba(255, 255, 255, 0.22);
        color: rgba(var(--color-deep-rgb), 0.72);
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
    }

    .booking-toggle input:checked + span {
        background: rgba(255, 255, 255, 0.92);
        color: rgba(var(--color-deep-rgb), 0.88);
        box-shadow: 0 24px 40px -28px rgba(var(--color-deep-rgb), 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    }

    .booking-field span {
        font-size: 0.82rem;
        letter-spacing: 0.2rem;
        color: rgba(var(--color-deep-rgb), 0.72);
    }

    .booking-field span em {
        font-size: 0.95em;
    }

    .booking-field {
        font-size: 0.9rem;
    }

    .booking-field input,
    .booking-field select,
    .booking-field textarea {
        font-size: 0.96rem;
        padding: 0.85rem 1.1rem;
    }

    .booking-alert__label {
        font-size: 0.86rem;
        letter-spacing: 0.18rem;
    }

    .booking-notice {
        font-size: 0.82rem;
    }

    .hero-ribbon {
        background: linear-gradient(135deg, rgba(255, 255, 255, 0.92), rgba(var(--color-accent-soft-rgb), 0.46));
        color: rgba(var(--color-deep-rgb), 0.8);
    }
}

@media (max-width: 900px) and (orientation: portrait) {
    .hero {
        padding-top: clamp(0.6rem, 1.6vw, 1.2rem);
        padding-bottom: clamp(2rem, 4.8vw, 3.2rem);
        min-height: clamp(320px, 60vh, 520px);
    }

    .hero-content {
        --hero-column-top: clamp(0.48rem, 1.6vw, 1.2rem);
        gap: clamp(1.1rem, 2.8vw, 2.1rem);
    }

    .hero-brand {
        min-height: clamp(200px, 32vh, 300px);
    }

    .hero-brand__logo {
        width: clamp(384px, 72vw, 1150px);
    }

    .hero-visual {
        padding-top: clamp(0.6rem, 1.8vw, 1.4rem);
        gap: clamp(1.6rem, 3.6vw, 2.6rem);
    }

    .hero-card-carousel {
        min-height: clamp(560px, 58vw, 760px);
    }
}

@media (max-width: 480px) {
    .hero-content {
        gap: clamp(0.28rem, 0.9vw, 0.45rem);
    }

    .hero-card-stage {
        transform: translateY(4%);
    }

    .hero-brand {
        min-height: clamp(70px, 22vw, 120px);
        gap: clamp(0.2rem, 1.2vw, 0.4rem);
        align-items: center;
    }

    .hero-brand__logo-slot {
        justify-content: center;
    }

    .hero-brand__logo {
        width: clamp(260px, 94vw, 520px);
    }

    .hero-frame[data-hero-card="quick"] .hero-caption-group {
        margin-bottom: clamp(0.45rem, 2.4vw, 0.85rem);
    }
}

