:root{
  --bg:#ffffff; --card:#ffffff; --text:#1b2430; --muted:#697584; --border:#e6e9ef; --accent:#0a7cff;
  --ok:#0b8a4c; --warn:#b76800; --err:#d23;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);color:var(--text);font:14px/1.5 -apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial}
.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--card);backdrop-filter:saturate(180%) blur(6px)}
.brand{font-weight:700}
.nav{display:flex;gap:8px;flex-wrap:wrap}
.nav-link{color:var(--text);text-decoration:none;padding:6px 10px;border-radius:6px}
.nav-link:hover{background:#f3f6fb}
@media (prefers-color-scheme: dark){ .nav-link:hover{background:#111827} }
.spacer{flex:1}
.meta{color:var(--muted);font-size:12px}
.container{width:min(1280px,100% - 24px);max-width:100%;margin-inline:auto;padding:clamp(12px,2.2vw,20px)}
main.container{flex:1 0 auto}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.grid-wide{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:16px}
.card{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:16px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.card h2{margin:0 0 8px;font-size:16px}
.card h3{margin:8px 0 6px;font-size:14px;color:var(--muted)}
.muted{color:var(--muted)}
.row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.kpi{display:flex;flex-direction:column;gap:4px}
.kpi .label{color:var(--muted);font-size:12px}
.kpi .value{font-weight:700;font-size:18px}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);font-size:12px}
.badge.ok{background:#e5f8ed;color:var(--ok);border-color:#cdf2dd}
.badge.warn{background:#fff4e5;color:#a15e00;border-color:#ffe1bd}
.badge.err{background:#fde8e8;color:#b42318;border-color:#fac5c5}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:10px}
table{border-collapse:collapse;width:100%;min-width:760px}
th,td{border-bottom:1px solid var(--border);padding:8px 10px;text-align:left;white-space:nowrap}
th{font-size:12px;color:var(--muted);font-weight:600;position:sticky;top:0;background:var(--card)}
.footer{border-top:1px solid var(--border);color:var(--muted);font-size:12px;padding:12px 16px;margin-top:16px}
.actions{display:flex;flex-direction:column;gap:6px}
.action-item{display:flex;justify-content:space-between;gap:8px;border:1px dashed var(--border);border-radius:10px;padding:8px}
.action-item .meta{font-size:12px}
.decision-structured-card{display:flex;flex-direction:column;gap:10px}
.decision-conclusion{font-size:16px;font-weight:700;color:var(--text)}
.decision-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.summary-title{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:4px}
.summary-list{margin:0;padding-left:18px;font-size:13px;color:var(--text)}
.summary-list li{margin-bottom:4px}
.summary-empty{font-size:12px;color:var(--muted)}
.confidence-row{display:flex;align-items:center;gap:8px}
.confidence-bar{flex:1;height:8px;border-radius:999px;background:var(--border);overflow:hidden}
.confidence-bar-fill{height:100%;background:var(--accent);border-radius:999px;width:0}
.signal-pills{display:flex;gap:8px;flex-wrap:wrap}
.signal-pill{padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px}
.signal-pill.positive{background:#e5f8ed;color:var(--ok);border-color:#cdf2dd}
.signal-pill.negative{background:#fde8e8;color:#b42318;border-color:#fac5c5}
.signal-pill.neutral{background:#f4f4f5;color:#444;border-color:#e2e3e7}
.views-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.decision-view-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:var(--card);box-shadow:0 1px 2px rgba(0,0,0,.02);display:flex;flex-direction:column;gap:8px}
.view-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.view-side{font-weight:700;font-size:13px;text-transform:uppercase}
.view-conclusion{font-size:13px;color:var(--text)}
.view-section .summary-list{padding-left:16px}
.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#eef5ff;color:#2b6dff;border:1px solid #d2e4ff;font-size:12px}
.pill.secondary{background:#eff5f6;color:#2b677e;border-color:#d7eaef}
.pill.ghost{background:transparent;border-color:var(--border);color:var(--muted)}
.pill.id-pill{background:#0f172a;color:#f1f5f9;border-color:#0f172a;font-family:'JetBrains Mono','SFMono-Regular',monospace;font-size:11px;letter-spacing:0.4px;cursor:pointer;user-select:none;transition:background .2s,color .2s,border-color .2s}
.pill.id-pill.copied{background:#047857;border-color:#047857;color:#ecfdf5}
.pill.id-pill.copy-error{background:#991b1b;border-color:#991b1b;color:#fee2e2}
/* TPSL 专用徽章 */
.pill.tp{background:#e6f2ff;color:#1e40af;border-color:#c7ddff}
.pill.sl{background:#fde8e8;color:#b42318;border-color:#fac5c5}
/* pill 语义色 */
.pill.ok{background:#e5f8ed;color:var(--ok);border-color:#cdf2dd}
.pill.warn{background:#fff4e5;color:#a15e00;border-color:#ffe1bd}
.pill.err{background:#fde8e8;color:#b42318;border-color:#fac5c5}
.id-chain-block{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}
.chain-detail{font-size:12px;color:var(--muted)}
.chain-detail summary{cursor:pointer;color:var(--accent);font-weight:600}
.chain-detail pre{background:#0f172a0d;border-radius:8px;padding:8px;max-height:260px;overflow:auto;font-size:12px}
.btn{border:1px solid var(--border);border-radius:10px;background:var(--card);color:var(--text);font-weight:600;padding:6px 14px;cursor:pointer;transition:background .2s,border-color .2s,box-shadow .2s}
.btn:hover{border-color:var(--accent);box-shadow:0 2px 6px rgba(0,0,0,.08)}
.btn:disabled{opacity:0.5;cursor:not-allowed}
.btn.secondary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.ghost{background:transparent;color:var(--muted)}
.btn.ghost:hover{color:var(--text)}
details pre{background:#0f172a0d;border-radius:8px;padding:12px;overflow:auto}
.split{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width: 1024px){ .split{grid-template-columns:1.25fr .75fr} }
.note{font-size:12px;color:var(--muted)}
.note.err{color:var(--err)}
.note.warn{color:var(--warn)}
.split > div{display:flex;flex-direction:column;gap:16px}
/* 桌面：右侧列拉伸 + 内部吸顶 */
@media (min-width:1024px){
  .sticky-col{position:relative; align-self:stretch; display:flex}
  .sticky-box{position:sticky; top:12px; min-height:100%; display:flex; flex-direction:column}
  .sticky-box .card:last-of-type{flex:1 1 auto; display:flex; flex-direction:column}
}
.kpi-row{display:flex;flex-direction:column;gap:8px}
.kpis-inline{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(140px,1fr);gap:12px;align-items:stretch}
@media (max-width: 720px){ .kpis-inline{grid-auto-flow:row;grid-auto-rows:auto} }
.kpi-compact{border:1px solid var(--border);border-radius:12px;background:var(--card);padding:10px}
.kpi-compact .label{font-size:12px;color:var(--muted)}
.kpi-compact .value{font-size:18px;font-weight:800}

/* 数字显示：等宽数字 + 右对齐，结合 JS 动态设宽 */
.mono{font-variant-numeric: tabular-nums lining-nums; font-feature-settings: 'tnum' 1,'lnum' 1}
.num{text-align:right; white-space:nowrap}

/* 首页表格：小屏转卡片 */
@media (max-width: 720px){
  .table-wrap{overflow:visible;}
  .pos-compact,
  .table-compact,
  .home-sub-table{min-width:100%;border-collapse:separate;border-spacing:0;}
  .pos-compact thead,
  .table-compact thead,
  .home-sub-table thead{display:none;}
  .pos-compact tr,
  .table-compact tr,
  .home-sub-table tr{display:block;border:1px solid var(--border);border-radius:12px;padding:8px 10px;margin-bottom:12px;background:var(--card);box-shadow:0 1px 2px rgba(0,0,0,.05);}
  .home-sub-table tbody tr:hover{background:var(--card);}
  .pos-compact td,
  .table-compact td,
  .home-sub-table td{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border:none;white-space:normal;font-size:13px;align-items:flex-start;}
  .pos-compact td::before,
  .table-compact td::before,
  .home-sub-table td::before{content:attr(data-label);font-weight:600;color:var(--muted);flex:0 0 38%;text-align:left;}
  .home-sub-table td.sub-reason{max-width:100%;}
  .home-sub-table td.sub-reason .fold-text{white-space:normal;}
}

/* 移动端辅助显示：默认隐藏，窄屏显示 */
.show-mobile{ display:none; }
@media (max-width: 680px){ .show-mobile{ display:block !important; } }
/* 桌面专属显示：在窄屏隐藏 */
.hide-mobile{ display:inline; }
@media (max-width: 680px){ .hide-mobile{ display:none !important; } }

/* 细节微调：更舒展的桌面留白与悬停反馈 */
@media (hover: hover){
  .card:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}
}

/* 日志页专用样式 */
.log-panel{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}
.log-panel-header{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start}
.log-panel-status{display:flex;flex-direction:column;gap:4px;align-items:flex-end;font-size:12px;color:var(--muted)}
@media (max-width:640px){ .log-panel-status{align-items:flex-start;width:100%;} }
.log-filter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.log-field{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:4px}
.log-field input,.log-field select{width:100%;border:1px solid var(--border);border-radius:10px;padding:6px 10px;font-size:14px;background:var(--bg);color:var(--text);transition:border-color .2s,box-shadow .2s}
.log-field input:focus,.log-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(10,124,255,.12)}
.log-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.log-autorefresh{display:flex;align-items:center;gap:6px;font-weight:600}
.log-toolbar-controls{display:flex;gap:8px;flex-wrap:wrap}
.log-chips{display:flex;flex-wrap:wrap;gap:8px}
.log-chips:empty{display:none}
.log-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;background:var(--card)}
.log-chip button{border:none;background:transparent;color:var(--muted);cursor:pointer;padding:0;font-size:14px;line-height:1}
.log-chip button:hover{color:var(--err)}
.log-table-card{display:flex;flex-direction:column;gap:8px}
.log-table-head{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;align-items:flex-start}
.log-table-meta strong{color:var(--text)}
.log-table{min-width:900px}
.log-table th,.log-table td{vertical-align:top}
.log-table td.message-cell{white-space:normal}
.log-id{font-variant-numeric:tabular-nums}
.log-message{white-space:pre-line;margin-bottom:4px;font-size:13px}
.log-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.log-meta-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;border:1px solid #d7e3ff;background:#eef2ff;color:#1d4ed8;font-size:12px}
.log-ago{font-size:12px;color:var(--muted)}
.log-source-main{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;font-weight:600}
.log-source-sub{font-size:12px;color:var(--muted)}
.log-level{display:inline-flex;align-items:center;gap:6px;padding:2px 12px;border-radius:999px;font-size:12px;font-weight:700}
.log-level-icon{display:inline-flex;width:16px;height:16px;align-items:center;justify-content:center;font-size:12px;line-height:1}
.log-level-text{display:inline-block}
.log-level-info{background:#e8f2ff;color:#1d4ed8}
.log-level-debug{background:#f0f2f7;color:#475467}
.log-level-warn{background:#fff4e5;color:#b45309}
.log-level-error{background:#fde8e8;color:#b42318}
.log-level-critical{background:#fde1e1;color:#8a1320}
.log-row-warning{box-shadow:inset 3px 0 0 rgba(250,204,21,.9)}
.log-row-error,.log-row-critical{box-shadow:inset 3px 0 0 rgba(239,68,68,.9)}
.log-row-debug{box-shadow:inset 3px 0 0 rgba(71,84,103,.5)}
.log-empty{padding:20px;text-align:center;color:var(--muted)}
.log-extra summary{cursor:pointer;color:var(--accent);font-size:12px}
@media (max-width:720px){
  .log-table{min-width:100%}
  .log-panel-status{order:3}
  .log-panel-header{flex-direction:column}
}
