@charset "utf-8";
/* ===================================================
	Mailform CSS
====================================================== */

/* Base style */
#form_area { font-feature-settings: "palt"; letter-spacing: 0.08em; }
.serif { font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", serif; }
.gothic { font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; }
.pg30 { border: 1px solid #ccc; }

.link_btn {max-width: 320px; margin: 25px auto 40px; text-align: center; font-size: 15px; font-weight: bold;}
.link_btn a { display: block; color: #fff; padding: 15px; background-color: #ba2559; border-radius: 50px;}
.link_btn a:hover { opacity: .8;}

/* cmn_tit_01 */
.cmn_tit_01{ width: 100%; text-align: center; line-height: 1.3; }
.cmn_tit_01 .ja{ font-size: 35px; color: #603219;}
.cmn_tit_01 .en{ font-size: 13px; display: inline-block; margin: 1em 0 0; position: relative;}
.cmn_tit_01 .en.light { color: #000; background: #fff; }
.cmn_tit_01 .en::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(90deg, rgba(231,140,103,1) 0%, rgba(200,139,202,1) 100%); pointer-events: none; }
.cmn_tit_01 .en.light::before { mix-blend-mode: screen; }

@media screen and (min-width: 641px) {
	.tel-link { pointer-events: none; }
}
@media screen and (max-width: 640px) {
	.btn-nav { text-align: left !important; }
	.cmn_tit_01 .ja{ font-size: 24px;}
	.cmn_tit_01 .en{ font-size: 10px; }
}

/* ---------------------------------------------------
	.mfp_area
------------------------------------------------------ */
/* ▼ mailform PRO のCSS上書き ▼ */
body { overflow-x: auto !important; }
#mailformpro .mfp_area dl dt,
#mailformpro .mfp_area dl dd { border: none; float: none; }
#mailformpro label { white-space: normal; border-radius: 0; margin: 0; display: inline; }
#mailformpro .mfp_area .mfp_colored { background-color: none !important;}
#mailformpro .mfp_area .mfp_not_checked,
#mailformpro .mfp_area .mfp_checked,
#mailformpro .mfp_area .mfp_colored { margin: 7px 10px 0 0 !important; padding: 0; background: none !important; box-shadow: none; border: none;}
.mfp_element_button { text-shadow: none !important; }
div.mfp_buttons { display: flex; flex-direction: row-reverse; justify-content: center; }
#mailformpro div.mfp_buttons button { width: 90%; max-width: 350px; line-height: 56px; border-radius: 30px; border: 1px solid #ccc; padding: 0; text-shadow: none; font-size: 16px; font-family: "Yu Gothic Medium", YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif; font-weight: bold; color: #333; background: #f0f0f0;  transition: opacity 0.5s ease;}

#form_area form#mailformpro label{ border: none; display: block;}
form#mailformpro label.mfp_checked{ background-color: transparent !important;}
@media screen and (hover: hover) and (min-width: 601px) {
	#mailformpro div.mfp_buttons button:hover { opacity: 0.6; }
}
@media screen and (max-width: 640px) {
	#mailformpro div.mfp_buttons button { font-size: 15px; }
}
/* ▲ mailform PRO のCSS上書き ▲ */

/* ▼ 共通スタイル※消さないで ▼ */
form#mailformpro .mfp_area > dl input,
form#mailformpro .mfp_area > dl select,
form#mailformpro .mfp_area > dl textarea { font-size: 14px; font-family: "Yu Gothic Medium", YuGothic, "Yu Gothic", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif; box-shadow: none; color: #333; }
form#mailformpro .mfp_area > dl select { height: 36px; padding: 5px 3px; }

form#mailformpro .mfp_area > dl input:focus,
form#mailformpro .mfp_area > dl select:focus,
form#mailformpro .mfp_area > dl textarea:focus { outline: none; border: 2px solid #999; }

form#mailformpro .mfp_area > dl input { max-width: 100%; height: 36px; padding: 5px 3px; border: 1px solid #999; box-sizing: border-box; }

form#mailformpro .mfp_area > dl input:not(input[type=checkbox],input[type=radio]),
form#mailformpro .mfp_area > dl select,
form#mailformpro .mfp_area > dl textarea { border-radius: 0; }
form#mailformpro .mfp_area > dl input[type=date] { min-width: 156px; }
form#mailformpro .mfp_area select::-ms-expand { display: none; }

form#mailformpro .mfp_area { border-top: 1px solid #999; border-bottom: 1px solid #999; width: 100%; }
form#mailformpro .mfp_area > dl { width: 100%; box-sizing: border-box; display: flex; background-color: rgba(255 255 255/50%); }
form#mailformpro .mfp_area > dl dt,
form#mailformpro .mfp_area > dl dd { margin: 0; box-sizing: border-box; border-bottom: 1px dashed #999; text-align: left; }
form#mailformpro .mfp_area > dl dt { width: 26.6%; padding: 25px 25px 25px 77px; position: relative; text-align: right; line-height: 2; }
form#mailformpro .mfp_area > dl dt span { display: block; }
form#mailformpro .mfp_area > dl dt .en { opacity: 0.6; }
form#mailformpro .mfp_area > dl dd { display: flex; width: 73.4%; padding: 15px 70px 15px 30px; flex-wrap: wrap; }
form#mailformpro .mfp_area > dl dd > ul { display: flex; justify-content: left; flex-wrap: wrap; width: 100%; }
form#mailformpro .mfp_area > dl dd > ul li { margin: 0 15px 10px 0; text-indent: -1.5em; padding-left: 1.5em; }
form#mailformpro .mfp_area > dl dd p { text-align: left; display: block; width: 100%; margin: 0; }
form#mailformpro .mfp_area > dl:last-of-type dt,
form#mailformpro .mfp_area > dl:last-of-type dd { border-bottom: none; }
form#mailformpro .mfp_area > dl dd.flex { flex-direction: column; align-content: flex-start; }
form#mailformpro .mfp_area > dl dd.flex>div { display: flex; align-items: center; flex-wrap: wrap; }
form#mailformpro .mfp_area > dl dd.flex>div+div { margin-top: 5px; }
form#mailformpro .mfp_area > dl dd.flex>div p { width: auto; margin: 0 1em 0 0; }

/* プラポリ */
#form_area form#mailformpro .pii_check { line-height: 2; }
#form_area form#mailformpro .pii_check a { text-decoration: underline; }
#form_area form#mailformpro .pii_check a:hover { opacity: 0.7; }
#form_area form#mailformpro .pii_check label { display: inline-block; }
#form_area form#mailformpro .pii_check input[type="checkbox"] { margin: 0; -webkit-appearance: none; -moz-appearance: none; appearance: none; border: 1px solid #c4c4c4; position: relative; vertical-align: text-bottom; border-radius: 0; height: 15px; width: 15px; }
#form_area form#mailformpro .pii_check input[type="checkbox"]:checked { border: 1px solid #c4c4c4; }
#form_area form#mailformpro .pii_check input[type="checkbox"]:checked::after { content: ""; display: block; position: absolute; top: -2px; left: 3px; width: 5px; height: 10px; transform: rotate(40deg); border-bottom: 3px solid #222; border-right: 3px solid #222; }

/* 送信ボタン */
#form_area form#mailformpro .mfp_buttons { margin: 55px auto 0; width: 96%; text-align: center; }
#form_area form#mailformpro .mfp_buttons button:hover { box-shadow: none; }

/* エラー表示 */
#form_area form#mailformpro div.mfp_err { margin: 5px 0px 0px 15px; padding: 3px 0px 5px 17px; background-position: 0px 6px; text-indent: 0;}
#form_area form#mailformpro label.mfp_checked { padding: 0; border: none; box-shadow: none; opacity: 1; }
#form_area form#mailformpro .pii_check div.mfp_err { margin: 4px auto 0px; }
#form_area form#mailformpro .mfp_not_checked { opacity: 1; padding: 0;}
/* ▲ 共通スタイル※消さないで ▲ */

/* 必須入力項目と任意入力項目 */
.required { font-size: 11px; letter-spacing: 0.08em; margin-right: 10px; width: 38px; box-sizing: border-box; display: inline-block; text-align: center; font-family: sans-serif; color: #fff; background-color: #d64646;}
form#mailformpro .mfp_area > dl dt .required { position: absolute; top: 25px; left: 25px; margin: auto 0; display: block; }

@media screen and (max-width: 640px) {
	/* ▼ 共通スタイル※消さないで ▼ */
	form#mailformpro .mfp_area > dl input,
	form#mailformpro .mfp_area > dl select,
	form#mailformpro .mfp_area > dl textarea { font-size: 16px; }

	form#mailformpro .mfp_area input,
	form#mailformpro .mfp_area textarea { -webkit-appearance: none; }

	form#mailformpro .mfp_area { border-bottom: none; }
	form#mailformpro .mfp_area > dl dt { width: 40%; padding: 20px 2% 20px 40px; }
	form#mailformpro .mfp_area > dl dd { width: 60%; padding: 20px 2%; }
	form#mailformpro .mfp_area > dl dd > ul li { width: 100%; margin-bottom: 10px; }
	form#mailformpro .mfp_area > dl dd > ul li:last-child { margin-bottom: 0; }
    form#mailformpro .mfp_area > dl:last-of-type dd { padding-bottom: 12px; }
	form#mailformpro .mfp_area > dl dd.flex input { width: 100%; }

	/* プラポリ */
	#form_area { padding-bottom: 60px; }
	#form_area form#mailformpro .pii_check { text-align: left; margin-top: 0; line-height: 2; }

	/* 送信ボタン */
    #form_area form#mailformpro .mfp_buttons { margin-top: 30px; }
	#form_area form#mailformpro .mfp_buttons button { width: 100%; }

	/* エラー表示 */
	#form_area form#mailformpro .pii_check div.mfp_err { width: 100%; }
	/* ▲ 共通スタイル※消さないで ▲ */

	/* ▼ 選択スタイル※不要なスタイルは削除 ▼ */

/* 必須入力項目と任意入力項目 */
	form#mailformpro .mfp_area > dl dt .required { top: 20px; left: 0; }

	/* チェックボックス */
	form#mailformpro .mfp_area .check_box dd { padding: 15px 0; }

	/* ラジオボタン */
	form#mailformpro .mfp_area .radio_btn dd { padding: 15px 0; }

	/* セレクトボックス */
	form#mailformpro .mfp_area .select_box select { width: 100%; }
	form#mailformpro .mfp_area .select_box dd { padding: 15px 0; }

	/* テキストボックス */
	form#mailformpro .mfp_area .text_box { border-bottom: none; }
	form#mailformpro .mfp_area .text_box dd { padding: 5px 0; }
	form#mailformpro .mfp_area .text_box textarea { width: 100%; height: 150px;}
	/* ▲ 選択スタイル※不要なスタイルは削除 ▲ */
}
@media screen and (max-width: 480px) {
	form#mailformpro .mfp_area > dl { display: block;}
	form#mailformpro .mfp_area > dl dt,
	form#mailformpro .mfp_area > dl dd { width: 100%; }
	form#mailformpro .mfp_area > dl dt { border-bottom: none; text-align: left; padding: 15px 2% 0 50px; line-height: 1.8; }
	form#mailformpro .mfp_area > dl dt .required { top: 15px; }
	form#mailformpro .mfp_area > dl dd { padding: 15px 2% 20px; }
	form#mailformpro .mfp_area > dl dd>p { margin-top: 10px; }
}


/* ---------------------------------------------------
	Layout
------------------------------------------------------ */
#form_area { padding: 80px 0; }
#form_area>.txt { margin-top: 30px; font-size: 18px; text-align: center; }
#mailformpro { margin-top: 40px; }
#mailformpro h4 { padding: 13px 20px; font-size: 15px; font-weight: bold; background-color: #f3efea; }

@media screen and (max-width: 640px) {
	#form_area { padding: 50px 0; }
	#form_area>.txt { margin-top: 20px; font-size: 14px; text-align: left; }
	#mailformpro { margin-top: 20px; }
	#mailformpro h4 { padding: 12px 3%; font-size: 14px; }
}


/* ---------------------------------------------------
	Thanks.php
------------------------------------------------------ */
.thanks #content { min-height: calc(100vh - 250px); }
.thanks .cmn_tit_01 { margin-bottom: 35px; }
.thanks section { padding: 30px 0; }
.thanks section>p { font-size: 18px; text-align: center; }

@media screen and (max-width: 640px) {
	.thanks section>p { font-size: 14px; }
	.thanks section .txt { text-align: left; }
}