.product-showcase {
  position: relative;
  overflow: hidden;
  padding: clamp(96px, 8vw, 130px) 0 clamp(86px, 7vw, 120px);
  background:
    radial-gradient(circle at 18% 50%, rgba(212, 175, 55, 0.18), transparent 30%),
    radial-gradient(circle at 88% 44%, rgba(255, 232, 166, 0.1), transparent 24%),
    linear-gradient(135deg, #050505 0%, #111 48%, #050505 100%);
  border-top: 1px solid rgba(212, 175, 55, 0.14);
  border-bottom: 1px solid rgba(212, 175, 55, 0.14);
}

.product-showcase-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.68), transparent 48%, rgba(0, 0, 0, 0.38)),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 92px);
  pointer-events: none;
}

.product-showcase-container {
  position: relative;
  z-index: 1;
  display: grid;
  width: min(100% - 48px, 1480px);
  grid-template-columns: 58px minmax(0, 1fr) 58px;
  grid-template-areas:
    "prev carousel next"
    "dots dots dots";
  align-items: center;
  gap: clamp(12px, 2vw, 24px);
}

.product-carousel {
  grid-area: carousel;
  position: relative;
  min-height: clamp(610px, 48vw, 720px);
  padding-top: clamp(128px, 10vw, 170px);
  touch-action: pan-y;
}

.product-carousel > .locales-premium-tag {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 4;
  transform: translateX(-50%);
}

.product-carousel > h2 {
  position: absolute;
  top: 58px;
  left: 50%;
  z-index: 4;
  width: min(100%, 1120px);
  max-width: min(86vw, 1120px);
  margin: 0;
  color: #d4af37;
  font-size: clamp(3.8rem, 5.8vw, 6.2rem);
  line-height: 0.9;
  text-align: center;
  white-space: nowrap;
  transform: translateX(-50%);
}

.product-slide {
  position: absolute;
  inset: clamp(132px, 11vw, 178px) 0 54px;
  display: grid;
  grid-template-columns: minmax(330px, 0.88fr) minmax(430px, 0.92fr);
  align-items: center;
  gap: clamp(44px, 5vw, 86px);
  opacity: 0;
  pointer-events: none;
  transform: translateX(48px) scale(0.98);
  filter: blur(14px);
  transition:
    opacity 420ms ease,
    transform 520ms cubic-bezier(0.2, 0.74, 0.2, 1),
    filter 420ms ease;
}

.product-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0) scale(1);
  filter: blur(0);
}

.product-visual {
  --product-x: 0px;
  --product-y: 0px;
  --gyro-rx: 0deg;
  --gyro-ry: 0deg;
  position: relative;
  min-height: clamp(360px, 34vw, 520px);
  display: flex;
  align-items: center;
  justify-content: center;
  transform:
    perspective(1000px)
    translate3d(var(--product-x), var(--product-y), 0)
    rotateX(var(--gyro-rx))
    rotateY(var(--gyro-ry));
  transition: transform 260ms ease;
}

.product-ring {
  position: absolute;
  width: min(40vw, 510px);
  aspect-ratio: 1;
  border: 1px dashed rgba(212, 175, 55, 0.38);
  border-radius: 50%;
  animation: product-spin 24s linear infinite;
}

.product-ring::before,
.product-ring::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.product-ring::before {
  inset: 12%;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.24), rgba(0, 0, 0, 0.08) 58%, transparent 70%);
  filter: blur(18px);
}

.product-ring::after {
  inset: -12%;
  border: 1px solid rgba(255, 232, 166, 0.1);
}

.product-visual img {
  position: relative;
  z-index: 2;
  width: min(34vw, 420px);
  max-height: 450px;
  object-fit: contain;
  border-radius: 22px;
  filter:
    drop-shadow(0 34px 70px rgba(0, 0, 0, 0.72))
    drop-shadow(0 0 28px rgba(212, 175, 55, 0.18));
  animation: product-float 5.6s ease-in-out infinite;
}

.product-copy {
  text-align: left;
}

.product-kicker {
  display: flex;
  width: fit-content;
  margin: 0 auto 18px;
  color: #d4af37;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.product-copy h2 {
  max-width: 700px;
  margin: 0 auto 22px;
  color: #fff7df;
  font-size: clamp(2.7rem, 4.1vw, 4.9rem);
  line-height: 0.96;
  letter-spacing: 0;
  text-align: center;
  text-transform: none;
}

.product-copy p {
  max-width: 720px;
  margin: 0;
  color: rgba(245, 239, 226, 0.78);
  font-size: 1.05rem;
  line-height: 1.8;
}

.product-price {
  display: block;
  margin: 28px 0 22px;
  color: #d4af37;
  font-size: clamp(2.4rem, 4vw, 4rem);
  line-height: 1;
}

.product-buy-button {
  display: inline-flex;
  min-height: 56px;
  align-items: center;
  justify-content: center;
  padding: 0 38px;
  border: 1px solid #d4af37;
  background: linear-gradient(135deg, #d4af37, #f7e08a);
  color: #080808;
  font-size: 0.86rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-decoration: none;
  text-transform: uppercase;
  box-shadow: 0 20px 54px rgba(212, 175, 55, 0.18);
  transition: transform 220ms ease, box-shadow 220ms ease;
}

.product-buy-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 28px 70px rgba(212, 175, 55, 0.26);
}

.product-arrow {
  position: relative;
  z-index: 3;
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(212, 175, 55, 0.42);
  border-radius: 50%;
  background: rgba(5, 5, 5, 0.72);
  color: #f7e08a;
  cursor: pointer;
  box-shadow: 0 0 28px rgba(212, 175, 55, 0.12);
  backdrop-filter: blur(14px);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

.product-prev {
  grid-area: prev;
  justify-self: center;
}

.product-next {
  grid-area: next;
  justify-self: center;
}

.product-arrow span {
  font-size: 1.75rem;
  line-height: 1;
}

.product-arrow:hover {
  transform: translateY(-3px);
  border-color: rgba(247, 224, 138, 0.86);
  box-shadow: 0 0 36px rgba(212, 175, 55, 0.24);
}

.product-dots {
  grid-area: dots;
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
}

.product-dot {
  width: 10px;
  height: 10px;
  border: 1px solid rgba(247, 224, 138, 0.54);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: width 220ms ease, background 220ms ease, box-shadow 220ms ease;
}

.product-dot.is-active {
  width: 34px;
  background: #d4af37;
  box-shadow: 0 0 18px rgba(212, 175, 55, 0.68);
}

@keyframes product-float {
  0%,
  100% {
    transform: translateY(-12px) rotate(-2deg);
  }

  50% {
    transform: translateY(16px) rotate(2deg);
  }
}

@keyframes product-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (max-width: 920px) {
  .product-showcase {
    padding: 82px 0 120px;
  }

  .product-showcase-container {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "carousel carousel"
      "prev next"
      "dots dots";
  }

  .product-carousel {
    min-height: 790px;
    padding-top: 126px;
    cursor: grab;
  }

  .product-carousel > .locales-premium-tag {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
  }

  .product-carousel > h2 {
    left: 50%;
    width: calc(100vw - 36px);
    max-width: 640px;
    font-size: clamp(2.65rem, 10vw, 4.2rem);
    line-height: 0.94;
    text-align: center;
    white-space: normal;
    transform: translateX(-50%);
  }

  .product-slide {
    inset: 138px 0 0;
    gap: 20px;
  }

  .product-carousel:active {
    cursor: grabbing;
  }

  .product-slide {
    grid-template-columns: 1fr;
    align-content: start;
    text-align: center;
  }

  .product-visual {
    min-height: 270px;
  }

  .product-ring {
    width: min(70vw, 300px);
  }

  .product-visual img {
    width: min(64vw, 265px);
    max-height: 275px;
  }

  .product-copy {
    text-align: center;
  }

  .product-copy p,
  .product-copy h2 {
    margin-left: auto;
    margin-right: auto;
  }

  .product-prev {
    justify-self: end;
  }

  .product-next {
    justify-self: start;
  }
}

@media (max-width: 560px) {
  .product-showcase {
    padding: 76px 0 136px;
  }

  .product-carousel {
    min-height: 760px;
    padding-top: 118px;
  }

  .product-carousel > h2 {
    top: 50px;
    width: calc(100vw - 32px);
    font-size: clamp(2.25rem, 11vw, 3.35rem);
    line-height: 0.92;
  }

  .product-slide {
    inset: 126px 0 0;
  }

  .product-visual {
    min-height: 230px;
  }

  .product-visual img {
    width: min(60vw, 230px);
    max-height: 235px;
  }

  .product-arrow {
    width: 50px;
    height: 50px;
  }
}
