:root{
  --bg:#eef2f8; --bg2:#e7edf6; --card:#ffffff; --ink:#152033; --ink2:#33415a; --muted:#6b7a90;
  --line:#e2e8f1; --line2:#eef2f7;
  --accent:#2563eb; --accent2:#0ea5a4; --accent-ink:#1d4ed8;
  --pos:#0a8f5b; --pos-bg:#e7f8ef; --neg:#c2410c; --neg-bg:#fdeee6;
  --danger:#dc2626; --danger-bg:#fef2f2; --danger-line:#fca5a5;
  --stat:#dc2626; --routine:#b45309; --normal:#475569;
  --pt:#0e7490; --pt-bg:#e0f5fa; --dr:#4338ca; --dr-bg:#e8eaff;
  --shadow:0 1px 2px rgba(20,40,80,.06),0 4px 16px rgba(20,40,80,.05);
  --shadow-lg:0 6px 30px rgba(20,40,80,.12);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:
  radial-gradient(1200px 600px at 80% -10%,#dbe6fb 0,transparent 60%),
  radial-gradient(900px 500px at -10% 10%,#d7f1ef 0,transparent 55%),
  var(--bg);
  color:var(--ink);
  font:15px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased}
h1,h2,h3{margin:0}

/* ---------- header ---------- */
header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 22px;
  background:rgba(255,255,255,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:#fff;font-size:19px;
  background:linear-gradient(140deg,var(--accent),var(--accent2));box-shadow:0 4px 14px rgba(37,99,235,.35)}
.brand h1{font-size:19px;letter-spacing:-.01em}
.sub{font-size:12px;color:var(--muted)}
.ctrls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.spec{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}
.spec input{font:inherit;font-size:13px;color:var(--ink);background:#fff;border:1px solid var(--line);
  border-radius:9px;padding:7px 10px;width:150px;outline:none}
.spec input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12)}

.status{font-size:13px;color:var(--muted);display:inline-flex;align-items:center;gap:7px;font-weight:600;
  padding:6px 11px;border-radius:999px;background:#fff;border:1px solid var(--line)}
.status::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 0 0 currentColor}
.status.listening{color:var(--pos)} .status.listening::before{animation:pulse 1.6s infinite}
.status.reconnecting{color:#b8860b} .status.error{color:var(--neg)}
.status.assist{color:var(--accent)} .status.assist::before{animation:pulse 1s infinite}
.status.paused{color:#7c3aed}
@keyframes pulse{0%{box-shadow:0 0 0 0 currentColor}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}

button{font:inherit;font-weight:600;cursor:pointer;border:1px solid transparent;border-radius:10px;padding:9px 16px;transition:.15s}
button:active{transform:translateY(1px)}
.rec{color:#fff;background:var(--accent);box-shadow:0 4px 14px rgba(37,99,235,.3)}
.rec:hover{background:#1d4ed8}
.rec.on{background:var(--danger);box-shadow:0 4px 14px rgba(220,38,38,.3)}
.pause{color:var(--ink2);background:#fff;border-color:var(--line)}
.pause:hover{border-color:#cbd5e6}
.pause.paused{color:#7c3aed;border-color:#d6c8f5;background:#f7f2ff}
.ai{color:#fff;background:linear-gradient(135deg,#7c3aed,#2563eb);box-shadow:0 4px 14px rgba(124,58,237,.3)}
.ai:hover{filter:brightness(1.07)}

/* ---------- progress strip ---------- */
.progress{display:flex;align-items:center;gap:10px;padding:9px 22px;font-size:13px;color:var(--ink2);
  background:rgba(255,255,255,.6);border-bottom:1px solid var(--line2)}
.progress .dot{width:9px;height:9px;border-radius:50%;background:#c3cede;flex:0 0 auto}
.progress.busy .dot{background:var(--accent);animation:pulse 1.1s infinite}
.prog-text{color:var(--ink2)}

/* ---------- layout ---------- */
/* note is its OWN full-width row; transcript + plan are the columns below it */
main{display:grid;grid-template-columns:.95fr 1.3fr;grid-template-areas:"note note" "transcript plan";gap:16px;padding:16px 22px;align-items:start}
.note-pane{grid-area:note}
.transcript-pane{grid-area:transcript}
.plan-pane{grid-area:plan}
@media(max-width:860px){main{grid-template-columns:1fr;grid-template-areas:"note" "transcript" "plan"}}
/* full-width note flows its sections into balanced columns */
.note{column-width:300px;column-gap:26px}
.note>div{break-inside:avoid}
.pane{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px 17px;box-shadow:var(--shadow)}
.pane>h2,.note-head h2,.plan-pane>h2{font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:9px;font-weight:700}
.note-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px}
.note-head h2{margin:0}
.block{margin-bottom:8px}
.transcript{white-space:pre-wrap;max-height:76vh;overflow:auto;font-size:15px;color:var(--ink2)}
.hint{color:var(--muted);font-size:13.5px;margin:4px 0}
.muted{color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}

.spec-tag{font-size:12px;font-weight:700;color:var(--accent-ink);background:#eaf1ff;border:1px solid #d3e0fb;
  border-radius:999px;padding:3px 11px;text-transform:capitalize}

/* ---------- acute / severe banner ---------- */
.acute{background:var(--danger-bg);border:1px solid var(--danger-line);border-radius:12px;padding:11px 13px;margin-bottom:12px}
.acute-h{font-size:12px;font-weight:800;letter-spacing:.02em;color:var(--danger);text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:7px}
.acute .findings li{color:#7f1d1d}
.bang-inline{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:50%;background:var(--danger);color:#fff;font-weight:900;font-size:12px;line-height:1}

/* ---------- findings with speaker chips ---------- */
.findings{list-style:none;margin:4px 0;padding:0}
.findings li{display:flex;gap:8px;align-items:baseline;margin:4px 0}
.findings li.pos .ftext{color:var(--pos)} .findings li.neg .ftext{color:var(--neg)}
.spk{flex:0 0 auto;font-size:10px;font-weight:800;letter-spacing:.03em;padding:1px 6px;border-radius:6px;text-transform:uppercase;transform:translateY(-1px)}
.spk.pt{color:var(--pt);background:var(--pt-bg)} .spk.dr{color:var(--dr);background:var(--dr-bg)}
.ftext{flex:1}

/* ---------- AI assist panel ---------- */
.assist{border:1px solid #d8ddf7;border-radius:13px;padding:13px 14px;margin-bottom:14px;
  background:linear-gradient(180deg,#f6f8ff,#fbfcff);position:relative;transition:.25s}
.assist.active{border-color:#9db4ff;box-shadow:0 0 0 3px rgba(99,102,241,.18),var(--shadow-lg)}
.assist-title{font-size:12.5px;font-weight:800;color:var(--accent-ink);display:flex;align-items:center;gap:7px;margin-bottom:8px}
.assist-title .spark{color:#7c3aed}
.assist .section-title{margin-top:10px}
.cadence select{font:inherit;font-size:13px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 8px;outline:none}
.cadence select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12)}

/* highest-yield data points */
.dp-bar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:2px 0 4px}
.dp-label{font-size:12px;color:var(--ink2);font-weight:600}
.dp-btns{display:inline-flex;gap:5px}
button.dp{padding:4px 11px;border:1px solid #cdd7ea;background:#fff;color:var(--accent-ink);font-weight:800;border-radius:8px;font-size:13px}
button.dp:hover{background:#eef3ff;border-color:#9db4ff}
.datapoints{margin:6px 0 2px}
.dp-item{display:flex;align-items:baseline;gap:8px;padding:7px 9px;border:1px solid var(--line);border-radius:9px;margin:5px 0;background:#fff}
.dp-main{flex:1}
.dp-ask{font-weight:600;color:var(--ink)}
.dp-why{color:var(--muted);font-size:12.5px;margin-left:4px}
.dp-speak{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:7px;cursor:pointer;padding:3px 8px;font-weight:500}
.chip.dp-lab{background:#eafaf3;color:var(--pos)} .chip.dp-exam{background:#fff1e6;color:var(--neg)} .chip.dp-question{background:#eef2ff;color:var(--accent)}

/* on-demand evidence button */
button.show-ev{margin-top:8px;padding:7px 13px;border:1px solid #cdd7ea;background:#f6f9ff;color:var(--accent-ink);font-weight:700;border-radius:9px;font-size:12.5px}
button.show-ev:hover{background:#eaf1ff;border-color:#9db4ff}
.assist-e .exam-item{font-size:14px;color:var(--ink2);padding:6px 10px;border:1px dashed #d8ddf7;border-radius:8px;margin:5px 0;background:#fff;cursor:pointer;display:flex;align-items:center}
.assist-e .exam-item:hover{border-color:#9db4ff}
.assist-e .exam-item::before{content:"🔎 ";}

/* suggested-question rows */
.q{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--line);border-radius:10px;margin:6px 0;background:#fff}
.q span{flex:1}
.q button{flex:0 0 auto;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;padding:4px 9px;font-weight:500}
.q.speaking,.exam-item.speaking,.dp-item.speaking{border-color:var(--accent2);box-shadow:0 0 0 2px rgba(14,165,164,.18) inset}
/* persistent "read" state — shows which questions/tasks were spoken (by click OR by the AI) */
.q.read,.exam-item.read,.dp-item.read{background:#f0faf4;border-color:#cde9d8}
.q.read::after,.exam-item.read::after,.dp-item.read::after{content:"✓ read";flex:0 0 auto;color:var(--pos);font-weight:800;font-size:10.5px;margin-left:8px;align-self:center;white-space:nowrap}
.exam-item.read::after{margin-left:6px}

/* ---------- add-problem ---------- */
.add-prob{display:flex;gap:7px;margin:2px 0 6px}
.add-prob input{flex:1;font:inherit;font-size:13.5px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:9px;padding:8px 11px;outline:none}
.add-prob input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.add-prob button{flex:0 0 auto;color:#fff;background:var(--accent);border-radius:9px;padding:8px 14px;font-size:13px}
.add-prob button:hover{background:#1d4ed8}

/* ---------- problem cards (differential) — enumerated ---------- */
#problems{counter-reset:prob}
.problem{counter-increment:prob;border:1px solid var(--line);border-radius:13px;padding:13px 14px;margin:11px 0;background:#fff;box-shadow:var(--shadow)}
.problem .label::before{content:counter(prob) ". ";color:var(--muted);font-weight:800}
.problem.danger{border-color:var(--danger-line);background:linear-gradient(180deg,#fff8f8,#fff)}
.problem>.head{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.prob-x{margin-left:auto;flex:0 0 auto;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 5px;border-radius:6px;align-self:flex-start}
.prob-x:hover{color:var(--neg);background:#fdeee6}
.problem .bang{display:none}
.problem.danger .bang{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;
  background:var(--danger);color:#fff;font-weight:900;font-size:13px;flex:0 0 auto;transform:translateY(2px);
  box-shadow:0 2px 6px rgba(220,38,38,.4)}
.problem .label{font-weight:800;font-size:16px;letter-spacing:-.01em}
.problem.danger .label{color:#991b1b}
.problem .one{color:var(--muted);font-size:13px}
.prob-pct{flex:0 0 auto;font-size:11px;font-weight:800;padding:2px 8px;border-radius:999px;margin-left:1px;transform:translateY(-1px)}
.prob-pct.hi{color:#fff;background:var(--accent)}
.prob-pct.mid{color:#fff;background:var(--routine)}
.prob-pct.lo{color:var(--normal);background:#eef1f6;border:1px solid #dde3ec}
.problem .loading{color:var(--muted);font-size:13px;margin-top:8px}

/* per-problem pertinents (bold labels, always visible) */
.pert{margin:8px 0 4px}
.pert-k{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin:8px 0 2px}
.pert-k.pos{color:var(--pos)} .pert-k.neg{color:var(--neg)}
.pert .findings li{font-size:14px}

.section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:12px 0 5px;font-weight:700}

/* orders + urgency */
.order{display:flex;gap:9px;align-items:flex-start;margin:6px 0}
.order-main{flex:1;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.chip{flex:0 0 auto;font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:2px 8px;border-radius:999px;
  background:#eef2ff;color:var(--accent);font-weight:800;margin-top:1px}
.chip.lab{background:#eafaf3;color:var(--pos)} .chip.imaging{background:#fff1e6;color:var(--neg)}
.chip.medication{background:#eef2ff;color:var(--accent)} .chip.referral{background:#f3eefb;color:#7c3aed}
.urg{flex:0 0 auto;font-size:9.5px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:6px}
.urg.stat{color:#fff;background:var(--stat);box-shadow:0 1px 4px rgba(220,38,38,.4)}
.urg.routine{color:#fff;background:var(--routine)}
.urg.normal{color:var(--normal);background:#eef1f6;border:1px solid #dde3ec}
.ord-x{flex:0 0 auto;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:12px;padding:1px 5px;border-radius:6px}
.ord-x:hover{color:var(--neg);background:#fdeee6}

/* add-order footer on each problem card */
.card-foot{display:flex;gap:6px;margin-top:10px;padding-top:9px;border-top:1px dashed var(--line)}
.order-in{flex:1;font:inherit;font-size:12.5px;color:var(--ink);background:#fbfdff;border:1px solid var(--line);border-radius:8px;padding:6px 9px;outline:none}
.order-in:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.order-add{flex:0 0 auto;color:var(--accent-ink);background:#eef3ff;border:1px solid #cdd7ea;border-radius:8px;padding:6px 11px;font-size:12.5px;font-weight:700}
.order-add:hover{background:#e2ebff;border-color:#9db4ff}

/* citations: dotted underline, hover popover */
.cite{border-bottom:1px dotted var(--accent);cursor:help}
.pop{position:fixed;z-index:50;max-width:360px;background:#0f1b2d;color:#eaf1ff;border-radius:10px;padding:11px 13px;
  font-size:13px;line-height:1.5;box-shadow:0 12px 34px rgba(0,0,0,.32);opacity:0;pointer-events:none;transition:opacity .12s;transform:translateY(-4px)}
.pop.show{opacity:1}
.pop .q{all:unset;display:block;font-style:italic;margin-bottom:6px;color:#cfe0ff}
.pop a{color:#7db1ff}
.pop .ctx{color:#9fb4d4;font-size:12px}

/* expandable evidence */
details.ev{margin-top:9px;border-top:1px dashed var(--line);padding-top:8px}
details.ev>summary{cursor:pointer;font-size:12.5px;color:var(--accent);font-weight:700;list-style:none}
details.ev>summary::-webkit-details-marker{display:none}
details.ev>summary::before{content:"▸ "}
details.ev[open]>summary::before{content:"▾ "}
.ev .row{margin:8px 0}
.ev .k{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.ev ul{margin:3px 0;padding-left:18px}
.ev li{margin:2px 0}
.goal{display:inline-block;background:var(--pos-bg);color:var(--pos);border-radius:7px;padding:2px 9px;font-weight:700}
.guide{color:var(--muted);font-size:12.5px}
.src{font-size:12px;margin:3px 0}
.src a{color:var(--accent)}

/* full structured note */
.note h3{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin:14px 0 4px;font-weight:700}
.note>div:first-child h3{margin-top:2px}
.note p{margin:3px 0;color:var(--ink2)}
.pos{color:var(--pos)} .neg{color:var(--neg)}

#toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#0f1b2d;color:#fff;
  padding:11px 16px;border-radius:10px;opacity:0;transition:.2s;pointer-events:none;z-index:60;box-shadow:var(--shadow-lg);max-width:90vw}
#toast.show{opacity:1}
