.principle {
  color: #1d2141;
  padding: 8.5rem 0 6.375rem;
}
.principle__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 1024px) {
  .principle__inner {
    grid-template-columns: 1fr 1fr;
    gap: 6.125rem;
  }
}
.principle__col--left {
  position: relative;
  padding-top: 1.75rem;
  padding-left: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.principle__circles {
  position: absolute;
  top: -30%;
  left: -5%;
  width: 9.5rem;
  pointer-events: none;
  z-index: 0;
}
.principle__circles[data-reveal] {
  opacity: 1;
  transform: none;
  transition: none;
}
.principle__circles svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}
.principle__circles svg > path {
  transform-box: fill-box;
  transform-origin: center;
  opacity: 0;
  transform: translateY(60px) scale(0.6);
}
.principle__circles.is-revealed svg > path {
  animation: bubble-up 1.4s cubic-bezier(0.16, 1, 0.3, 1) var(--bubble-delay, 0s) both, bubble-float 6s ease-in-out calc(1.4s + var(--bubble-delay, 0s)) infinite;
}
.principle__circles.is-revealed svg > path:nth-child(1) {
  --bubble-delay: 0s;
}
.principle__circles.is-revealed svg > path:nth-child(2) {
  --bubble-delay: 0.15s;
}
.principle__circles.is-revealed svg > path:nth-child(3) {
  --bubble-delay: 0.30s;
}
.principle__circles.is-revealed svg > path:nth-child(4) {
  --bubble-delay: 0.45s;
}
.principle__circles.is-revealed svg > path:nth-child(5) {
  --bubble-delay: 0.60s;
}
@media (prefers-reduced-motion: reduce) {
  .principle__circles svg > path {
    opacity: 1;
    transform: none;
    animation: none;
  }
}
.principle__label {
  position: relative;
  z-index: 2;
  margin-bottom: 1.125rem;
  font-weight: 400;
  font-size: 15px;
  line-height: 110%;
  text-align: center;
  color: #000;
}
.principle__quote {
  position: relative;
  z-index: 1;
  font-family: "STIX Two Text", Georgia, "Times New Roman", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 70px;
  line-height: 100%;
  letter-spacing: -0.03em;
  color: #1d2141;
  text-align: center;
}
.principle__logo {
  display: block;
  width: 9rem;
  height: auto;
  margin-top: 2.25rem;
}
.principle__col--right {
  display: flex;
  justify-content: flex-end;
}
.principle__image {
  width: 100%;
  height: 34.125rem;
  border-radius: 2.25rem;
  -o-object-fit: cover;
     object-fit: cover;
}

@keyframes bubble-up {
  from {
    opacity: 0;
    transform: translateY(60px) scale(0.6);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes bubble-float {
  0% {
    transform: translate(0, 0);
  }
  25% {
    transform: translate(6px, -4px);
  }
  50% {
    transform: translate(0, -10px);
  }
  75% {
    transform: translate(-6px, -4px);
  }
  100% {
    transform: translate(0, 0);
  }
}