:root {
  --ink: #1c2721;
  --forest: #233c33;
  --paper: #f5f0e7;
  --cream: #fbf8f2;
  --rust: #b95436;
  --line: rgba(28, 39, 33, 0.2);
  --serif: "Fraunces", Georgia, serif;
  --sans: "DM Sans", Arial, sans-serif;
}

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

.site-header {
  align-items: center; background: rgba(245, 240, 231, 0.94); display: flex; height: 76px;
  justify-content: space-between; padding: 0 6vw; position: sticky; top: 0; z-index: 10;
  border-bottom: 1px solid rgba(28, 39, 33, 0.13); backdrop-filter: blur(14px);
}
.wordmark { display: flex; flex-direction: column; line-height: 1; }
.wordmark-main { font-family: var(--serif); font-size: 30px; font-weight: 600; }
.wordmark-sub { font-size: 9px; font-weight: 700; letter-spacing: 2px; margin-top: 5px; text-transform: uppercase; }
.site-nav { align-items: center; display: flex; gap: 30px; font-size: 12px; font-weight: 700; text-transform: uppercase; }
.nav-call { background: var(--rust); color: white; padding: 13px 16px; }
.nav-toggle { display: none; }

.hero { color: white; height: min(760px, calc(100vh - 76px)); min-height: 610px; overflow: hidden; position: relative; }
.hero-image, .hero-shade { height: 100%; inset: 0; position: absolute; }
.hero-image { object-position: center; }
.hero-shade { background: linear-gradient(90deg, rgba(14, 23, 20, .88), rgba(14, 23, 20, .56) 45%, rgba(14, 23, 20, .12)); }
.hero-content { bottom: 16%; left: 7vw; max-width: 730px; position: absolute; }
.eyebrow, .section-kicker { color: var(--rust); font-size: 11px; font-weight: 700; letter-spacing: 2px; margin: 0 0 18px; text-transform: uppercase; }
.hero .eyebrow { color: #f0a383; }
h1, h2, h3, p { margin-top: 0; }
h1 { font-family: var(--serif); font-size: clamp(68px, 8vw, 118px); font-weight: 500; letter-spacing: 0; line-height: .92; margin-bottom: 22px; }
h1 em { color: #f0a383; font-weight: 500; }
.hero-copy { font-size: 17px; line-height: 1.65; max-width: 550px; }
.hero-actions { align-items: center; display: flex; gap: 22px; margin-top: 32px; }
.button { display: inline-block; font-size: 12px; font-weight: 700; padding: 15px 19px; text-transform: uppercase; }
.button-light { background: white; color: var(--ink); }
.text-link, .line-link { font-size: 12px; font-weight: 700; text-transform: uppercase; }
.text-link span, .line-link span { color: var(--rust); margin-left: 4px; }
.hero-meta { bottom: 28px; display: flex; font-size: 11px; font-weight: 700; justify-content: space-between; left: 7vw; letter-spacing: 1px; position: absolute; right: 7vw; text-transform: uppercase; }

.band { padding: 112px 7vw; }
.intro { background: var(--cream); }
.intro-grid { display: grid; gap: 80px; grid-template-columns: 1fr 0.7fr; }
h2 { font-family: var(--serif); font-size: clamp(44px, 5vw, 74px); font-weight: 500; letter-spacing: 0; line-height: 1; }
.intro-grid p, .story-copy p { color: rgba(28, 39, 33, .76); font-size: 16px; line-height: 1.8; }
.line-link { border-bottom: 1px solid var(--line); display: inline-block; margin-top: 13px; padding-bottom: 7px; }

.menu-section { background: var(--forest); color: white; }
.section-heading { align-items: end; display: flex; justify-content: space-between; margin-bottom: 42px; }
.section-heading h2 { margin-bottom: 0; }
.section-heading > p { color: rgba(255,255,255,.66); font-size: 14px; line-height: 1.6; margin-bottom: 4px; max-width: 380px; }
.menu-layout { display: grid; gap: 5vw; grid-template-columns: 1.05fr .95fr; }
.feature-dish img { height: 410px; }
.feature-caption { background: var(--cream); color: var(--ink); display: flex; gap: 24px; padding: 25px; }
.feature-caption span, .menu-number { color: var(--rust); font-family: var(--serif); font-size: 22px; }
.feature-caption h3, .menu-list h3 { font-family: var(--serif); font-size: 28px; font-weight: 500; letter-spacing: 0; margin-bottom: 6px; }
.feature-caption p, .menu-list p { color: rgba(28,39,33,.7); font-size: 13px; line-height: 1.55; margin: 0; }
.menu-list article { border-bottom: 1px solid rgba(255,255,255,.2); display: grid; gap: 22px; grid-template-columns: 38px 1fr; padding: 20px 0; }
.menu-list article:first-child { padding-top: 0; }
.menu-list p { color: rgba(255,255,255,.63); }
.menu-list h3 { color: white; }

.story-section { display: grid; gap: 7vw; grid-template-columns: 1fr .85fr; }
.story-image-wrap { position: relative; }
.story-image-wrap img { height: 590px; }
.image-note { background: var(--rust); bottom: 0; color: white; font-size: 11px; font-weight: 700; letter-spacing: 1px; padding: 15px 18px; position: absolute; right: 0; text-transform: uppercase; }
.story-copy { align-self: center; }
.story-copy h2 { font-size: clamp(43px, 4vw, 64px); }

.visit-section { background: var(--cream); display: grid; grid-template-columns: 1.05fr .95fr; }
.visit-copy { padding: 100px 7vw; }
.visit-grid { display: grid; gap: 40px; grid-template-columns: 1fr 1fr; margin-top: 46px; }
.visit-grid h3 { color: var(--rust); font-size: 11px; letter-spacing: 2px; text-transform: uppercase; }
.visit-grid p { font-size: 15px; line-height: 1.8; }
.visit-image img { height: 100%; min-height: 520px; }
footer { align-items: center; background: var(--ink); color: white; display: flex; gap: 38px; justify-content: space-between; padding: 34px 7vw; }
footer p { color: rgba(255,255,255,.58); font-size: 11px; line-height: 1.5; margin: 0; max-width: 520px; }
footer > a:last-child { font-size: 12px; font-weight: 700; }

@media (max-width: 760px) {
  .site-header { height: 68px; padding: 0 5vw; }
  .site-nav { background: var(--paper); border-top: 1px solid var(--line); display: none; flex-direction: column; gap: 0; left: 0; padding: 10px 5vw 18px; position: absolute; right: 0; top: 68px; }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 13px 0; width: 100%; }
  .site-nav .nav-call { padding-left: 14px; }
  .nav-toggle { background: transparent; border: 0; display: grid; gap: 6px; padding: 10px 0 10px 10px; }
  .nav-toggle span { background: var(--ink); display: block; height: 2px; width: 25px; }
  .hero { height: 700px; min-height: 0; }
  .hero-shade { background: linear-gradient(90deg, rgba(14,23,20,.8), rgba(14,23,20,.25)), linear-gradient(0deg, rgba(14,23,20,.75), transparent 55%); }
  .hero-content { bottom: 116px; left: 5vw; right: 5vw; }
  h1 { font-size: clamp(65px, 18vw, 88px); }
  .hero-copy { font-size: 15px; max-width: 360px; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 19px; margin-top: 26px; }
  .hero-meta { bottom: 23px; flex-direction: column; gap: 8px; left: 5vw; right: 5vw; }
  .band { padding: 78px 5vw; }
  .intro-grid, .menu-layout, .story-section, .visit-section { display: block; }
  h2 { font-size: 51px; }
  .intro-grid { gap: 0; }
  .section-heading { display: block; }
  .section-heading > p { margin-top: 17px; }
  .feature-dish img { height: 310px; }
  .menu-list { margin-top: 28px; }
  .story-image-wrap img { height: 390px; }
  .story-copy { padding-top: 45px; }
  .visit-copy { padding: 76px 5vw; }
  .visit-grid { display: grid; gap: 28px; grid-template-columns: 1fr; margin-top: 35px; }
  .visit-image img { min-height: 330px; }
  footer { align-items: flex-start; flex-direction: column; gap: 20px; padding: 32px 5vw; }
}
