    /* ═══════════════════════════════════════════
    PAGINA MENU — semplice & moderno
    ═══════════════════════════════════════════ */
    :root {
        --menu-bg: #f7f5f2;
        --menu-surface: #ffffff;
        --menu-accent: #641811;
        --menu-accent-2: #8B3520;
        --menu-gold: #c47f2a;
        --menu-text: #3a2a22;
        --menu-muted: #8a7568;
        --menu-line: rgba(58, 42, 34, 0.1);
        --menu-max: 660px;
    }

    html,
    body {
        overflow-x: clip;
    }

    body.page-menu {
        min-height: 100dvh;
        display: flex;
        flex-direction: column;
        font-size: 1em;
    }

    body.page-menu .menu-section {
        flex: 1 1 auto;
    }

    body.page-menu .footer {
        flex-shrink: 0;
    }

    /* ── Instagram ── */
    .insta-banner {
        height: 50px;
        background: linear-gradient(90deg, #4a1209, #641811, #8B3520, #641811, #4a1209);
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 30px;
        padding: 0 52px;
    }

    .insta-banner-txt {
        font-size: 0.9375em;
        letter-spacing: .2em;
        text-transform: uppercase;
        color: rgba(242, 224, 192, .75);
        white-space: nowrap;
    }

    .insta-banner-btn {
        border-radius: 999px;
        font-family: 'Baloo 2', sans-serif;
        font-size: 0.9375em;
        letter-spacing: .18em;
        text-transform: uppercase;
        color: #fff;
        text-decoration: none;
        border: 1px solid rgba(255, 255, 255, .35);
        padding: 9px 20px;
        transition: background .2s;
        white-space: nowrap;
    }

    .insta-banner-btn:hover {
        background: rgba(255, 255, 255, .15);
    }

    /* ── Navbar ── */
    #nav {
        background: #fff;
        backdrop-filter: blur(16px);
        -webkit-backdrop-filter: blur(16px);
        border-bottom: 1px solid var(--menu-line);
        box-shadow: none;
        z-index: 1000;
    }

    #nav.scrolled {
        background: #fff;
        box-shadow: 0 2px 20px rgba(58, 42, 34, .06);
    }

    #mob.open ~ #nav {
        z-index: 1100;
        background: #fff;
    }

    .nav-link { color: var(--menu-accent-2); }
    .nav-link:hover { background: rgba(139, 53, 32, .06); }
    #nav.scrolled .nav-link { color: var(--menu-accent-2); }
    #nav.scrolled .nav-link:hover { background: rgba(139, 53, 32, .06); }

    .burger {
        background: rgba(139, 53, 32, .05);
        border-color: rgba(139, 53, 32, .1);
    }

    .burger span,
    #nav.scrolled .burger span,
    #mob.open ~ #nav .burger span {
        background: var(--menu-accent-2);
    }

    /* ── Hero pagina menu ── */
    .menu-hero {
        position: relative;
        margin-top: var(--header-h);
        overflow: hidden;
        isolation: isolate;
        color: #fff;
        text-align: center;
    }

    .menu-hero-media {
        position: absolute;
        inset: 0;
        z-index: 0;
    }

    .menu-hero-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center 40%;
    }

    .menu-hero-overlay {
        position: absolute;
        inset: 0;
        z-index: 1;
        background:
            linear-gradient(180deg, rgba(74, 18, 9, .72) 0%, rgba(100, 24, 17, .55) 45%, rgba(58, 14, 8, .82) 100%),
            radial-gradient(ellipse at 50% 0%, rgba(196, 127, 42, .18) 0%, transparent 55%);
    }

    .menu-hero-content {
        position: relative;
        z-index: 2;
        max-width: 640px;
        margin: 0 auto;
        padding: clamp(40px, 8vw, 64px) 24px clamp(52px, 9vw, 72px);
    }

    .menu-hero-eyebrow {
        display: block;
        font-family: 'Baloo 2', sans-serif;
        font-size: 0.8125em;
        font-weight: 600;
        letter-spacing: .22em;
        text-transform: uppercase;
        color: rgba(230, 184, 128, .92);
        margin-bottom: 14px;
    }

    .menu-hero-title {
        font-family: 'Baloo 2', sans-serif;
        font-size: clamp(2em, 6vw, 2.75em);
        font-weight: 600;
        letter-spacing: .04em;
        line-height: 1.1;
        margin: 0 0 16px;
        text-shadow: 0 4px 28px rgba(0, 0, 0, .35);
    }

    .menu-hero-rule {
        display: block;
        width: 56px;
        height: 2px;
        margin: 0 auto 16px;
        border-radius: 999px;
        background: linear-gradient(90deg, transparent, #e6b880, transparent);
    }

    .menu-hero-sub {
        font-family: 'Jost', system-ui, sans-serif;
        font-size: clamp(1em, 2.5vw, 1.0625em);
        color: rgba(255, 255, 255, .82);
        margin: 0;
        line-height: 1.6;
        letter-spacing: .04em;
    }

    .menu-hero::after {
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        bottom: -1px;
        z-index: 3;
        height: 28px;
        background: var(--menu-bg);
        clip-path: ellipse(58% 100% at 50% 100%);
    }

    /* ── Sezione menu ── */
    strong {
        color: var(--menu-text);
        font-weight: 600;
    }

    .menu-section {
        font-family: 'Baloo 2', sans-serif;
        background: var(--menu-bg);
        padding: 4px 0 48px;
    }

    .menu-container {
        max-width: calc(var(--menu-max) + 40px);
        margin: 0 auto;
        padding: 0 20px;
        overflow-anchor: none;
        box-sizing: border-box;
    }

    .menu-section .rv,
    .menu-section .rv-up,
    .menu-section .rv-zoom {
        opacity: 1;
        transform: none;
        transition: none;
    }

    /* ── Tab categorie ── */
    .menu-nav-wrap {
        position: -webkit-sticky;
        position: sticky;
        top: var(--header-h);
        z-index: 800;
        background: var(--menu-bg);
        border-bottom: 1px solid var(--menu-line);
    }

    .menu-nav-arrow {
        display: none;
    }

    .menu-nav {
        display: flex;
        flex-wrap: nowrap;
        gap: 4px;
        overflow-x: auto;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
        max-width: calc(var(--menu-max) + 40px);
        margin: 0 auto;
        padding: 10px 16px 12px;
        min-width: 0;
        width: 100%;
    }

    .menu-nav::-webkit-scrollbar {
        display: none;
    }

    .menu-tab {
        flex-shrink: 0;
        font-family: inherit;
        font-size: 0.9375em;
        font-weight: 500;
        letter-spacing: .05em;
        text-transform: uppercase;
        line-height: 1.15;
        white-space: nowrap;
        min-height: 37px;
        padding: 0 16px;
        border: none;
        border-radius: 999px;
        background: transparent;
        color: var(--menu-muted);
        cursor: pointer;
        transition: color .15s, background .15s;
    }

    .menu-tab:hover {
        color: var(--menu-accent);
        background: rgba(100, 24, 17, .06);
    }

    .menu-tab.active {
        background: var(--menu-accent);
        color: #fff;
    }

    /* ── Categoria ── */
    .menu-cat {
        display: none;
    }

    .menu-cat.active {
        display: block;
        max-width: var(--menu-max);
        margin: 0 auto;
        padding: 28px 0 0;
    }

    .menu-cat-hdr {
        margin-bottom: 28px;
        text-align: center;
    }

    .eyebrow {
        font-family: inherit;
        font-size: 0.875em;
        font-weight: 600;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--menu-accent-2);
        margin-bottom: 8px;
        display: block;
    }

    .eyebrow::before,
    .eyebrow::after {
        display: none;
    }

    .menu-cat-hdr h2 {
        font-family: 'Cormorant Garamond', Georgia, serif;
        font-size: clamp(1.625em, 4.2vw, 2.125em);
        font-weight: 500;
        font-style: italic;
        color: var(--menu-text);
        margin: 0 0 8px;
        line-height: 1.15;
    }

    .menu-cat-hdr h2::after {
        display: none;
    }

    .menu-cat-desc {
        font-family: 'Jost', system-ui, sans-serif;
        font-size: 0.9375em;
        color: var(--menu-muted);
        line-height: 1.55;
        margin: 0;
    }

    u {
        text-decoration: none;
        color: var(--menu-muted);
    }

    /* ── Sottocategoria ── */
    .menu-subcat {
        margin-bottom: 32px;
    }

    .menu-subcat:last-child {
        margin-bottom: 0;
    }

    .menu-subcat-title {
        font-family: inherit;
        font-size: 0.9375em;
        font-weight: 600;
        letter-spacing: .14em;
        text-transform: uppercase;
        color: var(--menu-text);
        padding-bottom: 10px;
        margin-bottom: 6px;
        border-bottom: 2px solid var(--menu-accent);
        border-left: none;
        text-align: center;
    }

    .menu-subcat-title::after {
        display: none;
    }

    /* ── Piatti ── */
    .menu-list {
        display: flex;
        flex-direction: column;
    }

    .menu-item {
        display: flex;
        align-items: baseline;
        justify-content: space-between;
        gap: 14px;
        padding: 11px 0;
        border-bottom: 1px solid var(--menu-line);
        background: none;
        border-radius: 0;
    }

    .menu-item:last-child {
        border-bottom: none;
    }

    .menu-item--featured {
        padding-left: 0;
        border-left: none;
        margin: 0;
        background: none;
    }

    .menu-item--featured:first-child {
        margin-top: 0;
    }

    .menu-item-left {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 3px;
    }

    .menu-item-name {
        font-size: 1.09375em;
        font-weight: 600;
        color: var(--menu-text);
        line-height: 1.35;
        overflow-wrap: anywhere;
    }

    .menu-item-name::after {
        display: none;
    }

    .menu-item--featured .menu-item-name {
        color: var(--menu-text);
    }

    .menu-item-desc {
        font-family: 'Jost', system-ui, sans-serif;
        font-size: 0.9375em;
        color: var(--menu-muted);
        line-height: 1.5;
        overflow-wrap: anywhere;
    }

    .menu-item-price {
        font-family: inherit;
        font-size: 1em;
        font-weight: 700;
        color: var(--menu-accent);
        white-space: nowrap;
        flex-shrink: 0;
    }

    .menu-note {
        margin-top: 32px;
        padding-top: 20px;
        border-top: 1px solid var(--menu-line);
        text-align: center;
        font-family: 'Jost', system-ui, sans-serif;
        font-size: 0.9375em;
        color: var(--menu-muted);
        line-height: 1.7;
        background: none;
        border-radius: 0;
    }

    .rv-d6 { transition-delay: .6s; }
    .rv-d7 { transition-delay: .7s; }
    .rv-d8 { transition-delay: .8s; }
    .rv-d9 { transition-delay: .9s; }

    /* ═══════════════════════════════════════════
       RESPONSIVE — MENÙ (max-width)
       ─────────────────────────────────────────────
       ≥961px    Desktop — tab categorie a capo, link navbar visibili
       ≤1200px   Laptop / iPad Pro landscape (~1024px)
                   → navbar e banner Instagram più compatti
       ≤960px    Tablet iPad portrait (~768–1024px)
                   → hamburger al posto dei link · tab categorie scroll orizzontale + frecce
       ≤768px    iPad mini / iPhone Plus landscape (~768px)
                   → base testo pagina 96.875% · tab categorie leggermente più piccole
       ≤640px    Smartphone grande — iPhone 14/15, Galaxy S23 (~390–430px)
                   → tab Colazione/Pranzo/… · padding lista piatti · banner Instagram in colonna
       ≤480px    Smartphone standard — iPhone SE 2/3, iPhone 13 mini (~375px)
                   → nomi piatti, prezzi, eyebrow e descrizioni categorie ridimensionati
       ═══════════════════════════════════════════ */

    /* ≤768px — iPad mini, iPhone landscape: scala testo generale menù */
    @media (max-width: 768px) {
        html {
            font-size: 100%;
        }

        body.page-menu {
            font-size: 0.984375em;
        }

        .menu-nav-wrap {
            font-size: 0.96875em;
        }
    }

    /* ≤480px — iPhone SE 2/3, iPhone 13 mini (~375px): scala base pagina menù */
    @media (max-width: 480px) {
        html {
            font-size: 100%;
        }

        body.page-menu {
            font-size: 0.9375em;
        }
    }

    /* ≤960px — iPad portrait: tab categorie scroll + frecce ← → */
    @media (max-width: 960px) {
        .menu-nav-wrap {
            display: grid;
            grid-template-columns: 40px minmax(0, 1fr) 40px;
            align-items: center;
            gap: 0;
            padding: 0 4px;
        }

        .menu-nav-arrow {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 40px;
            height: 40px;
            flex-shrink: 0;
            border: none;
            border-radius: 50%;
            background: rgba(100, 24, 17, .12);
            color: var(--menu-accent);
            cursor: pointer;
            z-index: 2;
            transition: background .15s, opacity .15s, transform .15s;
            -webkit-tap-highlight-color: transparent;
        }

        .menu-nav-arrow svg {
            width: 20px;
            height: 20px;
        }

        .menu-nav-arrow:hover {
            background: rgba(100, 24, 17, .2);
        }

        .menu-nav-arrow:active {
            transform: scale(.94);
        }

        .menu-nav-wrap.is-at-start .menu-nav-arrow--prev {
            opacity: .35;
            pointer-events: none;
        }

        .menu-nav-wrap.is-at-end .menu-nav-arrow--next {
            opacity: .35;
            pointer-events: none;
        }

        .menu-nav {
            flex-wrap: nowrap;
            overflow-x: auto;
            max-width: none;
            margin: 0;
            padding: 8px 4px 10px;
            scroll-padding-inline: 6px;
            gap: 3px;
        }

        .menu-nav-wrap::before,
        .menu-nav-wrap::after {
            content: '';
            position: absolute;
            top: 0;
            bottom: 0;
            width: 32px;
            pointer-events: none;
            z-index: 1;
        }

        .menu-nav-wrap::before {
            left: 40px;
            background: linear-gradient(to right, var(--menu-bg) 20%, transparent);
            opacity: 0;
            transition: opacity .2s;
        }

        .menu-nav-wrap::after {
            right: 40px;
            background: linear-gradient(to left, var(--menu-bg) 20%, transparent);
            opacity: 1;
            transition: opacity .2s;
        }

        .menu-nav-wrap:not(.is-at-start)::before {
            opacity: 1;
        }

        .menu-nav-wrap.is-at-end::after {
            opacity: 0;
        }
    }

    /* ≥961px — Desktop: tab categorie su più righe, senza scroll */
    @media (min-width: 961px) {
        .menu-nav {
            flex-wrap: wrap;
            justify-content: center;
            overflow-x: visible;
        }
    }

    /* ≤1200px — Laptop / iPad Pro landscape: navbar top e banner Instagram */
    @media (max-width: 1200px) {
        #nav { padding: 0 20px; }
        .nav-link { padding: 0 8px; font-size: 0.8125em; }
        .insta-banner { gap: 24px; padding: 0 32px; }
        .insta-banner-txt { font-size: 0.875em; }
        .insta-banner-btn { font-size: 0.875em; padding: 8px 18px; }
    }

    /* ≤960px — iPad portrait: navbar hamburger, logo centrato, tab sotto header */
    @media (max-width: 960px) {
        #nav .nav-logo img {
            filter: brightness(0) saturate(100%) invert(28%) sepia(40%) saturate(1500%) hue-rotate(347deg) brightness(90%);
        }

        #nav {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            z-index: 1000;
            display: flex;
            align-items: center;
            justify-content: flex-end;
            height: var(--nav-h);
            padding: 0 16px;
        }

        #nav::before {
            content: '';
            width: 38px;
            height: 38px;
            flex-shrink: 0;
        }

        .nav-logo {
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            margin: 0;
        }

        .nav-logo:hover {
            transform: translate(-50%, -50%);
        }

        .nav-links { display: none; }

        .burger {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 38px;
            height: 38px;
            padding: 0;
            margin-left: auto;
        }

        .menu-nav-wrap {
            top: var(--header-h);
        }

        #mob.open ~ #menu .menu-nav-wrap {
            visibility: hidden;
            pointer-events: none;
        }
    }

    /* ≤640px — iPhone 14/15, Galaxy (~390–430px): tab, piatti, banner Instagram */
    @media (max-width: 640px) {
        .menu-container { padding: 0 16px; }

        .menu-nav-wrap {
            font-size: 0.9375em;
        }

        .menu-tab {
            font-size: 0.90625em;
            padding: 0 14px;
            min-height: 35px;
        }

        .menu-item {
            align-items: flex-start;
            gap: 10px;
            padding: 10px 0;
        }

        .insta-banner {
            flex-direction: column;
            height: auto;
            padding: 18px 16px;
            gap: 10px;
            text-align: center;
        }

        .insta-banner-txt {
            white-space: normal;
            line-height: 1.5;
        }

        .wa-btn {
            bottom: 20px;
            right: 20px;
            width: 46px;
            height: 46px;
        }

        .wa-btn svg {
            width: 24px;
            height: 24px;
        }
    }

    /* ≤480px — iPhone SE 2/3 (~375px): testi piatti, tab, eyebrow, note allergeni */
    @media (max-width: 480px) {
        .menu-item-name {
            font-size: 1.03125em;
        }

        .menu-item-desc {
            font-size: 0.90625em;
        }

        .menu-item-price {
            font-size: 0.96875em;
        }

        .menu-tab {
            font-size: 0.875em;
            min-height: 33px;
            padding: 0 13px;
            letter-spacing: .04em;
        }

        .menu-subcat-title {
            font-size: 0.90625em;
        }

        .menu-cat-desc {
            font-size: 0.90625em;
        }

        .menu-note {
            font-size: 0.90625em;
        }

        .eyebrow {
            font-size: 0.84375em;
        }
    }

    @media (prefers-reduced-motion: reduce) {
        .menu-tab { transition: none; }
    }