:root{
  --bg:#eef4fb; --card:#fff; --ink:#0f2540; --mut:#5b6b80; --line:#d8e6f5;
  --brandd:#0e3e82; --brand:#1769c0; --brand2:#2b86d8;
  --ok:#16a34a; --okbg:#dcfce7; --bad:#dc2626; --badbg:#fee2e2; --warnbg:#fef9c3; --warn:#a16207;
}
*{box-sizing:border-box}
body{margin:0;font:14px/1.5 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1040px;margin:24px auto;padding:0 20px}
.topbar{display:flex;align-items:center;gap:22px;padding:12px 20px;background:linear-gradient(120deg,#0e4ea0,#1769c0 60%,#2b86d8);color:#fff}
.topbar a{color:#fff}
.brand{font-weight:800;font-size:16px}
.topbar nav{display:flex;gap:16px;flex:1}
.topbar nav a{opacity:.9;font-weight:600}
.who{display:flex;align-items:center;gap:10px;font-size:12px}
.who .email{color:#dbeafe}
.who .logout{font-weight:600}
.chip{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:800;background:#fff;color:var(--brandd)}
.role-admin{background:#fde68a;color:#92400e}
.role-publisher{background:#bfdbfe;color:#1e40af}
.role-viewer{background:#e2e8f0;color:#334155}
.foot{max-width:1040px;margin:20px auto 40px;padding:0 20px;color:var(--mut);font-size:11px}

h1{font-size:22px;margin:0 0 4px}
h2{font-size:16px;margin:24px 0 10px;color:var(--brandd)}
.sub{color:var(--mut);margin:0 0 18px}

.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;box-shadow:0 4px 14px rgba(11,63,122,.06);margin-bottom:16px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.dcard{display:block;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:0 4px 14px rgba(11,63,122,.06)}
.dcard:hover{border-color:var(--brand2);text-decoration:none}
.dcard h3{margin:0 0 6px;color:var(--brandd);font-size:15px}
.dcard p{margin:0;color:var(--mut);font-size:12.5px}
.dcard .meta{margin-top:10px;font-size:11px;color:var(--mut)}

.btn{display:inline-block;padding:8px 14px;border-radius:9px;border:1px solid var(--brand);background:var(--brand);color:#fff;font-weight:700;font-size:13px;cursor:pointer}
.btn:hover{background:var(--brandd);text-decoration:none}
.btn.sec{background:#fff;color:var(--brand)}
.btn.ghost{background:#fff;color:var(--mut);border-color:var(--line)}
.btn.sm{padding:5px 10px;font-size:12px}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

label{display:block;font-size:12px;color:var(--mut);margin:10px 0 4px;font-weight:600}
input[type=text],input[type=email],input[type=password],select,textarea{
  width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:9px;font:inherit;background:#fbfdff}
textarea{min-height:220px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px}
input[type=file]{font-size:13px}

table{width:100%;border-collapse:collapse;font-size:13px}
th,td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--line)}
th{color:var(--mut);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px}
td.num{text-align:right;font-variant-numeric:tabular-nums}

.pill{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:800}
.st-passed{background:var(--okbg);color:var(--ok)}
.st-failed,.st-error{background:var(--badbg);color:var(--bad)}
.st-running,.st-queued{background:var(--warnbg);color:var(--warn)}

.banner{margin:0 0 16px;padding:12px 16px;border-radius:12px;font-weight:700}
.banner.err{background:var(--badbg);color:var(--bad)}
.banner.ok{background:var(--okbg);color:var(--ok)}
.log{background:#0b1c33;color:#cfe4fb;border-radius:12px;padding:14px;font-family:ui-monospace,Menlo,monospace;font-size:12px;white-space:pre-wrap;max-height:460px;overflow:auto}

.login-wrap{max-width:380px;margin:8vh auto}
.login-wrap .card{padding:26px}
.muted{color:var(--mut);font-size:12px}
.tag{font-size:11px;color:var(--mut);background:#f1f6fc;border:1px solid var(--line);padding:1px 7px;border-radius:6px}
