﻿

/* clearfix */

.clear {
    clear:both; height:0; line-height:0;}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
} 
.clearfix:before {
  content: "";
  display: block;
  clear: both;
} 
.clearfix {
  display: block;
}
/* Hides from IE-mac \*/  
* html .clearfix { height: 1%; }  
.clearfix { display: block; }  
/* End hide from IE-mac */ 
.m_over:hover{opacity:0.75;}


/*--margin--*/
@media print {
	body{font-size:80%;}
}

/*---------------------ベース--------------------------------------*/

.disp_pc{display:block !important;}
.disp_sp{display:none !important;}
.disp_in_pc{display:inline-block;}
.disp_in_sp{display:none;}
.ta-center { text-align: center; }
.ta-left { text-align: left; }
img{ max-width:100%; vertical-align: bottom;}
html {font-size: 62.5%;}
body { font-size: 1.6em; font-weight: 600; width: 100%; overflow-x: hidden;}
.none{ display:none;}
.bold{ font-weight:bold;}
.center{text-align:center;}



/* -----------------------------------------------------
 * PCデザイン
 * -------------------------------------------------- */

/*header*/
header { width: 100%; height: 40px; background-color: #0d1d2b; }
header .to_HP { max-width: 1440px; margin: 0 auto; padding: 0 30px; }
header a { display:inline-block; padding-left: 25px; line-height:40px; background:url("../image/ico_arrow.png") no-repeat left center; background-size: 7px 6px; }

/*mv*/
.mv { width: 100%;  }
.mv .mv_inner { width: 100%; max-width: 1440px; height:72.22vw; max-height:1040px; margin: 0 auto; padding: 0 0 0 4.16%; background:url("../image/bg_mv_pc1.png") no-repeat right top; background-size: auto 100%;  }
.mv .mv_inner .link_btn { display:flex; justify-content:flex-end; align-items:stretch; }
.mv .mv_inner .link_btn a { display: block; padding: 11px 0; width:20.14%; max-width:290px; text-align:center; }
.mv .mv_inner .link_btn a.faq { background-color:rgba(19, 39, 57, 0.7); }
.mv .mv_inner .link_btn a.login { background-color:rgba(108, 111, 113, 0.7);  }
.mv .mv_inner .link_btn a span { display:inline-block; padding-left: 23px; font-weight:bold; text-align:center;  }
.mv .mv_inner .faq span { position: relative; font-size:0.972vw; background:url("../image/ico012.png") no-repeat left center; background-size:13px 12px; top:17%; }
.mv .mv_inner .login span { font-size:1.11vw; line-height: 1.44; background:url("../image/ico022.png") no-repeat left center; background-size:12px 14px; }
.mv .mv_inner h1 { margin-top:10.4vw; }
.mv .mv_inner h1 img { width:36.4%; max-width: 524px; }
.mv .mv_inner h1 dfn { display: inline-block; margin-top: 1.875vw; font-size:1.32vw; font-weight:bold; font-style:normal; }
.mv .mv_inner p { margin-top: 2.5vw; font-size:2.22vw; font-weight:bold; line-height:1.75; font-family:"Noto Sans JP", "Meiryo", sans-serif; }
.mv .btn_area .trial { margin-top: 51px; }
.mv .btn_area .download { margin-top: 20px; }

@media screen and (min-width: 1440px) {
    .mv .mv_inner .faq span { font-size:1.4rem; }
    .mv .mv_inner .login span { font-size:1.6rem; }
    .mv .mv_inner h1 { margin-top:150px; }
    .mv .mv_inner h1 dfn { margin-top: 27px; font-size:1.9rem; }
    .mv .mv_inner p { margin-top: 36px; font-size:3.2rem; }
}

/*btn_area*/
.btn_area a { position: relative; display:block; width:400px; line-height:80px; font-size: 2.4rem; font-weight: bold; text-align: center; border-radius:40px; box-shadow:0 -5px 1px rgba(0, 0, 0, 0.3) inset; }
.btn_area a:after { position:absolute; content:""; display:inline-block; width:0; height:0; border-style:solid; border-width:8px 0 8px 12px; border-color: transparent transparent transparent #fff; right:20px; top:32px; }
.btn_area a:hover { text-decoration:none; }
.btn_area .trial { background: linear-gradient( 90deg, #ef0a6a, #7f17ff); }
.btn_area .trial:hover { background: linear-gradient( 90deg, #7f17ff, #ef0a6a); }
.btn_area .download { background: linear-gradient( 90deg, #22dcfd, #0621cf); }
.btn_area .download:hover { background: linear-gradient( 90deg, #0621cf, #22dcfd); }

/*cont01*/
.cont01{ width: 100%; padding-bottom:119px; background:url("../image/bg_section_top.png") repeat-x left bottom; }
.cont01 .co_inner { max-width: 1440px; margin: 0 auto; padding: 79px 0 85px; }
.cont01 h2 { position: relative; font-size:5rem; color:#fff; line-height:1.5; padding-left:9.72% }
.cont01 h2:before { position:absolute; content:""; display:inline-block; width:8.33%; height:1px; background-color:#fff; left:0; top:34px; }
.cont01 ul { position: relative; display:flex; justify-content:center; align-items:center; width:91.65%; margin: 87px auto 0; }
.cont01 ul:after { position:absolute; content:""; display:inline-block; width:58px; height:58px; border-bottom:solid 2px #192d3e; border-right:solid 2px #192d3e; position: absolute; left: 50%; bottom: -100px; transform: rotate(45deg) translateX(-50%); }
.cont01 li { display: flex; flex-direction: column; justify-content: center; width:33.26%; height: 110px; font-size: 2.4rem; font-weight: bold; line-height: 1.75; color: #fff; text-align: center; border-right:solid 1px #6c6f71; background:url("../image/bg_txt01.png") no-repeat center center; background-size: 43% auto; }
.cont01 li:last-child { border-right:none; }
.cont01 .flexBox { width: 90.27%; margin: 140px 0 0 9.73%; display:flex; justify-content: flex-end; align-items:center; }
.cont01 .flexBox h3 { width: 47.7%; padding:10px 0 0 40px; font-size:6rem; color:#fff; line-height:1.5; background:url("../image/bg_diagonal-line_01.png") no-repeat left top; }
.cont01 .flexBox figure { width: 52.3%; }
.cont01 .smart_biz { margin-top:165px; }
.cont01 .smart_biz h3 { font-size: 6rem; color:#fff; line-height: 1.33; text-align: center; padding: 75px 0; background:url("../image/bg_s.png") no-repeat center center;}
.cont01 .smart_biz p { margin-top: 50px; font-size: 2.4rem; font-weight:500; color:#fff; line-height:1.83; text-align:center; }
.cont01 .btn_area { margin: 69px auto 0; width:58.33%; display:flex; justify-content:space-between; }
.cont01 .btn_area a { width:47.62% }

/*cont02*/
.cont02{ width: 100%; padding:0 10px 119px; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom; }
.cont02 .co_inner { max-width: 1440px; margin: 0 auto; padding: 78px 0 100px;}
.cont02 h2 { font-size:6rem; color:#132739; text-align:center; }
.cont02 h2 em { margin-left: 0.2em; display: inline-block; font-style:normal; line-height:1; color: #3a7fde; background: -webkit-linear-gradient(90deg, #89fcfd, #3a7fde); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.cont02 .function { width: 80.83%; margin: 96px auto 0; display:flex; justify-content:space-between; align-items: center; }
.cont02 .function li { display:flex; flex-direction: column; justify-content: center; width: 28.35%; height: 196px; font-size:5rem; color:#132739; text-align:center; }
.cont02 .function li:first-child { background:url("../image/ico032.png") no-repeat center center; background-size:contain; }
.cont02 .function li:nth-child(2) { background:url("../image/ico041.png") no-repeat center center; background-size:contain; }
.cont02 .function li:last-child { background:url("../image/ico051.png") no-repeat center center; background-size:contain; }

/*cont03*/
.cont03 { width: 100%; padding:0 10px 119px; background: url("../image/bg_section_top.png") repeat-x left bottom; }
.cont03 .co_inner { max-width: 1160px; margin: 0 auto; padding: 83px 0 80px;}
.cont03 h2 { font-size:6rem; text-align:center; }
.cont03 .flexBox { margin-top: 115px; display:flex; justify-content:space-between; align-items: flex-start; }
.cont03 .flexBox:nth-of-type(1) { margin-top:97px; }
.cont03 .flexBox:nth-of-type(2) { flex-direction:row-reverse; }
.cont03 .flexBox figure { width:44.8%; margin-top:20px; }
.cont03 .flexBox figcaption { margin-top: 6px; font-size:1.5rem; font-weight:400; }
.cont03 .flexBox dl { width:50%; }
.cont03 .flexBox dt { padding-left:120px; font-size: 5rem; font-weight:bold; line-height:1.4; }
.cont03 .flexBox:nth-of-type(1) dt { background:url("../image/num01.png") no-repeat left center; background-size: 85px 70px; }
.cont03 .flexBox:nth-of-type(2) dt { background:url("../image/num02.png") no-repeat left center; background-size: 85px 70px; }
.cont03 .flexBox:nth-of-type(3) dt { background:url("../image/num03.png") no-repeat left center; background-size: 85px 70px; }
.cont03 .flexBox dd { padding-left:120px; }
.cont03 .flexBox .simple-txt { margin-top: 33px; font-size: 2.8rem; font-weight:600; }
.cont03 .flexBox .details { margin-top: 15px; font-size: 2.2rem; font-weight:500; line-height: 1.7; }
.cont03 .catch { margin-top: 57px; font-size:4rem; font-weight:bold; line-height:1.25; text-align:center; }
.cont03 .catch span { position: relative; margin-top: 20px; display:inline-block; background: linear-gradient( 90deg, #22dcfd, #0621cf); }
.cont03 .catch span:before { position: absolute; content:""; display:inline-block; width:0; height:0; border-style:solid; border-width: 50px 50px 0 0; border-color: transparent #22dcfd transparent transparent; top:0; left:-50px; }
.cont03 .catch span:after { position: absolute; content:""; display:inline-block; width:0; height:0; border-style:solid; border-width: 0 0 50px 50px; border-color: transparent transparent transparent #0621cf; bottom:0; right:-50px; }

/*cont04*/
.cont04 { width: 100%; padding:0 10px 119px; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom;  }
.cont04 .co_inner { max-width: 1160px; margin: 0 auto; padding: 83px 0 100px;}
.cont04 h2 { font-size:6rem; color:#132739; text-align:center; }
.cont04 .flexBox { width:100%; display:flex; justify-content:space-between; align-items: stretch; }
.cont04 .flexBox dl { margin-top: 97px; position: relative; width:27.5862%; padding-bottom:19.2%; }
.cont04 .flexBox dl:nth-of-type(1) { background:url("../image/bg_cont04_01.png") no-repeat 14% bottom; background-size:59.375% auto; }
.cont04 .flexBox dl:nth-of-type(2) { background:url("../image/bg_cont04_02.png") no-repeat 14% bottom; background-size:59.375% auto; }
.cont04 .flexBox dl:nth-of-type(3) { background:url("../image/bg_cont04_03.png") no-repeat 14% bottom; background-size:59.375% auto; }
.cont04 .flexBox dt { position:absolute; width: 183px; font-size:2rem; font-weight:bold; line-height:40px; text-align: center; background-color:#4896d5; border-radius:20px; top:0; left: 50%; transform:translateX(-50%); z-index:999; }
.cont04 .flexBox dd { position: relative; margin-top:20px; padding: 30px 25px; font-size:1.8rem; font-weight:400; line-height: 2.1; color:#132739; background-color:#e5e8ec; border-radius:18px; }
.cont04 .flexBox dd:after { position: absolute; content:""; display:inline-block; width:0; height:0; border-style:solid; border-width: 0 0 17px 23px; border-color: transparent transparent transparent #e5e8ec; top:100%; left:62.5%; }
@media screen and (max-width: 1439px) {
  .cont04 .flexBox dd { font-size: 1.25vw; }
}


/*cont05*/
.cont05 { width: 100%; padding:0 10px 119px; background: url("../image/bg_section_top.png") repeat-x left bottom;}
.cont05 .co_inner { max-width: 1320px; margin: 0 auto; padding: 82px 0 80px;}
.cont05 h2 { font-size:6rem; text-align:center; }
.cont05 .flexBox { width:100%; display:flex; justify-content:space-between; align-items: stretch; }
.cont05 .flexBox dl { margin-top: 98px; width:31.8%; padding: 40px 3.03%; box-shadow: 0 30px 30px rgba(13, 29, 43 , 0.5), 0 -18px 30px rgba(13, 29, 43, 0.5) }
.cont05 .flexBox dt { position: relative; font-size:2.4rem; font-weight:600; line-height:2.7; }
.cont05 .flexBox dt:after { position:absolute; content:""; display:inline-block; width:40px; height:3px; background:linear-gradient( 90deg, #3a7fde, #89fcfd); left:0; bottom:0; }
.cont05 .flexBox dd { margin-top: 21px; font-size:1.8rem; font-weight:500; line-height:2.1; letter-spacing:-0.01em; }
.cont05 .flexBox dd span { display: inline-block; font-size:1.5rem; font-weight:500; line-height: 1.67; text-indent:-1em; margin: 6px 0 0 1em; }
.cont05 .flexBox dd a { display:block; margin-top: 37px; padding: 12px 0; font-size: 1.8rem; font-weight: bold; line-height: 1.44; text-align: center; border:solid 2px #fff; border-radius:999999px; }
.cont05 .flexBox dd a:hover { color:#102537; text-decoration: none; background-color:#fff; }

/*cont06*/
.cont06 { width: 100%; padding:0 10px 119px; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom;  }
.cont06 .co_inner { max-width: 1160px; margin: 0 auto; padding: 82px 0 100px;}
.cont06 h2 { margin-bottom: 97px; font-size: 6rem; color:#132739; text-align:center; }
.cont06 .full { width:100%; font-size: 2.2rem; font-weight: bold; color:#102537; }
.cont06 .full.center { padding:23px 20px 22px; }
.cont06 .bg-gray { background-color:#e5e8ec; }
.cont06 .flexBox { display:flex; justify-content:space-between; align-items: flex-start; }
.cont06 .flexBox li { width:46.55%; }
.cont06 .flexBox li span { position: relative; display:block; padding-left: 23.7%; line-height:101px; font-size:2.2rem; font-weight:400; color:#132739; }
.cont06 .flexBox li span:after { position:absolute; content:""; display:inline-block; width:58px; height:58px; border-bottom:solid 2px #192d3e; border-right:solid 2px #192d3e; position: absolute; left: 50%; bottom: 20px; transform: rotate(45deg) translateX(-50%); }
.cont06 .flexBox li div.bg-gray { padding:40px 40px 60px; }
.cont06 .flexBox li div.bg-gray p { font-size:2.2rem; font-weight:600; color:#132739; line-height:1.7; }
.cont06 .flexBox li div.bg-gray em { display: inline-block; padding: 0 10px; font-style:normal; color:#fff; background-color:#d62859;  }
.cont06 .flexBox li div.bg-gray small { display: inline-block; margin-top: 11px; font-size:1.5rem; font-weight:600; color:#132739; line-height:1.67; }
.cont06 .flexBox li div.bg-gray figure { width:57.6%; margin:34px auto 0; }
.cont06 .flexBox li div.bg-gray a { display:block; width: 74%; margin: 60px auto 0; padding: 22px 20px 21px; font-size:2.2rem; font-weight:bold; color:#102537; line-height: 1.18; text-align: center; border:solid 1px #102537; border-radius:999999px; }
.cont06 .flexBox li div.bg-gray a:hover { color:#fff; text-decoration: none; background-color: #102537; }

/*cont07*/
.cont07 { width: 100%; padding:0 10px; }
.cont07 .co_inner { max-width: 1160px; margin: 0 auto; padding: 100px 0 100px;} 
.cont07 ul { display:flex; justify-content:space-between; align-items:center; }
.cont07 li { width:31%;  }
.cont07 li a { display:block; font-size:1.8rem; font-weight:bold; text-align:center; line-height:70px; border:solid 1px #fff; border-radius:999999px; }
.cont07 li a:hover { color: #102537; text-decoration: none; background-color:#fff; }

/*footer*/
footer { width: 100%; }
footer p { font-size: 1.6rem; font-weight: 400; text-align: center; line-height: 78px; background-color:#102537; }
footer .pagetop { position:fixed; display: block; width:100px; height:100px; bottom:0; right:0; z-index:999; }




/* -----------------------------------------------------
 * SPデザイン
 * -------------------------------------------------- */

@media screen and (max-width: 767px) {
.disp_pc{display:none !important;}
.disp_sp{display:block !important;}
.disp_in_pc{display:none !important;}
.disp_in_sp{display:inline-block !important;}
.br2{display:block; text-align:center;}
body{min-width: 100%}

/*header*/
header { width: 100%; height: 8vw; }
header .to_HP { max-width: 100%; margin: 0 auto; padding: 0 4vw; }
header a { display:inline-block; padding-left: 3.33vw; line-height:8vw; background:url("../image/ico_arrow.png") no-repeat left center; background-size: auto 1.2vw; }

/*mv*/
.mv { width: 100%;  }
.mv .mv_inner { width: 100%; max-width: 100%; height: auto; max-height: none; margin: 0 auto; padding: 0; background:url("../image/bg_mv_sp1.png") no-repeat center top; background-size: contain;  }
.mv .mv_inner .link_btn { display:flex; justify-content:center; align-items:stretch; }
.mv .mv_inner .link_btn a { display: block; padding: 11px 0; width:50%; max-width:50%; }
.mv .mv_inner .link_btn a span { display:inline-block; padding-left: 4.4vw; font-weight:bold; }
.mv .mv_inner .faq span { position: relative; font-size:2.93vw; background:url("../image/ico012.png") no-repeat left center; background-size: auto 2.4vw; }
.mv .mv_inner .login span { font-size:2.8vw; line-height: 1.5; background:url("../image/ico022.png") no-repeat left center; background-size:2.4vw auto; }
.mv .mv_inner h1 { margin:33.6vw 0 0 4vw; }
.mv .mv_inner h1 img { width:77.06vw; max-width: 77.06vw; }
.mv .mv_inner h1 dfn { margin-top: 4.26vw; font-size:3.46vw; font-weight:bold;}
.mv .mv_inner p { margin: 8.4vw 0 0 4vw; font-size:5.33vw; font-weight:bold; } 
.mv .btn_area .trial { margin-top: 10vw;}

/*btn_area*/
.btn_area a { width:84vw; margin: 0 auto; line-height:16vw; font-size: 4.26vw; font-weight: bold; border-radius:8vw; box-shadow:0 -0.67vw 1px rgba(0, 0, 0, 0.3) inset; }
.btn_area a:after { border-width:1.6vw 0 1.6vw 2.4vw; right:4vw; top:6.4vw; }
.btn_area a:hover { text-decoration:none; }
.btn_area .download { margin-top: 4vw; }

/*cont01*/
.cont01{ width: 100%; padding-bottom:15.86vw; background:url("../image/bg_section_top.png") repeat-x left bottom; background-size: auto 15.86vw; }
.cont01 .co_inner { max-width: 100%; margin: 0 auto; padding: 24vw 0 16.66vw; }
.cont01 h2 { position: relative; font-size:6.66vw; color:#fff; line-height:1.6; padding-left:8vw; }
.cont01 h2:before { position:absolute; content:""; display:inline-block; width:5.33vw; height:1px; background-color:#fff; left:0; top:5.6vw; }
.cont01 ul { flex-wrap: wrap; width:100%; margin: 3.6vw 0 0; }
.cont01 ul:after { width:13.2vw; height:13.2vw; border-bottom:solid 0.4vw #192d3e; border-right:solid 0.4vw #192d3e; position: absolute; left: 50%; bottom: -20vw; transform: rotate(45deg) translateX(-50%); }
.cont01 li { margin-top: 8vw; width:50%; height: 16vw; font-size: 3.73vw; font-weight: bold; line-height: 1.71; color: #fff; text-align: center; border-right:solid 1px #6c6f71; background:url("../image/bg_txt01.png") no-repeat center center; background-size: auto 13.6vw; }
.cont01 li:nth-child(2),
.cont01 li:last-child { border-right:none; }
.cont01 .flexBox { width: 96vw; margin: 28vw 0 0 4vw; display:block; }
.cont01 .flexBox h3 { width: 100%; padding:2vw 0 0 5.6vw; font-size:8vw; background:url("../image/bg_diagonal-line_01.png") no-repeat left top; }
.cont01 .flexBox figure { width: 92vw; margin: 5.6vw 0 0 4vw; }
.cont01 .smart_biz { margin-top:27.33vw; }
.cont01 .smart_biz h3 { font-size: 8vw; padding: 10vw 0; background:url("../image/bg_s.png") no-repeat center center; background-size: contain;}
.cont01 .smart_biz p { margin-top: 6.8vw; font-size: 3.73vw; font-weight:500; line-height:1.71; }
.cont01 .btn_area { margin: 8.93vw auto 0; width:100%; display:block; }
.cont01 .btn_area a { width:84vw; }

/*cont02*/
.cont02{ width: 100%; padding:0 0 15.86vw; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom; background-size: auto 15.86vw; }
.cont02 .co_inner { max-width: 92%; margin: 0 auto; padding: 13.2vw 0 14.8vw;}
.cont02 h2 { font-size:8vw; }
.cont02 h2 em { margin-left: 0.2em; }
.cont02 .function { width: 100%; margin: 0 auto; display:flex; justify-content:center; align-items: center; flex-wrap:wrap; }
.cont02 .function li { display:flex; flex-direction: column; justify-content: center; width: 40vw; height: 26.13vw; margin: 10.8vw 2vw 0; font-size:6.6vw; }

/*cont03*/
.cont03 { width: 100%; padding:0 0 15.86vw; background: url("../image/bg_section_top.png") repeat-x left bottom; background-size: auto 15.86vw;}
.cont03 .co_inner { max-width: 92%; margin: 0 auto; padding: 14vw 0 16vw;}
.cont03 h2 { font-size:8vw; }
.cont03 .flexBox { margin-top: 16vw; display:block; }
.cont03 .flexBox:nth-of-type(1) { margin-top:10vw; }
.cont03 .flexBox figure { width:100%; margin-top:6vw; padding-left:16.4vw; }
.cont03 .flexBox figcaption { margin-top: 6px; font-size:2.93vw; font-weight:400; }
.cont03 .flexBox dl { width:100%; }
.cont03 .flexBox dt { padding-left:16.4vw; font-size: 8vw; font-weight:bold; line-height:1.4; }
.cont03 .flexBox:nth-of-type(1) dt { background:url("../image/num01.png") no-repeat left center; background-size: contain; }
.cont03 .flexBox:nth-of-type(2) dt { background:url("../image/num02.png") no-repeat left center; background-size: contain; }
.cont03 .flexBox:nth-of-type(3) dt { background:url("../image/num03.png") no-repeat left center; background-size: contain; }
.cont03 .flexBox dd { padding-left:16.4vw; }
.cont03 .flexBox .simple-txt { margin-top: 5.2vw; font-size: 4.53vw; font-weight:600; }
.cont03 .flexBox .details { margin-top: 2.8vw; font-size: 3.73vw; font-weight:500; line-height: 1.7; }
.cont03 .catch { margin-top: 13.3vw; font-size:8vw; font-weight:bold; line-height:1.167; text-align:center; }
.cont03 .catch span { position: relative; margin-top: 2.66vw; display:inline-block; background: linear-gradient( 90deg, #22dcfd, #0621cf); }
.cont03 .catch span:before { border-width: 9.4vw 9.4vw 0 0; left:-9.33vw; }
.cont03 .catch span:after { border-width: 0 0 9.4vw 9.4vw; right:-9.33vw; }

/*cont04*/
.cont04 { width: 100%; padding:0 0 15.86vw; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom; background-size: auto 15.86vw; }
.cont04 .co_inner { max-width: 92%; margin: 0 auto; padding: 13.6vw 0 16vw;}
.cont04 h2 { font-size:8vw; }
.cont04 .flexBox { width:100%; display:block; }
.cont04 .flexBox dl { margin-top: 8vw; width:100%; padding-top:3.06vw; padding-bottom:5.33vw; padding-right:32vw }
.cont04 .flexBox dl:nth-of-type(1) { background:url("../image/bg_cont04_01.png") no-repeat right bottom; background-size:25.33vw auto; }
.cont04 .flexBox dl:nth-of-type(2) { background:url("../image/bg_cont04_02.png") no-repeat left bottom; background-size:25.33vw auto; padding-right:0; padding-left:32vw }
.cont04 .flexBox dl:nth-of-type(3) { background:url("../image/bg_cont04_03.png") no-repeat right bottom; background-size:25.33vw auto; }
.cont04 .flexBox dt { position:absolute; width: 29.3vw; font-size:3.46vw; font-weight:bold; line-height:6.13vw; text-align: center; border-radius:999999px; left:15.3vw; transform:none; }
.cont04 .flexBox dl:nth-of-type(2) dt { left:auto; right: 15.3vw; }
.cont04 .flexBox dd { margin-top: 0; padding: 4vw; font-size:3.2vw; font-weight:400; line-height: 1.83; border-radius:2.4vw; }
.cont04 .flexBox dd:after { border-width: 4.4vw 0 0 3.2vw; top:50%; left:100%; transform:translateY(-50%); }
.cont04 .flexBox dl:nth-of-type(2) dd:after { border-width: 4.4vw 3.2vw 0 0; border-color: transparent #e5e8ec transparent transparent; left:-3.2vw; }

/*cont05*/
.cont05 { width: 100%; padding:0 0 15.86vw; background: url("../image/bg_section_top.png") repeat-x left bottom; background-size: auto 15.86vw;}
.cont05 .co_inner { max-width: 92%; margin: 0 auto; padding: 13.6vw 0 16vw;}
.cont05 h2 { font-size:8vw; }
.cont05 .flexBox { margin-top: 10.4vw; width:100%; display:block; }
.cont05 .flexBox dl { margin-top: 8vw; width:100%; padding: 10.6vw 8vw; box-shadow: 0 4vw 4vw rgba(13, 29, 43 , 0.5), 0 -2.4vw 4vw rgba(13, 29, 43, 0.5) }
.cont05 .flexBox dt { font-size:5.33vw; font-weight:600; line-height:2.85; }
.cont05 .flexBox dt:after { position:absolute; content:""; display:inline-block; width:8vw; height:0.67vw; }
.cont05 .flexBox dd { margin-top: 4.4vw; font-size:3.73vw; font-weight:500; line-height:1.7; letter-spacing:-0.01em; }
.cont05 .flexBox dd span { display: inline-block; font-size:2.93vw; font-weight:500; line-height: 1.45; margin: 1.2vw 0 0 1em; }
.cont05 .flexBox dd a { display:block; margin-top: 7.2vw; padding: 2.67vw 0; font-size: 3.73vw; font-weight: bold; line-height: 1.357;}
.cont05 .flexBox dd a:hover { color:#fff; text-decoration: none; background-color:transparent; }

/*cont06*/
.cont06 { width: 100%; padding:0 0 15.86vw; background: #fff url("../image/bg_section_bottom.png") repeat-x left bottom; background-size: auto 15.86vw; }
.cont06 .co_inner { max-width: 92%; margin: 0 auto; padding: 11.2vw 0 16vw;}
.cont06 h2 { margin-bottom: 10vw; font-size: 8vw; } 
.cont06 h2 + ul { display:flex; justify-content:flex-start; align-items:stretch; }
.cont06 .full { width:auto; font-size: 3.73vw; font-weight: bold; }
.cont06 .full.center { width: 10.67vw; line-height: 10.67vw; padding: 8vw 0; text-align: center; writing-mode:vertical-rl; }
.cont06 .flexBox { display:flex; justify-content:space-between; align-items: stretch; flex-direction:column; width: 81.33vw; }
.cont06 .flexBox li { display: flex; width:81.33vw; justify-content:flex-start; align-items:stretch; }
.cont06 .flexBox li.yes { margin-bottom:4vw; }
.cont06 .flexBox li.no { margin-top:4vw; }
.cont06 .flexBox li span { position: relative; display:block; width: 12vw; padding-left: 0; line-height:1; font-size:2.93vw; font-weight:400; text-align:center; }
.cont06 .flexBox li.yes span { padding-top: 70%; }
.cont06 .flexBox li.no span { padding-top: 50%; }
.cont06 .flexBox li span:after { width:7.73vw; height:7.73vw; left: 50%; bottom: 50%; transform: rotate(-45deg) translate(-50%, -50%); }
.cont06 .flexBox li div.bg-gray { width: 69.33vw; padding:6.8vw 8vw; }
.cont06 .flexBox li div.bg-gray p { font-size:3.73vw; font-weight:600; }
.cont06 .flexBox li div.bg-gray em { padding: 0 1.6vw; }
.cont06 .flexBox li div.bg-gray small { margin-top: 0.533vw; font-size:2.93vw; font-weight:600; line-height:1.45; text-indent:-1em; margin-left:1em; }
.cont06 .flexBox li div.bg-gray figure { width:53.3vw; margin:4.93vw auto 0; }
.cont06 .flexBox li div.bg-gray a { display:flex; justify-content: center; flex-direction: column; width: 100%; height: 16vw; margin: 5.33vw auto 0; padding: 0; font-size: 3.73vw; font-weight:bold; line-height: 1.357; }
.cont06 .flexBox li div.bg-gray a:hover { color:#102537; text-decoration: none; background-color: transparent; }

/*cont07*/
.cont07 { width: 100%; padding:0; }
.cont07 .co_inner { max-width: 84vw; margin: 0 auto; padding: 10.8vw 0 16vw;} 
.cont07 ul { display:block; }
.cont07 li { margin-top: 5.33vw; width:100%;  }
.cont07 li a { display:block; font-size:3.73vw; font-weight:bold; text-align:center; line-height:16vw; }
.cont07 li a:hover { color: #fff; background-color:transparent; }

/*footer*/
footer { width: 100%; }
footer p { font-size: 2.13vw; font-weight: 400; line-height: 12.8vw; }
footer .pagetop { position:fixed; display: block; width:16vw; height:16vw; }



/******** rs-fixedBtn ********/
.rs-fixedBtn {
    position: fixed;
    width:100%;
    margin: 0 auto;
    padding:2.8vw 0 8vw;
    background:#20afa2;
    bottom:0;
    z-index: 999;
}
.rs-fixedBtn .flexBox { display:block; max-width:89.33%; margin:0 auto; }
.rs-fixedBtn .flexBox li { width:100%; margin:5.2vw 0 0 ; }
.rs-fixedBtn .flexBox a { position:relative; display: block; line-height:13.3vw; font-size: 4vw; font-weight: bold; }
.rs-fixedBtn .flexBox li a:hover { text-decoration:none; }
.rs-fixedBtn .flexBox li a:after { width:1.6vw; height:1.6vw; border-bottom:solid 4px #000; border-right:solid 4px #000; transform: rotate(-45deg); position: absolute; right:4vw; top:40%; }





