
section.contact {
	display: block;
}

section.contact dl {
	margin-right: 1em;
	border: 1px solid #333;
}

section.contact dl:after {
	content: "";
	display: block;
	clear: both;
}

section.contact dt,
section.contact dd {
	padding: 0.5em;
}

section.contact dt {
	float: left;
	clear: both;
}

section.contact dd {
	border-bottom: 1px solid #333;
}

section.contact dd:last-child {
	border-bottom: 0;
}

section.contact .full {
	width: 100%;
	padding-left: 0.5em !important;
	clear: both;
}

section.contact input[type=text],
section.contact textarea {
	width: 100%;
	padding: 2px;
	font-size: 100%;
	border: 1px solid #333;
	box-sizing: border-box;
}

section.contact select,
section.contact input[type=button] {
	font-size: 100%;
}

section.contact textarea {
	height: 5em;
}

section.contact .val_err {
	display: block;
}

section.contact .val_err ul {
	display: inline-block;
	text-align: left;
}

@media all and (min-width: 640px) {
/* PC start */
section.contact dt {
	width: 11em;
}
section.contact dd {
	position: relative;
	padding-left: 12em;
	padding-right: 1em;
}
section.contact dd:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 11em;
	width: 1px;
	height: 100%;
	background: #333;
}
section.contact dd.full:before {
	display: none;
}
/* PC end */
}

@media all and (max-width: 639px) {
/* SP start */
section.contact dt {
	padding-bottom: 0;
}
section.contact dd {
	padding-left: 1.1em;
	padding-right: 1.1em;
	clear: both;
}
/* SP end */
}
