@charset "utf-8";



/**************************************************
 pageHeader
**************************************************/
.pageHeader{
	position: relative;
	width: calc(100% - 40px);
	height: 380px;
	margin: 120px auto 0 auto;
	border-radius: 25px;
	overflow: hidden;
}

.pageHeader img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cateName{
	position: absolute;
	width: 400px;
	height: 60px;
	top: 75px;
	left: calc(50% - 200px);
	border-radius: 10.0rem;
	font-size: 2.2rem;
	font-weight: 700;
	letter-spacing: 1px;
	color: #FFFFFF;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center;
}
.cateName img{
	height: auto;
	margin-right: 10px;
}

.pageHeader h1{
	position: absolute;
	width: 750px;
	height: 181px;
	bottom: -1px;
	left: calc(50% - 375px);
	font-size: 4.5rem;
	font-weight: 900;
	letter-spacing: 3px;
	line-height: 1.2;
	text-align: center;
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
	background: #FFFFFF;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center;
}
.pageHeader h1 small{
	display: inline-block;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 1px;
	margin-bottom: 25px;
}
.pageHeader h1 small.style1{margin-bottom: 15px;}



/**************************************************
 wrapper
**************************************************/
#wrapper{padding: 80px 20px 0 20px;}



/**************************************************
 .innerWrapper
**************************************************/
.innerWrapper{
	position: relative;
	width: 1100px;
	margin: 0 auto 0 auto;
	-webkit-box-pack: end;
	justify-content: flex-end;
	/*-webkit-box-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	align-items: flex-start;*/
}



/**************************************************
 main
**************************************************/
main{
	width: 740px;
	order: 2;
}

.inPage.style1 ul{
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.inPage ul li{
	position: relative;
	width: calc((100% - 20px) / 3);
	height: 70px;
	margin: 0 10px 10px 0;
	font-size: 1.6rem;
	font-weight: 700;
	cursor: pointer;
	border-radius: 10px;
	display:-webkit-box;
  	display:flex;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center;
	-webkit-transition: 0.2s ease-in-out;
	transition: 0.2s ease-in-out;
}
.inPage ul li:nth-of-type(3n){margin: 0 0 10px 0;}
.inPage.style1 ul li:nth-of-type(2){margin: 0 0 10px 0;}
.inPage ul li::before{
	width: 6px;
	height: 6px;
	bottom: 10px;
	left: calc(50% - 3px);
	transform: rotate(45deg);
}
.inPage ul li:hover{color: #FFFFFF;}
.inPage ul li:hover::before{bottom: 5px;}



/**************************************************
 article
**************************************************/
article h2{
	position: relative;
	margin-top: 110px;
	font-size: 3.3rem;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.3;
	padding: 30px;
	background: var(--bg-color1);
	border-radius: 10px;
}
article h2::before{
	width: 11px;
	height: 50%;
	top: 25%;
	left: -5px;
	border-radius: 6px;
}
article h2.style1{margin-top: 0;}

article h3{
	position: relative;
	margin-top: 60px;
	font-size: 3.0rem;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.3;
	padding: 0 0 25px 40px;
	border-bottom: 1px solid var(--border-color1);
}
article h3::before{
	width: 24px;
	height: 6px;
	top: 17px;
	left: 0;
	border-radius: 3px;
}

article h4{
	position: relative;
	margin-top: 50px;
	padding: 15px 10px;
	font-size: 2.3rem;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.3;
	border-radius: 10px;
}
article h4.style1{margin-top: 40px;}

article h5{
	margin-top: 40px;
	font-size: 1.9rem;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.3;
}

article p{
	font-size: 1.7rem;
	line-height: 2.0;
	padding-top: 30px;
}
article p.style1{padding-top: 10px;}
article p a.common{
	color: var(--link-color);
	text-decoration: underline;
}
article p a.common:hover{
	opacity: 0.5;
	text-decoration: none;
}

article ul{
	margin-top: 25px;
	list-style: disc;
	padding-left: 40px;
}
article ul li{
	font-size: 1.7rem;
	line-height: 1.6;
	margin-top: 15px;
}

article ol{
	margin-top: 25px;
	list-style: decimal;
	padding-left: 30px;
}
article ol li{
	font-size: 1.7rem;
	line-height: 1.6;
	margin-top: 15px;
}
article ul.style1,
article ol.style1{margin-top: 10px;}

article ul li a,
article ol li a{
	color: var(--text-color1);
	text-decoration: underline;
}
article ul li a.common,
article ol li a.common{color: var(--link-color);}
article ul li a:hover,
article ol li a:hover{
	opacity: 0.5;
	text-decoration: none;
}

article table{
	margin-top: 30px;
	width: 100%;
	border-top: 1px solid var(--border-color1);
	border-left: 1px solid var(--border-color1);
}
article table th{
	padding: 15px;
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.3;
	text-align: left;
	background: var(--bg-color1);
	border-bottom: 1px solid var(--border-color1);
	border-right: 1px solid var(--border-color1);
}
article table td{
	padding: 15px;
	font-size: 1.7rem;
	line-height: 1.6;
	border-bottom: 1px solid var(--border-color1);
	border-right: 1px solid var(--border-color1);
}
article table.style1{
	width: auto;
	min-width: 65%;
	margin-top: 25px;
}
article table.style1 th{width: 40%;}
article table.style2 tbody tr td:first-of-type{background: var(--bg-color1);}

.tableHanger{
	position: relative;
	margin-top: 40px;
	padding-bottom: 2px;
}
.tableHanger table{margin-top: 0;}

.txtLink{margin-top: 20px;}
.txtLink a{
	position: relative;
	font-size: 1.7rem;
	line-height: 1.3;
	color: var(--text-color1);
	text-decoration: underline;
	padding-left: 20px;
}
.txtLink a::before{
	width: 6px;
	height: 6px;
	top: 10px;
	left: 0;
	transform: rotate(45deg);
}
.txtLink a:hover{
	color: rgba(0,0,0,0.5);
	text-decoration: none;
}
.txtLink a:hover::before{left: 5px;}

.relatedLink{
	margin-top: 50px;
	padding: 25px 30px;
	border: 5px solid var(--bg-color1);
	border-radius: 15px;
	-webkit-box-align: center;
	align-items: center;
}
.relatedLink span{
	display: inline-block;
	width: 140px;
	font-size: 1.8rem;
	font-weight: 700;
}
.relatedLink ul{
	width: calc(100% - 140px);
	margin: 0;
	padding: 0;
	list-style: none;
}
.relatedLink ul li{
	position: relative;
	margin: 5px 0;
	font-size: 1.7rem;
	padding-left: 20px;
}
.relatedLink ul li::before{
	width: 6px;
	height: 6px;
	top: 9px;
	left: 0;
	transform: rotate(45deg);
}
.relatedLink ul li a{
	position: relative;
	font-size: 1.7rem;
	line-height: 1.3;
	color: var(--text-color1);
	text-decoration: underline;
	/*padding-left: 20px;*/
}
.relatedLink ul li a:hover{
	color: rgba(0,0,0,0.5);
	text-decoration: none;
}
.relatedLink ul li:hover::before{left: 5px;}

.imageHanger{
	margin-top: 10px;
	text-align: center;
}

.figHanger{
	margin-top: 40px;
	text-align: center;
}

.graphHanger{
	margin-top: 20px;
	text-align: center;
}

.inquiryHanger{
	position: relative;
	margin-top: 100px;
	border-radius: 15px;
	overflow: hidden;
}
.inquiryHanger dt{
	padding: 25px 0;
	font-size: 2.8rem;
	font-weight: 900;
	text-align: center;
}
.inquiryHanger dd{
	padding: 25px 0;
	font-size: 2.0rem;
	font-weight: 700;
	line-height: 1.8;
	text-align: center;
	background: var(--bg-color1);
}
.inquiryHanger dd a{
	color: var(--text-color1);
	text-decoration: underline;
}
.inquiryHanger dd a:hover{
	opacity: 0.5;
	text-decoration: none;
}

article.flow::before{
	width: 2px;
	height: calc(100% + 110px);
	top: 0;
	left: 30px;
	z-index: 0;
}
article.flow.lastItem::before{height: 100%;}
article.flow h2::before{display: none;}
article.flow h2 span{
	position: absolute;
	display: block;
	top: -20px;
	left: -20px;
	font-size: 2.4rem;
	line-height: 1.0;
	color: #FFFFFF;
	padding: 10px 30px;
	border-radius: 10.0rem;
}
.flowInner{padding-left: 60px;}
.flowInner dl{
	margin-top: 30px;
	padding: 20px;
	border-radius: 15px;
	background: var(--bg-color1);
}
.flowInner dl dt{
	font-size: 2.0rem;
	font-weight: 700;
}
.flowInner dl dd{
	font-size: 1.7rem;
	line-height: 1.8;
	padding-top: 15px;
}

.flowInner ol li a,
.flowInner ul li a{
	position: relative;
	display: block;
	margin-top: 10px;
	padding-left: 20px;
}
.flowInner ol li a::before,
.flowInner ul li a::before{
	width: 6px;
	height: 6px;
	top: calc(50% - 3px);
	left: 0;
	transform: rotate(45deg);
}
.flowInner ol li a:hover::before,
.flowInner ul li a:hover::before{left: 5px;}
.flowInner ol li span{
	display: inline-block;
	margin-right: 20px;
}

.btnHanger{margin-top: 50px;}
.btnHanger a{
	position: relative;
	display: block;
	width: 600px;
	margin: 0 auto 20px auto;
	padding: 25px 30px;
	font-size: 1.9rem;
	font-weight: 700;
	color: #FFFFFF;
	background: var(--main-color3);
	border-radius: 10.0rem;
}
.btnHanger a:last-of-type{margin: 0 auto;}
.btnHanger a::before{
	width: 8px;
	height: 8px;
	top: calc(50% - 4px);
	right: 25px;
	border-top: 2px solid #FFFFFF;
	border-right: 2px solid #FFFFFF;
	transform: rotate(45deg);
}
.btnHanger a:hover{opacity: 0.5;}
.btnHanger a:hover::before{right: 20px;}
.btnHanger.flexWrap{margin-top: 30px;}
.btnHanger.flexWrap a{
	width: calc(50% - 10px);
	margin: 20px 20px 0 0;
}
.btnHanger.flexWrap a:nth-of-type(2n){margin: 20px 0 0 0;}



/**************************************************
 aside
**************************************************/
aside{
	position: absolute;
	top: 0;
	left: 0;
	width: 280px;
	order: 1;
}

aside h2{
	height: 80px;
	font-size: 1.8rem;
	font-weight: 700;
	color: #FFFFFF;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
	-webkit-box-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	align-items: center;
}
aside h2 img{
	height: auto;
	margin-right: 10px;
}

aside nav{
	position: relative;
	border: 1px solid #999999;
	border-top: none;
	border-bottom-left-radius: 10px;
	border-bottom-right-radius: 10px;
	overflow: hidden;
}
aside > nav > ul > li{border-top: 1px solid #999999;}
aside > nav > ul > li:first-of-type{border-top: none;}
aside nav ul li span,
aside.style1 nav ul li a{
	position: relative;
	display: block;
	font-size: 1.8rem;
	font-weight: 700;
	padding: 20px 10px 20px 25px;
}
aside.style1 nav ul li a{color: var(--text-color1);}
aside nav ul li span::before,
aside.style1 nav ul li a::before{
	width: 6px;
	height: 6px;
	top: calc(50% - 3px);
	left: 8px;
	transform: rotate(45deg);
}
aside.style1 nav ul li a::before{
	border-top: 2px solid var(--main-color3);
	border-right: 2px solid var(--main-color3);
}
aside.style1 nav ul li a:hover{opacity: 0.5;}
aside.style1 nav ul li a:hover::before{left: 5px;}
aside nav ul li ul{padding-bottom: 20px;}
aside nav ul li ul li{
	font-size: 1.6rem;
	margin-top: 30px;
	padding-left: 25px
}
aside nav ul li ul li:first-of-type{margin-top: 10px;}
aside nav ul li ul li a{
	position: relative;
	display: block;
	color: var(--text-color1);
	padding-left: 10px;
}
aside nav ul li ul li a::before{
	width: 4px;
	height: 4px;
	top: calc(50% - 1px);
	left: 0;
	background: var(--text-color1);
	border-radius: 100%;
}
aside nav ul li ul li a:hover{opacity: 0.5;}

aside dl.info{
	margin-top: 20px;
	padding: 20px;
	border-radius: 10px;
	background: var(--main-color3);
}
aside dl.info dt{
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 1px;
	color: #FFFFFF;
	text-align: center;
	padding-bottom: 18px;
}
aside dl.info dt small{
	display: block;
	font-size: 1.4rem;
	font-weight: 500;
	margin-top: 10px;
}
aside dl.info dd{
	padding: 10px;
	font-size: 1.6rem;
	line-height: 1.8;
	text-align: center;
	background: #FFFFFF;
	border-radius: 7px;
}



/**************************************************
 footer
**************************************************/
footer{margin-top: 200px;}



/**************************************************
 404
**************************************************/
.notfound_image{text-align: center;}

article.notFound p{text-align: center;}


