/* ============================================
   BLACKBOX Dashboard — Core Styles
   ============================================ */

/* --- Reset --- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  font-family: var(--font-display);
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  overflow-x: hidden;
  line-height: 1.5;
}
a { color: var(--accent-blue); text-decoration: none; }
button { font-family: var(--font-display); cursor: pointer; border: none; background: none; color: inherit; }
input, select { font-family: var(--font-display); }

/* ============================================
   Animated Background
   ============================================ */
.bg-animation {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.bg-animation::before {
  content: '';
  position: absolute;
  top: -5%;
  left: 10%;
  width: 1000px;
  height: 1000px;
  background: radial-gradient(circle, var(--anim-gradient-1) 0%, transparent 55%);
  animation: bgBreathe 10s ease-in-out infinite;
  filter: blur(60px);
}
.bg-animation::after {
  content: '';
  position: absolute;
  bottom: 0%;
  right: 5%;
  width: 900px;
  height: 900px;
  background: radial-gradient(circle, var(--anim-gradient-2) 0%, transparent 55%);
  animation: bgBreathe 13s ease-in-out infinite 2s;
  filter: blur(60px);
}
.bg-blob-3 {
  position: absolute;
  top: 30%;
  right: 25%;
  width: 800px;
  height: 800px;
  background: radial-gradient(circle, var(--anim-gradient-3) 0%, transparent 55%);
  animation: bgBreathe 16s ease-in-out infinite 4s;
  filter: blur(70px);
}
.bg-blob-4 {
  position: absolute;
  bottom: 20%;
  left: 30%;
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, var(--anim-gradient-4) 0%, transparent 55%);
  animation: bgBreathe 18s ease-in-out infinite 7s;
  filter: blur(70px);
}
.bg-blob-5 {
  position: absolute;
  top: 60%;
  right: 50%;
  width: 900px;
  height: 900px;
  background: radial-gradient(circle, var(--anim-gradient-5) 0%, transparent 55%);
  animation: bgBreathe 20s ease-in-out infinite 10s;
  filter: blur(80px);
}
@keyframes bgBreathe {
  0%, 100% { transform: scale(1) translate(0, 0); opacity: 0.7; }
  33% { transform: scale(1.15) translate(20px, -10px); opacity: 1; }
  66% { transform: scale(1.05) translate(-15px, 15px); opacity: 0.85; }
}
.grain {
  position: fixed;
  inset: 0;
  z-index: 1;
  opacity: var(--grain-opacity);
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 256px;
}

/* ============================================
   App Shell
   ============================================ */
.app {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.login-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-primary);
}
.login-overlay.hidden { display: none; }

/* ============================================
   Top Bar — Liquid Glass Pill
   ============================================ */
.topbar {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px var(--space-2xl);
  background: transparent;
  position: sticky;
  top: 0;
  z-index: 100;
  flex-shrink: 0;
}

/* Outer glass pill — contains everything */
.topbar-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1400px;
  padding: 6px 8px 6px 16px;
  background: rgba(12,17,32,0.55);
  backdrop-filter: blur(24px) saturate(1.4);
  -webkit-backdrop-filter: blur(24px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 50px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.04);
}
[data-theme="light"] .topbar-pill {
  background: rgba(255,255,255,0.55);
  border-color: rgba(0,0,0,0.06);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08), inset 0 1px 0 rgba(255,255,255,0.6);
}

.topbar-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.logo-img {
  height: 28px;
  width: auto;
  mix-blend-mode: screen;
}
[data-theme="light"] .logo-img {
  mix-blend-mode: multiply;
  filter: invert(1);
}

/* Inner glass pill — nav icons */
.topbar-nav {
  display: flex;
  align-items: center;
  gap: 2px;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 40px;
  padding: 4px 6px;
  border: 1px solid rgba(255,255,255,0.06);
}
[data-theme="light"] .topbar-nav {
  background: rgba(0,0,0,0.04);
  border-color: rgba(0,0,0,0.06);
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 7px 10px;
  border-radius: 30px;
  cursor: pointer;
  transition: all var(--transition-base);
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  position: relative;
}
.nav-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  stroke-width: 1.8;
}
.nav-item .nav-label {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-width var(--transition-base), opacity var(--transition-base), margin var(--transition-base);
  margin-left: 0;
  font-size: 12px;
  font-weight: 500;
}
.nav-item:hover .nav-label,
.nav-item.active .nav-label {
  max-width: 110px;
  opacity: 1;
  margin-left: 8px;
}
.nav-item:hover {
  color: var(--text-secondary);
  background: rgba(255,255,255,0.06);
}
.nav-item.active {
  color: var(--accent-blue);
  background: var(--accent-blue-subtle);
}
.nav-item .nav-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-red);
}

/* Top bar right */
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  flex-shrink: 0;
}
.topbar-search {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 30px;
  color: var(--text-muted);
  font-size: 12px;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.topbar-search:hover {
  border-color: var(--glass-border-hover);
  background: rgba(255,255,255,0.08);
  color: var(--text-secondary);
}
.topbar-search kbd {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 1px 5px;
  border-radius: 4px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.06);
}
.theme-toggle {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  transition: all var(--transition-fast);
  color: var(--text-muted);
}
.theme-toggle:hover {
  background: rgba(255,255,255,0.08);
  color: var(--text-secondary);
}
.theme-toggle svg { width: 16px; height: 16px; }
.avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--transition-fast);
}
.avatar:hover { border-color: var(--accent-blue); }

/* ============================================
   Main Area
   ============================================ */
.main-area {
  display: flex;
  flex: 1;
  min-height: calc(100vh - var(--topbar-height));
}

/* ============================================
   Sidebar
   ============================================ */
.sidebar {
  width: var(--sidebar-width);
  padding: var(--space-xl) var(--space-md);
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur-hover));
  -webkit-backdrop-filter: blur(var(--glass-blur-hover));
  border-right: 1px solid var(--glass-border);
  flex-shrink: 0;
  overflow-y: auto;
  transition: width var(--transition-base);
  display: none; /* Hidden until sub-nav functionality is added */
}
.sidebar-section { margin-bottom: var(--space-2xl); }
.sidebar-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  padding: 0 var(--space-md);
  margin-bottom: var(--space-sm);
}
.sidebar-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px var(--space-md);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--text-secondary);
  font-size: 13px;
  transition: all var(--transition-fast);
  margin-bottom: 1px;
}
.sidebar-item:hover {
  background: var(--glass-bg-hover);
  color: var(--text-primary);
}
.sidebar-item.active {
  background: var(--accent-blue-subtle);
  color: var(--accent-blue);
  font-weight: 500;
}
.sidebar-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.4;
  flex-shrink: 0;
}
.sidebar-item.active .sidebar-dot {
  background: var(--accent-blue);
  opacity: 1;
  box-shadow: 0 0 8px var(--accent-blue-muted);
}
.sidebar-collapse-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--space-sm);
  margin-top: var(--space-lg);
  border-radius: var(--radius-md);
  color: var(--text-muted);
  transition: all var(--transition-fast);
}
.sidebar-collapse-btn:hover {
  background: var(--glass-bg-hover);
  color: var(--text-secondary);
}
.sidebar-collapse-btn svg { width: 16px; height: 16px; }

/* ============================================
   Content Area
   ============================================ */
.content {
  flex: 1;
  padding: var(--space-2xl);
  overflow-y: auto;
  min-width: 0;
}
.section { display: none; }
.section.active {
  display: block;
  animation: sectionIn 0.3s ease;
}
@keyframes sectionIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   Glass Card
   ============================================ */
.glass-card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur-rest));
  -webkit-backdrop-filter: blur(var(--glass-blur-rest));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  transition: all var(--transition-smooth);
  position: relative;
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}
.glass-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.06) 0%, transparent 40%);
  pointer-events: none;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: xor;
  -webkit-mask-composite: xor;
  padding: 1px;
  z-index: 0;
}
.glass-card:hover {
  background: rgba(14,20,40,0.75);
  backdrop-filter: blur(32px) saturate(1.3);
  -webkit-backdrop-filter: blur(32px) saturate(1.3);
  border-color: rgba(255,255,255,0.12);
  box-shadow: 0 8px 32px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.05), 0 0 0 1px rgba(59,130,246,0.06);
  transform: translateY(-2px);
}
[data-theme="light"] .glass-card:hover {
  background: rgba(255,255,255,0.8);
  box-shadow: 0 8px 32px rgba(0,0,0,0.08), inset 0 1px 0 rgba(255,255,255,0.6);
}
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-lg);
}
.card-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}
.card-menu {
  color: var(--text-muted);
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}
.card-menu:hover { color: var(--text-secondary); background: var(--glass-bg-hover); }
.card-menu svg { width: 16px; height: 16px; }

/* ============================================
   Welcome Header
   ============================================ */
.welcome-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2xl);
  flex-wrap: wrap;
  gap: var(--space-lg);
}
.welcome-bar h1 {
  font-size: 22px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.welcome-bar .welcome-sub {
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: var(--font-weight-light);
  margin-top: 2px;
}
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 20px;
}
.status-badge.online {
  color: var(--accent-green);
  background: var(--accent-green-subtle);
  border: 1px solid var(--accent-green-muted);
}
.status-badge.degraded {
  color: var(--accent-orange);
  background: var(--accent-orange-subtle);
  border: 1px solid var(--accent-orange-muted);
}
.status-badge.offline {
  color: var(--accent-red);
  background: var(--accent-red-subtle);
  border: 1px solid var(--accent-red-muted);
}
.pulse-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; box-shadow: 0 0 0 0 currentColor; }
  50% { opacity: 0.6; box-shadow: 0 0 0 5px transparent; }
}

/* Date range picker */
.date-range {
  display: flex;
  gap: 2px;
  background: var(--glass-bg);
  border-radius: var(--radius-md);
  padding: 3px;
  border: 1px solid var(--glass-border);
}
.date-btn {
  padding: 5px 14px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  transition: all var(--transition-fast);
}
.date-btn:hover { color: var(--text-secondary); background: var(--glass-bg-hover); }
.date-btn.active { color: var(--text-primary); background: var(--accent-blue-subtle); }

/* Custom select dropdown — used for env filter, refresh interval, default range. */
.login-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  padding: 7px 30px 7px 12px;
  cursor: pointer;
  outline: none;
  transition: all var(--transition-fast);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 12px 12px;
}
.login-select:hover {
  background-color: var(--glass-bg-hover);
  border-color: var(--accent-blue-muted, rgba(96,165,250,0.4));
}
.login-select:focus {
  border-color: var(--accent-blue);
  box-shadow: 0 0 0 2px var(--accent-blue-subtle);
}
.login-select option {
  background: var(--bg-primary);
  color: var(--text-primary);
}

/* "Show N more" footer for paginated tables and feeds */
.paginate-more td { padding: 12px 0 !important; }
.paginate-more-feed { display: flex; justify-content: center; padding: 12px 0; }

/* Time-since-last-refresh pill in the home welcome bar */
.refresh-age {
  display: inline-block;
  margin-left: 10px;
  padding: 2px 9px;
  border-radius: 999px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  vertical-align: 1px;
}
.paginate-more-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  padding: 7px 16px;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.paginate-more-btn:hover {
  background: var(--glass-bg-hover);
  color: var(--text-primary);
  border-color: var(--accent-blue-muted, rgba(96,165,250,0.4));
}
.paginate-more-btn:active { transform: translateY(1px); }

/* Quick action buttons */
.quick-actions {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-2xl);
  flex-wrap: wrap;
}
.qa-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 500;
  transition: all var(--transition-base);
}
.qa-btn:hover {
  background: rgba(14,20,40,0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-color: rgba(59,130,246,0.15);
  color: var(--text-primary);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.2), 0 0 12px rgba(59,130,246,0.05);
}
.qa-btn svg { width: 14px; height: 14px; }

/* ============================================
   Stat Cards
   ============================================ */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
}
.stat-card {
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  top: 18px;
  left: 0;
  width: 3px;
  height: 20px;
  border-radius: 0 3px 3px 0;
}
.stat-card[data-accent="blue"]::before { background: var(--accent-blue); }
.stat-card[data-accent="cyan"]::before { background: var(--accent-cyan); }
.stat-card[data-accent="orange"]::before { background: var(--accent-orange); }
.stat-card[data-accent="red"]::before { background: var(--accent-red); }
.stat-card[data-accent="green"]::before { background: var(--accent-green); }
.stat-value {
  font-family: var(--font-mono);
  font-size: 26px;
  font-weight: 600;
  line-height: 1;
  margin-top: var(--space-sm);
  margin-bottom: var(--space-sm);
}
.stat-trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 4px;
}
.stat-trend.up { color: var(--accent-green); background: var(--accent-green-subtle); }
.stat-trend.down { color: var(--accent-red); background: var(--accent-red-subtle); }
.stat-trend.neutral { color: var(--accent-orange); background: var(--accent-orange-subtle); }
.stat-trend.healthy { color: var(--accent-green); background: var(--accent-green-subtle); }
.stat-sparkline {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 36px;
  opacity: 0.12;
  pointer-events: none;
}
.stat-sparkline svg { width: 100%; height: 100%; }

/* ============================================
   Grid Layouts
   ============================================ */
.grid-2-1 {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.grid-1-1 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-bottom: var(--space-2xl);
}
.grid-full {
  margin-bottom: var(--space-2xl);
}

/* ============================================
   Live Indicator
   ============================================ */
.live-indicator {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--accent-green);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.live-indicator::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-green);
  animation: pulse 1.5s ease-in-out infinite;
}

/* ============================================
   Map Background (Home Page)
   ============================================ */
.map-bg {
  position: fixed;
  top: -10vh;
  left: -10vw;
  right: -10vw;
  height: 85vh;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.map-bg-chart {
  width: 100%;
  height: 100%;
}
.map-bg-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 40%;
  background: linear-gradient(to top, var(--bg-primary) 0%, transparent 100%);
  pointer-events: none;
}
.map-bg-fade-top {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 15%;
  background: linear-gradient(to bottom, var(--bg-primary) 0%, transparent 100%);
  pointer-events: none;
}
/* Spacer to reveal the map behind content */
.map-spacer {
  height: 40vh;
  position: relative;
  z-index: 1;
}
/* Blur overlay — two layers: short gradient transition + full blur below */
.map-blur-overlay {
  position: sticky;
  top: -20vh;
  height: calc(100vh + 20vh);
  margin-top: -20vh;
  margin-bottom: calc(-100vh);
  z-index: 1;
  pointer-events: none;
}
/* Top: gradient transition from clear to blurred */
.map-blur-overlay::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 400px;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.3) 30%, rgba(0,0,0,0.7) 65%, black 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, rgba(0,0,0,0.3) 30%, rgba(0,0,0,0.7) 65%, black 100%);
}
/* Below: solid full blur, overlaps with gradient to avoid seam */
.map-blur-overlay::after {
  content: '';
  position: absolute;
  top: 360px;
  left: 0;
  right: 0;
  bottom: 0;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}
/* Ensure all home content sits above the map + overlay */
#section-home > *:not(.map-bg):not(.map-spacer):not(.map-blur-overlay) {
  position: relative;
  z-index: 2;
}

/* Old map container (keep for compat) */
.map-container {
  min-height: 340px;
  position: relative;
}
.map-chart {
  width: 100%;
  height: 300px;
}

/* ============================================
   Live Feed
   ============================================ */
.feed-list {
  max-height: 340px;
  overflow-y: auto;
}
.feed-list::-webkit-scrollbar { width: 4px; }
.feed-list::-webkit-scrollbar-track { background: transparent; }
.feed-list::-webkit-scrollbar-thumb { background: var(--glass-border); border-radius: 2px; }
.feed-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid var(--glass-border);
  transition: background var(--transition-fast);
}
.feed-item:last-child { border-bottom: none; }
.feed-item:hover {
  background: var(--glass-bg-hover);
  margin: 0 calc(var(--space-md) * -1);
  padding: 10px var(--space-md);
  border-radius: var(--radius-md);
}
.feed-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.feed-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.feed-icon svg { width: 14px; height: 14px; }
.feed-icon.match { background: var(--accent-blue-subtle); color: var(--accent-blue); }
.feed-icon.complete { background: var(--accent-green-subtle); color: var(--accent-green); }
.feed-players {
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.feed-detail {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
}
.feed-right { text-align: right; flex-shrink: 0; }
.feed-status {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
}
.feed-status.live {
  color: var(--accent-green);
  background: var(--accent-green-subtle);
  border: 1px solid var(--accent-green-muted);
}
.feed-status.ended {
  color: var(--text-muted);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
}
.feed-time {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 3px;
}

/* ============================================
   Chart Containers
   ============================================ */
.chart-container {
  width: 100%;
  height: 250px;
}
.chart-container.sm { height: 180px; }
.chart-container.lg { height: 350px; }
.chart-container.xl { height: 450px; }

/* ============================================
   Server Health Grid
   ============================================ */
.health-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}
.health-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px var(--space-md);
  background: var(--glass-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
  transition: all var(--transition-fast);
}
.health-item:hover {
  background: rgba(14,20,40,0.6);
  border-color: rgba(255,255,255,0.1);
  box-shadow: 0 0 12px rgba(59,130,246,0.04);
}
.health-name {
  font-size: 12px;
  color: var(--text-secondary);
}
.health-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
}
.health-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
}
.health-dot.green { background: var(--accent-green); box-shadow: 0 0 8px var(--accent-green-muted); }
.health-dot.orange { background: var(--accent-orange); box-shadow: 0 0 8px var(--accent-orange-muted); }
.health-dot.red { background: var(--accent-red); box-shadow: 0 0 8px var(--accent-red-muted); }

/* ============================================
   Alert Items
   ============================================ */
.alert-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-md);
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--glass-border);
}
.alert-item:last-child { border-bottom: none; }
.alert-severity {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-top: 5px;
  flex-shrink: 0;
}
.alert-severity.critical { background: var(--accent-red); box-shadow: 0 0 8px var(--accent-red-muted); }
.alert-severity.warning { background: var(--accent-orange); box-shadow: 0 0 8px var(--accent-orange-muted); }
.alert-severity.info { background: var(--accent-blue); box-shadow: 0 0 8px var(--accent-blue-muted); }
.alert-content { flex: 1; min-width: 0; }
.alert-message { font-size: 13px; color: var(--text-primary); }
.alert-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}

/* Filter bar */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-lg);
  flex-wrap: wrap;
}
.filter-btn {
  padding: 5px 12px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  transition: all var(--transition-fast);
}
.filter-btn:hover { color: var(--text-secondary); background: rgba(14,20,40,0.6); border-color: rgba(255,255,255,0.1); }
.filter-btn.active { color: var(--text-primary); background: var(--accent-blue-subtle); border-color: var(--accent-blue-muted); }

/* ============================================
   Data Tables
   ============================================ */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.data-table thead th {
  text-align: left;
  padding: var(--space-sm) var(--space-md);
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border-bottom: 1px solid var(--glass-border);
  cursor: pointer;
  user-select: none;
  transition: color var(--transition-fast);
}
.data-table thead th:hover { color: var(--text-secondary); }
.data-table thead th.sorted { color: var(--accent-blue); }
.data-table tbody td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--glass-border);
  color: var(--text-secondary);
}
.data-table tbody tr:hover td {
  background: rgba(14,20,40,0.5);
  color: var(--text-primary);
}
.data-table tbody tr {
  transition: background var(--transition-fast);
}
.data-table .mono {
  font-family: var(--font-mono);
  font-size: 12px;
}
.rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
}
.rank-badge.gold { background: rgba(255,193,7,0.15); color: #ffc107; }
.rank-badge.silver { background: rgba(192,192,192,0.15); color: #c0c0c0; }
.rank-badge.bronze { background: rgba(205,127,50,0.15); color: #cd7f32; }
.rank-badge.default { background: var(--glass-bg); color: var(--text-muted); }

/* ============================================
   Architecture Diagram
   ============================================ */
/* Architecture Flow (flexbox) */
.arch-flow {
  padding: var(--space-lg) 0;
}
.arch-row-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: var(--space-md);
  margin-top: var(--space-lg);
}
.arch-row-label:first-child { margin-top: 0; }
.arch-row {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: var(--space-sm);
}
.arch-node-v2 {
  flex: 1;
  padding: 12px 8px;
  background: var(--glass-bg-hover);
  border: 1px solid var(--glass-border-hover);
  border-radius: var(--radius-md);
  text-align: center;
  cursor: pointer;
  transition: all var(--transition-base);
  min-width: 0;
}
.arch-node-v2:hover {
  background: rgba(14,20,40,0.7);
  border-color: rgba(59,130,246,0.15);
  box-shadow: 0 4px 16px rgba(0,0,0,0.2), 0 0 12px rgba(59,130,246,0.06);
}
.arch-node-v2 .node-label {
  font-size: 9px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}
.arch-node-v2 .node-name {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
}
.arch-node-v2 .node-status {
  font-family: var(--font-mono);
  font-size: 10px;
  margin-top: 4px;
}
.arch-node-v2 .node-status.green { color: var(--accent-green); }
.arch-node-v2 .node-status.blue { color: var(--accent-blue); }
.arch-node-v2 .node-status.orange { color: var(--accent-orange); }
.arch-node-v2 .node-status.red { color: var(--accent-red); }

/* Connector arrow between nodes */
.arch-connector {
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
}
.arch-arrow {
  width: 100%;
  height: 2px;
  background: var(--accent-green);
  opacity: 0.35;
  position: relative;
  border-radius: 1px;
  overflow: visible;
}
.arch-arrow::after {
  content: '';
  position: absolute;
  right: -1px;
  top: -3px;
  width: 0;
  height: 0;
  border-left: 6px solid var(--accent-green);
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  opacity: 0.5;
}
/* Animated pulse dot flowing along the line */
.arch-arrow::before {
  content: '';
  position: absolute;
  top: -2px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-green);
  box-shadow: 0 0 8px var(--accent-green);
  animation: flowDot 2s ease-in-out infinite;
}
@keyframes flowDot {
  0% { left: 0; opacity: 0; }
  10% { opacity: 1; }
  90% { opacity: 1; }
  100% { left: calc(100% - 6px); opacity: 0; }
}
.arch-connector.blue .arch-arrow { background: var(--accent-blue); opacity: 0.35; }
.arch-connector.blue .arch-arrow::after { border-left-color: var(--accent-blue); }
.arch-connector.blue .arch-arrow::before { background: var(--accent-blue); box-shadow: 0 0 8px var(--accent-blue); }
.arch-connector.cyan .arch-arrow { background: var(--accent-cyan); opacity: 0.35; }
.arch-connector.cyan .arch-arrow::after { border-left-color: var(--accent-cyan); }
.arch-connector.cyan .arch-arrow::before { background: var(--accent-cyan); box-shadow: 0 0 8px var(--accent-cyan); }
.arch-connector.orange .arch-arrow { background: var(--accent-orange); opacity: 0.35; }
.arch-connector.orange .arch-arrow::after { border-left-color: var(--accent-orange); }
.arch-connector.orange .arch-arrow::before { background: var(--accent-orange); box-shadow: 0 0 8px var(--accent-orange); }
.arch-connector.red .arch-arrow { background: var(--accent-red); opacity: 0.35; }
.arch-connector.red .arch-arrow::after { border-left-color: var(--accent-red); }
.arch-connector.red .arch-arrow::before { background: var(--accent-red); box-shadow: 0 0 8px var(--accent-red); }

/* Old arch styles (keep for compat) */
.arch-diagram { position: relative; width: 100%; min-height: 400px; overflow: hidden; }

/* ============================================
   Settings Forms
   ============================================ */
.settings-group {
  margin-bottom: var(--space-2xl);
}
.settings-group h3 {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: var(--space-lg);
  color: var(--text-primary);
}
.setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--glass-border);
}
.setting-label {
  font-size: 13px;
  color: var(--text-secondary);
}
.setting-desc {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}
.toggle-switch {
  width: 40px;
  height: 22px;
  border-radius: 11px;
  background: var(--glass-border-hover);
  position: relative;
  cursor: pointer;
  transition: background var(--transition-base);
}
.toggle-switch.on { background: var(--accent-blue); }
.toggle-switch::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--text-primary);
  transition: transform var(--transition-base);
}
.toggle-switch.on::after { transform: translateX(18px); }

/* Role badges */
.role-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.role-badge.admin {
  color: var(--accent-orange);
  background: var(--accent-orange-subtle);
  border: 1px solid var(--accent-orange-muted);
}
.role-badge.viewer {
  color: var(--accent-blue);
  background: var(--accent-blue-subtle);
  border: 1px solid var(--accent-blue-muted);
}

/* Connection status */
.conn-status {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
}
.conn-status .conn-name { font-size: 13px; flex: 1; }
.conn-status .conn-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 4px;
}
.conn-badge.connected { color: var(--accent-green); background: var(--accent-green-subtle); }
.conn-badge.disconnected { color: var(--text-muted); background: var(--glass-bg-hover); }

/* ============================================
   Login Page
   ============================================ */
.login-card {
  width: 360px;
  text-align: center;
}
.login-card > svg { height: 40px; margin-bottom: var(--space-2xl); color: var(--text-primary); }
.login-google-btn svg { height: 18px; width: 18px; margin: 0; flex-shrink: 0; }
.login-card h2 { font-size: 20px; margin-bottom: var(--space-sm); }
.login-card p { color: var(--text-secondary); font-size: 13px; margin-bottom: var(--space-2xl); }
.login-input {
  width: 100%;
  padding: 10px var(--space-lg);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 14px;
  margin-bottom: var(--space-sm);
  outline: none;
  transition: border-color var(--transition-fast);
}
.login-input:focus { border-color: var(--accent-blue); }
.login-input::placeholder { color: var(--text-muted); }
.login-google-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.login-google-btn:hover { background: var(--glass-bg-hover, rgba(255,255,255,0.08)); border-color: var(--text-muted); }
.login-divider {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
  color: var(--text-muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.login-divider::before,
.login-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--glass-border);
}
.login-error {
  display: none;
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: var(--radius-md);
  color: #ef4444;
  font-size: 13px;
  padding: 8px 12px;
  margin-bottom: var(--space-lg);
  text-align: left;
}
.login-btn {
  width: 100%;
  padding: 10px;
  background: var(--accent-blue);
  color: #fff;
  border-radius: var(--radius-md);
  font-size: 14px;
  font-weight: 500;
  margin-top: var(--space-sm);
  transition: all var(--transition-fast);
}
.login-btn:hover { background: #2563eb; }
.conn-badge.connected { color: #22c55e; border-color: rgba(34, 197, 94, 0.3); background: rgba(34, 197, 94, 0.1); }

/* ============================================
   Search Overlay
   ============================================ */
.search-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 15vh;
}
.search-overlay.hidden { display: none; }
.search-box {
  width: 520px;
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border-hover);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 24px 48px rgba(0,0,0,0.4);
}
.search-input {
  width: 100%;
  padding: 16px var(--space-xl);
  background: transparent;
  border: none;
  outline: none;
  color: var(--text-primary);
  font-size: 16px;
  border-bottom: 1px solid var(--glass-border);
}
.search-input::placeholder { color: var(--text-muted); }
.search-results {
  padding: var(--space-sm);
  max-height: 300px;
  overflow-y: auto;
}
.search-result-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background var(--transition-fast);
  font-size: 13px;
  color: var(--text-secondary);
}
.search-result-item:hover { background: var(--glass-bg-hover); color: var(--text-primary); }
.search-result-item svg { width: 16px; height: 16px; color: var(--text-muted); }

/* ============================================
   Section-specific stat cards
   ============================================ */
.big-stat {
  text-align: center;
  padding: var(--space-2xl);
}
.big-stat .big-value {
  font-family: var(--font-mono);
  font-size: 42px;
  font-weight: 700;
  line-height: 1;
  margin: var(--space-sm) 0;
}
.big-stat .big-label {
  font-size: 12px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ============================================
   Responsive
   ============================================ */
/* Mobile menu button — base style. Hidden on desktop; the mobile media query
   below toggles it to flex. Defined here (before the media queries) so the
   cascade order is correct: base → media-query override. */
.topbar .mobile-menu-btn {
  display: none;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: var(--text-secondary);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  cursor: pointer;
  transition: background var(--transition-fast), color var(--transition-fast);
  margin-left: auto;
  flex-shrink: 0;
}
.topbar .mobile-menu-btn:hover { background: var(--glass-bg-hover); color: var(--text-primary); }
.topbar .mobile-menu-btn .mobile-menu-icon-close { display: none; }
body.mobile-menu-open .topbar .mobile-menu-btn .mobile-menu-icon-open { display: none; }
body.mobile-menu-open .topbar .mobile-menu-btn .mobile-menu-icon-close { display: inline-flex; }
body.mobile-menu-open .topbar .mobile-menu-btn { color: var(--text-primary); background: var(--glass-bg-hover); }

@media (max-width: 1199px) {
  .sidebar { width: var(--sidebar-collapsed); padding: var(--space-xl) var(--space-xs); }
  .sidebar .sidebar-label { display: none; }
  .sidebar .sidebar-item { justify-content: center; padding: 8px; font-size: 0; }
  .sidebar .sidebar-item .sidebar-dot { margin: 0; }
  /* Inline grid-template-columns="repeat(5,1fr)" overrides win on desktop;
     here we tighten everyone to 3 cols. !important is needed because inline
     style normally has higher specificity than a class selector. */
  .stats-grid { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 767px) {
  .sidebar { display: none; }
  /* Mobile topbar: only the logo + hamburger are visible by default. The nav
     and topbar-right collapse into a dropdown panel triggered by the menu
     button. The pill expands vertically when `body.mobile-menu-open` is set.
     This keeps the UI usable on phones without forcing horizontal scroll. */
  .topbar-pill { flex-wrap: wrap; row-gap: 10px; padding: 8px 10px 8px 14px; }
  .topbar-nav { display: none; }
  .topbar-right { display: none; }
  .topbar .mobile-menu-btn { display: flex; }

  /* Open state: nav + right tools become a stacked column under the logo. */
  body.mobile-menu-open .topbar-pill { border-radius: 22px; }
  body.mobile-menu-open .topbar-nav,
  body.mobile-menu-open .topbar-right {
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
  }
  body.mobile-menu-open .topbar-nav {
    border-radius: 14px;
    padding: 6px;
  }
  body.mobile-menu-open .topbar-nav .nav-item {
    width: 100%;
    justify-content: flex-start;
    padding: 11px 14px;
    border-radius: 8px;
    overflow: visible;
  }
  body.mobile-menu-open .topbar-nav .nav-item .nav-label {
    display: inline;
    max-width: none;
    margin-left: 10px;
    opacity: 1;
  }
  body.mobile-menu-open .topbar-right { gap: 8px; padding-top: 4px; }
  body.mobile-menu-open .topbar-right .login-select { width: 100%; }
  body.mobile-menu-open .topbar-right .topbar-search { width: 100%; }

  .stats-grid { grid-template-columns: 1fr 1fr !important; }
  .grid-2-1, .grid-1-2, .grid-1-1, .grid-1-1-1, .grid-3, .grid-2 { grid-template-columns: 1fr !important; }
  .content { padding: var(--space-lg); }
  .welcome-bar { flex-direction: column; align-items: flex-start; gap: 12px; }
  .welcome-bar h1 { font-size: 18px; }
  .welcome-sub { font-size: 12px; }
  /* Tables: allow horizontal scroll inside their card so dense rows don't
     squish into unreadable columns on phones. Block + nowrap preserves
     colspan'd footer rows (paginate-more) while letting wide rows scroll. */
  .glass-card .data-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
  .glass-card .data-table thead, .glass-card .data-table tbody { width: 100%; }
  /* Date-range and quick-actions wrap rather than overflow. */
  .date-range, .quick-actions { flex-wrap: wrap; }
  /* Big-stat values: trim to 24px so they don't push card sideways. */
  .big-stat .big-value { font-size: 24px !important; }
}
@media (max-width: 430px) {
  /* Phone-narrow: collapse to single column so cards have full width. */
  .stats-grid { grid-template-columns: 1fr !important; }
}

/* ============================================
   Config Section
   ============================================ */
.config-group {
  margin-bottom: var(--space-lg);
}
.config-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--glass-border);
}
.config-row:last-child { border-bottom: none; }
.config-label {
  font-size: 13px;
  color: var(--text-secondary);
}
.config-control {
  display: flex;
  align-items: center;
  gap: 6px;
}
.config-input {
  width: 80px;
  padding: 6px 10px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font-mono);
  font-size: 13px;
  text-align: right;
  outline: none;
  transition: border-color var(--transition-fast);
}
.config-input:focus {
  border-color: var(--accent-blue);
}
.config-select {
  padding: 6px 10px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-family: var(--font-display);
  font-size: 13px;
  outline: none;
  cursor: pointer;
  appearance: none;
}
.config-unit {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
}
.config-save-btn {
  width: 100%;
  padding: 10px;
  margin-top: var(--space-md);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 500;
  cursor: not-allowed;
  transition: all var(--transition-fast);
}
.config-save-btn:not(:disabled) {
  background: var(--accent-blue);
  color: #fff;
  cursor: pointer;
  border-color: var(--accent-blue);
}
.config-save-btn:not(:disabled):hover {
  background: #2563eb;
}

/* ============================================
   Visual Refinements — Glows, Animations, Polish
   ============================================ */

/* Topbar pill subtle edge glow */
.topbar-pill {
  position: relative;
}
.topbar-pill::after {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(59,130,246,0.12) 0%, transparent 30%, transparent 70%, rgba(6,182,212,0.12) 100%);
  pointer-events: none;
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask-composite: xor;
  -webkit-mask-composite: xor;
  padding: 1px;
  opacity: 0.6;
  animation: pillGlow 4s ease-in-out infinite;
}
@keyframes pillGlow {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 0.8; }
}

/* Stat card number pulse on update */
.stat-value.flash {
  animation: statFlash 0.6s ease;
}
@keyframes statFlash {
  0% { color: var(--accent-cyan); transform: scale(1.04); }
  100% { color: var(--text-primary); transform: scale(1); }
}

/* Feed item slide in */
.feed-item.slide-in {
  animation: feedSlide 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes feedSlide {
  from { opacity: 0; transform: translateY(-16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Health item pulse on update */
.health-item.pulse {
  animation: healthPulse 0.8s ease;
}
@keyframes healthPulse {
  0% { box-shadow: 0 0 0 0 rgba(34,197,94,0.3); }
  50% { box-shadow: 0 0 12px 2px rgba(34,197,94,0.15); }
  100% { box-shadow: none; }
}

/* Section loading skeleton */
.skeleton {
  background: linear-gradient(90deg, var(--glass-bg) 25%, var(--glass-bg-hover) 50%, var(--glass-bg) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-md);
}
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Accent glow on stat card side bars */
.stat-card[data-accent="blue"]::before { box-shadow: 4px 0 8px rgba(59,130,246,0.2); }
.stat-card[data-accent="cyan"]::before { box-shadow: 4px 0 8px rgba(6,182,212,0.2); }
.stat-card[data-accent="orange"]::before { box-shadow: 4px 0 8px rgba(249,115,22,0.2); }
.stat-card[data-accent="red"]::before { box-shadow: 4px 0 8px rgba(239,68,68,0.2); }
.stat-card[data-accent="green"]::before { box-shadow: 4px 0 8px rgba(34,197,94,0.2); }

/* Stat card hover — accent-tinted glow */
.stat-card[data-accent="blue"]:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 0 20px rgba(59,130,246,0.08), inset 0 0 30px rgba(59,130,246,0.03); }
.stat-card[data-accent="cyan"]:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 0 20px rgba(6,182,212,0.08), inset 0 0 30px rgba(6,182,212,0.03); }
.stat-card[data-accent="orange"]:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 0 20px rgba(249,115,22,0.08), inset 0 0 30px rgba(249,115,22,0.03); }
.stat-card[data-accent="red"]:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 0 20px rgba(239,68,68,0.08), inset 0 0 30px rgba(239,68,68,0.03); }
.stat-card[data-accent="green"]:hover { box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 0 20px rgba(34,197,94,0.08), inset 0 0 30px rgba(34,197,94,0.03); }

/* Quick action buttons hover glow */
.qa-btn:hover {
  box-shadow: 0 0 16px rgba(59,130,246,0.1);
}

/* Nav item active glow */
.nav-item.active {
  box-shadow: 0 0 12px var(--accent-blue-subtle);
}

/* Live indicator enhanced pulse */
.live-indicator::before {
  box-shadow: 0 0 6px var(--accent-green), 0 0 12px rgba(34,197,94,0.3);
}

/* Feed status badges glow */
.feed-status.live {
  box-shadow: 0 0 8px rgba(34,197,94,0.2);
}

/* Smooth section transition */
@keyframes sectionIn {
  from { opacity: 0; transform: translateY(12px); filter: blur(4px); }
  60% { filter: blur(0); }
  to { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* Status badge glow */
.status-badge.online {
  box-shadow: 0 0 12px rgba(34,197,94,0.15);
}

/* Avatar ring animation */
.avatar {
  position: relative;
}
.avatar::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid rgba(59,130,246,0.2);
  animation: avatarRing 3s ease-in-out infinite;
}
@keyframes avatarRing {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.08); }
}

/* Date range active button glow */
.date-btn.active {
  box-shadow: 0 0 8px var(--accent-blue-subtle);
}

/* Mini chart value display */
.mini-chart-value {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 600;
  margin: 4px 0 2px;
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 8px;
}

/* =====================================================
   New components for real-data dashboard
   ===================================================== */

/* 3-column grid (used in matchmaking, players, economy) */
.grid-1-1-1 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.card-sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-left: 8px;
  font-weight: 400;
}

/* Region pill row on home */
.region-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 16px;
  position: relative;
  z-index: 2;
}
.region-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
}
.region-pill .region-code {
  font-weight: 600;
  color: var(--accent-cyan);
}
.region-pill .region-count {
  color: var(--text-secondary);
}

/* Match feed (real-data) */
.match-feed {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 400px;
  overflow-y: auto;
}
.match-feed-row {
  display: grid;
  grid-template-columns: 24px 1fr 2fr 80px;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 6px;
  transition: background 200ms ease;
  animation: feedSlideIn 350ms cubic-bezier(0.2,0.8,0.2,1);
}
.match-feed-row:hover { background: rgba(255,255,255,0.04); }
.match-row-status i {
  width: 18px; height: 18px;
}
.match-row-players {
  font-size: 13px;
  font-weight: 500;
}
.match-row-players .p1 { color: var(--accent-blue); }
.match-row-players .p2 { color: var(--accent-cyan); }
.match-row-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
}
.match-row-time {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  text-align: right;
}
@keyframes feedSlideIn {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Alerts feed */
.alert-feed {
  display: flex;
  flex-direction: column;
  gap: 6px;
  max-height: 600px;
  overflow-y: auto;
}
.alert-row {
  display: grid;
  grid-template-columns: 28px 1fr 100px;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.02);
  border-left: 3px solid var(--text-muted);
  border-radius: 4px;
  transition: background 200ms ease;
  animation: feedSlideIn 350ms cubic-bezier(0.2,0.8,0.2,1);
}
.alert-row:hover { background: rgba(255,255,255,0.04); }
.alert-row.alert-critical { border-left-color: var(--accent-red); }
.alert-row.alert-warning  { border-left-color: var(--accent-orange); }
.alert-row.alert-info     { border-left-color: var(--accent-blue); }
.alert-row-icon i { width: 16px; height: 16px; }
.alert-row.alert-critical .alert-row-icon { color: var(--accent-red); }
.alert-row.alert-warning  .alert-row-icon { color: var(--accent-orange); }
.alert-row.alert-info     .alert-row-icon { color: var(--accent-blue); }
.alert-row-title {
  font-size: 12px;
  font-weight: 600;
}
.alert-row-source {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
  font-weight: 400;
  margin-left: 6px;
}
.alert-row-message {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 2px;
  word-break: break-word;
}
.alert-row-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}
.alert-row-occurrences {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
}
.alert-row-time {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
}

.feed-empty {
  text-align: center;
  padding: 32px 16px;
  color: var(--text-muted);
  font-size: 12px;
}
.empty-state {
  text-align: center;
  padding: 24px;
  color: var(--text-muted);
  font-size: 13px;
}

/* Severity pill (used in noisy errors table) */
.severity-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.severity-pill.critical {
  background: rgba(239,68,68,0.15);
  color: var(--accent-red);
}
.severity-pill.warning {
  background: rgba(249,115,22,0.15);
  color: var(--accent-orange);
}
.severity-pill.info {
  background: rgba(59,130,246,0.15);
  color: var(--accent-blue);
}

/* Chest queue grid (economy) */
.chest-queue-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.chest-queue-row {
  display: grid;
  grid-template-columns: 1fr 200px 60px;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.02);
  border-radius: 4px;
}
.chest-queue-name {
  font-size: 12px;
  font-weight: 500;
}
.chest-queue-slots {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.chest-slot {
  width: 36px;
  height: 36px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,0.05);
  color: var(--text-muted);
}
.chest-slot.filled {
  background: rgba(168,85,247,0.15);
  border-color: rgba(168,85,247,0.4);
  color: var(--accent-purple);
}
.chest-queue-count {
  text-align: right;
  font-size: 12px;
  color: var(--text-secondary);
}

/* Streak lists (players) */
.streak-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.streak-row {
  display: grid;
  grid-template-columns: 32px 1fr 60px;
  align-items: center;
  padding: 8px 12px;
  background: rgba(255,255,255,0.02);
  border-radius: 4px;
}
.streak-rank {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
}
.streak-name {
  font-size: 13px;
  font-weight: 500;
}
.streak-value {
  text-align: right;
  font-size: 14px;
  font-weight: 700;
}

/* Config cards grid */
.config-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}
.config-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.config-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.config-key {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}
.config-desc {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
  line-height: 1.4;
}
.config-updated {
  font-size: 10px;
  color: var(--text-muted);
  white-space: nowrap;
}
.config-card-body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.config-textarea {
  font-family: var(--font-mono);
  font-size: 12px;
  resize: vertical;
  min-height: 60px;
}
.config-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
.btn {
  padding: 6px 16px;
  border-radius: 4px;
  font-family: var(--font-display);
  font-size: 12px;
  font-weight: 500;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 150ms ease, color 150ms ease;
}
.btn-primary {
  background: var(--accent-blue);
  color: #ffffff;
}
.btn-primary:hover:not(:disabled) {
  background: #2563eb;
}
.btn-primary:disabled {
  background: rgba(255,255,255,0.05);
  color: var(--text-muted);
  cursor: not-allowed;
}
.btn.flash-success { background: var(--accent-green) !important; color: #ffffff; }
.btn.flash-error   { background: var(--accent-red) !important;   color: #ffffff; }
.btn.flash-warning { background: var(--accent-orange) !important; color: #ffffff; }

/* Toggle switch enhancements */
.toggle-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
}
.toggle-switch.disabled { opacity: 0.4; cursor: not-allowed; }
.toggle-switch .toggle-handle {
  display: inline-block;
  width: 36px;
  height: 20px;
  background: rgba(255,255,255,0.1);
  border-radius: 999px;
  position: relative;
  transition: background 200ms ease;
}
.toggle-switch .toggle-handle::after {
  content: '';
  position: absolute;
  top: 2px; left: 2px;
  width: 16px; height: 16px;
  background: #ffffff;
  border-radius: 50%;
  transition: transform 200ms ease;
}
.toggle-switch.on .toggle-handle { background: var(--accent-green); }
.toggle-switch.on .toggle-handle::after { transform: translateX(16px); }
.toggle-switch .toggle-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  color: var(--text-secondary);
  letter-spacing: 0.5px;
}

/* Settings: user list, conn status */
.user-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.user-row:last-child { border-bottom: none; }
.user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-cyan));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: #ffffff;
}
.user-info { display: flex; flex-direction: column; gap: 2px; }
.user-name { font-size: 13px; font-weight: 500; }
.user-email {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
}

.conn-status {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.conn-status:last-child { border-bottom: none; }
.conn-name { font-size: 12px; font-weight: 500; flex: 1; }
.conn-badge {
  padding: 2px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
}
.conn-badge.connected {
  background: rgba(34,197,94,0.15);
  color: var(--accent-green);
}
.conn-badge.disconnected {
  background: rgba(239,68,68,0.15);
  color: var(--accent-red);
}
.conn-latency {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-muted);
}

/* Light theme overrides */
[data-theme="light"] .match-feed-row,
[data-theme="light"] .alert-row,
[data-theme="light"] .chest-queue-row,
[data-theme="light"] .streak-row {
  background: rgba(15,23,41,0.02);
  border-color: rgba(15,23,41,0.06);
}
[data-theme="light"] .toggle-switch .toggle-handle {
  background: rgba(15,23,41,0.1);
}

/* =====================================================
   Matches section
   ===================================================== */

.matches-list-table tr.match-summary-row { transition: background 150ms ease; }
.matches-list-table tr.match-summary-row:hover { background: rgba(59,130,246,0.04); }
.matches-list-table tr.match-summary-row.expanded { background: rgba(59,130,246,0.08); }
.match-result {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
}
.match-result.draw { background: rgba(249,115,22,0.15); color: var(--accent-orange); }
.match-result.won  { background: rgba(34,197,94,0.15);  color: var(--accent-green); }

.match-detail-row td { padding: 0 !important; }
.match-detail-box {
  padding: 16px 24px;
  background: rgba(59,130,246,0.04);
  border-top: 1px solid rgba(59,130,246,0.18);
  border-bottom: 1px solid rgba(59,130,246,0.18);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.match-detail-summary {
  display: flex;
  gap: 24px;
  align-items: center;
  font-size: 12px;
  color: var(--text-secondary);
}
.match-detail-id { font-weight: 600; color: var(--text-primary); }
.match-detail-time { color: var(--text-muted); }
.match-detail-meta { font-family: var(--font-mono); font-size: 11px; color: var(--text-muted); margin-left: auto; }
.match-detail-players {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.match-detail-player {
  padding: 12px 16px;
  background: rgba(255,255,255,0.02);
  border-left: 3px solid var(--text-muted);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.match-detail-player.is-winner { border-left-color: var(--accent-green); }
.match-detail-player.is-loser  { border-left-color: var(--accent-red); }
.match-detail-player.is-draw   { border-left-color: var(--accent-orange); }
.match-detail-player-name { font-size: 14px; font-weight: 600; }
.match-detail-player-stats {
  display: flex;
  gap: 16px;
  font-size: 11px;
  color: var(--text-secondary);
}
.match-detail-cards {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.5;
}

/* Per-player detail: header tag + labelled stat chips */
.match-detail-player-head {
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.match-detail-player-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--text-muted);
}
.match-detail-player.is-winner .match-detail-player-tag { color: var(--accent-green); }
.match-detail-player.is-loser  .match-detail-player-tag { color: var(--accent-red); }
.match-detail-player.is-draw   .match-detail-player-tag { color: var(--accent-orange); }
.match-detail-statline {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
}
.mds {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-secondary);
}
.mds label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--text-muted);
}
.mds-val { color: var(--text-primary); }
.mds-delta { font-style: normal; }
.mds-delta.pos { color: var(--accent-green); }
.mds-delta.neg { color: var(--accent-red); }
/* Trophy-floor flag — a loss that cost 0 trophies (held by the floor). */
.mds-floor label, .mds-floor .mds-val { color: var(--accent-cyan); }

/* Matchmaking tuning panel (Config section) */
#mm-tuning-body { max-width: 600px; }
.mm-init-row, .mm-tier-row {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 7px; padding: 9px 12px; margin-bottom: 7px;
  transition: background 120ms ease, border-color 120ms ease;
}
.mm-tier-row:hover { border-color: rgba(59,130,246,0.30); background: rgba(59,130,246,0.05); }
.mm-tier-row.mm-dragging { opacity: 0.45; border-style: dashed; border-color: var(--accent-cyan); }
.mm-init-row { border-left: 3px solid var(--accent-cyan); margin-bottom: 10px; }
.mm-drag-handle { cursor: grab; color: var(--text-muted); display: flex; align-items: center; }
.mm-drag-handle:hover { color: var(--accent-cyan); }
.mm-drag-handle:active { cursor: grabbing; }
.mm-drag-handle svg, .mm-drag-handle i { width: 15px; height: 15px; }
.mm-tier-when { font-family: var(--font-mono); font-weight: 600; color: var(--text-secondary); min-width: 26px; font-size: 12px; }
.mm-tier-tag { text-transform: uppercase; letter-spacing: 0.5px; font-size: 9px; font-weight: 600; color: var(--accent-cyan); }
.mm-tier-when-pre { font-size: 11px; color: var(--text-muted); }
.mm-pm { font-family: var(--font-mono); color: var(--text-secondary); font-weight: 600; }
.mm-unit { font-size: 11px; color: var(--text-muted); white-space: nowrap; }
.mm-init-row .config-input, .mm-tier-row .config-input { width: 78px; }
.mm-tier-remove { margin-left: auto; background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 17px; line-height: 1; padding: 0 4px; transition: color 120ms ease; }
.mm-tier-remove:hover { color: var(--accent-red); }
.mm-tuning-actions { display: flex; align-items: center; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.mm-add-tier { background: none; border: 1px dashed rgba(255,255,255,0.18); color: var(--text-secondary); border-radius: 6px; padding: 6px 14px; cursor: pointer; font-size: 11px; transition: all 120ms ease; }
.mm-add-tier:hover { border-color: var(--accent-cyan); color: var(--accent-cyan); }
.mm-status { font-size: 11px; color: var(--text-secondary); }
.mm-foot { display: flex; flex-direction: column; gap: 3px; margin-top: 14px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.05); }
.mm-foot-limits, .mm-foot-meta { font-size: 10px; color: var(--text-muted); }
/* Gold scaling editor */
.gold-top { display: flex; gap: 24px; align-items: center; flex-wrap: wrap; padding: 2px 0 12px; }
.gold-en-row, .gold-mb-row { display: flex; align-items: center; gap: 9px; }
.gold-en-lbl, .gold-mb-lbl { font-size: 12px; font-weight: 600; color: var(--text-secondary); }
.gold-mb { width: 64px; text-align: center; }
.gold-mb-pct { color: var(--text-muted); }
.gold-grid { width: 100%; border-collapse: collapse; }
.gold-grid th { text-align: left; font-size: 10px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); padding: 4px 8px; border-bottom: 1px solid var(--glass-border); }
.gold-grid td { padding: 7px 8px; border-bottom: 1px solid var(--glass-border); vertical-align: middle; }
.gold-row.gold-off { opacity: 0.45; }
.gold-sig-name { font-weight: 600; font-size: 13px; }
.gold-sig-hint { font-size: 10px; color: var(--text-muted); }
.gold-w { width: 66px; text-align: center; }
.gold-r { width: 76px; text-align: center; }
.gold-r-td { white-space: nowrap; }
.gold-r-arrow { color: var(--text-muted); margin: 0 7px; }
.gold-preview { margin: 14px 0 4px; padding: 9px 13px; background: rgba(245,196,81,0.07); border: 1px solid rgba(245,196,81,0.25); border-radius: 8px; }
.gold-prev-line { font-size: 13px; font-weight: 600; color: var(--accent-yellow); }
.gold-prev-line.gold-prev-off { color: var(--text-muted); }
.gold-prev-sub { font-size: 11px; color: var(--text-secondary); margin-top: 3px; }
[data-theme="light"] .mm-init-row, [data-theme="light"] .mm-tier-row { background: rgba(15,23,41,0.02); border-color: rgba(15,23,41,0.06); }
[data-theme="light"] .mm-add-tier { border-color: rgba(15,23,41,0.18); }

/* Trophy-floor test-bypass list (Config section) */
.tf-list { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.tf-empty { font-size: 12px; color: var(--text-muted); }
.tf-chip {
  display: inline-flex; align-items: center; gap: 9px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07);
  border-radius: 999px; padding: 5px 7px 5px 13px;
}
.tf-chip-name { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.tf-chip-id { font-size: 10px; color: var(--text-muted); }
.tf-chip-remove {
  background: rgba(239,68,68,0.12); border: none; color: var(--accent-red); cursor: pointer;
  font-size: 14px; line-height: 1; width: 20px; height: 20px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center; transition: all 120ms ease;
}
.tf-chip-remove:hover { background: var(--accent-red); color: #fff; }
.tf-add-row { display: flex; gap: 8px; align-items: center; margin-bottom: 4px; }
.tf-add-input { width: 240px; }
[data-theme="light"] .tf-chip { background: rgba(15,23,41,0.03); border-color: rgba(15,23,41,0.08); }

/* Rewards summary — match payouts card (Economy section) */
.rw-payout-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 14px; }
.rw-stat { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05); border-radius: 6px; padding: 10px 12px; }
.rw-stat-value { font-size: 20px; font-weight: 600; color: var(--accent-cyan); }
.rw-stat-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; margin-top: 4px; }
.rw-payout-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; margin-bottom: 8px; }
.rw-awards { display: flex; flex-wrap: wrap; gap: 8px; }
.rw-award-chip { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06); border-radius: 999px; padding: 5px 12px; }
.rw-award-type { font-size: 12px; color: var(--text-primary); }
.rw-award-count { font-size: 11px; color: var(--text-muted); }
[data-theme="light"] .rw-stat, [data-theme="light"] .rw-award-chip { background: rgba(15,23,41,0.02); border-color: rgba(15,23,41,0.06); }

/* Chest card rewards (Economy section) */
.cardrw-pending { font-size: 12px; color: var(--text-muted); padding: 10px 0; }
.cardrw-r-common .rw-award-type { color: var(--text-secondary); }
.cardrw-r-rare .rw-award-type { color: var(--accent-blue); }
.cardrw-r-epic .rw-award-type { color: var(--accent-pink); }
.cardrw-r-legendary .rw-award-type { color: var(--accent-orange); }
.cardrw-feed { display: flex; flex-direction: column; gap: 7px; margin-top: 4px; }
.cardrw-open { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05); border-radius: 6px; padding: 9px 12px; transition: border-color 120ms ease; }
.cardrw-open:hover { border-color: rgba(59,130,246,0.25); }
.cardrw-open-head { display: flex; flex-wrap: wrap; gap: 10px; align-items: baseline; cursor: pointer; }
.cardrw-open-head::before { content: '▸'; color: var(--text-muted); font-size: 10px; transition: transform 120ms ease; display: inline-block; }
.cardrw-open-head.expanded::before { transform: rotate(90deg); }
.cardrw-open-type { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.cardrw-open-arena, .cardrw-open-user, .cardrw-open-meta { font-size: 11px; color: var(--text-muted); }
.cardrw-open-time { font-size: 11px; color: var(--text-muted); margin-left: auto; }
.cardrw-detail { margin-top: 10px; padding-top: 10px; border-top: 1px solid rgba(255,255,255,0.06); }
.cardrw-detail-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; margin-bottom: 10px; }
.cardrw-dstat { display: inline-flex; gap: 6px; align-items: baseline; }
.cardrw-dstat-l { font-size: 9px; text-transform: uppercase; letter-spacing: 0.4px; color: var(--text-muted); font-weight: 600; }
.cardrw-dstat-v { font-size: 11px; color: var(--text-primary); }
.cardrw-detail-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 8px; }
.cardrw-detail-card { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05); border-left-width: 3px; border-radius: 5px; padding: 7px 9px; }
.cardrw-detail-card.cardrw-r-common { border-left-color: var(--text-muted); }
.cardrw-detail-card.cardrw-r-rare { border-left-color: var(--accent-blue); }
.cardrw-detail-card.cardrw-r-epic { border-left-color: var(--accent-pink); }
.cardrw-detail-card.cardrw-r-legendary { border-left-color: var(--accent-orange); }
.cardrw-dc-name { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.cardrw-dc-sub { font-size: 10px; color: var(--text-muted); margin-top: 2px; }
.cardrw-dc-badges { display: flex; gap: 4px; margin-top: 5px; min-height: 12px; }
.cardrw-badge { font-size: 8px; font-weight: 700; letter-spacing: 0.5px; padding: 1px 5px; border-radius: 3px; }
.cardrw-badge.new { background: rgba(34,197,94,0.15); color: var(--accent-green); }
.cardrw-badge.max { background: rgba(249,115,22,0.15); color: var(--accent-orange); }
.cardrw-showmore { margin-top: 10px; }
[data-theme="light"] .cardrw-open, [data-theme="light"] .cardrw-detail-card { background: rgba(15,23,41,0.02); border-color: rgba(15,23,41,0.06); }

/* ===== Match replay viewer — neon / holographic ===== */
.match-watch-btn { align-self: flex-start; margin: 4px 0 8px; background: rgba(34,211,238,0.10); border: 1px solid rgba(34,211,238,0.45); color: #22d3ee; font-size: 11px; font-weight: 600; padding: 4px 12px; border-radius: 6px; cursor: pointer; transition: all 120ms ease; box-shadow: 0 0 0 rgba(34,211,238,0); }
.match-watch-btn:hover { background: rgba(34,211,238,0.22); box-shadow: 0 0 14px rgba(34,211,238,0.4); }
.replay-overlay { position: fixed; inset: 0; background: rgba(2,4,12,0.86); backdrop-filter: blur(4px); z-index: 4000; display: flex; align-items: center; justify-content: center; padding: 24px; }
.replay-modal { background: radial-gradient(120% 80% at 50% 0%, #0a1426 0%, #05080f 70%); border: 1px solid rgba(34,211,238,0.28); border-radius: 14px; padding: 16px 18px; width: min(580px, 96vw); max-height: 94vh; overflow: auto; box-shadow: 0 0 50px rgba(34,211,238,0.12), 0 24px 70px rgba(0,0,0,0.65); }
.replay-head { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 12px; }
.replay-title { font-size: 15px; font-weight: 700; letter-spacing: 0.5px; color: #c9f7ff; text-shadow: 0 0 12px rgba(34,211,238,0.55); }
.replay-sub { font-family: var(--font-mono); font-size: 10px; color: #5f7290; margin-top: 2px; word-break: break-all; }
.replay-close { font-size: 22px; line-height: 1; color: #5f7290; cursor: pointer; padding: 0 4px; }
.replay-close:hover { color: #ff3da6; text-shadow: 0 0 10px rgba(255,61,166,0.6); }
.replay-arena { position: relative; display: flex; justify-content: center; background: #02040a; border: 1px solid rgba(34,211,238,0.15); border-radius: 10px; padding: 10px; overflow: hidden; }
.replay-arena::after { content: ''; position: absolute; inset: 0; pointer-events: none; background: repeating-linear-gradient(0deg, rgba(34,211,238,0.035) 0 1px, transparent 1px 3px); }
.replay-svg { height: min(56vh, 520px); width: auto; display: block; }
.replay-field { fill: #03060e; }
.replay-terr-b { fill: rgba(255,61,166,0.05); }
.replay-terr-a { fill: rgba(34,211,238,0.05); }
.replay-grid line { stroke: rgba(34,211,238,0.13); stroke-width: 0.02; }
.replay-river { fill: rgba(56,189,248,0.16); }
.replay-bridge { fill: rgba(34,211,238,0.30); stroke: #22d3ee; stroke-width: 0.05; filter: url(#replay-glow); }
.replay-frame { fill: none; stroke: rgba(34,211,238,0.7); stroke-width: 0.07; filter: url(#replay-glow); animation: replay-frame-pulse 3.4s ease-in-out infinite; }
@keyframes replay-frame-pulse { 0%,100% { opacity: 0.55; } 50% { opacity: 0.95; } }
.replay-tower { fill: rgba(6,14,28,0.85); stroke-width: 0.09; filter: url(#replay-glow); }
.replay-tower.side-a { stroke: #22d3ee; }
.replay-tower.side-b { stroke: #ff3da6; }
.replay-tower.king { stroke-width: 0.14; }
.replay-place { stroke-width: 0.05; filter: url(#replay-glow); }
.replay-place.side-a { fill: #22d3ee; stroke: #0a6c80; }
.replay-place.side-b { fill: #ff3da6; stroke: #7a1450; }
.replay-place.type-spell { opacity: 0.78; }
.replay-dot-g.recent .replay-place { stroke: #ffffff; stroke-width: 0.16; }
.replay-dot-g.recent { animation: replay-pulse 0.7s ease-out; }
@keyframes replay-pulse { from { opacity: 0.35; } to { opacity: 1; } }
.replay-scrubwrap { position: relative; margin: 16px 2px 4px; }
.replay-marks { position: relative; height: 12px; }
.replay-mark { position: absolute; top: 2px; width: 3px; height: 9px; border-radius: 1px; transform: translateX(-1px); cursor: pointer; }
.replay-mark.side-a { background: #22d3ee; box-shadow: 0 0 6px rgba(34,211,238,0.7); }
.replay-mark.side-b { background: #ff3da6; box-shadow: 0 0 6px rgba(255,61,166,0.7); }
.replay-mark.ev { background: #f59e0b; height: 12px; top: 0; box-shadow: 0 0 6px rgba(245,158,11,0.7); }
.replay-range { width: 100%; accent-color: #22d3ee; cursor: pointer; }
.replay-controls { display: flex; align-items: center; gap: 10px; margin-top: 6px; }
.replay-btn { background: rgba(34,211,238,0.08); border: 1px solid rgba(34,211,238,0.3); color: #c9f7ff; border-radius: 6px; padding: 5px 12px; cursor: pointer; font-size: 12px; min-width: 38px; text-align: center; transition: all 120ms ease; }
.replay-btn:hover { background: rgba(34,211,238,0.2); box-shadow: 0 0 12px rgba(34,211,238,0.35); }
.replay-time { margin-left: auto; font-size: 11px; color: #5f7290; }
.replay-legend { display: flex; gap: 16px; margin-top: 10px; flex-wrap: wrap; }
.replay-legend-item { display: flex; align-items: center; gap: 6px; font-size: 10px; color: #5f7290; }
.replay-dot { width: 10px; height: 10px; border-radius: 50%; }
.replay-dot.side-a { background: #22d3ee; box-shadow: 0 0 8px rgba(34,211,238,0.7); }
.replay-dot.side-b { background: #ff3da6; box-shadow: 0 0 8px rgba(255,61,166,0.7); }
.replay-dot.ev { background: #f59e0b; border-radius: 1px; }
/* per-side player name banners around the arena */
.replay-side-banner { text-align: center; font-size: 12px; font-weight: 600; letter-spacing: 0.02em; padding: 5px 8px; border-radius: 6px; margin: 3px 0; }
.replay-side-banner.side-a { color: #22d3ee; background: rgba(34,211,238,0.08); border: 1px solid rgba(34,211,238,0.25); }
.replay-side-banner.side-b { color: #ff3da6; background: rgba(255,61,166,0.08); border: 1px solid rgba(255,61,166,0.25); }
/* match summary / insight chips */
.replay-summary { display: flex; flex-wrap: wrap; gap: 8px; padding: 8px 0 4px; }
.replay-chip { display: flex; flex-direction: column; gap: 1px; background: rgba(255,255,255,0.05); border: 1px solid var(--glass-border); border-radius: 7px; padding: 5px 10px; }
.replay-chip-l { font-size: 9px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); }
.replay-chip-v { font-size: 12.5px; font-weight: 600; color: var(--text-primary); }
.replay-chip.win .replay-chip-v { color: var(--accent-green); }
.replay-chip.comeback { border-color: var(--accent-orange); }
.replay-chip.comeback .replay-chip-v { color: var(--accent-orange); }
.replay-empty { margin-top: 12px; font-size: 12px; color: #9aa6c0; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.replay-demo { cursor: pointer; }
/* corner cut-outs (narrowed back rows) */
.replay-cut { fill: #02040a; }
/* placement: fresh ring + faded body */
.replay-ring { fill: none; stroke-width: 0.12; }
.replay-ring.side-a { stroke: #22d3ee; }
.replay-ring.side-b { stroke: #ff3da6; }
.replay-dot-g.fresh .replay-place { stroke: #fff; stroke-width: 0.15; }
/* death marker */
.replay-death line { stroke: #f59e0b; stroke-width: 0.14; filter: url(#replay-glow); }
/* tower destruction */
.replay-tower.destroyed { opacity: 0.42; }
.replay-tower.exploding { fill: #ff5252; opacity: 0.95; }
.replay-explode { fill: none; stroke: #ffcf6b; stroke-width: 0.18; filter: url(#replay-glow); }
.replay-tower-x { stroke: #ff3da6; stroke-width: 0.12; opacity: 0.85; }
.replay-mark.ev.death { background: #f59e0b; }
/* event log */
.replay-log-head { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: #5f7290; font-weight: 600; margin: 14px 0 6px; }
.replay-log { max-height: 150px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; padding-right: 4px; }
.replay-log-row { display: flex; gap: 10px; align-items: baseline; padding: 4px 8px; border-radius: 5px; cursor: pointer; border-left: 2px solid transparent; }
.replay-log-row:hover { background: rgba(34,211,238,0.06); }
.replay-log-row.side-a { border-left-color: rgba(34,211,238,0.45); }
.replay-log-row.side-b { border-left-color: rgba(255,61,166,0.45); }
.replay-log-row.tower, .replay-log-row.death { border-left-color: rgba(245,158,11,0.55); }
.replay-log-row.active { background: rgba(34,211,238,0.13); border-left-color: #22d3ee; }
.replay-log-t { font-size: 11px; color: #9aa6c0; min-width: 38px; }
.replay-log-desc { font-size: 11px; color: #c9d3e8; }
/* heat map */
.replay-heat { mix-blend-mode: screen; }
.replay-heatbtn.on { background: rgba(255,61,166,0.18); border-color: #ff3da6; color: #ffd6ec; box-shadow: 0 0 12px rgba(255,61,166,0.4); }
.replay-heatbar { display: flex; align-items: center; gap: 10px; margin-top: 8px; flex-wrap: wrap; }
.replay-sel { background: rgba(34,211,238,0.06); border: 1px solid rgba(34,211,238,0.25); color: #c9f7ff; border-radius: 6px; padding: 4px 8px; font-size: 11px; }
.replay-heat-legend { display: flex; align-items: center; gap: 6px; }
.replay-heat-lo, .replay-heat-hi { font-size: 9px; color: #5f7290; text-transform: uppercase; letter-spacing: 0.5px; }
.replay-heat-grad { width: 90px; height: 8px; border-radius: 4px; background: linear-gradient(90deg, hsl(190,90%,55%), hsl(95,90%,55%), hsl(40,90%,55%), hsl(0,90%,55%)); }
.replay-heat-count { margin-left: auto; font-size: 10px; color: #5f7290; }

/* Ranked/gamemode tag under the result pill in the collapsed row */
.match-summary-mode {
  font-size: 9px;
  color: var(--text-muted);
  margin-top: 3px;
}

/* =====================================================
   Server + Database panels (Infrastructure)
   ===================================================== */

.server-panel-meta {
  font-size: 11px;
  color: var(--text-muted);
  margin: -4px 0 12px;
}
.server-gauge-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.server-gauge-row .chart-container.sm { height: 110px; }
.server-trend-grid,
.database-trend-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.server-trend-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.server-trend-title {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  font-weight: 600;
}
.server-trend-cell .chart-container {
  height: 130px;
}

.database-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.database-stat {
  padding: 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.04);
  border-radius: 4px;
}
.database-stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  font-weight: 600;
  margin-bottom: 6px;
}
.database-stat-value {
  font-size: 24px;
  font-weight: 600;
  color: var(--accent-cyan);
}

[data-theme="light"] .match-detail-box,
[data-theme="light"] .match-detail-player,
[data-theme="light"] .database-stat {
  background: rgba(15,23,41,0.02);
  border-color: rgba(15,23,41,0.06);
}

/* Match-type filter (segmented control in matches header) */
.match-type-filter {
  display: inline-flex;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 8px;
  padding: 3px;
  gap: 2px;
}
.match-type-btn {
  appearance: none;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.3px;
  padding: 6px 14px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}
.match-type-btn:hover { color: var(--text-primary); }
.match-type-btn.active {
  background: rgba(255,255,255,0.08);
  color: var(--text-primary);
}
[data-theme="light"] .match-type-filter {
  background: rgba(15,23,41,0.03);
  border-color: rgba(15,23,41,0.06);
}
[data-theme="light"] .match-type-btn.active {
  background: rgba(15,23,41,0.06);
}

/* Match-type breakdown card */
.match-type-bar {
  display: flex;
  width: 100%;
  height: 14px;
  background: rgba(255,255,255,0.04);
  border-radius: 7px;
  overflow: hidden;
  margin: 12px 0 14px;
}
.match-type-bar-ranked   { height: 100%; background: var(--accent-blue);   transition: width 0.3s ease; }
.match-type-bar-friendly { height: 100%; background: var(--accent-orange); transition: width 0.3s ease; }
.match-type-bar-tutorial { height: 100%; background: var(--accent-purple); transition: width 0.3s ease; }
.match-type-bar-bot      { height: 100%; background: var(--accent-red);    transition: width 0.3s ease; }
.match-type-legend {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.match-type-legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--text-primary);
}
.match-type-legend-item .muted { color: var(--text-muted); }
.match-type-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}
.match-type-dot-ranked   { background: var(--accent-blue); }
.match-type-dot-friendly { background: var(--accent-orange); }
.match-type-dot-tutorial { background: var(--accent-purple); }
.match-type-dot-bot      { background: var(--accent-red); }
.match-type-modes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.match-type-mode {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
}
.match-type-mode-name { color: var(--text-secondary); }
.match-type-mode-count { color: var(--text-primary); font-family: var(--font-mono, monospace); font-weight: 600; }
[data-theme="light"] .match-type-bar { background: rgba(15,23,41,0.05); }
[data-theme="light"] .match-type-mode {
  background: rgba(15,23,41,0.03);
  border-color: rgba(15,23,41,0.06);
}

/* ============================================================
   UGC Studio (under construction) + Creator Codes
   Token-only; no emojis. Appended for the new sections.
   ============================================================ */

.mono { font-family: var(--font-mono); }

/* ---- Work-in-progress badge ---- */
.wip-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; color: var(--accent-orange);
  background: var(--accent-orange-subtle);
  border: 1px solid var(--accent-orange-muted);
  padding: 6px 12px; border-radius: var(--radius-sm);
  text-transform: uppercase; white-space: nowrap;
}
.wip-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent-orange);
  box-shadow: 0 0 0 0 var(--accent-orange);
  animation: wip-pulse 1.6s infinite;
}
@keyframes wip-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(249,115,22,0.5); opacity: 1; }
  70%  { box-shadow: 0 0 0 6px rgba(249,115,22,0); opacity: 0.6; }
  100% { box-shadow: 0 0 0 0 rgba(249,115,22,0); opacity: 1; }
}

/* ---- Build progress card ---- */
.ugc-progress-card { margin-bottom: var(--space-2xl); position: relative; overflow: hidden; }
.ugc-progress-card::after {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: repeating-linear-gradient(45deg,
    rgba(249,115,22,0.05) 0, rgba(249,115,22,0.05) 10px,
    transparent 10px, transparent 20px);
  opacity: 0.5;
}
.ugc-progress-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; position: relative; }
.ugc-progress-label { font-size: 12px; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.1em; }
.ugc-progress-pct { font-size: 16px; font-weight: 600; color: var(--accent-orange); }
.ugc-progress-track { height: 6px; border-radius: 3px; background: rgba(255,255,255,0.06); overflow: hidden; position: relative; }
[data-theme="light"] .ugc-progress-track { background: rgba(15,23,41,0.06); }
.ugc-progress-fill { height: 100%; border-radius: 3px; background: linear-gradient(90deg, var(--accent-orange), var(--accent-yellow)); }
.ugc-progress-note { margin-top: 10px; font-size: 12px; color: var(--text-muted); position: relative; }

/* ---- UGC block ---- */
.ugc-block { margin-bottom: var(--space-3xl); }
.ugc-block-head { display: flex; align-items: baseline; gap: 12px; margin-bottom: var(--space-lg); }
.ugc-kicker { font-size: 12px; color: var(--accent-blue); font-weight: 600; }
.ugc-block-head h2 { font-size: 16px; font-weight: 600; color: var(--text-primary); margin: 0; }
.ugc-block-sub { font-size: 12px; color: var(--text-muted); }

/* ---- Pipeline ---- */
.ugc-pipeline {
  display: flex; align-items: stretch; gap: 4px; flex-wrap: wrap;
  padding: var(--space-xl);
  border: 1px solid var(--glass-border); border-radius: var(--radius-lg);
  background:
    linear-gradient(var(--glass-bg), var(--glass-bg)),
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 100% 100%, 22px 22px, 22px 22px;
}
[data-theme="light"] .ugc-pipeline {
  background:
    linear-gradient(var(--glass-bg), var(--glass-bg)),
    linear-gradient(rgba(15,23,41,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,41,0.03) 1px, transparent 1px);
  background-size: 100% 100%, 22px 22px, 22px 22px;
}
.ugc-stage {
  flex: 1 1 150px; min-width: 140px;
  display: flex; flex-direction: column; gap: 6px;
  padding: 14px; border-radius: var(--radius-md);
  background: var(--bg-tertiary); border: 1px solid var(--glass-border);
  transition: transform var(--transition-fast), border-color var(--transition-fast);
}
.ugc-stage:hover { transform: translateY(-2px); border-color: var(--glass-border-hover); }
.ugc-stage-top { display: flex; align-items: center; justify-content: space-between; }
.ugc-stage-idx { font-size: 11px; color: var(--text-muted); font-weight: 600; }
.ugc-stage-icon { width: 18px; height: 18px; color: var(--accent-blue); }
.ugc-stage-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.ugc-stage-desc { font-size: 11px; color: var(--text-secondary); line-height: 1.35; flex: 1; }
.ugc-stage-pill {
  align-self: flex-start; font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  padding: 2px 7px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.06em;
}
.ugc-stage-pill.design  { color: var(--accent-cyan);   background: var(--accent-cyan-subtle);   border: 1px solid var(--accent-cyan-muted); }
.ugc-stage-pill.planned { color: var(--accent-blue);   background: var(--accent-blue-subtle);   border: 1px solid var(--accent-blue-muted); }
.ugc-stage-pill.locked  { color: var(--text-muted);    background: rgba(255,255,255,0.04);      border: 1px solid var(--glass-border); }
.ugc-stage[data-status="design"]  .ugc-stage-icon { color: var(--accent-cyan); }
.ugc-stage[data-status="locked"]  { opacity: 0.62; }
.ugc-stage[data-status="locked"]  .ugc-stage-icon { color: var(--text-muted); }
.ugc-arrow { display: flex; align-items: center; color: var(--text-muted); }
.ugc-arrow svg { width: 16px; height: 16px; }

/* ---- Capabilities grid ---- */
.ugc-cap-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-md); }
.ugc-cap {
  padding: var(--space-lg); border-radius: var(--radius-md);
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  transition: border-color var(--transition-fast), transform var(--transition-fast);
}
.ugc-cap:hover { border-color: var(--glass-border-hover); transform: translateY(-2px); }
.ugc-cap svg { width: 20px; height: 20px; color: var(--accent-purple); margin-bottom: 8px; }
.ugc-cap-t { font-size: 13px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; }
.ugc-cap-d { font-size: 11px; color: var(--text-secondary); line-height: 1.4; }

/* ---- Channels ---- */
.ugc-channels { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.ugc-channel {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 18px; border-radius: var(--radius-md);
  background: var(--glass-bg); border: 1px solid var(--glass-border); min-width: 150px;
}
.ugc-channel-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.ugc-channel-status {
  font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.06em;
  color: var(--accent-blue); text-transform: uppercase;
}

/* ---- Roadmap ---- */
.ugc-roadmap { display: flex; flex-direction: column; gap: var(--space-sm); }
.ugc-phase {
  display: flex; align-items: center; gap: var(--space-lg);
  padding: var(--space-lg); border-radius: var(--radius-md);
  background: var(--glass-bg); border: 1px solid var(--glass-border);
}
.ugc-phase[data-phase="active"] { border-color: var(--accent-cyan-muted); }
.ugc-phase-tag { font-size: 11px; font-weight: 600; color: var(--accent-blue); min-width: 64px; }
.ugc-phase-body { flex: 1; }
.ugc-phase-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.ugc-phase-desc { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }
.ugc-phase-pill {
  font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 3px 9px;
  border-radius: 4px; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap;
}
.ugc-phase-pill.design  { color: var(--accent-cyan); background: var(--accent-cyan-subtle); border: 1px solid var(--accent-cyan-muted); }
.ugc-phase-pill.planned { color: var(--text-muted); background: rgba(255,255,255,0.04); border: 1px solid var(--glass-border); }

/* ============================================================
   Creator Codes
   ============================================================ */

.cc-stat-foot { font-size: 11px; color: var(--text-muted); font-family: var(--font-mono); margin-top: 4px; }

/* status / generic pills */
.cc-pill {
  display: inline-block; font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  padding: 2px 8px; border-radius: 4px; text-transform: uppercase; letter-spacing: 0.05em;
}
.cc-pill.ok    { color: var(--accent-green);  background: var(--accent-green-subtle);  border: 1px solid var(--accent-green-muted); }
.cc-pill.warn  { color: var(--accent-orange); background: var(--accent-orange-subtle); border: 1px solid var(--accent-orange-muted); }
.cc-pill.muted { color: var(--text-muted);    background: rgba(255,255,255,0.04);      border: 1px solid var(--glass-border); }

.cc-muted { color: var(--text-muted); }
.cc-empty-sub { font-size: 12px; color: var(--text-muted); margin-top: 6px; }
.cc-error-text { color: var(--accent-red) !important; }

/* mini buttons */
.qa-btn.cc-mini { padding: 5px 10px; font-size: 12px; width: auto; }
.qa-btn.cc-danger { background: var(--accent-red); color: #fff; border-color: var(--accent-red); }

/* creator card */
.cc-creator {
  border: 1px solid var(--glass-border); border-radius: var(--radius-md);
  background: var(--bg-tertiary); margin-bottom: var(--space-md); overflow: hidden;
}
.cc-creator-head {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-md);
  padding: 14px var(--space-lg); flex-wrap: wrap;
}
.cc-creator-id { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cc-creator-name { font-size: 15px; font-weight: 600; color: var(--text-primary); }
.cc-creator-handle { font-size: 11px; color: var(--text-muted); }
.cc-creator-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cc-redeem-badge { display: flex; flex-direction: column; align-items: flex-end; margin-right: 4px; }
.cc-redeem-num { font-size: 15px; font-weight: 700; color: var(--accent-green); }
.cc-redeem-lbl { font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.cc-no-codes { padding: 10px var(--space-lg) 16px; font-size: 12px; color: var(--text-muted); }

/* codes table inside a creator card */
.data-table.cc-codes { margin: 0; }
.data-table.cc-codes thead th { padding: 8px var(--space-lg); }
.data-table.cc-codes tbody td { padding: 8px var(--space-lg); }
.cc-code-cell { color: var(--accent-cyan); font-weight: 600; }
.cc-code-actions { display: flex; gap: 6px; justify-content: flex-end; }

/* env badge */
.cc-env { font-family: var(--font-mono); font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 4px; text-transform: uppercase; }
.cc-env.prod   { color: var(--accent-green); background: var(--accent-green-subtle); border: 1px solid var(--accent-green-muted); }
.cc-env.studio { color: var(--accent-purple); background: var(--accent-purple-muted); border: 1px solid var(--accent-purple-muted); }

/* provisioning banner */
.cc-provision { padding: var(--space-2xl); text-align: center; }
.cc-provision-t { font-size: 14px; font-weight: 600; color: var(--accent-orange); margin-bottom: 6px; }
.cc-provision-d { font-size: 12px; color: var(--text-secondary); max-width: 520px; margin: 0 auto; line-height: 1.5; }

/* ---- modals ---- */
.cc-modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  background: rgba(3,6,14,0.6); backdrop-filter: blur(4px); padding: var(--space-lg);
}
.cc-modal-overlay.hidden { display: none; }
.cc-modal { width: 100%; max-width: 420px; padding: var(--space-2xl); }
.cc-modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-lg); }
.cc-modal-head h3 { font-size: 16px; font-weight: 600; margin: 0; color: var(--text-primary); }
.cc-modal-close { background: none; border: none; color: var(--text-muted); cursor: pointer; padding: 4px; display: flex; }
.cc-modal-close:hover { color: var(--text-primary); }
.cc-modal-close svg { width: 18px; height: 18px; }
.cc-modal-for { font-size: 12px; color: var(--text-muted); margin-bottom: var(--space-md); }
.cc-field { display: block; margin-bottom: var(--space-md); }
.cc-field > span { display: block; font-size: 12px; color: var(--text-secondary); margin-bottom: 5px; }
.cc-field .login-input { width: 100%; }
.cc-field textarea.login-input { resize: vertical; font-family: var(--font-display); }
.cc-modal-error { color: var(--accent-red); font-size: 12px; min-height: 16px; margin-bottom: 8px; }
.cc-modal-actions { display: flex; justify-content: flex-end; gap: var(--space-sm); }
.cc-modal-actions .qa-btn { width: auto; }

/* team member last-active line (Settings) */
.user-lastactive { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

/* ============================================================
   Player Editor (admin, coming soon — visual only)
   ============================================================ */
.pe-card { position: relative; }
.pe-note { font-size: 12px; color: var(--text-secondary); margin: -4px 0 var(--space-lg); max-width: 760px; line-height: 1.5; }

.pe-search { display: flex; gap: var(--space-sm); margin-bottom: var(--space-xl); max-width: 520px; }
.pe-search .login-input { flex: 1; }
.pe-search .btn { width: auto; white-space: nowrap; }

/* The editable body reads as a disabled/preview surface. */
.pe-editor {
  position: relative; border: 1px solid var(--glass-border); border-radius: var(--radius-md);
  padding: var(--space-xl); background: rgba(255,255,255,0.015);
}
[data-theme="light"] .pe-editor { background: rgba(15,23,41,0.015); }

.pe-player-head { display: flex; align-items: center; gap: var(--space-md); margin-bottom: var(--space-xl); flex-wrap: wrap; }
.pe-avatar { width: 44px; height: 44px; font-size: 15px; }
.pe-player-name { font-size: 16px; font-weight: 600; color: var(--text-primary); }
.pe-handle { font-size: 12px; color: var(--text-muted); font-weight: 400; margin-left: 6px; }
.pe-player-meta { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.pe-readonly-tag {
  margin-left: auto; font-family: var(--font-mono); font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em; color: var(--accent-orange);
  background: var(--accent-orange-subtle); border: 1px solid var(--accent-orange-muted);
  padding: 4px 9px; border-radius: 4px;
}

.pe-groups { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--space-lg); }
.pe-group { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-md); padding: var(--space-lg); }
.pe-group-wide { grid-column: 1 / -1; }
.pe-group-title {
  font-size: 12px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase;
  letter-spacing: 0.08em; margin-bottom: var(--space-md); display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
}
.pe-soon-tag, .pe-actions-note { font-family: var(--font-mono); font-size: 10px; color: var(--text-muted); text-transform: none; letter-spacing: 0; font-weight: 400; }

.pe-fields { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-sm) var(--space-md); }
.pe-field { display: flex; flex-direction: column; gap: 4px; }
.pe-field > span { font-size: 11px; color: var(--text-muted); }
.pe-field .login-input { width: 100%; padding: 7px 10px; font-size: 13px; }
.pe-field .login-input:disabled { color: var(--text-primary); opacity: 0.85; cursor: not-allowed; -webkit-text-fill-color: var(--text-primary); }
.pe-field-toggle { flex-direction: row; align-items: center; justify-content: space-between; }
.pe-field-toggle > span { font-size: 12px; color: var(--text-secondary); }
.pe-toggle-disabled { opacity: 0.45; cursor: not-allowed; pointer-events: none; }

/* placeholder card tiles */
.pe-cards { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.pe-card-tile {
  width: 52px; height: 68px; border-radius: var(--radius-sm);
  background: var(--bg-tertiary); border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.pe-card-tile::after {
  content: ''; position: absolute; left: 0; right: 0; top: 0; height: 3px;
}
.pe-card-tile[data-rarity="common"]::after    { background: var(--accent-slate, #64748b); }
.pe-card-tile[data-rarity="rare"]::after       { background: var(--accent-blue); }
.pe-card-tile[data-rarity="epic"]::after       { background: var(--accent-purple); }
.pe-card-tile[data-rarity="legendary"]::after  { background: var(--accent-orange); }
.pe-card-tile::before {
  content: '?'; font-family: var(--font-mono); font-size: 18px; color: var(--text-muted); opacity: 0.5;
}
.pe-card-more { font-family: var(--font-mono); font-size: 11px; color: var(--text-muted); }
.pe-card-more::before { content: ''; }

.pe-actions { display: flex; align-items: center; gap: var(--space-md); margin-top: var(--space-xl); flex-wrap: wrap; }
.pe-actions .btn { width: auto; }

.pe-note-top { margin: -4px 0 var(--space-xl); max-width: 860px; font-size: 13px; }

/* ============================================================================
   Infrastructure — Live Cloud Topology
   ============================================================================ */

.topo-root { display: flex; flex-direction: column; gap: var(--space-lg); margin-bottom: var(--space-xl); }
.topo-loading, .topo-empty { font-size: 12px; color: var(--text-muted); padding: var(--space-lg); }
.topo-foot { font-size: 11px; color: var(--text-muted); text-align: right; }

/* color helpers (reuse accent tokens) */
.topo-fg-green  { color: var(--accent-green); }
.topo-fg-cyan   { color: var(--accent-cyan); }
.topo-fg-blue   { color: var(--accent-blue); }
.topo-fg-orange { color: var(--accent-orange); }
.topo-fg-red    { color: var(--accent-red); }
.topo-fg-purple { color: var(--accent-purple); }
.topo-fg-muted  { color: var(--text-muted); }
.topo-bg-green  { background: var(--accent-green); }
.topo-bg-cyan   { background: var(--accent-cyan); }
.topo-bg-blue   { background: var(--accent-blue); }
.topo-bg-orange { background: var(--accent-orange); }
.topo-bg-red    { background: var(--accent-red); }
.topo-bg-purple { background: var(--accent-purple); }
.topo-bg-muted  { background: var(--text-muted); }

/* status dot */
.topo-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.topo-dot-ok    { background: var(--accent-green); box-shadow: 0 0 6px var(--accent-green); }
.topo-dot-warn  { background: var(--accent-orange); box-shadow: 0 0 6px var(--accent-orange); animation: topo-pulse 1.4s ease-in-out infinite; }
.topo-dot-bad   { background: var(--accent-red); box-shadow: 0 0 6px var(--accent-red); }
.topo-dot-muted { background: var(--text-muted); }
@keyframes topo-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }

/* badges */
.topo-badge { font-family: var(--font-mono); font-size: 10px; font-weight: 600; letter-spacing: 0.03em;
  padding: 1px 6px; border-radius: var(--radius-sm); text-transform: uppercase; white-space: nowrap; }
.topo-badge-blue   { background: var(--accent-blue-subtle, rgba(56,132,255,0.14)); color: var(--accent-blue); }
.topo-badge-green  { background: var(--accent-green-subtle, rgba(52,199,89,0.14)); color: var(--accent-green); }
.topo-badge-orange { background: var(--accent-orange-subtle, rgba(255,159,10,0.14)); color: var(--accent-orange); }
.topo-badge-red    { background: var(--accent-red-subtle, rgba(255,69,58,0.14)); color: var(--accent-red); }
.topo-badge-cyan   { background: var(--accent-cyan-subtle, rgba(50,215,235,0.14)); color: var(--accent-cyan); }
.topo-badge-purple { background: var(--accent-purple-muted, rgba(175,82,222,0.14)); color: var(--accent-purple); }
.topo-badge-muted  { background: var(--bg-tertiary); color: var(--text-secondary); }

/* summary strip */
/* upstream service status cards (Cloudflare / DigitalOcean / Roblox) */
.topo-svc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 14px; }
.topo-svc { padding: 14px 16px; border-radius: 12px; background: rgba(255,255,255,0.02); border: 1px solid var(--glass-border); }
.topo-svc-head { display: flex; align-items: center; gap: 9px; margin-bottom: 6px; }
.topo-svc-dot { width: 10px; height: 10px; border-radius: 50%; flex: 0 0 auto; }
.topo-svc-name { font-size: 14px; font-weight: 700; color: var(--text-primary); flex: 1; }
.topo-svc-note { font-size: 10.5px; color: var(--text-muted); margin-bottom: 10px; }
.topo-svc-stat { font-size: 12px; margin-bottom: 8px; }
.topo-svc-stat-n { font-weight: 700; }
.topo-svc-stat-l { color: var(--text-muted); }
.topo-svc-prob { display: flex; align-items: center; gap: 7px; font-size: 11px; padding: 2px 0; }
.topo-svc-prob-dot { width: 7px; height: 7px; border-radius: 50%; flex: 0 0 auto; }
.topo-svc-prob-name { flex: 1; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topo-svc-prob-st { color: var(--text-muted); font-size: 10px; flex: 0 0 auto; }
.topo-svc-more { font-size: 10px; color: var(--text-muted); margin-top: 3px; }
.topo-svc-inc { font-size: 11px; color: var(--accent-orange); margin-top: 6px; line-height: 1.4; }
.topo-svc-foot { font-size: 10px; color: var(--text-muted); margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--glass-border); }
.topo-summary { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.topo-chip { flex: 1 1 140px; background: var(--glass-bg); border: 1px solid var(--glass-border);
  border-radius: var(--radius-md); padding: 12px 14px; }
.topo-chip-val { font-size: 22px; font-weight: 700; line-height: 1.1; }
.topo-chip-label { font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 4px; }

/* live routing flow */
.topo-routing .topo-flow { display: flex; align-items: stretch; flex-wrap: wrap; gap: 8px; margin-top: var(--space-md); }
.topo-stage { flex: 1 1 0; min-width: 110px; border: 1px solid var(--glass-border); border-radius: var(--radius-md);
  padding: 10px 12px; background: var(--bg-secondary); border-left-width: 3px; }
.topo-stage-title { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.topo-stage-sub { font-size: 11px; color: var(--text-secondary); margin-top: 3px; }
.topo-stage-purple { border-left-color: var(--accent-purple); }
.topo-stage-blue   { border-left-color: var(--accent-blue); }
.topo-stage-green  { border-left-color: var(--accent-green); }
.topo-stage-cyan   { border-left-color: var(--accent-cyan); }
.topo-stage-orange { border-left-color: var(--accent-orange); }
.topo-stage-muted  { border-left-color: var(--text-muted); }
.topo-arrow { display: flex; align-items: center; color: var(--text-muted); font-size: 16px; flex: 0 0 auto; }

/* project section */
.topo-project { display: flex; flex-direction: column; gap: var(--space-md); }
.topo-project-head { display: flex; align-items: center; gap: 10px; margin-top: var(--space-sm); }
.topo-project-name { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.topo-project-purpose { font-size: 11px; color: var(--text-muted); }

/* cluster card */
.topo-cluster { display: flex; flex-direction: column; gap: var(--space-md); }
.topo-cluster-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.topo-cluster-name { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.topo-cluster-count { margin-left: auto; font-size: 12px; color: var(--text-secondary); }

/* autoscale capacity bar */
.topo-scale { display: flex; flex-direction: column; gap: 6px; }
.topo-scale-head { display: flex; justify-content: space-between; font-size: 11px; }
.topo-scale-label { color: var(--text-secondary); }
.topo-scale-range { color: var(--text-muted); }
.topo-scale-track { display: flex; gap: 4px; }
.topo-scale-cell { flex: 1 1 0; height: 6px; border-radius: 3px; background: var(--bg-tertiary); border: 1px solid var(--glass-border); }
.topo-scale-on   { background: var(--accent-green); border-color: var(--accent-green); }
.topo-scale-prov { background: var(--accent-orange); border-color: var(--accent-orange); animation: topo-pulse 1.4s ease-in-out infinite; }
.topo-scale-min  { background: var(--accent-blue-muted, rgba(56,132,255,0.3)); }

/* node grid + tiles */
.topo-nodes { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: var(--space-md); }
.topo-node { background: var(--bg-secondary); border: 1px solid var(--glass-border); border-radius: var(--radius-md); padding: 10px 12px; display: flex; flex-direction: column; gap: 7px; }
.topo-node-head { display: flex; align-items: center; gap: 7px; }
.topo-node-name { font-size: 12px; font-weight: 600; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topo-node-head .topo-badge { margin-left: auto; }
.topo-node-sub { font-size: 10px; color: var(--text-muted); }
.topo-node-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 2px; }
.topo-node-stats { font-size: 10px; color: var(--text-muted); white-space: nowrap; }
.topo-spark-wrap { flex: 1 1 0; height: 24px; min-width: 60px; }
.topo-spark { width: 100%; height: 24px; display: block; }

/* meters */
.topo-meter { display: flex; flex-direction: column; gap: 3px; }
.topo-meter-head { display: flex; justify-content: space-between; font-size: 10px; }
.topo-meter-label { color: var(--text-muted); letter-spacing: 0.04em; }
.topo-meter-val { font-weight: 600; }
.topo-meter-track { height: 5px; border-radius: 3px; background: var(--bg-tertiary); overflow: hidden; }
.topo-meter-fill { height: 100%; border-radius: 3px; transition: width var(--transition-base); }

/* load balancer (router) row */
.topo-lb { border-top: 1px dashed var(--glass-border); padding-top: var(--space-md); display: flex; flex-direction: column; gap: 6px; }
.topo-lb-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.topo-lb-title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--accent-blue); }
.topo-lb-name { font-size: 12px; color: var(--text-primary); }
.topo-lb-ip { font-size: 11px; color: var(--text-muted); margin-left: auto; }
.topo-lb-rules { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.topo-lb-backends { font-size: 11px; color: var(--text-secondary); }
.topo-lb-hc { font-size: 10px; color: var(--text-muted); }

/* managed database tiles */
.topo-dbs { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-md); }
.topo-db { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-md); padding: 12px 14px; display: flex; flex-direction: column; gap: 9px; }
.topo-db-head { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.topo-db-name { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.topo-db-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 14px; }
.topo-kv { display: flex; justify-content: space-between; gap: 8px; font-size: 11px; align-items: baseline; }
.topo-kv .tk-label { color: var(--text-muted); white-space: nowrap; }
.topo-kv .tk-value { color: var(--text-secondary); text-align: right; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.topo-db-host { font-size: 10px; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* standalone hosts */
.topo-standalone { display: flex; flex-direction: column; gap: var(--space-md); }
.topo-standalone-head { font-size: 13px; font-weight: 600; color: var(--text-primary); }

/* labeled divider */
.section-divider { display: flex; align-items: center; gap: var(--space-md); margin: var(--space-lg) 0 var(--space-sm); }
.section-divider::after { content: ''; flex: 1; height: 1px; background: var(--glass-border); }
.section-divider span { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
/* time-range selector embedded in a section divider (explicit line, selector on the right) */
.section-divider-tr::after { display: none; }
.section-divider-tr .sd-line { flex: 1; height: 1px; background: var(--glass-border); }
.time-range { display: inline-flex; gap: 4px; flex: 0 0 auto; }
.tr-pill { padding: 3px 9px; border-radius: 6px; cursor: pointer; font-family: inherit; font-size: 10.5px; font-weight: 600;
  background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); color: var(--text-muted); transition: 0.12s; }
.tr-pill:hover { color: var(--text-secondary); border-color: rgba(255,255,255,0.18); }
.tr-pill.tr-active { background: rgba(34,211,238,0.14); border-color: var(--accent-cyan); color: var(--accent-cyan); }

/* ---- overall status banner ---- */
.topo-status { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-radius: var(--radius-lg);
  border: 1px solid var(--glass-border); background: var(--glass-bg); position: relative; overflow: hidden; }
.topo-status::after { content: ''; position: absolute; inset: 0; pointer-events: none; opacity: 0.5;
  background: linear-gradient(90deg, transparent, transparent); }
/* status conveyed by the pulsing dot (no colored left bar) */
.topo-status-dot { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 auto; position: relative; }
.topo-status-ok .topo-status-dot { background: var(--accent-green); box-shadow: 0 0 0 0 rgba(52,199,89,0.5); animation: topo-ring 2.2s ease-out infinite; }
.topo-status-warn .topo-status-dot { background: var(--accent-orange); box-shadow: 0 0 0 0 rgba(255,159,10,0.5); animation: topo-ring 1.6s ease-out infinite; }
@keyframes topo-ring { 0% { box-shadow: 0 0 0 0 rgba(52,199,89,0.45); } 70% { box-shadow: 0 0 0 10px rgba(52,199,89,0); } 100% { box-shadow: 0 0 0 0 rgba(52,199,89,0); } }
.topo-status-title { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.topo-status-sub { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* ---- edge security / firewalls ---- */
.topo-fws { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-md); }
.topo-fw { background: var(--bg-secondary); border: 1px solid var(--glass-border); border-radius: var(--radius-md);
  padding: 12px 14px; display: flex; flex-direction: column; gap: 8px;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base); }
.topo-fw-head { display: flex; align-items: center; gap: 7px; }
.topo-fw-label { font-size: 12px; font-weight: 700; color: var(--text-primary); }
.topo-fw-head .topo-badge { margin-left: auto; }
.topo-fw-role { font-size: 11px; color: var(--text-secondary); }
.topo-fw-grid { display: grid; grid-template-columns: 1fr; gap: 5px 14px; }

/* ---- skeleton loader lines ---- */
.sk-line { height: 12px; margin: 4px 0; }
.sk-line-lg { height: 22px; width: 60%; }
.sk-line-md { height: 14px; width: 35%; margin-bottom: 14px; }
.sk-line-sm { height: 10px; width: 80%; }
.sk-block { height: 120px; width: 100%; margin-top: 8px; }

/* ---- enterprise hover + entrance polish ---- */
.topo-node, .topo-db, .topo-stage, .topo-chip {
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base), background var(--transition-base);
}
.topo-chip:hover { transform: translateY(-2px); border-color: rgba(255,255,255,0.14); box-shadow: 0 8px 24px rgba(0,0,0,0.28); }
.topo-node:hover { transform: translateY(-2px); border-color: rgba(255,255,255,0.16);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3), 0 0 0 1px rgba(59,130,246,0.08); }
.topo-db:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,0.32); border-color: rgba(255,255,255,0.14); }
.topo-db-cache:hover { box-shadow: 0 10px 28px rgba(0,0,0,0.32), 0 0 18px rgba(175,82,222,0.1); }
.topo-fw:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,0.32), 0 0 16px rgba(52,199,89,0.08); }
.topo-stage:hover { transform: translateY(-1px); background: var(--bg-tertiary); }
.topo-node:hover .topo-meter-fill { filter: brightness(1.15); }
.topo-spark { transition: opacity var(--transition-base); }
.topo-node:hover .topo-spark { opacity: 0.85; }

/* subtle staggered entrance — ONLY on first load (.topo-intro); refreshes don't re-animate */
.topo-root.topo-intro > * { animation: topo-rise 380ms cubic-bezier(0.22,1,0.36,1) both; }
.topo-root.topo-intro > *:nth-child(2) { animation-delay: 40ms; }
.topo-root.topo-intro > *:nth-child(3) { animation-delay: 80ms; }
.topo-root.topo-intro > *:nth-child(4) { animation-delay: 120ms; }
.topo-root.topo-intro > *:nth-child(n+5) { animation-delay: 160ms; }
@keyframes topo-rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .topo-root.topo-intro > * { animation: none; } .topo-status-dot { animation: none !important; } }

/* ============================================================================
   Initializing sequence overlay (white / blue / red orb intro)
   ============================================================================ */
#init-overlay { position: fixed; inset: 0; z-index: 99999; display: flex; flex-direction: column;
  align-items: center; justify-content: center; opacity: 0; transition: opacity 0.6s ease;
  background: transparent;                       /* floats over the live home screen */
  -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); }
#init-overlay.show { opacity: 1; }
#init-overlay.hide { opacity: 0; }
/* soft glow centred on the orb — keeps the home visible at the edges */
.init-bg { position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(560px 560px at 50% 46%, rgba(59,130,246,0.14), transparent 58%),
    radial-gradient(420px 420px at 50% 46%, rgba(255,40,64,0.08), transparent 60%); }
.init-stage { position: relative; z-index: 1; }
#init-orb { display: block; }
.init-caption { position: relative; z-index: 1; text-align: center; margin-top: 14px; }
.init-logo { width: 40px; height: 40px; margin: 0 auto 12px; color: #5b8cff;
  filter: drop-shadow(0 0 10px rgba(91,140,255,0.5)); }
.init-logo svg { width: 100%; height: 100%; display: block; }
.init-title { font-family: 'Sora', sans-serif; font-size: 12px; font-weight: 600;
  letter-spacing: 0.34em; color: rgba(255,255,255,0.72); text-shadow: 0 2px 20px rgba(0,0,0,0.7); }
.init-msg { font-family: 'Sora', sans-serif; font-size: 24px; font-weight: 700; margin-top: 10px;
  background: linear-gradient(90deg, #5b8cff 0%, #ffffff 50%, #ff5a6e 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
  background-size: 220% 100%; animation: init-sheen 4s ease-in-out infinite;
  filter: drop-shadow(0 2px 22px rgba(0,0,0,0.65)); }
@keyframes init-sheen { 0%,100% { background-position: 0% 0; } 50% { background-position: 100% 0; } }
.init-skip { position: absolute; top: 26px; right: 30px; z-index: 2; font-family: 'Sora', sans-serif;
  font-size: 13px; font-weight: 700; letter-spacing: 0.02em; color: #fff; background: rgba(12,18,34,0.6);
  border: 1px solid rgba(255,255,255,0.28); border-radius: 11px; padding: 10px 18px; cursor: pointer;
  transition: 0.15s; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  box-shadow: 0 4px 18px rgba(0,0,0,0.4); }
.init-skip:hover { background: rgba(40,52,86,0.85); border-color: rgba(255,255,255,0.5); transform: translateY(-1px); }
.init-hint { position: absolute; bottom: 42px; z-index: 2; font-family: 'JetBrains Mono', monospace;
  font-size: 12px; letter-spacing: 0.08em; color: rgba(255,255,255,0.5); opacity: 0; pointer-events: none; }
.init-hint.show { opacity: 1; animation: init-blink 1.6s ease-in-out infinite; }
@keyframes init-blink { 50% { opacity: 0.35; } }
@media (prefers-reduced-motion: reduce) { .init-msg { animation: none; } }

/* Error place badge (which Roblox place threw it: Lobby vs Match) */
.place-badge { display: inline-block; font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.03em; text-transform: uppercase; padding: 1px 7px; border-radius: var(--radius-sm);
  vertical-align: middle; margin-right: 6px; }
.place-badge.place-lobby { background: rgba(59,130,246,0.16); color: var(--accent-blue); }
.place-badge.place-match { background: rgba(239,68,68,0.16); color: var(--accent-red); }
.place-badge.place-other { background: var(--bg-tertiary); color: var(--text-secondary); }

/* Match list "When" — date + relative "X ago" */
.match-when-date { font-size: 12px; color: var(--text-primary); }
.match-when-ago { font-size: 11px; color: var(--text-muted); margin-top: 1px; }
.match-detail-ago { color: var(--text-muted); font-weight: 400; }

/* Per-card manual refresh button */
.card-head-l { display: flex; align-items: baseline; gap: 10px; min-width: 0; }
.card-head-r { display: flex; align-items: center; gap: 12px; flex: 0 0 auto; }

/* ===== Match list: per-type color coding + per-mode filter ===== */
/* left-edge accent on each row, color = match type (scannable at a glance) */
.match-kind-ranked   td:first-child { box-shadow: inset 3px 0 0 var(--accent-blue); }
.match-kind-friendly td:first-child { box-shadow: inset 3px 0 0 var(--accent-orange); }
.match-kind-tutorial td:first-child { box-shadow: inset 3px 0 0 var(--accent-purple); }
.match-kind-bot      td:first-child { box-shadow: inset 3px 0 0 var(--accent-red); }
/* type badge in the result cell */
.match-kind-badge { display: inline-block; font-size: 9px; font-weight: 700; letter-spacing: 0.05em; padding: 2px 6px; border-radius: 5px; }
.match-kind-badge-blue   { color: var(--accent-blue);   background: rgba(59,130,246,0.14); }
.match-kind-badge-orange { color: var(--accent-orange); background: rgba(249,115,22,0.14); }
.match-kind-badge-purple { color: var(--accent-purple); background: rgba(168,85,247,0.14); }
.match-kind-badge-slate  { color: var(--text-secondary); background: rgba(255,255,255,0.07); }
.match-kind-badge-red    { color: var(--accent-red); background: rgba(239,68,68,0.16); }
/* per-mode toggle chips */
.match-kind-filter { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.mkf-chip { display: inline-flex; align-items: center; gap: 5px; padding: 4px 9px; border-radius: 7px; cursor: pointer;
  background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); font-family: inherit;
  font-size: 10px; font-weight: 600; letter-spacing: 0.04em; color: var(--text-secondary); transition: 0.15s; }
.mkf-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.mkf-blue   .mkf-dot { background: var(--accent-blue); }
.mkf-orange .mkf-dot { background: var(--accent-orange); }
.mkf-purple .mkf-dot { background: var(--accent-purple); }
.mkf-slate  .mkf-dot { background: var(--text-muted); }
.mkf-red    .mkf-dot { background: var(--accent-red); }
.mkf-chip:hover { border-color: rgba(255,255,255,0.22); }
.mkf-off { opacity: 0.38; }
.mkf-off .mkf-dot { background: var(--text-muted) !important; }

/* ===== Player Lookup ===== */
.pl-search { display: flex; gap: 8px; margin-bottom: 4px; }
.pl-input { flex: 1; padding: 9px 12px; border-radius: 8px; background: rgba(255,255,255,0.03); border: 1px solid var(--glass-border); color: var(--text-primary); font-size: 13px; font-family: inherit; }
.pl-input:focus { outline: none; border-color: var(--accent-cyan); }
.pl-btn { padding: 9px 18px; border-radius: 8px; background: var(--accent-cyan); border: none; color: #06121a; font-weight: 700; font-size: 12px; cursor: pointer; font-family: inherit; white-space: nowrap; }
.pl-btn:hover { filter: brightness(1.08); }
.pl-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin: 20px 0 10px; flex-wrap: wrap; }
.pl-name { font-size: 20px; font-weight: 700; color: var(--text-primary); }
.pl-sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.pl-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.pl-dates { display: flex; flex-wrap: wrap; gap: 8px 24px; margin: 16px 0 6px; padding: 11px 0; border-top: 1px solid var(--glass-border); border-bottom: 1px solid var(--glass-border); }
.pl-kv { display: flex; flex-direction: column; gap: 2px; }
.pl-kv-l { font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); }
.pl-kv-v { font-size: 12px; color: var(--text-secondary); }
.pl-section-title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); margin: 20px 0 8px; }
.pl-scroll { max-height: 320px; overflow-y: auto; border: 1px solid var(--glass-border); border-radius: 8px; }
.pl-table { margin: 0; }
.pl-err-msg { max-width: 360px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--text-muted); }
/* colored stat tiles */
.pl-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(94px, 1fr)); gap: 8px; margin: 4px 0 6px; }
.pl-stat { padding: 10px 8px; border-radius: 9px; background: rgba(255,255,255,0.02); border: 1px solid var(--glass-border); text-align: center; }
.pl-stat-v { font-size: 16px; font-weight: 700; color: var(--text-primary); line-height: 1.1; }
.pl-stat-l { font-size: 9px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--text-muted); margin-top: 4px; }
/* 2-column section grid (keeps each history table narrow + organized) */
.pl-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 8px; }
.pl-sect { border: 1px solid var(--glass-border); border-radius: 11px; padding: 12px 14px; background: rgba(255,255,255,0.015); min-width: 0; }
.pl-sect-title { display: flex; align-items: center; gap: 7px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-secondary); margin-bottom: 9px; }
.pl-sect-dot { width: 7px; height: 7px; border-radius: 50%; flex: 0 0 auto; }
.pl-sect .pl-scroll { max-height: 250px; }
@media (max-width: 900px) { .pl-grid { grid-template-columns: 1fr; } }
/* mini toggle (e.g. Hide tutorials on the Match List card) */
.mini-toggle { display: inline-flex; align-items: center; gap: 7px; cursor: pointer; user-select: none; }
.mini-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.mini-toggle-sw { position: relative; width: 30px; height: 16px; border-radius: 9px; background: var(--bg-tertiary);
  border: 1px solid var(--glass-border); transition: 0.15s; flex: 0 0 auto; }
.mini-toggle-dot { position: absolute; top: 1px; left: 1px; width: 12px; height: 12px; border-radius: 50%; background: #fff; transition: left 0.15s; }
.mini-toggle input:checked + .mini-toggle-sw { background: var(--accent-cyan); border-color: var(--accent-cyan); }
.mini-toggle input:checked + .mini-toggle-sw .mini-toggle-dot { left: 15px; }
.mini-toggle-lbl { font-size: 11px; color: var(--text-muted); white-space: nowrap; }
.mini-toggle:hover .mini-toggle-lbl { color: var(--text-secondary); }

/* ===== New Players — funnel / cohort heatmap / tutorial ===== */
.np-funnel { display: flex; flex-direction: column; gap: 11px; }
.np-funnel-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 4px; }
.np-funnel-name { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.np-funnel-stat { display: flex; align-items: baseline; gap: 8px; }
.np-funnel-n { font-size: 12.5px; font-weight: 700; color: var(--text-primary); }
.np-funnel-pct { font-size: 10.5px; color: var(--text-muted); }
.np-funnel-track { height: 16px; border-radius: 5px; background: rgba(255,255,255,0.04); overflow: hidden; }
.np-funnel-fill { height: 100%; border-radius: 5px; background: linear-gradient(90deg, var(--accent-cyan), rgba(34,211,238,0.45)); transition: width 0.4s; }
.np-leak .np-funnel-fill { background: linear-gradient(90deg, var(--accent-red), rgba(255,61,61,0.45)); }
.np-funnel-step { font-size: 10.5px; color: var(--text-muted); margin-top: 5px; }
.np-leak-txt { color: var(--accent-red); font-weight: 600; }
.np-active { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--glass-border); }
.np-active-cell { text-align: center; }
.np-active-val { font-size: 18px; font-weight: 700; color: var(--accent-green); }
.np-active-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); margin-top: 3px; }
.np-cohorts th, .np-cohorts td { text-align: center; }
.np-cohorts th:first-child, .np-cohorts td:first-child { text-align: left; }
.np-heat { font-weight: 600; }
.np-tut-funnel { display: flex; flex-direction: column; gap: 10px; }
.np-tut-row { display: flex; align-items: center; gap: 12px; }
.np-tut-name { font-size: 11.5px; color: var(--text-secondary); width: 150px; flex: 0 0 auto; }
.np-tut-track { flex: 1 1 auto; height: 16px; border-radius: 5px; background: rgba(255,255,255,0.04); overflow: hidden; }
.np-tut-fill { height: 100%; background: var(--accent-purple); border-radius: 5px; transition: width 0.3s; }
.np-tut-stat { font-size: 11px; color: var(--text-primary); width: 96px; flex: 0 0 auto; text-align: right; }
.np-tut-vol { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--glass-border); }
.np-tut-vol-lbl { font-size: 10px; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-muted); margin-bottom: 9px; }
.np-tut-bars { display: flex; align-items: flex-end; gap: 3px; height: 50px; }
.np-tut-bar { flex: 1 1 0; height: 100%; display: flex; align-items: flex-end; }
.np-tut-bar-fill { width: 100%; background: var(--accent-purple); border-radius: 2px 2px 0 0; min-height: 2px; opacity: 0.78; }
.np-tut-bar:hover .np-tut-bar-fill { opacity: 1; }
.np-funnel-done { background: linear-gradient(90deg, var(--accent-green), rgba(52,199,89,0.45)); }
.np-tutdrop-stats { margin-top: 0; padding-top: 0; border-top: none; margin-bottom: 16px; grid-template-columns: repeat(2, 1fr); }
/* New Players echarts cards — keep them compact */
#np-cohorts-chart, #np-engagement-chart, #np-lossstreak-chart, #np-fairness-chart, #np-assisted-chart { height: 215px; }
/* Player Health KPI tiles */
/* summary line under the New Players chart cards */
.np-summary { display: flex; flex-wrap: wrap; gap: 8px 16px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--glass-border); font-size: 11px; color: var(--text-secondary); line-height: 1.5; }
.np-sum-item { display: inline-flex; align-items: center; gap: 6px; }
.np-sum-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }
.np-summary .np-sum-txt { white-space: nowrap; }
.np-health { display: grid; grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)); gap: 9px; }
.np-health-cell { padding: 12px 9px; border-radius: 10px; background: rgba(255,255,255,0.02); border: 1px solid var(--glass-border); text-align: center; }
.np-health-val { font-size: 19px; font-weight: 700; color: var(--text-primary); line-height: 1.1; }
.np-health-lbl { font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.03em; color: var(--text-muted); margin-top: 5px; }
.np-tone-good .np-health-val { color: var(--accent-green); }
.np-tone-warn .np-health-val { color: var(--accent-yellow); }
.np-tone-bad .np-health-val { color: var(--accent-red); }
.np-health-note { font-size: 10.5px; color: var(--text-muted); margin-top: 12px; line-height: 1.5; }
.card-refresh { flex: 0 0 auto; width: 28px; height: 28px; padding: 0; border-radius: 8px;
  background: transparent; border: 1px solid var(--glass-border); color: var(--text-muted);
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  font-size: 15px; line-height: 1; transition: 0.15s; }
.card-refresh:hover { color: var(--text-primary); background: var(--glass-bg-hover);
  border-color: rgba(255,255,255,0.18); }
.card-refresh:active { transform: scale(0.92); }
.card-refresh .cr-icon { display: inline-block; }
.card-refresh.spinning { color: var(--accent-cyan); pointer-events: none; }
.card-refresh.spinning .cr-icon { animation: bb-spin 0.7s linear infinite; }
@keyframes bb-spin { to { transform: rotate(360deg); } }

/* System Status — live functional canary tiles (Infra tab) */
.sys-status-card { margin-bottom: 18px; }
.sys-status-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
@media (max-width: 980px) { .sys-status-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .sys-status-grid { grid-template-columns: 1fr; } }
.sys-tile { position: relative; padding: 14px 16px; border-radius: 12px; background: var(--glass-bg, rgba(255,255,255,0.02));
  border: 1px solid var(--glass-border); transition: 0.15s; }
.sys-tile::before, .sys-tile::after { content: ""; position: absolute; width: 14px; height: 14px;
  pointer-events: none; border: 2px solid var(--text-muted); }
.sys-tile::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; border-top-left-radius: 12px; }
.sys-tile::after { right: -1px; bottom: -1px; border-left: 0; border-top: 0; border-bottom-right-radius: 12px; }
.sys-tile-head { display: flex; align-items: center; gap: 8px; }
.sys-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; background: var(--text-muted); }
.sys-domain { font-weight: 600; font-size: 13px; color: var(--text-primary); }
.sys-state { margin-left: auto; font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.05em; color: var(--text-muted); }
.sys-detail { font-size: 12px; color: var(--text-secondary); margin-top: 8px; min-height: 16px; }
.sys-checked { font-size: 10px; color: var(--text-muted); margin-top: 5px; }
.sys-empty { color: var(--text-muted); font-size: 13px; padding: 6px 2px; }
.sys-operational::before, .sys-operational::after { border-color: var(--accent-green); }
.sys-operational .sys-dot { background: var(--accent-green); box-shadow: 0 0 8px var(--accent-green); }
.sys-operational .sys-state { color: var(--accent-green); }
.sys-down::before, .sys-down::after { border-color: var(--accent-red); }
.sys-down .sys-dot { background: var(--accent-red); box-shadow: 0 0 8px var(--accent-red); }
.sys-down .sys-state { color: var(--accent-red); }
.sys-stale::before, .sys-stale::after { border-color: var(--accent-yellow); }
.sys-stale .sys-dot { background: var(--accent-yellow); }
.sys-stale .sys-state { color: var(--accent-yellow); }

/* "Update available" toast — subtle glass popup, bottom-right */
.bb-update-toast {
  position: fixed; right: 22px; bottom: 22px; z-index: 10000;
  display: flex; align-items: center; gap: 13px; max-width: 400px;
  padding: 14px 16px; border-radius: 14px;
  background: var(--glass-bg, rgba(18,22,34,0.92));
  border: 1px solid var(--glass-border);
  box-shadow: 0 14px 44px rgba(0,0,0,0.5);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  transform: translateY(24px) scale(0.98); opacity: 0;
  transition: transform 0.36s cubic-bezier(.2,.8,.2,1), opacity 0.36s;
}
.bb-update-toast.bb-update-in { transform: translateY(0) scale(1); opacity: 1; }
.bb-update-dot {
  width: 10px; height: 10px; border-radius: 50%; flex: 0 0 auto;
  background: var(--accent-cyan); animation: bb-update-pulse 2s infinite;
}
@keyframes bb-update-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(56,200,255,0.55); }
  70%  { box-shadow: 0 0 0 9px rgba(56,200,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(56,200,255,0); }
}
.bb-update-body { flex: 1 1 auto; min-width: 0; }
.bb-update-title { font-weight: 700; font-size: 13px; color: var(--text-primary); }
.bb-update-sub { font-size: 11.5px; color: var(--text-muted); margin-top: 2px; }
.bb-update-actions { display: flex; align-items: center; gap: 6px; flex: 0 0 auto; }
.bb-update-btn {
  background: var(--accent-cyan); color: #04121a; border: none; border-radius: 9px;
  font-weight: 700; font-size: 12px; padding: 8px 13px; cursor: pointer;
  white-space: nowrap; transition: 0.15s; font-family: inherit;
}
.bb-update-btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.bb-update-btn:disabled { opacity: 0.7; cursor: default; transform: none; }
.bb-update-dismiss {
  background: transparent; color: var(--text-muted); border: none;
  font-size: 11.5px; cursor: pointer; padding: 7px 6px; font-family: inherit;
}
.bb-update-dismiss:hover { color: var(--text-primary); }

/* ===== Critical Alert system ===== */
.bb-alert-root { position: fixed; inset: 0; z-index: 10050; pointer-events: none;
  display: flex; opacity: 0; transition: opacity 0.3s; }
.bb-alert-root.bb-alert-in { opacity: 1; }

/* critical: dim backdrop + flashing red vignette + centered blocking modal */
.bb-alert-critical { align-items: center; justify-content: center; }
.bb-alert-backdrop { position: absolute; inset: 0; background: rgba(8,10,16,0.62);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); pointer-events: auto; }
.bb-alert-vignette { position: absolute; inset: 0; pointer-events: none;
  box-shadow: inset 0 0 140px 24px rgba(255,40,55,0.0); animation: bb-alert-flash 1.05s ease-in-out infinite; }
@keyframes bb-alert-flash {
  0%, 100% { box-shadow: inset 0 0 120px 10px rgba(255,40,55,0.15); }
  50%      { box-shadow: inset 0 0 220px 60px rgba(255,40,55,0.6); }
}

/* high: top banner with red glow. warning: bottom-right amber toast. */
.bb-alert-high { align-items: flex-start; justify-content: center; }
.bb-alert-high .bb-alert-card { margin-top: 22px; box-shadow: 0 10px 40px rgba(255,60,70,0.35); }
.bb-alert-warning { align-items: flex-end; justify-content: flex-end; }
.bb-alert-warning .bb-alert-card { margin: 22px; max-width: 380px; }

/* the card */
.bb-alert-card { position: relative; pointer-events: auto; width: min(440px, calc(100vw - 40px));
  background: var(--glass-bg, rgba(18,20,30,0.96)); border: 1px solid var(--glass-border);
  border-radius: 16px; padding: 18px 20px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  transform: translateY(14px) scale(0.97); transition: transform 0.34s cubic-bezier(.2,.85,.25,1); }
.bb-alert-in .bb-alert-card { transform: translateY(0) scale(1); }
/* HUD corner brackets (replaces the colored left bar) — L-accents hugging the corners */
.bb-alert-card::before, .bb-alert-card::after { content: ""; position: absolute; width: 20px; height: 20px;
  pointer-events: none; border: 2px solid var(--accent-red); }
.bb-alert-card::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; border-top-left-radius: 16px; }
.bb-alert-card::after { right: -1px; bottom: -1px; border-left: 0; border-top: 0; border-bottom-right-radius: 16px; }
.bb-alert-high .bb-alert-card::before, .bb-alert-high .bb-alert-card::after,
.bb-alert-warning .bb-alert-card::before, .bb-alert-warning .bb-alert-card::after { border-color: var(--accent-yellow); }

.bb-alert-head { display: flex; align-items: center; gap: 10px; }
.bb-alert-dot { width: 11px; height: 11px; border-radius: 50%; flex: 0 0 auto;
  background: var(--accent-red); animation: bb-alert-pulse 1.1s infinite; }
.bb-alert-high .bb-alert-dot, .bb-alert-warning .bb-alert-dot { background: var(--accent-yellow); animation: none; }
@keyframes bb-alert-pulse {
  0% { box-shadow: 0 0 0 0 rgba(255,40,55,0.6); }
  70% { box-shadow: 0 0 0 10px rgba(255,40,55,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,40,55,0); }
}
.bb-alert-badge { font-size: 10px; font-weight: 800; letter-spacing: 0.08em;
  padding: 3px 7px; border-radius: 6px; color: #fff; background: var(--accent-red); }
.bb-alert-high .bb-alert-badge, .bb-alert-warning .bb-alert-badge { background: var(--accent-yellow); color: #1a1400; }
.bb-alert-title { font-size: 15px; font-weight: 700; color: var(--text-primary); flex: 1 1 auto; }
.bb-alert-detail { margin-top: 11px; font-size: 12.5px; color: var(--text-secondary); line-height: 1.5;
  font-family: 'JetBrains Mono', monospace; background: rgba(255,40,55,0.06); border-radius: 8px; padding: 9px 11px; }
.bb-alert-high .bb-alert-detail, .bb-alert-warning .bb-alert-detail { background: rgba(255,200,40,0.06); }
.bb-alert-fixes { margin-top: 13px; }
.bb-alert-fixes-label { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); }
.bb-alert-fixes-list { margin: 6px 0 0; padding-left: 18px; }
.bb-alert-fixes-list li { font-size: 12px; color: var(--text-secondary); line-height: 1.65; }
.bb-alert-meta { margin-top: 13px; font-size: 10.5px; color: var(--text-muted); }
.bb-alert-actions { margin-top: 15px; display: flex; gap: 9px; }
.bb-alert-notify { flex: 1 1 auto; background: var(--accent-red); color: #fff; border: none; border-radius: 9px;
  font-weight: 700; font-size: 12.5px; padding: 10px; cursor: pointer; font-family: inherit; transition: 0.15s; }
.bb-alert-notify:hover { filter: brightness(1.1); }
.bb-alert-notify:disabled { opacity: 0.75; cursor: default; }
.bb-alert-high .bb-alert-notify, .bb-alert-warning .bb-alert-notify { background: var(--accent-yellow); color: #1a1400; }
.bb-alert-ack { background: transparent; color: var(--text-secondary); border: 1px solid var(--glass-border);
  border-radius: 9px; font-weight: 600; font-size: 12.5px; padding: 10px 14px; cursor: pointer; font-family: inherit; transition: 0.15s; }
.bb-alert-ack:hover { color: var(--text-primary); border-color: rgba(255,255,255,0.22); }

/* Match-detail "Player profile" sub-section divider */
.match-detail-sublabel { font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-muted); margin: 10px 0 5px; padding-top: 8px;
  border-top: 1px dashed var(--glass-border); }

/* Deck Diversity — extra stats grid */
.deck-div-grid { margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--glass-border);
  display: flex; flex-direction: column; gap: 7px; }
.deck-div-row { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.deck-div-k { font-size: 11.5px; color: var(--text-muted); }
.deck-div-v { font-size: 12.5px; font-weight: 600; color: var(--text-secondary); }

/* Chest Rewards — drop-odds grid editor */
.chest-grid-wrap { overflow-x: auto; padding-bottom: 4px; }
.chest-grid { border-collapse: collapse; min-width: 100%; }
.chest-grid th, .chest-grid td { padding: 8px 10px; text-align: center; border-bottom: 1px solid var(--glass-border); vertical-align: middle; }
.chest-grid th { font-size: 10.5px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--text-muted); font-weight: 600; }
.cg-chest-h { text-align: left; }
.cg-br-lab { display: inline-flex; align-items: center; gap: 4px; justify-content: center; }
.cg-ge { color: var(--text-muted); }
.cg-br-input { width: 62px; text-align: center; }
.cg-name-input { width: 140px; }
.cg-w { width: 60px; text-align: center; }
.cg-cell { position: relative; }
.cg-br-range { font-size: 9px; color: var(--text-muted); margin-top: 3px; font-weight: 400; text-transform: none; letter-spacing: 0; }
/* effective-% mini bar under each weight */
.cg-eff { position: relative; height: 15px; border-radius: 4px; background: rgba(255,255,255,0.04);
  overflow: hidden; margin: 4px auto 0; width: 60px; display: flex; align-items: center; justify-content: center; }
.cg-eff-fill { position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: rgba(34,211,238,0.24); transition: width 0.15s; }
.cg-eff-txt { position: relative; font-size: 9.5px; font-weight: 600; color: var(--accent-cyan); }
.cg-eff-off { background: transparent; }
.cg-eff-off .cg-eff-txt { color: var(--text-muted); font-weight: 400; }
.chest-grid tbody tr:hover { background: rgba(255,255,255,0.02); }
.cg-row.cg-off .cg-name-input, .cg-row.cg-off .cg-w { opacity: 0.5; }
/* on/off switch */
.cg-sw { display: inline-block; width: 34px; height: 18px; border-radius: 10px; background: var(--bg-tertiary);
  border: 1px solid var(--glass-border); position: relative; transition: 0.15s; cursor: pointer; vertical-align: middle; }
.cg-sw.on { background: var(--accent-green); border-color: var(--accent-green); }
.cg-sw-h { position: absolute; top: 1px; left: 1px; width: 14px; height: 14px; border-radius: 50%; background: #fff; transition: left 0.15s; }
.cg-sw.on .cg-sw-h { left: 17px; }
.cg-sw-ro { opacity: 0.5; cursor: default; }
/* kill the browser default up/down spinner on all config number inputs */
.config-input[type="number"]::-webkit-outer-spin-button,
.config-input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.config-input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
/* hide work-in-progress tabs from the top bar (still reachable via Settings) */
.nav-item.nav-wip { display: none; }
/* Settings → "In Development" launcher cards */
.wip-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; }
.wip-item { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; text-align: left;
  padding: 13px 15px; border-radius: 11px; background: var(--glass-bg, rgba(255,255,255,0.02));
  border: 1px solid var(--glass-border); cursor: pointer; transition: 0.15s; font-family: inherit; }
.wip-item:hover { border-color: rgba(255,255,255,0.2); transform: translateY(-1px); }
.wip-name { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.wip-tag { font-size: 9.5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--accent-yellow); }
.wip-tag.soon { color: var(--text-muted); }
.cg-col-rm, .cg-row-rm { background: transparent; border: none; color: var(--text-muted); cursor: pointer;
  font-size: 14px; line-height: 1; margin-left: 5px; padding: 2px; }
.cg-col-rm:hover, .cg-row-rm:hover { color: var(--accent-red); }
.cg-addcol { background: transparent; border: 1px dashed var(--glass-border); color: var(--text-muted);
  border-radius: 7px; font-size: 11px; padding: 5px 9px; cursor: pointer; white-space: nowrap; }
.cg-addcol:hover { color: var(--text-primary); border-color: rgba(255,255,255,0.25); }
.chest-actions { display: flex; align-items: center; gap: 12px; margin-top: 16px; flex-wrap: wrap; }
.chest-drops-table th, .chest-drops-table td { text-align: center; }
.chest-drops-table th:first-child, .chest-drops-table td:first-child { text-align: left; }
.chest-drops-total td { font-weight: 700; border-top: 2px solid var(--glass-border); color: var(--text-primary); }
