/* Sage v3 共用样式 · Apple + 信号色 */
:root {
  --signal-green: #34c759;
  --signal-yellow: #ffcc00;
  --signal-red: #ff3b30;
  --signal-dead: #636366;
  --bg-primary: #0b0b0e;
  --bg-card: #16171b;
  --bg-card-2: #1c1d22;
  --text-primary: #f5f5f7;
  --text-secondary: #a1a1a6;
  --text-tertiary: #6e6e73;
  --border: rgba(255,255,255,0.08);
  --radius: 14px;
  --font-sans: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'PingFang SC', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --font-serif: 'Times New Roman', Georgia, serif;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-sans);
  line-height: 1.6;
  font-size: 15px;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
}
.wrap { max-width: 980px; margin: 0 auto; padding: 24px 18px 80px; }
.hdr { padding: 20px 0 28px; border-bottom: 0.5px solid var(--border); margin-bottom: 24px; }
.hdr h1 { font-size: 28px; margin: 0 0 6px; font-weight: 700; letter-spacing: -0.02em; }
.hdr .meta { color: var(--text-secondary); font-size: 13px; }
.hdr .meta .dot { display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--signal-green); box-shadow:0 0 8px var(--signal-green); margin:0 8px 0 0; vertical-align:middle; }
h2 { font-size: 20px; margin: 32px 0 14px; font-weight: 600; letter-spacing: -0.015em; display: flex; align-items: center; gap: 8px; }
h2 .tag { font-size: 10.5px; padding: 2px 8px; border-radius: 980px; background: rgba(255,255,255,0.06); color: var(--text-secondary); font-weight: 500; letter-spacing: 0; }
h3 { font-size: 15.5px; margin: 18px 0 8px; font-weight: 600; }
.card { background: var(--bg-card); border: 0.5px solid var(--border); border-radius: var(--radius); padding: 16px 18px; margin-bottom: 12px; }
.card--tight { padding: 12px 14px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.grid4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 720px) { .grid2, .grid3, .grid4 { grid-template-columns: 1fr; } }
table { width: 100%; border-collapse: collapse; font-size: 13px; margin: 10px 0; }
th, td { text-align: left; padding: 8px 10px; border-bottom: 0.5px solid var(--border); vertical-align: top; }
th { color: var(--text-secondary); font-weight: 500; font-size: 12px; }
.num { font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.up { color: var(--signal-green); }
.dn { color: var(--signal-red); }
.cn-up { color: var(--signal-red); } /* A股红涨 */
.cn-dn { color: var(--signal-green); }
.mute { color: var(--text-secondary); }
.pill { display: inline-block; padding: 2px 9px; border-radius: 980px; font-size: 11px; font-weight: 500; border: 0.5px solid var(--border); background: rgba(255,255,255,0.03); }
.pill-r { background: rgba(255,59,48,0.12); color: var(--signal-red); border-color: rgba(255,59,48,0.25); }
.pill-y { background: rgba(255,204,0,0.12); color: var(--signal-yellow); border-color: rgba(255,204,0,0.25); }
.pill-g { background: rgba(52,199,89,0.12); color: var(--signal-green); border-color: rgba(52,199,89,0.25); }
.pill-b { background: rgba(10,132,255,0.12); color: #0a84ff; border-color: rgba(10,132,255,0.25); }
code, pre { font-family: var(--font-mono); font-size: 12.5px; background: rgba(255,255,255,0.04); padding: 1px 5px; border-radius: 4px; }
pre { padding: 10px 12px; overflow-x: auto; border-radius: 8px; border: 0.5px solid var(--border); }
a { color: #0a84ff; text-decoration: none; }
a:hover { text-decoration: underline; }
blockquote { margin: 0; padding: 6px 14px; border-left: 2px solid var(--signal-red); color: var(--text-secondary); font-size: 13.5px; }
.ded { border-bottom: 1px dashed var(--text-secondary); cursor: help; }
.ded:hover { color: var(--signal-yellow); }
ul, ol { padding-left: 20px; }
li { margin: 3px 0; }
.ticker { font-family: var(--font-mono); background: rgba(255,204,0,0.10); color: var(--signal-yellow); padding: 1px 5px; border-radius: 3px; font-weight: 500; font-size: 12.5px; }
.quote { background: rgba(255,255,255,0.03); border-left: 2px solid rgba(255,255,255,0.15); padding: 8px 12px; font-size: 13px; font-style: italic; color: var(--text-secondary); margin: 6px 0; border-radius: 0 6px 6px 0; }
.sage-box { background: linear-gradient(135deg, rgba(191,90,242,0.08), rgba(255,55,95,0.05)); border: 0.5px solid rgba(191,90,242,0.25); border-radius: 10px; padding: 10px 14px; margin: 8px 0; font-size: 13.5px; }
.sage-box strong { color: #bf5af2; }
.foot { margin-top: 40px; padding-top: 20px; border-top: 0.5px solid var(--border); color: var(--text-tertiary); font-size: 12px; text-align: center; }
