.section--cta {
  padding-top: 120px;
}

.section--cta .cta-panel {
  position: relative;
  overflow: hidden;
  padding-top: 80px;
  padding-bottom: 80px;
}

.section--cta .cta-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(115deg, rgba(59, 130, 246, 0.2), transparent 34%),
    linear-gradient(245deg, rgba(124, 58, 237, 0.2), transparent 38%),
    linear-gradient(180deg, rgba(6, 182, 212, 0.14), transparent 58%);
  opacity: 0.72;
  pointer-events: none;
}

.section--cta .cta-panel::after {
  content: none;
}

.section--cta .cta-copy,
.section--cta .cta-actions {
  position: relative;
  z-index: 2;
}

.section--cta .cta-copy h2 {
  font-size: 40px;
  line-height: 56px;
}

@media (prefers-reduced-motion: reduce) {
  .section--cta .cta-panel::after {
    animation: none;
  }
}

@media (max-width: 640px) {
  .section--cta {
    padding-top: 64px;
  }

  .section--cta .cta-copy h2 {
    font-size: 32px;
    line-height: 1.35;
    white-space: normal;
    overflow-wrap: break-word;
  }
}
