@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&family=Nunito+Sans:wght@400;500;600&display=swap');

:root {
  --bg:#fef9f5;--bg2:#ffffff;--bg3:#fdf4ee;--bg4:#fce8d8;
  --bd:#f0d9c8;--bd2:#e8c9b0;
  --tx:#3d2c1e;--tx2:#8b6e5a;--tx3:#c4a48c;
  --ac:#f97316;--ac2:#ea6a08;--ac-bg:#fff4ed;--ac-soft:#ffedd5;
  --green:#22c55e;--green-bg:#f0fdf4;--green-bd:#bbf7d0;
  --amber:#f59e0b;--amber-bg:#fffbeb;--amber-bd:#fde68a;
  --red:#ef4444;--red-bg:#fef2f2;--red-bd:#fecaca;
  --blue:#3b82f6;--blue-bg:#eff6ff;--blue-bd:#bfdbfe;
  --purple:#a855f7;--purple-bg:#faf5ff;--purple-bd:#e9d5ff;
  --pink:#ec4899;--pink-bg:#fdf2f8;--pink-bd:#fbcfe8;
  --gold:#f59e0b;
  --shadow:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow2:0 4px 16px rgba(0,0,0,.12),0 2px 4px rgba(0,0,0,.06);
  --r:10px;--r2:16px;--r3:24px;
  --head:'Nunito',sans-serif;--mono:'Nunito Sans',sans-serif;
  --bot-nav-h:72px; /* bottom nav height on mobile */
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:var(--mono);background:var(--bg);color:var(--tx);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;overscroll-behavior:none}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg3)}
::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:10px}

/* ── Auth ─────────────────────────────────────────────────── */
#auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fff4ed,#fce8d8 50%,#fdf4ee);padding:16px}
.auth-card{background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r3);padding:36px 28px;width:100%;max-width:400px;box-shadow:var(--shadow2)}
.auth-logo{font-family:var(--head);font-size:26px;font-weight:800;text-align:center;margin-bottom:4px}
.auth-logo span{color:var(--ac)}
.auth-logo .logo-emoji{font-size:36px;display:block;text-align:center;margin-bottom:8px}
.auth-sub{text-align:center;color:var(--tx2);font-size:13px;margin-bottom:24px}
.auth-err{color:var(--red);font-size:12px;margin-top:8px;padding:8px 12px;background:var(--red-bg);border:1.5px solid var(--red-bd);border-radius:var(--r);display:none}

/* ── App shell ───────────────────────────────────────────── */
#app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}
.hidden{display:none!important}

/* ── Offline banner ──────────────────────────────────────── */
#offline-banner{display:none;background:var(--amber-bg);border-bottom:1.5px solid var(--amber-bd);padding:8px 16px;font-size:12px;color:var(--amber);text-align:center;font-weight:700;position:sticky;top:0;z-index:99}
#offline-banner.show{display:block}

/* ══════════════════════════════════════════════════════════
   DESKTOP TOPBAR (≥ 769px)
   ══════════════════════════════════════════════════════════ */
.topbar{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--bg2);border-bottom:1.5px solid var(--bd);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.logo{font-family:var(--head);font-size:17px;font-weight:800;white-space:nowrap;display:flex;align-items:center;gap:8px;color:var(--tx);flex-shrink:0}
.logo span{color:var(--ac)}
.logo-icon{width:30px;height:30px;background:var(--ac-soft);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px}
.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--green);transition:background .3s;flex-shrink:0}
.sync-dot.offline{background:var(--red)}
.sync-dot.syncing{background:var(--amber);animation:pulse .8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.nav{display:flex;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}
.ntab{padding:7px 14px;border:1.5px solid transparent;border-radius:50px;cursor:pointer;background:transparent;color:var(--tx2);font-family:var(--head);font-size:13px;font-weight:700;white-space:nowrap;transition:all .15s}
.ntab:hover{background:var(--bg3);color:var(--tx);border-color:var(--bd)}
.ntab.on{background:var(--ac-soft);color:var(--ac);border-color:var(--ac)}
.ntab .nb{display:inline-block;margin-left:4px;background:var(--red);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;font-weight:700}
.uinfo{display:flex;align-items:center;gap:7px;margin-left:auto;flex-shrink:0}
.urole{font-size:11px;padding:3px 10px;border-radius:50px;font-weight:700;white-space:nowrap;font-family:var(--head)}
.r-adm{background:var(--purple-bg);color:var(--purple);border:1.5px solid var(--purple-bd)}
.r-usr{background:var(--blue-bg);color:var(--blue);border:1.5px solid var(--blue-bd)}

/* ── Mobile topbar (≤ 768px) — slim, logo + sync + hamburger ── */
.mob-topbar{display:none;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg2);border-bottom:1.5px solid var(--bd);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.mob-logo{font-family:var(--head);font-size:16px;font-weight:800;display:flex;align-items:center;gap:7px}
.mob-logo span{color:var(--ac)}
.mob-logo .logo-icon{width:28px;height:28px;background:var(--ac-soft);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.mob-right{display:flex;align-items:center;gap:8px}
.hbg-btn{width:36px;height:36px;border:1.5px solid var(--bd);border-radius:50%;background:var(--bg2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;box-shadow:var(--shadow)}
.mob-add-btn{width:36px;height:36px;border-radius:50%;background:var(--ac);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;box-shadow:0 2px 8px rgba(249,115,22,.4)}

/* ── Hamburger drawer ──────────────────────────────────── */
#hbg-overlay{display:none;position:fixed;inset:0;background:rgba(61,44,30,.4);z-index:200;backdrop-filter:blur(2px)}
#hbg-overlay.open{display:block}
#hbg-drawer{position:fixed;top:0;right:-300px;width:280px;height:100%;background:var(--bg2);z-index:201;box-shadow:var(--shadow2);transition:right .25s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding-bottom:40px}
#hbg-drawer.open{right:0}
.hbg-head{padding:20px 18px 14px;border-bottom:1.5px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.hbg-user{display:flex;flex-direction:column;gap:3px}
.hbg-email{font-size:12px;color:var(--tx2);font-weight:600}
.hbg-close{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--bd);background:var(--bg3);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}
.hbg-section{padding:12px 18px}
.hbg-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--tx3);font-weight:700;margin-bottom:8px;font-family:var(--head)}
.hbg-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r2);cursor:pointer;font-size:13px;font-weight:700;font-family:var(--head);color:var(--tx2);transition:all .15s;border:none;background:transparent;width:100%;text-align:left}
.hbg-item:hover,.hbg-item:active{background:var(--bg3);color:var(--tx)}
.hbg-item.danger{color:var(--red)}
.hbg-item.danger:hover{background:var(--red-bg)}
.hbg-divider{height:1px;background:var(--bd);margin:4px 18px}
.hbg-sync{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--tx3);padding:6px 12px;font-weight:600}

/* ── Bottom nav bar (mobile) ─────────────────────────────── */
#bot-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:calc(var(--bot-nav-h) + env(safe-area-inset-bottom,0px));background:var(--bg2);border-top:1.5px solid var(--bd);z-index:100;box-shadow:0 -2px 12px rgba(0,0,0,.08)}
.bnav{display:flex;height:var(--bot-nav-h);align-items:stretch}
.btab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;border:none;background:transparent;color:var(--tx3);transition:color .15s;position:relative;padding-bottom:2px}
.btab.on{color:var(--ac)}
.btab .bi{font-size:20px;line-height:1;transition:transform .15s}
.btab.on .bi{transform:scale(1.15)}
.btab .bl{font-size:9px;font-family:var(--head);font-weight:700;white-space:nowrap}
.btab .bb{position:absolute;top:8px;right:calc(50% - 14px);min-width:16px;height:16px;background:var(--red);color:#fff;font-size:9px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;padding:0 4px}

/* ── Stats bar ───────────────────────────────────────────── */
.statsbar{background:var(--bg2);border-bottom:1.5px solid var(--bd);padding:10px 16px}
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:1400px;margin:0 auto}
.sc{background:var(--bg3);border:1.5px solid var(--bd);border-radius:var(--r2);padding:10px 8px;text-align:center;transition:transform .15s,box-shadow .15s;cursor:default}
.sc:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.sl{font-size:10px;color:var(--tx2);font-weight:700;margin-bottom:3px;font-family:var(--head)}
.sv{font-family:var(--head);font-size:22px;font-weight:800;line-height:1}
.sv.red{color:var(--red)}.sv.am{color:var(--amber)}.sv.gn{color:var(--green)}.sv.bl{color:var(--ac)}

/* ── Page content ────────────────────────────────────────── */
.page{padding:16px;max-width:1400px;margin:0 auto;width:100%}
.ph{font-family:var(--head);font-size:18px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{padding:8px 18px;border:1.5px solid var(--bd2);border-radius:50px;cursor:pointer;background:var(--bg2);color:var(--tx);font-family:var(--head);font-size:13px;font-weight:700;transition:all .15s;white-space:nowrap;box-shadow:var(--shadow)}
.btn:hover{border-color:var(--ac);color:var(--ac);background:var(--ac-bg)}
.btn:active{transform:scale(.97)}
.btn.pri{background:var(--ac);border-color:var(--ac);color:#fff}
.btn.pri:hover{background:var(--ac2);border-color:var(--ac2);color:#fff}
.btn.success{background:var(--green-bg);border-color:var(--green-bd);color:var(--green)}
.btn.success:hover{background:var(--green);color:#fff;border-color:var(--green)}
.btn.danger{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}
.btn.danger:hover{background:var(--red);color:#fff;border-color:var(--red)}
.btn.sm{padding:5px 12px;font-size:12px}
.btn.xs{padding:3px 8px;font-size:11px}

/* ── FAB (mobile floating add button) ───────────────────── */
#fab{display:none;position:fixed;right:16px;bottom:calc(var(--bot-nav-h) + env(safe-area-inset-bottom,0px) + 12px);width:52px;height:52px;border-radius:50%;background:var(--ac);border:none;cursor:pointer;box-shadow:0 4px 16px rgba(249,115,22,.45);font-size:24px;color:#fff;z-index:99;align-items:center;justify-content:center;transition:transform .15s}
#fab:active{transform:scale(.92)}

/* ── Toolbar ─────────────────────────────────────────────── */
.toolbar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
input.si{flex:1;min-width:140px;background:var(--bg2);border:1.5px solid var(--bd);border-radius:50px;padding:9px 16px;color:var(--tx);font-family:var(--mono);font-size:16px;transition:all .15s;box-shadow:var(--shadow)}
input.si:focus{outline:none;border-color:var(--ac);box-shadow:0 0 0 3px var(--ac-soft)}
input.si::placeholder{color:var(--tx3)}
select.fs{background:var(--bg2);border:1.5px solid var(--bd);border-radius:50px;padding:8px 12px;color:var(--tx);font-family:var(--head);font-size:16px;font-weight:700;cursor:pointer;box-shadow:var(--shadow)}
select.fs:focus{outline:none;border-color:var(--ac)}

/* ── Product grid ────────────────────────────────────────── */
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.pcard{background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all .2s;box-shadow:var(--shadow);animation:fi .2s ease both}
.pcard:hover{border-color:var(--ac);transform:translateY(-2px);box-shadow:var(--shadow2)}
.pcard:active{transform:scale(.98)}
.pcard.fav{border-color:var(--gold);background:linear-gradient(180deg,#fffbeb,#fff 40%)}
.pcard.shrd{border-color:var(--blue)}
.pcard.offline-pending{border-style:dashed;border-color:var(--amber)}
@keyframes fi{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.cimg{width:100%;height:110px;background:var(--bg3);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.cimg img{width:100%;height:100%;object-fit:cover}
.cimg-ph{color:var(--tx3);font-size:26px}
.cbadges{position:absolute;top:6px;right:6px;display:flex;flex-direction:column;gap:3px;align-items:flex-end}
.cshbadge{position:absolute;top:6px;left:6px}
.cbody{padding:10px 12px}
.cname{font-family:var(--head);font-size:13px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}
.cmeta{font-size:11px;color:var(--tx2);margin-bottom:5px}
.cprice{font-size:17px;font-weight:800;color:var(--green);font-family:var(--head)}
.corig{font-size:11px;color:var(--tx3);text-decoration:line-through;margin-left:5px}
.cusage{margin-top:6px}
.cubar{height:5px;background:var(--bg4);border-radius:10px;margin-top:3px;overflow:hidden}
.cufill{height:100%;background:linear-gradient(90deg,var(--ac),#fb923c);border-radius:10px;transition:width .3s}
.cfoot{display:flex;justify-content:space-between;align-items:center;padding:7px 12px;border-top:1.5px solid var(--bd);background:var(--bg3);gap:6px;flex-wrap:wrap}
.cacts{display:flex;gap:4px;flex-wrap:wrap}

/* ── Badges ──────────────────────────────────────────────── */
.badge{font-size:11px;padding:3px 8px;border-radius:50px;font-weight:700;white-space:nowrap;display:inline-block;font-family:var(--head)}
.ok{background:var(--green-bg);color:var(--green);border:1.5px solid var(--green-bd)}
.warn{background:var(--amber-bg);color:var(--amber);border:1.5px solid var(--amber-bd)}
.danger{background:var(--red-bg);color:var(--red);border:1.5px solid var(--red-bd)}
.info{background:var(--blue-bg);color:var(--blue);border:1.5px solid var(--blue-bd)}
.gold{background:var(--amber-bg);color:var(--gold);border:1.5px solid var(--amber-bd)}
.shbadge{background:var(--blue-bg);color:var(--blue);border:1.5px solid var(--blue-bd)}
.evt{background:var(--pink-bg);color:var(--pink);border:1.5px solid var(--pink-bd)}
.purple{background:var(--purple-bg);color:var(--purple);border:1.5px solid var(--purple-bd)}

/* ── Modal ───────────────────────────────────────────────── */
.mback{position:fixed;inset:0;background:rgba(61,44,30,.45);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;padding:0}
.modal{background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r3) var(--r3) 0 0;width:100%;max-width:640px;max-height:92vh;max-height:92dvh;overflow-y:auto;animation:slideup .2s ease both;box-shadow:var(--shadow2)}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.mhd{display:flex;flex-direction:column;align-items:stretch;gap:0;padding:14px 16px 0;border-bottom:1.5px solid var(--bd);position:sticky;top:0;background:var(--bg2);z-index:10;border-radius:var(--r3) var(--r3) 0 0}
.mtitle{font-family:var(--head);font-size:16px;font-weight:800}
.mbody{padding:14px 16px}
.mft{display:flex;gap:8px;justify-content:flex-end;padding:12px 16px;border-top:1.5px solid var(--bd);position:sticky;bottom:0;background:var(--bg2);border-radius:0}
.mtabs{display:flex;gap:0;margin-bottom:0;background:transparent;padding:0;border-radius:0;border:none}
.mtab{padding:10px 14px;font-size:12px;cursor:pointer;border:none;background:transparent;color:var(--tx2);font-family:var(--head);font-weight:700;border-radius:0;transition:all .15s;flex:1;text-align:center;border-bottom:2px solid transparent;margin-bottom:-1px}
.mtab:hover{color:var(--tx);background:var(--bg3)}
.mtab.on{color:var(--ac);border-bottom-color:var(--ac);background:transparent}

/* ── Form ────────────────────────────────────────────────── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fg .full{grid-column:1/-1}
.f{display:flex;flex-direction:column;gap:4px}
.f label{font-size:12px;color:var(--tx2);font-weight:700;font-family:var(--head)}
.f input,.f select,.f textarea{background:var(--bg3);border:1.5px solid var(--bd);border-radius:var(--r);padding:9px 12px;color:var(--tx);font-family:var(--mono);font-size:16px;transition:all .15s}
.f input:focus,.f select:focus,.f textarea:focus{outline:none;border-color:var(--ac);background:var(--bg2);box-shadow:0 0 0 3px var(--ac-soft)}
.f input::placeholder{color:var(--tx3)}
.f textarea{resize:vertical;min-height:60px}
.hint{font-size:11px;color:var(--tx3);margin-top:2px}
.dbts{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.dbt{padding:5px 11px;font-size:12px;border:1.5px solid var(--bd2);border-radius:50px;background:var(--bg2);color:var(--tx2);cursor:pointer;font-family:var(--head);font-weight:700;transition:all .15s}
.dbt:hover,.dbt.on{border-color:var(--amber);color:#fff;background:var(--amber)}

/* ── Toggle ──────────────────────────────────────────────── */
.trow{display:flex;align-items:center;gap:10px}
.tog{width:44px;height:24px;background:var(--bd2);border-radius:50px;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0;border:none}
.tog.on{background:var(--ac)}
.tog::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.tog.on::after{transform:translateX(20px)}
.tlbl{font-size:13px;color:var(--tx2);font-weight:600}

/* ── Image upload ────────────────────────────────────────── */
.uarea{border:2px dashed var(--bd2);border-radius:var(--r2);padding:18px;text-align:center;cursor:pointer;color:var(--tx3);font-size:13px;transition:all .15s;font-weight:700;background:var(--bg3)}
.uarea:hover{border-color:var(--ac);color:var(--ac);background:var(--ac-bg)}
.uarea.loading{border-color:var(--amber);color:var(--amber)}
.uarea.done{border-color:var(--green);color:var(--green);background:var(--green-bg)}
img.prev{width:100%;height:110px;object-fit:cover;border-radius:var(--r);border:1.5px solid var(--bd);display:none}
.pprev{padding:10px 12px;background:var(--ac-bg);border:1.5px solid var(--ac-soft);border-radius:var(--r);font-size:13px;min-height:36px;font-weight:700}

/* ── Table ───────────────────────────────────────────────── */
.tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:9px 12px;border-bottom:1.5px solid var(--bd);font-size:11px;color:var(--tx2);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-weight:700;font-family:var(--head);background:var(--bg3)}
td{padding:9px 12px;border-bottom:1.5px solid var(--bd);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg3)}
.best{color:var(--green);font-weight:800;font-family:var(--head)}

/* ── Expiry sections ─────────────────────────────────────── */
.esec{margin-bottom:20px}
.esetitle{font-family:var(--head);font-size:14px;font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:8px}

/* ── Admin ───────────────────────────────────────────────── */
.agrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.asec{background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r2);padding:14px;box-shadow:var(--shadow)}
.asec-t{font-size:13px;font-weight:800;color:var(--tx2);margin-bottom:10px;font-family:var(--head)}

/* ── Empty state ─────────────────────────────────────────── */
.empty{text-align:center;padding:48px 16px;color:var(--tx3)}
.empty-icon{font-size:44px;margin-bottom:10px}
.empty-t{font-family:var(--head);font-size:15px;color:var(--tx2);margin-bottom:6px;font-weight:800}

/* ── PriceWatch ──────────────────────────────────────────── */
.pw-card{background:var(--bg2);border:1.5px solid var(--bd);border-radius:var(--r2);margin-bottom:10px;overflow:hidden;box-shadow:var(--shadow);transition:all .2s}
.pw-card:hover{transform:translateY(-2px);box-shadow:var(--shadow2)}
.pw-head{padding:10px 14px;border-bottom:1.5px solid var(--bd);display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap;background:var(--bg3)}
.pw-name{font-family:var(--head);font-size:14px;font-weight:800}
.pw-brand{font-size:12px;color:var(--tx2);margin-top:2px}
.pw-cats{font-size:11px;color:var(--tx3);margin-top:1px}
.pw-prices{width:100%;border-collapse:collapse;font-size:13px}
.pw-prices th{text-align:left;padding:7px 12px;font-size:11px;color:var(--tx2);text-transform:uppercase;letter-spacing:.04em;border-bottom:1.5px solid var(--bd);white-space:nowrap;background:var(--bg3);font-weight:700}
.pw-prices td{padding:8px 12px;border-bottom:1.5px solid var(--bd);vertical-align:middle}
.pw-prices tr:last-child td{border-bottom:none}
.pw-prices tr:hover td{background:var(--bg3)}
.pw-best{color:var(--green);font-weight:800;font-family:var(--head)}
.pw-save{font-size:12px;color:var(--ac);cursor:pointer;border:1.5px solid var(--ac);background:var(--ac-bg);font-family:var(--head);font-weight:700;padding:4px 10px;border-radius:50px;transition:all .15s}
.pw-save:hover{background:var(--ac);color:#fff}
.pw-offer{font-size:11px;color:var(--pink);margin-top:2px;font-weight:700}
.pw-empty{text-align:center;padding:32px 16px;color:var(--tx3);font-size:13px}
.pw-loading{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--tx2);padding:20px 0}
.pw-spinner{width:18px;height:18px;border:2.5px solid var(--bd2);border-top-color:var(--ac);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.pw-savings{font-size:11px;color:var(--pink);background:var(--pink-bg);border:1px solid var(--pink-bd);border-radius:50px;padding:1px 7px;margin-left:6px;font-weight:700}

/* ══════════════════════════════════════════════════════════
   MOBILE OVERRIDES (≤ 768px)
   ══════════════════════════════════════════════════════════ */
/* Desktop: restore smaller font after mobile-safe 16px baseline */
@media(min-width:769px){
  .f input,.f select,.f textarea{font-size:13px}
  input.si{font-size:13px}
  select.fs{font-size:13px}
}

@media(max-width:768px){
  /* Fix 3: prevent iOS zoom on input focus — font-size must be >=16px */
  input, select, textarea { font-size: 16px !important; }
  /* Show mobile topbar, hide desktop topbar and desktop nav */
  .topbar{display:none}
  .mob-topbar{display:flex}
  #bot-nav{display:block}
  #fab{display:flex}

  /* Extra bottom padding so content doesn't hide behind bottom nav */
  .page{padding:14px 12px;padding-bottom:calc(var(--bot-nav-h) + env(safe-area-inset-bottom,0px) + 16px)}
  .statsbar{padding:10px 12px;padding-bottom:10px}

  /* Stats — compact on mobile */
  .stats{grid-template-columns:repeat(5,1fr);gap:6px}
  .sc{padding:8px 4px}
  .sl{font-size:9px}
  .sv{font-size:18px}

  /* Grid — 2 columns on mobile */
  .pgrid{grid-template-columns:repeat(2,1fr);gap:8px}

  /* Card — slimmer */
  .cimg{height:90px}
  .cbody{padding:8px 10px}
  .cname{font-size:12px}
  .cmeta{font-size:10px}
  .cprice{font-size:15px}
  .cfoot{padding:6px 10px}
  .btn.sm{padding:4px 8px;font-size:11px}
  .btn.xs{padding:2px 6px;font-size:10px}

  /* Modal slides up from bottom full-width */
  .mback{align-items:flex-end;padding:0}
  .modal{border-radius:var(--r3) var(--r3) 0 0;max-height:94vh;max-height:94dvh;width:100%;max-width:100%}
  .mbody{padding:12px 14px}
  .mft{padding:10px 14px}

  /* Form — single column */
  .fg{grid-template-columns:1fr}.fg .full{grid-column:1}

  /* Admin grid — single column */
  .agrid{grid-template-columns:1fr}

  /* Tables — compact */
  th,td{padding:7px 8px;font-size:12px}

  /* Page heading */
  .ph{font-size:16px;margin-bottom:10px}

  /* Toolbar — wrap neatly */
  .toolbar{gap:6px}
  input.si{padding:8px 14px;font-size:13px}
}

@media(max-width:360px){
  .pgrid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(3,1fr)}
}

/* ── PriceWatch two-panel ──────────────────────────────────── */
.pw-left-item{padding:10px 12px;border-bottom:1.5px solid var(--bd);cursor:pointer;transition:background .12s}
.pw-left-item:last-child{border-bottom:none}
.pw-left-item:hover{background:var(--bg3)}
.pw-left-item.selected{background:var(--ac-soft);border-left:3px solid var(--ac)}
.pw-li-name{font-family:var(--head);font-size:13px;font-weight:800;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pw-li-meta{font-size:11px;color:var(--tx2);margin-top:2px}
.pw-li-price{font-size:11px;color:var(--green);font-weight:700;margin-top:2px}

/* Mobile: stack panels vertically */
@media(max-width:768px){
  #pw-body{grid-template-columns:1fr!important}
  #pw-left-list{max-height:220px!important}
}
