.elementor-415 .elementor-element.elementor-element-caeddc0{--display:flex;--min-height:1018px;--justify-content:center;}.elementor-415 .elementor-element.elementor-element-caeddc0:not(.elementor-motion-effects-element-type-background), .elementor-415 .elementor-element.elementor-element-caeddc0 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}body.elementor-page-415:not(.elementor-motion-effects-element-type-background), body.elementor-page-415 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-text );}@media(min-width:768px){.elementor-415 .elementor-element.elementor-element-caeddc0{--content-width:1423px;}}/* Start custom CSS */.hf-product-hero {
  position: relative;
  width: 100%;
  padding: clamp(24px, 5vw, 80px);
  border-radius: 32px;
  overflow: hidden;
  color: #fff;
  background:
    radial-gradient(circle at top left, rgba(255, 106, 26, 0.22), transparent 34%),
    radial-gradient(circle at bottom right, rgba(255, 255, 255, 0.08), transparent 28%),
    linear-gradient(135deg, #050505 0%, #121212 45%, #030303 100%);
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
}

.hf-product-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(45deg, rgba(255,255,255,.025) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.025) 25%, transparent 25%);
  background-size: 18px 18px;
  opacity: .4;
  pointer-events: none;
}

.hf-product-hero > .e-con-inner {
  position: relative;
  z-index: 2;
}

/* Makes the main hero into a two-column layout */
.hf-product-hero.e-con,
.hf-product-hero .e-con-inner {
  display: grid !important;
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
}

/* Left image area */
.hf-product-gallery {
  min-width: 0;
  padding: clamp(18px, 3vw, 38px);
  border-radius: 30px;
  background:
    linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.13);
  box-shadow:
    0 32px 80px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.09);
  overflow: hidden;
}

.hf-product-gallery img {
  filter: drop-shadow(0 24px 28px rgba(0,0,0,.55));
  transition: transform .45s ease, opacity .25s ease;
}

.hf-product-gallery:hover img {
  transform: scale(1.025);
}

/* Gallery thumbnails */
.hf-product-gallery .flex-control-thumbs {
  display: flex;
  gap: 12px;
  margin-top: 16px !important;
  padding: 0 !important;
  overflow-x: auto;
}

.hf-product-gallery .flex-control-thumbs li {
  width: 86px !important;
  flex: 0 0 86px;
  list-style: none;
}

.hf-product-gallery .flex-control-thumbs img {
  height: 74px;
  object-fit: contain;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.13);
  background: rgba(255,255,255,.045);
  cursor: pointer;
  transition: .22s ease;
}

.hf-product-gallery .flex-control-thumbs img:hover,
.hf-product-gallery .flex-control-thumbs img.flex-active {
  border-color: #ff6a1a;
  background: rgba(255,106,26,.14);
  transform: translateY(-2px);
}

/* Right product info card */
.hf-product-info {
  padding: clamp(24px, 4vw, 46px);
  border-radius: 30px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.13);
  box-shadow: 0 30px 80px rgba(0,0,0,.36);
  backdrop-filter: blur(16px);
}

.hf-product-info::before {
  content: "HyperFab Racing";
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #ff6a1a;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 18px;
}

.hf-product-info::after {
  content: "";
  display: block;
  clear: both;
}

/* Product title */
.hf-product-title,
.hf-product-title h1,
.hf-product-title .elementor-heading-title {
  margin: 0 !important;
  color: #fff !important;
  font-size: clamp(36px, 5.2vw, 72px) !important;
  line-height: .92 !important;
  letter-spacing: -0.06em !important;
  font-weight: 850 !important;
}

/* Product price */
.hf-product-price,
.hf-product-price .price,
.hf-product-price .woocommerce-Price-amount,
.hf-product-price bdi {
  color: #fff !important;
  font-size: clamp(24px, 3vw, 36px) !important;
  font-weight: 800 !important;
}

.hf-product-price {
  margin-top: 22px;
}

.hf-product-price del {
  opacity: .45;
  margin-right: 8px;
}

.hf-product-price ins {
  text-decoration: none;
}

/* Description */
.hf-product-description {
  margin-top: 26px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.13);
}

.hf-product-description,
.hf-product-description p,
.hf-product-description div {
  color: rgba(255,255,255,.72) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.hf-product-description p:first-child {
  margin-top: 0;
}

.hf-product-description p:last-child {
  margin-bottom: 0;
}

/* Add to cart area */
.hf-cart-area {
  margin-top: 30px;
}

.hf-cart-area form.cart {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin: 0;
}

.hf-cart-area .quantity input.qty {
  width: 82px;
  min-height: 56px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 15px;
  font-weight: 800;
  text-align: center;
}

.hf-cart-area .single_add_to_cart_button,
.hf-cart-area button.button,
.hf-cart-area .button {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 34px !important;
  border-radius: 999px !important;
  border: 0 !important;
  background: linear-gradient(135deg, #ff7a1a, #d94b00) !important;
  color: #fff !important;
  text-decoration: none !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  letter-spacing: .09em;
  text-transform: uppercase;
  box-shadow: 0 18px 38px rgba(255,106,26,.32);
  overflow: hidden;
  transition: transform .22s ease, box-shadow .22s ease;
}

.hf-cart-area .single_add_to_cart_button:hover,
.hf-cart-area button.button:hover,
.hf-cart-area .button:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 48px rgba(255,106,26,.45);
}

.hf-cart-area .single_add_to_cart_button::after,
.hf-cart-area button.button::after,
.hf-cart-area .button::after {
  content: "";
  position: absolute;
  top: 0;
  left: -80%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.38), transparent);
  transform: skewX(-20deg);
  transition: left .55s ease;
}

.hf-cart-area .single_add_to_cart_button:hover::after,
.hf-cart-area button.button:hover::after,
.hf-cart-area .button:hover::after {
  left: 130%;
}

/* Floating cart */
.hf-floating-cart {
  position: fixed;
  top: 22px;
  right: 22px;
  z-index: 9999;
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(8,8,8,.88);
  color: #fff;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 18px 45px rgba(0,0,0,.38);
  backdrop-filter: blur(14px);
  transition: transform .22s ease;
}

.hf-floating-cart:hover {
  transform: translateY(-2px);
  color: #fff;
}

.hf-floating-cart span {
  font-size: 21px;
}

.hf-flying-cart {
  position: fixed;
  z-index: 10000;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  pointer-events: none;
  background: #ff6a1a;
  color: #fff;
  box-shadow: 0 18px 38px rgba(255,106,26,.45);
  transition:
    transform .72s cubic-bezier(.17,.67,.28,1.08),
    opacity .72s ease;
}

.hf-cart-pulse {
  animation: hfCartPulse .45s ease;
}

@keyframes hfCartPulse {
  0% { transform: scale(1); }
  50% { transform: scale(1.16); }
  100% { transform: scale(1); }
}

/* Mobile */
@media (max-width: 980px) {
  .hf-product-hero.e-con,
  .hf-product-hero .e-con-inner {
    grid-template-columns: 1fr;
  }

  .hf-product-info {
    order: -1;
  }
}

@media (max-width: 600px) {
  .hf-product-hero {
    padding: 18px;
    border-radius: 22px;
  }

  .hf-product-info,
  .hf-product-gallery {
    border-radius: 22px;
  }

  .hf-product-info {
    padding: 24px 20px;
  }

  .hf-product-title,
  .hf-product-title h1,
  .hf-product-title .elementor-heading-title {
    font-size: clamp(34px, 12vw, 48px) !important;
  }

  .hf-cart-area form.cart {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hf-cart-area .quantity input.qty,
  .hf-cart-area .single_add_to_cart_button,
  .hf-cart-area button.button {
    width: 100%;
  }

  .hf-floating-cart {
    width: 48px;
    height: 48px;
    top: 14px;
    right: 14px;
  }
}/* End custom CSS */