/* Product showcase — alternating text / image rows */

.product-showcase-block.section-feature {
  background: linear-gradient(180deg, #fff 0%, var(--bg-soft) 100%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.prod-showcase {
  display: flex;
  flex-direction: column;
  gap: clamp(80px, 9vw, 130px);
}

.prod-showcase-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}

.prod-showcase-item.reverse {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
}

.prod-showcase-item.reverse .ps-copy { order: 2; }
.prod-showcase-item.reverse .ps-visual { order: 1; }

@media (max-width: 980px) {
  .prod-showcase-item,
  .prod-showcase-item.reverse { grid-template-columns: 1fr; }
  .prod-showcase-item.reverse .ps-copy,
  .prod-showcase-item.reverse .ps-visual { order: initial; }
}

.prod-showcase-item .ps-copy {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.prod-showcase-item .ps-copy .eyebrow { align-self: flex-start; }

.prod-showcase-item h3 {
  font-family: var(--font-display);
  font-size: clamp(26px, 3vw, 36px);
  font-weight: 600;
  letter-spacing: -0.022em;
  line-height: 1.05;
  text-wrap: balance;
  margin: 0;
}

.prod-showcase-item .ps-copy p {
  color: var(--muted);
  font-size: 16px;
  line-height: 1.6;
  max-width: 50ch;
  margin: 0;
}

.prod-showcase-item .ps-bullets {
  list-style: none;
  padding: 0;
  margin: 6px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.prod-showcase-item .ps-bullets li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--ink-2);
}

.prod-showcase-item .ps-bullets li::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--brand-navy, #1e1f8c);
}

.ps-visual {
  position: relative;
}

.ps-visual-shadow {
  position: absolute;
  inset: 8% -4% -6% -4%;
  background:
    radial-gradient(closest-side at 25% 25%, rgba(30, 31, 140, 0.14), transparent 65%),
    radial-gradient(closest-side at 80% 80%, rgba(31, 174, 94, 0.12), transparent 65%);
  filter: blur(40px);
  z-index: 0;
}

.ps-visual-frame {
  position: relative;
  z-index: 1;
  margin: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  box-shadow: 0 24px 60px -24px rgba(11, 13, 26, 0.22), 0 8px 24px -12px rgba(11, 13, 26, 0.1);
  overflow: hidden;
}

.ps-visual-frame img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
}
