:root {
  color-scheme: light;
  --bg: #f5f6f8;
  --surface: #ffffff;
  --surface-2: #fafbfc;
  --surface-hover: #f4f6fa;
  --line: #e6e8ed;
  --line-soft: #eef0f3;
  --text: #1d2129;
  --text-2: #4e5969;
  --muted: #86909c;
  --muted-2: #c9cdd4;
  --up: #ef4444;
  --up-soft: #fde8e8;
  --down: #22c55e;
  --down-soft: #e2f7e8;
  --warn: #f59e0b;
  --warn-soft: #fff3e0;
  --info: #2563eb;
  --info-soft: #e8efff;
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04), 0 1px 1px rgba(15, 23, 42, 0.02);
  --shadow-md: 0 6px 24px rgba(15, 23, 42, 0.06);
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", Inter, "Helvetica Neue", Arial, sans-serif;
  font-size: 13px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

button {
  font-family: inherit;
  cursor: pointer;
}

h1, h2, h3, p {
  margin: 0;
}

/* Topbar + index-strip + content 三者共享一个 1640px 居中容器，
 * 左右边距 = max(24px, (viewport - 1640) / 2 + 24px) — 让它们的内容左缘永远对齐。 */
.topbar {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 12px max(24px, calc((100vw - 1640px) / 2 + 24px));
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
  position: sticky;
  top: 0;
  z-index: 10;
}

.brand {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.brand-mark {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.4px;
  color: var(--text);
}

.brand-sub {
  color: var(--muted);
  font-size: 12px;
}

.topnav {
  display: flex;
  gap: 4px;
  justify-content: center;
}

.tab {
  background: transparent;
  border: none;
  color: var(--muted);
  padding: 8px 14px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
}

.tab.active {
  color: var(--text);
  background: var(--surface-hover);
  font-weight: 600;
}

.market-mood {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 12px;
  color: var(--muted);
}

.mood-item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.mood-item em {
  font-style: normal;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.mood-up { color: var(--up); }
.mood-down { color: var(--down); }
.mood-strong { color: var(--up); }

.mood-divider {
  width: 1px;
  height: 14px;
  background: var(--line);
}

.asof {
  font-variant-numeric: tabular-nums;
}

.source-badge {
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px 10px;
  color: var(--info);
  background: var(--info-soft);
  font-size: 11px;
}

.source-badge.fallback {
  color: var(--warn);
  background: var(--warn-soft);
}

.index-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  background: var(--surface); /* 白底，padding 区域不再透灰 */
  border-bottom: 1px solid var(--line);
  padding: 0 max(24px, calc((100vw - 1640px) / 2 + 24px));
}

.index-cell {
  background: var(--surface);
  padding: 12px 18px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-right: 1px solid var(--line); /* 单元格分隔线 */
}

.index-cell:last-child  { border-right: none; }
.index-cell:first-child { padding-left: 0; }
.index-cell:last-child  { padding-right: 0; }

.index-cell .name {
  font-size: 12px;
  color: var(--muted);
}

.index-cell .price {
  font-size: 16px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.index-cell .change {
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

.content {
  padding: 18px max(24px, calc((100vw - 1640px) / 2 + 24px)) 40px;
  margin: 0 auto;
  max-width: 100%;
}

.tab-view {
  display: grid;
  gap: 16px;
}

[hidden] {
  display: none !important;
}

.brand-icon {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
}

.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-soft);
  gap: 16px;
  flex-wrap: wrap;
}

.card-head h2 {
  font-size: 15px;
  font-weight: 700;
}

.muted { color: var(--muted); font-size: 12px; }

.card-tools {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.legend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--muted);
  font-size: 12px;
}

.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.dot-up { background: var(--up); }
.dot-down { background: var(--down); }
.dot-warn { background: var(--warn); }
.dot-strong { background: var(--info); }

.search-inline {
  position: relative;
}

.search-inline input {
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 10px;
  font-size: 12px;
  outline: none;
  background: var(--surface-2);
  min-width: 240px;
}

.search-inline input:focus {
  border-color: var(--info);
  background: var(--surface);
}

.suggest-list {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  min-width: 280px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow-md);
  z-index: 20;
  max-height: 320px;
  overflow-y: auto;
}

.suggest-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--line-soft);
  font-size: 12px;
}

.suggest-row:last-child { border-bottom: none; }
.suggest-row:hover { background: var(--surface-hover); }
.suggest-row .suggest-name { font-weight: 600; color: var(--text); }
.suggest-row .suggest-code { color: var(--muted); font-size: 11px; margin-left: 6px; }
.suggest-row .suggest-board {
  font-size: 11px;
  color: var(--info);
  background: var(--info-soft);
  padding: 2px 6px;
  border-radius: 4px;
}
.suggest-empty { padding: 10px 12px; color: var(--muted); font-size: 12px; }

.board-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 18px;
  border-bottom: 1px solid var(--line-soft);
  background: var(--surface-2);
}

.board-chip {
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 12px;
  color: var(--text-2);
  cursor: pointer;
  user-select: none;
}

.board-chip:hover { border-color: var(--info); color: var(--info); }
.board-chip.active {
  background: var(--info);
  color: #fff;
  border-color: var(--info);
}
.board-chip .count { opacity: 0.7; margin-left: 4px; font-size: 11px; }

.refresh-btn {
  padding: 4px 10px;
  font-size: 12px;
}

.subtab-bar {
  display: flex;
  gap: 4px;
  margin-bottom: 12px;
}

.subtab {
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--text-2);
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 13px;
  cursor: pointer;
}

.subtab:hover {
  border-color: var(--info);
  color: var(--info);
}

.subtab.active {
  background: var(--info);
  color: #fff;
  border-color: var(--info);
}

.tech-panel {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.tech-summary {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  background: var(--surface-2);
  border: 1px solid var(--line);
}

.tech-summary .tag {
  font-weight: 700;
  font-size: 13px;
}

.tech-summary .tag.bull { color: var(--up); }
.tech-summary .tag.bear { color: var(--down); }
.tech-summary .tag.neutral { color: var(--muted); }

.tech-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.tech-cell {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: var(--surface);
}

.tech-cell .label {
  font-size: 11px;
  color: var(--muted);
}

.tech-cell .value {
  font-size: 13px;
  font-weight: 600;
  margin-top: 2px;
}

.tech-cell .meta-line {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}

.tech-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.tech-signal {
  font-size: 12px;
  padding: 3px 9px;
  border-radius: 999px;
}

.tech-signal.bull { background: var(--up-soft); color: var(--up); }
.tech-signal.bear { background: var(--down-soft); color: var(--down); }
.tech-signal.muted { background: var(--surface-2); color: var(--muted); }

.graph-shell {
  position: relative;
  padding: 12px 18px 18px;
}

#sectorGraphCanvas {
  display: block;
  width: 100%;
  height: 560px;
}

.radar-shell {
  position: relative;
  padding: 12px 18px;
}

#fundRadarCanvas {
  display: block;
  width: 100%;
  height: 480px;
}

.radar-tables {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 6px 18px 18px;
}

.radar-h3 {
  font-size: 13px;
  margin: 6px 0 8px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.radar-h3.up { color: var(--up); }
.radar-h3.down { color: var(--down); }
.radar-h3.weak { color: var(--muted); font-weight: 600; }

.radar-table { font-size: 12.5px; }
.radar-table td { padding: 8px 12px; border-bottom: 1px solid var(--line-soft); }

.chain-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  padding: 16px 18px;
}

@media (max-width: 1080px) {
  .chain-grid { grid-template-columns: 1fr; }
  .radar-tables { grid-template-columns: 1fr; }
}

.chain-col h3 {
  font-size: 13px;
  margin: 0 0 10px;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}

.chain-col h3 .chain-tag {
  font-size: 11px;
  font-weight: 500;
  color: var(--info);
  background: var(--info-soft);
  padding: 2px 8px;
  border-radius: 4px;
}

.chain-node {
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 8px;
  padding: 10px 12px;
  margin-bottom: 10px;
}

.chain-node .node-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}

.chain-node .node-name {
  font-weight: 700;
  font-size: 13px;
}

.chain-node .node-strength {
  font-variant-numeric: tabular-nums;
  font-size: 12px;
  font-weight: 700;
}

.chain-node .node-strength.bull { color: var(--up); }
.chain-node .node-strength.bear { color: var(--down); }

.chain-node .node-reason {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}

.chain-node .node-parent {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
}

.chain-node .node-leaders {
  margin-top: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.chain-node .node-leaders span {
  font-size: 11px;
  padding: 2px 6px;
  background: var(--surface-2);
  border-radius: 4px;
  font-variant-numeric: tabular-nums;
}

.chain-node.bear { border-left: 3px solid var(--down); }
.chain-node.bull { border-left: 3px solid var(--up); }

.upstream-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--line-soft);
}

.upstream-row:last-child { border-bottom: none; }

.upstream-row .from {
  font-weight: 600;
  font-size: 13px;
}

.upstream-row .from-type {
  font-size: 11px;
  background: var(--surface-2);
  padding: 2px 6px;
  border-radius: 4px;
  margin-left: 6px;
  color: var(--muted);
}

/* Limit-up sentiment */
.limit-pool {
  padding: 14px 18px;
  display: grid;
  gap: 14px;
}

.limit-headline {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: flex-end;
}

.limit-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.limit-stat .label {
  font-size: 11px;
  color: var(--muted);
}

.limit-stat .value {
  font-size: 22px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--up);
}

.limit-stat.warn .value { color: var(--warn); }
.limit-stat.neutral .value { color: var(--info); }

.ladder-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.ladder-pill {
  background: var(--up-soft);
  color: var(--up);
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
}

.ladder-pill.warn { background: var(--warn-soft); color: var(--warn); }
.ladder-pill .count { font-weight: 700; margin-left: 4px; }

.streak-table {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
}

.streak-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: var(--surface);
  display: grid;
  gap: 2px;
}

.streak-card .head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

.streak-card .name {
  font-weight: 700;
  font-size: 13px;
}

.streak-card .lbc {
  background: var(--up);
  color: #fff;
  font-size: 11px;
  padding: 1px 8px;
  border-radius: 999px;
  font-weight: 700;
}

.streak-card .meta {
  font-size: 11px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

/* Period switch on K-line */
.period-switch {
  display: inline-flex;
  border: 1px solid var(--line);
  border-radius: 6px;
  overflow: hidden;
}

.period-btn {
  background: var(--surface);
  border: none;
  color: var(--text-2);
  font-size: 12px;
  padding: 3px 10px;
  cursor: pointer;
  border-right: 1px solid var(--line);
}

.period-btn:last-child { border-right: none; }

.period-btn.active {
  background: var(--info);
  color: #fff;
}

/* Pattern chips inside tech-panel */
.tech-pattern {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  padding: 3px 8px;
  border-radius: 4px;
  margin-right: 4px;
}
.tech-pattern.bull { background: var(--up-soft); color: var(--up); }
.tech-pattern.bear { background: var(--down-soft); color: var(--down); }

/* Chart toggle button (next to period switch) */
.chart-toggle {
  border: 1px solid var(--line);
  background: var(--surface);
  color: var(--text-2);
  border-radius: 6px;
  padding: 3px 10px;
  font-size: 12px;
  cursor: pointer;
}
.chart-toggle:hover { border-color: var(--info); color: var(--info); }
.chart-toggle.active {
  background: var(--info-soft);
  color: var(--info);
  border-color: var(--info);
}

/* Trade plan card */
.trade-plan {
  margin-top: 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--surface);
  padding: 14px 16px;
  display: grid;
  gap: 12px;
}

.trade-plan .tp-head {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.trade-plan .tp-bias {
  font-size: 18px;
  font-weight: 800;
}

.trade-plan .tp-bias.bull-strong { color: var(--up); }
.trade-plan .tp-bias.bull { color: var(--up); }
.trade-plan .tp-bias.bear-strong { color: var(--down); }
.trade-plan .tp-bias.bear { color: var(--down); }
.trade-plan .tp-bias.neutral { color: var(--muted); }

.trade-plan .tp-score {
  font-size: 12px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}

.trade-plan .tp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
}

.tp-tile {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: var(--surface-2);
  display: grid;
  gap: 4px;
}

.tp-tile .tp-label {
  font-size: 11px;
  color: var(--muted);
}

.tp-tile .tp-value {
  font-size: 15px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.tp-tile .tp-meta {
  font-size: 11px;
  color: var(--muted);
}

.tp-tile.bull { border-left: 3px solid var(--up); }
.tp-tile.bear { border-left: 3px solid var(--down); }
.tp-tile.neutral { border-left: 3px solid var(--info); }

.tp-targets {
  display: grid;
  gap: 4px;
  font-size: 12px;
}

.tp-target-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  padding: 4px 0;
}

.tp-target-row .tp-target-label { color: var(--text-2); }
.tp-target-row .tp-target-price { font-variant-numeric: tabular-nums; color: var(--text); }
.tp-target-row .tp-target-gain { color: var(--up); font-weight: 700; font-variant-numeric: tabular-nums; }
.tp-target-row .tp-target-gain.bear { color: var(--down); }

.tp-reasons, .tp-warnings {
  font-size: 12px;
  display: grid;
  gap: 4px;
}

.tp-reasons .tp-row, .tp-warnings .tp-row {
  display: flex;
  gap: 6px;
  color: var(--text-2);
  line-height: 1.55;
}

.tp-warnings .tp-row { color: var(--warn); }

.tp-disclaimer {
  font-size: 11px;
  color: var(--muted);
  border-top: 1px dashed var(--line-soft);
  padding-top: 8px;
}

/* ============================================================
 * Violet-flower loader v2 — 紫罗兰从底部生长
 *
 * 单次循环 4s，五阶段链：
 *   0–5%    土壤出现
 *   5–35%   茎自下而上画出 (stroke-dasharray)
 *   30–55%  两片叶子先后展开
 *   50–70%  花头从茎顶上升
 *   60–85%  6 瓣依序绽放 + 花蕊弹出
 *   85–100% 整体维持，末尾轻微淡出再循环
 *
 * 全部使用百分比关键帧 + 共享的 4s 时长，避免不同元素的循环错位。
 * ============================================================ */
.violet-loader {
  display: inline-block;
  width: 100px;
  height: 100px;
  position: relative;
}

.violet-loader.sm { width: 48px; height: 48px; }
.violet-loader.md { width: 72px; height: 72px; }
.violet-loader.lg { width: 100px; height: 100px; }
.violet-loader.xl { width: 140px; height: 140px; }

.violet-loader svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* 土壤 */
.violet-loader .soil {
  animation: vio-soil 4s ease-in-out infinite;
}
@keyframes vio-soil {
  0%, 2%    { opacity: 0; }
  6%, 88%   { opacity: 0.55; }
  100%      { opacity: 0; }
}

/* 茎：stroke-dasharray 从底部往上画 */
.violet-loader .stem {
  stroke-dasharray: 80;
  stroke-dashoffset: 80;
  animation: vio-stem 4s ease-out infinite;
}
@keyframes vio-stem {
  0%, 5%    { stroke-dashoffset: 80; opacity: 0; }
  8%        { opacity: 1; }
  35%       { stroke-dashoffset: 0; opacity: 1; }
  88%       { stroke-dashoffset: 0; opacity: 1; }
  100%      { stroke-dashoffset: 0; opacity: 0; }
}

/* 叶子: 外层 g.leaf 仅做 scale 动画；transform-box 用 fill-box 确保
 * transform-origin 相对于自身 bbox。 */
.violet-loader .leaf {
  transform-box: fill-box;
  transform-origin: 50% 50%;
  animation-duration: 4s;
  animation-iteration-count: infinite;
  animation-timing-function: cubic-bezier(.34, 1.4, .6, 1);
}
.violet-loader .leaf-left  { animation-name: vio-leaf-left; }
.violet-loader .leaf-right { animation-name: vio-leaf-right; }
@keyframes vio-leaf-left {
  0%, 22%   { transform: scale(0); opacity: 0; }
  38%       { transform: scale(1.1); opacity: 1; }
  45%, 88%  { transform: scale(1); opacity: 1; }
  100%      { transform: scale(1); opacity: 0; }
}
@keyframes vio-leaf-right {
  0%, 28%   { transform: scale(0); opacity: 0; }
  44%       { transform: scale(1.1); opacity: 1; }
  52%, 88%  { transform: scale(1); opacity: 1; }
  100%      { transform: scale(1); opacity: 0; }
}

/* 花头: 父 g translate(50,32) 不动；本元素只做 scale */
.violet-loader .flower-head {
  transform-box: fill-box;
  transform-origin: 50% 50%;
  animation: vio-head 4s cubic-bezier(.34, 1.3, .5, 1) infinite;
}
@keyframes vio-head {
  0%, 45%   { transform: scale(0); opacity: 0; }
  62%       { transform: scale(1.12); opacity: 1; }
  72%, 88%  { transform: scale(1); opacity: 1; }
  100%      { transform: scale(1); opacity: 0; }
}

/* 6 瓣: 父 g rotate(N) 不动；本元素只做 scale，从基部 (50% 100%) 张开 */
.violet-loader .petal {
  transform-box: fill-box;
  transform-origin: 50% 100%;
  animation: vio-petal 4s cubic-bezier(.34, 1.45, .6, 1) infinite;
}
.violet-loader .petal-1 { animation-delay: 0s; }
.violet-loader .petal-2 { animation-delay: -0.07s; }
.violet-loader .petal-3 { animation-delay: -0.14s; }
.violet-loader .petal-4 { animation-delay: -0.21s; }
.violet-loader .petal-5 { animation-delay: -0.28s; }
.violet-loader .petal-6 { animation-delay: -0.35s; }
@keyframes vio-petal {
  0%, 55%   { transform: scaleY(0) scaleX(0.4); opacity: 0; }
  68%       { transform: scaleY(1.15) scaleX(1.05); opacity: 1; }
  76%, 88%  { transform: scaleY(1)    scaleX(1);    opacity: 1; }
  100%      { transform: scaleY(1)    scaleX(1);    opacity: 0; }
}

/* 花蕊 */
.violet-loader .core,
.violet-loader .core-spot {
  transform-box: fill-box;
  transform-origin: 50% 50%;
  animation: vio-core 4s cubic-bezier(.34, 1.6, .5, 1) infinite;
}
@keyframes vio-core {
  0%, 72%   { transform: scale(0); opacity: 0; }
  82%       { transform: scale(1.25); opacity: 1; }
  88%       { transform: scale(1); opacity: 1; }
  100%      { transform: scale(1); opacity: 0; }
}

/* Centered full-screen overlay (initial paint / manual refresh) */
.overlay-loader {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  animation: vio-fade-in 0.25s ease;
}

.overlay-loader[hidden] { display: none !important; }

@keyframes vio-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.overlay-loader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

.overlay-loader-text {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

.overlay-loader-sub {
  font-size: 12px;
  color: var(--muted);
}

/* Card-level loader: centered flower in a translucent panel inside the card.
 * 高度按花体 100×100 + 上下 28px 留白 + label 30px 估算下限 200px。
 * 当宿主 card 自然高度不足时撑开它而不是把花压扁。 */
.card-loader {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 32px 16px;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  z-index: 5;
  border-radius: 10px;
  color: var(--muted);
  font-size: 12px;
  min-height: 220px;
  box-sizing: border-box;
}

.card-loader.subtle {
  background: rgba(255, 255, 255, 0.7);
}

/* 当 card-loader 出现时，给宿主 card 一个最小高度以容纳花 */
.card:has(> .card-loader) {
  min-height: 240px;
}

.card-loader-label {
  font-size: 12px;
  color: var(--muted);
  text-align: center;
}

.card { position: relative; }

/* Radar toolbar */
.radar-toolbar {
  display: inline-flex;
  gap: 4px;
  align-items: center;
}

.radar-toolbar button {
  width: 28px;
  height: 28px;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 6px;
  font-size: 13px;
  cursor: pointer;
  color: var(--text-2);
}

.radar-toolbar button:hover { border-color: var(--info); color: var(--info); }

#fundRadarCanvas {
  cursor: grab;
  user-select: none;
}

#fundRadarCanvas.dragging { cursor: grabbing; }

/* 5-day market overview */
.market5 {
  padding: 16px 18px;
  display: grid;
  gap: 14px;
}

.market5-banner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px solid var(--line);
}

.market5-banner.bull { background: linear-gradient(135deg, var(--up-soft), #ffffff); border-color: rgba(239,68,68,0.2); }
.market5-banner.bear { background: linear-gradient(135deg, var(--down-soft), #ffffff); border-color: rgba(34,197,94,0.2); }
.market5-banner.neutral { background: linear-gradient(135deg, var(--info-soft), #ffffff); border-color: rgba(37,99,235,0.2); }
.market5-banner.warn { background: linear-gradient(135deg, var(--warn-soft), #ffffff); border-color: rgba(245,158,11,0.2); }

.m5-level {
  font-size: 28px;
  font-weight: 800;
  white-space: nowrap;
}
.m5-level.bull { color: var(--up); }
.m5-level.bear { color: var(--down); }
.m5-level.neutral { color: var(--info); }
.m5-level.warn { color: var(--warn); }

.m5-action {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.m5-reasons {
  font-size: 12px;
  color: var(--text-2);
  display: grid;
  gap: 2px;
}

.m5-stats {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  font-size: 12px;
  color: var(--muted);
}

.m5-stats .stat-value {
  font-size: 18px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.m5-stats .stat-value.bull { color: var(--up); }
.m5-stats .stat-value.bear { color: var(--down); }

.market5-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
}

.m5-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--surface);
}

.m5-card .name {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 6px;
}

.m5-card .name .verdict {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: 4px;
}
.m5-card .name .verdict.bull { background: var(--up-soft); color: var(--up); }
.m5-card .name .verdict.bear { background: var(--down-soft); color: var(--down); }
.m5-card .name .verdict.neutral { background: var(--warn-soft); color: var(--warn); }

.m5-card .kv {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 12px;
  font-size: 11.5px;
  color: var(--muted);
}

.m5-card .kv b {
  color: var(--text);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  margin-left: 4px;
}

.m5-spark {
  display: flex;
  gap: 3px;
  margin-top: 8px;
  align-items: flex-end;
  height: 32px;
}

.m5-bar {
  flex: 1;
  border-radius: 2px;
  min-height: 4px;
}

.m5-bar.up { background: var(--up); }
.m5-bar.down { background: var(--down); }
.m5-bar.flat { background: var(--muted-2); }

.m5-disclaimer {
  font-size: 11px;
  color: var(--muted);
  padding: 4px 4px 0;
}

/* Tomorrow prediction card */
.tomorrow {
  padding: 16px 18px;
  display: grid;
  gap: 16px;
}

.tomorrow-banner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px solid var(--line);
}
.tomorrow-banner.bull { background: linear-gradient(135deg, var(--up-soft), #ffffff); border-color: rgba(239,68,68,0.2); }
.tomorrow-banner.bear { background: linear-gradient(135deg, var(--down-soft), #ffffff); border-color: rgba(34,197,94,0.2); }
.tomorrow-banner.neutral { background: linear-gradient(135deg, var(--info-soft), #ffffff); border-color: rgba(37,99,235,0.2); }
.tomorrow-banner .tw-bias {
  font-size: 17px;
  font-weight: 800;
  white-space: nowrap;
}
.tomorrow-banner.bull .tw-bias { color: var(--up); }
.tomorrow-banner.bear .tw-bias { color: var(--down); }
.tomorrow-banner.neutral .tw-bias { color: var(--info); }
.tomorrow-banner .tw-reasons {
  font-size: 12px;
  color: var(--text-2);
  display: grid;
  gap: 2px;
}

.tw-sec-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin: 4px 0 6px;
}
.tw-sec-title .tw-tag {
  font-size: 11px;
  font-weight: 500;
  color: var(--info);
  background: var(--info-soft);
  padding: 2px 8px;
  border-radius: 4px;
  margin-left: 6px;
}

.tomorrow-sectors {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}

.tw-sector {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  background: var(--surface-2);
}
.tw-sector .head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.tw-sector .name { font-weight: 700; font-size: 13px; }
.tw-sector .pred {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--up-soft);
  color: var(--up);
}
.tw-sector .meta { font-size: 11px; color: var(--muted); margin-bottom: 4px; }
.tw-sector .reasons { font-size: 11.5px; color: var(--text-2); display: grid; gap: 2px; }

.tomorrow-stocks {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 10px;
}

.tw-stock {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px 14px;
  background: var(--surface);
  display: grid;
  gap: 8px;
}
.tw-stock.bull { border-left: 3px solid var(--up); }
.tw-stock.warn { border-left: 3px solid var(--warn); }

.tw-stock .head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.tw-stock .head .name-block { display: flex; gap: 8px; align-items: baseline; }
.tw-stock .head .stock-name { font-weight: 700; font-size: 14px; }
.tw-stock .head .stock-symbol { color: var(--muted); font-size: 11px; }
.tw-stock .head .stock-sector { color: var(--muted); font-size: 11px; }
.tw-stock .head .pred-pill {
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--up-soft);
  color: var(--up);
}
.tw-stock .head .pred-pill.weak { background: var(--info-soft); color: var(--info); }

.tw-stock .meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  font-size: 11.5px;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.tw-stock .meta-row b {
  color: var(--text);
  font-weight: 600;
  margin-left: 3px;
}
.tw-stock .meta-row b.up { color: var(--up); }
.tw-stock .meta-row b.down { color: var(--down); }

.tw-stock .reason-list {
  font-size: 12px;
  display: grid;
  gap: 3px;
  color: var(--text-2);
  line-height: 1.55;
}
.tw-stock .reason-list .danger { color: var(--down); }
.tw-stock .reason-list .warn { color: var(--warn); }
.tw-stock .reason-list .news { color: var(--info); }

.tw-stock .news-row {
  font-size: 11.5px;
  background: var(--info-soft);
  border-radius: 6px;
  padding: 6px 10px;
  color: var(--text-2);
}
.tw-stock .news-row a { color: var(--text); text-decoration: none; }
.tw-stock .news-row a:hover { color: var(--info); }

.tomorrow-watchouts {
  border: 1px solid rgba(245, 158, 11, 0.3);
  background: var(--warn-soft);
  border-radius: 8px;
  padding: 10px 12px;
  display: grid;
  gap: 4px;
}
.tomorrow-watchouts .head { font-size: 12px; font-weight: 700; color: var(--warn); }
.tomorrow-watchouts .item { font-size: 12px; color: var(--text-2); line-height: 1.55; }

.tomorrow-methodology {
  font-size: 11px;
  color: var(--muted);
  border-top: 1px dashed var(--line-soft);
  padding-top: 8px;
  line-height: 1.55;
}

.filter-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--text-2);
  font-size: 12px;
  cursor: pointer;
  user-select: none;
}

.ghost {
  background: var(--surface);
  border: 1px solid var(--line);
  color: var(--text-2);
  border-radius: 6px;
  padding: 6px 12px;
  font-size: 12px;
}

.ghost:hover {
  border-color: var(--info);
  color: var(--info);
}

.table-wrap {
  overflow-x: auto;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
}

.data-table thead th {
  background: var(--surface-2);
  text-align: left;
  font-weight: 600;
  color: var(--muted);
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  font-size: 12px;
  white-space: nowrap;
}

.data-table thead th.num {
  text-align: right;
}

.data-table thead th.sortable {
  cursor: pointer;
}

.data-table thead th.sortable.active {
  color: var(--info);
}

.data-table tbody td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--line-soft);
  vertical-align: middle;
  white-space: nowrap;
}

.data-table tbody td.num {
  text-align: right;
}

.data-table tbody tr:hover {
  background: var(--surface-hover);
}

.data-table tbody tr.active {
  background: var(--info-soft);
}

.col-rank {
  width: 38px;
  color: var(--muted);
  text-align: center !important;
}

.col-action {
  width: 80px;
}

.stock-name {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--text);
}

.stock-name .stock-sector {
  font-size: 11px;
  color: var(--muted);
  font-weight: 400;
}

.stock-code {
  color: var(--muted);
  font-size: 12px;
}

.up { color: var(--up); }
.down { color: var(--down); }
.flat { color: var(--muted); }

.score-pill {
  display: inline-block;
  min-width: 44px;
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 700;
  text-align: center;
  font-size: 12px;
}
.score-pill.high { background: var(--up-soft); color: var(--up); }
.score-pill.mid { background: var(--info-soft); color: var(--info); }
.score-pill.low { background: var(--surface-2); color: var(--muted); }

.tag-chip {
  display: inline-block;
  border-radius: 4px;
  padding: 2px 6px;
  margin: 2px 4px 2px 0;
  font-size: 11px;
  background: var(--up-soft);
  color: var(--up);
  border: 1px solid transparent;
}

.tag-chip.neutral { background: var(--surface-2); color: var(--text-2); }
.tag-chip.warn { background: var(--warn-soft); color: var(--warn); }
.tag-chip.danger { background: var(--up-soft); color: var(--up); border-color: rgba(239, 68, 68, 0.3); }
.tag-chip.calm { background: var(--info-soft); color: var(--info); }

.tag-chip.risk { background: #fef2f2; color: #b91c1c; border-color: rgba(185, 28, 28, 0.2); }
.tag-chip.risk-soft { background: var(--warn-soft); color: #92400e; }

.action-btn {
  background: var(--surface);
  border: 1px solid var(--info);
  color: var(--info);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 12px;
}
.action-btn:hover { background: var(--info); color: #fff; }
.action-btn.watched { background: var(--info-soft); color: var(--info); }

.detail-card { background: var(--surface); }

.detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 1fr);
  gap: 18px;
  padding: 18px;
}

.detail-title h2 {
  font-size: 18px;
}

.chart-shell {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  padding: 12px;
}

.chart-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.chart-head strong {
  font-size: 13px;
  color: var(--text);
}

#klineCanvas {
  display: block;
  width: 100%;
  height: 320px;
}

.chart-fallback {
  border: 1px dashed var(--line);
  background: var(--surface-2);
  border-radius: 8px;
  padding: 28px 18px;
  text-align: center;
  color: var(--muted);
  margin-top: 8px;
}

.chart-fallback strong { display: block; color: var(--warn); margin-bottom: 6px; }

.signal-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.signal-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--surface-2);
}

.signal-card .label {
  font-size: 12px;
  color: var(--muted);
  display: flex;
  justify-content: space-between;
}

.signal-card .value {
  font-size: 18px;
  font-weight: 700;
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}

.signal-card .bar-track {
  height: 4px;
  border-radius: 999px;
  background: var(--line-soft);
  margin-top: 6px;
  overflow: hidden;
}

.signal-card .bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--info), var(--up));
}

.detail-right {
  display: grid;
  gap: 14px;
}

.kv-block {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: var(--surface-2);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 18px;
}

.kv-row {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
}

.kv-row span:first-child {
  color: var(--muted);
}

.kv-row span:last-child {
  font-variant-numeric: tabular-nums;
  color: var(--text);
  font-weight: 600;
}

.logic-stack {
  display: grid;
  gap: 8px;
}

.logic-row {
  border-left: 3px solid var(--info);
  padding: 8px 12px;
  background: var(--surface-2);
  border-radius: 0 6px 6px 0;
  font-size: 12.5px;
  color: var(--text-2);
}

.related-news {
  display: grid;
  gap: 10px;
}

.related-news article {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--surface);
}

.related-news a {
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
}

.related-news a:hover { color: var(--info); }

.news-list {
  padding: 4px 18px 14px;
  display: grid;
  gap: 0;
}

.news-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line-soft);
}

.news-row:last-child { border-bottom: none; }

.news-time {
  color: var(--muted);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}

.news-title a {
  color: var(--text);
  text-decoration: none;
  font-size: 13px;
  line-height: 1.5;
}

.news-title a:hover { color: var(--info); }

.news-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: flex-end;
}

.sentiment {
  display: inline-flex;
  min-width: 44px;
  justify-content: center;
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 11px;
  font-variant-numeric: tabular-nums;
}

.sectors-table td:first-child,
.sectors-table th:first-child {
  text-align: center;
}

@media (max-width: 1100px) {
  .topbar {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .topnav { justify-content: flex-start; }
  .market-mood { flex-wrap: wrap; justify-content: flex-start; }
  .index-strip { grid-template-columns: repeat(3, 1fr); }
  .detail-grid { grid-template-columns: 1fr; }
}

/* ============================================================
 * Mobile (≤ 768px) — phones, stacked layout
 * ============================================================ */
@media (max-width: 768px) {
  html, body { font-size: 12.5px; }

  .topbar {
    padding: 10px 14px;
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .brand-mark { font-size: 17px; }
  .brand-sub { font-size: 11px; }
  .brand-icon { width: 32px; height: 32px; flex: 0 0 32px; }

  .topnav {
    overflow-x: auto;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 4px;
    -webkit-overflow-scrolling: touch;
  }
  .tab { padding: 6px 12px; font-size: 12px; white-space: nowrap; flex: 0 0 auto; }

  .market-mood {
    flex-wrap: wrap;
    gap: 8px;
    font-size: 11px;
    align-items: center;
  }
  .market-mood .mood-divider { display: none; }
  .market-mood .asof { font-size: 10px; }
  .refresh-btn { padding: 3px 8px; font-size: 11px; }

  /* Index strip — 2 cols, no horizontal padding overflow */
  .index-strip {
    grid-template-columns: repeat(2, 1fr);
    padding: 0;
  }
  .index-cell {
    padding: 9px 12px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .index-cell:nth-child(2n) { border-right: none; padding-right: 12px; }
  .index-cell:nth-last-child(-n+2):nth-child(2n+1),
  .index-cell:last-child { border-bottom: none; }
  .index-cell:first-child { padding-left: 12px; }
  .index-cell .price { font-size: 14px; }
  .index-cell .change { font-size: 11px; }

  /* Content */
  .content { padding: 12px 12px 32px; }
  .tab-view { gap: 12px; }

  /* Cards */
  .card-head {
    padding: 12px 14px;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .card-head h2 { font-size: 14px; }
  .card-tools { flex-wrap: wrap; gap: 6px; }

  /* Stock-row table: keep horizontal scroll via .table-wrap (already overflow-x:auto)
   * but slim down padding so more columns visible */
  .data-table thead th, .data-table tbody td {
    padding: 8px 10px;
    font-size: 12px;
  }

  /* Board chips — horizontal scroll on overflow */
  .board-chips {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 8px 14px;
  }
  .board-chip { flex: 0 0 auto; }

  /* Limit pool — stat row stacks but ladder pills wrap */
  .limit-pool { padding: 12px 14px; }
  .limit-headline {
    gap: 12px;
    align-items: flex-start;
  }
  .limit-stat .value { font-size: 18px; }
  .streak-table { grid-template-columns: 1fr; }

  /* News rows — STACK so Chinese titles get full width */
  .news-list { padding: 4px 14px 14px; }
  .news-row {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    gap: 6px;
    padding: 12px 0;
  }
  .news-row .news-time { order: 1; font-size: 11px; }
  .news-row .news-title { order: 2; }
  .news-row .news-title a { font-size: 13px; line-height: 1.55; word-break: break-word; }
  .news-row .news-tags { order: 3; justify-content: flex-start; flex-wrap: wrap; }

  /* Detail drawer */
  .detail-grid { grid-template-columns: 1fr; padding: 12px 14px; gap: 14px; }
  .detail-title h2 { font-size: 15px; }
  #klineCanvas { height: 240px; }
  .chart-shell { padding: 10px; }
  .chart-head { flex-wrap: wrap; gap: 6px; }
  .period-switch { font-size: 11px; }
  .period-btn { padding: 3px 8px; }
  .chart-toggle { font-size: 11px; padding: 3px 8px; }

  /* Signal grid */
  .signal-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .signal-card .value { font-size: 16px; }

  /* Tech panel grid 2 cols */
  .tech-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .tech-cell .value { font-size: 12px; }

  /* Trade plan */
  .trade-plan { padding: 12px 14px; gap: 10px; }
  .trade-plan .tp-bias { font-size: 16px; }
  .trade-plan .tp-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .tp-tile .tp-value { font-size: 13px; }

  /* Fundamentals KV — 1 column */
  .kv-block { grid-template-columns: 1fr; gap: 6px; padding: 10px; }

  /* 5-day market overview */
  .market5 { padding: 12px 14px; }
  .market5-banner {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 12px;
  }
  .m5-stats { align-items: flex-start; }
  .market5-grid { grid-template-columns: 1fr; gap: 8px; }
  .m5-level { font-size: 22px; }

  /* Macro tab */
  .radar-shell { padding: 8px 4px; }
  #fundRadarCanvas { height: 360px; }
  .radar-tables { grid-template-columns: 1fr; gap: 10px; padding: 6px 14px; }
  #sectorGraphCanvas { height: 380px; }
  .chain-grid { grid-template-columns: 1fr; padding: 12px 14px; gap: 10px; }

  /* Subtab bar */
  .subtab-bar { overflow-x: auto; flex-wrap: nowrap; }
  .subtab { flex: 0 0 auto; }

  /* Hide nav decoration that wastes space */
  .legend { font-size: 10px; }

  /* Search input full-width */
  .search-inline input { min-width: 0; width: 100%; }
  .search-inline { flex: 1; min-width: 200px; }

  /* Loaders: smaller flower on mobile */
  .violet-loader.lg { width: 80px; height: 80px; }
  .card-loader { min-height: 200px; padding: 24px 14px; }

  /* Overlay loader text */
  .overlay-loader-text { font-size: 13px; }
  .overlay-loader-sub { font-size: 11px; }
}

/* Very narrow phones (< 380px) — further compression */
@media (max-width: 380px) {
  .index-strip { grid-template-columns: 1fr 1fr; }
  .index-cell .name { font-size: 11px; }
  .signal-grid { grid-template-columns: 1fr 1fr; }
  .tech-grid { grid-template-columns: 1fr; }
  .trade-plan .tp-grid { grid-template-columns: 1fr; }
}
