.jp h1 {
    font-size: 40px!important;
    /* font-family: Noto Sans JP,sans-serif!important; */
    line-height: 1.24;
    color: #253746;
    font-weight: 500!important
}

@media screen and (max-width: 1024px) {
    .jp h1 {
        font-size:30px!important
    }
}

.jp h2 {
    font-size: 30px!important;
    /* font-family: Noto Sans JP,sans-serif!important; */
    line-height: 1.73;
    color: #253746;
    font-weight: 500!important;
    margin-bottom: 12px
}

@media screen and (max-width: 1024px) {
    .jp h2 {
        font-size:30px!important
    }
}

.jp h3 {
    font-size: 24px!important;
    /* font-family: Noto Sans JP,sans-serif!important; */
    line-height: 1.71;
    color: #253746;
    font-weight: 500!important;
    margin-bottom: 12px
}

@media screen and (max-width: 1024px) {
    .jp h3 {
        font-size:24px!important
    }
}

.jp h4, .jp h5, .jp h6 {
    font-weight: 500!important
}

/*
.jp a, .jp abbr, .jp address, .jp b, .jp h4, .jp h5, .jp h6, .jp input, .jp li, .jp p, .jp select, .jp span, .jp strong, .jp textarea {
    font-family: Noto Sans JP,sans-serif!important
}
*/

.jp p {
    font-size: 16px!important;
    line-height: 1.75;
    color: #253746;
    font-weight: 400!important;
}
.jp p {
    margin-top: 0;
    margin-bottom: 1rem;
}

.jp a:focus, .jp a:focus-visible, .jp a:focus-within, .jp button:focus, .jp button:focus-visible, .jp button:focus-within {
    outline: 3px dotted #ef9600!important;
}

.jp a:hover {
    text-decoration: none!important;
}

.jp ol li {
    font-size: 16px!important;
    /* font-family: Noto Sans JP,sans-serif!important; */
    line-height: 1.75;
    color: #253746;
    font-weight: 400!important;
    position: relative;
    margin-bottom: 6px;
    padding-left: 10px;
}

.jp ul li {
    font-size: 16px!important;
    /* font-family: Noto Sans JP,sans-serif!important; */
    line-height: 1.75;
    color: #253746;
    font-weight: 400!important;
    position: relative;
    margin-bottom: 6px;
    padding-left: 5px;
}

.jp.two-col-layout .two-col-layout-wrapper a.custom-btn.tranparent-blue-btn, .jp.two-col-layout .two-col-layout-wrapper a.custom-btn.tranparent-orange-btn {
    font-size: 16px;
}

.jp {
    .custom-btn-wrapper {
        display: block;
        float: left;
        width: 100%;
        max-width: 100%;
        position: relative;
        text-align: right;
        margin: 7px 0 8px;
    }
    a.custom-btn {
        display: inline-block;
        padding: 13px 34px;
        border-radius: 10px;
        min-width: 176px;
        -webkit-box-shadow: 0 0 0 transparent;
        box-shadow: 0 0 0 transparent;
        text-align: center;
        font-size: 16px;
        font-weight: 500;
        font-stretch: normal;
        line-height: normal;
        color: #253746;
    }
    a.custom-btn.tranparent-blue-btn {
        color: #007b84;
        font-size: 20px;
        min-width: 0;
        padding: 0;
        -webkit-transition: .4s ease;
        -o-transition: .4s ease;
        transition: .4s ease;
    }
    a.custom-btn.tranparent-blue-btn:hover {
        color: rgba(0,123,132,.62);
    }
    a.custom-btn.tranparent-blue-btn .arrow-right {
        border-left-color: #007b84;
        -webkit-transition: .4s ease;
        -o-transition: .4s ease;
        transition: .4s ease;
    }
    a.custom-btn.tranparent-blue-btn:hover .arrow-right {
        border-left-color: rgba(0,123,132,.62);
    }
    .arrow-right {
        width: 0;
        height: 0;
        border-top: 5px solid transparent;
        border-bottom: 5px solid transparent;
        border-left: 5px solid green;
        display: inline-block;
        margin-left: 10px;
    }
    a.custom-btn.blue-btn:hover {
        background-color: rgba(128,216,212,.62);
    }
    a.custom-btn.border-btn {
        border-radius: 17px;
        border: 1px solid #253746;
        color: #253746;
        background-color: #fff;
        -webkit-transition: .4s ease;
        -o-transition: .4s ease;
        transition: .4s ease;
    }
    a.custom-btn.border-btn:hover {
        background-color: rgba(0,178,169,.62);
    }
    a.custom-btn.blue-btn {
        border-radius: 17px;
        border: 1px solid #80d8d4;
        color: #253746;
        background-color: #80d8d4;
        -webkit-transition: .4s ease;
        -o-transition: .4s ease;
        transition: .4s ease
    }
    a:focus, a:focus-visible, a:focus-within, button:focus, button:focus-visible, button:focus-within {
        outline: 3px dotted #ef9600!important;
    }
    .aTeal:hover {
        color: #045755!important;
        text-decoration: underline!important;
    }
    .round-icon {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        width: auto;
        max-width: 70px;
        height: 70px
    }
    .curved-box {
        border-radius: 20px;
        overflow: hidden;
    }
    .no-border {
        border: 0!important;
    }
    .no-bg {
        background-color: transparent!important;
    }
    .bg-white {
        background-color: #fff!important;
    }
    .bg-blue .tranparent-blue-btn:hover {
        color: hsla(0,0%,100%,.8)!important;
    }
    .bg-blue .tranparent-blue-btn:hover .arrow-right {
        border-left-color: #fff!important;
    }
    .heading-wrapper {
        display: block;
        width: 100%;
        max-width: 100%;
        position: relative;
        padding: 5px 0;
    }
    .heading-wrapper h2 {
        /* font-family: Noto Sans JP,sans-serif!important; */
        margin-bottom: 3px!important;
        line-height: normal;
        font-size: 24px!important;
        color: #253746;
        font-weight: 500!important;
    }
    .heading-wrapper+.list-box-group.bg-white, .heading-wrapper+.list-box-group.list-border {
        margin-top: 8px;
    }
    figure.custom-cards.two-col-card, figure.custom-cards.two-col-card .two-col-card-wrapper {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    figure.custom-cards.two-col-card .two-col-card-wrapper {
        width: 100%;
        height: 100%;
    }
    figure.custom-cards, figure.custom-cards .round-card-icon {
        max-width: 100%;
        position: relative;
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    figure.custom-cards {
        background-color: #fff;
        border: 1px solid #c9cdd1;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-flow: column;
        flex-flow: column;
        margin-bottom: 0;
    }
    figure.custom-cards.two-col-card .left-block {
        width: 50%;
        background-color: #c9cdd1;
        display: block;
        float: left;
        min-height: 150px;
        background-size: cover;
        background-position: 50%;
        background-repeat: no-repeat;
    }
    figure.custom-cards.two-col-card figcaption {
        width: 50%;
        display: block;
        float: left;
        padding: 37px 25px 26px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
        flex-flow: row wrap;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    figure.custom-cards figcaption {
        display: block;
        width: 100%;
        max-width: 100%;
        float: left;
        padding: 44px 48px 45px;
        -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
        flex: 1 1 auto;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    figure.custom-cards figcaption h2 {
        margin-bottom: 5px!important;
        line-height: 1.37!important;
    }
    figure.custom-cards.two-col-card figcaption h3 {
        width: 100%;
    }
    figure.custom-cards figcaption h3,figure.custom-cards figcaption h5 {
        font-size: 18px!important;
        color: #253746;
        line-height: 2.28;
        font-weight: 400!important;
        margin-bottom: 10px!important;
    }
    figure.custom-cards.two-col-card figcaption p+.custom-btn-wrapper {
        margin-top: 13px;
    }
    figure.custom-cards figcaption .custom-btn-wrapper {
        margin: 3px 0;
    }
    figure.custom-cards.two-col-card figcaption a.custom-btn {
        width: 100%;
        padding: 13px 15px;
    }
    figure.custom-cards figcaption .custom-btn-wrapper .tranparent-black-btn, figure.custom-cards figcaption .custom-btn-wrapper .tranparent-blue-btn {
        display: inline-block;
        width: auto;
        font-size: 16px;
    }
    figure.custom-cards .round-card-icon {
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end;
        padding: 50px 50px 0;
        height: auto;
    }
    figure.custom-cards.no-bg.no-border .round-card-icon {
        height: auto;
        padding-top: 0;
    }
    figure.custom-cards .round-card-icon+figcaption {
        padding-top: 20px;
    }
    figure.custom-cards figcaption .bottom-content, figure.custom-cards figcaption .top-content {
        display: block;
        float: left;
        width: 100%;
        max-width: 100%;
        position: relative;
    }
    figure.custom-cards figcaption .bottom-content {
        margin-top: 27px;
    }
    figure.custom-cards a.custom-btn.blue-btn {
        padding: 13px 15px;
    }
}

.jp.two-col-layout .two-col-layout-wrapper a.custom-btn.tranparent-blue-btn,.jp.two-col-layout .two-col-layout-wrapper a.custom-btn.tranparent-orange-btn {
    font-size: 16px
}
.jp.list-box-holder {
    display: block;
    width: 100%;
    max-width: 100%;
    position: relative;
    padding: 44px 0 38px;
}
.jp.list-box-holder .list-box-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 auto;
    width: 100%;
    max-width: 850px;
}
.jp.list-box-holder .heading-wrapper {
    padding-top: 0;
    padding-bottom: 0;
}
.jp.list-box-holder .heading-wrapper h2 {
    line-height: 1.73;
}
.jp.list-box-holder .custom-btn-wrapper {
    margin-top: 19px!important;
}

@media (max-width: 767px) {
    .jp.list-box-holder .heading-wrapper {
        margin-bottom: 5px;
    }
    .jp.list-box-holder .custom-btn-wrapper {
        margin-top: 9px!important;
    }
    .jp figure.custom-cards figcaption .custom-btn-wrapper a {
        display: block;
        width: 100%;
    }
    div.jp figure.custom-cards .round-card-icon {
        height: auto;
        padding: 30px 20px 0;
    }
}

@media (max-width: 768px) {
    .jp a.custom-btn {
        display: block;
        width: 100%;
    }
}

@media screen and (max-width: 991px) {
    .jp figure.custom-cards.two-col-card .left-block {
        width: 100%;
        display: none;
    }
    .jp figure.custom-cards.two-col-card figcaption {
        width: 100%;
    }
}

@media screen and (max-width: 1024px) {
    .jp.list-box-holder {
        padding: 34px 0 24px;
    }
    .jp figure.custom-cards .round-card-icon {
        padding: 50px 20px 0;
    }
    .jp figure.custom-cards figcaption {
        padding: 25px 20px;
    }
    .jp figure.custom-cards figcaption h2 {
        font-size: 24px!important;
        margin-bottom: 8px;
    }
    .jp figure.custom-cards figcaption .bottom-content {
        margin-top: 0;
    }
}

@media screen and (max-width: 1299px) {
    .jp figure.custom-cards.two-col-card figcaption {
        padding: 37px 10px 45px!important;
    }
}

@media (max-width: 1300px) {
    .jp a.custom-btn {
        min-width: 0;
        padding: 10px 25px;
    }
}

.jp.two-col-layout {
    display: block;
    width: 100%;
    max-width: 100%;
    position: relative;
    padding: 49px 0;
}

@media screen and (max-width: 1024px) {
    .jp.two-col-layout {
        padding: 41px 0;
    }
}

.BlueButton,.OrangeButton,.TransparentButton,.WhiteButton {
    display: block;
    width: 100%;
    max-width: 100%;
    position: relative;
    margin-top: 7px
}

@media screen and (max-width: 574px) {
    .BlueButton,.OrangeButton,.TransparentButton,.WhiteButton {
        margin-top:20px
    }
}

.BlueButton a,.OrangeButton a,.TransparentButton a,.WhiteButton a {
    display: inline-block;
    padding: 13px 32px;
    border-radius: 10px;
    min-width: 176px;
    -webkit-box-shadow: 0 0 0 transparent;
    box-shadow: 0 0 0 transparent;
    text-align: center;
    font-size: 16px;
    font-weight: 500!important;
    font-stretch: normal;
    line-height: normal;
    color: #253746
}

.BlueButton a:hover,.OrangeButton a:hover,.TransparentButton a:hover,.WhiteButton a:hover {
    text-decoration: none;
    color: #253746
}

.TransparentButton a {
    display: inline-block;
    padding: 13px 32px;
    border-radius: 10px;
    min-width: 176px;
    -webkit-box-shadow: 0 0 0 transparent;
    box-shadow: 0 0 0 transparent;
    text-align: center;
    font-size: 16px;
    font-weight: 500;
    font-stretch: normal;
    line-height: normal;
    border-radius: 17px;
    border: 1px solid #000;
    color: #253746;
    background-color: transparent;
    -webkit-transition: .4s ease;
    -o-transition: .4s ease;
    transition: .4s ease
}

.TransparentButton a:hover {
    color: #107f78;
    border: 1px solid #107f78
}

.WhiteButton a {
    border-radius: 17px;
    border: 1px solid #253746;
    color: #253746;
    background-color: #fff;
    -webkit-transition: .4s ease;
    -o-transition: .4s ease;
    transition: .4s ease
}

.WhiteButton a:hover {
    background-color: rgba(0,178,169,.62)
}

.BlueButton a {
    border-radius: 17px;
    border: 1px solid #80d8d4;
    color: #253746;
    background-color: #80d8d4;
    -webkit-transition: .4s ease;
    -o-transition: .4s ease;
    transition: .4s ease
}

.BlueButton a:hover {
    background-color: rgba(128,216,212,.62)
}

.OrangeButton a {
    border-radius: 17px;
    border: 1px solid #ef9600;
    color: #253746;
    background-color: #ef9600;
    -webkit-transition: .4s ease;
    -o-transition: .4s ease;
    transition: .4s ease
}

.OrangeButton a:hover {
    background-color: rgba(239,150,0,.8)
}

@media (max-width: 1300px) {
    .BlueButton a,.OrangeButton a,.WhiteButton a {
        min-width:0;
        padding: 10px 25px
    }
}

@media (max-width: 767px) {
    .BlueButton a,.OrangeButton a,.WhiteButton a {
        display:block;
        width: 100%
    }
}

.jp .rich-text-block a {
    display: inline-block
}

a .BlueButton,a .OrangeButton,a .WhiteButton {
    float: left;
    width: 100%;
    max-width: 100%;
    position: relative;
    margin: 7px 0 8px;
    display: inline-block;
    padding: 15px 10px;
    border-radius: 10px;
    min-width: 176px;
    -webkit-box-shadow: 0 0 0 transparent;
    box-shadow: 0 0 0 transparent;
    text-align: center;
    font-size: 16px;
    font-weight: 700;
    font-stretch: normal;
    line-height: normal;
    color: #253746
}

a .BlueButton:hover,a .OrangeButton:hover,a .WhiteButton:hover {
    text-decoration: none;
    color: #253746
}

a .WhiteButton {
    border-radius: 17px;
    border: 1px solid #253746;
    color: #253746;
    background-color: #fff
}

a .BlueButton {
    border-radius: 17px;
    border: 1px solid #80d8d4;
    color: #253746;
    background-color: #80d8d4
}

a .OrangeButton {
    border-radius: 17px;
    border: 1px solid #ef9600;
    color: #253746;
    background-color: #ef9600
}

@media (max-width: 1300px) {
    a .BlueButton,a .OrangeButton,a .WhiteButton {
        min-width:0;
        padding: 10px 25px
    }
}

@media (max-width: 768px) {
    a .BlueButton,a .OrangeButton,a .WhiteButton {
        display:block;
        width: 100%
    }
}