@charset "utf-8";


#page_wrap {
    max-width: 1200px;
    margin: 0 auto;
}
#page_wrap .main_img {
    flex-basis: 60%;
}

#page_wrap section.module-header {
    background: #000000;
    margin-bottom: 60px;
	position: relative;
}



#page_wrap section.module-header div.main {
    flex-basis: 48%;
    min-width: 0;
	position: relative;
}
section.module-header .section-padding {
    padding-top: 0;
    padding-right: 10px;
    padding-bottom: 40px;
    margin-bottom: 20px;
    justify-content: space-between;
}
#page_wrap.evo h1 {
    font-size: 48px;
    line-height: 1.3;
    font-weight: bold;
    margin-top: 40px;
    margin-right: 10px;
    letter-spacing: -0.05em;
    text-align: left;
}
.header-text {
    max-width: 100%;
    margin-left: 0;
    font-size: 0.7em;
    margin-bottom: 3em;
    width: 100%;
    line-height: 1.7;
}
section.module-header h1+p {
    margin-bottom: 1rem;
}
.add_text1>div {
    position: relative;
    right: 0;
    bottom: 0;
    display: flex;
}
.add_text1>div p {
    font-size: 0.85em;
    font-weight: bold;
    width: 100%;
    line-height: 1.8;
    margin-top: 30px;
}
.add_text1>div p a{
    color: #2CBDFE;
    text-decoration: none;
}
.add_text1>div p a:hover{
    opacity: 0.8;
}
img.badge {
    max-height: 100%;
    width: 240px;
    position: absolute;
    right: 0;
    height: auto;
    bottom: 3%;
    left: 0;
    margin: 0 auto;
    text-align: center;
}


#page_wrap h3{
    text-align: left;
}

#page_wrap.evo p{
    text-align: left;
    letter-spacing: -0.05em;
}

.center{
    text-align: center!important;
}

#page_wrap ul.ul01 li{
text-align: left;
}

.add_text1>div::after{
    display: none;
}

section.module-header nav.tabs > div a.nav-link{
    font-weight:] bold;
}

#page_wrap.evo h1 > span{
    display: block;
    font-size: 32px;
    margin-bottom: 11px;    
	  color: #A0FC70;
  background: -webkit-linear-gradient(0deg, #A0FC70, #14FEEA);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
	
}
#page_wrap.evo h1 > span > sup {
    font-size: 70%;
    vertical-align: top;
    z-index: 10;
    margin-top: -10px;
    position: inherit;
    top: auto;
    line-height: inherit;
    text-align: center;
}
@media screen and (max-width: 768px){
    #page_wrap.evo h1 span{
        font-size: 0.7em;
    }
}


    #page_wrap.evo .bottom_txt {
    position: absolute;
    bottom: 15px;
    left: 20px;
    font-weight: bold!important;
    font-size: 20px;
    color:#fff
}

.section-gutter {
    padding-left: 0;
    padding-right: 0;
}
.section-padding {
    padding-top: 40px;
    padding-bottom: 0;
}
#page_wrap.evo h2 {
    font-size: 26px	;
    background:#1e57bd;
    text-align: center;
    font-weight: bold;
    padding: 20px;
    line-height: 1.3;
    margin-bottom: 40px;
    font-weight: bold;
}

.flex {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
	padding: 0;
}

.flex .img{
	flex-basis: 40%;
}
.flex .txt{
	flex-basis: 50%;
}

.bold {
    font-weight: bold!important;
}


#anchor-nav {
    display: flex;
    flex-wrap: wrap;
	padding: 0 20px;
	box-sizing: border-box;
	
}
#anchor-nav > div{
	flex-basis: 32%;
	margin-bottom: 10px;
	margin-right: 2%;
}
#anchor-nav > div:nth-child(3n){
	margin-right: 0;
}
#anchor-nav > div a {
    background: #2dbdfe;
    padding: 15px 5px;
    box-sizing: border-box;
    color: #fff;
    font-size: 18px;
    margin-bottom: 5px;
    width: 100%;
    height: 100%;
    text-decoration: none;
    transition: background .15s linear, color .15s linear;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
}
#anchor-nav > div a:hover{
	background: #00285a;
}

	.w1000{
		max-width:1000px;
		margin: 0 auto 60px;
	}

 #page_wrap .border_box{
	border: 4px solid #003cb2;
	box-sizing: border-box;
	padding: 40px 100px;
	text-align: center!important;
}
ul.ul01{
	padding: 0;
}
ul.ul01 li {
    padding: 0 0 5px 30px;
    position: relative;
	font-size: 22px;
	box-sizing: border-box;
	font-weight: bold;
}
ul.ul01 li:before {
    position: absolute;
    content: "";
    width: 4px;
    height: 4px;
    box-sizing: border-box;
    background: #000;
    left: 5px;
    top: 12px;
    border-radius: 50%;
}
ul.ul01 li a{
	text-decoration: none;
	color: #000;
}
ul.ul01 li a:hover{
	opacity: 0.8;
}

.center{
	text-align: center;
}

.wrapper ul li{
	list-style: none;
    text-align: left;
}
ul.column3 li{
	flex-basis: 32%;
}


#page_wrap h2 + p {
    font-size: 22px;
    line-height: 1.5;
    max-width: 1000px;
    margin: 0 auto 50px;
}
#sec2 .flex:first-of-type{
	max-width: 1000px;
	margin: 0 auto 40px;
}
.flex.img_r{
	flex-direction: row-reverse;
}

#sec2 .flex,#sec3 .flex{
	max-width: 900px;
	margin: 0 auto 60px;
}
#sec2 .flex h3,#sec3 .flex h3{
	font-size: 16px;
}
#sec2 .flex p,#sec3 .flex p{
	font-size: 16px;
}




#sec3 .bg_box{
	background: #d1efff;
	padding: 40px 70px 20px;
	margin-bottom: 40px;
}

#sec3 .bg_box .small{
	font-size: 16px;
}

#page_wrap.evo #sec3 h2{
	margin-bottom: 0;
}
#sec3 p.p1,#sec4 p.p1{
	margin-bottom: 40px;
}
#sec3 .img_box{
	position: relative;
	margin-top: 20px;
	text-align: center;
	margin-bottom: 40px;
}
#sec3 .img_box .img1{
	padding-top: 200px;
    padding-left: 250px;
}
#sec3 h4.bg {
    max-width: 340px;
    color: #fff!important;
    background: #00a9ea;
    padding: 10px;
    position: absolute;
    top: 0;
    right: 150px;
    text-align: center!important;
    line-height: 1.4;
}
#sec3 h4.bg span{
	font-size: 15px;
}
#sec3 .ttl_box{
	display: flex;
}
#sec3 .ttl_box.ttl1{
	position: absolute;
	top: 0;
	left: 0;
}
#sec3 .ttl_box.ttl2 {
    position: absolute;
    top: 140px;
    right: 30px;
}
#sec3 .ttl_box .border_box {
    border: 4px solid #004d9f;
    box-sizing: border-box;
    padding: 20px;
    background: #fff;
    max-width: 320px;
    margin-right: 15px;
    margin-top: 20px;
    text-align: left;
    position: relative;
}
#sec3 .ttl_box.ttl1 .border_box:before {
    position: absolute;
    content: "";
    background: url(../images/03hukidashi_left.png);
    width: 37px;
    height: 28px;
    bottom: -28px;
    right: 15px;
}
#sec3 .ttl_box .border_box h4{
	color: #003cb2;
	font-size: 30px;
	font-weight: bold;
}

#sec3 .ttl_box.ttl2 .border_box{
	margin-top: 50px;
	margin-left: 60px;
}
#sec3 .ttl_box.ttl2 .border_box:before {
    position: absolute;
    content: "";
    background: url(../images/03hukidashi_right.png);
    width: 37px;
    height: 28px;
    bottom: -28px;
    left: 15px;
}



#sec3 .ttl_box.ttl2 .icon_list{
	display: flex;
	position: absolute;
}
#sec3 .ttl_box.ttl2 .icon_list p{
	margin-right: 5px;
}

#sec3 .bg_box_bottom .border_box {
    background: #ffffff;
    padding: 20px 30px;
    box-sizing: border-box;
}
#sec3 .bg_box_bottom .border_box p {
    font-size: 22px;
    line-height: 1.3;
}
#page_wrap.evo #sec3 h4{
	text-align: left;
	color: #003cb2;
	font-weight: bold;
}
#page_wrap.evo #sec3 h4.bottom + p{
	font-size: 16px;
	margin-bottom: 40px;
}


.color1{
	color: #1e57bd;
}
.big{
	font-size: 40px;
	font-weight: bold;
}


#sec4  .center{
	max-width: 960px;
	margin: 0 auto;
}

#sec4 .img{
	margin: 0 auto 30px;
}
#sec4 .img + p {
    font-size: 16px;
    text-align: center;
    line-height: 2;
}
#sec4 .img + p > span{
	font-size: 20px;
}
#sec4 .img + p > span .num{
	font-size: 40px;
	font-weight: bold;
	padding: 0 5px;
}
#sec4 .img + p > span .percent{
	font-size: 30px;
	font-weight: bold;
}
#sec5 .info{
	margin-bottom:30px;
    margin-top: 15px;
}
#sec5 h3.center{
	margin: 0 auto 50px;
}
#sec5 .flex{
	max-width: 1080px;
	margin: 0 auto 80px;
}
#sec5 .flex .img{
	position: relative;
	padding-top: 20px;
	flex-basis: 30%;
}
#sec5 .flex .img .core {
    position: absolute;
    top: 0;
    left: -30px;
    max-width: 80px;
}
#sec5 .flex .txt{
	flex-basis: 65%;
}
#sec5 .flex .txt p{
	font-size: 16px;
}
#sec5 .flex .txt .info{
	display: flex;
	justify-content: space-between;
	font-size: 16px;
}
#sec5 .flex .txt .info ul:first-child{
		width: 38%;
		padding: 0;
}
#sec5 .flex .txt .info ul:last-child{
		width: 60%;
		padding: 0;
}
#sec5 .btn_flex{
	display: flex;
	max-width: 600px;
	justify-content: space-between;
}
#sec5 .link_btn{
	flex-basis: 49%;
}
#sec5 .link_btn a{
   text-align: center;
	background: #1e57bd;
	width: 100%;
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 8px;
	box-sizing: border-box;
	border-radius: 8px;
	position: relative;
}
#sec5 .link_btn a:before {
    position: absolute;
    top: 20px;
    right: 14px;
    width: 0.5em;
    height: 0.5em;
    transform: translateY(-50%) rotate(45deg);
    border-right: 1px solid #fff;
    border-top: 1px solid #fff;
    content: "";
    transition: 0.5s;
}
#sec5 .link_btn:last-child a {
    background: #fff;
    color: #73b670;
    border: 1px solid #73b670;
}
#sec5 .link_btn:last-child a span {
    background: url(../images/zaico_icon.png ) no-repeat left top;
    padding-left: 30px;
}
#sec5 .link_btn:last-child a:before {
    border-right: 1px solid #73b670;
    border-top: 1px solid #73b670;
}

#sec5 .link_btn a:hover{
	opacity: 0.8;
}
section.module-header h3 {
    padding-top: 0.5em;
    font-size: 1.6em;
}

.mb0{
	margin-bottom: 0!important;
}


a.back-to-top {
    right:1.5em;
    text-decoration: none;
    position:absolute;
    bottom:1.5em;
    font-size:15px !important;
    z-index:10;
    cursor:pointer;
    color:#00aeef;
}
a.back-to-top:hover{
    text-decoration: underline;
}
br.sp{
	display: none;
}

#legal-module .section-gutter {
    padding-left: 85px;
    padding-right: 85px;
}

#legal-module .section-padding {
    padding-top: 40px;
    padding-bottom: 40px;
}

#legal-module .module-content p{
margin-bottom: 0.75em;
line-height: 1.5em;
font-size: 1.15em;
text-align: left;
}

#page_wrap.evo section.module.legal p a{
    color: #000;
    margin-bottom:0.75em ;
    line-height: 1.5;
    font-size:0.77em
}

section.module.legal {
    padding-bottom: 1em;
}

section.module.legal{
    background-color:#d7d7d7;
}

.icon1 img{
    position: absolute;
    top:152px;
    left:100px ;
}

.icon_list{
    position: absolute;
    top:-10px;
    left:80px ;

}


.click_btn{
    display: none;
}
@media screen and (max-width: 1200px) {
#page_wrap.evo h1 {
    font-size: 30px;
    margin-top: 30px;
    text-align: left;
}
div.module-content {
    width: 98%;
}
#page_wrap.evo h2 {
    margin: 0 calc(50% - 50vw) 35px;
    /* padding: 20px calc(50vw - 50% + 8px); */
    width: 100vw;
	font-size: 26px;
}
#page_wrap.evo .bg_box {
    margin: 0 calc(50% - 50vw) 35px;
    /* padding: 20px calc(50vw - 50% + 8px); */
    width: 100vw;
    box-sizing: border-box;
}
	#sec5 .flex .img .core {
    max-width: 80px;
		left: 0;
}
#sec5 .flex .img {
    padding-top: 60px;
}
#page_wrap.evo .bottom_txt {
    bottom: 10px;
    font-size: 16px;
}
#index img, #topicsmain_detail img{
    max-width:60%;
}
.img1 img{
    left:0;
}

}

@media screen and (max-width: 900px) {

#page_wrap.evo h1 {
    font-size: 28px;
    margin-top: 30px;
}
#sec3 h4.bg {
    right: 50px;
}
#sec3 .ttl_box .border_box h4 {
    font-size: 22px;
}
#sec3 .ttl_box .border_box p {
    font-size: 16px;
}

.img1 img{
    position: relative;
    left:-150px ;
    width: 150%;
}
.icon1 img{
    top:144px;
}

#index img, #topicsmain_detail img{
    max-width:250%;
}

#index img, #topicsmain_detail img{
    zoom:0.9;
}

.icon_list{
    position: absolute;
    top:-4px;
    left:80px ;
    width: 100%;
}
.icon1 img{
    position: absolute;
    top:65px;
    left: 80px;
    top:158px;
}
#sec3 .ttl_box.ttl2 {
top:120px;
left: 150px;
}


#sec3 .ttl_box.ttl2 .icon_list {
    position:absolute;
    left:50px;
}

}

@media screen and (max-width: 767px) {
#page_wrap.evo .bg_box {
    padding: 20px calc(50vw - 50% + 8px);
    }
    

    div.module-content{
    margin-bottom:0.75em;
    line-height:1.5em;
    font-size:1.8em;
 }

#page_wrap .border_box{
    padding: 20px;
}

#page_wrap.evo h3{
    font-size:1.4em;
    color:#000;
}

#page_wrap.evo h4{
    font-size:1.5em;
    line-height:1.3;
}
#sec3 p.p1, #sec4 p.p1{
    width:340px;
    display:block;
    font-size:  13px !important;;
}

#page_wrap .header_bg {
    background: none;
    line-height:1.5;
}

br.sp{
	display: block;
}
br.pc{
	display: none;
}

.header-text{
    display: none;
}
	#page_wrap .main_img {
    flex-basis: 40%;
    padding-top: 0px;
}
section.module-header div.module-content {
    position: relative;
    display: block;
    padding-bottom: 0px;
}

#page_wrap.evo h1 {
    padding-bottom: 11em;
    font-size: 2.5em;
    text-align: center;
    margin-top: 0;
}

img.badge {
    width: 240px;
    bottom: 100px;
    right: 0;
    left: 0;
    text-align: center;
    margin: 0 auto;
}


.flex {
    display: block;
}
#page_wrap.evo p {
    font-size: 100%;
}
	

	#page_wrap h2 + p {
    font-size: 18px;
    margin: 0 auto 20px;
}
	
.flex .img {
    margin: 0 auto 30px;
    text-align: center;
    width: 100%;
}
.border_box {
    border: 4px solid #003cb2;
    box-sizing: border-box;
    padding: 20px;
}
#sec3 .bg_box_bottom .border_box {
    padding: 15px 15px;
    width: 96%;
    margin: 0 auto;
    max-width: 420px;
}
#sec3 .ttl_box .border_box h4 {
    font-size: 25px;
}
#sec3 .ttl_box .border_box p {
    font-size: 16px;
}
#sec4 .column3.flex li .img {
    margin: 0 auto 20px;
}
#sec4 .img + p {
    line-height: 1.4;
}
#sec4 .flex p {
    margin: 0 auto 30px;
}
#sec4 .column3.flex li .img p {
    margin: 0 auto 20px;
}
#sec4 .flex li p {
    margin: 0 auto 20px;
}
#sec5 .flex .img .core {
    position: absolute;
    top: 0;
    left: 0;
    max-width: 80px;
}
#sec5 .flex .img {
    position: relative;
    padding-top: 20px;
    max-width: 400px;
}
#sec5 .btn_flex {
    display: block;
    max-width: 320px;
    justify-content: space-between;
    margin: 0 auto;
}
	#sec5 .btn_flex .link_btn:first-child{
		margin: 0 auto 20px;
	}
}

	@media screen and (max-width: 600px) {

    section.module-header .section-padding {
        padding-right: 20px;
        padding-left: 20px;
        padding-top: 20px;
    }
    .section-padding {
        padding-top: 20px;
    }
    #page_wrap.evo h1 {
        padding-bottom: 15em;
        font-size: 1.5em;
        text-align: center;
        word-break: keep-all;
    }
    section#sec_top{
        margin-top: 60vw;
    }
    #page_wrap.evo #sec3 h2 {
        width: 375px;
    }
        img.badge {
        width: 220px;
        bottom: 75px;
    }
    .bottom_txt {
        bottom: 15px;
        left: 0;
        padding-left: 10px;
        padding-right: 10px;
        box-sizing: border-box;
    }
    section.module-header div.evo-graphic{
        top: 315px;
        left:0;
    }

    #page_wrap.evo h2 {
        font-size: 1.2em;
    }

    #page_wrap.evo p {
        font-size: 1em;
    }
    #page_wrap.evo .bottom_txt {
        font-size: 12px;
        bottom: 15px;
    }
    div.module-content {
        width: 92%;
    }
    ul.ul01 li {
        padding: 0 0 5px 20px;
        font-size: 18px;
    }
    .w1000 {
        margin: 0 0 40px 0;
        max-width:375px;
        margin-top:170px;
    }
    .sp_mt{
    margin-top:170px ;
    }
    .sp_mt2{
        margin-top:-60px ;
        }

    #sec3 h4.bg {
        right: auto;
        position: relative;
    }
    #sec3 .ttl_box .border_box {
        padding: 10px;
        max-width: 150px;
        margin-top: 5px;
    }
    #sec3 .ttl_box .border_box h4 {
        font-size: 20px;
    }	
    #sec3 .ttl_box .border_box p {
        font-size: 15px;
        margin-bottom: 0;
    }
    #sec3 .ttl_box.ttl1 {
        top: 110px;
        left: 0;
    }
    #sec3 .ttl_box.ttl2 {
        top: 150px;
        right: 0;
    }
        #sec3 .ttl_box.ttl2 .border_box{
            margin-right: 0;
        }
    #sec3 .ttl_box.ttl1 .border_box:before {
        right: 80px;
    }
    #sec3 .ttl_box.ttl2 .border_box:before {
        left: 70px;
    }
    #sec3 .bg_box_bottom .border_box p {
        font-size: 17px;
    }
    #sec2 .flex, #sec3 .flex {
        margin: 0 auto 40px;
    }
        .big {
        font-size: 26px;
    }
    #sec4 .flex li p {
        font-size: 0.8em;
    }
    #sec4 h3, #sec5 h3 {
        font-size: 18px;
    }
    #sec5 .column3 p {
        font-size: 14px;
    }
    #sec5 .flex .txt .info{
        display: block;
    }
    #sec5 .flex .txt .info ul:first-child{
        width: 100%;
        margin-bottom: 0;
    }
    #sec5 .flex .txt .info ul:last-child{
            width: 100%;
        padding: 0;
        margin-top:0;
        }
    #legal-module .section-gutter {
        padding-left: 20px;
        padding-right: 20px;
    }

    #page_wrap.evo h2 {
        width:100%;
    }

    #page_wrap.evo h1{
        padding-bottom:8em;
    }
}
@media screen and (max-width: 400px) {
#sec3 .ttl_box.ttl1 {
    top: 200px;
    left: 0;
}
#sec3 .ttl_box.ttl2 {
    top: 200px;
    right: 0;
}
}