@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 1em;
}
textarea {
	padding: .5em 1em;
}

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

/*
select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
*/
select {
	font-size:100%;
	width:100%;
	height:30px;
	border:1px solid #c5c5c5;
	border-radius: 0;
}
select.sel_y {
	width:5em;
}
select.sel_m {
	width:3em;
}
select.sel_d {
	width:3em;
}
select.sel_t {
	width:4em;
}

select.req {
	/*background-color: #fff4f4;*/
	/*border: 1px solid #ff0000;*/
}




input.req,
textarea.req {
	background-color: #feede6;
	border: 1px solid #fbbdc0;
}
input.opt,
textarea.opt {
	background-color: #f6f6f6;
	border: 1px solid #c6c6c6;
}


input.postal1,
input.postal2 {
	height: 50px;
}

input.postal1 {
	width: 70px;
}
input.postal2 {
	width: 80px;
}
input.etc {
	width: 520px;
}


input.year {
	width: 3.5em;
	text-align: right;
}
input.month {
	width: 2.5em;
	text-align: right;
}
input.day {
	width: 2.5em;
	text-align: right;
}

select.sel_m {
	width: 3.5em;
}
select.sel_d {
	width: 3.5em;
}

textarea.comment_s {
	height: 10em;
}



/* エラーメッセージ */
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;
}

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

/* 送信ボタン */
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 #1e94d4;
	background-color: #1e94d4;
	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;
/*	font-family: 'Zen Kaku Gothic New', sans-serif;*/
	/*font-family:"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;*/
}
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;
/*	font-family: 'Zen Kaku Gothic New', sans-serif;*/
	/*font-family:"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;*/
}
input.submit_submit {
	width:75%;
	clear: both;
	float: none;
	display: block;
	border:1px solid #1e94d4;
	background-color: #1e94d4;
	line-height:2.6em;
	border-radius: 30px;
	font-weight: bold;
	font-size:20px;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
/*	font-family: 'Zen Kaku Gothic New', sans-serif;*/
	/*font-family:"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;*/
}


/* 送信完了画面 */
.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: #fff;
	padding: 0.9em 2em 0.0em 3.6em;
	width: 100%;
	position: relative;
	font-weight: normal;
	border-bottom: 0px dotted #bebebd;
}
.form table th br.sbr {
	display: none;
}

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

.form table th.req:after {
	content:'必須';
	font-size: 12px;
	border: 2px solid #e3274b;
	background-color: #e3274b;
	border-radius: 0px;
	color: #fff;
	padding: 1px 5px 2px;
	position: absolute;
	right: auto;
	left: 0px;
	top: 1.0em;
	line-height: 1.2;
}
.form table th.opt:after {
	content:'任意';
	font-size: 12px;
	border: 2px solid #c6c6c6;
	background-color: #c6c6c6;
	border-radius: 0px;
	color: #fff;
	padding: 1px 5px 2px;
	position: absolute;
	right: auto;
	left: 0px;
	top: 1.0em;
	line-height: 1.2;
}
.form table td br.sbr {
	display: inline-block;
}


.form label {
	padding-left: 5px;	
}


/* その他の要素 */

.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;

}*/

.select_date span.brtf {
	display: block;
}
.select_date div {
	clear: none;
	border: 0px solid #f0f0f0;
	margin-bottom: 5px;
}


/* 要素のリスト */
.form .list_naiyo {
	clear: both;
}
.form .list_naiyo li {
	clear: both;
	float: none;
	width: auto;
	/*white-space: nowrap;*/
	border: 0px solid;
}

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

/* 共通 */
.form {
	max-width: 840px;
	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;
}


/* お問い合わせ */
#form_area .hl {
	font-size: 20px;
}

.form table th.req:after {
	top: 1.3em;
}
.form table th.opt:after {
	top: 1.3em;
}

/* 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: 1.5em 2em 1.5em 60px;
	width: 17em;
	/*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: 1.5em 2em 1.5em 0em;
	/*border-left: 2px solid #fff;*/
	width: auto;
}
.form table th.req:after {
	content:'必須';
	font-size: 15px;
	border: 2px solid #e3274b;
	background-color: #e3274b;
	border-radius: 0px;
	color: #fff;
	padding: 1px 5px 2px;
	position: absolute;
	right: auto;
	left: 0px;
	top: 2.6em;
	line-height: 1.2;
}
.form table th.req.req_s:after,
.form.confirm table th:after {
	top: 1.7em;
}
.form table th.opt:after {
	content:'任意';
	font-size: 15px;
	border: 2px solid #c6c6c6;
	background-color: #c6c6c6;
	border-radius: 0px;
	color: #fff;
	padding: 1px 5px 2px;
	position: absolute;
	right: auto;
	left: 0px;
	top: 2.4em;
	line-height: 1.2;
}
.form table th.opt.opt_s:after,
.form.confirm table th:after {
	top: 1.7em;
}


/* 送信完了画面 */
.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 */	
}

