/* ROSTER v1 — calm, professional, non-technical control plane.
   Light theme, card-based, generous spacing, restrained accent. */
:root{
  --bg:#f5f6f8; --card:#ffffff; --line:#e5e7eb; --line2:#eef0f3;
  --ink:#111827; --muted:#6b7280; --faint:#9ca3af;
  --accent:#4f46e5; --accent-ink:#ffffff; --accent-soft:#eef2ff;
  --green:#15803d; --green-soft:#dcfce7; --amber:#b45309; --amber-soft:#fef3c7;
  --red:#b91c1c; --red-soft:#fee2e2; --gray:#6b7280; --gray-soft:#f1f3f5;
  --shadow:0 1px 2px rgba(16,24,40,.04),0 4px 16px rgba(16,24,40,.06);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:22px;font-weight:700;margin:0}
h2{font-size:17px;font-weight:700;margin:0 0 4px}
h3{font-size:14px;font-weight:700;margin:0}
p{margin:0 0 10px}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.small{font-size:13px}
.mono{font-family:'SFMono-Regular',ui-monospace,Consolas,monospace;font-size:12.5px}

/* ── layout shell ── */
.layout{display:flex;min-height:100vh}
.sidebar{width:236px;background:var(--card);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{font-weight:800;font-size:20px;letter-spacing:.08em;padding:22px 22px 2px}
.brandsub{font-size:11px;color:var(--faint);letter-spacing:.14em;text-transform:uppercase;padding:0 22px 14px}
.armed-badge{margin:0 22px 16px}
nav{display:flex;flex-direction:column;gap:2px;padding:8px 12px}
nav a{color:var(--muted);font-weight:500;padding:9px 12px;border-radius:9px;font-size:14px}
nav a:hover{background:var(--gray-soft);text-decoration:none;color:var(--ink)}
nav a.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.sidefoot{margin-top:auto;padding:16px 22px;border-top:1px solid var(--line);font-size:12.5px;color:var(--muted)}
.content{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:20px 34px;border-bottom:1px solid var(--line);background:var(--card)}
.topbar .who{font-size:13px;color:var(--faint)}
.page{padding:28px 34px;max-width:1040px;width:100%}

/* ── cards ── */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px 22px;margin-bottom:18px}
.card.tight{padding:14px 18px}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px}

/* ── stat row ── */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.stat .n{font-size:26px;font-weight:800;line-height:1.1}
.stat .l{font-size:12.5px;color:var(--muted);margin-top:2px}

/* ── people / list rows ── */
.rowlist{display:flex;flex-direction:column}
.rowitem{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:15px 6px;border-bottom:1px solid var(--line2)}
.rowitem:last-child{border-bottom:none}
.person-name{font-weight:600}
.person-sub{font-size:12.5px;color:var(--faint)}
.access-chips{display:flex;flex-wrap:wrap;gap:6px}

/* ── pills / chips ── */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;
  padding:3px 10px;border-radius:999px;white-space:nowrap}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;
  padding:4px 10px;border-radius:8px;background:var(--gray-soft);color:#374151}
.chip b{font-weight:700}
.s-green{background:var(--green-soft);color:var(--green)}
.s-amber{background:var(--amber-soft);color:var(--amber)}
.s-red{background:var(--red-soft);color:var(--red)}
.s-gray{background:var(--gray-soft);color:var(--gray)}
.s-accent{background:var(--accent-soft);color:var(--accent)}

/* ── buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:14px;font-weight:600;
  padding:10px 16px;border-radius:10px;border:1px solid var(--line);background:var(--card);
  color:var(--ink);cursor:pointer;transition:.12s}
.btn:hover{background:var(--gray-soft);text-decoration:none}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#4338ca}
.btn.danger{background:var(--red);border-color:var(--red);color:#fff}
.btn.danger:hover{background:#991b1b}
.btn.ghost{background:transparent}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.lg{padding:12px 20px;font-size:15px}

/* ── forms ── */
label{display:block;font-size:13px;font-weight:600;color:#374151;margin:0 0 5px}
input[type=text],input[type=email],input[type=password],textarea,select{
  width:100%;font-family:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--line);
  border-radius:9px;background:#fff;color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.field{margin-bottom:14px}
.row{display:flex;gap:12px}
.row>*{flex:1}

/* ── guided flow: step groups ── */
.group{border:1px solid var(--line);border-radius:12px;margin-bottom:14px;overflow:hidden}
.group-head{background:#fafbfc;padding:12px 16px;border-bottom:1px solid var(--line2)}
.group-head .t{font-weight:700;font-size:14px}
.group-head .d{font-size:12.5px;color:var(--muted);margin-top:1px}
.step{display:flex;align-items:flex-start;gap:12px;padding:11px 16px;border-bottom:1px solid var(--line2)}
.step:last-child{border-bottom:none}
.step .ico{flex:none;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;
  font-size:12px;font-weight:700;margin-top:1px}
.step .body{min-width:0;flex:1}
.step .act{font-size:13.5px;font-weight:500}
.step .det{font-size:12.5px;color:var(--muted);margin-top:2px;word-break:break-word}
.ico.i-plan{background:var(--gray-soft);color:var(--gray)}
.ico.i-ok{background:var(--green-soft);color:var(--green)}
.ico.i-would{background:var(--accent-soft);color:var(--accent)}
.ico.i-warn{background:var(--amber-soft);color:var(--amber)}
.ico.i-fail{background:var(--red-soft);color:var(--red)}
.ico.i-run{background:var(--amber-soft);color:var(--amber);animation:pulse 1s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* ── banners ── */
.banner{border-radius:12px;padding:14px 16px;margin-bottom:18px;font-size:13.5px;display:flex;gap:10px;align-items:flex-start}
.banner.info{background:var(--accent-soft);color:#3730a3}
.banner.warn{background:var(--amber-soft);color:#92400e}
.banner.danger{background:var(--red-soft);color:#991b1b}
.banner.ok{background:var(--green-soft);color:#166534}
.banner b{font-weight:700}

/* ── summary strip after a run ── */
.summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:4px 0 16px}
.summary .box{border:1px solid var(--line);border-radius:10px;padding:12px 14px;text-align:center}
.summary .box .n{font-size:22px;font-weight:800}
.summary .box .l{font-size:12px;color:var(--muted)}

/* ── trace / activity ── */
.trace{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.trace .t{display:grid;grid-template-columns:150px 120px 1fr;gap:10px;padding:9px 14px;
  border-bottom:1px solid var(--line2);font-size:12.5px}
.trace .t:last-child{border-bottom:none}
.trace .t .ts{color:var(--faint);font-family:'SFMono-Regular',ui-monospace,monospace;font-size:11.5px}
.trace .t .ac{font-weight:600}

/* ── modal ── */
.modal-bg{position:fixed;inset:0;background:rgba(17,24,39,.55);display:none;
  align-items:center;justify-content:center;z-index:50;padding:20px}
.modal-bg.on{display:flex}
.modal{background:#fff;border-radius:16px;max-width:440px;width:100%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3)}

/* ── auth ── */
.authwrap{min-height:100vh;display:grid;place-items:center;background:var(--bg)}
.authcard{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);
  padding:34px;width:360px}
.authcard .brand{padding:0;text-align:center;font-size:24px}
.authcard .brandsub{padding:0;text-align:center;margin-bottom:22px}

.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.5);
  border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px}
@keyframes sp{to{transform:rotate(360deg)}}

/* ── people table (access matrix) ── */
.ptable{width:100%;border-collapse:collapse}
.ptable th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--faint);padding:2px 14px 11px;border-bottom:1px solid var(--line);white-space:nowrap}
.ptable th.num,.ptable td.num{text-align:center;width:96px}
.ptable td{padding:14px;border-bottom:1px solid var(--line2);vertical-align:middle}
.ptable tbody tr:last-child td{border-bottom:none}
.ptable tbody tr:hover{background:#fafbfc}
.ptable td.num{font-variant-numeric:tabular-nums;font-weight:700;font-size:15px}
.ptable td.num.zero{color:#d1d5db;font-weight:400}
.ptable td.act{text-align:right;width:104px}
.ptable .person-name{font-weight:600;font-size:14.5px}
.btn.sm{padding:6px 13px;font-size:13px}
