*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --brand:#5C1414;--brand-mid:#7A1F1F;--brand-soft:#9B3333;
  --green:#1B4332;--cream:#FAFAF7;--warm:#F0ECE6;
  --surface:#FFF;--ink:#141210;--ink-2:#57524B;--ink-3:#96908A;--ink-4:#BEB8B0;
  --border:#E8E2DA;--wa:#25D366;
  --max-w:520px;--gutter:16px;--r:16px;--r-sm:10px;
  --ease:cubic-bezier(.22,.68,0,1);--spring:cubic-bezier(.34,1.3,.64,1);
  --t:220ms;--safe-b:env(safe-area-inset-bottom,0px);
}
.dark{
  --cream:#0F0E0D;--warm:#1A1917;--surface:#1C1B19;
  --ink:#E5E1DC;--ink-2:#A39E97;--ink-3:#6B665F;--ink-4:#3A3733;
  --border:#282624;--brand:#D05050;--brand-mid:#E06666;--brand-soft:#EB8080;
}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--cream);color:var(--ink);
  -webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;
  overflow-x:hidden;line-height:1.5;padding-bottom:var(--safe-b);
  transition:background .35s ease,color .35s ease;
}

/* ── HERO ──────────────────────────────────── */
.hero{
  background:var(--brand);color:#fff;
  padding:44px var(--gutter) 32px;text-align:center;
  position:relative;overflow:hidden;
}
.dark .hero{background:#1A0808}
.hero-grain{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  pointer-events:none;
}
.hero-content{position:relative;z-index:1}
.hero-title{
  font-family:'Playfair Display',serif;font-size:clamp(1.9rem,8.5vw,2.6rem);font-weight:700;
  line-height:.95;letter-spacing:-1px;margin-bottom:0;
}
.hero-dot{color:var(--brand-soft);opacity:.6}
.dark .hero-dot{color:#FF6B6B}
.hero-tagline{
  font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:600;
  color:rgba(255,255,255,.5);letter-spacing:4px;text-transform:uppercase;
  margin-bottom:10px;
}
.hero-sub{font-size:.7rem;color:rgba(255,255,255,.35);margin-bottom:16px}
.hero-actions{display:flex;gap:8px;justify-content:center}
.ha-btn{
  height:28px;padding:0 12px;border:1px solid rgba(255,255,255,.12);
  border-radius:100px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.55);
  font:600 .6rem/28px 'Inter',sans-serif;cursor:pointer;
  display:flex;align-items:center;gap:4px;transition:all var(--t) ease;
}
.ha-btn:active{transform:scale(.92)}
.ha-btn svg{width:13px;height:13px}
.ico-moon{display:none}.dark .ico-sun{display:none}.dark .ico-moon{display:block}

/* ── STICKY NAV ────────────────────────────── */
.sticky-nav{
  position:sticky;top:0;z-index:200;background:var(--cream);
  border-bottom:1px solid transparent;
  transition:border-color var(--t) ease,box-shadow var(--t) ease,background .35s ease;
}
.sticky-nav.pinned{border-bottom-color:var(--border);box-shadow:0 4px 24px rgba(20,18,16,.04)}
.dark .sticky-nav.pinned{box-shadow:0 4px 24px rgba(0,0,0,.2)}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:10px var(--gutter) 0}

.search-field{position:relative;margin-bottom:10px}
.sf-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--ink-4);pointer-events:none}
#searchInput{
  width:100%;height:44px;padding:0 16px 0 42px;
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);
  font:500 .86rem/1 'Inter',sans-serif;color:var(--ink);outline:none;
  transition:border-color var(--t) ease,box-shadow var(--t) ease,background .35s ease;
}
#searchInput::placeholder{color:var(--ink-4);font-weight:400}
#searchInput:focus{border-color:var(--brand-soft);box-shadow:0 0 0 4px rgba(92,20,20,.05)}

.cat-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}
.cat-strip::-webkit-scrollbar{display:none}
.cat-chip{
  flex-shrink:0;height:36px;padding:0 15px;
  border:1.5px solid var(--border);border-radius:100px;background:var(--surface);
  font:600 .75rem/36px 'Inter',sans-serif;color:var(--ink-2);
  cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:5px;
  transition:all var(--t) var(--ease);user-select:none;-webkit-user-select:none;
}
.cat-chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.cat-chip:not(.on):active{transform:scale(.95)}
.cat-count{font-size:.55rem;font-weight:700;opacity:.4;background:rgba(0,0,0,.05);padding:1px 5px;border-radius:8px;line-height:1.4}
.cat-chip.on .cat-count{background:rgba(255,255,255,.18);opacity:.75}

/* ── SECTIONS ──────────────────────────────── */
.sec-title{
  font-size:.65rem;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--ink-3);margin-bottom:10px;
}
.picks,.combos{max-width:var(--max-w);margin:0 auto;padding:16px var(--gutter) 0}

/* Popular picks */
.picks-track{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.picks-track::-webkit-scrollbar{display:none}
.pick-card{
  flex-shrink:0;width:130px;background:var(--surface);border-radius:var(--r);
  overflow:hidden;cursor:pointer;box-shadow:0 1px 3px rgba(20,18,16,.04);
  transition:transform 150ms var(--ease);
}
.pick-card:active{transform:scale(.96)}
.pick-img{aspect-ratio:4/3;overflow:hidden;background:var(--warm)}
.pick-img img{width:100%;height:100%;object-fit:cover;display:block}
.pick-body{padding:8px 10px 10px}
.pick-name{font-size:.7rem;font-weight:700;line-height:1.25;margin-bottom:2px;color:var(--ink)}
.pick-price{font-size:.75rem;font-weight:700;color:var(--brand)}

/* Combos */
.combos-list{display:flex;flex-direction:column;gap:8px}
.combo-card{
  display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:var(--surface);border-radius:var(--r);
  border:1.5px solid var(--border);cursor:pointer;transition:transform 150ms ease;
}
.combo-card:active{transform:scale(.98)}
.combo-icon{font-size:1.2rem;flex-shrink:0;width:32px;text-align:center}
.combo-info{flex:1;min-width:0}
.combo-name{font-size:.8rem;font-weight:700;color:var(--ink)}
.combo-desc{font-size:.65rem;color:var(--ink-3)}
.combo-prices{text-align:right;flex-shrink:0}
.combo-old{font-size:.65rem;color:var(--ink-4);text-decoration:line-through}
.combo-new{font-size:.88rem;font-weight:700;color:var(--green)}
.dark .combo-new{color:#66BB6A}

/* ── MAIN / GRID ───────────────────────────── */
.content{max-width:var(--max-w);margin:0 auto;padding:6px var(--gutter) 48px;min-height:40vh}

/* ── CATEGORY PAGE ─────────────────────────── */
.cat-head{display:none;align-items:center;gap:12px;padding:16px 0 6px}
body.cat-page .cat-head{display:flex}
body.cat-page .hero,
body.cat-page .picks,
body.cat-page .combos{display:none}
body.cat-page .content{min-height:70vh}
.cat-back{
  width:38px;height:38px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--surface);color:var(--ink-2);cursor:pointer;
  display:grid;place-items:center;flex-shrink:0;transition:transform 120ms ease;
}
.cat-back:active{transform:scale(.88)}
.cat-head-title{
  font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;
  color:var(--ink);line-height:1.2;
}
.section-label{
  font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--ink-4);padding:20px 0 10px;display:flex;align-items:center;justify-content:space-between;
}
.section-label:first-child{padding-top:10px}
.section-range{font-weight:600;font-size:.58rem;color:var(--ink-4);text-transform:none;letter-spacing:0}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}

/* ── CARD ──────────────────────────────────── */
.card{
  background:var(--surface);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;cursor:pointer;
  box-shadow:0 1px 2px rgba(20,18,16,.03);
  transition:transform 150ms var(--ease),box-shadow 150ms var(--ease),background .35s ease;
  will-change:transform;
}
.card:active{transform:scale(.975);box-shadow:0 4px 16px rgba(20,18,16,.08)}
.card.entering{opacity:0;transform:translateY(14px)}
.card.entered{opacity:1;transform:translateY(0);transition:opacity 320ms var(--ease),transform 320ms var(--ease)}

.card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--warm)}
.card-img::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,var(--warm) 25%,rgba(255,255,255,.08) 50%,var(--warm) 75%);
  background-size:200% 100%;animation:shimmer 1.6s infinite;z-index:1;transition:opacity 300ms ease;
}
.card-img.loaded::before{opacity:0;pointer-events:none}
@keyframes shimmer{to{background-position:-200% 0}}
.card-img img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:2;opacity:0;transition:opacity 350ms ease}
.card-img.loaded img{opacity:1}

.card-fallback{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center}
.card-fallback svg{width:34px;height:34px;opacity:.14;color:var(--ink-2)}

.card-badge{
  position:absolute;top:8px;left:8px;z-index:3;
  height:21px;padding:0 8px;border-radius:6px;
  font-size:.54rem;font-weight:700;letter-spacing:.3px;
  text-transform:uppercase;line-height:21px;color:#fff;
}
.badge-popular{background:var(--brand)}.badge-spicy{background:#B91C1C}
.badge-mild{background:var(--green)}.badge-new{background:#B45309}

.card-cart-badge{
  position:absolute;top:8px;right:8px;z-index:4;
  width:22px;height:22px;border-radius:50%;
  background:var(--brand);color:#fff;
  font-size:.6rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.2);
}

.card-body{padding:10px 12px 14px;display:flex;flex-direction:column;flex:1}
.card-name{font-size:.8rem;font-weight:700;line-height:1.3;color:var(--ink);margin-bottom:2px}
.card-desc{font-size:.66rem;color:var(--ink-3);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.card-bottom{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:4px}
.card-price{font-size:.92rem;font-weight:700;color:var(--brand)}
.card-unit{font-size:.52rem;color:var(--ink-4);font-weight:600}
.card-add{
  width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--surface);color:var(--brand);font-size:1.1rem;font-weight:700;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:all 150ms ease;line-height:1;
}
.card-add:active{transform:scale(.85);background:var(--brand);color:#fff;border-color:var(--brand)}

/* ── EMPTY ─────────────────────────────────── */
.empty{display:none;text-align:center;padding:56px 20px}
.empty.on{display:block}
.empty-title{font-weight:700;margin-bottom:4px}
.empty-sub{font-size:.85rem;color:var(--ink-3)}

/* ── CART FAB ──────────────────────────────── */
.cart-fab{
  position:fixed;bottom:calc(20px + var(--safe-b));left:16px;z-index:300;
  width:48px;height:48px;border-radius:50%;border:none;
  background:var(--brand);color:#fff;
  box-shadow:0 4px 20px rgba(92,20,20,.3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transform:translateY(10px) scale(.8);
  transition:all var(--t) var(--spring);
}
.cart-fab.has-items{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.cart-fab:active{transform:scale(.88)}
.cart-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:20px;height:20px;padding:0 5px;
  background:#fff;color:var(--brand);border-radius:100px;
  font-size:.6rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}

/* ── BACK TO TOP ───────────────────────────── */
.btt{
  position:fixed;bottom:calc(20px + var(--safe-b));right:16px;z-index:300;
  width:42px;height:42px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--surface);color:var(--ink-2);
  box-shadow:0 2px 16px rgba(20,18,16,.1);cursor:pointer;display:grid;place-items:center;
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:all var(--t) ease;
}
.btt.show{opacity:1;visibility:visible;transform:translateY(0)}
.btt:active{transform:scale(.88)}

/* ── MODAL (shared) ───────────────────────── */
.overlay{
  position:fixed;inset:0;z-index:900;
  background:rgba(20,18,16,.55);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity 260ms ease,visibility 260ms ease;
}
.overlay.open{opacity:1;visibility:visible}

.sheet{
  background:var(--surface);width:100%;max-width:480px;max-height:92dvh;
  border-radius:24px 24px 0 0;overflow-y:auto;overscroll-behavior:contain;
  transform:translateY(100%);transition:transform 360ms var(--spring),background .35s ease;
  position:relative;
}
.overlay.open .sheet{transform:translateY(0)}
.sheet-bar{display:flex;justify-content:center;padding:10px 0 4px}
.sheet-handle{width:36px;height:4px;border-radius:4px;background:var(--ink-4);opacity:.5}
.sheet-x{
  position:absolute;top:16px;right:16px;z-index:10;
  width:36px;height:36px;border-radius:50%;border:none;
  background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:#fff;cursor:pointer;display:grid;place-items:center;transition:transform 120ms ease;
}
.sheet-x:active{transform:scale(.85)}

.sheet-img{width:100%;aspect-ratio:16/10;background:var(--warm);overflow:hidden}
.sheet-img img{width:100%;height:100%;object-fit:cover;display:block}
.sheet-img .card-fallback svg{width:48px;height:48px}

.sheet-body{padding:22px 22px 26px}
.sheet-head{margin-bottom:6px}
.sheet-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.sheet-tags:empty{display:none}
.sheet-tags .card-badge{position:static;font-size:.6rem;height:23px;line-height:23px;padding:0 10px}
.sheet-name{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;line-height:1.2;color:var(--ink);margin-bottom:4px}
.sheet-price{display:inline-block;font-size:1.1rem;font-weight:700;color:var(--brand)}
.sheet-unit{font-size:.7rem;color:var(--ink-3);font-weight:600;margin-left:6px}
.sheet-divider{height:1px;background:var(--border);margin:18px 0}

.s-block{margin-bottom:16px}.s-block:last-child{margin-bottom:0}
.s-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--ink-4);margin-bottom:4px}
.s-value{font-size:.85rem;line-height:1.6;color:var(--ink-2)}

/* Extras */
.extras-list{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.extra-row{
  display:flex;align-items:center;gap:10px;padding:11px 14px;
  border:1.5px solid var(--border);border-radius:var(--r-sm);
  background:var(--cream);cursor:pointer;user-select:none;-webkit-user-select:none;
  transition:border-color 150ms ease,background 150ms ease;
}
.extra-row:has(.extra-check:checked){border-color:var(--brand)}
.extra-check{width:16px;height:16px;accent-color:var(--brand);flex-shrink:0;cursor:pointer}
.extra-name{flex:1;font-size:.8rem;font-weight:600;color:var(--ink-2)}
.extra-price{font-size:.75rem;font-weight:700;color:var(--brand);flex-shrink:0}

.sheet-cta{
  position:sticky;bottom:0;padding:10px 22px calc(10px + var(--safe-b));
  background:var(--surface);border-top:1px solid var(--border);z-index:5;
  display:flex;flex-direction:column;gap:8px;
}
.order-note{
  width:100%;padding:10px 12px;border:1.5px solid var(--border);
  border-radius:var(--r-sm);font:400 .78rem/1.4 'Inter',sans-serif;
  color:var(--ink);background:var(--cream);resize:none;outline:none;
  transition:border-color var(--t) ease,background .35s ease;
}
.order-note:focus{border-color:var(--brand-soft)}

.btn-add-cart{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;height:50px;background:var(--brand);color:#fff;border:none;
  border-radius:var(--r);font:700 .88rem/1 'Inter',sans-serif;
  cursor:pointer;transition:all 150ms ease;
}
.btn-add-cart:active{transform:scale(.975)}

.btn-wa{
  display:flex;align-items:center;justify-content:center;gap:8px;
  width:100%;height:50px;background:var(--wa);color:#fff;border:none;
  border-radius:var(--r);font:700 .88rem/1 'Inter',sans-serif;
  text-decoration:none;cursor:pointer;transition:transform 120ms ease;
  box-shadow:0 4px 20px rgba(37,211,102,.2);
}
.btn-wa:active{transform:scale(.975)}
.btn-wa svg{flex-shrink:0}

/* ── CART SHEET ────────────────────────────── */
.cart-sheet .sheet-x{background:rgba(0,0,0,.08);color:var(--ink-3)}
.dark .cart-sheet .sheet-x{background:rgba(255,255,255,.1);color:var(--ink-2)}

.cart-header{
  display:flex;align-items:center;gap:10px;
  padding:4px 22px 16px;
  border-bottom:1px solid var(--border);
  color:var(--ink);
}
.cart-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700}

.cart-items{padding:12px 22px;min-height:80px}

.cart-empty-state{text-align:center;padding:40px 0}
.cart-empty-title{font-weight:700;color:var(--ink);margin-bottom:4px}
.cart-empty-sub{font-size:.8rem;color:var(--ink-3)}

.cart-item{
  display:flex;align-items:center;gap:10px;
  padding:12px 0;border-bottom:1px solid var(--border);
}
.cart-item:last-child{border-bottom:none}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:.82rem;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-ex{font-size:.62rem;color:var(--brand-soft);font-weight:600;line-height:1.35}
.cart-item-price{font-size:.68rem;color:var(--ink-3)}
.cart-item-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.cart-qty-controls{display:flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:100px;overflow:hidden}
.cart-qty-btn{
  width:32px;height:32px;border:none;background:transparent;
  color:var(--ink);font-size:1rem;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background 100ms ease;
}
.cart-qty-btn:active{background:var(--warm)}
.cart-qty-num{width:24px;text-align:center;font-size:.82rem;font-weight:700;color:var(--ink)}
.cart-item-total{font-size:.82rem;font-weight:700;color:var(--brand);min-width:50px;text-align:right}

.cart-footer{
  position:sticky;bottom:0;
  padding:14px 22px calc(14px + var(--safe-b));
  background:var(--surface);border-top:1px solid var(--border);
  display:flex;flex-direction:column;gap:10px;
}

.cart-total-row{display:flex;justify-content:space-between;align-items:center}
.cart-total-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--ink-3)}
.cart-total-amount{font-size:1.2rem;font-weight:800;color:var(--brand)}
.cart-pickup{display:flex;justify-content:space-between;align-items:center}
.cart-pickup-label{font-size:.68rem;font-weight:600;color:var(--ink-3)}
.cart-pickup-badge{
  height:28px;padding:0 14px;border-radius:100px;
  background:var(--brand);color:#fff;
  font:700 .68rem/28px 'Inter',sans-serif;
}

.cart-wa{margin-top:2px}
.cart-clear-btn{
  width:100%;height:40px;border:1.5px solid var(--border);
  border-radius:var(--r-sm);background:transparent;
  font:600 .72rem/1 'Inter',sans-serif;color:var(--ink-3);
  cursor:pointer;transition:all 150ms ease;
}
.cart-clear-btn:active{background:var(--warm)}

/* ── FOOTER ────────────────────────────────── */
.site-footer{background:#141210;color:rgba(255,255,255,.65);padding:30px var(--gutter) calc(24px + var(--safe-b));margin-top:12px}
.footer-inner{max-width:var(--max-w);margin:0 auto}
.footer-brand{display:flex;align-items:baseline;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.footer-brand h3{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:#fff}
.footer-rows{display:flex;flex-direction:column;gap:11px;margin-bottom:20px}
.f-row{display:flex;align-items:center;gap:10px;font-size:.78rem}
.f-row svg{width:14px;height:14px;flex-shrink:0;opacity:.3}
.f-row a{color:rgba(255,255,255,.65);text-decoration:none}
.f-row--wa svg{opacity:.6;color:#25D366}
.f-row--wa a{color:rgba(255,255,255,.8)}
.footer-note{font-size:.58rem;color:rgba(255,255,255,.15);padding-top:16px;border-top:1px solid rgba(255,255,255,.05);line-height:1.5}

/* ── RESPONSIVE ────────────────────────────── */
@media(max-width:359px){.grid{grid-template-columns:1fr;gap:10px}}
@media(min-width:390px){.grid{gap:14px}.card-name{font-size:.84rem}}
@media(min-width:600px){.hero-title{font-size:3rem}.sheet{border-radius:24px;align-self:center}}
