/* ============================================================
   Fynch AI — workshops.css
   Interactive workshop tooling + participant mobile view.
   Inherits all tokens from styles.css.
   ============================================================ */

/* ---- workshop slide frame ---- */
.ws{display:flex; flex-direction:column; height:100%; gap:22px;}
.ws-head{display:flex; align-items:flex-start; justify-content:space-between; gap:24px;}
.ws-head .left{display:flex; flex-direction:column; gap:8px;}
.ws-badge{display:inline-flex; align-items:center; gap:10px; font-family:var(--font-mono);
  font-size:14px; letter-spacing:1.5px; text-transform:uppercase; color:var(--brand-600); font-weight:500;}
.ws-badge .num{display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px;
  border-radius:7px; background:var(--brand-500); color:#fff; font-size:15px;}
.ws-controls{display:flex; align-items:center; gap:12px;}
.ws-avatars{display:flex; align-items:center;}
.ws-av{width:34px; height:34px; border-radius:50%; background:var(--brand-100); color:var(--brand-700); border:2px solid var(--surface);
  display:inline-flex; align-items:center; justify-content:center; font-size:12px; font-weight:600; margin-left:-8px; font-family:var(--font-sans);}
.ws-av:first-child{margin-left:0;}
.ws-av.more{background:var(--ink-700); color:#fff;}

/* live session pill (host) */
.session-pill{display:flex; align-items:center; gap:10px; background:var(--surface);
  border:1px solid var(--line-200); border-radius:var(--r-pill); padding:6px 14px 6px 12px; font-size:14px; color:var(--ink-600);}
.session-pill .live{width:9px;height:9px;border-radius:50%;background:#10b981; box-shadow:0 0 0 3px rgba(16,185,129,.18);}
.session-pill b{color:var(--ink-900); font-weight:600;}
.session-pill .code{font-family:var(--font-mono); letter-spacing:2px; color:var(--brand-600); font-weight:600;}
.session-pill .ppl{display:inline-flex; align-items:center; gap:5px; color:var(--ink-500); padding-left:10px; border-left:1px solid var(--line-200);}

.lock-toggle{display:inline-flex; align-items:center; gap:8px; cursor:pointer; user-select:none;
  font-size:14px; font-weight:600; color:var(--ink-600); border:1px solid var(--line-200);
  background:var(--surface); border-radius:var(--r-control); height:38px; padding:0 14px;}
.lock-toggle.locked{color:var(--review-fg); background:var(--review-bg); border-color:var(--review-border);}
.lock-toggle svg{width:16px;height:16px;stroke-width:2;}

/* ============================================================
   WORKSHOP 1 — pipeline / kanban mapper
   ============================================================ */
.pipeline{display:flex; gap:14px; overflow-x:auto; padding:6px 2px 16px; flex:1; align-items:stretch;}
.pipeline::-webkit-scrollbar{height:10px;}
.pipeline::-webkit-scrollbar-thumb{background:var(--line-300); border-radius:9999px;}
.stage-card{flex:0 0 322px; background:var(--surface); border:1px solid var(--line-200);
  border-radius:var(--r-card); display:flex; flex-direction:column; min-height:0; transition:box-shadow .15s, border-color .15s;}
.stage-card.dragging{opacity:.45;}
.stage-card.drop-target{border-color:var(--brand-500); box-shadow:var(--ring);}
.stage-card .sc-head{display:flex; align-items:center; gap:11px; padding:15px 16px 11px;}
.stage-card .sc-order{font-family:var(--font-mono); font-size:15px; font-weight:600; color:var(--brand-500); flex:0 0 auto;}
.stage-card .sc-name{font-size:21px; font-weight:600; line-height:1.15; flex:1; letter-spacing:-.01em;}
.stage-card .sc-name[contenteditable]:focus{outline:none; box-shadow:var(--ring); border-radius:4px;}
.sc-move{display:flex; gap:3px; flex:0 0 auto;}
.sc-move button{width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--line-200); background:var(--surface); color:var(--ink-500); border-radius:6px; cursor:pointer;}
.sc-move button:hover:not(:disabled){background:var(--canvas); color:var(--ink-900); border-color:var(--line-300);}
.sc-move button:disabled{opacity:.3; cursor:default;}
.sc-move button.rm:hover{color:var(--conflict-fg); border-color:var(--conflict-border); background:var(--conflict-bg);}
.stage-card .sc-body{padding:0 16px 14px; display:flex; flex-direction:column; gap:11px; flex:1;}
.sc-field{display:flex; flex-direction:column; gap:3px;}
.sc-field .fl{font-size:12px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; color:var(--ink-400);}
.sc-field .fv{font-size:16px; color:var(--ink-700); line-height:1.35;}
.sc-field .fv[contenteditable]:focus{outline:none; box-shadow:var(--ring); border-radius:4px;}
.sc-tags{display:flex; flex-wrap:wrap; gap:6px; margin-top:2px;}
.systag{font-family:var(--font-mono); font-size:12.5px; padding:3px 9px; border-radius:var(--r-chip);
  background:var(--line-100); color:var(--ink-600); border:1px solid var(--line-200); cursor:pointer; white-space:nowrap;}
.systag.on{background:var(--brand-50); color:var(--brand-700); border-color:var(--brand-200);}
.sc-foot{border-top:1px solid var(--line-100); padding:12px 16px; display:flex; flex-direction:column; gap:8px;}
.sc-foot .fl{font-size:12px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; color:var(--ink-400);}
.sev-seg{display:grid; grid-template-columns:repeat(4,1fr); gap:5px;}
.sev-seg button{font-family:inherit; font-size:13px; font-weight:600; padding:7px 0; border:1px solid var(--line-200); background:var(--surface); color:var(--ink-500); border-radius:6px; cursor:pointer;}
.sev-seg button:hover{border-color:var(--line-300);}
.sev-seg button.on{color:#fff;}
.sev-seg button.on.lv0{background:var(--ink-400); border-color:var(--ink-400);}
.sev-seg button.on.lv1{background:var(--approved-fg); border-color:var(--approved-fg);}
.sev-seg button.on.lv2{background:var(--review-fg); border-color:var(--review-fg);}
.sev-seg button.on.lv3{background:var(--conflict-fg); border-color:var(--conflict-fg);}
.pipeline .add-stage{flex:0 0 86px; border:1.5px dashed var(--line-300); border-radius:var(--r-card);
  display:flex; align-items:center; justify-content:center; color:var(--ink-400); cursor:pointer; background:transparent;}
.pipeline .add-stage:hover{border-color:var(--brand-300); color:var(--brand-500);}

/* auto-summary panel (right rail / bottom) */
.auto-panel{background:var(--surface); border:1px solid var(--line-200); border-radius:var(--r-card); padding:20px 22px; display:flex; flex-direction:column; gap:16px;}
.auto-panel h4{margin:0; font-size:14px; font-weight:600; letter-spacing:.5px; text-transform:uppercase; color:var(--ink-400);}
.auto-stat{display:flex; align-items:baseline; gap:12px;}
.auto-stat .n{font-size:38px; font-weight:600; letter-spacing:-.02em; font-variant-numeric:tabular-nums; line-height:1;}
.auto-stat .l{font-size:14px; color:var(--ink-500); line-height:1.3;}
.auto-obs{display:flex; flex-direction:column; gap:9px;}
.auto-obs .o{display:flex; gap:10px; align-items:flex-start; font-size:14px; color:var(--ink-700); line-height:1.4;}
.auto-obs .o .rank{font-family:var(--font-mono); font-weight:600; color:var(--brand-500); flex:0 0 auto;}

/* ============================================================
   WORKSHOP 2 — friction heatmap
   ============================================================ */
.heatmap{width:100%; border-collapse:separate; border-spacing:0; font-size:16px;}
.heatmap th{padding:6px 8px; font-size:14px; font-weight:600; color:var(--ink-500); text-align:center; vertical-align:bottom; line-height:1.2;}
.heatmap th.rowhead{text-align:left; width:300px; color:var(--ink-400); text-transform:uppercase; letter-spacing:.5px;}
.heatmap td.rowhead{text-align:left; font-size:17px; font-weight:600; color:var(--ink-900); padding:6px 14px 6px 4px;}
.heatmap td.rowhead .ix{font-family:var(--font-mono); color:var(--ink-300); margin-right:8px; font-weight:400;}
.hcell{width:126px; height:52px; text-align:center; vertical-align:middle; padding:3px;}
.hcell .box{height:100%; border-radius:6px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  cursor:pointer; position:relative; border:1px solid rgba(15,23,42,.05); transition:transform .08s;}
.hcell .box:hover{transform:scale(1.04); box-shadow:var(--shadow-pop);}
.hcell .box .sc{font-size:23px; font-weight:600; font-variant-numeric:tabular-nums; line-height:1;}
.hcell .box .var{position:absolute; bottom:4px; right:5px; font-size:11px; opacity:.75; font-family:var(--font-mono);}
.hcell .box.disagree::after{content:""; position:absolute; top:4px; right:5px; width:7px; height:7px; border-radius:50%; background:#7c3aed; box-shadow:0 0 0 2px rgba(255,255,255,.7);}
.heat-legend{display:flex; align-items:center; gap:14px; font-size:15px; color:var(--ink-500);}
.heat-legend .scale{display:flex; height:12px; border-radius:9999px; overflow:hidden; width:200px;}
.heat-legend .scale span{flex:1;}

/* ============================================================
   WORKSHOP 3 — source-to-fact trust map
   ============================================================ */
.trust-tbl{font-size:16px;}
.trust-tbl table{width:100%; border-collapse:collapse;}
.trust-tbl thead th{position:sticky; top:0; background:var(--subtle); z-index:2; cursor:pointer;
  text-align:left; font-size:11px; font-weight:600; letter-spacing:.5px; text-transform:uppercase;
  color:var(--ink-400); padding:10px 12px; border-bottom:1px solid var(--line-200); white-space:nowrap;}
.trust-tbl thead th.c{text-align:center;}
.trust-tbl tbody td{padding:11px 12px; border-top:1px solid var(--line-100); color:var(--ink-700); vertical-align:middle;}
.trust-tbl tbody tr.risk{background:#fef6f6;}
.trust-tbl tbody tr.risk:hover{background:#fef2f2;}
.trust-tbl tbody tr:hover{background:var(--canvas);}
.trust-tbl .fact{font-weight:600; color:var(--ink-900);}
.conf-pip{display:inline-flex; gap:3px; align-items:center;}
.conf-pip .p{width:9px; height:9px; border-radius:2px; background:var(--line-200);}
.conf-pip .p.on{background:var(--approved-fg);}
.conf-pip .p.on.lo{background:var(--conflict-fg);}
.conf-pip .p.on.md{background:var(--review-fg);}
.blocker-dot{display:inline-flex; align-items:center; justify-content:center; width:24px; height:24px; border-radius:6px; cursor:pointer;
  background:var(--missing-bg); color:var(--missing-fg); border:1px solid var(--missing-border); font-weight:700; font-size:13px;}
.blocker-dot.on{background:var(--conflict-bg); color:var(--conflict-fg); border-color:var(--conflict-border);}
.imp-select, .src-input{font-family:var(--font-sans); font-size:13px; border:1px solid var(--line-200);
  border-radius:6px; padding:4px 8px; color:var(--ink-700); background:var(--surface); max-width:150px;}
.imp-select:focus, .src-input:focus{outline:none; box-shadow:var(--ring);}
.coverage-meter{display:flex; align-items:center; gap:14px;}
.coverage-meter .bar{width:240px; height:10px; border-radius:9999px; background:var(--line-200); overflow:hidden;}
.coverage-meter .bar .fill{height:100%; background:var(--brand-500); border-radius:9999px; transition:width .4s;}

/* ============================================================
   WORKSHOP 4 — build / buy / hybrid matrix + iceberg
   ============================================================ */
.matrix-tbl{font-size:15px; width:100%;}
.matrix-tbl table{width:100%; border-collapse:collapse; table-layout:fixed;}
.matrix-tbl th:nth-child(1),.matrix-tbl td:nth-child(1){width:23%;}
.matrix-tbl th:nth-child(n+2):nth-child(-n+6),.matrix-tbl td:nth-child(n+2):nth-child(-n+6){width:10.4%;}
.matrix-tbl th:nth-child(7),.matrix-tbl td:nth-child(7){width:12%;}
.matrix-tbl th:nth-child(8),.matrix-tbl td:nth-child(8){width:13%;}
.matrix-tbl thead th{background:var(--subtle); text-align:center; font-size:12px; font-weight:600;
  letter-spacing:.5px; text-transform:uppercase; color:var(--ink-400); padding:8px 6px; border-bottom:1px solid var(--line-200);}
.matrix-tbl thead th.rowhead{text-align:left;}
.matrix-tbl tbody td{padding:3px 8px; border-top:1px solid var(--line-100); vertical-align:middle;}
.matrix-tbl .layer{font-weight:600; color:var(--ink-900); font-size:15px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.vote-cell{text-align:center;}
.vote-opt{display:flex; align-items:center; width:100%; justify-content:center; cursor:pointer; padding:3px 0;}
.vote-bar{width:100%; max-width:88px; height:17px; border-radius:5px; background:var(--line-100); position:relative; overflow:hidden;}
.vote-bar .vf{position:absolute; inset:0; width:0; transition:width .4s;}
.vf.build{background:var(--brand-200);} .vf.buy{background:var(--approved-border);}
.vf.hybrid{background:var(--review-border);} .vf.none{background:var(--missing-border);} .vf.unk{background:var(--unverified-border);}
.vote-bar .vn{position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:12px; font-weight:600; font-variant-numeric:tabular-nums; color:var(--ink-700);}
.complexity-band{display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:2px 9px; border-radius:9999px;}
.cb-low{background:var(--approved-bg); color:var(--approved-fg);}
.cb-med{background:var(--review-bg); color:var(--review-fg);}
.cb-high{background:var(--conflict-bg); color:var(--conflict-fg);}

/* iceberg */
.iceberg{position:relative; height:100%; border-radius:var(--r-card); overflow:hidden; border:1px solid var(--line-200);
  background:linear-gradient(180deg,#eaf2fb 0%,#dcebfa 32%, #cfe0f5 33%, #1e3a5f 34%, #0b1f38 100%);}
.iceberg .waterline{position:absolute; left:0; right:0; top:33%; height:2px; background:rgba(255,255,255,.55);}
.iceberg .waterline .lbl{position:absolute; right:14px; top:-22px; font-family:var(--font-mono); font-size:12px; color:#1e293b; letter-spacing:1px;}
.ice-zone{position:absolute; left:0; right:0; padding:18px 26px; display:flex; flex-wrap:wrap; gap:8px; align-content:flex-start;}
.ice-zone.above{top:0; height:33%;}
.ice-zone.below{top:34%; bottom:0; align-content:flex-start;}
.ice-chip{font-size:14px; font-weight:600; padding:6px 12px; border-radius:var(--r-pill); white-space:nowrap;}
.ice-zone.above .ice-chip{background:rgba(255,255,255,.85); color:#1e293b; border:1px solid rgba(15,23,42,.08);}
.ice-zone.below .ice-chip{background:rgba(255,255,255,.10); color:#dbe8ff; border:1px solid rgba(255,255,255,.16);}
.ice-zone .zlabel{width:100%; font-family:var(--font-mono); font-size:12px; letter-spacing:1px; text-transform:uppercase; margin-bottom:4px;}
.ice-zone.above .zlabel{color:#475569;} .ice-zone.below .zlabel{color:#7f9bc4;}

/* ============================================================
   WORKSHOP 5 — ROI / capacity calculator
   ============================================================ */
.roi-form{display:grid; grid-template-columns:1fr 1fr; gap:14px 24px;}
.roi-field{display:flex; flex-direction:column; gap:5px;}
.roi-field label{font-size:13px; font-weight:600; color:var(--ink-600);}
.roi-field .hint{font-size:11px; color:var(--ink-400);}
.roi-input{display:flex; align-items:center; gap:8px; border:1px solid var(--line-200); border-radius:var(--r-control);
  background:var(--surface); padding:0 12px; height:42px;}
.roi-input input{border:0; outline:none; font-family:var(--font-mono); font-size:17px; font-weight:500; width:100%;
  color:var(--ink-900); background:transparent; text-align:right; -moz-appearance:textfield;}
.roi-input input::-webkit-outer-spin-button,.roi-input input::-webkit-inner-spin-button{-webkit-appearance:none; margin:0;}
.roi-input .unit{font-size:13px; color:var(--ink-400); white-space:nowrap;}
.roi-input.assumed{border-color:var(--review-border); background:var(--review-bg);}
.assume-flag{font-size:11px; font-weight:600; color:var(--review-fg); display:inline-flex; align-items:center; gap:4px; cursor:pointer;}

/* ROI sliders (replaces text inputs) */
.roi-srow{display:flex; flex-direction:column; gap:9px;}
.roi-srow .rl{display:flex; justify-content:space-between; align-items:baseline; gap:12px;}
.roi-srow .rl .nm{font-size:17px; font-weight:600; color:var(--ink-700); line-height:1.2;}
.roi-srow .rl .vv{font-family:var(--font-mono); font-size:22px; font-weight:600; color:var(--brand-600); white-space:nowrap;}
.roi-range{-webkit-appearance:none; appearance:none; width:100%; height:8px; border-radius:9999px; outline:none; cursor:pointer;}
.roi-range::-webkit-slider-thumb{-webkit-appearance:none; width:26px; height:26px; border-radius:50%; background:var(--brand-500); border:3px solid #fff; box-shadow:var(--shadow-pop); cursor:pointer;}
.roi-range::-moz-range-thumb{width:26px; height:26px; border-radius:50%; background:var(--brand-500); border:3px solid #fff; box-shadow:var(--shadow-pop); cursor:pointer;}
.roi-range:focus-visible{box-shadow:var(--ring);}
.roi-cap{display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:12px; color:var(--ink-400);}
.scenario-tabs{display:inline-flex; background:var(--line-100); border-radius:var(--r-control); padding:3px;}
.scenario-tabs button{border:0; background:transparent; font-family:inherit; font-size:14px; font-weight:600; color:var(--ink-500);
  padding:7px 18px; border-radius:5px; cursor:pointer;}
.scenario-tabs button.on{background:var(--surface); color:var(--ink-900); box-shadow:var(--shadow-pop);}
.roi-out{display:flex; flex-direction:column; gap:14px;}
.roi-metric{display:flex; align-items:baseline; justify-content:space-between; padding:14px 18px; border:1px solid var(--line-200); border-radius:var(--r-card); background:var(--surface);}
.roi-metric.hero{background:var(--brand-500); border-color:var(--brand-500); color:#fff;}
.roi-metric .ml{font-size:14px; color:var(--ink-500);}
.roi-metric.hero .ml{color:rgba(255,255,255,.8);}
.roi-metric .mv{font-size:30px; font-weight:600; font-variant-numeric:tabular-nums; letter-spacing:-.02em;}
.roi-bars{display:flex; align-items:flex-end; gap:18px; height:170px; padding-top:10px;}
.roi-bars .b{flex:1; display:flex; flex-direction:column; align-items:center; gap:8px; justify-content:flex-end;}
.roi-bars .b .col{width:64px; border-radius:6px 6px 0 0; background:var(--brand-300); transition:height .4s;}
.roi-bars .b .col.cur{background:var(--ink-300);}
.roi-bars .b .cap{font-size:12px; color:var(--ink-500); text-align:center;}
.roi-bars .b .num{font-size:14px; font-weight:600; font-variant-numeric:tabular-nums;}

/* ============================================================
   GENERATED DOC PREVIEW (deliverables / pilot fact list)
   ============================================================ */
.doc-preview{background:var(--surface); border:1px solid var(--line-200); border-radius:var(--r-card);
  box-shadow:var(--shadow-pop); overflow:hidden; display:flex; flex-direction:column;}
.doc-preview .doc-bar{display:flex; align-items:center; gap:8px; padding:11px 16px; border-bottom:1px solid var(--line-200); background:var(--subtle);}
.doc-preview .doc-bar .dot{width:11px;height:11px;border-radius:50%;}
.doc-preview .doc-bar .fn{margin-left:8px; font-family:var(--font-mono); font-size:13px; color:var(--ink-500);}
.doc-body{padding:28px 34px; overflow:auto;}
.doc-body h3{font-size:22px; font-weight:600; margin:0 0 3px; letter-spacing:-.01em;}
.doc-body .doc-sub{font-size:13px; color:var(--ink-500); margin:0 0 20px; font-family:var(--font-mono);}
.doc-body .doc-sec{font-size:11px; font-weight:600; letter-spacing:.6px; text-transform:uppercase; color:var(--brand-600); margin:18px 0 8px;}

/* ============================================================
   PARTICIPANT MOBILE VIEW (participant.html)
   ============================================================ */
.p-body{background:var(--canvas); overflow:auto; height:100%;}
.p-shell{max-width:520px; margin:0 auto; min-height:100%; display:flex; flex-direction:column; background:var(--canvas);}
.p-top{position:sticky; top:0; z-index:10; background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line-200); padding:12px 18px; display:flex; align-items:center; gap:12px;}
.p-top img{width:26px;height:26px;}
.p-top .brand{font-weight:600; font-size:16px; letter-spacing:-.01em; white-space:nowrap;}
.p-top .brand b{color:var(--brand-600);}
.p-top .who{margin-left:auto; display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink-500);}
.p-top .live{width:8px;height:8px;border-radius:50%;background:#10b981;}
.p-main{flex:1; padding:20px 18px 40px; display:flex; flex-direction:column; gap:18px;}

/* join screen */
.join-card{background:var(--surface); border:1px solid var(--line-200); border-radius:var(--r-card); padding:28px 24px; margin-top:8vh;}
.join-card h1{font-size:24px; font-weight:600; margin:0 0 6px;}
.join-card p{color:var(--ink-500); font-size:15px; margin:0 0 22px; line-height:1.5;}
.field-lg{display:flex; flex-direction:column; gap:7px; margin-bottom:16px;}
.field-lg label{font-size:13px; font-weight:600; color:var(--ink-600);}
.field-lg input, .field-lg select{font-family:inherit; font-size:17px; height:50px; padding:0 14px; border:1px solid var(--line-200);
  border-radius:var(--r-control); color:var(--ink-900); background:var(--surface);}
.field-lg input.code{font-family:var(--font-mono); letter-spacing:6px; text-transform:uppercase; text-align:center; font-size:24px;}
.field-lg input:focus, .field-lg select:focus{outline:none; box-shadow:var(--ring); border-color:var(--brand-300);}
.btn-block{width:100%; justify-content:center; height:54px; font-size:18px; border-radius:var(--r-control);}

/* participant stage card */
.p-stage-head{display:flex; flex-direction:column; gap:6px;}
.p-stage-head .ws-tag{font-family:var(--font-mono); font-size:12px; letter-spacing:1.5px; text-transform:uppercase; color:var(--brand-600);}
.p-stage-head h2{font-size:22px; font-weight:600; margin:0; letter-spacing:-.01em; line-height:1.15;}
.p-stage-head .desc{font-size:14px; color:var(--ink-500); line-height:1.45;}
.p-waiting{text-align:center; color:var(--ink-400); padding:14vh 20px; font-size:16px; line-height:1.6;}
.p-waiting .spin{width:34px;height:34px;border:3px solid var(--line-200); border-top-color:var(--brand-500); border-radius:50%; margin:0 auto 18px; animation:pspin 0.9s linear infinite;}
@keyframes pspin{to{transform:rotate(360deg)}}

/* participant vote cards */
.p-card{background:var(--surface); border:1px solid var(--line-200); border-radius:var(--r-card); padding:16px 16px;}
.p-card .pc-title{font-size:16px; font-weight:600; margin:0 0 2px;}
.p-card .pc-sub{font-size:13px; color:var(--ink-500); margin:0 0 14px; line-height:1.4;}
.score-row{display:flex; flex-direction:column; gap:11px; padding:13px 0; border-top:1px solid var(--line-100);}
.score-row:first-of-type{border-top:0;}
.score-row .srl{display:flex; justify-content:space-between; align-items:center; font-size:14px; font-weight:600; color:var(--ink-800); line-height:1.3;}
.score-dots{display:flex; gap:8px;}
.score-dots button{flex:1; height:44px; border-radius:var(--r-control); border:1px solid var(--line-200); background:var(--surface);
  font-family:var(--font-mono); font-size:16px; font-weight:600; color:var(--ink-500); cursor:pointer; transition:all .12s;}
.score-dots button.on{background:var(--brand-500); color:#fff; border-color:var(--brand-500);}
.choice-grid{display:grid; grid-template-columns:1fr 1fr; gap:8px;}
.choice-grid button{height:46px; border-radius:var(--r-control); border:1px solid var(--line-200); background:var(--surface);
  font-family:inherit; font-size:14px; font-weight:600; color:var(--ink-600); cursor:pointer;}
.choice-grid button.on{background:var(--brand-50); border-color:var(--brand-500); color:var(--brand-700);}
.p-submit-note{text-align:center; font-size:13px; color:var(--approved-fg); padding:6px; display:flex; align-items:center; gap:7px; justify-content:center;}

/* high-contrast accessibility toggle hook */
body.hc{--ink-700:#0b1220; --ink-600:#0b1220; --ink-500:#1e293b; --line-200:#475569;}

/* ============================================================
   ANATOMY CARD (slide 7 intro)
   ============================================================ */
.anatomy-card{background:rgba(255,255,255,.04); border:1px solid var(--navy-line); border-radius:18px; padding:30px 32px; box-shadow:0 24px 70px rgba(0,0,0,.4);}
.anatomy-head{display:flex; align-items:center; gap:14px; padding-bottom:18px; border-bottom:1px solid var(--navy-line); margin-bottom:20px;}
.anatomy-ix{font-family:var(--font-mono); font-size:19px; color:var(--brand-300); font-weight:600;}
.anatomy-name{font-size:30px; font-weight:600; color:#f4f7fc; letter-spacing:-.01em;}
.anatomy-sev{margin-left:auto; font-size:14px; font-weight:600; color:#fca5a5; background:rgba(220,38,38,.16); border:1px solid rgba(220,38,38,.34); padding:5px 13px; border-radius:9999px;}
.anatomy-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
.anatomy-field{display:flex; gap:15px; align-items:flex-start;}
.af-ic{width:44px; height:44px; border-radius:11px; background:rgba(96,165,250,.12); border:1px solid var(--navy-line); color:var(--brand-300); display:flex; align-items:center; justify-content:center; flex:0 0 auto;}
.af-label{font-size:20px; font-weight:600; color:#eaf0fa;}
.af-desc{font-size:15px; color:#8696b3; line-height:1.35; margin-top:2px;}
.anatomy-foot{margin-top:22px; padding-top:18px; border-top:1px solid var(--navy-line); font-family:var(--font-mono); font-size:14px; color:#5b6b86; text-align:center;}
