:root {
  --bg: #f5efe8;
  --ink: #241912;
  --ink-soft: #5f4a3f;
  --surface: #fffaf5;
  --accent: #8b5e34;
  --accent-dark: #6b4422;
  --line: #e7d8c9;
  --radius: 14px;
  --max-w: 1120px;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "Nunito Sans", system-ui, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.55;
}
.shell { max-width: var(--max-w); margin: 0 auto; padding: 0 1rem; }
.offer-logo { display:flex; align-items:center; font-family:"Nunito Sans",sans-serif; font-size:1.1rem; font-weight:800; color:#20150f; text-decoration:none; margin-right:.5rem; }
.offer-banner {
  position: sticky; top: 0; z-index: 1000; background: #d4a030; color: #20150f;
  display: flex; align-items: center; justify-content: center; gap: .75rem; padding: .6rem .9rem; font-weight: 700; font-size: .9rem;
}
.offer-banner.hidden { display:none; }
.offer-cta { background:#20150f; color:#f3d49b; text-decoration:none; padding:.3rem .7rem; border-radius:6px; font-size:.8rem; }
.offer-close { margin-left:auto; background:none; border:none; font-size:1.2rem; cursor:pointer; color:#20150f99; }
.site-header {
  position: sticky; top: 0; z-index: 900; backdrop-filter: blur(8px);
  background: color-mix(in srgb, var(--bg) 88%, white 12%); border-bottom: 1px solid var(--line);
}
.header-inner { min-height: 70px; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.brand { display:flex; align-items:center; gap:.5rem; font-family:"Nunito Sans",sans-serif; font-size:1.35rem; font-weight:800; color:var(--ink); text-decoration:none; }
.site-header nav { display:flex; gap:1rem; }
.site-header nav a { color:var(--ink-soft); text-decoration:none; font-weight:700; }
.btn { border-radius: 10px; padding: .68rem 1rem; text-decoration: none; font-weight: 800; display:inline-flex; align-items:center; justify-content:center; }
.btn-solid { background: var(--accent); color: #fff; border: 1px solid var(--accent); }
.btn-solid:hover { background: var(--accent-dark); color:#fff; }
.btn-outline { background: transparent; color: var(--accent-dark); border: 1px solid var(--accent); }
.btn-outline:hover { background: #f0e0cf; }
.nav-call-btn { white-space: nowrap; }
.hero { position:relative; min-height: 72vh; display:flex; align-items:center; }
.hero-bg, .hero-bg img, .hero-overlay { position:absolute; inset:0; width:100%; height:100%; }
.hero-bg img { object-fit: cover; }
.hero-overlay { background: linear-gradient(90deg, rgba(25,16,11,.8), rgba(45,31,22,.45) 45%, rgba(45,31,22,.2) 75%); }
.hero-content { position:relative; z-index:2; color:#fff4e7; max-width: 700px; padding: 4rem 1rem; }
.eyebrow { text-transform:uppercase; letter-spacing:.12em; font-weight:700; color:#f0ce97; margin-bottom:.8rem; }
.hero h1 { font-family: "Bree Serif", serif; font-size: clamp(2rem, 5vw, 3.5rem); line-height:1.12; margin:0 0 .7rem; }
.hero p { font-size: 1.12rem; margin: 0 0 1.25rem; color:#f8e9d3; }
.hero-actions { display:flex; gap:.7rem; flex-wrap:wrap; }
.section { padding: 4rem 0; }
.section-head h2, #about h2, #visit h2 { font-family:"Bree Serif", serif; font-size:clamp(1.8rem,3.5vw,2.6rem); margin:.2rem 0 .4rem; }
.section-head p { color: var(--ink-soft); margin:0 0 1.2rem; }
.cards-grid { display:grid; gap:1rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.card { border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; background: var(--surface); box-shadow: 0 4px 14px rgba(55,34,20,.06); }
.card-img { height: 180px; }
.card-img img { width:100%; height:100%; object-fit:cover; }
.card-body { padding: 1rem; }
.tag { display:inline-block; padding:.2rem .5rem; border-radius:999px; background:#f2e4d4; color:#6d471f; font-size:.72rem; font-weight:800; margin-bottom:.4rem; }
.card h3 { margin:.15rem 0 .4rem; font-size:1.15rem; }
.card p { margin:0; color: var(--ink-soft); }
.section-dark { background: #2f2119; color: #f6e9dc; }
.about-grid { display:grid; grid-template-columns: 1.2fr .9fr; gap:1.3rem; align-items:center; }
.section-dark p { color:#edd9c4; }
.about-list { padding-left:1rem; }
.about-list li { margin:.45rem 0; }
.about-photo-wrap { border-radius: var(--radius); overflow:hidden; border:1px solid #4c372a; }
.about-photo { width:100%; height:100%; object-fit:cover; display:block; }
.visit-sub { color: var(--ink-soft); }
.visit-grid { display:grid; grid-template-columns: 1fr 1fr; gap:1rem; align-items:start; }
.hours { border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; margin:1rem 0; background:#fff; }
.hours div { display:flex; justify-content:space-between; gap:1rem; padding:.75rem .9rem; border-bottom:1px solid var(--line); }
.hours div:last-child { border-bottom:none; }
.contact-row { display:flex; gap:.6rem; flex-wrap:wrap; }
.map-wrap iframe { width:100%; height:360px; border:0; border-radius: var(--radius); box-shadow: 0 5px 20px rgba(52,34,19,.12); }
footer { background:#1f160f; color:#e8d8c4; text-align:center; padding:2rem 0; }
footer p { margin:0 0 .3rem; }
footer small { color:#bda58d; }
@media (max-width: 900px) {
  .about-grid, .visit-grid { grid-template-columns: 1fr; }
}
@media (max-width: 700px) {
  .site-header nav { display:none; }
  .header-inner { min-height: 62px; }
  .hero { min-height: 62vh; }
}