@charset 'utf-8';

/* common
------------------------------------------------ */
@media screen and (min-width: 769px) {
	.page__title { background-image: url(../../img/contact/page_title_bg.jpg); }
}

@media screen and (max-width: 768px) {
	.page__title { background-image: url(../../img/contact/page_title_bg-sp.jpg); }
}

/* contact
------------------------------------------------ */
.contact__form{
	margin: 0 auto;
	padding: 64px 66px 32px;
	width: 100%;
	max-width: 1060px;
	background: #F8F8F8;
}
.contact__form--txt-1{
	margin-bottom: 32px;
	font-size: 1.6rem;
	letter-spacing: 0.04em;
	color: #292929;
	line-height: 1.87;
}
.contact__form--request{color: #CD0000;}
.contact__form--group{display: table;width: 100%;margin-bottom: 43px;}
.contact__form--group:last-child .contact__form--txt-2{margin-top: 100px;}
.contact__form--col1{display: table-cell;width: 33.2%;vertical-align: middle;}
.contact__form--col2{display: table-cell;vertical-align: middle;font-size: 1.4rem;}
.contact__form--single { display: flex; justify-content: center; flex-wrap: wrap; margin-bottom: 32px; text-align: center; }
.contact__form--txt-2{
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: 0.04em;
	color: #292929;
}
.contact__form--input{
	padding: 0 32px;
	width: 100%;
	height: 60px;
	font-size: 1.6rem;
	letter-spacing: 0.04em;
	color: #292929;
	border:1px solid #707070;
}
.contact__form--select{
	padding: 0 32px;
	width: 100%;
	height: 60px;
	font-size: 1.6rem;
	color: #292929;
	letter-spacing: 0.04em;
	border:1px solid #707070;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background: url(../../img/share/arrow1.png) no-repeat 97% center #fff;
}
.contact__form--textarea{
	padding: 10px 32px;
	width: 100%;
	height: 240px;
	font-size: 1.6rem;
	letter-spacing: 0.04em;
	border:1px solid #707070;
	resize: none;
}
.contact__form--txt-3{
	padding-left: 45px;
	display: table;
	font-size: 1.6rem;
	letter-spacing: 0.04em;
	color: #292929;
	position: relative;
	cursor: pointer;
	vertical-align: middle;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}
.contact__form--checkbox{
	position: absolute;
	opacity: 0;
	cursor: pointer;
	height: 0;
	width: 0;
}
.contact__form--checkmark {
	position: absolute;
	top: 0;
	left: 0;
	height: 28px;
	width: 28px;
	background-color: #fff;
	border:1px solid #707070;
}
.contact__form--checkmark:after {
	display: none;
	content: "";
    position: absolute;
    left: 8px;
    top: 3px;
    width: 6px;
    height: 12px;
    border: solid #292929;
    border-width: 0 3px 3px 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.contact__form--checkbox:checked ~ .contact__form--checkmark:after {
  display: block;
}
.contact__form--submit-btn,
.contact__form--link-btn,
.contact__form--confirm-btn {
	display: block;
	position: relative;
	margin: 0 auto;
	padding: 21px 0;
	width: 300px;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	background-color: var(--color-primary);
	/*
	background: #209cff;
	background-image: -moz-linear-gradient(45deg, #209cff 0%, #68e0cf 51%, #209cff 100%);
	background-image: -webkit-linear-gradient(45deg, #209cff 0%, #68e0cf 51%, #209cff 100%);
	background-image: linear-gradient(45deg, #209cff 0%, #68e0cf 51%, #209cff 100%);
	background-size: 200% auto;
	*/
	border:none;
	border-radius: 36px;
	text-align: center;
	text-decoration: none;
	font-size: 1.8rem;
	letter-spacing: 0.04em;
	font-weight: bold;
	color:#fff;
	outline: none;
	cursor: pointer;
}
.contact__form--submit-btn:after,
.contact__form--link-btn:after,
.contact__form--confirm-btn:after {
	content: ' ';
	position: absolute;
	top: 50%;
	right: 18px;
	margin-top: -20px;
	width: 36px;
	height: 36px;
	background: url(../../img/share/arrow8.png) no-repeat center center;
	background-size: 12px;
	border: solid #fff 2px;
	border-radius: 50%;
}
.contact__form--confirm-btn:after { right: auto; left: 18px; transform: rotate(180deg); }
.device_click .contact__form--submit-btn:hover,
.device_click .contact__form--link-btn:hover,
.device_click .contact__form--confirm-btn:hover { /*background-position: right center;*/ opacity: 1; }


.contact__form--link-btn{
	display: table;
	text-decoration: none;
	margin: 0 auto;
}
.contact__success--txt{
	margin-bottom: 40px;
	font-size: 1.8rem;
	text-align: center;
	line-height: 1.66;
	letter-spacing: 0.04em;
	color: #292929;
}

.contact__success--tel{
	margin-bottom: 64px;
	font-size: 1.8rem;
	text-align: center;
	line-height: 1.66;
	letter-spacing: 0.04em;
	color: #292929;
}

.contact__success--tel strong {
	font-size: 2.4rem;
	font-weight: 700;
}

.contact__success--tel strong a {
	text-decoration: none;
	color: #292929;
}

.contact__form--error { margin-top: 10px; width: 100%; font-size: 1.4rem; color: #c00; }

@media screen and (max-width: 768px) {
	.contact{padding: 0 20px;}
	.contact__form{
		margin: 0 auto;
		padding: 22px 12px 1px;
	}
	.contact__form--group{margin-bottom: 30px;}
	.contact__form--txt-1{
		margin-bottom: 20px;
		font-size: 1.2rem;
	}
	.contact__form--txt-2{margin-bottom: 10px;font-size: 1.2rem;}

	.contact__form--col1{display: block;width: 100%;}
	.contact__form--col2{display: block;font-size: 1.2rem;}
	.contact__form--select{
		height: 40px;
		padding: 0 10px;
		font-size: 1.2rem;
		background-size: 12px;
	}
	.contact__form--input{
		height: 40px;
		padding: 0 10px;
		font-size: 1.2rem;
	}
	.contact__form--group:last-child .contact__form--txt-2{margin-top: 0;}
	.contact__form--textarea{
		padding: 10px;
		height: 120px;
		font-size: 1.2rem;
	}
	.contact__form--txt-3{
		font-size: 1.2rem;
	}
	.contact__form--checkmark{
		width: 20px;
		height: 20px;
	}
	.contact__form--checkmark:after {
	    left: 5px;
	    top: 1px;
	    width: 4px;
	    height: 10px;
	}
	.contact__form--submit-btn,
	.contact__form--link-btn,
	.contact__form--confirm-btn { padding: 15px 0; width: 100%; max-width: 200px; font-size: 1.2rem; 	}
	.contact__form--submit-btn:after,
	.contact__form--link-btn:after,
	.contact__form--confirm-btn:after { right: 12px; margin-top: -12px; width: 20px; height: 20px; background-size: 6px; border-width: 1px; }
.contact__form--confirm-btn:after { right: auto; left: 12px; }

	.contact__success--txt{
		margin-bottom: 16px;
		font-size: 1.2rem;
	}

	.contact__success--tel{
		margin-bottom: 31px;
		font-size: 1.2rem;
	}

	.contact__success--tel strong {
		font-size: 1.6rem;
	}

	.contact__form--error { margin-top: 6px; font-size: 1.2rem; }

}
