/* ============================================
   CHANGELOG PAGE — Vertical timeline
   Loaded only on the changelog page.
   ============================================ */

/* ─── Page header (back link + language switcher) ──────────────────────── */

.changelog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  max-width: var(--max-w-xl);
  margin: 0 auto;
  width: 100%;
}

.changelog-back {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: #ffffff;
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
  transition: color 200ms ease, opacity 200ms ease;
}

.changelog-back:hover {
  color: rgba(255, 255, 255, 0.85);
  opacity: 0.9;
}


/* ─── Main content wrapper ────────────────────────────────────────────── */

.changelog-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-8) var(--space-6);
  padding-bottom: var(--space-16);
  max-width: var(--max-w-md);
  margin: 0 auto;
  width: 100%;
}

.changelog-divider {
  width: 64px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  margin-bottom: var(--space-12);
}

.changelog-title {
  font-family: var(--font-sans);
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  line-height: 1.1;
  letter-spacing: var(--tracking-tight);
  color: #ffffff;
  margin-bottom: var(--space-4);
  text-align: center;
}

.changelog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: var(--font-light);
  line-height: var(--leading-relaxed);
  color: rgba(255, 255, 255, 0.6);
  text-align: center;
  margin-bottom: var(--space-12);
  max-width: 44ch;
}


/* ─── Timeline layout ─────────────────────────────────────────────────── */

.changelog-timeline {
  position: relative;
  width: 100%;
}

.changelog-line {
  position: absolute;
  left: 19px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    180deg,
    transparent 0%,
    color-mix(in srgb, var(--c-glass) 40%, transparent) 5%,
    color-mix(in srgb, var(--c-glass) 40%, transparent) 95%,
    transparent 100%
  );
  border-radius: 1px;
}

.changelog-milestone {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  margin-bottom: var(--space-10);
  padding-left: 0;
}

.changelog-milestone:last-of-type {
  margin-bottom: var(--space-12);
}

.changelog-node {
  flex-shrink: 0;
  width: 12px;
  height: 12px;
  margin-top: var(--space-3);
  margin-left: 13px;
  border-radius: 50%;
  background: var(--color-primary, #2563eb);
  border: 2px solid color-mix(in srgb, var(--c-light) 30%, transparent);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--c-dark) 15%, transparent);
}

.changelog-node-future {
  background: var(--color-gray-500, #737373);
  border-color: color-mix(in srgb, var(--c-glass) 50%, transparent);
}

.changelog-card {
  flex: 1;
  min-width: 0;
  padding: var(--space-6);
  margin-left: 0;
}

.changelog-card-title {
  font-family: var(--font-sans);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: #ffffff;
  margin-bottom: var(--space-3);
  line-height: var(--leading-tight);
}

.changelog-card-desc {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-light);
  line-height: var(--leading-relaxed);
  color: rgba(255, 255, 255, 0.65);
  margin: 0;
}

.changelog-badge {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-primary-light, #60a5fa);
  margin-bottom: var(--space-2);
}


/* ─── Future section ──────────────────────────────────────────────────── */

.changelog-future {
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid color-mix(in srgb, var(--c-glass) 25%, transparent);
}

.changelog-future-heading {
  font-family: var(--font-sans);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: #ffffff;
  margin-bottom: var(--space-8);
  text-align: center;
}

.changelog-milestone-future .changelog-card-title {
  font-size: var(--text-lg);
}


/* ─── Footer on changelog page ─────────────────────────────────────────── */

.changelog-footer {
  padding-top: var(--space-8);
}


/* ─── Responsive ──────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .changelog-header {
    padding: var(--space-3) var(--space-4);
  }

  .changelog-page {
    padding: var(--space-6) var(--space-4);
    padding-bottom: var(--space-12);
  }

  .changelog-title {
    font-size: var(--text-3xl);
  }

  .changelog-subtitle {
    font-size: var(--text-base);
    margin-bottom: var(--space-10);
  }

  .changelog-milestone {
    gap: var(--space-4);
    margin-bottom: var(--space-8);
  }

  .changelog-line {
    left: 15px;
  }

  .changelog-node {
    width: 10px;
    height: 10px;
    margin-left: 10px;
    margin-top: var(--space-2);
  }

  .changelog-card {
    padding: var(--space-4);
  }

  .changelog-card-title {
    font-size: var(--text-lg);
  }

  .changelog-card-desc {
    font-size: var(--text-sm);
  }
}
