/* v5.1.31 — mobile single product rebuild: reliable image, fit, buybox and lightbox */

.vlg-mobile-featured-image,
.vlg-mobile-image-modal {
  display: none;
}

@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 main {
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-single-product-page {
    width: 100% !important;
    max-width: 100vw !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
    padding-bottom: calc(120px + env(safe-area-inset-bottom)) !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product .vlg-breadcrumbs {
    display: none !important;
  }

  html body.vlg-theme.single-product .vlg-product-detail,
  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;
    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;
  }

  /* Use a reliable mobile image instead of the desktop/Flexslider gallery, which causes blank oversized areas on phones. */
  html body.vlg-theme.single-product .vlg-product-gallery-card {
    width: 100% !important;
    padding: 8px !important;
    margin: 0 0 10px !important;
    min-height: 0 !important;
    height: auto !important;
    border-radius: 22px !important;
    background: #fff !important;
    box-shadow: 0 10px 28px rgba(15, 23, 42, .06) !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 {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    min-height: 0 !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    aspect-ratio: 1 / .86 !important;
    min-height: 220px !important;
    max-height: 355px !important;
    padding: 8px !important;
    border-radius: 18px !important;
    background: linear-gradient(180deg, #ffffff 0%, #f7f8fa 100%) !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image__link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    text-decoration: none !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-featured-image__img,
  html body.vlg-theme.single-product .vlg-mobile-featured-image img {
    display: block !important;
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    margin: 0 auto !important;
    padding: 0 !important;
    background: transparent !important;
  }

  html body.vlg-theme.single-product .vlg-product-gallery-card .woocommerce-product-gallery,
  html body.vlg-theme.single-product .vlg-product-gallery-card div.images,
  html body.vlg-theme.single-product .vlg-product-gallery-card .flex-viewport,
  html body.vlg-theme.single-product .vlg-product-gallery-card .flex-control-thumbs {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-single-image-energy {
    right: 10px !important;
    bottom: 10px !important;
    top: auto !important;
    left: auto !important;
    transform: scale(.66) !important;
    transform-origin: right bottom !important;
    z-index: 8 !important;
  }

  html body.vlg-theme.single-product .vlg-product-summary-card,
  html body.vlg-theme.single-product div.product .summary {
    padding: 14px !important;
    margin: 0 !important;
    border-radius: 22px !important;
    overflow: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-pill {
    display: inline-flex !important;
    max-width: 100% !important;
    padding: 8px 12px !important;
    font-size: 12px !important;
    line-height: 1.15 !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }

  html body.vlg-theme.single-product .product_title,
  html body.vlg-theme.single-product div.product .product_title {
    width: 100% !important;
    max-width: 100% !important;
    margin: 10px 0 10px !important;
    font-size: clamp(18px, 5.5vw, 27px) !important;
    line-height: 1.15 !important;
    letter-spacing: -.025em !important;
    white-space: normal !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    hyphens: auto !important;
  }

  html body.vlg-theme.single-product .vlg-product-rating-row {
    margin: 0 0 10px !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(18px, 5vw, 25px) !important;
    line-height: 1.15 !important;
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }

  html body.vlg-theme.single-product .vlg-product-excerpt:empty,
  html body.vlg-theme.single-product .woocommerce-product-details__short-description:empty {
    display: none !important;
  }

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

  html body.vlg-theme.single-product .vlg-product-specs > div {
    min-width: 0 !important;
    padding: 12px !important;
    overflow: hidden !important;
  }

  html body.vlg-theme.single-product .vlg-product-specs strong {
    display: block !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  /* Buybox / variable products: never allow add-to-cart to run outside the screen. */
  html body.vlg-theme.single-product #vlg-product-buybox,
  html body.vlg-theme.single-product .vlg-product-buybox {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 0 !important;
    margin: 14px 0 0 !important;
    padding: 12px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product #vlg-product-buybox *,
  html body.vlg-theme.single-product .vlg-product-buybox * {
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  html body.vlg-theme.single-product form.cart,
  html body.vlg-theme.single-product div.product form.cart,
  html body.vlg-theme.single-product .vlg-product-buybox form.cart {
    position: relative !important;
    inset: auto !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) {
    display: grid !important;
    grid-template-columns: 74px minmax(0, 1fr) !important;
    gap: 8px !important;
    align-items: stretch !important;
  }

  html body.vlg-theme.single-product form.variations_form {
    display: grid !important;
    gap: 10px !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;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    text-align: left !important;
  }

  html body.vlg-theme.single-product form.variations_form table.variations tr {
    margin-bottom: 10px !important;
  }

  html body.vlg-theme.single-product form.variations_form table.variations label,
  html body.vlg-theme.single-product form.variations_form table.variations .label {
    display: block !important;
    margin-bottom: 6px !important;
    font-weight: 800 !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;
    min-height: 46px !important;
    max-width: 100% !important;
  }

  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 {
    display: grid !important;
    grid-template-columns: 74px minmax(0, 1fr) !important;
    gap: 8px !important;
    align-items: stretch !important;
    width: 100% !important;
    max-width: 100% !important;
  }

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

  html body.vlg-theme.single-product form.cart .quantity .qty,
  html body.vlg-theme.single-product form.cart input.qty {
    width: 100% !important;
    min-height: 48px !important;
    max-width: 100% !important;
    margin: 0 !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: 48px !important;
    margin: 0 !important;
    padding: 0 12px !important;
    line-height: 1.15 !important;
    font-size: 14px !important;
    white-space: normal !important;
    text-align: center !important;
  }

  html body.vlg-theme.single-product .vlg-mobile-product-bar {
    display: none !important;
  }

  /* Mobile image lightbox. */
  .vlg-mobile-image-modal.is-open {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 18px !important;
    background: rgba(15, 23, 42, .76) !important;
  }

  .vlg-mobile-image-modal__dialog {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: min(96vw, 520px) !important;
    max-height: calc(100dvh - 40px) !important;
    padding: 14px !important;
    border-radius: 22px !important;
    background: #fff !important;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .35) !important;
  }

  .vlg-mobile-image-modal__img {
    display: block !important;
    max-width: 100% !important;
    max-height: calc(100dvh - 90px) !important;
    object-fit: contain !important;
  }

  .vlg-mobile-image-modal__close {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    width: 42px !important;
    height: 42px !important;
    border: 1px solid rgba(15, 23, 42, .12) !important;
    border-radius: 14px !important;
    background: #fff !important;
    color: #0f172a !important;
    font-size: 26px !important;
    line-height: 1 !important;
  }

  /* Energy modal smaller and safe on phone. */
  .valgusallikad-energiasildid-modal,
  .fs-euel-modal {
    padding: 8px !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .valgusallikad-energiasildid-modal-dialog,
  .fs-euel-modal-dialog {
    width: min(94vw, 360px) !important;
    max-width: 94vw !important;
    max-height: calc(100dvh - 16px) !important;
    padding: 12px !important;
    border-radius: 20px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .valgusallikad-energiasildid-modal-image,
  .fs-euel-modal-image {
    width: auto !important;
    max-width: 100% !important;
    max-height: calc(100dvh - 210px) !important;
    object-fit: contain !important;
  }
}

@media (max-width: 390px) {
  html body.vlg-theme.single-product .vlg-mobile-featured-image {
    min-height: 210px !important;
    aspect-ratio: 1 / .82 !important;
  }

  html body.vlg-theme.single-product .product_title,
  html body.vlg-theme.single-product div.product .product_title {
    font-size: clamp(17px, 5.4vw, 23px) !important;
  }

  html body.vlg-theme.single-product form.cart:not(.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 {
    grid-template-columns: 70px minmax(0, 1fr) !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;
  }
}
