/* Search Parts BMW - V0.22.3 - Hero premium accueil VIN/modele */
.spb-ce-wrapper .spb-premium-hero,
.spb-premium-hero {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
  margin: 0 0 34px !important;
  padding: clamp(34px, 5vw, 76px) clamp(20px, 5.5vw, 84px) !important;
  min-height: 560px !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 88% 86%, rgba(204, 0, 0, .70), rgba(204,0,0,0) 33%),
    radial-gradient(circle at 80% 20%, rgba(255, 122, 0, .16), rgba(255,122,0,0) 28%),
    linear-gradient(112deg, #020202 0%, #050505 44%, #150000 72%, #3d0000 100%) !important;
  color: #fff !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.08) !important;
}

.spb-premium-hero:before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -3 !important;
  background:
    linear-gradient(90deg, rgba(0,0,0,.05), rgba(0,0,0,.88) 36%, rgba(0,0,0,.36) 100%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 84px) !important;
  opacity: .76 !important;
}

.spb-premium-hero:after {
  content: "" !important;
  position: absolute !important;
  inset: auto -10% -40% 35% !important;
  height: 58% !important;
  z-index: -2 !important;
  background: radial-gradient(ellipse at center, rgba(170,0,0,.62), transparent 62%) !important;
  filter: blur(18px) !important;
}

.spb-premium-hero__glow {
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  pointer-events: none !important;
  background: linear-gradient(180deg, rgba(255,255,255,.045), transparent 32%) !important;
}

/* Silhouette moto abstraite en CSS pour ne pas dependre d'une image externe */
.spb-premium-hero__moto {
  position: absolute !important;
  left: -58px !important;
  bottom: -10px !important;
  width: min(36vw, 500px) !important;
  height: min(32vw, 420px) !important;
  z-index: -1 !important;
  opacity: .34 !important;
  filter: drop-shadow(0 0 28px rgba(255,255,255,.12)) !important;
}

.spb-premium-hero__wheel {
  position: absolute !important;
  bottom: 12% !important;
  width: 32% !important;
  aspect-ratio: 1 !important;
  border-radius: 50% !important;
  border: 10px solid rgba(255,255,255,.20) !important;
  box-shadow: inset 0 0 0 10px rgba(0,0,0,.72), 0 0 36px rgba(255,255,255,.08) !important;
}
.spb-premium-hero__wheel--front { right: 5% !important; }
.spb-premium-hero__wheel--rear { left: 4% !important; }
.spb-premium-hero__frame {
  position: absolute !important;
  left: 24% !important;
  bottom: 35% !important;
  width: 46% !important;
  height: 28% !important;
  border-left: 9px solid rgba(255,255,255,.18) !important;
  border-bottom: 9px solid rgba(255,255,255,.18) !important;
  transform: skewX(-24deg) rotate(-7deg) !important;
}
.spb-premium-hero__handlebar {
  position: absolute !important;
  right: 8% !important;
  top: 34% !important;
  width: 20% !important;
  height: 7px !important;
  background: rgba(255,255,255,.20) !important;
  transform: rotate(-24deg) !important;
  border-radius: 999px !important;
}

.spb-premium-hero__content {
  position: relative !important;
  z-index: 2 !important;
  display: grid !important;
  grid-template-columns: minmax(280px, .95fr) minmax(520px, 1.45fr) !important;
  gap: clamp(28px, 5vw, 76px) !important;
  align-items: center !important;
}

.spb-premium-hero__kicker {
  display: inline-block !important;
  margin: 0 0 26px !important;
  color: #ff9900 !important;
  font-size: 15px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .075em !important;
}
.spb-premium-hero__kicker:after {
  content: "" !important;
  display: block !important;
  width: 44px !important;
  height: 4px !important;
  margin-top: 18px !important;
  border-radius: 20px !important;
  background: linear-gradient(90deg, #ff9c00, #ff5b00) !important;
}

.spb-premium-hero__intro h1 {
  margin: 0 0 26px !important;
  color: #fff !important;
  font-size: clamp(42px, 5.2vw, 72px) !important;
  line-height: .98 !important;
  letter-spacing: -.048em !important;
  font-weight: 950 !important;
  text-shadow: 0 12px 32px rgba(0,0,0,.55) !important;
}
.spb-premium-hero__intro p {
  max-width: 560px !important;
  margin: 0 !important;
  color: rgba(255,255,255,.86) !important;
  font-size: clamp(17px, 1.35vw, 21px) !important;
  line-height: 1.58 !important;
  font-weight: 500 !important;
}

.spb-premium-hero__benefits {
  margin-top: 36px !important;
  max-width: 560px !important;
}
.spb-premium-hero__benefit {
  display: flex !important;
  align-items: center !important;
  gap: 22px !important;
  padding: 21px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.14) !important;
}
.spb-premium-hero__benefit-icon {
  flex: 0 0 auto !important;
  display: grid !important;
  place-items: center !important;
  width: 50px !important;
  height: 50px !important;
  border-radius: 14px !important;
  color: #ff9100 !important;
  border: 1px solid rgba(255,145,0,.62) !important;
  background: rgba(255,145,0,.05) !important;
}
.spb-premium-hero__benefit strong {
  display: block !important;
  margin: 0 0 4px !important;
  color: #fff !important;
  font-size: 20px !important;
  font-weight: 850 !important;
}
.spb-premium-hero__benefit small {
  display: block !important;
  color: rgba(255,255,255,.58) !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.spb-premium-hero__cards {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2vw, 30px) !important;
  align-items: stretch !important;
}
.spb-premium-card {
  position: relative !important;
  min-height: 430px !important;
  display: flex !important;
  flex-direction: column !important;
  padding: clamp(26px, 2.4vw, 38px) !important;
  border: 1px solid rgba(255,145,0,.86) !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.025)), rgba(10,10,10,.74) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09), 0 22px 48px rgba(0,0,0,.42) !important;
  backdrop-filter: blur(8px) !important;
}
.spb-premium-card:before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  pointer-events: none !important;
  background: radial-gradient(circle at 16% 0, rgba(255,145,0,.12), transparent 32%) !important;
}
.spb-premium-card__head {
  position: relative !important;
  display: flex !important;
  gap: 18px !important;
  align-items: flex-start !important;
  margin-bottom: 26px !important;
}
.spb-premium-card__step {
  flex: 0 0 auto !important;
  display: grid !important;
  place-items: center !important;
  width: 64px !important;
  height: 64px !important;
  border-radius: 14px !important;
  border: 1px solid #ff7a00 !important;
  color: #ff7a00 !important;
  font-size: 34px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  background: rgba(255,122,0,.06) !important;
}
.spb-premium-card h2 {
  margin: 4px 0 0 !important;
  color: #fff !important;
  font-size: clamp(23px, 1.8vw, 30px) !important;
  line-height: 1.28 !important;
  font-weight: 950 !important;
  letter-spacing: -.02em !important;
}
.spb-premium-card p {
  position: relative !important;
  margin: 0 0 18px !important;
  color: rgba(255,255,255,.76) !important;
  font-size: 17px !important;
  line-height: 1.55 !important;
}
.spb-premium-card__label {
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  position: absolute !important;
  clip: rect(1px,1px,1px,1px) !important;
}
.spb-premium-card__input {
  position: relative !important;
  width: 100% !important;
  height: 64px !important;
  margin: 0 0 24px !important;
  padding: 0 24px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(255,255,255,.30) !important;
  background: rgba(0,0,0,.36) !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  outline: none !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04) !important;
}
.spb-premium-card__input::placeholder { color: rgba(255,255,255,.38) !important; font-weight: 500 !important; }
.spb-premium-card__input:focus {
  border-color: #ff7a00 !important;
  box-shadow: 0 0 0 4px rgba(255,122,0,.16), inset 0 1px 0 rgba(255,255,255,.04) !important;
}
.spb-premium-card__button {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 66px !important;
  padding: 0 24px !important;
  border-radius: 10px !important;
  border: 1px solid #ff7a00 !important;
  background: linear-gradient(180deg, #ff8e00 0%, #ff6500 38%, #bd3b00 100%) !important;
  color: #fff !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  font-size: 18px !important;
  font-weight: 950 !important;
  letter-spacing: .02em !important;
  cursor: pointer !important;
  box-shadow: 0 16px 28px rgba(255,90,0,.18), inset 0 1px 0 rgba(255,255,255,.24) !important;
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease !important;
}
.spb-premium-card__button:hover {
  color: #fff !important;
  text-decoration: none !important;
  filter: brightness(1.08) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 20px 36px rgba(255,90,0,.24), inset 0 1px 0 rgba(255,255,255,.24) !important;
}
.spb-premium-card__button--outline {
  margin-top: auto !important;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.01)), rgba(0,0,0,.36) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
}
.spb-premium-card__note {
  position: relative !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 13px !important;
  margin-top: 28px !important;
  color: rgba(255,255,255,.72) !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
}
.spb-premium-card__note span {
  flex: 0 0 auto !important;
  display: grid !important;
  place-items: center !important;
  width: 25px !important;
  height: 25px !important;
  border-radius: 50% !important;
  border: 1px solid #ff8a00 !important;
  color: #ff8a00 !important;
  font-weight: 900 !important;
  font-style: italic !important;
}
.spb-premium-card__bike {
  display: grid !important;
  place-items: center !important;
  width: 158px !important;
  height: 158px !important;
  margin: 22px auto 32px !important;
  border-radius: 50% !important;
  border: 1px dashed rgba(255,255,255,.22) !important;
  color: #ff8700 !important;
  background: radial-gradient(circle, rgba(255,135,0,.10), rgba(255,135,0,0) 60%) !important;
}
.spb-premium-card.is-loading .spb-premium-card__button,
.spb-premium-card.is-loading button {
  opacity: .82 !important;
  cursor: wait !important;
}

@media (max-width: 1180px) {
  .spb-premium-hero__content {
    grid-template-columns: 1fr !important;
  }
  .spb-premium-hero__moto {
    opacity: .20 !important;
    width: 58vw !important;
    height: 46vw !important;
  }
}

@media (max-width: 780px) {
  .spb-ce-wrapper .spb-premium-hero,
  .spb-premium-hero {
    min-height: auto !important;
    padding: 36px 18px !important;
    border-radius: 18px !important;
  }
  .spb-premium-hero__cards {
    grid-template-columns: 1fr !important;
  }
  .spb-premium-card {
    min-height: auto !important;
    border-radius: 18px !important;
  }
  .spb-premium-hero__benefit {
    gap: 14px !important;
  }
  .spb-premium-card__step {
    width: 54px !important;
    height: 54px !important;
    font-size: 28px !important;
  }
  .spb-premium-card__bike {
    width: 126px !important;
    height: 126px !important;
    margin: 10px auto 24px !important;
  }
}
