/* Blask Radar — global new-brand command center */
:root {
  --bg: #06080f;
  --bg-elev: #0b1120;
  --bg-elev-2: #131a2c;
  --bg-elev-3: #1a2240;
  --line: #1c2540;
  --line-soft: #161e36;
  --text: #e7ecff;
  --text-dim: #8a93b3;
  --text-mute: #5b6385;
  --accent: #00e0a4;
  --accent-2: #4dffcd;
  --accent-soft: rgba(0,224,164,.12);
  --hot: #ff647c;
  --hot-soft: rgba(255,100,124,.13);
  --warn: #ffb547;
  --warn-soft: rgba(255,181,71,.13);
  --info: #6cf;
  --info-soft: rgba(102,204,255,.13);
  --violet: #b693ff;
  --violet-soft: rgba(182,147,255,.13);
  --shadow: 0 2px 0 rgba(0,0,0,.4), 0 28px 70px -28px rgba(0,0,0,.55);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,224,164,.06), transparent 60%),
    radial-gradient(1000px 500px at -10% 50%, rgba(102,204,255,.04), transparent 60%),
    var(--bg);
  background-attachment: fixed;
  color: var(--text);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font: inherit; color: inherit; }
[hidden] { display: none !important; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #1c2540; border-radius: 8px; }
::-webkit-scrollbar-thumb:hover { background: #2a3760; }
::-webkit-scrollbar-track { background: transparent; }

.muted { color: var(--text-mute); font-weight: 400; }

/* ---------------- Topbar ---------------- */
.topbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(11,17,32,.95) 0%, rgba(6,8,15,.85) 100%);
  backdrop-filter: blur(10px);
  position: sticky; top: 0; z-index: 50;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-name { font-weight: 700; letter-spacing: .2px; font-size: 16px; }
.brand-sub { font-size: 11px; color: var(--text-mute); text-transform: uppercase; letter-spacing: 1.5px; }
.topbar-actions { display: flex; align-items: center; gap: 10px; }
.status {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--text-dim);
  padding: 5px 11px; background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 999px;
  display: inline-flex; align-items: center; gap: 7px;
}
.dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-mute); display: inline-block;
}
.dot-live { background: var(--accent); box-shadow: 0 0 0 0 var(--accent); animation: pulse-ring 2s ease-out infinite; }
.dot-sync { background: var(--warn); animation: pulse 1s linear infinite; }
.dot-warn { background: var(--hot); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }
@keyframes pulse-ring {
  0% { box-shadow: 0 0 0 0 rgba(0,224,164,.5); }
  100% { box-shadow: 0 0 0 8px rgba(0,224,164,0); }
}

/* ---------------- Controls ---------------- */
.controls {
  display: grid;
  grid-template-columns: auto auto auto minmax(160px, 1fr) minmax(180px, 1.4fr) auto;
  gap: 14px;
  padding: 16px 24px;
  border-bottom: 1px solid var(--line);
  background: rgba(11,17,32,.7);
  align-items: end;
}
.control { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.control label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 1.4px;
  color: var(--text-mute); font-weight: 600;
}
.control select, .control input, .btn {
  background: var(--bg-elev);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 12px;
  outline: none;
  font: inherit;
  transition: border-color .15s, background .15s;
}
.control select:focus, .control input:focus { border-color: var(--accent); }
.btn { background: var(--accent); color: #06251c; font-weight: 600; cursor: pointer; border-color: transparent; }
.btn:hover { background: var(--accent-2); }
.btn-ghost { background: var(--bg-elev); color: var(--text); border-color: var(--line); }
.btn-ghost:hover { background: var(--bg-elev-2); }
.btn:disabled { opacity: .5; cursor: not-allowed; }

.seg { display: inline-flex; background: var(--bg-elev); border: 1px solid var(--line); border-radius: 8px; padding: 2px; }
.seg button {
  background: transparent; color: var(--text-dim);
  border: 0; padding: 6px 12px; cursor: pointer;
  font-weight: 500; border-radius: 6px;
  font-size: 13px;
  transition: all .12s;
}
.seg button:hover { color: var(--text); }
.seg button.active { background: var(--bg-elev-3); color: var(--text); }

/* ---------------- KPIs ---------------- */
.kpis {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  padding: 18px 24px 0;
}
.kpi {
  background: linear-gradient(180deg, var(--bg-elev) 0%, rgba(11,17,32,.5) 100%);
  border: 1px solid var(--line);
  border-radius: 10px; padding: 14px 16px;
  position: relative;
  overflow: hidden;
}
.kpi::after {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--text-mute); opacity: .5;
}
.kpi-accent::after { background: var(--accent); opacity: 1; }
.kpi-hot::after { background: var(--hot); opacity: 1; }
.kpi-violet::after { background: var(--violet); opacity: 1; }
.kpi-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1.2px; color: var(--text-mute); font-weight: 600; }
.kpi-value { font-size: 26px; font-weight: 700; margin-top: 4px; font-feature-settings: 'tnum'; line-height: 1.1; }
.kpi-sub { font-size: 11px; color: var(--text-dim); margin-top: 3px; }

/* ---------------- Cards ---------------- */
.card { background: var(--bg-elev); border: 1px solid var(--line); border-radius: 10px; box-shadow: var(--shadow); }
.card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-soft);
}
.card-head h2 { font-size: 13px; margin: 0; text-transform: uppercase; letter-spacing: 1.2px; color: var(--text-dim); font-weight: 600; display: flex; align-items: center; gap: 8px; }
.card-head h2 span { color: var(--text); }
.card-head .muted { color: var(--text-mute); font-weight: 400; font-size: 12px; text-transform: none; letter-spacing: 0; }
.card-body { padding: 6px; }

/* ---------------- Alert card ---------------- */
.card-alert { margin: 18px 24px 0; border-color: rgba(255,181,71,.35); background: linear-gradient(180deg, rgba(255,181,71,.06) 0%, var(--bg-elev) 100%); }
.card-alert .card-head h2 { color: var(--warn); }
#alert-list .alert-row {
  display: grid; grid-template-columns: 40px 1fr 60px; gap: 14px; align-items: center;
  padding: 12px 14px; border-radius: 8px; cursor: pointer;
  background: transparent; border: 0; width: 100%; text-align: left; color: inherit;
}
#alert-list .alert-row:hover { background: var(--bg-elev-2); }
#alert-list .alert-row + .alert-row { border-top: 1px solid var(--line-soft); }
.alert-name { font-weight: 600; font-size: 15px; }
.alert-detail { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.alert-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }
.alert-chip {
  display: inline-block; padding: 2px 7px; border-radius: 5px;
  background: var(--bg-elev-3); border: 1px solid var(--line);
  font-size: 11px; color: var(--text-dim);
  font-family: 'JetBrains Mono', monospace;
}
.alert-score {
  text-align: center; font-family: 'JetBrains Mono', monospace;
  padding: 6px 10px; border-radius: 8px;
  background: var(--bg-elev-3); border: 1px solid var(--line);
  font-weight: 700; font-size: 16px;
}

/* ---------------- Brand icon ---------------- */
.bicon {
  width: 40px; height: 40px;
  border-radius: 9px;
  object-fit: cover;
  background: var(--bg-elev-3);
  border: 1px solid var(--line);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.bicon-fallback {
  font-weight: 700; font-size: 16px; color: var(--text-dim);
  background: linear-gradient(135deg, var(--bg-elev-2), var(--bg-elev-3));
}

/* ---------------- Main grid ---------------- */
main { padding: 18px 24px 32px; }
.grid {
  margin-top: 16px;
  display: grid; grid-template-columns: 1fr 380px; gap: 18px;
  align-items: start;
}

/* ---------------- Feed ---------------- */
.card-feed { overflow: hidden; }
.feed { max-height: 78vh; overflow: auto; }
.feed .empty { padding: 60px 20px; text-align: center; color: var(--text-mute); }
.event {
  display: grid;
  grid-template-columns: 80px 40px 1fr 70px;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line-soft);
  cursor: pointer;
  transition: background .12s;
  align-items: center;
  background: transparent; border-left: 0; border-right: 0; border-top: 0;
  width: 100%; text-align: left; color: inherit;
}
.event:hover { background: var(--bg-elev-2); }
.event:last-child { border-bottom: 0; }
.event-time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
}
.event-date { color: var(--text); font-weight: 600; }
.event-rel { color: var(--text-mute); margin-top: 2px; }
.event-icon { display: flex; }
.event-body { min-width: 0; }
.event-title { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-size: 14px; }
.event-title strong { font-weight: 700; font-size: 15px; }
.event-geo { color: var(--text); font-weight: 500; }
.event-meta {
  display: flex; gap: 8px; align-items: center; margin-top: 6px;
  font-size: 12px; color: var(--text-dim); flex-wrap: wrap;
}
.event-score {
  text-align: center;
  font-family: 'JetBrains Mono', monospace;
  padding: 8px 6px;
  border-radius: 8px;
  background: var(--bg-elev-3);
  border: 1px solid var(--line);
}
.score-num { font-size: 16px; font-weight: 700; line-height: 1; }
.score-label { font-size: 9px; color: var(--text-mute); letter-spacing: .8px; margin-top: 3px; }

.sev-high { background: var(--hot-soft); border-color: rgba(255,100,124,.4); color: var(--hot); }
.sev-high .score-label { color: var(--hot); }
.sev-med { background: var(--warn-soft); border-color: rgba(255,181,71,.4); color: var(--warn); }
.sev-med .score-label { color: var(--warn); }
.sev-low { background: var(--accent-soft); border-color: rgba(0,224,164,.35); color: var(--accent); }
.sev-low .score-label { color: var(--accent); }
.sev-min { background: var(--bg-elev-3); color: var(--text-dim); }

/* tracked events get a left tint */
.event-tracked { border-left: 2px solid rgba(102,204,255,.3); padding-left: 16px; }
.event-launched { border-left: 2px solid rgba(0,224,164,.3); padding-left: 16px; }

/* Tags & badges */
.tag {
  display: inline-flex; align-items: center;
  padding: 1px 7px; font-size: 11px; border-radius: 4px;
  border: 1px solid var(--line);
  color: var(--text-dim); white-space: nowrap;
  font-weight: 500;
}
.tag-casino { background: var(--accent-soft); border-color: rgba(0,224,164,.35); color: var(--accent); }
.tag-sports { background: var(--info-soft); border-color: rgba(102,204,255,.35); color: var(--info); }
.tag-prediction { background: var(--warn-soft); border-color: rgba(255,181,71,.35); color: var(--warn); }

.badge {
  display: inline-flex; align-items: center;
  padding: 1px 7px; font-size: 11px; border-radius: 4px;
  background: var(--bg-elev-3); border: 1px solid var(--line);
  color: var(--text-dim); white-space: nowrap;
  font-weight: 500;
}
.badge-rank { font-family: 'JetBrains Mono', monospace; color: var(--text); }
.badge-multi { background: var(--violet-soft); border-color: rgba(182,147,255,.4); color: var(--violet); font-weight: 600; }
.badge-reg { background: var(--violet-soft); border-color: rgba(182,147,255,.3); color: var(--violet); }

/* Compact table mode */
.feed.feed-table .event {
  grid-template-columns: 70px 28px 1fr 50px;
  padding: 6px 14px;
  gap: 10px;
  font-size: 12px;
}
.feed.feed-table .event-meta { display: none; }
.feed.feed-table .bicon { width: 24px; height: 24px; }

/* ---------------- Heatmap ---------------- */
.card-heat { overflow: hidden; }
.heatmap { max-height: 78vh; overflow: auto; padding: 6px; }
.heatmap .empty { padding: 40px 20px; text-align: center; color: var(--text-mute); }
.heat-row {
  display: grid; grid-template-columns: 24px 1fr 90px 36px; gap: 10px; align-items: center;
  padding: 9px 12px; border-radius: 7px; cursor: pointer;
  font-size: 13px;
  background: transparent; border: 0; width: 100%; text-align: left; color: inherit;
}
.heat-row + .heat-row { margin-top: 2px; }
.heat-row:hover { background: var(--bg-elev-2); }
.heat-flag { font-size: 18px; }
.heat-name { min-width: 0; }
.heat-country { color: var(--text); font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.heat-sub { font-size: 11px; color: var(--text-mute); margin-top: 1px; }
.heat-bar {
  position: relative;
  height: 6px;
  background: rgba(255,255,255,.04);
  border-radius: 4px;
  overflow: hidden;
}
.heat-bar > span {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: linear-gradient(90deg, var(--accent) 0%, var(--info) 100%);
  border-radius: 4px;
}
.heat-count {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600; text-align: right; color: var(--text);
}

/* ---------------- Drawer ---------------- */
.drawer-scrim {
  position: fixed; inset: 0; background: rgba(0,0,0,.5);
  z-index: 100; backdrop-filter: blur(2px);
}
.drawer {
  position: fixed; top: 0; right: 0; bottom: 0; width: min(560px, 92vw);
  background: var(--bg-elev); border-left: 1px solid var(--line);
  z-index: 101; display: flex; flex-direction: column;
  box-shadow: -30px 0 80px -30px rgba(0,0,0,.7);
  transform: translateX(100%);
  transition: transform .25s ease;
}
.drawer.open { transform: translateX(0); }
.drawer-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 22px; border-bottom: 1px solid var(--line);
}
.drawer-title { display: flex; align-items: center; gap: 14px; }
.drawer-title img { width: 44px; height: 44px; border-radius: 9px; background: var(--bg-elev-3); object-fit: cover; }
.drawer-brand { font-size: 18px; font-weight: 700; }
.drawer-sub { font-size: 12px; color: var(--text-mute); }
.drawer-body { flex: 1; overflow: auto; padding: 16px 22px 30px; }
.drawer-body section { margin-bottom: 24px; }
.drawer-body h3 {
  font-size: 11px; text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--text-mute); margin: 0 0 10px; font-weight: 600;
}
.drawer-stats {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.dstat {
  background: var(--bg-elev-2); border-radius: 8px; padding: 10px 12px;
  border: 1px solid var(--line-soft);
}
.dstat-val { font-size: 18px; font-weight: 700; font-feature-settings: 'tnum'; }
.dstat-lbl { font-size: 11px; color: var(--text-mute); text-transform: uppercase; letter-spacing: .8px; margin-top: 2px; }

.dev {
  display: grid; grid-template-columns: 100px 1fr auto; gap: 10px;
  padding: 8px 12px; border-radius: 7px;
  font-size: 13px;
  border-bottom: 1px solid var(--line-soft);
  align-items: center;
}
.dev:hover { background: var(--bg-elev-2); }
.dev-date { color: var(--text-dim); font-family: 'JetBrains Mono', monospace; font-size: 12px; }
.dev-geo { color: var(--text); }
.dev-kind {
  font-size: 10px; font-family: 'JetBrains Mono', monospace;
  text-transform: uppercase; padding: 2px 6px; border-radius: 4px;
  background: var(--bg-elev-3); color: var(--text-dim);
  letter-spacing: .6px; font-weight: 600;
}
.dev-kind.event-launched { background: var(--accent-soft); color: var(--accent); }
.dev-kind.event-tracked { background: var(--info-soft); color: var(--info); }

.dpres {
  display: grid; grid-template-columns: 1fr auto; gap: 10px;
  padding: 7px 12px; border-radius: 7px;
  font-size: 13px;
  border-bottom: 1px solid var(--line-soft);
  align-items: center;
}
.dpres:hover { background: var(--bg-elev-2); }
.dpres.stopped { opacity: .5; }
.dpres-geo { color: var(--text); }
.dpres-meta { color: var(--text-mute); font-family: 'JetBrains Mono', monospace; font-size: 12px; }

footer {
  padding: 18px 24px 28px; color: var(--text-mute); font-size: 12px;
  border-top: 1px solid var(--line);
  display: flex; gap: 12px; align-items: center; justify-content: center;
  flex-wrap: wrap;
}

/* ---------------- Responsive ---------------- */
@media (max-width: 1180px) {
  .kpis { grid-template-columns: repeat(2, 1fr); }
  .grid { grid-template-columns: 1fr; }
  .feed, .heatmap { max-height: none; }
  .controls { grid-template-columns: repeat(3, 1fr); }
  .controls .control:nth-child(5) { grid-column: span 2; }
  .controls .control:nth-child(6) { grid-column: 3; }
}
@media (max-width: 720px) {
  .controls { grid-template-columns: 1fr 1fr; padding: 14px; }
  .controls .control { grid-column: span 1 !important; }
  .topbar { padding: 12px 14px; }
  .kpis { padding: 14px 14px 0; }
  main { padding: 14px; }
  .event { grid-template-columns: 60px 32px 1fr 56px; padding: 12px; gap: 10px; }
  .bicon { width: 32px; height: 32px; }
  .card-alert { margin: 14px; }
  #alert-list .alert-row { grid-template-columns: 36px 1fr 50px; }
}

/* ---------------- Tabs ---------------- */
.tabs { display: flex; gap: 4px; margin: 0 16px; }
.tab {
  background: transparent; border: 0;
  padding: 8px 16px; font-size: 13px; font-weight: 500;
  color: var(--text-dim); cursor: pointer; border-radius: 7px;
  transition: all .15s ease;
}
.tab:hover { color: var(--text); background: var(--bg-elev-2); }
.tab.active { background: var(--bg-elev-3); color: var(--text); }

/* ---------------- Game-specific pills ---------------- */
.gpill {
  display: inline-flex; align-items: center;
  padding: 2px 8px; border-radius: 10px;
  font-size: 11px; font-weight: 500;
  background: var(--bg-elev-2); color: var(--text-dim);
  border: 1px solid var(--line-soft);
}
.gpill-genre { background: rgba(102,204,255,.10); color: var(--info); border-color: rgba(102,204,255,.25); }
.gpill-provider { background: rgba(182,147,255,.10); color: var(--violet); border-color: rgba(182,147,255,.25); }
.theme-chip {
  display: inline-flex; align-items: center;
  padding: 3px 8px; border-radius: 6px;
  font-size: 11px;
  background: var(--bg-elev-2); color: var(--text-dim);
  margin: 2px 4px 2px 0;
  border: 1px solid var(--line-soft);
}
.gicon {
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--bg-elev-2); object-fit: cover;
  border: 1px solid var(--line-soft);
}
.gicon-fallback {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--bg-elev-2); color: var(--text-mute);
  font-size: 16px; font-weight: 600;
  border: 1px solid var(--line-soft);
}
