/* Talent Compass — mobile-first responsive styles (R-033/N-011). WCAG AA contrast (R-063). */
:root{
  --bg:#f4f6f9; --card:#ffffff; --ink:#1a2230; --muted:#54607a; --line:#d9dee8;
  --brand:#1d4ed8; --brand-ink:#ffffff; --ok:#176b3a; --err:#a31515; --warn:#8a5a00;
  --high:#a31515; --medium:#8a5a00; --low:#176b3a;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:var(--brand)}
.container{max-width:1100px;margin:0 auto;padding:1rem}
.topbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;background:#0f1830;color:#fff;padding:.6rem 1rem}
.topbar a{color:#dce4f5;text-decoration:none}
.brand{font-weight:700;color:#fff !important;font-size:1.1rem;margin-right:1rem}
.mainnav{display:flex;flex-wrap:wrap;gap:.85rem;flex:1}
.mainnav a:hover{color:#fff;text-decoration:underline}
.userbox{display:flex;align-items:center;gap:.5rem;font-size:.9rem}
.role-badge{background:#1d4ed8;color:#fff;border-radius:.25rem;padding:.05rem .4rem;font-size:.7rem}
.inline{display:inline}
button.link{background:none;border:none;color:#dce4f5;cursor:pointer;text-decoration:underline;padding:0}
h1{font-size:1.5rem;margin:.3rem 0 1rem}
h2{font-size:1.15rem;margin:1rem 0 .5rem}
.card{background:var(--card);border:1px solid var(--line);border-radius:.5rem;padding:1rem;margin-bottom:1rem}
.card.narrow{max-width:560px}
.muted,.hint{color:var(--muted)}
.hint{font-size:.85rem}
label{display:block;font-weight:600;margin:.6rem 0 .2rem}
input,select,textarea{width:100%;padding:.5rem;border:1px solid var(--line);border-radius:.35rem;font:inherit;background:#fff;color:var(--ink)}
textarea{min-height:6rem;resize:vertical}
.btn{display:inline-block;background:#e8edf6;color:#143;border:1px solid var(--line);border-radius:.35rem;padding:.45rem .8rem;cursor:pointer;text-decoration:none;font:inherit;margin:.2rem .15rem 0 0}
.btn.primary{background:var(--brand);color:var(--brand-ink);border-color:var(--brand)}
.btn.danger{background:#fff;color:var(--err);border-color:var(--err)}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.alert{padding:.6rem .8rem;border-radius:.35rem;margin:.5rem 0}
.alert.error{background:#fbe9e7;color:var(--err);border:1px solid #f1b0a8}
.alert.success{background:#e6f4ea;color:var(--ok);border:1px solid #a7d7b5}
.alert.info{background:#e7eefc;color:#143a8a;border:1px solid #b4c8f0}
table.data{width:100%;border-collapse:collapse;margin:.5rem 0}
table.data th,table.data td{border-bottom:1px solid var(--line);padding:.45rem .5rem;text-align:left;vertical-align:top}
table.data th{background:#eef2f8;font-size:.85rem}
.badge{display:inline-block;background:#eef2f8;border:1px solid var(--line);border-radius:.25rem;padding:.05rem .4rem;font-size:.75rem}
.badge.p-high,.rating.r-high{color:var(--high);font-weight:700}
.badge.p-medium,.rating.r-medium{color:var(--medium);font-weight:700}
.badge.p-low,.rating.r-low{color:var(--low);font-weight:700}
.badge.s-active{color:var(--ok)}.badge.s-inactive{color:var(--warn)}.badge.s-terminated{color:var(--err)}
.badge.s-open{color:var(--ok)}.badge.s-closed{color:var(--muted)}
.badge.s-draft{color:var(--warn)}.badge.s-final{color:var(--ok)}.badge.s-superseded{color:var(--muted)}
.row-between{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.filters{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin:.5rem 0}
.filters input,.filters select{width:auto;min-width:9rem}
.empty-state{padding:1.5rem;text-align:center;color:var(--muted);background:#fafbfd;border:1px dashed var(--line);border-radius:.5rem}
.checklist{list-style:none;padding:0}.checklist li{padding:.2rem 0}.checklist li.done{color:var(--ok)}
.thread{list-style:none;padding:0}
.thread li{background:#f8fafc;border:1px solid var(--line);border-radius:.4rem;padding:.5rem .7rem;margin:.4rem 0}
.msg-meta{font-size:.75rem;color:var(--muted)}
.kv{display:grid;grid-template-columns:auto 1fr;gap:.2rem .8rem}
.kv dt{font-weight:600}
.pager{display:flex;gap:1rem;align-items:center;margin:.6rem 0;font-size:.9rem}
.big-metric{font-size:2.4rem;font-weight:800;color:var(--brand)}
.big-metric small{font-size:.9rem;font-weight:400;color:var(--muted)}
.report h2{border-top:1px solid var(--line);padding-top:.7rem}
.trace pre{white-space:pre-wrap;word-break:break-word;background:#0f1830;color:#cfe;padding:.6rem;border-radius:.4rem;font-size:.78rem}
.footer{text-align:center;color:var(--muted);padding:1.5rem}
.mt{margin-top:1rem}
.voice-wrap{position:relative}
.voice-btn{position:absolute;top:.3rem;right:.3rem;width:auto;padding:.15rem .4rem}
@media(max-width:640px){.topbar{flex-direction:column;align-items:flex-start}.mainnav{gap:.6rem}}
