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

@charset "utf-8";

@media screen and (max-width:1280px) {}
@media screen and (max-width:1024px) {}
@media screen and (max-width:896px) {}
@media screen and (max-width:480px) {}

/*******************************************************
	General
*******************************************************/
* {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-style: normal;
}

html {
	font-size: 10px;
	line-height: 10px;
}

body {
	width: 100%;
	color: #000;
}

html,
body {
	scroll-padding-top: 0px;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

a:hover img {
	opacity: .7;
}

/* PC SP 表示切替 */
.pc_only {
	display: inline-block;
}
.sp_only {
	display: none;
}
@media screen and (max-width:480px) {
	.pc_only {
		display: none;
	}
	.sp_only {
		display: inline-block;
	}
}




/*******************************************************
	Header
*******************************************************/

/* #site_header */
#site_header {
	width: 100%;
 	border-top: 10px solid #2660e4;
}
	@media screen and (max-width:480px) {
		#site_header {
		 	border-top: 5px solid #2660e4;
		 }
	}

/* #site_header .contents */
#site_header .contents {
	display: flex;
	width: auto;
	max-width: 1400px;
	height: 84px;
	margin: 0 auto;
	padding: 0 40px;
}
	@media screen and (max-width:1280px) { 
		#site_header .contents {
			display: block;
			position: relative;
			width: 100%;
			height: 124px;
		}
	}
	@media screen and (max-width:896px) {
		#site_header .contents {
			position: static;
			height: auto;
		}
	}

/* #site_header .contents h1 */
#site_header .contents h1 {
	width: 346px;
	height: 54px;
	margin: 15px 0;
}
#site_header .contents h1 img {
	width: 100%;
	height: 100%;
}
	@media screen and (max-width:1280px) {
		#site_header .contents h1 {
			position: absolute;
			top: 15px;
			left: 40px;
			margin: 0;
		}
	}
	@media screen and (max-width:896px) {
		#site_header .contents h1 {
			position: static;
			width: 80%;
			height: auto;
			margin: 15px auto;
		}
		#site_header .contents h1 img {
			height: auto;
		}
	}

#site_header .contents nav {
	width: calc( 100% - 536px );
	font-size: 1.6rem;
	line-height: 1.6rem;
	padding: 28px 0 0;
	color: #163580;
}
	@media screen and (max-width:1280px) {
		#site_header .contents nav {
			position: absolute;
			top: 84px;
			left: 40px;
			width: calc( 100% - 80px );
			padding: 0;
		}
	}
	@media screen and (max-width:896px) {
		#site_header .contents nav {
			display: none;
		}
	}

#site_header .contents nav ul {
	list-style: none;
	display: flex;
	justify-content: center;
}
#site_header .contents nav ul li {
	margin: 0px;
	padding: 0px;
}
#site_header .contents nav ul li.nav_btn {
	margin: 0 10px;
}
#site_header .contents nav ul li a {
	display: block;
	padding: 5px 0;
	color: #163580;
	text-decoration: none;
}
#site_header .contents nav ul li a:hover {
	border-bottom: 2px solid #163580;
}

.youtube {
	display: block;
	width: 194px;
	height: 74px;
	padding: 5px 20px;
	color: #000;
	text-align: center;
	text-decoration: none;
}
.youtube img {
	width: 144px;
	height: 34px;
	margin-bottom: 3px;
}
	@media screen and (max-width:1280px) {
		.youtube {
			position: absolute;
			top: 0;
			right: 40px;
		}
	}
	@media screen and (max-width:896px) {
		.youtube {
			display: none;
		}
	}

.hamburger {
	display: none !important;
}
	@media screen and (max-width:896px) {
		.hamburger {
			display: block !important;
		}
	}

.side_fix {
	display: block;
	position: fixed;
	top: 150px;
	right: 0;
	width: 60px;
	height: 250px;
	background-color: #fff;
	z-index: 100;
}
	@media screen and (max-width:480px) {
		.side_fix {
			display: none;
		}
	}





/*******************************************************
	Footer
*******************************************************/
#site_footer {
	width: 100%;
	border-top: 5px solid #2660e4;
	background-color: #2660e4;
}
#site_footer .footer_line {
	width: 100%;
	border-top: 3px solid #80b5db;
	background-color: #2660e4;
}


#site_footer .contents {
	display: flex;
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 40px;
	color: #fff;
}
	@media screen and (max-width:1280px) { 
		#site_footer .contents {
			display: block;
			width: 100%;
			margin: 0 auto;
			padding: 0;
			text-align: center;
		}
	}
	@media screen and (max-width:896px) {
		#site_footer .contents {
			padding: 30px 0;
		}
	}

#site_footer .contents #footer-logo {
	width: 346px;
	height: 54px;
	margin: 15px 0;
}
#site_footer .contents #footer-logo img {
	width: 100%;
	height: 100%;
}
	@media screen and (max-width:1280px) {
		#site_footer .contents #footer-logo {
			margin: 15px auto;
		}
	}
	@media screen and (max-width:896px) {
		#site_footer .contents #footer-logo {
			margin: 0 auto;
		}
	}
	@media screen and (max-width:480px) {
		#site_footer .contents #footer-logo {
			width: 80%;
			height: auto;
			margin: 0 auto;
		}
	}

#site_footer .contents nav {
	width: calc( 100% - 346px );
	font-size: 1.6rem;
	line-height: 1.6rem;
	padding: 28px 0 0;
	color: #fff;
}
#site_footer .contents nav ul {
	list-style: none;
	display: flex;
	justify-content: flex-end;
}
#site_footer .contents nav ul li {
	margin: 5px;
	padding: 0px;
	border-right: 1px solid #fff;
}
#site_footer .contents nav ul li:last-child {
	border-right: none;
}
#site_footer .contents nav ul li.nav_btn {
	margin: 0;
}
#site_footer .contents nav ul li a {
	display: block;
	margin: 0 10px;
	padding: 5px;
	color: #fff;
	text-decoration: none;
}
#site_footer .contents nav ul li a:hover {
	text-decoration: underline;
}
	@media screen and (max-width:1280px) {
		#site_footer .contents nav {
			width: 100%;
			padding: 0 0 30px;
		}
		#site_footer .contents nav ul {
			justify-content: center;
		}
	}
	@media screen and (max-width:896px) {
		#site_footer .contents nav {
			display: none;
		}
	}

.copy {
	margin: 15px 0;
	text-align: center;
	font-size: 1.2rem;
	line-height: 1.2rem;
}
	@media screen and (max-width:1280px) {
		.copy {
			margin: 15px 0;
			text-align: center;
			font-size: 1.2rem;
			line-height: 1.2rem;
		}
	}



/*******************************************************
	Topへ戻る
*******************************************************/
.goto_top {
	position: fixed;
	display: inline-block;
	bottom: -81px;
	right: 20px;
	padding: 10px;
	transition: .5s;
	background-color: rgba(0, 0, 0, .5);
}
.goto_top img {
	width: 42px;
	height: 51px;
}
.goto_top.hide {
	transform: translateY(-101px);
}



/*******************************************************
	Container
*******************************************************/
#container {
	width: 100%;
	font-size: 1.6rem;
	line-height: 2.1rem;
}



/*******************************************************
	Page header
*******************************************************/
.page_header {
	width: 100%;
	height: 155px;
	padding-top: 60px;
	background-color: #def5fb;
	background-image: url(../images/common/page_header_bg.png);
	background-position: center bottom;
	background-repeat: repeat-x;
	background-size: 728px 122px;
	font-size: 3.6rem;
	line-height: 3.6rem;
	font-weight: 700;
	color: #163580; 
}
@media only screen and (-webkit-min-device-pixel-ratio: 2) {
	#header-inner nav ul li a {
		background-image: url("../images/common/page_header_bg@2x.png");
	}
}
	@media screen and (max-width:480px) {
		.page_header {
			font-size: 7.0vw;
			line-height: 7.0vw;
		}
	}

section {
	width: 100%;
	padding: 80px 0;
	margin: 0;
	text-align: center;
}

p {
	line-height: 2em;
}

#title_head {
	padding: 0;
	line-height: 0.1em;
}
#title_head img {
	width: 100%;
	height: auto;
}

.pankuzu {
	background-color: #163580;
	color: #fff;
	font-size: 13px;
	line-height: 1em;
	padding: 3px 0;
}
.pankuzu p {
	width: 90%;
	padding: 0;
	margin: 0 auto;
	max-width: 1100px;
	text-align: left;
	line-height: 1em;
}
.pankuzu a {
	color: #fff;
	text-decoration: none;
	text-align: center;
}















