@charset "utf-8";

/* デザインに合わせて適宜変更してください */

/* パーツテンプレート
------------------------------------------------------------------*/
/* heading */
.hdg3 {
	margin-bottom: 60px;
}
.hdg4 {
	margin-bottom: 40px;
}
.hdg5 {
	margin-bottom: 20px;
}
/* row */
.row_default01 {
	margin-bottom: 60px;
}
.row_default01 .col_txt {
	width: 57%;
}
.row_default01 .copy {
	font-size: 137.5%;
	margin-bottom: 10px;
}
.row_default01 .col_img {
	width: 38%;
}
.row_default02 {
	margin-bottom: 60px;
}
.row_default02 .col {
	width: 47.5%;
}
.row_default02 .col .txt {
	text-align: center;
	font-size: 137.5%;
	margin-top: 20px;
}
.row_default03 {
	margin-bottom: 60px;
}
.row_default03 .col {
	width: 31.2%;
}
.row_default03 .col .txt {
	text-align: center;
	font-size: 125%;
	margin-top: 20px;
}
.row_default04 {
	margin: 0 auto 60px;
}
.row_default04 .col_txt {
	width: 66%;
}
.row_default04 .col_img {
	width: 29%;
}
/* box */
.box_default01 {
	background: #eee;
	padding: 40px 5% 45px;
	margin-bottom: 60px;
}
.row_default02 .box_default01 {
	margin-bottom: 0;
}
.row_default03 .box_default01 {
	padding: 45px 3% 40px;
	margin-bottom: 0;
}
.box_default01 dt {
	text-align: center;
	font-weight: normal;
	font-size: 125%;
	margin-bottom: 12px;
}
.box_default01 h5 {
	font-size: 125%;
	text-align: center;
	font-weight: normal;
	margin: 0 auto 25px;
}
/* list */
.list_default li {
	position: relative;
	padding-left: 24px;
	line-height: 1.375;
}
.list_default li:not(:last-child) {
	margin-bottom: 15px;
}
.list_default li:before {
	content: "";
	position: absolute;
	width: 6px;
	height: 6px;
	background: #333;
	border-radius: 10px;
	left: 0;
	top: .55em;
}
.list_default01 li {
	width: 49%;
}
.list_default02 {
	position: relative;
}
.list_default02:before, .list_default03:before {
	content: "";
	display: block;
	order: 1;
}
.list_default02:after, .list_default03:after {
	content: "";
	display: block;
}
.list_default02 li, .list_default02:before, .list_default02:after {
	width: 33%;
}
.list_default03 li, .list_default03:before, .list_default03:after {
	width: 24%;
}
/* flow */
.box_flow {
	background: #eee;
	padding: 50px 5% 50px;
	margin-bottom: 60px;
	position: relative;
}
.box_flow.arw_flow {
	margin-bottom: 110px;
}
.arw_flow:before {
	content: "";
	position: absolute;
	width: 0;
	height: 0;
	border-top: 30px solid #333;
	border-right: 45px solid transparent;
	border-left: 45px solid transparent;
	right: 0;
	left: 0;
	bottom: -70px;
	margin: auto;
}
.box_flow .col_txt {
	width: 56.6%;
}
.box_flow .col_txt dt {
	font-size: 137.5%;
	margin-bottom: 18px;
}
.box_flow .col_txt dt span {
	background: #333;
	color: #fff;
	display: inline-block;
	text-align: center;
	width: 40px;
	height: 40px;
	line-height: 40px;
	margin-right: 20px;
}
.box_flow .col_img {
	width: 38.4%;
	max-width: 345px;
}
/* qa */
.box_qa {
	background: #eee;
	padding: 50px 5% 45px;
	margin: 0 auto 60px;
}
.box_qa dt {
	font-size: 137.5%;
	line-height: 1.36;
	-ms-align-items: center;
	align-items: center;
	padding-bottom: 25px;
	margin-bottom: 20px;
	border-bottom: 1px solid #333;
}
.box_qa .box_q {
	background: #333;
	color: #fff;
	width: 40px;
	height: 40px;
	line-height: 40px;
	text-align: center;
	display: inline-block;
}
.box_qa .txt_q {
	width: calc(100% - 60px);
}
/* prof */
.row_prof {
	margin-bottom: 60px;
}
.box_prof {
	background: #eee;
	padding: 50px 5% 50px;
	width: 48%;
}
.box_prof h5 {
	text-align: center;
	font-size: 125%;
	font-weight: normal;
	margin-bottom: 24px;
}
.box_prof01 dl {
	line-height: 1.375;
}
.box_prof01 dt {
	width: 90px;
	font-weight: bold;
}
.box_prof01 dd {
	width: calc(100% - 90px);
}
.box_prof01 dt:not(:last-of-type), .box_prof01 dd:not(:last-of-type) {
	margin-bottom: 15px;
}
/* slide */
.wrap_slide {
	margin: 0 auto 60px;
}
.wrap_slide .bx-wrapper {
	box-shadow: none;
	border: none;
	margin-bottom: 0;
}
/* map */
#map_low {
	position: relative;
	width: 100%;
	padding: 430px 0 0 0;
	margin: 0 auto 60px;
}
#map_low iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
/* youtube */
.wrap_youtube {
	margin: 0 auto 60px;
}
.box_youtube {
	position: relative;
	width: 100%;
	max-width: 700px;
	padding: 490px 0 0 0;
	margin: 0 auto 40px;
}
.box_youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/* table */
.tbl_default {
	margin: 0 auto 60px;
}
.tbl_default table {
	border: 1px solid #333;
	width: 100%;
	line-height: 1.5;
}
.tbl_default th {
	background: #333;
	color: #fff;
	width: 25%;
	text-align: left;
	font-weight: 500;
	padding: 15px 18px;
	vertical-align: top;
}
.tbl_default tr:not(:last-child) th {
	border-bottom: 1px solid #fff;
}
.tbl_default td {
	width: 75%;
	padding: 15px 18px;
}
.tbl_default tr:not(:last-child) td {
	border-bottom: 1px solid #333;
}
.tbl_caption {
	margin-top: 10px;
}
.tbl_recruit .require span {
	position: relative;
	width: 100%;
	display: inline-block;
}
.tbl_recruit .require span:after {
	content: "必須";
	display: inline-block;
	color: #333;
	background: #fff;
	width: 40px;
	height: 25px;
	vertical-align: middle;
	position: absolute;
	right: 4px;
	font-size: 75%;
	text-align: center;
	line-height: 25px;
	top: 0;
	bottom: 0;
	margin: auto;
}
.tbl_recruit span.wpcf7-list-item.first {
	margin-left: 0;
}
.tbl_recruit td input {
	border: 1px solid #ddd;
	padding: 4px;
	width: 49%;
}
.tbl_recruit td .wpcf7-checkbox input {
	width: auto;
}
.tbl_recruit td select {
	background: #f2f4f5;
	width: 49%;
	padding: 5px;
}
.tbl_recruit td textarea {
	border: 1px solid #ddd;
	width: 100%;
	max-height: 200px;
}
.btn_submit {
	margin: 50px auto 0;
	text-align: center;
	position: relative;
	max-width: 330px;
	width: 100%;
}
.btn_submit:before {
	content: "";
	position: absolute;
	width: 7px;
	height: 7px;
	border-bottom: 2px solid #fff;
	border-right: 2px solid #fff;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 34px;
	transform: rotate(-45deg);
}
.btn_submit:hover {
	cursor: pointer;
	opacity: .85;
	transition: .3s;
}
.btn_submit input {
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: 137.5%;
	background: #333;
	line-height: 1;
	padding: 19px 5px;
	letter-spacing: .05em;
}
.btn_submit input:hover {
	cursor: pointer;
}
.btn_submit .wpcf7-spinner{
	position: absolute;
	top: 0;
	bottom: 0;
	right: -35px;
	margin: auto!important;
}
.txt_accept {
	text-align: center;
	margin: 40px auto;
}
.txt_accept span.wpcf7-list-item {
	margin-left: 0;
}
.box_form {
	background: #eee;
	text-align: center;
	padding: 10px 5% 15px;
}
@media only screen and (min-width: 768px) and (max-width: 960px) {
	.row_default02 .col {
		width: 49%;
	}
	.row_default03 .col {
		width: 32%;
	}
	.row_default02 .box_default01, .row_default03 .box_default01 {
		padding: 30px 3%;
		margin-bottom: 0;
	}
	.row_prof {
		display: block;
	}
	.box_prof {
		width: 100%;
	}
	.box_prof01 {
		margin-bottom: 40px;
	}
	.tbl_default th {
		width: 35%;
	}
	.tbl_default td {
		width: 65%;
	}
}

@media only screen and (max-width: 767px) {
	/* heading */
	.hdg3 {
		margin-bottom: 6vw;
	}
	.hdg4 {
		margin-bottom: 6vw;
	}
	.hdg5 {
		margin-bottom: 4vw;
	}
	/* row */
	.row_default01 {
		-webkit-flex-direction: column-reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
		margin-bottom: 11vw;
	}
	.row_default01 .col_txt {
		width: 100%;
		margin-top: 5vw;
	}
	.row_default01 .copy {
		font-size: 118.75%;
		margin-bottom: 2vw;
	}
	.row_default01 .col_img {
		width: 100%;
	}
	.row_default02 {
		display: block;
		margin-bottom: 11vw;
	}
	.row_default02 .col {
		width: 100%;
		text-align: center;
	}
	.row_default02 .col_l {
		margin-bottom: 7vw;
	}
	.row_default02 .col .txt {
		font-size: 100%;
		margin-top: 2.5vw;
	}
	.row_default03 {
		display: block;
		margin-bottom: 11vw;
	}
	.row_default03 .col {
		width: 100%;
		text-align: center;
	}
	.row_default03 .col_c {
		margin: 7vw auto;
	}
	.row_default03 .col .txt {
		font-size: 100%;
		margin-top: 2.5vw;
	}
	.row_default04 {
		-webkit-flex-direction: column-reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
		margin-bottom: 11vw;
	}
	.row_default04 .col_img {
		width: 100%;
		text-align: center;
	}
	.row_default04 .col_txt {
		width: 100%;
		margin-top: 5vw;
	}
	/* box */
	.box_default01 {
		padding: 6vw 5% 7vw;
		margin-bottom: 11vw;
	}
	.box_default01 dt {
		margin-bottom: 3.5vw;
	}
	.box_default01 h5 {
		font-size: 106.25%;
		margin-bottom: 4vw;
	}
	.row_default02 .box_default01 dd, .row_default03 .box_default01 dd, .row_default02 .box_default01 p, .row_default02 .box_default01 p {
		text-align: left;
	}
	/* list */
	.list_default {
		display: block;
	}
	.list_default li {
		width: 100%;
	}
	.list_default li:not(:last-child) {
		margin-bottom: 3vw;
	}
	/* flow */
	.box_flow {
		-webkit-flex-direction: column-reverse;
		-ms-flex-direction: column-reverse;
		flex-direction: column-reverse;
		padding: 8vw 5% 7vw;
		margin-bottom: 11vw;
	}
	.box_flow.arw_flow {
		margin-bottom: 15vw;
	}
	.box_flow .col_img {
		width: 100%;
		text-align: center;
		max-width: 100%;
	}
	.box_flow .col_txt {
		width: 100%;
		margin-top: 5vw;
	}
	.box_flow .col_txt dt {
		font-size: 125%;
		margin-bottom: 3vw;
	}
	.box_flow .col_txt dt span {
		margin-right: 10px;
	}
	.arw_flow:before {
		border-top-width: 15px;
		border-right-width: 22.5px;
		border-left-width: 22.5px;
		bottom: -9.5vw;
	}
	/* qa */
	.box_qa {
		padding: 7vw 5%;
		margin-bottom: 11vw;
	}
	.box_qa dt {
		font-size: 112.5%;
		padding-bottom: 4.5vw;
		margin-bottom: 4vw;
	}
	.box_qa .box_q {
		font-size: 122.22%;
	}
	.box_qa .txt_q {
		width: calc(100% - 50px);
	}
	/* prof */
	.row_prof {
		display: block;
		margin-bottom: 11vw;
	}
	.box_prof {
		width: 100%;
		padding: 8vw 5%;
	}
	.box_prof h5 {
		font-size: 106.25%;
		margin-bottom: 4vw;
	}
	.box_prof01 {
		margin-bottom: 5vw;
	}
	.box_prof01 dt {
		width: 25%;
	}
	.box_prof01 dd {
		width: 75%;
	}
	.box_prof01 dt:not(:last-of-type), .box_prof01 dd:not(:last-of-type) {
		margin-bottom: 2.5vw;
	}
	/* slide */
	.wrap_slide {
		margin-bottom: 11vw;
	}
	/* map */
	#map_low {
		padding-top: 215px;
		margin-bottom: 11vw;
	}
	/* youtube */
	.wrap_youtube {
		margin-bottom: 11vw;
	}
	.box_youtube {
		padding-top: 245px;
		margin-bottom: 5vw;
	}
	/* table */
	.tbl_default {
		margin-bottom: 11vw;
	}
	.tbl_default th {
		width: 40%;
		padding: 2vw 3vw 3vw;
		-ms-vertical-align: middle;
		vertical-align: middle;
	}
	.tbl_default td {
		width: 60%;
		padding: 2vw 3vw 3vw;;
	}
	.tbl_caption {
		margin-top: 4vw;
	}
	.tbl_recruit table, .tbl_recruit tbody, .tbl_recruit tr, .tbl_recruit th, .tbl_recruit td {
		display: block;
		width: 100%;
	}
	.tbl_recruit th {
		padding: 3vw 4vw 4vw;
	}
	.tbl_recruit .require span:after {
		font-size: 62.5%;
		width: 35px;
		height: 20px;
		line-height: 20px;
		right: 2px;
	}
	.tbl_recruit td {
		padding: 4vw 4vw 5vw;
	}
	.tbl_recruit td input {
		width: 100%;
	}
	.txt_accept {
		margin: 9vw auto 10vw;
	}
	.box_form {
		text-align: left;
		padding: 3vw 5%;
	}
	.btn_submit {
		margin-top: 8vw;
		max-width: 300px;
	}
	.btn_submit input {
		font-size: 106.25%;
		padding: 4vw 5% 5vw;
	}
	.btn_submit .wpcf7-spinner{
		right: auto;
		bottom: 0;
	}
}