/* ── Post hero image ────────────────────────────────── */
.post-hero {
  height: 460px;
  overflow: hidden;
  background: var(--color-neutral-100);
}

.post-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (max-width: 768px) {
  .post-hero { height: 260px; }
}

/* ── Post layout ─────────────────────────────────────── */
.post-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.5fr) minmax(0, 1fr);
  gap: var(--space-12);
  align-items: start;
  padding-top: var(--space-10);
  padding-bottom: var(--space-16);
}

@media (max-width: 1024px) {
  .post-layout {
    grid-template-columns: 1fr;
  }
  .post-sidebar { display: none; }
}

/* ── Post article ────────────────────────────────────── */
.post-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.post-title {
  font-size: var(--font-size-4xl);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-neutral-900);
}

.post-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.post-meta__date {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-400);
}

.post-meta__sep { color: var(--color-neutral-300); }

.post-meta__read-time {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-400);
}

@media (max-width: 768px) {
  .post-title { font-size: var(--font-size-2xl); }
}

/* ── Author box ──────────────────────────────────────── */
.author-box {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.author-box--compact {
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-neutral-200);
  margin-bottom: var(--space-8);
}

.author-box--full {
  padding: var(--space-6);
  background: var(--color-primary-light);
  border-radius: var(--border-radius-lg);
  margin-top: var(--space-10);
}

.author-box__avatar {
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--color-neutral-200);
}

.author-box--compact .author-box__avatar { width: 44px; height: 44px; }
.author-box--full    .author-box__avatar { width: 72px; height: 72px; }

.author-box__name {
  display: block;
  font-weight: 600;
  color: var(--color-neutral-900);
  font-size: var(--font-size-base);
}

.author-box__role {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--color-neutral-500);
}

.author-box--full .author-box__name { font-size: var(--font-size-lg); margin-bottom: var(--space-1); }

.author-box__bio {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-600, #4B5563);
  line-height: 1.6;
}

/* ── Post body typography ────────────────────────────── */
.post-body {
  font-size: var(--font-size-lg);
  line-height: 1.8;
  color: var(--color-neutral-700);
  margin-bottom: var(--space-10);
}

.post-body h2 {
  font-size: var(--font-size-2xl);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-primary-light);
}

.post-body h3 {
  font-size: var(--font-size-xl);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.post-body p { margin-bottom: var(--space-5); }

.post-body ul,
.post-body ol {
  margin-bottom: var(--space-5);
  padding-left: var(--space-6);
}

.post-body li { margin-bottom: var(--space-2); }

.post-body img {
  width: 100%;
  border-radius: var(--border-radius-lg);
  margin-block: var(--space-6);
}

.post-body blockquote {
  margin-block: var(--space-8);
  padding: var(--space-6);
  border-left: 4px solid var(--color-primary);
  background: var(--color-primary-light);
  border-radius: 0 var(--border-radius) var(--border-radius) 0;
  font-size: var(--font-size-lg);
  font-style: italic;
  color: var(--color-neutral-700);
}

/* ── Share bar ───────────────────────────────────────── */
.share-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-block: var(--space-6);
  border-top: 1px solid var(--color-neutral-200);
  border-bottom: 1px solid var(--color-neutral-200);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}

.share-bar__label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-neutral-500);
}

.share-btn {
  padding: var(--space-2) var(--space-4);
  border-radius: var(--border-radius);
  font-size: var(--font-size-sm);
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid var(--color-neutral-200);
  background: var(--color-white);
  color: var(--color-neutral-700);
  transition: all var(--transition-base);
}

.share-btn:hover { border-color: var(--color-primary); color: var(--color-primary); }
.share-btn:focus-visible { outline: 3px solid var(--color-primary); outline-offset: 2px; }

/* ── Sidebar ─────────────────────────────────────────── */
.post-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

.sidebar-widget {
  background: var(--color-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--border-radius-lg);
  padding: var(--space-6);
}

.sidebar-widget--sticky {
  position: sticky;
  top: calc(var(--header-height) + var(--space-6));
}

.sidebar-widget__title {
  font-family: var(--font-body);
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-4);
}

.sidebar-post-list { display: flex; flex-direction: column; gap: var(--space-4); }

.sidebar-post-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: var(--color-neutral-700);
  font-size: var(--font-size-sm);
  font-weight: 500;
  line-height: 1.4;
  transition: color var(--transition-base);
}

.sidebar-post-item:hover { color: var(--color-primary); }

.sidebar-post-item img {
  width: 56px;
  height: 56px;
  object-fit: cover;
  border-radius: var(--border-radius-sm);
  flex-shrink: 0;
  background: var(--color-neutral-100);
}

/* ── Table of contents ───────────────────────────────── */
.toc__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  border-left: 2px solid var(--color-neutral-200);
  padding-left: var(--space-4);
}

.toc__item--sub { padding-left: var(--space-3); }

.toc__link {
  font-size: var(--font-size-sm);
  color: var(--color-neutral-500);
  text-decoration: none;
  line-height: 1.4;
  display: block;
  transition: color var(--transition-base);
}

.toc__link:hover       { color: var(--color-primary); }
.toc__link--active     { color: var(--color-primary); font-weight: 600; }

/* ── Related posts ───────────────────────────────────── */
.related-posts {
  background: var(--color-neutral-100);
  border-top: 1px solid var(--color-neutral-200);
}
