@charset "utf-8";

/*-------------- all --------------*/

.btns,
.btns:visited,
.btns:link{ color: #9a8b68; }
.view { font-weight: 700; letter-spacing: 0.04em; color: #bdb28f; text-decoration: underline #bdb28f; text-underline-offset: 9px;}

.max_in { position: relative; max-width: 1600px; margin: 0 auto;}

a:visited,
a:link { color: inherit;}

body{ min-width: 1200px; margin: 0 auto; }

h3{ font-size: 20px; letter-spacing: 0.04em; font-weight: 500; text-align: center; }


nav ol{ padding: 0 0 0 195px; z-index: 90; top: 130px; position: absolute; }
nav ol li{ color: #fff; }
nav ol li:not(:last-of-type)::after{ color: #fff; }

.svg_title { display: block; margin: 0 auto 20px;}


/*-------------- fv --------------*/

#fv { color: #fff;}
#fv .fv_pic { position: relative; overflow: hidden; width: 100%; height: 100vh; background: url(../images/about/bg_fv.jpg) left center/cover no-repeat; }
/* #fv .fv_pic img{ display: block; position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); transform: translate(-50%, -50%); z-index: 1; } */

#fv .open{ position: absolute; top: 50%; left: 140px; transform: translate(0,-50%); z-index: 2; }
#fv .open h2{ padding: 50px 0 0; font-size: 20px; letter-spacing: 0.04em; text-align: left;}
#fv .open h2 img { display: block; margin-bottom: 20px;}

#fv .scroll { position: absolute; bottom: 46px; left: 40px; z-index: 2; font-size: 10px; letter-spacing: 0.4em; writing-mode: vertical-rl;}
#fv .scroll:after { content: ""; display: inline-block; width: 1px; height: 80px; background-color: #fff; margin-top: 13px; animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;}

@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}



/*-------------- concept --------------*/
#concept{ padding: 123px 0 0; }

#concept h3{ margin-bottom: 32px;}

#concept .video{ width: 980px; margin: 0 auto 100px; }
#concept .video video{ width: 100%; height: auto; }

#concept h4{ font-size: 20px; letter-spacing: 0.04em; margin-bottom: 44px; line-height: 1; text-align: center; font-weight: 500;}

#concept .parentheses{ width: 980px; margin: 0 auto 30px; padding: 24px 0; position: relative; font-size: 40px; letter-spacing: 0.04em; line-height: 1.5; font-weight: 700; text-align: center; }
#concept .parentheses:before,
#concept .parentheses:after{ position: absolute; content: ""; width: 28px; height: 100%; top: 0; border-bottom: 1px solid #000; border-top: 1px solid #000; }
#concept .parentheses:before{ left: 0; border-left: 1px solid #000; }
#concept .parentheses:after{ right: 0; border-right: 1px solid #000; }

#concept .text{ text-align: center; font-size: 18px; line-height: 2; margin-bottom: 90px;}

#concept .equip { position: relative; width: 880px; padding: 40px 0 26px; margin: 0 auto 119px; border: 1px solid #c9c9c9; border-radius: 10px; text-align: center;}
#concept .equip .top { position: absolute; top: -10px; left: 50%; transform: translateX(-50%); -webkit-transform: translateX(-50%); font-size: 22px; font-weight: 700; width: 760px; background: #fff;}
#concept .equip .circle { display: flex; justify-content: center; align-items: center; margin-bottom: 12px;}
#concept .equip .circle:last-child { margin-bottom: 0;}
#concept .equip .circle p { font-size: 14px; padding: 10px 40px; border: 1px solid #c9c9c9; border-radius: 20px; margin: 0 5px;}
#concept .equip .circle p:first-child { margin-left: 0;}
#concept .equip .circle p:last-child { margin-right: 0;}

#concept .bg { padding: 130px 0 150px; background: url(../images/about/bg_concept.jpg) no-repeat center top / 100%; }
#concept .concept { text-align: center;}
#concept .concept h5 { font-size: 22px; font-weight: 700; margin-bottom: 50px;}
#concept .concept h5 span { display: block; font-size: 40px; font-weight: 700; margin-top: 20px;}
#concept .concept .parentheses { width: 736px; margin: 0 auto 123px; font-size: 36px; line-height: 140%;}
#concept .concept p { font-size: 26px; line-height: 190%; font-family: dnp-shuei-mincho-pr6n, sans-serif; font-weight: 500; letter-spacing: 0.14em; margin-bottom: 600px;}
#concept .concept p em { font-size: 38px; line-height: 1; font-weight: 500;}
#concept .concept p span { display: block; font-size: 18px; letter-spacing: 0.1em; line-height: 210%; font-family: 'source-han-sans-cjk-ja', sans-serif; font-weight: 500; margin-top: 83px;}

/* slider */
#concept .slider_item{ float: left; width: 400px; height: 400px; margin: 0 20px 30px; }
#concept .slider_item img{ width: 100%; height: auto; }

#concept .slick-dots li button{ position: relative; }
#concept .slick-dots li button:before{ content: ""; width: 14px; height: 14px; border-radius: 50px; }

#concept .slick-dotted.slick-slider{ margin-left: -3.5%; }
#concept .slider .slick-dots li{ width: 14px; height: 14px; margin: 0 10px; border-radius: 50px; background: #c9c9c9; }
#concept .slick-dots li button:hover:before,
#concept .slick-dots li button:focus:before,
#concept .slick-dots li.slick-active button:before{ background: #8c0000; }



/*-------------- feature --------------*/
#feature{ padding: 100px 0;}
#feature h3{ margin-bottom: 40px; }

#feature .feature { position: relative; max-width: 1100px; height: 450px; display: flex; justify-content: flex-start; align-items: flex-start; flex-flow: row-reverse; margin: 0 auto 20px;}
#feature .feature .left { position: absolute; left: -23%;}
#feature .feature .right { width: 550px; padding-top: 16px; margin-left: 50px;}
#feature .feature .right .num { display: flex; align-items: center; padding-left: 10px; margin-bottom: 30px; border-left: 4px solid #000;}
#feature .feature .right .num span { font-size: 16px; font-weight: 500; letter-spacing: 0.04em; margin-right: 11px;}
#feature .feature .right .num span img { display: block; margin-bottom: 6px;}
#feature .feature .right .num img { }

#feature .feature .right .title { font-size: 36px; font-weight: 700; letter-spacing: 0.04em; line-height: 1.333; margin-bottom: 16px;}
#feature .feature .right .txt { font-size: 16px; line-height: 1.875; }

#feature .feature03 { align-items: center; margin-bottom: 0;}



/*-------------- points --------------*/
#points{ padding: 130px 0; background: url(../images/about/bg_repeat.jpg) center; }
#points h3{ margin-bottom: 50px; }

#points article .flex{ display: flex; }

#points article .text,
#points article figure{ width: 50%; height: auto; }
#points article figure figcaption{ display: none; }
#points article figure img{ width: 100%; height: auto; }

#points article .text{ box-sizing: border-box; padding: 50px 40px 0 0; }
#points article .text h4{ padding: 0 0 22px; font-size: 36px; letter-spacing: 0.04em; font-weight: 700; text-align: center;}
#points article .text h4 img { display: block; margin: 0 auto 24px;}
#points article .text p{ line-height: 200%; }
#points article .text p small{ display: block; padding: 15px 0 0; font-size: 12px; }

#points article:nth-of-type(even) .flex{ flex-direction: row-reverse; }
#points article:nth-of-type(even) .text{ padding: 50px 0 0 40px ; }

/*-------------- hospitality --------------*/

#hospitality { padding: 100px 0; }
#hospitality h3 { font-size: 18px; margin-bottom: 39px;}
#hospitality .box{ padding: 67px 0 57px; text-align: center; background: url(../images/about/bg_repeat_02.jpg) center; border-radius: 20px; }
#hospitality .box  h4{ font-size: 30px; font-weight: 700; margin-bottom: 32px;}
#hospitality .box  p{ line-height: 1.75;}


/*-------------- enjoy --------------*/
#enjoy .enjoy_inner{ width: 1100px; margin: 0 auto; padding: 0 0 0 35px; box-sizing: content-box; }
#enjoy img{ width: 100%; height: auto; }

#enjoy .w_box{ background: #fff; padding: 65px 0 100px 100px; margin: -24% 9% 0 0; position: relative; box-sizing: border-box; }
#enjoy .w_box .text{ float: left; width: 500px; padding: 0 50px 0 0; }
#enjoy .w_box .text h3{ padding: 0 0 35px; text-align: left; }
#enjoy .w_box .text h3 img{ width: 248px; height: auto; margin-left: 0;}
#enjoy .w_box .text h4{ padding: 0 0 30px; font-size: 36px; letter-spacing: 0.04em; font-weight: 600; line-height: 140%; }
#enjoy .w_box .text p{ padding: 0 0 50px; line-height: 200%; }
#enjoy .w_box .text .btns{ width: 280px; padding: 22px 15px 22px 0; background: url(../images/top/icn_05.png) no-repeat 90% center; }
#enjoy .w_box .text .btns:hover { color: #fff; background: #9a8b68;}

#enjoy .w_box .pic{ float: right; width: 550px; }
#enjoy .w_box .pic img:first-of-type{ padding: 0 0 10px; }


@media only screen and (max-width: 1380px) {
	
	#enjoy .w_box .text{ width: 500px; padding: 0 50px 0 0; }
	#enjoy .w_box .pic{ float: left; width: 500px; }
	
}

@media only screen and (max-width: 1250px) {
	
	#enjoy .enjoy_inner{ width: 965px; }
	#enjoy .w_box .text{ width: 460px; padding: 0 30px 0 0; }
	#enjoy .w_box .pic{ width: 450px; }
	
}



/*-------------- top_btn --------------*/
.top_btn{ padding: 0 0 100px; }
.top_btn .btns{ width: 280px; margin: 0 auto; padding: 22px 0; }

.access{ background: url(../images/about/bg_repeat.jpg) center; }
.access h3{ text-align: left; }






/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	
	/*-------------- all --------------*/
	
	.inner{ width: 85%; }
	.max_in { max-width: none;}
	
	body{ min-width: 100%; }
	h3{ font-size: 15px; }
	h3 img,
	h4 img { width: auto; height: 25px;}
	.svg_title { display: block; margin: 0 auto 15px;}
	
	nav ol{ top: 120px; padding-left: 5%;}

	
	/*-------------- fv --------------*/
	
	#fv .fv_pic { width: 100%; height: 70vh; background: url(../images/about/bg_fv-sp.jpg) center bottom/cover no-repeat; }
/* 	#fv .fv_pic img { position: absolute; top: 50%; left: 50%; min-width: 100%; min-height: 100%; -webkit-transform: translate(-50%, -50%); -moz-transform: translate(-50%, -50%); transform: translate(-50%, -50%); z-index: 1;} */
	
	#fv .open{ left: 5%; }
	#fv .open h2{ padding: 30% 0 0; font-size: 15px;}
	#fv .open h2 img { display: block; width: 273px; height: auto; margin-bottom: 15px;}

	
	#fv .scroll { position: absolute; bottom: 46px; left: 4%; z-index: 2;}
	#fv .scroll:after { content: ""; display: inline-block; width: 1px; height: 80px; background-color: #fff; margin-top: 13px; animation: sdl 1.5s cubic-bezier(1, 0, 0, 1) infinite;}
		
	
	/*-------------- concept --------------*/
	#concept{ padding: 50px 0 0;}
	
	#concept .video{ width: 100%; height: auto; margin-bottom: 60px;}
	
	#concept h4{ font-size: 15px;}

	#concept .parentheses{ width: 100%; margin: 0 auto 32px; padding: 8px 0; font-size: 20px; line-height: 1.5;}
	#concept .parentheses:before,
	#concept .parentheses:after{ width: 9px;}


	
	#concept .text{ font-size: 13px; line-height: 1.769; margin-bottom: 60px; white-space: nowrap;}
	
	#concept .equip { position: relative; width: 100%; padding: 40px 15px 15px; margin: 0 auto 50px; border: 1px solid #c9c9c9; border-radius: 10px; text-align: center;}
	#concept .equip .top { top: -20px; font-size: 15px; line-height: 1.333; font-weight: 700; width: 260px; background: #fff; font-feature-settings: "palt";}
	#concept .equip .circle { display: flex; justify-content: center; flex-wrap: wrap; align-items: center; margin-bottom: 0px;}
	#concept .equip .circle p { font-size: 12px; padding: 5px 20px; border-radius: 20px; margin: 0 2.5px 5px;}
	#concept .equip .circle p:nth-child(n+3) { margin-bottom: 0;}
	
	
	#concept .bg { background-size: auto 90%;}
	#concept .concept { text-align: center; padding: 60px 0 50px;}
	#concept .concept h5 { font-size: 18px; font-weight: 700; margin-bottom: 50px;}
	#concept .concept h5 span { display: block; font-size: 20px; font-weight: 700; margin-top: 20px;}
	#concept .concept .parentheses { width: 100%; margin: 0 auto 60px; font-size: 20px; line-height: 1.467;}
	#concept .concept p { font-size: 16px; line-height: 1.769; margin-bottom: 0;}
	#concept .concept p em { font-size: 20px; line-height: 2;}
	#concept .concept p span { display: block; font-size: 10px; line-height: 190%; margin-top: 40px;}

	/* 	slider */
	#concept .slider_item{ width: 200px; height: 200px; margin: 0 10px 5px; }
	#concept .slider .slick-dots li{ width: 10px; height: 10px; margin: 0 5px; }
	#concept .slick-dots li button{ width: 10px; height: 10px; padding: 0px; }
	#concept .slick-dots li button:before{ width: 10px; height: 10px; font-size: 40px; }
	#concept .slick-dotted.slick-slider{ margin-bottom: 15px; }
	
	
	
	/*-------------- feature --------------*/
	#feature{ padding: 50px 0;}
	#feature h3{ padding: 0; }
	
	#feature .feature { display: block; width: 90%; height: auto; margin: 0 auto 45px;}
	#feature .feature .left { position: static;}
	#feature .feature .right { width: 100%; padding-top: 0; margin: 0 0 14px;}
	#feature .feature .right .num { display: flex; align-items: center; padding-left: 10px; margin-bottom: 15px; border-left: 4px solid #000;}
	#feature .feature .right .num span { font-size: 13px; margin-right: 6px;}
	#feature .feature .right .num span img { display: block; height:  7.5px; margin-bottom: 6px;}
	#feature .feature .right .num img { width: auto; height: 25px;}
	
	#feature .feature .right .title { font-size: 20px; line-height: 1.5; margin-bottom: 8px;}
	#feature .feature .right .txt { font-size: 13px; line-height: 2; }
	
	#feature .feature03 { align-items: center; margin-bottom: 0;}

	/*-------------- points --------------*/
	#points{ padding: 50px 0; }
	#points h3{ padding: 0; margin-bottom: 33px;}
	#points article{ margin-bottom: 35px; padding-bottom: 35px; border-bottom: 1px solid #a0a0a0; }
	#points article:last-of-type{ padding-bottom: 0; border-bottom: 0px; margin-bottom: 0; }
	
	#points article .flex,
	#points article:nth-of-type(even) .flex{ flex-direction: column; }
	
	#points article .text,
	#points article figure{ width: 100%; }
	#points article figure figcaption{ display: block; font-size: 12px; padding: 15px 0 0; }
	
	#points article .text,
	#points article:nth-of-type(even) .text{ padding: 0 0 20px; }
	#points article .text h4{ padding: 0 0 12px; font-size: 20px; font-weight: 600; text-align: left;}
	#points article .text h4 img { width: auto; height: 25.5px; margin-left: 0;}
	#points article .text h4 span{ padding: 0 0 17px; font-size: 35px; }
	#points article .text p{ font-size: 13px; letter-spacing: -.02em; }
	#points article .text p small{ display: none; }
	
	
	/*-------------- hospitality --------------*/
	
	#hospitality { padding: 50px 0; }
	#hospitality h3 { font-size: 14px; margin-bottom: 39px;}
	#hospitality h3 img { width: auto; height: 22px;}
	#hospitality .box{ padding: 32px 0 23px; border-radius: 10px; }
	#hospitality .box h4{ font-size: 20px; line-height: 1.5; margin-bottom: 15px;}
	#hospitality .box p { font-size: 13px; letter-spacing: -0.025em; line-height: 2;}
	
		
	/*-------------- enjoy --------------*/
	#enjoy .enjoy_inner{ width: 90%; margin: 0 0 0 auto; padding: 0; }
	#enjoy .w_box{ margin: -25% 9% 0 0; padding: 50px 0 50px 0; }
	
	#enjoy .w_box .text{ float: none; width: 100%; padding: 0; }
	#enjoy .w_box .text h3{ padding: 0 0 30px; }
	#enjoy .w_box .text h3 span{ padding: 0 0 10px; }
	#enjoy .w_box .text h4{ padding: 0 0 15px; font-size: 20px; line-height: 170%; }
	#enjoy .w_box .text p{ padding: 0 0 30px; font-size: 13px; }
	
	#enjoy .w_box .pic{ float: none; width: 100%; padding: 40px 0 0; }
	
	
	/*-------------- top_btn --------------*/
	.top_btn{ padding: 0 0 50px; }
	.top_btn .btns{ width: 70%; padding: 18px 0; }

	
	
	
}
