/* ==========================================
   MENU NAVIGATION
========================================== */

.menu-nav {

    position: sticky;

    top: 90px;

    z-index: 900;

    background: rgba(11,11,11,.92);

    backdrop-filter: blur(14px);

    border-bottom: 1px solid rgba(255,215,0,.08);
}

.menu-nav__container {

    max-width: 1400px;

    margin: 0 auto;

    padding: 0 5%;

    display: flex;

    justify-content: center;

    gap: 18px;

    overflow-x: auto;

    scrollbar-width: none;
}

.menu-nav__container::-webkit-scrollbar {

    display: none;
}

.menu-nav__link {

    padding: 18px 24px;

    color: var(--gray);

    text-decoration: none;

    font-size: .95rem;

    font-weight: 500;

    white-space: nowrap;

    position: relative;

    transition: .3s ease;
}

.menu-nav__link:hover {

    color: var(--gold);
}

.menu-nav__link::after {

    content: "";

    position: absolute;

    left: 20px;

    right: 20px;

    bottom: 8px;

    height: 2px;

    background: var(--gold);

    transform: scaleX(0);

    transform-origin: center;

    transition: .3s ease;
}

.menu-nav__link:hover::after {

    transform: scaleX(1);
}

.menu-nav__link.active {

    color: var(--gold);
}

.menu-nav__link.active::after {

    transform: scaleX(1);
}

/* ==================================================
   MENU PAGE
================================================== */

.menu-category-section {

    padding: 56px 4% 60px;

    background: var(--black);

    position: relative;
}

.menu-category-section:nth-child(even) {

    background: var(--black-soft);
}

/* ==================================================
   HEADER
================================================== */

.menu-category-header,
.menu-section__header {

    max-width: 850px;

    margin: 0 auto 36px;

    text-align: center;
}

/* ==================================================
   SUBSECTION & CATEGORY
================================================== */

.menu-subsection,
.menu-category {

    margin-top: 40px;
}

.menu-subsection:first-of-type,
.menu-category:first-of-type {

    margin-top: 0;
}

.menu-subsection-title,
.menu-category__title {

    color: var(--gold);

    font-size: 2.5rem;

    font-family: "Cormorant Garamond", serif;

    text-align: center;

    margin-bottom: 36px;
}

.menu-category-header p{
    color: var(--gray);
}

.menu-section__header p{
    color: var(--gray);
}

/* ==================================================
   GRID
================================================== */

.menu-grid {

    display: grid;

    grid-template-columns: repeat(3, 1fr);

    gap: 28px;
}

/* Two-item grids: constrain width so cards don't stretch wall-to-wall */

.menu-grid--small {

    grid-template-columns: repeat(2, 1fr);

    max-width: 760px;

    margin-left: auto;

    margin-right: auto;
}

/* ==================================================
   CARD
================================================== */

.menu-card {

    background: rgba(255,255,255,.03);

    border: 1px solid rgba(255,215,0,.08);

    border-radius: var(--radius);

    overflow: hidden;

    transition:
        transform .35s ease,
        border-color .35s ease,
        box-shadow .35s ease;

    box-shadow: var(--shadow-soft);
}

.menu-card:hover {

    transform: translateY(-6px);

    border-color: rgba(255,215,0,.35);

    box-shadow: 0 20px 40px rgba(0,0,0,.45);
}

/* ==================================================
   IMAGE
================================================== */

.menu-card__image {

    height: 240px;

    overflow: hidden;

    position: relative;

    background: #111;
}

.menu-card__image img {

    width: 100%;

    height: 100%;

    object-fit: cover;

    object-position: center ;

    display: block;

    transition: transform .7s ease;
}

.menu-card:hover .menu-card__image img {

    transform: scale(1.06);
}

/* ==================================================
   GOLD OVERLAY
================================================== */

.menu-card__image::after {

    content: "";

    position: absolute;

    inset: 0;

    background: linear-gradient(
        to top,
        rgba(0,0,0,.55),
        transparent 60%
    );

    pointer-events: none;
}

/* ==================================================
   CARD CLICKABLE
================================================== */

.menu-card {

    cursor: default;
}

/* ==================================================
   EXPLORE BUTTON
================================================== */

.menu-card__btn {

    display: inline-flex;

    align-items: center;

    gap: 7px;

    margin-top: 16px;

    padding: 8px 18px;

    background: transparent;

    border: 1px solid rgba(255,215,0,.35);

    border-radius: 999px;

    color: var(--gold-soft);

    font-family: 'Poppins', sans-serif;

    font-size: .82rem;

    font-weight: 500;

    letter-spacing: .04em;

    cursor: pointer;

    transition:
        background .25s ease,
        border-color .25s ease,
        color .25s ease;
}

.menu-card__btn i {

    font-size: 14px;

    transition: transform .25s ease;
}

.menu-card__btn:hover {

    background: rgba(255,215,0,.1);

    border-color: var(--gold);

    color: var(--gold);
}

.menu-card__btn:hover i {

    transform: translateX(3px);
}

/* ==================================================
   MODAL OVERLAY
================================================== */

.menu-modal-overlay {

    position: fixed;

    inset: 0;

    z-index: 9999;

    background: rgba(0,0,0,.85);

    backdrop-filter: blur(12px);

    display: flex;

    align-items: center;

    justify-content: center;

    padding: 24px;

    opacity: 0;

    pointer-events: none;

    transition: opacity .3s ease;
}

.menu-modal-overlay.open {

    opacity: 1;

    pointer-events: all;
}

/* ==================================================
   MODAL BOX
================================================== */

.menu-modal {

    background: #141414;

    border: 1px solid rgba(255,215,0,.15);

    border-radius: var(--radius);

    width: 100%;

    max-width: 560px;

    max-height: 90vh;

    overflow-y: auto;

    scrollbar-width: thin;

    scrollbar-color: rgba(255,215,0,.15) transparent;

    transform: translateY(20px);

    transition: transform .35s ease;

    position: relative;
}

.menu-modal-overlay.open .menu-modal {

    transform: translateY(0);
}

/* ==================================================
   IMAGE — fully visible, no cropping
================================================== */

.menu-modal__image-wrap {

    width: 100%;

    background: #0d0d0d;

    border-radius: var(--radius) var(--radius) 0 0;

    display: flex;

    align-items: center;

    justify-content: center;

    padding: 24px;
}

.menu-modal__image {

    width: 100%;

    max-height: 340px;

    object-fit: contain;

    object-position: center;

    display: block;

    border-radius: 10px;
}

/* ==================================================
   CONTENT BELOW IMAGE
================================================== */

.menu-modal__body {

    padding: 28px 32px 36px;

    border-top: 1px solid rgba(255,215,0,.08);
}

.menu-modal__eyebrow {

    font-size: .72rem;

    font-weight: 600;

    letter-spacing: .16em;

    text-transform: uppercase;

    color: var(--gold-soft);

    margin-bottom: 10px;
}

.menu-modal__title {

    font-family: "Cormorant Garamond", serif;

    font-size: 1.9rem;

    font-weight: 600;

    color: var(--white);

    line-height: 1.2;

    margin-bottom: 14px;
}

.menu-modal__divider {

    width: 40px;

    height: 2px;

    background: var(--gold-soft);

    border: none;

    margin-bottom: 16px;
}

.menu-modal__desc {

    color: var(--gray);

    font-size: .95rem;

    line-height: 1.85;
}

/* ==================================================
   CLOSE BUTTON
================================================== */

.menu-modal__close {

    position: absolute;

    top: 12px;

    right: 12px;

    width: 34px;

    height: 34px;

    border-radius: 50%;

    background: rgba(0,0,0,.7);

    border: 1px solid rgba(255,255,255,.15);

    color: var(--white);

    font-size: 1rem;

    display: flex;

    align-items: center;

    justify-content: center;

    cursor: pointer;

    transition:
        background .25s ease,
        border-color .25s ease,
        color .25s ease;

    z-index: 2;
}

.menu-modal__close:hover {

    background: rgba(255,215,0,.12);

    border-color: rgba(255,215,0,.5);

    color: var(--gold);
}

/* ==================================================
   MOBILE
================================================== */

@media (max-width: 768px) {

    .menu-modal {

        max-width: 100%;
    }

    .menu-modal__image {

        max-height: 260px;
    }

    .menu-modal__body {

        padding: 22px 20px 32px;
    }

    .menu-modal__title {

        font-size: 1.6rem;
    }
}

/* ==================================================
   CONTENT
================================================== */

.menu-card__content {

    padding: 20px 22px 24px;
}

/* Target h3 and h4 — private dining and dessert sections use h4 */

.menu-card__content h3,
.menu-card__content h4 {

    color: var(--gold-soft);

    font-size: 1.1rem;

    line-height: 1.4;

    margin-bottom: 10px;

    font-weight: 600;

    transition: color .3s ease;
}

.menu-card:hover .menu-card__content h3,
.menu-card:hover .menu-card__content h4 {

    color: var(--gold);
}

.menu-card__content p {

    color: var(--gray);

    line-height: 1.75;

    font-size: .9rem;

    margin: 0;
}

/* ==================================================
   REVEAL ANIMATION
================================================== */

.fade-up {

    opacity: 0;

    transform: translateY(28px);

    transition:
        opacity .75s ease,
        transform .75s ease;

    transition-delay: var(--delay, 0s);
}

.fade-up.show {

    opacity: 1;

    transform: translateY(0);
}

/* ==================================================
   CTA
================================================== */

.menu-cta {

    padding: 60px 4%;

    text-align: center;

    background: var(--black-soft);

    border-top: 1px solid rgba(255,215,0,.08);
}

.menu-cta h2 {

    font-family: "Cormorant Garamond", serif;

    font-size: 2.4rem;

    color: var(--white);

    margin-bottom: 14px;
}

.menu-cta p {

    color: var(--gray);

    margin-bottom: 32px;

    font-size: 1rem;
}

/* ==================================================
   TABLET
================================================== */

@media (max-width: 1100px) {

    .menu-grid {

        grid-template-columns: repeat(2, 1fr);
    }

    .menu-grid--small {

        grid-template-columns: repeat(2, 1fr);

        max-width: 100%;
    }
}

/* ==================================================
   MOBILE
================================================== */

@media (max-width: 768px) {

    .menu-category-section {

        padding: 56px 5% 64px;
    }

    .menu-subsection,
    .menu-category {

        margin-top: 40px;
    }

    .menu-grid {

        grid-template-columns: 1fr;
    }

    .menu-grid--small {

        grid-template-columns: 1fr;

        max-width: 100%;
    }

    .menu-card__image {

        height: 210px;
    }

    .menu-subsection-title,
    .menu-category__title {

        font-size: 1.5rem;
    }
}