.ws-mask-hover{
    position: relative;
    margin: 0;
}
.ws-mask-hover .ws-mask-hover__content,
.ws-mask-hover .ws-mask-hover__content-wrapper{
    display: block;
}
.ws-mask-hover .ws-mask-hover__content-wrapper{
    position: absolute;
    left: 0;

    transition: clip-path var(--duration) var(--easing), -webkit-clip-path var(--duration) var(--easing);
    width: 100%;
    height: 100%;

    z-index: 2;
}
.ws-mask-hover[data-type="fromTop"] .ws-mask-hover__content-wrapper{
    top: 0;

    -webkit-clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
    clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
}
.ws-mask-hover[data-type="fromCenter"] .ws-mask-hover__content-wrapper{
    top: 50%;

    -webkit-clip-path: polygon(0 50%, 100% 50%, 100% 50%, 0 50%);
    clip-path: polygon(0 50%, 100% 50%, 100% 50%, 0 50%);
    transform: translateY(-50%);
}
.ws-mask-hover[data-type="fromBottom"] .ws-mask-hover__content-wrapper{
    top: 0;

    -webkit-clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
    clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
}
.ws-mask-hover:hover .ws-mask-hover__content-wrapper{
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.ws-mask-hover[data-openatbuilder="1"] .ws-mask-hover__content-wrapper{
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
