@charset "UTF-8";

/*
Theme Name: asuka_recruit
Author: AMOAMO
*/

/* リセット
================================================== */
* {margin: 0; padding: 0;}
.pc_no,
.pcm_no{display:none;}
*::after,
* {-webkit-box-sizing: border-box; -moz-box-sizing: border-box;	box-sizing: border-box;}
ul{padding: 0; margin: 0;}
li{padding: 0; margin: 0; list-style-type:none;}
img{border:none; vertical-align:top}
a:focus, *:focus {  outline:none; }
img a, a {
  -webkit-transition: .4s;
  transition: .4s;	
  outline: none;
}

/* フォント・文字装飾
================================================== */
.fw_500{font-weight: 500}
.fw_700{font-weight: 600}
.fw_700{font-weight: 700}

.fc_white{color:#fff}
.fc_blu{color:#61c0e0}
.fc_org{color:#f69a7b}

.fs_13{font-size:13px; line-height: 1.5em;}
.fs_14{font-size:14px; line-height: 1.6em;}
.fs_16{font-size:16px}
.fs_18{font-size:18px}
.fs_20{font-size:20px}
.fs_24{font-size:24px}
.fs_30{font-size:30px}
.fs_34{font-size:34px}

.ls01{letter-spacing: 0.1em;}
.ls03{letter-spacing: 0.3em;}
.ls05{letter-spacing: 0.5em;}
.ls06{letter-spacing: 0.6em;}
.ls1{letter-spacing: 1em;}
.ls2{letter-spacing: 2em;}

.vertical_title{writing-mode: vertical-rl;}


/* リンク
================================================== */
a:link{color: #000; text-decoration: none;}
a:visited{color: #000; text-decoration: none;}
a:active{color: #000; text-decoration: none;}
a:hover{color: #1d2087; text-decoration: none;}

a img:hover{filter: alpha(opacity=85);-moz-opacity:0.85;opacity:0.85;}
img a, a {
  -webkit-transition: .3s;
  transition: .3s;	
  outline: none;
}
/* 全体
================================================== */
html { scroll-behavior: smooth;}
body {
	font-family: "Lato","Noto Sans JP","游ゴシック", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  	font-weight: 500;
	color: #000;
	font-size: 16px;
	line-height: 2.2em;
	letter-spacing: 0.03em;
	-webkit-text-size-adjust: none;
}

/* レイアウト
================================================== */
.contents_wp{
	width:100%;
	max-width:1200px;
	margin-left: auto;
	margin-right: auto;
}
.contents_w85{
	width:85%;
	max-width:1200px;
	margin-left: auto;
	margin-right: auto;
}
.contents_full{
	width:100%;
	max-width:1500px;
	margin-left: auto;
	margin-right: auto;
}
.fl_right{float: right;}
.fl_left{float: left;}

.flex_wp,
.flex_wp_sp,
.flex_wp_spmd{
	display:flex;
	justify-content: space-between;
}
.flex_center{align-items: center;}
.flex_end{align-items: flex-end;}
.flex_wrp{flex-wrap: wrap;}

.txt_center, .w-txt_center{text-align:center;}
.txt_left{text-align:left!important;}
.txt_right{text-align:right}
.ps_rel{position: relative}
.ps_abs{position: absolute}
.clear{clear: both;}

.box_w25{width:25%}
.box_w30{width:30%}
.box_w35{width:35%}
.box_w40{width:40%}
.box_w45{width:45%}
.box_w48{width:48%}
.box_w50{width:50%}
.box_w55{width:55%}
.box_w60{width:60%}
.box_w65{width:65%}
.box_w70{width:70%}

img.w100{width:100%; height:auto;}
.br_right{border-radius: 0 40px 40px 0;}
.br_left{border-radius: 40px 0 0 40px;}
.br_all_30{border-radius: 30px}
.br_all_40{border-radius: 40px}

.br_50{border-radius:50px 0 50px 0;}
.br_70{border-radius:70px 0 70px 0;}
.br_80{border-radius:80px 0 80px 0;}

/* 背景
================================================== */
.lpur_bk{width:100%; background:#eeeef6;}
.lyew_bk{width:100%; background:#f5f5e9;}

/* margin、padding
================================================== */
.mt15{margin-top:15px}
.mt20{margin-top:20px}
.mt30{margin-top:30px}
.mt50{margin-top:50px}
.mt70{margin-top:70px}

.mb70{margin-bottom:100px}

.pt20{padding-top:20px}
.pt50{padding-top:50px}
.pt70{padding-top:70px}
.pt100{padding-top:100px}

.pb20{padding-bottom:20px}
.pb50{padding-bottom:50px}
.pb70{padding-bottom:70px}
.pb100{padding-bottom:100px}

.ptb70{padding:70px 0}
.ptb80{padding:80px 0}
.ptb100{padding:100px 0}

/* ヘッダー
================================================== */
#header_wp{
	position: fixed;
	max-width: 100%;
	width: 100%;
	z-index: 999;
	box-sizing: border-box;
}
.header_logo{
	position: absolute;
	width:30%;
	max-width:260px;
	top:20px;
	left:8%;
}
@media screen and (max-width: 1700px) {
	.header_logo{left:5%;}
}
.header_link{
	width:660px;
	position: absolute;
	top:0;
	right:3%;
	display:flex;
	justify-content: space-between;
}

.menu01{
	width:440px;
	background-color:#5961a7;
	border-radius:0 0 0 15px;
	padding:15px 0 15px 10px;	
}
.menu02{
	width:220px;
	background-color:#3b7ba6;
	border-radius:0 0 15px 0;
	padding:15px 0 15px;	
}
.menu01 ul li{width:50% }
.menu01 ul li:first-child{border-right:1px solid #fff}
.menu01 ul li a{
	display: block;
	font-size:15px;
	font-weight:500;
	line-height:1.5em;
	letter-spacing:0.1em;
	padding: 3px 40px 3px 45px;
	background : url("images/on_btn.png") no-repeat right 50px top 0.2em;
	background-size: 25px auto;
	color:#fff;
	transition: .4s;
}
.menu02 a{
	display: block;
	font-size:15px;
	font-weight:500;
	line-height:1.5em;
	letter-spacing:0.1em;
	padding: 3px 40px 3px 45px;
	background : url("images/mail_ic_on.png") no-repeat right 50px top;
	background-size: 30px auto;
	color:#fff;
	transition: .4s;
}
.menu01 ul li a:hover{
	background : url("images/on_btn.png") no-repeat right 45px top 0.2em;
	background-size: 25px auto;
}
.menu02 a:hover{
	background : url("images/mail_ic_on.png") no-repeat right 50px top;
	background-size: 30px auto;
}
.menu01 ul li a:hover{color:#a4a9d1;}
.menu02 a:hover{color:#9cbed5;}
.menu01 ul li a span{font-size:11px; font-weight:400; letter-spacing:0.05em;}
.menu02 a span{font-size:12px; font-weight:400; letter-spacing:0.05em;}

@media screen and (max-width: 1600px) {
	.header_logo{left:3%; width:25%; max-width:230px;}
}
@media screen and (max-width: 1200px) {
	.header_link{right:0;}
	.header_link{width:600px;}
	.menu01{width:400px; padding:15px 0 15px 10px;}
	.menu02{width:200px; border-radius:0;}
	.menu01 ul li a,
	.menu02 a{
		padding: 3px 30px 3px 35px;
		background : url("images/on_btn.png") no-repeat right 40px top 0.2em;
		background-size: 25px auto;
	}
	.menu01 ul li a:hover,
	.menu02 a:hover{
		background : url("images/on_btn.png") no-repeat right 35px top 0.2em;
		background-size: 25px auto;
	}
}
@media screen and (max-width: 1050px) {
	.header_link{width:495px;}
	.menu01{width:320px;}
	.menu02{width:175px;}
	.menu01 ul li a,
	.menu02 a{
		padding: 3px 25px 3px 25px;
		background : url("images/on_btn.png") no-repeat right 25px top 0.2em;
		background-size: 20px auto;
		font-size:14px;
	}
	.menu01 ul li a:hover,
	.menu02 a:hover{
		background : url("images/on_btn.png") no-repeat right 20px top 0.2em;
		background-size: 20px auto;
	}
	.menu01 ul li a span{font-size:10px; letter-spacing:0;}
	.menu02 a span{font-size:11px; letter-spacing:0;}
}

/* TOPスライダー
================================================== */
.top_wp{
	width:100%;
	padding-bottom:30px;
	background: -moz-linear-gradient(top, #eeeef6 80%, #ffffff 80%, #ffffff 100%);
  	background: -webkit-linear-gradient(left, #eeeef6 80%, #ffffff 80%, #ffffff 100%);
  	background: linear-gradient(to bottom, #eeeef6 80%, #ffffff 80%, #ffffff 100%);	
}
.top_wp_front{
	width:100%;
	background:url("images/left-shape.png") no-repeat left bottom;
	background-size:55% auto;
	padding-bottom:8%;
}
#viewer_wp{
	width:100%;
	height:830px;
	margin: 0 auto;
	position: relative;
}
.top_catch{
	position:absolute;
	left:10%;
	bottom:7%;
	width:35%;
	z-index:10;
}
.top_catch img{
	width:100%;
	max-width:500px;
	height:auto;	
	opacity: 0;
	transform: translateY(30px);
	animation: fadeInUp 1.5s ease-out forwards;
}
@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* 伸びるライン */
.line-animation,
.page_line-animation{
	position:absolute;
	bottom:8%;	
	width: 20%;
	height: 1px;
	background: linear-gradient(90deg, #000, #000);
	transform: scaleX(0);
	transform-origin: left;
	animation: lineScale 1.5s ease-out forwards;
	animation-delay: 0.8s;
	z-index:9999;
}
@keyframes lineScale {
  to {
    transform: scaleX(1);
  }
}

.sliderwp{
	float:right;
	position: relative;
	width: 80%;
	margin: 0;
	padding: 0;
}

.fadeslider li{
	width: 100%;
	height: 830px;
	overflow: hidden;	
	position:absolute;
}

.fadeslider img.slider_img{
	width:100%;
	height: 100%;
	object-fit: cover;
	vertical-align:top;
  border-radius:0 0 0 400px;
}
@media screen and (max-width: 1600px) {
	.sliderwp{width: 85%;}
	#viewer_wp,
	.fadeslider li{height:800px}
	.top_catch{left:6%}
	.line-animation {width: 20%;}
}
@media screen and (max-width: 1300px) {
	.sliderwp{width: 87%;}
	#viewer_wp,
	.fadeslider li{height:750px}
}
/* TOPページ
================================================== */
.mbpur_bk{
	width:100%;
	background:url("images/pur_bk.jpg") no-repeat center;
	background-size:cover;
}
.top_msgbk{
	width:100%;
	position:relative;
	padding-top:60px;
}
img.top_msgimg_01{
	width:15%;
	height:auto;
	position:absolute;
	top:30%;
	left:0;
	border-radius:0 10px 10px 0;
}
img.top_msgimg_02{
	width:30%;
	height:auto;
	position:absolute;
	top:0;
	right:0;
	border-radius:10px 0 0 10px;
}
.top_msg{
	width:50%;
	max-width:570px;
	margin:0 auto;
}
.top_msg_title{
	width:100%;
	max-width:280px;
	padding:50px 0 20px;
	background:url("images/top/brk_right.png"), url("images/top/brk_left.png");
	background-repeat:no-repeat, no-repeat;
	background-position:right top, left bottom;
	background-size:40px auto, 40px auto;
	margin:0 auto 50px;
	display: flex;
  	justify-content: center;
}
.top_msg_title_inner{
	display: flex;
	flex-direction: row-reverse;
	gap: 1em;
	align-items: flex-end;
}
.top_msg_title h2{
	writing-mode: vertical-rl;
	font-size:32px;
	font-weight:700;
	letter-spacing:0.2em;
	line-height:2.0em;
	margin-bottom: -1px;             /* 念のため */
  display: block;
	
}
.top_msgimg_bk{
	width:100%;
	background: linear-gradient(to bottom, transparent 50%, #e5e6ed 50%);
	padding-top:50px;
}
.top_msgimg{
	width:85%;
	max-width:1000px;
	margin:60px auto 0;
}
.top_msgimg img{
	border-radius:10px 150px 10px 150px;
}
.top_msgimg p{
	padding:30px 0 40px;
	text-align:center;
}
.top_work_bk{
	width:100%;
	padding-top:230px;
	background:url("images/lpur_wave.png"), url("images/top/leaf_bk.jpg"), url("images/top/leaf_bk_r.jpg");
	background-repeat:no-repeat, no-repeat, no-repeat;
	background-position:center top, left top 3%, right bottom 20%;
	background-size:100% auto, 50% auto, 40% auto;	
}
.top_work_wp{
	width:80%;
	max-width:1300px;
	margin:0 auto;
	padding:50px 0;
	display:flex;
	justify-content: space-between;
}
.top_work_text{width:38%;}
.wkt_left{padding:30px 0 10px 50px}
.wkt_right{padding:30px 50px 10px 0}
.top_work_img{width:57%;}
p.tw-sub_title{
	font-size:15px;
	font-weight:600;
	letter-spacing:0.1em;
	color:#1d2087;
}
p.tw-sub_title span{
	border-top:1px solid #1d2087;
	border-left:1px solid #1d2087;
	border-right:1px solid #1d2087;
	padding:0.8em 2em 0.3em;
}
.top_work_text h2,
.top_work2_text h2{
	font-size:32px;
	font-weight:600;
	line-height:1.7em;
}
.top_work_text h2{margin:25px 0 30px;}
.top_work2_text h2{margin:0 0 50px;}
.top_work_text p,
.top_work2_text p{line-height:2.0em; font-size:15px}

.top_work_img img{
	width:100%;
	height: 450px;
	object-fit: cover;
	border-radius:10px;
}

.text_link{
	width:100%;
	margin-top:45px;
	padding-bottom:0.5em;
}
.text_link a{
	display:block;
	border-bottom:1px solid #333;
	background : url("images/base_btn.png") no-repeat right 18px center;
	background-size: 60px auto;
	color:#000;
	font-size:20px;
	font-weight:700;
	padding:0 65px 7px 3px;
	transition: .4s;
}
.text_link a:hover{
	border-bottom:1px solid #424d9b;
	background : url("images/off_btn.png") no-repeat right 8px center;
	background-size: 60px auto;
	color:#444444;
}
.text_link a span{font-size:15px;}

.top_work2_bk{
	width:100%;
	margin-top:130px;
	padding-bottom:50px;
 	background: -moz-linear-gradient(top, #ffffff 30%, #e5e6ed 30%, #e5e6ed 100%);
  	background: -webkit-linear-gradient(left, #ffffff 30%, #e5e6ed 30%, #e5e6ed 100%);
  	background: linear-gradient(to bottom, #ffffff 30%, #e5e6ed 30%, #e5e6ed 100%);	  	
}
.top_work2_img{
	width:55%;
	border-radius: 0 10px 250px 0;
  	overflow: hidden;
}
		
.top_work2_img ul.top_scroll{width:100%; margin-bottom:15px}
.top_work2_img ul.top_scroll li{margin-right:10px;}
.top_work2_img ul.top_scroll li img{
	width:100%;
	height: 400px;
	object-fit: cover;
}
.top_work2_img img.top_workimg{
	width:100%;
	height: 420px;
	object-fit: cover;
}
.top_work2_text{width:40%; padding-right:15%; padding-bottom:40px;}
.top_target_bk{
	width:100%;
	padding:270px 0 150px;
	background:url("images/pur_wave.png") #f4f4f4 no-repeat center top;
	background-size:100% auto;	
}
.top_target_title{
	width:80%;
	max-width:1000px;
	margin:0 auto;
	text-align:center;
}
.tg_title{
	width:100%;
	max-width:650px;
	margin:0 auto 40px;
	padding:40px 60px;
	background:url("images/top/brk-y_left.png"), url("images/top/brk-y_right.png");
	background-repeat:no-repeat, no-repeat;
	background-position:left top, right bottom;
	background-size:150px auto, 150px auto;
}
.top_target_wp{
	width:90%;
	max-width:1300px;
	margin:50px auto;
	background:url("images/top/target-bk.jpg") no-repeat center center;
	background-size: cover;
	border-radius:10px 150px 10px 150px;
}
.top_target_box{
	width:80%;
	max-width:750px;
 	margin:0 auto;
	background:#fff;
	padding:70px 80px 20px;
}
.top_target_box ul{
	padding-bottom:20px;
	margin-bottom:40px;
	border-bottom:1px solid #333;
}
.top_target_box ul li{
	background : url("images/list_mark.png") no-repeat left 1em top 0.7em;
	background-size: 30px auto;
	font-weight:600;
	padding-left:60px;
	margin-bottom:0.7em;
}
.top_target_box p{
	font-size:16px;
	font-weight:700;
	text-align:center;
}
.top_btnwp{position:relative; bottom:-50px; text-align:center}
a.top_btn{
	display: inline-block;
	font-weight:700;
	font-size:17px;
	color:#1d2087;
	letter-spacing:0.07em;
	padding: 17px 110px 17px 80px;
	background: url("images/off_btn.png") #fff no-repeat right 40px center;
	background-size: 40px auto;
	border-radius: 50px;
	box-shadow: 0 0 15px rgba(115,127,150,0.4);
	transition: .4s;
}
a.top_btn:hover{
	background: url("images/on_btn.png"), linear-gradient(45deg, #595cae, #2b6f9e);
	background-repeat: no-repeat;
	background-position: right 35px center, left top;
	background-size: 40px auto, cover;
	color:#fff;
}

/* 固定ページ　タイトル
================================================== */
.page_header_wp{
	width:100%;
	padding-bottom:30px;
	background: -moz-linear-gradient(top, #eeeef6 50%, #ffffff 50%, #ffffff 100%);
  	background: -webkit-linear-gradient(left, #eeeef6 50%, #ffffff 50%, #ffffff 100%);
  	background: linear-gradient(to bottom, #eeeef6 50%, #ffffff 50%, #ffffff 100%);	
}
.page_header_bk{
	width:100%;
	background:url("images/left-shape.png") no-repeat left bottom;
	background-size:40% auto;
	padding-bottom:8%;
}
.recruit_header_wp{
	width:100%;
	background: -moz-linear-gradient(top, #ffffff 50%, #eeeef6 50%, #eeeef6 100%);
  	background: -webkit-linear-gradient(left, #ffffff 50%, #eeeef6 50%, #eeeef6 100%);
  	background: linear-gradient(to bottom, #ffffff 50%, #eeeef6 50%, #eeeef6 100%);	
}
.recruit_header_bk{
	width:100%;
	background:url("images/left-shape-wht.png") no-repeat left bottom;
	background-size:40% auto;
	padding-bottom:8%;
}
#page_title_wp{
	width:100%;
	height:400px;
	margin: 0 auto;
	position: relative;
}
.page_title{
	position:absolute;
	left:10%;
	bottom:15%;
	z-index:10;
}
.page_title h2{
	font-size:38px;
	letter-spacing: 0.07em;
	font-weight:600;
	animation: fadeInUp 1.5s ease-out forwards;
}
.page_titleimg{
	float:right;
	position: relative;
	width: 80%;
	margin: 0;
	padding: 0;
}

.page_titleimg img{
	width: 100%;
	height: 400px;
	object-fit: cover;
	vertical-align:top;
  	border-radius:0 0 0 400px;
}
@media screen and (max-width: 1500px) {
	#page_title_wp,
	.page_titleimg img{height:350px;}
}


/* 働く環境
================================================== */
.envi_meg_wp{
	width:100%;
	max-width:1300px;
	margin:50px auto;
}
.envi_meg_img{width:65%;}
.envi_meg_img img{width:100%; height:auto; border-radius:10px 100px 10px 100px;}
.envi_meg_text{	width:32%;	padding:15px 50px 15px 20px;}
@media screen and (max-width: 1600px) {
	.envi_meg_wp{max-width:100%;}
	.envi_meg_img{width:57%;}
	.envi_meg_img img{
		width:100%;
		height: 450px;
		object-fit: cover;
		 border-radius:0 100px 0 100px;
	}
	.envi_meg_text{	width:38%; padding:15px 100px 15px 0;}
}
@media screen and (max-width: 1300px) {
	.envi_meg_img{width:50%;}
	.envi_meg_img img{height: 400px;}
	.envi_meg_text{	width:45%;}
}
.page_main_text{
	width:85%;
	max-width:1000px;
	margin:0 auto;
	padding:50px 0;
}
.page_main_text h2{
	font-size:32px;
	font-weight:600;
	line-height:1.7em;
	margin:25px 0 30px;
}
.page_main_text p{line-height:2.0em; font-size:15px}
.loop_image {
	width: 100%;
	height: 400px;
	overflow: hidden;
	margin:60px auto 0;
}

.loop_inner {
	display: flex;
	width: max-content;
	height: 100%;
	animation: marquee 50s linear infinite;
	will-change: transform;
}

.loop_inner img {
	height: 100%;
	width: auto;
	object-fit: cover;
	flex-shrink: 0;
}
@keyframes marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
.page-pur_bk{
	width:100%;
	background:url("images/page/page-pur_bk.jpg") no-repeat center;
	background-size:cover;	
}
.envi_sc_title{
	width:80%;
	max-width:380px;
	padding:100px 0 30px;
	background:url("images/top/brk_right.png"), url("images/top/brk_left.png");
	background-repeat:no-repeat, no-repeat;
	background-position:right top 50px, left bottom;
	background-size:40px auto, 40px auto;
	margin:0 auto;
  display: flex;
  justify-content: center;
}
.envi_sc_title_inner{
  display: flex;
  flex-direction: row-reverse;
  gap: 3em;	
}
.envi_sc_title_inner p{
	writing-mode: vertical-rl;
	font-size:22px;
	font-weight:600;
	letter-spacing:0.1em;
	line-height:2.0em;
	margin: 0;
}
.envi_sc_text{
	width:80%;
	max-width:800px;
	margin: 0 auto;
	padding:80px 0 30px;
}
.development_bk{
	width:100%;
	padding:200px 0 20px;
	background:url("images/lpur_wave.png"),  url("images/page/dev_text.png");
	background-repeat:no-repeat, no-repeat;
	background-position:center top, left bottom;
	background-size:100% auto, 55% auto;
}
@media screen and (max-width: 1600px) {
	.development_bk{
		background:url("images/lpur_wave.png"),  url("images/page/dev_text.png");
		background-repeat:no-repeat, no-repeat;
		background-position:center top, left bottom;
		background-size:100% auto, 65% auto;
	}
}
.development_bottom{
	width:100%;
	padding-bottom:100px;
	background:url("images/page/kensyu_bk.jpg") #ffffff no-repeat center bottom;
	background-size:100% auto;	
}
.development_wp{
	width:85%;
	max-width:1050px;
	margin:0 auto 40px;
}
.dev_inner{
	width:31%;
	background:rgba(255,255,255,0.9);
	border:1px solid #ccc;
	border-radius:10px;
	padding:40px 50px 50px;
	position:relative;
	text-align:center;
}
.dev_inner img.dev_no{
	position:absolute;
	top:-3px;
	left:0;
	right:0;
	margin:auto;
	width:60px;
	height:auto;
}
.dev_inner h3{
	font-size:22px;
	letter-spacing:0.07em;
	padding-top:40px;
	margin-bottom:20px;
}
.sp_devimg img{
	width:70%;
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	object-fit: cover;
	border: 8px solid rgba(181,184,212,0.4);	
}
@media screen and (max-width: 1200px) {
	.development_wp{width:90%;}	
	.dev_inner{
		width:32%;
		padding:40px 30px 50px;
	}
	.dev_inner h3{padding-top:30px;}
	.dev_inner img.dev_no{width:55px;}
}
.sp_devtext{margin-top:25px; font-size:14px; line-height:1.8em;}
p.dev_info{
	text-align:center;
	font-size:14px;
	line-height:1.7em;
}
.career_bk{
	background: url("images/page/career_text.png") no-repeat right top 40%;
	background-size:60% auto;
	padding:80px 0 50px;
}
@media screen and (max-width: 1600px) {
	.development_bk{
		background:url("images/lpur_wave.png"),  url("images/page/dev_text.png");
		background-repeat:no-repeat, no-repeat;
		background-position:center top, left bottom;
		background-size:100% auto, 65% auto;
	}
	.career_bk{
		background: url("images/page/career_text.png") no-repeat right top 40%;
		background-size:70% auto;
	}
}
.career_img{
	width:85%;
	max-width:1000px;
	margin:0 auto;
}
.page_ylwwave_bk{
	width:100%;
	padding:180px 0 150px;
	background:url("images/ywl_wave.png") #ffffff no-repeat center top;
	background-size:100% auto;		
}
.benefit_wp{
	width:90%;
	max-width:1050px;
	margin:0 auto;
	padding:70px 100px 35px;
	border-radius:10px 140px 0 0;
	background:#eeeef6;
}
.event_wp{
	width:90%;
	max-width:1050px;
	margin:0 auto;
	padding:50px 100px 40px;
	border-radius:0 0 10px 140px;
	background:#d6d6e7;
}
@media screen and (max-width: 1200px) {
	.page_ylwwave_bk{padding:150px 0 100px;}
	.benefit_wp{
		width:100%;
		max-width:100%;
		border-radius:0 100px 0 0;
	}
	.event_wp{
		width:100%;
		max-width:100%;
		border-radius:0 0 0 100px;
	}
}
.benefit_title, .benefit_inner{width:31%}
.benefit_title{
	text-align: left;
	padding-left:40px;
}
.benefit_title-inner{
  writing-mode: vertical-rl;
  column-count: 1;
  column-gap: 1em;
  display: inline-block;
}
.benefit_title h3{font-size:26px; font-weight:700; letter-spacing:0.08em;}
.benefit_title p.en_title{font-size:12px; letter-spacing:0.08em; color:#1d2087; font-weight:400;}

.benefit_inner{
	padding:30px;
	background:#fff;
	border-radius:10px;
	text-align:center;
	margin-bottom:25px;
}
.benefit_inner p.bft_title{
	font-size:19px;
	font-weight:700;
	letter-spacing:0.05em;
	margin-bottom:15px;
}
.benefit_inner img{
	width:50%;
	max-width:100px;
	height:auto;
}
.benefit_inner p.bft_text{padding-top:15px;	line-height:1.6em; font-size:15px}

/* 募集要項
================================================== */
.recruit_wp,
.recruit_fullwp,
.requirements-btn{
	width:80%;
	max-width:1100px;
	margin-left: auto;
	margin-right: auto;	
}
.recruit_wp{padding:75px 0}
.requirements-btn{text-align:right}
.requirements-btn a{
	display: inline-block;
	font-weight:600;
	font-size:16px;
	color:#fff;
	letter-spacing:0.07em;
	padding: 15px 100px 15px 70px;
	background: url("images/down_btn.png"), linear-gradient(45deg, #595cae, #2b6f9e);
	background-repeat: no-repeat;
	background-position: right 30px center, left top;
	background-size: 35px auto, cover;
	border-radius:50px;
	box-shadow: 0 0 15px rgba(115,127,150,0.4);
	transition: .4s;
}
.requirements-btn a:hover{
	background: url("images/down_btn_on.png"), linear-gradient(45deg, #595cae, #2b6f9e);
	background-repeat: no-repeat;
	background-position: right 30px bottom 15px, left top;
	background-size: 35px auto, cover;
	color:#cdd7ec;
}
.requirements_bk{
	width:100%;
	padding-top:130px;
	background:url("images/lpur_wave.png") no-repeat center top;
	background-size:100% auto;
}
.requirements_box{
	background:#fff;
	border-radius:20px;
	padding:70px 70px 30px;
}
@media screen and (max-width: 1200px) {
	.recruit_fullwp{width:100%}
	.requirements_box{padding:60px 50px 30px;}
}
.hires_wp{
	width:100%;
	max-width:300px;
	display:flex;
	justify-content: space-between;	
}
.hires_half{width:48%;}

@media screen and (max-width: 1300px) {
	.wktl-sp_no{display:none;}
}
h2.recruit_line_ttl{
	position: relative;
	display: inline-block;
	margin-bottom: 1.2em;
	font-weight:600;
	font-size:28px;
}
h2.recruit_line_ttl::before {
  content: '';
  position: absolute;
  bottom: -20px;
  display: inline-block;
  width: 60px;
  height: 4px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #5961a7;
  border-radius: 2px;
}
p.recruit_en_ttl{font-size:14px; color:#999;}
.recruit_infowp{
	width:100%;
	margin:60px auto 80px;
}
.rec_text{
	width:45%;
	padding:20px 0 0 20px;
	text-align:justify;
	line-height:2.0em;
}
.rec_text p{line-height:2.0em; font-size:15px}
.rec_text h3{margin:35px 0 13px;}
.rec_text h3 span{
	background:#5961a7;
	border-radius:30px;
	padding:0.7em 2em;
	color:#fff;
	font-size:14px;
	font-weight:500;
}
.rec_text p.rccom_info{font-size:14px; padding-left:10px; line-height:1.8em}
.rec_text p.add{
	margin-top:10px;
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding:15px 10px;
	line-height:1.8em;
	text-align:left;
}
.rec_text p.add span.tel{margin-right:1.5em}
.rec_img{width:47%}
.rec_img img{border-radius:15px}
section#company-info > .recruit_wp { margin-bottom: 50px;}
/* フッター
================================================== */
#footer_wp{
	background: url("images/footer/footer_bk.jpg") no-repeat center;
	background-size:cover;
	padding:120px 0;
}
.footer_contact{
	width:88%;
	max-width:1100px;
	margin:0 auto;
}
.ft_contact_tl{width:40%;}
.ft_contact_tl h3 img{
	width:100%;
	max-width:400px;
	height:auto;
}
.ft_contact{width:50%; text-align:center}
img.ft_tel{
	width:80%;
	max-width:320px;
	height:auto;
	display:block;
	margin:0 auto 5px;
}
p.ft_tel_time{color:#fff; padding-left:15px;}
p.ft_tel_time span{margin-left:20px;}
.ft_btn{margin-top:25px}
.ft_btn a{
	display: inline-block;
	font-weight:700;
	font-size:18px;
	padding: 20px 50px 20px 110px;
	background : url("images/mail_ic.png") #fff no-repeat left 40px center;
	background-size: 45px auto;
	color:#1d2087;
	border:1px solid #fff;
	border-radius: 50px;
	transition: .4s;
}
.ft_btn a:hover{
	background: url("images/mail_ic_on.png"), linear-gradient(45deg, #595cae, #2b6f9e);
	background-repeat: no-repeat;
	background-position: left 40px center, left top;
	background-size: 45px auto, cover;
	border:1px solid #fff;
	color:#fff;
}
.footer_info{
	width:85%;
	margin:0 auto;
	padding:40px 0;
}
.ft_info_tl{width: 30%;}
.ft_info_tl img.ft_logo{
	width:100%;
	max-width:250px;
	height:auto;
}
.ft_info_list{width:70%; text-align:right;}

.ft_info_list ul li{
	display:inline-block;
	margin:0 25px;
}
.ft_info_list ul li a{font-weight:700; padding:0 0.3em}
.ft_info_list ul li.outside_link a{
	background : url("images/link_icon.png") no-repeat right 0.3em center;
	background-size: 15px auto;
	padding:0 32px 0 10px;
}

.hover-underline {
  position: relative;
}
.hover-underline::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 1px;
  background-color: #1d2087;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}
.hover-underline:hover::after {
  transform: scaleX(1);
}
.copy{
	text-align:right;
	padding:15px 7% 40px;
	font-size:12px;
	letter-spacing:0.05em;
}
@media screen and (max-width: 1100px) {
	.ft_btn a{
		font-size:16px;
		padding: 17px 35px 17px 90px;
		background : url("images/mail_ic.png") #fff no-repeat left 35px center;
		background-size: 40px auto;
	}
	.ft_btn a:hover{
		background: url("images/mail_ic_on.png"), linear-gradient(45deg, #595cae, #2b6f9e);
		background-repeat: no-repeat;
		background-position: left 35px center, left top;
		background-size: 40px auto, cover;
	}
	.footer_info{width:94%;}
	.ft_info_tl{width: calc(100% - 530px); padding-right:3%}
	.ft_info_list{width:550px;}
	.ft_info_list ul li{margin:0 10px;}
	.ft_info_list ul li a{font-weight:600; font-size:14px;}
	.copy{padding:15px 5% 40px;}
}
/* 左固定バナー
================================================== */
.fixed-banner {
  position: fixed;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  writing-mode: vertical-rl;
	background: url("images/side_arrow.png"), linear-gradient(45deg, #5c5fa7, #3084a6);
	background-repeat: no-repeat;
	background-position: bottom 25px left 50%, left top;
	background-size: 60px auto, cover;
	color:#fff!important;
  padding: 40px 15px 100px 25px;
  letter-spacing: 0.05em;
	font-size:18px;
	line-height:1.6em;
	border-radius: 40px 0 0 40px;
	box-shadow: 0 4px 12px rgba(0,0,0,0.2);
	transition: .4s;	
	z-index: 999;
}
.fixed-banner:hover{
	background: url("images/side_arrow.png"), linear-gradient(45deg, #595cae, #2b6f9e);
	background-repeat: no-repeat;
	background-position: bottom 25px left 60%, left top;
	background-size: 60px auto, cover;
}
.fixed-banner span{font-size:12px}
/*　clearfix */
.clearfix:after{
  content: " ";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix{
  min-height: 1px;
}

* html .clearfix{
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}
