@import url('../../prototype-shared/components.css');

.qtabs .qtab {flex:0 0 auto;text-align:center;padding:6px 12px;font-size:11px;border-radius:var(--r-pill);color:var(--text-2);font-weight:600;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.qtabs .qtab b {font-weight:700;opacity:.7}
.qtabs .qtab.active b {opacity:1}

@media(max-width:1280px){.queue-shell{grid-template-columns:300px 1fr 320px}}
@media(max-width:1100px){.queue-shell{grid-template-columns:1fr;height:auto}}

.sb-role {margin-top:auto;padding:10px 12px;border-top:1px solid rgba(255,255,255,.08);position:relative}
.sb-role .role-chip {display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:rgba(255,255,255,.06);cursor:pointer;transition:.15s;border:1px solid transparent}
.sb-role .role-chip:hover {background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.12)}
.sb-role .ravatar {width:30px;height:30px;border-radius:50%;background:var(--gradient-brand);color:#fff;display:grid;place-items:center;font-weight:800;font-size:11px;flex-shrink:0}
.sb-role .rmeta {line-height:1.2;flex:1;min-width:0}
.sb-role .rmeta .rname {font-size:12px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-role .rmeta .rrole {font-size:10px;color:#A9F0FA;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.sb-role .rarrow {color:#A9F0FA;opacity:.7;font-size:10px}
.role-menu {position:absolute;left:12px;right:12px;bottom:64px;background:#fff;border-radius:12px;box-shadow:0 20px 50px rgba(30,27,94,.35);padding:6px;display:none;z-index:10}
.role-menu.open {display:block}
.role-menu .role-opt {display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:12px;color:var(--text)}
.role-menu .role-opt:hover {background:var(--risk-soft)}
.role-menu .role-opt.active {background:var(--risk-soft);color:var(--brand)}
.role-menu .role-opt .ic {font-size:14px;line-height:1;margin-top:1px}
.role-menu .role-opt .rt {font-weight:700;color:var(--brand-deep)}
.role-menu .role-opt.active .rt {color:var(--brand)}
.role-menu .role-opt .rd {font-size:10px;color:var(--text-3);margin-top:2px}
.role-badge {display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:var(--r-pill);background:var(--risk-soft);color:var(--brand);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.role-badge .dot {width:6px;height:6px;border-radius:50%;background:var(--brand)}

.split-shell {display:grid;grid-template-columns:380px 1fr;gap:14px;height:calc(100vh - var(--topbar-h) - var(--footer-h) - 44px)}
.split-shell.wide {grid-template-columns:420px 1fr 320px}
.split-pane {background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;min-height:0}
.split-pane .ph {padding:14px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.split-pane .pbody {flex:1;overflow:auto;min-height:0}
.split-pane .pfoot {padding:12px 16px;border-top:1px solid var(--border);background:var(--surface-2);display:flex;gap:8px;align-items:center}

.dlg-card {padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:.12s}
.dlg-card:hover {background:var(--surface-2)}
.dlg-card.active {background:var(--risk-soft);border-left:3px solid var(--brand);padding-left:13px}
.dlg-card .dmeta {display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-3)}
.dlg-card .dmeta .mono {color:var(--text-3);font-size:10px}
.dlg-card .dtitle {font-size:13px;font-weight:600;color:var(--brand-deep);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dlg-card .dbadges {display:flex;gap:4px;flex-wrap:wrap}

.chat-thread {display:flex;flex-direction:column;gap:14px;padding:20px 22px}
.msg {display:flex;gap:10px;max-width:78%}
.msg .av {width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:800;flex-shrink:0;color:#fff}
.msg .av.user {background:var(--accent)}
.msg .av.bot {background:var(--gradient-brand)}
.msg .av.op {background:var(--brand-deep)}
.msg .bubble {background:var(--surface-2);border-radius:14px;padding:11px 14px;font-size:13px;line-height:1.55;color:var(--text);border:1px solid var(--border)}
.msg .bubble .meta {font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-bottom:4px;display:flex;gap:8px;align-items:center}
.msg.user {align-self:flex-end;flex-direction:row-reverse}
.msg.user .bubble {background:var(--info-soft);border-color:transparent}
.msg.bot .bubble {background:#fff;border-color:var(--border)}
.msg.op .bubble {background:#FFF7E6;border-color:#FFE0B5}
.msg .bubble .src {margin-top:8px;display:flex;flex-direction:column;gap:4px;padding-top:8px;border-top:1px dashed var(--border)}
.msg .bubble .src .sline {font-size:11px;color:var(--text-2);display:flex;align-items:center;gap:6px}
.msg .bubble .src .sline .mono {color:var(--brand)}
.msg .bubble .conf {display:inline-flex;align-items:center;gap:5px;font-size:10px;color:var(--text-3);margin-top:6px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.msg .bubble .conf .cbar {width:60px;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}
.msg .bubble .conf .cbar .cfill {height:100%;background:linear-gradient(90deg,var(--brand),var(--ok))}

.composer {display:flex;gap:8px;align-items:flex-end;padding:14px 18px;border-top:1px solid var(--border);background:var(--surface)}
.composer textarea {flex:1;min-height:44px;max-height:140px;padding:11px 14px;border:1px solid var(--border);border-radius:14px;font:inherit;font-size:13px;resize:none;outline:none;background:var(--surface-2);font-family:inherit}
.composer textarea:focus {border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px var(--risk-soft)}

.topic-tree {padding:6px 0}
.topic-tree .topic {display:flex;align-items:center;gap:8px;padding:7px 14px;font-size:12px;color:var(--text-2);cursor:pointer;border-left:2px solid transparent}
.topic-tree .topic:hover {background:var(--surface-2);color:var(--brand-deep)}
.topic-tree .topic.active {background:var(--risk-soft);color:var(--brand);font-weight:600;border-left-color:var(--brand)}
.topic-tree .topic .count {margin-left:auto;font-size:10px;color:var(--text-3);font-weight:600}
.topic-tree .topic.sub {padding-left:30px;font-size:11px}

.kb-editor {display:grid;grid-template-columns:1fr 320px;gap:14px;align-items:start}
.md-toolbar {display:flex;gap:4px;padding:6px;border:1px solid var(--border);border-bottom:0;border-radius:12px 12px 0 0;background:var(--surface-2);flex-wrap:wrap}
.md-toolbar button {height:28px;padding:0 10px;border-radius:8px;font-size:11px;font-weight:600;color:var(--text-2)}
.md-toolbar button:hover {background:#fff;color:var(--brand)}
.md-toolbar .sep {width:1px;background:var(--border);margin:4px 4px}
.md-editor {width:100%;min-height:380px;padding:16px;border:1px solid var(--border);border-radius:0 0 12px 12px;font-family:'JetBrains Mono',monospace;font-size:12px;line-height:1.65;resize:vertical;outline:none;background:#fff}
.md-editor:focus {border-color:var(--brand)}

.conf-ring {display:inline-grid;place-items:center;width:36px;height:36px;border-radius:50%;background:conic-gradient(var(--brand) var(--p,80%),var(--surface-2) 0);position:relative}
.conf-ring::before {content:"";position:absolute;inset:4px;background:#fff;border-radius:50%}
.conf-ring span {position:relative;font-family:'Bebas Neue';font-size:14px;color:var(--brand-deep);letter-spacing:.02em}

.scen-list {display:flex;flex-direction:column;gap:6px}
.scen-list .scen {padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;font-size:12px;color:var(--text);transition:.12s}
.scen-list .scen:hover {border-color:var(--brand);background:var(--risk-soft);color:var(--brand)}

.setting-row {display:grid;grid-template-columns:240px 1fr;gap:24px;padding:14px 0;border-bottom:1px solid var(--border)}
.setting-row:last-child {border-bottom:0}
.setting-row .sr-label {font-weight:700;color:var(--brand-deep);font-size:13px}
.setting-row .sr-desc {color:var(--text-3);font-size:11px;margin-top:4px;line-height:1.4}
.setting-row .sr-ctrl {display:flex;flex-direction:column;gap:8px}

.access-matrix {width:100%;border-collapse:collapse;font-size:12px}
.access-matrix th,.access-matrix td {padding:10px 12px;border-bottom:1px solid var(--border);text-align:center}
.access-matrix th {background:var(--surface-2);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:700}
.access-matrix th:first-child,.access-matrix td:first-child {text-align:left;font-weight:600;color:var(--brand-deep)}
.access-matrix .mark {display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:800}
.access-matrix .mark.yes {background:var(--ok-soft);color:#0F7A45}
.access-matrix .mark.no {background:var(--surface-2);color:var(--text-3)}
.access-matrix .mark.partial {background:var(--warn-soft);color:#B8431F}

.sb-link.hidden-role,.sb-section.hidden-role,.role-hide {display:none !important}

@media(max-width:1280px){.split-shell{grid-template-columns:320px 1fr}.kb-editor{grid-template-columns:1fr}}
@media(max-width:1100px){.split-shell{grid-template-columns:1fr;height:auto}}

.role-sep {height:1px;background:rgba(255,255,255,.08);margin:6px 4px}
.role-opt.role-logout {color:#FFB4C8}
.role-opt.role-logout:hover {background:rgba(237,30,121,.12)}
.role-opt.role-logout .ic {color:#ED1E79}

.topbar .user-chip:hover {background:var(--risk-soft)}

.topbar .user-chip .role-menu {position:absolute;top:calc(100% + 6px);right:0;left:auto;bottom:auto;min-width:260px;background:#fff;border-radius:12px;box-shadow:0 20px 50px rgba(30,27,94,.18);border:1px solid var(--border);padding:6px;display:none;z-index:50}

.topbar .user-chip .role-sep {height:1px;background:var(--border);margin:6px 4px}
.topbar .user-chip .role-opt.role-logout {color:var(--brand)}
.topbar .user-chip .role-opt.role-logout:hover {background:var(--risk-soft)}
.topbar .user-chip .role-opt.role-logout .ic {color:var(--brand)}

.chart {display:grid;grid-template-columns:36px 1fr auto;gap:10px;height:220px;font-size:11px;color:var(--text-2)}
.chart .y-axis {display:flex;flex-direction:column;justify-content:space-between;padding:6px 0 22px;text-align:right;color:var(--text-3);font-variant-numeric:tabular-nums}
.chart .plot {position:relative;display:flex;flex-direction:column;min-width:0}
.chart .plot .grid {position:absolute;inset:6px 0 22px 0;display:flex;flex-direction:column;justify-content:space-between;pointer-events:none}
.chart .plot .grid > div {border-top:1px dashed var(--border)}
.chart .plot .grid > div:last-child {border-top:1px solid var(--border-strong,var(--border))}
.chart .plot .bars {position:absolute;inset:6px 0 22px 0;display:flex;align-items:flex-end;gap:2px}
.chart .plot .bars .bar {flex:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;position:relative;border-radius:3px 3px 0 0;overflow:hidden;transition:filter .12s}
.chart .plot .bars .bar:hover {filter:brightness(1.08)}
.chart .plot .bars .bar .seg-esc {background:var(--brand)}
.chart .plot .bars .bar .seg-bot {background:var(--accent)}
.chart .plot .x-axis {position:absolute;left:0;right:0;bottom:0;height:18px;display:flex;align-items:flex-start;color:var(--text-3);font-variant-numeric:tabular-nums}
.chart .plot .x-axis .tick {flex:1;text-align:center;white-space:nowrap;overflow:hidden}
.chart .legend {display:flex;flex-direction:column;gap:8px;align-self:center;padding-left:14px;border-left:1px solid var(--border);font-size:11px;color:var(--text-2)}
.chart .legend .lg {display:flex;align-items:center;gap:6px}
.chart .legend .sw {width:10px;height:10px;border-radius:2px}

.chart-tt {position:absolute;z-index:30;background:var(--brand-deep);color:#fff;border-radius:8px;padding:8px 10px;font-size:11px;line-height:1.35;box-shadow:0 8px 24px rgba(0,0,0,.18);pointer-events:none;white-space:nowrap;transform:translate(-50%,-100%);margin-top:-8px;opacity:0;transition:opacity .12s}
.chart-tt.show {opacity:1}
.chart-tt .tt-d {font-weight:700;margin-bottom:3px}
.chart-tt .tt-r {display:flex;justify-content:space-between;gap:14px}
.chart-tt .tt-r .v {font-variant-numeric:tabular-nums;font-weight:600}
.chart-tt .dot {display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}

