/* Base Advocate design system. Mirrors training.html — same tokens,
   same glass recipe, same drifting blob backdrop. Blue + beige blobs
   only (no pink/orange). Applies globally to index.html (training.html
   keeps its own inline styles, untouched). */

:root {
  --accent:        #0A84FF;
  --accent-2:      #5E5CE6;
  --accent-grad:   linear-gradient(180deg, #1A8FFF 0%, #0A6FFF 100%);
  --text-h:        #1D1D1F;
  --text:          #3C3C43;
  --text-sub:      rgba(60,60,67,0.72);
  --text-dim:      rgba(60,60,67,0.45);
  --success:       #30D158;
  --warning:       #FF9F0A;
  --error:         #FF3B30;
  --r:             14px;
  --r-lg:          22px;
  --r-xl:          32px;
  --glass-bg:      rgba(255,255,255,0.55);
  --glass-bg-2:    rgba(255,255,255,0.72);
  --glass-stroke:  rgba(255,255,255,0.65);
  --glass-stroke-in: rgba(255,255,255,0.9);
  --glass-shadow:  0 30px 80px -20px rgba(15,30,80,0.25), 0 8px 24px -8px rgba(15,30,80,0.18), inset 0 1px 0 rgba(255,255,255,0.7);
  --ease-out:      cubic-bezier(0.22, 1, 0.36, 1);
  --spring:        cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── AMBIENT BACKDROP — blue blobs + warm beige ────────────────── */
html, body {
  -webkit-font-smoothing: antialiased;
  letter-spacing: -0.011em;
}
body {
  background:
    radial-gradient(60% 50% at 12% 20%, rgba(94,92,230,0.30), transparent 70%),
    radial-gradient(50% 50% at 88% 28%, rgba(232,205,165,0.42), transparent 65%),
    radial-gradient(60% 60% at 70% 92%, rgba(10,132,255,0.30), transparent 70%),
    radial-gradient(55% 55% at 18% 86%, rgba(245,225,185,0.36), transparent 70%),
    linear-gradient(180deg, #f5f1e8 0%, #eef0f8 100%) !important;
  background-attachment: fixed !important;
  background-image: var(--bg-img, none);
}
body::before {
  content: '';
  position: fixed; inset: -10vh -10vw;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(280px 280px at 20% 30%, rgba(94,92,230,0.45), transparent 60%),
    radial-gradient(320px 320px at 78% 22%, rgba(232,205,165,0.55), transparent 60%),
    radial-gradient(360px 360px at 75% 80%, rgba(10,132,255,0.50), transparent 60%),
    radial-gradient(260px 260px at 18% 78%, rgba(248,228,190,0.50), transparent 60%);
  filter: blur(20px);
  animation: bdDrift 28s ease-in-out infinite alternate;
}
@keyframes bdDrift {
  0%   { transform: translate3d(0,0,0)       scale(1);    }
  50%  { transform: translate3d(2%, -2%, 0)  scale(1.05); }
  100% { transform: translate3d(-2%, 1%, 0)  scale(0.98); }
}
body > * { position: relative; z-index: 1; }

/* All app screens become transparent so the body backdrop shows through */
.screen,
#screen-landing.screen,
#screen-fetching,
#screen-results,
#screen-profile,
#screen-profile-locked,
#screen-tasks,
#screen-leaderboard,
#screen-badges {
  background: transparent !important;
}

/* Loading screen — plain white, no blur, covers body backdrop */
#screen-loading {
  background: #ffffff !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}
#screen-landing.screen::before,
#screen-landing.screen::after { content: none !important; }
#screen-landing .landing-body { background-image: none; padding: 90px 28px 60px; gap: 24px; }

/* ──────────────────────────────────────────────────────────────
   GLASS PANEL RECIPE (training-exact)
   ────────────────────────────────────────────────────────────── */
.bd-glass {
  position: relative;
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(32px) saturate(190%);
  backdrop-filter: blur(32px) saturate(190%);
  border: 1px solid var(--glass-stroke);
  border-radius: var(--r-lg);
  box-shadow: var(--glass-shadow);
  overflow: hidden;
  isolation: isolate;
}
.bd-glass::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.45), transparent 70%);
  mix-blend-mode: screen;
}
.bd-glass::after {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.3), inset 0 -1px 0 rgba(255,255,255,0.4);
}
.bd-glass > * { position: relative; z-index: 1; }

/* ──────────────────────────────────────────────────────────────
   FLOATING CAPSULE NAVBAR (logged-in)
   ────────────────────────────────────────────────────────────── */
#navbar-loggedin {
  position: fixed !important;
  top: 18px !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) !important;
  width: auto !important;
  max-width: calc(100% - 32px) !important;
  height: 56px !important;
  z-index: 200 !important;
  align-items: center !important;
  gap: 18px !important;
  padding: 6px 6px 6px 18px !important;
  background: rgba(255,255,255,0.55) !important;
  -webkit-backdrop-filter: blur(28px) saturate(180%) !important;
  backdrop-filter: blur(28px) saturate(180%) !important;
  border: 1px solid rgba(255,255,255,0.7) !important;
  border-radius: 999px !important;
  box-shadow: 0 10px 30px -10px rgba(20,40,90,0.22), inset 0 1px 0 rgba(255,255,255,0.85) !important;
}
#navbar-loggedin .navbar-brand {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 13px; font-weight: 700; color: var(--text-h);
  letter-spacing: -0.01em; text-decoration: none;
}
#navbar-loggedin .navbar-logo {
  width: 24px; height: 24px; border-radius: 7px;
  object-fit: cover;
}
#navbar-loggedin .navbar-wordmark { color: var(--text-h); }
#navbar-loggedin .navbar-center {
  display: inline-flex; align-items: center; gap: 4px;
  padding-left: 10px; margin-left: 4px;
  border-left: 1px solid rgba(60,60,67,0.16);
}
#navbar-loggedin .nav-link {
  font-size: 13px; font-weight: 500;
  color: var(--text-sub);
  padding: 7px 12px;
  border-radius: 999px;
  text-decoration: none;
  transition: color 0.15s var(--ease-out), background 0.15s var(--ease-out);
}
#navbar-loggedin .nav-link:hover { color: var(--text-h); background: rgba(255,255,255,0.55); }
#navbar-loggedin .nav-link.active {
  color: var(--accent);
  background: rgba(10,132,255,0.10);
}
#navbar-loggedin .navbar-right { display: inline-flex; align-items: center; }
#navbar-loggedin #back-to-profile-btn {
  position: static !important;
  left: auto !important;
}
#navbar-loggedin #back-to-profile-btn button {
  background: rgba(255,255,255,0.5) !important;
  border: 1px solid rgba(255,255,255,0.7) !important;
  border-radius: 999px !important;
  padding: 6px 14px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--text-sub) !important;
  transition: background 0.15s, color 0.15s !important;
}
#navbar-loggedin #back-to-profile-btn button:hover {
  background: rgba(255,255,255,0.85) !important;
  color: var(--text-h) !important;
}

/* ──────────────────────────────────────────────────────────────
   ACCOUNT FLY-OUT CARD
   ────────────────────────────────────────────────────────────── */
.bd-account-menu { position: relative; }
.bd-account-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 4px 14px 4px 4px;
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: 999px;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  transition: background 0.18s var(--ease-out), border-color 0.18s var(--ease-out), box-shadow 0.18s var(--ease-out);
}
.bd-account-trigger:hover {
  background: rgba(255,255,255,0.85);
  border-color: rgba(10,132,255,0.32);
  box-shadow: 0 4px 14px -3px rgba(10,132,255,0.18);
}
.bd-acct-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0A84FF 0%, #5E5CE6 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  object-fit: cover;
  flex-shrink: 0;
  overflow: hidden;
}
.bd-acct-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bd-acct-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-h);
  letter-spacing: -0.01em;
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bd-acct-chev {
  color: var(--text-dim);
  transition: transform 0.25s var(--ease-out);
}
.bd-account-menu.open .bd-acct-chev { transform: rotate(180deg); }

.bd-account-card {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  width: 300px;
  padding: 10px;
  background: rgba(255,255,255,0.65);
  -webkit-backdrop-filter: blur(32px) saturate(190%);
  backdrop-filter: blur(32px) saturate(190%);
  border: 1px solid var(--glass-stroke);
  border-radius: var(--r-lg);
  box-shadow: var(--glass-shadow);
  opacity: 0;
  transform: translateY(-4px) scale(0.98);
  pointer-events: none;
  transition: opacity 0.2s var(--ease-out), transform 0.28s var(--spring);
  z-index: 300;
  overflow: hidden;
  isolation: isolate;
}
.bd-account-card::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.5), transparent 70%);
  mix-blend-mode: screen;
}
.bd-account-card > * { position: relative; z-index: 1; }
.bd-account-menu.open .bd-account-card {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.bd-acct-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 12px;
  border-bottom: 1px solid rgba(60,60,67,0.10);
  margin-bottom: 6px;
}
.bd-acct-card-avatar {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: linear-gradient(135deg, #0A84FF 0%, #5E5CE6 100%);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  object-fit: cover;
  flex-shrink: 0;
  overflow: hidden;
  box-shadow: 0 4px 14px -3px rgba(15,30,80,0.18);
}
.bd-acct-card-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bd-acct-card-id { min-width: 0; flex: 1; }
.bd-acct-discord-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-h);
  letter-spacing: -0.015em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bd-acct-reddit-handle {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  margin-top: 3px;
}
.bd-acct-rows { display: flex; flex-direction: column; gap: 1px; padding: 0 4px; }
.bd-acct-row {
  display: flex;
  align-items: center;
  gap: 12px;
  height: 38px;
  padding: 0 10px;
  border-radius: 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
  background: transparent;
  border: none;
  cursor: pointer;
  width: 100%;
  text-align: left;
  transition: background 0.15s var(--ease-out), color 0.15s var(--ease-out);
}
.bd-acct-row:hover { background: rgba(10,132,255,0.10); color: var(--text-h); }
.bd-acct-row.active { background: rgba(10,132,255,0.12); color: var(--accent); }
.bd-acct-row svg { width: 16px; height: 16px; flex-shrink: 0; opacity: 0.75; }
.bd-acct-row.active svg { opacity: 1; }
.bd-acct-divider { height: 1px; background: rgba(60,60,67,0.10); margin: 6px 8px; }
.bd-acct-row-danger { color: var(--error); }
.bd-acct-row-danger:hover { background: rgba(255,59,48,0.10); color: var(--error); }
.bd-acct-row-danger svg { opacity: 0.85; }

/* ──────────────────────────────────────────────────────────────
   LANDING SCREEN — uses the global backdrop now
   ────────────────────────────────────────────────────────────── */
body:has(#screen-landing.active) #navbar-loggedout { display: none !important; }

#screen-landing .bd-corner-actions {
  position: absolute;
  top: 28px; right: 28px; z-index: 5;
  display: inline-flex; align-items: center; gap: 10px;
}
#screen-landing .bd-discord-btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 42px; padding: 0 18px;
  border-radius: 11px;
  background: var(--accent-grad);
  color: #fff;
  font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em;
  border: none; font-family: 'Inter', sans-serif;
  cursor: pointer;
  box-shadow: 0 6px 14px -4px rgba(10,132,255,0.5);
  transition: transform 0.18s var(--spring), filter 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}
#screen-landing .bd-discord-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow: 0 10px 22px -6px rgba(10,132,255,0.55);
}
#screen-landing .bd-discord-btn:active { transform: translateY(0); filter: brightness(0.97); }
#screen-landing .bd-discord-btn svg { width: 16px; height: 16px; flex-shrink: 0; }

/* Pill / eyebrow */
#screen-landing .badge-pill {
  display: inline-flex; align-items: center; gap: 6px;
  height: 24px; padding: 0 11px;
  border-radius: 999px;
  background: rgba(10,132,255,0.10);
  border: 1px solid rgba(10,132,255,0.20);
  color: var(--accent);
  font-size: 11px; font-weight: 700;
  text-transform: none; letter-spacing: 0.04em;
  margin-bottom: 24px;
  text-decoration: none;
  transition: transform 0.25s var(--spring), filter 0.25s var(--ease-out);
}
#screen-landing .badge-pill::before {
  content: ""; width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 8px rgba(10,132,255,0.85);
  flex-shrink: 0;
}
#screen-landing .badge-pill:hover { transform: translateY(-1px); filter: brightness(1.05); }

#screen-landing .landing-title {
  font-size: clamp(36px, 4.6vw, 44px);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.08;
  color: var(--text-h);
  margin-bottom: 14px;
}
#screen-landing .landing-subtitle {
  font-size: 15px; line-height: 1.55;
  color: var(--text-sub);
  font-weight: 400;
  margin-bottom: 36px;
  max-width: 440px;
}

/* Glass form card on landing — same training recipe */
#screen-landing .search-card {
  position: relative;
  max-width: 480px;
  padding: 36px;
  border-radius: var(--r-xl);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(32px) saturate(190%);
  backdrop-filter: blur(32px) saturate(190%);
  border: 1px solid var(--glass-stroke);
  box-shadow: var(--glass-shadow);
  overflow: hidden;
  isolation: isolate;
}
#screen-landing .search-card::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.55) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.5), transparent 70%);
  mix-blend-mode: screen;
}
#screen-landing .search-card > * { position: relative; z-index: 1; }

#screen-landing .field-label {
  font-size: 13px; font-weight: 600;
  color: var(--text-sub);
}
#screen-landing .field-input,
#screen-landing .date-input-wrap input[type="date"] {
  height: 44px;
  border-radius: 12px;
  background: rgba(255,255,255,0.7);
  border: 1px solid rgba(60,60,67,0.14);
  color: var(--text-h);
  font-size: 15px;
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out), background 0.2s var(--ease-out);
}
#screen-landing .field-input::placeholder { color: var(--text-dim); }
#screen-landing .field-input:focus,
#screen-landing .date-input-wrap input[type="date"]:focus {
  border-color: var(--accent);
  background: rgba(255,255,255,0.92);
  box-shadow: 0 0 0 4px rgba(10,132,255,0.14);
}
#screen-landing .date-divider { font-size: 14px; color: var(--text-dim); }
#screen-landing .field-error { color: var(--error); font-size: 12px; font-weight: 500; }

#screen-landing .search-btn {
  height: 42px;
  border-radius: 11px;
  background: var(--accent-grad);
  color: #fff;
  font-size: 14px; font-weight: 600;
  letter-spacing: -0.005em;
  border: none;
  box-shadow: 0 6px 14px -4px rgba(10,132,255,0.5);
  margin-top: 12px;
  transition: transform 0.18s var(--spring), filter 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
  animation: none;
}
#screen-landing .search-btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow: 0 10px 22px -6px rgba(10,132,255,0.55);
}
#screen-landing .search-btn:active { transform: translateY(0); filter: brightness(0.97); }

#screen-landing .stats-bar {
  background: rgba(255,255,255,0.55);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255,255,255,0.7);
  border-bottom: 1px solid rgba(60,60,67,0.06);
  padding: 18px 24px;
  border-radius: var(--r);
}
#screen-landing .stats-bar-item {
  font-size: 11px; font-weight: 700;
  color: var(--text-sub);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-variant-numeric: tabular-nums;
}
#screen-landing .stats-bar-divider { background: rgba(60,60,67,0.10); }
#screen-landing .landing-footer {
  font-size: 11px; font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 24px 20px;
}

/* ──────────────────────────────────────────────────────────────
   LOGGED-IN SCREEN LAYOUT — push content below capsule navbar
   ────────────────────────────────────────────────────────────── */
#screen-profile .page-body,
#screen-tasks .page-body,
#screen-leaderboard .page-body,
#screen-badges .page-body {
  padding-top: 100px !important;
  position: relative;
  z-index: 1;
}

/* Glass treatment for every card */
#screen-profile .user-header,
#screen-profile .stat-card,
#screen-profile .tab-section,
#screen-tasks .tasks-grid,
#screen-leaderboard .leaderboard-table,
#screen-leaderboard .podium-card,
#screen-badges .badges-grid,
#screen-results .user-header-r,
#screen-results .stat-card-r,
#screen-results .tab-bar-r,
#screen-results .tab-panel-r {
  background: var(--glass-bg) !important;
  -webkit-backdrop-filter: blur(32px) saturate(190%) !important;
  backdrop-filter: blur(32px) saturate(190%) !important;
  border: 1px solid var(--glass-stroke) !important;
  box-shadow: var(--glass-shadow) !important;
  border-radius: var(--r-lg) !important;
}
#screen-profile .stat-card,
#screen-leaderboard .podium-card,
#screen-results .stat-card-r {
  border-radius: var(--r) !important;
}
#screen-profile .stat-number,
#screen-results .stat-number-r,
#screen-leaderboard .podium-xp { color: var(--accent); letter-spacing: -0.025em; }
#screen-profile .stat-label,
#screen-results .stat-label-r,
#screen-leaderboard .podium-xp-label { color: var(--text-sub); font-weight: 600; }

/* Page titles */
#screen-tasks .page-title,
#screen-leaderboard .page-title,
#screen-badges .page-title,
#screen-profile .user-name {
  color: var(--text-h);
  letter-spacing: -0.025em;
}
#screen-tasks .page-subtitle,
#screen-leaderboard .page-subtitle,
#screen-badges .page-subtitle { color: var(--text-sub); }

/* Filter pills + tab buttons match training */
#screen-tasks .filter-pill,
#screen-badges .filter-pill {
  background: rgba(255,255,255,0.55);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.7);
  color: var(--text-sub);
  border-radius: 999px;
  font-weight: 600;
  transition: background 0.15s var(--ease-out), border-color 0.15s var(--ease-out), color 0.15s var(--ease-out), transform 0.15s var(--ease-out);
}
#screen-tasks .filter-pill:hover,
#screen-badges .filter-pill:hover {
  border-color: rgba(10,132,255,0.32);
  color: var(--text-h);
  transform: translateY(-1px);
}
#screen-tasks .filter-pill.active,
#screen-badges .filter-pill.active {
  background: var(--accent-grad);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 4px 12px -3px rgba(10,132,255,0.45);
}

#screen-profile .tab-btn,
#screen-results .tab-btn-r {
  color: var(--text-sub);
  font-weight: 600;
  transition: color 0.15s var(--ease-out), border-color 0.15s var(--ease-out);
}
#screen-profile .tab-btn:hover,
#screen-results .tab-btn-r:hover { color: var(--text-h); }
#screen-profile .tab-btn.active,
#screen-results .tab-btn-r.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
#screen-profile .tab-bar { border-bottom-color: rgba(60,60,67,0.10); }

#screen-leaderboard .table-header { background: rgba(255,255,255,0.30); border-bottom-color: rgba(60,60,67,0.10); }
#screen-leaderboard .table-header-cell { color: var(--text-dim); }

/* ──────────────────────────────────────────────────────────────
   DASHBOARD HERO — Reddit handle prominent, Discord identity tag
   ────────────────────────────────────────────────────────────── */
#bd-reddit-handle {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-h);
  letter-spacing: -0.025em;
}
#bd-reddit-handle .bd-u-prefix {
  color: var(--accent);
  font-weight: 700;
  opacity: 0.85;
  margin-right: 1px;
}
#bd-reddit-handle.no-reddit .bd-u-prefix { display: none; }
#bd-reddit-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-sub);
}
#bd-reddit-meta .bd-meta-dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--text-dim);
  opacity: 0.6;
}
#bd-reddit-meta .bd-discord-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  background: rgba(88,101,242,0.10);
  border: 1px solid rgba(88,101,242,0.22);
  border-radius: 999px;
  color: #5865F2;
  font-weight: 600;
  font-size: 11px;
}
#bd-reddit-meta .bd-discord-tag .bd-discord-tag-img {
  width: 14px; height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  background: linear-gradient(135deg, #0A84FF, #5E5CE6);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700;
  overflow: hidden;
}
#bd-reddit-meta .bd-discord-tag .bd-discord-tag-img img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

/* ──────────────────────────────────────────────────────────────
   ADMIN PANEL — same liquid-glass system applied to sidebar shell
   ────────────────────────────────────────────────────────────── */
body.admin-page {
  display: block !important;
  background-attachment: fixed !important;
  min-height: 100vh;
}
body.admin-page .sidebar {
  position: fixed !important;
  top: 18px !important;
  left: 18px !important;
  bottom: 18px !important;
  width: 240px !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0 !important;
  background: rgba(255,255,255,0.55) !important;
  -webkit-backdrop-filter: blur(28px) saturate(180%) !important;
  backdrop-filter: blur(28px) saturate(180%) !important;
  border: 1px solid rgba(255,255,255,0.7) !important;
  border-radius: var(--r-xl) !important;
  box-shadow: 0 14px 36px -10px rgba(15,30,80,0.22), inset 0 1px 0 rgba(255,255,255,0.85) !important;
  overflow: hidden !important;
  isolation: isolate !important;
}
body.admin-page .sidebar::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.45), transparent 70%);
  mix-blend-mode: screen;
}
body.admin-page .sidebar > * { position: relative; z-index: 1; }
body.admin-page .sidebar-brand { padding: 22px 22px 14px !important; }
body.admin-page .sidebar-logo { border-radius: 8px; }
body.admin-page .sidebar-admin-badge { color: var(--text-dim); margin: 4px 18px 10px; }
body.admin-page .sidebar-nav { padding: 0 12px !important; gap: 3px !important; }
body.admin-page .sidebar-link {
  color: var(--text-sub) !important;
  border-radius: 10px !important;
  padding: 10px 12px !important;
  transition: background 0.15s var(--ease-out), color 0.15s var(--ease-out);
}
body.admin-page .sidebar-link:hover {
  background: rgba(10,132,255,0.08) !important;
  color: var(--text-h) !important;
}
body.admin-page .sidebar-link.active {
  background: rgba(10,132,255,0.12) !important;
  color: var(--accent) !important;
  font-weight: 600 !important;
}
body.admin-page .sidebar-link.active .sidebar-dot { background: var(--accent) !important; }
body.admin-page .sidebar-badge {
  background: rgba(255,159,10,0.14) !important;
  color: var(--warning) !important;
}
body.admin-page .sidebar-footer {
  border-top: 1px solid rgba(60,60,67,0.10) !important;
  padding: 14px 12px !important;
}
body.admin-page .sidebar-user {
  border-radius: 10px !important;
  background: rgba(255,255,255,0.45);
  border: 1px solid rgba(255,255,255,0.6);
}
body.admin-page .sidebar-username { color: var(--text-h) !important; }
body.admin-page .sidebar-role { color: var(--text-sub) !important; }
body.admin-page .sidebar-avatar {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #0A84FF, #5E5CE6) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}
body.admin-page .sidebar-avatar img {
  width: 100% !important;
  height: 100% !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  display: block !important;
}

/* Admin main canvas — fills viewport right of sidebar; content max-width centered */
body.admin-page .admin-screen {
  position: absolute !important;
  top: 0 !important;
  left: 276px !important;
  right: 0 !important;
  bottom: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  z-index: 1 !important;
  box-sizing: border-box !important;
  overflow-y: auto !important;
  background: transparent !important;
}
body.admin-page .admin-screen.active {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}
body.admin-page .admin-screen .topbar,
body.admin-page .admin-screen .page-body {
  width: 100% !important;
  max-width: 1100px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  box-sizing: border-box !important;
}
body.admin-page .admin-screen .page-body {
  padding: 8px 24px 48px !important;
}

/* Topbar = glass capsule */
body.admin-page .topbar {
  position: sticky !important;
  top: 18px !important;
  z-index: 50 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px 22px !important;
  margin: 24px 24px 12px !important;
  width: calc(100% - 48px) !important;
  background: rgba(255,255,255,0.55) !important;
  -webkit-backdrop-filter: blur(28px) saturate(180%) !important;
  backdrop-filter: blur(28px) saturate(180%) !important;
  border: 1px solid rgba(255,255,255,0.7) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: 0 10px 30px -10px rgba(20,40,90,0.22), inset 0 1px 0 rgba(255,255,255,0.85) !important;
}
body.admin-page .topbar-title {
  color: var(--text-h) !important;
  font-size: 16px !important;
  letter-spacing: -0.02em !important;
}
body.admin-page .topbar-sub { color: var(--text-sub) !important; font-weight: 500 !important; }
body.admin-page .topbar-btn {
  height: 38px !important;
  padding: 0 16px !important;
  border-radius: 10px !important;
  background: rgba(255,255,255,0.7) !important;
  border: 1px solid rgba(60,60,67,0.10) !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text-sub) !important;
  cursor: pointer !important;
  transition: background 0.15s var(--ease-out), color 0.15s var(--ease-out), border-color 0.15s var(--ease-out), transform 0.15s var(--ease-out) !important;
}
body.admin-page .topbar-btn:hover {
  background: #fff !important;
  border-color: rgba(10,132,255,0.32) !important;
  color: var(--text-h) !important;
}
body.admin-page .topbar-btn.primary {
  background: var(--accent-grad) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 4px 12px -3px rgba(10,132,255,0.45) !important;
}
body.admin-page .topbar-btn.primary:hover {
  filter: brightness(1.05) !important;
  transform: translateY(-1px) !important;
}

/* Stat + section cards = glass */
body.admin-page .stat-card,
body.admin-page .section-card,
body.admin-page .empty-state,
body.admin-page .data-table {
  background: var(--glass-bg) !important;
  -webkit-backdrop-filter: blur(32px) saturate(190%) !important;
  backdrop-filter: blur(32px) saturate(190%) !important;
  border: 1px solid var(--glass-stroke) !important;
  box-shadow: var(--glass-shadow) !important;
  border-radius: var(--r-lg) !important;
  position: relative;
  overflow: hidden;
}
body.admin-page .stat-card::before,
body.admin-page .section-card::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.40) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.40), transparent 70%);
  mix-blend-mode: screen;
}
body.admin-page .stat-card > *,
body.admin-page .section-card > * { position: relative; z-index: 1; }
body.admin-page .stat-number { color: var(--accent) !important; letter-spacing: -0.025em !important; }
body.admin-page .stat-label { color: var(--text-sub) !important; font-weight: 600 !important; }
body.admin-page .stat-change { color: var(--text-dim) !important; }
body.admin-page .section-title { color: var(--text-h) !important; letter-spacing: -0.015em !important; }
body.admin-page .section-link { color: var(--accent) !important; font-weight: 600 !important; }
body.admin-page .section-header { border-bottom-color: rgba(60,60,67,0.10) !important; }

body.admin-page .empty-state { color: var(--text-sub) !important; }
body.admin-page .empty-state-title { color: var(--text-h) !important; }

/* Tables, forms, common admin chrome */
body.admin-page table { color: var(--text) !important; }
body.admin-page th { color: var(--text-dim) !important; background: transparent !important; }
body.admin-page tr { border-color: rgba(60,60,67,0.08) !important; }
body.admin-page input[type="text"],
body.admin-page input[type="number"],
body.admin-page input[type="email"],
body.admin-page input[type="password"],
body.admin-page input[type="date"],
body.admin-page select,
body.admin-page textarea {
  background: rgba(255,255,255,0.7) !important;
  border: 1px solid rgba(60,60,67,0.14) !important;
  color: var(--text-h) !important;
  border-radius: 10px !important;
  font-family: 'Inter', sans-serif !important;
  transition: border-color 0.18s var(--ease-out), box-shadow 0.18s var(--ease-out), background 0.18s var(--ease-out) !important;
}
body.admin-page input:focus,
body.admin-page select:focus,
body.admin-page textarea:focus {
  border-color: var(--accent) !important;
  background: rgba(255,255,255,0.92) !important;
  box-shadow: 0 0 0 4px rgba(10,132,255,0.14) !important;
  outline: none !important;
}

/* ──────────────────────────────────────────────────────────────
   ADMIN LOGIN PAGE — same blob backdrop + glass card
   ────────────────────────────────────────────────────────────── */
body.admin-login-page { display: flex !important; align-items: center !important; justify-content: center !important; min-height: 100vh !important; }
body.admin-login-page .login-card,
body.admin-login-page .auth-card,
body.admin-login-page form,
body.admin-login-page .card {
  background: var(--glass-bg) !important;
  -webkit-backdrop-filter: blur(32px) saturate(190%) !important;
  backdrop-filter: blur(32px) saturate(190%) !important;
  border: 1px solid var(--glass-stroke) !important;
  box-shadow: var(--glass-shadow) !important;
  border-radius: var(--r-xl) !important;
}

/* ══════════════════════════════════════════════════════════════
   DARK THEME — black canvas with soft white glares
   Toggle: html[data-theme="dark"]. Crossfade via body::before
   (light) and body::after (dark) opacity transition.
   ══════════════════════════════════════════════════════════════ */

/* Light blob layer fades out in dark mode */
body::before { transition: opacity 0.7s var(--ease-out); }

/* Dark blob layer (white glares on near-black). Hidden by default,
   fades in when html[data-theme="dark"] is set. */
body::after {
  content: '';
  position: fixed; inset: -10vh -10vw;
  pointer-events: none; z-index: 0;
  background:
    radial-gradient(280px 280px at 18% 28%, rgba(255,255,255,0.10), transparent 60%),
    radial-gradient(360px 360px at 82% 22%, rgba(255,255,255,0.08), transparent 65%),
    radial-gradient(420px 420px at 75% 80%, rgba(255,255,255,0.10), transparent 60%),
    radial-gradient(300px 300px at 18% 82%, rgba(255,255,255,0.07), transparent 60%),
    #070709;
  filter: blur(28px);
  animation: bdDrift 28s ease-in-out infinite alternate;
  opacity: 0;
  transition: opacity 0.7s var(--ease-out);
}
html[data-theme="dark"] body::before { opacity: 0; }
html[data-theme="dark"] body::after  { opacity: 1; }

/* Token overrides — html + attr selector beats inline :root specificity */
html[data-theme="dark"] {
  --text-h:        #F2F2F4;
  --text:          rgba(235,235,240,0.86);
  --text-sub:      rgba(235,235,240,0.62);
  --text-dim:      rgba(235,235,240,0.40);
  --glass-bg:      rgba(20,20,26,0.55);
  --glass-bg-2:    rgba(28,28,34,0.72);
  --glass-stroke:  rgba(255,255,255,0.12);
  --glass-stroke-in: rgba(255,255,255,0.08);
  --glass-shadow:  0 30px 80px -20px rgba(0,0,0,0.7), 0 8px 24px -8px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.08);

  /* index.html / admin inline tokens — kept low-contrast for soft cards */
  --white:         #0F0F13;
  --black:         #F2F2F4;
  --gray-700:      #C8CDD4;
  --gray-600:      #A0A6B0;
  --gray-400:      #6B7280;
  --gray-300:      rgba(255,255,255,0.10);
  --gray-200:      rgba(255,255,255,0.08);
  --gray-100:      #0C0C10;
  --bg:            #14171D;
  --bg-subtle:     #1F232C;
  --border:        rgba(255,255,255,0.12);
  --border-strong: rgba(255,255,255,0.18);
  --text-primary:  #F2F2F4;
  --text-secondary: rgba(235,235,240,0.62);
  --text-tertiary:  rgba(235,235,240,0.40);
  --blue-light:    rgba(10,132,255,0.20);
  --blue-xlight:   rgba(10,132,255,0.12);
  --blue-subtle:   rgba(10,132,255,0.16);
  --success-light: rgba(48,209,88,0.16);
  --warning-light: rgba(255,159,10,0.16);
  --error-light:   rgba(255,59,48,0.16);
}
html[data-theme="dark"] body { background-color: #070709 !important; }

/* Smooth color transitions on key surfaces */
body, .bd-glass,
#navbar-loggedin, #navbar-loggedout,
.bd-account-trigger, .bd-account-card, .bd-acct-row,
.search-card, .field-input, .nav-link,
.profile-trigger, .profile-menu, .profile-menu-item,
.sidebar, .admin-screen, .topbar, .page-body, .stat-card, .data-card {
  transition: background-color 0.5s var(--ease-out),
              color 0.5s var(--ease-out),
              border-color 0.5s var(--ease-out),
              box-shadow 0.5s var(--ease-out);
}

/* ── FLOATING CAPSULE NAVBAR ── */
html[data-theme="dark"] #navbar-loggedin {
  background: rgba(20,20,26,0.55) !important;
  border-color: rgba(255,255,255,0.12) !important;
  box-shadow: 0 10px 30px -10px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.08) !important;
}
html[data-theme="dark"] #navbar-loggedin .navbar-center { border-left-color: rgba(255,255,255,0.10); }
html[data-theme="dark"] #navbar-loggedin .nav-link:hover { background: rgba(255,255,255,0.08); }
html[data-theme="dark"] #navbar-loggedin .nav-link.active { background: rgba(10,132,255,0.20); }
html[data-theme="dark"] #navbar-loggedin #back-to-profile-btn button {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.14) !important;
}
html[data-theme="dark"] #navbar-loggedin #back-to-profile-btn button:hover {
  background: rgba(255,255,255,0.12) !important;
}

/* ── ACCOUNT TRIGGER + DROPDOWN ── */
html[data-theme="dark"] .bd-account-trigger {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.12);
}
html[data-theme="dark"] .bd-account-trigger:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(10,132,255,0.40);
}
html[data-theme="dark"] .bd-account-card {
  background: rgba(20,20,28,0.85);
  border-color: rgba(255,255,255,0.12);
}
html[data-theme="dark"] .bd-account-card::before { display: none; }
html[data-theme="dark"] .bd-acct-header { border-bottom-color: rgba(255,255,255,0.10); }
html[data-theme="dark"] .bd-acct-divider { background: rgba(255,255,255,0.08); }
html[data-theme="dark"] .bd-acct-row { color: var(--text); }
html[data-theme="dark"] .bd-acct-row:hover { background: rgba(255,255,255,0.08); color: var(--text-h); }
html[data-theme="dark"] .bd-acct-row.active { background: rgba(10,132,255,0.20); color: var(--accent); }
html[data-theme="dark"] .bd-acct-row.bd-acct-row-danger:hover { background: rgba(255,59,48,0.18); }

/* ── GLASS PANELS ── */
html[data-theme="dark"] .bd-glass {
  background: var(--glass-bg);
  border-color: var(--glass-stroke);
}
html[data-theme="dark"] .bd-glass::before {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0) 38%),
    radial-gradient(120% 60% at 50% 0%, rgba(255,255,255,0.10), transparent 70%);
}
html[data-theme="dark"] .bd-glass::after {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06), inset 0 -1px 0 rgba(255,255,255,0.05);
}

/* ── LANDING SEARCH CARD ── */
html[data-theme="dark"] .search-card {
  background: rgba(22,22,28,0.78) !important;
  border-color: rgba(255,255,255,0.10) !important;
  box-shadow: 0 14px 40px -14px rgba(0,0,0,0.7) !important;
}
html[data-theme="dark"] .field-input {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.14) !important;
  color: var(--text-h) !important;
}
html[data-theme="dark"] .field-input::placeholder { color: rgba(235,235,240,0.36) !important; }
html[data-theme="dark"] .field-input:focus { border-color: rgba(10,132,255,0.55) !important; }
html[data-theme="dark"] .field-label { color: var(--text-sub) !important; }
html[data-theme="dark"] .badge-pill {
  background: rgba(10,132,255,0.20) !important;
  color: #5BB1FF !important;
}
html[data-theme="dark"] .stats-bar-item,
html[data-theme="dark"] .stats-bar-divider { color: var(--text-sub) !important; }
html[data-theme="dark"] .landing-footer { color: var(--text-dim) !important; }
html[data-theme="dark"] .landing-title { color: var(--text-h) !important; }
html[data-theme="dark"] .landing-subtitle { color: var(--text-sub) !important; }
html[data-theme="dark"] .date-input-wrap {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.14) !important;
}
html[data-theme="dark"] .date-divider { color: var(--text-sub) !important; }
html[data-theme="dark"] .date-input-wrap input { color: var(--text-h) !important; }

/* ── LOADING SCREEN — invert ── */
html[data-theme="dark"] #screen-loading { background: #070709 !important; }
html[data-theme="dark"] #screen-loading .logo-name { filter: invert(1) brightness(1.1); }

/* ── ADMIN ── */
html[data-theme="dark"] body.admin-page .sidebar {
  background: rgba(20,20,26,0.65) !important;
  border-color: rgba(255,255,255,0.12) !important;
}
html[data-theme="dark"] body.admin-page,
html[data-theme="dark"] body.admin-page .admin-screen {
  color: var(--text-h);
}

/* ── DASHBOARD / RESULT CARDS — dark mode ── */
html[data-theme="dark"] .card,
html[data-theme="dark"] .card-r,
html[data-theme="dark"] .task-card,
html[data-theme="dark"] .badge-card,
html[data-theme="dark"] .stat-card-r,
html[data-theme="dark"] .user-header-r,
html[data-theme="dark"] .tab-section,
html[data-theme="dark"] .tab-bar-r,
html[data-theme="dark"] .leaderboard-table,
html[data-theme="dark"] .tab-panel-r.active,
html[data-theme="dark"] .blur-user-header,
html[data-theme="dark"] .blur-stat,
html[data-theme="dark"] .blur-tabs,
html[data-theme="dark"] .blur-navbar,
html[data-theme="dark"] .form-input,
html[data-theme="dark"] .form-textarea,
html[data-theme="dark"] .drawer,
html[data-theme="dark"] .post-item-i,
html[data-theme="dark"] .comment-item-i {
  background: rgba(255,255,255,0.035) !important;
  border-color: rgba(255,255,255,0.08) !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.5), 0 4px 12px rgba(0,0,0,0.4) !important;
  color: var(--text-h);
}
html[data-theme="dark"] .card:hover,
html[data-theme="dark"] .task-card:hover {
  background: rgba(255,255,255,0.055) !important;
  box-shadow: 0 8px 28px rgba(10,132,255,0.18), 0 2px 8px rgba(0,0,0,0.55) !important;
}
html[data-theme="dark"] .card-title,
html[data-theme="dark"] .task-title,
html[data-theme="dark"] .badge-title,
html[data-theme="dark"] .tab-empty-title { color: var(--text-h) !important; }
html[data-theme="dark"] .card-body { color: rgba(235,235,240,0.78) !important; }
html[data-theme="dark"] .card-meta,
html[data-theme="dark"] .cards-header,
html[data-theme="dark"] .cards-summary,
html[data-theme="dark"] .cards-header-r,
html[data-theme="dark"] .cards-summary-r,
html[data-theme="dark"] .task-desc,
html[data-theme="dark"] .task-deadline,
html[data-theme="dark"] .tab-empty-sub,
html[data-theme="dark"] .section-divider { color: rgba(235,235,240,0.50) !important; }
html[data-theme="dark"] .card-reply {
  background: rgba(255,255,255,0.05) !important;
  color: rgba(235,235,240,0.65) !important;
}
html[data-theme="dark"] .filter-pill {
  background: rgba(255,255,255,0.04) !important;
  border-color: rgba(255,255,255,0.10) !important;
  color: rgba(235,235,240,0.70) !important;
}
html[data-theme="dark"] .filter-pill.active {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
}

/* Theme-toggle pill switch (used inside dropdown row) */
.bd-theme-switch {
  margin-left: auto;
  position: relative;
  width: 34px; height: 20px;
  border-radius: 999px;
  background: rgba(60,60,67,0.22);
  flex-shrink: 0;
  transition: background 0.3s var(--ease-out);
}
.bd-theme-switch::after {
  content: '';
  position: absolute; top: 2px; left: 2px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.18);
  transition: transform 0.3s var(--spring), background 0.3s var(--ease-out);
}
html[data-theme="dark"] .bd-theme-switch { background: rgba(10,132,255,0.55); }
html[data-theme="dark"] .bd-theme-switch::after { transform: translateX(14px); background: #F2F2F4; }
