/*
  font-size 1rem = 16px

  Montserrat
  html { font-size: 62.5%; }

  Nunito Sans
  html { font-size: 70.0%; }

  Hind
  html { font-size: 62.5%; }

  Apercu
  html { font-size: 68.0%; }
*/


/* #page-header it just included for the examples */
#page-header {
    display: block;
    float: left;
    max-width: 800px;
}

#page-header .bh-sl-title {
    color: #797874;
    font: normal 20px/1.4 Arial, Helvetica, sans-serif;
}

@media (min-width: 1024px) {
    #page-header .bh-sl-title {
        font-size: 30px;
    }
}
h1.bh-sl-title {
    margin: 0;
}
/* Infowindow Roboto font override */
.gm-style div, .gm-style span, .gm-style label, .gm-style a {
    font-family: Arial, Helvetica, sans-serif;
}

/* InfoBubble font size */
.bh-sl-window {
    font-size: 13px;
}

.bh-sl-error {
    clear: both;
    color: #ae2118;
    float: left;
    font-weight: bold;
    padding: 10px 0;
    width: 100%;
}

/* Avoid image issues with Google Maps and CSS resets */
.bh-sl-map-container img {
    border-radius: 0 !important;
    box-shadow: none !important;
    max-height: none !important;
    max-width: none !important;
}

.bh-sl-container {
    box-sizing: border-box;
    color: #555;
    float: left;
    font: normal 14px/1.4 Arial, Helvetica, sans-serif;
    padding: 0 15px;
    width: 100%;
    /* Avoid issues with Google Maps and CSS frameworks */
}

.bh-sl-container > * {
    box-sizing: content-box !important;
}

.bh-sl-container .bh-sl-form-container {
    clear: left;
    float: left;
    width: 100%;
    margin-bottom: 15px;
}

.bh-sl-container .form-input {
    float: left;
    width: 100%;
}


.bh-sl-container .form-input label {
    display: block;
    font-weight: bold;
    width: 100%;
}

@media (min-width: 768px) {
    .bh-sl-container .form-input label {
        display: inline-block;
        width: auto;
    }
}

.bh-sl-container .form-input input, .bh-sl-container .form-input select {
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 4px;
    font: normal 14px/1.4 Arial, Helvetica, sans-serif;
    margin: 0 0 15px 0;
    /* padding: 6px 12px; */
    width: 100%;

}

.bh-sl-container .loc-alt-dist {
    display: none;
}

.bh-sl-container button {
    background: #00447a;
    border: none;
    border-radius: 4px;
    color: #fff;
    cursor: pointer;
    float: left;
    font: bold 14px/1.4 Arial, Helvetica, sans-serif;
    margin-top: 3px;
    padding: 6px 12px;
    white-space: nowrap;
    -webkit-border-radius: 4px;
}

.bh-sl-container .bh-sl-loading {
    background: url(../img/ajax-loader.gif) no-repeat;
    float: left;
    margin: 4px 0 0 10px;
    height: 16px;
    width: 16px;
}

.bh-sl-container .bh-sl-filters-container {
    clear: both;
    float: left;
    margin: 15px 0;
    width: 100%;
}

.bh-sl-container .bh-sl-filters-container .bh-sl-filters {
    float: left;
    list-style: none;
    margin: 0 100px 0 0;
    padding: 0;
}

.bh-sl-container .bh-sl-filters-container .bh-sl-filters li {
    clear: left;
    display: block;
    float: left;
    margin: 5px 0;
    width: 100%;
}

.bh-sl-container .bh-sl-filters-container .bh-sl-filters li label {
    display: inline;
    vertical-align: text-bottom;
}

.bh-sl-container .bh-sl-filters-container .bh-sl-filters li input {
    display: block;
    float: left;
    margin-right: 8px;
}

.bh-sl-container .bh-sl-filters-container .bh-sl-filters li select {
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 4px;
    font: normal 14px/1.4 Arial, Helvetica, sans-serif;
    padding: 6px 12px;
    -webkit-border-radius: 4px;
}

.bh-sl-container .bh-sl-map-container {
    clear: left;
    float: left;
    margin-top: 27px;
    width: 100%;
}

@media (min-width: 1024px) {
    .bh-sl-container .bh-sl-map-container {
        margin-bottom: 60px;
    }
}

.bh-sl-container .bh-sl-map-container a {
    color: #005293;
    text-decoration: none;
}

.bh-sl-container .bh-sl-map-container a:active, .bh-sl-container .bh-sl-map-container a:focus, .bh-sl-container .bh-sl-map-container a:hover {
    text-decoration: underline;
}

.bh-sl-container .bh-sl-loc-list {
    font-size: 13px;
    height: 530px;
    overflow-x: auto;
    width: 100%;
}

@media (min-width: 1024px) {
    .bh-sl-container .bh-sl-loc-list {
        width: 45%;
        float: left;
        padding: 0 15px;
    }
}

.bh-sl-container .bh-sl-loc-list ul {
    display: block;
    clear: left;
    float: left;
    width: 100%;
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid #e2e2e2;
}

.bh-sl-container .bh-sl-loc-list ul li {
    border: 1px solid #fff;
    /* Adding this to prevent moving li elements when adding the list-focus class*/
    box-sizing: border-box;
    clear: left;
    cursor: pointer;
    display: block;
    float: left;
    width: 100%;
}

.bh-sl-container .bh-sl-loc-list .list-label {
    background: #00192d;
    border-radius: 15px;
    color: #fff;
    display: block;
    float: left;
    font-weight: bold;
    margin: 10px 0 0 15px;
    padding: 4px 7px;
    text-align: center;
    width: auto;
    min-width: 13px;
}

.bh-sl-container .bh-sl-loc-list .list-details {
    float: left;
    margin-left: 6px;
    width: 80%;
}

.bh-sl-container .bh-sl-loc-list .list-details .list-content {
    padding: 10px;
}

.bh-sl-container .bh-sl-loc-list .list-details .loc-dist {
    color: #6c6c6c;
    font-weight: bold;
    font-style: italic;
}

.bh-sl-container .bh-sl-loc-list .list-focus {
    border: 1px solid rgba(0, 82, 147, 0.4);
    transition: border 0.2s linear 0s, box-shadow 0.2s linear 0s;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-close-directions-container {
    height: 20px;
    position: relative;
    width: 100%;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-close-directions-container .bh-sl-close-icon {
    right: 6px;
    top: 0;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel {
    margin: 0 2%;
    /* Avoid issues with table-layout */
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel table {
    table-layout: auto;
    width: 100%;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel table, .bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel td {
    vertical-align: middle;
    border-collapse: separate;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel td {
    padding: 1px;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel .adp-placemark {
    margin: 10px 0;
    border: 1px solid #c0c0c0;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-directions-panel .adp-marker {
    padding: 3px;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-noresults-title {
    font-weight: bold;
    margin: 15px;
}

.bh-sl-container .bh-sl-loc-list .bh-sl-noresults-desc {
    margin: 0 15px;
}

.bh-sl-container .loc-name {
    /* Picked up by both list and infowindows */
    font-size: 15px;
    font-weight: bold;
}

.bh-sl-container .bh-sl-map {
    float: left;
    height: 530px;
    width: 100%;
}

@media (min-width: 1024px) {
    .bh-sl-container .bh-sl-map {
        width: 55%;
    }
}

.bh-sl-container .bh-sl-pagination-container {
    clear: both;
}

.bh-sl-container .bh-sl-pagination-container ol {
    list-style-type: none;
    margin: 0;
    padding: 10px 0;
    text-align: center;
}

.bh-sl-container .bh-sl-pagination-container ol li {
    color: #005293;
    cursor: pointer;
    display: inline-block;
    font: bold 14px Arial, Helvetica, sans-serif;
    padding: 10px;
}

.bh-sl-container .bh-sl-pagination-container ol .bh-sl-current {
    color: #555;
    cursor: auto;
    text-decoration: none;
}





/* ==========================================================================
   PDP v2 - Patches
   ========================================================================== */

/* --- Model-Info-Box: zwei Zeilen unterstuetzen (Tag 50022 + Tag 50005) --- */
.pdp_v2 .pdp_v2_model_info_text {
  flex: 1;
  min-width: 0;
}

.pdp_v2 .pdp_v2_model_info_text > div + div {
  margin-top: 4px;
}

/* --- Section-Heading (DIESEN LOOK KAUFEN etc.) wie Kategorie-Seite --- */
.pdp_v2 .pdp_v2_eyebrow {
  font-size: 1.8rem;
  line-height: 1.4;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #000;
  font-weight: 500;
  margin: 0 0 32px 0;
  padding: 0;
  border-bottom: none;
}

/* ==========================================================================
   CROSS-SELLING SEKTIONEN (volle Breite, kein Moodbild)
   Gilt fuer: "Diesen Look kaufen", "Mehr aus dieser Kategorie",
   spaeter "Mehr in diesem Style"
   ========================================================================== */

.pdp_v2 .pdp_v2_xsell_section {
  margin: 60px 0 0 0;
}

.pdp_v2 .pdp_v2_xsell_products {
  min-width: 0;
}

/* Headings vom internen Modul (MODULE_cross_selling) verstecken,
   wir haben unseren eigenen pdp_v2_eyebrow drueber */
.pdp_v2 .pdp_v2_xsell_products h2,
.pdp_v2 .pdp_v2_xsell_products h3 {
  display: none;
}

/* Produkt-Kacheln: 4 pro Reihe Desktop, 2 pro Reihe Mobile */
.pdp_v2 .pdp_v2_xsell_products .lb_box_1 {
  width: 25%;
}

@media (max-width: 779px) {
  .pdp_v2 .pdp_v2_xsell_products .lb_box_1 {
    width: 50%;
  }

  .pdp_v2 .pdp_v2_xsell_section {
    margin-top: 40px;
  }
}








/* =====================================================================
   Listing v2  -  Variante 1 "Reduktion pur" (fein, COS / dynamic-filter)
   ---------------------------------------------------------------------
   Ans Ende von  templates/pureistic_4000/css/custom.css  anhaengen
   (alten Block komplett ersetzen). Danach CSS-Cache leeren.

   Herz nutzt jetzt das template-eigene SVG (img/icons/heart.svg bzw.
   heart_filled.svg) statt FontAwesome -> exakt gleiche Strichstaerke
   wie der Bag-Trigger. Markup/JS dafuer sind im Modul angepasst.
   ===================================================================== */


/* ---------------------------------------------------------------------
   1) Wishlist-Herz: SVG, gleiche Groesse/Strichstaerke wie der Bag (16px),
      kein Kasten, kein Hover-Rahmen
   --------------------------------------------------------------------- */
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButtonColor1,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButtonColor1 *,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButton,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButton:hover {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .wl-heart-icon {
  width: 16px !important;
  height: 16px !important;
  display: block;
}
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButtonColor1:hover,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButtonColor1:hover * {
  opacity: 0.6;
}
/* leerer Submit-Button erzeugte das graue Kaestchen -> auf 0 */
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change button.add-btn,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change .cssButtonText {
  width: 0 !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  overflow: hidden;
}
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change *:focus,
.flex_listing_container_v2 .lb_box_v2 .wishlist-heart-change *:active {
  outline: none !important;
  box-shadow: none !important;
}


/* ---------------------------------------------------------------------
   2) Label + Groessen-Text: fein & klein (alle Viewports)
   --------------------------------------------------------------------- */
.flex_listing_container_v2 .lb_box_v2 .lb_attributes_title {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em;
  line-height: 1.4;
  color: #8a8a86;
  text-transform: uppercase;
}
.flex_listing_container_v2 .lb_box_v2 .lb_attributes_item {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.3;
}


/* ---------------------------------------------------------------------
   3) Bag-Trigger (.size_button): fein & klein, ohne Kasten (16px)
   --------------------------------------------------------------------- */
.flex_listing_container_v2 .lb_box_v2 .size_button,
.flex_listing_container_v2 .lb_box_v2 .size_button:hover,
.flex_listing_container_v2 .lb_box_v2 .size_button .cssButtonColor1,
.flex_listing_container_v2 .lb_box_v2 .size_button .cssButtonColor1 * {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.flex_listing_container_v2 .lb_box_v2 .size_button > span > img {
  /* optisch an das Herz angleichen: Bag-SVG fuellt seine viewBox weniger,
     daher groessere Box noetig fuer gleiche sichtbare Glyphe */
  width: 21px !important;
  height: 21px !important;
}


/* ---------------------------------------------------------------------
   4) Desktop / Tablet (ab 770px): Hover-Overlay, feine randlose Zellen
   --------------------------------------------------------------------- */
@media (min-width: 770px) {

  .flex_listing_container_v2 .lb_box_v2 .lb_attributes {
    background: rgba(255, 255, 255, 0.92);
    padding: 12px 12px 14px;
  }
  .flex_listing_container_v2 .lb_box_v2 .attr-header .hide-attributes {
    display: none !important;
  }
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_title {
    margin-bottom: 8px;
  }
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_row.quick_buy_size {
    flex-wrap: wrap;
    gap: 3px 2px;
  }
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_row .size_option_form,
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_row #form-disabled {
    width: 40px;
    margin: 0;
  }
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_row .size_option {
    display: block !important;
    width: 100%;
    padding: 4px 0;
  }
  .flex_listing_container_v2 .lb_box_v2 .lb_attributes_item:hover,
  .flex_listing_container_v2 .lb_box_v2 button.size_option.lb_attributes_item:hover,
  .flex_listing_container_v2 .lb_box_v2 button.size_option.lb_attributes_item:hover .lb_attributes_item {
    background: transparent !important;
    color: #111 !important;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}


/* ---------------------------------------------------------------------
   5) Mobiles Bottom-Sheet (<=769px): X klar getrennt + feine Zellen,
      Umbruch fuer beliebig viele Groessen (z.B. 12)
   --------------------------------------------------------------------- */
@media screen and (max-width: 769px) {

  .flex_listing_container_v2 .lb_box_v2 .lb_attributes.active_attribute {
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
  }

  /* Sheet-Kopf: X bekommt feste Breite rechts, Label zentriert & frei */
  .flex_listing_container_v2 .lb_box_v2 .active_attribute .attr-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 14px 0;
  }
  .flex_listing_container_v2 .lb_box_v2 .active_attribute .lb_attributes_title {
    flex: 1 1 auto;
    text-align: center;
    padding-left: 24px;   /* gleicht die X-Breite rechts aus -> echt mittig */
    margin: 0;
  }
  .flex_listing_container_v2 .lb_box_v2 .active_attribute .hide-attributes {
    flex: 0 0 16px;
    order: 2;
    padding: 0 !important;
    text-align: center;
  }

  /* Groessen: zentrierte, randlose Zellen mit Umbruch */
  .flex_listing_container_v2 .lb_box_v2 .active_attribute span.quick_buy_size {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 6px 10px;
    margin-top: 14px;
    padding: 0 14px 18px;
  }
  .flex_listing_container_v2 .lb_box_v2 .active_attribute form.size_option_form,
  .flex_listing_container_v2 .lb_box_v2 .active_attribute button#form-disabled.size_option {
    width: 44px;
    border-bottom: none !important;
    margin: 0;
  }
  .flex_listing_container_v2 .lb_box_v2 .active_attribute button#form-disabled.size_option,
  .flex_listing_container_v2 .lb_box_v2 .active_attribute button.size_option.lb_attributes_item:not(.hide-attributes) {
    display: block !important;
    width: 100%;
    text-align: center;
    padding: 10px 0 !important;
  }
  .flex_listing_container_v2 .lb_box_v2 .active_attribute .size_option_form:last-child {
    margin-bottom: 0;
  }
}


/* ---------------------------------------------------------------------
   6) Tag-Badges UNTEN LINKS (Option B) - kollidiert nicht mit Sale (oben)
      und nicht mit dem Herz (oben rechts). Beim Desktop-Groessen-Hover
      blenden sie aus, da das Overlay von unten aufgeht.
   --------------------------------------------------------------------- */
.flex_listing_container_v2 .lb_box_v2 .tags-images {
  top: auto !important;
  bottom: 12px !important;
  left: 10px !important;
  right: auto !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  transition: opacity 0.15s ease;
}
.flex_listing_container_v2 .lb_box_v2 .tags-images img.tag_image {
  width: 48px !important;
}
/* Desktop: beim Aufgehen des Groessen-Overlays Badges ausblenden */
@media (min-width: 770px) {
  .flex_listing_container_v2 .lb_box_v2:hover .tags-images,
  .flex_listing_container_v2 .lb_box_v2 .lb_image:hover .tags-images {
    opacity: 0;
    pointer-events: none;
  }
}


/* =====================================================================
   WISHLIST-SCOPE: dieselben feinen Groessen/Overlay-Regeln wie im Listing,
   aber auf .cg_wishlist .lb_box_1 gespiegelt (Wishlist nutzt .lb_box_1
   statt .lb_box_v2). Carousels (ebenfalls .lb_box_1) bleiben unberuehrt,
   da hier zusaetzlich .cg_wishlist verlangt wird.
   ===================================================================== */
/* ---------------------------------------------------------------------
   2) Label + Groessen-Text: fein & klein (alle Viewports)
   --------------------------------------------------------------------- */
.cg_wishlist .lb_box_1 .lb_attributes_title {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em;
  line-height: 1.4;
  color: #8a8a86;
  text-transform: uppercase;
}
.cg_wishlist .lb_box_1 .lb_attributes_item {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.3;
}


/* ---------------------------------------------------------------------
   3) Bag-Trigger (.size_button): fein & klein, ohne Kasten (16px)
   --------------------------------------------------------------------- */
.cg_wishlist .lb_box_1 .size_button,
.cg_wishlist .lb_box_1 .size_button:hover,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1 * {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.cg_wishlist .lb_box_1 .size_button > span > img {
  /* optisch an das Herz angleichen: Bag-SVG fuellt seine viewBox weniger,
     daher groessere Box noetig fuer gleiche sichtbare Glyphe */
  width: 21px !important;
  height: 21px !important;
}


/* ---------------------------------------------------------------------
   4) Desktop / Tablet (ab 770px): Hover-Overlay, feine randlose Zellen
   --------------------------------------------------------------------- */
@media (min-width: 770px) {

  .cg_wishlist .lb_box_1 .lb_attributes {
    background: rgba(255, 255, 255, 0.92);
    padding: 12px 12px 14px;
  }
  .cg_wishlist .lb_box_1 .attr-header .hide-attributes {
    display: none !important;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_title {
    margin-bottom: 8px;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row.quick_buy_size {
    flex-wrap: wrap;
    gap: 3px 2px;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row .size_option_form,
  .cg_wishlist .lb_box_1 .lb_attributes_row #form-disabled {
    width: 40px;
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row .size_option {
    display: block !important;
    width: 100%;
    padding: 4px 0;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_item:hover,
  .cg_wishlist .lb_box_1 button.size_option.lb_attributes_item:hover,
  .cg_wishlist .lb_box_1 button.size_option.lb_attributes_item:hover .lb_attributes_item {
    background: transparent !important;
    color: #111 !important;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}


/* ---------------------------------------------------------------------
   5) Mobiles Bottom-Sheet (<=769px): X klar getrennt + feine Zellen,
      Umbruch fuer beliebig viele Groessen (z.B. 12)
   --------------------------------------------------------------------- */
@media screen and (max-width: 769px) {

  .cg_wishlist .lb_box_1 .lb_attributes.active_attribute {
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
  }

  /* Sheet-Kopf: X bekommt feste Breite rechts, Label zentriert & frei */
  .cg_wishlist .lb_box_1 .active_attribute .attr-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 14px 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute .lb_attributes_title {
    flex: 1 1 auto;
    text-align: center;
    padding-left: 24px;   /* gleicht die X-Breite rechts aus -> echt mittig */
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute .hide-attributes {
    flex: 0 0 16px;
    order: 2;
    padding: 0 !important;
    text-align: center;
  }

  /* Groessen: zentrierte, randlose Zellen mit Umbruch */
  .cg_wishlist .lb_box_1 .active_attribute span.quick_buy_size {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 6px 10px;
    margin-top: 14px;
    padding: 0 14px 18px;
  }
  .cg_wishlist .lb_box_1 .active_attribute form.size_option_form,
  .cg_wishlist .lb_box_1 .active_attribute button#form-disabled.size_option {
    width: 44px;
    border-bottom: none !important;
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute button#form-disabled.size_option,
  .cg_wishlist .lb_box_1 .active_attribute button.size_option.lb_attributes_item:not(.hide-attributes) {
    display: block !important;
    width: 100%;
    text-align: center;
    padding: 10px 0 !important;
  }
  .cg_wishlist .lb_box_1 .active_attribute .size_option_form:last-child {
    margin-bottom: 0;
  }
}

/* =====================================================================
   8) Merkzettel-Seite (.cg_wishlist) — Styling konsolidiert ans DATEIENDE
      verschoben (siehe Block "8/11/12 KONSOLIDIERT v4.0.30"). Ab v4.0.30
      liegen X + Bag im .lb_image (Markup-Move in wishlist.html), daher
      keine content-verankerten Positionier-Hacks mehr hier.
   ===================================================================== */


/* =====================================================================
   CAROUSEL-SCOPE (Kategorie-/Startseiten-Slider): dieselbe feine Listing-
   Optik (Herz/Groessen/Bag/Overlay/Badges) auf [class*="slider-listingbox"] .lb_box_1
   gespiegelt. Die Carousel-Karten haben dasselbe Markup wie das Listing,
   nur Wrapper .lb_box_1 statt .lb_box_v2 -> reine CSS-Angleichung.
   PDP-Cross-Sell (.slider-listingbox-details) ist via [class*=]-Scope JETZT
   mit enthalten (zeigt Quick-Buy bereits, brauchte nur die feine Optik).
   ===================================================================== */
[class*="slider-listingbox"] .lb_box_1 .lb_image { position: relative; }
/* ---------------------------------------------------------------------
   1) Wishlist-Herz: SVG, gleiche Groesse/Strichstaerke wie der Bag (16px),
      kein Kasten, kein Hover-Rahmen
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1 *,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButton,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButton:hover {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .wl-heart-icon {
  width: 16px !important;
  height: 16px !important;
  display: block;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1:hover,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1:hover * {
  opacity: 0.6;
}
/* leerer Submit-Button erzeugte das graue Kaestchen -> auf 0 */
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change button.add-btn,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonText {
  width: 0 !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  overflow: hidden;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change *:focus,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change *:active {
  outline: none !important;
  box-shadow: none !important;
}


/* ---------------------------------------------------------------------
   2) Label + Groessen-Text: fein & klein (alle Viewports)
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .lb_attributes_title {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em;
  line-height: 1.4;
  color: #8a8a86;
  text-transform: uppercase;
}
[class*="slider-listingbox"] .lb_box_1 .lb_attributes_item {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.3;
}


/* ---------------------------------------------------------------------
   3) Bag-Trigger (.size_button): fein & klein, ohne Kasten (16px)
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .size_button,
[class*="slider-listingbox"] .lb_box_1 .size_button:hover,
[class*="slider-listingbox"] .lb_box_1 .size_button .cssButtonColor1,
[class*="slider-listingbox"] .lb_box_1 .size_button .cssButtonColor1 * {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
[class*="slider-listingbox"] .lb_box_1 .size_button > span > img {
  /* optisch an das Herz angleichen: Bag-SVG fuellt seine viewBox weniger,
     daher groessere Box noetig fuer gleiche sichtbare Glyphe */
  width: 21px !important;
  height: 21px !important;
}


/* ---------------------------------------------------------------------
   4) Desktop / Tablet (ab 770px): Hover-Overlay, feine randlose Zellen
   --------------------------------------------------------------------- */
@media (min-width: 770px) {

  [class*="slider-listingbox"] .lb_box_1 .lb_attributes {
    background: rgba(255, 255, 255, 0.92);
    padding: 12px 12px 14px;
  }
  [class*="slider-listingbox"] .lb_box_1 .attr-header .hide-attributes {
    display: none !important;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_title {
    margin-bottom: 8px;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row.quick_buy_size {
    flex-wrap: wrap;
    gap: 3px 2px;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row .size_option_form,
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row #form-disabled {
    width: 40px;
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row .size_option {
    display: block !important;
    width: 100%;
    padding: 4px 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_item:hover,
  [class*="slider-listingbox"] .lb_box_1 button.size_option.lb_attributes_item:hover,
  [class*="slider-listingbox"] .lb_box_1 button.size_option.lb_attributes_item:hover .lb_attributes_item {
    background: transparent !important;
    color: #111 !important;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}


/* ---------------------------------------------------------------------
   5) Mobiles Bottom-Sheet (<=769px): X klar getrennt + feine Zellen,
      Umbruch fuer beliebig viele Groessen (z.B. 12)
   --------------------------------------------------------------------- */
@media screen and (max-width: 769px) {

  [class*="slider-listingbox"] .lb_box_1 .lb_attributes.active_attribute {
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
  }

  /* Sheet-Kopf: X bekommt feste Breite rechts, Label zentriert & frei */
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .attr-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 14px 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .lb_attributes_title {
    flex: 1 1 auto;
    text-align: center;
    padding-left: 24px;   /* gleicht die X-Breite rechts aus -> echt mittig */
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .hide-attributes {
    flex: 0 0 16px;
    order: 2;
    padding: 0 !important;
    text-align: center;
  }

  /* Groessen: zentrierte, randlose Zellen mit Umbruch */
  [class*="slider-listingbox"] .lb_box_1 .active_attribute span.quick_buy_size {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 6px 10px;
    margin-top: 14px;
    padding: 0 14px 18px;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute form.size_option_form,
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button#form-disabled.size_option {
    width: 44px;
    border-bottom: none !important;
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button#form-disabled.size_option,
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button.size_option.lb_attributes_item:not(.hide-attributes) {
    display: block !important;
    width: 100%;
    text-align: center;
    padding: 10px 0 !important;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .size_option_form:last-child {
    margin-bottom: 0;
  }
}


/* ---------------------------------------------------------------------
   6) Tag-Badges UNTEN LINKS (Option B) - kollidiert nicht mit Sale (oben)
      und nicht mit dem Herz (oben rechts). Beim Desktop-Groessen-Hover
      blenden sie aus, da das Overlay von unten aufgeht.
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .tags-images {
  top: auto !important;
  bottom: 12px !important;
  left: 10px !important;
  right: auto !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  transition: opacity 0.15s ease;
}
[class*="slider-listingbox"] .lb_box_1 .tags-images img.tag_image {
  width: 48px !important;
}
/* Desktop: beim Aufgehen des Groessen-Overlays Badges ausblenden */
@media (min-width: 770px) {
  [class*="slider-listingbox"] .lb_box_1:hover .tags-images,
  [class*="slider-listingbox"] .lb_box_1 .lb_image:hover .tags-images {
    opacity: 0;
    pointer-events: none;
  }
}
/* =====================================================================
   9) MOBIL: vollbreites Bottom-Sheet, Groessen EDITORIAL (Variante B)
      - position:fixed, volle Breite, von unten; z-index ueber Tags/Badges.
      - Greif-Leiste oben (::before), Safe-Area unten, kein Backdrop.
      - Groessen als reiner Text, zentriert, umbrechend (KEIN Kasten/Rahmen);
        aktive/gedrueckte Groesse fein unterstrichen, ausverkauft grau +
        durchgestrichen. Komfortable Tap-Flaeche via Padding (unsichtbar).
      - touch-action + Scroll-Lock-Hook (JS-Snippet in docs/) gegen Doppeltap.
      - Global gescoped (gilt auch fuer die an <body> geklonten Slider-Sheets).
   ===================================================================== */
@media screen and (max-width: 769px) {

  .lb_attributes.active_attribute {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 80vh;
    overflow-y: auto;
    margin: 0 !important;
    z-index: 100000 !important;
    background: #fff;
    border-radius: 18px 18px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.12);
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px)) !important;
  }

  /* Greif-Leiste oben */
  .lb_attributes.active_attribute::before {
    content: "";
    display: block;
    width: 38px;
    height: 4px;
    border-radius: 2px;
    background: #d9d9d9;
    margin: 10px auto 2px;
  }

  /* Groessen: editorial - reiner Text, zentriert, umbrechend */
  .lb_attributes.active_attribute .quick_buy_size {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 14px 22px !important;
    margin-top: 14px !important;
    padding: 0 16px 8px !important;
  }
  .lb_attributes.active_attribute .size_option_form,
  .lb_attributes.active_attribute form.size_option_form,
  .lb_attributes.active_attribute button#form-disabled.size_option {
    width: auto !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    border-bottom: none !important;
  }
  /* Zelle = reiner Text mit komfortabler Tap-Flaeche, kein Rahmen/Hintergrund */
  .lb_attributes.active_attribute button.size_option.lb_attributes_item:not(.hide-attributes),
  .lb_attributes.active_attribute button#form-disabled.size_option {
    display: inline-block !important;
    width: auto !important;
    text-align: center !important;
    font-size: 15px !important;
    line-height: 1 !important;
    padding: 6px 8px !important;
    border: none !important;
    border-radius: 0 !important;
    background: none !important;
  }
  /* aktive/gedrueckte Groesse: feiner Unterstrich */
  .lb_attributes.active_attribute button.size_option.lb_attributes_item:not(.hide-attributes):active,
  .lb_attributes.active_attribute button.size_option.lb_attributes_item.active,
  .lb_attributes.active_attribute button.size_option.lb_attributes_item.selected {
    border-bottom: 1.5px solid #111 !important;
    padding-bottom: 3px !important;
  }
  /* ausverkauft: dezent grau + durchgestrichen */
  .lb_attributes.active_attribute button#form-disabled.size_option {
    color: #bdbdbd !important;
    text-decoration: line-through !important;
  }

  /* Tap-Reaktion: iOS-Tap-Verzoegerung / Doppeltap-Zoom raus */
  .lb_attributes.active_attribute,
  .lb_attributes.active_attribute .size_option,
  .lb_attributes.active_attribute button.size_option,
  .lb_attributes.active_attribute .size_option_form {
    touch-action: manipulation;
  }
  .size_button { touch-action: manipulation; }

  /* Body-Scroll-Lock solange Sheet offen (Klasse setzt das JS-Snippet) */
  body.cg-sheet-open { overflow: hidden !important; }
}


/* =====================================================================
   10) MOBIL Wishlist-Sheet-Kopf: die wishlist.html hat KEINEN
       .attr-header-Wrapper (X + Titel sind direkte Kinder von
       .lb_attributes) -> Flex-Header greift dort nicht und Titel/X
       ueberlappen. Fix CSS-only & nur fuer .cg_wishlist: X absolut oben
       rechts, Titel zentriert mit Seitenabstand. Kein Template-Eingriff.
   ===================================================================== */
@media screen and (max-width: 769px) {

  .cg_wishlist .lb_attributes.active_attribute .hide-attributes {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: 22px !important;
    height: 22px !important;
    min-width: 0 !important;
    flex: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: none !important;
    font-size: 15px !important;
    line-height: 22px !important;
    text-align: center !important;
    z-index: 2 !important;
  }
  .cg_wishlist .lb_attributes.active_attribute .lb_attributes_title {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 4px 44px 0 !important;
    margin: 0 !important;
  }
}


/* =====================================================================
   8/11/12) Merkzettel (wishlist.html, .cg_wishlist) — KONSOLIDIERT v4.0.30
   ---------------------------------------------------------------------
   Ab v4.0.30 liegen X (.lb_delete) und Bag-Trigger (.size_button) IM
   .lb_image (Markup-Move in wishlist.html) — exakt wie Herz + Bag im
   Listing. Das Basis-CSS positioniert beide dadurch automatisch:
   .lb_image ist position:relative (festes Seitenverhaeltnis), .lb_delete
   und .size_button sind position:absolute. Hier nur noch Feinjustage:
     - X exakt auf die Listing-Herz-Position (top:10px / right:10px)
     - X-Glyph: feines delete-x.svg statt FA-Trash
     - Bag: Basis-Gelb weg, Text "Groesse hinzufuegen" ausblenden, bag.svg
   Die alten content-verankerten Hacks (lb_content position-Tweaks) sind
   entfallen. Dieser Block steht bewusst am Dateiende (gewinnt Source-Order
   gegen den transparenten Bag aus Block 3).
   ===================================================================== */

/* X (.lb_delete): oben rechts ueber dem Bild, exakt wie das Listing-Herz */
.cg_wishlist .lb_box_1 .lb_delete {
  top: 10px !important;
  right: 10px !important;
  left: auto !important;
  bottom: auto !important;
  width: 30px !important;
  height: 30px !important;
  z-index: 999 !important;
}
.cg_wishlist .lb_box_1 .lb_delete .cssButton { padding: 0 !important; min-height: 0 !important; }
.cg_wishlist .lb_box_1 .lb_delete .cssButton .cssIconLeft i,
.cg_wishlist .lb_box_1 .lb_delete .cssButton [class*="trash"] { display: none !important; }
.cg_wishlist .lb_box_1 .lb_delete .cssButton .cssIconLeft {
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url("../img/icons/delete-x.svg") center / contain no-repeat;
}
.cg_wishlist .lb_box_1 .lb_delete a,
.cg_wishlist .lb_box_1 .lb_delete .cssButton { opacity: 0.55; transition: opacity 0.15s ease; }
.cg_wishlist .lb_box_1 .lb_delete a:hover,
.cg_wishlist .lb_box_1 .lb_delete .cssButton:hover { opacity: 1; text-decoration: none; }

/* Bag (.size_button): Position kommt vom Basis-CSS (unten rechts im .lb_image).
   Hier nur Optik: Basis-Gelb weg, Text raus, bag.svg als Glyph (21px). */
.cg_wishlist .lb_box_1 .size_button,
.cg_wishlist .lb_box_1 .size_button:hover,
.cg_wishlist .lb_box_1 .size_button:focus,
.cg_wishlist .lb_box_1 .size_button:active {
  background: url("../img/icons/bag.svg") center / 21px 21px no-repeat !important;
  border: 0 !important;
  box-shadow: none !important;
}
.cg_wishlist .lb_box_1 .size_button .cssButton,
.cg_wishlist .lb_box_1 .size_button span,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1 {
  font-size: 0 !important;
  line-height: 0 !important;
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: transparent !important;
}










































/* =====================================================================
   WISHLIST-SCOPE: dieselben feinen Groessen/Overlay-Regeln wie im Listing,
   aber auf .cg_wishlist .lb_box_1 gespiegelt (Wishlist nutzt .lb_box_1
   statt .lb_box_v2). Carousels (ebenfalls .lb_box_1) bleiben unberuehrt,
   da hier zusaetzlich .cg_wishlist verlangt wird.
   ===================================================================== */
/* ---------------------------------------------------------------------
   2) Label + Groessen-Text: fein & klein (alle Viewports)
   --------------------------------------------------------------------- */
.cg_wishlist .lb_box_1 .lb_attributes_title {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em;
  line-height: 1.4;
  color: #8a8a86;
  text-transform: uppercase;
}
.cg_wishlist .lb_box_1 .lb_attributes_item {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.3;
}


/* ---------------------------------------------------------------------
   3) Bag-Trigger (.size_button): fein & klein, ohne Kasten (16px)
   --------------------------------------------------------------------- */
.cg_wishlist .lb_box_1 .size_button,
.cg_wishlist .lb_box_1 .size_button:hover,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1 * {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.cg_wishlist .lb_box_1 .size_button > span > img {
  /* optisch an das Herz angleichen: Bag-SVG fuellt seine viewBox weniger,
     daher groessere Box noetig fuer gleiche sichtbare Glyphe */
  width: 21px !important;
  height: 21px !important;
}


/* ---------------------------------------------------------------------
   4) Desktop / Tablet (ab 770px): Hover-Overlay, feine randlose Zellen
   --------------------------------------------------------------------- */
@media (min-width: 770px) {

  .cg_wishlist .lb_box_1 .lb_attributes {
    background: rgba(255, 255, 255, 0.92);
    padding: 12px 12px 14px;
  }
  .cg_wishlist .lb_box_1 .attr-header .hide-attributes {
    display: none !important;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_title {
    margin-bottom: 8px;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row.quick_buy_size {
    flex-wrap: wrap;
    gap: 3px 2px;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row .size_option_form,
  .cg_wishlist .lb_box_1 .lb_attributes_row #form-disabled {
    width: 40px;
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_row .size_option {
    display: block !important;
    width: 100%;
    padding: 4px 0;
  }
  .cg_wishlist .lb_box_1 .lb_attributes_item:hover,
  .cg_wishlist .lb_box_1 button.size_option.lb_attributes_item:hover,
  .cg_wishlist .lb_box_1 button.size_option.lb_attributes_item:hover .lb_attributes_item {
    background: transparent !important;
    color: #111 !important;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}


/* ---------------------------------------------------------------------
   5) Mobiles Bottom-Sheet (<=769px): X klar getrennt + feine Zellen,
      Umbruch fuer beliebig viele Groessen (z.B. 12)
   --------------------------------------------------------------------- */
@media screen and (max-width: 769px) {

  .cg_wishlist .lb_box_1 .lb_attributes.active_attribute {
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
  }

  /* Sheet-Kopf: X bekommt feste Breite rechts, Label zentriert & frei */
  .cg_wishlist .lb_box_1 .active_attribute .attr-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 14px 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute .lb_attributes_title {
    flex: 1 1 auto;
    text-align: center;
    padding-left: 24px;   /* gleicht die X-Breite rechts aus -> echt mittig */
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute .hide-attributes {
    flex: 0 0 16px;
    order: 2;
    padding: 0 !important;
    text-align: center;
  }

  /* Groessen: zentrierte, randlose Zellen mit Umbruch */
  .cg_wishlist .lb_box_1 .active_attribute span.quick_buy_size {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 6px 10px;
    margin-top: 14px;
    padding: 0 14px 18px;
  }
  .cg_wishlist .lb_box_1 .active_attribute form.size_option_form,
  .cg_wishlist .lb_box_1 .active_attribute button#form-disabled.size_option {
    width: 44px;
    border-bottom: none !important;
    margin: 0;
  }
  .cg_wishlist .lb_box_1 .active_attribute button#form-disabled.size_option,
  .cg_wishlist .lb_box_1 .active_attribute button.size_option.lb_attributes_item:not(.hide-attributes) {
    display: block !important;
    width: 100%;
    text-align: center;
    padding: 10px 0 !important;
  }
  .cg_wishlist .lb_box_1 .active_attribute .size_option_form:last-child {
    margin-bottom: 0;
  }
}

/* =====================================================================
   8) Merkzettel-Seite (.cg_wishlist) — Styling konsolidiert ans DATEIENDE
      verschoben (siehe Block "8/11/12 KONSOLIDIERT v4.0.30"). Ab v4.0.30
      liegen X + Bag im .lb_image (Markup-Move in wishlist.html), daher
      keine content-verankerten Positionier-Hacks mehr hier.
   ===================================================================== */


/* =====================================================================
   CAROUSEL-SCOPE (Kategorie-/Startseiten-Slider): dieselbe feine Listing-
   Optik (Herz/Groessen/Bag/Overlay/Badges) auf [class*="slider-listingbox"] .lb_box_1
   gespiegelt. Die Carousel-Karten haben dasselbe Markup wie das Listing,
   nur Wrapper .lb_box_1 statt .lb_box_v2 -> reine CSS-Angleichung.
   PDP-Cross-Sell (.slider-listingbox-details) ist via [class*=]-Scope JETZT
   mit enthalten (zeigt Quick-Buy bereits, brauchte nur die feine Optik).
   ===================================================================== */
[class*="slider-listingbox"] .lb_box_1 .lb_image { position: relative; }
/* ---------------------------------------------------------------------
   1) Wishlist-Herz: SVG, gleiche Groesse/Strichstaerke wie der Bag (16px),
      kein Kasten, kein Hover-Rahmen
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1 *,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButton,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButton:hover {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .wl-heart-icon {
  width: 16px !important;
  height: 16px !important;
  display: block;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1:hover,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonColor1:hover * {
  opacity: 0.6;
}
/* leerer Submit-Button erzeugte das graue Kaestchen -> auf 0 */
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change button.add-btn,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change .cssButtonText {
  width: 0 !important;
  min-width: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  overflow: hidden;
}
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change *:focus,
[class*="slider-listingbox"] .lb_box_1 .wishlist-heart-change *:active {
  outline: none !important;
  box-shadow: none !important;
}


/* ---------------------------------------------------------------------
   2) Label + Groessen-Text: fein & klein (alle Viewports)
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .lb_attributes_title {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.22em;
  line-height: 1.4;
  color: #8a8a86;
  text-transform: uppercase;
}
[class*="slider-listingbox"] .lb_box_1 .lb_attributes_item {
  font-size: 12px !important;
  font-weight: 400 !important;
  line-height: 1.3;
}


/* ---------------------------------------------------------------------
   3) Bag-Trigger (.size_button): fein & klein, ohne Kasten (16px)
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .size_button,
[class*="slider-listingbox"] .lb_box_1 .size_button:hover,
[class*="slider-listingbox"] .lb_box_1 .size_button .cssButtonColor1,
[class*="slider-listingbox"] .lb_box_1 .size_button .cssButtonColor1 * {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
[class*="slider-listingbox"] .lb_box_1 .size_button > span > img {
  /* optisch an das Herz angleichen: Bag-SVG fuellt seine viewBox weniger,
     daher groessere Box noetig fuer gleiche sichtbare Glyphe */
  width: 21px !important;
  height: 21px !important;
}


/* ---------------------------------------------------------------------
   4) Desktop / Tablet (ab 770px): Hover-Overlay, feine randlose Zellen
   --------------------------------------------------------------------- */
@media (min-width: 770px) {

  [class*="slider-listingbox"] .lb_box_1 .lb_attributes {
    background: rgba(255, 255, 255, 0.92);
    padding: 12px 12px 14px;
  }
  [class*="slider-listingbox"] .lb_box_1 .attr-header .hide-attributes {
    display: none !important;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_title {
    margin-bottom: 8px;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row.quick_buy_size {
    flex-wrap: wrap;
    gap: 3px 2px;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row .size_option_form,
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row #form-disabled {
    width: 40px;
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_row .size_option {
    display: block !important;
    width: 100%;
    padding: 4px 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .lb_attributes_item:hover,
  [class*="slider-listingbox"] .lb_box_1 button.size_option.lb_attributes_item:hover,
  [class*="slider-listingbox"] .lb_box_1 button.size_option.lb_attributes_item:hover .lb_attributes_item {
    background: transparent !important;
    color: #111 !important;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
}


/* ---------------------------------------------------------------------
   5) Mobiles Bottom-Sheet (<=769px): X klar getrennt + feine Zellen,
      Umbruch fuer beliebig viele Groessen (z.B. 12)
   --------------------------------------------------------------------- */
@media screen and (max-width: 769px) {

  [class*="slider-listingbox"] .lb_box_1 .lb_attributes.active_attribute {
    border-radius: 16px 16px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.08);
  }

  /* Sheet-Kopf: X bekommt feste Breite rechts, Label zentriert & frei */
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .attr-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 14px 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .lb_attributes_title {
    flex: 1 1 auto;
    text-align: center;
    padding-left: 24px;   /* gleicht die X-Breite rechts aus -> echt mittig */
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .hide-attributes {
    flex: 0 0 16px;
    order: 2;
    padding: 0 !important;
    text-align: center;
  }

  /* Groessen: zentrierte, randlose Zellen mit Umbruch */
  [class*="slider-listingbox"] .lb_box_1 .active_attribute span.quick_buy_size {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 6px 10px;
    margin-top: 14px;
    padding: 0 14px 18px;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute form.size_option_form,
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button#form-disabled.size_option {
    width: 44px;
    border-bottom: none !important;
    margin: 0;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button#form-disabled.size_option,
  [class*="slider-listingbox"] .lb_box_1 .active_attribute button.size_option.lb_attributes_item:not(.hide-attributes) {
    display: block !important;
    width: 100%;
    text-align: center;
    padding: 10px 0 !important;
  }
  [class*="slider-listingbox"] .lb_box_1 .active_attribute .size_option_form:last-child {
    margin-bottom: 0;
  }
}


/* ---------------------------------------------------------------------
   6) Tag-Badges UNTEN LINKS (Option B) - kollidiert nicht mit Sale (oben)
      und nicht mit dem Herz (oben rechts). Beim Desktop-Groessen-Hover
      blenden sie aus, da das Overlay von unten aufgeht.
   --------------------------------------------------------------------- */
[class*="slider-listingbox"] .lb_box_1 .tags-images {
  top: auto !important;
  bottom: 12px !important;
  left: 10px !important;
  right: auto !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  transition: opacity 0.15s ease;
}
[class*="slider-listingbox"] .lb_box_1 .tags-images img.tag_image {
  width: 48px !important;
}
/* Desktop: beim Aufgehen des Groessen-Overlays Badges ausblenden */
@media (min-width: 770px) {
  [class*="slider-listingbox"] .lb_box_1:hover .tags-images,
  [class*="slider-listingbox"] .lb_box_1 .lb_image:hover .tags-images {
    opacity: 0;
    pointer-events: none;
  }
}
/* =====================================================================
   9) MOBIL: vollbreites Bottom-Sheet, Groessen EDITORIAL (Variante B)
      - position:fixed, volle Breite, von unten; z-index ueber Tags/Badges.
      - Greif-Leiste oben (::before), Safe-Area unten, kein Backdrop.
      - Groessen als reiner Text, zentriert, umbrechend (KEIN Kasten/Rahmen);
        aktive/gedrueckte Groesse fein unterstrichen, ausverkauft grau +
        durchgestrichen. Komfortable Tap-Flaeche via Padding (unsichtbar).
      - touch-action + Scroll-Lock-Hook (JS-Snippet in docs/) gegen Doppeltap.
      - Global gescoped (gilt auch fuer die an <body> geklonten Slider-Sheets).
   ===================================================================== */
@media screen and (max-width: 769px) {

  .lb_attributes.active_attribute {
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 80vh;
    overflow-y: auto;
    margin: 0 !important;
    z-index: 100000 !important;
    background: #fff;
    border-radius: 18px 18px 0 0;
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.12);
    padding-bottom: calc(18px + env(safe-area-inset-bottom, 0px)) !important;
  }

  /* Greif-Leiste oben */
  .lb_attributes.active_attribute::before {
    content: "";
    display: block;
    width: 38px;
    height: 4px;
    border-radius: 2px;
    background: #d9d9d9;
    margin: 10px auto 2px;
  }

  /* Groessen: editorial - reiner Text, zentriert, umbrechend */
  .lb_attributes.active_attribute .quick_buy_size {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 14px 22px !important;
    margin-top: 14px !important;
    padding: 0 16px 8px !important;
  }
  .lb_attributes.active_attribute .size_option_form,
  .lb_attributes.active_attribute form.size_option_form,
  .lb_attributes.active_attribute button#form-disabled.size_option {
    width: auto !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    border-bottom: none !important;
  }
  /* Zelle = reiner Text mit komfortabler Tap-Flaeche, kein Rahmen/Hintergrund */
  .lb_attributes.active_attribute button.size_option.lb_attributes_item:not(.hide-attributes),
  .lb_attributes.active_attribute button#form-disabled.size_option {
    display: inline-block !important;
    width: auto !important;
    text-align: center !important;
    font-size: 15px !important;
    line-height: 1 !important;
    padding: 6px 8px !important;
    border: none !important;
    border-radius: 0 !important;
    background: none !important;
  }
  /* aktive/gedrueckte Groesse: feiner Unterstrich */
  .lb_attributes.active_attribute button.size_option.lb_attributes_item:not(.hide-attributes):active,
  .lb_attributes.active_attribute button.size_option.lb_attributes_item.active,
  .lb_attributes.active_attribute button.size_option.lb_attributes_item.selected {
    border-bottom: 1.5px solid #111 !important;
    padding-bottom: 3px !important;
  }
  /* ausverkauft: dezent grau + durchgestrichen */
  .lb_attributes.active_attribute button#form-disabled.size_option {
    color: #bdbdbd !important;
    text-decoration: line-through !important;
  }

  /* Tap-Reaktion: iOS-Tap-Verzoegerung / Doppeltap-Zoom raus */
  .lb_attributes.active_attribute,
  .lb_attributes.active_attribute .size_option,
  .lb_attributes.active_attribute button.size_option,
  .lb_attributes.active_attribute .size_option_form {
    touch-action: manipulation;
  }
  .size_button { touch-action: manipulation; }

  /* Body-Scroll-Lock solange Sheet offen (Klasse setzt das JS-Snippet) */
  body.cg-sheet-open { overflow: hidden !important; }
}


/* =====================================================================
   10) MOBIL Wishlist-Sheet-Kopf: die wishlist.html hat KEINEN
       .attr-header-Wrapper (X + Titel sind direkte Kinder von
       .lb_attributes) -> Flex-Header greift dort nicht und Titel/X
       ueberlappen. Fix CSS-only & nur fuer .cg_wishlist: X absolut oben
       rechts, Titel zentriert mit Seitenabstand. Kein Template-Eingriff.
   ===================================================================== */
@media screen and (max-width: 769px) {

  .cg_wishlist .lb_attributes.active_attribute .hide-attributes {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: 22px !important;
    height: 22px !important;
    min-width: 0 !important;
    flex: none !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: none !important;
    font-size: 15px !important;
    line-height: 22px !important;
    text-align: center !important;
    z-index: 2 !important;
  }
  .cg_wishlist .lb_attributes.active_attribute .lb_attributes_title {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    padding: 4px 44px 0 !important;
    margin: 0 !important;
  }
}


/* =====================================================================
   8/11/12) Merkzettel (wishlist.html, .cg_wishlist) — KONSOLIDIERT v4.0.30
   ---------------------------------------------------------------------
   Ab v4.0.30 liegen X (.lb_delete) und Bag-Trigger (.size_button) IM
   .lb_image (Markup-Move in wishlist.html) — exakt wie Herz + Bag im
   Listing. Das Basis-CSS positioniert beide dadurch automatisch:
   .lb_image ist position:relative (festes Seitenverhaeltnis), .lb_delete
   und .size_button sind position:absolute. Hier nur noch Feinjustage:
     - X exakt auf die Listing-Herz-Position (top:10px / right:10px)
     - X-Glyph: feines delete-x.svg statt FA-Trash
     - Bag: Basis-Gelb weg, Text "Groesse hinzufuegen" ausblenden, bag.svg
   Die alten content-verankerten Hacks (lb_content position-Tweaks) sind
   entfallen. Dieser Block steht bewusst am Dateiende (gewinnt Source-Order
   gegen den transparenten Bag aus Block 3).
   ===================================================================== */

/* X (.lb_delete): oben rechts ueber dem Bild, exakt wie das Listing-Herz */
.cg_wishlist .lb_box_1 .lb_delete {
  top: 10px !important;
  right: 10px !important;
  left: auto !important;
  bottom: auto !important;
  width: 30px !important;
  height: 30px !important;
  z-index: 999 !important;
}
.cg_wishlist .lb_box_1 .lb_delete .cssButton { padding: 0 !important; min-height: 0 !important; }
.cg_wishlist .lb_box_1 .lb_delete .cssButton .cssIconLeft i,
.cg_wishlist .lb_box_1 .lb_delete .cssButton [class*="trash"] { display: none !important; }
.cg_wishlist .lb_box_1 .lb_delete .cssButton .cssIconLeft {
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url("../img/icons/delete-x.svg") center / contain no-repeat;
}
.cg_wishlist .lb_box_1 .lb_delete a,
.cg_wishlist .lb_box_1 .lb_delete .cssButton { opacity: 0.55; transition: opacity 0.15s ease; }
.cg_wishlist .lb_box_1 .lb_delete a:hover,
.cg_wishlist .lb_box_1 .lb_delete .cssButton:hover { opacity: 1; text-decoration: none; }

/* Bag (.size_button): Position kommt vom Basis-CSS (unten rechts im .lb_image).
   Hier nur Optik: Basis-Gelb weg, Text raus, bag.svg als Glyph (21px). */
.cg_wishlist .lb_box_1 .size_button,
.cg_wishlist .lb_box_1 .size_button:hover,
.cg_wishlist .lb_box_1 .size_button:focus,
.cg_wishlist .lb_box_1 .size_button:active {
  background: url("../img/icons/bag.svg") center / 21px 21px no-repeat !important;
  border: 0 !important;
  box-shadow: none !important;
}
.cg_wishlist .lb_box_1 .size_button .cssButton,
.cg_wishlist .lb_box_1 .size_button span,
.cg_wishlist .lb_box_1 .size_button .cssButtonColor1 {
  font-size: 0 !important;
  line-height: 0 !important;
  background: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: transparent !important;
}




/* MANUELL: Block ans Ende von templates/pureistic_4000/css/custom.css anhaengen.
   custom.css NICHT ersetzen. Danach templates_c leeren. */

/* === PDP BASE === */
.pdp_v2.pdp_base .layout_content_inner { padding-left: 16px; padding-right: 16px; }
@media (min-width: 780px) {
  .pdp_v2.pdp_base .layout_content_inner { padding-left: 32px; padding-right: 32px; }
}

@media (min-width: 780px) {
  .pdp_v2.pdp_base .pd_image_zoomer_gallery_item { width: 50%; }
  .pdp_v2.pdp_base .pd_flexcontent_small { max-width: 460px; }
}
.pdp_v2.pdp_base .pd_flexcontent_sticky { top: 80px; }

.pdp_v2.pdp_base .pd_catname a {
  font-size: 1.15rem; letter-spacing: 0.12em; text-transform: uppercase; color: #9a9a9a; border: 0;
}
.pdp_v2.pdp_base .pd_title {
  font-size: 1.8rem; line-height: 2.4rem; font-weight: 400; letter-spacing: -0.01em; padding: 10px 0 0;
}
.pdp_v2.pdp_base .pdp_v2_subtitle { font-size: 1.25rem; line-height: 1.8rem; color: #6b6b6b; margin-top: 8px; }
.pdp_v2.pdp_base .pd_pricebox { margin-top: 18px; }
.pdp_v2.pdp_base .pd_price { font-size: 1.8rem; }

.pdp_v2.pdp_base .pdp_v2_model_info { margin-top: 18px; }
.pdp_v2.pdp_base .pd_colorrow { margin-top: 24px; }
.pdp_v2.pdp_base .addtobasket_outer { margin-top: 22px; }
.pdp_v2.pdp_base .pdp_v2_benefits { margin-top: 24px; }
.pdp_v2.pdp_base .pdp_v2_accordion { margin-top: 28px; }
.pdp_v2.pdp_base .pdp_v2_badges { margin-top: 22px; }
.pdp_v2.pdp_base .pdp_v2_xsell_section { margin-top: 56px; }

.pdp_v2.pdp_base .pdp_v2_acc_title { font-size: 1.35rem; letter-spacing: 0.02em; }
.pdp_v2.pdp_base .pdp_v2_eyebrow { font-size: 1.5rem; letter-spacing: 0.04em; }

.pdp_v2.pdp_base .pdp_v2_badges { display: flex; flex-wrap: wrap; gap: 8px; }
.pdp_v2.pdp_base .pdp_v2_badge {
  font-size: 1.0rem; line-height: 1.4rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: #666; border: 0.5px solid #ddd; padding: 6px 12px;
}
.pdp_v2.pdp_base .pdp_v2_badge_eco { color: #000; }

.pdp_v2.pdp_base .pdp_v2_xsell_products .pseudo_h1 {
  font-size: 1.5rem; margin-top: 52px !important; margin-bottom: 18px !important;
}

/* Cross-Sell-Bilder: gilt fuer ALLE PDP-Carousels (Koennte dir gefallen,
   Kategorie, Style, Saison) — nicht nur sp_pdp_xsell. Verhindert dass die
   Bildflaeche auf Hoehe 0 kollabiert (deaktivierter ::before-Platzhalter). */
.pdp_v2 .sp_pdp_xsell .lb_image,
.pdp_v2 .slider-listingbox-details .lb_image {
  position: relative !important; aspect-ratio: 3 / 4; height: auto !important; overflow: hidden;
}
.pdp_v2 .sp_pdp_xsell .lb_image::before,
.pdp_v2 .slider-listingbox-details .lb_image::before { display: none !important; padding-top: 0 !important; }
.pdp_v2 .sp_pdp_xsell .lb_image > a,
.pdp_v2 .slider-listingbox-details .lb_image > a { display: block; position: absolute; inset: 0; }
.pdp_v2 .sp_pdp_xsell .lb_image img,
.pdp_v2 .slider-listingbox-details .lb_image img {
  position: absolute !important; inset: 0 !important; width: 100% !important; height: 100% !important; object-fit: cover !important;
}
/* === PDP BASE END === */


/* === PDP DATASHEET === */
@media (min-width: 780px) {
  .pdp_v2.pdp_datasheet .pd_image_zoomer_gallery_item:nth-child(3n) { width: 100%; }
}
.pdp_v2.pdp_datasheet .pdp_v2_sg_desc {
  margin-top: 22px; font-size: 1.3rem; line-height: 2.05rem; color: #3f3f3f;
}
.pdp_v2.pdp_datasheet .pdp_v2_sg_desc p { margin: 0 0 8px; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_artno { font-size: 1.1rem; color: #9a9a9a; margin-top: 12px; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_grid { margin-top: 28px; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_h {
  font-size: 1.35rem; letter-spacing: 0.02em; color: #1a1a1a; margin-bottom: 10px;
}
.pdp_v2.pdp_datasheet .pdp_v2_sg_row {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 12px; padding: 13px 0; border-bottom: 1px solid #efeeec;
}
.pdp_v2.pdp_datasheet .pdp_v2_sg_k {
  font-size: 1.15rem; letter-spacing: 0.05em; text-transform: uppercase; color: #9a9a9a;
}
.pdp_v2.pdp_datasheet .pdp_v2_sg_v { font-size: 1.3rem; color: #1a1a1a; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_v ul { list-style: none; margin: 0; padding: 0; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_v li { display: inline; }
.pdp_v2.pdp_datasheet .pdp_v2_sg_v li:not(:last-child)::after { content: ", "; }
/* === PDP DATASHEET END === */

/* === PDP MINIMAL === */
@media (min-width: 780px) {
  .pdp_v2.pdp_minimal .pd_image_zoomer_gallery_item { width: 100%; }
  .pdp_v2.pdp_minimal .pd_flexcontent_small { max-width: 380px; }
}
.pdp_v2.pdp_minimal .pd_flexcontent_sticky { top: 90px; }
.pdp_v2.pdp_minimal .layout_content_inner { padding-top: 20px; }

.pdp_v2.pdp_minimal .pdp_v2_min_head { display: block; }
.pdp_v2.pdp_minimal .pdp_v2_min_head .pd_title {
  font-size: 1.9rem; line-height: 2.6rem; font-weight: 500; padding: 0; margin: 0 0 14px;
}
.pdp_v2.pdp_minimal .pdp_v2_min_head .pd_pricebox { margin: 0; }
.pdp_v2.pdp_minimal .pdp_v2_min_head .pd_price { font-size: 1.6rem; font-weight: 500; padding: 0; }
.pdp_v2.pdp_minimal .pdp_v2_min_head .pd_tax { font-size: 1.0rem; color: #b0b0b0; margin-top: 4px; }
.pdp_v2.pdp_minimal .pdp_v2_min_comp { font-size: 1.2rem; line-height: 1.7rem; color: #8a8a8a; margin-top: 12px; }
.pdp_v2.pdp_minimal .pdp_v2_accordion { margin-top: 24px; }
/* === PDP MINIMAL END === */

/* === PDP CAROUSEL === */
.pdp_v2.pdp_carousel .pdp_car { display: flex; gap: 14px; }
.pdp_v2.pdp_carousel .pdp_car_rail {
  display: flex; flex-direction: column; gap: 12px; flex: none; width: 72px;
  max-height: 84vh; overflow-y: auto;
}
.pdp_v2.pdp_carousel .pdp_car_thumb {
  width: 72px; height: 96px; padding: 0; flex: none; background: #f2f0ec;
  border: 1px solid transparent; cursor: pointer; overflow: hidden;
}
.pdp_v2.pdp_carousel .pdp_car_thumb.is-active { border-color: #111; }
.pdp_v2.pdp_carousel .pdp_car_thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp_v2.pdp_carousel .pdp_car_stage {
  position: relative; flex: 1; aspect-ratio: 3 / 4; background: #f2f0ec; overflow: hidden;
}
.pdp_v2.pdp_carousel .pdp_car_frame { position: absolute; inset: 0; opacity: 0; transition: opacity .25s; }
.pdp_v2.pdp_carousel .pdp_car_frame.is-active { opacity: 1; }
.pdp_v2.pdp_carousel .pdp_car_frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp_v2.pdp_carousel .pdp_car_arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
  width: 40px; height: 40px; background: rgba(255,255,255,0.85); border: 0; cursor: pointer;
  font-size: 18px; color: #111; opacity: 0; transition: opacity .15s; line-height: 1;
}
.pdp_v2.pdp_carousel .pdp_car_stage:hover .pdp_car_arrow { opacity: 1; }
.pdp_v2.pdp_carousel .pdp_car_arrow.prev { left: 12px; }
.pdp_v2.pdp_carousel .pdp_car_arrow.next { right: 12px; }
@media (max-width: 779px) {
  .pdp_v2.pdp_carousel .pdp_car { flex-direction: column-reverse; }
  .pdp_v2.pdp_carousel .pdp_car_rail { flex-direction: row; width: auto; max-height: none; overflow-x: auto; }
}
/* === PDP CAROUSEL END === */

/* === PDP LOOKBOOK === */
@media (min-width: 780px) {
  .pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item { width: 50%; }
  .pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item:first-child { width: 100%; }
  .pdp_v2.pdp_lookbook .pd_flexcontent_small { max-width: 420px; }
}
.pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item { aspect-ratio: 3 / 4; overflow: hidden; }
.pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item picture,
.pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item picture img,
.pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item > img,
.pdp_v2.pdp_lookbook .pd_image_zoomer_gallery_item video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.pdp_v2.pdp_lookbook .pdp_lb_databand {
  width: 100% !important; aspect-ratio: auto !important; overflow: visible;
  display: flex; gap: 48px; align-items: flex-start;
  background: #fff; border-top: 1px solid #ececec; border-bottom: 1px solid #ececec; padding: 48px 8px;
}
.pdp_v2.pdp_lookbook .pdp_lb_mini { width: 36%; flex: none; aspect-ratio: 3 / 4; overflow: hidden; }
.pdp_v2.pdp_lookbook .pdp_lb_mini img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pdp_v2.pdp_lookbook .pdp_lb_info { flex: 1; }
.pdp_v2.pdp_lookbook .pdp_lb_h { font-size: 1.9rem; font-weight: 400; letter-spacing: -0.01em; margin: 10px 0 16px; }
.pdp_v2.pdp_lookbook .pdp_lb_desc { font-size: 1.3rem; line-height: 2.0rem; color: #444; margin: 0 0 22px; max-width: 52ch; }
.pdp_v2.pdp_lookbook .pdp_lb_dl { display: grid; grid-template-columns: auto 1fr; gap: 14px 28px; max-width: 420px; }
.pdp_v2.pdp_lookbook .pdp_lb_dl dt { font-size: 1.05rem; letter-spacing: 0.05em; text-transform: uppercase; color: #9a9a9a; align-self: center; }
.pdp_v2.pdp_lookbook .pdp_lb_dl dd { font-size: 1.3rem; color: #1a1a1a; }
@media (max-width: 779px) {
  .pdp_v2.pdp_lookbook .pdp_lb_databand { flex-direction: column; gap: 20px; padding: 24px; }
  .pdp_v2.pdp_lookbook .pdp_lb_mini { width: 60%; }
}
/* === PDP LOOKBOOK END === */










/* === PDP STICKY START ==================================================== */

/* ---------- MOBILE (< 780px): kompakter Kopf, kuerzere Bilder, mehr Peek ---------- */
@media (max-width: 779px) {
  .pdp_v2.pdp_sticky { padding-bottom: 76px; }
  .pdp_v2.pdp_sticky .pdp_sticky_nav { display: none; }

  .pdp_v2.pdp_sticky #pd_image_zoomer_single { display: none !important; }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery {
    display: flex !important; flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden;
    scroll-snap-type: x mandatory; gap: 3px; -webkit-overflow-scrolling: touch;
    scrollbar-width: none;                       /* native aus, eigener Balken unten */
    margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw);
    padding-bottom: 0;
  }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery::-webkit-scrollbar { display: none; }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .pd_image_zoomer_gallery_item {
    flex: 0 0 78% !important; width: 78% !important; scroll-snap-align: start;   /* kuerzer + mehr Peek */
    aspect-ratio: 3 / 4; overflow: hidden; margin: 0;
  }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .pd_image_zoomer_gallery_item picture,
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .pd_image_zoomer_gallery_item picture img,
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .pd_image_zoomer_gallery_item > img,
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .pd_image_zoomer_gallery_item video {
    width: 100% !important; height: 100% !important; object-fit: cover; display: block;
  }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .tags-images { display: none !important; }

  .pdp_v2.pdp_sticky .pdp_sticky_bar { display: block; position: relative; height: 2px; margin: 0 16px 4px; background: #d8d8d8; border-radius: 2px; }
  .pdp_v2.pdp_sticky .pdp_sticky_thumb { position: absolute; top: 0; left: 0; height: 2px; min-width: 16%; background: #111; border-radius: 2px; }

  /* Kompakter Kopf: Name hoch, Preis klein, Farbe klein */
  .pdp_v2.pdp_sticky .pd_flexcontent_sticky { padding-top: 0; }
  .pdp_v2.pdp_sticky .pd_catname { margin-bottom: 1px; }
  .pdp_v2.pdp_sticky .pd_title { font-size: 1.8rem; line-height: 1.2; margin: 1px 0 0; }
  .pdp_v2.pdp_sticky .pdp_v2_subtitle { font-size: 1.15rem; margin-top: 4px; }
  .pdp_v2.pdp_sticky .pd_pricebox { margin-top: 6px; }
  .pdp_v2.pdp_sticky .pd_price { font-size: 1.5rem; }
  .pdp_v2.pdp_sticky .pd_tax { font-size: 1.05rem; }
  .pdp_v2.pdp_sticky .pd_colorrow { margin-top: 14px; transform: scale(.92); transform-origin: left center; }
}

/* ---------- DESKTOP (>= 780px): Grid; Beschreibung unter Bildern; Buy-Box klebt ---------- */
@media (min-width: 780px) {
  .pdp_v2.pdp_sticky .pdp_sticky_bar { display: none; }

  .pdp_v2.pdp_sticky .pd_flexrow {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 380px !important;
    gap: clamp(24px, 3vw, 48px); align-items: start;
  }
  /* Theme-Breiten der Spalten zuruecksetzen, sonst staucht es die Buy-Box */
  .pdp_v2.pdp_sticky .pd_fleximage_big,
  .pdp_v2.pdp_sticky .pd_flexcontent_small,
  .pdp_v2.pdp_sticky .pdp_sticky_details {
    width: auto !important; max-width: none !important; min-width: 0 !important; flex: none !important; float: none !important;
  }
  .pdp_v2.pdp_sticky .pd_fleximage_big { grid-column: 1; grid-row: 1; position: relative; }
  .pdp_v2.pdp_sticky .pd_flexcontent_small { grid-column: 2; grid-row: 1 / span 2; }
  .pdp_v2.pdp_sticky .pdp_sticky_details { grid-column: 1; grid-row: 2; max-width: 820px; margin-top: 8px; }
  .pdp_v2.pdp_sticky .pd_flexcontent_sticky { position: sticky; top: 24px; }

  /* horizontale Scroll-Galerie: 2 Bilder + 3. angeschnitten, Scrollbalken sichtbar */
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery {
    display: flex; flex-wrap: nowrap; gap: 4px;
    overflow-x: auto; overflow-y: hidden; scroll-snap-type: x mandatory;
    padding-bottom: 8px; min-width: 0;
  }
  .pdp_v2.pdp_sticky #pd_image_zoomer_gallery .tags-images { display: none; }
  .pdp_v2.pdp_sticky .pd_image_zoomer_gallery_item {
    flex: 0 0 47% !important; width: 47% !important; scroll-snap-align: start;
    aspect-ratio: 3 / 4; overflow: hidden;
  }
  .pdp_v2.pdp_sticky .pd_image_zoomer_gallery_item picture,
  .pdp_v2.pdp_sticky .pd_image_zoomer_gallery_item picture img,
  .pdp_v2.pdp_sticky .pd_image_zoomer_gallery_item > img,
  .pdp_v2.pdp_sticky .pd_image_zoomer_gallery_item video {
    width: 100%; height: 100%; object-fit: cover; display: block;
  }

  .pdp_v2.pdp_sticky .pdp_sticky_nav {
    display: flex; align-items: center; justify-content: center;
    position: absolute; top: 50%; transform: translateY(-50%); z-index: 4;
    width: 40px; height: 56px; padding: 0; border: 0; border-radius: 0;
    background: transparent; color: #1a1a1a; cursor: pointer;
    font-size: 34px; line-height: 1; box-shadow: none; opacity: .75;
    text-shadow: 0 0 8px rgba(255,255,255,.95), 0 0 2px rgba(255,255,255,.95);
    transition: opacity .15s ease;
  }
  .pdp_v2.pdp_sticky .pdp_sticky_nav:hover { opacity: 1; }
  .pdp_v2.pdp_sticky .pdp_sticky_nav.prev { left: 12px; }
  .pdp_v2.pdp_sticky .pdp_sticky_nav.next { right: 12px; }
}

/* ---------- Sticky-Leiste (mobil): Button = exakt der Warenkorb-Button ---------- */
.pdp_v2.pdp_sticky .pdp_sticky_cta_mobile {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 999;
  background: #fff; border-top: 1px solid #e6e6e6; box-shadow: 0 -2px 12px rgba(0,0,0,.08);
  padding: 10px 16px; transition: transform .25s ease;
}
.pdp_v2.pdp_sticky .pdp_sticky_cta_mobile.is-hidden { transform: translateY(110%); }
.pdp_v2.pdp_sticky .pdp_sticky_cta_mobile .addtobasket { display: flex; justify-content: center; align-items: center; margin: 0; }
.pdp_v2.pdp_sticky .pdp_sticky_cta_mobile .addtobasket_cart { display: inline-block; }
@media (min-width: 780px) { .pdp_v2.pdp_sticky .pdp_sticky_cta_mobile { display: none; } }
/* === PDP STICKY END ====================================================== */








/* ============================================================================
   STYLEPOT — footer_variants.css
   Entkoppeltes Modell:  STRUKTUR  x  THEME  x  MOBIL
   Wrapper (aus index.html):
     .footer_variants .footer_struct_{classic|editorial|hero|refined|pro}
                      .footer_theme_{black|white}
                      .footer_m_{accordion|open}
   - THEME setzt ausschliesslich CSS-Variablen (Farbe).
   - STRUKTUR macht ausschliesslich Layout und nutzt diese Variablen.
   - MOBIL steuert nur das Spaltenverhalten unter 768px.
   An css/custom.css anhaengen ODER per <link> nach stylesheet.css laden.
   ========================================================================== */

/* ---------- THEME-TOKENS ---------- */
.footer_variants{
  --accent:#2DD4BF;                 /* Footer-Brandakzent (Tuerkis). Fuer Rot: #E0115F */
  font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--fg);
}
.footer_variants.footer_theme_black{
  --bg:#000; --fg:#fff; --muted:rgba(255,255,255,.62); --line:rgba(255,255,255,.15);
  --field:rgba(255,255,255,.4); --btn-bg:#fff; --btn-fg:#000; --outline:rgba(255,255,255,.7);
  --panel:#0d0d0d; --panel-border:rgba(255,255,255,.1); --logo-filter:invert(1);
}
.footer_variants.footer_theme_white{
  --bg:#fff; --fg:#16161a; --muted:rgba(0,0,0,.55); --line:rgba(0,0,0,.15);
  --field:rgba(0,0,0,.4); --btn-bg:#111; --btn-fg:#fff; --outline:rgba(0,0,0,.7);
  --panel:#f4f2ee; --panel-border:rgba(0,0,0,.08); --logo-filter:none;
}

/* ---------- BASIS (theme-agnostisch, Farbe via var) ---------- */
.footer_variants *,.footer_variants *::before,.footer_variants *::after{box-sizing:border-box}
.footer_variants a{color:inherit;text-decoration:none}

/* Spalten (Ueber uns / Service / Informationen) */
.footer_variants .footer_cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:36px}
.footer_variants .footer_col .box_content,
.footer_variants .footer_col .box_information{margin:0}
.footer_variants .box_content_heading{
  font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.13em;
  color:var(--fg);margin:0 0 18px;display:flex;align-items:center;justify-content:space-between;
}
.footer_variants .footerlist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.footer_variants .footerlist li{margin:0}
.footer_variants .footerlist li a{font-size:14px;color:var(--muted);transition:color .15s}
.footer_variants .footerlist li a:hover{color:var(--fg)}

/* Newsletter */
.footer_variants .box_newsletter_heading{
  font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin:0 0 14px;
}
.footer_variants .box_newsletter_form{display:flex;align-items:stretch;border:1px solid var(--field)}
.footer_variants .box_newsletter_input{flex:1;min-width:0;display:flex}
.footer_variants .box_newsletter_input input{
  width:100%;background:transparent;border:0;outline:none;color:var(--fg);
  font-family:inherit;font-size:15px;padding:16px 18px;
}
.footer_variants .box_newsletter_input input::placeholder{color:var(--muted)}
.footer_variants .box_newsletter_button button,
.footer_variants .box_newsletter_button input{
  height:100%;background:var(--btn-bg);border:0;color:var(--btn-fg);
  font-family:inherit;font-weight:700;font-size:14px;padding:0 22px;cursor:pointer;white-space:nowrap;
}
.footer_variants .box_newsletter_disclaimer{font-size:12.5px;color:var(--muted);margin-top:11px;line-height:1.5}

/* Logo — Legacy-Regeln neutralisieren (border-block + Doppel-Invert) */
.footer_variants .footer_logo_big{border-block:0;border:0;text-align:center;width:auto}
.footer_variants .footer_logo_big a{display:inline-block;line-height:0}
.footer_variants .footer_logo_big img{filter:var(--logo-filter);width:auto;height:clamp(34px,5vw,56px)}

/* Bottom-Row (Social + Payment) */
.footer_variants .footer_bottom_row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  border-top:1px solid var(--line);padding:24px 0;
}
.footer_variants .footer_social{display:flex;align-items:center;gap:16px}
.footer_variants .footer_social a{color:var(--fg);font-size:19px;opacity:.9;line-height:1}
.footer_variants .footer_social a:hover{opacity:1}
.footer_variants .footer_payment{display:flex;align-items:center;gap:10px}
.footer_variants .footer_payment img{height:24px;width:auto;display:block}

/* Copyright */
.footer_variants .copyright_note{
  text-align:center;color:var(--muted);font-size:12.5px;padding:20px 0 40px;border:0;display:block;
}

/* ============================================================================
   STRUKTUR: classic — Newsletter links, Spalten rechts, Logo, Bar
   ========================================================================== */
.footer_struct_classic .footer_inner{
  display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);gap:72px;
  max-width:1320px;margin:0 auto;padding:64px 56px 0;
}
.footer_struct_classic .footer_cs{grid-column:1/-1}
.footer_struct_classic .footer_news{grid-column:1}
.footer_struct_classic .footer_cols{grid-column:2}
.footer_struct_classic .footer_logo_big{grid-column:1/-1;margin:72px 0 36px}
.footer_struct_classic .footer_logo_big img{height:clamp(34px,5vw,60px)}
.footer_struct_classic .footer_bottom_row,
.footer_struct_classic .copyright_note{grid-column:1/-1}

/* ============================================================================
   STRUKTUR: editorial — Newsletter-Inline-Zeile oben, Versalien, viel Luft
   ========================================================================== */
.footer_struct_editorial .footer_inner{max-width:1320px;margin:0 auto;padding:56px 56px 0}
.footer_struct_editorial .footer_news{border-bottom:1px solid var(--line);padding-bottom:36px;margin-bottom:56px}
.footer_struct_editorial .box_newsletter{display:grid;grid-template-columns:1fr minmax(0,500px);gap:36px;align-items:center}
.footer_struct_editorial .box_newsletter_heading{
  text-transform:none;letter-spacing:-.01em;font-size:21px;color:var(--fg);margin:0;align-self:center;
}
.footer_struct_editorial .box_newsletter_form{border:0;border-bottom:1.5px solid var(--fg)}
.footer_struct_editorial .box_newsletter_input input{padding:13px 2px}
.footer_struct_editorial .box_newsletter_button button,
.footer_struct_editorial .box_newsletter_button input{background:transparent;color:var(--fg);padding:0 4px}
.footer_struct_editorial .box_newsletter_disclaimer{display:none}
.footer_struct_editorial .footer_logo_big{margin:56px 0 36px}
.footer_struct_editorial .footer_logo_big img{height:clamp(30px,4vw,50px)}

/* ============================================================================
   STRUKTUR: hero — zentriert, grosses Logo als Abschluss
   ========================================================================== */
.footer_struct_hero .footer_inner{max-width:1320px;margin:0 auto;padding:56px 56px 0;text-align:center}
.footer_struct_hero .footer_news{max-width:480px;margin:0 auto 36px}
.footer_struct_hero .box_newsletter_button button,
.footer_struct_hero .box_newsletter_button input{background:var(--accent);color:#000}
.footer_struct_hero .footer_cols{max-width:880px;margin:36px auto 0;text-align:left;border-top:1px solid var(--line);padding-top:36px}
.footer_struct_hero .footer_logo_big{margin:36px 0 48px}
.footer_struct_hero .footer_logo_big img{height:clamp(54px,9vw,120px)}
.footer_struct_hero .footer_bottom_row{justify-content:center;flex-wrap:wrap;gap:32px}

/* ============================================================================
   STRUKTUR: refined — Label + Unterstrich-Input, Haarlinien-Rhythmus
   ========================================================================== */
.footer_struct_refined .footer_inner{max-width:1320px;margin:0 auto;padding:64px 56px 0}
.footer_struct_refined .footer_news{margin-bottom:72px}
.footer_struct_refined .box_newsletter_heading{color:var(--fg);opacity:.85;letter-spacing:.16em;margin-bottom:24px}
.footer_struct_refined .box_newsletter_form{border:0;align-items:flex-end;gap:24px;max-width:760px}
.footer_struct_refined .box_newsletter_input input{border-bottom:1px solid var(--field);padding:14px 0;font-size:16px}
.footer_struct_refined .box_newsletter_button button,
.footer_struct_refined .box_newsletter_button input{
  border:1px solid var(--outline);background:transparent;color:var(--fg);
  text-transform:uppercase;letter-spacing:.14em;font-size:12px;padding:16px 30px;transition:background .2s,color .2s;
}
.footer_struct_refined .box_newsletter_button button:hover,
.footer_struct_refined .box_newsletter_button input:hover{background:var(--fg);color:var(--bg)}
.footer_struct_refined .box_newsletter_disclaimer{display:none}
.footer_struct_refined .box_content_heading{opacity:.85;letter-spacing:.16em}
.footer_struct_refined .footerlist li a{font-size:15px}
.footer_struct_refined .footer_logo_big{border-top:1px solid var(--line);margin-top:56px;padding:48px 0}
.footer_struct_refined .footer_logo_big img{height:clamp(38px,4.5vw,52px)}

/* ============================================================================
   STRUKTUR: pro — USP-Leiste + Incentive-CTA + Spalten (Conversion)
   ========================================================================== */
.footer_struct_pro .footer_usp{
  display:flex;justify-content:space-between;gap:24px;
  max-width:1320px;margin:0 auto;padding:20px 56px;border-bottom:1px solid var(--line);
}
.footer_struct_pro .footer_usp .usp{display:flex;align-items:center;gap:12px;flex:1}
.footer_struct_pro .footer_usp .usp svg{width:26px;height:26px;color:var(--fg);flex:none}
.footer_struct_pro .footer_usp .usp b{display:block;font-size:13.5px;font-weight:700}
.footer_struct_pro .footer_usp .usp span{display:block;font-size:12px;color:var(--muted)}
.footer_struct_pro .footer_inner{max-width:1320px;margin:0 auto;padding:56px 56px 0}
.footer_struct_pro .footer_news{
  display:grid;grid-template-columns:1fr minmax(0,420px);gap:56px;align-items:center;
  background:var(--panel);border:1px solid var(--panel-border);padding:36px;margin-bottom:56px;
}
.footer_struct_pro .footer_cta_meta .cta_eyebrow{margin:0 0 8px;font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-weight:700}
.footer_struct_pro .footer_cta_meta .cta_head{margin:0;font-size:clamp(22px,3vw,31px);font-weight:800;letter-spacing:-.02em;line-height:1.06;color:var(--fg)}
.footer_struct_pro .box_newsletter_heading{display:none}
.footer_struct_pro .box_newsletter_form{background:var(--bg);border:1px solid var(--field)}
.footer_struct_pro .box_newsletter_button button,
.footer_struct_pro .box_newsletter_button input{background:#111;color:#fff;font-size:15px;padding:0 26px}
.footer_variants.footer_theme_black.footer_struct_pro .box_newsletter_button button,
.footer_variants.footer_theme_black.footer_struct_pro .box_newsletter_button input{background:var(--accent);color:#000}
.footer_struct_pro .box_newsletter_disclaimer{display:none}
.footer_struct_pro .footer_logo_big{margin:56px 0 22px}
.footer_struct_pro .footer_logo_big img{height:clamp(40px,6vw,72px)}

/* Akkordion-Plus/Minus standardmaessig versteckt (nur mobil sichtbar) */
.footer_variants .box_content_heading::after{content:none}

/* ============================================================================
   MOBIL (< 768px)
   ========================================================================== */
@media (max-width:768px){
  /* Grundlayout: alles stapelt, Spalten IMMER untereinander (egal 2/3/4) */
  .footer_variants .footer_inner{display:block!important;padding:0!important;text-align:left!important;max-width:none!important}
  .footer_variants .footer_usp{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:22px 20px}
  .footer_variants .footer_news{
    padding:26px 20px!important;margin:0!important;max-width:none!important;
    display:block!important;grid-template-columns:none!important;border:0!important;background:transparent!important;
  }
  .footer_variants .box_newsletter{display:block!important;grid-template-columns:none!important}
  .footer_variants .footer_cols{display:block!important;grid-template-columns:none!important;margin:0!important;border:0!important;padding:0!important;max-width:none!important}
  /* Newsletter-Eingaben mobil immer gestapelt */
  .footer_variants .box_newsletter_form{flex-direction:column!important;align-items:stretch!important;gap:12px!important;border:0!important;max-width:none!important}
  .footer_variants .box_newsletter_input input{border:1px solid var(--field)!important;padding:16px!important}
  .footer_variants .box_newsletter_button button,
  .footer_variants .box_newsletter_button input{width:100%!important;padding:16px!important;font-size:16px!important;border:1px solid var(--field)!important}
  .footer_variants .footer_logo_big{margin:48px 0!important;padding:0!important;border:0!important}
  .footer_variants .footer_bottom_row{flex-direction:column;gap:22px;padding:30px 20px}
  .footer_variants .copyright_note{padding:24px 20px 40px!important;text-align:center!important}
  .footer_struct_hero .footer_news,
  .footer_struct_hero .box_content_heading,
  .footer_struct_hero .footerlist{text-align:center}

  /* ---- MOBIL-MODUS: accordion ---- */
  .footer_m_accordion .footer_col .box_content,
  .footer_m_accordion .footer_col .box_information{border-top:1px solid var(--line)}
  .footer_m_accordion .footer_col:last-child .box_content,
  .footer_m_accordion .footer_col:last-child .box_information{border-bottom:1px solid var(--line)}
  .footer_m_accordion .box_content_heading{
    padding:22px 20px;margin:0;cursor:pointer;font-size:15px;position:relative;
  }
  .footer_m_accordion .box_content_heading::after{
    content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);
    font-size:20px;font-weight:400;line-height:1;color:var(--muted);
  }
  .footer_m_accordion .box_content.is-open .box_content_heading::after,
  .footer_m_accordion .box_information.is-open .box_content_heading::after{content:"\2212"}
  .footer_m_accordion .footerlist{overflow:hidden;max-height:0;transition:max-height .3s ease;padding:0 20px}
  .footer_m_accordion .box_content.is-open .footerlist,
  .footer_m_accordion .box_information.is-open .footerlist{max-height:520px;padding-bottom:20px}

  /* ---- MOBIL-MODUS: open ---- */
  .footer_m_open .footer_col .box_content,
  .footer_m_open .footer_col .box_information{padding:24px 20px 0}
  .footer_m_open .footer_col:last-child .box_content,
  .footer_m_open .footer_col:last-child .box_information{padding-bottom:26px}
  .footer_m_open .box_content_heading{margin:0 0 14px;pointer-events:none}
  .footer_m_open .footerlist{padding:0}
}





