body {
  font-weight: 200 !important;
  font-family: "Be Vietnam Pro", sans-serif !important;
}
.btn-black {
  color: white !important;
  background-color: black !important;
  padding-top: 10px;
  padding: 12px !important;
}
.btn-black:hover {
  color: white !important;
  background-color: black !important;
  padding: 12px !important;
}

.navbar.bg-dark {
  padding: 0;
}
/* ------------------------------------------------------------------- */
/* ----------------------------Banner -------------------------------- */
/* ------------------------------------------------------------------- */
.banner {
  background-color: #ededed;
  text-align: center;
  padding: 20px 0;
}
.toggle-description {
height:30px;
width:30px;
}
/*.description {
  padding-top: 100px;
  padding-bottom: 100px;
}*/

.heading {
  /*font-size: 2.5rem;*/
  line-height: 1.25;
  font-weight: 200;
  font-family: "Be Vietnam Pro", sans-serif;
  text-align: left;
}
.h1, h1 {
  font-size: calc(1.275rem + 1.5vw) !important;
}
@media (min-width: 1200px) {
  .h1, h1 {
    font-size: 2.5rem !important;
  }
}

.sub_heading {
  font-size: 1.25rem;
  font-weight: 300;
  line-height: 1.6;
  font-family: "Be Vietnam Pro", sans-serif;
  /*padding-bottom: 50px;*/
  margin: 0;
  text-align: left;
}

.image-column {
  padding: 25px 0;
}

@media (min-width: 1920px) {
  .description {
    /*margin-left: 434px !important;*/
    padding-top: 205px !important;
  }

  /*.image-column {
    margin-right: 434px !important;
  }*/

  .sub_heading {
    padding-bottom: 293px;
  }

  .container {
    /*max-width: calc(100% - 868px);*/
    margin: 0 auto;
  }
  .container-fluid.custom-container {
    /*max-width: calc(100% - 868px) !important;*/
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .products,
  .filter_container {
    max-width: calc(100% - 868px) !important;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0;
    padding-right: 0;
  }
}

/* ------------------------------------------------------------------- */
/* ----------------------------Filter -------------------------------- */
/* ------------------------------------------------------------------- */
#filter-options {
  margin: 0 auto;
  padding-left: 0;
  padding-right: 0;
}
.container {
  margin: 0 auto;
  padding: 15px;
  max-width: 1055px !important;
}
.container-fluid .row {
  max-width: 1055px !important;
  margin: 0 auto !important;
}

.mobile_filter_category,
.mobile_filter_Abonnements {
  padding-left: 0 !important;
}
@media (max-width: 991px) and (min-width: 768px) {
  .mobile_filter_Abonnements {
    padding-right: calc(var(--bs-gutter-x) * .5) !important;
    padding-left: calc(var(--bs-gutter-x) * .5) !important;
  }
  .mobile_filter_reset {
    padding-left: calc(var(--bs-gutter-x) * .5) !important;
  }
  .mobile_filter_category {
    padding-left: 0 !important;
  }
  .mobile_filter_price {
    padding-right: calc(var(--bs-gutter-x) * .5) !important;
    padding-left: 0 !important;
  }
}
@media (max-width: 767px) and (min-width: 577px) {
  .mobile_filter_Abonnements,
  .mobile_filter_pramie,
  .mobile_filter_Abonnements {
    padding-left: 0 !important;
    padding-right: calc(var(--bs-gutter-x) * .5) !important;
  }

  .mobile_filter_title,
  .mobile_filter_price,
  .mobile_filter_reset {
    padding-right: 0 !important;
    padding-left: calc(var(--bs-gutter-x) * .5) !important;
  }
}

/* Larger Screens */
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}

.dropdownIcon {
  width: 10px;
  height: 10px;
  position: absolute;
  right: 10px;
  top: 53%;
  transform: translateY(-50%);
}

#price-min-input,
#price-max-input {
  border-right: none !important;
  border-radius: 0;
  text-align: right;
  padding-right: 0;
  background-color: #ededed;
  border-color: #ededed;
}
#price-min-input:focus,
#price-max-input:focus,
#price-min-input:focus-visible,
#price-max-input:focus-visible {
  box-shadow: none !important;
}

.price-range-inputs {
  position: relative;
}
.price-range-inputs:after {
  content: '-';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.price-range-inputs .col-6:first-child {
  padding-left: 0 !important;
}
.price-range-inputs .col-6:last-child {
  padding-right: 0 !important;
}

.euro_sign {
  background-color: #ededed !important;
  border-radius: 0 !important;
  border-color: #ededed !important;
  padding-left: 5px !important;
  min-width: 45%;
}

.filter_container {
  font-size: 16px;
  line-height: 26px;
  color: #000;
  font-family: "Be Vietnam Pro", sans-serif;
  border: #bcbcbc;
}

.footer {
  background-color: #000;
  color: #fff;
  padding: 33px 0;
  text-align: center;
}

.white {
  background-color: white !important;
}

.pad {
  border-radius: 0 !important;
}

.card_custom {
  border-radius: 0 !important;
}

/* Checkbox Radius */
.form-check-input[type="checkbox"] {
  border-radius: 0px !important;
  width: 24px;
  height: 24px;
  margin-top: 0;
}

.form-check-input:checked {
  background-color: #fff !important;
  border-color: #bcbcbc !important;
}

.form-check-input:checked[type="checkbox"] {
  background-image: url(https://image.news.communication.dpv.de/lib/fe3b117175640474771473/m/1/73d35a06-3e9f-4d26-ae1a-ed1ec0d5f557.png) !important;
  background-size: 12px 12px !important;
  width: 24px;
  height: 24px;
}

.form-check-label {
  width: 100%;
}

/* Change Dropdown Icon */
.dropdown-toggle::after {
  display: none !important;
}

/* Filter */
.transparent,
.dropdown-toggle {
  border: 1px solid black !important;
  border-radius: 0 !important;
  background-color: transparent;
  border: 1px solid #bcbcbc !important;
  color: #000;
  padding: 15px 30px;
  font-size: 18px;
}
.fillter_text {
  font-weight: 200 !important;
  font-family: "Be Vietnam Pro", sans-serif !important;
}
.dropdown-toggle:hover,
.dropdown-toggle:focus {
  background-color: rgba(0, 0, 0, 0.1);
  border-color: #aaa;
  color: #000;
}

/*  dropdown menu */
.transparent,
.dropdown-menu {
  padding: 32px 16px !important;
  background-color: rgba(255, 255, 255, 0.9);
  border: 1px solid #ccc;
  border-radius: 0 !important;
  width: 200px;
}
.dropdown-menu.w-100.dropdown-menu--wider {
  width: calc(100% + 65px) !important;
  transform: translate(-35px, 40px) !important;
}

.transparent,
.dropdown-item {
  cursor: pointer;
}

.dropdown-item {
  padding: 8px 16px 8px 0 !important;
  line-height: 24px;
}

.dropdown-item:hover,
.dropdown-item:active {
  /*background-color: rgba(0, 0, 0, 0.05);*/
  background-color: transparent !important;
  color: inherit !important;
}

.range-input {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.range-input input {
  width: 40%;
  padding: 5px;
  text-align: center;
  border: 1px solid #ccc;
  border-radius: 5px;
}

/* range slider */
.range-slider {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  flex-direction: column;
}
.range-slider > div {
  position: absolute;
  display: flex;
  align-items: center;
  left: 0;
  right: 16px;
  height: 4px;
}

.range-slider > div > .range-slider-val-left, 
.range-slider > div > .range-slider-val-right, 
.range-slider > div > .range-slider-val-range {
  height: 4px;
}
.range-slider > div > .range-slider-val-left {
  position: absolute;
  left: 0;
  border-radius: 0;
  background-color: #f3f3f3;
  margin: 0;
}
.range-slider > div > .range-slider-val-right {
  position: absolute;
  right: 0;
  border-radius: 0;
  background-color: #f3f3f3;
  margin: 0;
}
.range-slider > div > .range-slider-val-range {
  position: absolute;
  left: 0;
  top: -1px;
  height: 4px;
  border-radius: 0;
  background-color: #000000;
}

.range-slider > div > .range-slider-handle {
  z-index: 1;
  position: absolute;
  top: -6px;
  margin: 0;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background-color: #000000;
  outline: none;
  cursor: pointer;
}

div.range-slider > input[type="range"]::-ms-thumb {
  width: 30px;
  height: 30px;
  border: 0 none;
  border-radius: 0;
  background: red;
  pointer-events: all;
}
div.range-slider > input[type="range"]::-moz-range-thumb {
  width: 30px;
  height: 30px;
  border: 0 none;
  border-radius: 0;
  background: red;
  pointer-events: all;
}
div.range-slider > input[type="range"]::-webkit-slider-thumb {
  width: 30px;
  height: 30px;
  border: 0 none;
  border-radius: 0;
  background: red;
  pointer-events: all;
  -webkit-appearance: none;
}
div.range-slider > input[type="range"]::-ms-fill-lower {
  background: transparent;
  border: 0 none;
}
div.range-slider > input[type="range"]::-ms-fill-upper {
  background: transparent;
  border: 0 none;
}

.range-slider > input[type="range"] {
  z-index: 1;
  /*position: absolute;*/
  width: 100%;
  height: 4px;
  opacity: 0;
  filter: alpha(opacity=0);
  cursor: pointer;
  /*pointer-events: none;*/
  -webkit-appearance: none;
}

div.range-slider > input[type="range"]::-ms-track {
  background: transparent;
  color: transparent;
  -webkit-appearance: none;
}
div.range-slider > input[type="range"]::-moz-range-track {
  background: transparent;
  color: transparent;
  -moz-appearance: none;
}
div.range-slider > input[type="range"]:focus::-webkit-slider-runnable-track {
  background: transparent;
  border: transparent;
}
div.range-slider > input[type="range"]:focus {
  outline: none;
}
div.range-slider > input[type="range"]::-ms-tooltip {
  display: none;
}

/* ------------------------------------------------------------------- */
/* ----------------------------Products -------------------------------- */
/* ------------------------------------------------------------------- */
.product-card {
  padding-bottom: 20px !important;
}
.color_black {
  color: #000000 !important;
}
.card-img-top {
  transition: transform 0.3s ease-in-out;
  width: 340px;
  height: 320px;
  border-radius: 0;
  object-fit: cover;
  object-position: top;
}

.card-img,
.card-img-top {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
.product-card .card-img-top {
  transition: transform 2s ease-in-out; /* Slow transition */
}

/*.product-card:hover .card-img-top {
  transform: scale(1.05);
}*/

.img-ipad {
  position: relative;
}
.img-ipad:before {
  content: '';
  position: absolute;
  width: 24px;
  height: 3px;
  border-radius: 2px 2px 0 0;
  right: 30px;
  top: -3px;
  background-color: darkgrey;
}
.img-ipad:after {
  content: '';
  position: absolute;
  width: 3px;
  height: 24px;
  border-radius: 0 2px 2px 0;
  right: -3px;
  top: 30px;
  background-color: darkgrey;
}
.img-ipad div:after {
  content: '';
  position: absolute;
  width: 3px;
  height: 24px;
  border-radius: 0 2px 2px 0;
  right: -3px;
  top: 60px;
  background-color: darkgrey;
}

@media (max-width: 767.98px) {
  .mobile-hidden {
    display: none;
  }
  .banner .heading,
  .banner .sub_heading {
    text-align: center;
  }

  .description {
    padding: 50px 0;
  }
  .logo-container img, .logo-container svg  {
    width: auto !important; /* was 220px */
    height: 100px !important; /* was 60px */
  }
  /*.logo-container{
    margin-top: -28px !important;
  }*/
   
  .card-img-top {
    height: 320px;
    width: 340px;
  }

  /*.product-card:hover .card-img-top {
    transform: scale(1.02);
  }*/
}

#toggle-filters-btn {
  transition: all 0.3s ease;
}

#toggle-filters-btn:hover {
  background-color: white;
  color: black;
  border-color: black;
}

/* Slider styling */
#range1 {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 8px;
  background: black;
  outline: none;
  opacity: 0.7;
  transition: opacity 0.2s;
}

#range1::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: black;
  cursor: pointer;
}

#range1::-moz-range-thumb {
  width: 20px;
  height: 20px;
  background: black; /* Thumb color */
  cursor: pointer;
}

#range1::-webkit-slider-runnable-track {
  width: 100%;
  height: 8px;
  background: black; /* Track color */
}

#range1::-moz-range-track {
  width: 100%;
  height: 8px;
  background: black; /* Track color */
}
/* Button Filter on Desktop */
.mobile-only {
  display: none !important;
}

.hide-on-mobile {
  display: block !important;
}
@media (max-width: 576px) {
  .mobile-only {
    display: flex !important;
    padding: 0 45px 30px !important;
  }

  .hide-on-mobile {
    display: none !important; 
  }
  .abbrechen{
    background-color: #A5AEB1 !important;
    font-weight: 500 !important;
  }
  .filtern{
    background-color: black !important;
    color: white !important;
    font-weight: 500 !important;
  }
  .container.filter_container {
    padding: 0 !important;
    margin-top: 0 !important;
  }
  #toggle-filters-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000; 
    width: 100%;
    border-radius: 10px 10px 0 0;
    background-color: #ffffff;
    padding: 20px 45px;
    margin: 0;
    -webkit-box-shadow: 0px 0px 50px -4px rgba(0,0,0,0.5);
    -moz-box-shadow: 0px 0px 50px -4px rgba(0,0,0,0.5);
    box-shadow: 0px 0px 50px -4px rgba(0,0,0,0.5);
    border: none !important;
  }

  /* Filter panel to cover the screen above the filter button */
  #filter-options {
    position: fixed;
    /*top: 43px; */
    top: 100%;
    bottom: 0px;
    left: 0;
    right: 0;
    background-color: white;
    z-index: 999; 
    max-height: 100%;/*calc(100vh - 38px);*/
    overflow-y: auto; 
    transition: transform 0.3s ease-in-out;
    /*transform: translateY(100%);*/
  }

  /* Slide up to show the filter panel */
  #filter-options.show {
    /*transform: translateY(0); */
    top: 43px;
  }
  /* Move the filter button to the top when clicked */
  #toggle-filters-btn.fixed-top {
    position: fixed;
    top: 0;
    bottom: auto;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    border-bottom: 1px solid #bcbcbc !important;
  }
  .dropdownIcon{
    display: none !important;
  }
  .dropdown-menu {
    display: block !important;
    position: relative; 
    border: none;
  }
  .dropdown-menu.w-100.dropdown-menu--wider {
    transform: initial !important;
    width: 100% !important;
  }
  .mobile_filter_category {
    /*padding-bottom: 152px !important;*/
    padding-top: 15px;
    border-radius: 0px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    min-height: 268px;
  }
  .mobile_filter_title {
    /*padding-bottom: 152px !important;*/
    padding-top: 15px;
    border-radius: 0px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    min-height: 1194px;
  }
  .mobile_filter_pramie {
    /*padding-bottom: 86px;*/
    border-radius: 0px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    min-height: 166px;
  }
  .mobile_filter_price {
    /*padding-bottom: 86px !important;*/
    border-radius: 0px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    min-height: 156px;
  }
  .mobile_filter_Abonnements {
    /*padding-bottom: 115px;*/
    border-radius: 0px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    min-height: 209px;
  }
  .mobile_filter_category .dropdown-menu,
  .mobile_filter_title .dropdown-menu,
  .mobile_filter_pramie .dropdown-menu,
  .mobile_filter_price .dropdown-menu,
  .mobile_filter_Abonnements .dropdown-menu,
  .mobile_filter_category .btn,
  .mobile_filter_title .btn,
  .mobile_filter_pramie .btn,
  .mobile_filter_price .btn,
  .mobile_filter_Abonnements .btn {
    border: none !important;
    padding-left: 45px !important;
    padding-right: 45px !important;
  }
  .mobile_filter_category .btn,
  .mobile_filter_title .btn,
  .mobile_filter_pramie .btn,
  .mobile_filter_price .btn,
  .mobile_filter_Abonnements .btn {
    border-top: 1px solid #bcbcbc !important;
  }
  .mobile_filter_reset {
    padding: 0 !important;
    border-radius: 0px !important;
  }
  .mobile_filter_reset .col-6:first-child {
    padding-left: 0 !important;
  }
  .mobile_filter_reset .col-6:last-child {
    padding-right: 0 !important;
  }
  .btn_mob_setting {
    border-bottom: none !important;
    text-align: left !important;
    /*padding-top: 30px !important;*/
    font-weight: 600 !important;
    /*padding-left: 24px !important;*/
    padding: 30px 45px 6px 45px !important;
  }
  .dropdown-menu {
    border-radius: 0 !important;
    padding: 0 24px 24px !important;
    border-top: none !important;
  }
  .dropdown-toggle {
    pointer-events: none; 
  }
  .dropdown-item {
    padding: 10px 0 !important;
  }

  .dropdown-menu h6 {
    display: none; 
  }

  .price-slider {
    padding-left: 25px;
    padding-right: 25px;
  }
  .price-slider.range-slider {
    width: calc(100% - 46px);
    margin-left: 22px;
  }
  .price-slider .price-range-inputs .col-6:first-child {
    padding-left: 0;
  }
  .price-slider .price-range-inputs .col-6:las-child {
    padding-right: 0;
  }
}
