.restaurant-hero {
  position: relative;
}

.restaurant-hero__grid {
  display: grid;
  gap: var(--space-20);
}

@media (min-width: 992px) {
  .restaurant-hero__grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    align-items: center;
  }
}

.restaurant-hero__content p {
  max-width: 34rem;
}

.restaurant-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin-top: var(--space-16);
  margin-bottom: var(--space-16);
}

.restaurant-hero__media {
  position: relative;
}

.restaurant-hero__badge {
  position: absolute;
  left: 8%;
  bottom: 8%;
}

.restaurant-hero__badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--color-gold);
}

.restaurant-hero__highlights {
  display: grid;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

@media (min-width: 768px) {
  .restaurant-hero__highlights {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.restaurant-hero__highlight-item dt {
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--gray-500);
  margin-bottom: var(--space-3);
}

.restaurant-hero__highlight-item dd {
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.restaurant-section {
  display: flex;
  flex-direction: column;
  gap: var(--space-20);
}

.restaurant-section--split {
  gap: var(--space-24);
}

@media (min-width: 992px) {
  .restaurant-section--split {
    flex-direction: row;
    align-items: center;
  }

  .restaurant-section--reverse {
    flex-direction: row-reverse;
  }
}

.restaurant-section__content {
  flex: 1 1 0;
}

.restaurant-section__content--narrow {
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
}

.restaurant-section__sidecard {
  flex: 0 0 320px;
}

@media (max-width: 991.98px) {
  .restaurant-section__sidecard {
    flex: 1 1 auto;
  }
}

.restaurant-section__media-group {
  flex: 1 1 0;
}

.restaurant-section__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
  margin-top: var(--space-12);
}

.restaurant-figure {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.restaurant-figure__caption {
  font-size: var(--font-size-sm);
  color: var(--gray-500);
}

.restaurant-highlights {
  display: grid;
  gap: var(--space-12);
  margin-top: var(--space-12);
}

@media (min-width: 768px) {
  .restaurant-highlights {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.restaurant-highlight__title {
  font-size: var(--font-size-base);
  font-weight: 600;
  margin-bottom: var(--space-4);
}

.restaurant-bullets {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-8);
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.restaurant-bullets li::before {
  content: "•";
  margin-right: var(--space-4);
  color: var(--color-primary);
}

.restaurant-grid-3 {
  display: grid;
  gap: var(--space-12);
}

@media (min-width: 768px) {
  .restaurant-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.restaurant-grid-2 {
  display: grid;
  gap: var(--space-12);
}

@media (min-width: 768px) {
  .restaurant-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.restaurant-card-mini {
  padding: var(--space-16);
}

.restaurant-subtitle {
  font-size: var(--font-size-base);
  font-weight: 600;
  margin-bottom: var(--space-4);
}

.restaurant-testimonial blockquote {
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
  margin-bottom: var(--space-8);
}

.restaurant-testimonial__name {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 600;
}

.restaurant-testimonial__meta {
  display: block;
  font-size: var(--font-size-xs);
  color: var(--gray-500);
}

.restaurant-link-soft {
  font-size: var(--font-size-sm);
}

.restaurant-link-soft::after {
  bottom: -0.1em;
}

.restaurant-cta {
  background: radial-gradient(circle at top left, rgba(34, 184, 199, 0.12), transparent 55%), var(--color-surface);
}

.restaurant-section--cta {
  justify-content: center;
}

.restaurant-section__content--cta {
  max-width: 44rem;
  text-align: center;
}

.restaurant-cta__note {
  margin-top: var(--space-8);
  font-size: var(--font-size-sm);
  color: var(--gray-600);
}

.restaurant-cta__note a {
  font-weight: 500;
}
