:root{--ink:#2b3035;--ink-2:#3b4148;--bg:#f3f4f6;--card:#fff;--border:#e6e8ea;--text:#2b3035;--muted:#6b7280;--orange:#ef7d00;--orange-dark:#d06d00;--yellow:#f5b40a;--red:#e23b34;--green:#1f9d57;--shadow:0 1px 2px #14181c0f, 0 6px 20px #14181c0f;--shadow-sm:0 1px 2px #14181c0f;--gap:16px;--pad:18px;--radius:14px;--radius-sm:10px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{color:var(--text);-webkit-font-smoothing:antialiased;background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{flex-direction:column;min-height:100%;display:flex}input:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 3px #ef7d0026}.app-header{background:var(--ink);color:#fff;z-index:10;border-bottom:2px solid var(--orange);box-shadow:var(--shadow-sm);padding:12px 20px;position:sticky;top:0}.brand{align-items:center;gap:12px;display:flex}.brand-sub{color:#ffffffb3;font-size:14px;font-weight:500}.logo-box{justify-content:center;align-items:center;min-height:40px;padding:2px 0;display:inline-flex}.logo-img{width:auto;height:30px;display:block}.header-right{align-items:center;gap:8px;margin-left:auto;display:flex}.header-pill{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff29;border-radius:999px;align-items:center;gap:7px;padding:7px 14px;font-size:13px;font-weight:600;line-height:1;display:inline-flex}.header-pill:hover{background:#ffffff2e}.header-pill svg{display:block}.header-pill.icon-only{padding:8px}.tabs{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.tabs button{color:#ffffffd9;cursor:pointer;background:#ffffff14;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:9px 16px;font-size:14px;font-weight:600;display:inline-flex}.tabs button:hover{color:#fff;background:#ffffff29}.tabs button.active{background:var(--orange);color:#fff}.tab-badge{background:var(--red);color:#fff;border-radius:999px;padding:1px 7px;font-size:11px;font-weight:700}.app-main{flex:1;width:100%;max-width:1120px;margin:0 auto;padding:20px}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{background:var(--orange);color:#fff}.btn-primary:hover{background:var(--orange-dark)}.btn-secondary{color:var(--text);border:1px solid var(--border);background:#fff}.btn-secondary:hover{background:#f7f8f9;border-color:#d6d9dc}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{padding:10px}.link{color:var(--orange-dark);cursor:pointer;background:0 0;border:none;padding:2px 6px;font-size:13px}.link.danger{color:var(--red)}.scan-view{gap:var(--gap);flex-direction:column;max-width:560px;margin:0 auto;display:flex}.employee-bar{background:var(--card);width:100%;color:var(--ink);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:8px;padding:12px;font-size:15px;display:inline-flex}.employee-bar svg{color:var(--orange)}.employee-bar.warn{color:var(--red);background:#fdecec;border-color:#f6cfcd;font-weight:700}.employee-bar.warn svg{color:var(--red)}.mode-toggle{gap:var(--gap);display:flex}.mode-btn{cursor:pointer;border:1px solid var(--border);background:var(--card);border-radius:var(--radius);color:var(--muted);box-shadow:var(--shadow-sm);flex:1;justify-content:center;align-items:center;gap:8px;padding:20px;font-size:17px;font-weight:700;display:inline-flex}.mode-sign{font-size:22px;line-height:1}.mode-btn.active.out{border-color:var(--red);color:var(--red);background:#fdecec}.mode-btn.active.in{border-color:var(--green);color:var(--green);background:#e9f7ee}.qty-row{justify-content:space-between;align-items:center;display:flex}.qty-stepper{align-items:center;gap:8px;display:flex}.qty-stepper button{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:44px;height:44px;color:var(--text);background:#fff;font-size:22px}.qty-stepper input{text-align:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;width:64px;height:44px;font-size:18px}.scan-hint{color:var(--orange-dark);border:1px solid #f7e3b5;border-left:3px solid var(--yellow);border-radius:var(--radius);text-align:center;background:#fff7e6;padding:14px}.manual-row{gap:8px;display:flex}.manual-row input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#fff;flex:1;padding:11px 13px;font-size:15px}.feed{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.feed-empty{color:var(--muted);text-align:center;padding:24px}.feed-item{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);border-left:4px solid var(--green);flex-direction:column;padding:12px 14px;display:flex}.feed-item.low{border-left-color:var(--yellow)}.feed-item.error{border-left-color:var(--red)}.feed-text{font-weight:600}.feed-sub{color:var(--muted);font-size:13px}.feed-create{cursor:pointer;text-align:left;width:100%;color:inherit;font:inherit;background:0 0;border:none;flex-direction:column;align-items:flex-start;gap:2px;margin:0;padding:0;display:flex}.feed-item.error .feed-create:hover .feed-sub{color:var(--red);text-decoration:underline}.camera-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;justify-content:center;align-items:center;gap:var(--gap);background:#14181cb8;flex-direction:column;padding:20px;display:flex;position:fixed;inset:0}.camera-box{aspect-ratio:4/3;width:100%;max-width:420px;position:relative}.camera-video{object-fit:cover;border-radius:var(--radius);width:100%;height:100%}.camera-reticle{border:3px solid #ffffffd9;border-radius:12px;position:absolute;inset:18% 14%;box-shadow:0 0 0 9999px #00000040}.camera-error{color:#fff;text-align:center}.dashboard{gap:var(--gap);flex-direction:column;display:flex}.stat-row{gap:var(--gap);flex-wrap:wrap;display:flex}.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);min-width:130px;padding:var(--pad);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;display:flex}.stat-num{color:var(--ink);font-size:28px;font-weight:800}.stat-label{color:var(--muted);font-size:13px}.stat-alert{background:#fdecec;border-color:#f6cfcd}.stat-alert .stat-num{color:var(--red)}.toolbar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.search{border:1px solid var(--border);border-radius:var(--radius-sm);min-width:200px;color:var(--text);background:#fff;flex:1;padding:11px 13px;font-size:14px}.checkbox{color:var(--muted);align-items:center;gap:6px;font-size:14px;display:inline-flex}.table-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto}.grid{border-collapse:collapse;width:100%;font-size:14px}.grid th,.grid td{text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:11px 12px}.grid tbody tr:last-child td{border-bottom:none}.grid th{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;background:#fafbfc;font-size:12px;font-weight:600}.grid .num{text-align:right}.grid .strong{font-weight:700}.grid .mono,.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.grid tbody tr:hover{background:#fafbfc}.row-low{background:#fdf1f0}.row-low:hover{background:#fce9e7}.row-inactive{opacity:.5}.cell-name{font-weight:600}.cell-cat{color:var(--muted);font-size:12px}.unit{color:var(--muted);font-size:12px;font-weight:400}.actions{text-align:right}.empty{text-align:center;color:var(--muted);padding:24px}.muted{color:var(--muted)}.neg{color:var(--red)}.pos{color:var(--green)}.badge{border-radius:999px;padding:3px 9px;font-size:12px;font-weight:600}.badge-ok{color:var(--green);background:#e9f7ee}.badge-low{color:var(--red);background:#fdecec}.movements,.settings{gap:var(--gap);flex-direction:column;display:flex}.movements h2,.settings h2{color:var(--ink);margin:0}.setting-block{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--pad);box-shadow:var(--shadow-sm)}.setting-block h3{color:var(--ink);margin-top:0}.setting-block input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#fff;padding:10px 12px;font-size:15px}.setting-block input:focus{border-color:var(--orange);outline:none;box-shadow:0 0 0 3px #ef7d0026}.form-row>input{flex:1;min-width:0}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:40;background:#14181c73;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:600px;box-shadow:var(--shadow);flex-direction:column;gap:12px;padding:24px;display:flex}.modal h2{color:var(--ink);margin:0 0 4px}.modal label{color:var(--muted);flex-direction:column;gap:4px;font-size:13px;font-weight:600;display:flex}.modal input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:#fff;max-width:100%;padding:10px 12px;font-size:15px}.form-row{gap:12px;display:flex}.form-row label{flex:1;min-width:0}.modal-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.form-error{color:var(--red);margin:0;font-size:14px}.form-hint{color:var(--muted);margin:0;font-size:13px}.employee-list{flex-direction:column;gap:8px;margin:8px 0;display:flex}.employee-pick{text-align:left;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text);background:#fff;align-items:center;gap:10px;padding:14px 16px;font-size:16px;display:flex}.employee-pick svg{color:var(--orange);flex:none}.employee-pick:hover{border-color:var(--orange);background:#fff7e6}.login-screen{background:var(--ink);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:360px;box-shadow:var(--shadow);flex-direction:column;gap:14px;padding:32px;display:flex}.login-card h1{color:var(--ink);margin:0}.login-card input{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;padding:12px;font-size:16px}@media (width<=640px){.form-row{flex-direction:column}.brand-sub{display:none}.header-right{gap:6px}.brand{flex-wrap:wrap}}
