
:root{--bg:#f3f4f6;--fg:#111;--muted:#6b7280;--card:#fff;--border:#e5e7eb;--brand:#4f46e5;--success:#059669;--warn:#b91c1c}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);font:14px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Arial}
.container{max-width:1080px;margin:0 auto;padding:24px}
.card{background:var(--card);border-radius:16px;box-shadow:0 6px 20px rgba(0,0,0,.06);padding:20px;margin-bottom:24px}
.btn{padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:700}
.btn-danger{background:#fee2e2}
.input{width:100%;border:1px solid var(--border);border-radius:8px;padding:8px 12px}
.label{font-size:12px;color:#555}
.table{width:100%;border-collapse:collapse}
.table th{background:#f9fafb;color:#374151;font-size:12px;text-transform:uppercase;text-align:left;padding:12px}
.table td{padding:12px;border-top:1px solid #eee}
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.badge{padding:3px 8px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px}
.flex{display:flex}.gap8{gap:8px}.gap12{gap:12px}.space-between{justify-content:space-between}.center{align-items:center}
.grid{display:grid}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.grid-6{grid-template-columns:repeat(6,minmax(0,1fr))}
.progress{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}
.progress > div{height:8px;background:var(--brand);border-radius:999px}
.note{font-size:12px;color:var(--muted)}
.alert{padding:12px;border-radius:12px}
.alert-ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}
.alert-warn{background:#fffbeb;color:#92400e;border:1px solid #fcd34d}
.alert-err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
h1,h2,h3{margin:0 0 12px 0}
.toolbar{display:flex;gap:8px;align-items:center}
select{border:1px solid var(--border);border-radius:8px;padding:6px 8px}
.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.summary .box{background:#fff;border-radius:16px;padding:16px;box-shadow:0 6px 20px rgba(0,0,0,.06)}
.summary .box .v{font-size:18px;font-weight:800}
.link{background:none;border:none;color:#111;text-decoration:underline;text-underline-offset:3;cursor:pointer;font-weight:700;padding:0}
.hidden{display:none}
