
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Arial,'Noto Sans','Helvetica Neue',sans-serif;background:#f7f7fb;}
.container{max-width:1100px;margin:0 auto;padding:16px;}
.card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 1px 2px rgba(0,0,0,0.04);background:#fff;}
.btn{display:inline-block;padding:8px 12px;border-radius:8px;border:1px solid #111827;text-decoration:none;cursor:pointer;}
.btn-primary{background:#111827;color:#fff;}
.btn-ghost{background:#fff;color:#111827;border:1px solid #e5e7eb;}
.badge{padding:4px 8px;border-radius:999px;font-size:12px;}
.badge-ok{background:#DCFCE7;color:#166534;}
.badge-pend{background:#FEF9C3;color:#854D0E;}
.grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));}
.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.progress{height:12px;background:#e5e7eb;border-radius:999px;overflow:hidden;}
.progress>div{height:100%;background:#111827;}
.footer-note{font-size:12px;color:#6b7280;}
table{width:100%;border-collapse:collapse;}
th,td{padding:8px;border-bottom:1px solid #e5e7eb;text-align:left;}
label{font-weight:500;}
