:root{--primary:#7d9b76;--primary-dark:#5a7a52;--primary-light:#a8c4a0;--charcoal:#2d2d2d;--bg:#f8f9fa;--card-bg:#fff;--text:#4a4a4a;--text-light:#888;--border:#e0e0e0;--danger:#e74c3c;--warning:#f39c12;--success:#27ae60;--info:#3498db;color:var(--text);background:var(--bg);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px}*{box-sizing:border-box;margin:0;padding:0}body{margin:0}#root,.app{flex-direction:column;min-height:100vh;display:flex}.header{background:var(--charcoal);color:#fff;z-index:50;justify-content:space-between;align-items:center;height:48px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #00000026}.header h1{letter-spacing:-.3px;font-size:17px;font-weight:600}.header h1 span{color:var(--primary-light)}.header-right{color:#999;align-items:center;gap:16px;font-size:12px;display:flex}.header-right .connected{color:#4ade80;font-weight:500}.header-right .offline{color:#ef4444;font-weight:500}.main{flex:1;width:100%;max-width:1600px;margin:0 auto;padding:20px 24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--card-bg);border-left:4px solid var(--primary);border-radius:8px;padding:18px 20px;transition:box-shadow .15s;box-shadow:0 1px 3px #0000000f}.stat-card:hover{box-shadow:0 2px 8px #0000001a}.stat-card.warning{border-left-color:var(--warning)}.stat-card.danger{border-left-color:var(--danger)}.stat-card.info{border-left-color:var(--info)}.stat-card.success{border-left-color:var(--success)}.stat-label{text-transform:uppercase;color:var(--text-light);letter-spacing:.5px;font-size:11px}.stat-value{color:var(--charcoal);margin:4px 0;font-size:28px;font-weight:700}.stat-sub{color:var(--text-light);font-size:11px}.card{background:var(--card-bg);border-radius:8px;margin-bottom:20px;padding:20px;box-shadow:0 1px 3px #00000014}.card h2{color:var(--charcoal);margin-bottom:12px;font-size:16px;font-weight:600}.card h3{color:var(--text);margin-bottom:8px;font-size:14px;font-weight:500}.data-table{border-collapse:collapse;width:100%;font-size:12px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.3px;color:var(--text-light);border-bottom:2px solid var(--border);white-space:nowrap;z-index:2;background:#fafbfc;padding:10px 12px;font-size:11px;font-weight:600;position:sticky;top:0}.data-table td{color:var(--text);border-bottom:1px solid #f0f0f0;padding:8px 12px}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:#f8faf7}.data-table tbody tr.selected td{background:#f0f7ee}.badge{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.badge.fba{color:#2e7d32;background:#e8f5e9}.badge.fbm{color:#e65100;background:#fff3e0}.badge.bb{color:#1565c0;background:#e3f2fd}.two-col{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=900px){.two-col{grid-template-columns:1fr}}.service-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 0;display:flex}.service-row:last-child{border:none}.dot{border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.dot.green{background:var(--success)}.dot.yellow{background:var(--warning)}.dot.red{background:var(--danger)}.auth-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-box{text-align:center;background:#fff;border-radius:12px;width:90%;max-width:400px;padding:32px}.auth-box h2{margin-bottom:8px}.auth-box p{color:var(--text-light);margin-bottom:20px;font-size:13px}.auth-box input{border:1px solid var(--border);border-radius:6px;width:100%;margin-bottom:12px;padding:10px 14px;font-family:monospace;font-size:14px}.auth-box button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:600}.auth-box button:hover{background:var(--primary-dark)}.loading{text-align:center;color:var(--text-light);padding:40px}.error{color:var(--danger);background:#fef2f2;border-radius:6px;margin:12px 0;padding:12px}.tabs{border-bottom:1px solid var(--border);background:var(--card-bg);border-radius:8px 8px 0 0;flex-wrap:wrap;gap:0;margin-bottom:24px;padding:0 8px;display:flex}.tab{cursor:pointer;color:var(--text-light);white-space:nowrap;-webkit-user-select:none;user-select:none;border-bottom:3px solid #0000;margin-bottom:-1px;padding:12px 20px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--charcoal);background:#00000005}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.sub-tabs{gap:8px;margin-bottom:16px;display:flex}.sub-tabs button{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;color:var(--text);border-radius:6px;padding:6px 14px;font-size:12px}.sub-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.sub-tabs button:hover:not(.active){background:#f0f0f0}.table-filter{border:1px solid var(--border);border-radius:6px;width:100%;margin-bottom:12px;padding:8px 12px;font-size:13px}.table-wrap{border-radius:0 0 4px 4px;max-height:600px;overflow:auto}.title-cell{text-overflow:ellipsis;white-space:nowrap;max-width:250px;overflow:hidden}.table-footer{text-align:center;color:var(--text-light);padding:8px;font-size:12px}.chart-controls{align-items:center;gap:12px;margin-bottom:12px;display:flex}.chart-controls select{border:1px solid var(--border);background:#fff;border-radius:6px;padding:6px 10px;font-size:13px}.chart-info{color:var(--text-light);font-size:12px}.score-summary{border-top:1px solid var(--border);gap:24px;margin-top:16px;padding-top:12px;display:flex}.score-stat-label{text-transform:uppercase;color:var(--text-light);font-size:11px;display:block}.score-stat-value{color:var(--charcoal);font-size:20px;font-weight:700}.pipeline-layout{gap:20px;display:flex}.pipeline-layout .pipeline-main{flex:1;min-width:0}.pipeline-layout.with-inspector .pipeline-main{flex:1}.inspector-panel{background:var(--card-bg);border-radius:8px;align-self:flex-start;width:340px;min-width:340px;max-height:calc(100vh - 140px);position:sticky;top:20px;overflow-y:auto;box-shadow:0 1px 3px #00000014}.inspector-header{border-bottom:1px solid var(--border);background:var(--card-bg);z-index:1;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.inspector-header h3{color:var(--charcoal);font-size:14px;font-weight:600}.inspector-close{color:var(--text-light);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.inspector-close:hover{color:var(--charcoal)}.inspector-body{padding:16px 20px}.inspector-field{margin-bottom:12px}.inspector-label{text-transform:uppercase;color:var(--text-light);letter-spacing:.5px;margin-bottom:2px;font-size:11px;display:block}.inspector-value{color:var(--charcoal);word-break:break-word;font-size:13px}.inspector-value.mono{font-family:monospace;font-size:12px}.inspector-divider{border-top:1px solid var(--border);margin:14px 0}.inspector-section{color:var(--charcoal);margin-bottom:10px;font-size:12px;font-weight:600}.inspector-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.inspector-stat-label{text-transform:uppercase;color:var(--text-light);letter-spacing:.3px;font-size:10px;display:block}.inspector-stat-value{color:var(--charcoal);font-size:15px;font-weight:600}@media (width<=1100px){.pipeline-layout{flex-direction:column}.inspector-panel{width:100%;min-width:0;max-height:none;position:static}}.badge.grade-a-plus,.badge.grade-a{color:#166534;background:#dcfce7}.badge.grade-b{color:#1e40af;background:#dbeafe}.badge.grade-c{color:#92400e;background:#fef3c7}.badge.grade-d,.badge.grade-f,.badge.action-restock{color:#991b1b;background:#fee2e2}.badge.action-watch{color:#92400e;background:#fef3c7}.badge.action-ok{color:#166534;background:#dcfce7}.badge.action-critical{color:#fff;background:#991b1b}.badge.action-action{color:#fff;background:#ea580c}.badge.action-capture{color:#fff;background:#2563eb}.data-table tbody tr.row-critical td{background:#fef2f2}.data-table tbody tr.row-action td{background:#fffbeb}.data-table tbody tr.row-capture td{background:#eff6ff}.spark-bar{vertical-align:middle;background:#e5e7eb;border-radius:4px;width:60px;height:8px;margin-left:6px;display:inline-block}.spark-bar-fill{background:var(--primary);border-radius:4px;height:100%}.chart-container{width:100%;height:350px}.trend-up{color:var(--success);font-size:11px}.trend-down{color:var(--danger);font-size:11px}.file-link{color:var(--primary);font-size:12px;text-decoration:none}.file-link:hover{text-decoration:underline}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px;display:grid}.donut-wrap{justify-content:center;align-items:center;height:280px;display:flex}.three-col{grid-template-columns:1fr 1fr 1fr;gap:20px;display:grid}@media (width<=1100px){.three-col{grid-template-columns:1fr}}.action-feed-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:10px;padding:8px 12px;font-size:12px;transition:background .1s;display:flex}.action-feed-item:hover{background:#f8faf7}.action-feed-item:last-child{border-bottom:none}.roi-high{color:#16a34a;font-weight:600}.roi-mid{color:#ea580c;font-weight:600}.roi-low{color:#dc2626;font-weight:600}.date-range-picker{flex-wrap:wrap;align-items:center;gap:4px;padding:8px 0;display:flex}.date-range-btn{border:1px solid var(--border);cursor:pointer;color:var(--charcoal);background:#fff;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.date-range-btn:hover{border-color:var(--sage);color:var(--sage)}.date-range-btn.active{background:var(--sage);color:#fff;border-color:var(--sage)}.date-range-custom input[type=date]{border:1px solid var(--border);color:var(--charcoal);border-radius:4px;padding:3px 6px;font-size:11px}.date-range-info{color:#94a3b8;margin-left:8px;font-size:11px}.data-source-banner{border:1px solid var(--border);background:#f8fafc;border-radius:6px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:6px 12px;display:flex}.data-source-label{color:#64748b;font-size:11px;font-weight:600}.data-source-chip{white-space:nowrap;border:1px solid;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:500}.data-source-warning{color:#d97706;font-size:10px;font-style:italic}.btn-primary{background:var(--sage);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 20px;font-size:13px;font-weight:600;transition:all .15s}.btn-primary:hover{background:#5a7a5e}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.pnl-row td{padding:6px 12px;font-size:13px}.pnl-row.income td{color:#16a34a}.pnl-row.expense td{color:#dc2626}.pnl-row.total td{background:#f8fafc;font-size:14px;font-weight:700}
