.hanyou_wrap {
	padding: 0 15px;
}
.contact_hero {
	background-color: #f3ede7;
	background-image: url(../images/form_header.png);
}
.format-jp p {
	line-height: 1.8;
}
.content {
	line-height: 1.8;
}
h2 {
	margin-top: 60px;
}
.mL0 {
	margin-left: 0 !important;
}
.atn {
	font-size: 1.4rem;
}
.atn-list {
	margin: 35px 0 50px;
}
.atn-list li {
	position: relative;
	padding-left: 16px;
}
.atn-list li+li {
	margin-top: 8px;
}
.atn-list li::before {
	content: "";
	width: 8px;
	height: 8px;
	background: #4f3b13;
	border-radius: 50%;
	position: absolute;
	top: 10px;
	left: 0;
}
.must {
	background: #e95549;
	color: #fff;
	display: inline-block;
	line-height: 1;
	padding: 5px 5px 5px 5px;
	font-size: 14px;
	margin-right: 3px;
}
.inner-link {
	color: #FE8989;
	text-decoration: underline;
}

/* -------------------------------------
   form
------------------------------------- */
.form {
	margin: 20px 0 50px;
}
.table-default th {
	width: 280px;
	text-align: left;
	padding: 20px 15px;
	box-sizing: border-box;
	vertical-align: top;
}
.table-default th .must {
	margin-left: 8px;
}
.table-default td {
	position: relative;
	display: table-cell;
	padding: 20px;
}
.table-default td p {
	display: inline-block;
	font-size: 14px;
	margin-top: 5px;
}
.table-default .input01,
.table-default .input02,
.table-default .input03,
.table-default textarea {
	border-radius: 5px !important;
	border: solid 1px #ccc !important;
	padding: 5px 10px;
	margin: 0 10px;
}
.table-default .input01 {
	width: 68%;
	margin: 0 10px 0 0;
}
.table-default .input02 {
	width: 28%;
	margin: 0 20px 0 10px;
}
.table-default .input03 {
	width: 15%;
}
.table-default textarea {
	width: 100%;
}
.table-default #address {
	margin-top: 12px;
}
.table-default td.check_area01 {
	gap: 15px;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
}
.check_box {
	background: #eef1f3;
	display: inline-block;
	padding: 5px 15px 5px 40px;
	box-sizing: border-box;
	border-radius: 5px;
	cursor: pointer;
	position: relative;
	user-select: none;
	transition: 0.3s;
}
.check_box::before {
	content: "";
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	width: 21px;
	height: 21px;
	background: url(../images/checkbox_off.png) no-repeat center/contain;
}
.check_box.active {
	background: #e95549;
	color: #fff;
}
.check_box.active::before {
	background: url(../images/checkbox_on.png) no-repeat center/contain;
}
.check_box [type="checkbox"] {
	display: none;
}
.check_box .must {
	margin-left: 10px;
}

/* -------------------------------------
   privacy_area
------------------------------------- */
.privacy_area {
	height: 280px;
	overflow-y: scroll;
	padding: 15px 20px 15px 15px;
	border: solid 1px #cccccc;
	margin-bottom: 30px;
}
.privacy_area h3 {
	margin: 25px 0 5px;
	line-height: 1.4;
}
.privacy_area h3:first-of-type {
	margin-top: 0;
}
.privacy_area p,
.privacy_area li,
.privacy_area dt,
.privacy_area dd {
	font-size: 1.4rem;
}
.privacy_area ol li {
	list-style-type: decimal;
	margin-left: 30px;
}
.privacy_area ol li ol li {
	list-style: none;
	position: relative;
}
.privacy_area ol li ol li::before {
	position: absolute;
	right: calc(100% + 0.5rem);
	content: "(" counter(list-item) ")";
}
.privacy_area::-webkit-scrollbar {
	width: 12px;
	height: 12px;
}
.privacy_area::-webkit-scrollbar-track {
	background: #f0f0f0;
}
.privacy_area::-webkit-scrollbar-thumb {
	background: #999;
	border-radius: 8px;
	border: 3px solid #f0f0f0;
}
.privacy_area::-webkit-scrollbar-thumb:hover {
	background: #777;
}
.btn_agree {
	width: 300px;
	background: #e7ebed;
	margin: 50px auto 0;
	padding: 14px 0;
	padding-left: 40px;
	border-radius: 3px;
	text-align: center;
	display: block;
	background-position: 10px 17px !important;
}
.btn_agree.active .must {
	background: #fff;
	color: #e95549;
}
.check_box.btn_agree.disabled {
	opacity: 0.5;
	pointer-events: none;
}
.check_box.error {
	background-color: #ffecec;
}

/* -------------------------------------
   btn_brown
------------------------------------- */
.btn_brown {
	width: 300px;
	display: block;
	padding: 0;
	margin: 50px auto 0 !important;
}
.btn_brown a {
	display: block;
	background: #726242;
	text-decoration: none;
	text-align: center;
	border-radius: 3px;
	font-size: 1.6rem;
	text-decoration: none;
	padding: 14px 40px;
}
.btn_brown span {
	position: relative;
	display: inline-block;
	padding-left: 15px;
	line-height: 1;
	color: #fff;
}
.btn_brown span:before {
	content: "";
	position: absolute;
	top: 50%;
	left: -5px;
	width: 12px;
	height: 12px;
	border-right: solid 1px #FFF;
	border-bottom: solid 1px #FFF;
	transform: rotate(-45deg) translateY(-63%);
}
.no-arrow a {
	padding: 8px 0;
}
.no-arrow span {
	padding: 0;
}
.no-arrow span:before {
	content: none;
}
.btn_brown a.disabled {
	opacity: 0.5;
	pointer-events: none;
}
.link-btns {
	margin-top: 80px;
}
.link-btns a {
	position: relative;
	padding-left: 15px;
	font-size: 1.8rem;
	line-height: 1.6667;
}
.link-btns a:before {
	content: "";
	position: absolute;
	top: 8px;
	left: -5px;
	width: 11px;
	height: 11px;
	border-right: solid 1px #e95549;
	border-bottom: solid 1px #e95549;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.error-msg {
	color: #ff0000 !important;
	padding: 0 0 0 25px;
	margin: 10px 0 0 0 !important;
	display: inline-block;
	font-size: 1.5rem !important;
	line-height: 1.8 !important;
	background: url(../images/icon_error.png) left 3px no-repeat;
	background-size: 21px 21px;
}

/* -------------------------------------
   	confirm
------------------------------------- */
.confirm .table-default td span.txt {
	border: none;
	margin: 0;
	padding: 0;
}
.confirm .table-default td span.txt span+span {
	margin-left: 20px;
}

/* -------------------------------------
   	error
------------------------------------- */
.error input.error,
.error .check_box.error {
	background: #fce5e4;
}
.error input.error.active,
.error .check_box.error.active {
	background: #e95549;
	color: #fff;
}
.error .error-msg+.error-msg {
	margin-left: 20px !important;
}
.error p:not(.error-msg)+.error-msg {
	margin-top: 0 !important;
	display: block;
}
.error .btn_agree {
	background: #fce5e4;
}
.error .btn_agree.active {
	background: #e95549;
}

/* -------------------------------------
   	footer
------------------------------------- */
footer {
	padding-top: 0;
}



/* ========================================
   SP
======================================== */
@media (max-width: 767px) {
	.hanyou_hero_title {
		font-size: 2.8rem;
		padding-top: 18px;
		line-height: 1.5;
	}
	.sp-dsp-none {
		display: none;
	}
	.sp-block {
		display: block;
	}
	/* -------------------------------------
   	form
	------------------------------------- */
	.table-default tbody {
		display: block;
	}
	.table-default tr {
		display: block;
		width: 100%;
	}
	.table-default tr:last-of-type {
		border-bottom: none;
	}
	.table-default th {
		width: 100%;
		line-height: 1.5;
	}
	.table-default td {
		width: 100%;
		padding: 20px 10px;
		display: block;
	}
	.table-default .input01 {
		width: 100%;
		margin: 0;
	}
	.table-default .input02 {
		width: 34%;
		margin: 0 4% 0 2%;
	}
	.table-default td .input02:nth-of-type(2) {
		margin-right: 0;
	}
	.table-default .input03 {
		width: 27%;
	}
	.table-default textarea {
		margin: 0;
	}
	.link-btns {
		margin-top: 50px;
	}
	.btn_agree {
		margin: 30px auto 0;
	}
	input#mail_confirm::placeholder {
		font-size: 12px;
	}
	/* -------------------------------------
   	error
	------------------------------------- */
	.error .error-msg+.error-msg {
		margin-left: 0 !important;
	}
}

.btn_brown button {
	display: block;
	background: #726242;
	text-decoration: none;
	text-align: center;
	border-radius: 3px;
	font-size: 1.6rem;
	text-decoration: none;
	padding: 18px 40px;
	border: none;
	width: 100%;
	cursor: pointer;
}
.no-arrow button {
	padding: 12px 0;
}