/* -----------------
m_lead_wrap
-------------------- */
.m_lead_wrap {
    padding-bottom: 135px;
}

.m_lead_wrap .inner {
    padding-bottom: 71px;
    background : #F1F1F1;
}

.m_lead_wrap .box {
    display: flex;
}

.m_lead_wrap .box .txt {
    display: flex;
    align-items: center;
    width: calc(100% - 49.714285714%);
}

.m_lead_wrap .box .txt span {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    margin: 0 auto;
    padding: 15px;
    max-width: 470px;
}

.m_lead_wrap .box .image {
    width: 49.714285714%;
}

.m_lead_wrap .list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 72px auto 0;
    width: calc(100% - 30px);
    max-width: 1258px;
}

.m_lead_wrap .list::after {
    content:"";
    width: 29.570747217%;
}

.m_lead_wrap .list li {
    padding: 58px 0 43px;
    width: 29.570747217%;
    background: #fff;
}

.m_lead_wrap .list .sttl {
    font-weight: 500;
    font-size: 2.8rem;
    line-height: calc(48 / 28);
    letter-spacing: .02em;
    text-indent: .02em;
    text-align: center;
}

.m_lead_wrap .list .txt {
    font-weight: 500;
    font-size: 1.8rem;
    line-height: calc(34 / 18);
    letter-spacing: .04em;
    margin: 37px auto 0;
    width: calc(100% - 30px);
    max-width: 259px;
}

@media screen and (max-width: 767px) {
    .m_lead_wrap {
        padding-bottom: 68px;
    }

    .m_lead_wrap .inner {
        padding-bottom: 35px;
    }

    .m_lead_wrap .box {
        display: block;
        padding: 30px 3% 0;
    }

    .m_lead_wrap .box .txt {
        display: block;
        width: 100%;
    }

    .m_lead_wrap .box .txt span {
        display: block;
        padding: 0;
        max-width: 100%;
    }

    .m_lead_wrap .box .image {
        margin-top: 15px;
        width: 100%;
    }

    .m_lead_wrap .list {
        display: block;
        margin-top: 30px;
        width: calc(100% - 6%);
    }

    .m_lead_wrap .list::after {
        width: auto;
    }

    .m_lead_wrap .list li {
        padding: 29px 22px;
        width: 100%;
    }

    .m_lead_wrap .list li:nth-child(n+2) {
        margin-top: 20px;
    }

    .m_lead_wrap .list .sttl {
        font-size: 2rem;
        line-height: calc(28 / 20);
    }

    .m_lead_wrap .list .txt {
        font-size: 1.4rem;
        line-height: calc(28 / 14);
        margin-top: 18px;
        width: calc(100% - 12%);
        max-width: 100%;
    }
}

/* -----------------
sec01
-------------------- */
.sec01 .ttl {
    font-weight: 500;
    font-size: 3.8rem;
    line-height: calc(78 / 38);
    text-align: center;
    margin-top: 59px;
}

.sec01 .lead {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    margin: 24px auto 0;
    max-width: 653px;
}

.sec01 .pm_list {
    display: flex;
    justify-content: space-between;
    margin-left: auto;
    margin-right: auto;
}

.sec01 .pm_list .sttl {
    font-weight: 500;
    font-size: 2.8rem;
    line-height: calc(48 / 28);
    letter-spacing: .02em;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    margin-top: 28px;
}

.sec01 .pm_list .sttl_sml {
    font-weight: 400;
    font-size: 1.4rem;
    line-height: calc(36 / 14);
    letter-spacing: .04em;
}

.sec01 .pm_list .txt {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    margin: 11px auto 0;
    width: calc(100% - 30px);
}

.sec01 .col2_list {
    margin-top: 76px;
    max-width: 1330px;
}

.sec01 .col2_list li {
    width: 47.518796992%;
}

.sec01 .col2_list .txt {
    max-width: 525px;
}

.sec01 .col3_list {
    flex-wrap: wrap;
    margin-top: 80px;
    max-width: 1345px;
}

.sec01 .col3_list::after {
    content:"";
    width: 29.368029739%;
}

.sec01 .col3_list li {
    width: 29.368029739%;
}

.sec01 .box {
    display: flex;
    align-items: center;
    margin-top: 136px;
}

.sec01 .box .txt_box {
    padding: 0 6.09589041% 0 7.397260273%;
    width: calc(100% - 55.136986301%);
}

.sec01 .box .txt_box .sttl {
    font-weight: 500;
    font-size: 2.8rem;
    line-height: calc(48 / 28);
    letter-spacing: .02em;
}

.sec01 .box .txt_box .txt {
    font-weight: 500;
    font-size: 1.6rem;
    line-height: calc(32 / 16);
    letter-spacing: .04em;
    margin-top: 42px;
}

.sec01 .box .image {
    width: 55.136986301%;
}

.sec01 .list {
    display: flex;
    justify-content: space-between;
    margin: 134px auto 0;
    width: calc(100% - 60px);
    max-width: 1330px;
}

.sec01 .list > li {
    width: 47.744360902%;
    background: #f1f1f1;
}

.sec01 .list .sttl {
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    z-index: 1;
    padding: 0 10.078740157%;
    height: 200px;
}

.sec01 .list .sttl .bg {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
}

.sec01 .list .sttl .bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sec01 .list .sttl span {
    color: #fff;
    display: block;
}

.sec01 .list .sttl_jp {
    font-weight: 500;
    font-size: 3.2rem;
    line-height: calc(42 / 32);
    letter-spacing: .08em;
}

.sec01 .list .sttl_en {
    font-weight: 700;
    font-size: 1.4rem;
    line-height: 1;
    letter-spacing: .02em;
    position: relative;
    margin-top: 14px;
    padding-top: 19px;
}

.sec01 .list .sttl_en::before {
    content:"";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 96px;
    height: 2px;
    background: #fff;
}

.sec01 .list .txt_box {
    padding: 43px 15px 51px;
}

.sec01 .list .txt_box .ssttl {
    font-weight: 500;
    font-size: 2.4rem;
    line-height: calc(48 / 24);
    letter-spacing: .02em;
    margin: 0 auto;
    max-width: 481px;
}

.sec01 .list .txt_box .ssttl + .txt {
    margin-top: 20px;
}

.sec01 .list .txt_box .txt {
    font-weight: 500;
    font-size: 1.6rem;
    line-height: calc(32 / 16);
    letter-spacing: .04em;
    margin: 0 auto;
    max-width: 481px;
}

.sec01 .list .txt_box .sml_txt {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    margin: 0 auto;
    max-width: 481px;
}

.sec01 .list > li:nth-child(1) .txt_box .d_list {
    margin: 45px auto 0;
    max-width: 546px;
}

.sec01 .list > li:nth-child(2) .txt_box .d_list {
    margin: 34px auto 0;
    max-width: 470px;
}

.sec01 .list .txt_box .d_list dt {
    font-weight: 500;
    font-size: 2rem;
    line-height: calc(36 / 20);
    letter-spacing: .02em;
    text-align: center;
}

.sec01 .list .txt_box .d_list > dd {
    margin-top: 16px;
}

.sec01 .list .txt_box .circle_list {
    display: flex;
    justify-content: center;
}

.sec01 .list .txt_box .circle_list + .sml_txt {
    margin-top: 49px;
}

.sec01 .list .txt_box .circle_list > li {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    width: 210px;
    height: 210px;
    border-radius: 50%;
    background: #fff;
}

.sec01 .list .txt_box .d_circle_list dt {
    font-weight: 500;
    font-size: 2.4rem;
    line-height: 1;
    letter-spacing: .02em;
    text-indent: .02em;
    text-align: center;
}

.sec01 .list .txt_box .d_circle_list dd {
    font-weight: 500;
    font-size: 2rem;
    line-height: calc(32 / 20);
    letter-spacing: .02em;
    text-indent: .02em;
    text-align: center;
    position: relative;
    margin-top: 17px;
    padding-top: 10px;
}

.sec01 .list .txt_box .d_circle_list dd::before {
    content:"";
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    width: 39px;
    height: 1px;
    background: var(--m_color_bk);
    transform: translateX(-50%);
}

.sec01 .list .txt_box .square_list + .sml_txt {
    margin-top: 24px;
}

.sec01 .list .txt_box .square_list li {
    text-align: center;
    padding: 9px;
    border-radius: 5px;
    background: #fff;
}

.sec01 .list .txt_box .square_list li:nth-child(n+2) {
    margin-top: 25px;
}

.sec01 .list .txt_box .square_list li span {
    font-weight: 500;
    font-size: 2rem;
    line-height: calc(32 / 20);
    letter-spacing: .02em;
    text-align: left;
    display: inline-block;
}

.sec01 .m_contact_wrap {
    padding: 81px 0 145px;
}

@media screen and (max-width: 1089px) {
    .sec01 .ttl {
        font-size: 3.6rem;
    }

    .sec01 .box .txt_box {
        padding: 0 44px 0 54px;
    }

    .sec01 .list {
        align-items: flex-start;
    }

    .sec01 .list .txt_box .circle_list {
        display: block;
    }

    .sec01 .list .txt_box .circle_list > li:nth-child(n+2) {
        margin-top: 16px;
    }
}

@media screen and (max-width: 767px) {
    .sec01 .ttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
        text-align: left;
        margin-top: 30px;
    }

    .sec01 .lead {
        margin-top: 12px;
        max-width: 100%;
    }

    .sec01 .pm_list {
        display: block;
    }

    .sec01 .pm_list li:nth-child(n+2) {
        margin-top: 40px;
    }

    .sec01 .pm_list .sttl {
        font-size: 1.6rem;
        line-height: calc(26 / 16);
        margin-top: 14px;
    }

    .sec01 .pm_list .sttl_sml {
        font-size: 1.2rem;
        line-height: calc(24 / 12);
    }

    .sec01 .pm_list .txt {
        margin-top: 11px;
        width: calc(100% - 6%);
    }

    .sec01 .col2_list {
        margin-top: 38px;
    }

    .sec01 .col2_list li {
        width: 100%;
    }

    .sec01 .col2_list .txt {
        max-width: 100%;
    }

    .sec01 .col3_list {
        margin-top: 40px;
    }

    .sec01 .col3_list::after {
        width: auto;
    }

    .sec01 .col3_list li {
        width: 100%;
    }

    .sec01 .box {
        display: block;
        margin-top: 60px;
    }

    .sec01 .box .txt_box {
        padding: 0 3%;
        width: 100%;
    }

    .sec01 .box .txt_box .sttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
    }

    .sec01 .box .txt_box .txt {
        font-size: 1.4rem;
        line-height: calc(28 / 14);
        margin-top: 21px;
    }

    .sec01 .box .image {
        margin-top: 15px;
        width: 100%;
    }

    .sec01 .list {
        display: block;
        margin-top: 60px;
        width: 94%;
    }

    .sec01 .list > li {
        width: 100%;
    }

    .sec01 .list > li:nth-child(n+2) {
        margin-top: 20px;
    }

    .sec01 .list .sttl {
        display: block;
        padding: 30px 6%;
        height: auto;
    }

    .sec01 .list .sttl_jp {
        font-size: 2rem;
        line-height: calc(28 / 20);
        letter-spacing: .04em;
    }

    .sec01 .list .sttl_en {
        font-size: 1.2rem;
        margin-top: 7px;
        padding-top: 10px;
    }

    .sec01 .list .sttl_en::before {
        width: 80px;
        height: 1px;
    }

    .sec01 .list .txt_box {
        padding: 21px 3% 25px;
    }

    .sec01 .list .txt_box .ssttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
        max-width: 100%;
    }

    .sec01 .list .txt_box .ssttl + .txt {
        margin-top: 10px;
    }

    .sec01 .list .txt_box .txt {
        font-size: 1.4rem;
        line-height: calc(28 / 14);
        max-width: 100%;
    }

    .sec01 .list .txt_box .sml_txt {
        font-size: 1.2rem;
        line-height: calc(26 / 12);
        max-width: 100%;
    }

    .sec01 .list > li:nth-child(1) .txt_box .d_list {
        margin-top: 22px;
        max-width: 100%;
    }

    .sec01 .list > li:nth-child(2) .txt_box .d_list {
        margin-top: 17px;
        max-width: 100%;
    }

    .sec01 .list .txt_box .d_list dt {
        font-size: 1.6rem;
        line-height: calc(28 / 16);
    }

    .sec01 .list .txt_box .circle_list + .sml_txt {
        margin-top: 25px;
    }

    .sec01 .list .txt_box .square_list + .sml_txt {
        margin-top: 12px;
    }

    .sec01 .list .txt_box .square_list li {
        padding: 5px;
        border-radius: 3px;
    }

    .sec01 .list .txt_box .square_list li:nth-child(n+2) {
        margin-top: 12px;
    }

    .sec01 .list .txt_box .square_list li span {
        font-size: 1.6rem;
        line-height: calc(28 / 16);
    }

    .sec01 .m_contact_wrap {
        padding: 40px 0 72px;
    }
}

/* -----------------
sec02
-------------------- */
.sec02 .ttl {
    font-weight: 500;
    font-size: 3.8rem;
    line-height: calc(78 / 38);
    text-align: center;
    margin-top: 59px;
}

.sec02 .lead {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    text-align: center;
    margin: 24px auto 0;
    max-width: 773px;
}

.sec02 .list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 70px auto 0;
    max-width: 1330px;
}

.sec02 .list li {
    font-weight: 500;
    font-size: 2.8rem;
    line-height: calc(48 / 28);
    letter-spacing: .02em;
    text-indent: .02em;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 16.834532374vw;
    max-width: 234px;
    height: 16.834532374vw;
    max-height: 234px;
    border-radius: 50%;
    background: #f1f1f1;
}

.sec02 .box {
    display: flex;
    align-items: center;
    margin-top: 130px;
}

.sec02 .box .txt_box {
    padding: 0 6.09589041% 0 7.397260273%;
    width: calc(100% - 55.136986301%);
}

.sec02 .box .txt_box .sttl {
    font-weight: 500;
    font-size: 2.8rem;
    line-height: calc(48 / 28);
    letter-spacing: .02em;
}

.sec02 .box .txt_box .txt {
    font-weight: 500;
    font-size: 1.6rem;
    line-height: calc(32 / 16);
    letter-spacing: .04em;
    margin-top: 42px;
}

.sec02 .box .image {
    width: 55.136986301%;
}

.sec02 .m_contact_wrap {
    padding: 100px 0 157px;
}

@media screen and (max-width: 1089px) {
    .sec02 .ttl {
        font-size: 3.6rem;
    }

    .sec02 .list {
        justify-content: center;
        max-width: 500px;
    }

    .sec02 .list li {
        width: 234px;
        max-width: initial;
        height: 234px;
        max-height: initial;
    }

    .sec02 .list li:nth-child(even) {
        margin-left: 20px;
    }

    .sec02 .list li:nth-child(n+3) {
        margin-top: 20px;
    }
}

@media screen and (max-width: 767px) {
    .sec02 .ttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
        text-align: left;
        margin-top: 30px;
    }

    .sec02 .lead {
        text-align: left;
        margin-top: 12px;
        max-width: 100%;
    }

    .sec02 .list {
        margin-top: 35px;
        max-width: 301px;
    }

    .sec02 .list li {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
        letter-spacing: .02em;
        text-indent: .02em;
        width: 45.5vw;
        max-width: 145px;
        height: 45.5vw;
        max-height: 145px;
    }

    .sec02 .list li:nth-child(even) {
        margin-left: 3%;
    }

    .sec02 .list li:nth-child(n+3) {
        margin-top: 9px;
    }

    .sec02 .box {
        display: block;
        margin-top: 65px;
    }

    .sec02 .box .txt_box {
        padding: 0 3%;
        width: 100%;
    }

    .sec02 .box .txt_box .sttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
    }

    .sec02 .box .txt_box .txt {
        font-size: 1.4rem;
        line-height: calc(28 / 14);
        margin-top: 21px;
    }

    .sec02 .box .image {
        margin-top: 15px;
        width: 100%;
    }

    .sec02 .m_contact_wrap {
        padding: 50px 0 78px;
    }
}

/* -----------------
sec03
-------------------- */
.sec03 .ttl {
    font-weight: 500;
    font-size: 3.8rem;
    line-height: calc(78 / 38);
    text-align: center;
    margin-top: 59px;
}

.sec03 .lead {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    text-align: center;
    margin: 24px auto 0;
    max-width: 653px;
}

.sec03 .list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 107px auto 0;
    max-width: 1330px;
}

.sec03 .list::after {
    content:"";
    width: 29.69924812%;
}

.sec03 .list li {
    width: 29.69924812%;
}

.sec03 .list .sttl {
    margin-top: 31px;
}

.sec03 .list .sttl span {
    line-height: 1;
    letter-spacing: .02em;
    text-indent: .02em;
    text-align: center;
    display: block;
}

.sec03 .list .sttl_jp {
    font-weight: 500;
    font-size: 2.4rem;
}

.sec03 .list .sttl_en {
    font-weight: 700;
    font-size: 1.4rem;
    margin-top: 19px;
}

.sec03 .list .txt {
    font-size: 1.4rem;
    line-height: calc(28 / 14);
    letter-spacing: .04em;
    margin-top: 17px;
}

.sec03 .m_contact_wrap {
    padding: 99px 0 146px;
}

@media screen and (min-width: 768px) {
    .sec03 .ttl {
        font-size: 3.6rem;
    }

    .sec03 .list li:nth-child(2) {
        width: 30.827067669%;
    }
}

@media screen and (max-width: 767px) {
    .sec03 .ttl {
        font-size: 1.8rem;
        line-height: calc(28 / 18);
        text-align: left;
        margin-top: 30px;
    }

    .sec03 .lead {
        text-align: left;
        margin-top: 12px;
        max-width: 100%;
    }

    .sec03 .list {
        display: block;
        margin-top: 53px;
    }

    .sec03 .list::after {
        width: auto;
    }

    .sec03 .list li {
        width: 100%;
    }

    .sec03 .list li:nth-child(n+2) {
        margin-top: 40px;
    }

    .sec03 .list .sttl {
        margin-top: 15px;
    }

    .sec03 .list .sttl_jp {
        font-size: 1.8rem;
    }

    .sec03 .list .sttl_en {
        font-size: 1.2rem;
        margin-top: 9px;
    }

    .sec03 .list .txt {
        margin-top: 9px;
    }

    .sec03 .m_contact_wrap {
        padding: 50px 0 73px;
    }
}
