/* Filter category */
#shop-sidebar:has(> .block-scroll.filter) {
  position: sticky;
  top: 0;
  z-index: 999;
}
.relative {
  position: relative !important;
}
.hide {
  display: none !important;
}
.scrolling_inner {
  position: relative;
}
.scrolling_inner.scroll-right::after {
  background: linear-gradient(
    to right,
    rgba(255 255 255/0),
    rgba(255 255 255/1)
  );
  content: "";
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  width: 40px;
}
.block-scroll.filter {
  background-color: #fff;
  position: sticky;
  top: 0;
  z-index: 999;
  padding: 0;
      height: 45px;
}
.block-scroll-main::-webkit-scrollbar {
  display: none;
}
.block-scroll-main {
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
}
.scrolling_inner {
  position: relative;
}
.block-scroll {
  position: relative;
  padding: 10px 0 15px;
}
.box-filter {
  background: #fff;
  font-size: 0;
  margin-left: 90px;
}
.filter-item.active .filter-item__title {
  border: 1px solid #4a90e2;
}
.filter-item {
  display: inline-block;
  font-size: 14px;
  line-height: 18px;
  margin-right: 8px;
  padding-bottom: 10px;
}
.filter-item__title {
  background-color: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  padding: 8px 10px;
}
.filter-item__title:hover {
  cursor: pointer;
}
.filter-item__title span {
  padding-right: 12px;
  position: relative;
}
.filter-item__title span::before {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid #333;
  content: "";
  height: 0;
  position: absolute;
  top: 6px;
  right: 0;
  width: 0;
}
.filter-item .arrow-filter {
  display: none;
}
.filter-total {
  background-color: #fff;
  left: 0;
  position: absolute;
  padding-bottom: 9px;
  top: 0;
  z-index: 3;
}
.filter-total i {
  margin-right: 5px;
}
.filter-total .number {
  background-color: #f89406;
  border-radius: 50%;
  color: #fff;
  font-size: 10px;
  height: 16px;
  line-height: 16px;
  position: absolute;
  top: -8px;
  text-align: center;
  right: 5px;
  width: 16px;
}
.filter-item.active .filter-show {
  display: block;
}
.filter-show {
  display: none;
  background-color: #fff;
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.5);
  border-radius: 4px;
  max-width: 100vw;
  left: 0;
  position: absolute;
  padding: 10px 10px 0 10px;
  top: 45px;
  width: 600px;
  white-space: normal;
  z-index: 3;
}
.filter-show--right {
  left: auto;
  right: 0;
}
.filter-list {
  display: flex;
  flex-wrap: wrap;
}
.c-btnbox {
  align-items: center;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  color: #333;
  display: flex;
  font-size: 14px;
  justify-content: center;
  line-height: 17px;
  margin-bottom: 10px;
  margin-right: 10px;
  padding: 8px 9px;
}
.filter-total i {
  margin-right: 5px;
}
.c-btnbox.check {
  border: 1px solid #2f80ed;
  color: #2f80ed;
}
.c-btnbox:hover {
  border: 1px solid #2f80ed;
}
.c-btnbox img {
  display: flex;
  justify-content: center;
  max-height: 52px;
  width: auto;
  max-width: 90%;
  object-fit: contain;
}
.filter-button {
  width: 100%;
  background-color: #fff;
  box-shadow: 0 -4px 8px rgba(0, 0, 0, 0.05);
  font-size: 0;
  margin: 8px -10px 0;
  padding: 8px 10px;
  text-align: center;
  display: block;
}
.btn-filter-close,
.btn-filter-readmore {
  border-radius: 4px;
  display: inline-block;
  font-size: 14px;
  line-height: 16px;
  margin: 0 5px;
  padding: 10px;
  text-align: center;
  width: auto;
  position: relative;
}
.btn-filter-close {
  border: 1px solid #dd1c1a;
  color: #dd1c1a;
}
.btn-filter-readmore {
  background-color: #288ad6;
  color: #fff;
}
.filter-button-sticky {
  bottom: 0;
  margin: 0;
  position: sticky;
  width: 100%;
  z-index: 2;
}
.filter-list {
  display: flex;
  flex-wrap: wrap;
}

.filter-list--hang .c-btnbox {
  height: 40px;
  margin-right: 0;
  margin-bottom: 0;
  padding: 0;
}
.filter-list--hang .c-btnbox:not(.hide):nth-child(4n) {
  margin-right: 0;
}
.show-total {
  display: none;
  background-color: #fff;
  height: 100%;
  left: 0;
  right: 0;
  margin: 0 auto;
  overflow: auto;
  position: fixed;
  padding: 53px 0 15vh;
  top: 0;
  width: 100%;
  max-width: 640px;
  z-index: 9;
}
.show-total__main {
  padding: 0 10px;
}
.show-total-txt {
  font-size: 14px;
  font-weight: bold;
  line-height: 17px;
  margin-bottom: 8px;
}
.show-total-item {
  margin-bottom: 10px;
}
.flt-fixbtn {
  background-color: #fff;
  border-bottom: 1px solid #e0e0e0;
  left: 0;
  right: 0;
  margin: 0 auto;
  position: fixed;
  padding: 6px 10px;
  top: 0;
  width: 100%;
  max-width: 640px;
  z-index: 13;
}
.btn-closefilter {
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  color: #333;
  float: right;
  font-size: 14px;
  line-height: 21px;
  padding: 5px 5px 5px 0;
  position: relative;
  text-align: right;
  width: 65px;
}
.btn-closefilter::before,
.btn-closefilter::after {
  background-color: #333;
  content: "";
  left: 15px;
  height: 10px;
  position: absolute;
  top: 10px;
  width: 1px;
}
.btn-closefilter::before {
  transform: rotate(45deg);
}
.btn-closefilter::after {
  transform: rotate(-45deg);
}
.bg-whitefix {
  bottom: 52px;
  background: linear-gradient(
    to bottom,
    rgba(255 255 255/0),
    rgba(255 255 255/0.7),
    #fff
  );
  height: 100px;
  position: fixed;
  right: 0;
  width: 100%;
  z-index: 1;
}
.txtnb-readmore {
  color: #333;
  font-size: 12px;
  float: right;
  line-height: 16px;
  position: relative;
  padding-right: 8px;
  margin-top: 8px;
}
.txtnb-readmore::before {
  border-top: 1px solid #333;
  border-right: 1px solid #333;
  content: "";
  height: 4px;
  position: absolute;
  top: 4px;
  transform: rotate(135deg);
  right: -2px;
  width: 4px;
}
.filter-button {
  margin-top: 10px;
}
.filter-button--total {
  background-color: #fff;
  box-shadow: 0 -4px 8px rgba(0, 0, 0, 0.05);
  bottom: 0;
  padding: 8px 10px;
  position: fixed;
  width: 100%;
  z-index: 2;
  max-width: 640px;
  margin: 0 auto;
  left: 0;
  right: 0;
}
.btn-filter-close {
  color: #dd1c1a;
}
.btn-filter-readmore {
  background-color: #288ad6;
  color: #fff;
}
.hide {
  display: none !important;
}
.iconcate-filter {
  background-position: -285px -40px;
  height: 14px;
  width: 11px;
}
b.total-reloading {
  display: inline-block;
}
.relative {
  position: relative;
}
.count-total {
  display: none;
}
.filter-list.manu {
  display: grid;
  grid-auto-rows: minmax(min-content, max-content);
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 6px;
  margin-bottom: 10px;
}
.manu-view-more {
  grid-column: 1 / span 4;
  width: 100%;
  padding: 0 3px;
}
.block-scroll {
  padding: 10px 0 0;
}
input[type="tel"] {
  -webkit-appearance: none;
}
.noUi-target,
.noUi-target * {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-touch-action: none;
  touch-action: none;
  -ms-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.noUi-target {
  position: relative;
  direction: ltr;
  display: block;
  left: 0;
  width: 100%;
  margin: 0 auto 20px;
}
#slider-range-total {
  max-width: 100%;
}
.noUi-base {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1;
}
.noUi-origin {
  position: absolute;
  right: 0;
  top: 0;
  left: 0;
  bottom: 0;
}
.noUi-handle {
  position: relative;
  z-index: 1;
}
.noUi-base,
.noUi-handle {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.noUi-horizontal {
  height: 4px;
}
.noUi-horizontal .noUi-handle {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  left: -7px;
  top: -7px;
  border: 1px solid #4a90e2;
  background-color: #fff;
}
.noUi-background {
  background: #d6d7d9;
}
.noUi-connect {
  background: #4a90e2;
  -webkit-transition: background 450ms;
  transition: background 450ms;
}
.noUi-origin {
  border-radius: 2px;
}
.noUi-target {
  border-radius: 2px;
  cursor: pointer;
}
.noUi-handle {
  cursor: default;
  -webkit-box-sizing: content-box !important;
  -moz-box-sizing: content-box !important;
  box-sizing: content-box !important;
}
.noUi-handle:active {
  border: 17px solid #345dbb;
  border: 17px solid rgba(53, 93, 187, 0.38);
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  left: -23px;
  top: -23px;
}
form.range-price {
  display: block;
  overflow: hidden;
  padding: 0 0 20px;
  position: relative;
}
form.range-price span {
  padding: 10px;
  border: 1px solid #bdbdbd;
  border-radius: 4px;
  position: relative;
  z-index: 1;
  background: #fff;
}
form.range-price::before {
  content: "";
  position: absolute;
  border-top: 1px solid #ddd;
  display: block;
  width: 100%;
  top: 20px;
  z-index: 0;
}
span.range-left {
  float: left;
}
span.range-right {
  float: right;
}
.filter-item .container {
  max-width: 100%;
  margin: 0 auto;
  padding: 10px 15px;
  display: none;
}
.price-slider .container {
  display: block;
}
.filter-item .price-slider .container {
  padding: 10px 30px;
}
form.range-price input {
  border: 0;
  max-width: 43px;
  text-align: right;
  font-size: 14px;
  float: left;
  background-color: #fff;
}
form.range-price input {
  border: 0;
  max-width: 64px;
  text-align: right;
  font-size: 14px;
  float: left;
  background-color: #fff;
}
label.place-holder {
  color: #bdbdbd;
  font-size: 14px;
  float: left;
}
.range-toggle {
  margin: 6px 0;
}
.range-toggle span {
  position: relative;
}
.range-toggle span::after {
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid #288ad6;
  content: "";
  height: 0;
  position: absolute;
  top: 6px;
  right: -17px;
  transform: none;
  width: 0;
}
.range-toggle span.down::after {
  transform: rotate(-180deg);
}
.range-toggle a {
  display: block;
  font-size: 14px;
  margin-bottom: 20px;
}
.filter-item .range-toggle a {
  margin-bottom: 10px;
}
.range-toggle span {
  position: relative;
  display: inline-block;
  margin-left: 5px;
}
.iconcate-range {
  background-position: -243px -122px;
  width: 14px;
  height: 16px;
}
.noselecttext {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

@media screen and (max-width: 320px) {
  .filter-item .price-slider .container {
    padding: 10px 25px 10px 15px;
  }
}
.filter-button-sticky {
  bottom: -10px;
  margin: 0;
  position: sticky;
  width: 100%;
  z-index: 2;
  background: #fff;
  padding: 10px 0;
}
input[type="tel"] {
  -webkit-appearance: none;
}

.filter-show.show-total .filter-button {
  bottom: 0;
  margin: 0;
  position: sticky;
  width: 100%;
  z-index: 2;
}
.show-total .show-total-item {
  width: auto;
  float: left;
  max-width: 33%;
}
.show-total .show-total-item.warpper-manu-inside {
  width: 100%;
  clear: both;
  max-width: unset;
}
.show-total-main {
  display: flex;
  flex-wrap: wrap;
  height: auto;
  padding: 15px 0 10px;
}
.close-popup-total {
  margin-left: calc(100% - 100px);
  background-color: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 4px;
  cursor: pointer;
  padding: 8px 10px;
  color: #000;
  display: inline-block;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 10px;
  right: 10px;
}

.show-total-item .price-slider .container {
  padding: 0 20px 0 10px;
  overflow: visible;
}
.show-total-item .price-slider .container {
  padding: 0;
}
.show-total.filter.active {
  display: block;
}
@media screen and (max-width: 600px) {
  .filter-item.filter-total.active .filter-content {
    overflow: scroll;
    height: calc(100vh - 64px);
  }
  .filter-item.filter-total.active .filter-show.full {
    position: fixed;
    top: 0;
    height: 100vh;
  }
  .filter-item.filter-total.active .filter-button {
    display: block;
    position: fixed;
    bottom: 0;
    z-index: 0;
  }
  .c-btnbox:hover {
    border: 1px solid #333;
  }
}
.list-filter-active div {
  display: inline;
}
.list-filter-active a {
  padding: 17px 13px;
  margin-right: 7px;
  margin-bottom: 7px;
  color: #333;
  border: 1px solid #f2f4f7;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-height: 30px;
  background: rgba(242, 244, 247, 1);
  border-radius: 8px;
    margin-right: 7px;
  font-size: 13px;
  cursor: pointer;
}

.list-filter-active {
  display: none;
}
.list-filter-active:has(>.props) {
  display: block;
}
.list-filter-active span,
.list-filter-active a {
  font-size: initial;
}
.list-filter-active > span {
  font-weight: bold;
  margin-right: 5px;
}
.list-filter-active .scrollable div {
  display: inline;
}
.list-filter-active .relative {
  display: block;
}
.list-filter-active .scrollable {
  display: flex;
  flex-wrap: nowrap;
  overflow: auto;
  margin-top: 10px;
}
.list-filter-active .scrollable.scroll-right::after {
  background: linear-gradient(
    to right,
    rgba(255 255 255/0.3),
    rgba(255 255 255/0.8),
    #fff
  );
  content: "";
  height: 42px;
  position: absolute;
  top: 0;
  right: -3px;
  width: 40px;
}
.list-filter-active a:hover {
  border-color: #2f80ed;
  color: #288ad6;
  background: rgba(241, 248, 254, 1);
}

.list-filter-active i {
  margin-left: 5px;
  transform: rotate(45deg);
}
.list-filter-active a:after {
  display: inline-block;
  content: "x";
  margin-left: 5px;
  opacity: 0.9;
  position: relative;
  top: -1px;
}

