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

.booking-hero__inner {
  display: grid;
  gap: var(--space-24);
}

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

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

.booking-hero__panel {
  margin-top: var(--space-16);
}

.booking-hero__visual {
  min-height: 220px;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  background: radial-gradient(circle at 20% 20%, rgba(90, 143, 184, 0.18), transparent 55%),
              radial-gradient(circle at 80% 80%, rgba(76, 147, 131, 0.22), transparent 55%),
              linear-gradient(145deg, #f9fafb, #e0f1ec);
}

.booking-section-header {
  max-width: 720px;
  margin-bottom: var(--space-24);
}

.booking-section-header--center {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.booking-calendar-grid {
  align-items: flex-start;
}

.booking-calendar__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.booking-calendar__card {
  margin-bottom: var(--space-16);
}

.booking-calendar__note {
  font-size: var(--font-size-sm);
}

.booking-filter-form {
  display: grid;
  gap: var(--space-10);
}

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

.booking-steps {
  display: grid;
  gap: var(--space-16);
}

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

.booking-step {
  padding: var(--space-16);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  box-shadow: var(--shadow-xs);
}

.booking-types-grid {
  margin-top: var(--space-16);
}

.booking-type-card {
  height: 100%;
}

.booking-type-list,
.booking-price-list,
.booking-policy-list,
.booking-confirmation-list,
.booking-devices-list,
.booking-support-list {
  list-style: disc;
  padding-left: var(--space-16);
}

.booking-types-cta,
.booking-pricing-cta {
  margin-top: var(--space-16);
  font-size: var(--font-size-sm);
  text-align: center;
}

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

.booking-instructors__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.booking-pricing-grid {
  margin-top: var(--space-16);
}

.booking-price-card {
  height: 100%;
}

.booking-policy-grid,
.booking-confirmation-grid,
.booking-devices-grid,
.booking-support-grid {
  align-items: flex-start;
  gap: var(--space-24);
}

.booking-policy-panel {
  margin-top: var(--space-16);
  font-size: var(--font-size-sm);
}

.booking-faq {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  gap: var(--space-10);
}

.booking-faq-item {
  padding: var(--space-12) var(--space-16);
  border-radius: var(--radius-md);
  background-color: var(--color-surface);
  box-shadow: var(--shadow-xs);
}

.booking-faq-item summary {
  cursor: pointer;
  font-weight: 500;
}

.booking-faq-item summary::-webkit-details-marker {
  display: none;
}

.booking-faq-item summary::after {
  content: "+";
  float: right;
  font-weight: 400;
}

.booking-faq-item[open] summary::after {
  content: "–";
}

.booking-faq-item p {
  margin-top: var(--space-8);
  font-size: var(--font-size-sm);
}

.booking-devices__image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}

.booking-support-cta {
  display: flex;
  align-items: stretch;
}

.booking-support-cta .card {
  width: 100%;
}

.booking-support-cta__actions {
  margin-top: var(--space-16);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10);
}

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

  .booking-hero__visual {
    min-height: 160px;
  }
}
