.booking-reglab {
  background:
    radial-gradient(circle at top right, rgba(28, 182, 119, 0.18), transparent 28%),
    radial-gradient(circle at 15% 18%, rgba(28, 182, 119, 0.14), transparent 18%),
    linear-gradient(180deg, #09111d 0%, #0c1523 45%, #101a2b 100%);
  color: #eef4fb;
}

.booking-reglab #main {
  padding: 36px 16px;
}

.booking-reglab #book-appointment-wizard {
  overflow: hidden;
  border: 1px solid rgba(82, 107, 141, 0.3);
  border-radius: 32px;
  background:
    radial-gradient(circle at top right, rgba(37, 204, 137, 0.08), transparent 24%),
    linear-gradient(135deg, rgba(15, 24, 41, 0.98), rgba(10, 18, 29, 0.98));
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.34);
}

.booking-reglab #book-appointment-wizard #header {
  padding: 18px 24px 16px;
  border-bottom: 1px solid rgba(82, 107, 141, 0.18);
  background: linear-gradient(180deg, rgba(22, 31, 49, 0.92), rgba(15, 23, 37, 0.84));
}

.booking-reglab #book-appointment-wizard #company-name {
  min-width: 0;
}

.booking-reglab #book-appointment-wizard #company-name #company-logo {
  max-height: 34px;
  margin-bottom: 6px;
}

.booking-brand-name {
  display: block;
  color: #eef5fb;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.15;
}

.booking-reglab .display-booking-selection {
  color: #6fdbae;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.booking-reglab #book-appointment-wizard #steps {
  width: auto;
}

.booking-reglab #book-appointment-wizard .book-step {
  width: 40px;
  height: 40px;
  border: 1px solid rgba(53, 74, 104, 0.72);
  border-radius: 12px;
  background: rgba(16, 28, 45, 0.8);
}

.booking-reglab #book-appointment-wizard .book-step strong {
  color: #7c93b3;
  font-size: 13px;
  line-height: 22px;
}

.booking-reglab #book-appointment-wizard .active-step {
  width: 44px;
  height: 44px;
  margin-top: 3px;
  background: linear-gradient(180deg, #1fd88d, #17b776);
  border-color: transparent;
}

.booking-reglab #book-appointment-wizard .active-step strong {
  color: #08131d;
  font-size: 18px;
  line-height: 29px;
}

.booking-reglab .tippy-box {
  border: 1px solid rgba(82, 107, 141, 0.28);
  border-radius: 10px;
  background: rgba(12, 21, 33, 0.96);
  color: #dce8f5;
  font-size: 11px;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.28);
}

.booking-reglab .tippy-box[data-placement^="top"] > .tippy-arrow::before {
  border-top-color: rgba(12, 21, 33, 0.96);
}

.booking-reglab .tippy-content {
  padding: 7px 10px;
  line-height: 1.3;
}

.booking-reglab #book-appointment-wizard .wizard-frame {
  padding: 20px 24px 24px;
}

.booking-reglab #book-appointment-wizard .wizard-frame .frame-container {
  min-height: 0;
  padding: 0;
}

.booking-reglab #book-appointment-wizard .frame-container .frame-title {
  margin-bottom: 18px;
  color: #f5fbff;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  text-align: left;
}

.booking-intro {
  margin-bottom: 18px;
}

.booking-intro__title {
  margin: 0 0 6px;
  color: #f6fbff;
  font-size: 23px;
  font-weight: 800;
  line-height: 1.02;
}

.booking-intro__lead {
  margin: 0;
  max-width: 620px;
  color: #acbfd4;
  font-size: 14px;
  line-height: 1.45;
}

.selected-date-summary,
.booking-section-intro {
  border: 1px solid rgba(82, 107, 141, 0.26);
  border-radius: 999px;
  background: rgba(15, 29, 45, 0.72);
  color: #b8c7d9;
}

.booking-section-intro {
  display: inline-flex;
  margin-bottom: 18px;
  padding: 10px 16px;
  font-size: 14px;
}

.provider-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.provider-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 16px;
  border: 1px solid rgba(82, 107, 141, 0.26);
  border-radius: 20px;
  background:
    radial-gradient(circle at top right, rgba(31, 216, 141, 0.14), transparent 24%),
    linear-gradient(135deg, rgba(20, 31, 50, 0.96), rgba(9, 17, 30, 0.96));
  color: #f1f6fb;
  text-align: left;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.provider-card:hover {
  transform: translateY(-2px);
  border-color: rgba(31, 216, 141, 0.5);
}

.provider-card.is-disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.provider-card.is-disabled:hover {
  transform: none;
  border-color: rgba(82, 107, 141, 0.26);
}

.provider-card.is-selected {
  border-color: rgba(31, 216, 141, 0.88);
  box-shadow: 0 16px 32px rgba(31, 216, 141, 0.16);
}

.provider-card__avatar {
  flex: 0 0 68px;
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: linear-gradient(180deg, #1fd88d, #149462);
  color: #051018;
  font-size: 22px;
  font-weight: 800;
  line-height: 68px;
  text-align: center;
  box-shadow: inset 0 0 0 4px rgba(255, 255, 255, 0.04);
  overflow: hidden;
}

.provider-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.provider-card__name {
  margin: 0 0 6px;
  color: #f8fcff;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.08;
}

.provider-card__role {
  margin: 0;
  color: #c7d4e3;
  font-size: 12px;
  line-height: 1.45;
}

.booking-reglab .form-label,
.booking-reglab label {
  color: #dfe9f4;
}

.booking-reglab .form-control,
.booking-reglab .form-select {
  border: 1px solid rgba(82, 107, 141, 0.3);
  border-radius: 14px;
  background: rgba(10, 19, 30, 0.76);
  color: #eef4fb;
}

.booking-reglab .form-control:focus,
.booking-reglab .form-select:focus {
  border-color: rgba(31, 216, 141, 0.66);
  box-shadow: 0 0 0 0.2rem rgba(31, 216, 141, 0.12);
}

.booking-reglab .form-control::placeholder {
  color: #6e839f;
}

.booking-registration-notice {
  margin-top: 18px;
  color: #aebfd1;
  font-size: 13px;
  line-height: 1.6;
}

.booking-registration-notice a {
  color: #21d78c;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.booking-registration-notice a:hover {
  color: #56e7a8;
}

.booking-form-message {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 112, 112, 0.28);
  border-radius: 14px;
  background: rgba(76, 21, 27, 0.36);
  color: #ffd4d8;
  font-size: 13px;
  line-height: 1.5;
}

.confirm-policies {
  margin: 0 auto 18px;
  max-width: 760px;
}

.reglab-policy-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 14px;
}

.reglab-policy-check .form-check-input {
  margin-top: 3px;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  border-color: #13b479;
  background-color: transparent;
  box-shadow: none;
}

.reglab-policy-check .form-check-input:checked {
  background-color: #13b479;
  border-color: #13b479;
}

.reglab-policy-check .form-check-label {
  color: #eeeff0;
  font-size: 14px;
  line-height: 1.55;
}

.reglab-policy-check .form-check-label a {
  color: #13b479;
  text-decoration: none;
  border-bottom: 1px solid #13b479;
}

.reglab-policy-check .form-check-input.is-invalid {
  border-color: #ff8d97;
}

.booking-reglab #service-description {
  max-height: none;
  margin-top: 8px;
  color: #8ea4bf;
}

.selected-date-summary {
  display: inline-flex;
  margin-bottom: 14px;
  padding: 8px 14px;
  font-size: 12px;
}

.booking-reglab #select-date {
  display: none;
}

.booking-reglab .flatpickr-wrapper {
  display: none !important;
}

.booking-reglab #book-appointment-wizard .wizard-frame .flatpickr-calendar {
  margin: 0 auto;
  box-shadow: none;
}

.booking-reglab #select-time {
  max-width: none;
  padding: 0;
  display: block;
}

.booking-reglab #available-hours {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  max-height: none;
  padding-right: 0;
  margin-top: 0;
  align-content: start;
}

.booking-reglab #available-hours div {
  margin-right: 0;
}

.booking-reglab #available-hours .available-hour {
  margin-bottom: 0;
  padding: 12px 10px;
  border: 1px solid rgba(82, 107, 141, 0.28);
  border-radius: 14px;
  background: rgba(13, 22, 35, 0.78);
  color: #f0f6fb;
  text-align: center;
  font-size: 13px;
}

.booking-reglab #wizard-frame-2 .frame-content {
  align-items: flex-start;
  row-gap: 0;
}

.booking-reglab #wizard-frame-2 .frame-content > div:first-child {
  flex: 0 0 auto;
  width: 100%;
  max-width: 100%;
}

.booking-reglab #wizard-frame-2 .frame-content > div:last-child {
  flex: 0 0 auto;
  width: 100%;
  max-width: 100%;
}

.booking-reglab #available-hours .available-hour:hover {
  border-color: rgba(31, 216, 141, 0.42);
}

.booking-reglab #available-hours .selected-hour {
  background: linear-gradient(180deg, #1fd88d, #17b776);
  border-color: transparent;
  color: #07111b;
  font-weight: 700;
}

.booking-reglab #appointment-details,
.booking-reglab #customer-details {
  padding: 18px;
  border: 1px solid rgba(82, 107, 141, 0.24);
  border-radius: 20px;
  background: rgba(12, 22, 34, 0.72);
}

.booking-reglab #wizard-frame-4 .frame-title {
  margin-bottom: 14px;
}

.booking-reglab #wizard-frame-4 .confirm-frame {
  row-gap: 12px;
  max-width: 760px;
}

.booking-reglab #wizard-frame-4 #appointment-details,
.booking-reglab #wizard-frame-4 #customer-details {
  max-width: 760px;
}

.booking-reglab .confirm-card__title {
  margin-bottom: 10px;
  color: #f5fbff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
}

.booking-reglab .confirm-card__subtitle {
  margin-bottom: 8px;
  color: #aebfd2;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
}

.booking-reglab .confirm-card__meta {
  margin-bottom: 12px;
  color: #6fdbae;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.35;
}

.booking-reglab .confirm-card__item {
  margin-bottom: 8px;
  color: #eef4fb;
  font-size: 12px;
  line-height: 1.45;
}

.booking-reglab .confirm-card__item:last-child {
  margin-bottom: 0;
}

.booking-reglab .confirm-card__item i {
  width: 18px;
  color: #d8e3ef;
}

.booking-reglab .confirm-policies {
  max-width: 760px;
  justify-content: flex-start !important;
  gap: 20px;
  margin-bottom: 4px;
}

.booking-reglab .confirm-policies .form-check {
  margin-bottom: 0 !important;
}

.booking-reglab .confirm-policies .form-check-label {
  color: #b7c6d8;
  font-size: 12px;
  line-height: 1.4;
}

.booking-reglab #wizard-frame-4 .command-buttons {
  max-width: 760px;
  margin-top: 14px;
}

.booking-reglab .command-buttons {
  gap: 12px;
}

.booking-reglab .btn {
  min-width: 148px;
  border-radius: 14px;
  padding: 12px 18px;
  font-weight: 600;
  font-size: 13px;
}

.booking-reglab .btn-primary,
.booking-reglab .btn-dark {
  border: none;
  background: linear-gradient(180deg, #1fd88d, #17b776);
  color: #06101a;
}

.booking-reglab .btn-outline-secondary {
  border-color: rgba(82, 107, 141, 0.34);
  color: #d5e0ec;
  background: rgba(14, 23, 36, 0.72);
}

.booking-reglab .btn-outline-secondary:hover {
  border-color: rgba(31, 216, 141, 0.42);
  color: #ffffff;
  background: rgba(17, 31, 49, 0.92);
}

.booking-reglab #frame-footer {
  display: none;
}

@media (max-width: 991px) {
  .provider-cards {
    grid-template-columns: 1fr;
  }

  .booking-reglab #available-hours {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .booking-reglab #main {
    padding: 16px 10px;
  }

  .booking-reglab #book-appointment-wizard {
    border-radius: 22px;
  }

  .booking-reglab #book-appointment-wizard #header,
  .booking-reglab #book-appointment-wizard .wizard-frame {
    padding: 16px 14px;
  }

  .provider-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .provider-card__avatar {
    width: 58px;
    height: 58px;
    line-height: 58px;
    font-size: 18px;
  }

  .provider-card__name {
    font-size: 16px;
  }

  .booking-intro__title {
    font-size: 22px;
  }

  .booking-intro__lead {
    font-size: 13px;
  }

  .booking-reglab #available-hours {
    grid-template-columns: 1fr;
  }
}

.booking-message-page #message-frame {
  max-width: 760px;
  margin: 0 auto;
  padding: 36px 28px;
  border: 1px solid rgba(82, 107, 141, 0.24) !important;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(31, 216, 141, 0.1), transparent 22%),
    linear-gradient(135deg, rgba(15, 24, 41, 0.98), rgba(10, 18, 29, 0.98));
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.34);
  text-align: left;
}

.booking-message-page #success-frame {
  background: transparent;
  border: 0;
  padding: 0;
  text-align: left;
}

.booking-success-card {
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  align-items: flex-start;
}

.booking-success-title {
  margin: 0 0 12px;
  color: #f5fbff;
  font-size: 26px;
  font-weight: 800;
  line-height: 1.04;
}

.booking-success-copy {
  max-width: 560px;
}

.booking-success-text {
  margin: 0 0 10px;
  color: #d7e3ee;
  font-size: 16px;
  line-height: 1.5;
}

.booking-success-note {
  margin: 0;
  color: #8fa5bf;
  font-size: 13px;
  line-height: 1.45;
}

.booking-success-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: flex-start;
}

.booking-message-page #success-frame .btn {
  width: auto;
  max-width: none;
  margin-bottom: 0;
  min-width: 0;
}

.booking-message-page .booking-success-actions .btn-primary {
  order: 1;
}

.booking-message-page .booking-success-actions .btn-outline-secondary {
  order: 2;
}

@media (max-width: 767px) {
  .booking-message-page #message-frame {
    padding: 24px 18px;
    border-radius: 22px;
  }

  .booking-success-title {
    font-size: 24px;
  }

  .booking-success-text {
    font-size: 14px;
  }

  .booking-success-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .booking-message-page #success-frame .btn {
    width: 100%;
  }
}
