:root{--bg:#0f1117;--bg2:#161b27;--bg3:#1e2535;--bg4:#252d40;--border:#2a3348;--border2:#3a4560;--text1:#f0f4ff;--text2:#a8b4cc;--text3:#6b7a99;--accent:#6366f1;--accent2:#818cf8;--accent-bg:rgba(99,102,241,.12);--green:#10b981;--green-bg:rgba(16,185,129,.12);--red:#ef4444;--red-bg:rgba(239,68,68,.12);--yellow:#f59e0b;--yellow-bg:rgba(245,158,11,.12);--blue:#3b82f6;--purple:#8b5cf6;--sidebar-w:220px}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--text1);font-family:'PingFang SC','Helvetica Neue',Arial,sans-serif;font-size:14px}
/* AUTH */
.auth-screen{display:none;position:fixed;inset:0;background:var(--bg);z-index:200;align-items:center;justify-content:center;flex-direction:column}
.auth-screen.show{display:flex}
.auth-box{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:36px;width:420px}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo-title{font-size:22px;font-weight:700;margin-bottom:4px}
.auth-logo-sub{font-size:13px;color:var(--text3)}
.auth-tabs{display:flex;background:var(--bg3);border-radius:10px;padding:4px;margin-bottom:24px}
.auth-tab{flex:1;text-align:center;padding:8px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--text3);transition:all .15s}
.auth-tab.active{background:var(--bg2);color:var(--text1);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.auth-fg{margin-bottom:14px}
.auth-label{font-size:12px;color:var(--text3);margin-bottom:5px;display:block}
.auth-input{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text1);padding:10px 13px;border-radius:9px;font-size:14px;outline:none;transition:border .15s}
.auth-input:focus{border-color:var(--accent)}
.auth-btn{width:100%;padding:11px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;cursor:pointer;margin-top:6px}
.auth-btn:hover{background:var(--accent2)}
.auth-err{color:var(--red);font-size:12px;margin-top:8px;text-align:center;min-height:18px}
/* APP */
.app{display:none;height:100vh;height:100dvh;overflow:hidden}   /* dvh：iOS Safari 地址栏不再吃掉视口高度 */
.app.show{display:flex}
.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.logo{padding:20px 18px 14px;border-bottom:1px solid var(--border)}
.logo-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}
.logo-tag{font-size:10px;background:var(--accent-bg);color:var(--accent2);padding:2px 7px;border-radius:10px;font-weight:600}
.logo-sub{font-size:11px;color:var(--text3);margin-top:3px}
.brand-selector{padding:12px 14px;border-bottom:1px solid var(--border)}
.brand-selector select{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text1);padding:7px 10px;border-radius:8px;font-size:13px;cursor:pointer;outline:none}
.btn-add-brand{width:100%;margin-top:6px;padding:6px;border:1px dashed var(--border2);background:transparent;color:var(--text3);border-radius:8px;cursor:pointer;font-size:12px;transition:all .2s}
.btn-add-brand:hover{border-color:var(--accent);color:var(--accent)}
.nav{padding:8px 0;flex:1}
.nav-section{padding:6px 14px 3px;font-size:10px;color:var(--text3);font-weight:600;letter-spacing:.8px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 14px;cursor:pointer;transition:all .15s;color:var(--text2);font-size:13px}
.nav-item:hover{background:var(--bg3);color:var(--text1)}
.nav-item.active{background:var(--accent-bg);color:var(--accent2);border-right:2px solid var(--accent)}
.nav-icon{font-size:15px;width:18px;text-align:center}
.sidebar-footer{padding:14px;padding-bottom:48px;border-top:1px solid var(--border)}
.user-info{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-bg);color:var(--accent2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.user-name{font-size:12px;font-weight:600;flex:1}
.user-plan{font-size:10px;background:var(--green-bg);color:var(--green);padding:1px 6px;border-radius:8px}
.btn-logout{font-size:11px;color:var(--text3);background:none;border:none;cursor:pointer;width:100%;text-align:left;padding:4px 0;margin-top:6px}
.btn-logout:hover{color:var(--red)}
.model-status-bar{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}
.mdot-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text3)}
.mdot{width:6px;height:6px;border-radius:50%;background:var(--border2)}
.mdot.ok{background:var(--green)}
/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:52px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0}
.topbar-title{font-size:15px;font-weight:600;flex:1}
.topbar-brand{font-size:12px;color:var(--text3);background:var(--bg3);padding:4px 10px;border-radius:6px}
.btn{padding:7px 14px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}
.ps-table{width:100%;border-collapse:collapse}
.ps-table th{text-align:left;padding:8px;color:var(--text2);border-bottom:1px solid var(--border);font-weight:500;font-size:12px}
.ps-table td{padding:8px;border-bottom:1px solid var(--border);font-size:13px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--border2);color:var(--text1)}
.btn-sm{padding:5px 10px;font-size:12px}
.content{flex:1;overflow-y:auto;padding:24px}
.section{display:none}
.section.active{display:block}
/* CARDS */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:20px}
.card-title{font-size:13px;font-weight:600;color:var(--text2);margin-bottom:16px;display:flex;align-items:center;gap:7px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
/* KPI */
.kpi{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px}
.kpi-label{font-size:11px;color:var(--text3);margin-bottom:6px}
.kpi-value{font-size:28px;font-weight:700;line-height:1}
.kpi-bar{height:4px;border-radius:2px;background:var(--bg4);margin-top:10px}
.kpi-bar-fill{height:100%;border-radius:2px;transition:width .6s}
/* MODEL CARD */
.model-card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:14px;position:relative;overflow:hidden}
.model-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.model-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px}
.model-name{font-size:13px;font-weight:600}
.model-score{font-size:22px;font-weight:700;margin-bottom:2px}
.model-metrics{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:8px}
.model-metric{font-size:10px;color:var(--text3)}
.model-metric span{color:var(--text2);font-weight:500}
.model-bar{height:3px;border-radius:2px;background:var(--bg4);margin-top:10px}
.model-bar-fill{height:100%;border-radius:2px}
/* SOV */
.sov-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.sov-item:last-child{border-bottom:none}
.sov-name{width:90px;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sov-bar-wrap{flex:1;height:8px;background:var(--bg4);border-radius:4px;overflow:hidden}
.sov-bar-fill{height:100%;border-radius:4px;transition:width .6s}
.sov-pct{width:45px;text-align:right;font-size:12px;font-weight:600}
/* SENTIMENT */
.sent-donut{display:flex;align-items:center;gap:24px}
.sent-legend{display:flex;flex-direction:column;gap:8px}
.sent-item{display:flex;align-items:center;gap:8px;font-size:12px}
.sent-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
/* TABLE */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;padding:8px 12px;font-size:11px;color:var(--text3);border-bottom:1px solid var(--border);font-weight:600}
.table td{padding:9px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:top}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:rgba(255,255,255,.02)}
.tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}
.tag-pos{background:var(--green-bg);color:var(--green)}
.tag-neg{background:var(--red-bg);color:var(--red)}
.tag-high{background:var(--red-bg);color:var(--red)}
.tag-medium{background:var(--yellow-bg);color:var(--yellow)}
.tag-low{background:var(--bg4);color:var(--text3)}
/* SUGGESTIONS */
.sug-card{border-radius:10px;padding:16px;border:1px solid;margin-bottom:10px}
.sug-card.high{background:rgba(239,68,68,.06);border-color:rgba(239,68,68,.2)}
.sug-card.medium{background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.2)}
.sug-card.low{background:var(--bg3);border-color:var(--border)}
.sug-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.sug-title{font-size:13px;font-weight:600;flex:1}
.ch-tag{font-size:11px;background:var(--bg4);color:var(--text2);padding:2px 8px;border-radius:10px}
.act-item{font-size:12px;color:var(--text2);display:flex;gap:6px;margin-bottom:4px}
.act-item::before{content:'→';color:var(--accent2);flex-shrink:0}
/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:100;display:none;align-items:center;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px;width:520px;max-height:80vh;overflow-y:auto}
.modal-title{font-size:16px;font-weight:700;margin-bottom:20px}
.fg{margin-bottom:14px}
.fl{font-size:12px;color:var(--text3);margin-bottom:5px;display:block;font-weight:500}
.fi{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text1);padding:9px 12px;border-radius:8px;font-size:13px;outline:none;transition:border .15s}
.fi:focus{border-color:var(--accent)}
textarea.fi{resize:vertical;min-height:70px;font-family:inherit}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cbg{display:flex;flex-wrap:wrap;gap:8px}
.cbi{display:flex;align-items:center;gap:5px;cursor:pointer;font-size:12px;color:var(--text2)}
.cbi input{accent-color:var(--accent)}
/* PROGRESS */
.prog-bar{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:3px;transition:width .3s}
.sbadge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:10px;font-size:11px;font-weight:600}
.s-pending{background:var(--bg4);color:var(--text3)}
.s-running{background:rgba(59,130,246,.12);color:var(--blue)}
.s-done{background:var(--green-bg);color:var(--green)}
.s-failed{background:var(--red-bg);color:var(--red)}
/* KEY CONFIG */
.key-row{display:flex;align-items:center;gap:10px;padding:11px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;margin-bottom:8px}
.key-name{width:88px;font-size:13px;font-weight:600}
.key-inp{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text1);padding:7px 10px;border-radius:7px;font-size:12px;font-family:monospace;outline:none}
.key-inp:focus{border-color:var(--accent)}
.key-stat{font-size:11px;padding:2px 8px;border-radius:8px;white-space:nowrap}
.kok{background:var(--green-bg);color:var(--green)}
.knone{background:var(--bg4);color:var(--text3)}
.key-test{font-size:11px;padding:4px 8px;border-radius:6px;border:1px solid var(--border);background:none;color:var(--text3);cursor:pointer;white-space:nowrap}
.key-test:hover{border-color:var(--accent);color:var(--accent)}
/* EMPTY */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px;text-align:center}
.empty-icon{font-size:40px}
.empty-title{font-size:15px;font-weight:600;color:var(--text2)}
.empty-sub{font-size:13px;color:var(--text3);max-width:320px;line-height:1.6}
.chart-wrap{position:relative;height:200px}
.yes{color:var(--green);font-weight:600}
.no{color:var(--text3)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
@media(max-width:1024px){.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}}

/* ── 移动端适配（汉堡抽屉 + 卡片化 + 触屏尺寸 · Ticket #10）─────
   作用域：仅"读取查看"场景的响应式；深度录入（建品牌/扫描/配 Key）仍引导去 PC。
   :has() 用于表格横滚，iOS Safari 15.4+ 支持——目标机型 iPhone14/iPad11 都满足。 */
@keyframes slide {
  from{transform:translateX(-100%)} to{transform:translateX(300%)}
}
@keyframes pulse {
  0%,100%{opacity:1} 50%{opacity:.5}
}
@keyframes spin {
  to{transform:rotate(360deg)}
}

/* 汉堡按钮：桌面隐藏，≤900px 显示在 topbar 最左；≥44px hit area */
.hamburger{display:none;background:transparent;border:1px solid var(--border);color:var(--text1);font-size:18px;line-height:1;width:40px;height:40px;border-radius:8px;cursor:pointer;flex-shrink:0;align-items:center;justify-content:center}
.hamburger:hover{border-color:var(--border2)}
/* 抽屉打开时的半透明遮罩（点击关闭）*/
.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:390}

/* ── 平板 + 手机（≤900px）：侧栏变离屏抽屉 ── */
@media(max-width:900px){
  .hamburger{display:flex}
  .sidebar{position:fixed;top:0;left:0;height:100%;height:100dvh;z-index:400;width:240px;transform:translateX(-100%);transition:transform .25s ease;box-shadow:2px 0 24px rgba(0,0,0,.45);overflow-y:auto}
  /* 抽屉里恢复完整标签（撤掉旧版 56px 图标栏）*/
  .sidebar .nav-label,.sidebar .brand-name,.sidebar .user-info{display:flex}
  .sidebar .nav-icon{font-size:15px}
  .sidebar .nav-item{justify-content:flex-start;padding:11px 16px}
  body.nav-open .sidebar{transform:translateX(0)}
  body.nav-open .sidebar-backdrop{display:block}
  /* topbar 收紧 */
  .topbar{padding:0 12px;gap:8px}
  .topbar-title{font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .topbar-brand{display:none}                 /* 品牌已在抽屉里的选择器 */
  /* 主区：网格全部单列 */
  .content{padding:16px}
  .g4,.g3,.g2{grid-template-columns:1fr!important}
  .card{padding:16px}
  .card-title{font-size:13px}
  /* 大表格：在所在卡片里横向滚动（覆盖卡片内联 overflow:hidden）*/
  .card:has(> .table),.card:has(> table){overflow-x:auto!important;-webkit-overflow-scrolling:touch}
  .table{min-width:560px}
  .table th,.table td{padding:9px 8px;font-size:12px}
  /* grid 伪表格行（收入归因 / 反事实实验等）：堆叠 */
  .rev-row,.rev-kpis,.attr-row{grid-template-columns:1fr!important}
  /* 触屏尺寸：按钮 / 表单 ≥40px hit area */
  .btn{min-height:40px}
  .btn-sm{min-height:36px;padding:7px 12px;font-size:12px}
  .fi,.auth-input,.brand-selector select,.brand-selector input{padding:11px 13px;font-size:14px;min-height:42px}
  .nav-item{min-height:44px}
  /* 弹窗 / 浮层全宽 */
  .modal{width:calc(100vw - 24px);max-width:520px;padding:20px;max-height:88vh}
  .overlay{padding:12px}
  .auth-box{width:calc(100vw - 24px);max-width:420px;padding:24px}
  /* 预警面板 + 微信客服卡：贴边变全宽（覆盖内联定位）*/
  #alertPanel{left:12px!important;right:12px!important;width:auto!important;max-width:380px;margin:0 auto}
  #wechatSalesCard{left:12px!important;right:12px!important;width:auto!important;max-width:240px;margin:0 auto;bottom:64px!important}
  /* 图表高度略降 */
  .chart-wrap{height:180px}
}

/* ── 手机（≤480px）：更紧凑 ── */
@media(max-width:480px){
  .sidebar{width:84vw;max-width:300px}       /* 留一条 backdrop 缝隙便于点击关闭 */
  .topbar{padding:0 10px;gap:6px}
  .topbar-title{font-size:13px}
  .content{padding:12px}
  .card{padding:14px;border-radius:10px}
  .kpi{padding:14px}
  /* 极窄屏隐藏裂变 banner（点击进邀请页的入口），保留汉堡 + 标题 + 铃铛 + 退出 */
  .topbar #trialBanner{display:none!important}
}
/* ── 进度条动画 ──────────────────────────────────────────── */
.prog-fill{transition:width .4s ease}
/* ── 状态徽章 ──────────────────────────────────────────── */
.sbadge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.s-pending{background:#1e3a5f;color:#7dd3fc}
.s-running{background:#1e3a5f;color:#38bdf8;animation:pulse 1.5s infinite}
.s-done{background:#14532d;color:#86efac}
.s-failed{background:#450a0a;color:#fca5a5}
.s-cancelled{background:#1c1917;color:#78716c}
/* ── API Key 卡片网格 ──────────────────────────────────── */
.key-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:4px}
.kcard{border:1px solid var(--border);border-radius:10px;padding:14px;background:var(--bg3);transition:border-color .2s}
.kcard:hover{border-color:var(--accent)}
.kcard-ok{border-color:rgba(16,185,129,.4);background:rgba(16,185,129,.04)}
.kcard-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
/* ── 预警铃铛 ──────────────────────────────────────────── */
.bell-wrap{position:relative;cursor:pointer;font-size:20px;padding:4px 8px;border-radius:8px;transition:background .2s}
.bell-wrap:hover{background:var(--bg3)}
.bell-badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;line-height:1}
/* ── toggle switch ─────────────────────────────────────── */
#alertEnabled:checked + span{background:#3b82f6}
#alertEnabled:checked + span::before{transform:translateX(20px)}
span[id=alertToggleTrack]::before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}
/* ── 预警卡片 ─────────────────────────────────────────── */
.alert-item{padding:10px 12px;border-radius:8px;margin-bottom:6px;border-left:3px solid #ef4444;background:rgba(239,68,68,.08);cursor:pointer;transition:background .2s}
.alert-item.read{border-left-color:var(--border);background:var(--bg3);opacity:.65}
.alert-item:hover{background:rgba(239,68,68,.14)}
.alert-item.read:hover{background:var(--bg3)}


/* ────────────────────────────────────────────────────
   F01 双生态视觉层（2026.04 重设计）
   在原有暗色基座之上叠加：
     - 中文引擎主色 indigo，西方引擎主色 emerald
     - 引擎覆盖地图、收入归因、情感战场三块新 UI
   ──────────────────────────────────────────────────── */

:root{
  --zh: #6366f1;           /* 中文引擎主色 */
  --zh-bg: rgba(99,102,241,.14);
  --en: #10b981;           /* 西方引擎主色 */
  --en-bg: rgba(16,185,129,.14);
  --mock: #f59e0b;         /* mock 数据警示 */
  --mock-bg: rgba(245,158,11,.16);
  --danger: #ef4444;
  --danger-bg: rgba(239,68,68,.14);
}

/* Topbar 引擎活跃统计 */
.engines-live{
  display:flex;gap:10px;font-size:11px;color:var(--text3);
  border:1px solid var(--border);border-radius:8px;padding:4px 10px;
}
.engines-live .live-n{font-weight:700;color:var(--text1)}
.engines-live .zh-dot{color:var(--zh)}
.engines-live .en-dot{color:var(--en)}

/* 引擎覆盖地图 */
.coverage-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(170px, 1fr));
  gap:12px;
}
.engine-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;
  padding:14px;position:relative;overflow:hidden;transition:transform .15s, border-color .15s;
}
.engine-card:hover{transform:translateY(-2px);border-color:var(--border2)}
.engine-card.zh{border-left:3px solid var(--zh)}
.engine-card.en{border-left:3px solid var(--en)}
.engine-card .ec-name{font-weight:700;font-size:14px;margin-bottom:2px}
.engine-card .ec-prov{font-size:11px;color:var(--text3);margin-bottom:10px}
.engine-card .ec-badge{
  position:absolute;top:12px;right:12px;font-size:10px;font-weight:700;
  padding:2px 6px;border-radius:6px;
}
.engine-card .ec-badge.real{background:var(--en-bg);color:var(--en)}
.engine-card .ec-badge.mock{background:var(--mock-bg);color:var(--mock)}
.engine-card .ec-badge.off{background:var(--bg4);color:var(--text3)}
.engine-card .ec-metrics{display:flex;justify-content:space-between;font-size:11px;color:var(--text2);margin-top:8px}
.engine-card .ec-metric{display:flex;flex-direction:column;gap:1px}
.engine-card .ec-metric-v{font-size:16px;font-weight:700;color:var(--text1)}

/* F02 收入归因 */
.rev-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.rev-kpi{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px}
.rev-kpi .rk-label{font-size:11px;color:var(--text3);margin-bottom:6px}
.rev-kpi .rk-value{font-size:24px;font-weight:700;color:var(--text1)}
.rev-kpi .rk-value.pos{color:var(--en)}
.rev-kpi .rk-value.warn{color:var(--mock)}
.rev-kpi .rk-value.danger{color:var(--danger)}
.rev-kpi .rk-sub{font-size:11px;color:var(--text3);margin-top:4px}
.attr-link-row{
  display:grid;grid-template-columns:1fr auto auto auto auto;gap:12px;
  padding:10px 12px;border:1px solid var(--border);border-radius:10px;
  background:var(--bg2);align-items:center;margin-bottom:6px;font-size:13px;
}
.attr-kind{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase}
.attr-kind.direct{background:var(--en-bg);color:var(--en)}
.attr-kind.assisted{background:var(--zh-bg);color:var(--zh)}
.attr-kind.competitor_shadow{background:var(--danger-bg);color:var(--danger)}

/* F06 情感战场 */
.alert-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:12px;align-items:center;
  padding:12px 14px;border:1px solid var(--border);border-radius:10px;
  background:var(--bg2);margin-bottom:8px;
}
.alert-kind-badge{font-size:10px;font-weight:700;padding:3px 9px;border-radius:10px;text-transform:uppercase}
.alert-kind-badge.negative_surge{background:var(--danger-bg);color:var(--danger)}
.alert-kind-badge.competitor_attack{background:var(--mock-bg);color:var(--mock)}
.alert-kind-badge.topic_shift{background:var(--zh-bg);color:var(--zh)}
.alert-sev{font-size:10px;padding:2px 8px;border-radius:6px;font-weight:600}
.alert-sev.high{background:var(--danger-bg);color:var(--danger)}
.alert-sev.mid{background:var(--mock-bg);color:var(--mock)}
.alert-sev.low{background:var(--bg4);color:var(--text3)}
.alert-status-new{color:var(--danger);font-weight:700}
.alert-status-acknowledged{color:var(--mock)}
.alert-status-counter_launched{color:var(--zh)}
.alert-status-resolved{color:var(--text3)}

.counter-card{
  border:1px solid var(--border);border-radius:12px;background:var(--bg2);
  padding:16px;margin-bottom:12px;
}
.counter-card .cc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.counter-card .cc-title{font-weight:700;font-size:14px}
.counter-card .cc-channel{font-size:10px;background:var(--bg3);color:var(--text2);padding:2px 7px;border-radius:6px;text-transform:uppercase}
.counter-card pre{
  background:var(--bg);border:1px solid var(--border);border-radius:8px;
  padding:12px;font-size:12px;color:var(--text2);white-space:pre-wrap;word-break:break-word;
  max-height:220px;overflow-y:auto;font-family:inherit;
}
.counter-card .cc-actions{display:flex;gap:8px;margin-top:10px}
.counter-card .cc-status{font-size:10px;font-weight:700;padding:2px 8px;border-radius:6px}
.counter-card .cc-status.draft{background:var(--bg4);color:var(--text2)}
.counter-card .cc-status.approved{background:var(--zh-bg);color:var(--zh)}
.counter-card .cc-status.published{background:var(--en-bg);color:var(--en)}

/* 2026 polish：卡片阴影 + hover */
.card,.kpi,.rev-kpi,.engine-card,.counter-card{
  box-shadow:0 1px 0 rgba(255,255,255,.02), 0 12px 24px -18px rgba(0,0,0,.65);
}
.btn-emerald{background:var(--en);color:#fff}
.btn-emerald:hover{background:#0ea271}
.mock-banner{
  background:var(--mock-bg);border:1px solid var(--mock);color:var(--mock);
  padding:10px 14px;border-radius:10px;font-size:12px;margin-bottom:14px;
  display:flex;align-items:center;gap:8px;
}
.tabs-strip{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px}
.tabs-strip .tab{
  padding:8px 14px;cursor:pointer;color:var(--text3);font-size:13px;
  border-bottom:2px solid transparent;
}
.tabs-strip .tab.active{color:var(--text1);border-bottom-color:var(--accent)}
