@charset "UTF-8";
/* Form */

.form div.error {
/*	display: none;*/
}


/* フォームのリセット */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="submit"],
textarea {
	border:none;
	background:#fff;
	-webkit-appearance:none;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"],
textarea {
	border:1px solid #bcbcbc;
	border-radius:.5em;
	vertical-align:middle;
	font-size:100%;
	width:100%;
/*	font-family: 'Noto Sans JP', sans-serif;*/
/*font-family: inherit;*/
}
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"] {
	height: 35px;
	padding: 0 1em;

	font-size: 16px;
}
textarea {
	padding: .5em 1em;

	font-size: 16px;
}
input, select, button, textarea {
	font-family: inherit;
 }

::placeholder{
  color:#a3a3a3;
}


textarea.comment_s {
	height: 7em;
}

select {
	font-size:100%;
	width:100%;
	height:35px;
	border:1px solid #bcbcbc;
	border-radius:.5em;
	max-width: 400px;
	padding: 0 .6em;
}

input[type=checkbox] {
 	accent-color: #41956a;
 	inline-size: 1.2rem;
 	block-size: 1.2rem;
	display: inline-block;
	border: 1px solid blue;
	vertical-align: 3px;
}

input[type=radio] {
 	accent-color: #3090eb;
 	inline-size: 1.2rem;
 	block-size: 1.2rem;
	display: inline-block;
	border: 1px solid blue;
	vertical-align: 3px;
}

.form input.postal {
	width: 10em;
}

.form .flx {
	align-items: flex-start;
}
.form .flx div.lside input {
	position: relative;
	top: -.3em;
/*	border: 1px solid #000;*/
}
.form .flx div {
	/*height: 3em;
	border: 1px solid blue;*/
}
.form .msgCheck {
/*	padding-top: 1em;*/
/*	border: 1px solid #000;*/
}

.form label {
	padding-left: .8em;	
	padding-bottom: 1em;
	position: relative;
	top: -.4em;
}






/* エラーメッセージ */
.form  #error_message {
	display: block;
	color: #ff0000;
	margin-bottom: 10px;
}
.form  #error_message::before {
	content:url(../img/form/icon_error.png);
	padding-right:3px;
}
.form div.error {
/*	display: block;*/
	color: #ff0000;
/*	margin-top: 6px;*/
}
.form div.error::before {
	content:url(../img/form/icon_error.png);
	padding-right:3px;
}

.form label.error {
	display: block;
	color: #ff31c3;
	padding-top: .8em;
	padding-left: 0;
}
.form label.error::before {
	content:url(../img/form/icon_error.png);
	padding-right:3px;
}

.form .inp_ad {
	line-height: 2;
}

/* 送信ボタン */
input[type="submit"] {
/*	border:1px solid #000;*/
	line-height:3em;
	width:100%;
	border-radius:10px;
	font-size: 18px;
	cursor:pointer;
/*	border: 1px solid #000;*/
}

#btn_confirm {
	width: auto;
	margin: 0px auto 0px;
/*	border: 1px solid;*/
}

#btn_submit {
	width: auto;
	margin: 30px auto 30px;
	border: 0px solid;
}

input.submit_confirm {
	display: block;
	border:1px solid #3090eb;
	background-color: #3090eb;
	line-height:2.6em;
	width:100%;
	font-size: 16px;
	border-radius: .8em;
	font-weight: bold;
	cursor:pointer;
	margin: 10px auto 10px;
	color: #fff;
	-webkit-appearance:none;
}
input.submit_confirm:disabled {
	background-color: #aaa;
	border:1px solid #aaa;
	cursor:not-allowed;
}

input.submit_confirm.offSubmit {
	background-color: #aaa;
	border:1px solid #aaa;
	cursor:not-allowed;
}


input.submit_back {
	width:75%;
	clear: both;
	float: none;
	display: block;
	border:1px solid #a6a7a4;
	background-color: #a6a7a4;
	line-height:2.6em;
	border-radius: .8em;
	font-weight: bold;
	font-size:20px;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
}
input.submit_submit {
	width:75%;
	clear: both;
	float: none;
	display: block;
	border:1px solid #3090eb;
	background-color: #3090eb;
	line-height:2.6em;
	border-radius: .8em;
	font-weight: bold;
	font-size:20px;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
}


/* 送信完了画面 */
.form #msg_thanx {
	font-size: 22px;
	/*color: #816c38;*/
	text-align: center;
	position: relative;
}
.form #msg_thanx br {
	display: inline-block;
}
.form #msg_thanx:after {
	content: '';
	border-top: 1px solid #816c38;
	width: 100%;

	position: absolute;
	left: 0;
	bottom: -4px;
}

.form #msg_complete {
	text-align: center;
	margin: 30px 0 80px;
	line-height: 2.4;
}
.form #msg_complete #completed {
	font-size: 17px;
	font-weight: bold;
	color: #088eff;
	position: relative;
	line-height: 1.4;
}
.form #msg_complete p {
	line-height: 1.7;
	text-align: left;
}
.form #msg_complete p span.br {
	display: block;
}

.form #msg_complete .enc {
	display: table;
	margin-left: auto;
	margin-right: auto;
}
.form #msg_complete .enc div {
	display: table-cell;
	vertical-align: middle;
	line-height: 1;
}
.form #msg_complete .enc div.icn {
	width: 20px;
	padding-top: 5px;
}
.form #msg_complete .enc div.num {
	font-size: 24px;
	font-weight: bold;
	padding-left: .3em;
}
.form #msg_complete .enc div.num a {
	color: #000;
	text-decoration: none;
}

#form_area.thanks {
	background-color: #fff;
	
}











/* フォームのテーブル */
.form table {
	border-collapse:collapse;
	box-sizing: border-box;
	width: 100%;
}
.form table tr {
	display: table-row;
}
.form table th,
.form table td {
	box-sizing: border-box;
	display: block;
}
.form table th {
/*	background-color: #fff;*/
	font-size: 15px;
	padding: 0em 2em 0em 0em;
	width: 100%;
	position: relative;
	font-weight: block;
	border-bottom: 0px dotted #bebebd;
}
.form table th.req {
	padding: 0em 2em 0.0em 4.4em;
}

.form table th br.sbr {
	display: none;
}
.form table th span.caution {
	font-size: 93.8%;
	font-weight: normal;
}
.form .caution2 {
	font-size: 87.5%;
	font-weight: normal;
}

.form table td {
/*	background-color: #fff;*/
	padding: 0.3em 1em 0.3em 0em;
	/*border-left: 0px solid #fff;*/
	width: 100%;
/*	border-bottom: 1px dotted #bebebd;*/
}

.form table th span.req {
	display: inline-block;
	font-size: 12px;
	line-height: 1;
	color: #fff;
	background-color: #ff174e;
	padding: .3em .6em;
	margin-inline-start: .6em;
}

#pageSecond .form table td {
	padding: 0.3em 1em 1.3em 0em;
}




/* その他の要素 */

.form .msg_req {
	padding: 10px 0;
}


/* 要素のリスト */
.form ul.list_check li {
	margin-bottom: 1.2em;
}
.form ul.list_check li div {
	display: table;
}
.form ul.list_check li div span {
	display: table-cell;
	vertical-align: top;
	border: 0px solid #000;
}
.form ul.list_check li div span.chk {
	width: 1.9em;
}
.form ul.list_check li div span label {
	padding-left: 0;
}

/* 共通 */
.form {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.form .msg_top {
	text-align: left;
	margin-top: 1em;
}
.form .msg_last {
	text-align: left;
}


.form .sel_type .fcol {
	/*font-size: 14px;
	font-weight: bold;	*/
}
.form .sel_type .fcol:nth-of-type(1) {
	margin-bottom: .5em;
}
.form .sel_type .fcol:nth-of-type(2) {
	margin-bottom: .5em;
}
.form .sel_type .fcol:nth-of-type(3) {
	margin-bottom: .5em;
}
.form .sel_type .fcol:nth-of-type(4) {
	margin-bottom: .5em;
}.form .sel_type .fcol:nth-of-type(5) {
	margin-bottom: .5em;
}.form .sel_type .fcol:nth-of-type(6) {
	margin-bottom: 0em;
}



.form #check_agree {
	text-align: center;
}
.form #check_agree a {
	text-decoration: underline;
}


















@media handheld, print, screen and (min-width: 375px) {
/* iphone6 */

.form table td br.sbr {
	display: none;
}

/* end of media query(iphone6) */	
}








@media handheld, only screen and (min-width: 480px) {

.select_date span.brtf  {
	display: inline;
}	

/*textarea.comment_s {
	height: 16em;
}*/

/* 送信ボタン */
.form #btn_submit {
	width: 12em;
	font-size:30px;
	margin: 30px auto 30px;
}

input.submit_confirm {
	line-height:2.3em;
	width:100%;
	font-size:18px;
	margin: 30px auto 30px;
}

input.submit_back {
	width: 6em;
	font-size: 20px;
	clear: none;
	float: left;
}
input.submit_submit {
	width:8em;
	font-size: 20px;
	clear: none;
	float: right;
}

/* 送信完了画面 */
.form #msg_complete {
	text-align: center;
	margin: 100px 0 80px;
	line-height: 2.4;
}
.form #msg_complete #completed {
	font-size: 22px;
	position: relative;
}
.form #msg_complete p {
	line-height: 1.7;
}



/* 送信完了画面 */
.form #msg_thanx {
	font-size: 28px;
}
.form #msg_thanx br {
	display: none;
}

.form #msg_complete p span.br {
	display: inline;
}

/* 要素のリスト */
.form ul.list_check li {
	margin-bottom: .9em;
}
.form ul.list_check li div span.chk {
	width: 1.7em;
}

/* フォームのテーブル */
.form table th {
/*	font-size: 15px;*/
}

.form .sel_type .fcol {
/*	font-size: 15px;*/
}


/* end of media query */
}










@media handheld, print, screen and (min-width: 620px) {
/* iPad */

/* お問い合わせ */
/* 送信完了画面 */
.form #msg_thanx {
	font-size: 32px;
}
.form #msg_complete p {
	text-align: center;
}

/* フォームのテーブル */
.form table th {
/*	font-size: 16px;*/
}

.form .sel_type .fcol {
/*	font-size: 16px;*/
}

/* end of media query */	
}






@media handheld, only screen and (min-width: 834px) {

/* 送信ボタン */
.form #btn_submit {
	width: 14em;
	margin: 30px auto 30px;
	border: 0px solid;
}

input.submit_confirm {
	line-height:2.8em;
	width:100%;
	font-size:18px;
	margin: 10px auto 0px;
}

input.submit_back {
	width: 10em;
	font-size:18px;
	clear: none;
	float: left;
}
input.submit_submit {
	width:10em;
	font-size:18px;
	clear: none;
	float: right;
}


/* フォームのテーブル */
.form table th {
/*	font-size: 18px;*/
}


/* 送信完了画面 */
.form #msg_thanx {
	font-size: 36px;
}
.form #msg_complete #completed {
	font-size: 26px;
}


/* 要素のリスト */
.form .list_naiyo {
	clear: none;
}
.form .list_naiyo li {
	clear: none;
	float: left;
	width: 19em;
	white-space: nowrap;
}

.form .msg_top {
	text-align: center;
}
.form .msg_last {
	text-align: center;
}

.form .sel_type .fcol {
	font-size: 18px;
}

/* end of media query */	
}

@media handheld, only screen and (min-width: 1040px) {


.form .sel_type .fcol:nth-of-type(1) {
	margin-bottom: 1em;
}
.form .sel_type .fcol:nth-of-type(2) {
	margin-bottom: 1em;
}
.form .sel_type .fcol:nth-of-type(3) {
	margin-bottom: 1em;
}
.form .sel_type .fcol:nth-of-type(4) {
	margin-bottom: 0em;
}.form .sel_type .fcol:nth-of-type(5) {
	margin-bottom: 0em;
}.form .sel_type .fcol:nth-of-type(6) {
	margin-bottom: 0em;
}


/* end of media query */	
}

