/* server/public/tracker.css */

/* ── Theme variables ──────────────────────────────────────────────────── */
:root,
[data-theme="dark-purple"] {
  --bg-base:    #0d0f1a;
  --bg-card:    #161929;
  --bg-nav:     #0a0c14;
  --bg-input:   #1e2543;
  --accent:     #6366f1;
  --accent-h:   #818cf8;
  --text-1:     #e2e8f0;
  --text-2:     #94a3b8;
  --border:     #1e2543;
  --dot-purple: #a855f7;
  --dot-green:  #22c55e;
  --dot-amber:  #f59e0b;
  --dot-blue:   #3b82f6;
  --gold:       #f59e0b;
  --silver:     #94a3b8;
  --bronze:     #b45309;
  --highlight:  #1e2543;
}

[data-theme="dark-amber"] {
  --bg-base:    #0d0b08;
  --bg-card:    #1a1610;
  --bg-nav:     #090806;
  --bg-input:   #2a2015;
  --accent:     #d97706;
  --accent-h:   #f59e0b;
  --text-1:     #e2e8f0;
  --text-2:     #a8a29e;
  --border:     #2a2015;
  --dot-purple: #a855f7;
  --dot-green:  #22c55e;
  --dot-amber:  #f59e0b;
  --dot-blue:   #3b82f6;
  --gold:       #f59e0b;
  --silver:     #94a3b8;
  --bronze:     #b45309;
  --highlight:  #2a2015;
}

/* ── Reset / base ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg-base);
  color: var(--text-1);
  font-family: system-ui, -apple-system, sans-serif;
  font-size: 14px;
  line-height: 1.6;
  min-height: 100vh;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-h); text-decoration: underline; }

/* ── Nav ──────────────────────────────────────────────────────────────── */
.nav {
  background: var(--bg-nav);
  border-bottom: 1px solid var(--border);
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  height: 52px;
}
.nav-brand {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-1);
  letter-spacing: 0.03em;
  text-decoration: none;
}
.nav-brand:hover { color: var(--accent-h); text-decoration: none; }
.nav-links {
  display: flex;
  gap: 1rem;
  flex: 1;
}
.nav-links a {
  color: var(--text-2);
  font-size: 0.875rem;
}
.nav-links a:hover, .nav-links a.active { color: var(--text-1); text-decoration: none; }
.nav-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: auto;
}
.nav-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
}
.nav-username { color: var(--text-2); font-size: 0.875rem; }
.btn-theme {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-2);
  border-radius: 6px;
  padding: 0.25rem 0.625rem;
  cursor: pointer;
  font-size: 0.875rem;
}
.btn-theme:hover { color: var(--text-1); border-color: var(--text-2); }
.btn-logout {
  background: none;
  border: none;
  color: var(--text-2);
  font-size: 0.875rem;
  cursor: pointer;
  padding: 0;
}
.btn-logout:hover { color: var(--text-1); }

/* ── Page container ───────────────────────────────────────────────────── */
.page { max-width: 1100px; margin: 0 auto; padding: 2rem 1.5rem; }
.page-title { font-size: 1.375rem; font-weight: 600; margin-bottom: 1.5rem; color: var(--text-1); }

/* ── Stat bar ─────────────────────────────────────────────────────────── */
.stat-bar {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 1.5rem;
}
.stat-item {
  background: var(--bg-card);
  padding: 1rem 1.25rem;
  text-align: center;
}
.stat-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--accent);
  line-height: 1.2;
}
.stat-label { font-size: 0.75rem; color: var(--text-2); margin-top: 0.25rem; text-transform: uppercase; letter-spacing: 0.05em; }

/* ── Cards ────────────────────────────────────────────────────────────── */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}
.card-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}

/* ── Hero session card ────────────────────────────────────────────────── */
.hero-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.hero-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1rem; }
.hero-title { font-size: 1.125rem; font-weight: 600; }
.hero-meta { color: var(--text-2); font-size: 0.8125rem; margin-top: 0.25rem; }
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.hero-stat-value { font-size: 1.25rem; font-weight: 700; color: var(--accent); }
.hero-stat-label { font-size: 0.75rem; color: var(--text-2); }

/* ── Two-column layout ────────────────────────────────────────────────── */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }

/* ── Tables ───────────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th {
  text-align: left;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.625rem 0.75rem;
  border-bottom: 1px solid var(--border);
}
td {
  padding: 0.75rem;
  border-bottom: 1px solid var(--border);
  color: var(--text-1);
  font-size: 0.875rem;
}
tr:last-child td { border-bottom: none; }
tr:hover td { background: var(--highlight); }
.row-me td { background: color-mix(in srgb, var(--accent) 8%, var(--bg-card)); }

/* ── Leaderboard ──────────────────────────────────────────────────────── */
.rank-num { font-weight: 700; font-size: 1rem; }
.rank-gold   { color: var(--gold); }
.rank-silver { color: var(--silver); }
.rank-bronze { color: var(--bronze); }
.player-cell { display: flex; align-items: center; gap: 0.5rem; }
.player-cell img { width: 24px; height: 24px; border-radius: 50%; }

/* ── Tab bar ──────────────────────────────────────────────────────────── */
.tabs { display: flex; gap: 0.5rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.tab {
  padding: 0.4rem 1rem;
  border-radius: 6px;
  font-size: 0.875rem;
  color: var(--text-2);
  background: var(--bg-card);
  border: 1px solid var(--border);
}
.tab:hover { color: var(--text-1); text-decoration: none; }
.tab.active { color: var(--text-1); background: var(--accent); border-color: var(--accent); }

/* ── Timeline ─────────────────────────────────────────────────────────── */
.timeline { display: flex; flex-direction: column; gap: 0; }
.timeline-row {
  display: grid;
  grid-template-columns: 120px 24px 1fr;
  align-items: start;
  gap: 0 0.75rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
}
.timeline-row:last-child { border-bottom: none; }
.t-time { font-size: 0.75rem; color: var(--text-2); padding-top: 0.125rem; text-align: right; }
.t-dot-col { display: flex; flex-direction: column; align-items: center; padding-top: 0.25rem; }
.t-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.t-dot.purple { background: var(--dot-purple); }
.t-dot.green  { background: var(--dot-green); }
.t-dot.amber  { background: var(--dot-amber); }
.t-dot.blue   { background: var(--dot-blue); }
.t-desc { font-size: 0.875rem; color: var(--text-1); }
.t-rel { font-size: 0.75rem; color: var(--text-2); }

/* ── Pagination ───────────────────────────────────────────────────────── */
.pagination { display: flex; gap: 0.5rem; justify-content: center; margin-top: 1.5rem; }
.pagination a, .pagination span {
  padding: 0.375rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 0.875rem;
  color: var(--text-2);
  background: var(--bg-card);
}
.pagination a:hover { color: var(--text-1); text-decoration: none; }
.pagination .current { color: var(--text-1); background: var(--accent); border-color: var(--accent); }

/* ── Profile header ───────────────────────────────────────────────────── */
.profile-header { display: flex; align-items: center; gap: 1.5rem; margin-bottom: 1.5rem; }
.profile-avatar { width: 72px; height: 72px; border-radius: 50%; }
.profile-name { font-size: 1.25rem; font-weight: 700; }
.profile-meta { color: var(--text-2); font-size: 0.875rem; }

/* ── Empty state ──────────────────────────────────────────────────────── */
.empty { text-align: center; color: var(--text-2); padding: 3rem 1rem; font-size: 0.9375rem; }

/* ── Event list (overview recent events) ─────────────────────────────── */
.event-list { display: flex; flex-direction: column; }
.event-row {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.8125rem;
}
.event-row:last-child { border-bottom: none; }
.event-type {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--text-2);
  min-width: 80px;
  flex-shrink: 0;
}
.event-desc { color: var(--text-1); flex: 1; }
.event-time { color: var(--text-2); flex-shrink: 0; }

/* ── Setup page ───────────────────────────────────────────────────────────── */
.page-subtitle {
  color: var(--text-2);
  margin: -0.25rem 0 1.5rem;
  font-size: 0.9rem;
}
.setup-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 1.25rem;
}
.setup-download-card { grid-column: 1 / -1; }
.btn-download {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--accent);
  color: #fff;
  padding: 0.6rem 1.25rem;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  margin: 0.75rem 0 1rem;
  transition: background 0.15s;
}
.btn-download:hover { background: var(--accent-h); color: #fff; text-decoration: none; }
.setup-desc { color: var(--text-2); font-size: 0.875rem; margin-bottom: 0.5rem; }
.setup-note { color: var(--text-2); font-size: 0.8rem; line-height: 1.5; }
.setup-note code { background: var(--bg-input); padding: 0.1em 0.35em; border-radius: 3px; font-size: 0.78rem; }

.setup-steps { list-style: none; display: flex; flex-direction: column; gap: 1rem; }
.setup-steps li { display: flex; gap: 0.9rem; align-items: flex-start; font-size: 0.875rem; }
.step-num {
  background: var(--accent);
  color: #fff;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}
.setup-steps strong { display: block; margin-bottom: 0.2rem; }
.setup-steps code { background: var(--bg-input); padding: 0.1em 0.35em; border-radius: 3px; font-size: 0.78rem; }

.setup-faq { display: flex; flex-direction: column; gap: 0.9rem; }
.setup-faq dt { font-weight: 600; font-size: 0.875rem; margin-bottom: 0.2rem; }
.setup-faq dd { color: var(--text-2); font-size: 0.8125rem; margin: 0; }
.setup-faq code { background: var(--bg-input); padding: 0.1em 0.35em; border-radius: 3px; font-size: 0.78rem; color: var(--text-1); }

.setup-tree {
  background: var(--bg-input);
  border-radius: 6px;
  padding: 0.75rem 1rem;
  font-size: 0.8rem;
  color: var(--text-2);
  font-family: monospace;
  line-height: 1.7;
  margin-top: 0.5rem;
}

.setup-token-hint {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  background: var(--bg-input);
  border-radius: 6px;
  padding: 0.75rem;
  font-size: 0.8125rem;
  color: var(--text-2);
  margin-top: 0.75rem;
}

/* ── Burger button (hidden on desktop) ────────────────────────────────── */
.nav-burger {
  display: none;
  background: none;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.35rem 0.5rem;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
  margin-left: auto;
  margin-right: 0.5rem;
}
.nav-burger span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--text-1);
  border-radius: 1px;
}

@media (max-width: 768px) {
  .stat-bar { grid-template-columns: repeat(3, 1fr); }
  .two-col { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .setup-grid { grid-template-columns: 1fr; }
  .setup-download-card { grid-column: 1; }

  .nav-burger { display: flex; }
  .nav { gap: 0.75rem; padding: 0 1rem; flex-wrap: wrap; }
  .nav-links {
    display: none;
    flex-direction: column;
    width: 100%;
    background: var(--bg-nav);
    border-top: 1px solid var(--border);
    padding: 0.5rem 0;
    gap: 0;
    order: 99;
  }
  .nav-links a {
    padding: 0.625rem 1rem;
    border-bottom: 1px solid var(--border);
    font-size: 0.95rem;
  }
  .nav-links a:last-child { border-bottom: none; }
  body.nav-open .nav-links { display: flex; }
  .nav-right { gap: 0.5rem; }
  .nav-username { display: none; }
}

/* ── Highlights ───────────────────────────────────────────────────────── */
.highlight-feed { display: flex; flex-direction: column; }
.highlight-row {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 0.875rem;
  padding: 0.875rem 0.25rem;
  border-bottom: 1px solid var(--border);
  align-items: center;
}
.highlight-row:last-child { border-bottom: none; }
.highlight-icon { font-size: 1.5rem; text-align: center; }
.highlight-title { font-weight: 600; font-size: 0.9375rem; color: var(--text-1); }
.highlight-desc { color: var(--text-2); font-size: 0.8125rem; margin-top: 0.125rem; }
.highlight-meta { color: var(--text-2); font-size: 0.75rem; white-space: nowrap; }
.highlight-row.severity-epic  { border-left: 3px solid #facc15; padding-left: 0.75rem; }
.highlight-row.severity-major { border-left: 3px solid var(--accent); padding-left: 0.75rem; }
.highlight-row.severity-minor { border-left: 3px solid var(--dot-blue); padding-left: 0.75rem; }
.highlight-row.severity-info  { border-left: 3px solid var(--text-2); padding-left: 0.75rem; opacity: 0.85; }

/* ── Highlight badges (small chip on session cards/rows) ───────────────── */
.badge-row { display: flex; flex-wrap: wrap; gap: 0.25rem; }
.badge {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 0.125rem 0.45rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 15%, var(--bg-card));
  color: var(--accent-h);
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.badge.epic  { background: color-mix(in srgb, #facc15 18%, var(--bg-card)); color: #facc15; border-color: color-mix(in srgb, #facc15 35%, transparent); }
.badge.major { /* default purple/amber accent */ }
.badge.minor { background: color-mix(in srgb, var(--dot-blue) 15%, var(--bg-card)); color: var(--dot-blue); border-color: color-mix(in srgb, var(--dot-blue) 30%, transparent); }
.badge.info  { background: var(--bg-input); color: var(--text-2); border-color: var(--border); }

