.cta-with-image {
  background: #7371fc;
  background: radial-gradient(circle at 0% 0%, #6b5ef6, #7371fc);
  padding: 2rem;
  margin: 3rem 0;
  border-radius: 16px;
}

.cta-title {
  font-size: 28px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: white !important;
  margin-top: 0;
  margin-bottom: 12px;
}

.cta-subtitle {
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
  color: #dfe3ff !important;
  margin: 0;
  margin-bottom: 1.5rem;
}

.cta-image {
  background-size: cover;
  background-position: center center;
  height: 0;
  padding-bottom: 70%;
  border-radius: 8px;
}

@media screen and (max-width: 768px) {
  .cta-title {
    margin-top: 1rem!important;
  }
}

.cta-button {
  background: white;
  padding: 0.5rem 1.5rem;
  border-radius: 4px;
  font-size: 0.875rem;
  line-height: 1.5rem;
  font-weight: 500;
  display: inline-block;
  color: #7371fc;
  text-decoration: none;
  transition: 0.2s ease-out background;
}
.cta-button:hover {
  background: rgba(255, 255, 255, 0.9);
  color: #7371fc;
}