﻿@charset "utf-8";

.foot_bg{
    background: url( "../img/common/foot_bg.png");
    background-repeat: no-repeat;
    width: 100%;
    height: 185px;
    margin-top: 100px;
}


.about .foot_bg{
    background: url( "../img/common/foot_bg.png");
    background-repeat: no-repeat;
    width: 100%;
    height: 185px;
    margin-top: 100px;
    position: absolute;
    bottom: 0;
    z-index: -10;
}

/*.company .foot_bg,
.privacy .foot_bg,
.security .foot_bg,
.baseball .foot_bg,
.news .foot_bg,
.news01 .foot_bg,
.contact .foot_bg{
    background: url( "../img/common/foot_bg.png");
    background-repeat: no-repeat;
    width: 100%;
    height: 185px;
    margin-top: 100px;
}
*/
/*.home .heading_wrap {
    position: relative;
	padding-top: 50%;
    max-height: 850px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    z-index: 0;
	overflow: hidden;
}*/
.center{
    text-align: center;
}

.home .heading_wrap {
  position: relative;
  /* padding-top: 51%; */
  max-height: 968px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  z-index: 0;
  overflow: hidden;
}
.home .heading_wrap .mv_sliders{
	width: 100%;
	z-index:10;
	background: #039;
}
.home .heading_wrap .mv_sliders .mv_left{
	width: 100%;
	z-index:2;
	position: absolute;
}
.home .heading_wrap .mv_sliders .mv_right{
	width: 58.75%;
	z-index:1;
	margin-left: auto;
}
.home .heading_wrap .mv_sliders img{
	width:100%;
}
.home .heading_wrap .mv_sliders .display_pc{
	display:block;
}
.home .heading_wrap .mv_sliders .display_sp{
	display:none;
}
.home .heading_wrap:before, .heading_wrap:after {
    position: absolute;
    display: inline-block;
    /* content: ""; */
    width: 62.5%;
    height: 100%;
    background: url("../img/top_bg_left.png") no-repeat;
    background-position: right center;
    background-size: cover;
    left: 0;
    top: 0;
    z-index: -2;
}
.home .heading_wrap:after {
    background-image: url("../img/top_bg_rigth.png");
    background-position: bottom center;
    left: auto;
    right: 0;
    z-index: -3;
    width: 60.5%;
}
.home .bg_parts01{
	position: absolute;
	width: 40%;
	max-width: 652px;
	top: 25px;
	left: 0;
	z-index: -1;
}
.home .bg_parts02{
	position: absolute;
	/* width: 58.5%; */
	bottom: 0;
	left: 0;
	z-index: 11;
}
.home .bg_parts01 img,
.home .bg_parts02 img{
	width: 100%;
	height: auto;
}
.home .contents_wrap{
	position: relative;
	z-index: 1
}
.home .contents_wrap::after{
	content: "";
	position: absolute;
	background: url("../img/bg_parts02.png") no-repeat;
	background-size: contain;
	width: 543px;
	height: 1079px;
	top: 330px;
	right: 0;
	z-index: -1;
}
.home .contents_wrap::before{
	content: "";
	position: absolute;
	background: url("../img/bg_parts03.png") no-repeat;
	background-size: contain;
	width: 365px;
	height: 1060px;
	top: 1275px;
	left: 0;
}
/*.home .heading_wrap .catch {
	position: absolute;
	top: 50%;
	transform: translate(-40%,-50%);
	display: block;
	color: #fff;
	text-align: left;
	z-index: 10;
}*/
.home .heading_wrap .catch {
	position: absolute;
	top: 50%;
	transform: translate(0%,-50%);
	display: block;
	color: #fff;
	text-align: left;
	z-index: 10;
}
.home .heading_wrap .catch h1{
	font-size: 58px;
	font-weight: bold;
	margin: 0 0 30px 0;
}
.home .heading_wrap .catch sub{
	font-size: 16px;
	line-height: 2;
}
.home .contents_wrap .about_flex{
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: 1200px;
	max-width: 100%;
	min-width: 1200px;
	margin: auto;
}
.home .contents_wrap .sitewrap{
	width: 100%;
	min-width: 0;
	box-sizing: border-box;
}
.home .about_text_box{
	width: 550px;
	min-width: 550px;
	position: relative;
}
.home .contents_wrap .about_flex .left_imge{
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	position: relative;
}
.home .contents_wrap .about_flex .left_imge::after{
	content: "";
	position: absolute;
	background: url("../img/bg_parts01.png") no-repeat;
	background-size: contain;
	width: 894px;
	height: 528px;
	top: 0;
	left: 103px;
	z-index: -1;
}
.about_text_box h2{
	font-size: 38px;
	font-weight: bold;
	color: #003399;
	line-height: 1.4;
	margin-bottom: 30px;
}
.about_text_box p{
	font-size: 16px;
	line-height: 1.8;
	margin-bottom: 30px;	
}
.sitewrap_products{
	padding-right: 10px;
}
.products_box{
	width: 1200px;
	min-width: 1200px;
	box-sizing: border-box;
	margin: 85px auto 0;
	position: relative;
}
.products_box h2{
	font-size:60px;
	color: #003399;
	font-weight: bold;
}
.products_box h2 span{
	display: inline-block;
	font-size: 16px;
	font-weight: bold;
	color: #333333;
	padding: 0 0 0 15px;
}
.sub_text{
	font-size: 16px;
	margin-bottom: 40px;
}
.products_list{
	padding: 60px 0 0 0;
}
.bx-wrapper, .bx-viewport{
	height: 650px!important
}
.list_text{
	font-size: 18px;
	background: #fff;
	padding: 24px 0 64px 15px;
	border-radius: 0 0 10px 10px;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6);
}
.products_box .more_btn{
	position: absolute;
	top: 40px;
	left: 55%;
}
.products_box li{
	padding-bottom: 10px;
	width: 243px!important;
	margin-right: 20px;
}
.products_box .list_card{
	display: block;
	position: relative;
	transition-duration: .4s;
    transition-timing-function: cubic-bezier(.28,1.2,.5,1.1);
	text-decoration: none;
}
.products_box .list_card:hover{
	transform: translateY(-24px);
}
.products_box .products_list .more_btn02{
	background: #003399;
    border-radius: 8px 8px 0 0;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    line-height: 30px;
    padding: 0 35px 1% 15px;
    position: absolute;
    right: 16px;
    top: 3px;
    transition-duration: .4s;
    transition-timing-function: cubic-bezier(.28,1.2,.5,1.1);
    z-index: -1;
}
.products_box .products_list .more_btn02::after{
	content: "";
	position: absolute;
	background: url("../img/common/btn_02_arrow.png") no-repeat;
	width: 21px;
	height: 17px;
	top: 50%;
	transform: translateY(-51%);
	right: 3px;
}
.products_box .list_card:hover .more_btn02{
	top: -30px;
}
.home .news_wrap{
	border-top: solid 60px #07399e;
	position: relative;
	z-index: 1
}
.home .news_wrap::before{
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background: #07399e;
	width: 50%;
	height: 100%;
}
.home .news_wrap .sitewrap{
	width: 1200px;
	min-width: 1200px;
	position: relative;
}
.home .news_wrap .news_box{
	display: flex;
	justify-content: space-between;
	box-sizing: border-box;
}
.home .news_wrap h2{
	font-size: 60px;
	color: #fff;
	font-weight: bold;
	width: 20%;
}
.home .news_wrap h2 span{
	display: block;
	font-size: 16px;
	font-weight: normal;
}
.home .news_wrap .news_list{
	background: #fff;
	position: relative;
	width: 78%;
}
.home .news_wrap .more_btn{
	position: absolute;
	top: 125px;
	left: 0;
}
.home .news_wrap .more_btn a{
	width: 145px;
	background: none;
	text-align: left;
	padding: 0;
}
.home .news_wrap .news_list{
	position: relative;
	padding-top: 60px;
}
.home .news_wrap .news_list dl a{
	display: flex;
	padding: 15px 0 20px 0;
	font-size: 16px;
	position: relative;
	z-index: 1;
	border-bottom: solid 1px #cbcbcb;
	transition: .3s;
}
.home .news_wrap .news_list dl a:hover{
	background: #e8f0ff;
}
.home .news_wrap .news_list::before{
	content: "";
	position: absolute;
	width: 500px;
	top: 0;
	left: -128px;
	padding-top: 100%;
	background: #fff;
	transform: rotate(15deg);
	z-index: 0;
}
.home .news_wrap .news_list dl dt{
	width: 34%;
}
.home .news_wrap .news_list dl dd{
	width: 66%;
	line-height: 1.8;
}
.home .news_wrap .news_list dl dt span{
	display: inline-block;
	width: 146px;
	text-align: center;
	padding: 5px;
	margin-left: 25px;
	border-radius: 15px;
	color: #fff;
}
.home .news_wrap .news_list dl dt .blue_list{
	background: #0099cc;
}
.home .news_wrap .news_list dl dt .orenge_list{
	background: #f49315;
}
.home .recruit_wrap{
	padding: 144px 0 137px 0;
	position: relative;
	z-index: 2;
}
.home .recruit_wrap .sitewrap{
	overflow: visible;
}
.home .recruit_wrap .recruit_more a{
	display: flex;
	background: #f49315;
	color: #fff;
	transition: .2s;
}
.home .recruit_wrap .recruit_more a:hover{
	box-shadow: 0px 0px 16px -6px rgb(0 0 0 / 80%);
    transform: translateY(-10px);
}
.home .recruit_wrap .bg_logo{
	width: 50%;
	position: absolute;
	bottom: -9.7vw;
	left: -15px;
	transform: rotate(-7deg);
	z-index: 99;
}
.home .recruit_wrap .bg_logo img{
	width: 100%;
	height: auto;
	min-width: 530px;
	max-width: 646px;
}
.home .recruit_wrap .recruit_text{
	padding: 50px 70px 0 0;
}
.home .recruit_wrap .recruit_text h2{
	font-size: 37px;
	font-weight: bold;
	margin-bottom: 45px;
}
.home .recruit_wrap .recruit_text h2 span{
	display: inline-block;
	font-size: 16px;
	padding-left: 10px;
	font-weight: normal;
}
.home .recruit_wrap .recruit_text h3{
	font-size: 32px;
	font-weight: bold;
	margin-bottom: 20px;
}
.home .recruit_wrap .recruit_text p{
	width: 100%;
	overflow: hidden;
	font-size: 16px;
}
.home .recruit_wrap .recruit_text{
	color: #fff;
}
.home .recruit_wrap .recruit_text .more_btn .recruit_arrow{
	position: absolute;
	display: block;
	width: 100px;
	height: 65px;
	text-align: right;
	bottom: 1px;
	right: 1px;
	background: none;
	padding: 22px 20px 22px 0;
	box-sizing: border-box;
	border-radius: 0;
	overflow: hidden;
	z-index: 1;
}
.home .recruit_wrap .recruit_text .more_btn .recruit_arrow span{
	z-index: 2;
}
.recruit_text a{
	color: #fff;
}
.home .recruit_wrap .recruit_text .more_btn .recruit_arrow::after{
	content: "";
	position: absolute;
	background: #fff;
	width: 60px;
	height: 70px;
	bottom: 0;
	right: 0;
	z-index: -1;
}
.home .recruit_wrap .recruit_text .more_btn .recruit_arrow::before{
	content: "";
	position: absolute;
	background: #fff;
	width: 724px;
	height: 402px;
	top: -88px;
	left: 31px;
	transform: rotate(30deg);
	z-index: -1;
}
.home .base_ball_wrap{
	position: relative;
	background-color:#0a3b9f;
	overflow: hidden;
}
.home .base_ball_wrap::before{
	content: "";
	position: absolute;
	background-image: url("../img/bg05.png");
	background-repeat: no-repeat;
	background-position: bottom left;
	width: 60%;
	height: 100%;
	top: 0;
	left: auto;
    right: 0;
	background-size: cover;
}

.home .base_ball_wrap .sitewrap{
	overflow: visible;
}
.home .base_ball_wrap::after{
	content: '';
    position: absolute;
    left: 0;
    bottom: 98%;
    transform: skewY(-7deg);
    transform-origin: top right;
    width: 100%;
    height: 100%;
    background:#fff;
	z-index: 1;
}

.base_ball_flex{
	display: flex;
	justify-content: space-between;
	overflow: visible;
}
.home .base_ball_wrap .base_ball_text{
	padding:203px 0 0 0;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
}
.home .base_ball_wrap .base_ball_text::before{
	content: "";
	position: absolute;
	background: #0a3b9f;
	top: 0;
	right: -143px;
	width: 358px;
	height: 520px;
	transform: rotate(15deg);
	z-index: -1;
}
.home .base_ball_wrap .base_ball_text h2{
	font-size: 48px;
	width: 403px;
	color: #fff;
	font-weight: bold;
	margin-bottom: 25px;
}
.home .base_ball_wrap .base_ball_text .sub_text{
	font-size: 16px;
	color: #fff;
}

.home .base_ball_wrap .base_ball_text .more_btn a{
	background: #fff;
	color:#003399;
	font-size: 16px;
	font-weight: bold;
}
.home .base_ball_wrap .base_ball_text .more_btn a::after{
	background: url("../img/common/btn_arrow02.png") no-repeat;
	content: "";
	background-size: contain;
}
.base_ball_image{
	margin: 0 calc(50% - 50vw);
	position: relative;
	z-index: 2;
}
.base_ball_image span{
	position: relative;
	z-index: 3;
}
.home .base_ball_wrap .base_ball_image::before{
	position: absolute;
	content: "";
	background: url("../img/bg07.png") no-repeat;
	width: 81px;
	height: 130px;
	bottom: 0;
	right: 0;
	z-index: 4;
}
.home .contact_warp{
	background: #0099cc;
	padding: 60px 0 77px 0;
}
.home .contact_warp .contact_contents{
	display: flex;
	justify-content: space-between;
}
.home .contact_warp .contact_contents h2{
	display: block;
	font-size: 60px;
	color: #fff;
	font-weight: bold;
	width: 30%;
}
.home .contact_warp .contact_contents h2 span{
	font-size: 16px;
	display: block;
}
.home .contact_warp .contact_box{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 70%;
}
.home .contact_warp .contact_box .contact_text{
	width: 100%;
	color: #fff;
	font-size: 20px;
	margin-bottom: 20px;
}
.home .contact_warp .contact_box .contact_btn{
	width: 49%;
	background: #fff;
	padding: 15px 0 15px 90px;
	box-sizing: border-box;
	text-align: center;
	position: relative;
	border-radius: 10px;
}
.home .contact_warp .contact_box .btn_tell p{
	position: relative;
	text-align: left;
}
.home .contact_warp .contact_box .btn_tell p::before{
	position: absolute;
	content: "";
	background: url("../img/common/tel_icon_blue.png") no-repeat;
	width: 46px;
	height: 46px;
	top: 50%;
	transform: translateY(-50%);
	left: -60px;
}
.home .contact_warp .contact_box .btn_mail a{
	position: relative;
}
.home .contact_warp .contact_box .btn_mail a::before{
	position: absolute;
	content: "";
	background: url( "../img/common/mail_icon_blue.png") no-repeat;
	width: 46px;
	height: 46px;
	top: 50%;
	transform: translateY(-50%);
	left: -60px;
}
.home .contact_warp .contact_box .btn_tell p span:first-child{
	font-size: 16px;
	display: block;
}
.home .contact_warp .contact_box .btn_tell p span:last-child{
	font-size: 38px;
	font-weight: bold;
	display: block;
}
.home .contact_warp .contact_box .btn_mail{
	display: flex;
	align-items: center;
	font-size: 20px;
	text-align: left;
}
@media screen and (max-width:768px) {
	.home .heading_wrap{
		/* padding-top: 138%; */
	}
	.home .heading_wrap:before{
		background: url("../img/top_bg_sp.png") no-repeat top center;
		background-size: 100%;
		width: 100%;
		z-index: -1;
	}
	.home .heading_wrap:after{
		background: url("../img/top_bg_sp02.png") no-repeat bottom center;
		background-size: 100%;
		width: 100%;
		top: 0;
		z-index: 1;
	}
	.home .heading_wrap .mv_sliders .mv_left{
        order:2;
 }
	.home .heading_wrap .mv_sliders .mv_right{
		width: 100%;
		order:1;
	}
	.home .heading_wrap .mv_sliders .display_pc{
		display:none;
	}
	.home .heading_wrap .mv_sliders .display_sp{
		display:block;
	}
    .home .heading_wrap .catch{
      transform: none;
      padding: 0 15px;
      left: 0;
      top: 58%;
      width: 100%;
      box-sizing: border-box;
}
	.home .bg_parts01,
	.home .bg_parts02{
		/* display: none; */
		width: 58.5%;
	}
	.home .heading_wrap .catch h1{
		font-size: 30px;
		margin: 0 0 12px 0;
	}
	.home .heading_wrap .catch sub{
		font-size: 14px;
		line-height: normal;
	}
	.home .contents_wrap .about_flex{
		width: 100%;
		min-width: 0;
	}
	.home .contents_wrap .about_flex{
		flex-direction: column;
	}
	.home .contents_wrap .about_flex .left_imge{
		margin: 0 0 0 -10%;
	}
	.home .about_text_box{
		width: 100%;
		min-width: 0;
		/* padding: 0 15px; */
		box-sizing: border-box;
	}
	.about_text_box h2{
		font-size: 6vw;
		margin-bottom: 15px;
		padding: 0 15px;
	}
	.about_text_box p{
		font-size: 14px;
		line-height: normal;
		margin-bottom: 15px;
	}
	.more_btn{
		text-align: center;
	}
	.more_btn a{
		width: 70%;
		margin: auto;
		padding: 10px 0;
	}
	.more_btn a::after{
		width: 16px;
		height: 16px;
	}
	.products_box{
		width: 100%;
		min-width: 0;
		margin: 40px auto 0;
	}
	.products_box .more_btn{
		position: static;
		margin-bottom: 20px;
	}
	.products_box h2{
		font-size: 30px;
	}
	.products_box h2 span{
		font-size: 12px;
		padding: 0 0 0 8px;
	}
	.products_box .sub_text{
		font-size: 14px;
		margin-bottom: 13px;
	}
	.products_list{
		padding: 0;
	}
	.home .news_wrap{
		border: none;
		margin-top: 38px;
	}
	.home .news_wrap .sitewrap{
		width: 100%;
		min-width: 0;
		padding: 0 15px;
		box-sizing: border-box;
	}
	.home .news_wrap .news_box{
		flex-direction: column;
	}
	.home .news_wrap .news_list::before{
		display: none;
	}
	.home .news_wrap h2{
		font-size: 30px;
		width: 100%;
		margin-bottom: 25px;
	}
	.home .news_wrap h2 span{
		display: inline-block;
		padding-left: 8px;
		font-size: 12px;
	}
	.home .news_wrap::before{
		width: 100%;
		height: 90%;
		top: auto;
		bottom: 0;
	}
	.home .news_wrap .more_btn{
		position: static;
		transform: translateY(-85px);
	}
	.home .news_wrap .more_btn a{
		width: 70%;
		margin: auto;
		padding: 10px 0;
		text-align: center;
		background: #003399;
	}
	.home .news_wrap .news_list{
		width: 100%;
		padding: 0 15px 110px 15px;
		box-sizing: border-box;
	}
	.home .news_wrap .news_list dl a{
		flex-direction: column;
	}
	.home .news_wrap .news_list dl dt{
		width: 100%;
		font-size: 14px;
		margin-bottom: 5px;
	}
	.home .news_wrap .news_list dl dt span{
		width: 73px;
		padding: 3px;
		font-size: 11px;
	}
	.home .news_wrap .news_list dl dd{
		width: 100%;
		font-size: 14px;
		line-height: normal;
	}
	.home .recruit_wrap{
		padding: 27px 0 45px 0;
	}
	.home .recruit_wrap .recruit_more a{
		flex-direction: column;
	}
	.home .recruit_wrap .recruit_text{
		padding: 10px 0 25px 15px;
	}
	.home .recruit_wrap .recruit_text h2{
		font-size: 30px;
		margin-bottom: 25px;
	}
	.home .recruit_wrap .recruit_text h2 span{
		font-size: 12px;
		padding-left: 8px;
	}
	.home .recruit_wrap .recruit_text h3{
		font-size: 20px;
		margin-bottom: 13px;
	}
	.home .recruit_wrap .recruit_text p{
		font-size: 14px;
		padding-right: 90px;
		box-sizing: border-box;
	}
	.home .recruit_wrap .recruit_text .more_btn .recruit_arrow{
		width: 73px;
		height: 43px;
		padding: 11px 10px 11px 0;
	}
	.home .recruit_wrap .recruit_text .recruit_arrow img{
		width: 50%;
	}
	.home .recruit_wrap .recruit_text .more_btn .recruit_arrow::before {
		width: 724px;
		height: 406px;
		top: -52px;
		left: -9px;
		transform: rotate(27deg);
	}
	.home .recruit_wrap .recruit_text .more_btn .recruit_arrow::after {
		width: 46px;
		height: 43px;
	}
	.base_ball_flex{
		flex-direction: column;
		padding-top: 4vh;
	}
	.home .base_ball_wrap .base_ball_text{
		padding: 0;
		position: absolute;
		z-index: 3;
	}
	.home .base_ball_wrap .base_ball_text h2{
		font-size: 25px;
	}
	.home .base_ball_wrap .base_ball_text .sub_text{
		font-size: 14px;
	}
	.home .base_ball_wrap .base_ball_text::before,
	.home .base_ball_wrap .base_ball_text .sub_text,
	.home .base_ball_wrap .base_ball_text .more_btn{
		display: none;
	}
	.home .base_ball_wrap::before{
		width: 100%;
	}
	.base_ball_image{
		z-index: 0;
		margin-right: -15px;
		margin-left: auto;
	}
	.home .base_ball_wrap::after{
		transform: skewY(-13deg);
		bottom: 88%;
		background: #07399e;
	}
	.home .base_ball_wrap .base_ball_text .more_btn{
		text-align: left;
	}
	.home .base_ball_wrap .base_ball_text .more_btn a{
		width: 43%;
	}
	.home .contact_warp{
		padding: 23px 0 50px 0;
	}
	.home .contact_warp .contact_contents{
		flex-direction: column;
	}
	.home .contact_warp .contact_contents h2{
		width: 100%;
		text-align: center;
		font-size: 30px;
		margin-bottom: 24px;
	}
	.home .contact_warp .contact_contents h2 span{
		display: inline-block;
		font-size: 12px;
	}
	.home .contact_warp .contact_box{
		width: 100%;
		flex-direction: column;
	}
	.home .contact_warp .contact_box .contact_text{
		font-size: 14px;
		text-align: center;
	}
	.home .contact_warp .contact_box .contact_btn{
		width: 100%;
		max-width: 344px;
		height: 77px;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: 0 auto 20px;
		padding: 0 0 0 70px;
	}
	.home .contact_warp .contact_box .btn_tell p{
		padding-top: 10px;
		width: 100%;
		box-sizing: border-box;
	}
	.home .contact_warp .contact_box .btn_tell p span:first-child{
		font-size: 14px;
	}
	.home .contact_warp .contact_box .btn_tell p span:last-child {
			font-size: 34px;
		}
	.home .contact_warp .contact_box .btn_mail a{
		font-size: 18px;
		width: 100%;
		box-sizing: border-box;
	}
	.home .contents_wrap .about_flex .left_imge::after{
		width: 305px;
		height: 264px;
		left: auto;
		right: -108px;
	}
	.home .contents_wrap::after{
		width: 115px;
		top: 534px;
	}
	.home .news_wrap::after{
		content: '';
		position: absolute;
		left: 0;
		top: 4%;
		transform: skewY(7deg);
		transform-origin: top right;
		width: 100%;
		height: 90%;
		background: #07399e;;
		z-index: -1;
	}
	.home .contents_wrap::before{
		background: url("../img/bg_parts_sp.png") no-repeat;
		background-size: contain;
		width: 303px;
		height: 112px;
		content: "";
		position: absolute;
		top: auto;
		bottom: -80px;
		right: 0;
		left: auto;
	}
	.home .recruit_wrap .bg_logo{
		width: 40%;
		transform: rotate(-13deg);
		bottom: -26vw;
		left: 10px;
		opacity: 0.3;
	}
	.home .recruit_wrap .bg_logo img{
		min-width: 0;
	}
}
@media screen and (max-width:420px) {
	.home .heading_wrap:after{
		width: 110%;
	}
	.home .heading_wrap .catch{
		top: 54%;
	}
}
@media screen and (max-width:380px) {
	.home .heading_wrap:after{
		width: 120%;
	}
	.home .heading_wrap .catch{
		top: 46%;
	}
}
/*recruit--------------------------------------------------------------------------*/
.recruit main{
	padding-bottom: 0;
	overflow: hidden;
}
/*.recruit .heading_wrap {
    position: relative;
	padding-top: 50%;
    max-height: 850px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    z-index: 0;
	overflow: hidden;
}*/

.recruit .heading_wrap {
    position: relative;
    padding-top: 51%;
    max-height: 850px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    z-index: 0;
    overflow: hidden;
}
.recruit .heading_wrap:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 62.5%;
    height: 100%;
    background: url("../img/recruit/top_bg_left.png") no-repeat;
    background-position: right center;
    background-size: cover;
    left: 0;
    top: 0;
    z-index: -2;
}
.recruit .heading_wrap:after{
    position: absolute;
    display: inline-block;
    content: "";
    height: 100%;
    background-image: url( "../img/recruit/top_bg_rigth.png");
	background-position: bottom center;
	left: auto;
    right: 0;
    z-index: -3;
    width: 60.5%;
}
.recruit .heading_wrap .bg_parts01{
	position: absolute;
	width: 40%;
	max-width: 652px;
	top: 25px;
	left: 0;
	z-index: -1;
}
.recruit .heading_wrap .bg_parts02{
	position: absolute;
	width: 58.5%;
	bottom: 0;
	left: 0;
	z-index: -1;
}
.recruit .heading_wrap .bg_parts01 img,
.recruit .heading_wrap .bg_parts02 img{
	width: 100%;
	height: auto;
}
.recruit .contents_wrap{
	position: relative;
	z-index: 1
}

/*.recruit .heading_wrap .catch {
	position: absolute;
	top: 50%;
	transform: translate(-40%,-50%);
	display: block;
	color: #fff;
	text-align: left;
	z-index: 10;
}*/
.recruit .heading_wrap .catch {
	position: absolute;
	top: 50%;
	transform: translate(0%,-50%);
	display: block;
	color: #fff;
	text-align: left;
	z-index: 10;
}

.recruit .heading_wrap .catch h1{
	font-size: 58px;
	font-weight: bold;
	margin: 0 0 30px 0;
}
.recruit .heading_wrap .catch sub{
	font-size: 16px;
	line-height: 2;
}
.recruit .about_wrap{
	position: relative;
	padding-bottom: 65px;
}
.recruit .about_wrap .bg_parts03{
	position: absolute;
	top: 0;
	left: 0;
}
.recruit .about_wrap .bg_parts04{
	position: absolute;
	top: 0;
	right: 0;
}
.recruit .about_wrap h2{
	font-size: 50px;
	color: #f49315;
	font-weight: bold;
	text-align: center;
	margin: 120px 0 60px 0;
}
.recruit .about_wrap h2 span{
	font-size: 16px;
	color: #333333;
	padding-left: 3px;
}
.recruit .about_wrap p{
	font-size: 16px;
	text-align: center;
	line-height: 3.1;
	margin-bottom: 70px;
}
.recruit .work_wrap{
	position: relative;
}
.recruit .work_wrap::before{
	content: '';
    position: absolute;
    left: 0;
    top: 10%;
    transform: skewY(-7deg);
    transform-origin: top right;
    width: 60%;
    height: 75%;
    background: #f9be30;
    z-index: -1;
}
.recruit .work_wrap .sitewrap{
	overflow: visible;
}
.recruit .work_wrap h2{
	font-size: 50px;
	font-weight: bold;
	color: #f49315;
}
.recruit .work_wrap h2 span{
	font-size: 16px;
	color: #333333;
	padding-left: 3px;
}
.recruit .work_wrap .work_box{
	display: flex;
}
.recruit .work_wrap .work_box .left_work_box{
	padding: 200px 0 0 0;
	width: 50%;
}
.recruit .work_wrap .innner_left_work_box{
	margin: auto;
	text-align: left;
}
.recruit .work_wrap .innner_left_work_box h3{
	font-size: 40px;
	font-weight: bold;
	line-height: 1.6;
	margin-bottom: 30px;
}
.recruit .work_wrap .innner_left_work_box p:nth-child(2){
	font-size: 16px;
	line-height: 1.8;
	margin-bottom: 70px;
}
.recruit .work_wrap .innner_left_work_box .more_btn a{
	color: #333333;
	background: #fff;
}
.recruit .work_wrap .innner_left_work_box .more_btn a::after {
    background: url(../img/common/btn_arrow02_o.png) no-repeat;
    background-size: contain;
    right: 75px;
}
.recruit .work_wrap .innner_left_work_box .more_btn a:hover::after{
	right: 55px;
}
.recruit .work_wrap .right_work_box{
	margin: 0 calc(-48% + 50vw);
    width: 100vw;
}
.recruit .news_wrap .news_box{
	margin-top: 40px;
}
.recruit .news_wrap h2{
	font-size: 50px;
	color: #f49315;
	font-weight: bold;
}
.recruit .news_wrap h2 span{
	font-size: 16px;
	color: #333333;
	padding-left: 3px;
}
.recruit .news_wrap .news_list{
	position: relative;
	padding-top: 25px;
}
.recruit .news_wrap .news_list dl a{
	display: flex;
	padding: 15px 0 20px 0;
	font-size: 16px;
	position: relative;
	z-index: 1;
	border-bottom: solid 1px #cbcbcb;
	transition: .3s;
}
.recruit .news_wrap .news_list dl a:hover{
	background: #fef8ea;
}
.recruit .news_wrap .news_list dl dt{
	width: 31%;
}
.recruit .news_wrap .news_list dl dd{
	width: 66%;
	line-height: 1.8;
}
.recruit .news_wrap .news_list dl dt span{
	display: inline-block;
	width: 146px;
	text-align: center;
	padding: 5px;
	margin-left: 90px;
	border-radius: 15px;
	color: #fff;
}
.recruit .news_wrap .news_list dl dt .green_list{
	background: #26a238;
}
.recruit .news_wrap .more_btn{
	text-align: right;
	margin-top: 10px;
}
.recruit .news_wrap .more_btn a{
	background: none;
	color: #333333;
}
.recruit .news_wrap .more_btn a::after{
	background: url(../img/common/btn_arrow02_o.png) no-repeat;
    background-size: contain;
	right: 75px;
}
.recruit .more_btn a:hover::after{
	/* right: 55px; */
}
.recruit .interview_wrap{
	position: relative;
}
.recruit .interview_wrap .sitewrap{
	overflow: visible;
}
.recruit .interview_wrap h2{
	font-size: 50px;
	font-weight: bold;
	color: #f49315;
	margin-bottom: 35px;
}
.recruit .interview_wrap h2 span{
	font-size: 16px;
	color: #333333;
	padding-left: 3px;
}
.recruit .interview_wrap .interview_text{
	margin-bottom: 55px;
}
.recruit .interview_wrap ul{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
	margin-bottom: 85px;
}
.recruit .interview_wrap ul li{
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6);
	border-radius: 10px;
	overflow: hidden;
}
.recruit .interview_wrap ul li a{
	display: block;
	width: 323px;
}
.recruit .interview_wrap ul li a span{
	display: block;
	overflow: hidden;
	width: 100%;
}
.recruit .interview_wrap ul li a img{
	max-width: 100%;
    height: auto;
    vertical-align: bottom;
    margin: 0;
    transition: transform .4s;
}
.recruit .interview_wrap ul li a:hover img{
	transform: scale(1.1, 1.1);
}
.recruit .interview_wrap ul li p{
	background: #fff;
	padding: 20px;
}
.recruit .interview_wrap ul li p span:first-child{
	display: block;
	font-size: 20px;
	color: #f49315;
	margin: 5px 0 10px 0;
}
.recruit .interview_wrap ul li p span:last-child{
	display: block;
	font-size: 14px;
}
.recruit .interview_wrap ul li:nth-child(2){
	margin-top: 40px;
}
.recruit .interview_wrap ul li:nth-child(3){
	margin-top: 80px;
}
.recruit .interview_wrap ul li:nth-child(4){
	margin-top: -40px;
}
.recruit .interview_wrap ul li:nth-child(6){
	margin-top: 40px;
}
.recruit .interview_wrap::before{
	content: '';
    position: absolute;
    left: 0;
    top: 33%;
    transform: skewY(7deg);
    transform-origin: top right;
    width: 100%;
    height: 75%;
    background: #fef8ea;
    z-index: -1;
}
.recruit .interview_wrap .more_btn{
	margin-bottom: 110px;
}
.recruit .interview_wrap .more_btn a{
	background: #f49315;
}
.recruit .interview_wrap .more_btn a::after{
	background: url("../img/common/btn_arrow03_o.png") no-repeat;
	background-size: contain;
	right: 55px;
}
.recruit .interview_wrap .more_btn a:hover::after{
	right: 35px;
}
.recruit .welfare_wrap{
	position: relative;
}

.recruit .welfare_wrap .sitewrap{
	/* overflow: visible; */
}
.recruit .welfare_flex a{
	display: flex;
	justify-content: flex-start;
	/* width: 100%; */
	/* min-width: 810px; */
	margin: 10px 0;
	/* border-radius: 10px; */
	/* box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6); */
	overflow: visible;
	background: #fff;
	transition: .3s;
}
.recruit .welfare_flex a:hover{
	/* box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.8); */
	transform: translateY(-4px);
}
.recruit .welfare_flex .welfare_text{
	padding: 45px 40px;
	width: 463px;
	overflow: hidden;
	position: relative;
}
.recruit .welfare_flex .welfare_text p:first-child{
	font-size: 24px;
	color:#f49315;
	margin-bottom:20px;
}
.recruit .welfare_flex .welfare_text p:last-child{
	font-size: 14px;
}
.recruit .welfare_flex .welfare_text .more_btn{
	width: 100%;
	overflow: hidden;
}
.recruit .welfare_flex .welfare_text .more_btn .welfare_arrow {
    position: absolute;
    display: block;
    width: 72px;
	height: 48px;
	padding: 17px 12px 0 0;
	box-sizing: border-box;
    text-align: right;
    bottom: 0;
    right: 0;
    border-radius: 0 0 10px 0;
	background: none;
	overflow: hidden;
	z-index: 1;
}
.recruit .welfare_flex .welfare_text .more_btn .welfare_arrow::after {
    content: "";
    position: absolute;
    background: #f49315;
    width: 724px;
    height: 402px;
    top: -45px;
    left: 19px;
    transform: rotate(40deg);
	z-index: -1;
}
.recruit .entry_warp{
	position: relative;
	overflow: hidden;
}
.recruit .entry_warp::before{
	content: '';
    position: absolute;
    left: 0;
    top: 0;
    transform: skewY(-7deg);
    transform-origin: top right;
    width: 100%;
    height: 200%;
    background: #f9be30;
    z-index: 0;
}
.recruit .entry_warp .entry_contents{
	width: 810px;
	min-width: 810px;
	margin: 230px auto 0;
}
.recruit .entry_warp .entry_contents h2{
	font-size: 50px;
	font-weight: bold;
	padding-left: 55px;
}
.recruit .entry_warp .entry_contents h2 span{
	padding-left: 22px;
	font-size: 16px;
}
.recruit .entry_warp .entry_box{
	margin-top: 40px;
	display: flex;
	justify-content: space-between;
	padding: 0 55px;
	margin-bottom: 105px;
}
.recruit .entry_warp .entry_box .entry_btn01{
	text-align: center;
}
.recruit .entry_warp .entry_box .entry_btn01 a{
	display: block;
	font-size: 28px;
	color: #f49315;
	background: #fff;
	width: 330px;
	min-width: 330px;
	padding: 35px 0;
	position: relative;
	z-index: 1;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6);
	transition: .4s;
}
.recruit .entry_warp .entry_box .entry_btn01 a:hover,
.recruit .entry_warp .entry_box .entry_btn02 a:hover{
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.8);
	transform: translateY(-10px);
}
.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow{
	display: block;
	position: absolute;
	text-align: right;
	padding: 15px 15px 0 0;
	box-sizing: border-box;
	bottom: 1px;
	right: 1px;
	width: 77px;
	height: 45px;
	overflow: hidden;
}
.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow img{
	vertical-align: top;
}
.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow::after {
    content: "";
    position: absolute;
    background: #f49315;
    width: 724px;
    height: 402px;
    top: -66px;
    left: 19px;
    transform: rotate(35deg);
    z-index: -1;
}
.recruit .entry_warp .entry_box .entry_btn02{
	text-align: center;
}
.recruit .entry_warp .entry_box .entry_btn02 a{
	display: block;
	font-size: 28px;
	color: #fff;
	width: 330px;
	min-width: 330px;
	padding: 35px 0;
	position: relative;
	z-index: 1;
	background: #26a238;
	box-shadow: 0px 0px 16px -6px rgba(0,0,0,0.6);
	transition: .4s;
}
.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow{
	display: block;
	position: absolute;
	text-align: right;
	padding: 15px 15px 0 0;
	box-sizing: border-box;
	bottom: 1px;
	right: 1px;
	width: 77px;
	height: 45px;
	overflow: hidden;
}
.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow img{
	vertical-align: top;
}
.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow::after {
    content: "";
    position: absolute;
    background: #fff;
    width: 724px;
    height: 402px;
    top: -66px;
    left: 19px;
    transform: rotate(35deg);
    z-index: -1;
}
.recruit .entry_warp .entry_box .entry_btn02 a span:first-child{
	position: relative;
	padding-left: 37px;
}
.recruit .entry_warp .entry_box .entry_btn02 a span:first-child::after{
	content: "";
	position: absolute;
	background: url("../img/common/recruit_icon.png") no-repeat;
	width: 32px;
	height: 19px;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
}
@media screen and (max-width:768px) {
	.recruit .heading_wrap{
		padding-top: 138%;
	}
	.recruit .heading_wrap:before {
		background: url( "../img/recruit/top_bg_sp.png") no-repeat top center;
		background-size: 100%;
		width: 100%;
		z-index: -1;
	}
	.recruit .heading_wrap .bg_parts01{
		display:none;
	}
    .recruit .heading_wrap .catch {
      transform: none;
      padding: 0 15px;
      top: 58%;
      left: 0;
      width: 100%;
      box-sizing: border-box;
}
	.recruit .heading_wrap:after {
		background: url("../img/recruit/top_bg_sp02.png") no-repeat bottom center;
		background-size: 100%;
		width: 100%;
		top: 0;
		z-index: 1;
	}
	.recruit .heading_wrap .catch h1 {
		font-size: 30px;
		margin: 0 0 12px 0;
	}
	.recruit .heading_wrap .catch sub {
		font-size: 14px;
		line-height: normal;
	}
	.recruit .about_wrap{
		padding-bottom: 40px;
	}
	.recruit .about_wrap h2 {
		font-size: 30px;
		text-align: left;
		margin: 40px 0 23px 0;
	}
	.recruit .about_wrap h2 span{
		font-size: 12px;
	}
	.recruit .about_wrap p{
		font-size: 14px;
		line-height: 1.6;
		text-align: left;
		margin-bottom: 25px;
	}
	.recruit .about_wrap .bg_parts03,
	.recruit .about_wrap .bg_parts04{
		display: none;
	}
	.recruit .about_wrap .bg_parts05{
		position: absolute;
		top: 0;
		right: -100px;
	}
	.recruit .work_wrap{
		overflow: hidden;
	}
	.recruit .work_wrap h2{
		font-size: 30px;
	}
	.recruit .work_wrap h2 span{
		font-size: 12px;
	}
	.recruit .work_wrap .work_box{
		flex-direction: column-reverse;
	}
	.recruit .work_wrap .work_box img {
		display: block;
		width: 80%;
		height: auto;
		margin-right: 0;
		margin-left: auto;
	}
	.recruit .work_wrap::before{
		width: 100%;
		height: 100%;
	}
	.recruit .work_wrap .work_box .left_work_box{
		padding: 20px 0 0 0;
		width: 100%;
	}
	.recruit .work_wrap .innner_left_work_box h3{
		font-size: 25px;
		margin-bottom: 20px;
	}
	.recruit .work_wrap .innner_left_work_box p:nth-child(2){
		font-size: 14px;
		line-height: normal;
		margin-bottom: 30px;
	}
	.recruit .work_wrap .innner_left_work_box .more_btn a{
		margin-bottom: 42px;
	}
	.recruit .news_wrap h2{
		font-size: 30px;
	}
	.recruit .news_wrap h2 span{
		font-size: 12px;
	}
	.recruit .news_wrap .news_list dl a{
		flex-direction: column;
	}
	.recruit .news_wrap .news_list dl dt {
		width: 100%;
		font-size: 14px;
		margin-bottom: 5px;
	}
	.recruit .news_wrap .news_list dl dd {
		width: 100%;
		font-size: 14px;
		line-height: normal;
	}
	.recruit .news_wrap .news_list dl dt span {
		width: 73px;
		padding: 3px;
		font-size: 11px;
		margin-left: 10%;
	}
	.recruit .news_wrap .more_btn{
		text-align: center;
		margin: 25px 0 55px 0;
	}
	.recruit .news_wrap .more_btn a{
		width: 70%;
		margin: auto;
		padding: 10px 0;
		text-align: center;
		background: #f49315;
		color: #fff;
	}
	.recruit .news_wrap .more_btn a::after {
		background: url( "../img/common/btn_arrow03_o.png") no-repeat;
		background-size: contain;
		right: 40px;
	}
	.recruit .interview_wrap h2{
		font-size: 30px;
		margin-bottom: 13px;
	}
	.recruit .interview_wrap h2 span{
		font-size: 12px;
	}
	.recruit .interview_wrap .interview_text{
		font-size: 14px;
		margin-bottom: 20px;
	}
	.recruit .interview_wrap ul{
		margin-bottom: 17px;
	}
	.recruit .interview_wrap ul li{
		width: 48%;
	}
	.recruit .interview_wrap ul li a{
		width: 100%;
	}
	.recruit .interview_wrap ul li p{
		padding: 10px;
	}
	.recruit .interview_wrap ul li p span:first-child{
		font-size: 13px;
		margin: 0 0 10px 0;
	}
	.recruit .interview_wrap ul li p span:last-child{
		font-size: 11px;
	}
	.recruit .interview_wrap ul li:nth-child(2){
		margin-top: 0;
	}
	.recruit .interview_wrap ul li:nth-child(3),
	.recruit .interview_wrap ul li:nth-child(4),
	.recruit .interview_wrap ul li:nth-child(5),
	.recruit .interview_wrap ul li:last-child{
		margin-top: 18px;
	}
	.recruit .interview_wrap::before{
		height: 56%;
	}
	.recruit .interview_wrap .more_btn{
		margin-bottom: 45px;
	}
	.recruit .welfare_flex a{
		flex-direction: column;
		width: 100%;
		min-width: 0;
		box-sizing: border-box;
	}
	.recruit .welfare_flex .welfare_text{
		width: 100%;
		padding: 10px 10px 28px 10px;
		box-sizing: border-box;
	}
	.recruit .welfare_flex .welfare_text p:first-child{
		font-size: 16px;
		margin-bottom: 10px;
	}
	.recruit .welfare_flex .welfare_text p:nth-child(2){
		font-size: 14px;
	}
	.recruit .welfare_flex .welfare_text .more_btn .welfare_arrow{
		width: 55px;
		height: 30px;
		padding: 5px 5px 0 0;
	}
	.recruit .welfare_flex .welfare_text .more_btn .welfare_arrow img{
		width: 50%;
	}
	.recruit .welfare_flex .welfare_text .more_btn .welfare_arrow::after {
		top: -84px;
		transform: rotate(35deg);
	}
	.recruit .welfare_wrap::before{
		top: 59%;
	}
	.recruit .entry_warp::before{
		transform: skewY(-15deg);
	}
	.recruit .entry_warp .entry_contents{
		width: 100%;
		min-width: 0;
		margin: 100px auto 0;
	}
	.recruit .entry_warp .entry_contents h2{
		font-size: 30px;
		padding-left: 0;
		text-align: center;
		margin-bottom: 23px;
	}
	.recruit .entry_warp .entry_contents h2 span{
		padding-left: 3px;
		font-size: 12px;
	}
	.recruit .entry_warp .entry_box{
		flex-direction: column;
		padding: 0;
		width: 80%;
		margin: auto;
		align-items: center;
	}
	.recruit .entry_warp .entry_box .entry_btn01{
		margin-bottom: 30px;
	}
	.recruit .entry_warp .entry_box .entry_btn01,
	.recruit .entry_warp .entry_box .entry_btn02{
		max-width: 344px;
		width: 100%;
	}
	.recruit .entry_warp .entry_box .entry_btn01 a,
	.recruit .entry_warp .entry_box .entry_btn02 a{
		width: 100%;
		min-width: 0;
		font-size: 20px;
	}
	.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow,
	.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow{
		width: 55px;
		height: 30px;
		padding: 5px 5px 0 0;
	}
	.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow img,
	.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow img{
		width: 50%;
	}
	.recruit .entry_warp .entry_box .entry_btn01 a .entry_arrow::after,
	.recruit .entry_warp .entry_box .entry_btn02 a .entry_arrow::after{
		top: -84px;
	}
	.recruit .entry_warp .entry_box .entry_btn02{
		margin-bottom: 85px;
	}
}
@media screen and (max-width:420px) {
	.recruit .heading_wrap:after{
		width: 110%;
	}
	.recruit .heading_wrap .catch{
		top: 54%;
	}
}
@media screen and (max-width:380px) {
	.recruit .heading_wrap:after{
		width: 120%;
	}
	.recruit .heading_wrap .catch{
		top: 46%;
	}
}

/*service-------------------------------------------------------------------*/
.service main{
	padding-bottom: 0;
}
.service .service01{
	position: relative;
}
.service .service01 .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.service main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}
.service .visula{
	padding-top: 78px;
}
.service .top_bg_wrap{
	background: url("../img/service/top_bg.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}
.service .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.service .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}
.service .item_list {
	width: 380px;
	min-width: 380px;
	font-size: 14px;
	margin-left: auto;
	margin-right: 0;
	padding-right: 45px;
	position: relative;
	box-sizing: border-box;
	margin-bottom: 30px;
}
.service .item_list select {
	width: 100%;
	cursor: pointer;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	box-shadow: none;
	-webkit-appearance: none;
	appearance: none;
}

.pull_list{
	color: #333333;
	font-size: 14px;
}
.service .item_list.all_item {
	position: relative;
	border: solid 1px #ccc;
	background: #ffffff;
}
.service .item_list.all_item select {
	padding: 0 0 0 8px;
	color: #333333;
	height: 40px;
}
.service .item_list::before {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 15px;
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 12px 8px 0 8px;
	border-color: #ffffff transparent transparent transparent;
	pointer-events: none;
	z-index: 2;
}
.service .item_list::after{
	position: absolute;
	content: "";
	width:45px;
	height: 40px;
	right: 0;
	background: #214ea8;
	box-sizing: border-box;
	z-index: 1;
}


.service .service_flex{
	display: flex;
	border-bottom: solid 1px #e4e4e4;
	padding-bottom: 44px;
	margin-bottom: 40px;
}
.service .service_flex .left_image{
	margin-right: 30px;
}
.service .service_flex .right_text_box{
	width: 100%;
}
.service .service_flex .right_text_box h2{
	font-weight: bold;
	color: #003399;
	font-size: 22px;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: solid 2px #003399;
}
.service .service_flex .right_text_box p{
	line-height: 2.2;
}
.service .service_flex .right_text_box span{
	color: #003399;
}
.service .service_flex .right_text_box .last_list_text{
	margin-bottom: 15px;
}
.service .service_flex .right_text_box .pdf_text a{
	display: block;
	width: 365px;
	color: #003399;
	cursor: pointer;
	padding: 10px 0 10px 45px;
	position: relative;
	line-height: normal;
}
.service .service_flex .right_text_box .pdf_text a[href$=".pdf"]::before{
	position: absolute;
	content: "";
	background: url("../img/service/pdf_icon.png") no-repeat;
	background-size: contain;
	width: 25px;
	height: 30px;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
}
.service .service_flex .right_text_box .pdf_text a::after{
	content: "";
	position: absolute;
	background: #003399;
	width: 365px;
	height: 1px;
	bottom: 0;
	left: 0;
}
.service .left_image .more_btn a{
	width: 378px;
	margin-top: 15px;
}
.service .service_flex_last{
	border: none;
}
@media screen and (max-width:768px) {
	.service .service01 .bg_parts01{
		width: 50%;
	}
	.service main .sitewrap{
		width: 100%;
		min-width: 0;
	}
	.service .visula{
		padding-top: 0;
	}
	.service .top_bg_wrap{
		background: url("../img/service/top_bg_sp.png") no-repeat;
		background-size: cover;
		padding-top: 33%;
	}
	.service .top_bg_wrap .catch h1{
		font-size: 19px;
	}
	.service .all_item{
		width: 100%;
		min-width: 0;
		margin: 0 auto 15px;
	}
	.service .all_item span{
		width: calc(100% - 45px);
		min-width: 0;
	}
	.service .all_item ul li span{
		width: 100%;
	}
	.service .service_flex{
		flex-direction: column;
		padding-bottom: 10px;
		margin-bottom: 15px;
	}
	.service .service_flex .left_image{
		margin: auto;
	}
	.service .service_flex .right_text_box{
		padding: 15px 10px 0 10px;
		box-sizing: border-box;
	}
	.service .service_flex .right_text_box h2{
		font-size: 18px;
		padding-bottom: 5px;
		margin-bottom: 5px;
	}
	.service .service_flex .right_text_box p{
		font-size: 14px;
		line-height: normal;
		margin-bottom: 10px;
		overflow: hidden;
	}
	.service .service_flex .right_text_box .pdf_text a{
		width: 90%;
	}
	.service .service_flex .right_text_box .pdf_text::before{
		width: 18px;
	}
	.service .service_flex .right_text_box .pdf_text a::after{
		width: 100%;
	}
	.service .left_image .more_btn a{
		width: 80%;
		margin: 15px auto 0;
	}
}

/*about-------------------------------------------------------------------*/
.about main{
	padding-bottom: 0;
	position: relative;
}
.about .about01{
	position: relative;
}
.about .about01 .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.about main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}
.about .visula{
	padding-top: 78px;
}
.about .top_bg_wrap{
	background: url("../img/about/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}
.about .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.about .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.about h2 {
    font-size: 32px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 28px;
}

.about h3{
    font-size:22px;
    color: #003399;
    line-height: 48px;
    vertical-align: 0.03em;
    text-align: left;
    margin-bottom: 25px;
    font-weight: bold;
}

.about_text01,
.about_text02{
    margin-bottom: 85px;
    font-size: 16px;
    line-height: 30px;
    vertical-align: 0.03em;
}

.about_text02{
   width: 48%;
}

.about_text02 p{
   margin-bottom: 40px; 
}

.about_bg{
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
    text-align: right;
    max-width: 786px;
    width: 50%;
}

.about_bg img{
    display: block;
    width:100%;
    height: auto;
}


@media screen and (max-width:768px) {
.about .service01 .bg_parts01{
    width: 50%;
}
.about main .sitewrap{
    width: 100%;
    min-width: 0;
}
.about .visula{
    padding-top: 0;
}
.about .top_bg_wrap{
    background: url("../img/about/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
.about .top_bg_wrap .catch h1{
    font-size: 19px;
}
    
.about h2 {
    font-size: 18px;
}

.about h3{
    font-size:18px;
    margin-bottom: 15px;
    line-height: 24px;
}    

.about_text01, 
.about_text02 {
    margin-bottom: 30px;
    font-size: 14px;
    line-height: 1.4;
}

.about_text02 {
    width: 100%;
}
    
.about_bg {
   opacity: 0.4;
   width: 100%;
}
    
}
/*company-------------------------------------------------------------------*/    

.company main{
	padding-bottom: 0;
}
.company main p{
	line-height: 1.4;
}

.company .company01{
	position: relative;
}
.company .company01 .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.company main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.company .sitewrap #pan ul {
    margin: 14px 0 51px;
    font-size: 12px;
}

.company .visula{
	padding-top: 78px;
}
.company .top_bg_wrap{
	background: url("../img/company/csr_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.company .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.company .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.company h2{
	font-size: 32px;
    font-weight: bold;
    text-align: center;
}
/*csr-------------------------------------------------------------------*/

.csr .news_wrap .news_list{
	position: relative;
    padding-top: 14px;
}
	

.csr .news_wrap .news_list dl a{
	display: flex;
	padding: 15px 0 20px 0;
	font-size: 16px;
	position: relative;
	z-index: 1;
	border-bottom: solid 1px #cbcbcb;
	transition: .3s;
}
.csr .news_wrap .news_list dl a:hover{
	background: #e8f0ff;
}

.csr .news_wrap .news_list dl dt{
	width: 34%;
}
.csr .news_wrap .news_list dl dd{
	width: 66%;
	line-height: 1.8;
}
.csr .news_wrap .news_list dl dt span{
	display: inline-block;
	width: 146px;
	text-align: center;
	padding: 5px;
	margin-left: 25px;
	border-radius: 15px;
	color: #fff;
}
.csr .news_wrap .news_list dl dt .green_list{
	background: #208815;
}
.csr .news_wrap .news_list dl dt .orenge_list{
	background: #f49315;
}

.csr .more_btn{
	text-align: center;
}

.csr .more_btn a{
	width: 305px;
	margin-top: 40px;
}

.csr02,
.csr03{
    margin-top: 76px;
}

.csr_flex{
    display: flex;
    justify-content: space-between;
}

.csr_flex_l{
    width: 67%;
}

.csr_flex_r{
    width: 28%;
}

.csr_flex_r img{
    width: 100%;
    height: auto;
    display: block;
}

.csr_flex01{
   margin-bottom: 10px;
}

.csr02 h3,
.csr03 h3{
    font-size: 24px;
    font-weight: bold;
    position: relative;
    vertical-align: 0.03em;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 28px;
}

.csr02 h3::before,
.csr03 h3::before{
    content: "";
    background: url("../img/common/h2.png");
    background-size: contain;
    background-repeat: no-repeat;
    width: 21px;
    height: 44px;
    position: absolute;
    left: 0;
}

.csr02 h4,
.csr03 h4{
    font-size: 18px;
    font-weight: bold;
    vertical-align: 0.03em;
    line-height: 48px;
    color: #003399;
}

.csr04{
    margin-top: 100px;
}

.csr .csr04 h2{
    margin-bottom: 30px;
}

.csr04_img{
    text-align: center;
    margin-top: 25px;
}

/*philosophy-------------------------------------------------------------------*/  
.philosophy .blue_text{
    font-size: 22px;
    font-weight: bold;
    line-height: 48px;
    vertical-align: 0.03em;
    color: #003399;
}

.philosophy .philosophy02 p.blue_text{
    line-height: 40px;
    text-align: center;
    margin-bottom: 90px;
}

.philosophy .policy_flex{
    display: flex;
    margin: 55px auto 35px;
}

.philosophy .policy_flex dl{
    width:350px;
    text-align: center;
    border-left: 1px solid #dedede;
}

.philosophy .policy_flex dl:first-child{
    border-left: none;
}

.philosophy .philosophy03{
    position: relative;
}

.philosophy .philosophy03 h2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 48px;
    vertical-align: 0.03em;
    color: #fff;
    background: #003399;
    padding: 55px 0 250px;
}

.philosophy .philosophy03_flex{
    width: 1000px;
    display: flex;
    justify-content: space-between;
    position: absolute;
    top:135px;
}

.philosophy .philosophy03_flex dl{
    width:320px;
    text-align: center;
    background: #fff;
    box-shadow: 0px 0px 24px -5px rgb(0 0 0 / 13%);
    border-radius: 10px;
}

.philosophy .philosophy03_flex dl dt p{
   line-height: normal;
    padding-top: 30px;
}

.philosophy .philosophy03_flex dl dd{
   padding: 20px 30px 40px;
    box-sizing: border-box;
    text-align: left;
}

.philosophy .philosophy04{
    background: #e8f0ff;
    padding: 305px 0 70px;
}

.philosophy .philosophy04 dt{
    border-bottom: 1px solid #003399;
}

.philosophy .philosophy04 dd{
  margin: 20px auto 40px 0px;
}


/*history------------------------------------------------------------------*/  

.history .topics_list{
    border-top: none;
}

.history .topics_list li article dl{
	width:100%;
	display:flex;
}

.history .history_table .topics_list:first-of-type dl{
    border-top: 1px solid #e2e2e2;
}

.history .topics_list li article dt{
    width: 245px;
    background: #ecf7fa;
    letter-spacing: 0.03em;
    line-height: 50px;
    padding: 0px 20px 0;
}

.history .topics_list li article dd{
	width:100%;
	min-width:716px;
    display: flex;
   justify-content: flex-start;
    align-items: center;
    margin-left: 25px;
}

.history .topics_list.topics_left li article dd{
	width:100%;
	min-width:716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
	
.history .topics_list li article dd p{
	width:100%;
}

.history .topics_list li article dd p:first-of-type{
    font-weight: normal;
    letter-spacing: 0.12em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}


/*outline-------------------------------------------------------------------*/  

.outline .topics_list{
    border-top: none;
}

.outline .topics_list li article dl{
	width:100%;
	display:flex;
}

.outline .outline_table .topics_list:first-of-type dl{
    border-top: 1px solid #e2e2e2;
}

.outline .topics_list li article dt{
    width: 245px;
    background: #ecf7fa;
    letter-spacing: 0.03em;
    line-height: 50px;
    padding: 0px 20px 0;
}

.outline .topics_list li article dd li {
    border-bottom:none;
}

.outline .topics_list li article dd{
	width:100%;
	min-width:716px;
    display: flex;
   justify-content: flex-start;
    align-items: center;
    margin-left: 5px;
    padding: 20px;
    box-sizing: border-box;
}

.outline .topics_list.topics_left li article dd{
	width:100%;
	min-width:716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
	
.outline .topics_list li article dd p{
	width:100%;
}

.outline .topics_list li article dd p:first-of-type{
    font-weight: normal;
    letter-spacing: 0.12em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.outline .topics_list li article .office_wrap{
	flex-direction: column;
    align-items: flex-start;
}

.outline .office{
    margin-bottom: 20px;
}

.outline .office p{
    line-height: 1.4;
}

.outline .office > div{
    width: 620px;
}

.outline .office h3{
    font-size: 18px;
    line-height: 25px;
    vertical-align: 0.03em;
    color: #003399;
    padding-top: 15px;
}

.outline .topics_list li .office a {
    display: inline-block;
    padding: 0px;
}

.outline .office .office_img{
    display: flex;
    justify-content: space-between;
    margin: 15px auto;  
}

.outline .office_map{
    max-width: 618px;
    max-height: 200px;
}

.outline .office .office_map a{
    float: right;
    font-size: 14px;
    line-height: 35px;
    vertical-align: 0.03em;
    border-bottom: 1px solid #333333;
}

/*message-------------------------------------------------------------------*/   

.message h2{
    font-size:22px;
    color: #003399;
    line-height: 40px;
    vertical-align: 0.03em;
    text-align: left;
}

.message .message_inner p{
    font-size: 16px;
    line-height: 36px;
    vertical-align: 0.03em;
    margin-bottom: 60px;
}

.message .message_inner{
    margin: 50px auto 0px; 
}

.company .message_name{
    text-align: right;
    margin-bottom: 66px;
}


@media screen and (max-width:768px) {
/*company-------------------------------------------------------------------*/    

.company .foot_bg,
.privacy .foot_bg,
.security .foot_bg,
.baseball .foot_bg,
.news .foot_bg,
.news01 .foot_bg,
.contact .foot_bg{
    background: url( "../img/common/foot_bg.png");
    background-repeat: no-repeat;
    width: 100%;
    height: 185px;
    margin-top: 50px;
}    
    
.company main p {
    font-size: 14px;
    line-height: 1.4;
    margin-bottom: 10px;
    overflow: hidden;
}    
    
.outline .topics_list li article dd p:first-of-type {
    letter-spacing: 0;
}
    
.company main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}
    
.company h2,
.csr .news_wrap h2{
	font-size: 19px;
}
    
.company .top_bg_wrap{
    background: url("../img/company/csr_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
.company .top_bg_wrap .catch h1{
    font-size: 19px;
}
    
.company .news_wrap .sitewrap{
    padding: 0;
}
    
.company .visula{
	padding-top: 0px;
}
    
/*csr-------------------------------------------------------------------*/    

    
.csr02 h3, .csr03 h3 {
    font-size: 18px;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 25px;
}
    
.csr02 h3::before, .csr03 h3::before {
    content: "";
    background: url( "../img/common/h2.png");
    background-size: contain;
    background-repeat: no-repeat;
    height: 30px;
    position: absolute;
    left: 0;
    top: 5px;
}
    
.csr02 h4, .csr03 h4 {
    font-size: 16px;
}
    
.csr .visula {
    padding-top: 0px;
}
    

.csr .news_wrap .news_box{
    flex-direction: column;
}
.csr .news_wrap .more_btn a{
    width: 70%;
    margin: auto;
    padding: 10px 0;
    text-align: center;
    background: #003399;
}
.csr .news_wrap .news_list{
    width: 100%;
    padding: 0 15px 30px 15px;
    box-sizing: border-box;
}
.csr .news_wrap .news_list dl a{
    flex-direction: column;
}
.csr .news_wrap .news_list dl dt{
    width: 100%;
    font-size: 14px;
    margin-bottom: 5px;
}
.csr .news_wrap .news_list dl dt span{
    width: 90px;
    padding: 3px;
    font-size: 11px;
}
.csr .news_wrap .news_list dl dd{
    width: 100%;
    font-size: 14px;
    line-height: normal;
} 

.csr02,
.csr03,
.csr04{
    margin-top: 55px;
}

.csr_flex {
    display: flex;
    flex-direction: column;
} 
    
.csr_flex_r{
   order: 1;
}
    
.csr_flex_l{
   order: 2;
}
    
  .csr_flex_l,
  .csr_flex_r{
    width:100%;
}  
    
/*philosophy-------------------------------------------------------------------*/  
.philosophy .blue_text{
    font-size: 18px;
    line-height: normal;
}
    
.philosophy .blue_text p {
    font-size: 18px;
}

.philosophy .philosophy02 p.blue_text{
    font-size: 18px;
    line-height: normal;
    margin-bottom: 30px;
}
    
.philosophy h2{
    font-size: 19px;
}

.philosophy .policy_flex{
    display: block;
    margin: 30px auto 30px;
}

.philosophy .policy_flex dl{
    width:auto;
    text-align: center;
    border-left: none;
    margin-bottom: 15px;
}

.philosophy .policy_flex dl div{
   width:30%;
   margin: 0 auto;
}

.philosophy .philosophy03 h2 {
    font-size: 19px;
    line-height: normal;
    padding: 30px 0 250px;
}

.philosophy .philosophy03_flex{
    width: auto;
    display: block;
    position: absolute;
    top:90px;
    left: 50%;
    transform: translatex(-50%);
}

.philosophy .philosophy03_flex dl{
   margin-bottom: 15px;
}

.philosophy .philosophy03_flex dl dt p{
   line-height: normal;
    padding-top: 30px;
}

.philosophy .philosophy03_flex dl dd{
   padding: 20px 30px 40px;
    box-sizing: border-box;
}

.philosophy .philosophy04{
    background: #e8f0ff;
    padding: 1130px 0 30px;
}

.philosophy .philosophy04 dd{
  margin: 20px auto 30px 0px;
}

    
/*history-------------------------------------------------------------------*/  

.history .topics_list{
    border-top: none;
}

.history .topics_list li article dl{
	display: block;
    margin: 0 auto;
}

.history .history_table .topics_list:first-of-type dl{
    border-top: 1px solid #e2e2e2;
}

.history .topics_list li article dt{
   width: auto;
    padding: 0 0 0 10px;
}

.history .topics_list li article dd{
	width: 100%;
    min-width: 0px;
    height: 60px;
    margin-left: 8px;
}

.history .topics_list.topics_left li article dd{
	width: 100%;
    min-width: 0px;
    height: 60px;
    margin-left: 8px;
}    
    
/*outline-------------------------------------------------------------------*/  

.outline .topics_list{
    border-top: none;
}
    
.outline .topics_list li article .office_wrap {
    align-items: center;
}

.outline .topics_list li article dl{
	display: block;
    margin: 0 auto;
}

.outline .outline_table .topics_list:first-of-type dl{
    border-top: 1px solid #e2e2e2;
}

.outline .topics_list li article dt{
   width: auto;
    padding: 0 0 0 10px;
}

.outline .topics_list li article dd{
	width: 100%;
    min-width: 0px;
    min-height: 60px;
    height: auto;
    margin-left: 0px;
}

.outline .topics_list.topics_left li article dd{
	width: 100%;
    min-width: 0px;
    min-height: 60px;
    height: auto;
    margin-left: 8px;
}
    
.outline .office > div {
    width: auto;
}    
    
.outline .office .office_img {
    display: block;
    margin-bottom: 15px;
}
    
.outline .office .office_img div{
    margin-bottom: 15px;
}
    
.outline .office h3 {
    margin-bottom: 10px;
}
   
    
/*message-------------------------------------------------------------------*/   

.message h2{
    font-size:18px;
    color: #003399;
    line-height: normal;
    vertical-align: 0.03em;
    text-align: left;
}

.message .message_inner p{
    font-size: 14px;
    line-height: 1.4;
    vertical-align: 0.03em;
    margin-bottom: 60px;
}

.message .message_inner{
    margin: 30px auto 0px; 
}

.company .message_name{
    text-align: right;
    margin-bottom: 66px;
    float: right;
}    
    
.company .message_name::after{
    content: "";
   display: block;
   clear: both;
}  
    
}

/*baseball-------------------------------------------------------------------*/

.baseball footer{
    padding: 0px 0 0;
}

.baseball .copyright_wrap {
    justify-content: center;
}

/*baseball_header-------------------------------------------------------------------*/
.baseball .heading_right_menu li.contact_btn a {
    background: #003399;
    padding-right: 30px;
    color: #fff;
}

.baseball .heading_right_menu li.contact_btn a{
     padding-right: 30px;
    position: relative;
}

.baseball .heading_right_menu li.contact_btn a span {
    background-image: none;
    color: #fff;
}

.baseball .heading_right_menu li.contact_btn a::before {
    content: "";
    position: absolute;
    background: url(../img/common/new_btn.png) no-repeat;
    width: 19px;
    height: 19px;
    top: 50%;
    transform: translateY(-50%);
    right: 10px;
}

.baseball .heading_right_menu li.contact_btn a {
    width: 200px;
    padding: 0 40px 0 10px;
}

.baseball .drop_menu #NavWrap li.drop_wrap:hover + li:before {
    opacity: 0;
    max-height: 100vh;
}

.baseball .company_list {
    padding-right: 0px;
}

/*-------------------------------------------------------------------*/
.baseball main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.baseball main{
	padding-bottom: 0;
}

.baseball .visula{
	padding-top: 78px;
}

.baseball .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.baseball .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.baseball .baseball_head{
	position: relative;
}
.baseball .baseball_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

/*baseball_top-------------------------------------------------------------------*/

.baseball.baseball_top .top_bg_wrap{
	background: url( "../img/baseball/h1.png") no-repeat;
	background-size: cover;
	padding-top: 26%;
	position: relative;
}

.baseball.baseball_top .top_bg_wrap .catch h1 {
    font-size: 50px;
    font-weight: bold;
    color:#fff;
}

.baseball.baseball_top .top_bg_wrap .catch {
    position: absolute;
    top: 50%;
    left: 20%;
    transform: translate(-50%,-50%);
}

.baseball.baseball_top .baseball_wrap .sitewrap{
    width: 767px;
    min-width: 767px;
    margin: 0 auto;
}

.baseball.baseball_top .image{
    margin: 45px auto 35px;
}

.baseball.baseball_top .btn{
    text-align: center;
    margin-top: 70px;
}

/*baseball_inner-------------------------------------------------------------------*/
.baseball .top_bg_wrap{
	background: url("../img/baseball/player_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.baseball .btn_wrap{
    display: flex;
    justify-content: space-between;
}

.baseball .btn_inner{
    width: 100%;
}

.link_mark{
    display: block;
    margin-top: -50px;
    padding-top: 50px;
}

.baseball .btn_inner a{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 50px;
    background:#fff;
    border-radius: 5px;
    border:1px solid #003399;
    font-size: 16px;
    font-weight: bold;
    color: #003399;
    transition: background .4s;
    margin-right: 10px;
}

.baseball .btn_inner:last-of-type a{
    margin-right: 0;
}

.baseball .btn_inner a:hover{
    background:#003399;
    color:#fff;
}

.baseball h3{
    display: inline-block;
    font-size: 24px;
    font-weight: bold;
    position: relative;
    vertical-align: 0.03em;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 28px;    
}

.baseball h3::before{
    content: "";
    background: url("../img/common/h2.png");
    background-size: contain;
    background-repeat: no-repeat;
    width: 21px;
    height: 44px;
    position: absolute;
    left: 0;
}

.baseball .current a {
    background: #003399;
    color: #fff;
}
/*player-------------------------------------------------------------------*/

.player .player_wrap{
    display: flex;
    justify-content: space-between;
    margin-bottom: 30px;
}

.player .player_inner{
    width:260px;
    height:196px;
    background:#fff;
    border-radius: 12px;
    border:1px solid #003399;
    font-size: 16px;
    font-weight: bold;
    color: #003399;
    margin-bottom: 17px;
    padding: 40px 23px;
}

.player .player_inner > dt{
    padding-bottom: 23px;
    font-size: 22px;
    border-bottom: 1px solid #858585;
}

.player_inner dd dl{
    display: flex;
}

.player_inner dd dl dd span{
    display: block;
}


.player_inner dd dl,
.player_inner dd dl dd .mt16,
.player_inner dd > div{
   margin-top: 16px;
}

.omit{
    margin:128px auto 96px;
}

/*result-------------------------------------------------------------------*/

.result .btn_inner {
    width: 160px;
    margin-bottom: 15px;
}

.result .btn_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

.result .btn_inner:last-of-type a {
   margin-right: 10px;
}

.result .result_wrap{
    margin-bottom: 70px;
}

.result h2 {
    font-size: 32px;
    font-weight: bold;
    line-height: 48px;
    vertical-align: 0.03em;
    text-align: center;
    margin-top: 50px;
}

.result h3 {
   color: #003399;
}


.result td, 
.result th {
    border: 1px solid #e6e5eb;
	border-collapse: collapse;
    text-align: center;
	padding: 20px;
	width: 225px;
	height: 80px;
    box-sizing: border-box;
}

.result td:first-child,
.result th:first-child {
	width: 115px;
    border: none;
    border-bottom: 1px solid #e6e5eb;
}

.result td:last-child,
.result th:last-child {
    border: none;
    border-bottom: 1px solid #e6e5eb;
}

.result th {
	background: #003399;
    color: #fff;
    height: 55px;
}


.result .result_box_d th{
    background:#ecf7fa;
    color: #333;
}

.result .result_box_d .result_name{
    width: 305px;
}

.result .result_box_d td, 
.result .result_box_d th {
   width: 50px;
   height: 50px;
}

.result .result_box_d p{
   display: block;
   margin: 20px auto 0 115px;
}

.result .result_box_d .red_list{
    color: red;
}

.result .result_box{
    position: relative;
}

.result .table_btn{
    cursor: pointer;
    transition: 0.5s transform, right 0.2s;
    position: absolute;
    right: 45px;
    top: 83px;
}


.result .table_btn span{
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 5px;
    margin: 0 auto;
    background: #0099cc;
    color: #fff;
    width: 120px;
    height: 40px;
}

/*書き足し-------------------------------------------------------------------*/

.result .table_th {
    display: flex;
}

.result .table_th li:first-child, 
.result .result_box li:first-child {
    width: 115px;
    border: none;
    border-bottom: 1px solid #e6e5eb;
}

.result .result_box .table_th li{
    display: flex;
    align-items: center;
    justify-content: center;
    background: #003399;
    color: #fff;
    height: 55px;
    box-sizing: border-box; 
}

.result .table_td{
    display: flex;
    border: 1px solid #e6e5eb;
    border-collapse: collapse;
    text-align: center;
    padding: 20px;
    width: 225px;
    height: 80px;
    box-sizing: border-box; 
}

.result .result_box ul{
    display: flex;
}

.result .result_box li{
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #e6e5eb;
    border-collapse: collapse;
    text-align: center;
    padding: 20px;
    width: 225px;
    height: 80px;
    box-sizing: border-box;
}

.result .accordion_wrap .opened {
    margin: 20px auto 0 115px;
}

.result .accordion_wrap .opened .result_name {
    width: 305px;
}

.result .accordion_wrap .opened td,
.result .accordion_wrap .opened th{
    width: 50px;
    height: 50px;
}

.result .accordion_wrap .opened th {
    background: #ecf7fa;
    color: #333;
}

.result .accordion_wrap{
    position: relative;
}

.result .accordion_wrap .table_btn {
    cursor: pointer;
    transition: 0.5s transform, right 0.2s;
    position: absolute;
    right: 50px;
    top: 19px;
}

.result .result_box_d{
    padding: 10px;
}

.result .result_box_d p{
	display:inline-block;
}

@media screen and (max-width:768px) { 
    
/*baseball-------------------------------------------------------------------*/

.baseball .visula {
    padding-top: 0px;
}
    
.baseball .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.baseball .top_bg_wrap{
    background: url("../img/baseball/player_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}    
    
.baseball main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}
    
.baseball .copyright_wrap {
    justify-content: center;
    padding: 13px 15px 13px 15px;
}
    
/*baseball_header-------------------------------------------------------------------*/

.baseball .heading_right_menu li.contact_btn a {
    width: 60px;
    height: 60px;
    padding: 0;
    box-sizing: border-box;
    font-size: 9px;
    text-align: center;
    position: relative;
}
    
.baseball .heading_right_menu li.contact_btn a::before {
    content: "";
    position: absolute;
    background: url(../img/common/new_btn.png) no-repeat;
    width: 19px;
    height: 19px;
    top: 15%;
    right: unset;
    left: 50%;
    transform: translateX(-50%);
}
    
.baseball .drop_menu #NavWrap ul li.baseball_pc {
    display: none
}    
    
/*baseball_top-------------------------------------------------------------------*/

.baseball.baseball_top .top_bg_wrap{
	background: url( "../img/baseball/h1_sp.png") no-repeat;
	background-size: cover;
	padding-top: 66%;
	position: relative;
}

.baseball.baseball_top .top_bg_wrap .catch h1 {
    font-size: 22px;
    font-weight: bold;
    color:#fff;
}

.baseball.baseball_top .top_bg_wrap .catch {
    position: absolute;
    top: 25%;
    left: 20%;
    transform: translate(-50%,-50%);
}

.baseball.baseball_top .baseball_wrap .sitewrap{
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}

.baseball.baseball_top .image{
    margin: 45px auto 35px;
}

.baseball.baseball_top .btn{
    text-align: center;
    margin-top: 70px;
}


/*baseball_inner-------------------------------------------------------------------*/
    
.baseball h3 {
    font-size: 18px;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 25px;
}
    
.baseball h3::before {
    content: "";
    background: url(../img/common/h2.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 30px;
    position: absolute;
    left: 0;
    top: 5px;
}
    
.baseball .btn_wrap {
    display: flex;
    justify-content: space-evenly;
    flex-wrap: wrap;
}
    
.baseball .btn_inner{
    width: 45%;
    margin-bottom: 15px;
}
    
.baseball .btn_inner a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:100%;
}   
    
/*player-------------------------------------------------------------------*/
   
.player .player_wrap {
    display: block;
    margin-bottom: 30px;
}
    
 .player .player_inner {
   margin: 0 auto 15px;
}   
    
.player_box{
    margin-bottom: 30px;
}
    
.omit img{
    width:auto;
}
    
/*result-------------------------------------------------------------------*/

.result .btn_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
}

.result .result_wrap{
    margin-bottom: 30px;
}

.result h2 {
    font-size: 19px;
    margin-top: 30px;
    line-height: normal;
}
    
.result .table_btn span {
    width: 70px;
}
    
.result .accordion_wrap .table_btn {
    cursor: pointer;
    transition: 0.5s transform, right 0.2s;
    position: absolute;
    right: 7px;
    top: 19px;
}
    
.result .result_box li {
   padding: 10px;
}
 
.result td, 
.result th {
    text-align: center;
	padding: 10px;
	max-width: 225px;
	height: 40px;
}

/*240129 スマホ表示チーム名表示 ----------------
.result td:first-child,
.result th:first-child {
	display: none;
}
----------------------------------------------*/

.result th {
	background: #003399;
    color: #fff;
    height: 30px;
}

.result .accordion_wrap .opened {
    margin: 0;
}
.result .result_box_d table{
	display: block;
	overflow-x: scroll;
	white-space: nowrap;
	-webkit-overflow-scrolling: touch;
}
.result .result_box_d tbody{
	width: 500px;
	display:table;
}
.result .result_box_d th{
    background:#ecf7fa;
    color: #333;
}

.result .result_box_d td, 
.result .result_box_d th {
   width: 50px;
   height: 50px;
}

.result .result_box_d p{
   display: block;
   margin: 20px auto 0 0px;
} 
    
}

/*player01-------------------------------------------------------------------*/

.player01 .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.player01 main{
	padding-bottom: 0;
}

.player01 .visula{
	padding-top: 78px;
}

.player01 .top_bg_wrap{
	background: url("../img/baseball/player_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.player01 .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.player01 .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}

.player01 .player_head{
	position: relative;
}
.player01 .player_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.player01_flex{
    display: flex;
    justify-content: center;
    color: #003399;
    margin-bottom: 55px;
}

.player01_flex_l{
    padding-right: 40px;
}

.player01_flex_r > dl > dt{
    font-size: 22px;
    line-height: 32px;
    vertical-align: 0.05em;
    font-weight: bold;
}

.player01_flex_r > dl > .profile{
    margin-top: 36px;
    width: 400px;
}

.profile dl{
    display: flex;
    border-bottom: 1px solid #858585;
}

.profile dt{
    width: 89px;
    padding-top: 15px;
}

.profile dd{
    border-left: 1px solid #858585;
    padding: 15px 0 20px 10px;
}

.profile dl:first-of-type dd,
.profile dl:first-of-type dt{
    padding-top: 0;
}

.player01 .more_btn{
    text-align: center
}

@media screen and (max-width:768px) { 
    
.player01 .visula {
    padding-top: 0px;
}
    
.player01 .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.player01 .top_bg_wrap{
    background: url("../img/baseball/player_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}  
  
.player01 .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}    
    
.player01_flex {
    display: block;
    color: #003399;
   margin: 0 auto 30px;
}
    
.player01_flex_l {
    padding-right: 0px;
    margin-bottom: 15px;
}    
    
.player01_flex_r > dl > .profile {
    width: auto;
}
    
    
}

 /*news-------------------------------------------------------------------*/   
.news .news_head{
	position: relative;
}
.news .news_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.news main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.news main{
	padding-bottom: 0;
}

.news .visula{
	padding-top: 78px;
}

.news .top_bg_wrap{
	background: url("../img/news/news_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.news .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.news .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}  
    
.news .btn_wrap{
    display: flex;
    justify-content: space-between;
}

.news .btn_inner a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:160px;
    height: 50px;
    background:#fff;
    border-radius: 5px;
    border:1px solid #003399;
    font-size: 16px;
    font-weight: bold;
    color: #003399;
    transition: background .4s;
}   
    
.news .btn_inner a:hover{
    background:#003399;
    color:#fff;
}

.news .current a{
    background:#003399;
    color:#fff;
}

.news .new {
    display: inline-block;
    color: red;
    font-weight: bold;
    margin-left: 15px;
}  

.news .news_wrap .news_list{
	position: relative;
    padding-top: 30px;
}
	

.news .news_wrap .news_list dl a{
	display: flex;
	padding: 15px 0 20px 0;
	font-size: 16px;
	position: relative;
	z-index: 1;
	border-bottom: solid 1px #cbcbcb;
	transition: .3s;
}
.news .news_wrap .news_list dl a:hover{
	background: #e8f0ff;
}

.news .news_wrap .news_list dl dt{
	width: 30%;
}
.news .news_wrap .news_list dl dd{
	width: 68%;
	line-height: 1.8;
}
.news .news_wrap .news_list dl dt span{
	display: inline-block;
	width: 146px;
	text-align: center;
	padding: 5px;
	margin-left: 25px;
	border-radius: 15px;
	color: #fff;
}
.news .news_wrap .news_list dl dt .green_list{
	background: #208815;
}
.news .news_wrap .news_list dl dt .orenge_list{
	background: #f49315;
}    
.news .news_wrap .news_list dl dt .blue_list{
	background: #0099cc;
}
.news .news_wrap .news_list dl dt .red_list{
	background: #d41132;
}
.news .news_wrap .news_list dl dt .black_list{
	background: #5c5c5c;
}
 
.prev a div{
    content: "";
    background: url("../img/common/arrow_prev.png");
    background-repeat: no-repeat;
    background-size: contain;
    width:19px;
    height: 17px;
    display: inline-block;
}

.prev a:hover div{
    content: "";
    background: url("../img/common/arrow_prev_w.png");
    background-repeat: no-repeat;
    background-size: contain;
    width:19px;
    height: 17px;
    display: inline-block;
}

.next a div{
    content: "";
    background: url("../img/common/arrow_next.png");
    background-repeat: no-repeat;
    background-size: contain;
    width:19px;
    height: 17px;
    display: inline-block;
}

.next a:hover div{
    content: "";
    background: url("../img/common/arrow_next_w.png");
    background-repeat: no-repeat;
    background-size: contain;
    width:19px;
    height: 17px;
    display: inline-block;
}

.news .more_btn a{
    margin-top: 20px;
}

@media screen and (max-width:768px) { 
    
.news .visula {
    padding-top: 0px;
}
    
.news .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.news .top_bg_wrap{
    background: url("../img/news/news_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}  
  
.news main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}    
    
.news .btn_wrap {
    display: flex;
    justify-content: space-evenly;
    flex-wrap: wrap;
}
    
.news .btn_inner{
    width: 45%;
    margin-bottom: 15px;
}
    
.news .btn_inner a{
    display: flex;
    justify-content: center;
    align-items: center;
    width:100%;
} 
    
.news .player_wrap {
    display: block;
    margin-bottom: 30px;
}    
    
.news .news_wrap .sitewrap .sitewrap{
    padding: 0;
} 
    
.news .news_wrap .news_box{
    flex-direction: column;
}
.news .news_wrap .more_btn a{
    width: 70%;
    margin: auto;
    padding: 10px 0;
    text-align: center;
    background: #003399;
}
.news .news_wrap .news_list{
    width: 100%;
    padding: 0 15px 30px 15px;
    box-sizing: border-box;
}
.news .news_wrap .news_list dl a{
    flex-direction: column;
}
.news .news_wrap .news_list dl dt{
    width: 100%;
    font-size: 14px;
    margin-bottom: 5px;
}
.news .news_wrap .news_list dl dt span{
    width: 90px;
    padding: 3px;
    font-size: 11px;
}
.news .news_wrap .news_list dl dd{
    width: 100%;
    font-size: 14px;
    line-height: normal;
} 
    
}

/*news01-------------------------------------------------------------------*/  

.news01 .news_head{
	position: relative;
}
.news01 .news_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.news01 main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.news01 main{
	padding-bottom: 0;
}

.news01 .visula{
	padding-top: 78px;
}

.news01 .top_bg_wrap{
	background: url("../img/news/news_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.news01 .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.news01 .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}  

.news01 .news_wrap .white{
	display: inline-block;
	width: 146px;
	text-align: center;
	padding: 5px;
	border-radius: 15px;
    margin-right: 15px;
	color: #fff;
    line-height: 1.4;
}

.news01 .news_wrap .blue_list{
	background: #0099cc;
}

.news01 h2{
    font-size: 24px;
    font-weight: bold;
    position: relative;
    vertical-align: 0.03em;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 28px;    
}

.news01 h2::before{
    content: "";
    background: url("../img/common/h2.png");
    background-size: contain;
    background-repeat: no-repeat;
    width: 21px;
    height: 44px;
    position: absolute;
    left: 0;
}

.news01 .news_wrap{
    font-size: 16px;
    line-height: 36px;
    vertical-align: 0.03em;
    margin-bottom: 55px;
}

.news01 .news_wrap .more_btn{
    text-align: center;
}

.news01 .photo{
    text-align: center;
    margin: 85px auto;
}

.news01 .news_wrap p {
	line-height: 36px;
}

@media screen and (max-width:768px) { 
    
.news01 .visula {
    padding-top: 0px;
}
    
.news01 .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.news01 .top_bg_wrap{
    background: url("../img/news/news_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}  
  
.news01 main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}    

.news01 h2 {
    font-size: 18px;
    line-height:1.8;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 25px;
}
    
.news01 h2::before {
    content: "";
    background: url(../img/common/h2.png);
    background-size: contain;
    background-repeat: no-repeat;
    height: 30px;
    position: absolute;
    left: 0;
    top: 5px;
}
    
.news01 .news_wrap p {
	font-size: 14px;
    line-height: 1.4;
}


}

/*contact-------------------------------------------------------------------*/  

form{
    background:#fff;
}

.entry form {
    margin-bottom: 50px;
}

.contact .contact_head{
	position: relative;
}
.contact .contact_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.contact main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.contact main{
	padding-bottom: 0;
}

.contact .visula{
	padding-top: 78px;
}

.contact .top_bg_wrap{
	background: url("../img/contact/contact_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.contact .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.contact .contact_wrap h2{
	font-size: 32px;
    font-weight: bold;
    text-align: center;
    margin-bottom: 28px;
}

.contact .contact_wrap .form h2{
     margin-top: 90px;
}

.contact .contact_wrap .form h2,
.contact01 .contact_wrap .center,
.entry01 .contact_wrap .center{
    margin-bottom: 40px;
}

.entry .contact_wrap .center{
    margin: 60px auto 15px;
    text-align: center;
}
.entry .recruitbnr_wrap{
	display:flex;
	justify-content:center;
	align-items:center;
	margin-bottom:40px;
	flex-wrap: wrap;
}
.entry .recruitbnr_wrap a{
	display:block;
	margin:0 2%;
}
.contact_table_wrap{
    margin-bottom: 60px;
}
.contact_table_wrap .topics_list li a {
	display:inline-block;
	padding:0;
	text-decoration: underline;
}
.contact_table_wrap .topics_list li a:hover{
	text-decoration:none;
}
.contact .contact_wrap .tel{
	font-size: 22px;
    font-weight: bold;
    text-align: center;
    vertical-align: 0.03em;
}

.contact .contact_wrap .tel a{
	font-size: 36px;
    font-weight: bold;
    color:#003399;
}

.contact .contact_wrap .tel span{
	font-size: 16px;
    font-weight: normal;
    display: block;
}

.contact .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}  

.contact .contact_main .contact_table{
	position: relative;
    background: #fff;
    padding: 60px 115px;
    border-radius: 10px;
    box-shadow: 0px 3px 6px 1px #eee;
    margin: 100px 6px 6px;
    box-sizing: border-box;
}


.contact .contact_main .contact_table h3 span:first-of-type{
	display: block;
    border-bottom: none;
    padding: 0;
	text-align:center;
	font-size:24px;
}

.contact .contact_main .contact_table h3 span:last-of-type{
	padding: 0 55px;
	border-bottom: solid 2px #5073e4;
    text-align: center;
	font-size:24px;
}


.contact .contact_main .contact_table .topics_list li article dt span{
	display: block;
    width: 52px;
    height: 22px;
    background-color: #bd0d0d;
    color: #fff;
    font-size: 14px;
    text-align: center;
    line-height: 22px;
    margin-top: 15px;
	margin-left:0px;
	border: none;
    padding: 0;
}


.contact .contact_main .contact_table .topics_list li article dd span{
	margin-right: 10px;
	font-weight: bold;
	color: #636161;
	border: none;
    padding: 0;
    margin-left: 0px;
    font-size: 16px;
}

.contact .topics_list{
    border-top: none;
}


.contact .topics_list li article dl{
	width:100%;
	display:flex;
}


.contact .contact_table .topics_list:first-of-type dl{
    border-top: 1px solid #e2e2e2;
}

.contact .topics_list li article dt,
.entry .topics_list li article dt{
    width: 245px;
    background: #ecf7fa;
    letter-spacing: 0.03em;
    line-height: 50px;
    padding: 0px 20px 0;
}

.contact .topics_list li article dd{
	width:100%;
	min-width:716px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.contact .topics_list.topics_left li article dd{
	width:100%;
	min-width:716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.ml8{
	margin-left: 8px;
}

.ml8 span{
    display:inline-block;
    margin-left: 8px;
}

.contact .topics_list li article dd textarea,
.contact .topics_list li article dd input,
.contact .topics_list li article dd select{
	border: 1px solid #e2e2e2;
    height: 35px;
    display: inline-block;
    margin: 8px auto 8px 10px;
    border-radius: 5px;
    padding: 0.5em 1em;
}
	
.contact .topics_list li article dd p{
	width:100%;
}


.contact .topics_list li article dd p:first-of-type{
    font-weight: normal;
    letter-spacing: 0.12em;
    display: flex;
    justify-content: center;
    align-items: center;
}

.contact .topics_list li article dd textarea{
	width: 716px;
    height: 150px;
	font-size: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0.5em 1em;
    margin: 8px auto 8px 10px;
}

.contact .topics_list li article dd .name{
	width: 716px;
	font-size: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 8px;
    padding: 0.5em 1em;
}


.contact .topics_list li article dd .mail{
	width: 716px;
	font-size: 16px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0.5em 1em;
    margin: 8px auto 8px 10px;
}

.contact .topics_list li article dd .post{
	width: 50px;
    font-size: 16px;
    border-radius: 10px;
    padding: 0.3em 27px;
}

.contact .topics_list li article dd .post1{
	width: 41px;
}

.contact .topics_list li article dd select{
	width: 249px;
    color: #636161;
    font-size: 16px;
    padding: 0.5em 1em;
    margin: 8px auto 8px 10px;
}

.contact .topics_list li article dd .text{
	width:716px;
	font-size: 16px;
    padding: 0.5em 1em;
    margin: 8px auto 8px 10px;
}


.contact .contact_table .common_btn{
    display: inline-block;
    vertical-align: middle;
    text-decoration: none;
	width:100%;
	margin:0 auto;
}

.contact .contact_table .common_btn a:hover{
	color: #5073e4;
    background: #ffffff;
    margin-top: 20px;
    border-radius: 10px;
    font-weight: bold;
    border: 1px solid #5073e4;
    opacity: 0.8;
    box-sizing: border-box;
}

.contact .contact_table .common_btn a{
	display:inline-block;
	color: #fff;
    background: #5073e4;
    padding: 10px 80px;
	margin:20px auto 0px auto;
    border-radius: 10px;
    font-weight: bold;
	font-size: 15px;
	border:none;
	line-height:1.4;
}

.contact .contact_table .common_btn a:after{
	display: inline-block;
    content: "";
    width: 0;
    height: 0;
    border: 5px solid transparent;
    border-left: 8px solid #5073e4;
    position: absolute;
    top: 50%;
    margin-top: -5px;
    left:351px;
}


.contact .contact_table .common_btn a:before{
	display: inline-block;
	content:"";
	width:0;
	height:0;
	border: 6px solid transparent;
	border-left: 8px solid #fff;
	position:absolute;
	top: 50%;
    margin-top: -6px;
	left:352px;
	
}

.contact .contact_table .common_btn .submit:hover:after{
	 border-left: 8px solid #fff;
}

.contact .contact_table .more_btn .submit input[type="submit"],
.contact .contact_table .more_btn .reset input[type="reset"]{
	background-color: transparent;
    border: none;
    color: #fff;
    font-size: 16px;
    border-radius: 10px;
    font-weight: bold;
}

.contact .contact_table .more_btn .reset input[type="reset"]{
    color:#003399;
}

.entry01 .contact_table .more_btn .reset input[type="reset"]{
    color:#f49315;
}

.contact .more_btn .submit,
.contact .more_btn .reset{
	display: inline-block;
	width: 305px;
	border-radius: 5px;
	padding: 20px;
	box-sizing: border-box;
	color: #fff;
	background: #003399;
	text-align: center;
	position: relative;
	text-decoration: none;
    cursor : pointer;
}

.contact .more_btn .reset{
	color: #003399;
	background: #fff;
    border: 2px #003399 solid;
    margin-right: 20px;
}

.entry01 .more_btn .reset{
	color: #f49315;
    border: 2px #f49315 solid;
}

.contact .more_btn .submit::after{
	content: "";
	position: absolute;
	background: url("../img/common/btn_arrow.png") no-repeat;
	background-size: contain;
	width: 25px;
	height: 25px;
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	transition: .2s;
}

.contact .more_btn .reset::after{
    content: "";
	position: absolute;
	background: url( "../img/common/btn_arrow02_w.png") no-repeat;
	background-size: contain;
	width: 25px;
	height: 25px;
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	transition: .2s;
}

.entry01 .more_btn .reset::after{
    content: "";
	position: absolute;
	background: url( "../img/common/btn_arrow02_o.png") no-repeat;
	background-size: contain;
	width: 25px;
	height: 25px;
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	transition: .2s;
}

.contact .check{
    display: flex;
    justify-content: center;
    align-items: center;
}

input[type=checkbox] {
display: none; 
}

.checkbox{
    position: relative;
    padding-left: 3em;
}

.checkbox::before{
    content: "";
    position: absolute;
    width: 28px;
    height: 28px;
    border-radius: 5px;
    border: 1px solid #cad1d0;
    margin-right: 15px;
    left: 0px;
    top: -6px;
}

.contact .check > input[type="checkbox"] + label:after {
    width: 12px;
    height: 17px;
    border-width: 4px;
    left: 6px;
    top: 6px;
}

.contact .check input[type="checkbox"]:checked + label:after {
    opacity: 1;
}

.contact .check input[type="checkbox"] ~ label:after {
    content: "";
    display: inline-block;
    position: absolute;
    top: -2px;
    left: 9px;
    border-bottom: solid 3px #1c3385;
    border-right: solid 3px #1c3385;
    width: 12px;
    height: 16px;
    box-sizing: border-box;
    line-height: 1;
    z-index: 1;
    transform: rotate(45deg);
    opacity: 0;
    transition: opacity .4s;
}

.contact.entry .check input[type="checkbox"] ~ label:after {
    border-bottom: solid 3px #f49315;
    border-right: solid 3px #f49315;
}

.contact_table .more_btn{
    text-align: center;
    border-top: none;
    margin:30px auto 82px;
}

.contact01 .contact_table .more_btn,
.entry01 .contact_table .more_btn{
    text-align: center;
    border-top: none;
    margin:30px 0 82px;
}

.form_btn{
    display: flex;
    justify-content: center;
}

::placeholder{
  color:#cccccc;
  text-align: left;
  padding-left: 8px;
}

select {
  -webkit-appearance: none;
  appearance: none; 
}

.select{
    position: relative;
}

.select::after{
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 13px 8px 0 8px;
    border-color: #333333 transparent transparent transparent;
    left: 220px;

}

@media screen and (max-width:768px) { 
    
.contact .visula {
    padding-top: 0px;
}
    
.contact .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.contact .top_bg_wrap{
    background: url("../img/contact/contact_top_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}  
  
.contact main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}    
    
.contact .contact_wrap h2 {
    font-size: 18px;
}
    
.contact .contact_wrap .form h2{
     margin-top: 0px;
}
    
.contact .contact_wrap .tel {
    font-size: 14px;
}
    
.contact .contact_wrap .tel a {
    font-size: 18px;
}
    
.contact .contact_wrap .tel span {
    font-size: 14px;
}
    
.contact .form {
    margin-top: 30px;
}

.entry .recruitbnr_wrap{
	margin-bottom: 20px;
}
.entry .recruitbnr_wrap a{
	display:block;
	margin:0 2%;
}
    
.contact .topics_list li article dd .name{
    box-sizing: border-box;
    margin: 8px auto 8px 0px;
    width: 100%;
}
    
.contact .topics_list li article dd textarea,
.contact .topics_list li article dd input,
.contact .topics_list li article dd select{
    margin: 8px auto 8px 0px;
}
    
.contact .topics_list li article dd .text {
    margin: 8px auto 8px 0px;
}
    
.contact .topics_list li article dd .mail {
    margin: 8px auto 8px 0px;
}
 
.contact .topics_list li article dl {
    display: block;
    margin: 0 auto;
}
    
.contact .topics_list li article dd {
    min-width: 0px;
    width:100%;
    display: flex;
    justify-content: center;
    align-items: center;
} 
    
.contact .topics_list.topics_left li article dd {
    min-width: 0px;
    width:100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
    
 .contact .topics_list li article dt {
    width: auto;
    padding: 0 0 0 10px;
}
    
.contact .contact_table .topics_list:first-of-type dl {
    border-top: none;
}
    
 .topics_list li {
    border-bottom: none;
}
    
 .contact .check {
    display: flex;
    justify-content: space-around;
}
    
.check p{
    width: 80%;
    display: block;
}
    
.form_btn {
    display: block;
}
    
.contact .more_btn .reset,
.entry .more_btn .reset{
    margin-right: 0px;
}
    
.more_btn .reset {
    margin-right: 0px;
}
    
.contact_table .more_btn {
    margin: 30px auto 0px;
}
    
}

/*contact01-------------------------------------------------------------------*/  

.contact01 .topics_list li article dd p:first-of-type {
    font-weight: normal;
    letter-spacing: 0.12em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 8px;
}

.contact01 .topics_list li article dd {
    width: 100%;
    min-width: 716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 8px;
}

.contact01 .select::after {
    display: none;
}

@media screen and (max-width:768px) { 
.contact01 .topics_list li article dd,
.entry01 .topics_list li article dd{
    width: 100%;
    min-width: 0px;
    height: 60px;
}
    
 .contact .topics_list.topics_left li article dd {
    justify-content:flex-start;
    align-items: center;
}
    
.contact01 .contact_table .more_btn {
    text-align: center;
    border-top: none;
    margin: 30px 0 0px;
}

}

/*contact02-------------------------------------------------------------------*/
.contact.contact02  h2 {
    margin-bottom: 45px;
}

.contact02 .txt{
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

.contact02 .more_btn{
    text-align: center;
}

.contact02 .txt p{
    display: inline-block;
    margin-bottom: 40px;
}

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

.contact.contact02  h2 {
    margin-bottom: 30px;
}

.contact02 .txt{
    width: 100%;
    margin: 0 auto;
    text-align: left;
}

.contact02 .txt p{
    display: inline-block;
    margin-bottom: 20px;
}

}

/*entry-------------------------------------------------------------------*/

.entry .top_bg_wrap{
	background: url("../img/entry/contact_top.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}


.entry .topics_list li article dt {
    background: #f3f3f3;
    letter-spacing: 0.03em;
    line-height: 50px;
    padding: 0px 20px 0;
}

.entry .topics_list li article dt .shorten {
    letter-spacing: -0.08em;
}

.entry .more_btn .submit,
.entry .more_btn a{
    display: inline-block;
    width: 305px;
    border-radius: 5px;
    padding: 20px;
    box-sizing: border-box;
    color: #fff;
    background: #f49315;
    text-align: center;
    position: relative;
    text-decoration: none;
    cursor : pointer;
}

.entry .more_btn .submit::after,
.entry .more_btn a::after {
    content: "";
    position: absolute;
    background: url("../img/common/btn_arrow03_o.png") no-repeat;
    background-size: contain;
    width: 25px;
    height: 25px;
    top: 50%;
    transform: translateY(-50%);
    right: 25px;
    transition: .2s;
}

.flow{
    display: flex;
    justify-content: space-between;
    text-align: center;
    margin-top: 25px;
    padding: 20px 0 40px;
    border-top: 1px #e5e5e5 solid;
    border-bottom: 1px #e5e5e5 solid;
}

.flow span{
    display: inline-block;
    font-size: 18px;
    vertical-align: 0.03em;
    color: #f49315;
    margin-bottom: 25px;
}

.flow_inner{
    position: relative;
}

.flow_inner::after{
    content: "";
    background: url("../img/common/big_arrow.png");
    background-size: contain;
    background-repeat: no-repeat;
    width: 43px;
    height: 100px;
    position: absolute;
    top: 0;
    left: 100px;
}

.flow_inner:first-child::after{
    left: 80px;
}

.flow_inner:nth-child(2)::after{
    left: 180px;
}

.flow_inner:last-child::after{
    display: none;
}

.entry .topics_list.birth li article dd select {
    width: 115px;
    color: #636161;
    font-size: 16px;
}

.birth .select::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 13px 8px 0 8px;
    border-color: #333333 transparent transparent transparent;
    left: 95px;
    top: 20px;
}

.entry .topics_list.gender li article dd {
    width: 100%;
    min-width: 716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}

.entry .topics_list.gender li article dd input {
    border: 1px solid #e2e2e2;
    height: 35px;
    display: inline-block;
    margin: 8px 10px;
    border-radius: 5px;
}

@media screen and (max-width:768px) {
    
.entry .top_bg_wrap{
	background: url("../img/entry/contact_top_sp.png") no-repeat;
	background-size: cover;
	padding-top: 33%;
}
    
.flow_inner img{
    width: auto;
}  
    
.flow_inner{
    width: 100px;
    margin-top: 20px;
}
    
.flow {
    width: 100%;
    margin: 0 auto;
    flex-wrap: wrap;
    align-items: flex-end;
}   
    
.flow span {
    font-size: 14px;
    margin-bottom: 10px;
}
    
 .flow_inner::after {
    content: "";
    background: url(../img/common/big_arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    width: 20px;
    height: 100px;
    position: absolute;
    top: 20px;
    left: 100px;
}     
    
 .flow_inner:first-child::after {
    left: 100px;
}   
 
.flow_inner:nth-child(2)::after {
    left: 90px;
}
 
.flow_inner:nth-child(3)::after {
    display: none;
}
   
.entry .topics_list.birth li article dd select {
    width: 80px;
    color: #636161;
    font-size: 14px;
    margin: 8px 10px 8px auto;
}
    
.entry .topics_list.birth li article dd .shorten {
    letter-spacing: -0.08em;
}
    
.birth .select::after {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 6px 0 6px;
    border-color: #333333 transparent transparent transparent;
    left: 60px;
    top: 22px;
}
    
.contact_table .more_btn,
.entry01 .contact_table .more_btn{
    margin: 30px auto 0px;
}
    
}

/*entry01-------------------------------------------------------------------*/

.entry01 .topics_list li article dd p:first-of-type {
    font-weight: normal;
    letter-spacing: 0.12em;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 8px;
}

.entry01 .topics_list li article dd {
    width: 100%;
    min-width: 716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 8px;
}

.entry01 .select::after {
    display: none;
}

/*.entry02-------------------------------------------------------------------*/
.entry02  h2 {
    margin-bottom: 45px;
}

.entry02 .txt{
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

.entry02 .more_btn{
    text-align: center;
    margin-bottom: 80px;
}

.entry02 .txt p{
    display: inline-block;
    margin-bottom: 40px;
}

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

.entry02  h2 {
    margin-bottom: 30px;
}

.entry02 .txt{
    width: 100%;
    margin: 0 auto;
    text-align: left;
}

.entry02 .txt p{
    display: inline-block;
    margin-bottom: 20px;
}

}

/*jobs-------------------------------------------------------------------*/

.jobs main{
	padding-bottom: 0;
}
.jobs .jobs01{
	position: relative;
}
.jobs .jobs01 .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.jobs main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}
.jobs .visula{
	padding-top: 78px;
}
.jobs .top_bg_wrap{
	background: url( "../img/recruit/jobs/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}
.jobs .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.jobs .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.jobs_wrap{
    margin-bottom: 70px;
}

.jobs_wrap.jobs05{
    margin-bottom: 0px;
}

.jobs_wrap .jobs_flex{
    position: relative;
    height: 480px;
    display: flex;
    /* border-bottom: 1px solid #e7e7e7; */
}

.jobs .jobs02 .jobs_img{
    background: url("../img/recruit/jobs/jobs01.png");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 399px;
    width:684px;
    position: absolute;
    right: 0;
    z-index: -1;
}

.jobs .jobs03 .jobs_img{
    background: url("../img/recruit/jobs/jobs02.png");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 399px;
    width:684px;
    position: absolute;
    left: 0;
    z-index: -1;
}

.jobs .jobs04 .jobs_img{
    background: url("../img/recruit/jobs/jobs03.png");
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 399px;
    width:684px;
    position: absolute;
    right: 0;
    z-index: -1;
}
.jobs .jobs_box{
    display: block;
    width: 918px;
    height: 231px;
    background: rgba(244,147,21,0.90);
    position: absolute;
    bottom: 0;
    color: #f4f5f7;
    padding: 40px 50px;
    box-sizing: border-box;
}

.jobs .jobs03{
    background:  rgba(241,189,47,0.10);
    padding: 65px 0;  
    position: relative;
    z-index: -10;
}

.jobs .jobs03 .jobs_box{
    margin-left: 80px;
}

.jobs .jobs_box h2{
    font-size: 28px;
}

.jobs .jobs_wrap h3{
    font-size: 22px;
    color: #f49315;
    padding-bottom: 16px;
    border-bottom: 1px solid #f49315;
}

.jobs .jobs_box p{
    line-height: 30px;
    letter-spacing: 0.03em;
    font-size: 16px;
}

.jobs_wrap.jobs05{
     background:  rgba(241,189,47,0.10);
    padding: 20px 0 95px;
}

.jobs_wrap.jobs05 .jobs_flex{
    position: static;
    height: auto;
    padding: 45px 0;
}

.jobs_wrap.jobs05 .jobs_text{
    margin-left: 30px;
}
.jobs_wrap.jobs05 .jobs_text p{
    font-size: 16px;
    line-height: 36px;
    vertical-align: 0.03em;
    margin-top: 20px;
}

.jobs_wrap .recruit_wrap{
	display:flex;
	justify-content:center;
	align-items:center;
	flex-wrap: wrap;
	margin-top:50px;
}
.jobs_wrap .recruit_wrap a{
	display:block;
	margin:0 2%;
}

.jobs_wrap.jobs05 .more_btn{
    margin-top: 20px;
    text-align: center;
}


@media screen and (max-width:768px) { 
    
.jobs .visula{
	padding-top: 0px;
}

.entry.jobs .top_bg_wrap {
    background: url( "../img/recruit/jobs/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}

.jobs_wrap .jobs_flex {
    height: auto;
    display: block;
}
    
.jobs_wrap.jobs05 .jobs_flex {
    padding: 45px 0 0;
}

.jobs_wrap.jobs05 .more_btn{
    margin-top: 10px;
}

.jobs main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}
    
.jobs .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.jobs .jobs_box h2 {
    font-size: 19px;
}
    
.jobs_wrap{
    margin-bottom: 0px;
}

      
 .jobs .jobs02 .jobs_img {
    background: url(../img/recruit/jobs/jobs01.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 0;
    padding-top: 58%;
    width: 100%;
    position: absolute;
    right: 0;
    z-index: -1;
}   
    
.jobs .jobs03 .jobs_img {
    background: url(../img/recruit/jobs/jobs02.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 0;
    padding-top: 58%;
    width: 100%;
    position: absolute;
    right: 0;
    z-index: -1;
}    
    
 .jobs .jobs04 .jobs_img {
    background: url(../img/recruit/jobs/jobs03.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    height: 0;
    padding-top: 58%;
    width: 100%;
    position: absolute;
    right: 0;
    z-index: -1;
}   
    
.jobs .jobs_box {
    display: block;
    width: calc(100% - 20px);
    margin: 145px auto 0;
    height: auto;
    background: rgba(244,147,21,0.90);
    position: static;
    color: #f4f5f7;
    padding: 40px 50px;
    box-sizing: border-box;
}    
    
.jobs .jobs03 .jobs_box {
    margin-left: auto;
} 
    
.jobs_wrap.jobs05 .jobs_text {
    margin: 20px auto 0;
}
    
.jobs .jobs_box p{
    line-height: 1.4;
    font-size: 14px;
}
    
.jobs_wrap.jobs05 .jobs_text p {
    font-size: 14px;
    line-height: 1.4;
}
    
.jobs .jobs_wrap h3 {
    font-size: 18px;
}
    
}

/*welfare-------------------------------------------------------------------*/

.welfare main{
	padding-bottom: 0;
}
.welfare .welfare01{
	/* position: relative; */
}

p.bg_parts01{
    margin: 0;
}

.welfare .welfare01 .bg_parts01 {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}
.welfare main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}
.welfare .visula{
	padding-top: 78px;
}
.welfare .top_bg_wrap{
	background: url( "../img/recruit/welfare/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}
.welfare .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.welfare .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.welfare h2 {
    font-size: 24px;
    font-weight: bold;
    position: relative;
    vertical-align: 0.03em;
    line-height: 48px;
    margin-top: 33px;
    margin-bottom: 20px;
    padding-left: 28px;
}

.welfare h2::before{
    content: "";
    background: url( "../img/common/h2_o.png");
    background-size: contain;
    background-repeat: no-repeat;
    width: 21px;
    height: 44px;
    position: absolute;
    left: 0;
}

.welfare .welfare02 p{
    font-size: 16px;
    line-height: 36px;
    vertical-align: 0.03em;
    margin-top: 20px;
}

.welfare .welfare_flex{
    display: flex;
    justify-content: space-between;
    margin-bottom: 70px;
}

.welfare .welfare_l,
.welfare .welfare_r{
    width: 48%;
}
.welfare .welfare_r img{
    width: 100%;
}
.welfare .welfare_r .credit{
	font-size: 0.875rem;
}
.welfare_link{
    margin-top: 45px;
}

.welfare_link a{
    display: block;
    width: 370px;
    padding: 17px 0 17px 60px;
    box-sizing: border-box;
    color:#f49315;
    border-bottom: 1px solid #f49315;
    position: relative;
}

.welfare_link a::before{
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 7px 0 7px 14px;
    border-color: transparent transparent transparent #f49315;
    position: absolute;
    left: 35px;
    top: 22px;
}

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

.welfare .top_bg_wrap {
    background: url("../img/recruit/welfare/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}

.welfare_wrap .jobs_flex {
    height: auto;
    display: block;
}
    
.welfare main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}   

.welfare .top_bg_wrap .catch h1 {
    font-size: 19px;
}
    
.welfare h2 {
    font-size: 18px;
}

.welfare .visula {
    padding-top: 0px;
}

.welfare .welfare_flex {
    display: block;
    margin-bottom: 70px;
}

.welfare .welfare_l, 
.welfare .welfare_r {
    width: 100%;
}

.welfare_link{
    margin-bottom: 25px;
}
    
.welfare_link a {
    display: block;
    width: 100%;
}

.welfare .welfare02 p {
   margin: 20px auto 20px;
    font-size: 14px;
    line-height: 1.4;
}

}

/*requirements-------------------------------------------------------------------*/

.requirements .requirements_head{
	position: relative;
}
.requirements .requirements_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.requirements .topics_list li article dd {
    width: 100%;
    min-width: 716px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 8px;
    padding: 15px 0;
    box-sizing: border-box;
    background: #fff;
}

.requirements .list_span.topics_list li article dd {
    display: block;
}

.requirements .list_span span{
    display: block;
}

.requirements .work_location span:last-child{
    font-size: 14px;
}

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

.requirements .topics_list li article dd {
    width: 100%;
    min-width: auto;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 0;
    padding: 15px 0;
    padding-left: 8px;
    min-height: 60px;
    height: auto;
}
    
.requirements .contact_table .more_btn {
    margin: 30px auto 30px;
}

}

/*senior------------------------------------------------------------------*/

.senior main{
	padding-bottom: 0;
}
.senior .senior_head{
	position: relative;
}

.senior .senior_head .bg_parts01 {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}
.senior main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}
.senior .visula{
	padding-top: 78px;
}
.senior .top_bg_wrap{
	background: url( "../img/recruit/senior/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}
.senior .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
.senior .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.senior .senior_inner{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.senior .senior_inner > a{
    display: block;
    margin-bottom: 60px;
}

.senior .senior_inner span{
   display: block;
}

.senior .senior_inner span:first-of-type{
   font-size: 18px;
   vertical-align: 0.1em;
   color: #f49315;
   margin-top: 15px;
}

.senior .senior_inner span:last-of-type{
   font-size: 14px;
   vertical-align: 0.03em;
   margin-top: 5px;
}
.senior .recruit_wrap{
	display:flex;
	justify-content:center;
	align-items:center;
	flex-wrap: wrap;
}
.senior .recruit_wrap a{
	display:block;
	margin:0 2%;
}
.senior .form_btn {
    display: flex;
    justify-content: center;
    margin: 20px auto 60px;
}

@media screen and (max-width:768px) { 
    
.senior .top_bg_wrap {
    background: url( "../img/recruit/senior/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
   
.senior .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}   

.senior .top_bg_wrap .catch h1 {
    font-size: 19px;
}

.senior .visula {
    padding-top: 0px;
}    

.senior main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px
}

.senior .senior_inner {
    display: flex;
    flex-wrap: wrap;
}
    
.senior .senior_inner > a {
    width: 47%;
}

.senior .form_btn {
    display: flex;
    justify-content: center;
    margin: 10px auto 30px;
}

}

/*senior_d------------------------------------------------------------------*/

.senior.people01 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people01/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people02 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people02/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people03 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people03/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people04 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people04/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people05 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people05/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people06 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/people06/h1.png") no-repeat;
    background-size: cover;
    padding-top: 15%;
}

.senior.people .top_bg_wrap .catch h1{
    text-align: left;
    width: 1000px;
    min-width: 1000px;
}

.senior .top_bg_wrap .catch h1 span {
    font-size: 22px;
    font-weight: normal;
    display: block;
}

.senior .people_wrap{
    position: relative;
}

.senior .people_wrap .bg_parts02 {
    position: absolute;
    bottom: 20%;
    left: 0;
    z-index: -1;
}

.senior .people_flex{
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
    flex-direction: row;
}

.senior .people_flex dl{
    margin-bottom: 50px;
}

.senior .people_flex dt{
    font-size: 22px;
    color: #f49315;
    line-height: 32px;
    vertical-align: 0.05em;
}

.senior .people_flex .people_flex_r{
    order: 1;
}


.senior .people_flex .people_flex_img{
    width: 43%;
}

.senior .people_flex .people_flex_text{
    width: 50%;
}

.senior .message{
    width: 747px;
    height: 483px;
    background: #f49315;
    margin: 0 auto;
    padding: 22px;
    box-sizing: border-box;
    color: #ffffff;
    vertical-align: 0.05em;
    line-height: 30px;
}

.senior .message .message_img{
   text-align: center;
}

.senior .message .message_text{
   margin-top: 30px;
}


.senior .people_btn{
    margin-top: 75px;
    padding: 60px 0 ;
    border-top: 1px solid #e7e7e7;
}

.senior .people_btn .people_flex span:first-of-type{
   font-size: 18px;
   font-weight: bold;
   vertical-align: 0.1em;
   color: #f49315;
   margin-top: 20px;
   display: block;
}

.senior .people_btn .people_flex span:last-of-type{
   font-size: 14px;
   vertical-align: 0.03em;
   margin-top: 5px;
  display: block;
}

.senior .more_btn{
    text-align: center;
    margin-bottom: 100px;
}

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

.senior.people01 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people01.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people02 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people02.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people03 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people03.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people04 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people04.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people05 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people05.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people06 .top_bg_wrap {
    background: url( "../img/recruit/senior/people/sp/people06.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
    
.senior.people .top_bg_wrap .catch {
    position: absolute;
    top: 50%;
    left: 25%;
    transform: translate(-50%,-50%);
}

.senior.people .top_bg_wrap .catch h1 {
    text-align: left;
    width: auto;
    min-width: 0px;
}

.senior .top_bg_wrap .catch h1 span {
    font-size: 16px;
}

.senior .people_flex {
    display: block;
    margin-bottom: 50px;
}

.senior .people_flex .people_flex_img,
.senior .people_flex .people_flex_text{
    width: 100%;
}

.senior .people_flex .people_flex_text{
    margin-top: 30px;
}
    
.senior .people_flex dt {
    font-size: 18px;
    margin-bottom: 15px;
}
    
.senior .people_flex dl {
    margin-bottom: 30px;
}

.senior .message {
    width: 100%;
    height: auto;
    background: #f49315;
    margin: 0 auto;
    padding: 10px 10px 30px;
    box-sizing: border-box;
    color: #ffffff;
    vertical-align: 0.05em;
    line-height: 30px;
}


.senior .people_btn {
    margin-top: 30px;
    padding: 30px 0;
    border-top: 1px solid #e7e7e7;
}

.senior .people_btn .people_flex {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 50px;
    justify-content: space-around;
}
    
.senior .people_btn .people_flex > div {
    width: 47%;
    margin-bottom: 20px;
}
    
.senior .people_btn .people_flex span:first-of-type {
    margin-top: 10px;
}

.senior .more_btn {
    text-align: center;
    margin-bottom: 50px;
}
}

/*security-------------------------------------------------------------------*/

.security .security_head{
	position: relative;
}
.security .security_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.security main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.security main{
	padding-bottom: 0;
}

.security .visula{
	padding-top: 78px;
}

.security .top_bg_wrap,
.privacy .top_bg_wrap{
	background: url( "../img/security/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.security .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.security .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}  

.security .security02 dl{
    margin: 55px auto 40px;
    font-size: 16px;
    line-height: 30px;
    vertical-align: 0.03em;
}

.security .security02 dt{
    margin-bottom: 15px;
}

.security .security02 dd{
    margin-bottom: 50px;
}

.security .message_name {
    text-align: right;
    margin-bottom: 66px;
}

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

.security main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}
    
.security .top_bg_wrap .catch {
    width: 100%;
}
    
.security .top_bg_wrap{
    background: url( "../img/security/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
.security .top_bg_wrap .catch h1{
    font-size: 19px;
}
    
.security .visula{
	padding-top: 0px;
}
    
.security .security02 dt {
   font-size: 14px;
}
    
.security .security02 dd{
   font-size: 14px;
    line-height: 1.4;
}

}

/*privacy-------------------------------------------------------------------*/

.privacy .privacy_head{
	position: relative;
}
.privacy .privacy_head .bg_parts01{
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}

.privacy main .sitewrap{
	width: 1000px;
	min-width: 1000px;
}

.privacy main{
	padding-bottom: 0;
}

.privacy .visula{
	padding-top: 78px;
}

.privacy .top_bg_wrap{
	background: url( "../img/security/h1.png") no-repeat;
	background-size: cover;
	padding-top: 15%;
	position: relative;
}

.privacy .top_bg_wrap .catch h1{
	font-size: 38px;
    font-weight: bold;
}

.privacy .top_bg_wrap .catch{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}  

.privacy .privacy02 dt{
    font-size: 24px;
    font-weight: bold;
    line-height: 48px;
    vertical-align: 0.03em;
    padding-left: 30px;
    margin-bottom: 20px;
    position: relative;
}

.privacy .privacy02 dt::before{
    content: "";
    background:url("../img/common/h2.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width:21px;
    height: 44px;
    position: absolute;
    left: 0;
}

.privacy .privacy02 dd{
    margin-bottom: 70px;
     font-size: 16px;
    line-height: 30px;
    vertical-align: 0.03em;
}



@media screen and (max-width:768px) { 
.privacy main .sitewrap {
    width: 100%;
    min-width: 0;
    padding: 0 10px;
}
    
.privacy .top_bg_wrap .catch {
    width: 100%;
}

.privacy .top_bg_wrap{
    background: url( "../img/security/h1_sp.png") no-repeat;
    background-size: cover;
    padding-top: 33%;
}
.privacy .top_bg_wrap .catch h1{
    font-size: 19px;
}
    
.privacy .visula{
	padding-top: 0px;
}
    
.privacy .privacy02 dt{
    font-size: 18px;
    line-height: 30px;
    padding-left: 30px;
    margin-bottom: 20px;
    position: relative;
}

.privacy .privacy02 dt::before{
    content: "";
    background:url("../img/common/h2.png");
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    width:21px;
    height: 30px;
    position: absolute;
    left: 0;
}

.privacy .privacy02 dd{
    margin-bottom: 30px;
    font-size: 14px;
    line-height: 1.4;
}

}

/* 20220128追加 */

.p_relative {
	z-index: 1;
	position: relative;
}

.news_list .company {
	background: #0099cc;
}

.news_list .csr {
	background: #f49315;
}

.news_list .service {
	background: #208815;
}

.news_list .recruit {
	background: #000080;
}

.news_list .other {
	background: #5c5c5c;
}

.pager_style li {
	margin: 2px;
}


.contact .more_btn div {
	width: 305px;
	display: inline-block;
	position: relative;
}

.contact .more_btn div input.submit~span::after {
	content: "";
	position: absolute;
	background: url(../img/common/btn_arrow.png) no-repeat;
	background-size: contain;
	width: 25px;
	height: 25px;
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	transition: .2s;
}

.contact .more_btn div input.reset~span::after {
	content: "";
	position: absolute;
	background: url(../img/common/btn_arrow02_w.png) no-repeat;
	background-size: contain;
	width: 25px;
	height: 25px;
	top: 50%;
	transform: translateY(-50%);
	right: 25px;
	transition: .2s;
}

.contact .more_btn div:hover input.submit~span::after,
.contact .more_btn div:hover input.reset~span::after {
	right: 15px;
}

.required {
	color: red;
	font-size: .8em;
	margin-left: .5em;
}

.entry .more_btn div input.submit~span::after {
	background: url(../img/common/btn_arrow03_o.png) no-repeat;
}

.entry .more_btn div input.reset~span::after {
	background: url(../img/common/btn_arrow02_o.png) no-repeat;
}

.entry .btn-primary, .entry .btn-primary:hover {
	border-color: #f49315;
}

select.form-control {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}