@charset "UTF-8";
/* farben */
/* Alpine Stuff */
[x-cloak] {
  display: none !important;
}

/* Based on bootstrap-grid and mobile first */
/* Media Queries */
html {
  font-size: 16px;
}

body {
  margin: 0;
  padding: 0;
  height: 100vh;
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a {
  text-decoration: none;
  color: #161616;
}

a:hover {
  text-decoration: underline;
  color: #161616;
}

h1,
h2,
p {
  padding: 0;
  margin: 0;
}

ol li[data-list=bullet] {
  list-style-type: disc;
  list-style-position: inside;
  counter-reset: none;
}

ol {
  list-style: none;
  padding-left: 0;
}

[x-cloak] {
  display: none !important;
}

/* Kollektionen */
/*
.wq-content-wrap {
	max-width: 75rem;
	margin: 0 24px;

	@include tablet-landscape {
		margin: 0 auto;
	}
}
*/
.wq-content-wrap {
  max-width: 75rem;
  margin: 0 24px;
}
@media (min-width: 960px) {
  .wq-content-wrap {
    margin: 0 auto;
  }
}

.wq-pt-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
}

/* Produktdetail */
.wq-prod-wrap {
  display: grid;
  grid-gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .wq-prod-wrap {
    grid-template-columns: 1fr 1fr;
    max-width: 1584px;
    margin: 0 auto;
  }
}
@media (min-width: 1312px) {
  .wq-prod-wrap {
    max-width: 1312px;
  }
}

.wq-prod-images {
  width: 100vw;
  height: 75vh;
  overflow-y: auto;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
}
@media (min-width: 960px) {
  .wq-prod-images {
    width: auto;
    height: auto;
    overflow: visible;
  }
}

.wq-prod-images img {
  width: 100%;
  height: auto;
  scroll-snap-align: start;
  display: block;
}

.wq-prod-content {
  position: sticky; /* Macht den rechten Bereich sticky */
  bottom: 0; /* Der Bereich bleibt am oberen Rand des Viewports */
  align-self: end; /* Stellt sicher, dass der Bereich am oberen Rand der Spalte bleibt */
  height: 25vh;
  padding-bottom: 48px;
}
@media (min-width: 960px) {
  .wq-prod-content {
    grid-column: 2;
    top: 0; /* Sticky am oberen Rand des Viewports für größere Bildschirme */
    align-self: start;
    margin-top: 0;
    height: auto;
  }
}

.wq-prod-details {
  margin: 0;
  padding: 24px 24px 0 24px;
  background-color: #FFFFFF;
}
@media (min-width: 960px) {
  .wq-prod-details {
    margin: 0 32px 0 0;
  }
}
@media (min-width: 1312px) {
  .wq-prod-details {
    margin: 0 32px 0 0;
    padding: 24px 0 0 0;
  }
}
@media (min-width: 1584px) {
  .wq-prod-details {
    margin: 0 32px 0 0;
    padding: 24px 0 0 0;
  }
}

.wq-prod-details h1 {
  padding: 0;
  margin: 0;
  font-size: 2rem;
  line-height: 1.3em;
  font-weight: 800;
}
@media (min-width: 720px) {
  .wq-prod-details h1 {
    font-size: 2.4rem;
  }
}
@media (min-width: 1312px) {
  .wq-prod-details h1 {
    font-size: 2.6rem;
  }
}
@media (min-width: 1584px) {
  .wq-prod-details h1 {
    font-size: 3rem;
  }
}

.wq-prod-details h2 {
  padding: 0;
  margin: 0 0 16px 0;
  font-weight: 800;
  font-size: 1rem;
  line-height: 1.3em;
}

.wq-prod-details p {
  padding: 0;
  margin: 0;
  font-size: 1rem;
  line-height: 1.3em;
}

.wp-prod-info {
  display: none;
}
@media (min-width: 960px) {
  .wp-prod-info {
    display: block;
  }
}

@media (min-width: 960px) {
  .wp-prod-accordion .wp-prod-toggle {
    display: none; /* Button nur in Mobile anzeigen */
  }
}

.wp-prod-toggle {
  border: 0;
  background-color: #FFFFFF;
  font-family: "Inter";
  color: #161616;
  margin: 0;
  padding: 0;
  font-size: 0.9rem;
  line-height: 1.5em;
}

.wp-prod-toggle:hover {
  cursor: pointer;
}

.wq-main-prz {
  margin-top: 16px !important;
}
@media (min-width: 960px) {
  .wq-main-prz {
    margin-top: 24px !important;
  }
}

.wq-main-prz-uvp {
  margin-top: 0 !important;
  text-decoration: line-through;
  color: #8d8d8d;
}

.wq-main-size {
  margin-top: 8px;
  font-size: 0.8em;
  font-style: italic;
}

.wq-reorder {
  margin: 16px 0;
  padding: 16px 8px;
  background-color: #e0e0e0;
}

.wq-soldout {
  margin: 16px 0;
  padding: 16px 8px;
  background-color: #F4F4F4;
}

.wq-btn-wrap {
  margin: 0;
}

.wq-btn {
  background-color: #161616;
  color: #FFFFFF;
  font-size: 0.9rem;
  line-height: 1rem;
  text-align: center;
  padding: 18px 24px;
  max-width: 220px;
  border: 1px solid #161616;
  width: 100%;
}

.wq-btn:hover {
  border: 1px solid #161616;
  background-color: #FFFFFF;
  color: #161616;
  cursor: pointer;
}

.added-to-cart {
  background-color: #a8a8a8 !important;
  border: 1px solid #a8a8a8 !important;
  color: #161616 !important;
  opacity: 0.7;
  pointer-events: none; /* Verhindert weiteres Klicken */
  transition: all 0.3s ease-in-out;
  font-size: 1.1rem;
}

/* Related */
.wq-rel-wrap {
  display: grid;
  grid-gap: 24px;
  grid-template-columns: 1fr 1fr;
  justify-content: center;
}
@media (min-width: 720px) {
  .wq-rel-wrap {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1312px) {
  .wq-rel-wrap {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1584px) {
  .wq-rel-wrap {
    grid-template-columns: repeat(3, 1fr);
  }
}

.wq-rel-title {
  margin-top: 48px;
  margin-bottom: 24px;
}

.wq-rel-pt {
  border: 1px solid #e0e0e0;
  margin: 0;
  padding: 0;
  text-align: center;
}

.wq-rel-pt-txt {
  font-size: 1em;
}

.wq-rel-pt-txt h2 {
  font-weight: 700;
  font-size: 13px;
  color: #161616 !important;
}

.wq-rel-pt:hover a {
  text-decoration: none;
}

.wq-rel-prz {
  font-size: 13px;
  padding-top: 4px;
  padding-bottom: 12px;
  font-weight: 400;
}

/* Teasers */
.wq-pt {
  position: relative;
  flex: 0 1 calc(50% - 12px);
  max-width: calc(50% - 12px);
  box-sizing: border-box;
}
@media (min-width: 720px) {
  .wq-pt {
    flex: 0 1 calc(33.3333% - 24px);
    max-width: calc(33.3333% - 24px);
  }
}
@media (min-width: 1312px) {
  .wq-pt {
    flex: 0 1 calc(25% - 24px);
    max-width: calc(25% - 24px);
  }
}

.wq-pt a,
.wq-pt a:hover {
  text-decoration: none;
}

.wq-pt-img {
  overflow: hidden; /* Stellt sicher, dass das Bild nicht aus dem Rahmen herausläuft */
}

.wq-pt h2 {
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.4em;
  text-align: center;
  margin: 16px 0 0 0;
}

.img-fluid {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  transition: transform 0.3s ease; /* Fügt eine glatte Übergangsanimation hinzu */
}

.wq-pt:hover .img-fluid {
  transform: scale(1.1); /* Vergrößert das Bild um 10% */
}

.wq-pt-txt {
  transition: transform 0.3s ease;
  width: 100%;
  position: relative;
  z-index: 1;
  background-color: #FFFFFF;
  padding: 8px 0 16px 0;
}

.wq-pt:hover .wq-pt-txt {
  transform: translateY(-25px); /* Bewegt den Textblock 10px nach oben */
}

.wq-pt:hover .wq-pt-prz-hover {
  opacity: 1;
}

.wq-pt-prz-hover {
  font-size: 0.8rem;
  text-align: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.wq-pt-soldout {
  color: #161616;
  background-color: #e0e0e0;
  font-weight: 400;
  font-size: 1rem;
  position: absolute;
  top: 16px;
  right: 0;
  z-index: 10;
  padding: 4px 8px;
}

.wq-pt-new {
  color: #FFFFFF;
  background-color: #161616;
  font-weight: 400;
  font-size: 1rem;
  position: absolute;
  top: 16px;
  right: 0;
  z-index: 10;
  padding: 4px 8px;
}

.wq-pt-sale {
  color: #FFFFFF;
  background-color: #8d8d8d;
  font-weight: 400;
  font-size: 1rem;
  position: absolute;
  top: 16px;
  right: 0;
  z-index: 10;
  padding: 4px 8px;
}

/* Filter */
.wq-filter-wrap {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  max-width: 75rem;
  margin: 0 auto;
  gap: 16px;
  margin-bottom: 32px;
}
@media (min-width: 720px) {
  .wq-filter-wrap {
    display: flex;
    flex-direction: row;
  }
}
@media (min-width: 1312px) {
  .wq-filter-wrap {
    flex-direction: row;
  }
}

@media (min-width: 720px) {
  .wq-filter-mob-only {
    display: none;
  }
}

.wq-filter {
  border-radius: 16px;
  padding: 4px 16px;
  margin: 0;
  text-align: center;
  background-color: #fff;
  color: #000000;
  display: inline-flex;
  border: 1px solid #000000;
  font-size: 0.8em;
  letter-spacing: 0.2px;
  font-weight: 400;
}

.wq-filter:hover {
  background-color: #000000;
  color: #ffffff;
}

.wq-filter.active {
  background-color: #000000;
  color: #FFFFFF;
  border: 1px solid #000000;
}

.wq-filter a,
.wq-filter a:hover,
.wq-filter a:visited {
  font-size: 0.8em;
  letter-spacing: 0.2px;
  font-weight: 400;
  text-decoration: none;
}

.wq-filter a:hover {
  color: #FFFFFF;
}

/* Accordeion */
.wq-acc {
  border-bottom: 1px solid #161616;
}

.wq-acc-header {
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0 7px 0;
  font-weight: 800;
  font-size: 0.9rem;
  line-height: 0.9rem;
  text-transform: uppercase;
}

.wq-acc-content {
  padding: 8px 0 8px 0;
  border-bottom: 1px solid #ddd;
  font-weight: 400;
  font-size: 0.8rem;
}

/* Mini-Cart */
.wq-minicart {
  position: fixed;
  top: 0;
  right: 0;
  max-width: 25rem;
  width: 100%;
  height: 100%;
  background-color: #FFFFFF;
  overflow-y: hidden;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.1);
  transform: translateX(110%);
  transition: transform 0.6s ease-in-out, opacity 0.3s ease-in-out;
  z-index: 1100;
  opacity: 1;
  overflow-y: scroll;
}

.wq-minicart.open {
  transform: translateX(0);
  opacity: 1;
}

.wq-mc-close {
  font-size: 1.2em;
}

.wq-mc-close:hover,
.wq-mc-more:hover {
  cursor: pointer;
}

.wq-mc-wrap {
  margin: 24px;
}

.wq-mc-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0;
}

.wq-mc-titel {
  margin: 0;
  padding: 0;
  font-weight: 800;
}

.wq-mc-content {
  margin-top: 32px;
}

.wq-mc-content p {
  font-size: 0.8rem;
}

.wq-mc-more {
  text-decoration: underline;
}

/* Produkte Detail Anzahl */
.wq-btn-action {
  display: grid;
  grid-gap: 8px;
  grid-template-columns: 160px 1fr;
  margin: 16px 0;
}

.wq-anz-wrap-short {
  display: inline-grid;
  grid-gap: 0;
  grid-template-columns: 40px 40px 40px;
  color: #161616;
  font-family: "Inter";
  font-weight: 400;
  border: 1px solid #6f6f6f;
  border-radius: 0;
  padding: 16px;
}

.wq-negativ {
  font-family: "Inter";
  font-weight: 800;
  text-align: center;
}

.wq-plus {
  font-family: "Inter";
  font-weight: 800;
  text-align: center;
}

.wq-negativ:hover,
.wq-plus:hover {
  cursor: pointer;
}

.wq-nr {
  font-family: "Inter";
  font-weight: 800;
  text-align: center;
  color: #161616;
}

.wq-detail-back {
  display: none;
  max-width: 24px;
  padding-top: 32px;
  padding-left: 24px;
}
@media (min-width: 720px) {
  .wq-detail-back {
    display: block;
  }
}

.wg-back-path {
  fill: #161616;
}

.wg-back {
  max-width: 24px;
}

.wg-back:hover {
  cursor: pointer;
}

.wg-back:hover .wg-back-path {
  fill: #8d8d8d;
}

/* Sendinfo */
.wq-sendinfo {
  margin: 24px 0 0 0;
  font-size: 0.8rem;
  line-height: 1.3em;
}

/* Availiability Notifictation */
.wq-notify-wrap {
  margin: 24px 0;
}

.wq-notify-grid {
  margin-top: 24px;
  display: grid;
  grid-gap: 24px;
  grid-template-columns: 2fr 1fr;
}

.wq-input {
  width: 100%;
  border: 1px solid #a8a8a8;
  padding: 16px 12px 16px 8px;
  margin: 0;
  color: #161616;
  font-size: 1rem;
  box-sizing: border-box;
  background-color: #FFFFFF;
  border-radius: 0;
}

.wq-btn-soft {
  background-color: #8d8d8d;
  color: #FFFFFF;
  font-size: 0.9rem;
  line-height: 1rem;
  text-align: center;
  padding: 18px 24px;
  max-width: 100%;
  border: 1px solid #8d8d8d;
  width: 100%;
}

.wq-btn-soft:hover {
  border: 1px solid #8d8d8d;
  background-color: #FFFFFF;
  color: #161616;
  cursor: pointer;
}

.wq-notify-error {
  margin-top: 8px !important;
  font-size: 0.9em !important;
  color: red;
}

.wq-info-wrap {
  position: relative;
}

.wq-info-wrap img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.wq-info-wrap h2 {
  text-align: left;
  font-size: 3rem;
  line-height: 1.2em;
  font-family: "Montserrat";
  font-weight: 900;
}

.wq-info-wrap p {
  text-align: left;
  font-size: 1rem;
  line-height: 1.2em;
  font-family: "Montserrat";
  font-weight: 400;
}

.wq-grid-two {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 960px) {
  .wq-grid-two {
    grid-template-columns: 1fr 1fr;
    max-width: 720px;
    margin: 0 auto;
  }
}
@media (min-width: 1312px) {
  .wq-grid-two {
    max-width: 960px;
  }
}

.wq-grid-one-two {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .wq-grid-one-two {
    grid-template-columns: 1fr 2fr;
    max-width: 720px;
    margin: 0 auto;
  }
}
@media (min-width: 1312px) {
  .wq-grid-one-two {
    max-width: 960px;
  }
}

.wq-grid-two-one {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .wq-grid-two-one {
    grid-template-columns: 2fr 1fr;
    max-width: 720px;
    margin: 0 auto;
  }
}
@media (min-width: 1312px) {
  .wq-grid-two-one {
    max-width: 960px;
  }
}

.wq-grid-three {
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 960px) {
  .wq-grid-three {
    grid-template-columns: 1fr 1fr 1fr;
    max-width: 720px;
    margin: 0 auto;
  }
}
@media (min-width: 1312px) {
  .wq-grid-three {
    max-width: 960px;
  }
}

.wq-img-fade-in {
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.wq-img-fade-in.loaded {
  opacity: 1;
  transform: translateY(0);
}

.wq-info-box {
  align-self: center;
  padding-left: 32px;
  padding-right: 32px;
}
@media (min-width: 960px) {
  .wq-info-box {
    padding-left: 12px;
    padding-right: 12px;
  }
}
@media (min-width: 1312px) {
  .wq-info-box {
    padding-left: 0;
    padding-right: 0;
  }
}

.wq-mb-empty {
  font-size: 0.9em;
}

.wq-mb-empty-btn {
  background-color: #FFFFFF;
  color: #161616;
  font-size: 0.9rem;
  line-height: 1rem;
  text-align: center;
  padding: 12px 24px;
  max-width: 220px;
  border: 1px solid #161616;
  width: 100%;
}

.wq-mb-empty-btn:hover {
  border: 1px solid #161616;
  background-color: #161616;
  color: #FFFFFF;
  cursor: pointer;
}

.wq-mini-basket ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.wq-mb-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.wq-mini-basket li {
  display: grid;
  grid-template-columns: 80px 1fr;
  grid-gap: 16px;
  width: 100%;
  border-bottom: 1px solid #E6E4DC;
  padding: 16px 0 16px 0;
}

.wq-mb-sum {
  border-bottom: 1px solid #E6E4DC;
  padding: 16px 0 16px 0;
  font-size: 13px;
  line-height: 1.2em;
  font-family: "Inter";
  font-weight: 700;
  color: #2C4A32;
}

.wq-mb-thumb img {
  width: auto;
  max-width: 100%;
  height: auto;
}

.wq-mb-item {
  font-size: 13px;
  line-height: 1.2em;
  font-family: "Inter";
  font-weight: 400;
}

.wq-mb-item strong {
  font-weight: 800;
}

.wq-mb-prize-sale {
  text-decoration: line-through;
  color: #8d8d8d;
}

.wq-mb-lineaction {
  display: grid;
  grid-template-columns: 100px 1fr;
  grid-gap: 16px;
  width: 100%;
  padding-top: 16px;
}

.wq-anz-wrap-mini {
  display: inline-grid;
  grid-gap: 0;
  grid-template-columns: 20px 40px 20px;
  font-family: "Inter";
  font-weight: 400;
  border: 1px solid #161616;
  border-radius: 0;
  padding: 8px;
  font-size: 12px;
}

.wq-negativ-mini {
  font-family: "Inter";
  font-weight: 700;
  text-align: center;
}

.wq-plus-mini {
  font-family: "Inter";
  font-weight: 800;
  text-align: center;
}

.wq-negativ-mini:hover,
.wq-plus-mini:hover {
  cursor: pointer;
}

.wq-nr-mini {
  font-family: "Inter";
  font-weight: 800;
  text-align: center;
  color: #161616;
}

.wb-item-remove {
  margin-top: 9px;
  color: #8d8d8d;
}

.wb-item-remove:hover {
  cursor: pointer;
}

.wq-btn-small {
  background-color: #161616;
  color: #FFFFFF;
  font-size: 0.9rem;
  line-height: 1rem;
  text-align: center;
  padding: 8px 12px;
  max-width: 180px;
  border: 1px solid #161616;
  width: 100%;
}

.wq-btn-small:hover {
  border: 1px solid #161616;
  background-color: #FFFFFF;
  color: #161616;
  cursor: pointer;
}

/* inter-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Inter";
  font-style: normal;
  font-weight: 400;
  src: url("fonts/inter-v18-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* inter-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Inter";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/inter-v18-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* Header inklusive Intro-Sektion */
header {
  max-width: 1584px;
  margin: 0px auto 0px auto;
  display: grid;
  grid-gap: 8px;
  grid-template-columns: 80px 1fr 80px;
  padding: 24px 0 16px 0;
}
@media (min-width: 960px) {
  header {
    grid-template-columns: 80px 1fr 80px;
    max-width: 75rem;
  }
}
@media (min-width: 1312px) {
  header {
    max-width: 1312px;
  }
}

.wq-web-back {
  display: block;
}
@media (min-width: 960px) {
  .wq-web-back {
    display: block;
  }
}

.wq-logo {
  text-align: center;
  margin-left: 0 auto;
  max-width: 120px;
}
@media (min-width: 960px) {
  .wq-logo {
    text-align: center;
    margin: 0 auto;
    max-width: 280px;
  }
}

.wq-b {
  margin: 0 0 0 auto;
}
@media (min-width: 960px) {
  .wq-b {
    margin: 0 0 0 auto;
  }
}

.wq-basket {
  width: 50px;
  position: relative;
  height: 1.75rem;
}

.wq-num {
  font-size: 0.75rem;
  border-radius: 50%;
  width: 1.25rem;
  height: 1.25rem;
  color: #FFFFFF;
  background-color: #161616;
  position: absolute;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-weight: 800;
  right: 1rem;
  top: 0;
  z-index: 2;
}

#wqb {
  max-width: 24px;
  position: absolute;
  bottom: 0;
  text-align: left;
}

/* Intro */
.wq-intro-wrap {
  position: relative;
}

.wq-i-img {
  position: relative;
  max-height: 60vh;
  overflow: hidden;
}
@media (min-width: 1312px) {
  .wq-i-img {
    max-height: 45vh;
  }
}

.wq-i-h1 {
  padding: 36px 0 0 0;
  margin: 0 24px;
  text-align: center;
  font-size: 2rem;
  line-height: 1.2em;
  font-weight: 800;
}
@media (min-width: 720px) {
  .wq-i-h1 {
    margin: 0 auto;
    padding: 36px 0 0 0;
    max-width: 65vw;
  }
}
@media (min-width: 1312px) {
  .wq-i-h1 {
    margin: 0 auto;
    padding: 64px 0 0 0;
    max-width: 35vw;
  }
}

.wq-i-txt {
  padding: 24px 0 32px 0;
  margin: 0 24px;
  text-align: center;
  font-size: 1.2rem;
  line-height: 1.35em;
}
@media (min-width: 720px) {
  .wq-i-txt {
    margin: 0 auto;
    max-width: 65vw;
    font-size: 1.2rem;
  }
}
@media (min-width: 1312px) {
  .wq-i-txt {
    margin: 0 auto;
    max-width: 35vw;
  }
}

/* --- Burger Button --- */
.wq-burger {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 16px;
  cursor: pointer;
  margin-left: 24px;
  margin-top: 12px;
  transition: transform 0.3s ease;
  position: relative;
  z-index: 1001;
}
@media (min-width: 720px) {
  .wq-burger {
    display: none;
  }
}

.wq-burger span {
  display: block;
  height: 1.5px;
  background: #161616;
  border-radius: 0;
  transition: all 0.3s ease;
}

/* Animation für "X" */
.wq-burger.on span:nth-child(1) {
  transform: rotate(45deg) translate(4px, 4px);
}

.wq-burger.on span:nth-child(2) {
  opacity: 0;
}

.wq-burger.on span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

.wq-filter-wrap.mobile {
  position: fixed;
  display: flex;
  z-index: 1000;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  transform: translateY(-100%);
  transition: transform 0.4s ease;
  font-size: 1.5rem;
  margin: 0;
}

.wq-filter-wrap.mobile.on {
  transform: translateY(0);
}

footer {
  border-top: 0px solid #a8a8a8;
}

.wq-f-adr {
  padding: 16px 0 0 0;
  font-size: 0.9em;
  line-height: 1.3;
}

.wq-f-legal {
  padding-top: 24px;
  font-size: 0.9em;
  line-height: 1.3;
}

.wq-f-legal a {
  margin: 0 8px;
  text-decoration: none;
}

.wq-f-legal a:hover {
  margin: 0 8px;
  text-decoration: none;
  border-bottom: 1px solid #000000;
}

/* wq-copyright */
.wq-copyright {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 16px auto 0 auto;
  text-align: center;
  padding-bottom: 24px;
}

.wq-made {
  display: grid;
  grid-template-columns: 1fr 16px;
  grid-gap: 8px;
  margin: 0 auto;
}

.wq-made-txt {
  font-size: 0.7em;
  color: #666666;
}

.wq-made-icon {
  width: 16px;
  height: auto;
}

/* Social Media */
.wq-social-wrap {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  padding-top: 24px;
}

.wq-social-wrap a {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.wq-social-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Verhindert Scrollen im Body bei offenem Modal */
body.no-scroll {
  overflow: hidden;
}

/* Der halbtransparente Overlay-Hintergrund */
.modal-overlay {
  position: fixed;
  inset: 0; /* top, right, bottom, left: 0 */
  background-color: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

/* Der eigentliche Modal-Container */
.modal-content {
  background-color: #fafafa;
  width: 72vw;
  max-width: 72vw;
  height: 88vh;
  border-radius: 0;
  padding: 2rem;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3);
  font-size: 1em;
  line-height: 1.3;
  text-align: left;
}
@media (min-width: 1312px) {
  .modal-content {
    width: 72vw;
    max-width: 50vw;
    height: 72vh;
  }
}

.modal-content h2 {
  padding-bottom: 24px;
}

/* Schließen-Button oben rechts */
.modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  color: #333;
}

.modal-close:hover {
  color: #000;
}

.modal-overlay[x-cloak],
.modal-content[x-cloak] {
  display: none !important;
}

[x-show=showModal] .modal-overlay,
[x-show=showModal] .modal-content {
  transition: opacity 0.3s ease, transform 0.3s ease;
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Libre Baskerville";
  font-style: normal;
  font-weight: 400;
  src: url("fonts/libre-baskerville-v24-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* inter-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Libre Baskerville";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/libre-baskerville-v24-latin-600.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 400;
  src: url("fonts/montserrat-v31-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 700;
  src: url("fonts/montserrat-v31-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Montserrat";
  font-style: normal;
  font-weight: 900;
  src: url("fonts/montserrat-v31-latin-900.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
html {
  font-size: 16px;
}

body {
  margin: 0;
  padding: 0;
  font-family: "Montserrat";
  font-weight: 400;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a {
  text-decoration: none;
  color: #000000;
}

strong {
  font-weight: 900;
}

header {
  align-items: center;
  padding-top: 8px;
}
@media (min-width: 960px) {
  header {
    padding-top: 16px;
  }
}

.wq-basket {
  margin-top: 0px;
}
@media (min-width: 960px) {
  .wq-basket {
    margin-top: 0px;
  }
}

.wq-burger {
  padding-top: 12px;
}

.wq-header-wrap {
  width: 100vw;
}

.wq-logo {
  text-align: center;
  margin-left: 0;
  max-width: 140px;
  margin: 0 auto;
  padding-top: 16px;
}
@media (min-width: 960px) {
  .wq-logo {
    text-align: center;
    margin: 0 auto;
    max-width: 140px;
    padding-top: 8px;
  }
}

.img {
  width: auto;
  height: auto;
  max-width: 100%;
}

.wq-h-img {
  position: relative;
  max-height: 45vh;
  overflow: hidden;
}

.wq-i-h1 {
  padding: 36px 0 0 0;
  margin: 0 24px;
  text-align: center;
  font-size: 1.5rem;
  line-height: 1.2;
  font-family: "Montserrat";
  font-weight: 900;
  letter-spacing: 1px;
}
@media (min-width: 720px) {
  .wq-i-h1 {
    margin: 0 auto;
    padding: 36px 0 0 0;
    max-width: 65vw;
    line-height: 1.2;
  }
}
@media (min-width: 1312px) {
  .wq-i-h1 {
    margin: 0 auto;
    padding: 54px 0 0 0;
    max-width: 50vw;
    font-size: 1.8rem;
  }
}

.wq-i-h1 h1 {
  font-weight: 900;
}

.wq-i-txt {
  padding: 24px 0 32px 0;
  margin: 0 auto;
  text-align: center;
  font-size: 1.35rem;
  line-height: 1.2em;
  width: 100%;
  font-family: "Montserrat";
  font-weight: 400;
}
@media (min-width: 720px) {
  .wq-i-txt {
    padding: 24px 0 32px 0;
    max-width: 60vw;
  }
}
@media (min-width: 1312px) {
  .wq-i-txt {
    padding: 24px 0 32px 0;
    max-width: 35vw;
  }
}

.wq-i-txt p {
  padding: 0 24px;
}
@media (min-width: 1312px) {
  .wq-i-txt p {
    padding: 0;
  }
}

/* Teasers */
.wq-pt {
  border: 1px solid #e0e0e0;
}
@media (min-width: 1312px) {
  .wq-pt {
    flex: 0 1 calc(33.3333% - 24px);
    max-width: calc(33.3333% - 24px);
  }
}

.wq-pt-txt {
  text-align: center;
}

.wq-pt-txt h2 {
  display: inline-block;
  text-align: center;
  font-size: 1.2em;
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: 1px;
  background: linear-gradient(45deg, rgb(131, 58, 180) 0%, rgb(253, 29, 29) 74%, rgb(252, 176, 69) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.wq-pt-txt h3 {
  text-align: center;
  font-size: 0.9em;
  line-height: 1.2;
  font-weight: 700;
  margin: 8px 0 0 0;
  font-family: "Libre Baskerville";
}

.wq-pt-prz-zusatz {
  display: none;
}

.wq-pt-prz-hover {
  text-align: center;
  margin-top: 8px;
  color: #8d8d8d;
}

.wq-pt-new {
  font-weight: 900;
  letter-spacing: 1px;
}

/* Detailseite */
.wq-prod-details h1 {
  font-family: "Montserrat";
  font-weight: 900;
  letter-spacing: 1px;
  padding-bottom: 12px;
  margin: 0;
  display: inline-block;
  background: linear-gradient(45deg, rgb(131, 58, 180) 0%, rgb(253, 29, 29) 74%, rgb(252, 176, 69) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.wq-prod-details h2 {
  color: #8d8d8d;
  margin: 0;
}

.wq-prod-details p {
  font-family: "Montserrat";
  font-weight: 400;
}

.wq-main-prz {
  font-weight: 700 !important;
  font-family: "Montserrat";
}

.wq-reorder {
  font-weight: 400;
  margin: 16px 0;
  padding: 16px 8px;
  font-family: "Montserrat";
  color: #9d1429;
}

.wq-soldout {
  font-weight: 400;
  margin: 16px 0;
  padding: 16px 8px;
  font-family: "Inter";
  color: #9d1429;
}

.wq-acc-content p {
  font-size: 1em;
  line-height: 1.25;
  font-family: "Inter";
}

.wq-acc-header span {
  font-size: 2em;
  font-weight: 400;
}

.wq-rel-title {
  font-family: "Inter";
  font-weight: 600;
}

/* Toast */
.wq-toast {
  background-color: #0a0a0a;
  color: white;
  padding: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.9rem;
  position: relative;
}

.wq-toast-txt {
  position: absolute;
  white-space: nowrap; /* Verhindert Zeilenumbrüche */
}

.wq-anim {
  animation: scrollText 25s linear infinite;
}

.close-icon {
  cursor: pointer;
  margin-left: 10px;
  font-size: 1.2em;
  position: absolute;
  right: 0;
  padding: 0 16px 0 8px;
  background-color: #0a0a0a;
  z-index: 10;
}

/* END TOAST */
.wq-filter-grid {
  display: grid;
  grid-gap: 24px;
  grid-template-columns: 1fr 3fr;
}

/* Media Queries * */
@media (max-width: 600px) {
  /* Stile für mobile Geräte */
  .wq-filter-wrap {
    align-items: center;
  }
  .wq-h-h1 {
    padding: 36px 0 0 0;
    margin: 0 auto;
    text-align: center;
    font-size: 2rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-h-txt {
    padding: 24px 0 32px 0;
    margin: 0 auto;
    text-align: center;
    font-size: 1.35rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-h-txt p {
    margin: 0 32px;
  }
  .wq-filter-grid {
    grid-template-columns: 1fr;
    margin: 0 32px;
  }
}
@media (min-width: 601px) and (max-width: 768px) and (orientation: portrait) {
  /* Stile für iPad im Hochformat */
  .wq-filter-wrap {
    align-items: center;
  }
  .wq-h-h1 {
    padding: 36px 0 0 0;
    margin: 0 auto;
    text-align: center;
    font-size: 2rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-h-txt {
    padding: 24px 0 32px 0;
    margin: 0 auto;
    text-align: center;
    font-size: 1.35rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-filter-grid {
    grid-template-columns: 1fr;
    margin: 0 32px;
  }
}
@media (min-width: 769px) and (max-width: 1024px) and (orientation: landscape) {
  /* Stile für iPad im Querformat */
  .wq-filter-wrap {
    align-items: flex-start;
  }
  .wq-h-h1 {
    padding: 36px 0 0 0;
    margin: 0 auto;
    text-align: center;
    font-size: 2rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-h-txt {
    padding: 24px 0 32px 0;
    margin: 0 auto;
    text-align: center;
    font-size: 1.35rem;
    line-height: 1.2em;
    max-width: 95vw;
  }
  .wq-filter-grid {
    grid-template-columns: 1fr 3fr;
    margin: 0 32px;
  }
}
@media (min-width: 1025px) and (max-width: 1366px) {
  /* Stile für Laptops */
  .wq-filter-wrap {
    align-items: flex-start;
  }
  .wq-h-h1 {
    padding: 72px 0 0 0;
    margin: 0 auto;
    text-align: center;
    font-size: 2rem;
    line-height: 1.2em;
    max-width: 60vw;
  }
  .wq-h-txt {
    padding: 24px 0 32px 0;
    margin: 0 auto;
    text-align: center;
    font-size: 1.35rem;
    line-height: 1.2em;
    max-width: 60vw;
  }
  .wq-filter-grid {
    grid-template-columns: 1fr 3fr;
  }
}
@media (min-width: 1367px) {
  /* Stile für große Desktop-Bildschirme */
  .wq-h-h1 {
    padding: 72px 0 0 0;
    margin: 0 auto;
    text-align: center;
    font-size: 2rem;
    line-height: 1.2em;
    max-width: 35vw;
  }
  .wq-h-txt {
    padding: 24px 0 32px 0;
    margin: 0 auto;
    text-align: center;
    font-size: 1.35rem;
    line-height: 1.2em;
    max-width: 35vw;
  }
  .wq-filter-grid {
    grid-template-columns: 1fr 3fr;
  }
}
/* Footer */
footer {
  max-width: auto;
  margin: 0 auto;
  border-top: 1px solid #e0e0e0;
  background: #F4F4F4;
  background: linear-gradient(180deg, rgb(237, 237, 237) 0%, rgb(255, 255, 255) 87%);
}

.wq-footer {
  min-height: 100px;
  text-align: center;
  padding: 30px 0;
  margin-top: 50px;
}

.wq-f-logo img {
  max-width: 240px;
  margin: auto;
}

.wq-legal {
  padding: 16px;
}

.wq-legal-b {
  font-size: 0.8em;
}

.wq-legal-b:hover {
  cursor: pointer;
}

.wq-legal-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-height: 400px;
  overflow-y: auto;
}

.wq-legal-grid .left-sticky {
  position: sticky;
  top: 1rem;
  align-self: start;
}

.wq-legal-grid h3 {
  font-size: 3em;
  font-weight: 700;
  text-align: right;
  padding: 0;
  margin: 0;
}

.wq-legal-txt {
  margin: 16px 0;
}

.wq-legal-txt p {
  text-align: left;
  font-size: 0.9em;
}

@keyframes scrollText {
  0% {
    transform: translateX(100%); /* Startet außerhalb des sichtbaren Bereichs rechts */
  }
  100% {
    transform: translateX(-100%); /* Endet außerhalb des sichtbaren Bereichs links */
  }
}
.modal-content h2 {
  font-weight: 900;
  letter-spacing: 1px;
}

.wq-info-wrap h2 {
  display: inline-block;
  background: linear-gradient(45deg, rgb(131, 58, 180) 0%, rgb(253, 29, 29) 74%, rgb(252, 176, 69) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  padding-bottom: 24px;
}

/* Auktion */
.auction-message {
  padding: 16px 0 0 0;
  font-family: "Libre Baskerville";
  font-weight: 400;
  font-size: 0.9em;
  line-height: 1.6;
  color: #DE2121;
}
