/* Blog-specific styles. Подключается на страницах /blog/*. */

/* === Список постов на /blog/ === */
.post-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 1rem;
}
.post-list-item { margin: 0; }
.post-link {
  display: block;
  padding: 1.5rem 1.75rem;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: inherit;
  text-decoration: none;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.post-link:hover {
  border-color: var(--line-strong);
  box-shadow: var(--shadow);
  transform: translateY(-1px);
}
.post-date {
  display: block;
  color: var(--quiet);
  font-size: .85rem;
  font-family: var(--font-mono);
}
.post-title {
  margin: .35rem 0 .5rem;
  font-size: 1.4rem;
  line-height: 1.3;
}
.post-desc {
  color: var(--ink-soft);
  margin: 0 0 1rem;
  line-height: 1.55;
}
.post-tags {
  display: flex;
  gap: .4rem;
  flex-wrap: wrap;
}

/* === Тело поста === */
.blog-post {
  font-size: 1.05rem;
  line-height: 1.75;
}
.blog-post h2 {
  margin: 2.25rem 0 1rem;
  font-size: 1.6rem;
}
.blog-post h3 {
  margin: 1.75rem 0 .75rem;
  font-size: 1.25rem;
}
.blog-post p { margin: 0 0 1rem; }
.blog-post ul, .blog-post ol { margin: 0 0 1.25rem; padding-left: 1.5rem; }
.blog-post li { margin: .35rem 0; }
.blog-post img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius);
  margin: 1.5rem 0;
  border: 1px solid var(--line);
}
.blog-post pre {
  background: var(--dark);
  color: var(--dark-text);
  padding: 1rem 1.25rem;
  border-radius: var(--radius);
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: .9rem;
  line-height: 1.6;
  margin: 1.25rem 0;
}
.blog-post code {
  font-family: var(--font-mono);
  font-size: .9em;
  background: var(--surface-soft);
  padding: .1em .35em;
  border-radius: 4px;
}
.blog-post pre code {
  background: transparent;
  padding: 0;
  color: inherit;
}
.blog-post blockquote {
  border-left: 3px solid var(--accent);
  padding-left: 1rem;
  margin: 1.25rem 0;
  color: var(--ink-soft);
  font-style: italic;
}
.blog-post a:not(.wikilink) {
  color: var(--accent-strong);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

/* === Wikilinks (внутренние ссылки на кейсы) === */
.wikilink {
  color: var(--blue);
  background: var(--blue-soft);
  padding: .05em .35em;
  border-radius: 4px;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .15s ease;
}
.wikilink:hover {
  border-bottom-color: var(--blue);
}
.wikilink-broken {
  color: var(--red);
  background: var(--red-soft);
  text-decoration: line-through wavy;
  cursor: not-allowed;
}

/* === Блок «Связанные кейсы» === */
.related-cases {
  background: var(--surface-soft);
  padding: 1.5rem 1.75rem;
  border-radius: var(--radius);
  margin-top: 2.5rem;
}
.related-cases h3 {
  margin: 0 0 .75rem;
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted);
}
.related-cases ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.related-cases li {
  margin: .4rem 0;
}
.related-cases a {
  color: var(--accent-strong);
  text-decoration: none;
  font-weight: 500;
}
.related-cases a:hover {
  text-decoration: underline;
}

/* === Пустой блог === */
.empty {
  text-align: center;
  color: var(--muted);
  padding: 3rem 0;
}
