.headWrap{
	position: relative;
}

.header {
	position: absolute;
	width: 100%;
	left: 0;
	top: 0;
	z-index: 100;
}

.header_sitenameWrap {
	background: url("../img/header_logo_bg.svg") no-repeat right bottom;
	width: 428px;
	height: 206px;
	position: relative;
	z-index: 20;
}
.header_sitenameWrap__inner{
	position: absolute;
	top: 25%;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 80%;
}
.header_sitenameWrap_sitename {
	width: 191px;
	height: 40px;
	margin: 0 0 7px;
}
.header_sitenameWrap_sitename img{
	width: 191px;
	height: 40px;
}

.header_sitenameWrap_sitedesc {
	color: var(--color-lightText);
	text-align: left;
	font-weight: 400;
}

.header_contact {
	background: url("../img/header_contact_bg.svg") no-repeat;
	width: 256px;
	height: 135px;
	position: absolute;
	right: 0;
	top: 0;
	display: table;
	z-index: 20;
}
.header_contact a{
	color: var(--color-lightText);
	background: url("../img/icon_contact.svg") no-repeat left 50px center;
	background-size: 30px auto;
	padding-left: 90px;
	text-decoration: none;
	display: table-cell;
	vertical-align: middle;
	font-weight: 700;
}

.header_gnav{
	width: 100%;
	padding: 0 300px 0 460px;
	box-sizing: border-box;
	position: absolute;
	top: 40%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 10;
}
.header_gnav ul{
	background: #FFF;
	border-radius: 40px;
	display: flex;
	flex-wrap: wrap;
	padding: 0 2em;
	justify-content: center;
}
.header_gnav ul li{
	padding: 1em 0;
}
.header_gnav ul li a{
	display: block;
	padding: 0 2em;
	border-right: 1px solid #ccc;
	text-decoration: none;
}
.header_gnav ul li:last-child a{
	border: 0;
}

.mainImage{
	overflow: hidden;
}
.mainImage::before{
	padding-top: 20%;
	content: "";
	display: block;
}
.mainImage,
.mainImage .mask{
	width: 100%;
	line-height: 0;
}
.mainImage .photos img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right 0 bottom 0;
    z-index: 50;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
}
.mainImage .mask{
	width: 100%;
	height: 65px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 60;
	background: url("../img/FV_mask.png") no-repeat center bottom;
	background-size: 100% 65px;
}
aside.sp_menu{
	display: none;
}
@media screen and (max-width: 1450px){
	.header_gnav ul{
		padding: 0;
		font-size: 15px;
	}
	.header_gnav ul li{
		padding: 1em 0;
	}
	.header_gnav ul li a{
		padding: 0 1em;
	}
}
@media screen and (max-width: 1200px){
	.header_gnav ul{
		padding: 0;
		font-size: 15px;
	}
	.header_gnav ul li{
		padding: 1em 0;
	}
	.header_gnav ul li a{
		padding: 0 1em;
	}
}
@media screen and (max-width: 1024px){
	.header_sitenameWrap {
		background: url("../img/header_logo_bg.svg") no-repeat right bottom;
		background-size: auto 100%;
		width: 40%;
		height: auto;
		position: relative;
		z-index: 20;
	}
	.header_sitenameWrap:before{
		content: "";
		display: block;
		padding-top: 48%;
	}
	.header_sitenameWrap__inner{
		position: absolute;
		top: 15%;
		left: 50%;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
		width: 80%;
	}
	.header_contact {
		background: url("../img/header_contact_bg.svg") no-repeat top right;
		background-size: 100% 100%;
		width: 30%;
		height: auto;
		padding: 0;
	}
	.header_contact a{
		color: var(--color-lightText);
		background: url("../img/icon_contact.svg") no-repeat left 30px center;
		background-size: 20px auto;
		padding: 0 15px 0 70px;
		display: block;
		line-height: 80px;
	}
	.header_gnav{
		display: none;
	}
	
	aside.sp_menu{
		display: block;
	}
	aside.sp_menu ul{
		background: #D7E6EF;
		border-radius: 40px;
		display: flex;
		flex-wrap: wrap;
		padding: 0 2em;
		justify-content: center;
		width: 90%;
		margin: 0 auto 2em;
		box-sizing: border-box;
	}
	aside.sp_menu ul li{
		padding: 1em 0;
	}
	aside.sp_menu ul li a{
		display: block;
		padding: 0 2em;
		border-right: 1px solid #ccc;
		text-decoration: none;
	}
	aside.sp_menu ul li:last-child a{
		border: 0;
	}
}
@media screen and (max-width: 768px){
	.mainImage::before{
		padding-top: 40%;
	}
	.header_sitenameWrap {
		width: 50%;
	}
}
@media screen and (max-width: 599px) {
	.header_sitenameWrap {
		width: 70%;
	}
	
	.header_contact {
		background: none;
		background-color: #ff8001;
		width: 60px;
		height: 60px;
		display: block;
		border-radius: 50%;
	}
	.header_contact a{
		display: block;
		text-indent: -9999px;
		background: url("../img/icon_contact.svg") no-repeat center center;
		background-size: 20px auto;
		width: 60px;
		height: 60px;
		padding: 0;
		line-height: normal;
	}

	aside.sp_menu ul{
		padding: 0 .5em;
		width: 98%;
	}
	aside.sp_menu ul li{
		padding: 1em 0;
	}
	aside.sp_menu ul li a{
		padding: 0 1em;
		font-size: 14px;
	}

}

/*************************************************************************************/
.pagetitle{
	text-align: center;
	font-size: 2.222em;
	position: relative;
	margin-bottom: 1em;
	padding-top: 1em;
	font-weight: 900;
}
.pagetitle::before{
	width: 1.5em;
	height: 8px;
	background: var(--color-point);
	display: block;
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

section{
	padding-bottom: 80px;
}

/*page_template
************************************************************************************/
#page_template ul.cate-list{
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-rows: auto;
	column-gap: 20px;
	row-gap: 20px;
	align-items: stretch;
}
#page_template ul.cate-list li{
	padding: 30px 20px;
	border-radius: 20px;
	background: #F8F8F8;
}
#page_template ul.cate-list li .head{
	display: table;
	width: 100%;
	margin-bottom: 1.5em;
}
#page_template ul.cate-list li .head .image{
	width: 40%;
	display: table-cell;
	vertical-align: middle;
}
#page_template ul.cate-list li .head .image img{
	max-width: 100%;
	height: auto;
}
#page_template ul.cate-list li .head .titlebox{
	width: 60%;
	display: table-cell;
	vertical-align: middle;
	padding-left: 1em;
	box-sizing: border-box;
	margin-bottom: 1em;
}
#page_template ul.cate-list li .head .titlebox h2{
	margin: 0;
	font-size: 1em;
}
#page_template ul.cate-list li .head .titlebox .eng{
	font-weight: bold;
	color: #FF8001;
	font-size: 0.722em;
	padding: 0.5em 0 0;
}
#page_template ul.cate-list li .btn_orange a{
	background: url("../img/ar_white.svg") no-repeat right 30px center var(--color-point);
	background-size: 8px auto;
	padding: 1em calc(1em + 30px) 1em 1.5em;
	display: block;
	font-size: 0.833em;
}
#page_template ul.cate-list li .btn_orange span{
	background: no-repeat right 30px center var(--color-middle);
	color: var(--form-bg);
	background-size: 8px auto;
	padding: 1em calc(1em + 30px) 1em 1.5em;
	display: block;
	font-size: 0.833em;
	border-radius: 2em;
}
@media screen and (max-width: 768px){
	#page_template ul.cate-list{
		grid-template-columns: 1fr 1fr;
	}
}
@media screen and (max-width: 599px) {
	#page_template ul.cate-list{
		grid-template-columns: 1fr;
	}
}

/*page_faq
************************************************************************************/
#page_faq section{
	background: url("../img/bg_faq.jpg") no-repeat;
	background-size: cover;
	padding: 80px 0;
}
#page_faq section dl.openContent{
	background: #FFF;
	border-radius: 2.5em;
	padding: 1.5em 3em;
	margin-bottom: .7em;
}
#page_faq section dl.openContent dt{
	font-weight: bold;
	position: relative;
	cursor: pointer;
}
#page_faq section dl.openContent dt:after{
	content: "＋";
	font-weight: normal;
	position: absolute;
	right: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
#page_faq section dl.openContent dt.active:after{
	content: "－";
}

#page_faq section dl.openContent dd{
	padding: 1em 0 0;
	font-weight: 400;
}
@media screen and (max-width: 599px) {
	#page_faq section dl.openContent dt{
		padding-right: 1.5em;
	}
}

/*form
************************************************************************************/
.form{
	background: #FFF;
	padding: 40px;
	border-radius: 15px;
}
.form .post-content table th{
	width: 200px;
	padding-right: 50px;
	text-align: left;
}
.form .post-content table th.required{
	background: url("../img/icon-hissu.svg") no-repeat right;
}
.form input,
.form textarea{
	background: var(--form-bg);
	padding: 10px;
	border: 0;
	box-sizing: border-box;
	margin-right: 3px;
}
.form input[type=text],
.form input[type=email],
.form input[type=tel]{
	width: 490px;
}
.form input[type=text].small,
.form input[type=email].small,
.form input[type=tel].small{
	width: 100px;
}
.form textarea{
	width: 100%;
	height: 8em;
}
.form input[type=submit]{
	background: url("../img/icon-sendmail.svg") no-repeat right 1em center var(--color-main);
	border-radius: 50px;
	padding: 1em 4em 1em 3em;
	color: var(--color-lightText);
	margin: 40px auto 0;
	cursor: pointer;
}
@media screen and (max-width: 1024px){
	.form .post-content table th{
		width: 9em;
		padding-right: 50px;
		text-align: left;
	}
	.form .post-content table th.required{
		font-size: 1.4em;
	}
	.form input[type=text],
	.form input[type=email],
	.form input[type=tel]{
		width: 100%;
	}
	.form input[type=text].small,
	.form input[type=email].small,
	.form input[type=tel].small{
		width: 40%;
	}
}


.post-content table{
	width: 100%;
	margin: 1em auto;
	border-collapse:collapse;
	border-top: 1px solid #000;
}

.post-content th{
	padding: 15px;
	width: 10em;
	text-align: left;
	border-bottom: 1px solid #000;
}

.post-content td{
	padding: 15px;
	border-bottom: 1px solid #000;
}

/*scroll*/
.post-content .table_scroll .sp_comment{
	display: none;
}
.post-content .table_scroll .scroll_body{}


@media screen and (max-width: 620px) {
.post-content .table_scroll .sp_comment{
	display: block;
	padding: 10px;
	border: 1px solid #ededed;
	margin: 10px 0;
}
.post-content .table_scroll .sp_comment:after{
	content: "※表が見切れている場合は、横にスクロールしてご覧いただけます";
	color: #666;
	display: block;
}
.post-content .table_scroll .scroll_body{
	width: 97%;
	margin: auto;
	overflow-x: scroll;
	font-size: 14px !important;
}
.post-content .table_scroll .scroll_body .post-content table{
	width: 950px !important;
	font-size: 14px !important;
}
.post-content .table_scroll .scroll_body .post-content table th,
.post-content .table_scroll .scroll_body .post-content table td,
.post-content .table_scroll .scroll_body .post-content table.main th,
.post-content .table_scroll .scroll_body .post-content table.main td,
.post-content .table_scroll .scroll_body .post-content table.normal th,
.post-content .table_scroll .scroll_body .post-content table.normal td{
	word-break: keep-all;
	font-size: 14px !important;
}
}


/*sp*/

@media screen and (max-width: 620px) {
	.post-content table.smartphone{
		display: block;
		width: 100%;
	}
	.post-content table.smartphone thead{
		display: none;
	}
	.post-content table.smartphone tbody{
		display: block;
		width: 100%;
	}
	.post-content table.smartphone tr{
		display: block;
		margin-bottom: 1.5em;
		width: 100%;
	}
	.post-content table.smartphone th,
	.post-content table.smartphone td{
		display: list-item;
		width: 100%;
		padding: 5px 10px !important;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
		display: block;
		border: 0;
	}
	.post-content table.smartphone th{
		list-style-type: none;
		display: block;
	}

	.post-content table.smartphone td{
		margin-left: 0;
		list-style-type: none;
		border: 0;
		padding-left: 25px;
	}
}