@charset "UTF-8";

#main-visual{
	position: fixed;
	left: 0;
	top: 0;
	z-index: 1;
	height: 100vh;
	min-height: 90rem;
	width: 100%;
	background-color: #000000;
}
.catch-copy{
	height: 100vh;
	min-height: 90rem;
	font-size: 4.5rem;
	writing-mode: vertical-rl;
	position: relative;
	z-index: 1;
	line-height: 1.75;
	align-items: center;
	justify-content: center;
}
.catch-copy-inner{
	position: relative;
}
.catch-copy p.en{
	position: absolute;
	right: -4rem;
	top: 0;
	font-weight: 500;
	font-size: 1.8rem;
	letter-spacing: .1em;
}
.catch-copy p.ja{
	letter-spacing: .175em;
	text-align: center;
	filter: drop-shadow(2px 4px 6px black);
}
.catch-copy p{
	text-shadow: 0 0 1rem #000;
}
.catch-copy-inner span {
    opacity: 0;
    display: inline-block;
    transform: translateY(10px);
    transition: all 0.4s ease;
}
.catch-copy-inner span.show {
    opacity: 1;
    transform: translateY(0);
}
/* +++filter+++ */
.blur_wrap{
	/*backdrop-filter: blur(1rem);
	background: linear-gradient(180deg, rgba(0, 84, 56, 0) 0%, #2f2f2f 80%, #222 100%);*/
}
/* +++News+++ */
main{
	position: relative;
}
#sec01{

	/*background-color: rgba(58,58,58,0.4);
	backdrop-filter: blur(1rem);*/
	width: 100%;
	padding-top: 22.4rem;
	padding-bottom: 40rem;
}
.content-inner{
	align-items: flex-start;
	padding-left: 5rem;
}
#sec01 .pager{
	margin-top: -6rem;
}
.pager{
	width: 15rem;
	margin-left: auto;
	margin-right: 5rem;
}
.news-button-next, .news-button-prev,
.product-button-next, .product-button-prev{
	position: relative;
	left: auto;
	right: auto;
	top: auto;
	bottom: auto;
	margin: 0;
	width: 6rem;
	height: 6rem;
	border: 1px solid #fff;
	border-radius: 50%;
}
.news-button-next:hover, .news-button-prev:hover,
.product-button-next:hover, .product-button-prev:hover{
	cursor: pointer;
}
.product-button-next, .product-button-prev{
	border-color: #818181;
}
.news-button-next:after, .news-button-prev:after,
.product-button-next:after, .product-button-prev:after{
	content: "";
	display: block;
	width: 2.2rem;
	height: 100%;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100% auto;
	text-indent: -99999px;
	overflow: hidden;
}
/*メインビジュアル*/
.mv-slide {
  height: 100vh; 
  position: relative;
  overflow: hidden;
}
.swiper-slide {
  height: 100%; 
}
.swiper-slide-item.pic {
  height: 100%;
  width: 100%;
}
.swiper-slide-item.pic img {
  height: 100%;
  width: 100%;
  object-fit: cover; 
  object-position: center; 
  display: block;
}
/**/
.news-button-next:after{
	background-image: url(../images/next-arrow01.svg);
}
.news-button-prev:after{
	background-image: url(../images/prev-arrow01.svg);
}
.product-button-next:after{
	background-image: url(../images/next-arrow02.svg);
}
.product-button-prev:after{
	background-image: url(../images/prev-arrow02.svg);
}
.news-list-outer{
	margin-top: 6rem;
	width: 100%;
	overflow: hidden;
}
.news{
	border: 1px solid #fff;
	/*padding: 3rem 5rem 3rem 3rem;*/
	background: url(../images/post-arrow01.svg) no-repeat;
	background-size: 3rem auto;
	background-position: right 2rem center;
	background-color: rgba(255,255,255,.1);
	margin-right: 4rem;
	transition: all .8s;
}
.news a{
	padding: 3rem 5rem 3rem 3rem;
	width: 100%;
	height: 100%;
	display: block;
}
.news:hover{
    backdrop-filter: blur(6rem);
	transition: all .8s;
}
.news .post-head{
	margin-bottom: 2rem;
	justify-content: flex-start;
	align-items: center;
}
.news .cat{
	letter-spacing: .1em;
	font-size: 2rem;
	font-weight: 500;
	margin-left: 3rem;
}
.news .post-title{
	font-size: 1.6rem;
    line-height: 2;
    font-weight: 400;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-text-overflow: ellipsis;
}
/* +++About+++ */
#sec02{
	/*background: #222;*/
}
#sec02:before{
	/*content: "";
	display: block;
	width: 100%;
	height: 1rem;
	position: absolute;
	left: 0;
	right: 0;
	top: -1rem;
	background: linear-gradient(180deg, rgba(34,34,34,0), rgba(34,34,34,1));*/
}
#sec02 .contents{
	margin-left: auto;
	margin-right: 0;
	position: relative;
	align-items: flex-start;
	transform: translateY(-20rem);
	margin-bottom: -10rem;
}
#sec02 .ja{
	margin-bottom: 6rem;
	width: 78%;
	padding-right: 18.2rem;
}
#sec02 .english{
	max-width: 77.272%;
	margin-bottom: 14rem;
	padding-right: 18.2rem;
}
#sec02 .catch02{
	writing-mode: vertical-rl;
	font-size: 4.6rem;
	line-height: 1.75;
	letter-spacing: .4em;
	position: absolute;
	left: 64%;
	top: 0;
	font-weight: 400;
}
#sec02 .catch02 span{
	letter-spacing: .25em;
}
#sec02 .catch02 .catch02.sp{
	padding-top: 0;
}
#sec02 .pic-area{
	width: 39.370%;
	position: relative;
	padding-bottom: 16rem;
}
#sec02 .pic02{
	margin-top: 6rem;
	width: 46%;
	margin-left: auto;
}
#sec02 .pic03{
	margin-top: 6rem;
	width: 46%;
	position: absolute;
	left: -18%;
	bottom: 6rem;
}
#sec02 .txt{
	width: calc(100% - 39.370%);
	position: relative;
	padding-left: min(10rem, 6.944444vw);
}
#sec02 .sec-ttl01{
	padding-top: 8.6rem;
	margin-left: max(-10rem,-6.944444vw);
	line-height: 1.8;
}
#sec02 .pic04{
	width: 45.074%;
}
#sec02 .pic05{
	width: 32.089%;
	transform: translateY(13.953%);
}
.text-slide-outer{
	/*background: #222;*/
	overflow: hidden;
	padding-bottom: 6rem;
	margin-top: -1px;
}
.text-slide{
	width: 214vw;
	display: flex;
	flex-wrap: wrap;
	padding-top: 5.6rem;
}
.text-slide .en{
	animation-name: text-slide;
	animation-duration: 40s;
	animation-delay: -20s;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-fill-mode: none;
	padding: 0 4em;
	width: 107vw;
}
.text-slide .en img{
	display: block;
	width: 100%;
}
.text-slide .en:nth-of-type(2){
	animation-name: text-slide02;
	animation-duration: 40s;
	animation-delay: 0s;
}
/* +++text-slide+++ */
@keyframes text-slide{
	0%{
		transform: translateX(100%);
	}
	100%{
		transform: translateX(-100%);
	}
}
@keyframes text-slide02{
	0%{
		transform: translateX(0);
	}
	100%{
		transform: translateX(-200%);
	}
}
/* +++#sec-pic+++ */
#sec-pic{
	position: relative;
}
#sec-pic .inner{
	margin-top: -30rem;
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	transform: translateY(-30rem);
	z-index: 1;
	display: flex;
	justify-content: flex-end;
}
.catch02{
	writing-mode: vertical-rl;
	font-size: 4.6rem;
	line-height: 1.75;
	letter-spacing: .4em;
	position: relative;
	margin-right: 0;
	margin-left: auto;
}
.catch02>.m-top{
	font-style: normal;
	display: block;
	padding-top: 4em;
	letter-spacing: .4em !important;
}
/* +++Product+++ */
#sec03{
	background: url(../images/index-product-bg01.jpg) no-repeat;
	background-size: cover;
	padding-top: 20rem;
	padding-bottom: 20rem;
	overflow: hidden;
}
#sec03 .contents{
	flex-direction: row-reverse;
}
#sec03 .pic-area{
	width: 51.118%;
}
#sec03 .txt{
	width: calc(100% - 51.118%);
	align-items: flex-end;
	padding-top: 20rem;
}
#sec03 .ja{
	max-width: 42rem;
	width: 100%;
	margin-bottom: 4rem;
}
#sec03 .english{
	max-width: 42rem;
	width: 100%;
	margin-bottom: 8rem;
}
#sec03 .pic02{
	position: absolute;
	right: -15.692%;
	bottom: -15rem;
	width: 55.384%;
}
.product-list-outer{
	overflow: hidden;
}
#sec03 h3{
	margin-top: 2.6rem;
	line-height: 1.6;
	font-weight: 400;
	font-size: 2rem;
}
#sec03 .pager{
	padding-bottom: 4.3rem;
	padding-top: 23rem;
	margin-right: 0;
}
/*スライダー*/
#sec03 .produc .pic{
	position: relative;
	width: 100%;
	aspect-ratio: 7 / 6; /* 比率を維持（420:360） */
	overflow: hidden;
}
/* ++++++++smartphone style+++++++++++ */
@media screen and (max-width: 768px){
	#luxy{
		padding-top: 5rem;
	}
	#main-visual{
		min-height: 60rem;
		height: 100svh;
	}
	.mv-slide,
	.mv-slide .pic{
		height: 100%;
	}
	.catch-copy{
		height: 100svh;
		min-height: auto;
		font-size: 2.8rem;
		padding-top: 0;
		z-index: 1;
	}
	.catch-copy p.en{
		right: -2.5rem;
		font-size: 1.2rem;
	}
	.catch-copy p.ja{
		line-height: 1.75;
	}
/* +++News+++ */
	#sec01{
		padding-top: 10rem;
		padding-bottom: 18rem;
	}
	.content-inner{
		align-items: flex-start;
		padding-left: 2rem;
		padding-right: 2rem;
	}
	#sec01 .pager{
		margin-top: -8rem;
	}
	.pager{
		width: 9rem;
		margin-right: 0;
	}
	.news-button-next, .news-button-prev,
	.product-button-next, .product-button-prev{
		width: 3.6rem;
		height: 3.6rem;
	}
	.news-button-next:after, .news-button-prev:after,
	.product-button-next:after, .product-button-prev:after{
		width: 36%;
	}
	.news-list-outer{
		margin-top: 6.5rem;
	}
	.news{
		background-size: 1.8rem auto;
		background-position: right 1.2rem center;
		margin-right: 0;
	}
	.news a{
		padding: 1.8rem 4rem 1.8rem 1.8rem;
	}
	.news .post-head{
		margin-bottom: 2rem;
		justify-content: flex-start;
		align-items: center;
	}
	.news .cat{
		letter-spacing: .1em;
		font-size: 1.8rem;
		font-weight: 500;
		margin-left: 1.5rem;
	}
	.news date{
		font-size: 1.2rem;
	}
/* +++About+++ */
	#sec02 .contents{
		width: 100%;
		margin-left: 0;
		display: block;
		transform: translateY(-7rem);
		margin-bottom: -1rem;
	}

	#sec02 .ja{
		margin-bottom: 6rem;
		width: 100%;
		padding-right: 12rem;
	}
	#sec02 .english{
		max-width: 100%;
		margin-bottom: 4rem;
		padding-right: 0;
	}
	#sec02 .catch02{
		/*font-size: 2.8rem;*/
		font-size: 2.6rem;
		left: auto;
		right: 0;
		margin-top: -8rem;
	}
	#sec02 .catch02 div{
		display: inline;
		padding-top: 0;
	}
	#sec02 .catch02 div.sp{
		display: block;
		padding-top: 5em;
	}
	#sec02 .pic-area{
		width: 100%;
		padding-bottom: 10rem;
		padding-top: 8rem;
	}
	#sec02 .pic01{
		width: 80%;
		margin-right: 2rem;
		margin-left: auto;
	}
	#sec02 .pic02{
		margin-top: 1rem;
		width: 50%;
		margin-left: auto;
		margin-right: -2rem;
	}
	#sec02 .pic03{
		margin-top: 6rem;
		width: 55%;
		position: absolute;
		left: -2rem;
		bottom: 0;
	}
	#sec02 .txt{
		width: 100%;
		padding-left: 0;
	}
	#sec02 .sec-ttl01{
		padding-top: 0;
		margin-left: 0;
	}
	#sec02 .pic-area02{
		padding: 0;
	}
	#sec02 .pic04{
		width: 61.8%;
		margin-left: -2rem;
		margin-top: 10%;
	}
	#sec02 .pic05{
		width: 46%;
		margin-right: -2rem;
		transform: translateY(13.953%);
	}
	.text-slide{
		width: 500vw;
		padding-top: 3.6rem;
	}
	.text-slide .en{
		width: 250vw;
	}
/* +++#sec-pic+++ */
	#sec-pic .inner{
		top: 43rem;
		margin-top: 0;
	}
	#sec-pic .pic{
		/*height: 100vw;*/
	}
	.catch02{
		/*font-size: 3rem;*/
		font-size: 2.6rem;
		line-height: 1.75;
		padding-right: 0rem;
	}
	#sec-pic .catch02{
		padding-right: 2rem;
	}
/* +++Product+++ */
	#sec03{
		padding-top: 18rem;
		padding-bottom: 10rem;
		background-size: cover;
	}
	#sec03 .contents{
		flex-direction: column;
	}
	#sec03 .pic-area{
		width: 100%;
		padding-top: 4rem;
	}
	#sec03 .txt{
		width: 100%;
		align-items: flex-start;
		padding-top: 4rem;
	}
	#sec03 .ja{
		max-width: 100%;
		width: 100%;
		margin-bottom: 3rem;
	}
	#sec03 .english{
		max-width: 100%;
		width: 100%;
		margin-bottom: 4rem;
	}
	#sec03 .pic01{
		width: 90%;
		margin-left: -2rem;
	}
	#sec03 .pic02{
		right: -2rem;
		bottom: -10rem;
		width: 61.8%;
	}
	#sec03 h3{
		margin-top: 1.8rem;
		font-size: 1.6rem;
	}
	#sec03 .pager{
		padding-bottom: 4.5rem;
		padding-top: 16rem;
	}
}