@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap');
*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#f5f4f0;--surface:#fff;--card:#fff;--s2:#f0efe9;--s3:#e8e7e0;
  --text:#1a1917;--t2:#6b6a65;--t3:#9e9d98;
  --accent:#2563c4;--al:#e8effe;
  --green:#1a7a4a;--gl:#e6f4ed;
  --amber:#b45309;--aml:#fef3e2;
  --red:#c0392b;--rl:#fdecea;
  --border:#e2e1db;--r:10px;--rl2:16px;
}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;height:100vh;overflow:hidden;}
.shell{display:flex;height:100vh;}

/* ── Sidebar ── */
.sidebar{width:220px;flex-shrink:0;background:#111110;display:flex;flex-direction:column;}
.logo{padding:14px 16px 12px;border-bottom:1px solid rgba(255,255,255,.08);}
.logo-mark{display:flex;align-items:center;gap:9px;}
.logo-eye{width:28px;height:28px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;}
.logo-eye svg{width:14px;height:14px;fill:#fff;}
.logo-name{font-size:15px;font-weight:500;color:#fff;}
.logo-sub{font-size:10px;color:rgba(255,255,255,.3);margin-top:1px;}
.nav{flex:1;padding:6px 0;overflow-y:auto;}
.ns{padding:6px 14px 2px;font-size:9px;color:rgba(255,255,255,.25);letter-spacing:.1em;text-transform:uppercase;}
.ni{display:flex;align-items:center;gap:9px;padding:7px 14px;cursor:pointer;color:rgba(255,255,255,.45);font-size:12px;transition:all .15s;border-left:2px solid transparent;margin:1px 0;}
.ni:hover{color:rgba(255,255,255,.88);background:rgba(255,255,255,.06);}
.ni.active{color:#fff;background:rgba(255,255,255,.1);border-left-color:var(--accent);}
.ni svg{width:15px;height:15px;flex-shrink:0;opacity:.6;}
.ni.active svg{opacity:1;}
.ni-group-hd{display:flex;align-items:center;gap:9px;padding:7px 14px;cursor:pointer;color:rgba(255,255,255,.45);font-size:12px;transition:all .15s;border-left:2px solid transparent;margin:1px 0;user-select:none;}
.ni-group-hd:hover{color:rgba(255,255,255,.88);background:rgba(255,255,255,.06);}
.ni-group-hd.open{color:rgba(255,255,255,.75);}
.ni-group-hd.active{color:#fff;background:rgba(255,255,255,.1);border-left-color:var(--accent);}
.ni-group-hd svg{width:15px;height:15px;flex-shrink:0;opacity:.6;}
.ni-group-hd.open svg{opacity:.9;}
.ni-chevron{margin-left:auto;font-size:12px;transition:transform .2s;opacity:.4;line-height:1;}
.ni-group-hd.open .ni-chevron{transform:rotate(90deg);opacity:.65;}
.ni-sub-list{overflow:hidden;transition:max-height .22s ease;max-height:0;}
.ni-sub-list.open{max-height:320px;}
.ni-sub{display:flex;align-items:center;gap:8px;padding:5px 14px 5px 38px;cursor:pointer;color:rgba(255,255,255,.38);font-size:11.5px;transition:all .15s;border-left:2px solid transparent;margin:0;}
.ni-sub:hover{color:rgba(255,255,255,.75);background:rgba(255,255,255,.05);}
.ni-sub.active{color:#c4b5fd;background:rgba(139,92,246,.15);border-left-color:#8b5cf6;}
.nbadge{margin-left:auto;background:var(--accent);color:#fff;font-size:10px;padding:1px 6px;border-radius:10px;font-family:'DM Mono',monospace;}
.nbadge.red{background:var(--red);}
.sf{padding:10px 14px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:9px;}
.sa{width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:#fff;}
.sn{font-size:12px;color:rgba(255,255,255,.8);}
.sb{font-size:10px;color:rgba(255,255,255,.3);}

/* ── Main ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{height:44px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;flex-shrink:0;}
.mobile-menu-btn{display:none;width:34px;height:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;}
.tb-title{font-size:15px;font-weight:500;flex:1;}
.searchbox{display:flex;align-items:center;gap:8px;background:var(--s2);border:1px solid var(--border);border-radius:var(--r);padding:6px 12px;width:240px;}
.searchbox input{background:none;border:none;outline:none;font-size:13px;color:var(--text);width:100%;font-family:'DM Sans',sans-serif;}
.searchbox input::placeholder{color:var(--t3);}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--r);border:none;cursor:pointer;font-size:13px;font-family:'DM Sans',sans-serif;font-weight:500;transition:all .15s;}
.btn-p{background:var(--accent);color:#fff;}
.btn-p:hover{opacity:.88;}
.btn-g{background:transparent;color:var(--t2);border:1px solid var(--border);}
.btn-g:hover{background:var(--s2);}
.btn-green{background:var(--green);color:#fff;}
.btn-red{background:var(--red);color:#fff;}
.content{flex:1;overflow-y:auto;padding:14px;}
.page{display:none;}
.page.active{display:block;}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl2);overflow:hidden;margin-bottom:10px;}
.ch{padding:9px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;}
.ct{font-size:12px;font-weight:500;}
.cb{padding:12px 14px;}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;}

@media (max-width: 760px){
  body{overflow:hidden;}
  .shell{position:relative;}
  .sidebar{position:fixed;z-index:1200;left:0;top:0;bottom:0;width:280px;max-width:82vw;transform:translateX(-100%);transition:transform .2s ease;box-shadow:16px 0 32px rgba(0,0,0,.22);}
  body.sidebar-open .sidebar{transform:translateX(0);}
  body.sidebar-open::after{content:"";position:fixed;inset:0;background:rgba(15,23,42,.38);z-index:1100;}
  .main{min-width:0;width:100%;}
  .topbar{height:50px;padding:0 10px;gap:8px;}
  .mobile-menu-btn{display:inline-flex;}
  .tb-title{font-size:15px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  #sync-indicator{display:none!important;}
  .topbar .btn{height:34px;padding:0 10px;font-size:12px;white-space:nowrap;}
  .content{padding:10px;overflow-x:hidden;}
  .dash-kpi-grid{grid-template-columns:1fr 1fr!important;gap:10px!important;margin-bottom:14px!important;}
  .dash-main-grid{grid-template-columns:1fr!important;gap:12px!important;}
  .dash-quick-form{grid-template-columns:1fr!important;}
  .dash-table-scroll{overflow-x:auto;}
  .dash-table-scroll table{min-width:560px;}
  #sp-overview-cards{grid-template-columns:1fr 1fr!important;}
  #sp-order-toolbar{align-items:stretch!important;}
  #sp-order-toolbar .sp-order-toolbar-filters,#sp-order-toolbar .sp-order-toolbar-actions{width:100%;}
  #sp-order-toolbar input,#sp-order-toolbar select,#sp-order-toolbar button{width:100%;min-width:0!important;}
  #mp-msg-btn{width:44px!important;height:44px!important;right:16px!important;bottom:22px!important;font-size:20px!important;}
  #mp-msg-panel{right:10px!important;left:10px!important;bottom:74px!important;width:auto!important;max-height:70vh!important;}
  .toast{top:50%!important;bottom:auto!important;white-space:normal;text-align:center;padding:10px 14px;}
}

@media (max-width: 420px){
  .dash-kpi-grid,#sp-overview-cards{grid-template-columns:1fr!important;}
}

/* ── Tags ── */
.tag{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500;}
.tag-kc{background:var(--rl);color:var(--red);}
.tag-ok{background:var(--al);color:var(--accent);}
.tag-myo{background:var(--gl);color:var(--green);}
.tag-norm{background:var(--s2);color:var(--t2);}
.tag-warn{background:var(--aml);color:var(--amber);}
.tag-good{background:var(--gl);color:var(--green);}

/* Supplier order workbench */
.sp-workbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:-2px 0 12px;}
.sp-order-toolbar{display:flex;align-items:center;justify-content:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:12px;}
.sp-order-toolbar-filters{display:flex;align-items:center;gap:8px;flex:0 1 620px;min-width:280px;flex-wrap:wrap;}
.sp-order-toolbar-actions{display:flex;align-items:center;justify-content:flex-start;gap:8px;flex:0 1 auto;flex-wrap:wrap;}
.sp-order-toolbar select,.sp-order-toolbar input{height:32px;border:1px solid var(--border);border-radius:var(--r);padding:0 10px;font-size:12px;outline:none;background:var(--surface);}
.sp-order-toolbar select{width:146px;}
.sp-order-toolbar input[type="search"]{width:296px;min-width:220px;flex:1 1 260px;}
.sp-order-toolbar input[type="date"]{width:146px;padding:0 8px;}
.sp-order-toolbar .btn{height:32px;font-size:12px;padding:0 12px;white-space:nowrap;}
.sp-qchip{height:30px;padding:0 12px;border:1px solid var(--border);border-radius:15px;background:var(--surface);color:var(--t2);font-size:12px;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;gap:5px;transition:all .15s;}
.sp-qchip:hover{border-color:#cbd5e1;color:var(--text);background:#f8fafc;}
.sp-qchip.active{border-color:var(--accent);background:#eff6ff;color:var(--accent);font-weight:600;}
.sp-qchip .num{color:var(--t3);font-family:'DM Mono',monospace;font-size:11px;}
.sp-qchip.active .num{color:var(--accent);}
.sp-empty{padding:42px 16px;text-align:center;color:var(--t3);font-size:13px;background:#fafafa;border:1px dashed var(--border);border-radius:10px;}
.sp-stats-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:14px;flex-wrap:wrap;padding:10px 12px;background:#fafafa;border:1px solid var(--border);border-radius:10px;}
.sp-stats-toolbar-group{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.sp-stats-kpi{display:grid;gap:12px;margin-bottom:16px;}
.sp-kpi-section{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px;}
.sp-kpi-section-title{font-size:12px;font-weight:700;color:var(--t2);margin-bottom:10px;}
.sp-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;}
.sp-kpi-card{background:#fafafa;border:1px solid var(--border);border-radius:8px;padding:12px 14px;min-width:0;}
.sp-kpi-label{font-size:12px;color:var(--t2);margin-bottom:4px;}
.sp-kpi-value{font-size:24px;line-height:1.1;font-weight:700;font-family:'DM Mono',monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sp-kpi-sub{font-size:11px;color:var(--t3);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sp-order-card{border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden;transition:border-color .15s,box-shadow .15s,background .15s;}
.sp-order-card:hover{border-color:#cbd5e1;box-shadow:0 8px 22px rgba(15,23,42,.06);}
.sp-order-head{padding:13px 14px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;cursor:pointer;align-items:start;}
.sp-order-main{min-width:0;}
.sp-order-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.sp-order-no{font-size:13px;font-weight:700;color:var(--text);font-family:'DM Mono',monospace;letter-spacing:0;}
.sp-chip{display:inline-flex;align-items:center;gap:4px;height:22px;padding:0 8px;border-radius:11px;font-size:11px;font-weight:600;white-space:nowrap;}
.sp-chip.neutral{background:#f1f5f9;color:#64748b;}
.sp-chip.warn{background:#fff7ed;color:#c2410c;}
.sp-chip.bad{background:#fef2f2;color:#dc2626;}
.sp-chip.ok{background:#ecfdf5;color:#059669;}
.sp-order-title{font-size:12px;color:var(--t2);margin-top:6px;display:flex;gap:8px;align-items:center;min-width:0;}
.sp-order-line{font-size:11px;color:var(--t3);margin-top:3px;max-width:780px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sp-order-side{display:flex;align-items:flex-start;gap:10px;justify-content:flex-start;min-width:260px;}
.sp-order-money{font-size:14px;font-weight:700;text-align:right;white-space:nowrap;}
.sp-order-money.unpriced{color:#b45309;}
.sp-status-pill{height:24px;padding:0 10px;border-radius:12px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;white-space:nowrap;}
.sp-actions{display:flex;flex-direction:column;align-items:flex-start;gap:6px;max-width:270px;}
.sp-order-action-top{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-start;}
.sp-order-action-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-start;}
.sp-order-action-primary,.sp-order-action-more-btn{height:28px;padding:0 10px;border-radius:8px;font-size:11px;font-weight:650;white-space:nowrap;cursor:pointer;transition:all .15s;}
.sp-order-action-primary{min-width:64px;border:1px solid var(--border);background:#fff;color:#344054;box-shadow:var(--shadow-sm);}
.sp-order-action-primary:hover{background:#f8fafc;border-color:#c9d6e4;color:#111827;transform:translateY(-1px);}
.sp-order-action-primary.btn-p{border-color:var(--accent);background:linear-gradient(135deg,var(--accent),#1559c9);color:#fff;box-shadow:0 8px 18px rgba(31,111,235,.22);}
.sp-order-action-primary.btn-p:hover{background:linear-gradient(135deg,var(--accent),#1559c9);color:#fff;box-shadow:0 12px 24px rgba(31,111,235,.28);}
.sp-order-action-primary.btn-red{border-color:var(--red);background:linear-gradient(135deg,#d64550,#b4232e);color:#fff;box-shadow:0 8px 18px rgba(214,69,80,.18);}
.sp-order-action-primary.btn-red:hover{background:linear-gradient(135deg,#d64550,#b4232e);color:#fff;box-shadow:0 12px 24px rgba(214,69,80,.24);}
.sp-order-action-more-btn{border:1px solid var(--border);background:#fff;color:var(--t2);}
.sp-order-action-menu{position:fixed;z-index:100030;min-width:120px;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 12px 30px rgba(15,23,42,.16);overflow:hidden;}
.sp-order-action-menu button{display:block;width:100%;padding:7px 12px;border:0;background:#fff;text-align:left;font-size:12px;cursor:pointer;color:#374151;}
.sp-order-action-menu button:hover{background:#f8fafc;}
.sp-order-action-menu .danger{color:#dc2626;}
.sp-defective-actions{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.sp-defective-action-btn{height:26px;padding:0 9px;border-radius:8px;font-size:11px;line-height:24px;}
.sp-defective-more-btn{height:26px;min-width:42px;padding:0 9px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--t2);font-size:11px;cursor:pointer;}
.sp-defective-more-btn:hover{background:#f8fafc;color:var(--text);}
.sp-defective-action-menu{position:fixed;z-index:10020;min-width:112px;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 12px 30px rgba(15,23,42,.16);overflow:hidden;}
.sp-defective-action-menu button{display:block;width:100%;padding:8px 12px;border:0;background:#fff;text-align:left;font-size:12px;cursor:pointer;color:#374151;}
.sp-defective-action-menu button:hover{background:#f8fafc;}
.sp-defective-action-menu .primary{color:#2563eb;}
.sp-defective-action-menu .success{color:#16a34a;}
.sp-defective-action-menu .warn{color:#d97706;}
.sp-defective-action-menu .danger{color:#dc2626;}
.sp-progress{margin-top:9px;display:grid;grid-template-columns:minmax(120px,180px) minmax(0,1fr);gap:8px;align-items:center;max-width:520px;}
.sp-progress-text{font-size:11px;color:var(--t2);font-weight:600;}
.sp-progress-track{height:6px;background:#eef2f7;border-radius:999px;overflow:hidden;}
.sp-progress-fill{height:100%;background:#2563c4;border-radius:999px;}
.sp-order-alerts{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.sp-order-table-wrap{border:1px solid var(--border);border-radius:10px;overflow:auto;background:var(--surface);}
.sp-order-table{width:100%;min-width:1260px;border-collapse:collapse;table-layout:fixed;font-size:12px;}
.sp-order-table th{height:40px;padding:0 10px;text-align:left;color:var(--t2);background:#f8fafc;border-bottom:1px solid var(--border);font-weight:700;white-space:nowrap;}
.sp-order-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle;}
.sp-order-table tbody tr.sp-priority-row{background:#fffafb;}
.sp-order-table tbody tr.sp-order-row:hover{background:#fbfdff;}
.sp-order-table .w-check{width:38px;text-align:center;}
.sp-order-table .w-order{width:148px;}
.sp-order-table .w-status{width:86px;text-align:center;}
.sp-order-table .w-clinic{width:128px;}
.sp-order-table .w-code{width:112px;}
.sp-order-table .w-name{width:132px;}
.sp-order-table .w-brand{width:88px;}
.sp-order-table .w-series{width:92px;}
.sp-order-table .w-model{width:92px;}
.sp-order-table .w-desc{width:176px;}
.sp-order-table .w-qty{width:60px;text-align:center;}
.sp-order-table .w-process{width:96px;}
.sp-order-table .w-money{width:104px;text-align:right;}
.sp-order-table .w-action{width:128px;text-align:left;}
.sp-proc-payable-table-wrap{margin-left:0;margin-right:auto;}
.sp-proc-payable-table{margin-left:0;margin-right:auto;text-align:left;}
.sp-proc-payable-table th,
.sp-proc-payable-table td{text-align:left;}
.sp-proc-payable-table th,
.sp-proc-payable-table td{overflow:hidden;text-overflow:ellipsis;}
.sp-proc-payable-table td:nth-child(2){white-space:normal;line-height:1.45;}
.sp-proc-payable-table td:nth-child(9){overflow:visible;}
.sp-proc-payable-table th:nth-child(4),
.sp-proc-payable-table th:nth-child(5),
.sp-proc-payable-table th:nth-child(6),
.sp-proc-payable-table td:nth-child(4),
.sp-proc-payable-table td:nth-child(5),
.sp-proc-payable-table td:nth-child(6){text-align:right!important;}
.sp-proc-table{min-width:1600px;}
.sp-proc-table .w-proc{width:160px;}
.sp-proc-table .w-vendor{width:150px;}
.sp-proc-table .w-issue{width:176px;}
.sp-proc-table .w-inbound{width:118px;}
.sp-proc-table .w-action{width:210px;}
.sp-proc-table .sp-status-pill{height:22px;font-size:11px;padding:0 8px;}
.sp-proc-row .sp-actions{gap:5px;align-items:flex-start;}
.sp-proc-action-inline{display:flex;align-items:center;justify-content:flex-start;gap:8px;white-space:nowrap;}
.sp-proc-inline-primary{height:30px;padding:0 12px;border:1px solid var(--accent);border-radius:8px;background:linear-gradient(135deg,var(--accent),#1559c9);color:#fff;font-size:12px;font-weight:800;cursor:pointer;box-shadow:0 8px 18px rgba(31,111,235,.18);}
.sp-proc-inline-primary:hover{filter:brightness(.98);box-shadow:0 10px 22px rgba(31,111,235,.24);}
.sp-proc-inline-status{height:30px;min-width:108px;padding:0 12px;border:1px solid #d8e1ed;border-radius:8px;background:#f8fafc;color:#64748b;font-size:12px;font-weight:800;cursor:not-allowed;}
.sp-proc-action-more-btn{height:30px;min-width:64px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#1f2937;font-size:12px;font-weight:700;line-height:28px;text-align:center;cursor:pointer;box-shadow:var(--shadow-sm);}
.sp-proc-action-more-btn::after{content:"";display:inline-block;margin-left:6px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid #64748b;vertical-align:middle;}
.sp-proc-action-more-btn:hover{border-color:#b7c7dc;background:#f8fafc;}
.sp-proc-action-menu{position:fixed;z-index:100030;min-width:106px;padding:5px;border:1px solid #d1d5db;border-radius:8px;background:#fff;box-shadow:0 12px 28px rgba(15,23,42,.14);}
.sp-proc-action-menu button{display:block;width:100%;height:28px;padding:0 9px;border:0;border-radius:6px;background:#fff;color:#374151;text-align:left;font-size:12px;white-space:nowrap;cursor:pointer;}
.sp-proc-action-menu button:hover{background:#f8fafc;}
.sp-proc-action-menu button.primary{color:#1d4ed8;font-weight:700;}
.sp-proc-action-menu button.danger{color:#dc2626;font-weight:700;}
.sp-proc-progress .sp-cell-line{font-weight:700;color:var(--text);}
.sp-proc-note{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sp-proc-items-wrap{overflow:auto;border:1px solid var(--border);border-radius:8px;margin-top:10px;background:#fff;}
.sp-proc-items-table{width:100%;min-width:1180px;table-layout:fixed;font-size:12px;border-collapse:separate;border-spacing:0;}
.sp-proc-items-table.is-compact{min-width:980px;}
.sp-proc-items-table col.c-idx{width:44px;}
.sp-proc-items-table col.c-code{width:130px;}
.sp-proc-items-table col.c-name{width:150px;}
.sp-proc-items-table col.c-brand{width:88px;}
.sp-proc-items-table col.c-series{width:88px;}
.sp-proc-items-table col.c-model{width:104px;}
.sp-proc-items-table col.c-desc{width:170px;}
.sp-proc-items-table col.c-num{width:82px;}
.sp-proc-items-table col.c-money{width:112px;}
.sp-proc-items-table th{height:40px;padding:0 10px;background:#f8fafc;color:#475467;border-bottom:1px solid var(--border);font-weight:800;text-align:left;white-space:nowrap;vertical-align:middle;}
.sp-proc-items-table td{height:42px;padding:8px 10px;border-bottom:1px solid #edf2f7;color:#1f2937;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sp-proc-items-table tbody tr:last-child td{border-bottom:0;}
.sp-proc-items-table th:first-child,.sp-proc-items-table .sp-proc-item-idx{text-align:center;}
.sp-proc-items-table th:nth-child(n+8),.sp-proc-items-table .sp-proc-item-num,.sp-proc-items-table .sp-proc-item-money{text-align:right;font-variant-numeric:tabular-nums;}
.sp-proc-items-table .sp-proc-item-code{font-family:'DM Mono',monospace;font-size:11px;}
.sp-proc-items-table .sp-proc-item-name{color:var(--text);}
.sp-proc-items-table .sp-proc-item-desc{white-space:normal;line-height:1.45;}
.sp-proc-items-table .sp-proc-item-amount{font-weight:700;color:var(--text);}
.sp-proc-event-row{display:grid;grid-template-columns:145px 120px 90px minmax(0,1fr);gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px;align-items:start;}
.sp-proc-modal-mask{position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:9300;display:flex;align-items:center;justify-content:center;padding:18px;}
.sp-proc-exception-dialog{width:560px;max-width:96vw;max-height:92vh;display:flex;flex-direction:column;background:var(--card);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.28);overflow:hidden;}
.sp-proc-modal-head{height:58px;padding:0 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.sp-proc-modal-close{border:0;background:transparent;color:var(--t3);font-size:22px;line-height:1;cursor:pointer;}
.sp-proc-exception-body{padding:16px 18px 18px;}
.sp-proc-exception-meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;color:var(--t2);font-size:12px;}
.sp-proc-exception-meta span{padding:4px 8px;border-radius:999px;background:#f1f5f9;}
.sp-proc-exception-label{margin-bottom:8px;color:var(--text);font-size:13px;font-weight:700;}
.sp-proc-reason-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.sp-proc-reason-chips button{height:30px;padding:0 11px;border:1px solid var(--border);border-radius:999px;background:#fff;color:#374151;font-size:12px;cursor:pointer;}
.sp-proc-reason-chips button:hover{border-color:#93b4e8;background:#eff6ff;color:#1d4ed8;}
.sp-proc-exception-body textarea{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:8px;padding:10px 11px;resize:vertical;font-family:inherit;font-size:13px;line-height:1.5;outline:none;}
.sp-proc-exception-body textarea:focus{border-color:#93b4e8;box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.sp-proc-modal-foot{padding:13px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-start;gap:8px;background:#fbfdff;}
.sp-proc-arr-dialog{width:1160px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;background:var(--card);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.28);overflow:hidden;}
.sp-proc-arr-body{padding:16px 18px 18px;overflow:auto;background:#fff;}
.sp-proc-arr-table{width:100%;min-width:1340px;border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:12px;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.sp-proc-arr-table col.c-idx{width:44px;}
.sp-proc-arr-table col.c-code{width:118px;}
.sp-proc-arr-table col.c-name{width:150px;}
.sp-proc-arr-table col.c-brand{width:96px;}
.sp-proc-arr-table col.c-series{width:96px;}
.sp-proc-arr-table col.c-model{width:118px;}
.sp-proc-arr-table col.c-desc{width:180px;}
.sp-proc-arr-table col.c-num{width:82px;}
.sp-proc-arr-table col.c-arrive{width:120px;}
.sp-proc-arr-table col.c-note{width:260px;}
.sp-proc-arr-table th{height:42px;padding:0 10px;background:#f8fafc;color:#475467;border-bottom:1px solid var(--border);font-weight:800;text-align:left;white-space:nowrap;}
.sp-proc-arr-table td{height:48px;padding:7px 10px;border-bottom:1px solid #edf2f7;color:#1f2937;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sp-proc-arr-table tbody tr:last-child td{border-bottom:0;}
.sp-proc-arr-table .idx,.sp-proc-arr-table .num{text-align:center;font-family:'DM Mono',monospace;}
.sp-proc-arr-table .name{font-weight:700;}
.sp-proc-arr-table .input-cell,.sp-proc-arr-table .note-cell{padding:6px 8px;}
.sp-proc-arr-table .note-cell{white-space:normal;overflow:visible;text-overflow:clip;vertical-align:top;}
.sp-proc-arr-table textarea.form-input{width:100%;min-height:34px;box-sizing:border-box;line-height:1.45;resize:none;overflow:hidden;white-space:pre-wrap;overflow-wrap:anywhere;}
.sp-proc-arr-qty-input{width:96px!important;height:32px!important;text-align:center;}
.sp-proc-arr-note-input{width:100%!important;height:32px!important;}
.sp-proc-arr-table .empty{text-align:center;color:var(--t3);height:72px;}
.sp-cell-line{height:20px;line-height:20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sp-cell-sub{display:block;margin-top:3px;color:var(--t3);font-size:11px;}
.sp-product-name{font-weight:700;color:var(--text);}
.sp-product-desc{color:var(--t2);}
.sp-table-detail td{background:#fff;border-bottom:1px solid var(--border);}
.sp-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:12px;}
.sp-info-box{border:1px solid var(--border);border-radius:8px;background:#fafafa;padding:9px 11px;min-width:0;}
.sp-info-box.wide{grid-column:span 2;}
.sp-detail-mask{position:fixed;inset:0;z-index:9300;background:rgba(15,23,42,.34);}
.sp-detail-drawer{position:fixed;top:0;right:0;z-index:9301;width:min(760px,100vw);height:100vh;background:var(--surface);box-shadow:-18px 0 42px rgba(15,23,42,.18);display:flex;flex-direction:column;}
.sp-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px 16px;border-bottom:1px solid var(--border);}
.sp-detail-title{margin:0;color:var(--text);font-size:20px;line-height:1.25;}
.sp-detail-sub{margin-top:6px;color:var(--t3);font-size:13px;}
.sp-detail-close{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--t2);font-size:20px;line-height:28px;cursor:pointer;}
.sp-detail-body{flex:1;overflow:auto;padding:18px 24px 24px;background:#fbfcfe;}
.sp-detail-section{margin-bottom:16px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:8px;}
.sp-detail-section-title{margin:0 0 12px;color:var(--text);font-size:15px;font-weight:700;}
.sp-detail-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;}
.sp-detail-info-label{display:block;margin-bottom:4px;color:var(--t3);font-size:12px;}
.sp-detail-info-value{color:var(--text);font-weight:700;overflow-wrap:anywhere;}
.sp-detail-table{width:100%;border-collapse:collapse;font-size:12px;}
.sp-detail-table th,.sp-detail-table td{height:38px;padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;}
.sp-detail-table th{color:var(--t2);background:#f8fafc;font-size:12px;}
.sp-detail-timeline{position:relative;display:grid;gap:0;padding-left:4px;}
.sp-detail-log{position:relative;display:grid;grid-template-columns:136px 1fr;gap:18px;padding:0 0 18px 22px;}
.sp-detail-log:before{content:"";position:absolute;left:6px;top:6px;width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px #e9f2ff;}
.sp-detail-log:after{content:"";position:absolute;left:10px;top:20px;bottom:0;width:1px;background:#dfe6f0;}
.sp-detail-log:last-child{padding-bottom:0;}
.sp-detail-log:last-child:after{display:none;}
.sp-detail-log-time{color:var(--t2);font-size:12px;line-height:1.5;}
.sp-detail-log-title{color:var(--text);font-weight:800;}
.sp-detail-log-meta{margin-top:4px;color:var(--t2);font-size:12px;}
.sp-detail-log-note{margin-top:6px;color:var(--t2);line-height:1.5;}
.sp-customer-tools{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.sp-customer-tools input,.sp-customer-tools select{height:32px;border:1px solid var(--border);border-radius:var(--r);padding:0 10px;font-size:12px;outline:none;background:var(--surface);color:var(--text);font-family:'DM Sans',sans-serif;}
.sp-customer-tools input{min-width:220px;flex:1;}
.sp-customer-layout{display:block;}
.sp-customer-table-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface);}
.sp-customer-row{cursor:pointer;}
.sp-customer-row td{transition:background .15s;}
.sp-customer-row.active td{background:#eff6ff;}
.sp-customer-name{font-weight:700;color:var(--text);font-size:13px;}
.sp-customer-sub{font-size:11px;color:var(--t3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;}
.sp-customer-kind{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:11px;background:#f1f5f9;color:#64748b;font-size:11px;font-weight:600;white-space:nowrap;}
.sp-customer-kind.clinic{background:#eff6ff;color:#2563c4;}
.sp-customer-kind.optical{background:#ecfdf5;color:#059669;}
.sp-customer-detail{border:1px solid var(--border);border-radius:10px;background:#fafbfd;overflow:hidden;position:sticky;top:0;}
.sp-detail-body>.sp-customer-detail{position:static;border:0;border-radius:0;background:transparent;overflow:visible;}
.sp-customer-detail-head{padding:13px 14px;border-bottom:1px solid var(--border);background:var(--surface);}
.sp-customer-detail-title{font-size:15px;font-weight:700;color:var(--text);line-height:1.35;}
.sp-customer-detail-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.sp-customer-detail-body{padding:12px 14px;}
.sp-customer-metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;}
.sp-customer-metric{border:1px solid var(--border);border-radius:8px;background:var(--surface);padding:9px 10px;}
.sp-customer-metric .label{font-size:11px;color:var(--t3);margin-bottom:2px;}
.sp-customer-metric .value{font-family:'DM Mono',monospace;font-size:16px;font-weight:500;color:var(--text);}
.sp-customer-section{border-top:1px solid var(--border);padding-top:11px;margin-top:11px;}
.sp-customer-section:first-child{border-top:none;padding-top:0;margin-top:0;}
.sp-customer-section-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px;}
.sp-customer-line{display:flex;justify-content:space-between;gap:12px;font-size:12px;color:var(--t2);padding:4px 0;}
.sp-customer-line span:first-child{color:var(--t3);white-space:nowrap;}
.sp-customer-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;}
.sp-customer-actions .btn{justify-content:center;height:30px;font-size:12px;padding:0 10px;}
.spno-layer{position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:9400;display:flex;align-items:center;justify-content:center;padding:18px;}
.spno-dialog{width:min(1180px,100%);max-height:94vh;background:var(--surface);border-radius:10px;box-shadow:0 24px 70px rgba(15,23,42,.28);display:flex;flex-direction:column;overflow:hidden;}
.spno-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:16px;background:#fbfcfe;}
.spno-title{font-size:17px;font-weight:800;color:var(--text);line-height:1.25;}
.spno-sub{margin-top:4px;font-size:12px;color:var(--t3);}
.spno-close{width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--t2);font-size:20px;line-height:28px;cursor:pointer;}
.spno-body{flex:1;overflow:auto;padding:16px 20px 18px;background:#f8fafc;}
.spno-grid{display:grid;grid-template-columns:minmax(0,1fr) 270px;gap:12px;align-items:start;}
.spno-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px;}
.spno-panel-title{font-size:13px;font-weight:800;color:var(--text);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.spno-fields{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:10px;}
.spno-field{min-width:0;}
.spno-field.wide{grid-column:1/-1;}
.spno-label{display:block;font-size:11px;color:var(--t2);font-weight:700;margin-bottom:5px;}
.spno-field input,.spno-field select,.spno-field textarea,.spno-line input,.spno-line select,.spno-line textarea{width:100%;height:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);padding:0 9px;font-size:12px;outline:none;box-sizing:border-box;}
.spno-field textarea,.spno-line textarea{height:auto;min-height:34px;padding:7px 9px;line-height:1.45;resize:none;overflow:hidden;white-space:pre-wrap;overflow-wrap:anywhere;}
.spno-field input:focus,.spno-field select:focus,.spno-field textarea:focus,.spno-line input:focus,.spno-line select:focus,.spno-line textarea:focus{border-color:#93c5fd;box-shadow:0 0 0 3px rgba(37,99,196,.1);}
.spno-summary{display:grid;gap:9px;position:sticky;top:0;}
.spno-total-box{background:#0f172a;color:#fff;border-radius:8px;padding:13px 14px;}
.spno-total-label{font-size:11px;color:rgba(255,255,255,.64);margin-bottom:4px;}
.spno-total-value{font-size:24px;line-height:1.1;font-weight:800;font-family:'DM Mono',monospace;}
.spno-mini-row{display:flex;justify-content:space-between;gap:12px;font-size:12px;color:var(--t2);padding:7px 0;border-bottom:1px solid var(--border);}
.spno-mini-row:last-child{border-bottom:none;}
.spno-lines-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:14px 0 10px;}
.spno-lines-title{font-size:14px;font-weight:800;color:var(--text);}
.spno-lines{display:grid;gap:10px;}
.spno-line{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.spno-line-top{display:grid;grid-template-columns:34px minmax(110px,.8fr) minmax(110px,.8fr) minmax(220px,1.4fr) minmax(95px,.7fr) 70px 88px 52px;gap:6px;align-items:end;padding:11px 12px;background:#fff;}
.spno-line-no{width:26px;height:26px;border-radius:13px;background:#eff6ff;color:#2563c4;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;margin-bottom:4px;}
.spno-product-cell{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.spno-product-cell .name{grid-column:1/-1;}
.spno-line-bottom{display:grid;grid-template-columns:130px repeat(9,minmax(70px,1fr));gap:7px;align-items:end;padding:10px 12px;border-top:1px solid var(--border);background:#fbfcfe;}
.spno-check{height:34px;border:1px solid var(--border);border-radius:8px;background:var(--surface);display:flex;align-items:center;gap:7px;padding:0 9px;font-size:12px;color:var(--t2);white-space:nowrap;}
.spno-check input{width:14px;height:14px;padding:0;}
.spno-price-hint{font-size:10px;color:#16a34a;margin-top:3px;min-height:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spno-del{height:34px;border:1px solid #fee2e2;border-radius:8px;background:#fff;color:#dc2626;cursor:pointer;font-size:12px;}
.spno-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-start;background:var(--surface);}
@media (max-width:900px){
  .sp-order-head{grid-template-columns:1fr;}
  .sp-order-side{min-width:0;justify-content:space-between;flex-wrap:wrap;}
  .sp-actions{max-width:none;justify-content:flex-start;}
  .sp-progress{grid-template-columns:1fr;}
  .sp-detail-grid{grid-template-columns:1fr;}
  .sp-info-box.wide{grid-column:auto;}
  .sp-detail-head{padding:16px;}
  .sp-detail-body{padding:14px;}
  .sp-detail-info-grid{grid-template-columns:1fr;}
  .sp-detail-log{grid-template-columns:1fr;gap:4px;}
  .sp-stats-toolbar{align-items:stretch;}
  .sp-stats-toolbar-group{width:100%;}
  .sp-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .sp-customer-layout{grid-template-columns:1fr;}
  .sp-customer-detail{position:static;}
  .sp-customer-tools input{min-width:180px;}
  .spno-layer{padding:8px;align-items:stretch;}
  .spno-dialog{max-height:none;height:100%;}
  .spno-grid{grid-template-columns:1fr;}
  .spno-summary{position:static;}
  .spno-fields{grid-template-columns:1fr;}
  .spno-line-top,.spno-line-bottom,.spno-product-cell{grid-template-columns:1fr;}
}

/* ── Stat cards ── */
.mp-tab{padding:8px 18px;font-size:13px;font-weight:500;color:var(--t3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;}
.mp-tab:hover{color:var(--t1);}
.mp-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;}
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl2);padding:11px 14px;}
.stats-period-btn,.chain-period-btn,.cd-period-btn{padding:5px 12px;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;background:transparent;color:var(--t2);transition:all .15s;}
.stats-period-btn:hover,.chain-period-btn:hover,.cd-period-btn:hover{background:#e8ecf2;}
.stats-period-btn.active,.chain-period-btn.active,.cd-period-btn.active{background:#2563c4;color:#fff;}
.chart-toggle{display:flex;align-items:center;gap:4px;padding:3px 10px;border:1px solid var(--border);border-radius:14px;font-size:11px;color:var(--t3);background:var(--surface);cursor:pointer;transition:all .15s;opacity:.5;}
.chart-toggle:hover{opacity:.8;}
.chart-toggle.active{opacity:1;border-color:var(--tc);color:var(--t1);font-weight:500;}
.ct-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0;}
.stat-label{font-size:12px;color:var(--t2);margin-bottom:3px;}
.stat-value{font-size:22px;font-weight:300;font-family:'DM Mono',monospace;letter-spacing:-.02em;}
.stat-delta{font-size:11px;margin-top:2px;}
.delta-up{color:var(--green);}
.delta-warn{color:var(--amber);}
.delta-red{color:var(--red);}
.sp-proc-metric .stat-value{font-weight:700;letter-spacing:0;font-family:'DM Mono',monospace;}
#sp-proc-metrics{
  position:sticky;
  top:0;
  z-index:20;
  padding:10px 0 12px;
  background:rgba(248,250,252,.94);
  border-bottom:1px solid rgba(226,232,240,.9);
  box-shadow:0 10px 24px rgba(15,23,42,.06);
  backdrop-filter:blur(12px);
}

@media (max-width: 1280px){
  #sp-proc-metrics{grid-template-columns:repeat(3,minmax(150px,1fr)) !important;}
  .sp-proc-payable-summary{grid-template-columns:minmax(160px,1fr) minmax(260px,1fr) !important;}
}

@media (max-width: 760px){
  #sp-proc-metrics{grid-template-columns:1fr !important;}
  .sp-proc-payable-summary{grid-template-columns:1fr !important;}
}

/* ── Member table hover actions ── */
.mem-row{position:relative;}
.mem-acts{display:flex;gap:4px;justify-content:center;align-items:center;}
.mem-act-btn{padding:3px 9px;border-radius:6px;border:1px solid var(--border);background:#fff;font-size:11px;cursor:pointer;white-space:nowrap;color:var(--t2);transition:all .12s;opacity:0;pointer-events:none;}
.mem-row:hover .mem-act-btn{opacity:1;pointer-events:auto;}
.mem-act-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.mem-act-btn.topup{background:#eff6ff;color:#2563c4;border-color:#bfdbfe;}
.mem-act-btn.topup:hover{background:#2563c4;color:#fff;}
.mem-act-btn.adj{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0;}
.mem-act-btn.adj:hover{background:#16a34a;color:#fff;}
/* Member detail tabs */
.mem-tab-bar{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:12px;}
.mem-tab{padding:6px 16px;font-size:12px;font-weight:500;color:var(--t2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .12s;}
.mem-tab.active{color:var(--accent);border-bottom-color:var(--accent);}
.mem-tab-panel{display:none;}
.mem-tab-panel.active{display:block;}
/* Sortable table header */
.sort-th{cursor:pointer;user-select:none;}
.sort-th:hover{color:var(--accent);}
.sort-th .sort-icon{margin-left:4px;font-size:10px;color:var(--t3);}
.sort-th.asc .sort-icon::after{content:'▲';}
.sort-th.desc .sort-icon::after{content:'▼';}
.sort-th:not(.asc):not(.desc) .sort-icon::after{content:'⇅';}
/* Dormant badge */
.dormant-badge{display:inline-block;padding:1px 7px;border-radius:10px;font-size:10px;background:#fef3c7;color:#92400e;border:1px solid #fcd34d;}

/* ── Patient rows ── */
.patient-row{display:flex;align-items:center;gap:12px;padding:8px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;}
.patient-row:hover{background:var(--s2);}
.patient-row:last-child{border-bottom:none;}
.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;flex-shrink:0;}
.patient-name{font-size:13px;font-weight:500;}
.patient-meta{font-size:11px;color:var(--t3);margin-top:1px;}
.patient-info{flex:1;}
.next-visit{font-size:11px;color:var(--t3);text-align:right;min-width:60px;}
.next-visit.urgent{color:var(--red);font-weight:500;}
.next-visit.soon{color:var(--amber);}

/* ── Alert items ── */
.alert-item{display:flex;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.alert-item:last-child{border-bottom:none;}
.alert-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0;}
.alert-title{font-size:13px;font-weight:500;}
.alert-sub{font-size:11px;color:var(--t3);margin-top:2px;}

/* ── Forms ── */
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:12px;color:var(--t2);}
.field label .unit{color:var(--t3);font-size:11px;margin-left:2px;}
.field input,.field select,.field textarea{height:36px;border:1px solid var(--border);border-radius:var(--r);padding:0 10px;font-size:13px;color:var(--text);background:var(--surface);font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s;width:100%;}
.field textarea{height:72px;padding:8px 10px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);}
select{appearance:auto!important;-webkit-appearance:menulist!important;border:1px solid #767676!important;border-radius:0!important;background-color:#fff!important;box-shadow:none!important;}
.form-section-title{font-size:11px;font-weight:500;color:var(--t2);text-transform:uppercase;letter-spacing:.06em;margin:14px 0 10px;padding-bottom:7px;border-bottom:1px solid var(--border);}
.eye-panel{background:var(--s2);border-radius:var(--r);padding:14px;}
.eye-panel-title{font-size:12px;font-weight:500;margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.eye-dot{width:8px;height:8px;border-radius:50%;}
.radio-group{display:flex;gap:8px;flex-wrap:wrap;}
.radio-opt{padding:6px 13px;border-radius:var(--r);border:1px solid var(--border);cursor:pointer;font-size:13px;transition:all .15s;background:var(--surface);user-select:none;}
.radio-opt.sel{border-color:var(--accent);background:var(--al);color:var(--accent);}
.form-actions{display:flex;gap:10px;padding-top:14px;border-top:1px solid var(--border);margin-top:14px;}

/* ── Timeline ── */
.timeline{position:relative;padding-left:24px;}
.timeline::before{content:'';position:absolute;left:7px;top:8px;bottom:8px;width:1px;background:var(--border);}
.tl-item{position:relative;margin-bottom:16px;}
.tl-dot{position:absolute;left:-24px;width:15px;height:15px;border-radius:50%;border:2px solid var(--surface);top:2px;}
.tl-date{font-size:11px;color:var(--t3);margin-bottom:3px;font-family:'DM Mono',monospace;}
.tl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;}
.tl-title{font-size:13px;font-weight:500;margin-bottom:8px;}
.tl-data{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.tl-kv{background:var(--s2);border-radius:6px;padding:6px 8px;}
.tl-k{font-size:10px;color:var(--t3);}
.tl-v{font-size:13px;font-weight:500;font-family:'DM Mono',monospace;}
.tl-v.warn{color:var(--amber);}
.tl-v.bad{color:var(--red);}
.tl-v.ok{color:var(--green);}

/* ── Calendar ── */
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.cal-month{font-size:15px;font-weight:500;}
.cal-nav button{width:30px;height:30px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:16px;color:var(--t2);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;}
.cal-dow{text-align:center;font-size:11px;color:var(--t3);padding:4px 0;font-weight:500;}
.cal-day{min-height:70px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);padding:5px;cursor:pointer;transition:background .12s;}
.cal-day:hover{background:var(--s2);}
.cal-day.today{border-color:var(--accent);background:var(--al);}
.cal-day.other{opacity:.4;}
.cal-day-num{font-size:12px;font-weight:500;margin-bottom:3px;}
.cal-day.today .cal-day-num{color:var(--accent);}
.cal-event{font-size:10px;padding:2px 5px;border-radius:4px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ce-ok{background:var(--al);color:var(--accent);}
.ce-kc{background:var(--rl);color:var(--red);}
.ce-myo{background:var(--gl);color:var(--green);}
.ce-warn{background:var(--aml);color:var(--amber);}

/* ── AI Module ── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--rl2);padding:28px;text-align:center;cursor:pointer;transition:all .2s;background:var(--s2);position:relative;}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:var(--al);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.ai-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.2s ease-in-out infinite;display:inline-block;}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8);}50%{opacity:1;transform:scale(1);}}
@keyframes spin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes _urgePulse{0%,100%{opacity:1;}50%{opacity:.5;}}
.param-card{background:var(--s2);border-radius:var(--r);padding:10px 12px;}
.param-k{font-size:10px;color:var(--t3);margin-bottom:2px;}
.param-v{font-size:15px;font-weight:500;font-family:'DM Mono',monospace;}
.param-s{font-size:10px;margin-top:2px;}
.risk-track{height:10px;border-radius:5px;background:var(--s3);overflow:hidden;}
.risk-fill{height:100%;border-radius:5px;transition:width 1s ease;}

/* ── OK Lens table ── */
.data-table{display:table;width:100%;border-collapse:collapse;}
.data-table thead{display:table-header-group;}
.data-table tbody{display:table-row-group;}
.data-table tr{display:table-row;}
.data-table th,.data-table td{display:table-cell;}
.data-table th{text-align:left;font-size:11px;color:var(--t3);font-weight:500;padding:8px 14px;border-bottom:2px solid var(--border);white-space:nowrap;background:var(--surface);}
.data-table td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle;background:#fafbfd;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tr:hover td{background:var(--s2);}
#orders-table{
  width:1760px!important;
  min-width:1760px;
  table-layout:fixed;
}
#preq-table,#po-table{
  width:1680px!important;
  min-width:1680px;
  table-layout:fixed;
}
#orders-table th,#orders-table td,
#preq-table th,#preq-table td,
#po-table th,#po-table td{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
#orders-table th:nth-child(1),#orders-table td:nth-child(1){width:170px;}
#orders-table th:nth-child(2),#orders-table td:nth-child(2){width:112px;}
#orders-table th:nth-child(3),#orders-table td:nth-child(3){width:100px;}
#orders-table th:nth-child(4),#orders-table td:nth-child(4){width:92px;}
#orders-table th:nth-child(5),#orders-table td:nth-child(5){width:110px;}
#orders-table th:nth-child(6),#orders-table td:nth-child(6){width:130px;}
#orders-table th:nth-child(7),#orders-table td:nth-child(7){width:260px;}
#orders-table th:nth-child(8),#orders-table td:nth-child(8){width:100px;}
#orders-table th:nth-child(9),#orders-table td:nth-child(9){width:100px;}
#orders-table th:nth-child(10),#orders-table td:nth-child(10){width:100px;}
#orders-table th:nth-child(11),#orders-table td:nth-child(11){width:112px;}
#orders-table th:nth-child(12),#orders-table td:nth-child(12){width:140px;}
#preq-table th:nth-child(1),#preq-table td:nth-child(1),
#po-table th:nth-child(1),#po-table td:nth-child(1){width:180px;}
#preq-table th:nth-child(9),#preq-table td:nth-child(9),
#po-table th:nth-child(9),#po-table td:nth-child(9){width:240px;}
.sp-inv-table-scroll{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;}
.sp-inv-wide-table{width:max-content;min-width:1280px;}
.sp-inv-section-table{width:max-content;min-width:1320px;}
.sp-inv-movement-table,
.sp-stock-movement-table{width:max-content!important;min-width:1720px;}
.sp-inv-defective-table{width:max-content!important;min-width:1540px;}
.sp-stockflow-table{width:max-content!important;min-width:980px;}
.sp-stockflow-wide-table{width:max-content!important;min-width:1420px;}
.mono{font-family:'DM Mono',monospace;font-size:12px;}
.mpo-tab.active{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;}
.mpo-cnt{font-family:'DM Mono',monospace;font-size:10px;padding:1px 5px;border-radius:8px;background:var(--s3);color:var(--t2);margin-left:2px;}
.mpo-tab.active .mpo-cnt{background:rgba(255,255,255,.25);color:#fff;}
.ship-mode.active{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;}
/* 检查数据字段：默认只读，点击变编辑，失焦恢复 */
.exam-field{cursor:pointer;border:1.5px solid transparent!important;background:transparent!important;transition:border-color .15s,background .15s;color:var(--text);}
.exam-field:hover{border-color:var(--border)!important;background:rgba(255,255,255,.55)!important;}
.exam-field.editing{border-color:var(--accent)!important;background:#fff!important;cursor:text;}
.exam-field.editing-red{border-color:#e24b4a!important;background:#fff!important;cursor:text;}
.exam-field[disabled]{cursor:default;opacity:1;}

/* ── PDF Preview ── */
.pdf-page{background:#fff;padding:32px;font-family:'DM Sans',sans-serif;}
.pdf-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #1a1917;}
.pdf-logo-name{font-size:18px;font-weight:500;}
.pdf-logo-sub{font-size:11px;color:#6b6a65;margin-top:2px;}
.pdf-info{text-align:right;font-size:11px;color:#6b6a65;line-height:1.7;}
.pdf-patient{background:#f0efe9;border-radius:8px;padding:14px 16px;margin-bottom:20px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.pdf-k{font-size:10px;color:#9e9d98;}
.pdf-v{font-size:13px;font-weight:500;}
.pdf-sec-title{font-size:11px;font-weight:500;color:#6b6a65;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid #e2e1db;}
.pdf-param-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:12px;}
.pdf-param{background:#f0efe9;border-radius:6px;padding:8px 10px;}
.pdf-param-k{font-size:9px;color:#9e9d98;margin-bottom:2px;}
.pdf-param-v{font-size:13px;font-weight:500;font-family:'DM Mono',monospace;}
.pdf-conclusion{border-radius:8px;padding:12px 14px;margin-bottom:14px;}
.pdf-c-title{font-size:13px;font-weight:500;margin-bottom:4px;}
.pdf-c-body{font-size:12px;color:#6b6a65;line-height:1.6;}
.pdf-advice{display:flex;gap:8px;align-items:flex-start;font-size:12px;padding:6px 0;border-top:1px solid #e2e1db;}
.pdf-adot{width:6px;height:6px;border-radius:50%;margin-top:4px;flex-shrink:0;}
.pdf-footer{margin-top:20px;padding-top:12px;border-top:1px solid #e2e1db;display:flex;justify-content:space-between;font-size:10px;color:#9e9d98;}
.pdf-eye-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:12px;}
.pdf-eye-table th{background:#f0efe9;text-align:left;padding:7px 10px;font-weight:500;font-size:11px;color:#6b6a65;}
.pdf-eye-table td{padding:7px 10px;border-bottom:1px solid #e2e1db;}

/* ── Misc ── */
.mini-bars{display:flex;align-items:flex-end;gap:3px;height:44px;}
.mini-bar{flex:1;border-radius:3px 3px 0 0;background:var(--al);transition:height .3s;}
.mini-bar.hi{background:var(--accent);}
.reminder-item{display:flex;align-items:center;gap:10px;padding:9px 16px;border-bottom:1px solid var(--border);}
.reminder-item:last-child{border-bottom:none;}
.ri-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
#_ph-tooltip{position:fixed;background:#1e293b;color:#fff;font-size:12px;padding:4px 10px;border-radius:5px;white-space:nowrap;pointer-events:none;z-index:9999;display:none;}
.ri-info{flex:1;}
.ri-name{font-size:13px;font-weight:500;}
.ri-meta{font-size:11px;color:var(--t3);}
.ri-date{font-size:12px;font-family:'DM Mono',monospace;white-space:nowrap;}
.ri-date.urgent{color:var(--red);font-weight:500;}
.ri-date.soon{color:var(--amber);}
.bar-track{height:6px;border-radius:3px;background:var(--s3);overflow:hidden;flex:1;}
.bar-fill{height:100%;border-radius:3px;background:var(--accent);}
.status-on{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--green);}
.status-on::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);}
.status-off{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--t3);}
.status-off::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--t3);}
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.96);background:#1a1917;color:#fff;padding:12px 24px;border-radius:var(--r);font-size:13px;font-weight:500;z-index:9999;opacity:0;transition:all .3s;white-space:nowrap;max-width:min(760px,calc(100vw - 32px));box-sizing:border-box;}
.toast.show{transform:translate(-50%,-50%) scale(1);opacity:1;}
.toast.toast-error{background:#b91c1c;white-space:normal;padding:12px 14px;box-shadow:0 12px 36px rgba(0,0,0,.28);}
.toast.toast-long{white-space:normal;}
.toast-title{font-size:13px;font-weight:700;margin-bottom:4px;}
.toast-body{font-size:12px;font-weight:500;line-height:1.45;max-height:120px;overflow:auto;word-break:break-word;}
.toast-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px;}
.toast-actions button{height:26px;border:1px solid rgba(255,255,255,.45);background:rgba(255,255,255,.12);color:#fff;border-radius:6px;padding:0 9px;font-size:12px;cursor:pointer;}
.logout-confirm-mask{position:fixed;inset:0;z-index:100001;background:rgba(15,23,42,.48);display:flex;align-items:center;justify-content:center;padding:18px;box-sizing:border-box;}
.logout-confirm-dialog{width:min(380px,100%);background:#fff;border-radius:8px;box-shadow:0 24px 80px rgba(15,23,42,.28);padding:26px 28px 22px;box-sizing:border-box;text-align:center;color:#1f2937;}
.logout-confirm-icon{width:42px;height:42px;border-radius:50%;margin:0 auto 14px;background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;line-height:1;}
.logout-confirm-title{font-size:18px;font-weight:700;margin-bottom:8px;}
.logout-confirm-message{font-size:13px;line-height:1.6;color:#6b7280;margin:0 auto 22px;max-width:300px;}
.logout-confirm-actions{display:flex;justify-content:center;gap:10px;}
.logout-confirm-actions button{height:38px;min-width:96px;border-radius:7px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid #d1d5db;background:#fff;color:#374151;font-family:inherit;}
.logout-confirm-actions .logout-confirm-primary{border-color:#1f2937;background:#1f2937;color:#fff;}
.logout-confirm-actions button:hover{filter:brightness(.96);}
@media (max-width:520px){
  .logout-confirm-dialog{padding:24px 20px 20px;}
  .logout-confirm-actions{flex-direction:column-reverse;}
  .logout-confirm-actions button{width:100%;}
}
.error-dialog-overlay{position:fixed;inset:0;z-index:100002;background:rgba(15,23,42,.52);display:flex;align-items:center;justify-content:center;padding:18px;box-sizing:border-box;}
.error-dialog{width:min(720px,100%);max-height:calc(100vh - 36px);background:#fff;border-radius:8px;box-shadow:0 24px 80px rgba(0,0,0,.32);display:flex;flex-direction:column;overflow:hidden;}
.error-dialog-head{height:48px;padding:0 16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;gap:10px;background:#fef2f2;color:#991b1b;font-size:15px;font-weight:700;}
.error-dialog-body{padding:14px 16px;overflow:auto;color:#1f2937;font-size:13px;line-height:1.55;word-break:break-word;white-space:pre-wrap;}
.error-dialog-summary{font-weight:600;margin-bottom:8px;color:#991b1b;}
.error-dialog-detail{font-family:'DM Mono',Consolas,monospace;font-size:12px;background:#f8fafc;border:1px solid #e5e7eb;border-radius:6px;padding:10px;max-height:280px;overflow:auto;color:#334155;}
.error-dialog-foot{padding:12px 16px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:8px;background:#fff;}
.error-dialog-foot button{height:34px;padding:0 14px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;font-size:13px;cursor:pointer;}
.error-dialog-foot .primary{background:#b91c1c;border-color:#b91c1c;color:#fff;}
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal{background:var(--surface);border-radius:var(--rl2);padding:24px;width:520px;max-height:80vh;overflow-y:auto;transform:translateY(20px);transition:transform .2s;}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-title{font-size:16px;font-weight:500;margin-bottom:16px;}
.step-bar{display:flex;margin-bottom:22px;}
.step{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;}
.step:not(:last-child)::after{content:'';position:absolute;top:13px;left:50%;width:100%;height:1px;background:var(--border);}
.step.done::after,.step.cur::after{background:var(--accent);}
.step-dot{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--t3);z-index:1;}
.step.done .step-dot{background:var(--accent);border-color:var(--accent);color:#fff;}
.step.cur .step-dot{border-color:var(--accent);color:var(--accent);}
.step-lbl{font-size:11px;color:var(--t3);}
.step.cur .step-lbl{color:var(--accent);font-weight:500;}
.step.done .step-lbl{color:var(--text);}

/* ── 检查字段只读态 ── */
.exam-field {
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.exam-field[readonly] {
  background: var(--s2) !important;
  border-color: transparent !important;
  color: var(--text);
  cursor: pointer;
}
.exam-field[readonly]:hover {
  background: var(--al) !important;
  border-color: var(--accent) !important;
}
.exam-field:not([readonly]) {
  cursor: text;
}

/* ── 登录页面 ── */
#login-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f2027 100%);z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow-y:auto;}
body.auth-pending .sidebar,
body.auth-pending .main{visibility:hidden;}
html.vp-has-session body.auth-pending .sidebar,
html.vp-has-session body.auth-pending .main{visibility:visible;}
html.vp-has-session #login-overlay{display:none !important;}
.login-box{background:#fff;border-radius:20px;padding:40px 44px;width:380px;max-width:90vw;box-sizing:border-box;box-shadow:0 24px 80px rgba(0,0,0,.4);}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.login-logo-eye{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#2563c4,#1a7a4a);display:flex;align-items:center;justify-content:center;}
.login-logo-eye svg{width:22px;height:22px;fill:#fff;}
.login-logo-name{font-size:20px;font-weight:700;color:#1a1917;}
.login-logo-sub{font-size:11px;color:#9e9d98;margin-top:1px;}
.login-title{font-size:14px;font-weight:600;color:#1a1917;margin-bottom:18px;}
.login-field{margin-bottom:14px;}
.login-field label{display:block;font-size:12px;color:#6b6a65;margin-bottom:6px;font-weight:500;}
.login-field input{width:100%;box-sizing:border-box;border:1px solid #e2e1db;border-radius:9px;padding:10px 13px;font-size:14px;font-family:'DM Sans',sans-serif;outline:none;transition:border .15s;}
.login-field input:focus{border-color:#2563c4;box-shadow:0 0 0 3px rgba(37,99,196,.1);}
.login-account-wrap{position:relative;}
.login-account-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:30px;height:30px;border:none;border-radius:7px;background:transparent;color:#1f2937;font-size:13px;cursor:pointer;}
.login-account-toggle:hover{background:#f3f4f6;}
.login-account-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:100000;background:#fff;border:1px solid #e5e7eb;border-radius:9px;box-shadow:0 12px 28px rgba(15,23,42,.14);overflow:hidden;max-height:192px;overflow-y:auto;}
.login-account-menu.show{display:block;}
.login-account-item{width:100%;box-sizing:border-box;border:none;background:#fff;padding:10px 12px;text-align:left;font-size:14px;color:#111827;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.login-account-item:hover{background:#f8fafc;}
.login-account-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.login-account-remove{border:none;background:transparent;color:#9ca3af;font-size:12px;cursor:pointer;padding:3px 6px;border-radius:5px;flex-shrink:0;}
.login-account-remove:hover{background:#fee2e2;color:#dc2626;}
.login-btn{width:100%;padding:11px;background:#2563c4;color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;margin-top:6px;transition:opacity .15s;}
.login-btn:hover{opacity:.88;}
.login-err{color:#c0392b;font-size:12px;margin-top:10px;min-height:18px;text-align:center;}
.login-remember{display:flex;align-items:center;gap:7px;margin-top:2px;margin-bottom:2px;cursor:pointer;user-select:none;}
.login-remember input[type=checkbox]{width:15px;height:15px;accent-color:#2563c4;cursor:pointer;margin:0;}
.login-remember span{font-size:12px;color:#6b6a65;}

/* ── 只读模式 ── */
body.vp-readonly .btn-p,
body.vp-readonly .btn-green,
body.vp-readonly .btn-red,
body.vp-readonly [data-write]{opacity:.35;pointer-events:none;cursor:not-allowed;}

/* ── 侧边栏用户信息 ── */
.user-info-bar{padding:10px 12px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:9px;}
.user-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0;}
.user-name{font-size:12px;color:rgba(255,255,255,.88);font-weight:500;}
.user-role-badge{font-size:10px;color:rgba(255,255,255,.35);}
.logout-btn{margin-left:auto;background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.45);font-size:10px;padding:4px 8px;border-radius:6px;cursor:pointer;white-space:nowrap;transition:all .15s;}
.logout-btn:hover{background:rgba(255,255,255,.15);color:rgba(255,255,255,.8);}
/* ── Inventory Hub Sidebar ── */
.inv-tree-item{padding:7px 16px 7px 32px;cursor:pointer;font-size:13px;color:#cbd5e1;transition:background .15s;}
.inv-tree-item:hover{background:#334155;}
.inv-tree-item.active{background:#8b5cf6;color:#fff;border-left:3px solid #a78bfa;padding-left:29px;}
.inv-tree-group-header{padding:10px 16px 6px;font-size:11px;color:#64748b;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;user-select:none;}
.inv-tree-group-header:hover{color:#94a3b8;}
.inv-chevron{font-size:10px;transition:transform .2s;display:inline-block;}
/* 权限控制：根据 body class 隐藏按钮 */
body.no-create-patients [data-perm="patients.create"],
body.no-edit-patients [data-perm="patients.edit"],
body.no-delete-patients [data-perm="patients.delete"],
body.no-create-orders [data-perm="orders.create"],
body.no-edit-orders [data-perm="orders.edit"],
body.no-delete-orders [data-perm="orders.delete"],
body.no-create-inventory [data-perm="inventory.create"],
body.no-edit-inventory [data-perm="inventory.edit"],
body.no-delete-inventory [data-perm="inventory.delete"],
body.no-create-appointments [data-perm="appointments.create"],
body.no-edit-appointments [data-perm="appointments.edit"],
body.no-create-members [data-perm="members.create"],
body.no-edit-members [data-perm="members.edit"],
body.no-delete-members [data-perm="members.delete"],
body.no-create-employees [data-perm="employees.create"],
body.no-edit-employees [data-perm="employees.edit"],
body.no-delete-employees [data-perm="employees.delete"],
body.no-edit-schedule [data-perm="schedule.edit"],
body.no-edit-settings [data-perm="settings.edit"] { display:none !important; }

/* ── VisionPro UI polish layer ── */
:root{
  --bg:#eef3f8;
  --surface:#ffffff;
  --card:#ffffff;
  --s2:#f6f8fb;
  --s3:#e7edf5;
  --text:#172033;
  --t2:#667085;
  --t3:#98a2b3;
  --accent:#1f6feb;
  --accent-2:#16a3a7;
  --al:#eaf2ff;
  --green:#16875a;
  --gl:#e9f8f1;
  --amber:#b76e00;
  --aml:#fff5df;
  --red:#d33f49;
  --rl:#fff0f1;
  --border:#dce5ef;
  --r:8px;
  --rl2:8px;
  --shadow-sm:0 1px 2px rgba(16,24,40,.05);
  --shadow-md:0 10px 28px rgba(31,49,78,.10);
  --ring:0 0 0 3px rgba(31,111,235,.14);
}

body{
  background:
    radial-gradient(circle at 8% -8%, rgba(31,111,235,.14), transparent 30%),
    linear-gradient(180deg,#f8fbff 0%,var(--bg) 42%,#e9f0f7 100%);
  color:var(--text);
  font-weight:400;
  letter-spacing:0;
}

.shell{background:transparent;}
.sidebar{
  width:236px;
  background:
    linear-gradient(180deg,rgba(22,32,50,.98),rgba(12,17,28,.98)),
    #111827;
  border-right:1px solid rgba(255,255,255,.08);
  box-shadow:10px 0 36px rgba(15,23,42,.14);
}
.logo{
  padding:18px 18px 16px;
  border-bottom:1px solid rgba(255,255,255,.09);
}
.logo-eye{
  width:34px;
  height:34px;
  border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 10px 24px rgba(31,111,235,.32);
}
.logo-eye svg{width:17px;height:17px;}
.logo-name{font-size:16px;font-weight:700;letter-spacing:.01em;}
.logo-sub{color:rgba(255,255,255,.48);font-size:10.5px;}
.nav{padding:10px 8px;}
.ns{
  padding:14px 10px 6px;
  color:rgba(255,255,255,.38);
  font-size:10px;
  font-weight:700;
  letter-spacing:.12em;
}
.ni,.ni-group-hd{
  min-height:36px;
  margin:2px 0;
  padding:8px 10px;
  border-left:0;
  border-radius:8px;
  color:rgba(238,242,247,.62);
  font-size:12.5px;
  font-weight:500;
}
.ni:hover,.ni-group-hd:hover{
  color:#fff;
  background:rgba(255,255,255,.08);
  transform:translateX(1px);
}
.ni.active,.ni-group-hd.active{
  color:#fff;
  background:linear-gradient(135deg,rgba(31,111,235,.95),rgba(22,163,167,.84));
  box-shadow:0 10px 22px rgba(31,111,235,.22);
}
.ni svg,.ni-group-hd svg{opacity:.78;}
.ni.active svg,.ni-group-hd.active svg{opacity:1;}
.ni-sub{
  margin:1px 0 1px 18px;
  padding:7px 10px;
  border-left:0;
  border-radius:7px;
  color:rgba(238,242,247,.48);
}
.ni-sub:hover{background:rgba(255,255,255,.07);color:rgba(255,255,255,.86);}
.ni-sub.active{background:rgba(31,111,235,.18);color:#b9d5ff;border-left:0;}
.nbadge{
  border-radius:999px;
  padding:1px 7px;
  background:rgba(255,255,255,.18);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.sf,.user-info-bar{padding:12px 14px;border-top:1px solid rgba(255,255,255,.09);}
.sa,.user-avatar{border-radius:8px;background:linear-gradient(135deg,rgba(31,111,235,.95),rgba(22,163,167,.9));}

.main{min-width:0;}
.topbar{
  height:58px;
  padding:0 22px;
  background:rgba(255,255,255,.86);
  border-bottom:1px solid rgba(220,229,239,.86);
  box-shadow:0 1px 0 rgba(255,255,255,.7),0 8px 24px rgba(31,49,78,.05);
  backdrop-filter:blur(14px);
}
.tb-title{font-size:16px;font-weight:700;color:#111827;}
.content{padding:22px;scrollbar-gutter:stable;}
.page.active{animation:vpFadeIn .18s ease-out;}
@keyframes vpFadeIn{from{opacity:.6;transform:translateY(4px);}to{opacity:1;transform:none;}}

.searchbox{
  width:280px;
  height:38px;
  background:#f8fafc;
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.75);
}
.searchbox:focus-within{
  border-color:rgba(31,111,235,.55);
  box-shadow:var(--ring);
  background:#fff;
}

.btn,.login-btn,.sp-order-action-primary,.sp-order-action-more-btn,.sp-defective-action-btn,.sp-defective-more-btn,.logout-btn{
  border-radius:8px;
  font-weight:650;
  letter-spacing:0;
}
.btn{
  min-height:34px;
  padding:7px 13px;
  box-shadow:var(--shadow-sm);
}
.btn-p,.login-btn{
  background:linear-gradient(135deg,var(--accent),#1559c9);
  color:#fff;
  box-shadow:0 8px 18px rgba(31,111,235,.22);
}
.btn-p:hover,.login-btn:hover{
  opacity:1;
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(31,111,235,.28);
}
.btn-g{
  background:#fff;
  border:1px solid var(--border);
  color:#344054;
}
.btn-g:hover{background:#f8fafc;border-color:#c9d6e4;color:#111827;}
.btn-green{background:linear-gradient(135deg,#16a36d,#0f7f55);}
.btn-red{background:linear-gradient(135deg,#d64550,#b4232e);}
.sp-table-actions{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  flex-wrap:nowrap;
  white-space:nowrap;
}
.data-table td.sp-table-actions{
  min-width:168px;
  text-align:left;
}
.sp-action-btn{
  min-height:28px;
  height:28px;
  padding:0 9px!important;
  border-radius:7px;
  font-size:12px!important;
  line-height:26px;
  box-shadow:none;
}
.sp-action-btn.btn-p{
  box-shadow:0 6px 14px rgba(31,111,235,.16);
}
.sp-action-btn.btn-g{
  background:#fff;
}
.sp-action-btn:disabled{
  cursor:not-allowed;
  opacity:.62;
  background:#f3f4f6;
  color:#98a2b3;
  box-shadow:none;
}
.data-table td .sp-action-btn + .sp-action-btn,
.sp-inv-wide-table td .sp-action-btn + .sp-action-btn{
  margin-left:6px;
}
.sp-action-btn.is-warn{
  border-color:#fed7aa;
  color:#b45309;
  background:#fffaf0;
}
.sp-action-btn.is-danger{
  border-color:#fecaca;
  color:#dc2626;
  background:#fffafa;
}
.sp-action-btn.is-warn:hover{
  border-color:#fdba74;
  background:#fff7ed;
}
.sp-action-btn.is-danger:hover{
  border-color:#fca5a5;
  background:#fef2f2;
}

.card,.stat-card,.sp-kpi-section,.sp-kpi-card,.sp-order-card,.sp-customer-table-wrap,.sp-customer-detail,.sp-detail-section,.tl-card,.modal,.error-dialog{
  border-color:rgba(220,229,239,.92);
  border-radius:8px;
  box-shadow:var(--shadow-sm);
}
.card,.stat-card,.sp-kpi-section,.sp-order-card,.sp-customer-table-wrap,.sp-customer-detail,.sp-detail-section{
  background:rgba(255,255,255,.94);
}
.card:hover,.stat-card:hover,.sp-kpi-card:hover,.sp-order-card:hover{
  border-color:#c8d7e8;
  box-shadow:var(--shadow-md);
}
.ch{
  padding:12px 16px;
  background:linear-gradient(180deg,#fff,#f9fbfe);
}
.ct{font-size:13px;font-weight:700;color:#1d2939;}
.cb{padding:16px;}
.g2,.g3,.g4{gap:12px;}

.stat-card{padding:16px 18px;}
.stat-label,.sp-kpi-label{color:#667085;font-weight:650;}
.stat-value,.sp-kpi-value{font-weight:750;color:#111827;letter-spacing:0;}
.sp-kpi-card{background:linear-gradient(180deg,#fff,#f8fbff);border-radius:8px;}

.tag,.sp-chip,.sp-status-pill,.mpo-cnt{
  border-radius:999px;
  font-weight:700;
}
.tag-ok,.sp-chip.neutral{background:var(--al);color:var(--accent);}
.tag-good,.sp-chip.ok{background:var(--gl);color:var(--green);}
.tag-warn,.sp-chip.warn{background:var(--aml);color:var(--amber);}
.sp-chip.bad{background:var(--rl);color:var(--red);}

.field input,.field select,.field textarea,
.sp-order-toolbar select,.sp-order-toolbar input,
.sp-customer-tools input,.sp-customer-tools select,
.spno-field input,.spno-field select,.spno-line input,.spno-line select,
.login-field input{
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.field input:focus,.field select:focus,.field textarea:focus,
.sp-order-toolbar select:focus,.sp-order-toolbar input:focus,
.sp-customer-tools input:focus,.sp-customer-tools select:focus,
.spno-field input:focus,.spno-field select:focus,.spno-line input:focus,.spno-line select:focus,
.login-field input:focus{
  border-color:rgba(31,111,235,.62);
  box-shadow:var(--ring);
}
select{
  appearance:auto!important;
  -webkit-appearance:auto!important;
  border:1px solid var(--border)!important;
  border-radius:8px!important;
  background-color:#fff!important;
  color:var(--text)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8)!important;
}

.data-table,.sp-order-table,.sp-detail-table{border-collapse:separate;border-spacing:0;}
.data-table th,.sp-order-table th,.sp-detail-table th{
  background:#f4f7fb;
  color:#667085;
  font-weight:750;
  border-bottom:1px solid var(--border);
}
.data-table td,.sp-order-table td,.sp-detail-table td{
  background:#fff;
  border-bottom:1px solid #edf2f7;
}
.data-table tr:hover td,.sp-order-table tbody tr.sp-order-row:hover{background:#f8fbff;}
.sp-order-table-wrap{border-radius:8px;box-shadow:var(--shadow-sm);}

.modal-overlay{background:rgba(15,23,42,.44);backdrop-filter:blur(4px);}
.modal{
  box-shadow:0 24px 80px rgba(16,24,40,.24);
  border:1px solid rgba(255,255,255,.8);
}
.toast{
  border-radius:8px;
  box-shadow:0 18px 44px rgba(15,23,42,.24);
}

#login-overlay{
  background:
    radial-gradient(circle at 18% 12%,rgba(31,111,235,.32),transparent 34%),
    radial-gradient(circle at 78% 72%,rgba(22,163,167,.24),transparent 34%),
    linear-gradient(135deg,#0b1220 0%,#13233a 46%,#0b1624 100%);
}
.login-box{
  border-radius:8px;
  padding:34px 38px;
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 28px 90px rgba(2,8,23,.46);
}
.login-logo-eye{
  border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
}
.login-logo-name{color:#111827;}
.login-title{font-size:15px;color:#1d2939;}

@media (max-width: 560px){
  #login-overlay{
    justify-content:flex-start;
    align-items:stretch;
    min-height:100dvh;
    padding:calc(18px + env(safe-area-inset-top)) 14px calc(18px + env(safe-area-inset-bottom));
    box-sizing:border-box;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .login-box,
  #register-box{
    width:100%!important;
    max-width:none;
    max-height:none!important;
    padding:24px 18px;
    border-radius:8px;
    box-shadow:0 18px 52px rgba(2,8,23,.36);
  }
  #register-box{
    max-height:calc(100dvh - 36px - env(safe-area-inset-top) - env(safe-area-inset-bottom))!important;
    overflow-y:auto!important;
  }
  .login-logo{
    gap:10px;
    margin-bottom:22px;
  }
  .login-logo-eye{
    width:40px;
    height:40px;
  }
  .login-logo-name{
    font-size:18px;
  }
  .login-title{
    margin-bottom:16px;
  }
  .login-field{
    margin-bottom:12px;
  }
  .login-field input{
    min-height:44px;
    padding:11px 12px;
    font-size:16px;
  }
  .login-account-toggle{
    width:38px;
    height:38px;
    right:5px;
  }
  .login-btn{
    min-height:44px;
    padding:12px;
    font-size:15px;
  }
  .login-box>div[style*="justify-content:space-between"]{
    gap:12px;
    flex-wrap:wrap;
  }
  #register-box>div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
    gap:0!important;
  }
  #register-box>div[style*="border:1px"][style*="overflow:hidden"]{
    display:grid!important;
    grid-template-columns:1fr;
  }
  #register-box>div[style*="border:1px"][style*="overflow:hidden"]>div{
    border-left:0!important;
    border-top:1px solid #d1d5db;
  }
  #register-box>div[style*="border:1px"][style*="overflow:hidden"]>div:first-child{
    border-top:0;
  }
}

@media (max-width: 760px){
  .topbar{height:54px;padding:0 12px;}
  .content{padding:12px;}
  .searchbox{display:none;}
  .sidebar{width:286px;}
  .card,.stat-card,.sp-kpi-section,.sp-kpi-card,.sp-order-card{box-shadow:var(--shadow-sm);}
}

/* Dashboard polish: many dashboard blocks are rendered with inline styles. */
.dash-kpi-grid>div{
  border-radius:8px!important;
  border:1px solid rgba(220,229,239,.95)!important;
  border-top-width:3px!important;
  box-shadow:0 8px 24px rgba(31,49,78,.08)!important;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)!important;
}
.dash-kpi-grid>div:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 34px rgba(31,49,78,.13)!important;
}
.dash-kpi-grid>div>div:first-child{
  color:#667085!important;
  font-weight:700!important;
}
.dash-kpi-grid>div>div:nth-child(2){
  font-weight:800!important;
  letter-spacing:0!important;
}
.dash-main-grid>div>div[style*="background:#fff"],
.dash-main-grid>div[style*="display:flex"]>div[style*="background:#fff"]{
  border:1px solid rgba(220,229,239,.95)!important;
  border-radius:8px!important;
  box-shadow:0 8px 24px rgba(31,49,78,.07)!important;
}
.dash-main-grid table thead tr,
.dash-table-scroll table thead tr{
  background:#f4f7fb!important;
}
.dash-main-grid th,
.dash-table-scroll th{
  color:#667085!important;
  font-weight:750!important;
  border-bottom:1px solid var(--border)!important;
}
.dash-main-grid td,
.dash-table-scroll td{
  border-bottom:1px solid #edf2f7!important;
}
#dash-quick-appt{
  background:#f8fbff!important;
}
#dash-quick-appt input,
#dash-quick-appt select{
  height:34px!important;
  border-color:var(--border)!important;
  border-radius:8px!important;
  background:#fff!important;
}
#dash-quick-appt button{
  border-radius:8px!important;
  font-weight:700!important;
}
.dash-main-grid button{
  border-radius:8px!important;
  font-weight:700!important;
}

/* Login role selector polish */
.login-box>div:nth-child(3)>div[style*="border:1px"]{
  border-color:var(--border)!important;
  border-radius:8px!important;
  background:linear-gradient(180deg,#fff,#fbfdff)!important;
  box-shadow:var(--shadow-sm)!important;
  transition:transform .15s,box-shadow .15s,border-color .15s,background .15s;
}
.login-box>div:nth-child(3)>div[style*="border:1px"]:hover{
  border-color:rgba(31,111,235,.5)!important;
  background:#f8fbff!important;
  box-shadow:0 12px 28px rgba(31,49,78,.12)!important;
  transform:translateY(-1px);
}

/* Sidebar footer gets dense on real data. */
.user-info-bar{
  min-height:58px;
  background:rgba(255,255,255,.025);
}
.user-name{
  max-width:118px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.logout-btn{
  height:28px;
  padding:0 9px;
  background:rgba(255,255,255,.10);
}

/* Common list pages */
.page>.card:first-child,
.content>.card:first-child,
.page>div[style*="background:#fff"][style*="border-radius"],
.page>div[style*="background:var(--surface)"][style*="border-radius"]{
  border:1px solid rgba(220,229,239,.95)!important;
  border-radius:8px!important;
  box-shadow:0 10px 28px rgba(31,49,78,.08)!important;
  overflow:hidden;
}
.form-input,
input.form-input,
select.form-input,
textarea.form-input{
  border:1px solid var(--border)!important;
  border-radius:8px!important;
  background:#fff!important;
  color:var(--text)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8)!important;
}
.form-input:focus,
input.form-input:focus,
select.form-input:focus,
textarea.form-input:focus{
  border-color:rgba(31,111,235,.62)!important;
  box-shadow:var(--ring)!important;
}
.page table:not(.pdf-eye-table) tbody tr,
.data-table tbody tr,
.sp-order-table tbody tr{
  transition:background .14s,box-shadow .14s;
}
.page table:not(.pdf-eye-table) tbody tr:hover td,
.data-table tbody tr:hover td{
  background:#f8fbff!important;
}
.page table:not(.pdf-eye-table) th{
  background:#f4f7fb!important;
  color:#667085!important;
  font-weight:750!important;
}
.page table:not(.pdf-eye-table) td{
  border-bottom:1px solid #edf2f7!important;
}
.page table:not(.pdf-eye-table) th,
.data-table th,
.sp-order-table th,
.sp-detail-table th,
.sp-proc-items-table th,
.sp-proc-arr-table th{
  text-align:left;
}
.sp-order-table .sp-actions{
  align-items:flex-start!important;
}

/* Patient and order list surface details */
#page-patients .card,
#page-orders .card,
#page-members .card,
#page-calendar .card{
  background:rgba(255,255,255,.96);
}
#page-patients .card>div:first-child,
#page-orders .card>div:first-child{
  background:linear-gradient(180deg,#fff,#f8fbff)!important;
  border-bottom:1px solid var(--border)!important;
}
#page-patients input,
#page-patients select,
#page-orders input,
#page-orders select{
  min-height:34px;
}
#page-patients [class*="tag"],
#page-orders [class*="tag"]{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.42);
}

/* Shared clinic list primitives */
.vp-list-stack,
#spo-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.vp-list-row{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:56px;
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  transition:background .14s,border-color .14s,box-shadow .14s;
}
.vp-list-row:hover{background:#f8fbff;}
.vp-list-row:last-child{border-bottom:none;}
.vp-row-wrap{border-bottom:1px solid var(--border);}
.vp-row-wrap:last-child{border-bottom:none;}
.vp-row-wrap .vp-list-row{border-bottom:0;}
.vp-row-main{flex:1;min-width:0;}
.vp-row-title{
  color:var(--accent);
  display:inline-block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.vp-row-meta{
  color:var(--t2);
  font-size:12px;
  line-height:1.45;
  margin-top:2px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.vp-row-side{
  color:var(--t3);
  font-size:12px;
  min-width:56px;
  text-align:right;
  white-space:nowrap;
}
.vp-row-money{
  color:#111827;
  font-size:14px;
  font-weight:750;
  white-space:nowrap;
}
.vp-list-card{
  border:1px solid var(--border);
  border-radius:8px;
  padding:14px 16px;
  background:var(--surface);
  box-shadow:var(--shadow-sm);
  transition:border-color .14s,box-shadow .14s,background .14s;
}
.vp-list-card:hover{
  border-color:#c8d7e8;
  box-shadow:var(--shadow-md);
}
.vp-list-card-main{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.vp-action-row{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:6px;
  flex-wrap:wrap;
}
.vp-action-row .btn{
  min-height:28px;
  height:28px;
  padding:0 9px!important;
  font-size:11px!important;
  box-shadow:none;
}
.vp-action-row .is-warn{border-color:#fed7aa;color:#b45309;background:#fffaf0;}
.vp-action-row .is-danger{border-color:#fecaca;color:#dc2626;background:#fffafa;}
.vp-action-row .vp-action-note{
  align-self:center;
  color:var(--t3);
  font-size:10px;
}
.vp-action-row .vp-action-note.warn{color:#b45309;}
.vp-status{
  display:inline-flex;
  align-items:center;
  height:24px;
  padding:0 10px;
  border-radius:999px;
  background:var(--status-bg,#f1f5f9);
  color:var(--status-color,#64748b);
  font-size:12px;
  font-weight:700;
  white-space:nowrap;
}
.vp-empty{
  padding:32px 16px;
  text-align:center;
  color:var(--t3);
  font-size:13px;
  background:#fafafa;
  border:1px dashed var(--border);
  border-radius:8px;
}
.vp-pager{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 0;
  color:var(--t2);
  font-size:12px;
}
.vp-pager-total{margin-right:auto;color:var(--t3);}
.vp-pager-size{
  height:28px;
  min-height:28px!important;
  border:1px solid var(--border);
  border-radius:6px;
  background:#fff;
  color:var(--t2);
  font-size:12px;
}
.vp-pager-btn{
  height:28px;
  min-height:28px;
  padding:0 10px;
  font-size:12px;
}
.vp-pager-current{
  min-width:58px;
  color:var(--t2);
  text-align:center;
}
.vp-check{
  width:16px;
  height:16px;
  flex-shrink:0;
  margin-right:4px;
  cursor:pointer;
}
.vp-toolbar{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:8px;
  flex-wrap:wrap;
}
.vp-toolbar-fill{
  margin-left:0;
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.vp-filter-group{
  display:flex;
  align-items:center;
  gap:6px;
  flex:1;
  flex-wrap:wrap;
  min-width:220px;
}
.vp-control{
  height:32px;
  min-height:32px!important;
  border:1px solid var(--border);
  border-radius:8px;
  padding:0 10px;
  background:var(--surface);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  outline:none;
}
.vp-control:focus{
  border-color:rgba(31,111,235,.62);
  box-shadow:var(--ring);
}
.vp-search{
  position:relative;
  width:220px;
  min-width:180px;
}
.vp-search .vp-control{
  width:100%;
  padding-left:30px;
}
.vp-search svg{
  position:absolute;
  left:8px;
  top:50%;
  transform:translateY(-50%);
  pointer-events:none;
}
.vp-count{
  color:var(--t3);
  font-size:12px;
  white-space:nowrap;
}
.vp-compact-btn{
  height:32px;
  min-height:32px;
  padding:0 12px;
  font-size:12px;
  white-space:nowrap;
}
.vp-tabs{
  display:flex;
  gap:0;
  border-bottom:1px solid var(--border);
  margin-bottom:12px;
}
.vp-tab{
  padding:6px 16px;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  color:var(--t2);
  cursor:pointer;
  font-size:13px;
  font-weight:600;
}
.vp-tab.active{
  color:var(--accent);
  border-bottom-color:var(--accent);
}
.vp-note{
  color:#92400e;
  background:#fffbeb;
  border:1px solid #fde68a;
  border-radius:8px;
  padding:8px 10px;
  font-size:12px;
  line-height:1.6;
}
.vp-batch-bar{
  display:none;
  align-items:center;
  gap:10px;
  margin-top:8px;
  padding:8px 14px;
  border:1px solid #fde68a;
  border-radius:8px;
  background:#fffbeb;
  font-size:13px;
}
.vp-batch-label{
  display:flex;
  align-items:center;
  gap:4px;
  cursor:pointer;
}
.vp-batch-actions{
  margin-left:0;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.vp-danger-btn{
  border-color:#fca5a5!important;
  color:#ef4444!important;
  background:#fffafa!important;
}
.vp-modal-mask{
  position:fixed;
  inset:0;
  z-index:9300;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(15,23,42,.44);
  backdrop-filter:blur(4px);
}
.vp-modal-panel{
  width:900px;
  max-width:97vw;
  max-height:93vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.8);
  border-radius:8px;
  background:var(--card);
  box-shadow:0 24px 80px rgba(16,24,40,.24);
}
.vp-modal-panel.lg{width:820px;}
.vp-modal-panel.wide{width:760px;}
.vp-modal-panel.mid{width:660px;}
.vp-modal-panel.narrow{width:580px;}
.vp-modal-panel.sm{width:520px;}
.vp-modal-panel.xs{width:440px;}
.vp-modal-head{
  min-height:56px;
  padding:0 20px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.vp-modal-head[data-vp-window-head],
[data-vp-window-head]{
  cursor:move;
  user-select:none;
}
.vp-modal-title{
  color:#1d2939;
  font-size:15px;
  font-weight:750;
}
.vp-window-controls{
  margin-left:auto;
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.vp-window-controls-floating{
  position:absolute;
  top:12px;
  right:16px;
  z-index:3;
  margin-left:0;
}
.vp-window-btn{
  width:32px;
  height:32px;
  border:0;
  border-radius:8px;
  background:transparent;
  color:var(--t3);
  cursor:pointer;
  font-size:20px;
  line-height:1;
}
.vp-window-btn:hover{
  background:#f4f7fb;
  color:var(--text);
}
.vp-window-dragging{
  user-select:none;
  box-shadow:0 28px 90px rgba(16,24,40,.32)!important;
}
.vp-window-dock{
  position:fixed;
  top:18px;
  right:18px;
  z-index:100200;
  max-width:min(320px,calc(100vw - 36px));
  height:38px;
  padding:0 14px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--card);
  color:var(--text);
  box-shadow:0 12px 32px rgba(16,24,40,.18);
  cursor:pointer;
  font-size:13px;
  font-weight:650;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.vp-window-dock:hover{
  border-color:#cbd5e1;
  background:#f8fafc;
}
.vp-modal-close{
  width:32px;
  height:32px;
  border:0;
  border-radius:8px;
  background:transparent;
  color:var(--t3);
  cursor:pointer;
  font-size:18px;
}
.vp-modal-close:hover{background:#f4f7fb;color:var(--text);}
.vp-modal-body{
  flex:1;
  overflow-y:auto;
  padding:18px 20px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.vp-modal-foot{
  padding:12px 20px;
  border-top:1px solid var(--border);
  display:flex;
  justify-content:flex-start;
  gap:8px;
  background:#fbfdff;
}
.vp-form-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.vp-form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr));}
.vp-form-field{min-width:0;}
.vp-form-field.full{grid-column:1/-1;}
.vp-form-divider{
  grid-column:1/-1;
  border-top:1px solid var(--border);
  padding-top:8px;
  color:var(--t2);
  font-size:11px;
  font-weight:700;
}
.vp-field-popover{
  display:none;
  position:absolute;
  top:100%;
  left:0;
  right:0;
  z-index:999;
  max-height:200px;
  overflow-y:auto;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--card);
  box-shadow:0 4px 12px rgba(0,0,0,.1);
}
.vp-label{
  color:var(--t2);
  font-size:12px;
  font-weight:650;
  margin-bottom:4px;
}
.vp-label.sm{
  font-size:11px;
  margin-bottom:3px;
}
.vp-input{
  width:100%;
  box-sizing:border-box;
  font-size:12px;
}
.vp-line-card{
  border:1px solid var(--border);
  border-radius:8px;
  padding:12px;
  background:var(--surface);
  box-shadow:var(--shadow-sm);
}
.vp-line-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  margin-bottom:6px;
}
.vp-remove-btn{
  margin-left:auto;
  border:0;
  background:transparent;
  color:#dc2626;
  cursor:pointer;
  font-size:12px;
}
.vp-line-grid{
  display:grid;
  grid-template-columns:1fr .9fr .7fr .8fr .8fr 1.5fr .45fr .7fr;
  gap:8px;
  margin-bottom:8px;
}
.vp-rx-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:6px;
  align-items:end;
}
.vp-source-chip{
  color:#1677ff;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:4px;
  padding:1px 8px;
  font-size:11px;
}
.vp-stack-panel{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.vp-market-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:12px;
}
.vp-chip-row{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  margin:6px 0;
}
.vp-chip{
  display:inline-flex;
  align-items:center;
  min-height:20px;
  padding:0 7px;
  border-radius:4px;
  background:#e0e7ff;
  color:#4338ca;
  font-size:11px;
  font-weight:650;
}
.vp-full-btn{
  width:100%;
  justify-content:center;
}
.vp-muted-btn{
  opacity:.5;
}
.vp-scroll-list{
  max-height:52vh;
  overflow:auto;
}
@media (max-width: 760px){
  .vp-toolbar{align-items:stretch;}
  .vp-toolbar-fill,.vp-filter-group{width:100%;margin-left:0;}
  .vp-search{width:100%;}
  .vp-control,.vp-compact-btn{width:100%;min-width:0;}
  .vp-tabs{overflow-x:auto;}
  .vp-tab{white-space:nowrap;}
  .vp-batch-bar{align-items:stretch;flex-direction:column;}
  .vp-batch-actions{width:100%;margin-left:0;}
  .vp-batch-actions .btn{flex:1;justify-content:center;}
  .vp-modal-mask{padding:10px;}
  .vp-modal-head[data-vp-window-head],
  [data-vp-window-head]{cursor:default;}
  .vp-form-grid,.vp-line-grid,.vp-rx-grid{grid-template-columns:1fr;}
  .vp-market-grid{grid-template-columns:1fr;}
  .vp-modal-foot{flex-wrap:wrap;}
  .vp-modal-foot .btn{flex:1;justify-content:center;}
}

/* The small floating miniapp button is useful, but make it calmer. */
#mp-msg-btn{
  box-shadow:0 16px 34px rgba(16,163,127,.28)!important;
  border:1px solid rgba(255,255,255,.55)!important;
}
#mp-msg-btn:hover{transform:translateY(-2px) scale(1.02);}

@media (max-width: 760px){
  .dash-kpi-grid>div{padding:14px!important;}
  .dash-main-grid>div>div[style*="background:#fff"],
  .dash-main-grid>div[style*="display:flex"]>div[style*="background:#fff"]{
    box-shadow:var(--shadow-sm)!important;
  }
  .topbar .btn{box-shadow:none;}
  .user-name{max-width:150px;}
}

/* Supplier analytics dashboard */
.sp-analytics{
  display:block;
}
.sp-analytics-main-grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:16px;
  margin-bottom:16px;
}
.sp-analytics-panel{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(220,229,239,.95);
  border-radius:12px;
  box-shadow:0 2px 12px rgba(31,49,78,.07);
  padding:16px 18px;
  min-width:0;
  transition:box-shadow .18s;
}
.sp-analytics-panel:hover{
  box-shadow:0 6px 24px rgba(31,49,78,.11);
}
.sp-analytics-panel-full{
  grid-column:1/-1;
}
.sp-analytics-panel-wide{
  /* already wider via grid-column in main-grid */
}
.sp-analytics-panel-title{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:800;
  color:#1d2939;
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:1px solid #edf2f7;
}
.sp-analytics-panel-title:before{
  content:"";
  display:block;
  width:4px;
  height:14px;
  border-radius:999px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
  flex-shrink:0;
}
.sp-analytics-panel-title[data-icon]:after{
  content:attr(data-icon);
  margin-left:auto;
  font-size:16px;
  opacity:.55;
}
/* 骨架屏 */
@keyframes sp-shimmer{
  0%{background-position:-400px 0}
  100%{background-position:400px 0}
}
.sp-skel{
  border-radius:8px;
  background:linear-gradient(90deg,#f0f3f8 25%,#e4eaf4 50%,#f0f3f8 75%);
  background-size:800px 100%;
  animation:sp-shimmer 1.4s infinite linear;
}
.sp-skel-kpi{height:88px;}
.sp-skel-chart{height:280px;margin-top:8px;}
@media(max-width:1100px){
  .sp-analytics-main-grid{grid-template-columns:1fr;}
}
.sp-analytics .sp-stats-toolbar{
  position:sticky;
  top:0;
  z-index:10;
  padding:12px;
  margin-bottom:16px;
  background:rgba(255,255,255,.88);
  border:1px solid rgba(220,229,239,.95);
  border-radius:8px;
  box-shadow:0 10px 28px rgba(31,49,78,.08);
  backdrop-filter:blur(14px);
}
.sp-analytics .sp-stats-toolbar-group:first-child{
  padding:3px;
  background:#f4f7fb;
  border:1px solid #e2ebf5;
  border-radius:8px;
}
.sp-analytics .sp-stats-toolbar .btn{
  height:32px;
  min-height:32px;
  padding:0 12px;
  box-shadow:none;
}
.sp-analytics .sp-stats-toolbar input{
  height:32px!important;
  border-color:var(--border)!important;
  border-radius:8px!important;
  background:#fff!important;
  color:var(--text)!important;
}
.sp-analytics .sp-stats-kpi{
  gap:14px;
  margin-bottom:18px;
}
.sp-analytics-kpi-section{
  position:relative;
  overflow:hidden;
  padding:14px;
  border-radius:8px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  border:1px solid rgba(220,229,239,.95);
  box-shadow:0 12px 30px rgba(31,49,78,.08);
}
.sp-analytics-kpi-section:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
}
.sp-analytics-kpi-section .sp-kpi-section-title{
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:12px;
  color:#1d2939;
  font-size:13px;
  font-weight:800;
}
.sp-analytics-kpi-section .sp-kpi-section-title:before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(31,111,235,.10);
}
.sp-analytics-kpi{
  position:relative;
  padding:14px 14px 13px;
  border-radius:8px;
  background:#fff;
  border:1px solid #e7eef7;
  box-shadow:0 6px 18px rgba(31,49,78,.06);
}
.sp-analytics-kpi:after{
  content:"";
  position:absolute;
  right:12px;
  top:12px;
  width:34px;
  height:34px;
  border-radius:50%;
  background:color-mix(in srgb,var(--kpi-color) 12%,#fff);
}
.sp-analytics-kpi .sp-kpi-label{
  position:relative;
  z-index:1;
  color:#667085;
  font-size:12px;
  font-weight:750;
}
.sp-analytics-kpi .sp-kpi-value{
  position:relative;
  z-index:1;
  margin-top:6px;
  font-size:25px;
  line-height:1;
  font-weight:850;
}
.sp-analytics-kpi .sp-kpi-sub{
  position:relative;
  z-index:1;
  margin-top:8px;
  color:#98a2b3;
}
.sp-analytics>div[style*="grid-template-columns"]>div[style*="background:var(--surface)"]{
  border:1px solid rgba(220,229,239,.95)!important;
  border-radius:8px!important;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%)!important;
  box-shadow:0 12px 30px rgba(31,49,78,.08)!important;
}
.sp-analytics>div[style*="grid-template-columns"]>div[style*="background:var(--surface)"]>div:first-child{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:24px;
  color:#1d2939;
  font-size:13px!important;
  font-weight:800!important;
}
.sp-analytics>div[style*="grid-template-columns"]>div[style*="background:var(--surface)"]>div:first-child:after{
  content:"";
  width:34px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  opacity:.75;
}
.sp-analytics-chart-box{
  position:relative;
  width:100%;
  height:260px;
  max-height:260px;
  overflow:hidden;
  padding:4px 4px 0;
}
.sp-analytics-chart-box-lg{
  height:280px;
  max-height:280px;
}
#sp-chart-trend{
  display:block!important;
  width:100%!important;
  height:280px!important;
  max-height:280px!important;
  min-height:0!important;
}
.sp-analytics-rank-row{
  display:grid;
  grid-template-columns:28px minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:9px 0;
  border-bottom:1px solid #edf2f7;
}
.sp-analytics-rank-row:last-child{border-bottom:0;}
.sp-analytics-rank-no{
  width:24px;
  height:24px;
  border-radius:7px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#e8eef6;
  color:#667085;
  font-size:11px;
  font-weight:800;
  font-family:'DM Mono',monospace;
}
.sp-analytics-rank-no.rank-1{background:#fff2cc;color:#9a6700;}
.sp-analytics-rank-no.rank-2{background:#edf2f7;color:#475467;}
.sp-analytics-rank-no.rank-3{background:#ffe8d6;color:#b54708;}
.sp-analytics-rank-name{
  min-width:0;
  color:#344054;
  font-size:12px;
  font-weight:650;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sp-analytics-rank-value{
  color:#101828;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}
.sp-analytics-alert-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:9px 0;
  border-bottom:1px solid #edf2f7;
  color:#667085;
  font-size:12px;
}
.sp-analytics-alert-row:last-child{border-bottom:0;}
.sp-analytics-alert-row strong{
  min-width:34px;
  height:22px;
  padding:0 8px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:color-mix(in srgb,var(--alert-color) 12%,#fff);
  color:var(--alert-color);
  font-family:'DM Mono',monospace;
}
.sp-analytics-risk-item{
  position:relative;
  padding:11px 0 11px 14px;
  border-bottom:1px solid #edf2f7;
}
.sp-analytics-risk-item:last-child{border-bottom:0;}
.sp-analytics-risk-item:before{
  content:"";
  position:absolute;
  left:0;
  top:14px;
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--risk-color);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--risk-color) 12%,#fff);
}
.sp-analytics-risk-title{
  margin-bottom:4px;
  color:var(--risk-color);
  font-size:12px;
  font-weight:850;
}
.sp-analytics-risk-body{
  color:#667085;
  font-size:12px;
  line-height:1.6;
}
.sp-analytics-subgrid,
.sp-analytics-bottom-grid,
.sp-analytics div:has(> div > #sp-chart-slow-products){
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:16px!important;
  margin-bottom:16px!important;
  align-items:start!important;
}
.sp-analytics-bottom-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  align-items:start!important;
}
.sp-analytics-bottom-grid>div,
.sp-analytics div:has(> div > #sp-chart-slow-products)>div{
  grid-column:span 1!important;
  width:auto!important;
  min-width:0!important;
}
.sp-analytics-empty{
  padding:24px 14px;
  text-align:center;
  color:#98a2b3;
  font-size:12px;
  background:#f8fbff;
  border:1px dashed #d9e4f1;
  border-radius:8px;
}
.sp-analytics-chart-empty{
  min-height:220px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top:-300px;
  background:rgba(248,251,255,.88);
}

@media (max-width: 1180px){
  .sp-analytics>.sp-analytics-subgrid,
  .sp-analytics>.sp-analytics-bottom-grid,
  .sp-analytics div:has(> div > #sp-chart-slow-products){
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sp-analytics-bottom-grid>div{grid-column:span 1!important;}
}

@media (max-width: 980px){
  .sp-analytics .sp-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .sp-analytics>div[style*="grid-template-columns"]{
    grid-template-columns:1fr!important;
  }
  .sp-analytics>.sp-analytics-subgrid,
  .sp-analytics>.sp-analytics-bottom-grid,
  .sp-analytics div:has(> div > #sp-chart-slow-products){
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sp-analytics-bottom-grid>div{grid-column:span 1!important;}
}

@media (max-width: 560px){
  .sp-analytics .sp-stats-toolbar{position:static;}
  .sp-analytics .sp-stats-toolbar-group{width:100%;}
  .sp-analytics .sp-stats-toolbar .btn,
  .sp-analytics .sp-stats-toolbar input{
    flex:1 1 auto;
    min-width:0;
  }
  .sp-analytics .sp-kpi-grid{grid-template-columns:1fr;}
  .sp-analytics>.sp-analytics-subgrid,
  .sp-analytics>.sp-analytics-bottom-grid,
  .sp-analytics div:has(> div > #sp-chart-slow-products){
    grid-template-columns:1fr!important;
  }
  .sp-analytics-bottom-grid>div{grid-column:auto!important;}
  .sp-analytics-chart-box{height:240px;max-height:240px;}
  #sp-chart-trend{height:240px!important;max-height:240px!important;min-height:0!important;}
}

/* Supplier pages: keep action controls close to the left-side work area. */
#page-supplier-portal .ch,
#page-supplier-portal [style*="justify-content:flex-end"],
#ppanel-psuppliers [style*="justify-content:flex-end"],
#psup-modal [style*="justify-content:flex-end"],
#psup-acct-modal [style*="justify-content:flex-end"],
#psup-delete-modal [style*="justify-content:flex-end"],
#pin-modal [style*="justify-content:flex-end"],
#supplier-quick-modal [style*="justify-content:flex-end"],
#cfgpanel-supplier-accounts [style*="justify-content:flex-end"],
#cfgpanel-supplier-company [style*="justify-content:flex-end"],
#cfgpanel-supplier-settlement [style*="justify-content:flex-end"],
#cfgpanel-supplier-customer [style*="justify-content:flex-end"],
#cfgpanel-supplier-data [style*="justify-content:flex-end"],
#cfgpanel-supplier-security [style*="justify-content:flex-end"]{
  justify-content:flex-start!important;
}

#page-supplier-portal .sp-actions,
#page-supplier-portal .sp-order-action-top,
#page-supplier-portal .sp-order-action-row,
#page-supplier-portal .sp-proc-action-inline,
#page-supplier-portal .sp-table-actions,
#page-supplier-portal .vp-action-row,
#ppanel-psuppliers .sp-table-actions,
#ppanel-psuppliers .vp-action-row{
  align-items:center!important;
  justify-content:flex-start!important;
  text-align:left!important;
}

#page-supplier-portal .w-action,
#page-supplier-portal th:last-child,
#page-supplier-portal td.sp-table-actions,
#ppanel-psuppliers th:last-child,
#ppanel-psuppliers td:last-child{
  text-align:left!important;
}
