.spms-page .spms-hero,
.spms-page .spms-framework,
.spms-page .spms-insights,
.spms-page .spms-genesis,
.spms-page .spms-cta {
  scroll-margin-top: 90px;
}

.spms-page .hero-title {
  max-width: 899px;
  margin: 0 0 24px;
  font-size: clamp(42px, 5vw, 60px);
  line-height: 1.2;
}

.spms-hero {
  padding: 128px 0 88px;
}

.spms-hero-image {
  display: block;
  width: 100%;
  height: 363px;
  object-fit: cover;
}

.spms-intro {
  display: grid;
  grid-template-columns: minmax(320px, 570px) minmax(420px, 512px);
  gap: 61px;
  align-items: start;
  margin-top: 24px;
}

.spms-intro .body-copy {
  padding-left: 19px;
}

.spms-intro .body-copy .lede {
  font-size: 22px;
  line-height: 35px;
}

.spms-mosaic {
  position: relative;
  display: grid;
  grid-template-columns: 212px 287px;
  grid-template-rows: 191px 65px 171px;
  gap: 13px 12px;
  min-height: 453px;
}

.spms-mosaic img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mosaic-business {
  grid-row: 1 / span 2;
  object-position: 42% center;
}

.mosaic-eye {
  grid-column: 2;
  grid-row: 1;
}

.mosaic-handshake {
  grid-column: 2;
  grid-row: 3;
}

.mosaic-block {
  display: block;
  background: var(--color-plum);
}

.block-one {
  grid-column: 1;
  grid-row: 3;
  width: 120px;
  height: 71px;
}

.block-two {
  grid-column: 2;
  grid-row: 2;
  width: 78px;
  height: 65px;
}

.spms-framework {
  padding: 120px 0 133px;
  background:
    url("/images/strategic-performance-management-system/framework-background.svg") center / cover no-repeat,
    radial-gradient(circle at center, var(--color-plum) 0%, #050005 100%);
  color: var(--color-white);
}

.framework-layout {
  display: grid;
  grid-template-columns: minmax(320px, 570px) minmax(420px, 569px);
  gap: 100px;
  align-items: center;
}

.framework-visual {
  display: flex;
  justify-content: center;
}

.imac-diagram {
  --diagram-size: min(100%, 570px);
  position: relative;
  width: var(--diagram-size);
  max-width: 570px;
  aspect-ratio: 1;
}

.imac-circle {
  position: absolute;
  inset: 7% 6% 5% 6%;
  z-index: 1;
  width: 88%;
  height: 88%;
  pointer-events: none;
}

.imac-cross {
  position: absolute;
  top: 16%;
  left: 50%;
  z-index: 3;
  width: 46%;
  height: 67%;
  transform: translateX(-50%);
  pointer-events: none;
}

.imac-quadrant {
  position: absolute;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 36.2%;
  height: 33.1%;
  padding: 20px 18px;
  border: 0;
  appearance: none;
  background: transparent;
  color: var(--color-white);
  cursor: pointer;
  font-family: inherit;
  transition:
    background-color 180ms ease,
    color 180ms ease,
    transform 180ms ease;
}

.imac-quadrant:hover {
  transform: scale(1.025);
}

.imac-quadrant:hover,
.imac-quadrant.is-active {
  background: var(--quadrant-color);
}

.imac-quadrant span,
.imac-quadrant strong {
  position: relative;
  z-index: 2;
  display: block;
  font-size: 12px;
  line-height: 16px;
}

.imac-quadrant strong {
  margin-top: 4px;
  font-size: 14px;
  font-weight: 600;
}

.imac-quadrant--top-left {
  top: 13.8%;
  left: 11.2%;
  align-items: flex-end;
  border-top-left-radius: 100%;
  text-align: right;
}

.imac-quadrant--top-right {
  top: 13.8%;
  right: 11.2%;
  align-items: flex-start;
  border-top-right-radius: 100%;
  text-align: left;
}

.imac-quadrant--bottom-left {
  bottom: 13.8%;
  left: 11.2%;
  align-items: flex-end;
  border-bottom-left-radius: 100%;
  text-align: right;
}

.imac-quadrant--bottom-right {
  right: 11.2%;
  bottom: 13.8%;
  align-items: flex-start;
  border-bottom-right-radius: 100%;
  text-align: left;
}

.imac-quadrant--top-left strong {
  color: #42c5f3;
}

.imac-quadrant--top-right strong {
  color: #9dda5d;
}

.imac-quadrant--bottom-left strong {
  color: #ffcd52;
}

.imac-quadrant--bottom-right strong {
  color: #ff1142;
}

.imac-quadrant:hover strong,
.imac-quadrant.is-active strong {
  color: var(--color-white);
}

.imac-quadrant:hover span,
.imac-quadrant.is-active span {
  color: var(--color-white);
}

.imac-center {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 4;
  display: grid;
  place-items: center;
  width: 168px;
  min-height: 68px;
  padding: 12px 14px 10px;
  border-radius: 6px;
  background: var(--color-white);
  color: var(--color-black);
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  text-align: center;
  transform: translate(-50%, -50%);
}

.imac-center strong {
  font-weight: 700;
}

.imac-axis-label {
  position: absolute;
  z-index: 5;
  width: 139px;
  height: 56px;
  color: var(--color-white);
  font-size: 18px;
  line-height: 1;
}

.imac-axis-label img {
  display: block;
  width: 100%;
  height: 100%;
}

.imac-axis-label span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}

.imac-axis-label--top {
  top: 3.2%;
  left: 50%;
  transform: translateX(-50%);
}

.imac-axis-label--left {
  top: 50%;
  left: 0;
  transform: translate(-34%, -50%);
}

.imac-axis-label--right {
  top: 50%;
  right: 0;
  transform: translate(34%, -50%);
}

.imac-axis-label--bottom {
  bottom: 3.2%;
  left: 50%;
  transform: translateX(-50%);
}

.framework-card {
  position: relative;
  min-height: 471px;
  padding: 51px 55px 65px;
  border-radius: 10px;
  background: linear-gradient(116deg, #050005 0%, #771847 100%);
  color: var(--color-white);
}

.framework-title {
  margin: 0;
  font-size: clamp(34px, 3.2vw, 40px);
  line-height: 55px;
  color: var(--color-white);
}

.framework-title span {
  display: block;
}

.framework-title [data-framework-accent] {
  display: inline;
}

@media (min-width: 761px) {
  .framework-title-question {
    white-space: nowrap;
  }
}

.accent-cyan {
  color: #42c5f3;
}

.accent-green {
  color: #9dda5d;
}

.accent-yellow {
  color: #ffcd52;
}

.accent-red {
  color: #ff1142;
}

.framework-rule {
  width: 75px;
  height: 3px;
  margin: 6px 0 23px;
  background: var(--color-plum);
}

.framework-card p {
  max-width: 467px;
  margin: 0;
  font-size: 18px;
  line-height: 30px;
}

.framework-card p + p {
  margin-top: 30px;
}

.framework-progress {
  position: absolute;
  left: 50%;
  bottom: 28px;
  display: flex;
  gap: 8px;
  transform: translateX(-50%);
}

.framework-progress button {
  width: 50px;
  height: 5px;
  padding: 0;
  border: 0;
  appearance: none;
  background: var(--progress-color);
  cursor: pointer;
  opacity: 0.4;
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.framework-progress button:hover,
.framework-progress .is-active {
  opacity: 1;
}

.framework-progress button:hover {
  transform: translateY(-2px);
}

.spms-insights {
  padding: 111px 0 110px;
}

.spms-insights .featured-insights__eyebrow {
  margin-bottom: 65px;
}

.spms-insights .featured-insights__action {
  margin-top: 66px;
}

.spms-genesis {
  padding: 107px 0 110px;
}

.spms-genesis-grid {
  display: grid;
  grid-template-columns: 242px minmax(0, 807px);
  gap: 44px 125px;
  align-items: center;
}

.genesis-logo {
  display: block;
  width: 242px;
}

.spms-genesis .body-copy .lede {
  font-size: 22px;
  line-height: 35px;
}

.spms-genesis .button {
  min-width: 281px;
  margin-top: 30px;
}

.spms-cta {
  padding: 56px 0 48px;
  background: var(--color-black);
  color: var(--color-white);
}

.spms-cta-shell {
  display: grid;
  grid-template-columns: minmax(0, 760px) minmax(220px, 366px);
  gap: 56px;
  align-items: center;
  justify-content: space-between;
}

.spms-cta h2 {
  max-width: 760px;
  margin: 0;
  font-size: clamp(32px, 3vw, 42px);
  line-height: 1.28;
}

.spms-cta h2 span {
  display: block;
  color: #e60059;
}

.spms-cta .button {
  justify-self: end;
  min-width: 260px;
}

@media (max-width: 1180px) {
  .spms-intro,
  .framework-layout,
  .spms-genesis-grid,
  .spms-cta-shell {
    grid-template-columns: 1fr;
  }

  .spms-intro {
    gap: 40px;
  }

  .spms-intro .body-copy {
    padding-left: 0;
  }

  .spms-mosaic {
    max-width: 512px;
  }

  .imac-diagram {
    --diagram-size: min(100%, 560px);
  }

  .spms-cta-shell {
    gap: 28px;
    justify-items: start;
  }

  .spms-cta .button {
    justify-self: start;
  }
}

@media (max-width: 760px) {
  .spms-hero {
    padding: 92px 0 72px;
  }

  .spms-page .hero-title {
    font-size: 40px;
  }

  .spms-hero-image {
    height: 220px;
  }

  .spms-mosaic {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 180px 64px 150px;
    gap: 12px;
    min-height: 0;
  }

  .spms-framework {
    padding: 76px 0 84px;
  }

  .imac-diagram {
    --diagram-size: min(82vw, 360px);
  }

  .framework-card {
    min-height: 0;
    padding: 34px 24px 56px;
  }

  .framework-card p {
    font-size: 17px;
    line-height: 28px;
  }

  .imac-quadrant span,
  .imac-quadrant strong {
    font-size: 10px;
    line-height: 14px;
  }

  .imac-quadrant strong {
    font-size: 12px;
  }

  .imac-center {
    min-height: 48px;
    padding: 9px 10px 8px;
    font-size: 10px;
    line-height: 13px;
  }

  .imac-axis-label {
    width: 112px;
    height: 45px;
    font-size: 14px;
  }

  .framework-progress button {
    width: 36px;
  }

  .spms-genesis {
    padding: 72px 0 88px;
  }

  .spms-genesis-grid {
    justify-items: center;
    text-align: center;
  }

  .genesis-logo {
    margin: 0 auto;
  }

  .spms-genesis .button {
    margin-right: auto;
    margin-left: auto;
  }

  .spms-cta h2 {
    font-size: 29px;
    line-height: 1.32;
  }

  .spms-cta h2 span {
    display: inline;
  }

  .spms-cta .button {
    width: 100%;
    min-width: 0;
  }
}
