/*
 Theme Name:   Divi Child Theme – Blue Level Shop
 Author:       Blue Level
 Description:  Clean & stable WooCommerce Shop Styling (Divi-native)
 Version:      1.1

 Hinweis:
 - Variablen + Typografie liegen in base.css
 - shop.css enthält nur Shop-/Woo-/Layout-spezifische Regeln
*/

/* =========================================================
   0) SCOPE / RESET HELPERS
   ========================================================= */

.bl-layout-shop * { box-sizing: border-box; }

/* =========================================================
   1) SHOP – CONTAINER (DIVI-KONFORM)
   ========================================================= */

/* Divi Container nicht zerstören */
.bl-layout-shop.woocommerce-page .container { max-width: 100%; }

/* Sidebar-Trenner entfernen (Divi Bug) */
.et_right_sidebar #main-content .container:before,
.et_left_sidebar  #main-content .container:before { display: none; }

/* SHOP: full width container */
.bl-layout-shop #page-container,
.bl-layout-shop #et-main-area,
.bl-layout-shop #main-content,
.bl-layout-shop .container {
  max-width: none;
  width: 100%;
}

/* Divi rows are often capped – allow full width */
.bl-layout-shop .et_pb_row,
.bl-layout-shop .et_pb_row_inner {
  max-width: none;
  width: 100%;
}

/* =========================================================
   2) UNIFIED PADDING (HEADER + BODY)
   - Mobile soll nicht am Rand kleben
   ========================================================= */

.bl-layout-shop #et-main-area { padding-left: 0; padding-right: 0; }

/* einheitlicher Seiten-Padding-Wrapper für Header + Content */
.bl-layout-shop #main-header .container,
.bl-layout-shop #main-content .container {
  padding-left: 24px;
  padding-right: 24px;
}

@media (max-width: 980px) {
  .bl-layout-shop #main-header .container,
  .bl-layout-shop #main-content .container {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* =========================================================
   3) GLOBAL SHOP BODY: 3-COLUMN LAYOUT
   - Row hat class: bl-shop-layout
   - Columns haben class: bl-zone-left / bl-zone-main / bl-zone-right
   ========================================================= */



  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column{
    margin: 0 !important;
    float: none !important;
    width: auto !important;
    max-width: none !important;
  }

  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-left  { grid-column: 1; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-main  { grid-column: 2; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-right { grid-column: 3; }
}

@media (max-width: 980px) {
  .bl-layout-shop .et_pb_row.bl-shop-layout{
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 16px;
    align-items: start;
  }

  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column{
    margin: 0 !important;
    float: none !important;
    width: auto !important;
    max-width: none !important;
  }

  /* Mobile order: Left (menu) first, then Main, then Right */
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-left  { order: 1; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-main  { order: 2; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-right { order: 3; }
}

/* =========================================================
   4) CATEGORY TREE – BASIC STYLES
   (Shortcode: [bl_wc_category_tree ...])
   ========================================================= */

.bl-layout-shop .bl-wc-cat-tree,
.bl-layout-shop .bl-wc-cat-tree ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.bl-layout-shop .bl-wc-cat-tree a{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 0;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

.bl-layout-shop .bl-wc-cat-tree a:hover{
  text-decoration: underline;
}

/* =========================================================
   5) MOBILE CATEGORY DROPDOWN (details/summary)
   - Nur falls du es als <details class="bl-mobile-cat"> nutzt
   ========================================================= */

.bl-layout-shop details.bl-mobile-cat > summary { list-style: none; }
.bl-layout-shop details.bl-mobile-cat > summary::-webkit-details-marker { display: none; }

@media (min-width: 981px) {
  /* Desktop: Panel immer sichtbar, Toggle verstecken */
  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle { display: none !important; }
  .bl-layout-shop details.bl-mobile-cat > .bl-mobile-cat-panel{
    display: block !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    max-height: none !important;
    overflow: visible !important;
  }
}

@media (max-width: 980px) {
  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 10px;
    background: #fff;
    font-weight: 700;
    cursor: pointer;
  }

  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle::after{
    content: "▾";
    font-size: 16px;
    line-height: 1;
    opacity: 0.85;
    transform: rotate(0deg);
    transition: transform 0.15s ease;
  }

  .bl-layout-shop details.bl-mobile-cat[open] > summary.bl-mobile-cat-toggle::after{
    transform: rotate(180deg);
  }

  .bl-layout-shop details.bl-mobile-cat > .bl-mobile-cat-panel{
    margin-top: 10px;
    padding: 10px 12px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 10px;
    background: #fff;
    max-height: 60vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* =========================================================
   6) PRODUCT PAGE – HERO GRID (Main Content)
   Markup (dein Divi Code Modul):
   .bl-product-title + .bl-product-hero
   ========================================================= */

.bl-layout-shop .bl-product-title{
  margin: 35px 0 0 0;
  line-height: 1.15;
font-size: 30px;
}

.bl-layout-shop .bl-product-hero{
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 22px;
  align-items: start;
}

/* Bild */
.bl-layout-shop .bl-product-hero-image img{
  width: 100%;
  height: auto;
  display: block;
}

/* rechte Spalte */
.bl-layout-shop .bl-product-hero-meta{
  min-width: 0;
}

/* Mobile stacking */
@media (max-width: 980px){
  .bl-layout-shop .bl-product-hero{
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

/* Preis kompakter */
.bl-layout-shop .bl-price{
  margin: 0 0 8px 0;
}
.bl-layout-shop .bl-price-row{
  display: block;
  margin: 0;
  line-height: 1.25;
}
.bl-layout-shop .bl-price-value{
  font-weight: 700;
}
.bl-layout-shop .bl-price-note{
  font-size: 12px;
  opacity: 0.8;
  margin-left: 6px;
}

/* USPs kleiner + enger */
.bl-layout-shop .bl-usps{ margin-top: 10px; }
.bl-layout-shop .bl-usps .bl-bullets{
  margin: 8px 0 0 18px;
  padding: 0;
}
.bl-layout-shop .bl-usps .bl-bullets li{
  margin: 0 0 6px 0;
  line-height: 1.35;
  font-size: 16px;
}

/* Availability */
.bl-layout-shop .bl-availability{
  margin-top: 10px;
  font-size: 13px;
  opacity: 0.9;
}

/* =========================================================
   7) CTA ROW – BUTTONS IDENTISCH, KEIN PFEIL, KEINE VERSCHIEBUNG
   - Woo Add-to-cart kommt als: <form class="cart"> ... <button class="single_add_to_cart_button">
   - Angebot als: <a class="button bl-offer-btn">
   ========================================================= */

.bl-layout-shop .bl-product-cta{
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Woo form in die gleiche Zeile zwingen */
.bl-layout-shop .bl-product-cta form.cart{
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  gap: 0px;
}

/* Quantity kompakt */
.bl-layout-shop .bl-product-cta .quantity{
  margin: 0 !important;
}
.bl-layout-shop .bl-product-cta .quantity input.qty{
  height: 38px;
  min-height: 38px;
  width: 64px;
}

/* ===== Button Base (beide gleich) ===== */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta a.bl-offer-btn,
.bl-layout-shop .bl-product-cta a.button.bl-offer-btn{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 38px !important;
  line-height: 38px !important;
  padding: 0 14px !important;
  border-radius: 6px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  margin: 0 !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
  white-space: nowrap;
}

/* ===== Blue Level Blau (falls ihr Variable habt, kannst du später ersetzen) ===== */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta a.bl-offer-btn{
  background: #1e73be !important;
  color: #fff !important;
}

/* Hover */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button:hover,
.bl-layout-shop .bl-product-cta a.bl-offer-btn:hover{
  filter: brightness(0.95);
}

/* ===== DIVI PFEIL / ICON-KRAM KILLEN ===== */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button:after,
.bl-layout-shop .bl-product-cta a.bl-offer-btn:after,
.bl-layout-shop .bl-product-cta a.button.bl-offer-btn:after,
.bl-layout-shop .bl-product-cta .single_add_to_cart_button:before,
.bl-layout-shop .bl-product-cta a.bl-offer-btn:before,
.bl-layout-shop .bl-product-cta a.button.bl-offer-btn:before{
  content: none !important;
  display: none !important;
}

/* Divi setzt teils letter-spacing / padding auf .et_pb_button / .button */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta a.bl-offer-btn{
  letter-spacing: 0 !important;
}

/* =========================================================
   8) RIGHT COLUMN – SIDEBAR IMAGES (optional)
   ========================================================= */

.bl-layout-shop .bl-zone-right img{
  max-width: 100%;
  height: auto;
  display: block;
}

/* =========================================================
   9) SMALL CLEANUPS
   ========================================================= */

/* Woo notices / messages nicht zu breit */
.bl-layout-shop .woocommerce-message,
.bl-layout-shop .woocommerce-info,
.bl-layout-shop .woocommerce-error{
  margin-left: 0;
  margin-right: 0;
}

/* In Main nichts "ausfransen" lassen */
.bl-layout-shop .bl-zone-main { min-width: 0; }

/* =========================================================
   SHOP MAIN: Page vs Product Content – Sichtbarkeit
   ========================================================= */

/* Default: Produktblock aus, Page Content an */
.bl-layout-shop .bl-main-productcontent { display: none; }
.bl-layout-shop .bl-main-pagecontent { display: block; }

/* Auf Produktseiten: Page Content aus, Produktblock an */
.bl-layout-shop.single-product .bl-main-pagecontent { display: none; }
.bl-layout-shop.single-product .bl-main-productcontent { display: block; }


/* =========================================================
   CATEGORY TREE – Styling (restore)
   ========================================================= */

.bl-layout-shop .bl-wc-cat-tree,
.bl-layout-shop .bl-wc-cat-tree ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.bl-layout-shop .bl-wc-cat-tree li { margin: 0; padding: 0; }

.bl-layout-shop .bl-wc-cat-tree a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 0;
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.10);
}

.bl-layout-shop .bl-wc-cat-tree a:hover {
  text-decoration: underline;
}

.bl-layout-shop .bl-wc-cat-tree .is-active > a,
.bl-layout-shop .bl-wc-cat-tree a[aria-current="page"] {
  font-weight: 700;
}

/* =========================================================
   PATCH (append last): FIX category tree design + content visibility
   ========================================================= */

/* -----------------------------------------
   A) CONTENT VISIBILITY (Page vs Product)
   ----------------------------------------- */

/* Sicherheitsreset: beide erstmal sichtbar (falls Divi/Module was verstecken) */
.bl-layout-shop .bl-shop-page-content,
.bl-layout-shop .bl-shop-product-content{
  display: block !important;
}

/* Statische Seiten: nur Page-Block */
body.page.bl-layout-shop .bl-shop-product-content{
  display: none !important;
}

/* Produktseiten: nur Produkt-Block */
body.single-product.bl-layout-shop .bl-shop-page-content{
  display: none !important;
}

/* -----------------------------------------
   B) CATEGORY TREE – Design wieder erzwingen
   Voraussetzung: dein Shortcode/Output nutzt diese Klassen:
   .bl-cat-tree-wrap, .bl-cat-tree, .bl-cat-tree-item, .bl-cat-row, .bl-cat-link, .bl-cat-toggle
   ----------------------------------------- */

.bl-layout-shop .bl-cat-tree-wrap{
  font-size: 16px !important;
  line-height: 1.35 !important;
}

/* reset lists */
.bl-layout-shop .bl-cat-tree{
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* item reset */
.bl-layout-shop .bl-cat-tree-item{
  margin: 0 !important;
  padding: 0 !important;
}

/* one row per item: link left, toggle right */
.bl-layout-shop .bl-cat-row{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 5px 0 !important;
}

/* link */
.bl-layout-shop .bl-cat-link{
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: block !important;
  text-decoration: none !important;
  color: inherit !important;
}

.bl-layout-shop .bl-cat-link:hover{
  text-decoration: underline !important;
}

/* current item */
.bl-layout-shop .bl-cat-tree-item.is-current > .bl-cat-row .bl-cat-link{
  font-weight: 700 !important;
  text-decoration: underline !important;
}

/* toggle + spacer */
.bl-layout-shop .bl-cat-toggle,
.bl-layout-shop .bl-cat-toggle-spacer{
  flex: 0 0 26px !important;
  width: 26px !important;
  height: 26px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.bl-layout-shop .bl-cat-toggle-spacer{
  visibility: hidden !important;
}

/* toggle button hard reset */
.bl-layout-shop .bl-cat-toggle{
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;
  background: none !important;
  background-image: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  position: relative !important;
  opacity: 0.75 !important;
}

/* kill any other pseudo icon sources */
.bl-layout-shop .bl-cat-toggle::after{
  content: none !important;
  display: none !important;
}

/* the ONE icon we want */
.bl-layout-shop .bl-cat-toggle::before{
  content: ">" !important;
  font-size: 18px !important;
  line-height: 1 !important;
  display: inline-block !important;
  transform: rotate(0deg);
  transition: transform 0.15s ease, opacity 0.15s ease;
}

/* open -> down */
.bl-layout-shop .bl-cat-tree-item.is-open > .bl-cat-row .bl-cat-toggle::before{
  transform: rotate(90deg);
}

.bl-layout-shop .bl-cat-toggle:hover{
  opacity: 1 !important;
}

/* child lists: indent + guide line */
.bl-layout-shop .bl-cat-tree-level-2,
.bl-layout-shop .bl-cat-tree-level-3{
  margin: 5px 0 0 0 !important;
  padding-left: 14px !important;
  border-left: 1px solid rgba(0,0,0,0.10) !important;
}

/* hide children unless open */
.bl-layout-shop .bl-cat-tree-item:not(.is-open) > .bl-cat-tree{
  display: none !important;
}

/* top level dividers full width */
.bl-layout-shop .bl-cat-tree-level-1 > .bl-cat-tree-item > .bl-cat-row{
  border-bottom: 1px solid #006a9b !important;
}

/* Show the toggle ONLY for items that have children */
.bl-layout-shop .bl-cat-tree-item:not(.has-children) > .bl-cat-row .bl-cat-toggle{
  display: none !important;
}

/* Keep alignment calm: show spacer only when no children */
.bl-layout-shop .bl-cat-tree-item.has-children > .bl-cat-row .bl-cat-toggle-spacer{
  display: none !important;
}
.bl-layout-shop .bl-cat-tree-item:not(.has-children) > .bl-cat-row .bl-cat-toggle-spacer{
  display: inline-flex !important;
}

/* -----------------------------------------
   C) MOBILE CATEGORY DROPDOWN (details/summary)
   -> nur falls du das mobile extra Divi Code Modul nutzt
   ----------------------------------------- */

/* Remove default marker */
.bl-layout-shop details.bl-mobile-cat > summary{
  list-style: none !important;
}
.bl-layout-shop details.bl-mobile-cat > summary::-webkit-details-marker{
  display: none !important;
}

/* DESKTOP: Panel immer sichtbar, Summary aus */
@media (min-width: 981px){
  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle{
    display: none !important;
  }
  .bl-layout-shop details.bl-mobile-cat > .bl-mobile-cat-panel{
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    max-height: none !important;
    overflow: visible !important;
  }
}

/* MOBILE: Panel scrollbar statt "rauslaufen" */
@media (max-width: 980px){
  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle{
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    padding: 12px 14px !important;
    border: 1px solid var(--bl-border) !important;
    border-radius: var(--bl-radius) !important;
    background: #fff !important;
    font-weight: 700 !important;
    cursor: pointer !important;
  }

  .bl-layout-shop details.bl-mobile-cat > summary.bl-mobile-cat-toggle::after{
    content: "▾" !important;
    font-size: 16px !important;
    line-height: 1 !important;
    opacity: .85 !important;
    transition: transform .15s ease !important;
  }

  .bl-layout-shop details.bl-mobile-cat[open] > summary.bl-mobile-cat-toggle::after{
    transform: rotate(180deg);
  }

  .bl-layout-shop details.bl-mobile-cat > .bl-mobile-cat-panel{
    display: none !important;
    margin-top: 8px !important;
    padding: 8px 10px !important;
    border: 1px solid var(--bl-border) !important;
    border-radius: var(--bl-radius) !important;
    background: #fff !important;
    max-height: 60vh !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  .bl-layout-shop details.bl-mobile-cat[open] > .bl-mobile-cat-panel{
    display: block !important;
  }
}

/* =========================================================
   GLOBAL PADDING – Header & Body (Shop-Kontext)
   ========================================================= */

/* Desktop */
@media (min-width: 981px) {

  /* Header */
  body.bl-layout-shop .et-l--header,
  body.bl-layout-shop header {
    padding-left: 20px;
    padding-right: 20px;
  }

  /* Main content wrapper */
  body.bl-layout-shop .et-l--body,
  body.bl-layout-shop main,
  body.bl-layout-shop .et_pb_section {
    padding-left: 20px;
    padding-right: 20px;
  }
}

/* Tablet */
@media (max-width: 980px) and (min-width: 601px) {

  body.bl-layout-shop .et-l--header,
  body.bl-layout-shop header {
    padding-left: 18px;
    padding-right: 18px;
  }

  body.bl-layout-shop .et-l--body,
  body.bl-layout-shop main,
  body.bl-layout-shop .et_pb_section {
    padding-left: 18px;
    padding-right: 18px;
  }
}

/* Mobile */
@media (max-width: 600px) {

  body.bl-layout-shop .et-l--header,
  body.bl-layout-shop header {
    padding-left: 16px;
    padding-right: 16px;
  }

  body.bl-layout-shop .et-l--body,
  body.bl-layout-shop main,
  body.bl-layout-shop .et_pb_section {
    padding-left: 16px;
    padding-right: 16px;
  }
}

#shop-logo{
    max-width: 50px!important;
padding-top:10px;
  }

/* Optional: auch “Zurücksetzen” Link ausblenden */
.bl-layout-shop .bl-product-hero .variations_form .reset_variations {
  display: none !important;
}

/* =========================================================
   PRODUCT: Variable products – prevent duplicate dynamic price
   We keep the price at the top (.bl-product-price)
   and hide Woo's variation price block inside the form.
   ========================================================= */

/* Woo Variation-Ausgabe im Formular ausblenden (Preis/Verfügbarkeit/Description) */
.bl-layout-shop .bl-product-cta form.variations_form .single_variation,
.bl-layout-shop .bl-product-cta form.variations_form .woocommerce-variation {
  display: none !important;
}

/* Reset-Link optional ausblenden */
.bl-layout-shop .bl-product-cta form.variations_form .reset_variations{
  display:none !important;
}

/* Sicherheitsnetz: falls Woo den Preis als .price irgendwo im Variationsblock rendert */
.bl-layout-shop .bl-product-variants .single_variation .price {
  display: none !important;
}

/* Etwas Luft: Dropdown + Button sauber */
.bl-layout-shop .bl-product-variants .variations {
  margin-bottom: 10px;
}

/* CTA container */
.bl-layout-shop .bl-product-cta,
.bl-layout-shop .bl-cta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Woo add-to-cart form in a row */
.bl-layout-shop .bl-product-cta form.cart {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 !important;
}

/* Quantity looks aligned */
.bl-layout-shop .bl-product-cta form.cart .quantity {
  margin: 0 !important;
}

/* Both buttons same baseline */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta .bl-offer-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  padding: 0 14px !important;
  line-height: 38px !important;
  border-radius: 6px;
}

/* kill Divi arrow pseudo element inside buttons */
.bl-layout-shop .bl-product-cta a.et_pb_button:after,
.bl-layout-shop .bl-product-cta .button:after {
  display: none !important;
  content: none !important;
}

.bl-layout-shop .bl-product-cta{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.bl-layout-shop .bl-product-cta form.cart{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0 !important;
}

.bl-layout-shop .bl-product-cta form.cart .quantity{
  margin:0 !important;
}

.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta .bl-offer-btn,
.bl-layout-shop .bl-product-cta a.button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:38px;
  line-height:38px !important;
  padding:0 14px !important;
  border-radius:6px;
  margin:0 !important;
}

/* Divi Hover-Arrow sicher killen */
.bl-layout-shop .bl-product-cta a:after,
.bl-layout-shop .bl-product-cta button:after{
  content:none !important;
  display:none !important;
}

/* =========================================================
   PRODUCT HERO: Ordnung für Variation + CTA
   ========================================================= */

/* Der rechte Meta-Block bekommt klare vertikale Struktur */
.bl-layout-shop .bl-product-hero-meta{
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* Variation-Block: Label + Dropdown in einer Linie */
.bl-layout-shop .bl-product-variants{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  flex-wrap:wrap;
  margin:0 !important;
}

.bl-layout-shop .bl-product-variants label{
  font-weight:700;
  margin:0 !important;
  min-width:110px; /* damit "Ausführung" schön stabil ist */
}

/* Dropdown optisch passend */
.bl-layout-shop .bl-product-variants select{
  height:38px;
  padding:0 10px;
  border-radius:6px;
  max-width:320px;
}

/* CTA-Block: alles in eine gemeinsame Reihe */
.bl-layout-shop .bl-product-cta,
.bl-layout-shop .bl-product-cta .bl-cta{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin:0 !important;
}

/* Woo cart form (bei simple & variable) immer als Inline-Flex */
.bl-layout-shop .bl-product-cta form.cart{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  margin:0 !important;
  padding:0 !important;
}

/* Quantity: kein Eigenleben */
.bl-layout-shop .bl-product-cta form.cart .quantity{
  margin:0 !important;
}

/* Buttons: gleiche Höhe + gleiche Baseline */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta .bl-offer-btn,
.bl-layout-shop .bl-product-cta a.button,
.bl-layout-shop .bl-product-cta button.button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:38px !important;
  line-height:38px !important;
  padding:0 14px !important;
  border-radius:6px !important;
  margin:0 !important;
}

/* Angebotsbutton NICHT als Block mit riesigem Innenabstand */
.bl-layout-shop .bl-product-cta .bl-offer-btn{
  white-space:nowrap;
}

/* Divi Pfeil / After-Elemente wirklich weg */
.bl-layout-shop .bl-product-cta a:after,
.bl-layout-shop .bl-product-cta button:after{
  content:none !important;
  display:none !important;
}

/* Optional: Preis + Varianten + CTA links bündig */
.bl-layout-shop .bl-product-price,
.bl-layout-shop .bl-product-variants,
.bl-layout-shop .bl-product-cta{
  text-align:left;
}

/* =========================================================
   PRODUCT CTA: Add-to-cart + Offer Button in one row
   ========================================================= */

/* CTA wrapper */
.bl-layout-shop .bl-product-cta{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  margin:0 !important;
}

/* Woo add-to-cart form behaves like inline row */
.bl-layout-shop .bl-product-cta form.cart{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  margin:0 !important;
  padding:0 !important;
}

/* quantity spacing */
.bl-layout-shop .bl-product-cta form.cart .quantity{
  margin:0 !important;
}

/* --- Unified button style (Cart + Offer) --- */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta .button.single_add_to_cart_button,
.bl-layout-shop .bl-product-cta a.bl-offer-btn,
.bl-layout-shop .bl-product-cta a.button.bl-offer-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;

  height:38px !important;
  line-height:38px !important;
  padding:0 14px !important;

  border-radius:6px !important;
  font-weight:700 !important;
  text-decoration:none !important;

  background:#1f6fb2 !important; /* Blue Level Blau – wenn du anderes willst, sag kurz */
  color:#fff !important;

  border:1px solid #1f6fb2 !important;
  box-shadow:none !important;
}

/* hover */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button:hover,
.bl-layout-shop .bl-product-cta a.bl-offer-btn:hover{
  filter:brightness(0.95);
}

/* remove weird pseudo arrows */
.bl-layout-shop .bl-product-cta a:after,
.bl-layout-shop .bl-product-cta button:after{
  content:none !important;
  display:none !important;
}

/* CTA: Woo Form + Buttons sauber in einer Linie */
.bl-layout-shop .bl-product-cta .cart,
.bl-layout-shop .bl-cta .cart{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
}

.bl-layout-shop .bl-product-cta .quantity,
.bl-layout-shop .bl-product-cta button.single_add_to_cart_button{
  float:none !important;
  margin:0 !important;
}

.bl-layout-shop .bl-offer-inline{
  display:inline-flex !important;
  align-items:center !important;
}

/* Einheitlicher Buttonstyle (Cart + Offer) */
.bl-layout-shop .bl-product-cta .single_add_to_cart_button,
.bl-layout-shop .bl-product-cta a.bl-offer-btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  height:38px !important;
  line-height:38px !important;
  padding:0 14px !important;
  border-radius:6px !important;
  font-weight:700 !important;
  background:#1f6fb2 !important;
  border:1px solid #1f6fb2 !important;
  color:#fff !important;
  text-decoration:none !important;
}

/* Divi/Woo Pfeile killen */
.bl-layout-shop .bl-product-cta a:after,
.bl-layout-shop .bl-product-cta button:after{
  content:none !important;
  display:none !important;
}


/* =========================================================
   FIX: Divi wraps shortcodes in <p> (block/full width) -> stacking
   ========================================================= */

/* Mach die unmittelbaren Kinder der CTA wirklich "inline" */
.bl-product-cta {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
}

/* Divi packt oft jedes Shortcode-Ergebnis in <p> -> das sprengt dir die Reihe */
.bl-product-cta > p {
  margin: 0 !important;
  padding: 0 !important;
  display: contents !important; /* macht das <p> "unsichtbar" im Layout */
}

/* Sicherheit: falls Divi statt <p> noch <div> / <span> drumherum legt */
.bl-product-cta > div,
.bl-product-cta > span {
  margin: 0 !important;
  padding: 0 !important;
  flex: 0 0 auto !important;
  width: auto !important;
}

/* Woo Add-to-cart Form nicht auf 100% */
.bl-product-cta form.cart {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  width: auto !important;
  flex: 0 0 auto !important;
}

/* Qty + Buttons immer gleich hoch */
.bl-product-cta .quantity,
.bl-product-cta .quantity input.qty,
.bl-product-cta a,
.bl-product-cta button,
.bl-product-cta .button {
  height: 38px !important;
  line-height: 38px !important;
  margin: 0 !important;
}

/* Buttons als inline-flex, niemals full width */
.bl-product-cta a,
.bl-product-cta button,
.bl-product-cta .button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  padding: 0 14px !important;
  white-space: nowrap !important;
}

/* Divi Pfeil/After weg */
.bl-product-cta a:after,
.bl-product-cta button:after {
  content: none !important;
  display: none !important;
}


/* ================================
   Downloads – Produktdetails (kompakt)
================================ */

.bl-downloads {
  margin-top: 0px;
}

/* Kategorie-Block */
.bl-download-category {
  margin-bottom: 14px;
}

/* Kategorie-Titel */
.bl-download-category-title {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 6px;
padding-bottom: 0px !important;
  color: #222;
}

/* Liste */
.bl-download-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* Einzelner Download */
.bl-download-item {
  margin-bottom: 4px;
}

/* Link */
.bl-download-item a {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  font-size: 13.5px;
  line-height: 1.3;
  color: #0b5aa2;
}

.bl-download-item a:hover {
  text-decoration: underline;
}

/* Icons */
.bl-download-icon {
  width: 14px;
  height: 14px;
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
}

.bl-icon-pdf {
  background-image: url('/wp-content/uploads/icons/icon-pdf.svg');
}

.bl-icon-docx {
  background-image: url('/wp-content/uploads/icons/icon-doc.svg');
}

/* ================================
   Technische Daten – kompakte Liste
================================ */

.bl-techdata ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.bl-techdata li {
  margin-bottom: 4px;
  font-size: 16px;
  line-height: 1.35;
  color: #222;
}

.bl-techdata li strong {
  font-weight: 600;
}

/* ================================
   Produktbeschreibung – Abstände
================================ */

.bl-description p {
  margin: 0 0 12px 0;
}

.bl-description ul {
  margin: 8px 0 12px 18px;
  padding: 0;
}

.bl-description li {
  margin-bottom: 6px;
}

.bl-description ul li:last-child {
  margin-bottom: 0;
}

/* ================================
   Produktbeschreibung – kompakte Listen
================================ */

.bl-description ul {
  margin: 8px 0 12px 18px;
  padding: 0;
}

.bl-description li {
  line-height: 1.32 !important;
  margin-bottom: 4px;
  font-size: 16px;
}

.bl-description li:last-child {
  margin-bottom: 0;
}

.bl-product-accessories {
  margin-top: 60px;
}

.bl-accessory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 20px;
}

.bl-accessory-item img {
  width: 100%;
  height: auto;
  display: block;
}

.bl-accessory-title {
  margin-top: 6px;
  font-size: 14px;
  font-weight: 600;
}

/* ================================
   Zubehör – kompakte Darstellung
================================ */

.bl-accessories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 10px;
}

.bl-accessory-item {
  border: 1px solid #e6e6e6;
  border-radius: 6px;
  padding: 8px;
  background: #fafafa;
  transition: box-shadow 0.2s ease;
}

.bl-accessory-item:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.bl-accessory-item a {
  text-decoration: none;
  color: inherit;
  display: block;
}

/* Bild deutlich kleiner */
.bl-accessory-item img {
  width: 100%;
  max-width: 120px;
  height: auto;
  margin: 0 auto 6px;
  display: block;
}

/* Titel kompakt */
.bl-accessory-title {
  font-size: 13px;
  line-height: 1.3;
  font-weight: 500;
  margin-bottom: 4px;
  color: #222;
}

/* Preis ruhig & kleiner */
.bl-accessory-price {
  font-size: 13px;
  color: #444;
}

/* Preisbox aus dem großen Produkt entschärfen */
.bl-accessory-price .bl-price-box {
  padding: 0;
}

.bl-accessory-price .bl-price-incl,
.bl-accessory-price .bl-price-excl {
  font-size: 12px;
  line-height: 1.25;
padding-bottom: 5px !important;
}

/* ================================
   Zubehör – Grid & Cards
================================ */

.bl-accessories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
  margin-bottom: 12px;
}

.bl-accessory-item {
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  padding: 10px;
  background: #fff;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Bild */
.bl-accessory-item img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* Titel */
.bl-accessory-title {
  font-size: 13px;
  line-height: 1.3;
  color: #222;
  margin-top: 4px;
}

/* Preis */
.bl-accessory-price {
  font-size: 13px;
  line-height: 1.3;
}

.bl-accessory-price .bl-price-box {
  margin: 0;
}

.bl-accessory-price p {
  margin: 0;
}

/* ================================
   Zubehör – Aktionen
================================ */

.bl-accessory-actions {
  margin-top: auto; /* Button nach unten drücken */
}

.bl-accessory-actions .button {
  padding: 8px 10px;
  font-size: 13px !important;
  border-radius: 3px;
  text-align: center;
}

/* Warenkorb-Button dezenter als Haupt-CTA */
.bl-accessory-actions .add_to_cart_button {
  background: #f4f6f8;
  color: #0b5aa2;
  border: 1px solid #0b5aa2;
}

.bl-accessory-actions .add_to_cart_button:hover {
  background: #0b5aa2;
  color: #fff;
}

/* Fallback-Link */
.bl-accessory-more {
  background: #eee;
  color: #222;
}

.woocommerce-page a.button:hover::after {
display: none !important;
}

.woocommerce a.button:hover{
color: #2980b9 !important;
}

/* ================================
   Verwandte Produkte
================================ */

.bl-related-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
  margin-top: 12px;
}

.bl-related-item {
  border: 1px solid #eee;
  border-radius: 6px;
  padding: 10px;
  background: #fafafa;
  text-align: center;
}

.bl-related-item img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.bl-related-title {
  font-size: 13px;
  line-height: 1.3;
  margin-top: 6px;
  color: #222;
}

.bl-related-price {
  font-size: 13px;
  margin-top: 4px;
}

.bl-related-item a {
  text-decoration: none;
  color: inherit;
}

.bl-related-item:hover {
  border-color: #0b5aa2;
}

/* Warenkorb-Button */
.single_add_to_cart_button {
  height: 40px;
  padding: 0 18px;
  white-space: nowrap;
}

/* Angebotsbutton */
.bl-offer-btn {
  height: 40px;
  line-height: 40px;
  padding: 0 18px;
  white-space: nowrap;
}

/* Mobile: alles untereinander */
@media (max-width: 640px) {
  .woocommerce-variation-add-to-cart {
    flex-direction: column;
    align-items: stretch;
  }

  .single_add_to_cart_button,
  .bl-offer-btn {
    width: 100%;
    text-align: center;
  }
}

/* =========================================================
   DIVI FRONTEND BUILDER FIX
   → nichts ausblenden, wenn der Builder aktiv ist
   ========================================================= */

/* Divi Frontend Builder erkennen */
body.et-fb,
body.et_fb_enabled {

  /* Page- & Product-Content IMMER sichtbar */
  .bl-main-pagecontent,
  .bl-main-productcontent,
  .bl-shop-page-content,
  .bl-shop-product-content {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  /* Akkordeons im Builder immer offen */
  .bl-accordion-content {
    display: block !important;
    max-height: none !important;
    overflow: visible !important;
  }

  /* Sicherheitsnetz: nichts per is-closed verstecken */
  .bl-accordion-item.is-closed .bl-accordion-content {
    display: block !important;
  }
}

/* =========================================
   DIVI BUILDER GUARD – NICHTS AUSBLENDEN
   ========================================= */

/* Backend Builder */
body.et-fb,
body.et_fb_enabled,
body.et-fb #et-boc,
body.et_fb_enabled #et-boc {
  display: block !important;
}

/* Alle Divi-Sections / Rows / Modules sichtbar */
body.et-fb .et_pb_section,
body.et-fb .et_pb_row,
body.et-fb .et_pb_column,
body.et-fb .et_pb_module,
body.et_fb_enabled .et_pb_section,
body.et_fb_enabled .et_pb_row,
body.et_fb_enabled .et_pb_column,
body.et_fb_enabled .et_pb_module {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Eigene Produkt-/Static-Guards neutralisieren */
body.et-fb [class*="bl-"],
body.et_fb_enabled [class*="bl-"] {
  display: block !important;
}

/* =====================================================
   DIVI SAFE MODE – Kontext-CSS nur im echten Frontend
   ===================================================== */

/* Sobald Divi aktiv ist → KEINE Kontext-Ausblendung */
body.et-fb *,
body.et_fb_enabled * {
  display: revert !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* ============================
   AB HIER: NUR FRONTEND
   ============================ */

/* Produkt-spezifische Bereiche NUR im echten Frontend */
body:not(.et-fb):not(.et_fb_enabled):not(.single-product) .bl-only-product {
  display: none;
}

/* Statische Inhalte NICHT auf Produktseiten */
body:not(.et-fb):not(.et_fb_enabled).single-product .bl-only-static {
  display: none;
}

/* =====================================================
   CTA-STRUKTUR STABILISIEREN (wegen doppeltem Wrapper)
   ===================================================== */

.bl-product-cta.bl-cta-cart,
.bl-product-cta .bl-cta-cart,
.bl-product-cta form.variations_form {
  display: block !important;
}

/* =====================================================
   VARIATION FIX – Label & Dropdown sauber nebeneinander
   ===================================================== */

.bl-cta-cart form.variations_form table.variations {
  display: block !important;
  width: auto !important;
  margin: 0 !important;
  border: 0 !important;
}

.bl-cta-cart form.variations_form table.variations tr {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.bl-cta-cart form.variations_form table.variations th.label {
  padding: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  font-weight: 600;
}

.bl-cta-cart form.variations_form table.variations td.value {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 0 !important;
}

.bl-cta-cart form.variations_form table.variations select {
  min-width: 220px !important;
  max-width: 320px !important;
  height: 36px !important;
}

.bl-cta-cart form.variations_form .reset_variations {
  margin-left: 6px !important;
}

/* CTA-Inhalt IMMER horizontal */
.bl-cta-cart .woocommerce-variation-add-to-cart {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
}

/* =====================================================
   SHOP LAYOUT – FINAL & KONFLIKTFREI
   ===================================================== */

/* =====================================================
   ≥ 1600px – 3 Spalten
   ===================================================== */
@media (min-width: 1600px) {

  .bl-layout-shop .et_pb_row.bl-shop-layout {
    display: grid !important;
    grid-template-columns: 272px minmax(0, 1fr) 360px;
    gap: 32px;
    align-items: start;
  }

  .bl-layout-shop .bl-zone-right {
    display: block !important;
  }

  /* CTA nebeneinander */
  .bl-layout-shop .woocommerce-variation-add-to-cart,
  .bl-layout-shop .bl-product-cta form.cart {
    display: flex !important;
    flex-direction: row !important;
    gap: 12px;
  }
}

/* =====================================================
   1200–1599px – 2 Spalten, rechte Spalte UNTEN
   ===================================================== */
@media (min-width: 1200px) and (max-width: 1599px) {

  .bl-layout-shop .et_pb_row.bl-shop-layout {
    display: grid !important;
    grid-template-columns: 272px minmax(0, 1fr);
    gap: 28px;
  }

  .bl-layout-shop .bl-zone-right {
    grid-column: 1 / -1;
    margin-top: 40px;
  }

  /* CTA nebeneinander */
  .bl-layout-shop .woocommerce-variation-add-to-cart,
  .bl-layout-shop .bl-product-cta form.cart {
    display: flex !important;
    flex-direction: row !important;
    gap: 12px;
  }
}

/* =====================================================
   981–1199px – CTA UNTER Ausführung, Buttons untereinander
   ===================================================== */
@media (min-width: 981px) and (max-width: 1199px) {

  .bl-layout-shop .et_pb_row.bl-shop-layout {
    display: grid !important;
    grid-template-columns: 272px minmax(0, 1fr);
    gap: 24px;
  }

  .bl-layout-shop .bl-zone-right {
    grid-column: 1 / -1;
    margin-top: 32px;
  }

  /* CTA untereinander */
  .bl-layout-shop .woocommerce-variation-add-to-cart,
  .bl-layout-shop .bl-product-cta form.cart {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px;
  }

  .bl-layout-shop .bl-product-cta button,
  .bl-layout-shop .bl-product-cta a {
    width: 100% !important;
    justify-content: center;
  }
}

/* =====================================================
   ≤ 980px – Mobile
   ===================================================== */
@media (max-width: 980px) {

  .bl-layout-shop .woocommerce-variation-add-to-cart,
  .bl-layout-shop .bl-product-cta form.cart {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px;
  }

  .bl-layout-shop .bl-product-cta button,
  .bl-layout-shop .bl-product-cta a {
    width: 100% !important;
    justify-content: center;
  }
}

/* =====================================================
   MENGE AUF PRODUKTSEITEN AUSBLENDEN (simple + variable)
   ===================================================== */

/* Simple Products */
.bl-layout-shop form.cart .quantity {
  display: none !important;
}

/* Variable Products */
.bl-layout-shop .woocommerce-variation-add-to-cart .quantity {
  display: none !important;
}

/* =====================================================
   OVERRIDE: Shop Layout – Right Column erst ab 1600px
   (überschreibt das bestehende @media(min-width:981px) 3-col Grid)
   ===================================================== */

/* 981–1599px: 2 Spalten + Right unten (Grid Areas) */
@media (min-width: 981px) and (max-width: 1599px) {

  .bl-layout-shop .et_pb_row.bl-shop-layout{
    display: grid !important;
    grid-template-columns: 272px minmax(0, 1fr) !important;
    grid-template-areas:
      "left main"
      "right right";
    gap: 28px !important;
    align-items: start !important;
  }

  /* Divi Column-Floats killen (wichtig gegen Overlap) */
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column{
    float: none !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
  }

  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-left  { grid-area: left !important; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-main  { grid-area: main !important; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-right { grid-area: right !important; }

  /* Right unten etwas Luft */
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-right{
    margin-top: 32px !important;
  }
}

/* ≥1600px: echtes 3-Spalten-Layout */
@media (min-width: 1600px) {

  .bl-layout-shop .et_pb_row.bl-shop-layout{
    display: grid !important;
    grid-template-columns: 272px minmax(0, 1fr) 360px !important;
    grid-template-areas: "left main right";
    gap: 32px !important;
    align-items: start !important;
  }

  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column{
    float: none !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 !important;
  }

  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-left  { grid-area: left !important; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-main  { grid-area: main !important; }
  .bl-layout-shop .et_pb_row.bl-shop-layout > .et_pb_column.bl-zone-right { grid-area: right !important; margin-top: 0 !important; }
}

/* =====================================================
   CTA – Tablet: Buttons unter Ausführung (wie 600px)
   ===================================================== */

/* Menge überall ausblenden (simple + variable) */
.bl-layout-shop form.cart .quantity,
.bl-layout-shop .woocommerce-variation-add-to-cart .quantity{
  display: none !important;
}

/* 981–1199: Buttons untereinander & volle Breite */
@media (min-width: 981px) and (max-width: 1199px){

  /* Wichtig: Wrapper neutralisieren, damit nichts "nebendran" landet */
  .bl-layout-shop .bl-product-cta,
  .bl-layout-shop .bl-product-cta .bl-cta,
  .bl-layout-shop .bl-product-cta .bl-cta-cart,
  .bl-layout-shop .bl-cta-cart,
  .bl-layout-shop form.variations_form{
    display: block !important;
  }

  /* Add-to-cart Bereich: untereinander */
  .bl-layout-shop .woocommerce-variation-add-to-cart,
  .bl-layout-shop .bl-product-cta form.cart{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    margin-top: 10px !important;
  }

  /* Buttons full width */
  .bl-layout-shop .woocommerce-variation-add-to-cart button,
  .bl-layout-shop .woocommerce-variation-add-to-cart a,
  .bl-layout-shop .bl-product-cta form.cart button,
  .bl-layout-shop .bl-product-cta form.cart a{
    width: 100% !important;
    justify-content: center !important;
  }
}

/* =====================================================
 Design der Archivseiten für Produkte 
   ===================================================== */

/* SEO Header im Shop NIE anzeigen */
.bl-layout-shop .bl-seo-header {
  display: none !important;
}

/* Alle Zonen sichtbar */
.bl-layout-shop .bl-zone-left,
.bl-layout-shop .bl-zone-main,
.bl-layout-shop .bl-zone-right {
  display: block;
}

.bl-layout-shop .bl-shop-header {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
}

.bl-layout-shop .bl-seo-trockenschrank-header {
  display: none !important;
}

.bl-layout-shop .bl-shop-footer { display: block !important; }
.bl-layout-shop .bl-seo-trockenschrank-footer { display: none !important; }

/* Divi Row Reset für Shop-Layouts */
.bl-layout-shop .et_pb_row.bl-shop-layout,
.bl-layout-shop .et_pb_row.bl-archive-layout {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0;
  margin-right: 0;
}

/* Divi Row Reset für Shop-Header */
.bl-layout-shop .bl-shop-header .et_pb_row {
  width: 100% !important;
  max-width: none !important;
}

/* =========================================
   BLUE LEVEL – COMPACT 2-COLUMN CONFIG
========================================= */

/* Konfig Block komplett linksbündig */
.bl-product-config {
    width: 100%;
    max-width: 100%;
    margin: 0 0 0px 0;
    padding: 0;
}

/* Jede Optionszeile als 2-Spalten Layout */
.bl-config-group {
    display: grid;
    grid-template-columns: 160px 1fr;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
}

/* Labels links */
.bl-config-group label {
    font-size: 14px;
    font-weight: 600;
    margin: 0;
    color: #333;
}

/* Select rechts */
.bl-config-group select {
    width: 100%;
    padding: 6px 10px;
    font-size: 13px;
    border: 1px solid #d6d6d6;
    border-radius: 4px;
    background: #fafafa;
    transition: all 0.15s ease;
}

/* Hover */
.bl-config-group select:hover {
    border-color: #999;
    background: #fff;
}

/* Focus */
.bl-config-group select:focus {
    border-color: #2271b1;
    box-shadow: 0 0 0 1px rgba(34,113,177,0.15);
    background: #fff;
    outline: none;
}

/* Quantity kompakter */
.cart .quantity {
    margin: 10px 0 8px 0;
}

/* Buttons kompakter */
.single_add_to_cart_button,
.bl-offer-inline .button {
    padding: 8px 16px;
    font-size: 14px;
}

/* Abstand zwischen Buttons */
.single_add_to_cart_button {
    margin-right: 8px;
}

/* Cart Layout sauber */
.cart {
    display: flex;
    flex-direction: column;
}

/* =========================================
   HERO META SPACING FIX
========================================= */

/* Vertikale Abstände im rechten Bereich reduzieren */
.bl-product-hero-meta {
    gap: 0px !important;
}

/* Standard-Abstand zwischen den Elementen entfernen */
.bl-product-hero-meta > * {
    margin-bottom: 0px !important;
}

/* Preisblock kompakter */
.bl-product-price {
    margin-bottom: 0px !important;
}

/* Verfügbarkeitszeile enger */
.bl-product-availability {
    margin-top: 0px !important;
}

/* =====================================================
   PRODUCT CONFIG – MOBILE STACK (≤ 980px)
   ===================================================== */
@media (max-width: 1399px) {

  /* Optionsgruppe wieder vertikal: Label oben, Select darunter */
  .bl-product-config .bl-config-group{
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 4px !important;
    margin-bottom: 12px !important;
  }

  .bl-product-config .bl-config-group label{
    margin: 0 0 4px 0 !important;
  }

  .bl-product-config .bl-config-group select{
    width: 100% !important;
  }
}

/* =====================================
   PRODUCT DETAIL ACCORDION (BL FINAL)
   - Preview: .is-preview + .is-expanded
   - Normal:  .is-closed (JS toggles)
===================================== */

.bl-product-details{
  max-width: 100%;
  margin-top: 60px;
  border-top: 1px solid #e5e5e5;
}

/* Item */
.bl-accordion-item{
  border-bottom: 1px solid #e5e5e5;
}

/* Header */
.bl-accordion-header{
  width: 100%;
  background: none;
  border: 0;
  padding: 18px 0 12px 0;
  font-size: 16px;
  font-weight: 600;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  text-align: left;
  position: relative; /* für Pfeil */
  padding-right: 28px; /* Platz für Pfeil rechts */
}

/* Pfeil (Preview + Normal) */
.bl-accordion-header::after{
  content: "";
  position: absolute;
  right: 6px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 2px solid #666;
  border-bottom: 2px solid #666;
  transform: translateY(-50%) rotate(45deg); /* "zu" */
  transition: transform 0.2s ease;
  pointer-events: none;
}

/* Pfeil: Normal offen = nicht is-closed */
.bl-accordion-item:not(.is-preview):not(.is-closed) .bl-accordion-header::after{
  transform: translateY(-50%) rotate(-135deg); /* "offen" */
}

/* Pfeil: Preview offen = is-expanded */
.bl-accordion-item.is-preview.is-expanded .bl-accordion-header::after{
  transform: translateY(-50%) rotate(-135deg); /* "offen" */
}

/* Toggle Text (Mehr anzeigen) – Grundstil */
.bl-accordion-toggle{
  font-size: 16px;
  font-weight: 400;
  color: #0066cc;
  white-space: nowrap;
}

/* Content */
.bl-accordion-content{
  line-height: 1.6;
}

/* ===========================
   NORMAL (non-preview)
=========================== */

/* Normal: standard offen */
.bl-accordion-item:not(.is-preview) .bl-accordion-content{
  padding-bottom: 12px;
  display: block;
}

/* Normal: geschlossen */
.bl-accordion-item:not(.is-preview).is-closed .bl-accordion-content{
  display: none;
}

/* Bei normalen Akkordeons kein "Mehr anzeigen" */
.bl-accordion-item:not(.is-preview) .bl-accordion-toggle{
  display: none;
}

/* ===========================
   PREVIEW
=========================== */

.bl-accordion-item.is-preview{
  position: relative; /* Anker für "Mehr anzeigen" unten */
}

/* Preview: gekürzt */
.bl-accordion-item.is-preview .bl-accordion-content{
  max-height: 160px;
  overflow: hidden;
  position: relative;
  padding-bottom: 44px; /* Platz für "Mehr anzeigen" unten */
  transition: max-height 0.25s ease;
}

/* Preview Fade unten */
.bl-accordion-item.is-preview .bl-accordion-content::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 60px;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
}

/* Preview: geöffnet */
.bl-accordion-item.is-preview.is-expanded .bl-accordion-content{
  max-height: 3000px; /* bewusst gross */
  overflow: visible;
  padding-bottom: 12px;
}

.bl-accordion-item.is-preview.is-expanded .bl-accordion-content::after{
  display: none;
}

/* "Mehr anzeigen" bei Preview unten mittig platzieren (aber bleibt im Header DOM) */
.bl-accordion-item.is-preview .bl-accordion-toggle{
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  text-align: center;
  z-index: 2;
}

/* "Mehr anzeigen" nur anzeigen, wenn NICHT expanded */
.bl-accordion-item.is-preview.is-expanded .bl-accordion-toggle{
  display: none;
}

/* ===========================
   PREVIEW
=========================== */

.bl-accordion-item.is-preview{
  position: relative;
}

/* Vorschau-Zustand */
.bl-accordion-item.is-preview .bl-accordion-content{
  max-height: 160px;
  overflow: hidden;
  position: relative;
  padding-bottom: 50px; /* Platz für "Mehr anzeigen" unten */
  transition: max-height 0.25s ease;
}

/* Fade */
.bl-accordion-item.is-preview .bl-accordion-content::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 60px;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
}

/* "Mehr anzeigen" optisch unten mittig platzieren */
.bl-accordion-item.is-preview .bl-accordion-toggle{
  position: absolute;
  left: 50%;
  bottom: 16px;
  transform: translateX(-50%);
  font-size: 14px;
  font-weight: 500;
  color: #2980b9; /* Wunschfarbe */
  background: #fff;
  padding: 4px 12px;
  border-radius: 999px;
  z-index: 2;
}

/* Bei geöffnetem Preview */
.bl-accordion-item.is-preview.is-expanded .bl-accordion-content{
  max-height: 3000px;
  overflow: visible;
  padding-bottom: 12px;
}

.bl-accordion-item.is-preview.is-expanded .bl-accordion-content::after{
  display: none;
}

/* "Mehr anzeigen" verschwindet bei expand */
.bl-accordion-item.is-preview.is-expanded .bl-accordion-toggle{
  display: none;
}

.bl-accordion-item.is-preview .bl-accordion-footer .bl-accordion-toggle {
  cursor: pointer !important;
}
/* Preview Content */
.bl-accordion-item.is-preview .bl-accordion-content{
  position: relative;
}

/* Footer im unteren Bereich */
.bl-accordion-item.is-preview .bl-accordion-footer{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 24px 0 12px 0;
  text-align: center;
  pointer-events: none;

  /* sanfter Verlauf nur für Lesbarkeit */
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0),
    rgba(255,255,255,0.85)
  );
}

/* Klickbarer Text */
.bl-accordion-item.is-preview .bl-accordion-toggle{
  background: none;
  border: 0;
  padding: 0;
  font-size: 16px;
  color: #2980b9;
  cursor: pointer;
  pointer-events: auto;
}

/* Größerer Fade */
.bl-accordion-item.is-preview .bl-accordion-content::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100px; /* vorher 60px */
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,0),
    rgba(255,255,255,1)
  );
}

/* ===========================
   Woo Slider Styling
=========================== */
/* Woo Gallery in Hero: volle Breite, kein Float */
.bl-product-hero-image .woocommerce-product-gallery,
.bl-product-hero-image .woocommerce div.product div.images,
.bl-product-hero-image .woocommerce div.product .woocommerce-product-gallery {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

/* Flexslider/Viewport darf 100% sein – aber NICHT der Wrapper-Track */
.bl-product-hero-image .flex-viewport,
.bl-product-hero-image .flexslider {
  width: 100% !important;
  max-width: 100% !important;
}

/* Bilder sauber skalieren */
.bl-product-hero-image .woocommerce-product-gallery__image img,
.bl-product-hero-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Thumbs gross */
.bl-product-hero-image .flex-control-thumbs{
  display:flex;
  gap:14px;
  margin-top:16px;
  flex-wrap:wrap;
}
.bl-product-hero-image .flex-control-thumbs li{
  width:120px !important;
}

/* Cart-Form immer volle Breite */
.bl-product-cta .cart {
  width: 100%;
}

/* Buttons links ausrichten */
.bl-product-cta .cart {
  justify-content: flex-start !important;
}

/* Falls flex-direction row ist, aber wir wollen sauber untereinander */
.bl-product-cta .cart {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}