:root{
  --brand:#E8623D; --brand-dark:#C44A28; --ink:#2A211C; --muted:#655749;
  --cream:#FBF6EF; --card:#FFFFFF; --line:#EFE6DA; --good:#2E7D52; --focus:#2563A8;
  --shadow:0 6px 24px rgba(42,33,28,.08); --shadow-lg:0 18px 50px rgba(42,33,28,.18);
  --r-sm:10px; --r-md:14px; --r-lg:18px; --pill:999px;
  --t-xs:11px; --t-sm:13px; --t-md:14px; --t-lg:17px; --t-xl:23px; --t-2xl:26px;
  --nav-h:60px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
html{min-height:100%;background:var(--cream)}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--cream);color:var(--ink);max-width:480px;margin:0 auto;min-height:100vh;position:relative;-webkit-font-smoothing:antialiased;}
.app{padding-bottom:118px}
.scrollx{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:linear-gradient(90deg,#000 90%,transparent);mask-image:linear-gradient(90deg,#000 90%,transparent)}
.scrollx::-webkit-scrollbar{display:none}
button{font-family:inherit;cursor:pointer;transition:transform .1s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease}
button:focus-visible, [role=button]:focus-visible, .rcard:focus-visible{outline:3px solid var(--focus);outline-offset:2px}
@media(hover:hover){
  .rcard:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
  .addbtn:hover,.paybtn:hover,.composer button:hover{background:var(--brand-dark)}
  .chip:hover{background:var(--brand);color:#fff}
  .citytab:hover,.kindtab:hover,.ownerlink:hover,.otab:hover,.acct:hover{border-color:var(--ink)}
  .qstep button:hover,.back:hover,.close:hover,.again:hover{border-color:var(--ink)}
  .ai-launch:hover{box-shadow:var(--shadow-lg)}
  .navbtn:hover{color:var(--ink)}
}
header{position:sticky;top:0;z-index:40;background:rgba(251,246,239,.92);
  backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:10px;padding:14px 16px;}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;letter-spacing:-.4px;cursor:pointer}
.logo .dot{width:26px;height:26px;border-radius:var(--pill);background:var(--brand);display:grid;place-items:center;color:#fff;font-size:15px}
.logo b{color:var(--brand)}
.back{border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);width:40px;height:40px;font-size:20px;display:none;align-items:center;justify-content:center}
.tagline{margin-left:auto;font-size:var(--t-xs);color:var(--muted);text-align:right;line-height:1.3}
.tagline b{color:var(--good)}
.acct{border:1px solid var(--line);background:#fff;width:38px;height:38px;border-radius:50%;font-size:15px;display:flex;align-items:center;justify-content:center;margin-left:8px;flex:0 0 auto}
.hero{padding:16px 16px 4px}
.hero h1{font-size:24px;line-height:1.14;margin:0 0 6px;letter-spacing:-.6px}
.hero p{margin:0;color:var(--muted);font-size:var(--t-md);line-height:1.5}
.pillrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.pill{background:#fff;border:1px solid var(--line);border-radius:var(--pill);padding:7px 12px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px}
.pill .ic{color:var(--brand)}
.searchwrap{padding:12px 16px 0}
.searchbox{width:100%;border:1px solid var(--line);border-radius:var(--pill);padding:12px 16px;font-size:14px;background:#fff;outline:none}
.searchbox:focus{border-color:var(--brand)}
.section-label{padding:14px 16px 6px;font-size:var(--t-sm);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.citytabs{display:flex;gap:8px;padding:12px 16px 2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:linear-gradient(90deg,#000 92%,transparent);mask-image:linear-gradient(90deg,#000 92%,transparent)}
.citytabs::-webkit-scrollbar{display:none}
.citytab{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:var(--pill);padding:10px 15px;font-size:var(--t-sm);font-weight:700;color:var(--muted);display:flex;align-items:center;gap:6px}
.citytab .cpin{font-size:10px;color:var(--line)}
.citytab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.citytab.on .cpin{color:var(--brand)}
.kindrow{display:flex;gap:8px;padding:10px 16px 2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:linear-gradient(90deg,#000 92%,transparent);mask-image:linear-gradient(90deg,#000 92%,transparent)}
.kindrow::-webkit-scrollbar{display:none}
.kindtab{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:var(--pill);padding:7px 13px;font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap}
.kindtab.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.pop{font-size:10px;font-weight:800;padding:2px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px;background:#FCEFD9;color:#9C6206}
.rcard{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);margin:10px 16px;overflow:hidden;box-shadow:var(--shadow);cursor:pointer}
.rcard:active{transform:scale(.99)}
.rcard.is-feat{border-color:var(--brand);box-shadow:0 0 0 2px rgba(232,98,61,.22), var(--shadow)}
.rbanner{height:120px;display:flex;align-items:center;justify-content:center;font-size:50px;position:relative;background-size:cover;background-position:center}
.bemoji{filter:drop-shadow(0 6px 10px rgba(42,33,28,.20))}
.rbadge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,.96);color:var(--good);font-size:var(--t-xs);font-weight:800;padding:5px 9px;border-radius:var(--pill);display:flex;align-items:center;gap:5px;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.feat{position:absolute;top:10px;right:10px;background:var(--ink);color:#fff;font-size:var(--t-xs);font-weight:800;padding:5px 9px;border-radius:var(--pill);box-shadow:0 2px 6px rgba(0,0,0,.2)}
.rbody{padding:12px 14px 14px}
.rtop{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.rtop h3{margin:0 0 3px;font-size:var(--t-lg);letter-spacing:-.3px}
.favbtn{border:none;background:transparent;color:var(--brand);font-size:22px;line-height:1;padding:0;flex:0 0 auto;margin-top:-2px}
.rmeta{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:12.5px;flex-wrap:wrap}
.rmeta .star{color:#B8740B}
.rblurb{margin:8px 0 0;color:var(--muted);font-size:var(--t-sm);line-height:1.45}
#view-restaurant{display:none}
.rhead-banner{height:170px;display:flex;align-items:center;justify-content:center;font-size:70px;background-size:cover;background-position:center}
.rhead-info{padding:16px}
.rhead-info h2{margin:0 0 6px;font-size:var(--t-xl);letter-spacing:-.5px}
.rstory{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;margin:12px 0 4px;font-size:var(--t-sm);color:var(--muted);line-height:1.5}
.rstory b{color:var(--ink)}
.realnote{margin:8px 0 0;font-size:12px;color:var(--muted);background:#F3ECE2;border-radius:var(--r-sm);padding:8px 11px;line-height:1.45}
.dinerbanner{margin:0 16px 4px;background:#FBEAE5;border:1px solid #E8C7BD;color:#8A3A22;border-radius:var(--r-md);padding:10px 13px;font-size:13px;font-weight:600;line-height:1.4}
.menucat{padding:18px 16px 4px;font-size:15px;font-weight:800;letter-spacing:-.2px}
.mitem{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);margin:8px 16px;padding:10px 12px}
.mthumb{width:58px;height:58px;border-radius:11px;display:grid;place-items:center;font-size:26px;flex:0 0 auto;background-size:cover;background-position:center;overflow:hidden}
.mthumb.dim{opacity:.45;filter:grayscale(.5)}
.mthumb.sm{width:44px;height:44px;font-size:20px;border-radius:9px}
.minfo{flex:1;min-width:0}
.minfo h4{margin:0 0 2px;font-size:14.5px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.minfo p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.4}
.minfo .modhint{color:var(--brand);font-weight:600}
.tag{font-size:10px;font-weight:800;padding:2px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px}
.tag.gf{background:#EAF5EE;color:#1F6B43}
.tag.v{background:#EAF2FB;color:#1F548F}
.tag.spicy{background:#FBEAEA;color:#A8301F}
.madd{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.mprice{font-weight:700;font-size:var(--t-md)}
.soldtag{font-size:11px;font-weight:800;color:#C44A28;background:#FBEAE5;padding:5px 9px;border-radius:8px}
.addbtn{border:none;background:var(--brand);color:#fff;width:40px;height:40px;border-radius:11px;font-size:22px;line-height:1;font-weight:600}
.addbtn:active{background:var(--brand-dark)}
.ai-launch{margin:16px;background:linear-gradient(135deg,#2A211C,#43342B);color:#fff;border-radius:var(--r-md);padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:var(--shadow)}
.ai-launch .spark{font-size:24px}
.ai-launch .t{flex:1}
.ai-launch .t b{display:block;font-size:14.5px;margin-bottom:2px}
.ai-launch .t span{font-size:12.5px;color:#E4D8CD}
.ai-launch .go{font-size:18px;opacity:.85}
.cartbar{position:fixed;left:0;right:0;bottom:var(--nav-h);max-width:480px;margin:0 auto;z-index:44;background:var(--brand);color:#fff;padding:13px 18px;display:none;align-items:center;justify-content:space-between;cursor:pointer;box-shadow:0 -8px 24px rgba(42,33,28,.12)}
.cartbar b{font-size:15px}
.cartbar .ct{background:rgba(255,255,255,.24);border-radius:8px;padding:3px 9px;font-size:var(--t-sm);font-weight:700;margin-right:8px}
.cartbar .cta{font-weight:800;display:flex;align-items:center;gap:6px}
.bottomnav{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;z-index:46;height:var(--nav-h);background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(10px);border-top:1px solid var(--line);display:flex;padding-bottom:env(safe-area-inset-bottom)}
.navbtn{flex:1;border:none;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;font-weight:700;color:var(--muted);padding:0;letter-spacing:.2px}
.navbtn span{font-size:19px;line-height:1}
.navbtn.on{color:var(--brand)}
.sheet-backdrop{position:fixed;inset:0;background:rgba(42,33,28,.45);z-index:60;display:none;opacity:0;transition:opacity .2s}
.sheet{position:fixed;left:0;right:0;bottom:0;max-width:480px;margin:0 auto;height:86vh;background:var(--cream);border-radius:22px 22px 0 0;z-index:61;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .26s cubic-bezier(.2,.8,.2,1);box-shadow:var(--shadow-lg)}
.sheet.open{transform:translateY(0)}
.sheet-head{padding:14px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.sheet-head .av{width:36px;height:36px;border-radius:var(--pill);background:var(--ink);color:#fff;display:grid;place-items:center;font-size:18px}
.sheet-head .ht{flex:1}
.sheet-head .ht b{display:block;font-size:15px}
.sheet-head .ht span{font-size:11.5px;color:var(--good);font-weight:600}
.sheet-head .close{border:1px solid var(--line);background:#fff;width:38px;height:38px;border-radius:var(--r-sm);font-size:17px}
.chat{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.msg{max-width:82%;padding:11px 14px;border-radius:16px;font-size:var(--t-md);line-height:1.45;white-space:pre-wrap}
.msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:5px}
.msg.me{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:5px}
.msg.note{align-self:center;background:#F3ECE2;color:var(--muted);font-size:12.5px;border-radius:var(--r-sm);max-width:90%;text-align:center}
.typing{align-self:flex-start;background:#fff;border:1px solid var(--line);padding:13px 16px;border-radius:16px;border-bottom-left-radius:5px}
.typing span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--muted);margin:0 2px;animation:bob 1s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes bob{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.chips{display:flex;gap:8px;flex-wrap:wrap;padding:0 16px 8px}
.chip{background:#fff;border:1px solid var(--brand);color:var(--brand);border-radius:var(--pill);padding:9px 14px;font-size:var(--t-sm);font-weight:600}
.chip:active{background:var(--brand);color:#fff}
.composer{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:var(--cream);align-items:center}
.composer input{flex:1;border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-size:15px;outline:none;background:#fff}
.composer input:focus{border-color:var(--brand)}
.composer .mic{border:1px solid var(--line);background:#fff;border-radius:12px;width:48px;height:46px;font-size:20px;display:none;align-items:center;justify-content:center}
.composer .mic.on{background:var(--brand);color:#fff;border-color:var(--brand);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(232,98,61,.5)}50%{box-shadow:0 0 0 8px rgba(232,98,61,0)}}
.composer .send{border:none;background:var(--brand);color:#fff;border-radius:12px;width:48px;height:46px;font-size:19px}
#view-checkout{display:none;padding:8px 0 20px}
.co-line{display:flex;justify-content:space-between;align-items:flex-start;padding:11px 16px;font-size:var(--t-md);border-bottom:1px solid var(--line)}
.comods{font-size:11.5px;color:var(--muted);margin:2px 0 0;line-height:1.35}
.qstep{display:inline-flex;align-items:center;gap:14px;margin-top:8px}
.qstep button{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:#fff;font-size:18px;line-height:1;color:var(--ink)}
.qstep span{font-size:var(--t-md);font-weight:700;min-width:16px;text-align:center}
.promorow{display:flex;gap:8px;padding:12px 16px 2px}
.promoinput{flex:1;border:1px solid var(--line);border-radius:10px;padding:11px 13px;font-size:13px;outline:none;text-transform:uppercase;background:#fff}
.promoinput:focus{border-color:var(--brand)}
.promobtn{border:1px solid var(--ink);background:#fff;color:var(--ink);border-radius:10px;padding:11px 16px;font-size:13px;font-weight:700}
.tiplabel{padding:14px 16px 0;font-size:12.5px;font-weight:700;color:var(--muted)}
.tiprow{display:flex;gap:8px;padding:8px 16px 2px;flex-wrap:wrap}
.tipbtn{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:var(--pill);padding:9px 14px;font-size:12.5px;font-weight:700}
.tipbtn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.co-tot{display:flex;justify-content:space-between;padding:12px 16px;font-size:var(--t-md)}
.co-tot.big{font-weight:800;font-size:var(--t-lg);border-top:2px solid var(--line);margin-top:4px;padding-top:14px}
.savecard{margin:16px;background:#EAF5EE;border:1px solid #CDE7D8;border-radius:var(--r-md);padding:14px 16px}
.savecard h4{margin:0 0 6px;color:#1F6B43;font-size:var(--t-md);display:flex;align-items:center;gap:7px}
.savecard p{margin:0;font-size:var(--t-sm);color:#2A211C;line-height:1.5}
.savecard .big{font-size:22px;font-weight:800;color:#1F6B43}
.paybtn{margin:8px 16px 4px;display:block;width:calc(100% - 32px);border:none;background:var(--brand);color:#fff;padding:16px;border-radius:var(--r-md);font-size:16px;font-weight:800}
.paybtn:active{background:var(--brand-dark)}
.demo-note{text-align:center;font-size:var(--t-xs);color:var(--muted);padding:8px 16px}
#view-done{display:none;text-align:center;padding:60px 24px}
#view-done .check{width:84px;height:84px;border-radius:var(--pill);background:var(--good);color:#fff;font-size:46px;display:grid;place-items:center;margin:0 auto 18px}
#view-done h2{margin:0 0 8px;font-size:24px}
#view-done p{color:var(--muted);font-size:var(--t-md);line-height:1.5;margin:0 auto;max-width:300px}
#view-done .again{margin-top:22px;border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px 22px;font-weight:700}
#view-owner,#view-account{display:none}
.odash{padding:16px}
.otabs{display:flex;gap:6px;margin:4px 0 14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-mask-image:linear-gradient(90deg,#000 93%,transparent);mask-image:linear-gradient(90deg,#000 93%,transparent)}
.otabs::-webkit-scrollbar{display:none}
.otab{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:var(--pill);padding:8px 14px;font-size:12.5px;font-weight:700;color:var(--muted);white-space:nowrap}
.otab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.ohero{background:linear-gradient(135deg,#1F6B43,#2E7D52);color:#fff;border-radius:var(--r-lg);padding:20px 18px;box-shadow:var(--shadow)}
.ohero .lbl{font-size:12px;opacity:.9;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.ohero .amt{font-size:36px;font-weight:800;margin:4px 0 2px;letter-spacing:-.5px}
.ohero .osub{font-size:12.5px;opacity:.92;line-height:1.5}
.loyalcard{background:linear-gradient(135deg,#5B3CC4,#7C5CD6);color:#fff;border-radius:var(--r-lg);padding:18px 18px 16px;box-shadow:var(--shadow)}
.loyalcard .lbl{font-size:12px;opacity:.9;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.loyalcard .amt{font-size:32px;font-weight:800;margin:4px 0 2px}
.loyalcard .osub{font-size:12.5px;opacity:.92;line-height:1.5}
.lbar{height:8px;background:rgba(255,255,255,.28);border-radius:99px;margin-top:12px;overflow:hidden}
.lfill{height:100%;background:#fff;border-radius:99px;transition:width .3s}
.redeembtn{margin-top:12px;border:none;background:#fff;color:#5B3CC4;border-radius:10px;padding:10px 16px;font-weight:800;font-size:13px}
.profcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:6px 14px}
.profrow{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid var(--line);gap:10px}
.profrow:last-child{border-bottom:none}
.profrow .pk{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;font-weight:700}
.profrow .pv{font-size:13.5px;font-weight:600;flex:1;text-align:right;margin-right:8px;overflow:hidden;text-overflow:ellipsis}
.ostatrow{display:flex;gap:10px;margin:12px 0 4px}
.ostat{flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:12px 8px;text-align:center}
.ostat b{display:block;font-size:18px}
.ostat span{font-size:10.5px;color:var(--muted)}
.orow{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px;margin:8px 0;gap:10px}
.orow b{display:block;font-size:13px}
.orow span{font-size:11px;color:var(--muted)}
.okept{color:var(--good);font-weight:800;font-size:13px;white-space:nowrap}
.oqsum{font-size:12.5px;color:var(--muted);margin:0 0 8px;font-weight:600}
.ocard{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:12px 14px;margin:8px 0}
.ohd{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.ostatus{font-size:10.5px;font-weight:800;padding:3px 9px;border-radius:var(--pill);text-transform:uppercase;letter-spacing:.4px}
.st-new{background:#FBEAE5;color:#C44A28}
.st-prep{background:#FCEFD9;color:#9C6206}
.st-ready{background:#EAF5EE;color:#1F6B43}
.otime{font-size:11px;color:var(--muted)}
.oitems{font-size:13.5px;font-weight:600;margin-bottom:9px}
.ofoot{display:flex;justify-content:space-between;align-items:center;gap:10px}
.ocust{font-size:12px;color:var(--muted)}
.oadv{border:none;background:var(--brand);color:#fff;border-radius:10px;padding:9px 13px;font-size:12.5px;font-weight:700;white-space:nowrap}
.addbtn2{width:100%;border:1px dashed var(--brand);background:#fff;color:var(--brand);border-radius:var(--r-md);padding:12px;font-size:13.5px;font-weight:700;margin:0 0 6px}
.mrow{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px;margin:8px 0;gap:10px}
.mrow b{font-size:13.5px}.mrow .mp{font-size:12.5px;color:var(--muted)}
.mgrow{flex:1;min-width:0}
.mgrow .modcount{display:block;font-size:11px;color:var(--brand);font-weight:600;margin-top:2px}
.medit{display:flex;gap:6px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.ebtn{border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:var(--pill);padding:6px 11px;font-size:11.5px;font-weight:700}
.ebtn.del{border-color:#E1B8AD;color:#C44A28}
.soldbtn{flex:0 0 auto;border:1px solid #BFE0CC;background:#EAF5EE;color:#1F6B43;border-radius:var(--pill);padding:6px 11px;font-size:11.5px;font-weight:700;white-space:nowrap}
.soldbtn.off{border-color:#E1B8AD;background:#FBEAE5;color:#C44A28}
.rvreply{margin-top:8px;background:#F3ECE2;border-radius:var(--r-sm);padding:8px 10px;font-size:12.5px;color:var(--ink);line-height:1.4}
.rvreply b{color:var(--good)}
.hrow{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px;margin:8px 0;gap:12px}
.hrow.col{flex-direction:column;align-items:stretch}
.hrow b{font-size:14px;display:block;margin-bottom:2px}.hrow span{font-size:11.5px;color:var(--muted)}
.tgl{flex:0 0 auto;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:var(--pill);padding:9px 16px;font-size:13px;font-weight:800;min-width:80px}
.tgl.on{background:var(--good);color:#fff;border-color:var(--good)}
.tgl.warn{background:var(--brand-dark);color:#fff;border-color:var(--brand-dark)}
.prepwrap{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.prepbtn{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:var(--pill);padding:8px 12px;font-size:12px;font-weight:600}
.prepbtn.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.footer{padding:24px 16px 14px;text-align:center;color:var(--muted);font-size:var(--t-xs);line-height:1.6}
.footer b{color:var(--brand)}
.ownerlink{display:inline-block;margin:14px auto 0;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:var(--pill);padding:10px 16px;font-size:12.5px;font-weight:700}
.empty{padding:30px 24px;text-align:center;color:var(--muted);font-size:var(--t-sm)}
.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 16px);transform:translateX(-50%) translateY(18px);background:var(--ink);color:#fff;padding:11px 16px;border-radius:var(--pill);font-size:13px;font-weight:600;opacity:0;pointer-events:none;transition:all .25s ease;z-index:80;max-width:88%;text-align:center;box-shadow:var(--shadow-lg)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.modsheet{height:auto;max-height:84vh}
.modbody{flex:1;overflow-y:auto;padding:6px 16px 10px}
.modgroup{margin:14px 0 4px}
.modglabel{font-size:13.5px;font-weight:800;margin-bottom:8px;display:flex;justify-content:space-between;align-items:baseline}
.modglabel span{font-size:11px;color:var(--muted);font-weight:600;text-transform:none;letter-spacing:0}
.modopt{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);background:#fff;border-radius:var(--r-md);padding:11px 13px;margin:6px 0;font-size:13.5px;cursor:pointer;gap:10px}
.modopt.on{border-color:var(--brand);background:#FDEEE8}
.modopt .moname{flex:1}
.modopt .moprice{color:var(--muted);font-size:12.5px}
.modopt .modot{width:20px;height:20px;border-radius:50%;border:2px solid var(--line);flex:0 0 auto;display:grid;place-items:center}
.modopt.on .modot{border-color:var(--brand)}
.modopt.on .modot::after{content:"";width:10px;height:10px;border-radius:50%;background:var(--brand)}
.modfoot{padding:12px 16px;border-top:1px solid var(--line);background:var(--cream)}
.modfoot .paybtn{margin:0;width:100%}
/* Desktop: present the mobile app as a deliberate centered column on a warm backdrop */
@media(min-width:540px){
  html{background:radial-gradient(120% 80% at 50% 0%, #EFE3D4 0%, #E3D5C2 60%, #DCCDB8 100%);background-attachment:fixed}
  body{box-shadow:0 0 0 1px rgba(42,33,28,.06), 0 30px 90px rgba(42,33,28,.22)}
}
