:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#eff6ff;--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-danger-light:#fef2f2;--color-success:#22c55e;--color-success-light:#f0fdf4;--color-warning:#f59e0b;--color-warning-light:#fffbeb;--color-bg:#f1f5f9;--color-surface:#fff;--color-border:#e2e8f0;--color-border-focus:#93c5fd;--color-text:#0f172a;--color-text-secondary:#64748b;--color-text-muted:#94a3b8;--table-row-hover:#0f172a09;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #00000024}body[data-theme=dark]{--color-primary:#60a5fa;--color-primary-hover:#3b82f6;--color-primary-light:#1e293b;--color-danger:#f87171;--color-danger-hover:#ef4444;--color-danger-light:#3f1d1d;--color-success:#34d399;--color-success-light:#10281d;--color-warning:#fbbf24;--color-warning-light:#2f2410;--color-bg:#0b1220;--color-surface:#111a2c;--color-border:#22314a;--color-border-focus:#60a5fa;--color-text:#e2e8f0;--color-text-secondary:#a8b6cb;--color-text-muted:#8292aa;--table-row-hover:#94a3b81a;--shadow-sm:0 1px 2px #00000059;--shadow-md:0 10px 24px #00000059;--shadow-lg:0 18px 40px #00000073}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.login-shell{background:radial-gradient(1200px 500px at 8% 0,#0e749024,#0000 60%),radial-gradient(800px 450px at 92% 100%,#2563eb1f,#0000 65%),linear-gradient(135deg,#f8fafc 0%,#eff6ff 40%,#ecfeff 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-wrap{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffd1;border:1px solid #94a3b838;border-radius:24px;grid-template-columns:1.1fr .9fr;width:100%;max-width:980px;display:grid;overflow:hidden;box-shadow:0 24px 60px #0f172a24}.login-info{background:linear-gradient(165deg,#0284c71a 0%,#2563eb08 55%,#0000 100%);padding:42px}.login-card{background:var(--color-surface);padding:38px 34px}.login-logo{color:#fff;background:linear-gradient(145deg,#0284c7 0%,#2563eb 100%);border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:16px;font-size:18px;font-weight:700;display:flex}.login-overline{letter-spacing:1.6px;color:#0369a1;margin-bottom:10px;font-size:11px;font-weight:700}.login-heading{letter-spacing:-.8px;margin-bottom:12px;font-size:32px;line-height:1.12}.login-copy{color:var(--color-text-secondary);max-width:40ch;margin-bottom:20px;font-size:14px}.login-points{flex-direction:column;gap:8px;list-style:none;display:flex}.login-points li{color:#0f172a;padding-left:16px;font-size:13px;position:relative}.login-points li:before{content:"";background:#0284c7;border-radius:50%;width:7px;height:7px;position:absolute;top:6px;left:0}.login-title{letter-spacing:-.5px;margin-bottom:4px;font-size:27px}.login-subtitle{color:var(--color-text-secondary);margin-bottom:20px;font-size:13px}.login-card-header{margin-bottom:8px}.login-form{flex-direction:column;gap:16px;display:flex}.login-input{border-radius:9px;min-height:42px}.login-btn{width:100%;min-height:42px;margin-top:8px}@media (width<=900px){.login-wrap{grid-template-columns:1fr;max-width:460px}.login-info{border-bottom:1px solid #94a3b840;padding:26px 26px 18px}.login-heading{font-size:26px}.login-card{padding:26px}}@media (width<=520px){.login-shell{padding:14px}.login-info,.login-card{padding:20px}.login-heading{font-size:22px}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:28px 32px}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);height:60px;box-shadow:var(--shadow-sm);z-index:100;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:10px;display:flex}.navbar-logo{justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.navbar-logo-img{width:100%;height:100%}.navbar-title{color:var(--color-text);letter-spacing:-.3px;font-size:16px;font-weight:700}.navbar-subtitle{color:var(--color-text-secondary);margin-top:1px;font-size:12px}.navbar-right{align-items:center;gap:12px;display:flex}.catalog-toggle{border:1px solid var(--color-border);background:var(--color-bg);border-radius:999px;align-items:center;gap:4px;padding:3px;display:inline-flex}.catalog-btn{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600;transition:all .15s}.catalog-btn:hover{color:var(--color-text)}.catalog-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #2563eb59}.nav-switch{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:inline-flex}.nav-switch input{opacity:0;pointer-events:none;position:absolute}.nav-switch-track{background:#cbd5e1;border:1px solid #94a3b8;border-radius:999px;width:38px;height:22px;transition:all .2s;position:relative}.nav-switch-thumb{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.nav-switch.active .nav-switch-track{background:#86efac;border-color:#22c55e}.nav-switch.active .nav-switch-thumb{transform:translate(16px)}.nav-switch-label{color:var(--color-text-secondary);font-size:12px;font-weight:600}.nav-switch.active .nav-switch-label{color:#166534}.theme-toggle-btn{width:36px;min-width:36px;height:36px;padding:0}.theme-toggle-icon{font-size:16px;line-height:1}.navbar-stat{color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);border-radius:20px;padding:4px 10px;font-size:13px}.navbar-stat strong{color:var(--color-primary);font-weight:600}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px;display:flex}.page-title{color:var(--color-text);letter-spacing:-.4px;font-size:22px;font-weight:700}.page-subtitle{color:var(--color-text-secondary);margin-top:2px;font-size:13px}.page-actions{align-items:center;gap:10px;display:inline-flex}.stock-metrics-grid{grid-template-columns:repeat(4,minmax(140px,1fr));gap:10px;margin-bottom:14px;display:grid}.stock-metric-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:10px 12px}.stock-metric-card.is-loading{opacity:.88}.stock-metric-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.stock-metric-value{color:var(--color-text);margin-top:4px;font-size:21px;font-weight:700}.bulk-action-bar{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:8px 10px;display:flex}.movement-panel{margin-top:14px}.movement-panel-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;font-size:13px;font-weight:700;display:flex}.movement-list{padding:8px 14px}.movement-item{border-bottom:1px solid var(--color-border);padding:8px 0}.movement-item:last-child{border-bottom:none}.movement-main{color:var(--color-text);font-size:13px}.movement-meta{color:var(--color-text-secondary);margin-top:2px;font-size:11px}.movement-empty{color:var(--color-text-secondary);padding:10px 0;font-size:12px}.movement-loading-state{justify-content:center;align-items:center;gap:10px;min-height:86px;display:flex}.inline-loading-pill{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:12px;font-weight:600;display:inline-flex}.inline-loading-pill.compact{font-size:11px}.inline-spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}.navbar-loading-stat{align-items:center;gap:8px;display:inline-flex}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;line-height:1;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb59}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg);border-color:#cbd5e1}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #0000;padding:6px 8px;font-size:15px;line-height:1;transition:all .15s}.btn-icon-edit{color:var(--color-primary)}.btn-icon-edit:hover{background:var(--color-primary-light);border-color:#bfdbfe}.btn-icon-delete{color:var(--color-danger)}.btn-icon-delete:hover{background:var(--color-danger-light);border-color:#fecaca}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:10px 22px;font-size:14px}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.search-wrapper{flex:1;max-width:380px;position:relative}.search-icon{color:var(--color-text-muted);pointer-events:none;font-size:15px;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;color:var(--color-text);padding:8px 12px 8px 34px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:var(--color-text-muted)}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.table-wrapper{border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:900px}thead tr{background:var(--color-bg);border-bottom:1px solid var(--color-border)}th{text-align:left;color:var(--color-text-secondary);letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;padding:11px 16px;font-size:11px;font-weight:600}td{color:var(--color-text);vertical-align:middle;border-bottom:1px solid var(--color-border);padding:13px 16px;font-size:13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--table-row-hover)}.table-img{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);width:48px;height:60px}.table-img-placeholder{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);width:48px;height:60px;color:var(--color-text-muted);justify-content:center;align-items:center;font-size:20px;display:flex}.product-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;max-width:240px;font-weight:600;overflow:hidden}.product-sku{color:var(--color-text-muted);margin-top:2px;font-family:Courier New,monospace;font-size:11px}.product-meta-line{color:var(--color-text-secondary);margin-top:2px;font-size:11px}.inline-link-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;margin-top:4px;padding:0;font-size:11px;font-weight:600}.inline-link-btn:hover{text-decoration:underline}.badge{letter-spacing:.3px;border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-live{background:var(--color-success-light);color:#15803d;border:1px solid #bbf7d0}.badge-live-icon{background:#16a34a;border-radius:50%;width:12px;height:12px;display:inline-block;box-shadow:0 0 0 3px #dcfce7}.badge-inactive{color:var(--color-text-secondary);border:1px solid var(--color-border);background:#f8fafc}.badge-warehouse-yes{background:var(--color-success-light);color:#15803d;border:1px solid #bbf7d0}.badge-warehouse-external{color:#334155;background:#f8fafc;border:1px solid #cbd5e1}.status-stack{flex-direction:column;display:inline-flex}.inline-toggle{border:1px solid var(--color-border);color:#334155;cursor:pointer;background:#f8fafc;border-radius:999px;align-items:center;gap:7px;min-height:26px;padding:2px 9px 2px 4px;font-size:11px;font-weight:700;transition:all .15s;display:inline-flex}.inline-toggle:hover:not(:disabled){border-color:#94a3b8}.inline-toggle:disabled{opacity:.55;cursor:not-allowed}.inline-toggle.active{background:var(--color-success-light);color:#166534;border-color:#86efac}.inline-toggle-knob{background:#94a3b8;border-radius:50%;width:16px;height:16px;box-shadow:inset 0 0 0 1px #0f172a14}.inline-toggle.active .inline-toggle-knob{background:#16a34a}.inline-toggle-label{line-height:1}.warehouse-toggle{justify-content:flex-start;min-width:132px}.warehouse-toggle .inline-toggle-label{align-items:center;gap:6px;display:inline-flex}.warehouse-note{color:var(--color-text-secondary);margin-top:4px;font-size:11px}.warehouse-icon{font-size:12px;line-height:1}.status-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.badge-warehouse-yes,.badge-warehouse-external{align-items:center;gap:6px}.status-subtext{margin-top:3px}.badge-warning{background:var(--color-warning-light);color:#92400e;border:1px solid #fde68a}.availability-badge{justify-content:center;min-width:34px}.availability-available{color:#047857;background:#ecfdf5;border:1px solid #a7f3d0}.availability-preorder{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.availability-backorder{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.availability-unavailable{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.availability-unknown{color:#334155;background:#f8fafc;border:1px solid #cbd5e1}.availability-text{color:var(--color-text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:160px;margin-top:4px;font-size:11px;overflow:hidden}.qty-primary,.price-text{color:var(--color-text);font-weight:600}.sale-price-text{color:var(--color-success);margin-top:2px;font-size:11px;font-weight:500}.actions-cell{align-items:center;gap:4px;display:flex}.pagination{border-top:1px solid var(--color-border);background:var(--color-surface);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.pagination-info{color:var(--color-text-secondary);font-size:12px}.pagination-controls{align-items:center;gap:4px;display:flex}.page-btn{border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--radius-sm);min-width:32px;height:32px;color:var(--color-text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:0 8px;font-family:inherit;font-size:12px;transition:all .15s;display:flex}.page-btn:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-border-focus);color:var(--color-primary)}.page-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600}.page-btn:disabled{opacity:.4;cursor:not-allowed}.empty-state{text-align:center;padding:72px 24px}.empty-icon{opacity:.4;margin-bottom:16px;font-size:48px}.empty-title{color:var(--color-text);margin-bottom:6px;font-size:16px;font-weight:600}.empty-subtitle{color:var(--color-text-secondary);font-size:13px}.loading-wrapper{flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:72px 24px;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--color-text-secondary);font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#0f172a80;justify-content:center;align-items:flex-start;padding:40px 20px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:800px;margin:auto;animation:.2s modal-in;position:relative}@keyframes modal-in{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{color:var(--color-text);font-size:17px;font-weight:700}.modal-close{background:var(--color-bg);border-radius:var(--radius-sm);cursor:pointer;width:30px;height:30px;color:var(--color-text-secondary);border:none;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.modal-close:hover{background:var(--color-danger-light);color:var(--color-danger)}.modal-tabs{border-bottom:1px solid var(--color-border);gap:2px;padding:12px 24px 0;display:flex;overflow-x:auto}.tab-btn{color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s}.tab-btn:hover{color:var(--color-primary)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.modal-body{max-height:60vh;padding:24px;overflow-y:auto}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-grid.cols-3{grid-template-columns:1fr 1fr 1fr}.form-group{flex-direction:column;gap:5px;display:flex}.form-group.full-width{grid-column:1/-1}label{color:var(--color-text-secondary);letter-spacing:.3px;text-transform:uppercase;font-size:12px;font-weight:600}.form-input,.form-select,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);background:var(--color-surface);width:100%;padding:8px 12px;font-family:inherit;font-size:13px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px}.form-checkbox-group{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);align-items:center;gap:8px;padding:9px 12px;display:flex}.form-checkbox-group input[type=checkbox]{cursor:pointer;width:15px;height:15px;accent-color:var(--color-primary)}.form-checkbox-group span{color:var(--color-text);font-size:13px}.form-hint{color:var(--color-text-muted);font-size:11px}.image-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.image-item{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);overflow:hidden}.image-item-header{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--color-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:8px 12px;font-size:11px;font-weight:600;display:flex}.image-item-header .badge-primary{background:var(--color-primary-light);color:var(--color-primary);border:1px solid #bfdbfe;border-radius:20px;padding:1px 7px;font-size:10px}.image-preview-wrapper{background:#f8fafc;justify-content:center;align-items:center;min-height:100px;padding:12px;display:flex}.image-preview{object-fit:contain;border-radius:4px;max-width:100%;max-height:120px}.image-placeholder{opacity:.3;font-size:36px}.image-input-wrapper{background:var(--color-surface);border-top:1px solid var(--color-border);padding:10px 12px}.image-input-wrapper input{padding:6px 10px;font-size:12px}.image-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.image-file-input{display:none}.section-divider{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin:20px 0 12px;font-size:11px;font-weight:700;display:flex}.section-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.modal-footer{border-top:1px solid var(--color-border);background:var(--color-bg);border-radius:0 0 var(--radius-lg) var(--radius-lg);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.delete-modal{max-width:420px}.delete-modal .modal-body{text-align:center;max-height:none;padding:28px 24px;overflow:visible}.delete-icon{background:var(--color-danger-light);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:26px;display:flex}.delete-title{color:var(--color-text);margin-bottom:8px;font-size:16px;font-weight:700}.delete-subtitle{color:var(--color-text-secondary);font-size:13px;line-height:1.6}.delete-product-name{color:var(--color-text);font-weight:600}.quick-qty-modal{max-width:460px}.quick-qty-copy{color:var(--color-text-secondary);margin-bottom:14px;font-size:13px}.quick-qty-title{color:var(--color-text);font-weight:600}.quick-qty-field{gap:8px}.bulk-stock-modal{max-width:500px}.bulk-stock-copy{color:var(--color-text-secondary);margin-bottom:14px;font-size:13px}.bulk-stock-field{gap:8px}.form-error{color:var(--color-danger);margin-top:8px;font-size:12px}.bulk-upload-modal{max-width:700px}.bulk-upload-mode-switch{border:1px solid var(--color-border);border-radius:var(--radius-md);background:linear-gradient(#2563eb0d,#2563eb05);justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 14px;display:flex}.bulk-upload-mode-title{color:var(--color-text);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:700}.bulk-upload-mode-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:12px}.bulk-upload-switch{flex-shrink:0}.bulk-upload-steps{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.bulk-upload-help{color:var(--color-text-secondary);font-size:12px}.bulk-upload-notes{border:1px solid var(--color-border);background:var(--color-bg);border-radius:var(--radius-sm);gap:7px;margin-bottom:14px;padding:12px;display:grid}.bulk-upload-notes-title{color:var(--color-text);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:700}.bulk-upload-note-item{color:var(--color-text-secondary);font-size:12px;line-height:1.45}.bulk-upload-note-item strong{color:var(--color-text)}.bulk-upload-result{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);gap:4px;margin-top:14px;padding:12px;font-size:13px;display:grid}.bulk-upload-errors{border-top:1px solid var(--color-border);color:var(--color-danger);gap:3px;margin-top:8px;padding-top:8px;font-size:12px;display:grid}.bulk-csv-viewer{border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-top:14px;overflow:hidden}.bulk-csv-viewer-header{background:var(--color-bg);border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;font-size:12px;font-weight:600;display:flex}.json-validation-badge{border:1px solid;border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700}.json-validation-badge.valid{color:#166534;background:#dcfce7;border-color:#86efac}.json-validation-badge.invalid{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.bulk-csv-table-wrap{max-height:320px;overflow:auto}.bulk-csv-toolbar{border-bottom:1px solid var(--color-border);background:var(--color-surface);justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.bulk-csv-count{color:var(--color-text-secondary);font-size:12px}.bulk-csv-search{max-width:280px;padding:7px 10px;font-size:12px}.bulk-csv-table{border-collapse:collapse;width:100%;min-width:900px}.bulk-csv-table thead th{z-index:2;background:var(--color-bg);position:sticky;top:0}.bulk-csv-table th,.bulk-csv-table td{border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);vertical-align:top;padding:8px}.bulk-csv-table tbody tr:nth-child(2n){background:#94a3b80f}.bulk-csv-table tbody tr:hover{background:#2563eb14}.bulk-csv-index-col{z-index:3;background:var(--color-surface);text-align:center;min-width:54px;color:var(--color-text-secondary);font-size:12px;font-weight:600;position:sticky;left:0}.bulk-csv-table thead .bulk-csv-index-col{background:var(--color-bg)}.bulk-csv-image-col{min-width:210px}.bulk-csv-required-tag{color:#166534;background:#dcfce7;border:1px solid #86efac;border-radius:999px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700}.bulk-csv-table th:last-child,.bulk-csv-table td:last-child{border-right:none}.bulk-csv-table tbody tr:last-child td{border-bottom:none}.bulk-csv-cell-input{min-width:140px;padding:6px 8px;font-size:12px}.bulk-csv-cell-input.invalid-json-cell{background:#fff1f2;border-color:#ef4444}.bulk-csv-image-cell{gap:7px;display:grid}.bulk-csv-image-preview{object-fit:cover;border:1px solid var(--color-border);background:var(--color-bg);border-radius:6px;width:52px;height:66px}.bulk-csv-image-placeholder{border:1px dashed var(--color-border);background:var(--color-bg);width:52px;height:66px;color:var(--color-text-muted);text-align:center;border-radius:6px;justify-content:center;align-items:center;padding:4px;font-size:10px;display:flex}.bulk-csv-image-actions{flex-wrap:wrap;gap:6px;display:flex}.bulk-csv-upload-btn{position:relative;overflow:hidden}.bulk-csv-file-input{opacity:0;cursor:pointer;position:absolute;inset:0}.bulk-csv-empty{border-top:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-surface);padding:10px 12px;font-size:12px}.formats-modal{max-width:980px}.formats-toolbar{padding:10px 24px 0}.formats-meta{color:var(--color-text-secondary);flex-wrap:wrap;gap:12px 20px;margin-bottom:14px;font-size:13px;display:flex}.formats-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.format-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);flex-direction:column;gap:6px;padding:10px;display:flex}.format-image-wrap{border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#f8fafc;justify-content:center;align-items:center;height:130px;display:flex}.format-image{object-fit:contain;max-width:100%;max-height:128px}.format-title{color:var(--color-text);min-height:36px;font-size:13px;font-weight:600;line-height:1.4}.format-sub{color:var(--color-text-secondary);font-size:12px}.format-price-row{justify-content:space-between;align-items:center;margin-top:4px;font-size:12px;font-weight:600;display:flex}.format-actions{gap:8px;margin-top:6px;display:flex}@media (width<=768px){.main-content{padding:16px}.navbar{padding:0 16px}.form-grid{grid-template-columns:1fr}.form-grid.cols-3{grid-template-columns:1fr 1fr}.page-header{flex-direction:column;align-items:flex-start}.stock-metrics-grid{grid-template-columns:1fr 1fr}.toolbar{flex-direction:column;align-items:stretch}.search-wrapper{max-width:100%}.modal-overlay{padding:16px}}@media (width<=480px){.form-grid.cols-3{grid-template-columns:1fr}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:.2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0, 0, var(--toastify-z-index));width:var(--toastify-toast-width);box-sizing:border-box;color:#fff;padding:4px;position:fixed}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right)}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right)}@media only screen and (width<=480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0;padding:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}}.Toastify__toast{--y:0;-ms-touch-action:none;touch-action:none;min-height:var(--toastify-toast-min-height);box-sizing:border-box;border-radius:var(--toastify-toast-bd-radius);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);cursor:default;z-index:0;direction:ltr;justify-content:space-between;margin-bottom:1rem;padding:8px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001a}.Toastify__toast--stacked{width:100%;transform:translate3d(0, var(--y), 0) scale(var(--s));transition:transform .3s;position:absolute}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";height:calc(var(--g) * 1px);position:absolute;bottom:100%;left:0;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";z-index:-1;height:100%;position:absolute;bottom:0;left:0;right:0;transform:scaleY(3)}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{flex:auto;align-items:center;margin:auto 0;padding:6px;display:flex}.Toastify__toast-body>div:last-child{word-break:break-word;flex:1}.Toastify__toast-icon{-webkit-margin-end:10px;flex-shrink:0;width:20px;margin-inline-end:10px;display:flex}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (width<=480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;cursor:pointer;opacity:.7;z-index:1;background:0 0;border:none;outline:none;align-self:flex-start;padding:0;transition:all .3s}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;width:14px;height:16px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{width:100%;height:100%;z-index:var(--toastify-z-index);opacity:.7;transform-origin:0;border-bottom-left-radius:var(--toastify-toast-bd-radius);position:absolute;bottom:0;left:0}.Toastify__progress-bar--animated{animation:linear forwards Toastify__trackProgress}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:100%;border-bottom-left-radius:initial;border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp{border-bottom-left-radius:var(--toastify-toast-bd-radius);width:100%;height:5px;position:absolute;bottom:0;left:0}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{box-sizing:border-box;border:2px solid;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);border-radius:100%;width:20px;height:20px;animation:.65s linear infinite Toastify__spin}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(3000px)}60%{opacity:1;transform:translate(-25px)}75%{transform:translate(10px)}90%{transform:translate(-5px)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px, var(--y), 0)}to{opacity:0;transform:translate3d(2000px, var(--y), 0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(-3000px)}60%{opacity:1;transform:translate(25px)}75%{transform:translate(-10px)}90%{transform:translate(5px)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px, var(--y), 0)}to{opacity:0;transform:translate3d(-2000px, var(--y), 0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(3000px)}60%{opacity:1;transform:translateY(-20px)}75%{transform:translateY(10px)}90%{transform:translateY(-5px)}to{transform:translate(0,0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(-2000px)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(-3000px)}60%{opacity:1;transform:translateY(25px)}75%{transform:translateY(-10px)}90%{transform:translateY(5px)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(2000px)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0, var(--y), 0) scale3d(.3, .3, .3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{opacity:0;animation-timing-function:ease-in;transform:perspective(400px)rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;transform:perspective(400px)rotateX(10deg)}80%{transform:perspective(400px)rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0, var(--y), 0) perspective(400px)}30%{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, -20deg);opacity:1}to{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, 90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{visibility:visible;transform:translate(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInLeft{0%{visibility:visible;transform:translate(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInUp{0%{visibility:visible;transform:translateY(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInDown{0%{visibility:visible;transform:translateY(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(110%, var(--y), 0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(-110%, var(--y), 0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(500px)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(-500px)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-duration:.3s;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
