/* ---------------------------------------------------------------
start COMMON CSS
--------------------------------------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Akshar:wght@300..700&family=Shippori+Antique&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Akshar:wght@300..700&family=Shippori+Antique&display=swap');


body {
	width: 100%;
	margin: 0;
	padding: 0;
	color: #303030;
	font-family: 'Noto Sans JP', Meiryo, sans-serif;
	font-size: 15px;
	line-height: 1.85;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	position: relative;
	z-index: 0;
	background-color: #fff;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*\*/
	/*/
	height: auto;
	overflow: hidden;
	/**/
}

a {
	outline: none;
	color: #1d2087;
	text-decoration: underline;
}

a:hover {
	text-decoration: none;
	cursor: pointer;
}

button {
	outline: none;
}

img {
	height: auto;
	border: none;
	margin: 0;
	padding: 0;
	vertical-align: bottom;
	-ms-interpolation-mode: bicubic !important;
	-webkit-backface-visibility: hidden;
	-moz-backface-visibility: hidden;
	-ms-backface-visibility: hidden;
	backface-visibility: hidden;
}

p {
	margin: 0 0 15px 0;
	padding: 0;
}

ul {
	list-style: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0px;
}

h1,h2,h3,h4 {
	margin: 0;
	padding: 0;
}

.w100 {
	width: 100%;
}

.aligncenter {
	text-align: center;
}

.alignright {
	text-align: right;
}

.alignjust {
	text-align: justify;
	text-justify: inter-ideograph;
	-ms-text-justify: inter-ideograph;
}

.mb30{
	margin-bottom: 30px;
}

.fleft {
	float: left;
}

.fright {
	float: right;
}

.note {
	font-size: .7em;
}

.red {
	color: #e60012;
}

.serif {
	font-family: "Noto Serif JP", serif;
	;
}

.under {
	text-decoration: underline;
}

.iblock {
	display: inline-block;
}

.indent1 {
	padding-left: 1em;
	text-indent: -1em;
}

.indent1 * {
	text-indent: 0;
}

img.object-fit-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	font-family: 'object-fit: cover;'
}

.fade-in,
.scroll-in {
	opacity: 0;
	-webkit-transition: all 0.5s ease-in-out;
	transition: all 0.5s ease-in-out;
	position: relative;
}

.scroll-in.sc_active {
	opacity: 1;
}

.fade-in.active {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}


@media print,
screen and (min-width: 721px) {
	.pc_none {
		display: none;
	}
	
	.sp_none {
		display: block;
	}
}

@media print,
screen and (max-width: 700px) {
	.sp_none {
		display: none;
	}
}

#wrap {
	width: 100%;
	margin: 0;
	padding: 0;
	overflow: hidden;
}

a.btn {
	width: 215px;
	margin: 0;
	padding: 0.8em;
	text-decoration: none;
	border: solid 1px #1d2087;
	border-radius: 3.6em;
	transition: all .4s;
	display: flex;
	align-items: center;
	position: relative;
	z-index: 0;
}

@media print,
screen and (min-width: 851px) {
	a.btn.pc_none {
		display: none;
	}
}

@media print,
screen and (max-width: 850px) {
	a.btn {
		margin: 0 auto;
	}
}

a.btn::after {
	content: "→";
	width: 26px;
	height: 26px;
	margin: 0;
	padding: 0;
	text-align: center;
	border-left: solid 1px #1d2087;
}

a.btn span {
	margin: 0;
	padding: 0 0.8em;
	display: inline-block;
}

a.btn:hover {
	color: #fff;
	background-color: #1d2087;
}

a.btn:hover::after {
	border-left-color: #fff;
}


h2.en{
	font-size: 50px;
	font-weight: 600;
	font-style: normal;
	font-family: "Akshar", sans-serif;
}

h3.ja{
	font-size: 15px;
	font-weight: 500;
	color: #16a2dc;
}

h3.ja2{
	font-size: 15px;
	font-weight: 500;
	color: #003d67;
}

@media print,
screen and (max-width: 720px) {
	.sp_none{
		display: none;
	}
	
	h2.en{
		font-size: min(10vw , 70px);
	}
	
	h3.ja{
	font-size: 3.5vw;
}

	h3.ja2{
	font-size: min(3.2vw , 23px);
}

}






/* --------------- header --------------- */

header {
	width: 100%;
	margin: 0;
	padding: 0;
	background-color: #ffffffd9;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
}

.col_header {
	width: 100%;
	max-width: 1260px;
	height: 67px;
	margin: 0 auto;
	padding: 0 1% 0 2.6%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	box-sizing: border-box;
}

.logo_header {
	width: 20%;
	max-width: 232px;
	margin: 0;
	padding: 0;
}

.logo_header a {
	transition: opcity .3s;
}

.logo_header a:hover {
	opacity: 0.8;
}

img.header_img {
	width: 100%;
}

.col_navi {
	width: 85%;
	height: 100%;
	margin: 0;
	padding: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	justify-content: flex-end;
}

ul.navi_header {
	width: 100%;
	margin: 0;
	padding: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	justify-content: flex-end;
}

ul.navi_header>li {
	margin: 0;
	padding: 0 4% 0 0;
	text-align: center;
	line-height: 1.35;
	position: relative;
	z-index: 0;
}



ul.navi_header>li:last-child {
	border-right: none;
}

ul.navi_header>li.inquiry{
	padding: 10px 20px;
	border-radius: 50px;
	background-color: #16a2dc;
}



ul.navi_header li a {
	height: 100%;
	margin: 0;
	padding: 0;
	font-weight: 500;
	color: #003d67;
	text-decoration: none;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 0;
}

ul.navi_header li a:hover {
	opacity: 0.8;
}


ul.navi_header li.inquiry a{
	color: #fff;
}

br.tabmax{
	display: none;
}

print, screen and (max-width: 1030px) and (min-width: 851px){
	ul.navi_header li a .tabmax{
		display: inline;
	}
	

}

@media print,screen and ( max-width: 1080px ) {
	ul.navi_header>li{
		padding: 0 3% 0 0;
		font-size: 13px;
	}
	
}

@media print,screen and ( max-width: 800px ) {
	.logo_header{
		max-width: 200px;
	}
	
	ul.navi_header>li{
		padding: 0 5px 0 0;
	}
	
	ul.navi_header>li.inquiry{
		padding: 5px;
	}
	
}



@media print,screen and ( max-width: 720px ) {
	
	header{
		background-color: #ffffff;
	}
	
	.col_header{
		height: 55px;
		padding: 0 0 0 2.6%;
	}
	
	.logo_header {
		width: 200px;
		margin: 0 14% 0 0;
		max-width: 399px;
	}
	
	.col_navi{
		width: 40%;
		margin-left: auto;
	}
	
	ul.navi_header{
		width: 100%;
		height: auto;
		padding: 87px 0 270px 0;
		display: none;
		background-color: rgb(0 0 0 / 70%);
		position: absolute;
		top: 55px;
		right: 0;
		overflow: auto;
	}
	
	ul.navi_header > li{
		width: 85%;
		max-width: 447px;
		margin: 0 auto 25px;
		border-radius: 34px;
		background-color: #16a2dc;
		position: relative;
		z-index: 0;
		font-size: 15px;
	}
	
	ul.navi_header > li > a{
		color: #fff;
		padding: 18px 30px;
	}
	
	ul.navi_header>li.inquiry{
		width: 85%;
		max-width: 447px;
		margin: 0 auto 25px;
		padding: 0 5px 0 0;
		border-radius: 25px;
		background-color: #16a2dc;
		position: relative;
		z-index: 0;
	}
	
	ul.navi_header li a .tabmax{
		display: none;
	}

	#menubtn{
		width: 50%;
		max-width: 67px;
		height: 100%;
		margin: 0;
		padding: 0;
		display: block;
	}
	
	.btn{
		width: 30px;
		height: 100%;
		margin: 0 auto;
		position: relative;
		z-index: 0;
	}
	
	#menubtn .btn span{
		width: 100%;
		height: 3px;
		margin: auto;
		padding: 0;
		background-color: #003d67;
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 0;
		right: 0;
	}
	
	#menubtn span:nth-child(1){
		top: 32%;
	}
	
	#menubtn span:nth-child(2){
		top: 47%;
	}
	
	#menubtn span:nth-child(3){
		top: 64%;
	}
	
	#menubtn.active{
		background-color: #003d67;
	}
	
	#menubtn.active span:nth-of-type(1){
		width: 96%;
		transform: translateY(17px) rotate(-45deg);
		top: 20%;
		background: #fff;
	}
	
	#menubtn.active span:nth-of-type(2){
		opacity: 0;
	}
	
	#menubtn.active span:nth-of-type(3){
		width: 96%;
		transform: translateY(-17px) rotate(45deg);
		top: 80%;
		background: #fff;
	}
	
	.img_mail{
		width: 30%;
	    max-width: 30px;
	    margin: 0 7% 0 0;
	}
	

}





/* --------------- footer --------------- */

#footer{
	padding: 55px 0 50px;
	font-weight: 500;
	color: #003d67;
}

#footer .inner{
	width: 90%;
	max-width: 950px;
	margin: 0 auto;
	padding: 0;
}

#footer .inner .logo{
	width: 28%;
	max-width: 257px;
	margin: 0 380px 40px auto;
	padding: 0;
}

#footer .inner .logo a:hover{
	opacity: 0.8;
}

#footer img{
	width: 100%;
	height: auto;
	display: block;
}

ul.footer_list{
	margin: 0 0 40px;
	padding: 0;
	display: flex;
}

ul.footer_list a{
	color: #003d67;
	text-decoration: none;
}

ul.footer_list a:hover{
	opacity: 0.8;
}

ul.footer_list li{
	padding: 0 3.2% 0;
	border-right: solid 1px #003d67;
}

ul.footer_list li:first-child{
	padding: 0 2.6% 0 0;
}

ul.footer_list li:last-child{
	padding: 0 0 0 25px;
	border-right: none;
}

.txt_footer{
	text-align: center;
	font-size: 12px;
}

.copy{
	margin: 0;
	padding: 12px 0;
	text-align: center;
	color: #fff;
	font-size: 12px;
	background-color: #003d67;
}


@media print,
screen and (max-width: 1050px) {
	#footer .inner .logo{
		margin: 0 auto 40px;
	}
	

}

@media print,
screen and (max-width: 720px) {
	#footer .inner .logo{
		width: 72%;
		max-width: 515px;
		margin: 0 auto;
	}
	
	ul.footer_list{
		display: none;
	}
	
	.txt_footer{
		display: none;
	}
	
	
	
}




