/* ───────────────────────────────────────────────────────────────
   Blog / Journal page
   ─────────────────────────────────────────────────────────────── */

.blog-hero {
  padding: calc(var(--nav-h) + clamp(64px, 9vw, 128px)) clamp(24px, 3.5vw, 56px) clamp(48px, 6vw, 80px);
  background: var(--cream);
}
.blog-hero__eyebrow {
  font-size: 0.6875rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--greige);
  margin-bottom: clamp(24px, 3vw, 40px);
  display: block;
}
.blog-hero h1 {
  font-family: var(--font-display);
  font-weight: 200;
  font-size: var(--fs-hero);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.blog-hero h1 em { font-style: italic; }

/* Featured article */
.blog-featured {
  padding: 0 clamp(24px, 3.5vw, 56px) clamp(80px, 10vw, 120px);
  background: var(--cream);
}
.blog-featured__inner {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: center;
}
.blog-featured__media {
  aspect-ratio: 3/2;
  overflow: hidden;
}
.blog-featured__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-out);
}
.blog-featured__card:hover .blog-featured__media img { transform: scale(1.04); }
.blog-featured__meta {
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--greige);
  margin-bottom: 24px;
  display: flex; gap: 16px;
}
.blog-featured__title {
  font-family: var(--font-display);
  font-weight: 200;
  font-size: clamp(2rem, 4vw, 3.5rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  max-width: 18ch;
}
.blog-featured__title em { font-style: italic; }
.blog-featured__excerpt {
  font-size: var(--fs-body); line-height: 1.65;
  max-width: 460px;
  margin-bottom: 32px;
  color: var(--dark);
}
.blog-featured__card {
  display: contents; color: inherit;
}

/* Article grid */
.blog-grid {
  padding: clamp(64px, 8vw, 100px) clamp(24px, 3.5vw, 56px);
  background: var(--cream);
  border-top: 1px solid var(--rule);
}
.blog-grid__head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: clamp(40px, 5vw, 64px);
  gap: 32px;
}
.blog-grid__head h2 {
  font-family: var(--font-display);
  font-weight: 200;
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.blog-grid__head h2 em { font-style: italic; }
/* Category filters */
.blog-filters {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-bottom: clamp(32px, 4vw, 48px);
}
.blog-filter {
  font-family: var(--font-body);
  font-size: 0.75rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--greige);
  padding: 8px 16px;
  border: 1px solid var(--rule-dark);
  border-radius: 100px;
  cursor: pointer;
  transition: color 0.2s, background 0.2s, border-color 0.2s;
  background: transparent;
}
.blog-filter:hover { color: var(--dark); border-color: var(--dark); }
.blog-filter.is-active {
  color: var(--cream);
  background: var(--dark);
  border-color: var(--dark);
}

.blog-grid__list {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 48px);
}
.blog-card { display: block; color: inherit; }
.blog-card__media {
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--cream-2);
  margin-bottom: 20px;
}
.blog-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-out);
}
.blog-card:hover .blog-card__media img { transform: scale(1.04); }
.blog-card__meta {
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--greige);
  margin-bottom: 12px;
  display: flex; gap: 16px;
}
.blog-card__title {
  font-family: var(--font-display);
  font-weight: 200;
  font-size: 1.5rem;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 12px;
  max-width: 22ch;
}
.blog-card__title em { font-style: italic; }
.blog-card__excerpt {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--greige); /* D5: rimozione opacity hack */
}

/* Newsletter strip */
.blog-newsletter {
  background: var(--cream);
  color: var(--dark);
  padding: clamp(96px, 12vw, 160px) clamp(24px, 3.5vw, 56px);
  border-top: 1px solid var(--rule-dark);
}
.blog-newsletter__inner {
  display: grid; grid-template-columns: 1.3fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: end;
}
.blog-newsletter__title {
  font-family: var(--font-display);
  font-weight: 200;
  font-size: var(--fs-hero);
  line-height: 1.02;
  letter-spacing: -0.02em;
  max-width: 14ch;
}
.blog-newsletter__title em { font-style: italic; }
.blog-newsletter__form {
  display: flex; flex-direction: column; gap: 16px;
}
.blog-newsletter__form p {
  font-size: 0.875rem; line-height: 1.6;
  color: var(--greige);
  margin-bottom: 8px;
}
.blog-newsletter__field {
  display: flex;
  border-bottom: 1px solid var(--rule-dark);
  align-items: center;
}
.blog-newsletter__field input {
  flex: 1;
  background: transparent;
  border: 0;
  padding: 16px 0;
  color: var(--dark);
  font: inherit;
  font-size: 0.9375rem;
  outline: none;
}
.blog-newsletter__field input::placeholder { color: var(--greige); }
.blog-newsletter__field button {
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--dark);
  padding: 12px 0;
  cursor: pointer;
}

@media (max-width: 1024px) {
  .blog-featured__inner { grid-template-columns: 1fr; gap: 32px; }
  .blog-grid__list { grid-template-columns: 1fr 1fr; }
  .blog-newsletter__inner { grid-template-columns: 1fr; gap: 32px; align-items: start; }
}
@media (max-width: 768px) {
  .blog-grid__list { grid-template-columns: 1fr; }
  .blog-grid__head { flex-direction: column; align-items: flex-start; gap: 16px; }
}
