:root {
  --red: #c5162e;
  --blue: #123c8c;
  --navy: #111827;
  --gold: #f6b93b;
  --cream: #fff7ed;
  --white: #ffffff;
  --muted: #6b7280;
  --shadow: 0 18px 45px rgba(17, 24, 39, 0.12);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Montserrat', sans-serif; color: var(--navy); background: var(--cream); line-height: 1.6; }
a { text-decoration: none; color: inherit; }
.container { width: min(1120px, 92%); margin: auto; }

.topbar { background: var(--navy); color: var(--white); font-size: 0.85rem; }
.topbar-content { display: flex; justify-content: space-between; gap: 1rem; padding: .7rem 0; flex-wrap: wrap; }

.navbar { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.94); backdrop-filter: blur(12px); box-shadow: 0 8px 25px rgba(0,0,0,.06); }
.nav-content { display: flex; align-items: center; justify-content: space-between; padding: 1rem 0; }
.logo { display: flex; align-items: center; gap: .7rem; font-weight: 800; color: var(--red); }
.logo-mark { background: linear-gradient(135deg, var(--red), var(--blue)); color: white; width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; }
.nav-links { display: flex; list-style: none; gap: 1.5rem; font-weight: 600; }
.nav-links a:hover { color: var(--red); }
.menu-toggle { display: none; border: none; background: var(--red); color: white; padding: .55rem .8rem; border-radius: 10px; font-size: 1.3rem; }

.hero { padding: 5rem 0; background: radial-gradient(circle at top right, rgba(197,22,46,.15), transparent 35%), linear-gradient(135deg, #fff7ed 0%, #ffffff 100%); }
.hero-grid, .order-grid, .about-grid, .contact-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 3rem; align-items: center; }
.eyebrow { color: var(--red); font-weight: 800; text-transform: uppercase; letter-spacing: .12em; font-size: .82rem; margin-bottom: .7rem; }
h1, h2 { font-family: 'Playfair Display', serif; line-height: 1.1; }
h1 { font-size: clamp(2.4rem, 5vw, 4.8rem); margin-bottom: 1rem; }
h2 { font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem; }
.hero-description { font-size: 1.1rem; color: var(--muted); max-width: 620px; }
.hero-actions { display: flex; gap: 1rem; margin: 2rem 0; flex-wrap: wrap; }
.btn { display: inline-flex; align-items: center; justify-content: center; padding: .95rem 1.4rem; border-radius: 999px; font-weight: 800; border: 2px solid transparent; cursor: pointer; transition: .25s; }
.btn.primary { background: var(--red); color: white; box-shadow: 0 10px 25px rgba(197,22,46,.25); }
.btn.primary:hover { transform: translateY(-2px); background: #a91025; }
.btn.secondary { border-color: var(--blue); color: var(--blue); background: white; }
.btn.secondary:hover { background: var(--blue); color: white; }
.btn.full { width: 100%; margin-top: 1rem; }
.hero-stats { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-stats div { background: white; padding: 1rem; border-radius: 18px; box-shadow: var(--shadow); min-width: 120px; }
.hero-stats strong { display:block; color: var(--blue); font-size: 1.2rem; }
.hero-stats span { color: var(--muted); font-size: .85rem; }
.hero-card { background: white; border-radius: 32px; padding: 2rem; box-shadow: var(--shadow); text-align: center; border: 1px solid rgba(197,22,46,.12); }
.food-circle { width: 180px; height: 180px; margin: 0 auto 1rem; border-radius: 50%; display: grid; place-items: center; font-size: 5rem; background: linear-gradient(135deg, #fff0d9, #ffe2e8); }
.price { display:inline-block; margin-top:1rem; background:var(--gold); padding:.5rem 1rem; border-radius:999px; font-weight:800; }

.features { margin-top: -2rem; }
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.feature-grid article { background: white; border-radius: 24px; padding: 1.5rem; box-shadow: var(--shadow); }
.feature-grid span { font-size: 2rem; }

.section { padding: 5rem 0; }
.section-heading { text-align: center; max-width: 720px; margin: 0 auto 2rem; }
.section-heading p { color: var(--muted); }
.category-filter { display:flex; justify-content:center; flex-wrap:wrap; gap:.8rem; margin-bottom:2rem; }
.category-btn { border:none; background:white; padding:.7rem 1rem; border-radius:999px; font-weight:700; cursor:pointer; box-shadow:0 8px 20px rgba(0,0,0,.06); }
.category-btn.active { background:var(--blue); color:white; }
.menu-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:1.2rem; }
.menu-card { background:white; border-radius:24px; padding:1.3rem; box-shadow:var(--shadow); display:flex; flex-direction:column; gap:.7rem; }
.menu-card .emoji { font-size:2.4rem; }
.menu-card h3 { font-size:1.1rem; }
.menu-card p { color:var(--muted); font-size:.9rem; }
.menu-card footer { display:flex; align-items:center; justify-content:space-between; margin-top:auto; gap: .7rem; }
.add-btn { border:none; background:var(--red); color:white; border-radius:999px; padding:.55rem .8rem; font-weight:800; cursor:pointer; }
.add-btn:hover { background:#a91025; }

.order-section { background: white; }
.cart { background: var(--cream); border-radius: 20px; padding: 1rem; min-height: 120px; margin-top: 1.2rem; }
.cart-row { display:flex; justify-content:space-between; align-items:center; gap:.8rem; padding:.7rem 0; border-bottom:1px solid rgba(0,0,0,.08); }
.cart-row button { border:none; background:var(--navy); color:white; border-radius:8px; padding:.25rem .55rem; cursor:pointer; }
.empty-cart { color: var(--muted); }
.cart-total { display:flex; justify-content:space-between; margin-top:1rem; font-size:1.2rem; }
.order-card, .reservation-box, .contact-form { background: var(--cream); border-radius: 28px; padding: 2rem; box-shadow: var(--shadow); }
.order-card ol { padding-left:1.2rem; margin-top:1rem; }
.reservation-box { display:flex; align-items:center; justify-content:space-between; gap:2rem; background: linear-gradient(135deg, var(--red), var(--blue)); color:white; }
.reservation-box .eyebrow { color: #ffeab3; }
.about-image { min-height: 330px; border-radius: 32px; background: linear-gradient(135deg, var(--red), var(--blue)); display:grid; place-items:center; font-size:7rem; box-shadow:var(--shadow); }
.contact { background:white; }
.contact-form { display:flex; flex-direction:column; gap:1rem; }
.contact-form input, .contact-form textarea { width:100%; border:1px solid #e5e7eb; border-radius:16px; padding:1rem; font: inherit; }
.footer { background: var(--navy); color:white; padding:2rem 0; }
.footer-content { display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color:#d1d5db; }

@media (max-width: 850px) {
  .menu-toggle { display:block; }
  .nav-links { display:none; position:absolute; top:74px; left:0; right:0; background:white; flex-direction:column; padding:1rem 4%; box-shadow:var(--shadow); }
  .nav-links.open { display:flex; }
  .hero-grid, .order-grid, .about-grid, .contact-grid { grid-template-columns: 1fr; }
  .feature-grid, .menu-grid { grid-template-columns: 1fr; }
  .reservation-box { flex-direction:column; align-items:flex-start; }
}
