@charset "utf-8";


/* ==========================================================================
   HTML5 Reset
========================================================================== */


article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block;
}

audio,
canvas,
video {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}

audio:not([controls]) {
	height: 0;
	display: none;
}

blockquote, q {
    quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}


/* ==========================================================================
   Base
========================================================================== */


html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;

}

html,
button,
input,
select,
textarea {
	font-family: sans-serif;
}

body {
	margin: 0;
	padding: 0;
}


/* ==========================================================================
   Links
========================================================================== */


a:active,
a:hover,
a:focus {
	outline: 0;
}


/* ==========================================================================
   Typography
========================================================================== */


h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	font-size: 100%;
	font-weight: normal;
}

b,
strong {
	font-weight: bold;
}

p,
pre {
	margin: 0;
	padding: 0;
}

caption {
	text-align: left;
}


/* ==========================================================================
   Lists
========================================================================== */


dl,
menu,
ol,
ul,
li,
dt,
dd {
	margin: 0;
	padding: 0;
}

ul,
ol {
	list-style: none;
	list-style-image: none;
}


/* ==========================================================================
   Embedded content
========================================================================== */


img {
	border: 0;
	-ms-interpolation-mode: bicubic;
}

svg:not(:root) {
	overflow: hidden;
}


/* ==========================================================================
	Figures
========================================================================== */


figure {
	margin: 0;
}


/* ==========================================================================
	Forms
========================================================================== */


form {
	margin: 0;
	padding: 0;
}

input, textarea,{
	margin: 0;
	padding: 0;
}

textarea {
	overflow: auto;
	vertical-align: top;
}

fieldset {
	border: 0;
}

button,
input,
select,
textarea {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

button,
input {
	line-height: normal;
}

button,
select {
	ext-transform: none;
}

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}

button[disabled],
html input[disabled] {
	cursor: default;
}

input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

input[type="search"] {
	-webkit-appearance: textfield;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}


/* ==========================================================================
   Tables
========================================================================== */

table {
    border-collapse: collapse;
    border-spacing: 0;
}

td {
	padding: 0;
}

th {
	text-align: left;
}
@charset "utf-8";

html {
	font: normal normal normal 62.5%/1 "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "Osaka", "MS PGothic", "ＭＳ Ｐゴシック", sans-serif;
}

body {
	margin: 0;
	padding: 0;
	background-color: #FFF;
	background-color: rgba(255, 255, 255, 1);
	position: relative;
	color: #333;
	color: rgba(0, 0, 0, .8);
	text-rendering: optimizeLegibility;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
}

a {
	color: #000;
	color: rgba(0, 0, 0, 1);
	text-decoration: underline;
	-webkit-transition: all 300ms ease;
	        transition: all 300ms ease;
}

a:hover {
	text-decoration: none;
}

a,
input,
select,
textarea,
button,
*:before,
*:after {
	-webkit-transition: all 300ms ease;
	transition: all 300ms ease;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}

a:focus,
input:focus,
select:focus,
textarea:focus,
button:focus {
  outline: none;
}

img {
	width: 100%;
	vertical-align: bottom;
	-ms-interpolation-mode: bicubic;
	interpolation-mode: bicubic;
}

br {
	display: block;
	letter-spacing:0;
	white-space:normal;
}


/*------------------------------------*/


#header {
	padding: 0 calc(20px + .5vw);
	/*background-color: rgba(255, 255, 255, .9);*/
	background-color: rgba(255, 255, 255, .99);
	box-sizing: border-box;
	position:fixed;
	left:0;
	top:0;
	right:0;
	z-index:99999;
	box-shadow:0 0 3px #ccc;
}

.header-logo a {
	display: block;
}

.header-nav-list-item a {
	font-weight: bold;
	text-decoration: none;
	text-transform: uppercase;
	line-height:30px;
}

.header-nav-list-item a:hover,
.header-nav-list-item a.active {
	color: #1879c0;
}
.header-nav-list-item a.apply{
	display:inline-block;
	background:#03528F url(../image/e3_03.png) 8px center no-repeat;
	padding:0 8px 0 33px;
	color:#fff;
}

#menu {
	width: 25px;
	height: 25px;
	display: none;
	background-image: url(../image/img_menu.png);
	background-position: center top;
	background-size: 100%;
	cursor: pointer;
}

.ie9 .header-wrap {
	width: 100%;
	display: table;
}


@media screen and ( min-width: 801px ) {

	.header-wrap {
		height: 80px;
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
				align-items: center;
	}

	.header-logo {
		/*width: 200px;*/
	}

	.header-nav {
		margin-left: auto;
	}

	.header-nav-list {
		display: -webkit-flex;
		display: flex;
		-webkit-align-items: center;
				align-items: center;
	}

	.header-nav-list-item {
		margin-left: calc(1px + 1vw);
		margin-left: 20px;
		font-size: 1.4rem;
		line-height: 2rem;
	}

.ie9 .header-logo,
.ie9 .header-nav {
	display: table-cell;
	vertical-align: middle;
}

.ie9 .header-nav-list {
	display: table;
	margin-left: auto;
}

.ie9 .header-nav-list-item {
	padding-left: calc(1px + 4vw);
	display: table-cell;
	vertical-align: middle;
}

}

.header-nav-list-item{
	position:relative;
}
.header-nav-list-item .lev1{
	line-height:80px;
	display:block;
	padding-left:2em;
	padding-right:2em;
}
.header-nav-list-item .lev1:hover{
	background:#03528f;
	color:#fff;
}

.header-nav-list .sub{
	display:none;
	position:absolute;
	left:50%;
	top:80px;
	background:#fff;
	/*border:1px solid #d4d4d4;*/
	box-shadow:0px 0px 6px rgb(0 0 0 / 35%);
	border-radius:0 0 4px 4px;
	z-index:99999;
	transform:translate(-50%,0);
}
.header-nav-list .sub li{
	padding:0;
}
.header-nav-list .sub li a{
	white-space:nowrap;
	border:none;
	line-height:44px;
	font-weight:normal;
	position:relative;
	padding:0 20px;
	display:block;
}
.header-nav-list .sub li a::after{
	content:'';
	position:absolute;
	left:10px;
	right:10px;
	bottom:0;
	height:0;
	border-bottom:dotted 1px #000;
}
.header-nav-list .sub li:last-child a::after{
	border-bottom:none;
}
.header-nav-list .sub li a:hover{
	background:#03528f;
	color:#fff;
}
.header-nav-list li.dropdown:hover .sub a{
	/*border-top:1px solid #efeae4;*/
}
.header-nav-list li:hover .sub{
	display:block;
}

@media screen and ( max-width: 800px ) {

	#header {
		width: 100%;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 100;
	}

	.header-logo {
		width: 170px;
		height: 50px;
/* 		margin: 0 auto; */
/*
		display: -webkit-flex;
		display: flex;
*/
		position: relative;
		z-index: 150;
/*
		-webkit-justify-content: center;
				justify-content: center;
		-webkit-align-items: center;
				align-items: center;
*/
	}

	.header-logo a {
		height: 50px;
		display: -webkit-flex;
		display: flex;
		-webkit-justify-content: center;
				justify-content: center;
		-webkit-align-items: center;
				align-items: center;
	}

	.header-nav {
		width: 100%;
		height: 100vh;
		background-color: rgba(255, 255, 255, 1);
		position: fixed;
		top: 0;
		left: 0;
		z-index: -1;
		display: none;
	}

	.visible .header-nav {
		display: block;
		z-index: 100;
	}

/*
	.header-nav-list {
		padding-top: 30px;
	}
*/

	.header-nav-list {
		height: calc(100vh - 50px);
		display: -webkit-flex;
		display: flex;
		position: relative;
		top: 10px;
		box-sizing: border-box;
		-webkit-justify-content: center;
				justify-content: center;
		-webkit-align-items: center;
				align-items: center;
		-webkit-flex-direction: column;
				flex-direction: column;
	}

	.header-nav-list-item {
		width: 100%;
		font-size: 2rem;
		line-height: 4rem;
		border-bottom: 1px solid rgba(0, 0, 0, .1);
	}

	.header-nav-list-item:first-child {
		border-top: 1px solid rgba(0, 0, 0, .1);
	}

	.header-nav-list-item a {
		padding: 10px 0;
		display: block;
		text-align: center;
	}
	
	
.header-nav-list-item a.apply{
	display:block;
	background:none;
		padding: 10px 0;
		text-align: center;
	color:#000;
}

	#menu {
		display: block;
		position: fixed;
		right: 20px;
		top: 12px;
		z-index: 200;
	}

	.visible #menu {
		background-position: center bottom;
	}

	.ie9 .header-logo {
		padding-top: 10px;
		box-sizing: border-box;
	}

	.ie9 .header-nav {
		display: none;
	}

	.ie9 .visible .header-nav {
		display: table;
	}

	.ie9 .header-nav-list {
		display: table-cell;
		vertical-align: middle;
	}

}


/*------------------------------------*/


#footer {
	padding: 0 calc(20px + .5vw);
	background:#ececec;
}

.footer-wrap {
	display: -webkit-flex;
	display: flex;
}

.footer-logo {
	/*width: 155px;*/
}

.footer-list {
	display: -webkit-flex;
	display: flex;
	font-size: 1.4rem;
	line-height: 2.5rem;
	-webkit-align-items: center;
			align-items: center;
}

.footer-list-item a {
	text-decoration: none;
}

.footer-list-item a:hover,
.footer-list-item a.active {
	color: #1879c0;
}

.footer-copyright {
	font-size: 1.1rem;
	line-height: 2.5rem;
}


@media screen and ( min-width: 801px ) {

	.footer-wrap {
		-webkit-align-items: center;
				align-items: center;
	}

	.footer-logo {
		margin-right: calc(40px + 3vw);
	}

	.footer-list-item {
		margin-right: calc(20px + 1vw);
	}

	.footer-copyright {
		margin-left: auto;
	}

.ie9 .footer-wrap {
	width: 100%;
	display: table;
}

.ie9 .footer-logo,
.ie9 .footer-list,
.ie9 .footer-copyright {
	display: table-cell;
	vertical-align: middle;
}

.ie9 .footer-logo {
	padding-right: 60px;
}

.ie9 .footer-list-item {
	display: inline-block;
	vertical-align: middle;
}

.ie9 .footer-copyright {
	text-align: right;
}

}


@media screen and ( max-width: 800px ) {

	.footer-wrap {
		padding: 25px 0 10px 0;
		-webkit-flex-direction: column;
				flex-direction: column;
	}

	.footer-logo {
		margin: 0 auto;
		-webkit-order: 0;
				order: 0;
	}

	.footer-list {
		width: 200px;
		margin: 0 auto;
		margin-top: 10px;
		padding-top: 10px;
		border-top: 1px solid rgba(0, 0, 0, .15);
		-webkit-order: 2;
				order: 2;
	}

	.footer-list-item {
		font-size: 1.2rem;
		line-height: 2rem;
		text-align: center;
	}

	.footer-list-item:last-child {
		margin-left: auto;
	}

	.footer-copyright {
		margin: 10px auto 0 auto;
		display: block;
		text-align: center;
		-webkit-order: 1;
				order: 1;
	}

}


/*------------------------------------*/


.fbanner {
	padding: calc(20px + 1vw) calc(20px + .5vw);
	background-color: #e5e5e5;
}

.fbanner-wrap {
	max-width: 1200px;
	margin: 0 auto;
}

.fbanner-list {
	border-radius: 5px;
	position: relative;
	flex: 1;
	box-shadow: 0 2px 5px 0 rgba(0, 0, 0, .1);
}

.fbanner-list:before {
	content: "";
	width: 100%;
	height: 100%;
	display: block;
	background-position: center center;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}

.fbanner-list.fd {
	background-color: #1879c0;
}

.fbanner-list.recruit {
	background-color: rgba(0, 0, 0, 1);
}

.fbanner-list.fd:before {
	background-image: url(../image/img_finding.png);
	opacity: .2;
}

.fbanner-list.recruit:before {
	background-image: url(../../images/img_recruit.jpg);
	opacity: .6;
}

.fbanner-list a {
	height: calc(150px + 10vw);
	max-height: 300px;
	-js-display: flex;
	display: -webkit-flex;
	display: flex;
	position: relative;
	z-index: 1;
	text-decoration: none;
	color: rgba(255, 255, 255, 1);
	-webkit-align-items: center;
			align-items: center;
	-webkit-justify-content: center;
			justify-content: center;
	-webkit-flex-direction: column;
			flex-direction: column;
}

.fbanner-list.fd .font-eng {
	max-width: 283px;
/* 	height: 100px; */
	margin-bottom: calc(10px + 1vw);
	display: block;
}

.fbanner-list-title {
	margin-bottom: calc(10px + 1vw);
	display: block;
	font-weight: bold;
	line-height: 2rem;
}

.ie9 .fbanner-wrap {
	width: 100%;
	overflow: hidden;
}

.ie9 .fbanner-list {
	display: table;
	float: left;
	letter-spacing: normal;
}

.ie9 .fbanner-list a {
	display: table-cell;
	vertical-align: middle;
}

.ie9 .font-eng,
.ie9 .fbanner-list-title,
.ie9 .fbanner-list .btn {
	display: block;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}


@media screen and ( min-width: 801px ) {

	.fbanner-wrap {
		-js-display: flex;
		display: -webkit-flex;
		display: flex;
	}

	.fbanner-list {
		margin-left: calc(20px + 1vw);
	}

	.fbanner-list:first-child {
		margin: 0;
	}

	.fbanner .font-eng {
		font-size: 6rem;
		line-height: 6rem;
	}

	.fbanner-list-title {
		font-size: 1.6rem;
	}

	.ie9 .fbanner-list {
		width: calc((100% - (22px + 1vw)) / 2);
	}

}


@media screen and ( max-width: 800px ) {

	.fbanner-list {
		margin: 10px 0;
	}

	.fbanner-list.fd .font-eng {
		max-width: 200px;
	}

	.fbanner .font-eng {
		font-size: 4rem;
		line-height: 4rem;
	}

	.fbanner-list-title {
		font-size: 1.4rem;
	}

	.ie9 .fbanner-list {
		width: 100%;
	}

}


/*------------------------------------*/


.contents {
	overflow: hidden;
	position:relative;
}

.font-eng {
	font-family: 'Roboto Condensed', sans-serif;
	font-weight: 700;
	text-transform: uppercase;
}

.paagetitle {
	height: calc(100px + 10vw);
	/*max-height: 240px;*/
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
			justify-content: center;
	-webkit-align-items: center;
			align-items: center;
	-webkit-flex-direction: column;
			flex-direction: column;
	color:#fff;
	text-shadow:3px 0px 10px #999;
}

.paagetitle .font-eng {
	margin-bottom: 10px;
	padding-bottom: 5px;
	display: table;
	border-bottom: 2px solid #fff;
	font-size: 5rem;
	line-height: 6rem;
}

.paagetitle-name {
	display: table;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 2rem;
}

.ie9 .paagetitle {
	margin: 0 auto;
	padding-top: 80px;
}

.ie9 .paagetitle-name {
	margin: 0 auto;
}

.contents-title {
	margin: 0 auto;
	position: relative;
	z-index: 5;
	margin-bottom: calc(20px + 1vw);
	padding-bottom: 10px;
	display: table;
	border-bottom: 2px solid rgba(0, 0, 0, .5);
	font-size: 2.5rem;
	line-height: 3rem;
	font-weight: bold;
}

.ie9 .contents-title {
	width: auto;
}

.contents-title.font-eng {
	font-size: 3rem;
}

a.btn,
a .btn,
input.btn {
	width: calc(100px + 2vw);
	max-width: 140px;
	padding: 10px 0;
	display: block;
	background-color: transparent;
	border: 2px solid #1879c0;
	border-radius: 3px;
	font-size: 1.4rem;
	font-weight: bold;
	line-height: 2rem;
	text-align: center;
	text-decoration: none;
	color: #1879c0;
	box-sizing: border-box;
	transition: all 300ms ease;
}

a:hover.btn,
a:hover .btn {
	background-color: #1879c0;
	color: rgba(255, 255, 255, 1);
}

a.btn.wt,
a .btn.wt {
	border-color: rgba(255, 255, 255, 1);
	color: rgba(255, 255, 255, 1);
}

a:hover.btn.wt,
a:hover .btn.wt {
	background-color: rgba(255, 255, 255, 1);
	color: #1879c0;
}

a.btn.bk,
a .btn.bk {
	border-color: rgba(0, 0, 0, 1);
	color: rgba(0, 0, 0, 1);
}

a:hover.btn.bk,
a:hover .btn.bk {
	background-color: rgba(0, 0, 0, 1);
	color: rgba(255, 255, 255, 1);
}


@media screen and ( max-width: 801px ) {

	.paagetitle .font-eng {
		border-bottom: 3px solid #fff;
		font-size: 3.5rem;
		line-height: 4rem;
	}

	.paagetitle-name {
		font-size: 1.4rem;
	}

}


@media screen and ( max-width: 800px ) {

	.contents {
		margin-top: 50px;
		overflow: hidden;
	}

	.contents-title {
		padding-bottom: 10px;
		font-size: 2.5rem;
		line-height: 3rem;
	}

}
.footer-wrap{
	padding:60px 0 30px;
}
.footer-logo{
	width:50%;
	text-align:right;
	margin:0;
	padding-right:45px;
}
.footer-logo img{
	width:400px;
}
.footer-address{
	width:50%;
	font-size:16px;
	line-height:1.6;
	border-left:1px dashed #ccc;
	box-sizing:border-box;
	padding-left:45px;
}
.footer-address p + p{
	margin-top:18px;
}
.footer-address strong{
	font-size:28px;
}
.footer-copyright{
	text-align:center;
	padding:0 0 60px;
	font-size:16px;
	color:#999;
}
.footer-address a{
	text-decoration:none;
}
.page{
	text-align:center;
	margin:40px 0 0;
}
#menu + #container, #menu + .contents{
	margin-top:80px;
}
@media screen and ( max-width: 800px ) {
	.header-nav-list-item .lev1{
		line-height:32px;
	}
	.header-nav-list li .sub{
		display:block;
		position:inherit;
		left:inherit;
		display:flex;
		top:inherit;
		transform:none;
		flex-wrap: wrap;
	}
	.header-nav-list li:hover .sub{
		display:block;
		position:inherit;
		left:inherit;
		display:flex;
		top:inherit;
		transform:none;
		flex-wrap: wrap;
	}
	.header-nav-list li .sub li{
		width:50%;
		box-sizing:border-box;
		font-size:14px;
	}
	#menu + #container, #menu + .contents{
		margin-top:50px;
	}
}