/* ── Container ─────────────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

/* ── Typography ─────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  line-height: 1.25;
  color: var(--color-neutral-900);
}

h1 { font-size: var(--font-size-4xl); }
h2 { font-size: var(--font-size-3xl); }
h3 { font-size: var(--font-size-2xl); }
h4 { font-size: var(--font-size-xl); }

@media (max-width: 768px) {
  h1 { font-size: var(--font-size-3xl); }
  h2 { font-size: var(--font-size-2xl); }
  h3 { font-size: var(--font-size-xl); }
}

p { line-height: 1.7; color: var(--color-neutral-700); }

/* ── Section header ─────────────────────────────────── */
.section {
  padding-block: var(--space-16);
}

.section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
}

.section__title {
  font-size: var(--font-size-2xl);
  font-weight: 700;
}

.section__header-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* ── Link arrow ─────────────────────────────────────── */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-primary);
  white-space: nowrap;
  transition: gap var(--transition-base), color var(--transition-base);
}

.link-arrow:hover {
  color: var(--color-primary-dark);
  gap: var(--space-2);
}

/* ── Breadcrumb ─────────────────────────────────────── */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-neutral-400);
  flex-wrap: wrap;
}

.breadcrumb li:not(:last-child)::after {
  content: '›';
  margin-left: var(--space-2);
  color: var(--color-neutral-400);
}

.breadcrumb a {
  color: var(--color-neutral-500);
  transition: color var(--transition-base);
}

.breadcrumb a:hover { color: var(--color-primary); }

.breadcrumb [aria-current="page"] { color: var(--color-neutral-900); font-weight: 500; }

/* ── Posts grid ─────────────────────────────────────── */
.posts-grid {
  display: grid;
  gap: var(--space-6);
}

.posts-grid--3 { grid-template-columns: repeat(3, 1fr); }
.posts-grid--4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
  .posts-grid--4 { grid-template-columns: repeat(2, 1fr); }
  .posts-grid--3 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .posts-grid--3,
  .posts-grid--4 { grid-template-columns: 1fr; }
}

/* ── Lazy image fade-in ─────────────────────────────── */
img[data-src] { opacity: 0; transition: opacity var(--transition-slow); }
img.img--loaded { opacity: 1; }
img:not([data-src]) { opacity: 1; }
