/* === SELF-HOSTED FONTS (generated 2026-05-31) === */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/fraunces-italic-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/fraunces-italic-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/fraunces-italic-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/fraunces-italic-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/fraunces-normal-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Nunito Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('../fonts/nunito-sans-normal-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* === END SELF-HOSTED FONTS === */

/* ============================================================
   THE DAILY KNEAD — neighborhood bakery, Knoxville TN
   Brand (Athena v1): Crust Brown #5A3A22 · Warm Cream #FBF6EC
   · Bakehouse Ink #2B2420 · Terracotta #C56A3E · Sage #6B7A5A
   · Soft Stone #ECE3D2
   Type: Fraunces (display) + Nunito Sans (body). Scale 1.250.
   Voice: warm / honest / neighborly.
   CONTRAST DISCIPLINE (Athena): body text is ALWAYS Bakehouse Ink
   on cream/stone. Terracotta & Sage are decorative only — never
   carry small body text. Buttons = Crust Brown fill + cream text
   (9.4:1). Terracotta = rules, underlines, icon fills, hovers.
   ============================================================ */

:root {
  --crust:     #5A3A22;   /* primary: headlines, buttons, footer */
  --crust-700: #432A18;   /* button hover, deep */
  --cream:     #FBF6EC;   /* page background — the flour-dusted base */
  --cream-200: #F4ECDC;   /* subtle banding on cream */
  --ink:       #2B2420;   /* body text (14.2:1 on cream — AAA) */
  --terra:     #C56A3E;   /* accent: rules, underlines, icons, hover */
  --terra-600: #A9542C;   /* darker terracotta where text-adjacent */
  --sage:      #6B7A5A;   /* secondary accent: fresh/local cue */
  --sage-tint: #E7EADF;   /* sage at low strength for tag fills */
  --stone:     #ECE3D2;   /* cards, section banding */
  --stone-700: #C9BCA3;   /* hairlines on warm bg */
  --line:      #DED2BC;   /* borders */
  --muted:     #7A6E60;   /* secondary text — 4.9:1 on cream, AA */
  --white:     #FFFFFF;

  --maxw: 1180px;
  --gap: clamp(16px, 4vw, 40px);
  --radius: 14px;
  --radius-lg: 22px;

  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body: "Nunito Sans", system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
  --shadow: 0 18px 44px rgba(58,37,22,.12);
  --shadow-sm: 0 8px 22px rgba(58,37,22,.08);
}

/* ---------- reset ---------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 84px; }
body {
  font-family: var(--body);
  color: var(--ink);
  background: var(--cream);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font: inherit; cursor: pointer; border: none; background: none; }
::selection { background: var(--terra); color: #fff; }

.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 200;
  background: var(--crust); color: var(--cream); padding: 10px 16px; font-weight: 700; border-radius: 0 0 8px 0;
}
.skip-link:focus { left: 0; top: 0; }

/* ---------- keyboard focus (WCAG 2.4.7) ---------- */
:focus-visible { outline: 3px solid var(--crust); outline-offset: 3px; border-radius: 6px; }
.section--crust :focus-visible, .infostrip :focus-visible, .page-hero :focus-visible, .footer :focus-visible, .form-success :focus-visible { outline-color: var(--cream); }

/* ---------- layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 52px); }
.section { padding-block: clamp(56px, 8vw, 116px); position: relative; }
.section--cream { background: var(--cream); }
.section--stone { background: var(--stone); }
/* On the darker stone background, --muted #7A6E60 drops to 3.9:1 (fails AA).
   Re-scope it to a darker tone (4.8:1 on stone) for all descendants. */
.section--stone, .cater { --muted: #6B6052; }
.section--crust { background: var(--crust); color: var(--cream); }
.section--tight { padding-block: clamp(40px, 5vw, 72px); }

.eyebrow {
  font-family: var(--body);
  font-weight: 800; font-size: .8rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--terra-600); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 18px;
}
.eyebrow::before { content:""; width: 30px; height: 2px; background: var(--terra); display:inline-block; border-radius: 2px; }
.section--crust .eyebrow { color: #E9A77F; }
.section--crust .eyebrow::before { background: #E9A77F; }

.section__title {
  font-family: var(--display); font-weight: 600; letter-spacing: -.01em; line-height: 1.05;
  font-size: clamp(2rem, 4.6vw, 3.1rem); color: var(--crust); max-width: 18ch;
}
.section--crust .section__title { color: var(--cream); }
.lead { font-size: clamp(1.06rem, 1.5vw, 1.22rem); color: var(--muted); max-width: 56ch; margin-top: 18px; }
.section--crust .lead { color: rgba(251,246,236,.82); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--body); font-weight: 800; font-size: 1rem; letter-spacing: .01em;
  padding: 15px 26px; border-radius: 50px;
  transition: transform .2s var(--ease), background .2s, color .2s, border-color .2s, box-shadow .2s;
  border: 2px solid transparent; white-space: nowrap;
}
.btn svg { width: 18px; height: 18px; }
.btn--primary { background: var(--crust); color: var(--cream); }
.btn--primary:hover { background: var(--crust-700); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn--ghost { border-color: var(--crust); color: var(--crust); }
.btn--ghost:hover { background: var(--crust); color: var(--cream); transform: translateY(-2px); }
.btn--cream { background: var(--cream); color: var(--crust); }
.btn--cream:hover { background: #fff; transform: translateY(-2px); box-shadow: 0 10px 26px rgba(0,0,0,.18); }
.btn--ghost-cream { border-color: rgba(251,246,236,.55); color: var(--cream); }
.btn--ghost-cream:hover { border-color: var(--cream); background: rgba(251,246,236,.1); transform: translateY(-2px); }

/* ---------- header ---------- */
.header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(251,246,236,.88); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.header__inner { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 16px; }

/* stamp-style wordmark (CSS-recreatable per Athena) */
.brand { display: inline-flex; align-items: center; }
.dk-wordmark { font-family: var(--display); color: var(--crust); line-height: .92; text-align: left; }
.dk-wordmark .top { display:block; font-style: italic; font-weight: 500; font-size: .82rem; letter-spacing: .02em; }
.dk-wordmark .main { display:block; font-weight: 600; font-size: 1.5rem; letter-spacing: .05em; text-transform: uppercase; }
.dk-wordmark .rule { display:block; width: 100%; height: 2px; background: var(--terra); margin-top: 3px; border-radius: 2px; }

.nav { display: flex; align-items: center; gap: clamp(16px, 2.2vw, 32px); }
.nav__link {
  font-family: var(--body); font-weight: 700; font-size: .98rem; color: var(--ink);
  transition: color .15s; position: relative; padding: 6px 0;
}
.nav__link:hover { color: var(--terra-600); }
.nav__link::after { content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background: var(--terra); transition: width .2s var(--ease); border-radius: 2px; }
.nav__link:hover::after, .nav__link[aria-current="page"]::after { width: 100%; }
.nav__cta { margin-left: 4px; padding: 11px 22px; }
.nav-toggle { display:none; width:44px; height:44px; flex-direction:column; gap:5px; justify-content:center; align-items:center; }
.nav-toggle span { width:24px; height:2px; background: var(--crust); border-radius:2px; transition:.25s var(--ease); }

/* ---------- hero ---------- */
.hero { position: relative; background: var(--cream); overflow: hidden; }
.hero::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:
    radial-gradient(40% 55% at 88% 8%, rgba(197,106,62,.10), transparent 70%),
    radial-gradient(46% 50% at 6% 96%, rgba(107,122,90,.10), transparent 70%);
}
.hero__inner {
  position: relative; display: grid; grid-template-columns: 1.04fr .96fr;
  gap: clamp(28px, 5vw, 64px); align-items: center;
  padding-block: clamp(48px, 7vw, 104px);
}
.hero__badge {
  display:inline-flex; align-items:center; gap:9px; background: var(--sage-tint); color: var(--crust);
  font-weight: 800; font-size: .82rem; letter-spacing: .04em; padding: 8px 16px; border-radius: 50px; margin-bottom: 22px;
}
.hero__badge .dotpulse { width:8px; height:8px; border-radius:50%; background: var(--sage); position:relative; }
.hero__badge .dotpulse::after { content:""; position:absolute; inset:-4px; border-radius:50%; border:1px solid var(--sage); opacity:.5; }
.hero__title {
  font-family: var(--display); font-weight: 600; color: var(--crust);
  font-size: clamp(2.7rem, 6.4vw, 4.6rem); line-height: 1.02; letter-spacing: -.015em;
}
.hero__title em { font-style: italic; font-weight: 500; color: var(--terra-600); }
.hero__sub { margin-top: 22px; font-size: clamp(1.1rem, 1.7vw, 1.32rem); color: var(--ink); max-width: 40ch; }
.hero__cta { display:flex; flex-wrap:wrap; gap: 14px; margin-top: 34px; }
.hero__note { margin-top: 20px; font-size: .92rem; color: var(--muted); display:flex; align-items:center; gap:8px; }
.hero__note svg { width:16px; height:16px; color: var(--terra); flex:none; }

/* hero photo slot */
.hero__media {
  position: relative; aspect-ratio: 4/5; border-radius: var(--radius-lg); overflow: hidden;
  background:
    linear-gradient(150deg, #E8C9A0, #C56A3E 55%, #8A4424);
  box-shadow: var(--shadow); border: 1px solid rgba(90,58,34,.12);
}
.photo-slot { position: relative; display:flex; align-items:center; justify-content:center; text-align:center; isolation:isolate; }
.photo-slot::after {
  content: attr(data-slot); position:absolute; inset:0; z-index:1; pointer-events:none;
  display:flex; align-items:center; justify-content:center; text-align:center;
  font-family: var(--body); font-weight:800; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase;
  color: rgba(255,255,255,.92); padding: 24px; line-height:1.5;
  background: linear-gradient(180deg, rgba(58,37,22,.18), rgba(58,37,22,.42));
}
.hero__stamp {
  position:absolute; right: 18px; bottom: 18px; z-index:2; width: clamp(78px,9vw,104px); height: clamp(78px,9vw,104px);
  background: var(--cream); border-radius:50%; display:flex; flex-direction:column; align-items:center; justify-content:center;
  box-shadow: var(--shadow-sm); transform: rotate(-8deg); text-align:center; border: 2px solid var(--terra);
}
.hero__stamp b { font-family: var(--display); font-weight:600; color: var(--crust); font-size:1.5rem; line-height:.9; }
.hero__stamp span { font-weight:800; font-size:.58rem; letter-spacing:.12em; text-transform:uppercase; color: var(--terra-600); margin-top:2px; }

/* ---------- info strip (today / hours / location) ---------- */
.infostrip { background: var(--crust); color: var(--cream); }
.infostrip__grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: rgba(251,246,236,.16); border-radius: var(--radius); overflow:hidden; }
.infocell { background: var(--crust); padding: clamp(22px,3vw,34px); }
.infocell__k { font-weight:800; font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; color:#E9A77F; margin-bottom:10px; display:flex; align-items:center; gap:9px; }
.infocell__k svg { width:17px; height:17px; }
.infocell__v { font-family: var(--display); font-weight:600; font-size: clamp(1.15rem,1.8vw,1.5rem); line-height:1.15; }
.infocell__sub { margin-top:7px; font-size:.92rem; color: rgba(251,246,236,.7); }
.infocell a { color: var(--cream); border-bottom: 1px solid rgba(233,167,127,.5); transition: border-color .15s; }
.infocell a:hover { border-color: var(--cream); }

/* ---------- the goods / menu ---------- */
.menu-grid { display:grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: clamp(18px,2.4vw,28px); margin-top: 52px; }
.menu-card { background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); overflow:hidden; transition: transform .25s var(--ease), box-shadow .25s; }
.menu-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.menu-card__media { aspect-ratio: 3/2; background: linear-gradient(150deg,#E8C9A0,#C56A3E); }
.menu-card:nth-child(2) .menu-card__media { background: linear-gradient(150deg,#D9B98A,#A9542C); }
.menu-card:nth-child(3) .menu-card__media { background: linear-gradient(150deg,#B7A98B,#6B7A5A); }
.menu-card__body { padding: clamp(22px,2.6vw,30px); }
.menu-card__title { font-family: var(--display); font-weight:600; font-size: 1.5rem; color: var(--crust); }
.menu-card__desc { margin-top: 8px; color: var(--muted); font-size: .98rem; }
.menu-card__list { margin-top: 18px; border-top: 1px dashed var(--line); padding-top: 16px; }
.menu-card__list li { display:flex; justify-content:space-between; gap:12px; padding: 7px 0; font-weight:600; color: var(--ink); }
.menu-card__list li span { color: var(--terra-600); font-weight:800; white-space:nowrap; }
.menu-card__list li small { display:block; font-weight:400; color: var(--muted); font-size:.84rem; }
.menu-note { margin-top: 26px; font-size: .9rem; color: var(--muted); background: var(--cream-200); border:1px dashed var(--stone-700); border-radius: 12px; padding: 16px 20px; }
.menu-note strong { color: var(--crust); }

/* tag chips */
.chip { display:inline-block; background: var(--sage-tint); color: var(--crust); font-weight:800; font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; padding:5px 12px; border-radius:50px; }

/* ---------- story (split) ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(30px,5vw,70px); align-items:center; }
.split__media { aspect-ratio: 5/4; border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow); background: linear-gradient(150deg,#C9B79A,#5A3A22); border:1px solid rgba(90,58,34,.12); }
.prose p { font-size: clamp(1.04rem,1.5vw,1.16rem); color: var(--ink); margin-bottom: 18px; max-width: 60ch; }
.prose p.first::first-letter {
  font-family: var(--display); font-weight:600; font-size: 3.4rem; float:left; line-height:.8;
  padding: 6px 12px 0 0; color: var(--terra-600);
}
.signature { margin-top: 26px; display:flex; align-items:center; gap:16px; }
.signature__names { font-family: var(--display); font-style:italic; font-weight:500; font-size:1.35rem; color: var(--crust); }
.signature__role { font-size:.86rem; color: var(--muted); font-weight:700; letter-spacing:.04em; text-transform:uppercase; }

/* ---------- catering band ---------- */
.cater { background: var(--stone); }
.cater__inner { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(28px,5vw,60px); align-items:center; }
.cater__list { margin-top: 22px; display:grid; gap: 12px; }
.cater__list li { display:flex; gap:12px; align-items:flex-start; font-weight:600; color: var(--ink); }
.cater__list svg { width:22px; height:22px; color: var(--terra); flex:none; margin-top:1px; }
.cater__card { background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(26px,3vw,38px); box-shadow: var(--shadow-sm); }
.cater__card h3 { font-family: var(--display); font-weight:600; font-size:1.6rem; color: var(--crust); }
.cater__card p { color: var(--muted); margin: 10px 0 22px; }

/* ---------- visit / find us ---------- */
.visit-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(24px,4vw,48px); align-items:start; }
.visit-facts { display:grid; gap: 22px; }
.visit-fact { display:flex; gap:16px; align-items:flex-start; }
.visit-fact__ic { width:46px; height:46px; flex:none; border-radius:12px; background: var(--cream-200); display:flex; align-items:center; justify-content:center; color: var(--terra-600); }
.visit-fact__ic svg { width:22px; height:22px; }
.visit-fact h3 { font-family: var(--display); font-weight:600; font-size:1.2rem; color: var(--crust); }
.visit-fact p, .visit-fact a { color: var(--ink); font-weight:600; }
.visit-fact a { border-bottom:1px solid var(--terra); }
.visit-fact a:hover { color: var(--terra-600); }
.visit-fact .muted { color: var(--muted); font-weight:400; font-size:.95rem; }
.map-embed { aspect-ratio: 4/3; border-radius: var(--radius-lg); overflow:hidden; border:1px solid var(--line); background: var(--cream-200); position:relative; }
.map-embed iframe { width:100%; height:100%; border:0; display:block; }
.map-placeholder { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:24px; color: var(--muted); gap:10px; }
.map-placeholder svg { width:38px; height:38px; color: var(--stone-700); }

/* ---------- instagram strip ---------- */
.ig-strip { text-align:center; }
.ig-tiles { display:grid; grid-template-columns: repeat(6,1fr); gap: 8px; margin-top: 34px; }
.ig-tile { aspect-ratio:1; border-radius: 14px; overflow:hidden; background: linear-gradient(150deg,#E8C9A0,#C56A3E); }
.ig-tile:nth-child(even){ background: linear-gradient(150deg,#C9B79A,#6B7A5A); }
.ig-tile:nth-child(3n){ background: linear-gradient(150deg,#D9B98A,#A9542C); }

/* ---------- page hero (catering / inner) ---------- */
.page-hero { position:relative; background: var(--crust); color: var(--cream); overflow:hidden; }
.page-hero::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.6;
  background: radial-gradient(45% 60% at 85% 0%, rgba(197,106,62,.4), transparent 70%); }
.page-hero__inner { position:relative; padding-block: clamp(48px,7vw,92px); }
.crumbs { font-weight:700; font-size:.82rem; letter-spacing:.06em; color:#E9A77F; margin-bottom:16px; display:flex; gap:10px; flex-wrap:wrap; }
.crumbs a:hover { color: var(--cream); }
.crumbs span { color: rgba(251,246,236,.4); }
.page-hero__title { font-family: var(--display); font-weight:600; font-size: clamp(2.3rem,5.5vw,3.6rem); line-height:1.02; letter-spacing:-.015em; }
.page-hero__title em { font-style:italic; font-weight:500; color:#E9A77F; }
.page-hero__sub { margin-top: 18px; font-size: clamp(1.06rem,1.6vw,1.26rem); color: rgba(251,246,236,.85); max-width: 56ch; }

/* ---------- form ---------- */
.contact-split { display:grid; grid-template-columns: 1.05fr .95fr; gap: clamp(30px,5vw,60px); align-items:start; }
.form { background: var(--white); border:1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(24px,3vw,40px); box-shadow: var(--shadow-sm); }
.field { margin-bottom: 20px; position: relative; }
.field > label { display:block; font-family: var(--body); font-weight:800; font-size:.82rem; letter-spacing:.03em; color: var(--crust); margin-bottom:8px; }
.field .opt { font-weight:600; color: var(--muted); letter-spacing:0; }
.field input, .field select, .field textarea {
  width:100%; font: inherit; color: var(--ink); background: var(--cream);
  border:1.5px solid var(--line); border-radius: 12px; padding: 13px 15px; transition: border-color .15s, box-shadow .15s;
}
.field textarea { min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--terra); box-shadow: 0 0 0 3px rgba(197,106,62,.18); }
.field--error input, .field--error textarea, .field--error select { border-color:#B23B2E; background:#FBF1EF; }
.field__err { display:none; color:#B23B2E; font-size:.84rem; margin-top:6px; font-weight:700; }
.field--error .field__err { display:block; }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.hp { position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-success { display:none; background: var(--sage); color:#fff; border-radius: var(--radius-lg); padding: clamp(28px,4vw,44px); }
.form-success.is-on { display:block; }
.form-success h3 { font-family: var(--display); font-weight:600; font-size:1.7rem; margin-bottom:10px; }
.form-success p { color: rgba(255,255,255,.92); }
.form-success a { color:#fff; font-weight:800; text-decoration:underline; text-underline-offset:2px; }
.contact-aside .block { margin-bottom: 26px; }
.contact-aside h3 { font-family: var(--display); font-weight:600; font-size:1.25rem; color: var(--crust); margin-bottom:6px; }
.contact-aside a.big { font-weight:800; font-size: 1.15rem; color: var(--terra-600); }
.contact-aside a.big:hover { color: var(--crust); }
.contact-aside .muted { color: var(--muted); }

/* ---------- footer ---------- */
.footer { background: var(--crust); color: rgba(251,246,236,.78); padding-block: clamp(52px,6vw,80px) 28px; }
.footer__grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: clamp(26px,4vw,48px); }
.footer .dk-wordmark { color: var(--cream); }
.footer .dk-wordmark .top { color:#E9A77F; }
.footer__brand p { margin-top: 16px; font-size:.94rem; max-width: 32ch; color: rgba(251,246,236,.62); }
.footer__col h4 { font-family: var(--body); font-weight:800; letter-spacing:.1em; text-transform:uppercase; font-size:.76rem; color: var(--cream); margin-bottom:14px; }
.footer__col a { display:block; padding:6px 0; font-size:.96rem; color: rgba(251,246,236,.78); transition: color .15s; }
.footer__col a:hover { color:#E9A77F; }
.footer__contact a { color: var(--cream); font-weight:700; }
.footer__legal { margin-top: clamp(36px,5vw,60px); padding-top: 22px; border-top:1px solid rgba(251,246,236,.14); display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; font-size:.82rem; color: rgba(251,246,236,.5); }

/* ---------- reveal ---------- */
.reveal { opacity:0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none;} html{scroll-behavior:auto;} .hero__badge .dotpulse::after{display:none;} }

/* ---------- responsive ---------- */
@media (max-width: 940px){
  .hero__inner { grid-template-columns: 1fr; }
  .hero__media { aspect-ratio: 16/11; max-height: 420px; order: 2; }
  .split, .cater__inner, .visit-grid, .contact-split { grid-template-columns: 1fr; }
  .infostrip__grid { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .ig-tiles { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 760px){
  .nav-toggle { display:flex; }
  .nav {
    position: fixed; inset: 76px 0 auto 0; background: var(--cream);
    flex-direction: column; align-items: flex-start; gap: 2px; padding: 18px clamp(20px,5vw,52px) 28px;
    border-bottom: 1px solid var(--line); box-shadow: var(--shadow);
    transform: translateY(-135%); transition: transform .3s var(--ease); height:auto;
  }
  .nav--open { transform: translateY(0); }
  .nav__link { font-size: 1.15rem; padding: 13px 0; width:100%; }
  .nav__cta { margin: 12px 0 0; width:100%; justify-content:center; }
}
@media (max-width: 480px){
  .footer__grid { grid-template-columns: 1fr; }
  .form__row { grid-template-columns: 1fr; }
}
