:root {
  --ink: #21342d;
  --ink-soft: #5e6d61;
  --cream: #f5f0e4;
  --paper: #fffdf7;
  --sage: #dce3d1;
  --olive: #819064;
  --gold: #d8aa54;
  --line: rgba(33, 52, 45, 0.16);
  --serif: "Fraunces", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: var(--sans); line-height: 1.6; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; object-fit: cover; }

.site-header { align-items: center; background: rgba(245, 240, 228, 0.94); border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; padding: 18px clamp(18px, 4vw, 60px); position: sticky; top: 0; z-index: 10; }
.brand, .footer-brand { align-items: center; display: flex; gap: 12px; font-family: var(--serif); font-size: 17px; font-weight: 700; letter-spacing: 0; line-height: 1; }
.brand small { font-family: var(--sans); font-size: 10px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; }
.brand-mark { align-items: center; background: var(--ink); border-radius: 50%; color: var(--paper); display: inline-flex; font-size: 11px; height: 42px; justify-content: center; letter-spacing: 0.04em; width: 42px; }
nav { align-items: center; display: flex; gap: clamp(14px, 3vw, 34px); font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.nav-call { border: 1px solid var(--ink); border-radius: 999px; padding: 9px 14px; }

.hero { display: grid; min-height: min(760px, calc(100vh - 79px)); }
.hero-copy { align-self: center; padding: 72px clamp(22px, 7vw, 100px); }
.eyebrow, .menu-kicker { color: var(--olive); font-size: 11px; font-weight: 700; letter-spacing: 0.16em; margin: 0 0 16px; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--serif); font-weight: 600; letter-spacing: 0; line-height: 1.02; margin: 0; }
h1 { font-size: clamp(58px, 8vw, 112px); }
h1 em { color: var(--olive); font-weight: 500; }
h2 { font-size: clamp(44px, 5vw, 72px); }
h3 { font-size: 30px; }
.hero-intro { color: var(--ink-soft); font-size: 17px; margin: 30px 0 0; max-width: 580px; }
.hero-actions, .visit-actions { align-items: center; display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.button { border-radius: 999px; display: inline-flex; font-size: 12px; font-weight: 700; letter-spacing: 0.1em; padding: 14px 20px; text-transform: uppercase; }
.button-primary { background: var(--ink); color: var(--paper); }
.button-ghost { border: 1px solid var(--line); }
.hero-meta { border-top: 1px solid var(--line); display: flex; flex-wrap: wrap; font-size: 11px; font-weight: 700; gap: 12px 28px; letter-spacing: 0.12em; margin-top: 54px; padding-top: 18px; text-transform: uppercase; }
.hero-media { min-height: 440px; overflow: hidden; position: relative; }
.hero-media img { height: 100%; width: 100%; }
.image-note { background: rgba(33,52,45,.82); bottom: 14px; color: var(--paper); font-size: 10px; letter-spacing: .12em; margin: 0; padding: 7px 10px; position: absolute; right: 14px; text-transform: uppercase; }

.section-shell { margin: 0 auto; max-width: 1320px; padding: 100px clamp(22px, 6vw, 80px); }
.intro { display: grid; gap: 22px; }
.intro p:last-child, .section-heading > p:last-child, .visit-copy > p { color: var(--ink-soft); margin: 24px 0 0; max-width: 620px; }
.quick-info { background: var(--paper); border-bottom: 1px solid var(--line); border-top: 1px solid var(--line); display: grid; gap: 1px; grid-template-columns: 1fr; }
.quick-info > div { background: rgba(220, 227, 209, 0.42); display: grid; gap: 4px; min-height: 112px; padding: 24px clamp(22px, 6vw, 80px); }
.quick-info span { color: var(--olive); font-size: 11px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.quick-info strong { font-family: var(--serif); font-size: clamp(24px, 3vw, 34px); font-weight: 600; line-height: 1.08; }
.menu-section { background: var(--ink); color: var(--paper); }
.menu-section .eyebrow { color: var(--gold); }
.section-heading { display: grid; gap: 0; margin-bottom: 36px; }
.section-heading > p:last-child { color: rgba(255,253,247,.72); }
.menu-grid { display: grid; gap: 12px; }
.menu-card { background: var(--paper); color: var(--ink); min-height: 240px; overflow: hidden; }
.feature-card img, .image-card img { height: 230px; width: 100%; }
.feature-card div, .text-card { padding: 24px; }
.menu-card p { color: var(--ink-soft); font-size: 14px; margin: 14px 0 0; }
.menu-kicker { color: var(--olive) !important; margin: 0 0 10px !important; }
.text-card { display: flex; flex-direction: column; justify-content: end; }
.menu-number { color: var(--olive) !important; font-size: 11px !important; font-weight: 700; letter-spacing: .16em; margin: 0 auto auto 0 !important; }
.text-card.olive { background: var(--olive); color: var(--paper); }
.text-card.olive p, .text-card.gold p { color: rgba(255,253,247,.78) !important; }
.text-card.gold { background: var(--gold); color: var(--ink); }

.visit { display: grid; gap: 38px; }
.text-link { font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.hours-card { background: var(--sage); padding: 28px; }
dl { margin: 26px 0 0; }
dl div { border-top: 1px solid var(--line); display: flex; font-size: 14px; justify-content: space-between; padding: 12px 0; }
dt { font-weight: 700; }
dd { margin: 0; }
.hours-note { color: var(--ink-soft); font-size: 11px; margin: 18px 0 0; }
footer { align-items: center; background: #1b2b25; color: var(--paper); display: flex; flex-wrap: wrap; gap: 24px; justify-content: space-between; padding: 28px clamp(22px, 6vw, 80px); }
footer .brand-mark { background: var(--paper); color: var(--ink); }
footer span { color: rgba(255,253,247,.65); font-size: 12px; }
footer a { font-family: var(--serif); font-size: 24px; }

@media (min-width: 760px) {
  .hero { grid-template-columns: minmax(0, 1.08fr) minmax(340px, .92fr); }
  .intro { grid-template-columns: 190px minmax(0, 740px); }
  .quick-info { grid-template-columns: repeat(3, 1fr); }
  .quick-info > div { padding-left: clamp(28px, 4vw, 70px); padding-right: clamp(28px, 4vw, 70px); }
  .menu-grid { grid-template-columns: repeat(3, 1fr); }
  .feature-card { grid-row: span 2; }
  .feature-card img { height: 300px; }
  .visit { grid-template-columns: minmax(0, 1fr) minmax(300px, 430px); }
}

@media (max-width: 580px) {
  .site-header { padding: 14px 18px; }
  .brand { font-size: 15px; }
  .brand-mark { height: 38px; width: 38px; }
  nav a:not(.nav-call) { display: none; }
  .nav-call { font-size: 10px; padding: 8px 10px; }
  .hero-copy { padding: 56px 22px 42px; }
  h1 { font-size: 50px; }
  h2 { font-size: 40px; }
  h3 { font-size: 27px; }
  .hero-intro { font-size: 15px; }
  .hero-meta { margin-top: 38px; }
  .hero-media { min-height: 360px; }
  .section-shell { padding-bottom: 76px; padding-top: 76px; }
  .feature-card img { height: 250px; }
  .image-card { min-height: 200px; }
  .image-card img { height: 200px; }
  footer { align-items: flex-start; flex-direction: column; }
}
