/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 20;
  display: flex; flex-wrap: wrap; gap: var(--gap); align-items: center; justify-content: space-between;
  background: var(--ink); color: var(--paper); padding: 0.5rem 1.25rem;
}
.brand { display: flex; align-items: center; text-decoration: none; }
.brand__logo { display: block; height: 46px; width: auto; }
.site-nav { display: flex; gap: 1.25rem; flex-wrap: wrap; }
.site-nav a { color: var(--paper); text-decoration: none; font-weight: 600; letter-spacing: 0.2px; }
.site-nav a:hover { color: var(--md-gold); }

/* ---------- Hero ---------- */
.hero { position: relative; min-height: 460px; display: flex; align-items: center; justify-content: center; overflow: hidden; text-align: center; }
.hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-overlay { position: absolute; inset: 0; background:
  linear-gradient(180deg, rgba(26,26,26,0.50) 0%, rgba(184,28,40,0.40) 55%, rgba(26,26,26,0.88) 100%),
  linear-gradient(90deg, rgba(26,26,26,0.45) 0%, rgba(26,26,26,0) 55%); }
.hero-content { position: relative; z-index: 1; padding: 3rem 1rem; max-width: 760px; }
.hero-eyebrow { color: var(--md-gold); font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; font-size: 0.82rem; margin: 0 0 1.25rem; text-shadow: 0 1px 3px rgba(0,0,0,0.6); }
.hero-logo { display: block; width: 100%; max-width: 560px; height: auto; margin: 0 auto; filter: drop-shadow(0 8px 18px rgba(0,0,0,0.65)); }
.hero-tagline { color: #fff; font-weight: 700; margin: 1.25rem 0 0; text-shadow: 0 1px 4px rgba(0,0,0,0.7); }

/* ---------- Sections ---------- */
.section { max-width: var(--maxw); margin: 0 auto; padding: 2.75rem 1.25rem; }
.section__title { font-size: 1.7rem; margin: 0 0 1.5rem; color: var(--ink); position: relative; padding-bottom: 0.5rem; }
.section__title::after { content: ""; position: absolute; left: 0; bottom: 0; width: 56px; height: 4px; background: var(--md-gold); border-radius: 2px; }
.food__intro { margin: -0.75rem 0 1.5rem; max-width: 60ch; color: var(--ink); opacity: 0.85; }

/* ---------- Image-forward tiles ---------- */
.tile-grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.tile {
  position: relative; aspect-ratio: 4 / 5; border-radius: 16px; overflow: hidden;
  background: var(--ink); box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 16px 34px rgba(0,0,0,0.20);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.tile:hover { transform: translateY(-4px); box-shadow: 0 2px 6px rgba(0,0,0,0.15), 0 22px 44px rgba(0,0,0,0.28); }
.tile__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.tile--noimg { background: linear-gradient(150deg, var(--md-red) 0%, #7d1019 100%); }
.tile--noimg::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,0.06) 1px, transparent 1px); background-size: 16px 16px; }
.tile__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.25) 52%, rgba(0,0,0,0.86) 100%); }
.tile__text { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 1.1rem 1.15rem; color: #fff; }
.tile__name { margin: 0; font-size: 1.18rem; line-height: 1.2; text-shadow: 0 1px 3px rgba(0,0,0,0.7); }
.tile__price { margin: 0.35rem 0 0; font-weight: 800; color: var(--md-gold); text-shadow: 0 1px 3px rgba(0,0,0,0.7); }
.tile__blurb { margin: 0.4rem 0 0; font-size: 0.92rem; line-height: 1.35; opacity: 0.96; text-shadow: 0 1px 3px rgba(0,0,0,0.7); }
.badge { position: absolute; top: 10px; right: 10px; z-index: 2; background: var(--md-gold); color: var(--ink); font-weight: 800; font-size: 0.7rem; letter-spacing: 0.5px; padding: 0.2rem 0.5rem; border-radius: 5px; }

/* ---------- New Arrivals tabs ---------- */
.tabs { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.tab { min-height: 44px; padding: 0 1.15rem; border: 2px solid var(--md-red); background: transparent; color: var(--md-red); border-radius: 22px; font-weight: 700; cursor: pointer; transition: background 0.15s ease, color 0.15s ease; }
.tab:hover { background: rgba(184,28,40,0.08); }
.tab.is-active { background: var(--md-red); color: var(--paper); }

/* ---------- Locations ---------- */
.locations-grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); align-items: start; }
.location { border-radius: 16px; overflow: hidden; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.07), 0 14px 32px rgba(0,0,0,0.10); }
.location__img { display: block; width: 100%; height: 190px; object-fit: cover; }
.location__body { padding: 1.1rem 1.25rem 1.4rem; }
.location__body h3 { margin: 0 0 0.45rem; font-size: 1.2rem; }
.location__body p { margin: 0.2rem 0; }
.location__links { margin-top: 0.7rem; }
.location__links a { color: var(--md-red); font-weight: 700; text-decoration: none; margin-right: 0.85rem; }
.location__links a:hover { text-decoration: underline; }
.partners { margin-top: 1.5rem; font-weight: 600; }
.partners a, .partners .partner { color: var(--md-red); font-weight: 700; }

/* ---------- Community ---------- */
.community__intro { max-width: 62ch; color: var(--ink); opacity: 0.85; margin: -0.75rem 0 1.5rem; }
.community-grid { display: grid; gap: 1.25rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.community__img { width: 100%; height: 260px; object-fit: cover; border-radius: 16px; box-shadow: 0 1px 3px rgba(0,0,0,0.10), 0 14px 32px rgba(0,0,0,0.14); }

/* ---------- Misc ---------- */
.empty { font-style: italic; opacity: 0.75; }
.menu-link { display: inline-block; margin-top: 1.5rem; background: var(--md-gold); color: var(--ink); font-weight: 800; padding: 0.7rem 1.25rem; border-radius: 8px; text-decoration: none; }
.menu-link:hover { filter: brightness(0.95); }

.site-footer { background: var(--ink); color: var(--paper); text-align: center; padding: 2rem 1rem; margin-top: 1rem; }
.site-footer a { color: var(--md-gold); margin: 0 0.4rem; }
.footer__credit { font-size: 0.8rem; opacity: 0.65; margin-top: 0.75rem; }

@media (max-width: 600px) {
  .site-header { padding: 0.5rem 1rem; }
  .section { padding: 2rem 1rem; }
  .section__title { font-size: 1.4rem; }
}
