/* Product detail reference pass: Alpitronic-inspired, scoped to detail pages only. */

.pv-detail-hero-alpi {
  min-height: min(920px, 92vh);
  display: flex;
  align-items: center;
  background:
    radial-gradient(circle at 74% 45%, rgba(139, 92, 246, 0.22), transparent 32%),
    radial-gradient(circle at 82% 76%, rgba(255, 255, 255, 0.08), transparent 22%),
    linear-gradient(135deg, #06070a 0%, #0a0b10 58%, #050506 100%) !important;
}

.pv-detail-hero-alpi-inner {
  min-height: clamp(560px, 72vh, 760px);
}

.pv-detail-sidebrand {
  position: absolute;
  right: clamp(16px, 3vw, 48px);
  top: 50%;
  transform: translateY(-50%) rotate(180deg);
  writing-mode: vertical-rl;
  font-family: var(--font-display);
  font-size: clamp(86px, 11vw, 190px);
  font-weight: 800;
  letter-spacing: -0.08em;
  line-height: 0.82;
  color: rgba(255, 255, 255, 0.035);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.pv-detail-hero-alpi-copy,
.pv-detail-hero-alpi-media {
  z-index: 2;
}

.pv-detail-hero-alpi-media {
  height: clamp(380px, 55vh, 660px) !important;
}

.pv-detail-hero-alpi-media img {
  max-width: min(112%, 760px) !important;
  max-height: 100% !important;
  transform: translate3d(calc(var(--detail-pointer-x, 0) * 12px), calc(var(--detail-pointer-y, 0) * 10px), 0) scale(1.05) !important;
  filter: drop-shadow(0 54px 120px rgba(0,0,0,.78)) drop-shadow(0 0 42px rgba(139, 92, 246, .12)) !important;
}

.pv-detail-h1,
.pv-detail-h1 em,
.pv-detail-h1 .it {
  color: #fff !important;
  font-style: normal !important;
}

.pv-detail-hero-alpi .pv-detail-kicker[style] {
  color: rgba(255, 255, 255, 0.58) !important;
}

.pv-detail-metrics-strip {
  background: #050506 !important;
  padding: clamp(34px, 4.5vh, 58px) 0 !important;
}

.pv-detail-metric {
  padding: 0 clamp(14px, 2vw, 28px) 0 0 !important;
  border-right: 1px solid rgba(255,255,255,.08);
}

.pv-detail-metric:last-child {
  border-right: 0;
}

.pv-detail-metric-value {
  font-size: clamp(34px, 4.2vw, 64px) !important;
}

.pv-detail-feature-band {
  min-height: auto !important;
  padding: 0 !important;
  background: #06070a !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
}

.pv-detail-feature-alt {
  background: #0a0b0f !important;
}

.pv-detail-feature-inner {
  display: grid !important;
  grid-template-columns: minmax(90px, 0.22fr) minmax(0, 1fr) !important;
  gap: clamp(26px, 5vw, 82px) !important;
  align-items: start !important;
  padding: clamp(62px, 9vh, 112px) 0 !important;
}

.pv-detail-feature-copy {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(76px, 0.2fr) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 72px);
  transform: translate3d(0, calc(var(--detail-scroll, 0) * 12px), 0) !important;
}

.pv-detail-feature-label {
  margin: 0 !important;
  font-size: clamp(28px, 4vw, 60px) !important;
  line-height: 0.9;
  color: rgba(255,255,255,.14) !important;
  letter-spacing: -0.05em !important;
}

.pv-detail-feature-title {
  max-width: 900px;
  font-size: clamp(34px, 4.6vw, 76px) !important;
  margin: 0 0 20px !important;
}

.pv-detail-feature-desc {
  display: block !important;
  max-width: 760px !important;
  color: rgba(255,255,255,.70) !important;
  font-size: clamp(16px, 1.3vw, 21px) !important;
}

.pv-detail-blueprint-band {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 72% 34%, rgba(139, 92, 246, .16), transparent 30%),
    linear-gradient(180deg, #090a0e 0%, #050506 100%);
  color: #fff;
  padding: clamp(74px, 10vh, 132px) 0;
  border-bottom: 1px solid rgba(255,255,255,.07);
}

.pv-detail-blueprint-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 92px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.025) 0 1px, transparent 1px 92px);
  opacity: .45;
  transform: translate3d(calc(var(--detail-scroll, 0) * -22px), calc(var(--detail-scroll, 0) * 10px), 0);
  pointer-events: none;
}

.pv-detail-blueprint-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(420px, 1fr);
  gap: clamp(36px, 6vw, 96px);
  align-items: center;
}

.pv-detail-blueprint-copy p {
  color: rgba(255,255,255,.68);
  max-width: 58ch;
  font-size: clamp(16px, 1.25vw, 20px);
  line-height: 1.65;
}

.pv-detail-blueprint-copy .pv-detail-h2 {
  color: #fff !important;
  font-size: clamp(34px, 4.6vw, 76px);
}

.pv-detail-blueprint-diagram {
  position: relative;
  min-height: clamp(300px, 42vh, 520px);
  border: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.018)),
    radial-gradient(circle at 48% 50%, rgba(139,92,246,.22), transparent 42%);
  box-shadow: 0 40px 120px rgba(0,0,0,.32);
  padding: clamp(28px, 4vw, 54px);
}

.pv-detail-blueprint-rail {
  position: absolute;
  left: clamp(30px, 6vw, 74px);
  right: clamp(30px, 6vw, 74px);
  top: 42%;
  height: 2px;
  background: linear-gradient(90deg, rgba(139,92,246,.2), rgba(196,181,253,.8), rgba(139,92,246,.2));
}

.pv-detail-blueprint-rail::after {
  content: "";
  position: absolute;
  inset: -1px 0;
  width: 26%;
  background: linear-gradient(90deg, transparent, #fff, transparent);
  opacity: .8;
  animation: pvBlueprintFlow 3.2s linear infinite;
}

.pv-detail-blueprint-node {
  position: absolute;
  left: calc(var(--i) * 33.333%);
  top: 0;
  transform: translate(-50%, -50%);
  width: clamp(84px, 9vw, 120px);
  aspect-ratio: 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  text-align: center;
  background: rgba(7,8,12,.86);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 22px 60px rgba(0,0,0,.36), inset 0 0 0 1px rgba(255,255,255,.04);
}

.pv-detail-blueprint-node span {
  position: absolute;
  top: 16px;
  font: 500 10px/1 var(--font-mono);
  color: rgba(255,255,255,.42);
}

.pv-detail-blueprint-node b {
  font-size: clamp(12px, 1vw, 15px);
  color: #fff;
}

.pv-detail-blueprint-meta {
  position: absolute;
  left: clamp(28px, 4vw, 54px);
  right: clamp(28px, 4vw, 54px);
  bottom: clamp(26px, 3vw, 40px);
  font: 500 12px/1.5 var(--font-mono);
  color: rgba(255,255,255,.55);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pv-detail-blueprint-metrics {
  position: absolute;
  left: clamp(28px, 4vw, 54px);
  top: clamp(24px, 3vw, 38px);
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.pv-detail-blueprint-metrics div {
  min-width: 112px;
}

.pv-detail-blueprint-metrics strong {
  display: block;
  color: #fff;
  font-size: clamp(22px, 2.5vw, 38px);
  line-height: 1;
  letter-spacing: -0.04em;
}

.pv-detail-blueprint-metrics span {
  display: block;
  margin-top: 6px;
  color: rgba(255,255,255,.48);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.pv-detail-config-band,
.pv-detail-specs-band,
.pv-detail-other-band {
  padding: clamp(70px, 9vh, 118px) 0 !important;
}

.pv-detail-config-list,
.pv-detail-other-grid {
  gap: 0 !important;
  background: transparent !important;
  border: 0 !important;
}

.pv-detail-config-item,
.pv-detail-other-card {
  border-width: 1px 0 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

html:not([data-theme="dark"]) .pv-detail-config-item,
body:not([data-theme="dark"]) .pv-detail-config-item,
html:not([data-theme="dark"]) .pv-detail-other-card,
body:not([data-theme="dark"]) .pv-detail-other-card {
  background: transparent !important;
  box-shadow: none !important;
}

html:not([data-theme="dark"]) .pv-detail-feature-band,
body:not([data-theme="dark"]) .pv-detail-feature-band,
html:not([data-theme="dark"]) .pv-detail-feature-alt,
body:not([data-theme="dark"]) .pv-detail-feature-alt,
html:not([data-theme="dark"]) .pv-detail-blueprint-band,
body:not([data-theme="dark"]) .pv-detail-blueprint-band {
  color: #fff !important;
}

@keyframes pvBlueprintFlow {
  from { transform: translateX(-35%); }
  to { transform: translateX(420%); }
}

@media (max-width: 900px) {
  .pv-detail-hero-alpi {
    min-height: auto;
    padding-top: 112px !important;
  }

  .pv-detail-hero-alpi-inner,
  .pv-detail-blueprint-inner {
    grid-template-columns: 1fr;
  }

  .pv-detail-sidebrand {
    display: none;
  }

  .pv-detail-feature-copy {
    grid-template-columns: 1fr;
  }

  .pv-detail-blueprint-diagram {
    min-height: 380px;
  }

  .pv-detail-blueprint-node {
    width: 78px;
  }
}
