:root{--ff-body: "Barlow", sans-serif;--ff-cond: "Barlow Condensed", sans-serif;--font-size-xs: .694rem;--font-size-sm: .833rem;--font-size-base: 1rem;--font-size-md: 1.2rem;--font-size-lg: 1.44rem;--font-size-xl: 1.728rem;--font-size-2xl: 2.074rem;--color-navy: #0f1f3d;--color-navy-mid: #1e3a5f;--color-navy-light: #2c5282;--color-amber: #f59e0b;--color-amber-light: #fbbf24;--color-green: #10b981;--color-red: #ef4444;--color-blue: #3b82f6;--color-blue-light: #93c5fd;--color-bg: #f0f2f5;--color-surface: #ffffff;--color-surface-2: #f8fafc;--color-border: #e2e8f0;--color-text: #1e293b;--color-text-muted: #64748b;--color-text-light: #94a3b8;--sidebar-width: 220px;--sidebar-bg: var(--color-navy);--sidebar-text: rgba(255,255,255,.75);--sidebar-active-bg: var(--color-navy-mid);--sidebar-active: #ffffff;--sidebar-accent: var(--color-amber);--topbar-height: 52px;--topbar-bg: var(--color-surface);--topbar-border: var(--color-border);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px rgba(0,0,0,.08), 0 4px 6px rgba(0,0,0,.05);--status-ahead: var(--color-green);--status-on-track: var(--color-blue);--status-behind: var(--color-amber);--status-critical: var(--color-red);--chart-bl: #3b82f6;--chart-actual: #10b981;--chart-forecast: #f59e0b;--chart-grid: rgba(0,0,0,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--ff-body);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;height:100vh;overflow:hidden}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden;margin-left:var(--sidebar-width)}.page-body{flex:1;overflow-y:auto;padding:var(--space-lg)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:100;overflow:hidden}.sidebar-brand{padding:var(--space-md) var(--space-md) var(--space-sm);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.sidebar-brand-logo{font-family:var(--ff-cond);font-size:var(--font-size-lg);font-weight:700;color:var(--sidebar-active);letter-spacing:.5px;line-height:1.2}.sidebar-brand-sub{font-size:var(--font-size-xs);color:var(--sidebar-text);letter-spacing:.5px;text-transform:uppercase;margin-top:2px}.sidebar-nav{flex:1;padding:var(--space-sm) 0;overflow-y:auto}.sidebar-section-label{font-family:var(--ff-cond);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--sidebar-text);padding:var(--space-sm) var(--space-md) var(--space-xs);opacity:.5}.sidebar-link{display:flex;align-items:center;gap:var(--space-sm);padding:9px var(--space-md);color:var(--sidebar-text);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;border-left:3px solid transparent;transition:background .15s,color .15s,border-color .15s;cursor:pointer}.sidebar-link:hover{background:#ffffff0f;color:var(--sidebar-active)}.sidebar-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active);border-left-color:var(--sidebar-accent)}.sidebar-link svg{width:16px;height:16px;flex-shrink:0;opacity:.8}.sidebar-link.active svg{opacity:1}.sidebar-footer{padding:var(--space-md);border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.topbar{height:var(--topbar-height);background:var(--topbar-bg);border-bottom:1px solid var(--topbar-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);flex-shrink:0;gap:var(--space-md)}.topbar-title{font-family:var(--ff-cond);font-size:var(--font-size-md);font-weight:600;color:var(--color-navy);letter-spacing:.3px}.topbar-right{display:flex;align-items:center;gap:var(--space-md)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.card-title{font-family:var(--ff-cond);font-size:var(--font-size-md);font-weight:600;color:var(--color-navy);letter-spacing:.3px}.card-body{padding:var(--space-lg)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);box-shadow:var(--shadow-sm);border-left:4px solid var(--accent, var(--color-blue))}.kpi-label{font-family:var(--ff-cond);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.kpi-value{font-family:var(--ff-cond);font-size:var(--font-size-2xl);font-weight:700;color:var(--color-navy);line-height:1;margin-bottom:2px}.kpi-sub{font-size:var(--font-size-xs);color:var(--color-text-muted)}.kpi-delta{font-size:var(--font-size-xs);font-weight:600;display:inline-flex;align-items:center;gap:2px}.kpi-delta.pos{color:var(--color-green)}.kpi-delta.neg{color:var(--color-red)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:var(--font-size-xs);font-weight:600;letter-spacing:.3px;white-space:nowrap}.badge-green{background:#d1fae5;color:#065f46}.badge-amber{background:#fef3c7;color:#92400e}.badge-red{background:#fee2e2;color:#991b1b}.badge-blue{background:#dbeafe;color:#1e40af}.badge-gray{background:#f1f5f9;color:#475569}.data-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table th{font-family:var(--ff-cond);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md);background:var(--color-surface-2);border-bottom:2px solid var(--color-border);text-align:left;white-space:nowrap}.data-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);color:var(--color-text)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-surface-2)}.data-table td.num{text-align:right;font-family:var(--ff-cond);font-variant-numeric:tabular-nums}.section-title{font-family:var(--ff-cond);font-size:var(--font-size-md);font-weight:600;color:var(--color-navy);margin-bottom:var(--space-md)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-md)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-right{text-align:right}.loading-center{display:flex;align-items:center;justify-content:center;height:200px;color:var(--color-text-muted);gap:var(--space-sm);font-size:var(--font-size-sm)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-blue);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.filter-bar{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.filter-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted);white-space:nowrap}select.filter-select{font-family:var(--ff-body);font-size:var(--font-size-sm);padding:5px var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer}select.filter-select:focus{outline:2px solid var(--color-blue);outline-offset:1px}.prog-bar-wrap{display:flex;align-items:center;gap:var(--space-sm)}.prog-bar-track{flex:1;height:6px;background:var(--color-border);border-radius:100px;overflow:hidden}.prog-bar-fill{height:100%;border-radius:100px;background:var(--color-blue);transition:width .3s ease}.prog-bar-fill.green{background:var(--color-green)}.prog-bar-fill.amber{background:var(--color-amber)}.prog-bar-fill.red{background:var(--color-red)}.prog-bar-val{font-family:var(--ff-cond);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);min-width:38px;text-align:right}
