/**
 * Header logo — loaded after WooCommerce so .woocommerce-page img rules do not blow up the logo.
 */
.cpb-site-header .cpb-header-logo-col {
  flex: 0 0 auto;
  max-width: min(280px, 42vw);
  overflow: hidden;
}

.cpb-site-header .cpb-header-logo-link {
  display: block;
  line-height: 0;
  max-width: min(280px, 42vw);
}

.cpb-site-header .cpb-header-logo-img,
body.woocommerce-page .cpb-site-header img.cpb-header-logo-img,
body.single-product .cpb-site-header img.cpb-header-logo-img,
body.woocommerce .cpb-site-header img.cpb-header-logo-img {
  display: block !important;
  width: auto !important;
  max-width: min(280px, 42vw) !important;
  max-height: 52px !important;
  height: auto !important;
  object-fit: contain !important;
  object-position: left center;
}

@media (min-width: 768px) {
  .cpb-site-header .cpb-header-logo-img,
  body.woocommerce-page .cpb-site-header img.cpb-header-logo-img,
  body.single-product .cpb-site-header img.cpb-header-logo-img,
  body.woocommerce .cpb-site-header img.cpb-header-logo-img {
    max-height: 60px !important;
  }
}

.cpb-site-header .cpb-header-main-row {
  align-items: center;
  min-width: 0;
}

.cpb-site-header .cpb-header-search-col {
  min-width: 0;
}
