@charset "utf-8";
#content_wrap{border-top:1px solid #E6E6E6;}
.content_area{
	max-width:1140px;
	padding:20px 20px 0;
	margin:auto;
}
.page_title_area{
	height: 272px;
	display: flex;
	align-items: center;
	position: relative;
	overflow: hidden;
}
.page_title_area::after{
	position: absolute;
	display: inline-block;
	content: '';
	bottom: 0;
	background: url(/recruit-career/img/common/bg_common.png)no-repeat center bottom / cover;
	height: 540px;
	width: 100%;
}
.page_title{
	font-size:1.7rem;
	font-weight:bold;
	letter-spacing:1.7px;
	max-width: 1140px;
	width: 100%;
	margin: auto;
	padding: 0 20px;
	z-index: 10;
}
.page_title::before{
	display: block;
	content:attr(data-en);
	font-size: 6.4rem;
	letter-spacing: 3.2px;
	line-height: 6.4rem;
	text-transform: uppercase;
	font-family:var(--font_roboto);
	margin-bottom: 5px;
}
.page_title + *{margin-top:0;}

h2{
	margin:70px 0 23px;
	font-size:3rem;
	font-weight:bold;
	letter-spacing:1.5px;
	line-height:4.4rem;
	padding-left: 35px;
	position: relative;
}
h2::before,h2::after{
	display: inline-block;
	content: '';
	position: absolute;
	width: 8px;
	left: 0;
}
h2::before{
	top: 11px;
	height: 26px;
	background: #1C8416;
}
h2::after{
	top: 24px;
	height: 13px;
	background: #333333;
}
h3{
	margin:57px 0 18px;
	font-size:2.6rem;
	font-weight:bold;
	letter-spacing:1.3px;
	line-height:3.6rem;
	position: relative;
	padding-top: 17px;
}
h3::before{
	position: absolute;
	display: block;
	content: '';
	width: 100%;
	height: 1px;
	background: #798D78;
	top: 0;
}
h4{
	margin:36px 0 15px;
	font-size:2rem;
	font-weight:bold;
	letter-spacing:1px;
	line-height:3rem;
	position: relative;
	padding-left: 25px;
}
h4::before{
	position: absolute;
	display: inline-block;
	content: '';
	width: 6px;
	height: 21px;
	background-color: #1C8416;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
}
h5{
	margin:30px 0 12px;
	font-size: 1.8rem;
	font-weight:bold;
	letter-spacing:0.9px;
	line-height: 2.7rem;
}
p{
	font-size: 1.7rem;
	letter-spacing: 0.85px;
	line-height:3.06rem;
	margin-bottom:8px;
}
ul{
	padding-left:20px;
	margin-bottom:25px;
}
ol{
	padding-left:40px;
	margin-bottom:25px;
}
ul li{list-style:disc;}
li ul, li ol{margin:5px 0 10px;}
ul li ul li{list-style:circle;}
ul li ul li ul li{list-style:square;}
ol li{list-style:decimal;}
li{
	font-size: 1.7rem;
	letter-spacing: 0.85px;
	line-height: 3.06rem;
	margin-bottom: 4px;
}
table{
	table-layout:fixed;
	width:100%;
	margin-bottom:30px;
	border-top:1px solid #E6E6E6;
}
th, td{
	padding:22px 20px;
	border-bottom:1px solid #E6E6E6;
	line-height:2.9rem;
	vertical-align:top;
}
th{
	width:260px;
	font-weight:bold;
	text-align:left;
	padding-left: 0 !important;
}
th *:last-child, td *:last-child{margin-bottom:0;}
td li{margin:0;}
.txt_center{text-align: center;}
.scroll_table{margin-bottom:10px;}
.scroll_table table{
	table-layout:auto;
	margin-bottom:10px;
	min-width: 500px;
}
.scroll_table th, .scroll_table td{
	white-space: nowrap;
	display:table-cell !important;
}
.scroll_table thead th{
	min-width:200px;
	width:auto;
}
.scroll-hint-icon-wrap.is-active .scroll-hint-icon{opacity: 0.8;}
.scroll-hint-icon{
	top:0;
	right:0;
	bottom:0;
	left:0;
	width:130px;
	height:90px;
	margin:auto;
}

.alignleft{margin-right:auto;}
.aligncenter{margin:auto;}
.alignright{margin-left:auto;}

.column_2, .column_3, .gallery{
	display:grid;
	gap:30px 40px;
	padding:0;
	margin-bottom:30px;
}
.column_2, .gallery-columns-2{grid-template-columns:repeat(2, 1fr);}
.column_3, .gallery-columns-3{grid-template-columns:repeat(3, 1fr);}
.column_3 li{
	list-style: none;
	border: 1px solid #333;
	height: 170px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.gallery-item{
	width:auto !important;
	padding:0 !important;
}
.gallery img{margin:auto;}
.wp-caption{
	max-width:100%;
	margin-bottom:30px;
}
.wp-caption-text{
	padding:0 !important;
	margin:10px 0;
	font-size:1.5rem;
	letter-spacing:1.5px;
	line-height:2.2rem;
	text-align:center;
}
div.gallery > br{display:none;}

.localnav{
	padding:25px 40px 50px;
	margin-top:100px;
	background:#F5F5F5;
	border-radius:20px;
}
.ln_top{
	margin:0 0 15px;
	font-size:2rem;
	letter-spacing:1.2px;
	line-height:2.9rem;
}
.ln_top_link{
	display:block;
	position:relative;
	padding:20px 40px 20px 30px;
	background:url(/img/common/arrow_r.svg) no-repeat center right 15px;
	border-bottom:1px solid #DFDFDF;
	color:#333 !important;
	text-decoration:none;
	transition:background 0.3s, color 0.3s;
}

.ln_top_link:hover, .ln_link:hover{
	background-position-x:right 5px;
	color:#338B33 !important;
}
.ln_top_link::before{
	content:'';
	position:absolute;
	top:1px;
	bottom:0;
	left:0;
	width:17px;
	height:17px;
	margin:auto;
	background:url(/img/common/icon_local.svg) no-repeat center/cover;
}
.ln_top_link::after, .ln_link::after{
	content:'';
	position:absolute;
	bottom:-1px;
	left:0;
	width:100%;
	height:1px;
	background:#338B33;
	transform:scaleX(0);
	transform-origin:right;
	transition:transform 0.3s;
}
.ln_top_link:hover::after, .ln_link:hover::after{
	transform:scaleX(1);
	transform-origin:left;
}
.ln_list{
	display:grid;
	grid-template-columns:1fr 1fr 1fr;
	gap:15px 30px;
	padding:0;
	margin:0;
}
.ln_item{
	list-style:none;
	margin:0;
	font-size:1.5rem;
	letter-spacing:0.9px;
	line-height:2.2rem;
}
.ln_link{
	display:flex;
	align-items:center;
	position:relative;
	height:100%;
	padding:20px 40px 20px 0;
	background:url(/img/common/arrow_r.svg) no-repeat center right 15px;
	border-bottom:1px solid #DFDFDF;
	color:#333 !important;
	text-decoration:none !important;
	transition:background 0.3s, color 0.3s;
}
.on .ln_link{color:#338B33 !important;}
.on .ln_link::after{transform:scaleX(1);}
.map, .movie_wrap{
	position:relative;
	width:auto;
	height:0;
	padding-bottom:56.25%;
	margin:0 auto;
	overflow:hidden;
}
.map iframe, .map object, .map embed, .movie_wrap iframe, .movie_wrap object, .movie_wrap embed{
	position: absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}
#pankuzu{
	padding:0 70px 10px 0;
	margin-top:105px;
}
.localnav + #pankuzu{margin-top:45px;}
#pankuzu ol{
	display:flex;
	flex-wrap:wrap;
	padding:0;
	margin:0;
}
#pankuzu li{
	position:relative;
	list-style:none;
	padding-right:18px;
	margin:0 12px 10px 0;
	background:url(/img/common/arrow_pankuzu.svg) no-repeat center right;
	font-size:1.3rem;
	letter-spacing:0.78px;
	line-height:1.9rem;
}
#pankuzu li:last-child{
	padding:0;
	margin-right:0;
	background:none;
}
#pankuzu a{
	display:block;
	color:#333 !important;
	text-decoration:none !important;
}
#pankuzu a:hover{text-decoration:underline !important;}
#pankuzu a br{display: none;}
#pankuzu li:last-child a{pointer-events:none;}
.page_link{
	display:flex;
	flex-wrap:wrap;
	padding:0;
	margin:0 -40px 0 0;
}
.page_link li{
	list-style:none;
	margin:0 40px 20px 0;
	position: relative;
}
.page_link li:hover a{color: #1C8416 !important}

.page_link li::after{
	position: absolute;
	display: inline-block;
	content: '';
	width: 17px;
	height: 16px;
	background: url(/recruit-career/img/common/arrow_d_green.svg) no-repeat center / 17px;
	right: 12px;
	top: 0;
	bottom: 0;
	margin: auto;
}
@keyframes arrow_move_down{
	0%, 100%{
		background-position:center center;
	}
	50%, 60%{
		background-position:center bottom -15px;
	}
	61%{
		opacity:0;
		background-position:center top -15px;
	}
	62%{
		opacity:1;
		background-position:center top -15px;
	}
}
.page_link li:hover::after{
	animation:arrow_move_down 0.4s;
}
.page_link a{
	display:block;
	position:relative;
	padding:10px 50px 10px 0;
	color:#333 !important;
	text-decoration:none !important;
	transition: color 0.3s;
	height: 100%;
}
.page_link a::before, .page_link a::after{
	content:'';
	position:absolute;
	bottom:0;
	right:0;
	height:2px;
}
.page_link a::before{
	background:#DDDDDD;
	width:100%;
}
.page_link a::after{
	background:#1C8416;
	width: 40px;
}
/* ネクスコ・エンジニアリングを知る */
.about-us .page_title::before{content: 'about us';}
.about-us p{margin-bottom: 30px;}

/* sitemap */
.sitemap h2:first-child{margin-top: 0;}
.sitemap h2 a{color: #333 !important;}

/* ページナビ */
.single_prev_next_nav{
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 80px;
	padding-top: 20px;
	border-top: 1px solid #E6E6E6;
}
.single_prev_next_nav a{
	color: #333333 !important;
	text-decoration: none;
	font-size: 1.7rem;
	letter-spacing: 0.85px;
	line-height: 3.06rem;
	font-weight: 500;
}
.single_prev_next_nav a:hover{text-decoration: underline;}
.prev_link{
	float: left;
	padding-left: 30px;
	background: url(/recruit-career/img/common/arrow_l_green.svg) no-repeat center left / 16px;
}
.next_link{
	float: right;
	padding-right: 30px;
	background: url(/recruit-career/img/common/arrow_r_green.svg) no-repeat center right / 16px;
}
@media screen and (max-width:1024px){
.page_title_area::after {
	background-position: left bottom;
	height: 400px;
}
.page_title{
	font-size:1.6rem;
	letter-spacing:1.6px;
}
.page_title::before{
	font-size: 5.6rem;
	letter-spacing: 2.8px;
}

h2{
	font-size:2.8rem;
	letter-spacing:1.4px;
	padding-left: 33px;
	margin-bottom: 18px;
}
h3{
	margin:58px 0 17px;
	font-size:2.2rem;
	letter-spacing:1.1px;
	line-height:3.6rem;
	padding-top: 14px;
}
h4{padding-left: 20px;}

p{
	font-size: 1.6rem;
	letter-spacing: 0.8px;
	margin-bottom: 11px;
}
li{
	font-size: 1.6rem;
	letter-spacing: 0.8px;
	margin-bottom: 11px;
	margin-bottom: 3px;
}
th{
	width:213px;
}
th,td{
	font-size: 1.5rem;
	letter-spacing: 0.75px;
	line-height: 2.88rem;
	padding: 20px;
}
/* ページナビ */
.single_prev_next_nav{margin-top: 60px;}
.single_prev_next_nav a{
	font-size: 1.6rem;
	letter-spacing: 0.8px;
}
.prev_link{
	padding-left: 30px;
}
.next_link{
	padding-right: 30px;
}
}

@media screen and (max-width:767px){
.page_title_area{height: 160px;}
.page_title{
	font-size:1.4rem;
	letter-spacing:1.4px;
	line-height:2rem;
}
.page_title::before{
	font-size:4.4rem;
	letter-spacing:0.2px;
	line-height:4.6rem;
}
.page_title_area::after {
	height: 300px;
}

h2{
	margin-top:60px;
	font-size:2.6rem;
	letter-spacing:1.3px;
	line-height:3.7rem;
}
h2::before{top:8px;}
h2::after{top:21px}
h3{
	margin-top:48px;
	font-size:2rem;
	letter-spacing:1px;
	line-height:2.9rem;
}
h4{
	padding-left:20px;
	font-size:1.8rem;
	letter-spacing:0.9px;
	line-height:2.7rem;
	margin-top: 34px;
}
h5{
	margin-top:28px;
	font-size:1.6rem;
	letter-spacing:0.8px;
	line-height:2.4rem;
}
p{
	font-size: 1.5rem;
	letter-spacing: 0.75px;
	line-height: 2.55rem;

}
ul, ol, table{margin-bottom:20px;}
li{
	font-size:1.4rem;
	letter-spacing:1.4px;
	line-height:2.5rem;
}
th, td{
	padding:18px 15px 18px;
	line-height: 2.55rem;
}
th{
	width:90px;
	padding-right: 0;
}
.page_link{margin-right: -15px;}
.page_link li{
	width: 100%;
	margin-right: 15px;
}

#pankuzu{margin-top:80px;}
#pankuzu .pc_size,#pankuzu .tab_size,#pankuzu .sp_size{display: none !important;}
.content_area{padding-top: 40px;}
p.txt_center{text-align: left;}

.column_2{
	grid-template-columns: 1fr;
	gap: 15px;
}
/* ページナビ */
.single_prev_next_nav a{
	font-size: 1.3rem;
	letter-spacing: 0.65px;
	line-height: 1.95rem;
	width: calc(50% - 5px);
}
.next_link{text-align: right;}
}


@media screen and (max-width:650px){

.img_txt{display:block;}
.img_txt > p{margin:0 auto 20px;}
.img_txt h4{margin-top:35px;}

/* archive */
.select_box_in{
	flex-wrap:wrap;
	gap:15px 0;
	max-width:300px;
	margin:auto;
}
.select_name{
	width:65px;
	text-align:right;
}
.select_item{width:calc(100% - 75px);}
.select_item.cat_select{margin:0;}

}


@media screen and (max-width:600px){
.column_3, .gallery-columns-3{grid-template-columns:repeat(1, 1fr);}
}


@media screen and (max-width:550px){
.column_2, .gallery-columns-2{grid-template-columns:repeat(1, 1fr);}
/* ページナビ */

}