.booking-hero {
  padding-top: var(--space-32);
}

.booking-hero__grid {
  align-items: center;
  gap: var(--space-24);
}

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

.booking-hero__badge {
  margin-bottom: var(--space-8);
}

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

.booking-hero__meta {
  margin-top: var(--space-12);
  max-width: 32rem;
}

.booking-hero__media {
  min-height: 260px;
}

.booking-layout__grid {
  align-items: flex-start;
  gap: var(--space-24);
}

.booking-card {
  height: 100%;
}

.booking-form {
  margin-top: var(--space-12);
}

.booking-form--compact {
  margin-top: var(--space-8);
}

.field-inline-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}

.field-inline {
  flex: 1 1 200px;
}

.booking-form__checkboxes {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.booking-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-soft);
}

.booking-checkbox input[type="checkbox"] {
  margin-top: 0.15rem;
}

.booking-form__submit {
  margin-top: var(--space-4);
}

.booking-form__secure {
  margin-top: var(--space-8);
}

.booking-availability__footer {
  gap: var(--space-16);
  align-items: flex-end;
}

.booking-list {
  display: grid;
  gap: var(--space-8);
}

.booking-list__item {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.booking-faq {
  display: grid;
  gap: var(--space-12);
}

.booking-faq__item h3 {
  font-size: var(--font-size-md);
  margin-bottom: var(--space-4);
}

.booking-faq__item p {
  margin-bottom: 0;
}

.booking-info__grid {
  gap: var(--space-24);
}

.booking-info__item {
  height: 100%;
}

.booking-decor__grid {
  align-items: stretch;
  gap: var(--space-24);
}

.booking-contact__media {
  border-radius: var(--radius-md);
  overflow: hidden;
}

.booking-contact__footer {
  margin-top: var(--space-8);
  gap: var(--space-16);
  align-items: center;
}

.booking-rules {
  display: grid;
  gap: var(--space-4);
  padding-left: 1.25rem;
}

.booking-rules__item {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.booking-terms__card {
  max-width: 880px;
  margin-inline: auto;
}

@media (max-width: 767.98px) {
  .booking-hero {
    padding-top: var(--space-24);
  }

  .booking-hero__media {
    order: -1;
  }

  .booking-hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .booking-layout__grid {
    gap: var(--space-16);
  }

  .booking-contact__footer {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (min-width: 1024px) {
  .booking-hero__media {
    min-height: 320px;
  }
}
