/* ────────────────────────────────────────────────────────────────────────
 * Pulse dashboard styles.
 * All colours go through Material design tokens so dark/light schemes work
 * automatically; the only literal colour is the leaderboard accent stripe.
 * ──────────────────────────────────────────────────────────────────────── */

/* Static markdown tables (index, by-cpu, by-gpu, by-distro): tighter,
 * tabular-nums for numeric columns. */
.md-typeset table:not([class]) {
  font-size: 0.85rem;
}
.md-typeset table:not([class]) td {
  padding: 0.4em 0.6em;
}

/* ────────────────────────────────────────────────────────────────────────
 * Leaderboard
 * ──────────────────────────────────────────────────────────────────────── */

#pulse-leaderboard .pulse-lb-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: center;
  margin: 0.5rem 0 0.85rem;
  padding: 0.55rem 0.65rem;
  background: var(--md-code-bg-color);
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.5rem;
}

#pulse-leaderboard .pulse-lb-label {
  margin-right: 0.35rem;
  font-size: 0.75rem;
  color: var(--md-default-fg-color--light);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

#pulse-leaderboard .pulse-lb-sort {
  padding: 0.25rem 0.55rem;
  font: inherit;
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 0.35rem;
  cursor: pointer;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
#pulse-leaderboard .pulse-lb-sort:hover {
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
}
#pulse-leaderboard .pulse-lb-sort.is-active {
  color: var(--md-primary-bg-color);
  background: var(--md-primary-fg-color);
  border-color: var(--md-primary-fg-color);
}

#pulse-leaderboard .pulse-lb-grid {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: 1fr;
}

#pulse-leaderboard .pulse-lb-card {
  position: relative;
  padding: 0.95rem 1.1rem 0.85rem;
  background: var(--md-default-bg-color);
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.65rem;
  overflow: hidden;
  transition: border-color 0.15s, transform 0.12s;
}
#pulse-leaderboard .pulse-lb-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--md-primary-fg-color);
  opacity: 0.85;
}
#pulse-leaderboard .pulse-lb-card.is-partial::before {
  background: var(--md-default-fg-color--lighter);
}
#pulse-leaderboard .pulse-lb-card:hover {
  border-color: var(--md-primary-fg-color--light, var(--md-primary-fg-color));
}

#pulse-leaderboard .pulse-lb-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.85rem;
  align-items: center;
}

#pulse-leaderboard .pulse-lb-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.1rem;
  height: 2.1rem;
  padding: 0 0.45rem;
  font-weight: 700;
  font-size: 0.95rem;
  font-variant-numeric: tabular-nums;
  color: var(--md-primary-fg-color);
  background: color-mix(in srgb, var(--md-primary-fg-color) 12%, transparent);
  border-radius: 999px;
}

#pulse-leaderboard .pulse-lb-host {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
#pulse-leaderboard .pulse-lb-host > a {
  font-weight: 600;
  font-size: 1.02rem;
  color: var(--md-default-fg-color);
  text-decoration: none;
}
#pulse-leaderboard .pulse-lb-host > a:hover {
  color: var(--md-primary-fg-color);
  text-decoration: underline;
}
#pulse-leaderboard .pulse-lb-sub {
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
#pulse-leaderboard .pulse-lb-gpu { font-style: italic; }

#pulse-leaderboard .pulse-lb-overall {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.2rem;
  min-width: 9.5rem;
}
#pulse-leaderboard .pulse-lb-overall-val {
  font-size: 1.6rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: var(--md-default-fg-color);
}
#pulse-leaderboard .pulse-lb-overall-label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--md-default-fg-color--light);
}
#pulse-leaderboard .pulse-lb-cov.is-partial {
  color: var(--md-warning-fg-color, #c97a00);
  font-weight: 600;
}
#pulse-leaderboard .pulse-lb-bar {
  width: 100%;
  height: 4px;
  background: var(--md-default-fg-color--lightest);
  border-radius: 2px;
  overflow: hidden;
}
#pulse-leaderboard .pulse-lb-bar > span {
  display: block;
  height: 100%;
  background: var(--md-primary-fg-color);
  transition: width 0.3s ease;
}
#pulse-leaderboard .pulse-lb-card.is-partial .pulse-lb-bar > span {
  background: var(--md-default-fg-color--lighter);
}

#pulse-leaderboard .pulse-lb-cats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(5.5rem, 1fr));
  gap: 0.35rem;
  margin-top: 0.85rem;
  padding-top: 0.7rem;
  border-top: 1px dashed var(--md-default-fg-color--lightest);
}
#pulse-leaderboard .pulse-lb-cat {
  display: flex;
  flex-direction: column;
  padding: 0.3rem 0.45rem;
  background: var(--md-code-bg-color);
  border-radius: 0.35rem;
  line-height: 1.1;
}
#pulse-leaderboard .pulse-lb-cat.is-core {
  background: color-mix(in srgb, var(--md-primary-fg-color) 8%, var(--md-code-bg-color));
}
#pulse-leaderboard .pulse-lb-cat.is-missing { opacity: 0.45; }
#pulse-leaderboard .pulse-lb-cat-name {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--md-default-fg-color--light);
}
#pulse-leaderboard .pulse-lb-cat-val {
  font-size: 0.95rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--md-default-fg-color);
}

@media (max-width: 48em) {
  #pulse-leaderboard .pulse-lb-head {
    grid-template-columns: auto 1fr;
  }
  #pulse-leaderboard .pulse-lb-overall {
    grid-column: 1 / -1;
    align-items: flex-start;
  }
}

/* ────────────────────────────────────────────────────────────────────────
 * Compare-benchmark panel
 * ──────────────────────────────────────────────────────────────────────── */

.pulse-compare-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin: 0.5rem 0 0.65rem;
  padding: 0.55rem 0.7rem;
  background: var(--md-code-bg-color);
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.5rem;
}
.pulse-compare-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--md-default-fg-color--light);
}
.pulse-compare-select {
  flex: 0 1 18rem;
  padding: 0.35rem 0.55rem;
  font: inherit;
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
  border: 1px solid var(--md-default-fg-color--lighter);
  border-radius: 0.35rem;
}
.pulse-compare-meta {
  margin-left: auto;
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
}

/* ────────────────────────────────────────────────────────────────────────
 * Charts
 * ──────────────────────────────────────────────────────────────────────── */

.pulse-chart-wrap {
  height: 320px;
  margin: 0.75em 0 1.5em;
  padding: 0.75rem;
  background: var(--md-default-bg-color);
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.5rem;
}
.pulse-compare-canvas {
  /* Bench-compare wants height proportional to the number of bars; cap it
   * so a single benchmark doesn't get a stupidly tall chart. */
  height: 360px;
}

.pulse-empty {
  margin: 1em 0;
  padding: 1em 1.2em;
  background: var(--md-code-bg-color);
  border-left: 3px solid var(--md-default-fg-color--lighter);
  color: var(--md-default-fg-color--light);
  font-style: italic;
  border-radius: 0 0.35rem 0.35rem 0;
}

/* ────────────────────────────────────────────────────────────────────────
 * Tabulator dashboard toolbar
 * ──────────────────────────────────────────────────────────────────────── */

#pulse-dashboard .pulse-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin: 0.5rem 0 0.6rem;
  padding: 0.6rem;
  background: var(--md-code-bg-color);
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 0.5rem;
}

#pulse-dashboard .pulse-toolbar input[type="search"] {
  flex: 1 1 16rem;
  min-width: 12rem;
  padding: 0.4rem 0.6rem;
  font: inherit;
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
  border: 1px solid var(--md-default-fg-color--lighter);
  border-radius: 0.35rem;
}

#pulse-dashboard .pulse-toolbar select {
  flex: 0 1 12rem;
  min-width: 9rem;
  padding: 0.35rem 0.5rem;
  font: inherit;
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
  border: 1px solid var(--md-default-fg-color--lighter);
  border-radius: 0.35rem;
}

#pulse-dashboard .pulse-toolbar button {
  padding: 0.4rem 0.85rem;
  font: inherit;
  cursor: pointer;
  background: var(--md-primary-fg-color);
  color: var(--md-primary-bg-color);
  border: none;
  border-radius: 0.35rem;
  transition: filter 0.12s;
}
#pulse-dashboard .pulse-toolbar button:hover {
  filter: brightness(1.08);
}
#pulse-dashboard .pulse-toolbar button.pulse-secondary {
  background: transparent;
  color: var(--md-default-fg-color--light);
  border: 1px solid var(--md-default-fg-color--lighter);
}
#pulse-dashboard .pulse-toolbar button.pulse-secondary:hover {
  color: var(--md-default-fg-color);
  border-color: var(--md-default-fg-color);
  filter: none;
}

#pulse-dashboard .pulse-meta {
  margin: 0 0 0.5rem;
  font-size: 0.78rem;
  color: var(--md-default-fg-color--light);
}

#pulse-dashboard .pulse-error {
  padding: 0.75rem 1rem;
  color: var(--md-default-fg-color);
  background: var(--md-code-bg-color);
  border-left: 3px solid var(--md-warning-fg-color, #c97a00);
  border-radius: 0 0.35rem 0.35rem 0;
}

/* Tabulator: respect Material color scheme. Tabulator's default theme
 * is light; we override a handful of variables for dark mode. */
[data-md-color-scheme="slate"] .tabulator,
[data-md-color-scheme="slate"] .tabulator .tabulator-header,
[data-md-color-scheme="slate"] .tabulator .tabulator-header .tabulator-col,
[data-md-color-scheme="slate"] .tabulator .tabulator-row,
[data-md-color-scheme="slate"] .tabulator .tabulator-footer {
  color: var(--md-default-fg-color);
  border-color: var(--md-default-fg-color--lighter);
}
[data-md-color-scheme="slate"] .tabulator,
[data-md-color-scheme="slate"] .tabulator .tabulator-row {
  background: var(--md-default-bg-color);
}
[data-md-color-scheme="slate"] .tabulator .tabulator-header,
[data-md-color-scheme="slate"] .tabulator .tabulator-header .tabulator-col,
[data-md-color-scheme="slate"] .tabulator .tabulator-row.tabulator-row-even,
[data-md-color-scheme="slate"] .tabulator .tabulator-footer {
  background: var(--md-code-bg-color);
}
[data-md-color-scheme="slate"] .tabulator .tabulator-header .tabulator-col .tabulator-col-content .tabulator-col-title {
  color: var(--md-default-fg-color);
}
[data-md-color-scheme="slate"] .tabulator-edit-list,
[data-md-color-scheme="slate"] .tabulator-edit-select-list {
  background: var(--md-default-bg-color);
  color: var(--md-default-fg-color);
  border-color: var(--md-default-fg-color--lighter);
}

@media (max-width: 48em) {
  #pulse-dashboard .pulse-toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  #pulse-dashboard .pulse-toolbar select,
  #pulse-dashboard .pulse-toolbar input[type="search"] {
    width: 100%;
    max-width: none;
  }
  .pulse-compare-meta { margin-left: 0; }
}
