@charset "utf-8";
/* Copyright 2023 FSFIELD All Rights Reserved. */

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

パソコン、タブレット、スマートフォン（iPhone,Android) 共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

/* ------------------------------------------------------------

フォーム共通

------------------------------------------------------------ */

.visually-hidden{
	position: absolute !important;
	top: 0px !important;
	left: 0px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	overflow: hidden !important;
	border: none !important;
	margin: 0 !important;
	padding: 0 !important;
	display: block !important;
	visibility: visible !important;
}

/* ------------------------------------------------------------

フォーム関連

------------------------------------------------------------ */

.form{width: 100%;}

.form th,
.form td{padding: 15px 0;}

.form th{
	position: relative;
	width: 220px;
	padding-right: 50px;
	font-weight: 700;
}

.form th.align_top{
	vertical-align: top;
	padding-top: 28px;
}

.form td{word-break: break-all;}

.form input[type="text"],
.form input[type="email"],
.form input[type="password"],
.form input[type="tel"],
.form input[type="url"],
.form input[type="number"],
.form textarea{
	border: 1px solid #DAC7AA;
	padding: 22px 20px;
	border-radius: 6px;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	font-size: 1.6rem;
}

.form input::-moz-focus-inner,
.form select::-moz-focus-inner{border: 0;}/* Firefox 点線消す */

.form textarea{
	display: block;
	resize: vertical;
	width: 100%;
	min-height: 200px;
}

.form textarea::-moz-focus-inner{border: 0;}/* Firefox 点線消す */

.form textarea::-webkit-input-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form textarea::-moz-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form textarea::-ms-input-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form input::-webkit-input-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form input::-moz-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form input::-ms-input-placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}
.form input::placeholder{
	color: #DAC7AA;
	font-size: 1.5rem;
}

.form .error{
	color:#FF4C4C;
	display: block;
}

.form .must,
.form .optional{
	display: inline-block;
	border-radius: 12px;
	line-height: 1;
	padding: 2px 6px;
	font-size: 1.1rem;
	font-weight: 700;
	color: #FFF;
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -7.5px;
}

.form .must{background: #EA5502;}
.form .optional{background: #D8BC94;}

.form th.align_top .must,
.form th.align_top .optional{
	top: 34px;
	margin-top: 0;
}

.form label{display:inline-block;}

/*--セレクトボックス--*/
.wrap_select{position: relative;}

.wrap_select::after{
    content: "";
	display: block;
    background: url(../img/ico_arrow01.png) no-repeat 0 0;
    background-size: contain;
    width: 10px;
    height: 6px;
    position: absolute;
    top: 50%;
    right: 8px;
    margin-top: -2px;
}

.wrap_select select{
	background: #F2F5F7;
	border: none;
	padding: 15px;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.wrap_select select:focus-visible{outline: 2px dotted #333;}

/*--ラジオボタン--*/
.wrap_radio{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: -20px;
}

.radio_item{
	position: relative;
	margin: 0 20px 20px 0;
	display: flex;
	align-items: center;
}

.radio_item input[type="radio"]+label{
	display: inline-block;
	background: url("../../img/img_radio01.png") no-repeat 0 2px;
	background-size: 16px;
	padding: 0 0 0 20px;
	line-height: 1.2;
	min-height: 16px;
	cursor: pointer;
}

.radio_item input[type="radio"]:checked+label{
	background: url("../../img/img_radio01_on.png") no-repeat 0 2px;
	background-size: 16px;
}

.radio_item input[type="radio"]:focus-visible+label{outline: 2px dotted #333;}

/*--チェックボックス--*/
.wrap_checkbox{
	display: flex;
	flex-wrap: wrap;
	margin-bottom: -20px;
}

.checkbox_item{
	position: relative;
	margin: 0 20px 20px 0;
	display: flex;
	align-items: center;
}

.checkbox_item input[type="checkbox"]+label{
	display: inline-block;
	background: url("../../img/img_checkbox01.png") no-repeat 0 2px;
	background-size: 16px;
	padding: 0 0 0 20px;
	line-height: 1.2;
	min-height: 16px;
	cursor: pointer;
}

.checkbox_item input[type="checkbox"]:checked+label{
	background: url("../../img/img_checkbox01_on.png") no-repeat 0 2px;
	background-size: 16px;
}

.checkbox_item input[type="checkbox"]:focus-visible+label{outline: 2px dotted #333;}

/*--ボタン--*/
.btn_form{
	margin-top: 60px;
}

.btn_contact.submit,
.btn_contact.send,
.btn_contact.back{
	display: block;
	color: #FFF;
	text-align: center;
	border: 1px solid #FFB403;
	background: #FFB403;
	border-radius: 64px;
	width: 300px;
	position: relative;
	cursor: pointer;
	transition: opacity .3s;
	margin: 0 auto;
}

.btn_contact.back{background: #FFF;}

.btn_contact.send{margin-bottom: 20px;}

.btn_contact.submit:hover,
.btn_contact.send:hover,
.btn_contact.back:hover{opacity: .7;}

.btn_contact button{
	background: none;
	margin: 0;
	padding: 25px;
	outline: 0;
	border: none;
	border-radius: 0;
	-webkit-appearance: none;
	width: 100%;
	height: 100%;
	cursor: pointer;
	color: #FFF;
	line-height: 1;
	font-size: 1.5rem;
	font-weight: 700;
}

.btn_contact.back button{color: #FFB403;}

.btn_contact button:focus-visible{outline: 2px dotted #333;}

/*--Recaptcha--*/
.grecaptcha-badge{
    bottom: 80px !important;
    z-index: 1;
}


@media only screen and (max-width:1024px){ /* 表示領域が1024px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	フォーム関連

	------------------------------------------------------------ */
	
	/* 
	---------------------------------------------- */
	
	
}/*--@media--*/


@media only screen and (max-width:767px){ /* 表示領域が767px以下の場合に適用するスタイル */
	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

	/* ------------------------------------------------------------

	フォーム関連

	------------------------------------------------------------ */
	
	.form th{
		width: 100%;
		padding: 0 0 10px 44px;
		display: block;
		font-size: 1.5rem;
	}

	.form th.align_top{padding-top: 0;}
	
	.form td{
		padding: 0 0 23px;
		display: block;
	}
	
	.form tr:last-of-type td{padding-bottom: 0;}

	.form input[type="text"],
	.form input[type="email"],
	.form input[type="password"],
	.form input[type="tel"],
	.form input[type="url"],
	.form input[type="number"],
	.form textarea{padding: 15px;}
	
	.form .must,
	.form .optional{
		top: 6px;
		left: 0;
		right: unset;
		margin: 0;
	}
	
	.form th.align_top .must, 
	.form th.align_top .optional{top: 6px;}
	
	/*--ボタン--*/
	.btn_form{margin-top: 40px;}

	.btn_contact.submit,
	.btn_contact.send,
	.btn_contact.back{
		width: 100%;
		max-width: 260px;
	}

	.btn_contact button{
		padding: 21px 0;
		font-size: 1.4rem;
	}

	
}/*--@media--*/

