/* ===================== Cxtreme Inventory — Light/Navy theme ===================== */
:root{
  --page:#e8ecf7; --panel:#fbfcff; --card:#ffffff;
  --ink:#16224a; --ink2:#2b3756; --muted:#8a96b5; --faint:#aab3cc;
  --line:#eef1f8; --line2:#e4e9f4;
  --brand:#3b6ef5; --brand-2:#5b8def; --brand-3:#7aa2f7; --brand-dim:#eaf0ff;
  --navy-1:#1f2f6b; --navy-2:#13204c; --navy-line:rgba(255,255,255,.08);
  --nav-ink:#aeb9da; --nav-ink-dim:#7e8cb8;
  --green:#16a34a; --green-dim:#e7f7ee;
  --amber:#d98a09; --amber-dim:#fdf2dd;
  --red:#e5484d; --red-dim:#fdebec;
  --violet:#7c5cfc; --violet-dim:#efeafe;
  --teal:#0ea5a4; --teal-dim:#e2f6f5;
  /* status */
  --stock:#16a34a; --stock-dim:#e7f7ee;
  --allot:#3b6ef5; --allot-dim:#eaf0ff;
  --recv:#d98a09; --recv-dim:#fdf2dd;
  --fault:#e5484d; --fault-dim:#fdebec;
  --pay:#7c5cfc; --pay-dim:#efeafe;
  --disp:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --body:'Inter',system-ui,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --r:18px;
}
*{box-sizing:border-box}
html,body{margin:0;overflow-x:hidden}
body{background:var(--page);color:var(--ink2);font-family:var(--body);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--disp);color:var(--ink);margin:0;letter-spacing:-.02em}
::selection{background:#cfe0ff}
input,select,textarea,button{font-family:inherit;font-size:14px}

/* ---------- App shell: rounded navy sidebar + white panel ---------- */
.app{display:grid;grid-template-columns:264px 1fr;gap:14px;padding:14px;height:100vh;height:100dvh;overflow:hidden}
.navtoggle{display:none}
.scrim{display:none}

.side{height:100%;border-radius:24px;overflow:hidden;
  background:linear-gradient(178deg,var(--navy-1) 0%,var(--navy-2) 100%);
  display:flex;flex-direction:column;box-shadow:0 24px 60px -30px rgba(20,30,80,.5)}
.brand{display:flex;align-items:center;gap:11px;padding:20px 20px 16px;flex:none}
.brand .mark{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none;
  background:linear-gradient(150deg,#5b8def,#3b6ef5);color:#fff;font-family:var(--disp);font-weight:800;font-size:13px;letter-spacing:.5px}
.brand h1{color:#fff;font-size:19px;font-weight:800;line-height:1}
.brand h1 i{color:var(--brand-3);font-style:normal}
.brand small{display:block;color:var(--nav-ink-dim);font-size:10.5px;margin-top:2px;letter-spacing:.02em}

nav{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding:6px 14px 14px;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}
nav::-webkit-scrollbar{width:7px}
nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:8px}
.nav-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--nav-ink-dim);
  padding:14px 12px 7px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 13px;border-radius:13px;color:var(--nav-ink);
  font-size:14px;font-weight:500;margin-bottom:2px;transition:background .14s,color .14s;position:relative}
.nav-item svg{width:19px;height:19px;flex:none;stroke-width:1.9;opacity:.92}
.nav-item:hover{background:rgba(255,255,255,.06);color:#eaf0ff}
.nav-item.active{background:linear-gradient(180deg,#4f7bf7,#3a6cf4);color:#fff;
  box-shadow:0 10px 22px -10px rgba(59,110,245,.85)}
.nav-item.active svg{opacity:1}
.nav-item .badge{margin-left:auto;font-family:var(--mono);font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:20px;background:rgba(255,255,255,.16);color:#fff}
.nav-item .badge.f{background:var(--red);color:#fff}

.side-foot{flex:none;margin:8px 14px 16px;padding:12px;border-radius:15px;background:rgba(255,255,255,.05);
  display:flex;align-items:center;gap:10px;border:1px solid var(--navy-line)}
.side-foot .avatar{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none;
  background:linear-gradient(150deg,#5b8def,#3b6ef5);color:#fff;font-weight:700;font-size:12px;font-family:var(--mono)}
.side-foot .who{color:#eef2fb;font-size:13px;font-weight:600;line-height:1.2}
.side-foot .role{color:var(--nav-ink-dim);font-size:11px}
.side-foot a{margin-left:auto;color:var(--nav-ink);display:grid;place-items:center;width:30px;height:30px;border-radius:9px}
.side-foot a:hover{background:rgba(255,255,255,.08);color:#fff}

main{border-radius:24px;background:var(--panel);min-width:0;height:100%;display:flex;flex-direction:column;
  box-shadow:0 1px 2px rgba(16,24,64,.03),0 30px 60px -50px rgba(16,24,64,.4);overflow:hidden}

/* ---------- Topbar (greeting + date + search + bell + customize) ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:18px 26px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.topbar .hello{font-family:var(--disp);font-size:21px;font-weight:800;color:var(--ink);letter-spacing:-.02em;margin-right:auto}
.topbar .clock{font-family:var(--mono);font-size:12.5px;color:var(--muted);letter-spacing:.02em;white-space:nowrap}
.tb-pill{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 15px;border-radius:13px;border:1px solid var(--line2);background:#fff;color:var(--ink2);font-size:13px;font-weight:600}
.tb-pill svg{width:16px;height:16px;stroke-width:2}
.tb-search{display:inline-flex;align-items:center;gap:9px;height:40px;padding:0 13px;border-radius:13px;border:1px solid var(--line2);background:#f7f9fe;color:var(--muted);min-width:230px}
.tb-search svg{width:16px;height:16px;stroke-width:2;flex:none}
.tb-search input{border:none;background:transparent;flex:1;min-width:0;color:var(--ink);font-size:13.5px}
.tb-search input:focus{outline:none;box-shadow:none}
.tb-search kbd{font-family:var(--mono);font-size:10px;background:#eef1f8;border:1px solid var(--line2);border-radius:6px;padding:2px 6px;color:var(--muted)}
.tb-ic{width:40px;height:40px;border-radius:13px;border:1px solid var(--line2);background:#fff;display:grid;place-items:center;color:var(--ink2);position:relative;cursor:pointer}
.tb-ic svg{width:18px;height:18px;stroke-width:2}
.tb-ic .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--red);border:1.5px solid #fff}
.tb-customize{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 17px;border-radius:13px;border:1px solid var(--line2);background:#fff;color:var(--ink);font-size:13px;font-weight:700}
.tb-customize svg{width:16px;height:16px;stroke-width:2}
.hamb{display:none}

.content{padding:22px 26px 40px;flex:1;overflow-y:auto;scrollbar-width:thin}
.content::-webkit-scrollbar{width:9px}
.content::-webkit-scrollbar-thumb{background:#d4dbea;border-radius:8px}
.content::-webkit-scrollbar-track{background:transparent}

/* ---------- Headings / structure ---------- */
.sec{font-size:22px;font-weight:800}
.sub{color:var(--muted);font-size:13px;margin-top:4px}
.eyebrow,.section-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);font-weight:600;margin:6px 0 12px}
.between{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.muted{color:var(--muted)}
.hint{color:var(--faint);font-size:11.5px;font-weight:500}
.req{color:var(--red)}
.mono{font-family:var(--mono);font-size:12.5px}
.link{color:var(--brand);font-size:12.5px;font-weight:600}
.link:hover{text-decoration:underline}

/* ---------- Cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px;
  box-shadow:0 1px 2px rgba(16,24,64,.03),0 16px 32px -28px rgba(16,24,64,.22)}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.panel-head h3{font-size:15.5px;font-weight:700}
.grid{display:grid;gap:14px}
.two{grid-template-columns:1fr 1fr}
.cards3{grid-template-columns:repeat(3,1fr)}

/* ---------- Quick-action pills ---------- */
.qa{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.qa a{display:inline-flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line2);border-radius:30px;
  padding:9px 18px 9px 9px;font-size:13.5px;font-weight:600;color:var(--ink);transition:transform .12s,box-shadow .12s,border-color .12s}
.qa a:hover{transform:translateY(-1px);box-shadow:0 12px 24px -16px rgba(16,24,64,.35);border-color:#d6deef}
.qa .qi{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;flex:none}
.qa .qi svg{width:17px;height:17px;stroke-width:2}

/* ---------- KPI dot-matrix cards (dashboard signature) ---------- */
.stat-grid{grid-template-columns:repeat(4,1fr)}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;position:relative;
  box-shadow:0 1px 2px rgba(16,24,64,.03),0 16px 32px -28px rgba(16,24,64,.2)}
.scard .head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.scard .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--brand-dim);color:var(--brand)}
.scard .ic svg{width:19px;height:19px;stroke-width:2}
.scard .delta{font-family:var(--mono);font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px}
.scard .delta.up{background:var(--green-dim);color:var(--green)}
.scard .delta.down{background:var(--red-dim);color:var(--red)}
.scard .delta.flat{background:#eef1f8;color:var(--muted)}
.scard .lbl{color:var(--muted);font-size:13px;font-weight:500}
.scard .n{font-family:var(--disp);font-size:33px;font-weight:800;color:var(--ink);line-height:1.1;margin:2px 0 4px;letter-spacing:-.03em}
.scard .sub2{color:var(--faint);font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.scard .divider{height:1px;background:var(--line);margin:12px 0 11px}
/* dot matrix */
.dots{display:flex;gap:5px;align-items:flex-end;height:42px;margin-bottom:9px}
.dc{display:flex;flex-direction:column-reverse;gap:5px}
.dc i{width:6px;height:6px;border-radius:2px;background:#e9edf7;display:block}
.dc i.on{background:var(--brand-3)}
.scard.green .ic{background:var(--green-dim);color:var(--green)} .scard.green .dc i.on{background:#74d99a}
.scard.violet .ic{background:var(--violet-dim);color:var(--violet)} .scard.violet .dc i.on{background:#a892fb}
.scard.amber .ic{background:var(--amber-dim);color:var(--amber)}
.scard.amber .dc i.on{background:#f4c869}
.scard.rose .ic{background:var(--red-dim);color:var(--red)} .scard.rose .dc i.on{background:#f3888c}
.scard.teal .ic{background:var(--teal-dim);color:var(--teal)} .scard.teal .dc i.on{background:#5cc9c8}

/* ---------- Monthly summary mini cards ---------- */
.statbig{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.statbig .b{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:15px 16px}
.statbig .v{font-family:var(--disp);font-size:23px;font-weight:800;color:var(--ink);letter-spacing:-.02em}
.statbig .k{color:var(--muted);font-size:12px;margin-top:3px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 17px;border-radius:13px;border:1px solid var(--line2);
  background:#fff;color:var(--ink);font-size:13.5px;font-weight:600;cursor:pointer;transition:background .13s,border-color .13s,transform .1s;white-space:nowrap}
.btn:hover{background:#f6f8fe;border-color:#d6deef}
.btn:active{transform:translateY(1px)}
.btn svg{width:16px;height:16px;stroke-width:2}
.btn.primary{background:linear-gradient(180deg,#4f7bf7,#3a6cf4);border-color:#3a6cf4;color:#fff;
  box-shadow:0 12px 22px -12px rgba(59,110,245,.7)}
.btn.primary:hover{background:linear-gradient(180deg,#5b85f9,#4070f6)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn.ghost:hover{background:#f1f4fb;color:var(--ink2)}
.btn.danger{color:var(--red);border-color:#f6d4d6}
.btn.danger:hover{background:var(--red-dim)}
.btn.sm{height:32px;padding:0 12px;font-size:12.5px;border-radius:10px}
.iconbtn{width:34px;height:34px;border-radius:10px;border:1px solid var(--line2);background:#fff;display:inline-grid;place-items:center;color:var(--muted);cursor:pointer;transition:.12s}
.iconbtn svg{width:16px;height:16px;stroke-width:1.9}
.iconbtn:hover{background:#f4f7fe;color:var(--ink2);border-color:#d6deef}
.iconbtn.del:hover{background:var(--red-dim);color:var(--red);border-color:#f6d4d6}

/* ---------- Chips / badges ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:20px;
  background:#eef1f8;color:var(--muted);letter-spacing:.01em;white-space:nowrap}
.chip::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}
.chip.in_stock{background:var(--stock-dim);color:var(--stock)}
.chip.allotted,.chip.allot{background:var(--allot-dim);color:var(--allot)}
.chip.to_receive{background:var(--recv-dim);color:var(--recv)}
.chip.faulty,.chip.fault,.chip.scrapped{background:var(--fault-dim);color:var(--fault)}
.chip.returned_vendor{background:#eef1f8;color:var(--muted)}
.chip.stock{background:var(--stock-dim);color:var(--stock)}
.chip.pay{background:var(--pay-dim);color:var(--pay)}
.chip.active{background:var(--brand);color:#fff}
.chip.active::before{background:#fff}
.vendor-tag{display:inline-flex;align-items:center;font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.04em;
  padding:3px 8px;border-radius:7px;background:#eef2fc;color:#41568f}
.tname{font-weight:600;color:var(--ink2)}

/* ---------- Tables ---------- */
.tscroll{overflow-x:auto;margin:0 -4px;padding:0 4px}
.tscroll::-webkit-scrollbar{height:8px}
.tscroll::-webkit-scrollbar-thumb{background:#dde3f0;border-radius:8px}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
  font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line2);white-space:nowrap}
tbody td{padding:13px 14px;border-bottom:1px solid var(--line);color:var(--ink2);font-size:13.5px;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr.clk{cursor:pointer;transition:background .12s}
tbody tr.clk:hover{background:#f6f8fe}
th.num,td.num{text-align:right;font-family:var(--mono)}
td.desc{color:var(--muted);font-size:12.5px;max-width:280px}

/* ---------- Forms ---------- */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:2px}
.field label{font-size:12px;font-weight:600;color:var(--ink2)}
.field.full{grid-column:1/-1}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
input,select,textarea{width:100%;height:42px;padding:0 13px;border:1px solid var(--line2);border-radius:11px;background:#fff;color:var(--ink);transition:border-color .13s,box-shadow .13s}
textarea{height:auto;min-height:84px;padding:11px 13px;resize:vertical}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(59,110,245,.14)}
input[type=checkbox]{width:17px;height:17px;accent-color:var(--brand);cursor:pointer}
.mb{margin-bottom:16px}
.seg{display:inline-flex;background:#eef1f8;border-radius:11px;padding:3px;gap:2px}
.seg a{padding:7px 14px;border-radius:9px;font-size:12.5px;font-weight:600;color:var(--muted)}
.seg a.on{background:#fff;color:var(--ink);box-shadow:0 2px 6px -2px rgba(16,24,64,.18)}

/* ---------- Search + bulk bars ---------- */
.searchbar{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line2);border-radius:13px;padding:0 14px;height:44px;max-width:560px}
.searchbar svg{color:var(--faint);flex:none}
.searchbar input{border:none;background:transparent;height:auto;padding:0;font-size:14px;flex:1;min-width:0}
.searchbar input:focus{box-shadow:none}
.searchbar .btn{height:32px}
.bulkbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;background:#eef3ff;border:1px solid #d8e3ff;border-radius:14px;padding:11px 14px;margin-bottom:14px}
.bulkbar .cnt{font-weight:700;font-size:13px;color:var(--brand)}
.bulkbar select{height:36px;max-width:240px}
.bulkbar input{height:36px}

/* ---------- Modals (CSS :target) ---------- */
.modal{position:fixed;inset:0;background:rgba(20,28,60,.42);backdrop-filter:blur(3px);display:none;z-index:120;
  align-items:center;justify-content:center;padding:18px}
.modal:target{display:flex}
.modal .box{background:#fff;border-radius:20px;width:520px;max-width:100%;max-height:90vh;max-height:90dvh;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 40px 90px -30px rgba(16,24,64,.5)}
.modal .box.lg{width:780px}
.mh{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line);flex:none}
.mh h3{font-size:16px;font-weight:700}
.mh a{font-size:24px;color:var(--faint);line-height:1}
.mb{padding:20px 22px;overflow-y:auto;flex:1 1 auto;min-height:0}
.mf{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line);background:#fafbfe;border-radius:0 0 20px 20px;flex:none}

/* ---------- Misc page bits ---------- */
.ecard{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;
  box-shadow:0 16px 32px -30px rgba(16,24,64,.22)}
.scard.mini{padding:14px}
.vbar{display:flex;gap:12px;flex-wrap:wrap}
.vcell{flex:1;min-width:120px;background:#f7f9fe;border:1px solid var(--line);border-radius:13px;padding:13px 14px}
.vcell .vn{font-family:var(--disp);font-size:22px;font-weight:800;color:var(--ink);margin-top:7px}
.vcell .vs{color:var(--muted);font-size:11.5px;margin-top:2px}
.arow{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line)}
.arow:last-child{border-bottom:none}
.arow .ad{width:8px;height:8px;border-radius:50%;flex:none}
.arow .grow{flex:1;min-width:0}
.arow .ti{font-size:13px;color:var(--ink2);font-weight:500}
.arow .me{font-size:11.5px;color:var(--muted)}
.feed .ev{display:flex;gap:11px;padding:10px 0;border-bottom:1px solid var(--line)}
.feed .ev:last-child{border-bottom:none}
.feed .ev .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none;background:var(--brand-dim)}
.feed .ev .ic svg{width:15px;height:15px;stroke-width:2}
.feed .ev .t{font-size:12.5px;color:var(--ink2)}
.feed .ev .m{font-size:11px;color:var(--faint);margin-top:2px}
.statbig.stat-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
.timeline .tl{display:flex;gap:11px;padding:10px 0;border-bottom:1px solid var(--line)}
.loc{font-size:11.5px;color:var(--muted)}

/* ---------- Flash ---------- */
.flash{padding:12px 16px;border-radius:13px;font-size:13.5px;font-weight:500;margin-bottom:16px;border:1px solid transparent}
.flash.ok{background:var(--green-dim);color:#15803d;border-color:#bfe8cf}
.flash.err{background:var(--red-dim);color:#c0353a;border-color:#f6cbcd}

/* ---------- Login (split) ---------- */
.login-wrap{min-height:100vh;min-height:100dvh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--panel)}
.login-aside{background:linear-gradient(168deg,var(--navy-1),var(--navy-2));color:#fff;padding:46px 50px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.login-aside .lbrand{display:flex;align-items:center;gap:11px}
.login-aside .lbrand .mk{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex:none;background:linear-gradient(150deg,#5b8def,#3b6ef5);color:#fff;font-family:var(--disp);font-weight:800;font-size:16px;letter-spacing:.5px}
.login-aside .lbrand .lwm{color:#fff;font-family:var(--disp);font-size:26px;font-weight:800;line-height:1;letter-spacing:-.2px}
.login-aside .lbrand .lwm i{color:#86b0ff;font-style:normal}
.lpanel{background:rgba(255,255,255,.07);border:1px solid var(--navy-line);border-radius:18px;padding:20px;margin-top:34px}
.lpanel .rev-k{color:#aebbe0;font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px}
.lpanel .rev-k::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand-3)}
.lpanel .rev-v{font-family:var(--disp);font-size:34px;font-weight:800;margin:10px 0 8px}
.lpanel .rev-v small{font-size:15px;color:#9fb0da;font-weight:600;margin-right:6px}
.lpanel .up{display:inline-flex;align-items:center;gap:5px;background:rgba(64,210,140,.16);color:#7ee2ab;font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px}
.lquote{margin-top:auto;color:#c3cdec;font-style:italic;font-size:14px;line-height:1.6}
.lquote span{display:block;font-style:normal;color:#8e9cc6;font-size:12.5px;margin-top:10px}
.login-main{display:flex;align-items:center;justify-content:center;padding:40px}
.login{width:100%;max-width:380px}
.login .lbrand2{display:flex;align-items:center;gap:10px;margin-bottom:26px}
.login .lbrand2 .mk{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none;background:linear-gradient(150deg,#5b8def,#3b6ef5);color:#fff;font-family:var(--disp);font-weight:800;font-size:14px;letter-spacing:.5px}
.login .lbrand2 .lwm{color:var(--ink);font-family:var(--disp);font-size:23px;font-weight:800;line-height:1;letter-spacing:-.2px}
.login .lbrand2 .lwm i{color:var(--brand);font-style:normal}
.login h1{font-size:30px;font-weight:800;line-height:1.15;margin-bottom:26px}
.login .field{margin-bottom:16px}

/* ---------- Responsive ---------- */
@media(max-width:1100px){ .stat-grid{grid-template-columns:repeat(2,1fr)} .statbig{grid-template-columns:repeat(3,1fr)} .cards3{grid-template-columns:1fr 1fr} }
@media(max-width:920px){
  /* iOS Safari: let the page scroll naturally instead of locking to 100vh (which clips under the address bar) */
  html,body{height:auto;overflow-x:hidden}
  .app{grid-template-columns:1fr;padding:0;gap:0;height:auto;min-height:100dvh;overflow:visible}
  .side{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:280px;max-width:86vw;border-radius:0 22px 22px 0;z-index:200;
    transform:translateX(-104%);transition:transform .24s ease;padding-left:env(safe-area-inset-left);overflow-y:auto}
  .navtoggle:checked ~ .side{transform:translateX(0)}
  .navtoggle:checked ~ .scrim{display:block;position:fixed;inset:0;background:rgba(15,22,50,.5);z-index:150}
  main{border-radius:0;min-height:0;height:auto;overflow:visible}
  .content{overflow:visible;flex:none;padding-bottom:calc(28px + env(safe-area-inset-bottom))}
  .hamb{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;border:1px solid var(--line2);background:#fff;color:var(--ink2);cursor:pointer}
  .hamb svg{width:20px;height:20px;stroke:currentColor;stroke-width:2;fill:none}
  .topbar{padding:14px 16px;position:sticky;top:0;z-index:90;background:var(--panel);padding-top:calc(14px + env(safe-area-inset-top))}
  .topbar .hello{font-size:18px}
  .content{padding:16px}
  .two{grid-template-columns:1fr}
  .tb-search{min-width:0;flex:1}
  .login-wrap{grid-template-columns:1fr}
  .login-aside{display:none}
}
@media(max-width:680px){
  .stat-grid{grid-template-columns:1fr 1fr} .statbig{grid-template-columns:1fr 1fr} .cards3{grid-template-columns:1fr}
  .formgrid{grid-template-columns:1fr}
  input,select,textarea{font-size:16px} /* iOS no-zoom */
  .modal{padding:0;align-items:flex-end}
  .modal .box{width:100%;border-radius:20px 20px 0 0;max-height:92vh;max-height:92dvh}
  .modal .box.lg{width:100%}
  .mf{padding-bottom:calc(16px + env(safe-area-inset-bottom))}
  .tb-search kbd{display:none}
}

/* ---- vendor-wise organized ---- */
.vgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.vrow{background:#f7f9fe;border:1px solid var(--line);border-radius:13px;padding:13px 14px}
.vtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.vtop .vtot{font-family:var(--disp);font-size:22px;font-weight:800;color:var(--ink)}
.vbarline{display:flex;height:8px;border-radius:6px;overflow:hidden;background:#e6ebf5;margin-bottom:8px}
.vbarline span{display:block;height:100%}
.vlegend{font-size:11px;color:var(--muted);display:flex;align-items:center;flex-wrap:wrap}
.vlegend i{width:8px;height:8px;border-radius:3px;display:inline-block;margin:0 5px 0 0;vertical-align:middle}
/* ---- top dealers list ---- */
.dlist{display:flex;flex-direction:column;gap:4px}
.drow{display:flex;align-items:center;gap:14px;padding:11px 12px;border-radius:12px;transition:background .12s}
.drow:hover{background:#f6f8fe}
.drow .dinfo{flex:1;min-width:0}
.drow .dn{font-weight:600;color:var(--ink2);font-size:13.5px;margin-bottom:6px}
.drow .dbar{height:7px;background:#e9edf7;border-radius:5px;overflow:hidden}
.drow .dbar span{display:block;height:100%;background:linear-gradient(90deg,#5b8def,#3b6ef5);border-radius:5px}
.drow .dcount{text-align:right;flex:none}
.drow .dcount b{font-family:var(--disp);font-size:18px;color:var(--ink);font-weight:800}
.drow .dcount small{display:block;font-size:10px;color:var(--faint);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
/* ---- searchable combo ---- */
.combo{position:relative}
.combo-list{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--line2);
  border-radius:12px;box-shadow:0 18px 40px -20px rgba(16,24,64,.35);max-height:260px;overflow:auto;z-index:40}
.combo-list > div{padding:10px 14px;font-size:13.5px;cursor:pointer;border-bottom:1px solid var(--line)}
.combo-list > div:last-child{border-bottom:none}
.combo-list > div:hover{background:#f1f4fb}
/* ---- pager ---- */
.pager{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.pgbtn{min-width:32px;height:32px;border-radius:9px;border:1px solid var(--line2);background:#fff;color:var(--muted);font-size:12.5px;font-weight:600;cursor:pointer;font-family:var(--mono)}
.pgbtn:hover{background:#f4f7fe;color:var(--ink2)}
.pgbtn.on{background:var(--brand);border-color:var(--brand);color:#fff}
/* ---- topbar notification dropdown ---- */
.belldrop{position:relative}
.bellmenu{display:none;position:absolute;top:calc(100% + 8px);right:0;width:320px;max-width:86vw;background:#fff;border:1px solid var(--line2);
  border-radius:16px;box-shadow:0 24px 60px -24px rgba(16,24,64,.45);z-index:60;overflow:hidden}
.belldrop:focus-within .bellmenu,.bellmenu.open{display:block}
.bellmenu .bh{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700;color:var(--ink);font-size:13.5px}
.bellmenu .bi{display:flex;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line)}
.bellmenu .bi:last-child{border-bottom:none}
.bellmenu .bi .t{font-size:12.5px;color:var(--ink2)}
.bellmenu .bi .m{font-size:11px;color:var(--faint);margin-top:2px}

/* inventory filters bar */
.invfilters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.invfilters select{width:auto;min-width:130px;height:44px}
.invfilters .btn{height:44px}

/* ---------- collapse button + logout ---------- */
.brand .brandtext{flex:1;min-width:0}
.collapse-btn{width:30px;height:30px;border-radius:9px;border:1px solid var(--navy-line);background:rgba(255,255,255,.05);color:var(--nav-ink);display:grid;place-items:center;cursor:pointer;flex:none;transition:.15s}
.collapse-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.collapse-btn svg{width:16px;height:16px}
.collapse-btn .ic-unlock{display:none}
.logout-form{flex:none;margin:0 14px 16px}
.logout-btn{width:100%;display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:13px;border:1px solid var(--navy-line);
  background:rgba(255,255,255,.04);color:var(--nav-ink);font-size:14px;font-weight:600;cursor:pointer;transition:.14s}
.logout-btn:hover{background:rgba(229,72,77,.16);border-color:rgba(229,72,77,.3);color:#ffb4b7}
.logout-btn svg{width:18px;height:18px;flex:none}

/* ---------- unpinned sidebar: icon rail that expands on hover ---------- */
.collapse-btn .ic-unlock{display:none}
.app.unpinned{grid-template-columns:84px 1fr}
.app.unpinned main{grid-column:2}
.app.unpinned .side{position:fixed;top:14px;left:14px;height:calc(100dvh - 28px);width:84px;z-index:250;transition:width .18s ease}
.app.unpinned .side:hover{width:264px;box-shadow:0 30px 70px -20px rgba(20,30,80,.6)}
.app.unpinned .collapse-btn .ic-lock{display:none}
.app.unpinned .collapse-btn .ic-unlock{display:block}
/* contents hidden while rail is collapsed (not hovered) */
.app.unpinned .side:not(:hover) .brandtext,
.app.unpinned .side:not(:hover) .nav-label,
.app.unpinned .side:not(:hover) .nav-txt,
.app.unpinned .side:not(:hover) .foot-id,
.app.unpinned .side:not(:hover) .foot-acc,
.app.unpinned .side:not(:hover) .collapse-btn{display:none}
.app.unpinned .side:not(:hover) .brand{justify-content:center;padding:20px 0 16px}
.app.unpinned .side:not(:hover) nav{padding:6px 12px}
.app.unpinned .side:not(:hover) .nav-item{justify-content:center;padding:11px 0}
.app.unpinned .side:not(:hover) .nav-item .badge{position:absolute;top:5px;right:18px;margin:0;padding:0;min-width:8px;width:8px;height:8px;font-size:0;border-radius:50%}
.app.unpinned .side:not(:hover) .side-foot{justify-content:center;padding:12px 0;margin:8px 12px 8px}
.app.unpinned .side:not(:hover) .logout-form{margin:0 12px 16px}
.app.unpinned .side:not(:hover) .logout-btn{justify-content:center;padding:11px 0}
@media(max-width:920px){ .app.unpinned{grid-template-columns:1fr} .app.unpinned .side{position:fixed} .collapse-btn{display:none} }

/* ---------- KPI vendor mini-list ---------- */
.vmini{display:flex;flex-direction:column;gap:7px}
.vmini-r{display:flex;align-items:center;justify-content:space-between;gap:8px}
.vmini-r b{font-family:var(--mono);font-size:13px;color:var(--ink);font-weight:700}

/* ---------- themed confirm dialog ---------- */
.cxc-overlay{position:fixed;inset:0;background:rgba(18,26,58,.5);backdrop-filter:blur(4px);z-index:300;
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .18s}
.cxc-overlay.show{opacity:1;visibility:visible}
.cxc-box{background:#fff;border-radius:20px;width:400px;max-width:100%;padding:26px 24px 20px;text-align:center;
  box-shadow:0 40px 90px -30px rgba(16,24,64,.6);transform:translateY(12px) scale(.97);transition:transform .2s cubic-bezier(.34,1.56,.64,1)}
.cxc-overlay.show .cxc-box{transform:translateY(0) scale(1)}
.cxc-ic{width:54px;height:54px;border-radius:16px;margin:0 auto 14px;display:grid;place-items:center;background:var(--red-dim);color:var(--red)}
.cxc-ic svg{width:26px;height:26px}
.cxc-box h3{font-size:18px;font-weight:800;margin-bottom:7px}
.cxc-box p{color:var(--muted);font-size:13.5px;line-height:1.55;margin-bottom:20px}
.cxc-actions{display:flex;gap:10px}
.cxc-actions .btn{flex:1;justify-content:center;height:44px}

/* installment delete option buttons */
.idel-opt{width:100%;text-align:left;display:flex;flex-direction:column;gap:3px;padding:13px 15px;border-radius:13px;
  border:1px solid var(--line2);background:var(--panel-2);cursor:pointer;transition:.14s}
.idel-opt:hover{border-color:var(--brand);background:var(--brand-dim)}
.idel-opt b{font-size:14px;color:var(--ink)}
.idel-opt span{font-size:12px;color:var(--muted)}

/* to-collect status chip (pending collection from dealer) */
.chip.to_collect{background:#fff3e0;color:#c05621}
.vendor-tag{}

/* sortable table headers */
th[data-sort]{cursor:pointer;white-space:nowrap}
th[data-sort]:hover{color:var(--brand)}
th .sortarrow{color:var(--brand);font-weight:700}
