/*
 * main.css — Paobee Bakery PWA
 * Mobile-first styles (all screens, components, and animations)
 *
 * TABLE OF CONTENTS:
 *   1. ROOT VARIABLES & RESET
 *   2. SPLASH SCREEN
 *   3. SCREENS & KEYFRAME ANIMATIONS
 *   4. TOP BAR & BOTTOM NAV
 *   5. HOME — Hero, Stats Strip, About, Categories
 *   6. SHOP — Product Cards, Search Bar, Reorder
 *   7. CART & CHECKOUT — Items, Summary, Promo, Payment, Schedule
 *   8. ORDER TRACKING — Progress Bar, History Cards, Ratings
 *   9. LOYALTY / POINTS
 *  10. SETTINGS — Profile, Preferences, Payment Methods
 *  11. MANAGER — Tabs, Order Cards, Product Cards, Analytics
 *  12. MODALS — Product Detail, Edit/Add Product, Add Payment
 *  13. DELIVERY ZONES — Leaflet map, zone rows, status badges
 *  14. AUTH SCREENS — Login, Signup, OTP, User Pill
 *  15. UTILITY — Empty states, WhatsApp button, misc helpers
 */

/* ============================================================
   PAOBEE — Bakery PWA  |  paobee.html
   ------------------------------------------------------------
   STRUCTURE:
   1. ROOT & RESET
   2. SPLASH SCREEN
   3. SCREENS & ANIMATIONS
   4. TOP BAR & NAV
   5. HOME (hero, stats, about, categories)
   6. SHOP (product cards, search)
   7. CART & CHECKOUT (items, summary, promo, payment, schedule)
   8. ORDER TRACKING (progress, history, ratings)
   9. LOYALTY / POINTS
  10. SETTINGS (profile, prefs, payment methods)
  11. MANAGER (orders, products, schedule, analytics)
  12. MODALS (product, edit, add, payment method)
  13. UTILITY
   ============================================================ */

/* ────────── ROOT & RESET ────────────────────────────────────── */

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --pink:#E8587A;
  --pl:#FDF0F3;
  --pm:#F9D4DF;
  --cream:#FAF7F4;
  --card:#fff;
  --text:#1a1a1a;
  --muted:#888;
  --border:#F0E8EC;
  --sub:#555;
  --ibg:#fff;
  --sbg:#FAF7F4
}
body.dark{
  --cream:#1a1118;
  --card:#251c22;
  --text:#f0e8ec;
  --muted:#a08898;
  --border:#3a2a35;
  --sub:#c0a8b8;
  --ibg:#2e2028;
  --sbg:#1a1118;
  --pl:#3a1528;
  --pm:#4a1f30
}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--text);
  max-width:430px;
  margin:0 auto;
  min-height:100vh;
  overflow-x:hidden
}
.about-body{padding:18px}
.about-body h3{
  font-family:Georgia,serif;
  font-size:18px;
  margin-bottom:8px;
  color:var(--text)
}
.about-body p{
  font-size:13px;
  color:var(--sub);
  line-height:1.8;
  margin-bottom:10px
}
.pcard-body{padding:10px 12px}
body.dark .bnav{background:rgba(26,17,24,0.97)}

/* ────────── SPLASH SCREEN ───────────────────────────────────── */

#splash{
  position:fixed;
  inset:0;
  background:var(--pink);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  z-index:9999;
  animation:splashOut 0.5s ease 2s forwards
}
.splash-logo{
  font-family:Georgia,serif;
  font-size:48px;
  color:#fff;
  margin-bottom:6px
}
.splash-tag{
  font-size:13px;
  color:rgba(255,255,255,.8);
  letter-spacing:2px;
  text-transform:uppercase
}
.splash-dots{display:flex;gap:8px;margin-top:28px}
.splash-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:rgba(255,255,255,.4);
  animation:dp 1.2s ease infinite
}
.splash-dot:nth-child(2){animation-delay:.2s}
.splash-dot:nth-child(3){animation-delay:.4s}

/* ────────── SCREENS & ANIMATIONS ────────────────────────────── */

@keyframes splashOut{99%{visibility:visible}100%{opacity:0;visibility:hidden;pointer-events:none}}
@keyframes dp{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}
.screen{display:none;padding-bottom:90px;min-height:100vh}
.screen.active{display:block;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ────────── TOP BAR & NAV ───────────────────────────────────── */

.topbar{
  background:var(--cream);
  padding:16px 20px 8px;
  position:sticky;
  top:0;
  z-index:10;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between
}
.logo{font-family:Georgia,serif;font-size:22px;color:var(--pink)}
.cart-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:50px;
  padding:8px 14px;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px
}
.cc{
  background:#fff;
  color:var(--pink);
  border-radius:50%;
  width:18px;
  height:18px;
  font-size:11px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center
}
.bnav{
  position:fixed;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:100%;
  max-width:430px;
  background:rgba(250,247,244,0.97);
  border-top:1px solid var(--border);
  display:flex;
  z-index:100;
  padding:8px 0 12px
}
.nav-item{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:3px;
  cursor:pointer;
  padding:4px 0;
  position:relative
}
.nav-icon{font-size:20px;line-height:1}
.nav-lbl{font-size:10px;font-weight:500;color:var(--muted)}
.nav-item.active .nav-lbl{color:var(--pink)}
.nav-dot{
  width:4px;
  height:4px;
  border-radius:50%;
  background:var(--pink);
  margin-top:1px;
  opacity:0
}
.nav-item.active .nav-dot{opacity:1}
.nav-badge{
  position:absolute;
  top:2px;
  right:10px;
  background:var(--pink);
  color:#fff;
  border-radius:50%;
  width:16px;
  height:16px;
  font-size:9px;
  font-weight:700;
  display:none;
  align-items:center;
  justify-content:center
}
.nav-badge.show{display:flex}

/* ────────── HOME – HERO ─────────────────────────────────────── */

.hero-wrap{
  position:relative;
  margin:12px 16px;
  border-radius:24px;
  overflow:hidden;
  min-height:260px;
  display:flex;
  align-items:flex-end
}
.hero-bg{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,#F9D4DF,#FDE8F0);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:110px;
  opacity:1
}
.hero-wrap::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to right,rgba(253,224,235,0.92) 45%,rgba(253,224,235,0.1) 100%);
  border-radius:24px;
  pointer-events:none;
  z-index:1
}
.hero-content{position:relative;padding:24px;width:100%;z-index:2}
.hero-tag{
  font-size:11px;
  font-weight:500;
  color:var(--pink);
  letter-spacing:1.5px;
  text-transform:uppercase;
  margin-bottom:8px
}
.hero-title{
  font-family:Georgia,serif;
  font-size:30px;
  line-height:1.15;
  margin-bottom:10px;
  color:var(--text)
}
.hero-title em{color:var(--pink);font-style:italic}
.hero-sub{
  font-size:13px;
  color:var(--sub);
  line-height:1.6;
  max-width:240px;
  margin-bottom:20px
}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}

/* ────────── HOME – STATS STRIP ──────────────────────────────── */

.astrip{
  display:flex;
  margin:14px 16px 0;
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  overflow:hidden
}
.astat{
  flex:1;
  padding:14px 12px;
  text-align:center;
  border-right:1px solid var(--border)
}
.astat:last-child{border-right:none}
.astat-num{
  font-family:Georgia,serif;
  font-size:20px;
  color:var(--pink);
  font-weight:600
}
.astat-lbl{font-size:11px;color:var(--muted);margin-top:2px}

/* ────────── HOME – ABOUT & CATS ─────────────────────────────── */

.about-card{
  margin:12px 16px;
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  overflow:hidden
}
.about-img{
  width:100%;
  height:130px;
  background:linear-gradient(135deg,#F9D4DF,var(--pm));
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:56px
}
.about-tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:12px
}
.about-tag{
  background:var(--pl);
  color:var(--pink);
  font-size:11px;
  font-weight:600;
  padding:5px 12px;
  border-radius:50px
}
.sec{padding:18px 16px 8px}
.sec-hdr{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  margin-bottom:12px
}
.sec-title{font-family:Georgia,serif;font-size:19px;color:var(--text)}
.sec-title em{color:var(--pink);font-style:italic}
.see-all{
  font-size:13px;
  color:var(--pink);
  cursor:pointer;
  font-weight:500
}
.cats{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding-bottom:4px;
  scrollbar-width:none
}
.cats::-webkit-scrollbar{display:none}
.cat{
  flex-shrink:0;
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:14px;
  padding:9px 13px;
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
  color:var(--text)
}
.cat.active{background:var(--pink);color:#fff;border-color:var(--pink)}

/* ────────── SHOP – PRODUCT CARDS ────────────────────────────── */

.pgrid{
  padding:4px 16px;
  display:grid;
  grid-template-columns:1fr;
  gap:16px
}
.pcard{
  background:var(--card);
  border-radius:20px;
  overflow:hidden;
  border:1px solid var(--border);
  cursor:pointer;
  position:relative
}
.pcard-img{
  width:100%;
  height:220px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:64px;
  overflow:hidden;
  position:relative
}
.pcard-img img{width:100%;height:100%;object-fit:cover}
.sold-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.5);
  display:flex;
  align-items:center;
  justify-content:center
}
.sold-badge{
  background:#fff;
  color:#1a1a1a;
  font-size:11px;
  font-weight:700;
  padding:5px 12px;
  border-radius:50px
}
.low-badge{
  position:absolute;
  bottom:6px;
  left:6px;
  background:#FFF3CD;
  color:#7B4A00;
  font-size:10px;
  font-weight:700;
  padding:3px 8px;
  border-radius:50px
}
.pcard-cat{
  font-size:10px;
  font-weight:500;
  color:var(--pink);
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:3px
}
.pcard-name{
  font-family:Georgia,serif;
  font-size:16px;
  font-weight:600;
  margin-bottom:4px;
  line-height:1.3;
  color:var(--text)
}
.star-mini{
  font-size:11px;
  color:var(--muted);
  margin-bottom:5px;
  display:block
}
.pcard-desc{
  font-size:11px;
  color:var(--muted);
  margin-bottom:8px;
  line-height:1.5;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden
}
.pcard-row{display:flex;align-items:center;justify-content:space-between}
.pcard-price{font-size:15px;font-weight:600;color:var(--pink)}
.add-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:50%;
  width:28px;
  height:28px;
  font-size:18px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center
}
.add-btn:disabled{background:var(--border);cursor:not-allowed}
.feat-badge{
  background:var(--pink);
  color:#fff;
  font-size:10px;
  font-weight:600;
  padding:3px 8px;
  border-radius:50px;
  display:inline-block;
  margin-bottom:4px
}

/* ────────── REORDER CARDS ───────────────────────────────────── */

.reorder-card{
  margin:0 16px 10px;
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  padding:12px 14px;
  display:flex;
  align-items:center;
  gap:12px
}
.reorder-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0;
  overflow:hidden
}
.reorder-icon img{width:100%;height:100%;object-fit:cover}
.reorder-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:10px;
  padding:8px 14px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  white-space:nowrap;
  margin-left:auto
}

/* ────────── SEARCH BAR ──────────────────────────────────────── */

.search-bar{padding:10px 16px}
.search-wrap{position:relative}
.search-inp{
  width:100%;
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:14px;
  padding:11px 16px 11px 40px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  color:var(--text);
  outline:none
}
.search-ico{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  color:var(--muted);
  font-size:16px;
  pointer-events:none
}

/* ────────── CART & CART ITEMS ───────────────────────────────── */

.cart-empty{text-align:center;padding:60px 24px}
.cart-empty-icon{font-size:56px;margin-bottom:16px}
.cart-empty h3{
  font-family:Georgia,serif;
  font-size:22px;
  margin-bottom:8px;
  color:var(--text)
}
.cart-empty p{color:var(--muted);font-size:14px;margin-bottom:24px}
.cart-items{padding:16px}
.cart-item{
  background:var(--card);
  border-radius:16px;
  padding:14px;
  margin-bottom:10px;
  display:flex;
  gap:12px;
  align-items:center;
  border:1px solid var(--border)
}
.ci-img{
  width:56px;
  height:56px;
  border-radius:12px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  flex-shrink:0;
  overflow:hidden
}
.ci-img img{width:100%;height:100%;object-fit:cover}
.qty-ctrl{display:flex;align-items:center;gap:8px}
.qty-btn{
  background:var(--pl);
  border:none;
  border-radius:8px;
  width:26px;
  height:26px;
  font-size:16px;
  cursor:pointer;
  color:var(--pink);
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center
}
.qty-num{
  font-size:14px;
  font-weight:600;
  min-width:16px;
  text-align:center;
  color:var(--text)
}

/* ────────── CHECKOUT ────────────────────────────────────────── */

.co-section{padding:16px}
.co-card{
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  padding:18px;
  margin-bottom:12px
}
.co-card h3{
  font-family:Georgia,serif;
  font-size:16px;
  color:var(--text);
  margin-bottom:14px
}
.fld{margin-bottom:13px}
.flbl{
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:5px;
  display:block;
  text-transform:uppercase;
  letter-spacing:.4px
}
.finp{
  width:100%;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:11px 14px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  color:var(--text);
  outline:none;
  background:var(--ibg)
}
.finp:focus{border-color:var(--pink)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.del-opts{display:flex;gap:10px;margin-bottom:14px}
.del-opt{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:12px;
  cursor:pointer;
  text-align:center;
  background:var(--card)
}
.del-opt.active{border-color:var(--pink);background:var(--pl)}
.del-opt-icon{font-size:22px;margin-bottom:4px}
.del-opt-lbl{font-size:12px;font-weight:600;color:var(--text)}
.del-opt-sub{font-size:11px;color:var(--muted)}
.sum-card{
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  padding:18px;
  margin-bottom:12px
}
.sum-row{
  display:flex;
  justify-content:space-between;
  font-size:14px;
  margin-bottom:8px;
  color:var(--text)
}
.sum-row.total{
  font-weight:700;
  font-size:16px;
  border-top:1px solid var(--border);
  padding-top:12px;
  margin-top:4px
}
.place-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:16px;
  width:100%;
  padding:16px;
  font-family:'DM Sans',sans-serif;
  font-size:15px;
  font-weight:600;
  cursor:pointer
}

/* ────────── PROMO & PAYMENT ─────────────────────────────────── */

.promo-row{display:flex;gap:8px;margin-bottom:10px}
.promo-inp{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:11px 14px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  color:var(--text);
  outline:none;
  background:var(--ibg)
}
.promo-btn{
  background:var(--pl);
  color:var(--pink);
  border:none;
  border-radius:12px;
  padding:11px 16px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif
}
.promo-ok{
  font-size:12px;
  color:#2E7D32;
  padding:6px 10px;
  background:#E8F5E9;
  border-radius:8px;
  margin-bottom:8px;
  font-weight:600
}
.promo-err{
  font-size:12px;
  color:#C0392B;
  padding:6px 10px;
  background:#FFF0F0;
  border-radius:8px;
  margin-bottom:8px;
  font-weight:600
}
.pay-opts{display:flex;flex-direction:column;gap:8px}
.pay-opt{
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  cursor:pointer;
  background:var(--card);
  display:flex;
  align-items:center;
  gap:10px
}
.pay-opt.active{border-color:var(--pink);background:var(--pl)}
.pay-opt-lbl{font-size:13px;font-weight:600;color:var(--text)}
.pay-opt-sub{font-size:11px;color:var(--muted)}
.pay-note{
  font-size:12px;
  color:var(--muted);
  background:var(--sbg);
  border-radius:10px;
  padding:10px 12px;
  margin-top:10px;
  line-height:1.6
}

/* ────────── SCHEDULING SLOTS ────────────────────────────────── */

.date-slots{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding-bottom:4px;
  scrollbar-width:none;
  margin-bottom:10px
}
.date-slots::-webkit-scrollbar{display:none}
.dslot{
  flex-shrink:0;
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:14px;
  padding:10px 14px;
  text-align:center;
  cursor:pointer;
  min-width:64px
}
.dslot.active{background:var(--pink);border-color:var(--pink)}
.dslot.disabled{opacity:.4;cursor:not-allowed}
.dslot-day{
  font-size:11px;
  font-weight:500;
  color:var(--muted);
  margin-bottom:2px
}
.dslot.active .dslot-day,.dslot.active .dslot-num{color:#fff}
.dslot-num{font-size:18px;font-weight:700;color:var(--text)}
.tslots{display:flex;gap:8px;flex-wrap:wrap}
.tslot{
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:8px 12px;
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  color:var(--text)
}
.tslot.active{background:var(--pink);border-color:var(--pink);color:#fff}

/* ────────── LOYALTY / POINTS ────────────────────────────────── */

.lrb{
  background:linear-gradient(135deg,var(--pl),var(--card));
  border:1.5px solid var(--pm);
  border-radius:14px;
  padding:14px;
  margin-bottom:14px
}
.lrb-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px
}
.lrb-title{font-size:14px;font-weight:600;color:var(--text)}
.lrb-pts{font-size:13px;color:var(--pink);font-weight:600}
.tog-sw{
  position:relative;
  width:44px;
  height:26px;
  cursor:pointer;
  flex-shrink:0
}
.tog-sw input{opacity:0;width:0;height:0}
.tog-sl{
  position:absolute;
  inset:0;
  background:var(--border);
  border-radius:26px;
  transition:.3s
}
.tog-sl:before{
  content:'';
  position:absolute;
  width:20px;
  height:20px;
  left:3px;
  bottom:3px;
  background:#fff;
  border-radius:50%;
  transition:.3s
}
.tog-sw input:checked+.tog-sl{background:var(--pink)}
.tog-sw input:checked+.tog-sl:before{transform:translateX(18px)}
.loyalty-card{
  margin:0 16px 14px;
  background:linear-gradient(135deg,#E8587A,#C03060);
  border-radius:20px;
  padding:20px;
  color:#fff;
  position:relative;
  overflow:hidden
}
.loy-tag{
  font-size:11px;
  font-weight:600;
  letter-spacing:1.5px;
  text-transform:uppercase;
  opacity:.8;
  margin-bottom:6px
}
.loy-pts{
  font-family:Georgia,serif;
  font-size:36px;
  font-weight:600;
  margin-bottom:2px
}
.loy-sub{font-size:13px;opacity:.8;margin-bottom:12px}
.loy-bg{
  background:rgba(255,255,255,.25);
  border-radius:50px;
  height:8px;
  margin-bottom:6px
}
.loy-fill{background:#fff;border-radius:50px;height:8px}
.loy-hint{font-size:12px;opacity:.8}
.loy-acts{display:flex;gap:8px;margin-top:14px}
.loy-btn{
  flex:1;
  background:rgba(255,255,255,.2);
  border:1.5px solid rgba(255,255,255,.4);
  border-radius:12px;
  padding:10px;
  font-size:13px;
  font-weight:600;
  color:#fff;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  text-align:center
}
.loy-btn.red{background:#fff;color:var(--pink);border-color:#fff}
.pts-hcard{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  overflow:hidden;
  margin:0 16px 14px
}
.pts-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  border-bottom:1px solid var(--border)
}
.pts-row:last-child{border-bottom:none}
.pts-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:15px;
  margin-right:10px;
  flex-shrink:0
}
.pts-earn{color:#2E7D32;font-size:14px;font-weight:700}
.pts-spend{color:var(--pink);font-size:14px;font-weight:700}
.pts-pend{color:var(--muted);font-size:14px;font-weight:700}
.pts-stats-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:8px;
  padding:0 16px;
  margin-bottom:12px
}

/* ────────── ORDER SUCCESS ───────────────────────────────────── */

.success-screen{text-align:center;padding:60px 24px}
.success-icon{font-size:64px;margin-bottom:16px}
.success-screen h2{
  font-family:Georgia,serif;
  font-size:26px;
  color:var(--text);
  margin-bottom:8px
}
.success-screen p{
  font-size:14px;
  color:var(--muted);
  margin-bottom:24px;
  line-height:1.6
}

/* ────────── ORDER TRACKING ──────────────────────────────────── */

.track-tabs{display:flex;padding:0 16px;border-bottom:1px solid var(--border)}
.track-tab{
  flex:1;
  padding:12px 0;
  font-size:13px;
  font-weight:600;
  color:var(--muted);
  cursor:pointer;
  text-align:center;
  border-bottom:2px solid transparent;
  background:none;
  border-top:none;
  border-left:none;
  border-right:none;
  font-family:'DM Sans',sans-serif
}
.track-tab.active{color:var(--pink);border-bottom-color:var(--pink)}
.aoc{
  background:var(--card);
  border-radius:20px;
  border:1px solid var(--border);
  margin:16px;
  overflow:hidden
}
.aoc-hdr{background:linear-gradient(135deg,var(--pm),var(--pl));padding:16px 20px}
.aoc-num{
  font-size:11px;
  font-weight:600;
  color:var(--pink);
  letter-spacing:1px;
  text-transform:uppercase;
  margin-bottom:2px
}
.aoc-name{
  font-family:Georgia,serif;
  font-size:18px;
  color:var(--text);
  margin-bottom:4px
}
.aoc-meta{
  font-size:12px;
  color:var(--muted);
  display:flex;
  gap:12px;
  flex-wrap:wrap
}
.prog-sec{padding:22px 20px 14px}
.prog-track{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:18px
}
.prog-bg{
  position:absolute;
  top:50%;
  left:0;
  right:0;
  height:3px;
  background:var(--border);
  transform:translateY(-50%);
  z-index:0
}
.prog-fill{
  position:absolute;
  top:50%;
  left:0;
  height:3px;
  background:var(--pink);
  transform:translateY(-50%);
  z-index:1;
  transition:width .6s
}
.prog-step{position:relative;z-index:2}
.prog-dot{
  width:36px;
  height:36px;
  border-radius:50%;
  border:3px solid var(--border);
  background:var(--card);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:700;
  color:var(--muted)
}
.prog-dot.done{background:var(--pink);border-color:var(--pink);color:#fff}
.prog-dot.act{
  background:var(--card);
  border-color:var(--pink);
  color:var(--pink);
  box-shadow:0 0 0 5px var(--pl)
}
.prog-labels{display:flex;justify-content:space-between}
.prog-lbl{
  font-size:10px;
  font-weight:500;
  text-align:center;
  color:var(--muted);
  width:70px;
  line-height:1.3
}
.prog-lbl.act{color:var(--pink);font-weight:700}
.status-msg{
  background:var(--pl);
  border-radius:12px;
  padding:12px 16px;
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 20px 14px
}
.status-msg-icon{font-size:20px}
.status-msg-txt{font-size:13px;color:var(--pink);font-weight:500}
.ois{padding:0 20px 14px}
.oi-title{
  font-size:11px;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:8px
}
.oi-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px
}
.oi-img{
  width:38px;
  height:38px;
  border-radius:10px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  flex-shrink:0;
  overflow:hidden
}
.oi-img img{width:100%;height:100%;object-fit:cover}
.oi-name{
  flex:1;
  font-size:13px;
  font-weight:500;
  color:var(--text)
}
.oi-qty{font-size:12px;color:var(--muted)}
.oi-price{font-size:13px;font-weight:600;color:var(--pink)}
.ot{padding:12px 20px 14px;border-top:1px solid var(--border)}

/* ────────── ORDER HISTORY ───────────────────────────────────── */

.hcard{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  margin:0 16px 10px;
  overflow:hidden;
  cursor:pointer
}
.hcard-h{
  padding:14px 16px;
  display:flex;
  align-items:center;
  gap:12px
}
.hcard-img{
  width:44px;
  height:44px;
  border-radius:12px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  flex-shrink:0;
  overflow:hidden
}
.hcard-img img{width:100%;height:100%;object-fit:cover}
.hcard-top{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  margin-bottom:2px
}
.hcard-num{font-size:13px;font-weight:700;color:var(--text)}
.hcard-price{font-size:13px;font-weight:700;color:var(--pink)}
.hcard-items{font-size:12px;color:var(--muted);margin-bottom:3px}
.hcard-meta{
  display:flex;
  gap:6px;
  align-items:center;
  flex-wrap:wrap
}
.hcard-date{font-size:11px;color:var(--muted)}
.spill{
  font-size:10px;
  font-weight:600;
  padding:2px 8px;
  border-radius:50px
}
.s-completed{background:#E8F5E9;color:#2E7D32}
.s-confirmed{background:#D1ECF1;color:#0C4A57}
.s-preparing{background:#FFE8CC;color:#7A3B00}
.s-on_the_way{background:#E3F2FD;color:#1565C0}
.s-cancelled{background:#F8D7DA;color:#721C24}
.hcard-exp{padding:0 16px 14px;border-top:1px solid var(--border)}
.hcard-ei{
  display:flex;
  justify-content:space-between;
  font-size:12px;
  color:var(--text);
  padding:4px 0
}
.ptsb{
  background:var(--pl);
  color:var(--pink);
  font-size:10px;
  font-weight:600;
  padding:2px 7px;
  border-radius:50px
}

/* ────────── RATINGS ─────────────────────────────────────────── */

.rating-prompt{
  background:var(--card);
  border-radius:16px;
  border:1.5px solid var(--pink);
  padding:14px;
  margin-bottom:10px
}
.star-picker{display:flex;gap:6px;margin:10px 0}
.star-pick{
  font-size:24px;
  cursor:pointer;
  opacity:.25;
  transition:opacity .15s
}
.star-pick.lit{opacity:1}
.rate-submit{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:10px;
  padding:9px 18px;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:600;
  cursor:pointer
}
.rate-skip{
  background:none;
  border:none;
  font-size:12px;
  color:var(--muted);
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  margin-left:10px
}

/* ────────── SETTINGS ────────────────────────────────────────── */

.s-hero{
  background:linear-gradient(135deg,var(--pm),var(--pl));
  margin:12px 16px;
  border-radius:20px;
  padding:20px;
  display:flex;
  align-items:center;
  gap:14px
}
.s-avatar{
  width:58px;
  height:58px;
  border-radius:50%;
  background:var(--pink);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  color:#fff;
  font-weight:700;
  font-family:Georgia,serif;
  flex-shrink:0
}
.s-name{
  font-family:Georgia,serif;
  font-size:20px;
  color:var(--text);
  margin-bottom:2px
}
.s-phone{font-size:13px;color:var(--muted)}
.stitle{
  font-size:11px;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:8px;
  padding:0 4px
}
.sgroup{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  overflow:hidden;
  margin-bottom:16px
}
.srow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid var(--border)
}
.srow:last-child{border-bottom:none}
.srow-left{display:flex;align-items:center;gap:12px}
.srow-icon{
  width:34px;
  height:34px;
  border-radius:10px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  flex-shrink:0
}
.srow-lbl{font-size:14px;font-weight:500;color:var(--text)}
.lang-sel{
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:7px 12px;
  font-size:13px;
  font-weight:500;
  color:var(--text);
  background:var(--ibg);
  font-family:'DM Sans',sans-serif;
  cursor:pointer;
  outline:none
}

/* ────────── PAYMENT METHODS ─────────────────────────────────── */

.pm-card{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  padding:14px 16px;
  margin-bottom:10px;
  display:flex;
  align-items:center;
  gap:12px
}
.pm-icon{
  width:42px;
  height:42px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0
}
.pm-label{font-size:14px;font-weight:600;color:var(--text)}
.pm-sub{font-size:12px;color:var(--muted)}
.pm-rem{
  background:none;
  border:none;
  color:#C0392B;
  font-size:18px;
  cursor:pointer;
  padding:4px;
  margin-left:auto
}
.add-pm-btn{
  background:var(--card);
  border:1.5px dashed var(--border);
  border-radius:16px;
  width:calc(100% - 32px);
  margin:0 16px 12px;
  padding:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-size:14px;
  font-weight:600;
  color:var(--pink);
  cursor:pointer;
  font-family:'DM Sans',sans-serif
}
.pm-type-row{display:flex;gap:8px;margin-bottom:14px}
.pm-type-btn{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:10px 6px;
  text-align:center;
  cursor:pointer;
  background:var(--card);
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  font-weight:600;
  color:var(--text)
}
.pm-type-btn.active{border-color:var(--pink);background:var(--pl);color:var(--pink)}

/* ────────── MANAGER ─────────────────────────────────────────── */

.mgr-tabs{
  display:flex;
  padding:10px 16px 8px;
  gap:6px;
  overflow-x:auto;
  scrollbar-width:none
}
.mgr-tabs::-webkit-scrollbar{display:none}
.mgr-tab{
  flex-shrink:0;
  background:var(--card);
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:9px 14px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  white-space:nowrap
}
.mgr-tab.active{background:var(--pink);color:#fff;border-color:var(--pink)}
.stats-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:0 16px;
  margin-bottom:14px
}
.stat-card{
  background:var(--card);
  border-radius:16px;
  padding:14px;
  border:1px solid var(--border)
}
.stat-lbl{
  font-size:11px;
  color:var(--muted);
  margin-bottom:4px;
  text-transform:uppercase;
  letter-spacing:.5px
}
.stat-val{font-size:22px;font-weight:600;color:var(--pink)}
.ocm{
  background:var(--card);
  border-radius:20px;
  padding:0;
  margin:0 16px 12px;
  border:1px solid var(--border);
  overflow:hidden
}
.oct{padding:14px 16px 12px}
.stage-sec{padding:10px 16px 14px;border-top:1px solid var(--border)}
.stage-lbl{
  font-size:11px;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:8px
}
.stage-btn{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:8px 3px;
  font-size:10px;
  font-weight:600;
  cursor:pointer;
  text-align:center;
  background:var(--card);
  color:var(--muted);
  font-family:'DM Sans',sans-serif;
  line-height:1.3
}
.stage-btn.active{border-color:var(--pink);background:var(--pink);color:#fff}
.stage-btn.past{background:var(--sbg);color:var(--muted)}
.stage-icon-s{font-size:13px;display:block;margin-bottom:2px}
.cancel-btn{
  background:none;
  border:none;
  font-size:11px;
  color:#C0392B;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  font-weight:600;
  padding:2px 0;
  margin-top:8px;
  display:block
}
.pad-card{
  background:var(--card);
  border-radius:16px;
  margin:0 16px 10px;
  border:1px solid var(--border);
  padding:12px;
  display:flex;
  gap:12px;
  align-items:center
}
.pad-img{
  width:48px;
  height:48px;
  border-radius:10px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  flex-shrink:0;
  overflow:hidden
}
.pad-img img{width:100%;height:100%;object-fit:cover}
.pad-acts{
  display:flex;
  gap:4px;
  margin-top:6px;
  flex-wrap:wrap
}
.pad-edit{
  background:var(--pl);
  color:var(--pink);
  border:none;
  border-radius:8px;
  padding:4px 10px;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif
}
.pad-del{
  background:#FFF0F0;
  color:#C0392B;
  border:none;
  border-radius:8px;
  padding:4px 10px;
  font-size:11px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif
}
.stk-btns{display:flex;gap:4px;margin-top:6px}
.stk-btn{
  border:1.5px solid var(--border);
  border-radius:8px;
  padding:4px 8px;
  font-size:10px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  background:var(--card);
  color:var(--text)
}
.stk-in{background:#E8F5E9;color:#2E7D32;border-color:#2E7D32}
.stk-low{background:#FFF3CD;color:#7B4A00;border-color:#E65100}
.stk-out{background:#FFF0F0;color:#C0392B;border-color:#C0392B}
.add-prod-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:14px;
  margin:0 16px 12px;
  padding:13px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  width:calc(100% - 32px);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px
}
.chart-box{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  padding:16px;
  margin:0 16px 12px
}
.chart-title{
  font-size:13px;
  font-weight:600;
  color:var(--text);
  margin-bottom:2px
}
.chart-sub{font-size:11px;color:var(--muted);margin-bottom:12px}
.sched-card{
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  padding:16px;
  margin:0 16px 12px
}
.sched-card h4{
  font-size:14px;
  font-weight:600;
  color:var(--text);
  margin-bottom:12px
}
.day-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 0;
  border-bottom:1px solid var(--border)
}
.day-row:last-child{border-bottom:none}
.day-name{
  font-size:13px;
  font-weight:500;
  color:var(--text);
  width:80px
}
.day-times{display:flex;gap:6px;align-items:center}
.time-inp{
  border:1.5px solid var(--border);
  border-radius:8px;
  padding:4px 8px;
  font-size:12px;
  color:var(--text);
  background:var(--ibg);
  font-family:'DM Sans',sans-serif;
  width:80px
}
.adv-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--border)
}
.adv-sel{
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:8px 12px;
  font-size:13px;
  color:var(--text);
  background:var(--ibg);
  font-family:'DM Sans',sans-serif;
  cursor:pointer
}
.psg{
  background:var(--card);
  border-radius:14px;
  border:1px solid var(--border);
  padding:12px;
  text-align:center
}
.psg-val{
  font-size:18px;
  font-weight:700;
  color:var(--pink);
  margin-bottom:2px
}
.psg-lbl{
  font-size:10px;
  color:var(--muted);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.4px;
  line-height:1.3
}
.act-card{
  margin:0 16px 10px;
  background:var(--card);
  border-radius:16px;
  border:1px solid var(--border);
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between
}
.act-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:10px;
  padding:9px 16px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif
}

/* ────────── MODALS ──────────────────────────────────────────── */

.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.5);
  z-index:200;
  display:none;
  align-items:flex-end;
  justify-content:center
}
.modal-overlay.open{display:flex}
.modal,.edit-modal{
  background:var(--cream);
  border-radius:28px 28px 0 0;
  padding:22px 20px 40px;
  width:100%;
  max-width:430px;
  position:relative;
  animation:slideUp .25s ease;
  max-height:92vh;
  overflow-y:auto
}
.edit-modal{background:var(--card)}
.modal-handle{
  width:36px;
  height:4px;
  background:var(--border);
  border-radius:2px;
  margin:0 auto 18px;
  display:block
}
.modal-img{
  width:100%;
  height:170px;
  border-radius:20px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:68px;
  margin-bottom:14px;
  overflow:hidden
}
.modal-img img{width:100%;height:100%;object-fit:cover}
.modal-cat{
  font-size:11px;
  font-weight:500;
  color:var(--pink);
  letter-spacing:1.2px;
  text-transform:uppercase;
  margin-bottom:4px
}
.modal-name{
  font-family:Georgia,serif;
  font-size:21px;
  font-weight:600;
  margin-bottom:6px;
  color:var(--text)
}
.modal-rating{margin-bottom:10px;font-size:14px;color:var(--muted)}
.modal-desc{
  font-size:14px;
  color:var(--sub);
  line-height:1.7;
  margin-bottom:12px
}
.modal-bottom{display:flex;align-items:center;justify-content:space-between}
.modal-price{font-size:24px;font-weight:700;color:var(--pink)}
.modal-add-btn{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:50px;
  padding:13px 26px;
  font-family:'DM Sans',sans-serif;
  font-size:15px;
  font-weight:500;
  cursor:pointer
}
.modal-close{
  position:absolute;
  top:16px;
  right:20px;
  background:var(--border);
  border:none;
  border-radius:50%;
  width:32px;
  height:32px;
  font-size:16px;
  cursor:pointer;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:center
}
.ef{margin-bottom:13px}
.elbl{
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:5px;
  display:block;
  text-transform:uppercase;
  letter-spacing:.4px
}
.einp{
  width:100%;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:11px 14px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  color:var(--text);
  outline:none;
  background:var(--ibg)
}
.einp:focus{border-color:var(--pink)}
.efr{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.photo-sec{
  background:var(--sbg);
  border:1.5px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  margin-bottom:13px
}
.photo-acts{padding:10px 12px;display:flex;gap:8px}
.photo-btn{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:9px 6px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  font-family:'DM Sans',sans-serif;
  background:var(--card);
  color:var(--text)
}
.photo-btn.pink{background:var(--pink);color:#fff;border-color:var(--pink)}
.url-div{
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 12px 8px
}
.url-line{flex:1;height:1px;background:var(--border)}
.url-txt{font-size:11px;color:var(--muted);font-weight:500}
.url-row-f{padding:0 12px 12px;display:flex;gap:8px}
.url-inp{
  flex:1;
  border:1.5px solid var(--border);
  border-radius:10px;
  padding:9px 12px;
  font-size:13px;
  color:var(--text);
  outline:none;
  background:var(--ibg);
  font-family:'DM Sans',sans-serif
}
.url-inp::placeholder{color:var(--muted)}
.url-inp:focus{border-color:var(--pink)}
.url-apply{
  background:var(--pl);
  color:var(--pink);
  border:none;
  border-radius:10px;
  padding:9px 14px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;
  white-space:nowrap
}
.pclr{
  position:absolute;
  top:8px;
  right:8px;
  background:rgba(0,0,0,.5);
  color:#fff;
  border:none;
  border-radius:50%;
  width:28px;
  height:28px;
  font-size:13px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center
}
.feat-row{
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--sbg);
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:12px 14px;
  margin-bottom:13px;
  cursor:pointer
}
.feat-row input{
  width:18px;
  height:18px;
  accent-color:var(--pink);
  cursor:pointer;
  flex-shrink:0
}
.feat-row label{
  font-size:13px;
  font-weight:500;
  color:var(--text);
  cursor:pointer;
  flex:1
}
.feat-row span{font-size:11px;color:var(--muted)}
.esave{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:14px;
  width:100%;
  padding:15px;
  font-family:'DM Sans',sans-serif;
  font-size:15px;
  font-weight:600;
  cursor:pointer
}

/* ────────── DELIVERY ZONES ──────────────────────────────────── */

#dz-map, #checkout-map {
  width: 100%;
  border-radius: 16px;
  border: 1.5px solid var(--border);
  overflow: hidden;
  background: var(--sbg);
  z-index: 1;
}
#dz-map { height: 480px; }
#checkout-map { height: 280px; }
.dz-zone-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 10px 14px;
  margin-bottom: 8px;
}
.dz-zone-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--pink);
  flex-shrink: 0;
}
.dz-zone-name { flex: 1; font-size: 14px; font-weight: 600; color: var(--text); }
.dz-fee-inp {
  width: 72px;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--pink);
  text-align: center;
  background: var(--ibg);
  font-family: 'DM Sans', sans-serif;
  outline: none;
}
.dz-fee-inp:focus { border-color: var(--pink); }
.dz-remove-btn {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 16px;
  padding: 2px 4px;
  border-radius: 6px;
}
.dz-remove-btn:hover { color: #C0392B; background: #FFF0F0; }
.dz-save-btn {
  background: var(--pink);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 14px;
  width: 100%;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 12px;
}
.dz-hint {
  font-size: 12px;
  color: var(--muted);
  background: var(--sbg);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 14px;
  line-height: 1.6;
}
.dz-status-ok {
  font-size: 13px;
  color: #2E7D32;
  background: #E8F5E9;
  border-radius: 10px;
  padding: 10px 14px;
  margin-top: 10px;
  font-weight: 600;
}
.dz-status-no {
  font-size: 13px;
  color: #856404;
  background: #FFF8E1;
  border-radius: 10px;
  padding: 10px 14px;
  margin-top: 10px;
  font-weight: 600;
}
.leaflet-container { font-family: 'DM Sans', sans-serif !important; }

/* ────────── UTILITY ─────────────────────────────────────────── */

.empty-state{text-align:center;padding:48px 24px}
.empty-state-icon{font-size:48px;margin-bottom:12px}
.empty-state h3{
  font-family:Georgia,serif;
  font-size:20px;
  color:var(--text);
  margin-bottom:6px
}
.empty-state p{font-size:13px;color:var(--muted);line-height:1.6}
.wa-btn{
  position:fixed;
  bottom:85px;
  right:16px;
  width:50px;
  height:50px;
  background:#25D366;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:24px;
  z-index:50;
  cursor:pointer;
  box-shadow:0 4px 16px rgba(37,211,102,.4);
  text-decoration:none;
  border:none
}

/* ────────── MISC ────────────────────────────────────────────── */


.btn-pink{
  background:var(--pink);
  color:#fff;
  border:none;
  border-radius:50px;
  padding:12px 22px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  font-weight:500;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px
}
.btn-outline{
  background:transparent;
  color:var(--pink);
  border:1.5px solid var(--pink);
  border-radius:50px;
  padding:11px 20px;
  font-family:'DM Sans',sans-serif;
  font-size:14px;
  font-weight:500;
  cursor:pointer
}
.contact-row{display:flex;gap:10px}
.cbtn{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px;
  border-radius:14px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  border:none;
  font-family:'DM Sans',sans-serif;
  text-decoration:none
}
.cbtn.wa{background:#25D366;color:#fff}
.cbtn.ig{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);color:#fff}
.order-pill{
  background:var(--pl);
  color:var(--pink);
  font-size:18px;
  font-weight:700;
  padding:12px 24px;
  border-radius:12px;
  display:inline-block;
  margin-bottom:24px;
  font-family:Georgia,serif
}
.stages{display:flex;gap:5px}
.allergen-box{
  background:var(--pl);
  border-radius:12px;
  padding:10px 14px;
  margin-bottom:14px
}
.allergen-title{
  font-size:11px;
  font-weight:600;
  color:var(--pink);
  text-transform:uppercase;
  letter-spacing:.8px;
  margin-bottom:6px
}
.allergen-tags{display:flex;gap:6px;flex-wrap:wrap}
.allergen-tag{
  background:var(--pm);
  color:var(--pink);
  font-size:11px;
  font-weight:600;
  padding:3px 10px;
  border-radius:50px
}
.ppl{
  width:100%;
  height:150px;
  background:var(--pm);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  overflow:hidden
}

.php{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  color:var(--muted)
}
.php-icon{font-size:30px}
.php-text{font-size:12px;font-weight:500}

/* ────────── PHOTO PAN (drag to reposition) ─────────────────── */
.ppl{touch-action:none;overflow:hidden}
.ppl img{position:absolute;cursor:grab;user-select:none;-webkit-user-select:none}
.ppl img.dragging{cursor:grabbing}
.pan-hint{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.55);color:#fff;font-size:10px;font-weight:600;padding:3px 10px;border-radius:50px;pointer-events:none;white-space:nowrap;letter-spacing:.3px}
.pan-zoom{position:absolute;bottom:6px;right:6px;display:flex;flex-direction:column;gap:4px}
.pan-zoom-btn{background:rgba(0,0,0,.55);color:#fff;border:none;border-radius:50%;width:26px;height:26px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700}

/* ────────── CATEGORY PILLS ─────────────────────────────────── */
.cat-pill-row{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 12px}
.cat-pill{display:flex;align-items:center;gap:6px;background:var(--pl);border:1.5px solid var(--pm);border-radius:50px;padding:7px 12px;font-size:13px;font-weight:600;color:var(--pink);cursor:pointer}
.cat-pill-edit{background:none;border:none;font-size:12px;cursor:pointer;color:var(--pink);padding:0 0 0 4px;line-height:1}
.cat-pill-add{background:var(--pink);color:#fff;border:none;border-radius:50px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif}
.cat-sec-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;padding:14px 16px 8px;display:flex;align-items:center;justify-content:space-between}

/* ────────── AUTH SCREENS ──────────────────────────────────── */
#auth-screen{position:fixed;inset:0;background:var(--cream);z-index:500;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;animation:fadeIn .3s ease}
.auth-logo{font-family:Georgia,serif;font-size:42px;color:var(--pink);margin-bottom:6px;text-align:center}
.auth-tag{font-size:12px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:40px;text-align:center}
.auth-card{background:var(--card);border-radius:24px;border:1px solid var(--border);padding:28px 24px;width:100%;max-width:390px}
.auth-title{font-family:Georgia,serif;font-size:22px;color:var(--text);margin-bottom:6px}
.auth-sub{font-size:13px;color:var(--muted);margin-bottom:22px;line-height:1.5}
.auth-tabs{display:flex;gap:0;margin-bottom:22px;background:var(--sbg);border-radius:12px;padding:4px}
.auth-tab{flex:1;padding:9px;text-align:center;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-radius:9px;border:none;background:none;font-family:'DM Sans',sans-serif}
.auth-tab.active{background:var(--card);color:var(--pink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.auth-method{display:flex;gap:8px;margin-bottom:18px}
.auth-method-btn{flex:1;border:1.5px solid var(--border);border-radius:12px;padding:10px 6px;text-align:center;cursor:pointer;background:var(--card);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--text)}
.auth-method-btn.active{border-color:var(--pink);background:var(--pl);color:var(--pink)}
.auth-fld{margin-bottom:14px}
.auth-lbl{font-size:11px;font-weight:600;color:var(--muted);margin-bottom:5px;display:block;text-transform:uppercase;letter-spacing:.4px}
.auth-inp{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);outline:none;background:var(--ibg)}
.auth-inp:focus{border-color:var(--pink)}
.auth-btn{background:var(--pink);color:#fff;border:none;border-radius:14px;width:100%;padding:15px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;margin-top:4px}
.auth-btn:disabled{opacity:.6;cursor:not-allowed}
.auth-err{background:#FFF0F0;color:#C0392B;border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:12px;line-height:1.5}
.auth-ok{background:#E8F5E9;color:#2E7D32;border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:12px;line-height:1.5}
.auth-divider{display:flex;align-items:center;gap:10px;margin:16px 0}
.auth-divider-line{flex:1;height:1px;background:var(--border)}
.auth-divider-txt{font-size:11px;color:var(--muted);font-weight:500}
.auth-switch{text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}
.auth-switch span{color:var(--pink);cursor:pointer;font-weight:600}
.auth-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;color:var(--muted);font-size:13px}
.otp-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:14px}
.otp-inp{width:44px;height:52px;border:1.5px solid var(--border);border-radius:12px;text-align:center;font-size:20px;font-weight:700;color:var(--text);background:var(--ibg);font-family:'DM Sans',sans-serif;outline:none}
.otp-inp:focus{border-color:var(--pink)}
.user-pill{position:fixed;top:12px;right:16px;z-index:20;background:var(--card);border:1px solid var(--border);border-radius:50px;padding:6px 12px 6px 8px;display:flex;align-items:center;gap:8px;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.user-pill-avatar{width:26px;height:26px;border-radius:50%;background:var(--pink);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;font-family:Georgia,serif}
.user-pill-name{font-size:12px;font-weight:600;color:var(--text);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mgr-badge{background:var(--pink);color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:50px;margin-left:2px}

/* ══════════════════════════════════════════════════════════════
   DESKTOP LAYOUT  (>= 1024px)
   ══════════════════════════════════════════════════════════════ */