
:root {
    --accordion-button-active-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='19' height='2' viewBox='0 0 19 2' fill='none'><path d='M18 1L1 1' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>");
    --accordion-button-icon: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='19' height='20' viewBox='0 0 19 20' fill='none'><path d='M9.5 1.5V18.5' stroke='black' stroke-width='1.5' stroke-linecap='round'/><path d='M18 10L1 10' stroke='black' stroke-width='1.5' stroke-linecap='round'/></svg>");
}

section.page-banner {
    padding: 70px 0;
}
section.page-banner .page-title {
    color: #000;
    font-size: 40px;
    text-transform: uppercase;
    font-weight: 400 !important;
    text-align: center;
}

.breadcrumbs .breacrumb-item {
    position: relative;
    width: fit-content;
    height: 22px;
    background-color: #F4F4F4;
    margin: 0px 5px;
    padding: 0 1rem;

    font-size: 12px;
    font-weight: 500;
    color: #A7A7A7;
    text-transform: uppercase;
    line-height: 23px;
    padding-left: calc(1rem + 11px);
    z-index: 2;
    white-space: nowrap;

    margin-bottom: 10px;
  }
  
  .breadcrumbs .breacrumb-item:before,
  .breadcrumbs .breacrumb-item:after {
    content: " ";
    position: absolute;
    border-top: 11px solid transparent;
    border-bottom: 11px solid transparent;
  }
  
  .breadcrumbs .breacrumb-item:before {
    left: 100%;
    border-left: 11px solid #F4F4F4;
  }
  
  .breadcrumbs .breacrumb-item:after {
    right: 100%;
    border-right: 11px solid #fff;
    transform: rotate(-180deg) translateX(calc(-100% + 1px));
  }

  /* .breadcrumbs .breacrumb-item.active:before, .breadcrumbs .breacrumb-item.active:after {
    border-top: 12px solid transparent;
  } */

  .breadcrumbs {
    display: flex;
  }

  .breadcrumbs .breacrumb-item.active {
    scale: 1.2;
    z-index: 0;
    background-color: var(--bs-secondary);
    color: #fff;
    margin-left: 20px;
    /* border-top: 1px solid var(--bs-secondary); */
    /* border-bottom: 1.5px solid var(--bs-secondary); */
    border-top-right-radius: 2.4px;
    border-bottom-right-radius: 2.4px;
    border-right: 1px solid var(--bs-secondary);
  }
  .breadcrumbs .breacrumb-item.active::before{
    border-left-color: var(--bs-secondary);
    top: 50%;
    transform: translateY(-50%);

  }

  .breadcrumbs .breacrumb-item.active ~ .breacrumb-item {
    z-index: -1;

  }
  .breadcrumbs {
      flex-direction: row;
        flex-wrap: wrap;

  }

.accordion-button::after {
    background-image: var(--accordion-button-icon);
    background-position: center;
    background-size: 80%;
}

.accordion-button:not(.collapsed)::after {
    background-image: var(--accordion-button-active-icon);
    background-position: center;
    background-size: 80%;

}

.products-list .accordion-item {
    border-left: 0px;
    border-right: 0px;
}

.products-list .accordion-item:first-child {
    border-top: 0px;
}

.products-list .accordion-item .accordion-button {
    border-radius: 0;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 35px; /* 218.75% */
    letter-spacing: 0.303px;
}

.products-list #productsCategories .accordion-body{

    padding: 0;
}

.products-list #productsCategories .accordion-item .accordion-button:not(.collapsed) {
    color: #000;
    background-color: transparent;
    border-bottom: 0;
    box-shadow: none;
}

.products-list .meta-text {
    color: #949494;

    font-family: Roboto;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.008px;
}

.product-card {
    border: .6px solid #CCCCCC;
    padding: 10px 20px;
    position: relative;
}

.product-card .image {
    height: 200px;
}

.product-card .title p {
    color: #000;

    font-family: Roboto;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    line-height: 35px; /* 175% */
    letter-spacing: 0.379px;
    text-align: center;
    margin-bottom: 0;
    margin-bottom: 0;
}

.product-card .text {
    color: #949494;

    text-align: center;
    font-family: Roboto;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 19px; /* 135.714% */
    letter-spacing: 0.008px;

    /* Limit text to 2 lines */
    overflow: hidden;
   display: -webkit-box;
   -webkit-line-clamp: 2; /* number of lines to show */
           line-clamp: 2; 
   -webkit-box-orient: vertical;
}

.product-card .product-card-footer .info {
    color: var(--bs-primary);
    border: 1px solid var(--bs-primary);
    height: 27px;
    width: 27px;
    display: block;
    border-radius: 50%;
    text-align: center;
}

.product-card .tooltip {
    background-color: #F4F4F4;
}

.tooltip > .tooltip-inner {
    background-color: var(--bs-primary);
    font-family: Roboto;
    font-size: 12px;
    border-radius: none;
}

.tooltip > .tooltip-arrow::before {
    border-top-color: var(--bs-primary) !important;
}

.product-card .view-products-wrapper {
    display: none;
    transition: .7s;
}

/* .product-card:hover .view-products-wrapper { */
.product-card .up-content:hover ~ .view-products-wrapper {
    transition: 1.7s;
    display: flex;
    background-color: rgba(0, 0, 0, .5);
    padding: 1rem;

    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

.product-card .view-products-wrapper .btn {
    padding: 10px;
    width: 100%;
    text-align: center;
    color: var(--bs-primary);
    font-family: Roboto;
    font-size: 16.8px;
    font-style: normal;
    font-weight: 400;
    line-height: 36px; /* 214.286% */
    letter-spacing: 0.318px;

    background-color: #fff;
    border-radius: 0;
}

.products-list .pagination .page-link {
    border-top: 0px;
    border-left: 0px;
    border-right: 0px;
    color: #C9C9C9;
}

.products-list .pagination .page-item {
    padding: 0 10px;
}

.products-list .pagination .page-item.active .page-link {
    color: #000;
    background-color: transparent;
}

.sub-cat-filters .accordion-item .accordion-header .accordion-button, .products-list #productsCategories .accordion-item .accordion-button:not(.collapsed){
    background-color: #F1F1F1 ;
    padding: 5px 10px;
    margin-bottom: 10px;
}

.sub-cat-filters .accordion-item {
    border: none;
}

.sub-cat-filters .accordion-item .accordion-body {
    padding: 10px !important;
}

.sub-cat-filters .accordion-item .filter-title {
    font-family: Roboto;
    font-size: 16px;
    font-style: normal;
    font-weight: 500;

    padding-left: 25px;
    position: relative;
}


.sub-cat-filters .accordion-item .filter-title::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border-bottom: 2px solid;
    width: 15px;
    border-radius: 1px;
}

.sub-cat-filters .accordion-item .filter-options {
    color: #3C3C3C;

    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px; /* 142.857% */
    letter-spacing: 0.008px;
}

.sub-cat-filters .accordion-item .filter-options input {
    border-radius: 0;
    
}

.sub-cat-filters .accordion-item .filter-options input:checked[type=checkbox] {
    background-size: 80%;
    background-color: #000;
    background-image: none;
    position: relative;
    border-color: #000;
    border-width: 1px;
}   

.sub-cat-filters .accordion-item .filter-options input:checked[type=checkbox]::before {
    content: "";
    height: 95%;
    width: 95%;
    border: 2px solid #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.product-card-2 {
    margin-bottom: 20px !important;
}

.product-card-2 .title p{
    color: #949494;

    text-align: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 18px;
    letter-spacing: 0.008px;
    margin-bottom: 10px;
    
}


.product-card-2 .text p{
    color: #B39C81;

    text-align: center;
    font-family: Roboto;
    font-size: 14.28px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 0.009px;
}

.product-card-2 .btn {
    background-color: var(--bs-secondary);
    color: #fff;
}

.product-card-2:hover .action {
    opacity: 1;
}

.product-card-2 .action {
    transition: .7s;
    position: absolute;
    bottom: 10px;
    width: 100%;
    right: 0;
    padding: 0 10px;
    z-index: 3;
    opacity: 0;
}

.product-card-2 .action .btn {
    border: 0px;
    border-radius: 0;
    width: 100%;
}

.product-card-2 .image {
    height: 150px !important;
}

span.in-reapro {
    color: #E78746;
    font-size: 12px;
    font-style: normal;
    position: relative;
    padding-left: 15px;
    line-height: 24px;
}

span.in-reapro::before {
    content: "";
    height: 10px;
    width: 10px;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    background-color: #E78746;
}

.product-metas .nav-tabs .nav-link.active {
    border-top: none;
    border-left: none;
    border-right: none;
    color: #000;
    border-bottom: 1px solid var(--bs-primary);
}

.product-metas .nav-tabs .nav-link {
    color: #B4B4B4;

    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 28px; /* 322.222% */
    letter-spacing: 0.341px;
    padding: 0;
    margin-right: 20px;
}

.product-metas .nav-tabs .nav-link:hover, .product-metas .nav-tabs .nav-link:active {
    border: none;
}

.product-metas .text {
    color: #5C5C5C;

    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 23px; /* 164.286% */
    letter-spacing: 0.378px;
}

.product-metas .content {
    padding: 54px;
    border-top: 4px solid var(--bs-primary);
    background-color: #F0F2F2;
}

.product-metas .content .title {
    color: #000;

    font-size: 30px;
    font-style: normal;
    font-weight: 500;
    line-height: 41px; /* 136.667% */
    letter-spacing: 0.268px;
}

.products-list .view-list .table thead tr th {
    border-bottom: 0;
    text-transform: uppercase;
    color: #000;

    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 0.265px;
    text-transform: uppercase;
    padding: 15px 5px;
}

.products-list .view-list .table .in-stock, .products-list .view-list .table .in-reapro {
    white-space: nowrap;
    text-transform: uppercase;
}

.products-list .view-list .table tr .product-name {
    color: #000;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px; /* 142.857% */
    letter-spacing: 0.008px;
    text-decoration: none;
}


.products-list .view-list .table tr .product-name:hover {
    color: var(--bs-primary);
}

.products-list .view-list .table tr .price {
    color: var(--bs-primary);
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 25px; /* 178.571% */
    letter-spacing: 0.008px;
}

.products-list .view-list .table tbody tr td {
    vertical-align: middle;
}

.products-list .view-list .table tbody tr td.dimention {
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 20px; /* 125% */
    letter-spacing: 0.01px;
}


/* Products slider */


  
.products-thumbnail.swiper-container {
    width: 100%;
    max-width: 940px;
  }
  .products-thumbnail.swiper-container.slider {
    height: 300px;
  }
  .products-thumbnail.swiper-container.slider-thumbnail {
    height: 300px;
  }
  .products-thumbnail.swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide {
    height: 100%;
    opacity: 0.5;
    overflow: hidden;
  }
  .products-thumbnail
  .swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide.swiper-slide-thumb-active {
    opacity: 1;
  }


  .products-images .swiper-wrapper .swiper-slide img
{
    width: 100%;
    overflow: hidden;
}
.product-images {
    display: flex;
    flex-direction: row;
    overflow: hidden;
}

.product-images .products-slider {
    width: 80%;
    overflow: hidden;
    height: 300px;
    padding: 10px;
    border: .6px solid var(--bs-primary);
}

.product-images .products-slider .swiper-slide, .product-images .products-slider .swiper-slide div {
    overflow: hidden;
}

.product-images .products-slider .swiper-slide div {
    height: 100%;
    width: 100%;
    padding: 50px;
}
.product-images .products-slider .swiper-slide div img {
    height: 100%;
}

.product-images .products-thumbnail {
    width: 20%;
    padding: 0 10px;
}

.product-images .products-thumbnail .swiper-wrapper {
    display: flex;
    flex-direction: column;
}

.product-images .products-thumbnail .swiper-wrapper .swiper-slide-thumb-active {
    opacity: 1 !important;
}

.product-images .products-thumbnail .swiper-wrapper .swiper-slide {
    width: 100%;
}

.products-thumbnail.swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide {
    padding: 10px;
    border: .6px solid var(--bs-primary);
    overflow: hidden;
}

.products-thumbnail.swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide div {
    overflow: hidden;
    height: 100%;

}

.products-thumbnail.swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide:not(:last-child) {
    margin-bottom: 10px;
}


.products-thumbnail.swiper-container.slider-thumbnail .swiper-wrapper .swiper-slide img {
    height: 100%;

}

.product-details .product-infos .title{
    font-size: 25px;
    font-style: normal;
    font-weight: 500;
    line-height: 41px; /* 117.143% */
    letter-spacing: 0.312px;
}

.product-details .product-infos .price{
    color: var(--bs-primary);
    font-size: 20.5px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.031px;
    margin: 10px 0;
}

.product-details .product-infos .price .small{
    font-size: 14.13px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.019px;

}

.product-details .product-infos .text{
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.014px;
    margin: 30px 0;
}

.product-details .product-infos .choice-btn{
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.013px;
    padding: 1rem;
    border-radius: 0;
    width: 100%;
    margin-bottom: 1rem;
    margin: 10px 0;
}

.product-details .product-infos .follow-us {
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.303px;
}
.product-details .product-infos a{
    text-decoration: none;
}

.details-title {
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 58px; /* 322.222% */
    letter-spacing: 0.341px;
    text-transform: uppercase;
    border-bottom: 2px solid var(--bs-primary);
}

.product-details .table-longueurs tbody tr td{
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 27px; /* 192.857% */
    letter-spacing: 0.378px;
    color: #000;

    padding-left: 15px;
    padding-right: 15px;
    vertical-align: middle;
}


.product-details .table-longueurs thead tr th {
    border: 0;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.265px;
    text-transform: uppercase;

    padding: 15px;
}

.text-gray {
    color: #5C5C5C !important;
}
.product-details .table-longueurs tbody tr td .strong {
    font-weight: 700;
}

.product-details .table-longueurs tbody tr td button {
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 0.007px;
    padding: 10px;
    white-space: nowrap;
}

.product-details .btn-primary:hover {
    /* background-color: var(--bs-primary); */
}

.product-details .btn-primary:disabled {
    background-color: #787878;
    border-color: #787878;
}

/* custom .tooltip  */

.tooltip-wrapper {
    position: relative;
}

.tooltip-text {
    visibility: hidden;
    position: absolute;
    z-index: 2;
    width: 100px;
    color: white;
    font-size: 12px;
    background-color: #fff;
    border-radius: 0px;
    padding: 5px 15px 5px 15px;
    white-space: nowrap;
    color: #5C5C5C;

    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.265px;
  }
  
  .tooltip-text::before {
    content: "";
    position: absolute;
    transform: rotate(45deg);
    background-color: #fff;
    padding: 5px;
    z-index: 1;
  }
  
  .tooltip-wrapper:hover .tooltip-text {
    visibility: visible;
  }
  
  .tooltip-text.top {
    top: -40px;
    left: -50%;
    transform: translateX(-30%)
  }
  
  .tooltip-text.top::before {
    top: 80%;
    left: 45%;
  }

  .variation-add-to-cart {
    display: flex;
  }
  
  .qib-container {
    display: flex;
  }
  
  input.qty {
    width: 50px;
    text-align: center;
    height: 100%;
    border: none;

    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.227px;
  }

  input.qty:focus {
    outline: none;
  }
  
  input.qty::-webkit-outer-spin-button,
  input.qty::-webkit-inner-spin-button {
    /* display: none; <- Crashes Chrome on hover */
    -webkit-appearance: none;
    margin: 0; /* <-- Apparently some margin are still there even though it's hidden */
}

input.qty[type=number] {
    -moz-appearance:textfield; /* Firefox */
}

input.qty:active {
    box-shadow: none;
}

.qib-button {
    padding-left: 15px !important;
    padding-right: 15px !important;
    border: none;
    color: var(--bs-secondary);
    background-color: #EEEEEE;
}

.quantity.buttons_added {
    border: 1px solid #EEEEEE;
}

.product-details-text {
    color: #5C5C5C;

font-size: 14px;
font-style: normal;
font-weight: 400;
line-height: 28px; /* 200% */
}


.product-details-text strong{
    color: #000;
}

.tech-features {
    color: #5C5C5C;

    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 20px; /* 328.571% */
    letter-spacing: 0.378px;
}

.tech-features tbody tr td:first-child {
    background: #F0F2F2;
    width: 50%;
}

.tech-features tbody tr td:last-child {
    padding-left: 35px;
}

.tech-doc table tr{
    background: #F0F2F2;
    padding: 30px 0;
}

.tech-doc table tr td {
    background: #F0F2F2;
    padding: 20px 10px;
    vertical-align: middle;
}

.tech-doc table tr td span {
    color: #007C37;

    font-size: 16px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.303px;
}

.tech-doc table tr td a {
    text-decoration: none;
}

.tech-doc table tr td:first-child span {
    color: #000;

    font-family: Roboto;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 0.341px;
}

.w-fit {
    width: fit-content;
}

.text-2lines {
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2; /* number of lines to show */
                line-clamp: 2; 
        -webkit-box-orient: vertical;
}