@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
:root{--bg:#0a0a0a;--s1:#141414;--s2:#1e1e1e;--s3:#282828;--b:#2e2e2e;--accent:#f05023;--adim:rgba(240,80,35,.12);--cream:#f2e9d8;--text:#fff;--muted:#777;--green:#22c55e;--r:14px;--font:'Inter',sans-serif}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100dvh;overscroll-behavior:none}

/* HERO */
/* HERO */
.hero{background:radial-gradient(circle at center, #1a1a1a 0%, #0a0a0a 100%);padding:40px 20px 20px;text-align:center;position:relative;overflow:hidden;min-height:180px;display:flex;align-items:center;justify-content:center}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(240,80,35,0.15),transparent);pointer-events:none}
.hero-content{position:relative;z-index:10;width:100%}
.logo{font-size:2.2rem;font-weight:900;letter-spacing:4px;color:var(--accent);line-height:1;text-shadow:0 0 40px rgba(0,0,0,0.8), 0 0 20px rgba(240,80,35,0.4)}
.tagline{font-size:.62rem;letter-spacing:3px;color:rgba(255,255,255,0.7);text-transform:uppercase;margin-top:8px;font-weight:600}
.hero-pills{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:rgba(20,20,20,0.6);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.1);border-radius:100px;font-size:.7rem;font-weight:600;color:var(--text)}
.pill.on{background:rgba(34,197,94,0.15);border-color:rgba(34,197,94,0.3);color:var(--green)}

/* CATEGORY NAV */
.cat-nav{position:sticky;top:0;z-index:200;background:rgba(10,10,10,.97);backdrop-filter:blur(20px);border-bottom:1px solid var(--b)}
.cat-scroll{display:flex;gap:6px;padding:12px 16px;overflow-x:auto;scrollbar-width:none}
.cat-scroll::-webkit-scrollbar{display:none}
.cat-btn{flex-shrink:0;background:var(--s1);border:1px solid var(--b);color:var(--muted);padding:10px 20px;border-radius:12px;font-size:.75rem;font-weight:700;font-family:var(--font);letter-spacing:.3px;white-space:nowrap;transition:all .2s;cursor:pointer}
.cat-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 8px 20px rgba(240,80,35,0.25)}

/* CONTROLS */
.top-controls{padding:20px 16px;background:var(--bg);display:flex;flex-direction:column;gap:12px}
.search-box{display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--b);border-radius:14px;padding:12px 18px;transition:all .3s ease;box-shadow:0 4px 15px rgba(0,0,0,0.2)}
.search-box:focus-within{border-color:var(--accent);box-shadow:0 4px 20px rgba(240,80,35,0.15)}
.search-box input{flex:1;background:transparent;border:none;color:var(--text);font-size:.95rem;font-family:var(--font);outline:none}
.search-box input::placeholder{color:var(--muted)}
.search-icon{color:var(--muted);font-size:1.1rem}

.filter-bar{display:flex;gap:10px;align-items:center;margin-top:4px}
.sort-wrap{flex:1;position:relative;background:var(--s2);border:1px solid var(--b);border-radius:12px;height:44px;display:flex;align-items:center;transition:all .2s;cursor:pointer}
.sort-label{width:100%;padding:0 35px 0 14px;font-size:.78rem;font-weight:600;color:var(--text);letter-spacing:.2px}
.sort-wrap select{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer;z-index:2}
/* Fix for native select accessibility in dark mode */
.sort-wrap select option{background:var(--s2);color:var(--text)}
.sort-icon{position:absolute;right:14px;color:var(--muted);display:flex;align-items:center;pointer-events:none;z-index:1}

.filter-btn{background:var(--s2);border:1px solid var(--b);border-radius:12px;padding:0 14px;height:44px;display:flex;align-items:center;gap:8px;color:var(--text);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.2px}
.filter-btn.active{border-color:var(--green);background:rgba(34,197,94,0.08);color:var(--green)}
.veg-dot-sm{width:12px;height:12px;border:1.5px solid var(--green);border-radius:3px;position:relative;display:flex;align-items:center;justify-content:center}
.veg-dot-sm::after{content:'';width:4.5px;height:4.5px;background:var(--green);border-radius:50%;opacity:0;transition:opacity .2s}
.filter-btn.active .veg-dot-sm::after{opacity:1}

/* SECTION HEADER */
.section-head{display:flex;align-items:center;justify-content:space-between;padding:24px 16px 12px}
.section-head h2{font-size:1.05rem;font-weight:900;letter-spacing:-.2px}
.section-head span{font-size:.7rem;color:var(--muted);font-weight:500;background:var(--s2);padding:2px 8px;border-radius:6px}

/* GRID */
.item-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px}
.item-grid.list-mode{grid-template-columns:1fr}

/* CARD — GRID */
.item-card{background:var(--s1);border:1px solid var(--b);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;position:relative;transition:all .2s ease;box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.item-card:active{transform:scale(.98)}
.item-card-img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:var(--s2)}
.item-card-emoji{width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,var(--s2),var(--s3))}
.item-card-body{padding:12px;flex:1;display:flex;flex-direction:column;gap:4px}
.item-card-name{font-size:.88rem;font-weight:800;line-height:1.2;color:var(--text);letter-spacing:-.2px}
.item-card-desc{font-size:.65rem;color:var(--muted);line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.item-card-footer{display:flex;align-items:flex-end;justify-content:space-between;margin-top:auto}
.item-price{font-size:1.05rem;font-weight:900;color:var(--accent);line-height:1}
.item-price-sub{font-size:.62rem;color:var(--muted);font-weight:600;display:block;margin-top:2px}

/* CARD — LIST MODE */
.list-card{background:var(--s1);border:1px solid var(--b);border-radius:var(--r);display:flex;align-items:center;overflow:hidden;transition:transform .15s}
.list-card:active{transform:scale(.98)}
.list-card-img{width:110px;height:100px;object-fit:cover;flex-shrink:0;background:var(--s2);display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.list-card-body{flex:1;padding:14px;display:flex;flex-direction:column;gap:5px}
.list-card-name{font-size:.9rem;font-weight:700}
.list-card-desc{font-size:.72rem;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.list-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px}

/* VEG DOT */
.veg-dot{position:absolute;top:8px;left:8px;width:14px;height:14px;border:2px solid var(--green);border-radius:3px;background:transparent;display:flex;align-items:center;justify-content:center}
.veg-dot::after{content:'';width:6px;height:6px;background:var(--green);border-radius:50%}
.nveg-dot{position:absolute;top:8px;left:8px;width:14px;height:14px;border:2px solid #ef4444;border-radius:3px;display:flex;align-items:center;justify-content:center}
.nveg-dot::after{content:'';width:6px;height:6px;background:#ef4444;border-radius:50%}

/* TAGS */
.tag-row{display:flex;gap:4px;flex-wrap:wrap}
.tag{font-size:.58rem;font-weight:700;padding:2px 7px;border-radius:100px;letter-spacing:.3px}
.t-pop{background:rgba(234,179,8,.1);color:#eab308}
.t-hot{background:rgba(240,80,35,.12);color:var(--accent)}
.t-new{background:rgba(34,197,94,.1);color:var(--green)}
.t-best{background:rgba(168,85,247,.1);color:#a855f7}

/* ADD BTN */
.add-btn{width:36px;height:36px;border-radius:12px;background:var(--accent);border:none;color:#fff;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;box-shadow:0 6px 16px rgba(240,80,35,0.35);transition:all .2s}
.add-btn:active{transform:translateY(2px) scale(.9)}
.list-add-btn{margin-right:14px}

/* OVERLAY */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(6px);z-index:500;opacity:0;pointer-events:none;transition:opacity .3s}
.overlay.on{opacity:1;pointer-events:all}

/* BOTTOM SHEET */
.sheet{position:fixed;bottom:0;left:0;right:0;background:var(--s1);border-radius:28px 28px 0 0;border-top:1px solid var(--b);z-index:600;transform:translateY(110%);transition:transform .38s cubic-bezier(.16,1,.3,1);max-height:88dvh;overflow-y:auto}
.sheet.on{transform:translateY(0)}
.handle{width:40px;height:4px;background:var(--b);border-radius:2px;margin:14px auto 0}

/* SIZE SHEET */
.sheet-preview{display:flex;align-items:center;gap:14px;padding:16px;background:var(--s2);border-radius:14px;margin:16px}
.sheet-preview-img{width:72px;height:72px;object-fit:cover;border-radius:10px;flex-shrink:0;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:2rem;overflow:hidden}
.sheet-preview-img img{width:100%;height:100%;object-fit:cover}
.sheet-lbl{font-size:.65rem;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--muted);padding:0 20px 10px}
.sz-opt{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--b);cursor:pointer;transition:background .15s}
.sz-opt:last-child{border-bottom:none}
.sz-opt.sel{background:var(--adim)}
.sz-radio{width:22px;height:22px;border:2px solid var(--b);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0;transition:border-color .2s}
.sz-opt.sel .sz-radio{border-color:var(--accent)}
.sz-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);opacity:0;transition:opacity .2s}
.sz-opt.sel .sz-dot{opacity:1}
.sz-checkbox{width:22px;height:22px;border:2px solid var(--b);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-right:12px;flex-shrink:0;transition:all .2s}
.sz-opt.sel .sz-checkbox{border-color:var(--accent);background:var(--accent)}
.sz-checkbox .sz-dot{width:14px;height:14px;background:transparent;opacity:0}
.sz-opt.sel .sz-checkbox .sz-dot{opacity:1;background:url('data:image/svg+xml;utf8,<svg viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="4" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"></polyline></svg>') center/contain no-repeat}
.sz-name{font-size:.9rem;font-weight:600}
.sz-price{font-size:.9rem;font-weight:800;color:var(--accent)}
.sheet-cta{display:block;width:calc(100% - 32px);margin:16px;padding:17px;background:var(--accent);border:none;border-radius:14px;color:#fff;font-size:1rem;font-weight:800;font-family:var(--font);cursor:pointer;box-shadow:0 8px 24px rgba(240,80,35,.4);transition:transform .1s}
.sheet-cta:active{transform:scale(.97)}

/* CART SHEET */
.cart-item-row{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--b)}
.cart-item-row:last-child{border-bottom:none}
.ci-emoji{font-size:1.6rem;width:44px;text-align:center;flex-shrink:0}
.ci-name{font-size:.88rem;font-weight:700;flex:1}
.ci-size{font-size:.72rem;color:var(--muted)}
.ci-price{font-size:.95rem;font-weight:800;color:var(--accent)}
.ci-rm{width:28px;height:28px;background:var(--s2);border:1px solid var(--b);border-radius:8px;color:var(--muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s}
.ci-rm:hover{background:rgba(239,68,68,0.1);color:#ef4444;border-color:rgba(239,68,68,0.2)}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;font-weight:700}

/* CART FAB */
.cart-bar{position:fixed;bottom:0;left:0;right:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom,0px));background:rgba(10,10,10,.97);border-top:1px solid var(--b);backdrop-filter:blur(20px);z-index:400;transform:translateY(110%);transition:transform .35s cubic-bezier(.16,1,.3,1)}
.cart-bar.on{transform:translateY(0)}
.cart-bar-inner{display:flex;align-items:center;gap:12px;background:var(--accent);border-radius:14px;padding:15px 18px;cursor:pointer}
.cb-badge{background:rgba(0,0,0,.25);border-radius:8px;padding:4px 10px;font-size:.75rem;font-weight:800;white-space:nowrap;flex-shrink:0}
.cb-label{flex:1;text-align:center;font-size:.95rem;font-weight:800;letter-spacing:.5px}
.cb-total{font-size:1rem;font-weight:800;flex-shrink:0}

/* MISC */
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ei{font-size:3rem;margin-bottom:12px}
.spacer{height:120px}
.divider{height:1px;background:var(--b);margin:0 16px}
