/* ═══════════════════════════════════════════════════════════
   BLOG — v3
   ═══════════════════════════════════════════════════════════ */

.blog-header {
  padding: 9rem 3rem 5rem 5rem;
  border-bottom: 1px solid var(--c-border);
  background: var(--c-white);
}

.blog-header__label { color: var(--c-bronze); margin-bottom: 1.5rem; }

.blog-header h1 {
  font-family: var(--f-serif);
  font-size: clamp(2.8rem, 5.5vw, 5.5rem);
  color: var(--c-navy);
  font-weight: 600;
  line-height: 1;
  max-width: 700px;
}

.blog-header p {
  font-family: var(--f-sans);
  font-size: 1rem;
  color: var(--c-mid);
  margin-top: 1.5rem;
  font-weight: 300;
  max-width: 500px;
  line-height: 1.78;
}

.blog-wrap { padding: 5rem 3rem 5rem 5rem; background: var(--c-ivory); }

.blog-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 2rem;
  max-width: 1280px;
}

.card-post {
  background: var(--c-white);
  border: 1px solid var(--c-border);
  transition: border-color 0.2s ease;
  display: flex;
  flex-direction: column;
}
.card-post:hover { border-color: var(--c-navy); }

.card-post__meta {
  display: flex;
  gap: 1rem;
  align-items: center;
  padding: 1.5rem 1.7rem 0;
}

.card-post__cat {
  font-family: var(--f-sans);
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  background: var(--c-navy);
  color: var(--c-white);
  padding: 0.2rem 0.7rem;
}

.card-post__date {
  font-family: var(--f-sans);
  font-size: 0.78rem;
  color: var(--c-mid);
  font-weight: 300;
}

.card-post__body { padding: 1.1rem 1.7rem 2rem; flex: 1; display: flex; flex-direction: column; }

.card-post__title {
  font-family: var(--f-serif);
  font-size: 1.2rem;
  color: var(--c-navy);
  font-weight: 600;
  margin-bottom: 0.85rem;
  line-height: 1.25;
}
.card-post__title a { transition: color 0.2s ease; }
.card-post__title a:hover { color: var(--c-bronze); }

.card-post__excerpt {
  font-family: var(--f-sans);
  font-size: 0.9rem;
  color: var(--c-mid);
  font-weight: 300;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  flex: 1;
}

.card-post__link {
  font-family: var(--f-sans);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-navy);
  border-bottom: 1px solid var(--c-bronze);
  padding-bottom: 2px;
  font-weight: 600;
  align-self: flex-start;
  transition: color 0.2s ease;
}
.card-post__link:hover { color: var(--c-bronze); }

/* Paginazione */
.blog-pagination { margin-top: 3.5rem; display: flex; gap: 0.4rem; align-items: center; }

.blog-pagination .page-numbers {
  font-family: var(--f-sans);
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--c-mid);
  padding: 0.55rem 1rem;
  border: 1px solid var(--c-border);
  transition: all 0.2s ease;
}

.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
  border-color: var(--c-navy);
  background: var(--c-navy);
  color: var(--c-white);
}

@media (max-width: 1100px) { .blog-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 900px)  { .blog-header, .blog-wrap { padding-left: 3rem; } }
@media (max-width: 768px)  {
  .blog-header, .blog-wrap { padding-inline: 1.4rem; }
  .blog-header { padding-top: 6rem; }
  .blog-grid { grid-template-columns: 1fr; }
}
