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

/* フォームのリセット */
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 #c5c5c5;
/*	vertical-align:middle;*/
	font-size:100%;
	width:100%;
}
input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"] {
	height: 50px;
	padding: 0 .6em;
	border-radius: .3em;
}
textarea {
	border-radius: .3em;
/*	padding: .5em 1em;*/
}

input[type=checkbox] {
 	accent-color: #e71875;
 	inline-size: 1.5rem;
 	block-size: 1.5rem;

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

textarea.comment_s {
	height: 10em;
	padding: 0 .6em;
}



/* エラーメッセージ */
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 .error {
	display: block;
	color: #ff0000;
	margin-top: 6px;
}
.form .error::before {
	content:url(../img/form/icon_error.png);
	padding-right:3px;
}


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

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



input.submit_confirm {
	display: block;
	border:1px solid #3896ef;
	background-color: #3896ef;
	line-height:2.6em;
	width:12em;
	font-size: 20px;
	border-radius: 30px;
	font-weight: bold;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
}
input.submit_confirm:disabled {
	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: 30px;
	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 #3896ef;
	background-color: #3896ef;
	line-height:2.6em;
	border-radius: 30px;
	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: 18px;
	font-weight: bold;
	color: #1e94d4;
	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 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: #fafafa;*/
	padding: 0 0 0.3em 0;
	width: 100%;
	position: relative;
	font-weight: bold;
	border-bottom: 0px dotted #bebebd;
}
.form table th span.req {
	color: #e71875;
	font-size: 18px;
}
.form table th br.sbr {
	display: none;
}

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

.form table td br.sbr {
	display: inline-block;
}





/* その他の要素 */

.form .msg_req {
	padding: 10px 0;
}
/* 必須 */
/*.form .msg_req span {
	display: inline-block;
	font-size: 13px;
	font-weight: bold;
	border: 2px solid #d6644d;
	background-color: #d6644d;
	border-radius: 5px;
	color: #fff;
	padding: 2px 5px 2px;
	margin-right: 4px;
	line-height: 1.2;

}*/


/* 要素のリスト */
.form .flist {
	line-height: 2.4;
}

.memo_potal {
	clear: none;
	font-size: 13px;
}

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

.form .caution {
	font-size: 13px;
}

.form .sel_type .fcol {
	margin-bottom: .8em;
}


.form tr#sel_date {
	/*display: none;*/
	display: table-row;
}








@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:13em;
	font-size:20px;
	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: 50px 0 80px;
	line-height: 2.4;
}
.form #msg_complete #completed {
	font-size: 26px;
	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;
}




/* 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 .sel_type .fcol {
	margin-bottom: 0;
}

/* 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:14em;
	font-size:20px;
	margin: 30px auto 30px;
}

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


/* フォームのテーブル */
.form table {
	display: table;
}
.form table tr {
	display: table-row;
}
.form table th,
.form table td {
	display: table-cell;
}

.form table th {
	padding: 0 2em 1.5em 0;
	width: 11em;
	/*z-index: -1;*/
/*	border-bottom: 1px dotted #bebebd;*/
}
/*.form table th span {
	display: inline-block;
	position: relative;
	top: .8em;
}*/
/*.form.confirm table th span {
	top: 0em;
}*/
.form table th br.sbr {
	display: inline-block;
}
.form table td {
	padding: 0 2em 1.5em 0em;
	/*border-left: 2px solid #fff;*/
	width: auto;
}



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


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


/* end of media query */	
}

