:root{--color-primary: #6366f1;--color-primary-hover: #818cf8;--color-primary-muted: rgba(99, 102, 241, .15);--color-bg: #0f1117;--color-surface: #1a1d2e;--color-surface-hover: #22263a;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-border: #2d3348;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--sidebar-width: 260px;--header-height: 64px;--transition-fast: .15s ease;--transition-base: .25s ease}[data-theme=light]{--color-primary: #4f46e5;--color-primary-hover: #6366f1;--color-primary-muted: rgba(79, 70, 229, .1);--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-hover: #f1f5f9;--color-text: #1e293b;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-success: #16a34a;--color-warning: #d97706;--color-danger: #dc2626;--color-info: #2563eb;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background-color .3s ease,color .3s ease}.sidebar,.card,.stat-card,.page-header,.data-table,input,select,textarea,button{transition:background-color .3s ease,border-color .3s ease,color .3s ease}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:20px 24px;border-bottom:1px solid var(--color-border)}.sidebar-logo{display:flex;align-items:center;gap:10px;font-size:1.25rem;font-weight:700;color:var(--color-text)}.sidebar-logo .logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),#a78bfa);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:.9rem;font-weight:500;transition:all var(--transition-fast);cursor:pointer}.nav-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-link.active{background:var(--color-primary-muted);color:var(--color-primary)}.nav-link .nav-icon{font-size:1.1rem;width:20px;text-align:center}.main-content{flex:1;margin-left:var(--sidebar-width)}.page-header{height:var(--header-height);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:var(--color-surface);position:sticky;top:0;z-index:50}.page-title{font-size:1.25rem;font-weight:600}.page-body{padding:32px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;transition:border-color var(--transition-fast)}.card:hover{border-color:var(--color-primary-muted)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;border:none;transition:all var(--transition-fast)}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.badge-success{background:#22c55e26;color:var(--color-success)}.badge-warning{background:#f59e0b26;color:var(--color-warning)}.badge-danger{background:#ef444426;color:var(--color-danger)}@media(max-width:768px){.sidebar{width:0;overflow:hidden}.main-content{margin-left:0}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:var(--color-text-muted)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);background-image:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(167,139,250,.06) 0%,transparent 50%)}.login-card{width:100%;max-width:420px;background:#1a1d2ecc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:32px}.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1.5rem;font-weight:700;margin-bottom:8px}.login-subtitle{color:var(--color-text-muted);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:20px}.login-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:var(--color-danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem}.login-btn{width:100%;padding:12px;font-size:1rem;background:linear-gradient(135deg,var(--color-primary),#8b5cf6);justify-content:center}.login-btn:hover{background:linear-gradient(135deg,var(--color-primary-hover),#a78bfa);transform:translateY(-1px)}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{margin-top:24px;text-align:center;color:var(--color-text-muted);font-size:.8rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:500;color:var(--color-text-muted)}.form-group input,.form-group select{padding:10px 14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.9rem;transition:border-color var(--transition-fast);outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.form-group input::placeholder{color:var(--color-text-muted);opacity:.5}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.sidebar-footer{padding:16px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:12px}.theme-toggle-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast);width:100%}.theme-toggle-btn:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-primary)}.theme-icon{font-size:1rem}.theme-label{font-weight:500}.sidebar-user-row{display:flex;align-items:center;justify-content:space-between}.user-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary),#a78bfa);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:#fff}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{font-size:.85rem;font-weight:600}.user-role .badge{font-size:.65rem;padding:2px 6px}.btn-text{background:none;border:none;color:var(--color-text-muted);font-size:.8rem;cursor:pointer;transition:color var(--transition-fast);padding:4px 8px}.btn-text:hover{color:var(--color-danger)}.logout-btn{font-size:.75rem}.main-header{padding:12px 32px;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.search-bar{position:relative;max-width:480px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:12px;font-size:.9rem;pointer-events:none}.search-input{width:100%;padding:8px 70px 8px 36px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.85rem;outline:none;transition:all var(--transition-fast)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#1a1d2ef2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden}.search-result{display:block;width:100%;padding:12px 16px;background:none;border:none;border-bottom:1px solid var(--color-border);color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.selected{background:var(--color-surface-hover)}.search-result-name{font-weight:500;font-size:.9rem}.search-result-meta{display:flex;gap:12px;margin-top:2px;font-size:.78rem;color:var(--color-text-muted)}.search-no-results{padding:16px;text-align:center;color:var(--color-text-muted);font-size:.85rem}.search-kbd{position:absolute;right:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:2px 6px;font-size:.7rem;color:var(--color-text-muted);font-family:monospace;pointer-events:none}.search-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh}.search-modal{width:560px;max-width:90vw;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;max-height:70vh;display:flex;flex-direction:column}.search-modal-header{display:flex;align-items:center;gap:10px;padding:16px;border-bottom:1px solid var(--color-border)}.search-modal-header .search-icon{position:static;font-size:1.1rem}.search-modal-input{flex:1;background:none;border:none;color:var(--color-text);font-size:1rem;outline:none}.search-modal-input::placeholder{color:var(--color-text-muted)}.search-modal-header .search-kbd{position:static;cursor:pointer;pointer-events:auto}.search-modal-hint{padding:24px;text-align:center;color:var(--color-text-muted)}.search-modal-hint p{margin-bottom:16px;font-size:.85rem}.search-shortcuts{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.search-shortcut{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8rem;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.search-shortcut:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-primary)}.search-modal-results{overflow-y:auto;padding:8px 0}.search-result-group{margin-bottom:4px}.search-result-group-label{padding:8px 16px 4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.search-modal-result{display:flex;align-items:center;gap:10px;padding:10px 16px;width:100%;background:none;border:none;color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.search-modal-result:hover,.search-modal-result.selected{background:var(--color-surface-hover)}.search-modal-result-icon{font-size:1.1rem;flex-shrink:0}.search-modal-result-info{flex:1;min-width:0}.search-modal-result-label{font-weight:500;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-modal-result-sublabel{font-size:.78rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-modal-result-arrow{color:var(--color-text-muted);font-size:.8rem;flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.search-modal-result:hover .search-modal-result-arrow,.search-modal-result.selected .search-modal-result-arrow{opacity:1}.search-modal-empty{padding:32px;text-align:center;color:var(--color-text-muted);font-size:.85rem}.welcome-card{margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat-card{display:flex;align-items:center;gap:16px}.stat-icon{width:48px;height:48px;background:var(--color-primary-muted);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{font-size:.8rem;color:var(--color-text-muted)}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:10px 12px;font-size:.78rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.data-table td{padding:12px;font-size:.875rem;border-bottom:1px solid var(--color-border)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-surface-hover)}.role-select{padding:4px 8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.8rem;cursor:pointer}.invite-form .form-group input,.invite-form .form-group select{padding:8px 12px;font-size:.85rem}.scanner-container{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.scanner-tabs{display:flex;background:var(--color-bg);border-bottom:1px solid var(--color-border)}.scanner-tab{flex:1;padding:10px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.scanner-tab:hover{color:var(--color-text);background:var(--color-surface-hover)}.scanner-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.scanner-content{padding:20px;min-height:200px;display:flex;align-items:center;justify-content:center}.camera-viewport{width:100%;max-width:400px;border-radius:var(--radius-sm);overflow:hidden}.usb-mode{text-align:center;padding:24px}.usb-icon-pulse{font-size:3rem;animation:pulse 2s ease-in-out infinite;margin-bottom:12px}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.manual-mode{width:100%;max-width:400px}.scan-result-flash{padding:12px 16px;background:#22c55e1f;border-top:1px solid rgba(34,197,94,.3);color:var(--color-success);font-size:.85rem;animation:flashIn .3s ease}@keyframes flashIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.scanner-error{text-align:center;padding:16px;color:var(--color-danger);font-size:.85rem}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:1.2rem}.modal-close{background:none;border:none;color:var(--color-text-muted);font-size:1.2rem;cursor:pointer;padding:4px}.ws-indicator{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;color:var(--color-text-muted)}.ws-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);animation:blink 2s ease infinite}.ws-dot.disconnected{background:var(--color-danger);animation:none}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.stock-flash{animation:highlightRow 1.5s ease}@keyframes highlightRow{0%{background:#22c55e33}to{background:transparent}}.progress-bar{height:6px;background:var(--color-bg);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:3px;transition:width var(--transition-base)}.filter-bar{display:flex;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.filter-bar input,.filter-bar select{padding:6px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.85rem;outline:none}.filter-bar input:focus,.filter-bar select:focus{border-color:var(--color-primary)}.filter-toggle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--color-text-muted);cursor:pointer}.filter-toggle input[type=checkbox]{accent-color:var(--color-primary)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:16px}.warehouse-cards{display:flex;flex-direction:column;gap:8px}.warehouse-card{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.warehouse-card-name{font-weight:600;font-size:.9rem}.warehouse-card-stats{display:flex;gap:12px;align-items:center;font-size:.8rem;color:var(--color-text-muted)}.urgency-critical{color:var(--color-danger)}.urgency-warning{color:var(--color-warning)}.urgency-watch{color:var(--color-text-muted)}.steps{display:flex;gap:4px;margin-bottom:24px}.step{flex:1;height:4px;background:var(--color-border);border-radius:2px}.step.active{background:var(--color-primary)}.step.done{background:var(--color-success)}.csv-preview{max-height:300px;overflow-y:auto;margin:16px 0}.csv-preview table{width:100%;font-size:.8rem}.file-input-wrapper{display:flex;align-items:center;gap:12px;padding:16px;border:2px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast)}.file-input-wrapper:hover{border-color:var(--color-primary)}.file-input-wrapper input[type=file]{display:none}.count-input{width:80px;padding:6px 8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:.9rem;text-align:center;outline:none}.count-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-muted)}.variance-positive{color:var(--color-success)}.variance-negative{color:var(--color-danger)}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--color-text-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.demo-btn{width:100%;padding:10px;background:linear-gradient(135deg,#6366f126,#a855f726);border:1px solid var(--color-primary);color:var(--color-text);border-radius:var(--radius-md);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.demo-btn:hover{background:linear-gradient(135deg,#6366f14d,#a855f74d);transform:translateY(-1px)}.demo-hint{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-top:8px}.demo-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:6px 12px;background:linear-gradient(90deg,#6366f126,#a855f726);border-bottom:1px solid var(--color-primary);font-size:.8rem;color:var(--color-primary-hover)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
