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

.booking-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.4fr);
  gap: var(--grid-gap);
  align-items: center;
}

@media (max-width: 900px) {
  .booking-hero-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-hero-copy h1 {
  margin-top: var(--space-4);
}

.booking-hero-highlight {
  display: inline-block;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.booking-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.booking-hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.booking-hero-panel {
  max-width: 430px;
  margin-left: auto;
}

.booking-hero-card {
  padding: var(--space-6);
}

.booking-mini-steps {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.booking-mini-steps h3 {
  font-size: var(--font-size-sm);
  margin-bottom: var(--space-1);
}

.booking-mini-steps p {
  margin-bottom: 0;
  font-size: var(--font-size-sm);
}

.booking-mini-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(184, 255, 59, 0.8);
  font-size: var(--font-size-xs);
  margin-right: var(--space-3);
}

.booking-mini-cta {
  width: 100%;
}

.booking-section-header {
  max-width: 720px;
  margin-inline: auto;
}

.booking-section-header p {
  margin-top: var(--space-3);
}

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

.booking-step-card .card-body {
  font-size: var(--font-size-sm);
}

.booking-list {
  list-style: none;
  padding: 0;
  margin: var(--space-3) 0 0;
}

.booking-list li {
  position: relative;
  padding-left: 1.4rem;
  margin-bottom: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.booking-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.4rem;
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: radial-gradient(circle, var(--color-primary) 0%, transparent 70%);
  box-shadow: var(--shadow-neon-lime);
}

.booking-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.4fr) minmax(0, 3fr);
  gap: var(--grid-gap);
  align-items: flex-start;
}

@media (max-width: 900px) {
  .booking-form-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

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

.booking-form-benefits {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0 var(--space-4);
}

.booking-form-benefits li {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}

.booking-form-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
}

@media (max-width: 600px) {
  .booking-form-grid-2 {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-format-fieldset {
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}

.booking-format-fieldset .label {
  margin-bottom: var(--space-3);
}

.booking-format-options {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

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

.booking-checkbox input {
  margin-top: 0.25rem;
}

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

.booking-package-card .card-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.booking-package-note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-3);
}

.booking-availability-layout {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.2fr);
  gap: var(--grid-gap);
  align-items: flex-start;
}

@media (max-width: 900px) {
  .booking-availability-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-availability-list {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0 var(--space-4);
}

.booking-availability-list li {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}

.booking-availability-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.booking-calendar-card {
  padding: var(--space-5);
}

.booking-calendar-note {
  font-size: var(--font-size-xs);
}

.booking-calendar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-4);
}

@media (max-width: 600px) {
  .booking-calendar-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.booking-calendar-day {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.booking-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  padding-inline: 0.5rem;
  padding-block: 0.2rem;
  border: 1px solid transparent;
}

.booking-dot-free {
  border-color: rgba(184, 255, 59, 0.7);
  background-color: var(--color-primary-soft);
}

.booking-dot-medium {
  border-color: rgba(241, 196, 15, 0.9);
  background-color: rgba(241, 196, 15, 0.12);
}

.booking-dot-busy {
  border-color: rgba(231, 76, 60, 0.9);
  background-color: rgba(231, 76, 60, 0.07);
}

.booking-calendar-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.booking-calendar-legend span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.booking-calendar-legend .booking-dot {
  width: 0.9rem;
  height: 0.9rem;
  padding: 0;
}

.booking-locations-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 3fr);
  gap: var(--grid-gap);
  align-items: center;
}

@media (max-width: 900px) {
  .booking-locations-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

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

.booking-personalization-card .card-body {
  font-size: var(--font-size-sm);
}

.booking-testimonials-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.4fr) minmax(0, 3fr);
  gap: var(--grid-gap);
  align-items: center;
}

@media (max-width: 900px) {
  .booking-testimonials-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-testimonials-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.booking-testimonial-card .card-body {
  font-size: var(--font-size-sm);
}

.booking-testimonial-meta {
  margin-top: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.booking-team-layout {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.4fr);
  gap: var(--grid-gap);
  align-items: center;
}

@media (max-width: 900px) {
  .booking-team-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-team-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-4);
}

@media (max-width: 900px) {
  .booking-team-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-team-card .card-body {
  font-size: var(--font-size-sm);
}

.booking-faq-grid {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2.4fr);
  gap: var(--grid-gap);
  margin-top: var(--space-8);
}

@media (max-width: 900px) {
  .booking-faq-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.booking-faq-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.booking-final-cta-content {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  align-items: flex-start;
}

.booking-final-cta-text {
  flex: 2 1 320px;
}

.booking-final-cta-text p {
  margin-top: var(--space-3);
}

.booking-final-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.booking-final-cta-links {
  flex: 1 1 200px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--font-size-xs);
}

.booking-final-cta-links a {
  color: var(--color-text-muted);
}

.booking-final-cta-links a:hover {
  color: var(--color-primary);
  transform: translateX(2px);
}
