:root{--bg-primary:#e3f2fd;--bg-secondary:#fff;--bg-card:#fff;--bg-card-hover:#fff;--bg-input:#fff;--bg-nav:#fff;--bg-table-header:#f8fbff;--bg-table-row-hover:#fce4ec;--bg-table-stripe:#fcfdfe;--text-primary:#444;--text-secondary:#666;--text-muted:#94a3b8;--text-label:#555;--text-heading:#4a76c0;--accent-primary:#ad1457;--accent-primary-hover:#880e4f;--accent-light:#fce4ec;--accent-gradient:linear-gradient(135deg, #4a76c0, #63a4ff);--success:#059669;--success-light:#d1fae5;--success-dark:#065f46;--warning:#ad1457;--warning-light:#fce4ec;--danger:#ad1457;--danger-light:#fce4ec;--info:#4a76c0;--info-light:#e3f2fd;--border-color:#dee2e6;--border-focus:#4a76c0;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:8px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 2px 8px #00000014;--shadow-lg:0 4px 16px #0000001a;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.75rem;--font-sm:.85rem;--font-md:1rem;--font-lg:1.25rem;--font-xl:1.5rem;--font-2xl:1.75rem;--transition-fast:.15s ease;--transition-normal:.25s ease;--nav-height:56px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5}#app{min-height:100vh;padding-top:var(--nav-height)}#page-content{width:100%;max-width:1600px;padding:var(--space-lg) var(--space-md);margin:0 auto;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes fadeOut{to{opacity:0;transform:translate(-50%)translateY(-20px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}#bottom-nav{height:var(--nav-height);background:var(--bg-nav);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:var(--space-xs);padding:0 var(--space-md);z-index:100;display:flex;position:fixed;top:0;left:0;right:0}.nav-item{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;flex-direction:row;justify-content:center;align-items:center;gap:8px;min-width:100px;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex;position:relative}.nav-item:hover{background:var(--bg-primary);color:var(--accent-primary)}.nav-item.active{color:var(--accent-primary);background:var(--accent-light);font-weight:600}.nav-icon{font-size:1.1rem;line-height:1}.nav-item .nav-badge{background:var(--accent-primary);color:#fff;border:2px solid var(--bg-nav);border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:9px;font-weight:700;display:flex;position:absolute;top:4px;right:4px}h1,h2,h3,h4,h5,h6{color:var(--text-heading);letter-spacing:-.025em;font-weight:700}h1{font-size:var(--font-2xl)}h2{font-size:var(--font-xl);color:var(--text-primary);font-weight:600}h3{font-size:var(--font-lg);font-weight:600}.page-header{margin-bottom:var(--space-lg)}.page-header h1{margin-bottom:2px}.page-header p{color:var(--text-secondary);font-size:var(--font-sm)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.card-compact{padding:var(--space-md)}.btn{border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{color:#ad1457;background:#fce4ec;border:none;font-weight:600;box-shadow:0 2px 4px #ad14571a}.btn-primary:hover{color:#ad1457;background:#f8bbd0;transform:translateY(-1px);box-shadow:0 4px 8px #ad145726}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-light)}.btn-gray{color:#475569;background:#f1f5f9;border:1px solid #e2e8f0}.btn-gray:hover{color:#1e293b;background:#e2e8f0}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#047857}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{color:var(--text-secondary);background:0 0;padding:8px 12px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-input)}.btn-icon{border-radius:var(--radius-md);width:38px;height:38px;padding:0;font-size:1rem}.btn-full{width:100%}.btn-sm{font-size:var(--font-xs);padding:6px 12px}.form-group{margin-bottom:var(--space-md)}.form-label{font-size:var(--font-sm);color:var(--text-label);margin-bottom:var(--space-xs);font-weight:500;display:block}.form-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-md);transition:all var(--transition-fast);outline:none;padding:10px 14px}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #4f46e51a}.form-input::placeholder{color:var(--text-muted)}.input-with-btn{gap:var(--space-sm);display:flex}.input-with-btn .form-input{flex:1}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%235f6673' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.badge{font-size:var(--font-xs);white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.data-table-wrapper{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.data-table-toolbar{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--border-color);flex-wrap:wrap;display:flex}.data-table-toolbar .form-input{flex:1;max-width:50%}.data-table-toolbar .toolbar-right{gap:var(--space-sm);margin-left:auto;display:flex}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-sm)}.data-table thead th{text-align:left;color:var(--text-secondary);font-weight:600;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-table-header);border-bottom:1px solid var(--border-color);white-space:nowrap;-webkit-user-select:none;user-select:none;padding:10px 14px}.data-table tbody td{border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle;padding:10px 14px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:nth-child(2n){background:var(--bg-table-stripe)}.data-table tbody tr:hover{background:var(--bg-table-row-hover)}.row-clickable{cursor:pointer}.row-clickable:hover{background:var(--bg-table-row-hover)}.data-table .col-actions{text-align:right;white-space:nowrap}.form-input-sm{font-size:var(--font-xs);padding:4px 8px}.data-table .col-stock{text-align:center;font-weight:700}.data-table .col-price{white-space:nowrap}.data-table .col-unit{text-align:center}.data-table .product-name-cell{font-weight:600}.data-table .product-barcode-cell{font-size:var(--font-xs);color:var(--text-muted);font-family:SF Mono,Consolas,monospace}.table-actions-group{gap:4px;display:inline-flex}.data-table-scroll{overflow-x:auto}.stats-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.stat-card{background:var(--bg-card);padding:var(--space-lg);border-radius:var(--radius-lg);align-items:center;gap:var(--space-md);border:1px solid #00000005;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 4px 12px #00000008}.stat-card:hover{border-color:var(--accent-light);transform:translateY(-4px);box-shadow:0 12px 24px #0000000f}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.stat-icon.icon-products{background:var(--info-light)}.stat-icon.icon-low{background:var(--warning-light)}.stat-icon.icon-value{background:var(--success-light)}.stat-icon.icon-movements{background:var(--accent-light)}.stat-icon.icon-expiring{background:var(--warning-light)}.stat-card-clickable{cursor:pointer;transition:all var(--transition-fast)}.stat-card-clickable:hover{border-color:var(--warning);box-shadow:var(--shadow-md)}.nav-scanner-icon{object-fit:contain;width:22px;height:22px}.stat-info{flex:1}.stat-value{font-size:var(--font-xl);color:var(--text-primary);font-weight:800;line-height:1.2}.stat-label{font-size:var(--font-xs);color:var(--text-secondary)}.alert-banner{background:var(--warning-light);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);border:1px solid #d9770640;display:flex}.alert-banner-icon{font-size:1.2rem}.alert-banner-text{font-size:var(--font-sm);color:var(--warning);font-weight:500}.movement-item{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color);display:flex}.movement-item:last-child{border-bottom:none}.movement-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.movement-icon.entry{background:var(--success-light)}.movement-icon.exit{background:var(--danger-light)}.movement-details{flex:1;min-width:0}.movement-product{font-weight:600;font-size:var(--font-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.movement-meta{font-size:var(--font-xs);color:var(--text-muted)}.movement-qty{font-weight:700;font-size:var(--font-sm);white-space:nowrap}.movement-qty.entry{color:var(--success)}.movement-qty.exit{color:var(--danger)}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;background:#00000059;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-lg);width:90%;max-width:540px;max-height:80vh;padding:var(--space-lg);box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.modal-header h2{font-size:var(--font-lg)}.modal-close{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-primary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;font-size:1rem;display:flex}.modal-close:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.toast{border-radius:var(--radius-md);font-size:var(--font-sm);z-index:300;align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-lg);max-width:90vw;padding:10px 20px;font-weight:500;animation:.3s slideDown,.3s 2.7s forwards fadeOut;display:flex;position:fixed;top:68px;left:50%;transform:translate(-50%)}.toast-success{background:var(--success);color:#fff}.toast-danger{background:var(--danger);color:#fff}.toast-warning{background:var(--warning);color:#fff}.toast-info{background:var(--info);color:#fff}.table-wrapper{border-radius:var(--radius-md);overflow-x:auto}table:not(.data-table){border-collapse:collapse;width:100%;font-size:var(--font-sm)}table:not(.data-table) thead th{text-align:left;color:var(--text-secondary);font-weight:600;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-table-header);border-bottom:1px solid var(--border-color);padding:8px 12px}table:not(.data-table) tbody td{border-bottom:1px solid var(--border-color);padding:8px 12px}.confirm-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:250;background:#00000059;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.confirm-box{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;width:90%;max-width:360px;box-shadow:var(--shadow-lg)}.confirm-box h3{margin-bottom:var(--space-sm)}.confirm-box p{color:var(--text-secondary);font-size:var(--font-sm);margin-bottom:var(--space-lg)}.confirm-actions{gap:var(--space-sm);display:flex}.confirm-actions .btn{flex:1}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--text-muted)}.btn-lg{font-size:var(--font-md);padding:10px 24px}.empty-state-icon{margin-bottom:var(--space-md);opacity:.4;font-size:2.5rem}.empty-state-text{font-size:var(--font-md);margin-bottom:var(--space-lg);color:var(--text-secondary)}.scanner-ready-card{padding:var(--space-md) var(--space-lg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff}.scanner-horizontal-layout{align-items:center;gap:var(--space-lg);width:100%;display:flex}.scanner-ready-status{text-align:left;flex:1}.scanner-ready-status h3{color:var(--text-primary);font-size:var(--font-md);margin:0}.scanner-ready-status p{color:var(--text-secondary);font-size:var(--font-sm)}.scanner-icon-pulse{border:1px solid var(--accent-light);width:60px;height:60px;box-shadow:var(--shadow-md);background:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.scanner-icon-pulse:after{content:"";border:2px solid var(--accent-primary);opacity:0;border-radius:50%;animation:2s infinite pulseScale;position:absolute;inset:-8px}@keyframes pulseScale{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.4)}}.scanner-input-group{flex:2;max-width:400px}.scanner-input-wrapper{width:100%}.form-input-lg{font-size:var(--font-lg);text-align:center;letter-spacing:.05em;padding:14px 20px;font-weight:600}.section-title{font-size:var(--font-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-md);font-weight:600}.divider{background:var(--border-color);height:1px;margin:var(--space-lg) 0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.text-center{text-align:center}.text-sm{font-size:var(--font-sm)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-bold{font-weight:700}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (width<=640px){.stats-grid{grid-template-columns:repeat(2,1fr)}.data-table-toolbar{flex-direction:column;align-items:stretch}.data-table-toolbar .form-input{max-width:none}.data-table-toolbar .toolbar-right{margin-left:0}}.login-container{min-height:calc(100vh - var(--nav-height) - var(--space-lg) * 2);padding:var(--space-md);justify-content:center;align-items:center;display:flex}.login-card{text-align:center;border-radius:var(--radius-xl);width:100%;max-width:480px;box-shadow:var(--shadow-lg);background:var(--bg-card);padding:64px 48px}.login-header{margin-top:var(--space-md);margin-bottom:var(--space-xl)}.login-logo{margin-bottom:var(--space-xl);justify-content:center;align-items:center;display:flex}.login-header h1{font-size:var(--font-2xl);margin-bottom:var(--space-xs)}.login-header p{color:var(--text-secondary);font-size:var(--font-sm)}.login-footer{margin-top:var(--space-2xl);border-top:1px solid var(--border-color);padding-top:var(--space-lg);padding-bottom:var(--space-md)}
