.restaurant-hero {
  position: relative;
}

.restaurant-hero-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
}

.restaurant-hero-content {
  max-width: 640px;
}

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

.restaurant-hero-media {
  min-height: 280px;
}

.restaurant-hero-meta {
  font-size: var(--font-size-sm);
}

.restaurant-two-col {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: var(--space-8);
  align-items: center;
}

.restaurant-image-card {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.restaurant-section-header {
  max-width: 720px;
  margin: 0 auto;
}

.restaurant-list {
  list-style: none;
  padding-left: 0;
}

.restaurant-list li {
  position: relative;
  padding-left: 1.5rem;
  margin-bottom: var(--space-2);
  color: var(--color-text-muted);
}

.restaurant-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55rem;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-primary);
}

.restaurant-list--ordered {
  counter-reset: restaurant-counter;
}

.restaurant-list--ordered li {
  padding-left: 2rem;
}

.restaurant-list--ordered li::before {
  counter-increment: restaurant-counter;
  content: counter(restaurant-counter) ".";
  width: auto;
  height: auto;
  background: transparent;
  color: var(--color-primary);
  font-weight: 600;
}

.restaurant-signature-grid {
  gap: var(--space-6);
}

.restaurant-signature-title {
  font-size: var(--font-size-lg);
}

.restaurant-evening-card {
  height: 100%;
}

.restaurant-evening-image {
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.restaurant-dessert-card {
  height: 100%;
}

.restaurant-testimonials {
  display: flex;
  flex-direction: column;
}

.restaurant-testimonials-author {
  margin-top: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.restaurant-info-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
}

.restaurant-info-title {
  font-size: var(--font-size-lg);
}

.restaurant-cta-card {
  align-self: stretch;
}

@media (max-width: 1024px) {
  .restaurant-hero-grid,
  .restaurant-two-col {
    grid-template-columns: 1fr;
  }

  .restaurant-hero-media {
    order: -1;
  }
}

@media (max-width: 768px) {
  .restaurant-info-grid {
    grid-template-columns: 1fr;
  }

  .restaurant-hero-ctas .btn {
    flex: 1 1 100%;
  }
}
