.framing-showcase {
  --finish-media-radius: 16px;
  width: min(100%, 1440px);
  margin: 0 auto;
  padding: 104px clamp(18px, 4vw, 56px) 72px;
  overflow-x: hidden;
}

.framing-hero {
  text-align: center;
  margin-bottom: 28px;
}

.framing-hero .banner-sub {
  margin-top: 2px;
}

.framing-hero .banner-catchphrase {
  overflow-wrap: anywhere;
}

.finish-tabs-shell {
  position: relative;
  z-index: 30;
  display: flex;
  justify-content: center;
  margin: 0 auto 28px;
  padding: 0;
  background: #fff;
}

.finish-tabs {
  display: flex;
  justify-content: stretch;
  gap: 0;
  width: min(100%, 1120px);
  padding: 0 0 7px;
  border-bottom: 1px solid rgba(17, 17, 17, 0.12);
  background: #fff;
}

.finish-tab {
  position: relative;
  flex: 1 1 0;
  min-width: 0;
  min-height: 26px;
  padding: 0 10px 6px;
  border-radius: 0;
  color: rgba(18, 18, 18, 0.48);
  font-family: "Montserrat", sans-serif !important;
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.11em;
  line-height: 1.25;
  text-align: center;
  text-transform: uppercase;
  transition: color 220ms ease;
  overflow-wrap: anywhere;
}

.finish-tab span {
  position: relative;
  z-index: 1;
}

.finish-tab::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 2px;
  background: #111;
  opacity: 0;
  transform: scaleX(0.42);
  transform-origin: center;
  transition:
    opacity 220ms ease,
    transform 220ms ease;
}

.finish-tab:hover,
.finish-tab:focus-visible {
  color: #121212;
}

.finish-tab:focus-visible {
  outline: 1px solid rgba(18, 18, 18, 0.4);
  outline-offset: 3px;
}

.finish-tab.is-active {
  color: #111;
}

.finish-tab.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

.finish-panel[hidden] {
  display: none;
}

.finish-panel {
  animation: panelFade 520ms ease both;
}

.finish-panel-intro {
  width: min(100%, 880px);
  margin: 0 auto 56px;
  text-align: center;
}

.finish-kicker {
  margin: 0 0 12px;
  color: #8a7557;
  font-family: "Montserrat", sans-serif !important;
  font-size: 0.72rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  line-height: 1.4;
  text-transform: uppercase;
}

.finish-panel-intro .finish-kicker {
  margin: 0 0 20px;
  color: #111;
  font-size: clamp(0.92rem, 1.15vw, 1.12rem);
  font-weight: 700;
  letter-spacing: 0.12em;
}

.finish-panel-intro h2,
.finish-copy h3 {
  margin: 0;
  color: #111;
  font-family: "WestwingROM", serif;
  font-weight: 300;
  letter-spacing: 0;
}

.finish-panel-intro h2 {
  margin-bottom: 20px;
  font-size: clamp(1.9rem, 4vw, 3.8rem);
  line-height: 1.04;
}

.finish-panel-intro p:not(.finish-kicker) {
  max-width: 760px;
  margin: 0 auto;
  color: #3f3b36;
  font-size: clamp(1.04rem, 1.2vw, 1.28rem);
  line-height: 1.8;
  overflow-wrap: anywhere;
}

.finish-row {
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) minmax(320px, 1fr);
  gap: clamp(32px, 6vw, 92px);
  align-items: center;
  margin-bottom: clamp(56px, 8vw, 104px);
}

.finish-row.is-reverse {
  grid-template-columns: minmax(320px, 1fr) minmax(280px, 0.92fr);
}

.finish-row.is-reverse .finish-media {
  order: 2;
}

.finish-row.is-reverse .finish-copy {
  order: 1;
}

.finish-copy {
  max-width: 610px;
}

.finish-copy .finish-kicker {
  font-weight: 700;
}

.finish-copy h3 {
  margin-bottom: 22px;
  font-size: clamp(1.92rem, 3.1vw, 3.5rem);
  line-height: 1.04;
}

.finish-copy p:not(.finish-kicker) {
  margin: 0 0 18px;
  color: #35312d;
  font-size: clamp(1.03rem, 1.1vw, 1.18rem);
  line-height: 1.82;
  overflow-wrap: anywhere;
}

.finish-copy p:last-child {
  margin-bottom: 0;
}

.finish-media {
  position: relative;
  display: block;
  margin: 0;
  overflow: hidden;
  border-radius: var(--finish-media-radius);
  background: transparent;
  box-shadow: none;
}

.finish-media::before {
  display: none;
}

.finish-media img {
  position: static;
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  border-radius: var(--finish-media-radius);
  overflow: hidden;
  clip-path: inset(0 round var(--finish-media-radius));
  background: transparent;
  transform: none;
  transition: filter 850ms ease;
}

.finish-media-stack {
  display: grid;
  align-items: center;
  gap: 28px;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.finish-media-stack::before {
  display: none;
}

.finish-media-stack img {
  position: static;
  height: auto;
  border-radius: var(--finish-media-radius);
  object-fit: contain;
  overflow: hidden;
  clip-path: inset(0 round var(--finish-media-radius));
  box-shadow: none;
}

.finish-row-with-stack {
  align-items: center;
}

.finish-row-with-stack .finish-copy {
  align-self: center;
  max-width: 680px;
}

.finish-row-with-stack .finish-media-stack {
  align-self: center;
  height: clamp(520px, 42vw, 640px);
}

.finish-media-stack-equal {
  grid-template-rows: repeat(2, minmax(0, 1fr));
}

.finish-row-with-stack .finish-media-stack-fineart {
  grid-template-rows: repeat(2, minmax(0, 1fr));
  height: clamp(780px, 20vw, 300px);
}

@media (max-width: 1030px) {
  .finish-row-with-stack .finish-media-stack-fineart {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: none;
    height: auto;
  }
}

.finish-row-fineart .finish-media-stack-fineart {
  align-self: center;
}

.finish-media-stack-equal img,
.finish-media-stack-fineart img {
  width: auto;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  min-height: 0;
  align-self: center;
  justify-self: center;
}

.finish-media-stack-fineart img:first-child {
  object-position: center top;
}

.finish-media-stack-fineart img:last-child {
  object-position: center center;
}

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 760ms ease,
    transform 760ms ease;
}

.reveal-on-scroll .finish-media,
.reveal-on-scroll.finish-media {
  filter: saturate(0.82);
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-on-scroll.is-visible .finish-media,
.reveal-on-scroll.is-visible.finish-media {
  filter: saturate(1);
}

@keyframes panelFade {
  from {
    opacity: 0;
    transform: translateY(14px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .finish-panel,
  .finish-tab,
  .finish-tab::after,
  .finish-media img,
  .reveal-on-scroll {
    animation: none;
    transition: none;
  }

  .reveal-on-scroll {
    opacity: 1;
    transform: none;
  }
}

@media (max-width: 1030px) {
  .finish-tabs-shell {
    justify-content: flex-start;
    margin-bottom: 18px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .finish-tabs-shell::-webkit-scrollbar {
    display: none;
  }

  .finish-tabs {
    display: flex;
    width: 100%;
    min-width: 100%;
    gap: 0;
  }

  .finish-tab {
    flex: 1 1 0;
    max-width: none;
    white-space: normal;
  }

  .finish-row,
  .finish-row.is-reverse {
    grid-template-columns: 1fr;
    gap: 28px;
    margin-bottom: 20px;
  }

  .finish-row.is-reverse .finish-media,
  .finish-row.is-reverse .finish-copy {
    order: initial;
  }

  .finish-copy {
    max-width: none;
  }
}

@media (max-width: 800px) {
  .framing-showcase {
    padding: 92px 18px 46px;
  }

  .framing-hero {
    margin-bottom: 30px;
  }

  .finish-tabs-shell {
    top: auto;
    margin-left: -18px;
    margin-right: -18px;
    padding: 4px 18px;
    max-width: 100vw;
  }

  .finish-tabs {
    min-width: 100%;
  }

  .finish-panel-intro {
    width: 100%;
    max-width: calc(100vw - 36px);
    margin-bottom: 34px;
    text-align: left;
  }

  .finish-panel-intro.reveal-on-scroll {
    opacity: 1;
    transform: none;
  }

  .finish-panel-intro h2 {
    display: block;
    visibility: visible;
    opacity: 1;
  }

  .finish-panel-intro p:not(.finish-kicker) {
    width: 100%;
    max-width: calc(100vw - 36px);
    margin-left: 0;
  }

  .finish-row,
  .finish-row.is-reverse,
  .finish-copy,
  .finish-media {
    width: 100%;
    max-width: calc(100vw - 36px);
  }

  .finish-copy h3 {
    margin-bottom: 16px;
  }

  .finish-media-stack {
    grid-template-columns: 1fr;
    height: auto;
  }

  .finish-media-stack-equal,
  .finish-media-stack-fineart {
    grid-template-rows: none;
    height: auto;
  }

  .finish-media-stack-equal img,
  .finish-media-stack-fineart img {
    height: auto;
  }
}

@media (max-width: 520px) {
  .finish-tab {
    min-height: 30px;
    padding: 5px 8px;
    font-size: 0.6rem;
  }
}
