/* HACG 进销存 全局样式 */
:root{
  --bg:#f4f6f9;--card:#fff;--line:#e5e9f0;--txt:#1f2937;--sub:#6b7280;
  --pri:#2563eb;--pri-d:#1d4ed8;--ok:#16a34a;--warn:#d97706;--bad:#dc2626;
  --gold:#b45309;--r:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,"PingFang SC","Microsoft YaHei",sans-serif;
  background:var(--bg);color:var(--txt);font-size:14px}
a{color:var(--pri);text-decoration:none}
h2{font-size:18px;margin-bottom:14px}
h3{font-size:15px;margin:14px 0 8px}

/* ---- 桌面布局 ---- */
.layout{display:flex;min-height:100vh}
.side{width:200px;background:#111827;color:#d1d5db;flex-shrink:0;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.side .logo{padding:18px 16px;font-weight:700;color:#fff;font-size:15px;
  border-bottom:1px solid #1f2937}
.side .logo small{display:block;font-weight:400;color:#9ca3af;font-size:11px;margin-top:3px}
.side .grp{padding:10px 16px 4px;font-size:11px;color:#6b7280}
.side a{display:block;padding:9px 16px;color:#d1d5db;font-size:13px}
.side a:hover{background:#1f2937;color:#fff}
.side a.on{background:var(--pri);color:#fff}
.side .foot{margin-top:auto;padding:12px 16px;border-top:1px solid #1f2937;font-size:12px}
.main{flex:1;padding:20px 24px;max-width:1280px}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.topbar .ev{background:#eef2ff;color:#3730a3;padding:4px 12px;border-radius:99px;font-size:12px}

/* ---- 组件 ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:16px;margin-bottom:16px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px}
.stat .n{font-size:24px;font-weight:700;margin-top:4px}
.stat .l{color:var(--sub);font-size:12px}
.stat.gold .n{color:var(--gold)} .stat.bad .n{color:var(--bad)} .stat.ok .n{color:var(--ok)}

table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:9px 10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}
th{background:#f9fafb;color:var(--sub);font-weight:600;white-space:nowrap}
tr:hover td{background:#fafbfd}
.num{text-align:right;font-variant-numeric:tabular-nums}

.btn{display:inline-block;border:none;border-radius:8px;padding:8px 16px;font-size:13px;
  cursor:pointer;background:var(--pri);color:#fff;line-height:1.4}
.btn:hover{background:var(--pri-d)}
.btn.ghost{background:#fff;color:var(--txt);border:1px solid var(--line)}
.btn.ghost:hover{background:#f3f4f6}
.btn.sm{padding:4px 10px;font-size:12px;border-radius:6px}
.btn.bad{background:var(--bad)} .btn.ok{background:var(--ok)} .btn.warn{background:var(--warn)}
.btn:disabled{opacity:.5;cursor:not-allowed}

input,select,textarea{border:1px solid #d1d5db;border-radius:8px;padding:8px 10px;
  font-size:14px;width:100%;background:#fff;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:2px solid #bfdbfe;border-color:var(--pri)}
label{display:block;font-size:12px;color:var(--sub);margin:10px 0 4px}
.row{display:flex;gap:10px;flex-wrap:wrap}
.row>*{flex:1;min-width:120px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.filters input,.filters select{width:auto;min-width:110px}

.tag{display:inline-block;padding:2px 8px;border-radius:99px;font-size:12px;background:#f3f4f6}
.tag.gold{background:#fef3c7;color:var(--gold)}
.tag.blue{background:#dbeafe;color:#1e40af}
.tag.ok{background:#dcfce7;color:#166534}
.tag.bad{background:#fee2e2;color:#991b1b}
.tag.warn{background:#ffedd5;color:#9a3412}

.muted{color:var(--sub)} .b{font-weight:600}
.pager{margin-top:12px;display:flex;gap:8px;align-items:center}

/* ---- 弹层 ---- */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);display:none;
  align-items:center;justify-content:center;z-index:50;padding:16px}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:14px;padding:20px;width:100%;max-width:440px;
  max-height:90vh;overflow-y:auto}
.modal h3{margin:0 0 6px}

/* ---- Toast ---- */
#toast{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:99;
  display:flex;flex-direction:column;gap:8px;align-items:center}
#toast .t{background:#111827;color:#fff;padding:10px 18px;border-radius:10px;
  font-size:14px;box-shadow:0 6px 20px rgba(0,0,0,.25);max-width:90vw}
#toast .t.err{background:var(--bad)} #toast .t.ok{background:var(--ok)}

/* ---- 手机端 ---- */
.m-body{max-width:560px;margin:0 auto;min-height:100vh;background:var(--bg);
  display:flex;flex-direction:column}
.m-head{background:#111827;color:#fff;padding:14px 16px;display:flex;
  justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10}
.m-head .ttl{font-weight:700;font-size:16px}
.m-head a{color:#9ca3af;font-size:13px}
.m-main{padding:16px;flex:1}
.bigbtn{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:16px;padding:20px 18px;margin-bottom:14px;font-size:17px;font-weight:600;
  color:var(--txt);box-shadow:0 1px 3px rgba(0,0,0,.04)}
.bigbtn .ic{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:22px;color:#fff;flex-shrink:0}
.bigbtn small{display:block;font-weight:400;color:var(--sub);font-size:12px;margin-top:3px}
.ic.blue{background:var(--pri)} .ic.gold{background:#d97706} .ic.green{background:var(--ok)}
.ic.gray{background:#6b7280}

#reader{width:100%;border-radius:14px;overflow:hidden;background:#000;min-height:230px}
.scan-tip{text-align:center;color:var(--sub);font-size:12px;margin:8px 0}
.found{background:#eef6ff;border:1px solid #bfdbfe;border-radius:12px;padding:12px;margin:12px 0}
.found .nm{font-weight:700;font-size:16px}
.photo-box{border:2px dashed #cbd5e1;border-radius:14px;min-height:150px;display:flex;
  align-items:center;justify-content:center;color:var(--sub);overflow:hidden;background:#fff}
.photo-box img{width:100%;display:block}
.thumb{width:44px;height:44px;object-fit:cover;border-radius:8px;border:1px solid var(--line);
  background:#f3f4f6;cursor:pointer;display:block}
.thumb-sm{width:36px;height:36px;object-fit:cover;border-radius:6px;border:1px solid var(--line);flex-shrink:0}
.noimg{width:44px;height:44px;border-radius:8px;background:#f3f4f6;color:#cbd5e1;
  display:flex;align-items:center;justify-content:center;font-size:11px}
.m-submit{position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg) 30%);
  padding:10px 0 16px}
.m-submit .btn{width:100%;padding:14px;font-size:16px;border-radius:12px}
.qbadge{background:var(--warn);color:#fff;border-radius:99px;padding:2px 10px;font-size:12px}
.consent{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--sub);margin:10px 0}
.consent input{width:18px;height:18px;flex-shrink:0;margin-top:1px}

@media (max-width:860px){
  .layout{flex-direction:column}
  .side{width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center}
  .side .grp{display:none}.side .logo{border:none;padding:12px}
  .side a{padding:10px 12px}.side .foot{margin:0;border:none;margin-left:auto}
  .main{padding:14px}
  table{display:block;overflow-x:auto;white-space:nowrap}
}
@media print{.side,.topbar,.btn,.filters{display:none!important}.main{padding:0}}
