:root{--c:#00a6a7;--ch:#008f90;--bg:#f4f6f8;--sf:#fff;--t1:#1f2937;--t2:#64748b;--bd:#e2e8f0;--r:8px;--rl:12px;--s1:0 1px 2px rgba(0,0,0,.05);--s2:0 4px 6px -1px rgba(0,0,0,.1);--s3:0 10px 15px -3px rgba(0,0,0,.1)}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif;background:var(--bg);color:var(--t1);height:100vh;width:100vw;overflow:hidden;display:flex}
.app{display:flex;height:100vh;width:100vw;overflow:hidden}
.sidebar{width:260px;min-width:260px;background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;z-index:10;box-shadow:var(--s1)}
.sidebar-header{height:72px;display:flex;align-items:center;padding:0 24px;border-bottom:1px solid var(--bd)}
.sidebar-header h1{font-size:18px;font-weight:600;color:var(--c);display:flex;align-items:center;gap:10px}
.sidebar-menu{padding:16px;flex:1;display:flex;flex-direction:column;gap:4px}
.menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--r);cursor:pointer;color:var(--t2);font-size:15px;font-weight:500;transition:all .2s}
.menu-item:hover{background:#f8fafc;color:var(--c)}
.menu-item.active{background:rgba(0,166,167,.1);color:var(--c)}
.menu-item i{width:20px;font-size:16px;text-align:center}
.menu-divider{height:1px;background:var(--bd);margin:8px 16px}
.menu-label{font-size:11px;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:8px 16px 4px}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.top-header{height:72px;background:var(--sf);border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center;padding:0 32px;box-shadow:var(--s1);z-index:5}
.header-title{font-size:20px;font-weight:600}
.header-actions{display:flex;gap:12px;align-items:center}
.license-stack{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-right:6px}
.license-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  line-height:1;
  color:#334155;
  background:rgba(255,255,255,0.9);
  border:1px solid rgba(226,232,240,0.95);
  border-radius:10px;
  padding:7px 10px;
  box-shadow:0 1px 0 rgba(15,23,42,0.03), 0 6px 20px rgba(15,23,42,0.04);
  white-space:nowrap;
}
.license-chip::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:999px;
  background:linear-gradient(135deg,#38bdf8,#6366f1);
  box-shadow:0 0 0 3px rgba(59,130,246,0.10);
}
.license-chip-sub{
  font-size:11px;
  color:#64748b;
  background:rgba(248,250,252,0.9);
  padding:6px 10px;
}
.license-chip-sub::before{
  background:linear-gradient(135deg,#94a3b8,#cbd5e1);
  box-shadow:none;
}

/* 剩余授权比例指示灯 */
.license-chip-sub.dot-green::before{
  background:linear-gradient(135deg,#22c55e,#86efac);
  box-shadow:0 0 0 3px rgba(34,197,94,0.14);
}
.license-chip-sub.dot-blue::before{
  background:linear-gradient(135deg,#3b82f6,#60a5fa);
  box-shadow:0 0 0 3px rgba(59,130,246,0.14);
}
.license-chip-sub.dot-red::before{
  background:linear-gradient(135deg,#ef4444,#fca5a5);
  box-shadow:0 0 0 3px rgba(239,68,68,0.14);
}
.content-body{flex:1;overflow-y:auto;padding:32px}
.view-pane{display:none;animation:fi .3s ease}
.view-pane.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.btn{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;border-radius:var(--r);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent}
.btn-primary{background:var(--c);color:#fff}.btn-primary:hover{background:var(--ch);transform:translateY(-1px)}
.btn-outline{background:#fff;border-color:var(--bd);color:var(--t1)}.btn-outline:hover{border-color:var(--c);color:var(--c)}
.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}
.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}
.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}
.btn-sm{padding:5px 12px;font-size:12px}
.upload-wrapper{position:relative;display:inline-block}
.upload-wrapper input[type=file]{position:absolute;left:0;top:0;opacity:0;width:100%;height:100%;cursor:pointer}
.empty-state{background:var(--sf);border-radius:var(--rl);padding:80px 20px;text-align:center;border:1px dashed #cbd5e1;margin-bottom:24px}
.empty-state i{font-size:64px;color:#cbd5e1;margin-bottom:24px}
.empty-state h3{font-size:18px;margin-bottom:12px}
.empty-state p{font-size:14px;color:var(--t2);max-width:500px;margin:0 auto 24px;line-height:1.6}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:24px}
.stat-card{background:var(--sf);border-radius:var(--rl);padding:24px;box-shadow:var(--s1);border:1px solid var(--bd);display:flex;align-items:center;gap:16px;transition:transform .2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--s2)}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.stat-info{flex:1}.stat-label{font-size:13px;color:var(--t2);margin-bottom:4px;font-weight:500}
.stat-val{font-size:28px;font-weight:700;line-height:1}
.si-total .stat-icon{background:#f1f5f9;color:#475569}
.si-matched .stat-icon{background:#dcfce7;color:#22c55e}.si-matched .stat-val{color:#22c55e}
.si-contacted .stat-icon{background:#e0f2fe;color:#0ea5e9}.si-contacted .stat-val{color:#0ea5e9}
.si-pending .stat-icon{background:#fef9c3;color:#eab308}.si-pending .stat-val{color:#eab308}
.si-rejected .stat-icon{background:#fee2e2;color:#ef4444}.si-rejected .stat-val{color:#ef4444}
.filter-section{background:var(--sf);border-radius:var(--rl);padding:16px 20px;margin-bottom:16px;box-shadow:var(--s1);border:1px solid var(--bd);display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.filter-item{display:flex;align-items:center;gap:8px;min-height:34px}
.filter-item label{font-size:14px;font-weight:500;color:var(--t2);white-space:nowrap}
.form-control{padding:8px 16px;border:1px solid var(--bd);border-radius:var(--r);font-size:14px;outline:none;transition:all .2s;background:#fff;min-width:140px;color:var(--t1)}
.form-control:focus{border-color:var(--c);box-shadow:0 0 0 3px rgba(0,166,167,.1)}
.quick-filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin:-4px 0 12px}
.quick-filter-chip{border:1px solid #dbe3ef;background:#fff;color:#475569;border-radius:999px;padding:5px 12px;font-size:12px;cursor:pointer;transition:all .18s}
.quick-filter-chip:hover{border-color:#7dd3fc;color:#0c4a6e;background:#f0f9ff}
.quick-filter-chip.active{border-color:var(--c);background:rgba(0,166,167,.1);color:var(--c);font-weight:600}
.table-card{background:var(--sf);border-radius:var(--rl);box-shadow:var(--s1);border:1px solid var(--bd);overflow:hidden}
.talent-layout-wrap{display:flex;gap:12px;align-items:stretch}
.talent-layout-wrap .table-card{flex:1}
.talent-tree-panel{width:220px;min-width:220px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--s1);padding:12px 8px;max-height:calc(100vh - 330px);overflow:auto}
.talent-tree-title{font-size:13px;font-weight:700;color:#475569;padding:0 8px 10px 8px;border-bottom:1px solid #f1f5f9;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.talent-tree-list{display:flex;flex-direction:column;gap:4px}
.talent-tree-item{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:8px;cursor:pointer;color:#334155;font-size:13px;transition:all .15s}
.talent-tree-item:hover{background:#f8fafc}
.talent-tree-item.active{background:rgba(0,166,167,.1);color:var(--c);font-weight:600}
.talent-tree-item .cat-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.talent-tree-item .cat-count{background:#eef2ff;color:#475569;border-radius:999px;padding:1px 8px;font-size:11px}
.table-header{padding:14px 16px;border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.table-header h2{font-size:16px;font-weight:600;margin:0}
.table-header-right{display:flex;align-items:center;gap:12px}
.table-count{font-size:13px;color:var(--t2);background:#f1f5f9;padding:4px 12px;border-radius:20px}
.table-responsive{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 420px)}
table{width:100%;border-collapse:collapse;text-align:left;table-layout:fixed;min-width:1180px}
.talent-table{min-width:1194px}
th,td{padding:11px 12px;border-bottom:1px solid var(--bd);font-size:13px}
th{background:#f8fafc;font-weight:600;color:var(--t2);position:sticky;top:0;z-index:1;white-space:nowrap;cursor:pointer;user-select:none}
th:hover{background:#f1f5f9}
th .sort-icon{margin-left:4px;font-size:11px;color:#cbd5e1}
th .sort-icon.active{color:var(--c)}
td{vertical-align:middle;line-height:1.45}
tbody tr{transition:background .2s}
tbody tr:hover{background:#f8fafc}
.table-responsive::-webkit-scrollbar{height:8px;width:8px}
.table-responsive::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}
.table-responsive::-webkit-scrollbar-track{background:#f8fafc}

/* 简历库：更清爽的“文件单元格”样式 */
.resume-table{min-width:980px}
.resume-name-cell{font-weight:700;color:#0f172a}
.resume-time-cell{color:var(--t2);font-size:13px;white-space:nowrap}
.resume-file-cell{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.resume-file-text{color:#475569;font-size:13px}
.resume-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid transparent;line-height:1}
.resume-badge.online{background:#e0f2fe;color:#075985;border-color:#bae6fd}
.resume-badge.empty{background:#f1f5f9;color:#475569;border-color:#e2e8f0}
.resume-view-btn{border-radius:999px}
.resume-file-cell .action-link{white-space:nowrap}

@media (max-width: 1100px){
  .resume-file-cell{gap:8px}
  .resume-file-text{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}

/* 人才库列表列宽与内容规整 */
#tableBody td:nth-child(2){font-weight:600}
#tableBody td:nth-child(3){text-align:center}
#tableBody td:nth-child(4){color:#334155}
#tableBody td:nth-child(5){text-align:center}
#tableBody td:nth-child(6){color:#475569;line-height:1.5;word-break:break-word}
#tableBody td:nth-child(7){font-weight:600}
#tableBody td:nth-child(8){color:#64748b}
#tableBody td:nth-child(9){white-space:nowrap;color:#64748b;font-size:12px}
#tableBody td:nth-child(10){white-space:nowrap}
.talent-table th:nth-child(1), .talent-table td:nth-child(1){text-align:center}
.talent-table th:nth-child(3), .talent-table td:nth-child(3){text-align:center}
.talent-table th:nth-child(5), .talent-table td:nth-child(5){text-align:center}
.talent-table th:nth-child(7), .talent-table td:nth-child(7){text-align:center}
.talent-table th:nth-child(10), .talent-table td:nth-child(10){text-align:center}
.table-header-right .table-count{min-width:72px;text-align:center}
.candidate-score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:24px;padding:0 8px;border-radius:999px;font-size:12px;font-weight:700}
.candidate-score-badge.excellent{background:#dcfce7;color:#166534}
.candidate-score-badge.good{background:#dbeafe;color:#1d4ed8}
.candidate-score-badge.normal{background:#fef3c7;color:#92400e}
.candidate-score-badge.weak{background:#fee2e2;color:#991b1b}
.row-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--c)}
.tag{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:6px}
.tag::before{content:'';display:block;width:6px;height:6px;border-radius:50%}
.tag-matched{background:#dcfce7;color:#166534}.tag-matched::before{background:#22c55e}
.tag-rejected{background:#fee2e2;color:#991b1b}.tag-rejected::before{background:#ef4444}
.tag-contacted{background:#e0f2fe;color:#075985}.tag-contacted::before{background:#0ea5e9}
.tag-pending{background:#fef9c3;color:#854d0e}.tag-pending::before{background:#eab308}
.text-truncate{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.action-link{color:var(--c);cursor:pointer;text-decoration:none;font-weight:500;transition:color .2s;display:inline-flex;align-items:center;gap:4px;font-size:13px}
.action-link:hover{color:var(--ch);text-decoration:underline}
.pagination-bar{padding:12px 16px;border-top:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center;background:#fff}
.pagination-info{font-size:13px;color:var(--t2)}
.pagination-controls{display:flex;gap:4px;align-items:center}
.pagination-controls button{width:36px;height:36px;border:1px solid var(--bd);background:#fff;border-radius:var(--r);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--t1)}
.pagination-controls button:hover:not(:disabled){border-color:var(--c);color:var(--c)}
.pagination-controls button.active{background:var(--c);color:#fff;border-color:var(--c)}
.pagination-controls button:disabled{opacity:.4;cursor:not-allowed}
.page-size-select{padding:6px 10px;border:1px solid var(--bd);border-radius:var(--r);font-size:13px;color:var(--t1);background:#fff}
.batch-bar{padding:12px 24px;background:#eff6ff;border-bottom:1px solid #bfdbfe;align-items:center;gap:16px;font-size:14px;color:#1e40af;display:none}
.batch-bar.show{display:flex}
.toast{position:fixed;top:24px;left:50%;transform:translateX(-50%) translateY(-20px);background:var(--sf);padding:12px 24px;border-radius:var(--r);box-shadow:var(--s3);display:flex;align-items:center;gap:12px;z-index:10000;opacity:0;pointer-events:none;transition:all .3s;font-weight:500;border:1px solid var(--bd)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast i.success{color:#22c55e;font-size:18px}
.toast i.error{color:#ef4444;font-size:18px}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(15,23,42,.6);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.modal-overlay.show{display:flex;opacity:1}
.modal{background:var(--sf);width:700px;max-width:90vw;border-radius:var(--rl);box-shadow:var(--s3);display:flex;flex-direction:column;max-height:85vh}
.modal-overlay.show .modal{transform:scale(1)}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center}
.modal-header h3{font-size:18px;font-weight:600;margin:0}
.modal-close{cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--t2);transition:all .2s}
.modal-close:hover{background:#f1f5f9;color:var(--t1)}
.modal-body{padding:24px;overflow-y:auto;flex:1;font-size:14px;line-height:1.8}
.modal-footer{padding:16px 24px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:12px}
.chat-bubble{margin-bottom:16px;display:flex;flex-direction:column}
.chat-bubble.hr{align-items:flex-end}.chat-bubble.candidate{align-items:flex-start}
.chat-sender{font-size:12px;color:var(--t2);margin-bottom:4px;font-weight:500}
.chat-text{padding:12px 16px;border-radius:12px;max-width:85%;word-wrap:break-word;box-shadow:var(--s1)}
.chat-bubble.hr .chat-text{background:var(--c);color:#fff;border-bottom-right-radius:4px}
.chat-bubble.candidate .chat-text{background:#f1f5f9;color:var(--t1);border-bottom-left-radius:4px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}
.detail-item{display:flex;flex-direction:column;gap:4px}
.detail-label{font-size:12px;color:var(--t2);font-weight:600;text-transform:uppercase}
.detail-value{font-size:14px;color:var(--t1);word-break:break-all}
.detail-divider{grid-column:1/-1;height:1px;background:var(--bd);margin:8px 0}
.detail-full{grid-column:1/-1}
.detail-tags{display:flex;flex-wrap:wrap;gap:8px}
.detail-tag{background:#f1f5f9;color:var(--t2);padding:4px 12px;border-radius:20px;font-size:12px}
.timeline{position:relative;padding-left:24px}
.timeline::before{content:'';position:absolute;left:8px;top:4px;bottom:4px;width:2px;background:var(--bd)}
.timeline-item{position:relative;margin-bottom:16px}
.timeline-item::before{content:'';position:absolute;left:-20px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--c);border:2px solid #fff;box-shadow:0 0 0 2px var(--c)}
.timeline-item .tl-time{font-size:12px;color:var(--t2)}
.timeline-item .tl-text{font-size:14px}
.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.chart-card{background:var(--sf);border-radius:var(--rl);padding:24px;box-shadow:var(--s1);border:1px solid var(--bd)}
.chart-card h3{font-size:16px;font-weight:600;margin-bottom:20px}
.bar-chart{display:flex;flex-direction:column;gap:12px}
.bar-row{display:flex;align-items:center;gap:12px}
.bar-label{width:80px;font-size:13px;color:var(--t2);text-align:right;flex-shrink:0}
.bar-track{flex:1;height:28px;background:#f1f5f9;border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;transition:width .6s;display:flex;align-items:center;padding-left:10px;font-size:12px;color:#fff;font-weight:600;min-width:fit-content}
.bar-count{margin-left:8px;font-size:13px;color:var(--t2);flex-shrink:0;width:40px}
.trend-row{display:flex;align-items:flex-end;gap:6px;height:140px;padding-top:20px}
.trend-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%;justify-content:flex-end}
.trend-bar{width:100%;background:var(--c);border-radius:4px 4px 0 0;min-height:4px;transition:height .4s;opacity:.8}
.trend-bar:hover{opacity:1}
.trend-label{font-size:11px;color:var(--t2)}
.trend-count{font-size:11px;font-weight:600}
.dedup-summary{display:flex;gap:24px;margin-bottom:24px}
.dedup-stat{background:var(--sf);border-radius:var(--rl);padding:24px 32px;box-shadow:var(--s1);border:1px solid var(--bd);text-align:center;flex:1}
.dedup-stat .ds-val{font-size:32px;font-weight:700;color:var(--c)}
.dedup-stat .ds-label{font-size:13px;color:var(--t2);margin-top:4px}
.dedup-group{background:var(--sf);border-radius:var(--rl);padding:20px 24px;margin-bottom:16px;box-shadow:var(--s1);border:1px solid var(--bd)}
.dedup-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.dedup-group-title{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.dedup-group-title .dup-count{background:#fee2e2;color:#991b1b;padding:2px 10px;border-radius:20px;font-size:12px}
.dedup-row{display:flex;align-items:center;gap:16px;padding:10px 16px;border-radius:var(--r);border:1px solid var(--bd);margin-bottom:8px;font-size:13px}
.dedup-row.keeper{border-color:#10b981;background:#f0fdf4}
.dedup-row .dr-name{font-weight:600;width:80px}
.dedup-row .dr-info{flex:1;color:var(--t2)}
.dedup-row .dr-time{font-size:12px;color:var(--t2);width:140px}
.dr-badge{font-size:11px;padding:2px 8px;border-radius:10px}
.dr-badge.keep{background:#dcfce7;color:#166534}
.dr-badge.remove{background:#fee2e2;color:#991b1b}
.export-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.export-card{background:var(--sf);border-radius:var(--rl);padding:32px;box-shadow:var(--s1);border:1px solid var(--bd);text-align:center;cursor:pointer;transition:all .2s}
.export-card:hover{transform:translateY(-2px);box-shadow:var(--s2);border-color:var(--c)}
.export-card i{font-size:48px;color:var(--c);margin-bottom:16px}
.export-card h3{font-size:16px;margin-bottom:8px}
.export-card p{font-size:13px;color:var(--t2);line-height:1.6}
.settings-card{background:var(--sf);border-radius:var(--rl);padding:32px;box-shadow:var(--s1);border:1px solid var(--bd);margin-bottom:24px;max-width:800px}
.settings-card h2{margin-bottom:24px;color:var(--c);font-size:18px}
.settings-card p{line-height:1.8;color:var(--t2);font-size:15px;margin-bottom:16px}
.db-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
.db-stat-item{text-align:center;padding:16px;background:#f8fafc;border-radius:var(--r)}
.db-stat-item .dsv{font-size:24px;font-weight:700;color:var(--c)}
.db-stat-item .dsl{font-size:12px;color:var(--t2);margin-top:4px}

/* ===== Settings Page Styles ===== */
.settings-tabs{display:flex;gap:0;border-bottom:2px solid var(--bd);margin-bottom:28px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.settings-tab{padding:12px 22px;border:none;background:transparent;font-size:14px;font-weight:500;color:var(--t2);cursor:pointer;transition:all .2s;white-space:nowrap;position:relative;border-bottom:2px solid transparent;margin-bottom:-2px}
.settings-tab:hover{color:var(--c);background:rgba(0,166,167,.04)}
.settings-tab.active{color:var(--c);font-weight:600;border-bottom-color:var(--c)}
.settings-tab i{margin-right:6px;font-size:13px}
.settings-tab-pane{display:none;animation:fi .3s ease}
.settings-tab-pane.active{display:block}
.job-filter-head{display:flex;justify-content:space-between;align-items:center;gap:12px}
.job-filter-tabs{display:flex;gap:16px;flex-wrap:wrap;align-items:center;border-bottom:1px solid var(--bd);padding:4px 2px;max-height:92px;overflow:auto}
.job-filter-tab{padding:10px 2px;border:none;background:transparent;color:var(--t2);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-filter-tab:hover{color:var(--c)}
.job-filter-tab.active{color:var(--c);font-weight:600;border-bottom-color:var(--c)}
.setting-checkbox-group{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.setting-checkbox-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--t1);cursor:pointer}
.setting-checkbox-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--c);cursor:pointer}
.setting-conditional{margin-top:12px;padding:16px;background:#f8fafc;border-radius:var(--r);border:1px solid var(--bd);display:none}
.setting-conditional.show{display:block}
.setting-env-info{background:#f8fafc;border-radius:var(--r);padding:16px 20px;margin-bottom:16px;border:1px solid var(--bd)}
.setting-env-info p{font-size:14px;color:var(--t2);margin-bottom:8px;line-height:1.6}
.setting-env-info p:last-child{margin-bottom:0}
.setting-env-info b{color:var(--t1)}
.setting-danger-zone{margin-top:24px;padding:20px 24px;border:1px solid #fecaca;border-radius:var(--r);background:#fef2f2}
.setting-danger-zone h4{color:#dc2626;font-size:14px;font-weight:600;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.setting-danger-zone p{font-size:13px;color:#991b1b;margin-bottom:12px}
.setting-section{background:var(--sf);border-radius:var(--rl);padding:28px 32px;box-shadow:var(--s1);border:1px solid var(--bd);margin-bottom:24px;max-width:800px}
.setting-section-title{font-size:16px;font-weight:600;color:var(--c);margin-bottom:20px;display:flex;align-items:center;gap:10px}
.setting-section-title i{font-size:18px}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f1f5f9}
.setting-row:last-child{border-bottom:none}
.setting-row-left{display:flex;align-items:center;gap:12px;flex:1}
.setting-row-emoji{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.setting-row-info{flex:1}
.setting-row-name{font-size:14px;font-weight:500;color:var(--t1)}
.setting-row-desc{font-size:12px;color:var(--t2);margin-top:2px}
.setting-label{font-size:14px;font-weight:500;color:var(--t1);margin-bottom:6px;display:block}
.setting-hint{font-size:12px;color:var(--t2);margin-bottom:8px}
.setting-input{width:100%;padding:10px 14px;border:1px solid var(--bd);border-radius:var(--r);font-size:14px;outline:none;transition:border-color .2s;background:#fff;color:var(--t1)}
.setting-input:focus{border-color:var(--c);box-shadow:0 0 0 3px rgba(0,166,167,.1)}
.setting-textarea{width:100%;padding:10px 14px;border:1px solid var(--bd);border-radius:var(--r);font-size:14px;outline:none;resize:vertical;min-height:80px;transition:border-color .2s;font-family:inherit;background:#fff;color:var(--t1)}
.setting-textarea:focus{border-color:var(--c);box-shadow:0 0 0 3px rgba(0,166,167,.1)}
.setting-select{padding:10px 14px;border:1px solid var(--bd);border-radius:var(--r);font-size:14px;outline:none;background:#fff;color:var(--t1);min-width:160px;cursor:pointer;transition:border-color .2s}
.setting-select:focus{border-color:var(--c);box-shadow:0 0 0 3px rgba(0,166,167,.1)}
.setting-form-group{margin-bottom:16px}
.setting-form-group:last-child{margin-bottom:0}
.setting-form-row{display:flex;gap:16px;margin-bottom:16px}
.setting-form-row .setting-form-group{flex:1;margin-bottom:0}
.setting-salary-range{display:flex;align-items:center;gap:8px}
.setting-salary-range .setting-input{width:100px}
.setting-salary-range .range-sep{color:var(--t2);font-weight:500}
.setting-salary-range .range-unit{color:var(--t2);font-size:14px;font-weight:500}
.setting-input-group{display:flex;gap:0}
.setting-input-group .setting-input{border-top-right-radius:0;border-bottom-right-radius:0;flex:1}
.setting-input-group .toggle-btn{padding:10px 14px;border:1px solid var(--bd);border-left:none;border-radius:0 var(--r) var(--r) 0;background:#f8fafc;cursor:pointer;font-size:16px;display:flex;align-items:center;transition:background .2s;color:var(--t2)}
.setting-input-group .toggle-btn:hover{background:#e2e8f0}
.settings-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.settings-switch input{opacity:0;width:0;height:0}
.settings-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#cbd5e1;transition:.3s;border-radius:24px}
.settings-slider::before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.settings-switch input:checked+.settings-slider{background:var(--c)}
.settings-switch input:checked+.settings-slider::before{transform:translateX(20px)}
.setting-save-bar{max-width:800px;padding:20px 0;display:flex;gap:12px;align-items:center}
.setting-save-bar .btn{padding:12px 32px;font-size:15px}
.setting-save-status{font-size:13px;color:var(--t2);margin-left:8px}

/* 话术模板页 */
.template-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:1200px}
.template-section{max-width:none;margin-bottom:0}
.template-textarea{min-height:110px;line-height:1.65}

/* 使用文档页 */
.doc-layout{display:grid;grid-template-columns:260px 1fr;gap:16px;align-items:start}
.doc-toc{position:sticky;top:12px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--s1);padding:12px}
.doc-toc-title{font-size:13px;font-weight:700;color:#475569;padding:4px 6px 10px;border-bottom:1px solid #eef2f7;margin-bottom:8px}
.doc-toc-item{display:block;padding:8px 10px;border-radius:8px;color:#334155;text-decoration:none;font-size:13px;line-height:1.4}
.doc-toc-item:hover{background:#f8fafc;color:var(--c)}
.doc-content{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--s1);padding:22px 24px;max-height:calc(100vh - 170px);overflow:auto}
.doc-section{padding-bottom:20px;margin-bottom:20px;border-bottom:1px dashed #e2e8f0}
.doc-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.doc-section h3{font-size:18px;color:#0f172a;margin-bottom:10px}
.doc-section h4{font-size:14px;color:#334155;margin:10px 0 6px}
.doc-section p,.doc-section li{font-size:14px;color:#334155;line-height:1.8}
.doc-section ul,.doc-section ol{padding-left:20px}
.doc-section code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;padding:1px 6px;font-size:12px}
.doc-figure{margin:14px 0;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;background:#fff}
.doc-img{display:block;width:100%;height:auto}
.doc-figure figcaption{padding:10px 12px;background:#f8fafc;border-top:1px solid #e2e8f0;color:#64748b;font-size:12px}
.doc-callout{margin:12px 0;padding:10px 12px;border-radius:10px;background:#f0f9ff;border:1px solid #bae6fd;color:#0c4a6e;font-size:13px;line-height:1.75}
.doc-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

@media (max-width: 1080px){
  .template-grid{grid-template-columns:1fr}
  .doc-layout{grid-template-columns:1fr}
  .doc-toc{position:relative;top:0}
  .doc-content{max-height:none}
  .doc-grid2{grid-template-columns:1fr}
}

@media (max-width: 1360px){
  .talent-layout-wrap{flex-direction:column}
  .talent-tree-panel{width:100%;min-width:0;max-height:220px}
  .talent-tree-item .cat-name{max-width:none}
}
