.result-driven-contact {
    background-color: #fff;
    border-radius: 20px;
    font-family: Noto Sans JP,Helvetica Neue,sans-serif;
    margin-bottom: 130px;
    overflow: hidden;
    padding: 55px 40px 60px;
    position: relative;
    text-align: center
}

.result-driven-contact:after,.result-driven-contact:before {
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 400px;
    pointer-events: none;
    position: absolute;
    width: 400px;
    z-index: 0
}

.result-driven-contact:before {
    background-image: url(https://8914736.fs1.hubspotusercontent-na2.net/hubfs/8914736/two-way-contact/top/bg-cloud-l.svg);
    left: 0;
    top: 0;
    transform: translate(-10%,-10%)
}

.result-driven-contact:after {
    background-image: url(https://8914736.fs1.hubspotusercontent-na2.net/hubfs/8914736/two-way-contact/top/bg-cloud-r.svg);
    bottom: 0;
    right: 0;
    transform: translate(10%,10%)
}

.result-driven-contact .inner {
    z-index: 1
}

.result-driven-contact .image-left,.result-driven-contact .image-right {
    height: auto;
    pointer-events: none;
    position: absolute;
    top: 50%;
    transform: translateY(-28px);
    width: 260px;
    z-index: 1
}

.result-driven-contact .image-left {
    left: 31px;
}

.result-driven-contact .image-right {
    right: 30px;
}

.result-driven-contact .inner {
    margin: 0 auto;
    position: relative;
    z-index: 2
}

.result-driven-contact .text-area {
    margin: -4px auto 57px;
    max-width: 720px;
    position: relative;
    text-align: center;
    z-index: 2
}

.result-driven-contact .subtitle {
    color: #333;
    display: inline-block;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: .2rem;
    margin: 0 auto;
    position: relative
}

.result-driven-contact .subtitle span:after,
.result-driven-contact .subtitle span:before {
    background-color: #000;
    content: "";
    height: 1px;
    position: absolute;
    top: 100%;
    transform: translateY(-50%) rotate(52deg);
    width: 25px;
}

.result-driven-contact .subtitle span:before {
    left: -36px;
    transform: translateY(-50%) rotate(52deg);
}

.result-driven-contact .subtitle span:after {
    right: -40px;
    transform: translateY(-50%) rotate(-53deg);
    )
}

.result-driven-contact .title {
    color: #333;
    font-size: 43px;
    font-weight: 900;
    line-height: 1.35;
    margin-bottom: 3px;
}

.result-driven-contact .line1 {
    display: block;
    font-size: 77px;
    margin-top: 6px;
    margin-bottom: -5px;
    letter-spacing: 0.08em;
}

.result-driven-contact .line2 {
    letter-spacing: 0.15em;
}

.result-driven-contact .description {
    color: #444;
    font-size: 15px;
    line-height: 1.9;
    margin: 7px auto 19px;
    max-width: 680px;
    letter-spacing: 0.04em;
}

.result-driven-contact .stats {
    display: flex;
    flex-wrap: nowrap;
    gap: 25px;
    justify-content: center
}

.result-driven-contact .stat-item {
    align-items: center;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 8px 18px rgba(0,0,0,.12);
    display: flex;
    flex-direction: column;
    height: 120px;
    justify-content: center;
    text-align: center;
    width: 120px
}

.result-driven-contact .stat-label {
    background: #333;
    border-radius: 4px;
    color: #fff;
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    margin-bottom: 4px;
    padding: 3px 9px
}

.result-driven-contact .stat-value {
    align-items: baseline;
    color: #d65f5f;
    display: flex;
    font-family: Montserrat,sans-serif;
    font-size: 40px;
    font-weight: 700;
    line-height: 1;
    position: relative
}

.result-driven-contact .percent {
    font-size: 1.4rem
}

.result-driven-contact .stat-note {
    color: #666;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .05em;
    margin-top: 4px
}

.result-driven-contact .cta {
    background: #b22c2c;
    border-radius: 0 0 20px 20px;
    bottom: 0;
    left: 0;
    padding: 24px 0;
    position: absolute;
    right: 0;
    width: 100%;
    z-index: 3;
    display: block;
    transition: 0.5s;
    text-decoration: none;
}

.result-driven-contact .cta:hover {
  background-color: #E50000;
}

.result-driven-contact .btn {
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    padding-right: 20px;
    position: relative;
    text-decoration: none;
    letter-spacing: 0.1em;
}

.result-driven-contact .btn:after {
    background-color: currentColor;
    content: "";
    height: 14px;
    mask: url(https://8914736.fs1.hubspotusercontent-na2.net/hubfs/8914736/two-way-contact/top/ico-carat-r.svg) no-repeat center/contain;
    -webkit-mask: url(https://8914736.fs1.hubspotusercontent-na2.net/hubfs/8914736/two-way-contact/top/ico-carat-r.svg) no-repeat center/contain;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 11px
}

@media (max-width: 999px) {
    .reasons-module {
      padding-bottom: 30px;
    }
    .result-driven-contact {
        margin-bottom: 50px;
        border-radius: 10px;
    }
    .result-driven-contact .cta {
        border-radius: 0 0 10px 10px;
    }
    .result-driven-contact .subtitle {
        font-size: 15px;
    }

    .result-driven-contact .stats {
        flex-wrap: wrap;
        gap: 24px
    }

    .result-driven-contact .stat-item {
        height: 92px;
        width: 92px;
    }

    .result-driven-contact .title {
    line-height: 1.2;
    }

    .result-driven-contact .line1 {
        font-size: 52px;
    }
    .result-driven-contact .line2 {
        font-size: 29px;
    }

    .result-driven-contact .description {
        font-size: 14px;
        max-width: 280px;
    }

    .result-driven-contact .description br {
        display: none;
    }

    .result-driven-contact .image-left {
        left: 0;
        width: 153px;
    }
    
    .result-driven-contact .image-right {
        right: 0;
        width: 154px;
    }

    .result-driven-contact .stat-label {
        font-size: 9px;
    }
    
    .result-driven-contact .stat-value {
        font-size: 34px;
    }
    
    .result-driven-contact .percent {
        font-size: 1.4rem
    }
    
    .result-driven-contact .stat-note {
        display: none;
    }
    .result-driven-contact .btn {
        font-size: 15px;
    }
}

@media screen and (max-width: 767px) {
    .result-driven-contact {
        margin-bottom: 60px;
        padding-bottom: 150px;
        padding-left: 15px;
        padding-right: 15px;
    }

    .result-driven-contact .stats {
        gap: 10px
    }

    .result-driven-contact .inner {
        position: static;
    }

    .result-driven-contact .image-left,
    .result-driven-contact .image-right {
        top: auto;
        bottom: 58px;
        height: auto;
    }

    .result-driven-contact .image-left {
        left: calc(50% - 114px);
        width: 114px;
    }

    .result-driven-contact .image-right {
        right: calc(50% - 114px);
        width: 110px;
    }
}
