/* ============================================================
   KS Workbench — DLS Design System "Rams-light"
   Scoped under #tab-workbench. Reuses global --ds-* tokens
   (dashboard/tokens.css). See docs/references/design-system.md
   and the reference mockup docs/research/ks-workbench-mockup.html
   ============================================================ */

#tab-workbench{
  padding:0;
  height:calc(100vh - 112px);     /* fill below nav + chrome-bar; tuned visually */
  display:flex;flex-direction:column;min-height:0;
  font-family:var(--ds-font-ui);color:var(--ds-ink);
}

/* ---- sub-bar: lens switcher + command + role ---- */
.wb-bar{display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--ds-surface);border-bottom:1px solid var(--ds-border);flex:0 0 auto}
.wb-cmd{flex:1;max-width:520px;position:relative}
.wb-cmd input{width:100%;background:var(--ds-surface-sunken);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);color:var(--ds-ink);padding:7px 12px 7px 32px;font-size:14px;outline:none;font-family:var(--ds-font-ui)}
.wb-cmd input::placeholder{color:var(--ds-ink-4)}
.wb-cmd input:focus{border-color:var(--ds-accent);box-shadow:0 0 0 3px var(--ds-accent-soft)}
.wb-cmd .ico{position:absolute;left:10px;top:7px;color:var(--ds-ink-4);font-size:15px}
.wb-lenses{display:flex;gap:2px;margin-left:auto}
.wb-lens{background:transparent;border:1px solid transparent;border-radius:var(--ds-r-sm);padding:6px 12px;font-size:14px;color:var(--ds-ink-3);cursor:pointer}
.wb-lens:hover{color:var(--ds-ink)}
.wb-lens.active{background:var(--ds-accent-soft);color:var(--ds-accent);font-weight:500}
.wb-lens .wb-badge{display:none;min-width:16px;text-align:center;background:var(--ds-warn);color:#fff;border-radius:9px;font-size:11px;font-weight:600;padding:0 5px;margin-left:6px;font-family:var(--ds-font-mono)}
.wb-lens .wb-badge.show{display:inline-block}
.wb-role{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ds-ink-3);white-space:nowrap;padding-left:8px;border-left:1px solid var(--ds-border)}
.wb-role b{color:var(--ds-ink);font-weight:500}

/* ---- body: center + Detail column + Chat column, drag-resizable ---- */
.wb-body{flex:1 1 auto;display:flex;min-height:0}
.wb-center{flex:1 1 0;min-width:260px;overflow:auto;background:var(--ds-bg)}
.wb-col{flex:0 0 auto;min-width:220px;display:flex;flex-direction:column;min-height:0;background:var(--ds-surface);border-left:1px solid var(--ds-border)}
.wb-col-here{width:268px}
.wb-col-detail{width:360px}
.wb-col-chat{width:340px}
/* Facts-on-this-page column — only in Read lens */
.wb-readonly-col.wb-hidden{display:none!important}
.wb-here-item{padding:9px 10px;border-radius:var(--ds-r-sm);cursor:pointer;border:1px solid transparent;border-left:2px solid transparent}
.wb-here-item:hover{background:var(--ds-surface-raised);border-color:var(--ds-border)}
.wb-here-item.sel{background:var(--ds-accent-soft);border-left-color:var(--ds-accent)}
.wb-here-item.origin{border-left-color:var(--ds-accent)}
.wb-here-item.linked{border-left-color:var(--ds-ink-4)}
.wb-here-slug{font-family:var(--ds-font-mono);font-size:13px;color:var(--ds-accent);word-break:break-all;display:block}
.wb-here-origin{font-size:12px;color:var(--ds-ink-3);margin-top:2px;display:flex;align-items:center;gap:5px}
.wb-here-origin .o-here{color:var(--ds-accent)}
.wb-here-origin .o-link{color:var(--ds-ink-3)}
.wb-here-sec{font-size:11px;text-transform:uppercase;letter-spacing:.3px;color:var(--ds-ink-4);margin:8px 4px 4px;font-weight:500}
.wb-here-foot{font-size:12px;color:var(--ds-ink-4);padding:10px 4px;line-height:1.5}
/* chat context chip */
.wb-ctxchip{background:var(--ds-surface-raised);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);padding:8px 11px;font-size:13px;color:var(--ds-ink-3);margin-bottom:10px;line-height:1.5;flex:0 0 auto}
.wb-ctxchip .b{color:var(--ds-ink);font-weight:500}
.wb-ctxchip .slug{font-size:13px}
/* chat column layout */
.wb-chat-wrap{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;padding:14px 16px}
.wb-chatlog{flex:1 1 auto;overflow:auto;min-height:0;display:flex;flex-direction:column;gap:12px;padding:2px 0}
.wb-chatlog:empty::before{content:'Ask about this article, or click a fact to discuss it. The chat sees the Facts store + KB.';color:var(--ds-ink-4);font-size:13px;line-height:1.6}
.wb-msg{font-size:14px;line-height:1.6}
.wb-msg .who{font-size:11px;color:var(--ds-ink-4);text-transform:uppercase;letter-spacing:.3px;margin-bottom:3px;font-family:var(--ds-font-mono)}
.wb-msg.u .bub{background:var(--ds-surface-raised);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);padding:8px 11px;color:var(--ds-ink)}
.wb-msg.a .bub{color:var(--ds-ink-2)}
.wb-msg .bub code{background:var(--ds-surface-sunken);padding:1px 5px;border-radius:3px;font-size:13px;color:var(--ds-accent);font-family:var(--ds-font-mono)}
.wb-msg .bub a{color:var(--ds-accent)}
.wb-msg .bub b{color:var(--ds-ink)}
.wb-msg .bub ul{margin:6px 0;padding-left:20px}
.wb-msg .bub p{margin:6px 0}
.wb-msg .bub p:first-child{margin-top:0}
.wb-msg .status{color:var(--ds-ink-4);font-style:italic;font-size:13px}
.wb-cdiv{display:flex;align-items:center;gap:8px;color:var(--ds-ink-4);font-size:12px;margin:4px 0}
.wb-cdiv::before,.wb-cdiv::after{content:'';flex:1;height:1px;background:var(--ds-border)}
/* suggested-op card */
.wb-op{margin-top:8px;border:1px solid var(--ds-border);border-left:2px solid var(--ds-warn);border-radius:var(--ds-r-sm);padding:10px;background:var(--ds-surface-raised)}
.wb-op .h{font-size:11px;color:var(--ds-warn);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-bottom:5px;font-family:var(--ds-font-mono)}
.wb-op .reason{font-size:13px;color:var(--ds-ink-2);margin-bottom:8px;line-height:1.5}
.wb-op .actions{display:flex;gap:8px}
.wb-op.done{border-left-color:var(--ds-success);opacity:.75}
/* starters + input */
.wb-chat-starters{flex:0 0 auto;display:flex;flex-wrap:wrap;gap:5px;margin:8px 0 0}
.wb-chat-starters .wb-pill{cursor:pointer}
.wb-chatin{flex:0 0 auto;display:flex;gap:8px;margin-top:10px;align-items:flex-end}
.wb-chatin textarea{flex:1;background:var(--ds-surface-sunken);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);color:var(--ds-ink);padding:8px 10px;font-size:14px;font-family:var(--ds-font-ui);outline:none;resize:none;line-height:1.5}
.wb-chatin textarea:focus{border-color:var(--ds-accent);box-shadow:0 0 0 3px var(--ds-accent-soft)}
.wb-colhead{flex:0 0 auto;padding:11px 16px;font-size:14px;font-weight:600;color:var(--ds-ink);border-bottom:1px solid var(--ds-border);background:var(--ds-surface);display:flex;align-items:center;gap:8px}
.wb-colhead .wb-muted{font-weight:400;font-size:13px}
.wb-colbody{flex:1 1 auto;overflow:auto;padding:16px}
/* drag handle (like dls-ticket-full column dividers) */
.wb-divider{flex:0 0 7px;cursor:col-resize;background:transparent;position:relative;align-self:stretch}
.wb-divider::after{content:'';position:absolute;left:3px;top:0;bottom:0;width:1px;background:var(--ds-border)}
.wb-divider:hover::after,.wb-divider.dragging::after{width:3px;left:2px;background:var(--ds-accent)}
.wb-lens-panel.hidden,.wb-hidden{display:none!important}
.wb-mono{font-family:var(--ds-font-mono)}
.wb-muted{color:var(--ds-ink-3)}

/* ---- READ lens ---- */
.wb-legend{position:sticky;top:0;z-index:5;background:var(--ds-bg);border-bottom:1px solid var(--ds-border);padding:9px 40px;display:flex;gap:20px;font-size:13px;color:var(--ds-ink-3);align-items:center}
.wb-legend i{font-style:normal;display:inline-flex;align-items:center;gap:7px}
.wb-sw{width:22px;display:inline-block;border-bottom:2px solid var(--ds-accent)}
.wb-sw.d{border-bottom:1.5px dotted var(--ds-ink-3)}
.wb-sw.v{border-bottom:2px solid var(--ds-warn)}
.wb-legend .wb-count{margin-left:auto;color:var(--ds-ink-4);font-family:var(--ds-font-mono);font-size:12px}
.wb-doc{max-width:720px;margin:0 auto;padding:28px 40px 90px}
.wb-crumbs{font-size:13px;color:var(--ds-ink-4);margin-bottom:8px;font-family:var(--ds-font-mono)}
.wb-crumbs b{color:var(--ds-ink-3);font-weight:500}
.wb-doc h1{font-size:28px;line-height:1.15;margin:.1em 0;font-weight:600;letter-spacing:-.01em;color:var(--ds-ink)}
.wb-docmeta{font-size:13px;color:var(--ds-ink-4);margin:8px 0 24px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.wb-status-pill{font-size:13px;border-radius:999px;padding:2px 10px;border:1px solid var(--ds-border);background:transparent;color:var(--ds-ink-3)}
.wb-status-pill.ok{color:var(--ds-success);border-color:var(--ds-success)}
.wb-status-pill.interim{color:var(--ds-warn);border-color:var(--ds-warn)}
.wb-prose{margin:14px 0;color:var(--ds-ink-2);font-size:15px;line-height:1.75}
.wb-prose p{margin:14px 0}
.wb-prose h2{font-size:19px;font-weight:600;color:var(--ds-ink);margin:30px 0 6px;letter-spacing:-.01em}
.wb-prose h3{font-size:16px;font-weight:600;color:var(--ds-ink);margin:22px 0 4px}
.wb-prose ul{margin:10px 0;padding-left:22px}
.wb-prose li{margin:6px 0;line-height:1.7}
/* fact highlights in prose */
.wb-f{cursor:pointer;border-radius:2px;padding:0 1px;transition:background .12s}
.wb-f.pre{border-bottom:2px solid var(--ds-accent)}
.wb-f.pre:hover{background:var(--ds-accent-soft)}
.wb-f.draft{border-bottom:1.5px dotted var(--ds-ink-3);color:var(--ds-ink)}
.wb-f.draft:hover{background:var(--ds-surface-sunken)}
.wb-f.dup{border-bottom:2px solid var(--ds-warn)}
.wb-f.dup:hover{background:var(--ds-warn-soft)}
.wb-f.sel{background:var(--ds-accent-soft)!important;box-shadow:0 0 0 1px var(--ds-accent)}
.wb-article-pick{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 4px}
.wb-article-pick .chip{cursor:pointer}

/* ---- FACTS lens (inline-expand list) ---- */
.wb-panel{max-width:880px;margin:0 auto;padding:24px 40px 80px}
.wb-panel h1{font-size:20px;margin:0 0 4px;font-weight:600;color:var(--ds-ink)}
.wb-panel .wb-sub{color:var(--ds-ink-3);font-size:14px;margin-bottom:18px;line-height:1.55}
.wb-facts-controls{display:flex;gap:10px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.wb-facts-controls input[type=search]{flex:1;min-width:200px;background:var(--ds-surface-sunken);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);color:var(--ds-ink);padding:7px 11px;font-size:14px;outline:none}
.wb-facts-controls input:focus{border-color:var(--ds-accent);box-shadow:0 0 0 3px var(--ds-accent-soft)}
.wb-pills{display:flex;gap:4px;flex-wrap:wrap}
.wb-pill{font-size:13px;border:1px solid var(--ds-border);background:var(--ds-surface-raised);color:var(--ds-ink-3);border-radius:999px;padding:4px 11px;cursor:pointer}
.wb-pill:hover{border-color:var(--ds-border-strong);color:var(--ds-ink)}
.wb-pill.active{background:var(--ds-accent-soft);border-color:var(--ds-accent);color:var(--ds-accent)}
/* row */
.wb-row{border:1px solid transparent;border-radius:var(--ds-r-sm);cursor:pointer;transition:background .12s,border-color .12s}
.wb-row:hover{background:var(--ds-surface-raised);border-color:var(--ds-border)}
.wb-row.expanded{background:var(--ds-surface-raised);border-color:var(--ds-border);border-left:2px solid var(--ds-accent)}
.wb-row-head{display:flex;align-items:center;gap:12px;padding:9px 12px}
.wb-row .slug{flex:1}
.wb-row .val{color:var(--ds-ink-3);font-size:13px;font-family:var(--ds-font-mono)}
.wb-row-details{border-top:1px solid var(--ds-border);padding:12px;margin:0 4px}

/* ---- shared detail (slug card) ---- */
.slug{font-family:var(--ds-font-mono);font-size:14px;color:var(--ds-accent);font-weight:500;word-break:break-all}
.wb-empty{color:var(--ds-ink-4);text-align:center;padding:48px 12px;font-size:14px;line-height:1.7}
.wb-statline{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0 16px}
.wb-band{font-size:13px;border-radius:999px;padding:1px 9px;background:transparent;border:1px solid var(--ds-ink-4);color:var(--ds-ink-3);font-family:var(--ds-font-mono)}
.wb-band.pre{border-color:var(--ds-accent);color:var(--ds-accent)}
.wb-band.canonical{border-color:var(--ds-success);color:var(--ds-success)}
.wb-band.role{border-color:var(--ds-border-strong);color:var(--ds-ink-3)}
.wb-band.role.hard{border-color:var(--ds-danger);color:var(--ds-danger)}
.wb-band.warn{border-color:var(--ds-warn);color:var(--ds-warn)}
.wb-field{margin:14px 0}
.wb-field label{display:block;font-size:13px;color:var(--ds-ink-3);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.wb-field input,.wb-field select{width:100%;background:var(--ds-surface-sunken);border:1px solid var(--ds-border);border-radius:var(--ds-r-sm);color:var(--ds-ink);padding:7px 10px;font-size:14px;outline:none;font-family:var(--ds-font-mono)}
.wb-field select{font-family:var(--ds-font-ui)}
.wb-field input:focus,.wb-field select:focus{border-color:var(--ds-accent);box-shadow:0 0 0 3px var(--ds-accent-soft)}
.wb-ev{background:var(--ds-surface-sunken);border-left:2px solid var(--ds-ink-4);padding:9px 12px;border-radius:0 var(--ds-r-sm) var(--ds-r-sm) 0;font-size:14px;color:var(--ds-ink-2);line-height:1.6}
.wb-ev b{display:block;color:var(--ds-ink-3);font-size:12px;font-weight:500;font-family:var(--ds-font-mono);margin-bottom:3px}
.wb-ev .q{font-style:italic}
.wb-linkrow{display:flex;gap:16px;margin-top:14px;font-size:14px}
.wb-linkrow a{color:var(--ds-accent);text-decoration:none;cursor:pointer}
.wb-linkrow a:hover{color:var(--ds-accent-hover);text-decoration:underline}
.wb-reaches{margin-top:16px;border-top:1px solid var(--ds-border);padding-top:12px}
.wb-reaches h4{margin:0 0 8px;font-size:12px;color:var(--ds-ink-3);text-transform:uppercase;letter-spacing:.3px;font-weight:500}
.wb-cons{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ds-ink-2);padding:3px 0}
.wb-dot{width:8px;height:8px;display:inline-block}
.wb-dot.ok{background:var(--ds-success)} .wb-dot.no{background:var(--ds-ink-4)}
.wb-savebar{margin-top:16px;border-top:1px solid var(--ds-border);padding-top:12px;display:none;gap:8px;align-items:center}
.wb-savebar.show{display:flex}
.wb-savebar .note{font-size:13px;flex:1;line-height:1.4}
.wb-savebar .note.live{color:var(--ds-success)} .wb-savebar .note.prop{color:var(--ds-warn)}
.wb-btn{border:1px solid var(--ds-border);background:var(--ds-surface-raised);border-radius:var(--ds-r-sm);padding:6px 14px;font-size:13px;font-weight:500;color:var(--ds-ink-2);cursor:pointer}
.wb-btn:hover{border-color:var(--ds-border-strong);color:var(--ds-ink)}
.wb-btn.primary{background:var(--ds-accent);border-color:var(--ds-accent);color:var(--ds-accent-ink)}
.wb-btn.primary:hover{background:var(--ds-accent-hover);border-color:var(--ds-accent-hover);color:#fff}
.wb-btn.propose{border-color:var(--ds-warn);color:var(--ds-warn);background:var(--ds-warn-soft)}
.wb-btn.propose:hover{background:var(--ds-warn);color:#fff}
.wb-btn.ghost{background:transparent}

/* chat pane (stub for now) */
.wb-chat-stub{color:var(--ds-ink-3);font-size:14px;line-height:1.7;padding:24px 6px;text-align:center}

/* coming-soon lens placeholders */
.wb-soon{max-width:560px;margin:60px auto;text-align:center;color:var(--ds-ink-3);font-size:15px;line-height:1.7}
.wb-soon h2{color:var(--ds-ink);font-size:20px;margin:0 0 8px;font-weight:600}
.wb-soon code{font-family:var(--ds-font-mono);background:var(--ds-surface-sunken);padding:1px 5px;border-radius:3px;color:var(--ds-accent);font-size:13px}

/* selection-to-fact floating btn */
#wb-selbtn{position:fixed;z-index:1200;display:none;background:var(--ds-accent);color:var(--ds-accent-ink);border:none;border-radius:var(--ds-r-sm);padding:6px 12px;font-size:13px;font-weight:500;box-shadow:var(--ds-shadow-overlay);cursor:pointer}

/* toast */
#wb-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);opacity:0;transition:.22s;background:var(--ds-ink);color:var(--ds-surface);border-radius:var(--ds-r-sm);padding:10px 18px;font-size:14px;z-index:1300;box-shadow:var(--ds-shadow-overlay)}
#wb-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#wb-toast .k{display:inline-block;width:8px;height:8px;margin-right:8px;vertical-align:middle}
#wb-toast.live .k{background:var(--ds-success)} #wb-toast.prop .k{background:var(--ds-warn)}
