/* =====================================================
   DRB-LAYOUT.CSS
   Ladereihenfolge: 2/3
   Zuständigkeit: Seitenstruktur, Navigation, Shop,
   Warenkorb, Checkout, Footer, Slider, Hero

   Quellen: drb-responsive-20240718.css
            drb-carousel-20240718.css
            itb-20240718.css (eingemergt, eigene Datei entfällt)

   Bugfixes in dieser Version:
   - .suchbegriff: doppeltes ";;" entfernt
   - .topline: Duplikat entfernt (definiert in drb-base.css)
   Stand: 2026-04
   ===================================================== */


/* =====================================================
   1. OVERLAYS & BLOCKER
   ===================================================== */

.overlay        { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; }
.errorblocker   { background: rgba(var(--rgbwhite), 0.96); z-index: 50000; }
.menueblocker   { display: none; background: rgba(var(--rgbmain), 0.5); z-index: 150; }
.blocker        { position: fixed; top: 0; left: 0; height: 100vh; background-color: rgba(var(--rgbmain), 0.5); z-index: 30000; }
.errorcont, .okrightcont { margin: 1.5rem 0.625rem 0; }


/* =====================================================
   2. SEITEN-CONTAINER
   ===================================================== */

.wbox       { margin: 0 auto; max-width: 1260px; }
.cheight    { min-height: 100vh; }
main        { position: relative; }
.fullwidthimg, .fullimg { max-width: 100%; height: auto; }
.nodeco, .nodeco:hover { text-decoration: none; }


/* =====================================================
   3. HEADER
   ===================================================== */

header {
  position: relative;
  height: 100px;
  border-bottom: 1px solid var(--bordernorm);
  border-collapse: collapse;
  background-color: var(--bgheader);
  z-index: 200;
}

.headwbox { height: 100px; max-width: 1260px; margin: 0 auto; }
.logobox  { height: 6rem; transition: all 0.3s ease; }
.logobox img { max-height: 5rem; width: auto; max-width: 100%; margin: 0.5rem 0; }


/* =====================================================
   4. SOCIAL BAR (unter Header)
   ===================================================== */

.socialwrapper      { height: 60px; background-color: #eeeeee; }
.socialsides        { width: calc(50% - 100px); }
.socialsides div    { height: 100%; background-color: #ffffff; }
.socialsideleft div { border-bottom-right-radius: 12px; }
.socialsideright div{ border-bottom-left-radius: 12px; }
.socialmid          { width: 200px; background-color: #ffffff; }
.socialmidbg        { height: 100%; background-color: #eeeeee; border-top-left-radius: 12px; border-top-right-radius: 12px; }
.socialmid svg, .socialmid img { height: 1.5rem; width: auto; margin: auto 0.75rem; }
.socialmid svg path { fill: #666666; }
.socialmid svg:hover path { fill: var(--high); }


/* =====================================================
   5. HAMBURGER (mobil)
   ===================================================== */

#hamburgerbox { cursor: pointer; transition: all ease 0.3s; }
#hamburger    { padding: 0.625rem 0 0.0625rem; }

#hhbart, #hhbarm, #hhbarb {
  width: 2.125rem; height: 0.125rem;
  background-color: var(--txt);
  margin: 0 0 0.4375rem;
  transition: all ease 0.3s;
}
#hhbarm { width: 1.9375rem; }
#hamburger:hover #hhbart,
#hamburger:hover #hhbarm,
#hamburger:hover #hhbarb { background-color: var(--high); }

/* Hamburger → X Animation */
.hhani #hhbart { width: 2.125rem; transform: rotate(45deg) translate(7px, 10px); }
.hhani #hhbarm { opacity: 0; }
.hhani #hhbarb { width: 2.125rem; transform: rotate(-45deg) translate(3px, -5px); }
.hhbox .priarrow { margin: 5.6875rem 0 0 -1.5rem; }


/* =====================================================
   6. NAVIGATION (mobil + desktop)
   ===================================================== */

.naviwrap {
  display: flex;
  align-items: center;
  padding: 0.5rem 0 0;
  transition: all 0.3s ease;
}

nav {
  line-height: 1.5;
  position: absolute;
  left: 0; top: 100%;
  display: none;
  height: 250vh;
  width: 100%; max-width: 350px;
  background-color: rgba(var(--rgbwhite), 0.97);
  border-top: 1px solid var(--borderdropbox);
  box-shadow: 0 18px 14px -8px rgba(var(--rgbblack), 0.05),
              14px 8px 14px -4px rgba(var(--rgbblack), 0.1),
              -14px 8px 14px -4px rgba(var(--rgbblack), 0.1);
  z-index: 200;
}

.navigation   { position: relative; }
.naviheadmobil{ padding: 1rem 0 0.5rem 1rem; border-bottom: 1px solid var(--borderdropbox); }
.navdummy     { display: none; }

/* Erste Nav-Ebene */
.onebox { width: 100%; font-size: 1rem; background-color: var(--white); transition: background-color 0.3s ease; }
.onebox:hover { background-color: var(--high); }
.onebox:active{ background-color: var(--activ); }
.onebox a { display: block; color: var(--txt); text-decoration: none; }
.onebox a:hover { color: var(--txtwhite); }
.onebox:hover .onelink { color: var(--txtwhite); cursor: pointer; }
.onelink {
  display: block; width: 100%;
  padding: 0.5rem 0 0.5rem 1rem;
  letter-spacing: 0.0625rem;
  border-bottom: 1px solid var(--bordertop);
  cursor: pointer;
}
.bordertop { border-top: 1px solid var(--bordertop); }

/* Zweite Nav-Ebene */
.twowarp {
  position: absolute; top: -1px; left: 0;
  width: 100%; min-height: 250vh;
  padding: 0 0 1rem;
  border-top: 1px solid var(--borderdropbox);
  background-color: var(--white);
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
  opacity: 0;
}
.twobox   { width: 100%; max-width: 350px; color: var(--txt); overflow: hidden; }
.twolink  { width: 100%; display: block; padding: 0.5rem 0 0.5rem 1rem; background-color: var(--white); border-bottom: 1px solid var(--bordernorm); cursor: pointer; overflow: hidden; }
.twoall   { background-color: rgba(var(--rgbmain), 0.15); }
.twolink:hover  { color: var(--txtwhite); background-color: var(--navhigh); }
.twolink:active { color: var(--txtwhite); background-color: var(--activ); }
.twoback  { padding: 0.5rem 0 0.5rem 1.5rem; color: var(--txt); background: var(--twobackbg) url('arrowprev.svg') no-repeat left 0.5rem center; transition: all 0.25s ease; }
.twoback:hover  { color: var(--txtwhite); background: var(--navhigh) url('arrowprev-wht.svg') no-repeat left 0.5rem center; }
.twoback:active { color: var(--txtwhite); background: var(--activ) url('arrowprev-wht.svg') no-repeat left 0.5rem center; }
.twounter { padding: 0.5rem 2rem 0.5rem 1rem; background: var(--white) url('arrownext.svg') no-repeat right 1.5rem center; transition: all 0.25s ease; }
.twounter:hover  { background: var(--navhigh) url('arrownext-wht.svg') no-repeat right 1.5rem center; }
.twounter:active { background: var(--activ) url('arrownext-wht.svg') no-repeat right 1.5rem center; }
.mkatopen { -webkit-transform: translate3d(0,0,0) !important; transform: translate3d(0,0,0) !important; opacity: 1 !important; }
.onebox:first-child .ktwowarp { top: 0; }

/* Mobil-Nav Icons */
.mobil .onelink       { text-transform: none; letter-spacing: 0; }
.mobil .mlogin        { padding-left: 2.5rem; background: url('user.svg') no-repeat left 1rem center; }
.mobil .mlogin:hover  { background: url('user-over.svg') no-repeat left 1rem center; }
.mobil .mkasse        { padding-left: 2.5rem; background: url('coin-euro-grey.svg') no-repeat left 1rem center; }
.mobil .mkasse:hover  { background: url('coin-euro-wht.svg') no-repeat left 1rem center; }
.mobil .mwk           { padding-left: 2.5rem; background: url('warenkorb.svg') no-repeat left 1rem center; }
.mobil .mwk:hover     { background: url('warenkorbwht.svg') no-repeat left 1rem center; }
.mobil .mmz           { padding-left: 2.5rem; background: url('heart-grey.svg') no-repeat left 1rem center; }
.mobil .mmz:hover     { background: url('heart-wht.svg') no-repeat left 1rem center; }
.mobil .mlanguage     { padding-left: 2.5rem; background: url('flag.svg') no-repeat left 1rem center; }
.mobil .mlanguage:hover { background: url('flag-wht.svg') no-repeat left 1rem center; }

/* Listen-Navigation (Sidebar) */
.lstmenubox, .menubox { display: none; }
.mobilnavbtn     { padding: 0 2.25rem 0 0; cursor: pointer; }
.mobilnavbtndown { text-align: left; background: url('arrowdown.svg') no-repeat center right 1rem; }
.mobilnavbtndown:hover { color: var(--high); background: url('arrowdown-over.svg') no-repeat center right 1rem; }
.mobilnavbtnup   { text-align: left; background: url('arrowup.svg') no-repeat center right 1rem; }
.mobilnavbtnup:hover { color: var(--high); background: url('arrowup-over.svg') no-repeat center right 1rem; }
.lstmenubox {
  position: absolute; top: 0; left: 0.625rem;
  width: calc(100% - 1.25rem); max-width: 320px;
  padding-top: 1rem;
  background-color: var(--white);
  z-index: 5;
  box-shadow: 0 8px 14px -4px rgba(var(--rgbblack), 0.075),
              14px 8px 14px 4px rgba(var(--rgbblack), 0.075),
              -14px 8px 14px 2px rgba(var(--rgbblack), 0.075);
}

.naviborder   { padding: 0.5rem 0.25rem; border: 1px solid var(--bordernorm); border-radius: 5px; }
.listennavi ul { list-style: none; }
.listennavi a, .listennavi a:hover { text-decoration: none; }
ul#navisub { padding: 0; }
ul#navisub ul { position: relative; padding: 0 0 0 0.625rem; margin: 0.5rem 0 0; border-top: 1px solid var(--bordernorm); border-bottom: 1px solid var(--bordernorm); }
ul#navisub ul::before { position: absolute; content: ""; width: 0; height: 0; border-style: solid; top: 0; left: 0; margin: auto; border-width: 6px 6px 0 6px; border-color: var(--high) transparent transparent transparent; }
.listennavi ul li a, .navihead { display: block; width: 100%; padding: 0 0 0.25rem; margin: 0 0 0.5rem; font-size: 1.125rem; line-height: 1.4; font-weight: 300; text-transform: uppercase; letter-spacing: 0.0625rem; color: var(--txt); border-bottom: 1px solid #d9d9d9; }
.listennavi ul li a:hover { color: var(--high); }
.listennavi ul li ul li { padding: 0.5rem 0; }
.listennavi ul li ul li a { padding: 0; margin: 0; font-size: 0.875rem; line-height: 1.4; border-bottom: none; text-transform: none; letter-spacing: normal; color: var(--txt); cursor: pointer; }
.listennavi ul li ul li a:hover, .listennavi ul li.firston a { color: var(--high); }
.listennavi ul li ul li a.katfett, .listennavi ul li ul li.katfett a { color: var(--links); }
.listennavi ul li ul li a.katfett:hover, .listennavi ul li ul li.katfett a:hover { color: var(--high); }
.listennavi ul li ul li.katfett li a, .listennavi ul li.firston ul li a { color: var(--txt); }
.listennavi ul li ul li.katfett li a:hover, .listennavi ul li.firston ul li a:hover { color: var(--high); }
.listennavi ul li ul li.katfett a.txtfett, .listennavi ul li ul li.katfett a { color: var(--black); padding: 0 1.25rem 0 0; background: url('arrownext-blk.svg') right center no-repeat; background-size: 1.125rem; font-weight: 400; }
.listennavi ul li ul li ul li.katfett a { color: var(--black); padding: 0 1.25rem 0 0; background: url('arrownext-blk.svg') right center no-repeat; background-size: 1.125rem; font-weight: 400; }
.listennavi ul li ul li.katfett ul li a { color: var(--txt); padding: 0 1.25rem 0 0; background: none; font-weight: 300; }
.listennavi ul li ul li a { font-size: 0.9375rem; }


/* =====================================================
   7. HEADER-TOOLS (Suche, Konto, Warenkorb, Merkliste)
   ===================================================== */

.htoolsheight   { height: 2.8125rem; }
.hsmallboxes    { width: 2.8125rem; transition: all 0.3s; }
.hsmallboxes svg path { fill: var(--txtwhite); }
.hsmallboxes a, .hsmallboxes svg path { color: var(--hfill); fill: var(--hfill); text-decoration: none; transition: all 0.3s; }
.hsmallboxes .dropbox a, .hsmallboxes .dropbox a svg path { color: var(--txt); fill: var(--txt); }
.hsmallboxes a:hover, .hsmallboxes:hover svg path, .hsmallboxes:hover { color: var(--hfillhigh); fill: var(--hfillhigh); }
.hsmallboxes:hover .headbubble, .hsmallboxes:hover .headbubble svg path, .hsmallboxes .btnlink:hover { fill: var(--txtwhite); background: var(--hfillhigh); }
.hsmallboxes .btnlink:hover  { color: var(--txtwhite); background: var(--btnover); }
.hsmallboxes .btnlink:active { color: var(--txtwhite); background: var(--btnactive); }
.headiconbox    { height: 100%; width: 100%; cursor: pointer; }
.headiconbox svg { height: 1.25rem; width: auto; }
.prisides .headiconbox svg { height: 1rem; width: auto; }
.headbubble { position: absolute; top: 0; right: 0; min-width: 18px; padding: 3px; font-size: 10px; line-height: 12px; text-align: center; color: var(--txtwhite); background-color: var(--bubble); border-radius: 9px; transition: all 0.3s; }
.headbubble svg { width: 0.625rem; height: 0.625rem; vertical-align: middle; }
.headbubble svg path { fill: var(--txtwhite); }

/* Dropdown-Box */
.dropbox {
  display: none; position: absolute;
  top: calc(100% + 22px);
  padding: 0.625rem 1.25rem;
  background: rgba(var(--rgbwhite), .96);
  border-top: 1px solid var(--borderdropbox);
  transition: top 0.3s;
  border-bottom-left-radius: 3px; border-bottom-right-radius: 3px;
  box-shadow: 0 18px 14px -8px rgba(var(--rgbblack), 0.05),
              14px 8px 14px -4px rgba(var(--rgbblack), 0.1),
              -14px 8px 14px -4px rgba(var(--rgbblack), 0.1);
  color: var(--txt); white-space: normal; z-index: 5;
}

/* Pfeil vor Dropdowns */
.priarrow { display: none; position: absolute; top: calc(100% + 3px); width: 0; right: calc(50% + 12px); transition: top 0.3s; z-index: 1101; }
.priarrow::before, .priarrow::after { content: ""; width: 0; height: 0; border-style: solid; border-width: 10px 12px; border-color: transparent transparent var(--borderdropbox) transparent; position: absolute; top: 0; left: 0; right: 0; }
.priarrow::after { border-color: transparent transparent var(--white) transparent; top: 1px; }
.hhani .priarrow { top: calc(100% + 2px); display: block; }
.koani { display: block; }
.onebox .koani { display: none; }

/* Sprachauswahl */
.prisprachen { top: 100%; right: -10px; }
.hsprachen   { display: none; left: -45px; min-width: 135px; line-height: 1.8; }
.hsprachen a { padding: 0 0 0 24px; background: url('checkbox-unchecked.svg') left center no-repeat; }
.hsprachen a:hover  { color: var(--high); background: url('checkbox-unchecked-over.svg') left center no-repeat; text-decoration: none; }
.hsprachen a.txtaktiv { background: url('checkbox-checked.svg') left center no-repeat; }
.hsprachen a.txtaktiv:hover { background: url('checkbox-checked-over.svg') left center no-repeat; }

/* Konto Dropdown */
.hkontotool { right: calc((-100% * 2) - 10px); width: 100vw; max-width: 360px; overflow-y: auto; }
.hloginbox  { padding: 0.25rem 0 1rem; }
.hpwforgot  { top: 81px; right: 0; }
#hkontotxt  { padding: 1rem 0 0.5rem; border-top: 1px solid var(--borderdropbox); }
#hkontotxt h2 { padding: 0 0 0.5rem; margin: 0; }
#hkontolink { color: var(--txtwhite); }

/* Warenkorb Vorschau */
.prevwkbox  { right: -10px; width: 100vw; max-width: 450px; overflow-y: auto; }
.prevwkbox form { display: block; }
.prevwkpbox { padding: 0.75rem 0; border-bottom: 1px solid var(--bordernorm); }
.prwkimgb   { position: relative; width: 20%; padding-top: 20%; border-radius: 3px; }
.prwkimgb img { display: inline; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; max-width: 100%; max-height: 100%; border-radius: 3px; vertical-align: bottom; }
.prwkbezb   { width: 50%; padding: 0 0 0 0.5rem; font-size: 0.875rem; line-height: 1.3; }
.prwkbez    { padding: 0 0 0.25rem; font-size: 0.875rem; }
.prwkpdatabez { display: inline-block; width: 40%; }
.prwkpdata  { display: inline-block; width: 60%; }
.prwkgpb    { width: 30%; line-height: 1.3; }
#prevwktotalbox { line-height: 46px; padding: 4px 0 0; border-bottom: 1px solid var(--bordernorm); }
#prwktotal  { display: inline-block; width: 30%; }
#lblprwktotal { display: inline-block; width: 70%; }
#prevwkeditbox { padding: 1.25rem 0 0; font-size: 0.875rem; }
.prevwkbtnboxs { padding: 0.75rem 0 1.25rem; }
.prevwkbox .btnsublink { min-width: 45%; }
.prevwkbox a.btnlink { min-width: 45%; color: var(--txtwhite); }
#prevwkbtnbox div { cursor: pointer; }

/* Merkliste Vorschau */
.prevmzbox  { right: calc(-100% - 10px); }
.prmzbezb   { width: 80%; }

/* Suche */
#suchbox    { left: -55px; width: 100vw; max-width: 360px; padding: 1rem 1.25rem; }
#hsbox      { width: 100%; margin: 0 auto; border: 1px solid var(--bordertop); border-radius: 3px; }

/* BUGFIX: doppeltes ";;" entfernt */
.suchbegriff {
  width: calc(100% - 36px);
  height: 2.25rem;
  padding: 0 0 0 0.75rem;
  font-size: 0.875rem;
  line-height: 2.125rem;
  color: var(--txt);
  background-color: var(--txtwhite);
  border: 0 none;
  -webkit-appearance: none;
  transition: all 0.3s ease;
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}
.suchbegriff:focus { border: 1px solid var(--txt); background-color: var(--white); }
.suchbtn {
  width: 2.25rem; line-height: 2rem; padding: 0;
  background: var(--btn) url('search-wht.svg') center no-repeat; background-size: 1rem;
  border: none; border-top-right-radius: 3px; border-bottom-right-radius: 3px;
  cursor: pointer; -webkit-appearance: none; transition: all 0.3s ease;
}
.suchbtn:hover  { background: var(--btnover)  url('search-wht.svg') center no-repeat; background-size: 16px; }
.suchbtn:active { background: var(--btnactive) url('search-wht.svg') center no-repeat; background-size: 16px; }

/* Live-Suche Ergebnisse */
#slbox      { min-width: 300px; padding: 0.5rem 0; background-color: var(--white); z-index: 203; transition: all 0.25s ease; }
.slwimg     { -webkit-animation: livesucheImg 2s steps(240) infinite; animation: livesucheImg 2s steps(240) infinite; position: absolute; display: inline-block; top: 0.25rem; left: 0; right: 0; margin: auto; width: 3rem; height: auto; padding: 0.625rem; border: 1px solid var(--borderdropbox); border-radius: 50%; background: rgba(var(--rgbwhite), 0.9); z-index: 10004; }
@keyframes livesucheImg {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
#sldatabox  { padding: 0.5rem 0; }
.itemboxsl  { padding: 0.375rem 0; }
#slbox a:hover { color: var(--txt); }
.itemsl     { padding: 0 1% 0 1%; margin: 1.25rem 0 0; border-radius: 3px; }
.itemslwb   { border-radius: 3px; }
.slitemimgbox { position: relative; width: 12%; padding-top: 12%; min-width: 12%; border-radius: 3px; }
.itembezsl  { padding: 0 0 0 0.75rem; }
.zuletztbox .slitemimgbox { width: 17%; padding-top: 17%; min-width: 17%; }


/* =====================================================
   8. BREADCRUMB & CONTENT-BEREICH
   ===================================================== */

#lstcontent, .contentbox { width: 100%; }
.kruemel    { color: #959595; line-height: 1.25rem; }
.kruemel a  { color: var(--txt); text-decoration: none; white-space: nowrap; }
.kruemel a:hover  { color: var(--high); text-decoration: none; }
.kruemel a:active { color: var(--activ); text-decoration: none; }
.kreumelbox { display: inline; }

#lstcontent .ptfull h1 { margin: 0 0 1rem; }


/* =====================================================
   9. PRODUKT-KATEGORIE & LISTING
   ===================================================== */

.lstkatdetailimg { width: 100%; height: 21.25rem; border-bottom-left-radius: 3px; border-bottom-right-radius: 3px; }
.katbezicon  { width: 42px; min-height: 100%; }
.lstkdbezopen  { background: url('arrowup.svg') center no-repeat; }
.lstkdbezclose { background: url('arrowdown.svg') center no-repeat; }
#lstkatbez   { font-size: 1.25rem; padding: 0 0 1rem; }

.itemwarp, .zubwarp { margin: 1.25rem 0; }

/* Kategorie-Kacheln */
.katwarp {
  width: calc(50% - 1.25rem);
  padding: 0;
  margin: 1.25rem 0.625rem;
  border: 1px solid #dddddd;
  border-radius: 3px;
}
.katwarp:hover { border: 1px solid var(--high); }

.subkatbox  { height: 100%; border-radius: 3px; cursor: pointer; transition: background-color, background-size, box-shadow 0.35s ease; }
.subkatbox:hover { box-shadow: 0 2px 4px 0 rgba(var(--rgbblack), 0.1); }
.kataloglink { position: static; padding: 0.5rem; font-size: 0.875rem; text-align: center; font-weight: 400; transition: all 0.35s ease; }

/* Farbfilter */
.filtercbbox { padding: 12px 0 0; background-color: var(--white); border-top: 1px solid var(--borderdropbox); }
.filtercbbox > div { min-width: 50px; padding: 5px 10px; }
.filtercb:checked, .filtercb:not(:checked) { background: transparent; position: relative; opacity: 0; margin: 0; padding: 0; width: 1.875rem; height: 1.875rem; }
.filtercbbez { width: 30px; height: 0; overflow: hidden; }
.filtercb:checked + .filtercbbez::before,
.filtercb:not(:checked) + .filtercbbez::before { position: absolute; top: 5px; left: 10px; width: 30px; height: 30px; margin: auto; content: ""; border-radius: 50%; cursor: pointer; }
.filtercb:checked + .fc-blau.filtercbbez::before,    .filtercb:not(:checked) + .fc-blau.filtercbbez::before    { background-color: var(--blau); }
.filtercb:checked + .fc-bronze.filtercbbez::before,  .filtercb:not(:checked) + .fc-bronze.filtercbbez::before  { background: linear-gradient(145deg, #ceab00 0%, #ceab00 30%, #ffd402 50%, #ceab00 70%, #ceab00 100%); }
.filtercb:checked + .fc-bunt.filtercbbez::before,    .filtercb:not(:checked) + .fc-bunt.filtercbbez::before    { background: linear-gradient(90deg, #3c8cff 0%, #d50000 20%, #ffff00 40%, #33cc00 60%, #ff8c23 80%, #6e2682 100%); }
.filtercb:checked + .fc-gelb.filtercbbez::before,    .filtercb:not(:checked) + .fc-gelb.filtercbbez::before    { background-color: var(--gelb); }
.filtercb:checked + .fc-gold.filtercbbez::before,    .filtercb:not(:checked) + .fc-gold.filtercbbez::before    { background: linear-gradient(145deg, #ffff00 0%, #ffff00 30%, #ffe990 50%, #ffff00 70%, #ffff00 100%); }
.filtercb:checked + .fc-grau.filtercbbez::before,    .filtercb:not(:checked) + .fc-grau.filtercbbez::before    { background-color: var(--borderdropbox); }
.filtercb:checked + .fc-gruen.filtercbbez::before,   .filtercb:not(:checked) + .fc-gruen.filtercbbez::before   { background-color: var(--gruen); }
.filtercb:checked + .fc-violett.filtercbbez::before, .filtercb:not(:checked) + .fc-violett.filtercbbez::before { background-color: var(--violett); }
.filtercb:checked + .fc-orange.filtercbbez::before,  .filtercb:not(:checked) + .fc-orange.filtercbbez::before  { background-color: var(--orange); }
.filtercb:checked + .fc-rosa.filtercbbez::before,    .filtercb:not(:checked) + .fc-rosa.filtercbbez::before    { background-color: var(--rosa); }
.filtercb:checked + .fc-rot.filtercbbez::before,     .filtercb:not(:checked) + .fc-rot.filtercbbez::before     { background-color: var(--error); }
.filtercb:checked + .fc-schwarz.filtercbbez::before, .filtercb:not(:checked) + .fc-schwarz.filtercbbez::before { background-color: var(--black); }
.filtercb:checked + .fc-silber.filtercbbez::before,  .filtercb:not(:checked) + .fc-silber.filtercbbez::before  { background: linear-gradient(145deg, #eeeeee 0%, #eeeeee 30%, var(--borderdropbox) 50%, #eeeeee 70%, #eeeeee 100%); }
.filtercb:checked + .fc-weiss.filtercbbez::before,   .filtercb:not(:checked) + .fc-weiss.filtercbbez::before   { width: 28px; height: 28px; background-color: var(--white); border: 1px solid var(--txtmidgrey); }
.filtercb:checked + .filtercbbez::after { position: absolute; top: 5px; left: 10px; width: 30px; height: 30px; margin: auto; content: ""; background: url('checkmark-wht.svg') center no-repeat; }
.filtercb:checked + .fc-weiss.filtercbbez::after,
.filtercb:checked + .fc-gelb.filtercbbez::after,
.filtercb:checked + .fc-silber.filtercbbez::after { background-image: url('checkmark.svg'); background-position: center; background-repeat: no-repeat; }

/* Lade-Animation Filter */
.filterimg { width: 4rem; height: auto; top: -100px; left: 0; right: 0; margin: auto; padding: 0.625rem; border: 1px solid var(--borderdropbox); border-radius: 50%; background-color: rgba(var(--rgbwhite), 0.5); z-index: 10004; -webkit-animation: filterimgrotate 2s steps(240) infinite; animation: filterimgrotate 2s steps(240) infinite; }
@keyframes filterimgrotate {
  0%   { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}


/* =====================================================
   10. PRODUKT-KACHELN & BILDER
   ===================================================== */

.homewarp, .zubwrap, .itemwarp, .galwrap, .suchwrap, .phgalwrap { width: 50%; }

.itembox::before, .zuletztbox::before, .homeboxes::before {
  display: block; position: absolute; content: '';
  top: 0; right: 0; bottom: 0; left: 0;
  border-radius: 3px; z-index: 1; cursor: pointer;
  background: transparent url(zoom-in.svg) center no-repeat; background-size: 0;
  transition: background-color, background-size, 0.35s ease;
}
.itembox:hover::before, .zuletztbox:hover::before, .homeboxes:hover::before { background-color: rgba(var(--rgbitem), 0.1); background-size: 4rem; }
.zuletztbox:hover::before { background-size: 1.5rem; }
.itembox:active::before, .zuletztbox:active::before, .homeboxes:active::before, .subkatbox:active::before { background-color: rgba(var(--rgbactiv), 0.1); background-size: 4rem; }
.zuletztbox:active::before { background-size: 1.5rem; }

.itemimgbox, .itemimgfit { position: relative; padding-top: 100%; width: 100%; border-radius: 3px; }
.itemimgbox img, .slitemimgbox img { position: absolute; left: 0; right: 0; bottom: 0; margin: auto; max-width: 100%; max-height: 100%; border-radius: 3px; }
.zuletztbox img { top: 0; }

.subkatbox .itemimgbox { overflow: hidden; }
.subkatbox .itemimgbox img { border-bottom-left-radius: 0; border-bottom-right-radius: 0; transition: all 0.3s ease-in-out; }
.subkatbox:hover .itemimgbox img { transform: scale(1.06); }

.itemimgfit img, .slitemimg { position: absolute; top: 0; left: 0; margin: auto; width: 100%; height: 100%; object-fit: cover; object-position: center; }

/* Artikel-Badges */
.itemspecials        { top: 0.5rem; left: 0; font-weight: 400; }
.itemspecials div    { padding: 0.125rem 0.5rem; }
.itemstreichep       { color: var(--black); background-color: var(--gelb); }
.itemaktionsep       { color: var(--txtwhite); background-color: var(--orange); }
.itemrabatt          { color: var(--black); background-color: var(--bestandgruen); }
.itemhot             { color: var(--txtwhite); background-color: var(--links); }
.itemnew             { color: var(--white); background-color: var(--itemnewbg); }

/* Bestandsanzeige */
.dbestand        { font-size: 0.75rem; }
.dbestandverf    { color: var(--bestandgruen); }
.dbestandgering  { color: var(--bestandorange); }
.dbestandnicht   { color: var(--blau); }
.dbestandanfrage { color: var(--error); }

/* Listing-Sortierung */
.blackfont { color: #353535; background-color: rgba(var(--rgbmain), 0.05); margin: 1rem 0.625rem 0; padding: 1rem; }
.lstsort   { width: auto; -webkit-appearance: none; -webkit-border-radius: 3px; padding: 6px 36px 4px 8px; color: var(--txt); border: 1px solid #cccccc; border-radius: 3px; background: url('arrowdown.svg') no-repeat right center; cursor: pointer; }
.btnpages  { display: inline-block; width: 2rem; line-height: 2rem; margin: 0.5rem 0.125rem 0; text-decoration: none; background-color: var(--black); color: var(--txtwhite); border-radius: 3px; transition: all 0.2s ease; }
.btnpages:hover  { color: var(--txtwhite); background: var(--high); text-decoration: none; }
.btnpages:active { color: var(--txtwhite); background-color: var(--activ); text-decoration: none; }
.btnpagesa, .pagesno { display: inline-block; width: 2rem; line-height: 2rem; margin: 0.5rem 0.125rem 0; color: var(--txtwhite); background-color: var(--high); border-radius: 3px; }
.pagesno { width: 1.5rem; margin: 0.5rem 0 0; color: var(--txt); background-color: transparent; }

/* Keine Kategorie in Breadcrumb */
.dkruemelnokat        { display: none; }
.dkruemelnokat:last-child { display: inline; }
#dherstellerimg { height: 32px; width: auto; }


/* =====================================================
   11. PRODUKT-DETAIL
   ===================================================== */

.dcolleft  { width: 100%; }
.dcolright { width: 100%; }
.dimg      { float: none; clear: left; max-width: 100%; height: auto; max-height: 37.5rem; }
.dimggal   { max-height: 2.625rem; width: auto; margin: 0.625rem 0.25rem 0; }
.dcolleft .itemspecials { top: 1.5rem; left: 0.625rem; }

/* Fancybox Galerie */
.fancybox-nav span { width: 20px !important; height: 64px !important; background-color: rgba(var(--rgbmain), 0.5); background-position: center !important; background-repeat: no-repeat; background-size: 20px; border-radius: 3px; visibility: visible !important; transition: all 0.3s ease; }
.fancybox-next span { background-image: url('arrownext-wht.svg') !important; }
.fancybox-prev span { background-image: url('arrowprev-wht.svg') !important; }
.fancybox-nav:hover span { background-color: var(--high); }
.fancybox-close { background-color: rgba(var(--rgbmain), 0.5); background-image: url('cancel-wht.svg') !important; background-size: 24px; background-position: center !important; background-repeat: no-repeat; border-radius: 50%; transition: all 0.3s ease; }
.fancybox-close:hover { background-color: var(--high); background-size: 24px; }

/* Detail-Tools & Icons */
.dtoolbox  { padding: 0.625rem 0 0.5rem; border-bottom: 1px solid var(--bordertop); }
.iconsize  { padding: 0 0 0 1.5rem; background: url('stats-bars2-link.svg') left center no-repeat; }
.iconsize:hover  { background: url('stats-bars2-over.svg') left center no-repeat; }
.iconsize:active { background: url('stats-bars2-active.svg') left center no-repeat; }
.iconemail { padding: 0 0 0 1.5rem; background: url('mail-link.svg') left center no-repeat; }
.iconemail:hover  { background: url('mail-over.svg') left center no-repeat; }
.iconemail:active { background: url('mail-active.svg') left center no-repeat; }
a.ddokuicon { padding: 0 0 0 1.5rem; background: url('file-pdf-link.svg') left top 2px no-repeat; }
a.ddokuicon:hover  { background: url('file-pdf-over.svg') left top 2px no-repeat; }
a.ddokuicon:active { background: url('file-pdf-active.svg') left top 2px no-repeat; }
a.btnpdf   { padding-left: 2.75rem; background: url('file-pdf-grey.svg') left 1.25rem center no-repeat; }
a.btnpdf:hover, .btnpdf:active { background-image: url('file-pdf-wht.svg'); background-position: left 1.25rem center; }

/* Preis */
.depbxs  { padding: 0; vertical-align: baseline; }
.dep     { font-size: 1.5rem; vertical-align: baseline; color: var(--black); font-weight: 400; }
.dwaehr  { padding: 0 0 0 3px; font-size: 1.0625rem; vertical-align: baseline; color: var(--black); }
.dmwstbox{ font-size: 0.75rem; line-height: 1rem; vertical-align: baseline; }

/* In den Warenkorb */
.dvarianten div select { margin: 0.25rem 0 1rem; padding: 0.75rem 0.1875rem 0.75rem 0.625rem; }
.daddwkepbox { width: 100%; }
#dinputbox   { top: -120px; left: 0; }
.ankztxterror { border-color: var(--error); background: var(--lockedbg); }
.daddwkquant { margin: 0 20% 1rem; width: 60%; height: 2.5rem; font-size: 1rem; line-height: 2.5rem; text-align: center; color: var(--txtdarkgrey); background-color: var(--txtwhite); border-left: none; border-right: none; border-top: 1px solid var(--bordertop); border-bottom: 1px solid var(--bordertop); padding: 0; }
.daddwkquant:focus { background-color: var(--white); }
.daddwkbtn {
  -webkit-appearance: none; -webkit-border-radius: 3px;
  width: 100%; padding: 0 0 0 20px; height: 2.5rem;
  font-size: 0.875rem; line-height: 2.5rem; text-align: center;
  color: var(--txtwhite); text-decoration: none; border: none; display: block; cursor: pointer;
  background-color: var(--btnaddwk);
  background-image: url('warenkorbwht.svg'); background-position: calc(50% - 70px) center; background-repeat: no-repeat; background-size: 1.25rem auto;
  transition: all 0.3s linear;
}
.daddwkbtn:hover  { color: var(--txtwhite); background-color: var(--activ); background-image: url('warenkorbwht.svg'); text-decoration: none; }
.daddwkbtn:active { color: var(--txtwhite); background-color: var(--bggruen); background-image: url('warenkorbwht.svg'); text-decoration: none; }
.danfragebtn { background-image: url('bubble2-wht.svg'); background-position: calc(50% - 55px) center; background-repeat: no-repeat; }
.danfragebtn:hover, .danfragebtn:active { background-image: url('bubble2-wht.svg'); background-position: calc(50% - 55px) center; background-repeat: no-repeat; }

/* Mengen-Stepper */
#daddwkup, #daddwkdown { position: absolute; top: 0; width: 20%; height: 2rem; line-height: 2rem; color: var(--txt); background: var(--bordertop); cursor: pointer; transition: all 0.25s linear; }
#daddwkup { left: 80%; }
#daddwkdown { left: 0; }
.btnwkup, .btnwkdown { position: absolute; top: 0; width: 20%; height: 2.5rem !important; line-height: 2.5rem; text-align: center; font-weight: 300; color: var(--txt); background: var(--bordertop); cursor: pointer; }
.btnwkup  { left: 80%; border-top-right-radius: 3px; border-bottom-right-radius: 3px; }
.btnwkdown{ left: 0;   border-top-left-radius: 3px;  border-bottom-left-radius: 3px; }
#daddwkup::before, .btnwkup::before   { position: absolute; content: ""; width: 0; height: 0; border-style: solid; top: 0; left: 0; right: 0; bottom: 0; margin: auto; border-width: 0 8px 8px; border-color: transparent transparent var(--txt) transparent; }
#daddwkdown::before, .btnwkdown::before { position: absolute; content: ""; width: 0; height: 0; border-style: solid; top: 0; left: 0; right: 0; bottom: 0; margin: auto; border-width: 8px 8px 0; border-color: var(--txt) transparent transparent transparent; }
#daddwkup:hover, #daddwkdown:hover, .btnwkup:hover, .btnwkdown:hover { background: var(--high); }
#daddwkup:active, #daddwkdown:active, .btnwkup:active, .btnwkdown:active { background: var(--bggruen); }
#daddwkup:hover::before, .btnwkup:hover::before, #daddwkup:active::before, .btnwkup:active::before { border-color: transparent transparent var(--txtwhite) transparent; }
#daddwkdown:hover::before, .btnwkdown:hover::before, #daddwkdown:active::before, .btnwkdown:active::before { border-color: var(--txtwhite) transparent transparent transparent; }
#daddwk_LabelME { top: -101px; left: 0; }
#daddwk_Unit    { top: -78px; left: 0; max-width: 200px; }
.meunitplace    { padding: 5.5rem 0 0; }

/* Merken */
.btndmerk { color: var(--txt); background: transparent url('heart-grey.svg') left center no-repeat; background-size: 1rem auto; border: none; padding: 0 0 0 1.25rem; cursor: pointer; }
.btndmerk:hover { color: var(--high); background: transparent url('heart-over.svg') left center no-repeat; background-size: 1rem auto; }
.btndmerk:active, .dmzok { color: var(--bggruen); padding: 0 0 0 1.25rem; background: transparent url('heart-green.svg') left center no-repeat; background-size: 1rem auto; }

.dtxtboxes    { margin: 3rem 1.25rem 0; border-top: 1px solid var(--bordernorm); }
.dtxtboxhead  { display: block; padding: 2rem 0; color: var(--txt); font-size: 1.5rem; }

/* Bild-Größen im Content */
.halfimgbox   { padding: 50% 0 0; }
img.bild400   { display: block; width: 100%; max-width: 25rem; margin: 0 auto; }
img.bild600   { display: block; width: 100%; max-width: 37.5rem; margin: 0 auto; }
img.bild800   { display: block; width: 100%; max-width: 50rem; margin: 0 auto; }

/* Dokument-Downloads */
.downloads a { display: inline-block; min-height: 1.25rem; }
.downloads a[href$='.pdf'] { background: url('file-pdf-link.svg') left center no-repeat; background-size: 1.25rem auto; padding-left: 1.75rem; }
.downloads a[href$='.pdf']:hover  { background-image: url('file-pdf-over.svg'); }
.downloads a[href$='.pdf']:active { background-image: url('file-pdf-active.svg'); }
.downloads a[href$='.zip'] { background: url('cloud-download-link.svg') left center no-repeat; background-size: 1.25rem auto; padding-left: 1.75rem; }
.downloads a[href$='.zip']:hover  { background-image: url('cloud-download-over.svg'); }
.downloads a[href$='.zip']:active { background-image: url('cloud-download-active.svg'); }

/* Sizetable */
.sizetable table { width: 100%; border-collapse: collapse; }
.sizetable table tr:first-child td { border-bottom: 1px solid var(--bordermid); }
.sizetable table tr:nth-child(odd) td { background-color: var(--bordernorm); }
.sizetable table tr td { padding: 0.25rem; vertical-align: middle; text-align: center; border-right: 2px solid var(--white); }
.sizetable table tr td:first-child { width: 25%; padding: 0.5rem 0.5rem 0.5rem 0.25rem; border-right: 2px solid var(--white); text-align: left; }
.sizetable table tr td:last-child { border-right: none; }
.sizetable table tr:last-child td:first-child { text-align: center; }


/* =====================================================
   12. WARENKORB & CHECKOUT
   ===================================================== */

.freeshipbox   { color: var(--txtwhite); background-color: var(--shipnofree); border: 1px solid var(--txt); }
.freeshipttxt  { padding: 0.5rem; z-index: 4; }
.freeshiptogo  { top: 0; left: 0; height: 100%; background-color: var(--bestandgruen); z-index: 2; }
.freeshipok    { padding: 0.5rem; color: var(--txtwhite); background-color: var(--bestandgruen); border: 1px solid var(--txt); }
.orderborder   { padding: 0.75rem 0; border-bottom: 3px double var(--bordermid); }

#wkposliste    { padding: 1.5rem 0 0; border-top: 1px solid var(--borderdropbox); }
#wkposwarp form{ width: 100%; }
.wklockedbg    { background-color: var(--lockedbg); }
.wkpboxes      { padding: 0.75rem 0; border-bottom: 1px solid var(--borderdropbox); }
.wkpboxes .errorall { margin-bottom: 0.5rem; }
.kasposborder  { padding: 0 0 1rem; margin-bottom: 1rem; border-bottom: 1px solid var(--borderdropbox); }

.wkpimg, .kaspimg { width: 20%; }
.wkposbezb, .kasposbezb { width: 80%; padding: 0 0 0 1rem; }
.mt0l24m   { white-space: nowrap; }
.wkkasbez  { font-size: 1rem; }
.wkpdatabez{ display: inline-block; width: 30%; }
.wkpdata   { display: inline-block; width: 70%; }
.wkpmenge  { max-width: 14rem; }
.wkpgp     { width: 100%; }
.wkpdel    { text-align: left; }
.wkdel     { color: var(--txt); background: url('abfalleimer.svg') left center no-repeat; background-size: 0.875rem; padding: 0 0 0 1.25rem; }
.wkdel:hover  { color: var(--error); background: url('abfalleimer-over.svg') left center no-repeat; background-size: 0.875rem; padding: 0 0 0 1.25rem; }
.wkdel:active { color: var(--ok); background: url('abfalleimer-active.svg') left center no-repeat; background-size: 0.875rem; padding: 0 0 0 1.25rem; }

.posimg    { display: inline-block; max-width: 100%; height: auto; max-height: 10rem; }
.wkqw      { width: calc(100% - 50px); position: relative; }
.wkqw .daddwkquant { width: 60%; margin: 0 20%; }
.wkrefrbox { width: 40px; margin: 0 0 0 10px; }
.btnrefresh { -webkit-appearance: none; -webkit-border-radius: 3px; width: 100%; height: 2.5rem !important; line-height: 2.5rem; font-size: 1.75rem; padding: 0 0 0.375rem; border: none; font-weight: bold; color: var(--txt); text-align: center; cursor: pointer; background: var(--bordertop) url('refresh.svg') center no-repeat; background-size: 1rem; border-radius: 3px; transition: all 0.3s ease; }
.btnrefresh:hover  { color: var(--txtwhite); background: var(--high)   url('refresh-wht.svg') center no-repeat; background-size: 1rem; }
.btnrefresh:active { color: var(--txtwhite); background: var(--activ)  url('refresh-wht.svg') center no-repeat; background-size: 1rem; }

.totalbezbox { width: 60%; }
.totalpreisbox { width: 40%; }
.ordmid      { font-size: 0.875rem; }
.ordbig      { font-size: 1.25rem; }
.orderbr33   { flex: 0 0 100%; }

.kasheadbox h2, .kasheadbox div { min-width: 45%; }
.kasheadbox a, .kasheadbox a svg path, #kaswklink svg path, .orderinfobtn, .orderinfobtn svg path { color: var(--links); fill: var(--links); }
.kasheadbox a:hover, .kasheadbox a:hover svg path, #kaswklink:hover svg path, .orderinfobtn:hover, .orderinfobtn:hover svg path { color: var(--high); fill: var(--high); }
.kasheadbox a:active, .kasheadbox a:active svg path, #kaswklink:active svg path, .orderinfobtn:active, .orderinfobtn:active svg path { color: var(--activ); fill: var(--activ); }
.regheadlink svg, .kasheadbox svg { vertical-align: middle; }

/* Zahlungsauswahl */
.auswheadbox { border-bottom: 1px solid var(--borderdropbox); margin: 0 0 0.625rem; }
.auswahlbox  { padding: 0.375rem 0; }
#payselect form  { display: block; }
#payselect label { display: inline-block; width: 100%; }
.txtuncheck, .txtcheck { position: relative; padding: 0 0 0 1.6875rem; cursor: pointer; }
.txtcheck::before, .txtuncheck::before { position: absolute; top: 0.0625rem; left: 0; margin: auto; }
.txtuncheck::before { content: url('checkbox-unchecked.svg'); }
.txtcheck::before   { content: url('checkbox-checked-active.svg'); }
.paybox  { position: relative; }
.paybez  { padding: 0 0 0 0.5rem; cursor: pointer; }
.paybes  { padding: 0.25rem 0 0 1.625rem; }
.payradio:checked, .payradio:not(:checked) { background: transparent; position: relative; visibility: hidden; margin: 0; padding: 0; width: 1.125rem; height: 1.125rem; }
.payradio:checked + .paybez::before, .payradio:not(:checked) + .paybez::before { position: absolute; top: 0; left: 0; margin: auto; content: url('checkbox-unchecked.svg'); }
.payradioppp:checked + .paybez::before, .payradioppp:not(:checked) + .paybez::before { top: 0.6875rem; }
.payradio:checked + .paybez::before { content: url('checkbox-checked-active.svg'); }
.payradio:checked + .paybez, .txtcheck { color: var(--bggruen); font-weight: 500; }
.txtuncheck:hover::before, .payradio:not(:checked):hover + .paybez::before   { content: url('checkbox-unchecked-over.svg'); }
.txtuncheck:active::before, .payradio:not(:checked):active + .paybez::before { content: url('checkbox-unchecked-active.svg'); }
.txtuncheck:hover, .payradio:not(:checked):hover + .paybez   { color: var(--high); }
.txtuncheck:active, .payradio:not(:checked):active + .paybez { color: var(--bggruen); }

/* AGB & Bestellen */
.adrswitch      { margin: 0.25rem 0 0 0.375rem; height: 2.3125rem; line-height: 2.3125rem; }
.adrswitch::before { top: 0.25rem; }
.kastxtfull     { height: 4rem; }
#kasagbbox      { flex-grow: 1; font-size: 0.75rem; }
#kasagbbox a    { text-decoration: underline; }
.kasagbbg { padding: 1rem; background-color: rgba(var(--rgberror), 0.03); border: 1px solid var(--error); transition: background-color, border 0.3s ease-in-out; }
.kasagbok { padding: 1rem; background-color: rgba(var(--rgbok), 0.03); border: 1px solid var(--ok); }
#wkbottomwarp   { padding: 2rem 0.625rem 3rem; }
#wkbottom       { flex-wrap: wrap; min-height: 44px; }
#kasagbbox, #kasbestellenbox { width: 100%; }
#kasbestellenbox { margin-top: 1rem; }
.btnbestellen { width: 100%; color: var(--txtwhite); background-color: var(--bggruen); background-image: url('arrownext-wht.svg'); background-repeat: no-repeat; background-position: right 0.75rem center; }
.btnbestellen:hover { background-image: url('arrownext-wht.svg'); background-repeat: no-repeat; background-position: right 0.75rem center; }
.agbbez       { padding: 0 0 0 1.5rem; cursor: pointer; display: inline-block; }
.agbradio:checked, .agbradio:not(:checked) { background: transparent; position: relative; visibility: hidden; display: none; margin: 0; padding: 0; }
.agbradio:checked + .agbbez::before, .agbradio:not(:checked) + .agbbez::before { position: absolute; top: 2px; left: 0; margin: auto; content: url('checkbox-unchecked.svg'); }
.agbradio:checked + .agbbez::before { content: url('checkbox-checked-active.svg'); }
.agbradio:checked + .agbbez, .agbradio:checked + .agbbez a { color: var(--txt); }

#btnpppblocker  { display: none; position: absolute; left: 0; top: 0; width: 100%; height: 100%; padding-top: 0.625rem; background: rgba(var(--rgbblack), 0.9); z-index: 3001; color: var(--txtwhite); text-align: center; border-radius: 3px; }
#agbchecknot    { display: flex; position: absolute; left: 0; top: 0; width: 100%; height: 100%; background-color: var(--error); z-index: 300; color: var(--txtwhite); text-align: center; border-radius: 3px; }
.btnkasorduser  { font-weight: 300; font-size: 0.875rem; line-height: 1.6; color: var(--txtdarkgrey); margin: 0.75rem auto 0; }
.kasordbtnmuss  { color: var(--txtwhite); background-color: var(--black); }
.btnkasorduser:hover  { color: var(--txtwhite); background-color: var(--high); }
.btnkasorduser:active { color: var(--txtdarkgrey); }
#kasform .btnsublink  { display: inline-block; width: 50%; padding: 0; font-weight: 400; }
.kascheckerror  { position: absolute; top: 0; left: 0; background-color: var(--white); z-index: 6; }

/* =====================================================
   12b. KASSENSYSTEM-ERWEITERUNGEN (ehem. itb-20240718.css)
   ===================================================== */

.adrinput .ipfull, .adrinput .selfull, .adrplzort { width: 100%; }

#kasgutschein {
  display: flex;
  max-width: 360px;
  margin: 1rem auto 0;
}

#kasgutschein_neu {
  display: flex;
  flex-direction: column;
  margin: 1rem auto 0;
}

#kasgutschein_neu_Button { margin-top: 1rem; }

.kas_gutschein_infotext {
  margin-top: 1rem;
  color: var(--bestandgruen);
  font-weight: bold;
}

.kas_gutschein_label {
  color: var(--bestandgruen);
  margin-top: 1rem;
  font-weight: bold;
}


/* =====================================================
   13. MERKLISTE
   ===================================================== */

.mzpimg   { width: 4.375rem; }
.mzpbezb  { width: calc(100% - 4.375rem); padding: 0 0.25rem 0 0.5rem; }
.mzpgp    { width: 100%; max-width: 17rem; padding: 0 0 0 4.875rem; }


/* =====================================================
   14. KONTO-BEREICH
   ===================================================== */

.acclogoout { padding: 0 0 0 1.5rem; background: url('user-minus-link.svg') left center no-repeat; color: var(--black); text-decoration: none; transition: all 0.3s ease; }
.acclogoout:hover  { background: url('user-minus-over.svg') left center no-repeat; text-decoration: none; color: var(--high); }
.acclogoout:active { background: url('user-minus-active.svg') left center no-repeat; text-decoration: none; color: var(--activ); }

.anmservimg { margin: 0 0.5rem 0 0; }
.anmservices, .anmservices .anmservimg svg path { color: var(--black); fill: var(--txt); transition: all 0.3s ease; }
.anmservices:hover, .anmservices:hover .anmservimg path, .anmservices:hover .anmservimg svg path { color: var(--high); fill: var(--high); }
.anmservices:active, .anmservices:active .anmservimg path, .anmservices:active .anmservimg svg path { color: var(--activ); fill: var(--activ); }

#hloginuserbox a, #hloginuserbox svg path { color: var(--black); fill: var(--txt); transition: all 0.3s ease; }
#hloginuserbox .anmservices:hover, #hloginuserbox .anmservices:hover .anmservimg path { color: var(--high); fill: var(--high); }
#hloginuserbox .anmservices:active, #hloginuserbox .anmservices:active .anmservimg path { color: var(--activ); fill: var(--activ); }

/* Adress-Verwaltung */
.ktoadrbox    { width: 100%; border-bottom: 1px solid var(--bordertop); }
.ktoadrhead   { border-bottom: 1px solid #858585; font-size: 0.75rem; }
.adrleftbox   { flex-wrap: wrap; width: 70%; padding: 0.5rem 0; }
.adrrightbox  { width: 30%; max-width: 90px; padding: 0.5rem 0; }
.adrleftbox > div { width: 100%; }
div.adrplz { width: 50px; text-align: left; }
div.adrort { width: calc(100% - 50px); }
.ktoadrhead .adrrightbox { padding: 0.25rem 0; }
.btnadrselcet { width: 2rem; height: 2rem; border: 1px solid var(--borderdropbox); color: var(--txt); cursor: pointer; transition: all 0.25s ease; }
.btnadrre { background: var(--white) url('coin-euro-grey.svg') center no-repeat; }
.btnadrre:hover { background: var(--high) url('coin-euro-wht.svg') center no-repeat; border: 1px solid var(--high); }
.btnadrli { background: var(--white) url('truck-grey.svg') center no-repeat; }
.btnadrli:hover { background: var(--high) url('truck-wht.svg') center no-repeat; border: 1px solid var(--high); }
.btnadrre:active, .btnadrli:active { background-color: var(--bggruen); border: 1px solid var(--bggruen); }
.nobtnadrre { background: var(--bggruen) url('coin-euro-wht.svg') center no-repeat; border: 1px solid var(--bggruen); cursor: text; }
.nobtnadrli { background: var(--bggruen) url('truck-wht.svg') center no-repeat; border: 1px solid var(--bggruen); cursor: text; }
.adrinput .ipfull, .adrinput .selfull, .adrplzort { width: 65%; }
.adrinput .adrplzort .ipfull { width: 100%; }
.adrswitch { margin: 0.25rem 0 0 0.375rem; height: 2.3125rem; line-height: 2.3125rem; }
.adrswitch::before { top: 3px; }

/* Konto-Navigation */
.kontowrapper { flex-direction: column; }
.kontomenu    { flex-direction: column; }
.kontomenu a, .kontomenu > div { width: 100%; }
.kontonavi    { width: 30%; }

/* Upload */
.btnupload { min-width: 200px; line-height: 2rem; padding: 0.375rem 0.5rem 0.375rem 2.5rem; color: var(--txtwhite); background-color: var(--btn); background-image: url('folder-open-wht.svg'); background-repeat: no-repeat; background-size: 1.25rem; background-position: left 0.75rem center; transition: all ease 0.3s; }
.btnupload:hover { color: var(--txtwhite); background-color: var(--btnover); background-image: url('folder-open-wht.svg'); background-repeat: no-repeat; background-size: 1.25rem; background-position: left 0.75rem center; }
.btnuploadactiv { background-image: url('file-picture-wht.svg'); background-repeat: no-repeat; background-size: 1.25rem; background-position: left 0.75rem center; }
.btnuploadactiv:hover { background-image: url('file-picture-wht.svg'); background-repeat: no-repeat; background-size: 1.25rem; background-position: left 0.75rem center; }
.btnuploadreset { height: 2.75rem; width: 2.75rem; margin-left: 0.625rem; background: url('abfalleimer.svg') center no-repeat; background-size: 1.5rem; cursor: pointer; }
.btnuploadreset:hover { background-image: url('abfalleimer-over.svg'); }

/* Listen-Tabellen */
.lstrows > div, .lstrows > a { padding: 0.5rem 0.625rem; }
.lstrows > div:nth-child(even), .lstrows > a:nth-child(4n-2) { background-color: var(--lstrowsbg); }
.lstrows > a { transition: all 0.3s ease-in-out; }
.lstrows > a:hover  { color: var(--txtwhite); background-color: var(--high); }
.lstrows > a:active { color: var(--black); background-color: var(--activ); }
.lstheadbox { padding: 0 0.625rem; }
.lstcols5, .lstcols10, .lstcols12, .lstcols15, .lstcols20, .lstcols25, .lstcols30, .lstcols33, .lstcols40, .lstcols50, .lstcols60 { width: 100%; }
.lstcols65 { width: 65%; }
.lstcols35-s { width: 35%; }
.lstheadbox .lstcols50, .lstheadbox .lstcols10 { width: 50%; }
.lstrows .itemimgbox { width: 80px; min-width: 80px; padding-top: 80px; margin-right: 0.75rem; }
.lstrows .itemimgbox img { top: 0; }
.lstrows form { position: relative; }
.lstrows .daddwkbtn { max-width: 190px; margin-left: calc(100% - 190px); background-position: calc(50% - 70px) center; }
.lstrows #daddwkup, .lstrows #daddwkdown { width: 15%; }
.lstrows #daddwkup { left: 30%; }
.lieferkosten.dvarianten select { width: 100%; }
.lieferkosten.dvarianten form { display: flex; justify-content: space-between; flex-wrap: wrap; }


/* =====================================================
   15. CONTENT-TYPOGRAFIE (ptfull / pttxt)
   Design-Overrides in drb-brand.css
   ===================================================== */

.ptfull h1 { margin: 1rem 0 1.5rem; font-size: 1.6875rem; text-align: left; border: none; }
.ptfull h1.homehead { font-size: 1.9375rem; text-align: center; }
.ptfull h2, .ptfull h3, .pttxt h2, .pttxt h3 { margin: 1rem 0; text-align: left; }
.ptfull h2, .pttxt h2 { font-size: 1.4375rem; color: #353535; }
.ptfull h3, .pttxt h3 { font-size: 1.1875rem; color: #252525; }
.ptfull h4, .pttxt h4 { font-size: 1rem; font-weight: 600; color: #4a4a4a; text-align: left; }

.pttxt, .pttxt div, .pttxt span, .pttxt a,
.ptfull div, .ptfull p, .ptfull span, .ptfull li, .ptfull ul, .ptfull ol, .ptfull a, .ptfull img { font-family: inherit !important; font-size: inherit !important; color: var(--txt) !important; }
.pttxt a, .pttxt a div, .pttxt a span, .ptfull a, .ptfull a div, .ptfull a span { color: var(--links) !important; text-decoration: none !important; }
.pttxt a:hover, .pttxt a:hover span, .ptfull a:hover, .ptfull a:hover span { color: var(--high) !important; text-decoration: underline !important; }
.pttxt a:active, .pttxt a:active span, .ptfull a:active, .ptfull a:active span { color: var(--activ) !important; text-decoration: none !important; }
.ptfull ul, .ptfull ol, .pttxt ul, .pttxt ol { padding: 0.75rem 0 0.5rem 1rem; }
.ptfull li, .pttxt li { padding: 0.25rem 0 0.25rem 0.25rem; }
.ptfull a.txt13 { font-size: 0.75rem !important; }
.ptfull img, .pttxt img { max-width: 100%; height: auto; padding: 0.75rem 0; }
.ptfull svg, .txticon { display: inline-block; max-height: 0.875rem; width: auto; padding: 0; vertical-align: baseline; }

h1.homehead, h2.homehead { font-size: 1.9375rem; text-align: center; }


/* =====================================================
   16. ANSPRECHPARTNER & HÄNDLER
   ===================================================== */

.ansprechwidth { width: 50%; }
.ansprechwidth img { right: auto; }
.brhaendler    { width: 100%; }
.haendlerimgbox{ width: 110px; }
.haendlertxtbox{ width: calc(100% - 110px); }
.haendlerimg   { max-width: 110px; max-height: 110px; }
.plsl          { padding-left: 1rem; }


/* =====================================================
   17. USP & AKTIONEN (Startseite)
   ===================================================== */

.uspbgbox      { padding: 2rem 1rem; color: var(--txt); background: rgba(var(--rgbmain), 0.075); }
.uspbgbox h3   { font-size: 1.0625rem; }
.uspbgbox a, .uspbgbox a span { color: var(--links) !important; }

.aktbgbox      { background: rgba(var(--rgbmain), 0.075); padding: 1rem 1rem 4rem; }
.aktimgfit     { padding-top: 55%; width: 100%; background-color: var(--white); }
.aktimgfittop  { object-position: top center; }
.aktimgfit svg { position: absolute; top: 0; bottom: 0; left: 50%; margin: auto; width: 50%; height: 94%; object-fit: cover; object-position: center; }
.aktimgfit svg path { fill: #eeeeee; }
.aktlinkbox    { left: 0; bottom: 1rem; }


/* =====================================================
   18. FORMULARE (Kontakt, Newsletter)
   ===================================================== */

.formrow       { max-width: 600px; margin: 0 auto; }
.formrow form, .formrowfull form { display: flex; align-items: center; flex-wrap: wrap; order: 2; }
.formrow .ipfull { width: 60%; min-width: 15rem; padding: 0.3125rem 0.1875rem 0.3125rem 0.625rem; line-height: 2rem; }
.formrow .btnformfull { width: calc(40% - 1rem); min-width: 10rem; padding: 0.375rem 0; }
.formrow .errorall, .formrowfull .errorall { order: 1; }

.anmboxs       { flex: 1 1 100%; }
.plz           { padding-right: 1rem; }


/* =====================================================
   19. FOOTER
   ===================================================== */

footer { padding: 3rem 0 0; }
.footnewlwarp  { background: rgba(221,221,221,0.5); padding: 3rem 0; }
.footnewslbox  { max-width: 35.25rem; margin: 0 auto; }
.fnewlsinput   { padding: 0 0.1875rem 0 0.625rem; width: calc(100% - 44px); height: 2.75rem; line-height: 2.75rem; background-color: var(--white); border-top: 1px solid var(--borderdropbox); border-left: 1px solid var(--borderdropbox); border-bottom: 1px solid var(--borderdropbox); border-top-left-radius: 3px; border-bottom-left-radius: 3px; vertical-align: middle; }
.fnewlsbtn     { height: 2.75rem; width: 2.75rem; min-width: auto; background-color: var(--btn); background-image: url('arrownext-wht.svg'); background-repeat: no-repeat; background-position: center; background-size: 32px; border-top-right-radius: 3px; border-bottom-right-radius: 3px; }
.footwarp      { background: rgba(221,221,221,0.9); color: var(--txt); }
.footwarp a    { color: var(--txt); text-decoration: none; }
.footwarp a:hover  { color: var(--high); text-decoration: none; }
.footwarp a:active { color: var(--activ); text-decoration: none; }
.footcols      { flex: 1 1 100%; min-width: 10rem; padding: 0.625rem; }
.footcols li, .footcols a { padding: 0.125rem 0; }
.footcols a.newtab { padding-right: 1.25rem; }
.footcols .kasheadbox { padding: 1rem 0 0.25rem; margin: 0 0 1rem; border-bottom: 1px solid #d2d2d2; }
.footpartner   { background: #d0d0d0; }
.footpartner h3{ margin: 0; padding: 0 0 1rem; color: var(--txt); font-size: 1rem; }
.footend       { background-color: #bdbdbd; }

/* "Nach oben" Button */
.gotop         { position: fixed; right: 0.5rem; bottom: 0.5rem; width: 42px; height: 42px; border-radius: 3px; z-index: 20000; }
.gotop a       { border-radius: 3px; }
.gotop div     { height: 42px; background-color: var(--btn); border-radius: 3px; box-shadow: 0 1px 3px 1px rgba(var(--rgbblack), 0.2); }
.gotop svg     { width: 2rem; height: auto; }
.gotop:hover div  { background-color: var(--btnover); }
.gotop:active div { background-color: var(--btnactive); }


/* =====================================================
   20. SPEZIAL-KOMPONENTEN
   ===================================================== */

/* Tracking */
.trackwrapper  { min-height: 22.5rem; background-color: var(--txtwhite); }
.trackbox      { max-width: 40rem; }
.minsbox       { min-width: 300px; }

/* Cookie-Consent */
.consentfix    { position: fixed; top: 0; left: 0; right: 0; width: 50%; min-width: 360px; max-width: 550px; max-height: 100vh; margin: auto; background-color: var(--white); box-shadow: 0 0 10px 3px rgba(var(--rgbblack), 0.4); z-index: 30000; overflow: auto; border-bottom-left-radius: 3px; border-bottom-right-radius: 3px; }
.consentfix #logobox { height: 60px; }
.consentfix #logobox img { max-height: 60px; margin: 0; }
.btnconsent    { margin: 0.375rem 5%; }
.forder1 { order: 1; }
.forder2 { order: 2; }
#consentcmd .btnlink        { color: var(--txtwhite); background-color: var(--black); letter-spacing: 0.0625rem; }
#consentcmd .btnlink:hover  { color: var(--txtwhite); background-color: var(--high); text-decoration: none; }
#consentcmd .btnlink:active { color: var(--txtwhite); background-color: var(--activ); text-decoration: none; }
#consentcmd .btnsublink        { color: #9a9a9a; background-color: var(--bordertop); }
#consentcmd .btnsublink:hover  { color: var(--txtwhite); background-color: var(--high); text-decoration: none; }
#consentcmd .btnsublink:active { color: #7e7e7e; background-color: #d1d1d1; text-decoration: none; }

.trackptopen, .loginptopen { cursor: pointer; white-space: nowrap; color: var(--link); }
.trackptopen:hover, .loginptopen:hover   { color: var(--high); }
.trackptopen:active, .loginptopen:active { color: var(--activ); }
.contsentptbox { color: var(--txtmidgrey); }
.contsentptbox .ptfull, .contsentptbox .ptfull div, .contsentptbox .ptfull span, .contsentptbox .ptfull p, .contsentptbox .ptfull a { font-size: 0.8125rem !important; }
.cshead        { padding: 0 0 0.25rem; margin-bottom: 0.5rem; border-bottom: 1px solid var(--borderdropbox); }
.trackclose, .loginclose { padding: 0.25rem 0.75rem; line-height: 1.4; font-size: 0.8125rem !important; font-weight: 400; color: #4f4f4f; background-color: var(--bordertop); }
.topclose      { margin-bottom: -50px; }

/* System-Parameterbox (Entwicklung) */
.syspara    { position: fixed; bottom: 1.5rem; left: 0; padding: 0.25rem 0.5rem; color: var(--txtwhite); background-color: var(--violett); z-index: 222222; }
.syshomelink{ bottom: 3.5rem; background-color: var(--orange); }

/* Button-Varianten */
.btnicon    { font-weight: 400; min-width: 12.5rem; }
.btnicon svg{ vertical-align: middle; }
.btnicon:hover svg path { fill: #f8f8f8; }
.btndown    { text-align: left; background: url('arrowdown.svg') right 1rem center no-repeat; }
.btndown:hover { background-image: url('arrowdown-wht.svg'); background-position: right 1rem center; }
.btnup      { text-align: left; background: url('arrowup.svg') right 1rem center no-repeat; }
.btnup:hover { background-image: url('arrowup-wht.svg'); background-position: right 1rem center; }


/* =====================================================
   21. SLICK SLIDER BIBLIOTHEK
   (embedded, 1:1 aus drb-carousel-20240718.css)
   ===================================================== */

.slick-slider { position: relative; display: block; box-sizing: border-box; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-touch-callout: none; -khtml-user-select: none; -ms-touch-action: pan-y; touch-action: pan-y; -webkit-tap-highlight-color: transparent; }
.slick-list   { position: relative; display: block; overflow: hidden; margin: 0; padding: 0; }
.slick-list:focus { outline: none; }
.slick-list.dragging { cursor: pointer; cursor: hand; }
.slick-slider .slick-track,
.slick-slider .slick-list { -webkit-transform: translate3d(0,0,0); -moz-transform: translate3d(0,0,0); -ms-transform: translate3d(0,0,0); -o-transform: translate3d(0,0,0); transform: translate3d(0,0,0); }
.slick-track  { position: relative; top: 0; left: 0; display: block; margin-left: auto; margin-right: auto; }
.slick-track:before, .slick-track:after { display: table; content: ''; }
.slick-track:after { clear: both; }
.slick-loading .slick-track { visibility: hidden; }
.slick-slide  { display: none; float: left; height: 100%; min-height: 1px; }
[dir='rtl'] .slick-slide { float: right; }
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none; }
.slick-slide.dragging img { pointer-events: none; }
.slick-initialized .slick-slide { display: block; }
.slick-loading .slick-slide { visibility: hidden; }
.slick-vertical .slick-slide { display: block; height: auto; border: 1px solid transparent; }
.slick-arrow.slick-hidden { display: none; }
.slick-loading .slick-list { background: var(--white) url(spinner-grey.svg) center no-repeat; }

/* Slider Pfeile */
.slick-prev, .slick-next { position: absolute; top: 50%; display: block; width: 20px; height: 64px; padding: 0; -webkit-transform: translate(0,-50%); -ms-transform: translate(0,-50%); transform: translate(0,-50%); cursor: pointer; color: transparent; border: none; outline: none; z-index: 11; border-radius: 3px; background-color: rgba(var(--rgbwhite), 0.6); }
.slick-slider:hover .slick-prev, .slick-slider:hover .slick-next { background-color: rgba(var(--rgbwhite), 0.9); }
.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus { color: transparent; outline: none; }
.slick-prev:hover::before { background: var(--white) url('arrowprev-blk.svg') center no-repeat; background-size: 24px 32px; }
.slick-next:hover::before { background: var(--white) url('arrownext-blk.svg') center no-repeat; background-size: 24px 32px; }
.slick-prev.slick-disabled::before, .slick-next.slick-disabled::before { opacity: .25; }
.slick-prev::before, .slick-next::before { position: absolute; top: 0; left: 0; height: 64px; width: 20px; border-radius: 3px; }
.slick-prev { left: 0; }
.hero .slick-prev { left: 1.25rem; }
.slick-prev::before, .slick-next::before { content: ' '; background-size: 24px 32px; background-position: center; background-repeat: no-repeat; }
.slick-prev::before { background-image: url('arrowprev.svg'); }
.slick-next::before { background-image: url('arrownext.svg'); }
.slick-next { right: 0; }
.hero .slick-next { right: 1.25rem; }


/* =====================================================
   22. HERO-CAROUSEL
   ===================================================== */

.herolink    { left: 0; top: 0; height: 100%; }
.herobgbox   { display: none; }
.herowidth   { max-width: 1920px; }
.herotxtbox  { top: 0; left: 0; right: 0; bottom: 0; margin: auto; }
.hero h2, .hero h4 { color: var(--txtwhite); font-weight: 400; text-shadow: 0 0 4px var(--txt); }
.hero h2 { font-size: 1rem; }
.hero h4 { font-size: 0.825rem; }

/* Hero-Button (Basis — Design-Override in drb-brand.css) */
.herobtn {
  color: var(--txtwhite);
  background-color: var(--btn);
  padding: 0.75rem 1.25rem;
  border-radius: 3px;
  box-shadow: 0 0 4px 0 var(--txt);
  font-size: 1rem;
  font-weight: 400;
  text-transform: uppercase;
  text-decoration: none;
  letter-spacing: 0.0625rem;
  width: 100%;
  margin-top: 1.5rem;
}
.herobtn:hover { color: var(--txtwhite); background-color: var(--btnover); text-decoration: none; }
.herobtnspace  { width: 25vw; }

/* Slide-Animationen */
.slick-active .animated { animation-duration: 1s; animation-fill-mode: both; }
.slick-active .fadeinup-animated h2  { animation-delay: 1s;   animation-name: fadeInUp; }
.slick-active .fadeinup-animated h4  { animation-delay: 1.6s; animation-name: fadeInUp; }
.slick-active .fadeinup-animated div { animation-delay: 1.5s; animation-name: fadeInUp; }
@keyframes fadeInUp {
  from { opacity: 0; transform: translate3d(0,100%,0); }
  to   { opacity: 1; transform: none; }
}
.fadeInUp { animation-name: fadeInUp; }

/* Hero-Hintergründe
   BEKANNTE BUGS (werden nach Konsolidierung gefixt):
   - herobg-blau und herobg-lila sind identisch
   - herobg-orange rendert grau (nutzt --bordernorm)
   - herobg-gruen rendert dunkelgrau (nutzt --txtmidgrey) */
.herobg-lila   { background: var(--links); background: linear-gradient(to bottom, var(--links) 0%, var(--high) 100%); }
.herobg-blau   { background: var(--links); background: linear-gradient(to bottom, var(--links) 0%, var(--high) 100%); }
.herobg-orange { background: var(--bordernorm); background: linear-gradient(to bottom, var(--bordernorm) 0%, var(--borderdropbox) 100%); }
.herobg-gruen  { background: var(--txtmidgrey); background: linear-gradient(to bottom, var(--txtmidgrey) 0%, var(--txtdarkgrey) 100%); }


/* =====================================================
   23. RESPONSIVE BREAKPOINTS
   Alle @media-Regeln an einem Ort.
   ===================================================== */

@media screen and (min-width: 400px) {
  .flexdxs { display: flex; }
  #navsuche { margin-left: 2.8125rem; }
  #suchbox  { left: -100px; }
  .kontomenu { flex-direction: row; }
  .kontomenu a, .kontomenu > div { width: 50%; }
}

@media screen and (min-width: 500px) {
  /* itb-20240718.css — kassensystem */
  .zurKasseLink { margin-top: 1rem; }

  .prirightbox { display: block; }
  .zubwrap     { width: 33.333%; }
  .katwarp     { width: calc(33.333% - 1.25rem); }
  .kataloglink { font-size: 1rem; }
  .dcolleft, .dcolright, .brl25 { width: 50%; }
  .orderbr33   { flex: 1 0 40%; }
  .ansprechwidth { width: 33.33%; }
  .footcols    { flex: 1 1 48%; }

  /* Hero */
  .hero h2 { font-size: 1.5rem; }
  .hero h4 { font-size: 1rem; }
}

@media screen and (min-width: 600px) {
  .brc50, .brl33 { width: 50%; }
  .navdummy { display: block; }
  .flexds   { display: flex; }
  .itemwarp, .galwrap, .suchwrap, .phgalwrap, .homewarp { width: 33.33%; }
  .dcolleft  { width: 40%; }
  .dcolright { width: 60%; }
  .daddwkquant { margin: 0 40px 1rem; width: 20%; }
  .daddwkbtn   { float: right; width: calc((100% - 20%) - 88px); margin: 0 0 1rem; }
  .danfragebtn { width: 100%; }
  #daddwkup, #daddwkdown { width: 40px; }
  #daddwkup  { left: calc(20% + 40px); }
  #daddwkdown{ left: 0; }
  .mt0l24m   { margin-left: 1.5rem; }
  .kaspimg   { width: 7%; }
  .wkposbezb { width: 60%; }
  .kasposbezb{ width: 73%; }
  .wkpgp     { width: 20%; }
  #wkbottomwarp { padding: 2rem 0.625rem 0; }
  #wkbottom  { flex-wrap: nowrap; }
  #kasagbbox, #kasbestellenbox { width: auto; }
  #kasbestellenbox { margin-top: 0; }
  .btnbestellen { max-width: 15rem; min-width: 12.5rem; }
  .printer   { padding-left: 24px; background: url('printer-link.svg') left center no-repeat; }
  .printer:hover  { background-image: url('printer-over.svg'); }
  .printer:active { background-image: url('printer-active.svg'); }
  .kontomenu a, .kontomenu > div { width: 33.33%; }
  .mzpimg    { width: 6.25rem; }
  .mzpbezb   { width: calc(70% - 6.25rem); }
  .mzpgp     { width: 30%; padding: 0; max-width: none; }
  .mzpgp .daddwkquant { width: calc(100% - 40%); margin: 0 0 1rem; }
  .mzpgp .daddwkbtn   { float: none; width: 100%; margin: 0; }
  #ptpartner .ptpartner div { flex: 1 1 20%; margin: 0 0.625rem 1.25rem; }
  #ptpartner .ptpartner img { max-width: 150px; max-height: 150px; }
  .brhaendler { width: 50%; }
  .lieferkosten.dvarianten select { width: 48%; }
}

@media screen and (min-width: 641px) {
  .herobtnbox { max-width: 640px; margin-left: auto; margin-right: auto; }
  .herobtn    { padding: 0.75rem 1.5rem; width: auto; }
}

@media screen and (min-width: 750px) {
  .brl50 { width: 50%; margin: 0 auto; }
  .brc33, .brl25 { width: 33.33%; }
  .br3-1 { width: 35%; }
  .br3-2 { width: 65%; }
  #suchbox { left: -90px; }
  .zubwrap { width: 25%; }
  .katwarp { width: calc(25% - 1.25rem); }
  .dnavibox a { padding: 0 1rem; }
  .dcolleft, .dcolright { width: 50%; }
  .dcolrightbot > div { width: 100%; }
  .dimggal   { max-height: 5rem; }
  .wkpimg    { width: 20%; }
  #kasposheadep { width: 73%; }
  .kaspbez   { width: 60%; }
  .kaspmeng  { width: 14%; text-align: center; }
  .totalbezbox  { width: 80%; }
  .totalpreisbox{ width: 20%; }
  .orderbr33 { flex: 1 1 30%; }
  .anmboxs   { flex: 1 1 26%; }
  .anmboxs:first-child { flex: 1 1 100%; }
  .kontowrapper { flex-direction: row; }
  .kontonavi { width: 30%; }
  .kontowrapper .contentbox { width: 70%; }
  .kontomenu { flex-direction: column; }
  .kontomenu a, .kontomenu > div { width: 100%; }
  .adrleftbox { flex-wrap: nowrap; width: 86%; padding: 0.5rem 0; }
  .adrrightbox{ width: 14%; padding: 0.5rem 0; }
  .adrleftbox > div { width: 30%; }
  div.adrplz  { width: 8%; text-align: right; }
  div.adrort  { width: 15%; }
  div.adrland { width: 6%; }
  .ktoadrhead .adrleftbox > div { display: block; }
  .ktoadrhead > div { padding: 0.25rem 0; }
  .footcols  { flex: 1 1 30%; }

  /* Hero */
  .hero h2 { font-size: 3rem; }
  .hero h4 { font-size: 1.75rem; }
  .herobtn { padding: 0.75rem 2rem; }
}

@media screen and (min-width: 1000px) {
  .brl33 { width: 33.33%; }
  .brl25 { width: 25%; }
  .txtr-m { text-align: right; }
  .flexjustrm { justify-content: flex-start; }
  .flexjuspam { justify-content: space-between; }
  .order1m { order: 1; }
  .order2m { order: 2; }
  .order3m { order: 3; }
  .order4m { order: 4; }
  .mlss { margin-left: 1.25rem; }
  .mrss { margin-right: 1.25rem; }
  .pslnh    { padding: 0 2.5rem; }
  .plistnhxl{ padding: 0 0.625rem; }
  .plistsh  { padding: 1rem 0.625rem 0; }
  .pssnh    { padding: 0 1.25rem; }
  .pssxsh   { padding: 0.25rem 1.25rem 0; }
  .psssh    { padding: 0.5rem 1.25rem 0; }
  .pssmh    { padding: 1rem 1.25rem 0; }
  .psslh, .psslhxl { padding: 2rem 1.25rem 0; }
  .pssxlh   { padding: 3rem 1.25rem 0; }
  .pssxxlh  { padding: 4rem 1.25rem 0; }
  .errorcont, .okrightcont { margin: 2rem 1.25rem 0; }

  header    { height: 120px; }
  .headwbox { height: 120px; }
  #hamburgerbox { display: none; }
  .menueblocker { display: none !important; }

  .naviwrap { position: static; flex: 1 1 55%; padding: 0.5rem 0 0; border-top: 0 none; }
  nav {
    position: relative; top: auto; left: auto; height: 100%;
    display: flex !important;
    justify-content: space-between; align-items: center;
    max-width: none; background-color: transparent;
    border-top: 0 none; box-shadow: 0 0 0 transparent;
  }
  nav a { text-decoration: none; }
  .navigation { display: flex; justify-content: center; align-items: center; width: 100%; height: 100%; min-height: 0; }
  .onebox a:hover { color: var(--hfillhigh); }
  .onebox { display: flex; justify-content: center; align-items: center; position: relative; width: auto; height: 100%; font-size: 0.875rem; transition: none; background: transparent; border-bottom: 0 none transparent !important; }
  .onebox:hover, .onebox:hover .onelink { color: var(--navhigh); background-color: transparent; }
  .onebox:active, .onebox:active .onelink { color: var(--navhigh); background-color: transparent; }
  .onebox:hover .onelink { cursor: pointer; }
  .onelink { color: var(--high); padding: 0.6875rem 0.75rem; line-height: 1.5rem; border-bottom: 0 none transparent !important; cursor: pointer; }
  .onebox .koani { display: block; top: calc(100% - 21px); }
  .twowarp { display: none; position: absolute; top: calc(100% - 1px); left: -0.5rem; width: auto; min-height: inherit; min-width: 100%; white-space: nowrap; padding: 0; border-top: 1px solid var(--borderdropbox); transform: translate3d(0,0,0); opacity: 1; box-shadow: 0 8px 14px -4px rgba(var(--rgbblack), 0.075), 14px 8px 14px 4px rgba(var(--rgbblack), 0.075), -14px 8px 14px 2px rgba(var(--rgbblack), 0.075); z-index: 195; transition: none; }
  .twobox { max-width: 450px; overflow: hidden; }
  .onebox:first-child .ktwowarp { top: 0; }
  a.twoall  { display: none; }
  a.twolink { width: 100%; padding: 0.5rem 1.25rem; color: var(--txt); cursor: pointer; overflow: inherit; }
  a.twolink:hover  { color: var(--txtwhite); background-color: var(--navhigh); border-bottom: 1px solid var(--navhigh); }
  a.twolink:active { color: var(--txtwhite); background-color: var(--navactiv); border-bottom: 1px solid var(--navactiv); }
  .twoback  { display: none; }
  .twounter { background: transparent; transition: all 0.25s ease; }
  .twounter:hover, .twounter:active { background: transparent; }
  .onebox .priarrow::after { border-color: transparent transparent var(--oneboxbg) transparent; }
  #navsuche { margin-left: 0.5rem; }
  .navdummy { display: none; }
  #suchbox  { left: -155px; }
  .dropbox  { top: calc(100% + 32px); }
  .prisprachen { top: 100%; }
  .priarrow { top: calc(100% + 12px); }

  .menubox  { display: block; width: 25%; }
  .lstmenubox { display: block !important; position: static; width: 25%; max-width: none; box-shadow: 0 0 0; }
  .contentbox { width: 75%; }
  #lstkatimgbox { padding: 0 1.25rem; }

  .katwarp  { width: calc(33.333% - 2.5rem); padding: 0; margin: 1.25rem; }
  .hkatlst .katwarp { width: calc(20% - 2.5rem); padding: 0; margin: 1.25rem; }
  .homewarp { width: 25%; }
  .suchwrap { width: 25%; }
  .stwarp   { width: 50%; }
  .itemtest { width: 75%; }
  .stwarp .itemimgbox { width: 25%; padding: 25% 0 0; }
  .dcolleft .itemspecials { left: 1.25rem; }

  .blackfont { margin: 1rem 1.25rem 0; }
  #wkbottomwarp { padding: 2rem 1.25rem 0; }

  .anmboxs:first-child { flex: 1 1 30%; }
  .mzpimg  { width: 15%; }
  .mzpbezb { width: 65%; padding: 0 0.25rem 0 0.75rem; }
  .mzpgp   { width: 20%; }

  .kontonavi { width: 25%; }
  .kontowrapper .contentbox { width: 75%; }
  .phgalwrap { width: 25%; }

  .lstcols5  { width: 5%; }
  .lstcols10, .lstheadbox .lstcols10 { width: 10%; }
  .lstcols12 { width: 12.5%; }
  .lstcols15 { width: 15%; }
  .lstcols20 { width: 20%; }
  .lstcols25 { width: 25%; }
  .lstcols30 { width: 30%; }
  .lstcols33 { width: 33.33%; }
  .lstcols40 { width: 40%; }
  .lstcols50, .lstheadbox .lstcols50 { width: 50%; }
  .lstcols60 { width: 60%; }
  .lstcols65 { width: 65%; }
  .lstrows .daddwkbtn { width: calc(100% - 0.5rem); margin: 0 0 0 0.5rem; font-size: 0.8125rem; background-position: calc(50% - 58px) center; background-size: 1rem auto; }

  .brhaendler { width: 33.33%; }
  .ansprechwidth { width: 25%; }
  .footcols { flex: 1 1 23%; }
  .mhno  { display: block; }
  .mhyes { display: none; }
  .mobil, .mobilview { display: none; }

  /* Hero */
  .hero h2 { font-size: 3rem; }
  .hero h4 { font-size: 1.75rem; }
  .herobtn { padding: 0.75rem 2.5rem; font-size: 1.25rem; }
}

@media screen and (min-width: 1200px) {
  .naviwrap { padding: 0.5rem 2.8125rem 0 0.5rem; }
  .onebox   { font-size: 0.9375rem; }
  #navsuche { margin-left: 0.75rem; }
  .lstrows .daddwkbtn { font-size: 0.875rem; background-position: calc(50% - 70px) center; background-size: 1.25rem auto; }
}

@media screen and (min-width: 1921px) {
  .heroflex  { display: flex; align-items: stretch; }
  .herobgbox { display: block; flex: 1 1 20%; }
  .herobg    { background-color: var(--twobackbg); height: calc(100% + 0.0625rem); }
}
