@charset "utf-8";
/* ===================================================
	Home CSS
====================================================== */
#home .inner { width: 92%; max-width: 1100px; margin: 0 auto;}
#home .inner_large { width: 92%; max-width: 1400px; margin: 0 auto;}
/* ---------------------------------------------------
main_img
------------------------------------------------------ */
#main_img { position: relative;}
#main_img .flexslider { margin: 0; border: none; border-radius: 0; background: none; z-index: 0;}
#main_img .flexslider img {
	width: 100%; height: 800px; min-height: 600px;
	object-fit: cover; font-family: 'object-fit: cover;';
}

#main_img h1{
	text-align: center;
	position: absolute;
	left: 0; top: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	z-index: 1;
	width: 100%;
	height: 100%;
}
#main_img h1 span{
  padding: 0 0 10px;
	color: #fff;
	display: block;
	font-size: 32px;
	margin-top: 30px;
	text-shadow: rgba(0,0,0,0.2) 1px 1px 10px, rgba(0,0,0,0.2) -1px 1px 10px, rgba(0,0,0,0.2) 1px -1px 10px, rgba(0,0,0,0.2) -1px -1px 10px;
}

@media screen and (max-width: 600px) {
	#main_img h1 img { width: 50vw;}
	#main_img h1 span { font-size: 20px; margin-top: 0;}
	#main_img .flexslider img { height: 450px; min-height: inherit;}
}



/* ---------------------------------------------------
sec_lead
------------------------------------------------------ */
#sec_lead { padding: 100px 0; background: url(../img/lead_bg.gif)no-repeat top center; background-color: #f3f2ea; color: #7c7651; text-align: center;}
#sec_lead h2 { padding: 0 0 40px; font-size: 30px; line-height: 2.5;}
#sec_lead #map { margin-top: 10px; position: relative;}
#sec_lead #map img:nth-of-type(2) { position: absolute; top: 7%; left: 0; width: 45%;}
#sec_lead ul { display: flex; flex-wrap: wrap; justify-content: center;}
#sec_lead ul li { width: 400px; margin-right: 20px;}
#sec_lead ul li:last-of-type { margin-right: 0;}
#sec_lead ul li a { display: block; background: url(../img/arrow1.svg)no-repeat center right 15px #b59624; color: #fff; text-align: center; padding: 10px 0;}
#sec_lead ul li a:hover { opacity: 0.75; text-decoration: none;}
@media screen and (max-width: 600px) {
	#sec_lead { padding: 50px 0;}
	#sec_lead > div { overflow: hidden;}
	#sec_lead h2 { padding: 0 0 20px; font-size: 24px; line-height: 1.8;}
	#sec_lead h2+p { width: 92%; margin: 0 auto; text-align: left;}
	#sec_lead #map { margin-top: 0;}
	#sec_lead #map img:first-of-type { width: 110%; max-width: none; position: relative; left: 49%; transform: translateX(-50%);}
	#sec_lead #map img:nth-of-type(2) { position: relative; width: 85%; margin: -15vw auto 25px;}
	#sec_lead ul li { width: 90%; margin-right: 0; margin-bottom: 10px;}
	#sec_lead ul li:last-of-type { margin-bottom: 0;}
}


/* ---------------------------------------------------
sec1
------------------------------------------------------ */
#sec1 { padding: 80px 0; background: #e9dfbd;}
#sec1 h2 { text-align: center; font-family: 'EB Garamond', serif; font-size: 46px; color: #b59624; line-height: 1.5;}
#sec1 h2 span { display: block; font-size: 15px; color: #5e572b;}
#sec1 h2+p {  padding: 45px 0 25px; text-align: center;}
#sec1 h2+p+p { display: table; margin: 0 auto 45px; padding: 0 0 0 25px; text-align: center; background: url(../../img/sec1_icon.png)no-repeat left 7px;}
#sec1 ul { display: flex; flex-wrap: wrap;}
#sec1 ul li { position: relative; width: calc(100% / 3); border-right: 2px solid #e9dfbd; border-bottom: 2px solid #e9dfbd; box-sizing: border-box;}
*::-ms-backdrop, #sec1 ul li { width: 33.33%;}
#sec1 ul li p { position: absolute; bottom: 0; width: 100%; text-align: center; font-size: 18px; color: #fff; background-color: rgba(94,74,43,0.6);}
#sec1 ul li p span { display: inline; padding: 0 20px 0 0;}
#sec1 ul li:nth-last-of-type(1) p { top: 50%; bottom: inherit; left: 50%; width: 280px; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); padding: 8px 0; background-color: inherit;}
#sec1 ul li:nth-last-of-type(1) p::after { display: block; content: ''; position: absolute; right: 15px; top: 45%; width: 20px; height: 6px; border-bottom: 1px solid #fff; border-right: 1px solid #fff; transform: skew(45deg);}
#sec1 ul li img { width: 100%; height: 300px;}
#sec1 ul li:nth-of-type(3n) { border-right: none;}

@media screen and (max-width: 600px) {
	#sec1 { padding: 50px 0;}
	#sec1 h2 { font-size: 32px;}
	#sec1 h2+p { padding: 20px 4% 10px; text-align: left;}
	#sec1 ul li { width: 50%;}
	#sec1 ul li:nth-of-type(3n) { border-right: 1px solid #fff;}
	#sec1 ul li:nth-of-type(even) { border-right: none;}
	#sec1 ul li:nth-last-of-type(1) p { width: 90%;}
	#sec1 ul li:nth-last-of-type(1) p::after { position: relative; right: -42%;}
	#sec1 ul li img { height: 200px;}
}

/* ---------------------------------------------------
sec2
------------------------------------------------------ */
#sec2 section { padding: 80px 0;}
#sec2 section > div { display: flex; flex-wrap: wrap;}
#sec2 section h2 { font-family: 'EB Garamond', serif; font-size: 46px; color: #b59624; margin-bottom: 10px;}
#sec2 section .photo { width: 60%;}
#sec2 section .photo img { width: 100%; height: 100%;}
#sec2 section .txt { width: 455px; max-width: 40%; padding: 0 0 0 45px; box-sizing: border-box;}
#sec2 section .txt p + p { margin-top: 20px;}

#sec2 section:nth-of-type(2n) { background: #f3f2ea;}
#sec2 section:nth-of-type(2n) > div { justify-content: flex-end;}
#sec2 section:nth-of-type(2n) .photo { order: 1;}
#sec2 section:nth-of-type(2n) .txt { padding: 0 45px 0 0;}

#sec2 .slick-dots li button:before { font-size: 12px; color: #ccc; opacity: 1;}
#sec2 .slick-dots li.slick-active button:before { color: #b59624;}
#sec2 .slick_center { margin-bottom: 0;}
#sec2 .slick_center .slick-list { font-size: 0; height: 100%;}
#sec2 .slick_center .slick-list * { height: 100%;}
#sec2 .slick_center .slick-next { right: 0; z-index: 1;}
#sec2 .slick_center .slick-prev { left: 0; z-index: 1;}
#sec2 .slick_center .slick-arrow::before,
#sec2 .slick_center .slick-arrow::after { content: ''; width: 35px; height: 2px; position: absolute; top: 50%; background: #fff; opacity: 1;}
#sec2 .slick_center .slick-prev::before,
#sec2 .slick_center .slick-prev::after { left: 3px; transform-origin: left center;}
#sec2 .slick_center .slick-prev::before { transform: rotate(-45deg);}
#sec2 .slick_center .slick-prev::after { transform: rotate(45deg);}
#sec2 .slick_center .slick-next::before,
#sec2 .slick_center .slick-next::after { right: 3px; transform-origin: right center;}
#sec2 .slick_center .slick-next::before { transform: rotate(45deg);}
#sec2 .slick_center .slick-next::after { transform: rotate(-45deg);}

@media screen and (max-width: 600px) {
	#sec2 section { padding: 40px 0 50px;}
	#sec2 section h2 { font-size: 32px; text-align: center; margin-bottom: 20px;}
	#sec2 section .photo { width: 100%; order: 1; margin-top: 20px;}
	#sec2 section .txt { width: 100%; max-width: none; padding: 0;}
	#sec2 section:nth-of-type(2n) .txt { padding: 0;}

	#sec2 .slick_center .slick-arrow::before,
	#sec2 .slick_center .slick-arrow::after { width: 15px;}


}


/* ---------------------------------------------------
sec3
------------------------------------------------------ */
#sec3 { background: #f9f9f4; padding: 80px 0;}
#sec3 h2 { text-align: center; font-family: 'EB Garamond', serif; font-size: 46px; color: #b59624; line-height: 1.5;}
#sec3 h2 + p { padding: 25px 0; text-align: center;}
#sec3 .route { margin: 20px auto 0; text-align: center; display: flex; justify-content: space-between;}
#sec3 .route dl { display: flex; flex-direction: column; width: 30%; position: relative; z-index: 1;}
#sec3 .route dt { background: #5e572b; color: #fff; font-size: 17px; padding: 11px 0; line-height: 1.5;}
#sec3 .route dt span { display: block; font-size: 15px;}
#sec3 .route dd, section .route dd * { display: flex; flex-direction: column;}
#sec3 .route dd { flex-grow: 1; position: relative;}
#sec3 .route dd ul { position: relative;}
#sec3 .route dl ul:first-of-type { height: 235px;}
#sec3 .route dd ul::before { content: ''; display: block; border-right: 5px solid #ceccbf; height: 100%; position: absolute; left: calc(50% - 3px); z-index: -1;}
#sec3 .route dl:first-of-type .common_route { width: 333%; margin: 0 auto;}
#sec3 .route li { padding: 8px 0; justify-content: center; color: #000;}
#sec3 .route li:not([class]) { padding: 20px 0; flex-grow: 1; flex-shrink: 1;}
#sec3 .route li:not([class]) span { padding: 10px 0; background: #f9f9f4;}
#sec3 .route .point { font-size: 17px; background: #e9dfbd;}
#sec3 .route .goal { background: #b59624; color: #fff; font-size: 17px;}
#sec3 .route dl:not(:first-of-type) .common_route { display: none;}
#sec3 .route + a { display: block; width: 400px; padding: 10px; background: url(../img/arrow2.svg)no-repeat center right 20px #fff; border: 1px solid #b59624; text-align: center; margin: 45px auto 0; box-sizing: border-box;}
#sec3 .route + a:hover { text-decoration: none; opacity: 0.75;}

@media screen and (max-width: 600px) {
	#sec3 { padding: 50px 0;}
	#sec3 h2 { font-size: 32px;}
	#sec3 h2 + p { padding: 20px 0 10px;}
	#sec3 .route { display: block;}
	#sec3 .route dl { width: 100%; margin-top: 15px;}
	#sec3 .route dt { position: relative; font-size: 16px;}
	#sec3 .route dt::after { content: ''; display: block; width: 10px; height: 10px; position: absolute; right: 3vw; top: calc(50% - 10px); border-right: 2px solid #fff; border-bottom: 2px solid #fff; transform: rotate(45deg);}
	#sec3 .route dd { display: none;}
	#sec3 .route dl ul:first-of-type { height: auto;}
	#sec3 .route dl:first-of-type .common_route { width: 100%;}
	#sec3 .route li:not([class]) { padding: 15px 0;}
	#sec3 .route .start,
	#sec3 .route .goal { font-size: 16px;}
	#sec3 .route dl:not(:first-of-type) .common_route { display: block;}
	#sec3 .route + a { width: 100%; margin: 30px auto 0;}
}


/* ---------------------------------------------------
sec4
------------------------------------------------------ */
#sec4 { padding: 80px 0 110px;}
#sec4 h2 { text-align: center; font-family: 'EB Garamond', serif; font-size: 46px; color: #b59624; line-height: 1.5;}
#sec4 .tb_layout { margin-top: 30px;}
#sec4 .tb_layout dl { display: flex; flex-wrap: wrap; border-bottom: 1px solid #cac8b7;}
#sec4 .tb_layout dl dt { width: 300px; padding: 20px 0 20px 30px; background-color: #f9f9f4; box-sizing: border-box; display: flex; justify-content: center; align-items: center;}
#sec4 .tb_layout dl dd { width: calc(100% - 300px); padding: 20px 0 20px 30px; box-sizing: border-box;}
@media screen and (max-width: 600px) {
	#sec4 { padding: 50px 0 70px;}
	#sec4 h2 { font-size: 32px;}
	#sec4 .tb_layout { text-align: center;}
	#sec4 .tb_layout dl:first-of-type { border-top: 1px solid #cac8b7;}
	#sec4 .tb_layout dl dt { width: 100%; padding: 10px;}
	#sec4 .tb_layout dl dd { width: 100%; padding: 10px;}
}
