main .container {
	margin:0 auto 6em;
}

main h1 {
	text-align: center;
	font-family: "Noto Sans", sans-serif;
	letter-spacing: 0.1em;
	font-size: 1.7em;
	color: var(--BaseColor);
	margin: 2em 0 1.5em;
}

main h1 span {
	display: block;
	font-family: "Noto Sans JP", sans-serif;
	font-size:0.5em;
	letter-spacing: 0.05em;
}

section.form_area {
	width: 100%;
    max-width: 960px;
    margin:0 auto;
}

section.form_area > p {
	font-size: 1.1em;
}

section#form.form_area > p {
	text-align: center;
}

section.form_area > p.note {
	margin-top:0.5em;
	margin-bottom:4em;
	font-size:0.9em;
	color:var(--DarkGray);
}

section.form_area p.lead span,
section.form_area > p.note span {
	display: inline-block;
}

section.form_area > p + dl {
	margin-top:3em;
}

section.form_area dl {
	margin-bottom:3em;
}

section.form_area dl dt {
	font-weight:bold;
	font-size:1.1em;
	line-height: 1.0;
	padding-bottom:0.6em;
}

section.form_area dl dt span {
	display: inline-block;
	vertical-align: middle;
	margin-left:0.5em;
	border:solid 1px #EE4455;
	color: #EE4455;
	background: #FFF;
	font-size:0.9em;
	font-weight:400;
	line-height: 1.0;
	padding:0.1em 0.4em 0.2em;
}

section.form_area dl dt p.note {
	display: inline-block;
	vertical-align: middle;
	margin-left:1em;
	font-weight:400;
	font-size:0.9em;
	color:var(--DarkGray);
}

section.form_area dl dd {
	width:100%;
}

section.form_area dl dd ul li + li {
	margin-top:0.5em;
}

section.form_area input[type=text],
section.form_area textarea {
	width:100%;
	box-sizing: border-box;
	padding:0.7em
}

section.form_area p.err {
	color:#EE4455;
	margin:0.3em 0;
}

section.form_area p.err#message-error {
	margin:0 0 0.6em 0
}

.agree_box {
	text-align: center;
	margin-bottom:1em;
	font-size:1.1em;
}

p.agree_link {
	text-align: center;
}

p.agree_link a {
	color:var(--BaseColor);
}

section.form_area input[type=radio] + label {
	margin: 0;
    position: relative;
    padding: 0 0 0 24px;
    text-align: left;
    line-height: 1.2;
}

section.form_area input[type=radio] + label {
	cursor: pointer;
	pointer-events: auto;
}

section.form_area input[type=radio] {
	display: none;
}

section.form_area input[type=radio] + label:before {
	position: absolute;
    content: "";
    top: calc(50% - 7px);
    left: 0;
    width: 14px;
    height: 14px;
    margin-top: 0;
    background: #FFF;
    border: 1px solid #666;
    border-radius: 100%;
}

section.form_area input[type=radio]:checked + label:before {
    border: 1px solid #444;
}

section.form_area input[type=radio]:checked + label:after {
	position: absolute;
    content: "";
    top: calc(50% - 4px);
    left: 3px;
    width: 10px;
    height: 10px;
    margin-top: 0;
    background: #444;
    border-radius: 100%;
}

section.form_area input[type=checkbox] + label {
    margin: 0;
    position: relative;
    padding: 0 0 0 24px;
    text-align: left;
    line-height: 1.2;
}

section.form_area input[type=checkbox] + label {
	cursor: pointer;
	pointer-events: auto;
}

section.form_area input[type=checkbox] {
	display: none;
}

section.form_area input[type=checkbox] + label:before {
	position: absolute;
    content: "";
    top: 3px;
    left: 0;
    width: 14px;
    height: 14px;
    margin-top: 0;
    background: #FFF;
    border: 1px solid #666;
    border-radius: 2px;
}

section.form_area input[type=checkbox]:checked + label:before {
	background: #444;
    border: 1px solid #444;
}

section.form_area input[type=checkbox]:checked + label:after {
	position: absolute;
    content: "";
    top: 7px;
    left: 3px;
    width: 8px;
    height: 3px;
    margin-top: 0;
    border-bottom: solid 2px #FFF;
    border-left: solid 2px #FFF;
    transform: rotate(-45deg);
}

section.form_area dl dd input[type=checkbox] + label:before,
section.form_area dl dd input[type=checkbox]:checked + label:before {
	transform: translateY(-1px);
}

section.form_area dl dd input[type=checkbox]:checked + label:after {
	transform: translateY(-1px) rotate(-45deg);
}


section.form_area a.disabled {
	pointer-events: none;
    cursor: default;
    opacity: 0.2;
}

section.form_area .btn_wrapper {
	margin-top:2em;
	text-align: center;
}

section.form_area .btn_confirm,
section.form_area .btn_submit {
    background: #222;
    color: #FFF;
    padding: 0.7em 0.8em 0.8em 0.85em;
    width: 12em;
    font-size: 1.4em;
    letter-spacing: 0.05em;
    display: inline-block;
    text-align: center;
    text-decoration: none;
    font-weight:600;
}

section.form_area .btn_back_wrapper {
	margin-top:1.5em;
	text-align: center;
}

section.form_area .btn_back {
	color:var(--BaseColor);
}

section#thanks.form_area p {
	line-height: 1.7;
}

section.form_area .thanks_copy {
	padding:1em;
	text-align: center;
	background: #EDF3FD;
	color:#0066CC;
	margin-bottom:1em;
	font-size:1.1em;
	font-weight:600;
}

section.form_area .to_home {
	text-align: center;
	margin-top:2em;
}

section.form_area .to_home a {
	color:var(--BaseColor);
}




@media print, screen and (min-width: 480px) {

}


@media print, screen and (min-width: 640px) {

main h1 {
	font-size:2em;
}

section.form_area dl {
	display: flex;
	align-items: stretch;
	margin-bottom:0;
	border-bottom:solid 1px #DDD;
}

section.form_area dl:first-child,
section.form_area > p + dl {
	border-top:solid 1px #DDD;
}

section.form_area dl dt {
	width:19em;
	max-width:19em;
	background: #F5F5F5;
	padding:1.5em 1.3em;
}

section.form_area dl dt p.note {
	display: block;
	margin:0.2em 0 0 0;
}

section.form_area dl dd {
	padding:1.5em 0 1.5em 1.5em;
}

.agree_box {
	margin-top:3em;
	margin-bottom:0.3em;
}

section.form_area .btn_wrapper {
	margin-top:3em;
}

}


@media print, screen and (min-width: 768px) {

section.form_area input[type=checkbox] + label:before {
    top: 4px;
}

section.form_area input[type=checkbox]:checked + label:after {
    top: 8px;
}

section#confirm > p {
	text-align: center;
}

section.form_area dl dt {
	width:20em;
	max-width:20em;
	padding:1.5em 1.5em;
}

section#thanks.form_area p {
	text-align: center;
}


}


@media print, screen and (min-width: 960px) {

}


@media print, screen and (min-width: 1200px) {

section.form_area dl dt {
	font-size:1em;
}

section.form_area input[type=checkbox] + label:before {
    top: 5px;
}

section.form_area input[type=checkbox]:checked + label:after {
    top: 9px;
}

section.form_area .thanks_copy {
	margin-bottom:2em;
}

section.form_area .to_home {
	margin-top:3em;
}

}


@media print, screen and (min-width: 1520px) {


}


@media print, screen and (min-width: 1200px) and (min-height: 900px) {

section#thanks.form_area {
	min-height: calc(100vh - 450px);
}

}
