/* .cta-wrapper {
align-items: end;
background: url(https://147239775.fs1.hubspotusercontent-eu1.net/hubfs/147239775/abnormal_hero_intro.jpg);
background-position: bottom;
background-repeat: no-repeat;
background-size: cover;
display: flex;
min-height: 75svh;
position: relative;
}

section.cta-wrapper:before {
content: '';
width: 100%;
height: 100%;
position: absolute;
background: linear-gradient(180deg,rgba(255, 255, 255, 0) 0%, rgba(21, 24, 24, 1) 100%);
}

.cta-wrapper .cta-large-container {
margin-left: auto;
margin-right: auto;
max-width: calc(100% - 100px);
padding-left: 16px;
padding-right: 16px;
width: 100%;
position: relative;
}

.cta-wrapper .cta-hero-content {
padding-bottom: 150px;
max-width: 500px;
margin-left: auto;
text-align: right;
} */

.cta-wrapper {
  overflow: hidden;
}

.cta-dots {
  background-color: #000;
  position: absolute;
  width: 20px;
  height: 20px;
  border-radius: 20px;
}

/* Pulse ring */
.cta-dots::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid #00ff7f;
  animation: ring-pulse 1.2s infinite;
}

.cta-dots:hover {
  animation-play-state: paused !important;
  transform: scale(1) !important; /* reset size */
  opacity: 1 !important;         /* reset opacity */
  cursor: pointer;
}

.cta-dots:hover:after {
  animation-play-state: paused !important;
  transform: scale(1) !important; /* reset size */
  opacity: 1 !important;          /* reset opacity */
}

/* Tooltip */
.cta-dots::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 150%;            /* show above the dot */
  left: 50%;
  transform: translateX(-50%);
  background: #111;
  color: #fff;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 11px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

/* Show tooltip on hover */
.cta-dots:hover::before {
  opacity: 1;
  transform: translateX(-50%) translateY(-4px);
}

/* Your keyframes */
@keyframes ring-pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}



.safety-dot-1 {
  top: 55%;
  left: 14%;
}

.safety-dot-2 {
  top: 47%;
  left: 32%;
}

.safety-dot-3 {
  top: 33%;
  left: 41%;
}

.safety-dot-4 {
  top: 40%;
  left: 68%;
}

.safety-dot-5 {
  top: 40%;
  left: 68%;
}

.safety-dot-6 {
  top: 25%;
  left: 72%;
}

.safety-dot-7 {
  top: 35%;
  left: 75%;
}

/* @keyframes pulse {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

.cta-dots:after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid #00ff7f;
  animation: ring-pulse 1.5s infinite;
}

@keyframes ring-pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  60% {
    opacity: 1;
  }
  100% {
    transform: scale(1.6);
    opacity: 0; /* resets sooner so it doesn’t stay invisible */
  }
} */


.placement-dots {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.dots-wrapper {
  position: relative;
  border-radius: 12px;
}

.cta-wrapper img {
  width: 100%;
  border-radius: 12px;
}