.shop-action-btns {
  width: 80%;
  justify-content: flex-end;
  font-size: 1.8rem;

  .shop-action-btn {
    gap: 1.2rem;
  }
}

.products {
  display: grid;
  grid-template-columns: repeat(5, 17.5vw);
  gap: 1rem;
  margin-bottom: 5rem;
  position: relative;
}

.product {
  padding: 4rem 5rem 3rem 5rem;
  gap: 1.2rem;
  justify-content: space-around;
  border: 0.1rem solid var(--color-dark);
  margin: 1rem;
  border-radius: 3rem;
  box-shadow: 0.4rem 0.4rem 0.7rem var(--color-grey);
  transition: all linear 200ms;
  line-break: anywhere;
}

.product:hover {
  scale: 1.03;
}

.product-title-container {
  height: 40%;
}

.product-title-container .product-title {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.product-image-container {
  justify-content: center;
  align-items: center;
  align-self: center;
  width: 100%;
  height: 16rem;
  flex-shrink: 0;
}

.product-image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 1rem;
}

.product .name {
  font-size: 2.2rem;
  text-decoration: none;
  color: var(--color-dark);
  height: 30%;
}

.product .name:hover {
  color: var(--color-secondary);
}

.product .price-box {
  gap: 0.5rem;
  height: 20%;
  gap: 0.1rem;
}

.product .price-box .price {
  font-size: 2rem;
  font-weight: 600;
}

.product .price-box .price-text {
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--color-success);
}

.product .price-box .price-text.unavailable {
  color: var(--color-error);
}

.product .action-btns {
  justify-content: end;
  font-size: 1.5rem;
  margin-right: -1rem;
  margin-top: 1rem;
}

.btn.like {
  font-size: 1.12rem;
}

.pagination-box {
  width: 100%;
  justify-content: center;
  margin-top: auto;
  font-size: 1.7rem;
}

.pagination-box .pagination-btns {
  gap: 0.5rem;
}

.pagination-box .pagination-btns .pagination-btn {
  cursor: pointer;
}

.pagination-box .pagination-btns .pagination-btn .link {
  padding: 0.6rem 1.2rem;
  border: 0.16rem solid transparent;
  border-radius: 0.8rem;
}

.pagination-box .pagination-btns .pagination-btn:hover .link {
  border-color: var(--color-secondary);
}

.pagination-box .pagination-btns .pagination-btn .link.current {
  background-color: var(--color-secondary);
  color: var(--color-secondary-light);
}

.no-products-message {
  font-size: 2.3rem;
  top: 5rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  gap: 3rem;
}

.no-products-message i {
  font-size: 5rem;
  color: var(--color-secondary);
}

/* --- Responsive ---  */
@media (max-width: 800px) {
  .products {
    grid-template-columns: repeat(4, 22vw);
  }
}

@media (max-width: 600px) {
  .products {
    grid-template-columns: repeat(2, 45vw);
    font-size: 2rem;
  }

  .product-image-container {
    height: 20rem;
  }

  .product .name {
    font-size: 2.8rem;
  }

  .product .price-box .price {
    font-size: 2.3rem;
  }

  .product .price-box .price-text {
    font-size: 2rem;
  }

  .product .action-btns {
    font-size: 2.3rem;
  }

  .btn.like {
    font-size: 1.65rem;
  }

  .shop-action-btns {
    font-size: 2rem;
  }

  .pagination-box {
    font-size: 3rem;
  }

  .pagination-box .pagination-btns {
    gap: 1rem;
  }

  .ts-control,
  .ts-dropdown {
    font-size: 2.5rem;
  }
}

@media (max-width: 400px) {
  .products {
    grid-template-columns: repeat(1, 80vw);
    font-size: 1.8rem;
  }

  .product .name {
    font-size: 2.5rem;
  }

  .product .price-box .price {
    font-size: 2.1rem;
  }

  .product .price-box .price-text {
    font-size: 1.8rem;
  }

  .product-image-container {
    height: 25rem;
  }

  .shop-action-btns {
    font-size: 2rem;
  }
}
