/* css/booking-panel.css */
:root {
  --bg: #050505;
  --panel: #0d0d0f;
  --panel-2: #111113;
  --card: #141417;
  --line: #26262b;
  --line-strong: #34343a;
  --text: #fafafa;
  --muted: #a1a1aa;
  --primary: #818cf8;
  --primary-strong: #6366f1;
  --success: #22c55e;
  --danger: #ef4444;
  --info: #60a5fa;
}

.booking-layout {
  position: relative;
  min-height: 100vh;
  background: var(--bg);
}

.booking-panel {
  position: fixed;
  inset: 0 0 0 auto;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  background: rgba(5, 5, 5);
  border-left: 1px solid rgba(255, 255, 255, 0.06);
  transform: translateX(100%);
  opacity: 0;
  pointer-events: none;
  transition:
    transform 0.35s ease,
    opacity 0.25s ease;
  z-index: 60;
}

.booking-panel-scroll {
  height: 100%;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-bottom: env(safe-area-inset-bottom);
}

.booking-layout.form-open .booking-panel,
body.booking-panel-open .booking-panel {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
}


@media (max-width: 1024px) {
  .booking-layout.form-open {
    overflow: hidden;
  }
  body.booking-panel-open {
    overflow: hidden;
  }
}

@media (min-width: 1024px) {
  .booking-panel {
    width: min(42vw, 720px);
  }
}

.selected-card {
  border-color: rgba(129, 140, 248, 0.46) !important;
  background: rgba(129, 140, 248, 0.1) !important;
  box-shadow: 0 0 0 1px rgba(129, 140, 248, 0.14);
}

.calendar-day.is-disabled {
  opacity: 0.38;
  pointer-events: none;
}


.period-card.is-disabled {
  opacity: 0.38;
  pointer-events: none;
  border-style: dashed;
}

.step-panel {
  animation: fadeUp 0.22s ease;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Estilos adicionais para horários */
.schedule-day.today .day-name {
  color: var(--primary);
  font-weight: bold;
}
.schedule-day.today .hours {
  color: var(--primary);
  font-weight: 500;
}

#step-indicators-grid {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
}

.step-indicator {
  display: block !important;
}
