/* ============================================================
   MENU.CSS — Food Park Charleroi
   Page-specific styles for menu.php only
   Depends on global.css (tokens, buttons, nav, footer)
   ============================================================ */

/* ── SHARED ACCENT HELPERS ────────────────────────────────── */
.neon-y  { color: var(--yellow);  text-shadow: var(--glow-yellow); }
.neon-m  { color: var(--magenta); text-shadow: var(--glow-magenta); }
.serif-acc {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 500;
    color: var(--brass-2); text-shadow: none;
}
.section-eyebrow {
    display: inline-flex; align-items: center; gap: 12px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px; letter-spacing: .25em; text-transform: uppercase;
    color: var(--brass); margin-bottom: 16px;
}
.section-eyebrow::before {
    content: ""; width: 36px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--brass));
    box-shadow: var(--glow-brass);
}

/* ── HERO ─────────────────────────────────────────────────── */
.menu-hero {
    position: relative;
    min-height: 46vh;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    padding: 120px 40px 80px;
    overflow: hidden;
}
.menu-hero-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    transform: scale(1.04);
    transition: transform 8s ease;
}
.menu-hero:hover .menu-hero-bg { transform: scale(1.0); }
.menu-hero-bg::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(
        180deg,
        rgba(12,10,8,.55) 0%,
        rgba(12,10,8,.72) 50%,
        rgba(12,10,8,.95) 100%
    );
}
.menu-hero-glow-y {
    position: absolute; top: -120px; right: -120px;
    width: 500px; height: 500px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,210,63,.15), transparent 65%);
    filter: blur(18px); pointer-events: none;
}
.menu-hero-glow-m {
    position: absolute; bottom: -100px; left: -100px;
    width: 400px; height: 400px; border-radius: 50%;
    background: radial-gradient(circle, rgba(255,62,165,.11), transparent 65%);
    filter: blur(18px); pointer-events: none;
}
.menu-hero-content {
    position: relative; z-index: 2;
    max-width: 700px;
}
.menu-hero-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(56px, 8vw, 110px);
    line-height: .9; letter-spacing: -.01em;
    margin: 0 0 20px;
}
.menu-hero-suffix {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic; font-weight: 400;
    font-size: clamp(22px, 3vw, 38px);
    color: var(--brass-2); letter-spacing: .04em;
    text-shadow: var(--glow-brass);
    margin-top: 6px;
}
.menu-hero-desc {
    font-size: 16px; color: var(--ink-2);
    line-height: 1.6; max-width: 480px; margin: 0 auto;
}
.menu-hero-scroll {
    position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
    z-index: 2; color: var(--brass); opacity: .6;
    animation: hero-bounce 2s ease-in-out infinite;
}
@keyframes hero-bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50%       { transform: translateX(-50%) translateY(6px); }
}

/* ── STICKY FILTER BAR ────────────────────────────────────── */
.menu-filter {
    position: sticky; top: 68px; z-index: 40;
    background: rgba(12,10,8,.92);
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--line-brass);
    box-shadow: 0 4px 24px rgba(0,0,0,.4);
}
.menu-filter-inner {
    max-width: 1200px; margin: 0 auto;
    padding: 0 40px;
    height: 60px;
    display: flex; align-items: center;
    justify-content: space-between; gap: 20px;
}
.menu-tabs {
    display: flex; align-items: center; gap: 4px;
    flex-shrink: 0;
}
.menu-tab {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 8px 18px; border-radius: var(--radius-pill);
    border: 1px solid transparent;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mute);
    background: transparent;
    transition: all var(--transition);
    white-space: nowrap;
}
.menu-tab svg { flex-shrink: 0; opacity: .7; transition: opacity var(--transition); }
.menu-tab:hover { color: var(--ink); border-color: var(--line-brass); }
.menu-tab:hover svg { opacity: 1; }

/* Active states */
.menu-tab.street.is-active {
    background: var(--yellow); color: #0b0b0b;
    border-color: var(--yellow); box-shadow: var(--glow-soft-yellow);
}
.menu-tab.dessert.is-active {
    background: var(--magenta); color: #fff;
    border-color: var(--magenta); box-shadow: var(--glow-soft-magenta);
}
.menu-tab.drinks.is-active {
    background: var(--brass); color: #0b0b0b;
    border-color: var(--brass); box-shadow: var(--glow-brass);
}
.menu-tab.is-active svg { opacity: 1; }

/* Search */
.menu-search-wrap {
    position: relative; flex: 1; max-width: 300px;
}
.menu-search-icon {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: var(--mute); pointer-events: none;
}
.menu-search {
    width: 100%; padding: 10px 16px 10px 38px;
    background: rgba(255,255,255,.04); border: 1px solid var(--line-brass);
    border-radius: var(--radius-pill); color: var(--ink);
    font-family: 'Inter', sans-serif; font-size: 13px;
    outline: none; transition: border-color var(--transition), box-shadow var(--transition);
    appearance: none;
}
.menu-search:focus { border-color: rgba(255,210,63,.5); box-shadow: var(--glow-soft-yellow); }
.menu-search::placeholder { color: var(--mute); }
/* Remove native search input chrome */
.menu-search::-webkit-search-cancel-button { -webkit-appearance: none; }

/* ── CATEGORY SECTIONS ────────────────────────────────────── */
.menu-section { padding: 64px 0; }
.menu-section[hidden] { display: none; }
.menu-section-inner { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

.menu-section-head {
    display: flex; align-items: center; gap: 24px;
    margin-bottom: 40px;
}
.menu-section-title {
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(32px, 4vw, 52px);
    letter-spacing: .04em; line-height: 1;
    white-space: nowrap;
}
.menu-section-title.street  { color: var(--yellow);  text-shadow: var(--glow-soft-yellow); }
.menu-section-title.dessert { color: var(--magenta); text-shadow: var(--glow-soft-magenta); }
.menu-section-title.drinks  { color: var(--brass-2); text-shadow: var(--glow-brass); }

.menu-section-line {
    flex: 1; height: 1px;
    background: linear-gradient(90deg, var(--line-brass) 0%, transparent 100%);
}
.menu-section-line.street  { background: linear-gradient(90deg, rgba(255,210,63,.3), transparent); }
.menu-section-line.dessert { background: linear-gradient(90deg, rgba(255,62,165,.3),  transparent); }
.menu-section-line.drinks  { background: linear-gradient(90deg, rgba(201,169,110,.3), transparent); }

/* ── MENU GRID ────────────────────────────────────────────── */
.menu-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 24px;
}
.menu-card-hidden { display: none !important; }

/* ── MENU CARDS ───────────────────────────────────────────── */
.menu-card {
    background: var(--bg-2);
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.menu-card:hover { transform: translateY(-4px); }
.menu-card.street:hover  { border-color: rgba(255,210,63,.35);  box-shadow: 0 20px 50px rgba(0,0,0,.5), var(--glow-soft-yellow); }
.menu-card.dessert:hover { border-color: rgba(255,62,165,.35);  box-shadow: 0 20px 50px rgba(0,0,0,.5), var(--glow-soft-magenta); }
.menu-card.drinks:hover  { border-color: rgba(201,169,110,.35); box-shadow: 0 20px 50px rgba(0,0,0,.5), var(--glow-brass); }

/* Featured card: slightly elevated */
.menu-card.is-featured { border-color: var(--line-brass); }

/* Card image */
.menu-card-media {
    position: relative;
    aspect-ratio: 3/2;
    overflow: hidden; flex-shrink: 0;
    background: var(--bg-3);
}
.menu-card-img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .5s ease;
}
.menu-card:hover .menu-card-img { transform: scale(1.05); }
.menu-card-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(12,10,8,.8) 100%);
    pointer-events: none;
}

/* Badge */
.menu-badge {
    display: inline-flex; align-items: center;
    position: absolute; top: 12px; left: 12px;
    padding: 4px 10px; border-radius: var(--radius-pill);
    font-family: 'JetBrains Mono', monospace;
    font-size: 9px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
}
.menu-badge.street  { background: var(--yellow);  color: #0b0b0b; }
.menu-badge.dessert { background: var(--magenta); color: #fff; }
.menu-badge.drinks  { background: var(--brass);   color: #0b0b0b; }

/* Card body */
.menu-card-body {
    padding: 18px 20px 20px;
    display: flex; flex-direction: column; gap: 10px;
    flex: 1;
}
.menu-card-top {
    display: flex; align-items: flex-start;
    justify-content: space-between; gap: 12px;
}
.menu-card-name {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 20px; letter-spacing: .04em; line-height: 1.1;
    color: var(--ink); flex: 1;
}
.menu-card-price {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 22px; letter-spacing: .04em;
    white-space: nowrap; flex-shrink: 0;
    line-height: 1;
}
.menu-card-price.street  { color: var(--yellow);  text-shadow: var(--glow-soft-yellow); }
.menu-card-price.dessert { color: var(--magenta); text-shadow: var(--glow-soft-magenta); }
.menu-card-price.drinks  { color: var(--brass-2); text-shadow: var(--glow-brass); }

.menu-card-desc {
    font-size: 13px; color: var(--mute);
    line-height: 1.55; flex: 1;
}
.menu-card-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    margin-top: auto; padding: 10px 18px;
    border-radius: var(--radius-pill);
    border: 1px solid var(--line-brass); color: var(--ink-2);
    font-family: 'JetBrains Mono', monospace;
    font-size: 10px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    background: transparent;
    transition: all var(--transition);
}
.menu-card.street  .menu-card-btn:hover { border-color: var(--yellow);  color: var(--yellow);  box-shadow: var(--glow-soft-yellow); }
.menu-card.dessert .menu-card-btn:hover { border-color: var(--magenta); color: var(--magenta); box-shadow: var(--glow-soft-magenta); }
.menu-card.drinks  .menu-card-btn:hover { border-color: var(--brass);   color: var(--brass-2); box-shadow: var(--glow-brass); }

/* ── EMPTY STATE ──────────────────────────────────────────── */
.menu-empty {
    padding: 48px 24px;
    text-align: center;
    font-size: 14px; color: var(--mute); font-style: italic;
    border: 1px dashed var(--line-brass); border-radius: var(--radius-md);
}

/* ── SEE MORE ─────────────────────────────────────────────── */
.menu-more-wrap { text-align: center; margin-top: 32px; }
.menu-more-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 12px 28px; border-radius: var(--radius-pill);
    border: 1px solid var(--line-brass); color: var(--ink-2);
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
    background: transparent; transition: all var(--transition);
}
.menu-more-btn:hover { border-color: var(--brass); color: var(--brass-2); }
.menu-more-count { color: var(--mute); font-weight: 400; }

/* ── MODAL ────────────────────────────────────────────────── */
.menu-modal {
    position: fixed; inset: 0; z-index: 9000;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    transition: opacity .2s ease;
}
.menu-modal[aria-hidden="true"] {
    opacity: 0; pointer-events: none;
}
.menu-modal[aria-hidden="false"] {
    opacity: 1;
}
.menu-modal-overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,.78); backdrop-filter: blur(6px);
}
.menu-modal-panel {
    position: relative; z-index: 1;
    width: 100%; max-width: 500px;
    background: var(--bg-2); border: 1px solid var(--line-brass);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 40px 80px rgba(0,0,0,.7);
    transform: translateY(0);
    transition: transform .25s ease;
}
.menu-modal[aria-hidden="true"] .menu-modal-panel { transform: translateY(16px); }
.menu-modal-close {
    position: absolute; top: 12px; right: 12px; z-index: 2;
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(12,10,8,.7); border: 1px solid var(--line-brass);
    display: grid; place-items: center; color: var(--ink-2);
    transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.menu-modal-close:hover { background: var(--bg-3); border-color: var(--brass); color: var(--brass-2); }

.menu-modal-media { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--bg-3); }
.menu-modal-img   { width: 100%; height: 100%; object-fit: cover; }
.menu-modal-media .menu-badge { top: 14px; left: 14px; font-size: 10px; }

.menu-modal-body  { padding: 24px 24px 28px; }
.menu-modal-name  {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 28px; letter-spacing: .04em; margin-bottom: 8px; line-height: 1;
}
.menu-modal-name.street  { color: var(--yellow);  text-shadow: var(--glow-soft-yellow); }
.menu-modal-name.dessert { color: var(--magenta); text-shadow: var(--glow-soft-magenta); }
.menu-modal-name.drinks  { color: var(--brass-2); text-shadow: var(--glow-brass); }

.menu-modal-desc  { font-size: 14px; color: var(--ink-2); line-height: 1.65; }
.menu-modal-footer {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    margin-top: 20px; padding-top: 20px;
    border-top: 1px solid var(--line-brass);
}
.menu-modal-price {
    font-family: 'Bebas Neue', sans-serif; font-size: 30px; letter-spacing: .04em;
}
.menu-modal-price.street  { color: var(--yellow);  text-shadow: var(--glow-soft-yellow); }
.menu-modal-price.dessert { color: var(--magenta); text-shadow: var(--glow-soft-magenta); }
.menu-modal-price.drinks  { color: var(--brass-2); text-shadow: var(--glow-brass); }

.menu-modal-btn-close { padding: 10px 20px; font-size: 12px; }

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media (max-width: 1024px) {
    .menu-filter-inner { padding: 0 24px; }
    .menu-section-inner { padding: 0 24px; }
}

@media (max-width: 768px) {
    .menu-hero { padding: 100px 24px 60px; min-height: 38vh; }
    .menu-filter-inner { gap: 12px; height: auto; padding: 10px 16px; flex-wrap: wrap; }
    .menu-tabs { gap: 4px; overflow-x: auto; padding-bottom: 2px; -webkit-overflow-scrolling: touch; }
    .menu-tab { padding: 7px 14px; font-size: 10px; }
    .menu-search-wrap { max-width: 100%; width: 100%; flex-basis: 100%; }
    .menu-section { padding: 44px 0; }
    .menu-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
    .menu-section-head { gap: 16px; margin-bottom: 28px; }
}

@media (max-width: 500px) {
    .menu-hero-title { font-size: 48px; }
    .menu-filter { top: 60px; }
    .menu-grid { grid-template-columns: 1fr; }
    .menu-modal-panel { border-radius: var(--radius-md); }
    .menu-modal-name { font-size: 24px; }
}
