/*
Template:nishiki
Theme Name:open-tec
Theme URI: 
Author: nsl
Author URI: http://www.open-tec.co.jp/
*/
/**------------------**/
/*採用情報*/
/**------------------**/

/*ページのヘッダ*/
.page #main > header.otRecruit{
	margin-top: 10vh;
	/*background-position: top;*/
}

.page header.otRecruit::after{
	opacity: 0;
}

.open-tec #main > header .page-header.otRecruitHeader{
	padding: calc(3rem + 10vh) 0 3rem;
}

@media only screen and (min-width: 520px) {
	.open-tec #main > header .page-header.otRecruitHeader{
		padding: calc(8rem + 7vh) 0 8rem;
	}
	.page #main > header.otRecruit{
		margin-top: 7vh;
	}
}

@media only screen and (min-width: 960px) {	
	.open-tec #main > header .page-header.otRecruitHeader{
		padding: calc(14rem + 10vh) 0 14rem;
	}
	.page #main > header.otRecruit{
		margin-top: 10vh;
	}
}

.recruit {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 100%;
}
.r-category-box {
  position: relative;
  display: block;
  margin-bottom: 100px;
  width: 33%;
  height: 400px;
  overflow: hidden;
}
.r-category-box img {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100%;
  display: block;
  -webkit-transition: .4s ease-in-out;
  transition: .4s ease-in-out;
}
.r-category-box:hover img:nth-of-type(2) {
  opacity: 0;
}
@media only screen and (max-width: 769px) {
  .recruit {
    flex-wrap: wrap;
    text-align: center;
  }
  .r-category-box {
    width: 50%;
    min-height: 400px;
  }
}
@media only screen and (max-width: 480px) {
	.r-category-box {width: 100%;}
}

/**------------------**/
/*福利厚生*/
/**------------------**/

.benefitsContent{}

.single .entry-content table#bene-table, 
.page .entry-content table#bene-table{
	margin: 0 auto;
	width: 100%;
}

.entry-content #bene-table th {
  background: #eee;
}

.seidoList{
	list-style: none;
	padding-left: 0;
}

.shisetsuList{margin: 0;}
.shisetsuList dt{font-weight: bold;}
.shisetsuList dd{margin-left: 0;}

@media only screen and (min-width: 769px) {
	.entry-content #bene-table {
    display: table;
		margin: 0 auto;
  }
  .entry-content #bene-table th {
    width: 30%;
		text-align: center;
  }
	.entry-content #bene-table td {
		padding: 2rem;
	}
}

/**------------------**/
/*研修制度・資格取得制度*/
/**------------------**/
.case {
  text-align: center;
  margin-bottom: 50px;
}
.case1 {
  display: block;
  margin-bottom: 30px;
  text-align: center;
}
.case2 {
  display: block;
  text-align: center;
}
.Training {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

#TrainingReward{
	text-align: center;
}

#TrainingReward table{
	margin: 0 auto;
}
#TrainingReward th.title1, 
#TrainingReward th.title2, 
#TrainingReward th.title3 {
  background: #011a4b;
  color: white;
}
#TrainingReward th.title1 {
  width: 60%;
}
#TrainingReward th.title2, #TrainingReward th.title3 {
  width: 20%;
}

#TrainingReward td.sikaku1.Backgr, #TrainingReward td.sikaku2.Backgr, #TrainingReward td.sikaku3.Backgr {
  /*background: #a4a5a9;*/
	background: #f9f9f9;
}

@media only screen and (min-width: 769px) {
	#TrainingReward table{
		display: table;
		width:90%;
	}
}

@media only screen and (min-width: 1000px) {
	.open-tec .entry-content .otHeading3.traHeading{
		margin-top: 0;
	}
  .case1 {
    text-align: right;
    margin-top: -15px;
  }
  .case2 {
    text-align: right;
    margin-top: 70px;
  }
  p.tra-txt {
    text-align: center;
  }
  .guidance, .sin-tra, .teq-tra, .lea-tra {
    display: flex;
    width: 100%;
  }
  .guidance-img, .sin-tra-img, .teq-tra-img, .lea-tra-img {
    margin-bottom: 60px;
    margin-right: 50px;
  }
  .guidance-txt, .sin-tra-txt, .teq-tra-txt, .lea-tra-txt {
    margin-left: 20px;
    height: 324px;
    width: 50%;
  }
  .guidance p, .sin-trap, .teq-trap, .lea-trap {
    line-height: 1.6;
  }
  #TrainingReward th .title1 {
    width: 60%;
    color: white;
    background: #011a4b;
  }
  #TrainingReward th .title2 {
    width: 20%;
    color: white;
    background: #011a4b;
  }
  #TrainingReward th .title3 {
    width: 20%;
    color: white;
    background: #011a4b;
  }
  #TrainingReward {
    display: block;
    margin: 0 auto;
    text-align: center;
  }
  #TrainingReward td .sikaku1 {
    width: 60%;
  }
  #TrainingReward td .sikaku2 {
    width: 20%;
  }
  #TrainingReward td .sikaku3 {
    width: 20%;
  }
}
@media only screen and (max-width: 1000px) {
  .Training {
    max-width: 400px;
    justify-content: center;
    margin: 0 auto;
  }
  p.tra-txt {
    text-align: center;
  }
  section.sup {
    text-align: center;
  }
}
/**------------------**/
/*メッセージ*/
/**------------------**/

.page .entry-content .otHeadingMsg{
	font-size: 1.8rem;
	margin-bottom: 0;
}

.seni01, .seni02, .seni03, .seni04, .seni05, .seni06, .seni07, .seni08, .seni09 {
  display: flex;
  flex-wrap: wrap;
	padding: 3rem 0 1.5rem;
}

.entry-button {
  text-align: center;
}

.seni01-img, .seni02-img, .seni03-img, .seni04-img, .seni05-img, .seni06-img, .seni07-img, .seni08-img, .seni09-img {
  display: block;
  margin: 0 auto;
}
.entry-button a.otBtn {
  width: 250px;
  margin-top: 50px;
}

@media only screen and (min-width: 769px) {
  .entry-button {
    display: flex;
    margin: 0 auto;
    justify-content: center;
  }
  .grad, .care {
    margin: 10px;
  }
  .seni01, .seni02, .seni03, .seni04, .seni05, .seni06, .seni07, .seni08, .seni09 {
		border-bottom: 1px dotted #121212;
  }
  .seni01-img, .seni02-img, .seni03-img, .seni04-img, .seni05-img, .seni06-img, .seni07-img, .seni08-img, .seni09-img {
    margin-bottom: 60px;
    margin-right: 150px;
  }
  .seni01-txt, .seni02-txt, .seni03-txt, .seni04-txt, .seni05-txt, .seni06-txt, .seni07-txt, .seni08-txt, .seni09-txt {
    width: 50%;
  }
}


/**------------------**/
/*新卒採用情報・キャリア採用情報*/
/**------------------**/
.hutozi {
  text-align: center;
  font-size: 1.25rem;
  font-weight: bold;
}
/*キャリア採用ヘッダー装飾*/
.open-tec .entry-content .otHeading002 {
  position: relative;
  margin: 1.8rem 0;
  padding: 1rem 0;
  text-align: center;
  border: none;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 1.6rem;
}
.open-tec .entry-content .otHeading002::after {
  content: '';
  position: absolute;
  left: calc(50% - 30px);
  bottom: 0;
  width: 60px;
  height: 5px;
  background: #ab6732;
}
/*新卒採用バナー*/
.grad-banner {
  text-align: center;
  background-image: url("images/recruit_header.png");
	background-size: cover;
	background-position: center center;
  margin: 2rem 0;
}
.New-entry-contents {
  padding: 3rem 4rem 5rem 4rem;
}
.open-tec .entry-content .otBtn a.New-entry-contents {
  padding: 10% 40%;
}
p.New-entry-ttl {
	font-size: 1.3rem;
  font-weight: bold;
  color: #fff;
}
#currBtn {
  color: #fff;
  padding: 1rem 4rem;
  background: #b07b00;
  text-decoration: none;
  font-weight: bold;
}
#currBtn:hover {
  opacity: 0.6;
}
#newBtn {
  color: #fff;
  padding: 1rem 4rem;
  background: #023193;
  text-decoration: none;
  font-weight: bold;
}
#newBtn:hover {
  opacity: 0.6;
}

@media only screen and (min-width: 769px) {
	#currBtn {padding: 2% 15%;}
	#newBtn {padding: 2% 15%;}
}

.sel-box {
  text-align: center;
}
.proc01, .proc02, .proc03, .proc04, .proc05, .proc06, .proc07 {
  display: none;
}
.proc01-sp, .proc02-sp, .proc03-sp, .proc04-sp, .proc05-sp, .proc06-sp, .proc07-sp {
  margin-bottom: 20px;
}
.task-img, .curr-img, .comm-img {
  text-align: center;
}
.task-txt, .curr-txt, .comm-txt {
  margin-bottom: 50px;
  max-width: 350px;
  text-align: left;
  padding: 5px;
}
.et-background {
  display: none;
}
.tel-banner-pc, .entry-banner-pc {
  text-align: center;
  margin-top: 20px;
  padding-top: 20px;
  padding-bottom: 20px;
}
.recContact {
  margin-top: 60px;
  margin-bottom: 60px;
  background-image: url("images/back_img_80.png");
  background-size: cover;
	padding-top: 1.4rem;
	padding-bottom: 2rem;
}

.recContact_heading{
	text-align: center;
	color: #fff;
}

.recContact_bnrs{
	list-style: none;
	padding-left: 0;
}

.recContact_bnrs li{
	padding-bottom: 1.4rem;
}

@media only screen and (min-width: 768px) {
	.recContact_bnrs{
		display: flex;
		justify-content: space-between;
		width: 90%;
		margin: 0 auto;
	}
	.recContact_bnrs li{
		width: 45%;
	}
}
@media only screen and (min-width: 960px) {
	.recContact_bnrs{
		width: 80%;
	}
	.recContact_bnrs li{
		width: auto;
	}
}

.traning-details {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
table.grad-table {
  border-color: #3c3c3c;
  table-layout: fixed;
}
table.grad-table th {
  background: #eaeaf6;
  width: 15%;
}

@media only screen and (min-width: 768px) {
	.page .entry-content table.grad-table {
		display:table;
		width: 90%;
		margin: 0 auto;
	}
}

.contents_inner {
  width: 75%;
  margin: 12% auto;
}

.task, .curr, .comm {
  max-width: 350px;
  display: inline-block;
  margin: 1%;
}
@media only screen and (min-width: 765px) {
  .recruitment {
    margin-top: 5％;
  }
  .traning-details {
    display: flex;
    justify-content: center;
    margin: -60px;
  }
  .task-txt, .curr-txt, .comm-txt {
    margin-bottom: 50px;
    max-width: 350px;
    padding: 10px;
  }
  .sel-box {
    display: flex;
    justify-content: center;
  }
  .proc01, .proc02, .proc03, .proc04, .proc05, .proc06, .proc07 {
    display: block;
    margin-top: 40px;
    margin-bottom: 100px;
    margin-left: 15px;
    margin-right: 15px;
  }
  .proc01-sp, .proc02-sp, .proc03-sp, .proc04-sp, .proc05-sp, .proc06-sp, .proc07-sp {
    display: none;
  }
  .entry-gred {
    position: relative;
  }
  .tel-banner-pc {
    display: inline-block;
    position: absolute;
    left: 15%;
    top: 25%;
    padding-top: 0px;
  }
  .entry-banner-pc {
    display: inline-block;
    position: absolute;
    right: 15%;
    top: 25%;
    padding-top: 0px;
  }
  .et-background {
    display: inline-block;
  }
  .tel-banner-sp, .entry-banner-sp {
    display: none;
  }
  .Diagonal_Decoration::before {
    content: '';
    position: absolute;
    top: -153%;
    left: -107%;
    width: 250%;
    height: 230%;
    background: #8ec2f0;
    transform-origin: right center;
    transform: rotate(-10deg);
    z-index: -1;
  }
  .Diagonal_Decoration2::before {
    content: '';
    position: absolute;
    top: -187%;
    left: -42%;
    width: 200%;
    height: 309px;
    background: #3872b8;
    transform-origin: right center;
    transform: rotate(-10deg);
    z-index: -10;
  }
  .Diagonal_Decoration3::before {
    content: '';
    position: absolute;
    top: -153%;
    left: -107%;
    width: 250%;
    height: 230%;
    background: #f4e1b6;
    transform-origin: right center;
    transform: rotate(-10deg);
    z-index: -1;
  }
  .Diagonal_Decoration4::before {
    content: '';
    position: absolute;
    top: -187%;
    left: -42%;
    width: 200%;
    height: 309px;
    background: #996f04;
    transform-origin: right center;
    transform: rotate(-10deg);
    z-index: -10;
  }
}

/*新卒採用*/
.training__header {
  background: #f00;
}
.training__heading-wrap {
  position: relative;
  background: #3872b8;
  padding-bottom: 2rem;
}
.trainingDeco1 {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12rem 100vw 0 0;
  border-color: #fff transparent transparent transparent;
}
.training__heading2 {
  position: absolute;
  z-index: 10;
  bottom: 1rem;
  text-align: center;
  display: inline-block;
  width: 100%;
}
.trainingDeco2 {
  position: absolute;
  bottom: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 12rem 100vw;
  border-color: transparent transparent #c8d8eb transparent;
}
.training__txtArea {
  padding: 1rem 0;
  background: #c8d8eb;
}
.training__contentArea {
  background: #fff;
	position: relative;
}
.trainingDeco3 {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12rem 100vw 0 0;
  border-color: #c8d8eb transparent transparent transparent;
}

.training__content{
	margin-top: -12rem;
}

/*キャリア採用*/
.trainingCareer__header {
  background: #f00;
}
.trainingCareer__heading-wrap {
  position: relative;
  background: #996f04;
  padding-bottom: 2rem;
}
.trainingCareerDeco1 {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12rem 100vw 0 0;
  border-color: #fff transparent transparent transparent;
}
.trainingCareer__heading2 {
  position: absolute;
  z-index: 10;
  bottom: 1rem;
  text-align: center;
  display: inline-block;
  width: 100%;
}
.trainingCareerDeco2 {
  position: absolute;
  bottom: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 12rem 100vw;
  border-color: transparent transparent #e3d7b9 transparent;
}
.trainingCareer__txtArea {
  padding: 1rem 0;
  background: #e3d7b9;
}
.trainingCareer__contentArea {
  background: #fff;
	position: relative;
}
.trainingCareerDeco3 {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12rem 100vw 0 0;
  border-color: #e3d7b9 transparent transparent transparent;
}

.trainingCareer__content{
	margin-top: -12rem;
}

/**------------------**/
/*エントリーフォーム*/
/**------------------**/
section.entry-form {
  width: 100%;
  font-size: 0.9rem;
}
section.entry-form dl {
  display: block;
  margin: 3rem 0;
}
section.entry-form dt {
  width: 100%;
  font-size: 0.9rem;
  font-weight: bold;
  text-align: left;
}
section.entry-form dd {
  width: 100%;
  margin-left: 0;
}
dd.birth {
  display: flex;
}
dd.birth > span {
  margin: 0 0.5rem;
}
span.wpcf7-form-control-wrap {
  margin-left: 0;
}
select.wpcf7-form-control.wpcf7-select.wpcf7-validates-as-required {
  width: 100%;
}
span.required {
  border: 1px solid;
  padding: 0.01rem 0.1rem;
  margin-left: 1rem;
  color: #f00;
  font-size: 0.6rem;
}
span.wpcf7-list-item-label {
  font-weight: bold;
}
p.confirm-title {
  font-size: 0.9rem;
  font-weight: bold;
  text-align: left;
}
.privacy-policy_area {
  height: 200px;
  overflow-y: scroll;
}
input.wpcf7-form-control.wpcf7c-btn-confirm, input.wpcf7-form-control.wpcf7c-btn-confirm:hover, input.wpcf7-form-control.wpcf7c-btn-confirm:focus, input.wpcf7-form-control.wpcf7c-btn-confirm:active {
  font-weight: bold;
  background-color: #72a8e9;
  color: #FFF;
  border: 1px solid #72a8e9;
  border-radius: 0 10px 0 0;
  width: 50%;
  outline-style: none;
}
input.wpcf7-form-control.wpcf7c-btn-confirm:hover {
  opacity: 0.7;
}
@media only screen and (min-width: 769px) {
  section.entry-form {
    width: 80%;
  }
  section.entry-form dl {
    display: flex;
  }
  section.entry-form dt {
    width: 200px;
    text-align: right;
  }
  section.entry-form dd {
    margin-left: 40px;
  }
  section.entry-form dd.birth {
    display: flex;
  }
  span.wpcf7-form-control-wrap {
    margin-left: 14px;
  }
  span.required {
    padding: 0.1rem;
    margin-left: 1rem;
  }
  section.entry-form .confirm {
    margin-left: 215px;
  }
  p.confirm-title {
    text-align: center;
  }
}