:root{font-family:system-ui,Segoe UI,sans-serif;line-height:1.5;color:#e8e8e8;background:#12141a}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{max-width:1400px;margin:0 auto;padding:1rem 1.25rem 2rem}h1{font-size:1.35rem;font-weight:600;margin:0 0 1rem}h2{font-size:1rem;margin:1.25rem 0 .5rem;color:#a8b0c0}.grid-kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem}.kpi{background:#1a1e28;border:1px solid #2a3142;border-radius:8px;padding:.75rem 1rem}.kpi label{display:block;font-size:.75rem;color:#8892a4;margin-bottom:.25rem}.kpi strong{font-size:1.15rem}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.75rem}button{background:#2d3a55;color:#e8e8e8;border:1px solid #3d4d6a;border-radius:6px;padding:.4rem .85rem;cursor:pointer;font-size:.9rem}button:hover{background:#3a4a6a}.badge{font-size:.8rem;padding:.2rem .5rem;border-radius:4px;background:#2a3142}.badge.ok{background:#1e3d2e;color:#7dffb3}.badge.warn{background:#3d2e1e;color:#ffc97d}.log-console{background:#0a0c10;border:1px solid #2a3142;border-radius:8px;height:280px;overflow:auto;padding:.6rem .75rem;font-family:ui-monospace,Consolas,monospace;font-size:.78rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}.log-line{color:#b8c4d8}.log-line.err{color:#ff8a8a}table.data{width:100%;border-collapse:collapse;font-size:.82rem;background:#1a1e28;border:1px solid #2a3142;border-radius:8px;overflow:hidden}table.data th,table.data td{padding:.4rem .5rem;text-align:left;border-bottom:1px solid #2a3142}table.data th{background:#141820;color:#8892a4;font-weight:500}.hint{font-size:.85rem;color:#8892a4;margin:.5rem 0}
