@charset "UTF-8";
main section, .bg01 {
    padding: 30px 40px 20px 40px;
	
}
.wrap.flex{
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

.description{
	line-height: 1.6;
}

.required{
	background-color: #c42134;
	color: #ffffff;
	font-size: 1.2rem;
	padding: 2px 5px;
	font-weight: bold;
	display: inline-block;
}

.table01 .required{
	margin-left: 10px;
}

.table01{
	text-align: left;
}

.table01 td,.table01 th{
	padding: 20px;
	vertical-align: middle;
}
@media screen and (max-width: 767px) {
	.table01 td,.table01 th{
		padding: 15px;
	}
}

input[type="text"]{
	border: 1px solid #dedede;
	padding: 10px;
}

input[type="radio"]{
	float: none;
	margin: 0 5px 0 0;
}

input[type="radio"],label{
	cursor: pointer;
}

textarea{
	border: 1px solid #dedede;
 	resize: vertical;
	padding: 10px;
	width: 100%;
}

label{
	margin-right:15px
}

label:last-child{
	margin-right:0;
}

:placeholder-shown {color: #c4c4c4; }
::-webkit-input-placeholder { color: #c4c4c4; }
:-moz-placeholder {color: #c4c4c4; opacity: 1; }
::-moz-placeholder {color: #c4c4c4; opacity: 1; }
:-ms-input-placeholder {color: #c4c4c4; }

.btn02{
 
}

.order_btn {
    display: block;
    width: auto;
    margin: auto;
    padding: 20px;
    text-align: center;
}

.requirement{
	line-height: 2.6 !important;
}
.requirement > span:not(.err-text) {
	display: inline-block;
	margin-right: 15px;
}

select {
	padding: 10px;
	margin-right: 5px;
}
select:not(:first-of-type) {
	margin-left: 5px;
}
.caution {
	margin-top: 10px;
}

@media screen and (max-width: 767px) {
	.bg01{
		padding: 3%;
	}
	.table01 td, .table01 th{
		display: block;
		border-bottom: none;
	}
	input[type="text"]{
		width: 100%;
	}
	input,textarea{
		-webkit-appearance: none;
		border-radius: 0;
		font-size: 1.6rem;
		line-height: 1;
	}
	/*input[type="radio"] {
		-webkit-appearance: radio;
		-moz-appearance: radio;
		appearance: radio;
	}*/
	textarea{line-height: 1.5;}
	.border01{border-bottom: 1px solid #dfd5c7 !important;}
	select {
		margin-right: 4px;
		font-size: 16px;
	}
	.btn02 {
		padding: 16px 65px;
		width: 100%;
	}
}

#sys-form h3,
.thx_text {
	text-align: center;
}
.thx_text {
	margin-top: 20px;
}

.table01 th {
	width: 240px;
}
@media screen and (max-width: 767px) {
	.table01 th {
		width: 100%;
	}
}
@media screen and (max-width: 580px) {
	.caution {
		font-size: 2.7vw;
		line-height: 1.4;
	}
}
@media screen and (max-width: 374px) {
	select:nth-of-type(3) {
		margin-left: 0;
		margin-top: 10px;
	}
}

.table01 small {
	letter-spacing: -1px;
}