/* ===== CafeVibee Reservations Page Styles ===== */
.reservations-hero {
  background: var(--color-primary);
  color: #fff;
  text-align: left;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  margin-bottom: var(--space-12);
}
.reservations-hero h1 {
  color: #fff;
  margin-top: 0;
}
.reservations-hero p {
  color: #fff;
  font-size: 1.12rem;
}
.reservations-hero .button {
  background: #fff;
  color: var(--color-primary);
  font-weight: 700;
  border: 1.5px solid #fff;
}
.reservations-hero .button:hover {
  background: var(--color-primary-hover);
  color: #fff;
  border-color: #fff;
}

.reservation-section {
  margin-bottom: var(--space-12);
}
.reservation-section h2 {
  margin-bottom: var(--space-4);
}

.reservation-options {
  grid-template-columns: repeat(auto-fit, minmax(265px, 1fr));
  gap: var(--space-6);
  list-style: none;
  padding: 0;
}
.reservation-options li {
  background: var(--color-gray-100);
  padding: var(--space-6);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
}
.reservation-options h3 {
  margin-top: 0;
}

.reservation-process {
  list-style: decimal inside;
  padding-left: 1.3em;
}
.reservation-process li {
  margin-bottom: var(--space-3);
}
.walkin-note {
  color: var(--color-warning);
  font-size: 0.98em;
  display: block;
  margin-top: var(--space-2);
}

.reservation-policies {
  list-style: disc inside;
  padding-left: 1.3em;
  margin-bottom: 0;
}
.reservation-policies li {
  margin-bottom: var(--space-3);
}

.reservation-faqs details {
  margin-bottom: var(--space-4);
  background: var(--color-gray-100);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  box-shadow: var(--shadow-xs);
  font-size: var(--font-size-md);
}
.reservation-faqs summary {
  font-weight: 600;
  cursor: pointer;
  outline: none;
}

.reservation-benefits {
  grid-template-columns: repeat(auto-fit, minmax(265px, 1fr));
  gap: var(--space-6);
  margin-bottom: 0;
  list-style: none;
  padding: 0;
}
.reservation-benefits li {
  background: var(--color-success);
  color: #fff;
  padding: var(--space-6);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}
.benefit-icon {
  font-size: 2rem;
  margin-right: var(--space-3);
}

.reservation-management {
  list-style: disc inside;
  padding-left: 1.3em;
}
.reservation-management li {
  margin-bottom: var(--space-3);
}

.reservation-testimonials {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
}
.testimonial {
  background: var(--color-gray-100);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  padding: var(--space-6) var(--space-6) var(--space-4) var(--space-6);
  font-style: italic;
  margin-bottom: 0;
}
.testimonial footer {
  font-style: normal;
  margin-top: var(--space-3);
  font-size: 0.98em;
  color: var(--color-primary-hover);
}

@media (max-width: 800px) {
  .reservations-hero, .reservation-section, .testimonial {
    padding: var(--space-4);
  }
}
@media (max-width: 600px) {
  .reservations-hero, .reservation-section {
    margin-bottom: var(--space-8);
  }
  .reservation-options, .reservation-benefits, .reservation-testimonials {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}
