@charset "utf-8";

.languageMenu{
	position: absolute;
	z-index: 999;
	top: 110px;
	right: 30px;
	width: 135px;
	color: #FFF;
	border: 1px solid #FFF;
}
.languageMenu dt{
	line-height: 32px;
	text-align: center;
	cursor: pointer;
}
.languageMenu dd{
	border-top: 1px solid #FFF;
}
.languageMenu dd a{
	display: block;
	line-height: 32px;
	text-align: center;
	background-color: rgba(0,94,119,0.6);
}
.languageMenu div{
	display: none;
}
.languageMenu:hover div{
	display: block;
}



#mv,
#topSlider,
#topSlider .swiper-slide{
	width: 100%;
	height: calc(100vh - 80px - 24px);
	position: relative;
}
#topSlider{
	border: 10px solid #601513;
}
#topSlider .swiper-pagination{
	bottom: 280px;
	right: 40px;
	width: 10px;
	left: auto;
}
#topSlider .swiper-pagination-bullet{
	width: 15px;
	height: 15px;
	border-radius: 100%;
	background-color: #FFF;
	border: none;
	transition: all 1s ease;
	opacity: 0.5 !important;
	margin: 8px 0;
	z-index: 9;
}
#topSlider .swiper-pagination-bullet-active{
	opacity: 1 !important;
}
#topSlider .catchcopy{
	width: 100%;
	height: 300px;
	background-size: 1200px;
	background-repeat: no-repeat;
	background-position: center center;
	left: 0;
	top: calc(50% - 150px);
	z-index: 9;
	position: absolute;
}
#topSlider .topSLider01 .catchcopy{
	top: 0;
	left: 0;
	width: 900px;
	height: 100%;
	background-size: 100%;
	background-image: url("../images/home/topSlider01_catch.png");
}
#topSlider .topSLider02 .catchcopy{
	background-image: url("../images/home/topSlider02_catch.png");
}
#topSlider .topSLider03 .catchcopy{
	background-image: url("../images/home/topSlider03_catch.png");
}
#topSlider .topSLider04 .catchcopy{
	background-image: url("../images/home/topSlider04_catch.png");
}
#topSlider .topSLider05 .catchcopy{
	background-image: url("../images/home/topSlider05_catch.png");
}
#topSlider .topSLider06 .catchcopy{
	background-image: url("../images/home/topSlider06_catch.png");
}
#mv .scroll{
	display: block;
	position: absolute;
	z-index: 99;
	width: 16px;
	height: 137px;
	bottom: 30px;
	right:45px;
	overflow: hidden;
	background: url("../images/home/mv_scroll.png") no-repeat center top;
	background-size: 100%;
}
#mv .snsList{
	flex-direction: column;
	position: absolute;
	z-index: 9;
	right: 40px;
	bottom: 200px;
	height: 70px;
}
#mv .snsList dd{
	margin-left: 0;
	width: 24px;
}
#homeBanner a{
	display: block;
	width: 49%;
	margin-top: 8px;
	margin-bottom: 8px;
}
#homeBanner a.wide{
	width: 100%;
}
#home01{
	background: url("../images/home/home01_bg.jpg") no-repeat center top;
	position: relative;
	height: 1320px;
}
#home01:before{
	content: "";
	display: block;
	width: 100%;
	background: url("../images/home/home01_before.png") no-repeat center top;
	height: 1056px;
	background-size: 2000px;
	position: absolute;
	top: 0;
	left: 0;
}
#home01 .container1080{
	padding-right: 550px;
}
.home01_catch{
	font-size: 168px;
	color: rgba(255,255,255,0.5);
	line-height: 1;
	position: absolute;
	top: 700px;
	width: 2000px;
	text-align: center;
	left: calc(50% - 1000px);
	z-index: 999;
}
.home01_pic01{
	width: 2000px;
	text-align: center;
	position: absolute;
	bottom: 0;
	left: calc(50% - 1000px);
	z-index: 99;
}
#home02 h2{
	position: relative;
	padding-top: 130px;
}
#home02 h2 span{
	vertical-align: middle;
	display: inline-block;
	padding: 0 15px;
}
#home02 h2:before{
	content: "Appealing Point";
	display: block;
	text-align: center;
	color: #EFE8E7;
	position: absolute;
	width: 2000px;
	top: 0;
	left: calc(50% - 1000px);
	font-size: 196px;
	z-index: -1;
	letter-spacing: 0.1em;
}
#home02 .appealingBox{
	background: url("../images/home/home02_bg.jpg") no-repeat center top;
	background-size: cover;
}
.appealingBox .image{
	width: 50%;
	height: 736px;
}
.appealingBox .text{
	width: 460px;
}
.appealingBox .image img{
	float: right;
	max-width: none;
}
.appealingBox .flexReverse .image img{
	float: left;
}
.appealingBox_title{
	flex-wrap: nowrap;
	position: relative;
}
.appealingBox_title:after{
	content: "";
	display: block;
	width: 100vw;
	height: 1px;
	background-color: #AF8A89;
	position: absolute;
	left: 0;
	bottom: 56px;
}
.appealingBox_title div + div{
	margin-left: 40px;
}
.appealingBox_title span{
	display: block;
	white-space: nowrap;
}
#home02 .appealingBox_title{
	margin-left: -260px;
}
.home02_h402 span{
	position: relative;
}
.home02_h402 span:before,
.home02_h402 span:after{
	content: "";
	display: block;
	height: 1px;
	width: 100vw;
	position: absolute;
	top: 50%;
	background-color: #601513;
}
.home02_h402 span:before{
	right: calc(100% + 20px);
}
.home02_h402 span:after{
	left: calc(100% + 20px);
}
.home02Slider{
	margin-top: -40px;
	padding-bottom: 0;
}
.home02Slider ul li{
	width: 20%;
}
.home02Slider ul li a{
	display: block;
	position: relative;
}
.home02Slider ul li a:after{
	content: "";
	display: block;
	width: calc(100% - 12px);
	height: calc(100% - 12px);
	position: absolute;
	border: 1px solid #FFF;
	top: 5px;
	left: 5px;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}
.home02Slider ul li a .image{
	transition: all 0.3s ease;
}
.home02Slider ul li a .text{
	position: absolute;
	width: calc(100% - 80px);
	height: calc(100% - 80px);
	background: rgba(255,255,255,0.7);
	top: 40px;
	left: 40px;
	display: flex;
	align-items: center;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}
.home02Slider ul li a .text p{
	background-size: 45px;
	width: 100%;
}
.home02Slider ul li a .text p .single{
	line-height: 72px;
}
.home02Slider ul li a:hover{
	opacity: 1;
}
.home02Slider ul li a:hover .image{
	filter: blur(10px);
}
.home02Slider ul li a:hover:after,
.home02Slider ul li a:hover .text{
	opacity: 1;
	visibility: visible;
}
#home03{
	margin-top: -1px;
}
#home03 .appealingBox_title:after{
	left: auto;
	right: 0;
}
#home03 .lead .flexSpace{
	align-items: flex-end;
}
#home03 .lead h4{
	padding-bottom: 45px;
}
.home03List{
	width: 1600px;
	margin-left: auto;
	margin-right: auto;
	max-width: calc(100% - 64px);
}
.home03List li{
	margin: 4px 0;
	width: calc((100% - 24px) / 4);
}
.home03List li.wide{
	width: calc((100% - 16px) / 3);
}
.home03List li a{
	display: block;
	position: relative;
}
.home03List li a:after{
	content: "";
	display: block;
	width: calc(100% - 12px);
	height: calc(100% - 12px);
	top: 5px;
	left: 5px;
	border: 1px solid #FFF;
	transition: all 0.3s ease;
	opacity: 0;
	visibility: hidden;
	position: absolute;
	z-index: 999;
}
.home03List li a .image{
	position: relative;
}
.home03List li a .text{
	position: absolute;
	left: 18px;
	bottom: 16px;
	align-items: flex-end;
	z-index: 999;
}
.home03List li a .hov {
	position: absolute;
	width: 90%;
	top: 2em;
	left: 5%;
	font-size: 18px;
	line-height: 2.2;
}
.home03List li a .more span {
	font-size: 16px;
	line-height: 1.7;
}
.home03List li a .text span:nth-of-type(1){
	opacity: 0.5;
	margin-right: 20px;
	display: inline-block;
}
.home03List li a .text span:nth-of-type(2){
	padding-bottom: 12px;
}
.home03List li a:hover{
	opacity: 1;
}
.home03List li a:hover:after{
	opacity: 1;
	visibility: visible;
}
.home04Slider{
	margin-top: 15px;
	overflow: visible;
}
.home04Slider li{
	width: 472px;
}
.home05Box .image{
	width: 50%;
}
.home05Box .image img{
	float: right;
	max-width: none;
}
.home05Box .text{
	width: 43%;
}
.home05Slider ul li{
	width: 400px;
	height: 280px;
	position: relative;
}
.home05Slider ul li .overraycaption .caption{
	bottom: 100px;
}
.home05Slider ul li .text{
	background-color: rgba(96,21,18,0.4);
	color: #FFF;
	position: absolute;
	width: 100%;
	bottom: 0;
	left: 0;
	padding: 16px 16px 8px 16px;
}
.home05Slider ul li .text p{
	line-height: 32px;
	padding-left: 40px;
	background-size: 32px;
	background-repeat: no-repeat;
	background-position: left center;
	margin-top: 8px;
	font-size: 16px;
	line-height: 1.4;
}
.home05Slider ul li .text p.car{
	background-image: url("../images/home/icon_car.png");
}
.home05Slider ul li .text p.walk{
	background-image: url("../images/home/icon_walk.png");
}
.home06List{
	width: 1600px;
	margin-left: auto;
	margin-right: auto;
	max-width: calc(100% - 64px);
	overflow: visible;
}
.home06List li{
	width: 25%;
	transition: all 0.3s ease;
}
.home06List .text{
	padding: 24px;
	transition: all 0.3s ease;
}
.home06List .text p{
	line-height: 1;
	transition: all 0.3s ease;
}
.home06List .text h4{
	transition: all 0.3s ease;
	line-height: 1.5;
}
.home06List li:hover{
	transform: scale(1.14);
	z-index: 999;
}
.home06List li a:hover{
	opacity: 1;
}
.home06List li a:hover .text p,
.home06List li a:hover .text h4{
	color: #FFF;
}
.home06List li.business{
	background-color: #C6E6E7;
}
.home06List li.business a p{
	color: #47BCC0;
}
.home06List li.business:hover{
	background-color: #47BCC0;
}
.home06List li.couple{
	background-color: #F2DEE7;
}
.home06List li.couple a p{
	color: #E771A0;
}
.home06List li.couple:hover{
	background-color: #E771A0;
}
.home06List li.solo{
	background-color: #E7DBE7;
}
.home06List li.solo a p{
	color: #AC75AC;
}
.home06List li.solo:hover{
	background-color: #AC75AC;
}
.home06List li.family{
	background-color: #F3E2CF;
}
.home06List li.family a p{
	color: #F08D2C;
}
.home06List li.family:hover{
	background-color: #F08D2C;
}
#homeNews{
	width: 50%;
}
#homeSns{
	width: calc(50% - 40px);
	padding-left: 40px;
	border-left: 1px solid #AF8A89;
}
#homeSns h3{
	padding-left: 40px;
	background-size: 32px;
	background-repeat: no-repeat;
	background-position: left center;
	line-height: 32px;
}
#homeSns h3.instagram{
	background-image: url("../images/home/icon_instagram.png");
}
#homeSns h3.twitter{
	background-image: url("../images/home/icon_twitter.png");
}
.home08Banner li{
	width: calc((100% - 24px) / 2);
	margin: 12px 0;
}
#homeNews #tabMenu{
	border-bottom: 1px dotted #AF8A89;
}
#homeNews #tabMenu li a{
	display: block;
	padding: 8px 2px;
	background-color: #E7DCDC;
}
#homeNews #tabMenu li a.current{
	background-color: #AF8A89;
	color: #FFF;
}
.homeNewsList li a .image{
	width: 177px;
}
.homeNewsList li a .text{
	width: calc(100% - 200px);
}
.homeNewsList li + li{
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px dotted #AF8A89;
}
.homeNewsList li .meta{
	margin-top: 12px;
}
.homeNewsList li .meta time{
	line-height: 34px;
	margin-right: 16px;
}
.homeNewsList li .meta .category{
	line-height: 32px;
	display: inline-block;
	padding: 0 8px;
	background-color: #FFF;
	border: 1px solid #AF8A89;
}
#homeNews #tabBoxes > div{
	display: none;
}
#homeNews #tabBoxes > div.active{
	display: block;
}

/*------------------------------------------------
sp
--------------------------------------------------*/
@media screen and (max-width: 810px){
	.languageMenu{
		position: relative;
		top: auto;
		right: auto;
		border: none;
		width: 100%;
	}
	.languageMenu dt{
		background-color: #8E8E8E;
	}
	#mv, #topSlider,
	#topSlider .swiper-slide{
		height: auto;
	}
	#topSlider .swiper-slide img{
		width: 100%;
		height: 100%;
		object-fit: cover;
		object-position: center;
	}
	#topSlider .catchcopy{
		display: none;
	}
	#mv .snsList{
		display: none;
	}
	#mv .scroll{
		bottom: 20px;
		right: 20px;
	}
	#topSlider .swiper-pagination{
		right: 15px;
		bottom: 160px;
	}
	#homeBanner a{
		width: 100%;
		margin: 4px 0;
	}
	#home01{
		height: 150vw;
		margin-top: 6vw;
	}
	#home01:before{
		left: -180px;
		width: calc(100% + 180px);
	}
	#home01 .container1080{
		padding-right: 430px;
	}
	.home01_catch{
		font-size: 8.5vw;
		top: 105vw;
	}
	.home01_pic01{
		width: 96%;
		left: 2%;
		bottom: auto;
		top: 110vw;
	}
	#home02 h2:before{
		display: none;
	}
	#home02 h2{
		background: url("../images/home/home02_h2_bg_sp.png") no-repeat center center;
		background-size: contain;
		height: 40vw;
		padding-top: 11vw;
	}
	#home02 h2 span{
		padding: 0;
	}
	.appealingBox .container1080{
		padding-left: 0;
		padding-right: 0;
	}
	.appealingBox .text{
		width: 100%;
	}
	.appealingBox_title{
		margin: 0 !important;
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100%;
		height: 20vw;
		width: 100%;
	}
	.appealingBox_title div{
		display: none;
	}
	.appealingBox_title:after{
		display: none;
	}
	#home02 .appealingBox_title{
		background-image: url("../images/home/home02_h2_sp.png");
	}
	.home02Slider{
		padding-bottom: 80px;
	}
	.home02Slider .swiper-pagination{
		width: 100%;
		position: absolute;
		left: 0;
		bottom: 15px;
	}
	.home02Slider .swiper-button-next,
	.home02Slider .swiper-button-prev{
		top: 10vw;
		position: absolute;
	}
	#home03 .appealingBox_title{
		background-image: url("../images/home/home03_h2_sp.png");
	}
	#home04 .appealingBox_title{
		background-image: url("../images/home/home04_h2_sp.png");
		height: 30vw;
	}
	.appealingBox .image{
		width: 100%;
		height: auto;
	}
	.appealingBox .image img{
		width: 100%;
		max-width: 100%;
		float: none;
		margin: 20px 0;
	}
	.appealingBox h4,
	.appealingBox p{
		padding-left: 20px;
		padding-right: 20px;
	}
	.home02_h402 span:before,
	.home02_h402 span:after{
		display: none;
	}
	.home02_h402{
		width: calc(100% - 40px);
		padding: 20px 0 !important;
		border-top: 1px solid #AF8A89;
		border-bottom: 1px solid #AF8A89;
		margin-bottom: 20px;
		margin-left: auto;
		margin-right: auto;
		line-height: 1.5;
	}
	.home02Slider{
		background: url("../images/home/home02_bg.jpg");
	}
	.home02Slider .swiper-slide{
		width: auto;
	}
	.home02Slider .swiper-button-next,
	.home02Slider .swiper-button-prev{
		position: absolute;
		top: 22vw;
	}
	#home03 .lead h4{
		padding: 20px 0;
	}
	.home03List{
		width: 100%;
		padding: 0 20px;
		max-width: 100%;
		margin-top: 20px;
	}
	.home03List li{
		width: 100% !important;
		height: 34vw;
		margin: 8px 0;
		overflow: hidden;
	}
	.home03List li.wide{
		height: 42vw;
	}
	.home03List li a{
		display: block;
		height: 100%;
	}
	.home03List li .image{
		width: 100%;
		height: 100%;
	}
	.home03List li .image img{
		width: 100%;
		height: 100%;
		-o-object-fit: cover;
		object-fit: cover;
	}
	.home03List li a .text{
		height: 60px;
		width: 100%;
		bottom: 0;
		left: 0;
		padding-left: 10px;
		background-size: 50px;
		padding-bottom: 10px;
	}
	.home03List li a .text span{
		display: block;
		width: 100%;
	}
	.home03List li a .text span br{
		display: none;
	}
	.home03List li a .text span:nth-of-type(1){
		margin-top: -20px;
	}
	.home03List li a .text span:nth-of-type(2){
		padding-bottom: 0;
	}
	#home04 h3 + h4{
		margin-top: 20px;
	}
	.home04Slider{
		margin-top: 20px;
	}
	#home05{
		padding-bottom: 40px;
	}
	.home05Box .image,
	.home05Box .text{
		width: 100%;
	}
	.home05Box .image{
		margin-top: 20px;
	}
	.home05Box .image img{
		float: none;
		width: 100vw;
		margin-left: -20px;
	}
	.home06List{
		width: 100%;
		max-width: 100%;
		padding: 0 20px;
	}
	.home06List li{
		width: 100%;
	}
	.home06List li + li{
		margin-top: 12px;
	}
	.home06List li a{
		display: flex;
	}
	.home06List li a .image{
		width: 40%;
	}
	.home06List li a .image img{
		width: 100%;
		height: 100%;
		-o-object-fit: cover;
		object-fit: cover;
	}
	.home06List li a .text{
		width: 60%;
		padding: 8vw 0;
	}
	.home06List .text h4{
		margin-top: 10px;
	}
	#homeNews{
		width: 100%;
	}
	#homeNews #tabMenu li a{
		font-size: 2.5vw;
	}
	.homeNewsList li .meta time{
		font-size: 18px;
	}
	.homeNewsList li a .image{
		width: 110px;
	}
	.homeNewsList li a .image img{
		height: auto;
	}
	.homeNewsList li a .text{
		width: calc(100% - 130px);
	}
	.homeNewsList li .meta .category{
		font-size: 15px;
	}
	#homeSns{
		width: 100%;
		margin-top: 30px;
		padding-left: 0;
		border: none;
		padding-top: 30px;
		border-top: 1px solid #AF8A89;
	}
	.home08Banner li{
		width: 100%;
		margin: 8px 0;
	}
	.homeNewsList li:nth-of-type(n+4){
		display: none;
	}
}/*sp end*/


@media screen and (max-width: 480px){
	.home06List li a .text{
		padding: 10PX 0;
	}
	#home01{
		background: url("../images/home/home01_bg_sp.png") no-repeat center top;
		background-size: 100%;
		height: 347vw;
		padding-top: 5vw;
	}
	#home01:before{
		display: none;
	}
	#home01 .container1080{
		padding-right: 20px;
	}
	#home01 h2{
		letter-spacing: 0;
	}
	#home01 a.btn01{
		margin-top: 48vw;
	}
	.home01_catch,
	.home01_pic01{
		display: none;
	}
	.home01-desc {
		font-size: 4.6vw;
		margin-top: 2vw;
	}
}
	




/* ----- */
#home02 .appealingBox_title {
	flex-wrap: nowrap;
}
@media screen and (max-width: 810px){
	.home03List li.wide,
	.home03List li {
		height: auto;
	}
	.home03List li a {
		height: auto;
	}
	.home03List li .image {
		height: 34vw;
	}
	.home03List li.wide .image {
		height: 42vw;
	}
	.home03List li more {
		display: none;
	}
	.home03List li a + .sp {
		font-size: 18px;
		line-height: 1.8;
		margin-top: 0.8em;
		margin-bottom: 0.5em;
		font-family: "PingFang-SC", "Lucida Grande", Helvetica, Arial, "微軟正黑體修正", "微軟正黑體", sans-serif;
	}
}