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

.main-img {
	color: #fff;
	background: #222834;
}

.main-img .bg-img {
	background: url( ../img/entry/2x/main-img.png ) center center / cover no-repeat;
}

.single .main-img .bg-img {
	background: #eee;
}

.single .main-img .bg-img::before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: -webkit-linear-gradient( 30deg, rgba( 255, 255, 255, .9 ), rgba( 255, 255, 255, .7 ) 20%, transparent 60%, transparent );
	background: -moz-linear-gradient( 30deg, rgba( 255, 255, 255, .9 ), rgba( 255, 255, 255, .7 ) 20%, transparent 60%, transparent );
	background: linear-gradient( 60deg, rgba( 255, 255, 255, .9 ), rgba( 255, 255, 255, .7 ) 20%, transparent 60%, transparent );
	z-index: 1;
}

.main-img > .flex {
	padding-top: 10px;
}

.main-img .box {
	text-align: center;
}

.ttl-04 h1 {
	letter-spacing: 28px;
	margin-left: 15px;
}

.ttl-04 .en {
	letter-spacing: 16px;
}

.job-box {
	position: relative;
	margin-top: 1rem;
	padding: 6rem 0;
}

.job-box .en-bg {
	position: absolute;
	top: 0;
	right: 0;
	left: 10px;
	font-size: 18rem;
	text-align: center;
	line-height: 1;
	letter-spacing: 1.4px;
	white-space: nowrap;
	color: #f5f5f5;
	z-index: -1;
}

.block-list .block-03 {
	display: block;
	margin: 0 0 14rem;
	padding-bottom: 4rem;
}

.archive .block-list .block-03 {
	margin: 0 0 10rem;
}

.archive .block-03 .wrap .txt {
	justify-content: flex-start;
}

.archive .block-list .block-03 .img + .wrap .txt {
	padding-top: 8px;
}

.block-03 .img,
.block-03 .img div {
	transition: all .2s !important;
}

.block-list .block-03 .img + .wrap .txt {
	position: relative;
	padding: 0 0 2.8rem;
	margin-left: calc( 50% + 100px );
}

.block-list .block-03.img-right .img + .wrap .txt {
	margin: 0;
	margin-right: calc( 50% + 100px );
}

.archive .block-list .block-03 .txt::after {
	content: '';
	background: #f5f5f5;
	position: absolute;
	top: 40px;
	bottom: -40px;
	left: -150px;
	right: -150px;
	z-index: -1;
	transition: all .2s;
}

.archive .block-list .block-03 .img + .wrap .txt::after {
	left: -250px;
}

.archive .block-list .block-03.img-right .img + .wrap .txt::after {
	left: -150px;
	right: -250px;
}

.block-list .block-03 .mov-ttl .en {
	letter-spacing: 4px;
}

.block-list .block-03 h3 {
	letter-spacing: 1.8px;
}

.job-box .job-list {
	margin-top: 2rem;
}

.job-box .job-list li {
	width: calc( ( 100% - 20px ) / 2 );
	margin-bottom: 20px;
}

.job-box .job-list li:nth-child( odd ) {
	margin-right: 20px;
}

.job-box .job-list li a {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	line-height: 1.5;
	padding: 18px 10px;
	font-weight: 500;
	color: #fff;
	background: url( ../img/entry/2x/job-bg.png ) center center / cover no-repeat;
}

.job-box .job-list li a::before {
	content: '';
	position: absolute;
	top: 0;
	right: 100%;
	bottom: 0;
	left: 0;
	background: #13a158;
	transition: all .2s;
}

.job-box .job-list li.view a {
	box-shadow: 0 0 10px rgba( 0, 0, 0, .1 );
}

.job-box .job-list li a span {
	position: relative;
	z-index: 99;
}

.archive footer .bottom-wrap {
	padding-top: 10rem;	
}

/* single */

.single {
	background: #fff;
}

.single .main-img {
	color: #222834;
}

.single .main-img > .flex {
	justify-content: flex-start;
	padding-top: 5px;
}

.single .main-img .box {
	text-align: left;
}

.single .mov-ttl .attr .mov-txt-wrap::after {
	top: 0;
	bottom: 15px;
}

.single .ttl-05 .info .tab {
	background: #13a158;
	color: #fff;
}

.single .main-img .job {
	margin-top: 18px;
}

.single .main-img .job .ttl {
	font-size: 2.4rem;
	font-weight: 300;
	line-height: 1.2;
	letter-spacing: 2.2px;
}

.single .main-img .job .en {
	font-size: 12rem;
	letter-spacing: 5px;
	text-indent: -3px;
	margin-top: 1px;
}

.single .info-box {
	margin-top: 1rem;
	padding-bottom: 10rem;
}

.single .block-list {
	margin: 9.5rem 0 0;
}

.single .block-list .block-03 {
	margin: 0 0 6rem;
}

.single .block-list .block-03 .img + .wrap .txt {
	padding: 5px 0 0;
}

.single .block-04 .box {
	margin: 14rem 0 5rem;
}

.desc-box {
	padding-bottom: 3rem;
}

.desc-box .desc-ttl {
	text-align: center;
	background: url( ../img/entry/2x/desc-ttl-bg.png ) center center / cover no-repeat;
	color: #fff;
	line-height: 1.5;
	padding: 128px 0 130px;
	margin-bottom: 85px;
}

.desc-box .desc-ttl .en {
	font-size: 7.2rem;
	letter-spacing: 3px;
	margin-left: 4px;
}

.desc-box .desc-ttl .jp {
	font-size: 2.4rem;
	letter-spacing: 5px;
	font-weight: 500;
}

.desc-box .info {
	margin-bottom: 4rem;
}

.desc-box .info .flex .txt {
	width: 50%;
	padding-right: 50px;
}

.desc-box .info .txt h3 {
	font-size: 3.6rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 2px;
	margin-bottom: 30px;
}

.desc-box .info .txt .read {
	line-height: 2.4;
	letter-spacing: 1.4px;
}

.desc-box .info .flex .check {
	width: 50%;
}

.desc-box .skill {
	margin: 4.5rem 0;
}

.desc-box .skill .ttl-01 {
	margin-bottom: -5.5rem;
	position: relative;
	z-index: 99;
}

.desc-box .skill .box {
	background: #f5f5f5;
	padding: 9.5rem 4rem 4rem;
}

.desc-box .skill .box .cont {
	position: relative;
	background: #fff;
	text-align: center;
	padding: 5rem 1rem 4rem;
}

.desc-box .skill .box .flex .cont {
	width: calc( ( 100% - 40px ) / 2 );
}

.desc-box .skill .box .flex .cont:nth-child( odd ) {
	margin-right: 40px;
}

.desc-box .skill .box .cont::before {
	content: '';
	width: 1px;
	height: 60px;
	background: #13a158;
	position: absolute;
	top: -30px;
	left: 50%;
}

.desc-box .skill h3 {
	font-size: 2rem;
	font-weight: 500;
	color: #13a158;
	letter-spacing: 10px;
	margin-bottom: 25px;
	margin-left: 5px;
}

.guideline-box {
	margin-top: 8rem;
	padding-bottom: 4rem;
}

.guideline-box .dl-02 {
	margin: 6rem 0;
}

.guideline-box .dl-02 .note {
	font-size: 1.4rem;
	color: #666;
}

.guideline-box .dl-02 .flex {
	align-items: center;
}

.guideline-box .dl-02 .btn-01 {
	margin-left: 8.5rem;
	margin-bottom: 1rem;

}

.guideline-box .dl-02 .btn-01 a {
	letter-spacing: 1.4px;
}

.guideline-box .dl-02 .flex > div {
	margin-right: 2rem;
}

.guideline-box .dl-02 .list-01 li {
	margin-bottom: 0;
	letter-spacing: 1.8px;
}

.guideline-box h3 {
	font-weight: 500;
	margin-top: 1.5rem;
}

.guideline-box .flex strong {
	margin-right: 1rem;
	font-weight: 500;
}

#fix-bnr-line {
	position: fixed;
	right: 0;
	bottom: 20px;
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transform: translateY( 40px );
	transition: all .2s;
}

#fix-bnr-line.active {
	opacity: 1;
	visibility: visible;
	z-index: 9999;
	transform: none;
}

#fix-bnr-line.active.hide {
	opacity: 0;
	visibility: hidden;
	z-index: -1;
	transform: translateY( 40px );
}

#fix-bnr-line a {
	display: block;
	width: 280px;
	text-align: center;
	background: #17bb05;
	color: #fff;
	padding: 16px 16px 16px 8px;
	position: relative;
}

#fix-bnr-line a::after {
	content: '';
	position: absolute;
	top: 0;
	right: 100%;
	bottom: 0;
	left: 0;
	background: #13a158;
	transition: all .2s;
}

#fix-bnr-line a .txt {
	position: absolute;
	top: -4rem;
	right: 0;
	left: 0;
	z-index: 99;
}

#fix-bnr-line a .btn {
	position: relative;
	z-index: 99;
}

#fix-bnr-line a .btn span {
	display: inline-block;
	font-size: 2rem;
	font-weight: 500;
	padding: 5px 0 5px 50px;
	background: url( ../img/entry/2x/bnr-line-icon.png ) left center / 43px no-repeat;
}

.flow-box {
	padding-bottom: 9rem;
	margin-top: 1rem;
}

.flow-box .box-list {
	margin-top: 4rem;
	margin-bottom: 0;
}

.flow-box .box-list .slick-list {
	padding-top: 1rem !important;
}

.flow-box .box-list figure img {
	width: 180px;
	height: 180px;
	border-radius: 50%;
}

.form-box .bnr-single {
	margin: 4.5rem 0 6rem;

}

.form-box .notice .ttl {
	width: 170px;
}

.form-box .notice {
	margin: 4rem 0 3.5rem;
	justify-content: center;
}

.form-box .notice .ttl h3 {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: calc( 100% - 28px );
	margin-top: 4px;
	border: solid 2px #13a158;
	font-weight: 500;
	color: #13a158;
	letter-spacing: 1px;
}

.form-box .notice .txt {
	max-width: calc( 100% - 200px );
	padding-left: 4rem;
	transform: translateY( -10px );
}

.form-box .notice .txt li {
	letter-spacing: 1px;
	margin-bottom: 8px;
}

.form-box .form-wrap {
	background: #f5f5f5;
	padding: 6rem 0 15rem;
	margin-bottom: -4rem;
}

.form-box .form-wrap .wrap {
	max-width: 1010px;
}

.form-box .form-wrap .box {
	background: #fff;
	padding: 50px 50px 20px;
}

/* form-step */

.form-step {
	width: 100%;
	margin-bottom: 8px;
}

.form-step > p {
	width: calc( ( 99.999999% - 18px ) / 3 );
	height: 60px;
	line-height: 60px;
	padding: 0 20px !important;
	background: #fff url( ../img/entry/2x/step-bg-02.png ) right center / auto 60px no-repeat;
	color: #13a158;
	border-top: none !important;
	border-right: none !important;
	border-bottom: none !important;
	border-left: solid 2px #13a158;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: .8px;
	text-align: center;
	white-space: nowrap;
	margin-right: 9px;
	position: relative;
	overflow: hidden;
}

.form-step > p .en {
	font-weight: 300;
	margin-right: 5px;
}

.form-step > p:last-child {
	margin-right: 0;
}

#mailformpro .step {
	background: #fff url( ../img/entry/2x/step-bg-02.png ) right center / auto 60px no-repeat;
}

.mw_wp_form_input .step-01,
.mw_wp_form_confirm .step-02 {
	background: #fff url( ../img/entry/2x/step-bg-01.png ) right center / auto 60px no-repeat;
	color: #fff;
}

.form-step .step-03 {
	background: #fff url( ../img/entry/2x/step-bg-03.png ) right center / auto 60px no-repeat;
}

/* form */

#contact2 .form-wrap .mw_wp_form form > dl {
	-js-display: flex;
	display: -ms-flex;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3.5rem;
}

#contact2 .form-wrap .mw_wp_form_input form dl dt {
	width: 260px;
	padding: 42px 90px 0 0;
	border: none;
	text-align: left;
	letter-spacing: .4px;
	background: transparent;
	position: relative;
}

#contact2 .form-wrap .req-label {
	display: inline-block;
	background: #13a158;
	color: #fff;
	font-size: 1.4rem;
	line-height: 1.7;
	padding: .5px 11px;
	margin-right: .5rem;
	border-radius: 3px;
}

#contact2 .form-wrap dl .req-label {
	position: absolute;
	top: 48px;
	right: 30px;
}

#contact2 .form-wrap .mw_wp_form_input form dl dd {
	width: calc( 100% - 260px );
	max-width: initial;
	flex: auto;
	padding: 32px 39px 32px 0;
	border: none;
	font-size: 1.6rem;
	position: relative;
}

#contact2 .form-wrap .mw_wp_form_input form dl dd::before {
	content: '';
	border-bottom: dotted 1px #ccc;
	position: absolute;
	right: 0;
	bottom: 0;
	left: -260px;
}

#contact2 .form-wrap .mw_wp_form_input form dl dd .inline {
	padding: 6px 0;
}

#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday {
	margin: 10px 0 15px;
}

#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday span {
	display: inline-block;
	margin: 0 16px 0 2px;
	transform: translateY( 2px );
}

.submit-box {
	text-align: center;
}

.submit-box .agree {
	text-align: center;
	margin: 30px 0 35px;
}

.submit-box .agree .req-label {
	margin-right: 1rem;
	transform: translateY( -1px );
}

.form-box .agree label {
	margin: 0 !important;
	font-size: 1.6rem;
	letter-spacing: .6px;
}

.form-box .agree label .req-label {
	margin-right: .5rem;
}

.form-box .agree .pp-mark {
	display: inline-block;
	vertical-align: middle;
	margin-left: 15px;
	line-height: .5;
}

.form-box .agree .pp-mark a {
	display: inline-block;
	width: 70px;
	border: none !important;
}

.form-box .agree .mwform-checkbox-field {
	width: 33px;
	height: 33px;
	color: transparent;
	overflow: hidden;
	display: inline-block;
	vertical-align: middle;
	transform: translateY( -5px );
}

.form-box .agree label a {
	border: none;
	margin-right: 2px;
	padding: 0 1.7rem 0 0;
	background: url( ../img/common/icon-link-gr.png ) right center / 17px no-repeat;
}

.form-box .agree label a span {
	color: #13a158;
	border-bottom: solid 1px #13a158;
	padding: 3px;
}

.form-box form label {
	margin: 0;
}

.form-box form a {
	padding: 5px 0;
	border-bottom: solid 1px #333;
}

#contact2 .form-wrap .tf-error {
	margin-top: 0;
	line-height: 3;
	white-space: nowrap;
}

#contact2 .form-wrap .mw_wp_form .horizontal-item + .horizontal-item {
	margin-left: 35px;
}

#contact2 .form-wrap .mwform-radio-field-text {
	display: inline-block;
	padding: 4px 0 4px 34px;
	margin: 12px 0;
	font-weight: 300 !important;
	line-height: 1.6;
	cursor: pointer;
	position: relative;
}

#contact2 .form-wrap .mwform-radio-field-text::before,
#contact2 .form-wrap .mwform-checkbox-field-text::before {
	content: '';
	display: inline-block;
	width: 22px;
	height: 22px;
	border: solid 2px #ccc;
	position: absolute;
	top: 4px;
	left: 0;
}

#contact2 .form-wrap .mwform-radio-field-text::before {
	border-radius: 50%;
}

#contact2 .form-wrap .mwform-checkbox-field-text::before {
	border-radius: 5px;
}

#contact2 .form-wrap .mwform-radio-field-text::after {
	content: '';
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: #13a158;
	position: absolute;
	top: 11px;
	left: 7px;
	opacity: 0;
	transition: all .2s;
}

#contact2 .form-wrap .mwform-checkbox-field-text::after {
	content: '';
	width: 6px;
	height: 12px;
	border-right: solid 3px #13a158;
	border-bottom: solid 3px #13a158;
	position: absolute;
	left: 8px;
	top: 7px;
	opacity: 0;
	transform: rotate( 45deg );
	transition: all .2s;
}

.mw_wp_form input[type="file"] {
	margin: 15px 0;
}

#contact2 .tf-input-error {
	border: none !important;
}

/*
.mw_wp_form input[type="file"] {
	opacity: 0;
	position: absolute;
	z-index: -1;
}

.form-box form label.file-btn {
	display: inline-block;
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: 1px;
	color: #222834;
	padding: 8px 20px;
	margin: 7.5px 0;
	border: solid 2px #d1d1d1;
	background: #f8f8f8;
	border-radius: 4px;
}
*/

#contact2 .form-wrap button[type="submit"] {
	display: inline-block;
	width: 250px;
	background: url( ../img/common/2x/btn-bg-01.png ) center center / cover no-repeat;
	color: #fff;
	border: none;
	box-shadow: 0 0 10px rgba( 0, 0, 0, .1 ) !important;
	padding: 18px 10px;
	margin: 0 0 4rem;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	text-align: center;
	letter-spacing: 2.4px;
	position: relative;
}

#contact2 .form-wrap button[type="submit"]::after {
	content: '';
	display: inline-block;
	width: 31px;
	height: 8px;
	background: url( ../img/common/2x/arrow-01.png ) center center / contain no-repeat;
	position: absolute;
	top: calc( 50% - 4px );
	right: 20px;
	z-index: 99;
	transition: all .2s;
}

#contact2 .form-wrap button[type="submit"].disabled {
	background: #999;
	box-shadow: none !important;
}

#contact2 .form-wrap button[type="submit"].disabled::after {
	display: none;
}

#contact2 .form-wrap .tf-marker {
	right: 0;
	top: 50%;
	transform: translateY( -50% );
}

#contact2 .form-wrap .tf-require-counter {
	border: solid 1px #13a158;
	bottom: 20px;
}

#contact2 .form-wrap .tf-require-counter__num {
	background: #13a158;
}

#contact2 .form-wrap .back-btn {
	display: none;
}

/* confirm */

#confirm {
	background: #f5f5f5;
}

#confirm #contact2 .form-wrap h3.ttl {
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 1.2px;
	text-align: center;
	margin-bottom: 3rem;
}

#confirm #contact2 .form-wrap .back-btn {
	display: inline-block;
	width: 250px;
	color: #333;
	background: #f8f8f8;
	border: solid 2px #d1d1d1;
	padding: 16px 10px;
	margin-right: 20px;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 1.6rem;
	font-weight: 300;
	text-align: center;
	letter-spacing: 2.4px;
	position: relative;
	cursor: pointer;
	transition: all .2s;
}

#confirm .form-box .form-wrap {
	padding: 2rem 0 10rem;
}

#confirm footer .bottom-wrap,
#thanks footer .bottom-wrap {
	padding: 10rem 0;
}

#contact2 .form-wrap .mw_wp_form_confirm form > dl {
	border: none;
	border-top: solid 1px #dbdbdb;
}

#contact2 .form-wrap .mw_wp_form_confirm form dl dt {
	width: 260px;
	padding: 30px;
	border: none;
	text-align: left;
	font-weight: 300;
	letter-spacing: .4px;
	background: #f4f9e8;
	border-bottom: solid 1px #dbdbdb;
	position: relative;
}

#contact2 .form-wrap .mw_wp_form_confirm form dl dd {
	width: calc( 100% - 260px );
	max-width: initial;
	flex: auto;
	padding: 30px;
	border: none;
	font-size: 1.6rem;
	font-weight: 300;
	border-bottom: solid 1px #dbdbdb;
	position: relative;
}

#confirm .form-box form label.file-btn {
	display: none;
}


/*
----------------------------------------
1400
----------------------------------------
*/

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

	.block-03 .img {
		right: 50%;
	}

	.block-03.img-right .img {
		left: 50%;
	}

	.block-list .block-03 .img + .wrap .txt {
		margin-left: calc( 50% + 20px );
	}

	.block-list .block-03.img-right .img + .wrap .txt {
		margin-right: calc( 50% + 20px );
	}

	.job-box .job-list li a {
		padding: 15px 10px;
	}

	.desc-box .info .flex .txt {
		padding-right: 30px;
	}

}


/*
----------------------------------------
1200
----------------------------------------
*/

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

	.single .main-img .job .ttl {
		font-size: 2.2rem;
	}

	.single .main-img .job .en {
		font-size: 11rem;
	}

	.info-box .ttl-03 {
		padding-top: 6rem;
	}

	.info-box .ttl-03 .bg-txt {
		font-size: 15rem;
	}

	.block-list .block-03 {
		margin: 0 0 10rem;
	}

	.single .info-box {
		padding-bottom: 6rem;
	}

}


/*
----------------------------------------
1000
----------------------------------------
*/

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

	.single .block-04 .box {
		margin: 8rem 0 4rem;
	}

	.job-box .en-bg {
		font-size: 12rem;
		top: 30px;
	}

	.job-box .job-list li {
		width: calc( ( 100% - 10px ) / 2 );
		margin-bottom: 10px;
	}

	.job-box .job-list li:nth-child( odd ) {
		margin-right: 10px;
	}

	.job-box .job-list li a {
		font-size: 1.4rem;
	}

	.desc-box .info .txt h3 {
		font-size: 2.4rem;
		margin-bottom: 20px;
	}

	.guideline-box .dl-02 .flex > div {
		margin-right: 0;
	}

	.guideline-box .dl-02 .btn-01 {
		margin-left: 10%;
	}

	.guideline-box .dl-02 .btn-01 a {
		width: 220px;
		letter-spacing: 1px;
	}

	.flow-box .box-list figure img {
		width: 140px;
		height: 140px;
	}

	.form-box .form-wrap .box {
		padding: 30px 20px 20px;
	}

}


/*
----------------------------------------
768
----------------------------------------
*/

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

	.main-img > .flex {
		padding: 22px 5px 5px;
	}

	.single .main-img .bg-img img {
		object-position: 40% center;
	}

	.ttl-04 h1 {
		letter-spacing: 14px;
	}

	.ttl-04 .en {
		letter-spacing: 8px;
	}

	.single .block-04 .box {
		margin: 0;
	}

	.job-box {
		padding: 3rem 0;
	}

	.job-box .en-bg {
		font-size: 9rem;
		top: 0;
		left: 20px;
	}

	.job-box .job-list {
		margin-top: 2.2rem;
	}

	.archive .block-list .block-03 {
		padding: 8px 0 10px;
		margin-bottom: 5rem;
		position: relative;
	}

	.block-03 .img {
		padding: 0 20px;
		margin-bottom: 15px;
		height: auto;
	}

	.block-03.img-right .img {
		left: 0;
	}

	.archive .block-03 .img img,
	.archive .block-03.img-right .img img {
		height: 50.67vw;
	}

	.block-list .block-03 .img + .wrap .txt {
		position: static;
	}

	.block-list .block-03.img-right .img + .wrap .txt,
	.block-list .block-03 .img + .wrap .txt {
		margin: 0;
	}

	.archive .block-list .block-03 .txt::after,
	.archive .block-list .block-03.img-right .img + .wrap .txt::after {
		top: 25px;
		right: -20px;
		bottom: -20px;
		left: 0;
	}

	.block-list .block-03 h3 {
		top: 0;
	}

	.archive .block-list .block-03 .mov-ttl .en {
		font-size: 1.6rem;
		letter-spacing: 3px;
	}

	.archive .block-list .block-03 h3 {
		font-size: 2.4rem;
		letter-spacing: 1px;
		padding: 0;
	}

	.job-box .job-list li a {
		font-size: 1.6rem;
		font-weight: 300;
		padding: 12px 8px;
	}

	.archive footer .bottom-wrap {
		padding-top: 4rem;	
	}

	/* single */

	.single .main-img > .flex {
		padding: 20px;
	}

	.single .main-img .job {
		margin-top: 5px;
	}

	.single .mov-ttl .attr .mov-txt-wrap::after {
		bottom: 8px;
	}

	.single .ttl-05 .info .tab {
		font-weight: 300;
	}

	.single .main-img .job .ttl {
		font-size: 1.6rem;
		line-height: 1.5;
	}

	.single .main-img .job .en {
		font-size: 5rem;
		letter-spacing: 1.2px;
		line-height: 1;
		margin-left: 6px;
	}

	.info-box .ttl-03 {
		padding-top: .5rem;
	}

	.info-box .ttl-03 .bg-txt {
		font-size: 6rem;
	}

	.single .block-list {
		padding: 5rem 0 1rem;
		margin: 0;
	}

	.single .block-list .block-03 {
		padding-bottom: 0;
		margin-bottom: 4rem;
	}

	.single .info-box {
		margin-top: 2rem;
		padding-bottom: 4rem;
	}

	.desc-box .desc-ttl {
		padding: 50px 0 55px;
		margin-bottom: 30px;
	}

	.desc-box .desc-ttl .en {
		font-size: 3.2rem;
	}

	.desc-box .desc-ttl .jp {
		font-size: 1.8rem;
	}

	.desc-box .info > .flex {
		flex-direction: column;
	}

	.desc-box .info .flex .txt {
		width: 100%;
		padding-right: 0;
		margin-bottom: 30px;
	}

	.desc-box .info .txt h3 {
		font-size: 2.1rem;
		margin-bottom: 15px;
	}

	.desc-box .info .txt .read {
		line-height: 2;
		letter-spacing: 1px;
	}

	.desc-box .info .flex .check {
		width: 100%;
	}

	.desc-box .skill {
		margin: 0;
	}

	.desc-box .skill .ttl-01 {
		margin-bottom: -5rem;
	}

	.desc-box .skill .box {
		padding: 5rem 2rem 3rem;
	}

	.desc-box .skill .box > .flex {
		flex-direction: column;
	}

	.desc-box .skill .box .cont {
		padding: 3rem 2rem 2rem;
		margin-top: 4rem;
	}

	.desc-box .skill .box .flex .cont {
		width: 100%;
		margin-right: 0 !important;
	}

	.desc-box .skill .box .cont::before {
		height: 40px;
		top: -20px;
	}

	.desc-box .skill h3 {
		font-size: 1.8rem;
		letter-spacing: 8px;
		margin-bottom: 15px;
	}

	.guideline-box {
		margin-top: 2rem;
		padding-bottom: 0;
	}

	.guideline-box .ttl-03 .bg-txt {
		left: -48px;
	}

	.guideline-box .dl-02 {
		margin: 2rem 0;
	}

	.guideline-box .dl-02 .note {
		font-size: 1.5rem;
	}

	.guideline-box .dl-02 .btn-01 {
		width: 100%;
		margin: 1.5rem 0 .5rem !important;
		text-align: left;
	}

	.guideline-box .dl-02 .btn-01 a {
		padding: 11px 10px 12px;
		width: 232px;
	}

	.guideline-box .dl-02 .list-01 li::before {
		top: 11px;
	}

	.flow-box {
		padding-bottom: 4.5rem;
	}

	.flow-box .wrap {
		padding: 0;
	}

	.flow-box .box-list {
		margin-top: 1.2rem;
		margin-left: -3rem;
	}

	.flow-box.cont-01 .box-list {
		margin-left: auto;
	}

	.flow-box .box-list .box {
		padding: 40px 30px 35px;
		margin-right: 10px !important;
		transform: translateY( 0 ) scale( 1 );
		opacity: 1;
		position: absolute;
		top: 0;
	}

	.flow-box .box-list .box.slick-slide,
	.flow-box .box-list .box:first-child {
		position: relative;
	}

	.flow-box .box-list .box:nth-child( even ) {
		margin-right: 8px !important;
	}

	.flow-box .box-list figure {
		width: 185px;
		height: 185px;
	}

	.flow-box .box-list figure img {
		width: 185px;
		height: 185px;
	}

	.flow-box .box-list .num {
		font-size: 2.8rem;
		left: 1.4rem;
	}

	.flow-box .box-list h3 {
		font-size: 2.1rem;
	}

	.flow-box .box-list .read {
		font-size: 1.4rem;
	}

	.form-box .bnr-single {
		margin: 2.2rem 0 3.4rem;
	}

	.form-box .notice {
		flex-direction: column;
		margin: 0;
	}

	.form-box .form-wrap {
		padding: 2.8rem 0 6rem;
	}

	.form-box .notice .ttl {
		width: 100%;
		margin-bottom: 22px;
	}

	.form-box .notice .ttl h3 {
		margin-top: 0;
		padding: 2px;
		font-size: 1.6rem;
	}

	.form-box .notice .txt {
		max-width: 100%;
		padding-left: 0;
	}

	.form-box .notice .txt li {
		margin-bottom: 12px;
	}

	.form-box .form-wrap .box {
		padding: 20px;
	}

	.form-step > p {
		width: calc( ( 99.999999% - 12px ) / 3 );
		margin-right: 6px;
		font-size: 1.2rem;
		height: 30px;
		line-height: 30px;
		padding: 0 12px 0 8px !important;
		background: #fff url( ../img/entry/sp/step-bg-02-sp.png ) right center / auto 30px no-repeat;
	}

	.mw_wp_form_input .step-01,
	.mw_wp_form_confirm .step-02 {
		background: #fff url( ../img/entry/sp/step-bg-01-sp.png ) right center / auto 30px no-repeat;
		color: #fff;
	}

	.form-step .step-03 {
		background: #fff url( ../img/entry/sp/step-bg-03-sp.png ) right center / auto 30px no-repeat;
	}

	.form-step > p .en {
		display: none;
	}

	#contact2 .form-wrap .mw_wp_form form > dl {
		flex-direction: column;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dt {
		width: 100%;
		padding: 13px 0;
	}

	#contact2 .form-wrap dl .req-label {
		position: relative;
		top: -1px;
		right: 0;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd {
		width: 100%;
		padding: 0 0 20px;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd::before {
		left: 0;
	}

	#contact2 .form-wrap .tf-marker {
		top: -30px;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday {
		justify-content: space-between;
		margin: 0;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday > div select {
		width: 6.5rem;
		min-width: initial;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday > div.y select {
		width: 9rem;
	}

	#contact2 .form-wrap .mw_wp_form_input form dl dd .birthday span {
		margin: 0 -2px 0 1px;
	}

	#contact2 .form-wrap .mwform-radio-field-text {
		margin: 3.5rem 0;
	}

	#contact2 .form-wrap .mw_wp_form .horizontal-item + .horizontal-item {
		margin-left: 20px;
	}

	#contact2 .form-wrap .mwform-radio-field-text {
		margin: 0;
	}

	.form-box form label.file-btn {
		margin: 0;
		padding: 7.5px 20px;
	}

	#contact2 .form-wrap .tf-require-counter {
		bottom: 0;
	}

	#contact2 .form-wrap .req-label {
		margin-right: 0;
		transform: none;
	}

	.submit-box {
		text-align: center;
		margin: 0 -20px;
	}

	.submit-box .agree {
		margin: 3rem 0;
	}

	.form-box .agree label {
		font-size: 1.4rem;
		letter-spacing: 0;
	}

	.form-box .agree label a {
		background: transparent;
		padding: 0;
	}

	.form-box .agree .pp-mark {
		margin-left: 8px;
	}

	.form-box .agree .pp-mark a {
		width: 40px;
	}

	#contact2 .form-wrap button[type=submit] {
		margin-bottom: 2rem;
	}

	#fix-bnr-line {
		bottom: 0;
		left: 0;
	}

	#fix-bnr-line a {
		width: 100%;
		padding: 12.5px 16px 12.5px 8px;
	}

	#fix-bnr-line a .btn span {
		padding: 5px 0 5px 55px;
	}

	/*
	footer .bottom-wrap {
		padding: 11rem 0 16rem;
	}
	*/

	/* confirm */

	#confirm #contact2 .form-wrap h3.ttl {
		font-size: 2rem;
		margin-bottom: 2rem;
	}

	#contact2 .form-wrap .mw_wp_form_confirm form > dl {
		margin: 3rem 0 4rem;
	}

	#contact2 .form-wrap .mw_wp_form_confirm form dl dt {
		width: 100%;
		padding: 12px 20px 14px;
		border-bottom: none;
	}

	#contact2 .form-wrap .mw_wp_form_confirm form dl dd {
		width: 100%;
		padding: 15px 20px 20px;
		min-height: 6rem;
	}

	#confirm .form-box form a {
		padding: 0;
		border: none;
		text-decoration: underline;
	}

	#confirm .submit-box > p {
		-js-display: flex;
		display: -ms-flex;
		display: -webkit-flex;
		display: flex;
		flex-direction: column-reverse;
	}

	#confirm #contact2 .form-wrap button[type="submit"] {
		width: 100%;
	}

	#confirm #contact2 .form-wrap .back-btn {
		width: 100%;
		margin-right: 0;
	}

	#confirm footer .bottom-wrap,
	#thanks footer .bottom-wrap {
		padding: 4rem 0;
	}

}


/*
----------------------------------------
hover
----------------------------------------
*/

@media screen and ( min-width: 769px ) {

	.job-box .job-list li.view a:hover {
		box-shadow: 0 0 10px rgba( 0, 0, 0, .2 );
	}

	.job-box .job-list li a:hover::before {
		right: 0;
	}

	#fix-bnr-line a:hover::after {
		right: 0;
	}

	#contact2 .form-wrap button[type="submit"]:hover {
		box-shadow: 0 0 20px rgba( 0, 0, 0, .4 ) !important;
	}

	#contact2 .form-wrap button[type="submit"]:hover::after {
		transform: translateX( 5px );
	}

	#contact2 .form-wrap button[type="submit"].disabled:hover {
		box-shadow: none !important;
	}

	#confirm #contact2 .form-wrap .back-btn:hover {
		opacity: .8;
	}

}
