/********************************
			General
********************************/
h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
li,
#contact-wrapper h1.title{
	color: #999;
	margin: 0;
	/*font-family: futura-pt, sans-serif;*/
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
	font-weight: 700;
	/*-style: italic;*/
	color: #333;
}
span,
input{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
input{
	outline: none;
}
input::-webkit-input-placeholder{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
input:-moz-placeholder{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
input::-moz-placeholder{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
input:-ms-input-placeholder{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
h1{
	font-size: 2em !important;
}
h2.title,
p.desc{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
	font-weight: 200 !important;
}
h3.title{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;
}
#company-wrapper th,
#company-wrapper td{
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif !important;	
}
h2{
	color: #333;
	font-size: 25px !important;
	line-height: 1.8 !important;
	letter-spacing: 1px !important;
	font-family :
}
h3{
	color: #333;
	font-size: 18px !important;
	line-height: 1.8 !important;
	letter-spacing: 1px !important;
}
p,
a,
td,
th{
	color: #333;
	font-size: 16px !important;
	line-height: 1.8 !important;
	letter-spacing: 1px !important;
}
a{
	text-decoration: none !important;
}
a:hover{
	color: #333;
	text-decoration: none !important;
}
/*.wrapper{
	overflow: hidden;
}*/
.DFJC{
	display: flex;
	justify-content: center;
}
.DN{
	display: none;
}
.DF{
	display: block;
}
/*@media screen and (min-width: 1025px) {
	.dn_pc{
		display: block !important;
	}
}
.dn_pc{
	display: none;
}*/
.dn_tablet{
	display: block;
}
@media screen and (max-width: 1024px) {
	.dn_tablet{
		display: none;
	}
}
.br_sp{
	display: none;
}
.br_pc{
	display: block;
}

#main_wrapper{
	width: calc( 100% - 60px );
    padding: 0;
}
.top_wrapper,
#company-wrapper{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}
.top_wrapper{
	padding-top: 60px;
}
.navbar-expand-md{
	justify-content: center;
}
.navbar-expand-md .navbar-brand{
	margin-right: 0;
}

.wrapper{
	padding: 0;
}
/********************************
			General
********************************/
.row.inner{
	max-width: 1000px;
	margin: auto;
}
.row.inner .inner_title{
	font-family :
	YuMincho,    /* Mac用 */
	'Yu Mincho', /* Windows用 */
	serif;
	line-height: 1.5;
	margin: 30px auto;
	font-size: 24px;
}
.row.inner .inner_sub_title{
	font-family :
	YuMincho,    /* Mac用 */
	'Yu Mincho', /* Windows用 */
	serif;
	line-height: 1.5;
	margin: 30px auto;
	font-size: 20px;
}
.row.inner .inner_text{
	font-family :
	YuMincho,    /* Mac用 */
	'Yu Mincho', /* Windows用 */
	serif;
	line-height: 1.5;
	margin: 30px auto;
	font-size: 16px;
}
.row.inner .card_wrap{
	width: 100%;
	display: flex;
	justify-content: center;
	margin: 30px auto;
}
.row.inner.card_wrap .card{
	border: none;
	padding: 0;
}
.row.inner.card_wrap .card p{
	font-size: 14px !important;
	margin-top: 20px;
	padding: 10px;
	text-align: left;
}
.row.inner.title_wrap{
	display: flex;
	justify-content: center;
	flex-flow: column;
	-ms-align-items: center;
	align-items: center;
}

/********************************
			Animation
********************************/

.delighter.slide_right { transform:translate(-80%); opacity:0; transition: all .75s ease-out; }
.delighter.slide_right.started { transform:none; opacity:1; }

.delighter.slide_left { transform:translate(80%); opacity:0; transition: all .75s ease-out; }
.delighter.slide_left.started { transform:none; opacity:1; }

.delighter.slide_bottom { transform:translatey(30%); opacity:0; transition: all .75s ease-out; }
.delighter.slide_bottom.started { transform:none; opacity:1; }

/* 基本のスタイル */
.delighter {
	transition: all .7s ease-in;
	transform: translateX(-100%);
	opacity: 0;
}
  
/* スタート時のスタイル */
.delighter.started {
	transform: none;
	opacity: 1;
}


/********************************
			Search
********************************/

.TopSlideWrapper .search_wrapper{
	background: rgba(0,0,0,0.5);
	position: absolute;
	bottom: 0;
	z-index: 9999;
	display: none;
}
.search_wrapper select,
.search_wrapper input{
	width: 210px;
	border: none;
}
.search_wrapper input{
	border-radius: 5px;
    padding-left: 35px;
}
.select_area{
	width: 210px;
    overflow: hidden;
    border-radius: 5px;
    height: 50px;
    position: relative;
}
.select_area::after{
	content: '▼';
	color: #333;
	display: inline-block;
	width: 15px;
	height: 15px;
	position: absolute;
	top: 50%;
	right: 20px;
	margin-top: -12px;
}
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 230px;
    height: 50px;
    margin: 0;
    border: 0;
    outline: none;
    padding-left: 75px;
    background: transparent;
    color: #333;
    background: white;
}

.TopSlideWrapper .search_wrapper .inner{
	justify-content: center;
	align-items: center;
	height: 90px;
	max-width: 1000px;
	margin: 0 auto;
}
.TopSlideWrapper .search_wrapper .inner form{
	width: 100%;
	justify-content: space-between;
}
.TopSlideWrapper .search_wrapper .inner .search_area,
.TopSlideWrapper .search_wrapper .inner .search_contract,
.TopSlideWrapper .search_wrapper .inner .search_purpose,
.TopSlideWrapper .search_wrapper .inner .search_button{
	max-width: 225px;
	width: 85%;
	padding: 10px 40px;
	margin: 0 15px;
	text-align: center;
	font-size: 14px;
}
.TopSlideWrapper .search_wrapper .inner .search_button{
	border-radius: 20px;
	background: #0d5ea9;
	color: white;
	text-decoration: none;
}
.TopSlideWrapper .search_wrapper .inner .search_button p{
	margin: 0;
}

/***************************************************
					News Ticker
***************************************************/
.ticker_wrap{
	padding: 0;
	background: black;
}
.ticker_wrap .outer{
	border-bottom: 1px solid white;
	width: 100%;
}
.ticker_wrap .inner{
	max-width: 1000px;
	margin: 0 auto;
	padding: 5px 0;
	width: 100%;
	align-items: center;
}
.ticker {
	margin: 0 auto;
	text-align: left;
	position: relative;
	overflow: hidden;
	height: 50px !important;
}
.ticker ul {
	width: 100%;
	height: 100%;
	position: relative;
}
.ticker ul li {
	width: 100%;
	display: none;
	margin-top: -12px;
	color: white !important;
}
.ticker ul li span{
	display: inline-block;
	padding: 0 15px;
}
.ticker ul li a{
	color: white;
	text-decoration: none;
}
.ticker ul .archive{
	color: white;
	text-decoration: none;
	position: absolute;
	right: 0;
	top: 50%;
	margin-top: -14px;
	z-index: 999;
}




/***************************************************
				Under Page General
***************************************************/
#mv_under{
	background: url(../img/general/mv_under.jpg) center no-repeat;
	background-size: cover;
	padding: 0 !important;
	height: 300px;
}
#container_with_side{
	max-width: 1000px;
}
#container_with_side .row:first-child{
	justify-content: space-around;
}
#content_with_side{
	max-width: 720px;
    margin: 0px auto 50px;
}


/***************************************************
			Blog Page with Sidebar
***************************************************/
article .blog_header{
	background: #f7f7f7;
	padding: 1em;
	margin: 30px auto;
}
article .entry-title{
	color: #333;
	font-size: 16px !important;
	font-weight: 600;
	margin-bottom: 20px;
}

.post-navigation .nav-links{
	border-top: 1px solid lightgray;
	border-bottom: 1px solid lightgray;
}
.post-navigation .nav-links span{
	display: block;
	width: 50%;
	text-align: center;
	font-size: 14px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.post-navigation .nav-links span a{
	text-align: left;
	padding: 30px;
	color: gray;
	text-decoration: none;
}
.post-navigation .nav-links .nav-previous span a i{
	margin-left: -10px;
}
.nav-previous{
	border-right: 1px solid lightgray;
}

/***************************************************
					Archive Page
***************************************************/
.cat_archive .page-title{
	color: #ffbb00;
	font-size: 20px !important;
	font-weight: 700;
	border-left: 5px solid #ffbb0f;
	padding-left: 10px;
	margin: 30px auto;
}

.cat_archive .archive_content{
	display: flex;
	align-items: center;
	justify-content: space-between;
    flex-direction: column;
	padding-top: 15px;
	padding-bottom: 30px;
	margin: 30px auto;
	border-bottom: 1px solid #bbb;
	max-width: 100%;
}
.cat_archive .archive_thumb{
	margin-right: 30px;
}
/*
.cat_archive .archive_thumb img{
	border-radius: 50%;
}
.cat_archive .dummyimage{
	margin-right: 30px;
}*/
.cat_archive .dummyimage img{
	width: 225px;
}
.cat_archive .inner_wrap{
	width: 100%;
}
.cat_archive .entry-title a{
	font-size: 16px;
	color: #333;
	font-weight: 600;
	line-height: 2;
	margin: 5px auto;
}

/***************************************************
					Archive News
***************************************************/
.cat_archive.news_archive .archive_thumb,
.vacant_box{
	width: 225px;
	height: 150px;
	display: flex;
	align-items: center;
}
.cat_archive.news_archive .archive_thumb img{
	border-radius: 0 !important;
}
.vacant_box{
	width: 225px;
	height: 150px;
	margin-right: 30px;
}
.vacant_box a{
	display: block;
    width: 100%;
    height: 100%;
}
.cat_archive.news_archive .cat_name{
	background: #aaaaaa;
	color: white;
	text-align: center;
	font-size: 14px;
	padding: 5px 10px;
	border-radius: 20px;
	margin-bottom: 20px;
}
.cat_archive.news_archive .inner_footer{
	justify-content: space-between;
}
.cat_archive.news_archive .inner_footer p{
	margin-bottom: 0;
}

/***************************************************
				   privacy policy
***************************************************/
.pp_wrap h1{
	color: #004a9f;
	font-size: 20px !important;
	font-weight: 700;
	border-left: 5px solid #004a9f;
	padding-left: 10px;
	margin: 30px auto;
}
.pp_wrap h2{
	color: gray;
	font-size: 18px !important;
	margin: 30px auto;
	padding-bottom: 10px;
	border-bottom: 1px solid lightgray;
}
.pp_wrap h3{
	color: #333;
	font-size: 16px !important;
	margin: 15px auto;
}
.pp_wrap p{
	color: gray;
	font-size: 15px !important;
}
.pp_wrap table{
	margin: 30px 0;
}
.pp_wrap table tr{
	vertical-align: top;
}
.pp_wrap table th,
.pp_wrap table td{
	font-size: 15px;
	color: #333;
	line-height: 2;
}

/***************************************************
					Search Content
***************************************************/
.search_content{
	max-width: 1000px;
	justify-content: space-between;
	margin: 0 auto;
}

/***************************************************
				   Contact
***************************************************/
#contact-wrapper h1.title{
	color: #B40019;
	/*border-left: 5px solid #04101a;*/
	font-weight: 400 !important;
	margin-top: 35px;
	font-size: 70px !important;
}
#contact-wrapper h2.title{
    margin: 40px 0 15px;
}
#contact-wrapper .desc{
	color: #333;
	font-weight: 400;
	font-size: 16px !important;
}
#contact-wrapper form{
	margin-top: 30px;
}
#contact-wrapper input,
#contact-wrapper textarea{
	width: 100%;
	padding: 10px;
	margin: 0 0 10px;
}
#contact-wrapper label{
	margin-top: 20px;
}
#contact-wrapper .mwform-tel-field{
	width: 100%;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	-ms-align-items: center;
	align-items: center;
}
#contact-wrapper form p a{
	text-decoration: underline !important;
	font-size: 14px !important;
    margin: 20px;
}
#contact-wrapper .mwform-tel-field input{
	width: 30%;
}
#contact-wrapper .inner form p:last-of-type{
    text-align: center;
    margin-top: 20px;
}
#contact-wrapper .inner form p:last-of-type button{
    background: white;
    border: 1px solid #B40019;
    padding: 1em;
    width: 320px;
    color: #B40019;
    border-radius: 5px;
    cursor: pointer;
}
#contact-wrapper form input[type="submit"]{
	width: 600px !important;
	border: none;
	color: white;
	background: #B40019;
}
/***************************************************
					404 Page
***************************************************/
#error-404-wrapper .img_wrap{
	text-align: center;
}
#error-404-wrapper .btn_wrap{
	background-color: #547692;
    width: 300px;
    height: 50px;
    margin: 30px auto;
}
#error-404-wrapper .btn_wrap a{
	display: block;
	color: #fff;
	text-align: center;
	width: 100%;
    height: 100%;
    line-height: 50px !important;
}


#pager .page-numbers{
    border: 2px solid #004B9F;
    padding: 10px;
    text-align: center;
}
#pager .page-numbers.current{
    background: #004B9f;
    color:#fff;
    padding: 10px;
    text-align: center;
}


/***************************************************
						Footer
***************************************************/



/***************************************************
				   Media Queries
***************************************************/

@media screen and ( max-width: 767px ){
	.br_sp{
		display: block;
	}
	.wrapper_breadcrumb{
		display: none;
	}
	.dn_sp{
		display: none;
	}
	.dn_pc{
		display: block;
	}
	.br_pc{
		display: none;
	}
	/**************************************
					Search
	**************************************/
	.search_wrapper{
		overflow: hidden;
		display: none;
	}
	.search_wrapper .row{
		justify-content: center;
	}
	.search_wrapper form{
		display: block;
		text-align: center;
		margin-top: 50px;
	}
	.search_wrapper select,
	.search_wrapper input{
		width: 300px;
		border: none;
	}
	.search_wrapper input{
		border-radius: 5px;
	    padding-left: 35px;
	}
	.select_area{
		width: 300px;
	    overflow: hidden;
	    border-radius: 5px;
	    height: 50px;
	    position: relative;
	    border: 1px solid lightgray;
	    margin-bottom: 20px;
	}
	.select_area::after{
		content: '▼';
		color: #333;
		display: inline-block;
		width: 15px;
		height: 15px;
		position: absolute;
		top: 50%;
		right: 20px;
		margin-top: -12px;
	}
	select {
	    -webkit-appearance: none;
	    -moz-appearance: none;
	    appearance: none;
	    width: 230px;
	    height: 50px;
	    margin: 0;
	    border: 0;
	    outline: none;
	    padding-left: 100px;
	    background: transparent;
	    color: #333;
	    background: white;
	}
	.keywords{
		height: 50px;
		width: 300px;
		margin-bottom: 20px;
		padding-left: 75px !important;
		border: 1px solid lightgray !important;
	}

	input.search_button{
		background: #004a9f;
		color: white;
		border: none; 
		padding: 0 !important;
		height: 50px;
	}
	/**************************************
					TOP
	**************************************/
	
	/**********************************
		    /下層ページタブの一括指定
	**********************************/




	.cat_archive .archive_content{
		padding-bottom: 20px;
		margin: 10px auto;
	}
	.cat_archive.news_archive .cat_name{
		margin-bottom: 0;
	}
	.cat_archive.news_archive .entry-title{
		margin: 10px auto;
	}
	.cat_archive.news_archive .inner_footer{
		flex-flow: column;
	    align-items: flex-end;
	}
	.cat_archive.news_archive .inner_footer .posted-on{
		font-size: 14px;
		margin-bottom: 10px;
	}
	.cat_archive.news_archive .inner_footer p a{
		text-align: center;
		font-size: 14px;
	}


	/**************************************
					Sidebar
	**************************************/
	#sidebar{
		max-width: 100%;
		margin-top: 50px;
		border: none !important;
		padding: 0 !important;
	}
	#sidebar h2{
		margin-top: 20px;
		margin-bottom: 0;
	}
	#sidebar .side_banner_wrap img{
		margin: 10px auto 10px;
	}
	#sidebar .side_banner_wrap img{
		width: 100%;
	}

	article .entry-content{
		margin: 50px auto;
	}
	#content_with_side .related_news_wrap .card{
		margin: 15px auto;
	}

	#contact-wrapper form input[type="submit"]{
		width: 300px !important;
	}

}