/* RIBBON BANNERS */

.ribbon {
    position: absolute;
    top: -7px;
    right: 2px;
    z-index: 99;
}

/* reset certain elements (in case of conflicting CSS for classes, links, etc.) */
.ribbon .text,
.ribbon .banner,
.ribbon a {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

.ribbon a {
    color: #fff;
    text-decoration: none;
}

.no-css-transforms .ribbon {
    font-size: 1em;
    position: relative;
    width: 100%;
}

.ribbon .banner {
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
    color: #fff;
    -webkit-font-smoothing: antialiased;
    display: block;
    float: right;
    position: relative;
    right: 0px;
    top: 30px;
    width: 100px;
}

.ribbon-small .banner {
    right: -8px;
    top: 15px;
    width: 65px;
}

.ribbon-large .banner {
    right: -20px;
    top: 32px;
    width: 150px;
}

.ribbon .banner::after,
.ribbon .banner::before {
    content: '';
    display: block;
    height: 12px;
    position: absolute;
    width: 30px;
}

.ribbon-small .banner::after,
.ribbon-small .banner::before {
    height: 6px;
    width: 20px;
}

.ribbon-large .banner::after,
.ribbon-large .banner::before {
    height: 18px;
    width: 45px;
}

.ribbon .banner::before {
    -webkit-transform: skewY(-45deg) translate(50%,15px);
    -moz-transform: skewY(-45deg) translate(50%,15px);
    -ms-transform: skewY(-45deg) translate(50%,15px);
    -o-transform: skewY(-45deg) translate(50%,15px);
    -webkit-transform-origin: 100% center;
    -moz-transform-origin: 100% center;
    -ms-transform-origin: 100% center;
    -o-transform-origin: 100% center;
    left: -45px;
}

.ribbon-small .banner::before {
    top: -5px;
    left: -30px;
}

.ribbon-large .banner::before {
    top: 9px;
    left: -68px;
}

.ribbon .banner::after {
    -webkit-transform: translate(100%,-100%) skewY(45deg) translateX(-58%);
    -moz-transform: translate(100%,-100%) skewY(45deg) translateX(-58%);
    -ms-transform: translate(100%,-100%) skewY(45deg) translateX(-58%);
    -o-transform: translate(100%,-100%) skewY(45deg) translateX(-58%);
    -webkit-transform-origin: 0 center;
    -moz-transform-origin: 0 center;
    -ms-transform-origin: 0 center;
    -o-transform-origin: 0 center;
    right: -17px;
}

.ribbon-small .banner::after {
    top: 18px;
    right: -12px;
}

.ribbon-large .banner::after {
    top: 45px;
    right: -26px;
}


.no-css-transforms .ribbon .banner {
    position: static;
    width: 100%;
    float: none;
    font-size: 10px;
}

.ribbon .text {
    position: relative;
    z-index: 2;
    padding: 6px 0px;
    font-size: 14px;
    font-weight: bold;
    min-height: 18px;
    line-height: 18px;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.20);
    white-space: nowrap;
    text-overflow: ellipsis;
}

/* small text */
.ribbon-small .text {
    padding: 3px 0;
    font-size: 8px;
    min-height: 14px;
    line-height: 14px;
}

/* large text */
.ribbon-large .text {
    padding: 9px 0;
    font-size: 18px;
    min-height: 28px;
    line-height: 28px;
}


.ribbon .text::before,
.ribbon .text::after {
    content: '';
    display: block;
    height: 30px;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1;
}

/* small text */
.ribbon.ribbon-small .text::before,
.ribbon.ribbon-small .text::after {
    height: 20px;
}

/* large text */
.ribbon.ribbon-large .text::before,
.ribbon.ribbon-large .text::after {
    height: 46px;
}

.ribbon .text::before {
    -webkit-transform: translateX(-15%) skewX(-45deg);
    -moz-transform: translateX(-15%) skewX(-45deg);
    -ms-transform: translateX(-15%) skewX(-45deg);
    -o-transform: translateX(-15%) skewX(-45deg);
}

.ribbon .text::after {
    -webkit-transform: translateX(15%) skewX(45deg);
    -moz-transform: translateX(15%) skewX(45deg);
    -ms-transform: translateX(15%) skewX(45deg);
    -o-transform: translateX(15%) skewX(45deg);
}

.no-css-transforms .ribbon .text {
    height: 25px;
    padding: 3px;
}


/*--- RIBBON COLORS ---*/

/* yellow */
.ribbon-yellow .banner::after,
.ribbon-yellow .banner::before {
    background-color: #f2ba00;
}
.ribbon-yellow .text::before,
.ribbon-yellow .text::after,
.no-css-transforms .ribbon-yellow .text {
    background-color: #ffd95e;
}

/* orange */
.ribbon-orange .banner::after,
.ribbon-orange .banner::before {
    background-color: #F77600;
}
.ribbon-orange .text::before,
.ribbon-orange .text::after,
.no-css-transforms .ribbon-orange .text {
    background-color: #FF8B07;
}


@media (max-width:767px){
    /*.ribbon {
        top: 3px!important;
    }*/
    .ribbon {
        top:-7px!important;
    }
    .community-badge {
        top: 22px!important;
    }
}

.community-badge{
    top: 22px;
    left: -24px;
    right: unset;
    transform: rotate(274deg);
}

.community-badge > .banner{
    width: 120px;
}

.community-badge .banner::after,
.community-badge .banner::before {
    background-color: #264c73;
}
.community-badge .text::before,
.community-badge .text::after,
.no-css-transforms .community-badge .text {
    background-color: #33669B;
}


.cr-container-l .community-badge {
    right: unset;
    left: -40px;
}
.cr-container .community-badge {
    right: unset;
    top: 22px!important;
    left: -39px;
}

.scrafter-product > a > .himg > .community-badge{
    top: -7px !important;
    right:unset;
}

a.product-link-loop > .product-loop-in > .community-badge{
    right:unset;
    left: -40px;
}

.slick-slide:not(.slick-active) .community-badge{
   display: none;
}