/* ask-dom.css — right-rail assistant · NuCRM / NuStack design system */
.ad-wrap{display:flex;flex-direction:column;height:100%;background:var(--surface)}
.ad-tabbar{display:flex;align-items:center;gap:4px;padding:12px 14px 0;border-bottom:1px solid var(--border)}
.ad-tab{display:flex;align-items:center;gap:7px;padding:8px 12px;font-size:13px;font-weight:650;color:var(--muted);background:transparent;border:0;border-bottom:2px solid transparent;cursor:pointer;transition:.12s}
.ad-tab:hover{color:var(--ink)}
.ad-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.ad-tab .ad-dot{width:7px;height:7px;border-radius:50%;background:var(--green);display:inline-block}
.ad-body{flex:1;display:flex;flex-direction:column;overflow:hidden}
.ad-panel{flex:1;display:none;flex-direction:column;overflow:hidden}
.ad-panel.active{display:flex}

/* context chip */
.ad-ctx{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);font-size:12px}
.ad-ctx .lbl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.ad-ctx .slug{font-weight:650;font-size:12px;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.ad-ctx .clear{margin-left:auto;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-2);border-radius:999px;padding:4px 11px;cursor:pointer;transition:.12s;box-shadow:var(--shadow-sm)}
.ad-ctx .clear:hover{background:var(--surface-3);border-color:var(--border-strong)}

/* chat */
.ad-chat{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:12px}
.ad-empty{color:var(--muted);font-size:13px;line-height:1.65;text-align:center;padding:32px 16px}
.ad-empty b{color:var(--ink)}
.ad-divider{display:flex;align-items:center;gap:9px;margin:5px 0 1px}
.ad-divider .rule{flex:1;height:1px;background:var(--border)}
.ad-divider .lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:3px 10px;border-radius:999px;white-space:nowrap}
.ad-bubble .role{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:4px}
.ad-bubble.user .role{color:var(--accent)}
.ad-bubble .body{font-size:13.5px;line-height:1.6;color:var(--ink)}
.ad-bubble.user .body{background:var(--accent);border-radius:12px 12px 3px 12px;padding:10px 13px;color:#fff;box-shadow:0 1px 2px rgba(58,85,230,.25)}
.ad-bubble.dom .body{background:var(--surface);border:1px solid var(--border);border-radius:12px 12px 12px 3px;padding:11px 14px;box-shadow:var(--shadow-sm)}
.ad-bubble .body p{margin:0 0 8px}.ad-bubble .body p:last-child{margin:0}
.ad-bubble .body ul{margin:6px 0;padding-left:18px}.ad-bubble .body li{margin:3px 0}
.ad-bubble .body li::marker{color:var(--accent)}
.ad-bubble.dom .body strong{color:var(--ink);font-weight:700}
.ad-bubble.user .body strong{color:#fff}
.ad-bubble.thinking .body{color:var(--muted);font-style:italic}
.ad-cite{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:var(--accent);background:var(--accent-wash);border-radius:999px;padding:3px 9px;margin:3px 4px 0 0}

/* artifact card */
.ad-artifact{margin-top:11px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow-sm)}
.ad-artifact .ah{display:flex;align-items:center;gap:8px;padding:10px 13px;font-size:11.5px;font-weight:700;color:var(--ink);background:var(--surface-2);border-bottom:1px solid var(--border)}
.ad-artifact .ah .gold{color:var(--accent)}
.ad-artifact .ab{padding:12px 13px;font-size:12.5px;line-height:1.55;color:var(--ink-2)}
.ad-artifact .ab b{color:var(--ink)}
.ad-artifact .brandrow{display:flex;align-items:center;gap:6px;margin:9px 0}
.ad-artifact .sw{width:17px;height:17px;border-radius:5px;border:1px solid rgba(0,0,0,.08)}
.ad-artifact .gen{margin-top:10px;width:100%;padding:10px;border:1px solid var(--accent);border-radius:9px;background:var(--accent);color:#fff;font-size:12.5px;font-weight:700;cursor:pointer;box-shadow:0 1px 2px rgba(58,85,230,.25);transition:.12s}
.ad-artifact .gen:hover{background:var(--accent-press);border-color:var(--accent-press)}

/* composer */
.ad-composer{border-top:1px solid var(--border);padding:12px 14px;background:var(--surface)}
.ad-composer textarea{width:100%;min-height:56px;max-height:140px;resize:vertical;border:1px solid var(--border-2);border-radius:10px;padding:10px 12px;font:13.5px var(--sans);color:var(--ink);outline:none;transition:.14s}
.ad-composer textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-wash)}
.ad-foot{display:flex;align-items:center;justify-content:space-between;margin-top:9px}
.ad-foot .pwr{font-size:11px;color:var(--muted)}.ad-foot .pwr b{color:var(--ink-2)}
.ad-send{padding:9px 18px;border:1px solid var(--accent);border-radius:9px;background:var(--accent);color:#fff;font-size:12.5px;font-weight:700;cursor:pointer;box-shadow:0 1px 2px rgba(58,85,230,.25);transition:.12s}
.ad-send:hover{background:var(--accent-press);border-color:var(--accent-press)}
.ad-send:disabled{opacity:.5;cursor:not-allowed}
.ad-suggest{display:flex;flex-wrap:wrap;gap:7px;padding:0 14px 12px}
.ad-chip{font-size:11.5px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-2);border-radius:999px;padding:6px 12px;cursor:pointer;box-shadow:var(--shadow-sm);transition:.12s}
.ad-chip:hover{border-color:var(--accent-border);background:var(--accent-wash);color:var(--accent)}

/* artifacts gallery */
.ad-gallery{flex:1;overflow-y:auto;padding:14px}
.ad-gcard{border:1px solid var(--border);border-radius:var(--radius);padding:12px 13px;margin-bottom:10px;display:flex;gap:11px;align-items:flex-start;cursor:pointer;background:var(--surface);box-shadow:var(--shadow-sm);transition:.12s}
.ad-gcard:hover{border-color:var(--accent-border);box-shadow:var(--shadow);transform:translateY(-1px)}
.ad-gcard .ico{font-size:20px}
.ad-gcard .t{font-size:13px;font-weight:650;color:var(--ink)}
.ad-gcard .m{font-size:11px;color:var(--muted);margin-top:3px}
.ad-gnew{width:100%;padding:11px;border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--surface-2);color:var(--ink-2);font-size:12.5px;font-weight:650;cursor:pointer;margin-bottom:11px;transition:.12s}
.ad-gnew:hover{background:var(--accent-wash);border-color:var(--accent-border);color:var(--accent)}

/* generation modal */
.ad-modal-bg{position:fixed;inset:0;background:rgba(25,27,35,.32);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}
.ad-modal{width:440px;max-width:92vw;background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg)}
.ad-modal .mh{padding:20px 22px 16px;font-size:17px;font-weight:760;letter-spacing:-.3px;color:var(--ink);display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--border)}
.ad-modal .mh .gold{color:var(--accent)}
.ad-modal .mb{padding:22px}
.ad-prog{height:8px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin:16px 0}
.ad-prog > i{display:block;height:100%;width:0;border-radius:999px;transition:width .42s cubic-bezier(.22,.61,.36,1);background:var(--accent)}
.ad-step{font-size:13.5px;color:var(--ink);min-height:20px}
.ad-step .em{color:var(--muted)}
.ad-modal .done{margin-top:16px;display:none}.ad-modal .done.show{display:block}
.ad-modal .done .ok{font-size:13px;font-weight:700;color:var(--green);margin-bottom:12px}
.ad-modal .slides{display:flex;gap:9px;margin-bottom:16px}
.ad-modal .sl{flex:1;aspect-ratio:16/10;border:1px solid var(--border);border-radius:8px;background:var(--surface);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.ad-modal .sl .bar{position:absolute;left:0;top:0;height:6px;width:100%}
.ad-modal .sl .ln{position:absolute;left:9px;height:4px;border-radius:2px;background:var(--surface-3)}
.ad-modal .mbtns{display:flex;gap:9px}
.ad-modal button.primary{flex:1;padding:10px;border:1px solid var(--accent);border-radius:9px;background:var(--accent);color:#fff;font-size:12.5px;font-weight:700;cursor:pointer;box-shadow:0 1px 2px rgba(58,85,230,.25)}
.ad-modal button.ghost{padding:10px 16px;border:1px solid var(--border-2);border-radius:9px;background:var(--surface);color:var(--ink-2);font-size:12.5px;font-weight:650;cursor:pointer;box-shadow:var(--shadow-sm)}
