/* v5.1.37 — Mobile product view stabilization
   Goal: stop the huge blank image area, keep product visible, and keep add-to-cart usable. */

@media (max-width: 782px) {
  html body.vlg-theme.single-product,
  html body.vlg-theme.single-product #page,
  html body.vlg-theme.single-product .site,
  html body.vlg-theme.single-product .site-main {
    overflow-x: hidden !important;
    max-width: 100vw !important;
  }

  html body.vlg-theme.single-product .vlg-single-product-page {
    padding-left: 8px !important;
    padding-right: 8px !important;
    padding-bottom: calc(220px + env(safe-area-inset-bottom)) !important;
  }

  html body.vlg-theme.single-product .vlg-product-main-grid,
  html body.vlg-theme.single-product .vlg-product-left,
  html body.vlg-theme.single-product .vlg-product-right,
  html body.vlg-theme.single-product .vlg-product-summary-card,
  html body.vlg-theme.single-product div.product .summary {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product .vlg-product-main-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  html body.vlg-theme.single-product .vlg-product-gallery-card {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 6px !important;
    margin: 0 0 10px !important;
    border-radius: 18px !important;
    background: #fff !important;
    overflow: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-product-gallery-card::before,
  html body.vlg-theme.single-product .vlg-product-gallery-card::after {
    display: none !important;
  }

  html body.vlg-theme.single-product .vlg-product-gallery-media {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
  }

  /* The reliable/mobile image block: compact height. */
  html body.vlg-theme.single-product .vlg-mobile-featured-image,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image {
    width: 100% !important;
    height: clamp(150px, 41vw, 186px) !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 14px !important;
    background-color: #fff !important;
    background-repeat: no-repeat !important;
    background-position: 100% 50% !important;
    background-size: auto 245% !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image__link,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image__link {
    width: 100% !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }

  /* Normal/cropped image mode. Cropped images stay centered. */
  html body.vlg-theme.single-product .vlg-mobile-featured-image img,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image img,
  html body.vlg-theme.single-product .vlg-mobile-featured-image__img,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image__img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: auto !important;
    padding: 0 !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  /* Fallback mode for bad product images with huge white canvas: zoom the right side. */
  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-bg-product-crop,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-bg-product-crop,
  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-force-right-crop,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-force-right-crop {
    background-position: 100% 50% !important;
    background-size: auto 265% !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-bg-product-crop img,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-bg-product-crop img,
  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-force-right-crop img,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-force-right-crop img {
    opacity: 0 !important;
    visibility: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image img.vlg-autocropped-image,
  html body.vlg-theme.single-product .vlg-mobile-featured-image img.vlg-core-cropped-image,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image img.vlg-autocropped-image,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image img.vlg-core-cropped-image {
    opacity: 1 !important;
    visibility: visible !important;
    width: auto !important;
    height: auto !important;
    max-width: 98% !important;
    max-height: 98% !important;
    object-fit: contain !important;
    object-position: center center !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image:has(img.vlg-autocropped-image),
  html body.vlg-theme.single-product .vlg-mobile-featured-image:has(img.vlg-core-cropped-image),
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image:has(img.vlg-autocropped-image),
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image:has(img.vlg-core-cropped-image) {
    background-image: none !important;
  }

  html body.vlg-theme.single-product .vlg-single-image-energy {
    right: 5px !important;
    bottom: 5px !important;
    transform: scale(.48) !important;
    transform-origin: right bottom !important;
  }

  html body.vlg-theme.single-product .vlg-product-summary-card,
  html body.vlg-theme.single-product div.product .summary {
    padding: 12px !important;
    padding-bottom: calc(165px + env(safe-area-inset-bottom)) !important;
    border-radius: 18px !important;
  }

  html body.vlg-theme.single-product .vlg-pill {
    font-size: 11px !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    max-width: 100% !important;
  }

  html body.vlg-theme.single-product .product_title,
  html body.vlg-theme.single-product div.product .product_title {
    font-size: clamp(18px, 5.2vw, 24px) !important;
    line-height: 1.14 !important;
    margin: 8px 0 9px !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  html body.vlg-theme.single-product .vlg-product-price,
  html body.vlg-theme.single-product div.product p.price,
  html body.vlg-theme.single-product div.product span.price {
    font-size: clamp(20px, 5.4vw, 26px) !important;
    line-height: 1.12 !important;
  }

  html body.vlg-theme.single-product .vlg-product-specs,
  html body.vlg-theme.single-product .vlg-product-meta-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* Buybox and variable products: use flex to prevent the orange button collapsing into a thin strip. */
  html body.vlg-theme.single-product .vlg-product-buybox,
  html body.vlg-theme.single-product #vlg-product-buybox {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    margin: 14px 0 calc(170px + env(safe-area-inset-bottom)) !important;
    padding: 12px !important;
    border-radius: 18px !important;
  }

  html body.vlg-theme.single-product form.cart,
  html body.vlg-theme.single-product form.variations_form,
  html body.vlg-theme.single-product form.variations_form .single_variation_wrap,
  html body.vlg-theme.single-product form.variations_form .woocommerce-variation-add-to-cart,
  html body.vlg-theme.single-product form.variations_form .woocommerce-variation-add-to-cart.variations_button {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product form.variations_form table.variations,
  html body.vlg-theme.single-product form.variations_form table.variations tbody,
  html body.vlg-theme.single-product form.variations_form table.variations tr,
  html body.vlg-theme.single-product form.variations_form table.variations th,
  html body.vlg-theme.single-product form.variations_form table.variations td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product form.variations_form table.variations select,
  html body.vlg-theme.single-product form.variations_form table.variations .select2,
  html body.vlg-theme.single-product form.variations_form table.variations .select2-container,
  html body.vlg-theme.single-product form.cart select {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 46px !important;
  }

  html body.vlg-theme.single-product form.cart:not(.variations_form),
  html body.vlg-theme.single-product form.variations_form .woocommerce-variation-add-to-cart,
  html body.vlg-theme.single-product form.variations_form .woocommerce-variation-add-to-cart.variations_button {
    display: flex !important;
    align-items: stretch !important;
    gap: 8px !important;
  }

  html body.vlg-theme.single-product form.cart .quantity {
    flex: 0 0 72px !important;
    width: 72px !important;
    min-width: 72px !important;
    max-width: 72px !important;
    margin: 0 !important;
  }

  html body.vlg-theme.single-product form.cart input.qty {
    width: 100% !important;
    min-height: 48px !important;
  }

  html body.vlg-theme.single-product form.cart .single_add_to_cart_button,
  html body.vlg-theme.single-product .vlg-product-buybox form.cart .single_add_to_cart_button {
    flex: 1 1 auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 48px !important;
    padding: 0 12px !important;
    white-space: normal !important;
    line-height: 1.15 !important;
    font-size: 14px !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-product-bar,
  html body.vlg-theme.single-product [data-vlg-mobile-buybar] {
    display: none !important;
  }
}

@media (max-width: 390px) {
  html body.vlg-theme.single-product .vlg-mobile-featured-image,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image {
    height: clamp(140px, 40vw, 172px) !important;
    background-size: auto 280% !important;
    background-position: 100% 50% !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-bg-product-crop,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-bg-product-crop,
  html body.vlg-theme.single-product .vlg-mobile-featured-image.vlg-force-right-crop,
  html body.vlg-theme.single-product .vlg-core-mobile-featured-image.vlg-force-right-crop {
    background-size: auto 295% !important;
  }
}
