:root{
  --cream:#f3ece0;
  --paper:#f9f5ee;
  --ink:#2b2b2a;
  --wine:#a51c23;
  --olive:#395b41;
  --accent:#d9b26f;
  --border:#e2dacd;
  --maxw:1100px;
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Georgia,'Times New Roman',serif;background:var(--paper);color:var(--ink)}
img{max-width:100%;display:block}
.container{width:min(92%,var(--maxw));margin-inline:auto}
.section-pad{padding:56px 0}

/* Header */
.site-header{position:sticky;top:0;background:rgba(249,245,238,.9);backdrop-filter:saturate(1.2) blur(6px);border-bottom:1px solid var(--border);z-index:50}
.nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand,.brand-foot{font-weight:800;letter-spacing:.5px;color:var(--ink);text-decoration:none}
.brand span,.brand-foot span{color:var(--wine)}
.menu{display:flex;gap:18px;align-items:center}
.menu a{text-decoration:none;color:#5b5b59}
.menu a.active,.menu a:hover{color:var(--wine)}
.burger{display:none;background:none;border:1px solid var(--border);padding:6px 10px;border-radius:10px;color:var(--ink)}

/* Hero */
.hero{position:relative;min-height:56vh;display:grid;place-items:center;border-bottom:1px solid var(--border)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1) saturate(.9) blur(.3px)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom, rgba(243,236,224,.6), rgba(243,236,224,.95))}
.hero-content{position:relative;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);margin:0 0 8px}
.hero .sub{margin:0 0 16px;color:#5b5b59}
.btn{display:inline-block;text-decoration:none;border:1px solid var(--wine);color:var(--wine);padding:10px 16px;border-radius:999px}
.btn-primary{background:var(--wine);color:#fff}

/* Cards / Sections */
h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:0 0 18px;border-bottom:2px solid var(--olive);display:inline-block;padding-bottom:6px}
.card{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid.two{grid-template-columns:repeat(2,1fr)}
.list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.list li{display:flex;justify-content:space-between;border-bottom:1px dotted #cfc6b8;padding-bottom:6px}
.note{color:#6c6b67}

/* Hours */
.hours ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.hours li{display:flex;justify-content:space-between;background:var(--cream);border:1px solid var(--border);border-radius:10px;padding:10px 12px}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.rev{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.rev header{margin-bottom:6px;color:#444}
.rev header strong{color:var(--ink)}
.rev header span{color:#7a7a75}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}
.form{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.form-group{display:grid;gap:6px;margin-bottom:12px}
input,textarea{border:1px solid #cfc6b8;border-radius:10px;padding:10px 12px;background:#fff;color:var(--ink);font-family:inherit}
textarea{resize:vertical}
.info{display:grid;gap:10px}
.map iframe{width:100%;height:260px;border:0;border-radius:12px}

/* Footer */
.site-footer{border-top:1px solid var(--border);margin-top:36px;background:var(--cream)}
.footer-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0;flex-wrap:wrap}
.footer-nav{display:flex;gap:12px}
.footer-nav a{text-decoration:none;color:#5b5b59}
.copy{color:#6c6b67}

/* Responsive */
@media (max-width:920px){
  .grid{grid-template-columns:1fr}
  .grid.two{grid-template-columns:1fr}
  .reviews{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .burger{display:block}
  .menu{position:absolute;top:60px;right:4%;background:var(--cream);border:1px solid var(--border);border-radius:12px;display:none;flex-direction:column;overflow:hidden}
  .menu a{padding:10px 14px;border-bottom:1px solid var(--border)}
  .menu.show{display:flex}
}
