/* The Laundering · Case 30 · "Subject Analysis" interactive HUD.
   Self-contained, scoped under #subject-analysis. Evokes the ad's dark
   holographic console. No external assets. Honors prefers-reduced-motion. */
#subject-analysis{
  --sa-bg:#06090f; --sa-panel:#0a1018; --sa-line:#16324a; --sa-cyan:#39c2ff;
  --sa-cyan-dim:#1c6e9c; --sa-ink:#cfe6f5; --sa-dim:#5e7d94; --sa-warn:#ffb454;
  --sa-red:#ff5a5a; --sa-mono:"JetBrains Mono",ui-monospace,monospace;
  position:relative; margin:34px 0; padding:0; color:var(--sa-ink);
  background:
    radial-gradient(120% 80% at 78% 18%, rgba(57,194,255,.10), transparent 60%),
    linear-gradient(180deg,#070b12,#05080d);
  border:1px solid var(--sa-line); border-radius:12px; overflow:hidden;
  font-family:var(--sa-mono); -webkit-font-smoothing:antialiased;
}
#subject-analysis *{box-sizing:border-box}
#subject-analysis .sa-scan{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(57,194,255,.06) 50%,transparent);
  background-size:100% 8px;opacity:.5;mix-blend-mode:screen;animation:sa-scanmove 7s linear infinite}
@keyframes sa-scanmove{from{background-position:0 -40px}to{background-position:0 40px}}
#subject-analysis .sa-top{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 16px;border-bottom:1px solid var(--sa-line);background:rgba(57,194,255,.04)}
#subject-analysis .sa-title{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sa-cyan)}
#subject-analysis .sa-status{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--sa-dim);
  display:inline-flex;align-items:center;gap:7px}
#subject-analysis .sa-dot{width:7px;height:7px;border-radius:50%;background:var(--sa-cyan);
  box-shadow:0 0 8px var(--sa-cyan);animation:sa-blink 1.6s ease-in-out infinite}
@keyframes sa-blink{50%{opacity:.25}}
#subject-analysis .sa-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:0}
@media(max-width:640px){#subject-analysis .sa-grid{grid-template-columns:1fr}}

/* Sensor suite */
#subject-analysis .sa-sensors{padding:14px 16px;border-right:1px solid var(--sa-line)}
@media(max-width:640px){#subject-analysis .sa-sensors{border-right:0;border-bottom:1px solid var(--sa-line)}}
#subject-analysis .sa-h{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sa-dim);margin:0 0 12px}
#subject-analysis .sa-chips{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
#subject-analysis .sa-chip{background:var(--sa-panel);border:1px solid var(--sa-line);border-radius:8px;
  padding:9px 8px;min-height:74px;display:flex;flex-direction:column;gap:5px;transition:border-color .3s,box-shadow .3s;opacity:.55}
#subject-analysis .sa-chip.on{opacity:1;border-color:var(--sa-cyan-dim);box-shadow:0 0 0 1px rgba(57,194,255,.18) inset}
#subject-analysis .sa-chip .ic{width:18px;height:18px;color:var(--sa-cyan)}
#subject-analysis .sa-chip .nm{font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sa-dim)}
#subject-analysis .sa-chip .vl{font-size:.66rem;line-height:1.25;color:var(--sa-ink);word-break:break-word}
#subject-analysis .sa-chip.off .vl{color:var(--sa-dim);font-style:italic}

/* Subject analysis panel */
#subject-analysis .sa-subject{padding:14px 16px;display:flex;flex-direction:column;gap:10px}
#subject-analysis .sa-metrics{display:flex;flex-direction:column;gap:9px}
#subject-analysis .sa-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  border-bottom:1px dotted rgba(94,125,148,.25);padding-bottom:7px}
#subject-analysis .sa-row .k{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sa-dim)}
#subject-analysis .sa-row .v{font-size:.82rem;color:var(--sa-ink);text-align:right;transition:color .2s}
#subject-analysis .sa-row .v.hot{color:var(--sa-cyan)}
#subject-analysis .sa-row .v.warn{color:var(--sa-warn)}
#subject-analysis .sa-learn{margin-top:4px}
#subject-analysis .sa-learn .lab{display:flex;justify-content:space-between;font-size:.58rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--sa-dim);margin-bottom:5px}
#subject-analysis .sa-bar{height:6px;background:#0c1622;border:1px solid var(--sa-line);border-radius:3px;overflow:hidden}
#subject-analysis .sa-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--sa-cyan-dim),var(--sa-cyan));
  box-shadow:0 0 10px rgba(57,194,255,.5);transition:width .6s ease-out}
#subject-analysis .sa-count{font-size:.6rem;letter-spacing:.1em;color:var(--sa-dim);text-transform:uppercase}
#subject-analysis .sa-count b{color:var(--sa-cyan);font-variant-numeric:tabular-nums}

/* Behavioral futures ticker */
#subject-analysis .sa-ticker{border-top:1px solid var(--sa-line);background:rgba(57,194,255,.03);
  padding:10px 16px;min-height:42px;display:flex;align-items:center;gap:10px;overflow:hidden}
#subject-analysis .sa-tag{flex:none;font-size:.54rem;letter-spacing:.14em;text-transform:uppercase;color:#06090f;
  background:var(--sa-cyan);padding:2px 6px;border-radius:3px}
#subject-analysis .sa-tline{font-size:.72rem;color:var(--sa-ink);opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s}
#subject-analysis .sa-tline.show{opacity:1;transform:none}
#subject-analysis .sa-tline em{color:var(--sa-dim);font-style:normal;font-size:.62rem}

/* Reveal / purge */
#subject-analysis .sa-reveal{border-top:1px solid var(--sa-line);padding:16px;background:linear-gradient(180deg,rgba(255,90,90,.05),transparent)}
#subject-analysis .sa-reveal h4{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sa-warn);margin:0 0 8px}
#subject-analysis .sa-reveal p{font-family:"Source Serif 4",Georgia,serif;font-size:.95rem;line-height:1.55;color:var(--sa-ink);margin:0 0 12px}
#subject-analysis .sa-reveal p .lock{color:var(--sa-warn)}
#subject-analysis .sa-actions{display:flex;flex-wrap:wrap;align-items:center;gap:12px}
#subject-analysis .sa-purge{font-family:var(--sa-mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;
  background:transparent;color:var(--sa-red);border:1px solid var(--sa-red);border-radius:5px;padding:8px 14px;cursor:pointer;
  transition:background .15s,color .15s}
#subject-analysis .sa-purge:hover{background:var(--sa-red);color:#06090f}
#subject-analysis .sa-purged{font-size:.66rem;letter-spacing:.04em;color:var(--sa-dim);font-style:italic}
#subject-analysis .sa-note{font-size:.56rem;letter-spacing:.08em;color:var(--sa-dim);text-transform:uppercase}

@media(prefers-reduced-motion: reduce){
  #subject-analysis .sa-scan,#subject-analysis .sa-dot{animation:none}
  #subject-analysis .sa-fill,#subject-analysis .sa-tline,#subject-analysis .sa-row .v{transition:none}
}

/* ---- Tier-1 edge-device sensor suite (the car's rack) ---- */
#subject-analysis .sa-suitewrap{padding:14px 16px;border-bottom:1px solid var(--sa-line)}
#subject-analysis .sa-suite{display:grid;grid-template-columns:repeat(6,1fr);gap:7px}
@media(max-width:640px){#subject-analysis .sa-suite{grid-template-columns:repeat(3,1fr)}}
#subject-analysis .sa-node{position:relative;overflow:hidden;background:var(--sa-panel);border:1px solid var(--sa-line);
  border-radius:7px;padding:8px 7px;display:flex;flex-direction:column;gap:3px}
#subject-analysis .sa-node .ic{width:16px;height:16px;color:var(--sa-cyan)}
#subject-analysis .sa-node .nn{font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sa-ink)}
#subject-analysis .sa-node .nh{font-size:.53rem;line-height:1.25;color:var(--sa-dim)}
#subject-analysis .sa-node .nt{position:absolute;top:7px;right:8px;font-size:.5rem;color:var(--sa-cyan-dim);letter-spacing:.12em}
#subject-analysis .sa-node::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:linear-gradient(90deg,transparent,var(--sa-cyan-dim),transparent);opacity:.7;animation:sa-sweep 2.8s linear infinite}
@keyframes sa-sweep{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ---- harvest manifest + extraction log ---- */
#subject-analysis .sa-harvest{border-top:1px solid var(--sa-line)}
#subject-analysis .sa-hcols{display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(max-width:640px){#subject-analysis .sa-hcols{grid-template-columns:1fr}}
#subject-analysis .sa-manifest{padding:14px 16px;border-right:1px solid var(--sa-line)}
@media(max-width:640px){#subject-analysis .sa-manifest{border-right:0;border-bottom:1px solid var(--sa-line)}}
#subject-analysis .sa-mrow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:7px 0;
  border-bottom:1px dotted rgba(94,125,148,.2)}
#subject-analysis .sa-mrow .md{font-size:.66rem;color:var(--sa-ink);display:flex;flex-direction:column;gap:2px}
#subject-analysis .sa-mrow .md .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--sa-dim);margin-right:7px}
#subject-analysis .sa-mrow.on .md .dot{background:var(--sa-cyan);box-shadow:0 0 6px var(--sa-cyan)}
#subject-analysis .sa-mrow .mdesc{font-size:.54rem;color:var(--sa-dim);padding-left:13px}
#subject-analysis .sa-mrow .mc{font-size:.6rem;color:var(--sa-dim);white-space:nowrap;font-variant-numeric:tabular-nums}
#subject-analysis .sa-mrow .mc.hit{color:var(--sa-cyan)}
#subject-analysis .sa-total{margin-top:10px;font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sa-dim)}
#subject-analysis .sa-total b{color:var(--sa-warn);font-variant-numeric:tabular-nums;font-size:.78rem}
#subject-analysis .sa-logwrap{padding:14px 16px;min-width:0}
#subject-analysis .sa-log{height:170px;overflow:hidden;display:flex;flex-direction:column;font-size:.6rem;line-height:1.55}
#subject-analysis .sa-ll{display:flex;gap:7px;white-space:nowrap;overflow:hidden;animation:sa-in .3s ease-out}
@keyframes sa-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
#subject-analysis .sa-ll .ts{color:var(--sa-cyan-dim);flex:none}
#subject-analysis .sa-ll .kk{color:var(--sa-ink);flex:none}
#subject-analysis .sa-ll .ar{color:var(--sa-dim);flex:none}
#subject-analysis .sa-ll .vv{color:var(--sa-dim);overflow:hidden;text-overflow:ellipsis}
@media(prefers-reduced-motion: reduce){#subject-analysis .sa-node::after,#subject-analysis .sa-ll{animation:none}}
