:root{
  --navy:#2b4a6f; --navy-d:#1f3a59; --orange:#d98324; --orange-d:#b96d18;
  --cream:#f6efe3; --paper:#fffaf2; --ink:#3a2f28; --muted:#7c6e60; --line:#e7dcc9; --rose:#d98aa0;
  --maxw:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;line-height:1.7}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;color:var(--navy);line-height:1.16;margin:0 0 .4em;font-weight:600}
.script{font-family:'Pacifico',cursive;font-weight:400}
a{color:var(--orange-d)}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.btn{display:inline-block;background:var(--orange);color:#fff;text-decoration:none;font-weight:700;padding:13px 26px;border-radius:30px;transition:background .15s,transform .12s}
.btn:hover{background:var(--orange-d);color:#fff;transform:translateY(-1px)}
.btn-navy{background:var(--navy)} .btn-navy:hover{background:var(--navy-d)}
.btn-ghost{background:transparent;border:2px solid #fff;color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}

/* topbar */
.topbar{background:var(--navy);color:#dbe6f3;font-size:.85rem;text-align:center;padding:8px 14px}
.topbar strong{color:#fff} .topbar a{color:#ffd9a8;font-weight:700;text-decoration:none}
.open-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#6cc77d;margin-right:5px;vertical-align:middle}
.open-dot.closed{background:#e09a9a}

/* header */
header.site{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
header.site .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 22px}
header.site .logo{height:60px;width:auto}
header.site nav{display:flex;align-items:center;gap:22px}
header.site nav a{color:var(--navy);text-decoration:none;font-weight:600;font-size:.95rem}
header.site nav a:hover{color:var(--orange-d)}
header.site nav a.btn{color:#fff}
header.site nav a.btn:hover{color:#fff}
@media(max-width:720px){header.site nav a:not(.btn){display:none}}

/* hero */
.hero{position:relative;color:#fff;text-align:center;
  background:linear-gradient(rgba(25,30,45,.5),rgba(25,30,45,.7)),url('assets/img/storefront.jpg') center/cover;
  padding:96px 0}
.hero .eyebrow{font-family:'Pacifico',cursive;font-size:1.5rem;color:#ffd9a8;margin-bottom:10px}
.hero h1{color:#fff;font-size:clamp(2.2rem,5.5vw,3.6rem);margin-bottom:.3em}
.hero p{font-size:1.18rem;color:#f3ead9;max-width:600px;margin:0 auto 1.6em}
.hero .btn{margin:6px}
.badge-open{display:inline-block;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);color:#fff;border-radius:30px;padding:7px 18px;font-size:.92rem;margin-bottom:18px}

/* feature strip */
.features{background:var(--orange);color:#fff}
.features .container{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 36px;padding:16px 22px;text-align:center;font-weight:700}
.features .item{font-size:.98rem}

section{padding:70px 0}
.section-alt{background:var(--paper)}
.section-head{max-width:660px;margin:0 auto 44px;text-align:center}
.eyebrow{font-family:'Pacifico',cursive;color:var(--orange-d);font-size:1.25rem;margin-bottom:4px}
.section-head h2{font-size:2.3rem}
.section-head p{color:var(--muted)}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.split img{border-radius:14px;box-shadow:0 16px 38px rgba(58,47,40,.18)}
.split h2{font-size:2.1rem}
.split .muted{color:var(--muted)}

/* menu cards */
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.m-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .15s,box-shadow .15s}
.m-card:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(58,47,40,.14)}
.m-card .ph{height:180px;background-size:cover;background-position:center}
.m-card .body{padding:22px}
.m-card h3{font-size:1.35rem;margin-bottom:.2em}
.m-card .body p{margin:0;color:var(--muted);font-size:.96rem}
.m-card .tag{display:inline-block;background:var(--rose);color:#fff;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;padding:3px 11px;border-radius:20px;margin-bottom:8px;font-weight:700}

/* community / cat strip */
.cat{background:var(--navy);color:#eaf0f8}
.cat h2{color:#fff} .cat .eyebrow{color:#ffd9a8}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.cat-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:24px;text-align:center}
.cat-card .ic{font-size:1.9rem;margin-bottom:8px}
.cat-card h3{color:#fff;font-size:1.2rem}
.cat-card p{color:#c8d4e4;margin:0;font-size:.95rem}

/* reviews */
.reviews{text-align:center}
.reviews .stars{color:var(--orange);font-size:1.7rem;letter-spacing:3px}
.reviews h2{font-size:2.5rem;margin:.1em 0}
.reviews p{color:var(--muted);max-width:520px;margin:6px auto 0}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:8px}
.gallery img{width:100%;height:180px;object-fit:cover;border-radius:12px}

/* visit */
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.visit-grid iframe{width:100%;height:340px;border:0;border-radius:14px;box-shadow:0 12px 30px rgba(58,47,40,.16)}
.info-row{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}
.info-row .ic{font-size:1.2rem}
.info-row a{color:var(--navy);font-weight:600;text-decoration:none}
.info-row a:hover{color:var(--orange-d)}
.hours{list-style:none;padding:0;margin:14px 0 0}
.hours li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dotted var(--line);font-size:.97rem}
.hours li.today{font-weight:700;color:var(--navy)}
.hours li .d{color:var(--muted)} .hours li.today .d{color:var(--navy)}
.cta-row{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap}

/* footer */
footer.site-foot{background:var(--navy-d);color:#cdd9ea;text-align:center;padding:46px 22px}
footer.site-foot .logo{height:84px;margin:0 auto 16px;background:var(--cream);padding:12px 18px;border-radius:16px}
footer.site-foot a{color:#ffd9a8;text-decoration:none;font-weight:600}
footer.site-foot .socials{margin:10px 0}
footer.site-foot .socials a{margin:0 10px}
footer.site-foot .fine{font-size:.82rem;color:#9fb0c8;margin-top:12px}

@media(max-width:780px){.split,.visit-grid{grid-template-columns:1fr;gap:28px}.menu-grid,.cat-grid{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}section{padding:52px 0}}

/* Summer menu section */
.summer-wrap{display:grid;grid-template-columns:0.9fr 1.1fr;gap:40px;align-items:center}
.summer-img img{border-radius:16px;box-shadow:0 16px 40px rgba(58,47,40,.2);max-width:420px;margin:0 auto;width:100%}
.summer-list{list-style:none;margin:0;padding:0}
.summer-list li{padding:13px 0;border-bottom:1px dashed var(--line)}
.summer-list li:last-child{border-bottom:0}
.summer-list b{display:block;font-family:'Fraunces',Georgia,serif;color:var(--navy);font-size:1.18rem}
.summer-list span{color:var(--muted);font-size:.95rem}
@media(max-width:780px){.summer-wrap{grid-template-columns:1fr;gap:26px}}

/* Full menu image */
.full-menu{max-width:760px;margin:50px auto 0;text-align:center}
.full-menu-title{font-size:1.9rem;margin-bottom:18px}
.full-menu img{width:100%;border-radius:14px;box-shadow:0 16px 40px rgba(58,47,40,.2);cursor:zoom-in;border:1px solid var(--line)}
.full-menu-note{color:var(--muted);font-size:.92rem;margin-top:14px}
