.payform {
  width: 100%;
  max-width: 920px;
  margin: 20px auto 0;
  padding: 0;
  color: var(--fab-ink);
  font-family: "Inter", sans-serif !important;
  font-size: 15px;
  font-variant: normal;
}

ul {
  list-style-type: none;
}

/*.payform {*/
/*background: #F6F9FC;*/
/*display: flex;*/
/*align-items: center;*/
/*min-height: 100%;*/
/*}*/

.fab-booking-dialog {
  max-width: 1240px;
  margin: 32px auto;
}

.fab-booking-plugin .modal-content {
  display: block;
  border: 1px solid #dfe5ec;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(180deg, #ffffff 0%, #f7fafc 100%);
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.12);
}

.fab-booking-plugin .fab-back-btn {
  border-radius: 4px;
  border: 1px solid #06b6d5 !important;
  background: #fff !important;
  color: #06b6d5 !important;
  padding: 10px 18px;
  min-height: 45px !important;
  min-width: 150px;
  font-family: Inter;
  font-size: 16px !important;
  font-weight: 600 !important;
}

.fab-booking-plugin .fab-step-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 80px;
  clear: both;
}

.fab-step-actions {
  padding: 30px 0 0;
}

.fab-booking-plugin .fab-step-actions .fab-back-btn,
.fab-booking-plugin .fab-step-actions .fab-next-btn {
  float: none !important;
  margin-top: 0;
}

.fab-booking-plugin .fab-step-actions .fab-next-btn {
  margin-left: auto;
}

.fab-booking-plugin .fab-next-btn,
.fab-booking-plugin #form1nextbtn {
  background-color: #f3c !important;
  background: #f3c !important;
  border: 1px solid #f3c !important;
  color: #fff;
  font-family: Inter;
  border-radius: 4px !important;
  min-width: 180px;
  min-height: 45px;
  font-size: 16px !important;
  font-weight: 600 !important;
}

@media (max-width: 768px) {
    #form1nextbtn {
      width: 100% !important;
      float: none !important;
      display: block !important;
    }
  }

.fab-booking-plugin .fab-next-btn:after,
.fab-booking-plugin #form1nextbtn:after {
  content: "\e907";
  font-family: "Fabs-Icons";
  margin-left: 10px;
  font-size: 13px;
  font-weight: normal;
}

.fab-booking-plugin .fab-back-btn:before {
  content: "\e906";
  font-family: "Fabs-Icons";
  margin-right: 10px;
  font-size: 13px;
  font-weight: normal;
}

.fab-booking-plugin {
  --fab-accent: #0f766e;
  --fab-accent-strong: #115e59;
  --fab-ink: #132238;
  --fab-muted: #64748b;
  --fab-line: #dbe3ec;
  --fab-soft: #eef6f5;
}


@font-face {
  font-family: "fa-light";
  src: url("./fonts/fa-light.woff2") format("woff2");
  font-display: auto;
}

@font-face {
  font-family: "fa-regular";
  src: url("./fonts/fa-regular.woff2") format("woff2");
  font-display: auto;
}

@font-face {
  font-family: "fa-solid";
  src: url("./fonts/fa-solid.woff2") format("woff2");
  font-display: auto;
}

@font-face {
  font-family: "Fabs-Icons";
  src: url("./fonts/fabs-icon.woff2") format("woff2");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

.fab-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Fabs-Icons";
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  line-height: 1;
  text-transform: none;
  speak: none;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.fab-icon::before {
  display: block;
}

.fab-icon-star::before {
  content: "\e800";
}
.fab-icon-play::before {
  content: "\e802";
}
.fab-icon-download::before {
  content: "\e80c";
}
.fab-icon-location::before {
  content: "\e844";
}
.fab-icon-truck::before {
  content: "\e845";
}
.fab-icon-cleaning::before {
  content: "\e846";
}
.fab-icon-bookings::before {
  content: "\e909";
}
.fab-icon-calendar::before {
  content: "\e90a";
}
.fab-icon-call::before {
  content: "\e90b";
}
.fab-icon-check-circle::before {
  content: "\e90f";
}
.fab-icon-check::before {
  content: "\e910";
}
.fab-icon-clock::before {
  content: "\e911";
}
.fab-icon-credit-card::before {
  content: "\e916";
}
.fab-icon-mail::before {
  content: "\e92c";
}
.fab-icon-postcode::before {
  content: "\e92d";
}
.fab-icon-plus::before {
  content: "\e936";
}
.fab-icon-question-circle::before {
  content: "\e937";
}
.fab-icon-search::before {
  content: "\e93a";
}
.fab-icon-upload::before {
  content: "\e941";
}
.fab-icon-calendar-check::before {
  content: "\f274";
}

.fab-booking-header {
  padding: 32px 36px 20px;
  border-bottom: 1px solid var(--fab-line);
  background: radial-gradient(
      circle at top right,
      rgba(15, 118, 110, 0.16),
      transparent 28%
    ),
    linear-gradient(135deg, #ffffff 0%, #f4fbfa 100%);
}

.fab-booking-eyebrow {
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fab-accent);
}

.fab-booking-header .modal-title {
  margin: 0;
  font-size: 34px;
  line-height: 1.1;
  color: var(--fab-ink);
}

.fab-booking-subtitle {
  margin: 10px 0 0;
  max-width: 640px;
  color: var(--fab-muted);
  font-size: 16px;
}

.fab-booking-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(290px, 0.9fr);
  gap: 28px;
  padding: 28px 32px 32px;
  align-items: start;
  background: #fff;
}

.fab-booking-main {
  min-width: 0;
  -webkit-box-shadow: 0px 4px 25px 0px rgba(86,66,199,0.05);
  box-shadow: 0px 4px 25px 0px rgba(86,66,199,0.05);
  padding: 20px 35px 40px;
  border-radius: 8px !important;
  border: 1px solid #cad5e2;
  background: #FFF;
  overflow: hidden;
}

.fab-booking-stepbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
  padding: 18px 0;
  border-bottom: 1px solid var(--fab-line);
  background: #fff;
}

.fab-step-label {
  display: block;
  margin-bottom: 6px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--fab-muted);
}

.fab-step-title {
  margin: 0;
  font-size: 24px;
  color: var(--fab-ink);
}

.fab-price-chip {
  flex-shrink: 0;
  border-radius: 999px;
  padding: 12px 18px;
  background: linear-gradient(135deg, var(--fab-accent) 0%, #14b8a6 100%);
  color: #fff;
  font-weight: 700;
  font-size: 18px;
}

.fab-booking-summary {
  position: sticky;
  top: 24px;
}

.fab-summary-card {
  border-radius: 12px;
  border: 1px solid #cad5e2;
  background: #fff;
  -webkit-box-shadow: 0px 4px 25px 0px rgba(86, 66, 199, 0.05);
  box-shadow: 0px 4px 25px 0px rgba(86, 66, 199, 0.05);
  overflow: hidden;
}

.fab-summary-kicker {
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.72);
}

.fab-summary-title {
  background-color: #e0e6ec !important; 
  background-image: url("./img/sidebar-clean.jpg");
  background-size: cover;
  background-position: center;
  background-blend-mode: multiply; 
  padding: 36px 24px;
  margin: 0;
  color: #435c78;
  font-size: 23px;
  font-weight: 600;
  text-align: left;
  position: relative;
  border-radius: 8px 8px 0 0 !important;
  text-shadow: 2px 2px 4px #fff;
  font-family: Inter !important;
}

#summaryPostcode {
  font-size: 14px;
  font-weight: 400;
  color: #394e66;
  &:before {
    content: "\e925" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

#summaryDuration {
  font-size: 14px;
  font-weight: 400;
  color: #394e66;
  &:before {
    content: "\e911" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    font-size: 13.8px;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

#summaryDateTime {
  font-size: 14px;
  font-weight: 400;
  color: #394e66;
  &:before {
    content: "\e93d" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

#summaryFrequency {
  font-size: 14px;
  font-weight: 400;
  color: #394e66;
  &:before {
    content: "\e91f" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

#summaryPaymentMethod {
  font-size: 14px;
  font-weight: 400;
  color: #394e66;
  &:before {
    content: "\e917" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

.fab-summary-copy {
  margin: 0 0 20px;
  color: rgba(255, 255, 255, 0.78);
}

.fab-summary-price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.fab-summary-price span {
  color: #435c78;
  font-weight: 800;
  font-size: 20px;
}

.fab-summary-price strong {
  font-size: 25px;
  line-height: 1;
  margin-right: -5px;
  color: #435c78;
}

.fab-summary-list {
  display: grid;
  gap: 12px;
  padding: 24px;
  margin-top: 15px;
}

.fab-summary-item {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 2px 0;
}

.fab-summary-item span {
  color: #394e66;
  font-weight: 500;
  font-size: 16px;
}

.fab-booking-layout > aside > div > div > div:nth-child(10) {
  border-bottom: 1px solid #bfccda;
  margin-bottom: 5px;
  padding-bottom: 10px;
}

.fab-summary-item strong {
  text-align: right;
  color: #394e66;
  font-weight: 500;
  font-size: 16px;
}

.fab-summary-note {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.78);
}

.fab-summary-breakdown {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid #bfccda;
  border-bottom: 1px solid #bfccda;
  margin-bottom: 25px;
  padding-bottom: 25px;
}

.fab-summary-breakdown-title {
  font-size: 16px;
  font-weight: 500;
  text-transform: capitalize;
  margin-bottom: 5px;
  color: #394e66;
  &:before {
    content: "\e91a" !important;
    display: inline-block;
    font-family: Fabs-Icons;
    margin-right: 10px;
    color: #7ca5c0;
    font-weight: 400;
  }
}

.fab-summary-breakdown-list {
  margin: 0;
  padding-left: 18px;
  color: #394e66;
}

.fab-summary-breakdown-list li {
  margin-bottom: 3px;
  margin-left: 8px;
  font-size: 14px;
}

.payform label {
  display: block;
  margin: 0;
}

.payform label > span {
  display: block;
  margin: 0 0 10px;
  color: #41556f;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.3;
}

.payform .field {
  width: 100%;
  height: 53px;
  padding: 0 22px;
  border: 1px solid #e1e7ee;
  border-radius: 8px;
  background: #fff;
  color: #637178;
  font-size: 15px;
  line-height: 1.2;
  box-sizing: border-box;
  outline: none;
  -webkit-box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06);
  box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06);
  transition: border-color 0.2s ease, box-shadow 0.2s ease,
    background-color 0.2s ease;
}

.payform input.field {
  cursor: text;
}

.payform .field::-webkit-input-placeholder {
  color: #97a7be;
}
.payform .field::-moz-placeholder {
  color: #97a7be;
}
.payform .field:-ms-input-placeholder {
  color: #97a7be;
}

.payform .field:focus,
.payform .field.StripeElement--focus {
  border-color: #6a5cff;
  box-shadow: 0 0 0 4px rgba(106, 92, 255, 0.08);
}

.payform .field[readonly] {
  background: #f7f9fc;
  color: #5e7088;
}

.payform button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  min-height: 45px;
  padding: 10px 18px !important;
  border-radius: 4px;
  background: #f3c;
  border: 1px solid #f3c !important;
  color: #fff;
  font-size: 16px !important;
  font-weight: 600;
  transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.payform button:active {
  transform: translateY(0);
}

.payform button[disabled] {
  cursor: not-allowed;
  opacity: 0.7;
  transform: none;
}

.payform .outcome {
  min-height: 22px;
  padding-top: 8px;
  text-align: center;
}

.payform .success,
.error {
  display: none;
  font-size: 13px;
}

.payform .success.visible,
.error.visible {
  display: inline;
}

.payform .error {
  color: #e4584c;
}

.payform .success {
  color: #f8b563;
}

.payform .success .token {
  font-weight: 500;
  font-size: 13px;
}

/* Responsive - Stack on mobile */
@media (max-width: 768px) {
  .fab-step-actions {
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
    padding-top: 18px;
  }

  .fab-back-btn,
  .fab-next-btn {
    width: 100%;
    text-align: center;
    padding: 14px 20px;
    font-size: 16px;
    border-radius: 4px;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .fab-step-actions {
    gap: 10px;
    margin-top: 20px;
    padding-top: 15px;
  }

  .fab-back-btn,
  .fab-next-btn {
    padding: 12px 16px;
    font-size: 16px;
  }
}

/* Large screens - wider buttons */
@media (min-width: 1200px) {
  .fab-back-btn,
  .fab-next-btn {
    padding: 14px 40px;
    font-size: 16px;
  }
}

/*MY CUSTOM CSS IS BELOW HERE*/

label.error {
  color: red;
}

#radioBtn .notActive {
  color: #3276b1;
  background-color: #fff;
}

.fab-booking-plugin .form-group label,
.fab-booking-plugin .col-md-6 > label,
.fab-booking-plugin .col-md-4 > label {
  font-weight: 600;
  color: var(--fab-ink);
}

.fab-booking-plugin .form-control {
  min-height: 50px;
  border: 1px solid var(--fab-line);
  border-radius: 6px;
  box-shadow: none;
  background: #fff;
}

.fab-booking-plugin textarea.form-control {
  min-height: 120px;
}

.fab-personal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px 28px;
  margin-bottom: 18px;
}

.fab-personal-field-wide {
  grid-column: 1 / -1;
}

.fab-personal-input {
  min-height: 49px !important;
  padding: 0 28px !important;
  border-radius: 8px !important;
  border-color: #d6dee9 !important;
  box-shadow: none !important;
  color: #637178 !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  background: #fff !important;
  border: 1px solid #e1e7ee !important;
  -webkit-box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06) !important;
  box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06) !important;
}

.fab-personal-input::placeholder {
  color: #9aa6b6;
  opacity: 1;
}

.fab-personal-input:focus {
  border-color: #6a5cff !important;
  box-shadow: 0 0 0 4px rgba(106, 92, 255, 0.08) !important;
}

/* For select elements */
.fab-personal-select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important ;
  background-repeat: no-repeat !important ;
  background-position: right 12px center !important ;
  background-size: 22px !important ;
  padding-right: 35px !important ;
}

/* Create floating label from placeholder */
.fab-personal-input:focus::placeholder,
.fab-personal-input:not(:placeholder-shown)::placeholder {
  font-size: 11px;
  transform: translateY(-16px);
}

.fab-personal-hidden-field {
  display: none !important;
}

.fab-booking-plugin .btn-success,
.fab-booking-plugin .btn-primary {
  border: 0;
  border-radius: 999px;
  padding: 12px 22px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--fab-accent) 0%, #14b8a6 100%);
  box-shadow: 0 12px 30px rgba(20, 184, 166, 0.22);
}

.fab-booking-plugin .btn-group .btn {
  border-radius: 8px !important;
  margin-right: 8px;
  margin-bottom: 8px;
  border: 1px solid var(--fab-line);
  background: #fff;
  color: var(--fab-ink);
  padding: 10px 12px;
  box-shadow: none;
}

.fab-booking-plugin .btn-group .btn.active {
  background: #fff;
  border-color: #0bb8e3;
  color: #0bb8e3;
  border-width: 1px;
}

/* Radio buttons Option Redesign  */
.radiobtn {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, auto));
  gap: 15px;
  margin-top: 10px;
}

/* Frequency Option Redesign  */
.fab-radio-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, auto));
  gap: 15px;
  margin-top: 10px;
}

.fab-radio-option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  border: 1px solid oklch(86.9% 0.022 252.894) !important;
  border-radius: 8px !important;
  background-color: #fff !important;
  color: #06b6d5 !important;
  line-height: 10px;
  margin: 0;
  text-align: center;
  padding: 16px 12px;
}

/* Hide the default radio button */
.fab-radio-input {
  display: none;
}

/* Center the text and make it full width */
.fab-radio-option span {
  cursor: pointer;
  text-align: center;
  width: 100%;
  font-size: 16px !important;
  font-weight: 500 !important;
  color: #394e66 !important;
}

/* Hover effect */
.fab-radio-option:hover {
  border: 1px solid #06b6d5 !important;
  background: #fff !important;
}

/* Active/Selected state */
.fab-radio-option.active {
  border-color: #06b6d5 !important;
  background-color: #fff !important;
  box-shadow: none !important;
}

.fab-radio-option.active span {
  color: #fff !important;
  font-weight: 500 !important;
  color: #06b6d5 !important;
}

.fab-booking-plugin hr {
  border-top: 1px solid var(--fab-line);
}

.fab-postcode-actions {
  display: grid;
  gap: 8px;
  margin-bottom: 18px;
}

.fab-postcode-helper {
  color: var(--fab-muted);
  font-size: 13px;
}

.fab-postcode-result {
  min-height: 22px;
  font-weight: 500;
  font-size: 13px;
  font-family: Inter;
}


.fab-postcode-result.is-success {
  color: #15803d;
}

.fab-postcode-result.is-error {
  color: #b42318;
}

.fab-postcode-result.is-info {
  color: #0f766e;
}

.fab-extra-title {
  margin: 0 0 8px;
  color: var(--fab-ink);
  font-size: 20px;
}

.fab-extra-subtitle {
  margin: 0 0 16px;
  color: var(--fab-muted);
  font-size: 15px;
}

.fab-subtitle {
  margin: 0 0 16px;
  color: var(--fab-muted);
  font-size: 15px;
  margin-bottom: 20px;
}

/* Add icons to extra */
.fab-extra-card:nth-child(1) .fab-extra-icon {
  background-image: url("./img/double-oven.svg");
}

.fab-extra-card:nth-child(2) .fab-extra-icon {
  background-image: url("./img/window-inside.svg");
}

.fab-extra-card:nth-child(3) .fab-extra-icon {
  background-image: url("./img/fridge-freezer.svg");
}

.fab-extra-card:nth-child(4) .fab-extra-icon {
  background-image: url("./img/washingmachine.png");
}

.fab-discount-block {
  margin: 24px 0 18px;
  padding-bottom: 24px;
  padding-top: 24px;
  border-bottom: 1px dashed #f1f1f4;
}

.fab-discount-title {
  position: absolute;
  top: 19px;
  left: 18px;
  background-color: white;
  padding: 0px 5px;
  font-size: 13px;
  transition: 0.2s;
  pointer-events: none;
  color: #394e66;
  font-weight: 300;
  font-family: "Inter";
}

/* Style the input container */
.fab-discount-block {
  position: relative;
  margin-bottom: 30px;
}

.fab-discount-subtitle {
  margin: 0 0 16px;
  color: var(--fab-muted);
  font-size: 15px;
}

.fab-discount-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 180px;
  gap: 16px;
  align-items: center;
}

.fab-discount-input {
  height: 50px;
  min-height: 50px !important ;
  border-radius: 8px !important ;
}

.fab-discount-apply {
  height: 50px;
  border-radius: 0.5rem !important;
  font-size: 20px;
  border-radius: 0.5rem !important;
  padding: 0.75rem 1rem !important;
  background: #ffffff !important;
  color: #111827;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  border: 1px solid rgb(209, 213, 219) !important;
  -webkit-box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05) !important;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.fab-discount-apply:hover {
  background-color: #f9fafb !important;
  color: #111827;
}

.fab-discount-message {
  min-height: 22px;
  margin-top: 12px;
  font-weight: 600;
}

.fab-discount-message.is-success {
  color: #15803d;
  font-size: 14px;
  font-weight: 400;
}

.fab-discount-message.is-error {
  color: #b42318;
  font-size: 14px;
  font-weight: 400;
}

.fab-discount-message.is-info {
  color: #0f766e;
}

.fab-payment-methods {
  display: grid;
  gap: 18px;
}

.fab-payment-title {
  margin: 0;
  color: var(--fab-ink);
  font-size: 28px;
  line-height: 1.15;
}

.fab-payment-note {
  padding: 0 2px;
  color: #637178;
  font-size: 15px;
  line-height: 1.5;
}

.fab-payment-shell {
  display: grid;
  gap: 10px;
}

.fab-payment-choice-grid {
  grid-template-columns: repeat(2, minmax(220px, 300px));
  gap: 14px;
  justify-content: start;
}

.fab-payment-option {
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  max-height: 50px;
  padding: 14px 12px !important;
  border-radius: 12px !important ;
  border: 1px solid #d6deea;
  background: #fff;
  box-shadow: none;
}

.fab-payment-option.active {
  background: #06b6d5 !important;
  color: #fff !important ;
}

.fab-payment-option.active strong {
  color: #fff !important ;
}

/* Grid container compact */
.fab-payment-choice-grid {
  display: grid !important;
  grid-template-columns: repeat(2, auto) !important;
  gap: 10px !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Optional: Make the grid responsive */
@media (max-width: 640px) {
  .fab-payment-choice-grid {
    grid-template-columns: 1fr !important;
    gap: 15px !important;
  }
}

@media (max-width: 640px) {
  .fab-payment-option {
    min-height: 50px !important;
    padding: 22px 20px;
  }
}

@media (max-width: 640px) {
  .fab-payment-option-copy strong {
    font-size: 15px !important;
  }
}

.fab-payment-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.fab-payment-option-copy {
  flex: 1;
}

.fab-payment-option-copy strong {
  color: #394e66;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.15;
}

.fab-payment-option-indicator {
  position: relative;
  flex: 0 0 auto;
  width: 13px !important;
  height: 13px !important;
  border: 1px solid #cbd7e6;
  border-radius: 999px;
  background: #fff;
  display: none !important;
}

.fab-payment-option-indicator::after {
  content: "";
  position: absolute;
  inset: 2px;
  border-radius: 999px;
  background: transparent;
  transform: scale(0.6);
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.fab-payment-option.active .fab-payment-option-indicator {
  border-color: #6a5cff;
  display: none;
}

.fab-payment-option.active .fab-payment-option-indicator::after {
  background: #6a5cff;
  transform: scale(1);
}

.fab-payment-card {
  padding: 28px;
  padding-left: 0;
}

#payform > div > div.fab-payment-card > div.fab-payment-grid > label > span {
  display: none;
}

.fab-payment-card-header {
  margin-bottom: 22px;
}

.fab-payment-card-title {
  margin: 0 0 8px;
  color: #394e66;
  font-size: 22px;
  font-weight: 400;
}


.fab-payment-card-copy {
  margin: 0;
  color: #267108;
  font-size: 15px;
  line-height: 1.5;
}

.fab-payment-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 22px;
}

.fab-payment-field-wide {
  grid-column: 1 / -1;
}

#card-number-element.field,
#card-expiry-element.field,
#card-cvc-element.field {
  display: block;
  padding-top: 16px;
  padding-bottom: 20px;
}

#card-number-element .__PrivateStripeElement,
#card-expiry-element .__PrivateStripeElement,
#card-cvc-element .__PrivateStripeElement,
#card-number-element iframe,
#card-expiry-element iframe,
#card-cvc-element iframe {
  width: 100% !important;
  min-height: 24px !important;
}

.fab-payment-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.fab-payment-actions .fab-back-btn {
  float: none !important;
  margin-top: 0;
}

.fab-payment-actions #pay {
  margin-left: auto;
  margin-right: 27px;
}

/* SVG padlock icon */
#pay::before {
  content: "\f023" !important ;
  font-family: "fa-solid";
  font-weight: 900 !important;
  display: inline-block !important;
  margin-right: 8px !important ;
  font-size: 14px !important ;
}

.payform button:hover {
  background-color: #fff;
  color: #f3c;
}

/* Responsive - Stack on mobile */
@media (max-width: 768px) {
  .fab-payment-actions {
    flex-direction: column;
    gap: 12px;
    margin-top: 20px;
    padding-top: 18px;
  }

  .fab-back-btn,
  #pay {
    width: 100%;
    text-align: center;
    padding: 14px 20px;
    font-size: 16px;
    border-radius: 4px;
  }
}

/* Extra small devices */
@media (max-width: 480px) {
  .fab-payment-actions {
    gap: 10px;
    margin-top: 20px;
    padding-top: 15px;
  }

  .fab-back-btn,
  #pay {
    padding: 12px 16px;
    font-size: 16px;
  }
}

/* Large screens - wider buttons */
@media (min-width: 1200px) {
  .fab-back-btn,
  #pay {
    padding: 14px 40px;
    font-size: 16px;
  }
}

.fab-schedule-shell {
  display: grid;
  gap: 24px;
}

.fab-schedule-shell #datepicker {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

.fab-week-toolbar {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: center;
}

.fab-week-title {
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  color: #3956d8;
}

.fab-week-nav {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  border: 0;
  background: transparent;
  color: #3956d8;
  font-size: 18px;
  font-weight: 500;
  padding: 0;
}

.fab-week-nav:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.fab-week-nav-next {
  justify-self: end;
}

.fab-week-nav-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 2px solid #6a7cff;
  border-radius: 999px;
  font-size: 28px;
  line-height: 1;
}

.fab-week-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 12px;
}

.fab-weekday-card {
  display: grid;
  justify-items: center;
  gap: 1px;
  height: 55px !important;
  padding: 9px 5px;
  border: 1px solid #e4eaf5;
  border-radius: 6px;
  background: #fff;
  color: var(--fab-ink);
  -webkit-box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06);
  box-shadow: 0px 2px 10px 0px rgba(86, 66, 199, 0.06);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.fab-weekday-card:hover:not(:disabled) {
  transform: translateY(-1px);
  border-color: #c8d4ff;
}

.fab-weekday-card.is-selected {
  border-color: #06b6d5;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(106, 124, 255, 0.08);
}

.fab-weekday-card.is-disabled,
.fab-weekday-card:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  background: #fff;
}

.fab-weekday-name {
  font-size: 10px;
  font-weight: 700;
  color: #2f3640;
  text-transform: uppercase;
}

.fab-weekday-number {
  font-size: 18px;
  line-height: 1;
  font-weight: 400;
  color: #2f3640;
}

.fab-slot-heading {
  font-size: 20px;
  color: #2b3139;
}

.fab-slot-heading strong {
  font-weight: 700;
}

.fab-slot-groups {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 30px !important;
  align-items: start;
  border-top: 1px solid #f1f1f4;
  padding-top: 50px;
  border-bottom: 1px dashed #f1f1f4;
  padding-bottom: 50px;
}

.fab-slot-group {
  display: grid;
  gap: 12px;
}

.fab-slot-group-title {
  margin: 0;
  text-align: center;
  font-size: 18px;
  font-weight: 400;
  color: #2f3640;
  font-family: Inter;
}

.fab-slot-card {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  padding: 14px 16px;
  border: 1px solid #dbe3ec;
  border-radius: 6px;
  background: #fff;
  color: #2f3640 !important;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.fab-slot-card:hover {
  text-decoration: none;
  color: #06b6d5 !important ;
  border-color: #06b6d5;
}

.fab-slot-card.active {
  border-color: #06b6d5;
  background: #fff;
  color: #06b6d5 !important ;
  box-shadow: 0 0 0 1px rgba(106, 124, 255, 0.08);
  text-decoration: none;
}

.fab-slot-card.disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.fab-slot-badge {
  position: absolute;
  top: -10px;
  right: 16px;
  padding: 4px 10px;
  border-radius: 999px;
  background: #68b9ce;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.1;
  text-shadow: 2px 2px 4px #000000;
}

/* Custom calendar previous icon */
#fabPrevWeek .fab-week-nav-icon {
  visibility: hidden;
  position: relative;
  &:before {
    content: "\e906";
    font-family: Fabs-Icons;
    font-size: 15px;
    position: absolute;
    top: 86px;
    right: 50px;
    visibility: visible;
    color: #f3c;
  }
}

/* Custom calendar next icon */
.fab-week-nav-next .fab-week-nav-icon {
  visibility: hidden;
  position: relative;
  &:before {
    content: "\e907";
    font-family: Fabs-Icons;
    font-size: 15px;
    position: absolute;
    top: 86px;
    left: 50px;
    visibility: visible;
    color: #f3c;
  }
}

/* Custom calendar previous icon mobile */
@media (max-width: 768px) {
  #fabPrevWeek .fab-week-nav-icon {
    visibility: hidden;
    position: relative;
    &:before {
      content: "\e906";
      font-family: Fabs-Icons;
      font-size: 15px;
      position: absolute;
      top: 110px;
      right: 130px;
      visibility: visible;
      color: #f3c;
    }
  }
}

/* Custom calendar next icon mobile */
@media (max-width: 768px) {
  .fab-week-nav-next .fab-week-nav-icon {
    visibility: hidden;
    position: relative;
    &:before {
      content: "\e907";
      font-family: Fabs-Icons;
      font-size: 15px;
      position: absolute;
      top: 8px;
      left: 130px;
      visibility: visible;
      color: #f3c;
    }
  }
}

.fab-week-title {
  text-align: center;
  font-size: 18px !important;
  font-weight: 300 !important;
  color: #394e66 !important;
}

/* Hide text spans */
.fab-week-nav span:not(.fab-week-nav-icon) {
  display: none;
}

#cleaningType {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="%230BB8E3" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="6 9 12 15 18 9"></polyline></svg>');
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 22px;
  border-radius: 8px;
  padding-right: 35px;
  cursor: pointer;
  color: #394e66;
  font-size: 16px;
  font-weight: 300;
  font-family: "Inter";
  margin-bottom: 30px;
}

/* Postal code */
#postalCode {
  text-transform: uppercase;
  border-radius: 8px;
}

/* post code redesign Position the form group relative for pseudo-element */
#form1 .form-group:has(#postalCode) {
  position: relative;
}

/* Add icon as pseudo-element postcode */
#form1 .form-group:has(#postalCode)::before {
  content: "\e92d";
  position: absolute;
  font-family: Fabs-Icons;
  left: 12px;
  bottom: 13px;
  font-size: 16px;
  color: #0bb8e3;
  pointer-events: none;
  z-index: 1;
}

/* Add padding to input to make room for icon */
#postalCode {
  padding-left: 35px;
}

/* Target the label when it's inside the same form-group as the postal code */
#form1 .form-group:has(#postalCode) label {
  position: absolute;
  top: 13px;
  left: 30px;
  background-color: white;
  padding: 0px 5px;
  font-size: 16px;
  transition: 0.2s;
  pointer-events: none;
  color: #394e66;
  font-weight: 300;
  font-family: "Inter";
}

/* Style the input container */
#form1 .form-group:has(#postalCode) {
  position: relative;
  margin-bottom: 30px;
}

/* Float label on focus */
#postalCode:focus + label {
  top: -8px !important;
  left: 18px !important;
  font-size: 12px !important;
  color: #394e66 !important;
}

/* Keep label floated when input has value */
#postalCode:not(:placeholder-shown) + label {
  top: -8px !important;
  left: 18px !important;
  font-size: 12px !important;
  color: #444;
}

/* Change autofill text background */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
textarea:-webkit-autofill:active,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
select:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px white inset !important;
  -webkit-text-fill-color: #637178 !important;
}

.fab-booking-plugin #postalCode.fab-checking {
  border-color: #75c9c0;
  box-shadow: 0 0 0 1px rgba(15, 118, 110, 0.08);
  background: #f3fbfa;
}

.fab-booking-plugin #postalCode.fab-valid {
  border-color: #86d19d;
  box-shadow: 0 0 0 1px rgba(22, 163, 74, 0.08);
  background: #fff;
}

.fab-booking-plugin #postalCode.fab-invalid {
  border-color: #f0a6a6;
  box-shadow: 0 0 0 1px rgba(180, 35, 24, 0.08);
  background: #fff;
}

@media (max-width: 991px) {
  .fab-booking-layout {
    grid-template-columns: 1fr;
  }

  .fab-booking-summary {
    position: static;
  }

  .fab-booking-stepbar {
    flex-direction: column;
    align-items: flex-start;
  }

  .fab-week-grid,
  .fab-slot-groups {
    grid-template-columns: 1fr;
  }

  .fab-week-toolbar {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .fab-week-nav-next {
    justify-self: center;
  }
}

@media (max-width: 640px) {
  .fab-booking-dialog {
    margin: 16px auto;
  }

  .fab-booking-header,
  .fab-booking-layout {
    padding-left: 18px;
    padding-right: 18px;
  }

  .fab-booking-header .modal-title {
    font-size: 28px;
  }

  .payform {
    width: 100%;
  }

  .payform .field {
    min-height: 58px;
  }

  .fab-discount-row {
    grid-template-columns: 1fr;
  }

  .fab-personal-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .fab-personal-input {
    min-height: 48px !important;
    font-size: 15px !important;
    padding: 0 22px !important;
  }

  .fab-payment-choice-grid,
  .fab-payment-grid {
    grid-template-columns: 1fr;
  }

  .fab-payment-option {
    min-height: 108px;
    padding: 22px 20px;
  }

  .fab-payment-option-copy strong {
    font-size: 20px;
  }

  .fab-payment-card {
    padding: 22px 18px;
  }

  @media (max-width: 640px) {
    .fab-payment-card {
      padding: 1px;
    }
  }

  .fab-payment-actions {
    justify-content: stretch;
  }

  .payform button {
    width: 100%;
    min-width: 0;
  }
}

/**************************************************************************
    custom css I made
***************************************************************************/
.marginTop10 {
  margin-top: 10px !important;
}

.marginTop20 {
  margin-top: 20px !important;
}

.marginTop30 {
  margin-top: 30px !important;
}

.marginTop40 {
  margin-top: 40px !important;
}

.marginTop50 {
  margin-top: 50px !important;
}

.marginTop60 {
  margin-top: 60px !important;
}

.marginTop70 {
  margin-top: 70px !important;
}

.marginTop80 {
  margin-top: 80px !important;
}

.marginTop90 {
  margin-top: 90px !important;
}

.marginBottom20 {
  margin-bottom: 20px !important;
}

.marginBottom30 {
  margin-bottom: 30px !important;
}

.marginBottom40 {
  margin-bottom: 40px !important;
}

.marginBottom50 {
  margin-bottom: 50px !important;
}

.marginBottom60 {
  margin-bottom: 60px !important;
}

.marginBottom70 {
  margin-bottom: 70px !important;
}

.marginBottom80 {
  margin-bottom: 80px !important;
}

.marginBottom90 {
  margin-bottom: 90px !important;
}

.fabheading {
  color: #435c78 !important;
  font-size: 26px !important;
  font-weight: 500 !important;
  font-family: Inter !important;
}

.picker-heading {
  font-weight: 400 !important;
  color: #64748b !important;
  font-size: 14px !important;
  font-family: "Inter" !important;
}

/*******************************************************************
  picker button
********************************************************************/

.input-group .form-control:not(:first-child):not(:last-child) {
  text-align: center !important  ;
  color: #73788f !important;
  font-family: "Nunito Sans", sans-serif !important;
  font-size: 14px;
}

input::-webkit-inner-spin-button {
  visibility: hidden;
}

/* For WebKit browsers (Chrome, Safari) */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Hide in Firefox */
input[type="number"] {
  -moz-appearance: textfield;
}

/* Custom plus icon */
.fab-booking-plugin .input-group-btn .bootstrap-touchspin-up {
  visibility: hidden;
  position: relative;
  &:before {
    content: "\e936";
    font-family: Fabs-Icons;
    font-size: 10px;
    position: absolute;
    top: 13px;
    visibility: visible;
    color: #0bb8e3;
  }
}

/* Custom minus icon */
.fab-booking-plugin .input-group-btn .bootstrap-touchspin-down {
  visibility: hidden;
  position: relative;
  &:before {
    content: "\e92f";
    font-family: Fabs-Icons;
    font-size: 11px;
    position: absolute;
    top: 13px;
    left: 13px;
    visibility: visible;
    color: #63788f;
  }
}

.fab-booking-plugin .input-group .form-control {
  height: 39px !important;
  min-height: 39px !important;
  border: 1px solid oklch(86.9% 0.022 252.894) !important;
  border-radius: 16px;
  box-shadow: none;
  background: #fff;
}

.input-group-btn {
  height: 39px !important;
}

.fab-booking-plugin span.input-group-btn:first-child {
  border-top-left-radius: 4px !important;
  border-bottom-left-radius: 4px !important;
  border: 1px solid oklch(86.9% 0.022 252.894);
  border-right: none !important;
}

.fab-booking-plugin span.input-group-btn:last-child {
  border-top-right-radius: 4px !important;
  border-bottom-right-radius: 4px !important;
  border: 1px solid oklch(86.9% 0.022 252.894);
  border-left: none !important;
}

/***********************************************************************
  choose  extra items blocks
************************************************************************/

.fab-extra-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 15px;
  border: 1px solid #cfd6e5;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
  background: white;
  gap: 8px;
  min-height: 135px;
}

/* Strong tag (title) - appears at bottom */
.fab-extra-card strong {
  font-size: 14px;
  font-weight: 600;
  color: #394e66;
  order: 2;
}

/* Icon container with animations */
.fab-extra-icon {
  display: block;
  width: 48px;
  height: 48px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  order: 1;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  color: #666;
}

/* Hover animation */
.fab-extra-card:hover .fab-extra-icon {
  transform: scale(1.1);
  color: #4caf50;
}

/* Checked state */
.fab-extra-card:has(.fab-extra-checkbox:checked) .fab-extra-icon {
  color: #4caf50;
  transform: scale(1.05);
}

/* Hide the checkbox visually but keep it accessible */
.fab-extra-checkbox {
  position: absolute;
  margin-top: -100px;
  margin-right: 100px;
}

/* Optional: Style for checked state */
.fab-extra-card:has(.fab-extra-checkbox:checked) {
  border: 1px solid rgb(0 0 0 / 18%);
  background-color: rgb(241 245 249);
}

/* Grid layout for the cards */
.fab-extra-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 15px;
  margin-top: 20px;
}

/* Optional: Add hover effect */
.fab-extra-card:hover {
  border: 1px solid oklch(86.9% 0.022 252.894);
  background: rgb(241 245 249);
}

@media (max-width: 768px) {
  .separate-containers .inside-article,
  .separate-containers .comments-area,
  .separate-containers .page-header,
  .separate-containers .paging-navigation,
  .one-container .site-content,
  .inside-page-header {
    padding: 60px 10px 60px 10px;
  }
}

@media (max-width: 640px) {
  .fab-booking-layout {
    padding-left: 1px;
    padding-right: 1px;
  }
}
