*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-body: #f4f6fb;--bg-white: #ffffff;--bg-surface: #f8f9fc;--bg-hover: #f0f2f8;--primary: #4f46e5;--primary-light: #ede9fe;--primary-dark: #3730a3;--success: #059669;--success-light: #ecfdf5;--warning: #d97706;--warning-light: #fefce8;--danger: #dc2626;--danger-light: #fef2f2;--info: #0891b2;--info-light: #ecfeff;--text-dark: #1e1b4b;--text-body: #374151;--text-muted: #9ca3af;--text-subtle: #6b7280;--border: #e5e7eb;--border-light: #f3f4f6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .03);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .08);--shadow-colored: 0 4px 14px rgba(79, 70, 229, .12);--radius: 20px;--radius-md: 14px;--radius-sm: 10px;--radius-xs: 8px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}body{font-family:var(--font);background:var(--bg-body);color:var(--text-body);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{max-width:1380px;margin:0 auto;padding:28px 36px 48px}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px}.header-left{display:flex;align-items:center;gap:14px}.header-logo{width:50px;height:50px;border-radius:16px;background:linear-gradient(135deg,#4f46e5,#7c3aed,#a78bfa);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;box-shadow:0 6px 20px #4f46e54d;letter-spacing:-.5px}.header-title{font-size:24px;font-weight:700;color:var(--text-dark);letter-spacing:-.3px}.header-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px;font-weight:400}.header-right{display:flex;align-items:center;gap:12px}.header-date{font-size:13px;color:var(--text-subtle);font-weight:500;padding:8px 16px;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-xs)}.header-badge{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border-radius:50px;background:var(--success-light);color:var(--success);font-size:12px;font-weight:600;letter-spacing:.2px}.header-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:breathe 2.5s ease-in-out infinite}@keyframes breathe{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}.stat-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;position:relative;overflow:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:default}.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.stat-card-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px}.stat-card.purple .stat-card-icon{background:var(--primary-light)}.stat-card.green .stat-card-icon{background:var(--success-light)}.stat-card.amber .stat-card-icon{background:var(--warning-light)}.stat-card.cyan .stat-card-icon{background:var(--info-light)}.stat-card-trend{font-size:11px;font-weight:600;padding:3px 8px;border-radius:6px;background:var(--success-light);color:var(--success)}.stat-card-value{font-size:34px;font-weight:800;color:var(--text-dark);line-height:1;margin-bottom:6px;letter-spacing:-1px}.stat-card-label{font-size:13px;font-weight:500;color:var(--text-muted)}.stat-card-bar{position:absolute;bottom:0;left:0;right:0;height:3px}.stat-card.purple .stat-card-bar{background:linear-gradient(90deg,#4f46e5,#a78bfa)}.stat-card.green .stat-card-bar{background:linear-gradient(90deg,#059669,#34d399)}.stat-card.amber .stat-card-bar{background:linear-gradient(90deg,#d97706,#fbbf24)}.stat-card.cyan .stat-card-bar{background:linear-gradient(90deg,#0891b2,#22d3ee)}.filters{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap;align-items:center}.filters-label{font-size:13px;font-weight:600;color:var(--text-subtle);margin-right:6px}.filter-select{padding:9px 32px 9px 14px;border-radius:var(--radius-xs);border:1px solid var(--border);background:var(--bg-white);color:var(--text-body);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.filter-select:hover{border-color:var(--primary)}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.charts-grid{display:grid;grid-template-columns:3fr 2fr;gap:18px;margin-bottom:22px}.chart-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;transition:box-shadow .25s ease}.chart-card:hover{box-shadow:var(--shadow-md)}.chart-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}.chart-card-title{font-size:15px;font-weight:700;color:var(--text-dark);display:flex;align-items:center;gap:8px}.chart-card-title .icon{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-size:14px}.chart-card-title .icon.purple{background:var(--primary-light)}.chart-card-title .icon.cyan{background:var(--info-light)}.chart-card-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px;font-weight:400}.table-card{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;overflow:hidden;transition:box-shadow .25s ease}.table-card:hover{box-shadow:var(--shadow-md)}.table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.table-header h3{font-size:15px;font-weight:700;color:var(--text-dark);display:flex;align-items:center;gap:8px}.table-header h3 .icon{width:28px;height:28px;border-radius:8px;background:var(--warning-light);display:inline-flex;align-items:center;justify-content:center;font-size:14px}.table-count{font-size:12px;color:var(--text-muted);font-weight:500;background:var(--bg-surface);padding:4px 12px;border-radius:20px}.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border-light)}.reports-table{width:100%;border-collapse:collapse}.reports-table th{text-align:left;padding:11px 18px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border)}.reports-table td{padding:13px 18px;font-size:13px;font-weight:450;color:var(--text-body);border-bottom:1px solid var(--border-light);transition:background .15s ease}.reports-table tbody tr:last-child td{border-bottom:none}.reports-table tbody tr:hover td{background:#fafaff}.reports-table .location-cell{display:flex;align-items:center;gap:8px}.location-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0}.qty-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 14px;border-radius:8px;font-weight:700;font-size:13px;min-width:48px}.qty-high{background:var(--success-light);color:var(--success)}.qty-mid{background:var(--warning-light);color:var(--warning)}.qty-low{background:var(--danger-light);color:var(--danger)}.reporter-tag{font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-surface);padding:3px 10px;border-radius:6px}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 0;gap:16px}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.loading-text{font-size:14px;color:var(--text-muted);font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 0;color:var(--text-muted);font-size:13px;font-weight:500}@media(max-width:1100px){.charts-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.app{padding:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px}.header{flex-direction:column;align-items:flex-start;gap:12px}.header-right{width:100%;justify-content:space-between}.filters{flex-direction:column}.filter-select{width:100%}.stat-card-value{font-size:26px}.detail-panel{width:100%!important}}.reports-table tbody tr.clickable{cursor:pointer}.reports-table tbody tr.clickable:hover td{background:var(--primary-light)}.clickable-hint{font-size:11px;color:var(--text-muted);font-weight:400;margin-left:8px;opacity:.6}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail-panel{position:fixed;top:0;right:0;width:520px;height:100vh;background:var(--bg-white);box-shadow:-8px 0 40px #0000001f;z-index:1000;display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 28px 20px;border-bottom:1px solid var(--border-light);flex-shrink:0}.panel-type-badge{display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--primary);background:var(--primary-light);padding:4px 10px;border-radius:6px;margin-bottom:8px}.panel-title{font-size:22px;font-weight:800;color:var(--text-dark);letter-spacing:-.3px}.panel-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px;font-weight:400}.panel-close{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-subtle);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.panel-close:hover{background:var(--danger-light);color:var(--danger);border-color:transparent}.panel-body{flex:1;overflow-y:auto;padding:24px 28px 40px}.panel-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:26px}.panel-kpi{background:var(--bg-surface);border-radius:var(--radius-sm);padding:14px 12px;text-align:center}.panel-kpi-value{display:block;font-size:20px;font-weight:800;color:var(--text-dark);line-height:1;margin-bottom:4px}.panel-kpi-label{display:block;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.panel-section{margin-bottom:24px}.panel-section-title{font-size:13px;font-weight:700;color:var(--text-dark);margin-bottom:14px}.panel-empty{font-size:13px;color:var(--text-muted);text-align:center;padding:20px 0}.panel-table-wrap{border:1px solid var(--border-light);border-radius:var(--radius-xs);overflow:hidden}.panel-table{width:100%;border-collapse:collapse}.panel-table th{text-align:left;padding:8px 14px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border)}.panel-table td{padding:9px 14px;font-size:12px;font-weight:450;color:var(--text-body);border-bottom:1px solid var(--border-light)}.panel-table tbody tr:last-child td{border-bottom:none}.panel-table .qty-badge{padding:2px 10px;font-size:12px;min-width:36px}.panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;gap:12px}
