@charset "utf-8";

/* --------------------------
 フォーム
----------------------------*/
.screen-reader-response, .wpcf7-response-output{
width:100%;
text-align:center;
}
.screen-reader-response ul{
display:none;
}
.screen-reader-response, .wpcf7-response-output{
/*display:none;*/
}
.wpcf7-submit{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;

	margin: 0 2px; /*レイアウト調整*/
}
.wpcf7-submit:hover,
.wpcf7-submit:focus{
	opacity: 0.8;
}
.wpcf7-submit{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 260px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: large;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#C0D20A 0%, #91AA10 100%);
	background-image: linear-gradient(#C0D20A 0%, #91AA10 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
	margin:8px 0;
}
.wpcf7-textarea{
width:90%;
}
span.indispensable{
	display:inline-block;
	line-height: 1.0;
	padding: 4px 4px;
	font-size: 10px;
	color: #fff;
	border-radius: 2px;
	-moz-border-radius: 2px;
	-webkit-border-radius: 2px;
	-khtml-border-radius: 2px;
	behavior: url(./txt/PIE.htc);
	background-color: #ff5f82;
	vertical-align: middle;
}
h3{
	background-color: #F0F0F0;
	font-size: medium;
	font-weight: bold;
	margin: 30px 0px 0px;
	padding: 15px 15px;
}
.form_entry{
	padding-top: 15px;
}
.form_entry ul{
	border-bottom: solid 1px #CCCCCC;
}
.form_entry li{
	background-color: #ffffff;
	border-top: solid 1px #CCCCCC;
	font-size: 0;
}
.form_entry li span{
	vertical-align: middle;
}
.form_entry li .left{
	width: 32%;
	background-color: #ffffff;
	vertical-align: middle;
	display: inline-block;
	margin: 15px 0;
	padding-left: 0;
}
.form_entry li .left span{
	margin-right: 5px;
}
.form_entry li .right{
	width: 68%;
	background-color: #ffffff;
	vertical-align: middle;
	display: inline-block;
	margin: 15px 0;
}
.form_entry li .right div{
	display: inline-block;
	margin-left: 6px;
	margin-right: 6px;
	margin-bottom: 15px;
	vertical-align: middle;
	width: 100%;
}
.form_entry li .right div.block{
	display: block;
}
.form_entry li .right span{
	display: block;
	margin-top: 6px;
}
.form_entry input[type=file]{
}
.form_entry input[type=text], .form_entry input[type=email]{
	display: block;
	width: 90%;
	border: solid 1px #ccc;
	padding: 5px 5px;
	/*margin-left: -15px; レイアウト調整 */
}
.form_entry textarea{
	/*
	display: block;
	width: 96%;
	border: solid 1px #ccc;
	margin-top: 5px;
	padding: 5px 5px;
	vertical-align: middle;
	*/
	 /*margin-left: -15px レイアウト調整 */
}

input[type=text]::-webkit-input-placeholder,
input[type=email]::-webkit-input-placeholder,
input[type=search]::-webkit-input-placeholder{
	position: relative;
	top: -0.2em;
}


/* --------------------------
 common
----------------------------*/
button, input, select, textarea{
	/*font-family: inherit;*/
	font-size: 100%;
}

/*---------------
 * Form file
 *--------------*/
::file-selector-button{
	font:inherit
}
::-webkit-file-upload-button{
	font:inherit;
	-webkit-appearance:button
}

input[type=file]{
	display:block;
	width:90%;
	padding:.375rem .75rem;
	font-size:1rem;
	font-weight:400;
	line-height:1.5;
	color:#212529;
	background-color:#fff;
	background-clip:padding-box;
	border:1px solid #ced4da;
	-webkit-appearance:none;
	-moz-appearance:none;
	appearance:none;
	border-radius:.25rem;
	transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out
	overflow: hidden
}
@media(prefers-reduced-motion:reduce){
	input[type=file]{
		transition:none
	}
}
input[type=file]:not(:disabled):not([readonly]){
	cursor:pointer
}
input[type=file]:focus{
	/*
	color:#212529;
	background-color:#fff;
	border-color:#86b7fe;
	outline:0;
	box-shadow:0 0 0 .25rem rgba(13,110,253,.25)
	box-shadow:0 0 0 0.2rem rgba(0,117,255,0.5)
	*/
	/*
	outline: 2px solid #333333;
	*/
}
input[type=file]::-webkit-date-and-time-value{
	height:1.5em
}
input[type=file]::-moz-placeholder{
	color:#6c757d;
	opacity:1
}
input[type=file]::placeholder{
		color:#6c757d;
		opacity:1
	}
input[type=file]:disabled{
	background-color:#e9ecef;
	opacity:1
}
input[type=file]::file-selector-button{
	padding:.375rem .75rem;margin:-.375rem -.75rem;
	-webkit-margin-end:.75rem;
	margin-inline-end:.75rem;
	color:#212529;
	background-color:#e9ecef;
	pointer-events:none;
	border-color:inherit;
	border-style:solid;
	border-width:0;
	border-inline-end-width:1px;
	border-radius:0;
	transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out
}
@media(prefers-reduced-motion:reduce){
	input[type=file]::file-selector-button{
		transition:none
	}
}
input[type=file]:hover:not(:disabled):not([readonly])::file-selector-button{
	background-color:#dde0e3
}
input[type=file]::-webkit-file-upload-button{
	padding:.375rem .75rem;
	margin:-.375rem -.75rem;
	-webkit-margin-end:.75rem;
	margin-inline-end:.75rem;
	color:#212529;
	background-color:#e9ecef;
	pointer-events:none;
	border-color:inherit;
	border-style:solid;
	border-width:0;
	border-inline-end-width:1px;
	border-radius:0;
	-webkit-transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
	transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out
}
@media (prefers-reduced-motion:reduce){
	input[type=file]::-webkit-file-upload-button{
		-webkit-transition:none;transition:none
	}
}
input[type=file]:hover:not(:disabled):not([readonly])::-webkit-file-upload-button{
	background-color:#dde0e3
}

/* --------------------------
 select
----------------------------*/
select::-ms-expand{
	display: none;
}

select.txt{
	/*width: 100%;*/
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 1px solid #999;
	background: #eee;
	background: url("../images/carat-d-white.png") 100% 50% no-repeat, -webkit-linear-gradient(top, #fff 0%,#fff 100%);
	background: url("../images/carat-d-white.png") 100% 50% no-repeat, linear-gradient(to bottom, #fff 0%,#fff 100%);
	background-size: 26px, 100%;

	padding: 5px 30px 5px 10px;
	-moz-border-radius: 3px;
	-webkit-border-radius: 3px;
	-khtml-border-radius: 3px;
	border-radius: 3px;
	vertical-align: baseline;
	//box-sizing: border-box;
}

@media screen and (max-width:479px){
	select.txt{
		width: 96%;
	}
}

/* --------------------------
 radio checkbox共通
----------------------------*/
label{
	text-decoration: underline;
	margin-top: 0px;
}

/* --------------------------
 radio
----------------------------*/
.radio{
	/*position: relative;*/
	display: inline-block;
	padding: 0px 0 0px 0px;
	vertical-align: bottom;

	cursor: pointer;
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
	-webkit-touch-callout: none;
	font-size: 0px;
	line-height: 0;
}

.radio:hover{
	text-decoration: underline;
}

input[type=radio]{
	display: none;
}

input[type=radio]:checked + label{
	color: #000000;
}

input[type=radio] + label{
	padding-left: 25px;
	position:relative;
	padding-top: 1px;

	line-height: 1.2;

}

input[type=radio] + label::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 18px;
	height: 18px;
	border: 1px solid #999;
	border-radius: 50%;
}

input[type=radio]:checked + label::before{
	animation: pulsate .6s ease-out; /* スピードなど */
	border: 1px solid #666; /* 波紋カラーなど */
}
@keyframes pulsate{
	0%  { transform: scale(1, 1); border: 1px solid #fff; }
	50% { opacity: 1; background: rgba(221, 221, 221, 0.8); border: 1px solid #fff; }
	100%{ transform: scale(2.0, 2.0); opacity: 0.0; border: 1px solid #fff; }
}

input[type=radio]:checked + label::after{
	content: "";
	display: block;
	position: absolute;
	top: 4px;
	left: 4px;
	width: 12px;
	height: 12px;
	background: #777;
	border-radius: 50%;
}

/* --------------------------
 checkbox
----------------------------*/
.checkbox{
	position: relative;
	display: inline-block;
	padding: 0px 0 0px 25px;
	vertical-align: top;
	cursor: pointer;
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
	-webkit-touch-callout: none;
	font-size: 0px;
	line-height: 0;
}

.checkbox:hover{
	text-decoration: underline;
}

input[type=checkbox] + label{
	color: #000000;
	line-height: 1.2;
	padding-top: 1px;
}

input[type=checkbox]:checked + .checkbox:after{
	animation: pulsate2 .6s ease-out; /* スピードなど */
	border: 1px solid #999; /* 波紋カラーなど */
}

@keyframes pulsate2{
	0%  { transform: scale(1, 1); border: 1px solid #fff; }
	50% { opacity: 1; background: rgba(221, 221, 221, 0.8); border: 1px solid #fff; }
	100%{ transform: scale(2.0, 2.0); opacity: 0.0; border: 1px solid #fff; }
}

.checkbox:after{
	/* ボックス */
	-webkit-transition: border-color 0.1s linear;
	transition: border-color 0.1s linear;
	position: absolute;
	top: 0px;
	left: 0px;
	display: block;
	margin-top: 0;
	width: 18px;
	height: 18px;
	border: 1px solid #999;
	box-sizing: border-box;
	content: '';
}

.checkbox:before{
	/* チェック */
	-webkit-transition: opacity 0.1s linear;
	transition: opacity 0.1s linear;
	position: absolute;
	top: 0px;
	left: 5px;
	display: block;
	margin-top: 0px;
	width: 6px;
	height: 12px;
	border-right: 3px solid #777;
	border-bottom: 3px solid #777;
	content: '';
	opacity: 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

input[type=checkbox]{
	display: none;
}
input[type=checkbox]:checked + .checkbox:before{
	opacity: 1;
}

/* --------------------------
 text, textarea
----------------------------*/
input[type=text]{
	border: solid 1px #999;
	box-sizing: border-box;
	-webkit-appearance: none;
	border-radius: 3px;
}

textarea{
	/*
	border: solid 1px #999;
	box-sizing: border-box;
	-webkit-appearance: none;
	border-radius: 3px;
	*/
	/*height: 100px;*/
}

/* --------------------------
 placeholder
----------------------------*/
input::placeholder{
	color: #AAAAAA;
}

/* IE */
input:-ms-input-placeholder{
	color: #AAAAAA;
}

/* Edge */
input::-ms-input-placeholder{
	color: #AAAAAA;
}

/* --------------------------
 responsive
----------------------------*/
@media screen and (max-width:959px){
}

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

@media screen and (max-width:479px){
	.form_entry li .left{
		width: 100%;
		display: inline-block;
		margin: 15px 0 0;
		padding-left: 10px;
	}
	.form_entry li .right{
		width: 100%;
		display: inline-block;
		margin: 10px 0 15px;
		padding-left: 10px;
	}

	input[type=radio] + label{
	}

	input[type=radio] + label::before{
	}

	input[type=radio]:checked + label::after{
	}

	.checkbox{
	}

	.checkbox:before{
	}

	.checkbox:after{
	}
}

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