@charset "utf-8";

/*********** KV ***********/

.kv {
	position: relative;
	background: url("../../images/recruit/top/top_kv.png") center top / cover;
	width: 100vw;
	height: 100vh;
    min-height: 600px;
	z-index: 1;
}
.kv .cc {
	position: absolute;
	width: 650px;
	bottom: 130px;
	left: 12%;
	color: #fff;
	font-size: 120px;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: 0.2rem;
	mix-blend-mode: exclusion;
}
.kv .fv_bt {
	position: absolute;
	width: 100%;
	height: 85px;
	bottom: 0;
	left: 0;
	margin: auto;
	background: #A50000;
	color: #fff;
	font-weight: 500;
}
.kv .fv_bt p {
	padding-top: 1.7em;
	padding-left: 12%;
	font-size: 17px;
	letter-spacing: 0.2em;
}


/*********** ABOUT ***********/

.r_top_about {
	position: relative;
	background: #A50000;
	color: #fff;
}
.r_top_about .img_1 {
	position: absolute;
	width: 315px;
	top: 200px;
	left: 0;
	right: -950px;
	margin: auto;
}
.r_top_about .img_2 {
	position: absolute;
	width: 335px;
	top: 400px;
	left: -1100px;
	right: 0;
	margin: auto;
}
.r_top_about dl {
	width: 480px;
	margin: 100px auto;
	line-height: 2.2;
}
.r_top_about dl dt {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	float: left;
	font-size: 24px;
	font-weight: 300;
	letter-spacing: 0.3em;
}
.r_top_about dl dd {
	width: 375px;
	margin-left: auto;
	padding-top: 90px;
}


/*********** BUSINESS ***********/

.r_top_business {
	position: relative;
	margin: 100px auto;
	padding: 30px 0 0;
}
.r_top_system {
	position: relative;
	margin: 0 auto 50px;
	padding: 30px 0;
}
.r_top_business .img_box,
.r_top_system .img_box {
	position: absolute;
	width: calc(50% - 85px);
	height: 500px;
	top: 0;
	right: 85px;
	background: url("../../images/recruit/top/top_business_img.png") no-repeat center top / cover;
	display: block;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_system .img_box {
	background: url("../../images/recruit/top/top_system_img.png") no-repeat center top / cover;
}
.r_top_business .img_box:hover,
.r_top_system .img_box:hover{
	filter: grayscale(0%);
}
.r_top_business .box,
.r_top_system .box {
	position: relative;
	width: 445px;
	margin: 0 auto 0 0;
}


/*********** INTERVIEW ***********/

.r_top_interview {
	position: relative;
	background: #A50000;
	color: #fff;
	padding-bottom: 120px; 
}
.r_top_interview {
	position: relative;
	background: #A50000;
	color: #fff;
}
.r_top_interview .slide-none-box {
	width: 45%;
	margin: 100px 0 0;
}
.r_top_interview .article {
	position: relative;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_interview .article:hover {
	filter: grayscale(0%);
}
.r_top_interview .article a {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.r_top_interview .article_txt_box dl {
	margin-top: 1.5em;
	padding: 0 60px;
	box-sizing: border-box;
}
.r_top_interview .article_txt_box dl dt {
	font-weight: 700;
	margin-bottom: 1.5em;
}

.r_top_interview .swiper-slide {
  transition: transform 0.6s;
}
.r_top_interview .swiper-slide-prev,
.r_top_interview .swiper-slide-next,
.r_top_interview .swiper-slide-duplicate-prev,
.r_top_interview .swiper-slide-duplicate-next {
	transform: scale(0.85);
	opacity: 0.5;
}
.r_top_interview .swiper-button-next {
    background: url("../../images/recruit/top/slide_navi_r.png") no-repeat center / cover;
	width: 35px;
	height: 35px;
	top: 38%;
	left: 0;
	right: -50%;
	margin: auto;
}
.r_top_interview .swiper-button-prev {
    background: url("../../images/recruit/top/slide_navi_l.png") no-repeat center / cover;
	width: 35px;
	height: 35px;
	top: 38%;
	left: -50%;
	right: 0;
	margin: auto;
}
.swiper-button-prev:after, .swiper-button-next:after {
	display: none;
}

/*********** COMPANY ***********/

.r_top_company {
	width: 100%;
	background: url("../../images/recruit/top/top_company_bg.png") no-repeat center / cover;
	color: #fff;
}
.r_top_company .col2_box li {
	width: calc(50% - 1px);
	margin:0 0 5% 0;
}
.r_top_company .ttl_box_bk {
	margin-bottom: 0;
}

/*********** Pitch ***********/

.r_top_pitch .pitch_box {
	position: relative;
	padding-top: 56%;
	height: 0;
	overflow: hidden;
}
.r_top_pitch .pitch_box iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/*********** QUESTION ***********/

.r_top_faq .qa_list li {
	
}
.r_top_faq .qa_list li:last-child {
	border-bottom: 1px solid #000;
}

/*アコーディオン全体*/
.accordion-area{
    list-style: none;
    width: 100%;
    margin: auto;
}
.accordion-area li{
	padding: 25px 0;
	border-top: 1px solid #000;
}
.accordion-area li:last-child {
	border-bottom: 1px solid #000;
}

/*アコーディオンタイトル*/
.title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    padding: 10px 60px 10px 40px;
    transition: all .3s ease;
	background: url("../../images/recruit/top/top_qa_icon.png") no-repeat center left;
	background-size: 26px;
	line-height: 1.5;
	font-size: 1.15rem;
}

/*アイコンの＋と×*/
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 20px;
    height: 1px;
    background-color: #000;
}
.title::before{
    top:50%;
    right: 15px;
    transform: rotate(0deg);
}
.title::after{
    top:50%;
    right: 15px;
    transform: rotate(90deg);
}
/*　closeというクラスがついたら形状変化　*/
.title.close::before{
  	top:50%;
    right: 15px;
    transform: rotate(0deg);
}
.title.close::after{
	display: none;
}

/*アコーディオンで現れるエリア*/
.answer_box {
    display: none;/*はじめは非表示*/
    background: url("../images/icon_faq_a.png") no-repeat top left;
	background-size: 36px;
  	margin: 10px auto 0;
    padding: 5px 60px 10px 40px;
	font-size: 0.85rem;
}



/*********** POSITION ***********/

.r_top_position {
	position: relative;
	background: #A50000;
	color: #fff;
}
.position_list_box ul li {
	position: relative;
	background-image: linear-gradient(135deg, #A50000 0%, #A50000 3.5%, #fff 3.5%, #fff 96.5%, #A50000 96.5%, #A50000 100%);
}
.position_list_box ul li:after {
	position: absolute;
	content: '';
	top: calc(50% - 5px);
	right: 15px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 7px;
	height: 7px;
	border-bottom: 1px solid #A50000;
	border-right: 1px solid #A50000;
	transform: rotate(-45deg);
}
.position_list_box ul li:before {
	position: absolute;
	content: '';
	top: calc(50% - 1px);
	right: 15px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 10px;
	height: 1px;
	background: #A50000;
}
.position_list_box ul li a {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
}
.position_list_box ul li .label {
	position: absolute;
	width: 100%;
	top: 0;
	bottom: 0;
	left: 1.2em;
	color: #A50000;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0;
	writing-mode: sideways-lr;
	text-align: center;
}
.position_list_box ul li dl {
	width: calc(100% - 80px);
	height: 100%;
	padding: 30px 40px;
	margin: auto;
	box-sizing: border-box;
	border-left: 1px solid #A50000;
	border-right: 1px solid #A50000;
	color: #000;
}
.position_list_box ul li dt {
	font-size: 1.15em;
	font-weight: 700;
	margin-bottom: 0.5em;
}
.position_list_box ul li dd {
	font-size: 0.85em;
}



@media screen and (max-width: 1024px) {

/*********** KV ***********/

.kv .cc {
	left: 5%;
}	
.kv .fv_bt {
	position: absolute;
	width: 100%;
	height: 85px;
	bottom: 0;
	left: 0;
	margin: auto;
	background: #A50000;
	color: #fff;
	font-weight: 500;
}
.kv .fv_bt p {
	padding-top: 1.9em;
	padding-left: 5%;
	font-size: 15px;
	letter-spacing: 0.2em;
}
	
/*********** ABOUT ***********/

.r_top_about {
	position: relative;
	background: #A50000;
	color: #fff;
}
.r_top_about .img_1 {
	position: absolute;
	width: 25%;
	top: 50px;
	left: auto;
	right: 85px;
	margin: auto;
}
.r_top_about .img_2 {
	position: absolute;
	width: 25%;
	top: 400px;
	left: 0;
	right: auto;
	margin: auto;
}
.r_top_about dl {
	width: 65%;
	margin: 150px 0 100px auto;
	line-height: 2.2;
}
.r_top_about dl dt {
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	float: left;
	font-size: 24px;
	font-weight: 300;
	letter-spacing: 0.3em;
}
.r_top_about dl dd {
	width: 80%;
	margin-left: auto;
	padding-top: 90px;
}

/*********** BUSINESS ***********/

.r_top_business {
	position: relative;
	margin: 100px auto;
	padding: 0;
}
.r_top_system {
	position: relative;
	margin: 0 auto 50px;
	padding: 30px 0;
}
.r_top_business .img_box,
.r_top_system .img_box {
	position: absolute;
	width: calc(50% - 85px);
	height: 450px;
	top: 0;
	right: 85px;
	background: url("../../images/recruit/top/top_business_img.png") no-repeat center top / cover;
	display: block;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_system .img_box {
	background: url("../../images/recruit/top/top_system_img.png") no-repeat center top / cover;
}
.r_top_business .img_box:hover,
.r_top_system .img_box:hover{
	filter: grayscale(0%);
}
.r_top_business .box,
.r_top_system .box {
	position: relative;
	width: 50%;
	margin: 0 auto 0 0;
}
	
/*********** INTERVIEW ***********/

.r_top_interview {
	position: relative;
	background: #A50000;
	color: #fff;
	padding-bottom: 80px; 
}
.r_top_interview .article {
	position: relative;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_interview .article:hover {
	filter: grayscale(0%);
}
.r_top_interview .article a {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.r_top_interview .article_txt_box dl {
	margin-top: 1.5em;
	padding: 0 5%;
	box-sizing: border-box;
}
.r_top_interview .swiper-slide-prev,
.r_top_interview .swiper-slide-next,
.r_top_interview .swiper-slide-duplicate-prev,
.r_top_interview .swiper-slide-duplicate-next {
	transform: scale(0.85);
	opacity: 0.5;
}
.r_top_interview .swiper-button-next {
    background: url("../../images/recruit/top/slide_navi_r.png") no-repeat center / cover;
	width: 25px;
	height: 25px;
	top: 35%;
	left: 0;
	right: -52%;
	margin: auto;
}
.r_top_interview .swiper-button-prev {
    background: url("../../images/recruit/top/slide_navi_l.png") no-repeat center / cover;
	width: 25px;
	height: 25px;
	top: 35%;
	left: -52%;
	right: 0;
	margin: auto;
}	
	
}



@media screen and (max-width: 767px) {

/*********** KV ***********/
	
.kv {
	width: 100vw;
	height: 710px;
}
.kv .cc {
	position: absolute;
	width: 100%;
	bottom: 68px;
	left: 5%;
	color: #fff;
	font-size: 24vw;
}
.kv .fv_bt {
	position: absolute;
	width: 100%;
	height: 85px;
	bottom: 0;
	left: 0;
	margin: auto;
	background: #A50000;
	color: #fff;
	font-weight: 500;
}
.kv .fv_bt p {
	padding-top: 1.7em;
	padding-left: 5%;
	font-size: 13px;
	letter-spacing: 0.2em;
}


	
/*********** ABOUT ***********/
	
.r_top_about {
	padding-top: 5% 0 0;
}
.r_top_about .img_1 {
	position: absolute;
	width: 160px;
	top: 120px;
	left: auto;
	right: 0;
	margin: auto;
}
.r_top_about .img_2 {
	position: absolute;
	width: 150px;
	top: 200px;
	left: auto;
	right: 180px;
	margin: auto;
}
.r_top_about dl {
	width: 90%;
	margin: 340px auto 70px;
	line-height: 2.2;
	display: flex;
}
.r_top_about dl dt {
	-ms-writing-mode: tb-rl;
	white-space: pre;
	float: none;
	width: 10%;
	height: auto;
	font-size: 18px;
	font-weight: 300;
	letter-spacing: 0.3em;
}
.r_top_about dl dt span {
	writing-mode: vertical-rl;
	display: inline-block;
}
.r_top_about dl dd {
	width: 76%;
	margin-left: auto;
	padding-top: 70px;
}


/*********** BUSINESS ***********/

.r_top_business {
	position: relative;
	margin: 0 auto;
	padding: 30px 0 0;
}
.r_top_system {
	position: relative;
	margin: 0 auto 50px;
	padding: 30px 0;
}
.r_top_business .img_box,
.r_top_system .img_box {
	position: relative;
	width: 100%;
	height: 250px;
	top: 0;
	right: 0;
	background: url("../../images/recruit/top/top_business_img.png") no-repeat center top / cover;
	display: block;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_system .img_box {
	background: url("../../images/recruit/top/top_system_img.png") no-repeat center top / cover;
}
.r_top_business .img_box:ontouchstart,
.r_top_system .img_box:ontouchstart{
	filter: grayscale(0%);
}
.r_top_business .box,
.r_top_system .box {
	position: relative;
	width: 100%;
	margin: 5% auto;
}
.r_top_business .ttl_box_bk,
.r_top_system .ttl_box_bk{
	margin-bottom: 5%;
}
	
	
/*********** INTERVIEW ***********/

.r_top_interview {
	position: relative;
	background: #A50000;
	color: #fff;
	padding-bottom: 60px; 
}
.r_top_interview .slide-none-box {
	width: 85%;
	margin: 50px auto 0;
}
.r_top_interview .article {
	position: relative;
	filter: grayscale(100%);
	transition: all 0.3s ease-in;
}
.r_top_interview .article:ontouchstart {
	filter: grayscale(0%);
}
.r_top_interview .article a {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.r_top_interview .article_txt_box dl {
	margin-top: 1.5em;
	padding: 0 5%;
	box-sizing: border-box;
}
.r_top_interview .swiper-slide-prev,
.r_top_interview .swiper-slide-next,
.r_top_interview .swiper-slide-duplicate-prev,
.r_top_interview .swiper-slide-duplicate-next {
	transform: scale(0.85);
	opacity: 0.5;
}
.r_top_interview .swiper-button-next {
    background: url("../../images/recruit/top/slide_navi_r.png") no-repeat center / cover;
	width: 20px;
	height: 20px;
	top: 35%;
	left: 0;
	right: -85%;
	margin: auto;
}
.r_top_interview .swiper-button-prev {
    background: url("../../images/recruit/top/slide_navi_l.png") no-repeat center / cover;
	width: 20px;
	height: 20px;
	top: 35%;
	left: -85%;
	right: 0;
	margin: auto;
}
	
/*********** COMPANY ***********/

.r_top_company {
	width: 100%;
	background: url("../../images/recruit/top/top_company_bg.png") no-repeat center / cover;
	color: #fff;
}
.r_top_company .col2_box li {
	width: 100%;
	margin:0 0 5% 0;
}
.r_top_company .ttl_box_bk {
	margin-bottom: 0;
}


/*********** QUESTION ***********/

.r_top_faq .qa_list li:last-child {
	border-bottom: 1px solid #000;
}

/*アコーディオン全体*/
.accordion-area li{
	padding: 1.0em 0;
	border-top: 1px solid #000;
}
.accordion-area li:last-child {
	border-bottom: 1px solid #000;
}

/*アコーディオンタイトル*/
.title {
    position: relative;/*+マークの位置基準とするためrelative指定*/
    cursor: pointer;
    padding: 10px 45px 10px 30px;
    transition: all .3s ease;
	background: url("../../images/recruit/top/top_qa_icon.png") no-repeat center left;
	background-size: 20px;
	line-height: 1.5;
	font-size: 1.0rem;
}

/*アイコンの＋と×*/
.title::before,
.title::after{
    position: absolute;
    content:'';
    width: 15px;
    height: 1px;
    background-color: #000;
}
.title::before{
    top:50%;
    right: 15px;
    transform: rotate(0deg);
}
.title::after{
    top:50%;
    right: 15px;
    transform: rotate(90deg);
}
/*　closeというクラスがついたら形状変化　*/
.title.close::before{
  	top:50%;
    right: 15px;
    transform: rotate(0deg);
}
.title.close::after{
	display: none;
}

/*アコーディオンで現れるエリア*/
.answer_box {
    display: none;/*はじめは非表示*/
    background: url("../images/icon_faq_a.png") no-repeat top left;
	background-size: 36px;
  	margin: 10px auto 0;
    padding: 5px 45px 10px 30px;
	font-size: 0.85rem;
}
	
/*********** POSITION ***********/

.r_top_position {
	position: relative;
	background: #A50000;
	color: #fff;
}
.position_list_box ul li {
	position: relative;
	background-image: linear-gradient(135deg, #A50000 0%, #A50000 3%, #fff 3%, #fff 97%, #A50000 97%, #A50000 100%);
}
.position_list_box ul li:after {
	position: absolute;
	content: '';
	top: calc(50% - 5px);
	right: 10px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 7px;
	height: 7px;
	border-bottom: 1px solid #A50000;
	border-right: 1px solid #A50000;
	transform: rotate(-45deg);
}
.position_list_box ul li:before {
	position: absolute;
	content: '';
	top: calc(50% - 1px);
	right: 10px;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 10px;
	height: 1px;
	background: #A50000;
}
.position_list_box ul li a {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
}
.position_list_box ul li .label {
	position: absolute;
	width: 100%;
	top: 0;
	bottom: 0;
	left: 1.0em;
	color: #A50000;
	font-size: 8px;
	font-weight: 700;
	letter-spacing: 0;
	writing-mode: sideways-lr;
	text-align: center;
}
.position_list_box ul li dl {
	width: calc(100% - 60px);
	padding: 1.0em 2.0em;
	margin: auto;
	box-sizing: border-box;
	border-left: 1px solid #A50000;
	border-right: 1px solid #A50000;
	color: #000;
}
.position_list_box ul li dt {
	font-size: 1.15em;
	font-weight: 700;
	margin-bottom: 0.5em;
}
.position_list_box ul li dd {
	font-size: 0.85em;
}


}


