.coffee-hero {
  padding-top: var(--space-12);
}

.coffee-hero-grid {
  align-items: center;
}

.coffee-hero-content {
  max-width: 36rem;
}

.coffee-hero-lead {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
}

.coffee-hero-actions {
  margin-top: var(--space-4);
  flex-wrap: wrap;
}

.coffee-hero-highlights {
  margin-top: var(--space-4);
  padding-left: 1.1rem;
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.coffee-hero-highlights li + li {
  margin-top: var(--space-1);
}

.coffee-breadcrumb {
  margin-bottom: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.coffee-breadcrumb ol {
  list-style: none;
  padding-left: 0;
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.coffee-breadcrumb li::after {
  content: "/";
  margin-left: var(--space-1);
  color: var(--color-gray-400);
}

.coffee-breadcrumb li:last-child::after {
  content: "";
}

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

.coffee-section-grid {
  align-items: center;
  gap: var(--space-8);
}

.coffee-section-media {
  max-width: 32rem;
  margin: 0 auto;
}

.coffee-subheading {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-2);
}

.coffee-list {
  padding-left: 1.1rem;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.coffee-list li + li {
  margin-top: var(--space-1);
}

.coffee-card {
  height: 100%;
}

.coffee-brand-columns,
.coffee-machine-grid,
.coffee-accessories-grid,
.coffee-sustainability-grid,
.coffee-checkout-grid {
  gap: var(--space-4);
}

.coffee-section-heading {
  max-width: 40rem;
  margin: 0 auto;
}

.coffee-reviews-grid {
  gap: var(--space-6);
}

.review-card .review-meta {
  margin-top: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-gray-500);
}

.coffee-cta-row {
  flex-wrap: wrap;
}

.coffee-privacy-note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.coffee-sustainability-note {
  max-width: 28rem;
}

@media (max-width: 900px) {
  .coffee-hero {
    padding-top: var(--space-10);
  }

  .coffee-section-grid {
    gap: var(--space-6);
  }

  .coffee-hero-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .coffee-cta-row {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 600px) {
  .coffee-hero-content {
    max-width: 100%;
  }

  .coffee-hero-lead {
    font-size: var(--font-size-base);
  }
}
