:root {
  --ink: #1d211d;
  --paper: #f4f0e7;
  --surface: #fbf8f1;
  --moss: #2f4438;
  --moss-dark: #1d3028;
  --brick: #a64d32;
  --gold: #d4ae65;
  --muted: #736f67;
  --line: rgba(29, 33, 29, 0.16);
  color-scheme: light;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "DM Sans", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0;
}

img {
  display: block;
  width: 100%;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

.site-header {
  position: fixed;
  z-index: 20;
  inset: 0 0 auto;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  padding: 18px clamp(18px, 4vw, 58px);
  color: #fffdf8;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
}

.site-header.is-scrolled {
  background: rgba(244, 240, 231, 0.96);
  border-bottom: 1px solid var(--line);
  color: var(--ink);
  backdrop-filter: blur(16px);
}

.wordmark {
  display: grid;
  width: max-content;
  gap: 2px;
}

.wordmark span,
h1,
h2 {
  font-family: "Libre Baskerville", Georgia, serif;
  font-weight: 400;
  letter-spacing: 0;
}

.wordmark span {
  font-size: 1.15rem;
}

.wordmark small,
nav,
.header-call,
.kicker,
.fact-strip span,
.dish span,
.button {
  font-size: 0.71rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.wordmark small {
  opacity: 0.78;
}

nav {
  display: flex;
  gap: clamp(18px, 3vw, 34px);
}

.header-call {
  justify-self: end;
  border-bottom: 1px solid currentColor;
  padding: 8px 1px 5px;
}

.hero {
  position: relative;
  min-height: 91svh;
  display: grid;
  align-items: end;
  overflow: hidden;
  padding: 132px clamp(18px, 4vw, 58px) 76px;
  color: #fffdf8;
}

.hero-image,
.hero-shade {
  position: absolute;
  inset: 0;
}

.hero-image {
  background: url("https://images.unsplash.com/photo-1516211697506-8360dbcfe9a4?auto=format&fit=crop&w=2200&q=86") center/cover;
  transform: scale(1.02);
}

.hero-shade {
  background:
    linear-gradient(90deg, rgba(12, 18, 15, 0.86), rgba(12, 18, 15, 0.48) 58%, rgba(12, 18, 15, 0.16)),
    linear-gradient(0deg, rgba(12, 18, 15, 0.78), rgba(12, 18, 15, 0.05) 52%);
}

.hero-copy {
  position: relative;
  z-index: 2;
  max-width: 820px;
}

.kicker {
  margin: 0 0 14px;
  color: var(--brick);
}

.hero .kicker {
  color: var(--gold);
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 20px;
  font-size: clamp(4.2rem, 11vw, 9rem);
  line-height: 0.93;
}

h2 {
  max-width: 12ch;
  margin-bottom: 0;
  font-size: clamp(2.45rem, 5.5vw, 5rem);
  line-height: 1.01;
}

h3 {
  margin: 0 0 7px;
  font-size: 1.05rem;
}

.hero-lede {
  max-width: 570px;
  margin-bottom: 0;
  color: rgba(255, 253, 248, 0.88);
  font-size: clamp(1.05rem, 2vw, 1.3rem);
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 11px;
  margin-top: 28px;
}

.button {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid currentColor;
  padding: 12px 18px;
}

.button.light {
  background: #fffdf8;
  border-color: #fffdf8;
  color: var(--ink);
}

.button.outline {
  color: #fffdf8;
}

.button.dark {
  background: var(--moss-dark);
  border-color: var(--moss-dark);
  color: #fffdf8;
}

.button.line {
  color: var(--moss-dark);
}

.hero-address {
  position: absolute;
  z-index: 2;
  right: clamp(18px, 4vw, 58px);
  bottom: 34px;
  display: grid;
  color: #fffdf8;
  text-align: right;
}

.hero-address span {
  font-weight: 700;
}

.hero-address small {
  color: rgba(255, 253, 248, 0.74);
}

.fact-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  background: var(--moss-dark);
  color: #fffdf8;
}

.fact-strip div {
  min-height: 132px;
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 24px clamp(18px, 4vw, 58px);
  border-right: 1px solid rgba(255, 253, 248, 0.17);
}

.fact-strip span {
  color: var(--gold);
}

.fact-strip small {
  color: rgba(255, 253, 248, 0.68);
}

.section {
  padding: clamp(74px, 10vw, 132px) clamp(18px, 4vw, 58px);
}

.intro {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.72fr);
  align-items: end;
  gap: clamp(30px, 6vw, 86px);
}

.intro > p,
.menu-heading > p {
  max-width: 610px;
  margin-bottom: 4px;
  color: var(--muted);
  font-size: clamp(1.02rem, 1.8vw, 1.2rem);
}

.menu {
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.menu-heading {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.64fr);
  gap: 14px clamp(30px, 6vw, 86px);
  align-items: end;
  margin-bottom: 36px;
}

.menu-heading .kicker {
  grid-column: 1 / -1;
}

.dish-grid {
  display: grid;
  grid-template-columns: 1.25fr 1fr 1fr;
  gap: 14px;
}

.dish {
  display: grid;
  min-height: 420px;
  overflow: hidden;
  background: var(--moss-dark);
  color: #fffdf8;
}

.dish img {
  height: 100%;
  min-height: 278px;
  object-fit: cover;
}

.dish div {
  padding: 20px;
}

.dish span {
  display: block;
  margin-bottom: 8px;
  color: var(--gold);
}

.dish p {
  margin-bottom: 0;
  color: rgba(255, 253, 248, 0.72);
  font-size: 0.91rem;
}

.visit {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, 0.96fr);
  min-height: 650px;
}

.visit-image {
  min-height: 430px;
  background: url("https://images.unsplash.com/photo-1552566626-52f8b828add9?auto=format&fit=crop&w=1600&q=84") center/cover;
}

.visit-copy {
  display: grid;
  align-content: center;
  padding: clamp(52px, 8vw, 112px) clamp(18px, 6vw, 90px);
  background: #dfd6c6;
}

address {
  display: grid;
  gap: 4px;
  margin-top: 28px;
  color: #5f5d56;
  font-style: normal;
}

address strong {
  margin-bottom: 5px;
  color: var(--ink);
}

footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px 26px;
  padding: 22px clamp(18px, 4vw, 58px);
  background: var(--moss-dark);
  color: rgba(255, 253, 248, 0.68);
  font-size: 0.74rem;
}

@media (max-width: 760px) {
  .site-header {
    grid-template-columns: 1fr auto;
  }

  nav {
    display: none;
  }

  .hero {
    min-height: 86svh;
    padding-bottom: 108px;
  }

  .hero-address {
    left: 18px;
    right: auto;
    bottom: 30px;
    text-align: left;
  }

  h1 {
    font-size: clamp(3.85rem, 18vw, 5.9rem);
  }

  h2 {
    font-size: clamp(2.35rem, 12vw, 3.6rem);
  }

  .fact-strip,
  .intro,
  .menu-heading,
  .dish-grid,
  .visit {
    grid-template-columns: 1fr;
  }

  .fact-strip div {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(255, 253, 248, 0.17);
  }

  .fact-strip div:last-child {
    border-bottom: 0;
  }

  .menu-heading .kicker {
    grid-column: auto;
  }

  .dish {
    min-height: auto;
  }

  .dish img {
    height: 280px;
    min-height: auto;
  }

  .visit {
    min-height: auto;
  }

  .visit-image {
    min-height: 330px;
  }
}
