/* Communication CTA (Figma 11332:7) */
.cta { position: relative; padding: 36px 0 20px; background: transparent !important; }

/* Top note */
.cta__note {
  max-width: 540px; margin: 0 0 8px; text-align: center;
  background: linear-gradient(to bottom, rgba(210, 228, 255, 0) 0%, rgba(210, 228, 255, 0.62) 40%);
  padding: 0 10px 2px;
  color: rgba(0,0,0,0.7); font-size: 14px; line-height: 20px; padding: 16px 18px;
}

/* Mini card and scribble */
.cta__mini { position: relative; width: 180px; height: 90px; background: #fff; border-radius: 10px; margin: 60px auto 60px; box-shadow: 13px 14px 40px rgba(39,98,131,0.15); display: grid; place-items: center; left: -130px; }
.cta__mini-icon { position: absolute; top: -35px; left: 50%; transform: translateX(-50%); width: 52px; height: 52px; }
.cta__mini-icon img { width: 100%; height: 100%; object-fit: contain; }
.cta__mini-text { color: #4b4d4c; font-size: 14px; letter-spacing: 0.6px; text-align: center; width: 195px; }
.cta__mini-scribble { position: absolute; left: 27%; top: 170px; width: 80px; height: 20px; transform: rotate(25deg) scaleY(-1); pointer-events: none; }

/* Banner */
.cta__banner { position: relative; max-width: 1369px; margin: 16px auto 0; height: 412px; border-radius: 25px; overflow: hidden; }
.cta__bg { position: absolute; inset: 0; }
.cta__bg::before {
  content: ""; position: absolute; inset: 0; border-radius: 25px; pointer-events: none;
  background: linear-gradient(90deg, #00b894 0%, #D2EAEF 100%);
}

/* Ensure the banner itself has no paint behind the bg shape */
.cta__banner { background: transparent !important; overflow: visible; }
.cta__bg-shape { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.25; }

.cta__content { position: absolute; left: 80px; top: 100px; max-width: 650px; z-index: 1; text-align: left; }
.cta__title { color: #fff; font-weight: 700; font-size: 53.3px; line-height: 63.8px; margin: 0 0 10px; }
.cta__sub { color: #4d4d4d; font-size: 20px; line-height: 30px; margin: 0; max-width: 500px; }

.cta__hero { position: absolute; right: 21px; bottom: -30px; width: 535px; height: 560px; z-index: 1; }
.cta__hero img { width: 100%; height: 100%; object-fit: contain; display: block; }

/* Responsive */
@media (max-width: 1200px) {
  .cta__banner { height: 380px; }
  .cta__title { font-size: 46px; line-height: 56px; }
  .cta__hero { width: 460px; height: 480px; }
}

@media (max-width: 992px) {
  .cta__banner { height: auto; padding: 24px 24px 0; }
  .cta__content { position: relative; left: 0; top: 0; max-width: none; text-align: left; }
  .cta__hero { position: relative; right: auto; bottom: auto; margin: 16px auto 0; width: 70%; height: auto; }
}

@media (max-width: 640px) {
  .cta { padding: 24px 0; }
  .cta__note { margin-bottom: 6px; }
  .cta__mini-scribble { display: none; }
  /* Center the mini card on small screens */
  .cta__mini { left: 0; margin-left: auto; margin-right: auto; }
  .cta__title { font-size: 34px; line-height: 40px; }
  .cta__sub { font-size: 16px; line-height: 24px; }
  .cta__hero { width: 88%; }
}
