/* ===== Menu page — authentic editorial trattoria menu ===== */

.menu-hero { padding: clamp(34px, 5vw, 60px) 0 clamp(20px, 3vw, 32px); text-align: center; position: relative; }
.menu-hero h1 { font-size: clamp(2.8rem, 6vw, 4.6rem); }
.menu-hero h1 .script { color: var(--green); display: block; font-size: .62em; }
.menu-hero p { color: var(--ink-soft); max-width: 56ch; margin: 14px auto 0; font-size: 1.08rem; }
.menu-hero .promo-row { justify-content: center; margin-top: 22px; }

/* sticky category nav */
.cat-nav { position: sticky; top: var(--header-h); z-index: 100; background: color-mix(in srgb, var(--paper) 92%, transparent); backdrop-filter: blur(12px); border-top: 1px solid rgba(36,31,27,.08); border-bottom: 1px solid rgba(36,31,27,.08); }
.cat-nav .wrap { display: flex; gap: 8px; overflow-x: auto; padding-top: 12px; padding-bottom: 12px; scrollbar-width: none; }
.cat-nav .wrap::-webkit-scrollbar { display: none; }
.cat-nav a { white-space: nowrap; padding: 9px 16px; border-radius: var(--r-pill); font-weight: 700; font-size: .92rem; color: var(--ink-soft); border: 1.5px solid rgba(36,31,27,.14); transition: all .18s ease; }
.cat-nav a:hover { border-color: var(--ink); color: var(--ink); }
.cat-nav a.active { background: var(--red); color: #fff; border-color: var(--red); }

/* category sections */
.mcat { padding: clamp(40px, 5vw, 64px) 0; scroll-margin-top: calc(var(--header-h) + 64px); }
.mcat:nth-of-type(even) { background: var(--paper-2); }
.mcat-head { display: flex; align-items: baseline; gap: 18px; margin-bottom: 8px; flex-wrap: wrap; }
.mcat-head h2 { font-size: clamp(2rem, 4vw, 3rem); }
.mcat-head .count { font-family: var(--sans); font-weight: 700; color: var(--ink-faint); font-size: .85rem; letter-spacing: .04em; white-space: nowrap; }
.mcat-sub { color: var(--ink-soft); margin: 0 0 28px; max-width: 60ch; }

/* pizza grid — text rows with leaders */
.menu-items { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 56px; }
.mi { display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 6px 14px; padding: 16px 0; border-bottom: 1px solid rgba(36,31,27,.12); }
.mi .mi-main { min-width: 0; }
.mi .mi-name { font-family: var(--serif); font-size: 1.35rem; line-height: 1.15; }
.mi .mi-name .dot-tags { display: inline-flex; gap: 5px; vertical-align: middle; margin-left: 5px; }
.mi .mi-name .t { font-family: var(--sans); font-size: .6rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; padding: 3px 7px; border-radius: var(--r-pill); }
.mi .t.veg { background: var(--green-tint); color: var(--green-deep); }
.mi .t.spicy { background: var(--red-tint); color: var(--red-deep); }
.mi .t.halal { background: var(--gold-tint); color: var(--gold); }
.mi .mi-desc { color: var(--ink-soft); font-size: .92rem; margin: 4px 0 0; }
.mi .mi-price { font-family: var(--serif); color: var(--red); font-size: 1.2rem; white-space: nowrap; text-align: right; }
.mi .mi-price small { display: block; font-family: var(--sans); font-weight: 600; font-size: .68rem; color: var(--ink-faint); letter-spacing: .02em; }
@media (max-width: 800px) { .menu-items { grid-template-columns: 1fr; gap: 0; } }

/* pizza photo cards */
.pizza-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(258px, 1fr)); gap: 18px; }
.pcard { background: var(--card); border: 1px solid rgba(36,31,27,.08); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; transition: transform .2s ease, box-shadow .2s ease; }
.pcard:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.pcard .pic { position: relative; aspect-ratio: 16/11; overflow: hidden; background: var(--paper-2); }
.pcard .pic img { width: 100%; height: 100%; object-fit: cover; transition: transform .45s ease; }
.pcard:hover .pic img { transform: scale(1.05); }
.pcard .pic.logo { display: grid; place-items: center; background: radial-gradient(circle at 50% 38%, var(--paper) 0%, var(--paper-2) 60%, var(--paper-3) 100%); }
.pcard .pic.logo img { width: 66px; height: 66px; border-radius: 50%; opacity: .9; box-shadow: var(--shadow-sm); }
.pcard .pic .ptags { position: absolute; top: 10px; left: 10px; display: flex; gap: 6px; z-index: 1; }
.pcard .pic .ptags .t { font-family: var(--sans); font-size: .62rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; padding: 4px 8px; border-radius: var(--r-pill); box-shadow: var(--shadow-sm); }
.pcard .pic .ptags .t.veg { background: var(--green); color: #fff; }
.pcard .pic .ptags .t.spicy { background: var(--red); color: #fff; }
.pcard .pic .ptags .t.halal { background: var(--gold); color: #fff; }
.pcard .b { padding: 15px 18px 18px; display: flex; flex-direction: column; gap: 5px; flex: 1; }
.pcard .b .top { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; }
.pcard h3 { font-size: 1.3rem; min-width: 0; }
.pcard .pr { font-family: var(--serif); color: var(--red); font-size: 1.15rem; white-space: nowrap; flex: none; text-align: right; line-height: 1.05; }
.pcard .pr small { display: block; font-family: var(--sans); font-weight: 600; font-size: .58rem; color: var(--ink-faint); letter-spacing: .02em; }
.pcard p { color: var(--ink-soft); font-size: .88rem; margin: 0; }

/* compact two-col for sides/sauces/drinks */
.menu-compact { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 4px 48px; }
.mc { display: flex; align-items: baseline; gap: 12px; padding: 12px 0; border-bottom: 1px solid rgba(36,31,27,.1); }
.mc .mc-name { font-weight: 600; font-size: 1.02rem; }
.mc .mc-name small { color: var(--ink-faint); font-weight: 500; font-size: .82rem; }
.mc .leader { flex: 1; border-bottom: 1px dotted rgba(36,31,27,.28); transform: translateY(-4px); }
.mc .mc-price { font-weight: 800; color: var(--red); }

/* combo cards (highlighted) */
.combos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.combo { background: var(--card); border-radius: var(--r-lg); border: 1px solid rgba(36,31,27,.1); box-shadow: var(--shadow-sm); padding: 0 0 24px; position: relative; display: flex; flex-direction: column; overflow: hidden; transition: transform .2s ease, box-shadow .2s ease; }
.combo:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.combo.best { border-color: var(--red); box-shadow: 0 0 0 1px var(--red), var(--shadow-sm); }
.combo .cpic { aspect-ratio: 16/10; overflow: hidden; background: var(--paper-2); }
.combo .cpic img { width: 100%; height: 100%; object-fit: cover; }
.combo .cbody { padding: 22px 24px 0; display: flex; flex-direction: column; flex: 1; }
.combo .ribbon-tag { position: absolute; top: 14px; left: 14px; background: var(--red); color: #fff; font-size: .68rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; padding: 5px 12px; border-radius: var(--r-pill); box-shadow: var(--shadow-sm); z-index: 1; }
.combo h3 { font-size: 1.6rem; }
.combo .combo-price { font-family: var(--serif); color: var(--red); font-size: 2.2rem; line-height: 1; margin: 6px 0 14px; }
.combo ul { list-style: none; margin: 0 0 20px; padding: 0; display: grid; gap: 9px; flex: 1; }
.combo li { display: flex; gap: 10px; align-items: flex-start; color: var(--ink-soft); font-size: .95rem; }
.combo li svg { width: 17px; height: 17px; color: var(--green); flex: none; margin-top: 3px; }
.combo .btn { margin: 0 24px; }
@media (max-width: 820px) { .combos { grid-template-columns: 1fr; } }

/* size/pricing callout + toppings */
.price-card { background: var(--card); border: 1px solid rgba(36,31,27,.1); border-radius: var(--r-lg); padding: 26px 28px; box-shadow: var(--shadow-sm); }
.price-card h3 { font-size: 1.3rem; margin-bottom: 16px; }
.size-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.size { text-align: center; padding: 16px 10px; border-radius: var(--r); background: var(--paper-2); border: 1px solid rgba(36,31,27,.08); }
.size b { font-family: var(--serif); display: block; font-size: 1.1rem; }
.size .sz-price { color: var(--red); font-weight: 800; font-size: 1.15rem; margin-top: 4px; }
.size small { color: var(--ink-faint); font-size: .78rem; }
@media (max-width: 600px) { .size-row { grid-template-columns: 1fr 1fr; } }

.menu-aside { display: grid; grid-template-columns: 1.3fr 1fr; gap: 24px; margin-top: 26px; align-items: start; }
.toppings-card { background: var(--green-tint); border-radius: var(--r-lg); padding: 26px 28px; }
.toppings-card h3 { font-size: 1.3rem; color: var(--green-deep); }
.toppings-card p { color: var(--green-deep); font-size: .95rem; margin: 8px 0 0; opacity: .9; }
.toppings-card .chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.toppings-card .chips span { background: rgba(255,255,255,.6); border-radius: var(--r-pill); padding: 6px 13px; font-size: .85rem; font-weight: 600; color: var(--green-deep); }
@media (max-width: 760px) { .menu-aside { grid-template-columns: 1fr; } }

/* order strip CTA between sections */
.menu-cta { background: linear-gradient(135deg, var(--red), var(--red-deep)); color: #fff; border-radius: var(--r-lg); padding: clamp(28px, 4vw, 44px); text-align: center; position: relative; overflow: hidden; }
.menu-cta::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 85% 20%, rgba(255,255,255,.12), transparent 50%); }
.menu-cta > * { position: relative; }
.menu-cta h2 { color: #fff; font-size: clamp(1.8rem, 3.6vw, 2.6rem); }
.menu-cta p { color: rgba(255,255,255,.85); margin: 8px auto 20px; max-width: 46ch; }

/* side photos + drink cans */
.side-photos { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 14px; margin-bottom: 26px; }
.side-photos figure { margin: 0; border-radius: var(--r); overflow: hidden; box-shadow: var(--shadow-sm); position: relative; aspect-ratio: 16/10; }
.side-photos img { width: 100%; height: 100%; object-fit: cover; }
.side-photos figcaption { position: absolute; left: 0; right: 0; bottom: 0; padding: 22px 14px 11px; color: #fff; font-family: var(--serif); font-size: 1.15rem; background: linear-gradient(transparent, rgba(20,12,8,.72)); }
.cans { display: flex; gap: 14px 22px; flex-wrap: wrap; margin-bottom: 22px; }
.can { display: flex; flex-direction: column; align-items: center; gap: 8px; width: 92px; text-align: center; }
.can img { height: 104px; width: auto; object-fit: contain; filter: drop-shadow(0 8px 14px rgba(20,12,8,.16)); }
.can b { font-size: .82rem; font-weight: 700; }
.can .cp { color: var(--red); font-weight: 800; font-size: .88rem; }
