@charset "utf-8";

/*===========================================================

eyecatch

============================================================= */

#eyecatch {
	background:url(../img/eyecatch.jpg) center center no-repeat;
	background-size:cover;
	width:100%;
	height:40vh;
	position:relative;
}

#page_title {
	width:290px;
	padding:0.8em 0;
	text-align:center;
	background:rgba(5,48,91,0.7);
	position:absolute;
	bottom:0;
	left:50%;
	margin-left:-145px;
}

#page_title * {
	color:#fff;
}

#page_title .en {
	font-size:1.2rem;
	letter-spacing:2px;
}

#page_title h1 {
	font-weight:bold;
	font-size:2rem;
}

@media screen and (max-width:440px){
	#page_title .en {
		font-size:1rem;
	}
	#page_title h1 {
		font-size:1.8rem;
	}
}

/*===========================================================

thought

============================================================= */
#thought {
	width:94%;
	max-width:1200px;
	margin:8% auto;
	text-align:center;
	position:relative;
}

#thought:after {
	display:inline-block;
	content:'';
	width:1px;
	height:70px;
	background:#05305B;
	margin-top:5%;
}

#thought:before {
	display:inline-block;
	content:'';
	width:1px;
	height:70px;
	background:#05305B;
	margin-bottom:5%;
}

#thought * {
	color:#05305B;
}

#thought h2 {
	font-size:3rem;
	font-weight:500;
}

#thought p {
	line-height:2;
	margin-top:2em;
}

#thought .tho_logo {
	text-align:center;
	position:relative;
}

#thought .tho_logo img {
	display:block;
	margin:0 auto;
}

#thought .tho_logo:before {
	display:inline-block;
	content:'';
	width:1px;
	height:70px;
	background:#05305B;
	margin:5% 0;
}

@media screen and (max-width:800px){
	#thought h2 {
		font-size:2.6rem;
	}
	#thought p {
		font-size:1.4rem;
	}
}

@media screen and (max-width:680px){
	#thought p {
		text-align:left;
	}
	#thought p br.pc_only {
		display:none;
	}
}

@media screen and (max-width:440px){
	#thought {
		margin:10% auto;
	}
	#thought h2 {
		font-size:2rem;
	}
	#thought p {
		font-size:1.2rem;
	}
}

/*===========================================================

service

============================================================= */
#service {
	background:#F0EBE1;
	text-align:center;
	padding-bottom:8%;
}

#service .title_box {
	display:table;
	background:#87C2D9;
	padding:40px 15px 10px 15px;
	margin:0 auto;
}

#service .title_box * {
	color:#fff;
	text-align:center;
}

#service .title_box .en {
	font-size:1.2rem;
	letter-spacing:2px;
}

#service .title_box h3 {
	font-size:2.6rem;
	font-weight:bold;
}

#service > p {
	width:94%;
	max-width:1200px;
	margin:0 auto;
	text-align:center;
	padding:2em 0 3em 0;
	font-size:1.4rem;
}

#service > h4 {
	font-size:1.8rem;
	display:inline-block;
	margin-bottom:1em;
	border-bottom:1px solid #E83416;
	padding-bottom:0.3em;
}

#service .movie {
	width:90%;
	max-width:640px;
	margin:0 auto;
}

#service .resp {
	width:100%;
	padding-top: 56.25%;
	overflow:hidden;
	position:relative;
}
#service .resp > * {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

@media screen and (max-width:890px){
	#service > p br {
		display:none;
	}
}

@media screen and (max-width:440px){
	#service {
		padding-bottom:10%;
	}
	#service .title_box .en {
		font-size:1rem;
	}
	#service .title_box h3 {
		font-size:1.8rem;
	}
	#service > p {
		font-size:1.2rem;
	}
	#service > h4 {
		font-size:1.6rem;
	}
}

/*===========================================================

noc_group

============================================================= */

#noc_group {
	padding:8% 0;
	text-align:center;
}

#noc_group h4 {
	display:inline-block;
	text-align:center;
	margin-bottom:1em;
	font-size:1.8rem;
	font-weight:bold;
	border-bottom:1px solid #87C2D9;
	color:#606060;
	padding-bottom:0.3em;
}

#noc_group .list {
	width:94%;
	max-width:1200px;
	margin:0 auto;
}

#noc_group .group {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-align-items:center;
	-moz-align-items:center;
	-ms-align-items:center;
	align-items:center;
	padding:2em 0;
	border-bottom:1px solid #707070;
}

#noc_group .group .logo {
	width:30%;
	max-width:340px;
	font-weight:bold;
	color:#606060;
	font-size:1.4rem;
}

#noc_group .group .outline {
	-webkit-flex:1 1 0%;
	flex:1 1 0%;
	text-align:left;
	padding: 0 1em;
}

#noc_group .group .outline h5 {
	margin-bottom:10px;
	font-weight:bold;
	color:#606060;
}

#noc_group .group .outline dl {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-moz-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	-webkit-align-items:flex-start;
	-moz-align-items:flex-start;
	-ms-align-items:flex-start;
	align-items:flex-start;
}
#noc_group .group .outline dl + dl {
	margin-top:10px;
}

#noc_group .group .outline dt {
	background:#87C2D9;
	color:#fff;
	font-size:1.2rem;
	line-height:1;
	padding:0.5em 0;
	width:6em;
	text-align:center;
}

#noc_group .group .outline dd {
	-webkit-flex:1 1 0%;
	flex:1 1 0%;
	padding-left:1em;
}

#noc_group .group .outline * {
	font-size:1.4rem;
}

#noc_group .group .link {
	width:12em;
}

#noc_group .group .link a {
	display:block;
	padding:0.5em;
	position:relative;
	border:1px solid #707070;
	font-size:1.4rem;
}

#noc_group .group .link a:after {
	font-family: "Font Awesome 5 Free";
	content: "\f101";
	-webkit-font-smoothing: antialiased;
	display: inline-block;
	font-style: normal;
	font-variant: normal;
	text-rendering: auto;
	font-weight: 900;
	margin-left:0.5em;
}

@media screen and (max-width:1000px){
	#noc_group .group .logo {
		width:100%;
		max-width:100%;
		text-align:left;
		margin-bottom:10px;
	}
	#noc_group .group .outline {
		padding-left:0;
	}
}

@media screen and (max-width:786px){
	#noc_group .group .logo {
		text-align:center;
	}
	#noc_group .group .outline {
		padding:1em 0;
		width:100%;
		-webkit-flex:auto;
		flex:auto;
	}
	#noc_group .group .outline h5 {
		text-align:center;
	}
	#noc_group .group .link {
		width:100%;
		text-align:center;
	}
	
	#noc_group .group .link a {
		max-width:16em;
		margin:0 auto;
	}
}

@media screen and (max-width:440px){
	#noc_group {
		padding:10% 0;
	}
	#noc_group .group .outline dt {
		font-size:1rem;
	}
	#noc_group .group .outline dd {
		font-size:1.2rem;
	}
}