/* 默认 = 白天模式（浅色）。深色见 [data-theme="dark"]。 */
:root {
  --bg: #f7f8fa;
  --panel: #ffffff;
  --panel-2: #eef1f6;
  --border: #d8dde6;
  --text: #1c2330;
  --muted: #6b7280;
  --accent: #2962ff;
  --green: #119e8e;
  --red: #e23b38;
  --amber: #c47f00;
  --topbar-bg: #ffffff;
  --today-hl: #fff1a8;
  --today-fg: #5a4a00;
}
:root[data-theme="dark"] {
  --bg: #0b0e14;
  --panel: #131722;
  --panel-2: #1b2230;
  --border: #262d3d;
  --text: #d1d4dc;
  --muted: #787b86;
  --accent: #2962ff;
  --green: #26a69a;
  --red: #ef5350;
  --amber: #f0a000;
  --topbar-bg: #0d1117;
  --today-hl: #6b5a00;
  --today-fg: #ffe999;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", Roboto, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.55;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
.muted { color: var(--muted); font-weight: 400; font-size: 12px; }

.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 18px; background: var(--topbar-bg); border-bottom: 1px solid var(--border);
}
.brand { font-weight: 700; font-size: 16px; display: flex; align-items: center; gap: 9px; }
.brand .logo { flex: 0 0 auto; height: 28px; width: 28px; border-radius: 6px; object-fit: contain; display: block; }
.nav a { margin-left: 16px; color: var(--muted); font-size: 13px; }
.nav a:hover { color: var(--text); text-decoration: none; }

.ticker-tape { border-bottom: 1px solid var(--border); background: var(--panel); min-height: 46px; }

main { max-width: 1600px; margin: 0 auto; padding: 18px; }
.board { margin-bottom: 34px; scroll-margin-top: 64px; }
.board-title {
  font-size: 17px; margin: 0 0 14px; display: flex; align-items: center; gap: 12px;
  border-left: 3px solid var(--accent); padding-left: 10px;
}
.board-title .hint { font-size: 12px; color: var(--muted); font-weight: 400; }
.board-title .updated {
  margin-left: auto; font-size: 11px; color: var(--muted);
  border: 1px solid var(--border); border-radius: 10px; padding: 2px 9px;
}
.board-title .updated.fresh { color: var(--green); border-color: var(--green); }
.board-title .updated.stale { color: var(--amber); border-color: var(--amber); }

/* 板块1 右侧控件组 */
.board-controls { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.edit-btn {
  background: var(--panel); color: var(--text); border: 1px solid var(--border);
  border-radius: 6px; padding: 4px 12px; font-size: 12px; cursor: pointer; font-family: inherit;
}
.edit-btn:hover { border-color: var(--accent); color: #fff; }

/* 板块1 周期选择器 */
.interval-picker { display: inline-flex; gap: 4px; }
.iv-btn {
  background: var(--panel); color: var(--muted); border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 10px; font-size: 12px; cursor: pointer;
  font-family: inherit; transition: all .12s;
}
.iv-btn:hover { color: var(--text); border-color: var(--muted); }
.iv-btn.active { color: #fff; background: var(--accent); border-color: var(--accent); }

/* 板块1 K线网格 */
.chart-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 1200px) { .chart-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px)  { .chart-grid { grid-template-columns: 1fr; } }
.chart-cell {
  background: var(--panel); border: 1px solid var(--border); border-radius: 8px;
  overflow: hidden; height: 360px; display: flex; flex-direction: column;
}
.chart-cell .cell-head {
  display: flex; align-items: center; gap: 8px; padding: 6px 10px;
  border-bottom: 1px solid var(--border); font-size: 13px; font-weight: 600;
}
.chart-cell .cell-head .grp { font-size: 10px; color: var(--muted); border: 1px solid var(--border); border-radius: 8px; padding: 1px 7px; }
.chart-cell .tv-holder { flex: 1; position: relative; }
.chart-cell .tv-holder .placeholder {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 12px;
}

/* 通用面板 */
.panel { background: transparent; }
/* 两维单选过滤器 */
.lead-filter { display: flex; gap: 14px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.seg-label { font-size: 12px; color: var(--muted); }
.seg { display: inline-flex; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.seg button { background: var(--panel); color: var(--muted); border: none; padding: 6px 18px; font-size: 13px; cursor: pointer; font-family: inherit; }
.seg button + button { border-left: 1px solid var(--border); }
.seg button.active { background: var(--accent); color: #fff; }

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; }
.card {
  background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px;
}
/* 仅板块2 龙头卡片：用 subgrid 让同一行所有卡片的 标题/摘要/建议/事件/标的 五行彼此对齐，
   行高取该行最高者 → 整行工整等高。每张卡固定 5 个直接子元素（h3 + summary + 3×crow）。
   注意：此规则只作用于 #unlisted-panel，避免污染板块3/4（它们子元素数量不定）。 */
#unlisted-panel .cards, #influencers-panel .cards { column-gap: 14px; row-gap: 12px; }
#unlisted-panel .card, #influencers-panel .card { grid-row: span 5; display: grid; grid-template-rows: subgrid; align-content: start; }
/* 板块4 Reddit：每张分类卡 3 个直接子元素（h3 + 2×crow），跨卡片对齐。
   列更宽（≤4 类，加宽减少 解读 文字换行高度）。 */
#reddit-panel .cards { grid-template-columns: repeat(auto-fill, minmax(460px, 1fr)); column-gap: 14px; row-gap: 12px; }
#reddit-panel .card { grid-row: span 4; display: grid; grid-template-rows: subgrid; align-content: start; }
/* 卡片标题上方的分类标签（紧凑药丸，不撑满整行） */
.cat-tag {
  justify-self: start; align-self: start; font-size: 10px; letter-spacing: .04em;
  color: var(--accent); border: 1px solid var(--accent); border-radius: 10px; padding: 1px 9px;
}
.card h3 { margin: 0 0 6px; font-size: 15px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.card h3 .aka { color: var(--muted); font-size: 12px; font-weight: 400; }
.card .summary { font-size: 13px; margin: 6px 0 4px; }
.section-label { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin: 10px 0 4px; }

/* 板块2 龙头分组 */
.lead-group { margin-bottom: 20px; }
.lead-group-title {
  font-size: 13px; font-weight: 600; color: var(--text); margin: 0 0 10px;
  padding: 4px 10px; background: var(--panel); border-left: 3px solid var(--accent); border-radius: 0 6px 6px 0;
}

.badge { font-size: 11px; border-radius: 10px; padding: 1px 8px; border: 1px solid var(--border); }
.badge.bullish, .badge.long  { color: var(--green); border-color: var(--green); }
.badge.bearish, .badge.short { color: var(--red); border-color: var(--red); }
.badge.neutral { color: var(--muted); }
.badge.watch, .badge.mixed { color: var(--amber); border-color: var(--amber); }

/* 板块2 卡片：建议/近期事件/代理股 对齐成「标签 | 内容」表格行 */
.crow { display: grid; grid-template-columns: 64px 1fr; gap: 12px; align-items: start;
        padding: 9px 0; border-top: 1px solid var(--border); }
.crow-label { font-size: 11px; color: var(--muted); padding-top: 2px; line-height: 1.6; }
.crow-label.reco-label { color: var(--amber); font-weight: 600; }
.crow-body { min-width: 0; }
.crow-reco { font-size: 13px; }

/* 代理股行：代码 | 方向 | 理由 三列对齐 */
.proxy { display: grid; grid-template-columns: 58px 56px 1fr; gap: 8px; align-items: start; padding: 4px 0; }
.proxy + .proxy { border-top: 1px dashed var(--border); }
.proxy .tk { font-weight: 700; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.proxy .rel { font-size: 11px; }
.proxy .dir { font-size: 12px; }

.event { font-size: 12px; padding: 4px 0; border-top: 1px dashed var(--border); }
.event .meta { color: var(--muted); font-size: 11px; }
/* 今日最新：荧光底色，扫读时一眼识别「今天才出现的消息源」 */
.date-today { background: var(--today-hl); color: var(--today-fg); font-weight: 700; padding: 0 5px; border-radius: 4px; }
.reco { margin-top: 10px; padding: 8px 10px; background: var(--panel-2); border-radius: 8px; font-size: 13px; }
.reco b { color: var(--amber); }

.tldr { background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; margin-bottom: 14px; }
.tldr ul { margin: 6px 0 0; padding-left: 18px; }
.reddit-section { margin-bottom: 0; }
.reddit-section .body { font-size: 13px; }
.reddit-section .body p { margin: 6px 0; }
.quote { border-left: 2px solid var(--border); padding-left: 10px; color: var(--muted); font-size: 12px; margin: 6px 0; }

.ov-caption { font-size: 12px; color: var(--muted); margin: 8px 0 0; }
.ov-caption b { color: var(--text); font-weight: 600; }
.market-overview { height: 680px; background: var(--panel); border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }

.empty { color: var(--muted); font-size: 13px; padding: 18px; border: 1px dashed var(--border); border-radius: 8px; text-align: center; }
.empty code { background: var(--panel-2); padding: 2px 6px; border-radius: 4px; }

.footer { max-width: 1600px; margin: 0 auto; padding: 18px; display: flex; gap: 16px; border-top: 1px solid var(--border); }

/* 自定义标的编辑器 modal */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100; background: rgba(0,0,0,.6);
  display: flex; align-items: center; justify-content: center; padding: 24px;
}
.modal-overlay.hidden { display: none; }
.modal {
  background: var(--bg); border: 1px solid var(--border); border-radius: 12px;
  width: min(880px, 96vw); max-height: 86vh; display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border); font-size: 15px; font-weight: 600;
}
.se-close { background: none; border: none; color: var(--muted); font-size: 18px; cursor: pointer; }
.se-close:hover { color: var(--text); }
.modal-body { padding: 8px 18px 18px; overflow-y: auto; }
.modal-foot {
  display: flex; align-items: center; gap: 10px; padding: 12px 18px;
  border-top: 1px solid var(--border);
}
.btn-primary { background: var(--accent); color: #fff; border: none; border-radius: 6px; padding: 7px 18px; font-size: 13px; cursor: pointer; font-family: inherit; }
.btn-ghost { background: var(--panel); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 7px 14px; font-size: 13px; cursor: pointer; font-family: inherit; }
.btn-ghost:hover { border-color: var(--muted); }

.se-order-wrap { padding: 10px 18px; border-bottom: 1px solid var(--border); background: var(--panel); }
.se-order-label { font-size: 11px; color: var(--muted); margin-bottom: 7px; }
.se-order { display: flex; flex-wrap: wrap; gap: 6px; min-height: 30px; }
.se-chip {
  display: inline-flex; align-items: center; gap: 6px; background: var(--panel-2);
  border: 1px solid var(--border); border-radius: 7px; padding: 4px 9px; font-size: 12px;
  cursor: grab; user-select: none;
}
.se-chip.dragging { opacity: .35; }
.se-chip.drop-target { border-color: var(--accent); }
.se-chip .grip { color: var(--muted); cursor: grab; font-size: 11px; }
.se-chip .x { color: var(--muted); cursor: pointer; font-size: 11px; padding-left: 2px; }
.se-chip .x:hover { color: var(--red); }

.se-cat { margin-top: 14px; }
.se-cat-title { font-size: 12px; color: var(--accent); font-weight: 600; margin-bottom: 6px; letter-spacing: .04em; }
.se-items { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 6px 12px; }
.se-item { display: flex; align-items: center; gap: 8px; font-size: 13px; cursor: pointer; padding: 3px 0; }
.se-item input { accent-color: var(--accent); cursor: pointer; }
.se-item .se-sym { margin-left: auto; font-size: 10px; color: var(--muted); font-family: ui-monospace, Menlo, monospace; }

/* ---------- 板块6：投资建议（表格 + 筛选 + 详情弹窗） ---------- */
.adv-filter { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin: 0 0 12px; }
.adv-filter .seg-label { font-size: 11px; color: var(--muted); margin-left: 6px; }
.adv-filter .seg-label:first-child { margin-left: 0; }
#adv-count { margin-left: auto; font-size: 12px; }

.adv-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 10px; }
.adv-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.adv-table thead th { text-align: left; font-size: 11px; color: var(--muted); font-weight: 600;
  padding: 10px 12px; border-bottom: 1px solid var(--border); background: var(--panel); white-space: nowrap; }
.adv-table tbody td { padding: 10px 12px; border-bottom: 1px solid var(--border); vertical-align: top; }
.adv-table tbody tr:last-child td { border-bottom: none; }
.adv-row { cursor: pointer; }
.adv-row:hover { background: var(--panel-2); }
.adv-tk { font-weight: 700; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; white-space: nowrap; }
.adv-name { min-width: 120px; }
.adv-stance { white-space: nowrap; min-width: 52px; }
.adv-stance .badge { white-space: nowrap; }
.adv-type { font-size: 10px; color: var(--muted); margin-left: 6px; border: 1px solid var(--border);
  border-radius: 6px; padding: 0 5px; }
.adv-reason { color: var(--text); min-width: 280px; line-height: 1.5; }
.adv-q { white-space: nowrap; }
.adv-q .qchip { font-size: 11px; color: var(--muted); background: var(--panel-2); border: 1px solid var(--border);
  border-radius: 6px; padding: 1px 7px; font-family: ui-monospace, Menlo, monospace; }
.adv-empty-row { text-align: center; color: var(--muted); padding: 24px; }

/* 详情弹窗内容 */
#advice-detail .modal-head .tk { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 700; }
#advice-detail .modal-head { gap: 8px; flex-wrap: wrap; }
.ad-reason { font-size: 14px; line-height: 1.6; color: var(--text); background: var(--panel-2);
  border-left: 3px solid var(--accent); border-radius: 6px; padding: 10px 12px; margin-bottom: 4px; }
.ad-section-label { font-size: 11px; color: var(--accent); font-weight: 600; letter-spacing: .04em;
  margin: 16px 0 8px; }
.ad-points { margin: 0; padding-left: 20px; display: flex; flex-direction: column; gap: 9px; }
.ad-points li { font-size: 13px; line-height: 1.7; }
.ad-points li b { color: var(--text); }
.adq-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px 14px; }
.adq-cell { display: flex; justify-content: space-between; gap: 8px; font-size: 12px;
  border-bottom: 1px dashed var(--border); padding-bottom: 4px; }
.adq-k { color: var(--muted); }
.adq-v { font-family: ui-monospace, Menlo, monospace; text-align: right; }
.disclaimer { font-size: 11px; color: var(--muted); margin-top: 16px; padding-top: 10px; border-top: 1px solid var(--border); }

/* ---------- 主题切换 toggle（右上角；后续并入头像下拉） ---------- */
.topbar-right { display: flex; align-items: center; gap: 12px; }
.theme-toggle {
  display: inline-flex; align-items: center; gap: 2px; cursor: pointer;
  border: 1px solid var(--border); border-radius: 999px; padding: 3px; background: var(--panel-2);
  user-select: none;
}
.theme-toggle .tg-ico {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 22px; border-radius: 999px; font-size: 13px; line-height: 1;
  color: var(--muted); transition: background .15s, color .15s;
}
/* 高亮当前激活的那一侧 */
:root[data-theme="dark"] .theme-toggle .tg-moon { background: var(--accent); color: #fff; }
:root:not([data-theme="dark"]) .theme-toggle .tg-sun { background: var(--amber); color: #fff; }
