@charset "UTF-8";
/* ===========================
service.css
============================== */

.series_header {
    margin: 80px 0 0;
    padding: 20px 0 80px;
}

#ps-light .series_header {
    background-color: #E5F7FD;
}

#ps-advance .series_header {
    background-color: #FCECF4;
}

#ps-pro .series_header {
    background-color: #F7F5EE;
}

.series_header .intro {
    max-width: 830px;
    width: 94%;
    margin: 0 auto;
    font-size: 1.5625rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    text-align: center;
    line-height: 1.6;
    letter-spacing: 0.15em;
}

.series_header .intro span {
    display: block;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    line-height: 1.4;
    letter-spacing: 0.1em;
}

#ps-light {
    color: #00B3EC;
}

#ps-advance {
    color: #E64290;
}

#ps-pro {
    color: #AE9A52;
}

.series_header .intro span {
    color: #7A7A7A;
}

.series_header_inner {
    max-width: 830px;
    width: 94%;
    margin: 30px auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.series_header_inner h2 {
    width: 48%;
    margin: 0;
}

.series_header_inner .point {
    width: 48%;
    margin: 0 0 15px;
    background: #fff;
    position: relative;
    /* overflow: hidden; */
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    line-height: 1.54;
    letter-spacing: 0.1em;
    border-radius: 50%;
}

.series_header_inner .point::before {
    content: "";
    padding-top: 100%;
    display: block;
}

.series_header .copy {
    max-width: 830px;
    width: 94%;
    margin: 30px auto 0;
    font-size: 1.25rem;
    transform: skewX(0.03deg);
    font-weight: 800;
    text-align: center;
    line-height: 1.3;
    letter-spacing: 0.15em;
}

.series_header .txt {
    max-width: 830px;
    width: 94%;
    margin: 10px auto 0;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    text-align: center;
    line-height: 1.3;
    letter-spacing: 0.15em;
}

.service_contents {
    max-width: 970px;
    width: 94%;
    margin: -60px auto 0;
    padding: 0 0 80px;
}

.service_contents_inner {
    max-width: 830px;
    width: 94%;
    margin: 0 auto 0;
}

.service_contents h3 {
    margin-top: 50px;
    padding: 0 0 10px 1em;
    font-size: 1.5625rem;
    font-weight: 500;
    line-height: 1;
    text-align: center;
    letter-spacing: 1em;
}

#ps-light .service_contents h3 {
    border-bottom: #0398C2 1px solid;
}

#ps-advance .service_contents h3 {
    border-bottom: #E64290 1px solid;
}

#ps-pro .service_contents h3 {
    border-bottom: #AE9A52 1px solid;
}

.service_features {
    margin-top: 40px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.service_features > p {
    margin: 0 0 20px;
    padding: 15px;
    position: relative;
    border: transparent 5px solid;
    border-top-left-radius: 20px;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 700;
    line-height: 1.5;
    text-align: justify;
    color: #fff;
}

#ps-light .service_features > p {
    background-color: #33C2F0;
    border-color: #80D9F5;
}

#ps-advance .service_features > p {
    background-color: #EB68A6;
    border-color: #F2A0C7;
}

#ps-pro .service_features > p {
    background-color: #AE9A52;
    border-color: #D6CCA8;
}

.service_features > p::after {
    content: '';
    position: absolute;
    top: -18px;
    left: -18px;
}

#ps-light .service_features > p::after {
    content: url(../../img/service/attention_light.svg);
}

#ps-advance .service_features > p::after {
    content: url(../../img/service/attention_advance.svg);
}

#ps-pro .service_features > p::after {
    content: url(../../img/service/attention_pro.svg);
}

.column_1-3 {
    width: 100%;
}

.column_1-2 {
    width: 100%;
}

.column_1 {
    width: 100%;
}

.service_features > p small {
    display: inline-block;
    font-size: 0.8125rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    line-height: 1.4;
}

.service_features > p a {
    display: block;
    width: 100%;
    margin: 5px 0 0;
    padding: 0.8em 2.6em 0.8em 0;
    position: relative;
    font-size: 0.71875rem;
    transform: skewX(0.03deg);
    font-weight: 800;
    text-decoration: none;
    text-align: center;
    background-color: #fff;
    border-radius: 1.4em;
    transition: all 0.2s;
}

.service_features > p a:hover {
    opacity: .7;
}

#ps-pro .service_features > p a {
    color: #AE9A52;
}

.service_features > p a::before {
    content: '';
    width: 2.2em;
    height: 2.2em;
    border-radius: 50%;
    position: absolute;
    top: 0.4em;
    right: 0.4em;
}

#ps-pro .service_features > p a::before {
    background-color: #AE9A52;
}

.service_features > p a::after {
    content: '';
    width: 0.8em;
    height: 0.8em;
    position: absolute;
    top: 1.1em;
    right: 1.1em;
    border-top: #fff 3px solid;
    border-right: #fff 3px solid;
    transform: rotate(45deg);
}

.service_impact {
    margin-top: 40px;
}

.service_impact .txt {
    margin: 20px 0 0;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    text-align: center;
    line-height: 1.7;
    letter-spacing: 0.1em;
    color: #7A7A7A;
}

.service_impact ul {
    margin: 25px 0 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.service_impact ul li {
    width: 100%;
    margin: 0 0 20px;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    text-align: justify;
    line-height: 1.7;
    letter-spacing: 0.1em;
    color: #7A7A7A;
}

.service_impact ul li span {
    margin: 0 auto 10px;
    width: 66px;
    height: 66px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2.9375rem;
    font-weight: 800;
    line-height: 1;
    border: transparent 7px solid;
    border-radius: 50%;
}

#ps-light .service_impact ul li span {
    color: #B2E8F9;
    border-color: #B2E8F9;
}

#ps-advance .service_impact ul li span {
    color: #F7C6DE;
    border-color: #F7C6DE;
}

.service_impact h4 {
    margin: 50px 0 0;
    padding: 30px 0 0;
    font-size: 1.5625rem;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
    letter-spacing: 0.18em;
    border-top: transparent 6px solid;
    position: relative;
}

.service_impact h4:after {
    content: '';
    width: 35px;
    height: 35px;
    background-color: #fff;
    border-top: transparent 0px solid;
    border-right: transparent 0px solid;
    border-bottom: transparent 6px solid;
    border-left: transparent 6px solid;
    transform: rotate(-45deg);
    position: absolute;
    top: -19px;
    left: calc(50% - 19px);
}

#ps-light .service_impact h4,
#ps-light .service_impact h4:after {
    border-color: #CDEAF3;
}

#ps-advance .service_impact h4,
#ps-advance .service_impact h4:after {
    border-color: #FAD9E9;
}

.service_impact .summarize {
    margin: 30px 0 0;
    padding: 20px;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 800;
    line-height: 1.7;
    letter-spacing: 0.1em;
    text-align: justify;
    border: transparent 5px solid;
}

#ps-light .service_impact .summarize {
    color: #00A0E9;
    border-color: #00A0E9;
}

#ps-advance .service_impact .summarize {
    color: #E64290;
    border-color: #E64290
}

#ps-light .service_impact strong {
    color: #008dbd;
}

#ps-advance .service_impact strong {
    color: #c93977;
}

#service_appeal {
    margin: 0 auto 90px;
    padding: 0 0 30px;
    background: linear-gradient(#fff 10%, #B4E1F2 50%, #CDEAF3);
}

.appeal_inner {
    max-width: 970px;
    width: 94%;
    margin: 0 auto 0;
    padding: 0 0 0;
}

.appeal_inner > p {
    margin: 0;
    font-size: 1.25rem;
    transform: skewX(0.03deg);
    font-weight: 500;
    line-height: 1.6;
    letter-spacing: 0.1em;
    text-align: center;
    color: #0398C2;
}

.appeal_point {
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.appeal_point > div {
    width: 48%;
    position: relative;
}

.appeal_point > div:nth-child(3) {
    margin-top: -25px;
}

.appeal_point > div::after {
    content: '';
    padding-top: 100%;
    display: block;
}

.appeal_point > div::before {
    content: '';
    position: absolute;
    width: 130%;
    height: 130%;
    top: -10%;
    right: 0;
    background: url(../../img/service/appeal-shadow.png) left bottom no-repeat;
    background-size: contain;
}

.appeal_point > div > p {
    width: 100%;
    height: 100%;
    margin: 0;
    background: url(../../img/service/appeal-back.png) center center no-repeat;
    background-size: contain;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.125rem;
    transform: skewX(0.03deg);
    font-weight: 800;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0;
    color: #fff;
}

@media screen and (min-width: 35.5em) {
    /* 568px sm */
    .series_header_inner h2 {
        width: 28%;
    }

    .series_header_inner .point {
        width: 20%;
        margin: 0;
        font-size: 1rem;
        letter-spacing: 0em;
    }

    .series_header .copy {
        font-size: 1.625rem;
        transform: skewX(0.03deg);
    }

    .column_1-3 {
        width: 31%;
    }

    .column_1-2 {
        width: 48%;
    }

    .service_impact ul li {
        width: 28%;
        margin: 0;
    }

    .appeal_inner > p {
        font-size: 2rem;
    }

    .appeal_point > div {
        width: 31%;
    }

    .appeal_point > div:nth-child(3) {
        margin-top: 0;
    }

    .appeal_point > div > p {
        font-size: 1.25rem;
        transform: skewX(0.03deg);
        letter-spacing: 0.1em;
    }
}

@media screen and (min-width: 48em) {
    /* 768px md */
    .series_header_inner .point {
        font-size: 1.125rem;
        letter-spacing: 0.1em;
    }

    .appeal_point > div {
        width: 27%;
    }

    .appeal_point > div > p {
        font-size: 1.625rem;
        transform: skewX(0.03deg);
    }
}


/* パララックス */
@media screen and (min-width: 48em) {
    /* 768px md */
    .service_features.fadeIn {
        transform: translateY(100px);
    }

    .service_features.fadeIn.is-fadeIn {
        transform: translateY(0);
    }

    .service_impact ul.fadeIn {
        transform: translateY(100px);
    }

    .service_impact ul.fadeIn.is-fadeIn {
        transform: translateY(0);
    }

    .appeal_point > .fadeIn {
        transform: translateY(100px);
    }

    .appeal_point > .fadeIn:nth-child(2) {
        transition-delay: 0.1s;
    }

    .appeal_point > .fadeIn:nth-child(3) {
        transition-delay: 0.2s;
    }

    .appeal_point > .fadeIn.is-fadeIn {
        transform: translateY(0);
    }
}
