/* chat-render.css — 代码块 + HTML 预览卡 */

/* ── LaTeX 数学 ── */
.cr-math-block{
  margin:8px 0;
  padding:12px 14px;
  background:rgba(43,36,32,.03);
  border-radius:12px;
  overflow-x:auto;
  text-align:center;
}
.cr-math-block .katex{font-size:1.1em}
.katex{font-size:.95em}

/* ── 行内代码 ── */
.cr-inline{
  background:rgba(43,36,32,.07);
  border-radius:5px;
  padding:1.5px 5px;
  font-family:var(--mono);
  font-size:12px;
  color:var(--accent-deep);
}
.msg.user .cr-inline{
  background:rgba(255,255,255,.12);
  color:#f2dfd4;
}

/* ── 代码块 ── */
.cr-code-block{
  margin:4px 0 2px;
  border-radius:12px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  --cr-bg:#2b2420;
  --cr-bar:rgba(255,255,255,.04);
  --cr-bar-border:rgba(255,255,255,.06);
  --cr-fg:#f5ede4;
  --cr-fg-soft:rgba(245,237,228,.5);
  --cr-fg-faint:rgba(245,237,228,.2);
  --cr-btn-bg:rgba(255,255,255,.08);
  --cr-btn-hover:rgba(255,255,255,.14);
  --cr-btn-fg:rgba(245,237,228,.6);
}

/* 主题：dark 已在上方定义为默认值 */
.cr-code-block[data-theme="warm"]{
  --cr-bg:#faf5ed;
  --cr-bar:rgba(43,36,32,.04);
  --cr-bar-border:rgba(43,36,32,.08);
  --cr-fg:#2b2420;
  --cr-fg-soft:rgba(43,36,32,.45);
  --cr-fg-faint:rgba(43,36,32,.15);
  --cr-btn-bg:rgba(43,36,32,.06);
  --cr-btn-hover:rgba(43,36,32,.12);
  --cr-btn-fg:rgba(43,36,32,.5);
  border-color:rgba(43,36,32,.1);
}
.cr-code-block[data-theme="moss"]{
  --cr-bg:#1a2e1e;
  --cr-bar:rgba(255,255,255,.04);
  --cr-bar-border:rgba(255,255,255,.06);
  --cr-fg:#d8e4d9;
  --cr-fg-soft:rgba(216,228,217,.5);
  --cr-fg-faint:rgba(216,228,217,.2);
  --cr-btn-bg:rgba(255,255,255,.08);
  --cr-btn-hover:rgba(255,255,255,.14);
  --cr-btn-fg:rgba(216,228,217,.6);
}
.cr-code-block[data-theme="rose"]{
  --cr-bg:#2e1f24;
  --cr-bar:rgba(255,255,255,.04);
  --cr-bar-border:rgba(255,255,255,.06);
  --cr-fg:#f0dde0;
  --cr-fg-soft:rgba(240,221,224,.5);
  --cr-fg-faint:rgba(240,221,224,.2);
  --cr-btn-bg:rgba(255,255,255,.08);
  --cr-btn-hover:rgba(255,255,255,.14);
  --cr-btn-fg:rgba(240,221,224,.6);
}
.cr-code-block[data-theme="ocean"]{
  --cr-bg:#1a2230;
  --cr-bar:rgba(255,255,255,.04);
  --cr-bar-border:rgba(255,255,255,.06);
  --cr-fg:#d4e2f0;
  --cr-fg-soft:rgba(212,226,240,.5);
  --cr-fg-faint:rgba(212,226,240,.2);
  --cr-btn-bg:rgba(255,255,255,.08);
  --cr-btn-hover:rgba(255,255,255,.14);
  --cr-btn-fg:rgba(212,226,240,.6);
}

.cr-code-block{background:var(--cr-bg,#2b2420)}
.cr-code-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:6px 12px;
  background:var(--cr-bar,rgba(255,255,255,.04));
  border-bottom:1px solid var(--cr-bar-border,rgba(255,255,255,.06));
}
.cr-code-lang{
  font-family:var(--mono);
  font-size:9px;
  font-weight:600;
  color:var(--cr-fg-soft,rgba(245,237,228,.5));
  letter-spacing:.5px;
}
.cr-code-bar-right{
  display:flex;
  align-items:center;
  gap:4px;
}
.cr-code-copy{
  border:none;
  background:var(--cr-btn-bg,rgba(255,255,255,.08));
  color:var(--cr-btn-fg,rgba(245,237,228,.6));
  font-family:var(--mono);
  font-size:9px;
  padding:3px 8px;
  border-radius:6px;
  cursor:pointer;
  transition:background .12s,color .12s;
}
.cr-code-copy:hover{background:var(--cr-btn-hover,rgba(255,255,255,.14));color:var(--cr-fg)}
.cr-code-copy:active{transform:scale(.94)}
.cr-code-scroll{
  display:flex;
  overflow-x:auto;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  max-height:320px;
  overflow-y:auto;
}
.cr-code-scroll::-webkit-scrollbar{display:none}
.cr-code-lines{
  display:flex;
  flex-direction:column;
  padding:10px 0 10px 12px;
  text-align:right;
  user-select:none;
  flex-shrink:0;
  min-width:28px;
}
.cr-ln{
  font-family:var(--mono);
  font-size:11px;
  line-height:1.7;
  color:var(--cr-fg-faint,rgba(245,237,228,.2));
}
.cr-code-pre{
  margin:0;
  padding:10px 14px;
  font-family:var(--mono);
  font-size:11px;
  line-height:1.7;
  color:var(--cr-fg,#f5ede4);
  white-space:pre;
  flex:1;
  min-width:0;
}
.cr-code-pre code{font-family:inherit;font-size:inherit}

/* 语法高亮色 — dark 和 moss 通用 */
.cr-comment{color:#8a7e72;font-style:italic}
.cr-keyword{color:#e8a896}
.cr-string{color:#c9a35e}
.cr-number{color:#6b8e6f}
.cr-func{color:#c97b5e}
.cr-type{color:#b8a9d4}
.cr-punct{color:#a89886}
.cr-tag{color:#e8a896}
.cr-attr{color:#c9a35e}
.cr-attrval{color:#6b8e6f}
/* warm 主题语法色 */
.cr-code-block[data-theme="warm"] .cr-comment{color:#a89886}
.cr-code-block[data-theme="warm"] .cr-keyword{color:#a85f45}
.cr-code-block[data-theme="warm"] .cr-string{color:#8a6d2f}
.cr-code-block[data-theme="warm"] .cr-number{color:#4a7a4e}
.cr-code-block[data-theme="warm"] .cr-func{color:#c97b5e}
.cr-code-block[data-theme="warm"] .cr-type{color:#7a6aa8}
.cr-code-block[data-theme="warm"] .cr-punct{color:#a89886}
.cr-code-block[data-theme="warm"] .cr-tag{color:#a85f45}
.cr-code-block[data-theme="warm"] .cr-attr{color:#8a6d2f}
.cr-code-block[data-theme="warm"] .cr-attrval{color:#4a7a4e}
/* rose 主题语法色 */
.cr-code-block[data-theme="rose"] .cr-comment{color:#8a7278}
.cr-code-block[data-theme="rose"] .cr-keyword{color:#e89aaa}
.cr-code-block[data-theme="rose"] .cr-string{color:#d4a86a}
.cr-code-block[data-theme="rose"] .cr-number{color:#7eb88a}
.cr-code-block[data-theme="rose"] .cr-func{color:#d98ea0}
.cr-code-block[data-theme="rose"] .cr-type{color:#c4a8d4}
.cr-code-block[data-theme="rose"] .cr-punct{color:#a08a90}
/* ocean 主题语法色 */
.cr-code-block[data-theme="ocean"] .cr-comment{color:#6a7e8a}
.cr-code-block[data-theme="ocean"] .cr-keyword{color:#7eb4d8}
.cr-code-block[data-theme="ocean"] .cr-string{color:#d4c46a}
.cr-code-block[data-theme="ocean"] .cr-number{color:#7ed8a0}
.cr-code-block[data-theme="ocean"] .cr-func{color:#8aabe0}
.cr-code-block[data-theme="ocean"] .cr-type{color:#b8a8e0}
.cr-code-block[data-theme="ocean"] .cr-punct{color:#8a9aa6}

/* 用户消息里的代码块微调 */
.msg.user .cr-code-block{border-color:rgba(255,255,255,.1)}
.msg.user .cr-html-card{border-color:rgba(255,255,255,.15)}

/* ═══ Console-style HTML preview card ═══ */
.cr-html-card{
  margin:10px 0;border-radius:12px;
  border:1px solid rgba(201,125,46,.28);
  background:rgba(201,125,46,.06);
  cursor:pointer;overflow:hidden;
  transition:border-color .18s,background .18s,transform .12s;
  user-select:none;
}
.cr-html-card:hover{border-color:rgba(201,125,46,.55);background:rgba(201,125,46,.11);transform:translateY(-1px)}
.cr-html-card:active{transform:translateY(0)}
.hpc-header{display:flex;align-items:center;gap:8px;padding:10px 14px 7px}
.hpc-icon{font-size:15px;line-height:1}
.hpc-title{font-size:12px;font-weight:600;flex:1;letter-spacing:.03em}
.hpc-open{font-size:11px;opacity:.5;font-style:italic}
.hpc-snippet{padding:0 14px 10px;font-size:10.5px;font-family:var(--mono);opacity:.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}

/* ═══ Console-style HTML fullscreen modal ═══ */
.hpm-modal{
  position:fixed;inset:0;z-index:9800;
  display:none;flex-direction:column;
  background:#fff;
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
}
.hpm-modal.open{transform:translateY(0)}
.hpm-header{
  display:flex;align-items:center;
  padding:12px 16px;
  border-bottom:1px solid rgba(201,125,46,.2);
  gap:12px;min-height:52px;flex-shrink:0;
}
.hpm-back-btn{
  background:none;border:none;font-size:13px;
  color:#c47a3a;cursor:pointer;padding:6px 10px;
  border-radius:8px;font-weight:600;transition:background .15s;white-space:nowrap;
}
.hpm-back-btn:hover{background:rgba(201,125,46,.1)}
.hpm-title{flex:1;font-size:13px;font-weight:600;text-align:center;opacity:.7}
.hpm-frame{flex:1;border:none;width:100%;background:#fff}

.hpm-menu-wrap{position:relative}
.hpm-menu-btn{
  background:none;border:none;cursor:pointer;
  padding:7px 10px;border-radius:8px;
  color:#c47a3a;font-size:16px;font-weight:700;
  transition:background .15s;
}
.hpm-menu-btn:hover{background:rgba(201,125,46,.1)}
.hpm-menu-popup{
  position:absolute;top:calc(100% + 6px);right:0;
  background:var(--bg,#FAF6F0);
  border:1px solid rgba(201,125,46,.25);border-radius:12px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  overflow:hidden;min-width:148px;
  opacity:0;transform:scale(.92) translateY(-6px);
  transform-origin:top right;pointer-events:none;
  transition:opacity .15s,transform .15s;z-index:10;
}
.hpm-menu-popup.open{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}
.hpm-menu-item{
  display:flex;align-items:center;gap:8px;
  width:100%;padding:11px 16px;border:none;background:none;
  text-align:left;font-size:13px;cursor:pointer;
  color:var(--ink,#3A2010);transition:background .12s;
}
.hpm-menu-item:hover{background:rgba(201,125,46,.1)}

.hpm-src-view{
  position:absolute;bottom:0;left:0;right:0;height:55%;
  background:#1a1208;display:flex;flex-direction:column;
  border-top:1px solid rgba(201,125,46,.3);z-index:5;
  animation:srcSlideUp .22s ease;
}
@keyframes srcSlideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.hpm-src-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;font-size:12px;color:#c47a3a;
  font-weight:600;border-bottom:1px solid rgba(201,125,46,.15);flex-shrink:0;
}
.hpm-src-close{background:none;border:none;color:#c47a3a;cursor:pointer;font-size:14px;padding:2px 6px;border-radius:6px}
.hpm-src-close:hover{background:rgba(201,125,46,.15)}
.hpm-src-pre{
  flex:1;overflow:auto;padding:14px 16px;margin:0;
  font-family:var(--mono);font-size:11px;line-height:1.6;
  color:#d4b896;white-space:pre;word-break:normal;
}

/* ═══ Tool detail expandable ═══ */
.msg-tool-detail{display:inline-flex;flex-direction:column;vertical-align:top}
.msg-tool-tag.expandable{cursor:pointer}
.msg-tool-tag.expandable .tool-arrow{font-size:9px;transition:transform .15s}
.msg-tool-tag.expandable.open .tool-arrow{transform:rotate(90deg)}
.tool-detail-body{
  display:none;
  margin:4px 0 2px;
  padding:8px 10px;
  background:rgba(43,36,32,.04);
  border:1px solid var(--line,rgba(43,36,32,.08));
  border-radius:10px;
  max-width:320px;
  overflow:hidden;
}
.msg-tool-detail.open .tool-detail-body{display:block}
.tool-detail-section{margin-bottom:6px}
.tool-detail-section:last-child{margin-bottom:0}
.tool-detail-label{font-size:9px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.tool-detail-pre{
  margin:0;padding:6px 8px;
  background:rgba(43,36,32,.06);border-radius:6px;
  font-family:var(--mono);font-size:10px;line-height:1.5;
  color:var(--ink-soft);white-space:pre-wrap;word-break:break-all;
  max-height:120px;overflow-y:auto;
}
