/* ══════════════════════════════════════
   components.css — 组件样式
   智能反馈工单系统 V7.0
══════════════════════════════════════ */

/* ── KPI Cards — Tech Glow ── */
.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:20px}
.kpi{background:var(--card);border-radius:var(--radius);padding:20px 22px;border:1px solid var(--border);position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--kpi-color,var(--primary)),transparent);opacity:.8;transition:opacity .3s}
.kpi:hover{border-color:rgba(124,127,255,.2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.3),0 0 0 1px rgba(124,127,255,.1)}
.kpi:hover::before{opacity:1}
.kpi::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,var(--kpi-color,var(--primary)),transparent 70%);opacity:0;transition:opacity .4s}
.kpi:hover::after{opacity:.04}
.kpi-val{font-size:32px;font-weight:800;letter-spacing:-.5px;line-height:1;font-variant-numeric:tabular-nums}
.kpi-val-glow{text-shadow:0 0 20px currentColor;transition:text-shadow .4s}
.kpi-label{font-size:12px;color:var(--text3);margin-top:8px;font-weight:500}
.kpi-sub{font-size:11px;color:var(--text3);margin-top:4px}
.kpi-icon{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:32px;opacity:.06}
.kpi-skeleton .kpi-val{opacity:.3}

/* ── Panel ── */
.panel{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;transition:all .3s;overflow:hidden;animation:panelIn .3s cubic-bezier(.16,1,.3,1) both}
.panel:hover{border-color:rgba(255,255,255,.08)}
.panel:nth-child(2){animation-delay:.05s}
.panel:nth-child(3){animation-delay:.1s}
.panel-hd{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.panel-hd h2{font-size:14px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}
.panel-bd{padding:20px 22px}
.panel-sub{font-size:12px;color:var(--text3);margin-left:8px;font-weight:400}

/* ── Charts ── */
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.chart-box{height:260px;transition:opacity .4s}

/* ── Tags — Glow Badges ── */
.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;gap:4px;transition:all var(--tr);letter-spacing:.2px}
.t-pending{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.15)}
.t-processing{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.15)}
.t-resolved{background:rgba(59,130,246,.12);color:#60a5fa;border:1px solid rgba(59,130,246,.15)}
.t-closed{background:rgba(100,116,139,.12);color:var(--text3);border:1px solid rgba(100,116,139,.1)}
.t-\9AD8{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.15)}
.t-\4E2D{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.15)}
.t-\4F4E{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.15)}

/* ── Sync Tags ── */
.sync-yes{background:rgba(16,185,129,.12);color:#34d399;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;border:1px solid rgba(16,185,129,.15)}
.sync-yes:hover{background:rgba(16,185,129,.2);box-shadow:0 0 12px rgba(16,185,129,.2)}
.sync-no{background:rgba(245,158,11,.1);color:var(--orange);font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}
.sync-link{color:var(--accent);text-decoration:none;font-size:12px;font-weight:600;transition:all .2s}
.sync-link:hover{color:#67e8f9;text-shadow:0 0 8px rgba(45,217,244,.3)}

/* ── V6.0 Storage Monitor ── */
.storage-panel .panel-hd{display:flex;align-items:center;gap:10px}
.storage-badge{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:700}
.storage-normal{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.15)}
.storage-warning{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}
.storage-danger{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.2)}
.storage-grid{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}
.storage-main{flex:1;min-width:260px}
.storage-bar-label{display:flex;justify-content:space-between;font-size:12px;color:var(--text2);margin-bottom:8px}
.storage-bar{height:10px;border-radius:5px;background:rgba(255,255,255,.06);overflow:hidden}
.storage-bar-fill{height:100%;border-radius:5px;transition:width .8s cubic-bezier(.16,1,.3,1)}
.bar-normal{background:linear-gradient(90deg,#10b981,#34d399)}
.bar-warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.bar-danger{background:linear-gradient(90deg,#ef4444,#f87171);animation:barPulse 2s ease-in-out infinite}
.storage-bar-hint{font-size:12px;color:var(--text3);margin-top:8px}
.storage-bar-hint b{color:var(--text)}
.storage-uploads{display:flex;gap:20px}
.storage-stat-item{text-align:center;min-width:80px}
.storage-stat-val{font-size:22px;font-weight:800;color:var(--accent);line-height:1.2;font-variant-numeric:tabular-nums}
.storage-stat-lbl{font-size:11px;color:var(--text3);margin-top:4px}

/* ── V7.0 Month Compare ── */
.month-compare{display:flex;align-items:center;gap:0;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px}
.mc-item{display:flex;align-items:center;gap:14px;flex:1;justify-content:center}
.mc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.mc-val{font-size:28px;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums;line-height:1.1}
.mc-label{font-size:12px;color:var(--text3);margin-top:2px}
.mc-divider{width:1px;height:48px;background:var(--border);flex-shrink:0;margin:0 8px}

/* ── V7.0 Efficiency Ranking ── */
.eff-list{display:flex;flex-direction:column;gap:10px}
.eff-item{display:flex;align-items:center;gap:10px;font-size:13px}
.eff-rank{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;background:rgba(100,116,139,.12);color:var(--text3);flex-shrink:0}
.eff-rank.gold{background:rgba(245,158,11,.15);color:#fbbf24}
.eff-rank.silver{background:rgba(148,163,184,.15);color:#94a3b8}
.eff-rank.bronze{background:rgba(180,83,9,.15);color:#d97706}
.eff-name{width:80px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}
.eff-bar-wrap{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;min-width:60px}
.eff-bar{height:100%;border-radius:4px;background:linear-gradient(90deg,#7c7fff,#818cf8);transition:width .8s cubic-bezier(.16,1,.3,1)}
.eff-val{font-weight:700;color:var(--accent);width:50px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}
.eff-detail{font-size:11px;color:var(--text3);white-space:nowrap;flex-shrink:0}

/* ── Filter Bar ── */
.fbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px}
.fbar-select{
  height:34px;padding:0 32px 0 12px;border:1px solid var(--border-l);border-radius:var(--radius-s);
  font-size:13px;color:var(--text);background:var(--bg2);outline:none;cursor:pointer;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;background-size:12px;
  transition:all .25s;min-width:120px;
}
.fbar-select option{background:var(--card);color:var(--text)}
.fbar-select:hover{border-color:var(--primary)}
.fbar-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.fbar-input{
  height:34px;padding:0 12px;border:1px solid var(--border-l);border-radius:var(--radius-s);
  font-size:13px;color:var(--text);background:var(--bg2);outline:none;width:260px;
  transition:all .25s;
}
.fbar-input::placeholder{color:var(--text3)}
.fbar-input:hover{border-color:var(--primary)}
.fbar-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}
.fbar-btn{
  height:34px;padding:0 16px;border:1px solid var(--border-l);border-radius:var(--radius-s);
  font-size:13px;color:var(--text2);background:var(--bg2);cursor:pointer;
  transition:all .25s;font-weight:500;
}
.fbar-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.fbar-btn:active{transform:scale(.97)}

/* ── Detail Page ── */
.d-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.d-item{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-s);padding:14px 16px;transition:all var(--tr)}
.d-item:hover{border-color:rgba(124,127,255,.15);background:rgba(124,127,255,.03)}
.d-item .d-lb{font-size:10px;color:var(--text3);font-weight:600;margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px}
.d-item .d-vl{font-size:14px;font-weight:600;color:var(--text)}
.d-section{margin-top:16px}
.d-section h4{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.d-box{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-s);padding:14px 16px;color:var(--text2);line-height:1.7;font-size:13.5px;white-space:pre-wrap}

/* ── Architecture ── */
.arch-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.arch-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .3s}
.arch-card:hover{border-color:rgba(124,127,255,.15);box-shadow:0 4px 20px rgba(0,0,0,.2)}
.arch-card h3{font-size:15px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px;color:var(--text)}
.arch-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-s);margin-bottom:8px;transition:all var(--tr)}
.arch-item:hover{background:rgba(255,255,255,.03);border-color:rgba(124,127,255,.1)}
.arch-item-left{display:flex;align-items:center;gap:10px}
.arch-item-icon{width:34px;height:34px;border-radius:var(--radius-s);display:flex;align-items:center;justify-content:center;font-size:16px}
.arch-item-label{font-size:13px;font-weight:600;color:var(--text)}
.arch-item-desc{font-size:11px;color:var(--text3);margin-top:2px}
.arch-item-status{font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px}
.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.status-dot.green{background:var(--green);box-shadow:0 0 6px rgba(16,185,129,.4)}
.status-dot.orange{background:var(--orange);box-shadow:0 0 6px rgba(245,158,11,.4)}
.status-dot.red{background:var(--red);box-shadow:0 0 6px rgba(239,68,68,.4)}
.status-dot.blue{background:var(--blue);box-shadow:0 0 6px rgba(59,130,246,.4)}
.status-dot.teal{background:var(--teal);box-shadow:0 0 6px rgba(20,184,166,.4)}

/* ── V5 Info Banner ── */
.v5-banner{background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.15);border-radius:var(--radius);padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:14px;transition:all .3s}
.v5-banner:hover{border-color:rgba(16,185,129,.25);box-shadow:0 0 30px rgba(16,185,129,.06)}
.v5-banner-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--green),var(--teal));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex-shrink:0;box-shadow:0 4px 12px rgba(16,185,129,.3)}
.v5-banner-text h3{font-size:14px;font-weight:700;color:var(--green);margin-bottom:2px}
.v5-banner-text p{font-size:12px;color:var(--text2);line-height:1.5}

/* ── V10.F2 看板筛选栏 ── */
.dash-filter-bar{
  position:sticky; top:0; z-index:10;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px 18px; margin-bottom:16px;
  box-shadow:0 2px 12px rgba(0,0,0,.2);
}
.dash-filter-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.dash-filter-group{display:flex;align-items:center;gap:10px}
.dash-filter-label{font-size:12px;color:var(--text2);font-weight:600;white-space:nowrap;letter-spacing:.5px}
.dash-filter-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.dash-filter-hint{font-size:12px;color:var(--primary);font-weight:600;padding:4px 12px;background:rgba(124,127,255,.12);border-radius:12px;border:1px solid rgba(124,127,255,.25)}

/* 分段按钮组（替代 el-select 下拉，避免 z-index 问题 + 一眼可见所有选项） */
.dash-chip-group{display:inline-flex;flex-wrap:wrap;gap:6px;padding:4px;background:var(--bg2, rgba(0,0,0,.2));border:1px solid var(--border);border-radius:10px}
.dash-chip{
  border:none;background:transparent;color:var(--text2);
  padding:6px 12px;font-size:12px;font-weight:500;
  border-radius:6px;cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
}
.dash-chip:hover{background:rgba(255,255,255,.05);color:var(--text)}
.dash-chip.active{
  background:linear-gradient(135deg,var(--primary),var(--purple,#8b5cf6));
  color:#fff;font-weight:600;
  box-shadow:0 2px 8px rgba(124,127,255,.3);
}
.dash-chip.active:hover{color:#fff}

/* 修 Element Plus 下拉弹出层 z-index（日期选择器还在用） */
.el-select__popper.el-popper,
.el-picker__popper.el-popper,
.el-popper.is-light{z-index:2000 !important}

@media (max-width:900px){
  .dash-filter-row{gap:10px}
  .dash-filter-actions{margin-left:0;width:100%}
  .dash-chip{padding:5px 10px;font-size:11px}
}

/* ── Plugin Endpoints ── */
.ep-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ep-card{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--radius-s);padding:14px 16px;transition:all .25s}
.ep-card:hover{border-color:rgba(124,127,255,.2);background:rgba(124,127,255,.03)}
.ep-card .ep-method{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;font-family:monospace;margin-right:6px}
.ep-card .ep-method.post{background:rgba(16,185,129,.15);color:var(--green)}
.ep-card .ep-path{font-size:13px;font-weight:600;font-family:monospace;color:var(--accent)}
.ep-card .ep-desc{font-size:12px;color:var(--text2);margin-top:6px;line-height:1.5}
.ep-card .ep-params{font-size:11px;color:var(--text3);margin-top:6px;font-family:monospace;background:rgba(255,255,255,.03);padding:8px 10px;border-radius:6px;line-height:1.7;border:1px solid var(--border)}

/* ── Sync Page ── */
.sync-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.sync-folder{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--radius-s);font-size:12px;margin:4px;transition:all .2s}
.sync-folder:hover{border-color:rgba(124,127,255,.2);background:rgba(124,127,255,.03)}
.sync-folder .sf-icon{font-size:14px}
.sync-folder .sf-name{font-weight:600;color:var(--text)}
.sync-folder .sf-id{color:var(--text3);font-size:11px;font-family:monospace}
.log-action{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700}
.log-action.auto{background:rgba(59,130,246,.12);color:var(--blue)}
.log-action.manual{background:rgba(139,92,246,.12);color:var(--purple)}
.log-action.batch{background:rgba(245,158,11,.12);color:var(--orange)}
.log-status{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}
.log-status.success{background:rgba(16,185,129,.12);color:var(--green)}
.log-status.failed{background:rgba(239,68,68,.12);color:var(--red)}

/* ── Audit Log ── */
.audit-action{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700}
.audit-action.login{background:rgba(16,185,129,.12);color:var(--green)}
.audit-action.login_failed{background:rgba(239,68,68,.12);color:var(--red)}
.audit-action.create_user{background:rgba(59,130,246,.12);color:var(--blue)}
.audit-action.delete_user{background:rgba(239,68,68,.12);color:var(--red)}
.audit-action.reset_password{background:rgba(139,92,246,.12);color:var(--purple)}
.audit-action.change_password{background:rgba(245,158,11,.12);color:var(--orange)}
.audit-action.change_password_failed{background:rgba(239,68,68,.12);color:var(--red)}
.audit-action.create_ticket{background:rgba(16,185,129,.12);color:var(--green)}
.audit-action.update_ticket_status{background:rgba(59,130,246,.12);color:var(--blue)}
.pwd-rule{font-size:11px;color:var(--text3);margin-top:4px;line-height:1.6}
.pwd-rule.ok{color:var(--green)}.pwd-rule.fail{color:var(--red)}

/* ── Ticket Images (V6.0/V6.6) ── */
.ticket-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:8px}
.ticket-img-card{position:relative;border-radius:var(--radius-s);border:1px solid var(--border);overflow:hidden;background:rgba(255,255,255,.02);transition:all .3s;aspect-ratio:1;cursor:pointer}
.ticket-img-card:hover{border-color:rgba(124,127,255,.3);box-shadow:0 4px 16px rgba(0,0,0,.3);transform:translateY(-2px)}
.ticket-img-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.ticket-img-card:hover img{transform:scale(1.05)}
.ticket-img-card .img-overlay{position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(0,0,0,.7));opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;justify-content:space-between;padding:8px 10px}
.ticket-img-card:hover .img-overlay{opacity:1}
.ticket-img-card .img-name{font-size:10px;color:rgba(255,255,255,.8);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}
.ticket-img-card .img-del{font-size:16px;cursor:pointer;color:rgba(255,255,255,.7);transition:all .2s;background:rgba(239,68,68,.6);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ticket-img-card .img-del:hover{color:#fff;background:rgba(239,68,68,.9);transform:scale(1.15)}
.ticket-img-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;color:var(--text3);gap:8px;border:1px dashed var(--border);border-radius:var(--radius-s);background:rgba(255,255,255,.01)}
.ticket-img-empty-icon{font-size:28px;opacity:.3}
.ticket-img-empty-text{font-size:12px}

/* Image Preview Overlay */
.img-preview-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:zoom-out;animation:fadeIn .2s ease}
.img-preview-overlay img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5)}
.img-preview-close{position:absolute;top:20px;right:24px;color:#fff;font-size:28px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:all .2s}
.img-preview-close:hover{background:rgba(255,255,255,.2)}

/* V6.6: Status image upload */
.status-img-upload{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.status-img-thumb{position:relative;width:60px;height:60px;border-radius:6px;overflow:hidden;border:1px solid var(--border-l)}
.status-img-thumb img{width:100%;height:100%;object-fit:cover}
.status-img-del{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:10px;line-height:16px;text-align:center;cursor:pointer}
.status-img-add{width:60px;height:60px;border:1px dashed var(--border-l);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:2px;transition:all .2s}
.status-img-add:hover{border-color:var(--primary);background:rgba(124,127,255,.05)}
.detail-upload-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:6px;background:rgba(124,127,255,.1);color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid rgba(124,127,255,.2)}
.detail-upload-btn:hover{background:rgba(124,127,255,.18);border-color:var(--primary)}

/* V8.2 Paste zone */
.paste-zone{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 20px;border:2px dashed var(--border-l);border-radius:8px;cursor:pointer;transition:all .25s;background:transparent;outline:none;position:relative}
.paste-zone:hover{border-color:var(--primary);background:rgba(124,127,255,.04)}
.paste-zone:focus{border-color:var(--primary);border-style:solid;background:rgba(124,127,255,.08);box-shadow:0 0 0 4px rgba(124,127,255,.15),0 0 20px rgba(124,127,255,.08)}
.paste-zone-text{font-size:12px;color:var(--text3);user-select:none;white-space:nowrap;transition:color .25s}
.paste-zone:hover .paste-zone-text{color:var(--text2)}
.paste-zone:focus .paste-zone-text{color:var(--primary);font-weight:600}
.paste-zone-ready{display:none;font-size:11px;color:var(--primary);font-weight:600;animation:pastePulse 1.5s ease-in-out infinite}
.paste-zone:focus .paste-zone-ready{display:inline}

/* V8.4 系统健康面板 */
.health-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.health-card{padding:16px;border:1px solid var(--border);border-radius:12px;background:var(--bg2);transition:all .25s;position:relative;overflow:hidden}
.health-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--border-l);transition:background .25s}
.health-card:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,.08)}
.health-card.health-healthy::before{background:var(--green)}
.health-card.health-warning::before{background:#f59e0b}
.health-card.health-error::before{background:var(--red)}
.health-card.health-unknown::before{background:var(--text3)}
.health-card-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.health-card-icon{font-size:22px;line-height:1}
.health-card-name{font-size:14px;font-weight:600;color:var(--text);flex:1}
.health-card-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:10px;font-size:11px;font-weight:600}
.health-card-badge.hb-healthy{background:rgba(16,185,129,.12);color:var(--green)}
.health-card-badge.hb-warning{background:rgba(245,158,11,.12);color:#f59e0b}
.health-card-badge.hb-error{background:rgba(239,68,68,.12);color:var(--red)}
.health-card-badge.hb-unknown{background:rgba(100,116,139,.12);color:var(--text3)}
.health-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.health-card.health-healthy .health-dot{animation:healthPulse 2s ease-in-out infinite}
.health-card-detail{font-size:12px;color:var(--text2);line-height:1.6;padding-left:32px}
@keyframes healthPulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,.5)}50%{opacity:.7;box-shadow:0 0 0 4px rgba(16,185,129,0)}}

/* V10.F3 乐享 Token 续期卡片 */
.lexiang-token-zone{margin:12px 0 0 32px;padding:10px 12px;border-radius:8px;background:rgba(124,127,255,.04);border:1px dashed rgba(124,127,255,.2)}
.lxtoken-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px;font-size:12px}
.lxtoken-label{color:var(--text2);font-weight:600}
.lxtoken-days{font-weight:700;padding:2px 10px;border-radius:12px;font-size:12px}
.lxtoken-days.lxtoken-ok{color:#10b981;background:rgba(16,185,129,.1)}
.lxtoken-days.lxtoken-warning{color:#f59e0b;background:rgba(245,158,11,.1)}
.lxtoken-days.lxtoken-critical{color:#ef4444;background:rgba(239,68,68,.1);animation:lxtokenBlink 1.5s ease-in-out infinite}
.lxtoken-days.lxtoken-expired{color:#fff;background:#ef4444;animation:lxtokenBlink 1s ease-in-out infinite}
.lxtoken-expire{color:var(--text3);font-size:11px}
.lxtoken-actions{display:flex;gap:6px;flex-wrap:wrap}
@keyframes lxtokenBlink{0%,100%{opacity:1}50%{opacity:.6}}

/* V9.1 SLA 倒计时卡片 */
.sla-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-top:8px}
.sla-card{padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:var(--bg2);position:relative;overflow:hidden;transition:all .25s}
.sla-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--border-l);transition:background .25s}
.sla-card.sla-ok::before{background:var(--green)}
.sla-card.sla-warning::before{background:#f59e0b}
.sla-card.sla-timeout::before{background:var(--red)}
.sla-card.sla-done::before{background:var(--text3)}
.sla-card-label{font-size:12px;color:var(--text3);font-weight:500;margin-bottom:6px}
.sla-card-val{font-size:17px;font-weight:700;color:var(--text);padding-left:8px;letter-spacing:.3px}
.sla-card.sla-ok .sla-card-val{color:var(--green)}
.sla-card.sla-warning .sla-card-val{color:#f59e0b}
.sla-card.sla-timeout .sla-card-val{color:var(--red)}
.sla-card.sla-done .sla-card-val{color:var(--text3)}
.sla-card-sub{font-size:11px;color:var(--text3);margin-top:8px;padding-left:8px;line-height:1.5}
.paste-zone:focus .paste-zone-hint{display:none}
@keyframes pastePulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ── Empty State ── */
.empty-state{text-align:center;padding:60px 20px;color:var(--text3)}
.empty-state-icon{font-size:56px;opacity:.2;margin-bottom:16px;display:block;animation:floatIcon 3s ease-in-out infinite}
.empty-state-text{font-size:15px;font-weight:600;color:var(--text2);margin-bottom:6px}
.empty-state-sub{font-size:13px;color:var(--text3);line-height:1.6}

/* ── V6.4 Changelog Timeline ── */
.changelog-header{text-align:center;margin-bottom:32px}
.changelog-header h2{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.3px;margin-bottom:6px}
.changelog-header p{font-size:13px;color:var(--text3);line-height:1.6}
.changelog-timeline{position:relative;padding:0 0 20px}
.changelog-timeline::before{content:'';position:absolute;left:28px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--primary),var(--teal),var(--primary-light));border-radius:2px}
.cl-item{position:relative;padding:0 0 28px 64px;animation:panelIn .4s cubic-bezier(.16,1,.3,1) both}
.cl-item:last-child{padding-bottom:0}
.cl-dot{position:absolute;left:19px;top:4px;width:20px;height:20px;border-radius:50%;background:var(--card);border:3px solid var(--primary);z-index:1;transition:all .3s}
.cl-item:hover .cl-dot{transform:scale(1.2);box-shadow:0 0 16px var(--primary-glow)}
.cl-item.latest .cl-dot{background:var(--primary);border-color:var(--primary);box-shadow:0 0 12px var(--primary-glow);animation:dotPulse 2s ease-in-out infinite}
.cl-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 22px;transition:all .3s;position:relative;overflow:hidden}
.cl-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:0;transition:opacity .3s}
.cl-card:hover{border-color:rgba(124,127,255,.2);box-shadow:0 4px 24px rgba(0,0,0,.2);transform:translateX(4px)}
.cl-card:hover::before{opacity:1}
.cl-item.latest .cl-card{border-color:rgba(124,127,255,.25);background:linear-gradient(135deg,rgba(124,127,255,.06),rgba(45,217,244,.03))}
.cl-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.cl-version{font-size:16px;font-weight:800;color:var(--primary);letter-spacing:-.2px}
.cl-item.latest .cl-version{background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:18px}
.cl-tag{padding:2px 10px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px}
.cl-tag.feat{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.15)}
.cl-tag.fix{background:rgba(59,130,246,.12);color:#60a5fa;border:1px solid rgba(59,130,246,.15)}
.cl-tag.arch{background:rgba(139,92,246,.12);color:#a78bfa;border:1px solid rgba(139,92,246,.15)}
.cl-tag.sec{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.15)}
.cl-tag.perf{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.15)}
.cl-tag.latest-tag{background:linear-gradient(135deg,rgba(124,127,255,.2),rgba(45,217,244,.2));color:var(--accent);border:1px solid rgba(45,217,244,.25);animation:badgePulse 2s infinite}
.cl-date{font-size:11px;color:var(--text3);font-weight:500}
.cl-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px}
.cl-changes{list-style:none;padding:0;margin:0}
.cl-changes li{font-size:12px;color:var(--text2);line-height:1.8;padding-left:16px;position:relative}
.cl-changes li::before{content:'\203A';position:absolute;left:0;color:var(--primary);font-weight:700;font-size:14px}

/* ── Responsive Overrides (Component-specific) ── */
@media(max-width:1100px){.charts-row,.arch-grid,.ep-grid{grid-template-columns:1fr}.sync-kpi-row{grid-template-columns:1fr 1fr}}
@media(max-width:768px){
  .kpi-row,.sync-kpi-row{grid-template-columns:1fr 1fr}
  .d-grid{grid-template-columns:1fr}
  .month-compare{flex-direction:column;gap:16px;padding:16px}
  .mc-divider{width:100%;height:1px;margin:0}
  .eff-detail{display:none}.eff-name{width:60px}
  .changelog-timeline::before{left:18px}.cl-item{padding-left:48px}.cl-dot{left:9px;width:18px;height:18px}
}
@media(max-width:600px){.storage-grid{flex-direction:column;gap:16px}.storage-uploads{justify-content:center}}
@media(max-width:480px){.kpi-row{grid-template-columns:1fr}.sync-kpi-row{grid-template-columns:1fr 1fr}}

/* ═══ V11.0 运营报告 ═══ */
.tag.tag-warning{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}
.tag.tag-info{background:rgba(59,130,246,.12);color:#60a5fa;border:1px solid rgba(59,130,246,.2)}
.tag.tag-success{background:rgba(16,185,129,.12);color:#34d399;border:1px solid rgba(16,185,129,.2)}
.tag.tag-danger{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.2)}

.report-detail{padding:24px 28px;color:var(--text)}
.report-detail-hd{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:20px}
.report-section{margin-bottom:22px}
.report-section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px;padding-left:10px;border-left:3px solid var(--primary)}
.report-summary{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;font-size:13px;line-height:1.75;color:var(--text2)}

.report-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.report-kpi-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:all var(--tr)}
.report-kpi-card:hover{transform:translateY(-2px);border-color:var(--primary-glow)}
.report-kpi-card[data-color=blue]{border-left:3px solid var(--blue)}
.report-kpi-card[data-color=green]{border-left:3px solid var(--green)}
.report-kpi-card[data-color=orange]{border-left:3px solid var(--orange)}
.report-kpi-card[data-color=red]{border-left:3px solid var(--red)}
.report-kpi-card[data-color=purple]{border-left:3px solid var(--purple)}
.report-kpi-card .kpi-icon{font-size:18px}
.report-kpi-card .kpi-label{font-size:12px;color:var(--text3);margin:4px 0}
.report-kpi-card .kpi-value{font-size:24px;font-weight:700;color:var(--text)}
.report-kpi-card .kpi-unit{font-size:13px;color:var(--text3);margin-left:2px;font-weight:500}
.report-kpi-card .kpi-trend{font-size:11px;color:var(--text3);margin-top:4px}

.report-topic-list,.report-sys-list,.report-handler-list,.report-bottleneck-list,.report-action-list{display:flex;flex-direction:column;gap:10px}
.report-topic-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.topic-hd{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}
.topic-rank{background:var(--primary);color:#fff;padding:2px 8px;border-radius:4px;font-weight:700;font-size:12px}
.topic-name{font-weight:600;color:var(--text)}
.topic-sev{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}
.topic-sev[data-sev=高]{background:rgba(239,68,68,.15);color:#fca5a5}
.topic-sev[data-sev=中]{background:rgba(245,158,11,.15);color:#fcd34d}
.topic-sev[data-sev=低]{background:rgba(59,130,246,.15);color:#93c5fd}
.topic-count{margin-left:auto;color:var(--text3);font-size:12px}
.topic-samples{margin:6px 0}
.sample-item{color:var(--text3);font-size:12px;line-height:1.8;padding-left:8px}
.topic-insight{margin-top:6px;color:var(--text2);font-size:12.5px;background:var(--bg2);padding:8px 10px;border-radius:6px;line-height:1.6}

.report-sys-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.sys-hd{display:flex;gap:10px;align-items:center;margin-bottom:6px}
.sys-eval{color:var(--text2);font-size:13px;line-height:1.6;margin-bottom:6px}
.sys-issues{display:flex;flex-wrap:wrap;gap:6px}
.sys-issue-tag{display:inline-block;background:var(--bg2);color:var(--text2);padding:2px 8px;border-radius:4px;font-size:11px;border:1px solid var(--border)}

.report-handler-row{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px;border-left:3px solid var(--text3)}
.report-handler-row[data-tone=praise]{border-left-color:var(--green)}
.report-handler-row[data-tone=concern]{border-left-color:var(--orange)}
.report-handler-row[data-tone=neutral]{border-left-color:var(--text3)}
.handler-head{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.handler-tone{font-size:16px}
.handler-comment{color:var(--text2);font-size:13px;line-height:1.6}

.report-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.report-subcard{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.subcard-title{font-weight:600;font-size:13px;color:var(--text);margin-bottom:8px}
.subcard-kpi{display:flex;align-items:baseline;gap:10px;margin-bottom:6px}
.subcard-num{font-size:26px;font-weight:700;color:var(--primary)}
.subcard-hint{color:var(--text3);font-size:12px}
.subcard-comment{color:var(--text2);font-size:12.5px;line-height:1.6;margin-top:6px}

.report-bottleneck-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px;border-left:3px solid var(--orange)}
.bn-title{font-weight:600;color:var(--text);margin-bottom:4px;font-size:13.5px}
.bn-detail{color:var(--text2);font-size:13px;line-height:1.6}

.report-next-action{display:flex;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.na-priority{background:var(--primary);color:#fff;padding:4px 10px;border-radius:6px;font-weight:700;height:fit-content;font-size:12px}
.na-main{flex:1}
.na-action{font-weight:600;color:var(--text);margin-bottom:4px;font-size:13.5px}
.na-meta{display:flex;gap:12px;color:var(--text3);font-size:12px}

@media(max-width:900px){.report-kpi-grid{grid-template-columns:repeat(2,1fr)}.report-row-2{grid-template-columns:1fr}}

/* ═══ V11.1 工单详情 inline edit ═══ */
.d-editable{display:flex;align-items:center}
.d-inline-select{width:auto!important;min-width:90px}
.d-inline-select .el-select__wrapper{padding:2px 8px!important;height:28px!important;min-height:28px!important;font-size:13px!important}
.d-inline-select .el-select__caret{font-size:12px!important}
