/* ───────────────────────────────────────────────────────────
   Cyboflow site — Changelog page
   Sits on tokens.css + site.css. A reading-column release
   timeline: hero + "synced from source" bar, sticky change-type
   filter, and a vertical spine of releases grouped by kind.
   Paper aesthetic — hairline borders, square corners, one rust
   accent, the design system's per-kind colors (Added=green,
   Fixed=rust, Changed=gold).
   ─────────────────────────────────────────────────────────── */

.cl {
  /* change-item body sits a touch darker than the global body ink */
  --cl-text: #2c2820;
}

/* 940px reading column with the design's 28px gutters. */
.cl-wrap { width: min(940px, 100%); margin-inline: auto; padding-inline: 28px; }

/* Inline code chip, reused in the lede and in change text. */
.cl-code {
  font-family: var(--cf-font);
  background: rgba(106, 94, 68, .09);
  border: 1px solid var(--cf-line-soft);
  border-radius: 2px;
  padding: 1px 5px;
  font-size: .9em;
  color: var(--cf-ink);
}

/* Square-pulse — the only motion on the page. Distinct from the
   shared cf-pulse (which scales to .8); the changelog design calls
   for a tighter .7. */
@keyframes cl-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .4; transform: scale(.7); }
}

/* ─── Hero ────────────────────────────────────────────────── */
.cl-hero { padding-block: 64px 0; }
.cl-hero .cl-wrap { border-bottom: 1px solid var(--cf-line-soft); padding-bottom: 30px; }
.cl-eyebrow {
  font-size: 9px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--cf-ink-3); font-weight: 600;
}
.cl-title {
  font-size: 46px; line-height: 1.02; font-weight: 700;
  letter-spacing: -0.025em; margin: 16px 0 0; color: var(--cf-ink);
}
.cl-lede {
  font-size: 14px; line-height: 1.6; color: var(--cf-ink-2);
  margin: 18px 0 0; max-width: 580px;
}

/* Synced-from-source status bar */
.cl-sync {
  display: flex; align-items: center; flex-wrap: wrap; gap: 14px;
  margin-top: 26px; padding: 11px 14px;
  background: var(--cf-card); border: 1px solid var(--cf-line);
}
.cl-sync .grow { flex: 1; }
.cl-sync-live { display: inline-flex; align-items: center; gap: 8px; }
.cl-sync-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--cf-green); animation: cl-pulse 1.4s infinite; display: inline-block;
}
.cl-sync-live-l {
  font-size: 9px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cf-green); font-weight: 700;
}
.cl-sync-src { font-size: 11.5px; color: var(--cf-ink-2); }
/* Live sync failed → the bar honestly downgrades to "showing saved copy". */
.cl-sync.is-stale .cl-sync-dot { background: var(--cf-ink-4); animation: none; }
.cl-sync.is-stale .cl-sync-live-l { color: var(--cf-ink-3); }
.cl-sync-mid { color: var(--cf-ink-4); }
.cl-sync-time { font-size: 10px; color: var(--cf-ink-3); }
.cl-ghost {
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--cf-ink-2); border: 1px solid var(--cf-line);
  padding: 6px 11px; text-decoration: none; background: transparent;
  white-space: nowrap; transition: border-color .12s, color .12s;
}
.cl-ghost:hover { border-color: var(--cf-ink); color: var(--cf-ink); }
.cl-ghost:focus-visible { outline: 2px solid var(--cf-rust); outline-offset: 3px; color: var(--cf-ink); }

/* ─── Filter bar (sticky under the 52px site header) ──────── */
.cl-filter {
  position: sticky; top: 52px; z-index: 10;
  background: var(--cf-page);
}
.cl-filter-row {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding-block: 16px; border-bottom: 1px solid var(--cf-line-soft);
}
.cl-filter-label {
  font-size: 9px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cf-ink-4); font-weight: 600; margin-right: 2px;
}
.cl-chip {
  font-family: var(--cf-font);
  font-size: 10px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: 6px 12px; white-space: nowrap; cursor: pointer;
  background: transparent; color: var(--cf-ink-2);
  border: 1px solid var(--cf-line);
  transition: background .12s, color .12s, border-color .12s;
}
.cl-chip[data-filter="all"]     { --accent: var(--cf-ink); }
.cl-chip[data-filter="Added"]   { --accent: var(--cf-green); }
.cl-chip[data-filter="Fixed"]   { --accent: var(--cf-rust); }
.cl-chip[data-filter="Changed"] { --accent: var(--cf-gold); }
.cl-chip.is-active {
  background: var(--accent); border-color: var(--accent); color: var(--cf-page);
}
.cl-chip:focus-visible { outline: 2px solid var(--cf-rust); outline-offset: 2px; }
.cl-chip-n { opacity: .6; font-weight: 400; margin-left: 3px; }

/* ─── Timeline ────────────────────────────────────────────── */
.cl-timeline { padding-bottom: 100px; }
.cl-track { position: relative; margin-top: 40px; }
.cl-spine {
  position: absolute; left: 7px; top: 6px; bottom: 10px; width: 2px;
  background: linear-gradient(var(--cf-line), var(--cf-line) 88%, transparent);
}

.cl-rel { position: relative; padding-left: 54px; padding-bottom: 52px; }
.cl-node {
  position: absolute; left: 0; top: 4px; width: 16px; height: 16px;
  border-radius: 50%; background: var(--cf-ink);
  box-shadow: 0 0 0 5px var(--cf-page); /* masks the spine behind the dot */
}
.cl-rel--latest .cl-node { background: var(--cf-rust); animation: cl-pulse 1.6s infinite; }

.cl-rel-head {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 4px;
}
.cl-ver {
  display: inline-block; margin: 0;
  font-size: 15px; font-weight: 700; letter-spacing: -0.01em; color: var(--cf-ink);
  background: var(--cf-card); border: 1.4px solid var(--cf-ink); padding: 3px 11px;
}
.cl-date { font-size: 11px; color: var(--cf-ink-3); font-variant-numeric: tabular-nums; }
.cl-latest {
  font-size: 8.5px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cf-page); background: var(--cf-rust); padding: 3px 7px;
}
.cl-blurb {
  font-size: 13px; line-height: 1.55; color: var(--cf-ink-2);
  margin: 8px 0 0; font-style: italic;
}

/* Change group — --accent defaults muted so an unrecognized change-kind
   (e.g. a future Removed/Security section) still renders sanely. */
.cl-group { margin-top: 20px; --accent: var(--cf-ink-3); }
.cl-group[data-kind="Added"]   { --accent: var(--cf-green); }
.cl-group[data-kind="Fixed"]   { --accent: var(--cf-rust); }
.cl-group[data-kind="Changed"] { --accent: var(--cf-gold); }
.cl-group-head { display: flex; align-items: center; gap: 9px; margin-bottom: 12px; }
.cl-kind {
  margin: 0; font-size: 9px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--accent); border: 1px solid var(--accent); padding: 2px 8px;
}
.cl-rule { flex: 1; height: 1px; background: var(--cf-line-soft); }
.cl-count { font-size: 9.5px; color: var(--cf-ink-4); }

.cl-items { list-style: none; margin: 0; padding: 0; }
.cl-item { display: flex; gap: 13px; margin-bottom: 13px; }
.cl-bullet {
  flex: 0 0 7px; width: 7px; height: 7px; margin-top: 7px; background: var(--accent);
}
.cl-text { flex: 1; font-size: 13px; line-height: 1.65; color: var(--cl-text); }
.cl-text strong { font-weight: 700; color: var(--cf-ink); }
.cl-text em { font-style: italic; color: var(--cf-ink-2); }

/* Critical fix callout */
.cl-item--critical {
  display: block; margin: 0 0 14px; padding: 13px 15px;
  background: rgba(201, 100, 66, .06);
  border: 1px solid rgba(201, 100, 66, .4);
  border-left: 3px solid var(--cf-rust);
}
.cl-crit-head { display: inline-flex; align-items: center; gap: 6px; margin-bottom: 9px; }
.cl-crit-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--cf-rust); animation: cl-pulse 1.4s infinite; display: inline-block;
}
.cl-crit-label {
  font-size: 8.5px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--cf-rust);
}

/* Terminus */
.cl-terminus { position: relative; padding-left: 54px; padding-top: 2px; }
.cl-terminus-node {
  position: absolute; left: 1px; top: 0; width: 14px; height: 14px; border-radius: 50%;
  border: 2px solid var(--cf-line); background: var(--cf-page);
  box-shadow: 0 0 0 5px var(--cf-page);
}
.cl-terminus-label {
  font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--cf-ink-4);
}

/* Filtered-out rows/groups are pulled from flow entirely (no fade — the
   design system swaps content instantly). JS sets [hidden]. */
.cl-rel[hidden], .cl-group[hidden] { display: none; }

/* ─── Responsive ──────────────────────────────────────────── */
@media (max-width: 640px) {
  .cl-wrap { padding-inline: 20px; }
  .cl-hero { padding-top: 44px; }
  .cl-title { font-size: 34px; }
  .cl-rel, .cl-terminus { padding-left: 42px; }
}

/* At <=560px the shared header wraps to two rows (variable height), so the
   filter bar can't reliably stick a fixed 52px below it — let it scroll. */
@media (max-width: 560px) {
  .cl-filter { position: static; }
}
