:root{--bg-primary: #0f0f11;--bg-secondary: #18181b;--bg-tertiary: #232329;--bg-elevated: #2a2a32;--accent-primary: #f59e0b;--accent-secondary: #d97706;--accent-hover: #fbbf24;--accent-muted: rgba(245, 158, 11, .1);--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--text-muted: #52525b;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--border-color: rgba(255, 255, 255, .08);--border-hover: rgba(245, 158, 11, .3);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(245, 158, 11, .15);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--font-mono: "JetBrains Mono", monospace;--font-sans: "Noto Sans SC", -apple-system, BlinkMacSystemFont, sans-serif;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{min-height:100vh;height:100vh;display:flex;flex-direction:column;overflow:hidden}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--space-md) var(--space-xl);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-brand{display:flex;align-items:center;gap:var(--space-md)}.sidebar-toggle{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:var(--bg-tertiary);color:var(--accent-primary);border-color:var(--accent-primary)}.logo{color:var(--accent-primary);display:flex;align-items:center;justify-content:center}.title{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-meta{display:flex;align-items:center;gap:var(--space-md)}.badge{background:var(--accent-muted);color:var(--accent-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:var(--font-mono);border:1px solid rgba(245,158,11,.2)}.sidebar{position:fixed;top:0;left:0;width:840px;height:100vh;max-height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:200;transform:translate(-100%);transition:transform var(--transition-base);display:flex;flex-direction:column}.sidebar.open{transform:translate(0)}.sidebar-content{flex:1;overflow-y:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.sidebar-section{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.sidebar-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);background:linear-gradient(90deg,var(--bg-tertiary) 0%,var(--bg-elevated) 100%)}.sidebar-icon{color:var(--accent-primary);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--accent-muted);border-radius:var(--radius-md);border:1px solid rgba(245,158,11,.2)}.sidebar-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);flex:1}.sidebar-actions{display:flex;align-items:center;gap:var(--space-xs)}.sidebar-body{padding:var(--space-lg)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:150;opacity:0;visibility:hidden;transition:all var(--transition-base)}.sidebar-overlay.open{opacity:1;visibility:visible}.main{flex:1;display:grid;grid-template-columns:1fr 380px;gap:var(--space-xl);padding:var(--space-xl);max-width:1600px;margin:0 auto;width:100%;height:calc(100vh - 60px);overflow:hidden}.main.four-column{grid-template-columns:61.8% 38.2%;gap:var(--space-lg);max-width:100%;padding:var(--space-lg);height:calc(100vh - 60px);min-height:calc(100vh - 60px)}.sidebar.open~.main.four-column,.sidebar-overlay.open~.main.four-column{grid-template-columns:61.8% 38.2%}.column{display:flex;flex-direction:column;gap:var(--space-lg);min-width:0;height:100%;max-height:100%;overflow:hidden}.column-1{overflow-y:auto}.column-2{position:sticky;top:0;height:100%;max-height:100%}.column-3{display:none}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);display:flex;flex-direction:column;flex:1;min-height:0}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.card-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%)}.card-icon{color:var(--accent-primary);display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--accent-muted);border-radius:var(--radius-md);border:1px solid rgba(245,158,11,.2)}.card-icon.scan-icon{color:var(--success);background:#22c55e1a;border-color:#22c55e33}.card-icon.realtime-icon{color:var(--info);background:#3b82f61a;border-color:#3b82f633}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary);flex:1}.card-actions{display:flex;align-items:center;gap:var(--space-sm)}.card-body{padding:var(--space-lg);flex:1;overflow-y:auto;min-height:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 0 15px #f59e0b66}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--text-muted)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--text-muted)}.btn-scan{background:linear-gradient(135deg,var(--success) 0%,#16a34a 100%);color:#fff;border:none;font-weight:600}.btn-scan:hover:not(:disabled){background:linear-gradient(135deg,#22c55e,#22c55e);box-shadow:0 0 15px #22c55e66}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.8125rem}.btn-lg{padding:var(--space-md) var(--space-lg);font-size:.9375rem}.btn-block{width:100%}.input-group{display:flex;flex-direction:column;gap:var(--space-xs)}.input-label{display:flex;align-items:center;justify-content:space-between;font-size:.8125rem;color:var(--text-secondary)}.label-text{font-weight:500}.label-unit{color:var(--text-tertiary);font-family:var(--font-mono);font-size:.75rem}.input-field{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);color:var(--text-primary);font-family:var(--font-sans);font-size:.875rem;transition:all var(--transition-fast);width:100%}.input-field::placeholder{color:var(--text-muted)}.input-field:hover{border-color:var(--text-muted)}.input-field:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #f59e0b1a}.config-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table thead{background:var(--bg-elevated)}.data-table th{padding:var(--space-sm) var(--space-md);text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color);color:var(--text-primary)}.data-table tbody tr:hover{background:var(--bg-elevated)}.data-table tbody tr:last-child td{border-bottom:none}.data-table input{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);color:var(--text-primary);font-size:.875rem;width:100%;min-width:80px}.data-table input:focus{outline:none;border-color:var(--accent-primary)}.row-actions{display:flex;gap:var(--space-xs);align-items:center}.copy-row{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-color);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;transition:all var(--transition-fast)}.copy-row:hover{background:#22c55e1a;color:var(--success);border-color:var(--success)}.remove-row{background:transparent;color:var(--text-tertiary);border:1px solid var(--border-color);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;transition:all var(--transition-fast)}.remove-row:hover{background:#ef44441a;color:var(--error);border-color:var(--error)}.action-buttons{display:flex;gap:var(--space-md);flex-wrap:wrap}.results-card{flex:1;display:flex;flex-direction:column;min-height:0}.results-card .card-body{flex:1;overflow-y:auto;min-height:0}.scan-card{flex:0 0 30%;display:flex;flex-direction:column;min-height:0;max-height:30%}.scan-card .card-body{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:row;gap:var(--space-lg)}.realtime-card{flex:1;display:flex;flex-direction:column;min-height:0}.realtime-card .card-body{flex:1;overflow-y:auto;min-height:0}.results-container{min-height:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary);text-align:center;gap:var(--space-md)}.empty-state svg{color:var(--text-muted)}.pallet-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-md);transition:all var(--transition-base)}.pallet-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.pallet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color)}.pallet-title{font-weight:600;color:var(--accent-primary);font-family:var(--font-mono);font-size:1rem}.pallet-customer{color:var(--text-secondary);font-size:.8125rem}.pallet-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-md)}.stat-item{text-align:center;padding:var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm)}.stat-value{font-family:var(--font-mono);font-size:1.125rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-tertiary);margin-top:var(--space-xs)}.pallet-details-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.pallet-details-list{list-style:none}.detail-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);border:1px solid var(--border-color)}.detail-info{display:flex;align-items:center;gap:var(--space-sm)}.detail-mark{font-family:var(--font-mono);color:var(--accent-primary);font-size:.875rem}.detail-count{color:var(--text-tertiary);font-size:.8125rem}.detail-actions{display:flex;gap:var(--space-xs);flex-wrap:wrap;max-width:100%;min-width:0}.scan-button{background:var(--accent-muted);color:var(--accent-primary);border:1px solid rgba(245,158,11,.3);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all var(--transition-fast)}.scan-button:hover{background:var(--accent-primary);color:var(--bg-primary)}.scan-button.completed{background:#22c55e1a;color:var(--success);border:1px solid rgba(34,197,94,.3);cursor:pointer}.scan-button.completed:hover{background:var(--success);color:var(--bg-primary)}.scan-form{display:flex;flex-direction:column;gap:var(--space-md);flex:0 0 40%;min-width:0}.scan-results{min-height:0;flex:1;overflow-y:auto;min-width:0}.result-message{padding:var(--space-md);border-radius:var(--radius-md);border:1px solid;margin-bottom:var(--space-md)}.result-message.success{background:#22c55e1a;border-color:#22c55e4d;color:var(--success)}.result-message.error{background:#ef44441a;border-color:#ef44444d;color:var(--error)}.result-message.info{background:#3b82f61a;border-color:#3b82f64d;color:var(--info)}.status-indicator{display:flex;align-items:center;gap:var(--space-xs)}.status-dot{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:.75rem;color:var(--success);font-weight:500}.realtime-container{flex:1;overflow-y:auto;min-height:0}.realtime-pallet{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);transition:all var(--transition-base)}.realtime-pallet:hover{border-color:var(--info);box-shadow:0 0 15px #3b82f61a}.realtime-pallet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.realtime-pallet-title{font-family:var(--font-mono);font-weight:600;color:var(--info);font-size:.9375rem}.realtime-pallet-status{font-size:.75rem;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-weight:500}.realtime-pallet-status.in_use{background:#3b82f61a;color:var(--info)}.realtime-pallet-status.completed{background:#22c55e1a;color:var(--success)}.realtime-pallet-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-md)}.realtime-stat{display:flex;flex-direction:column;padding:var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm)}.realtime-stat-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.realtime-stat-value{font-family:var(--font-mono);font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-top:var(--space-xs)}.loaded-details{border-top:1px solid var(--border-color);padding-top:var(--space-md);margin-top:var(--space-md)}.loaded-details-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.loaded-details-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-xs)}.loaded-detail-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:.8125rem}.loaded-detail-mark{font-family:var(--font-mono);color:var(--text-secondary)}.loaded-detail-info{color:var(--text-tertiary);font-size:.75rem}.result-summary{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.summary-item{display:flex;align-items:center;gap:var(--space-sm)}.summary-label{color:var(--text-tertiary);font-size:.8125rem}.summary-value{font-family:var(--font-mono);font-size:1.125rem;font-weight:600;color:var(--accent-primary)}@media(max-width:1400px){.main.four-column{grid-template-columns:1fr 280px 280px}}@media(max-width:1200px){.main.four-column{grid-template-columns:1fr 1fr}.column-1{grid-column:1 / -1;max-height:none}.column-2,.column-3{position:static}}@media(max-width:1024px){.main{grid-template-columns:1fr}.sidebar{width:100%}}@media(max-width:768px){.main{padding:var(--space-md)}.main.four-column{grid-template-columns:1fr}.column-2,.column-3{grid-column:1 / -1}.config-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-lg{width:100%}.pallet-stats,.realtime-pallet-stats{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card,.pallet-card,.realtime-pallet{animation:fadeIn .3s ease-out}
