.stats-page {
  max-width: 800px;
  margin: 0 auto;
  padding: 2rem 1.5rem 4rem;
}

.stats-header {
  margin-bottom: 2.5rem;
}

.stats-title {
  font-size: 2rem;
  margin: 0 0 0.4rem;
  color: var(--color-text-primary);
}

.stats-subtitle {
  color: var(--color-text-muted);
  margin: 0;
  font-size: 0.95rem;
}

/* ── Summary cards ── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 1rem;
  margin-bottom: 3rem;
}

.stat-card {
  background: var(--color-bg-secondary);
  border-radius: 14px;
  padding: 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  border: 1px solid var(--color-bg-muted);
  border-left-width: 3px;
  transition: box-shadow 0.25s, transform 0.25s cubic-bezier(0.33, 1, 0.68, 1);
  position: relative;
  overflow: hidden;
}

.stat-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}

.stat-card:hover { transform: translateY(-3px); }
.stat-card:hover::after { opacity: 1; }

/* posts card — red */
.stat-card--posts {
  border-left-color: var(--color-red);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-red) 10%, var(--color-bg-secondary)) 0%,
    var(--color-bg-secondary) 60%
  );
}
.stat-card--posts::after {
  background: radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--color-red) 12%, transparent), transparent 70%);
}
.stat-card--posts:hover { box-shadow: 0 8px 28px color-mix(in srgb, var(--color-red) 22%, transparent); }
.stat-card--posts .stat-card__value { color: var(--color-red); }

/* words card — yellow */
.stat-card--words {
  border-left-color: var(--color-yellow);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-yellow) 12%, var(--color-bg-secondary)) 0%,
    var(--color-bg-secondary) 60%
  );
}
.stat-card--words::after {
  background: radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--color-yellow) 14%, transparent), transparent 70%);
}
.stat-card--words:hover { box-shadow: 0 8px 28px color-mix(in srgb, var(--color-yellow) 22%, transparent); }
.stat-card--words .stat-card__value { color: var(--color-light-yellow); }

/* time card — blue */
.stat-card--time {
  border-left-color: var(--color-blue);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-blue) 12%, var(--color-bg-secondary)) 0%,
    var(--color-bg-secondary) 60%
  );
}
.stat-card--time::after {
  background: radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--color-blue) 14%, transparent), transparent 70%);
}
.stat-card--time:hover { box-shadow: 0 8px 28px color-mix(in srgb, var(--color-blue) 22%, transparent); }
.stat-card--time .stat-card__value { color: var(--color-light-blue, #89c4e1); }

/* tags card — purple */
.stat-card--tags {
  border-left-color: var(--color-purple);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--color-purple) 12%, var(--color-bg-secondary)) 0%,
    var(--color-bg-secondary) 60%
  );
}
.stat-card--tags::after {
  background: radial-gradient(ellipse at 0% 50%, color-mix(in srgb, var(--color-purple) 14%, transparent), transparent 70%);
}
.stat-card--tags:hover { box-shadow: 0 8px 28px color-mix(in srgb, var(--color-purple) 22%, transparent); }
.stat-card--tags .stat-card__value { color: var(--color-light-purple, #c1b6f0); }

.stat-card__value {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
}

.stat-card__unit {
  font-size: 1.2rem;
  opacity: 0.7;
}

.stat-card__label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}

/* ── Section layout ── */
.stats-section {
  margin-bottom: 3rem;
}

.stats-section__title {
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-primary);
  margin: 0 0 1.25rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-bg-muted);
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.stats-section__title::before {
  content: '';
  display: inline-block;
  width: 3px;
  height: 1.1em;
  border-radius: 2px;
  flex-shrink: 0;
}

.stats-section--tags .stats-section__title::before  { background: var(--color-yellow); }
.stats-section--years .stats-section__title::before { background: var(--color-green); }
.stats-section--posts .stats-section__title::before { background: var(--color-pink); }

/* ── Tag bars ── */
.tag-bars,
.year-bars {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.tag-bar,
.year-bar {
  display: grid;
  grid-template-columns: 100px 1fr 2rem;
  align-items: center;
  gap: 0.75rem;
}

.tag-bar__label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.2s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tag-bar__label:hover {
  color: var(--color-text-primary);
}

.tag-bar__track,
.year-bar__track {
  background: var(--color-bg-muted);
  border-radius: 999px;
  height: 8px;
  overflow: hidden;
}

.tag-bar__fill,
.year-bar__fill {
  height: 100%;
  border-radius: 999px;
  width: var(--pct, 0%);
  transition: width 0.8s cubic-bezier(0.33, 1, 0.68, 1);
  animation: bar-grow 0.9s cubic-bezier(0.33, 1, 0.68, 1) both;
}

@keyframes bar-grow {
  from { width: 0; }
  to   { width: var(--pct, 0%); }
}

/* cycle through the palette per tag bar */
.tag-bar:nth-child(1) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-red), color-mix(in srgb, var(--color-red) 55%, var(--color-yellow)));
}
.tag-bar:nth-child(2) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-yellow), var(--color-light-yellow));
}
.tag-bar:nth-child(3) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-green), color-mix(in srgb, var(--color-green) 50%, var(--color-blue)));
}
.tag-bar:nth-child(4) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-blue), var(--color-light-blue, #89c4e1));
}
.tag-bar:nth-child(5) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-pink), color-mix(in srgb, var(--color-pink) 55%, var(--color-purple)));
}
.tag-bar:nth-child(6) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-purple), var(--color-light-purple, #c1b6f0));
}
.tag-bar:nth-child(7) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-light-blue, #89c4e1), var(--color-green));
}
.tag-bar:nth-child(8) .tag-bar__fill {
  background: linear-gradient(90deg, var(--color-red), var(--color-pink));
}

.tag-bar__count,
.year-bar__count {
  font-size: 0.75rem;
  color: var(--color-text-muted);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.year-bar__label {
  font-size: 0.8rem;
  color: var(--color-text-muted);
  white-space: nowrap;
}

.year-bar__fill {
  background: linear-gradient(90deg, var(--color-green), var(--color-light-purple, #c1b6f0));
}

/* ── Post list ── */
.stats-post-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.stats-post-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.6rem 0.5rem 0.6rem 0.75rem;
  border-bottom: 1px solid color-mix(in srgb, var(--color-bg-muted) 60%, transparent);
  border-left: 2px solid transparent;
  transition: border-color 0.2s, background 0.2s;
}

.stats-post-item:last-child {
  border-bottom: none;
}

.stats-post-item:hover {
  background: color-mix(in srgb, var(--color-bg-muted) 30%, transparent);
  border-left-color: var(--color-accent, var(--color-yellow));
}

/* cycle left-border accent per post row */
.stats-post-item:nth-child(6n+1):hover { border-left-color: var(--color-red); }
.stats-post-item:nth-child(6n+2):hover { border-left-color: var(--color-yellow); }
.stats-post-item:nth-child(6n+3):hover { border-left-color: var(--color-green); }
.stats-post-item:nth-child(6n+4):hover { border-left-color: var(--color-blue); }
.stats-post-item:nth-child(6n+5):hover { border-left-color: var(--color-pink); }
.stats-post-item:nth-child(6n+6):hover { border-left-color: var(--color-purple); }

.stats-post-item__title {
  font-size: 0.9rem;
  color: var(--color-text-primary);
  text-decoration: none;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: color 0.2s;
}

.stats-post-item__title:hover {
  color: var(--color-light-yellow);
}

.stats-post-item__meta {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
  align-items: center;
}

.stats-post-item__date {
  font-size: 0.72rem;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  background: color-mix(in srgb, var(--color-blue) 18%, var(--color-bg-muted));
  color: var(--color-light-blue, #89c4e1);
  padding: 0.15em 0.55em;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-blue) 30%, transparent);
}

.stats-post-item__words {
  font-size: 0.72rem;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  background: color-mix(in srgb, var(--color-purple) 14%, var(--color-bg-muted));
  color: var(--color-light-purple, #c1b6f0);
  padding: 0.15em 0.55em;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--color-purple) 28%, transparent);
}

@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .tag-bar,
  .year-bar {
    grid-template-columns: 80px 1fr 1.5rem;
    gap: 0.5rem;
  }

  .stats-post-item {
    flex-direction: column;
    gap: 0.3rem;
  }

  .stats-post-item__title {
    white-space: normal;
  }

  .stats-post-item__meta {
    gap: 0.35rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .tag-bar__fill,
  .year-bar__fill {
    animation: none;
  }
  .stat-card {
    transition: none;
  }
}
