.textwidget.custom-html-widget {
  height: 100% !important;
  display: flex;
  flex-direction: column;
}

.services-hero-panel {
  padding: 60px 40px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  position: relative;
  overflow: hidden;
}

.services-hero-panel svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.services-hero-panel .content-wrapper {
  position: relative;
  z-index: 2;
}

.services-hero-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 48px;
  font-weight: 700;
  color: white;
  margin: 0 0 20px 0;
  line-height: 1.2;
  letter-spacing: -0.5px;
}

.services-hero-subtitle {
  font-family: 'Source Sans Pro', sans-serif;
  font-size: 18px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.95);
  margin: 0;
  line-height: 1.6;
  max-width: 90%;
}

.services-hero-title .char,
.services-hero-subtitle .char {
  display: inline-block;
  will-change: opacity, transform;
}

.services-hero-title .char:not(.space),
.services-hero-subtitle .char:not(.space) {
  margin-right: 0;
}

.services-hero-title .space,
.services-hero-subtitle .space {
  width: 0.28em;
  min-width: 0.28em;
}

@media (max-width: 768px) {
  .services-hero-panel {
    padding: 40px 25px;
  }

  .services-hero-title {
    font-size: 32px;
  }

  .services-hero-subtitle {
    font-size: 16px;
  }
}
