*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--crimson: #991b1b;--crimson-bg: #fef2f2;--crimson-border: #f87171;--red: #dc2626;--red-bg: #fef2f2;--red-border: #fca5a5;--red-light: #fee2e2;--orange: #ea580c;--orange-bg: #fff7ed;--orange-border: #fdba74;--orange-light: #ffedd5;--yellow: #d97706;--yellow-bg: #fffbeb;--yellow-border: #fcd34d;--yellow-light: #fef3c7;--green: #16a34a;--green-bg: #f0fdf4;--green-border: #86efac;--green-light: #dcfce7;--dark: #374151;--dark-bg: #f9fafb;--dark-border: #9ca3af;--blue: #2563eb;--blue-bg: #eff6ff;--blue-border: #93c5fd;--nav: #0f172a;--nav-sub: #94a3b8;--surface: #f8fafc;--border: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--white: #ffffff;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -1px rgba(0,0,0,.05)}html{font-size:15px}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--surface);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{background:var(--nav);padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #0000004d}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-avatar{width:38px;height:38px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;letter-spacing:.5px;flex-shrink:0}.topbar-company{font-weight:700;font-size:15px;color:#fff;letter-spacing:.3px}.topbar-sub{font-size:11px;color:var(--nav-sub);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}.urgency-pill{background:#dc262633;border:1px solid rgba(220,38,38,.4);color:#fca5a5;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:600;white-space:nowrap}.pill-expired-header{background:#991b1b59;border-color:#991b1b99;color:#fecaca;animation:pulse 1.8s infinite}.sync-label{font-size:12px;color:var(--nav-sub);display:flex;align-items:center;gap:6px;white-space:nowrap}.sync-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e4d;display:inline-block;flex-shrink:0}.main{flex:1;padding:24px;max-width:1400px;width:100%;margin:0 auto}.cards-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:24px}.card{background:#fff;border-radius:var(--radius);padding:18px 16px;display:flex;align-items:flex-start;gap:12px;box-shadow:var(--shadow);border-left:4px solid transparent;position:relative;overflow:hidden;transition:box-shadow .15s}.card:hover{box-shadow:var(--shadow-md)}.card-alert-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 3px #dc262633;animation:pulse 1.8s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #dc262633}50%{box-shadow:0 0 0 6px #dc262614}}.card-icon{font-size:22px;line-height:1;flex-shrink:0;margin-top:2px}.card-info{min-width:0}.card-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.card-count{font-size:26px;font-weight:700;line-height:1}.card-qty{font-size:12px;color:var(--text-muted);margin-top:3px}.card-action-hint{font-size:10px;color:var(--text-muted);margin-top:5px;font-style:italic}.card-crimson{border-left-color:var(--crimson);background:#fff1f2}.card-crimson .card-count{color:var(--crimson)}.card-red{border-left-color:var(--red);background:var(--red-bg)}.card-red .card-count{color:var(--red)}.card-orange{border-left-color:var(--orange);background:var(--orange-bg)}.card-orange .card-count{color:var(--orange)}.card-yellow{border-left-color:var(--yellow);background:var(--yellow-bg)}.card-yellow .card-count{color:var(--yellow)}.card-green{border-left-color:var(--green);background:var(--green-bg)}.card-green .card-count{color:var(--green)}.card-dark{border-left-color:var(--dark);background:var(--dark-bg)}.card-dark .card-count{color:var(--dark)}.card-blue{border-left-color:var(--blue);background:var(--blue-bg)}.card-blue .card-count{color:var(--blue)}.section{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:24px;overflow:hidden}.section-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.wrap-header{flex-wrap:wrap;gap:12px}.section-title{font-size:15px;font-weight:700;flex:1}.urgent-title{color:var(--red)}.count-badge{padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600;background:var(--dark-bg);color:var(--text-muted);white-space:nowrap}.red-badge{background:var(--red-light);color:var(--red)}.table-controls{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.search-input{padding:7px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;width:220px;outline:none;transition:border-color .15s,box-shadow .15s;background:var(--surface)}.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1a}.filter-group{display:flex;gap:4px}.filter-btn{padding:6px 12px;border:1px solid var(--border);border-radius:6px;font-size:12px;font-weight:500;background:#fff;color:var(--text-muted);cursor:pointer;transition:all .15s;white-space:nowrap}.filter-btn:hover{border-color:#cbd5e1;color:var(--text);background:var(--surface)}.filter-btn.active{background:var(--nav);color:#fff;border-color:var(--nav)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table thead tr{background:#f8fafc}.data-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table th.num-col,.data-table td.num-col{text-align:right}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr.main-row:hover{background:#f8fafc}.data-table tbody tr.clickable{cursor:pointer}.data-table td{padding:10px 14px;vertical-align:middle}.td-product{font-weight:500;max-width:260px}.td-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px;color:var(--text-muted)}.num-col{text-align:right;font-variant-numeric:tabular-nums}.fw-600{font-weight:600}.tr-expired{background:#fee2e2!important}.tr-critical{background:#fecaca!important}.tr-red{background:#fff1f2!important}.tr-orange{background:#fff3e0!important}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-size:11px;font-weight:800;background:#e5e7eb;color:#374151}.tr-expired .rank-badge,.tr-critical .rank-badge{background:#991b1b;color:#fff}.tr-red .rank-badge{background:var(--red);color:#fff}.tr-orange .rank-badge{background:var(--orange);color:#fff}.product-name{font-weight:500}.expiry-hint{font-size:11px;margin-top:2px;font-weight:500}.hint-expired{color:#991b1b}.hint-red{color:var(--red)}.hint-orange{color:var(--orange)}.hint-yellow{color:var(--yellow)}.action-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:5px;font-size:12px;font-weight:700;letter-spacing:.2px;white-space:nowrap}.action-sm{font-size:11px;padding:3px 8px}.action-remove{background:#7f1d1d;color:#fff}.action-return{background:#991b1b;color:#fff}.action-sell-now{background:var(--red);color:#fff}.action-push{background:var(--orange);color:#fff}.action-safe{background:var(--green-light);color:var(--green);border:1px solid var(--green-border);font-weight:600}.crimson-badge{background:#fecaca;color:#991b1b}.val-red{color:var(--red);font-weight:600}.val-orange{color:var(--orange);font-weight:600}.val-yellow{color:var(--yellow);font-weight:600}.val-green{color:var(--green);font-weight:600}.val-dark{color:var(--dark);font-weight:600}.col-red{color:var(--red)!important}.col-orange{color:var(--orange)!important}.col-yellow{color:var(--yellow)!important}.col-green{color:var(--green)!important}.col-dark{color:var(--dark)!important}.expand-cell{width:36px;padding:10px 8px 10px 14px;color:var(--text-muted)}.chevron{font-size:12px;display:inline-block;transition:transform .15s}.expand-row>td{padding:0}.expand-cell-wrap{padding:0!important}.batch-panel{background:#f8fafc;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.batch-panel-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:10px 20px 6px}.inner-table-wrap{padding:0 8px 12px}.batch-table{width:100%;border-collapse:collapse;font-size:12px}.batch-table th{padding:8px 12px;text-align:left;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:#fff}.batch-table th.num-col{text-align:right}.batch-table td{padding:8px 12px;border-bottom:1px solid #f1f5f9}.batch-table tr:last-child td{border-bottom:none}.pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.pill-expired{background:#7f1d1d;color:#fff}.pill-red{background:var(--red-light);color:var(--red);border:1px solid var(--red-border)}.pill-orange{background:var(--orange-light);color:var(--orange);border:1px solid var(--orange-border)}.pill-yellow{background:var(--yellow-light);color:var(--yellow);border:1px solid var(--yellow-border)}.pill-green{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}.pill-unknown{background:var(--dark-bg);color:var(--dark);border:1px solid var(--dark-border)}.table-footer{padding:10px 20px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--border);background:#fafafa}.empty-cell{text-align:center;padding:40px!important;color:var(--text-muted);font-size:13px}.screen-center{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px;background:var(--surface)}.error-icon{font-size:48px}.screen-msg{font-size:18px;font-weight:600;color:var(--text)}.screen-sub{font-size:13px;color:var(--text-muted)}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.retry-btn{margin-top:8px;padding:8px 20px;background:var(--blue);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.retry-btn:hover{background:#1d4ed8}.user-chip{display:flex;align-items:center;gap:7px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:99px;padding:4px 10px 4px 4px}.user-avatar{width:24px;height:24px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.user-name{font-size:12px;color:#e2e8f0;font-weight:500}.logout-btn{background:none;border:none;color:#94a3b8;font-size:14px;cursor:pointer;padding:0 2px;line-height:1;transition:color .15s}.logout-btn:hover{color:#f87171}.login-bg{min-height:100vh;background:#f0f4f8;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:44px 40px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.shake{animation:shake .4s ease}.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:32px}.login-avatar{width:48px;height:48px;background:var(--blue);border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0}.login-company{font-weight:700;font-size:15px;color:var(--text);letter-spacing:.3px}.login-tagline{font-size:11px;color:var(--text-muted);margin-top:2px}.login-heading{font-size:20px;font-weight:700;color:var(--text);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.login-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:11px 14px;font-size:14px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.login-input::placeholder{color:#cbd5e1}.login-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f;background:#fff}.login-error{background:#fef2f2;border:1px solid #fecaca;color:var(--red);border-radius:7px;padding:9px 13px;font-size:13px;font-weight:500}.login-btn{background:var(--blue);color:#fff;border:none;border-radius:8px;padding:13px;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.3px;transition:background .15s,transform .1s;margin-top:4px;font-family:inherit}.login-btn:hover:not(:disabled){background:#1d4ed8}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.changes-section{margin-bottom:20px}.changes-banner{width:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:11px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;font-size:13px;font-family:inherit;text-align:left;box-shadow:var(--shadow);transition:border-color .15s}.changes-banner:hover{border-color:#cbd5e1}.changes-clean{cursor:default;color:var(--green);font-weight:500;justify-content:flex-start}.changes-clean:hover{border-color:var(--border)}.changes-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.changes-chevron{font-size:12px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.chg-pill{padding:2px 9px;border-radius:99px;font-size:11px;font-weight:700}.chg-new{background:#dcfce7;color:#15803d}.chg-removed{background:#f1f5f9;color:#475569}.chg-changed{background:#eff6ff;color:#2563eb}.chg-warn{background:#fee2e2;color:#dc2626}.changes-body{background:#fff;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);overflow:hidden}.chg-group{border-bottom:1px solid var(--border)}.chg-group:last-child{border-bottom:none}.chg-group-title{padding:8px 18px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.chg-group-warn{background:#fff1f2;color:#991b1b}.chg-group-ok{background:#f0fdf4;color:#15803d}.chg-group-new{background:#eff6ff;color:#2563eb}.chg-group-removed{background:#f8fafc;color:#475569}.chg-row{display:flex;align-items:baseline;gap:12px;padding:7px 18px;border-top:1px solid #f1f5f9;font-size:13px}.chg-row:first-of-type{border-top:none}.chg-name{font-weight:500;min-width:220px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px}.chg-fields{display:flex;gap:10px;flex-wrap:wrap}.chg-field{font-size:12px;padding:2px 8px;border-radius:4px;white-space:nowrap}.chg-field em{font-style:normal;font-weight:700;margin-left:2px}.chg-worse{background:#fee2e2;color:#991b1b}.chg-worse em{color:#dc2626}.chg-warn-field{background:#fff3e0;color:#c2410c}.chg-better{background:#dcfce7;color:#15803d}.chg-better em{color:#16a34a}.chg-neutral{background:#f1f5f9;color:#475569}@media (max-width: 1200px){.cards-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.topbar{height:auto;padding:12px 16px;flex-wrap:wrap}.topbar-right{width:100%;justify-content:flex-start}.urgency-pill{font-size:11px}.main{padding:12px}.cards-grid{grid-template-columns:repeat(2,1fr);gap:10px}.card{padding:14px 12px}.card-count{font-size:22px}.section-header{padding:12px 14px;flex-direction:column;align-items:flex-start}.table-controls,.search-input{width:100%}.filter-group{flex-wrap:wrap}.td-product{max-width:140px;word-break:break-word}}@media (max-width: 480px){.cards-grid{grid-template-columns:1fr 1fr}.topbar-company{font-size:13px}}
