@charset "utf-8";
/* -------------------------------
FONT
------------------------------- */
html { font-size: 62.5%; }
body {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.8;
	font-size: 16px;
	font-size: 1.6rem;
	color: #000;
}
/* -------------------------------
LAYOUT
------------------------------- */
* {
	word-break: break-all;
	word-wrap: break-word;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
html,
body {
	height: 100%;
}
html { -webkit-text-size-adjust: 1; }
#container {
	width: 100%;
	min-height: 100%;
	height: auto !important;
	height: 100%;
	position: relative;
	margin: 0 auto;
	background: #e9eff2;
	overflow-anchor: none;
}
@media screen and (max-width: 768px){
	#container {
		overflow-x: hidden;
	}
}
.sp {
	display: none;
}
/* -------------------------------
FONT
------------------------------- */
/* -------------------------------
FONT
------------------------------- */
.font_mb_l{font-family: "ゴシックMB101 L",Gothic MB101 Light !important;}
.font_mb_r{font-family: "ゴシックMB101 R",Gothic MB101 Regular !important;}
.font_mb_m{font-family: "ゴシックMB101 M",Gothic MB101 Medium !important;}
.font_mb_b{font-family: "ゴシックMB101 B",Gothic MB101 Bold !important;}
.font_arial{font-family: Arial !important;}
.font_arial_n{font-family: Arial Narrow !important;}
/* -------------------------------
COLOR
------------------------------- */
.red { color: #ff0000; }
.yellow { color: #FFF01F; }
.orange { color: #fe6600; }
/* -------------------------------
COMMON PARTS
------------------------------- */
/* font-size */
.fs10 { font-size: 1.0rem !important; }
.fs11 { font-size: 1.1rem !important; }
.fs12 { font-size: 1.2rem !important; }
.fs13 { font-size: 1.3rem !important; }
.fs14 { font-size: 1.4rem !important; }
.fs15 { font-size: 1.5rem !important; }
.fs16 { font-size: 1.6rem !important; }
.fs17 { font-size: 1.7rem !important; }
.fs18 { font-size: 1.8rem !important; }
.fs19 { font-size: 1.9rem !important; }
.fs20 { font-size: 2.0rem !important; }
.fs21 { font-size: 2.1rem !important; }
.fs22 { font-size: 2.2rem !important; }
.fs23 { font-size: 2.3rem !important; }
.fs24 { font-size: 2.4rem !important; }
.fs25 { font-size: 2.5rem !important; }
.fs26 { font-size: 2.6rem !important; }
/* link */
a {
	color: #777;
	outline: none !important;
	text-decoration: none;
}
a:visited {
	color: #777;
	text-decoration: none;
}
a:hover {
	color: #999;
	text-decoration: underline;
}
a:active { }
/* bold */
.bold { font-weight: bold; }
/* img */
img { vertical-align: bottom; }
img[usemap] {
    max-width: 100%;
    height: auto;
}
/* margin */
.mb0 { margin-bottom: 0rem !important; }
.mb1 { margin-bottom: 0.1rem !important; }
.mb2 { margin-bottom: 0.2rem !important; }
.mb3 { margin-bottom: 0.3rem !important; }
.mb4 { margin-bottom: 0.4rem !important; }
.mb5 { margin-bottom: 0.5rem !important; }
.mb6 { margin-bottom: 0.6rem !important; }
.mb7 { margin-bottom: 0.7rem !important; }
.mb8 { margin-bottom: 0.8rem !important; }
.mb9 { margin-bottom: 0.9rem !important; }
.mb10 { margin-bottom: 1.0rem !important; }
.mb11 { margin-bottom: 1.1rem !important; }
.mb12 { margin-bottom: 1.2rem !important; }
.mb13 { margin-bottom: 1.3rem !important; }
.mb14 { margin-bottom: 1.4rem !important; }
.mb15 { margin-bottom: 1.5rem !important; }
.mb20 { margin-bottom: 2.0rem !important; }
.mb25 { margin-bottom: 2.5rem !important; }
.mb30 { margin-bottom: 3.0rem !important; }
.mb35 { margin-bottom: 3.5rem !important; }
.mb40 { margin-bottom: 4.0rem !important; }
.mb45 { margin-bottom: 4.5rem !important; }
.mb50 { margin-bottom: 5.0rem !important; }
.mt0 { margin-top: 0rem !important; }
.mt1 { margin-top: 0.1rem !important; }
.mt2 { margin-top: 0.2rem !important; }
.mt3 { margin-top: 0.3rem !important; }
.mt4 { margin-top: 0.4rem !important; }
.mt5 { margin-top: 0.5rem !important; }
.mt6 { margin-top: 0.6rem !important; }
.mt7 { margin-top: 0.7rem !important; }
.mt8 { margin-top: 0.8rem !important; }
.mt9 { margin-top: 0.9rem !important; }
.mt10 { margin-top: 1.0rem !important; }
.mt11 { margin-top: 1.1rem !important; }
.mt12 { margin-top: 1.2rem !important; }
.mt13 { margin-top: 1.3rem !important; }
.mt14 { margin-top: 1.4rem !important; }
.mt15 { margin-top: 1.5rem !important; }
.mt20 { margin-top: 2.0rem !important; }
.mt25 { margin-top: 2.5rem !important; }
.mt30 { margin-top: 3.0rem !important; }
.mt35 { margin-top: 3.5rem !important; }
.mt40 { margin-top: 4.0rem !important; }
.mt45 { margin-top: 4.5rem !important; }
.mt50 { margin-top: 5.0rem !important; }
.ml5 { margin-left: 0.5rem !important; }
.ml10 { margin-left: 1.0rem !important; }
.ml15 { margin-left: 1.5rem !important; }
.ml20 { margin-left: 2.0rem !important; }
.ml25 { margin-left: 2.5rem !important; }
.ml30 { margin-left: 3.0rem !important; }
.mr5 { margin-right: 0.5rem !important; }
.mr10 { margin-right: 1.0rem !important; }
.mr15 { margin-right: 1.5rem !important; }
.mr20 { margin-right: 2.0rem !important; }
.mr25 { margin-right: 2.5rem !important; }
.mr30 { margin-right: 3.0rem !important; }
/* padding */
.p1 { padding: 0.1rem !important; }
.p2 { padding: 0.2rem !important; }
.p3 { padding: 0.3rem !important; }
.p4 { padding: 0.4rem !important; }
.p5 { padding: 0.5rem !important; }
.p6 { padding: 0.6rem !important; }
.p7 { padding: 0.7rem !important; }
.p8 { padding: 0.8rem !important; }
.p9 { padding: 0.9rem !important; }
.p10 { padding: 1.0rem !important; }
.p15 { padding: 1.5rem !important; }
.p20 { padding: 2.0rem !important; }
.pb0 { padding-bottom: 0rem !important; }
.pb1 { padding-bottom: 0.1rem !important; }
.pb2 { padding-bottom: 0.2rem !important; }
.pb3 { padding-bottom: 0.3rem !important; }
.pb4 { padding-bottom: 0.4rem !important; }
.pb5 { padding-bottom: 0.5rem !important; }
.pb6 { padding-bottom: 0.6rem !important; }
.pb7 { padding-bottom: 0.7rem !important; }
.pb8 { padding-bottom: 0.8rem !important; }
.pb9 { padding-bottom: 0.9rem !important; }
.pb10 { padding-bottom: 1.0rem !important; }
.pb11 { padding-bottom: 1.1rem !important; }
.pb12 { padding-bottom: 1.2rem !important; }
.pb13 { padding-bottom: 1.3rem !important; }
.pb14 { padding-bottom: 1.4rem !important; }
.pb15 { padding-bottom: 1.5rem !important; }
.pb20 { padding-bottom: 2.0rem !important; }
.pb25 { padding-bottom: 2.5rem !important; }
.pb30 { padding-bottom: 3.0rem !important; }
.pt0 { padding-top: 0rem !important; }
.pt1 { padding-top: 0.1rem !important; }
.pt2 { padding-top: 0.2rem !important; }
.pt3 { padding-top: 0.3rem !important; }
.pt4 { padding-top: 0.4rem !important; }
.pt5 { padding-top: 0.5rem !important; }
.pt6 { padding-top: 0.6rem !important; }
.pt7 { padding-top: 0.7rem !important; }
.pt8 { padding-top: 0.8rem !important; }
.pt9 { padding-top: 0.9rem !important; }
.pt10 { padding-top: 1.0rem !important; }
.pt11 { padding-top: 1.1rem !important; }
.pt12 { padding-top: 1.2rem !important; }
.pt13 { padding-top: 1.3rem !important; }
.pt14 { padding-top: 1.4rem !important; }
.pt15 { padding-top: 1.5rem !important; }
.pt20 { padding-top: 2.0rem !important; }
.pt25 { padding-top: 2.5rem !important; }
.pt30 { padding-top: 3.0rem !important; }
.pl5 { padding-left: 0.5rem !important; }
.pl10 { padding-left: 1.0rem !important; }
.pl15 { padding-left: 1.5rem !important; }
.pl20 { padding-left: 2.0rem !important; }
.pl25 { padding-left: 2.5rem !important; }
.pl30 { padding-left: 3.0rem !important; }
.pr5 { padding-right: 0.5rem !important; }
.pr10 { padding-right: 1.0rem !important; }
.pr15 { padding-right: 1.5rem !important; }
.pr20 { padding-right: 2.0rem !important; }
.pr25 { padding-right: 2.5rem !important; }
.pr30 { padding-right: 3.0rem !important; }
/* text-align */
.alignCenter { text-align: center !important; }
.alignLeft { text-align: left !important; }
.alignRight { text-align: right !important; }
/* float */
.floatLeft { float: left; }
.floatRight { float: right; }
/* display */
.dispInlineBlock { display: inline-block; }
.dispInline { display: inline; }
.dispBlock { display: block; }
.dispNone { display: none; }
/* hr */
hr {
	display: block;
	margin: 0;
	padding: 0;
	border: none;
}
/* clear */
.clear { clear: both;}
/* clearfix */
.clearfix { min-height: 1%; }
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.linkBox { cursor: pointer; }

::-webkit-input-placeholder {
 color: #b2b2b2;
}
:-ms-input-placeholder {
 color: #b2b2b2;
}
::-moz-placeholder {
 color: #b2b2b2;
}

@media screen and (max-width: 991px){
html {
	min-width: 100%;
}
body {
	min-width: 100%;
	overflow-x: hidden;
}
}
/* -------------------------------
HEADER
------------------------------- */
header{
	width: 100%;
	height: 120px;
	background: #fff;
	z-index: 100;
	position: fixed;
	top: 0;
}
header .inn {
	width: 100%;
	max-width: 1200px;
	height: 100%;
	padding: 15px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
}
header .logo {
	display: flex;
	align-items: center;
}
header #navBtn {
	display: none;
}
@media screen and (max-width: 768px){
	header{
		height: 70px;
	}
	header .logo img {
		width: 9rem;
	}
	header #navBtn {
		cursor: pointer;
		display: block;
		padding: 24px 16px;
		position: absolute;
		bottom: 0;
		right: 0;
		top: 0;
		width: 60px;
	}
 	header #navBtn span {
		display: block;
		height: 4px;
		width: 100%;
		background: #666;
		border-radius: 2px;
		transition: all 0.5s ease;
	}
	header #navBtn span:nth-of-type(2),
	header #navBtn span:nth-of-type(3) {
		margin-top: 5px;
	}
	header.open #navBtn span:nth-of-type(1) {
		-webkit-transform: translateY(9px) translateX(0) rotate(45deg);
		transform: translateY(9px) translateX(0) rotate(45deg);
	}
	header.open #navBtn span:nth-of-type(2) {
		margin-top: 5px;
		opacity: 0;
		-webkit-transform: translateY(9px);
		transform: translateY(9px);
	}
	header.open #navBtn span:nth-of-type(3) {
		-webkit-transform: translateY(-9px) translateX(0) rotate(-45deg);
		transform: translateY(-9px) translateX(0) rotate(-45deg);
	}
	#bgModal {
		display: none;
		background: rgba(0, 0, 0, 0.6);
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 10;
	}
}
/* -------------------------------
GNAV
------------------------------- */
#gnav {
	flex: 1;
	margin-left: 20%;
	display: flex;
}
#gnav ul {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	width:100%;
}
#gnav ul li {
	display: flex;
	align-items: stretch;
}
#gnav ul li a{
	display: flex;
	align-items:center;
	position: relative;
}
#gnav ul li a::after {
	content: "";
	display: block;
	height: 3px;
	width: 100%;
	bottom: 0;
	left: 0;
	right: 0;
	position: absolute;
	background: #0C328C;
	transform: scaleX(0);
	transition: all 0.2s ease;
}
#gnav ul li a:hover::after {
	transform: scaleX(1);
}
#gnav ul li a img {
	height: 4.1rem;
}
@media screen and (max-width: 768px){
	#gnav { 
		position: absolute;
		width: 100%;
		top: 70px;
		left: 100%;
		transition: all 0.4s ease;
		margin-left: 0;
	}
	header.open #gnav {
		left:0;
	}
	#gnav > ul {
		display: flex;
		justify-content: flex-start;
		flex-direction:column;
		flex-wrap: wrap;
		margin-top: 0px;
		width: 100%;
		background: #fff;
	}
	#gnav > ul > li {
		width: 100%;
		position: relative;
		border-top: 1px solid #ccc;
		padding: 0;
	}
	#gnav > ul > li > a {
		color: #4B4948;
		display: flex;
		position: relative;
		padding: 10px;
		text-decoration: none;
		width: 100%;
	}
	#gnav ul li a::after {
		display: none;
	}
	#gnav > ul > li > a::before {
        content:attr(data-label);
    }
	#gnav > ul > li > a img {
        display:none;
    }
}
/* -------------------------------
TITLE
------------------------------- */
h1.title {
	height: 30rem;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 120px;
	font-size: 7.2rem;
	font-family: "ゴシックMB101 L",Gothic MB101 Light;
	text-shadow: 0 0 5px rgba(255,255,255,1),0 0 5px rgba(255,255,255,1),0 0 5px rgba(255,255,255,1);
}
@media screen and (max-width: 768px){
	h1.title {
		height: 14rem;
		margin-top: 70px;
		font-size: 3.6rem;
	}
}

/* -------------------------------
CONTENTS
------------------------------- */
#contents {
	width: 100%;
	max-width: 120rem;
	margin: 0 auto;
	padding: 12.5rem 1.5rem;
	overflow-anchor: none;
}
#contents .contArea {
	position: relative;
	margin-top: 10rem;
	overflow-anchor: none;
}
#contents .contArea:first-child {
	margin-top: 0;
}
#contents .contArea .txt {
	background: #fff;
	padding: 4.0rem;
	position: absolute;
	display: flex;
	flex-direction: column;
}
#contents .contArea .txt h2 {
	font-size: 4.8rem;
	line-height: 1;
	align-self: stretch;
	font-family: 'Roboto Slab', serif; 
}
#contents .contArea .txt h3 {
	font-size: 2.4rem;
	line-height: 1;
	margin-top: 1.0rem;
	align-self: stretch;
	font-family: "ゴシックMB101 L",Gothic MB101 Light;
}
#contents .contArea .txt h3 span {
	display: inline-block;
	margin-bottom: 0.5rem;
}
#contents .contArea .txt h3 span::after {
	content: "、";
}
#contents .contArea .txt h3 span:last-child::after {
	content: "";
}

#contents .contArea .txt p {
	font-size: 1.6rem;
	line-height: 1.8;
	margin-top: 2.0rem;
	align-self: stretch;
	overflow-y: auto;
}
#contents .contArea .txt .btn {
	align-self: stretch;
	text-align: center;
	margin-top: auto;
}
#contents .contArea .txt .btn a {
	display: inline-block;
	width: 20rem;
	height: 4rem;
	color: #fff;
	font-size: 1.8rem;
	line-height: 4rem;
	background: #9d9d9d;
	border-radius: 2rem;
	text-decoration: none;
	text-align: center;
	transition: all 0.2s ease;
}
#contents .contArea .txt .btn a:hover {
	background: #0C328C;
}
#contents .contArea .txt .btn a::after {
	content:"";
	display: inline-block;
	width: 1.05rem;
	height: 1.15rem;
	background: url(../images/ico_arrow01.png) no-repeat center center / contain;
	margin-left: 1rem;
	transition: all 0.2s ease;
}
#contents .contArea .txt .btn a:hover::after {
	transform: translateX(3px)
}
#contents .contArea .pic {
	padding-top: 5.0rem;
}
@media screen and (max-width: 768px){
	#contents {
		padding: 4rem 1.5rem;
	}
	#contents .contArea {
		margin-top: 4rem;
	}
	#contents .contArea .txt {
		padding: 2rem;
		position: relative;
		display: flex;
		flex-direction: column;
	}
	#contents .contArea .txt {
		width: 100% !important;
		height: auto !important;
	}
	#contents .contArea .txt h2 {
		font-size: 3.2rem;
	}
	#contents .contArea .txt h3 {
		font-size: 2.0rem;
	}
	#contents .contArea .txt p {
		line-height: 1.6;
		margin-top: 2.0rem;
	}
	#contents .contArea .txt .btn {
		align-self: stretch;
		text-align: center;
		margin-top: 2rem;
	}
	#contents .contArea .txt .btn a {
		background: #0C328C;
		transition: none;
	}
	#contents .contArea .txt .btn a::after {
		transition: none;
	}
	#contents .contArea .txt .btn a:hover::after {
		transform: translateX(0)
	}
	#contents .contArea .pic {
		padding-top: 0;
	}
	#contents .contArea .pic img {
		width: 100%;
	}
	
}

/* -------------------------------
FOOTER
------------------------------- */
footer {
	width: 100%;
	border-top: 1px solid #666;	
	margin-top: 8rem;
}
footer #contact {
	padding: 8rem 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
footer #contact h2 {
	font-size: 4.8rem;
	line-height: 1;
	text-align: center;
	font-family: 'Roboto Slab', serif;
}
footer #contact h3 {
	font-size: 2.4rem;
	line-height: 1;
	margin-top: 1.0rem;
	text-align: center;
	font-family: "ゴシックMB101 L",Gothic MB101 Light;
}
footer #contact p {
	margin-top: 5rem;
}
footer #contact address {
	margin-top: 3rem;
}
footer #contact address a {
	font-size: 2.4rem;
	font-weight: bold;
	pointer-events: none;
	color: #333;
}
footer #fnav {
	height: 6rem;
	line-height: 6rem;
	background: #1e287e;
}
footer #fnav ul {
	display: flex;
	justify-content: center;
}
footer #fnav ul li {
	margin: 0 2rem;
}
footer #fnav ul li a {
	color: #fff;
	font-family: "ゴシックMB101 L",Gothic MB101 Light;
}
footer #copyright {
	background: #0e3589;
	padding: 4rem 0 1.5rem;
	display: flex;
	justify-content: center;
	flex-direction: column;
}
footer #copyright .logo {
	width: 8.7rem;
	margin:  0 auto;
	flex: none;
}
footer #copyright .logo img {
	width: 100%;
	fill: #fff;
}
footer #copyright small {
	font-size: 1.4rem;
	color: #fff;
	font-family: Arial;
	margin-top: 1.5rem;
	text-align: center;
}
@media screen and (max-width: 768px){
	footer {
		margin-top: 4rem;
	}
	footer #contact {
		padding: 3rem 1.5rem;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	footer #contact h2 {
		font-size: 3.2rem;
	}
	footer #contact h3 {
		font-size: 2.0rem;
	}
	footer #contact p {
	}
	footer #contact address {
		text-align: center;
	}
	footer #contact address a {
		font-size: 2.8rem;
		pointer-events: auto;
	}
	footer #contact address a::after {
		content: "\A";
		white-space: pre;		
	}
	
	footer #fnav {
		height: 6rem;
		line-height: 6rem;
	}
	footer #fnav ul {
		display: flex;
		justify-content: center;
	}
	footer #fnav ul li {
		margin: 0 2rem;
	}
	footer #fnav ul li a {
		color: #fff;
		font-family: "ゴシックMB101 L",Gothic MB101 Light;
	}
	footer #copyright {
		padding: 4rem 0 1.5rem;
		display: flex;
		justify-content: center;
		flex-direction: column;
	}
	footer #copyright .logo {
		width: 8.7rem;
		margin:  0 auto;
	}
	footer #copyright .logo img {
		width: 100%;
	}
	footer #copyright small {
		font-size: 1.4rem;
		color: #fff;
		font-family: Arial;
		margin-top: 1.5rem;
		text-align: center;
	}
}

@media screen and (max-width: 768px){
/*--------------------------------------
SP
---------------------------------------*/
}
