:root{--bg:#f4f5f7;--surface:#ffffff;--surface-2:#fafbfc;--border:#e4e7eb;--border-strong:#d4d8de;--text:#191c22;--text-2:#5a6373;--text-3:#8b93a1;--accent:#2456c9;--accent-weak:#eaf0fc;--ok-bg:#e7f5ee;--ok-fg:#0c7a42;--low-bg:#fdf4e3;--low-fg:#9a5a00;--out-bg:#fdecea;--out-fg:#b3362b;--radius:7px;--radius-sm:5px;--row-h:38px;--header-h:56px;--font-sans:"IBM Plex Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;--font-mono:"IBM Plex Mono",ui-monospace,"SF Mono","Menlo","Consolas",monospace;--modal-shadow:0 12px 32px rgba(20,28,46,0.18),0 2px 6px rgba(20,28,46,0.08);--accent-strong:#1f4cb3;--accent-line:#2456c9;--focus-ring:0 0 0 3px var(--accent-weak);--focus-ring-strong:0 0 0 3px rgba(36,86,201,0.35);--ok-line:#16a05a;--low-line:#d79320;--out-line:#d24436;--s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:22px;--s6:32px;--tap:48px;--ease:cubic-bezier(0.22,0.61,0.36,1)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}.mono,.num{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.num{text-align:right}:focus-visible{outline:none;box-shadow:var(--focus-ring-strong);border-radius:var(--radius-sm)}.btn:focus-visible,.input:focus-visible,.select:focus-visible{box-shadow:var(--focus-ring-strong)}.app-shell{min-height:100vh;display:flex;flex-direction:column}.header{position:-webkit-sticky;position:sticky;top:0;z-index:30;height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);border-top:2px solid var(--accent-line);gap:14px;padding:0 18px}.header,.header__brand{display:flex;align-items:center}.header__brand{gap:9px}.brand-mark{width:18px;height:18px;flex:none;display:block}.header__logo{font-weight:700;font-size:16px;letter-spacing:-.02em}.header__site{color:var(--text-2);font-size:12.5px;padding-left:9px;border-left:1px solid var(--border);align-self:center;line-height:1;white-space:nowrap}.header__nav{display:flex;gap:2px;margin-left:4px;flex-wrap:nowrap;align-self:stretch;align-items:center;overflow-x:auto;scrollbar-width:none}.header__nav::-webkit-scrollbar{display:none}.header__nav a{white-space:nowrap;position:relative;color:var(--text-2);padding:7px 11px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:background .12s var(--ease),color .12s var(--ease)}.header__nav a:hover{background:var(--surface-2);text-decoration:none;color:var(--text)}.header__nav a.active{color:var(--accent);background:transparent;font-weight:600}.header__nav a.active:after{content:"";position:absolute;left:9px;right:9px;bottom:-2px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}.header__right{margin-left:auto;display:flex;align-items:center;gap:14px;flex:none}.header__clock{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:13px;color:var(--text-2);letter-spacing:.02em}.header__status{display:flex;align-items:center;gap:7px}.header__status,.header__user{font-size:12.5px;color:var(--text-2)}.statusdot{width:8px;height:8px;border-radius:50%;background:var(--ok-fg);box-shadow:0 0 0 3px var(--ok-bg)}.statusdot--live{position:relative}.statusdot--live:after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(12,122,66,.4);animation:livepulse 2.6s var(--ease) infinite}@keyframes livepulse{0%{box-shadow:0 0 0 0 rgba(12,122,66,.35)}70%,to{box-shadow:0 0 0 7px rgba(12,122,66,0)}}.statusdot--stale{background:var(--text-3);box-shadow:0 0 0 3px var(--border)}.main{flex:1 1;padding:22px 20px 40px;max-width:1320px;width:100%;margin:0 auto}.footer{border-top:1px solid var(--border);padding:14px 20px;color:var(--text-3);font-size:12px;text-align:center}.footer strong{color:var(--text-2);font-weight:600}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.page-head h1{font-size:19px}.page-head__sub{color:var(--text-2);font-size:13px;margin-top:3px}.page-head__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.panel{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.panel,.panel__head{background:var(--surface)}.panel__head{padding:11px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}.panel__title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-2)}.panel__body{padding:14px}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:12px;gap:12px;margin-bottom:18px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;position:relative;overflow:hidden}.stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent}.stat--alert-low:before{background:var(--low-line)}.stat--alert-out:before{background:var(--out-line)}.stat--alert-accent:before{background:var(--accent)}.stat__label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);display:flex;align-items:center;gap:6px}.stat__value{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:25px;font-weight:500;margin-top:5px;line-height:1}.stat__value--low{color:var(--low-fg)}.stat__value--out{color:var(--out-fg)}.stat__value--accent{color:var(--accent)}.stat__sub{color:var(--text-3);margin-top:5px}.stat__sub,.stat__sub .mono{font-size:11.5px}.table-wrap{width:100%;overflow-x:auto;overflow-y:auto}.table-wrap--tall{max-height:calc(100vh - 320px);min-height:200px}table.data{width:100%;border-collapse:collapse;font-size:13px}table.data thead th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);font-weight:600;padding:9px 12px;border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;position:-webkit-sticky;position:sticky;top:0;z-index:2}table.data thead th.num{text-align:right}table.data tbody td{padding:0 12px;height:var(--row-h);border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}table.data tbody tr:last-child td{border-bottom:none}table.data tbody tr{transition:background .14s var(--ease)}table.data tbody tr:hover{background:var(--surface-2)}table.data .num,table.data th.num{text-align:right;font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}table.data .col-name{font-weight:500}table.data .muted,table.data td.muted{color:var(--text-2)}.cell-actions{display:flex;gap:6px;justify-content:flex-end}.empty{padding:28px 14px;text-align:center;color:var(--text-3);font-size:13px}td.rail{width:4px;padding:0}td.rail>i{display:block;width:4px;height:var(--row-h)}td.rail--ok>i,td.rail>i,tr:hover td.rail>i{background:transparent}td.rail--low>i{background:var(--low-line)}td.rail--out>i{background:var(--out-line)}.gauge{display:inline-flex;align-items:center;gap:9px;width:132px}.gauge__track{position:relative;flex:1 1;height:6px;border-radius:100px;background:var(--border);overflow:visible}.gauge__fill{position:absolute;left:0;top:0;bottom:0;border-radius:100px;background:var(--ok-line);transition:width .2s var(--ease),background .2s var(--ease)}.gauge__fill--low{background:var(--low-line)}.gauge__fill--out{background:var(--out-line)}.gauge__tick{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--text-3);border-radius:2px;opacity:.7}.gauge__val{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:13px;min-width:26px;text-align:right}@keyframes shimmer{0%{background-position:-360px 0}to{background-position:360px 0}}.skel{display:inline-block;height:11px;border-radius:4px;vertical-align:middle;background:linear-gradient(90deg,var(--surface-2) 0,var(--border) 50%,var(--surface-2) 100%);background-size:720px 100%;animation:shimmer 1.2s linear infinite}@keyframes rowflash{0%{background:var(--accent-weak)}to{background:transparent}}tr.flash{animation:rowflash 1.1s ease-out}@keyframes rowin{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}tr.row-new{animation:rowin .16s var(--ease)}.badge{display:inline-flex;align-items:center;gap:6px;padding:2px 9px 2px 7px;border-radius:100px;font-size:11.5px;font-weight:600;line-height:1.6;white-space:nowrap}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge--ok{background:var(--ok-bg);color:var(--ok-fg)}.badge--low{background:var(--low-bg);color:var(--low-fg)}.badge--out{background:var(--out-bg);color:var(--out-fg)}.badge--sent{background:var(--accent-weak);color:var(--accent)}.badge--received{background:var(--ok-bg);color:var(--ok-fg)}.badge--pending{background:var(--low-bg);color:var(--low-fg)}.badge--neutral{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--font-sans);font-size:13px;font-weight:500;padding:7px 13px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);cursor:pointer;transition:background .12s var(--ease),border-color .12s var(--ease),opacity .12s var(--ease);white-space:nowrap}.btn:hover{background:var(--surface-2)}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn--danger{color:var(--out-fg);border-color:var(--border-strong)}.btn--danger:hover{background:var(--out-bg);border-color:var(--out-fg)}.btn--sm{padding:4px 9px;font-size:12px}.btn--block{width:100%}.btn--lg{padding:13px 18px;font-size:15px}.btn--ghost{border-color:transparent;background:transparent;color:var(--text-2)}.btn--ghost:hover{background:var(--surface-2);color:var(--text)}.field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}.field label{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);font-weight:600}.input,.select{font-family:var(--font-sans);font-size:14px;padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);width:100%;transition:border-color .12s var(--ease),box-shadow .12s var(--ease)}.input:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:var(--focus-ring)}.input.mono{font-family:var(--font-mono)}.input::placeholder{color:var(--text-3)}.field-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.help{font-size:12px;color:var(--text-3)}.form-error{background:var(--out-bg);color:var(--out-fg);padding:9px 11px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px}.search{position:relative}.search>svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.search .input{padding-left:32px}.toolbar{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:14px}.toolbar .field{margin-bottom:0}.toolbar .field label{margin-bottom:1px}.chips{flex-wrap:wrap}.chip,.chips{display:inline-flex;gap:6px}.chip{align-items:center;cursor:pointer;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-2);padding:5px 11px;border-radius:100px;font-size:12.5px;font-weight:500;font-family:var(--font-sans);transition:background .12s var(--ease),color .12s var(--ease),border-color .12s var(--ease)}.chip:hover{background:var(--surface-2);color:var(--text)}.chip.active{background:var(--accent-weak);border-color:var(--accent);color:var(--accent)}.chip__count{font-family:var(--font-mono);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:11px;opacity:.85}.switch{display:inline-flex;align-items:center;gap:9px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.switch input{display:none}.switch__track{width:38px;height:21px;border-radius:100px;background:var(--border-strong);position:relative;transition:background .14s var(--ease);flex:none}.switch__track:after{content:"";position:absolute;top:2px;left:2px;width:17px;height:17px;border-radius:50%;background:#fff;transition:transform .14s var(--ease);border:1px solid var(--border-strong)}.switch input:checked+.switch__track{background:var(--accent)}.switch input:checked+.switch__track:after{transform:translateX(17px)}.segmented{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden}.segmented button{border:none;background:var(--surface);color:var(--text-2);padding:7px 14px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background .12s var(--ease),color .12s var(--ease)}.segmented button:hover{background:var(--surface-2);color:var(--text)}.segmented button+button{border-left:1px solid var(--border)}.segmented button.active{background:var(--accent);color:#fff}.segmented button.active:hover{background:var(--accent-strong)}.modal-overlay{position:fixed;inset:0;background:rgba(20,28,46,.38);display:flex;align-items:flex-start;justify-content:center;padding:60px 16px;z-index:50;animation:fadein .14s var(--ease)}@keyframes fadein{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;box-shadow:var(--modal-shadow);animation:modalin .16s var(--ease)}@keyframes modalin{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.modal__head{padding:15px 17px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal__head h3{font-size:15px}.modal__body{padding:17px;max-height:70vh;overflow-y:auto}.modal__foot{padding:13px 17px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:9px}.modal__close{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:20px;line-height:1;padding:2px 6px;border-radius:4px}.modal__close:hover{background:var(--surface-2);color:var(--text)}.toast-host{position:fixed;right:18px;bottom:18px;z-index:60;display:flex;flex-direction:column;gap:8px;align-items:flex-end}.toast{display:flex;align-items:center;gap:10px;max-width:360px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--ok-line);border-radius:var(--radius);padding:11px 13px;font-size:13px;color:var(--text);box-shadow:var(--modal-shadow);animation:toastin .18s var(--ease)}.toast--info{border-left-color:var(--accent)}.toast--warn{border-left-color:var(--low-line)}@keyframes toastin{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(120% 80% at 50% -10%,#ffffff 0,var(--bg) 60%)}.login-card{background:var(--surface);border:1px solid var(--border);border-top:2px solid var(--accent);border-radius:var(--radius);width:100%;max-width:380px;padding:26px}.login-card .brand{display:flex;align-items:center;gap:9px;font-weight:700;font-size:20px;letter-spacing:-.02em}.login-card .tag{color:var(--text-2);font-size:13px;margin:3px 0 20px}.login-hint{margin-top:16px;font-size:12px;color:var(--text-3);border-top:1px solid var(--border);padding-top:12px}.login-hint code{font-family:var(--font-mono);color:var(--text-2)}.scan-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.scan-top{background:var(--surface);border-bottom:1px solid var(--border);border-top:2px solid var(--accent);padding:11px 16px;justify-content:space-between;position:-webkit-sticky;position:sticky;top:0;z-index:10}.scan-top,.scan-top .brand{display:flex;align-items:center}.scan-top .brand{gap:8px;font-weight:700;font-size:16px}.scan-top .who{font-size:12px;color:var(--text-2)}.scan-body{flex:1 1;max-width:540px;width:100%;margin:0 auto;padding:16px 16px 96px}.scan-mode-tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);margin-bottom:12px}.scan-reader{border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;background:#000;min-height:220px;position:relative}#qr-reader,#qr-reader video{width:100%!important}#qr-reader video{display:block;height:auto!important}#qr-reader img[alt="Info icon"]{display:none}.scan-reticle{position:absolute;inset:0;pointer-events:none;z-index:5}.scan-reticle span{position:absolute;width:26px;height:26px;border:2px solid #fff}.scan-reticle span:first-child{top:18%;left:18%;border-right:0;border-bottom:0}.scan-reticle span:nth-child(2){top:18%;right:18%;border-left:0;border-bottom:0}.scan-reticle span:nth-child(3){bottom:18%;left:18%;border-right:0;border-top:0}.scan-reticle span:nth-child(4){bottom:18%;right:18%;border-left:0;border-top:0}.scan-cta{text-align:center;padding:26px 16px}.scan-cta__icon{width:56px;height:56px;margin:0 auto 12px;border:2px solid var(--accent);border-radius:12px;position:relative}.scan-cta__icon:after,.scan-cta__icon:before{content:"";position:absolute;left:12px;right:12px;height:2px;background:var(--accent-weak);top:50%}.scan-cta__icon:after{background:var(--accent);animation:scanline 1.6s ease-in-out infinite}@keyframes scanline{0%,to{top:22%}50%{top:74%}}.scan-cta__hint{color:var(--text-2);font-size:13px;margin-top:4px}.divider{display:flex;align-items:center;gap:10px;color:var(--text-3);font-size:12px;margin:18px 0}.divider:after,.divider:before{content:"";flex:1 1;height:1px;background:var(--border)}.item-list{display:flex;flex-direction:column;gap:6px;max-height:360px;overflow-y:auto}.item-list button{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 13px;min-height:var(--tap);cursor:pointer;font-family:var(--font-sans);display:flex;justify-content:space-between;align-items:center;gap:10px;transition:border-color .12s var(--ease),background .12s var(--ease)}.item-list button:focus-visible,.item-list button:hover{border-color:var(--accent);background:var(--accent-weak)}.item-list .il-name{font-weight:500;font-size:14px}.item-list .il-meta{font-size:12px;color:var(--text-2);font-family:var(--font-mono)}.item-list .il-right{display:flex;align-items:center;gap:10px}.resolved{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.resolved__name{font-size:20px;font-weight:600}.resolved__meta{display:flex;gap:8px;flex-wrap:wrap;color:var(--text-2);font-size:13px;margin:6px 0 16px;font-family:var(--font-mono)}.resolved__onhand{display:flex;align-items:baseline;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:16px}.resolved__onhand .v{font-family:var(--font-mono);font-size:30px;font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.resolved__onhand .l{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3)}.projected{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px;margin-bottom:16px;border:1px dashed var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);flex-wrap:wrap}.projected .from{font-family:var(--font-mono);font-size:18px;color:var(--text-2);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.projected .arrow{color:var(--text-3);display:inline-flex}.projected .to{font-family:var(--font-mono);font-size:24px;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.projected .to--out{color:var(--out-fg)}.projected .to--low{color:var(--low-fg)}.qty-stepper{display:flex;align-items:stretch;gap:0;margin-bottom:10px}.qty-stepper button{width:64px;min-height:var(--tap);font-size:26px;border:1px solid var(--border-strong);background:var(--surface);cursor:pointer;color:var(--text);transition:background .12s var(--ease)}.qty-stepper button:hover{background:var(--surface-2)}.qty-stepper button:active{background:var(--accent-weak)}.qty-stepper button:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.qty-stepper button:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.qty-stepper input{flex:1 1;text-align:center;border:1px solid var(--border-strong);border-left:none;border-right:none;font-family:var(--font-mono);font-size:26px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;min-width:0}.qty-stepper input:focus{outline:none;box-shadow:inset var(--focus-ring)}.scan-actionbar{position:fixed;left:0;right:0;bottom:0;z-index:20;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px calc(12px + env(safe-area-inset-bottom));display:flex;gap:10px;max-width:540px;margin:0 auto}.scan-actionbar .btn{flex:1 1}.scan-actionbar .btn--confirm{flex:2 1}.scan-success{text-align:center;padding:30px 16px}.scan-success__check{width:64px;height:64px;margin:0 auto 14px;border-radius:50%;background:var(--ok-bg);color:var(--ok-fg);display:flex;align-items:center;justify-content:center;animation:pop .22s var(--ease)}.scan-success__check svg{width:30px;height:30px}@keyframes pop{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.scan-success h2{font-size:18px;margin-bottom:4px}.scan-success p{color:var(--text-2);font-size:14px}.scan-success .po-flag{margin-top:14px;display:inline-flex}.po-callout{margin:16px auto 0;max-width:380px;text-align:left;border:1px solid var(--accent);background:var(--accent-weak);border-radius:var(--radius);padding:12px 14px}.po-callout .pc-head{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--accent);font-size:13px}.po-callout .pc-body{margin-top:6px;font-size:13px;color:var(--text-2)}.po-callout .pc-body strong{color:var(--text);font-family:var(--font-mono)}.chart{width:100%;position:relative}.chart svg{width:100%;height:auto;display:block}.chart .bar{fill:var(--accent);transition:fill .12s var(--ease);cursor:default}.chart .bar:hover,.chart g.hot .bar{fill:var(--accent-strong)}.chart .bar-bg{fill:var(--surface-2)}.chart .axis-line{stroke:var(--border-strong);stroke-width:1}.chart .grid-line{stroke:var(--border);stroke-width:1}.chart .axis-label{fill:var(--text-3);font-size:10px;font-family:var(--font-sans)}.chart .bar-label{fill:var(--text-2);font-size:11px;font-family:var(--font-sans)}.chart g.hot .bar-label{fill:var(--text)}.chart .val-label{fill:var(--text);font-size:11px;font-family:var(--font-mono);font-weight:600}.labels-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:12px;gap:12px}.bin-label{border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:14px;display:flex;gap:14px;align-items:center;background:#fff;page-break-inside:avoid;break-inside:avoid}.bin-label .ql-qr,.bin-label img{width:96px;height:96px;flex-shrink:0;display:block}.bin-label .bl-name{font-weight:600;font-size:15px}.bin-label .bl-sku{font-family:var(--font-mono);font-size:13px;color:var(--text-2);margin-top:2px}.bin-label .bl-loc{font-size:12px;color:var(--text-3);margin-top:6px;text-transform:uppercase;letter-spacing:.05em}.bin-label .bl-code{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:4px}.print-bar{margin-bottom:16px;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.settings-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:16px;gap:16px;align-items:start}@media (max-width:880px){.settings-grid{grid-template-columns:1fr}}@media print{.no-print{display:none!important}body{background:#fff}.main{padding:0;max-width:none}.labels-grid{grid-template-columns:repeat(3,1fr);gap:8px}.bin-label{border-color:#999}.statusdot--live:after{animation:none}}.spinner{width:16px;height:16px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(1turn)}}.center-load{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-3);font-size:13px}.qr-glyph{display:inline-flex}.qr-glyph svg{display:block}.row-gap{display:flex;gap:8px;align-items:center}.btn-link{background:none;border:none;padding:0;margin:0;font:inherit;color:var(--accent);cursor:pointer}.btn-link:hover{text-decoration:underline}.btn-link:focus-visible{outline:none;box-shadow:var(--focus-ring-strong);border-radius:3px}.text-2{color:var(--text-2)}.text-3{color:var(--text-3)}.nowrap{white-space:nowrap}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:40px 16px;text-align:center}.empty-state svg{color:var(--text-3);opacity:.7}.empty-state .es-title{font-size:14px;font-weight:600;color:var(--text-2)}.empty-state .es-sub{font-size:12.5px;color:var(--text-3);max-width:320px}@media (max-width:1080px){.header__site{display:none}}@media (max-width:920px){.header__clock{display:none}}@media (max-width:760px){.field-row{grid-template-columns:1fr}.header{flex-wrap:wrap;height:auto;padding:8px 14px;gap:10px}.header__nav{order:3;width:100%}.header__nav a.active:after{bottom:0}.header__site{display:none}.main{padding:16px 12px 32px}table.data .col-lowpri{display:none}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}