html{height:100%;margin:0}body{margin:0;background:#eef1f6;overflow-x:hidden}#app,body{min-height:100%}#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#2c3e50}.sub-page[data-v-15ef4f99]{padding:16px;max-width:1320px;margin:0 auto;background:#eef1f6;min-height:100vh}.fans-page[data-v-15ef4f99]{max-width:none;width:100%;margin:0;padding:8px 10px;box-sizing:border-box;min-height:100%}.fans-page .panel[data-v-15ef4f99],.form-row[data-v-15ef4f99] .date-range-input.el-date-editor.el-input__inner,.form-row[data-v-15ef4f99] .date-range-input.el-range-editor.el-input__inner{width:100%;max-width:100%;box-sizing:border-box}.sub-header[data-v-15ef4f99]{margin-bottom:16px}.sub-title[data-v-15ef4f99]{text-align:center;margin:0;font-size:20px;font-weight:600;color:#1a1a1a}.panel[data-v-15ef4f99]{background:#fff;padding:16px 14px;border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.06)}.table-dock[data-v-15ef4f99]{min-width:0;margin-bottom:8px}.table-pagination[data-v-15ef4f99]{margin-top:8px;margin-bottom:0}.form-row[data-v-15ef4f99]{margin:12px 0}.form-label[data-v-15ef4f99]{display:block;margin-bottom:6px;font-size:14px;color:#606266}.block-btn[data-v-15ef4f99]{width:100%;margin:12px 0}.kpi-row[data-v-15ef4f99]{display:flex;flex-wrap:wrap;gap:12px;margin:20px 0 20px}.kpi-card[data-v-15ef4f99]{flex:1;min-width:140px;padding:16px;background:linear-gradient(180deg,#fafbfc,#f3f5f7);border-radius:10px;text-align:center;border:1px solid #e8eaed}.kpi-label[data-v-15ef4f99]{font-size:13px;color:#666;margin-bottom:8px}.kpi-value[data-v-15ef4f99]{font-size:22px;font-weight:700;color:#222}.filter-card[data-v-15ef4f99]{margin-bottom:20px;padding:16px 18px 8px;background:#fff;border:1px solid #e4e7ed;border-radius:8px}.filter-card.is-collapsed[data-v-15ef4f99]{padding-bottom:14px}.filter-card.is-collapsed .filter-card__head[data-v-15ef4f99]{border-bottom:none;margin-bottom:0;padding-bottom:0}.filter-card__head[data-v-15ef4f99]{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #ebeef5}.filter-card__head-main[data-v-15ef4f99]{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:1;min-width:0}.filter-card__title[data-v-15ef4f99]{font-size:15px;font-weight:600;color:#303133}.filter-card__hint[data-v-15ef4f99]{font-size:12px;color:#409eff}.filter-expand-btn[data-v-15ef4f99]{flex-shrink:0}.filter-card__body .filter-row[data-v-15ef4f99]:last-child{margin-bottom:4px}.filter-row[data-v-15ef4f99]{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:12px;align-items:center}.tp[data-v-15ef4f99]{border:none;cursor:pointer;font-size:13px;padding:8px 16px;border-radius:6px;transition:transform .12s ease,box-shadow .12s ease;font-family:inherit}.tp[data-v-15ef4f99]:hover{transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.12)}.tp--all[data-v-15ef4f99]{background:#fff;color:#606266;border:1px solid #dcdfe6}.tp--all.is-active[data-v-15ef4f99]{border-color:#409eff;color:#409eff;box-shadow:0 0 0 2px rgba(64,158,255,.2)}.tp--valid-light[data-v-15ef4f99]{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.tp--valid-light.is-active[data-v-15ef4f99]{box-shadow:0 0 0 2px rgba(46,125,50,.35)}.tp--danger-light[data-v-15ef4f99]{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}.tp--danger-light.is-active[data-v-15ef4f99]{box-shadow:0 0 0 2px rgba(198,40,40,.35)}.tp--warn-light[data-v-15ef4f99]{background:#fff3e0;color:#e65100;border:1px solid #ffe0b2}.tp--warn-light.is-active[data-v-15ef4f99]{box-shadow:0 0 0 2px rgba(230,81,0,.3)}.tp--solid[data-v-15ef4f99]{color:#fff;font-weight:500;border:1px solid transparent}.tp--solid.is-active[data-v-15ef4f99]{box-shadow:0 0 0 2px hsla(0,0%,100%,.85),0 0 0 4px rgba(64,158,255,.45)}.tp--blue[data-v-15ef4f99]{background:#1976d2}.tp--green[data-v-15ef4f99]{background:#43a047}.tp--orange[data-v-15ef4f99]{background:#f57c00}.tp--coral[data-v-15ef4f99]{background:#e57373}.tp--rate[data-v-15ef4f99]{background:#2e7d32;color:#fff;cursor:pointer;font-weight:500}.tp--rate.is-active[data-v-15ef4f99]{box-shadow:0 0 0 2px hsla(0,0%,100%,.9),0 0 0 4px rgba(46,125,50,.55)}.tp--rate[data-v-15ef4f99]:hover{box-shadow:0 2px 10px rgba(46,125,50,.45)}.tp--rate.tp--rate-readonly[data-v-15ef4f99]{cursor:default;display:inline-block}.tp--rate.tp--rate-readonly[data-v-15ef4f99]:hover{transform:none;box-shadow:none}.section-title[data-v-15ef4f99]{font-size:15px;font-weight:600;margin:20px 0 12px}.legend-card[data-v-15ef4f99]{margin:20px 0 12px}.legend-card__head[data-v-15ef4f99]{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.legend-card__title.section-title[data-v-15ef4f99]{margin:0}.legend-card.is-collapsed[data-v-15ef4f99]{margin-bottom:8px}.legend-expand-btn[data-v-15ef4f99]{flex-shrink:0}.legend-card .status-desc--legend[data-v-15ef4f99]{margin-top:12px}.status-desc[data-v-15ef4f99]{font-size:13px;color:#666;line-height:1.8}.status-desc--legend[data-v-15ef4f99]{background:#fafafa;border:1px solid #ebeef5;border-radius:8px;padding:14px 16px 10px}.legend-row[data-v-15ef4f99]{display:flex;align-items:flex-start;gap:12px;margin:12px 0;line-height:1.65}.legend-row--ip[data-v-15ef4f99]{align-items:center}.legend-text[data-v-15ef4f99]{flex:1;color:#606266;font-size:13px}.status-sample[data-v-15ef4f99]{display:inline-block;padding:4px 12px;border-radius:4px;font-size:12px;vertical-align:middle;flex-shrink:0;font-weight:500}.status-sample.status-valid[data-v-15ef4f99]{background:#e1f3d8;color:#529b2e;border:1px solid #b3e19d}.status-sample.status-feiguonei[data-v-15ef4f99]{background:#fde2e2;color:#c62828;border:1px solid #f8b4b4}.ip-sample[data-v-15ef4f99]{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-family:Consolas,Monaco,monospace;flex-shrink:0;min-width:124px;text-align:center;box-sizing:border-box}.ip-sample--segment[data-v-15ef4f99]{background:#fdf6ec;color:#e6a23c;border:1px solid #f5dab1}.ip-sample--mid[data-v-15ef4f99]{background:#ecf5ff;color:#409eff;border:1px solid #b3d8ff}.ip-sample--high[data-v-15ef4f99]{background:#fef0f0;color:#f56c6c;border:1px solid #fbc4c4}.tip[data-v-15ef4f99]{color:#909399;font-size:12px;margin-top:8px}.tip--footer[data-v-15ef4f99]{margin-top:14px;padding-top:10px;border-top:1px dashed #e4e7ed;line-height:1.7}.empty-tip[data-v-15ef4f99]{text-align:center;color:#999;padding:40px 0}.el-pagination[data-v-15ef4f99]{justify-content:flex-start;flex-wrap:wrap;row-gap:8px}.table-toolbar[data-v-15ef4f99]{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:12px}.table-toolbar .section-title[data-v-15ef4f99]{margin:0}.count-hint[data-v-15ef4f99]{font-size:12px;color:#606266;font-weight:400;margin-left:8px}.count-hint strong[data-v-15ef4f99]{color:#303133}.toolbar-actions[data-v-15ef4f99]{display:flex;align-items:center;gap:10px}.column-option[data-v-15ef4f99]{margin-bottom:6px}.visitor-table[data-v-15ef4f99],.visitor-table[data-v-15ef4f99] .el-table__body-wrapper{font-size:12px}.visitor-table[data-v-15ef4f99] .el-table .cell{padding:7px 4px;line-height:1.45;word-break:break-word}.visitor-table[data-v-15ef4f99] .el-table th>.cell{padding:8px 4px;line-height:1.35}.visitor-table[data-v-15ef4f99] .el-table th{font-size:12px}.visitor-table[data-v-15ef4f99] .el-table .el-tag--mini{padding:0 4px;height:20px;line-height:18px}.visitor-table[data-v-15ef4f99] .invalid-row{background:#fef0f0!important}.visitor-table[data-v-15ef4f99] .invalid-row .el-tag--danger{background:#f56c6c;color:#fff;border-color:#f56c6c}.ip-text.ip-normal[data-v-15ef4f99]{color:#67c23a}.ip-text.ip-segment[data-v-15ef4f99]{color:#e6a23c}.ip-text.ip-mid[data-v-15ef4f99]{color:#409eff;font-weight:500}.ip-text.ip-high[data-v-15ef4f99]{color:#f56c6c;font-weight:500}.status-desc p[data-v-15ef4f99]{margin:8px 0}.status-desc--legend .tip--footer[data-v-15ef4f99]{margin-bottom:0}.status-desc code[data-v-15ef4f99]{font-size:12px;background:#f4f4f5;padding:1px 6px;border-radius:3px}.last-msg-cell[data-v-15ef4f99]{display:block;max-width:120px;margin:0 auto;text-align:left;word-break:break-word;font-size:12px;line-height:1.45}.last-msg-cell--img[data-v-15ef4f99]{text-align:center;max-width:56px}.last-msg-thumb[data-v-15ef4f99]{width:48px;height:48px;border-radius:6px;border:1px solid #ebeef5;vertical-align:middle;cursor:pointer}.last-msg-thumb[data-v-15ef4f99] .el-image__inner{-o-object-fit:cover;object-fit:cover}.last-msg-img-fallback[data-v-15ef4f99]{font-size:11px;line-height:1.3;padding:4px 2px}.last-msg-img-fallback a[data-v-15ef4f99]{color:#409eff;word-break:break-all}