@charset "utf-8";

/* -------------------------------------------------- */
/* PC*/
/* -------------------------------------------------- */

/* フォームのcssリセット */
input,
button,
textarea,
select {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	/*
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
	*/
}

input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
	width: 100%;
	padding: 20px;
	margin-top: 15px;
	outline: none;
	border: 1px solid #aaa;
	font-size: 2rem;
	border-radius: 5px;
	-webkit-transition: all .3s;
	transition: all .3s;
	color: #000;
	font-family: inherit;
	-webkit-appearance: none;
	line-height: 1.4;
}

input[type="text"]:focus,
textarea:focus {
	box-shadow: 0 0 7px #aaa;
	border: 1px solid #aaa;
}

input:placeholder,
textarea:placeholder {
	color: #878787;
	letter-spacing: .1em;
	font-family: inherit;
}

.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="date"] {
	width: 100%;
	padding: 20px;
	outline: none;
	border: 1px solid #aaa;
	font-size: 2rem;
	border-radius: 5px;
	-webkit-transition: all .3s;
	transition: all .3s;
	color: #000;
	font-family: inherit;
}

#formBox .wpcf7-not-valid-tip {
	padding-top: 15px;
	font-size: 1.4rem;
	color: #B10418;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output {
	margin: 2em 0 1em;
	color: #B10418;
	border-color: #B10418 !important;
	text-align: center;
}

.wpcf7 form.sent .wpcf7-response-output {
	margin: 2em 0 1em;
	text-align: center;
	border-color: #FDD437 !important;
}

#select45txt {
	display: block;
	padding-bottom: 15px;
	margin-bottom: 15px;
	border-bottom: 1px solid #aaaaaa;
}

.pc.calendar {
	padding-left: 10px;
	display: inline !important;
	font-size: 1.4rem;
	vertical-align: middle;
}

/* Chrome */
:-webkit-input-placeholder,
:-webkit-textarea-placeholder {
	color: #878787;
	letter-spacing: .1em;
	font-family: inherit;
}

/* Firefox */
:-moz-placeholder,
:-moz-textarea {
	color: #878787;
	letter-spacing: .1em;
	font-family: inherit;
}

/* IE */
:-ms-input-placeholder,
:-ms-textarea-placeholder {
	color: #878787;
	letter-spacing: .1em;
	font-family: inherit;
}

#form {}


#formTxt {
	padding-bottom: 50px;
	text-align: center;
	font-size: 1.8rem;
	line-height: 1.77;
}

#formBox {
	margin-bottom: 150px;
	padding: 60px 0;
	border: 1px solid #000000;
}

#formList {
	width: 66.6%;
	margin: 0 auto;
}

#formList label {
	vertical-align: middle;
	line-height: 1;
	font-size: 2rem;
}

#formList .mandatory {
	margin-left: 10px;
	padding: 2px 5px;
	border-radius: 3px;
	font-size: 1.2rem;
	line-height: 1;
	vertical-align: middle;
	color: #FFFFFF;
	background: #C51919;
}

.wpcf7-form-control-wrap {
	display: block;
}

.select45 .wpcf7-form-control-wrap.your-sex-child {
	display: block;
}

#formList p {
	padding-bottom: 40px;
}

.alart {
	padding-top: 15px;
	display: block;
	font-size: 1.4rem;
	color: #B10418;
}

select {
	width: 100%;
	margin-top: 15px;
	padding: 20px;
	border-radius: 5px;
	border: 1px solid #aaa;
}

#age1,
#age2 {
	width: 80px;
}

#age1 {
	margin: 0 10px 0 25px;
}

#age2 {
	margin-right: 10px;
}

#or {
	padding: 0 25px;
}

#select45 .wpcf7-list-item {
	position: relative;
	padding-left: 45px;
}

.select45 .wpcf7-form-control-wrap {
	display: inline;
}

#select45 {
	margin: -40px 0 30px;
}

#select45sex {
	padding-bottom: 70px;
}

#plus {
	margin-bottom: 50px;
	position: relative;
}

#plus:before {
	content: '';
	width: 22px;
	height: 22px;
	display: inline-block;
	background: url(../../img/contact/form_plus_icon_pc.png) no-repeat center;
	background-size: contain;
	-webkit-background-size: contain;
	position: absolute;
	bottom: -45px;
	left: 0;
}

.formTit {
	padding-bottom: 10px;
	display: inline-block;
	font-size: 1.6rem;
	font-weight: bold;
}

input[type=radio] {
	display: none;
}

input[type=radio] + span {
	padding-left: 30px;
	margin-bottom: 10px;
	position: relative;
	cursor: pointer;
	font-size: 1.6rem;
	display: inline-block;
}

input[type="radio"]:checked + span:before {
	content: "";
	display: block;
	width: 15px;
	height: 15px;
	position: absolute;
	top: 50%;
	left: 5px;
	background: #0F77E2;
	border-radius: 15px;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

input[type="radio"] + span:after {
	content: "";
	display: block;
	width: 21px;
	height: 21px;
	position: absolute;
	top: 50%;
	left: 0;
	border: 2px solid #999;
	border-radius: 15px;
	cursor: pointer;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

input[type="checkbox"] {
	-webkit-appearance: normal;
	-moz-appearance: normal;
	appearance: normal;
}

.radioBtn {
	display: inline-block;
}


p#formPlus {
	padding-bottom: 50px;
	margin-bottom: 10px;
	background: url(../../img/contact/form_plus_icon_pc.png) no-repeat 0 bottom;
}

.calendar {
	padding-left: 1em;
}

.anno {
	padding-top: 5px;
	font-size: 1.2rem;
	line-height: 1.4;
	display: inline-block;
}

/* ラジオボタン装飾 */
/* -------------------------------------------------- */
/* labelタグに包まれていないため装飾不可 */

/* チェックボックス装飾 */
/* -------------------------------------------------- */
#time1 input,
#time2 input {
	display: none;
}

#time1 .mwform-checkbox-field-text,
#time2 .mwform-checkbox-field-text {
	padding-left: 30px;
	margin-right: 20px;
	margin-bottom: 10px;
	font-size: 1.8rem;
	position: relative;
	display: inline-block;
}

#time1 .mwform-checkbox-field-text:before,
#time2 .mwform-checkbox-field-text:before {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 0;
	width: 18px;
	height: 18px;
	border: 2px solid #999;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

#time1 input:checked + .mwform-checkbox-field-text,
#time2 input:checked + .mwform-checkbox-field-text {
	/* color: #d01137; */
}

#time1 input:checked + .mwform-checkbox-field-text:after,
#time2 input:checked + .mwform-checkbox-field-text:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 4px;
	width: 14px;
	height: 14px;
	background: #0F77E2;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

#time1 .wpcf7-list-item,
#time2 .wpcf7-list-item {
	padding-bottom: 10px;
}








/* プライバシーポリシー */
/* -------------------------------------------------- */
#ppWrap {
	margin-bottom: 60px;
	padding: 30px 25px;
	background: #EEEEEE;
}

#pp {
	width: 100%;
	height: 160px;
	position: relative;

}

#pp .ppTxt {
	padding-right: 50px;
	padding-bottom: 1em;
	font-size: 1.4rem;
}

.ppTxtLarge {
	padding-right: 50px;
	font-size: 1.8rem;
	font-weight: 700;
}

#pp .ps__rail-x,
.ps__rail-y {
	opacity: 1 !important;
}

#pp .ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
	width: 3px !important;
	background: #c9c9c9 !important;
	right: 0px !important;
}

.ps__thumb-y {
	width: 3px !important;
	background: #434343 !important;
	right: 0 !important;
}



/* 送信ボタン */
/* -------------------------------------------------- */
#submitBtn {
	width: 470px;
	margin: 0 auto;
	padding-bottom: 0 !important;
	letter-spacing: -.4em;
	text-align: center;
	position: relative;
}

#submitBtn input[type="submit"] {
	width: 100%;
	padding: 55px 0 25px;
	position: relative;
	border-radius: 4px;
	font-size: 2.6rem;
	line-height: 1;
	color: #fdd437;
	background: url(../../img/contact/contact_arrow.svg) no-repeat right 30px center #434343;
	transition: all 0.3s ease-in-out 0s;
	font-family: inherit;
	display: block;
	cursor: pointer;
}

#submitBtn:before {
	content: 'プライバシーポリシーに同意の上';
	display: inline-block;
	width: 100%;
	height: auto;
	font-size: 1.8rem;
	line-height: 1;
	letter-spacing: 0;
	color: #fdd437;
	position: absolute;
	top: 27px;
	left: 0;
	z-index: 1;
	transition: all 0.3s ease-in-out 0s;
	font-family: inherit;
	pointer-events:none;
}

/* -------------------------------------------------- */
/* mouse on 1024px以上 */
/* -------------------------------------------------- */
@media screen and (min-width: 1024px) {
	#submitBtn:hover input[type="submit"] {
		color: #434343;
		background: url(../../img/contact/contact_arrow_on.svg) no-repeat right 30px center #fdd437;
	}

	#submitBtn:hover:before {
		color: #434343;
	}

}

/* -------------------------------------------------- */
/* PC 1260px ~ 1024px */
/* -------------------------------------------------- */
@media screen and (min-width: 1024px) and (max-width: 1260px) {
	#formList {
		width: 80%;
	}





}


/* -------------------------------------------------- */
/* TAB */
/* -------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {
	#formTxt {
		width: 92%;
		margin: 0 auto;
		text-align: left;
		font-size: 1.4rem;
	}

	#formBox {
		padding: 30px;
	}

	#formList {
		width: 100%;
	}

	#formList label {
		font-size: 1.8rem;
	}

	input[type="text"],
	input[type="tel"],
	input[type="email"],
	textarea {
		padding: 10px;
		font-size: 1.6rem;
	}

	select {
		color: #333;
		padding: 10px;
		margin-top: 0px;
	}

	#ppWrap {
		padding: 15px;
	}

	#pp .ppTxt {
		padding-right: 20px;
	}

	.block {
		display: block;
	}

	#submitBtn {
		width: 100%;
	}

	#submitBtn:before {
		font-size: 1.4rem;
	}

	#submitBtn input[type="submit"] {
		padding: 50px 0 25px;
		font-size: 2.2rem;
		background: url(../../img/contact/contact_arrow.svg) no-repeat right 15px center #434343;
	}

	.calendar {
		padding-left: 1em;
	}

	#plus:before {
		background: url(../../img/contact/form_plus_icon_sp.png) no-repeat center;
		background-size: contain;
		-webkit-background-size: contain;
	}

}

/* -------------------------------------------------- */
/* SP */
/* -------------------------------------------------- */
@media screen and (max-width: 767px) {
	#formTxt {
		width: 92%;
		margin: 0 auto;
		text-align: left;
		font-size: 1.4rem;
	}

	#formBox {
		padding: 20px;
	}

	#formList {
		width: 100%;
	}

	#formList label {
		font-size: 1.8rem;
	}

	input[type="text"],
	input[type="tel"],
	input[type="email"],
	textarea {
		margin-top: 0;
		padding: 10px;
		font-size: 1.5rem;
	}

	select {
		padding: 10px;
		margin: 0;
		color: #333;
	}

	#ppWrap {
		padding: 15px;
	}

	#pp .ppTxt {
		padding-right: 20px;
	}

	.block {
		display: block;
	}

	#submitBtn {
		width: 100%;
	}

	#submitBtn:before {
		font-size: 1.4rem;
	}

	#submitBtn input[type="submit"] {
		padding: 50px 0 25px;
		font-size: 2.2rem;
		background: url(../../img/contact/contact_arrow.svg) no-repeat right 15px center #434343;
	}

	.pc.calendar {
		display: none !important;
	}

	.wpcf7 input[type="url"],
	.wpcf7 input[type="email"],
	.wpcf7 input[type="tel"],
	.wpcf7 input[type="date"] {
		padding: 10px;
	}

	.wpcf7 input[type="date"] {
		min-height: 55px;
	}

	#plus:before {
		background: url(../../img/contact/form_plus_icon_sp.png) no-repeat center;
		background-size: contain;
		-webkit-background-size: contain;
	}

	#age1 {
		margin: 0 5px 0 0;
	}
	#age2 {
		margin: 0 5px 0 0;
	}
	#or {
		padding: 0px 10px;
	}
	
	.calendar {
		display: block;
		line-height: 1.2;
		padding-left: 0;
		font-size: 1.1rem;
		font-weight: bold;
	}

}

/* 210428追記 */
.sent p,
.sent #ppWrap,
.sent .select45,
.sent #plus,
.sent #submitBtn{
	display: none!important;
}

#topReturn {
	display: none;
}

#topReturn a {
	padding-left: 20px;
	background: url(../../img/top/event_arrow_prev_pc.png) 0 center no-repeat;
	transition: all 0.3s ease-in-out 0s;
}

#topReturn a:hover {
	color: #FDD437;
}

.sent #topReturn {
	display: block;
}
	
.wpcf7-response-output {
	padding: 20px!important;
	background: #FDD437;
	font-weight: bold;
	font-weight: 2rem;
}


/*221118*/
span.mwform-checkbox-field {
	display: inline-block;
	margin: 0 1em 0 0!important;
}

.error {
	padding-top: 10px;
}

.caution {
	color: #C51919;
	font-weight: bold;
}

#select45 .formTit {
	display: block;
}

.ppTxtLarge {
	font-size: 1.6rem;
}

.mw_wp_form .horizontal-item + .horizontal-item {
	margin-left: 0px!important;
	margin-right: 10px;
}