/* Blog — reuses the design tokens from css/style.css */

.blog-list { list-style: none; padding-left: 0; }
.blog-row { padding: 0.85rem 0; border-bottom: 1px solid var(--border-default); }
.blog-row-link { display: flex; gap: 0.75rem; align-items: baseline; }
.blog-date { color: var(--text-muted); font-size: 0.85em; white-space: nowrap; }
.blog-row-title { color: var(--accent-cyan); font-weight: 500; }
.blog-summary { color: var(--text-secondary); margin: 0.25rem 0 0.35rem; font-size: 0.92em; }
.blog-row-tags { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.blog-tag {
  background-color: color-mix(in srgb, var(--accent-cyan), transparent 88%);
  color: var(--accent-cyan); padding: 0.05rem 0.4rem; border-radius: 4px; font-size: 0.78em;
}

.blog-filters { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 1.25rem; }
.blog-filter {
  background: transparent; border: 1px solid var(--border-default); color: var(--text-secondary);
  font-family: inherit; font-size: 0.82em; padding: 0.15rem 0.55rem; border-radius: 4px; cursor: pointer;
  transition: color 0.2s ease, border-color 0.2s ease;
}
.blog-filter:hover { color: var(--accent-green); }
.blog-filter.is-active { color: var(--accent-green); border-color: var(--accent-green); }

.blog-empty, .blog-error { color: var(--text-muted); }
.blog-error { color: var(--accent-amber); }

@media (max-width: 767px) {
  .blog-row-link { flex-direction: column; gap: 0.15rem; }
}

/* Single post */
.post-title { color: var(--text-primary); margin-bottom: 0.25rem; }
.post-meta { margin-bottom: 1.75rem; display: flex; gap: 0.5rem; align-items: baseline; flex-wrap: wrap; }
.post-body { color: var(--text-primary); line-height: 1.7; }
.post-body h1, .post-body h2, .post-body h3 { color: var(--accent-cyan); margin-top: 2rem; }
.post-body a { color: var(--accent-link); }
.post-body blockquote {
  border-left: 3px solid var(--accent-purple); margin: 1rem 0; padding: 0.25rem 0 0.25rem 1rem;
  color: var(--text-secondary);
}
.post-body table { border-collapse: collapse; margin: 1rem 0; width: 100%; }
.post-body th, .post-body td { border: 1px solid var(--border-default); padding: 0.4rem 0.7rem; text-align: left; }
.post-body th { color: var(--accent-amber); }
.post-body img { max-width: 100%; border-radius: 8px; }
.post-body code:not(pre code) {
  background: color-mix(in srgb, var(--accent-cyan), transparent 90%);
  color: var(--accent-cyan); padding: 0.05rem 0.3rem; border-radius: 4px; font-size: 0.9em;
}
.post-body pre {
  background: var(--bg-titlebar); border: 1px solid var(--border-default); border-radius: 8px;
  padding: 1rem; overflow-x: auto; margin: 1rem 0;
}
.post-body pre code { background: none; padding: 0; font-size: 0.88em; }

/* highlight.js tokens mapped to the Deep Ocean palette */
.hljs { color: var(--text-primary); background: transparent; }
.hljs-comment, .hljs-quote { color: var(--text-muted); font-style: italic; }
.hljs-keyword, .hljs-selector-tag, .hljs-built_in, .hljs-type { color: var(--accent-purple); }
.hljs-string, .hljs-attr { color: var(--accent-green); }
.hljs-number, .hljs-literal { color: var(--accent-amber); }
.hljs-title, .hljs-function .hljs-title, .hljs-section { color: var(--accent-cyan); }
.hljs-meta { color: var(--text-secondary); }

.blog-404 { color: var(--accent-amber); background: var(--bg-titlebar); border: 1px solid var(--border-default); border-radius: 8px; padding: 1rem; }
