:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#0f172a;background:#f1f5f9;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:#f1f5f9;min-height:100vh}#root{width:100%}.topbar{color:#e2e8f0;z-index:100;background:linear-gradient(135deg,#1e293b,#0f172a);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0f172a4d}.brand{align-items:center;gap:.75rem;display:flex}.brand-logo{font-size:1.6rem}.brand-info{flex-direction:column;display:flex}.brand-company{color:#e2e8f0;letter-spacing:.02em;font-size:1.05rem;font-weight:700}.brand-subtitle{color:#94a3b8;font-size:.65rem}.topbar-badge{color:#a5b4fc;text-transform:uppercase;letter-spacing:.05em;background:#6366f126;border-radius:4px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.app-layout{min-height:calc(100vh - 52px);display:flex}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;gap:.75rem;width:260px;max-height:calc(100vh - 52px);padding:1rem;display:flex;position:sticky;top:52px;overflow-y:auto}.sidebar-section{flex-direction:column;gap:.4rem;display:flex}.sidebar-title{text-transform:uppercase;letter-spacing:.06em;color:#64748b;border-bottom:1px solid #f1f5f9;padding-bottom:.2rem;font-size:.68rem;font-weight:600}.file-select,.filter-input,.filter-select{color:#0f172a;background:#fff;border:1px solid #e2e8f0;border-radius:6px;width:100%;padding:.35rem .5rem;font-family:inherit;font-size:.78rem}.file-select:focus,.filter-input:focus,.filter-select:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 2px #6366f11f}.upload-zone{text-align:center;cursor:pointer;background:linear-gradient(135deg,#6366f10f,#22d3ee0f);border:1px dashed #cbd5e1;border-radius:6px;padding:.5rem;transition:border-color .2s}.upload-zone:hover{border-color:#6366f1}.upload-zone input[type=file]{display:none}.upload-label{color:#64748b;cursor:pointer;font-size:.72rem}.filter-chips{flex-wrap:wrap;gap:.25rem;display:flex}.chip{color:#475569;cursor:pointer;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:.12rem .45rem;font-size:.68rem;transition:all .15s}.chip.active{color:#6366f1;background:#6366f11a;border-color:#6366f1;font-weight:600}.chip:hover{border-color:#6366f1}.btn-apply{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#22d3ee);border:none;border-radius:6px;width:100%;padding:.4rem .8rem;font-family:inherit;font-size:.78rem;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 6px 16px #4f46e54d}.btn-apply:hover{transform:translateY(-1px);box-shadow:0 8px 20px #4f46e566}.content{flex-direction:column;flex:1;gap:.75rem;min-width:0;padding:1rem;display:flex}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem;display:grid}.kpi-card{background:#fff;border-radius:8px;flex-direction:column;gap:.05rem;padding:.5rem .65rem;display:flex;box-shadow:0 2px 6px #0f172a0f}.kpi-label{text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-size:.62rem}.kpi-value{color:#0f172a;font-size:1.1rem;font-weight:700}.kpi-value.warn{color:#c00000}.kpi-value.ok{color:#548235}.tabs{background:#e2e8f0;border-radius:8px;gap:.15rem;padding:.15rem;display:flex}.tab{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:.35rem .9rem;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .15s}.tab.active{color:#0f172a;background:#fff;font-weight:600;box-shadow:0 1px 3px #0f172a1a}.tab:hover:not(.active){color:#0f172a}.panel{background:#fff;border-radius:8px;flex-direction:column;gap:.4rem;padding:.65rem .9rem;display:flex;box-shadow:0 2px 8px #0f172a0f}.panel-title{color:#0f172a;margin:0;font-size:.78rem;font-weight:600}.panel-grid{grid-template-columns:1fr 1fr;gap:.6rem;display:grid}.panel-full{grid-column:1/-1}.table-wrapper{border-radius:6px;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:500px}th,td{text-align:left;border-bottom:1px solid #e2e8f0;padding:.35rem .5rem;font-size:.75rem}th{text-transform:uppercase;letter-spacing:.03em;color:#64748b;background:#f8fafc;font-size:.65rem;font-weight:600}tr:hover td{background:#f8fafc}.numeric{text-align:right;font-variant-numeric:tabular-nums}.loading{color:#64748b;justify-content:center;align-items:center;padding:3rem;font-size:.9rem;display:flex}.spinner{border:2px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;width:18px;height:18px;margin-right:.5rem;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.footer{text-align:center;color:#94a3b8;border-top:1px solid #e2e8f0;margin-top:.5rem;padding:.75rem 0 .4rem;font-size:.65rem}.chart-container{width:100%;min-height:280px}.status-badge{border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:600;display:inline-block}.status-complete{color:#166534;background:#dcfce7}.status-pending{color:#92400e;background:#fef3c7}.date-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.date-row label{color:#64748b;font-size:.7rem}.date-row input{border:1px solid #e2e8f0;border-radius:6px;padding:.3rem .5rem;font-family:inherit;font-size:.78rem}@media (width<=1024px){.sidebar{width:220px}.panel-grid{grid-template-columns:1fr}}@media (width<=768px){.app-layout{flex-direction:column}.sidebar{border-bottom:1px solid #e2e8f0;border-right:none;flex-flow:wrap;width:100%;max-height:none;position:static}.sidebar-section{flex:1;min-width:130px}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(85px,1fr))}}
