/* styles/markets.css — MARKETS page widgets */

/* indices grid */
.idx-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; height: 100%; min-height: 0; }
.idx-cell {
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 4px;
  padding: 8px 10px;
  display: grid; gap: 2px;
  min-width: 0;
}
.idx-cell__top { display: flex; justify-content: space-between; align-items: baseline; }
.idx-cell__reg { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em; color: var(--gold-soft); }
.idx-cell__chg { font-family: var(--font-mono); font-size: 11px; font-weight: 600; }
.idx-cell__sym { font-family: var(--font-mono); font-size: 12.5px; font-weight: 700; color: var(--txt-1); letter-spacing: 0.04em; }
.idx-cell__nm  { font-family: var(--font-mono); font-size: 9.5px; color: var(--txt-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.idx-cell__val { font-family: var(--font-mono); font-size: 15px; font-weight: 600; color: var(--txt-1); margin-top: 2px; line-height: 1.1; }
.idx-cell__ytd { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9.5px; color: var(--txt-3); padding-top: 2px; border-top: 1px solid rgba(255,255,255,0.04); margin-top: 2px; }

/* sector bars (bidirectional, centered) */
.sectors { display: flex; flex-direction: column; gap: 5px; font-family: var(--font-mono); font-size: 11px; }
.sectors__row { display: grid; grid-template-columns: 36px 90px 1fr 56px 44px; gap: 8px; align-items: center; }
.sectors__sym { font-weight: 700; color: var(--txt-1); font-size: 10.5px; }
.sectors__nm  { color: var(--txt-2); font-size: 10.5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sectors__track { position: relative; height: 8px; background: rgba(255,255,255,0.03); border-radius: 1.5px; }
.sectors__track::before { content: ''; position: absolute; top: 0; bottom: 0; left: 50%; width: 1px; background: rgba(201,168,106,0.4); }
.sectors__bar { position: absolute; top: 0; bottom: 0; }
.sectors__bar--right { left: 50%; }
.sectors__bar--left { right: 50%; }
.sectors__bar--up { background: linear-gradient(90deg, rgba(52,211,153,0.45),  rgba(52,211,153,0.9)); }
.sectors__bar--dn { background: linear-gradient(270deg,rgba(248,113,113,0.45), rgba(248,113,113,0.9)); }
.sectors__chg { text-align: right; font-weight: 600; }
.sectors__wt { text-align: right; font-size: 10px; }

/* megacap */
.megacap { font-family: var(--font-mono); font-size: 11.5px; }
.megacap__row {
  display: grid;
  grid-template-columns: 24px 56px 1fr 70px 60px 64px;
  gap: 10px;
  align-items: center;
  padding: 6px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.megacap__row:last-child { border-bottom: 0; }
.megacap__rk  { color: var(--txt-3); font-size: 10px; }
.megacap__sym { font-weight: 700; color: var(--txt-1); letter-spacing: 0.04em; }
.megacap__nm  { font-size: 10.5px; }
.megacap__px  { text-align: right; color: var(--txt-1); }
.megacap__chg { text-align: right; font-weight: 600; }
.megacap__mcap{ text-align: right; color: var(--gold-soft); font-size: 11px; }

/* breadth */
.breadth { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; height: 100%; }
.breadth__cell {
  border-radius: 4px;
  padding: 8px 10px;
  display: grid; gap: 2px;
  border: 1px solid rgba(255,255,255,0.04);
}
.breadth__lbl { font-family: var(--font-mono); font-size: 9px; color: var(--txt-3); letter-spacing: 0.16em; text-transform: uppercase; }
.breadth__val { font-family: var(--font-mono); font-size: 15px; font-weight: 600; }

/* sessions */
.sessions { display: flex; flex-direction: column; }
.sessions__row {
  display: grid;
  grid-template-columns: 12px 1fr 56px 56px;
  gap: 10px;
  align-items: center;
  padding: 7px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-family: var(--font-mono);
  font-size: 11.5px;
}
.sessions__row:last-child { border-bottom: 0; }
.sessions__dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.18); }
.sessions__dot.is-on { background: var(--up); box-shadow: 0 0 6px rgba(52,211,153,0.6); }
.sessions__nm { color: var(--txt-1); font-weight: 600; }
.sessions__tz { font-size: 10px; }
.sessions__s  { text-align: right; font-weight: 600; font-size: 10.5px; letter-spacing: 0.08em; }
.gold { color: var(--gold-soft); }

@media (max-width: 1100px) {
  .idx-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 820px) {
  .idx-grid { grid-template-columns: repeat(2, 1fr); }
  .sectors__row { grid-template-columns: 36px 1fr 56px 44px; }
  .sectors__nm { display: none; }
  .megacap__row { grid-template-columns: 24px 56px 1fr 60px 64px; }
  .megacap__nm { display: none; }
}

/* ---------- Single-name movers (top SPX gainers + losers) ---------- */
.single-movers { font-family: var(--font-mono); font-size: 11.5px; }
.single-movers__row {
  display: grid;
  grid-template-columns: 22px 52px 1fr 54px 56px;
  align-items: center; gap: 8px;
  padding: 7px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.single-movers__row:last-child { border-bottom: 0; }
.single-movers__row:hover { background: rgba(201,165,92,0.04); }
.single-movers__rk { color: var(--txt-3); font-size: 10px; }
.single-movers__sym { font-weight: 700; color: var(--txt-1); letter-spacing: 0.04em; }
.single-movers__bar-wrap { height: 6px; background: rgba(255,255,255,0.04); border-radius: 1.5px; overflow: hidden; }
.single-movers__bar { height: 100%; }
.single-movers__bar.up-bg { background: linear-gradient(90deg, rgba(52,211,153,0.85),  rgba(52,211,153,0.4)); }
.single-movers__bar.dn-bg { background: linear-gradient(90deg, rgba(248,113,113,0.85), rgba(248,113,113,0.4)); }
.single-movers__chg { text-align: right; font-weight: 600; }
.single-movers__vol { text-align: right; font-size: 10px; color: var(--txt-3); }

@media (max-width: 1100px) {
  .single-movers__row { grid-template-columns: 22px 52px 1fr 54px; }
  .single-movers__vol { display: none; }
}

/* ---------- Mobile typography floor · GMG_STANDARDS §5 ---------- */
@media (max-width: 899px) {
  /* Caption ≥ 11px */
  .ftable__nm,
  .idx-cell__reg, .idx-cell__nm, .idx-cell__ytd,
  .sectors__sym, .sectors__nm, .sectors__wt,
  .megacap__nm, .megacap__mcap, .megacap__rk,
  .single-movers__rk, .single-movers__vol,
  .sessions__tz, .sessions__s,
  .ftable thead th, .breadth__lbl,
  .onchain__lbl, .onchain__sub, .onchain__hint
  { font-size: 11px !important; line-height: 1.25 !important; }
  /* Body ≥ 13px */
  .idx-cell__sym, .idx-cell__val,
  .sectors__chg, .megacap__sym, .megacap__px, .megacap__chg,
  .single-movers__sym, .single-movers__chg,
  .sessions__nm,
  .ftable tbody td,
  .breadth__val, .onchain__val
  { font-size: 13px !important; line-height: 1.3 !important; }
  /* Indices grid stays 2-col on phones */
  .idx-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 6px; }
  /* Microspark hidden — no horizontal room */
  .microspark { display: none; }
}
