/* ──────────────────────────────────────────────────────────────────────
   Checkers — vanilla CSS. Mobile-first, fluid (no media queries).
   Tokens from .reference/skill design system.
   ────────────────────────────────────────────────────────────────────── */

:root {
  /* Neutrals */
  --color-bg: #ffffff;
  --color-bg-subtle: #f5f5f5;
  --color-text: #111111;
  --color-text-muted: #5d6265;
  --color-border: #e6e6e6;
  --color-border-dark: #b3b3b3;
  --color-grey-100: #f5f5f5;
  --color-grey-200: #d9d9d9;
  --color-grey-300: #8c8c8c;

  /* Semantic state colors (status pills, alerts) */
  --color-status-queued-bg: #f5f5f5;
  --color-status-queued-fg: #5d6265;
  --color-status-running-bg: #ebebe5;
  --color-status-running-fg: #4f4f4a;
  --color-status-done-bg: #f0f5f1;
  --color-status-done-fg: #1c403a;
  --color-status-failed-bg: #fbeae6;
  --color-status-failed-fg: #7a2418;
  --color-status-lost-bg: #f4f1f8;
  --color-status-lost-fg: #51485b;

  /* Type */
  --font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --size--2: clamp(0.78rem, 0.75rem + 0.18vw, 0.88rem);
  --size--1: clamp(0.94rem, 0.88rem + 0.30vw, 1.10rem);
  --size-0:  clamp(1.13rem, 1.03rem + 0.45vw, 1.38rem);
  --size-1:  clamp(1.35rem, 1.22rem + 0.67vw, 1.72rem);
  --size-2:  clamp(1.62rem, 1.43rem + 0.96vw, 2.15rem);
  --size-3:  clamp(1.94rem, 1.67rem + 1.35vw, 2.69rem);
  --size-4:  clamp(2.33rem, 1.96rem + 1.86vw, 3.36rem);
  --size-5:  clamp(1.80rem, 1.29rem + 2.54vw, 4.20rem);

  /* Spacing */
  --space-3xs: clamp(0.25rem, 0.23rem + 0.11vw, 0.31rem);
  --space-2xs: clamp(0.50rem, 0.46rem + 0.22vw, 0.63rem);
  --space-xs:  clamp(0.75rem, 0.69rem + 0.33vw, 0.94rem);
  --space-s:   clamp(1.00rem, 0.91rem + 0.43vw, 1.25rem);
  --space-m:   clamp(1.50rem, 1.37rem + 0.65vw, 1.88rem);
  --space-l:   clamp(2.00rem, 1.83rem + 0.87vw, 2.50rem);
  --space-xl:  clamp(3.00rem, 2.74rem + 1.30vw, 3.75rem);
  --space-2xl: clamp(4.00rem, 3.65rem + 1.74vw, 5.00rem);
  --space-3xl: clamp(6.00rem, 5.48rem + 2.61vw, 7.50rem);

  --radius: 4px;
  --transition: 150ms ease;
}

/* ── Reset ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; text-size-adjust: 100%; }
body {
  font-family: var(--font-sans);
  font-size: var(--size-0);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.5;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }
code { font-family: var(--font-mono); font-size: 0.92em; }
:focus-visible { outline: 2px solid var(--color-text); outline-offset: 2px; border-radius: 2px; }

/* ── Layout ──────────────────────────────────────────────────────────── */
.container {
  width: 100%;
  max-width: 100rem;
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2.5rem);
}

.site-main { flex: 1; padding-block: var(--space-xl) var(--space-2xl); }

/* ── Header (brand palette, scoped) ──────────────────────────────────── */
/* Brand tokens — only used inside .site-header. */
.site-header {
  --brand-board-light: #FFEEBB;
  --brand-board-dark:  #558822;
  --brand-piece-light: #FFF9F4;
  --brand-piece-red:   #C40003;
  --brand-ink:         #000000;
  --brand-cream:       #F2E4C9;

  background: var(--brand-cream);
  border-bottom: 1px solid #e5d9c4;
  padding-block: var(--space-s);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-m); flex-wrap: wrap;
}
.logo-text { font-size: var(--size-1); font-weight: 600; letter-spacing: -0.02em; }
.site-logo { display: inline-flex; align-items: center; gap: var(--space-2xs); line-height: 1; color: var(--brand-ink); }
.site-logo img { width: clamp(2rem, 2vw + 1.5rem, 2.75rem); height: auto; display: block; }
.site-logo__text { font-size: var(--size-1); font-weight: 600; letter-spacing: -0.02em; }
.site-header .site-nav { display: flex; gap: var(--space-m); list-style: none; flex-wrap: wrap; }
.site-header .site-nav a {
  font-size: var(--size--1); font-weight: 600;
  color: var(--brand-ink); transition: color var(--transition);
}
.site-header .site-nav a:hover { color: var(--brand-board-dark); }
.site-header .site-nav a[aria-current] { color: var(--brand-piece-red); }

/* ── Footer ──────────────────────────────────────────────────────────── */
.site-footer { border-top: 1px solid var(--color-border); padding-block: var(--space-l); margin-top: var(--space-2xl); }
.site-footer__text { color: var(--color-text-muted); }

/* ── Eyebrow / labels ────────────────────────────────────────────────── */
.eyebrow {
  display: block; font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-muted); margin-bottom: var(--space-s);
}

/* ── Hero ────────────────────────────────────────────────────────────── */
.hero { max-width: 50rem; }
.hero__title {
  font-size: var(--size-4); font-weight: 600; letter-spacing: -0.02em;
  line-height: 1.1; margin-bottom: var(--space-m);
}
.hero__lead {
  font-size: var(--size-0); color: var(--color-text-muted);
  margin-bottom: var(--space-xl); max-width: 40rem;
}

/* ── Check form ──────────────────────────────────────────────────────── */
.check-form {
  display: flex; flex-direction: column; gap: var(--space-xs);
  margin-bottom: var(--space-2xl);
}
.check-form__label {
  font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-muted);
}
.check-form__row {
  display: flex; gap: var(--space-s); flex-wrap: wrap;
}
.check-form__input {
  flex: 1 1 18rem; min-width: 0;
  padding: 0.85rem 1rem;
  font-family: var(--font-sans);
  font-size: var(--size-0);
  color: var(--color-text);
  background: #fff;
  border: 1px solid var(--color-border-dark);
  border-radius: var(--radius);
  transition: border-color var(--transition);
}
.check-form__input:hover { border-color: var(--color-text); }
.check-form__input:focus-visible { outline: none; border-color: var(--color-text); }
.check-form__textarea {
  font-family: inherit; resize: vertical; min-height: 8rem;
  line-height: 1.5;
}
.check-form__submit { flex: 0 0 auto; }
.check-form__hint { font-size: var(--size--2); color: var(--color-text-muted); }
.check-form__error {
  background: var(--color-status-failed-bg);
  color: var(--color-status-failed-fg);
  padding: var(--space-xs) var(--space-s);
  border-radius: var(--radius);
  font-size: var(--size--1);
}

/* ── Buttons ─────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 1.5rem;
  font-family: var(--font-sans);
  font-size: var(--size--1); font-weight: 600;
  border-radius: var(--radius);
  border: 1px solid transparent;
  cursor: pointer; white-space: nowrap;
  transition: background-color var(--transition), border-color var(--transition), color var(--transition);
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn--primary { background: var(--color-grey-100); color: var(--color-text); border-color: var(--color-border-dark); }
.btn--primary:hover:not(:disabled) { background: var(--color-grey-200); border-color: var(--color-text); }
.btn--secondary { background: transparent; color: var(--color-text); border-color: var(--color-border-dark); }
.btn--secondary:hover { border-color: var(--color-text); }
.btn--ghost {
  background: none; border: none; color: var(--color-text);
  padding-inline: 0; text-decoration: underline; text-underline-offset: 3px;
}

/* ── Feature grid ────────────────────────────────────────────────────── */
.features { margin-top: var(--space-2xl); }
.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
  gap: var(--space-m);
  list-style: none;
}
.feature-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-l);
  display: flex; flex-direction: column; gap: var(--space-s);
}
.feature-card__title {
  font-size: var(--size-1); font-weight: 600;
  letter-spacing: -0.01em; line-height: 1.2;
}
.feature-card__body { font-size: var(--size--1); color: var(--color-text-muted); }

/* ── Check (waiting) page ────────────────────────────────────────────── */
.check { max-width: none; }
.check__back { margin-bottom: var(--space-m); }
.check__title {
  font-size: var(--size-3); font-weight: 600; letter-spacing: -0.02em;
  line-height: 1.2; margin-bottom: var(--space-l);
  word-break: break-all;
}
.check__status {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-l);
  display: flex; flex-direction: column; gap: var(--space-m);
}
.check__status-head {
  display: flex; align-items: center; gap: var(--space-s); flex-wrap: wrap;
}
.check__timer {
  font-family: var(--font-mono); font-size: var(--size--1);
  color: var(--color-text-muted); margin-left: auto;
}
.check__status-text { font-size: var(--size-0); color: var(--color-text-muted); }
.is-processing::after {
  content: '';
  display: inline-block;
  width: 1.2em;
  text-align: left;
  animation: processing-dots 1.2s steps(4) infinite;
}
@keyframes processing-dots {
  0%   { content: ''; }
  25%  { content: '.'; }
  50%  { content: '..'; }
  75%  { content: '...'; }
}
.check__progress {
  width: 100%; height: 6px;
  appearance: none; -webkit-appearance: none;
  border: none; background: var(--color-grey-100); border-radius: 999px; overflow: hidden;
}
.check__progress::-webkit-progress-bar { background: var(--color-grey-100); border-radius: 999px; }
.check__progress::-webkit-progress-value { background: var(--color-text); transition: width var(--transition); border-radius: 999px; }
.check__progress::-moz-progress-bar { background: var(--color-text); border-radius: 999px; }
.check__log {
  list-style: none;
  display: flex; flex-direction: column; gap: var(--space-3xs);
  font-size: var(--size--2); color: var(--color-text-muted);
  font-family: var(--font-mono);
}
.check__log li::before { content: "› "; color: var(--color-grey-300); }
.check__actions { display: flex; gap: var(--space-s); flex-wrap: wrap; margin-top: var(--space-s); }

/* ── Status pill ─────────────────────────────────────────────────────── */
.status-pill {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.25rem 0.75rem; border-radius: 999px;
  font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
}
.status-pill::before {
  content: ""; width: 0.5rem; height: 0.5rem; border-radius: 50%;
  background: currentColor;
}
.status-pill--queued { background: var(--color-status-queued-bg); color: var(--color-status-queued-fg); }
.status-pill--running { background: var(--color-status-running-bg); color: var(--color-status-running-fg); }
.status-pill--running::before { animation: pulse 1.4s ease-in-out infinite; }
.status-pill--done { background: var(--color-status-done-bg); color: var(--color-status-done-fg); }
.status-pill--failed { background: var(--color-status-failed-bg); color: var(--color-status-failed-fg); }
.status-pill--lost { background: var(--color-status-lost-bg); color: var(--color-status-lost-fg); }

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.4; transform: scale(1.3); }
}

/* ── Report page chrome ──────────────────────────────────────────────── */
.report-page__head {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-s); flex-wrap: wrap;
  margin-bottom: var(--space-l);
}
.report-page__loading {
  display: flex; align-items: center; gap: var(--space-s);
  padding: var(--space-l);
  background: var(--color-bg-subtle);
  border-radius: var(--radius);
}
.report-page__loading-text { font-size: var(--size-0); color: var(--color-text-muted); }
.report-page__error {
  padding: var(--space-l);
  border: 1px solid var(--color-status-failed-fg);
  background: var(--color-status-failed-bg);
  border-radius: var(--radius);
  margin-bottom: var(--space-l);
}
.report-page__error h2 {
  font-size: var(--size-2); font-weight: 600;
  color: var(--color-status-failed-fg); margin-bottom: var(--space-s);
}
.report-page__error p { margin-bottom: var(--space-m); }
.report-page__error-actions { display: flex; gap: var(--space-s); flex-wrap: wrap; }

/* ── Report ──────────────────────────────────────────────────────────── */
.report-slot { margin-top: 0; }
.report__header {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: var(--space-l);
  margin-bottom: var(--space-l);
}
.report__eyebrow {
  display: block; font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-muted); margin-bottom: var(--space-s);
}
.report__url {
  font-size: var(--size-2); font-weight: 600; letter-spacing: -0.01em;
  word-break: break-all; margin-bottom: var(--space-xs);
}
.report__redirect { font-size: var(--size--1); color: var(--color-text-muted); margin-bottom: var(--space-m); }
.report__meta {
  list-style: none; display: flex; flex-wrap: wrap;
  gap: var(--space-l); margin-top: var(--space-m);
}
.report__meta li { display: flex; flex-direction: column; gap: 2px; }
.report__meta span {
  font-size: var(--size--2); color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.08em;
}
.report__meta strong { font-size: var(--size-0); font-weight: 600; font-family: var(--font-mono); }
.report__meta-action {
  margin-left: auto;
  align-self: center;
  display: flex;
  flex-direction: row;
  align-items: center;
}

.report__notice {
  margin-top: var(--space-m);
  padding: var(--space-s) var(--space-m);
  background: var(--color-status-running-bg);
  color: var(--color-status-running-fg);
  border-left: 3px solid var(--color-border-dark);
  border-radius: 2px;
}
.report__notice p { margin: 0; }
.report__notice a { color: inherit; text-decoration: underline; }

.report-section {
  margin-block: var(--space-xl);
  padding-top: var(--space-l);
  border-top: 1px solid var(--color-border);
}
.report-section:first-of-type { border-top: none; padding-top: 0; }
.report-section--compact {
  margin-block: var(--space-m);
  padding-top: var(--space-s);
}
.report-section--compact .report-section__head { margin-bottom: 0; }
/* Tighten the next section's leading space too — otherwise the compact
   section looks like it has a big gap below it. */
.report-section--compact + .report-section {
  margin-top: var(--space-m);
  padding-top: var(--space-s);
}
.report-section__title {
  font-size: var(--size-2); font-weight: 600; letter-spacing: -0.01em;
  margin-bottom: var(--space-m);
}
.report-section__subtitle {
  font-size: var(--size--1); font-weight: 600;
  margin-top: var(--space-l); margin-bottom: var(--space-s);
  color: var(--color-text-muted);
  text-transform: uppercase; letter-spacing: 0.1em;
}
.report-section__note {
  font-size: var(--size--1); color: var(--color-text-muted);
  padding: var(--space-s) var(--space-m);
  background: var(--color-bg-subtle); border-radius: var(--radius);
}
/* Inline header: title on the left, empty-state hint on the right. */
.report-section__head {
  display: flex; align-items: baseline; flex-wrap: wrap;
  gap: var(--space-m); margin-bottom: var(--space-m);
}
.report-section__head .report-section__title { margin-bottom: 0; }
.report-section__hint {
  font-size: var(--size--1); color: var(--color-text-muted); margin: 0;
}

/* ── Stat grid (legacy + new strip) ──────────────────────────────────── */
.stat-grid {
  list-style: none; display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 9rem), 1fr));
  gap: var(--space-m);
}
.stat-grid--compact { gap: var(--space-s); }
.stat { display: flex; flex-direction: column; gap: 4px; }
.stat__number {
  font-size: var(--size-3); font-weight: 600; letter-spacing: -0.02em;
  line-height: 1;
}
.stat__label { font-size: var(--size--2); color: var(--color-text-muted); }

/* New "at a glance" before/after stat strip. */
.stat-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 11rem), 1fr));
  gap: var(--space-m);
}
.stat__value {
  display: flex; align-items: baseline; gap: var(--space-2xs);
}
.stat__num {
  font-size: var(--size-4); font-weight: 600;
  letter-spacing: -0.02em; line-height: 1;
}
.stat__num--after {
  font-size: var(--size-1); color: var(--color-text-muted);
  padding: 0.1rem 0.6rem;
  background: var(--color-status-done-bg);
  border-radius: 999px;
}
.stat__num--after::before { content: "→ "; }
.stat__delta {
  font-size: var(--size--2);
  margin-top: var(--space-2xs);
}
.stat__delta--up   { color: var(--color-status-done-fg); font-weight: 600; }
.stat__delta--down { color: var(--color-status-failed-fg); font-weight: 600; }
.stat__delta--flat { color: var(--color-text-muted); }

/* ── Key/value list ──────────────────────────────────────────────────── */
.kv-list { display: flex; flex-direction: column; gap: var(--space-xs); }
.kv-list__row {
  display: grid; grid-template-columns: minmax(8rem, 14ch) 1fr;
  gap: var(--space-s); padding-block: var(--space-2xs);
  border-bottom: 1px solid var(--color-border);
}
.kv-list__row:last-child { border-bottom: none; }
.kv-list__row dt {
  font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.kv-list__row dd { font-size: var(--size--1); word-break: break-word; }
.code--block {
  display: block; padding: var(--space-xs); background: var(--color-bg-subtle);
  border-radius: var(--radius); white-space: pre-wrap; word-break: break-all;
}

/* ── Data table ──────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; margin-block: var(--space-s); }
.data-table {
  width: 100%; border-collapse: collapse;
  font-size: var(--size--1); min-width: 30rem;
}
.data-table th, .data-table td {
  padding: var(--space-2xs) var(--space-s);
  text-align: left; vertical-align: top;
  border-bottom: 1px solid var(--color-border);
}
.data-table thead th {
  font-weight: 600; font-size: var(--size--2);
  background: var(--color-grey-100);
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.data-table__value, .data-table__url {
  font-family: var(--font-mono); font-size: 0.85em;
  word-break: break-all; max-width: 40rem;
}
.data-table--compact th, .data-table--compact td {
  padding: var(--space-3xs) var(--space-s);
}

/* ── Flags (cookie attrs) ────────────────────────────────────────────── */
.flag {
  display: inline-block; min-width: 1.2rem; text-align: center;
  padding: 0 0.4rem; border-radius: 3px;
  font-family: var(--font-mono); font-size: var(--size--2);
  background: var(--color-grey-100); color: var(--color-grey-300);
  margin-right: 2px;
}
.flag--on { background: var(--color-status-done-bg); color: var(--color-status-done-fg); }
.flag--text {
  background: transparent; color: var(--color-text-muted);
  font-family: var(--font-sans); padding: 0 0.3rem;
}

/* ── Technologies (grouped) ──────────────────────────────────────────── */
.tech-groups {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr));
  gap: var(--space-m);
}
.tech-group { display: flex; flex-direction: column; gap: var(--space-xs); min-width: 0; }
.tech-group__title {
  font-size: var(--size--2); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-muted);
}

/* ── Tags ────────────────────────────────────────────────────────────── */
.tag-list {
  list-style: none; display: flex; flex-wrap: wrap;
  gap: var(--space-2xs);
}
.tag {
  font-size: var(--size--1);
  padding: 0.25rem 0.75rem;
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
}
.tag__type {
  font-size: var(--size--2); color: var(--color-text-muted);
  margin-left: 0.25rem;
}

/* ── Compare (before / after side-by-side) ──────────────────────────── */
.compare {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 28rem), 1fr));
  gap: var(--space-m);
}
.compare__col {
  display: flex; flex-direction: column; gap: var(--space-s);
  min-width: 0;
}
.compare__title {
  font-size: var(--size-1); font-weight: 600;
  letter-spacing: -0.01em;
}
.compare__meta {
  font-size: var(--size--1); color: var(--color-text-muted);
  margin-top: calc(-1 * var(--space-2xs));
}
.compare__meta--muted { font-style: italic; }

/* Status tags shown inline next to a name/url to mark new/changed entries. */
.status-tag {
  display: inline-block;
  font-size: 0.65rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 0.1rem 0.4rem;
  border-radius: 999px;
  margin-left: 0.4rem;
  vertical-align: middle;
}
.status-tag--new     { background: var(--color-status-done-bg); color: var(--color-status-done-fg); }
.status-tag--changed { background: var(--color-status-running-bg); color: var(--color-status-running-fg); }

/* ── Tree (grouped lists with details/summary) ───────────────────────── */
.tree {
  list-style: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
  overflow: hidden;
}
.tree__node + .tree__node { border-top: 1px solid var(--color-border); }
.tree__head,
.tree__summary {
  display: grid;
  /* Caret · main · party-badge · count.  Fixed widths on the trailing two
     so the header columns line up with the data values — `auto auto` made
     each row size independently and the columns drifted. */
  grid-template-columns: 1.5rem minmax(0, 1fr) 4.5rem 6rem;
  align-items: center;
  gap: var(--space-s);
}
/* On narrow screens the fixed columns squeeze the main column, so let them
   collapse to content width. Header/row alignment drifts slightly but the
   layout no longer breaks. */
@media (max-width: 36rem) {
  .tree__head,
  .tree__summary {
    grid-template-columns: 1.5rem minmax(0, 1fr) auto auto;
    gap: var(--space-xs);
  }
}
.tree__head {
  padding: var(--space-2xs) var(--space-s);
  background: var(--color-grey-100);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--size--2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}
.tree__details { width: 100%; }
.tree__summary {
  padding: var(--space-xs) var(--space-s);
  cursor: pointer;
  user-select: none;
  list-style: none;
  background: #fff;
  transition: background-color var(--transition);
}
.tree__summary::-webkit-details-marker { display: none; }
.tree__caret {
  width: 0; height: 0;
  border-style: solid;
  border-width: 5px 0 5px 7px;
  border-color: transparent transparent transparent var(--color-text);
  transition: transform 150ms ease;
  justify-self: center;
}
.tree__details[open] > .tree__summary .tree__caret { transform: rotate(90deg); }
.tree__summary:hover { background: var(--color-bg-subtle); }

.tree__host, .tree__name {
  font-family: var(--font-mono);
  font-size: var(--size--1);
  word-break: break-all;
  min-width: 0;
}
.tree__host { font-weight: 600; }
.tree__count {
  font-family: var(--font-mono);
  font-size: var(--size--2);
  color: var(--color-text-muted);
  background: var(--color-bg-subtle);
  padding: 0.15rem 0.6rem;
  border-radius: 999px;
  min-width: 2.5ch;
  text-align: center;
  justify-self: start;
}
.tree__badge {
  font-size: var(--size--2);
  font-weight: 600;
  padding: 0.15rem 0.6rem;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  justify-self: start;
}
.tree__badge--first { background: var(--color-status-done-bg); color: var(--color-status-done-fg); }
.tree__badge--third { background: var(--color-status-lost-bg); color: var(--color-status-lost-fg); }

.tree__children {
  list-style: none;
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
}
.tree__leaf {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: baseline;
  gap: var(--space-s);
  padding: var(--space-2xs) var(--space-s) var(--space-2xs) calc(var(--space-s) + 1.5rem);
  border-top: 1px solid var(--color-border);
  font-size: var(--size--1);
}
.tree__leaf:first-child { border-top: none; }
.tree__url, .tree__leaf > code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  word-break: break-all;
  min-width: 0;
}
.tree__meta {
  font-size: var(--size--2);
  color: var(--color-text-muted);
  text-align: right;
  white-space: nowrap;
  /* Scales the cap from 6rem on phones up to 14rem on wide screens so the
     content-type column doesn't push the URL column off-screen on mobile. */
  max-width: clamp(6rem, 35vw, 14rem);
  overflow: hidden;
  text-overflow: ellipsis;
}
.tree__meta--mono { font-family: var(--font-mono); }
.tree__leaf--cookie { padding-block: var(--space-3xs); }

/* Storage rows: 2-column grid where the value column wraps on long JSON blobs. */
.tree__head--storage,
.tree__leaf--storage {
  grid-template-columns: minmax(8rem, 1fr) minmax(0, 3fr);
  padding-left: var(--space-s);
}
.tree__value {
  font-family: var(--font-mono);
  font-size: 0.85em;
  color: var(--color-text-muted);
  word-break: break-all;
  overflow-wrap: anywhere;
  min-width: 0;
}

/* ── Disclosure (details/summary) ────────────────────────────────────── */
.disclosure {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: #fff;
}
.disclosure__summary {
  padding: var(--space-s) var(--space-m);
  font-size: var(--size--1); font-weight: 600;
  cursor: pointer; user-select: none;
  list-style: none;
}
.disclosure__summary::-webkit-details-marker { display: none; }
.disclosure__summary::before { content: "+ "; color: var(--color-text-muted); }
.disclosure[open] .disclosure__summary::before { content: "− "; }
.disclosure[open] .disclosure__summary { border-bottom: 1px solid var(--color-border); }

/* ── Report error ────────────────────────────────────────────────────── */
.report-error {
  padding: var(--space-l);
  border: 1px solid var(--color-status-failed-fg);
  background: var(--color-status-failed-bg);
  border-radius: var(--radius);
}
.report-error__title {
  font-size: var(--size-2); font-weight: 600;
  color: var(--color-status-failed-fg); margin-bottom: var(--space-s);
}
.report-error__reason { font-size: var(--size-0); margin-bottom: var(--space-s); }
.report-error__url { font-size: var(--size--1); color: var(--color-text-muted); }

/* ── Prose (about page) ──────────────────────────────────────────────── */
.prose { max-width: 50rem; }
.prose h1 {
  font-size: var(--size-4); font-weight: 600; letter-spacing: -0.02em;
  line-height: 1.1; margin-bottom: var(--space-m);
}
.prose h2 {
  font-size: var(--size-2); font-weight: 600;
  margin-top: var(--space-xl); margin-bottom: var(--space-s);
}
.prose .lead { font-size: var(--size-0); color: var(--color-text-muted); margin-bottom: var(--space-l); }
.prose p { margin-bottom: var(--space-s); }
.prose ol, .prose ul { margin: var(--space-s) 0 var(--space-m) var(--space-l); }
.prose li { margin-bottom: var(--space-2xs); }
.prose__muted { color: var(--color-text-muted); font-size: var(--size--1); }
