.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: 60px;
  line-height: 80px;
}

.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: 200px;
  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 {
  --handshake-offset: 132px;
  position: relative;
  display: grid;
  grid-template-columns: 212px 287px;
  grid-template-rows: 191px 65px auto;
  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;
}

.spms-mosaic .mosaic-handshake {
  grid-column: 1 / -1;
  grid-row: 3;
  width: calc(100% - var(--handshake-offset));
  height: auto;
  margin-left: var(--handshake-offset);
}

.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;
  width: min(calc(100% - var(--container-gutter)), 1320px);
  grid-template-columns: minmax(320px, 620px) minmax(420px, 569px);
  gap: 100px;
  align-items: center;
}

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

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

.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: clamp(10px, 3.23cqw, 20px) clamp(9px, 2.9cqw, 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: clamp(8px, 2.42cqw, 15px);
  line-height: clamp(12px, 2.9cqw, 18px);
}

.imac-quadrant strong {
  margin-top: clamp(2px, 0.65cqw, 4px);
  font-size: clamp(11px, 4.5cqw, 17px);
  font-weight: 600;
  line-height: clamp(13px, 3.23cqw, 20px);
}

.imac-quadrant--top-left {
  top: 13.8%;
  left: 11.2%;
  align-items: flex-end;
  justify-content: end;
  padding-right: clamp(10px, 3.23cqw, 20px);
  padding-bottom: clamp(20px, 6.45cqw, 40px);
  border-top-left-radius: 100%;
  text-align: right;
}

.imac-quadrant--top-right {
  top: 13.8%;
  right: 11.2%;
  align-items: flex-start;
  justify-content: end;
  padding-left: clamp(10px, 3.23cqw, 20px);
  padding-bottom: clamp(20px, 6.45cqw, 40px);
  border-top-right-radius: 100%;
  text-align: left;
}

.imac-quadrant--bottom-left {
  bottom: 13.8%;
  left: 11.2%;
  align-items: flex-end;
  justify-content: start;
  padding-right: clamp(10px, 3.23cqw, 20px);
  padding-top: clamp(20px, 6.45cqw, 40px);
  border-bottom-left-radius: 100%;
  text-align: right;
}

.imac-quadrant--bottom-right {
  right: 11.2%;
  bottom: 13.8%;
  align-items: flex-start;
  justify-content: start;
  padding-left: clamp(10px, 3.23cqw, 20px);
  padding-top: clamp(20px, 6.45cqw, 40px);
  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;
  min-height: clamp(48px, 10.97cqw, 68px);
  padding:
    clamp(8px, 1.94cqw, 12px)
    clamp(9px, 2.26cqw, 14px)
    clamp(7px, 1.61cqw, 10px);
  border-radius: clamp(4px, 0.97cqw, 6px);
  background: var(--color-white);
  color: var(--color-black);
  font-size: clamp(9px, 2.26cqw, 14px);
  font-weight: 500;
  line-height: clamp(12px, 2.9cqw, 18px);
  text-align: center;
  transform: translate(-50%, -50%);
}

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

.imac-axis-label {
  position: absolute;
  z-index: 5;
  width: clamp(90px, 22.42cqw, 139px);
  height: clamp(36px, 9.03cqw, 56px);
  color: var(--color-white);
  font-size: clamp(12px, 2.9cqw, 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-family: var(--font-display);
  font-size: var(--title-section-size);
  line-height: var(--title-section-line);
  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;
}

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

  .framework-layout {
    gap: clamp(28px, 4vw, 42px);
  }

  .spms-intro {
    gap: 40px;
  }

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

  .spms-mosaic {
    justify-content: center;
  }

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

}

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

  .spms-page .hero-title {
    font-size: var(--title-hero-mobile-size);
    line-height: var(--title-hero-mobile-line);
  }

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

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

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

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

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

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

  .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;
  }

}

@media (min-width: 761px) and (max-width: 1180px) and (orientation: landscape) {
  .framework-layout {
    grid-template-columns: minmax(410px, 1fr) minmax(390px, 0.96fr);
    gap: clamp(22px, 3vw, 40px);
  }

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

  .framework-card {
    min-height: 0;
    padding: 44px 42px 60px;
  }

  .framework-title {
    font-size: clamp(34px, 3.6vw, 42px);
  }

  .framework-title-question {
    white-space: normal;
  }
}

@media (max-width: 760px) {
  .spms-framework {
    padding-top: 58px;
  }

  .framework-layout {
    --spms-mobile-framework-size: min(100%, 320px);
    justify-items: center;
    gap: 24px;
  }

  .framework-visual,
  .framework-card {
    width: var(--spms-mobile-framework-size);
    max-width: var(--spms-mobile-framework-size);
  }

  .imac-diagram {
    --diagram-size: min(calc(100% - 70px), 320px);
    flex: 0 0 auto;
  }

  .imac-quadrant span {
    font-size: clamp(7px, 2.25cqw, 10px);
    line-height: clamp(9px, 2.9cqw, 12px);
  }

  .imac-quadrant strong {
    font-size: clamp(8px, 2.75cqw, 12px);
    line-height: clamp(10px, 3.2cqw, 14px);
  }

  .imac-center {
    min-height: clamp(36px, 11.2cqw, 46px);
    padding: clamp(5px, 1.8cqw, 8px) clamp(6px, 2.2cqw, 9px);
    font-size: clamp(7px, 2.55cqw, 10px);
    line-height: clamp(9px, 3.1cqw, 12px);
  }

  .imac-axis-label {
    font-size: clamp(10px, 3.1cqw, 13px);
  }

  .framework-card {
    display: flex;
    min-height: 320px;
    flex-direction: column;
    padding: 28px 24px 56px;
  }

  .framework-title {
    font-size: 32px;
    line-height: 1.18;
  }

  .framework-rule {
    margin: 8px 0 20px;
  }

  .framework-copy {
    flex: 1 1 auto;
  }

  .framework-card p {
    font-size: 16px;
    line-height: 26px;
  }

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