.elementor-556 .elementor-element.elementor-element-b8422e9{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-animated-headline .elementor-headline-plain-text{color:var( --e-global-color-secondary );}.elementor-widget-animated-headline .elementor-headline{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-animated-headline{--dynamic-text-color:var( --e-global-color-secondary );}.elementor-widget-animated-headline .elementor-headline-dynamic-text{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-animated-headline .elementor-headline-dynamic-wrapper path{stroke:var( --e-global-color-accent );}.elementor-556 .elementor-element.elementor-element-f0cb5f5{--animation-duration:1800ms;--dynamic-text-color:#345D77;}.elementor-556 .elementor-element.elementor-element-f0cb5f5 .elementor-headline{text-align:center;font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-f0cb5f5 .elementor-headline-plain-text{color:#54595F;}.elementor-556 .elementor-element.elementor-element-f0cb5f5 .elementor-headline-dynamic-text{font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-f0cb5f5 .elementor-headline .elementor-headline-dynamic-wrapper{-webkit-text-stroke-color:#000;stroke:#000;}.elementor-556 .elementor-element.elementor-element-f0cb5f5 .elementor-headline-dynamic-wrapper path{stroke:#345D77;}.elementor-556 .elementor-element.elementor-element-f98c8f0{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-556 .elementor-element.elementor-element-691f26a{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-556 .elementor-element.elementor-element-691f26a.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-556 .elementor-element.elementor-element-9e6f470{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-556 .elementor-element.elementor-element-9e6f470.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-556 .elementor-element.elementor-element-9058fcf{text-align:center;}.elementor-556 .elementor-element.elementor-element-b215299{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-556 .elementor-element.elementor-element-8099711{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-divider{--divider-color:var( --e-global-color-secondary );}.elementor-widget-divider .elementor-divider__text{color:var( --e-global-color-secondary );font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-divider.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-secondary );}.elementor-widget-divider.elementor-view-framed .elementor-icon, .elementor-widget-divider.elementor-view-default .elementor-icon{color:var( --e-global-color-secondary );border-color:var( --e-global-color-secondary );}.elementor-widget-divider.elementor-view-framed .elementor-icon, .elementor-widget-divider.elementor-view-default .elementor-icon svg{fill:var( --e-global-color-secondary );}.elementor-556 .elementor-element.elementor-element-52a7d0c{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-556 .elementor-element.elementor-element-52a7d0c .elementor-divider-separator{width:100%;}.elementor-556 .elementor-element.elementor-element-52a7d0c .elementor-divider{padding-block-start:15px;padding-block-end:15px;}.elementor-556 .elementor-element.elementor-element-cd15625{--animation-duration:1800ms;--dynamic-text-color:#345D77;}.elementor-556 .elementor-element.elementor-element-cd15625 .elementor-headline{text-align:center;font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-cd15625 .elementor-headline-plain-text{color:#54595F;}.elementor-556 .elementor-element.elementor-element-cd15625 .elementor-headline-dynamic-text{font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-cd15625 .elementor-headline .elementor-headline-dynamic-wrapper{-webkit-text-stroke-color:#000;stroke:#000;}.elementor-556 .elementor-element.elementor-element-cd15625 .elementor-headline-dynamic-wrapper path{stroke:#345D77;}.elementor-556 .elementor-element.elementor-element-1ea056d{--display:flex;}.elementor-556 .elementor-element.elementor-element-f10e6d1{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .woocommerce-loop-product__title{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .woocommerce-loop-category__title{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .woocommerce-loop-product__title, .elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .woocommerce-loop-category__title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price{color:var( --e-global-color-primary );font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price ins{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price ins .amount{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products{--products-title-color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.products-heading-show .related-products > h2, .elementor-widget-woocommerce-products.products-heading-show .upsells > h2, .elementor-widget-woocommerce-products.products-heading-show .cross-sells > h2{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price del{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price del .amount{color:var( --e-global-color-primary );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .price del {font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-woocommerce-products.elementor-wc-products ul.products li.product .button{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-woocommerce-products.elementor-wc-products .added_to_cart{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .woocommerce-loop-product__title{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .woocommerce-loop-category__title{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .price{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .price ins{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .price ins .amount{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .price del{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product .price del .amount{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products ul.products li.product span.onsale{display:block;}.elementor-556 .elementor-element.elementor-element-6339111{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-556 .elementor-element.elementor-element-cf61938{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-556 .elementor-element.elementor-element-cf61938 .elementor-divider-separator{width:100%;}.elementor-556 .elementor-element.elementor-element-cf61938 .elementor-divider{padding-block-start:15px;padding-block-end:15px;}.elementor-556 .elementor-element.elementor-element-f80d565{--animation-duration:1800ms;--dynamic-text-color:#345D77;}.elementor-556 .elementor-element.elementor-element-f80d565 .elementor-headline{text-align:center;font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-f80d565 .elementor-headline-plain-text{color:#54595F;}.elementor-556 .elementor-element.elementor-element-f80d565 .elementor-headline-dynamic-text{font-family:"Gochi Hand", Sans-serif;font-weight:600;}.elementor-556 .elementor-element.elementor-element-f80d565 .elementor-headline .elementor-headline-dynamic-wrapper{-webkit-text-stroke-color:#000;stroke:#000;}.elementor-556 .elementor-element.elementor-element-f80d565 .elementor-headline-dynamic-wrapper path{stroke:#345D77;}.elementor-556 .elementor-element.elementor-element-6f5bf15{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-wc-categories .woocommerce .woocommerce-loop-category__title{color:var( --e-global-color-primary );font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-widget-wc-categories .woocommerce-loop-category__title .count{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-556 .elementor-element.elementor-element-19602f7.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:30px;}.elementor-556 .elementor-element.elementor-element-19602f7 .woocommerce .woocommerce-loop-category__title{color:var( --e-global-color-d5b1335 );}.elementor-556 .elementor-element.elementor-element-19602f7 .woocommerce-loop-category__title .count{color:var( --e-global-color-d5b1335 );}@media(min-width:768px){.elementor-556 .elementor-element.elementor-element-691f26a{--width:16%;}.elementor-556 .elementor-element.elementor-element-9e6f470{--width:66%;}.elementor-556 .elementor-element.elementor-element-b215299{--width:25%;}}@media(max-width:1024px){.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}}@media(max-width:767px){.elementor-556 .elementor-element.elementor-element-7f615d4.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}}/* Start custom CSS for container, class: .elementor-element-6f5bf15 */.woocommerce ul.products {
  gap: 24px; 
}

/* Card */
.woocommerce ul.products li.product-category.product {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  overflow: hidden;
  background: #f7f7f7;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.woocommerce ul.products li.product-category.product > a {
  display: block;
  text-decoration: none;
  color: inherit;
}

.woocommerce ul.products li.product-category.product img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: #f3f4f6; /* fallback/placeholder */
  transition: transform .35s ease;
}

.woocommerce ul.products li.product-category.product .woocommerce-loop-category__title {
  margin: 0;
  padding: 14px 16px 16px;
  font-size: 1.05rem;
  font-weight: 650;
  letter-spacing: 0.01em;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.woocommerce ul.products li.product-category.product .woocommerce-loop-category__title .count {
  background: #f3f4f6;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: .85rem;
  font-weight: 600;
  line-height: 1;
  color: #374151;
}

.woocommerce ul.products li.product-category.product:hover {
  transform: translateY(-4px);
  border-color: #d1d5db;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
}

.woocommerce ul.products li.product-category.product:hover img {
  transform: scale(1.03);
}

.woocommerce ul.products li.product-category.product > a:focus-visible {
  outline: 3px solid rgba(59,130,246,.35);
  outline-offset: 3px;
  border-radius: 16px;
}

.woocommerce ul.products li.product-category.product img[src*="woocommerce-placeholder"] {
  object-fit: contain;
  padding: 22px;
  background: #f9fafb;
}



/* =========================================
   WooCommerce Archive – Feinschliff
   ========================================= */

:root{
  --brand: #345d77;
  --brand-hover: #2c4f66; /* etwas dunkler */
}

/* ---------- Toolbar: links Ergebniszahl, rechts Sortierung ---------- */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering{
  float: none !important;
  margin: 0 !important;
}

.woocommerce .woocommerce-result-count{
  display: inline-flex;
  align-items: center;
  color: #374151;
  font-size: .95rem;
}

.woocommerce .woocommerce-ordering{
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  position: relative;
}

/* Wrapper für beide Elemente: wir nutzen den nächstbesten gemeinsamen Container */
.woocommerce .woocommerce-notices-wrapper + .woocommerce-result-count{
  /* sorgt dafür, dass result-count + ordering in einer Zeile stehen */
  display: inline-flex;
  align-items: center;
  gap: 16px;
}

/* Wenn ordering direkt nach result-count kommt: eine Toolbar-Zeile bauen */
.woocommerce .woocommerce-result-count + .woocommerce-ordering{
  display: inline-flex;
}

/* Toolbar als Flex-Zeile (robust gegen Theme-Styles) */
.woocommerce .woocommerce-result-count{
  width: auto;
}
.woocommerce .woocommerce-ordering{
  width: auto;
}

/* Gemeinsame Toolbar: wir hängen sie an beide Elemente via :has (wenn unterstützt) */
.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-result-count,
.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-ordering{
  margin-bottom: 16px !important;
}

.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-result-count{
  display: flex;
}
.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-ordering{
  display: flex;
}

.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-result-count{
  flex: 1 1 auto;
}
.woocommerce:has(.woocommerce-result-count + .woocommerce-ordering) .woocommerce-ordering{
  flex: 0 0 auto;
}

/* Fallback ohne :has(): klassisch beide als block und ordering rechts */
@supports not .elementor-556 .elementor-element.elementor-element-6f5bf15(:has(*)) {
  .woocommerce .woocommerce-result-count{
    display: inline-block;
    margin-bottom: 16px !important;
  }
  .woocommerce .woocommerce-ordering{
    display: inline-block;
    float: right !important;
    margin-bottom: 16px !important;
  }
}

/* Select modern */
.woocommerce .woocommerce-ordering select.orderby{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  border: 1px solid #d1d5db;
  border-radius: 12px;
  padding: 10px 40px 10px 12px;
  font-size: .95rem;
  background: #fff;
  color: #111827;
  line-height: 1.2;
  cursor: pointer;
}
.woocommerce .woocommerce-ordering::after{
  content: "▾";
  position: absolute;
  right: 14px;
  pointer-events: none;
  color: #6b7280;
  font-size: 14px;
}

/* ---------- Produktkarten: gleiche Höhe ---------- */
/* Elementor Grid ist meistens display:grid; wir stellen sicher, dass Items stretch können */
.woocommerce ul.products{
  align-items: stretch;
}

/* Karte als Flex-Container, damit Button immer unten sitzt */
.woocommerce ul.products li.product{
  display: flex;
  flex-direction: column;
  height: 100%;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.woocommerce ul.products li.product:hover{
  transform: translateY(-4px);
  border-color: #d1d5db;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
}

/* Link-Block (Bild+Titel+Preis) nimmt den Platz ein */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link{
  display: block;
  text-decoration: none;
  color: inherit;
  flex: 1 1 auto; /* wichtig für gleiche Höhen */
}

/* Bild */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link img{
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  background: #f3f4f6;
  transition: transform .35s ease;
}
.woocommerce ul.products li.product:hover a.woocommerce-LoopProduct-link img{
  transform: scale(1.03);
}

/* Titel: feste Mindesthöhe, damit 1- und 2-zeilige Titel gleich wirken */
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  margin: 0;
  padding: 14px 16px 6px;
  font-size: 1.05rem;
  font-weight: 650;
  letter-spacing: .01em;
  color: #111827;

  min-height: 3.0em;      /* ~2 Zeilen */
  line-height: 1.5em;
  display: block;
}

/* Preis */
.woocommerce ul.products li.product .price{
  display: block;
  padding: 0 16px 14px;
  font-size: 1rem;
  font-weight: 600;
  color: #374151;
}

/* ---------- Buttons: Farbe + Text (Groß/Klein) ---------- */
.woocommerce ul.products li.product a.button{
  margin: 0 16px 16px;
  display: inline-flex;
  width: calc(100% - 32px);
  justify-content: center;
  align-items: center;

  border-radius: 999px;
  padding: 12px 14px;
  font-size: .95rem;
  font-weight: 650;

  border: 1px solid var(--brand);
  background: var(--brand);
  color: #fff;
  text-decoration: none;

  transition: transform .15s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.woocommerce ul.products li.product a.button:hover{
  transform: translateY(-1px);
  background: var(--brand-hover);
  border-color: var(--brand-hover);
  color: #fff;
}

/* "Select options" visuell korrekt: Optionen wählen (richtige Groß/Klein) */
.woocommerce ul.products li.product a.button:not(.ajax_add_to_cart)[href*="/produkt/"]{
  font-size: 0; /* Originaltext verstecken */
}
.woocommerce ul.products li.product a.button:not(.ajax_add_to_cart)[href*="/produkt/"]::before{
  content: "Optionen wählen";
  font-size: .95rem;
}

/* Optional: "In den Warenkorb" in exakt dieser Schreibweise erzwingen */
.woocommerce ul.products li.product a.ajax_add_to_cart{
  font-size: 0;
}
.woocommerce ul.products li.product a.ajax_add_to_cart::before{
  content: "In den Warenkorb";
  font-size: .95rem;
}

/* Fokus */
.woocommerce ul.products li.product a:focus-visible,
.woocommerce .woocommerce-ordering select.orderby:focus-visible{
  outline: 3px solid rgba(52,93,119,.35);
  outline-offset: 3px;
  border-radius: 14px;
}

/* Fix: keine automatische Großschreibung (capitalize) auf Buttons */
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product a.button::before {
  text-transform: none !important;
  letter-spacing: normal !important;
}

/* Falls das Theme auch noch variant/caps anders setzt */
.woocommerce ul.products li.product a.button {
  font-variant-caps: normal !important;
}

/* Kategorie-Titel */
.woocommerce ul.products li.product-category .woocommerce-loop-category__title {
  font-family: 'Gochi Hand', cursive;
  color: #345d77 !important;;
  font-weight: 600 !important;
  font-size: 2em !important;
}/* End custom CSS */