@charset "UTF-8";

/* ---------------------------------------
  girls-session
-----------------------------------------*/


/* sec_mv
--------------------------------*/
@media screen and (max-width: 768px) {
	#pagettl .ttl .ja {
		letter-spacing: 0.05em;
	}
}

/* sec_mv
--------------------------------*/
#sec_mv {
	padding: 54px 0 158px;
	background-color: #efb349;
}

#sec_mv::before {
	content: "";
	width: 100%;
	height: 158px;
	background-color: #fff;
	transform: skewY(-5deg);
	transform-origin: left bottom;
	position: absolute;
	left: 0;
	bottom: -158px;
}

#sec_mv .wrap {
	align-items: center;
}

#sec_mv .ttlwrap {
	width: 459px;
}

#sec_mv .ttlwrap .txt span {
	display: inline-block;
	width: 202px;
	text-align: center;
	color: #fff;
	background-color: #000;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.7;
	padding: .5em;
	clip-path: polygon(15px 0%, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
}

#sec_mv .ttlwrap .txt {
	margin-top: 34px;
}

#sec_mv .ttlwrap .txt span + span {
	margin-left: 20px;
}

#sec_mv .imgwrap {
	position: relative;
	width: 559px;
	z-index: 1;
}

#sec_mv .imgwrap .ob {
	position: absolute;
}

#sec_mv .imgwrap .ob01 {
	width: 143px;
	left: -63px;
	top: 0;
	z-index: -1;
}

#sec_mv .imgwrap .ob02 {
	width: 177px;
	right: -75px;
	bottom: 16px;
	z-index: -1;
}

#sec_mv .imgwrap .ob03 {
	width: 66px;
	left: -25px;
	bottom: -33px;
	z-index: -1;
}

@media screen and (max-width: 768px) {
	#sec_mv {
		padding: 5vw 0 12vw;
	}

	#sec_mv::before {
		height: 8.8vw;
		bottom: -8.8vw;
	}

	#sec_mv .ttlwrap {
		width: 100%;
	}

	#sec_mv .ttlwrap .txt span {
		width: 40.13vw;
		font-size: 4vw;
		clip-path: polygon(3vw 0%, 100% 0, 100% calc(100% - 3vw), calc(100% - 3vw) 100%, 0 100%, 0 3vw);
	}

	#sec_mv .ttlwrap .txt {
		margin-top: 34px;
		display: flex;
		justify-content: space-between;
	}

	#sec_mv .ttlwrap .txt span + span {
		margin-left: 0;
	}

	#sec_mv .imgwrap {
		width: 74.67vw;
		margin: 8vw auto 0;
	}

	#sec_mv .imgwrap .ob01 {
		width: 19.07vw;
		left: -8.53vw;
	}

	#sec_mv .imgwrap .ob02 {
		width: 23.6vw;
		right: -10vw;
		bottom: 1.87vw;
	}

	#sec_mv .imgwrap .ob03 {
		width: 8.8vw;
		left: -3.33vw;
		bottom: -4.2vw;
	}

}


/* contents
--------------------------------*/
#sec_contents {
	padding: 0 0 110px;
}

#sec_contents .bgob {
	position: absolute;
}

#sec_contents .bgob01 {
	left: 0;
	top: 0;
}

#sec_contents .bgob02 {
	right: 0;
	top: -170px;
}

#sec_contents .bgob03 {
	width: 66px;
	right: 154px;
	top: 20px;
}

#sec_contents .txtwrap .lead {
	color: #efb349;
	font-size: 3.4rem;
	line-height: 1.58;
	margin-bottom: 1em;
}

#sec_contents .main {
	margin-top: 60px;
}

#sec_contents .imgwrap {
	margin-top: 45px;
	align-items: flex-start;
}

#sec_contents .imgwrap .img {
	position: relative;
}

#sec_contents .imgwrap .img02 {
	padding-top: 120px;
}

#sec_contents .imgwrap .img .ob {
	position: absolute;
	z-index: -1;
}

#sec_contents .imgwrap .img01 .ob01 {
	width: 83px;
	left: -32px;
	bottom: -24px;
}

#sec_contents .imgwrap .img01 .ob02 {
	width: 62px;
	right: -32px;
	top: 62px;
}


#sec_contents .imgwrap .img02 .ob02 {
	width: 126px;
	left: -48px;
	bottom: -36px;
}

#sec_contents .imgwrap .img03 .ob01 {
	width: 118px;
	right: -36px;
	bottom: -28px;
}

#sec_contents .imgwrap .img03 .ob02 {
	width: 126px;
	left: -39px;
	top: -11px;
}

@media screen and (max-width: 768px) {
	#sec_contents {
		padding: 0 0 26vw;
	}

	#sec_contents .wrap {
		padding-top: 25vw;
	}

	#sec_contents .bgob01 {
		width: 23.07vw;
		left: 0;
		top: 2.67vw;
	}

	#sec_contents .bgob02 {
		width: 24.67vw;
		right: 6vw;
		top: -11.4vw;
	}

	#sec_contents .bgob03 {
		width: 8.8vw;
		right: 33vw;
		top: 7.2vw;
	}

	#sec_contents .txtwrap .lead {
		font-size: 6.4vw;
	}

	#sec_contents .txtwrap .txt {
		margin: 0 -1em;
	}

	#sec_contents .main {
		margin: 17vw -.2665vw 0;
	}

	#sec_contents .imgwrap {
		margin-top: 10vw;
		padding: 0 6.6vw;
	}

	#sec_contents .imgwrap .img {
		width: 58.8vw;
	}

	#sec_contents .imgwrap .img + .img {
		margin-top: 4.27vw;
	}

	#sec_contents .imgwrap .img02 {
		padding-top: 0;
		margin-top: 3.46vw;
		margin-left: auto;
	}

	#sec_contents .imgwrap .img01 .ob01 {
		width: 14.67vw;
		left: -6.6vw;
		bottom: -4.3vw;
	}

	#sec_contents .imgwrap .img01 .ob02 {
		width: 10.93vw;
		right: -5.33vw;
		top: 11.2vw;
	}


	#sec_contents .imgwrap .img02 .ob02 {
		width: 22.27vw;
		left: auto;
		right: -6.6vw;
		bottom: auto;
		top: -6.53vw;
	}

	#sec_contents .imgwrap .img03 .ob01 {
		width: 20.93vw;
		right: -6.67vw;
		bottom: -4.67vw;
	}

	#sec_contents .imgwrap .img03 .ob02 {
		width: 22.27vw;
		left: -6.6vw;
		top: -1.87vw;
	}

}

/* learn
--------------------------------*/
#sec_learn {
	padding: 70px 0;
	background-color: #efb349;
}

#sec_learn::before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 36px 36px 36px;
	border-color: transparent transparent #efb249 transparent;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 100%;
	margin: 0 auto;
}

#sec_learn .wrap {
	align-items: flex-start;
}

#sec_learn .txtwrap {
	width: 625px;
}

#sec_learn .txtwrap .ttl {
	color: #fff;
	font-weight: 700;
	font-size: 2.4rem;
	/*	line-height: 1.5;*/
	text-align: center;
	background-color: #000;
	padding: .38em .5em;
	clip-path: polygon(15px 0%, calc(100% - 15px) 0%, 100% 50%, calc(100% - 15px) 100%, 15px 100%, 0 50%);
	margin-bottom: 1.4em;
}

#sec_learn .message {
	width: 480px;
}

#sec_learn .message .box {
	align-items: flex-end;
	width: 100%;
	background-color: #fff;
	border: 2px solid #000;
	border-radius: 15px;
	padding: 16px 40px 35px;
}

#sec_learn .message .box .txt {
	width: 201px;
	font-size: 1.4rem;
	line-height: 2.714em;
	text-align: justify;
	background-image:
		linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%, #fff 50%, #fff 50%),
		linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 95%, #ccc 95%, #ccc 100%);
	background-size: 6px 100%, 100% 2.714em;
	/*	text-decoration: 2px solid #cccccc;*/
}

#sec_learn .message .box .imgwrap {
	width: 168px;
}

#sec_learn .message .box .imgwrap .name {
	text-align: center;
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.5;
	margin-top: .8em;
}

#sec_learn .message .box .imgwrap .name span {
	display: block;
	font-size: 1.4rem;
	line-height: 1.4;
	margin-bottom: .4em;
}

@media screen and (max-width: 768px) {
	#sec_learn {
		padding: 13vw 0;
	}

	#sec_learn::before {
		border-width: 0 7.33vw 7.33vw 7.33vw;
	}

	#sec_learn .txtwrap {
		width: 100%;
	}

	#sec_learn .txtwrap .ttl {
		font-size: 4.27vw;
		padding: .53em .5em;
		clip-path: polygon(2.8vw 0%, calc(100% - 2.8vw) 0%, 100% 50%, calc(100% - 2.8vw) 100%, 2.8vw 100%, 0 50%);
		margin-bottom: 1.6em;
	}

	#sec_learn .txtwrap .main {
		margin-left: -3.2vw;
	}

	#sec_learn .message {
		width: 100%;
	}

	#sec_learn .message .box {
		margin-top: 9vw;
		border: .4vw solid #000;
		border-radius: 3vw;
		padding: 1.4vw 8vw 7vw;
	}

	#sec_learn .message .box .txt {
		width: 100%;
		font-size: 3.2vw;
		line-height: 2.58em;
		background-size: 1.2vw 100%, 100% 2.58em;
		margin-top: 3vw;
	}

	#sec_learn .message .box .imgwrap {
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	#sec_learn .message .box .imgwrap .img {
		width: 23.47vw;
	}

	#sec_learn .message .box .imgwrap .name {
		width: 34vw;
		font-size: 4vw;
		margin-top: 2vw;
		text-align: left;
	}

	#sec_learn .message .box .imgwrap .name span {
		font-size: 2.8vw;
	}
}

/* requirements
--------------------------------*/
#sec_requirements {
	background-color: #fdf7ec;
	padding: 100px 0 0;
	/*	min-height: 453px;*/
}

#sec_requirements .detail {
	margin: 0 auto;
	clip-path: polygon(25px 0%, 100% 0, 100% calc(100% - 25px), calc(100% - 25px) 100%, 0 100%, 0 25px);
}

#sec_requirements .detail .detailttl {
	font-weight: 700;
	font-size: 2.4rem;
	background-color: #efb349;
	padding: .318em 1em;
}

#sec_requirements .detail .inner {
	background-color: #fff;
	padding: 36px 83px;
}

#sec_requirements .detail .tb {
	display: flex;
	flex-wrap: wrap;
}

#sec_requirements .detail .tb dt,
#sec_requirements .detail .tb dd {
	color: #000;
	border-top: 1px solid #b2b2b2;
	padding: 1em 0;
	text-align: justify;
}

#sec_requirements .detail .tb dt:first-of-type,
#sec_requirements .detail .tb dd:first-of-type {
	border-top: none;
}

#sec_requirements .detail .tb dt {
	width: 240px;
	font-weight: 700;
}

#sec_requirements .detail .tb dd {
	width: calc(100% - 240px);
}

#sec_requirements .detail .tb dd a {
	text-decoration: underline;
}

#sec_requirements .lead.last {
	text-align: center;
	color: #000;
	font-weight: 700;
	font-size: 3.2rem;
	line-height: 1.875;
	margin-top: 1.7em;
}

#sec_requirements .lead.last span {
	padding-bottom: .1em;
	border-bottom: 5px solid #000;
}

/*entry_box*/
#sec_requirements .entry_box {
	width: 473px;
	background-color: #efb349;
	padding: 32px 20px 40px;
	margin: 60px auto 0;
	position: relative;
}

#sec_requirements .entry_box .ttl {
	color: #000;
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.5;
	margin-bottom: .85em;
}

#sec_requirements .entry_box .btn a {
	min-width: 230px;
	background: linear-gradient(0deg, rgba(204, 204, 204, 1) 0%, rgba(255, 255, 255, 1) 100%);
	color: #000;
	border: 1px solid transparent;
}

#sec_requirements .entry_box .btn a::before {
	background-image: url(../img/common/btn_arw_s_black.svg);
}

#sec_requirements .entry_box .btn a::after {
	opacity: 0;
}


@media screen and (min-width: 769px) {
	#sec_requirements .entry_box .btn a:hover {
		background: transparent;
		color: #fff;
		border: 1px solid #fff;
	}

	#sec_requirements .entry_box .btn a:hover::before {
		background-image: url(../img/common/btn_arw_s.svg);
	}

	#sec_requirements .entry_box .btn a:hover::after {
		opacity: 1;
	}
}

@media screen and (max-width: 768px) {
	#sec_requirements {
		padding: 17vw 0 0;
	}

	#sec_requirements .detail {
		margin: 0 auto;
		clip-path: polygon(4.8vw 0%, 100% 0, 100% calc(100% - 4.8vw), calc(100% - 4.8vw) 100%, 0 100%, 0 4.8vw);
	}

	#sec_requirements .detail .detailttl {
		font-size: 4.8vw;
		padding: .318em 1em;
	}

	#sec_requirements .detail .inner {
		padding: 7.2vw 8vw;
	}

	#sec_requirements .detail .tb {
		display: block;
	}

	#sec_requirements .detail .tb dt,
	#sec_requirements .detail .tb dd {
		padding: 1em 0;
	}

	#sec_requirements .detail .tb dt {
		width: 100%;
		padding-bottom: 0;
	}

	#sec_requirements .detail .tb dd {
		width: 100%;
		padding-top: .4em;
		border: none;
	}

	#sec_requirements .lead.last {
		font-size: 5.07vw;
		line-height: 2.1;
		margin: 3.15em -.5em 0;
	}

	#sec_requirements .lead.last span {
		padding-bottom: .1em;
		border-bottom: .8vw solid #000;
	}

	/*entry_box*/
	#sec_requirements .entry_box {
		width: 100%;
		padding: 7vw 3vw 8vw;
		margin: 12vw auto 0;
	}

	#sec_requirements .entry_box .ttl {
		font-size: 4.8vw;
	}

	#sec_requirements .entry_box .btn a {
		min-width: 46vw;
		border: none;
	}
}


/*contact_tel*/

.contact_tel {
	padding: 240px 0 90px;
	margin-top: -180px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: url(../img/internship/contact_bg_pc.png) no-repeat right top/ cover;
}

.contact_tel .box {
	width: 728px;
	margin: 0 auto;
	position: relative;
	clip-path: polygon(20px 0%, 100% 0, 100% calc(100% - 20px), calc(100% - 20px) 100%, 0 100%, 0 20px);
	backface-visibility: hidden;
}

.contact_tel .box .inner {
	align-items: center;
	padding: 26px 48px;
	position: relative;
	border: 3px solid #231815;
}

.contact_tel .box .inner::before,
.contact_tel .box .inner::after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	position: absolute;
}

.contact_tel .box .inner::before {
	border-width: 18px 18px 0 0;
	border-color: #231815 transparent transparent transparent;
	left: 0;
	top: 0;
}

.contact_tel .box .inner::after {
	border-width: 0 0 19px 19px;
	border-color: transparent transparent #231815 transparent;
	right: 0;
	bottom: 0;
}

.contact_tel .box .ttl {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: 0.14em;
}

.contact_tel .box .tel {
	padding-left: 26px;
	border-left: 2px solid #231815;
}

.contact_tel .box .tel .num {
	font-size: 3.5rem;
	line-height: 1;
	letter-spacing: 0.05em;
}

.contact_tel .box .tel .txt {
	line-height: 1.5;
	margin-top: 6px;
}

#sec_entryform.thanks .contact_tel {
	height: 32.888vw;
	min-height: 592px;
	padding-bottom: 62px;
	padding: 3.8vw 0 62px;
}
@media screen and (max-width: 1800px) {
	.contact_tel {
		background-size: 1800px auto;
	}
}

@media screen and (max-width: 768px) {
	.contact_tel {
		padding: 40vw 0 12vw;
		margin-top: -25vw;
		display: flex;
		align-items: center;
		justify-content: center;
		background: url(../img/internship/contact_bg_sp.png) no-repeat right top/ cover;
	}

	.contact_tel .box {
		width: 84%;
		clip-path: polygon(15px 0%, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
	}

	.contact_tel .box .inner {
		padding: 5vw 8vw;
		display: block;
		border-width: 2px;
	}

	.contact_tel .box .inner::before {
		border-width: 14px 14px 0 0;
	}

	.contact_tel .box .inner::after {
		border-width: 0 0 14px 14px;
	}

	.contact_tel .box .ttl {
		font-size: 4vw;
		text-align: center;
		margin-bottom: 4vw;
	}

	.contact_tel .box .tel {
		padding-left: 0;
		padding-top: 4vw;
		border-left: none;
		position: relative;
	}

	.contact_tel .box .tel::before {
		content: "";
		width: 56.53vw;
		height: .4vw;
		background-color: #000;
		position: absolute;
		left: 0;
		right: 0;
		margin: 0 auto;
		top: 0;
	}

	.contact_tel .box .tel .num {
		font-size: 7vw;
	}

	.contact_tel .box .tel .txt {
		margin-top: .4em;
	}

	#sec_entryform.thanks .contact_tel {
		height: 117.87vw;
    min-height: inherit;
		padding-bottom: 12vw;
	}
}


/* sec_entryform
--------------------------------*/
#sec_entryform {
	background-color: #f7f7f7;
	padding: 50px 0 0;
	z-index: 1;
}

#sec_entryform .lead {
	width: 984px;
	margin: 0 auto;
	color: #000;
}

#sec_entryform .lead .txt {
	font-size: 1.8rem;
	letter-spacing: 0.15em;
	position: relative;
}

#sec_entryform .lead .txt:first-child {
	padding-bottom: 1.5em;
	margin-bottom: 1.5em;
}

#sec_entryform .lead .txt:first-child::after {
	content: "";
	width: 55px;
	height: 1px;
	background-color: #000000;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	margin: 0 auto;
}

#sec_entryform .lead .txt a {
	color: #808080;
	text-decoration: underline;
}

#sec_entryform .lead .bnr {
	width: 956px;
	margin: 25px auto 45px;
}

#sec_entryform .lead .bnr a {
	position: relative;
	display: block;
	box-shadow: 16px 16px 0 rgba(0, 0, 0, .2);
	transition: .3s ease;
}

#sec_entryform .lead .note {
	font-size: 1.2rem;
	margin-top: 2em;
}

#sec_entryform .lead .note .must {
	color: #cd0016;
}

.form_wrap {
	margin-top: 60px;
	background-color: #fff;
	position: relative;
	padding: 30px 83px 70px;
	border-top: 6px solid #efb349;
}

.form_wrap h2.ttl-confirm-format {
	font-size: 2.2rem;
	text-align: center;
	margin-bottom: 1.2em;
	font-weight: bold;
}

.form_wrap .notice {
	font-size: 1.8rem;
	text-align: center;
	margin-top: 2em;
}

@media screen and (max-width: 768px) {
	.form_wrap h2.ttl-confirm-format {
		font-size: 4vw;
	}

	.form_wrap .notice {
		font-size: 3.4vw;
	}
}

/*form*/
.form .box {
	padding: 24px 0;
	position: relative;
	border-bottom: 1px solid #cccccc;
}

.form .box dl {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.form .box dl + dl {
	margin-top: 17px;
}

.form .box dl dt,
.form .box dl dd {
	line-height: 1.5;
}

.form .box dl dd p {
	line-height: 1;
}

.form .box dl dd:not(.flex) p + p {
	margin-top: 20px;
}

.form .box dd p span.txt {
	margin-top: 1.4em;
}

.form .box dl dt {
	width: 300px;
	padding-top: 1.125em;
}

.form .box dl .must {
	display: inline-block;
	color: #cd0016;
	font-size: 1.6rem;
	letter-spacing: 0;
	line-height: 1;
	margin-left: 2px;
}

.form .box dl dd {
	width: 684px;
}

.form .box dl dd.flex {
	justify-content: space-between;
}

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form select,
.form textarea {
	width: 100%;
	background: #f7f7f7;
	height: 60px;
	border: 1px solid #e5e5e5;
	padding: 1em;
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.625;
}

.form input.short {
	width: 243px;
}

.form input.short2 {
	width: 130px;
}

::placeholder {
	color: #d2d2d3;
}

:-ms-input-placeholder {
	color: #d2d2d3;
}

::-ms-input-placeholder {
	color: #d2d2d3;
}

/*select*/

.form select {
	padding-right: 2em;
	background: #f7f7f7 url(../img/entry/select.png) no-repeat;
	background-position: right 18px center;
	cursor: pointer;
}

/* .form select option.disabled {
	color: #cd0016;
	opacity: 1;
} */

/*textarea*/

.form textarea {
	resize: vertical;
	overflow: auto;
}


/*check*/

.form .checklist {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	margin: 17px 0 0;
}

.form .checklist > * {
	display: block;
	line-height: 1.3125;
}

.form .wpcf7-list-item {
	margin: 0;
}

.form .checklist > * + * {
	margin-left: 40px;
}

.form .checkwrap label,
.form .checklist label {
	display: inline-block;
	position: relative;
}

.form .checkwrap input[type=checkbox],
.form .checklist input[type=radio],
.form .checklist input[type=checkbox] {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	width: 1px;
}

.form .checkwrap input[type=checkbox] + span,
.form .checklist input[type=radio] + span,
.form .checklist input[type=checkbox] + span {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	cursor: pointer;
	padding-left: 1.8em;
	min-width: inherit;
}

.form .checkwrap input[type=checkbox] + span::before,
.form .checkwrap input[type=checkbox] + span::after,
.form .checklist input[type=radio] + span::before,
.form .checklist input[type=radio] + span::after,
.form .checklist input[type=checkbox] + span::before,
.form .checklist input[type=checkbox] + span::after {
	content: "";
	display: inline-block;
	position: absolute;
}

.form .checkwrap input[type=checkbox] + span::before,
.form .checklist input[type=radio] + span::before,
.form .checklist input[type=checkbox] + span::before {
	width: 1.125em;
	height: 1.125em;
	background: #f7f7f7;
	border: 1px solid #e5e5e5;
	top: .15em;
	left: 0;
}

.form .checkwrap input[type=checkbox]:checked + span::before,
.form .checklist input[type=radio]:checked + span::before,
.form .checklist input[type=checkbox]:checked + span::before {
	border-color: #efb349;
	background-color: #efb349;
}


.form .checkwrap input[type=checkbox]:checked + span::after,
.form .checklist input[type=radio]:checked + span::after,
.form .checklist input[type=checkbox]:checked + span::after {
	width: 0.6em;
	height: 0.35em;
	border-bottom: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: rotate(-48deg);
	border-radius: 0;
	background: transparent;
	left: 0.25em;
	top: 0.45em;
}

/*name*/

.form .name dd p {
	display: flex;
	align-items: flex-start;
}

.form .name dd p span.txt {
	min-width: 3.5em;
}

/*birthday*/
.form .birthday dd p {
	display: flex;
	align-items: flex-start;
	max-width: 166px;
}

.form .birthday dd p + p {
	margin-left: 2.5em;
}

.confirm-format .form .birthday dd p + p {
	margin-left: 1em;
}

.form .birthday select {
	width: 130px;
}

.form .box .birthday dd.flex {
	justify-content: flex-start;
}

.form .birthday dd p span.txt {
	margin-left: 1.1em;
}


/*phone*/

.form .phone dd > span {
	display: inline-block;
	max-width: 130px;
	vertical-align: top;
}

.form .phone dd .txt {
	vertical-align: top;
	font-size: 2rem;
	line-height: 1;
	margin: 1em .5em 0;
}

.form .phone input:last-child {
	margin-right: 0;
}

.form .phone .txt_s {
	font-size: 1.2rem;
	margin: .8em 0 0 !important;
}

/*reki*/
.form .reki dd p {
	display: flex;
	align-items: flex-start;
}

.form .reki dd p .txt_ttl {
	width: calc(100% - 560px);
	margin-top: 1.2em;
}

.form .reki dd p input {
	width: 560px;
}

.form .reki dd p .graduation-year input {
	width: 100%;
}

.form .reki dd p span.txt {
	margin-left: 1.1em;
}

.form .reki select {
	width: 130px;
}

.form .reki dd p .graduation-year {
	max-width: 130px;
}

/*referred*/
.form dl.referred {
	background: #fdf7ec;
	padding: 19px 0;
}

.form dl.referred dt {
	padding-left: 1.2em;
}

.form dl.referred select {
	/* width: 197px; */
	width: 50%;
	background-color: #fff;
}

/*type*/
.form dl.type dt,
.form dl.type .checklist {
	margin: 0;
	padding: 0;
}


/*privacy*/

.form .privacy {
	border: none;
	padding: 30px 0 0;
}

.form .privacy .txt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.05em;
}

.form .privacy .txt a {
	color: #808080;
	text-decoration: underline;
}

.form .privacy .checkwrap {
	line-height: 1.3125;
	margin: 30px 0 0;
}

.form .privacy .checkwrap input[type=checkbox] + span {
	font-weight: 700;
}

/*submitbtn*/

.form .maltistep-btn {
	margin: 60px auto 0;
	justify-content: center;
	display: flex;
}

.form .editbtn {
	position: relative;
	width: 345px;
	height: 62px;
	margin-bottom: 10px;
}

.form .submitbtn {
	position: relative;
	width: 345px;
	height: 62px;
	margin-left: 10px;
}

.form .editbtn {
	clip-path: polygon(10px 0%, 100% 0%, 100% 100%, 10px 100%, 0% 50%);
	background: #ccc;
	padding: 1px;
	transition: .3s ease;
}

.form .editbtn input {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: #b2b2b2;
	font-weight: 700;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	padding: 0 4em;
	position: relative;
	clip-path: polygon(10px 0%, 100% 0%, 100% 100%, 10px 100%, 0% 50%);
	/* background-image: linear-gradient(to right, rgba(255, 255, 255, .7) 0%, rgba(65, 180, 190, 1) 50%, rgba(6, 74, 150, 1) 100%); */
	background: #fff;
	background-size: 200% auto;
	background-position: right center;
	transition: .3s ease;
	cursor: pointer;
}

.form .editbtn:hover {
	opacity: .7;
}

.form .submitbtn input {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: #fff;
	font-weight: 700;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	padding: 0 4em;
	position: relative;
	clip-path: polygon(calc(100% - 10px) 0, 100% 50%, calc(100% - 10px) 100%, 0% 100%, 0% 0%);
	background-image: linear-gradient(to right, rgba(65, 180, 190, 1) 0%, rgba(6, 74, 150, 1) 50%, rgba(65, 180, 190, 1) 100%);
	background-size: 200% auto;
	background-position: right center;
	transition: .3s ease;
	cursor: pointer;
}

.form .submitbtn .wpcf7-spinner {
	margin: 24px auto;
	display: block;
}

.form .editbtn::before {
	content: "";
	width: 10px;
	height: 51px;
	background-image: url(../img/common/btn_arw_s_back.svg);
	position: absolute;
	right: auto;
	top: 0;
	left: 5px;
	bottom: 0;
	margin: auto;
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: right center;
	transition: .3s ease;
	z-index: 2;
}

.form .submitbtn::before {
	content: "";
	width: 10px;
	height: 51px;
	background-image: url(../img/common/btn_arw_s.svg);
	position: absolute;
	top: 0;
	bottom: 0;
	right: 5px;
	margin: auto;
	background-repeat: no-repeat;
	background-size: auto 100%;
	background-position: right center;
	transition: .3s ease;
	z-index: 2;
}


.form .editbtn input:hover {
	background-position: left center;
}

.form .submitbtn input:hover {
	background-position: left center;
}


@media screen and (min-width: 769px) {
	#sec_entryform .lead .bnr a::before {
		content: "";
		width: 100%;
		height: 100%;
		background-color: rgba(255, 255, 255, .15);
		position: absolute;
		left: 0;
		top: 0;
		opacity: 0;
		transition: .3s ease;
	}

	#sec_entryform .lead .bnr a:hover::before {
		opacity: 1;
	}

	#sec_entryform .lead .bnr a:hover {
		transform: translate(16px, 16px);
		box-shadow: 0 0 0 rgba(0, 0, 0, .2);
	}
}

@media screen and (max-width: 768px) {
	#sec_entryform {
		padding: 10vw 0 0;
	}

	#sec_entryform .lead {
		width: 100%;
	}

	#sec_entryform .lead .txt {
		font-size: 3.6vw;
	}

	#sec_entryform .lead .txt:first-child::after {
		width: 11vw;
	}

	#sec_entryform .lead .bnr {
		width: 100%;
		margin: 5vw auto 9vw;
	}

	#sec_entryform .lead .bnr a {
		box-shadow: 3.2vw 3.2vw 0 rgba(0, 0, 0, .2);
	}

	#sec_entryform .lead .note {
		font-size: 2.4vw;
	}

	#sec_entryform.graduate .message .box .txtwrap {
		width: 100%;
	}

	#sec_entryform.graduate .message .box .img {
		width: 44vw;
		margin-right: -4vw;
		margin-left: -8vw;
	}

	#sec_entryform.career .message .box .txtwrap {
		width: 100%;
	}

	#sec_entryform.career .message .box .img {
		width: 32.66vw;
		margin-right: -1vw;
	}

	.form_wrap {
		margin: 18vw 0 0;
		padding: 8vw 4vw 12vw;
		border-top-width: 1.2vw;
	}

	/*form*/
	.form .box {
		padding: 4vw 0;
	}

	.form .box dl {
		display: block;
	}

	.form .box dl + dl {
		margin-top: 4vw;
	}

	.form .box dl dd:not(.flex) p + p {
		margin-top: 4vw;
	}

	.form .box dd p span.txt {
		margin-top: 1em;
	}

	.form .box dl dt {
		width: 100%;
		padding-top: 0;
		margin-bottom: .5em;
	}

	.form .box dl .must {
		font-size: 3.2vw;
		margin-left: .4vw;
	}

	.form .box dl dd {
		width: 100%;
	}

	.form input[type="text"],
	.form input[type="email"],
	.form input[type="tel"],
	.form select,
	.form textarea {
		height: 10vw;
		padding: .75em .5em;
		font-size: 3.2vw;
	}

	.form input.short,
	.form .reki dd p .graduation-year input {
		width: 29vw;
	}

	.form input.short2 {
		width: 20vw;
	}

	::placeholder {
		font-size: 2.8vw;
	}

	:-ms-input-placeholder {
		font-size: 2.8vw;
	}

	::-ms-input-placeholder {
		font-size: 2.8vw;
	}

	/*select*/

	.form select {
		padding-right: 1.8em;
		background-size: 1.8vw auto;
		background-position: right 2vw center;
	}

	/*textarea*/

	.form .message textarea {
		height: 52vw;
	}


	/*check*/
	.form .checklist {
		width: 100%;
		margin: 0;
	}

	.form .checklist > * {
		width: 50%;
	}

	.form .wpcf7-list-item {
		margin: 0;
	}

	.form .checklist > * + * {
		margin-left: 0;
		margin: 1.4vw 0;
	}

	.form .checkwrap input[type=checkbox]:checked + span::after,
	.form .checklist input[type=radio]:checked + span::after {
		border-bottom: .53vw solid #fff;
		border-left: .53vw solid #fff;
	}

	/*name*/

	.form .name dd p {
		width: 48%;
	}

	.form .name dd p span.txt {
		min-width: 2.5em;
	}

	/*birthday*/
	.form .box .birthday dd.flex {
		justify-content: space-between;
	}

	.form .birthday dd p {
		max-width: 31%;
	}

	.form .birthday dd p + p {
		margin-left: auto;
	}

	.form .birthday select {
		width: 19vw;
	}

	.form .box .birthday dd.flex {
		justify-content: flex-start;
	}

	.form .birthday dd p span.txt {
		margin-left: .4em;
	}


	/*phone*/

	.form .phone dd > span {
		max-width: 27.4%;
	}

	.form .phone dd .txt {
		font-size: 3.2vw;
		margin: 1em .5em 0;
	}

	.form .phone input:last-child {
		margin-right: 0;
	}

	.form .phone .txt_s {
		font-size: 2.4vw;
	}

	/*reki*/

	.form .reki dd p {
		display: block;
	}

	.form .reki dd p .txt_ttl {
		display: block;
		width: 100%;
		margin-top: 1em;
		margin-bottom: .5em;
	}

	.form .reki dd p input {
		width: 100%;
	}

	.form .reki dd p span.txt {
		margin-left: 1em;
	}

	.form .reki select {
		width: 32vw;
	}

	.form .reki dd p .graduation-year {
		max-width: 32vw;
	}

	/*referred*/
	.form dl.referred {
		padding: 3.8vw;
	}

	.form dl.referred dt {
		padding-left: 0;
	}

	.form dl.referred select {
		/* width: 80%; */
		width: 100%;
	}

	/*privacy*/

	.form .privacy {
		padding: 6vw 0 0;
	}

	.form .privacy .txt {
		font-size: 3.2vw;
	}

	.form .privacy .checkwrap {
		margin: 6vw 0 0;
	}

	/*submitbtn*/

	.form .submitbtn {
		margin: 12vw auto 0;
		width: 54vw;
		height: 12.4vw;
	}

	.form .submitbtn input {
		font-size: 3.2vw;
		padding: 0 2.5em;
		clip-path: polygon(calc(100% - 2vw) 0, 100% 50%, calc(100% - 2vw) 100%, 0% 100%, 0% 0%);
	}

	.form .submitbtn::before {
		width: 19.2vw;
		height: 11vw;
		right: 1.1vw;
	}

	.form .editbtn input {
		font-size: 3.2vw;
	}

	.form .maltistep-btn {
		flex-direction: column;
		margin: 0;
	}

	.form .maltistep-btn .editbtn {
		order: 2;
		width: 42vw;
		margin-left: auto;
		margin-right: auto;
		margin-top: 6vw;
		height: 10vw;
		clip-path: polygon(1.5vw 0%, 100% 0%, 100% 100%, 1.5vw 100%, 0% 50%);
	}

	.form .maltistep-btn .editbtn::before {
		height: 8vw;
		left: 0.34vw;
		background-image: url(../img/common/btn_arw_s_back_sp.svg);
	}

	.form .maltistep-btn .editbtn input {
		clip-path: polygon(1.5vw 0%, 100% 0%, 100% 100%, 1.5vw 100%, 0% 50%);
	}

	.form .maltistep-btn .submitbtn {
		order: 1;
		margin-top: 8vw;
	}
}


/*エラー用*/
#sec_entryform .wpcf7-not-valid-tip {
	display: block;
	line-height: 1.75;
	font-size: .72em;
	margin-top: 0.25em;
}

.wpcf7-list-item {
	display: block;
	margin-top: 4px;
}

/* .wpcf7-list-item + .wpcf7-list-item {
	margin-top: 4px;
} */

@media screen and (max-width: 768px) {
	.wpcf7-list-item + .wpcf7-list-item {
		margin-top: 1vw;
	}
}


/* confirm
--------------------------------*/
#sec_entryform.confirm {
	padding-bottom: 90px;
}
#sec_entryform.confirm .form_wrap {
	margin-top: 0;
}

@media screen and (max-width: 768px) {
	#sec_entryform.confirm {
		padding-bottom: 8vw;
	}
}


/* thanks
--------------------------------*/

#sec_entryform.thanks .form_wrap {
	margin-top: 0;
	padding-top: 40px;
	padding-bottom: 60px;
}

#sec_entryform.thanks .form_wrap .ttl {
	text-align: center;
	font-weight: 700;
	font-style: italic;
	font-size: 2.4rem;
	line-height: 1.75;
	letter-spacing: 0.14em;
	margin-bottom: 40px;
}

#sec_entryform.thanks .form_wrap .ttl span {
	display: block;
	color: #fdf7ec;
	font-size: 8.8rem;
	line-height: 1;
	letter-spacing: 0.05em;
	margin-bottom: -.5em;
}


@media screen and (max-width: 768px) {
	#sec_entryform.thanks .form_wrap {
		padding-top: 10vw;
		padding-bottom: 10vw;
	}

	#sec_entryform.thanks .form_wrap .ttl {
		font-size: 4.8vw;
		margin-bottom: 8vw;
	}

	#sec_entryform.thanks .form_wrap .ttl span {
		font-size: 17.6vw;
		margin-bottom: -1.5em;
	}
}

/* sec_mynavi
--------------------------------*/
#sec_mynavi {
	width: 100%;
	height: 0;
	position: relative;
/*	top: -9.44vw;*/
	top: -170px;
	z-index: 2;
}

#sec_mynavi .box {
	background-color: #0b318f;
	-webkitclip-path: polygon(25px 0%, 100% 0, 100% calc(100% - 25px), calc(100% - 25px) 100%, 0 100%, 0 25px);
	clip-path: polygon(25px 0%, 100% 0, 100% calc(100% - 25px), calc(100% - 25px) 100%, 0 100%, 0 25px);
	padding: 40px 83px 60px;
	z-index: 3;
}

#sec_mynavi .box .ttl {
	font-weight: 700;
	font-size: 2.4rem;
	letter-spacing: 0.2em;
	line-height: 1.9;
	margin-bottom: 1.25em;
}

#sec_mynavi .box .link {
	width: 470px;
	background-color: #00aaeb;
	padding: 4px;
	margin-left: auto;
	margin-right: auto;
}

#sec_mynavi .box .link .logo {
	height: 78px;
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}

#sec_mynavi .box .link .txt {
	color: #fff;
	font-weight: 700;
	font-size: 1.8rem;
	line-height: 1.5;
	padding: 1em;
	position: relative;
}

#sec_mynavi .box .link .txt::before {
	content: "";
	width: 11px;
	height: 30px;
	background: url(../img/common/arw_s.svg) no-repeat center / auto 100%;
	position: absolute;
	right: 1em;
	top: 50%;
	transform: translate(0, -50%);
	transition: .3s ease;
	z-index: 2;
}


@media screen and (min-width: 769px) {
	#sec_mynavi .box .link a:hover .txt::before {
		transform: translate(5px, -50%);
	}
}

@media screen and (max-width: 768px) {
	#sec_mynavi {
		width: 100%;
		height: 0;
		position: relative;
		top: -24vw;
	}

	#sec_mynavi .box {
		-webkitclip-path: polygon(3.33vw 0%, 100% 0, 100% calc(100% - 3.33vw), calc(100% - 3.33vw) 100%, 0 100%, 0 3.33vw);
		clip-path: polygon(3.33vw 0%, 100% 0, 100% calc(100% - 3.33vw), calc(100% - 3.33vw) 100%, 0 100%, 0 3.33vw);
		padding: 8vw;
	}

	#sec_mynavi .box .ttl {
		font-size: 4.8vw;
		line-height: 1.68;
	}

	#sec_mynavi .box .link + .link {
		margin-top: 4vw;
	}

	#sec_mynavi .box .link {
		width: 100%;
		padding: 1vw;
	}

	#sec_mynavi .box .link .logo {
		height: 14.13vw;
	}

	#sec_mynavi .box .link .logo img {
		width: auto;
		height: 7.2vw;
	}

	#sec_mynavi .box .link .txt {
		font-size: 3.2vw;
		padding: .75em;
	}

	#sec_mynavi .box .link .txt::before {
		width: 2vw;
		height: 4vw;
	}
}


/* sec_session
--------------------------------*/
#sec_interview_list.under {
	margin-top: -90px;
	padding-top: 90px;
	padding-bottom: 0;
}

#sec_interview_list.under::before {
	border: none;
	height: calc(100% - 270px);
}

#sec_interview_list.under .check {
	font-weight: 700;
	font-style: italic;
	font-size: 3.2rem;
	line-height: 1.875;
	margin-bottom: 90px;
}

#sec_interview_list.under .check span {
	border-bottom: 5px solid #0b318f;
}

#sec_interview_list .ttlwrap {
	margin-bottom: 60px;
}

#sec_mynavi + #sec_interview_list.under {
	padding-top: 380px;
}

@media screen and (min-width: 1800px) {
	#sec_interview_list.under {
/*		margin-top: -8.8vw;*/
		margin-top: -5vw;
		padding-top: 9.34vw;
	}
}

@media screen and (max-width: 768px) {
	#sec_interview_list.under {
		margin-top: -8.8vw;
		padding-top: 23vw;
	}

	#sec_interview_list.under::before {
		height: calc(100% - 63vw);
	}

	#sec_interview_list.under .check {
		font-size: 6.13vw;
		margin-bottom: 18vw;
	}

	#sec_interview_list.under .check span {
		border-bottom: .93vw solid #0b318f;
	}

	#sec_interview_list .ttlwrap {
		margin-bottom: 6vw;
	}

	#sec_interview_list .ttlwrap .secttl {
		text-align: center;
		margin-bottom: 1.5em;
	}

	#sec_interview_list .ttlwrap .lead {
		text-align: center;
		letter-spacing: 0.1em;
	}

	#sec_mynavi + #sec_interview_list.under {
		/* padding-top: 110vw; */
		padding-top: 80vw;
	}
}

/* sec_other
--------------------------------*/
#sec_other {
	padding: 100px 0 90px;
}

#sec_other .bnrwrap .bnr {
	width: 557px;
	margin: 0 auto;
	box-shadow: 8px 8px 0 rgba(0, 0, 0, .2);
}

#sec_other .bnrwrap .bnr:nth-child(n + 3) {
	margin-top: 36px;
}

#sec_other .bnrwrap .bnr a {
	position: relative;
	display: block;
	transition: .3s ease;
}


@media screen and (min-width: 769px) {
	#sec_other .bnrwrap .bnr a::before {
		content: "";
		width: 100%;
		height: 100%;
		background-color: rgba(255, 255, 255, .15);
		position: absolute;
		left: 0;
		top: 0;
		opacity: 0;
		transition: .3s ease;
	}

	#sec_other .bnrwrap .bnr a:hover::before {
		opacity: 1;
	}

	#sec_other .bnrwrap .bnr a:hover {
		transform: translate(8px, 8px);
	}
}

@media screen and (max-width: 768px) {
	#sec_other {
		padding: 10vw 0 18vw;
		-webkit-clip-path: polygon(0 8.5vw, 100% 0%, 100% 100%, 0% 100%);
		clip-path: polygon(0 8.5vw, 100% 0%, 100% 100%, 0% 100%);
		margin-top: 16vw;
	}

	#sec_other .bnrwrap .bnr {
		width: 100%;
		box-shadow: 1.6vw 1.6vw 0 rgba(0, 0, 0, .2);
	}

	#sec_other .bnrwrap .bnr + .bnr {
		margin-top: 6.4vw;
	}
}

/* confirm-format
--------------------------------*/
.confirm-format .form .box dl dt {
	padding-top: 0;
}

.confirm-format .form .box dl.name dd p span.txt {
	display: none;
}

.confirm-format .form .box dl.name dd.flex {
	justify-content: flex-start;
}

.confirm-format .form .birthday dd p span.txt {
	margin-left: 0;
	margin-top: 0;
}

.confirm-format .form .phone dd .txt  {
	margin: 0.15em 0.5em 0;
}

/* footer
--------------------------------*/
footer {
	margin-top: 10px;
}

@media screen and (max-width: 768px) {
	footer {
		margin-top: 2vw;
	}
}
