/* GADROCRYPTO — styles */
* { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #0b0e11;
  --bg2: #11161c;
  --bg3: #171d24;
  --line: #232b34;
  --tx: #e8edf2;
  --tx2: #94a0ad;
  --accent: #00e676;
  --up: #0ecb81;
  --down: #f6465d;
}
[data-theme="light"] {
  --bg: #f2f4f7;
  --bg2: #ffffff;
  --bg3: #e9edf1;
  --line: #d7dee5;
  --tx: #15202b;
  --tx2: #5b6770;
}

[hidden] { display: none !important; }

html, body {
  background: var(--bg);
  color: var(--tx);
  font-family: Inter, "Segoe UI", system-ui, -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased;
}
button { font-family: inherit; }
input, select { font-family: inherit; }

/* ---------- top bar ---------- */
.topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--bg2);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 50;
  flex-wrap: wrap;
}
.brand { display: flex; align-items: center; gap: 8px; user-select: none; }
.brand-name { font-weight: 800; font-size: 19px; letter-spacing: .4px; }
.brand-name em { font-style: normal; color: var(--accent); }

.searchbox { position: relative; flex: 1 1 200px; max-width: 420px; }
.searchbox input {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 8px;
  padding: 8px 64px 8px 12px;
  font-size: 14px;
  outline: none;
}
.searchbox input:focus { border-color: var(--accent); }
.search-count {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  color: var(--tx2);
  pointer-events: none;
}
.search-results {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,.5);
  z-index: 80;
  overflow: hidden;
  max-height: 60vh;
  overflow-y: auto;
}
.sr-row {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 11px;
  cursor: pointer;
  border-bottom: 1px solid var(--line);
}
.sr-row:last-child { border-bottom: 0; }
.sr-row:hover { background: var(--bg3); }
.sr-row img { width: 20px; height: 20px; border-radius: 50%; flex: none; }
.sr-name { font-weight: 600; font-size: 13px; }
.sr-sym { color: var(--tx2); font-size: 11px; font-weight: 700; }
.sr-rank { margin-left: auto; color: var(--tx2); font-size: 11px; }
.sr-tag {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  background: rgba(0,230,118,.15);
  color: var(--accent);
  border-radius: 5px;
  padding: 1px 6px;
}

.top-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; flex-wrap: wrap; }

.pill { font-size: 10px; font-weight: 700; letter-spacing: .8px; padding: 4px 9px; border-radius: 99px; white-space: nowrap; }
.pill.loading { background: rgba(255,255,255,.08); color: var(--tx2); }
.pill.live { background: rgba(14,203,129,.15); color: var(--up); }
.pill.live::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--up);
  margin-right: 5px;
  animation: pulse 1.6s infinite;
}
.pill.stale { background: rgba(240,185,11,.15); color: #f0b90b; }
.pill.demo { background: rgba(167,139,250,.18); color: #a78bfa; }
@keyframes pulse { 50% { opacity: .3; } }

.countdown { font-size: 11px; color: var(--tx2); min-width: 30px; text-align: right; font-variant-numeric: tabular-nums; }

.icon-btn {
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  height: 34px;
  min-width: 34px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 15px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.icon-btn:hover { border-color: var(--accent); }
.icon-btn.spinning { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.badge {
  position: absolute;
  top: -5px; right: -5px;
  background: var(--accent);
  color: #04140b;
  font-size: 10px;
  font-weight: 700;
  border-radius: 99px;
  padding: 1px 5px;
}
.pf-btn { width: auto; padding: 0 10px; gap: 6px; }
.pf-chip { font-size: 11px; font-weight: 700; color: var(--accent); }

/* ---------- stats bar ---------- */
.statsbar {
  display: flex;
  gap: 8px;
  padding: 8px 14px;
  overflow-x: auto;
  border-bottom: 1px solid var(--line);
  scrollbar-width: none;
}
.statsbar::-webkit-scrollbar { display: none; }
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--bg2);
  border: 1px solid var(--line);
  padding: 5px 11px;
  border-radius: 99px;
  font-size: 12px;
  white-space: nowrap;
  flex: none;
}
.chip-l { color: var(--tx2); font-size: 11px; }
.chip-v { font-weight: 700; }
.chip-d { font-size: 11px; font-weight: 600; color: var(--tx2); }
.chip-d.up { color: var(--up); }
.chip-d.down { color: var(--down); }
.fng-dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }

/* ---------- ticker tape ---------- */
.ticker { overflow: hidden; border-bottom: 1px solid var(--line); background: var(--bg2); }
.ticker:hover .ticker-track { animation-play-state: paused; }
.ticker-track { display: inline-flex; width: max-content; animation: tickmove 60s linear infinite; padding: 6px 0; }
@keyframes tickmove { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .ticker-track { animation: none; } }
.tick-item {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  padding: 0 16px;
  border-right: 1px solid var(--line);
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
}
.tick-item:hover .tick-sym { color: var(--accent); }
.tick-sym { font-weight: 700; }
.tick-pr { color: var(--tx2); }
.tick-pc.up { color: var(--up); }
.tick-pc.down { color: var(--down); }

/* ---------- toolbar ---------- */
.toolbar { display: flex; align-items: center; gap: 8px; padding: 9px 14px; flex-wrap: wrap; }
.seg { display: inline-flex; background: var(--bg3); border: 1px solid var(--line); border-radius: 8px; overflow: hidden; flex: none; }
.seg button {
  background: transparent;
  border: 0;
  color: var(--tx2);
  padding: 7px 13px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
}
.seg button.active { background: var(--accent); color: #04140b; }
.sel {
  background: var(--bg3);
  color: var(--tx);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 7px 9px;
  font-size: 12.5px;
  cursor: pointer;
}
.tog {
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx2);
  border-radius: 8px;
  padding: 7px 12px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
}
.tog:hover { color: var(--tx); }
.tog.active { color: var(--accent); border-color: var(--accent); background: rgba(0,230,118,.08); }

.banner {
  margin: 0 14px 8px;
  padding: 9px 13px;
  border-radius: 8px;
  font-size: 13px;
  background: rgba(167,139,250,.12);
  color: #b9a5fb;
  border: 1px solid rgba(167,139,250,.35);
}
.banner.stale { background: rgba(240,185,11,.1); color: #f0b90b; border-color: rgba(240,185,11,.35); }

main { padding: 0 14px 10px; }

/* ---------- heatmap ---------- */
.heatmap { position: relative; width: 100%; border-radius: 10px; overflow: hidden; background: var(--bg2); }
.tile {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  cursor: pointer;
  border-radius: 2px;
  color: #fff;
  line-height: 1.18;
  background: transparent; /* color + 7d chart are painted on .hm-canvas behind */
  z-index: 1;
  contain: strict;
}
.tile:hover { background: rgba(255,255,255,.16); z-index: 2; outline: 1px solid rgba(255,255,255,.6); }
.tile:focus-visible { z-index: 3; outline: 2px solid var(--accent); outline-offset: -2px; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.tile .tl { text-shadow: 0 1px 2px rgba(0,0,0,.45); white-space: nowrap; max-width: 100%; }
.tile .sym { font-weight: 800; letter-spacing: .3px; }
.tile .pr { font-weight: 500; opacity: .96; }
.tile .pc { font-weight: 600; opacity: .96; }
.tile-star {
  position: absolute;
  top: 1px; right: 4px;
  font-size: 10px;
  color: #ffd54a;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
.ghead {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  color: #cfd6dd;
  background: rgba(0,0,0,.5);
  overflow: hidden;
  white-space: nowrap;
  z-index: 1;
}
[data-theme="light"] .ghead { background: rgba(0,0,0,.55); }
.ghead { cursor: pointer; }
.ghead:hover { background: rgba(0,0,0,.72); color: #fff; }
.ghead:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
.ghead .share { color: #8b949e; font-weight: 600; }
.empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tx2);
  font-size: 14px;
}

/* ---------- bubbles ---------- */
.bubbles-wrap {
  position: relative;
  width: 100%;
  border-radius: 10px;
  overflow: hidden;
  background: radial-gradient(ellipse at center, var(--bg2) 0%, var(--bg) 100%);
  border: 1px solid var(--line);
}
.bubbles-wrap canvas { display: block; }

/* ---------- table ---------- */
.table-wrap { overflow: auto; border: 1px solid var(--line); border-radius: 10px; background: var(--bg2); }
table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 880px; }
thead th {
  position: sticky;
  top: 0;
  background: var(--bg3);
  color: var(--tx2);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .4px;
  padding: 9px 10px;
  text-align: right;
  z-index: 1;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
th.sortable { cursor: pointer; user-select: none; }
th.sortable:hover { color: var(--tx); }
th.sorted-asc::after { content: ' ▲'; font-size: 9px; }
th.sorted-desc::after { content: ' ▼'; font-size: 9px; }
tbody td { padding: 7px 10px; border-bottom: 1px solid var(--line); text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
tbody tr { cursor: pointer; }
tbody tr:hover { background: var(--bg3); }
.coin-cell { text-align: left !important; min-width: 170px; }
.coin-cell img { width: 20px; height: 20px; border-radius: 50%; vertical-align: -5px; margin-right: 8px; }
.cname { font-weight: 600; margin-right: 7px; }
.csym { color: var(--tx2); font-size: 11px; font-weight: 700; }
td.up { color: var(--up); }
td.down { color: var(--down); }
.star-cell { width: 34px; text-align: center !important; color: var(--tx2); font-size: 14px; }
.star-cell.on { color: #ffd54a; }
.num { text-align: right; }
.spark-cell { width: 118px; }
.spark-cell canvas { display: block; }

/* ---------- footer ---------- */
.foot {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  padding: 12px 16px 18px;
  color: var(--tx2);
  font-size: 12px;
}
.foot a { color: var(--accent); text-decoration: none; }

/* ---------- tooltip ---------- */
.tooltip {
  position: fixed;
  z-index: 90;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 11px;
  font-size: 12px;
  pointer-events: none;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
  min-width: 190px;
}
.tooltip .tt-head { display: flex; gap: 4px; align-items: baseline; font-weight: 700; margin-bottom: 5px; }
.tooltip .row { display: flex; justify-content: space-between; gap: 14px; color: var(--tx2); line-height: 1.6; }
.tooltip .row b { color: var(--tx); font-weight: 600; }
.tooltip .row b.up { color: var(--up); }
.tooltip .row b.down { color: var(--down); }

/* ---------- toasts ---------- */
.toasts {
  position: fixed;
  right: 14px;
  bottom: 14px;
  z-index: 120;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 340px;
}
.toast {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: 8px;
  padding: 10px 13px;
  font-size: 13px;
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
  cursor: pointer;
  animation: slidein .18s ease;
  transition: opacity .3s;
}
.toast.warn { border-left-color: #f0b90b; }
.toast.alert { border-left-color: var(--down); }
@keyframes slidein { from { transform: translateY(8px); opacity: 0; } }

/* ---------- modals ---------- */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.modal.open { display: flex; }
.sheet {
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 14px;
  width: 100%;
  max-width: 580px;
  max-height: 90vh;
  max-height: 90dvh;
  overflow: auto;
  position: relative;
  padding: 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.sheet-x {
  position: absolute;
  top: 8px; right: 12px;
  background: none;
  border: 0;
  color: var(--tx2);
  font-size: 24px;
  cursor: pointer;
  line-height: 1;
}
.sheet-x:hover { color: var(--tx); }
.sheet-title { font-size: 16px; margin-bottom: 12px; }

.cm-head { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
.cm-head img { width: 36px; height: 36px; border-radius: 50%; }
.cm-name { font-size: 17px; font-weight: 700; }
.cm-sym { color: var(--tx2); font-weight: 700; font-size: 12px; }
.rank-chip {
  font-size: 10px;
  background: var(--bg3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 2px 7px;
  color: var(--tx2);
  font-weight: 600;
}
.cm-price { font-size: 27px; font-weight: 800; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 4px 0; }
.pct-badge { font-size: 12.5px; font-weight: 700; padding: 3px 9px; border-radius: 6px; }
.pct-badge.up { background: rgba(14,203,129,.15); color: var(--up); }
.pct-badge.down { background: rgba(246,70,93,.15); color: var(--down); }
.cm-badges { display: flex; gap: 12px; margin: 6px 0; flex-wrap: wrap; font-size: 11.5px; color: var(--tx2); align-items: center; }
.cm-badges b { font-weight: 700; }
.cm-badges b.up { color: var(--up); }
.cm-badges b.down { color: var(--down); }
.cm-chart { margin: 10px 0 2px; }
.cm-chart canvas { width: 100%; height: 150px; display: block; }
.chart-range { display: flex; justify-content: space-between; color: var(--tx2); font-size: 11px; margin-top: 3px; min-height: 15px; }
.cm-chart-seg { margin-bottom: 8px; }
.cm-chart-seg button { padding: 5px 12px; font-size: 12px; }
.cm-links { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0 2px; }
.link-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  text-decoration: none;
  border-radius: 99px;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
}
.link-chip:hover { border-color: var(--accent); color: var(--accent); }
.cm-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; margin: 12px 0; }
.cm-grid .cell { background: var(--bg3); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; }
.cell .k { font-size: 10px; color: var(--tx2); text-transform: uppercase; letter-spacing: .4px; }
.cell .v { font-weight: 700; font-size: 13px; margin-top: 2px; }
.cm-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }

.btn {
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 8px;
  padding: 8px 13px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.btn:hover { border-color: var(--accent); }
.btn.primary { background: var(--accent); color: #04140b; border-color: var(--accent); }
.btn.danger { color: var(--down); }
.btn.danger:hover { border-color: var(--down); }
.btn.on { color: #ffd54a; border-color: #ffd54a; background: rgba(255,213,74,.08); }

.cm-form {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
  flex-wrap: wrap;
  background: var(--bg3);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
}
.cm-form select, .cm-form input {
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 7px;
  padding: 7px 9px;
  font-size: 13px;
}
.cm-form input { width: 150px; }
.muted { color: var(--tx2); font-size: 11.5px; line-height: 1.55; }
p.muted { margin-top: 12px; }

.alert-row, .pf-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 2px;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}
.alert-row .grow, .pf-row .grow { flex: 1; min-width: 60px; }
.status-tag { font-size: 10px; font-weight: 700; border-radius: 6px; padding: 2px 7px; white-space: nowrap; }
.status-tag.active { background: rgba(14,203,129,.15); color: var(--up); }
.status-tag.done { background: rgba(240,185,11,.15); color: #f0b90b; }
.status-tag.paused { background: rgba(255,255,255,.07); color: var(--tx2); }
.pf-total { display: flex; justify-content: space-between; align-items: center; padding: 2px 2px 12px; gap: 10px; flex-wrap: wrap; }
.pf-total .tv { font-size: 25px; font-weight: 800; }
.pf-row input {
  width: 110px;
  background: var(--bg);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 7px;
  padding: 6px 8px;
  font-size: 13px;
  text-align: right;
}

/* ---------- GADROCRYPTO watermark — big embossed diagonal across the map ---------- */
.heatmap::after, .bubbles-wrap::after {
  content: 'GADROCRYPTO';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-28deg);
  font-weight: 800;
  letter-spacing: .14em;
  font-size: clamp(28px, 8vw, 120px);
  line-height: 1;
  white-space: nowrap;
  color: rgba(255,255,255,.12);
  text-shadow: 1px 1px 1px rgba(0,0,0,.22), -1px -1px 1px rgba(255,255,255,.12);
  pointer-events: none;
  user-select: none;
  z-index: 3;
}
/* faint 7d chart layer drawn behind tile labels (CoinGecko-card style) */
.hm-canvas { position: absolute; inset: 0; z-index: 0; pointer-events: none; }

/* ---------- derivatives ---------- */
.derivs-bar { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 2px 0 8px; }
.derivs-stats { border-bottom: 0; padding: 0 0 8px; }
.fundmap { border: 1px solid var(--line); }
td.fr-cell { font-weight: 700; }
body.derivs-mode #periodSeg,
body.derivs-mode #topNSel,
body.derivs-mode #currencySel,
body.derivs-mode #groupTog,
body.derivs-mode #peggedTog,
body.derivs-mode #watchTog { display: none; }

/* ---------- embed modal ---------- */
.sheet-wide { max-width: 700px; }
.embed-opts { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 12px; }
.embed-opts label { font-size: 11.5px; color: var(--tx2); display: flex; align-items: center; gap: 5px; }
.embed-opts select, .embed-opts input[type="number"] {
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 7px;
  padding: 6px 8px;
  font-size: 12.5px;
}
.embed-opts input[type="number"] { width: 76px; }
.embed-preview { border: 1px solid var(--line); border-radius: 10px; overflow: hidden; margin-bottom: 12px; background: var(--bg); }
.embed-preview iframe { display: block; width: 100%; border: 0; }
.embed-code {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--line);
  color: var(--tx);
  border-radius: 8px;
  padding: 10px;
  font-family: Consolas, monospace;
  font-size: 11.5px;
  line-height: 1.5;
  resize: vertical;
  min-height: 84px;
}
.embed-actions { display: flex; gap: 8px; align-items: center; margin-top: 8px; flex-wrap: wrap; }

/* ---------- widget page ---------- */
body.widget {
  display: flex;
  flex-direction: column;
  height: 100vh;  /* fallback */
  height: 100dvh; /* tracks the real visible area on phones (collapsing URL bar) */
  overflow: hidden;
}
body.widget #whead {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 10px;
  border-bottom: 1px solid var(--line);
  background: var(--bg2);
  flex: none;
}
body.widget .brand-name { font-size: 13.5px; }
body.widget #wmap { flex: 1; border-radius: 0; cursor: pointer; }
body.widget #wfoot {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  align-items: center;
  padding: 5px 10px;
  border-top: 1px solid var(--line);
  background: var(--bg2);
  font-size: 11px;
  flex: none;
}
#wfoot a { color: var(--accent); font-weight: 800; text-decoration: none; letter-spacing: .4px; font-size: 11px; }

/* ---------- top movers ---------- */
.mv-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.mv-col { background: var(--bg3); border: 1px solid var(--line); border-radius: 10px; padding: 8px; }
.mv-h { font-size: 12px; font-weight: 700; padding: 4px 6px 8px; border-bottom: 1px solid var(--line); margin-bottom: 4px; }
.mv-h.up { color: var(--up); }
.mv-h.down { color: var(--down); }
.mv-h.vol { color: var(--tx); }
.mv-row { display: flex; align-items: center; gap: 7px; padding: 6px 6px; border-radius: 7px; cursor: pointer; }
.mv-row:hover { background: var(--bg2); }
.mv-row img { width: 18px; height: 18px; border-radius: 50%; flex: none; }
.mv-sym { font-weight: 700; font-size: 12px; min-width: 38px; }
.mv-price { color: var(--tx2); font-size: 11.5px; text-align: right; }
.mv-metric { font-size: 12px; font-weight: 700; min-width: 58px; text-align: right; }
.mv-metric.up { color: var(--up); }
.mv-metric.down { color: var(--down); }
@media (max-width: 680px) { .mv-cols { grid-template-columns: 1fr; } }

/* ---------- price flash on refresh ---------- */
@keyframes flashUp { from { background-color: rgba(14,203,129,.42); } to { background-color: transparent; } }
@keyframes flashDown { from { background-color: rgba(246,70,93,.42); } to { background-color: transparent; } }
.tile.flash-up, td.flash-up { animation: flashUp 1.2s ease-out; }
.tile.flash-down, td.flash-down { animation: flashDown 1.2s ease-out; }
@media (prefers-reduced-motion: reduce) { .flash-up, .flash-down { animation: none !important; } }

/* ---------- "⋯" overflow menu ---------- */
#moreBtn { display: none; }
.more-menu {
  position: fixed;
  right: 10px;
  top: 54px;
  z-index: 115;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.5);
  display: flex;
  flex-direction: column;
  min-width: 200px;
  overflow: hidden;
  animation: slidein .15s ease;
}
.more-menu button {
  background: none;
  border: 0;
  color: var(--tx);
  text-align: left;
  padding: 12px 15px;
  font-size: 13.5px;
  font-weight: 600;
  cursor: pointer;
  border-bottom: 1px solid var(--line);
}
.more-menu button:last-child { border-bottom: 0; }
.more-menu button:hover { background: var(--bg3); }
@media (max-width: 620px) {
  #snapshotBtn, #embedBtn, #moversBtn, #compareBtn, #helpBtn { display: none; }
  #moreBtn { display: inline-flex; }
}

/* ---------- install bar ---------- */
.install-bar {
  position: fixed;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  z-index: 110;
  background: var(--bg2);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.5);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  width: min(460px, calc(100vw - 24px));
  font-size: 13px;
  animation: slidein .2s ease;
}
.install-bar .ib-icon { font-size: 20px; flex: none; }
.install-bar .ib-text { flex: 1; line-height: 1.35; color: var(--tx); }
.install-bar .ib-text b { color: var(--accent); font-weight: 700; }
.install-bar .btn { flex: none; }
.install-bar .ib-x { background: none; border: 0; color: var(--tx2); font-size: 14px; cursor: pointer; flex: none; padding: 2px 4px; }
.install-bar .ib-x:hover { color: var(--tx); }

/* ---------- legend / help ---------- */
.legend-bar {
  height: 30px;
  border-radius: 8px;
  background: linear-gradient(90deg, #f6465d 0%, #3b424c 50%, #0ecb81 100%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
  margin-bottom: 14px;
}
.help-grid { display: grid; grid-template-columns: max-content 1fr; gap: 6px 14px; font-size: 13px; align-items: start; }
.help-k { font-weight: 700; color: var(--tx); }
.help-v { color: var(--tx2); line-height: 1.45; }
.help-h { font-size: 13px; margin: 16px 0 8px; }

/* ---------- loading skeletons ---------- */
@keyframes shimmer { 100% { background-position: -200% 0; } }
.skel, .skel-bar {
  background: linear-gradient(90deg, var(--bg3) 25%, var(--line) 37%, var(--bg3) 63%);
  background-size: 200% 100%;
  animation: shimmer 1.4s ease infinite;
}
.tile.skel { cursor: default; border-radius: 2px; pointer-events: none; }
.skel-bar { display: inline-block; width: 78%; height: 12px; border-radius: 4px; vertical-align: middle; }
@media (prefers-reduced-motion: reduce) { .skel, .skel-bar { animation: none; } }

/* ---------- compare ---------- */
.cmp-controls { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 10px; }
.cmp-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.cmp-chip {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--bg3); border: 1px solid var(--line);
  border-radius: 99px; padding: 5px 8px 5px 11px; font-size: 12px; font-weight: 700;
}
.cmp-dot { width: 10px; height: 10px; border-radius: 50%; flex: none; }
.cmp-x { background: none; border: 0; color: var(--tx2); cursor: pointer; font-size: 12px; padding: 0 2px; }
.cmp-x:hover { color: var(--down); }
.cmp-chart { background: var(--bg3); border: 1px solid var(--line); border-radius: 10px; padding: 6px; }
.cmp-chart canvas { width: 100%; height: 280px; display: block; }
.cmp-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 10px; }
.cmp-leg-item { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; }
.cmp-leg-item b.up { color: var(--up); }
.cmp-leg-item b.down { color: var(--down); }

/* ---------- responsive ---------- */
@media (max-width: 760px) {
  .brand-name { font-size: 16px; }
  .searchbox { order: 3; flex-basis: 100%; max-width: none; }
  .topbar { gap: 8px; padding: 8px 10px; }
  .statsbar { padding: 8px 10px; }
  .toolbar { padding: 8px 10px; gap: 6px; }
  main { padding: 0 8px 8px; }
  .banner { margin: 0 8px 8px; }
  .seg button { padding: 7px 10px; font-size: 12px; }
  .sheet { padding: 14px; }
  .cm-form input { width: 120px; }
}
