@import url("https://fonts.googleapis.com/css?family=Roboto:300,400,500,700|Google+Sans:400,500,700|Google+Sans+Text:400,500,700&lang=en");
@import url("https://fonts.googleapis.com/css?family=Inter:100,200,300,400,500,600,700,800,900&display=swap");

.ssp-booking-app {
  --ssp-blue: #0890f1;
  --ssp-blue-hover: #32a9fe;
  --ssp-deep-blue: #202b93;
  --ssp-black: #1c2026;
  --ssp-dark-grey: #585c62;
  --ssp-medium-grey: #9c9ea3;
  --ssp-border: #d8dcdf;
  --ssp-soft-blue: #baebff;

  min-height: 100vh;
  margin-top: 0;
  padding-bottom: 72px;
  background: #fff;
  color: var(--ssp-black);
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.ssp-booking-app *,
.ssp-booking-app *::before,
.ssp-booking-app *::after {
  box-sizing: border-box;
  letter-spacing: 0;
}

.ssp-booking-app__header {
  position: relative;
  z-index: 20;
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px clamp(16px, 4vw, 40px);
  background: #fff;
  border-bottom: 1px solid var(--ssp-border);
}

#main-content:has(.ssp-booking-app) {
  padding: 0 !important;
}

.ssp-booking-brand,
.ssp-booking-actions,
.ssp-booking-actions a {
  display: flex;
  align-items: center;
}

.ssp-booking-brand {
  gap: 10px;
  min-width: 0;
  color: var(--ssp-deep-blue);
  font-size: 20px;
  line-height: 24px;
  font-weight: 700;
  text-decoration: none;
}

.ssp-booking-brand svg {
  flex: 0 0 auto;
}

.ssp-booking-actions {
  gap: 12px;
}

.ssp-booking-actions a {
  min-height: 40px;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--ssp-border);
  border-radius: 4px;
  background: #fff;
  color: var(--ssp-black);
  font-size: 15px;
  line-height: 22px;
  font-weight: 400;
  text-decoration: none;
  transition: border-color 0.15s ease, color 0.15s ease;
}

.ssp-booking-actions a:hover {
  border-color: var(--ssp-black);
  color: var(--ssp-black);
}

.ssp-booking-stepper {
  display: none;
  width: min(1320px, 100%);
  margin: 24px auto 0;
  padding: 0 16px;
}

.ssp-booking-stepper__track {
  display: flex;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
  border: 1px solid var(--ssp-border);
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
}

.ssp-booking-step {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 148px;
  min-height: 48px;
  padding: 12px 24px;
  color: var(--ssp-medium-grey);
  font-size: 14px;
  line-height: 21px;
  white-space: nowrap;
}

.ssp-booking-step strong {
  font-weight: 700;
}

.ssp-booking-step.is-valid,
.ssp-booking-step.is-active {
  color: var(--ssp-black);
}

.ssp-booking-step__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border: 1px solid var(--ssp-border);
  border-radius: 50%;
}

.ssp-booking-step__icon span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ssp-border);
}

.ssp-booking-step.is-valid .ssp-booking-step__icon {
  border-color: var(--ssp-blue);
  background: var(--ssp-blue);
  color: #fff;
}

.ssp-booking-step.is-active .ssp-booking-step__icon {
  border-color: var(--ssp-blue);
}

.ssp-booking-step.is-active .ssp-booking-step__icon span {
  background: var(--ssp-blue);
}

.ssp-booking-stepper__divider {
  width: 1px;
  background: var(--ssp-border);
}

.ssp-booking-stepper.simplified-booking-stepper--card {
  position: relative;
  top: auto;
  z-index: 1;
  display: flex !important;
  width: min(1320px, 100%);
  margin: calc(var(--lh-nav-offset, 80px) + 16px) auto 20px;
  padding: 0 16px;
  justify-content: flex-start !important;
  background: transparent;
  border: 0;
}

.ssp-booking-stepper.simplified-booking-stepper--card > hr {
  display: none;
}

.ssp-booking-stepper hr {
  width: 1px;
  height: auto;
  border: 0;
  border-left: 1px solid #dce1e5;
}

.simplified-booking-stepper--body {
  width: fit-content;
  max-width: 100%;
  max-height: none;
  min-width: 0;
  background: #fff;
  border: 1px solid #0890f1;
  border-radius: 999px;
  overflow-x: auto;
  overflow-y: hidden;
  box-shadow: 0 6px 18px rgba(8, 144, 241, 0.12);
}

.ssp-booking-stepper .summary-line {
  flex-shrink: 1;
  min-width: 112px;
  max-width: 150px;
  padding: 8px 14px !important;
  background: #fff;
}

.ssp-booking-stepper #stepper-services {
  min-width: 130px;
  max-width: 170px;
}

.ssp-booking-stepper #stepper-pickup {
  min-width: 150px;
  max-width: 180px;
}

.ssp-booking-stepper #stepper-payment {
  min-width: 190px;
  max-width: 220px;
}

.ssp-booking-stepper .summary-line.not-clickable {
  cursor: default;
  opacity: 0.6;
}

.ssp-booking-stepper .summary-line.not-clickable:hover {
  background-color: transparent !important;
}

.ssp-booking-stepper .summary-line.is-workflow-locked {
  cursor: default;
  opacity: 0.55;
}

.ssp-booking-stepper .summary-line.is-workflow-locked:hover {
  background-color: transparent !important;
}

.ssp-booking-stepper .summary-line--header {
  min-width: 0;
}

.ssp-booking-stepper .text-nowrap-container {
  min-width: 0;
  flex: 1;
}

.ssp-booking-stepper .validation-check .fill-me {
  fill: #d8dcdf;
}

.ssp-booking-stepper .summary-line:hover {
  background: #f8fbfd;
}

.ssp-booking-stepper .summary-line.is-active-tab {
  background: #fff;
}

.ssp-booking-stepper .summary-line.is-active-tab .validation-check .fill-me {
  fill: #0890f1;
}

.ssp-booking-stepper .summary-line.is-complete-tab .validation-check .fill-me {
  fill: #0890f1;
}

.ssp-booking-stepper .summary-line.is-active-tab .font-14-24 {
  color: #1c2026 !important;
}

.ssp-booking-stepper .summary-line.is-complete-tab .font-14-24 {
  color: #1c2026 !important;
}

.ssp-tab-panel[hidden] {
  display: none !important;
}

.d-flex {
  display: flex !important;
}

.flex-row {
  flex-direction: row !important;
}

.flex-column {
  flex-direction: column !important;
}

.justify-content-center {
  justify-content: center !important;
}

.justify-content-between {
  justify-content: space-between !important;
}

.align-items-center {
  align-items: center !important;
}

.overflow-hidden {
  overflow: hidden !important;
}

.position-relative {
  position: relative !important;
}

.position-absolute {
  position: absolute !important;
}

.top-50 {
  top: 50% !important;
}

.end-0 {
  right: 0 !important;
}

.translate-middle-y {
  transform: translateY(-50%) !important;
}

.m-0 {
  margin: 0 !important;
}

.p-0 {
  padding: 0 !important;
}

.px-32 {
  padding-right: 32px !important;
  padding-left: 32px !important;
}

.py-12 {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

.ps-32 {
  padding-left: 32px !important;
}

.me-8 {
  margin-right: 8px !important;
}

.border-light-grey-1 {
  border: 1px solid #d8dcdf;
}

.rounded-border-8 {
  border-radius: 8px;
}

.clickable {
  cursor: pointer;
}

.flex-shrink-0 {
  flex-shrink: 0 !important;
}

.fw-bold {
  font-weight: 700 !important;
}

.medium-grey {
  color: #9c9ea3;
}

.dark-grey {
  color: #585c62 !important;
}

.deep-black {
  color: #1c2026 !important;
}

.font-14-21 {
  font-size: 14px;
  line-height: 21px;
}

.font-14-24 {
  font-size: 14px;
  line-height: 24px;
}

.ssp-booking-stepper .font-14-24 {
  font-size: 15px;
  line-height: 24px;
}

.text-ellipsis {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-booking-layout {
  display: grid;
  gap: 32px;
  width: min(1320px, 100%);
  margin: 40px auto 0;
  padding: 0 16px;
}

.ssp-booking-panel,
.ssp-booking-summary__card,
.ssp-booking-services {
  border: 1px solid var(--ssp-border);
  border-radius: 8px;
  background: #fff;
  box-shadow: none;
}

.ssp-booking-panel {
  padding: 24px;
}

.ssp-booking-kicker {
  margin: 0 0 8px;
  color: var(--ssp-dark-grey);
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
}

.ssp-booking-panel h1,
.ssp-booking-services h2 {
  margin: 0 0 32px;
  color: #000;
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 24px;
  line-height: 28px;
  font-weight: 700;
}

.ssp-booking-field {
  margin-bottom: 24px;
}

.ssp-booking-field label,
.ssp-address-type p {
  display: block;
  margin: 0 0 8px;
  color: var(--ssp-dark-grey);
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
}

.ssp-booking-field input,
.ssp-booking-field select {
  width: 100%;
  min-height: 56px;
  padding: 17px 16px;
  border: 0;
  outline: 1px solid var(--ssp-border);
  border-radius: 4px;
  background: #fff;
  color: var(--ssp-black);
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 21px;
  transition: outline-color 0.15s ease, box-shadow 0.15s ease;
}

.ssp-booking-field input:focus,
.ssp-booking-field select:focus {
  outline-color: var(--ssp-blue);
  box-shadow: 0 0 0 3px rgba(8, 144, 241, 0.14);
}

.ssp-field-error {
  display: block;
  margin: 6px 0 0;
  color: #c43131;
  font-size: 13px;
  line-height: 18px;
  font-weight: 600;
}

.ssp-field-error[hidden] {
  display: none !important;
}

.ssp-saved-services-notice {
  display: grid;
  gap: 4px;
  margin: -12px 0 20px;
  padding: 12px 14px;
  border: 1px solid #b8e2ff;
  border-radius: 8px;
  background: #eef8ff;
  color: #1c2026;
}

.ssp-saved-services-notice[hidden] {
  display: none !important;
}

.ssp-saved-services-notice strong,
.ssp-saved-services-notice span {
  display: block;
}

.ssp-saved-services-notice strong {
  font-size: 14px;
  line-height: 18px;
}

.ssp-saved-services-notice span {
  color: #585c62;
  font-size: 13px;
  line-height: 18px;
}

.ssp-booking-field.has-field-error input,
.ssp-booking-field.has-field-error select,
.ssp-contact-picker .lh-input.has-field-error,
.ssp-contact-picker .phone-row-body.has-field-error .lh-input {
  outline-color: #c43131;
  box-shadow: 0 0 0 3px rgba(196, 49, 49, 0.12);
}

.ssp-booking-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 24px;
  padding: 8px 10px;
  border: 0;
  border-radius: 50px;
  background: #f3f3f3;
  color: var(--ssp-deep-blue);
  font-size: 15px;
  line-height: 24px;
  font-weight: 700;
  cursor: pointer;
}

.ssp-address-type {
  margin: 0 0 24px;
}

.ssp-address-search-field {
  position: relative;
}

.ssp-address-results {
  position: absolute;
  z-index: 30;
  top: calc(100% - 16px);
  right: 0;
  left: 0;
  display: none;
  max-height: 320px;
  overflow-y: auto;
  border: 1px solid #d8dcdf;
  border-radius: 0 0 8px 8px;
  background: #fff;
  box-shadow: 0 10px 25px rgba(71, 79, 88, 0.12);
}

.ssp-address-results.is-open {
  display: block;
}

.ssp-address-modal[hidden] {
  display: none !important;
}

.ssp-address-modal {
  position: fixed;
  z-index: 9999;
  inset: 0;
}

.ssp-address-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
}

.ssp-address-modal__window {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: #fff;
  font-family: Inter, Helvetica, Arial, sans-serif;
}

.ssp-address-modal__head {
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 62px;
  padding: 18px 16px;
  border-bottom: 1px solid #edf1f4;
}

.ssp-address-modal__head h2 {
  flex: 1 1 auto;
  margin: 0;
  color: #1c2026;
  font-size: 18px;
  line-height: 24px;
  font-weight: 700;
}

.ssp-address-modal__close {
  position: relative;
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  border: 0;
  border-radius: 50%;
  background: #f3f6f8;
  cursor: pointer;
}

.ssp-address-modal__close::before,
.ssp-address-modal__close::after {
  content: "";
  position: absolute;
  top: 17px;
  left: 10px;
  width: 16px;
  height: 2px;
  border-radius: 2px;
  background: #1c2026;
}

.ssp-address-modal__close::before {
  transform: rotate(45deg);
}

.ssp-address-modal__close::after {
  transform: rotate(-45deg);
}

.ssp-address-modal__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px;
}

.ssp-address-modal__search,
.ssp-address-modal__manual {
  margin-bottom: 24px;
}

.ssp-address-modal__search label,
.ssp-address-modal__manual h3 {
  display: block;
  margin: 0 0 8px;
  color: #585c62;
  font-size: 14px;
  line-height: 24px;
  font-weight: 400;
}

.ssp-address-modal__manual h3 {
  color: #1c2026;
  font-size: 18px;
  font-weight: 700;
}

.ssp-address-modal__search input {
  width: 100%;
  min-height: 56px;
  padding: 17px 16px;
  border: 0;
  border-radius: 4px;
  outline: 1px solid #d8dcdf;
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 21px;
}

.ssp-address-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin: 0 0 28px;
}

.ssp-address-modal__actions button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  padding: 0;
  border: 0;
  background: transparent;
  color: #0890f1;
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 16px;
  font-weight: 700;
  cursor: pointer;
}

.ssp-address-modal__icon {
  position: relative;
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  border: 2px solid #0890f1;
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
}

.ssp-address-modal__icon::after {
  content: "";
  position: absolute;
  inset: 5px;
  border-radius: 50%;
  background: #0890f1;
}

.ssp-address-modal__icon--search {
  border-radius: 50%;
  transform: none;
}

.ssp-address-modal__icon--search::before {
  content: "";
  position: absolute;
  right: -5px;
  bottom: -3px;
  width: 9px;
  height: 2px;
  border-radius: 2px;
  background: #0890f1;
  transform: rotate(45deg);
}

.ssp-address-modal__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.ssp-address-modal__save {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 56px;
  border: 0;
  border-radius: 4px;
  background: #0890f1;
  color: #fff;
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 20px;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
}

body.ssp-address-modal-open {
  overflow: hidden;
}

@media (min-width: 768px) {
  .ssp-address-modal__window {
    inset: auto;
    top: 50%;
    left: 50%;
    width: min(640px, 90vw);
    max-height: 90vh;
    border-radius: 4px;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.28);
    transform: translate(-50%, -50%);
  }

  .ssp-address-modal__body {
    padding: 24px;
  }

  .ssp-address-modal__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
}

.ssp-address-result {
  display: block;
  width: 100%;
  padding: 14px 16px;
  border: 0;
  border-bottom: 1px solid #f3f3f3;
  background: #fff;
  color: #1c2026;
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
  text-align: left;
  cursor: pointer;
}

.ssp-address-result:hover {
  background: #daf4ff;
  color: #1c2026;
}

.ssp-address-result.is-muted {
  color: #585c62;
  cursor: default;
}

.ssp-address-type__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.ssp-address-type__grid button {
  min-height: 50px;
  padding: 12px;
  border: 1px solid var(--ssp-border);
  border-radius: 4px;
  background: #fff;
  color: var(--ssp-black);
  font-family: Inter, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.ssp-address-type__grid button:hover {
  border-color: var(--ssp-black);
}

.ssp-address-type__grid button.is-active {
  border-color: var(--ssp-blue);
  background: var(--ssp-soft-blue);
  color: var(--ssp-blue);
  font-weight: 700;
}

.ssp-entrance-card {
  display: grid;
  gap: 0;
  margin-top: 24px;
  border: 1px solid var(--ssp-border);
  border-radius: 4px;
  overflow: hidden;
}

.ssp-entrance-card__map {
  position: relative;
  min-height: 176px;
  background:
    linear-gradient(90deg, rgba(216, 220, 223, 0.5) 1px, transparent 1px),
    linear-gradient(rgba(216, 220, 223, 0.5) 1px, transparent 1px),
    #e5e3df;
  background-size: 36px 36px;
}

.ssp-entrance-card__map span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 56px;
  height: 56px;
  border-radius: 50% 50% 50% 0;
  background: var(--ssp-blue);
  transform: translate(-50%, calc(-50% - 20px)) rotate(-45deg);
  box-shadow: 0 8px 18px rgba(8, 144, 241, 0.24);
}

.ssp-entrance-card__map span::after {
  content: "";
  position: absolute;
  inset: 15px;
  border-radius: 50%;
  background: #fff;
}

.ssp-entrance-card__copy {
  padding: 16px;
  background: #fff;
}

.ssp-entrance-card__copy strong,
.ssp-entrance-card__copy p {
  display: block;
  margin: 0;
}

.ssp-entrance-card__copy strong {
  margin-bottom: 8px;
  color: var(--ssp-black);
  font-size: 16px;
  line-height: 24px;
  font-weight: 700;
}

.ssp-entrance-card__copy p,
.ssp-booking-summary__card p,
.ssp-booking-services__heading p,
.ssp-booking-footer {
  color: var(--ssp-dark-grey);
  font-size: 14px;
  line-height: 24px;
}

.ssp-booking-summary {
  min-width: 0;
}

.ssp-booking-summary__card {
  display: grid;
  justify-items: center;
  gap: 16px;
  min-height: 160px;
  padding: 24px;
  text-align: center;
}

.ssp-booking-summary__image {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ssp-booking-summary__card p {
  margin: 0;
}

.ssp-booking-summary__card a:not(.ssp-booking-next) {
  color: var(--ssp-blue);
  font-weight: 700;
  text-decoration: none;
}

.ssp-booking-next {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 56px;
  padding: 18px;
  border-radius: 4px;
  background: var(--ssp-blue);
  color: #fff;
  font-size: 16px;
  line-height: 20px;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: background-color 0.25s ease;
}

.ssp-booking-next:hover {
  background: var(--ssp-blue-hover);
  color: #fff;
}

.booking-summary-top-wrapper {
  min-height: 160px;
}

.booking-login-notice {
  align-items: center;
  border-radius: 8px;
  background-color: #e3f7ff;
}

.booking-login-notice a {
  color: #1c2026 !important;
  text-decoration: none;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.booking-login-notice a:hover,
.booking-login-notice a:focus {
  color: #0890f1 !important;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
}

.ssp-booking-blue-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #0890f3;
  white-space: nowrap;
}

.ssp-booking-blue-logo .lh-brand__icon {
  flex: 0 0 auto;
  width: 32px;
  height: 30px;
}

.ssp-booking-blue-logo .lh-brand__text {
  color: #1c2026;
  font-size: 18px;
  line-height: 22px;
  font-weight: 800;
}

.ssp-login-brand-mark {
  flex: 0 0 auto;
  transform: scale(0.9);
  transform-origin: right center;
}

.ssp-address-sidebar-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0;
  width: 100%;
  min-width: 0;
}

.ssp-address-sidebar-card > * {
  width: 100%;
  max-width: 100%;
}

.ssp-address-sidebar-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  padding: 14px;
  border-radius: 8px;
  background: #f7fafc;
  text-align: center;
}

.ssp-address-sidebar-logo {
  flex: 0 0 auto;
}

.ssp-address-sidebar-logo .lh-brand__icon {
  width: 28px;
  height: 26px;
}

.ssp-address-sidebar-logo .lh-brand__text {
  font-size: 16px;
  line-height: 20px;
}

.ssp-address-sidebar-brand p {
  margin: 0;
  color: #585c62;
  font-size: 14px;
  line-height: 21px;
}

.ssp-address-sidebar-card .full-cart-header {
  justify-content: center !important;
  text-align: center;
}

.ssp-address-sidebar-card .full-cart-header .gap-12 {
  justify-content: center;
  width: 100%;
}

.ssp-address-sidebar-card .full-cart-header p {
  margin-bottom: 0 !important;
}

.ssp-address-sidebar-summary {
  display: grid;
  gap: 0;
  margin-bottom: 16px;
  border: 1px solid #edf1f4;
  border-radius: 8px;
  overflow: hidden;
  text-align: left;
}

.ssp-address-sidebar-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
  border-bottom: 1px solid #edf1f4;
  background: #fff;
}

.ssp-address-sidebar-row:last-child {
  border-bottom: 0;
}

.ssp-address-sidebar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #daf4ff;
  color: #202b93;
  font-size: 13px;
  line-height: 1;
  font-weight: 800;
}

.ssp-address-sidebar-row strong {
  display: block;
  margin: 0 0 3px;
  color: #1c2026;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
}

.ssp-address-sidebar-row p {
  margin: 0;
  color: #585c62;
  font-size: 13px;
  line-height: 18px;
}

.ssp-address-sidebar-card .booking-summary-cta-wrapper {
  width: 100%;
  margin-top: 4px;
}

.ssp-address-sidebar-card #summary-button-address {
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 56px;
  padding: 18px;
  border-radius: 4px;
  background-color: #0890f1;
  color: #fff;
  font-size: 16px;
  line-height: 20px;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  transition: background-color 0.25s ease, color 0.25s ease;
}

.ssp-address-sidebar-card #summary-button-address:hover {
  background-color: #32a9fe;
  color: #fff;
}

.ssp-address-sidebar-card #summary-button-address.disabled,
.ssp-address-sidebar-card #summary-button-address[aria-disabled="true"] {
  background-color: #d8dcdf;
  color: #fff;
  cursor: default;
}

.ssp-address-sidebar-card #summary-button-address.disabled:hover,
.ssp-address-sidebar-card #summary-button-address[aria-disabled="true"]:hover {
  background-color: #d8dcdf;
}

.dark-blue {
  color: #202b93;
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-md-72 {
  margin-top: 0 !important;
}

.p-24 {
  padding: 24px !important;
}

.p-10 {
  padding: 10px !important;
}

.text-center {
  text-align: center !important;
}

.text-start {
  text-align: left !important;
}

.font-14-18 {
  font-size: 14px;
  line-height: 18px;
}

.rounded-0 {
  border-radius: 0 !important;
}

.button.disabled {
  pointer-events: none;
}

.button-primary.disabled {
  background-color: #d8dcdf;
}

.button.disabled.preserve-disabled-click {
  pointer-events: initial !important;
  cursor: default;
}

.ssp-cart-minimum-note.is-valid {
  color: #0d7c73 !important;
  font-weight: 600;
}

.ssp-cart-minimum-note.is-alert {
  border-color: #d83a3a;
  background: #fff4f4 !important;
  color: #9e1b1b !important;
}

.ssp-cart-minimum-note.is-alert strong {
  color: #9e1b1b;
}

.ssp-cart-minimum-note {
  display: grid;
  gap: 4px;
  border: 1px solid #f1d48a;
  color: #6f4b00 !important;
  font-size: 13px;
  line-height: 18px;
}

.ssp-cart-minimum-note strong {
  display: block;
  color: #1c2026;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
}

.ssp-cart-minimum-note span {
  display: block;
}

.ssp-confirm-order-status {
  margin: 10px 0 0;
  color: #585c62;
  font-size: 13px;
  line-height: 18px;
  text-align: center;
}

.ssp-confirm-order-status.is-error {
  color: #c43131;
  font-weight: 600;
}

.ssp-confirm-order-status[hidden] {
  display: none !important;
}

#summary-button-order.is-submitting {
  opacity: 0.78;
  pointer-events: none;
}

.ssp-booking-services {
  width: min(1320px, 100%);
  margin: 32px auto 0;
  padding: 24px 16px;
}

.ssp-booking-services__heading {
  max-width: 760px;
  margin-bottom: 24px;
}

.ssp-booking-services__heading p {
  margin: 0 0 8px;
}

.ssp-booking-services__heading p:last-child {
  margin-top: -16px;
}

.ssp-booking-services__mount {
  position: relative;
  overflow: visible;
}

.ssp-booking-services .laundry-service-plugin {
  background: #fff;
}

.ssp-booking-footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  width: min(1320px, 100%);
  margin: 32px auto 0;
  padding: 18px 16px 0;
  border-top: 1px solid var(--ssp-border);
}

.ssp-booking-footer p {
  margin: 0;
}

.ssp-booking-footer div {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.ssp-booking-footer a {
  color: var(--ssp-blue);
  font-weight: 700;
  text-decoration: none;
}

@media (min-width: 768px) {
  .mt-md-72 {
    margin-top: 72px !important;
  }

  .position-md-relative {
    position: relative !important;
  }

  .rounded-border-md-4 {
    border-radius: 4px !important;
  }

  .ssp-booking-stepper.simplified-booking-stepper--card {
    display: flex;
  }

  .ssp-booking-stepper {
    display: block;
  }

  .ssp-booking-layout {
    grid-template-columns: minmax(0, 66.6667%) minmax(0, 33.3333%);
    align-items: start;
    padding-right: 16px;
    padding-left: 16px;
  }

  .ssp-booking-panel,
  .ssp-booking-summary__card,
  .ssp-booking-services {
    padding: 24px 40px;
  }

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

  .ssp-booking-panel h1,
  .ssp-booking-services h2 {
    font-size: 36px;
    line-height: 40px;
  }

  .ssp-entrance-card__map {
    min-height: 336px;
  }

  .ssp-entrance-card__map span {
    width: 96px;
    height: 96px;
    transform: translate(-50%, calc(-50% - 30px)) rotate(-45deg);
  }

  .ssp-entrance-card__map span::after {
    inset: 28px;
  }
}

@media (min-width: 1200px) {
  .ssp-booking-layout,
  .ssp-booking-services,
  .ssp-booking-footer,
  .ssp-booking-stepper {
    max-width: 1320px;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .ssp-services-picker .ssp-service-category-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .ssp-services-picker .ssp-service-item-card {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .ssp-services-picker .ssp-service-item-action {
    grid-column: 2;
  }

  .ssp-services-picker .ssp-service-item-title-row {
    flex-direction: column;
    gap: 4px;
  }

  .ssp-booking-app {
    margin-top: 0;
    padding-bottom: 72px;
  }

  .ssp-booking-app__header {
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .ssp-booking-brand {
    width: 32px;
    overflow: hidden;
  }

  .ssp-booking-brand span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .ssp-booking-actions {
    gap: 8px;
  }

  .ssp-booking-actions a {
    padding: 8px 10px;
    font-size: 14px;
    line-height: 20px;
  }

  .ssp-booking-actions a:first-child {
    display: none;
  }

  .ssp-booking-layout {
    margin-top: 24px;
  }

  .ssp-booking-panel,
  .ssp-booking-summary__card,
  .ssp-booking-services {
    padding: 16px;
  }

  .ssp-address-type__grid {
    grid-template-columns: 1fr;
  }

  .ssp-order-summary-intro {
    margin-right: -16px;
    margin-left: -16px;
  }

  .ssp-order-summary-picker .booking-summary-cta-wrapper {
    position: sticky;
    z-index: 5;
    bottom: 0;
    margin-top: 16px;
    padding: 16px 0;
    background: #fff;
  }

  .ssp-order-summary-picker #summary-button-order {
    margin-top: 0;
  }

  .ssp-order-summary-picker .summary-payment-option__head {
    min-height: 58px;
    padding: 14px 16px;
  }

  .ssp-order-summary-picker .summary-payment-detail {
    margin-right: 16px;
    margin-left: 16px;
  }

  .ssp-order-summary-picker .summary-payment-terms {
    padding-right: 16px;
    padding-left: 16px;
    font-size: 14px;
    line-height: 21px;
  }
}

.ssp-booking-services {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.ssp-booking-timeslots {
  width: min(1320px, 100%);
  margin: 0 auto;
  padding: 0;
  background: transparent;
}

.ssp-booking-contact {
  width: min(1320px, 100%);
  margin: 0 auto;
  padding: 0;
  background: transparent;
}

.ssp-booking-order-summary {
  width: min(1320px, 100%);
  margin: 0 auto;
  padding: 0;
  background: transparent;
}

.ssp-order-summary-intro {
  width: 100%;
  font-family: Inter, Helvetica, Arial, sans-serif;
}

.ssp-order-summary-intro .container {
  --bs-gutter-x: 32px;
  --bs-gutter-y: 0;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
}

.ssp-order-summary-intro .row {
  --bs-gutter-x: 32px;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.ssp-order-summary-intro .row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

.ssp-order-summary-intro .col-12 {
  flex: 0 0 auto;
  width: 100%;
}

.ssp-order-summary-intro h1,
.ssp-order-summary-intro p {
  margin-top: 0;
}

.ssp-order-summary-intro .font-36d-24m {
  font-size: 24px;
  line-height: 26px;
}

.ssp-order-summary-intro .fit-content {
  width: fit-content;
}

.ssp-services-picker,
.ssp-services-picker * {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  word-wrap: normal;
}

.ssp-services-picker {
  --bs-gutter-x: 32px;
  --bs-gutter-y: 0;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  font-family: Inter, Helvetica, Arial, sans-serif;
}

.ssp-services-picker div,
.ssp-services-picker section,
.ssp-services-picker ul,
.ssp-services-picker li,
.ssp-services-picker h1,
.ssp-services-picker p,
.ssp-services-picker a,
.ssp-services-picker span {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

.ssp-services-picker ul {
  list-style: none;
}

.ssp-services-picker img {
  max-width: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

.ssp-services-picker a {
  color: #0890f1;
  text-decoration: none;
  outline: none;
  cursor: pointer;
}

.ssp-services-picker .component-container {
  position: relative;
  scroll-behavior: smooth;
}

.ssp-services-picker .component-container.booking {
  display: flex;
  flex-direction: column;
  min-height: inherit;
}

.ssp-services-picker .row {
  --bs-gutter-x: 32px;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}

.ssp-services-picker .row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

.ssp-services-picker .col-12 {
  flex: 0 0 auto;
  width: 100%;
}

.ssp-services-picker .mt-16 {
  margin-top: 16px !important;
}

.ssp-services-picker .mt-24 {
  margin-top: 24px !important;
}

.ssp-services-picker .mt-32 {
  margin-top: 32px !important;
}

.ssp-services-picker .mb-16 {
  margin-bottom: 16px !important;
}

.ssp-services-picker .mb-24 {
  margin-bottom: 24px !important;
}

.ssp-services-picker .mb-32 {
  margin-bottom: 32px !important;
}

.ssp-services-picker .mt-12 {
  margin-top: 12px !important;
}

.ssp-services-picker .mt-18 {
  margin-top: 18px !important;
}

.ssp-services-picker .mb-20 {
  margin-bottom: 20px !important;
}

.ssp-services-picker .mb-12 {
  margin-bottom: 12px !important;
}

.ssp-services-picker .mb-8 {
  margin-bottom: 8px !important;
}

.ssp-services-picker .mb-6 {
  margin-bottom: 6px !important;
}

.ssp-services-picker .mb-2 {
  margin-bottom: 2px !important;
}

.ssp-services-picker .mb-0 {
  margin-bottom: 0 !important;
}

.ssp-booking-app .mt-0 {
  margin-top: 0 !important;
}

.ssp-booking-app .mb-0 {
  margin-bottom: 0 !important;
}

.ssp-services-picker .me-8 {
  margin-right: 8px !important;
}

.ssp-services-picker .me-16 {
  margin-right: 16px !important;
}

.ssp-services-picker .me-32 {
  margin-right: 32px !important;
}

.ssp-services-picker .me-auto {
  margin-right: auto !important;
}

.ssp-services-picker .ms-auto {
  margin-left: auto !important;
}

.ssp-services-picker .p-16 {
  padding: 16px !important;
}

.ssp-services-picker .p-10 {
  padding: 10px !important;
}

.ssp-services-picker .p-20 {
  padding: 20px !important;
}

.ssp-services-picker .py-8 {
  padding-top: 8px !important;
  padding-bottom: 8px !important;
}

.ssp-services-picker .px-4 {
  padding-right: 4px !important;
  padding-left: 4px !important;
}

.ssp-services-picker .py-1 {
  padding-top: 1px !important;
  padding-bottom: 1px !important;
}

.ssp-services-picker .px-24 {
  padding-right: 24px !important;
  padding-left: 24px !important;
}

.ssp-services-picker .py-20 {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.ssp-services-picker .ps-24 {
  padding-left: 24px !important;
}

.ssp-services-picker .pe-24 {
  padding-right: 24px !important;
}

.ssp-services-picker .pt-16 {
  padding-top: 16px !important;
}

.ssp-services-picker .pb-16 {
  padding-bottom: 16px !important;
}

.ssp-services-picker .py-16 {
  padding-top: 16px !important;
  padding-bottom: 16px !important;
}

.ssp-services-picker .pt-20 {
  padding-top: 20px !important;
}

.ssp-services-picker .pb-20 {
  padding-bottom: 20px !important;
}

.ssp-services-picker .d-none {
  display: none !important;
}

.ssp-services-picker .d-block {
  display: block !important;
}

.ssp-services-picker .d-flex {
  display: flex !important;
}

.ssp-services-picker .d-inline-block {
  display: inline-block !important;
}

.ssp-booking-app .d-inline-block {
  display: inline-block !important;
}

.ssp-services-picker .d-inline-flex {
  display: inline-flex !important;
}

.ssp-services-picker .flex-row {
  flex-direction: row !important;
}

.ssp-services-picker .flex-column {
  flex-direction: column !important;
}

.ssp-services-picker .align-items-center {
  align-items: center !important;
}

.ssp-services-picker .align-items-start {
  align-items: flex-start !important;
}

.ssp-services-picker .justify-content-between {
  justify-content: space-between !important;
}

.ssp-services-picker .gap-4 {
  gap: 4px !important;
}

.ssp-services-picker .gap-12 {
  gap: 12px !important;
}

.ssp-services-picker .gap-16 {
  gap: 16px !important;
}

.ssp-services-picker .gap-32 {
  gap: 32px !important;
}

.ssp-services-picker .gap-8 {
  gap: 8px !important;
}

.ssp-services-picker .gap-10 {
  gap: 10px !important;
}

.ssp-services-picker .w-100 {
  width: 100% !important;
}

.ssp-services-picker .mw-0 {
  min-width: 0;
}

.ssp-services-picker .flex-grow-1 {
  flex-grow: 1 !important;
}

.ssp-services-picker .flex-wrap {
  flex-wrap: wrap !important;
}

.ssp-services-picker .position-relative {
  position: relative !important;
}

.ssp-services-picker .position-absolute {
  position: absolute !important;
}

.ssp-services-picker .end-0 {
  right: 0 !important;
}

.ssp-services-picker .order-first {
  order: -1 !important;
}

.ssp-services-picker .flex-shrink-0 {
  flex-shrink: 0 !important;
}

.ssp-services-picker .text-end {
  text-align: right !important;
}

.ssp-services-picker .text-start {
  text-align: left !important;
}

.ssp-services-picker .text-uppercase {
  text-transform: uppercase !important;
}

.ssp-services-picker .clickable,
.ssp-services-picker .cursor-pointer {
  cursor: pointer;
}

.ssp-services-picker .fw-bold {
  font-weight: 700 !important;
}

.ssp-services-picker .fw-600 {
  font-weight: 600;
}

.ssp-services-picker .fw-500 {
  font-weight: 500;
}

.ssp-services-picker .fw-normal {
  font-weight: 400 !important;
}

.ssp-services-picker .primary-blue {
  color: #0890f1;
}

.ssp-services-picker .deep-black {
  color: #1c2026 !important;
}

.ssp-services-picker .dark-grey {
  color: #585c62 !important;
}

.ssp-services-picker .font-16-20 {
  font-size: 16px;
  line-height: 20px;
}

.ssp-services-picker .font-16-24 {
  font-size: 16px;
  line-height: 24px;
}

.ssp-services-picker .font-18-24 {
  font-size: 18px;
  line-height: 24px;
}

.ssp-services-picker .font-18d-16m {
  font-size: 16px;
  line-height: 18px;
}

.ssp-services-picker .font-14-21 {
  font-size: 14px;
  line-height: 21px;
}

.ssp-services-picker .font-14-18 {
  font-size: 14px;
  line-height: 18px;
}

.ssp-services-picker .font-14-16 {
  font-size: 14px;
  line-height: 16px;
}

.ssp-services-picker .font-13-24 {
  font-size: 13px;
  line-height: 24px;
}

.ssp-services-picker .font-13-18 {
  font-size: 13px;
  line-height: 18px;
}

.ssp-services-picker .font-12-16 {
  font-size: 12px;
  line-height: 16px;
}

.ssp-services-picker .font-12-14 {
  font-size: 12px;
  line-height: 14px;
}

.ssp-services-picker .bg-light-grey {
  background-color: #d8dcdf;
}

.ssp-services-picker .bg-white {
  background-color: #fff !important;
}

.ssp-services-picker .bg-light-blue-modal {
  background-color: #e3f7ff;
}

.ssp-services-picker .bg-highlight-light-blue {
  background-color: #daf4ff;
}

.ssp-services-picker .bg-background-grey {
  background-color: #f7fafc;
}

.ssp-services-picker .bg-mobile-background {
  background-color: #f3f3f3;
}

.ssp-services-picker .border-light-grey-1 {
  border: 1px solid #d8dcdf;
}

.ssp-services-picker .border-tag-grey {
  border: 1px solid #f3f3f3;
}

.ssp-services-picker .rounded-border-8 {
  border-radius: 8px;
}

.ssp-services-picker .rounded-border-4 {
  border-radius: 4px;
}

.ssp-services-picker h1,
.ssp-services-picker h1.smaller-mobile {
  color: #000;
  font-size: 24px;
  line-height: 24px;
  font-weight: 700;
}

.ssp-services-picker .simplified-booking-summary {
  position: relative;
}

.ssp-services-picker .simplified-service-list-item {
  min-height: 112px;
  background: #fff;
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.4);
}

.ssp-services-picker .simplified-service-list-item.selected {
  border: 2px solid #0890f1;
}

.ssp-services-picker .simplified-service-list-item-right {
  min-width: 0;
  width: 100%;
}

.ssp-services-picker .icon-carret {
  bottom: 50%;
  transform: translateY(50%);
}

.ssp-services-picker .ssp-service-title-row {
  min-width: 0;
}

.ssp-services-picker .ssp-service-title-row > div {
  min-width: 0;
}

.ssp-services-picker .ssp-service-price-pill {
  flex: 0 0 auto;
  padding: 6px 8px;
  border-radius: 4px;
  background: #f7fafc;
  white-space: nowrap;
}

.ssp-services-picker .ssp-service-price-preview {
  display: grid;
  gap: 6px;
  padding: 10px 12px;
  border-radius: 6px;
  background: #f7fafc;
}

.ssp-services-picker .ssp-service-price-preview__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #585c62;
  font-size: 13px;
  line-height: 18px;
}

.ssp-services-picker .ssp-service-price-preview__item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-services-picker .ssp-service-price-preview__item strong {
  flex: 0 0 auto;
  color: #1c2026;
  font-weight: 700;
}

.ssp-services-picker .simplified-service-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 1px 4px;
  border-radius: 4px;
  background-color: #f3f3f3;
  color: #585c62;
}

.ssp-services-picker .full-cart-summary {
  background: #fff;
}

.ssp-services-picker .full-cart-items {
  list-style: none;
}

.ssp-services-picker .ssp-service-catalogue {
  display: grid;
  gap: 16px;
}

.ssp-services-picker .ssp-service-category-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ssp-services-picker .ssp-service-category-tab {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 74px;
  padding: 12px;
  border: 1px solid #d8dcdf;
  border-radius: 8px;
  background: #fff;
  color: #1c2026;
  text-align: left;
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.35);
  cursor: pointer;
}

.ssp-services-picker .ssp-service-category-tab.is-active {
  border: 2px solid #0890f1;
  background: #f3fbff;
}

.ssp-services-picker .ssp-service-category-tab img {
  grid-row: 1 / span 2;
  object-fit: contain;
}

.ssp-services-picker .ssp-service-category-tab strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
}

.ssp-services-picker .ssp-service-category-tab span {
  color: #585c62;
  font-size: 12px;
  line-height: 16px;
}

.ssp-services-picker .ssp-service-category-copy {
  padding: 16px;
  border-radius: 8px;
  background: #f7fafc;
}

.ssp-services-picker .ssp-service-category-copy h2 {
  margin: 0 0 4px;
  color: #1c2026;
  font-size: 20px;
  line-height: 26px;
  font-weight: 700;
}

.ssp-services-picker .ssp-service-category-copy p {
  color: #585c62;
  font-size: 14px;
  line-height: 21px;
}

.ssp-services-picker .ssp-service-subcategory-tabs {
  display: block;
  width: 100%;
  padding: 10px;
  border-radius: 12px;
  background: #f7fafc;
}

.ssp-services-picker .ssp-service-subcategory-track {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  width: 100%;
  overflow: visible;
  padding: 0;
}

.ssp-services-picker .ssp-service-subcategory-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: max-content;
  max-width: max-content;
  scroll-snap-align: start;
  padding: 8px 12px;
  border: 1px solid #d8dcdf;
  border-radius: 999px;
  background: #fff;
  color: #585c62;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}

.ssp-services-picker .ssp-service-subcategory-tab.is-active {
  border-color: #0890f1;
  background: #daf4ff;
  color: #1c2026;
}

.ssp-services-picker .ssp-service-items {
  display: grid;
  gap: 12px;
}

.ssp-services-picker .ssp-service-item-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px solid #d8dcdf;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.35);
}

.ssp-services-picker .ssp-service-item-card.is-added {
  border-color: #0890f1;
}

.ssp-services-picker .ssp-service-item-media {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: #f7fafc;
}

.ssp-services-picker .ssp-service-item-media img {
  max-width: 52px;
  max-height: 52px;
  object-fit: contain;
}

.ssp-services-picker .ssp-service-item-media span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #e3f7ff;
  color: #202b93;
  font-size: 15px;
  line-height: 34px;
  font-weight: 800;
}

.ssp-services-picker .ssp-service-item-main {
  min-width: 0;
}

.ssp-services-picker .ssp-service-item-title-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.ssp-services-picker .ssp-service-item-title-row h3 {
  margin: 0;
  color: #1c2026;
  font-size: 15px;
  line-height: 20px;
  font-weight: 700;
}

.ssp-services-picker .ssp-service-item-price {
  flex: 0 0 auto;
  display: flex;
  align-items: baseline;
  gap: 6px;
  white-space: nowrap;
}

.ssp-services-picker .ssp-service-item-price strong {
  color: #1c2026;
  font-size: 15px;
  line-height: 20px;
  font-weight: 800;
}

.ssp-services-picker .ssp-service-item-original {
  color: #8b929a;
  font-size: 12px;
  line-height: 16px;
  text-decoration: line-through;
}

.ssp-services-picker .ssp-service-item-description {
  margin-top: 5px;
  color: #585c62;
  font-size: 13px;
  line-height: 19px;
}

.ssp-services-picker .ssp-service-item-badge {
  display: inline-flex;
  margin-top: 8px;
  padding: 3px 6px;
  border-radius: 4px;
  background: #e3f7ff;
  color: #202b93;
  font-size: 12px;
  line-height: 16px;
  font-weight: 700;
}

.ssp-services-picker .ssp-item-add,
.ssp-services-picker .ssp-item-qty button,
.ssp-services-picker .ssp-cart-qty button {
  border: 1px solid #0890f1;
  border-radius: 4px;
  background: #fff;
  color: #0890f1;
  font-weight: 800;
  cursor: pointer;
}

.ssp-services-picker .ssp-item-add {
  width: 24px;
  height: 24px;
  min-width: 24px;
  padding: 0;
  background: #0890f1;
  color: #fff;
  font-size: 16px;
  line-height: 22px;
  text-align: center;
  text-transform: none;
}

.ssp-services-picker .ssp-item-add.is-selected {
  background: #daf4ff;
  color: #0890f1;
  font-size: 0;
  line-height: 1;
}

.ssp-services-picker .ssp-item-add.is-selected::before {
  content: "\2713";
  font-size: 14px;
  line-height: 1;
}

.ssp-services-picker .ssp-service-item-card.is-disabled {
  opacity: 0.72;
}

.ssp-services-picker .ssp-item-add.is-disabled,
.ssp-services-picker .ssp-item-add:disabled {
  border-color: #d8dcdf;
  background: #edf1f4;
  color: #9c9ea3;
  cursor: not-allowed;
}

.ssp-services-picker .ssp-item-qty,
.ssp-services-picker .ssp-cart-qty {
  display: inline-flex;
  align-items: center;
  gap: 0;
  overflow: hidden;
  border: 1px solid #d8dcdf;
  border-radius: 4px;
  background: #fff;
}

.ssp-services-picker .ssp-item-qty button,
.ssp-services-picker .ssp-cart-qty button {
  width: 26px;
  height: 26px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: #fff;
  color: #0890f1;
  font-size: 16px;
  line-height: 24px;
  text-align: center;
}

.ssp-services-picker .ssp-item-qty span,
.ssp-services-picker .ssp-cart-qty span {
  min-width: 28px;
  height: 26px;
  color: #1c2026;
  text-align: center;
  font-size: 13px;
  line-height: 26px;
  font-weight: 700;
  border-right: 1px solid #edf1f4;
  border-left: 1px solid #edf1f4;
}

.ssp-services-picker .ssp-cart-empty {
  padding: 14px;
  border-radius: 8px;
  background: #f7fafc;
  color: #585c62;
  font-size: 14px;
  line-height: 20px;
}

.ssp-services-picker .ssp-sidebar-category-group {
  margin: 0 0 12px;
  padding: 0;
  overflow: hidden;
  border: 1px solid #edf1f4;
  border-radius: 8px;
  background: #fff;
  list-style: none;
}

.ssp-services-picker .ssp-sidebar-category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: #f7fafc;
  color: #1c2026;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
}

.ssp-services-picker .ssp-sidebar-category-header strong {
  flex: 0 0 auto;
  font-size: 14px;
  line-height: 18px;
}

.ssp-services-picker .ssp-sidebar-category-items {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ssp-services-picker .ssp-cart-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid #edf1f4;
}

.ssp-services-picker .ssp-cart-item:last-child {
  border-bottom: 0;
}

.ssp-services-picker .ssp-cart-item .service-info {
  flex: 1 1 auto;
  min-width: 0;
}

.ssp-services-picker .ssp-cart-item .service-info p {
  margin: 0;
}

.ssp-services-picker .ssp-cart-item .service-meta {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 8px;
  text-align: right;
}

.ssp-services-picker .ssp-cart-remove {
  min-height: 26px;
  padding: 0 8px;
  border: 1px solid #d8dcdf;
  border-radius: 4px;
  background: #fff;
  color: #585c62;
  font-size: 12px;
  line-height: 24px;
  font-weight: 700;
  cursor: pointer;
}

.ssp-services-picker .ssp-cart-total {
  padding-top: 12px;
  border-top: 1px solid #d8dcdf;
}

.ssp-order-summary-picker .summary-selected-service-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.ssp-order-summary-picker .summary-selected-service-row p {
  margin: 0;
}

.ssp-order-summary-picker .summary-selected-service-row strong {
  flex: 0 0 auto;
  font-size: 14px;
  line-height: 21px;
}

.ssp-services-picker .booking-form-section,
.ssp-contact-picker .booking-form-section,
.ssp-timeslots-picker .booking-form-section {
  padding: 24px;
  border: 1px solid #e5e9ed;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 34px rgba(28, 32, 38, 0.06);
}

.ssp-services-picker .ssp-plugin-data-notice {
  border: 1px solid #baebff;
  background: linear-gradient(180deg, #f3fbff 0%, #fff 100%);
}

.ssp-services-picker .ssp-service-category-tab {
  grid-template-columns: 40px minmax(0, 1fr);
  min-height: 68px;
  border-radius: 10px;
  box-shadow: none;
}

.ssp-services-picker .ssp-service-category-tab.is-active {
  box-shadow: 0 10px 24px rgba(8, 144, 241, 0.12);
}

.ssp-services-picker .ssp-service-category-copy {
  border: 1px solid #edf1f4;
  border-radius: 12px;
}

.ssp-services-picker .ssp-service-subcategory-tab {
  border-color: transparent;
  border-radius: 10px;
}

.ssp-services-picker .ssp-service-subcategory-tab.is-active {
  background: #fff;
  box-shadow: 0 6px 18px rgba(28, 32, 38, 0.08);
}

.ssp-services-picker .ssp-service-item-card {
  min-height: 116px;
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(28, 32, 38, 0.055);
}

.ssp-services-picker .ssp-service-item-card:hover {
  border-color: #9fdfff;
}

.ssp-services-picker .ssp-service-item-media {
  border: 1px solid #edf1f4;
}

.ssp-services-picker .ssp-item-add {
  border: 0;
  border-radius: 4px;
  box-shadow: none;
}

.ssp-services-picker .full-cart-summary,
.ssp-timeslots-picker .simplified-booking-summary > div,
.ssp-contact-picker .booking-summary-top-wrapper,
.ssp-order-summary-picker .simplified-booking-summary--card {
  border-radius: 12px !important;
  background: #fff;
  box-shadow: 0 14px 36px rgba(28, 32, 38, 0.08);
}

.ssp-services-picker .full-cart-header p,
.ssp-timeslots-picker .booking-summary-top-wrapper .font-14-16.fw-bold,
.ssp-contact-picker .booking-summary-top-wrapper p:first-child {
  letter-spacing: 0;
}

.ssp-services-picker .ssp-cart-total {
  margin-top: 16px;
}

.ssp-services-picker .ssp-cart-minimum-note {
  padding: 8px 10px;
  border-radius: 8px;
  background: #f7fafc;
}

.ssp-address-search-field,
.ssp-address-select-field,
.ssp-booking-field {
  position: relative;
}

.ssp-address-results {
  border-radius: 10px;
  box-shadow: 0 16px 36px rgba(28, 32, 38, 0.14);
}

.ssp-address-result {
  text-align: left;
}

.ssp-address-result:hover {
  background: #f3fbff;
  color: #1c2026;
}

.ssp-timeslots-picker .booking-summary-top-wrapper {
  border: 1px solid #e5e9ed;
}

.ssp-timeslots-picker .booking-summary-top-wrapper .collection,
.ssp-timeslots-picker .booking-summary-top-wrapper .delivery {
  width: 100%;
  padding: 14px;
  border-radius: 10px;
  background: #f7fafc;
}

.ssp-entrance-card__map {
  min-height: 220px;
  overflow: hidden;
  border-radius: 12px;
  background: #eef3f7;
}

.ssp-entrance-card__map iframe {
  display: block;
  width: 100%;
  height: 220px;
  border: 0;
}

.ssp-services-picker .button {
  cursor: pointer;
  padding: 18px;
  border-radius: 4px;
  background-color: #fff;
  font-size: 16px;
  line-height: 20px;
  font-weight: 700;
  text-align: center;
  transition: all 0.25s;
}

.ssp-services-picker .button-primary {
  background-color: #0890f1;
  color: #fff;
  text-transform: uppercase;
}

.ssp-services-picker .button-primary:hover {
  background-color: #32a9fe;
}

.ssp-timeslots-picker .timeslots-countdown {
  background-color: #ffd230;
  border-radius: 4px;
}

.ssp-timeslots-picker .timer-fixed-width {
  min-width: 46px;
}

.ssp-timeslots-picker .booking-timeslot-picker .expanded-view {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px 24px;
}

.ssp-timeslots-picker .booking-timeslot-picker .expanded-view .timeslot-picker--method {
  grid-column: 1 / -1;
  min-width: 0;
}

.ssp-timeslots-picker .timeslot-picker--date {
  width: fit-content;
  min-width: 0;
  max-width: 100%;
  justify-self: start;
}

.ssp-timeslots-picker .ssp-date-menu {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  min-height: 52px;
  padding: 10px 14px;
  border: 1px solid #f3f3f3;
  border-radius: 8px;
  background-color: #fff;
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.4);
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.ssp-timeslots-picker .ssp-date-menu:hover,
.ssp-timeslots-picker .ssp-date-menu:focus-within {
  border-color: #e9f6ff;
  background-color: #e9f6ff;
}

.ssp-timeslots-picker .ssp-timeslot-date-input {
  position: absolute;
  inset: 0;
  z-index: 2;
  min-width: 0;
  width: 100%;
  height: 100%;
  border: 0;
  background: transparent;
  color: #1c2026;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  opacity: 0;
  outline: none;
  cursor: pointer;
}

.ssp-timeslots-picker .ssp-timeslot-date-display {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-width: 104px;
  color: #1c2026;
  font-size: 18px;
  line-height: 24px;
  font-weight: 500;
  white-space: nowrap;
}

@media (max-width: 991px) {
  .ssp-timeslots-picker .booking-timeslot-picker .expanded-view {
    grid-template-columns: 1fr;
  }

  .ssp-timeslots-picker .timeslot-picker--date,
  .ssp-timeslots-picker .ssp-date-menu {
    width: fit-content;
  }

  .ssp-booking-stepper.simplified-booking-stepper--card {
    padding: 8px 12px;
  }

  .ssp-booking-stepper .summary-line {
    min-width: 104px;
    padding: 8px 12px !important;
  }
}

.ssp-timeslots-picker .menu {
  position: relative;
  display: flex;
  align-items: center;
  width: auto;
  min-height: 52px;
  padding: 10px 14px;
  border: 1px solid #f3f3f3;
  border-radius: 8px;
  background-color: #fff;
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.4);
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.ssp-timeslots-picker .menu:hover,
.ssp-timeslots-picker .menu:focus-within,
.ssp-timeslots-picker .menu.is-open {
  border-color: #e9f6ff;
  background-color: #e9f6ff;
}

.ssp-timeslots-picker .ssp-date-menu img,
.ssp-timeslots-picker .menu > .font-16-24 img {
  width: 18px;
  height: 18px;
  margin-right: 12px !important;
}

.ssp-timeslots-picker .menu > img {
  width: 18px;
  height: 18px;
}

.ssp-timeslots-picker .menu > .font-16-24 {
  min-width: 0;
  line-height: 24px;
}

.ssp-timeslots-picker .menu > .font-16-24 span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-timeslots-picker .menu .menu-body {
  position: absolute;
  z-index: 10;
  top: 100%;
  left: 0;
  display: none;
  flex-direction: column;
  justify-content: flex-start;
  width: 100%;
  min-width: 220px;
  max-height: 320px;
  margin-top: 16px;
  padding: 0;
  overflow-x: hidden !important;
  overflow-y: auto;
  border: 1px solid #dce1e5;
  border-radius: 8px;
  background-color: #fff;
  box-shadow: 0 1px 23px 8px rgba(71, 79, 88, 0.05);
}

.ssp-timeslots-picker .menu.is-open .menu-body {
  display: flex;
}

.ssp-timeslots-picker .dropdown-item {
  text-align: left;
  color: #1c2026;
  text-decoration: none;
}

.ssp-timeslots-picker .dropdown-item.active,
.ssp-timeslots-picker .dropdown-item:hover {
  background-color: #daf4ff;
}

.ssp-timeslots-picker .slot-border {
  border-bottom: 1px solid #f7fafc;
}

.ssp-timeslots-picker .input-checkbox {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}

.ssp-timeslots-picker .input-checkbox > * {
  position: absolute;
}

.ssp-timeslots-picker .input-checkbox input {
  z-index: 2;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}

.ssp-timeslots-picker .method-dropdown .method-dropdown--list-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  min-width: 0;
  color: #000;
}

.ssp-timeslots-picker .method-dropdown .method-dropdown--list-item img {
  display: inline-block;
  height: 24px;
  margin-right: 12px;
}

.ssp-timeslots-picker .method-dropdown .method-dropdown--list-item--text {
  display: inline-block;
  min-width: 0;
  overflow: hidden;
  flex-shrink: 1;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-timeslots-picker .summary-card-shadow {
  box-shadow: 0 2px 12px rgba(216, 220, 223, 0.4);
}

.ssp-timeslots-picker .booking-summary-top-wrapper {
  min-height: 160px;
}

.ssp-timeslots-picker .input-switch {
  position: relative;
  width: 1.5em;
  min-width: 1.5em;
  height: 1em;
  overflow: hidden;
  border-radius: 0.5em;
  background-color: #d8dcdf;
  cursor: pointer;
  transition: all 0.25s;
}

.ssp-timeslots-picker .input-switch input {
  position: absolute;
  z-index: 5;
  top: 0;
  left: 0;
  width: 1.5em;
  height: 1.5em;
  margin: 0;
  cursor: pointer;
  opacity: 0;
}

.ssp-timeslots-picker .input-switch .switch-slider {
  position: absolute;
  top: 0.065em;
  left: 0.065em;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 0.87em;
  height: 0.87em;
  border: 0.5px solid rgba(0, 0, 0, 0.04);
  border-radius: 50%;
  background-color: #fff;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.15), 0 3px 1px rgba(0, 0, 0, 0.06);
  transition: all 0.25s;
}

.ssp-timeslots-picker .input-switch input:checked + .switch-slider {
  transform: translateX(0.5em);
}

.ssp-timeslots-picker .input-switch:has(input:checked) {
  background-color: #0890f1;
}

.ssp-timeslots-picker .fit-content {
  width: fit-content;
}

.ssp-contact-picker .booking-contact {
  position: relative;
  width: 100%;
  max-width: 100%;
}

.ssp-contact-picker h3 {
  margin: 0;
  color: #000;
  letter-spacing: 0;
}

.ssp-contact-picker .input-group,
.ssp-contact-picker .edit-user--email-row,
.ssp-contact-picker .phone-row-body {
  width: 100%;
  min-width: 0;
}

.ssp-contact-picker .user-type-option {
  width: auto;
  min-width: 0;
}

.ssp-contact-picker .user-type-option img {
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}

.ssp-contact-picker .ssp-contact-radio {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.ssp-contact-picker .lh-input {
  position: relative;
  display: block;
  width: 100%;
  min-height: 58px;
  padding: 17.6px 16px;
  overflow: hidden;
  border-radius: 4px;
  background-color: #fff;
  outline: 1px solid #d8dcdf;
  transition: outline-color 0.15s ease, box-shadow 0.15s ease;
}

.ssp-contact-picker .lh-input:focus-within,
.ssp-contact-picker .input-select:focus-within {
  outline-color: #0890f1;
  box-shadow: 0 0 0 3px rgba(8, 144, 241, 0.14);
}

.ssp-contact-picker .lh-input label {
  display: none;
  color: #585c62;
  font-size: 14px;
  line-height: 16px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-contact-picker .lh-input input {
  width: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  outline: none;
  background: transparent;
  color: #1c2026;
  font-family: Inter, Helvetica, Arial, sans-serif !important;
  font-size: 16px;
  line-height: 21px;
  text-overflow: ellipsis;
  appearance: none;
}

.ssp-contact-picker .lh-input input::placeholder {
  color: #9c9ea3;
  opacity: 1;
}

.ssp-contact-picker .input-select {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 58px;
  min-width: 0;
  padding: 17.6px 16px;
  border: 1px solid #d8dcdf;
  border-radius: 4px;
  background: #fff;
  outline: 1px solid transparent;
  transition: outline-color 0.15s ease, box-shadow 0.15s ease;
}

.ssp-contact-picker .input-select .displayed-label {
  margin-right: 20px;
  overflow: hidden;
  color: #1c2026;
  font-size: 16px;
  line-height: 21px;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ssp-contact-picker .input-select .icon-carret {
  position: absolute;
  top: 50%;
  right: 16px;
  width: 0;
  height: 0;
  border-top: 5px solid #1c2026;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  transform: translateY(-50%);
}

.ssp-contact-picker .input-select select {
  position: absolute;
  inset: 0;
  width: 100%;
  max-width: 100%;
  border: 0;
  border-radius: 4px;
  background-color: transparent;
  background-image: none !important;
  color: transparent;
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.ssp-contact-picker .input-select select::-ms-expand {
  display: none;
}

.ssp-contact-picker .input-select select option {
  color: #1c2026;
}

.ssp-contact-picker .edit-user .edit-user--phone-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-areas:
    "phoneCode phoneBody phoneBody"
    "phoneError phoneError phoneError";
  gap: 10px 16px;
  align-items: start;
}

.ssp-contact-picker .edit-user .edit-user--phone-row .phone-row-code {
  grid-area: phoneCode;
}

.ssp-contact-picker .edit-user .edit-user--phone-row .phone-row-body {
  grid-area: phoneBody;
}

.ssp-contact-picker .edit-user .edit-user--email-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.ssp-contact-picker .booking-summary-top-wrapper {
  min-height: 160px;
}

.ssp-order-summary-picker .simplified-booking-summary--card {
  border-radius: 12px !important;
  background: #fff;
}

.ssp-order-summary-picker .ssp-order-sidebar-card {
  gap: 0;
  overflow: hidden;
  border-color: #d8dcdf !important;
  box-shadow: 0 14px 36px rgba(28, 32, 38, 0.08);
}

.ssp-order-summary-picker .ssp-order-sidebar-memberships {
  display: none;
}

.ssp-order-summary-picker .ssp-order-sidebar-header {
  padding-bottom: 14px;
  border-bottom: 1px solid #edf1f4;
}

.ssp-order-summary-picker .ssp-order-sidebar-logo {
  width: 32px;
  max-width: 32px;
  height: auto;
  flex: 0 0 32px;
  overflow: hidden;
}

.ssp-order-summary-picker .ssp-order-sidebar-logo .lh-brand__text {
  display: none;
}

.ssp-order-summary-picker .ssp-order-sidebar-logo .lh-brand__icon {
  width: 32px;
  height: 30px;
}

.ssp-order-summary-picker .ssp-order-sidebar-header .gap-12 {
  gap: 12px !important;
}

.ssp-order-summary-picker .font-16-20 {
  font-size: 16px;
  line-height: 20px;
}

.ssp-order-summary-picker .mb-2 {
  margin-bottom: 2px !important;
}

.ssp-order-summary-picker .booking-payment {
  min-height: 320px;
}

.ssp-order-summary-picker .summary-guidance-panel {
  background: #fff;
}

.ssp-order-summary-picker .summary-guidance-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.ssp-order-summary-picker .summary-guidance-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.ssp-order-summary-picker .summary-guidance-icon {
  display: inline-flex;
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #daf4ff;
  color: #202b93;
  font-size: 13px;
  line-height: 1;
  font-weight: 700;
}

.ssp-order-summary-picker .simplified-booking-summary--header {
  padding: 0 0 16px;
  overflow: visible;
}

.ssp-order-summary-picker .full-width {
  width: 100%;
  margin-right: 0;
  margin-left: 0;
}

.ssp-order-summary-picker .price-estimate-section {
  overflow: hidden;
  margin: 0 0 12px !important;
  padding: 0 !important;
  border: 1px solid #edf1f4;
  border-radius: 10px;
  background: #fff;
}

.ssp-order-summary-picker .charges-breakdown {
  margin: 0 !important;
  padding: 4px 14px;
}

.ssp-order-summary-picker .charges-breakdown > .d-flex {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid #edf1f4;
}

.ssp-order-summary-picker .charges-breakdown > .d-flex:last-child {
  border-bottom: 0;
}

.ssp-order-summary-picker .summary-order-total-row {
  margin-top: 2px;
  border-top: 1px solid #d8dcdf;
  border-bottom: 0 !important;
}

.ssp-order-summary-picker .charge-price-wrapper.free-charge {
  width: auto;
  border-radius: 4px;
  background: #e9fbf8;
  color: #0d7c73;
}

.ssp-order-summary-picker .add-referral-wrapper {
  width: 100%;
  margin: 0;
  padding: 12px 14px;
  border: 0;
  border-top: 1px solid #edf1f4;
  background: #f7fafc;
  color: #1c2026;
  font-family: Inter, Helvetica, Arial, sans-serif;
  text-align: left;
}

.ssp-order-summary-picker .summary-driver-tip {
  padding-bottom: 48px !important;
  margin-top: 12px;
  border-color: #edf1f4 !important;
  border-radius: 10px !important;
  box-shadow: none;
  background: #fff;
}

.ssp-order-summary-picker .summary-tip-option {
  width: 42px !important;
  min-width: 42px;
  max-width: 42px;
  min-height: 42px;
  height: 42px;
  flex: 0 0 42px;
  padding: 0 !important;
  border: 1px solid #d8dcdf;
  background: #fff;
  color: #1c2026;
  font-family: Inter, Helvetica, Arial, sans-serif;
  aspect-ratio: 1 / 1;
  transition: background-color 0.15s ease, border-color 0.15s ease, font-weight 0.15s ease;
}

.ssp-order-summary-picker .summary-driver-tip .gap-8 {
  justify-content: flex-start;
  gap: 8px !important;
  flex-wrap: wrap;
}

.ssp-order-summary-picker .summary-tip-option span {
  font-size: 14px;
  line-height: 18px;
}

.ssp-order-summary-picker .summary-tip-option.is-active {
  border-color: #0890f1;
  background: #daf4ff;
  font-weight: 700;
}

.ssp-order-summary-picker .summary-tip-tooltip {
  position: absolute;
  right: 16px;
  bottom: 12px;
  left: 16px;
  display: flex;
  justify-content: center;
  padding: 4px 16px;
  border-radius: 6px;
  background-color: #eef7fb;
  color: #585c62;
  text-align: center;
}

.ssp-order-summary-picker .summary-tip-tooltip::before {
  content: "";
  position: absolute;
  top: -8px;
  left: 68%;
  width: 16px;
  height: 16px;
  background: #eef7fb;
  transform: rotate(45deg);
}

.ssp-order-summary-picker .summary-tip-tooltip > div {
  position: relative;
  z-index: 1;
}

.ssp-order-summary-picker .summary-subscription-card {
  background: #fff;
  border-color: #edf1f4 !important;
  border-radius: 10px !important;
  box-shadow: none;
}

.ssp-order-summary-picker .summary-subscription-card:hover,
.ssp-order-summary-picker .summary-payment-option:hover,
.ssp-order-summary-picker .summary-line:hover {
  border-color: #bfeeff !important;
  box-shadow: 0 8px 22px rgba(8, 144, 241, 0.08);
}

.ssp-order-summary-picker .summary-subscription-card .text-end {
  width: auto !important;
  flex: 0 0 auto;
  white-space: nowrap;
}

.ssp-order-summary-picker .ssp-summary-membership-brand {
  min-width: 0;
  gap: 8px !important;
}

.ssp-order-summary-picker .ssp-summary-membership-logo {
  width: 24px;
  max-width: 24px;
  flex: 0 0 24px;
  overflow: hidden;
}

.ssp-order-summary-picker .ssp-summary-membership-logo .lh-brand__icon {
  width: 24px;
  height: 22px;
}

.ssp-order-summary-picker .ssp-summary-membership-logo .lh-brand__text {
  display: none;
}

.ssp-order-summary-picker .ssp-summary-membership-name {
  min-width: 0;
  color: #1c2026;
  font-size: 14px;
  line-height: 18px;
  font-weight: 700;
  white-space: nowrap;
}

.ssp-order-summary-picker .input-checkbox {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
}

.ssp-order-summary-picker .input-checkbox > * {
  position: absolute;
}

.ssp-order-summary-picker .input-checkbox input {
  z-index: 2;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

.ssp-order-summary-picker .input-checkbox img {
  width: 20px;
  height: 20px;
}

.ssp-order-summary-picker .booking-summary--body {
  padding-top: 0;
}

.ssp-order-summary-picker .booking-summary--body hr {
  display: none;
}

.ssp-order-summary-picker .summary-line {
  margin-bottom: 10px;
  padding: 12px !important;
  border: 1px solid #edf1f4;
  border-radius: 10px;
  background: #fff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ssp-order-summary-picker .summary-line--header {
  min-width: 0;
}

.ssp-order-summary-picker .summary-line--content {
  margin-top: 4px;
  padding-left: 0 !important;
}

.ssp-order-summary-picker .summary-edit-icon {
  position: relative;
  display: inline-flex;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #baebff;
}

.ssp-order-summary-picker .summary-edit-icon::before {
  content: "";
  width: 9px;
  height: 9px;
  border-right: 2px solid #1c2026;
  border-bottom: 2px solid #1c2026;
  transform: rotate(-45deg);
}

.ssp-order-summary-picker .terms-wrapper a {
  color: #0890f1;
  font-weight: 700;
  text-decoration: none;
}

.ssp-order-summary-picker .terms-wrapper {
  margin-top: 2px !important;
  padding: 10px 2px 14px !important;
}

.ssp-order-summary-picker .summary-payment-wrapper {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px !important;
  padding-right: 0 !important;
  padding-left: 0 !important;
}

.ssp-order-summary-picker .summary-payment-option {
  border: 1px solid #edf1f4;
  border-radius: 10px;
  background: #fff;
  box-shadow: none;
  cursor: pointer;
  overflow: hidden;
}

.ssp-order-summary-picker .summary-payment-option[hidden] {
  display: none !important;
}

.ssp-order-summary-picker .summary-payment-option__head {
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 58px;
  padding: 14px 16px;
}

.ssp-order-summary-picker .summary-payment-radio {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  border: 2px solid #727987;
  border-radius: 50%;
  background: #fff;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-radio {
  border-color: #087ced;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-radio::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: #087ced;
}

.ssp-order-summary-picker .summary-payment-mark {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.ssp-order-summary-picker .summary-payment-title {
  color: #006fc9;
  font-size: 16px;
  line-height: 22px;
  font-weight: 700;
}

.ssp-order-summary-picker .summary-payment-option:not(.is-active) .summary-payment-title {
  color: #6b7280;
}

.ssp-order-summary-picker .summary-payment-detail {
  display: none;
  margin: 0 14px;
  overflow: hidden;
  border: 1px solid #dce1e5;
  border-radius: 6px;
  background: #fff;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-detail {
  display: block;
}

.ssp-order-summary-picker .summary-payment-detail__logo {
  display: block;
  width: 44px;
  height: 44px;
  margin: 14px 0 12px 14px;
  object-fit: contain;
}

.ssp-order-summary-picker .summary-payment-selected {
  margin: 0;
  padding: 0 14px 16px;
  color: #3f434c;
  font-size: 16px;
  line-height: 22px;
}

.ssp-order-summary-picker .summary-payment-redirect {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px;
  border-top: 1px solid #edf0f2;
  color: #6f7582;
  font-size: 14px;
  line-height: 21px;
}

.ssp-order-summary-picker .summary-payment-window-icon {
  position: relative;
  width: 48px;
  height: 34px;
  flex: 0 0 48px;
  border: 2px solid #a8adb7;
  border-radius: 4px;
}

.ssp-order-summary-picker .summary-payment-window-icon::before {
  content: "";
  position: absolute;
  top: 7px;
  right: -11px;
  width: 18px;
  height: 18px;
  border-top: 2px solid #a8adb7;
  border-right: 2px solid #a8adb7;
  transform: rotate(45deg);
}

.ssp-order-summary-picker .summary-payment-window-icon::after {
  content: "";
  position: absolute;
  top: -2px;
  left: 5px;
  width: 26px;
  height: 5px;
  border-radius: 3px;
  background: #a8adb7;
}

.ssp-order-summary-picker .summary-payment-terms {
  display: none;
  margin: 0;
  padding: 12px 16px 16px;
  color: #6f7582;
  font-size: 13px;
  line-height: 20px;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-terms {
  display: block;
}

.ssp-order-summary-picker .summary-payment-card-icon {
  position: relative;
  width: 22px;
  height: 16px;
  flex: 0 0 22px;
  border-radius: 2px;
  background: #6f7582;
}

.ssp-order-summary-picker .summary-payment-card-icon::before {
  content: "";
  position: absolute;
  top: 4px;
  left: 0;
  right: 0;
  height: 3px;
  background: #fff;
  opacity: 0.95;
}

.ssp-order-summary-picker .summary-payment-cash-icon {
  position: relative;
  width: 24px;
  height: 18px;
  flex: 0 0 24px;
  border: 2px solid #0d7c73;
  border-radius: 4px;
  background: #e9fbf8;
}

.ssp-order-summary-picker .summary-payment-cash-icon::before {
  content: "";
  position: absolute;
  inset: 4px 7px;
  border: 2px solid #0d7c73;
  border-radius: 50%;
}

.ssp-order-summary-picker .summary-payment-cash-large {
  position: relative;
  display: block;
  width: 52px;
  height: 36px;
  margin: 18px 0 14px 14px;
  border: 2px solid #0d7c73;
  border-radius: 6px;
  background: #e9fbf8;
}

.ssp-order-summary-picker .summary-payment-cash-large::before {
  content: "";
  position: absolute;
  inset: 8px 17px;
  border: 2px solid #0d7c73;
  border-radius: 50%;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-cash-icon,
.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-cash-large {
  border-color: #0890f1;
  background: #daf4ff;
}

.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-cash-icon::before,
.ssp-order-summary-picker .summary-payment-option.is-active .summary-payment-cash-large::before {
  border-color: #0890f1;
}

.ssp-order-summary-picker .summary-payment-card-large {
  position: relative;
  display: block;
  width: 48px;
  height: 34px;
  margin: 18px 0 14px 14px;
  border-radius: 5px;
  background: #6f7582;
}

.ssp-order-summary-picker .summary-payment-card-large::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0;
  right: 0;
  height: 6px;
  background: #fff;
  opacity: 0.95;
}

.ssp-order-summary-picker .button {
  margin-top: 16px;
}

.ssp-order-summary-picker #summary-button-order {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border-radius: 4px;
  min-height: 56px;
  border: 0;
  background: #0890f1;
  color: #fff;
  font-size: 18px;
  line-height: 22px;
  text-transform: uppercase;
  transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

.ssp-order-summary-picker #summary-button-order:hover,
.ssp-order-summary-picker #summary-button-order:focus {
  background: #32a9fe;
  box-shadow: 0 8px 18px rgba(8, 144, 241, 0.22);
  color: #fff;
}

.ssp-order-summary-picker .summary-lock-icon {
  flex: 0 0 auto;
}

@media (min-width: 768px) {
  .ssp-services-picker .ssp-service-category-tabs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ssp-services-picker {
    max-width: 720px;
  }

  .ssp-services-picker.mt-md-40 {
    margin-top: 40px !important;
  }

  .ssp-services-picker .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }

  .ssp-services-picker .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }

  .ssp-services-picker .order-md-0 {
    order: 0 !important;
  }

  .ssp-services-picker .d-md-none {
    display: none !important;
  }

  .ssp-services-picker .d-md-block {
    display: block !important;
  }

  .ssp-services-picker .d-md-flex {
    display: flex !important;
  }

  .ssp-services-picker .mb-md-24 {
    margin-bottom: 24px !important;
  }

  .ssp-booking-app .mt-md-24 {
    margin-top: 24px !important;
  }

  .ssp-booking-app .mb-md-24 {
    margin-bottom: 24px !important;
  }

  .ssp-services-picker .mb-md-48 {
    margin-bottom: 48px !important;
  }

  .ssp-services-picker .px-md-16 {
    padding-right: 16px !important;
    padding-left: 16px !important;
  }

  .ssp-services-picker .pt-md-16 {
    padding-top: 16px !important;
  }

  .ssp-services-picker .me-md-32 {
    margin-right: 32px !important;
  }

  .ssp-services-picker .gap-md-32 {
    gap: 32px !important;
  }

  .ssp-services-picker h1.smaller-mobile {
    font-size: 36px;
    line-height: 40px;
  }

  .ssp-order-summary-intro .container {
    max-width: 720px;
  }

  .ssp-order-summary-intro .font-36d-24m {
    font-size: 36px;
    line-height: 40px;
  }

  .ssp-contact-picker .edit-user .edit-user--phone-row {
    grid-template-columns: repeat(12, minmax(0, 1fr));
    grid-template-areas: "phoneCode phoneCode phoneCode phoneCode phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody";
  }

  .ssp-order-summary-picker .border-light-grey-1-md-only {
    border: 1px solid #d8dcdf;
  }

  .ssp-order-summary-picker .simplified-booking-summary {
    position: sticky;
    top: 24px;
  }
}

@media (min-width: 992px) {
  .ssp-services-picker {
    max-width: 960px;
  }

  .ssp-services-picker .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }

  .ssp-order-summary-intro .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .ssp-services-picker {
    max-width: 1320px;
  }

  .ssp-order-summary-intro .container {
    max-width: 1320px;
  }

  .ssp-contact-picker .edit-user .edit-user--phone-row {
    grid-template-columns: repeat(10, minmax(0, 1fr));
    grid-template-areas: "phoneCode phoneCode phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody phoneBody";
  }
}

/* Keep price-list service names readable on narrow phones. */
.ssp-services-picker .ssp-service-category-tab strong,
.ssp-services-picker .ssp-service-category-tab span {
  min-width: 0;
}

@media (max-width: 575px) {
  .ssp-services-picker .ssp-service-category-tab strong {
    overflow: visible;
    text-overflow: clip;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .ssp-services-picker .ssp-service-category-tab span {
    white-space: normal;
  }
}

@media (max-width: 420px) {
  .ssp-services-picker .ssp-service-category-tabs {
    grid-template-columns: 1fr;
  }
}

/* Price-list order summary refinements only. */
.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible details {
  display: block;
}

.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible summary {
  list-style: none;
  cursor: pointer;
}

.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible summary::-webkit-details-marker {
  display: none;
}

.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible .ssp-sidebar-category-header::after {
  content: "";
  flex: 0 0 auto;
  width: 8px;
  height: 8px;
  margin-left: 2px;
  border-right: 2px solid #585c62;
  border-bottom: 2px solid #585c62;
  transform: rotate(45deg);
  transition: transform 0.16s ease;
}

.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible details[open] .ssp-sidebar-category-header::after {
  transform: rotate(225deg);
}

.ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group--collapsible .ssp-sidebar-category-header span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.ssp-mobile-order-summary-toggle {
  display: none;
}

@media (max-width: 767px) {
  .ssp-price-list-page {
    padding-bottom: 178px;
  }

  .ssp-price-list-page .ssp-services-picker .simplified-booking-summary,
  .ssp-price-list-page .ssp-services-picker .cart-summary {
    display: contents;
  }

  .ssp-price-list-page .ssp-services-picker .full-cart-summary {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1000;
    max-height: 78vh;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 18px 18px 0 0 !important;
    overflow-y: auto;
    background: #fff;
    box-shadow: 0 -16px 36px rgba(28, 32, 38, 0.18);
  }

  .ssp-price-list-page .ssp-services-picker .full-cart-items {
    display: none;
    order: 12;
    margin: 0;
    padding: 0 16px 10px;
  }

  .ssp-price-list-page .ssp-services-picker .full-cart-header,
  .ssp-price-list-page .ssp-services-picker .ssp-cart-empty {
    display: none !important;
  }

  .ssp-price-list-page .ssp-services-picker .full-cart-summary.is-mobile-summary-expanded .full-cart-items,
  .ssp-price-list-page .ssp-services-picker .full-cart-summary.is-mobile-summary-expanded .ssp-cart-empty:not([hidden]) {
    display: block !important;
  }

  .ssp-price-list-page .ssp-services-picker .full-cart-summary.is-mobile-summary-expanded .ssp-cart-empty:not([hidden]) {
    order: 12;
    margin: 0 16px 10px;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-sidebar-category-group {
    margin-bottom: 10px;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-count,
  .ssp-price-list-page .ssp-services-picker .full-cart-summary .d-none.d-md-flex {
    display: none !important;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-minimum-note {
    order: 22;
    margin: 0 !important;
    padding: 0 16px 8px;
    border: 0;
    background: #fff;
    text-align: center;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-minimum-note strong {
    display: none;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-minimum-note span {
    color: #6f4b00;
    font-size: 13px;
    line-height: 18px;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-minimum-note.is-valid {
    display: none;
  }

  .ssp-price-list-page .ssp-mobile-order-summary-toggle {
    order: 18;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    width: 100%;
    min-height: 34px;
    padding: 8px 16px 2px;
    border: 0;
    background: #fff;
    color: #1c2026;
    cursor: pointer;
  }

  .ssp-price-list-page .ssp-mobile-order-summary-toggle__text {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .ssp-price-list-page .ssp-mobile-order-summary-toggle__icon {
    width: 13px;
    height: 13px;
    border-right: 2px solid #585c62;
    border-bottom: 2px solid #585c62;
    transform: rotate(225deg);
    transition: transform 0.16s ease;
  }

  .ssp-price-list-page .full-cart-summary.is-mobile-summary-expanded .ssp-mobile-order-summary-toggle__icon {
    transform: rotate(45deg);
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-total {
    order: 20;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin: 0;
    padding: 10px 16px 8px;
    border-top: 0;
    background: #fff;
    box-shadow: none;
  }

  .ssp-price-list-page .ssp-services-picker .ssp-cart-total span,
  .ssp-price-list-page .ssp-services-picker .ssp-cart-total strong {
    margin: 0;
    white-space: nowrap;
  }

  .ssp-price-list-page .ssp-services-picker .booking-summary-cta-wrapper {
    order: 24;
    margin: 0;
    padding: 0 16px 14px;
    background: #fff;
    box-shadow: none;
  }

  .ssp-price-list-page .ssp-services-picker #summary-button {
    min-height: 52px;
    width: 100%;
  }
}
