:root{
  --brand:#0b6e4f; --brand2:#0d8a63; --accent:#ff7a45;
  --ink:#1c2733; --muted:#6b7a89; --line:#e8edf1; --bg:#f5f7f9; --card:#fff;
  --ok:#1f8a4c; --warn:#e0a800; --bad:#d64545; --radius:14px;
  --shadow:0 2px 10px rgba(18,39,51,.08);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5}
a{color:var(--brand2);text-decoration:none}
img{max-width:100%;display:block}
#app{max-width:760px;margin:0 auto;min-height:100vh;background:var(--bg);position:relative;padding-bottom:78px}
.hidden{display:none!important}

/* Top bar */
.topbar{position:sticky;top:0;z-index:20;background:var(--brand);color:#fff;padding:14px 16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}
.topbar h1{font-size:18px;margin:0;font-weight:700;letter-spacing:.2px}
.topbar .sub{font-size:11px;opacity:.85;margin-top:2px}
.topbar .spacer{flex:1}
.iconbtn{background:rgba(255,255,255,.16);border:none;color:#fff;width:38px;height:38px;border-radius:10px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative}
.badge{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:10px;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}

/* Search */
.searchwrap{padding:12px 16px;background:var(--brand);position:sticky;top:64px;z-index:15}
.searchbox{display:flex;align-items:center;background:#fff;border-radius:12px;padding:10px 14px;box-shadow:var(--shadow)}
.searchbox input{border:none;outline:none;flex:1;font-size:15px;color:var(--ink);background:transparent}
.searchbox .si{color:var(--brand);font-size:16px;margin-right:8px}

/* Layout */
.wrap{padding:16px}
.section-title{font-size:15px;font-weight:700;margin:18px 16px 8px}
.chips{display:flex;gap:8px;overflow-x:auto;padding:10px 16px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:13px;cursor:pointer;white-space:nowrap}
.chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}

/* Cards */
.grid{display:grid;grid-template-columns:1fr;gap:12px;padding:0 16px}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.itemcard{display:flex;gap:12px;padding:12px}
.itemcard .thumb{width:84px;height:84px;border-radius:10px;background:#eef2f4 center/cover no-repeat;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#9bb;font-size:24px}
.itemcard .body{flex:1;min-width:0}
.itemcard .name{font-weight:700;font-size:15px}
.itemcard .vend{font-size:12px;color:var(--muted);margin-top:2px}
.vendorcard{display:flex;gap:12px;padding:12px}
.vendorcard .thumb{width:84px;height:84px;border-radius:10px;background:#eef2f4 center/cover no-repeat;flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#9bb;font-size:30px}
.vendorcard .body{flex:1;min-width:0}
.vendorcard .name{font-weight:800;font-size:16px}
.vendorcard .vend{font-size:12px;color:var(--muted);margin-top:2px}
/* Category cards (Zomato-style entry points) */
.catlist{display:flex;flex-direction:column;gap:10px;padding:0 16px}
.catcard{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.catcard:active{transform:scale(.985)}
.catcard .cicon{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;display:flex;align-items:center;justify-content:center;font-size:23px;flex:0 0 auto}
.catcard .cmeta{flex:1;min-width:0}
.catcard .cname{font-weight:700;font-size:16px}
.catcard .csub{font-size:12px;color:var(--muted);margin-top:1px}
.catcard .cchev{color:var(--muted);font-size:26px;font-weight:300;line-height:1}
/* Auth note banner on login */
.authnote{margin:0 16px 4px;background:#eef6f1;color:var(--brand);border:1px solid #d6ebe0;border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;text-align:center}
.itemcard .desc{font-size:12px;color:var(--muted);margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.row{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}
.price{font-weight:800;color:var(--ink)}
.stars{color:var(--warn);font-size:12px}
.muted{color:var(--muted);font-size:12px}
.tag{font-size:10px;background:#eef6f1;color:var(--brand);padding:2px 7px;border-radius:6px;font-weight:600;text-transform:capitalize}
.tag.svc{background:#fff0e8;color:var(--accent)}
.offline{font-size:10px;background:#fdecec;color:var(--bad);padding:2px 7px;border-radius:6px;font-weight:600}
.online{font-size:10px;background:#e7f6ec;color:var(--ok);padding:2px 7px;border-radius:6px;font-weight:600}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--brand);color:#fff;border:none;border-radius:10px;padding:11px 16px;font-size:14px;font-weight:700;cursor:pointer}
.btn:active{transform:scale(.98)}
.btn.block{width:100%}
.btn.block+.btn.block{margin-top:8px}
.iconbtn.back{font-size:24px;font-weight:300}
.btn.sm{padding:7px 12px;font-size:13px}
.btn.alt{background:var(--accent)}
.btn.ghost{background:#fff;color:var(--brand);border:1px solid var(--brand)}
.btn.gray{background:#eef2f4;color:var(--ink)}
.btn.danger{background:var(--bad)}
.btn:disabled{opacity:.5}

/* Forms */
.field{margin-bottom:12px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;outline:none;background:#fff;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand)}
.form-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin:16px}
.logo-row{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.logo-preview{width:72px;height:72px;border-radius:16px;background:#eef2f4 center/cover no-repeat;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:30px;border:1px solid var(--line)}
.logo-field{flex:1;min-width:0}
.logo-field label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.logo-field input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;outline:none;background:#fff;font-family:inherit}
.logo-field input:focus{border-color:var(--brand)}

/* Login */
.tabs{display:flex;background:#fff;border-radius:12px;overflow:hidden;margin:16px;box-shadow:var(--shadow)}
.tabs button{flex:1;padding:13px;border:none;background:#fff;font-weight:700;font-size:14px;cursor:pointer;color:var(--muted)}
.tabs button.active{background:var(--brand);color:#fff}
.hero{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;padding:30px 20px 22px;text-align:center}
.hero h2{margin:0 0 4px;font-size:24px}
.hero p{margin:0;opacity:.9;font-size:14px}

/* Bottom nav */
.bottomnav{position:fixed;bottom:0;left:0;right:0;max-width:760px;margin:0 auto;background:#fff;border-top:1px solid var(--line);display:flex;z-index:30}
.bottomnav button{flex:1;border:none;background:none;padding:9px 0 7px;font-size:10px;color:var(--muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}
.bottomnav button .ic{font-size:19px}
.bottomnav button.active{color:var(--brand);font-weight:700}

/* Status pill */
.pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;display:inline-block}
.pill.pending{background:#fff6e5;color:#a87b00}
.pill.confirmed{background:#e6f0ff;color:#2563c9}
.pill.preparing{background:#fff0e8;color:var(--accent)}
.pill.awaited_pickup{background:#f0ecff;color:#6b46c1}
.pill.on_way{background:#e7f6ec;color:var(--ok)}
.pill.complete{background:#e7f6ec;color:var(--ok)}
.pill.payment_received{background:#dff5e6;color:#0a7a3d}
.pill.cancelled{background:#fdecec;color:var(--bad)}
.pill.requested{background:#fff6e5;color:#a87b00}
.pill.approved{background:#e7f6ec;color:var(--ok)}
.pill.rejected{background:#fdecec;color:var(--bad)}

/* Timeline */
.timeline{margin:10px 0}
.timeline .step{display:flex;gap:10px;align-items:flex-start;padding:4px 0}
.timeline .dot{width:12px;height:12px;border-radius:50%;background:var(--brand);margin-top:4px;flex:0 0 auto}
.timeline .step.future .dot{background:var(--line)}
.timeline .ln{font-size:13px}

/* Misc */
.empty{text-align:center;color:var(--muted);padding:50px 20px}
.empty .big{font-size:40px;margin-bottom:8px}
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);background:#1c2733;color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;z-index:100;box-shadow:var(--shadow);max-width:90%}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:60;display:flex;align-items:flex-end;justify-content:center}
.modal{background:#fff;border-radius:18px 18px 0 0;width:100%;max-width:760px;padding:20px;max-height:88vh;overflow:auto}
.modal h3{margin:0 0 14px}
.modal .close{position:absolute;top:10px;right:14px;font-size:22px;color:#fff;cursor:pointer}
.list-row{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--line)}
.list-row:last-child{border-bottom:none}

/* Offers & promotions */
.offerbadge{display:inline-block;background:#e7f6ec;color:#0b6e4f;font-weight:700;font-size:12px;padding:3px 9px;border-radius:20px;margin-top:6px}
.offerbanner{background:linear-gradient(90deg,#0b6e4f,#13966b);color:#fff;font-weight:700;font-size:14px;padding:10px 14px;border-radius:12px;margin:0 16px 12px}
.mrp{color:var(--muted);text-decoration:line-through;font-size:13px;margin-left:8px}
.offpct{color:#0b6e4f;font-weight:700;font-size:12px;margin-left:6px}

/* Filter bar */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;padding:10px 16px;overflow-x:auto}
.fchip{border:1px solid var(--line);background:#fff;color:var(--ink,#1c2733);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}
.fchip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.fsort{margin-left:auto;border:1px solid var(--line);border-radius:10px;padding:6px 10px;font-size:13px;background:#fff}

/* Blocked screen */
.blocked-screen{max-width:420px;margin:60px auto;text-align:center;padding:30px 22px}
.blocked-screen .big{font-size:48px;margin-bottom:14px}
.blocked-screen h2{margin:0 0 10px;color:var(--bad,#d23f3f)}
.blocked-screen p{color:var(--muted);margin:0 0 18px}

/* Master admin */
.masterbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#1c2733;color:#fff;font-size:13px;padding:8px 16px}
.masterbar b{color:#ffd479}
.masterbar .btn{margin-left:auto}
.storelist{display:flex;flex-direction:column;gap:10px}
.storepick{display:block;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;cursor:pointer}
.storepick.on{border-color:var(--brand);box-shadow:0 0 0 2px rgba(0,0,0,.04)}
.storepick .sp-name{font-weight:700;font-size:16px;margin-bottom:4px}
.storepick .sp-meta{color:var(--muted);font-size:13px}
.qtybtn{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:#fff;font-size:16px;cursor:pointer}
.stat{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;text-align:center}
.stat .n{font-size:22px;font-weight:800;color:var(--brand)}
.stat .l{font-size:11px;color:var(--muted);margin-top:2px}
.statgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding:0 16px}
.center{text-align:center}
.spin{width:30px;height:30px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:sp 1s linear infinite;margin:40px auto}
@keyframes sp{to{transform:rotate(360deg)}}
.ratepick{display:flex;gap:6px;font-size:30px;color:var(--line);cursor:pointer;justify-content:center;margin:8px 0}
.ratepick .on{color:var(--warn)}
.fab{position:fixed;right:18px;bottom:92px;background:var(--brand);color:#fff;width:54px;height:54px;border-radius:50%;border:none;font-size:26px;box-shadow:var(--shadow);cursor:pointer;z-index:25;max-width:760px}
