/* Added fallbacks to help with CLS, feel free to remove if it doesn't help on your project */
/* Colours */
/* Fluid heading sizes - set your min/max sizes and you're done! */
/* Some device sizes to use with min-width */
/* adjusted breakpoints for above */
/* 100% widths look better than "Snapping" IMO */
/* Utility */
/* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
/* Added fallbacks to help with CLS, feel free to remove if it doesn't help on your project */
/* Colours */
/* Fluid heading sizes - set your min/max sizes and you're done! */
/* Some device sizes to use with min-width */
/* adjusted breakpoints for above */
/* 100% widths look better than "Snapping" IMO */
/* Utility */
/* Additional Spacers -- don't think you'll need more than 7, but if you do -- maybe just use a custom class  :)  */
#hero {
  background: #131F35;
  text-align: center;
  min-height: 350px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#hero h1 {
  color: #FFFFFF;
  position: relative;
  text-align: left;
}
#hero h1::after {
  content: "";
  position: absolute;
  bottom: -13px;
  left: 0;
  width: 145px !important;
  height: 9px;
  background-color: #EB010F;
  right: 0;
}
#hero h3,
#hero p.h3 {
  color: #FFFFFF;
  font: normal normal normal 18px/32px Rubik !important;
  text-align: left;
}
@media screen and (min-width: 1025px) {
  #hero {
    min-height: 320px;
  }
  #hero h1, #hero h3, #hero p.h3 {
    text-align: center;
  }
  #hero h1::after {
    margin-left: auto;
    margin-right: auto;
  }
  #hero h3,
  #hero p.h3 {
    font-size: clamp(1.5rem, 24px + (33 - 24) * (100vw - 320px) / 1600, 2.0625rem) !important;
    line-height: clamp(2.1875rem, 35px + (44 - 35) * (100vw - 320px) / 1600, 2.75rem) !important;
  }
}

#breadcrumb {
  background: #FFFFFF 0% 0% no-repeat padding-box;
  border-bottom: 1px solid #BABABA;
}
#breadcrumb .rank-math-breadcrumb .separator {
  display: inline-block;
  margin-left: 7px;
  margin-right: 7px;
  padding-top: 22px;
  padding-bottom: 22px;
}
#breadcrumb .rank-math-breadcrumb p {
  padding: 0;
}
#breadcrumb .rank-math-breadcrumb .separator,
#breadcrumb .rank-math-breadcrumb a,
#breadcrumb .rank-math-breadcrumb .last {
  font: normal normal bold 16px/19px Rubik;
  letter-spacing: 0px;
  color: #131F35;
  text-transform: capitalize;
}

body {
  background: #F7F7F7;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;
  padding: 10px 40px 10px 15px;
  border: 1px solid #ddd;
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
}

#breadcrumb {
  border-top: 1px solid #BABABA;
}

/*Shop Category*/
#shop-category {
  max-width: 1920px;
  margin-left: auto;
  margin-right: auto;
}
#shop-category .title-shop {
  margin-bottom: -10px;
  text-transform: uppercase;
  color: #EB010F;
  position: relative;
}
#shop-category .button-left,
#shop-category .button-right {
  background: transparent;
  border: 0;
}
#shop-category .subtitle {
  position: relative;
}
#shop-category .subtitle::after {
  content: "";
  position: absolute;
  bottom: -24px;
  left: 0;
  width: 10% !important;
  height: 9px;
  background-color: #EB010F;
}
#shop-category .icon-Aslong-arrow-left {
  font-size: 56px;
  cursor: pointer;
}
#shop-category .icon-Aslong-arrow-left.right {
  transform: scaleX(-1);
}
#shop-category .icon-Aslong-arrow-left:hover {
  color: #EB010F;
}

/*List Categories*/
#list-categories {
  overflow: hidden;
  max-width: 1920px;
  margin-left: auto;
  margin-right: auto;
}
#list-categories .category-name {
  color: #FFFFFF;
  padding: 0 0 10px 10px;
  text-align: left;
}
#list-categories .icon-Aslong-arrow-left {
  font-size: 56px;
  cursor: pointer;
}
#list-categories .icon-Aslong-arrow-left.right {
  transform: scaleX(-1);
}
#list-categories .icon-Aslong-arrow-left:hover {
  color: #EB010F;
}
#list-categories .container-buttons-bottom {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
#list-categories .carousel-nav-arrows-bottom {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
#list-categories .category-image img {
  border-radius: 8px;
}
#list-categories .category-info {
  bottom: 0;
}
@media screen and (min-width: 1025px) {
  #list-categories .category-name {
    padding: 28px;
  }
}

/*Shop*/
#shop {
  padding-bottom: 5em;
}
#shop .shop-sidebar {
  background: #FFFFFF;
  padding: 20px;
}
#shop .parent-no-subcategory,
#shop .toggle-icon {
  font: normal normal normal 18px/22px Rubik;
  display: flex;
  align-items: center;
  gap: 16px;
}
#shop .icon-plus,
#shop .icon-minus {
  font-size: 12px;
}
#shop .title-active {
  color: #EB010F;
}
#shop .parent-category {
  margin-bottom: 28px;
}
#shop .child-category {
  font: normal normal normal 16px/18px Rubik;
}
#shop label.checkbox-container {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
  cursor: pointer;
}
#shop .category-filter {
  width: 16px;
  display: flex;
  height: 16px;
}
#shop .subcategory-list.show {
  margin-top: 25px;
  display: block;
  margin-bottom: 30px;
  margin-left: 20px;
}
#shop .subcategory-list {
  display: none;
}
#shop .shop-header {
  background: #FFFFFF;
  min-height: 70px;
  align-items: center;
  display: flex;
  padding-left: 25px;
  padding-right: 25px;
  padding-top: 15px;
  padding-bottom: 15px;
}
#shop .woocommerce-ordering {
  margin-bottom: 0;
}
#shop .products-count {
  font: normal normal normal 18px/27px Rubik;
}
#shop .woocommerce-ordering select {
  display: flex;
  align-items: center;
  height: 50px;
  border: 1px solid #BABABA;
  border-radius: 5px;
  padding-left: 20px;
  padding-right: 40px;
}
#shop .product-item {
  background: #FFFFFF 0% 0% no-repeat padding-box;
  border: 1px solid #B2B2B2;
  border-radius: 8px;
  padding: 27px 20px 0;
  display: flex;
  flex-direction: column;
  height: 100%;
}
#shop .product-item .yith-wcwl-add-to-wishlist-button--added svg path {
  fill: #EB010F;
}
#shop .product-item .yith-wcwl-add-to-wishlist-button__label {
  display: none !important;
}
#shop .product-item .yith-add-to-wishlist-button-block {
  margin: unset !important;
  height: fit-content !important;
}
#shop .product-item > a {
  flex: 1;
  display: flex;
  flex-direction: column;
}
#shop .product-item .product-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#shop .product-title {
  font: normal normal normal 16px/25px Rubik;
  max-width: 248px;
}
#shop .icon-Aslong-arrow-left {
  font-size: 56px;
  cursor: pointer;
}
#shop .icon-Aslong-arrow-left.right {
  transform: scaleX(-1);
}
#shop .icon-Aslong-arrow-left:hover {
  color: #EB010F;
}
#shop .container-buttons-bottom {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
#shop .carousel-nav-arrows-bottom {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
#shop .product-title {
  font: normal normal normal 16px/25px Rubik;
  max-width: 248px;
}
#shop .product-image {
  background: #FFFFFF 0% 0% no-repeat padding-box;
  border: 1px solid #E3E3E3;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 236px;
}
#shop .product-image picture, #shop .product-image img {
  max-width: 265px;
  object-fit: contain;
  height: 200px;
}
#shop .product-image img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
#shop .product-price {
  font: normal normal normal 18px/27px Rubik;
  letter-spacing: 0px;
  color: #131F35;
}
#shop .product-info {
  padding-top: 18px;
}
#shop .tag-sale {
  color: #FFFFFF;
  text-transform: uppercase;
  background: #EB010F 0% 0% no-repeat padding-box;
  position: absolute;
  min-height: 48px;
  display: flex;
  align-items: center;
  padding-left: 30px;
  padding-right: 30px;
  top: -19px;
  right: -11px;
}
#shop .container-links {
  justify-content: center;
  border-top: 1px solid #B2B2B2;
}
#shop .icon-heart {
  color: #000000;
  font-size: 20px;
}
#shop .add-to-cart {
  font: normal normal bold 16px/48px Rubik;
  letter-spacing: 0px;
  color: #464646;
  text-transform: capitalize;
  width: 100%;
  text-align: center;
}
#shop .add-to-cart:hover {
  background: #131F35 0% 0% no-repeat padding-box;
  border-radius: 8px;
  color: #FFFFFF;
}
#shop .view-product {
  color: #131F35;
  font: normal normal normal 16px/48px Rubik;
  width: 100%;
  text-align: center;
}
#shop .view-product:hover {
  background: #131F35 0% 0% no-repeat padding-box;
  border-radius: 8px;
  color: #FFFFFF;
}
#shop .line-height {
  height: 48px;
  width: 1px;
  background: #B2B2B2;
  margin-left: 10px;
  margin-right: 10px;
}
#shop .pi-edd.pi-edd-loop {
  background: transparent;
  border: 0;
  text-align: left;
  color: #131F35;
  font: normal normal normal 14px/25px Rubik;
  padding: 0;
}
#shop .product-filter-form h4 {
  margin-bottom: 20px;
}
#shop .products-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
#shop .products-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.8);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 999;
}
#shop .products-loading-overlay.active {
  display: flex;
}
#shop .products-loading-overlay .spinner-border {
  width: 3rem;
  height: 3rem;
}
#shop .category-header {
  cursor: pointer;
}
#shop .irs-handle {
  background: #FFFFFF !important;
  width: 20px;
  display: inline-block;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #000000;
}
#shop .irs--flat .irs-from, #shop .irs--flat .irs-to, #shop .irs--flat .irs-single {
  background-color: #000000;
}
#shop .irs--flat .irs-from:before, #shop .irs--flat .irs-to:before, #shop .irs--flat .irs-single:before {
  border-top-color: #000000;
}
#shop .irs-handle i {
  display: none !important;
}
#shop .irs--flat .irs-bar {
  background-color: black !important;
}
#shop .container-price,
#shop .container-filter {
  flex-basis: 100%;
}
#shop .container-filter {
  text-align: end;
}
#shop .container-price input {
  width: 100%;
  border: 1px solid #BABABA;
  border-radius: 5px;
  height: 37px;
  padding-left: 9px;
  padding-right: 9px;
  background: #E8E8E8;
}
#shop .container-outter-price {
  gap: 12px;
}
#shop .container-price-filter {
  margin-top: 23px;
}
#shop .text-decoration-underline {
  font: normal normal bold 16px/19px Rubik;
  color: #000000;
}
#shop .irs-min,
#shop .irs-max {
  display: none !important;
}
#shop .page-numbers {
  list-style: none;
  padding-left: 0;
  display: flex;
  justify-content: flex-start;
  border-radius: 5px;
  width: fit-content;
  margin-left: auto;
  font: normal normal normal 18px/27px Rubik;
  letter-spacing: 0px;
  color: #E0E0E0;
  flex-wrap: wrap;
}
#shop .page-numbers.current {
  font: normal normal normal 18px/27px Rubik;
  letter-spacing: 0px;
  color: #000000;
}
#shop .page-numbers .icon-chevron-right,
#shop .page-numbers .icon-chevron-left {
  color: #000000;
  font-size: 14px;
}
#shop .page-numbers li {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px solid #E0E0E0;
  background: #FFFFFF 0% 0% no-repeat padding-box;
}
#shop .page-numbers li:last-of-type {
  border-right: 0;
}
#shop .page-numbers li span,
#shop .page-numbers li a {
  margin-left: unset;
}
#shop .page-numbers li a {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#shop .delivery-item,
#shop .brand-item,
#shop .attribute-item {
  font: normal normal normal 18px/24px Rubik;
}
#shop .delivery-item input,
#shop .brand-item input,
#shop .attribute-item input {
  display: inline-block;
  width: 16px;
  height: 16px;
}
#shop .brand-list {
  height: 300px;
  overflow: auto;
}
#shop .line-divider {
  width: 100%;
  height: 1px;
  background: #A8A8A8;
}
@media screen and (min-width: 641px) {
  #shop .product-item {
    margin: 0;
  }
  #shop .products-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (min-width: 1025px) {
  #shop {
    padding-bottom: 9em;
  }
  #shop .product-item {
    margin: 0;
  }
  #shop .brand-list {
    height: 400px;
    overflow: auto;
  }
  #shop .products-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
  #shop .page-numbers {
    justify-content: flex-end;
  }
  #shop .shop-sidebar {
    padding: 38px;
  }
}