*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#0f172a;background:#f1f5f9}a{color:#2563eb}.wrap{max-width:1200px;margin:0 auto;padding:20px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px}.row{display:flex;gap:12px;align-items:center}.muted{color:#64748b}.btn{background:#2563eb;color:#fff;border:0;border-radius:8px;padding:8px 14px;font-weight:600;cursor:pointer}.btn.ghost{background:#fff;color:#334155}.btn.ghost,.input{border:1px solid #cbd5e1}.input{width:100%;padding:9px 11px;border-radius:8px;font-size:14px}table{width:100%;border-collapse:collapse;font-size:13px}td,th{text-align:left;padding:8px 10px;border-bottom:1px solid #eef2f7}th{color:#64748b;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em}tbody tr{cursor:pointer}tbody tr:hover{background:#f8fafc}.tag{display:inline-block;padding:1px 8px;border-radius:999px;font-size:11px;font-weight:600;background:#eef2f7;color:#334155}.tag.err{background:#fee2e2;color:#b91c1c}.tag.ok{background:#dcfce7;color:#166534}pre{background:#0f172a;color:#e2e8f0;padding:14px;border-radius:8px;overflow:auto;font-size:12px;line-height:1.5;max-height:60vh;white-space:pre-wrap;word-break:break-word}.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.modal{background:#fff;border-radius:12px;max-width:980px;width:100%;max-height:90vh;overflow:auto;padding:20px}.tabbtn{background:none;border:0;padding:8px 12px;font-weight:600;color:#64748b;cursor:pointer;border-radius:8px}.tabbtn.active{background:#eff6ff;color:#1d4ed8}.section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin:14px 0 4px}