/* Round 27: Per-doc scoped chat panel — slides in from right on any
   detail page. Consumes /api/v1/chat/{company}/scoped/messages/stream.
   Diagram: solace/diagrams/round27-scoped-chat-panel.prime-mermaid.md */

.scp-trigger { display:inline-flex; align-items:center; gap:6px;
  padding:6px 12px; border:1px solid var(--border-card, #e5e7eb);
  border-radius:999px; background:var(--bg, #fff); cursor:pointer;
  font-size:13px; font-weight:500; color:var(--text, #111);
  transition:all 0.15s; }
.scp-trigger:hover { background:#f0f9ff; border-color:#2563eb; color:#1e3a8a; }
.scp-trigger .scp-dot { width:8px; height:8px; border-radius:50%;
  background:#10b981; box-shadow:0 0 0 2px rgba(16,185,129,0.2); }

.scp-panel { position:fixed; top:0; right:0; width:min(480px, 95vw);
  height:100vh; background:var(--bg, #fff);
  border-left:1px solid var(--border-card, #e5e7eb);
  box-shadow:-8px 0 32px rgba(0,0,0,0.08); z-index:999;
  display:flex; flex-direction:column; transform:translateX(100%);
  transition:transform 0.25s cubic-bezier(0.4,0,0.2,1); }
.scp-panel.scp-open { transform:translateX(0); }

.scp-header { display:flex; gap:10px; align-items:center;
  padding:14px 16px; border-bottom:1px solid var(--border-card, #e5e7eb);
  background:linear-gradient(180deg, #f8fafc, var(--bg, #fff)); }
.scp-header-title { flex:1; min-width:0; }
.scp-header-title .scp-title { font-weight:700; font-size:14px;
  color:var(--text, #111); }
.scp-header-title .scp-subtitle { font-size:11px; color:var(--text-dim, #6b7280);
  font-family:var(--font-mono, monospace); overflow:hidden;
  text-overflow:ellipsis; white-space:nowrap; }
.scp-header-btn { background:transparent; border:1px solid var(--border-card, #e5e7eb);
  border-radius:6px; padding:4px 8px; font-size:11px; cursor:pointer;
  color:var(--text-muted, #6b7280); }
.scp-header-btn:hover { background:var(--bg-hover, #f3f4f6); color:var(--text, #111); }
.scp-header-btn.scp-raw-on { background:#fef3c7; border-color:#f59e0b; color:#92400e; }

.scp-body { flex:1; overflow-y:auto; padding:16px;
  display:flex; flex-direction:column; gap:12px;
  background:linear-gradient(180deg, var(--bg, #fff), #fafafa); }

.scp-msg { display:flex; flex-direction:column; gap:4px; max-width:90%; }
.scp-msg.scp-user { align-self:flex-end; align-items:flex-end; }
.scp-msg.scp-worker { align-self:flex-start; align-items:flex-start; }
.scp-msg .scp-who { font-size:10px; color:var(--text-dim, #6b7280);
  font-weight:600; letter-spacing:0.02em; text-transform:uppercase; }
.scp-msg .scp-bubble { padding:10px 14px; border-radius:12px;
  font-size:13px; line-height:1.5; white-space:pre-wrap; word-wrap:break-word; }
.scp-msg.scp-user .scp-bubble { background:#2563eb; color:#fff;
  border-bottom-right-radius:4px; }
.scp-msg.scp-worker .scp-bubble { background:#f1f5f9; color:#0f172a;
  border-bottom-left-radius:4px; border:1px solid #e2e8f0; }
.scp-msg .scp-banter { font-size:11px; font-style:italic;
  color:#f59e0b; padding:2px 8px; background:#fef3c7;
  border-radius:10px; margin-bottom:2px; }
.scp-msg .scp-context { font-size:10px; color:var(--text-dim, #6b7280);
  font-family:var(--font-mono, monospace); padding:2px 8px;
  background:rgba(0,0,0,0.04); border-radius:10px; }

.scp-tool-card { margin-top:6px; padding:10px 12px; border-radius:10px;
  background:#fefce8; border:1px solid #fde047;
  display:flex; flex-direction:column; gap:6px; }
.scp-tool-card .scp-tool-head { display:flex; gap:8px; align-items:center;
  font-size:11px; font-weight:700; color:#92400e; letter-spacing:0.02em;
  text-transform:uppercase; }
.scp-tool-card .scp-tool-head::before { content:'⚡'; font-size:14px; }
.scp-tool-card .scp-tool-args { font-family:var(--font-mono, monospace);
  font-size:11px; color:#451a03; background:rgba(255,255,255,0.6);
  padding:8px 10px; border-radius:6px; max-height:180px; overflow-y:auto;
  white-space:pre-wrap; word-wrap:break-word; }
.scp-tool-card .scp-tool-actions { display:flex; gap:6px; }
.scp-tool-card .scp-btn { padding:6px 12px; border-radius:6px;
  font-size:12px; font-weight:600; cursor:pointer; border:none; }
.scp-tool-card .scp-btn-queue { background:#f59e0b; color:#fff; }
.scp-tool-card .scp-btn-queue:hover { background:#d97706; }
.scp-tool-card .scp-btn-reject { background:transparent;
  border:1px solid #e5e7eb; color:#6b7280; }
.scp-tool-card.scp-error { background:#fef2f2; border-color:#fca5a5; }
.scp-tool-card.scp-error .scp-tool-head { color:#991b1b; }
.scp-tool-card.scp-error .scp-tool-head::before { content:'⚠'; }

.scp-mmdiff-card { margin-top:6px; padding:10px 12px; border-radius:10px;
  background:#faf5ff; border:1px solid #d8b4fe;
  display:flex; flex-direction:column; gap:8px; }
.scp-mmdiff-card .scp-tool-head { display:flex; gap:8px; align-items:center;
  font-size:11px; font-weight:700; color:#6d28d9; letter-spacing:0.02em;
  text-transform:uppercase; }
.scp-mmdiff-card .scp-tool-head::before { content:'⬡'; }
.scp-mmdiff-card .scp-diff-grid { display:grid;
  grid-template-columns:1fr 1fr; gap:6px; }
.scp-mmdiff-card .scp-diff-col { display:flex; flex-direction:column; gap:4px; }
.scp-mmdiff-card .scp-diff-col label { font-size:10px; font-weight:600;
  color:#6b7280; text-transform:uppercase; letter-spacing:0.02em; }
.scp-mmdiff-card .scp-diff-col pre { background:rgba(255,255,255,0.6);
  padding:6px 8px; border-radius:4px; font-size:10px;
  max-height:140px; overflow:auto; margin:0;
  font-family:var(--font-mono, monospace); }
.scp-mmdiff-card .scp-diff-col.scp-old pre { border-left:3px solid #fca5a5; }
.scp-mmdiff-card .scp-diff-col.scp-new pre { border-left:3px solid #86efac; }
.scp-mmdiff-card .scp-reasoning { font-size:11px; color:#4c1d95;
  font-style:italic; padding:4px 8px; background:rgba(255,255,255,0.5);
  border-radius:4px; }

.scp-footer { display:flex; gap:6px; padding:10px 12px;
  border-top:1px solid var(--border-card, #e5e7eb); background:var(--bg, #fff); }
.scp-footer textarea { flex:1; resize:none; min-height:40px; max-height:120px;
  padding:8px 10px; border:1px solid var(--border-card, #e5e7eb);
  border-radius:8px; font-size:13px; font-family:inherit;
  background:var(--bg, #fff); color:var(--text, #111); }
.scp-footer textarea:focus { outline:none; border-color:#2563eb; }
.scp-footer button { padding:8px 14px; border:none; border-radius:8px;
  background:#2563eb; color:#fff; font-weight:600; font-size:13px; cursor:pointer; }
.scp-footer button:disabled { opacity:0.5; cursor:not-allowed; }

.scp-empty { padding:24px 12px; text-align:center; color:var(--text-dim, #6b7280);
  font-size:12px; }
.scp-raw { font-family:var(--font-mono, monospace); font-size:11px;
  background:#111827; color:#d1d5db; padding:10px 12px;
  border-radius:6px; white-space:pre-wrap; word-wrap:break-word;
  max-height:240px; overflow-y:auto; }

@media (prefers-color-scheme: dark) {
  .scp-panel { background:#0f172a; border-left-color:#1f2937; }
  .scp-header { background:linear-gradient(180deg, #111827, #0f172a); border-bottom-color:#1f2937; }
  .scp-body { background:linear-gradient(180deg, #0f172a, #0b1220); }
  .scp-msg.scp-worker .scp-bubble { background:#1f2937; color:#e5e7eb; border-color:#374151; }
  .scp-footer { background:#0f172a; border-top-color:#1f2937; }
  .scp-footer textarea { background:#111827; color:#e5e7eb; border-color:#374151; }
}
