/* Chilli & Chive — design system base + home scope
   Card components (.dish-card, .home-*-card, .qa-item, etc.) keep their own rules; do not restyle here. */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&display=swap');

:root{
  --font-sans:'Outfit',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  /* Apple-like neutral surfaces */
  --bg:#f5f5f7;
  --surface:#ffffff;
  --surface-2:#f2f2f4;
  --text:#0b1220;
  --muted:#667085;
  --border:rgba(15,23,42,.10);
  --border-2:rgba(15,23,42,.14);
  --red:#e11d48;
  --red-dark:#be123c;
  --amber:#f59e0b;
  /* Softer Apple-style elevation */
  --shadow-sm:0 1px 1px rgba(15,23,42,.04), 0 8px 18px rgba(15,23,42,.06);
  --shadow-md:0 1px 2px rgba(15,23,42,.06), 0 20px 45px rgba(15,23,42,.10);
  /* Continuous corners */
  --radius-sm:.8rem;
  --radius-md:1.1rem;
  --radius-lg:1.35rem;
  --radius-xl:1.85rem;
  --max:72rem;
  --pad:1rem;
  /* Design language — spacing & motion (system-wide tokens) */
  --dl-ease:cubic-bezier(.22,1,.36,1);
  --dl-duration:.18s;
  --dl-space-1:.25rem;
  --dl-space-2:.5rem;
  --dl-space-3:.75rem;
  --dl-space-4:1rem;
  --dl-space-5:1.25rem;
  --dl-space-6:1.5rem;
  --dl-space-8:2rem;
  --dl-space-10:2.5rem;
  --dl-text-xs:.75rem;
  --dl-text-sm:.875rem;
  --dl-text-base:1rem;
  --dl-leading-snug:1.35;
  --dl-leading-normal:1.5;
  --dl-leading-relaxed:1.62;
  --dl-section-y:2rem;
  --dl-section-y-md:2.5rem;
  --dl-section-y-lg:3rem;
  --dl-max-prose:48rem;
  /* Polish — depth & motion (system-wide) */
  --ease-smooth:cubic-bezier(.4,0,.2,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --surface-glass:rgba(255,255,255,.82);
  --ring-focus:0 0 0 3px rgba(225,29,72,.22);
  --shadow-glow-sm:0 1px 0 rgba(255,255,255,.7) inset,0 12px 40px rgba(15,23,42,.08);
  /* Cards — shared motion (all “card” surfaces) */
  --card-transition:transform .22s var(--ease-smooth),box-shadow .22s var(--ease-smooth),border-color .22s var(--ease-smooth);
  --card-lift-sm:translateY(-2px);
  --card-lift-md:translateY(-3px);
  /* Typography scale (responsive, system-wide) */
  --fs-body:clamp(.98rem,.2vw + .95rem,1.05rem);
  --fs-h1:clamp(1.65rem,1vw + 1.35rem,2.25rem);
  --fs-h2:clamp(1.3rem,.7vw + 1.15rem,1.75rem);
  --fs-h3:clamp(1.05rem,.35vw + 1rem,1.25rem);
  --fs-title:clamp(1.55rem,1vw + 1.25rem,2.05rem);
}
@media (min-width:640px){:root{--pad:1.25rem}}
@media (min-width:1024px){:root{--pad:1.5rem}}
@media (min-width:768px){
  :root{
    --dl-section-y:2.5rem;
    --dl-section-y-md:3rem;
    --dl-section-y-lg:3.5rem;
  }
}

/* 2-up card rows on phone (design language — use for small tiles, not full menu dish grids) */
.dl-grid-2-sm{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:var(--dl-space-3) var(--dl-space-4);
  align-items:stretch;
}

/* Home page: layout chrome only (sections, hero, strips — not product cards) */
.page-home{
  --home-section-pad-y:var(--dl-section-y-md);
}
@media (min-width:768px){
  .page-home{--home-section-pad-y:var(--dl-section-y-lg)}
}
.page-home .home-section{
  padding-block:var(--home-section-pad-y);
}
.page-home .home-section__head{
  max-width:var(--dl-max-prose);
}
.page-home .home-section__lead{
  margin-bottom:var(--dl-space-6);
  line-height:var(--dl-leading-relaxed);
}
.page-home .section-cta{
  margin-top:var(--dl-space-6);
}
.page-home .hero-panel__shell{
  max-width:min(72rem,100%);
}
.page-home .search-strip--vercel{
  padding-block:var(--dl-space-4) calc(var(--dl-space-5) + 2px);
}
.page-home .quick-strip--vercel{
  padding-block:var(--dl-space-4) var(--dl-space-6);
}
.page-home .cat-strip--mind{
  padding-block:var(--dl-space-6) var(--dl-space-5);
}
.page-home .cat-strip-title--mind{
  margin:0;
}
.page-home .home-book-band{
  margin-top:var(--dl-space-6);
  margin-bottom:0;
}
.page-home .home-stats{
  border-top:1px solid var(--border);
}
.page-home .home-stats__grid{
  padding-block:var(--dl-space-6);
}
@media (min-width:768px){
  .page-home .home-stats__grid{padding-block:var(--dl-space-8)}
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:var(--fs-body);
  line-height:var(--dl-leading-normal);
  color:var(--text);
  background-color:var(--bg);
  background-image:
    radial-gradient(1200px 600px at 100% -10%,rgba(225,29,72,.06),transparent 55%),
    radial-gradient(900px 500px at -15% 20%,rgba(59,130,246,.05),transparent 50%),
    radial-gradient(700px 400px at 50% 100%,rgba(245,158,11,.04),transparent 45%);
  background-attachment:fixed;
  min-height:100vh;
  min-height:100dvh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
/* Typography defaults: classes override these */
h1{font-size:var(--fs-h1);font-weight:950;letter-spacing:-.02em;line-height:1.15}
h2{font-size:var(--fs-h2);font-weight:950;letter-spacing:-.02em;line-height:1.2}
h3{font-size:var(--fs-h3);font-weight:950;letter-spacing:-.01em;line-height:1.25}
p{line-height:var(--dl-leading-normal)}
/* Prevent long strings from breaking layouts */
body, .app-shell, .card-surface, .dish-card, .home-offer-card, .home-feature-card, .home-promo-card, .home-combo-card {
  overflow-wrap: anywhere;
  word-break: break-word;
}
img,svg,video{max-width:100%}
a{color:inherit;text-decoration:none}
a:hover{color:var(--red)}
a:focus-visible{
  outline:2px solid rgba(225,29,72,.5);
  outline-offset:3px;
  border-radius:.2rem;
}

.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Shell */
.app-shell{
  width:100%;
  max-width:min(var(--max),100%);
  margin-inline:auto;
  padding-inline:var(--pad);
}

main.site-main{
  flex:1 1 auto;
  display:block;
  width:100%;
  min-width:0;
  padding-inline:max(0px,env(safe-area-inset-left,0px)) max(0px,env(safe-area-inset-right,0px));
}
.layout-page{display:flex;flex-direction:column;min-height:0}
.layout-page__primary{min-width:0}

/* Announcement */
.ann-bar{
  background:linear-gradient(90deg,var(--red),var(--red-dark));
  color:#fff;
  font-weight:700;
  font-size:.875rem;
  padding:.55rem var(--pad);
  text-align:center;
}

/* Header */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px) saturate(1.15);
  -webkit-backdrop-filter:blur(14px) saturate(1.15);
  border-bottom:1px solid var(--border);
  box-shadow:0 1px 0 rgba(255,255,255,.65) inset;
}
.site-header::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.35),rgba(255,255,255,0));
}
.nav-inner{
  min-height:60px;
  display:flex;align-items:center;gap:.75rem;
  padding-block:.65rem;
  position:relative;
  z-index:1;
}
.brand-logo{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.brand-logo__img{height:34px;width:auto;max-width:min(200px,58vw);object-fit:contain}
/* Keep header clean — logo only (no extra brand text) */
.brand-logo-text{display:none!important}
.nav-spacer{flex:1;min-width:0}
@media (min-width:768px){.nav-spacer{display:block}}

.nav-pill-tablet{display:none;gap:.25rem;align-items:center}
@media (min-width:640px) and (max-width:767px){.nav-pill-tablet{display:flex}}
.nav-pill-tablet a{
  padding:.45rem .7rem;border-radius:.9rem;
  color:var(--text);font-weight:700;font-size:.95rem;
}
.nav-pill-tablet a:hover{background:#f1f5f9}

.nav-links{
  display:flex;
  align-items:center;
  gap:.9rem;
  flex-wrap:wrap;
  justify-content:flex-end;
  min-width:0;
}
.nav-links .nav-link{font-weight:700;font-size:.95rem;color:var(--text)}
.nav-links .nav-link--muted{color:var(--muted)}
.nav-links .nav-link.is-active{color:var(--red)}
.nav-link--drawer-only{display:none}
.nav-links .nav-link{padding:.4rem .6rem;border-radius:.9rem}
.nav-links .nav-link:hover{background:rgba(15,23,42,.05)}
.nav-links .nav-link--muted:hover{background:rgba(15,23,42,.04)}

/* Desktop grouping: primary left, actions right */
.nav-primary,.nav-actions{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.nav-actions{margin-left:auto}
.nav-cta{box-shadow:0 10px 22px rgba(225,29,72,.16)}
.nav-cta:hover{box-shadow:0 18px 40px rgba(225,29,72,.20)}

.nav-cart{position:relative;display:inline-flex;align-items:center;gap:.45rem;padding:.35rem;border-radius:.9rem}
.nav-cart:hover{background:#f1f5f9}
.cart-badge{
  position:absolute;top:.05rem;right:.05rem;
  min-width:1.05rem;height:1.05rem;border-radius:999px;
  background:var(--red);color:#fff;font-weight:900;font-size:10px;
  display:grid;place-items:center;padding:0 .25rem;
}
.nav-cart-label{display:none}
@media (max-width:767px){.nav-cart-label{display:inline}}

/* Toolbar cart (mobile) */
.nav-cart--toolbar{
  position:relative;
  display:none;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  border-radius:var(--radius-sm);
  border:1px solid var(--border);
  background:#fff;
}
.nav-cart--toolbar:hover{background:#f8fafc}
.nav-cart--toolbar svg{display:block}
.nav-cart--toolbar.is-active{border-color:rgba(225,29,72,.22);box-shadow:0 10px 22px rgba(225,29,72,.10)}

.nav-burger{
  display:none;
  width:44px;height:44px;border-radius:var(--radius-sm);
  border:1px solid var(--border);background:#fff;
  align-items:center;justify-content:center;gap:5px;flex-direction:column;
}
.nav-burger:hover{background:#f8fafc}
.nav-burger-bar{width:18px;height:2px;background:var(--text);border-radius:2px}
.nav-backdrop{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);
  backdrop-filter:blur(10px);z-index:40;
}

@media (max-width:767px){
  .nav-burger{display:flex}
  .nav-cart--toolbar{display:inline-flex}
  .nav-pill-tablet{display:none!important}
  /* Mobile topbar: keep clean, drawer handles the list */
  .nav-links{justify-content:flex-start}
  .nav-links{
    position:fixed;top:0;right:0;z-index:60;
    height:100dvh;width:min(22rem,92vw);
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    background:#fff;border-left:1px solid var(--border);
    box-shadow:-24px 0 64px rgba(0,0,0,.20);
    padding:max(2.6rem,env(safe-area-inset-top,0px)) 0 1.1rem;
    transform:translateX(100%);
    transition:transform .25s cubic-bezier(.22,1,.36,1);
    overflow:auto;
    gap:0;
  }
  .site-header.nav-open .nav-links{transform:translateX(0)}
  .site-header.nav-open .nav-backdrop{display:block}
  .nav-link--drawer-only{display:block}
  /* Avoid duplicate cart: toolbar has it, drawer doesn't need it */
  .nav-links .nav-cart{display:none}
  .nav-primary,.nav-actions{display:block}
  .nav-actions{margin-left:0}
  .nav-links{gap:0}
  .nav-links a{
    padding:.95rem 1.15rem;
    border-bottom:1px solid rgba(0,0,0,.05);
  }
  .nav-links a:active{background:rgba(225,29,72,.06)}
  .nav-links a.nav-link.is-active{background:rgba(225,29,72,.08);box-shadow:inset 3px 0 0 var(--red)}
}

/* Mobile drawer header (less clutter + futuristic close button) */
.nav-drawer-head{
  display:none;
}
@media (max-width:767px){
  .nav-drawer-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.75rem;
    padding:.75rem 1.05rem .6rem;
    position:sticky;
    top:0;
    z-index:2;
    background:rgba(255,255,255,.92);
    backdrop-filter:blur(14px);
    border-bottom:1px solid rgba(15,23,42,.06);
  }
  .nav-drawer-logo{
    height:30px;width:auto;
    max-width:148px;
    object-fit:contain;
    filter:drop-shadow(0 10px 22px rgba(15,23,42,.10));
  }
  .nav-drawer-brand{display:flex;align-items:center;gap:.55rem;min-width:0}
  .nav-drawer-brand__dot{
    width:10px;height:10px;border-radius:999px;
    background:radial-gradient(circle at 30% 30%, #fff, rgba(255,255,255,.2) 35%), linear-gradient(135deg, var(--red), #ff5a7a);
    box-shadow:0 10px 22px rgba(225,29,72,.22);
    flex:0 0 auto;
  }
  .nav-drawer-brand__txt{
    font-weight:950;
    letter-spacing:-.02em;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .nav-close{
    width:44px;height:44px;
    border-radius:16px;
    border:1px solid rgba(15,23,42,.10);
    background:
      radial-gradient(120px 50px at 20% 0%, rgba(225,29,72,.12), transparent 55%),
      radial-gradient(120px 60px at 90% 30%, rgba(59,130,246,.12), transparent 55%),
      linear-gradient(180deg,#fff,#f7f7f9);
    box-shadow:0 10px 26px rgba(15,23,42,.10);
    position:relative;
    cursor:pointer;
    transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
  }
  .nav-close:hover{box-shadow:0 18px 46px rgba(15,23,42,.14);filter:saturate(1.05)}
  .nav-close:active{transform:translateY(1px) scale(.99)}
  .nav-close__x{
    position:absolute;inset:0;
    margin:auto;
    width:18px;height:18px;
  }
  .nav-close__x::before,
  .nav-close__x::after{
    content:"";
    position:absolute;left:50%;top:50%;
    width:18px;height:2px;
    background:rgba(11,18,32,.86);
    border-radius:2px;
    transform-origin:center;
  }
  .nav-close__x::before{transform:translate(-50%,-50%) rotate(45deg)}
  .nav-close__x::after{transform:translate(-50%,-50%) rotate(-45deg)}

  /* Drawer links: reduce clutter (card section) */
  .nav-primary,.nav-actions{padding:.25rem 0}
  .nav-primary{
    margin:.35rem 1.05rem .35rem;
    border:1px solid rgba(15,23,42,.08);
    border-radius:var(--radius-lg);
    overflow:hidden;
    background:#fff;
    box-shadow:var(--shadow-sm);
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .nav-primary a{display:flex;align-items:center;justify-content:flex-start}
  .nav-primary a.nav-link--drawer-only{grid-column:1 / -1}
  .nav-primary a:nth-child(2n){border-left:1px solid rgba(15,23,42,.06)}
  .nav-actions{
    margin:0 1.05rem .2rem;
  }
  .nav-links a{
    border-bottom:1px solid rgba(15,23,42,.06);
  }
  .nav-primary a:last-child{border-bottom:0}
}

/* Mobile scroll stability */
.site-header{will-change:transform}
@media (max-width:767px){
  .nav-links{-webkit-overflow-scrolling:touch}
}

/* Drawer footer: informative + fills empty space */
.nav-drawer-footer{padding:1rem 1.05rem 0}
.nav-drawer-cards{
  display:grid;
  grid-template-columns:1fr;
  gap:.75rem;
}
.nav-drawer-card{
  background:linear-gradient(180deg,#fff,#fbfbfc);
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:1rem 1rem 1.05rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
}
.nav-drawer-card strong{font-weight:950;letter-spacing:-.01em}
.nav-drawer-card span{color:var(--muted);font-weight:750;font-size:.92rem;line-height:1.35}
.nav-drawer-hours__list{
  margin:.1rem 0 .15rem;
  padding:0 0 0 1rem;
  color:var(--muted);
  font-weight:750;
  font-size:.92rem;
  line-height:1.35;
}
.nav-drawer-hours__list li{margin:.15rem 0}
.nav-drawer-phone{display:inline-flex;align-items:center;font-weight:950;color:var(--red)}
.nav-drawer-phone:hover{color:var(--red-dark)}
.nav-drawer-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}
.nav-drawer-pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.55rem .8rem;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:#fff;
  font-weight:900;
  font-size:.9rem;
}
.nav-drawer-pill:hover{background:#f8fafc}
.nav-drawer-card--cta{border-color:rgba(225,29,72,.18)}

/* Legal / policy pages */
.prose-static{
  max-width:48rem;
  margin:0 auto;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
  padding:1.25rem 1.15rem 1.35rem;
  width:100%;
}
@media (min-width:640px){.prose-static{padding:1.55rem 1.6rem 1.7rem}}
.page-section .app-shell{min-width:0}
.page-section .prose-static{overflow:hidden}
.prose-static h1{margin:.15rem 0 .55rem;font-size:clamp(1.55rem,1.1vw+1.2rem,2.1rem);letter-spacing:-.02em;font-weight:950}
.prose-static h2{margin:1.1rem 0 .4rem;font-size:1.1rem;font-weight:950;letter-spacing:-.01em}
.prose-static p{margin:.4rem 0;color:var(--text);line-height:1.6}
.prose-static .muted{color:var(--muted)}
.prose-static .small{font-size:.92rem}
.prose-static a.small.muted{
  display:inline-flex!important;
  align-items:center;
  gap:.45rem;
  padding:.55rem .85rem;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#fff,#fbfbfc);
  box-shadow:0 10px 22px rgba(15,23,42,.06);
  margin-bottom:1rem!important;
}
.prose-static a.small.muted:hover{background:#f8fafc}
@media (min-width:768px){
  .nav-burger{display:none!important}
  .nav-backdrop{display:none!important}
  .nav-link--drawer-only{display:none!important}
}

/* Prevent background scroll when drawer open */
body.nav-drawer-open{overflow:hidden}

/* Safer spacing for fixed drawer on iOS */
@supports (padding: max(0px)){
  @media (max-width:767px){
    .nav-links{
      padding-top:max(2.7rem,env(safe-area-inset-top,0px));
      padding-bottom:calc(1.1rem + env(safe-area-inset-bottom,0px));
    }
  }
}

/* Buttons */
.btn-chilli{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;
  padding:.75rem 1.1rem;
  border-radius:1rem;
  border:1px solid transparent;
  background:var(--red);
  color:#fff;
  font-weight:900;
  letter-spacing:-.01em;
  box-shadow:0 10px 22px rgba(225,29,72,.18);
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, filter .18s ease;
}
.btn-chilli:hover{background:var(--red-dark);color:#fff}
.btn-chilli:active{transform:translateY(1px) scale(.99);filter:saturate(1.04)}
.btn-chilli:focus-visible{outline:3px solid rgba(225,29,72,.25);outline-offset:2px}
.btn-chilli--sm{min-height:40px;padding:.55rem .85rem;font-size:.9rem;box-shadow:none}
.btn-chilli--compact{min-height:40px;padding:.55rem .85rem;font-size:.9rem;box-shadow:none}
.btn-hero-outline{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;padding:.75rem 1.1rem;border-radius:1rem;
  border:1.5px solid rgba(255,255,255,.75);
  background:transparent;color:#fff;font-weight:900;
  transition:transform .18s ease, background-color .18s ease, border-color .18s ease;
}
.btn-hero-outline:hover{background:rgba(255,255,255,.10)}
.btn-hero-outline:active{transform:translateY(1px) scale(.99)}
/* Light hero (hero-panel) secondary */
.btn-hero-panel-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:.7rem 1.15rem;
  border-radius:var(--radius-md);
  border:1.5px solid var(--border-2);
  background:var(--surface);
  color:var(--text);
  font-weight:850;
  font-size:.95rem;
  text-decoration:none;
  transition:background var(--dl-duration) var(--dl-ease),border-color var(--dl-duration) var(--dl-ease),transform .12s ease;
}
.btn-hero-panel-secondary:hover{background:var(--surface-2);border-color:rgba(15,23,42,.2)}
.btn-hero-panel-secondary:active{transform:translateY(1px)}
.btn-hero-panel-secondary:focus-visible{outline:3px solid rgba(225,29,72,.2);outline-offset:2px}
.btn-outline-red{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:44px;padding:.75rem 1.1rem;border-radius:1rem;
  border:2px solid var(--red);background:#fff;color:var(--red);font-weight:900;
  transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease;
}
.btn-outline-red:hover{background:rgba(225,29,72,.06)}
.btn-outline-red:active{transform:translateY(1px) scale(.99)}
.btn{display:inline-flex;align-items:center;justify-content:center}
.btn-ghost,.btn.btn-ghost{
  min-height:40px;padding:.5rem .85rem;border-radius:.9rem;
  border:1px solid var(--border);background:#fff;color:var(--text);font-weight:800;
  transition:transform .18s ease, background-color .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.btn-ghost:hover{background:#f8fafc}
.btn-ghost:active{transform:translateY(1px) scale(.99)}

/* Forms */
label{display:block;font-weight:800;color:var(--text);font-size:.95rem}
input:not([type=checkbox]):not([type=radio]),select,textarea{
  width:100%;
  min-height:48px;
  padding:.75rem .95rem;
  border-radius:1.05rem;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  font:inherit;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
  transition:border-color .2s var(--ease-smooth),box-shadow .2s var(--ease-smooth),background-color .2s var(--ease-smooth);
}
input:-webkit-autofill,
select:-webkit-autofill,
textarea:-webkit-autofill{
  -webkit-box-shadow:0 0 0 32px #fff inset!important;
}
textarea{min-height:120px;resize:vertical}
input:focus,select:focus,textarea:focus{
  outline:3px solid rgba(225,29,72,.16);
  outline-offset:2px;
  border-color:rgba(225,29,72,.35);
  box-shadow:0 4px 18px rgba(225,29,72,.08);
}
.form-grid{display:grid;gap:.85rem}
.form-grid-wide{grid-template-columns:1fr}
@media (min-width:768px){
  .form-grid-wide{grid-template-columns:repeat(2,minmax(0,1fr))}
  .form-grid-wide .full-width{grid-column:1/-1}
}

/* Page rhythm */
.page-section{padding:2rem 0}
@media (min-width:768px){.page-section{padding:2.75rem 0}}
.page-title{margin:0 0 .5rem;font-size:var(--fs-title);font-weight:950;letter-spacing:-.02em;line-height:1.15}
.page-title--tight{margin-bottom:.35rem}
.page-lead{margin:0 0 1.25rem;color:var(--muted)}
.page-lead--tight{margin-bottom:.75rem}
.small{font-size:.875rem}
.muted{color:var(--muted)}
.error{color:var(--red-dark);font-weight:800}
.flash.ok{
  background:rgba(16,185,129,.12);
  border:1px solid rgba(16,185,129,.25);
  color:#065f46;
  padding:.85rem 1rem;border-radius:1rem;
}

/* Cards */
.card-surface{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  transition:box-shadow .22s var(--ease-smooth),border-color .22s var(--ease-smooth),transform .22s var(--ease-smooth);
}

/* Apple-like separators inside cards/tables */
.card-surface hr{
  border:0;
  height:1px;
  background:rgba(15,23,42,.08);
}

/* Home hero — light editorial card (split layout; replaces dark full-bleed banner) */
.hero-panel{
  position:relative;
  padding:var(--dl-space-5) 0 var(--dl-space-4);
  background:var(--bg);
  color:var(--text);
}
.hero-panel__card{
  display:flex;
  flex-direction:column;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.hero-panel__visual{
  order:-1;
  position:relative;
  min-height:11.5rem;
  background:linear-gradient(145deg,#fff7ed,#fff1f2 45%,#fef9c3);
}
.hero-panel--has-photo .hero-panel__visual{
  min-height:0;
  background:#f1f5f9;
}
.hero-panel__photo-frame{
  margin:0;
  aspect-ratio:16/11;
  max-height:min(52vh,420px);
  overflow:hidden;
}
@media (min-width:900px){
  .hero-panel__photo-frame{
    aspect-ratio:auto;
    height:100%;
    min-height:100%;
    max-height:none;
  }
}
.hero-panel__photo{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.hero-panel__abstract{
  position:absolute;
  inset:0;
  overflow:hidden;
}
.hero-panel__abstract-blob{
  position:absolute;
  border-radius:50%;
  filter:blur(40px);
  opacity:.85;
  pointer-events:none;
}
.hero-panel__abstract-blob--a{
  width:70%;
  height:70%;
  left:-15%;
  top:-20%;
  background:radial-gradient(circle,rgba(225,29,72,.35),transparent 65%);
}
.hero-panel__abstract-blob--b{
  width:55%;
  height:55%;
  right:-10%;
  bottom:-5%;
  background:radial-gradient(circle,rgba(245,158,11,.4),transparent 60%);
}
.hero-panel__abstract-blob--c{
  width:40%;
  height:40%;
  left:35%;
  bottom:10%;
  background:radial-gradient(circle,rgba(225,29,72,.2),transparent 70%);
  filter:blur(28px);
}

.hero-panel__body{
  order:0;
  padding:var(--dl-space-6) var(--dl-space-4) var(--dl-space-5);
}
@media (min-width:640px){
  .hero-panel__body{padding:var(--dl-space-8) var(--dl-space-6) var(--dl-space-6)}
}

@media (min-width:900px){
  .hero-panel__card{
    display:grid;
    grid-template-columns:minmax(0,1.05fr) minmax(0,0.95fr);
    grid-template-rows:minmax(22rem,1fr);
    align-items:stretch;
  }
  .hero-panel__visual{
    order:2;
    min-height:100%;
  }
  .hero-panel__body{
    order:1;
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:var(--dl-space-8);
  }
  .hero-panel__photo-frame{
    height:100%;
    max-height:none;
  }
}

.hero-panel__eyebrow{
  margin:0 0 var(--dl-space-3);
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--red-dark);
}
.hero-panel__title{
  margin:0 0 var(--dl-space-3);
  font-size:clamp(1.75rem,.85rem + 3vw,2.85rem);
  font-weight:950;
  letter-spacing:-.035em;
  line-height:1.08;
  color:var(--text);
}
.hero-panel__lead{
  margin:0 0 var(--dl-space-5);
  font-size:clamp(1rem,.15vw + .94rem,1.125rem);
  line-height:1.6;
  color:var(--muted);
  font-weight:500;
  max-width:36rem;
}

.hero-panel__ticks{
  margin:0 0 var(--dl-space-5);
  padding:0;
  list-style:none;
  display:grid;
  gap:.45rem;
  font-size:.875rem;
  font-weight:650;
  color:#334155;
}
.hero-panel__ticks li{
  position:relative;
  padding-left:1.15rem;
}
.hero-panel__ticks li::before{
  content:"";
  position:absolute;
  left:0;
  top:.45em;
  width:.35rem;
  height:.35rem;
  border-radius:50%;
  background:linear-gradient(135deg,var(--red),#fb7185);
}

.hero-panel__actions{
  display:flex;
  flex-direction:column;
  gap:var(--dl-space-3);
  margin-bottom:var(--dl-space-5);
}
@media (min-width:480px){
  .hero-panel__actions{
    flex-direction:row;
    flex-wrap:wrap;
    align-items:center;
  }
}
.hero-panel__btn-primary{
  width:100%;
  min-height:48px;
  justify-content:center;
  border-radius:var(--radius-md);
  font-weight:900;
  box-shadow:0 8px 24px rgba(225,29,72,.2);
}
.hero-panel__actions .btn-hero-panel-secondary{
  width:100%;
  min-height:48px;
  justify-content:center;
}
@media (min-width:480px){
  .hero-panel__btn-primary{width:auto;min-width:10.5rem}
  .hero-panel__actions .btn-hero-panel-secondary{width:auto;min-width:9.5rem}
}

.hero-panel__fineprint{
  margin:0;
  font-size:.78rem;
  line-height:1.45;
  color:var(--muted);
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:.25rem .4rem;
}
.hero-panel__tel{
  color:var(--text);
  font-weight:750;
  text-decoration:none;
  border-bottom:1px solid rgba(15,23,42,.2);
}
.hero-panel__tel:hover{border-bottom-color:var(--red)}
.hero-panel__dot{opacity:.45}

@media (prefers-reduced-motion:reduce){
  .btn-hero-panel-secondary:active,.hero-panel__btn-primary:active{transform:none}
}

/* Search strip + quick actions */
.search-strip--vercel,.quick-strip--vercel{
  background:#fff;
  border-bottom:1px solid rgba(15,23,42,.08);
}
.search-strip--vercel{padding:1rem 0 1.15rem}
.search-strip__shell{max-width:40rem;margin-inline:auto}
.search-form{display:flex;gap:.65rem;align-items:stretch;max-width:min(40rem,100%);margin:0 auto}
.search-form .wrap{position:relative;flex:1;min-width:0}
.search-form .wrap svg{position:absolute;left:.95rem;top:50%;transform:translateY(-50%);width:1.1rem;height:1.1rem;color:#94a3b8;pointer-events:none}
.search-form input[type=search]{padding-left:2.75rem;background:#f8fafc}
.search-form__btn{border-radius:1rem;min-width:7rem}
@media (max-width:639px){
  .search-form{flex-direction:column}
  .search-form__btn{width:100%}
}
.quick-strip--vercel{padding:1rem 0 1.5rem}
.quick-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}
@media (max-width:420px){.quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.qa-item{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.35rem;
  min-height:4.75rem;
  padding:.75rem .5rem;
  border:1px solid var(--border);
  border-radius:1rem;
  background:#fff;
  box-shadow:var(--shadow-sm);
  font-weight:900;
  font-size:.8rem;
  transition:var(--card-transition);
  touch-action:manipulation;
}
.qa-icon{width:1.35rem;height:1.35rem}
@media (hover:hover) and (pointer:fine){
  .qa-item:hover{border-color:rgba(225,29,72,.25);transform:var(--card-lift-sm);box-shadow:var(--shadow-md)}
}

/* Horizontal scroll helpers */
.u-hscroll-hide-scrollbar{scrollbar-width:none}
.u-hscroll-hide-scrollbar::-webkit-scrollbar{display:none}

/* Sections */
.home-section--slate{background:#f8fafc}
.home-section--white{background:#fff}
.home-section--muted{background:#f8fafc}
.home-section{padding:2rem 0}
@media (min-width:768px){.home-section{padding:2.75rem 0}}
.home-section__head{max-width:48rem}
.home-eyebrow{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--red)}
.home-eyebrow--combo-deal{
  color:#9a3412;
  background:linear-gradient(135deg,rgba(254,243,199,.95),rgba(255,237,213,.75));
  border:1px solid rgba(234,88,12,.22);
  border-radius:999px;
  padding:.28rem .65rem;
  letter-spacing:.1em;
}
.home-section--combo-deals{
  background:linear-gradient(180deg,#fffbf5 0%,#fff 38%,#f8fafc 100%);
  border-block:1px solid rgba(15,23,42,.06);
}
.home-section__title{margin:.5rem 0 .5rem;font-size:var(--fs-title);font-weight:950;letter-spacing:-.02em;line-height:1.15}
.home-section__lead{margin:0 0 1rem;color:var(--muted)}

/* Home — order type cards: always 1×3 row (phone → desktop) */
.home-order-types .home-hscroll--order-types{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.5rem .4rem;
  margin-top:.75rem;
  align-items:stretch;
}
@media (min-width:400px){
  .home-order-types .home-hscroll--order-types{gap:.55rem .55rem}
}
@media (min-width:640px){
  .home-order-types .home-hscroll--order-types{gap:1rem}
}
.home-ot-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:.65rem .45rem .75rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
  min-height:0;
  min-height:104px;
  transition:var(--card-transition);
  touch-action:manipulation;
}
@media (min-width:400px){
  .home-ot-card{padding:.75rem .55rem .85rem;min-height:112px}
}
@media (min-width:640px){
  .home-ot-card{
    padding:1rem 1rem 1.05rem;
    gap:.55rem;
    min-height:126px;
  }
}
@media (hover:hover) and (pointer:fine){
  .home-ot-card:hover{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.14);
  }
}
.home-ot-card__icon{
  width:32px;height:32px;
  border-radius:12px;
  display:grid;place-items:center;
  background:var(--surface-2);
  color:var(--text);
}
.home-ot-card__icon svg{width:18px;height:18px}
@media (min-width:400px){
  .home-ot-card__icon{width:36px;height:36px;border-radius:13px}
  .home-ot-card__icon svg{width:20px;height:20px}
}
@media (min-width:640px){
  .home-ot-card__icon{width:44px;height:44px;border-radius:14px}
  .home-ot-card__icon svg{width:28px;height:28px}
}
.home-ot-card__label{
  font-weight:950;
  letter-spacing:-.01em;
  font-size:.78rem;
  line-height:1.15;
}
@media (min-width:400px){.home-ot-card__label{font-size:.85rem}}
@media (min-width:640px){.home-ot-card__label{font-size:1rem}}
.home-ot-card__sub{
  color:var(--muted);
  font-weight:700;
  font-size:.68rem;
  line-height:1.2;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
@media (min-width:400px){.home-ot-card__sub{font-size:.72rem}}
@media (min-width:640px){
  .home-ot-card__sub{font-size:.92rem;-webkit-line-clamp:3;line-height:1.25}
}
.home-ot-card--delivery .home-ot-card__icon{background:rgba(225,29,72,.10);color:var(--red)}
.home-ot-card--takeaway .home-ot-card__icon{background:rgba(245,158,11,.16);color:#b45309}
.home-ot-card--dinein .home-ot-card__icon{background:rgba(245,158,11,.16);color:#b45309}

.home-section__title--center{text-align:left}
@media (min-width:640px){.home-section__title--center{text-align:left}}

.section-cta{margin-top:1rem}
.section-cta--left{display:flex;justify-content:flex-start}

/* Home — category strip (legacy pill chips — unused on home) */
.cat-strip{
  padding:1.25rem 0;
  background:transparent;
}
.cat-strip-title{
  margin:0 0 .75rem;
  font-size:1.5rem;
  font-weight:950;
  letter-spacing:-.02em;
}
.cat-strip-scroll{
  display:flex;
  gap:.6rem;
  overflow:auto;
  padding-bottom:.25rem;
}
.cat-strip-chip{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.55rem .85rem;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 1px 1px rgba(15,23,42,.03);
  font-weight:900;
  color:var(--text);
  white-space:nowrap;
}
.cat-strip-chip:hover{background:#f8fafc;border-color:rgba(15,23,42,.14)}
.cat-strip-chip__icon{font-size:1rem;line-height:1}
.cat-strip-chip__label{font-size:.95rem;line-height:1}

/* Home — “What’s on your mind?” style category row (Swiggy-like) */
.cat-strip--mind{
  background:#fff;
  padding:var(--dl-space-6) 0 var(--dl-space-5);
  border-top:1px solid rgba(15,23,42,.06);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.cat-strip-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:var(--dl-space-4);
  margin-bottom:var(--dl-space-5);
}
.cat-strip-title--mind{
  margin:0;
  font-size:clamp(1.2rem,1vw + 1rem,1.45rem);
  font-weight:950;
  letter-spacing:-.03em;
  color:var(--text);
  line-height:1.2;
}
.cat-strip-nav{
  display:none;
  align-items:center;
  gap:.35rem;
  flex-shrink:0;
}
@media (min-width:768px){
  .cat-strip-nav{display:flex}
}
.cat-strip-nav__btn{
  width:38px;
  height:38px;
  padding:0;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background:#f3f4f6;
  color:#374151;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:background var(--dl-duration) var(--dl-ease),border-color var(--dl-duration) var(--dl-ease);
}
.cat-strip-nav__btn:hover{background:#e5e7eb;border-color:rgba(15,23,42,.14)}
.cat-strip-nav__btn:focus-visible{
  outline:2px solid rgba(225,29,72,.45);
  outline-offset:2px;
}
.cat-strip-scroll--mind{
  display:flex;
  gap:clamp(.75rem,2vw,1.35rem);
  overflow-x:auto;
  overflow-y:hidden;
  padding:0 0 var(--dl-space-2);
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
  scroll-padding-inline:var(--pad);
}
.cat-mind-card{
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  width:var(--cat-mind-w,5.75rem);
  min-width:var(--cat-mind-w,5.75rem);
  text-align:center;
  text-decoration:none;
  color:#1f2937;
  scroll-snap-align:start;
  transition:var(--card-transition);
  -webkit-tap-highlight-color:transparent;
}
@media (min-width:480px){
  .cat-mind-card{
    --cat-mind-w:6.25rem;
  }
}
@media (min-width:1024px){
  .cat-mind-card{
    --cat-mind-w:6.75rem;
  }
}
@media (hover:hover) and (pointer:fine){
  .cat-mind-card:hover{
    transform:var(--card-lift-sm);
  }
}
.cat-mind-card:hover .cat-mind-card__label{
  color:var(--red-dark);
}
.cat-mind-card__plate{
  width:var(--cat-mind-w,5.75rem);
  height:var(--cat-mind-w,5.75rem);
  border-radius:50%;
  background:#fff;
  overflow:hidden;
  display:grid;
  place-items:center;
  box-shadow:
    0 4px 14px rgba(15,23,42,.08),
    0 12px 28px rgba(15,23,42,.06);
  margin-bottom:.5rem;
}
.cat-mind-card__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.cat-mind-card__label{
  font-size:.8rem;
  font-weight:650;
  line-height:1.25;
  max-width:7.5rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:#374151;
  transition:color var(--dl-duration) var(--dl-ease);
}
@media (min-width:768px){
  .cat-mind-card__label{font-size:.825rem}
}

@media (prefers-reduced-motion:reduce){
  .cat-mind-card,.cat-mind-card__label{transition:none}
  .cat-mind-card:hover{transform:none}
}

/* Card strips */
.premium-product-scroll,.home-hscroll{display:flex;gap:1rem;overflow:auto;padding-bottom:.25rem;scroll-snap-type:x mandatory}
.premium-product-scroll > *, .home-hscroll > *{scroll-snap-align:start}
.home-hscroll--combo-cards{gap:1.05rem;padding-bottom:.4rem;scroll-padding-inline:var(--pad,1rem)}
.home-hscroll--combo-cards .home-combo-card{flex:0 0 auto}

/* Home offer cards */
.home-offer-card{
  min-width:min(86vw,340px);
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:1.1rem 1.1rem 1rem;
  overflow:hidden;
  transition:var(--card-transition);
}
.home-offer-card__tag{margin:0;color:var(--muted);font-weight:900;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em}
.home-offer-card h3{margin:.5rem 0 .5rem;font-size:1.1rem;font-weight:950}
.home-offer-card__codes{margin:0;display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.home-offer-card__code{font-weight:950;background:#0b1220;color:#fff;border-radius:999px;padding:.25rem .6rem;font-size:.85rem}
.home-offer-card__cta{display:inline-block;margin-top:.85rem;font-weight:950;color:var(--red)}

/* Home feature cards */
.home-feature-card{
  min-width:min(86vw,320px);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-height:0;
  transition:var(--card-transition);
}
.home-feature-card__media{aspect-ratio:4/3;background:var(--surface-2)}
.home-feature-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.home-feature-card__body{padding:1rem 1rem 1.1rem}
.home-feature-card__body h3{margin:0 0 .35rem;font-weight:950}
.home-feature-card__desc{margin:0 0 .6rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.home-feature-card__price{margin:0;font-weight:950;color:var(--red)}

/* Menu page */
.search-strip--menu-top{padding:1.25rem 0;background:#fff;border-bottom:1px solid rgba(15,23,42,.08)}
.cat-strip--menu-filter{padding:.75rem 0;background:#fff;border-bottom:1px solid rgba(15,23,42,.06)}
.cat-strip__shell{max-width:var(--max)}
.cat-hscroll{display:flex;gap:.5rem;overflow:auto}
.cat-pill-link{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.55rem .85rem;border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:900;font-size:.9rem;color:var(--text);
}
.cat-pill-link:hover{background:#f8fafc}
.card-grid{display:grid;grid-template-columns:1fr;gap:1rem;align-items:stretch}
@media (min-width:640px){.card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width:1024px){.card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.dish-card{
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  height:100%;
  min-width:0;
  transition:var(--card-transition);
  -webkit-tap-highlight-color:transparent;
}
.dish-img{aspect-ratio:4/3;width:100%;object-fit:cover;background:var(--surface-2);display:block}
.dish-img--placeholder{aspect-ratio:4/3;background:
  radial-gradient(120px 80px at 30% 30%, rgba(0,0,0,.05), transparent 60%),
  radial-gradient(140px 90px at 70% 60%, rgba(0,0,0,.04), transparent 60%),
  linear-gradient(180deg, #f9fafb, #eef2f7);
}
.dish-body{padding:1rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.45rem;flex:1 1 auto;min-height:0}
.dish-body,
.dish-meta,
.dish-body__head,
.dish-body__title,
.dish-desc,
.dish-stepper-wrap{
  min-width:0;
}
.dish-body__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.6rem;
}
.dish-body__title{
  margin:0;
  font-size:1.05rem;
  font-weight:950;
  line-height:1.2;
  letter-spacing:-.01em;
}
.dish-body h3{
  line-height:1.2;
}
.dish-fav-form{margin:0}
.fav-btn{
  width:36px;height:36px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:950;
  line-height:1;
  cursor:pointer;
  flex-shrink:0;
}
.fav-btn.is-on{border-color:rgba(225,29,72,.25);color:var(--red)}
.dish-body h3{margin:0;font-size:1.05rem;font-weight:950}
.dish-desc{margin:0;color:var(--muted);font-size:.9rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dish-meta{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.dish-meta__left{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.dish-stepper-wrap{display:flex;justify-content:flex-end;min-width:0}
.price{font-weight:950;color:var(--red);font-size:1.05rem}
.prep-chip{font-size:.75rem;font-weight:900;background:#f1f5f9;border-radius:999px;padding:.25rem .55rem;color:var(--text)}

.cat-pill{
  display:inline-flex;align-items:center;align-self:flex-start;
  font-size:.68rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase;
  padding:.22rem .5rem;border-radius:999px;
  background:#f1f5f9;color:#475569;border:1px solid rgba(15,23,42,.08);
}
.cat-pill--combo{
  background:linear-gradient(135deg,#fff7ed,#ffedd5);
  border-color:rgba(234,88,12,.28);
  color:#9a3412;
}

.menu-combo-intro{margin:-.25rem 0 1rem;max-width:42rem;line-height:1.45}
.menu-combo-grid .menu-combo-card{
  border:1px solid rgba(15,23,42,.1);
  background:linear-gradient(180deg,#fffefb,#fff);
  box-shadow:0 10px 28px rgba(15,23,42,.07);
  transition:var(--card-transition);
}
.menu-page .dish-card.menu-combo-card{
  display:flex;
  flex-direction:column;
}
.menu-page .menu-combo-card .dish-img,
.menu-page .menu-combo-card .dish-img--placeholder{
  width:100%;
  aspect-ratio:4/3;
  height:auto;
}
.menu-combo-card__bar{
  display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  padding:.45rem .65rem;
  background:linear-gradient(90deg,rgba(255,247,237,.95),rgba(255,255,255,.5));
  border-bottom:1px solid rgba(234,88,12,.14);
}
.menu-combo-card__kind{
  font-size:.68rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:#9a3412;
}
.menu-combo-card__deal{
  font-size:.65rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg,#ea580c,#e11d48);
  padding:.18rem .45rem;border-radius:999px;
}
.menu-combo-card__detail{
  margin:.15rem 0 .35rem;
  padding:.55rem .65rem .6rem;
  border-radius:var(--radius-sm);
  background:rgba(248,250,252,.9);
  border:1px solid rgba(15,23,42,.07);
}
.menu-combo-card__detail-h{
  margin:0 0 .35rem;
  font-size:.65rem;font-weight:950;letter-spacing:.1em;text-transform:uppercase;color:#64748b;
}
.menu-combo-card__steps{
  margin:0;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:.3rem;
}
.menu-combo-card__steps li{
  display:flex;align-items:baseline;gap:.4rem;
  font-size:.82rem;line-height:1.35;
}
.menu-combo-card__n{
  flex:0 0 1.2rem;
  font-size:.7rem;font-weight:950;
  color:#c2410c;
  background:#ffedd5;border-radius:6px;
  text-align:center;line-height:1.2rem;
}
.menu-combo-card__includes{
  margin:0;padding-left:1rem;
  font-size:.82rem;line-height:1.4;
}
.menu-combo-card__hint{margin:0;font-size:.8rem;line-height:1.35}
.dish-meta--combo{align-items:flex-end}

/* Phone view: compact “Apple list card” style (menu page only) */
@media (max-width:520px){
  .menu-page .card-grid{gap:.75rem}
  .menu-page .dish-card:not(.menu-combo-card){
    display:grid;
    grid-template-columns:104px minmax(0,1fr);
    align-items:stretch;
  }
  .menu-page .dish-img,
  .menu-page .dish-img--placeholder{
    aspect-ratio:1/1;
    width:104px;
    height:104px;
  }
  .menu-page .menu-combo-card .dish-img,
  .menu-page .menu-combo-card .dish-img--placeholder{
    width:100%;
    aspect-ratio:4/3;
    height:auto;
  }
  .menu-page .dish-body{
    padding:.85rem .9rem .9rem;
    gap:.35rem;
  }
  .menu-page .dish-body h3,
  .menu-page .dish-body__title{
    font-size:1rem;
  }
  .menu-page .dish-desc{-webkit-line-clamp:2;font-size:.875rem}
  .menu-page .dish-meta{gap:.5rem .65rem}
  .menu-page .btn-chilli--sm{min-height:38px;padding:.5rem .75rem}
  .menu-page .stepper-btn{width:36px;height:36px}
  .menu-page .stepper-input{width:40px;min-height:36px}
}

@media (max-width:360px){
  .menu-page .dish-card:not(.menu-combo-card){grid-template-columns:96px minmax(0,1fr)}
  .menu-page .dish-card:not(.menu-combo-card) .dish-img,
  .menu-page .dish-card:not(.menu-combo-card) .dish-img--placeholder{width:96px;height:96px}
  .menu-page .dish-body{padding:.75rem .8rem .8rem}
  .menu-page .dish-desc{-webkit-line-clamp:2;font-size:.85rem}
  .menu-page .price{font-size:1rem}
}

/* Stepper alignment (mobile/desktop consistent) */
.dish-qty-update{display:inline-flex;align-items:center;gap:.35rem}
.stepper-btn{
  width:40px;height:40px;border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:950;
  cursor:pointer;
}
.stepper-btn:active{background:#f8fafc}
.stepper-input{
  width:44px;min-height:40px;
  text-align:center;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  font-weight:950;
  padding:0;
}

/* Home promo (legacy restore) + home combo deal cards */
.home-promo-card{
  min-width:min(86vw,340px);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:var(--card-transition);
}
.home-promo-card__media{position:relative;aspect-ratio:4/3;background:var(--surface-2)}
.home-promo-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.home-promo-card__badge{
  position:absolute;left:.75rem;top:.75rem;
  display:inline-flex;align-items:center;justify-content:center;
  height:28px;padding:0 .65rem;border-radius:999px;
  background:rgba(11,18,32,.82);
  color:#fff;font-weight:950;font-size:.78rem;letter-spacing:.12em;
}
.home-promo-card__price{
  position:absolute;right:.75rem;bottom:.75rem;
  display:inline-flex;align-items:center;justify-content:center;
  height:30px;padding:0 .7rem;border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,23,42,.12);
  color:var(--text);font-weight:950;
  box-shadow:0 8px 18px rgba(15,23,42,.12);
}
.home-promo-card__body{padding:1rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.45rem;flex:1 1 auto}
.home-promo-card__body h3{margin:0;font-weight:950}
.home-promo-card__desc{margin:0;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.home-promo-card__bundle{margin:0;color:var(--text);font-weight:750;font-size:.92rem}
.home-promo-card__prep{margin:0;color:var(--muted)}
.home-promo-card__actions{margin-top:auto}
.home-promo-card__actions .btn-chilli--compact{min-height:40px;padding:.55rem .85rem;border-radius:999px}
.home-promo-card__form{margin:0}

.home-combo-card{
  position:relative;
  min-width:min(88vw,360px);
  max-width:min(92vw,400px);
  border:1px solid rgba(15,23,42,.1);
  border-radius:calc(var(--radius-xl) + 2px);
  background:
    linear-gradient(160deg,rgba(255,255,255,.99),#fffef9) padding-box,
    linear-gradient(135deg,rgba(234,88,12,.4),rgba(225,29,72,.28),rgba(251,191,36,.35)) border-box;
  box-shadow:0 16px 40px rgba(15,23,42,.09),0 1px 0 rgba(255,255,255,.9) inset;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:var(--card-transition);
  -webkit-tap-highlight-color:transparent;
}
@media (hover:hover) and (pointer:fine){
  .home-combo-card:hover{
    transform:var(--card-lift-md);
    box-shadow:0 22px 48px rgba(15,23,42,.12),0 1px 0 rgba(255,255,255,.9) inset;
  }
}
.home-combo-card--pick{
  background:
    linear-gradient(160deg,rgba(255,255,255,.99),#f8fafc) padding-box,
    linear-gradient(135deg,rgba(59,130,246,.25),rgba(225,29,72,.3),rgba(245,158,11,.35)) border-box;
}
.home-combo-card__ribbon{
  position:absolute;
  top:.65rem;left:-2.25rem;
  z-index:3;
  width:9rem;
  padding:.28rem 0;
  text-align:center;
  font-size:.62rem;font-weight:950;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(90deg,#ea580c,#e11d48);
  transform:rotate(-42deg);
  box-shadow:0 4px 12px rgba(225,29,72,.35);
  pointer-events:none;
}
.home-combo-card__topbar{
  display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  padding:.55rem .85rem .5rem;
  background:linear-gradient(90deg,rgba(255,247,237,.95),rgba(255,255,255,.5));
  border-bottom:1px solid rgba(234,88,12,.14);
}
.home-combo-card__kind{
  font-size:.72rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;
  color:#9a3412;
}
.home-combo-card__deal-pill{
  font-size:.65rem;font-weight:950;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;
  background:linear-gradient(135deg,#0f172a,#334155);
  padding:.2rem .5rem;border-radius:999px;
}
.home-combo-card__media{
  position:relative;aspect-ratio:4/3;background:var(--surface-2);
}
.home-combo-card__media img{width:100%;height:100%;object-fit:cover;display:block}
.home-combo-card__price-stack{
  position:absolute;right:.65rem;bottom:.65rem;
  display:flex;flex-direction:column;align-items:flex-end;gap:.12rem;
}
.home-combo-card__price-tag{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:34px;padding:0 .85rem;border-radius:999px;
  background:linear-gradient(180deg,#fffef9,#fff7ed);
  border:1px solid rgba(234,88,12,.4);
  color:#9a3412;font-weight:950;font-size:1.05rem;
  box-shadow:0 10px 26px rgba(15,23,42,.16);
}
.home-combo-card__price-note{
  font-size:.62rem;font-weight:850;letter-spacing:.06em;text-transform:uppercase;
  color:rgba(15,23,42,.55);
  background:rgba(255,255,255,.92);
  padding:.12rem .45rem;border-radius:999px;
  border:1px solid rgba(15,23,42,.08);
}
.home-combo-card__body{
  padding:.9rem 1rem 1.1rem;
  display:flex;flex-direction:column;gap:.45rem;flex:1 1 auto;min-height:0;
}
.home-combo-card__meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}
.home-combo-card__prep{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.78rem;font-weight:800;color:#64748b;
}
.home-combo-card__prep-icon{font-size:.95rem;line-height:1;opacity:.85}
.home-combo-card__title{margin:0;font-weight:950;font-size:1.12rem;line-height:1.22;letter-spacing:-.02em;color:var(--text)}
.home-combo-card__summary{
  margin:0;font-size:.84rem;line-height:1.45;color:#475569;font-weight:600;
}
.home-combo-card__summary strong{color:#0f172a;font-weight:850}
.home-combo-card__desc{
  margin:0;color:var(--muted);font-size:.88rem;line-height:1.45;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.home-combo-card__detail{
  margin-top:.1rem;
  padding:.7rem .75rem .75rem;
  border-radius:var(--radius-md);
  background:linear-gradient(180deg,#f8fafc,rgba(255,255,255,.9));
  border:1px solid rgba(15,23,42,.09);
}
.home-combo-card__detail-h{
  margin:0 0 .5rem;
  font-size:.65rem;font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:#64748b;
}
.home-combo-card__steps--rich{
  display:flex;flex-direction:column;gap:.55rem;
}
.home-combo-card__step-block{
  padding:.5rem .55rem;
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.85);
  border:1px solid rgba(15,23,42,.07);
}
.home-combo-card__step-head{
  display:flex;align-items:center;gap:.45rem;margin-bottom:.35rem;
}
.home-combo-card__step-num{
  flex:0 0 1.4rem;height:1.4rem;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:950;
  background:linear-gradient(135deg,#fff7ed,#ffedd5);
  border:1px solid rgba(234,88,12,.28);
  color:#c2410c;
}
.home-combo-card__step-title{
  font-size:.88rem;font-weight:850;color:var(--text);
  line-height:1.25;
}
.home-combo-card__step-picks{
  margin:0 0 .25rem;
  font-size:.78rem;line-height:1.4;
  color:#334155;
}
.home-combo-card__step-picks-label{
  font-weight:800;color:#64748b;
  display:block;
  margin-bottom:.15rem;
  font-size:.68rem;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.home-combo-card__step-sub{
  margin:0;
  font-size:.72rem;font-weight:750;color:var(--muted);
}
.home-combo-card__includes{
  margin:0;padding-left:1.15rem;
  font-size:.86rem;line-height:1.5;color:var(--text);
}
.home-combo-card__includes li{margin:.18rem 0}
.home-combo-card__more{list-style:none;margin-left:-1.15rem;font-style:italic;color:var(--muted)!important}
.home-combo-card__hint{margin:.4rem 0 0;font-size:.78rem;line-height:1.4;color:#64748b}
.home-combo-card__foot{
  margin-top:auto;
  padding-top:.75rem;
  border-top:1px dashed rgba(15,23,42,.12);
  display:flex;
  flex-direction:column;
  gap:.65rem;
}
.home-combo-card__foot-price{
  display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;
}
.home-combo-card__foot-price-label{
  font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
}
.home-combo-card__foot-price-val{
  font-size:1.25rem;font-weight:950;color:var(--red-dark);
  letter-spacing:-.02em;
}
.home-combo-card__actions{width:100%}
.home-combo-card__actions .home-combo-card__btn{
  width:100%;justify-content:center;text-align:center;
  min-height:46px;border-radius:999px;font-weight:950;
  box-shadow:0 8px 22px rgba(225,29,72,.22);
}
.home-combo-card__form{margin:0}

.home-empty-combos{
  background:#fff;
  border:1px dashed rgba(15,23,42,.18);
  border-radius:var(--radius-lg);
  padding:1.25rem 1.15rem;
  display:flex;
  flex-direction:column;
  gap:.65rem;
  align-items:flex-start;
  box-shadow:var(--shadow-sm);
}
.home-empty-combos__icon{color:var(--muted)}
.home-empty-combos__title{margin:0;font-weight:950;letter-spacing:-.02em}

/* Offers/Featured — equalise vertical rhythm */
.home-offer-card,.home-feature-card{height:100%}
.home-offer-card{display:flex;flex-direction:column}
.home-offer-card__exp{color:var(--muted);font-weight:800;font-size:.9rem}
.home-offer-card__cta{margin-top:auto}
.home-feature-card__link{display:block;height:100%}
.home-feature-card__body{display:flex;flex-direction:column;min-height:0}
.home-feature-card__price{margin-top:auto}

/* Home — Book a table CTA (card, design tokens, responsive) */
.home-book-band{
  padding-block:var(--dl-space-6) var(--dl-space-5);
  background:linear-gradient(180deg,rgba(255,255,255,.5),transparent 40%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
@media (min-width:768px){
  .home-book-band{padding-block:var(--dl-section-y-md) var(--dl-space-6)}
}
.home-book-band__shell{
  max-width:min(var(--max),100%);
  margin-inline:auto;
}

.home-book-cta{
  position:relative;
  display:grid;
  grid-template-columns:1fr;
  gap:var(--dl-space-4);
  align-items:center;
  justify-items:center;
  text-align:center;
  padding:var(--dl-space-6) var(--dl-space-4);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md);
  overflow:hidden;
  transition:var(--card-transition);
}
.home-book-cta::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(100% 90% at 0% 0%,rgba(225,29,72,.09),transparent 55%),
    radial-gradient(90% 80% at 100% 100%,rgba(245,158,11,.11),transparent 52%);
  opacity:1;
}
@media (hover:hover) and (pointer:fine){
  .home-book-cta:hover{
    box-shadow:0 12px 40px rgba(15,23,42,.10);
    border-color:var(--border-2);
    transform:var(--card-lift-sm);
  }
}
.home-book-cta > *{position:relative;z-index:1}

.home-book-cta__mark{
  flex-shrink:0;
  width:3.25rem;
  height:3.25rem;
  border-radius:1.125rem;
  display:grid;
  place-items:center;
  background:linear-gradient(145deg,rgba(225,29,72,.14),rgba(245,158,11,.12));
  border:1px solid rgba(15,23,42,.08);
  color:var(--red-dark);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}
.home-book-cta__mark svg{
  width:1.5rem;
  height:1.5rem;
}

.home-book-cta__copy{
  min-width:0;
  max-width:var(--dl-max-prose);
}
.home-book-cta__title{
  margin:0 0 var(--dl-space-2);
  font-size:clamp(1.2rem,2.4vw,1.5rem);
  font-weight:950;
  letter-spacing:-.03em;
  line-height:var(--dl-leading-snug);
  color:var(--text);
}
.home-book-cta__lead{
  margin:0;
  font-size:var(--dl-text-sm);
  line-height:var(--dl-leading-relaxed);
  font-weight:650;
  color:var(--muted);
}
@media (min-width:480px){
  .home-book-cta__lead{font-size:var(--dl-text-base)}
}

.home-book-cta__action{
  width:100%;
  display:flex;
  justify-content:center;
}
.home-book-cta__btn{
  width:100%;
  max-width:18rem;
  min-height:48px;
  justify-content:center;
}

/* Tablet: icon + text on one row, button full width below */
@media (min-width:480px) and (max-width:767px){
  .home-book-cta{
    grid-template-columns:auto 1fr;
    grid-template-rows:auto auto;
    gap:var(--dl-space-4) var(--dl-space-5);
    justify-items:stretch;
    text-align:left;
    padding:var(--dl-space-6);
  }
  .home-book-cta__mark{grid-column:1;grid-row:1;justify-self:start;align-self:start;margin-top:.15rem}
  .home-book-cta__copy{grid-column:2;grid-row:1}
  .home-book-cta__action{grid-column:1/-1;grid-row:2;width:100%}
  .home-book-cta__btn{max-width:none}
}

/* Desktop: one bar — icon | copy | button */
@media (min-width:768px){
  .home-book-cta{
    grid-template-columns:auto minmax(0,1fr) auto;
    gap:var(--dl-space-5) var(--dl-space-8);
    align-items:center;
    justify-items:stretch;
    text-align:left;
    padding:var(--dl-space-6) var(--dl-space-8);
  }
  .home-book-cta__mark{align-self:center}
  .home-book-cta__copy{max-width:none}
  .home-book-cta__title{margin-bottom:var(--dl-space-2)}
  .home-book-cta__action{
    width:auto;
    justify-content:flex-end;
    align-self:center;
  }
  .home-book-cta__btn{
    width:auto;
    max-width:none;
    min-width:11rem;
  }
}

@media (prefers-reduced-motion:reduce){
  .home-book-cta{transition:none}
}

.home-why-grid{
  margin-top:1rem;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.65rem .75rem;
}
@media (min-width:1024px){.home-why-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem}}
.home-why-item{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:.85rem .8rem .95rem;
  display:flex;
  flex-direction:column;
  gap:.25rem;
  min-width:0;
}
@media (min-width:640px){
  .home-why-item{padding:1rem 1rem 1.05rem}
}
.home-why-item__icon{
  width:40px;height:40px;
  border-radius:14px;
  display:grid;place-items:center;
  background:var(--surface-2);
  font-weight:950;
}
.home-why-item strong{font-weight:950}
.home-why-item span{color:var(--muted);font-weight:700}

.home-stats{
  background:#fff;
  border-top:1px solid rgba(15,23,42,.06);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.home-stats__grid{
  padding:1.1rem 0;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.5rem;
  text-align:center;
}
.home-stats__num{display:block;font-weight:950;font-size:1.3rem;letter-spacing:-.02em}
.home-stats__lbl{display:block;color:var(--muted);font-weight:750;font-size:.9rem}
@media (min-width:768px){
  .home-stats__grid{padding:1.35rem 0}
  .home-stats__num{font-size:1.55rem}
}

/* Pre-footer — one panel: intro left, stacked cards right (all breakpoints aligned) */
.pre-footer{
  margin-top:1.25rem;
  padding:1.25rem 0 1.5rem;
  background:
    radial-gradient(720px 280px at 8% 0%, rgba(225,29,72,.09), transparent 58%),
    radial-gradient(720px 280px at 92% 40%, rgba(245,158,11,.11), transparent 58%),
    linear-gradient(180deg,#f5f5f7,#fbfbfc);
  border-top:1px solid rgba(15,23,42,.06);
}
.pre-footer__shell{max-width:min(var(--max),100%)}
.pre-footer__panel{
  display:grid;
  grid-template-columns:1fr;
  gap:1.25rem;
  align-items:start;
  padding:1.15rem 1.1rem 1.2rem;
  border-radius:var(--radius-xl);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:var(--shadow-sm);
}
@media (min-width:900px){
  .pre-footer__panel{
    grid-template-columns:minmax(0,1.08fr) minmax(0,.95fr);
    gap:0 2.25rem;
    padding:1.5rem 1.5rem 1.55rem;
    align-items:stretch;
  }
  /* Left column matches right height — centre intro so no “dead” gap under CTA */
  .pre-footer__intro{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-self:stretch;
    min-height:100%;
    padding-right:1.75rem;
    border-right:1px solid rgba(15,23,42,.08);
  }
}
.pre-footer__eyebrow{
  margin:0 0 .4rem;
  font-size:.72rem;
  font-weight:950;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--red);
}
.pre-footer__title{
  margin:0 0 .45rem;
  font-size:clamp(1.4rem,.55vw+1.15rem,1.85rem);
  font-weight:950;
  letter-spacing:-.02em;
  line-height:1.15;
}
.pre-footer__lead{
  margin:0 0 1rem;
  color:var(--muted);
  font-weight:750;
  line-height:1.55;
  max-width:36rem;
}
@media (min-width:900px){
  .pre-footer__lead{margin-bottom:1.15rem;max-width:28rem}
}
.pre-footer__cta{
  width:100%;
  max-width:16rem;
}
@media (min-width:900px){
  .pre-footer__cta{max-width:15rem}
}
@media (max-width:899px){
  .pre-footer__cta{max-width:none}
}
.btn-chilli--on-dark{box-shadow:0 14px 34px rgba(225,29,72,.22)}

.pre-footer__cards{
  display:flex;
  flex-direction:column;
  gap:.65rem;
  min-width:0;
}
.pre-footer-card{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  padding:.85rem .95rem;
  border-radius:var(--radius-lg);
  background:var(--surface-2);
  border:1px solid rgba(15,23,42,.08);
  transition:var(--card-transition);
}
.pre-footer-card--link{
  text-decoration:none;
  color:inherit;
  cursor:pointer;
}
@media (hover:hover) and (pointer:fine){
  .pre-footer-card--link:hover{
    background:#fff;
    border-color:rgba(15,23,42,.12);
    box-shadow:0 12px 28px rgba(15,23,42,.08);
    transform:var(--card-lift-sm);
  }
}
.pre-footer-card--hours{align-items:flex-start}
.pre-footer-card__icon{
  flex:0 0 auto;
  width:40px;height:40px;
  border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(180deg,#fff,#f2f2f4);
  border:1px solid rgba(15,23,42,.08);
  color:var(--red);
}
.pre-footer-card__icon svg{width:20px;height:20px;display:block}
.pre-footer-card--hours .pre-footer-card__icon{color:var(--text)}
.pre-footer-card__body{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:.25rem;
}
.pre-footer-card__label{
  font-size:.72rem;
  font-weight:950;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(102,112,133,.95);
}
.pre-footer-card__value{
  font-size:1.05rem;
  font-weight:950;
  letter-spacing:-.02em;
  line-height:1.25;
}
.pre-footer-card__value--multiline{
  font-size:.95rem;
  font-weight:800;
  line-height:1.45;
  color:var(--text);
}
.pre-footer-card__chev{
  flex:0 0 auto;
  align-self:center;
  font-size:1.1rem;
  font-weight:900;
  color:rgba(15,23,42,.35);
}
.pre-footer-card--link:hover .pre-footer-card__chev{color:var(--red)}
.pre-footer-card__hours{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.35rem;
}
.pre-footer-card__hours li{
  font-size:.9rem;
  font-weight:750;
  color:var(--text);
  line-height:1.4;
  padding:.35rem .5rem;
  border-radius:var(--radius-sm);
  background:rgba(255,255,255,.65);
  border:1px solid rgba(15,23,42,.06);
}
.pre-footer-card__hours-plain{
  margin:0;
  font-size:.9rem;
  font-weight:750;
  color:var(--text);
  line-height:1.5;
}
@media (min-width:640px){
  .pre-footer-card__hours{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:.4rem .5rem;
  }
  /* Odd last row: one pill full width so grid doesn’t look “broken” */
  .pre-footer-card__hours li:last-child:nth-child(odd):not(:only-child){
    grid-column:1 / -1;
  }
}

.home-testimonials .home-testimonials__sub{max-width:48rem}
.home-quote-card{
  min-width:min(86vw,360px);
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:1.1rem 1.1rem 1rem;
  position:relative;
  overflow:hidden;
  transition:var(--card-transition);
}
.home-quote-card::before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:4px;
  border-radius:4px 0 0 4px;
  background:linear-gradient(180deg,var(--red) 0%,#f97316 100%);
  opacity:.85;
}
.home-quote-card__text{
  margin:0 0 .75rem;
  font-weight:750;
  color:var(--text);
  line-height:1.45;
}
.home-quote-card footer{color:var(--muted);font-weight:850}
.home-quote-card__text,
.home-quote-card footer{position:relative;z-index:1}

/* Fine pointers: lift + shadow on card surfaces (touch stays flat — no sticky hover) */
@media (hover:hover) and (pointer:fine){
  .home-offer-card:hover,
  .home-quote-card:hover{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.12);
  }
  .home-feature-card:hover,
  .home-feature-card:focus-within{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.12);
  }
  .home-promo-card:hover{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.12);
  }
  .dish-card:hover{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.12);
  }
  .menu-page .dish-card.menu-combo-card:hover{
    transform:var(--card-lift-sm);
    box-shadow:0 18px 44px rgba(15,23,42,.1);
  }
}
.home-feature-card__link:focus-visible{
  outline:3px solid rgba(225,29,72,.28);
  outline-offset:3px;
  border-radius:var(--radius-md);
}

.home-popular .card-grid--hscroll-mobile{
  margin-top:1rem;
}
@media (max-width:639px){
  .home-popular .card-grid--hscroll-mobile{
    display:flex;
    gap:.85rem;
    overflow:auto;
    padding-bottom:.25rem;
    scroll-snap-type:x mandatory;
  }
  .home-popular .card-grid--hscroll-mobile > *{scroll-snap-align:start}
  .home-popular .dish-card{min-width:min(86vw,340px)}
}
.dish-img--tile{aspect-ratio:1/1}
.home-popular .dish-body > p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Micro responsive tightening (small devices) */
@media (max-width:360px){
  .dish-body{padding:.9rem .9rem 1rem}
  .dish-body h3{font-size:1rem}
  .home-offer-card{padding:1rem}
  .home-feature-card__body{padding:.95rem}
}

/* Home — rhythm improvements */
.home-section__lead{max-width:52rem}
.home-hscroll{scroll-padding-left:var(--pad)}
.cat-strip-scroll{scroll-padding-left:var(--pad)}

/* Motion safety — no universal * selector (breaks focus/loading transitions) */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .home-offer-card,
  .home-feature-card,
  .home-promo-card,
  .home-quote-card,
  .dish-card,
  .home-ot-card,
  .qa-item,
  .cat-mind-card,
  .admin-dash-card,
  .home-combo-card,
  .pre-footer-card,
  .home-book-cta,
  .orders-card-mini,
  .card-surface{
    transition-duration:.01ms!important;
  }
  .qa-item:hover,
  .home-ot-card:hover,
  .admin-dash-card:hover,
  .home-offer-card:hover,
  .home-quote-card:hover,
  .home-feature-card:hover,
  .home-promo-card:hover,
  .dish-card:hover,
  .home-combo-card:hover,
  .cat-mind-card:hover,
  .orders-card-mini:hover,
  .home-book-cta:hover{
    transform:none!important;
  }
  .mobile-dock__item,
  .btn-chilli,
  .btn-outline-red{
    transition-duration:.01ms!important;
  }
  .ui-checkout-strip,
  .ui-checkout-strip.ui-checkout-strip--show{
    transition:opacity .2s ease!important;
    transform:none!important;
  }
}

/* Cart / checkout */
.table-wrap{overflow:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff}
table.data{width:100%;border-collapse:collapse}
table.data th,table.data td{padding:.85rem 1rem;border-bottom:1px solid rgba(15,23,42,.08);text-align:left}
table.data th{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:950;background:rgba(242,242,244,.9)}
.table-wrap table.data tr:hover td{background:rgba(242,242,244,.55)}

/* Admin tables → stacked cards on narrow screens (see td[data-label]) */
@media (max-width:767px){
  .table-wrap:not(.admin-orders-table-wrap){
    overflow:visible;
    border:none;
    background:transparent;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data{
    display:block;
    width:100%;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data thead{display:none}
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody{display:block}
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody.admin-table-stack{display:block;margin-bottom:1rem}
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody tr{
    display:block;
    width:100%;
    background:#fff;
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    padding:.65rem .95rem .85rem;
    margin-bottom:.75rem;
    box-shadow:var(--shadow-sm);
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody:not(.admin-table-stack) tr:last-child{margin-bottom:0}
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody tr:hover td{background:transparent}
  .table-wrap:not(.admin-orders-table-wrap) table.data td{
    display:grid;
    grid-template-columns:minmax(6.25rem,36%) 1fr;
    gap:.25rem .65rem;
    align-items:start;
    padding:.5rem 0;
    border:none;
    border-bottom:1px solid rgba(15,23,42,.07);
    text-align:left;
    word-break:normal;
    overflow-wrap:anywhere;
    hyphens:auto;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data td:last-child{border-bottom:0;padding-bottom:0}
  .table-wrap:not(.admin-orders-table-wrap) table.data td[data-label]:not([data-label=""])::before{
    content:attr(data-label);
    font-weight:850;
    font-size:.68rem;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
    line-height:1.35;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data td:not([data-label]){
    grid-template-columns:1fr;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data tr.data-stack-detail td{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:.35rem;
    padding-top:.5rem;
    border-bottom:0;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data tr.data-stack-detail td::before{
    content:"Message";
    font-weight:850;
    font-size:.68rem;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--muted);
  }
  /* Ticket body row attaches to card above */
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody.admin-table-stack tr:first-child{
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    margin-bottom:0;
    padding-bottom:.35rem;
  }
  .table-wrap:not(.admin-orders-table-wrap) table.data tbody.admin-table-stack tr.data-stack-detail{
    margin-top:-1px;
    border-top:0;
    border-radius:0 0 var(--radius-lg) var(--radius-lg);
    padding-top:.5rem;
    margin-bottom:.85rem;
    box-shadow:var(--shadow-sm);
  }
}

/* Orders list: cards on phone, table on desktop */
.admin-orders-page .admin-orders-cards{display:none}
.admin-orders-page .admin-orders-table-wrap{display:block}
@media (max-width:767px){
  .admin-orders-page .admin-orders-cards{
    display:grid;
    gap:.75rem;
    margin-bottom:0;
  }
  .admin-orders-page .admin-orders-table-wrap{display:none!important}
}
@media (min-width:768px){
  .admin-orders-page .admin-orders-cards{display:none!important}
}

/* My orders — card list on phone, table on desktop */
.orders-list-page .orders-cards{display:none;list-style:none;margin:0;padding:0}
.orders-list-page .orders-table-wrap{display:block}
.orders-card-mini{
  padding:1rem 1.05rem;
  transition:var(--card-transition);
}
.orders-card-mini__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:.75rem;
  flex-wrap:wrap;
}
.orders-card-mini__when{margin:.35rem 0 0}
.orders-card-mini__line{margin:.25rem 0 0;font-size:.9rem;line-height:1.35}
.orders-card-mini__btn{flex-shrink:0}
@media (hover:hover) and (pointer:fine){
  .orders-card-mini:hover{
    transform:var(--card-lift-sm);
    box-shadow:var(--shadow-md);
    border-color:rgba(15,23,42,.12);
  }
}
@media (max-width:767px){
  .orders-list-page .orders-table-wrap{display:none!important}
  .orders-list-page .orders-cards{display:grid;gap:.75rem}
}
@media (min-width:768px){
  .orders-list-page .orders-cards{display:none!important}
}

.admin-order-card{
  padding:1rem 1.05rem 1.1rem;
  display:flex;
  flex-direction:column;
  gap:.55rem;
  border-radius:var(--radius-lg);
  transition:var(--card-transition);
}
.admin-order-card__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.35rem .75rem;align-items:baseline}
.admin-order-card__id{font-weight:950;font-size:.88rem;word-break:break-all}
.admin-order-card__cust{margin:0;font-weight:750}
.admin-order-card__row{
  display:grid;
  grid-template-columns:1fr;
  gap:.35rem;
  font-size:.92rem;
}
@media (min-width:380px){
  .admin-order-card__row{grid-template-columns:repeat(3,minmax(0,1fr))}
}
.admin-order-card__row strong{display:block;font-size:.65rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:850}
.admin-order-extend-btns{display:flex;flex-wrap:wrap;gap:.35rem}
.admin-extend-chip{min-height:40px;padding:.35rem .55rem!important;font-size:.8rem!important;border-radius:999px}
.admin-order-card__foot{
  display:flex;
  flex-direction:column;
  gap:.6rem;
  padding-top:.35rem;
  border-top:1px solid rgba(15,23,42,.08);
}
.admin-order-card__status-form{display:flex;flex-wrap:wrap;gap:.45rem;align-items:center}
.admin-order-card__status-form select{min-width:0;flex:1 1 10rem}
.admin-order-card__status-form .admin-order-save-btn{flex:0 0 auto}

.admin-td-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.35rem .5rem;
  align-items:center;
}

/* Admin dashboard cards (Apple grid) */
.admin-page-title{margin:0 0 .5rem;font-size:var(--fs-title);font-weight:950;letter-spacing:-.02em;line-height:1.15}
.admin-lead{margin:0;color:var(--muted)}
.admin-bar{
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid rgba(15,23,42,.08);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}
.admin-bar .app-shell{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  min-height:3rem;
  padding-block:.65rem;
  font-weight:800;
  font-size:.92rem;
  color:var(--text);
}
.admin-bar a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:.45rem .95rem;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.1);
  background:linear-gradient(180deg,#fff,#f8fafc);
  font-weight:850;
  color:var(--red);
  box-shadow:var(--shadow-sm);
  transition:transform .18s var(--ease-smooth),box-shadow .18s var(--ease-smooth),border-color .18s;
}
.admin-bar a:hover{
  border-color:rgba(225,29,72,.25);
  box-shadow:var(--shadow-md);
}
.admin-bar a:active{transform:translateY(1px)}
.admin-lead--spaced{margin-bottom:1.25rem!important}
.admin-dash-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.65rem .75rem;
}
@media (min-width:640px){.admin-dash-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}}
@media (min-width:1024px){.admin-dash-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.admin-dash-card{
  background:var(--surface);
  border:1px solid rgba(15,23,42,.10);
  border-radius:var(--radius-lg);
  padding:1rem 1rem 1.05rem;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  gap:.35rem;
  transition:var(--card-transition);
  -webkit-tap-highlight-color:transparent;
}
.admin-dash-card strong{font-weight:950}
.admin-dash-card span{color:var(--muted);font-weight:700;font-size:.92rem}
@media (hover:hover) and (pointer:fine){
  .admin-dash-card:hover{transform:var(--card-lift-sm);box-shadow:var(--shadow-md);border-color:rgba(15,23,42,.14)}
}
.admin-dash-card--primary{border-color:rgba(225,29,72,.20)}
.admin-dash-card--accent{border-color:rgba(245,158,11,.24)}
.cart-total{font-weight:950;font-size:1.1rem}
.cart-actions{display:flex;gap:.75rem;flex-wrap:wrap}

/* Footer (vercel style from views) */
.site-footer--vercel{
  margin-top:auto;
  background:linear-gradient(180deg,#0f0f0f,#1a1a1a);
  color:#cbd5e1;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-inner--stack{display:flex;flex-direction:column;gap:1.35rem}
.footer-inner{padding:2.25rem var(--pad) 1.85rem}
@media (min-width:640px){.footer-inner{padding:3.2rem var(--pad) 2.1rem}}
.footer-grid--vercel{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media (min-width:640px){.footer-grid--vercel{grid-template-columns:repeat(3,minmax(0,1fr));gap:2rem}}
.footer-brand-col,.footer-links-block,.footer-contact-col{min-width:0}
.footer-brand-mark{display:flex;align-items:center}
.footer-brand-logo{height:2.1rem;width:auto;max-width:12rem;object-fit:contain;display:block}
.footer-brand-name{margin:.75rem 0 .5rem;color:#fff;font-weight:950;letter-spacing:-.02em}
.footer-blurb{margin:0;color:#94a3b8;max-width:26rem}
.footer-col-title{margin:0 0 .6rem;color:#fff;font-weight:900}
.footer-links{list-style:none;margin:0;padding:0}
.footer-links a{display:block;padding:.35rem 0;color:#cbd5e1;font-weight:700}
.footer-links a:hover{color:#fbbf24}
.footer-addr,.footer-hours{margin:0;color:#cbd5e1}
.footer-phone{display:inline-block;margin-top:.25rem;color:#e2e8f0;font-weight:900}
.footer-phone:hover{color:#fbbf24}
.footer-payment{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.08)}
.footer-payment__methods{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}
.footer-payment__label{color:#94a3b8;font-weight:900;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem}
.footer-pay-chip{display:inline-flex;align-items:center;justify-content:center;height:28px;min-width:44px;padding:0 .6rem;border-radius:8px;background:#fff;color:#111;font-weight:900;font-size:.8rem}
.footer-pay-chip--apple{background:#111;color:#fff}
.footer-policies{margin-top:1.35rem;display:flex;gap:.9rem 1.1rem;flex-wrap:wrap;justify-content:center}
.footer-policies a{color:#cbd5e1;font-weight:800}
.footer-policies a:hover{color:#fbbf24}
.footer-bottom{margin-top:1.25rem;text-align:center;color:#94a3b8;font-weight:700}

@media (max-width:639px){
  .footer-grid--vercel{gap:1.25rem}
  .footer-brand-name{margin:.65rem 0 .45rem}
  .footer-payment{margin-top:1.1rem;padding-top:1.1rem}
  .footer-payment__methods{gap:.45rem .55rem}
}

/* Mobile dock */
.mobile-dock{
  position:fixed;left:0;right:0;bottom:0;z-index:30;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px) saturate(1.15);
  -webkit-backdrop-filter:blur(16px) saturate(1.15);
  border-top:1px solid rgba(15,23,42,.08);
  box-shadow:0 -8px 32px rgba(15,23,42,.07);
  display:flex;justify-content:space-around;gap:.25rem;
  padding:.45rem max(var(--pad),env(safe-area-inset-left,0px)) calc(.45rem + env(safe-area-inset-bottom,0px));
}
@media (min-width:768px){.mobile-dock{display:none}}
.mobile-dock__item{
  flex:1;min-width:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.2rem;
  min-height:52px;
  border-radius:1rem;
  color:var(--muted);
  font-weight:900;
  font-size:.72rem;
  transition:color .2s var(--ease-smooth),background .2s var(--ease-smooth),transform .2s var(--ease-spring);
}
.mobile-dock__item svg{
  opacity:.88;
  transition:opacity .2s,transform .2s var(--ease-spring);
}
.mobile-dock__item.is-active{
  color:var(--red);
  background:rgba(225,29,72,.06);
}
.mobile-dock__item.is-active svg{opacity:1;transform:translateY(-1px)}
.mobile-dock__item:hover{background:rgba(15,23,42,.04)}
.mobile-dock__item:active{transform:scale(.97)}

/* Prevent fixed dock covering content on mobile */
@media (max-width:767px){
  body{padding-bottom:calc(74px + env(safe-area-inset-bottom,0px))}
}

/* Combo customize — build-your-own steps + summary */
.combo-customize-page{padding-bottom:2rem}
.combo-customize-back{margin:0 0 1rem}
.combo-customize-back a{font-weight:800;color:var(--text)}
.combo-customize-hero{
  overflow:hidden;
  margin-bottom:1.25rem;
  display:grid;
  gap:0;
}
@media (min-width:768px){
  .combo-customize-hero{grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);align-items:stretch}
}
.combo-customize-hero__media{aspect-ratio:16/9;background:var(--surface-2)}
.combo-customize-hero__media img{width:100%;height:100%;object-fit:cover;display:block}
.combo-customize-hero__body{padding:1.1rem 1.15rem 1.2rem}
.combo-customize-title{margin:.35rem 0 .5rem;font-weight:950;letter-spacing:-.03em;line-height:1.15}
.combo-customize-desc{margin:0 0 .65rem;color:var(--muted);max-width:52ch}
.combo-customize-price{margin:0;font-weight:950;font-size:1.15rem}
.combo-customize-flash{
  margin:0 0 1rem;padding:.85rem 1rem;border-radius:var(--radius-lg);
  background:rgba(225,29,72,.08);border:1px solid rgba(225,29,72,.22);
  color:var(--red-dark);font-weight:750;
}

.combo-customize-layout{max-width:72rem}
.combo-customize-progress{
  display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem;
  margin:0 0 1.25rem;padding:.65rem .85rem;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,#fffbeb,#fff7ed);
  border:1px solid rgba(245,158,11,.22);
}
.combo-customize-progress__label{font-weight:900;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:#9a3412}
.combo-customize-progress__dots{
  list-style:none;margin:0;padding:0;display:flex;gap:.45rem;flex-wrap:wrap;
}
.combo-customize-progress__dot{
  display:inline-flex;align-items:center;justify-content:center;
  width:2rem;height:2rem;border-radius:999px;
  border:2px solid rgba(15,23,42,.18);
  background:#fff;font-weight:950;font-size:.85rem;color:var(--muted);
  transition:background .2s,border-color .2s,color .2s,transform .2s;
}
.combo-customize-progress__dot.is-complete{
  border-color:rgba(22,163,74,.45);
  background:rgba(22,163,74,.12);
  color:#166534;
}
.combo-customize-main{
  display:grid;gap:1.25rem;
}
@media (min-width:900px){
  .combo-customize-main{grid-template-columns:minmax(0,1fr) minmax(260px,320px);align-items:start}
}

.combo-slot-fieldset{
  border:0;margin:0 0 1rem;padding:1rem 1rem 1.1rem;
}
.combo-slot-legend{
  padding:0 .35rem 0 0;font-weight:950;font-size:1.05rem;
}
.combo-slot-hint{margin:0 0 .85rem}
.combo-slot-options{
  display:grid;gap:.65rem;
  grid-template-columns:1fr;
}
@media (min-width:520px){
  .combo-slot-options{grid-template-columns:repeat(2,minmax(0,1fr))}
}
.combo-slot-option{display:block;cursor:pointer;margin:0}
.combo-slot-option input{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.combo-slot-option__card{
  display:flex;gap:.75rem;align-items:flex-start;
  min-height:100%;
  padding:.75rem .85rem;border-radius:var(--radius-lg);
  border:2px solid rgba(15,23,42,.10);
  background:#fff;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.combo-slot-option:focus-within .combo-slot-option__card{
  outline:2px solid rgba(225,29,72,.35);outline-offset:2px;
}
.combo-slot-option input:checked + .combo-slot-option__card{
  border-color:rgba(225,29,72,.55);
  box-shadow:0 8px 24px rgba(225,29,72,.12);
  background:linear-gradient(180deg,#fff,#fff5f5);
}
.combo-slot-option__img{
  flex:0 0 72px;width:72px;height:72px;border-radius:12px;overflow:hidden;background:var(--surface-2);
}
.combo-slot-option__img img{width:100%;height:100%;object-fit:cover;display:block}
.combo-slot-option__text{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.combo-slot-option__price{margin-top:.35rem;font-weight:900;color:var(--text)}

.combo-customize-summary{
  padding:1rem 1.05rem 1.15rem;
  position:sticky;top:1rem;
}
.combo-customize-summary__title{margin:0 0 .35rem;font-size:1.05rem;font-weight:950}
.combo-customize-summary__lead{margin:0 0 .75rem}
.combo-customize-summary__list{
  list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem;
}
.combo-customize-summary__item{
  display:flex;flex-direction:column;gap:.1rem;padding-bottom:.55rem;
  border-bottom:1px solid rgba(15,23,42,.08);
  font-size:.92rem;
}
.combo-customize-summary__item:last-of-type{border-bottom:0;padding-bottom:0}
.combo-customize-summary__item strong{font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:900}
.combo-customize-summary__pick{font-weight:800;color:var(--text)}
.combo-customize-summary__total{
  margin:1rem 0 0;padding-top:.85rem;border-top:1px dashed rgba(15,23,42,.12);
  display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;
}
.combo-customize-actions{
  display:flex;flex-wrap:wrap;gap:.65rem;align-items:center;margin-top:.25rem;
}

/* --- AJAX cart toast (injected by footer script) --- */
.ui-checkout-strip{
  position:fixed;
  left:max(12px,env(safe-area-inset-left,0px));
  right:max(12px,env(safe-area-inset-right,0px));
  bottom:calc(88px + env(safe-area-inset-bottom,0px));
  z-index:55;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  padding:.85rem 1rem;
  border-radius:var(--radius-lg);
  background:rgba(15,23,42,.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  color:#f8fafc;
  font-weight:800;
  font-size:.9rem;
  text-decoration:none;
  box-shadow:0 16px 48px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.08);
  transform:translateY(120%);
  opacity:0;
  transition:transform .35s var(--ease-spring),opacity .25s var(--ease-smooth);
}
@media (min-width:768px){
  .ui-checkout-strip{
    left:50%;
    right:auto;
    bottom:1.5rem;
    width:min(420px,calc(100vw - 2rem));
    transform:translate(-50%,120%);
  }
  .ui-checkout-strip.ui-checkout-strip--show{
    transform:translate(-50%,0);
  }
}
.ui-checkout-strip.ui-checkout-strip--show{
  transform:translateY(0);
  opacity:1;
}
.ui-checkout-strip__left{display:flex;align-items:center;gap:.55rem;min-width:0}
.ui-checkout-strip__icon{font-size:1.15rem;line-height:1}
.ui-checkout-strip__right{
  flex:0 0 auto;
  font-weight:900;
  font-size:.82rem;
  letter-spacing:.02em;
  opacity:.95;
}
.ui-checkout-strip:hover{color:#fff;filter:brightness(1.06)}
.ui-checkout-strip:focus-visible{
  outline:3px solid rgba(251,191,36,.5);
  outline-offset:2px;
}

/* --- Tables: calmer rows (admin + account) --- */
table.data tbody tr{
  transition:background-color .15s var(--ease-smooth);
}
table.data tbody tr:hover td{
  background:rgba(15,23,42,.02);
}

/* --- Cards: subtle lift on hover (interactive surfaces) --- */
@media (hover:hover) and (pointer:fine){
  a.card-surface:hover,
  button.card-surface:hover{
    border-color:rgba(15,23,42,.14);
    box-shadow:var(--shadow-md);
    transform:var(--card-lift-sm);
  }
}

