/* ============================================================
   base.css — 全站设计地基:reset + 单一设计令牌源(唯一权威)
   由 styles.css 中散落的 7 个 :root + 2 个 body.dark 令牌块
   「按最后一次定义生效」合并而来(CSS 自定义属性最后值全局生效、
   与使用位置无关,故合并后级联结果与原来完全一致)。
   以后改颜色/圆角/阴影/间距,只改这里一处。
   组件内的局部变量(如 #panel-tasks 的 --task-*)仍在各自组件中。
   加载顺序:必须最先加载(在 styles.css 之前)。
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* 底色 / 表面 */
  --bg:#f5f7fa; --bg2:#ffffff; --bg3:#f7f8fa; --bg4:#eef1f5;
  --surface:#fff; --surface-soft:#f8fafc; --glass:#ffffff;
  /* 描边 / 分割线 */
  --border:#e5e6eb; --border2:#d9d9d9; --line:#e5e6eb; --line-strong:#d3dae7;
  /* 文字 */
  --text1:#1f2329; --text2:#4e5969; --text3:#86909c;
  /* 主题色(Aliyun 蓝)+ 语义色 */
  --primary:#1677ff; --primary2:#4096ff; --primary-soft:#e8f3ff;
  --green:#00a870;  --green-soft:#e8f7f0;
  --amber:#ff7d00;  --amber-soft:#fff7e8;
  --blue:#1677ff;   --blue-soft:#e8f3ff;
  --purple:#7b61ff; --purple-soft:#f1efff;
  --teal:#14b8a6;   --teal-soft:#e8f8f6;
  --danger:#f53f3f;
  /* 圆角 / 阴影 / 字体 */
  --radius:2px; --sh:none; --sh-lift:none;
  --font:-apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", Arial, sans-serif;
  /* ui-* 命名空间(Aliyun pass 引入) */
  --ui-page:#ffffff; --ui-line:#e5e6eb; --ui-line-soft:#edf0f5;
  --ui-text:#1f2329; --ui-sub:#86909c; --ui-blue:#1677ff;
  --ui-radius:2px; --ui-control-h:32px; --ui-control-sm-h:26px;
  /* console-* 命名空间(数据看板 pass 引入) */
  --console-page-x:24px; --console-page-y:20px;
  --console-section-gap:14px; --console-title-size:22px;
}

body.dark {
  --bg:#080b10; --bg2:#10151d; --bg3:#151b25; --bg4:#1d2531;
  --border:#202838; --border2:#2b3546;
  --text1:#f2f5f9; --text2:#a7b0c1; --text3:#717d91;
  --primary:#ff564d; --primary-soft:rgba(255,86,77,.14);
  --green:#28c06f;  --green-soft:rgba(40,192,111,.16);
  --amber:#f5a623;  --amber-soft:rgba(245,166,35,.16);
  --blue:#4f8bff;   --blue-soft:rgba(79,139,255,.16);
  --purple:#9a78f0; --purple-soft:rgba(154,120,240,.16);
  --teal:#1db3a3;   --teal-soft:rgba(29,179,163,.16);
  --sh:0 2px 6px rgba(0,0,0,.35),0 10px 28px rgba(0,0,0,.4);
  --sh-lift:0 8px 22px rgba(0,0,0,.5),0 18px 44px rgba(0,0,0,.45);
  --glass:rgba(23,26,33,.72);
  background:#080b10;
}

/* ============================================================
   以下:原始核心组件样式(从 styles.css 顶部整段搬入,顺序不变)。
   sidebar / topbar / card / table.dt / 按钮 / tagselect / modal /
   form / banner / 手风琴 等共享基础件。这些是「原始定义」,后续
   styles.css 里的各 pass 仍在其后加载并覆盖,级联结果不变。
   ============================================================ */
body{font-family:var(--font);background:var(--bg);color:var(--text1);font-size:13px;transition:background .2s,color .2s}
.wrap{display:flex;min-height:100vh}
.sidebar{width:212px;min-width:212px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.logo{padding:18px 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);min-height:66px;box-sizing:border-box}
.logo-icon{width:33px;height:33px;background:var(--primary);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;color:#fff;box-shadow:0 4px 10px rgba(246,66,58,.3)}
.logo-text{font-size:13.5px;font-weight:800;line-height:1.2}
.logo-text small{display:block;font-size:9.5px;font-weight:500;color:var(--text3);letter-spacing:.04em;margin-top:1px}
.nav-section{padding:10px 8px 2px}
.nav-label{font-size:9.5px;font-weight:700;letter-spacing:.1em;color:var(--text3);padding:0 8px;margin-bottom:4px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:8px;cursor:pointer;color:var(--text2);font-size:12.5px;transition:all .15s;user-select:none}
.nav-item:hover{background:var(--bg3);color:var(--text1)}
.nav-item.active{background:var(--primary-soft);color:var(--primary);font-weight:700}
.nav-item i{font-size:16px;width:17px;text-align:center}
.nav-item .dot{width:6px;height:6px;border-radius:50%;margin-left:auto}
.dot-green{background:var(--green)}.dot-amber{background:var(--amber)}.dot-red{background:var(--primary)}.dot-gray{background:var(--text3)}
.main{flex:1;min-width:0;overflow-y:auto}
.topbar{padding:11px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-wrap:wrap;position:sticky;top:0;background:var(--glass);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);z-index:6;min-height:66px;box-sizing:border-box}
.kpi-pill{display:flex;align-items:center;gap:6px;padding:6px 13px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;font-size:11.5px;box-shadow:var(--sh)}
.kpi-label{color:var(--text2)}.kpi-val{font-weight:800}.kpi-delta{font-size:10.5px;font-weight:800}
.delta-neg{color:var(--primary)}.delta-pos{color:var(--green)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.sync-note{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:5px}
.sync-note b{color:var(--primary);cursor:pointer}
.theme-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px}
.theme-btn:hover{border-color:var(--primary);color:var(--primary)}

/* inline time filter */
.timebar-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.timebar-inline .tlabel{font-size:11px;color:var(--text3);margin-right:2px;display:flex;align-items:center;gap:4px}
.trange{padding:4px 11px;border-radius:15px;border:1px solid var(--border2);background:var(--bg2);font-size:11px;color:var(--text2);cursor:pointer}
.trange:hover{border-color:var(--primary);color:var(--primary)}
.trange.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}
.tauto{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);font-size:11px;color:var(--text2)}
.timebar-inline .tlabel-gap{margin-left:8px}
.tgran{padding:4px 8px;border-radius:8px;border:1px solid var(--border2);background:var(--bg2);font-size:11px;color:var(--text2);cursor:pointer}
.tgran-note{font-size:10.5px;color:var(--text3)}

.content{padding:22px 28px;max-width:none;width:100%}
.panel{display:none;animation:fade .25s}.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.page-title{font-size:18px;font-weight:800}
.page-sub{font-size:12px;color:var(--text3);margin-top:3px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px}
.grid32{display:grid;grid-template-columns:1fr 2fr;gap:14px;margin-bottom:14px} /* 6.23 文档 3：KPI 1/3 + 询盘趋势 2/3 */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--sh);transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:var(--sh-lift)}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;gap:8px}
.card-title{font-size:13px;font-weight:800}
.card-sub{font-size:11px;color:var(--text3)}
.card-link{font-size:11px;color:var(--primary);cursor:pointer;font-weight:600}
.chart-wrap{position:relative;width:100%}
.chart-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--text3);font-size:12px;text-align:center;padding:6px}
.chart-empty .ce-sub{font-size:10.5px;opacity:.7}

table.dt{width:100%;border-collapse:collapse;font-size:12px;table-layout:fixed}
table.dt th{color:var(--text3);font-weight:700;padding:8px 10px;border-bottom:1px solid var(--border);font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;text-align:left}
table.dt th.ctr{text-align:center}table.dt th.num{text-align:right}
table.dt tbody tr{vertical-align:top}
table.dt td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:top!important;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.45}
table.dt td.ctr,table.dt td.num{vertical-align:top!important}
table.dt tr:last-child td{border-bottom:none}
table.dt tbody tr:hover{background:var(--bg3)}
/* A组：列浅色分割线，更像表格 */
table.dt th,table.dt td{border-right:1px solid var(--border)}
table.dt th:last-child,table.dt td:last-child{border-right:none}
/* A组：关键词库表头与「加词」工具条固定，词多也不用上划 */
#panel-keywords .sheet-toolbar{position:sticky;top:0;z-index:3;background:var(--bg2);padding:6px 0}
#panel-keywords table.dt thead th{position:sticky;top:42px;z-index:2;background:var(--bg2)}
/* A组：单元格日期选择器 + 删除就地确认态 */
input.cell-date{font-family:var(--font);font-size:11.5px;padding:3px 6px;border:1px solid var(--border2);border-radius:6px;background:var(--bg2);color:var(--text1)}
.kw-del.confirming{color:#fff!important;background:var(--primary)!important;border-color:var(--primary)!important}
/* 通用「就地两次点确认」红态：删除/归档/恢复/停用 统一，不再用顶部弹框 */
.confirming{color:#fff!important;background:var(--primary)!important;border-color:var(--primary)!important;white-space:nowrap}
.fix-table th:nth-child(1){width:11%}
.fix-table th:nth-child(2){width:72px}
.fix-table th:nth-child(3){width:36%}
.fix-table th:nth-child(4){width:28%}
.fix-table th:nth-child(5){width:74px}
.fix-table th:nth-child(6){width:76px}
.fix-table th:nth-child(7){width:92px}
.fix-table td:nth-child(2),.fix-table td:nth-child(5),.fix-table td:nth-child(6),.fix-table td:nth-child(7){white-space:nowrap}
/* 表格录入：可编辑单元格像谷歌表格——自动换行、保留换行、完整显示，行高随内容增长 */
table.dt td.editable{white-space:pre-wrap;overflow:visible;overflow-wrap:anywhere;word-break:break-word;text-overflow:clip;text-align:left;direction:ltr}
.kw-name{white-space:pre-wrap!important;overflow:visible!important;text-overflow:clip!important}
#tb-kw-seo td,#tb-kw-sem td,#tb-kw-high td,#tb-kw-cust td,#tb-neg td,#tb-ad td{height:42px}
.num{text-align:right;font-variant-numeric:tabular-nums}th.num{text-align:right}
.ctr{text-align:center}th.ctr{text-align:center}
.dim{color:var(--text2)}

.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:11px;font-size:10.5px;font-weight:700;white-space:nowrap}
.b-red{background:var(--primary-soft);color:var(--primary)}
.b-green{background:var(--green-soft);color:var(--green)}
.b-amber{background:var(--amber-soft);color:var(--amber)}
.b-blue{background:var(--blue-soft);color:var(--blue)}
.b-purple{background:var(--purple-soft);color:var(--purple)}
.b-teal{background:var(--teal-soft);color:var(--teal)}
.b-gray{background:var(--bg4);color:var(--text2)}

.btn-primary{padding:7px 15px;background:var(--primary);border:none;border-radius:8px;color:#fff;font-size:12px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:6px;box-shadow:0 3px 8px rgba(246,66,58,.25)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{padding:6px 13px;background:var(--bg2);border:1px solid var(--border2);border-radius:8px;color:var(--text2);font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.btn-ai{padding:5px 12px;background:var(--primary-soft);border:1px solid rgba(246,66,58,.3);border-radius:13px;color:var(--primary);font-size:11px;cursor:pointer;font-weight:700;display:inline-flex;align-items:center;gap:5px}
.btn-ai:hover{filter:brightness(1.04)}
.btn-ai.analyzed,.btn-mini.analyzed{background:var(--bg4);border-color:var(--border);color:var(--text3);box-shadow:none}
.ai-analyzed-row{background:var(--bg3)!important;color:var(--text3)}
.btn-mini{font-size:10.5px;padding:3px 10px;border-radius:9px;border:1px solid var(--border2);background:var(--bg2);color:var(--blue);cursor:pointer;font-weight:600;white-space:nowrap}
.btn-mini:hover{border-color:var(--blue)}

.metric-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.metric-card{background:var(--bg2);border:1px solid var(--border);border-radius:11px;padding:14px 16px;box-shadow:var(--sh)}
.metric-num{font-size:24px;font-weight:800}
.metric-lbl{font-size:11px;color:var(--text2);margin-top:3px}
.metric-delta{font-size:11px;font-weight:700;margin-top:6px}

.ai-box{background:linear-gradient(135deg,rgba(246,66,58,.06),rgba(123,84,224,.05));border:1px solid rgba(246,66,58,.2);border-radius:12px;padding:15px 16px;margin-bottom:14px}
.ai-box.blue{background:linear-gradient(135deg,rgba(47,114,232,.06),rgba(246,66,58,.04));border-color:rgba(47,114,232,.2)}
.ai-box.purple{background:linear-gradient(135deg,rgba(123,84,224,.06),rgba(246,66,58,.04));border-color:rgba(123,84,224,.2)}
.ai-box.green{background:linear-gradient(135deg,rgba(21,168,90,.06),rgba(246,66,58,.04));border-color:rgba(21,168,90,.2)}
.ai-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ai-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.ai-title{font-size:12px;font-weight:800;color:var(--primary)}
.ai-item{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid rgba(128,128,128,.12);font-size:12px;color:var(--text2);line-height:1.55;align-items:flex-start}
.ai-item:last-child{border-bottom:none}
.ai-item>i{font-size:15px;margin-top:1px;flex-shrink:0;color:var(--primary)}
.ai-item .body{flex:1}.ai-item .body strong{color:var(--text1)}
.ai-actions{display:flex;gap:5px;flex-shrink:0;flex-wrap:wrap}
.aibtn{font-size:10px;border:1px solid var(--border2);background:var(--bg2);color:var(--text3);border-radius:9px;padding:2px 9px;cursor:pointer;white-space:nowrap}
.aibtn:hover{border-color:var(--primary);color:var(--primary)}
.aibtn.dep{color:var(--teal)}.aibtn.adopt{color:var(--green)}.aibtn.test{color:var(--amber)}
.aibtn.done{background:var(--bg4);color:var(--text3);border-color:transparent;cursor:default}

.progress-bar{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .8s}

.score-hero{display:flex;align-items:center;gap:22px}
.gauge{position:relative;width:140px;height:140px;flex-shrink:0}
.gauge svg{transform:rotate(-90deg)}
.gauge-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge-score{font-size:34px;font-weight:800;line-height:1}
.gauge-max{font-size:11px;color:var(--text3);margin-top:3px}
.grade-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 14px;border-radius:20px;font-size:13px;font-weight:800;margin-top:8px}
.person-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 15px;box-shadow:var(--sh);text-align:center}
.person-name{font-size:14px;font-weight:800;margin-bottom:10px}
.person-score{font-size:30px;font-weight:800;line-height:1}

.funnel-step{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.funnel-step .lbl{font-size:11.5px;color:var(--text2);margin-bottom:3px}
.funnel-bar{height:30px;border-radius:6px;display:flex;align-items:center;padding:0 11px;font-size:12px;font-weight:800;color:#fff}
.funnel-pct{font-size:11px;color:var(--text3);width:42px;text-align:right}

.subtabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}
.subtab{padding:9px 16px;font-size:13px;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;font-weight:600}
.subtab:hover{color:var(--text1)}
.subtab.active{color:var(--primary);border-bottom-color:var(--primary)}
.subpanel{display:none}.subpanel.active{display:block}
/* B-5/B-6 设置页左竖栏（参考侧栏 nav-item 选中观感）*/
.set-layout{display:flex;gap:18px;align-items:flex-start}
.set-nav{width:200px;min-width:200px;display:flex;flex-direction:column;gap:3px;border-right:1px solid var(--border);padding-right:10px}
.set-nav .subtab{border-bottom:none;border-radius:8px;padding:9px 11px;display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--text2)}
.set-nav .subtab i{font-size:16px;width:17px;text-align:center}
.set-nav .subtab:hover{background:var(--bg3);color:var(--text1)}
.set-nav .subtab.active{background:var(--primary-soft);color:var(--primary);border-bottom:none;font-weight:700}
.set-nav .set-logout{margin-top:6px;border-top:1px solid var(--border);padding-top:12px;padding-left:11px;padding-bottom:9px;color:var(--primary);cursor:pointer;display:flex;align-items:center;gap:9px;font-size:12.5px;font-weight:600;border-radius:8px}
.set-nav .set-logout:hover{background:var(--primary-soft)}
.set-body{flex:1;min-width:0}
.prof-field{margin-bottom:14px}
.prof-field label{display:block;font-size:11.5px;color:var(--text3);margin-bottom:5px}
.prof-field .val{font-size:13px;color:var(--text1);font-weight:600}
@media(max-width:760px){.set-layout{flex-direction:column}.set-nav{width:100%;min-width:0;flex-direction:row;flex-wrap:wrap;border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:8px}.set-nav .set-logout{margin-top:0;border-top:none;padding-top:9px}}
/* C-1 关键词分页器 */
.kw-pager{display:flex;align-items:center;gap:4px;flex-wrap:wrap;margin-top:10px}
.kw-pg{min-width:28px;height:28px;padding:0 8px;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);border-radius:7px;font-size:12px;cursor:pointer}
.kw-pg:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}
.kw-pg.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary);font-weight:700}
.kw-pg:disabled{opacity:.4;cursor:default}
.kw-pg-info{font-size:11.5px;color:var(--text3);margin-left:6px}
.kw-pg-size{margin-left:auto;font-size:11.5px;padding:3px 6px;border:1px solid var(--border2);background:var(--bg2);color:var(--text2);border-radius:6px;cursor:pointer}
/* C组：询盘按月折叠分隔行 */
.inq-msep td{background:var(--bg3);font-weight:700;font-size:12px;padding:8px 10px;cursor:pointer;user-select:none}
.inq-msep .hicon{transition:transform .15s;color:var(--text3)}
.inq-msep.collapsed .hicon{transform:rotate(-90deg)}
/* 6.23 文档 9：上调过等级的询盘行（被低估·重点处理） */
.inq-upgraded td:first-child{border-left:3px solid var(--primary)}
.inq-upgraded{background:rgba(246,66,58,.03)}
/* 6.23 文档 7：跟踪反馈单元格点开编辑（hover 提示可点）。
   注意：inline-block 才能让 text-overflow:ellipsis 正确生效（inline-flex 下会失败）。*/
.track-cell{display:inline-block;cursor:pointer;font-size:11.5px;padding:3px 8px;border-radius:6px;border:1px dashed var(--border2);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;line-height:1.4}
.track-cell i{margin-right:3px;vertical-align:-1px}
.track-cell:hover{border-color:var(--primary);color:var(--primary)}
.track-cell.track-empty{color:var(--text3);border-style:dashed}

/* closed-loop stepper */
.loopbar{display:flex;align-items:center;flex-wrap:wrap;gap:0;margin-bottom:16px}
.loopstep{display:inline-flex;align-items:center;gap:5px;padding:5px 13px;border-radius:20px;font-size:11.5px;color:var(--text3);background:var(--bg3);border:1px solid var(--border);cursor:pointer;white-space:nowrap;transition:all .15s}
.loopstep:hover{color:var(--text1);border-color:var(--border2)}
.loopstep.done{color:var(--green);border-color:var(--green-soft)}
.loopstep.active{background:var(--primary-soft);border-color:rgba(246,66,58,.32);color:var(--primary);font-weight:700}
.loopsep{width:16px;height:1.5px;background:var(--border2);margin:0 5px;flex-shrink:0}

.sheet-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.sheet-tip{font-size:11px;color:var(--text3);display:flex;align-items:center;gap:5px}
.editable{outline:none}
.editable:focus{background:var(--primary-soft);border-radius:4px;box-shadow:0 0 0 2px rgba(246,66,58,.2)}
table.dt td.editable:focus{background:transparent;border-radius:0;box-shadow:inset 0 -2px 0 rgba(246,66,58,.45)}
.editable.kpi-saving{background:var(--amber-soft);border-radius:4px;box-shadow:0 0 0 2px var(--amber-soft)}
.editable.kpi-ok{background:var(--green-soft);border-radius:4px;transition:background .3s}
.editable.kpi-error{background:var(--primary-soft);border-radius:4px;box-shadow:0 0 0 2px rgba(246,66,58,.4)}
.cat-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.cat-tab{padding:5px 12px;border-radius:7px;background:var(--bg3);border:1px solid var(--border);font-size:11.5px;color:var(--text2);cursor:pointer}
.cat-tab.active{background:var(--primary-soft);border-color:rgba(246,66,58,.3);color:var(--primary);font-weight:600}
.cat-tab.add{border-style:dashed;color:var(--text3)}

/* colored tag-select */
.tagselect{display:inline-flex;align-items:center;gap:3px;padding:2px 9px;border-radius:11px;font-size:10.5px;font-weight:700;cursor:pointer;user-select:none;white-space:nowrap}
.tagselect i{font-size:12px;opacity:.6}
#selMenu{position:fixed;background:var(--bg2);border:1px solid var(--border2);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.18);padding:6px;z-index:90;display:none;flex-direction:column;gap:4px}
#selMenu .opt{padding:3px 6px;border-radius:8px;cursor:pointer;display:flex}
#selMenu .opt:hover{background:var(--bg3)}

/* kanban v3 */
/* 任务看板：公司 / SEM / SEO 三栏 1:1:1 并排；窄屏(≤1100px)退回 公司整行 + SEM/SEO 两列 */
.tboard{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}
@media(max-width:1100px){
  .tboard{grid-template-columns:1fr 1fr}
  .tboard .pblock.co-block{grid-column:1 / -1} /* 公司块占整行 */
}
.cols2{display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap}
.cols2>.col{flex:1 1 0;min-width:280px}
.col-cap{font-size:12px;font-weight:700;margin:0 0 8px;display:flex;align-items:center;gap:6px}
.pstack{display:flex;flex-direction:column;gap:14px}
.pblock{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--sh)}
.pblock-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.pblock-head .pn{font-size:13px;font-weight:800}
.kcount{background:var(--bg4);border-radius:10px;padding:2px 9px;font-size:11px;color:var(--text2);margin-left:auto}
.sopnew{display:flex;flex-direction:column;gap:12px} /* 三栏并排后栏宽变窄：SOP 区与新增区改上下排 */
.colcap{font-size:10px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;display:flex;align-items:center;gap:5px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.freq-cap{font-size:9.5px;color:var(--text3);font-weight:700;margin:8px 0 5px;display:flex;align-items:center;gap:4px}
.cocol{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--sh);height:100%}
.tcard{background:var(--bg3);border:1px solid transparent;border-radius:9px;padding:9px 11px;margin-bottom:7px;cursor:pointer}
.tcard:hover{border-color:var(--border2)}
.tcard.must{border-left:3px solid var(--blue)}
.tcard.urgent{border-left:3px solid var(--primary);background:var(--primary-soft)}
.tcard.done{opacity:.55}.tcard.done .ttitle{text-decoration:line-through}
.ttitle{font-size:11.5px;font-weight:600;line-height:1.4;display:flex;align-items:flex-start;gap:7px}
.tcheck{width:15px;height:15px;border:1.5px solid var(--border2);border-radius:5px;flex-shrink:0;margin-top:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff}
.tcheck.on{background:var(--green);border-color:var(--green)}
.tmeta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:6px}
.tdue{font-size:9.5px;color:var(--text3);margin-left:auto;display:flex;align-items:center;gap:3px}
.add-task{width:100%;padding:6px;background:none;border:1px dashed var(--border2);border-radius:8px;color:var(--text3);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;margin-top:2px}
.add-task:hover{border-color:var(--primary);color:var(--primary)}

.banner{border-radius:10px;padding:11px 14px;margin-bottom:14px;display:flex;align-items:center;gap:11px}
.banner-red{background:var(--primary-soft);border:1px solid rgba(246,66,58,.25)}
.banner-t{font-size:12.5px;font-weight:700}
.banner-s{font-size:11px;color:var(--text3);margin-top:1px}

.review-grid{display:grid;grid-template-columns:130px 1fr;gap:0}
.review-grid>div{padding:11px 13px;border-bottom:1px solid var(--border);font-size:12px;line-height:1.6}
.review-grid .rk{color:var(--text2);font-weight:700;background:var(--bg3)}
.next3{background:var(--primary-soft)!important}
.rowflex{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}

.legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text2)}
.legend-dot{width:8px;height:8px;border-radius:50%}
.report-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text3);flex-wrap:wrap}
.cache-tag{background:var(--green-soft);color:var(--green);border-radius:10px;padding:2px 9px;font-weight:700}
.mkt-list{font-size:12px;line-height:1.9;color:var(--text2)}
.mkt-list b{color:var(--text1)}
.chip{display:inline-block;padding:3px 10px;border-radius:13px;font-size:11px;font-weight:600;margin:0 6px 6px 0;background:var(--bg3);border:1px solid var(--border)}

/* ---- v5 additions ---- */
.minitabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.minitab{padding:5px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text2);background:var(--bg3);border:1px solid var(--border);user-select:none;display:flex;align-items:center;gap:5px}
.minitab:hover{color:var(--text1)}
.minitab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.minitab.active .badge{background:rgba(255,255,255,.25);color:#fff}
.minipanel{display:none}.minipanel.active{display:block}
.rankpill{display:inline-flex;align-items:center;gap:4px;font-weight:800;font-size:12px}
.spark{display:inline-block;vertical-align:middle}
table.hierarchy td:first-child{font-variant-numeric:tabular-nums}
.h-camp{cursor:pointer;font-weight:600}.h-camp:hover{background:var(--bg3)}
.h-camp .hicon{font-size:13px;transition:transform .15s;display:inline-block}
.h-camp.collapsed .hicon{transform:rotate(-90deg)}
.h-grp,.h-kw{color:var(--text2)}.h-kw{font-size:11.5px;color:var(--text3)}
.modal-mask{position:fixed;inset:0;background:rgba(10,12,18,.5);backdrop-filter:blur(2px);z-index:200;display:none;align-items:flex-start;justify-content:center;padding:6vh 16px;overflow-y:auto}
.modal-mask.show{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:520px;max-width:100%;box-shadow:0 24px 60px rgba(0,0,0,.3);overflow:hidden}
.modal-head{display:flex;align-items:center;gap:8px;padding:16px 18px;border-bottom:1px solid var(--border);font-weight:800;font-size:14px}
.modal-head .x{margin-left:auto;cursor:pointer;color:var(--text3);font-size:18px}
.modal-body{padding:16px 18px;font-size:12.5px;line-height:1.6;color:var(--text2);max-height:60vh;overflow-y:auto}
.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.ai-chat-modal{width:min(920px,calc(100vw - 32px))}
.ai-chat-head{padding:18px 24px}
.ai-chat-body{padding:0;max-height:72vh;display:grid;grid-template-rows:minmax(260px,1fr) auto;overflow:hidden}
.ai-chat-scroll{padding:22px 26px;overflow-y:auto;min-height:300px;line-height:1.75}
.ai-chat-item{display:flex;gap:10px;margin-bottom:14px}
.ai-chat-item .bubble{max-width:82%;border:1px solid var(--border);border-radius:12px;padding:11px 13px;background:var(--bg3);font-size:12.5px;color:var(--text2)}
.ai-chat-item.assistant .bubble{background:var(--bg2);border-left:3px solid var(--primary)}
.ai-chat-item.user{justify-content:flex-end}
.ai-chat-item.user .bubble{background:var(--primary-soft);border-color:rgba(246,66,58,.18);color:var(--text1)}
.ai-chat-compose{border-top:1px solid var(--border);padding:14px 18px;background:var(--bg2)}
.ai-chat-compose textarea{width:100%;box-sizing:border-box;min-height:72px;max-height:160px;resize:vertical;padding:10px 12px}
.ai-chat-tools{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}
.ai-file-chip{font-size:11px;color:var(--text3);padding:4px 8px;border:1px solid var(--border);border-radius:999px;background:var(--bg3)}
.fld{margin-bottom:12px}.fld label{display:block;font-size:11px;color:var(--text3);font-weight:600;margin-bottom:4px}
.fld input,.fld select,.fld textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:8px 10px;color:var(--text1);font-size:12.5px;font-family:var(--font)}
.fld textarea{resize:vertical;min-height:46px}
.fld-row{display:flex;gap:10px}.fld-row>.fld{flex:1}
.ai-loading{display:flex;align-items:center;gap:8px;color:var(--text3);font-size:12px;padding:4px 0}
.ai-loading .spin{width:13px;height:13px;border:2px solid var(--border2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ai-render p{margin-bottom:7px}.ai-render strong{color:var(--text1)}
/* 复盘周报 手风琴 + 并排 */
.acc-week{border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;background:var(--bg2);box-shadow:var(--sh)}
.acc-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;cursor:pointer;font-weight:800;font-size:13px}
.acc-bar:hover{background:var(--bg3)}
.acc-bar .hicon{transition:transform .15s}
.acc-week.collapsed .acc-bar .hicon{transform:rotate(-90deg)}
.acc-body{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:14px 16px;border-top:1px solid var(--border)}
.acc-week.collapsed .acc-body{display:none}
.rv-col{border:1px solid var(--border);border-radius:10px;padding:12px;background:var(--bg2)}
.rv-col.seo{border-left:3px solid var(--blue)}.rv-col.sem{border-left:3px solid var(--purple)}
.rv-sec{margin-bottom:12px}
.rv-sec h5{font-size:11px;color:var(--text3);font-weight:800;margin:0 0 6px;text-transform:uppercase;letter-spacing:.04em}
.rv-item{display:flex;align-items:flex-start;gap:6px;padding:5px 0;border-bottom:1px solid var(--border)}
.rv-item .txt{flex:1;font-size:12px;outline:none;line-height:1.5}
.rv-item .txt:focus{background:var(--primary-soft);border-radius:4px}
.rv-del{color:var(--text3);cursor:pointer;font-size:13px}.rv-del:hover{color:var(--primary)}
.rv-add{font-size:11px;color:var(--primary);cursor:pointer;font-weight:600;margin-top:5px;display:inline-flex;align-items:center;gap:3px}
@media(max-width:900px){.acc-body{grid-template-columns:1fr}}
.api-warn{font-size:11px;color:var(--amber);background:var(--amber-soft);padding:8px 10px;border-radius:8px;margin-top:8px}

