@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700;800&family=Playfair+Display:ital,wght@0,500;0,700;1,500;1,700&display=swap');

:root{
  --red:#dc2626;
  --red-dark:#b91c1c;
  --red-deep:#7a1414;
  --ink:#141414;
  --charcoal:#1a1a1a;
  --cream:#faf6ee;
  --cream-2:#f3ecdc;
  --paper:#ffffff;
  --mustard:#e8a82c;
  --muted:#6b6b6b;
  --border:#e8e0cf;
  --border-strong:#3a3027;
  --radius:14px;
  --radius-lg:22px;
  --shadow-sm:0 1px 2px rgba(20,20,20,.05);
  --shadow:0 12px 30px -12px rgba(20,20,20,.18);
  --shadow-lg:0 30px 60px -20px rgba(20,20,20,.35);
  --container:1240px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Outfit', system-ui, -apple-system, sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}

/* ---------- Type ---------- */
.display{
  font-family:'Bebas Neue', Impact, sans-serif;
  letter-spacing:.01em;
  line-height:.92;
  text-transform:uppercase;
}
.eyebrow{
  font-size:.78rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.22em;
  color:var(--red);
  display:inline-flex;
  align-items:center;
  gap:.6rem;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:32px;
  height:1px;
  background:var(--red);
}
.serif-italic{font-family:'Playfair Display', serif;font-style:italic;font-weight:500}
h1,h2,h3,h4{margin:0 0 .4em;color:var(--ink)}
p{margin:0 0 1em}

/* ---------- Top Announcement Bar ---------- */
.topbar{
  background:var(--ink);
  color:#f7eccf;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:.55rem 0;
  font-weight:500;
}
.topbar .row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:2rem;
  flex-wrap:wrap;
}
.topbar .leaf{color:#ff5151}
.topbar .dot{opacity:.4}
.topbar .since{color:var(--mustard)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(250,246,238,.92);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:78px;
}
.logo{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  line-height:0;
}
.logo img{
  height:46px;
  width:auto;
  display:block;
  transition:transform .25s ease;
}
.logo:hover img{transform:scale(1.03)}
@media (max-width:560px){
  .logo img{height:38px}
}
/* Footer logo: dark backgrounds get the white silhouette variant so the
   "diner" wordmark stays readable. */
.footer-brand .logo img{
  content:url('../img/logo-white.png');
  height:64px;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:2.2rem;
  list-style:none;
  margin:0;padding:0;
}
.nav-links a{
  font-size:.92rem;
  font-weight:500;
  color:var(--ink);
  position:relative;
  padding:.4rem 0;
  transition:color .2s ease;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-2px;
  height:2px;
  background:var(--red);
  transform:scaleX(0);
  transform-origin:right;
  transition:transform .25s ease;
}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after,.nav-links a.active::after{
  transform:scaleX(1);
  transform-origin:left;
}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:10px;
  align-items:center;justify-content:center;
}
.nav-toggle span{
  width:22px;height:2px;background:var(--ink);
  position:relative;display:block;
  transition:transform .25s ease, opacity .2s ease;
}
.nav-toggle span::before,.nav-toggle span::after{
  content:"";position:absolute;left:0;
  width:22px;height:2px;background:var(--ink);
  transition:transform .25s ease;
}
.nav-toggle span::before{top:-7px}
.nav-toggle span::after{top:7px}
.nav-open .nav-toggle span{background:transparent}
.nav-open .nav-toggle span::before{transform:rotate(45deg) translate(5px,5px)}
.nav-open .nav-toggle span::after{transform:rotate(-45deg) translate(5px,-5px)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  padding:.95rem 1.6rem;
  font-weight:600;
  font-size:.92rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  border-radius:999px;
  transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn-primary{
  background:var(--red);
  color:#fff;
  box-shadow:0 6px 18px -6px rgba(220,38,38,.55);
}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-1px)}
.btn-outline{
  border:1.5px solid var(--ink);
  color:var(--ink);
}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-ghost{
  color:var(--ink);font-weight:500;
}
.btn-ghost:hover{color:var(--red)}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:min(86vh,820px);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:#1a1208;
  isolation:isolate;
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.15) 30%, rgba(0,0,0,.55) 75%, rgba(0,0,0,.85) 100%);
  z-index:1;
}
.hero-media{
  position:absolute;inset:0;
  z-index:0;
}
.hero-media img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 40%;
}
.hero-content{
  position:relative;
  z-index:2;
  width:100%;
  padding:120px 0 80px;
  color:#fff;
}
.hero-eyebrow{
  color:#f7d49a;
  font-size:.82rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.32em;
  margin-bottom:1.2rem;
  display:flex;align-items:center;gap:.8rem;
}
.hero-eyebrow::before{
  content:"";display:inline-block;width:48px;height:1px;background:#f7d49a;
}
.hero h1{
  font-family:'Bebas Neue', sans-serif;
  font-size:clamp(3.6rem, 9vw, 8.5rem);
  line-height:.9;
  letter-spacing:.005em;
  color:#fff;
  margin:0 0 1.2rem;
  text-transform:uppercase;
}
.hero h1 .accent{
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-weight:500;
  text-transform:none;
  color:#ffd383;
  letter-spacing:-.01em;
  display:inline-block;
}
.hero p.lead{
  max-width:540px;
  font-size:clamp(1rem, 1.2vw, 1.18rem);
  color:rgba(255,255,255,.85);
  line-height:1.55;
  margin:0 0 2rem;
}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero-meta{
  display:flex;align-items:center;gap:1.4rem;
  margin-top:3rem;
  flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.18);
  padding-top:1.5rem;
}
.hero-meta-item{
  display:flex;align-items:center;gap:.7rem;
  color:rgba(255,255,255,.85);
  font-size:.88rem;
}
.hero-meta-item .num{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:#ffd383;
  letter-spacing:.02em;
  line-height:1;
}
.hero-badge{
  position:absolute;
  top:130px;right:5vw;
  z-index:3;
  width:160px;height:160px;
  border-radius:50%;
  background:var(--red);
  color:#fff;
  display:grid;place-items:center;
  text-align:center;
  font-family:'Bebas Neue',sans-serif;
  letter-spacing:.04em;
  line-height:1;
  transform:rotate(-8deg);
  box-shadow:0 20px 40px -10px rgba(0,0,0,.4), inset 0 0 0 6px rgba(255,255,255,.12);
  animation:wobble 6s ease-in-out infinite;
}
.hero-badge .since{
  font-size:.85rem;letter-spacing:.18em;opacity:.85;display:block;margin-bottom:.2rem;
}
.hero-badge .year{
  font-size:2.6rem;display:block;
}
.hero-badge .canadian{
  font-size:.7rem;letter-spacing:.18em;display:block;margin-top:.25rem;opacity:.85;
}
@keyframes wobble{
  0%,100%{transform:rotate(-8deg)}
  50%{transform:rotate(-2deg)}
}

/* ---------- Marquee ticker ---------- */
.marquee{
  background:var(--red);
  color:#fff;
  border-block:1px solid rgba(0,0,0,.15);
  padding:1.1rem 0;
  overflow:hidden;
  position:relative;
}
.marquee-track{
  display:flex;
  gap:3rem;
  white-space:nowrap;
  animation:scroll 40s linear infinite;
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem;
  letter-spacing:.08em;
}
.marquee-track span{display:inline-flex;align-items:center;gap:3rem}
.marquee-track .star{color:#ffd383;font-size:1.2rem}
@keyframes scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ---------- Sections ---------- */
section{padding:96px 0}
@media (max-width:768px){section{padding:64px 0}}
.section-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 56px;
}
.section-head .eyebrow{justify-content:center}
.section-head .eyebrow::after{
  content:"";display:inline-block;width:32px;height:1px;background:var(--red);
}
.section-head h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.4rem, 5vw, 4.6rem);
  letter-spacing:.01em;
  line-height:.95;
  text-transform:uppercase;
  margin:1rem 0 1rem;
}
.section-head h2 .it{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:500;
  text-transform:none;
  color:var(--red);
}
.section-head p{
  color:var(--muted);
  font-size:1.08rem;
  max-width:600px;
  margin:0 auto;
}

/* ---------- Featured dishes grid ---------- */
.dish-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:24px;
}
.dish{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:#fff;
  cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  isolation:isolate;
  box-shadow:var(--shadow-sm);
}
.dish:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
}
.dish-img{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
}
.dish-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.dish:hover .dish-img img{transform:scale(1.06)}
.dish-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.7));
}
.dish-body{
  position:absolute;
  inset:auto 0 0 0;
  padding:24px;
  color:#fff;
  z-index:2;
}
.dish-cat{
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#ffd383;
  margin-bottom:.4rem;
  display:block;
}
.dish-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem;
  letter-spacing:.02em;
  line-height:1;
  margin:0 0 .35rem;
  text-transform:uppercase;
}
.dish-desc{
  font-size:.86rem;
  color:rgba(255,255,255,.82);
  margin:0;
  line-height:1.4;
  max-height:0;overflow:hidden;
  transition:max-height .35s ease, margin .35s ease;
}
.dish:hover .dish-desc{max-height:60px;margin-top:.2rem}

.dish.feat-lg{grid-column:span 6;grid-row:span 2}
.dish.feat-lg .dish-img{aspect-ratio:4/5.4}
.dish.feat-lg .dish-title{font-size:2.4rem}
.dish.feat-md{grid-column:span 6}
.dish.feat-md .dish-img{aspect-ratio:8/5}
.dish.feat-sm{grid-column:span 4}
.dish.feat-sm .dish-img{aspect-ratio:1/1.1}
.dish.feat-half{grid-column:span 6}
.dish.feat-half .dish-img{aspect-ratio:8/5}

@media (max-width:900px){
  .dish-grid{grid-template-columns:repeat(6, 1fr)}
  .dish.feat-lg, .dish.feat-md, .dish.feat-sm, .dish.feat-half{grid-column:span 6;grid-row:auto}
  .dish.feat-lg .dish-img,.dish.feat-md .dish-img,.dish.feat-sm .dish-img,.dish.feat-half .dish-img{aspect-ratio:8/5}
}

/* ---------- Editorial split ---------- */
.split{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
}
.split.reverse{grid-template-columns:1fr 1.1fr}
.split.reverse .split-media{order:2}
.split.reverse .split-text{order:1}
.split-media{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:5/6;
}
.split-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s ease;
}
.split-media:hover img{transform:scale(1.03)}
.split-media .sticker{
  position:absolute;
  bottom:24px;left:24px;
  background:var(--mustard);
  color:var(--ink);
  padding:.7rem 1.1rem;
  border-radius:999px;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.split-text h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.4rem, 5vw, 4.6rem);
  letter-spacing:.01em;
  line-height:.95;
  text-transform:uppercase;
  margin:1rem 0 1.4rem;
}
.split-text h2 .it{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-weight:500;
  text-transform:none;
  color:var(--red);
}
.split-text p{font-size:1.08rem;color:#3b3a37;line-height:1.65}
.split-text .signature{
  margin-top:1.6rem;
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:1.2rem;
  color:var(--red);
}
@media (max-width:900px){
  .split{grid-template-columns:1fr;gap:32px}
  .split.reverse{grid-template-columns:1fr}
  .split.reverse .split-media{order:0}
  .split.reverse .split-text{order:0}
}

/* ---------- Categories pills ---------- */
.cats{
  background:var(--ink);
  color:#f7eccf;
}
.cats .section-head h2{color:#fff}
.cats .section-head p{color:rgba(255,255,255,.7)}
.cats .section-head .eyebrow{color:#ffd383}
.cats .section-head .eyebrow::before,.cats .section-head .eyebrow::after{background:#ffd383}
.cat-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
@media(max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
.cat{
  background:#221a10;
  border:1px solid #3a2c1c;
  border-radius:var(--radius);
  padding:28px 26px;
  display:flex;
  flex-direction:column;
  gap:1.4rem;
  min-height:200px;
  transition:border-color .25s ease, transform .25s ease, background .25s ease;
  text-decoration:none;
  color:#f7eccf;
}
.cat:hover{
  border-color:var(--red);
  background:#2c1f12;
  transform:translateY(-3px);
}
.cat-num{
  font-family:'Bebas Neue',sans-serif;
  font-size:.95rem;color:#ffd383;letter-spacing:.2em;
}
.cat-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:2rem;line-height:1;letter-spacing:.02em;
  margin-top:auto;
}
.cat-arrow{
  align-self:flex-end;
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.08);
  display:grid;place-items:center;color:#fff;
  transition:background .2s ease,transform .25s ease;
}
.cat:hover .cat-arrow{background:var(--red);transform:rotate(-45deg)}

/* ---------- Locations preview ---------- */
.loc-wrap{
  background:var(--cream-2);
  border-radius:var(--radius-lg);
  padding:48px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
@media(max-width:900px){.loc-wrap{grid-template-columns:1fr;padding:28px;gap:24px}}
.loc-text h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.2rem, 4.4vw, 3.8rem);
  text-transform:uppercase;
  line-height:.95;letter-spacing:.01em;margin:.8rem 0 1.2rem;
}
.loc-text h2 .it{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:500;
  text-transform:none;color:var(--red);
}
.loc-text p{color:var(--muted);max-width:440px;font-size:1.05rem}
.loc-search{
  margin-top:1.6rem;
  display:flex;align-items:stretch;
  background:#fff;border:1px solid var(--border);
  border-radius:999px;padding:6px 6px 6px 22px;
  max-width:440px;
}
.loc-search input{
  flex:1;border:none;outline:none;background:transparent;
  font-family:inherit;font-size:.95rem;color:var(--ink);
}
.loc-search input::placeholder{color:#a59c87}
.loc-search button{
  background:var(--ink);color:#fff;
  border-radius:999px;padding:.7rem 1.4rem;
  font-weight:600;font-size:.85rem;letter-spacing:.05em;
  text-transform:uppercase;
}
.loc-search button:hover{background:var(--red)}
.loc-list{
  display:grid;grid-template-columns:1fr 1fr;gap:18px 30px;
}
@media(max-width:560px){.loc-list{grid-template-columns:1fr}}
.loc-item{
  border-top:1px solid var(--border);padding-top:14px;
}
.loc-item .city{
  font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;line-height:1;
}
.loc-item .addr{font-size:.85rem;color:var(--muted);margin-top:.25rem}
.loc-item .phone{font-size:.85rem;color:var(--ink);margin-top:.15rem;font-weight:500}

/* ---------- CTA strip ---------- */
.cta-strip{
  background:var(--red);color:#fff;
  padding:80px 0;
  position:relative;overflow:hidden;
  text-align:center;
}
.cta-strip::before,.cta-strip::after{
  content:"";position:absolute;
  width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,#ff5151 0%,transparent 70%);
  opacity:.6;pointer-events:none;
}
.cta-strip::before{top:-120px;left:-120px}
.cta-strip::after{bottom:-160px;right:-100px}
.cta-strip h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.6rem, 6vw, 5.5rem);
  letter-spacing:.02em;
  text-transform:uppercase;
  line-height:.92;
  margin:0 0 .6rem;
  color:#fff;
  position:relative;z-index:1;
}
.cta-strip h2 .it{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:500;
  text-transform:none;color:#ffd383;
}
.cta-strip p{
  position:relative;z-index:1;
  color:rgba(255,255,255,.9);
  max-width:560px;margin:0 auto 2rem;
  font-size:1.05rem;
}
.cta-strip .btn{position:relative;z-index:1}
.cta-strip .btn-primary{background:var(--ink);box-shadow:0 6px 18px -6px rgba(0,0,0,.45)}
.cta-strip .btn-primary:hover{background:#000}
.cta-strip .btn-outline{border-color:#fff;color:#fff}
.cta-strip .btn-outline:hover{background:#fff;color:var(--ink)}

/* ---------- Why us / value props ---------- */
.values{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
@media(max-width:900px){.values{grid-template-columns:repeat(2,1fr)}}
.value{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:32px 28px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.value:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.value-icon{
  width:56px;height:56px;border-radius:14px;
  background:var(--cream-2);display:grid;place-items:center;
  font-size:1.6rem;margin-bottom:1.1rem;
  color:var(--red);
}
.value h3{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem;letter-spacing:.03em;line-height:1;
  margin:0 0 .6rem;text-transform:uppercase;
}
.value p{font-size:.94rem;color:var(--muted);margin:0;line-height:1.55}

/* ---------- Footer (sized ~20% larger for presence) ---------- */
.site-footer{
  background:#0c0c0c;
  color:#a8a89f;
  padding:104px 0 40px;
  font-size:1.04rem;
  line-height:1.7;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:60px;
  padding-bottom:60px;
  border-bottom:1px solid #1f1f1f;
}
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr;gap:36px}
}
.footer-brand p{margin-top:1.4rem;max-width:380px;line-height:1.7;font-size:1.02rem;color:#bcbcb2}
.footer-col h4{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.45rem;letter-spacing:.2em;color:#fff;
  text-transform:uppercase;margin:0 0 1.45rem;
}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.95rem}
.footer-col a{transition:color .2s ease}
.footer-col a:hover{color:#fff}
.footer-newsletter input{
  width:100%;background:transparent;border:none;border-bottom:1px solid #2a2a2a;
  color:#fff;padding:1rem 0;outline:none;font-family:inherit;font-size:1.04rem;
  margin-bottom:1.2rem;
}
.footer-newsletter input::placeholder{color:#5a5a55}
.footer-newsletter input:focus{border-color:var(--red)}
.footer-newsletter button{
  background:var(--red);color:#fff;
  padding:.85rem 1.55rem;border-radius:999px;
  font-size:.86rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
}
.footer-newsletter button:hover{background:var(--red-dark)}
.socials{display:flex;gap:.7rem;margin-top:1.7rem}
.socials a{
  width:48px;height:48px;border-radius:50%;
  background:#1a1a1a;display:grid;place-items:center;color:#fff;
  transition:background .2s ease, transform .2s ease;
}
.socials a svg{width:18px;height:18px}
.socials a:hover{background:var(--red);transform:translateY(-2px)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:36px;flex-wrap:wrap;gap:1.2rem;
  font-size:.92rem;color:#777;
}
.footer-bottom .legal{display:flex;gap:1.7rem;flex-wrap:wrap}
.footer-bottom a:hover{color:#fff}

/* ---------- Specials (homepage promotions) ---------- */
.specials-section{background:var(--cream-2);border-block:1px solid var(--border)}
.specials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:24px;
}
.special-card{
  background:#fff;
  padding:32px 30px;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.special-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow);
  border-color:var(--red);
}
.special-card::before{
  content:"";
  position:absolute;top:0;right:0;
  width:140px;height:140px;
  background:radial-gradient(circle at 100% 0%, rgba(220,38,38,.08), transparent 70%);
  pointer-events:none;
}
.special-eyebrow{
  align-self:flex-start;
  background:var(--mustard);
  color:var(--ink);
  padding:.4rem .9rem;
  border-radius:999px;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:1.4rem;
}
.special-title{
  font-family:'Bebas Neue', sans-serif;
  font-size:2.1rem;
  letter-spacing:.02em;
  line-height:.95;
  margin:0 0 .9rem;
  text-transform:uppercase;
}
.special-card p{
  color:#3b3a37;
  margin-bottom:1.6rem;
  line-height:1.6;
  flex:1;
}
.special-card .btn{align-self:flex-start}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- Page transitions (Pursimple-style: fast & smooth) ---------- */
@keyframes pageFadeIn{
  0%{opacity:0;transform:translateY(8px)}
  100%{opacity:1;transform:translateY(0)}
}
/* Tight stagger — total entrance ~520ms feels snappy without choppy. */
.topbar,.site-header,.hero,.page-head,section,.site-footer{
  animation:pageFadeIn .42s cubic-bezier(.25,.8,.25,1) both;
  will-change:opacity,transform;
}
.topbar{animation-delay:0s}
.site-header{animation-delay:.02s}
.hero,.page-head{animation-delay:.04s}
section:not(.hero):not(.page-head){animation-delay:.06s}
.site-footer{animation-delay:.08s}

/* Click-to-leave: clean fade + tiny lift, no curtain. */
body.is-leaving > *{
  opacity:0;
  transform:translateY(-6px);
  transition:opacity .18s cubic-bezier(.4,0,.2,1), transform .18s cubic-bezier(.4,0,.2,1);
}

/* Subtle logo flourish */
@keyframes logoEnter{
  0%{opacity:0;transform:scale(.96)}
  100%{opacity:1;transform:scale(1)}
}
.site-header .logo img{
  animation:logoEnter .42s cubic-bezier(.25,.8,.25,1) .04s both;
}

@media (prefers-reduced-motion: reduce){
  .topbar,.site-header,.hero,.page-head,section,.site-footer,
  body.is-leaving > *,.site-header .logo img{
    animation:none !important;
    transition:none !important;
  }
}

/* ---------- Page header (interior pages) ---------- */
.page-head{
  background:var(--ink);
  color:#f7eccf;
  padding:140px 0 100px;
  position:relative;overflow:hidden;
  text-align:center;
}
.page-head::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 80% 10%, rgba(220,38,38,.18), transparent 60%),
    radial-gradient(600px 300px at 10% 90%, rgba(232,168,44,.12), transparent 60%);
}
.page-head h1{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem, 8vw, 7rem);
  letter-spacing:.02em;
  line-height:.92;
  text-transform:uppercase;
  margin:0 0 1rem;
  color:#fff;
  position:relative;
}
.page-head h1 .it{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:500;
  text-transform:none;color:#ffd383;
}
.page-head p{position:relative;color:rgba(255,255,255,.75);max-width:560px;margin:0 auto;font-size:1.08rem}
.crumbs{
  position:relative;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-bottom:1.4rem;
}
.crumbs a{color:#ffd383}
.crumbs span{color:rgba(255,255,255,.4);margin:0 .6rem}

/* ---------- Menu page ---------- */
.menu-tabs{
  display:flex;flex-wrap:wrap;gap:.6rem;
  justify-content:center;margin:0 0 60px;
}
.menu-tab{
  background:#fff;border:1px solid var(--border);
  padding:.7rem 1.3rem;border-radius:999px;
  font-size:.82rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);transition:all .2s ease;
}
.menu-tab:hover{border-color:var(--ink)}
.menu-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}

.menu-section{margin-bottom:80px;scroll-margin-top:120px}
.menu-section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  border-bottom:1px solid var(--border);padding-bottom:18px;margin-bottom:36px;
  flex-wrap:wrap;gap:1rem;
}
.menu-section-head h2{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.2rem,4vw,3.4rem);
  letter-spacing:.02em;text-transform:uppercase;
  margin:0;line-height:.9;
}
.menu-section-head .num{
  font-family:'Playfair Display',serif;font-style:italic;
  color:var(--red);font-size:1rem;
}
.menu-items{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:32px 64px;
}
@media(max-width:760px){.menu-items{grid-template-columns:1fr;gap:28px}}
.menu-item{
  display:flex;align-items:flex-start;gap:18px;
  padding-bottom:24px;border-bottom:1px dashed var(--border);
}
.menu-item-img{
  flex:0 0 90px;
  width:90px;height:90px;border-radius:14px;overflow:hidden;
  background:var(--cream-2);
}
.menu-item-img img{width:100%;height:100%;object-fit:cover}
.menu-item-body{flex:1;min-width:0}
.menu-item-row{
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  margin-bottom:.3rem;
}
.menu-item-name{
  font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;
  text-transform:uppercase;line-height:1;
  flex:1;min-width:0;
}
.menu-item-dots{
  flex:1;border-bottom:1px dotted #c7bfa9;height:1px;align-self:flex-end;margin:0 .5rem .25rem;
}
.menu-item-price{
  font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.04em;color:var(--red);
}
.menu-item-desc{font-size:.9rem;color:var(--muted);line-height:1.5;margin:0}
.menu-tag{
  display:inline-block;font-size:.62rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  background:var(--mustard);color:var(--ink);
  padding:.18rem .5rem;border-radius:4px;
  margin-left:.5rem;vertical-align:middle;
}
.menu-tag.new{background:var(--red);color:#fff}

/* ---------- Locations page ---------- */
.loc-toolbar{
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  margin-bottom:32px;
}
.loc-count{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.04em;}
.loc-count em{font-style:normal;color:var(--red)}
.loc-search-large{
  display:flex;background:#fff;border:1px solid var(--border);
  border-radius:999px;padding:6px 6px 6px 22px;
  flex:1;max-width:480px;min-width:280px;
}
.loc-search-large input{
  flex:1;border:none;outline:none;background:transparent;font-family:inherit;font-size:.95rem;
}
.loc-search-large button{
  background:var(--red);color:#fff;border-radius:999px;
  padding:.65rem 1.2rem;font-weight:600;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
}
.loc-search-large button:hover{background:var(--red-dark)}
.loc-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media(max-width:900px){.loc-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.loc-cards{grid-template-columns:1fr}}
.loc-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:22px 22px;transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  display:flex;flex-direction:column;gap:.4rem;
}
.loc-card:hover{transform:translateY(-2px);border-color:var(--red);box-shadow:var(--shadow)}
.loc-card .city{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.03em;line-height:1}
.loc-card .branch{
  display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--red);margin-top:.2rem;
}
.loc-card .addr{color:var(--muted);font-size:.9rem;margin:.4rem 0 .2rem;line-height:1.5}
.loc-card .phone{font-size:.95rem;font-weight:600;color:var(--ink)}
.loc-card .phone a:hover{color:var(--red)}
.loc-card .links{
  margin-top:auto;padding-top:14px;border-top:1px dashed var(--border);
  display:flex;gap:1rem;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
}
.loc-card .links a{color:var(--ink)}
.loc-card .links a:hover{color:var(--red)}
.loc-empty{
  grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted);
  background:#fff;border:1px dashed var(--border);border-radius:var(--radius);
}

/* ---------- About page ---------- */
.story-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);gap:24px;
  margin-top:60px;
}
@media(max-width:900px){.story-stats{grid-template-columns:repeat(2,1fr)}}
.stat{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 28px;text-align:center;
}
.stat .num{
  font-family:'Bebas Neue',sans-serif;font-size:3.4rem;letter-spacing:.02em;
  color:var(--red);line-height:1;display:block;
}
.stat .label{
  font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);margin-top:.6rem;display:block;
}

.timeline{
  position:relative;
  padding-left:30px;
  border-left:2px solid var(--border);
  margin-top:40px;
}
.tl-item{
  position:relative;
  padding-bottom:36px;
}
.tl-item::before{
  content:"";position:absolute;left:-37px;top:6px;
  width:14px;height:14px;border-radius:50%;
  background:var(--red);
  box-shadow:0 0 0 4px var(--cream);
}
.tl-year{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem;letter-spacing:.04em;color:var(--red);line-height:1;
  margin-bottom:.3rem;
}
.tl-item h3{
  font-family:'Bebas Neue',sans-serif;
  font-size:1.4rem;letter-spacing:.04em;text-transform:uppercase;
  margin:0 0 .4rem;
}
.tl-item p{color:var(--muted);font-size:.96rem;margin:0;max-width:560px}

/* ---------- Mobile Nav ---------- */
@media (max-width:900px){
  .nav-links,.nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav-cta .btn-mobile-order{display:inline-flex !important}
  .site-header.nav-open .nav-links{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:78px;left:0;right:0;
    background:var(--cream);
    padding:24px;
    gap:1rem;
    border-bottom:1px solid var(--border);
    box-shadow:var(--shadow);
  }
  .site-header.nav-open .nav-links a{
    font-size:1.4rem;font-family:'Bebas Neue',sans-serif;letter-spacing:.04em;
  }
  .hero-badge{
    width:110px;height:110px;top:auto;bottom:30px;right:24px;
  }
  .hero-badge .year{font-size:1.8rem}
  .hero-content{padding:90px 0 60px}
  .hero-meta{margin-top:2rem}
}
.nav-cta .btn-mobile-order{display:none}
