/* Calander CSS */
#pb-calendar {
    flex: 3;
    border: 1px solid #D4D7C6;
    padding: 30px;
    border-radius: 30px;
}
#pb-times {
  flex: 1;
  border: 1px solid #D4D7C6;
  padding: 30px;
  border-radius: 30px;
}
.clander-header {
    display: flex;
    justify-content: space-between;
}
.calander-nev button#pb-prev-month, .calander-nev button#pb-next-month {
  border: none;
  font-size: 30px;
  line-height: 30px;
  color: #D4D7C6;
}
.pb-date.disabled {
  background: #eee;
  color: #999;
  pointer-events: none;
}
.pb-mini-calendar {
  border-collapse: collapse;
  width: 100%;
  text-align: center;
}

.pb-mini-calendar th, .pb-mini-calendar td {
  border: 1px solid #ddd;
  padding: 10px;
  width: 14.2%;
}

.pb-date.available {
  background-color: #c8e6c9; /* green highlight */
  cursor: pointer;
}

.pb-date.selected {
    background: #3C4121;
    color: #fff;
}

.pb-slot {
    float: left;
    margin: 5px;
}

.pb-slot button {
    padding: 8px 15px;
    font-size: 14px;
    font-weight: bold;
    background-color: var(--e-global-color-primary);
    color: white;
    border: none;
    border-radius: 16px;
    cursor: pointer;
}

.pb-slot button:hover {
  background: #e0e0e0;
}
/* Calander CSS */

/* Red border for invalid fields */
.error-field {
    border: 1px solid red !important;
    background: #ffe6e6;
}

.error {
    color: red;
    font-size: 0.9em;
    margin-top: 4px;
}
.disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.warning-message {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: transparent; /* or a subtle tint if desired */
  margin: 12px 0;
  padding: 0;
  color: #b3261e; /* warning color (red) */
  font-weight: 600;
  font-size: 1rem;
}

.warning-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-top: 2px; /* visually align icon with text */
  color: #b3261e; /* SVG uses currentColor */
}

.warning-text {
  margin: 0;
  line-height: 1.4;
}

/* Generic layout for any step wrapper */
.eligibility-step > div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 30px;
}

/* Target both image and content blocks inside any wrapper */
.eligibility-step [class*="-image"],
.eligibility-step [class*="-content"] {
  flex: 1 1 45%;
  box-sizing: border-box;
}

/* Responsive image */
.eligibility-step [class*="-image"] img {
  width: 100%;
  height: auto;
  display: block;
}

/* Intro Heading */
.eligibility-step h1,
.title-heading {
    text-transform: uppercase;
    /* color: var(--e-global-color-primary); */
    font-size: 32px;
    font-weight: 700;
    margin: 0;
}

.description.subtext,
.description {
  font-size: var(--e-global-typography-8f2f62c-font-size);
  color: var(--e-global-color-fe41a10);
}
.subtext, .checkbox-label, .progress-fill, .consent-note a {
color: var(--e-global-color-primary);
}
.highlight {
  font-size: 24px;
  font-weight: 600;
  color: var(--e-global-color-primary);
  text-align: center;
}
.intro-content,
.form-content,
.form-content form,
.eligibility-content,
.health-content,
.form-field,
.not-eligible-content,
.success-content {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.success-content {
  align-items: center;
}
.success-content .second-highlight {
  font-size: 20px !important;
  color: var(--e-global-color-primary);
  font-weight: 600;
  margin-bottom: 0 !important;
}
/* Step Cards */
.step-card {
  display: flex;
  gap: 15px;
  align-items: normal;
  background: var(--e-global-color-ca4f870);
  border-radius: 12px;
  padding: 15px 20px;
  border: 1px solid var(--e-global-color-e0facc9);
}
.step-text{
 display: flex;
 flex-direction: column;
 justify-content: space-between;
}
.step-icon {
  width: 82px !important;
  height: 82px !important;
  object-fit: cover;
  border-radius: 6px;
}
/* Step cards headings */
.step-headings {
  font-size: 20px;
  font-weight: 700;
  line-height: 28px;
}
/* Paragraph */
#pb-eligibility-form .para-fourteen {
  font-size: var(--e-global-typography-0f8339d-font-size);
  color: var(--e-global-color-fe41a10);
  margin: 0;
}

/* Progress bar */
.progress-bar {
  width: 100%;
  height: 6px;
  background-color: #f1f1e6;
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 25px;
}

.progress-fill {
  height: 100%;
  width: 40%;

  background-color: #2f2f2f;
}

/* Buttons */
button.next-btn,
button.proceed-booking {
  padding: 12px 30px;
  font-size: 15px;
  background-color: var(--e-global-color-primary);
  color: white;
  border: none;
  border-radius: 30px;
  cursor: pointer;
  max-width: 100%;
  width: 100%;
}

button.prev-btn {
  width: fit-content;
  border: none;
  color: var(--e-global-color-primary);
  font-weight: 600;
  padding: 0;
}
button.prev-btn:hover {
  background-color: transparent !important;
  color: var(--e-global-color-primary);
}

button.home-button {
  background-color: transparent;
  border: 1px solid var(--e-global-color-primary);
  border-radius: 12px;
  max-width: 100%;
  width: 100%;
  color: var(--e-global-color-primary);
}

/* Consent Para */
.consent-note.para-fourteen {
  color: var(--e-global-color-13fe5df) !important;
}

.form-field .ques-label {
  font-size: 20px;
  font-weight: 600;
  line-height: 28px;
  color: var(--e-global-color-primary);
}

input[type="radio"],
input[type="checkbox"] {
  accent-color: var(--e-global-color-primary);;
}
/* Step 2 Form input fields */
.input-field input[type="text"],
.input-field input[type="email"] {
  width: 100%;
  padding: 12px;
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 8px;
  outline: none;
  box-sizing: border-box;
}

.radio-group {
  display: flex;
  gap: 20px;
}

/* Eligibility Steps */
.eligibility-step {
  display: none;
}
.eligibility-step.active {
  display: block;
}

.error {
  color: red;
  display: none;
}

.not-eligible-content {
  flex: 1;
  /* max-width: 600px;
  margin-top: 40px; */
}
/* Multi-step form styling */

/* Services Cards */
#pb-services-container {
  width: 50%;
}

.pb-service-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: var(--card-color, #007a99);
  color: white;
  padding: 30px;
  border-radius: 4px;
  margin-bottom: 20px;
}

/* Practitioners Cards */
#pb-practitioners-container {
  width: 50%;
  padding: 60px 10px;
}
#pb-practitioners-container hr {
  color: var(--e-global-color-primary);
}
.pb-practitioner-card {
  padding: 15px 0;
  gap: 20px;
}

.pb-practitioner-img {
    width: 20%;
    display: flex;
}
.pb-practitioner-img img {
    width: 120px;
    border-radius: 50% !important;
}
.pb-practitioner-info {
    width: 80%;
    display: flex;
    justify-content: space-between;
    align-items: left;
    flex-direction: column;
}
.pb-book-heading {
  text-transform: uppercase;
  font-size: 32px;
  font-weight: 700;
  margin: 0;
}
.pb-select-practitioner-heading {
  text-transform: capitalize;
  font-size: 24px;
  color: var(--e-global-color-primary);
}

.pb-practitioner-name {
  font-size: 24px;
  font-weight: 600;
}
.view-details {
    cursor: pointer;
    margin-bottom: 12px;
    font-weight: 600;
    color: var(--e-global-color-primary);
    font-size: 15px;
    line-height: 14.63px;
    text-align: left;
}

button#pb-prev-month, button#pb-next-month {
    padding: 5px 15px;
    font-size: 20px;
    background-color: var(--e-global-color-primary);
    color: white;
    border: none;
    border-radius: 50px;
    cursor: pointer;
}

button.pb-show-availability {
  padding: 5px 20px;
  font-size: 14px;
  background-color: var(--e-global-color-primary);
  color: white;
  border: none;
  border-radius: 30px;
  cursor: pointer;
  margin-top:10px;
  width: fit-content;
}

button.pb-show-availability:hover {
  background-color: var(--e-global-color-secondary);
}

.pb-availability {
    height:20px;
}

.pb-earliest-availability {
    font-size: 14px;
}

button.pb-select-practitioner,
button.back-to-pract {
  padding: 12px 30px;
  font-size: 16px;
  background-color: var(--e-global-color-primary);
  color: white;
  border: none;
  border-radius: 30px;
  cursor: pointer;
}

button.pb-select-practitioner:hover,
button.back-to-pract:hover {
  background-color: var(--e-global-color-secondary);
}
.fc-button-group button {
    background-color: var(--e-global-color-text) !important;
}

/* Booking cards styling Naeem */
.pb-practitioner-card-main{
	    display: flex !important;
    align-items: center !important;
}

.pb-practitioner-card-info {
  display: flex;
  align-items: center;
  padding: 15px 0;
  gap: 20px;
	width : 100%;
}

.pb-practitioner-card-main .pb-select-practitioner{
	height: fit-content;
    width: auto;
}

/* Spinner CSS */
#pb-loading-spinner {
  text-align: center;
  margin: 20px 0;
}

.spinner {
  border: 6px solid #f3f3f3;
  border-top: 6px solid var(--e-global-color-primary);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: spin 0.8s linear infinite;
  margin: auto;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* Booking form */
.booking-form-wrapper {
  display: flex;
  gap: 20px;
}
.booking-form-wrapper [class*="-image"],
.booking-form-wrapper [class*="-form"] {
  flex: 1 1 45%;
  box-sizing: border-box;
}
/* ======= Booking Form Styling ======= */
/* Style the entire form */
#booking-form {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  max-width: 800px;
  margin: 0 auto;
  font-family: sans-serif;
}

.booking-form-content h1 {
  font-family: var(--e-global-typography-text-font-family), Sans-serif;
  font-size: var(--e-global-typography-text-font-size);
  font-weight: var(--e-global-typography-text-font-weight);
  color: var(--e-global-color-primary);
  text-transform: uppercase;
  margin: 0px;
}
.booking-form-content p {
  margin: 0 !important;
}

/* Top heading div (full width) */
#booking-form > div:first-of-type {
  flex: 0 0 100%;
}

/* Style each label block */
#booking-form label {
  display: flex;
  flex-direction: column;
  flex: 0 0 48%;
  position: relative;
}

/* Full-width for textarea */
#booking-form textarea {
  min-height: 100px;
  resize: vertical;
}

/* Only this one should be full width */
#booking-form label:has(textarea) {
  flex: 0 0 100%;
}

/* Hide all labels except specific ones */
#booking-form
  label:not(:has([name="dob"])):not(:has([name="gender"])):not(
    :has([name="pronouns"])
  ):not(:has(textarea))
  > span,
#booking-form
  label:not(:has([name="dob"])):not(:has([name="gender"])):not(
    :has([name="pronouns"])
  ):not(:has(textarea))::before {
  display: none;
}

/* Input, select, textarea styling */
#booking-form input[type="text"],
#booking-form input[type="email"],
#booking-form input[type="date"],
#booking-form select,
#booking-form textarea {
  margin-top: 6px;
  padding: 12px 14px;
  font-size: 14px;
  border: 1px solid #ccc;
  border-radius: 6px;
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.2s ease;
}

.consent-container {
  display: flex;
  align-items: center;
  gap: 6px; /* space between checkbox and text */
  flex-wrap: wrap; /* allows wrapping if needed on smaller screens */
}

.consent-container input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
}

.consent-container .consent_offers {
  font-size: 14px;
  line-height: 1.4;
  color: #333;
  margin: 0;
}

.consent-container a {
  color: var(--e-global-color-primary);
  text-decoration: none;
}

.consent-container a:hover {
  text-decoration: underline;
}

/* Payment Success */
.thanyou-section .success-wrapper {
  display: flex;
  align-items: center;
  gap: 20px;
}
.thanyou-section .payment-success-title {
  display: flex;
  align-items: center;
  gap: 10px;
}
.thanyou-section .success-content {
  background-color: var(--e-global-color-ca4f870);
  padding: 20px;
  border: 1px solid var(--e-global-color-secondary);
  border-radius: 16px;
}
#redirecting-message .success-wrapper .success-image,
#redirecting-message .success-wrapper .content{
  flex: 1 1 45%;
}

.thankyou-container{
    width: 100%;
    max-width: 1240px;
    padding: 20px;
    display: block;
    margin: auto;

}

.progress-fill{
    background-color:var(--e-global-color-primary);
}

.radio-group label{
    color: var(--e-global-color-primary);
}

a#go-home {
    width: 100%;
    border-radius: 30px;
    background-color: var(--e-global-color-primary);
    color: #ffffff;
}

/* Mobile responsiveness */
@media (max-width: 1024px) {
  #pb-eligibility-form {
    padding: 10px;
  }
  .eligibility-step > div,
  .booking-form-wrapper {
    flex-direction: column-reverse;
  }

  .intro-image {
    margin-top: 10px;
  }
  .eligibility-step [class*="-image"],
  .eligibility-step [class*="-content"],
  .booking-form-wrapper [class*="-image"],
  .booking-form-wrapper [class*="-form"] {
    flex: 1 1 100%;
    max-width: 100%;
    width: 100%;
  }
  /* Step cards headings */
  .step-headings {
    font-size: 18px;
    line-height: 24px;
  }

  .intro-content,
  .form-content,
  .form-content form,
  .eligibility-content,
  .health-content,
  .form-field,
  .not-eligible-content,
  .success-content {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  /* Practitioners Cards */
  .pb-book-heading {
    text-transform: uppercase;
    color: var(--e-global-color-primary);
    font-size: 22px;
    font-weight: 700;
    margin: 0;
  }
  .pb-select-practitioner-heading {
    text-transform: capitalize;
    font-size: 20px;
    color: var(--e-global-color-primary);
  }

  .pb-practitioner-name {
    font-size: 20px;
    font-weight: 600;
    color: var(--e-global-color-primary);
  }

  #booking-form label {
    display: flex;
    flex-direction: column;
    flex: 0 0 100%;
    position: relative;
  }
  /* Payment Success */
  .thanyou-section .success-wrapper {
    flex-wrap: wrap-reverse;
  }

    #redirecting-message .success-wrapper .success-image,
    #redirecting-message .success-wrapper .content{
      flex: 1 1 100%;
    }
	
	/* Booking cards styling Naeem */
	#pb-practitioners-container{
		width : 100%;
	}

}

@media (max-width: 768px) {
    
    #pb-practitioners-container {
      width: 100%;
    }
    #pb-calendar {
        border: none;
        padding: 0px;
    }
    #pb-times {
        padding: 20px;
    }
    body {
        overflow-x: hidden;
    }
    #pb-calendar p.second-highlight {
        text-align: center;
    }
	
	/* Booking cards styling Naeem */
	.pb-practitioner-card {
    	justify-content: center;
        display: flex;
        flex-direction : column;
	}
    .pb-practitioner-card-main{
    	flex-wrap : wrap;
    	justify-content : center;
	}
	.pb-practitioner-card-info{
	    flex-wrap : wrap;
    }
    button.pb-show-availability {
        display: block;
        margin: auto;
        margin-top: 10px;
    }

    .pb-practitioner-card-info .pb-practitioner-img{
		width: 100%;
	}
	
	.pb-practitioner-card-main .pb-practitioner-card-info, .pb-practitioner-card-main .pb-practitioner-img, .pb-practitioner-card .view-details{
		text-align : center !important;
		justify-content : center;
	}
}
