/* Mobile text cut-off fix for BW101 pages */
.bw101-page,
.bw101-page * {
  max-width: 100%;
  box-sizing: border-box;
}

.bw101-page,
.bw101-page section,
.bw101-page div,
.bw101-page article,
.bw101-page p,
.bw101-page h2,
.bw101-page h3,
.bw101-page li,
.bw101-page a,
.bw101-page button {
  overflow-wrap: anywhere;
  word-wrap: break-word;
  white-space: normal;
}

.bw101-page .bw101-wrap,
.bw101-page .bw101-grid,
.bw101-page .bw101-panel,
.bw101-page .bw101-card,
.bw101-page .bw101-feature,
.bw101-page .bw101-link-card,
.bw101-page .bw101-step,
.bw101-page .bw101-cta,
.bw101-page .bw101-faq-item {
  min-width: 0;
  overflow: visible;
  height: auto;
  max-height: none;
}

.bw101-page img {
  max-width: 100%;
  height: auto;
}

@media (max-width: 767px) {
  .bw101-page .bw101-wrap {
    padding-left: 16px;
    padding-right: 16px;
  }

  .bw101-page .bw101-hero h2 {
    font-size: clamp(2rem, 10vw, 3rem);
    line-height: 1.08;
    overflow-wrap: anywhere;
  }

  .bw101-page .bw101-section h2 {
    font-size: clamp(1.55rem, 8vw, 2.25rem);
    line-height: 1.14;
  }

  .bw101-page .bw101-section h3 {
    font-size: 1.18rem;
  }

  .bw101-page .bw101-section p,
  .bw101-page .bw101-section li,
  .bw101-page .bw101-link-card,
  .bw101-page .bw101-feature {
    font-size: 1rem;
  }

  .bw101-page .bw101-hero,
  .bw101-page .bw101-section,
  .bw101-page .bw101-panel,
  .bw101-page .bw101-card,
  .bw101-page .bw101-cta {
    overflow: visible;
    height: auto;
    max-height: none;
  }

  .bw101-page .bw101-link-grid,
  .bw101-page .bw101-grid,
  .bw101-page .bw101-grid.three,
  .bw101-page .bw101-process,
  .bw101-page .bw101-feature-list,
  .bw101-page .bw101-image-row {
    grid-template-columns: 1fr !important;
  }
}

/* Emergency Elementor mobile clipping fix for BW101 pages */
.elementor:has(.bw101-page),
.elementor-section:has(.bw101-page),
.elementor-container:has(.bw101-page),
.elementor-column:has(.bw101-page),
.elementor-widget-wrap:has(.bw101-page),
.elementor-widget-html:has(.bw101-page),
.elementor-widget-container:has(.bw101-page),
.e-con:has(.bw101-page),
.e-con-inner:has(.bw101-page) {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
  transform: none !important;
}

.bw101-page,
.bw101-page * {
  box-sizing: border-box !important;
  max-width: 100% !important;
}

.bw101-page,
.bw101-page section,
.bw101-page header,
.bw101-page div,
.bw101-page p,
.bw101-page h2,
.bw101-page h3,
.bw101-page li,
.bw101-page a,
.bw101-page button {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
  white-space: normal !important;
  overflow-wrap: break-word !important;
  word-break: normal !important;
}

@media (max-width: 767px) {
  .bw101-page .bw101-wrap {
    width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .bw101-page .bw101-hero-grid,
  .bw101-page .bw101-grid,
  .bw101-page .bw101-grid.three,
  .bw101-page .bw101-process,
  .bw101-page .bw101-link-grid,
  .bw101-page .bw101-feature-list,
  .bw101-page .bw101-image-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .bw101-page .bw101-hero h2 {
    font-size: clamp(1.85rem, 9vw, 2.75rem) !important;
    line-height: 1.1 !important;
  }

  .bw101-page .bw101-section h2 {
    font-size: clamp(1.45rem, 7vw, 2.1rem) !important;
    line-height: 1.15 !important;
  }

  .bw101-page .bw101-panel,
  .bw101-page .bw101-card,
  .bw101-page .bw101-feature,
  .bw101-page .bw101-step,
  .bw101-page .bw101-link-card,
  .bw101-page .bw101-cta {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .bw101-page img,
  .bw101-page .bw101-image,
  .bw101-page .bw101-hero-visual img,
  .bw101-page .bw101-image-row img {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
  }
}