/*!
Theme Name: CBD
Theme URI: https://www.cbwebsitedesign.co.uk/
Author: Creative Brand Design
Author URI: https://www.cbwebsitedesign.co.uk/
Description: Creative Brand Design
Version: 6.3
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: cbd
*/

/* Admin Bar */
.admin-bar .booking-header {
  margin-top: 32px;
}

.admin-bar .sidebar {
  top: 32px;
}

.admin-bar .wrapper > header + main {
  margin-top: 0;
}

.admin-bar .wrapper > main {
	margin-top: 32px;
}

.admin-bar .toastify {
  top: calc(0.5rem + 32px) !important;
}

@media (min-width: 992px) {
  .admin-bar .sidebar {
    height: calc(100% - 32px);
  }
}

@media (max-width: 991px) {
  .admin-bar .sidebar__body {
    top: calc(5.5rem + 32px);
    height: calc(100% - 5.5rem - 32px);
  }

  .admin-bar .wrapper.wrapper--sidebar > main {
    margin-top: calc(5.5rem + 32px);
  }
}

@media (max-width: 782px) {
  .admin-bar .booking-header {
    margin-top: 46px;
  }

  .admin-bar .sidebar {
    top: 46px;
  }

  .admin-bar .sidebar__body {
    top: calc(5.5rem + 46px);
    height: calc(100% - 5.5rem - 46px);
  }

  .admin-bar .wrapper > main {
    margin-top: 46px;
  }

  .admin-bar .wrapper.wrapper--sidebar > main {
    margin-top: calc(5.5rem + 46px);
  }

  .admin-bar .toastify {
    top: calc(0.5rem + 46px) !important;
  }
}

@media (max-width: 600px) {
  #wpadminbar {
    position: fixed;
  }
}

/* Errors */
form .success-message {
  margin-top: 1.5rem;
  color: #00a32a;
}

form .error-message {
	margin-top: 1.5rem;
	color: #d63638;
}

form .error-field {
	border-color: #d63638;
}

form .error-field.checkbox {
  color: #d63638;
}

form .error-field .checkbox__mark {
  border-color: #d63638;
}

/* Ajax */
.ajax_loading {
  position: relative;
  pointer-events: none;
}

.ajax_loading:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.75);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 9;
}

.ajax_loading:after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url(img/loader.gif) center / 5rem no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
}

/* Gravity Forms */
.form .gform_required_legend {
  display: none;
}

.form .gform_wrapper.gravity-theme .gform_fields {
    grid-column-gap: 1rem;
    grid-row-gap: 1.5rem;
}

.form .gform_wrapper.gravity-theme .gfield_label {
    font-weight: 400;
    letter-spacing: -0.08rem;
}

.form .gform_wrapper.gravity-theme .gfield input,
.form .gform_wrapper.gravity-theme .gfield textarea,
.form .gform_wrapper.gravity-theme .gfield select {
  display: block;
  outline: none;
  border: 0.0625rem solid #ebeded;
  border-radius: 0.5rem;
  width: 100%;
  padding: 0.6875rem 1rem;
  background-color: #f5f5f5;
  font-size: 1rem;
  line-height: 1;
  color: #020203;
  resize: none;
  transition: border-color 0.35s, padding 0.35s;
}

.form .gform_wrapper.gravity-theme .gfield input::placeholder,
.form .gform_wrapper.gravity-theme .gfield textarea::placeholder,
.form .gform_wrapper.gravity-theme .gfield select::placeholder {
  color: #888989;
}

.form .gform_wrapper.gravity-theme .gfield input:focus,
.form .gform_wrapper.gravity-theme .gfield textarea:focus,
.form .gform_wrapper.gravity-theme .gfield select:focus,
.form .gform_wrapper.gravity-theme .gfield input:hover,
.form .gform_wrapper.gravity-theme .gfield textarea:hover,
.form .gform_wrapper.gravity-theme .gfield select:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.form .gform_wrapper.gravity-theme .gfield textarea {
  resize: none;
}

.form .gform_wrapper.gravity-theme .gfield textarea.medium {
    height: 156px;
}

.form .gform_wrapper.gravity-theme .gchoice input {
  display: none;
}

.form .gform_wrapper.gravity-theme .gchoice label {
  position: relative;
  cursor: pointer;
  max-width: 100%;
  padding-left: 2rem;
  line-height: 1.6;
  color: #888989;
}

.form .gform_wrapper.gravity-theme .gchoice label:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  border: 0.0625rem solid #ebeded;
  border-radius: 0.375rem;
  width: 1.5rem;
  height: 1.5rem;
  background-color: #fff;
  transition: all 0.35s ease;
}

.form .gform_wrapper.gravity-theme .gchoice input:checked + label:before {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
}

.form .gform_wrapper.gravity-theme .gfield_radio label:before {
  border-radius: 50%;
}

.form .gform_wrapper.gravity-theme .gchoice label:after {
  content: "";
  position: absolute;
  left: 0.55rem;
  top: 0.15rem;
  border: solid #fff;
  border-width: 0 0.1875rem 0.1875rem 0;
  width: 0.5rem;
  height: 0.9375rem;
  opacity: 0;
  visibility: hidden;
  transform: rotate(45deg);
  transition: all 0.35s ease;
}

.form .gform_wrapper.gravity-theme .gfield_radio label:after {
  width: 0.8rem;
  height: 0.8rem;
  background-color: #fff;
  border: none;
  border-radius: 50%;
  top: 0.35rem;
  left: 0.35rem;
}

.form .gform_wrapper.gravity-theme .gchoice input:checked + label:after {
  opacity: 1;
  visibility: visible;
}

.form .gform_wrapper.gravity-theme .gform_footer {
    margin: 1.5rem 0 0;
    padding: 0;
}

.form .gform_wrapper.gravity-theme .gform_footer button {
  width: 100%;
  margin: 0;
}

.form .gform_wrapper.gravity-theme a {
    text-decoration: underline;
    transition: color 0.35s;
}

.form .gform_wrapper.gravity-theme a:hover {
    color: var(--color-primary);
}

.form .gform_wrapper.gravity-theme .gform_validation_errors {
  background: none;
  margin: 0 0 1.5rem;
  padding: 0;
  border: none;
  box-shadow: none;
}

.form .gform_wrapper.gravity-theme .gform_validation_errors > h2 {
  font-size: inherit;
  letter-spacing: 0;
}

.form .gform_wrapper.gravity-theme .gfield_validation_message {
  background: none;
  padding: 0;
  border: none;
}

.form .gform_wrapper.gravity-theme .gfield_error label {
  color: #c02b0a;
}

.form .gform_wrapper.gravity-theme .gfield_error [aria-invalid=true],
.form .gform_wrapper.gravity-theme .gfield_error .gchoice label:before {
  border-color: #c02b0a;
}

@media (min-width: 1280px) {
  .form .gform_confirmation_message {
    max-width: 75%;
    margin: 0 auto;
  }
}

.form .gform_confirmation_message > *:not(:last-child) {
  margin-bottom: 1.5rem;
}

.form .gform_confirmation_message p {
  color: #888989;
}

.form .gform_ajax_spinner {
  object-fit: contain;
}

/* Header */
.booking-header__logo img {
  object-fit: contain;
}

/* Main */
@media (max-width: 991px) {
  .wrapper.wrapper--sidebar > main {
    margin-top: 5.5rem;
  }
}

/* Sidebar */
@media (min-width: 991px) {
  body.booking .wrapper--sidebar {
    padding-left: 0;
  }

  body.booking .sidebar {
    display: none;
  }
}

@media (max-width: 991px) {
  body.booking .booking-header {
    display: none;
  }
}

/* Thank You */
@media (min-width: 992px) {
  .section-thankyou .section-login__text {
    min-height: calc(100vh - 6rem - 72px);
  }

  .admin-bar .section-thankyou .section-login__text {
    min-height: calc(100vh - 6rem - 72px - 32px);
  }
}

/* Profile */
.sidebar__img img {
  border-radius: 50%;
}

.profile-img__img > span {
  display: inline-flex;
  width: inherit;
  height: inherit;
}

.profile-img__img .noavatar-img img {
  width: auto;
  height: auto;
  margin: auto;
}

.profile-img__btn input {
  display: none;
}

/* No Found */
.nofound {
  color: #888989;
}

/* Event Image */
.booking-card__img,
.h-event-header__img {
  display: none;
}

/* Booking Form */
.booking-form .gform_ajax_spinner {
  object-fit: contain;
}

.booking-form .gform_wrapper.gravity-theme .gf_progressbar {
  height: 0.25rem;
  margin-bottom: 1.5rem;
  border-radius: 0.25rem;
  background: #f5f5f5;
}

.booking-form .gform_wrapper.gravity-theme .gf_progressbar_percentage.percentbar_blue {
  background-color: var(--color-primary);
  border-radius: inherit;
  height: inherit;
}

.booking-form .gform_wrapper.gravity-theme .gf_progressbar_percentage.percentbar_blue > span {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gform_fields {
  grid-column-gap: 1rem;
  grid-row-gap: 1.5rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield_html > h2 {
  margin-bottom: 1rem;
  text-align: center;
}

.booking-form .gform_wrapper.gravity-theme .gfield_html > h3 {
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.05em;
  margin-bottom: 1.5rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield_required {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield_label {
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.05em;
  margin-bottom: 1.5rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield.hide {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield input,
.booking-form .gform_wrapper.gravity-theme .gfield textarea,
.booking-form .gform_wrapper.gravity-theme .gfield select {
  display: block;
  outline: none;
  border: 0.0625rem solid #ebeded;
  border-radius: 0.5rem;
  width: 100%;
  padding: 0.6875rem 1rem;
  background-color: #f5f5f5;
  font-size: 1rem;
  line-height: 1;
  color: #020203;
  resize: none;
  transition: border-color 0.35s, padding 0.35s;
}

.booking-form .gform_wrapper.gravity-theme .gfield input::placeholder,
.booking-form .gform_wrapper.gravity-theme .gfield textarea::placeholder,
.booking-form .gform_wrapper.gravity-theme .gfield select::placeholder {
  color: #888989;
}

.booking-form .gform_wrapper.gravity-theme .gfield input:focus,
.booking-form .gform_wrapper.gravity-theme .gfield textarea:focus,
.booking-form .gform_wrapper.gravity-theme .gfield select:focus,
.booking-form .gform_wrapper.gravity-theme .gfield input:not(:disabled):hover,
.booking-form .gform_wrapper.gravity-theme .gfield textarea:not(:disabled):hover,
.booking-form .gform_wrapper.gravity-theme .gfield select:not(:disabled):hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.booking-form .gform_wrapper.gravity-theme .gfield textarea {
  resize: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield textarea.medium {
    height: 152px;
}

.booking-form .gform_wrapper.gravity-theme .gchoice input[type=checkbox],
.booking-form .gform_wrapper.gravity-theme .gchoice input[type=radio] {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield_radio {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.booking-form .gform_wrapper.gravity-theme .gchoice label {
  position: relative;
  cursor: pointer;
  max-width: 100%;
  padding-left: 2rem;
  line-height: 1.6;
  color: #888989;
}

.booking-form .gform_wrapper.gravity-theme .gchoice label:before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  border: 0.0625rem solid #ebeded;
  border-radius: 0.375rem;
  width: 1.5rem;
  height: 1.5rem;
  background-color: #fff;
  transition: all 0.35s ease;
}

.booking-form .gform_wrapper.gravity-theme .gchoice input:checked + label:before {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield_radio label:before {
  border-radius: 50%;
}

.booking-form .gform_wrapper.gravity-theme .gchoice label:after {
  content: "";
  position: absolute;
  left: 0.55rem;
  top: 0.15rem;
  border: solid #fff;
  border-width: 0 0.1875rem 0.1875rem 0;
  width: 0.5rem;
  height: 0.9375rem;
  opacity: 0;
  visibility: hidden;
  transform: rotate(45deg);
  transition: all 0.35s ease;
}

.booking-form .gform_wrapper.gravity-theme .gfield_radio label:after {
  width: 0.8rem;
  height: 0.8rem;
  background-color: #fff;
  border: none;
  border-radius: 50%;
  top: 0.35rem;
  left: 0.35rem;
}

.booking-form .gform_wrapper.gravity-theme .gchoice input:checked + label:after {
  opacity: 1;
  visibility: visible;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice input[type=radio] {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gfield_radio {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0.5rem;
}

.booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(1) .radio-buttons .gchoice:last-child,
.booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(3) .radio-buttons .gchoice:last-child {
  width: 100%;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice label {
  display: inline-block;
  cursor: pointer;
  border: 0.0625rem solid #ebeded;
  border-radius: 2.5rem;
  max-width: 100%;
  padding: 0.5rem 1rem;
  text-align: center;
  transition: border-color 0.35s, color 0.35s, background-color 0.35s;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice label:before,
.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice label:after {
  content: none;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice label:hover,
.booking-form .gform_wrapper.gravity-theme .radio-buttons .gchoice input:checked + label {
    border-color: var(--color-primary);
    background-color: var(--color-primary-light);
    color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(1) .radio-buttons .gchoice:last-child input[type=text] {
  max-width: 10rem;
}

.booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(3) .radio-buttons .gchoice:last-child input[type=text] {
  max-width: 100%;
}

.booking-form .gform_wrapper.gravity-theme .radio-buttons .gfield_radio input[type=text]:disabled {
  opacity: 0.55;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload .gfield_description:not(.validation_message),
.booking-form .gform_wrapper.gravity-theme .radio-buttons .gfield_description:not(.validation_message) {
  padding-top: 0.5rem;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.32;
  letter-spacing: -0.015rem;
  color: #888989;
}

@media (max-width: 480px) {
  .booking-form .gform_wrapper.gravity-theme #downloadable-documents .col-xs-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-name .ginput_complex label {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload input[type=file] {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 0.0625rem dashed #dcdede;
  border-radius: 0.5rem;
  padding: 3.5rem 1rem 1rem;
  background: #f5f5f5 url(img/icons/cloud-upload.svg) 50% 0.5rem / 40px no-repeat;
  font-size: 0;
  transition: border-color var(--transition-duration-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload input[type=file]:hover,
.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload input[type=file]:focus {
  background-color: #f5f5f5;
  border-color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload input[type=file]::file-selector-button {
  cursor: pointer;
  width: 100%;
  display: flex;
  justify-content: center;
  background: none;
  border: none;
  font-size: 0.75rem;
  font-weight: inherit;
  text-decoration: underline;
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-fileupload .gform_fileupload_rules {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gform_drop_area {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  margin-bottom: 0.5rem;
  padding: 3.5rem 1rem 2rem;
  background: #f5f5f5 url(img/icons/cloud-upload.svg) 50% 0.5rem / 40px no-repeat;
  border: 0.0625rem dashed #dcdede;
  border-radius: 0.5rem;
  font-size: 0.75rem;
  font-weight: 400;
  transition: border-color var(--transition-duration-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_drop_area:hover {
  border-color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_drop_area .gform_drop_instructions {
  color: #888989;
  margin-bottom: 0;
  line-height: inherit;
}

.booking-form .gform_wrapper.gravity-theme .gform_drop_area button {
  cursor: pointer;
  background: none;
  border: none;
  text-decoration: underline;
  color: var(--color-primary);
  line-height: inherit;
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  margin: 0;
  padding: 1rem 0;
  border-bottom: 0.0625rem solid #ebeded;
}

.booking-form-2 .gform_wrapper.gravity-theme .ginput_preview:before {
  content: '';
  width: 30px;
  height: 36px;
  background: url(img/icons/pdf.svg) 50% / contain no-repeat;
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gfield_fileupload_filename {
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.32;
  letter-spacing: -0.015em;
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file {
  margin-left: auto;
  margin-right: 0.75rem;
  line-height: 1;
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file .dashicons-trash {
  position: relative;
  width: 15px;
  height: 15px;
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file .dashicons-trash:before,
.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file .dashicons-trash:after {
  content: '';
  position: absolute;
  left: 50%;
  height: 100%;
  width: 1.5px;
  background-color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file .dashicons-trash:before {
  transform: rotate(45deg);
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gform_delete_file .dashicons-trash:after {
  transform: rotate(-45deg);
}

.booking-form .gform_wrapper.gravity-theme .ginput_preview .gfield_fileupload_filesize,
.booking-form .gform_wrapper.gravity-theme .ginput_preview .gfield_fileupload_progress {
  display: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-repeater .gfield_repeater_item {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater .gfield_repeater_items .gfield_repeater_item:not(:last-child) {
  margin: 0 0 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #EBEDED;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_cell {
  margin-top: 0;
  padding: 0;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_cell label {
  padding: 0;
  font-size: 1rem;
  color: #020203;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_items .gfield_repeater_cell,
.booking-form .gform_wrapper.gravity-theme .gfield_repeater_items .gfield_repeater_cell:not(:first-child) {
  width: 100%;
  margin: 0;
  padding: 0;
}

@media (min-width: 641px) {
  .booking-form .gform_wrapper.gravity-theme .gfield_repeater_items .gfield_repeater_cell:not(:first-child) {
    width: calc(50% - 0.5rem);
  }
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_buttons {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding-top: 0.5rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_buttons button {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
  justify-content: center;
  margin: 0;
  outline: none;
  border: 0.0625rem solid var(--color-primary);
  border-radius: 3rem;
  min-height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: var(--color-primary);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.02rem;
  white-space: nowrap;
  text-align: center;
  color: #fff;
  cursor: pointer;
  transition: background-color 0.35s, border-color 0.35s, color 0.35s;
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_buttons button:hover {
  background-color: transparent;
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_buttons .add_repeater_item {
  border-color: var(--color-primary);
  background-color: transparent;
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield_repeater_buttons .add_repeater_item:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary);
  color: #fff;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-product {
  position: absolute;
  visibility: hidden;
  opacity: 0;
  height: 0;
}

.booking-form .gform_wrapper.gravity-theme .extras .gfield_checkbox {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.booking-form .gform_wrapper.gravity-theme .extras .gchoice {
  width: 100%;
  margin-bottom: 1rem;
}

@media (min-width: 641px) {
  .booking-form .gform_wrapper.gravity-theme .extras .gchoice {
    width: calc(33% - 0.55rem);
  }
}

.booking-form .gform_wrapper.gravity-theme .extras .gchoice label {
  position: static;
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #fff;
  margin-bottom: 1rem;
  padding: 1.5rem;
  border: 0.0625rem solid #ebeded;
  border-radius: 0.5rem;
  text-align: center;
  font-weight: 400;
  font-size: 1.25rem;
  color: inherit;
  letter-spacing: -0.05em;
  line-height: 1.2;
  transition: border-color 0.35s, background-color 0.35s;
}

@media (min-width: 992px) {
  .booking-form .gform_wrapper.gravity-theme .extras .gchoice label {
    padding: 1.5rem 3.5rem;
  }
}

.booking-form .gform_wrapper.gravity-theme .extras .gchoice input:checked + label,
.booking-form .gform_wrapper.gravity-theme .extras .gchoice label:hover {
  border-color: var(--color-primary);
  background-color: var(--color-primary-light);
}

.booking-form .gform_wrapper.gravity-theme .extras .gchoice label span {
  display: block;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  font-size: 1rem;
  line-height: 1;
  letter-spacing: -0.02rem;
  color: inherit;
}

@media (min-width: 1280px) {
  .booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(4) .gfield--type-total {
    width: 66%;
    margin-left: auto;
    margin-right: auto;
  }
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-total {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 0.5rem;
  min-height: 2.5rem;
  padding: 0.75rem 1rem;
  background-color: var(--color-primary-light);
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-total label {
  width: 50%;
  margin: 0;
  text-align: right;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1.32;
  letter-spacing: -0.015rem;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-total .ginput_container_total {
  width: 50%;
}

.booking-form .gform_wrapper.gravity-theme .gfield--type-total input {
  display: flex;
  width: auto;
  padding: 0;
  background: none;
  border: none;
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: -0.015rem;
  color: inherit;
}

.booking-form .gform_wrapper.gravity-theme .gfield_html .info {
  margin: 2.5rem 0;
  padding: 0.75rem 0.75rem 0.75rem 4.5rem;
  border: 0.0625rem solid #f9b332;
  border-radius: 0.5rem;
  background: #fff6e8 url(img/icons/alert-warning.svg) 1rem 50% / 40px no-repeat;
}

.booking-form .gform_wrapper.gravity-theme .gfield_html .info[data-modal-target] {
  cursor: pointer;
}

.booking-form .gform_wrapper.gravity-theme label a {
    text-decoration: underline;
    transition: color 0.35s;
}

.booking-form .gform_wrapper.gravity-theme label a:hover {
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_footer,
.booking-form .gform_wrapper.gravity-theme .gform_page_footer {
  display: flex;
  gap: 1rem;
  margin: 1rem 0 0;
  padding: 0;
}

.booking-form .gform_wrapper.gravity-theme .gform_page_footer .button {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0;
  outline: none;
  border: 0.0625rem solid var(--color-primary);
  border-radius: 3rem;
  min-height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: var(--color-primary);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.02rem;
  white-space: nowrap;
  text-align: center;
  color: #fff;
  cursor: pointer;
  transition: background-color 0.35s, border-color 0.35s, color 0.35s;
}

.booking-form .gform_wrapper.gravity-theme .gform_page_footer .button:hover {
  background-color: transparent;
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_page_footer .gform-theme-button--secondary {
  border-color: var(--color-primary);
  background-color: transparent;
  color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_page_footer .gform-theme-button--secondary:hover {
    border-color: var(--color-primary);
    background-color: var(--color-primary);
    color: #fff;
}

.booking-form .gform_wrapper.gravity-theme .gform_footer .btn,
.booking-form .gform_wrapper.gravity-theme .gform_page_footer .button {
  max-width: 50%;
}

.booking-form .gform_wrapper.gravity-theme .gform_footer .btn,
.booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(1) .gform_page_footer .button {
  margin-left: auto;
  margin-right: auto;
}

.booking-form .gform_wrapper.gravity-theme .gform_footer .btn,
.booking-form .gform_wrapper.gravity-theme .gform_page_footer button[type=submit] {
  width: 100%;
  margin-bottom: 0;
}

.booking-form #ga_appointments_calendar {
  background: var(--color-white);
  border: 0.0625rem solid #ebeded;
  border-radius: 0.5rem;
  margin: 0;
  padding: 1rem;
  box-shadow: none;
}

.booking-form .ga_appointments_calendar_header {
  margin-bottom: 1rem;
  padding: 0;
}

.booking-form .ga_appointments_calendar_header .arrow-left, 
.booking-form .ga_appointments_calendar_header .arrow-right {
  --btn-size: 2.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0.0625rem solid var(--color-primary);
  border-radius: var(--btn-size);
  width: var(--btn-size);
  height: var(--btn-size);
  font-size: 1em;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  color: var(--color-primary);
  user-select: none;
  color: #238799 !important;
  transition: background-color var(--transition-duration-primary), box-shadow var(--transition-duration-primary), color var(--transition-duration-primary);
}

.booking-form .ga_appointments_calendar_header .arrow-left:hover, 
.booking-form .ga_appointments_calendar_header .arrow-right:hover {
    background: #238799;
    color: #fff !important;
}

.booking-form .ga_appointments_calendar_header h3 {
  text-transform: none;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.05rem;
}

.booking-form .ga_monthly_schedule_wrapper thead th {
  text-transform: none;
  font-size: 0.75rem;
  font-weight: bold !important;
  line-height: 1 !important;
  letter-spacing: -0.015rem;
}

.booking-form .ga_monthly_schedule_wrapper table.table_fixed {
  border-spacing: 4px !important;
}

.booking-form .ga_monthly_schedule_wrapper td {
  border-width: 1px !important;
  border-radius: 4px !important;
}

.booking-form .ga_monthly_schedule_wrapper td.ga_day_past,
.booking-form .ga_monthly_schedule_wrapper td.day_unavailable {
  background: #F5F5F5 !important;
  color: #CBCCCC !important;
}

.booking-form .ga_monthly_schedule_wrapper td.ga_today {
  border-color: #238799 !important;
}

.booking-form .ga_monthly_schedule_wrapper td span {
  font-size: 1.25rem;
  line-height: 1.2;
  letter-spacing: -0.05em;
}

.booking-form .ga_wrapper_small .ga_monthly_schedule_wrapper td.ga_today span, 
.booking-form .ga_wrapper_medium .ga_monthly_schedule_wrapper td.ga_today span, 
.booking-form .ga_wrapper_large .ga_monthly_schedule_wrapper td.ga_today span {
  border-color: transparent !important;
}

.booking-form .ga_wrapper_small .ga_monthly_schedule_wrapper td.day_available:hover span, 
.booking-form .ga_wrapper_small .ga_monthly_schedule_wrapper td.selected span, 
.booking-form .ga_wrapper_medium .ga_monthly_schedule_wrapper td.day_available:hover span, 
.booking-form .ga_wrapper_medium .ga_monthly_schedule_wrapper td.selected span, 
.booking-form .ga_wrapper_large .ga_monthly_schedule_wrapper td.day_available:hover span, 
.booking-form .ga_wrapper_large .ga_monthly_schedule_wrapper td.selected span {
  background: transparent !important;
  border-color: transparent !important;
}

.booking-form .ga_wrapper_small .ga_monthly_schedule_wrapper td.day_available.selected, 
.booking-form .ga_wrapper_medium .ga_monthly_schedule_wrapper td.day_available.selected, 
.booking-form .ga_wrapper_large .ga_monthly_schedule_wrapper td.day_available.selected,
.booking-form .ga_wrapper_small .ga_monthly_schedule_wrapper td.day_available:hover,
.booking-form .ga_wrapper_medium .ga_monthly_schedule_wrapper td.day_available:hover,
.booking-form .ga_wrapper_large .ga_monthly_schedule_wrapper td.day_available:hover {
  background: #EBF8FA !important;
  border-color: #238799 !important;
}

.booking-form #gappointments_calendar_slots label.time_slot {
    border: 1px solid #EBEDED;
    border-radius: 4px;
    transition: all 0.2s ease-in-out;
}

.booking-form #gappointments_calendar_slots label.time_selected {
  border-color: #238799;
}

.booking-form #ga_appointments_calendar *::-webkit-scrollbar {
  width: 0.5rem;
  height: 0.5rem;
}

.booking-form #ga_appointments_calendar *::-webkit-scrollbar-track {
  background-color: #c8c8c8;
}

.booking-form #ga_appointments_calendar *::-webkit-scrollbar-thumb {
  background-color: var(--color-primary);
}

.booking-form .gform_wrapper.gravity-theme .gform_validation_errors {
  background: none;
  margin: 0 0 1.5rem;
  border: none;
  box-shadow: none;
}

.booking-form .gform_wrapper.gravity-theme .gform_validation_errors > h2 {
  font-size: inherit;
  letter-spacing: 0;
}

.booking-form .gform_wrapper.gravity-theme .gfield_validation_message {
  background: none;
  padding: 0;
  border: none;
}

.booking-form .gform_wrapper.gravity-theme .gfield_error label {
  color: #c02b0a;
}

.booking-form .gform_wrapper.gravity-theme .gfield_error [aria-invalid=true],
.booking-form .gform_wrapper.gravity-theme .gfield_error .gchoice label:before {
  border-color: #c02b0a;
}

@media (min-width: 1280px) {
  .booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(2),
  .booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(3),
  .booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(4) .gform_page_footer,
  .booking-form .gform_wrapper.gravity-theme .gform-body .gform_page:nth-child(5),
  .booking-form-2 .gform_wrapper.gravity-theme .gform-body .gform_page,
  .booking-form-3 .gform_wrapper.gravity-theme .gform-body {
    max-width: 66.6666666667%;
    margin-left: auto;
    margin-right: auto;
  }
}

.extras-form {
  margin-top: 1.5rem;
  padding: 1.5rem;
  background-color: #d6f5f7;
  border-radius: 0.5rem;
}

.extras-form .gform_wrapper.gravity-theme .gfield_html > h2 {
  margin-bottom: 0;
  text-align: left;
}

.extras-form .gform_wrapper.gravity-theme .extras .gchoice.checked label {
  pointer-events: none;
  background-color: var(--color-primary);
  color: #fff;
}

.extras-form .gform_wrapper.gravity-theme #field_submit .btn {
  width: 100%;
}

@media (min-width: 641px) {
  .extras-form .gform_wrapper.gravity-theme .extras .gchoice {
    width: calc(33.33% - 0.67rem);
  }

  .extras-form .gform_wrapper.gravity-theme #field_submit {
    justify-content: flex-end;
  }

  .extras-form .gform_wrapper.gravity-theme #field_submit .btn {
    max-width: 50%;
  }
}