.products .product.ed-style{
    min-height: 275px;
}
.product .product-title{
    overflow:hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
}

/* product hover */
.product-media {
    position: relative;
    display: block;
    background-color: transparent;
    margin-bottom: 0;
    max-height: 165px;
    overflow: hidden;
}
.owl-carousel .product-media {max-height: 100%;}

.product-media>a {
    position: relative;
    display: block;
    overflow: hidden;
}

.product.ed-style .product-body {
    position: relative;
    padding-bottom: 10px;
    margin-bottom: 0px;
}
.product-media>a .product-image{display:block;width:100%;height:auto;transform: scale(1);transition: all .3s ease 0s;}
.product-media>a:hover .product-image {
    transform: scale(1.1);
}
.product-image-hover {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    width: 100%;
    height: auto;
    transition: all .4s ease;
}
.product-image{display:block;width:100%;height:auto}
.product-image-hover{position:absolute;left:0;top:0;opacity:0;width:100%;height:auto;transition:all .4s ease}
.relativeCase .reItem:hover .product-image-hover,
.product .pd-item:hover .product-image-hover{opacity:1}

.product-media>a .product-image{
    width: 100%;
}

/* Product */
/* object-oriented(not include description) */
.news .entry-title,
.products .product-title{
    text-align: center;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
}
.news .entry-title{
  text-align: left;
}
.owl-carousel .product-media>a .product-image{  
    display: block;
    width: 100%;
    height: auto;
}

/* fancybox carousel */
.fancybox__backdrop{background:var(--fancybox-bg, rgba(0, 0, 0, 0.95))}
#mainCarousel, .index-material #mtlCarousel{
    width: 100%;
    margin: 0 auto 5px auto;
  
    --carousel-button-color: #170724;
    --carousel-button-bg: #fff;
    --carousel-button-shadow: 0 2px 1px -1px rgb(0 0 0 / 20%),
      0 1px 1px 0 rgb(0 0 0 / 14%), 0 1px 3px 0 rgb(0 0 0 / 12%);
  
    --carousel-button-svg-width: 20px;
    --carousel-button-svg-height: 20px;
    --carousel-button-svg-stroke-width: 2.5;
  }
  .index-material #mtlCarousel{
    width: 60%;
  }
  #mainCarousel .carousel__slide,
  #mtlCarousel .carousel__slide {
    width: 100%;
    padding: 0;
  }
  #mainCarousel .carousel__slide img,
  #mtlCarousel .carousel__slide img{width: 100%;}
  #mtlCarousel .materialItem .materialBody .materialTitle{
    font-size: 17px;
    line-height: 1.2;
  }
  #mainCarousel .carousel__button:focus,
  #mainCarousel .carousel__button:focus .carousel__button:focus,
  #mtlCarousel .carousel__button:focus,
  #mtlCarousel .carousel__button:focus .carousel__button:focus{outline: none; border: 0;}
  #mainCarousel .carousel__button.is-prev{
    left: -50px;
  }
  #mainCarousel .carousel__button.is-next{
    right: -50px;
  }
  #mainCarousel .carousel__button.is-prev,
  #mainCarousel .carousel__button.is-next span,
  #mtlCarousel .carousel__button.is-prev,
  #mtlCarousel .carousel__button.is-next span{font-size: 55px;}
  #mainCarousel .carousel__button:focus,
  #mtlCarousel .carousel__button:focus {
    outline: none;
    color: #3595A9;
  }
  #thumbCarousel{
    width: 100%;
    /* max-width: 800px; */
    margin: 0 auto 1rem auto;
  }
  #thumbCarousel .carousel__slide {
    opacity: 0.5;
    padding: 0;
    margin: 0.25rem;
    width: calc( ( 100% / 6 ) - 8px );
    height: auto;
  }
  
  #thumbCarousel .carousel__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  
  #thumbCarousel .carousel__slide.is-nav-selected {
    opacity: 1;
  }
  .carousel__button{color: #5bcac1; background-color: transparent; box-shadow: none; width: 30px; height: 30px;}
  .carousel__button svg{width: 30px; height: 30px; }
  .fancybox__toolbar .carousel__button svg{color:#fff; width: 21px; height: 21px;}
  .fancybox__thumbs .fancybox__thumb,
  .fancybox__thumbs .carousel__slide .fancybox__thumb::after{border-radius: 0;}
  .fancybox__thumbs .carousel__slide .fancybox__thumb::after{
      border-color: #5bcac1;
  }
  .fancybox__nav .carousel__button{
      font-size: 60px;
  }
  .relativeCase .f-carousel__slide {
    width: calc( 100% / 3 );
  }
  
.portfolio .port-grid .port-item:nth-child(3n+1) {
  clear: both;
}


/* object-oriented */
@media (max-width: 1439px){
  #mainCarousel .carousel__button.is-prev{
    left: 15px;
  }
  #mainCarousel .carousel__button.is-next{
    right: 15px;
  }
}
@media (max-width: 1199px){
}
@media (max-width: 1024px){
  #thumbCarousel .carousel__slide {
    width: calc( ( 100% / 4 ) - 8px );
  }
  #mainCarousel .carousel__button.is-prev{
    left: 0px;
  }
  #mainCarousel .carousel__button.is-next{
    right: 0px;
  }
}
@media (max-width: 991px){
.portfolio .port-grid .port-item:nth-child(3n+1) {
  clear: unset;
}
  .portfolio .port-grid .port-item:nth-child(2n+1) {
  clear: both;
}
 
}
@media (max-width: 767px){
  #thumbCarousel .carousel__slide {
    width: calc(100% / 3);
    margin: 0;
  }
}
@media (max-width: 575px){
}
@media (max-width: 479px){
}





