@charset "utf-8";

/* -----------------------------------------------------------
    form
-------------------------------------------------------------- */
/*#main{
	margin: 0;
}
#header{
	position: relative;
    z-index: 100;
}
.page-title-area{
	margin: 0 auto;
}
#nav-container,
#nav-toggle{
	position: absolute;
}
@media screen and (max-width: 768px){
	.h1-area.type02{
		top: 0px
	}
	.page-title-area.type02{
		margin: 0;
	}
	#sp-header{
		position: absolute;
	}
}*/

/* イントロ */
#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: flex-start;
}
#form .intro-area .txt-wrap{
	width: calc(100% - 440px);
}
#form .intro-area .catch-box{
	padding: 20px;
	display: flex;
	align-items: center;
	background: var(--main-color);
	margin: 0 0 20px;
	position: relative;
	/* background: url(../img/bg-texture01.jpg) no-repeat top 20px left 20px / calc(100% - 40px) calc(100% - 40px) var(--main-color); */
}
#form .intro-area .catch-box::before{
	position: absolute;
    content: "";
    background-color: var(--yellow);
    width: 20%;
    min-width: 240px;
    aspect-ratio: 4 / 3;
    top: 0px;
    right: 0;
    z-index: 0;
}
#form .intro-area .catch-box::after{
	position: absolute;
    content: "";
    background-color: #4C6EC2;
    width: 20%;
    min-width: 240px;
    aspect-ratio: 8 / 5;
    bottom: 0px;
    left: 0;
    z-index: 0;
}
#form .intro-area .catch-box .txt-box{
	width: calc(100% - 345px);
	position: relative;
	height: fit-content;
	min-height: 203px;
	padding: 20px;
	background: url(../img/bg-texture01-sp.jpg) no-repeat center / cover;
}
#form .intro-area .catch-box .txt-box .catch{
	font-size: 2.2rem;
	font-weight: 600;
	color: var(--main-color);
}
#form .intro-area .catch-box .txt-box .catch span{
	font-size: 1.6rem;
	letter-spacing: -0.05em;
	display: block;
}
#form .intro-area .catch-box .txt-box .acc{
	font-size: 1.5rem;
	color: #707070;
	letter-spacing: 0.06em;
}
#form .intro-area .catch-box .txt-box .time{
	font-size: 3.2rem;
	line-height: 1;
	font-weight: bold;
	letter-spacing: 0.02em;
	color: #D42525;
	margin: 15px 0 5px;
}
#form .intro-area .catch-box .txt-box .time .num{
	font-family: var(--heebo);
	font-size: 5.6rem;
	font-weight: 800;
	letter-spacing: 0;
	margin: 0 5px;
}
#form .intro-area .img {
	height: 100%;
	/* min-height: 210px; */
	width: 345px;
	position: relative;
	z-index: 1;
}
#form .intro-area .img img{
	width: 100%;
    height: 100%;
	/* min-height: 210px; */
    object-fit: cover;
}
#form .intro-area .cv-box{
	background-color: var(--rightblue);
	border-radius: 10px;
	padding: 30px 40px;
}
#form .intro-area .cv-box .ttl{
	font-size: 2.0rem;
	text-align: center;
	color: var(--main-color);
	margin: 0 0 30px;
	font-weight: bold;
}
#form .intro-area .cv-box .tel-box{
	text-align: center;
}
#form .intro-area .cv-box .tel-box .catch{
    font-size: 1.7rem;
    font-weight: bold;
    text-align: center;
    position: relative;
    color: var(--main-color);
}
#form .intro-area .cv-box .tel-box .catch::before,
#form .intro-area .cv-box .tel-box .catch::after{
    content: "";
    display: inline-block;
    width: 20px;
    height: 1.5px;
    background: var(--main-color);
    vertical-align: middle;
}
#form .intro-area .cv-box .tel-box .catch::before{
    transform: rotate(70deg);
}
#form .intro-area .cv-box .tel-box .catch::after{
    transform: rotate(-70deg);
}
#form .intro-area .cv-box .tel-box a{
    font-family: var(--font-en);
    font-size: 3.6rem;
    font-weight: bold;
    margin: 5px 0;
    display: inline-block;
    position: relative;
    padding: 0 0 0 30px;
}
#form .intro-area .cv-box .tel-box a::before{
    content: "";
    width: 27px;
    height: 27px;
    background: url(../img/icon-tel.svg) no-repeat center / contain;
    margin: 0 6px 0 0;
    left: 0;
}
#form .intro-area .cv-box .tel-box a i{
    font-size: 3.2rem;
}
#form .intro-area .cv-box .tel-box .time{
    font-size: 1.4rem;
    text-align: center;
    font-weight: 500;
}
#form .intro-area .cv-box .btn-box .btn{
	display: block;
    text-align: center;
    width: 320px;
    height: 90px;
    color: #fff;
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 90px;
    border-radius: 8px;
    position: relative;
    box-shadow: 0px 3px 20px rgba(0, 0, 0, 0.16);
	background: var(--line);
	margin: 20px auto 0;
	z-index: 1;
	overflow: hidden;
}
#form .intro-area .cv-box .btn-box .btn::before{
	position: absolute;
    content: "";
    width: 104px;
    height: 90px;
    background: url(../img/logomark-wh.svg) no-repeat center center / cover;
    right: 0;
    top: 0px;
    opacity: 0.2;
}
#form .intro-area .cv-box .btn-box .btn::after{
	content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
    transition: all .4s;
    z-index: -1;
	background: #0AC959;
}
#form .intro-area .cv-box .btn-box .btn:hover::after{
    width: 100%;
    left: 0;
}
#form .back-link{
	text-align: center;
}
#form .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(--navy);
}
.f-copy.single{
	margin: 0 auto;
    font-size: 1.3rem;
    padding: 50px 0;
    text-align: center;
}
@media screen and (max-width: 768px) {

	/* イントロ */
	#form .intro-area.inner{
		flex-wrap: wrap;
		padding: 0 20px;
		margin: 40px auto 0;
	}
	#form .intro-area .txt-wrap{
		width: 100%;
	}
	#form .intro-area .catch-box{
		flex-wrap: wrap;
	}
	#form .intro-area .catch-box .txt-box{
		width: 100%;
		z-index: 1;
		min-height: auto;
	}
	#form .intro-area .catch-box .txt-box .catch{
		font-size: 2.0rem;
		letter-spacing: -0.05em;
	}
	#form .intro-area .catch-box .txt-box .catch span{
		font-size: 1.3rem;
	}
	#form .intro-area .catch-box .txt-box .time{
		font-size: 2.8rem;
	}
	#form .intro-area .catch-box .txt-box .time .num{
		font-size: 4.0rem;
	}
	#form .intro-area .catch-box .txt-box .acc{
		font-size: 1.4rem;
	}
	#form .intro-area .cv-box{
		width: 100%;
		padding: 30px 20px;
		margin: 30px 0 0;
	}
	/* #form .intro-area {
		padding: 0 20px;
		display: block;
		margin: 0 0 15px;
	}

	#form .intro-area.inner {
		width: 100%;
		flex-wrap: wrap;
		padding: 0;
		margin: 0;
		background-size: 250px;
		background-position: left bottom -20px;
	}
	#form .intro-area.inner .img{
		width: 100%;
		margin: 0px;
	}
	#form .intro-area.inner .img img{
		max-width: 100%;
		width: 100%;
		height: 200px;
	}
	#form .intro-area.inner .txt-box{
		order: 2;
		width: 100%;
		padding: 20px;
	}
	#form .intro-area.inner .catch{
		margin: 0 0 15px;
		font-size: 2.4rem;
	} */
}


/* フォームエリア */
#form .form_area {
	padding: 20px 0 30px;
}
/* スパム対策------------- */
#form .form_area .husegutospm{
	display: none;
}
/* -------------スパム対策 */
#form .form_area .contact_form .wrap .unit{
	display: flex;
	align-items: center;
	padding: 30px 0 30px;
	border-bottom: 1px solid #ddd;
}
#form .form_area .contact_form .wrap .unit.type02{
	padding: 0;
	border: none;
}
#form .form_area .contact_form .wrap .title{
	width: 35%;
    padding: 30px 50px;
    text-align: left;
    font-weight: bold;
    vertical-align: top;
	position: relative;
}
#form .form_area .contact_form .wrap .title span{
	display: inline-block;
    margin: 5px 0 0;
    padding: 3px 12px;
    font-size: 1.3rem;
    font-weight: bold;
    color: #fff;
    background: #E94647;
	position: absolute;
    right: 50px;
}
#form .form_area .contact_form .wrap .text{
	width: 80%
}
#form .form_area .contact_form .wrap .select{
	width: 80%;
}
#form .form_area .contact_form .wrap .select select{
	width: 100%;
}
#form .form_area .contact_form .wrap textarea{
	width: 80%;
}
#form .form_area .contact_form  .wrap .checkbox.top{
	margin: 60px 0 40px;
	text-align: center;
}
#form .form_area .contact_form  .wrap .btn{
	display: block;
	color: #fff;
	min-width: 350px;
    border-radius: 50px;
    height: 70px;
    background: var(--navy);
    font-size: 1.9rem;
	margin: 0 auto 30px;
}
#form .form_area .contact_form  .wrap .note{
	text-align: center;
}
@media screen and (max-width: 768px) {
	#form .form_area{
		padding: 20px 20px 0;
	}
	#form .form_area .contact_form .wrap .unit{
		display: block;
		padding: 15px 0 20px;
	}
	#form .form_area .contact_form .wrap .title{
		width: 100%;
		margin: 0 auto;
		padding: 15px 0px;
	}
	#form .form_area .contact_form .wrap .text{
		width: 100%;
    display: block;
    margin: 0 auto;
	}
	#form .form_area .contact_form .wrap .title span{
		font-size: 1.2rem;
		margin: 0px;
		right: 0;
	}
	#form .form_area .contact_form .wrap .select{
		width: 100%;
		margin: 0 auto;
	}
	#form .form_area .contact_form .wrap textarea{
		width: 100%;
		display: block;
		margin: 0 auto;
	}
	#form .form_area .contact_form .wrap .checkbox.top{
		margin: 30px 0 30px;
	}
	#form .form_area .contact_form .wrap .btn{
		width: 100%;
		min-width: 100%;
	}
}
/* -----------------------------------------------------------
    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"]{
	vertical-align: -1px;
	margin: 0 12px 0 0;
	font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	border-radius: 0;
	visibility: hidden;
}

.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: 70px;
	background: var(--navy);
	font-size: 1.9rem;
	padding: 0;
	line-height: 70px;
}

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

/* #form input[type="submit"] {
	background: var(-navy);
} */

#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;
}

.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: 300px;
		padding: 25px 10px;
		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: 300px;
		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: 80px auto 0;
}
/* #form .intro-area .catch-box 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: var(--font-en);
}
#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);
}

.radio_list li:not(:last-of-type){
	margin: 0 0 10px;
}
.radio-label{
	position: relative;
    min-width: 10%;
    display: flex;
    margin: 0 0 0 -25px;
}
.radio-label .label-check {
	position: relative;
	display: block;
	padding-left: 30px;
	cursor: pointer;
	transition: .5s;
	line-height: 1.5;
	font-size: 1.6rem;
}
.radio-label .label-check:before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	display: block;
	margin: auto;
	width: 18px;
	height: 18px;
}
.radio-label input[type="radio"]:checked + .label-check:after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 5px;
	display: block;
	margin: auto;
}

.radio-label input[type="radio"]:checked + .label-check:before {
	border-color: var(--main-color);
}

.radio-label .label-check.round:before {
	border: 1px solid #bfbfbf;
	border-radius: 40px;
}

.radio-label input[type="radio"]:checked + .label-check.round::after {
	width: 10px;
	height: 10px;
	background-color: var(--main-color);
	border-radius: 40px;
}
input[type="checkbox"]{
	visibility: visible;
	transform: scale(1.4);
    vertical-align: middle;
    margin-right: 15px;
}
input[type="checkbox"]:checked{
	accent-color: var(--main-color);
}

input[type="checkbox"]:checked + label {
	color: var(--main-color);
}
.check-list li{
	font-size: 1.6rem;
}