/* ---------------------------------------------
   Сulinorya – RESERVATIONS PAGE STYLES
---------------------------------------------- */

.reservation-hero {
  margin-top: var(--space-16);
  margin-bottom: var(--space-10);
  text-align: center;
}
.reservation-hero .lead {
  font-size: var(--font-size-lg);
  color: var(--color-gray-700);
  margin-top: var(--space-4);
  margin-bottom: 0;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

.reservation-options .option-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--space-6) var(--space-4);
  text-align: center;
  cursor: pointer;
  min-height: 330px;
}
.reservation-options .option-card img {
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);

  object-fit: cover;
  box-shadow: var(--shadow-sm);
  background: var(--color-gray-100);
}

.reservation-step {
  margin-top: var(--space-12);
  margin-bottom: var(--space-10);
  text-align: left;
}
.reservation-step .reservation-process {
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--space-5);
}
.reservation-step .reservation-process li {
  position: relative;
  background: var(--color-gray-100);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-3);
  padding: var(--space-3) var(--space-4) var(--space-3) var(--space-12);
  font-size: var(--font-size-md);
}
.reservation-step .step-number {
  position: absolute;
  left: var(--space-2);
  top: 50%;
  transform: translateY(-50%);
  background: var(--color-primary);
  color: #fff;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-weight: 600;
  font-size: var(--font-size-md);
  box-shadow: var(--shadow-sm);
}
.reservation-action {
  display: inline-block;
  margin-top: var(--space-4);
}

.reservation-benefits {
  margin-top: var(--space-12);
}
.benefits-list {
  list-style: disc inside;
  max-width: 620px;
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
  padding-left: var(--space-4);
}
.benefits-list li {
  margin-bottom: var(--space-2);
  font-size: var(--font-size-md);
}

.reservation-policies {
  background: var(--color-gray-100);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6);
  margin-top: var(--space-12);
  margin-bottom: var(--space-12);
}
.policies-list dt {
  font-weight: 600;
  margin-top: var(--space-4);
  color: var(--color-primary);
  font-size: var(--font-size-md);
}
.policies-list dd {
  margin-left: var(--space-4);
  margin-bottom: var(--space-3);
  color: var(--color-gray-800);
  font-size: var(--font-size-sm);
}

.reservation-faqs {
  margin-bottom: var(--space-12);
  max-width: 660px;
}
.faqs-list details {
  border-bottom: 1px solid var(--color-gray-200);
  padding: var(--space-2) 0;
  margin-bottom: var(--space-2);
}
.faqs-list summary {
  cursor: pointer;
  font-weight: 600;
  outline: none;
  color: var(--color-primary);
}
.faqs-list details[open] summary {
  color: var(--color-text);
}
.faqs-list p {
  color: var(--color-gray-700);
  margin-top: var(--space-2);
  margin-bottom: var(--space-2);
  font-size: var(--font-size-sm);
}

.reservation-testimonials {
  margin-bottom: var(--space-12);
  margin-top: var(--space-10);
}
.testimonials-list {
  gap: var(--space-8);
}
.testimonial-card {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  font-size: var(--font-size-md);
}
.testimonial-card footer {
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  margin-top: var(--space-3);
  font-style: normal;
  text-align: right;
}

.reservation-gallery {
  margin-bottom: var(--space-12);
}
.reservation-gallery-list {
  gap: var(--space-6);
  margin-top: var(--space-4);
}
.reservation-gallery-list figure {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.reservation-gallery-list img {
  width: 100%;
  height: 95px;
  object-fit: cover;
  border-radius: var(--radius-sm);
}
.reservation-gallery-list figcaption {
  font-size: var(--font-size-xs);
  color: var(--color-gray-700);
  margin-top: var(--space-2);
}

.reservation-contact {
  background: var(--color-gray-100);
  border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6);
  margin-bottom: var(--space-16);
  margin-top: var(--space-6);
  max-width: 760px;
}
.reservation-contact-list {
  list-style: none;
  padding: 0;
  margin-bottom: var(--space-4);
}
.reservation-contact-list li {
  margin-bottom: var(--space-3);
  font-size: var(--font-size-md);
}

@media (max-width: 1100px) {
  .reservation-gallery-list {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 900px) {
  .grid-3 {
    grid-template-columns: 1fr 1fr;
  }
  .reservation-options .option-card {
    min-height: unset;
  }
  .testimonials-list {
    grid-template-columns: 1fr;
  }
  .reservation-gallery-list {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}
@media (max-width: 700px) {
  .reservation-hero {
    margin-top: var(--space-10);
    margin-bottom: var(--space-5);
  }
  .reservation-step, .reservation-policies, .reservation-contact, .reservation-benefits, .reservation-faqs {
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }
  .reservation-policies, .reservation-contact {
    padding: var(--space-5) var(--space-2);
  }
}
