@charset "UTF-8";

body {
	background: #fff;
}
header {
	background: #fff;
}
/* h1 */
header h1.job {
	padding:130px 0 160px;
}
/* main */
#job #box_wrap {
    max-width: 1284px;
    width: 100%;
    margin: 0 auto 0;
}
#job #masonry {
	margin:0 auto;
	overflow:hidden;
	text-align:center;
}  
#job figure {
	position: relative;
	overflow: hidden;
	width: 320px;
	height:320px;
	line-height: 0;
	float: left;
	margin: 0 15px 30px 15px;
}
#job figure:after {
	content: url(../job/img/icon_triangle.png);
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 10;
}
#job figcaption {
	display: table;
	position: absolute;
	bottom:0;
	left: 0;
	z-index: 2;
	width: 100%;
	height: 50px;
	background: rgba(0,0,0,.75);
	transition: .3s;
	line-height: 1.8;
	text-align: center;
    justify-content: center;
    align-items: center;
}
#job figure figcaption div {
	display:table-cell;
	vertical-align:middle;
	width:100%;
	background: url(../img/icon_arrow03.png) 150% center no-repeat;
	background-size: 14px;
	transition: all .2s;
}
#job figcaption h3 {
	width:100%;
	color: #fff;
	font-weight: normal;
	font-size: 1.4rem;
}
#job figure figcaption h3::after {
	content:none;
}
#job figure figcaption p {
	display:none;
}
#job figure:hover figcaption {
	bottom: 0;
	height:100%;
	background: rgba(0,0,0,.75);
}
#job figure:hover figcaption div {
	background: url(../img/icon_arrow03.png) 96% center no-repeat;
	background-size: 14px;
}
#job figure:hover figcaption h3::after {
	content:'ENTRY';
	display:block;
	color: #ff0000;
	font-size: 2.0rem;
	font-weight:bold;
}
/*@media screen and (max-width:1111px) {
	#job #box_wrap {
		padding: 0 0 100px 0;
	}
	#job figure {
		position: relative;
		overflow: hidden;
		width: 320px;
		height:320px;
		line-height: 0;
		float: left;
		margin: 0 15px 30px 15px;
	}
}*/
@media screen and (max-width:767px) {
	/* h1 */
	header h1.job {
		padding:70px 0 80px;
	}
	/* main */
	#job #box_wrap {
		margin: -30px auto 0 auto;
		width: 92%;
		height:auto;
	}
	#job #masonry {
		width: 100%;
		margin: 0;
	}
	#job figure {
		width: 100%;
		height:auto;
		float: none;
		margin: 0 auto 30px auto !important;
	}
	#job figure img {
		width: 100%;
	}
	#job figure:after {
		content: normal;
	}
	#job figcaption {
		position: absolute;
		bottom: 0;
		left: 0;
		height: auto;
		-webkit-transition: none;
		transition: none;
	}
	#job figure figcaption div {
		background: url(../img/icon_arrow03.png) 96% center no-repeat;
		background-size: 14px;
		padding: 4% 0;
	}
	#job figcaption h3 {
		font-size: 1.4rem;
	}
	#job figure figcaption h3::after ,
	#job figure:hover figcaption h3::after {
		content:none;
	}
	#job figure figcaption p {
		display:block;
		color: #ff0000;
		font-size: 2.0rem;
		line-height:1.2;
		font-weight:bold;
	}
}








/* h1 */
header .job {
	display:block;
	position:relative;
}
header .job h1 {
	width:100%;
    padding: 130px 0 100px;
	color:#4c4948;
	z-index:10;
}
header .job h1 span:first-child { display:block;}
header .job h1 span:not(.other) { color:#ff0000;}
header .job .name_area {
	max-width:800px;
	width:90%;
	margin:0 auto;
	padding:40px;
	background:#4c4948;
	font-size:1.2rem;
	color:#fff;
	text-align:center;
	letter-spacing: 2px;
	box-sizing:border-box;
	z-index:9;
}

#job{
    margin-bottom: 100px;
}

#job .main_txt{
    text-align: center;
    -webkit-font-feature-settings: "palt";
    -moz-font-feature-settings: "palt";
    -ms-font-feature-settings: "palt" 1;
    font-feature-settings: "palt";
    letter-spacing: 3px;
}

#job .global_site_link{
    display: block;
    width: 370px;
    background: -webkit-linear-gradient(left, #ff8c00, #F00);
    background: -o-linear-gradient(left, #ff8c00, #F00);
    background: linear-gradient(to right, #ff8c00, #F00);
    color: #fff;
    font-size: 22px;
    padding: 36px 0;
    margin: 70px auto 0;
    text-align: center;
    line-height: 1em;
    position: relative;
}

#job .global_site_link::after {
    content: '';
    position: absolute;
    top: 0;
    right: 20px;
    width: 15px;
    height: 100%;
    background: url(../img/icon_arrow02.png) no-repeat center center;
    background-size: contain;
    transition: all .2s;
}

#job .global_site_link:hover::after {
    right: 15px;
}

#job .global_site_link svg{
    width: 20px;
    height: 20px;
    margin-left: 4px;
}


@media screen and (max-width:767px) {
    
	/* h1 */
	header .job h1 {
		padding: 70px 0 50px;
	}
    
    #job .global_site_link{
        width: 90%; 
        font-size: 18px;
        padding: 25px 0;
    }
    
}

@media screen and (max-width:520px) {
    .sp_min_none{
        display: none;
    }
    
    #job .main_txt{
        text-align: left;
        letter-spacing: 2px
    }
    
}