:root{
  --bg:#151617;
  --panel:#1e2023;
  --border:#2b2f34;
  --muted:#9aa3ad;
  --text:#e8edf2;
  --accent:#2a6df4;  /* cobalt */
  --accent-soft:#5a8cff;
  --ok:#52d67a;
  --warn:#ffb454;
  --bad:#ff6b6b;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:linear-gradient(180deg,#141517 0%,#17191b 40%,#151617 100%);
  color:var(--text); font:14px/1.4 ui-sans-serif,system-ui,Segoe UI,Roboto,Arial,sans-serif;
}

.topbar{
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 20px; border-bottom:1px solid var(--border);
  background:#0f1113;
  position:sticky; top:0; z-index:30;
}
.brand{display:flex; gap:12px; align-items:center}
.brand-logo{
  width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:white;font-weight:800;letter-spacing:1px;
}
.brand-copy h1{margin:0;font-size:18px}
.brand-copy small{font-weight:500;color:var(--muted)}
.tagline{margin:2px 0 0;color:var(--muted);font-size:12px}
.accent{color:var(--accent)}

.actions{display:flex; gap:8px}
.btn{
  background:var(--accent); color:#fff; border:none; border-radius:10px;
  padding:10px 14px; font-weight:600; cursor:pointer; box-shadow:0 6px 18px rgba(42,109,244,0.25);
}
.btn-ghost{
  background:#0f1113; color:var(--text); border:1px solid var(--border);
}
.btn:hover{filter:brightness(1.05)}
.btn-ghost:hover{border-color:var(--accent)}

.tickerbar{border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:#0f1113}
.ticker-track{white-space:nowrap; overflow:hidden; padding:10px 0}
.ticker-track span{display:inline-block; padding:0 28px; color:#cfe0ff}

.container{max-width:1200px;margin:20px auto;padding:0 16px}
.row{display:grid; grid-template-columns:1fr; gap:16px; margin-bottom:16px}
@media(min-width:960px){ .row-a{grid-template-columns:1.2fr 1fr 1fr} .row-c{grid-template-columns:1.2fr 0.8fr 1fr} }

.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px; padding:16px;
  box-shadow:0 6px 18px rgba(0,0,0,0.25);
}
h2{margin:0 0 10px; font-size:16px}

.summary-grid,.balance-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:12px;
}
.summary-grid > div,.balance-grid > div{
  background:#191b1e;border:1px solid var(--border);border-radius:12px;padding:12px
}
.label{color:var(--muted);font-size:12px}
.metric{font-weight:800;font-size:20px;margin-top:6px}

.badge{display:inline-block;padding:2px 8px;border-radius:999px;background:#2a2d31;color:var(--muted);font-size:12px}
.badge-ok{background:#123c22;color:#9af0b5;border:1px solid #215b35}
.badge-warn{background:#3c2a12;color:#ffd7a1;border:1px solid #5b3e21}

.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.muted{color:var(--muted)}
.tiny{font-size:12px;color:var(--muted);margin-top:8px}

.graph-card canvas{width:100%;height:auto;display:block;background:#14161a;border-radius:10px;border:1px solid var(--border)}
.legend{margin-top:8px;display:flex;flex-wrap:wrap;gap:10px}
.legend .key{display:flex;align-items:center;gap:6px;color:#cbd6e6}
.legend .dot{width:10px;height:10px;border-radius:50%}

.chart-tooltip{
  position:fixed; display:none; pointer-events:none;
  padding:6px 8px; background:#0f1113; border:1px solid var(--border);
  border-radius:8px; font-size:12px; color:#cfe0ff; box-shadow:0 8px 24px rgba(0,0,0,0.35);
}

.sentiment-bar{position:relative;height:14px;border-radius:999px;background:linear-gradient(90deg,#ff6b6b,#7b7f87,#2a6df4);border:1px solid var(--border)}
.sentiment-bar .fill{position:absolute;top:-3px;left:0;width:2px;height:20px;background:#fff;border-radius:2px;box-shadow:0 0 12px rgba(255,255,255,0.8)}
.sentiment-card .labels{display:flex;justify-content:space-between;color:#c2c7ce;font-size:11px;margin-top:6px}

.news-list{margin:0;padding-left:18px}
.tx-list{margin:0;padding-left:18px}

.footer{padding:24px 16px;color:var(--muted);text-align:center;border-top:1px solid var(--border);margin-top:24px}
/* === Marquee ticker fix === */
.tickerbar{overflow:hidden}
.ticker-track{
  display:inline-block;
  white-space:nowrap;
  will-change:transform;
  animation: ticker-move 40s linear infinite;
}
.ticker-track.paused{animation-play-state:paused}

@keyframes ticker-move{
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); } /* assumes content is duplicated */
}
