/* ==========================================================================
   型態雷達 styles.css — 只引用 tokens.css 的語意化變數,不寫裸色值。
   主題模型:頁面預設淺色(內容頁,SEO 閱讀);.tool-page 或
   [data-theme="dark"] 之內(工具表面/首頁工具框/整個 /live 頁)切換為深色終端風。
   ========================================================================== */

*{box-sizing:border-box}
body{
  margin:0;
  background:var(--bg-page);
  font-family:var(--font-sans);
  color:var(--fg);
  -webkit-font-smoothing:antialiased;
}

/* 全站連結:底線 + AA 對比(淺/深皆過);hover/focus 換色但不失對比 */
a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
a:hover,a:focus-visible{color:var(--up)}

/* 可見焦點環:所有互動元素 */
a:focus-visible,
button:focus-visible,
.tab:focus-visible,
.iv:focus-visible,
.card:focus-visible,
.f:focus-visible,
input:focus-visible,
select:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
  border-radius:var(--radius-sm);
}

/* 數字類:報價/百分比/樣本數一律等寬數字,避免跳動 */
.conf,.status,.stat,.num,.pill,.card .p,.ago,.lcard .row2,.lcard .conf{
  font-variant-numeric:tabular-nums;
}

/* ==========================================================================
   工具表面(.tool-page,或 [data-theme="dark"])共用底色
   ========================================================================== */
.tool-page{
  background:var(--bg-page);
  color:var(--fg);
}

.wrap{max-width:min(1640px,94vw);margin:22px auto;padding:0 16px}

.frame{
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.top{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:8px;font-size:var(--fs-base);font-weight:500;color:var(--fg)}
.brand .d{width:8px;height:8px;border-radius:50%;background:var(--up);animation:pulse 1.6s ease-in-out infinite}
.brand .sub{color:var(--fg-faint);font-weight:400;font-size:var(--fs-sm)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.tabs{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.tab{
  padding:4px 12px;font-size:var(--fs-sm);border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);background:transparent;color:var(--fg-muted);
  cursor:pointer;font-family:inherit;text-decoration:none;
}
.tab:hover{border-color:var(--border-strong);color:var(--fg)}
.tab.active{background:var(--up-bg);color:var(--up);border-color:var(--up)}
.more{color:var(--fg-faint);font-size:var(--fs-sm);margin-left:2px}
.live{display:flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--up)}

.body{display:flex;gap:16px;padding:16px;flex-wrap:wrap}
.chartcol{flex:2.2 1 460px;min-width:340px}
.feedcol{flex:1 1 220px;min-width:210px}

.chhead{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.chleft{display:flex;align-items:center;gap:9px;font-size:var(--fs-md);font-weight:500;color:var(--fg)}

/* 型態 pill:多方用 up token、空方用 down token(語意化,非連結色) */
.pat{font-size:var(--fs-sm);padding:2px 10px;border-radius:var(--radius-sm);border:1px solid var(--up);color:var(--up);background:var(--up-bg)}
.pat.bear{border-color:var(--down);color:var(--down);background:var(--down-bg)}
.conf{font-size:var(--fs-base);color:var(--up);font-weight:600}

.tools{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.iv{
  padding:2px 9px;font-size:var(--fs-sm);border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);background:transparent;color:var(--fg-muted);
  cursor:pointer;font-family:inherit;
}
.iv:hover{border-color:var(--border-strong);color:var(--fg)}
.iv.on{background:var(--up-bg);color:var(--up);border-color:var(--up)}

.chip{font-size:var(--fs-xs);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);color:var(--fg-faint)}
.chip.on{background:var(--up-bg);color:var(--up);border-color:var(--up)}

#chart{width:100%;height:360px}
/* 首頁工具區(.wrap 只用於首頁)圖表加高、隨視窗自適應,接近 TradingView 的滿版氣勢;
   生成頁的圖表(在 840px 內容欄裡)維持 360px 不變。 */
.wrap #chart{height:clamp(400px,58vh,640px)}

/* 圖表 legend:說明標註線含義(頸線/目標/失效),小字 + 對應色虛線色塊 */
.chart-legend{
  display:flex;flex-wrap:wrap;gap:14px;align-items:center;
  margin-top:8px;font-size:var(--fs-xs);color:var(--fg-faint);
}
.chart-legend .li{display:flex;align-items:center;gap:5px}
.chart-legend .sw{
  display:inline-block;width:16px;height:0;border-top:2px dashed;
}
.chart-legend .sw.neckline{border-color:#c9d3df}
.chart-legend .sw.target{border-color:var(--accent)}
.chart-legend .sw.invalid{border-color:var(--down)}

.explain{
  margin-top:12px;padding-top:12px;border-top:1px solid var(--border);
  font-size:var(--fs-sm);line-height:var(--lh-loose);color:var(--fg-muted);
}

.feedhead{font-size:var(--fs-base);font-weight:500;margin-bottom:10px;color:var(--fg)}
.feedhead .sub{color:var(--fg-faint);font-weight:400}
.feed{display:flex;flex-direction:column;gap:8px}
.card{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:9px 11px;border:1px solid var(--border);border-radius:var(--radius-md);
  cursor:pointer;background:var(--bg-surface);
}
.card:hover{border-color:var(--border-strong)}
.card.sel{background:var(--up-bg);border-color:var(--up)}
.card .s{font-size:var(--fs-base);font-weight:500;color:var(--fg)}
.card .p{font-size:var(--fs-sm);color:var(--fg-faint)}
.card .r{display:flex;flex-direction:column;align-items:flex-end;gap:3px}

/* 狀態 pill:.pill.form 用 status-form、.pill.done 用 status-done(不用連結 accent) */
.pill{font-size:var(--fs-xs);padding:1px 8px;border-radius:var(--radius-sm);font-weight:500}
.pill.form{background:var(--status-form-bg);color:var(--status-form)}
.pill.done{background:var(--status-done-bg);color:var(--status-done)}

.ago{font-size:var(--fs-xs);color:var(--fg-faint)}
.empty,.note{font-size:var(--fs-sm);color:var(--fg-faint);padding:8px 2px;line-height:var(--lh-loose)}
.note{border-top:1px solid var(--border);margin-top:4px;padding-top:8px}
.foot{padding:10px 16px;border-top:1px solid var(--border);font-size:var(--fs-xs);color:var(--fg-faint)}
.src{font-size:var(--fs-xs);color:var(--fg-faint);margin-top:8px;text-align:right}

/* 漲跌不只靠顏色:.up/.dn 語意 class(若標記存在)加 ▲▼ 前綴 */
.up::before{content:"▲ ";font-size:.85em}
.dn::before{content:"▼ ";font-size:.85em}
.pat:not(.bear)::before{content:"▲ ";font-size:.85em}
.pat.bear::before{content:"▼ ";font-size:.85em}

/* ==========================================================================
   /live 篩選列(live/index.html 內嵌 .live-toolbar/.f/.lcard,一併 token 化)
   ========================================================================== */
.live-toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:14px 0}
.live-toolbar .grp{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.live-toolbar .lbl{font-size:var(--fs-sm);color:var(--fg-faint);margin-right:2px}
.f{
  padding:3px 11px;font-size:var(--fs-sm);border-radius:var(--radius-sm);
  border:1px solid var(--border-strong);background:transparent;color:var(--fg-muted);
  cursor:pointer;font-family:inherit;
}
.f:hover{border-color:var(--border-strong);color:var(--fg)}
.f.on{background:var(--up-bg);color:var(--up);border-color:var(--up)}
.f.on.bear-on{background:var(--down-bg);color:var(--down);border-color:var(--down)}
.live-meta{font-size:var(--fs-sm);color:var(--fg-faint);margin:0 0 14px}
.live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.lcard,
.content-page .lcard{
  display:block;padding:12px 13px;border:1px solid var(--border);border-radius:var(--radius-md);
  text-decoration:none;color:inherit;background:var(--bg-surface);
}
.lcard:hover{border-color:var(--border-strong)}
.lcard .row1{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.lcard .sym{font-size:var(--fs-base);font-weight:600;color:var(--fg)}
.lcard .pname{font-size:var(--fs-sm);color:var(--fg-muted);margin-bottom:4px}
.lcard .pname.bear{color:var(--down)}
.lcard .row2{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:var(--fs-xs);color:var(--fg-faint)}
.lcard .conf{color:var(--up)}
.live-empty{font-size:var(--fs-base);color:var(--fg-faint);padding:20px 4px;line-height:var(--lh-loose)}
.live-progress{font-size:var(--fs-sm);color:var(--fg-faint);margin:0 0 10px}

/* ==========================================================================
   內容頁(.content-page):淺色編輯閱讀風
   ========================================================================== */
.content-page{background:var(--bg-page);color:var(--fg)}

.content-page a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.content-page a:visited{color:var(--accent)}
.content-page a:hover,.content-page a:focus-visible{color:var(--up)}
.content-page p a,.prose a,.livelist li a{text-decoration:underline;text-underline-offset:2px}

.site-top{
  display:flex;align-items:center;gap:18px;padding:12px 20px;
  border-bottom:1px solid var(--border);position:sticky;top:0;
  background:var(--bg-page);z-index:5;
}
.site-top .brand{display:flex;align-items:center;gap:7px;font-size:var(--fs-base);font-weight:500;color:var(--fg);text-decoration:none}
.site-top .brand .d{width:8px;height:8px;border-radius:50%;background:var(--up);animation:pulse 1.6s ease-in-out infinite}
.site-nav{display:flex;gap:14px;flex-wrap:wrap}
.site-nav a{font-size:var(--fs-sm);color:var(--fg-muted);text-decoration:underline;text-underline-offset:2px}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--up)}

.page-wrap{max-width:840px;margin:20px auto 60px;padding:0 20px}
.crumb{font-size:var(--fs-sm);color:var(--fg-faint);margin-bottom:12px}
.crumb a{color:var(--fg-muted);text-decoration:underline;text-underline-offset:2px}
.crumb a:hover,.crumb a:focus-visible{color:var(--up)}
.crumb .sep{margin:0 7px;color:var(--fg-faint)}

.content-page h1{font-size:var(--fs-2xl);font-weight:600;margin:6px 0 16px;line-height:var(--lh-tight);color:var(--fg)}
.content-page h2{font-size:var(--fs-lg);font-weight:600;margin:26px 0 10px;line-height:var(--lh-tight);color:var(--fg)}
.content-page h3{font-size:var(--fs-md);font-weight:600;margin:20px 0 8px;line-height:var(--lh-tight);color:var(--fg)}

/* .prose:好讀窄欄編輯風——15px 內文、寬行高 */
.prose{max-width:72ch}
.prose p{font-size:var(--fs-base);line-height:var(--lh-loose);color:var(--fg-muted);margin:10px 0}
.prose strong{color:var(--fg);font-weight:600}
.prose code{
  font-family:var(--font-mono);font-size:.9em;background:var(--bg-surface-2);
  border:1px solid var(--border);border-radius:4px;padding:1px 5px;color:var(--fg);
}
.prose ul,.prose ol{font-size:var(--fs-base);line-height:var(--lh-loose);color:var(--fg-muted);padding-left:1.4em}
.prose li{margin:4px 0}
.prose.stat{color:var(--fg-muted)}

.status{font-size:var(--fs-base);color:var(--up);margin:12px 0 0;line-height:var(--lh-normal)}

.related{margin:24px 0}
.related ul,.livelist ul{list-style:none;padding:0;margin:8px 0;display:flex;flex-wrap:wrap;gap:8px}
.livelist ul{flex-direction:column}
.related li a{
  display:inline-block;font-size:var(--fs-sm);color:var(--fg);text-decoration:none;
  border:1px solid var(--border);border-radius:var(--radius-md);padding:7px 12px;background:var(--bg-surface);
}
.related li a:hover,.related li a:focus-visible{border-color:var(--up);color:var(--up)}
.livelist li{font-size:var(--fs-base);color:var(--fg-muted);padding:6px 0;border-bottom:1px solid var(--border)}
.livelist li a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.livelist li a:hover,.livelist li a:focus-visible{color:var(--up)}

.backlink{margin:20px 0}
.backlink a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;font-size:var(--fs-base)}
.backlink a:hover,.backlink a:focus-visible{color:var(--up)}

.site-foot{max-width:840px;margin:0 auto;padding:20px;border-top:1px solid var(--border)}
.site-foot .ext{font-size:var(--fs-sm);color:var(--fg-muted);line-height:var(--lh-loose)}
.site-foot .ext .disc{color:var(--fg-faint);font-style:normal}
.site-foot .aff{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.site-foot .aff:hover,.site-foot .aff:focus-visible{color:var(--up)}
.site-foot .dis{font-size:var(--fs-xs);color:var(--fg-faint);margin-top:10px}
.site-foot .dis a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.site-foot .dis.info-box{color:var(--info-fg);font-size:var(--fs-sm)}
.site-foot .dis.info-box a{color:var(--info-fg)}
.site-foot .dis.info-box a:hover,.site-foot .dis.info-box a:focus-visible{color:var(--accent)}

/* 內容頁裡的即時圖表框(.frame)是深色島:token 覆寫定義在 tokens.css
   (.content-page .frame 與 .tool-page 共用同一組深色變數),這裡只套用底色。 */
.content-page .frame{padding:14px;background:var(--bg-surface);color:var(--fg)}

/* ==========================================================================
   免責 / 提示用 info-box
   ========================================================================== */
.info-box{
  background:var(--info-bg);
  border:1px solid var(--info-border);
  color:var(--info-fg);
  border-radius:var(--radius-md);
  padding:var(--sp-3) var(--sp-4);
  font-size:var(--fs-sm);
  line-height:var(--lh-loose);
  margin:var(--sp-4) 0;
}
.info-box a{color:var(--info-fg);text-decoration:underline;text-underline-offset:2px}
.info-box a:hover,.info-box a:focus-visible{color:var(--accent)}
