/* ============ 闲鱼监控 — 设计系统 ============ */
:root {
  --accent: #7c3aed;
  --accent-600: #6d28d9;
  --accent-700: #5b21b6;
  --accent-soft: #f1ecfd;
  --accent-soft-2: #ede9fe;
  --radius: 8px;
  --radius-sm: 6px;

  --bg: #f5f6f8;
  --panel: #ffffff;
  --ink: #1a1d24;
  --ink-2: #525866;
  --ink-3: #868d9b;
  --line: #e6e8ee;
  --line-2: #eef0f4;
  --up: #16a34a;
  --up-soft: #e8f6ec;
  --down: #dc2626;
  --down-soft: #fdecec;
  --sidebar: #14161d;
  --sidebar-2: #1c1f29;
  --sidebar-ink: #aab1c0;
  --sidebar-ink-2: #6b7280;

  --mono: "SF Mono", "JetBrains Mono", ui-monospace, "Roboto Mono", Menlo, Consolas, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Source Han Sans CN", "Noto Sans CJK SC", system-ui, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  font-size: 13px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
}
.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.tnum { font-variant-numeric: tabular-nums; }
button { font-family: inherit; cursor: pointer; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #cfd3db; border-radius: 6px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: #b6bbc6; }

/* ============ shell ============ */
.xy-app { display: flex; height: 100vh; overflow: hidden; }

/* sidebar */
/* 自动隐藏 · 覆盖式：默认移出视口不占布局，hover 左边缘或点 ☰ 浮出 */
.xy-side { position: fixed; left: 0; top: 0; bottom: 0; width: 224px; z-index: 60; background: var(--sidebar); color: var(--sidebar-ink); display: flex; flex-direction: column; overflow: hidden; transform: translateX(-100%); transition: transform .22s ease; box-shadow: 2px 0 18px rgba(0,0,0,.22); }
.xy-side.peek { transform: translateX(0); }
.xy-side-hotzone { position: fixed; left: 0; top: 0; bottom: 0; width: 10px; z-index: 55; }
.xy-brand { display: flex; align-items: center; gap: 9px; padding: 15px 16px 14px; }
.xy-brand-logo { width: 28px; height: 28px; border-radius: 7px; background: linear-gradient(135deg, var(--accent), #9f67f5); display: grid; place-items: center; font-size: 16px; }
.xy-brand b { color: #fff; font-size: 14.5px; letter-spacing: .3px; }
.xy-brand span { color: var(--sidebar-ink-2); font-size: 10.5px; display: block; margin-top: 1px; }
.xy-nav { padding: 4px 10px; }
.xy-nav-label { color: var(--sidebar-ink-2); font-size: 10.5px; letter-spacing: .8px; padding: 12px 8px 5px; text-transform: uppercase; }
.xy-nav-item { display: flex; align-items: center; gap: 10px; padding: 7px 10px; border-radius: 7px; color: var(--sidebar-ink); font-size: 13px; border: none; background: none; width: 100%; text-align: left; }
.xy-nav-item:hover { background: var(--sidebar-2); color: #e8eaf0; }
.xy-nav-item.on { background: var(--accent); color: #fff; }
.xy-nav-item.on .xy-nav-ico { opacity: 1; }
.xy-nav-ico { width: 16px; opacity: .7; flex: none; text-align: center; }
.xy-nav-count { margin-left: auto; font-size: 11px; color: var(--sidebar-ink-2); font-variant-numeric: tabular-nums; }
.xy-nav-item.on .xy-nav-count { color: rgba(255,255,255,.8); }
.xy-group-item { display: flex; align-items: center; gap: 9px; padding: 6px 10px; border-radius: 7px; width: 100%; border: none; background: none; color: var(--sidebar-ink); text-align: left; font-size: 12.5px; }
.xy-group-item:hover { background: var(--sidebar-2); color: #e8eaf0; }
.xy-group-item.on { background: var(--sidebar-2); color: #fff; }
.xy-group-dot { width: 8px; height: 8px; border-radius: 3px; flex: none; }
.xy-group-count { margin-left: auto; font-size: 11px; color: var(--sidebar-ink-2); font-variant-numeric: tabular-nums; }
.xy-side-foot { margin-top: auto; padding: 12px; border-top: 1px solid #232732; }
.xy-collect { display: flex; flex-direction: column; gap: 7px; }
.xy-collect-row { display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--sidebar-ink); }
.xy-live { width: 7px; height: 7px; border-radius: 50%; background: var(--up); box-shadow: 0 0 0 3px rgba(22,163,74,.18); animation: pulse 2s infinite; }
.xy-live.idle { background: #6b7280; box-shadow: none; animation: none; }
@keyframes pulse { 50% { box-shadow: 0 0 0 5px rgba(22,163,74,0); } }
.xy-collect-row small { margin-left: auto; color: var(--sidebar-ink-2); font-variant-numeric: tabular-nums; }

/* main */
.xy-main { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.xy-top { height: 52px; flex: none; background: var(--panel); border-bottom: 1px solid var(--line); display: flex; align-items: center; gap: 14px; padding: 0 18px; }
.xy-side-toggle { width: 30px; height: 30px; flex: none; border: 1px solid var(--line); border-radius: 8px; background: #fff; color: var(--ink-2); display: inline-flex; align-items: center; justify-content: center; font-size: 15px; line-height: 1; }
.xy-side-toggle:hover { border-color: #d2d6df; color: var(--ink); }
.xy-crumb { display: flex; align-items: center; gap: 7px; font-size: 13px; color: var(--ink-3); }
.xy-crumb b { color: var(--ink); font-weight: 600; }
.xy-crumb a { color: var(--ink-3); text-decoration: none; cursor: pointer; }
.xy-crumb a:hover { color: var(--accent); }
.xy-crumb .sep { color: #c7ccd6; }
.xy-search { margin-left: auto; position: relative; }
.xy-search input { width: 230px; height: 32px; border: 1px solid var(--line); border-radius: 8px; padding: 0 12px 0 30px; font-size: 12.5px; background: #fafbfc; outline: none; font-family: inherit; }
.xy-search input:focus { border-color: var(--accent); background: #fff; box-shadow: 0 0 0 3px var(--accent-soft); }
.xy-search .ic { position: absolute; left: 9px; top: 8px; color: var(--ink-3); font-size: 13px; }
.xy-top-btn { height: 32px; padding: 0 13px; border-radius: 8px; border: 1px solid var(--line); background: #fff; color: var(--ink-2); font-size: 12.5px; display: inline-flex; align-items: center; gap: 6px; }
.xy-top-btn:hover { border-color: #d2d6df; }
.xy-top-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.xy-top-btn.primary:hover { background: var(--accent-600); }
.xy-range { display: flex; align-items: center; gap: 8px; }
.xy-range-lbl { font-size: 11.5px; color: var(--ink-3); white-space: nowrap; }
.xy-range .xy-seg button { padding: 4px 10px; font-size: 12px; }

.xy-body { flex: 1; overflow-y: auto; padding: 18px; }
.xy-page-head { display: flex; align-items: flex-end; gap: 14px; margin-bottom: 14px; }
.xy-page-head h1 { font-size: 19px; margin: 0; font-weight: 650; letter-spacing: .2px; }
.xy-page-head .sub { color: var(--ink-3); font-size: 12.5px; }
.xy-page-head .spacer { flex: 1; }

/* ============ toolbar (filters/sort/search) ============ */
.xy-toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.xy-seg { display: inline-flex; background: #eceef2; border-radius: 8px; padding: 2px; }
.xy-seg button { border: none; background: none; padding: 5px 11px; border-radius: 6px; font-size: 12.5px; color: var(--ink-2); }
.xy-seg button.on { background: #fff; color: var(--ink); box-shadow: 0 1px 2px rgba(0,0,0,.06); font-weight: 550; }
.xy-select { height: 31px; border: 1px solid var(--line); border-radius: 8px; background: #fff; padding: 0 28px 0 11px; font-size: 12.5px; color: var(--ink-2); font-family: inherit; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23868d9b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; }
.xy-chip-filter { height: 31px; padding: 0 11px; border: 1px solid var(--line); border-radius: 8px; background: #fff; font-size: 12.5px; color: var(--ink-2); display: inline-flex; align-items: center; gap: 6px; }
.xy-chip-filter.on { border-color: var(--accent); background: var(--accent-soft); color: var(--accent-700); }
.xy-tool-spacer { flex: 1; }
.xy-count-note { color: var(--ink-3); font-size: 12px; }
.xy-viewswitch { display: inline-flex; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; }
.xy-viewswitch button { border: none; background: #fff; padding: 0 11px; height: 31px; font-size: 12px; color: var(--ink-2); display: inline-flex; align-items: center; gap: 5px; border-left: 1px solid var(--line); }
.xy-viewswitch button:first-child { border-left: none; }
.xy-viewswitch button .ic { font-size: 13px; line-height: 1; }
.xy-viewswitch button.on { background: var(--accent); color: #fff; }
.xy-viewswitch button:not(.on):hover { background: #f5f6f8; }

/* ============ cards / panels ============ */
.xy-panel { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); }
.xy-panel-head { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--line-2); overflow: hidden; }
.xy-panel-head h3 { margin: 0; font-size: 13.5px; font-weight: 620; white-space: nowrap; }
.xy-panel-head .hint { color: var(--ink-3); font-size: 11.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
.xy-panel-body { padding: 14px; }
.xy-grid { display: grid; gap: 14px; }

/* ============ table ============ */
.xy-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
/* 深色表头(显眼) + 列竖分隔线(整齐) */
.xy-table th { text-align: left; font-weight: 650; color: #fff; font-size: 13px; padding: 12px; white-space: nowrap; background: #4a5266; position: sticky; top: 0; z-index: 1; }
.xy-table th:not(:first-child) { border-left: 1px solid rgba(255,255,255,.1); }
.xy-table td:not(:first-child) { border-left: 1px solid var(--line); }
.xy-table th.num, .xy-table td.num { text-align: center; font-variant-numeric: tabular-nums; }
/* 核心指标色身份：表头色点 + 整列极淡专属底色，一眼识别哪类数据(配色与详情页一致) */
.xy-table th.col-sold::before, .xy-table th.col-review::before, .xy-table th.col-followers::before,
.xy-table th.col-price::before, .xy-table th.col-want::before, .xy-table th.col-view::before,
.xy-table th.col-viewtotal::before {
  content: ''; display: inline-block; width: 7px; height: 7px; border-radius: 50%; margin-right: 6px; vertical-align: middle;
}
.xy-table th.col-sold::before { background: #16a34a; }
.xy-table th.col-review::before { background: #0ea5e9; }
.xy-table th.col-followers::before { background: #f59e0b; }
.xy-table th.col-price::before { background: #f59e0b; }
.xy-table th.col-want::before { background: #7c3aed; }
.xy-table th.col-view::before { background: #0ea5e9; }
.xy-table td.col-sold { background: rgba(22,163,74,.05); }
.xy-table td.col-review { background: rgba(14,165,233,.055); }
.xy-table td.col-followers { background: rgba(245,158,11,.06); }
.xy-table td.col-price { background: rgba(245,158,11,.06); }
.xy-table td.col-want { background: rgba(124,58,237,.055); }
.xy-table td.col-view { background: rgba(14,165,233,.055); }
.xy-table th.col-viewtotal::before { background: #ec4899; }
.xy-table td.col-viewtotal { background: rgba(236,72,153,.05); }
.xy-table td { padding: 12px; border-bottom: 1px solid var(--line-2); vertical-align: middle; white-space: nowrap; }
.xy-table tbody tr:hover { background: #f9fafc; }
.xy-table tbody tr.click { cursor: pointer; }
.xy-table tbody tr:last-child td { border-bottom: none; }
.xy-th-sort { cursor: pointer; user-select: none; }
.xy-th-sort:hover { color: #fff; opacity: .9; }
.xy-th-sort .arr { color: #c4b5fd; margin-left: 3px; }

/* seller row card variant */
.xy-srow-name { display: flex; align-items: center; gap: 10px; }
/* 本轮新增 · 店铺汇总 cluster */
/* 「近30天新增」列不再特殊染色/染字：表头与其它列统一颜色，靠列标题文字本身区分，保持整排表头整齐 */
.xy-newcluster { display: flex; flex-direction: column; gap: 2px; font-size: 11px; }
.xy-newcluster span { display: flex; align-items: center; gap: 7px; }
.xy-newcluster i { color: var(--ink-3); font-style: normal; width: 28px; display: inline-block; }
.xy-newrow { display: flex; align-items: center; gap: 10px; margin-top: 9px; padding: 7px 10px; background: var(--accent-soft); border-radius: 7px; font-size: 11px; flex-wrap: wrap; }
.xy-newrow .lbl { color: var(--accent-700); font-weight: 600; }
.xy-newrow span { display: flex; align-items: center; gap: 4px; }
.xy-newrow i { color: var(--ink-3); font-style: normal; }
.xy-srow-name .nm { font-weight: 600; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.xy-srow-name .meta { color: var(--ink-3); font-size: 11px; }
.xy-bignum { font-family: var(--mono); font-variant-numeric: tabular-nums; font-weight: 650; font-size: 14.5px; color: var(--ink); }
.xy-cell-stack { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.xy-cell-stack .lbl { font-size: 10px; color: var(--ink-3); }

/* card layout for sellers */
.xy-scards { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 12px; }
.xy-pcards { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 12px; }
.xy-scard { position: relative; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 13px; cursor: pointer; transition: border-color .12s, box-shadow .12s; }
.xy-scard:hover { border-color: #d6d2ef; box-shadow: 0 4px 16px rgba(80,60,160,.08); }
.xy-scard-top { display: flex; gap: 11px; align-items: flex-start; }
.xy-scard-top .nm { font-weight: 650; font-size: 14px; }
.xy-scard-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 11px; }
.xy-scard-stat { background: #fafbfc; border: 1px solid var(--line-2); border-radius: 7px; padding: 7px 9px; }
.xy-scard-stat .v { font-family: var(--mono); font-weight: 650; font-size: 15px; }
.xy-scard-stat .k { color: var(--ink-3); font-size: 10.5px; margin-top: 1px; }

/* ============ stat blocks (detail) ============ */
.xy-core { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.xy-core.five { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1100px) { .xy-core.five { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .xy-core.five { grid-template-columns: repeat(2, 1fr); } }
.xy-core.five .xy-corecard .v { font-size: 22px; }

/* KPI grid (行业总览) */
.xy-kpi { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; margin-bottom: 16px; }
@media (max-width: 1300px) { .xy-kpi { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .xy-kpi { grid-template-columns: repeat(2, 1fr); } }

/* 排行榜 (行业总览) */
.xy-rank { padding: 2px 0; }
.xy-rank-row { display: flex; align-items: center; gap: 10px; padding: 8px 14px; border-bottom: 1px solid var(--line-2); }
.xy-rank-row:last-child { border-bottom: none; }
.xy-rank-row.click { cursor: pointer; }
.xy-rank-row:hover { background: #f9fafc; }
.xy-rank-no { width: 20px; height: 20px; flex: none; display: grid; place-items: center; font-size: 11px; font-weight: 700; color: var(--ink-3); font-variant-numeric: tabular-nums; }
.xy-rank-no.top { background: var(--accent); color: #fff; border-radius: 6px; }
.xy-rank-id { min-width: 0; width: 150px; flex: none; }
.xy-rank-id .nm { display: block; font-weight: 600; font-size: 12.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.xy-rank-id .sub { display: block; color: var(--ink-3); font-size: 10.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.xy-rank-bar { flex: 1; height: 6px; background: #eef0f4; border-radius: 3px; overflow: hidden; min-width: 24px; }
.xy-rank-bar i { display: block; height: 100%; border-radius: 3px; }
.xy-rank-val { flex: none; width: 66px; text-align: right; }
.xy-corecard { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px; }
.xy-corecard .k { color: var(--ink-3); font-size: 12px; display: flex; align-items: center; gap: 6px; }
.xy-corecard .v { font-family: var(--mono); font-weight: 680; font-size: 26px; letter-spacing: -.5px; margin: 4px 0 2px; }
.xy-corecard .foot { display: flex; align-items: center; gap: 8px; }

/* archive field list */
.xy-fields { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0 28px; }
.xy-fields.one { grid-template-columns: 1fr; }
.xy-field { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 2px; border-bottom: 1px solid var(--line-2); font-size: 13px; }
.xy-field .k { color: var(--ink-3); font-size: 12px; flex: none; letter-spacing: .2px; }
.xy-field .v { color: var(--ink); font-weight: 550; min-width: 0; text-align: right; }
/* 画像档案 — 重点指标卡片 + 认证徽章 */
.xy-profile-kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 16px; }
@media (max-width: 760px) { .xy-profile-kpis { grid-template-columns: repeat(2, 1fr); } }
.xy-pk { display: flex; align-items: center; gap: 10px; background: linear-gradient(180deg,#fcfcfe,#f7f8fb); border: 1px solid var(--line-2); border-radius: 11px; padding: 12px; }
.xy-pk .ic { font-size: 18px; line-height: 1; flex: none; }
.xy-pk .bd { min-width: 0; }
.xy-pk .v { font-weight: 650; font-size: 15px; color: var(--ink); white-space: nowrap; }
.xy-pk .k { font-size: 11px; color: var(--ink-3); margin-top: 3px; }
.xy-profile-badges { display: flex; flex-wrap: wrap; gap: 7px; margin: 14px 0; }
.xy-vbadge { display: inline-flex; align-items: center; gap: 4px; font-size: 11.5px; font-weight: 600; padding: 4px 11px; border-radius: 20px; background: #eaf2ff; color: #1d6fd0; }
.xy-vbadge.green { background: var(--up-soft); color: #15803d; }

/* ============ deltas ============ */
.xy-delta { display: inline-flex; align-items: center; gap: 1px; font-variant-numeric: tabular-nums; font-weight: 500; font-size: 11px; }
.xy-delta-up { color: var(--up); }
.xy-delta-down { color: var(--down); }
.xy-delta-zero { color: #c4c8d0; font-weight: 400; }
.xy-delta-mute { color: var(--ink-3); }
.xy-delta-lg { font-size: 13px; }
.xy-delta-pill { padding: 2px 7px; border-radius: 20px; }
.xy-delta-up.xy-delta-pill { background: var(--up-soft); }
.xy-delta-down.xy-delta-pill { background: var(--down-soft); }

/* daily list (逐日新增/总量) */
.xy-daily { font-size: 12.5px; }
.xy-daily-row { display: grid; grid-template-columns: 78px 1fr auto; align-items: center; gap: 12px; padding: 7px 12px; border-bottom: 1px solid var(--line-2); }
.xy-daily-row:hover { background: #f9fafc; }
.xy-daily-row .d { color: var(--ink-2); font-variant-numeric: tabular-nums; }
.xy-daily-row .bar { height: 6px; border-radius: 3px; background: var(--accent-soft-2); position: relative; overflow: hidden; }
.xy-daily-row .bar i { position: absolute; left: 0; top: 0; bottom: 0; background: var(--accent); border-radius: 3px; }
.xy-daily-row .tot { font-family: var(--mono); font-variant-numeric: tabular-nums; font-weight: 600; min-width: 56px; text-align: right; }
.xy-daily-head { display: grid; grid-template-columns: 78px 1fr auto; gap: 12px; padding: 8px 12px; color: var(--ink-3); font-size: 11px; border-bottom: 1px solid var(--line); background: #fafbfc; }

/* ============ misc atoms ============ */
.xy-avatar { border-radius: 9px; color: #fff; display: grid; place-items: center; font-weight: 600; flex: none; overflow: hidden; }
.xy-avatar-img { object-fit: cover; background: #eef0f4; }
.xy-pill { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; padding: 2px 8px; border-radius: 20px; background: #f0f1f4; color: var(--ink-2); font-weight: 500; white-space: nowrap; }
.xy-pill-green { background: var(--up-soft); color: #15803d; }
.xy-pill-red { background: var(--down-soft); color: #b91c1c; }
.xy-pill-violet { background: var(--accent-soft); color: var(--accent-700); }
.xy-pill-amber { background: #fdf0d5; color: #b45309; }
.xy-pill-blue { background: #e6f1fd; color: #1d6fd0; }
.xy-pill-gray { background: #eef0f4; color: var(--ink-2); }
.xy-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
/* 列内状态/分组标签：点+文字，替代整列重复的彩色胶囊，降低重复噪音 */
.xy-tagline { display: inline-flex; align-items: center; gap: 6px; color: var(--ink-2); font-size: 12px; white-space: nowrap; }
.xy-tagline .xy-dot { flex: none; }
.xy-credit { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; color: var(--ink-2); }
.xy-credit-bars { display: inline-flex; gap: 1.5px; }
.xy-credit-bars i { width: 3px; height: 10px; border-radius: 1px; background: #dfe2e8; }
.xy-credit-bars i.on { background: var(--accent); }

.xy-spark { display: block; }
.xy-bars { width: 100%; height: auto; display: block; }
.xy-tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }
.xy-tag-cloud .t { background: var(--accent-soft); color: var(--accent-700); border-radius: 6px; padding: 3px 8px; font-size: 11.5px; }
.xy-tag-cloud .t b { font-weight: 700; }
.xy-tag-cloud .t .n { color: var(--accent); font-variant-numeric: tabular-nums; margin-left: 3px; opacity: .8; }

/* chart */
.xy-chart-wrap { position: relative; }
.xy-linechart { width: 100%; height: auto; display: block; overflow: visible; }
.xy-grid { stroke: var(--line-2); stroke-width: 1; }
.xy-cursor { stroke: #c9b8f0; stroke-width: 1; stroke-dasharray: 3 3; }
.xy-axis-y { fill: var(--ink-3); font-size: 9.5px; text-anchor: end; font-family: var(--mono); }
.xy-axis-x { fill: var(--ink-3); font-size: 9.5px; text-anchor: middle; font-family: var(--mono); }
.xy-chart-tip { position: absolute; top: 6px; transform: translateX(-50%); background: #1f2430; color: #fff; border-radius: 7px; padding: 7px 9px; font-size: 11px; pointer-events: none; white-space: nowrap; z-index: 5; box-shadow: 0 6px 18px rgba(0,0,0,.2); }
.xy-tip-date { color: #aeb6c6; font-size: 10px; margin-bottom: 3px; font-family: var(--mono); }
.xy-tip-row { display: flex; align-items: center; gap: 6px; }
.xy-tip-row i { width: 8px; height: 8px; border-radius: 2px; }
.xy-tip-row b { margin-left: auto; font-family: var(--mono); }

/* thumbnail */
.xy-thumb { position: relative; border-radius: 7px; overflow: hidden; border: 1px solid var(--line); flex: none; }
.xy-thumb svg { display: block; }
.xy-thumb-img { display: block; width: 100%; height: 100%; object-fit: cover; background: #eef0f4; }
.xy-thumb-tag { position: absolute; inset: 0; display: grid; place-items: center; font-size: 9px; color: #9aa1ad; font-family: var(--mono); text-align: center; padding: 2px; }
.xy-thumb-off { position: absolute; left: 0; bottom: 0; right: 0; background: rgba(20,22,29,.72); color: #fff; font-size: 8.5px; text-align: center; padding: 1px; }

/* tabs */
.xy-tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--line); }
.xy-tab { border: none; background: none; padding: 9px 14px; font-size: 13px; color: var(--ink-2); position: relative; font-weight: 500; }
.xy-tab.on { color: var(--accent); }
.xy-tab.on::after { content: ''; position: absolute; left: 10px; right: 10px; bottom: -1px; height: 2px; background: var(--accent); border-radius: 2px; }
.xy-tab-count { margin-left: 5px; font-size: 11px; background: #eef0f4; color: var(--ink-3); border-radius: 10px; padding: 0 6px; font-variant-numeric: tabular-nums; }
.xy-tab.on .xy-tab-count { background: var(--accent-soft); color: var(--accent-700); }

/* product title clamp */
.xy-ptitle { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; line-height: 1.35; max-width: 360px; white-space: normal; }
/* 商品库：标题列优先给宽(最重要)，所属卖家列收窄、名字省略(hover 看全名) */
.xy-table td.col-title { min-width: 250px; }
.xy-table td.col-seller .snm { display: inline-block; max-width: 76px; overflow: hidden; text-overflow: ellipsis; vertical-align: middle; }
.xy-desc-fold { color: var(--ink-2); font-size: 12.5px; line-height: 1.6; }
.xy-desc-toggle { color: var(--accent); font-size: 12px; background: none; border: none; padding: 4px 0 0; }

.xy-back { display: inline-flex; align-items: center; gap: 5px; color: var(--ink-2); font-size: 12.5px; background: none; border: none; padding: 4px 0; }
.xy-back:hover { color: var(--accent); }

.xy-link { color: var(--accent); text-decoration: none; }
.xy-link:hover { text-decoration: underline; }
.xy-muted { color: var(--ink-3); }
.xy-empty { text-align: center; color: var(--ink-3); padding: 40px; font-size: 13px; }

/* ============ 标签 + 备注 ============ */
.xy-tagcell { display: inline-flex; flex-wrap: nowrap; align-items: center; gap: 4px; cursor: pointer; max-width: 100%; }
.xy-tagchips { display: inline-flex; flex-wrap: nowrap; align-items: center; gap: 4px; white-space: nowrap; }
.xy-tagpill { display: inline-flex; align-items: center; font-size: 10px; padding: 1px 6px; border-radius: 5px; font-weight: 600; line-height: 1.6; white-space: nowrap; }
.xy-note-dot { font-size: 10px; line-height: 1; filter: grayscale(.2); }
.xy-tag-add { font-size: 10.5px; color: var(--ink-3); border: 1px dashed var(--line); border-radius: 5px; padding: 1px 7px; line-height: 1.6; }
.xy-tagcell:hover .xy-tag-add { color: var(--accent); border-color: var(--accent); }
.xy-tag-edit { font-size: 10px; color: var(--ink-3); opacity: 0; transition: opacity .12s; }
.xy-tagcell:hover .xy-tag-edit { opacity: 1; }

.xy-tag-overlay { position: fixed; inset: 0; z-index: 55; }
.xy-tag-pop { position: fixed; z-index: 60; width: 264px; background: #fff; border: 1px solid var(--line); border-radius: 11px; box-shadow: 0 14px 40px rgba(20,22,29,.2); padding: 13px; }
.xy-tag-pop h5 { margin: 0 0 8px; font-size: 11px; color: var(--ink-3); font-weight: 600; letter-spacing: .3px; }
.xy-tag-opts { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 13px; }
.xy-tag-opt { font-size: 11.5px; padding: 3px 9px; border-radius: 7px; border: 1px solid var(--line); background: #fff; color: var(--ink-2); display: inline-flex; align-items: center; gap: 5px; }
.xy-tag-opt i { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.xy-tag-opt:hover { border-color: #d2d6df; }
.xy-tag-note { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 7px 9px; font-size: 12px; font-family: inherit; line-height: 1.5; resize: vertical; min-height: 52px; outline: none; color: var(--ink); }
.xy-tag-note:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.xy-tag-pop-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 10px; }
.xy-tag-done { font-size: 12px; padding: 4px 14px; border-radius: 7px; border: none; background: var(--accent); color: #fff; font-weight: 550; }
.xy-tag-done:hover { background: var(--accent-600); }

/* two-up grid helpers */
.xy-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.xy-2col-wide { display: grid; grid-template-columns: 1.4fr 1fr; gap: 14px; }
@media (max-width: 1100px) { .xy-2col, .xy-2col-wide { grid-template-columns: 1fr; } }

/* ============ 任务管理 ============ */
.xy-kpi.tasks { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1100px) { .xy-kpi.tasks { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .xy-kpi.tasks { grid-template-columns: repeat(2, 1fr); } }

/* custom checkbox */
.xy-check { width: 16px; height: 16px; border: 1.5px solid #cfd3db; border-radius: 5px; display: inline-grid; place-items: center; flex: none; background: #fff; color: #fff; font-size: 10px; line-height: 1; transition: background .12s, border-color .12s; }
.xy-check.on { background: var(--accent); border-color: var(--accent); }

/* step label */
.xy-step { display: flex; align-items: center; gap: 9px; margin: 0 0 11px; }
.xy-step-no { width: 19px; height: 19px; border-radius: 50%; background: var(--accent); color: #fff; font-size: 11px; font-weight: 700; display: grid; place-items: center; flex: none; }
.xy-step b { font-size: 13px; font-weight: 620; }
.xy-step .hint { color: var(--ink-3); font-size: 11.5px; }

/* source mode grid */
.xy-mode-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (max-width: 1100px) { .xy-mode-grid { grid-template-columns: repeat(2, 1fr); } }
.xy-mode-card { border: 1px solid var(--line); border-radius: var(--radius); padding: 12px; cursor: pointer; display: flex; gap: 11px; align-items: flex-start; background: #fff; transition: border-color .12s, background .12s; position: relative; text-align: left; }
.xy-mode-card:hover { border-color: #d2d6df; }
.xy-mode-card.on { border-color: var(--accent); background: var(--accent-soft); box-shadow: inset 0 0 0 1px var(--accent); }
.xy-mode-ico { width: 34px; height: 34px; border-radius: 9px; background: #f0f1f4; display: grid; place-items: center; font-size: 17px; flex: none; color: var(--ink-2); }
.xy-mode-card.on .xy-mode-ico { background: var(--accent); color: #fff; }
.xy-mode-card h4 { margin: 0 0 3px; font-size: 13px; font-weight: 620; color: var(--ink); }
.xy-mode-card p { margin: 0; font-size: 11px; color: var(--ink-3); line-height: 1.45; }
.xy-mode-tick { position: absolute; top: 9px; right: 10px; width: 16px; height: 16px; border-radius: 50%; background: var(--accent); color: #fff; font-size: 10px; display: none; place-items: center; }
.xy-mode-card.on .xy-mode-tick { display: grid; }

/* config sub-region */
.xy-cfg { margin-top: 14px; border: 1px solid var(--line-2); border-radius: var(--radius); background: #fafbfc; padding: 14px; }

/* checklist */
.xy-cl-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 9px; }
.xy-cl-bar .sel { font-size: 11.5px; color: var(--ink-3); }
.xy-cl-mini { font-size: 11.5px; color: var(--accent); background: none; border: none; padding: 2px 4px; }
.xy-cl-mini:hover { text-decoration: underline; }
.xy-checklist { border: 1px solid var(--line); border-radius: 8px; background: #fff; max-height: 296px; overflow-y: auto; }
.xy-cl-row { display: flex; align-items: center; gap: 11px; padding: 8px 12px; border-bottom: 1px solid var(--line-2); cursor: pointer; }
.xy-cl-row:last-child { border-bottom: none; }
.xy-cl-row:hover { background: #f9fafc; }
.xy-cl-row .nm { font-weight: 550; font-size: 12.5px; }
.xy-cl-row .meta { color: var(--ink-3); font-size: 11px; }
.xy-cl-grow { flex: 1; min-width: 0; }

/* big-statement (全部卖家) */
.xy-allstate { display: flex; align-items: center; gap: 16px; padding: 6px 4px 14px; }
.xy-allstate .big { font-family: var(--mono); font-size: 40px; font-weight: 700; color: var(--accent-700); letter-spacing: -1px; line-height: 1; }
.xy-allstate .lbl { font-size: 12.5px; color: var(--ink-2); }
.xy-allchips { display: flex; flex-wrap: wrap; gap: 7px; }

/* link parser */
.xy-linkgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 980px) { .xy-linkgrid { grid-template-columns: 1fr; } }
.xy-linkta { width: 100%; min-height: 232px; border: 1px solid var(--line); border-radius: 8px; padding: 11px 12px; font-family: var(--mono); font-size: 12px; line-height: 1.75; resize: vertical; outline: none; color: var(--ink); background: #fff; }
.xy-linkta:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.xy-parse { border: 1px solid var(--line); border-radius: 8px; background: #fff; min-height: 232px; max-height: 300px; overflow-y: auto; }
.xy-parse-head { display: flex; align-items: center; justify-content: space-between; padding: 8px 11px; border-bottom: 1px solid var(--line); background: #fafbfc; font-size: 11px; color: var(--ink-3); position: sticky; top: 0; }
.xy-parse-row { display: flex; align-items: center; gap: 9px; padding: 8px 11px; border-bottom: 1px solid var(--line-2); font-size: 11.5px; }
.xy-parse-row:last-child { border-bottom: none; }
.xy-parse-row .url { font-family: var(--mono); color: var(--ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; min-width: 0; }
.xy-parse-row.bad .url { color: var(--down); }
.xy-parse-empty { padding: 30px 12px; text-align: center; color: var(--ink-3); font-size: 12px; }

/* tag picker */
.xy-tagpick-grp { margin-bottom: 12px; }
.xy-tagpick-grp:last-child { margin-bottom: 0; }
.xy-tagpick-grp h5 { margin: 0 0 8px; font-size: 11px; color: var(--ink-3); font-weight: 600; letter-spacing: .3px; }
.xy-tagpick { display: flex; flex-wrap: wrap; gap: 7px; }
.xy-tagpick .opt { font-size: 12px; padding: 5px 11px; border-radius: 8px; border: 1px solid var(--line); background: #fff; color: var(--ink-2); display: inline-flex; align-items: center; gap: 6px; }
.xy-tagpick .opt i { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.xy-tagpick .opt .c { font-variant-numeric: tabular-nums; color: var(--ink-3); font-size: 11px; }
.xy-tagpick .opt:hover { border-color: #d2d6df; }

/* footer / sync bar */
.xy-task-foot { display: flex; align-items: center; gap: 12px; margin-top: 15px; padding-top: 15px; border-top: 1px solid var(--line); flex-wrap: wrap; }
.xy-task-foot .lbl { font-size: 11.5px; color: var(--ink-3); }
.xy-task-foot .spacer { flex: 1; }
.xy-runseg .xy-seg button { padding: 5px 12px; }
.xy-dev-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--up); display: inline-block; box-shadow: 0 0 0 3px rgba(22,163,74,.16); }
.xy-dev-dot.off { background: #c2c7d0; box-shadow: none; }
.xy-preview { font-size: 13px; color: var(--ink-2); white-space: nowrap; }
.xy-preview b { color: var(--accent-700); font-family: var(--mono); font-size: 15px; }
.xy-sync-btn { height: 36px; padding: 0 18px; border-radius: 9px; border: none; background: var(--accent); color: #fff; font-size: 13px; font-weight: 600; display: inline-flex; align-items: center; gap: 7px; }
.xy-sync-btn:hover { background: var(--accent-600); }
.xy-sync-btn:disabled { background: #d6d8de; cursor: not-allowed; }
.xy-chk-inline { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--ink-2); cursor: pointer; }

/* progress */
.xy-progress { width: 116px; height: 6px; background: #eef0f4; border-radius: 3px; overflow: hidden; }
.xy-progress i { display: block; height: 100%; background: var(--accent); border-radius: 3px; transition: width .5s ease; }
.xy-progress.done i { background: var(--up); }
.xy-progress.fail i { background: var(--down); }
.xy-prog-wrap { display: flex; align-items: center; gap: 9px; }
.xy-prog-wrap .pct { font-family: var(--mono); font-size: 11px; color: var(--ink-2); min-width: 30px; text-align: right; }

/* queue row meta + actions */
.xy-q-name { display: flex; flex-direction: column; gap: 3px; }
.xy-q-name .t { font-weight: 600; font-size: 12.5px; }
.xy-q-src { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; }
.xy-q-act { display: inline-flex; gap: 4px; }
.xy-q-act button { border: 1px solid var(--line); background: #fff; color: var(--ink-2); border-radius: 6px; padding: 3px 9px; font-size: 11.5px; }
.xy-q-act button:hover { border-color: #d2d6df; color: var(--ink); }
.xy-q-act button.danger:hover { border-color: var(--down); color: var(--down); }
.xy-running-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft-2); animation: pulse-v 1.4s infinite; display: inline-block; }
@keyframes pulse-v { 50% { box-shadow: 0 0 0 6px rgba(124,58,237,0); } }

/* batch management */
.xy-batchbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0 12px;
  padding: 9px 12px;
  border: 1px solid var(--accent-soft-2);
  border-radius: 8px;
  background: #fbfaff;
  color: var(--ink-2);
  font-size: 12px;
}
.xy-batchbar b { color: var(--accent-700); font-family: var(--mono); }
.xy-batch-check,
.xy-batch-danger {
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  color: var(--ink-2);
  padding: 5px 10px;
  font-size: 12px;
  cursor: pointer;
}
.xy-batch-check:hover { border-color: var(--accent); color: var(--accent-700); }
.xy-batch-danger { margin-left: auto; border-color: #fecaca; color: var(--down); font-weight: 600; }
.xy-batch-danger:hover { background: #fef2f2; }
.xy-batch-check:disabled,
.xy-batch-danger:disabled { opacity: .45; cursor: not-allowed; }
.xy-card-check {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
}
.xy-scard.is-selected {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.xy-table input[type="checkbox"],
.xy-scard input[type="checkbox"],
.xy-batchbar input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--accent);
}

/* ============ 详情抽屉(右侧覆盖式) ============ */
.xy-drawer-root { position: fixed; inset: 0; z-index: 70; pointer-events: none; }
.xy-drawer-root.open { pointer-events: auto; }
.xy-drawer-mask { position: absolute; inset: 0; background: rgba(20,22,29,0); transition: background .26s ease; }
.xy-drawer-root.open .xy-drawer-mask { background: rgba(20,22,29,.38); }
.xy-drawer { position: absolute; top: 0; right: 0; bottom: 0; width: min(60vw, 1200px); background: var(--bg); box-shadow: -10px 0 34px rgba(0,0,0,.22); display: flex; flex-direction: column; transform: translateX(100%); transition: transform .28s cubic-bezier(.4,0,.2,1); }
@media (max-width: 768px) { .xy-drawer { width: 94vw; } }   /* 手机太窄，60vw 没法看，回退到接近全屏 */
.xy-drawer-root.open .xy-drawer { transform: translateX(0); }
.xy-drawer-head { flex: none; height: 52px; display: flex; align-items: center; gap: 12px; padding: 0 16px; background: var(--panel); border-bottom: 1px solid var(--line); }
.xy-drawer-title { font-weight: 650; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; min-width: 0; }
.xy-drawer-back { border: 1px solid var(--line); background: #fff; border-radius: 7px; padding: 5px 11px; font-size: 12.5px; color: var(--ink-2); flex: none; }
.xy-drawer-back:hover { border-color: #d2d6df; color: var(--ink); }
.xy-drawer-close { border: none; background: none; font-size: 16px; color: var(--ink-3); width: 30px; height: 30px; border-radius: 7px; flex: none; }
.xy-drawer-close:hover { background: var(--line-2); color: var(--ink); }
.xy-drawer-body { flex: 1; overflow-y: auto; padding: 18px; }
/* 抽屉是窄容器(~888px)，但详情组件响应式断点基于视口；大视口下打开抽屉时按容器强制降级，避免多列被压扁 */
.xy-drawer-body .xy-core.five { grid-template-columns: repeat(3, 1fr); }
.xy-drawer-body .xy-2col,
.xy-drawer-body .xy-2col-wide { grid-template-columns: 1fr; }
/* 抽屉=60vw，视口<1200 时抽屉<720px，核心数降到 2 列防挤 */
@media (max-width: 1200px) { .xy-drawer-body .xy-core.five { grid-template-columns: repeat(2, 1fr); } }
