.cb-home-testimonials {
    background-color: #0D0012;
    padding: 120px 0 150px;
    overflow: hidden;
}

.cb-home-testimonials .cb-container {
    padding: 0 16px;
    margin-bottom: 64px;
}

.cb-home-testimonials-image {
    display: block;
    width: 336px;
    height: 336px;
    margin: 0 auto;
    object-fit: contain;
}

.cb-home-testimonials-animation-group {
    width: 336px;
    height: 336px;
    margin: 0 auto;
    background-image: url(../../img/testimonials-animation-group-bg.png);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    position: relative;
    z-index: 0;
}

.cb-home-testimonials-animation-group:before {
    content: url('data:image/svg+xml,<svg viewBox="0 0 286 247" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M3 84.9189C3 153 59.272 189.279 100.464 221.752C115 233.211 129 244 143 244C157 244 171 233.211 185.536 221.752C226.728 189.279 283 153 283 84.9189C283 20.0826 213.163 -26.7968 152.093 25.4148C147.508 29.3349 145.215 31.295 143 31.295C140.785 31.295 138.492 29.3349 133.907 25.4148C72.8372 -26.7968 3 20.0826 3 84.9189Z" stroke="url(%23paint0_linear_1_5027)" stroke-width="5"/><defs><linearGradient id="paint0_linear_1_5027" x1="143" y1="2.98828" x2="143" y2="244" gradientUnits="userSpaceOnUse"><stop stop-color="white"/><stop offset="1" stop-color="%23F6F7F9"/></linearGradient></defs></svg>');
    display: block;
    width: 286px;
    height: 247px;
    position: absolute;
    z-index: 2;
    left: 25px;
    top: 43px;
}

.cb-home-testimonials-animation-group:after {
    content: '';
    display: block;
    width: 336px;
    height: 236px;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 3;
    background: linear-gradient(180deg, rgba(13, 0, 18, 0) 0%, #0D0012 63.12%);
}

.cb-home-testimonials-animation-group .swiper-container {
    position: absolute;
    left: 30px;
    top: 123px;
    width: 276px;
    z-index: 1;
    overflow: hidden;
    border-radius: 0 0 20px 20px;
}

.cb-home-testimonials-animation-group .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
    transition-timing-function: linear !important;
}

.cb-home-testimonials-animation-group .swiper-slide {
    display: block;
    overflow: hidden;
    border: 1px solid #fff;
    width: 54px;
    min-width: 54px;
    height: 54px;
    border-radius: 50%;
}

.cb-home-testimonials-animation-group .swiper-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cb-home-testimonials-animation-group .cb-icon-container {
    position: absolute;
    z-index: 4;
    width: 112px;
    height: 112px;
    top: 93px;
    left: 112px;
    padding: 14px;
}

.cb-home-testimonials-animation-group .cb-icon-container:before {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    z-index: 0;
    position: absolute;
    top: 0;
    left: 0;
    background-color: #66A4FF33;
    backdrop-filter: blur(6px);
    border-radius: 50%;
}

.cb-home-testimonials-animation-group .cb-icon-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    background-image: url(../../img/testimonials-animation-group-icon-container-bg.png);
    background-size: 100% 100%;
    padding: 10px;
    border-radius: 50%;
    animation: cb-testimonials-animation-group-rotate 6s linear infinite;
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 1;
}

.cb-home-testimonials-animation-group .cb-icon-wrapper svg {
    display: block;
    max-width: 100%;
    max-height: 100%;
}

.cb-home-testimonials-animation-group .cb-title-container {
    background-color: #fff;
    border-radius: 100px;
    padding: 3px;
    position: absolute;
    width: max-content;
    max-width: 300px;
    top: 214px;
    left: 50%;
    transform: translate(-50%, 0);
    z-index: 4;
}

.cb-home-testimonials-animation-group .cb-title-wrapper {
    background-color: #F2F7FD;
    border-radius: 100px;
    border: 1px solid #D4E7F6;
    box-shadow: 0px 2px 3px 0px #B7B7B71A,
    0px 0px 0px 3px #FFFFFF;
    padding: 5px 9px;
    display: flex;
    align-items: center;
}

.cb-home-testimonials-animation-group .cb-title-wrapper svg {
    display: block;
    width: 24px;
    height: 24px;
    min-width: 24px;
    margin-right: 4px;
}

.cb-home-testimonials-animation-group .cb-title-wrapper p {
    font-weight: 500;
    font-size: 17px;
    line-height: 26px;
    color: #3D3D3D;
}

.cb-home-testimonials-title {
    color: #fff;
    font-weight: 500;
    font-size: 64px;
    line-height: 120%;
    text-align: center;
    margin-top: -55px;
    position: relative;
    z-index: 1;
}

.cb-home-testimonials-text {
    color: #fff;
    max-width: 700px;
    margin: 20px auto 0;
    font-weight: 400;
    font-size: 18px;
    line-height: 150%;
    text-align: center;
    position: relative;
    z-index: 1;
}

.cb-home-testimonials .cb-testimonials {
    position: relative;
}

.cb-home-testimonials .cb-testimonials .swiper-wrapper {
    z-index: 1;
}

.cb-home-testimonials .cb-testimonials:before {
    content: '';
    display: block;
    width: 11%;
    height: calc(100% + 3px);
    background: linear-gradient(270deg, rgba(13, 0, 18, 0) 0%, #0D0012 100%);
    position: absolute;
    left: -1px;
    top: -1px;
    z-index: 2;
}

.cb-home-testimonials .cb-testimonials:after {
    content: '';
    display: block;
    width: 11%;
    height: calc(100% + 3px);
    background: linear-gradient(90deg, rgba(13, 0, 18, 0) 0%, #0D0012 100%);
    position: absolute;
    right: -1px;
    top: -1px;
    z-index: 2;
}

.cb-home-testimonials .cb-testimonial {
    display: flex;
    flex-direction: column;
    padding: 34px;
    position: relative;
    border-radius: 20px;
    background-color: #fff;
    height: auto;
    width: 380px;
}

.cb-home-testimonials .cb-testimonial:before {
    content: '';
    display: block;
    position: absolute;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    left: 4px;
    top: 4px;
    z-index: 1;
    background-image: url(../../img/testimonials-dots.png);
    border-radius: 20px;
}

.cb-home-testimonials .cb-testimonial:after {
    content: '';
    display: block;
    position: absolute;
    width: calc(100% - 8px);
    height: calc(100% - 8px);
    left: 4px;
    top: 4px;
    border-radius: 20px;
    background: linear-gradient(180deg, #EAF3FB99 0%, #FFFFFF 100%),
    linear-gradient(180deg, rgba(234, 243, 251, 0) 0%, #FFFFFF 100%);
    border: 1px solid #E1E4EB;
    box-shadow: 0px 0px 0px 4px #FFFFFF;
    z-index: 2;
}

.cb-home-testimonials .cb-testimonial-text {
    color: #333;
    z-index: 3;
    font-weight: 400;
    font-size: 18px;
    line-height: 150%;
    margin-bottom: 24px;
}

.cb-home-testimonials .cb-testimonial-profile {
    display: flex;
    align-items: center;
    padding-top: 24px;
    border-top: 1px solid #E1E4EB;
    margin-top: auto;
    z-index: 3;
}

.cb-home-testimonials .cb-testimonial-profile-image {
    display: block;
    width: 55px;
    height: 55px;
    object-fit: cover;
    min-width: 55px;
    margin-right: 8px;
    border-radius: 12px;
}

.cb-home-testimonials .cb-testimonial-profile-info {
    width: 100%;
}

.cb-home-testimonials .cb-testimonial-profile-name {
    font-weight: 500;
    font-size: 18px;
    line-height: 150%;
    color: #1a1a1a;
}

.cb-home-testimonials .cb-testimonial-profile-job {
    font-weight: 500;
    font-size: 15px;
    line-height: 150%;
    color: #4d4d4d;
}

.cb-home-testimonials .cb-testimonial-profile-rating {
    display: flex;
    gap: 2px;
    width: 108px;
    min-width: 108px;
    margin-left: 8px;
}

.cb-home-testimonials .cb-testimonial-profile-rating svg {
    display: block;
    width: 20px;
    height: 20px;
}

.cb-home-testimonials .cb-testimonial-profile-rating[data-rating="1"] svg:not(:first-child),
.cb-home-testimonials .cb-testimonial-profile-rating[data-rating="2"] svg:not(:first-child):not(:nth-child(2)),
.cb-home-testimonials .cb-testimonial-profile-rating[data-rating="3"] svg:nth-child(4),
.cb-home-testimonials .cb-testimonial-profile-rating[data-rating="3"] svg:nth-child(5),
.cb-home-testimonials .cb-testimonial-profile-rating[data-rating="4"] svg:last-child {
    display: none;
}

.cb-home-testimonials .swiper-pagination {
    position: static;
    margin-top: 20px;
    display: flex;
    padding: 0 16px;
    gap: 6px;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
}

.cb-home-testimonials .swiper-pagination-bullet {
    display: block;
    margin: 0 !important;
    width: 12px;
    height: 12px;
    background: linear-gradient(180deg, #335FFF 0%, #1A4BFF 100%);
    cursor: pointer;
    opacity: .4;
}

.cb-home-testimonials .swiper-pagination-bullet-active {
    opacity: 1;
}

@keyframes cb-testimonials-animation-group-rotate {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(359deg);
    }
}

@media screen and (max-width: 1024px) {
    .cb-home-testimonials {
        padding: 30px 0 80px;
    }

    .cb-home-testimonials .cb-container {
        margin-bottom: 32px;
    }

    .cb-home-testimonials-image {
        width: 267px;
        height: 267px;
    }

    .cb-home-testimonials-animation-group {
        width: 267px;
        height: 267px;
    }

    .cb-home-testimonials-animation-group:before {
        width: 226px;
        height: 192px;
        left: 20px;
        top: 34px;
    }

    .cb-home-testimonials-animation-group:after {
        width: 267px;
        height: 220px;
    }

    .cb-home-testimonials-animation-group .swiper-container {
        width: 218px;
        left: 24px;
        top: 99px;
        border-radius: 0 0 16px 16px;
    }

    .cb-home-testimonials-animation-group .swiper-slide {
        width: 42px;
        min-width: 42px;
        height: 42px;
    }

    .cb-home-testimonials-animation-group .cb-icon-container {
        width: 82px;
        height: 82px;
        top: 74px;
        left: 93px;
    }

    .cb-home-testimonials-animation-group .cb-title-container {
        max-width: 100%;
        top: 169px;
    }

    .cb-home-testimonials-animation-group .cb-title-wrapper svg {
        width: 20px;
        height: 20px;
        min-width: 20px;
    }

    .cb-home-testimonials-animation-group .cb-title-wrapper p {
        font-size: 14px;
        line-height: 21px;
    }

    .cb-home-testimonials-title {
        font-size: 32px;
        font-weight: 700;
        margin-top: -50px;
    }

    .cb-home-testimonials-text {
        display: none;
    }

    .cb-home-testimonials .cb-testimonials:before,
    .cb-home-testimonials .cb-testimonials:after {
        display: none;
    }

    .cb-home-testimonials .cb-testimonial {
        padding: 28px 20px;
        border-radius: 16px;
        width: calc(100vh - 38px);
        max-width: 337px;
    }

    .cb-home-testimonials .cb-testimonial:before {
        border-radius: 16px;
    }

    .cb-home-testimonials .cb-testimonial:after {
        border-radius: 16px;
    }

    .cb-home-testimonials .cb-testimonial-text {
        font-size: 16px;
    }

    .cb-home-testimonials .cb-testimonial-profile-image {
        width: 48px;
        height: 48px;
        min-width: 48px;
    }

    .cb-home-testimonials .cb-testimonial-profile-name {
        font-size: 16px;
    }

    .cb-home-testimonials .cb-testimonial-profile-job {
        font-size: 14px;
    }

    .cb-home-testimonials .cb-testimonial-profile-rating {
        width: 98px;
        min-width: 98px;
    }

    .cb-home-testimonials .cb-testimonial-profile-rating svg {
        width: 18px;
        height: 18px;
    }
}
