@charset "utf-8";

/* -----------------------------------------------------------
    form
-------------------------------------------------------------- */
.h1-area{
	/*top: 280px;*/
	top: 380px;
}
#main{
	margin: 0px 0 0;
}
@media screen and (max-width: 768px){
#sp-header{
	position: absolute;
}
	/* .sp-gnav-btn{
		position: absolute;
		top: -25px;
	} */
}
#form {
}

#form .section-catch.intro{
	text-align: center;
	    font: 500 3.6rem / 1.7 'Noto Sans JP', serif;
	padding: 60px 0 0;
	line-height: 1.5;
}

/* 画像スライド */
.slide-img {
	position: relative;
	background: url(../img/slide.png) repeat-x 0 0;
	background-size: 1600px auto;
	width: 100%;
	overflow: hidden;
	height: 160px;
	-moz-animation: loop 30s linear infinite;
	animation: loop 30s linear infinite;
	margin: 50px 0 0;
}
/*アニメーション*/
@keyframes loop {
0% {
	background-position: 0 0;
	}
100% {
	background-position: -1475px 0;
	}
}

@media screen and (max-width: 768px){

	#form .section-catch.intro{
		font-size: 2rem;
		padding: 30px 0 0;
	}
	#form .section-catch.intro span{
		font-size: 3rem;
	}


	/* 画像スライド */
	.slide-img {
		-moz-animation: loop 30s linear infinite;
		animation: loop 30s linear infinite;
		margin: 30px 0 0;
		height: 130px;
	}
	/*アニメーション*/
	@keyframes loop {
	0% {
		background-position: 0 0;
		}
	100% {
		background-position: -1475px 0;
		}
	}

}

.page-contact .f_contents_top,
.page-contact .f_btm_list,
.page-contact #footer_fixed {
	display: none!important;
}

.page-contact .header {
	position: relative!important;
}

.page-contact.hamburger-open .header {
	position: fixed!important;
}

.page-contact.hamburger-open .sp-gnav-btn {
	position: fixed;
}

.page-contact #wrapper {
	padding: 0!important;
}

.page-contact .f_contents_bottom .inner{
	text-align: center;
	justify-content: center;
}

.page-contact .f_contents_area {
	padding: 0;
}

.page-contact #form .form_area {
	padding: 0 0 40px;
}

.bread-h1-wrap {
	padding-bottom: 20px;
	top: 65px;
}

.sbh1{display:none;}
input[type="radio"]:checked#sbh1~div.sbh1 {display:block;}



/* イントロ */
#form .intro-area.inner{
	/* width: 1000px;
	margin: 0 auto 30px auto; */
	position: relative;
	/* padding: 35px 0 40px; */
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 1100px;
}
#form .intro-area.inner .catch{
	margin: 0 0 30px;

	font-size: 3.0rem;
}

/* .intro-img img {
	width: 190px;
	position: absolute;
	right: -5px;
	top: 45px;
}

.intro-txt {
	text-align: center;
	margin: 15px 0 0 0;
}

.intro-txt-head {
	font-size: 2.6rem;
	font-weight: bold;
	color: var(--main-color);
	text-align: center;
	line-height: 1.5;
	letter-spacing: .05em;
}

.other-wrap {
	display: flex;
	margin: 25px auto 0;
	justify-content: center;
	background: #fff;
	width: 800px;
	padding: 20px 10px;
	border-radius: 20px;
}

.other-line {
	padding: 0 20px 0 0;
}

.other-line .other-line-txt {
	text-align: center;
}

.other-line .other-line-txt span {
	background: #11b24e;
	color: #fff;
	border-radius: 30px;
	padding: 3px 15px 5px;
}

.other-line .catch02 {
	line-height: 1.4;
	color: #11b24e;
	font-size: 1.8rem;
	font-weight: bold;
}

.other-line .qr-box img{
	width: 100px;
}

.other-line .id-box .id {
	font-size: 2.5rem;
	display: inline-block;
	padding: 5px 20px;
	background: #e2f9e9;
	margin: 20px 0 0 0;
}

.other-tel {
	color: #a29789;
	cursor: pointer;
	margin: 0 0 0 17px;
}

.other-tel-wrap {
	margin: 0 0 0 20px;
	border-left: 1px solid #ddd;
	padding: 0 0 0 10px;
}

.other-tel-note {
	color: #a29789;
	font-size: 1.8rem;
	font-weight: bold;
	margin: 15px 0;
	height: 50px;
	line-height: 55px;
}

.other-tel .other-tel-time {
	color: #a29789;
	display: block;
	text-align: center;
	font-size: 1.6rem;
	margin: 15px 0 0 0;
}

.other-tel .other-num-txt {
	color: #a29789;
	font: bold 2.9rem/1 'Poppins', sans-serif;
	letter-spacing: .05em;
}

.other-tel .other-num-txt i {
	font-size: 2.5rem;
	margin: 0 8px 5px 0;
}

.other-wrap .friend-box {
	display: flex;
	margin: 10px 0 0 0;
}

.other-wrap .friend-box .box {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 0 10px;
} */


@media screen and (max-width: 768px) {

	/* イントロ */
	#form .intro-area {
		padding: 0 20px;
		display: block;
		margin: 0 0 15px;
	}

	#form .intro-area.inner {
		width: 100%;
		flex-wrap: wrap;
		padding: 40px 20px 20px;
		margin: 0;
	}
	#form .intro-area.inner .img{
		width: 100%;
		margin: 0 0 15px;
	}
	#form .intro-area.inner .img img{
		max-width: 100%;
	}
	#form .intro-area.inner .txt-box{
		order: 2;
	}
	#form .intro-area.inner .catch{
		margin: 0 0 15px;
		font-size: 2.4rem;
	}
	.intro-txt-head {
		font-size: 2rem;
		text-align: left;
		letter-spacing: .03em;
	}

	.other-wrap {
		display: block;
		width: 100%;
		padding: 15px 20px;
		margin: 15px 0 0 0;
	}

	.intro-img img {
		width: 100px;
		position: absolute;
		right: -30px;
		top: 80px;
	}

	.other-line img {
		width: 130px;
	}

	.other-wrap .friend-box {
		display: none;
	}

	.other-line {
		display: block;
		margin: 0 0 10px;
	}

	.other-line .catch02 {
		font-size: 1.5rem;
	}

	.other-tel-wrap {
		border-top: 1px solid #ddd;
		border-left: none;
		margin: 15px 0 0 0;
	}

	.other-tel {
		display: flex;
		flex-direction: column;
		width: 100%;
		margin: 0;
	}

	.other-tel-note {
		font-size: 1.5rem;
		margin: 20px 0 15px 0;
		height: auto;
		line-height: unset;
	}

	.other-tel .other-num-txt {
		font-size: 2.5rem;
	}

	.other-tel .other-num-txt i {
		font-size: 2rem;
	}

	.other-tel .other-tel-time {
		margin: 10px 0 0 0;
	}






}

/* aboutarea */
#form #top .about-area {
	padding: 0;
	margin: -20px auto 0;
}
#form #top .about-area .about-detail-area {
    background: none;
    padding: 0 0 20px;
}
#form #top .about-detail-area .title-block,
#form #top .about-detail-area .btn{
	display: none!important;
}

@media screen and (max-width: 768px) {

	/* aboutarea */
	#form #top .about-area {
		padding: 0 20px;
		margin: 0 auto 0;
	}
	#form #top .about-area .about-detail-area {
		padding: 0 0 0;
	}

	#form #top .about-area .block-wrapper .block{
		margin: 0 0 90px;
	}

}




#form .contact-area-txt {
	text-align: center;
	font-size: 1.8rem;
	line-height: 1.6;
}
#form .contact-area-title {
	text-align: center;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.6;
	padding: 0 0 30px;
}

@media screen and (max-width: 768px) {

	#form .contact-area-txt {
		text-align: left;
		font-size: 1.7rem;
		line-height: 1.7;
		padding: 0 20px;
	}
	#form .contact-area-title {
		font-size: 2rem;
		padding: 0 0 15px;
	}

}


/*
#form .page_title_area {
	background: url(../img/gray_bg.png)repeat;
}
*/

#form .form_area {
	padding: 30px 0 120px;
}

#form .form_area.complete {
	padding: 40px 0 0;
}

#form .form_area .tel_area {
	margin: 30px 0 0 0;
	padding: 30px;
	text-align: center;
	border: 1px #F58A00 solid;
}

#form .form_area .tel_area .txt {
	font-size: 2.0rem;
	font-weight: bold;
	color: #F48A00;
}

#form .form_area .tel_area .tel_txt {
	margin: 8px 0 0 0;
	font-size: 3.0rem;
	font-weight: bold;
	font-family: Arial, Helvetica, "sans-serif";
}

#form .form_area .tel_area .tel_txt img {
	width: 24px;
	vertical-align: top;
	margin: 4px 5px 0 0;
}

#form .form_area .tel_area .tel_time {
	margin: 10px 0 0 0;
	font-size: 1.2rem;
}

#form .form_area .mail_title {
	font-size: 2.0rem;
	font-weight: bold;
	color: #F48A00;
	padding: 60px 0 20px 0;
}

#form .form_area .mail_title img {
	width: 26px;
	vertical-align: middle;
	margin: 0 5px 0 0;
}

#form .form_area.complete .back-link {
	text-align: center;
	padding: 0 0 100px;
	position: relative;
}

#form .form_area.complete .back-link a::before {
	display: inline-block;
	content: "\f105";
	font-weight: 900;
	font-family: 'Font Awesome 5 Free';
	padding: 0 5px 0 0;
	color: var(--main-color);
}

@media screen and (max-width: 768px) {
	#form .form_area {
		padding: 0 0 70px;
	}
	#form .form_area.complete {
		padding: 30px 20px 20px;
	}
	#form .form_area .tel_area {
		margin: 20px 20px 0 20px;
		padding: 20px;
		text-align: center;
	}
	#form .form_area .tel_area .txt {
		font-size: 1.6rem;
	}
	#form .form_area .tel_area .tel_txt {
		font-size: 2.6rem;
		color: #444;
	}
	#form .form_area .tel_area .tel_txt img {
		width: 22px;
		margin: 2px 5px 0 0;
	}
	#form .form_area .tel_area .tel_time {
		margin: 10px 0 0 0;
	}
	#form .form_area .mail_title {
		font-size: 1.8rem;
		padding: 30px 20px 20px 20px;
	}
	#form .form_area .mail_title img {
		width: 22px;
		margin: 0 5px 0 0;
	}
	#form .form_area.complete .back-link {
		padding: 30px 0 0 0;
	}
}


/* -----------------------------------------------------------
    input
-------------------------------------------------------------- */

.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area input[type="number"],
.form_area input[type="password"],
.form_area select,
.form_area textarea {
	border: 1px solid #DDD;
	padding: 15px;
	font-size: 1.6rem;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	letter-spacing: 0.03em;
	background: #fff;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.form_area input[type="text"]:focus,
.form_area input[type="email"]:focus,
.form_area input[type="tel"]:focus,
.form_area input[type="number"]:focus,
.form_area input[type="password"]:focus,
.form_area select:focus,
.form_area textarea:focus {
	border: 1px solid #3972B7;
	outline: none;
}

.form_area input[type="number"] {
	-moz-appearance: textfield;
}

.form_area input[type="number"]::-webkit-outer-spin-button,
.form_area input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.form_area select {
	width: 45%;
	padding: 15px;
	/* margin: 0 0 0 10px; */
	background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
	background-size: 20px auto;
}

.form_area td.area select {
	width: 40%;
	padding: 10px;
	margin: 0 0 0 0;
	background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
	background-size: 20px auto;
}

.form_area select:hover {
	cursor: pointer;
}

.form_area option {
	padding: 5px 15px;
}

.form_area select option selected {
	color: #999;
}

.form_area textarea {
	width: 100%;
}

.form_area input[type="radio"],
.form_area input[type="checkbox"] {
	vertical-align: -1px;
	margin: 0 12px 0 0;
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	border-radius: 0;
}

.form_area label:hover {
	cursor: pointer;
}

.form_area label.label_first {
	display: inline-block;
	margin: 0 40px 0 0;
}


/* -----------------------------------------------------------
    button / submit
-------------------------------------------------------------- */

input[type="submit"],
input[type="button"] {
	display: block;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	letter-spacing: 0.08em;
	margin: 0 auto;
	transition: 0.5s;
	border: none;
	outline: none;
	appearance: none;
	color: #FFF;
	font-size: 1.9rem;
	font-weight: bold;
	width: 330px;
	padding: 28px 30px 31px;
	text-align: center;
	line-height: 1;
	border-radius: 3px;
}

#form input[type="submit"],
#form input[type="button"] {
	min-width: 350px;
	border-radius: 50px;
	height: auto;
	background: var(--main-color);
	font-size: 1.9rem;
}

#form input[type="submit"][disabled] {
	color: #fff;
	background: #bbb;
	border-radius: 40px;
}

#form input[type="submit"] {
	background: var(--main-color);
}

#form input[type="submit"].submit_gray,
#form input[type="button"].submit_gray {
	color: #333;
	width: 330px;
	background: #EEE;
	padding: 28px 30px 31px;
	text-align: center;
}

input[type="button"]:hover {
	cursor: pointer;
	background: #CCC;
}

input[type="submit"]:hover {
	cursor: pointer;
	background: #ffb438;
}


/*		送信ボタン		*/

.form_btn_area {
	padding: 60px 0 0 0;
	text-align: center;
}

.form_btn_area .fl {
	float: left;
}

.form_btn_area .fr {
	float: right;
}

.form_btn_area .confirm .clearfix {
	display: flex;
	justify-content: center;
	width: 750px;
}

.form_btn_txt {
	margin: 0 0 40px;
}
.form_btn_txt a{
	color: var(--main-color);
}
.error_message {
	text-align: center;
	padding: 130px 0 40px;
	line-height: 1.8;
}

.submit_btn {
	background: #ebc118;
}


/* -----------------------------------------------------------
    フォーム共通
-------------------------------------------------------------- */

.form_toptxt {
	line-height: 1.8;
	text-align: center;
}

.form_toptxt.s {
	font-size: 1.3rem;
}

.back_btn {
	margin: -65px 0 0;
	width: 21%;
	font-size: 1.4rem;
	text-align: center;
	background: url(../img/icon_arrow_left.png) no-repeat 10% 49%;
	background-size: 7px 13px;
}

.back_btn a {
	display: block;
	padding: 20px 0;
	border: 1px solid #666;
}

.attention {
	margin: 10px 0;
	line-height: 1.6;
}


/* -----------------------------------------------------------
    入力画面共通  /  table
-------------------------------------------------------------- */

.form_table {
	margin: 40px 0 0;
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #ddd;
	letter-spacing: 0.05em;
	line-height: 2;
}

.form_table tr {
	border-bottom: 1px solid #ddd;
}

.form_table th {
	width: 35%;
	padding: 30px 50px;
	text-align: left;
	font-weight: bold;
	vertical-align: top;
}

.form_th_title {
	display: inline-block;
	padding: 5px 0 0;
}

.form_th_notes {
	float: right;
	display: inline-block;
	margin: 5px 0 0;
	padding: 3px 12px;
	font-size: 1.3rem;
	font-weight: bold;
	color: #fff;
	background: #E94647;
}

.form_table td {
	padding: 30px 30px 30px 0;
	text-align: left;
	vertical-align: top;
}

.form_table .none td {
	text-align: center;
	font-size: 1.7rem;
	font-weight: 500;
}

.form_table input[type="text"],
.form_table input[type="password"],
.form_table input[type="tel"],
.form_table input[type="email"],
.form_table select {
	width: 80%;
}
.form_table select#year,
.form_table select#month,
.form_table select#days{
	width: 25%;
}
.form_table input[type="number"] {
	width: 30%;
}

/*		郵便番号		*/

.form_area input[type="number"].input_zip {
	width: 30%;
	margin: 0 0 0 10px;
}

.zip_btn {
	width: 30%;
	margin: 15px 0 0;
	text-align: center;
}

.zip_btn a {
	display: block;
	padding: 10px 0;
	color: #fff;
	background: #7FB2AA;
}
@media screen and (max-width:768px) {
	.form_table select#year,
	.form_table select#month,
	.form_table select#days{
		width: 100%;
	}
}


/*		お問い合わせ		*/

.radio_list {}

.radio_list li {
	line-height: 2.4;
}


/*		注釈		*/

.form_td_notes {
	display: inline-block;
	font-size: 1.4rem;
	/*color: #286bea;*/
}

.form_td_notes02 {
	margin: 15px 0;
	font-size: 1.5rem;
	/*color: #286bea;*/
}

.form_td_notes03 {
	margin: 15px 0 0;
	font-size: 1.4rem;
}

.form_td_notes04 {
	margin: 7px 0 15px;
	font-size: 1.4rem;
}


/*最後の枠　js用*/
.form_table.last {
	border-top: none;
	margin-top: 0;
}


/* -----------------------------------------------------------
    確認画面共通
-------------------------------------------------------------- */

.form_table.confirm {}

.form_table.confirm th {
	width: 30%;
}


/*		写真添付		*/

.form_table .form_photo {
	margin: 10px 0 0;
}

.form_table .form_photo img {
	width: 300px;
}

.form_btn_area.confirm .btn-wrap {
	display: flex;
	width: 800px;
	justify-content: center;
	margin: 0 auto;
}

.form_btn_area.confirm .btn-wrap input {
	margin: 0 30px;
}


/* -----------------------------------------------------------
    完了画面共通
-------------------------------------------------------------- */

.form_area .complete_title {
	font-size: 2.4rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.6;
	padding: 0 0 10px;
}

.form_area .complete_txt {
	margin: 30px 0 50px;
	line-height: 1.8;
	text-align: center;
}

.form_area .back_link {
	margin: 60px 0 20px;
	text-align: center;
	font-family: 'Noto Sans JP', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}


/* -----------------------------------------------------------
    SP
-------------------------------------------------------------- */

@media screen and (max-width:768px) {
	/* -----------------------------------------------------------
		input
	-------------------------------------------------------------- */
	.form_area input[type="text"],
	.form_area input[type="tel"],
	.form_area input[type="password"],
	.form_area input[type="email"],
	.form_area input[type="number"],
	.form_area select,
	.form_area textarea {
		padding: 15px;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		font-size: 1.6rem;
		-webkit-appearance: none;
		border-radius: 0;
	}
	.form_area input[type="text"],
	.form_area input[type="email"],
	.form_area input[type="number"],
	.form_area input[type="tel"],
	.form_area input[type="password"],
	.form_area select,
	.form_area textarea {
		width: 100%;
	}
	.form_area select {
		padding: 10px 15px;
		background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
		background-size: 18px auto
	}
	.form_area td.area select {
		width: 100%;
		padding: 10px 15px;
		background: #fff url(../img/icon_arrow_under.png) no-repeat 95% 50%;
		background-size: 18px auto
	}
	.form_area input[type="radio"],
	.form_area input[type="checkbox"] {}
	/* -----------------------------------------------------------
		button / submit
	-------------------------------------------------------------- */
	.btn {}
	.btn.back_btn {
		top: 0;
	}
	.btn.back_btn a {
		display: inline-block;
		width: auto;
		padding: 10px 5px 10px 20px;
		border: none;
		font-size: 1.6rem;
		text-align: left;
		background: #fff url(../img/icon_arrow03.png) no-repeat 0 50%;
		background-size: 11px 11px;
	}
	.form_area input[type="submit"] {
		display: block;
		width: 100%;
		max-width: 320px;
		padding: 25px 10px 28px;
		font-size: 1.80rem;
		box-sizing: border-box;
		box-shadow: 2px 2px 3px #DDD;
	}
	#form input[type="submit"],
	#form input[type="button"] {
		min-width: inherit;
	}
	input[type="submit"].submit_gray,
	input[type="button"].submit_gray {
		width: 100%;
		font-size: 1.4rem;
		padding: 10px 10px;
	}
	.form_btn_area {
		padding: 30px 20px 0;
		/* text-align: left; */
	}
	.form_btn_txt {
		margin: 0 0 20px;
		line-height: 1.8;
		/*
		text-align: center;
		*/
		/* text-align: left; */
	}
	.submit_org {}
	.submit_gray {
		font-size: 1.4rem;
		box-shadow: 2px 2px 3px #DDD;
	}
	.submit_magenta {}
	.submit_green {}
	.form_btn_area .fl,
	.form_btn_area .fr {
		float: none;
	}
	.form_btn_area .fr {
		margin: 30px 0 0 0;
	}
	.error_message {
		text-align: left;
		padding: 30px 0 20px;
	}
	/* -----------------------------------------------------------
		フォーム共通
	-------------------------------------------------------------- */
	.form_toptxt {
		padding: 0 20px 0;
		line-height: 1.8;
		text-align: left;
	}
	.form_toptxt.s {
		padding: 0 0 0 0;
		font-size: 1.3rem;
	}
	/* -----------------------------------------------------------
		入力画面共通  /  table
	-------------------------------------------------------------- */
	.form_table {
		margin: 20px 0 0;
	}
	.form_table tr {
		border: none;
	}
	.form_table th {
		display: block;
		width: 100%;
		padding: 15px 15px;
		text-align: left;
		vertical-align: middle;
		border-top: 1px #ddd solid;
	}
	.form_table tr:first-of-type th {
		border-top: none;
	}
	.form_table tr:last-child td {
		border-bottom: 1px solid #ddd;
	}
	.form_table td {
		display: block;
		width: 100%;
		border: none;
		padding: 0 20px 20px 20px;
		text-align: left;
		vertical-align: top;
	}
	.form_table td .size-item {
		display: flex;
		align-items: center;
	}
	.form_table td .size-item input {
		max-width: 200px;

	}
	.form_th_title {
		padding: 0;
	}
	.form_table th .form_th_notes {
		float: none;
		display: inline-block;
		margin: -5px 0 0 10px;
		padding: 2px 10px;
		font-size: 1.2rem;
		font-weight: bold;
		background: #E94647;
	}
	.form_table.rec th .form_th_notes {
		background: #66CCC0;
	}
	.form_table input[type="text"],
	.form_table input[type="password"],
	.form_table input[type="tel"],
	.form_table input[type="email"],
	.form_table select {
		width: 100%;
	}
	.form_table input[type="number"] {
		width: 100%;
	}
	/*		生年月日		*/
	.form_area input[type="text"].birth {
		width: 50%;
	}
	/*		郵便番号		*/
	.form_area input[type="text"].input_zip,
	.form_area input[type="number"].input_zip {
		width: 50%;
		margin: 0 10px 0 10px;
	}
	/*		年齢		*/
	.form_area input[type="number"].input_old {
		width: 40%;
		margin: 0 10px 0 0;
	}
	/*		お問い合わせ		*/
	.radio_list {}
	.radio_list li {
		line-height: 1.8;
	}
	.radio_list label {
		display: block;
		padding: 5px;
	}
	/*		注釈		*/
	.form_td_notes {
		display: inline-block;
		margin: 10px 0 0;
		font-size: 1.4rem;
	}
	.form_td_notes02 {
		margin: 10px 0;
		font-size: 1.4rem;
	}
	.form_td_notes03 {
		margin: 10px 0 0;
		font-size: 1.4rem;
	}

	/* -----------------------------------------------------------
		確認画面
	-------------------------------------------------------------- */
	.form_btn_area.confirm .btn-wrap{
		flex-direction: column-reverse;
		justify-content: center;
		width: 100%;
	}

	/*最後の枠　js用*/
	.form_table.last {
		margin-bottom: 20px;
	}

	.form_btn_area.confirm .btn-wrap input {
		max-width: 320px;
		margin: 0 auto 20px;
		padding: 25px 10px;
	}

	/* -----------------------------------------------------------
		完了画面共通
	-------------------------------------------------------------- */
	.form_area .complete_title {
		font-size: 2.0rem;
		padding: 0 0 0;
	}
	.form_area .complete_txt {
		margin: 20px 0 15px;
		text-align: left;
	}
	.form_area .back_link {
		margin: 30px 0 20px;
		text-align: left;
	}
}

.copy {
	padding: 0 0 40px;
	font-size: 1.2rem;
	text-align: center;
}


/* -----------------------------------------------------------
    order
-------------------------------------------------------------- */

.order_table {
	width: 100%;
	border-collapse: collapse;
	margin: 30px auto;
}

.order_table th {
	background-color: #999;
	border: solid 1px #ddd;
	padding: 10px;
	color: #fff;
}

.form_area .order_table input {
	border: none;
}

.form_area .order_table input:focus {
	border: none;
	background: #EFF5F9;
}

.order_table .sample {
	background: #f0f0f0;
}

.order_table .sample td:nth-of-type(2),
.order_table .sample td:nth-of-type(3) {
	padding: 15px;
}

.order_table td {
	border-bottom: solid 1px #ddd;
	border-right: solid 1px #ddd;
}

.order_table td:first-of-type {
	width: 60px;
	text-align: center;
	border-left: solid 1px #ddd;
}

.order_table td:nth-of-type(2) {
	width: 580px;
}

.order_table td:nth-of-type(3) {
	width: 140px;
}

.order_table input {
	width: 100%;
}
#form {
	position:relative;
	z-index:0 !important;
}
#form .g-recaptcha-response {
	position:relative;
	z-index:10 !important;
}

@media screen and (max-width:768px) {
	.order_table {
		width: auto;
		margin: 20px -20px 0;
	}
}
table td ul li{
	padding: 0;
	margin: 0;
}
table td ul li::before{
	content: none;
}

/* -----------------------------------------------------------
    製品予約フォーム
-------------------------------------------------------------- */
#form .intro-area{
	margin: 110px auto 0;
}
#form .intro-area span{
	font-weight: bold;
	color: var(--main-color);
}
#form .intro-area .top-box{
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 80px 40px;
	margin: 0 0 30px;
}
.contact #form .intro-area .top-box{
	background-image: url(../img/bg-contact.jpg);
}
.delivery #form .intro-area .top-box{
	background-image: url(../img/bg-contact-deli.jpg);
	background-position: right;
}
.dressreserve #form .intro-area .top-box{
	background-image: url(../img/bg-contact-dress.jpg);
	background-position: right;
}
#form .intro-area .top-box .ttl{
    font-size: 3.0rem;
    line-height: 1.5;
    /* letter-spacing: 0.15em; */
    color: #333;
    text-shadow: 3px 3px 0 rgba(255,255,255,0.4), -3px -3px 0 rgba(255,255,255,0.4), -3px 3px 0 rgba(255,255,255,0.4), 3px -3px 0 rgba(255,255,255,0.4), 0px 3px 0 rgba(255,255,255,0.4), 0 -3px 0 rgba(255,255,255,0.4), -3px 0 0 rgba(255,255,255,0.4), 3px 0 0 rgba(255,255,255,0.4);
}
#form .intro-area .fs-box{
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	margin: 30px 0;
}
#form .intro-area .fs-box .tel-box{
	padding: 30px;
	background-image: url(../img/frame600-top.png) , url(../img/frame600-bot.png);
	background-position: top , bottom;
	background-size: contain;
}
#form .intro-area .fs-box .tel-box .ttl{
	color: var(--main-color);
	font-size: 2.0rem;
	margin: 0 0 15px;
	text-align: center;
}
#form .intro-area .fs-box .tel-box .tel:nth-child(n + 3){
	margin: 15px 0 0;
	font-size: 1.5rem;
}
#form .intro-area .fs-box .tel-box .shop-name{
	position: relative;
	padding: 0 0 0 25px;
	font-size: 2.0rem;
	color: #333;
}
#form .intro-area .fs-box .tel-box .shop-name::before{
	position: absolute;
	content: "";
	background-image: url(../img/icon-rose-gold.png);
	width: 20px;
	height: 20px;
	background-size: cover;
	left: 0;
	top: 7px;
}
#form .intro-area .fs-box .tel-box i{
	margin: 0 10px 0 0;
	font-size: 2.2rem;
}
#form .intro-area .fs-box .tel-box a{
	font-size: 3.0rem;
	font-weight: bold;
	font-family: 'Lato', sans-serif;
}
#form .intro-area{
	background: none;
}

/* バナー */
#form .intro-area .bnr{
	width: 1200px;
	/* background-image: url(../img/bg-banner.jpg); */
	background-image: url(../img/frame1200-top.png) , url(../img/frame1200-bot.png) , url(../img/bnr-flow01.png) ,url(../img/bg-damasku01.jpg);
	background-repeat: no-repeat;
    background-position: top , bottom , left,center;
    padding: 40px 40px 40px 0;
    margin: 40px 0 0;
	position: relative;
	/* display: flex;
	align-items: center;
	gap: 60px; */
	/* display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 60px; */
	box-shadow: 0px 5px 30px rgb(0 0 0 / 16%);
	transition: .5s;
}
#form .intro-area .bnr a{
	width: 100%;
	height: 100%;
	display: flex;
	align-items: flex-end;
	/* justify-content: space-between; */
	gap: 60px;
	position: relative;
}
#form .intro-area .bnr:hover{
	box-shadow: none;
	transition: .5s;
}
#form .intro-area .bnr a::before{
    position: absolute;
    content: "";
    background-image: url(../img/illust-butterfly.png);
    width: 86px;
    height: 112px;
	background-size: cover;
	top: -70px;
    right: -20px;
}
/* #form .intro-area .bnr::after{
    position: absolute;
    content: "";
    background-image: url(../img/illust-rose.png);
    width: 128px;
    height: 104px;
	left: 25px;
    bottom: -50px;
} */
#form .intro-area .bnr .en{
	font-family: 'Tangerine', cursive;
    font-size: 3.0rem;
    color: var(--main-color);
    line-height: 1;

	/* position: absolute;
	top: 20px; */
	/* transform: rotate(-15deg); */
}
#form .intro-area .bnr img{
	border-radius: 0 60px 0 0;
}
#form .intro-area .bnr .txt-box{
	padding: 0 0 0 380px;
}
#form .intro-area .bnr .catch{
	margin: 0 0 5px;
	font-size: 2.0rem;
}
#form .intro-area .bnr .ttl{
	margin: 0 0 8px;
	font-size: 3.0rem;
}
#form .intro-area .bnr .more-txt{
	width: 220px;
    line-height: 50px;
    height: 50px;
    margin: 35px 0 0;
	font-size: 1.7rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    position: relative;
    text-align: center;
	color: #fff;
    background-color: #E3979F;
	position: relative;
}
#form .intro-area .bnr .more-txt::after{
	position: absolute;
    content: "";
    background-image: url(../img/arrow-gold.png);
    background-repeat: no-repeat;
    background-size: cover;
    width: 34px;
    height: 7px;
    top: 50%;
    right: -20px;
    transition: all 0.3s ease;
}
#form .intro-area .bnr:hover .more-txt::after{
	right: -25px;
	transition: all 0.3s ease;
}
/* #form .intro-area .bnr .btn a{
    width: 220px;
    line-height: 50px;
    height: 50px;
	pointer-events: none;
} */
@media screen and (max-width: 768px) {
	#form .intro-area .fs-box{
		display: block;
	}
	.delivery #form .intro-area .fs-box{
		display: flex;
		flex-wrap: wrap;
	}
	.delivery #form .intro-area .fs-box .txt-box{
		order: 1;
	}
	.delivery #form .intro-area .fs-box .tel-box{
		order: 3;
	}
	.delivery #form .intro-area .fs-box .bnr{
		order: 2;
	}
	#form .intro-area .top-box{
		padding: 40px 50px 40px 10px;
	}
	#form .intro-area .top-box .ttl{
		font-size: 1.8rem;
		text-shadow: 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff, 0 0 3px #fff;
	}
	#form .intro-area .fs-box .tel-box{
		margin: 30px 0 0;
		padding: 40px 20px;
		background-image: url(../img/frame-sp-top.png) , url(../img/frame-sp-bot.png);
		background-position: top , bottom;
	}
	#form .intro-area .fs-box .tel-box .shop-name{
		font-size: 1.8rem;
	}
	#form .intro-area .fs-box .tel-box .tel{
		font-size: 1.5rem;
	}
	#form .intro-area .fs-box .tel-box a{
		font-size: 2.5rem;
	}
	#form .intro-area .fs-box .tel-box i{
		font-size: 2.1rem;
	}
	/* バナー */
	/*
	#form .intro-area .bnr{
		width: 100%;
		height:130px;
		padding: 30px 20px 20px;
		background-image: url(../img/frame-sp-top.png) , url(../img/frame-sp-bot.png) , url(../img/bnr-flow-sp.jpg);
		background-position: top , bottom , center;
		background-size: contain,contain,cover;
		margin: 15px 0 0;
	}
	#form .intro-area .bnr .txt-box{
		padding: 0;
	}
	#form .intro-area .bnr a{
		align-items: center;
	}
	#form .intro-area .bnr a::before{
		position: absolute;
		content: "";
		background-image: url(../img/arrow-gold.png);
		width: 36px;
		height: 7px;
		right: 0;
		top: auto;
		bottom: 0;
		background-size: cover;
		transition: .5s;
	}
	#form .intro-area .bnr .en{
		position: absolute;
		top: -35px;
		left: 20px;
	}
	#form .intro-area .bnr .catch{
		font-size: 1.6rem;
		margin: 0 0 5px;
	}
	#form .intro-area .bnr .ttl{
		font-size: 1.8rem;
	}
	#form .intro-area .bnr .txt{
		font-size: 1.5rem;
	}
	*/

	/* バナー */
	#form .intro-area .bnr{
		width: auto;
		background: none;
		padding: 0;
		box-shadow: none;
		margin: 20px 0 0;
	}
	#form .intro-area .bnr a{
		display: block;
		color: #C74171;
		font-size: 1.7rem;
		line-height: 1.5;
	}
	#form .intro-area .bnr a::before{
		font-family: "FontAwesome";
		content: "\f105";
		background: none;
		width: auto;
		height: auto;
		top: 5px;
		right: auto;
		left: 0;
	}
	#form .intro-area .bnr .en{
		display: none;
	}
	#form .intro-area .bnr .txt-box{
		padding: 0 0 0 20px;
		margin: 0 0 0;
	}
	#form .intro-area .bnr .catch{
		display: none;
	}
	#form .intro-area .bnr .ttl{
		margin: 0 0 0;
		font-size: 1.8rem;
	}
	#form .intro-area .bnr .txt{
		font-size: 1.6rem;
	}

}




/* -----------------------------------------------------------
    製品予約フォーム
-------------------------------------------------------------- */

/* .dressreserve .intro-area ul{
	display: flex;
}
.dressreserve .intro-area ul li{
	padding: 20px;
	background-color: #fff;
	border-radius: 20px;
}
.dressreserve .intro-area .kome{
	color: var(--main-color);
	font-size: 1.5rem;
} */
.form_table.type2{
    border: 1px solid #ccc;
}
.form_table.type2 th{
	background-color: #F8F4F3;
	padding: 30px;
}
.form_table.type2 th .txt{
	font-weight: normal;
	font-size: 1.5rem;
}
.form_table.type2 td{
	padding: 30px;
}
.form_table.type2 td .list-ttl{
	margin: 20px 0 0;
	font-weight: bold;
}
.form_table.type2 td li:first-of-type .list-ttl{
	margin: 0;
}
.form_table.type2 td .caution{
	font-size: 1.5rem;
	margin: 20px 0 0;
}
.dressreserve .box{
	border: solid 1px var(--main-color);
	padding: 60px;
}
.table-ttl{
	font-size: 2.0rem;
	font-weight: bold;
	margin: 60px 0 0;
	position: relative;
	padding: 0 0 0 20px;
}
.table-ttl::before{
	position: absolute;
	content: "";
	background-color: var(--main-color);
	width: 5px;
	border-radius: 25%;
	height: 100%;
	top: 2px;
	left: 0px;
}
@media screen and (max-width: 768px) {
	.table-ttl{
		width: calc(100% - 40px);
		margin: 50px auto 0;
		padding: 0 20px;
	}

	.form_table.type2{
		border: none;
	}
	.form_table.type2 th{
		padding: 15px 20px;
	}
	.form_table.type2 td{
		padding: 20px 20px 30px;
	}

}



/* -----------------------------------------------------------
    label 装飾
-------------------------------------------------------------- */

.color_input input[type="checkbox"],
.color_input input[type="radio"]{
    display: none;
}
.color_input input[type="checkbox"] + label,
.color_input input[type="radio"] + label{
	display: block;
	position: relative;
	padding: 10px 10px 10px 35px;
	font-size: 1.6rem;
	line-height: 1.3;
	color: #333;
	cursor: pointer;
	border: 1px #ddd solid;
	border-radius: 0;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;

	text-align: left;
}
.color_input input[type="checkbox"]:checked + label,
.color_input input[type="radio"]:checked + label{
    /*
	background: #ff7b94;
    color: #fff;
    color: #ff7b94;
    */
    border: 1px #ff7b94 solid;
    background: #FFEEF1;
}

.color_input input[type="checkbox"] + label:before,
.color_input input[type="radio"] + label:before{
	content: "";
	display: block;
    position: absolute;
	top: 12px;
    left: 10px;
    width: 16px;
    height: 16px;
    border: 1px solid #ddd;
    border-radius: 50%;
    background: url("../img/icon-check-wht.svg") #e0e0e0 no-repeat center center / 10px auto;
}
.color_input input[type="checkbox"]:checked + label:before,
.color_input input[type="radio"]:checked + label:before{
    border: 1px solid #ff7b94;
    background: url("../img/icon-check-wht.svg") #ff7b94 no-repeat center center / 10px auto;
}


/* シンプルラジオボタン */
.simple_input input[type="checkbox"],
.simple_input input[type="radio"]{
    display: none;
}
.simple_input input[type="checkbox"] + label,
.simple_input input[type="radio"] + label{
    position:relative;
    padding: 0 0 0 26px;
    font-size: 1.6rem;
    cursor: pointer;
	text-align: left;
}
.simple_input input[type="checkbox"] + label::before,
.simple_input input[type="radio"] + label::before{
    content: "";
    display: block;
    position: absolute;
    /*
    top: 3px;
    left: 3px;
    */
    top: 0;
    left: 0;
    width: 16px;
    height: 16px;
    border: 1px solid #ddd;
    background: #fff;
    border-radius: 50%;
}
.simple_input input[type="checkbox"]:checked + label::after,
.simple_input input[type="radio"]:checked + label::after{
    content: "";
    display: block;
    position: absolute;
    /*
    top: 6px;
    left: 6px;
    */
    top: 4px;
    left: 4px;
    width: 8px;
    height: 8px;
    background: #ff7b94;
    border: 1px solid #ff7b94;
    border-radius: 50%;
}
.simple_input input[type="checkbox"]:checked + label,
.simple_input input[type="radio"]:checked + label{
    /*
    color: #ff7b94;
    */
    font-weight: bold;
}
.simple_input input[type="checkbox"] + label::before{
    /*
    border-radius: 0;
    */
}
.simple_input input[type="checkbox"]:checked + label::after{
    /*
	background: #FE696F;
	content: "\f00c";
	font-family: FontAwesome;
	color: #fff;
    */
    background: url("../img/icon-check-wht.svg") #ff7b94 no-repeat center center / 10px auto;
	font-size: 1.4rem;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 16px;
    height: 16px;
    top: 0;
    left: 0;
}


/* toggle on off */
.toggle_btn {
	position: relative;
	width: 48px;
	height: 28px;
	border-radius: 50px;
	overflow: hidden;
	cursor: pointer;
}
.toggle_btn input[type=checkbox] {
	display: none;
}
.toggle_btn:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: block;
	background: #e0e0e0;
	-webkit-transition: 0.2s ease-out;
	transition: 0.2s ease-out;
}
.toggle_btn:after {
	content: "";
	position: absolute;
	top: 3px;
	left: 3px;
	width: 22px;
	height: 22px;
	display: block;
	border-radius: 50px;
	background: #fff;
	box-shadow: 0 9px 28px -6px rgba(0, 0, 0, 0.3);
	-webkit-transition: 0.2s ease-out;
	transition: 0.2s ease-out;
}
.toggle_btn.checked:before {
	background: #35c759;
}
.toggle_btn.checked:after {
	left: 23px;
	box-shadow: 0 9px 28px -6px rgba(0, 0, 0, 0.5);
}


/*20240409*/
.page-title-area {
	margin: 0 0 0 0;
}

/*20240618 追記*/
/* -----------------------------------------------------------
    個人情報の取り扱いについて
-------------------------------------------------------------- */
.privacy-box {
	background: #fff;
    border: 1px solid #ddd;
	font-size: 1.5rem;
    line-height: 1.6;
    width: 100%;
    height: 240px;
    overflow: auto;
    padding: 40px 50px;
	margin: 0 0 60px;
	text-align: left;
}
.privacy-box .head-ttl {
    font-size: 2.6rem;
    line-height: 1.2;
    padding: 0 0 0 20px;
    border-left: 6px solid var(--main-color);
    margin: 0 0 20px;
}
.privacy-box .ttl {
	font-size: 1.8rem;
	line-height: 1.4;
    padding: 30px 0 10px;
	color: var(--main-color);
}
.privacy-box .ttl:nth-of-type(1){
	padding: 0 0 10px;
}
.privacy-box .bg-box {
	background: #eee;
	border-radius: 5px;
	font-weight: bold;
	margin: 15px 0 0;
	padding: 20px;
}
.privacy-box .contact-box {
    margin: 20px auto 0;
    /* border-radius: 20px; */
    /* border: var(--main-color) solid 3px; */
    position: relative;
    padding: 30px 30px;
    max-width: 1200px;
    background-color: var(--accent-color-light);
}

.form_btn_area .check-btn {
	margin: 0 0 50px;
	font-size: 1.8rem;
	letter-spacing: 0;
	font-weight: 500;
}
.form_btn_area .check-btn input[type=checkbox] {
	transform: scale(1.4, 1.4);
	vertical-align: middle;
}
.privacy-box .end-txt {
	text-align: right;
	padding: 10px 0 0;
}

/*同意しないボタン*/
.top-btn-area {
    
}
.top-btn-area a {
	display: block;
	background: #fff;
    border-radius: 50px;
	margin: 40px auto 0;
	padding: 15px 30px;
	width: 350px;
    height: auto;
	color: #888;
	font-size: 1.8rem;
	line-height: 1.2;
	border: 1px #ccc solid;
}
.top-btn-area span {
   font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
	.privacy-box {
		padding: 15px;
		height: 200px;
		margin: 0 0 40px;
	}
	 .privacy-box .head-ttl {
        font-size: 2.0rem;
        line-height: 1.4;
        padding: 0 0 0 15px;
        margin: 0 0 20px;
    }
	.privacy-box .ttl {
		padding: 20px 0 5px;
		font-size: 1.6rem;
	}
	.privacy-box .ttl:nth-of-type(1) {
		padding: 0 0 5px;
	}
	.privacy-box .bg-box {
		padding: 15px;
	}
	.privacy-box .contact-box {
		font-size: 1.6rem;
		margin: 20px 0 30px;
		padding: 20px 20px;
		max-width: 100%;
	}
	
	.form_btn_area .check-btn {
		margin: 0 0 40px;
	}
	
	/*同意しないボタン*/
	.top-btn-area {

	}
	
	.top-btn-area a {
		margin: 30px auto 0;
		padding: 15px 10px;
		width: 100%;
		max-width: 320px;
		font-size: 1.8rem;
	}
	.top-btn-area span {
	}

}

/*20254010 注釈追加*/
.txt-note {
	color: #CC0000;
	padding-left:1em;
	text-indent:-1em;
}
.txt-note a {
	color: #CC0000;
}