*,
*::before,
*::after {
    box-sizing: border-box;
}


.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.object-fit {
    width: 100%;
    height: 100%;
    object-fit: cover;
    max-width: unset;
}

.clear {
    clear: both;
    line-height: 0;
    font-size: 0;
}


img {
    max-width: 100%;
}

p {
    font-size: 15px;
    margin: 0;
    font-weight: 400;
}

a {
    text-decoration: none;
}


h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
    margin: 0;
    padding: 0;
    font-weight: 900;
}

ul,
ol {
    margin: 0;
    padding: 0;
    list-style-type: none;
}

.container {
    width: 100%;
    max-width: 1370px;
    margin: 0 auto;
    padding: 0 15px;
}


@media (min-width: 768px) {
    .container-fluid {
        max-width: 90%;
    }

    .container {
        padding: 0 45px !important;
    }
}

@media (min-width: 1440px) {

    .container,
    .container-fluid,
    .container-sm,
    .container-md,
    .container-lg,
    .container-xl {
        padding-right: 22px;
        padding-left: 22px;
    }
}



/*button style*/
.banner-btn {
    font-size: 1rem;
    padding: 1rem 1.4rem 1rem 1.4rem;
    color: #fff;
    border-radius: 1rem 1rem 1rem 1rem;
    display: inline-block;
    line-height: 1em;

    text-align: center;
    font-weight: 600 !important;
    position: relative;
    transition: all ease 0.3s;
    background: #0044EB;
    color: #fff;
    border: 1px solid #0044EB;
}

.banner-btn:hover {
    background: #FF852A;
    color: #fff;
    border: 1px solid #FF852A;
    transform: translateY(-0.2rem);
}

.btn-secondary {
    font-size: 1rem;
    padding: 1rem 1.4rem 1rem 1.4rem;
    color: #fff;
    border-radius: 1rem 1rem 1rem 1rem;
    display: inline-block;
    line-height: 1em;
    text-align: center;
    font-weight: 600 !important;
    position: relative;
    transition: all ease 0.3s;
    background: transparent;
    color: #1C1C20;
    border: 1px solid #c5c5c5;
}

.btn-secondary:hover {
    background: transparent;
    color: #F05838;
    border: 1px solid #F05838;
}



/*@media (min-width: 768px) {*/
/*    .btn {*/
/*        font-size: 1.25rem;*/
/*        border-radius: 1rem 1rem 1rem 1rem;*/
/*        padding: 1.1rem 1.875rem 1rem 1.875rem;*/
/*    }*/

/*    .btn-link {*/
/*        padding: 0 !important;*/
/*    }*/
/*}*/

@media (min-width: 1200px) {

    .btn-link {
        padding: 0 !important;
    }
}

.banner-bg {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: 40px 0;
}

.banner-bg-wrapper {
    position: relative;
    z-index: 2;
}

.banner-bg-text-slider {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;
}

.banner-bg-text-slider-area {
    width: 100%;
    height: 250px;
    overflow: hidden;
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    position: relative;
}

.banner-bg-text-slider {
    display: flex;
    flex-direction: column;
    position: absolute;
    width: 100%;
    transition: transform 0.6s ease-in-out;
}

.banner-bg-text-slide {
    height: 250px;
    /* line-height: 50px; */
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}


.banner-bg-text-slide-text h1 {
    font-size: 5.7rem;
    line-height: 7.5rem;
    color: #000;
    font-family: "Manrope", Sans-serif;
    font-weight: 700;
    letter-spacing: -0.4rem;
}

.blue h1 {
    color: #1F55CC;
}

.yellow h1 {
    color: #f37a20;
}

.green h1 {
    color: #13aa52;
}

.violet h1 {
    color: #A86DBB;
}

.banner-bg-text-slide-image {
    max-width: 210px;
}

.banner-bg-text-slide-image img {
    width: 100%;
}

.banner-bg-text-slide-image svg {
    width: 100% !important;
    height: auto !important;
    max-width: 210px;
    max-height: 129px;
}

.banner-bg-content h2 {
    font-family: "Manrope", Sans-serif;
    font-weight: 700;
    color: #000;
    font-size: 3.2rem;
    line-height: 3.1rem;
    letter-spacing: -0.2rem;
    min-height: 104px;
}

.banner-bg-content-animation {
    text-align: center;

    transition: background .3s, border .3s, border-radius .3s, box-shadow .3s, transform var(--e-transform-transition-duration, .4s);
}

.banner-bg-content-animation-wrapper {
    background: linear-gradient(45deg, #FAEC60, #F3A338, #F37528, #F44380, #BE3DB3, #0044EB, #5A71F1, #439EFF);
    background-size: 200% auto;
    color: #000;
    background-clip: text;
    text-fill-color: transparent;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: shine 15s linear infinite;
    margin: 20px 0;
}

.banner-bg-content {
    text-align: center;
}

@keyframes shine {
    to {
        background-position: 200% center;
    }
}

.banner-bg-content p {
    font-size: 15px;
    color: #565656;
    max-width: 500px;
    margin: 0 auto 50px;
}
@media(min-width: 768px) {
.banner-bg-content h2 {
    min-height: unset;
    line-height: 3.7rem;
}
}





@keyframes moveRightToLeft {
    from {
        transform: translateX(100%);
    }

    to {
        transform: translateX(-100%);
    }
}

.image-circle-block {
    position: relative;
    overflow: hidden;

    z-index: 1;
}

.image-circle-animation {
    width: 150%;
    aspect-ratio: 2 / 2;
    animation: rotate 10s infinite linear;
    background-image: url(../img/round-circle-animation.svg);
    background-size: cover;
    background-position: center center;
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: -1;
    min-width: 970px;
}

.image-circle-block-content {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 765px;
    text-align: center;
}

.image-circle-block-content h2 {
    font-weight: 700;
    font-size: 2.3rem;
    line-height: 2.4rem;
    color: #1e293b;
    letter-spacing: 0rem;
    margin: 0 0 19px;
}

.image-circle-block-content p {
    font-size: 15px;
    color: #565656;
    max-width: 270px;
    margin: 0 auto;
}

@keyframes rotate {
    from {
        transform: translate(-50%, -50%) rotate(0deg);
    }

    to {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}



.wrapper {
    padding-top: 100px;
    padding-bottom: 50px;
    border-top: dashed 2px var(--color-surface50);
    border-bottom: dashed 2px var(--color-surface50);
  }
  
  .card-animation {
    width: 100%;
    perspective: 500px;
    margin-bottom: 50px;
  }
  .card-animation:last-child {
    margin-bottom: 0;
  }
  
  .card-animation-item {
    width: calc(100% - 30px);    
    height: 510px;
    font-size: 30px;
    border-radius: 10px;
    color: var(--color-just-black);
    transition: all ease 0.3s;
    margin: 0 auto;
    overflow: hidden;
    padding: 1.2rem 1.2rem 0 1.2rem;
}

.card-animation-item-flex {
    display: flex;
    height: 100%;
    justify-content: space-between;
    flex-direction: column;
}

.card-animation-item.bg-blue {
    background: #1F55CC;
    color: #fff;
}

.card-animation-item.bg-purple {
    background: #8c62c5;
    color: #fff;
}

.card-animation-item.bg-orange {
    background: #f37a20;
    color: #fff;
}

.card-animation-item.bg-yellow {
    background: #E9B900;
    color: #fff;
}

.card-animation-item.bg-violet {
    background: #32248F;
    color: #fff;
}

.card-animation-item.bg-green {
    background: #13aa52;
    color: #fff;
}
  
.card-animation-item-flex__content .btn-primary {
    display: flex;
    align-items: center;
    justify-content: center;
    width: max-content;
    color: #2C4D96;    
    border-radius: 0.5rem 0.5rem 0.5rem 0.5rem;
    padding: 0.6rem 1rem 0.6rem 1.3rem;
    background-color: #FFFFFF;
    border-color: #FFFFFF;
    font-family: "Manrope", Sans-serif;
    font-size: 1rem;
} 

.card-animation-item-flex__content .btn-primary svg {
    height: auto;
    width: 1em;
}

.card-animation-item-flex__content .btn-primary svg path {
    fill: #2C4D96;
}
  
.card-animation-item-flex__content p {
    text-align: left;
    color: #FFFFFFD1;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5rem;
    margin: 0 0 15px;
}

.card-animation-item-flex__content h2 {
    font-weight: 500;
    color: #FFFFFF;
    font-size: 26px;
    line-height: 1.3em;
    margin: 0 0 15px;
}

.card-animation-item-flex__image img {
    margin: 0 auto;
    display: table;
}

.card-animation-item-flex__content {
    margin-bottom: 2rem;
}

.card-animation-item-flex__image.web img {
    width: 281px;
}

.card-animation-item-flex__image.marketing img {
    width: 14.5rem;
}

.card-animation-item-flex__image.optimisation img {
    width: 27rem;
}

.card-animation-item-flex__image.management img {
    width: 18rem;
}

.card-animation-item-flex__image.facebook img {
    width: 14.9rem;
}

.card-animation-item-flex__image.landing img {
    width: 34rem;
}

.card-animation-item-flex__image.content img {
    width: 28rem;
}

.card-animation-item-flex__image.branding img {
    width: 28rem;
}

.color-black .card-animation-item-flex__content h2 {
    color: #383838;
}

.color-black .card-animation-item-flex__content p {
    color: #383838;
}

.card-animation-section-heading h2 {
    font-size: 24px;
    font-weight: 500;
    line-height: 1.3em;
    text-align: center;
    margin: 0 0 25px;
}

.cards-animation-section {
    padding: 72px 0;
}


.banner-bg {
    padding: 40px 0 60px;
    min-height: 700px;
}


.banner-bg--bg {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 100%;
    height: 100%;
    background: url(../img/bg-animation.svg) repeat-x;
    animation: scrollBg 300s linear infinite;
    width: 30000px;
    transition: all ease 0.3s;
    transform: translate(-50%, -50%) scale(0.8);
}

    

.banner-bg--bg:before {
    content: "";
    width: calc(100vw + 44vw);
    height: 100%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.9) 35%, rgba(255, 255, 255, 0) 100%);
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
}
    

    @keyframes scrollBg {
        from {
            background-position: 0 50%;
        }

        to {
            background-position: -100% 50%;
        }
    }
@media(min-width: 768px) {
    .banner-bg {
        padding: 60px 0;
    }

    .banner-bg-text-slide {
        height: 250px;
        flex-direction: row;
        gap: 0 2rem;
    }

    .banner-bg-text-slider-area {
        height: 250px;
    }

    .banner-bg-text-slide-text h1 {
        font-size: 8rem;
        line-height: normal;
    }

    .banner-bg-content p {
        font-size: 16px;
        max-width: 530px;
    }

    .image-circle-block-content h2 {
        font-size: 3.6rem;
        line-height: 3.6rem;
        letter-spacing: -0.2rem;
    }

    .image-circle-block-content p {
        font-size: 15px;
        max-width: 385px;
    }

    .card-animation-section-heading h2 {
        font-size: 30px;
        margin: 0 0 40px;
    }

    .cards-animation-section {
        padding: 102px 0 90px;
    }
    
    .banner-bg {
        padding: 100px 0 150px;
    }  
}




@media(min-width: 1200px) {
    .banner-bg--bg {
        transform: translate(-50%, -50%) scale(1);
    }
    
    .banner-bg--bg:before {
        width: 100vw;
    }

    .banner-bg-text-slide-text h1 {
        font-size: 12rem;
        letter-spacing: -0.4rem;
        line-height: 1.4em;
    }
    
    .banner-bg-text-slide-image {
        max-width: 250px;
    }
    
    .banner-bg-text-slide-image svg {
        max-width: 250px;
        max-height: 170px;
    }

    .banner-bg-content h2 {
        font-size: 5rem;
        line-height: 7.5rem;
        letter-spacing: -0.2rem;
    }

    .image-circle-block-content {
        height: 694px;
        max-width: 930px;
        margin: 0 auto;
    }

    .image-circle-block-content h2 {
        font-size: 5.875rem;
        line-height: 5.875rem;
        letter-spacing: -0.3rem;
    }

    .image-circle-block-content p {
        font-size: 16px;
        max-width: 595px;
    }

    .image-circle-animation {
        width: 120%;
    }

    .card-animation-item {
        width: 96%;
        height: 459px;
        font-size: 30px;
        padding: 3rem 3rem 0 3rem;
        max-width: 1280px;
    }

    .card-animation-item-flex__content h2 {
        font-size: 2.5rem;
        font-weight: 500;
        color: #FFFFFF;
        margin: 0 0 20px;
    }

    .card-animation-item-flex {
        flex-direction: row;
        align-items: center;
    }

    .card-animation-item-flex__content {
        width: calc(100% - 677px);
    }

    .card-animation-item-flex__image {
        width: 677px;
    }

    .card-animation-item-flex__image.web {
        text-align: right;
    }

    .card-animation-item-flex__content p {
        font-size: 15px;
        margin: 0 0 42px;
    }

    .card-animation-item-flex__image.web img {
        width: 552px;
        display: inline-block;
    }

    .card-animation-item-flex__image.marketing img {
        width: 416px;
    }

    .card-animation-item-flex__image.optimisation img {
        width: 544px;
    }

    .card-animation-item-flex__image.management img {
        width: 448px;
    }

    .card-animation-item-flex__image.facebook img {
        width: 416px;
    }

    .card-animation-item-flex__image.landing img {
        width: 552px;
    }

    .card-animation-item-flex__image.content img {
        width: 552px;
    }

    .card-animation-item-flex__image.branding img {
        width: 552px;
    }

    .card-animation-section-heading h2 {
        font-size: 36px;
        margin: 0 0 70px;
    }

    .cards-animation-section {
        padding: 112px 0;
    }
}




.side-notification__btn {
    width: 110px;
    height: 30px;
    background: #000;
    border-radius: 8px 8px 0 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 14px;
    position: absolute;
    font-weight: 600;
    top: 50%;
    transform: rotate(-90deg) translate(-50%, -50%);
    transform-origin: 0 0;
    margin-left: -15px;
}

.side-notification {
    position: fixed;
    top: 50%;
    transform: translate(0, -50%);
    right: calc(-100% + 65px);
    z-index: 222;
    transition: all ease 0.3s;
}


.side-notification__content {
    padding: 1.5rem;
    border-radius: 15px 0 0 15px;
    background: #3A3F51;
    color: #fff;
    width: calc(100vw - 65px);

}

.side-notification.active {
    right: 0;
}

.side-notification__content-info ul {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 12px 0;
}

.side-notification__content-info ul li {
    width: 50%;
    font-size: 12px;
    color: #C1C1C1;
    line-height: 24px;
}

.side-notification__content-info ul li span {
    display: block;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 0;
    color: #fff;
    margin-top: 0px;
}

.side-notification__content-info ul li a {
    color: #fff;
}

.side-notification__content-info ul li:last-child {
    width: 100%;
}

.side-notification__content-link {
    padding: 10px;
    background-color: #fff;
    border-radius: 15px;
}

.side-notification__content-link ul {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px 0;
}

.side-notification__content-link ul li {
    width: 100%;
    font-size: 15px;
    color: #313131;
    display: flex;
}

.side-notification__content-link ul li img {
    margin-right: 6px;
}

.side-notification__content-link ul li a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    font-size: 15px;
    color: #000;
    font-weight: 600;
}

.side-notification__content-link ul li a svg {
    width: 20px;
}

.side-notification__content-link ul li strong {
    display: flex;
}

.side-notification__content-link-area .side-notification__content-link+.side-notification__content-link {
    margin-top: 10px;
}

.side-notification__content-link-area {
    margin-top: 15px;
}

.display-date-time {
    display: flex;
    align-items: center;
    gap: 5px;
}

.side-notification-overlay {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -111;
    opacity: 0;
}

.side-notification-overlay.active {
    z-index: 111;
    opacity: 1;
}


@media(min-width: 768px) {
    .side-notification {
        right: -592px;
    }


    .side-notification__content {
        width: 592px;

    }

    .side-notification__content-link.more-text ul li {
        width: max-content;
    }
}

@media(min-width: 1200px) {
    .side-notification__content-info ul li {
        font-size: 16px;
        font-weight: 300;
    }

    .side-notification__content-info ul li span {
        font-size: 24px;
        margin-top: 3px;
    }

    .side-notification__content-link ul {
        flex-direction: row;
        align-items: center;
        gap: 20px;
    }

    .side-notification__content-link ul li a {
        font-size: 17px;
        line-height: 20px;
    }

    .side-notification__content-info ul {
        gap: 22px 0;
    }

    .side-notification__content-link ul li a svg {
        width: 30px !important;
    }

    .side-notification__content-link {
        padding: 17px 15px;
    }

    .side-notification__content-link-area {
        margin-top: 20px;
    }

    .side-notification__content-link-area .side-notification__content-link+.side-notification__content-link {
        margin-top: 20px;
    }

    .side-notification__btn {
        width: 150px;
        height: 47px;
        font-size: 17px;
        margin-left: -23px;
    }

    .side-notification__content-link ul li {
        font-size: 15px;
    }

    .side-notification__btn:hover {
        background-color: #383838;
    }
}