@charset "UTF-8";
/***************************
common
***************************/
#Contents {
    padding: 40px 0 0 0;
    font-family: "Noto Sans", "Noto Sans CJK JP", sans-serif;
}
#Clmbx {
    margin: 0 0 60px 0;
}
.btn a:hover{
    opacity: 0.7;
}
.btn a {
    display: inline-block;
}
.com_maintitle {
    width: 940px;
    margin: 0 auto 50px;
}
/***************************
application
***************************/
.application{
    width: 940px;
    border: 2px solid #00217a;
    padding: 55px 68px;
    box-sizing: border-box;
    margin: 0 auto;
}
.application .ttl {
    margin: 0 0 30px 0;
}
.application .btnbx {
    margin: 0 0 30px 0;
}
.application .btn {
    display: inline-block;
}
.application .btn:first-child {
    padding: 0 35px 0 0;
}
.application .btn a {
    display: inline-block;
}
/***************************
information
***************************/
.information{
    width: 1024px;
    box-sizing: border-box;
    margin: 0 auto;
    padding: 36px 101px 87px;
    background: #fff;
    border-radius: 40px;
    box-shadow: 0 0 10px rgba(60, 175, 205, 0.06);
}
.information .ttl{
    margin-bottom: 24px;
}
.information .infoin {
    margin-bottom: 29px;
}
.information .infoin dl {
    display: flex;
    margin: 0 0 41px;
}
.information .infoin dl:last-child{
    margin: 0;
}
.information .infoin dl dt {
    text-align: left;
}
.information .infoin dl dt span {
    display: inline-block;
    width: 120px;
    background: #004ea2;
    border-radius: 10px;
    font-size: 20px;
    line-height: 1;
    color: #fff;
    font-weight: bold;
    text-align: center;
    padding: 10px 0;
}
.information .infoin dl dd {
    letter-spacing: normal;
    text-align: left;
    padding: 10px 0 0 23px;
    font-size: 26px;
    line-height: 1;
    color: #000000;
    font-weight: bold;
    text-align: left;
}
.information .infoin dl:last-child dd {
    padding: 0 0 0 23px;
}
.information .infoin dl dd .s2{
    padding-top: 10px;
    display: inline-block;
    font-size: 18px;
    font-weight: normal;
    font-feature-settings: "palt";
}
.information .infoimg1 {
    text-align: center;
}
.information .infoimg1 img {
    border-radius: 16px;
}
.information .infoimg2 {
    text-align: center;
    margin-bottom: 79px;
}
/***************************
page
***************************/
.topsc {
    background: url(images/mvbg-repeat.png) repeat-x center top;
    background-color: #0068b7;
}
.topimg {
    background: url(images/mvbg.png) no-repeat center center;
    width: 100%;
    height: 563px;
    text-align: center;
}
.topimg img {
    padding-top: 33px;
    transform: translateX(27px);
    display: block;
    margin: 0 auto;
}
/***************************
about
***************************/
.topsub_img {
    padding-bottom: 70px;
    text-align: center;
}
.about_wrap {
    position: relative;
    width: 100%;
    background-color: #ecfaff;
    z-index: 1;
}
.about_wrap::before {
    position: absolute;
    background: url(images/bg1_25.png) no-repeat center center;
    background-size: 100% auto;
    content: '';
    width: 100%;
    height: 9.37vw;
    left: 0;
    top: -80px;
    z-index: -1;
}
.about_in {
    margin: 0 auto;
    padding: 45px 0 max(17.204vw,235px);
    width: 1024px;
}
/***************************
mate
***************************/
.mate_wrap {
	background: #fff;
    position: relative;
    padding: 188px 0 101px;
}
.mate_wrap.mate_top::before {
    position: absolute;
    content: "";
    background: url(images/bg2.png) no-repeat bottom center / 100% auto;
    width: 100%;
    height: 2.394vw;
    top: -2.2vw;
    left: 0;
    z-index: 1;
}
.matetxt_wrap {
    width: 940px;
    margin: 0 auto 0;
    position: relative;
}
.mate-wrapttl {
    margin-bottom: 111px;
}
.matetxt_wrap.is-ver2 {
    margin: 0 auto 164px;
}
.matetxt_wrap.is-ver2::before {
    position: absolute;
    background: url(images/mate_bgimg01.png) no-repeat;
    content: '';
    width: 90px;
    height: 144px;
    left: 0;
    top: -87px;
    z-index: 9;
}
.matetxt_wrap.is-ver3 {
    margin: 0 auto 124px;
}
.matetxt_wrap.is-ver4::before {
    position: absolute;
    background: url(images/mate_bgimg02.png) no-repeat;
    content: '';
    width: 173px;
    height: 116px;
    right: 0;
    top: -60px;
    z-index: 9;
}
.mate_ttl {
    margin-bottom: 38px;
}
.mate_ttl.ver2 {
    margin-bottom: 36px;
}
.mate_ttl.ver3 {
    margin-bottom: 37px;
}
.extdCnt_Intxt p {
    font-size: 22px;
    line-height: 1.8;
    font-weight: 500;
    text-align: left;
}
.mateCnt_wrap {
    position: relative;
    width: 940px;
    margin: 150px auto 0 auto;
    border-radius: 10px;
    box-sizing: border-box;
    background: #fefcef;
}
.mateCnt_ttl {
    position: absolute;
    top: -96px;
    left: 30px;
    z-index: 10;
}
.mateCnt-ttl {
    width: 180px;
    height: 180px;
}
.mateCnt-ttl span {
    width: 100%;
    height: 0;
    display: block;
    overflow: hidden;
    padding: 180px 0 0 0;
}
.mateCnt-ttl.l1 span {
    background: url(images/matecnt_ttl01.png) no-repeat 0 0;
    background-size: 100% auto;
}
.mateCnt-ttl.l2 span {
    background: url(images/matecnt_ttl02.png) no-repeat 0 0;
    background-size: 100% auto;
}
.mateCnt-ttl.l3 span {
    background: url(images/matecnt_ttl03.png) no-repeat 0 0;
    background-size: 100% auto;
}
.mateCnt_img {
    text-align: center;
}
.mateCnt_wrap.n1 {
    padding: 115px 0 52px;
    margin: 234px auto 0 auto;
    border: 6px solid #397bf5;
}
.mateCnt_wrap.n2 {
    padding: 66px 50px;
    border: 6px solid #f67100;
}
.mateCnt_wrap.n3 {
    padding: 135px 30px 76px;
    border: 6px solid #f33f94;
}
.mateTxt_tp {
    font-size: 28px;
    line-height: 1.6;
    font-weight: 500;
    text-align: left;
}
.n1 .mateTxt_tp {
    padding: 0 20px 20px 220px;
}
.n2 .mateTxt_tp {
    padding: 60px 34px 0 0;
    width: calc(100% - 350px);
    box-sizing: border-box;
}
.n3 .mateTxt_tp {
    padding: 0 20px 20px;
}
.n1 .mateTxt_wrap {
    display: flex;
    flex-wrap: wrap;
    padding-left: 44px;
}
.n2 .mateTxt_wrap {
    display: flex;
    flex-wrap: wrap;
}
.n3 .mateCnt_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-top: 60px;
}
.mateTxt_dl {
    border: 3px solid #f33f94;
    padding: 24px;
    width: 405px;
    background: #fff;
    border-radius: 10px;
    box-sizing: border-box;
}
.mateTxt_dl dt {
    font-size: 28px;
    line-height: 1.2;
    font-weight: 500;
    text-align: center;
    color: #f33f94;
    font-feature-settings: "palt";
    padding: 0 0 20px;
}
.mateTxt_dl dt span {
    font-size: 42px;
    font-weight: bold;
}
.mateTxt_dl dd {
    font-size: 24px;
    line-height: 1.6;
    font-weight: 500;
    text-align: left;
}
.mateTxt_left {
    width: 456px;
}
.mateTxt_bx {
    width: 100%;
    border: 3px solid #ed393d;
    background-color: #fff;
    font-size: 24px;
    line-height: 1.5;
    font-weight: 500;
    text-align: left;
    border-radius: 3px;
    padding: 20px 28px;
    box-sizing: border-box;
}
.n1-txt {
    display: block;
    text-align: center;
    line-height: 1;
    font-size: 30px;
    font-weight: 900;
    color: #ed393d;
    margin: 0 0 15px 0;
}
.youtube {
    text-align: center;
    margin-top: 30px;
    margin-bottom: 26px;
}
.youtube .ttl {
    font-size: 24px;
    font-weight: bold;
    color: #00a0e9;
    margin: 0 0 15px 0;
}
.youtube .ttl span {
    display: flex;
    justify-content: center;
    align-items: center;
}
.youtube .ttl span:before,
.youtube .ttl span:after {
    content: '';
    width: 3px;
    height: 28px;
    background-color: #00a0e9;
}
.youtube .ttl span:before {
    margin-right: 18px;
    transform: rotate(-35deg)
}
.youtube .ttl span:after {
    margin-left: 18px;
    transform: rotate(35deg)
}
.youtube .mv iframe {
    width: 458px;
    height: 258px;
}
/***************************
stepFlow
***************************/
.stepFlow_wrap {
    padding-bottom: 82px;
}
.step_ttl {
    margin-bottom: 70px;
}
/***************************
money
***************************/
.money_wrap {
    margin-top: 80px;
    background: #e7f7f8;
    padding: 68px 0 56px;
}
.money_in {
    width: 440px;
    margin: 0 auto;
}
.money_in.ver1 {
    margin-bottom: 34px;
}
.money_in.ver2 {
    margin-bottom: 30px;
}
.money_ttl {
    font-size: 44px;
    font-weight: bold;
    color: #004ea2;
    margin-bottom: 30px;
    line-height: 1.36;
}
.money_box {
    width: 440px;
    background-color: #fff;
    border-radius: 15px;
    padding: 55px 0 50px;
    box-shadow: rgba(0, 0, 0, .1) 0 0 10px;
}
.money_pay {
    font-size: 36px;
    font-weight: bold;
}
.money_pay span {
    font-size: 20px;
    font-weight: normal;
}
.money_pay .tax {
    font-size: 16px;
}
.money_add {
    font-size: 14px;
    padding-top: 16px;
}
.money_flx {
    margin-bottom: 30px;
}
.money_dtl {
    width: 440px;
    margin: 0 auto;
    margin-bottom: 30px;
}
.money_dtl dl {
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, .1) 0 0 10px;
}
.money_dtl dl dt {
    color: #fff;
    background: #004ea2;
    border-radius: 15px 15px 0 0;
    line-height: 1.33;
    padding: 15px 0;
    font-size: 30px;
    text-align: center;
}
.money_dtl dl dd {
    border-radius: 0 0 15px 15px;
    background: #fff;
    padding: 55px 0 50px;
    font-size: 36px;
    font-weight: bold;
    box-sizing: border-box;
}
.money_dtl dl dd span {
    font-size: 20px;
    font-weight: normal;
}
.money_btn {
    width: 300px;
    height: 50px;
    margin: 0 auto;
    border-radius: 25px;
    background: #ffdf00;
    box-shadow: #c1aa07 0 4px 0;
}
.money_btn a {
    display: flex;
    width: 100%;
    height: 100%;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    color: #000;
    border-radius: 25px;
    font-size: 18px;
}
.money_btn:hover {
    box-shadow: none;
    transform: translate(0,4px);
}
/***************************
bnr
***************************/
.mate_wrap.summer_bnr {
    padding: 65px 0 64px;
}
.mate_wrap.summer_bnr a {
    display: inline-block;
}
.infoano-txt {
    margin: 35px 0;
    font-size: 18px;
    text-align: center;
}