/* v5.1.40 — Mobile product page: image -> info -> add to cart; remove extra sticky buybar */

@media (max-width: 782px) {
  html body.vlg-theme.single-product {
    overflow-x: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-single-product-page {
    padding-left: 0 !important;
    padding-right: 0 !important;
    /* only room for bottom navigation, not the removed sticky buy bar */
    padding-bottom: calc(var(--vlg-mobile-appbar-h, 78px) + 56px + env(safe-area-inset-bottom)) !important;
  }

  /* Disable the extra floating Osta bar. It hides the category bottom nav and the real buybox. */
  html body.vlg-theme.single-product .vlg-mobile-product-bar,
  html body.vlg-theme.single-product .vlg-mobile-product-bar[hidden],
  html body.vlg-theme.single-product [data-vlg-mobile-buybar],
  html body.vlg-theme.single-product [data-vlg-mobile-buybar][hidden],
  html body.vlg-mobile-buybar-visible .vlg-mobile-product-bar,
  html body.vlg-mobile-buybar-visible [data-vlg-mobile-buybar] {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  html body.vlg-mobile-buybar-visible {
    padding-bottom: 0 !important;
  }

  /* Correct order: picture first, product info second, add-to-cart inside info, then tabs/additional info. */
  html body.vlg-theme.single-product .vlg-product-main-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  html body.vlg-theme.single-product .vlg-product-left {
    display: contents !important;
  }

  html body.vlg-theme.single-product .vlg-product-gallery-card {
    order: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    border-radius: 0 0 18px 18px !important;
  }

  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 {
    order: 2 !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  html body.vlg-theme.single-product .vlg-product-tabs {
    order: 3 !important;
    margin: 12px 8px 0 !important;
  }

  html body.vlg-theme.single-product .vlg-product-related-wrap {
    order: 4 !important;
    margin: 12px 8px 0 !important;
  }

  /* Info card should be compact and full-width on mobile. */
  html body.vlg-theme.single-product .vlg-product-summary-card,
  html body.vlg-theme.single-product div.product .summary {
    padding: 16px 16px calc(var(--vlg-mobile-appbar-h, 78px) + 38px + env(safe-area-inset-bottom)) !important;
    border-radius: 18px 18px 0 0 !important;
    overflow: visible !important;
    background: #fff !important;
  }

  html body.vlg-theme.single-product .product_title,
  html body.vlg-theme.single-product div.product .product_title {
    font-size: clamp(20px, 5.7vw, 28px) !important;
    line-height: 1.12 !important;
    margin: 10px 0 10px !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !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.8vw, 28px) !important;
    line-height: 1.15 !important;
  }

  /* Real add-to-cart must be visible after info, not hidden behind bottom nav. */
  html body.vlg-theme.single-product .vlg-product-buybox,
  html body.vlg-theme.single-product #vlg-product-buybox {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 16px 0 18px !important;
    padding: 12px !important;
    border-radius: 18px !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 5 !important;
    background: rgba(255, 250, 244, .96) !important;
    border: 1px solid rgba(242, 138, 0, .22) !important;
  }

  html body.vlg-theme.single-product .vlg-product-buybox form.cart,
  html body.vlg-theme.single-product div.product form.cart,
  html body.vlg-theme.single-product form.cart {
    position: relative !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: auto !important;
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  html body.vlg-theme.single-product form.cart:not(.variations_form),
  html body.vlg-theme.single-product .vlg-product-buybox 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 {
    grid-template-columns: 76px minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

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

  html body.vlg-theme.single-product form.cart input.qty,
  html body.vlg-theme.single-product form.cart .quantity .qty {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 52px !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 {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 52px !important;
    padding: 0 14px !important;
    margin: 0 !important;
    border-radius: 16px !important;
    white-space: normal !important;
    text-align: center !important;
  }

  /* Variable products: selector first, then qty + button below it. */
  html body.vlg-theme.single-product form.variations_form,
  html body.vlg-theme.single-product .vlg-product-buybox form.variations_form {
    display: block !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 td,
  html body.vlg-theme.single-product form.variations_form table.variations th {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

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

@media (max-width: 390px) {
  html body.vlg-theme.single-product form.cart:not(.variations_form),
  html body.vlg-theme.single-product .vlg-product-buybox 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 {
    grid-template-columns: 70px minmax(0, 1fr) !important;
    gap: 8px !important;
  }

  html body.vlg-theme.single-product form.cart .quantity,
  html body.vlg-theme.single-product .vlg-product-buybox form.cart .quantity {
    width: 70px !important;
    min-width: 70px !important;
    max-width: 70px !important;
  }
}
