@charset "UTF-8";



/* FONT size
---------------------------------------------------------------------
[ px ]	[ % ]
10px 	72  %		19px 	136 %
11px 	79  %		20px 	143 %
12px 	86 %		21px 	150 %
13px 	93 %		22px 	158 %
14px 	100 %		23px 	165 %
15px 	108 %		24px 	172 %
16px 	115 %		25px 	179 %
17px 	122 %		26px 	186 %
18px 	129 %
---------------------------------------------------------------------*/




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 共通項目 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
*{margin:0;padding:0;text-decoration:none}fieldset{border:0}body{line-height:1.8;font-size:88%}body,dd,dl,dt,form,h1,h2,h3,h4,h5,h6,input,li,ol,p,select,ul{margin:0;padding:0}img{border:0;vertical-align:top}a{text-decoration:none}em{font-style:normal}ul li{list-style-type:none;list-style-image:none}address{font-style:normal}



/* マージン */
.margin02 {	margin-bottom: 2px; }
.margin05 {	margin-bottom: 5px; }
.margin06 {	margin-bottom: 6px; }
.margin08 {	margin-bottom: 8px; }
.margin10 {	margin-bottom: 10px; }
.margin15 {	margin-bottom: 15px; }
.margin20 {	margin-bottom: 20px; }
.margin30 {	margin-bottom: 30px; }
.margin40 {	margin-bottom: 40px; }


/* 文字装飾 */
strong {
	font-weight: bold;
}

ul {
	
}
	ul li {
		list-style:none;	
	}


/* float解除 */
.cbox { 
}
* html .cbox {
	zoom: 100%;
}
*:first-child+html .cbox {
	display: inline-block;
}
.cbox:after {
	content: "."; 
	clear: both; 
	height: 0; 
	display: block; 
	visibility: hidden;
}


/* box-sizing */ 
* {
	box-sizing: border-box;
}



/* sp */ 
.sp {
	display: none;
}



/* リンク */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
a {
	color: #231815;
	text-decoration: none;
}


/* テキスト装飾 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 小文字 */
.cap {
	line-height: 1.5;
	font-size: 86%;
}

/* インデント */
.indent {
	text-indent: -14px;
}



/* 横幅 */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
body {
	font-family: 'Noto Sans JP','Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
	font-weight: 500;
	color: #231815;
	padding: 0;
	margin: 0;
	letter-spacing: 3px;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	font-feature-settings: "palt";
	text-justify: inter-ideograph;
	-ms-text-justify: inter-ideograph;
}




/* フォント */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.en {
	font-family: 'Hammersmith One', sans-serif;
	font-weight: 400;
}




/* flex */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
.flex {
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.flex-start {
	display: flex;
	display: -webkit-flex;
	justify-content: space-between;
}
.flex-end {
	display: flex;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	 -ms-flex-direction: row-reverse;
		 flex-direction: row-reverse;
}
.flex-center {
	display: flex;
	justify-content: center;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}




/* particles-js */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#particles-js {
	width: 100%;
	height: 100%;
	position: fixed;
	z-index: -1;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header {
}
	#header .logo {
		position: absolute;
		top: 30px;
		left: 30px;
		z-index: 100001;
		color: #fff;
	}
		#header .logo span {
			width: 350px;
			display: block;
			font-size: 14px;
			line-height: 35px;
			padding-left: 20px;
			letter-spacing: 2px;
			position: absolute;
			top: 0;
			left: 150px;
		}


	#header ul {
		position: fixed;
		top: 17px;
		right: 84px;
		z-index: 10000;
	}
		#header ul li {
			width: 120px;
			margin-right: 10px;
		}
			#header ul li a {
				display: flex;
				justify-content: center;
				align-items: center;
				font-size: 12px;
				font-weight: 700;
				height: 46px;
				text-align: center;
				letter-spacing: 0.1em;
				transition: 0.3s;
				-webkit−transition: 0.3s;
			}
			#header ul li.intern a {
				background: #d7f0fc;
			}
			#header ul li.mypage a {
				background: #00a0f7;
				color: #fff;
			}
			#header ul li.entry a {
				background: #00a0f7;
				color: #fff;
			}
			#header ul li.career a {
				background: #fff;
				border: solid 1px #000;
			}
			#header ul li a.active {
				background: #000;
				color: #fff;
				border: none;
			}
			#header ul li a:hover {
				background: #000;
				color: #fff;
				border: none;
				letter-spacing: 0.13em;
			}

			#header ul li .sublist {
				display: none;
				position: static;
			}
				#header ul li .sublist li a {
					background: #fff;
					color: #000;
					border: solid 1px #000;
					border-top: none;
					letter-spacing: 0;
				}
				#header ul li .sublist li a:hover {
					background: #fff;
					color: #000;
					border: solid 1px #000;
					border-top: none;
					opacity: 0.7;
				}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ナビゲーション */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#nav {
	width: 80px;
	height: 100%;
	background: #000;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10000;
}
	#nav ul.sns {
		width: 80px;
		position: fixed;
		top: 50%;
		right: 0;
		margin-top: -17.5px;
	}
		#nav ul.sns li {
			margin-bottom: 20px;
		}
		#nav ul.sns li:nth-child(2) {
			margin-bottom: 0;
		}
			#nav ul.sns li a {
				display: block;
				text-align: center;
			}


	#nav .scroll {
		width: 80px;
		position: fixed;
		bottom: 20px;
		right: 0;
	}
		#nav .scroll {
			display: block;
			text-align: center;
		}
			#nav .scroll a.top {
				display: none;
				position: absolute;
				bottom: 0;
				left: 0;
			}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */

/* main */
#main {
	display: block;
}
.inner {
	width: 1280px;
	margin: 0 auto;
	padding-right: 80px;
	position: relative;
}

	
	
/* title  */
.title {
	padding-bottom: 80px;
}
	.title .en {
		font-size: 158%;
		color: #00a0f7;
		line-height: 1;
		padding-bottom: 15px;
	}

	.title h2 {
		font-size: 38px;
		line-height: 1;
	}

 
	
/* tag */
ul.tag {
}
	ul.tag li {
		margin-right: 5px;
	}
	ul.tag li:nth-last-child(1) {
		margin-right: 0;
	}
		ul.tag li a {
			display: block;
			font-size: 86%;
			letter-spacing: 1px;
		}
			ul.tag li a span {
				background: #d7f0fc;
				border-radius: 30px;
				line-height: 30px;
				padding: 5px 10px;
				transition: 0.3s;
				-webkit−transition: 0.3s;
			}
			ul.tag li a:hover span {
				background: #00a0f7;
				color: #fff;
			}

 
	
/* btn */
.btn {
	width: 250px;
}
	.btn a {
		display: block;
		height: 60px;
		line-height: 64px;
		font-size: 115%;
		background: #00a0f7;
		color: #fff;
		text-align: center;
		position: relative;
		transition: 0.3s;
		-webkit−transition: 0.3s;
	}
	.btn a:hover {
		background: #000;
		color: #fff;
		letter-spacing: 5px;
	}

	.btn a:after {
		content: "";
		width: 41px;
		height: 10px;
		position: absolute;
		right: -18px;
		top: 50%;
		margin-top: -8px;
		transition: 0.3s;
		-webkit−transition: 0.3s;
	}
	.btn.black a:after {
		background: url(../img/arrow_black.svg) no-repeat;
	}
	.btn.white a:after {
		background: url(../img/arrow_white.svg) no-repeat;
	}
	.btn a:hover:after {
		right: -23px;
	}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#pagetitle {
	width: 100%;
}
#pagetitle .inner {
	height: 100vh;
}
	#pagetitle .titbox {
		width: 100%;
		text-align: center;
		color: #fff;
		position: absolute;
		top: 50%;
		left: 0;
		margin-top: -73.5px;
	}
		#pagetitle .titbox h1 {
			font-size: 60px;
			font-weight: 700;
			letter-spacing: 5px;
		}

		#pagetitle .titbox .en {
			font-size: 22px;
			letter-spacing: 5px;
		}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* パンくず */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#breadcrumb {
	width: 100%;
	background: #f9f9f9;
}
	#breadcrumb ul li {
		height: 40px;
		font-size: 72%;
		line-height: 40px;
		background: url(../img/breadcrumb_arrow.png) no-repeat right center;
		padding-right: 30px;
		margin-right: 17px;
	}
	#breadcrumb ul li:nth-last-child(1) {
		background: none;
	}
		#breadcrumb ul li a {
			display: block;
			height: 40px;
			color: #8f8a88;
			text-decoration: underline;
			line-height: 40px;
		}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	width: 100%;
	padding: 70px 0 60px 0;
}
	#footer .logo {
		padding-top: 10px;
		color: #00a0f7;
	}
		#footer .logo span {
			line-height: 35px;
			padding-left: 20px;
			letter-spacing: 2px;
		}

	#footer .text {
		text-align: right;
	}
		#footer .text .link {
			font-size: 86%;
			letter-spacing: 2px;
			padding-bottom: 10px;
		}

		#footer .text .copy {
			font-size: 72%;
			letter-spacing: 2px;
		}







/* 1400px */
@media screen and (max-width: 1400px) {





/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header .menu {
	width: 80px;
	height: 80px;
	background: #000;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 10000;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */

/* main */
#main {
	display: block;
	padding-right: 0;
}
.inner {
	width: 100%;
	padding: 0 5%;
}



/* nav */
#nav {
	display: none;
}






}







/* 1160px */
@media screen and (max-width: 1160px) {




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header .logo {
	width: 95%;
	position: absolute;
	top: 20px;
	left: 5%;
	z-index: 10;
}
	#header .logo img {
		width: 120px;
		height: auto;
	}
	
	#header .logo span {
		width: -webkit-calc(100% - 70px);
		width: calc(100% - 70px);
		display: block;
		font-size: 10px;
		padding-left: 0;
		letter-spacing: 1px;
		padding-left: 0;
		top: 25px;
		left: 0;
	}




	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer .logo span {
	display: block;
	font-size: 86%;
}

#footer .text {
	padding-top: 15px;
}
	#footer .text .link,
	#footer .text .copy {
		letter-spacing: 1px;
	}






}

	







/* max 767px */
@media screen and (max-width: 767px) {


.sp {
	display: block;
}
.pc {
	display: none;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* ヘッダー */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#header .logo {
	width: 95%;
	position: absolute;
	top: 20px;
	left: 5%;
	z-index: 10;
}
	#header .logo img {
		width: 120px;
		height: auto;
	}
	
	#header .logo span {
		width: -webkit-calc(100% - 70px);
		width: calc(100% - 70px);
		display: block;
		font-size: 10px;
		padding-left: 0;
		letter-spacing: 0;
		padding-left: 0;
		top: 25px;
		left: 0;
	}


#header ul {
	top: 0;
	right: 70px;
}
	#header ul li {
		width: 70px;
		margin-right: 0;
	}
	#header ul li.intern {
		display: none;
	}
		#header ul li a {
			font-size: 10px;
			font-weight: 700;
			height: 70px;
			line-height: 1.3em;
		}
		#header ul li.mypage a {
			background: #d7f0fc;
			border: none;
		}
		#header ul li.entry a {
			background: #00a0f7;
			color: #fff;
		}
		#header ul li.career a {
			background: #d7f0fc;
			border: none;
		}
		#header ul li a.active {
			background: #000;
			color: #fff;
			border: none;
		}
		#header ul li a:hover {
			color: #fff;
			border: none;
		}
		#header ul li.career a:hover {
			background: #d7f0fc;
			border: none;
			color: #000;
		}

		#header ul li .sublist {
			width: 100%;
			display: none;
			position: absolute;
			top: 70px;
			left: 0;
		}
			#header ul li .sublist li {
				width: 100%;
				background: #fff;
				color: #000;
			}
				#header ul li .sublist li a {
					display: block;
					height: 40px !important;
					background: #fff;
					color: #000;
					line-height: 40px;
				}
				#header ul li .sublist li a:hover {
					background: #fff;
					color: #000;
					border: solid 1px #000;
					border-top: none;
					opacity: 0.7;
				}


#header .menu {
	width: 70px;
	height: 70px;
}
	



	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 基本レイアウト */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
	
	
/* title
--------------------- */
.title {
	padding-bottom: 30px !important;
}
	.title .en {
		font-size: 16px;
		color: #00a0f7;
		line-height: 1;
		padding-bottom: 7px;
	}

	.title h2 {
		font-size: 25px;
		letter-spacing: 0.1em;
		line-height: 1.4em;
	}
 
	
/* tag */
ul.tag li a {
	font-size: 72%;
}

 
	
/* btn */
.btn {
	margin: auto;
}




/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* 下層タイトル */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#pagetitle .inner {
	height: 100vh;
}
#pagetitle .titbox {
	margin-top: -51px;
}
	#pagetitle .titbox h1 {
		font-size: 32px;
		letter-spacing: 3px;
		line-height: 1.4em;
		padding-bottom: 10px;
	}

	#pagetitle .titbox .en {
		font-size: 16px;
		letter-spacing: 2px;
	}


	
	
	
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
/* フッター */
/* ++++++++++++++++++++++++++++++++++++++++++++++ */
#footer {
	padding: 50px 0 30px 0;
}
#footer .inner {
	display: block;
}
	#footer .logo {
		color: #00a0f7;
		text-align: center;
	}
		#footer .logo span {
			display: block;
			padding-top: 15px;
			line-height: 1;
			padding-left: 0;
		}

	#footer .text {
		padding-top: 40px;
		text-align: center;
	}
		#footer .text .link {
			font-size: 79%;
			padding-bottom: 20px;
		}




}






.fadein {
    opacity : 0;
    transform : translate(0, 50px);
    transition : all 1000ms;
 }
.fadein.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}