@charset "utf-8";
.page_top{
	position:relative;
	width: 100%;
	max-width: 1260px;
	padding: 70px 30px 0;
	margin: 0 auto;
}
.error .page_top{max-width: 1060px;}
.page_top::before, .page_top::after{
	content: '';
	position: absolute;
	left: calc(50% - var(--vw-50));
	width: var(--vw-100);
	pointer-events: none;
}
.page_top::before{
	top: 0;
	height: 286px;
	background: url(/ja/recruit/img/common/bg_h1.jpg) no-repeat left top/cover;
	z-index: -2;
}
.page_top::after{
	top: calc(286px - 60px);
	height: 60px;
	background: linear-gradient(180deg, #FFFFFF00 0%, #FFFFFF 100%);
	z-index: -1;
}
.page_title{
	font-weight: bold;
	font-size: 3.6rem;
	line-height: 5.2rem;
	padding-bottom: 60px;
}
.page_title::before{
	content:attr(data-en);
	display: block;
	font-family: var(--font_inter);
	font-weight: bold;
	font-size: 2rem;
	line-height: 2.4rem;
	color: #CC0000;
	margin-bottom: 7px;
}
.page_top img{
	width: 100%;
	border-radius: 5px;
}
.content_area{
	max-width: 1060px;
	padding: 60px 30px 90px;
	margin:auto;
}
.error .content_area{padding-top: 0;}
.content_area > *:first-child{margin-top:0;}
.content_area img{border-radius: 5px;}
h2{
	position:relative;
	font-weight: bold;
	font-size:3rem;
	line-height: 4.4rem;
	padding-bottom:20px;
	margin:90px 0 28px;
}
h2::before, h2::after{
	content:'';
	position:absolute;
	display:block;
	left:0;
	bottom:0;
	height:2px;
}
h2::before{
	width:100%;
	background:#ddd;
}
h2::after{
	width:50px;
	background:#CC0000;
}
h3{
	position:relative;
	font-weight: bold;
	font-size: 2.4rem;
	line-height: 3.5rem;
	padding-left: 13px;
	margin: 50px 0 18px;
}
h3::before{
	content:'';
	position:absolute;
	top:5px;
	left:0;
	width:2px;
	height: 26px;
	background:#CC0000;
}
h4{
	font-weight: bold;
	font-size: 2rem;
	line-height: 2.9rem;
	margin:40px 0 18px;
}
h5{
	font-weight: bold;
	font-size: 1.8rem;
	line-height: 2.6rem;
	margin: 30px 0 15px;
}
h6{
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 2.4rem;
	margin: 20px 0 15px;
}
p{
	font-size: 1.6rem;
	line-height: 2.88rem;
	margin-bottom:15px;
}
ul, ol{
	padding-left:20px;
	margin-bottom:20px;
}
ul li{list-style:disc;}
ol li{list-style:decimal;}
ul li ul, ol li ol{margin-top:5px;}
ul li li {list-style: circle;}
li{
	font-size: 1.6rem;
	line-height: 2.88rem;
	margin-bottom: 5px;
}
table{
	width:100%;
	margin-bottom: 20px;
	border-top:1px solid #ccc;
}
th, td{
	position: relative;
	font-size: 1.6rem;
	line-height: 2.88rem;
	padding:15px 20px 16px;
	border-bottom:1px solid #ccc;
}
th{
	font-weight:bold;
	width:240px;
	background: #F8F8F8;
	text-align:left;
}
td *:last-child{margin-bottom:0;}
.scroll_table table{table-layout:auto;}
.scroll_table th, .scroll_table td{display:table-cell !important;}
.scroll_table thead th{
	width:auto;
	min-width:160px;
}
.scroll-hint-icon{
	top:0;
	right:0;
	bottom:0;
	left:0;
	width:130px;
	height:90px;
	margin:auto;
}
.scroll-hint-text{font-size: 1rem;}
#pankuzu{
	max-width: 1060px;
	padding: 0 30px;
	margin: auto;
}
#pankuzu ol{
	display:flex;
	flex-wrap:wrap;
	gap: 5px 0;
	padding: 15px 60px 0 0;
	margin:0 0 20px 0;
}
#pankuzu li{
	position:relative;
	font-size:1.3rem;
	line-height:1.9rem;
	padding-right:11px;
	margin:0 10px 0 0;
	list-style:none;
}
#pankuzu li::after{
	content:'';
	position: absolute;
	display: block;
	top: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 6px;
	height: 6px;
	border-top: 1px solid #222;
	border-right: 1px solid #222;
	transform: rotate(45deg);
}
#pankuzu li:last-child{
	padding:0;
	margin-right:0;
}
#pankuzu li:last-child::after{display: none;}
#pankuzu a{
	display:block;
	color:#222 !important;
}
#pankuzu li:last-child a{
	pointer-events:none;
	text-decoration:none !important;
}
#pankuzu a:hover{text-decoration:none !important;}
.page_link{
	overflow:hidden;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px 20px;
	padding: 26px 50px;
	margin: 60px 0;
	background: #F8F8F8;
	border-radius: 5px;
}
.page_link li{
	margin:0;
	list-style:none;
}
.page_link a{
	position:relative;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 2.4rem;
	color: #222 !important;
	padding-left: 32px;
	text-decoration:none;
	transition: color 0.3s;
}
.page_link a:hover{color: #880000 !important;}
.page_link a::before,
.page_link a::after{
	content: '';
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	transition: opacity 0.3s;
}
.page_link a::before{
	background: #fff url(/ja/recruit/img/common/arrow_b_red.svg) no-repeat center center;
	border: 1px solid #E57E7E;
}
.page_link a::after{
	background: #CC0000 url(/ja/recruit/img/common/arrow_b_white.svg) no-repeat center center;
	border: 1px solid #CC0000;
	opacity: 0;
}
.page_link a:hover::before{opacity: 0;}
.page_link a:hover::after{opacity: 1;}

.column_2, .column_3, .column_4{
	display:grid;
	grid-gap:45px 30px;
	margin:30px 0;
}
.column_2{grid-template-columns:repeat(2,1fr);}
.column_3{grid-template-columns:repeat(3,1fr);}
.column_4{grid-template-columns:repeat(4,1fr);}
.column_2.reverse > div:last-child{order: -1;}
.map, .movie_wrap{
	position:relative;
	overflow:hidden;
	width:auto;
	height:0;
	padding-bottom:56.25%;
}
.movie_wrap{margin:0 auto 30px;}
.map{
	min-height: 300px;
	margin: 0 auto 15px;
}
.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;
}
.catch_copy{
	font-size: 3rem;
	line-height: 4.4rem;
	color: #CC0000;
	padding: 0;
	text-align: center;
}
.catch_copy::before, .catch_copy::after{all: unset;}
.lead_txt{
	margin-bottom: 30px;
	text-align: center;
}
.caption{
	font-size: 1.3rem;
	line-height: 1.9rem;
	margin: 10px 0 0;
	text-align: center;
}
.img_full{
	width: 100%;
	margin: 30px 0;
}
.img_border{border: 1px solid #D3D3D3;}
.no_radius{border-radius: 0 !important;}
.zoom-in_txt{display: none;}
.entry_btn{
	display: block;
	font: inherit;
	font-weight: bold;
	font-size: 1.6rem;
	letter-spacing: 0;
	line-height: 2.4rem;
	color: #CC0000 !important;
	padding: 19px 20px !important;
	margin: 30px auto;
	width: 100%;
	max-width: 354px;
	background: none !important;
	border:1px solid #E57E7E;
	border-radius: 5px;
	text-decoration: none;
	text-align: center;
	cursor: pointer;
	transition: background .3s, color .3s, border .3s;
}
.entry_btn:hover{
	background:#CC0000 !important;
	border: 1px solid #CC0000;
	color:#fff !important;
}
.entry_btn span{
	position: relative;
	padding-right: 22px;/*CIS Edit*/
}
.entry_btn span::before, .entry_btn span::after{
	content:'';
	position:absolute;
	top: 0;
	bottom: 0;
	right: 0;/*CIS Edit*/
	margin: auto;
	width: 14px;
	height:14px;
	transition:opacity 0.3s;
}
.entry_btn span::before{background: url(/ja/recruit/img/common/popup.svg) no-repeat;}
.entry_btn span::after{
	background: url(/ja/recruit/img/common/popup_white.svg) no-repeat;
	opacity:0;
}
.entry_btn:hover span::before{opacity:0;}
.entry_btn:hover span::after{opacity:1;}
.entry_bnr_btn{
	display: block;
	width: 100%;
	max-width: 354px;
	margin: 30px auto 0;
	border:1px solid #ddd;
	border-radius: 5px;
	text-decoration: none;
	transition: border .3s;
}
.entry_bnr_mynavi {/*CIS Edit*/
	margin: 0px!important;
	padding: 0px!important;
}
.entry_bnr_mynavi img {/*CIS Edit*/
	width: 194px!important;
	text-decoration: none;
}
.entry_bnr_btn:hover{border-color: #CC0000;}
.btn_submit{
	-webkit-appearance: none;
	appearance: none;
	display: inline-block;
	font-weight: 400 !important;
	font-size: 1.6rem;
	color: #222;
	-webkit-text-fill-color: #222;
	padding:0 20px 0 0; /*CIS Edit*/
	background:url(/ja/recruit/img/common/popup.svg) no-repeat center right; /*CIS Edit*/
	/*padding:0 0 0 20px;
	background:url(/ja/recruit/img/common/popup.svg) no-repeat center left;*/
	text-decoration: underline;
	cursor: pointer;
}
.btn_submit:hover{text-decoration: none;}

@media screen and (max-width:1024px){
.page_top{
	padding: 50px 30px 0;
	margin: 0 auto;
}
.page_top::before{height: 200px;}
.page_top::after{
	top: calc(200px - 48px);
	height: 48px;
}
.page_title{
	font-size: 2.8rem;
	line-height: 4.48rem;
	padding-bottom: 35px;
}
.page_title::before{
	font-size: 1.4rem;
	line-height: 1.7rem;
	margin-bottom: 4px;
}
h2{
	font-size:2.6rem;
	line-height: 4.16rem;
	padding-bottom:15px;
	margin:65px 0 25px;
}
h3{
	font-size: 2.2rem;
	line-height: 3.52rem;
	padding-left: 13px;
	margin: 35px 0 15px;
}
h4{
	font-size: 1.8rem;
	line-height: 2.88rem;
	margin:35px 0 10px;
}
h5{
	font-size: 1.6rem;
	line-height: 2.56rem;
	margin: 20px 0 13px;
}
h6{
	font-size: 1.4rem;
	line-height: 2.24rem;
	margin: 20px 0 13px;
}
p{
	font-size: 1.4rem;
	line-height: 2.52rem;
	margin-bottom:10px;
}
li{
	font-size: 1.4rem;
	line-height: 2.52rem;
}
th, td{
	font-size: 1.4rem;
	line-height: 2.52rem;
	padding:12px 15px;
}
th{width:200px;}
.page_link{
	display: grid;
	grid-template-columns: repeat(3,1fr);
	gap: 0 20px;
	padding: 18px 30px 30px;
}
.page_link a{
	display: block;
	font-size: 1.4rem;
	line-height: 2.24rem;
	padding: 13px 20px 13px 32px;
	border-bottom: 1px solid #ddd;
}
.page_link a::before, .page_link a::after{top: 12px;}
.column_2, .column_3, .column_4{
	gap: 20px;
	margin: 20px 0;
}
.movie_wrap{margin-bottom: 20px;}
.catch_copy{
	font-size: 2.6rem;
	line-height: 4.16rem;
	margin-bottom: 20px;
}
.img_full{margin: 20px 0;}
.btn_submit{font-size: 1.4rem;}
}

@media screen and (max-width:767px){
.content_area{padding: 50px 20px 80px;}
.error .content_area{padding: 0 20px 80px;}
.page_top{padding: 40px 20px 0;}
.error .page_top{padding: 40px 20px 0;}
.page_title{padding-bottom: 25px;}
.error .page_title{
	font-size: 2.6rem;
	line-height: 4.16rem;
}
/*th{width:120px;} CIS Edit*/
th, td { /*CIS Edit*/
	display: block;
	width: 100%;
	font-size: 1.3rem;
	letter-spacing: 0.78px;
}
.scroll_table thead th{min-width:140px;}
#pankuzu{padding: 0 20px;}
.page_link{
	grid-template-columns: repeat(1,1fr);
	gap: 0;
	padding: 18px 20px 30px;
	margin: 40px 0;
}
.column_2, .column_3, .column_4{gap: 13px;}
.column_3, .column_4{grid-template-columns:repeat(2,1fr);}
img{margin: auto;}
.zoom-in_txt{
	display: block;
	font-size: 1.3rem;
	letter-spacing: 1.3px;
	line-height: 2.52rem;
	text-align: center;
}
.zoom-in_txt span{
	position: relative;
	padding-left: 32px;
}
.zoom-in_txt span::before{
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 26px;
	height: 26px;
	margin: auto;
	background: url(/ja/recruit/img/common/icon_zoom-in.svg) no-repeat center/contain;
}
.entry_btn{
	font-size: 1.4rem;
	line-height: 2rem;
	padding: 18px 20px !important;
	max-width: 320px;
}
.entry_bnr_btn{max-width: 335px;}
}