/* ============================================================
   Coindaily - Markets / all-in-one overview page
   Complements styles.css.
   ============================================================ */

.page-hero { padding: 18px 0 18px; border-bottom: 1px solid var(--hairline); }
.page-hero h1 { font-size: 26px; font-weight: 700; color: var(--tx-hi); letter-spacing: -0.025em; }
.page-hero .ph-sub { font-size: 13px; color: var(--tx-dim); margin-top: 6px; max-width: 760px; }
.page-hero .ph-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }

.mkt-tabs { display: flex; gap: 4px; flex-wrap: wrap; }
.mkt-tabs a { padding: 7px 13px; border-radius: 7px; font-size: 13px; color: var(--tx-mid); font-weight: 500; border: 1px solid transparent; transition: .12s; }
.mkt-tabs a:hover { color: var(--tx-hi); background: var(--panel-2); }
.mkt-tabs a.active { color: var(--amber); border-color: rgba(201,154,75,.3); background: rgba(201,154,75,.06); }

/* market-state hero: the dominant focal point */
.market-state { display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap;
  background: linear-gradient(135deg, var(--panel-2) 0%, var(--panel) 60%); border: 1px solid var(--hairline);
  border-radius: var(--r-lg); padding: 17px 22px; margin: 18px 0 0; }
.ms-label { display: flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--tx-dim); margin-bottom: 9px; }
.ms-cap { font-size: 40px; font-weight: 700; letter-spacing: -0.03em; color: var(--tx-hi); line-height: 1; }
.ms-chg { font-size: 12.5px; margin-top: 9px; color: var(--tx-mid); }
.ms-chg.up { color: #5f9277; } .ms-chg.down { color: #ad6670; }
.ms-side { display: flex; gap: 28px; flex-wrap: wrap; }
.ms-stat { display: flex; flex-direction: column; gap: 7px; }
.ms-stat .k { font-family: var(--mono); font-size: 9px; letter-spacing: .07em; text-transform: uppercase; color: var(--tx-dim); }
.ms-stat .v { font-family: var(--mono); font-size: 19px; color: var(--tx-hi); font-weight: 600; }

/* price band: lighter ticker strip, subordinate to the hero */
.price-band { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; margin: 13px 0 0; background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; }
.price-band .mkt-card { border: 0; border-right: 1px solid var(--hairline); border-radius: 0; background: transparent; padding: 12px 15px; }
.price-band .mkt-card:last-child { border-right: 0; }
.price-band .mkt-card:hover { background: var(--panel-2); }

/* group labels for the gauge clusters */
.pulse-group-label { display: flex; align-items: center; gap: 11px; font-family: var(--mono); font-size: 9.5px; letter-spacing: .09em; text-transform: uppercase; color: var(--tx-dim); margin: 13px 0 10px; }
.pulse-group-label::after { content: ""; flex: 1; height: 1px; background: var(--hairline); }

/* top asset cards (legacy class, kept for other usages) */
.mkt-cards { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin: 18px 0; }
.mkt-card { background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--r); padding: 13px 15px; transition: .12s; display: block; }
.mkt-card:hover { border-color: rgba(255,255,255,.14); background: var(--panel-2); }
.mkt-card .top { display: flex; align-items: center; gap: 9px; margin-bottom: 10px; }
.mkt-card .top img { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; background: #16171b; }
.mkt-card .top .s { font-weight: 600; color: var(--tx-hi); font-size: 13px; }
.mkt-card .top .n { font-size: 10.5px; color: var(--tx-dim); }
.mkt-card .row2 { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; }
.mkt-card .px { font-family: var(--mono); font-size: 15px; color: var(--tx-hi); font-weight: 600; letter-spacing: -0.01em; }
.mkt-card .chg { font-family: var(--mono); font-size: 11.5px; }
.mkt-card .spark { height: 28px; margin-top: 8px; }

/* sentiment grid */
.sent-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 14px; }
.sent { background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 15px 17px; }
a.sent { display: block; color: inherit; text-decoration: none; transition: .14s; }
a.sent:hover { border-color: rgba(255,255,255,.18); background: var(--panel-2); transform: translateY(-2px); }
.sent-go { display: block; font-size: 10.5px; color: var(--amber); font-weight: 500; margin-top: 10px; opacity: .55; transition: opacity .14s; }
a.sent:hover .sent-go { opacity: 1; }

/* indicator strip: the remaining gauges, all linked */
.ind-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 20px; }
.ind-tile { display: flex; flex-direction: column; background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 14px 16px 12px; color: inherit; text-decoration: none; transition: .14s; }
.ind-tile:hover { border-color: rgba(255,255,255,.18); background: var(--panel-2); transform: translateY(-2px); }
.it-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 9px; }
.it-l { font-size: 12px; color: var(--tx-mid); font-weight: 500; }
.it-chip.model { font-family: var(--mono); font-size: 8.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--tx-dim); border: 1px solid var(--hairline); border-radius: 4px; padding: 2px 6px; }
.it-val { font-family: var(--mono); font-size: 21px; font-weight: 600; letter-spacing: -0.02em; line-height: 1; margin-bottom: 10px; color: var(--tx-hi); }
.it-dim { color: var(--tx-faint); font-weight: 400; }
.it-zone { position: relative; height: 6px; border-radius: 3px; margin-bottom: 10px; }
.it-zone .zb { position: absolute; inset: 0; border-radius: 3px; opacity: .8; }
.it-zone .zb.mvrv { background: linear-gradient(90deg, #4F9E7C, #C9A24B 45%, #BE5E6C); }
.it-zone .zb.rsi { background: linear-gradient(90deg, #4F9E7C 0 30%, #C9A24B 30% 70%, #BE5E6C 70% 100%); }
.it-zone .zb.rainbow { background: linear-gradient(90deg, #3f63cf, #4a86c0, #46ad93, #6fb358, #bcc74c, #e6c64c, #e9a157, #df7a4c, #d24b3e); }
.it-zone i { position: absolute; top: -3px; width: 2.5px; height: 12px; background: #fff; border-radius: 1px; transform: translateX(-50%); box-shadow: 0 0 0 1.5px rgba(10,13,18,.8); }
.it-split { display: flex; height: 6px; border-radius: 3px; overflow: hidden; margin-bottom: 10px; }
.it-split .lo { background: #4F9E7C; } .it-split .sh { background: #BE5E6C; }
.it-read { font-size: 11.5px; color: var(--tx-mid); line-height: 1.5; }
.it-go { margin-top: auto; padding-top: 9px; font-size: 10.5px; color: var(--amber); font-weight: 500; opacity: .55; transition: opacity .14s; }
.ind-tile:hover .it-go { opacity: 1; }
.sent .h { font-size: 12px; color: var(--tx-mid); margin-bottom: 12px; display: flex; align-items: center; gap: 7px; font-weight: 500; }
.sent .h .q { width: 13px; height: 13px; border: 1px solid var(--hairline); border-radius: 50%; display: inline-grid; place-items: center; font-size: 8px; color: var(--tx-dim); }
/* fear & greed gauge */
.gauge-wrap { display: flex; align-items: center; gap: 16px; }
.gauge { width: 130px; flex-shrink: 0; }
.gauge-val { font-family: var(--mono); font-size: 30px; font-weight: 700; line-height: 1; }
.gauge-lab { font-size: 12px; color: var(--tx-mid); margin-top: 4px; }
/* altcoin season bar */
.alt-val { font-family: var(--mono); font-size: 30px; font-weight: 700; color: var(--tx-hi); line-height: 1; }
.alt-val small { font-size: 13px; color: var(--tx-dim); font-weight: 500; }
.alt-bar { height: 7px; border-radius: 4px; margin: 16px 0 8px; background: linear-gradient(90deg, var(--amber) 0%, var(--amber-dim) 25%, #3a4150 50%, #4a6a9a 75%, #5E86C8 100%); position: relative; }
.alt-bar i { position: absolute; top: -3px; width: 3px; height: 13px; background: #fff; border-radius: 2px; box-shadow: 0 0 6px rgba(0,0,0,.6); }
.alt-ends { display: flex; justify-content: space-between; font-size: 10.5px; color: var(--tx-dim); }
/* dominance mini */
.domm .v { font-family: var(--mono); font-size: 17px; color: var(--tx-hi); font-weight: 600; }
.domm-stack { height: 7px; border-radius: 4px; overflow: hidden; display: flex; margin: 12px 0 9px; }
.domm-stack i { display: block; height: 100%; }
.domm-legend { display: flex; flex-direction: column; gap: 5px; font-size: 11px; }
.domm-legend .lg { display: flex; align-items: center; justify-content: space-between; }
.domm-legend .lg .k { display: flex; align-items: center; gap: 6px; color: var(--tx-mid); }
.domm-legend .lg .k i { width: 7px; height: 7px; border-radius: 2px; }
.domm-legend .lg .v2 { font-family: var(--mono); color: var(--tx-hi); }
/* big stat */
.bigstat .v { font-family: var(--mono); font-size: 22px; color: var(--tx-hi); font-weight: 600; letter-spacing: -0.02em; }
.bigstat .d { font-family: var(--mono); font-size: 12px; margin-top: 6px; }
.bigstat .sub2 { font-size: 11px; color: var(--tx-dim); margin-top: 14px; }
.bigstat .sub2 b { color: var(--tx-mid); font-family: var(--mono); font-weight: 600; }

/* market cap chart */
.mc-wrap { position: relative; padding: 14px 16px 8px; }
.mc-svg { width: 100%; height: 230px; display: block; }
/* market-cap chart loading skeleton - shimmer until the real CoinGlass history lands (never a modelled chart) */
body.mc-loading #mc-svg { opacity: 0; }
body.mc-loading #mc-wrap::after {
  content: ""; position: absolute; left: 16px; right: 16px; top: 14px; bottom: 14px; border-radius: 8px; pointer-events: none;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: mk-shimmer 1.3s ease-in-out infinite; }
.mc-ylab { position: absolute; right: 14px; font-family: var(--mono); font-size: 10.5px; font-weight: 500; color: var(--tx); background: var(--panel); padding: 0 4px; transform: translateY(-50%); pointer-events: none; }
.mc-xlab { position: absolute; bottom: 6px; font-family: var(--mono); font-size: 10.5px; font-weight: 500; color: var(--tx); transform: translateX(-50%); }

/* macro strip */
.macro-strip { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: var(--hairline-2); border: 1px solid var(--hairline); border-radius: var(--r); overflow: hidden; }
.macro-strip .m { background: var(--panel); padding: 13px 15px; }
.macro-strip .m .l { font-size: 10px; color: var(--tx-dim); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.macro-strip .m .l .cc { font-family: var(--mono); font-size: 8.5px; color: var(--amber); border: 1px solid var(--hairline); border-radius: 2px; padding: 0 3px; }
.macro-strip .m .v { font-family: var(--mono); font-size: 16px; color: var(--tx-hi); font-weight: 600; }
.macro-strip .m .d { font-family: var(--mono); font-size: 10.5px; margin-top: 4px; }
.macro-strip .m.m-pend { opacity: .5; }
.macro-strip .m.m-pend .d { color: var(--tx-dim); font-style: italic; }

/* screener toolbar */
.scr-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 16px; border-bottom: 1px solid var(--hairline); flex-wrap: wrap; }
.scr-filters { display: flex; gap: 3px; flex-wrap: wrap; }
.scr-filters button { padding: 6px 12px; border-radius: 7px; font-size: 12.5px; color: var(--tx-mid); font-weight: 500; border: 1px solid transparent; transition: .12s; font-family: var(--sans); display: inline-flex; align-items: center; gap: 5px; }
.scr-filters button:hover { color: var(--tx-hi); background: var(--panel-2); }
.scr-filters button.active { color: var(--amber); border-color: rgba(201,154,75,.3); background: rgba(201,154,75,.06); }
.scr-filters .fav-star { color: var(--amber); font-size: 11px; }
.scr-filters .fav-count { font-family: var(--mono); font-size: 10px; color: var(--tx-dim); }
.scr-right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.scr-search { display: flex; align-items: center; gap: 7px; background: var(--panel-2); border: 1px solid var(--hairline); border-radius: 8px; padding: 6px 11px; transition: .12s; }
.scr-search:focus-within { border-color: rgba(201,154,75,.4); }
.scr-search svg { width: 13px; height: 13px; stroke: var(--tx-dim); fill: none; stroke-width: 2; }
.scr-search input { background: none; border: none; outline: none; color: var(--tx-hi); font-size: 12.5px; width: 168px; font-family: var(--sans); }
.scr-search input::placeholder { color: var(--tx-faint); }
.scr-per { display: flex; align-items: center; gap: 8px; }
.scr-per > span { font-size: 11px; color: var(--tx-dim); font-family: var(--mono); }
.scr-per .idx-tabs { display: inline-flex; gap: 1px; background: var(--hairline-2); border: 1px solid var(--hairline); border-radius: 7px; overflow: hidden; }
.scr-per .idx-tabs button { padding: 5px 11px; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); background: var(--panel); transition: .12s; }
.scr-per .idx-tabs button:hover { color: var(--tx-hi); }
.scr-per .idx-tabs button.active { color: var(--amber); background: rgba(201,154,75,.09); }

/* screener table */
.scr-scroll { overflow-x: auto; }
.scr-scroll .screener { min-width: 920px; }
table.screener thead th.asset-h { text-align: left; }
.screener thead th.spark-h { text-align: right; }
.screener td.star, .screener th.star-h { width: 30px; text-align: center; }
.screener td.star { color: var(--tx-faint); cursor: pointer; font-size: 14px; transition: .1s; }
.screener td.star:hover { color: var(--amber); transform: scale(1.18); }
.screener td.star.on { color: var(--amber); }
.screener td.rank { color: var(--tx-faint); font-family: var(--mono); font-size: 12px; }
.screener td.supply { font-family: var(--mono); color: var(--tx-mid); }
.screener td.supply .sup-sym { color: var(--tx-faint); font-size: 10px; }
.screener .num1h { font-family: var(--mono); }
.screener tbody tr { cursor: pointer; }

@media (max-width: 1180px) { .screener .col-mid { display: none; } }
@media (max-width: 920px) { .screener .col-hide { display: none; } }

/* pagination */
.pager { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 16px; flex-wrap: wrap; }
.pager button { min-width: 32px; height: 32px; padding: 0 9px; border: 1px solid var(--hairline); background: var(--panel); border-radius: 6px; font-family: var(--mono); font-size: 12px; color: var(--tx-mid); transition: .12s; }
.pager button:hover:not(:disabled) { color: var(--tx-hi); border-color: rgba(255,255,255,.2); }
.pager button.active { background: var(--amber); color: #100B02; border-color: var(--amber); font-weight: 600; }
.pager button:disabled { opacity: .35; cursor: default; }
.pager .info { font-size: 11.5px; color: var(--tx-dim); margin-left: 8px; }

/* gainers & losers */
.gl-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.gl-row { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--hairline-2); font-size: 13px; }
.gl-row:last-child { border-bottom: none; }
.gl-row:hover { background: rgba(255,255,255,.018); }
.gl-row img { width: 20px; height: 20px; border-radius: 50%; object-fit: cover; background: #16171b; }
.gl-row .s { font-weight: 600; color: var(--tx-hi); }
.gl-row .px { margin-left: auto; font-family: var(--mono); color: var(--tx-mid); }
.gl-row .chg { font-family: var(--mono); min-width: 70px; text-align: right; }

/* heatmap treemap */
.tm-wrap { position: relative; width: 100%; height: 380px; }
.tm-tile { position: absolute; border: 1px solid rgba(10,10,11,.6); display: flex; flex-direction: column; align-items: center; justify-content: center; overflow: hidden; cursor: default; transition: filter .1s; }
.tm-tile:hover { filter: brightness(1.18); }
.tm-tile .ts { font-weight: 700; color: #fff; line-height: 1.05; }
.tm-tile .tc { font-family: var(--mono); color: rgba(255,255,255,.88); }

@media (max-width: 1100px) {
  .mkt-cards { grid-template-columns: repeat(3, 1fr); }
  .sent-grid { grid-template-columns: 1fr 1fr; } .ind-strip { grid-template-columns: 1fr 1fr; }
  .macro-strip { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .mkt-cards { grid-template-columns: repeat(2, 1fr); }
  .sent-grid { grid-template-columns: 1fr; } .ind-strip { grid-template-columns: 1fr; }
  .gl-grid { grid-template-columns: 1fr; }
  .macro-strip { grid-template-columns: repeat(2, 1fr); }
  .price-band { grid-template-columns: repeat(2, 1fr); }
  .price-band .mkt-card:nth-child(2) { border-right: 0; }
  .price-band .mkt-card { border-bottom: 1px solid var(--hairline); }
  .market-state { padding: 15px 17px; }
  .ms-cap { font-size: 32px; }
}
@media (max-width: 560px) {
  .price-band { grid-template-columns: 1fr; }
  .price-band .mkt-card { border-right: 0; }
}

/* ============ cross-asset performance ============ */
.ca-wrap { padding: 16px 20px 6px; overflow-x: auto; }
.ca-chart { position: relative; height: 176px; display: flex; align-items: stretch; min-width: 660px; }
.ca-zero { position: absolute; left: 0; right: 0; top: 50%; height: 1px; background: rgba(255,255,255,.13); z-index: 1; }
.ca-col { flex: 1; position: relative; cursor: default; }
.ca-col:hover .ca-bar { filter: brightness(1.2); }
.ca-col.ca-pend { opacity: .5; }
.ca-pend-mark { position: absolute; left: -24px; right: -24px; text-align: center; transform: translateY(-50%); font-family: var(--mono); font-size: 13px; color: var(--tx-dim); }
.ca-name.pend { color: var(--tx-dim); }
.ca-bar { position: absolute; left: 24%; right: 24%; min-height: 3px; z-index: 2; transition: height .35s cubic-bezier(.4,0,.2,1); }
.ca-bar.up { bottom: 50%; background: linear-gradient(180deg, rgba(79,158,124,.16), rgba(79,158,124,.42)); border-top: 2.5px solid #4F9E7C; border-radius: 3px 3px 0 0; }
.ca-bar.down { top: 50%; background: linear-gradient(0deg, rgba(190,94,108,.16), rgba(190,94,108,.42)); border-bottom: 2.5px solid #BE5E6C; border-radius: 0 0 3px 3px; }
.ca-bar.live.up { box-shadow: inset 0 0 0 1px rgba(201,154,75,.45); }
.ca-bar.live.down { box-shadow: inset 0 0 0 1px rgba(201,154,75,.45); }
.ca-val { position: absolute; left: -24px; right: -24px; text-align: center; font-family: var(--mono); font-size: 11px; white-space: nowrap; }
.ca-bar.up .ca-val { top: -17px; color: #5f9277; }
.ca-bar.down .ca-val { bottom: -17px; color: #ad6670; }
.ca-names { display: flex; padding-top: 11px; min-width: 660px; }
.ca-name { flex: 1; text-align: center; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); letter-spacing: .02em; }
.ca-name.live { color: var(--tx-mid); }
.ca-read { padding: 15px 20px; border-top: 1px solid var(--hairline); font-size: 13px; color: var(--tx-mid); line-height: 1.6; }
.ca-read b { color: var(--tx-hi); font-weight: 600; }
.ca-read .ca-lead { color: var(--amber); font-weight: 600; }
.ca-read .up { color: #5f9277; } .ca-read .down { color: #ad6670; }
.ca-foot { display: flex; justify-content: space-between; padding: 9px 20px 14px; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); }

/* ============================================================
   Loading skeleton (body.mk-loading) - shimmer the live coin
   data (global top-line, price-band cards, screener rows,
   gainers/losers) until the real Coinranking data lands.
   Never paint modelled numbers first. Mirrors /price/.
   ============================================================ */
@keyframes mk-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }
.mk-sk { display: inline-block; vertical-align: middle; border-radius: 4px;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: mk-shimmer 1.3s ease-in-out infinite; }
/* global top-line numbers - shimmer during the full-page load (mk-loading) AND whenever the
   global stat isn't real yet (mk-gl-pending) so the modelled fallback never flashes */
body.mk-loading #ms-mcap, body.mk-loading #ms-vol, body.mk-loading #ms-dom,
body.mk-gl-pending #ms-mcap, body.mk-gl-pending #ms-vol, body.mk-gl-pending #ms-dom {
  color: transparent !important; border-radius: 5px;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: mk-shimmer 1.3s ease-in-out infinite; }
body.mk-loading #ms-mcap-d, body.mk-gl-pending #ms-mcap-d { visibility: hidden; }
/* today's-gauges tiles (Fear&Greed / Altcoin / Dominance mini) shimmer during the full-page load */
body.mk-loading #fg-num, body.mk-loading #fg-lab, body.mk-loading #ms-mood,
body.mk-loading #alt-num, body.mk-loading #alt-lab,
body.mk-loading #dm-btc, body.mk-loading #dm-eth, body.mk-loading #dm-oth {
  color: transparent !important; border-radius: 5px;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: mk-shimmer 1.3s ease-in-out infinite; }
body.mk-loading #fg-gauge, body.mk-loading #alt-needle, body.mk-loading #dm-stk-btc,
body.mk-loading #dm-stk-eth, body.mk-loading #dm-stk-oth { visibility: hidden; }
/* price-band cards */
.mk-sk-card { pointer-events: none; }
.mk-sk-card .mk-sk-ic { width: 22px; height: 22px; border-radius: 50%; }
.mk-sk-card .mk-sk-tx { width: 56px; height: 11px; }
.mk-sk-card .mk-sk-px { width: 80px; height: 13px; }
.mk-sk-card .mk-sk-spk { display: block; width: 100%; height: 28px; margin-top: 8px; border-radius: 6px; }
/* screener rows */
.mk-sk-row td { padding: 11px 10px; }
.mk-sk-row .mk-sk { width: 58px; height: 11px; }
.mk-sk-row .mk-sk-sm { width: 38px; }
.mk-sk-row .mk-sk-ic { width: 20px; height: 20px; border-radius: 50%; margin-right: 8px; }
.mk-sk-row .mk-sk-tx { width: 64px; height: 11px; }
.mk-sk-row .mk-sk-spk { width: 60px; height: 22px; border-radius: 4px; }
/* gainers / losers rows (mirror .gl-row) */
.mk-sk-glrow { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--hairline-2); }
.mk-sk-glrow:last-child { border-bottom: none; }
.mk-sk-glrow .mk-sk-ic { width: 20px; height: 20px; border-radius: 50%; }
.mk-sk-glrow .mk-sk-tx { width: 54px; height: 11px; }
.mk-sk-glrow .mk-sk-sm { width: 64px; height: 11px; margin-left: auto; }
