:root { --bg:#0b0f14; --card:#111826; --text:#e6edf3; --muted:#9fb0c0; --line:#1f2a3a; --btn:#2f81f7; --btn2:#233045; }
* { box-sizing: border-box; }
body { margin:0; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial; background: var(--bg); color: var(--text); }
a { color: var(--text); text-decoration: none; }
.wrap { max-width: 1100px; margin: 24px auto; padding: 0 16px; }
.topbar { display:flex; align-items:center; justify-content:space-between; padding: 14px 16px; border-bottom: 1px solid var(--line); position: sticky; top:0; background: rgba(11,15,20,0.9); backdrop-filter: blur(8px); }
.brand a { font-weight: 700; }
.nav a { margin-left: 14px; color: var(--muted); }
.nav a:hover { color: var(--text); }
h1 { margin: 8px 0 16px; font-size: 24px; }
table { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
th, td { padding: 10px 10px; border-bottom: 1px solid var(--line); vertical-align: top; }
th { text-align: left; font-size: 12px; color: var(--muted); background: rgba(255,255,255,0.02); }
tr:last-child td { border-bottom: none; }
.card { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 14px; margin: 14px 0; }
.form { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 14px; }
label { display:block; font-size: 12px; color: var(--muted); margin-top: 12px; margin-bottom: 6px; }
input, textarea { width:100%; padding: 10px; border-radius: 10px; border: 1px solid var(--line); background: #0e1522; color: var(--text); }
textarea.mono, .mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size: 12px; }
.hint { color: var(--muted); font-size: 12px; margin-top: 6px; }
.actions { margin: 12px 0; display:flex; gap: 10px; flex-wrap: wrap; }
.btn { display:inline-block; background: var(--btn); color: #fff; padding: 10px 12px; border-radius: 10px; font-weight: 600; }
.btn.small { padding: 6px 10px; font-size: 12px; }
.btn.secondary { background: var(--btn2); color: var(--text); }
.badge { display:inline-block; padding: 4px 8px; border-radius: 999px; font-size: 12px; border:1px solid var(--line); }
.badge.ok { background: rgba(46, 160, 67, 0.18); }
.badge.warn { background: rgba(187, 128, 9, 0.18); }
.badge.bad { background: rgba(248, 81, 73, 0.18); }
.center { text-align: center; color: var(--muted); }
.grid2 { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.checklist { background: #0e1522; border: 1px solid var(--line); border-radius: 12px; padding: 10px; }
.check { display:flex; gap: 10px; align-items:flex-start; margin: 6px 0; color: var(--text); }
@media (max-width: 720px) { .grid2 { grid-template-columns: 1fr; } }

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:900px){.grid3{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.grid3{grid-template-columns:1fr}}

.k{color:var(--muted);font-size:12px}
.v{font-size:22px;font-weight:700;margin-top:4px}

.pill{display:inline-block;padding:6px 10px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.pill.on{background:rgba(47,129,247,0.16);color:var(--text)}

.badge.success{background:rgba(46,160,67,0.18)}
.badge.partial{background:rgba(187,128,9,0.18)}
.badge.fail{background:rgba(248,81,73,0.18)}

.t{width:100%}
.alert{padding:10px 12px;border-radius:12px;border:1px solid var(--line);margin:12px 0}
.alert.bad{background:rgba(248,81,73,0.10)}

/* --- Bulk Re-consent checklist layout fix --- */
.checklist{max-height:260px;overflow:auto;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:12px}
.check{display:grid;grid-template-columns:18px 1fr;gap:12px;align-items:flex-start;padding:8px 10px;border-radius:10px}
.check:hover{background:rgba(255,255,255,.03)}
.check input{width:16px;height:16px;margin:2px 0 0 0}
.check span{display:block;white-space:normal;word-break:break-word;line-height:1.25;text-align:left}
