/* Terms.Law Client Workroom Engine - UI chrome may use brand indigo; the DOCUMENT
   preview is strict attorney style: black headings, no blue, nothing oversized. */
:root{
  --ink:#0b1220; --ink2:#1f2937; --muted:#6b7280; --line:#e5e7eb; --bg:#f4f6f8;
  --brand:#1e3a5f; --brand2:#2563eb; --paper:#ffffff;
  --hi:#fde68a; --hi-edge:#f59e0b;
  --r-high:#dc2626; --r-high-bg:#fef2f2; --r-med:#d97706; --r-med-bg:#fffbeb;
  --r-low:#16a34a; --r-low-bg:#f0fdf4; --r-gray:#6b7280; --r-gray-bg:#f3f4f6;
}
*{box-sizing:border-box;}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;}
a{color:var(--brand2);}
.wrap{max-width:1400px;margin:0 auto;padding:0 18px;}

/* Header */
header.hd{background:linear-gradient(160deg,#0b1220,#16263f 60%,#1e3a5f);color:#fff;padding:18px 0;}
header.hd h1{margin:0;font-size:20px;font-weight:800;}
header.hd .sub{color:#cbd5e1;font-size:13px;margin-top:2px;}
header.hd .meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px;}
header.hd .chip{font-size:12px;font-weight:600;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:4px 11px;color:#e2e8f0;}
.statusbar{background:#7c2d12;color:#fff;font-size:12.5px;font-weight:700;text-align:center;padding:7px 14px;}

/* Doc tabs */
.tabs{display:flex;flex-wrap:wrap;gap:6px;padding:12px 0 0;}
.tab{font-size:13px;font-weight:600;border:1px solid var(--line);background:#fff;border-radius:8px 8px 0 0;padding:9px 14px;cursor:pointer;color:var(--ink2);position:relative;}
.tab.active{border-bottom-color:#fff;color:var(--brand);box-shadow:0 -2px 0 var(--brand2) inset;}
.tab .badge{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;margin-left:6px;padding:1px 6px;border-radius:999px;vertical-align:middle;}
.tab .badge.live{background:#dcfce7;color:#166534;}
.tab .badge.next{background:#f1f5f9;color:#64748b;}

/* Two-pane layout */
.pane-row{display:grid;grid-template-columns:minmax(340px,2fr) 3fr;gap:16px;align-items:start;margin-top:0;border:1px solid var(--line);border-top:none;background:#fff;border-radius:0 0 12px 12px;padding:16px;}
.builder{min-width:0;}
.builder h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 4px;}
.doc-meta{font-size:13px;color:var(--ink2);background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-bottom:12px;}
.doc-meta b{color:var(--ink);}

.fgroup{margin:0 0 6px;border:1px solid var(--line);border-radius:10px;overflow:hidden;}
.fgroup>summary{cursor:pointer;list-style:none;padding:9px 12px;font-size:12.5px;font-weight:700;color:var(--brand);background:#f8fafc;user-select:none;}
.fgroup>summary::-webkit-details-marker{display:none;}
.fgroup>summary::before{content:"▸";margin-right:7px;font-size:10px;color:var(--muted);}
.fgroup[open]>summary::before{content:"▾";}
.fgrid{padding:10px 12px;}
.field-row{margin:0 0 10px;}
.field-row label{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:3px;}
.field-row .hint{display:inline-block;width:15px;height:15px;line-height:15px;text-align:center;border-radius:50%;background:#e5e7eb;color:#475569;font-size:10px;font-weight:700;cursor:help;margin-left:5px;}
.field-row input,.field-row select,.field-row textarea{width:100%;font-family:inherit;font-size:13px;padding:7px 9px;border:1px solid #cbd5e1;border-radius:7px;background:#fff;color:var(--ink);}
.field-row input:focus,.field-row select:focus,.field-row textarea:focus{outline:none;border-color:var(--brand2);box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.field-row textarea{resize:vertical;line-height:1.45;}

/* Stable, internally-scrolling preview pane */
.preview-wrap{position:sticky;top:14px;}
.preview-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.preview-bar .ttl{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;}
.preview-bar .draftpill{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#9a3412;background:#ffedd5;border:1px solid #fed7aa;border-radius:999px;padding:2px 9px;}
.preview{height:calc(100vh - 120px);min-height:420px;overflow-y:auto;background:var(--paper);border:1px solid var(--line);border-radius:10px;box-shadow:0 6px 22px rgba(11,20,48,.06);padding:30px 34px;scroll-behavior:smooth;}

/* The document itself: strict black attorney style, nothing oversized, no blue */
.doc{font-family:Georgia,'Times New Roman',serif;color:#000;font-size:12px;line-height:1.55;}
.doc .doc-title{font-size:14px;font-weight:700;text-align:center;color:#000;margin:0 0 2px;letter-spacing:.02em;}
.doc .doc-sub{text-align:center;font-size:11px;color:#000;margin:0 0 16px;font-style:italic;}
.doc .doc-h{font-size:12px;font-weight:700;color:#000;margin:16px 0 5px;}
.doc .doc-p{font-size:12px;color:#000;margin:0 0 9px;text-align:justify;}
.doc .doc-list{font-size:12px;color:#000;margin:0 0 10px;padding-left:20px;}
.doc .doc-list li{margin:0 0 5px;}
.doc table{width:100%;border-collapse:collapse;margin:8px 0 12px;}
.doc .kv-table td{border:1px solid #cfcfcf;padding:5px 9px;font-size:11.5px;vertical-align:top;}
.doc .kv-table td:first-child{width:38%;font-weight:700;background:#f3f3f3;}
.doc .sig-table td{padding:9px 12px 2px 0;font-size:11.5px;vertical-align:bottom;width:50%;}

/* Surgical highlight: only the field value, never the paragraph */
.field{border-radius:3px;-webkit-box-decoration-break:clone;box-decoration-break:clone;}
.field.empty{color:#9a3412;background:#fff7ed;border-bottom:1px dashed #fdba74;padding:0 2px;font-style:italic;}
@keyframes fieldFlash{0%{background:var(--hi);box-shadow:0 0 0 2px var(--hi);}100%{background:transparent;box-shadow:0 0 0 2px transparent;}}
.field-flash{animation:fieldFlash 1.25s ease-out;}

/* Risk Boundary Panel */
.riskpanel{margin-top:14px;border:1px solid var(--line);border-radius:10px;padding:12px 13px;background:#fff;}
.riskpanel h3{margin:0 0 8px;}
.riskpanel .ok{font-size:12.5px;color:#166534;background:var(--r-low-bg);border:1px solid #bbf7d0;border-radius:8px;padding:9px 11px;}
.risk-card{border-left:4px solid var(--r-gray);border-radius:0 8px 8px 0;background:var(--r-gray-bg);padding:9px 11px;margin:0 0 8px;}
.risk-card.high{border-color:var(--r-high);background:var(--r-high-bg);}
.risk-card.medium{border-color:var(--r-med);background:var(--r-med-bg);}
.risk-card .rt{font-size:12.5px;font-weight:800;display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.risk-card .inh{font-size:10px;font-weight:600;color:var(--muted);}
.rep-table{border-collapse:collapse;width:100%;margin:6px 0 12px;}
.rep-table td{border:1px solid #d7dee8;padding:5px 9px;font-size:12.5px;vertical-align:top;color:#000;}
.doc-note{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:10px 12px;font-size:12.5px;color:var(--ink2);margin:8px 0;}
.risk-card .sev{font-size:9.5px;font-weight:800;text-transform:uppercase;padding:1px 7px;border-radius:999px;}
.risk-card.high .sev{background:var(--r-high);color:#fff;}.risk-card.medium .sev{background:var(--r-med);color:#fff;}
.risk-card .rm{font-size:12px;color:var(--ink2);margin-top:4px;line-height:1.5;}

/* Downloads + actions */
.actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;}
.btn{font-family:inherit;font-size:12.5px;font-weight:700;border:1px solid var(--brand2);background:var(--brand2);color:#fff;border-radius:8px;padding:9px 14px;cursor:pointer;text-decoration:none;display:inline-block;}
.btn.secondary{background:#fff;color:var(--brand2);}
.btn.ghost{background:#fff;color:var(--ink2);border-color:var(--line);}
.btn:hover{filter:brightness(.96);}

/* Coming-next placeholder */
.placeholder{padding:40px 24px;text-align:center;color:var(--muted);}
.placeholder .big{font-size:15px;font-weight:700;color:var(--ink2);margin-bottom:6px;}
.dep-line{font-size:12px;color:#4338ca;background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;padding:7px 10px;margin:10px auto 0;max-width:520px;}

/* Dashboard / scope strip */
.scopebar{display:flex;flex-wrap:wrap;gap:8px;padding:12px 0 4px;font-size:12px;}
.scopebar .doc-pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:4px 11px;color:var(--ink2);}
.scopebar .doc-pill.def{border-style:dashed;color:var(--muted);background:#fafafa;}

.disc{font-size:11.5px;color:var(--muted);margin:14px 0 24px;line-height:1.55;}
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#0b1220;color:#fff;font-size:12.5px;font-weight:600;padding:9px 16px;border-radius:8px;opacity:0;transition:opacity .25s;z-index:50;pointer-events:none;}
.toast.show{opacity:1;}

/* Project-knowledge cluster */
.kbox{border:1px solid #c7d2fe;background:#eef2ff;border-radius:10px;margin:0 0 12px;overflow:hidden;}
.kbox>summary{cursor:pointer;list-style:none;padding:10px 13px;font-size:12.5px;font-weight:800;color:#3730a3;user-select:none;}
.kbox>summary::-webkit-details-marker{display:none;}
.kbox>summary::before{content:"▸";margin-right:7px;font-size:10px;}
.kbox[open]>summary::before{content:"▾";}
.kbody{padding:4px 13px 12px;}
.k-sum{font-size:12.5px;color:var(--ink2);margin:4px 0 8px;line-height:1.5;}
.k-ent{font-size:12px;color:var(--ink2);background:#fff;border:1px solid #e0e7ff;border-radius:8px;padding:8px 10px;margin:0 0 8px;line-height:1.5;}
.ksub{border-top:1px solid #dbe1fb;}
.ksub>summary{cursor:pointer;list-style:none;padding:7px 2px;font-size:12px;font-weight:700;color:#4338ca;user-select:none;}
.ksub>summary::-webkit-details-marker{display:none;}
.ksub>summary::before{content:"+";margin-right:7px;font-weight:800;}
.ksub[open]>summary::before{content:"-";}
.k-list{margin:2px 0 8px;padding-left:18px;}
.k-list li{font-size:12px;color:var(--ink2);margin:0 0 4px;line-height:1.45;}
.k-def{font-size:12px;background:#fff;border:1px solid #e0e7ff;border-radius:7px;padding:7px 9px;margin:0 0 6px;line-height:1.45;}
.k-def .k-why{color:var(--muted);}
.k-def .k-trig{color:#4338ca;}
.k-gl{font-size:12px;color:var(--ink2);padding:5px 0;border-bottom:1px solid #eef0fb;line-height:1.45;}
.k-gl b{color:var(--ink);}

/* Phases repeater */
.phase-card{border:1px solid var(--line);border-radius:9px;padding:9px 11px;margin:0 0 9px;background:#fcfcfd;}
.phase-card-h{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:800;color:var(--brand);margin-bottom:5px;}
.phase-x,.rep-x{border:1px solid #fecaca;background:#fef2f2;color:#dc2626;font-size:15px;line-height:1;width:24px;height:24px;border-radius:6px;cursor:pointer;font-weight:700;}
.phase-x:hover,.rep-x:hover{background:#dc2626;color:#fff;border-color:#dc2626;}
.phase-card label{display:block;font-size:11.5px;font-weight:600;color:var(--ink2);margin:6px 0 3px;}
.phase-card textarea,.phase-card input{width:100%;font-family:inherit;font-size:12.5px;padding:6px 8px;border:1px solid #cbd5e1;border-radius:6px;}
.phase-card textarea:focus,.phase-card input:focus{outline:none;border-color:var(--brand2);box-shadow:0 0 0 3px rgba(37,99,235,.12);}
.phase-add,.rep-add{margin-top:2px;}

@media (max-width:920px){
  .pane-row{grid-template-columns:1fr;}
  .builder,.preview-wrap{min-width:0;}
  .preview-wrap{position:static;}
  .preview{height:auto;max-height:70vh;overflow-x:auto;}
}

/* ============================================================================
   Healthcare SaaS control-room panels (CarePilot demo). Scoped to .doc so they
   only affect the preview pane. Reference panels use a sans "console" feel
   while the BAA itself stays serif. Additive; the shared engine is untouched.
   ========================================================================== */
:root{ --hc-sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif; }
.doc .chips,.doc .flow,.doc .callout,.doc .rr-table,.doc .lifecycle,.doc .checklist,.doc .two-col,.doc .roadmap{font-family:var(--hc-sans);}

/* "?" explainer tooltip */
.doc .tip{display:inline-flex;align-items:center;justify-content:center;width:15px;height:15px;border-radius:50%;background:#1e3a5f;color:#fff;font-size:9.5px;font-weight:800;font-family:var(--hc-sans);cursor:help;margin:0 1px;vertical-align:middle;position:relative;text-align:center;}
.doc .tip:hover,.doc .tip:focus{background:#2563eb;outline:none;}
.doc .tip:hover::after,.doc .tip:focus::after{content:attr(data-tip);position:absolute;left:50%;bottom:150%;transform:translateX(-50%);width:250px;max-width:60vw;background:#0b1220;color:#e7edf6;font-size:11px;font-weight:400;line-height:1.45;letter-spacing:0;text-align:left;padding:8px 10px;border-radius:7px;box-shadow:0 8px 26px rgba(11,20,48,.32);z-index:60;white-space:normal;}
.doc .tip:hover::before,.doc .tip:focus::before{content:"";position:absolute;left:50%;bottom:150%;transform:translate(-50%,90%);border:5px solid transparent;border-top-color:#0b1220;z-index:60;}

/* status chips */
.doc .chips{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0 4px;}
.doc .chip{font-size:11px;font-weight:600;border-radius:999px;padding:4px 11px;border:1px solid transparent;white-space:nowrap;}
.doc .chip-ok{background:#ecfdf5;color:#065f46;border-color:#a7f3d0;}
.doc .chip-warn{background:#fffbeb;color:#92400e;border-color:#fde68a;}
.doc .chip-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe;}

/* PHI flow map */
.doc .flow{display:flex;flex-wrap:wrap;align-items:stretch;gap:6px;margin:10px 0 14px;}
.doc .flow-step{flex:1 1 150px;min-width:130px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:9px 11px;font-size:11px;color:#334155;display:flex;flex-direction:column;gap:3px;}
.doc .flow-step b{font-size:11.5px;color:#0b1220;font-family:var(--hc-sans);}
.doc .flow-step span{font-size:10.5px;line-height:1.4;}
.doc .flow-inference{background:#eef2ff;border-color:#c7d2fe;}
.doc .flow-arrow{align-self:center;color:#94a3b8;font-size:16px;font-weight:700;padding:0 1px;}

/* color-coded callouts */
.doc .callout{border:1px solid;border-left-width:4px;border-radius:9px;padding:10px 13px;margin:10px 0;font-size:11.5px;line-height:1.5;color:#1f2937;}
.doc .callout b{color:#0b1220;}
.doc .callout.info{background:#eff6ff;border-color:#bfdbfe;border-left-color:#2563eb;}
.doc .callout.warn{background:#fffbeb;border-color:#fde68a;border-left-color:#d97706;}
.doc .callout.ok{background:#ecfdf5;border-color:#a7f3d0;border-left-color:#16a34a;}
.doc .callout.danger{background:#fef2f2;border-color:#fecaca;border-left-color:#dc2626;}

/* review-room tables (matrix + trust chain) */
.doc .rr-table{border-collapse:collapse;width:100%;margin:8px 0 12px;font-size:11px;}
.doc .rr-table td{border:1px solid #e2e8f0;padding:6px 9px;vertical-align:top;color:#334155;line-height:1.4;}
.doc .rr-table tr:first-child td{background:#0b1220;color:#e7edf6;font-weight:700;border-color:#0b1220;font-size:10.8px;}
.doc .rr-table tr:nth-child(even):not(:first-child) td{background:#f8fafc;}
.doc .rr-table .cell-ok{color:#065f46;font-weight:600;}
.doc .rr-table .cell-warn{color:#92400e;font-weight:600;}
.doc .rr-table .cell-impl{color:#1e40af;font-weight:600;}
.doc .rr-table .cell-muted{color:#94a3b8;font-style:italic;background:#fbfcfe;}

/* data lifecycle */
.doc .lifecycle{margin:10px 0 12px;padding-left:6px;border-left:2px solid #e2e8f0;}
.doc .life-step{position:relative;padding:0 0 12px 18px;}
.doc .life-dot{position:absolute;left:-7px;top:3px;width:11px;height:11px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 0 0 1px #2563eb;}
.doc .life-step b{font-size:11.5px;color:#0b1220;font-family:var(--hc-sans);}
.doc .life-step p{font-size:11px;color:#475569;margin:2px 0 0;line-height:1.45;}
.doc .tag-impl,.doc .tag-future{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;padding:2px 7px;border-radius:999px;margin-top:5px;}
.doc .tag-impl{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe;}
.doc .tag-future{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;margin:0 0 5px;}

/* checklist */
.doc .checklist{list-style:none;padding:0;margin:8px 0 12px;}
.doc .checklist .check-item{position:relative;padding:6px 0 6px 26px;font-size:11.5px;color:#334155;border-bottom:1px solid #f1f5f9;line-height:1.45;}
.doc .checklist .check-item::before{content:"\2713";position:absolute;left:4px;top:6px;width:15px;height:15px;line-height:15px;text-align:center;border-radius:4px;background:#ecfdf5;color:#16a34a;font-size:11px;font-weight:800;border:1px solid #a7f3d0;}

/* two-column feature gates */
.doc .two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0;}
.doc .two-col .col-h{font-size:11px;font-weight:800;font-family:var(--hc-sans);text-transform:uppercase;letter-spacing:.03em;margin-bottom:6px;}
.doc .two-col ul{margin:0;padding-left:16px;font-size:11px;color:#334155;line-height:1.5;}
.doc .two-col .col-ok{background:#ecfdf5;border:1px solid #a7f3d0;border-radius:9px;padding:10px 12px;}
.doc .two-col .col-ok .col-h{color:#065f46;}
.doc .two-col .col-warn{background:#fffbeb;border:1px solid #fde68a;border-radius:9px;padding:10px 12px;}
.doc .two-col .col-warn .col-h{color:#92400e;}

/* scale-up roadmap cards */
.doc .roadmap{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0;}
.doc .road-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;}
.doc .road-card b{display:block;font-size:11.5px;color:#0b1220;font-family:var(--hc-sans);margin:2px 0 3px;}
.doc .road-card p{font-size:10.8px;color:#475569;margin:0;line-height:1.45;}

@media (max-width:720px){
  .doc .two-col,.doc .roadmap{grid-template-columns:1fr;}
  .doc .flow-arrow{transform:rotate(90deg);}
}
