@charset "utf-8";
/* CSS Document */

/* --------------------------------------------------------------
WRAP
-------------------------------------------------------------- */
#wrap {
	background: url("../images/top/bgTop.png"), linear-gradient(180deg,#6ABCEF 0%,#6ABCEF 994px,#fff 100px,#fff 100%);
	background-size: 1600px 412px, auto auto;
	background-repeat: repeat-x, no-repeat;
	background-position: center top 584px, center top;
}


/*__________ SP __________*/
@media screen and (max-width: 767px) {

	#wrap {
		background: url("../images/top/bgTop.png"), linear-gradient(180deg,#6ABCEF 0%,#6ABCEF 800px,#fff 100px,#fff 100%);
	background-size: 1600px 412px, auto auto;
	background-repeat: repeat-x, no-repeat;
		background-position: center top 390px, center top;
	}

}


/* --------------------------------------------------------------
HEADER,FOOTER
-------------------------------------------------------------- */
#header {
	position: relative;
}

#headerArea {
	width: 1024px;
	margin: 0 auto;
	padding: 30px 12px;
}

#headerArea p#yobousan {
	position: absolute;
	top: 20px;
	right: 10px;
	z-index: 99;
	animation: yobousanMv 4s infinite;
}

@keyframes yobousanMv {
	0% {top: 20px;}
	50% {top: 40px;}
	100% {top: 20px;}
}

#headerArea p#yobousan img {
	width: 248px;
	height: auto;
}

#headerArea h1 {
	text-align: center;
	line-height: 1;
}

#headerArea h1 img {
	width: 584px;
	height: auto;
}

#footerArea #footBanner {
	background: #6ABCEF;
}

#footerArea #footBannerArea {
	width: 1024px;
	margin: 0 auto;
	padding: 40px 12px;
}

#footerArea #footBannerArea ul {
	font-size: 0;
	text-align: center;
	margin: -20px 0 0 -20px;
}

#footerArea #footBannerArea ul li {
	font-size: 16px;
	margin: 20px 0 0 20px;
	display: inline-block;
}

#footerArea #footBannerArea ul li img {
	width: 300px;
	height: auto;
}


/*__________ TAB-SP __________*/
@media screen and (max-width: 959px) {

	#footerArea #footBannerArea {
		padding: 40px 10px;
	}

}


/*__________ TAB __________*/
@media screen and (max-width: 959px) and (min-width: 768px) {

	#headerArea {
		width: 768px;
		padding: 30px 10px;
	}

	#footerArea #footBannerArea {
		width: 768px;
	}

}


/*__________ SP __________*/
@media screen and (max-width: 767px) {

	#headerArea {
		width: auto;
		min-width: 320px;
		max-width: 520px;
		padding: 140px 10px 30px;
	}

	#headerArea p#yobousan {
		top: 10px;
	}

	#headerArea p#yobousan img {
		width: 124px;
	}

	#headerArea h1 img {
		width: 300px;
	}

	#footerArea #footBannerArea {
		width: auto;
		min-width: 320px;
		max-width: 520px;
	}

	#footerArea #footBannerArea ul {
		margin: -20px 0 0;
	}

	#footerArea #footBannerArea ul li {
		margin: 20px 0 0;
		display: block;
	}

}


/* --------------------------------------------------------------
CONTENT
-------------------------------------------------------------- */
#contentsArea {
	width: 1024px;
	margin: 0 auto;
	padding: 30px 12px;
}

#topLead {
	background: rgba(4, 70, 150, 0.6);
	border-radius: 10px;
	padding: 30px;
	font-size: 36px;
	font-weight: bold;
	line-height: 1.5;
	color: #fff;
	text-align: center;
	margin-bottom: 60px;
}

#topLead h2 {
	margin: -60px 0 20px;
}

#topLead h2 span {
	display: inline-block;
	position: relative;
}

#topLead h2 span::before, 
#topLead h2 span::after {
	content: '';
	background: url("../images/top/bgTitLead.png") no-repeat left top;
	background-size: 156px 12px;
	width: 156px;
	height: 12px;
	position: absolute;
	bottom: 0;
}

#topLead h2 span::before {
	left: -168px;
}

#topLead h2 span::after {
	right: -168px;
	transform: rotateZ(180deg);
}

#topLead h2 span img {
	width: 200px;
	height: auto;
}

#topMenu {
	background: url("../images/common/bgLine.png") no-repeat center bottom;
	background-size: 996px 12px;
	padding: 40px 0 72px;
	margin-bottom: 60px;
}

#topMenu ul {
	font-size: 0;
	text-align: center;
	margin: -40px 0 0 -140px;
}

#topMenu ul li {
	font-size: 22px;
	font-weight: bold;
	display: inline-block;
	width: 240px;
	margin: 40px 0 0 140px;
}

#topMenu ul li a {
	background: url("../images/top/bgMenu.png") no-repeat center center;
	background-size: 240px 240px;
	border-radius: 100%;
	color: #fff;
	padding: 24px;
	height: 240px;
	display: block;
	position: relative;
}

#topMenu ul li:first-child a {
	background-color: #86C188;
}

#topMenu ul li:nth-child(2) a {
	background-color: #F5B076;
}

#topMenu ul li:nth-child(3) a {
	background-color: #EF6670;
}

#topMenu ul li:nth-child(4) a {
	background-color: #86CBDC;
}

#topMenu ul li:nth-child(5) a {
	background-color: #8092CB;
}

#topMenu ul li a p.ph {
	position: absolute;
	top: -40px;
	right: 50%;
	transform: translateX(50%);
}

#topMenu ul li a p.ph img {
	width: 210px;
	height: auto;
}

#topMenu ul li a:hover p.ph img {
	filter: Alpha("opacity=100");
	opacity: 1;
	transform:rotate(-10deg);
}

#topMenu ul li a p.tit {
	width: 100%;
	position: absolute;
	right: 50%;
	bottom: 50%;
	transform: translate(50%, 50%);
	padding: 0 24px;
}

#topOther {
	text-align: center;
	margin-bottom: 40px;
}

#topOther h2 {
	font-size: 18px;
	color: #366BAB;
	margin: 20px 0 5px;
}

#topOther h2:first-child {
	margin-top: 0;
}


/*__________ TAB-SP __________*/
@media screen and (max-width: 959px) {

	#contentsArea {
		padding: 30px 10px;
	}

}


/*__________ TAB __________*/
@media screen and (max-width: 959px) and (min-width: 768px) {

	#contentsArea {
		width: 768px;
	}

	#topMenu ul {
		margin: -40px 0 0 -14px;
	}

	#topMenu ul li {
		margin: 40px 0 0 14px;
	}

}


/*__________ SP __________*/
@media screen and (max-width: 767px) {

	#contentsArea {
		width: auto;
		min-width: 320px;
		max-width: 520px;
	}

	#topLead {
		padding: 20px;
		font-size: 28px;
	}

	#topLead h2 {
		margin: -40px 0 33px;
	}

	#topLead h2 span::before, 
	#topLead h2 span::after {
		background-size: 78px 6px;
		width: 78px;
		height: 6px;
		position: absolute;
		bottom: -13px;
	}

	#topLead h2 span::before {
		left: -53px;
	}

	#topLead h2 span::after {
		right: -53px;
	}

	#topLead h2 span img {
		width: 140px;
	}

	#topMenu ul {
		margin: -50px 0 0;
	}

	#topMenu ul li {
		display: block;
		margin: 50px auto 0;
	}

}


/* --------------------------------------------------------------
TOPPAGE END
-------------------------------------------------------------- */
#topBg {
	background: #6ABCEF;
}

#topHeaderArea {
	position: relative;
}

#topHeaderArea p#yobousan {
	position: absolute;
	top: 20px;
	right: 50%;
	transform: translateX(50%);
	z-index: 99;
	animation: yobousanMv 4s infinite;
}

#topHeaderArea p#yobousan img {
	width: 248px;
	height: auto;
}

#topHeaderArea #headMainEnd {
	padding: 260px 0 50px;
	margin: 0 auto;
	width: 100%;
	max-width: 768px;
	font-size: 26px;
	color: #fff;
	text-align: center;
}

#topHeaderArea #headMainEnd h1 {
	font-size: 48px;
	margin-bottom: 30px;
	line-height: 1.5;
}


/*__________ SP __________*/
@media screen and (max-width: 767px) {

	#topHeaderArea p#yobousan {
		top: 10px;
	}

	#topHeaderArea p#yobousan img {
		width: 124px;
	}

	#topHeaderArea #headMainEnd {
		padding: 150px 10px 30px;
		font-size: 20px;
	}

	#topHeaderArea #headMainEnd h1 {
		font-size: 32px;
		margin-bottom: 25px;
	}

}