@charset "UTF-8";

main p {
	margin-bottom: 1rem;
}

.btns {
	margin: 2em 0;
}

.input_wrap,
.radio_wrap,
.select_wrap,
.date_wrap {
	margin: 1em auto 1.75em auto;
}

.input_wrap label,
.select_wrap label:nth-of-type(1) {
	top: -0.5em;
	left: 1em;
	width: auto;
	padding: 0 0.25em;
	background: var(--color-white);
	font-size: 80%;
}

/* resume */
main.resume .btns {
	margin-top: 5em;
} 

/* top */
main.register .img {
	margin-top: 1em;
}

main.register .img img {
	width: 6rem;
}

main.register h3 {
	margin: 2.5rem auto;
	font-size: 150%;
	text-align: left;
}

main.register .input_wrap a.showPasswd {
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0.5em;
	width: 1em;
	height: 1em;
	margin: auto;
	font-size: 1.25em;
	color: var(--color-primary);
	line-height: 1;
}

main.register .input_wrap a.showPasswd:after {
	content: "\f06e";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	font-family: "Font Awesome 7 Free";
	font-weight: 900;
}
main.register .input_wrap.open a.showPasswd:after {
	content: "\f070";
}

main.register .agree_wrap .errMsg {
	margin-top: 0.5em;
	font-size: 60%;
}

main.register h4 {
	margin-bottom: 0.5em;
	font-size: 80%;
	line-height: 1em;
	color: var(--color-primary);
	font-weight: bold;
}

main.register .radio_wrap {
	margin-top: -0.75em;
}

main.register .radio_wrap #gender-1:checked + label {
	background: linear-gradient(89.72deg, #2059EC -1.16%, #679BFF 99.76%);
	color: var(--color-white);
	border-color: transparent;
}
main.register .radio_wrap #gender-2:checked + label {
    background: linear-gradient(90deg, #FF4646 0%, #FF8181 105.63%);
    color: var(--color-white);
	border-color: transparent;
}

main.register .radio_wrap label:before,
main.register .radio_wrap label:after {
	display: none;
}

main.register .agree_wrap {
	color: var(--color-secondary);
	text-align: center;
}

main.register .agree_wrap ul {
	display: inline-block;
	font-size: 80%;
	text-align: left;
	line-height: 2;
}

main.register .agree_wrap .checkbox_wrap input[type="checkbox"] + label::before {
	color: var(--color-key);
}

/* mailsent */

main.mailsent small .description {
	font-size: 85%;
}

main.mailsent .bar {
	position: relative;
	width: 13.5em;
	margin: 4em auto 2em auto;
	padding: 0.75em 0;
	text-align: center;
	background-color: var(--color-grayLight);
}

main.mailsent .btns .btn3 {
	margin-top: 1em;
}

/* intro1, intro2 */
main.intro {
	position: relative;
	padding: 0;
	height: 100vh;
/*	background: linear-gradient(349.37deg, #FFDEDE 2.69%, #FFE0C9 28.46%, #FFEBE2 56.89%, #FFFAFA 97.65%);*/
}

main.intro form {
	width: 100%;
	max-width: 100%;
	height: 100%;
}

main.intro .intro_list li {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: none;
}

main.intro .intro_list li.active {
	display: block;
}

main.intro .intro_list li:first-child {
	background: linear-gradient(101.01deg, rgba(252, 118, 109, 0.4) 3.46%, rgba(93, 116, 205, 0.4) 51.72%, rgba(0, 200, 207, 0.4) 99.03%);
}
main.intro .intro_list li:nth-child(2) {
	background: linear-gradient(40.7deg, rgba(252, 118, 109, 0.5) 5.29%, rgba(93, 116, 205, 0.5) 37.05%, rgba(0, 200, 207, 0.5) 68.18%);
}
main.intro .intro_list li:last-child {
	background: linear-gradient(155.2deg, rgba(252, 118, 109, 0.5) 14.21%, rgba(93, 116, 205, 0.5) 44.57%, rgba(0, 200, 207, 0.5) 74.32%);
	font-size: 80%;
}

main.intro .intro_list a {
	display: flex;
	width: 100%;
	height: 100%;
	padding: 1px;
	text-align: center;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	font-size: 125%;
	color: var(--color-white);
	font-weight: bold;
	text-decoration: none;
}

main.intro .intro_list a > * {
	max-width: 90%;
}

main.intro .intro_list h3 {
	margin: 0 0 1.5rem 0;
	font-size: 200%;
}

main.intro .intro_list h4 {
	margin: 0 0 1.5rem 0;
	font-size: 150%;
}

main.intro .intro_list img {
	max-width: 50%;
}

/* step3 */
main.step3 .input_wrap {
	margin-top: 2em;
}

main.step3 .area_wrap {
	position: relative;
	padding: 1em;
	color: var(--color-key);
	border: 1px solid var(--color-line);
	border-radius: 0.5em;
}

main.step3 .area_wrap > label {
	position: absolute;
	top: -0.5em;
	left: 1em;
	width: auto;
	padding: 0 0.25em;
	background: var(--color-white);
	font-size: 80%;
	line-height: 1em;
	color: var(--color-primary);
	font-weight: bold;
}

main.step3 .area_wrap > label .must {
	color: var(--color-key);
}

main.step3 .area_wrap ul label {
	padding: 1em;
	border-color: var(--color-primary);
	font-family: 'Roboto', sans-serif;
	font-weight: 600;
	color: var(--color-primary);
}

main.step3 .area_wrap ul input[type="checkbox"]:checked + label {
	border-color: var(--color-key);
}

/* step4 */
main.step4 .errMsg {
	font-size: 80%;
	margin-bottom: 1em;
}

/* step6 */
main.step6 .description {
	margin-top: 1em;
}

main.step6 h4 {
	display: block;
	max-width: 100%;
	margin: 1em auto 2em auto;
	font-size: 90%;
	text-align: left;
	color: var(--color-secondary);
	text-decoration: none;
	box-sizing: border-box;
}

main.step6 h4 .no {
	display: inline-block;
	width: 1.5rem;
	height: 1.5rem;
	margin-right: 0.5em;
	background: var(--color-key);
	border-radius: 50%;
	color: var(--color-white);
	line-height: calc(1.5rem - 2px);
	text-align: center;
}

main.step6 .textarea_wrap label {
	font-size: 80%;
}

main.step6 .input_wrap:after {
	content: "";
	display: block;
	clear: both;
}

main.step6 .input_name:before {
	content: "";
	display: block;
	position: absolute;
	bottom: -1px;
	left: 0;
	right: 0;
	width: 3px;
	height: 3px;
	margin: auto;
	background: var(--color-white);
	z-index: 1;
}

main.step6 input[name=rname1],
main.step6 input[name=rname2] {
	float: left;
	width: 50%;
	box-sizing: border-box;
}

main.step6 .reject textarea {
	height: 1px;
	border: 0;
	border-bottom: 1px solid var(--color-key);
	border-radius: 0;
	color: var(--color-gray);
}

main.step6 .reject label {
	color: var(--color-key);
	opacity: 1;
}

main.step6 .certificates {
	margin-top: -1.5em;
	margin-bottom: 1em;
}

/* payment */

main.payment h3 {
	width: 100%;
	margin-top: 0;
}

main.payment ul {
	margin-bottom: 1em;
}

main.payment li {
	margin-left: 1em;
	list-style: disc;
}

main.payment li.disabledByCampaign a {
	position: relative;
	pointer-events: none;
	cursor: default;
	overflow: hidden;
}

main.payment li.disabledByCampaign a:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.75);
	z-index: 1;
}

main.payment li.disabledByCampaign a:after {
	content: "※こちらは選択できません";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1.5em;
	line-height: 1.5;
	color: var(--color-white);
	text-align: center;
	z-index: 1;
}

main.payment li.disabledByCampaign .point {
	display: none;
}

main.payment p.img img {
	border-radius: 0.5em;
}

main.payment .description {
	margin: 2em 0;
	font-size: 70%;
	text-align: left;
	line-height: 1.35;
}

main.payment .description h4,
main.payment .description p {
	margin-bottom: 0.75rem;
}

main.payment .description img {
	vertical-align: middle;
}

main.payment .paidy .input_wrap {
	margin-top: 1.5em;
	margin-bottom: 1.5em;
}
