:root{--ink:#14161c;--sub:#5b616e;--wash:#f5f6f8;--paper:#fff;--line:#e4e7ec;--brand:#2b59ff;--brand-dark:#1e40e0;--pend:#b7791f;--pend-bg:#fef3c7;--print:#1d4ed8;--print-bg:#dbeafe;--ok:#15803d;--ok-bg:#dcfce7;--err:#dc2626;--err-bg:#fee2e2;--mono:"IBM Plex Mono",ui-monospace,monospace}*{box-sizing:border-box}body{margin:0;font-family:IBM Plex Sans Thai,system-ui,sans-serif;color:var(--ink);background:var(--wash);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none}button:disabled{opacity:.6;cursor:default}.topbar{position:sticky;top:0;z-index:20;background:var(--ink);color:#fff;padding:14px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}.brand-mark{display:flex;align-items:center;gap:11px;margin-right:auto}.brand-mark .glyph{width:34px;height:34px;border-radius:9px;background:var(--brand);display:grid;place-items:center;font-weight:700;font-size:18px}.brand-mark h1{font-size:17px;font-weight:600;margin:0}.brand-mark p{font-size:11.5px;color:#9aa0ad;margin:2px 0 0}.stats{display:flex;gap:8px;flex-wrap:wrap}.stat{background:#1f232c;border:1px solid #2b303b;border-radius:11px;padding:7px 13px;min-width:78px;text-align:center}.stat .n{font-size:20px;font-weight:700;line-height:1;font-family:var(--mono)}.stat .l{font-size:10.5px;color:#9aa0ad;margin-top:3px}.stat.pend .n{color:#facc55}.stat.print .n{color:#7ea6ff}.stat.ok .n{color:#5ee69a}.progress-wrap{padding:0 20px 12px;background:var(--ink)}.progress{height:6px;background:#2b303b;border-radius:99px;overflow:hidden}.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),#5ee69a);transition:width .4s ease}.wrap{max-width:1000px;margin:0 auto;padding:20px}.panel{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}.panel-head{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}.panel-head h2{font-size:14px;margin:0;font-weight:600}.panel-head .hint{font-size:12px;color:var(--sub);margin-left:auto}.panel-body{padding:18px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.search{flex:1;min-width:180px}.search input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:13px;font-family:inherit}.search input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2b59ff22}.btn{padding:9px 15px;border-radius:9px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:7px}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark)}.btn-scan{background:var(--ink);color:#fff}.btn-scan:hover{background:#000}.btn-ghost{background:var(--wash);color:var(--ink);border:1px solid var(--line)}.btn-ghost:hover{background:#eceef1}.empty{text-align:center;padding:52px 20px;color:var(--sub)}.empty-glyph{font-size:40px;color:var(--line);margin-bottom:8px}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;color:var(--sub);font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:0 10px 9px}td{padding:11px 10px;border-top:1px solid var(--line);vertical-align:middle}.carrier-line{display:flex;align-items:center;gap:7px;margin-bottom:3px}.carrier-dot{width:9px;height:9px;border-radius:99px;flex:none}.carrier-name{font-size:12px;font-weight:600}.cod{font-size:10px;font-weight:700;color:var(--err);background:var(--err-bg);padding:1px 6px;border-radius:5px}.track{font-family:var(--mono);font-size:13px;font-weight:600}.track.none{color:var(--sub);font-style:italic;font-family:inherit;font-size:12px;font-weight:400}.order-no{font-size:11px;color:var(--sub);margin-top:2px}.recipient{font-size:12.5px;color:var(--ink)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:99px;white-space:nowrap}.badge:before{content:"";width:7px;height:7px;border-radius:99px;background:currentColor}.b-pend{background:var(--pend-bg);color:var(--pend)}.b-print{background:var(--print-bg);color:var(--print)}.b-ok{background:var(--ok-bg);color:var(--ok)}.row-actions{display:flex;gap:6px;justify-content:flex-end}.mini{padding:6px 11px;border-radius:8px;font-size:12px;font-weight:600}.mini-print{background:var(--brand);color:#fff}.mini-print:hover{background:var(--brand-dark)}.mini-ok{background:var(--wash);color:var(--ok);border:1px solid var(--ok-bg)}.mini-ok:hover{background:var(--ok-bg)}tr.done td{background:#fbfefb}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0c12b8;z-index:40;display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:var(--paper);border-radius:18px;width:100%;max-width:440px;overflow:hidden;max-height:92vh;display:flex;flex-direction:column}.modal-head{padding:15px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:15px;font-weight:600}.modal-head .x{margin-left:auto;background:var(--wash);width:30px;height:30px;border-radius:8px;font-size:18px;color:var(--sub)}#reader{width:100%;background:#000}.scan-status{padding:14px 18px;text-align:center;min-height:64px;display:flex;flex-direction:column;justify-content:center;gap:3px}.scan-status .msg{font-size:14px;font-weight:600}.scan-status .sub{font-size:12px;color:var(--sub)}.scan-status.ok{background:var(--ok-bg)}.scan-status.ok .msg{color:var(--ok)}.scan-status.err{background:var(--err-bg)}.scan-status.err .msg{color:var(--err)}.scan-status.warn{background:var(--pend-bg)}.scan-status.warn .msg{color:var(--pend)}.scan-log{padding:0 18px 16px;max-height:150px;overflow-y:auto}.scan-log .item{font-size:12px;padding:7px 0;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center}.scan-log .item .dot{width:8px;height:8px;border-radius:99px;flex:none}.scan-log .item .t{font-family:var(--mono);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scan-log .item .time{color:var(--sub);font-size:11px}.log-empty{font-size:12px;color:var(--sub);padding:8px 0}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%) translateY(20px);z-index:60;opacity:0;transition:.25s;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.toast .t{background:var(--ink);color:#fff;padding:11px 18px;border-radius:11px;font-size:13.5px;font-weight:500;box-shadow:0 8px 24px #00000040}.toast.ok .t{background:var(--ok)}.toast.err .t{background:var(--err)}.toast.warn .t{background:var(--pend)}.set-modal{max-width:480px}.set-body{padding:18px;overflow-y:auto}.set-field{margin-bottom:14px}.set-field label{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;margin-bottom:6px}.set-field input,.set-field select,.set-field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:13px;font-family:inherit}.set-field textarea{font-family:var(--mono);font-size:11.5px;resize:vertical}.set-field input:focus,.set-field select:focus,.set-field textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2b59ff22}.set-hint{font-size:11.5px;color:var(--sub);margin-top:5px;line-height:1.5}.set-hint code{font-family:var(--mono);background:var(--wash);padding:1px 5px;border-radius:4px;font-size:11px}.set-badge{font-size:10px;font-weight:700;color:var(--ok);background:var(--ok-bg);padding:2px 7px;border-radius:6px}.set-divider{font-size:11px;font-weight:700;color:var(--sub);text-transform:uppercase;letter-spacing:.4px;margin:20px 0 12px;padding-top:14px;border-top:1px solid var(--line)}.set-full{width:100%;justify-content:center;margin-top:4px}.drive-status{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--wash);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px;font-size:13px}.drive-status .ok{color:var(--ok)}.drive-status .no{color:var(--pend)}.set-row{display:flex;gap:8px;margin-top:8px}.set-grow{flex:1;justify-content:center}.mini-del{background:var(--wash);color:var(--err);border:1px solid var(--err-bg)}.mini-del:hover{background:var(--err-bg)}.selbar{display:flex;align-items:center;gap:10px;background:#eef2ff;border:1px solid #d6e0ff;border-radius:10px;padding:9px 14px;margin-bottom:12px;font-size:13px;font-weight:600;flex-wrap:wrap}.selbar span{margin-right:auto}.btn-del{background:var(--err);color:#fff}.btn-del:hover{background:#b91c1c}tr.sel td{background:#eef2ff!important}td input[type=checkbox],th input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--brand)}.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}.pager-info{font-size:12.5px;color:var(--sub)}.pager-ctrl{display:flex;align-items:center;gap:10px}.pager-ctrl label{font-size:12.5px;color:var(--sub);display:flex;align-items:center;gap:6px}.pager-ctrl select{padding:6px 8px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-family:inherit;cursor:pointer}.pg-btn{width:30px;height:30px;border-radius:8px;background:var(--wash);border:1px solid var(--line);font-size:16px;line-height:1}.pg-btn:hover:not(:disabled){background:#eceef1}.pg-btn:disabled{opacity:.4;cursor:default}.pg-num{font-size:13px;font-weight:600;font-family:var(--mono);min-width:44px;text-align:center}.pg-nums{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.pg-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}.pg-ellipsis{padding:0 4px;color:var(--sub);font-size:14px}.mini-del{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px}.icon-btn{background:none;border:none;padding:1px;cursor:pointer;display:inline-flex;line-height:0;border-radius:50%;transition:transform .1s,opacity .1s}.icon-btn:hover:not(:disabled){transform:scale(1.1)}.icon-btn:disabled{opacity:.4;cursor:default}.row-actions{gap:4px}.carrier-badge{width:26px;height:26px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;letter-spacing:-.3px;flex:none;overflow:hidden;box-shadow:inset 0 0 0 1px #0000000f}.carrier-badge img{width:100%;height:100%;object-fit:contain}.scan-status.dup{background:var(--err-bg);animation:dupflash .5s ease-in-out 2}.scan-status.dup .msg{color:var(--err);font-size:16px}.toast.dup .t{background:var(--err)}@keyframes dupflash{0%,to{background:var(--err-bg)}50%{background:#fca5a5}}.preview-modal{max-width:520px}.preview-body{padding:16px;display:flex;align-items:center;justify-content:center;max-height:78vh;overflow:auto;background:#f0f1f3}.preview-body img{max-width:100%;height:auto;border-radius:6px;box-shadow:0 2px 12px #00000026;background:#fff}.preview-loading{padding:60px 20px;color:var(--sub);font-size:14px}.items-btn{margin-top:5px;padding:3px 9px;border:1px dashed var(--line);border-radius:7px;background:var(--wash);font-size:11.5px;color:var(--sub);cursor:pointer;font-family:inherit}.items-btn:hover{border-color:var(--brand);color:var(--brand)}.items-btn.has{border-style:solid;border-color:var(--brand);color:var(--brand);background:#eef2ff;font-weight:600}.items-modal{max-width:460px}.items-body{padding:14px 16px}.items-hint{font-size:12px;color:var(--sub);margin-bottom:12px;line-height:1.5}.item-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.item-row .it-qty{width:60px;flex:none;padding:8px;border:1px solid var(--line);border-radius:8px;font-size:14px;text-align:center;font-family:inherit}.item-row .it-name{flex:1;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit}.item-row .it-del{width:30px;height:30px;flex:none;border:none;background:var(--wash);border-radius:8px;color:var(--err);font-size:18px;cursor:pointer}.item-row .it-del:hover{background:var(--err-bg)}.it-add{width:100%;justify-content:center;border-style:dashed}.items-foot{display:flex;gap:8px;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--line)}.items-foot .btn-primary{min-width:110px;justify-content:center}.recip-field{margin-bottom:12px}.recip-field label{display:block;font-size:12px;color:var(--sub);margin-bottom:5px}.recip-field input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;box-sizing:border-box}.recipient-edit{cursor:pointer;border-radius:6px}.recipient-edit:hover{background:var(--wash)}.rc-empty{color:var(--brand);font-size:12px;opacity:.75}.ref-no{font-size:11px;font-weight:700;color:var(--brand);background:#eef2ff;border-radius:5px;padding:1px 6px;font-family:var(--mono)}.items-cell{font-size:12.5px;line-height:1.45;vertical-align:top}.item-line{white-space:normal;word-break:break-word}.item-line .q{color:var(--sub);font-weight:700;font-family:var(--mono);white-space:nowrap}.boot{min-height:60vh;display:flex;align-items:center;justify-content:center;color:var(--sub)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--wash)}.login-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px 28px;width:100%;max-width:360px;box-shadow:0 8px 30px #00000014;text-align:center}.login-logo{font-size:40px}.login-card h1{font-size:20px;margin:8px 0 2px}.login-sub{color:var(--sub);font-size:13px;margin-bottom:20px}.login-field{text-align:left;margin-bottom:12px}.login-field label{display:block;font-size:12px;color:var(--sub);margin-bottom:5px}.login-field input{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:inherit;box-sizing:border-box}.login-err{background:var(--err-bg);color:var(--err);font-size:13px;padding:8px 10px;border-radius:8px;margin-bottom:12px}.login-btn{width:100%;justify-content:center;margin-top:4px}.user-chip{margin-left:auto;font-size:12px;color:var(--sub);align-self:center;padding:0 8px}.user-chip b{color:var(--brand);font-weight:700}.users-mgr{margin-bottom:6px}.user-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.user-item{display:flex;align-items:center;gap:8px;background:var(--wash);border:1px solid var(--line);border-radius:9px;padding:8px 10px}.user-item .ue{flex:1;font-size:13px;word-break:break-all}.urole{font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px}.urole.owner{background:#eef2ff;color:var(--brand)}.urole.packer{background:#f1f3f5;color:var(--sub)}.u-del{border:none;background:none;color:var(--err);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:6px}.u-del:hover{background:var(--err-bg)}.user-add{display:flex;gap:8px;flex-wrap:wrap}.user-add input{flex:1;min-width:120px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:13px;font-family:inherit}.user-add .btn{white-space:nowrap}.topbar.statbar-only,.topbar.statbar-only .stats{justify-content:center}.appmenu{position:fixed;top:12px;right:14px;z-index:60}.appmenu-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:#fff;font-size:18px;cursor:pointer;box-shadow:0 1px 4px #00000014;display:flex;align-items:center;justify-content:center}.appmenu-btn:hover{background:var(--wash)}.appmenu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:59}.appmenu-pop{position:absolute;top:46px;right:0;z-index:61;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 28px #00000024;min-width:210px;overflow:hidden;padding:6px}.am-user{padding:10px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}.am-email{font-size:13px;font-weight:600;word-break:break-all}.am-role{display:inline-block;margin-top:5px;font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px}.am-role.owner{background:#eef2ff;color:var(--brand)}.am-role.packer{background:#f1f3f5;color:var(--sub)}.am-item{display:block;width:100%;text-align:left;padding:10px 12px;border:none;background:none;font-size:14px;cursor:pointer;border-radius:8px;font-family:inherit;color:var(--ink,#14161c)}.am-item:hover{background:var(--wash)}.am-logout{color:var(--err)}.export-modal{max-width:400px}.export-body{padding:16px}.ex-hint{font-size:12px;color:var(--sub);margin-bottom:14px;line-height:1.5}.ex-field{margin-bottom:12px}.ex-field label{display:block;font-size:12px;color:var(--sub);margin-bottom:5px}.ex-field input{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;box-sizing:border-box}.ex-presets{display:flex;gap:8px}.export-foot{display:flex;gap:8px;justify-content:flex-end;padding:12px 16px;border-top:1px solid var(--line)}.btn-verify{background:var(--ok);color:#fff}.btn-verify:hover{filter:brightness(.95)}.tabs{display:flex;gap:6px;margin-bottom:14px;border-bottom:1px solid var(--line)}.tab{border:none;background:none;padding:9px 14px;font-size:14px;font-family:inherit;color:var(--sub);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:600}.tab:hover{color:var(--ink,#14161c)}.tab.on{color:var(--brand);border-bottom-color:var(--brand)}.rounds{display:flex;flex-direction:column;gap:10px}.round{border:1px solid var(--line);border-radius:11px;overflow:hidden}.round-head{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--wash);border:none;cursor:pointer;font-family:inherit;font-size:14px;text-align:left}.round-head:hover{background:#eceef1}.rd-caret{color:var(--sub);width:14px}.rd-when{font-weight:700}.rd-count{margin-left:auto;font-size:12.5px;color:var(--brand);font-weight:700;white-space:nowrap}.round-body{padding:6px 8px}.rd-item{display:grid;grid-template-columns:70px 1.3fr 1fr 1.4fr auto;gap:8px;align-items:center;padding:8px;border-top:1px solid var(--line);font-size:12.5px}.rd-item:first-child{border-top:none}.rd-carrier{font-weight:700}.rd-track{font-family:var(--mono);word-break:break-all}.rd-recip{color:var(--sub)}.rd-goods{color:var(--sub);word-break:break-word}.rd-view{border:1px solid var(--line);background:#fff;border-radius:7px;padding:4px 10px;font-size:12px;cursor:pointer;font-family:inherit}.rd-view:hover{border-color:var(--brand);color:var(--brand)}@media (max-width:640px){.rd-item{grid-template-columns:1fr auto;grid-auto-flow:row}}.round-pager{margin-top:8px;padding:8px;border-top:1px dashed var(--line)}
