/* ==========================================================================
   BREAD BASKET DELI — bbd.css
   A fresh, modern design system. Black + Red + Cream. Est. 1977.
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --red:#db2b25;
  --red-dark:#b21f1b;
  --red-soft:#f6e0dd;
  --ink:#17120f;
  --ink-2:#2a211c;
  --ink-3:#43382f;
  --cream:#fbf5ea;
  --cream-2:#f3e8d5;
  --paper:#ffffff;
  --gold:#f2a516;
  --green:#4f7a3f;
  --muted:#73685d;
  --line:rgba(23,18,15,.12);
  --line-2:rgba(23,18,15,.08);

  --font-display:"Anton",'Arial Narrow',Impact,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-script:"Pacifico","Brush Script MT",cursive;

  --shadow-sm:0 2px 8px rgba(23,18,15,.08);
  --shadow:0 14px 34px rgba(23,18,15,.12);
  --shadow-lg:0 30px 60px rgba(23,18,15,.20);
  --radius:18px;
  --radius-lg:26px;
  --container:1200px;
  --header-h:78px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{margin:0;line-height:1.04;font-weight:800}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--red);outline-offset:3px;border-radius:6px}
::selection{background:var(--red);color:#fff}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section--tight{padding:64px 0}
.section--cream{background:var(--cream)}
.section--alt{background:var(--cream-2)}
.section--paper{background:var(--paper)}
.section--ink{background:var(--ink);color:#f3ece2}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff}
.center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.maxw-680{max-width:680px}
.maxw-760{max-width:760px}

/* ---------- Typography ---------- */
.display{
  font-family:var(--font-display);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:.92;
}
.h-xxl{font-size:clamp(2.6rem,6.4vw,5.4rem)}
.h-xl{font-size:clamp(2.1rem,4.6vw,3.6rem)}
.h-lg{font-size:clamp(1.7rem,3vw,2.5rem)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55em;
  font-weight:800;text-transform:uppercase;letter-spacing:.18em;
  font-size:.78rem;color:var(--red);margin:0 0 16px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.eyebrow--center{justify-content:center}
.eyebrow--light{color:var(--gold)}
.eyebrow--light::before{background:var(--gold)}
.script{font-family:var(--font-script);color:var(--red);font-weight:400;line-height:1}
.lead{font-size:1.15rem;color:var(--muted);max-width:60ch}
.section--ink .lead{color:#c9bfb2}
.text-red{color:var(--red)}
.text-muted{color:var(--muted)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--red);--fg:#fff;--bd:var(--red);
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  background:var(--bg);color:var(--fg);border:2px solid var(--bd);
  font-weight:800;font-size:.92rem;letter-spacing:.04em;text-transform:uppercase;
  padding:15px 30px;border-radius:999px;cursor:pointer;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .2s,color .2s;
  box-shadow:0 10px 22px rgba(219,43,37,.28);
}
.btn:hover{transform:translateY(-3px);background:var(--red-dark);border-color:var(--red-dark);box-shadow:0 16px 30px rgba(219,43,37,.36)}
.btn--ink{--bg:var(--ink);--bd:var(--ink);box-shadow:0 10px 22px rgba(23,18,15,.28)}
.btn--ink:hover{background:#000;border-color:#000}
.btn--outline{--bg:transparent;--fg:var(--ink);--bd:rgba(23,18,15,.28);box-shadow:none}
.btn--outline:hover{--bg:var(--ink);--fg:#fff;border-color:var(--ink);transform:translateY(-3px)}
.btn--ghost-light{--bg:transparent;--fg:#fff;--bd:rgba(255,255,255,.5);box-shadow:none}
.btn--ghost-light:hover{--bg:#fff;--fg:var(--ink);border-color:#fff}
.btn--gold{--bg:var(--gold);--fg:var(--ink);--bd:var(--gold);box-shadow:0 10px 22px rgba(242,165,22,.32)}
.btn--gold:hover{background:#e0950c;border-color:#e0950c}
.btn--sm{padding:11px 22px;font-size:.82rem}
.btn--lg{padding:18px 38px;font-size:1rem}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-row--center{justify-content:center}

/* Arrow link */
.arrow-link{display:inline-flex;align-items:center;gap:.5em;font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.86rem;color:var(--ink)}
.arrow-link svg{transition:transform .25s var(--ease)}
.arrow-link:hover{color:var(--red)}
.arrow-link:hover svg{transform:translateX(5px)}

/* Pills / tags */
.pill{display:inline-flex;align-items:center;gap:.4em;background:var(--red-soft);color:var(--red-dark);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;padding:6px 13px;border-radius:999px}
.pill--gold{background:#fbecc8;color:#9a6a08}
.pill--green{background:#e4efdd;color:#3c5f30}
.pill--ink{background:rgba(255,255,255,.14);color:#fff}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:80;height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(251,245,234,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:background .3s,box-shadow .3s,border-color .3s,height .3s;
}
.site-header.scrolled{background:rgba(251,245,234,.97);box-shadow:0 6px 20px rgba(23,18,15,.10);border-color:var(--line-2)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.brand img{height:46px;width:auto}
.nav{display:flex;align-items:center;gap:30px}
.nav a{font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:.82rem;color:var(--ink-2);position:relative;padding:6px 0;transition:color .2s}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .25s var(--ease)}
.nav a:hover,.nav a[aria-current="page"]{color:var(--red)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.header-actions{display:flex;align-items:center;gap:14px}
.header-cta{flex-shrink:0}
.nav-cta{display:none}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:var(--paper);align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{width:20px;height:2px;background:var(--ink);transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* announcement bar */
.topbar{background:var(--ink);color:#f3ece2;font-size:.78rem;letter-spacing:.04em}
.topbar .container{display:flex;align-items:center;justify-content:center;gap:18px;min-height:38px;text-align:center;padding-top:8px;padding-bottom:8px}
.topbar strong{color:var(--gold)}
.topbar a{color:#fff;text-decoration:underline;text-underline-offset:3px;font-weight:700}
.has-topbar .site-header{top:0}

/* spacer so fixed header doesn't overlap content */
.header-spacer{height:var(--header-h)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(100deg,rgba(15,11,9,.92) 0%,rgba(15,11,9,.72) 38%,rgba(15,11,9,.30) 70%,rgba(15,11,9,.55) 100%);}
.hero__inner{position:relative;z-index:2;padding:120px 0 90px;max-width:760px}
.hero .eyebrow{color:var(--gold)}
.hero .eyebrow::before{background:var(--gold)}
.hero h1{font-size:clamp(2.8rem,7vw,6rem);margin:0 0 22px;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero h1 .script{display:block;font-size:.42em;color:var(--gold);text-transform:none;margin-bottom:.1em;text-shadow:none}
.hero p{font-size:1.2rem;color:#ece3d6;max-width:54ch;margin-bottom:30px}
.hero__meta{display:flex;flex-wrap:wrap;gap:22px;margin-top:34px;color:#d8cdbd;font-size:.86rem;font-weight:600}
.hero__meta span{display:inline-flex;align-items:center;gap:.5em}
.hero__badge{position:absolute;right:6%;bottom:8%;z-index:3;width:148px;height:148px;border-radius:50%;
  background:var(--red);color:#fff;display:grid;place-content:center;text-align:center;
  border:3px solid #fff;box-shadow:var(--shadow-lg);transform:rotate(-9deg);animation:bob 5s ease-in-out infinite}
.hero__badge b{font-family:var(--font-display);font-size:1.9rem;display:block;line-height:.9}
.hero__badge small{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:800}
@keyframes bob{50%{transform:rotate(-9deg) translateY(-10px)}}

/* ---------- Marquee ---------- */
.marquee{background:var(--red);color:#fff;overflow:hidden;border-top:4px solid var(--ink);border-bottom:4px solid var(--ink)}
.marquee__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scroll 28s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee span{font-family:var(--font-display);text-transform:uppercase;font-size:1.5rem;letter-spacing:.04em;padding:16px 26px;display:inline-flex;align-items:center;gap:26px}
.marquee span::after{content:"★";color:var(--gold);font-size:1rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Section heading block ---------- */
.sec-head{max-width:720px;margin:0 0 52px}
.sec-head--center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{margin-bottom:16px}
.sec-head p{color:var(--muted);font-size:1.1rem;margin:0}
.section--ink .sec-head p{color:#c7bcae}
.sec-head__row{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:46px}
.sec-head__row .sec-head{margin-bottom:0}

/* ---------- Order-your-way cards ---------- */
.ways{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.way{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius-lg);padding:34px 30px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative;overflow:hidden}
.way:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.way__icon{width:60px;height:60px;border-radius:16px;display:grid;place-content:center;background:var(--red-soft);color:var(--red);margin-bottom:20px}
.way__icon svg{width:30px;height:30px}
.way h3{font-size:1.4rem;margin-bottom:10px}
.way p{color:var(--muted);font-size:.98rem;margin-bottom:18px}

/* ---------- Category cards ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cat-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow);isolation:isolate}
.cat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .6s var(--ease)}
.cat-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(15,11,9,.92),rgba(15,11,9,.25) 55%,rgba(15,11,9,.05))}
.cat-card:hover img{transform:scale(1.07)}
.cat-card__body{padding:26px 26px 24px}
.cat-card h3{font-size:1.7rem;font-family:var(--font-display);text-transform:uppercase;font-weight:400;letter-spacing:.01em}
.cat-card p{font-size:.92rem;color:#e7ddcf;margin:6px 0 0}
.cat-card .pill{position:absolute;top:18px;left:18px}
.cat-card__count{margin-top:14px;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:.5em}

/* ---------- Feature rows (spotlight) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.feature+.feature{margin-top:110px}
.feature--rev .feature__media{order:2}
.feature__media{position:relative}
.feature__media img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.feature__media .tag-float{position:absolute;left:-18px;bottom:24px;background:var(--paper);border-radius:16px;padding:14px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px}
.feature__media .tag-float b{font-family:var(--font-display);font-size:1.8rem;color:var(--red);line-height:1}
.feature__media .tag-float small{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:var(--muted)}
.feature h2{margin-bottom:18px}
.feature__price{display:inline-flex;align-items:baseline;gap:8px;margin:6px 0 18px;font-weight:800}
.feature__price b{font-family:var(--font-display);font-weight:400;font-size:1.6rem;color:var(--red)}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:10px}
.stat b{display:block;font-family:var(--font-display);font-weight:400;font-size:clamp(2.4rem,4vw,3.4rem);color:var(--gold);line-height:1}
.stat span{font-size:.84rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:#d6cabb;margin-top:8px;display:block}

/* ---------- Supplier chips ---------- */
.suppliers{display:flex;flex-wrap:wrap;gap:14px}
.supplier{display:inline-flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 20px;font-weight:700;box-shadow:var(--shadow-sm)}
.supplier b{color:var(--red)}
.supplier small{color:var(--muted);font-weight:600;font-size:.78rem}

/* ---------- Gallery teaser strip ---------- */
.strip{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.strip a{border-radius:14px;overflow:hidden;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.strip img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.strip a:hover img{transform:scale(1.1)}

/* ---------- Locations teaser ---------- */
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.loc-card{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:6px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.loc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.loc-card h3{font-size:1.3rem;display:flex;align-items:center;gap:10px}
.loc-card h3 .pin{color:var(--red)}
.loc-card .addr{color:var(--muted);font-size:.98rem;margin:2px 0 0}
.loc-card .hours{font-size:.88rem;color:var(--ink-3);margin-top:4px}
.loc-card .loc-actions{margin-top:14px;display:flex;gap:18px;flex-wrap:wrap}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.quote .stars{color:var(--gold);letter-spacing:3px;margin-bottom:12px}
.quote p{font-size:1.05rem;color:var(--ink-2)}
.quote cite{font-style:normal;font-weight:800;color:var(--red);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;color:#fff;text-align:center}
.cta-band__bg{position:absolute;inset:0;z-index:0}
.cta-band__bg img{width:100%;height:100%;object-fit:cover}
.cta-band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(15,11,9,.86),rgba(15,11,9,.86))}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{margin-bottom:18px}
.cta-band p{color:#ddd2c4;font-size:1.15rem;max-width:60ch;margin:0 auto 28px}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#cabfb1;padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand .wordmark{font-family:var(--font-display);font-size:2rem;color:#fff;text-transform:uppercase;line-height:.9;letter-spacing:.01em}
.footer-brand .wordmark b{color:var(--red)}
.footer-brand .est{font-family:var(--font-script);color:var(--gold);font-size:1.2rem}
.footer-brand p{margin:14px 0 18px;font-size:.95rem;max-width:34ch}
.footer-col h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px}
.footer-col ul{display:flex;flex-direction:column;gap:11px}
.footer-col a,.footer-col li{font-size:.94rem;color:#bcb1a3;transition:color .2s}
.footer-col a:hover{color:#fff}
.socials{display:flex;gap:10px;margin-top:6px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-content:center;color:#fff;transition:.25s}
.socials a:hover{background:var(--red);border-color:var(--red);transform:translateY(-3px)}
.socials svg{width:18px;height:18px}
.newsletter form{display:flex;gap:8px;margin-top:6px}
.newsletter input{flex:1;min-width:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:13px 18px;color:#fff;font-family:inherit}
.newsletter input::placeholder{color:#9d9286}
.newsletter button{flex-shrink:0;border:none}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:22px 0;font-size:.84rem;color:#9d9286}
.footer-bottom a{color:#bcb1a3}
.footer-bottom a:hover{color:#fff}

/* ---------- Page header (interior pages) ---------- */
.page-hero{position:relative;color:#fff;padding:150px 0 70px;overflow:hidden}
.page-hero__bg{position:absolute;inset:0;z-index:0}
.page-hero__bg img{width:100%;height:100%;object-fit:cover}
.page-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(15,11,9,.92),rgba(15,11,9,.55))}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);margin:0 0 14px}
.page-hero p{color:#e3d9cb;font-size:1.15rem;max-width:60ch;margin:0}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:#d8cdbd;margin-bottom:18px}
.breadcrumb a{color:var(--gold)}
.breadcrumb span{opacity:.6}

/* ---------- Menu page ---------- */
.menu-tabs{position:sticky;top:var(--header-h);z-index:40;background:rgba(251,245,234,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:14px 0}
.menu-tabs__inner{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}
.menu-tabs__inner::-webkit-scrollbar{display:none}
.menu-tab{flex-shrink:0;border:1px solid var(--line);background:var(--paper);color:var(--ink-2);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;padding:10px 18px;border-radius:999px;transition:.2s}
.menu-tab:hover{border-color:var(--red);color:var(--red)}
.menu-tab.active{background:var(--red);border-color:var(--red);color:#fff}
.menu-cat{padding-top:46px;scroll-margin-top:calc(var(--header-h) + 70px)}
.menu-cat__head{display:flex;align-items:center;gap:16px;margin-bottom:8px}
.menu-cat__head h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.menu-cat__head .line{flex:1;height:2px;background:var(--line)}
.menu-cat__note{color:var(--muted);margin-bottom:26px}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.menu-item{display:flex;gap:18px;background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.menu-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.menu-item__img{width:118px;height:118px;flex-shrink:0;border-radius:14px;overflow:hidden}
.menu-item__img img{width:100%;height:100%;object-fit:cover}
.menu-item__body{flex:1;min-width:0}
.menu-item__top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.menu-item__top h3{font-size:1.18rem}
.menu-item__price{font-family:var(--font-display);font-weight:400;color:var(--red);font-size:1.3rem;white-space:nowrap}
.menu-item p{font-size:.92rem;color:var(--muted);margin:6px 0 0}
.menu-item .pill{margin-top:10px}

/* ---------- Gallery ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:34px}
.filter-btn{border:1px solid var(--line);background:var(--paper);color:var(--ink-2);font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;padding:10px 18px;border-radius:999px;transition:.2s}
.filter-btn:hover{border-color:var(--red);color:var(--red)}
.filter-btn.active{background:var(--ink);border-color:var(--ink);color:#fff}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px}
.g-card{position:relative;border-radius:18px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);background:var(--cream-2);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.g-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.g-card.is-hidden{display:none}
.g-card__img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.g-card__img img{width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.03);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.g-card__img img.loaded{opacity:1;transform:none}
.g-card:hover .g-card__img img.loaded{transform:scale(1.07)}
.g-card__count{position:absolute;top:12px;right:12px;background:rgba(15,11,9,.72);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px)}
.g-card figcaption{padding:14px 16px;font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:space-between;gap:8px}
.g-card figcaption::after{content:"\203A";color:var(--red);font-size:1.4rem;line-height:1;transition:transform .25s var(--ease)}
.g-card:hover figcaption::after{transform:translateX(4px)}
.gallery-empty{text-align:center;color:var(--muted);padding:40px}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(10,7,5,.93);display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:82vh;border-radius:12px;box-shadow:var(--shadow-lg)}
.lightbox__cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;color:#fff;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.lb-btn{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;width:54px;height:54px;border-radius:50%;display:grid;place-content:center;font-size:1.4rem;transition:.2s}
.lb-btn:hover{background:var(--red);border-color:var(--red)}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
.lb-close{top:24px;right:24px;width:48px;height:48px}

/* ---------- Forms ---------- */
.form{display:grid;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-family:inherit;font-size:1rem;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.field textarea{min-height:140px;resize:vertical}
.form-note{font-size:.86rem;color:var(--muted)}

/* ---------- Info card / contact ---------- */
.info-list{display:grid;gap:18px}
.info-item{display:flex;gap:16px;align-items:flex-start}
.info-item__icon{width:48px;height:48px;border-radius:12px;background:var(--red-soft);color:var(--red);display:grid;place-content:center;flex-shrink:0}
.info-item h4{font-size:1.05rem;margin-bottom:3px}
.info-item p{margin:0;color:var(--muted)}

/* ---------- Values / about ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.value__icon{width:56px;height:56px;border-radius:14px;background:var(--ink);color:var(--gold);display:grid;place-content:center;margin-bottom:18px}
.value h3{font-size:1.25rem;margin-bottom:8px}
.value p{color:var(--muted);font-size:.96rem;margin:0}

/* timeline */
.timeline{position:relative;max-width:760px;margin:0 auto;padding-left:34px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl{position:relative;padding-bottom:34px}
.tl::before{content:"";position:absolute;left:-34px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--red);border:3px solid var(--cream)}
.tl b{font-family:var(--font-display);font-weight:400;color:var(--red);font-size:1.4rem;display:block;margin-bottom:4px}

/* split / faq */
.faq{display:grid;gap:14px;max-width:780px;margin:0 auto}
.faq details{background:var(--paper);border:1px solid var(--line-2);border-radius:14px;padding:6px 22px;box-shadow:var(--shadow-sm)}
.faq summary{font-weight:800;padding:16px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--font-display);color:var(--red);font-size:1.5rem}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 18px;margin:0;color:var(--muted)}

/* catering tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tier{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.tier:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tier.featured{border:2px solid var(--red)}
.tier__img{aspect-ratio:16/10;overflow:hidden}
.tier__img img{width:100%;height:100%;object-fit:cover}
.tier__body{padding:26px;display:flex;flex-direction:column;flex:1}
.tier h3{font-size:1.4rem;margin-bottom:6px}
.tier .price{font-family:var(--font-display);font-weight:400;color:var(--red);font-size:1.8rem;margin:4px 0 14px}
.tier ul{display:grid;gap:9px;margin-bottom:22px}
.tier li{display:flex;gap:10px;font-size:.94rem;color:var(--ink-2)}
.tier li svg{color:var(--green);flex-shrink:0;margin-top:3px}
.tier .btn{margin-top:auto}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee__track,.hero__badge{animation:none}
  html{scroll-behavior:auto}
}

/* ---------- Mobile nav drawer ---------- */
.nav-backdrop{position:fixed;inset:0;background:rgba(15,11,9,.5);z-index:90;opacity:0;visibility:hidden;transition:.3s}
.nav-backdrop.open{opacity:1;visibility:visible}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px}
  .strip{grid-template-columns:repeat(4,1fr)}
  .gallery{columns:3}
}
@media (max-width:860px){
  .section{padding:72px 0}
  .header-cta{display:none}
  .nav-toggle{display:flex}
  .nav{
    position:fixed;top:0;right:0;height:100dvh;width:min(86vw,360px);
    background:var(--cream);flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:0;padding:90px 28px 28px;z-index:95;transform:translateX(100%);transition:transform .35s var(--ease);
    box-shadow:var(--shadow-lg);overflow-y:auto;
  }
  .nav.open{transform:none}
  .nav a{font-size:1.1rem;padding:16px 0;border-bottom:1px solid var(--line-2)}
  .nav a::after{display:none}
  .nav-cta{display:inline-flex;margin-top:22px}
  .nav a.nav-cta{border-bottom:none}
  .ways,.cat-grid,.values,.tiers,.quotes,.stats{grid-template-columns:1fr 1fr}
  .feature{grid-template-columns:1fr;gap:32px}
  .feature--rev .feature__media{order:0}
  .feature+.feature{margin-top:64px}
  .menu-grid,.loc-grid{grid-template-columns:1fr}
  .gallery{columns:2}
  .hero__badge{width:118px;height:118px;right:5%;bottom:5%}
  .hero__badge b{font-size:1.5rem}
}
@media (max-width:560px){
  body{font-size:16px}
  .container{padding:0 18px}
  .section{padding:56px 0}
  .ways,.cat-grid,.values,.tiers,.quotes,.stats,.strip{grid-template-columns:1fr 1fr}
  .stats{gap:18px}
  .menu-item{flex-direction:column}
  .menu-item__img{width:100%;height:170px}
  .gallery{grid-template-columns:repeat(2,1fr);gap:12px}
  .g-card figcaption{font-size:.86rem;padding:11px 12px}
  .marquee span{font-size:1.15rem}
  .btn{width:100%}
  .btn-row{flex-direction:column}
  .hero__badge{display:none}
  .footer-grid{grid-template-columns:1fr}
  .strip{grid-template-columns:repeat(3,1fr)}
}

/* ==========================================================================
   ONLINE ORDERING
   ========================================================================== */
.btn:disabled,.btn[disabled]{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.btn:disabled:hover,.btn[disabled]:hover{transform:none;background:var(--red);border-color:var(--red)}

.header-cart{display:none;position:relative;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:var(--paper);place-content:center;color:var(--ink)}
.header-cart:hover{border-color:var(--red);color:var(--red)}
.header-cart__badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--red);color:#fff;font-size:.7rem;font-weight:800;display:grid;place-content:center;border:2px solid var(--cream)}
.header-cart__badge.is-zero{display:none}

.order-head{padding:calc(var(--header-h) + 30px) 0 18px;background:var(--cream)}
.order-head h1{margin:6px 0 12px}
.order-status{display:inline-flex;align-items:center;gap:9px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:.92rem;font-weight:600}
.order-status .dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot--open{background:var(--green);box-shadow:0 0 0 4px rgba(79,122,63,.2)}
.dot--closed{background:var(--gold);box-shadow:0 0 0 4px rgba(242,165,22,.2)}

.order-grid{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.order-menu{min-width:0}
.order-menu .menu-cat:first-child{padding-top:8px}
.order-aside{position:sticky;top:calc(var(--header-h) + 70px)}
.cart{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;max-height:calc(100vh - var(--header-h) - 90px)}
.cart__head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--line-2)}
.cart__head h2{font-size:1.5rem}
.cart__close{display:none;background:none;border:none;font-size:1.9rem;line-height:1;color:var(--muted)}
.cart__items{overflow-y:auto;padding:6px 22px;flex:1}
.cart-empty{text-align:center;padding:34px 6px;color:var(--ink-2)}
.cart-empty p{margin:0 0 6px}
.cart-line{display:grid;grid-template-columns:1fr auto;grid-template-areas:"info qty" "info sub";gap:2px 12px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line-2);position:relative}
.cart-line__info{grid-area:info;min-width:0;padding-right:16px}
.cart-line__info b{display:block;font-size:.95rem;line-height:1.25}
.cart-line__info span{font-size:.82rem;color:var(--muted)}
.cart-line__qty{grid-area:qty;display:inline-flex;align-items:center;gap:9px;background:var(--cream);border-radius:999px;padding:4px}
.cart-line__qty button{width:24px;height:24px;border-radius:50%;border:none;background:var(--paper);box-shadow:var(--shadow-sm);font-weight:800;color:var(--ink);line-height:1}
.cart-line__qty button:hover{background:var(--red);color:#fff}
.cart-line__qty b{min-width:14px;text-align:center;font-size:.9rem}
.cart-line__sub{grid-area:sub;justify-self:end;font-weight:800;color:var(--red)}
.cart-line__rm{position:absolute;top:8px;right:-4px;background:none;border:none;color:var(--muted);font-size:1.1rem;line-height:1;opacity:.5}
.cart-line__rm:hover{opacity:1;color:var(--red)}
.cart__foot{padding:18px 22px;border-top:1px solid var(--line-2);background:var(--cream)}
.cart__total{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:4px}
.cart__total b{font-family:var(--font-display);font-weight:400;font-size:1.7rem;color:var(--ink)}

.mi-unit{font-family:var(--font-body);font-size:.72rem;font-weight:700;color:var(--muted);margin-left:4px}
.menu-item .mi-control{margin-top:12px}
.btn-mini{display:inline-flex;align-items:center;gap:.4em;background:var(--ink);color:#fff;border:none;border-radius:999px;padding:9px 18px;font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;transition:.2s}
.btn-mini:hover{background:var(--red)}
.mi-step{display:inline-flex;align-items:center;gap:14px;background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:5px}
.mi-step button{width:30px;height:30px;border-radius:50%;border:none;background:var(--red);color:#fff;font-size:1.1rem;font-weight:800;line-height:1;display:grid;place-content:center}
.mi-step button:hover{background:var(--red-dark)}
.mi-step .mi-n{min-width:16px;text-align:center;font-weight:800}

.cart-bar{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:70;align-items:center;justify-content:space-between;gap:14px;background:var(--red);color:#fff;border:none;border-radius:16px;padding:15px 22px;box-shadow:var(--shadow-lg);font-weight:800;font-size:1rem}
.cart-bar__left{display:inline-flex;align-items:center;gap:10px}
.cart-bar__count{background:#fff;color:var(--red);min-width:24px;height:24px;border-radius:999px;display:inline-grid;place-content:center;font-size:.82rem}
.cart-backdrop{position:fixed;inset:0;background:rgba(15,11,9,.5);z-index:99;opacity:0;visibility:hidden;transition:.3s}
.cart-backdrop.open{opacity:1;visibility:visible}

.checkout{margin-top:70px;scroll-margin-top:calc(var(--header-h) + 16px)}
.checkout-form{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:38px}
.checkout-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.co-block{border:none;margin:0;padding:0;min-width:0}
.co-block legend{font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;color:var(--red);margin-bottom:14px;padding:0}
.checkout-grid .co-block:nth-child(n+3){grid-column:1 / -1}
.opt-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.opt{position:relative;cursor:pointer;display:block}
.opt input{position:absolute;opacity:0;inset:0}
.opt__box{display:block;border:2px solid var(--line);border-radius:14px;padding:14px 16px;transition:.2s;height:100%}
.opt__box b{display:block}
.opt__box small{color:var(--muted);font-size:.82rem}
.opt input:checked + .opt__box{border-color:var(--red);background:var(--red-soft)}
.opt input:focus-visible + .opt__box{outline:3px solid var(--red);outline-offset:2px}
.checkout-submit{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:26px;padding-top:24px;border-top:1px solid var(--line-2)}
.checkout-submit__total{font-size:1.1rem;font-weight:700}
.checkout-submit__total b{font-family:var(--font-display);font-weight:400;font-size:1.7rem;color:var(--red);margin-left:8px}

.order-success{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:46px 34px;text-align:center;max-width:640px;margin:0 auto}
.order-success__check{width:74px;height:74px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-content:center;margin:0 auto 18px}
.order-success h2{margin-bottom:12px}
.order-success p{color:var(--muted);max-width:50ch;margin:0 auto 10px}
.order-success__meta{background:var(--cream);border-radius:12px;padding:12px 16px;display:inline-block;color:var(--ink-2)!important}
.order-success .btn-row{margin-top:24px}

.order-flash{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);z-index:130;background:var(--ink);color:#fff;padding:14px 22px;border-radius:12px;font-weight:700;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:.3s;max-width:90vw;text-align:center}
.order-flash.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}

@media (max-width:980px){
  .header-cart{display:grid}
  .order-grid{grid-template-columns:1fr}
  .order-aside{position:fixed;top:0;right:0;height:100dvh;width:min(92vw,400px);z-index:100;transform:translateX(100%);transition:transform .35s var(--ease)}
  .order-aside.open{transform:none}
  .cart{height:100dvh;max-height:none;border-radius:0;border:none}
  .cart__close{display:block}
  .cart-bar.show{display:flex}
  .checkout-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  .checkout-form{padding:24px 18px}
  .opt-row{grid-template-columns:1fr}
  .menu-item .mi-control{margin-top:14px}
}

/* ---- modifier "count in order" badge on menu cards ---- */
.mi-control{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.mi-count{font-size:.78rem;font-weight:800;color:var(--red);background:var(--red-soft);padding:5px 11px;border-radius:999px}
.cart-line__mods{display:block;font-size:.79rem;color:var(--ink-3);line-height:1.35;margin:2px 0}

/* ---- modifier modal ---- */
.modal{position:fixed;inset:0;z-index:140;background:rgba(15,11,9,.62);display:flex;align-items:center;justify-content:center;padding:18px;opacity:0;transition:opacity .25s}
.modal.open{opacity:1}
.modal__dialog{background:var(--paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:540px;width:100%;max-height:92vh;overflow:auto;position:relative;transform:translateY(16px);transition:transform .25s var(--ease)}
.modal.open .modal__dialog{transform:none}
.modal__close{position:absolute;top:12px;right:12px;z-index:3;width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,.92);font-size:1.6rem;line-height:1;box-shadow:var(--shadow-sm);color:var(--ink)}
.modal__close:hover{background:var(--red);color:#fff}
.modal__img{aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.modal__img img{width:100%;height:100%;object-fit:cover}
.modal__body{padding:24px 26px 10px}
.modal__body h3{font-size:1.5rem}
.modal__desc{color:var(--muted);font-size:.92rem;margin:6px 0 20px}
.opt-group{margin-bottom:20px}
.opt-group h4{font-size:.9rem;text-transform:uppercase;letter-spacing:.04em;margin-bottom:11px;display:flex;gap:9px;align-items:center}
.opt-group h4 em{font-style:normal;font-size:.64rem;color:var(--red);background:var(--red-soft);padding:3px 9px;border-radius:999px;font-weight:800;letter-spacing:.06em}
.opt-choices{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.opt-choice{display:flex;align-items:center;gap:10px;border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;cursor:pointer;font-size:.92rem;transition:border-color .15s,background .15s}
.opt-choice:hover{border-color:var(--red)}
.opt-choice:has(input:checked){border-color:var(--red);background:var(--red-soft)}
.opt-choice input{accent-color:var(--red);width:17px;height:17px;flex-shrink:0;margin:0}
.opt-choice .oc-price{color:var(--red);font-weight:700;font-size:.84rem}
.modal__foot{position:sticky;bottom:0;background:var(--paper);border-top:1px solid var(--line-2);padding:16px 22px;display:flex;align-items:center;gap:14px}
.qty-pick{display:inline-flex;align-items:center;gap:14px;background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:5px;flex-shrink:0}
.qty-pick button{width:34px;height:34px;border-radius:50%;border:none;background:var(--red);color:#fff;font-size:1.2rem;font-weight:800;line-height:1}
.qty-pick button:hover{background:var(--red-dark)}
.qty-pick b{min-width:18px;text-align:center}
.modal__add{flex:1;justify-content:center}
@media (max-width:520px){.opt-choices{grid-template-columns:1fr}}

/* ==========================================================================
   UNIFIED MENU + ORDERING: toolbar, icons, animations
   ========================================================================== */
.btn-mini{background:var(--red)}
.btn-mini:hover{background:var(--red-dark)}

.order-head__sub{color:var(--muted);font-size:1.06rem;margin:-2px 0 14px;max-width:54ch}

.order-toolbar{display:flex;align-items:center;gap:14px}
.order-search-wrap{position:relative;flex-shrink:0;width:250px}
.order-search-ic{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none}
.order-search{width:100%;border:1px solid var(--line);border-radius:999px;padding:11px 16px 11px 42px;font-family:inherit;font-size:.95rem;background:var(--paper);color:var(--ink)}
.order-search:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.menu-tabs__inner{flex:1}

.menu-tab{display:inline-flex;align-items:center;gap:8px}
.tab-ic{font-size:1.05em;line-height:1}
.tab-n{font-size:.7rem;font-weight:800;background:rgba(23,18,15,.08);color:var(--muted);padding:1px 7px;border-radius:999px;min-width:20px;text-align:center}
.menu-tab:hover .tab-n{background:var(--red-soft);color:var(--red)}
.menu-tab.active .tab-n{background:rgba(255,255,255,.26);color:#fff}
.menu-cat__head{align-items:center}
.cat-ic{font-size:1.7rem;line-height:1}

.menu-cat[hidden]{display:none}
.menu-item.is-hidden{display:none}
.order-menu-col{min-width:0}
.order-menu{min-height:48vh}
.order-aside{top:calc(var(--header-h) + 92px)}

.cart-empty__ic{font-size:2.7rem;margin-bottom:6px;line-height:1}

.fly-plus{position:fixed;z-index:135;transform:translateX(-50%);font-family:var(--font-display);font-size:1.6rem;color:var(--red);pointer-events:none;text-shadow:0 2px 10px rgba(255,255,255,.85)}

.order-success{position:relative;overflow:hidden}
.confetti{position:absolute;top:-14px;width:9px;height:15px;border-radius:2px;opacity:.95;animation:confettiFall 1.7s cubic-bezier(.2,.6,.4,1) forwards}
@keyframes confettiFall{0%{transform:translateY(0) rotate(0)}100%{transform:translateY(560px) rotate(var(--rot,360deg));opacity:0}}
.order-success__check{animation:checkPop .5s var(--ease) both}
.order-success__check svg path{stroke-dasharray:30;stroke-dashoffset:30;animation:drawCheck .5s .25s forwards}
@keyframes checkPop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.12)}100%{transform:scale(1);opacity:1}}
@keyframes drawCheck{to{stroke-dashoffset:0}}

@media (prefers-reduced-motion:reduce){
  .confetti{animation:none;display:none}
  .order-success__check{animation:none}
  .order-success__check svg path{animation:none;stroke-dashoffset:0}
}

/* ==========================================================================
   MOBILE POLISH
   ========================================================================== */
@media (max-width:860px){
  .order-toolbar{flex-direction:column;align-items:stretch;gap:10px}
  .order-search-wrap{width:100%}
  .order-head__sub{font-size:.98rem}
  .checkout{padding-bottom:84px}
  .sec-head__row .btn{align-self:flex-start}
}
@media (max-width:560px){
  :root{--header-h:64px}
  .brand img{height:40px}
  .hero{min-height:82vh}
  .hero__inner{padding:92px 0 60px}
  .hero p{font-size:1.05rem;margin-bottom:24px}
  .hero__meta{gap:8px 16px;font-size:.78rem;margin-top:24px}
  .page-hero{padding:118px 0 48px}
  .marquee span{font-size:1rem;padding:12px 16px;gap:16px}
  .sec-head{margin-bottom:28px}
  .sec-head__row{margin-bottom:26px;gap:16px}
  .feature+.feature{margin-top:44px}
  .menu-cat__head h2{font-size:1.45rem}
  .menu-cat__head .cat-ic{font-size:1.35rem}
  .menu-item{padding:12px;gap:12px}
  .menu-item__top h3{font-size:1.08rem}
  .cart-bar{left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom,0px));border-radius:14px}
  .checkout{margin-top:46px;padding-bottom:86px}
  .checkout-form{padding:22px 16px}
  .order-success{padding:34px 20px}
  .order-success__meta{display:block}
  .footer-bottom{flex-direction:column;text-align:center;gap:8px}
  .btn--lg{padding:15px 26px;font-size:.95rem}
  .quote p{font-size:1rem}
  .stat b{font-size:2.6rem}
}
@media (max-width:400px){
  .tab-n{display:none}
  .hero h1{font-size:2.35rem}
  .menu-cat__head h2{font-size:1.3rem}
}
