:root { --bg:#0e1116; --panel:#161b22; --fg:#d7dde5; --muted:#7d8694; --accent:#3b82f6; --line:#222a35;
  --chart-bg:#0e1116; --chart-text:#a7b0bd; --chart-grid:#1b212b; --chart-border:#2a323d; --legend-shadow:rgba(0,0,0,.85); }
body.light { --bg:#f4f6f9; --panel:#ffffff; --fg:#1f2937; --muted:#6b7280; --accent:#2563eb; --line:#d7dde5;
  --chart-bg:#ffffff; --chart-text:#4b5563; --chart-grid:#eceff3; --chart-border:#cdd3db; --legend-shadow:rgba(255,255,255,.9); }
* { box-sizing: border-box; }
html, body { margin:0; height:100%; background:var(--bg); color:var(--fg);
  font:13px/1.4 -apple-system, "Segoe UI", system-ui, sans-serif; }
body { display:flex; flex-direction:column; height:100dvh; overflow:hidden; }

.topbar { display:flex; align-items:center; gap:6px; padding:6px 8px; background:var(--panel);
  border-bottom:1px solid var(--line); flex:0 0 auto; flex-wrap:wrap; }
.brand { margin-right:2px; }
.topbar button { background:var(--bg); color:var(--fg); border:1px solid var(--line);
  border-radius:6px; padding:5px 9px; font-size:13px; cursor:pointer; }
.topbar button.primary { background:var(--accent); border-color:var(--accent); color:#fff; font-weight:600; }
.topbar button.icon { padding:5px 8px; }
#refreshBtn.spin { animation:spin .45s linear; }
@keyframes spin { from { transform:rotate(0) } to { transform:rotate(360deg) } }
.badge { padding:4px 8px; border-radius:6px; background:var(--bg); border:1px solid var(--line);
  font-variant-numeric:tabular-nums; }
/* 更新関係(↻ ⏸ 更新N分毎 枠)。デスクトップは右寄せインライン */
#statusbar { display:flex; align-items:center; gap:6px; margin-left:auto; }
.badge.warn { color:#f59e0b; border-color:#f59e0b; }
.badge.err { color:#ef4444; border-color:#ef4444; }
.muted { color:var(--muted); }

/* 操作バーを畳む: ≡ だけ残す */
body.bar-collapsed .topbar > :not(#collapseBar) { display:none; }

/* レイアウトメニュー（プレビュー付き） */
.lay-wrap { position:relative; }
.lay-menu { position:absolute; top:100%; left:0; margin-top:5px; z-index:30; background:var(--panel);
  border:1px solid var(--line); border-radius:8px; padding:8px; display:grid;
  grid-template-columns:repeat(3, 70px); gap:8px; box-shadow:0 8px 24px rgba(0,0,0,.45); }
.lay-menu[hidden] { display:none; }
.lay-tile { cursor:pointer; border:1px solid var(--line); border-radius:6px; padding:5px 5px 3px;
  background:var(--bg); }
.lay-tile:hover { border-color:var(--accent); }
.lay-tile.active { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent) inset; }
.lay-prev { display:grid; gap:2px; height:36px; }
.lay-prev > i { background:var(--muted); border-radius:2px; opacity:.55; }
.lay-label { font-size:9px; text-align:center; color:var(--muted); margin-top:3px; }

/* グリッド: 既定は幅で自動列。JSがレイアウトで上書き */
#grid { flex:1 1 auto; min-height:0; display:grid; gap:6px; padding:6px;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  grid-auto-rows: minmax(220px, 1fr); overflow:auto; }
/* 下バー: 既定(デスクトップ)は非表示。statusbarは上バーに居る */
#bottombar { display:none; }

@media (max-width: 760px) {
  #grid:not([data-fixed]) { grid-template-columns: 1fr; }
  /* スマホ: 更新関係(#statusbar)をJSで #bottombar に移し、body最下部のフロー要素として表示 */
  #bottombar { display:flex; flex:0 0 auto; align-items:center; background:var(--panel);
    border-top:1px solid var(--line);
    padding:7px 10px calc(7px + env(safe-area-inset-bottom)) 10px; }
  #bottombar #statusbar { width:100%; margin:0; justify-content:space-between; }
  #bottombar #statusbar .badge { background:transparent; }
}

.panel { position:relative; min-height:0; min-width:0;
  background:var(--panel); border:1px solid var(--line); border-radius:8px; overflow:hidden; }
.pchart { position:absolute; inset:0; }

/* チャート内オーバーレイのレジェンド（TradingView風・左上） */
.legend { position:absolute; top:5px; left:8px; z-index:2; display:flex; flex-direction:column; gap:1px;
  pointer-events:none; text-shadow:0 1px 3px rgba(0,0,0,.85); }
.legend .lg-row { display:flex; align-items:center; gap:3px; pointer-events:auto; }
.legend select { appearance:none; -webkit-appearance:none; background:transparent; border:none;
  color:var(--fg); font-size:13px; font-weight:700; padding:1px 2px; cursor:pointer; border-radius:4px; }
.legend select:hover { background:rgba(255,255,255,.08); }
.legend select.tf { color:#9aa4b2; }
.legend .sep { color:#5a626e; }
.legend .lag { font-size:10px; color:var(--muted); font-variant-numeric:tabular-nums; margin-left:4px; }
.legend .lag.warn { color:#f59e0b; }
.legend .ohlc { font-size:11px; font-variant-numeric:tabular-nums; white-space:nowrap; color:var(--muted); }
.legend .ohlc b { font-weight:600; }
.legend .ohlc .up { color:#26a69a; } .legend .ohlc .dn { color:#ef5350; }

/* ▼ インジ開閉ボタン（OHLCの下） */
.legend .ind-toggle { pointer-events:auto; align-self:flex-start; background:transparent; border:none;
  color:#9aa4b2; font-size:10px; cursor:pointer; padding:1px 2px; margin-top:1px; }
.legend .ind-toggle:hover { color:var(--fg); }

/* インジのレジェンド: 折り畳み対象 */
.ind-legend { display:flex; gap:8px; margin-top:1px; pointer-events:auto; }
.ind-legend .tg { display:flex; align-items:center; gap:3px; color:#9aa4b2; font-size:11px; cursor:pointer; }
.ind-legend .tg input { margin:0; }
.panel.ind-off .ind-legend { display:none; }

/* 右上ツール: × 閉じる */
.ptools { position:absolute; top:5px; right:6px; z-index:2; display:flex; gap:2px; }
.ptools button { background:rgba(127,127,127,.18); border:1px solid transparent; cursor:pointer; line-height:1;
  color:var(--muted); border-radius:5px; padding:2px 6px; font-size:15px; }
.ptools .rm:hover { color:#ef4444; }
