@charset "utf-8";

/****************************************
 * input・button / submit
*****************************************/

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="password"],
select, textarea {
	border: 1px solid #DDD;
	padding: 15px;
	font-size: 1.6rem;
	font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', Hiragino Kaku Gothic Pro W3, 'ＭＳ Ｐゴシック', MS P Gothic, Verdana, sans-serif;
	letter-spacing: 0.03em;
	background: #F5F5F5;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	transition: .5s;
	outline: none;
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
input[type="password"]:focus,
select:focus, textarea:focus {
	outline: none;
	border: 1px solid #ed1b2e;
	background: #FFF;
}
input[type="number"] {
	-moz-appearance: textfield;
}
input[type="number"]::-webkit-outer-spin-button, input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}
select {
	width: 100%;
	color: #000;
	padding: 10px 15px;
	background: #F5F5F5 url(images/icons/icon_under01.webp) no-repeat 95% 50%;
	background-size: 20px 13px;
}
select:focus {
	background: #F5F5F5 url(images/icons/icon_under01.webp) no-repeat 95% 50%;
	background-size: 20px 13px;
}
select:hover {
	cursor: pointer;
}
option {
	padding: 5px 15px;
}
select option selected {
	color: #999;
}
textarea {
	width: 100%;
}
label:hover {
	cursor: pointer;
}
label.label_first {
	display: inline-block;
	margin: 0 40px 0 0;
}

input[type="submit"] {
	border-radius: 0;
	-webkit-box-sizing: content-box;
	-webkit-appearance: button;
	appearance: button;
	border: none;
	cursor: pointer;
}
input[type="submit"]:hover {
	cursor: pointer;
	opacity: 0.8;
}
.submit_red {
	color: #fff;
	background: #ed1b2e;
	border: 1px solid #ed1b2e;
	border-bottom: 4px solid #89111c;
}
.submit_blue {
	color: #fff;
	background: #00C6C5;
	border: 1px solid #00C6C5;
	-webkit-box-shadow: 5px 5px 0px 0px rgba(156, 217, 202, 1);
	-moz-box-shadow: 5px 5px 0px 0px rgba(156, 217, 202, 1);
	box-shadow: 5px 5px 0px 0px rgba(156, 217, 202, 1);
}
.back_btn {
	width: 20%;
	text-align: center;
	background: url(../img/icon_left01.png) #FFF no-repeat 10% 49%;
	background-size: 10px 15px;
	font-size: 1.4rem;
}
.form_btn_area .back_btn {
	margin: -75px 0 0;
}
.back_btn a {
	display: block;
	padding: 25px 0;
	border: 1px solid #eee;
	color: #666;
}
.attention {
	margin: 10px 0;
	line-height: 1.6;
}
.error_message {
	text-align: center;
	padding: 130px 0 40px;
	line-height: 1.8;
}

@media screen and (max-width: 667px) {
	input[type="text"], input[type="tel"], input[type="password"], input[type="email"], input[type="number"], select, textarea {
		padding: 12px;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		font-size: 1.6rem;
		-webkit-appearance: none;
		border-radius: 0;
		border: 1px solid #DDD;
		font-size: 1.6rem;
	}
	input[type="text"], input[type="email"], input[type="number"], input[type="tel"], input[type="password"], select, textarea {
		width: 100%;
	}
	select {
		border-radius: 0;
	}
	textarea {
		height: 180px;
	}
	input[type="radio"], input[type="checkbox"] {}


	.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;
	}
	input[type="submit"] {
		display: block;
		width: 100%;
		padding: 20px 10px;
		font-size: 1.85rem;
		border-radius: 0;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
	}
	.form_btn_area {
		padding: 0 15px 0;
	}
	.form_btn_area input[type="submit"] {
		width: 100%;
		margin: 0 auto;
	}
	.back_btn {
		width: 100%;
		text-align: left;
		background: url(../img/icon_left01.png) no-repeat 0% 49%;
		background-size: 10px 15px;
	}
	.form_btn_area .back_btn {
		margin: 25px 0 0;
	}
	.back_btn a {
		display: inline-block;
		padding: 10px 20px;
		border: none;
	}
	.error_message {
		text-align: left;
		padding: 30px 0 20px;
	}
}

/****************************************
 * コンテンツ
*****************************************/

#inquiry .form_area {
	padding: 70px 0;
	background: #F0F8FF;
	box-shadow: 0 5px 5px -2px #CCC inset;
}
#inquiry .inquiry_box {
	padding: 0;
}
#inquiry .form_area .form_top {
	text-align: center;
}
#inquiry .form_area .form_top p {
	color: #ed1b2e;
	margin-bottom: 18px;
	font-weight: bold;
}

#inquiry .mail_title {
	font-size: 2.4rem;
	text-align: center;
	color: #004b79;
	letter-spacing: 0.1em;
	font-weight: bold;
	padding: 0 0 30px 0;
}
#inquiry .form_title {
	padding: 0 0 30px;
	font-size: 2.4rem;
	text-align: center;
	color: #212121;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.form_box .form_title span {
	display: block;
	margin-top: 12px;
}
.form_box .form_title img {
	margin: 0 0 5px 0;
	width: 90px;
}
.form_box .form_title .sub_txt {
	font-size: 1.8rem;
}
.form_table_inner {
	background: #FFF;
	padding: 60px 60px 60px;
}
.form_box .cau_txt {
	line-height: 2.0;
	font-size: 1.5rem;
	text-align: center;
	padding: 0 0 30px 0;
}
.form_txt {
	margin: 15px 0 0;
	text-align: center;
	line-height: 1.7;
}

@media screen and (max-width: 768px) {
	#inquiry .form_area {
		padding: 50px 0;
	}
	.form_table_inner {
		padding: 60px 30px 30px;
	}
	.form_box .form_title img {
		width: 70px;
	}
}
@media screen and (max-width: 560px) {
	#inquiry .form_area {
		background: #FFF;
		padding: 30px 0;
	}
	.form_table_inner {
		padding: 0 0 20px;
	}
	#inquiry .form_title {
		padding: 0;
		margin-bottom: 20px;
		font-size: 2.0rem;
		font-weight: bold;
		line-height: 1.4;
		letter-spacing: 0.05em;
	}
	.form_table_inner .button_box.center {
		padding: 0 30px;
	}

}
@media screen and (max-width: 430px) {
	#inquiry .form_title {
		font-size: 1.6rem;
	}
	.form_table_inner .button_box.center {
		padding: 0 20px;
	}
}
@media screen and (max-width: 380px) {
	#inquiry .mail_title {
		font-size: 2rem;
	}
	
}
@media screen and (max-width: 320px) {
	#inquiry .form_title {
		font-size: 1.4rem;
	}
	#inquiry .mail_title {
		font-size: 1.8rem;
	}
	
}


/****************************************
 * テーブル
*****************************************/

table.form_table {
	border: none;
	table-layout: fixed;
}
table.form_table,
table.form_table tr,
table.form_table th,
table.form_table td {
	border-collapse: collapse;
}
table.form_table tr {
	display: flex;
	border: 1px solid #EDEDED;
	border-left: none;
	border-right: none;
}
table.form_table th {
	width: 30%;
	border: none;
	font-weight: bold;
	padding: 25px 25px 25px 25px;
	position: relative;
	display: flex;
	align-items: center;
}
table.form_table th .form_th_title {
	display: inline-block;
	padding: 5px 0 0;
}
table.form_table th p.form_th_notes {
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	display: inline-block;
	padding: 3px 12px;
	font-size: 1.3rem;
	font-weight: bold;
	color: #ed1b2e;
	border: 2px solid #ed1b2e;
}
table.form_table td {
	width: 70%;
	padding: 25px 25px 25px 25px;
}
table.form_table td dl.double {
	display: flex;
	align-items: center;
	margin-top: 18px;
}
table.form_table td dl.double dt {
	width: 24%;
}
table.form_table td dl.double dd {
	width: 76%;
}

@media screen and (max-width: 768px) {
	table.form_table tr {
		flex-direction: column;
	}
	table.form_table th,
	table.form_table td {
		width: 100%;
	}
	table.form_table th {
		padding: 20px 0 0 0
	}
	table.form_table td {
		padding: 12px 0 20px 0
	}
	table.form_table th .form_th_title {
		padding: 0 0 0 3px;
	}
	table.form_table th p.form_th_notes {
		display: inline-block;
		position: static;
		transform: none;
		margin-left: 12px;
		padding: 1px 6px;
		background: #ed1b2e;
		color: #FFF;
		font-size: 1.1rem;
	}
	
	table.form_table td dl.double {
		flex-direction: column;
	}
	table.form_table td dl.double dt {
		width: 100%;

	}
	table.form_table td dl.double dd {
		width: 100%;
	}
}
@media screen and (max-width: 560px) {
	table.form_table th {
		padding: 12px 20px;
	}
	table.form_table td {
		padding: 15px 20px;
	}
	table.form_table th .form_th_title {
		padding: 0;
	}
	table.form_table th p.form_th_notes {
		display: inline-block;
		position: static;
		transform: none;
		margin: 0 0 0 12px;
		padding: 3px 6px;
		background: #ed1b2e;
		color: #FFF;
		border: 1px solid #FFF;
		font-size: 1.1rem;
	}
	ul.file_attachment_list {
		margin-top: 12px;
	}
}


/****************************************
 * 入力項目
*****************************************/

input.name,
input.kana,
input.phone {
	width: 60%;
}
select.jusho {
	width: 30%;
}
input.your-jusho2 {
	width: 100%;
}
input.mail {
	width: 78%;
}
textarea.message {
	width: 100%;
}
table.form_table span.howYouKnow { /* ラジオボタン */
	display: flex;
	flex-wrap: wrap;
}
table.form_table span.howYouKnow span {
	margin: 0 30px 0 0;
}
table.form_table span.howYouKnow span input[type="radio"] {
	width: 18px;
	height: 18px;
	margin: 0 3px 0 0;
}

@media screen and (max-width: 768px) {
	input.name,
	input.kana,
	input.phone,
	input.mail {
		width: 100%;
	}
	select.jusho {
		width: 50%;
	}
}
@media screen and (max-width: 560px) {
	select.jusho {
		width: 30%;
	}
	table.form_table span.howYouKnow span {
		width: calc(100% / 2);
		margin: 0;
	}
}
@media screen and (max-width: 430px) {
	select.jusho {
		width: 100%;
	}
	table.form_table span.howYouKnow span {
		width: 100%;
		margin-top: 3px;
	}
	
}


/* エラーメッセージ
 * *********************************/

.wpcf7-not-valid-tip {
	display: block;
	color: #ed1b2e;
	font-size: .8em;
	font-weight: bold;
	margin-top: 6px;
}



/* 個人情報の取扱い
 * *********************************/

.privacy_box {
	margin: 30px auto 0;
	border: 1px solid #DDD;
	font-size: 1.4rem;
	line-height: 1.5;
	overflow-x: auto;
}
.privacy_box_title {
	padding: 20px 0 0;
	font-size: 1.6rem;
	text-align: center;
}
.privacy_box .content_box {
	width: 100%;
	height: 150px;
	padding: 10px 20px 20px;
}
.privacy_title {
	padding: 30px 0 15px;
}

