@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 #e1e6ee;
	background-color: #f1f3f5;
	border-radius: 5px;
	vertical-align:middle;
	font-size:16px;
	width:100%;
	padding: 0.4em 0.6em;
}

input[type="checkbox"] {
	-webkit-transform: scale(2.0, 2.0);
	transform: scale(2.0, 2.0);
	border:1px solid #e1e6ee;
}


.checkbox1 .checkbox-input{
	display: none;
}
.checkbox1 .checkbox-parts{
	padding-left: 40px;
	position:relative;
	margin-right: 20px;
	border: 0px solid blue;
}
.checkbox1 .checkbox-parts::before{
	content: "";
	display: block;
	position: absolute;
	top: -7px;
	left: 0;
	width: 25px;
	height: 25px;
	border: 2px solid #bfbfbf;
	border-radius: 0px;
}
.checkbox1 .checkbox-input:checked + .checkbox-parts{
	/*color: #d01137;*/	
}
.checkbox1 .checkbox-parts::after{
	content: "";
	display: block;
	position: absolute;
	top: -14px;
	left: 10px;
	width: 12px;
	height: 22px;
	transform: rotate(40deg);
	border-bottom: 7px solid #37b3ce;
	border-right: 7px solid #37b3ce;
	transition: all 300ms 0s ease;
	opacity: 0;
}
.checkbox1 .checkbox-input:checked + .checkbox-parts::after{
	opacity: 1;
}
.checkbox1 .cbox {
	height: 26px;
	line-height: 1.2;
	font-feature-settings: "palt";
	letter-spacing: .00em;
	margin-top: 10px;
	margin-bottom: 0px;
	border: 0px solid red;
}







/*
select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
*/

select {
	font-size:115%;
	width:100%;
	height:30px;
	border:1px solid #c5c5c5;
}
select.sel_y {
	width:5em;
}
select.sel_m {
	width:3em;
}
select.sel_d {
	width:3em;
}
select.sel_t {
	width:4em;
}
/*ホームページ無料診断select  */
select.select_diagnose {
	width: 10em;
}


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





input[type="text"],
input[type="password"],
input[type="email"],
input[type="tel"],
input[type="number"] {
	height:45px;
}


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

	display: block;
}
.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_confirm {
	width: auto;
	margin: 50px auto 30px;
	border: 0px solid;
}

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



input.submit_confirm {
	display: block;
	border:1px solid #37b3ce;
	background-color: #37b3ce;
	line-height:2.6em;
	width:12em;
	font-size: 17px;
	border-radius: 35px;
	font-weight: bold;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
	/*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: 35px;
	font-weight: bold;
	font-size:17px;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
	/*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 #37b3ce;
	background-color: #37b3ce;
	line-height:2.6em;
	border-radius: 35px;
	font-weight: bold;
	font-size:17px;
	cursor:pointer;
	margin: 30px auto 30px;
	color: #fff;
	-webkit-appearance:none;
	/*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: #000;*/
	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: block;
}
.form table th,
.form table td {
	box-sizing: border-box;
	border-bottom: 2px solid #fff;
	display: block;
}
.form table th {
	background-color: #fff;
	padding: 0.6em 2em 0.0em 1em;
	width: 100%;
	position: relative;
	font-weight: bold;
}
.form table th br.sbr {
	display: none;
}

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

.form table th.req:after {
	content:'必須';
	font-size: 15px;
	border: 1px solid #b158f4;
	background-color: #fff;
	border-radius: 5px;
	color: #b158f4;
	padding: 4px 8px 2px;
	position: relative;
	right: auto;
	left: 10px;
	top: 0px;
	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 #d58462;
	background-color: #d58462;
	border-radius: 5px;
	color: #fff;
	padding: 4px 5px 2px;
	margin-right: 4px;

}

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


/* 共通 */
#form_area {
	background-color: #fff;
}

#form_area .msg {
	text-align: center;
}

.form {
	max-width: 750px;
	margin-left: auto;
	margin-right: auto;
}

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


#form_area .hl {
	font-size: 22px;
	font-weight: bold;
	text-align: center;
	line-height: 1.4;
}
#form_area .hl br {
	display: inline-block;
}
#form_area .hl span {
	display: none;
}









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

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

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








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


.checkbox1 .checkbox-parts::before{
	top: -5px;
	left: 0;
	width: 25px;
	height: 25px;
}
.checkbox1 .checkbox-input:checked + .checkbox-parts{
	/*color: #d01137;*/	
}
.checkbox1 .checkbox-parts::after{
	top: -12px;
	left: 10px;
	width: 12px;
	height: 22px;
	border-bottom: 7px solid #37b3ce;
	border-right: 7px solid #37b3ce;
}




.select_date span.brtf  {
	display: inline;
}	

/* 送信ボタン */
.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: 26px;
}
#form_area .hl br {
	display: none;
}
#form_area .hl span {
	display: inline;
}


/* end of media query */
}









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

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

#form_area .hl {
	font-size: 30px;
}

/* end of media query */	
}






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

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

input.submit_confirm {
	line-height:2.8em;
	width:18em;
	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.4em 2em 0em 0em;
	width: 12em;
	/*z-index: -1;*/
}
.form table th br.sbr {
	display: inline-block;
}
.form table td {
	padding: 1.0em 2em 0em 1em;
	border-left: 2px solid #fff;
	width: auto;
}
#pageConfirm .form table td {
	padding: 1.4em 2em 0em 1em;
}

.form table th.req:after {
	position: absolute;
	right: 23px;
	left: auto;
	top: 26px;
}

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

#form_area .hl {
	font-size: 40px;
}


/* end of media query */	
}

