﻿/* ----------------------------------------------------------------------------
 * Software Solutions - Online Appointment Scheduler
 *
 * @package     SoftwareSolutions
 * @author      Joe Albert <softwaresolutions.ssok@gmail.com>
 * @copyright   Copyright (c) Alex Tselegidis
 * @license     https://opensource.org/licenses/GPL-3.0 - GPLv3
 * @link        #
 * @since       v1.5.0
 * ---------------------------------------------------------------------------- */
/* Responsive booking wizard styles (rounded corners and shadow on md+ screens) */
@media (min-width: 768px) {
  #book-appointment-wizard {
    border-radius: var(--bs-border-radius) !important;
    box-shadow: var(--bs-box-shadow-sm) !important;
  }
}
/* Active step indicator - dynamic state that changes via JavaScript */
#book-appointment-wizard .book-step.active-step {
  height: 45px !important;
  width: 45px !important;
  background: var(--bs-white) !important;
  padding: 7px !important;
  margin-right: 13px !important;
  margin-top: 0 !important;
}

#book-appointment-wizard .book-step.active-step strong {
  color: var(--bs-primary) !important;
  font-size: 21px !important;
}

/* Inactive step indicator - ensures consistent styling when step becomes inactive */
#book-appointment-wizard .book-step:not(.active-step) {
  height: 35px !important;
  width: 35px !important;
  background: rgba(0, 0, 0, 0.2) !important;
  padding: 8px !important;
  margin-right: 12px !important;
  margin-top: 6px !important;
}

#book-appointment-wizard .book-step:not(.active-step) strong {
  color: rgba(255, 255, 255, 0.5) !important;
  font-size: 12px !important;
}

/* Selected hour button state */
#book-appointment-wizard #available-hours .available-hour {
  margin-bottom: 10px;
}

#book-appointment-wizard #available-hours .selected-hour {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  color: var(--bs-white) !important;
}

/* Captcha refresh icon hover effect */
#book-appointment-wizard .captcha-title .fa-sync-alt {
  cursor: pointer;
  transition: all 0.3s linear;
}

#book-appointment-wizard .captcha-title .fa-sync-alt:hover {
  color: var(--bs-primary);
}

/* Language popover list */
.popover .popover-title {
  text-align: center;
}

.popover .popover-content #language-list .language {
  margin: 15px 0;
}

#book-appointment-wizard .flatpickr-calendar.inline {
  margin: auto;
}

#wizard-frame-2 {
  padding-top: 1.25rem !important;
  padding-bottom: 1rem !important;
}

#wizard-frame-2 .frame-container {
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

#wizard-frame-2 .frame-title {
  margin-bottom: 1.5rem !important;
}

#wizard-frame-2 .frame-content {
  align-items: flex-start;
  row-gap: 1rem;
}

#wizard-frame-2 #select-date {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  min-height: 0;
  margin: 0 auto !important;
}

#wizard-frame-2 .flatpickr-calendar.inline {
  transform: scale(1.22);
  transform-origin: top center;
  margin: 0 auto;
}

#wizard-frame-2 .flatpickr-current-month {
  font-size: 160%;
}

#wizard-frame-2 .flatpickr-weekday {
  font-size: 1rem;
}

#wizard-frame-2 #booking-location-bar {
  border: 1px solid #dbe7f3;
  border-radius: 1rem;
  background: linear-gradient(180deg, #f8fbff 0%, #eef5fb 100%) !important;
  box-shadow: 0 0.5rem 1.2rem rgba(15, 23, 42, 0.06);
  margin-bottom: 1.35rem;
}

#wizard-frame-2 #select-time {
  max-width: 420px !important;
  margin: 0 auto !important;
  padding-top: 0 !important;
}

#wizard-frame-2 #available-hours {
  max-height: 360px !important;
  padding-right: 0.35rem;
}

#wizard-frame-2 .command-buttons {
  margin-top: 1.25rem !important;
}

/* Show the consultation location bar only on the calendar step of the booking wizard */
#book-appointment-wizard[data-step-index]:not([data-step-index="2"]) #booking-location-bar {
  display: none !important;
}

@media (max-width: 991.98px) {
  #wizard-frame-2 .booking-details-column {
    display: contents;
  }

  #wizard-frame-2 #booking-location-bar {
    order: 1;
    flex: 0 0 auto;
    width: calc(100% - var(--bs-gutter-x));
    margin-right: calc(var(--bs-gutter-x) * 0.5);
    margin-left: calc(var(--bs-gutter-x) * 0.5);
    margin-bottom: 1.15rem;
  }

  #wizard-frame-2 .booking-calendar-column {
    order: 2;
    margin-bottom: 1.15rem;
  }

  #wizard-frame-2 #select-time {
    order: 3;
    flex: 0 0 auto;
    width: calc(100% - var(--bs-gutter-x));
    margin-right: calc(var(--bs-gutter-x) * 0.5) !important;
    margin-left: calc(var(--bs-gutter-x) * 0.5) !important;
  }

  #wizard-frame-2 .flatpickr-calendar.inline {
    transform: scale(1.08);
  }

  #wizard-frame-2 #select-time {
    max-width: 100% !important;
  }
}
