.compliance {
  position: relative;
  padding: 0 0 100px;
  background: linear-gradient(135deg,
    var(--color-navy) 0%,
    #16345A 30%,
    #132E50 60%,
    var(--color-navy-deep) 100%);
  overflow: hidden;
}


.compliance__bg-ring {
  position: absolute;
  bottom: -6%;
  left: -6%;
  width: 500px;
  opacity: 0.04;
  pointer-events: none;
  z-index: -1;
}

@keyframes complianceRingBreathe {
  0%, 100% { opacity: 0.04; }
  50% { opacity: 0.07; }
}

@media (prefers-reduced-motion: no-preference) {
  .compliance__bg-ring {
    animation: complianceRingBreathe 5s ease-in-out infinite;
  }
}

.compliance__bg-blob {
  position: absolute;
  top: -6%;
  right: -6%;
  width: 550px;
  opacity: 0.07;
  pointer-events: none;
  z-index: 0;
}

@media (prefers-reduced-motion: no-preference) {
  .compliance__bg-blob {
    animation: blobFloat 10s ease-in-out infinite alternate;
  }
}

/* .compliance__inner {
  position: relative;
  z-index: 1;
  padding: 60px 0;
} */

.compliance__inner {
  position: relative;
  z-index: 1;
  padding-top: 60px;
  padding-bottom: 60px;
}

.compliance__hero-image {
  display: block;
  width: 580px;
  max-width: 95%;
  margin: 0 auto 0;
}

@media (prefers-reduced-motion: no-preference) {
  .compliance__hero-image {
    animation: complianceHeroFloat 6s ease-in-out infinite;
  }
}

@keyframes complianceHeroFloat {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-6px); }
}

.compliance__illustration-wrapper {
  position: relative;
  text-align: center;
}

.compliance__illustration-wrapper::after {
  content: '';
  position: absolute;
  bottom: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 80%;
  height: 60px;
  background: radial-gradient(ellipse, rgba(59,191,178,0.25) 0%, rgba(59,191,178,0.10) 40%, transparent 75%);
  z-index: 0;
  pointer-events: none;
}

@media (prefers-reduced-motion: no-preference) {
  .compliance__illustration-wrapper::after {
    animation: complianceGlowPulse 4s ease-in-out infinite;
  }
}

@keyframes complianceGlowPulse {
  0%, 100% { opacity: 0.6; transform: translateX(-50%) scaleX(1); }
  50% { opacity: 1; transform: translateX(-50%) scaleX(1.08); }
}

.compliance__headline {
  text-align: center;
  font-size: var(--fs-h2);
  font-weight: var(--fw-bold);
  color: white;
  margin-bottom: 12px;
}

.compliance__subhead {
  text-align: center;
  font-size: var(--fs-body);
  color: var(--white-70);
  margin-bottom: 64px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.compliance__pillars {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 840px;
  margin: 0 auto 48px;
  position: relative;
  z-index: 1;
}

.compliance__pillar {
  text-align: center;
  padding: 32px 20px;
  background: var(--white-5);
  border: 1px solid var(--white-10);
  border-radius: var(--radius-lg);
  transition: all var(--transition-default);
}

.compliance__pillar:hover {
  background: rgba(255, 255, 255, 0.08);
  transform: translateY(-4px);
  border-color: var(--teal-40);
}

.compliance__pillar-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 16px;
  color: var(--color-teal);
}

.compliance__pillar-headline {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: white;
  margin-bottom: 8px;
}

.compliance__pillar-text {
  font-size: var(--fs-small);
  color: var(--white-65);
  line-height: var(--lh-body);
}

.compliance__cta-row {
  text-align: center;
  position: relative;
}

.compliance__cta-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-small);
  font-weight: var(--fw-semibold);
  color: var(--color-teal);
  transition: gap var(--transition-default);
}

.compliance__cta-link:hover {
  gap: 10px;
}

@media (max-width: 1024px) {
  .compliance__pillars {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 767px) {
  .compliance__hero-image,
  .compliance__illustration-wrapper {
    display: none !important;
  }

  .compliance__bg-ring,
  .compliance__bg-blob {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .compliance__pillars {
    grid-template-columns: 1fr;
  }

  .compliance__inner {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
