/* Prism carousel 3D */
.prism-stage {
  display: grid;
  min-height: 74vh;
  grid-template-columns: minmax(280px, 0.68fr) minmax(320px, 1fr);
  gap: clamp(24px, 6vw, 78px);
  align-items: center;
  overflow: hidden;
  padding: 32px max(16px, calc((100vw - 1180px) / 2));
  perspective: 1200px;
}

.prism-copy {
  position: relative;
  z-index: 3;
}

.prism-lab {
  display: grid;
  min-height: clamp(420px, 54vw, 620px);
  place-items: center;
  perspective: 1200px;
}

.prism-ring {
  position: relative;
  width: min(84vw, 560px);
  height: min(86vw, 560px);
  transform-style: preserve-3d;
  will-change: transform;
}

.prism-card {
  position: absolute;
  inset: 50% auto auto 50%;
  display: grid;
  width: clamp(170px, 25vw, 260px);
  min-height: clamp(170px, 24vw, 270px);
  align-content: space-between;
  border: 1px solid rgba(17, 19, 21, 0.16);
  border-radius: 8px;
  padding: clamp(18px, 3vw, 24px);
  background: var(--tone);
  box-shadow: 0 26px 68px rgba(17, 19, 21, 0.2);
  color: #111315;
  transform-style: preserve-3d;
  backface-visibility: hidden;
  will-change: transform, opacity;
}

.prism-card::after {
  position: absolute;
  inset: 10px;
  content: "";
  border: 1px solid rgba(17, 19, 21, 0.1);
  border-radius: 6px;
  transform: translateZ(-24px);
}

.prism-card small {
  color: rgba(17, 19, 21, 0.58);
  font-weight: 850;
  text-transform: uppercase;
}

.prism-card h2 {
  margin: 0;
  font-size: clamp(30px, 4.6vw, 58px);
  line-height: 0.9;
}

.prism-card p {
  margin: 0;
  color: rgba(17, 19, 21, 0.68);
}

@media (max-width: 840px) {
  .prism-stage {
    grid-template-columns: 1fr;
  }

  .prism-ring {
    width: min(88vw, 430px);
    height: 430px;
  }

  .prism-card {
    width: min(70vw, 240px);
    min-height: 210px;
  }
}
