/* Booking Page Specific Styles */

/* Hero Section */
.booking-hero {
  position: relative;
  background-color: var(--color-primary-dark);
  color: var(--color-surface);
  padding: var(--space-16) 0;
  overflow: hidden;
}

.booking-hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.booking-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.booking-hero-bg .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(41, 50, 65, 0.95), rgba(41, 50, 65, 0.7));
}

.booking-hero .container {
  position: relative;
  z-index: 1;
}

.hero-content h1 {
  color: var(--color-surface);
  margin-bottom: var(--space-4);
}

.hero-content p {
  font-size: var(--font-size-xl);
  color: #cbd5e0;
  max-width: 600px;
}

/* Layout Grid */
.section-padding {
  padding: var(--space-12) 0;
}

.booking-layout {
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 992px) {
  .booking-layout {
    grid-template-columns: 2fr 1fr;
  }
}

/* Form Styles */
.booking-form-wrapper {
  background: var(--color-surface);
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
}

.form-section {
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}

.form-section:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

/* Service Selection Cards */
.service-selection {
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space-4);
}

.service-option {
  cursor: pointer;
  position: relative;
}

.service-option input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.option-content {
  display: block;
  padding: var(--space-4);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  background-color: var(--color-background);
}

.option-title {
  display: block;
  font-weight: 700;
  color: var(--color-primary-dark);
  margin-bottom: var(--space-1);
}

.option-desc {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--color-text-light);
}

.service-option input:checked + .option-content {
  border-color: var(--color-accent);
  background-color: rgba(42, 157, 143, 0.05);
  box-shadow: 0 0 0 2px rgba(42, 157, 143, 0.1);
}

.service-option:hover .option-content {
  border-color: var(--color-primary);
}

/* Vehicle Grid */
.grid-cols-2 {
  grid-template-columns: 1fr;
}

@media (min-width: 600px) {
  .grid-cols-2 {
    grid-template-columns: 1fr 1fr;
  }
}

.full-width {
  grid-column: 1 / -1;
}

.full-width-btn {
  width: 100%;
}

/* Calendar Mockup */
.calendar-mockup {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  background: #fff;
}

.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
  font-weight: 700;
}

.btn-nav {
  background: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  cursor: pointer;
}

.calendar-dates {
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}

.date-slot {
  padding: 8px;
  background: var(--color-background);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition-base);
}

.date-slot:hover:not(.disabled) {
  background: var(--color-border);
}

.date-slot.active {
  background-color: var(--color-primary);
  color: #fff;
}

.date-slot.disabled {
  color: var(--color-text-light);
  opacity: 0.5;
  cursor: not-allowed;
}

.time-slots {
  grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
  gap: var(--space-2);
}

.time-radio {
  display: block;
  padding: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  text-align: center;
  cursor: pointer;
  font-size: var(--font-size-sm);
}

.time-radio input {
  margin-right: 4px;
}

/* Sidebar Styles */
.booking-sidebar h3 {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-2);
}

.booking-sidebar h4 {
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  margin-bottom: var(--space-2);
}

.card-img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.rounded {
  border-radius: var(--radius-md);
}

.text-danger {
  color: var(--color-danger);
}

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