/* ==========================================================================
   HUT Dining Buffet — warm premium Japanese-buffet theme
   Binchotan espresso + lacquer red + warm gold + washi cream
   (CSS class names kept as sy-* for parity with the shared portal codebase)
   ========================================================================== */

:root {
    /* Core palette */
    --sy-ink:        #211611;       /* warm binchotan espresso */
    --sy-ink-soft:   #3c2c23;
    --sy-indigo:     #8c2f23;       /* lacquer red-brown (prices / links) */
    --sy-indigo-deep:#6f2419;
    --sy-washi:      #f3e8d6;       /* warm washi cream */
    --sy-washi-soft: #e7d6bb;
    --sy-paper:      #f7f1e6;       /* warm paper */
    --sy-sakura:     #b12f2f;       /* lacquer red accent */
    --sy-sakura-soft:#dd9b8f;
    --sy-gold:       #b3873a;       /* warm gold */
    --sy-gold-light: #d8b066;
    --sy-line:       rgba(33,22,17,0.12);
    --sy-line-soft:  rgba(33,22,17,0.06);
    --sy-muted:      #7c6f62;

    /* Type */
    --sy-display: 'Shippori Mincho', 'Cormorant Garamond', 'Times New Roman', serif;
    --sy-serif:   'Cormorant Garamond', 'Shippori Mincho', serif;
    --sy-sans:    'Inter', 'Noto Sans JP', system-ui, -apple-system, sans-serif;

    /* Misc */
    --sy-radius:     2px;
    --sy-radius-md:  10px;
    --sy-shadow-sm:  0 1px 2px rgba(20,23,28,0.04), 0 4px 16px rgba(20,23,28,0.05);
    --sy-shadow:     0 8px 32px rgba(20,23,28,0.08), 0 2px 8px rgba(20,23,28,0.04);
    --sy-shadow-lg:  0 24px 64px rgba(20,23,28,0.12);
    --sy-trans:      cubic-bezier(0.4, 0, 0.2, 1);
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body.sy-body {
    font-family: var(--sy-sans);
    font-size: 16px;
    line-height: 1.6;
    color: var(--sy-ink);
    background: var(--sy-paper);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a { color: var(--sy-indigo); text-decoration: none; transition: color 0.2s var(--sy-trans); }
a:hover { color: var(--sy-sakura); }

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

h1, h2, h3, h4, h5, h6 {
    font-family: var(--sy-display);
    font-weight: 500;
    color: var(--sy-ink);
    letter-spacing: 0.01em;
    line-height: 1.25;
    margin: 0 0 0.5em;
}

p { margin: 0 0 1em; }
p:last-child { margin-bottom: 0; }

.sy-eyebrow {
    font-family: var(--sy-sans);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-gold);
}

.sy-divider {
    display: inline-block;
    width: 56px;
    height: 1px;
    background: var(--sy-gold);
    margin: 1rem 0;
}

/* ==========================================================================
   Navigation
   ========================================================================== */
.sy-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(247, 241, 230, 0.92);
    backdrop-filter: saturate(180%) blur(12px);
    -webkit-backdrop-filter: saturate(180%) blur(12px);
    border-bottom: 1px solid var(--sy-line);
}
.sy-nav__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px;
    height: 76px;
    display: flex;
    align-items: center;
    gap: 32px;
}
.sy-nav__brand {
    display: flex;
    align-items: center;
    gap: 14px;
    color: var(--sy-ink);
}
.sy-nav__brand:hover { color: var(--sy-ink); }
.sy-nav__brand-mark {
    font-family: var(--sy-display);
    font-weight: 700;
    font-size: 1.6rem;
    width: 44px;
    height: 44px;
    border: 1.5px solid var(--sy-ink);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--sy-ink);
    color: var(--sy-washi);
    line-height: 1;
}
.sy-nav__brand-logo {
    height: 44px;
    width: auto;
    max-width: 96px;
    object-fit: contain;
    display: block;
}
.sy-nav__brand-text { display: flex; flex-direction: column; line-height: 1; }
.sy-nav__brand-name {
    font-family: var(--sy-display);
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: 0.05em;
}
.sy-nav__brand-tagline {
    font-size: 0.65rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-muted);
    margin-top: 4px;
}
.sy-nav__links {
    display: flex;
    gap: 28px;
    margin-left: auto;
    align-items: center;
}
.sy-nav__links a {
    color: var(--sy-ink);
    font-size: 0.9rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    position: relative;
    padding: 8px 0;
}
.sy-nav__links a::after {
    content: '';
    position: absolute;
    left: 0; bottom: 0;
    width: 0; height: 1.5px;
    background: var(--sy-sakura);
    transition: width 0.3s var(--sy-trans);
}
.sy-nav__links a:hover::after { width: 100%; }
.sy-nav__phone {
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    border: 1px solid var(--sy-ink);
    color: var(--sy-ink);
    font-size: 0.88rem;
    font-weight: 500;
    letter-spacing: 0.04em;
    transition: all 0.2s var(--sy-trans);
}
.sy-nav__phone:hover {
    background: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-nav__phone i { font-size: 0.95rem; color: var(--sy-gold); }
.sy-nav__phone:hover i { color: var(--sy-gold-light); }
@media (max-width: 600px) {
    .sy-nav__phone span { display: none; }
    .sy-nav__phone { padding: 10px 14px; }
}

/* Legacy CTA / mobile-panel from old multi-page nav (kept for safety) */
.sy-nav__cta { display: none; }
.sy-nav__burger {
    display: none;
    background: transparent;
    border: 0;
    color: var(--sy-ink);
    font-size: 1.6rem;
    cursor: pointer;
    padding: 8px;
}
.sy-nav__mobile-panel { display: none; }

@media (max-width: 900px) {
    .sy-nav__inner { padding: 0 20px; gap: 16px; }
    .sy-nav__links { display: none; }
    .sy-nav__cta { display: none; }
    .sy-nav__burger { display: inline-flex; margin-left: auto; }
    .sy-nav__brand-tagline { display: none; }
    .sy-nav__mobile-panel {
        display: none;
        flex-direction: column;
        background: var(--sy-paper);
        border-top: 1px solid var(--sy-line);
        padding: 12px 20px 24px;
    }
    .sy-nav__mobile-panel.is-open { display: flex; }
    .sy-nav__mobile-panel a {
        padding: 14px 0;
        border-bottom: 1px solid var(--sy-line-soft);
        color: var(--sy-ink);
        font-size: 1rem;
    }
    .sy-nav__mobile-cta {
        margin-top: 16px;
        background: var(--sy-ink);
        color: var(--sy-washi) !important;
        text-align: center;
        padding: 14px 0 !important;
        border: 0 !important;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        font-size: 0.85rem !important;
    }
}

/* ==========================================================================
   Hero
   ========================================================================== */
.sy-hero {
    position: relative;
    min-height: 88vh;
    display: flex;
    align-items: center;
    overflow: hidden;
    background: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-hero__bg {
    position: absolute;
    inset: 0;
    background-image: url('/img/Sushi-Yoshi-hero.jpg');
    background-size: cover;
    background-position: center;
    opacity: 0.5;
    transform: scale(1.05);
}
.sy-hero__bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        rgba(20,23,28,0.55) 0%,
        rgba(20,23,28,0.25) 40%,
        rgba(20,23,28,0.85) 100%);
}
.sy-hero__inner {
    position: relative;
    max-width: 1280px;
    margin: 0 auto;
    padding: 96px 32px;
    width: 100%;
    z-index: 2;
}
.sy-hero__eyebrow {
    color: var(--sy-gold-light);
    margin-bottom: 24px;
    display: inline-block;
}
.sy-hero__title {
    font-family: var(--sy-display);
    font-size: clamp(2.6rem, 6vw, 4.8rem);
    font-weight: 500;
    line-height: 1.1;
    letter-spacing: 0.01em;
    color: var(--sy-washi);
    margin-bottom: 24px;
    max-width: 14ch;
}
.sy-hero__title em {
    font-style: italic;
    font-weight: 400;
    color: var(--sy-sakura-soft);
}
.sy-hero__subtitle {
    font-size: 1.05rem;
    line-height: 1.7;
    color: rgba(245, 241, 232, 0.85);
    max-width: 56ch;
    margin-bottom: 40px;
    font-weight: 300;
}
.sy-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 16px 32px;
    background: var(--sy-washi);
    color: var(--sy-ink);
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    transition: all 0.3s var(--sy-trans);
    border: 1px solid var(--sy-washi);
}
.sy-hero__cta:hover {
    background: var(--sy-sakura);
    border-color: var(--sy-sakura);
    color: #fff;
    transform: translateY(-2px);
}
.sy-hero__cta-arrow { font-size: 1.1rem; }
.sy-hero__meta {
    margin-top: 64px;
    display: flex;
    gap: 56px;
    flex-wrap: wrap;
    border-top: 1px solid rgba(245,241,232,0.18);
    padding-top: 32px;
}
.sy-hero__meta-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.sy-hero__meta-label {
    font-size: 0.65rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-gold-light);
}
.sy-hero__meta-value {
    font-family: var(--sy-display);
    font-size: 1.15rem;
    color: var(--sy-washi);
}

/* Vertical Japanese accent on hero */
.sy-hero__kanji-strip {
    position: absolute;
    right: 56px;
    top: 50%;
    transform: translateY(-50%);
    writing-mode: vertical-rl;
    font-family: var(--sy-display);
    font-size: 1.2rem;
    letter-spacing: 0.6em;
    color: rgba(245,241,232,0.35);
    text-transform: uppercase;
    z-index: 2;
}
@media (max-width: 900px) {
    .sy-hero { min-height: 80vh; }
    .sy-hero__inner { padding: 64px 20px; }
    .sy-hero__meta { gap: 28px; margin-top: 40px; padding-top: 24px; }
    .sy-hero__kanji-strip { display: none; }
}

/* ==========================================================================
   Banner-style hero (uses the official Sushi Yoshi banner)
   ========================================================================== */
.sy-hero-banner {
    background: var(--sy-paper);
}
.sy-hero-banner__img {
    margin: 0 auto;
    overflow: hidden;
    line-height: 0;
    box-shadow: var(--sy-shadow);
}
.sy-hero-banner__img img {
    width: 100%;
    height: auto;
    display: block;
}
.sy-hero-banner__under {
    background: var(--sy-paper);
    padding: 56px 0 80px;
}
.sy-hero-banner__row {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 64px;
    align-items: end;
}
.sy-hero-banner__title {
    font-family: var(--sy-display);
    font-size: clamp(2rem, 4vw, 3rem);
    margin: 16px 0 16px;
    color: var(--sy-ink);
    line-height: 1.15;
}
.sy-hero-banner__sub {
    font-size: 1.02rem;
    color: var(--sy-ink-soft);
    line-height: 1.75;
    max-width: 56ch;
    margin: 0;
}
.sy-hero-banner__cta-col {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
}
.sy-hero-banner__cta { padding: 18px 36px; font-size: 0.9rem; }
.sy-hero-banner__meta {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    border-left: 2px solid var(--sy-gold);
    padding-left: 20px;
    width: 100%;
}
.sy-hero-banner__meta > div { display: flex; flex-direction: column; gap: 2px; }
.sy-hero-banner__meta span {
    font-size: 0.65rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
}
.sy-hero-banner__meta strong {
    font-family: var(--sy-display);
    font-size: 1.05rem;
    color: var(--sy-ink);
    font-weight: 500;
}
@media (max-width: 900px) {
    .sy-hero-banner__under { padding: 40px 0 56px; }
    .sy-hero-banner__row { grid-template-columns: 1fr; gap: 32px; }
    .sy-hero-banner__cta-col { width: 100%; }
    .sy-hero-banner__cta { width: 100%; justify-content: center; }
}

/* ==========================================================================
   Omakase tier display (Menu page)
   ========================================================================== */
.sy-tier-tabs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 64px;
    border-bottom: 1px solid var(--sy-line);
    padding-bottom: 24px;
}
.sy-tier-tab {
    padding: 18px 16px;
    background: var(--sy-paper);
    border: 1px solid var(--sy-line);
    color: var(--sy-ink);
    text-align: center;
    transition: all 0.2s var(--sy-trans);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.sy-tier-tab:hover {
    border-color: var(--sy-ink);
    color: var(--sy-ink);
    transform: translateY(-2px);
}
.sy-tier-tab.is-active {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-tier-tab__name {
    font-family: var(--sy-display);
    font-size: 1.05rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}
.sy-tier-tab__price {
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    color: var(--sy-gold);
    font-weight: 600;
}
.sy-tier-tab.is-active .sy-tier-tab__price { color: var(--sy-gold-light); }

.sy-omakase-cover {
    max-width: 480px;
    margin: 0 auto 80px;
    background: var(--sy-paper);
    box-shadow: var(--sy-shadow-sm);
}
.sy-omakase-cover img { width: 100%; height: auto; display: block; }

.sy-omakase-tier {
    margin-bottom: 96px;
    scroll-margin-top: 120px;
}
.sy-omakase-tier__head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 32px;
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--sy-line);
}
.sy-omakase-tier__head h2 {
    font-family: var(--sy-display);
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    margin: 8px 0 4px;
}
.sy-omakase-tier__note {
    color: var(--sy-muted);
    font-size: 0.95rem;
    margin: 0;
}
.sy-omakase-tier__price-block {
    text-align: right;
    flex-shrink: 0;
}
.sy-omakase-tier__price {
    font-family: var(--sy-display);
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    color: var(--sy-gold);
    font-weight: 600;
    display: block;
    line-height: 1;
}
.sy-omakase-tier__per {
    font-size: 0.7rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-top: 6px;
    display: block;
}
.sy-omakase-tier__img {
    max-width: 480px;
    margin: 0 auto;
    background: var(--sy-paper);
    box-shadow: var(--sy-shadow-sm);
    transition: transform 0.4s var(--sy-trans), box-shadow 0.4s var(--sy-trans);
}
.sy-omakase-tier__img:hover {
    transform: translateY(-4px);
    box-shadow: var(--sy-shadow);
}
.sy-omakase-tier__img img { width: 100%; height: auto; display: block; }
.sy-omakase-tier__placeholder {
    max-width: 480px;
    margin: 0 auto;
    aspect-ratio: 827 / 2244;
    background: linear-gradient(180deg,
        var(--sy-paper) 0%,
        var(--sy-washi-soft) 50%,
        var(--sy-paper) 100%);
    box-shadow: var(--sy-shadow-sm);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 48px 32px;
    text-align: center;
}
.sy-omakase-tier__placeholder-mark {
    font-family: var(--sy-display);
    font-size: 6rem;
    color: var(--sy-gold);
    opacity: 0.7;
    line-height: 1;
    margin-bottom: 24px;
}
.sy-omakase-tier__placeholder p {
    color: var(--sy-muted);
    font-style: italic;
    max-width: 32ch;
    line-height: 1.6;
}
.sy-omakase-tier__cta {
    text-align: center;
    margin-top: 32px;
}

.sy-menu-fineprint {
    text-align: center;
    color: var(--sy-muted);
    font-size: 0.9rem;
    font-style: italic;
    max-width: 56ch;
    margin: 64px auto 0;
    line-height: 1.7;
}

@media (max-width: 768px) {
    .sy-tier-tabs { grid-template-columns: repeat(2, 1fr); }
    .sy-omakase-tier__head { flex-direction: column; align-items: flex-start; gap: 12px; }
    .sy-omakase-tier__price-block { text-align: left; }
}

/* ==========================================================================
   Section primitives
   ========================================================================== */
.sy-section {
    padding: 120px 0;
    background: var(--sy-paper);
}
.sy-section--washi { background: var(--sy-washi); }
.sy-section--ink { background: var(--sy-ink); color: var(--sy-washi); }
.sy-section--ink h1, .sy-section--ink h2, .sy-section--ink h3 { color: var(--sy-washi); }
.sy-section--ink .sy-eyebrow { color: var(--sy-gold-light); }

.sy-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px;
}
.sy-container--narrow { max-width: 920px; }
.sy-container--reading { max-width: 720px; }

.sy-section__head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 72px;
}
.sy-section__head h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-top: 16px;
}
.sy-section__head p {
    color: var(--sy-muted);
    font-size: 1.05rem;
    margin-top: 16px;
}

@media (max-width: 768px) {
    .sy-section { padding: 80px 0; }
    .sy-container { padding: 0 20px; }
    .sy-section__head { margin-bottom: 48px; }
}

/* ==========================================================================
   Story / About strip on home
   ========================================================================== */
.sy-story {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}
.sy-story__media {
    position: relative;
    aspect-ratio: 4 / 5;
    background: var(--sy-ink);
    overflow: hidden;
}
.sy-story__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 1.2s var(--sy-trans);
}
.sy-story__media:hover img { transform: scale(1.04); }
.sy-story__media::before {
    content: '寿司';
    position: absolute;
    top: -32px; left: -16px;
    font-family: var(--sy-display);
    font-size: 9rem;
    color: var(--sy-gold);
    opacity: 0.18;
    z-index: 2;
    line-height: 1;
}
.sy-story__copy h2 { font-size: clamp(2rem, 3.6vw, 2.8rem); }
.sy-story__copy p { color: var(--sy-ink-soft); font-size: 1.02rem; line-height: 1.85; }
.sy-story__signature {
    margin-top: 32px;
    font-family: var(--sy-display);
    font-style: italic;
    font-size: 1.1rem;
    color: var(--sy-indigo);
}
@media (max-width: 900px) {
    .sy-story { grid-template-columns: 1fr; gap: 40px; }
    .sy-story__media { aspect-ratio: 3 / 4; max-width: 480px; margin: 0 auto; }
}

/* ==========================================================================
   Signature dishes grid
   ========================================================================== */
.sy-dishes {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.sy-dish-card {
    background: var(--sy-paper);
    border: 1px solid var(--sy-line);
    overflow: hidden;
    transition: all 0.3s var(--sy-trans);
}
.sy-dish-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sy-shadow);
    border-color: transparent;
}
.sy-dish-card__img-wrap {
    aspect-ratio: 4/3;
    overflow: hidden;
    background: var(--sy-washi);
    position: relative;
}
.sy-dish-card__img-wrap img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--sy-trans);
}
.sy-dish-card:hover .sy-dish-card__img-wrap img { transform: scale(1.05); }
.sy-dish-card__placeholder {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--sy-washi) 0%, var(--sy-washi-soft) 100%);
    color: var(--sy-gold);
    font-family: var(--sy-display);
    font-size: 4rem;
}
.sy-dish-card__body { padding: 28px 24px; }
.sy-dish-card__cat {
    font-size: 0.65rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-gold);
    font-weight: 600;
    margin-bottom: 10px;
}
.sy-dish-card__name {
    font-family: var(--sy-display);
    font-size: 1.4rem;
    margin-bottom: 8px;
    color: var(--sy-ink);
}
.sy-dish-card__desc {
    color: var(--sy-muted);
    font-size: 0.92rem;
    line-height: 1.65;
    margin-bottom: 16px;
    min-height: 3.3em;
}
.sy-dish-card__price {
    font-family: var(--sy-display);
    font-size: 1.05rem;
    color: var(--sy-indigo);
    font-weight: 500;
}
@media (max-width: 900px) { .sy-dishes { grid-template-columns: repeat(2, 1fr); gap: 20px; } }
@media (max-width: 600px) { .sy-dishes { grid-template-columns: 1fr; } }

/* ==========================================================================
   Outlet card
   ========================================================================== */
.sy-outlet {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
}
.sy-outlet__map {
    aspect-ratio: 4/3;
    background: var(--sy-ink);
    position: relative;
    overflow: hidden;
}
.sy-outlet__map img {
    width: 100%; height: 100%; object-fit: cover; opacity: 0.85;
}
.sy-outlet__detail h3 { font-size: clamp(1.6rem, 2.6vw, 2.2rem); }
.sy-outlet__rows { margin: 24px 0; padding: 0; list-style: none; }
.sy-outlet__rows li {
    display: flex;
    gap: 18px;
    padding: 14px 0;
    border-bottom: 1px solid var(--sy-line-soft);
    font-size: 0.95rem;
}
.sy-outlet__rows i {
    color: var(--sy-gold);
    font-size: 1.1rem;
    margin-top: 2px;
    width: 22px;
    text-align: center;
}
.sy-outlet__rows strong {
    display: block;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-bottom: 4px;
}
@media (max-width: 900px) { .sy-outlet { grid-template-columns: 1fr; gap: 32px; } }

/* ==========================================================================
   CTA strip
   ========================================================================== */
.sy-cta-strip {
    text-align: center;
    padding: 100px 32px;
    background: var(--sy-ink) url('/img/Sushi-Yoshi-cta.jpg') center / cover no-repeat;
    position: relative;
    color: var(--sy-washi);
}
.sy-cta-strip::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(20,23,28,0.78);
}
.sy-cta-strip > * { position: relative; z-index: 2; }
.sy-cta-strip h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--sy-washi);
    margin-bottom: 16px;
}
.sy-cta-strip p {
    color: rgba(245,241,232,0.8);
    max-width: 56ch;
    margin: 0 auto 32px;
    font-size: 1.05rem;
}

/* ==========================================================================
   Buttons
   ========================================================================== */
.sy-btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 14px 32px;
    font-family: var(--sy-sans);
    font-size: 0.85rem;
    font-weight: 500;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border: 1px solid var(--sy-ink);
    background: var(--sy-ink);
    color: var(--sy-washi);
    cursor: pointer;
    transition: all 0.25s var(--sy-trans);
}
.sy-btn:hover {
    background: var(--sy-sakura);
    border-color: var(--sy-sakura);
    color: #fff;
    transform: translateY(-1px);
}
.sy-btn--ghost {
    background: transparent;
    color: var(--sy-ink);
    border-color: var(--sy-ink);
}
.sy-btn--ghost:hover { background: var(--sy-ink); color: var(--sy-washi); }
.sy-btn--light {
    background: var(--sy-washi);
    border-color: var(--sy-washi);
    color: var(--sy-ink);
}
.sy-btn--light:hover { background: var(--sy-sakura); color: #fff; border-color: var(--sy-sakura); }
.sy-btn--block { display: flex; width: 100%; justify-content: center; }

/* ==========================================================================
   Menu page
   ========================================================================== */
.sy-menu-page {
    padding: 80px 0 120px;
    background: var(--sy-paper);
}
.sy-menu-tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 64px;
    border-bottom: 1px solid var(--sy-line);
    padding-bottom: 24px;
}
.sy-menu-tab {
    padding: 10px 22px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--sy-muted);
    cursor: pointer;
    font-family: var(--sy-sans);
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 500;
    transition: all 0.2s var(--sy-trans);
}
.sy-menu-tab:hover { color: var(--sy-ink); }
.sy-menu-tab.is-active {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-menu-category {
    margin-bottom: 80px;
    scroll-margin-top: 96px;
}
.sy-menu-category__head {
    text-align: center;
    margin-bottom: 48px;
}
.sy-menu-category__name {
    font-family: var(--sy-display);
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    color: var(--sy-ink);
    position: relative;
    display: inline-block;
}
.sy-menu-category__name::before,
.sy-menu-category__name::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 48px;
    height: 1px;
    background: var(--sy-gold);
}
.sy-menu-category__name::before { left: -64px; }
.sy-menu-category__name::after  { right: -64px; }
.sy-menu-items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 64px;
}
.sy-menu-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 24px;
    padding: 24px 0;
    border-bottom: 1px dashed var(--sy-line);
}
.sy-menu-item__name {
    font-family: var(--sy-display);
    font-size: 1.2rem;
    color: var(--sy-ink);
    margin-bottom: 6px;
    font-weight: 500;
}
.sy-menu-item__desc {
    font-size: 0.9rem;
    color: var(--sy-muted);
    line-height: 1.6;
}
.sy-menu-item__price {
    font-family: var(--sy-display);
    font-size: 1.15rem;
    color: var(--sy-indigo);
    white-space: nowrap;
    font-weight: 500;
}
.sy-menu-item__badge {
    display: inline-block;
    margin-left: 6px;
    padding: 2px 8px;
    background: var(--sy-sakura);
    color: #fff;
    font-size: 0.65rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    vertical-align: middle;
}
@media (max-width: 768px) {
    .sy-menu-items { grid-template-columns: 1fr; gap: 0 0; }
    .sy-menu-category__name::before,
    .sy-menu-category__name::after { display: none; }
}

/* ==========================================================================
   Long-form pages (About, Terms)
   ========================================================================== */
.sy-page {
    padding: 96px 0 120px;
}
.sy-page__title {
    text-align: center;
    margin-bottom: 56px;
}
.sy-page__title h1 {
    font-size: clamp(2.4rem, 4.5vw, 3.4rem);
    margin-top: 16px;
}
.sy-page__title p {
    color: var(--sy-muted);
    max-width: 56ch;
    margin: 16px auto 0;
}
.sy-rich {
    font-size: 1.02rem;
    line-height: 1.85;
    color: var(--sy-ink-soft);
}
.sy-rich h1, .sy-rich h2, .sy-rich h3 {
    font-family: var(--sy-display);
    color: var(--sy-ink);
    margin-top: 2em;
    margin-bottom: 0.6em;
}
.sy-rich h2 { font-size: 1.6rem; }
.sy-rich h3 { font-size: 1.3rem; }
.sy-rich p, .sy-rich ul, .sy-rich ol { margin-bottom: 1.2em; }
.sy-rich ul, .sy-rich ol { padding-left: 1.4em; }
.sy-rich li { margin-bottom: 0.4em; }
.sy-rich a { color: var(--sy-indigo); border-bottom: 1px solid var(--sy-gold); }
.sy-rich strong { color: var(--sy-ink); font-weight: 600; }
.sy-rich blockquote {
    margin: 2em 0;
    padding: 1.2em 1.6em;
    background: var(--sy-washi);
    border-left: 3px solid var(--sy-gold);
    font-style: italic;
}

/* ==========================================================================
   Booking page
   ========================================================================== */
.sy-booking {
    padding: 64px 0 96px;
    background: var(--sy-paper);
}
.sy-booking--landing { padding-top: 56px; }
.sy-landing-intro {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 56px;
}
.sy-landing-intro h1 {
    font-family: var(--sy-display);
    font-size: clamp(2rem, 4vw, 2.8rem);
    margin: 16px 0 14px;
}
.sy-landing-intro p {
    color: var(--sy-ink-soft);
    font-size: 1.02rem;
    line-height: 1.7;
}
.sy-landing-intro p strong { color: var(--sy-ink); }
@media (max-width: 768px) {
    .sy-landing-intro { margin-bottom: 36px; }
}
.sy-booking__layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 56px;
    align-items: start;
}
.sy-booking__form {
    background: #fff;
    border: 1px solid var(--sy-line);
    padding: 48px;
}
.sy-booking__step {
    margin-bottom: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid var(--sy-line-soft);
}
.sy-booking__step:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }
.sy-booking__step-head {
    display: flex;
    align-items: baseline;
    gap: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.sy-booking__step-aside {
    margin-left: auto;
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
}
.sy-booking__step-aside strong { color: var(--sy-ink); }
.sy-booking__hint {
    color: var(--sy-muted);
    font-size: 0.92rem;
    line-height: 1.6;
    display: block;
}
.sy-booking__step-num {
    font-family: var(--sy-display);
    font-size: 1rem;
    color: var(--sy-gold);
    font-weight: 600;
    letter-spacing: 0.2em;
}
.sy-booking__step-title {
    font-family: var(--sy-display);
    font-size: 1.4rem;
    color: var(--sy-ink);
    margin: 0;
}
.sy-booking__pax,
.sy-booking__times {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.sy-pax-btn,
.sy-time-btn {
    background: var(--sy-paper);
    border: 1px solid var(--sy-line);
    color: var(--sy-ink);
    padding: 12px 16px;
    font-family: var(--sy-sans);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s var(--sy-trans);
    min-width: 56px;
    text-align: center;
    border-radius: 4px;
}
.sy-pax-btn:hover,
.sy-time-btn:hover { border-color: var(--sy-ink); }
.sy-pax-btn.is-active,
.sy-time-btn.is-active {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-time-btn.is-full,
.sy-time-btn.is-disabled,
.sy-time-btn[disabled] {
    opacity: 0.45;
    cursor: not-allowed;
    background: var(--sy-washi);
    color: var(--sy-muted);
    pointer-events: none;
}
.sy-time-btn.is-tight { border-color: var(--sy-sakura); color: var(--sy-sakura); }
.sy-time-btn { display: inline-flex; flex-direction: column; align-items: center; gap: 2px; line-height: 1.2; padding: 10px 14px; min-width: 76px; }
.sy-time-btn__time { font-size: 0.95rem; font-weight: 600; letter-spacing: 0.02em; }
.sy-time-btn__meta { font-size: 0.68rem; letter-spacing: 0.04em; color: var(--sy-muted); text-transform: uppercase; }
.sy-time-btn.is-active .sy-time-btn__meta { color: rgba(255,255,255,0.75); }
.sy-time-btn.is-disabled .sy-time-btn__meta,
.sy-time-btn[disabled] .sy-time-btn__meta { text-transform: uppercase; font-weight: 600; }

/* ===== Inline month-grid calendar (replaces the old date pill row + Pick-date tile) ===== */
.sy-cal {
    background: var(--sy-paper);
    border: 1px solid var(--sy-line);
    border-radius: 4px;
    padding: 18px 20px 14px;
    box-shadow: var(--sy-shadow-sm);
}
.sy-cal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}
.sy-cal-title {
    font-family: var(--sy-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--sy-ink);
    letter-spacing: 0.02em;
    text-align: center;
    flex: 1 1 auto;
}
.sy-cal-nav {
    background: transparent;
    border: 1px solid var(--sy-line);
    color: var(--sy-ink);
    width: 36px;
    height: 36px;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 0.9rem;
    transition: all 0.2s var(--sy-trans);
}
.sy-cal-nav:hover:not(:disabled) {
    border-color: var(--sy-ink);
    background: var(--sy-washi);
}
.sy-cal-nav:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}
.sy-cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
    margin-bottom: 6px;
}
.sy-cal-weekdays span {
    text-align: center;
    font-size: 0.66rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    padding: 6px 0;
}
.sy-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}
.sy-cal-day {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    aspect-ratio: 1 / 1;
    min-height: 44px;
    border: 1px solid transparent;
    border-radius: 4px;
    color: var(--sy-ink);
    background: transparent;
    cursor: pointer;
    transition: all 0.18s var(--sy-trans);
    user-select: none;
    box-sizing: border-box;
    padding: 4px 2px;
}
.sy-cal-day__num {
    font-family: var(--sy-display);
    font-size: 1.05rem;
    font-weight: 500;
    line-height: 1;
}
.sy-cal-day__chip {
    margin-top: 3px;
    font-size: 0.55rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--sy-gold);
    font-weight: 600;
}
.sy-cal-day:not(.sy-cal-day--disabled):not(.sy-cal-day--locked):not(.sy-cal-day--selected):hover {
    border-color: var(--sy-ink);
    background: var(--sy-washi);
}
.sy-cal-day:focus-visible {
    outline: 2px solid var(--sy-gold);
    outline-offset: 2px;
}
.sy-cal-day--blank {
    pointer-events: none;
    cursor: default;
}
.sy-cal-day--today {
    border-color: var(--sy-gold);
    background: rgba(184, 148, 90, 0.08);
}
.sy-cal-day--today .sy-cal-day__num { color: var(--sy-ink); }
.sy-cal-day--selected,
.sy-cal-day--selected:hover {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
    color: var(--sy-washi);
    box-shadow: 0 2px 8px rgba(20,23,28,0.18);
    transform: translateY(-1px);
}
.sy-cal-day--selected .sy-cal-day__num { color: var(--sy-washi); }
.sy-cal-day--selected .sy-cal-day__chip { color: var(--sy-gold-light); }
.sy-cal-day--selected::after {
    content: "";
    position: absolute;
    top: 4px;
    right: 4px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--sy-gold);
}
.sy-cal-day--disabled {
    color: var(--sy-muted);
    opacity: 0.32;
    cursor: not-allowed;
    pointer-events: none;
}
.sy-cal-day--locked {
    color: var(--sy-muted);
    opacity: 0.45;
    cursor: not-allowed;
    text-decoration: line-through;
}
.sy-cal-day--locked:hover {
    border-color: transparent;
    background: transparent;
}
.sy-cal-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--sy-line-soft);
    font-size: 0.72rem;
    color: var(--sy-muted);
    letter-spacing: 0.04em;
}
.sy-cal-legend__item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.sy-cal-legend__sw {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 3px;
    border: 1px solid var(--sy-line);
}
.sy-cal-legend__sw--today {
    border-color: var(--sy-gold);
    background: rgba(184, 148, 90, 0.18);
}
.sy-cal-legend__sw--selected {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
}
.sy-cal-legend__sw--locked {
    background: var(--sy-line);
    opacity: 0.5;
}
@media (max-width: 540px) {
    .sy-cal { padding: 14px 10px 10px; }
    .sy-cal-title { font-size: 1.1rem; }
    .sy-cal-day { min-height: 38px; padding: 2px; }
    .sy-cal-day__num { font-size: 0.95rem; }
    .sy-cal-day__chip { font-size: 0.5rem; letter-spacing: 0.1em; }
    .sy-cal-weekdays span { font-size: 0.58rem; padding: 4px 0; letter-spacing: 0.12em; }
    .sy-cal-grid { gap: 3px; }
    .sy-cal-weekdays { gap: 3px; }
    .sy-cal-legend { gap: 10px; font-size: 0.66rem; }
}

.sy-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.sy-form-field { display: flex; flex-direction: column; }
.sy-form-field label {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-bottom: 8px;
}
.sy-form-field label .req { color: var(--sy-sakura); }
.sy-form-field input,
.sy-form-field textarea {
    border: 1px solid var(--sy-line);
    background: var(--sy-paper);
    color: var(--sy-ink);
    padding: 14px 16px;
    font-family: var(--sy-sans);
    font-size: 0.95rem;
    transition: border-color 0.2s var(--sy-trans);
}
.sy-form-field input:focus,
.sy-form-field textarea:focus {
    outline: none;
    border-color: var(--sy-ink);
    background: #fff;
}
.sy-form-field textarea { resize: vertical; min-height: 96px; }
.sy-form-field--full { grid-column: 1 / -1; }

/* ===== Tier card grid (Menu = step 01) ===== */
.sy-tier-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
@media (max-width: 1100px) { .sy-tier-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .sy-tier-grid { grid-template-columns: 1fr; } }

.sy-tier-card {
    border: 1px solid var(--sy-line);
    background: #fff;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: all 0.25s var(--sy-trans);
}
.sy-tier-card.is-selected {
    border-color: var(--sy-ink);
    box-shadow: 0 0 0 1px var(--sy-ink), var(--sy-shadow);
}
.sy-tier-card.is-locked {
    opacity: 0.55;
    background: var(--sy-washi-soft);
}
.sy-tier-card__art {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1.25;
    border: 0;
    padding: 0;
    background: var(--sy-washi);
    cursor: zoom-in;
    overflow: hidden;
    display: block;
}
.sy-tier-card__art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    transition: transform 0.6s var(--sy-trans);
}
.sy-tier-card__art:hover img { transform: scale(1.04); }
.sy-tier-card__art-zoom {
    position: absolute;
    bottom: 12px; right: 12px;
    background: rgba(20,23,28,0.78);
    color: var(--sy-washi);
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 6px 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}
.sy-tier-card__placeholder {
    position: absolute; inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, var(--sy-paper) 0%, var(--sy-washi-soft) 60%, var(--sy-paper) 100%);
    gap: 16px;
}
.sy-tier-card__placeholder-mark {
    font-family: var(--sy-display);
    font-size: 5rem;
    color: var(--sy-gold);
    opacity: 0.6;
    line-height: 1;
}
.sy-tier-card__placeholder-label {
    font-size: 0.7rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
}
.sy-tier-card__body {
    padding: 20px 22px 22px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    flex: 1;
}
.sy-tier-card__row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.sy-tier-card__name {
    font-family: var(--sy-display);
    font-size: 1.2rem;
    font-weight: 500;
    color: var(--sy-ink);
    line-height: 1.2;
}
.sy-tier-card__jp {
    font-family: var(--sy-display);
    font-size: 0.92rem;
    color: var(--sy-gold);
    margin-top: 4px;
}
.sy-tier-card__price {
    text-align: right;
    font-family: var(--sy-display);
    font-size: 1.15rem;
    color: var(--sy-indigo);
    font-weight: 600;
    line-height: 1.1;
    flex-shrink: 0;
}
.sy-tier-card__price span {
    display: block;
    font-family: var(--sy-sans);
    font-size: 0.6rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-top: 4px;
}
.sy-tier-card__desc {
    font-size: 0.88rem;
    color: var(--sy-muted);
    line-height: 1.55;
    margin: 0;
}
.sy-tier-card__notice {
    background: var(--sy-washi);
    border-left: 2px solid var(--sy-gold);
    padding: 8px 12px;
    color: var(--sy-ink-soft);
    font-size: 0.8rem;
    line-height: 1.5;
}
.sy-tier-card__qty {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px dashed var(--sy-line);
}
/* Split layout: per-tier Adults + Kids rows stack on top of each other */
.sy-tier-card__qty--split {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
}
.sy-tier-pax-row {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}
.sy-tier-pax-label {
    display: inline-flex;
    align-items: center;
    font-size: 0.62rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    min-width: 42px;
}
.sy-tier-pax-label i {
    font-size: 0.95rem;
    color: var(--sy-ink-soft);
    letter-spacing: normal;
}
.sy-tier-card__qty-label {
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
}

.sy-takumi-note {
    margin-top: 16px;
    padding: 12px 16px;
    background: var(--sy-washi);
    border-left: 3px solid var(--sy-sakura);
    color: var(--sy-ink);
    font-size: 0.88rem;
    line-height: 1.55;
}
.sy-takumi-note i { color: var(--sy-sakura); margin-right: 6px; }

/* ===== Lightbox ===== */
.sy-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(8,6,4,0.95);
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 32px;
}
.sy-lightbox.is-open { display: flex; }
.sy-lightbox__stage {
    margin: 0;
    max-width: min(90vw, 720px);
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
.sy-lightbox__stage img {
    max-width: 100%;
    max-height: 78vh;
    object-fit: contain;
    box-shadow: 0 24px 80px rgba(0,0,0,0.5);
}
.sy-lightbox__stage figcaption {
    color: rgba(245, 241, 232, 0.85);
    font-family: var(--sy-display);
    font-size: 1rem;
    letter-spacing: 0.04em;
    text-align: center;
}
.sy-lightbox__close,
.sy-lightbox__nav {
    position: absolute;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.18);
    color: var(--sy-washi);
    width: 48px; height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s var(--sy-trans);
    backdrop-filter: blur(8px);
}
.sy-lightbox__close:hover,
.sy-lightbox__nav:hover {
    background: var(--sy-sakura);
    border-color: var(--sy-sakura);
}
.sy-lightbox__close { top: 24px; right: 24px; font-size: 1.2rem; }
.sy-lightbox__nav { top: 50%; transform: translateY(-50%); font-size: 1.4rem; }
.sy-lightbox__nav--prev { left: 24px; }
.sy-lightbox__nav--next { right: 24px; }
@media (max-width: 768px) {
    .sy-lightbox { padding: 16px; }
    .sy-lightbox__close { top: 12px; right: 12px; width: 40px; height: 40px; }
    .sy-lightbox__nav { width: 40px; height: 40px; }
    .sy-lightbox__nav--prev { left: 8px; }
    .sy-lightbox__nav--next { right: 8px; }
}

/* Menu picker (booking step 04) */
.sy-menu-picker {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.sy-menu-pick {
    border: 1px solid var(--sy-line);
    background: var(--sy-paper);
    padding: 20px 24px;
    transition: all 0.2s var(--sy-trans);
}
.sy-menu-pick:hover { border-color: var(--sy-ink); }
.sy-menu-pick.is-locked {
    opacity: 0.55;
    background: var(--sy-washi-soft);
}
.sy-menu-pick.is-locked .sy-menu-pick__notice {
    background: var(--sy-sakura-soft);
    color: var(--sy-ink);
    border-left-color: var(--sy-sakura);
}
.sy-menu-pick__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    margin-bottom: 14px;
}
.sy-menu-pick__name {
    font-family: var(--sy-display);
    font-size: 1.15rem;
    font-weight: 500;
    color: var(--sy-ink);
}
.sy-menu-pick__jp {
    font-family: var(--sy-display);
    font-size: 0.88rem;
    color: var(--sy-gold);
    margin-top: 2px;
}
.sy-menu-pick__desc {
    font-size: 0.88rem;
    color: var(--sy-muted);
    margin-top: 8px;
    line-height: 1.55;
}
.sy-menu-pick__price {
    text-align: right;
    font-family: var(--sy-display);
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--sy-indigo);
    line-height: 1.1;
    flex-shrink: 0;
}
.sy-menu-pick__price span {
    display: block;
    font-family: var(--sy-sans);
    font-size: 0.6rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-top: 4px;
}
.sy-menu-pick__qty {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    border: 1px solid var(--sy-line);
    background: #fff;
    padding: 2px;
}
.sy-menu-pick__qty input {
    width: 32px;
    text-align: center;
    border: 0;
    font-family: var(--sy-display);
    font-size: 16px; /* iOS Safari auto-zooms when an input <16px gets focus, even with user-scalable=no */
    color: var(--sy-ink);
    background: transparent;
    outline: none;
    -moz-appearance: textfield;
    pointer-events: none; /* tap goes to the +/- buttons; don't focus the readonly field */
}
.sy-menu-pick__qty input::-webkit-outer-spin-button,
.sy-menu-pick__qty input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sy-qty-btn {
    width: 26px; height: 26px;
    flex: 0 0 26px;
    background: transparent;
    border: 0;
    cursor: pointer;
    color: var(--sy-ink);
    font-size: 1.05rem;
    line-height: 1;
    padding: 0;
    transition: background 0.15s var(--sy-trans);
}
.sy-qty-btn:hover:not(:disabled) { background: var(--sy-washi); }
.sy-qty-btn:disabled { color: var(--sy-line); cursor: not-allowed; }
.sy-menu-pick__notice {
    margin-top: 12px;
    padding: 8px 12px;
    background: var(--sy-washi);
    border-left: 2px solid var(--sy-gold);
    color: var(--sy-ink-soft);
    font-size: 0.82rem;
    line-height: 1.5;
}
.sy-kids-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-top: 18px;
    padding: 14px 18px;
    background: var(--sy-paper, #fcf9f3);
    border: 1px solid var(--sy-rule, #e7dec9);
    border-radius: 8px;
}
.sy-kids-row__label { display: flex; flex-direction: column; gap: 2px; }
.sy-kids-row__label strong {
    font-family: var(--sy-display);
    font-size: 0.95rem;
    color: var(--sy-ink);
}
.sy-kids-row__label small {
    font-size: 0.72rem;
    color: var(--sy-ink-soft);
}

.sy-menu-total {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
    padding: 16px 20px;
    background: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-menu-total > div { display: flex; flex-direction: column; gap: 4px; }
.sy-menu-total span {
    font-size: 0.65rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--sy-gold-light);
    font-weight: 600;
}
.sy-menu-total strong {
    font-family: var(--sy-display);
    font-size: 1.1rem;
    color: var(--sy-washi);
}
.sy-menu-total__note {
    font-size: 0.62rem;
    letter-spacing: 0.04em;
    text-transform: none;
    font-weight: 400;
    color: var(--sy-gold-light);
    opacity: 0.75;
    margin-top: 2px;
}

/* Occasion picker */
.sy-occasions {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 8px;
}
.sy-occasion {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 8px;
    border: 1px solid var(--sy-line);
    background: var(--sy-paper);
    cursor: pointer;
    transition: all 0.2s var(--sy-trans);
    text-align: center;
}
.sy-occasion:hover { border-color: var(--sy-ink); }
.sy-occasion.is-active {
    background: var(--sy-ink);
    border-color: var(--sy-ink);
    color: var(--sy-washi);
}
.sy-occasion input { display: none; }
.sy-occasion i { font-size: 1.4rem; color: var(--sy-gold); }
.sy-occasion.is-active i { color: var(--sy-gold-light); }
.sy-occasion span {
    font-size: 0.78rem;
    font-weight: 500;
}
@media (max-width: 768px) { .sy-occasions { grid-template-columns: repeat(3, 1fr); } }

.sy-tnc-box {
    background: var(--sy-washi);
    border-left: 3px solid var(--sy-gold);
    padding: 20px 24px;
    margin: 8px 0 16px;
    max-height: 240px;
    overflow-y: auto;
    font-size: 0.92rem;
    line-height: 1.7;
}
.sy-tnc-box p { margin-bottom: 0.8em; }
.sy-tnc-box strong { color: var(--sy-ink); }

.sy-checkbox {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
    font-size: 0.92rem;
    color: var(--sy-ink-soft);
    user-select: none;
}
.sy-checkbox input { margin-top: 4px; flex-shrink: 0; transform: scale(1.15); accent-color: var(--sy-ink); }

.sy-booking__sidebar {
    position: sticky;
    top: 96px;
    background: var(--sy-ink);
    color: var(--sy-washi);
    padding: 40px 32px;
}
.sy-booking__sidebar h3 {
    color: var(--sy-washi);
    font-size: 1.5rem;
}
.sy-booking__sidebar .sy-eyebrow { color: var(--sy-gold-light); }
.sy-booking__sidebar p { color: rgba(245,241,232,0.78); font-size: 0.92rem; }
.sy-booking__summary {
    margin: 24px 0;
    padding: 24px 0;
    border-top: 1px solid rgba(245,241,232,0.18);
    border-bottom: 1px solid rgba(245,241,232,0.18);
}
.sy-booking__summary-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    font-size: 0.92rem;
}
.sy-booking__summary-row span:first-child {
    color: rgba(245,241,232,0.65);
    letter-spacing: 0.08em;
    font-size: 0.78rem;
    text-transform: uppercase;
}
.sy-booking__summary-row span:last-child {
    font-family: var(--sy-display);
    color: var(--sy-washi);
    font-size: 1.05rem;
}

.sy-alert {
    padding: 16px 20px;
    background: var(--sy-washi);
    border-left: 3px solid var(--sy-sakura);
    margin-bottom: 24px;
    color: var(--sy-ink);
    font-size: 0.92rem;
    line-height: 1.6;
}
.sy-alert--ok { border-left-color: var(--sy-gold); }

/* ----- Inline form validation panel ----- */
.sy-form-error {
    background: #fff5f3;
    border: 1px solid #f3c8c1;
    border-left: 4px solid var(--sy-sakura);
    padding: 16px 20px 18px;
    margin-bottom: 24px;
    border-radius: 6px;
}
.sy-form-error__head {
    display: flex; align-items: center; gap: 10px;
    color: #8c3a30;
    font-weight: 600;
    margin-bottom: 8px;
}
.sy-form-error__head i { font-size: 1.05rem; }
.sy-form-error__list {
    margin: 0; padding-left: 22px;
    color: #5d2a23;
    font-size: 0.92rem; line-height: 1.65;
}
.sy-form-error__list li + li { margin-top: 2px; }

/* Shake to draw the eye when the error panel reappears */
@keyframes sy-shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-4px); }
    40% { transform: translateX(4px); }
    60% { transform: translateX(-3px); }
    80% { transform: translateX(2px); }
}
.sy-shake { animation: sy-shake 0.45s ease; }

/* ----- Loading overlay (shown while submitting) ----- */
.sy-loading-overlay {
    position: fixed; inset: 0;
    background: rgba(20, 23, 28, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    z-index: 9999;
    opacity: 0; visibility: hidden;
    transition: opacity 0.25s ease, visibility 0s linear 0.25s;
}
.sy-loading-overlay.is-on {
    opacity: 1; visibility: visible;
    transition: opacity 0.25s ease, visibility 0s linear 0s;
}
.sy-loading-overlay__panel {
    background: var(--sy-paper, #f5f1e8);
    color: var(--sy-ink, #14171c);
    padding: 36px 48px;
    border-radius: 6px;
    text-align: center;
    box-shadow: 0 24px 60px rgba(0,0,0,0.3);
    max-width: 420px;
    border-top: 3px solid var(--sy-gold, #b8945a);
}
.sy-loading-overlay__seal {
    width: 64px; height: 64px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--sy-gold, #b8945a);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem;
}
.sy-loading-overlay__seal i { animation: spin 1.1s linear infinite; }
.sy-loading-overlay__title {
    font-family: var(--sy-display, "Cormorant Garamond", serif);
    font-size: 1.45rem;
    font-weight: 600;
    margin-bottom: 6px;
}
.sy-loading-overlay__sub {
    color: var(--sy-muted, #6e6a64);
    font-size: 0.92rem;
    line-height: 1.55;
}
@keyframes spin { 100% { transform: rotate(360deg); } }

@media (max-width: 900px) {
    .sy-booking__layout { grid-template-columns: 1fr; }
    .sy-booking__form { padding: 28px 20px; }
    .sy-booking__sidebar { position: static; padding: 32px 24px; }
    .sy-form-row { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Confirmation
   ========================================================================== */
.sy-confirm {
    padding: 96px 0;
    text-align: center;
    background: var(--sy-paper);
}
.sy-confirm__seal {
    width: 96px; height: 96px;
    margin: 0 auto 24px;
    border: 2px solid var(--sy-sakura);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sy-sakura);
    font-size: 2.4rem;
}
.sy-confirm__id {
    font-family: var(--sy-display);
    font-size: 0.95rem;
    color: var(--sy-muted);
    letter-spacing: 0.18em;
    margin-top: 8px;
}
.sy-confirm__details {
    max-width: 480px;
    margin: 32px auto 0;
    padding: 32px;
    background: #fff;
    border: 1px solid var(--sy-line);
    text-align: left;
}
.sy-confirm__details dl { display: grid; grid-template-columns: auto 1fr; gap: 12px 24px; margin: 0; }
.sy-confirm__details dt {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    align-self: center;
}
.sy-confirm__details dd { margin: 0; font-family: var(--sy-display); font-size: 1.05rem; color: var(--sy-ink); }
.sy-confirm__menus {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--sy-line);
}
.sy-confirm__menus-head {
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
    margin-bottom: 12px;
}
.sy-confirm__menu-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-family: var(--sy-display);
    font-size: 0.95rem;
    color: var(--sy-ink);
}
.sy-confirm__menu-total {
    display: flex;
    justify-content: space-between;
    padding-top: 12px;
    margin-top: 8px;
    border-top: 1px dashed var(--sy-line);
    font-family: var(--sy-display);
    font-size: 1.1rem;
    color: var(--sy-indigo);
    font-weight: 600;
}
.sy-confirm__menu-fineprint {
    font-size: 0.78rem;
    color: var(--sy-muted);
    font-style: italic;
    margin-top: 8px;
    text-align: left;
}

/* ===== Saveable booking pass ===== */
.sy-pass {
    max-width: 540px;
    margin: 16px auto 0;
    background: #fbf8f1;
    border: 1px solid #d4b886;
    padding: 36px 36px 28px;
    text-align: left;
    position: relative;
    box-shadow: 0 8px 32px rgba(20, 23, 28, 0.08);
}
.sy-pass::before {
    content: '寿';
    position: absolute;
    top: 24px; right: 28px;
    font-family: var(--sy-display);
    font-size: 7rem;
    line-height: 1;
    color: rgba(184, 148, 90, 0.10);
    pointer-events: none;
    font-weight: 700;
}

.sy-pass__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding-bottom: 20px;
    border-bottom: 1px dashed rgba(184, 148, 90, 0.4);
}
.sy-pass__brand {
    display: flex;
    gap: 14px;
    align-items: center;
}
.sy-pass__mark {
    width: 44px; height: 44px;
    background: #14171c;
    color: #f5f1e8;
    font-family: var(--sy-display);
    font-size: 1.6rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.sy-pass__logo {
    height: 72px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
    display: block;
}
.sy-pass__brand-name {
    font-family: var(--sy-display);
    font-size: 1.2rem;
    font-weight: 600;
    color: #14171c;
    line-height: 1.1;
}
.sy-pass__brand-line {
    font-size: 0.65rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #b8945a;
    font-weight: 600;
    margin-top: 4px;
}
.sy-pass__ref { text-align: right; }
.sy-pass__ref span {
    font-size: 0.6rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #6b6f78;
    font-weight: 600;
    display: block;
    margin-bottom: 4px;
}
.sy-pass__ref strong {
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 1.05rem;
    color: #14171c;
    letter-spacing: 0.08em;
    font-weight: 700;
}

.sy-pass__title {
    padding: 24px 0 12px;
    text-align: center;
    border-bottom: 1px solid rgba(184, 148, 90, 0.18);
}
.sy-pass__eyebrow {
    font-size: 0.62rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: #b8945a;
    font-weight: 600;
}
.sy-pass__title h2 {
    font-family: var(--sy-display);
    font-size: 1.6rem;
    color: #14171c;
    font-weight: 500;
    margin: 8px 0 0;
}

.sy-pass__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 24px;
    padding: 24px 0;
}
.sy-pass__cell {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.sy-pass__cell span {
    font-size: 0.62rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #6b6f78;
    font-weight: 600;
}
.sy-pass__cell strong {
    font-family: var(--sy-display);
    font-size: 1.05rem;
    color: #14171c;
    font-weight: 500;
}

.sy-pass__menus {
    border-top: 1px dashed rgba(184, 148, 90, 0.4);
    padding-top: 20px;
}
.sy-pass__menus-head {
    font-size: 0.62rem;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: #6b6f78;
    font-weight: 600;
    margin-bottom: 12px;
}
.sy-pass__menu-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-family: var(--sy-display);
    font-size: 0.95rem;
    color: #14171c;
}
.sy-pass__menu-total {
    display: flex;
    justify-content: space-between;
    padding: 12px 0 0;
    margin-top: 8px;
    border-top: 1px solid rgba(184, 148, 90, 0.3);
    font-family: var(--sy-display);
    font-size: 1.1rem;
    color: #1f3b4d;
    font-weight: 600;
}
.sy-pass__fineprint {
    font-size: 0.74rem;
    color: #6b6f78;
    font-style: italic;
    margin-top: 8px;
}

.sy-pass__foot {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px dashed rgba(184, 148, 90, 0.4);
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
}
.sy-pass__addr {
    font-size: 0.78rem;
    color: #2a2f38;
    line-height: 1.7;
}
.sy-pass__addr i {
    color: #b8945a;
    margin-right: 6px;
    width: 16px;
    display: inline-block;
}
.sy-pass__line {
    font-family: var(--sy-display);
    font-style: italic;
    font-size: 0.85rem;
    color: #b8945a;
    text-align: right;
}

@media (max-width: 600px) {
    .sy-pass { padding: 24px 22px 22px; }
    .sy-pass::before { font-size: 5rem; right: 16px; }
    .sy-pass__grid { grid-template-columns: 1fr 1fr; gap: 14px; }
    .sy-pass__foot { flex-direction: column; align-items: flex-start; }
    .sy-pass__line { text-align: left; }
}

.sy-confirm__actions {
    margin-top: 32px;
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
}
.sy-confirm__share {
    margin-top: 16px;
    font-size: 0.85rem;
    color: var(--sy-muted);
    line-height: 1.7;
    max-width: 56ch;
    margin-left: auto;
    margin-right: auto;
}
.sy-confirm__share i { color: var(--sy-gold); margin-right: 4px; }

/* ==========================================================================
   Footer
   ========================================================================== */
.sy-footer {
    background: var(--sy-ink);
    color: rgba(245,241,232,0.75);
    padding: 80px 0 0;
}
.sy-footer__top {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 32px 64px;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
    gap: 48px;
}
.sy-footer__brand { display: flex; gap: 16px; align-items: center; margin-bottom: 16px; }
.sy-footer__mark {
    width: 48px; height: 48px;
    background: var(--sy-washi);
    color: var(--sy-ink);
    font-family: var(--sy-display);
    font-size: 1.6rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.sy-footer__logo {
    width: 80px;
    height: 48px;
    object-fit: contain;
    background: var(--sy-washi);
    padding: 6px 8px;
}
.sy-footer__social {
    margin-top: 16px;
    display: flex;
    gap: 12px;
}
.sy-footer__social a {
    width: 36px; height: 36px;
    border: 1px solid rgba(245,241,232,0.18);
    color: rgba(245,241,232,0.7);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s var(--sy-trans);
}
.sy-footer__social a:hover {
    background: var(--sy-sakura);
    color: #fff;
    border-color: var(--sy-sakura);
}
.sy-footer__name {
    color: var(--sy-washi);
    font-family: var(--sy-display);
    font-size: 1.3rem;
    font-weight: 500;
}
.sy-footer__line {
    font-size: 0.7rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sy-gold-light);
    margin-top: 4px;
}
.sy-footer__about { font-size: 0.92rem; line-height: 1.75; color: rgba(245,241,232,0.6); }
.sy-footer__col h6 {
    color: var(--sy-washi);
    font-family: var(--sy-sans);
    font-size: 0.7rem;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    margin-bottom: 18px;
    font-weight: 600;
}
.sy-footer__col a {
    display: block;
    color: rgba(245,241,232,0.7);
    padding: 6px 0;
    font-size: 0.92rem;
}
.sy-footer__col a:hover { color: var(--sy-sakura-soft); }
.sy-footer__col p { font-size: 0.92rem; color: rgba(245,241,232,0.7); margin-bottom: 8px; }
.sy-footer__cta {
    background: var(--sy-washi);
    color: var(--sy-ink) !important;
    padding: 12px 24px !important;
    text-align: center;
    margin-bottom: 12px;
    font-size: 0.85rem !important;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    font-weight: 500;
}
.sy-footer__cta:hover { background: var(--sy-sakura) !important; color: #fff !important; }
.sy-footer__small { font-size: 0.78rem !important; color: rgba(245,241,232,0.5) !important; }
.sy-footer__bottom {
    border-top: 1px solid rgba(245,241,232,0.12);
    padding: 24px 32px;
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 0.82rem;
    color: rgba(245,241,232,0.5);
}
.sy-footer__legal a { color: rgba(245,241,232,0.7); border-bottom: 1px solid rgba(245,241,232,0.2); }
@media (max-width: 900px) {
    .sy-footer__top { grid-template-columns: 1fr 1fr; gap: 32px; padding-bottom: 40px; }
}
@media (max-width: 600px) {
    .sy-footer__top { grid-template-columns: 1fr; }
    .sy-footer__bottom { flex-direction: column; padding: 20px; }
}

/* ==========================================================================
   HUT buffet additions — brand badge, hero overlay, selectable tier cards,
   guest steppers (kept here so the shared sy-* base above is untouched)
   ========================================================================== */
.sy-brand-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 46px;
    height: 46px;
    border-radius: 12px;
    background: var(--sy-sakura);
    color: var(--sy-washi);
    font-family: var(--sy-display);
    font-weight: 700;
    font-size: 0.95rem;
    letter-spacing: 0.04em;
    line-height: 1;
    flex-shrink: 0;
}
.sy-footer__logo.sy-brand-badge { width: 52px; height: 52px; padding: 0; background: var(--sy-washi); color: var(--sy-ink); }
.sy-pass__logo.sy-brand-badge { width: 52px; height: 52px; padding: 0; background: #b12f2f; color: #f3e8d6; }

/* Hero as a background image with overlay copy */
.sy-hero-banner__img {
    position: relative;
    min-height: clamp(240px, 40vw, 460px);
    background: var(--sy-ink) center / cover no-repeat;
    line-height: normal;
    display: flex;
    align-items: flex-end;
    box-shadow: var(--sy-shadow);
}
.sy-hero-banner__overlay {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 48px 32px;
    color: var(--sy-washi);
}
.sy-hero-banner__eyebrow {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--sy-gold-light);
}
.sy-hero-banner__title {
    font-family: var(--sy-display);
    font-size: clamp(2rem, 5vw, 3.4rem);
    color: var(--sy-washi);
    margin: 10px 0 8px;
    line-height: 1.1;
}
.sy-hero-banner__tag {
    font-size: 1rem;
    color: rgba(243, 232, 214, 0.9);
    margin: 0;
}
@media (max-width: 600px) {
    .sy-hero-banner__overlay { padding: 26px 20px; }
}

/* Selectable buffet tier cards (single choice; <button> reset) */
.sy-tier-card--select {
    position: relative;
    text-align: left;
    cursor: pointer;
    width: 100%;
    font: inherit;
    color: inherit;
    padding: 0;
    background: #fff;
}
.sy-tier-card--select:hover { border-color: var(--sy-ink); }
.sy-tier-card__check {
    position: absolute;
    top: 12px; right: 12px;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--sy-ink);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    opacity: 0;
    transform: scale(0.6);
    transition: all 0.2s var(--sy-trans);
    z-index: 2;
}
.sy-tier-card--select.is-selected .sy-tier-card__check { opacity: 1; transform: scale(1); }
.sy-tier-card__from {
    display: block;
    font-family: var(--sy-sans);
    font-size: 0.58rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--sy-muted);
    font-weight: 600;
}

/* Guests step */
.sy-guest-grid { display: flex; flex-direction: column; gap: 12px; }
.sy-guest-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 16px 18px;
    background: var(--sy-paper);
    border: 1px solid var(--sy-line);
    border-radius: 8px;
}
.sy-guest-row__label { display: flex; flex-direction: column; gap: 3px; max-width: 70%; }
.sy-guest-row__label strong { font-family: var(--sy-display); font-size: 1.02rem; color: var(--sy-ink); }
.sy-guest-row__label small { font-size: 0.76rem; color: var(--sy-muted); line-height: 1.45; }
.sy-guest-row .sy-menu-pick__qty { padding: 4px; }
.sy-guest-row .sy-menu-pick__qty input { width: 40px; font-size: 16px; }
.sy-guest-row .sy-qty-btn { width: 32px; height: 32px; flex: 0 0 32px; }
