@charset "UTF-8";


#contact
{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding-top: max(7vw, 7rem);
	padding-bottom: max(8vw, 8rem);
	
	max-width: 950px;
}

#contact h1
{
	font-family: 'FS-R';
	font-size: clamp(1.3rem, 3vw, 1.7rem);
	line-height: 1;
	padding-bottom: .25em;
	
	margin-bottom: 1em;
	border-bottom: 1px solid;
}

#contact h2
{
	font-size: clamp(1.2rem, 3vw, 1.5rem);
	margin-top:0;
	padding-bottom: 1em;
	margin-bottom:1em;
	border-bottom: 1px solid;
}

#menu
{
	position:sticky;
	top: 5rem;
	width: 10rem;
}

#menu li.menu.now
{
	color: rgba(0, 0, 0, 1);
}

#menu ul
{
	list-style: none;
}

#menu li.menu
{
	cursor:pointer;
	display: flex;
	justify-content: space-between;
/*	font-family: serif, "LB-R";
	font-weight: 400;*/
	font-family: 'FS-R';
	line-height: 1.3;
	padding-top: .5em;
	color: rgba(100, 100, 100, 1);
}

#menu li.menu:after
{
	content:"";
	display:block;
	width: 1em;
	height: 1em;
	transform-origin: center center;
	border-style: solid;
	border-width:4px 4px 0 0;
	transform: rotate(45deg) scale(.25);
}

body:not(.touch) #menu li.menu:hover
{
	color: rgba(0, 0, 0, 1);
}

#menu > p + p
{
	margin-top: .5em;
}

#contact .contents
{
	width:calc(100% - 15rem);
	padding-top: clamp(2.5rem, 6.5vw, 3.7rem);
	max-width: 650px;
}

#contact .contents .copy
{
	font-family: 'FS-R';
	font-size: 1rem;
	margin-bottom: max(2vw, 2rem);
}

#contact h3
{
	font-family: 'FS-R';
	font-size: clamp(1rem, 5vw, 1.2rem);
	border-bottom: 1px solid rgb(200,200,200);
	padding-bottom:.5em;
	margin-bottom:.5em;
}

#contact .step
{
	margin-bottom: 2em;
}

#contact h3 span
{
	display:inline-block;
}

#contact h3 span:nth-of-type(1)
{
	margin-right: 1em;
}

#form
{
	margin-top: 4em;
}

#contact #form h3
{
	margin-top: 2em;
}

#form label
{
	display: block;
	font-size: .9em;
}

#form textarea
{
	padding: .5em;
}

#information_center
{
	margin-top: max(8vw, 8rem);
}

#information_center .photo_text
{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

#information_center figure
{
	width: 50%;
	aspect-ratio: 5 / 3;
	background-color: rgb(240, 240, 240);
	line-height: 1;
}

#information_center figure img
{
	width: 100%;
	height: 100%;
	object-fit:cover;
	object-position: 50% 50%;
	transition: all 1.5s ease;
}

#information_center .text
{
	width: calc(50% - 2rem);
}

#information_center .text > p
{
	line-height: 1.35;
	margin-bottom: 1em;
}

#information_center .text > p:nth-of-type(1)
{
	font-size: 1.1em;
	font-family: 'FS-R';
}

#information_center iframe
{
	margin-top: 2rem;
	aspect-ratio: 5/ 2;
}

/************************************************/
/********************* Form *********************/
/***********************************************/

.formWrapper
{
	margin-top: 2rem;
}

.formItem
{
	display:flex;
	
	align-items: flex-start;
	justify-content: flex-start;

	padding: 0em 0;
	border-bottom: 1px dotted rgb(200, 200, 200);
}

.form_contents._b
{
	margin-left: -1em;
}

.wpcf7-form .form_contents,
.wpcf7-form .form_contents.radio .flex,
.formWrapper .form_contents,
.formWrapper .form_contents.radio .flex,
{
	flex-wrap: wrap;
}

.wpcf7-form .form_contents.radio > label,
.wpcf7-form .form_contents.radio > .flex > label,
.formWrapper .form_contents.radio > label,
.formWrapper .form_contents.radio > .flex > label
{
	margin: 0 .5rem;
	cursor: pointer;
}

.wpcf7-form .form_contents.radio > label.nw,
.wpcf7-form .form_contents.radio > .flex > label.nw,
.formWrapper .form_contents.radio > label.nw,
.formWrapper .form_contents.radio > .flex > label.nw
{
	white-space: nowrap;
}

.wpcf7-form .formItem.privacy .form_contents,
.formItem.privacy .form_contents
{
	width: auto;
}

.wpcf7-form .form_contents,
.formWrapper .form_contents
{
	padding: 1rem 0;
/*	border-left: 1px solid rgb(200, 200, 200);
	margin-left: -1px;*/
	line-height: 2;
	width: 100%;
	
	-webkit-align-items: center;
	align-items: center;
}

.q-title
{
	display:block;
	margin-top: .25em;
}

.qName .linkBt
{
	display: block;
	margin: .5rem .5rem 0;
	color: rgb(255, 255, 255);
	background-color: rgb(120, 120, 120);
}
body:not(.touch) .qName .linkBt:hover
{
	background-color: rgb(50, 50, 50);
}

.qName
{
	padding: 1rem  0;
	width: 15rem;
	padding-right: 1em;
	
/*	border-right: 1px solid rgb(200, 200, 200);*/

	-moz-flex-direction: column;
	-webkit-flex-direction: column;
	flex-direction: column;

	-webkit-align-items: flex-start;
	align-items: flex-start;
	
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
}

.wpcf7-form .form_contents .q-title._s,
.formWrapper .form_contents .q-title._s
{
	padding: 0;
	border-right-width: 0px;
}
.wpcf7-form .form_contents._d div,
.formWrapper .form_contents._d div
{
	margin-top: 1em;
}

/*input:not([type=checkbox]):not([type=radio]):not([type=submit]):not([type=hidden])
{
	font-family: 'FS-R';
	border: 1px solid;
	width: 100%;
}*/

input:not([type=submit]),
textarea, 
option
{
	width: 100%;
	box-sizing:border-box;
	padding: .5em;
	font-size: 1em;
	border:1px solid rgb(230,230,230);
	background-color: rgb(240,240,240);
	-moz-border-radius: 0em;
	-webkit-border-radius: 0em;
	border-radius: 0em;
	-webkit-appearance: none;
}

fieldset.hidden-fields-container,
input[type=hidden]
{
	display: none;
}


option
{
	border:1px solid;
}

input[type=checkbox],
input[type=radio]
{
	margin-top:.1em;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus
{
	outline: 0;
	background-color: rgb(250, 250, 250);
	color: rgb(100, 100, 100);
}

textarea{width: 100%;}

#selectorWrapper
{
	margin-top: 3em;
}

#selectorWrapper label
{
	position: relative;		/* 選択ボックスの位置指定 */ 
	display: inline-block;			/* ブロックレベル要素化にする */ 
	box-sizing:border-box;
	width: auto;
	padding: .5em;
	padding-right: 2em;
	background-color:rgb(255, 255, 255);
	border: 1px solid rgb(100,100,100);/* ボックスの境界線を実線で指定する */
}
#selectorWrapper label:before
{
	content: "";
	position: absolute;
	width: .4em;
	height: .4em;
	
	top: 50%;
	right: 1em;
	display: block;
	margin-top: -.3em;
	
	border-color: rgb(0, 0, 0);
	border-style: solid;
	border-width: 0 1px 1px 0;
	
	transform: rotate( 45deg );
	-ms-transform: rotate( 45deg );
}
#selectorWrapper select
{
	cursor: pointer;
	font-size: 1em;
	padding: .2em .5em;
	box-sizing:border-box;
	-webkit-appearance: none;/* ベンダープレフィックス(Google Chrome、Safari用) */
	-moz-appearance: none;	/* ベンダープレフィックス(Firefox用) */
	appearance: none;		/* 標準のスタイルを無効にする */ 
	display: block;			/* ブロックレベル要素化する */ 
	border: none;			/* 境界線をなしに指定する */
	background: transparent;/* 背景を透過指定する */
	color: rgb(100, 100, 100);
}
#selectorWrapper select:focus
{
	outline: none;
}

::-ms-expand
{		/* select要素のデザインを無効にする（IE用） */
	display: none;
}
#formContainer .formparts
{
	box-sizing:border-box;
	margin-bottom: 2rem;
}

#formContainer .formparts .q-title._s
{
	padding: 0;
	border-right-width: 0px;
}
#formContainer .formparts._d div{margin-top: 1em;}

.q-short{width:50%}
.q-large{width: 100%;}
.q-textArea
{
	height: 100%;
	min-height: 17em;
	padding: 1em;
}

span.req{color: rgb(226, 0, 43);}
.noReq{display: none;}
.q-title .smallerText{letter-spacing:0;}
.q-smaller{font-size:.9em; margin-left:15px;}
.q-caution
{
	font-size:.8em;
}

.q-radio{display:inline; margin-right:5px;}

#langArea + span{margin-left: 1em;}

.privacyStatement
{
	position: relative;
	box-sizing:border-box;
	border:1px solid rgb(255,255,255);
	height: calc(3rem * 1.75 + .75em);
	overflow: auto;
	width: 100%;
	
	margin-bottom: 1rem;
}
.privacyStatement div{padding: 1em; font-size: 1em;}
.privacyStatement div .strongText{margin-top: 1em;}

.privacy, .language
{
	margin-top: .5em;
	display:-webkit-box;
	display:-moz-box;
	display:-ms-box;
	display:-webkit-flexbox;
	display:-moz-flexbox;
	display:-ms-flexbox;
	display:-webkit-flex;
	display:-moz-flex;
	display:-ms-flex;
	display:flex;
	
	-webkit-align-items: center;
	align-items: center;
	
	-webkit-justify-content: flex-start;
	justify-content: flex-start;
}

.privacy
{
	margin-top: 2em;
}

.privacy div, .language div
{
	margin-left: 1em;
}
.privacy div p, .language div p{line-height: 1;}

.privacy div p + p, .language div p + p{margin-top: 1em;}

#sendDate
{
	font-weight: bold; margin-top: 2em; text-align: center; border: 1px solid; padding: .5em;
	color: black;
	-moz-border-radius: 0em;
	-webkit-border-radius: 0em;
	border-radius: 0em;
}


.submitBtWrapper
{
	margin-top: 3em;
}

.submitBt
{
	font-family: 'FS-R';
	cursor: pointer;
	box-sizing:border-box;
	font-size: 1.5rem;
	display:inline-block;
	margin-top: 1rem;
	padding: .5em;
	width: 100%;
	text-align: center;
	color: rgb(255, 255, 255);
	background-color: rgb(50, 50, 50);
	border: 1px solid rgb(50, 50, 50);
	
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-ms-transition: all .3s ease;
	-o-transition: all .3s ease;
	transition: all .3s ease;
}
.submitBt:hover
{
	color: rgb(50, 50, 50);
	background-color: rgb(255, 255, 255);
}

.sentMessage
{
	position: relative;
	width:100%;
	padding-bottom: 1rem;
}

.inputFlexWrapper
{
	display:flex;
	justify-content: space-between;
	margin-bottom: 3rem;
	
}

.inputWrapper
{
	position: relative;
	box-sizing:border-box;
	width: calc(40% - 1rem);
	margin-right: 1rem;
}

.inputWrapper .formparts
{
	display: block;
	margin-bottom: 1rem;
}

.inputFlexWrapper > .formparts
{
	width: calc(50% - 1rem);
}
.inputWrapper + div
{
	width: calc(50% - 1rem);
}

.inputWrapper + div > p
{
	height: 100%;
}

.inputWrapper input
{
	width:100%;
}

input::placeholder,
textarea::placeholder
{
	font-family: 'FS-R';
	font-weight: 400;
	color: rgb(150, 150, 150);
}

:placeholder-shown
{
	color: rgb(100, 100, 100);
}

::-webkit-input-placeholder
{
	color: rgb(100, 100, 100);
}

:-moz-placeholder
{
	color: rgb(100, 100, 100);
	opacity: 1;
}

::-moz-placeholder
{
	color: rgb(100, 100, 100);
	opacity: 1;
}

:-ms-input-placeholder
{
	color: rgb(100, 100, 100);
}

/* Checkbox Raiobutton */

.privacy .wpcf7-list-item
{
	margin: 0;
}

input[type=radio]._c,
input[type=checkbox]._c,
.privacy input[type=checkbox],
._c input[type=radio],
._c input[type=checkbox]
{
	box-sizing:border-box;
	padding: .5em;
	font-size: 1rem;
	-moz-border-radius: 0em;
	-webkit-border-radius: 0em;
	border-radius: 0em;
	-webkit-appearance: none;

	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	-o-appearance: none;
	appearance: none;
	position: relative;
	right: 0;
	bottom: 0;
	left: 0;
	height: 1em;
	width: 1em;
	vertical-align: -.3em;
	transition:all 0s ease-out 0s;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	margin: 0;
	outline: none;
	border-radius: 10%;
	
/*	transform: scale(.75);*/
}

input[type=radio]._c:before, input[type=radio]._c:after,
input[type=checkbox]._c:before, input[type=checkbox]._c:after,
.privacy input[type=checkbox]:before, .privacy input[type=checkbox]:after,
._c input[type=radio]:before, ._c input[type=radio]:after,
._c input[type=checkbox]:before, ._c input[type=checkbox]:after
{
	position: absolute;
	content: "";
	background: rgb(50,50,50);
	transition: all 0s ease-in-out;
}
input[type=radio]._c:before ,
input[type=checkbox]._c:before,
.privacy input[type=checkbox]:before,
._c input[type=radio]:before,
._c input[type=checkbox]:before
{
	left: 2px;
	top: 6px;
	width: 0;
	height: 2px;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-o-transform: rotate(45deg);
}
input[type=radio]._c:after,
input[type=checkbox]._c:after,
.privacy input[type=checkbox]:after,
._c input[type=radio]:after,
._c input[type=checkbox]:after
{
	right: 9px;
	bottom: 3px;
	width: 2px;
	height: 0;
	transform: rotate(40deg);
	-webkit-transform: rotate(40deg);
	-moz-transform: rotate(40deg);
	-ms-transform: rotate(40deg);
	-o-transform: rotate(40deg);
	transition-delay: 0s;
}
input[type=radio]._c:checked:before,
input[type=checkbox]._c:checked:before,
.privacy input[type=checkbox]:checked:before,
._c input[type=radio]:checked:before,
._c input[type=checkbox]:checked:before
{
	left: 1px;
	top: 10px;
	width: 6px;
	height: 2px;
}
input[type=radio]._c:checked:after,
input[type=checkbox]._c:checked:after,
.privacy input[type=checkbox]:checked:after,
._c input[type=radio]:checked:after,
._c input[type=checkbox]:checked:after
{
	right: 5px;
	bottom: 1px;
	width: 2px;
	height: 14px;
}
input[type=radio]._c:indeterminate:before,input[type=radio]._c:indeterminate:after,
input[type=checkbox]._c:indeterminate:before,input[type=checkbox]._c:indeterminate:after,
.privacy input[type=checkbox]:indeterminate:before, .privacy input[type=checkbox]:indeterminate:after,
._c input[type=radio]:indeterminate:before, ._c input[type=radio]:indeterminate:after,
._c input[type=checkbox]:indeterminate:before, ._c input[type=checkbox]:indeterminate:after
{
	width: 7px;
	height: 2px;
	transform: rotate(0);
	-webkit-transform: rotate(0);
	-moz-transform: rotate(0);
	-ms-transform: rotate(0);
	-o-transform: rotate(0);
}
input[type=radio]._c:indeterminate:before,
input[type=checkbox]._c:indeterminate:before,
.privacy input[type=checkbox]:indeterminate:before,
._c input[type=radio]:indeterminate:before,
._c input[type=checkbox]:indeterminate:before
{
	left: 1px;
	top: 7px;
}
input[type=radio]._c:indeterminate:after,
input[type=checkbox]._c:indeterminate:after,
.privacy input[type=checkbox]:indeterminate:after,
._c input[type=radio]:indeterminate:after,
._c input[type=checkbox]:indeterminate:after
{
	right: 1px;
	bottom: 7px;
}

/* 青 */
input[type=radio]._c,
input[type=radio],
input[type=checkbox]._c,
input[type=checkbox],
.privacy input[type=checkbox],
._c input[type=radio],
._c input[type=checkbox]
{
	margin-right: .25em;
}
input[type=radio]._c:checked,
input[type=radio]._c:indeterminate,
input[type=checkbox]._c:checked,
input[type=checkbox]._c:indeterminate,
.privacy input[type=checkbox]:checked,
.privacy input[type=checkbox]:indeterminate,
._c input[type=radio]:checked,
._c input[type=radio]:indeterminate,
._c input[type=checkbox]:checked,
._c input[type=checkbox]:indeterminate
{
	background: rgb(220, 220, 220);
}


.privacyStatement + p .wpcf7-list-item
{
	margin-left:0;
}

.wpcf7-not-valid-tip
{
	font-size: .8em;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output
{
	border-color: rgb(150,0,0);
	background-color: rgb(150,0,0);
	margin: 1rem 0 0 0;
	color: #fff;
	font-family: 'FS-R',sans-serif;
	font-weight: 400;
}

.form_succsess
{
	font-family: 'FS-R';
	padding: 1em;
	margin-top: 1em;
	border-radius: .5em;
	background-color: rgb(245, 245, 245);
	font-size: clamp(1rem, 5vw, 1.2rem);
}


/*//////////////////////////////////////////////////////////////////////////////////
///////////////////////////////// MEDIA SCREEN ////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////*/

@media screen and (max-width: 750px)
{
	#contact
	{
		flex-direction:column;
	}
	#contact h1
	{
		position:relative;
		top: 0;
	}
	#contact .contents
	{
		width: 100%;
		max-width: 100%;
	}
	
	#menu
	{
		position:relative;
		top: 0;
		width: 100%;
	}
}

@media screen and (max-width: 650px)
{
	.formItem
	{
		flex-direction: column;
	}
	.qName
	{
		width: 100%;
		padding-bottom: 0;
	}
}

@media screen and (max-width: 500px)
{
	#information_center .photo_text
	{
		flex-direction:column;
		align-items: flex-start;
	}
	
	#information_center figure,
	#information_center .text
	{
		width: 100%;
	}
	#information_center .text
	{
		margin-top: 2rem;
	}
	
	#information_center iframe
	{
		aspect-ratio: 5 / 3;
	}
}