@charset "utf-8";

/*adstaff*/

@media (min-width: 1107px) {
	.mainVisual .headLine01 :not(span.en) {
		/*text-shadow: 1px 1px 1px #fff;*/
	}
}
@media (max-width: 767px) {
	.mainVisual .headLine01 {
		/*text-shadow: 0px 1px 3px #fff;*/
	}
}

/*------------------------------------------------------------
	animation
------------------------------------------------------------*/

.comNavi li a:after {
	/*bottom:-30px;*/
  /*transition: bottom .1s linear;*/
}
.comNavi li a:hover:after {
  animation-name: iconMoveToBottom;
  animation-duration: .35s;
  animation-timing-function: easeInQuint;
  animation-iteration-count: 1;
  animation-delay: .0s;
  animation-fill-mode:forwards;
}

@keyframes iconMoveToBottom {
  0% {
    bottom:-30px;
  }
  35% {
  	bottom:-38px;
  }
  100% {
  	bottom:-30px;
  }
}

div.mainVisual .headLine01 {
	z-index: 3;
}
div.mainVisual .headLine01 .en {

}
div.mainVisual div.shadow {
	position: absolute;
	left: 0;
	top: 0;
	width: 71.2%;
	height: 100%;
	background-color: #E3E3E3;
	content: "";
}

#main  {
	z-index: 2;
}

@media (max-width:767px){
	div.mainVisual div.shadow {
    	height: 210px;
	}


}/*sp*/

/*/adstaff*/



/*------------------------------------------------------------
	index
	------------------------------------------------------------*/
	.mainVisual {
		/*padding-bottom: 60px;*/
	}
	.mainVisual .headLine01 {
		/*margin-bottom: -122px;*/
	}
	#pagePath {
		margin-bottom: 160px;
	}
	#main .staffBox {
		margin-bottom: 135px;
		padding-bottom: 190px;
		background: url("../img/common/line.png") repeat-x left bottom;
		background-size: 14px auto;
	}
	#main .staffBox:last-child {
		background: none;
	}
	#main .infoBox {
		margin-bottom: 95px;
		display: flex;
		justify-content: space-between;
	}
	#main .infoBox .photoList {
		margin-top: 98px;
		width: 72.5%;
		display: flex;
	}
	#main .infoBox .photoList li {
		margin-right: -11.5%;
		width: 77.9%;
		position: relative;
	}
	#main .infoBox .photoList li p {
		margin-top: 12px;
		font-weight: bold;
		letter-spacing: 1.6px;
	}
	#main .infoBox .photoList li .en {
		margin-top: 0;
		position: absolute;
		left: 7%;
		top: -80px;
		font-size: 14.5rem;
		line-height: 1;
		font-weight: normal;
		letter-spacing: 0;
	}
	#main .infoBox .photoList li:last-child {
		margin: 36.4% 0 0;
		width: 33.7%;
	}
	#main .infoBox h3 {
		width: 28%;
		color: #000;
	}
	#main .infoBox h3 > span {
		display: block;
		margin: 0 auto;
		width: 144px;
		height: 645px;
		line-height: 1.4;
		-webkit-writing-mode: tb-rl;
		-webkit-writing-mode: vertical-rl;
		writing-mode: tb-rl;
		writing-mode: vertical-rl;
		font-size: 4.8rem;
		letter-spacing: 4.8px;
		font-feature-settings: normal;
		-moz-font-feature-settings: normal;
	}
	#main .inner {
		margin: 0 auto;
		max-width: 1080px;
		padding: 0 40px;
	}
	#main .txtList {
		margin-bottom: 155px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#main .txtList li {
		width: 45%;
	}
	#main .txtList li:nth-child(2) {
		margin-top: 104px;
	}
	#main .txtList li p {
		margin-bottom: 95px;
		letter-spacing: 4.8px;
		line-height: 1.77;
		text-align: justify;
		text-justify: inter-ideograph;
	}
	#main .txtList li:nth-child(2) p {
		margin-bottom: 65px;
	}
	#main .txtList li p:last-child {
		margin-bottom: 0;
	}
	#main .txtList li .ttl {
		margin-bottom: 12px !important;
		font-size: 2.4rem;
		font-weight: bold;
		letter-spacing: 2.4px;
	}
	#main .staffBox .headLine02 {
		margin-bottom: 86px;
	}
	#main .staffBox .stepList {
		margin: -20px 0 60px;
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	#main .staffBox .stepList li {
		margin: 20px 96px 0 0;
		padding: 17px;
		position: relative;
		width: 296px;
		font-weight: 700;
		letter-spacing: 1.5px;
		text-align: center;
		box-sizing: border-box;
		border: 1px solid #D9D9D9;
	}
	#main .staffBox .stepList li::after {
		position: absolute;
		top: 19px;
		right: -84px;
		width: 61px;
		height: 18px;
		background: url("../img/interview/arrow.png") no-repeat right center / 61px;
		content: '';
	}
	#main .staffBox .stepList li:last-child {
		margin-right: 0;
	}
	#main .staffBox .stepList li:last-child::after {
		background: none;
	}
	#main .staffBox .stepList02 li {
		width: 378px;
	}
	#main .staffBox .text {
		margin-bottom: 101px;
		line-height: 2.03;
		letter-spacing: 4.8px;
		text-align: justify;
		text-justify: inter-ideograph;
		font-weight: 700;
	}
	#main .staffBox .headLine02.oneDay {
		margin-bottom: 129px;
	}
	#main .staffBox .timeList {
		margin: -59px 0 184px;
		display: flex;
		flex-wrap: wrap;
	}
	#main .staffBox .timeList li {
		margin-top: 59px;
		padding: 0 6px;
		width: 33.33%;
		text-align: center;
		box-sizing: border-box;
	}
	#main .staffBox .timeList li .photo {
		margin: 0 auto 43px;
		width: 80px;
	}
	#main .staffBox .timeList li .ttl {
		margin-bottom: 20px;
		font-size: 2.1rem;
		letter-spacing: 1.9px;
		font-weight: 700;
	}
	#main .staffBox .timeList li p {
		font-size: 1.4rem;
		letter-spacing: 4px;
		font-weight: 700;
	}
	#main .staffBox .imgBox {
		display: flex;
		flex-wrap: wrap;
	}
	#main .staffBox .imgBox .photoBox {
		width: 56.2%;
	}
	#main .staffBox .imgBox .textBox {
		padding: 40px 0 50px 52px;
		margin: 23% 0 0 -82px;
		position: relative;
		width: 49%;
		height: 100%;
		font-weight: 700;
		line-height: 2;
		letter-spacing: 4.3px;
		text-align: justify;
		text-justify: inter-ideograph;
		background-color: #fff;
		box-sizing: border-box;
	}
	#main .staffBox02 .infoBox h3 {
		width: 24.6%;
	}
	#main .staffBox02 .infoBox h3 span {
		height: 800px;
	}
	#main .staffBox02 .infoBox .photoList {
		margin-top: 188px;
		width: 75.4%;
	}
	#main .staffBox02 .infoBox .photoList li {
		width: 72.5%;
	}
	#main .staffBox02 .infoBox .photoList li:first-child {
		margin-right: -11.2%;
	}
	#main .staffBox02 .infoBox .photoList li p {
		margin-right: 24.5%;
		text-align: right;
	}
	#main .staffBox02 .infoBox .photoList li:last-child {
		margin-top: 140px;
		width: 41%;
	}
	#main .staffBox02 .infoBox .photoList li:last-child .en {
		margin-right: 0;
		left: auto;
		right: 9%;
	}
	#main .staffBox02 .text {
		margin-bottom: 155px;
	}
	#main .staffBox02 .headLine02.oneDay {
		margin-bottom: 105px;
	}
	#main .staffBox03 .infoBox {
		margin-bottom: 130px;
	}
	#main .staffBox03 .infoBox h3 {
		width: 33.5%;
	}
	#main .staffBox03 .infoBox h3 span {
		height: 750px;
	}
	#main .staffBox03 .infoBox .photoList {
		width: 66.5%;
	}
	#main .staffBox03 .infoBox .photoList li {
		width: 84.3%;
	}
	#main .staffBox03 .infoBox .photoList li:last-child {
		margin-top: 34%;
		width: 36.6%;
	}
	#main .staffBox03 .infoBox .photoList li:first-child {
		margin-right: -21%;
	}

	/*adstaff*/
	#pagePath {
		margin-bottom: 120px;
	}
/*============================
#requirements
============================*/
section#requirements.requirements {

	margin-bottom: 170px;
}
section#requirements.requirements>div.comBox {

}
section#requirements.requirements>div.comBox>h3.headLine02 {

}
section#requirements.requirements>div.comBox>h3.headLine02>span.en {

}
section#requirements.requirements>div.comBox>div.flexbox.data {
	margin-bottom: 40px;
	margin-top: 30px;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv:last-child {
	border-bottom: 1px solid #cccccc;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv {
	display: flex;
	border-top: 1px solid #cccccc;
	padding:28px 20px;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.thDiv {
	width: 14%;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.thDiv>h4 {
	font-size: 18px;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: 3px;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv {
	width: 86%;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv>p {
	font-size: 18px;
	line-height: 1.6;
	letter-spacing: 3px;
}

/*============================
#flow
============================*/
section#flow.flow {
}
section#flow.flow>div.comBox {

}
section#flow.flow>div.comBox>h3.headLine02 {

}
section#flow.flow>div.comBox>h3.headLine02>span.en {

}
section#flow.flow>div.comBox>div.trDiv {
	margin-top: 30px;
	margin-bottom: 40px;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv:last-child {
	border-bottom: 1px solid #cccccc;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv {

	border-top: 1px solid #cccccc;
	padding:28px 20px;
}
section#flow.flow>div.comBox p.note {
	font-size: 18px;
	line-height: 1.6;
	text-align: center;
	margin-bottom: 39px;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv>h4 {
	font-size: 18px;
	line-height: 1.6;
	font-weight: bold;
	text-align: center;
	letter-spacing: 3px;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv>h4 span.note {
	font-weight: normal;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv.delta {
	padding:10px 0;
}
section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv.delta>p.delta {
	font-size: 28px;
	text-align: center;
}

section#flow.flow div.entryBtn {
	/* width: 576px; */
	height: 120px;
	margin-top: 133px;
	margin-bottom: 210px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	gap: 0 60px;
	width: 80%;
}
section#flow.flow div.entryBtn>a:hover {
	background-color: #fff;
	border: 1px solid #0070c4;
}
section#flow.flow div.entryBtn>a:hover>p {
	color: #0070c4;
}
section#flow.flow div.entryBtn>a:hover>p>span.bar {
	background-color: #0070c4;
}
section#flow.flow div.entryBtn>a {
	/* width: 100%; */
	height: 100%;
	display: block;
	background: #0070c4;
	transition:.2s;
	border: 1px solid #0070c4;
	width: calc(50% - 30px);
}
section#flow.flow div.entryBtn>a>p {
	width: 100%;
	height: 100%;
	line-height: 120px;
	text-align: center;
	color: #fff;
	font-size: 24px;
	letter-spacing: 5px;
	position: relative;
}
section#flow.flow div.entryBtn>a>p>span.bar {
	position: absolute;
	width: 30px;
	height: 1px;
	top:59px;
	right:0;
	background-color: #fff;
}
section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv .pc_hide {
	display: none;
	width: 0;
	height: 0;
}



/*/adstaff*/
@media all and (-ms-high-contrast:none){
	#main .infoBox h3 > span {
		margin-left: 13%;
	}
	#main .staffBox .timeList li p {
		letter-spacing: 3px;
	}
}
@media all and (max-width: 1240px) {
	#main .staffBox .stepList01 li {
		margin-right: 6.5%;
		width: 29%;
	}
	#main .staffBox .stepList01 li:after {
		right: -18%;
		width: 2em;
		background-size: 2em auto;
	}
}
@media all and (min-width: 768px) {

}
@media all and (max-width: 767px) {
	.mainVisual {
		/*padding-bottom: 65px;*/
	}
	.mainVisual:before {
		/*height: 210px;*/
	}
	.mainVisual .headLine01 {
		/*margin-bottom: 16px;*/
	}
	#main .staffBox {
		margin-bottom: 160px;
		padding-bottom: 0;
		background: none;
	}
	#main .infoBox {
		margin: 0 -16px 40px;
		flex-wrap: wrap;
		position: relative;
	}
	#main .infoBox .photoList {
		margin-top: 0;
		width: 100%;
		flex-wrap: wrap;
		justify-content: flex-end;
	}
	#main .infoBox .photoList li {
		margin: 0;
		width: 100%;
	}
	#main .infoBox .photoList li p {
		margin-left: 16px;
		letter-spacing: 1.4px;
	}
	#main .infoBox .photoList li .en {
		left: 8px;
		top: -40px;
		font-size: 7.5rem;
	}
	#main .infoBox .photoList li:last-child {
		margin: -34% 24px 0 0;
		width: 44%;
	}
	#main .infoBox h3 {
		position: absolute;
		right: 40px;
		top: -78px;
		width: 72px;
		height: 355px;
		z-index: 1;
	}
	#main .infoBox h3 > span {
		margin: 0;
		width: auto;
		height: auto;
		font-size: 2.4rem;
		line-height: 1.5;
		letter-spacing: 2.4px;
	}
	#main .infoBox h3 span span {
		padding: 0 4px;
		background-color: #fff;
	}
	#main .inner {
		padding: 0 0;
	}
	#main .txtList {
		margin-bottom: 55px;
	}
	#main .txtList li {
		width: 100%;
	}
	#main .txtList li:nth-child(2) {
		margin-top: 30px;
	}
	#main .txtList li p {
		margin-bottom: 30px;
		letter-spacing: 2.5px;
		line-height: 1.5;
	}
	#main .txtList li:nth-child(2) p {
		margin-bottom: 20px;
	}
	#main .txtList li .ttl {
		margin-bottom: 4px !important;
		font-size: 2rem;
		letter-spacing: 2px;
	}
	#main .staffBox .headLine02 {
		margin-bottom: 38px;
	}
	#main .staffBox .stepList {
		margin: -75px 0 50px;
	}
	#main .staffBox .stepList li {
		margin: 75px 0 0;
		padding: 16px 10px;
		font-size: 1.5rem;
		width: 100% !important;
	}
	#main .staffBox .stepList li::after {
		margin-left: -8px;
		top: auto;
		bottom: -65px;
		right: auto;
		left: 50%;
		width: 16px;
		height: 55px;
		background-image: url("../img/interview/sp_arrow.png");
		background-size: 16px auto;
	}
	#main .staffBox .text {
		margin-bottom: 65px;
		line-height: 1.5;
		letter-spacing: 3px;
	}
	#main .staffBox .headLine02 {
		line-height: 1.2;
	}
	#main .staffBox .headLine02 .en {
		margin-bottom: 5px;
	}
	#main .staffBox .headLine02.oneDay {
		margin-bottom: 44px;
	}
	#main .staffBox .timeList {
		margin: -23px 0 65px;
		justify-content: space-between;
	}
	#main .staffBox .timeList li {
		margin-top: 23px;
		padding: 0 5px;
		width: 50%;
	}
	#main .staffBox .timeList li .photo {
		margin-bottom: 30px;
		width: 50px;
	}
	#main .staffBox .timeList li .ttl {
		margin: 0 -10px 15px;
		font-size: 1.4rem;
		letter-spacing: 0.7px;
	}
	#main .staffBox .timeList li p {
		font-size: 1.2rem;
		letter-spacing: 2.6px;
		line-height: 1.15;
	}
	#main .staffBox .imgBox {
		margin: 0 -16px;
	}
	#main .staffBox .imgBox .photoBox {
		width: 100%;
	}
	#main .staffBox .imgBox .textBox {
		padding: 25px 15px 0;
		margin: 0;
		width: 100%;
		height: auto;
		line-height: 1.5;
		letter-spacing: 3.2px;
	}
	#main .staffBox02 .infoBox h3 {
		width: 72px;
		right: 20px;
		height: 400px;
	}
	#main .staffBox02 .infoBox h3 span {
		height: auto;
	}
	#main .staffBox02 .infoBox .photoList {
		margin-top: 0;
		width: 100%;
	}
	#main .staffBox02 .infoBox .photoList li {
		width: 100%;
	}
	#main .staffBox02 .infoBox .photoList li:first-child {
		margin-right: 0;
	}
	#main .staffBox02 .infoBox .photoList li p {
		margin-right: 0;
		text-align: left;
	}
	#main .staffBox02 .infoBox .photoList li:last-child {
		margin: -40% 24px 0 0;
		width: 44%;
	}
	#main .staffBox02 .text {
		margin-bottom: 55px;
	}
	#main .staffBox02 .headLine02.oneDay {
		margin-bottom: 45px;
	}
	#main .staffBox03 .infoBox {
		margin-bottom: 40px;
	}
	#main .staffBox03 .infoBox h3 {
		width: 72px;
		height: 380px;
		right: auto;
		left: 24px;
		top: -90px;
	}
	#main .staffBox03 .infoBox h3 span {
		height: auto;
	}
	#main .staffBox03 .infoBox .photoList {
		width: 100%;
		justify-content: flex-start;
	}
	#main .staffBox03 .infoBox .photoList li {
		width: 100%;
	}
	#main .staffBox03 .infoBox .photoList li p {
		margin-left: 58%;
	}
	#main .staffBox03 .infoBox .photoList li .en {
		margin: 0;
		left: auto;
		right: 10px;
	}
	#main .staffBox03 .infoBox .photoList li:last-child {
		margin: -40% 0 0 20px;
		width: 44%;
	}
	#main .staffBox03 .infoBox .photoList li:first-child {
		margin-right: 0;
	}
	#main .staffBox03 {
		margin-bottom: 90px;
	}

	/*adstaff*/
	section#requirements.requirements>div.comBox>div.flexbox.data {
		margin-bottom: 40px;
		margin-top: 30px;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv:last-child {
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv {
		display: block;
		padding:28px 20px;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.thDiv {
		width: 100%;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.thDiv>h4 {
		font-size: 18px;
		letter-spacing: 3px;
		text-align: center;
		font-weight: bold;
		margin-bottom: 10px;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv span.pc_hide {
		display: block;
		width: 0;
		height: 0;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv span.sp_hide {
		display: block;
		width: 0;
		height: 0;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv {
		width: 100%;
	}
	section#requirements.requirements>div.comBox>div.flexbox.data>div.trDiv>div.tdDiv>p {
		font-size: 15px;
		line-height: 1.6;
		letter-spacing: 3px;
		font-weight: normal;
	}
	section#flow.flow>div.comBox p.note {
			font-size: 15px;
			line-height: 1.6;
			text-align: center;
			margin-bottom: 24px;
	}
	section#flow.flow>div.comBox>div.trDiv {
		margin-top: 30px;
		margin-bottom: 40px;
	}
	section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv:last-child {
	}
	section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv {
		padding:28px 20px;
	}
	section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv>h4 {
		font-size: 17px;
		line-height: 1.6;
		letter-spacing: 3px;
	}
	section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv.delta {
		padding:10px 0;
	}
	section#flow.flow>div.comBox>div.trDiv>div.allWidthDiv.delta>p.delta {
		font-size: 24px;
	}

	section#flow.flow div.entryBtn {
		width: 88%;
		height: 70px;
		margin-top: 100px;
		margin-bottom: 110px;
	}
	section#flow.flow div.entryBtn>a:hover {
	}
	section#flow.flow div.entryBtn>a:hover>p {
	}
	section#flow.flow div.entryBtn>a:hover>p>span.bar {
	}
	section#flow.flow div.entryBtn>a {
	}
	section#flow.flow div.entryBtn>a>p {
		line-height: 70px;
		font-size: 19px;
		letter-spacing: 5px;
	}
	section#flow.flow div.entryBtn>a>p>span.bar {
		width: 30px;
		height: 1px;
		top:35px;
	}
	/*/adstaff*/
	section#flow.flow div.entryBtn {
		flex-direction: column;
		gap: 30px 0;
		margin-top: 60px;
		margin-bottom: 200px;
	}
	section#flow.flow div.entryBtn a {
		width: 100%;
	}
}
@media all and (max-width: 374px) {

	#main .infoBox h3 > span {
		font-size: 2rem;
	}
	#main .infoBox .photoList li:last-child {
		margin-top: -27%;
	}
}
@media all and (max-width: 359px) {

	#main .staffBox .stepList li {
		font-size: 1.4rem;
	}
}