@charset "UTF-8";
/*-----全体------*/
.sp_only {
	display: none;
}
.pc_only {
	display: block;
}
html{
	font-size: 62.5%;
	scroll-padding-top: 80px;
	font-family: 'Noto Sans JP', sans-serif;
}
body{
	position: relative;
}
h1{
	font-size: 2.1vw;
    font-weight: 500;
    color: #323232;
    line-height: 1.5;
}
h2{
	font-size: 2.4rem;
    font-weight: 400;
	color: #323232;
}
h3{
	font-size: 3.4rem;
    font-weight: 500;
	color: #323232;
	line-height: 1.5;
	letter-spacing: 0.1rem;
}
.Prop h3,.products_box h3{
	color: #2764EF;
	font-size: 1.3rem;
	margin-top: 10px;
	text-align: center;
}
p,dt,dd{
	font-weight: 400;
	font-size: 1.4rem;
	letter-spacing: 1px;
    line-height: 1.8;
	color: #2B3A4C;
	font-feature-settings: "palt";
}
a{
	display: block;
}
.Poppins{
	font-family: "Poppins", sans-serif;
	font-weight: 600;
	font-style: normal;
}
.Poppins img{
	margin-right: 8px;
}
.title{
	display: flex;
    flex-direction: column;
    align-items: center;
	margin-bottom: 40px;
}
.blue{
	color: #2764EF;
}
#pagetop{
	display: block;
	position: fixed;
	right: 50px;
	bottom: 50px;
	z-index: 10;
	cursor: pointer;
}
#pagetop img{
	width: 60px;
}

/*-----header_トグル------*/
.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	display: flex;
	position: relative;
	z-index: 2;
	margin: 0px;
	width: 50px;
	height: 30px;
	border-radius: 50px;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	pointer-events: auto;
}
.menu-trigger span {
	left: 10px;
	width: 30px;
	height: 2px;
	background-color: #323232;
	border-radius: 4px;
}
.menu-trigger.active span:nth-of-type(1) {
	transform: translateY(11px) rotate(-45deg);
	background-color: #323232;
}
.menu-trigger.active span:nth-of-type(2) {
	transform: translateY(-4px) rotate(45deg);
	background-color: #323232;
}	
.menu-trigger.active span:nth-of-type(3) {
	display: none;
}
header {
	position: fixed;
    z-index: 3;
    width: 100%;
	top: 0;
	background-color: #ffffff;
}
.nav_menu{
	font-weight: 500;
    font-size: 1vw;
    color: #2B3A4C;
    align-items: center;
    display: flex;
    justify-content: space-between;
	margin: 0 4%;
}
header nav,header nav ul{
	display: flex;
	align-items: center;
}
header li{
	margin-right: 1.6rem;
}
header .contact_btn_li a{
	margin-left: 10px;
    padding: 12px 40px;
}
header li:last-of-type{
	margin-right: 0rem;
}
.nav_menu .logo{
	margin: 30px 0px 20px 0px;
}
.logo img{
	height: 40px;
}


/*-----main------*/
main{
	position: relative;
}
.title h2{
	text-align: center;
    padding-top: 20px;
	font-size: 3rem;
	border-bottom: solid #A3BDF7 1px;
	width: max-content;
	margin: auto;
    padding-bottom: 10px;
	margin-bottom: 10px;
}
.about_contents,.products_contents{
	margin: auto;
	padding: 0 4%;
}
.about,.products{
	background-color: #EBF7FF;
	padding-top: 100px;
}
.about_contents,.products_contents,.flow_contents,.qa-list,.caption{
	max-width: 96rem;
	margin: auto;
}
/*-----top_kv------*/
.top_kv{
	position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: auto;
	padding: 100px 4% 0;
	background-image: url(../img/wave.png);
    background-position: bottom -1px left;
    background-size:cover;
    background-repeat: no-repeat;
}
.top_kv_box{
	width: 40%;
}
.top_kv_box p{
	font-size: 1.6rem;
    margin: 20px auto 50px;
	letter-spacing: 1px;
}
.top_kv_box a,.contact_contents a{
	display: contents;
}
.contact_btn{
	background-color: #2764EF;
    border: none;
    color: #fff;
    padding: 14px 40px;
    border-radius: 30px;
    font-size: 1vw;
    font-weight: 600;
	display: flex;
    align-items: center;
	cursor: pointer;
	cursor: hand;
	letter-spacing: 0.5px;	
}
.contact_btn::after{
	content: "";
    width: 6px;
    height: 6px;
    border: 2px solid;
    border-color: #ffffff #ffffff transparent transparent;
    transform: rotate(45deg);
    display: block;
    margin-left: 6px;
}
.contact_btn:hover{
	background-color: #6491F7;
}
.contact_contents button:hover{
	background-color: #6491F7;
   box-shadow: 0px 10px 20px 0px rgb(43 10 23 / 23%);
}
.under_line{
	display: inline-block;
	position: relative;
 	text-decoration: none;
	padding-bottom: 5px;
    box-sizing: border-box;
}
.under_line:before{
	content: "";
	position: absolute;
	left: 0;
	bottom: -4px;
	width: 100%;
	height: 3px;
	background: #2764EF;
	transform: scale(0, 1);
	transform-origin: left;
	transition: 0.4s;
}
.under_line:hover:before {
	transform: scale(1);
}
.top_kv_service{
	display: flex;
    flex-wrap: wrap;
    width: 56%;
	justify-content: center;
}
.top_kv_box h1 span{
	font-size:4.3vw;
}
.Prop{
	width: 44%;
    padding: 15px;
    box-shadow: 0px 0px 10px #00288326;
    border-radius: 20px;
	margin-bottom: 8px;
	background-color: #ffffff8c;
	border: solid 1px #ffffff;
}
.Prop:nth-child(odd){
	margin-right: 8px;
}
.Prop h2{
    display: flex;
	justify-content: center;
    align-items: center;
}
.Prop p{
	font-size: 1.4rem;
	color: #636363;
}
.Prop h3::after{
	content: "";
	border-bottom: solid #A3BDF7 1px;
    display: block;
    margin: 4px auto;
}
.top_kv_service a{
	text-decoration: underline;
	display: inline-block;
}
/*-----about------*/
.about_contents{
	font-size: 1.8rem;
}
.about_contents .title{
	margin-bottom: 20px;
}

/*-----products------*/
.products_box{
	display: flex;
    flex-wrap: wrap;
	justify-content: space-around;
}
.products_box_1{
	width: 28%;
    padding: 20px;
    box-shadow: 0px 0px 10px #00288326;
    border-radius: 20px;
    margin-bottom: 15px;
    background-color: #ffffff8c;
	border: solid 1px #ffffff;
}
.products_box_1 h3::after{
	content: "";
	border-bottom: solid #A3BDF7 1px;
    display: block;
    margin: 4px auto;
}
.products_box_2{
	display: flex;
}
.products_box_2 img{
	margin-right: 4px;
}
.products_box_1 h2{
	display: flex;
    align-items: center;
	justify-content: center;
}
.products{
	background-image: url("../img/PRODUCTS.svg");
	background-position: left 0 top 17%;
    background-size: 76%;
    background-repeat: no-repeat;
    padding-bottom: 100px;
}

/*-----flow------*/
.flow{
	padding: 100px 0;
}
.flow_contents{
	display: flex;
    justify-content: space-between;
	position: relative;
}
.flow_contents p{
	font-size: 1.3rem;
	color: #2764EF;
	font-weight: 400;
	width: 10%;
	letter-spacing: 0;
}
.flow_contents_box{
	display: flex;
    flex-direction: column;
    align-items: center;
}
.flow_contents_box img{
	box-shadow: 0px 0px 10px #00288326;
    border-radius: 100%;
	margin-bottom: 8px;
	width: 100%;
}
.flow_contents::after{
	content: "";
    border-bottom: solid #A3BDF7 1px;
    display: block;
    width: 100%;
    position: absolute;
    top: 37%;
    z-index: -1;
}
/*-----faq------*/
.faq{
	background-color: #F7F6F7;
	padding-bottom: 100px;
}
.faq_img{
	width: 100%;
    vertical-align: bottom;
}
.qa span{
	color: #2764EF;
    font-size: 2rem;
    padding-right: 10px;
}
.qa-list dl {
	position: relative;
    padding: 15px 80px 15px 15px;
    cursor: pointer;
    background-color: #ffff;
    margin-bottom: 10px;
    border-radius: 15px;
}	
.qa-list dl::before {
    position: absolute;
    top: 35px;
    right: 30px;
    display: block;
    width: 10px;
    height: 10px;
    margin: auto;
    content: '';
    transform: rotate(135deg);
    border-top: 3px solid #323232;
    border-right: 3px solid #323232;
}
.qa-list .open::before {
    transform: rotate(-45deg);
}
.qa-list dl dt {
    position: relative;
    margin: 0;
}
.qa-list dl dt::before {
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 0;
    display: block;
    content: '';
}
.qa-list dl dd::before {
    line-height: 1;
    position: absolute;
    top: 3px;
    left: 2px;
    display: block;
    content: '';
}
.qa-list dl dd {
    position: relative;
    display: none;
    height: auto;
    margin: 20px 0 0;
}
.qa-list dl dd p {
    margin: 30px 0 0;
	color: #666666;
}
.qa-list dl dd p:first-child{
    margin-top: 0;
}

/*-----contact------*/
.contact{
	background-color: #323232;
	padding: 40px 0px 30px;
}
.contact h2{
	border-bottom: none;
	margin: auto;
    font-size: 3rem;
}
.contact_contents{
	margin-bottom: auto;
}
.contact_contents .title,.contact .title h2,.contact  h4,.contact_contents p,small{
	color: #fff;
}
.contact_contents p{
	text-align: center;
	margin: 0px auto 50px;
	font-weight: 400;
}
.contact_contents button{
	margin: auto;
    background-color: #2764EF;
    border: none;
    color: #ffffff;
    padding: 0px 50px;
    border-radius: 50px;
    font-size: 1.6rem;
    height: 70px;
}
.contact_contents button::after{
	border-color: #ffffff #ffffff transparent transparent;
}
.contact_contents .title{
	margin-bottom: 50px;
	display: flex;
    justify-content: center;
}
.caption{
	color: #ffffff;
	display: flex;
	justify-content: space-between;
	margin-top: 100px;
}
small{
	font-size: 1rem;
    text-align: left;
    font-weight: 200;
}
.caption_contents{
	display: flex;
	justify-content: flex-end;
	align-items: center;
}
.caption_contents a{
	margin-left: 20px;
	font-size: 1.2rem;
}
/*-----pc　1919px------*/
@media screen and (max-width: 1920px){
	.top_kv{
		background-size: contain;
	}
}
/*-----pc　1450px------*/
@media screen and (max-width: 1450px){
}

/*-----pc　1280px------*/
@media screen and (max-width: 1280px){
	
}

/*-----ipad air　横　1181px------*/
@media screen and (max-width: 1181px){
	.about_contents, .products_contents, .flow_contents, .qa-list, .caption {
		padding: 0 4% 0;
	}
	.top_kv_box p {
		font-size: 1.2vw;
	}
	.Prop h3 {
		font-size: 1.3rem;
	}
	.products_box h3{
		font-size: 1.6rem;
        letter-spacing: 0;
	}
	h2 {
		font-size: 2vw;
	}
	.Prop p {
		font-size: 1rem;
	}
}

/*-----ipad mini　横　1164px------*/
@media screen and (max-width: 1164px){
	.Prop {
		width: 40%;
	}
	.products{
		background-size: 80%;
	}
	.products_box_1{
		width: 28%;
	}
	.products_box_2 {
		margin-bottom: 2px;
	}
	.products{
		background-image: none;
	}
	.flow_contents{
		flex-wrap: wrap;
	}
	.flow_contents p{
		margin-bottom: 20px;
	}
	.flow_contents::after{
		border-bottom: none;
	}
	.Prop h3 {
		font-size: 0.9rem;
	}
}

/*-----ipad　縦------*/
@media screen and (max-width: 821px) {
	.sp_only {
		display: block;
	}
	.pc_only {
		display: none;
	}
	header nav{
		display: none;
		width: 100%;
		position: absolute;
		background-color: #fffffff0;
		padding: 80px 20px 20px;
		box-sizing: border-box;
		left: 0;
		top: 0;
	}
	.nav_menu .logo {
		margin: 0px 0px 0px 0px;
		z-index: 1;
	}
	.nav_menu{
		margin: auto 4%;
	}
	header .contact_btn_li a{
		border-radius: 100px;
		margin-left: 0px;
	}
	header nav ul{
		flex-direction: column;
	}
	header li {
		margin-right: 0;
		margin-bottom: 20px;
	}
	.nav_menu{
		height: 60px;
	}
	.sp_contact{
		display: flex;
		align-items: center;
	}
	.contact_btn{
		padding: 6px 15px;
	}
	.top_kv_box .contact_btn{
		display: none;
	}
	.products_box_1 {
        width: 26%;
    }
	.top_kv_box p {
		font-size: 2vw;
		margin: 20px auto 20px;
	}
	.top_kv{
		display: flex;
		flex-direction: column;
	}
	.top_kv_box,.top_kv_service{
		width: 100%;
	}
	.top_kv_service{
		justify-content: space-between;
	}
	.Prop {
        width: 45%;
    }
	.Prop p {
		font-size: 1.4vw;
	}
	.nav_menu,.contact_btn {
		font-size: 1.8vw;
	}
	.top_kv_box, .top_kv_service{
		margin-bottom: 20px;
	}
	.top_kv_box h1 span {
		font-size: 8.6vw;
	}
	h1 {
		font-size: 46px;
	}
	h3 {
		font-size: 5.6vw;
	}
	.Prop h3 {
        font-size: 1.8vw;
    }
	.products_box h3{
		font-size: 2.1vw;
	}
	h2 {
		font-size: 3.2vw;
	}
	.title h2 {
		font-size: 4.2vw;
	}
	p, dt, dd {
		font-size: 2vw;
	}
	.products_box_1 {
        width: 43%;
    }
	.about, .products {
		padding-top: 50px;
	}
	caption_contents a {
    	font-size: 1.6vw;
	}
	small {
		font-size: 1.2vw;
	}
	#pagetop{
		right: 10px;
	}
}

/*-----ipad mini 縦------*/
@media screen and (max-width: 782px) {
	.Prop {
        width: 44%;
    }
}
/*-----ipad mini 縦------*/
@media screen and (max-width: 770px) {
}
/*-----ipad mini 縦------*/
@media screen and (max-width: 652px) {
	.Prop {
        width: 43%;
    }
}
/*-----iPhoneX_12pro XR------*/
@media screen and (max-width: 599px) {
	.top_kv{
		padding: 15% 4% 0;
	}
	.top_kv_box p {
        font-size: 3.8vw;
    }
	h1 {
        font-size: 8vw;
    }
	.top_kv_box h1 span {
        font-size: 10vw;
    }
	.nav_menu, .contact_btn {
        font-size: 3.8vw;
    }
	.Prop p {
        font-size: 3.2vw;
    }
	.Prop {
        width: 100%;
    }
	.Prop:nth-child(odd) {
		margin-right: 0;
	}
	.Prop h3{
		margin-top: 4px;
	}
	h2 {
        font-size: 6.2vw;
    }
	.Prop h3, .products_box h3 {
        font-size: 3.8vw;
    }
	.top_kv {
        background-image: url(../img/wave_sp.jpg);
        background-color: #ebf7ff;
		background-position: top;
	}
	.top_kv_box, .top_kv_service {
        margin-bottom: 0px;
    }
	.title h2 {
        font-size: 6.2vw;
    }
	.about, .products {
		padding-top: 60px;
	}
	p, dt, dd {
        font-size: 4vw;
    }
	.title{
		margin-bottom: 20px;
	}
	.products_box_1 {
        width: 100%;
    }
	.flow {
		padding: 60px 0;
	}
	.flow_contents p {
        margin-bottom: 20px;
        width: 30%;
        text-align: center;
		font-size: 3.5vw;
    }
	.flow_contents_box img{
		width: 80%;
	}
	.contact_contents p{
		text-align: justify;
		padding: 0 4%;
	}
	dt .Poppins,.qa span {
		font-size: 5vw;
	}
	.caption{
		display: flex;
		flex-direction: column-reverse;
		align-items: center;
	}
	small {
        font-size: 2.2vw;
		margin-top: 10%;
    }
	.caption_contents a {
		font-size: 3vw;
	}
	.contact h2{
		font-size: 9.2vw;
	}
	.caption_contents a:first-child{
		margin-left: 0px;
	}
	.caption{
		margin-top: 60px;
	}
}

/*-----iPhoneSE------*/
@media screen and (max-width: 376px) {
	h1{
		letter-spacing: 2px;
	}
}


