.cta-section {
  position: relative;
  height: 520px;
  overflow: hidden;
}

.cta-webgl {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.cta-content {
  position: relative;
  z-index: 2;
  height: 100%;

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  text-align: center;
  backdrop-filter: blur(4px);
}

.cta-content h2 {
  font-size: 3rem;
  color: #f8fafc;
  margin-bottom: 10px;
}

.cta-content p {
  font-size: 1.4rem;
  color: rgba(203,213,225,0.75);
  margin-bottom: 36px;
}

.cta-primary {
  padding: 14px 34px;
  border-radius: 999px;
  background: linear-gradient(135deg,#f8fafc,#cbd5e1);
  color: #020617;
  font-weight: 600;
  text-decoration: none;
}
