/**
 * Layout1 bold — home shell + pure BEM hero (l1-home / l1-hero).
 * Loads after layout1-page.css. Build: 20260522-layout1-home-v3
 *
 * Markup must NOT use hero / saf_hero / storefront-bold__hero / sf-hero classes
 * (see layout/home/index.php) so storefront-modern-bem.css cannot strip the overlay.
 */

/* ========== Home shell — under fixed header ========== */
body.storefront-bold.theme-layout1:has(.l1-header) .layout-page__main > .l1-home:first-child {
  margin-top: -130px;
}

@media (min-width: 768px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .layout-page__main > .l1-home:first-child {
    margin-top: -140px;
  }
}

@media (min-width: 992px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .layout-page__main > .l1-home:first-child {
    margin-top: -150px;
  }
}

@media (max-width: 991.98px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .layout-page__main > .l1-home:first-child {
    margin-top: 0 !important;
  }
}

@supports selector(:has(*)) {
  .layout-page:has(.layout-page__main > .l1-home:first-child .l1-hero) .layout-page__main {
    padding-top: 0;
  }

  .layout-page:has(.layout-page__main > .l1-home:first-child .l1-hero)
    .layout-page__main
    > .l1-home:first-child {
    margin-top: 0;
  }
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home {
  position: relative;
  width: 100%;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero {
  margin-top: 0;
  margin-bottom: 0;
}

/* ========== CMS intro row ========== */
body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere:not(.storefront-bold__prose--centered) > p:first-child,
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--cms.l1-page-content #contentpagehere:not(.storefront-bold__prose--centered) > p:first-child {
  display: grid !important;
  grid-template-columns: minmax(7.5rem, 11rem) minmax(0, 1fr) !important;
  gap: 0.85rem 1.15rem !important;
  align-items: center !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 0 var(--l1-page-gap, 1.25rem) !important;
  padding: 0 0 0.75rem !important;
  text-align: left !important;
  border-bottom: 3px solid var(--sf-theme-accent, #eab308) !important;
  float: none !important;
  clear: both !important;
  box-sizing: border-box !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere:not(.storefront-bold__prose--centered) > p:first-child:not(:has(img)),
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--cms.l1-page-content #contentpagehere:not(.storefront-bold__prose--centered) > p:first-child:not(:has(img)) {
  grid-template-columns: minmax(0, 1fr) !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:first-child img,
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--cms.l1-page-content #contentpagehere > p:first-child img {
  grid-column: 1 !important;
  grid-row: 1 !important;
  float: none !important;
  display: block !important;
  width: 100% !important;
  max-width: 11rem !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: var(--l1-card-radius, 12px) !important;
  box-shadow: var(--l1-card-shadow, 0 8px 24px rgba(15, 23, 42, 0.08)) !important;
  object-fit: cover !important;
  aspect-ratio: 4 / 3;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:first-child > :not(img),
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--cms.l1-page-content #contentpagehere > p:first-child > :not(img) {
  grid-column: 2 !important;
  align-self: center !important;
  text-align: left !important;
  float: none !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:first-child span,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:first-child strong,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:first-child .storefront-bold__prose-heading {
  text-align: left !important;
  border-bottom: 0 !important;
  margin: 0 !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere > p:not(:first-child) {
  text-align: left !important;
  margin: 0 0 1rem !important;
}

@media (max-width: 767.98px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-page-content #contentpagehere:not(.storefront-bold__prose--centered) > p:first-child:has(img) {
    grid-template-columns: minmax(6.5rem, 8.5rem) minmax(0, 1fr) !important;
  }
}

/* ========== l1-hero — pure BEM (no legacy hero / saf_hero hooks) ========== */
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 0 0 clamp(14px, 3vw, 24px) clamp(14px, 3vw, 24px);
  box-shadow: 0 28px 64px rgba(15, 23, 42, 0.14);
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slider {
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  margin: 0;
  padding: 0;
  float: none !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero .swiper-wrapper,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero .swiper-slide,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero .l1-hero__slide-wrap {
  width: 100%;
  height: auto !important;
  min-height: 0 !important;
  margin: 0;
  padding: 0;
  float: none !important;
  box-sizing: border-box;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slide {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  min-height: var(--l1-hero-min-h, clamp(280px, 38vw, 520px)) !important;
  margin: 0;
  padding: 0;
  float: none !important;
  box-sizing: border-box;
  background-image: var(--hero-bg-image, none);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  overflow: hidden;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slide:has(.l1-hero__img) {
  background-image: none !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center center;
  margin: 0;
  padding: 0;
  border: 0;
}

/* Dark opacity gradient + light blur — defaults; Manage Theme overrides via --l1-hero-shade-* */
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__shade {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  display: block !important;
  background: linear-gradient(
    90deg,
    rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), var(--l1-hero-shade-peak, 0.88)) 0%,
    rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak, 0.88) * 0.705)) 38%,
    rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak, 0.88) * 0.318)) 62%,
    rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak, 0.88) * 0.091)) 100%
  ) !important;
  backdrop-filter: blur(var(--l1-hero-shade-blur, 1px));
  -webkit-backdrop-filter: blur(var(--l1-hero-shade-blur, 1px));
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__inner {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: flex-end;
  width: 100%;
  max-width: var(--l1-page-max, 75rem);
  min-height: inherit;
  margin: 0 auto;
  padding: clamp(1.25rem, 3.5vw, 2rem) var(--l1-page-pad-x, 1rem)
    clamp(3.5rem, 10vw, 4.75rem);
  box-sizing: border-box;
  float: none !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  width: 100%;
  max-width: min(100%, 36rem);
  margin: 0;
  gap: 0.65rem;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__copy {
  width: 100%;
  min-width: 0;
  margin: 0;
  padding: 0;
  text-align: left;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__title {
  margin: 0 0 0.5rem;
  color: var(--hero-title-color, #fff);
  font-size: clamp(1.35rem, 1rem + 2.2vw, 2.65rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 18px rgba(0, 0, 0, 0.45) !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__desc {
  margin: 0 0 0.75rem;
  color: var(--hero-desc-color, rgba(255, 255, 255, 0.94));
  font-size: clamp(0.9rem, 0.8rem + 0.45vw, 1.1rem);
  line-height: 1.5;
  max-width: 34rem;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.4) !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
  padding: 0.55rem 1.35rem;
  margin: 0;
  border-radius: 999px;
  font-weight: 700;
  text-decoration: none;
  color: var(--hero-btn-color, #0f172a);
  background-color: var(--hero-btn-bg, var(--sf-theme-accent, #eab308));
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.2);
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__controls {
  position: absolute;
  left: 0;
  right: 0;
  bottom: clamp(0.65rem, 2.5vw, 1rem);
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin: 0;
  padding: 0 var(--l1-page-pad-x, 1rem);
  pointer-events: none;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__prev,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__next,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__pagination {
  pointer-events: auto;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__prev,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__next {
  width: 2.5rem;
  height: 2.5rem;
  margin: 0;
  border-radius: 50%;
  background: rgba(15, 23, 42, 0.45);
  color: #fff;
  transition: background 0.2s ease;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__prev:hover,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__next:hover {
  background: rgba(15, 23, 42, 0.72);
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero--single-slide .l1-hero__prev,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero--single-slide .l1-hero__next,
body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero--single-slide .l1-hero__pagination {
  display: none !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .l1-home #home-hero-swiper .swiper-notification {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  border: 0 !important;
  white-space: nowrap !important;
}

@media (max-width: 991.98px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slide,
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero .swiper-slide {
    min-height: var(--l1-hero-min-h-mobile, clamp(300px, 78vw, 500px)) !important;
    height: auto !important;
    padding-bottom: 0 !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slider {
    min-height: var(--l1-hero-min-h-mobile, clamp(300px, 78vw, 500px)) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__img {
    object-position: 72% center;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__shade {
    background: linear-gradient(
      180deg,
      rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak-mobile, 0.92) * 0.13)) 0%,
      rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak-mobile, 0.92) * 0.522)) 42%,
      rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), calc(var(--l1-hero-shade-peak-mobile, 0.92) * 0.913)) 74%,
      rgba(var(--l1-hero-shade-r, 15), var(--l1-hero-shade-g, 23), var(--l1-hero-shade-b, 42), min(1, calc(var(--l1-hero-shade-peak-mobile, 0.92) * 1.022))) 100%
    ) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__inner {
    padding-bottom: clamp(4rem, 13vw, 5.25rem);
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__grid {
    max-width: min(100%, 22rem);
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__title {
    color: var(--hero-title-color, #fff) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__desc {
    color: var(--hero-desc-color, rgba(255, 255, 255, 0.95)) !important;
  }
}

@media (max-width: 575.98px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slide,
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero .swiper-slide {
    min-height: var(--l1-hero-min-h-phone, clamp(320px, 100vw, 540px)) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__slider {
    min-height: var(--l1-hero-min-h-phone, clamp(320px, 100vw, 540px)) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__img {
    object-position: 78% 28%;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__title {
    font-size: clamp(1.15rem, 5.8vw, 1.55rem);
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__desc {
    font-size: clamp(0.85rem, 3.4vw, 0.98rem);
  }
}

@media (min-width: 992px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__grid {
    max-width: min(50%, 36rem);
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__title {
    color: var(--hero-title-color, #1e293b) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .l1-home .l1-hero__desc {
    color: var(--hero-desc-color, #38bdf8) !important;
  }
}

/* ========== Legacy markup bridge (until index.php v3 is on server) ========== */
/* Old wrapper: mega-commerce--home storefront-bold__home + hero/saf_hero classes */
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .storefront-bold__hero,
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--home.storefront-bold__home .hero.saf_hero_wrapper,
body.storefront-bold.theme-layout1:has(.l1-header) .mega-commerce--home.storefront-bold__home .l1-hero {
  position: relative !important;
  width: 100% !important;
  overflow: hidden !important;
  margin-bottom: 0 !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__slide.saf_hero_slide,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__slide {
  position: relative !important;
  min-height: var(--l1-hero-min-h-mobile, clamp(300px, 78vw, 500px)) !important;
  background-image: none !important;
  padding-bottom: 0 !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__slide.saf_hero_slide::after,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .saf_hero_slide::after {
  display: none !important;
  content: none !important;
}

/* Inject overlay when old markup has no l1-hero__shade element */
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__slide.saf_hero_slide:not(:has(.l1-hero__shade))::before,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__slide:not(:has(.l1-hero__shade))::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  pointer-events: none !important;
  background: linear-gradient(
    90deg,
    rgba(15, 23, 42, 0.88) 0%,
    rgba(15, 23, 42, 0.62) 38%,
    rgba(15, 23, 42, 0.28) 62%,
    rgba(15, 23, 42, 0.08) 100%
  ) !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__shade {
  z-index: 2 !important;
  display: block !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .saf_hero_title,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__title,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__title {
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.55) !important;
}

body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .saf_hero_desc,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__desc,
body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__desc {
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.45) !important;
}

@media (max-width: 991.98px) {
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__slide.saf_hero_slide:not(:has(.l1-hero__shade))::before,
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__slide:not(:has(.l1-hero__shade))::before {
    background: linear-gradient(
      180deg,
      rgba(15, 23, 42, 0.12) 0%,
      rgba(15, 23, 42, 0.48) 42%,
      rgba(15, 23, 42, 0.84) 74%,
      rgba(15, 23, 42, 0.94) 100%
    ) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .saf_hero_title,
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__title,
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__title {
    color: var(--hero-title-color, #fff) !important;
  }

  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .saf_hero_desc,
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .hero__desc,
  body.storefront-bold.theme-layout1:has(.l1-header) .storefront-bold__home .l1-hero__desc {
    color: var(--hero-desc-color, rgba(255, 255, 255, 0.95)) !important;
  }
}
