/* chat-body.css —— 两个 chat(工作台 /workspace + 主页发现页)共用「消息正文」渲染内核的样式。
   配合 chat-body.jsx(window.ChatBody / window.ToolBlock / window.ToolsPanel)。两页都加载本文件
   (工作台经 index.html、主页经 batx.html);规则与 app.css 中同名项一致(单一渲染、避免分叉)。
   各页「外壳」样式(头像/气泡/卡片/token条/报错/chip)仍在各自 app.css/tob.css,本文件不含。 */

/* ── Markdown 正文(window.Markdown 输出)── */
.md-body{white-space:normal;}
.md-body .md-p{margin:0 0 8px;}
.md-body .md-br{height:6px;}
.md-body .md-h{font-weight:700;margin:14px 0 6px;line-height:1.4;}
.md-body h1.md-h{font-size:17px;}
.md-body h2.md-h{font-size:15.5px;}
.md-body h3.md-h,.md-body h4.md-h{font-size:14px;}
.md-body ul,.md-body ol{margin:4px 0 8px;padding-left:20px;}
.md-body li{margin-bottom:3px;}
.md-body .md-bq{border-left:3px solid var(--line2);margin:6px 0;padding:4px 10px;color:var(--t2);font-style:italic;}
.md-body .md-hr{border:none;border-top:1px solid var(--line);margin:12px 0;}
.md-body strong{font-weight:700;}
.md-body em{font-style:italic;}
.md-body a{color:var(--blue);text-decoration:none;}
.md-body a:hover{text-decoration:underline;}
.md-fileref{display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  background:var(--blue-soft);color:var(--blue);border-radius:6px;
  padding:2px 8px 2px 5px;font-size:12.5px;font-weight:500;
  border:1px solid #d6e0fc;margin:0 2px;vertical-align:middle;transition:background .12s;}
.md-fileref:hover{background:#dde7fd;}
.md-fileref-ext{font-size:10px;font-weight:700;background:var(--blue);color:#fff;
  border-radius:3px;padding:0 4px;line-height:16px;font-family:var(--mono);}
.md-ic{background:#f0f2f5;border-radius:4px;padding:1px 5px;font-family:var(--mono);font-size:12.5px;color:#c7254e;}
.md-artifact{display:flex;align-items:center;gap:8px;cursor:pointer;
  background:#f0f4ff;border:1px solid #c7d4fa;border-radius:8px;
  padding:8px 12px;margin:8px 0;transition:background .12s;}
.md-artifact:hover{background:#e0e9ff;}
.md-artifact-ic::before{content:"";display:inline-block;width:14px;height:14px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%232563eb' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2.5' y='3' width='11' height='10' rx='1.2'/%3E%3Cpath d='M2.5 5.8h11'/%3E%3C/svg%3E") center/contain no-repeat;}
.md-artifact-name{font-size:13px;font-weight:600;color:var(--blue);flex:1;}
.md-artifact-badge{font-size:10px;font-weight:700;background:var(--blue);color:#fff;
  border-radius:3px;padding:1px 5px;font-family:var(--mono);}
.md-body .md-pre{background:#1e2229;border-radius:8px;padding:12px 14px;margin:8px 0;overflow-x:auto;}
.md-body .md-code{font-family:var(--mono);font-size:12.5px;color:#e8eaf0;white-space:pre;}
.md-body .md-table-wrap{overflow-x:auto;margin:8px 0;}
.md-body .md-table{border-collapse:collapse;font-size:13px;width:100%;}
.md-body .md-table th,.md-body .md-table td{border:1px solid var(--line);padding:5px 10px;text-align:left;}
.md-body .md-table th{background:#f4f6f8;font-weight:600;}
.md-raw{white-space:pre-wrap;}

/* ── 流式光标 / 等待动画 ── */
.typing{display:inline-flex;gap:4px;align-items:center;color:var(--t2);font-size:13px;}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--t3);animation:bln 1.2s infinite;}
.typing i:nth-child(2){animation-delay:.2s;} .typing i:nth-child(3){animation-delay:.4s;}
@keyframes bln{0%,60%,100%{opacity:.3;}30%{opacity:1;}}
.caret{display:inline-block;width:7px;color:var(--blue);font-weight:700;animation:bk 1s steps(2) infinite;margin-left:1px;}
@keyframes bk{0%,100%{opacity:1;}50%{opacity:0;}}

/* ── 工具调用块(ToolBlock)── */
.tool-block{white-space:normal;background:#f8f9fb;border:1px solid var(--line);border-radius:10px;margin:10px 0 4px;overflow:hidden;font-size:13px;}
.tool-header{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f1f3f6;border-bottom:1px solid var(--line);}
.tool-label{font-size:11.5px;font-weight:700;color:var(--t2);letter-spacing:.3px;flex-shrink:0;}
.tool-arg{flex:1;min-width:0;font-family:var(--mono);font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tool-step{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#eef2fe;color:#2563eb;font-size:10px;font-weight:800;font-family:var(--mono);flex-shrink:0;}
.tool-status{font-size:11px;color:var(--down);flex-shrink:0;}.tool-status.err{color:var(--up);}
.tool-toggle{font-size:10.5px;color:var(--t3);user-select:none;flex-shrink:0;background:#eef0f3;padding:2px 7px;border-radius:5px;}
.tool-empty{padding:10px 18px;font-size:12px;color:var(--t3);}
.tool-running{display:inline-flex;gap:3px;align-items:center;}
.tool-running i{width:5px;height:5px;border-radius:50%;background:var(--blue);animation:bln 1.2s infinite;}
.tool-running i:nth-child(2){animation-delay:.2s;}.tool-running i:nth-child(3){animation-delay:.4s;}
.tool-code{padding:10px 14px;margin:0;font-family:var(--mono);font-size:12px;line-height:1.6;
  white-space:pre-wrap;word-break:break-all;max-height:260px;overflow-y:auto;color:var(--t1);}
.tool-result{border-top:1px solid var(--line);padding:10px 12px;display:flex;flex-direction:column;gap:8px;}
.tool-stdout{margin:0;font-family:var(--mono);font-size:12px;line-height:1.6;white-space:pre-wrap;
  color:var(--t1);background:#fff;border-radius:6px;padding:8px 10px;max-height:220px;overflow-y:auto;}
.tool-error{margin:0;font-family:var(--mono);font-size:12px;line-height:1.6;white-space:pre-wrap;
  color:#c00;background:#fff5f5;border-radius:6px;padding:8px 10px;max-height:220px;overflow-y:auto;}
.tool-figure{max-width:100%;border-radius:8px;display:block;}
.tool-table-wrap{overflow:hidden;}
.tool-table-meta{font-size:11px;color:var(--t3);margin-bottom:4px;}
.tool-table{border-collapse:collapse;font-size:12px;width:100%;font-family:var(--mono);}
.tool-table th,.tool-table td{border:1px solid var(--line);padding:4px 8px;white-space:nowrap;text-align:right;}
.tool-table th{background:#f4f6f8;font-weight:700;text-align:left;color:var(--t2);}
.tool-table tr:nth-child(even) td{background:#fafbfc;}
.tool-table-pager{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:6px;}
.ttp-btn{border:none;background:#f1f3f5;color:var(--t2);width:22px;height:22px;border-radius:6px;cursor:pointer;font-size:13px;line-height:1;transition:.13s;}
.ttp-btn:hover:not(:disabled){background:var(--blue-soft,#eef2fe);color:var(--blue,#3a6df0);}
.ttp-btn:disabled{opacity:.4;cursor:default;}
.ttp-info{font-size:11px;color:var(--t3);font-family:var(--mono);font-variant-numeric:tabular-nums;}

/* ── 工具调用弹窗(ToolsPanel)── */
.tools-overlay{position:fixed;inset:0;background:rgba(8,14,28,.55);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center;}
.tools-modal{width:min(700px,96vw);max-height:82vh;display:flex;flex-direction:column;background:#fff;border-radius:16px;box-shadow:0 24px 72px rgba(8,14,28,.32),0 0 0 1px rgba(255,255,255,.1);overflow:hidden;}
.tools-modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:#0f1117;flex-shrink:0;gap:12px;}
.tools-modal-head span{font-size:13px;font-weight:600;color:#e2e8f0;letter-spacing:-.1px;}
.tools-modal-head-badge{background:rgba(37,99,235,.3);color:#93c5fd;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;font-family:var(--mono);}
.tools-modal-close{background:rgba(255,255,255,.07);border:none;font-size:14px;color:rgba(255,255,255,.5);cursor:pointer;padding:5px 8px;border-radius:7px;line-height:1;flex-shrink:0;transition:background .15s,color .15s;}
.tools-modal-close:hover{background:rgba(255,255,255,.16);color:#fff;}
.tools-modal-body{overflow-y:auto;padding:0;display:flex;flex-direction:column;}
.tools-modal-body .tool-block{margin:0;border:none;border-left:3px solid #a8aeb5;border-radius:0;border-bottom:1px solid var(--line);background:#fff;}
.tools-modal-body .tool-block:last-child{border-bottom:none;}
.tools-modal-body .tool-block.cat-code{border-left-color:#2563eb;}
.tools-modal-body .tool-block.cat-read{border-left-color:#0d9488;}
.tools-modal-body .tool-block.cat-search{border-left-color:#8b5cf6;}
.tools-modal-body .tool-block.cat-web{border-left-color:#e8852b;}
.tools-modal-body .tool-block.cat-write{border-left-color:#15a35a;}
.tools-modal-body .tool-block.cat-skill{border-left-color:#d6453d;}
.tools-modal-body .tool-block.is-err{border-left-color:var(--up);}
.tools-modal-body .tool-header{background:#fafbfc;border-bottom:1px solid var(--line);padding:9px 16px;gap:9px;cursor:pointer;}
.tools-modal-body .tool-header:hover{background:#f1f4f8;}
.tools-modal-body .tool-label{font-size:12.5px;font-weight:700;color:var(--t1);}
.tools-modal-body .tool-code{background:#0f1117;color:#c9d1d9;border-radius:0;margin:0;padding:14px 20px;max-height:200px;border-top:1px solid #222;}
.tools-modal-body .tool-result{background:#f8f9fb;border-top:1px dashed var(--line);padding:12px 18px;}
.tools-modal-body .tool-stdout{background:#fff;color:var(--t1);}
.tools-modal-body .tool-error{background:#fff5f5;}
.tools-modal-body .tool-table-wrap{padding:0;}
/* 头部成败统计 */
.tools-head-stat{display:inline-flex;gap:10px;margin-left:2px;font-family:var(--mono);font-size:11px;font-weight:700;}
.tools-head-stat .ths-ok{color:#34d399;}.tools-head-stat .ths-fail{color:#f87171;}.tools-head-stat .ths-run{color:#93c5fd;}
.tools-modal-head .tools-modal-close{margin-left:auto;}
/* 类型 chip 条(点击=按类型筛选)*/
.tools-typebar{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;background:#f4f6f8;border-bottom:1px solid var(--line);flex-shrink:0;}
.tools-type-chip{border:1px solid var(--line);background:#fff;color:var(--t2);font-size:11.5px;border-radius:999px;padding:3px 9px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:.13s;}
.tools-type-chip:hover{border-color:#c5d4f5;color:var(--t1);}
.tools-type-chip b{font-family:var(--mono);font-size:10.5px;color:#fff;background:#a8b0bb;border-radius:999px;min-width:15px;text-align:center;padding:0 4px;font-weight:800;}
.tools-type-chip.on{background:#2563eb;border-color:#2563eb;color:#fff;}
.tools-type-chip.on b{background:rgba(255,255,255,.28);}
/* 筛选框 */
.tools-filter{display:flex;align-items:center;gap:6px;padding:9px 16px;border-bottom:1px solid var(--line);flex-shrink:0;background:#fff;}
.tools-filter input{flex:1;border:1px solid var(--line);border-radius:8px;padding:6px 10px;font-size:12.5px;color:var(--t1);outline:none;}
.tools-filter input:focus{border-color:#93b4f5;box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.tools-filter-x{border:none;background:#eef0f3;color:var(--t2);width:26px;height:26px;border-radius:7px;cursor:pointer;font-size:12px;flex-shrink:0;}
.tools-filter-x:hover{background:#e2e6ea;}
.tools-empty{padding:32px 18px;text-align:center;color:var(--t3);font-size:13px;}
@media(max-width:560px){
  .tools-modal{width:100vw;max-height:88vh;border-radius:14px 14px 0 0;}
  .tools-modal-body .tool-arg{font-size:10.5px;}
}

/* ── 工具调用:单独大区域 + 每工具「输入/输出」分段(重构) ── */
.tools-modal.lg{width:min(1100px,94vw);max-height:88vh;}
.tools-modal.lg .tools-modal-body{padding:0;}
.tool-io{display:flex;flex-direction:column;}
.tool-io-sec{border-top:1px solid var(--line);}
.tool-io-sec:first-child{border-top:none;}
.tool-io-label{font-size:11px;font-weight:800;letter-spacing:1px;padding:9px 16px 2px;}
.tool-io-label.in{color:#2563eb;}
.tool-io-label.out{color:#15a35a;}
.tool-args{padding:6px 16px 12px;display:flex;flex-direction:column;gap:8px;}
.tool-arg-row{display:flex;flex-direction:column;gap:3px;}
.tool-arg-k{font-size:11px;font-weight:700;color:var(--t2);font-family:var(--mono);}
.tool-arg-v{margin:0;font-family:var(--mono);font-size:12px;line-height:1.55;white-space:pre-wrap;
  word-break:break-word;background:#0f1117;color:#c9d1d9;border-radius:6px;padding:9px 12px;max-height:260px;overflow:auto;}
/* 大区域里输入代码/输出文字给更高上限,看全 Python 代码与结果 */
.tools-modal.lg .tool-code,.tools-modal.lg .tool-arg-v,.tools-modal.lg .tool-stdout,.tools-modal.lg .tool-error{max-height:360px;}
.tool-io .tool-result{border-top:none;}

/* ── 工具调用记录弹窗:左列表 + 右(含 tab)详情 ── */
.tools-modal.split{width:min(1080px,94vw);height:min(640px,86vh);max-height:86vh;}
.tools-split{flex:1;display:flex;min-height:0;}
.tools-list{width:288px;flex-shrink:0;border-right:1px solid var(--line);overflow-y:auto;background:#fafbfc;}
.tools-list-filter{position:sticky;top:0;z-index:1;display:flex;align-items:center;gap:6px;padding:9px 12px;background:#fafbfc;border-bottom:1px solid var(--line);}
.tools-list-filter input{flex:1;min-width:0;border:1px solid var(--line);border-radius:8px;padding:6px 9px;font-size:12px;color:var(--t1);outline:none;}
.tools-list-filter input:focus{border-color:#93b4f5;box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.tools-li{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:none;border-left:3px solid #c5cbd3;border-bottom:1px solid var(--line);padding:9px 12px;cursor:pointer;transition:background .12s;}
.tools-li:hover{background:#f1f4f8;}
.tools-li.on{background:#eef3ff;}
.tools-li.cat-code{border-left-color:#2563eb;}.tools-li.cat-read{border-left-color:#0d9488;}
.tools-li.cat-search{border-left-color:#8b5cf6;}.tools-li.cat-web{border-left-color:#e8852b;}
.tools-li.cat-write{border-left-color:#15a35a;}.tools-li.cat-skill{border-left-color:#d6453d;}
.tools-li.is-err{border-left-color:var(--up);}
.tools-li-step{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#eef2fe;color:#2563eb;font-size:10px;font-weight:800;font-family:var(--mono);flex-shrink:0;}
.tools-li.on .tools-li-step{background:#2563eb;color:#fff;}
.tools-li-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.tools-li-label{font-size:12.5px;font-weight:700;color:var(--t1);line-height:1.2;}
.tools-li-arg{font-family:var(--mono);font-size:10.5px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tools-li-st{font-size:12.5px;color:var(--down);flex-shrink:0;font-weight:700;}.tools-li-st.err{color:var(--up);}
.tools-detail{flex:1;min-width:0;display:flex;flex-direction:column;background:#fff;}
.tools-tabs{display:flex;align-items:center;gap:2px;padding:0 14px;border-bottom:1px solid var(--line);flex-shrink:0;background:#fff;}
.tools-tab{border:none;background:none;font-size:13px;font-weight:700;color:var(--t3);padding:11px 13px 9px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s,border-color .12s;}
.tools-tab:hover{color:var(--t1);}
.tools-tab.on{color:#2563eb;border-bottom-color:#2563eb;}
.tools-tab-cur{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--t3);}
.tools-detail-body{flex:1;overflow-y:auto;}
.tools-detail-body .tool-code{background:#0f1117;color:#c9d1d9;margin:0;border:none;border-radius:0;padding:14px 18px;max-height:none;}
.tools-detail-body .tool-args{padding:14px 16px;}
.tools-detail-body .tool-arg-v,.tools-detail-body .tool-stdout,.tools-detail-body .tool-error{max-height:none;}
.tools-detail-body .tool-result{border-top:none;background:#fff;padding:14px 16px;}
.tools-detail-body .tool-stdout{background:#fff;color:var(--t1);}
.tools-detail-body .tool-empty{padding:30px 18px;text-align:center;}
@media (max-width:760px){
  .tools-modal.split{height:88vh;}
  .tools-split{flex-direction:column;}
  .tools-list{width:auto;max-height:40%;border-right:none;border-bottom:1px solid var(--line);}
}

/* —— watchlist 任务末尾成果 gate(达成/未产出/路径误解) —— */
.gate-block{margin-top:8px;border-radius:10px;border:1px solid var(--line2);background:var(--card);padding:9px 12px;font-size:12.5px;}
.gate-block.ok{border-color:#cde8d6;background:#f3fbf5;}
.gate-block.err{border-color:#f6cdd2;background:#fdf4f5;}
.gate-block.warn{border-color:var(--line2);background:#fafbfc;}
.gate-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.gate-pill{font-size:11px;font-weight:800;padding:2px 9px;border-radius:7px;color:#fff;background:#a8aeb5;}
.gate-pill.ok{background:var(--down);}
.gate-pill.err{background:var(--up);}
.gate-expected{color:var(--t3);font-size:11px;}
.gate-expected code{font-family:var(--mono);background:var(--bg);padding:1px 5px;border-radius:4px;color:var(--t2);}
.gate-body{margin-top:6px;color:var(--t2);line-height:1.6;}
.gate-body .md-fileref{margin:2px 4px 2px 0;}

/* ── 海报 bundle 回显卡(banner 大小):左 16:9 框(banner.html iframe / 文字占位) + 右侧保存按钮 ── */
.md-postercard{display:flex;gap:14px;align-items:stretch;margin:10px 0;padding:10px;
  background:#fff;border:1px solid var(--line,#eceef1);border-radius:12px;cursor:pointer;
  box-shadow:0 1px 2px rgba(20,25,35,.04);max-width:640px;transition:box-shadow .15s;}
.md-postercard:hover{box-shadow:0 6px 18px rgba(20,25,35,.12);}
.md-postercard-frame{position:relative;flex:0 0 380px;max-width:62%;aspect-ratio:16/9;
  border-radius:8px;overflow:hidden;background:#f4f6f8;}
.md-postercard-iframe{border:0;pointer-events:none;transform-origin:0 0;display:block;}
.md-postercard-ph{display:flex;align-items:center;justify-content:center;height:100%;padding:12px;
  background:linear-gradient(135deg,#1a1d21,#2d3a55);color:#fff;font-size:15px;font-weight:700;text-align:center;}
.md-postercard-side{flex:1;display:flex;flex-direction:column;justify-content:center;gap:8px;min-width:0;}
.md-postercard-name{font-size:13px;font-weight:700;color:var(--t1,#1a1d21);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.md-postercard-hint{font-size:11px;color:var(--t3,#a8aeb5);}
.md-postercard-save{align-self:flex-start;font-size:12px;font-weight:600;padding:6px 14px;border-radius:8px;
  cursor:pointer;border:1px solid var(--blue,#3a6df0);background:var(--blue,#3a6df0);color:#fff;}
.md-postercard-save:hover{filter:brightness(1.08);}
.md-postercard-save:disabled{opacity:.65;cursor:default;filter:none;}
.md-postercard-save.saved{background:var(--down,#15a35a);border-color:var(--down,#15a35a);}
@media (max-width:640px){
  .md-postercard{flex-direction:column;}
  .md-postercard-frame{flex:none;max-width:100%;width:100%;}
}

/* ── 对话流内的任务进度时间线(todo_write → 纵向 stepper)──
   放此处:chat-body.css 被 /workspace 与 batx 主页共同加载(app.css 仅 /workspace)。
   TodoChecklist 组件在 chat-body.jsx,样式须与其同域,否则主页上组件渲染却无样式=纯文本。
   var 一律带兜底值,防主页未定义某变量。 */
.todo-card{margin:10px 0;border:1px solid var(--line2,#e4e7ea);border-radius:14px;background:var(--card,#fff);
  overflow:hidden;max-width:500px;box-shadow:0 1px 2px rgba(15,37,64,.04);}
.todo-card.is-live{border-color:rgba(58,109,240,.32);box-shadow:0 2px 14px rgba(58,109,240,.08);}
.todo-card-head{display:flex;align-items:center;justify-content:space-between;padding:10px 15px 9px;}
.todo-card-eyebrow{font-size:10.5px;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--t3,#a8aeb5);}
.todo-card.is-live .todo-card-eyebrow{color:var(--blue,#3a6df0);}
.todo-card-count{font-family:var(--mono,ui-monospace,Menlo,Consolas,monospace);font-size:12px;color:var(--t3,#a8aeb5);}
.todo-card-count b{font-size:16px;font-weight:700;color:var(--t1,#1a1d21);}
.todo-card-count i{font-style:normal;}
.todo-card-bar{height:3px;background:var(--line,#eceef1);}
.todo-card-bar-fill{height:3px;background:linear-gradient(90deg,var(--down,#15a35a),#4fb488);
  transition:width .45s cubic-bezier(.4,0,.2,1);border-radius:0 3px 3px 0;}
.todo-timeline{list-style:none;margin:0;padding:12px 16px 13px;}
.todo-step{position:relative;padding:0 0 15px 28px;}
.todo-step:last-child{padding-bottom:2px;}
.todo-step:not(:last-child)::before{content:"";position:absolute;left:8px;top:17px;bottom:1px;
  width:2px;background:var(--line2,#e4e7ea);border-radius:2px;}
.todo-step.completed:not(:last-child)::before{background:var(--down,#15a35a);}
.todo-node{position:absolute;left:2px;top:2px;width:15px;height:15px;border-radius:50%;
  border:2px solid var(--t3,#a8aeb5);background:var(--card,#fff);box-sizing:border-box;}
.todo-step.completed .todo-node{border-color:var(--down,#15a35a);background:var(--down,#15a35a);}
.todo-step.completed .todo-node::after{content:"✓";position:absolute;inset:0;display:flex;
  align-items:center;justify-content:center;color:#fff;font-size:9px;font-weight:900;line-height:1;}
.todo-step.in_progress .todo-node{border-color:var(--blue,#3a6df0);animation:todoPing 1.9s ease-out infinite;}
.todo-step.in_progress .todo-node::after{content:"";position:absolute;inset:2.5px;border-radius:50%;background:var(--blue,#3a6df0);}
@keyframes todoPing{0%{box-shadow:0 0 0 0 rgba(58,109,240,.38);}70%,100%{box-shadow:0 0 0 6px rgba(58,109,240,0);}}
.todo-step-title{font-size:13px;line-height:1.45;}
.todo-step.pending .todo-step-title{color:var(--t3,#a8aeb5);}
.todo-step.completed .todo-step-title{color:var(--t2,#878d94);}
.todo-step.in_progress .todo-step-title{color:var(--t1,#1a1d21);font-weight:650;}
.todo-step-detail{margin-top:3px;font-family:var(--mono,ui-monospace,Menlo,Consolas,monospace);font-size:11.5px;
  color:var(--blue,#3a6df0);display:inline-flex;align-items:center;gap:5px;}
.todo-step-detail::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--blue,#3a6df0);flex:0 0 auto;}
@media (prefers-reduced-motion:reduce){.todo-step.in_progress .todo-node{animation:none;}.todo-card-bar-fill{transition:none;}}
