form *{
	padding:0;
	line-height:1.6em;
}

form .privacy_area dl dt{
	font-weight:bold;
	border-bottom:dashed 1px #aaa;
	font-size:110%;
	text-align:left;
	margin-bottom:10px;
}

form .privacy_area dl dd{
	width:95%;
	margin:0 auto 10px;
	text-indent:1em;
	text-align:left;
}

form .privacy_area ul{
	margin-left:0;
}

form .privacy_area li{
	width:100%;
	margin:10px auto;
	list-style-type:none;
}

form .privacy_area .document_dl{
	background:#37a;
	color:#fff;
	padding:5px 15px;
	display:block;
	text-align:center;
	width:300px;
	margin:20px auto;
}

form table{
	width:85%;
	margin:0px auto;
}

form table td,
form table th{
	padding:15px;
	box-sizing:border-box;
	vertical-align:middle;
	border-bottom:dashed 1px #ccc;
}

form table th{
	width:30%;
	position:relative;
	padding-right:50px;
}

form table.kakunin_tbl{
	margin-bottom:30px;
}

form table.kakunin_tbl td,
form table.kakunin_tbl th{
	width:50%;
}

form table th span{
	position:absolute;
	right:0;
	top:calc(50% - 12px);
	font-size:12px;
	padding:5px;
	color:#fff;
	border-radius:3px;
	line-height:1;
}

form table th span.must{
	background:#f77;
}

form table th span.free{
	background:#5af;
}

form table td{
	width:70%;
}

form table td ul{
	overflow:hidden;
	margin:0 auto;
}

form table td ul li{
	width:74%;
	list-style-type:none;
	text-align:left;
	display:block;
	margin:5px auto;
}

section.form form table td ul li label{
	font-weight:normal;
	display:block;
	width:100%;
	vertical-align:baseline;
}

section.form form table td ul li label.radio,
section.form form table td ul li label.checkbox {
	background-color: #f6f7f8;
	color:#2E2F57;
}

section.form form table td ul li label.radio:hover,
section.form form table td ul li label.checkbox:hover {
	background-color: #eef;
}

section.form form table td ul li label.radio:hover:after,
section.form form table td ul li label.checkbox:hover:after {
	border-color: #2E2F57;
}

section.form form table td ul li label.radio:before {
	background-color: #fee;
}

section.form form table td ul li label.checkbox:before {
	border-right: 3px solid #2E2F57;
	border-bottom: 3px solid #2E2F57;
}

form table td textarea,
form table td input[type=tel],
form table td input[type=email],
form table td input[type=text]{
	width:70%;
	border:none;
	padding:10px;
	outline:none;
	background:#eee;
}

form table td textarea{
	height:10em;
}

form table td textarea:focus,
form table td input[type=tel]:focus,
form table td input[type=email]:focus,
form table td input[type=text]:focus,
form table td textarea:active,
form table td input[type=tel]:active,
form table td input[type=email]:active,
form table td input[type=text]:active{
	border:solid 1px #37a;
}

section.form form {
	margin:20px auto;
}

section.form form .agree_area span{
	font-weight:bold;
	color:#2E2F57;
}


section.form form .privacy_area h2{
	font-size:100%;
}

form .privacy_area{
	overflow:auto;
	height:500px;
	width:90%;
	margin:10px auto;
	padding:2% 5%;
	box-sizing:border-box;
	border:solid 1px #aaa;
	font-size:90%;
}

form .privacy_area dl{
	margin:10px auto;
}

form .privacy_area p{
	text-indent:1em;
}

form .privacy_area p,
form .privacy_area dl dd,
form .privacy_area dl dt{
	font-size:85%;
}
form input[type=checkbox] {
	display: none;
}

form label.radio {
	box-sizing: border-box;
	-webkit-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
	position: relative;
	display: inline-block;
	margin: 30px 20px 8px 0;
	padding: 12px 30px 12px 23px;
	border-radius: 8px;
	background-color: #F2F1F7;
	vertical-align: middle;
	cursor: pointer;
	color:#2E2F57;
}

form label.checkbox {
	box-sizing: border-box;
	-webkit-transition: background-color 0.2s linear;
	transition: background-color 0.2s linear;
	position: relative;
	display: inline-block;
	margin: 15px 20px 0px 0;
	padding: 14px 30px 10px 40px;
	border-radius: 8px;
	background-color: #F2F1F7;
	vertical-align: middle;
	cursor: pointer;
	color:#2E2F57;
}

form .aligncenter label.checkbox {
	padding-left:42px;
}

form label.radio:hover,
form label.checkbox:hover {
	background-color: #F2F1F7;
}

form label.radio:hover:after,
form label.checkbox:hover:after {
	border-color: #2E2F57;
}

form label.checkbox:after {
	-webkit-transition: border-color 0.2s linear;
	transition: border-color 0.2s linear;
	position: absolute;
	top: 50%;
	left: 15px;
	display: block;
	margin-top: -10px;
	width: 16px;
	height: 16px;
	border: 2px solid #bbb;
	border-radius: 6px;
	content: '';
}


form label.checkbox:before {
	-webkit-transition: opacity 0.2s linear;
	transition: opacity 0.2s linear;
	position: absolute;
	top: 50%;
	left: 21px;
	display: block;
	margin-top: -7px;
	width: 5px;
	height: 9px;
	border-right: 3px solid #2E2F57;
	border-bottom: 3px solid #2E2F57;
	content: '';
	opacity: 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

form input[type=checkbox]:checked + .checkbox:before {
	opacity: 1;
}


form input[type=radio] {
	width:20px;
	height:20px;
	margin-right:15px;
	-webkit-appearance: auto;
}


.to_top,
.end_form .sbmt_area{
	width:30%;
	margin:10px auto;
}

.to_top a,
form .sbmt_area input[type=submit]{
	text-align:center;
	margin:20px auto 150px;
	display:block;
	background:#E25F00;
	border:none;
	font-size:120%;
	color:#eee;
	padding:10px 50px;
	border:solid 1px #E25F3F;
	border-radius:3px;
	-webkit-transition: all .3s;
	transition: all .3s;
	text-decoration:none;
}


.to_top a:hover,
form .sbmt_area input[type=submit]:hover{
	cursor:pointer;
	background:#fff;
	color:#E25F00;
}

form .err_mes{
	width:85%;
	margin:10px auto;
	border:solid 1px #f55;
	padding:10px;
	box-sizing:border-box;
	border-radius:3px;
	color:#f55;
	padding:0 10px;
}

form .err_mes li{
	color:#f55;
	position:relative;
	padding-left:0;
	margin:5px 0 5px 30px;
	z-index:1;
	list-style-type:circle;
	text-align:left;
}


@media screen and ( max-width:750px )
{
	form table{
		width:100%;
		margin:10px auto;
	}

	section.form form table td,
	section.form form table th{
		display:block;
		padding:5px;
		width:100%;
		box-sizing:border-box;
		vertical-align:middle;
		border-bottom:dashed 1px #ccc;
	}

	section.form form table th{
		text-align:left;
		position:relative;
		padding-left:45px;
	}

	section.form form table.kakunin_tbl th{
		padding-left:5px;
		font-weight:bold;
	}

	form table th span{
		position:absolute;
		right:auto;
		left:5px;
		top:calc(50% - 12px);
		font-size:12px;
		padding:5px;
		color:#fff;
		border-radius:3px;
		line-height:1;
	}

	section.form form table td{
		margin-bottom:25px;
	}

	.login_page form input[type=password],
	.login_page form input[type=text],
	form table td textarea,
	form table td input[type=tel],
	form table td input[type=email],
	form table td input[type=text]{
		width:100%;
		border:none;
		padding:10px;
		outline:none;
		background:#eee;
		box-sizing:border-box;
	}

	form table td ul li{
		width:100%;
		float:none;
	}

	form label.radio,
	form label.checkbox {
		box-sizing: border-box;
		-webkit-transition: background-color 0.2s linear;
		transition: background-color 0.2s linear;
		position: relative;
		display: block;
		margin: 0 20px 8px 0;
		padding:11px;
		border-radius: 8px;
		background-color: #F2F1F7;
		vertical-align: middle;
		cursor: pointer;
		color:#2E2F57;
		font-weight:bold;
	}
	form li label.checkbox {
		padding:11px 5px 7px 42px;
	}

	section.form .aligncenter label{
		text-align:center;
		margin:auto;
		width:90%;
	font-size: 13px;
	}

	.to_top,
	.end_form .sbmt_area{
		width:90%;
		margin:10px auto;
	}

	.end_form p{
		text-align:left;
		width:90%;
		margin:auto;
	}

}
