/* ============================================================
   AAUGE AI · App Shell + 设计系统基座 (aauge-shell.css) v1
   —— 从 UI Lab v3 提炼的全站可复用基座。
   现已被 5 页统一引用：index / app / connections / workflow / review（不替换 aauge.css）。
   方向：AI 运营中控台 —— 深色 · 克制 · 高级 · 有秩序。
   只用内联 SVG 图标，不引入任何外部 CDN / 字体 / 图标库。
   颜色全部走 :root 语义 token（--bg/--panel/--line/--ink/--sub/--blue/--ok/--warn/--bad …），
   便于后续「主题系统砖」加 深色/浅色/跟随系统（本基座未做主题切换、未引 JS 主题）。
   注：为兼容现有 JS 动态生成的类名，保留 .ag-* 别名（ag-chip/ag-card/ag-btn/ag-empty/ag-step/ag-bar/ag-table 等）。
   ============================================================ */
:root{
  --bg:#0a0e1a; --sidebar:#0b101e; --panel:#0e1424; --raise:#121a2e;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.12); --line-act:rgba(58,123,255,.42);
  --ink:#eaf0ff; --sub:#9aa6c4; --faint:#6b7794;
  --blue:#3a7bff; --violet:#7c5cff; --teal:#16d6c8; --grad:linear-gradient(135deg,#3a7bff,#7c5cff);
  --ok:#3ad29f; --run:#3a7bff; --warn:#ffd166; --bad:#ff6b6b; --mute:#7783a8;
  --r:11px; --r-lg:16px; --r-pill:999px; --shadow:0 14px 36px rgba(0,0,0,.42);
  --mobile-tab-h:64px;   /* 移动端固定底部 Tab 的近似高度，用于内容区底部安全留白 */
  color-scheme:dark;   /* 默认深色（主模式）；主题切换见 theme.js */
}

/* ===== 主题：浅色（由 theme.js 在 <html> 上设 data-theme-resolved="light"；重定义语义 token，非 filter 反转） ===== */
[data-theme-resolved="light"]{
  --bg:#eef1f7; --sidebar:#ffffff; --panel:#ffffff; --raise:#eef1f8;
  --line:rgba(16,24,48,.10); --line-2:rgba(16,24,48,.16); --line-act:rgba(58,123,255,.50);
  --ink:#0f1830; --sub:#46506a; --faint:#6b7488; --mute:#8a93ab;
  --shadow:0 10px 30px rgba(16,24,48,.10);
  color-scheme:light;
  /* 品牌色 --blue/--violet/--teal/--grad 与状态色 --ok/--warn/--bad 保持不变 */
}
/* 浅色下：把深色专用的“白色低透填充 / 浅蓝文字”集中重定义为浅底可读色（基座统一，页面无需改） */
[data-theme-resolved="light"] ::-webkit-scrollbar-thumb{background:rgba(16,24,48,.16)}
[data-theme-resolved="light"] .topbar,[data-theme-resolved="light"] .m-header{background:rgba(255,255,255,.82)}
[data-theme-resolved="light"] .m-tabbar{background:rgba(255,255,255,.92)}
[data-theme-resolved="light"] .nav.on{background:rgba(58,123,255,.12);color:#1f4fb0}
[data-theme-resolved="light"] .nav.on .ico{color:#2a5fc8}
[data-theme-resolved="light"] .nav.on .ct{background:rgba(58,123,255,.20);color:#1f4fb0}
[data-theme-resolved="light"] .m-tabbar .mt.on{color:#1f4fb0}
[data-theme-resolved="light"] .m-tabbar .mt.on svg{color:#2a5fc8}
[data-theme-resolved="light"] .badge.soft{color:#1f4fb0;background:rgba(58,123,255,.10);border-color:rgba(58,123,255,.28)}
[data-theme-resolved="light"] .dlink,[data-theme-resolved="light"] .bc-side .lk,[data-theme-resolved="light"] .tcost b,[data-theme-resolved="light"] .more{color:#1f4fb0}
[data-theme-resolved="light"] .dtag{color:#1f4fb0;background:rgba(58,123,255,.10);border-color:rgba(58,123,255,.26)}
[data-theme-resolved="light"] .run .rstep.act{color:#1f4fb0}
[data-theme-resolved="light"] .flow .fnum,[data-theme-resolved="light"] .flow-m-body .num{color:#1f4fb0;background:rgba(58,123,255,.12)}
[data-theme-resolved="light"] .ag-row{background:rgba(16,24,48,.025)}
[data-theme-resolved="light"] .ag-table th{background:rgba(16,24,48,.04);color:var(--sub)}
[data-theme-resolved="light"] .dbody{background:rgba(16,24,48,.025)}
[data-theme-resolved="light"] .addbox{background:rgba(16,24,48,.02)}
[data-theme-resolved="light"] .soonbtn{background:rgba(16,24,48,.04)}
[data-theme-resolved="light"] .estim{color:#8a5a00;background:rgba(255,209,102,.16);border-color:rgba(255,209,102,.5)}
[data-theme-resolved="light"] .statusnote,[data-theme-resolved="light"] .wf-status{background:rgba(255,209,102,.14);border-color:rgba(255,209,102,.5)}
[data-theme-resolved="light"] .statusnote .stxt b,[data-theme-resolved="light"] .wf-status .st b{color:#8a5a00}
[data-theme-resolved="light"] .m-status{color:#8a5a00}
[data-theme-resolved="light"] .lock{color:#1f4fb0}
/* 页面 <style> 内高频浅蓝/amber 文字（eyebrow/achip/testnote）在浅色统一重定义 */
[data-theme-resolved="light"] .eyebrow,[data-theme-resolved="light"] .achip{color:#1f4fb0;background:rgba(58,123,255,.10);border-color:rgba(58,123,255,.26)}
[data-theme-resolved="light"] .testnote{color:#8a5a00;background:rgba(255,209,102,.16);border-color:rgba(255,209,102,.5)}

/* ===== 主题切换控件 ===== */
/* 后台四页：复用 .tlink（顶栏 / 移动头）；index：右上角浮动 .theme-fab */
.theme-fab{position:fixed;top:14px;right:16px;z-index:50;height:34px;padding:0 13px;border-radius:var(--r-pill);
  border:1px solid var(--line-2);background:var(--panel);color:var(--sub);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;box-shadow:var(--shadow)}
.theme-fab:hover{border-color:var(--line-act);color:var(--ink)}

*{box-sizing:border-box}
html,body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);
  font-family:"PingFang SC","Microsoft YaHei",-apple-system,"Segoe UI",system-ui,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:8px}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px}

/* ===== App Shell ===== */
.shell{display:grid;grid-template-columns:244px minmax(0,1fr);min-height:100vh}
.maincol,.stat,.titem>div,.nav,.ptitle,.uinfo{min-width:0}
.side{background:var(--sidebar);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px}
.logo{width:34px;height:34px;border-radius:10px;background:var(--grad);color:#fff;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(58,123,255,.45);flex:none}
.bname{font-weight:800;font-size:16px;letter-spacing:.3px}
.bname .ai{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.sgroup{padding:8px 12px;margin-top:6px}
.slabel{font-size:10.5px;font-weight:700;letter-spacing:.8px;color:var(--faint);padding:8px 10px 6px;text-transform:uppercase}
.nav{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r);color:var(--sub);font-weight:600;font-size:13.5px;width:100%;text-align:left;transition:background .15s,color .15s}
.nav:hover{background:var(--raise);color:var(--ink)}
.nav.on{background:rgba(58,123,255,.14);color:#cfe0ff}
.nav.on .ico{color:#8fb3ff}
.nav .ico{width:18px;height:18px;flex:none;color:var(--faint)}
.nav .ct{margin-left:auto;font-size:11px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:rgba(255,255,255,.10);color:var(--sub);display:inline-flex;align-items:center;justify-content:center}
.nav.on .ct{background:rgba(58,123,255,.30);color:#dbe7ff}
.sfoot{margin-top:auto;border-top:1px solid var(--line);padding:12px;display:flex;align-items:center;gap:10px}
.avatar{width:32px;height:32px;border-radius:9px;background:linear-gradient(135deg,#2a3550,#3a7bff);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none;color:#fff}
.uinfo{min-width:0}.uname{font-size:12.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.uplan{font-size:11px;color:var(--faint)}

.maincol{display:flex;flex-direction:column;min-width:0}
.topbar{position:sticky;top:0;z-index:20;height:58px;display:flex;align-items:center;gap:14px;padding:0 22px;background:rgba(10,14,26,.82);border-bottom:1px solid var(--line);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.ptitle{font-size:15px;font-weight:700}
.crumb{color:var(--faint);font-size:12.5px}
.spacer{flex:1}
.who{font-size:13px;color:var(--sub);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tlink{background:transparent;border:1px solid var(--line);color:var(--sub);border-radius:9px;padding:7px 13px;font-size:13px;font-weight:600;transition:.15s}
.tlink:hover{border-color:var(--line-act);color:var(--ink)}

/* 移动头 + 底部 Tab（≤960 启用） */
.m-header,.m-tabbar{display:none}
.m-header{align-items:center;gap:10px;padding:10px 16px;position:sticky;top:0;z-index:30;background:rgba(10,14,26,.92);border-bottom:1px solid var(--line);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.m-header .logo{width:30px;height:30px;font-size:16px}
.m-header .m-brand{font-weight:800;font-size:15px}
.m-header .m-brand .ai{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.m-back{color:var(--sub);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:5px}
.m-tabbar{position:fixed;left:0;right:0;bottom:0;z-index:40;align-items:stretch;background:rgba(11,16,30,.96);border-top:1px solid var(--line);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:7px 4px calc(7px + env(safe-area-inset-bottom,0px))}
.m-tabbar .mt{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 2px;color:var(--faint);font-size:10.5px;font-weight:600}
.m-tabbar .mt svg{width:21px;height:21px;color:var(--faint)}
.m-tabbar .mt.on{color:#cfe0ff}.m-tabbar .mt.on svg{color:#8fb3ff}

/* ===== 内容容器 ===== */
.content{padding:28px 26px 64px;max-width:1160px;width:100%;margin:0 auto}
.sec-h{display:flex;align-items:baseline;gap:10px;margin:26px 0 14px}
.sec-h h2{font-size:16px;font-weight:800;margin:0}.sec-h .meta{font-size:12px;color:var(--faint)}

/* ===== 组件 ===== */
.card,.ag-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;color:var(--ink);text-align:left}
.btn,.ag-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:44px;padding:0 20px;border-radius:var(--r);background:var(--grad);color:#fff;font-weight:700;font-size:13.5px;box-shadow:0 8px 22px rgba(58,123,255,.34);transition:transform .14s,box-shadow .2s}
.btn:hover,.ag-btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(58,123,255,.5)}
.btn:disabled,.ag-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn.ghost,.ag-btn.ghost{background:transparent;border:1px solid var(--line-2);color:var(--sub);box-shadow:none}
.btn.ghost:hover,.ag-btn.ghost:hover{border-color:var(--line-act);color:var(--ink);transform:none}
.btn.sm{height:38px;padding:0 15px;font-size:13px}
.textarea,.ag-textarea{width:100%;min-height:120px;border:1px solid var(--line-2);border-radius:var(--r);background:var(--raise);color:var(--ink);padding:11px 13px;font:inherit;outline:none;resize:vertical;transition:border .15s,box-shadow .15s}
.input,.ag-input{height:44px;width:100%;border:1px solid var(--line-2);border-radius:var(--r);background:var(--raise);color:var(--ink);padding:0 13px;font:inherit;outline:none;transition:border .15s,box-shadow .15s}
.textarea:focus,.ag-textarea:focus,.input:focus,.ag-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,123,255,.2)}
.textarea::placeholder,.ag-textarea::placeholder,.ag-input::placeholder{color:var(--faint)}
.lbl{font-size:12.5px;color:var(--sub);margin-bottom:6px;display:block}

.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;border-radius:7px;padding:3px 9px;white-space:nowrap}
.badge.ok{color:#06231a;background:var(--ok)}
.badge.run{color:#fff;background:var(--run)}
.badge.warn{color:#3a2c00;background:var(--warn)}
.badge.bad{color:#fff;background:var(--bad)}
.badge.mute{color:var(--sub);background:rgba(255,255,255,.08)}
.badge.soft{color:#a9c4ff;background:rgba(58,123,255,.12);border:1px solid rgba(58,123,255,.24)}

/* chips（连接选择；兼容现有 JS：.ag-chip + 内 .chk/.nm2/.meta） */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.ag-chip{display:inline-flex;align-items:center;gap:10px;border:1.5px solid var(--line-2);border-radius:12px;padding:10px 13px;cursor:pointer;color:var(--ink);background:transparent;text-align:left;transition:border-color .15s,background .15s}
.ag-chip:hover{border-color:var(--line-act)}
.ag-chip.on{border-color:var(--blue);background:rgba(58,123,255,.14)}
.ag-chip .chk{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;flex:none}
.ag-chip.on .chk{background:var(--blue);border-color:var(--blue)}
.ag-chip .nm2{font-weight:600;font-size:13px}
.ag-chip .meta{font-size:11.5px;color:var(--faint)}

/* 空状态 */
.ag-empty{border:1px dashed var(--line-2);border-radius:var(--r-lg);padding:28px 22px;text-align:center;color:var(--faint);font-size:13px;line-height:1.7}
.ag-empty a{color:var(--blue);font-weight:700}
.empty-ic{width:40px;height:40px;margin:0 auto 12px;color:var(--mute)}
.empty-t{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:6px}
.empty-d{font-size:12.5px;color:var(--faint);line-height:1.6;margin-bottom:16px;max-width:340px;margin-left:auto;margin-right:auto}
.empty-note{font-size:11.5px;color:var(--faint);margin-top:14px;display:inline-flex;align-items:center;gap:6px}

/* 步骤指示（兼容现有 JS：.ag-step/.dot/.lab + .ag-bar） */
.steps{display:flex;align-items:center;margin:6px 0 22px}
.ag-step{display:flex;align-items:center;gap:8px;color:var(--faint)}
.ag-step .dot{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.08);color:var(--faint);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;transition:background .25s}
.ag-step.on{color:var(--ink)}.ag-step.on .dot{background:var(--grad);color:#fff}
.ag-step.done .dot{background:var(--teal);color:#06231a}
.ag-step .lab{font-size:13px;font-weight:600}
.ag-bar{flex:1;height:2px;background:rgba(255,255,255,.1);margin:0 4px}.ag-bar.on{background:var(--blue)}

/* 效果档位卡（兼容现有 JS：.tier + .rec/.tname/.ttone/.tcost/.tmodels） */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.tier{position:relative;cursor:pointer;padding:16px}
.tier.on{border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,123,255,.22)}
.tier .rec{position:absolute;top:-9px;left:14px;font-size:10px;font-weight:700;color:#fff;background:var(--grad);border-radius:6px;padding:2px 8px}
.tname{font-size:15px;font-weight:800}
.ttone{font-size:12px;color:var(--sub);margin:5px 0 10px;min-height:32px}
.tcost{font-size:13px}.tcost b{color:#8fb3ff}
.tmodels{font-size:11px;color:var(--faint);margin-top:8px;border-top:1px dashed var(--line);padding-top:7px}
.estim{font-size:11.5px;color:#d8c089;background:rgba(255,209,102,.07);border:1px solid rgba(255,209,102,.22);border-radius:10px;padding:9px 12px;margin-top:14px}
.more{margin-top:12px;font-size:12.5px;color:#8fb3ff;cursor:pointer;background:none;border:none;font:inherit;padding:0}
.ag-table-wrap{overflow-x:auto;margin-top:10px}
.ag-table{width:100%;border-collapse:collapse;font-size:12.5px}
.ag-table th,.ag-table td{border:1px solid var(--line);padding:8px 10px;text-align:left;white-space:nowrap}
.ag-table th{background:rgba(255,255,255,.03);color:var(--sub);font-weight:600}
table.cmp{display:none}table.cmp.show{display:table}

/* 运行状态条（前端可信反馈；非真实模型） */
.run{margin-top:18px;padding:18px;border:1px solid var(--line-act);border-radius:var(--r-lg);background:linear-gradient(180deg,rgba(58,123,255,.06),transparent)}
.run .rh{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px;margin-bottom:14px}
.run .spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(58,123,255,.3);border-top-color:var(--blue);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.prog{height:8px;border-radius:6px;background:rgba(255,255,255,.07);overflow:hidden}
.prog .bar{height:100%;width:0;background:var(--grad);border-radius:6px;transition:width .5s ease}
.rsteps{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:14px;font-size:12px;color:var(--faint)}
.rstep{display:flex;align-items:center;gap:7px}
.rstep .rc{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:10px}
.rstep.act{color:#cfe0ff}.rstep.act .rc{border-color:var(--blue);color:var(--blue)}
.rstep.fin{color:var(--ok)}.rstep.fin .rc{background:var(--ok);border-color:var(--ok);color:#06231a}
.run-note{font-size:11.5px;color:var(--faint);margin-top:12px;line-height:1.55}

/* 摘要面板（桌面右栏） */
.summary .srow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px}
.summary .srow:last-of-type{border-bottom:none}
.summary .sk{color:var(--sub)}.summary .sv{font-weight:700}
.summary .snote{font-size:11.5px;color:var(--faint);line-height:1.6;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}

/* 专员页头 */
.wf-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:8px}
.wf-ic{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex:none;border:1px solid var(--line);background:linear-gradient(135deg,rgba(58,123,255,.26),rgba(124,92,255,.24))}
.wf-ic svg{width:25px;height:25px}
.wf-name{font-size:20px;font-weight:800;display:flex;align-items:center;flex-wrap:wrap;gap:9px}
.wf-desc{color:var(--sub);font-size:13px;line-height:1.6;margin-top:4px}
.wf-status{display:flex;gap:9px;align-items:flex-start;margin:14px 0 4px;padding:10px 12px;border:1px solid rgba(255,209,102,.22);background:rgba(255,209,102,.06);border-radius:10px}
.wf-status .sd{width:7px;height:7px;border-radius:50%;background:var(--warn);margin-top:5px;flex:none;box-shadow:0 0 6px rgba(255,209,102,.5)}
.wf-status .st{font-size:11.5px;color:var(--sub);line-height:1.6}.wf-status .st b{color:#e9d8a6}

/* 工作区两栏（桌面） */
.wf-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:22px;align-items:start}
.wf-side{position:sticky;top:78px}
.nav-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:18px}
.toast{position:fixed;left:50%;bottom:30px;transform:translateX(-50%) translateY(16px);background:var(--raise);border:1px solid var(--line-act);color:var(--ink);padding:12px 18px;border-radius:12px;font-size:13.5px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s;z-index:60}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

@media (prefers-reduced-motion: no-preference){
  .content{animation:fadein .3s ease both}@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
}

/* ===== 响应式：移动任务面板 ===== */
@media(max-width:1040px){ .wf-grid{grid-template-columns:1fr} .wf-side{position:static} }
@media(max-width:960px){
  .shell{grid-template-columns:minmax(0,1fr)}
  .side{display:none}
  .topbar{display:none}
  .m-header{display:flex}
  .m-tabbar{display:flex}
  /* 底部留足：Tab 高 + 88px 缓冲 + 安全区。足够让最后一行（含错误态/空态卡片末行）滚到 Tab 上方完整露出 */
  .content{padding:16px 16px calc(var(--mobile-tab-h, 64px) + 88px + env(safe-area-inset-bottom,0px))}
  .wf-name{font-size:18px}
}
@media(max-width:600px){
  .content{padding:14px 14px calc(var(--mobile-tab-h, 64px) + 88px + env(safe-area-inset-bottom,0px))}
  .tiers{grid-template-columns:1fr}
  .wf-info-grid{grid-template-columns:1fr}
  .nav-row .btn,.nav-row .ag-btn{flex:1}
  .ag-step .lab{display:none}
  .step-now{display:block}
}

/* 移动端当前步骤说明（桌面隐藏，≤600 显示） */
.step-now{display:none;font-size:13.5px;font-weight:700;color:#cfe0ff;margin:-6px 0 16px}
/* 空状态动作按钮组 */
.empty-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:2px}
/* 页面收口信息卡 */
.wf-info{margin-top:18px}
.wf-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.wfi{display:flex;gap:11px;align-items:flex-start}
.wfi svg{width:18px;height:18px;color:var(--teal);flex:none;margin-top:1px}
.wfi-t{font-size:13px;font-weight:700;margin-bottom:3px}
.wfi-d{font-size:11.5px;color:var(--faint);line-height:1.55}

/* ===== 连接中心组件（语义化 token；为未来主题切换预留，不写死颜色） ===== */
.lock{display:inline-flex;align-items:flex-start;gap:8px;background:rgba(58,123,255,.10);border:1px solid rgba(58,123,255,.26);color:#a9c4ff;border-radius:10px;padding:9px 12px;font-size:12.5px;line-height:1.55;margin:10px 0 22px}
.pcard{margin-bottom:14px}
.ch{display:flex;align-items:center;gap:12px}
.ci{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex:none;border:1px solid var(--line);background:linear-gradient(135deg,rgba(58,123,255,.24),rgba(124,92,255,.20))}
.cname{font-size:15.5px;font-weight:700;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cdesc{font-size:12.5px;color:var(--sub)}
.cuse{font-size:11.5px;color:var(--faint);margin-top:2px}
.addb{margin-left:auto;flex:none;background:rgba(58,123,255,.14);color:#a9c4ff;border:1px solid rgba(58,123,255,.3);border-radius:9px;padding:8px 14px;font:inherit;font-weight:700;font-size:13px;cursor:pointer;transition:background .15s}
.addb:hover{background:rgba(58,123,255,.22)}
.accts{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.ag-row{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:var(--r);padding:11px 13px;background:rgba(255,255,255,.02)}
.ag-row>div{flex:1;min-width:0}
.ag-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);flex:none;box-shadow:0 0 8px rgba(58,210,159,.5)}
.ag-name{font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ag-meta{font-size:12px;color:var(--faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acct .rm{margin-left:auto;flex:none;background:none;border:1px solid var(--line-2);border-radius:8px;padding:6px 11px;color:var(--sub);font:inherit;font-size:12.5px;cursor:pointer;transition:.15s}
.acct .rm:hover{border-color:var(--bad);color:var(--bad)}
.addbox{margin-top:14px;border:1px solid var(--line);border-radius:12px;padding:15px;background:rgba(255,255,255,.02)}
.f{display:flex;flex-direction:column;margin-bottom:11px}
.f label{font-size:12px;color:var(--sub);margin-bottom:5px}
.enc-hint{font-size:11px;color:var(--faint);margin:2px 0 4px;display:inline-flex;align-items:center;gap:6px}
.mini{display:flex;gap:8px;margin-top:6px}
.mini .ag-btn,.mini .btn{height:40px;padding:0 18px;font-size:13px}
.msg{font-size:12.5px;margin-top:8px;min-height:16px}.msg.err{color:var(--bad)}.msg.ok{color:var(--ok)}
@media(max-width:600px){ .ch{flex-wrap:wrap} .addb{margin-left:0;margin-top:8px} }

/* ===== 状态概览卡 / Tabs / 审核台 / 看板（语义 token，主题可复用） ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:16px 0 4px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px}
.stat .k{font-size:12px;color:var(--faint);display:flex;align-items:center;gap:7px}
.stat .k svg{width:15px;height:15px;color:var(--mute)}
.stat .v{font-size:24px;font-weight:800;margin-top:6px;letter-spacing:.3px}
.stat .v small{font-size:11.5px;color:var(--faint);font-weight:600;margin-left:5px}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}}

.tabs{display:inline-flex;gap:5px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:5px;margin:18px 0 18px;max-width:100%}
.tab{padding:9px 16px;border-radius:8px;font-weight:600;font-size:13.5px;color:var(--sub);transition:.15s}
.tab.on{background:var(--grad);color:#fff}
.countpill{display:inline-flex;min-width:18px;height:18px;padding:0 5px;align-items:center;justify-content:center;border-radius:9px;background:rgba(255,255,255,.16);font-size:11px;font-weight:700;margin-left:7px}
.tab.on .countpill{background:rgba(255,255,255,.28)}
.note{font-size:11.5px;color:var(--faint);line-height:1.55}
.loading{color:var(--faint);font-size:13px;text-align:center;padding:24px}

/* 审核卡 */
.rev{margin-bottom:14px;padding:18px}
.rev .rtop{display:flex;align-items:center;gap:10px;margin-bottom:11px}
.wfic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;background:linear-gradient(135deg,rgba(58,123,255,.28),rgba(124,92,255,.24));border:1px solid var(--line);flex:none}
.rtitle{font-weight:700;font-size:14.5px;line-height:1.3}
.rmeta{font-size:11.5px;color:var(--faint)}
.dbody{font-size:13px;color:var(--sub);line-height:1.65;white-space:pre-wrap;word-break:break-word;background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:10px;padding:11px 13px;max-height:220px;overflow:auto;margin:4px 0 11px}
.dtags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:11px}
.dtag{font-size:11.5px;color:#a9c4ff;background:rgba(58,123,255,.12);border:1px solid rgba(58,123,255,.26);border-radius:7px;padding:3px 8px}
.dlink{font-size:12px;color:#8fb3ff;text-decoration:none;word-break:break-all}.dlink:hover{text-decoration:underline}
.racts{display:flex;gap:10px;margin-top:4px}
.racts .btn,.racts .ag-btn{flex:1}
.btn-rej{background:transparent;border:1px solid var(--line-2);color:var(--sub);box-shadow:none}
.btn-rej:hover{border-color:var(--bad);color:var(--bad);transform:none}
.rmsg{font-size:12px;margin-top:8px;min-height:14px}.rmsg.err{color:var(--bad)}.rmsg.ok{color:var(--ok)}

/* 结果看板（卡片化，移动友好；不用宽表格） */
.board-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.board-list{display:flex;flex-direction:column;gap:10px}
.board-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg)}
.bc-ic{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;background:linear-gradient(135deg,rgba(58,123,255,.24),rgba(124,92,255,.2));border:1px solid var(--line);flex:none}
.bc-main{flex:1;min-width:0}
.bc-title{font-weight:600;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bc-meta{font-size:11.5px;color:var(--faint);margin-top:3px}
.bc-side{display:flex;align-items:center;gap:12px;flex:none}
.bc-side .lk{color:#8fb3ff;font-size:12.5px;text-decoration:none}.bc-side .lk:hover{text-decoration:underline}
@media(max-width:600px){
  .board-card{flex-direction:column;align-items:flex-start;gap:9px}
  .bc-side{width:100%;justify-content:space-between}
}

/* 横向溢出探针（仅 ?debug） */
#dbg{display:none;position:fixed;top:8px;left:8px;z-index:99;background:#000a;border:1px solid var(--line-act);color:#7CFFB2;font:11px/1.4 ui-monospace,Menlo,Consolas,monospace;padding:6px 9px;border-radius:7px}
