/* ******************************************** */
/** COMPONENT: PRODUCTS
/* ******************************************** */

.c-products {
  position: relative;
  margin-top: 4rem;
}

/* Heading */

.c-products-heading {
  text-align: center;
}

.c-products-heading__title {
  font-size: clamp(3.4rem, 3vw, 4.4rem);
  font-weight: 700;
}
.c-products-heading__title--promo {
  color: var(--color-secondary);
}
.c-products-heading__link {
  display: inline-block;
  position: relative;
  margin-top: 0.5em;
  font-size: 1.7rem;
  font-weight: 600;
  color: var(--color-black);
}
.c-products-heading__link::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 7px;
  height: 7px;
  margin-left: 6px;
  margin-top: -1px;
  border: solid var(--color-black);
  border-width: 0 2px 2px 0;
  transform: rotate(-45deg);
  transition: border-color 200ms ease-out;
}

/* List */

.c-products-list.no-carousel {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-x);
  /* padding: 1rem; */
}

.c-products-list.no-carousel .c-products-item {
  padding: 0;
  width: 100%;
  margin: 2rem;
}

@media (min-width: 414px) {
  .c-products-list.no-carousel .c-products-item {
    width: calc(50% - var(--space-x));
  }
}
@media (min-width: 600px) {
  .c-products-list.no-carousel .c-products-item {
    width: calc(33.33333% - var(--space-x));
  }
}
@media (min-width: 980px) {
  .c-products-list.no-carousel .c-products-item {
    width: calc(25% - var(--space-x));
  }
}

/*
.tns-nav[style*="display"] ~ .tns-ovh .c-products-list{
    padding-left: 24px;
}

@media (min-width:768px){
    .tns-nav[style*="display"] ~ .tns-ovh .c-products-list{
        padding-left: 32px;
    }
}

@media (min-width:980px){
    .tns-nav[style*="display"] ~ .tns-ovh .c-products-list{
        padding-left: 42px;
    }
}

@media (min-width:1440px){
    .tns-nav[style*="display"] ~ .tns-ovh .c-products-list{
        padding-left: 85px;
    }
}

*/
/*
@media (min-width:1440px){
    .c-products-list.no-carousel .c-products-item{
        width: calc(20% - var(--space-x));
    }
    
}
*/

/* Item */

.c-products-item--nostock {
  opacity: 0.4;
}
.c-products-item__img {
  display: block;
  width: 100%;
  position: relative;
  background-color: var(--color-grey-200);
}
.c-products-item__img:before {
  content: "";
  display: block;
  width: 100%;
  height: 0;
  padding-bottom: 100%;
}

.c-products-item__title {
  display: inline-block;
  margin-top: 1.3em;
  font-size: clamp(1.8rem, 1.3vw, 2em);
  color: var(--color-black);
  font-weight: 600;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.c-product-info-brand-small {
  font-size: 1.4rem;
  font-weight: bold;
  margin-top: 0.5rem;
  color: var(--color-grey-500);
}

.c-products-item__price {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-top: 1.7em;
}

@media (max-width: 375px) {
  .c-products-item__price {
    flex-wrap: wrap;
  }
}

.c-products-item__num {
  font-weight: 900;
  font-size: clamp(1.8rem, 1.3vw, 2em);
}
.c-products-item__promo {
  padding: 0.3em 0.6em;
  background-color: var(--color-secondary);
  color: var(--color-white);
  font-size: 1.1em;
  text-transform: uppercase;
  font-weight: 900;
}

.c-products-item__actions {
  margin-top: 1.8em;
  font-size: clamp(1.6rem, 1.25vw, 1.7em);
}
.c-products-item__btn {
  font-weight: 600;
  padding-top: 10px;
  padding-bottom: 10px;
}
button.c-products-item__btn {
  padding-left: 13px;
  padding-right: 13px;
  transition: background-color 250ms ease-out, color 250ms ease-out;
}
.c-products-item:not(.c-products-item--nostock) .c-products-item__btn:not(.in-cart) {
  border: 1px solid rgb(57 169 99 / 38%);
}
.c-products-item__text {
  border: none !important;
}
.c-products-item__icon {
  margin-right: 6px;
  font-size: 1.5rem;
  margin-top: 2px;
}
.c-products-item__icon.icon-cart {
  font-size: 1.7rem;
}

.c-price__iva {
  display: block;
  font-size: 0.7em;
  text-align: right;
  opacity: 0.5;
}

@media (max-width: 375px) {
  .c-products-item__icon {
    display: none;
  }
}

.c-products-item__btn--added {
  opacity: 0.4;
}
.c-products-item__btn--nostock {
  color: var(--color-error);
}

/* Btns */

.in-cart.c-products-item__btn,
.c-products-item__btn--added {
  display: none;
}

.in-cart ~ .c-products-item__btn--added {
  display: block;
}

/* Colors */

.c-products-item__colors {
  margin-top: 20px;
}
.c-products-item__color {
  display: inline-block;
  vertical-align: middle;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  margin-right: 5px;
  border: 1px solid var(--color-grey-200);
}
.c-products-item__color.is-disabled {
  opacity: 0.3;
}

.c-product-item__image {
  display: none !important;
}
.c-product-item__image.is-showing {
  display: block !important;
}

@media (min-width: 768px) {
  /* Heading */

  .c-products-heading {
    display: flex;
    align-items: center;
    gap: 20px;
  }
  .c-products-heading__title {
    white-space: nowrap;
  }
  .c-products-heading__line {
    display: block;
    width: 100%;
    height: 1px;
    background: var(--color-grey-200);
  }
  .c-products-heading__link {
    margin-top: 5px;
    white-space: nowrap;
  }

  /* Controls */

  .c-products-controls {
    width: 100px;
  }

  .c-products-controls.tns-controls button {
    position: static;
    display: inline-block;
    vertical-align: middle;
    width: 44px;
    height: 44px;
    top: auto;
    left: auto;
    margin-top: 0;
  }
}

@media (min-width: 980px) {
  /* Heading */

  .c-products-heading {
    gap: 27px;
  }

  /* Item */

  .c-products-item {
    transform: scale(1);
    padding: 20px 25px;
    transition: transform 300ms ease-out, box-shadow 300ms ease-out;
    box-shadow: 0 0 16px 11px transparent;
  }

  @media (hover: hover) {
    /* Heading */

    .c-products-heading__link:is(:hover, :focus) {
      color: var(--color-primary);
    }
    .c-products-heading__link:is(:hover, :focus):after {
      border-color: var(--color-primary);
    }

    /* Item */

    .c-products-list:not(.no-carousel) .c-products-item:is(:hover, :focus) {
      box-shadow: 0 0 16px 11px #f3f3f3;
      border: 1px solid var(--color-grey-200);
      background: #fff;
      z-index: 1;
      position: relative;

      transform: scale(1.1);
    }

    .c-products-item:is(:hover, :focus) .c-products-item__title {
      color: var(--color-secondary);
    }

    button.c-products-item__btn:is(:hover, :focus) {
      background-color: var(--color-primary);
      color: var(--color-white);
    }
  }
}
