:root{
  /* Brand */
  --orange:#ff5a1f; --orange-d:#e44a14; --orange-50:#fff4ef; --orange-100:#ffe2d4;
  --green:#0c9d61; --amber:#f6a609; --red:#e23b3b;
  /* Neutrals (cleaner, cooler greys + higher-contrast text) */
  --bg:#f6f7f9; --card:#fff; --ink:#15181e; --ink-2:#3c424d; --muted:#646b76; --border:#ebedf0;
  /* Elevation — soft, layered, low-spread */
  --sh-1:0 1px 2px rgba(18,22,33,.05), 0 1px 3px rgba(18,22,33,.04);
  --sh-2:0 4px 14px rgba(18,22,33,.08);
  --sh-3:0 14px 34px rgba(18,22,33,.13);
  --shadow:var(--sh-1);
  /* Spacing — 8pt system (4px half-step) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:20px; --s6:24px; --s7:32px; --s8:40px;
  /* Radius */
  --r1:10px; --r2:14px; --r3:18px; --r4:24px;
  /* Motion */
  --ease:cubic-bezier(.2,.7,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);line-height:1.45;-webkit-font-smoothing:antialiased;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-feature-settings:'cv11','ss01';letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* Topbar */
.topbar{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.6) blur(12px);
  -webkit-backdrop-filter:saturate(1.6) blur(12px);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 var(--s4);height:56px}
.brand{font-size:19px;font-weight:800;color:var(--orange);display:flex;align-items:center;gap:var(--s2);white-space:nowrap;letter-spacing:-.02em}
.brand i{font-size:21px}
.brand img{height:26px;width:auto;display:block}
.nav{display:flex;align-items:center;gap:var(--s1)}
.nav a{display:flex;align-items:center;gap:var(--s2);min-height:40px;padding:0 var(--s3);border-radius:var(--r1);
  color:var(--ink-2);font-weight:600;font-size:14px;position:relative;transition:background .15s,color .15s}
.nav a:hover{background:var(--bg);color:var(--ink)}
.nav a.who{color:var(--ink)}
/* icon-only actions (profile / logout) get a balanced square tap target */
.nav a:not(.who):has(>i:only-child){width:40px;padding:0;justify-content:center;color:var(--muted);font-size:18px}
.nav a:not(.who):has(>i:only-child):hover{color:var(--ink)}
.nav .badge{position:absolute;top:3px;right:5px;background:var(--orange);color:#fff;border-radius:20px;font-size:10px;padding:1px 6px;font-weight:700}
@media(max-width:640px){.nav a span{display:none}.brand span{display:none}}

/* Layout */
.wrap{max-width:1100px;margin:0 auto;padding:22px 18px 60px}
.wrap-wide{max-width:1320px;margin:0 auto;padding:22px 18px 60px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:860px){.split{grid-template-columns:1fr}}

/* Headings — type scale: 28/22/18/16/14/13/11 */
h1{font-size:26px;font-weight:800;margin-bottom:var(--s1);letter-spacing:-.4px;line-height:1.18;color:var(--ink)}
h2{font-size:18px;font-weight:800;margin-bottom:var(--s3);letter-spacing:-.3px;line-height:1.25;color:var(--ink)}
.sub{color:var(--muted);font-size:14px;margin-bottom:var(--s4)}
.section-title{display:flex;align-items:center;justify-content:space-between;margin:var(--s6) 0 var(--s3)}

/* Page header — title + subtitle on the left, actions on the right */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s4);flex-wrap:wrap;margin-bottom:var(--s5)}
.page-head .ph-text{min-width:0}
.page-head h1{margin-bottom:2px}
.page-head .sub{margin-bottom:0}
.page-head .ph-actions{display:flex;gap:var(--s2);flex-wrap:wrap;align-items:center}
@media(max-width:600px){.page-head .ph-actions{width:100%}.page-head .ph-actions .btn{flex:1}}
.page-back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-weight:600;font-size:13px;margin-bottom:var(--s2)}
.page-back:hover{color:var(--ink)}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.card+.card{margin-top:14px}
.grid{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.grid{grid-template-columns:1fr}}

/* Restaurant card */
.rcard{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}
.rcard:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(20,25,40,.12)}
.rcard .thumb{height:140px;background:linear-gradient(135deg,#ffd9c7,#ffb38f);display:flex;align-items:center;justify-content:center;font-size:42px;color:#fff}
.rcard .body{padding:14px}
.rcard h3{font-size:16px;font-weight:700}
.rcard .meta{color:var(--muted);font-size:13px;margin-top:4px;display:flex;gap:12px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:4px;background:var(--bg);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;color:var(--muted)}
.chip.rate{background:#fff7e6;color:var(--amber)}
.chip.closed{background:#fdecec;color:var(--red)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:11px;
  border:none;cursor:pointer;font-size:15px;font-weight:700;transition:opacity .15s,transform .08s}
.btn:active{transform:scale(.98)}
.btn-block{width:100%}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-d)}
.btn-green{background:var(--green);color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-ghost{background:var(--bg);color:var(--ink);border:1px solid var(--border)}
.btn-danger{background:#fdecec;color:var(--red)}
.btn-sm{padding:7px 12px;font-size:13px;border-radius:9px}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1px solid var(--border);
  border-radius:11px;font-size:15px;background:var(--card);color:var(--ink);font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange)}
.errorlist{list-style:none;color:var(--red);font-size:13px;margin-top:4px}
.help{color:var(--muted);font-size:12px;margin-top:4px}

/* Auth */
.auth{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#ff5a1f,#ff8a3d)}
.auth-card{position:relative;background:var(--card);border-radius:20px;padding:34px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.auth-card .brand{justify-content:center;font-size:26px;margin-bottom:6px}
.auth-card .brand img{height:36px}
.staff-toggle{position:absolute;top:14px;right:14px;display:inline-flex;align-items:center;gap:6px;
  border:1px solid var(--border);background:#fff;color:var(--muted);font-size:12px;font-weight:600;
  padding:6px 10px;border-radius:999px;cursor:pointer;transition:all .15s ease}
.staff-toggle:hover{border-color:var(--orange);color:var(--orange)}
.staff-toggle i{font-size:14px}
.role-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.role-pick label{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 6px;border:1.5px solid var(--border);
  border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted)}
.role-pick input{display:none}
.role-pick input:checked+span{color:var(--orange)}
.role-pick label:has(input:checked){border-color:var(--orange);background:#fff4ef;color:var(--orange)}
.role-pick i{font-size:22px}

/* Map */
.map{height:420px;border-radius:16px;border:1px solid var(--border);z-index:1}
.map-sm{height:300px}

/* Menu list */
.menu-item{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.menu-item:last-child{border-bottom:none}
.menu-item .info{flex:1}
.menu-item .name{font-weight:700}
.menu-item .desc{color:var(--muted);font-size:13px}
.menu-item .price{font-weight:700;color:var(--orange);margin-top:4px}

/* Cart / order rows */
.row-line{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.row-line:last-child{border-bottom:none}
.qty{display:inline-flex;align-items:center;gap:10px}
.qty button{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--card);cursor:pointer;font-weight:700}
.pay-cod{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:var(--bg,#fafafa)}
.pay-cod i{font-size:24px;color:var(--brand,#ff5a1f)}
.pay-cod span{display:flex;flex-direction:column}
.pay-cod small{color:var(--muted)}
.totals{margin-top:12px}
.totals .t{display:flex;justify-content:space-between;padding:5px 0;color:var(--muted)}
.totals .grand{font-size:19px;font-weight:800;color:var(--ink);border-top:1px solid var(--border);margin-top:6px;padding-top:10px}
.totals .discount-line{color:var(--ok,#16a34a);font-weight:600}

/* Coupon box (checkout) */
.coupon-box{margin:14px 0 4px;padding:12px 0;border-top:1px solid var(--border)}
.coupon-input{display:flex;gap:8px}
.coupon-input input{flex:1;text-transform:uppercase}
.coupon-applied{display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:rgba(22,163,74,.08);border:1px solid rgba(22,163,74,.3);border-radius:10px;padding:8px 12px}
.coupon-applied .muted{color:var(--muted);font-weight:500;margin-left:4px}
.coupon-error{color:var(--danger,#dc2626);margin:6px 0 0}
.coupon-box .hidden,.totals .hidden{display:none}

/* Bulk coupon form */
.coupon-form .cf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.coupon-form .cf-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.chip-accent{background:rgba(255,107,44,.12);color:var(--accent,#FF6B2C);border-color:rgba(255,107,44,.3)}

/* Status pill */
.pill{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700}
.s-pending{background:#fff4e5;color:#b76e00}
.s-accepted,.s-preparing{background:#e8f0fe;color:#1a56db}
.s-ready,.s-assigned{background:#fff0f5;color:#c2186a}
.s-picked_up,.s-on_the_way{background:#e6f4ff;color:#0b76c4}
.s-delivered{background:#e6f7ef;color:var(--green)}
.s-cancelled{background:#fdecec;color:var(--red)}

/* Progress steps */
.steps{display:flex;justify-content:space-between;margin:18px 0;position:relative}
.steps::before{content:'';position:absolute;top:14px;left:5%;right:5%;height:3px;background:var(--border)}
.steps .bar{position:absolute;top:14px;left:5%;height:3px;background:var(--green);transition:width .4s}
.step{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}
.step .dot{width:30px;height:30px;border-radius:50%;background:var(--card);border:3px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px}
.step.done .dot{border-color:var(--green);background:var(--green);color:#fff}
.step small{font-size:11px;color:var(--muted);text-align:center}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow)}
.stat .n{font-size:28px;font-weight:800}
.stat .l{color:var(--muted);font-size:13px;font-weight:600}
.stat i{font-size:20px;color:var(--orange)}

/* Table */
.table{width:100%;border-collapse:collapse;font-size:14px}
.table th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;padding:10px;border-bottom:1px solid var(--border)}
.table td{padding:11px 10px;border-bottom:1px solid var(--border)}
.table tr:hover td{background:var(--bg)}

/* Toasts */
.toasts{position:fixed;top:72px;right:18px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--ink);color:#fff;padding:12px 18px;border-radius:11px;font-weight:600;font-size:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.2);transition:opacity .4s;max-width:340px}
.toast.success{background:var(--green)}.toast.error{background:var(--red)}.toast.info{background:#1a56db}
.toast.flash{opacity:0;transform:translateY(-8px);transition:opacity .35s ease,transform .35s ease}
.toast.flash.in{opacity:1;transform:none}

/* Avatar */
.avatar{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;color:#fff;background:var(--orange);flex-shrink:0;text-transform:uppercase}
.avatar.r-customer{background:#1a56db}.avatar.r-merchant{background:var(--orange)}
.avatar.r-rider{background:var(--green)}.avatar.r-admin{background:var(--ink)}
.user-cell{display:flex;align-items:center;gap:10px}

/* Filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.filters a{padding:7px 14px;border-radius:20px;background:var(--card);border:1px solid var(--border);font-size:13px;font-weight:600;color:var(--muted)}
.filters a.active{background:var(--orange);color:#fff;border-color:var(--orange)}
.searchbar{display:flex;gap:8px;margin-bottom:16px}
.searchbar input{flex:1}

.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty i{font-size:48px;display:block;margin-bottom:12px;opacity:.4}
.online-dot{width:9px;height:9px;border-radius:50%;display:inline-block;background:var(--muted)}
.online-dot.on{background:var(--green)}

/* Foodpanda-style customer home */
.hero{background:linear-gradient(120deg,#ff5a1f,#ff8a3d);border-radius:20px;padding:28px 26px;color:#fff;
  box-shadow:0 10px 30px rgba(255,90,31,.28);margin-bottom:22px}
.hero h1{font-size:30px;font-weight:800;margin-bottom:4px}
.hero .loc{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;opacity:.95;margin-bottom:14px;
  background:rgba(255,255,255,.18);padding:6px 13px;border-radius:20px;color:#fff;border:none;cursor:pointer;
  font-family:inherit;transition:background .15s}
.hero .loc:hover{background:rgba(255,255,255,.3)}
.hero .loc b{font-weight:700}

/* Modal */
.modal{position:fixed;inset:0;z-index:4000;background:rgba(15,18,25,.5);display:flex;align-items:center;justify-content:center;
  padding:18px;opacity:0;transition:opacity .2s}
.modal.open{opacity:1}
.modal-card{background:var(--card);border-radius:18px;padding:22px;width:100%;max-width:460px;box-shadow:0 24px 70px rgba(0,0,0,.3);
  transform:translateY(12px) scale(.98);transition:transform .25s cubic-bezier(.2,.8,.3,1.1)}
.modal.open .modal-card{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.modal-head h2{margin:0}
.modal-x{background:var(--bg);border:none;border-radius:10px;width:34px;height:34px;cursor:pointer;font-size:15px;color:var(--muted)}
.modal-x:hover{background:var(--border)}
.hero-search{display:flex;gap:10px;max-width:560px}
.hero-search input{flex:1;border:none;border-radius:13px;padding:14px 16px;font-size:15px;color:var(--ink)}
.hero-search input:focus{outline:3px solid rgba(255,255,255,.5)}
.hero-search .btn{background:var(--ink);color:#fff;border-radius:13px}

.cat-row{display:flex;gap:var(--s3);overflow-x:auto;padding:var(--s1) var(--s1) var(--s3);margin-bottom:var(--s2);
  scrollbar-width:none;-webkit-overflow-scrolling:touch}
.cat-row::-webkit-scrollbar{display:none}
.cat{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--s2);width:68px;text-align:center;
  font-size:12px;font-weight:600;color:var(--muted);transition:color .15s}
.cat .ic{width:60px;height:60px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:25px;
  background:var(--card);border:1px solid var(--border);box-shadow:var(--sh-1);color:var(--orange);
  transition:transform .18s var(--ease),background .18s,color .18s,border-color .18s,box-shadow .18s}
.cat:hover .ic{transform:translateY(-2px);border-color:var(--orange-100);box-shadow:var(--sh-2)}
.cat:active .ic{transform:scale(.94)}
.cat.active{color:var(--orange)}
.cat.active .ic{background:var(--orange);color:#fff;border-color:var(--orange);box-shadow:0 6px 16px rgba(255,90,31,.32)}
.cat span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:72px}

/* Card entrance — fades/rises in as it scrolls into view (JS toggles .in) */
.rcard.reveal{opacity:0;transform:translateY(20px);
  transition:opacity .6s cubic-bezier(.2,.7,.3,1),transform .6s cubic-bezier(.2,.7,.3,1)}
.rcard.reveal.in{opacity:1;transform:none}
/* Staggered cascade so cards revealed together cascade one after another */
.grid .rcard.reveal:nth-child(2n){transition-delay:.08s}
.rcard .thumb{position:relative;overflow:hidden}
.rcard .thumb img{position:relative;z-index:1;transition:transform .4s ease}
.rcard:hover .thumb img{transform:scale(1.08)}
.rcard .dist{position:absolute;left:10px;bottom:10px;background:rgba(0,0,0,.62);color:#fff;font-size:11px;
  font-weight:700;padding:3px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:4px}
.rcard .closed-ov{position:absolute;inset:0;background:rgba(255,255,255,.55);display:flex;align-items:center;
  justify-content:center;font-weight:800;color:var(--red);letter-spacing:.5px}
.rcard.feat{border:1.5px solid #ffd9c7}
.rail-head{display:flex;align-items:center;justify-content:space-between;margin:6px 0 12px}
.rail-head h2{margin:0;display:flex;align-items:center;gap:8px}
.rail-head .tag{font-size:12px;font-weight:700;color:var(--orange);background:#fff4ef;padding:4px 12px;border-radius:20px}

.maptoggle{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;font-weight:700;color:var(--orange);
  background:#fff4ef;border:none;padding:8px 14px;border-radius:20px}
.map.hidden{display:none}

/* Add-to-cart fly toast with arrow pointing at cart */
@keyframes badgeBump{0%{transform:scale(1)}40%{transform:scale(1.6)}100%{transform:scale(1)}}
.nav .badge.bump{animation:badgeBump .45s ease}
.cart-toast{position:fixed;z-index:3000;background:#fff;border:1px solid var(--border);border-radius:14px;
  box-shadow:0 14px 40px rgba(20,25,40,.22);padding:12px;display:flex;align-items:center;gap:12px;max-width:300px;
  opacity:0;transform:translateY(-10px) scale(.96);transition:opacity .28s ease,transform .28s cubic-bezier(.2,.8,.3,1.2)}
.cart-toast.in{opacity:1;transform:none}
.cart-toast img,.cart-toast .ct-noimg{width:46px;height:46px;border-radius:10px;object-fit:cover;flex-shrink:0}
.cart-toast .ct-noimg{background:linear-gradient(135deg,#ffd9c7,#ffb38f);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.cart-toast .ct-name{font-weight:700;font-size:14px;line-height:1.2;color:var(--ink)}
.cart-toast .ct-meta{font-size:12px;color:var(--green);font-weight:600;margin-top:2px;display:flex;align-items:center;gap:5px}
.cart-toast .ct-arrow{position:absolute;top:-8px;right:22px;width:16px;height:16px;background:#fff;
  border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg)}
@keyframes flyDot{0%{opacity:1;transform:translate(0,0) scale(1)}80%{opacity:1}100%{opacity:0;transform:var(--fly) scale(.2)}}
.fly-dot{position:fixed;z-index:3001;width:18px;height:18px;border-radius:50%;background:var(--orange);
  box-shadow:0 4px 12px rgba(255,90,31,.5);pointer-events:none;animation:flyDot .7s cubic-bezier(.4,.1,.7,1) forwards}

/* Restaurant gallery editor (merchant) */
.gallery-edit{display:flex;flex-wrap:wrap;gap:10px}
.gthumb{position:relative;width:92px;height:92px;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.gthumb img{width:100%;height:100%;object-fit:cover}
.gthumb .gdel{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.6);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px}
.gthumb .gdel:hover{background:var(--red)}

/* Branded map markers (Leaflet divIcons) — real icons, no emojis */
.mappin{position:relative;width:38px;height:38px;filter:drop-shadow(0 4px 5px rgba(0,0,0,.35))}
.mappin .pin{position:absolute;inset:0;border-radius:50% 50% 50% 0;transform:rotate(-45deg);
  display:flex;align-items:center;justify-content:center;border:2.5px solid #fff;box-sizing:border-box}
.mappin .pin i{transform:rotate(45deg);color:#fff;font-size:17px;line-height:1}
.mappin.shop  .pin{background:#ff5a1f}
.mappin.home  .pin{background:#111827}
.mappin.rider .pin{background:#16a34a}
.mappin.me    .pin{background:#2563eb}
.mappin.place .pin{background:#ff5a1f}
/* soft ground shadow dot under the tip */
.mappin::after{content:'';position:absolute;left:50%;bottom:-3px;width:10px;height:4px;border-radius:50%;
  background:rgba(0,0,0,.28);transform:translateX(-50%)}
/* gentle live pulse for the moving rider */
.mappin.rider .pin{animation:pinPulse 1.8s ease-in-out infinite}
@keyframes pinPulse{0%,100%{box-shadow:0 0 0 0 rgba(22,163,74,.45)}50%{box-shadow:0 0 0 8px rgba(22,163,74,0)}}

/* Cycling slideshow inside restaurant cards */
.thumb .slideshow{position:absolute;inset:0;z-index:1}
.thumb .slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;z-index:1;transition:opacity .8s ease}
.thumb .slide.on{opacity:1;z-index:2}
.thumb .slide.on.loading{opacity:0}  /* hold transparent until the image paints, then fade in */

/* Loading skeleton — shimmer sits behind the (lazy) image until it paints */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.rcard .thumb::before{content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(100deg,#ece6e1 25%,#f6f1ec 38%,#ece6e1 52%);background-size:200% 100%;
  animation:shimmer 1.5s linear infinite}
.skeleton{background:linear-gradient(100deg,#e9ebef 25%,#f3f4f7 38%,#e9ebef 52%);background-size:200% 100%;
  animation:shimmer 1.5s linear infinite;border-radius:var(--r2)}
@media(prefers-reduced-motion:reduce){
  .rcard .thumb::before,.skeleton{animation:none}
  .cat .ic,.bottom-nav a i{transition:none;animation:none}
  .rcard.reveal{transition:none;opacity:1;transform:none}
}

/* 21:9 auto-playing hero carousel (restaurant detail) */
.hero-carousel{position:relative;width:100%;aspect-ratio:21/9;border-radius:16px;overflow:hidden;
  background:#15171c;margin-bottom:16px;box-shadow:var(--shadow)}
.hero-carousel .hc-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 1s ease;image-rendering:auto}
.hero-carousel .hc-slide.on{opacity:1}
.hc-dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:2}
.hc-dots span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.55);transition:width .3s,background .3s}
.hc-dots span.on{background:#fff;width:20px;border-radius:6px}

/* ============================================================= */
/* Discovery screen redesign (customer restaurant list)          */
/* ============================================================= */
.disco{padding-top:var(--s2)}

/* Sticky address + search header */
.disco-bar{position:sticky;top:56px;z-index:900;display:flex;gap:var(--s2);align-items:stretch;
  background:var(--bg);padding:var(--s3) 0;margin-bottom:var(--s3)}
.disco-bar::after{content:'';position:absolute;left:0;right:0;bottom:0;height:14px;pointer-events:none;
  background:linear-gradient(var(--bg),rgba(246,247,249,0));transform:translateY(100%)}
.disco-bar .addr{display:inline-flex;align-items:center;gap:var(--s2);background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2);padding:0 var(--s3);min-height:48px;cursor:pointer;font-family:inherit;color:var(--ink);
  box-shadow:var(--sh-1);transition:border-color .15s,box-shadow .15s}
.disco-bar .addr:hover{border-color:#dcdfe4}
.disco-bar .addr>i:first-child{color:var(--orange);font-size:18px}
.disco-bar .addr span{display:flex;flex-direction:column;line-height:1.15;text-align:left;overflow:hidden}
.disco-bar .addr small{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.disco-bar .addr b{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.disco-bar .addr .caret{font-size:12px;color:var(--muted)}
.disco-search{flex:1;display:flex;align-items:center;gap:var(--s3);background:var(--card);border:1px solid var(--border);
  border-radius:var(--r2);padding:0 var(--s4);min-height:48px;box-shadow:var(--sh-1);
  transition:border-color .15s,box-shadow .15s}
.disco-search>i{color:var(--muted);font-size:18px}
.disco-search input{flex:1;border:none;background:none;padding:var(--s3) 0;font-size:15px;color:var(--ink);font-family:inherit}
.disco-search input::placeholder{color:var(--muted)}
.disco-search input:focus{outline:none}
.disco-search:focus-within{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,90,31,.14),var(--sh-1)}
.disco-search .clear{color:var(--muted);font-size:16px;display:flex}

/* "What are you craving?" hero — compact cover image that fades into the orange */
.craving{position:relative;display:flex;align-items:center;overflow:hidden;min-height:200px;
  background:linear-gradient(120deg,#ff5a1f,#ff8a3d);color:#fff;border-radius:var(--r3);
  margin-bottom:var(--s5);box-shadow:0 10px 26px rgba(255,90,31,.24)}
.craving-copy{position:relative;z-index:2;flex:1;min-width:0;max-width:56%;padding:var(--s5) var(--s6)}
.craving-copy h1{font-size:25px;font-weight:800;color:#fff;margin-bottom:var(--s1);letter-spacing:-.5px;line-height:1.1}
.craving-copy p{font-size:14px;opacity:.92;margin:0;max-width:28ch;line-height:1.4}
/* image stage bleeds to the right edge; the mask melts its left side into orange */
.craving-stage{position:absolute;top:0;right:0;bottom:0;width:56%;
  -webkit-mask:linear-gradient(to right,transparent 0,rgba(0,0,0,.6) 30%,#000 60%);
  mask:linear-gradient(to right,transparent 0,rgba(0,0,0,.6) 30%,#000 60%)}
.cshot{position:absolute;inset:0;display:block;background:#2a2a2a no-repeat center/cover;
  opacity:0;pointer-events:none;transition:opacity 1.4s ease}
.cshot.on{opacity:1;pointer-events:auto}
.cshot-meta{position:absolute;right:18px;bottom:16px;z-index:2;display:flex;flex-direction:column;
  align-items:flex-end;gap:7px;text-align:right}
.cshot-rate{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.95);
  color:#b8780a;font-size:12px;font-weight:800;padding:4px 10px;border-radius:20px}
.cshot-rate i{font-size:11px;color:var(--amber)}
.cshot-name{color:#fff;font-size:16px;font-weight:800;text-shadow:0 2px 8px rgba(0,0,0,.65);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}

/* Featured horizontal rail */
.rail-head{display:flex;align-items:center;justify-content:space-between;margin:10px 0 12px}
.rail-head h2{margin:0;display:flex;align-items:center;gap:8px}
.rail-head h2 i{color:var(--orange)}
.rail-nav{display:flex;gap:8px}
.rail-nav button{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--card);
  cursor:pointer;color:var(--ink);box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;
  font-size:15px;transition:background .15s,color .15s}
.rail-nav button:hover{background:var(--orange);color:#fff;border-color:var(--orange)}
.rail{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 2px 18px;scrollbar-width:none}
.rail::-webkit-scrollbar{display:none}
.rail-item{flex:0 0 300px;scroll-snap-align:start}
@media(max-width:600px){.rail-item{flex:0 0 82%}}

/* Results header + sort pills */
.results-head{display:flex;align-items:center;justify-content:space-between;gap:var(--s3);margin:var(--s5) 0 var(--s3)}
.results-head h2{margin:0;font-size:18px;font-weight:800;letter-spacing:-.3px}
.sortbar{display:flex;gap:var(--s2);overflow-x:auto;padding-bottom:var(--s4);margin-bottom:var(--s1);scrollbar-width:none}
.sortbar::-webkit-scrollbar{display:none}
.sortpill{flex:0 0 auto;display:inline-flex;align-items:center;gap:var(--s1);min-height:36px;padding:0 var(--s4);border-radius:999px;
  background:var(--card);border:1px solid var(--border);font-size:13px;font-weight:600;color:var(--ink-2);
  transition:border-color .15s,color .15s,background .15s,transform .08s}
.sortpill:hover{border-color:#d6d9df;color:var(--ink)}
.sortpill:active{transform:scale(.96)}
.sortpill.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.sortpill.active i{color:var(--amber)}
.maptoggle.active{background:var(--orange);color:#fff}

/* Premium restaurant card (overrides the base .rcard) */
.rcard{display:block;background:var(--card);border:1px solid var(--border);border-radius:var(--r3);overflow:hidden;
  box-shadow:var(--sh-1);transition:transform .16s var(--ease),box-shadow .16s var(--ease)}
.rcard:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
.rcard:active{transform:translateY(-1px) scale(.99);box-shadow:var(--sh-2);transition-duration:.06s}
.rcard .thumb{position:relative;width:100%;height:auto;aspect-ratio:16/9;overflow:hidden;
  background:linear-gradient(135deg,#ffd9c7,#ffb38f)}
/* bottom scrim so the ETA/closed pill stays legible on bright photos */
.rcard .thumb::after{content:'';position:absolute;inset:auto 0 0 0;height:46%;pointer-events:none;
  background:linear-gradient(to top,rgba(0,0,0,.35),transparent)}
.rcard .thumb .noimg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:46px;color:#fff;opacity:.9}
.rcard .fav{position:absolute;top:var(--s2);right:var(--s2);width:36px;height:36px;border-radius:50%;border:none;cursor:pointer;z-index:2;
  background:rgba(255,255,255,.94);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:16px;
  box-shadow:0 2px 8px rgba(0,0,0,.2);transition:transform .12s var(--ease)}
.rcard .fav:hover{transform:scale(1.12)}
.rcard .fav:active{transform:scale(.9)}
.rcard .fav.on{color:var(--red)}
.rcard .eta-pill{position:absolute;left:var(--s2);bottom:var(--s2);z-index:2;display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.96);color:var(--ink);font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:999px;box-shadow:0 2px 8px rgba(0,0,0,.16)}
.rcard .eta-pill i{font-size:11px;color:var(--orange)}
.rcard .closed-tag{position:absolute;left:var(--s2);bottom:var(--s2);z-index:2;background:rgba(21,24,30,.9);color:#fff;font-size:11px;
  font-weight:700;padding:5px 10px;border-radius:999px;letter-spacing:.3px}
.rcard.is-closed .slideshow,.rcard.is-closed .noimg{filter:grayscale(.55) brightness(.92)}
.rcard .body{padding:var(--s3) var(--s3) var(--s4)}
.rcard .title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s2)}
.rcard .title-row h3{font-size:16px;font-weight:800;line-height:1.25;letter-spacing:-.2px;color:var(--ink);
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.rcard .stars-row{display:flex;align-items:center;gap:6px;margin-top:var(--s1)}
.stars{--pct:100%;display:inline-block;position:relative;font-size:14px;line-height:1;letter-spacing:1px}
.stars::before{content:"★★★★★";color:var(--border)}
.stars::after{content:"★★★★★";color:var(--amber);position:absolute;inset:0;width:var(--pct);overflow:hidden;white-space:nowrap}
.rcard .rate-num{font-size:13px;font-weight:800;color:#9a6608}
.rcard .cuisine{color:var(--muted);font-size:13px;margin-top:var(--s1);display:flex;align-items:center;gap:var(--s2)}
.rcard .fee-row{margin-top:var(--s3);padding-top:var(--s3);border-top:1px solid var(--border)}
.rcard .fee{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-2)}
.rcard .fee i{font-size:14px;color:var(--muted)}

@media(max-width:760px){
  .craving{flex-direction:column;align-items:stretch;min-height:0}
  .craving-copy{max-width:100%;padding:var(--s4) var(--s5) var(--s1)}
  .craving-copy h1{font-size:21px}
  .craving-copy p{font-size:13px}
  .craving-stage{position:relative;width:100%;height:96px;
    -webkit-mask:linear-gradient(to bottom,transparent 0,rgba(0,0,0,.6) 16%,#000 40%);
    mask:linear-gradient(to bottom,transparent 0,rgba(0,0,0,.6) 16%,#000 40%)}
}
@media(max-width:640px){
  .disco-bar{top:0;flex-wrap:wrap}
  .disco-bar .addr{order:1;flex:1}
  .disco-search{order:2;flex:1 0 100%}
}

/* Mobile bottom tab bar (modern, with active indicator) */
.bottom-nav{display:none}
@media(max-width:640px){
  .bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:1500;
    background:rgba(255,255,255,.9);backdrop-filter:saturate(1.6) blur(14px);-webkit-backdrop-filter:saturate(1.6) blur(14px);
    border-top:1px solid var(--border);box-shadow:0 -6px 20px rgba(18,22,33,.07);
    padding:var(--s2) var(--s1) calc(var(--s2) + env(safe-area-inset-bottom));justify-content:space-around}
  .bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    min-height:44px;padding:4px 0;color:var(--muted);font-size:10.5px;font-weight:600;position:relative;
    transition:color .18s var(--ease)}
  .bottom-nav a i{font-size:21px;transition:transform .2s var(--ease)}
  .bottom-nav a:active i{transform:scale(.86)}
  .bottom-nav a.active{color:var(--orange)}
  .bottom-nav a.active i{transform:translateY(-1px)}
  /* active pill indicator above the label */
  .bottom-nav a.active::before{content:'';position:absolute;top:-1px;width:22px;height:3px;border-radius:3px;
    background:var(--orange);box-shadow:0 1px 6px rgba(255,90,31,.5)}
  .bottom-nav .badge{position:absolute;top:0;right:50%;margin-right:-22px;background:var(--orange);color:#fff;
    border-radius:20px;font-size:10px;padding:0 5px;font-weight:700;box-shadow:0 2px 6px rgba(255,90,31,.4)}
  .hide-mobile{display:none !important}
  body{padding-bottom:68px}
  .wrap,.wrap-wide{padding-top:var(--s4);padding-bottom:var(--s6)}
  .hero{padding:18px 18px 20px;border-radius:0 0 22px 22px;margin:0 -18px 18px}
  .hero h1{font-size:24px}
  .hero-search{flex-direction:column}
  .hero-search .btn{width:100%}
  .cat .ic{width:56px;height:56px;font-size:22px}
  h1{font-size:22px}
}

/* ── Rider new-order alert sheet ───────────────────────────── */
.req-sheet{position:fixed;inset:0;z-index:1200;display:flex;align-items:flex-end;
  justify-content:center;pointer-events:none;background:rgba(15,20,30,0);
  transition:background .25s ease}
.req-sheet.open{pointer-events:auto;background:rgba(15,20,30,.38)}
.req-sheet-card{width:100%;max-width:460px;background:var(--card);
  border-radius:20px 20px 0 0;box-shadow:0 -8px 30px rgba(20,25,40,.22);
  padding:10px 18px 22px;transform:translateY(110%);transition:transform .28s cubic-bezier(.22,1,.36,1)}
.req-sheet.open .req-sheet-card{transform:translateY(0)}
.req-grip{width:40px;height:4px;border-radius:4px;background:var(--border);margin:4px auto 12px}
.req-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.req-head b{display:block;font-size:16px}
.req-head small{color:var(--muted);font-size:12.5px}
.req-ping{flex:none;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;color:#fff;background:var(--orange);font-size:18px;
  box-shadow:0 0 0 0 rgba(255,90,31,.55);animation:reqping 1.4s ease-out infinite}
@keyframes reqping{0%{box-shadow:0 0 0 0 rgba(255,90,31,.5)}
  70%{box-shadow:0 0 0 14px rgba(255,90,31,0)}100%{box-shadow:0 0 0 0 rgba(255,90,31,0)}}
.req-meta{display:flex;flex-wrap:wrap;gap:10px 18px;font-size:13.5px;color:var(--ink);
  background:var(--bg);border-radius:12px;padding:11px 14px;margin-bottom:16px}
.req-meta i{color:var(--orange)}
.req-actions{display:flex;gap:10px;justify-content:flex-end}
.req-actions form{margin:0}
@media(min-width:560px){.req-sheet{align-items:center}
  .req-sheet-card{border-radius:20px;transform:translateY(24px) scale(.96);opacity:0;
    transition:transform .25s ease,opacity .25s ease}
  .req-sheet.open .req-sheet-card{transform:none;opacity:1}}

/* ── Admin "customer preview" bar (restaurant applications) ─── */
.preview-bar{position:sticky;top:0;z-index:1100;display:flex;align-items:center;
  justify-content:space-between;gap:12px;margin:-4px 0 16px;padding:11px 16px;
  background:#1d2026;color:#fff;border-radius:14px;box-shadow:0 6px 20px rgba(20,25,40,.18)}
.preview-bar form{margin:0}
.pv-back{display:inline-flex;align-items:center;gap:6px;color:#cfd3da;text-decoration:none;
  font-size:13.5px;font-weight:600;white-space:nowrap}
.pv-back:hover{color:#fff}
.pv-label{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700}
.pv-tag{font-size:11px;font-weight:800;padding:2px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}
.pv-tag.pending{background:rgba(246,166,9,.2);color:#f6a609}
.pv-tag.live{background:rgba(12,157,97,.22);color:#34d399}
@media(max-width:560px){.pv-back span,.pv-label .pv-tag{display:none}}
