*{box-sizing:border-box}body{color:#111827;background:#f5f7fb;margin:0;font-family:Inter,Arial,sans-serif}main{max-width:1180px;margin:0 auto;padding:32px 18px 60px}.hero{grid-template-columns:1fr 320px;align-items:stretch;gap:24px;margin-bottom:24px;display:grid}.eyebrow{color:#2563eb;text-transform:uppercase;letter-spacing:.08em;font-size:13px;font-weight:800}h1{margin:8px 0 12px;font-size:42px;line-height:1.05}h2{margin-top:0;font-size:22px}.sub{color:#4b5563;max-width:780px;font-size:17px}.card,.statusCard,.metric{background:#fff;border:1px solid #e5e7eb;border-radius:22px;padding:22px;box-shadow:0 12px 40px #0f172a0f}.statusCard{flex-direction:column;justify-content:center;gap:8px;display:flex}.statusCard span,.metric span{color:#6b7280;font-size:14px}.statusCard strong,.metric strong{font-size:24px}.card{margin-bottom:20px}.uploadRow{flex-wrap:wrap;align-items:center;gap:12px;display:flex}input[type=file]{background:#f9fafb;border:1px dashed #cbd5e1;border-radius:14px;flex:1;min-width:260px;padding:14px}button{color:#fff;cursor:pointer;background:#111827;border:0;border-radius:14px;padding:14px 18px;font-weight:800}button:disabled{opacity:.55;cursor:not-allowed}.info{background:#f8fafc;border:1px solid #e5e7eb;border-radius:16px;margin-top:16px;padding:14px}.info p{color:#4b5563;margin:6px 0}.progressBox{margin-top:16px}.progressTop{justify-content:space-between;margin-bottom:8px;display:flex}.bar{background:#e5e7eb;border-radius:999px;height:12px;overflow:hidden}.bar div{background:#2563eb;height:100%}.grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px;display:grid}.metric,.table{flex-direction:column;gap:8px;display:flex}.row{background:#f9fafb;border-radius:14px;grid-template-columns:1.5fr 1fr .6fr 2fr;align-items:center;gap:12px;padding:12px;display:grid}.row.head{color:#fff;background:#111827;font-weight:800}.controls{flex-direction:column;gap:12px;display:flex}.control{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;justify-content:space-between;gap:20px;padding:16px;display:flex}.control p{color:#4b5563;margin:6px 0}.badge{border-radius:999px;align-self:flex-start;padding:7px 11px;font-size:12px;font-weight:900}.ok{color:#166534;background:#dcfce7}.bad{color:#991b1b;background:#fee2e2}.warn{color:#92400e;background:#fef3c7}.neutral{color:#374151;background:#e5e7eb}@media (width<=850px){.hero,.grid{grid-template-columns:1fr}h1{font-size:32px}.row{grid-template-columns:1fr}.control{flex-direction:column}}
