/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:'Source Sans 3',system-ui,sans-serif;color:#222;background:#fff;line-height:1.6}
img{max-width:100%;display:block}
a{color:#b5451b;text-decoration:none}
a:hover{text-decoration:underline}

/* ===== Layout ===== */
.wrap{max-width:1080px;margin:0 auto;padding:0 1.25rem}

/* ===== Header ===== */
.site-header{background:#1a1a1a;padding:.75rem 0}
.nav-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}
.brand img{height:56px;width:auto}
.site-nav{display:flex;gap:1.25rem;flex-wrap:wrap}
.site-nav a{color:#eee;font-weight:600;font-size:.95rem;padding:.25rem 0;border-bottom:2px solid transparent;transition:border-color .2s}
.site-nav a:hover,.site-nav a.active{border-color:#e8a838;text-decoration:none}

/* ===== Hero ===== */
.hero{padding:3rem 0 2.5rem;background:#faf7f2}
.hero-grid{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
.eyebrow{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#888;margin-bottom:.5rem}
.hero-copy h1{font-family:'Bree Serif',serif;font-size:2rem;line-height:1.25;margin-bottom:1rem;color:#1a1a1a}
.lede{font-size:1.1rem;color:#444;margin-bottom:1.5rem;max-width:540px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}

/* Buttons */
.button{display:inline-block;padding:.65rem 1.4rem;border-radius:4px;font-weight:700;font-size:.95rem;text-align:center;transition:background .2s,color .2s}
.button:hover{text-decoration:none}
.button:not(.button-secondary):not(.button-phone){background:#b5451b;color:#fff}
.button:not(.button-secondary):not(.button-phone):hover{background:#943a17}
.button-secondary{background:#1a1a1a;color:#fff}
.button-secondary:hover{background:#333}
.button-phone{background:#fff;color:#b5451b;border:2px solid #b5451b}
.button-phone:hover{background:#fdf0ea}

/* Info card */
.info-card{background:#fff;border:1px solid #ddd;border-radius:6px;padding:1.5rem;box-shadow:0 2px 6px rgba(0,0,0,.06)}
.info-card h2{font-family:'Bree Serif',serif;font-size:1.25rem;margin-bottom:1rem;color:#1a1a1a}
.info-card dl div{margin-bottom:1rem}
.info-card dt{font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:#888}
.info-card dd{margin:0;font-size:.95rem}
.info-card a{color:#b5451b}

/* ===== Highlight Band ===== */
.highlight-band{background:#1a1a1a;color:#fff;padding:2.5rem 0}
.highlight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.highlight-grid h2{font-family:'Bree Serif',serif;font-size:1.15rem;margin-bottom:.5rem;color:#e8a838}
.highlight-grid p{font-size:.95rem;color:#ccc;line-height:1.5}

/* ===== Quick Links ===== */
.quick-links{padding:3rem 0}
.section-heading{text-align:center;margin-bottom:2rem}
.section-heading h2{font-family:'Bree Serif',serif;font-size:1.5rem}
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.link-card{background:#faf7f2;border-radius:6px;padding:1.5rem;border:1px solid #eee}
.link-card h3{font-family:'Bree Serif',serif;font-size:1.1rem;margin-bottom:.5rem}
.link-card p{font-size:.9rem;color:#555;margin-bottom:.75rem}
.link-card a{font-weight:600;font-size:.9rem}
.accent-card{background:#b5451b;color:#fff;border-color:#b5451b}
.accent-card h3,.accent-card p,.accent-card a{color:#fff}
.accent-card a:hover{color:#fde8d8}

/* ===== Footer ===== */
.site-footer{background:#1a1a1a;color:#aaa;padding:1.5rem 0;font-size:.85rem;text-align:center}
.site-footer a{color:#e8a838}
.social-links{margin-top:.35rem}
.social-links a{color:#e8a838;font-weight:600}

/* ===== Menu Pages ===== */
.page-title-bar{background:#faf7f2;padding:2rem 0 1.5rem;border-bottom:1px solid #eee}
.page-title-bar h1{font-family:'Bree Serif',serif;font-size:1.75rem;color:#1a1a1a}
.page-title-bar .subtitle{color:#666;font-size:1rem;margin-top:.25rem}

.menu-content{padding:2rem 0 3rem}
.menu-section{margin-bottom:2.5rem}
.menu-section h2{font-family:'Bree Serif',serif;font-size:1.35rem;color:#b5451b;border-bottom:2px solid #e8a838;padding-bottom:.35rem;margin-bottom:1rem}
.menu-section h3{font-family:'Bree Serif',serif;font-size:1.1rem;color:#1a1a1a;margin:1.25rem 0 .5rem}
.menu-note{font-size:.9rem;color:#666;font-style:italic;margin-bottom:1rem}

.menu-item{display:flex;justify-content:space-between;align-items:baseline;padding:.35rem 0;border-bottom:1px dotted #ddd;gap:1rem}
.menu-item:last-child{border-bottom:none}
.item-name{font-weight:600;font-size:.95rem}
.item-price{font-weight:700;color:#b5451b;white-space:nowrap;font-size:.95rem}
.item-desc{font-size:.85rem;color:#666;padding-left:0;margin-bottom:.25rem}

.menu-sidebar{position:sticky;top:1rem}
.menu-sidebar h2{font-family:'Bree Serif',serif;font-size:1.1rem;margin-bottom:.75rem}
.menu-sidebar ul{list-style:none;padding:0}
.menu-sidebar li{margin-bottom:.4rem}
.menu-sidebar a{font-size:.9rem;color:#555}
.menu-sidebar a:hover{color:#b5451b}

.menu-layout{display:grid;grid-template-columns:1fr 220px;gap:2.5rem;align-items:start}

/* ===== Responsive ===== */
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr}
  .highlight-grid{grid-template-columns:1fr}
  .cards-grid{grid-template-columns:1fr}
  .menu-layout{grid-template-columns:1fr}
  .menu-sidebar{position:static;order:-1;border-bottom:1px solid #eee;padding-bottom:1rem;margin-bottom:1rem}
  .hero-copy h1{font-size:1.5rem}
  .nav-row{justify-content:center;text-align:center}
  .brand img{height:44px}
}
