@charset "utf-8";
.content_area{
	max-width:1060px;
	padding:0 30px 120px;
	margin:auto;
}
.content_area > *:first-child{margin-top:0;}
.content_area img{border-radius: 10px;}
.title_box{
	max-width:1060px;
	margin: auto;
	padding: 50px 30px;
}
.page_title{
	font-size:2.4rem;
	font-weight:bold;
	letter-spacing:1.2px;
	line-height: 3.5rem;
	color: #178748;
}
.page_title::before{
	content:attr(data-slug);
	width:100%;
	text-transform:uppercase;
	display: block;
	font-family: var(--font_montserrat);
	font-weight: 600;
	font-size: 7rem;
	letter-spacing: 0.7px;
	line-height: 8.6rem;
	color: #000;
	padding-bottom: 7px;
}
.page_image img{
	width: 100%;
	object-fit: cover;
	min-height: 208px;
	margin-bottom: 70px;
}
h2{
	position:relative;
	font-weight:bold;
	font-size:3.2rem;
	letter-spacing: 1.6px;
	line-height: 4.6rem;
	margin:95px 0 25px;
	padding-bottom: 20px;
}
h2::before, h2::after{
	content:'';
	display:block;
	position:absolute;
	left:0;
}
h2::before{
	width:100%;
	height: 1px;
	background:#ddd;
	bottom: 4px;
}
h2::after{
	width:70px;
	height: 5px;
	background: linear-gradient(90deg, #30A909 0%, #8DD842 100%);
	bottom:0;
}
h3{
	font-weight:bold;
	position:relative;
	font-size:2.6rem;
	letter-spacing: 1.3px;
	line-height: 3.7rem;
	margin:55px 0 15px;
	padding-left: 19px;
}
h3::before{
	content:'';
	display:block;
	position:absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left:0;
	width: 4px;
	height: 26px;
	background: #ccc;
}
h4{
	font-weight: bold;
	font-size: 2.2rem;
	letter-spacing: 1.1px;
	line-height: 3.2rem;
	margin:45px 0 15px;
}
h5{
	font-weight: bold;
	font-size: 1.8rem;
	letter-spacing: 0.9px;
	line-height: 2.6rem;
	margin: 45px 0 15px;
}
h6{
	font-weight: bold;
	font-size: 1.6rem;
	letter-spacing: 0.8px;
	line-height: 2.4rem;
	margin: 35px 0 10px;
}
p{
	margin-bottom:30px;
	font-size: 1.6rem;
	letter-spacing: 1.6px;
	line-height: 2.9rem;
}
ul, ol{
	padding-left:20px;
	margin-bottom:20px;
}
ul li{list-style:disc;}
ul li li{list-style:circle;}
ul li li li{list-style:square;}
ol li{list-style:decimal;}
li{
	font-size: 1.6rem;
	letter-spacing: 1.6px;
	line-height: 2.9rem;
	margin-bottom:5px;
}
table{
	width:100%;
	margin:20px 0;
	border-top:1px solid #ddd;
}
th, td{
	padding:21px 20px;
	border-bottom:1px solid #ddd;
	vertical-align:top;
	font-size: 1.6rem;
	letter-spacing: 1.28px;
	line-height: 2.9rem;
}
th{
	width:210px;
	background:#F7F7F7;
	font-weight:bold;
	text-align:left;
}
td *:last-child{margin-bottom:0;}
.scroll_table{margin-bottom:10px;}
.scroll_table table{
	table-layout:auto;
	margin-bottom:10px;
}
.scroll_table th, .scroll_table td{display:table-cell !important;}
.scroll_table th{
	min-width:110px;
	width:auto;
}
.scroll-hint-icon{
	width:125px;
	height:90px;
}
.alignleft{margin-right:auto;}
.aligncenter{margin:auto;}
.alignright{margin-left:auto;}
#pankuzu{
	max-width:1060px;
	padding:0 70px 0 30px;
	margin:auto;
}
#pankuzu ol{
	display:flex;
	flex-wrap:wrap;
	padding:0;
	margin:0 0 20px 0;
	gap: 8px 0;
}
#pankuzu li{
	position:relative;
	list-style:none;
	padding-right:18px;
	margin:0 12px 0 0;
	font-size:1.3rem;
	letter-spacing:1.3px;
	line-height:1.9rem;
}
#pankuzu li::after{
	content:'';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0;
	width: 6px;
	height: 6px;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	transform: rotate(45deg);
}
#pankuzu li:last-child{
	padding:0;
	margin-right:0;
}
#pankuzu li:last-child::after{display: none;}
#pankuzu a{
	display:block;
	color:#333 !important;
	text-decoration:underline !important;
}
#pankuzu li:last-child a{
	pointer-events:none;
	text-decoration:none !important;
}
#pankuzu a:hover{text-decoration:none !important;}
.page_link{
	padding:23px 25px 24px;
	overflow:hidden;
	background: #F7F7F7;
	border-radius: 10px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0 40px;
	margin: 60px 0;
}
.page_link li{
	list-style:none;
	margin:0;
}
.page_link a{
	position:relative;
	padding-right:19px;
	color:#333;
	font-weight: bold;
	font-size: 1.7rem;
	letter-spacing: 1.7px;
	line-height: 2.72rem;
	text-decoration:none;
	transition: color .3s;
	background: url(/recruit-newgrads/img/common/arrow_b_green.svg)no-repeat center right;
}
.page_link a:hover{
	text-decoration:underline;
	color: #178748;
}

.column_2, .column_3, .column_4, .gallery{
	display:grid;
	grid-gap:35px;
	margin-bottom:30px;
}
.column_2, .gallery-columns-2{grid-template-columns:repeat(auto-fit, calc((100% - 35px) / 2));}
.column_3, .gallery-columns-3{grid-template-columns:repeat(auto-fit, calc((100% - 70px) / 3));}
.column_4{grid-template-columns:repeat(auto-fit, calc((100% - 105px) / 4));}
div.gallery > br {display: none;}
.gallery-caption{
	margin:8px 0;
	font-size:1.3rem;
	letter-spacing:0.7px;
	line-height:1.9rem;
}
.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%;
	border:none;
}
.txt_center{text-align: center;}
.catch_copy{
	color: #178748;
	font-size: 2.6rem;
	letter-spacing: 1.3px;
	line-height: 4.68rem;
	margin-bottom: 25px;
}
.entry_box{
	background: #178748;
	border-radius: 10px;
	padding: 40px 30px;
	text-align: center;
	margin-bottom: 30px;
}
.entry_box--yellowgreen{background: #C5F66B;}
.entry_box--lightgreen{background: #F0F7E9;}
.entry_box h2{
	padding: 0;
	margin: 0 0 15px;
	color: #fff;
	font-size: 2.8rem;
	letter-spacing: 1.4px;
	line-height: 4rem;
}
.entry_box--yellowgreen h2{color: #178748;}
.entry_box--lightgreen h2{color: #333;}
.entry_box h2::before, .entry_box h2::after{display: none;}
.entry_box h2 span{
	font-family: var(--font_montserrat);
	font-weight: bold;
	font-size: 4.4rem;
	letter-spacing: 2.2px;
	line-height: 5.4rem;
	margin-right: 6px;
}
.entry_box p{
	color: #fff;
	margin-bottom: 17px;
}
.entry_box--yellowgreen p{color: #333;}
.entry_box--lightgreen p{color: #333;}
.entry_col{
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 30px;
}
.entry_link{
	display: inline-block;
	border-radius: 10px;
	vertical-align: top;
	overflow: hidden;
	border: 1px solid #ccc;
}
.entry_img{
	width: 280px;
	transition: transform .3s;
	border-radius: 0 !important;
}
.entry_link:hover .entry_img{transform:scale(1.05);}
.lead_txt{
	font-size: 2.4rem;
	letter-spacing: 1.92px;
	line-height: 4.32rem;
	text-align: center;
}
.lead_txt strong{font-weight: 500;}
/* ----- 私たちの仕事をもっと知る ----- */
.localnav{
	position: relative;
	padding: 0 30px;
	max-width: 1286px;
	margin: 0 auto 120px;
}
.localnav_box{
	max-width: 1226px;
	background: #178748;
	padding: 50px 30px;
	border-radius: 16px;
}
.localnav h2{
	color: #fff;
	text-align: center;
	margin: 0;
	padding-bottom: 30px;
	font-size: 2.6rem;
	letter-spacing: 1.3px;
	line-height: 3.7rem;
}
.localnav h2::before, .localnav h2::after{display: none;}
.ln_list{
	margin: 0;
	display: flex;
	justify-content: center;
	padding: 0;
	gap: 30px;
}
.ln_item{
	list-style: none;
	margin-bottom: 0;
	max-width: 353px;
	width: 100%;
}
.ln_link{
	display: flex;
	align-items: center;
	color: #000 !important;
	font-weight: bold;
	font-size: 1.8rem;
	letter-spacing: 0.9px;
	line-height: 2.6rem;
	text-decoration: none;
	background: #fff;
	border-radius: 10px;
	height: 86px;
	width: 100%;
	padding: 20px 80px 20px 30px;
	position: relative;
	transition: color .3s;
}
.ln_link:hover{color: #178748 !important;}
.ln_link::before,
.ln_link:after {
	content: '';
	display: block;
	position: absolute;
	right: 28px;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 37px;
	height: 37px;
	border-radius: 50%;
	transition: opacity 0.3s, border .3s;
	border: 1px solid;
}
.ln_link::before {
	background: #fff url(/recruit-newgrads/img/common/arrow_r_green.svg) no-repeat center center;
	border-color: #CCC;
}
.ln_link::after {
	background: #30A909 url(/recruit-newgrads/img/common/arrow_r_white.svg) no-repeat center center;
	border-color: #30A909;
	opacity: 0;
}
.ln_link:hover::before {opacity: 0;}
.ln_link:hover::after {opacity: 1;}

/* ----- sub_page ------ */
.page_sub .title_box {padding-bottom: 55px;}
.page_sub .page_title{
	font-size: 1.8rem;
	letter-spacing: 0.9px;
	line-height: 3.24rem;
}
.page_sub .page_title::before{
	font-size: 5rem;
	letter-spacing: 0.5px;
	line-height: 6.1rem;
	padding-bottom: 5px;
}

@media screen and (max-width:1024px){
.title_box{
	padding: 60px 30px 30px;
}
.page_title{
	font-size:2rem;
	letter-spacing:1px;
	line-height: 2.9rem;
}
.page_title::before{
	font-size: 5.8rem;
	letter-spacing: 0.58px;
	line-height: 7.1rem;
	padding-bottom: 7px;
}
.page_image img{margin-bottom: 60px;}
.content_area{padding: 0 30px 110px;}
h2{
	font-size:2.7rem;
	letter-spacing: 1.5px;
	line-height: 3.9rem;
	margin:75px 0 20px;
	padding-bottom: 15px;
}
h2::after{width:50px;}
h3{
	font-size:2.2rem;
	letter-spacing: 1.1px;
	line-height: 3.2rem;
	margin:45px 0 15px;
	padding-left: 14px;
}
h3::before{height: 23px;}
h4{
	font-size: 1.9rem;
	letter-spacing: 0.95px;
	line-height: 2.7rem;
	margin:25px 0 15px;
}
h5{
	font-size: 1.6rem;
	letter-spacing: 0.8px;
	line-height: 2.4rem;
	margin: 25px 0 15px;
}
h6{
	font-size: 1.4rem;
	letter-spacing: 0.7px;
	line-height: 2rem;
	margin: 25px 0 12px;
}
p{
	margin-bottom:25px;
	font-size: 1.4rem;
	letter-spacing: 1.4px;
	line-height: 2.5rem;
}
ul, ol{margin-bottom:15px;}
li{
	font-size: 1.4rem;
	letter-spacing: 1.4px;
	line-height: 2.5rem;
}
th, td{
	padding:17px 15px;
	font-size: 1.4rem;
	letter-spacing: 1.12px;
	line-height: 2.5rem;
}
th{width:170px;}
.page_link{
	gap: 30px;
	padding: 20px 20px 21px;
}
.page_link a{
	font-size: 1.5rem;
	letter-spacing: 1.5px;
}
.column_2, .column_3, .column_4, .gallery{
	grid-gap:25px;
	margin-bottom:20px;
}
.column_2, .gallery-columns-2{grid-template-columns:repeat(auto-fit, calc((100% - 25px) / 2));}
.column_3, .gallery-columns-3{grid-template-columns:repeat(auto-fit, calc((100% - 50px) / 3));}
.column_4{grid-template-columns:repeat(auto-fit, calc((100% - 75px) / 4));}
#pankuzu li{
	padding-right:13px;
	margin-right:10px;
	font-size:1.2rem;
	letter-spacing:1.2px;
	line-height:1.7rem;
}
.lead_txt{
	font-size: 1.8rem;
	letter-spacing: 1.44px;
	line-height: 3.24rem;
	text-align: center;
}
}

@media screen and (max-width:767px){
.title_box{padding: 30px 20px 30px;}
.page_title{
	font-size:1.4rem;
	letter-spacing:0.7px;
	line-height: 2rem;
}
.page_title::before{
	font-size: 3.8rem;
	letter-spacing: 0;
	line-height: 4.6rem;
	padding-bottom: 5px;
}
.page_image img{margin-bottom: 40px;}
.content_area{padding: 0 20px 100px;}
h2{
	font-size:2.5rem;
	letter-spacing: 1.25px;
	line-height: 3.6rem;
	margin:65px 0 20px;
}
h3{
	font-size:2.1rem;
	letter-spacing: 1.05px;
	line-height: 3rem;
}
h4{
	font-size: 1.8rem;
	letter-spacing: 0.9px;
	line-height: 2.6rem;
}
h5{
	font-size: 1.5rem;
	letter-spacing: 0.75px;
	line-height: 2.1rem;
}
h6{
	font-size: 1.3rem;
	letter-spacing: 0.65px;
	line-height: 1.9rem;
}
img{margin:auto;}
p{
	font-size:1.3rem;
	letter-spacing: 1.3px;
	line-height: 2.4rem;
}
li{
	font-size:1.3rem;
	letter-spacing: 1.3px;
	line-height: 2.4rem;
}
table{margin-bottom:15px;}
table:not(.row_table) th{width: 105px;}
.row_table th{width:100%;}
th, td{
	font-size:1.3rem;
	letter-spacing: 1.3px;
	line-height: 2.4rem;
}
.row_table th, .row_table td{
	display:list-item;
	list-style:none;
}
.row_table{table-layout:auto;}
.page_link{
	padding:10px 20px 17px;
	flex-direction: column;
	gap: 0;
	margin: 40px 0;
}
.page_link li{
	border-bottom: 1px solid #ddd;
}
.page_link a{
	display: block;
	width: 100%;
	font-size: 1.4rem;
	letter-spacing: 1.4px;
	padding: 8px 19px 8px 0;
}
.column_2, .gallery-columns-2{
	grid-template-columns: repeat(auto-fit, calc((100% - 13px) / 2));
	gap: 13px;
}
.column_3, .gallery-columns-3 {
	grid-template-columns: repeat(auto-fit, calc((100% - 26px) / 3));
	gap: 13px;
}
.column_4{grid-template-columns:repeat(auto-fit, 48.181%);}
#pankuzu{padding: 0 70px 0 20px;}
.tel{pointer-events:auto;}
.lead_txt{
	font-size: 1.6rem;
	letter-spacing: 1.28px;
	line-height: 2.88rem;
	text-align: left;
}
/* ----- sub_page ------ */
.page_sub .title_box {padding: 43px 20px 40px;}
.page_sub .page_title{
	font-size: 1.4rem;
	letter-spacing: 0.7px;
	line-height: 2rem;
}
.page_sub .page_title::before{
	font-size: 3rem;
	letter-spacing: 0.3px;
	line-height: 3.7rem;
	padding-bottom: 6px;
}
.catch_copy{
	font-size: 2.1rem;
	letter-spacing: 1.05px;
	line-height: 3rem;
	margin-bottom: 20px;
}
.entry_box{
	padding: 30px 20px;
	margin-bottom: 20px;
}
.entry_box h2{
	font-size: 1.8rem;
	letter-spacing: 0.9px;
	line-height: 2.6rem;
}
.entry_box h2 span{
	font-size: 3rem;
	letter-spacing: 1.5px;
	line-height: 3.7rem;
	margin-right: 5px;
}
.entry_col{
	flex-direction: column;
	gap: 10px;
}
.localnav{
	padding: 0 20px;
	margin-bottom: 100px;
}
.localnav_box{
	padding: 40px 20px;
	border-radius: 10px;
}
.localnav h2{
	padding-bottom: 25px;
	font-size: 2.1rem;
	letter-spacing: 1.05px;
	line-height: 3rem;
}
.ln_list{
	flex-direction: column;
	align-items: center;
	gap: 16px;
}
.ln_item{max-width: 295px;}
.ln_link{
	font-size: 1.4rem;
	letter-spacing: 0.7px;
	line-height: 2rem;
	height: 70px;
	padding: 20px 60px 20px 20px;
}
.ln_link::before,
.ln_link:after {
	right: 20px;
	width: 26px;
	height: 26px;
	background-size: 12px 8px;	
}

}

@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);}
}