/* BC Tool design system — ported from the mockup at
   mca-poc/mockups/background_check_tool/index.html (read-only UX reference).
   Re-architected as server-rendered Django templates; no client-side
   renderers copied — only the visual language (variables, classes, layout). */

:root{
  --bg:#f0eeeb; --panel:#fdfcfa; --ink:#3d3c3a; --muted:#8a8278; --line:#e0dbd5;
  --tint:#eae7e2; --tint-soft:#efede9; --ink-2:#55534f; --faint:#c9c4bc;
  --accent-line:#d6e0fd; --accent-faint:#f7f9ff; --hi-line:#f3c9c9; --hi-ink:#7a2020;
  --med-line:#f3dcae; --med-ink:#7a5304;
  --accent:#2f5bea; --accent-soft:#eaeffe; --clearblue:#1F4E79;
  --hi:#e03131; --hi-soft:#fdecec; --med:#e8920c; --med-soft:#fdf3e2; --ok:#2f9e44; --ok-soft:#e9f7ee;
  --src-clear:#2f5bea; --src-merch:#7c3aed; --src-court:#0d9488; --src-web:#d9740a; --src-exp:#c2255c;
  --shadow:0 1px 2px rgba(30,25,20,.05),0 6px 18px rgba(30,25,20,.04);
  --fs:13px; --cardpad:11px 13px; --gap:8px; --rowpad:8px 11px; --h1:19px; --sec-gap:14px;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:var(--fs);line-height:1.4}
button{font-family:inherit;font-size:var(--fs);cursor:pointer;border:none;background:none}
a{color:var(--accent);text-decoration:none}
table{border-collapse:collapse}

.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:9px;font-weight:600;border:1px solid var(--line);background:var(--panel);color:var(--ink);transition:.12s;font-size:var(--fs)}
.btn:hover{background:var(--tint)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{background:#2549c9}
.btn.danger{background:var(--panel);color:var(--hi);border-color:var(--hi-line)}
.btn.danger:hover{background:var(--hi-soft)}
.btn.sm{padding:4px 8px;font-size:calc(var(--fs) - 1px);border-radius:7px}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--tint)}
.btn[disabled]{opacity:.45;cursor:not-allowed}
.spacer{flex:1}
.hint{color:var(--muted);font-size:calc(var(--fs) - .5px)}

.pill{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px;background:var(--med-soft);color:var(--med);text-transform:uppercase;letter-spacing:.4px}
.pill.risk-hi{background:var(--hi-soft);color:var(--hi)}
.pill.risk-none{background:var(--tint-soft);color:var(--muted)}

.src-badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:7px;color:#fff;text-align:center;display:inline-block}
.b-clear{background:var(--src-clear)} .b-merch{background:var(--src-merch)} .b-court{background:var(--src-court)}
.b-web{background:var(--src-web)} .b-exp{background:var(--src-exp)}
.f-src{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;background:var(--tint-soft);color:var(--muted);border:1px solid var(--line);white-space:nowrap;display:inline-block}

.offtag{font-size:9px;font-weight:800;letter-spacing:.5px;color:var(--muted);border:1px solid var(--line);border-radius:4px;padding:0 4px;margin-left:5px;text-transform:uppercase;white-space:nowrap}
.rail-item.rail-off{opacity:.7}
.rail-item.rail-off .src-badge{filter:grayscale(1);opacity:.65}

/* top bar */
.topbar{height:54px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:0 16px;position:sticky;top:0;z-index:40}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;white-space:nowrap;color:var(--ink)}
.logo .mark{width:28px;height:28px;border-radius:8px;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800}
.gsearch{position:relative;flex:1;max-width:480px;display:flex;align-items:stretch;border:1px solid var(--line);border-radius:9px;background:var(--tint)}
.gsearch:focus-within{background:var(--panel);border-color:var(--accent)}
.gsearch input{flex:1;min-width:0;border:none;border-radius:9px;padding:8px 12px;outline:none;background:transparent;font-size:var(--fs)}
.topbar-user{font-size:calc(var(--fs) - .5px);color:var(--muted);white-space:nowrap}

/* ALL DEALS */
.cases-wrap{max-width:1180px;margin:0 auto;padding:20px}
.cases-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.cases-head h1{font-size:var(--h1);margin:0}
table.cases{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
table.cases th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:9px 13px;border-bottom:1px solid var(--line);background:var(--tint-soft);white-space:nowrap}
table.cases td{padding:10px 13px;border-bottom:1px solid var(--line)}
table.cases tr:last-child td{border-bottom:none}
table.cases tbody tr:hover td{background:var(--tint)}
table.cases tbody tr{cursor:pointer}
.cs-name{font-weight:700}
.stat{display:inline-flex;align-items:center;gap:6px;font-size:calc(var(--fs) - .5px);font-weight:600}
.dot{width:8px;height:8px;border-radius:50%;flex:none;display:inline-block}
.st-intake{background:var(--accent)} .st-running{background:#8b5cf6} .st-review{background:var(--med)}
.st-decided{background:var(--ok)} .st-aborted{background:var(--hi)}

/* CASE / DEAL WORKSPACE */
.case-screen{display:flex;min-height:calc(100vh - 54px)}
.rail{width:236px;min-width:236px;background:var(--panel);border-right:1px solid var(--line);overflow:auto;padding:11px 9px}
.rail .back{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:9px;font-weight:700;color:var(--ink);border:1px solid var(--line);margin-bottom:11px;background:var(--panel)}
.rail .back:hover{background:var(--tint)}
.rail-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:9px;cursor:pointer;font-weight:600;color:var(--ink);margin-bottom:2px;text-decoration:none}
.rail-item:hover{background:var(--tint)}
.rail-item.active{background:var(--accent-soft);color:var(--accent)}
.rail-item .rc{margin-left:auto;font-size:11px;font-weight:700}
.rail-group{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:14px 10px 6px}
.rc-found{color:var(--hi)} .rc-done{color:var(--ok)} .rc-idle{color:var(--muted)}
.rc-running{color:var(--accent)} .rc-queued{color:var(--med)} .rc-failed{color:var(--hi)}

.case-main{flex:1;overflow:auto;padding:14px 20px 90px}
.case-inner{max-width:1000px}
.deal-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:11px 15px;margin-bottom:var(--sec-gap);box-shadow:var(--shadow)}
.deal-strip h1{font-size:var(--h1);margin:0}
.chip{font-size:calc(var(--fs) - .5px);background:var(--tint-soft);border:1px solid var(--line);border-radius:8px;padding:3px 9px;color:var(--ink)}
.chip b{color:var(--ink)}

.tabnav{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:var(--sec-gap);border-bottom:1px solid var(--line);padding-bottom:8px}
.tabnav a{font-size:calc(var(--fs) - .5px);border:1px solid var(--line);border-radius:999px;padding:5px 11px;background:var(--panel);font-weight:600;color:var(--ink)}
.tabnav a.active{background:var(--accent);border-color:var(--accent);color:#fff}
.tabnav a:hover:not(.active){background:var(--tint)}

.section-row{display:flex;align-items:center;justify-content:space-between;margin:2px 0 11px;gap:10px;flex-wrap:wrap}
.section-row h2{font-size:calc(var(--fs) + 2px);margin:0}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow);padding:var(--cardpad);margin-bottom:12px}
.empty{color:var(--muted);text-align:center;padding:30px;border:1px dashed var(--line);border-radius:12px;background:var(--tint-soft)}
.run-cta{display:flex;flex-direction:column;align-items:center;gap:11px;padding:32px;border:1px dashed var(--line);border-radius:12px;background:var(--tint-soft);text-align:center}

/* aligned findings table */
table.findings{width:100%;border-collapse:collapse;font-size:var(--fs);background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;font-variant-numeric:tabular-nums}
table.findings th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);padding:8px 10px;border-bottom:1px solid var(--line);background:var(--tint-soft);white-space:nowrap}
table.findings td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
table.findings tr:last-child td{border-bottom:none}
table.findings th.num,table.findings td.num{text-align:right}
table.findings .dash{color:var(--faint)}
table.findings tr.ignored{opacity:.5}
.stt-open{color:var(--hi);font-weight:700} .stt-closed{color:var(--ok);font-weight:700}
.ign-btn{font-size:10px;font-weight:700;color:var(--muted);background:transparent;border:1px solid var(--line);border-radius:999px;padding:1px 8px;cursor:pointer;white-space:nowrap}
.ign-btn:hover{color:var(--hi);border-color:var(--hi)}

/* modal / decision dialogs */
.overlay-inline{display:flex;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:16px;width:480px;max-width:100%;box-shadow:0 24px 60px rgba(15,20,40,.3);padding:20px}
.modal h3{margin:0 0 4px;font-size:16px}
.modal p.sub{margin:0 0 14px;color:var(--muted)}
.modal-actions{display:flex;gap:9px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}
.opt-row{display:flex;gap:9px;flex-wrap:wrap}
.opt{flex:1;min-width:120px;border:1px solid var(--line);border-radius:11px;padding:12px;cursor:pointer;text-align:center;font-weight:700;background:var(--panel)}
.opt:hover{border-color:var(--accent);background:var(--accent-soft)}
.opt:disabled{opacity:.5;cursor:not-allowed}
.reason-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.reason{display:flex;align-items:center;gap:8px;padding:6px 9px;border:1px solid var(--line);border-radius:9px;font-size:calc(var(--fs) - 1px)}
.form-error{background:var(--hi-soft);color:var(--hi-ink);border:1px solid var(--hi-line);border-radius:9px;padding:9px 12px;margin-bottom:10px;font-size:calc(var(--fs) - .5px)}

/* run progress fragment */
.progress-box{border:1px solid var(--line);border-radius:11px;background:var(--panel);padding:10px 13px;margin-bottom:12px}
.progress-row{display:flex;align-items:center;gap:9px;padding:5px 0}
.progress-row .spin{width:12px;height:12px;border-radius:50%;border:2px solid var(--line);border-top-color:var(--accent);animation:bctool-rot .8s linear infinite;flex:none}
@keyframes bctool-rot{to{transform:rotate(360deg)}}
.progress-step-status{margin-left:auto;font-size:calc(var(--fs) - 1px);color:var(--muted);font-weight:600}

/* History timeline */
.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-node{position:relative;margin-bottom:var(--gap)}
.tl-dot{position:absolute;left:-20px;top:4px;width:11px;height:11px;border-radius:50%;background:var(--accent);border:2px solid var(--panel);box-shadow:0 0 0 2px var(--line)}
.tl-dot.g{background:var(--ok)} .tl-dot.o{background:var(--med)} .tl-dot.r{background:var(--hi)}
.tl-card{border:1px solid var(--line);border-radius:9px;padding:8px 11px;background:var(--panel)}
.tl-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tl-act{font-weight:700} .tl-meta{color:var(--muted);font-size:calc(var(--fs) - 1px);margin-left:auto;white-space:nowrap}
.tl-sub{color:var(--ink-2);font-size:calc(var(--fs) - .5px);margin-top:2px}

.messages{max-width:1000px;margin:10px auto 0}
.message{border-radius:9px;padding:9px 13px;margin-bottom:8px;font-size:calc(var(--fs) - .5px)}
.message.success{background:var(--ok-soft);color:var(--ok)}
.message.error{background:var(--hi-soft);color:var(--hi-ink)}
.message.info{background:var(--accent-soft);color:var(--accent)}

/* --- findings gist + two-tier citation rendering (architecture §5 am. 3) --- */
table.findings .gist{margin-top:3px;font-size:12.5px;color:#555;max-width:520px}
.ground{display:inline-block;margin-left:6px;padding:0 6px;border-radius:8px;font-size:10.5px;vertical-align:1px}
.ground.ok{background:#e6f4ea;color:#1e7e34;border:1px solid #bfe3c8}
.ground.claim{background:#fdf3e3;color:#9a6b00;border:1px solid #f0dcae}
.pill.warn{background:#fdf3e3;color:#9a6b00;border:1px solid #f0dcae;margin-left:6px;font-size:10.5px;padding:0 6px;border-radius:8px}
.pick-row.pick-off{opacity:.55}
.pick-why{font-size:11px;color:#777;margin-left:6px}

/* --- UI wave 2 (appended block; see web/views.py "UI wave 2" comments) --- */

/* spec 8.8a: clickable source pills look like links — accent + tint + ↗ —
   everywhere (findings, UCC, entities/people Source column). Non-clickable
   pills keep the existing muted .f-src look untouched. */
.f-src-link{background:var(--accent-faint);border-color:var(--accent-line);color:var(--accent);font-weight:700}
.f-src-link:hover{background:var(--accent-soft)}

/* pure-CSS :target flash on the report viewer — no vendored JS (spec 8.8a) */
table.findings tr.report-record-row:target{animation:bctool-target-flash 2.2s ease-out 1}
@keyframes bctool-target-flash{
  0%{background:var(--accent-soft)}
  100%{background:transparent}
}

/* applicant chips (spec 7.9) */
.chip.applicant-chip{display:inline-flex;align-items:center;gap:4px}

/* decided banner (spec 17) */
.decided-banner{display:flex;align-items:center;gap:10px}
.decided-banner b{color:var(--ok)}

/* hand-pick union rows (spec 15.11b) reuse .reason-list/.reason; no new
   classes needed beyond what decision dialogs already carry. */

/* --- UI wave 3 (appended block; see web/views.py "UI wave 3" comments) --- */

/* Focus filter (spec 7.8): dimmed rows stay fully visible, never hidden —
   the SAME family as .ignored (opacity, not display:none), so a row can be
   both dimmed AND ignored without conflict. */
table.findings tr.dimmed, .tl-node.dimmed, tr.dimmed { opacity: .45 }
.tl-node.dimmed .tl-card { background: var(--tint-soft) }

.focus-chip select{border:1px solid var(--line);border-radius:8px;padding:3px 7px;background:transparent;color:inherit;font:inherit;font-size:calc(var(--fs) - 1px);cursor:pointer}
.focus-banner{display:flex;align-items:center;gap:9px;flex-wrap:wrap;background:var(--accent-soft);border-color:var(--accent-line);color:var(--accent);font-weight:600}
.focus-banner .btn{margin-left:auto}
.focus-banner b{color:var(--accent)}

/* Prior-submission picker + historical read-only banner (spec 13) */
.sub-picker{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.sub-picker-chip{border:1px solid var(--line);border-radius:999px;padding:4px 11px;background:var(--panel);font-weight:600}
.sub-picker-chip.on{background:var(--accent);border-color:var(--accent);color:#fff}
.historical-banner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--hi-soft);border-color:var(--hi-line);color:var(--hi-ink)}
.historical-banner b{color:var(--hi)}
.historical-banner .btn{margin-left:auto}

/* Re-check / actualization PRIOR vs CURRENT (spec 13.5/13.6) */
.actualization{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px;padding:8px 10px;border:1px solid var(--accent-line);background:var(--accent-faint);border-radius:9px;font-size:calc(var(--fs) - .5px)}
.actualization-col{flex:1;min-width:160px}

/* Drag-to-reorder handle (spec 8.5/11.7) */
.drag-handle{cursor:grab;color:var(--muted);margin-right:4px;user-select:none}
.drag-handle:active{cursor:grabbing}
tr.sortable-ghost{opacity:.3}
tr.sortable-chosen{background:var(--tint)}

/* Report-a-problem footer link (POC item 86) */
.app-footer{padding:14px 20px;text-align:center}
.app-footer a{color:var(--muted);font-size:calc(var(--fs) - 1px);text-decoration:none}
.app-footer a:hover{color:var(--accent);text-decoration:underline}

/* Manual takeover (spec 3.1): a small text link next to the rail's Run
   button, and its record-entry table. */
.manual-link{font-size:calc(var(--fs) - 1px);color:var(--accent);text-decoration:none;margin-left:6px}
.manual-link:hover{text-decoration:underline}
tr.manual-row input{border:1px solid var(--line);border-radius:6px;padding:4px 6px;font:inherit;font-size:calc(var(--fs) - 1px)}

/* Guided tour overlay (spec 4.1a) — no-dependency, plain fixed-position card */
.bctool-tour-overlay{position:fixed;inset:0;background:rgba(20,18,15,.35);z-index:1000;display:flex;align-items:flex-end;justify-content:center;padding:24px}
.bctool-tour-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px rgba(15,20,40,.35);padding:18px 20px;max-width:420px;width:100%}
.bctool-tour-card h3{margin:0 0 6px;font-size:15px}
.bctool-tour-card p{margin:0 0 8px}
.bctool-tour-highlight{position:relative;z-index:1001;outline:3px solid var(--accent);outline-offset:2px;border-radius:8px}
