/* ============================================================================
   calendar-slots-fix.css — compatibilité calendrier
   Lot NE : les surcharges UX de l'étape Date et heure ont été déplacées dans
   css/datetime-step-ux.css pour éviter les conflits lot-par-lot et garder le
   branding multi-société piloté par BrandThemeManager.
   ============================================================================ */

.time-slots-container.hidden,
#step-datetime #time-slots-container.hidden {
  display: none;
  animation: none;
}

/* Les tooltips doivent rester visibles même quand le calendrier est dans une carte. */
#step-datetime .calendar-container,
#step-datetime .calendar-grid,
#step-datetime .calendar-day,
.calendar-container,
.calendar-grid,
.calendar-day {
  overflow: visible;
}

#step-datetime .calendar-day,
.calendar-day {
  position: relative;
}

#step-datetime .calendar-day.available:hover,
#step-datetime .calendar-day.available:focus-visible,
.calendar-day.available:hover,
.calendar-day.available:focus-visible {
  z-index: 130;
}

#step-datetime .calendar-day .calendar-day-availability-tooltip,
.calendar-day .calendar-day-availability-tooltip,
#step-datetime .calendar-day > .calendar-day-availability-tooltip,
.calendar-day > .calendar-day-availability-tooltip {
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  z-index: 250;
  width: max-content;
  min-width: 190px;
  max-width: min(260px, calc(100vw - 32px));
  display: grid;
  gap: 4px;
  padding: 10px 11px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--brand-primary, var(--accent, #5c2d91)) 18%, #e9e3f5);
  background: color-mix(in srgb, var(--brand-primary, var(--accent, #5c2d91)) 8%, #fff);
  color: var(--brand-text, #1f2937);
  box-shadow: 0 16px 36px rgba(32, 18, 52, .18);
  opacity: 0;
  visibility: hidden;
  transform: translate(-50%, 6px);
  pointer-events: none;
  text-align: left;
  line-height: 1.25;
  white-space: normal;
  font-size: .72rem;
  font-weight: 700;
}

#step-datetime .calendar-day .calendar-day-availability-tooltip::after,
.calendar-day .calendar-day-availability-tooltip::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 100%;
  width: 10px;
  height: 10px;
  background: inherit;
  border-right: 1px solid color-mix(in srgb, var(--brand-primary, var(--accent, #5c2d91)) 18%, #e9e3f5);
  border-bottom: 1px solid color-mix(in srgb, var(--brand-primary, var(--accent, #5c2d91)) 18%, #e9e3f5);
  transform: translate(-50%, -5px) rotate(45deg);
}

#step-datetime .calendar-day.available:hover .calendar-day-availability-tooltip,
#step-datetime .calendar-day.available:focus-visible .calendar-day-availability-tooltip,
.calendar-day.available:hover .calendar-day-availability-tooltip,
.calendar-day.available:focus-visible .calendar-day-availability-tooltip,
#step-datetime .calendar-day.available:hover > .calendar-day-availability-tooltip,
#step-datetime .calendar-day.available:focus-visible > .calendar-day-availability-tooltip,
.calendar-day.available:hover > .calendar-day-availability-tooltip,
.calendar-day.available:focus-visible > .calendar-day-availability-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, 0);
}

#step-datetime .calendar-day .calendar-day-availability-tooltip__heading,
.calendar-day .calendar-day-availability-tooltip__heading {
  color: var(--brand-primary, var(--accent, #5c2d91));
  font-size: .78rem;
  font-weight: 900;
}

#step-datetime .calendar-day .calendar-day-availability-tooltip__meta,
.calendar-day .calendar-day-availability-tooltip__meta {
  color: #5f5872;
  font-size: .72rem;
  font-weight: 750;
}

#step-datetime .calendar-day .calendar-day-availability-tooltip__slot,
.calendar-day .calendar-day-availability-tooltip__slot {
  color: var(--brand-text, #1f2937);
  font-size: .72rem;
  font-weight: 700;
}

#step-datetime .calendar-day .calendar-day-availability-tooltip__more,
#step-datetime .calendar-day .calendar-day-availability-tooltip__lunar,
.calendar-day .calendar-day-availability-tooltip__more,
.calendar-day .calendar-day-availability-tooltip__lunar {
  color: #7b728d;
  font-size: .68rem;
  font-weight: 650;
}

@media (hover: none) {
  #step-datetime .calendar-day .calendar-day-availability-tooltip,
  .calendar-day .calendar-day-availability-tooltip {
    display: none;
  }
}

/* Lot NG — tooltip bord gauche/droit : le contenu ne doit pas sortir du calendrier. */
#step-datetime .calendar-grid .calendar-day:nth-child(7n+1) > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day:nth-child(7n+1) > .calendar-day-availability-tooltip {
  left: 0;
  right: auto;
  transform: translate(0, 6px);
}
#step-datetime .calendar-grid .calendar-day:nth-child(7n+1) > .calendar-day-availability-tooltip::after,
.calendar-grid .calendar-day:nth-child(7n+1) > .calendar-day-availability-tooltip::after {
  left: 18px;
  right: auto;
  transform: translate(0, -5px) rotate(45deg);
}
#step-datetime .calendar-grid .calendar-day:nth-child(7n) > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day:nth-child(7n) > .calendar-day-availability-tooltip {
  left: auto;
  right: 0;
  transform: translate(0, 6px);
}
#step-datetime .calendar-grid .calendar-day:nth-child(7n) > .calendar-day-availability-tooltip::after,
.calendar-grid .calendar-day:nth-child(7n) > .calendar-day-availability-tooltip::after {
  left: auto;
  right: 18px;
  transform: translate(0, -5px) rotate(45deg);
}
#step-datetime .calendar-grid .calendar-day.available:nth-child(7n+1):hover > .calendar-day-availability-tooltip,
#step-datetime .calendar-grid .calendar-day.available:nth-child(7n+1):focus-visible > .calendar-day-availability-tooltip,
#step-datetime .calendar-grid .calendar-day.available:nth-child(7n):hover > .calendar-day-availability-tooltip,
#step-datetime .calendar-grid .calendar-day.available:nth-child(7n):focus-visible > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day.available:nth-child(7n+1):hover > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day.available:nth-child(7n+1):focus-visible > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day.available:nth-child(7n):hover > .calendar-day-availability-tooltip,
.calendar-grid .calendar-day.available:nth-child(7n):focus-visible > .calendar-day-availability-tooltip {
  transform: translate(0, 0);
}
