@charset "utf-8";
/*=============================================================
 contents Layout
=============================================================*/
#contents{
	position: relative;
	padding: 140px 0 0;
}
#contents .section{
	width: 100%;
	max-width: 1500px;
	padding: 0 20px;
	margin: 0 auto;
	position: relative;
	z-index: 2;
	line-height: 1.7;
}
/* #footTrace
-------------------------------------------------------------*/
#footTrace{
	width: 100%;
	padding: 3px 20px;
	background-color: #dfe9f4;
	border-bottom: 1px solid #8d95a9;
}
#footTrace ul{
	width: 100%;
	max-width: 1460px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
}
#footTrace ul li{
	position: relative;
	font-size: 13px;
	line-height: 1.7;
}
#footTrace ul li:before{
	content: ">";
	display: inline-block;
	width: 2em;
	text-align: center;
}
#footTrace ul li:first-child:before{
	display: none;
}
#footTrace ul li a{
	text-decoration: underline;
}
/* #pageTtl
-------------------------------------------------------------*/
#pageTtl{
	width: 100%;
	height: 140px;
	display: flex;
	align-items: center;
	margin: 0;
	padding: 0px 20px 0;
	background: rgba(242,247,253,0.7);
	line-height: 1.7;
	position: absolute; 
	top: 0;
	left: 0;
	z-index: 9999;
}
#pageTtlInner{
	width: 100%;
	max-width: 1500px;
		padding: 0 20px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#pageTtl h1{
	font-size: 38px;
	color: #121738;
	transition:all 0.4s;
	line-height: 1.15;
}
#pageTtl h1.boxCenter{
	width: 100%;
	text-align: center;
}
#pageTtl ul{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}
#pageTtl ul li{
	margin: 0 0 0 30px;
}
#pageTtl ul li a{
	display: inline-block;
	position: relative;
	padding: 0 0 0 1.5em;
	font-weight: 400;
	cursor: pointer;
	color: #121738;
	font-size: 15px;
}
#pageTtl ul li a:before{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 7px 0 7px;
	border-color: #121738 transparent transparent transparent;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
@media print, screen and (min-width:1024px){
.pageFix #pageTtl{
	position: fixed;
	height: 100px;
	background: rgba(242,247,253,0.9);
	padding: 50px 20px 0px;
}
.pageFix #pageTtl h1{
	font-size: 21px;
}
}

.ttlLineDef{
	position: relative;
	margin: 70px 0 0;
	padding: 20px 0 20px;
}
.ttlLineDef:before{
	content: "";
	width: 100%;
	height: 5px;
	background-color: #efefef;
	position: absolute;
	top: 0;
	left: 0;
}
.ttlLineDef:after{
	content: "";
	width: 50px;
	height: 5px;
	background-color: #121738;
	position: absolute;
	top: 0;
	left: 0;
}
.ttlLineDef h2,
.ttlLineDef h3{
	font-size: 30px;
	color: #121738;
}








/*+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 Smartphones
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++*/
@media only screen and (max-width:1023px){
#contents{
	padding: 100px 0 0;
}
/* #pageTtl
-------------------------------------------------------------*/
#pageTtl{
	height: auto;
	padding: 0;
}
#pageTtlInner{
	display: block;
	padding: 0;
}
#pageTtl h1{
	margin: 10px 0 0;
	padding: 0 20px 10px;
	font-size: 24px;
	transition:all 0.6s ease 0.2s;
}
.pageFix #pageTtl h1{
	width: 100%;
	height: 50px;
	display: flex;
	align-items: center;
	position: fixed;
	top: 0;
	left: 0;
	margin: 50px 0 0;
	padding: 0 20px;
	background: rgba(242,247,253,0.9); 
	z-index: 3;
}
#pageTtl ul{
	margin: 0px 20px 0;
	padding: 10px 0;
	border-top: 1px solid #121738;
	flex-wrap: wrap;
	justify-content: flex-start;
}
#pageTtl ul li{
	margin: 0 10px 0 0;
}
#pageTtl ul li a{
	padding: 0 0 0 1.0em;
	font-size: 13px
}
#pageTtl ul li a:before{
	border-width: 7px 5px 0 5px;
}
	
.ttlLineDef{
	margin: 50px 0 0;
}
.ttlLineDef h2,
.ttlLineDef h3{
	font-size: 20px;
}
}
