.spinner-inline[data-v-e9864e88]{display:inline-block;width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--primary, #2563eb);border-radius:50%;animation:spin-e9864e88 .7s linear infinite;vertical-align:-2px;margin-right:4px}.spinner[data-v-e9864e88]{display:inline-block;width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary, #2563eb);border-radius:50%;animation:spin-e9864e88 .8s linear infinite}@keyframes spin-e9864e88{to{transform:rotate(360deg)}}:root{--navy: #1F2B3E;--navy-light: #2a3a52;--orange: #E8531E;--orange-light: #f06535;--bg: #f4f5f7;--surface: #fff;--border: #dde1e7;--text: #1a1a2e;--muted: #6b7280;--success: #16a34a;--success-bg: #dcfce7;--warning: #b45309;--warning-bg: #fef3c7;--danger: #dc2626;--danger-bg: #fee2e2;--info: #1d4ed8;--info-bg: #eff6ff;--radius: 10px;--shadow: 0 1px 4px rgba(0,0,0,.08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px}.login-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--navy) 0%,#0f1722 100%);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.login-box{background:#fff;border-radius:14px;padding:32px;width:100%;max-width:380px;box-shadow:0 20px 60px #0000004d}.login-logo{width:52px;height:52px;background:var(--orange);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;margin:0 auto 14px}.login-title{text-align:center;font-size:18px;font-weight:700;color:var(--navy);margin-bottom:4px}.login-sub{text-align:center;font-size:12px;color:var(--muted);margin-bottom:24px}.login-hint{margin-top:14px;padding:10px;background:var(--info-bg);color:var(--info);border-radius:8px;font-size:11px;line-height:1.5}.header{background:var(--navy);color:#fff;padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:10px}.header-logo{width:32px;height:32px;background:var(--orange);border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:#fff}.header-title{font-size:15px;font-weight:600}.header-sub{font-size:11px;opacity:.6;margin-top:1px}.header-right{display:flex;gap:10px;align-items:center}.role-badge{font-size:10px;padding:3px 8px;border-radius:20px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.role-badge.admin{background:var(--orange);color:#fff}.role-badge.operator{background:#fff3;color:#fff}.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:#fff;padding:5px 12px;border-radius:6px;font-size:12px;cursor:pointer}.badge-count{background:var(--orange);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;min-width:28px;text-align:center}.tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;overflow-x:auto}.tab{padding:12px 16px;font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none;background:none;border-left:0;border-right:0;border-top:0;font-family:inherit}.tab.active{color:var(--orange);border-bottom-color:var(--orange)}.main{max-width:1400px;margin:0 auto;padding:20px}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;margin-bottom:16px;box-shadow:var(--shadow)}.card-title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.card-title .dot{width:6px;height:6px;border-radius:50%;background:var(--orange)}.form-row{margin-bottom:14px}.form-row label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.form-row input,.form-row select,.form-row textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;background:var(--surface);color:var(--text);outline:none;font-family:inherit}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px #e8531e14}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;border:none;font-family:inherit}.btn-primary{background:var(--orange);color:#fff}.btn-navy{background:var(--navy);color:#fff}.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--border)}.btn-outline:hover{background:var(--bg)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:6px 10px;font-size:12px}.btn-full{width:100%;justify-content:center}.scan-button-big{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;padding:32px;background:linear-gradient(135deg,var(--orange) 0%,#d9471a 100%);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.5px}.scan-button-big svg{width:44px;height:44px}.scan-button-big small{font-size:11px;opacity:.9;font-weight:500;text-transform:none;letter-spacing:0}.photo-preview-wrap{text-align:center;margin-top:14px;padding:14px;background:var(--bg);border-radius:8px}.photo-preview{max-width:100%;max-height:240px;border-radius:8px;border:1px solid var(--border)}.photo-status{margin-top:10px;font-size:13px;font-weight:500}.scanner-wrap{position:relative;margin-top:14px;background:#000;border-radius:12px;overflow:hidden;aspect-ratio:4 / 3}.scanner-video{width:100%;height:100%;object-fit:cover;display:block}.scanner-frame{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border:2px solid rgba(255,255,255,.85);border-radius:12px;box-shadow:0 0 0 9999px #00000059;pointer-events:none}.scanner-cancel{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#fffffff2}.scanner-torch{position:absolute;top:12px;right:12px;background:#ffffffe6;padding:6px 12px;font-size:12px}.scanner-torch.on{background:#ffd84d;border-color:#e6b800;color:#3a2d00}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:var(--navy);color:#fff}thead th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}tbody tr{border-bottom:1px solid var(--border)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#fafafa}tbody td{padding:9px 12px;vertical-align:middle}.td-mono{font-family:Courier New,monospace;font-size:12px;color:var(--navy);font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}.badge-orange{background:#fff7ed;color:var(--orange)}.badge-blue{background:var(--info-bg);color:var(--info)}.badge-gray{background:#f1f5f9;color:var(--muted)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.search-row{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.search-row input,.search-row select{padding:9px 12px;border:1px solid var(--border);border-radius:7px;font-size:13px;outline:none;font-family:inherit}.search-row input{flex:1;min-width:160px}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{background:var(--navy);color:#fff;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;max-width:280px;box-shadow:0 4px 12px #0003}.toast.success{background:var(--success)}.toast.error{background:var(--danger)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--surface);border-radius:var(--radius);padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;position:relative}.modal-title{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.modal-close{position:absolute;top:14px;right:16px;font-size:20px;cursor:pointer;color:var(--muted);background:none;border:none;line-height:1}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:16px}.empty{text-align:center;padding:40px 20px;color:var(--muted)}.empty-icon{font-size:40px;margin-bottom:10px}.chip-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.chip{background:var(--info-bg);color:var(--info);border:1px solid #bfdbfe;border-radius:20px;padding:5px 12px;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.chip.sel{background:var(--navy);color:#fff;border-color:var(--navy)}.chip.dispatch{background:var(--warning-bg);color:var(--warning);border-color:#fde68a;font-weight:600}.chip.dispatch.sel{background:var(--warning);color:#fff}.chip.unassigned{background:#f1f5f9;color:var(--muted);border-color:var(--border)}.chip.unassigned.sel{background:var(--muted);color:#fff;border-color:var(--muted)}.section-label{font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.divider{border:none;border-top:1px solid var(--border);margin:14px 0}.manual-row{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap}.manual-row .form-row{flex:1;min-width:160px;margin-bottom:0}.history-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:12px}@media(max-width:600px){.main{padding:12px}.tabs{padding:0 8px}.tab{padding:10px 12px;font-size:12px}.card{padding:14px}.btn{padding:11px 14px;font-size:13px;min-height:42px}.btn-sm{padding:8px 10px;font-size:12px;min-height:34px}.form-grid{grid-template-columns:1fr}table{min-width:760px}.search-row{flex-direction:column}.search-row input,.search-row select{width:100%}thead th{font-size:10px;padding:8px}tbody td{padding:8px;font-size:12px}.header-sub{display:none}.header{padding:0 12px}}
