.service-showcase-section {
  position: relative;
  overflow: hidden;
  padding: 8rem 0 8.5rem;
  background: linear-gradient(180deg, #fff 0%, #fff 70%, #f2f6fb 100%);
}

.service-showcase-heading {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(18rem, .75fr);
  gap: 5rem;
  align-items: end;
  margin-bottom: 3.5rem;
}

.service-showcase-heading::before {
  top: -.42em;
  left: -.04em;
  font-size: 9.4rem;
}

.service-showcase-heading h2 {
  max-width: 51rem;
  margin: .8rem 0 0;
  color: #0c2335;
  font-family: var(--font-display);
  font-size: 3.65rem;
  font-weight: 800;
  line-height: 1.03;
  letter-spacing: 0;
}

.service-showcase-heading > p {
  max-width: 32rem;
  margin: 0 0 .35rem;
  color: #536876;
  font-size: 1.05rem;
  line-height: 1.75;
}

.service-showcase-shell {
  position: relative;
  z-index: 1;
}

.service-showcase-index {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-bottom: 2.25rem;
  border-bottom: 1px solid #dce5e8;
}

.service-showcase-index button {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .7rem;
  align-items: center;
  min-width: 0;
  min-height: 4.5rem;
  padding: .75rem .65rem 1.05rem;
  border: 0;
  background: transparent;
  color: #71848f;
  text-align: left;
  transition: color .25s ease;
}

.service-showcase-index button::after {
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 3px;
  border-radius: 3px 3px 0 0;
  background: var(--primary);
  content: "";
  opacity: 0;
  transform: scaleX(.25);
  transition: opacity .25s ease, transform .25s ease;
}

.service-showcase-index button:hover,
.service-showcase-index button:focus-visible,
.service-showcase-index button.is-active {
  color: #0c2335;
}

.service-showcase-index button.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

.service-showcase-index span {
  color: var(--primary);
  font-size: .7rem;
  font-weight: 800;
}

.service-showcase-index b {
  overflow: hidden;
  font-size: .91rem;
  font-weight: 750;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.service-showcase-stage,
.service-showcase-swiper {
  min-width: 0;
}

.service-showcase-slide {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(22rem, .8fr);
  gap: 4.75rem;
  align-items: center;
  min-height: 35rem;
  height: auto;
  background: transparent;
}

.service-showcase-media {
  position: relative;
  display: block;
  min-height: 35rem;
  overflow: hidden;
  border-radius: 1.75rem .75rem 1.75rem .75rem;
}

.service-showcase-media::after {
  position: absolute;
  inset: 0;
  border: 1px solid rgba(255, 255, 255, .26);
  border-radius: inherit;
  content: "";
  pointer-events: none;
}

.service-showcase-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.1s cubic-bezier(.2, .7, .2, 1);
}

.service-showcase-slide.swiper-slide-active .service-showcase-media img {
  transform: scale(1.018);
}

.service-showcase-copy {
  position: relative;
  padding: 1rem 1.25rem 1rem 0;
}

.service-showcase-copy::before {
  display: block;
  width: 3rem;
  height: .25rem;
  margin-bottom: 1.75rem;
  border-radius: 1rem;
  background: var(--primary);
  content: "";
}

.service-showcase-label {
  display: block;
  margin-bottom: .9rem;
  color: var(--primary);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.service-showcase-copy h3 {
  max-width: 29rem;
  margin: 0 0 1.15rem;
  color: #0c2335;
  font-family: var(--font-display);
  font-size: 2.6rem;
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: 0;
}

.service-showcase-copy > p {
  max-width: 31rem;
  margin: 0;
  color: #536876;
  font-size: 1rem;
  line-height: 1.72;
}

.service-showcase-copy ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem 1rem;
  margin: 1.7rem 0 2rem;
  padding: 0;
  list-style: none;
}

.service-showcase-copy li {
  display: flex;
  gap: .62rem;
  align-items: center;
  color: #294553;
  font-size: .88rem;
  font-weight: 650;
}

.service-showcase-copy li:last-child {
  grid-column: 1 / -1;
}

.service-showcase-copy li svg {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
  color: var(--primary);
  stroke-width: 2.2;
}

.service-showcase-copy .btn {
  align-self: flex-start;
}

.service-showcase-controls {
  display: grid;
  grid-template-columns: auto minmax(5rem, 1fr) auto;
  gap: 1.35rem;
  align-items: center;
  width: calc(40% - 1.5rem);
  margin: 1.25rem 0 0 auto;
}

.service-showcase-position {
  display: flex;
  gap: .4rem;
  align-items: baseline;
  color: #7a8d98;
  font-size: .76rem;
  font-weight: 700;
}

.service-showcase-position strong {
  color: #0c2335;
  font-size: 1.25rem;
}

.service-showcase-progress {
  height: 2px;
  overflow: hidden;
  background: #d7e2e6;
}

.service-showcase-progress i {
  display: block;
  width: 16.666%;
  height: 100%;
  background: var(--primary);
  transition: width .45s ease;
}

.service-showcase-arrows {
  display: flex;
  gap: .5rem;
}

.service-showcase-arrows button {
  display: inline-grid;
  width: 2.8rem;
  height: 2.8rem;
  padding: 0;
  border: 1px solid #cad7dc;
  border-radius: 50%;
  background: transparent;
  color: #0c2335;
  place-items: center;
  transition: border-color .2s ease, background-color .2s ease, color .2s ease, transform .2s ease;
}

.service-showcase-arrows button:hover,
.service-showcase-arrows button:focus-visible {
  border-color: #0c2335;
  background: #0c2335;
  color: #fff;
  transform: translateY(-2px);
}

.service-showcase-arrows svg {
  width: 1.05rem;
  height: 1.05rem;
}

@media (max-width: 1199.98px) {
  .service-showcase-heading h2 { font-size: 3.15rem; }
  .service-showcase-slide { grid-template-columns: minmax(0, 1.1fr) minmax(20rem, .9fr); gap: 3rem; }
  .service-showcase-copy h3 { font-size: 2.2rem; }
  .service-showcase-index button { grid-template-columns: 1fr; gap: .2rem; }
  .service-showcase-controls { width: calc(45% - 1rem); }
}

@media (max-width: 991.98px) {
  .service-showcase-section { padding: 6.5rem 0; }
  .service-showcase-heading { grid-template-columns: 1fr; gap: 1.5rem; }
  .service-showcase-heading::before { font-size: 7rem; }
  .service-showcase-heading > p { max-width: 43rem; }
  .service-showcase-index {
    display: flex;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .service-showcase-index::-webkit-scrollbar { display: none; }
  .service-showcase-index button {
    flex: 0 0 auto;
    grid-template-columns: auto auto;
    min-height: 4rem;
    padding-right: 1.25rem;
    padding-left: 1.25rem;
  }
  .service-showcase-slide { grid-template-columns: 1fr; gap: 2.5rem; }
  .service-showcase-media { min-height: 28rem; }
  .service-showcase-copy { padding: 0 .25rem; }
  .service-showcase-controls { width: 100%; margin-top: 2rem; }
}

@media (max-width: 575.98px) {
  .service-showcase-section { padding: 5rem 0; }
  .service-showcase-heading { margin-bottom: 2.25rem; }
  .service-showcase-heading::before { font-size: 4.8rem; }
  .service-showcase-heading h2 { font-size: 2.45rem; line-height: 1.06; }
  .service-showcase-heading h2 br { display: none; }
  .service-showcase-heading > p { font-size: .98rem; }
  .service-showcase-index { margin-right: -.75rem; margin-left: -.75rem; padding: 0 .75rem; }
  .service-showcase-media { min-height: 21rem; border-radius: 1.25rem .55rem 1.25rem .55rem; }
  .service-showcase-copy h3 { font-size: 1.95rem; }
  .service-showcase-copy ul { grid-template-columns: 1fr; }
  .service-showcase-copy li:last-child { grid-column: auto; }
  .service-showcase-controls { gap: .9rem; }
  .service-showcase-arrows button { width: 2.55rem; height: 2.55rem; }
}

@media (prefers-reduced-motion: reduce) {
  .service-showcase-media img,
  .service-showcase-progress i { transition: none; }
}
