@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300&family=Noto+Sans+JP:wght@100..900&display=swap');
#contents {  margin: 0 auto; }
video	{ width: 100%; max-width: 100%; line-height: 1; }
.lgzcontents	{ display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; padding: 0; margin: 0 0 4cqw; letter-spacing:.1em; font-style: normal; line-height:1.75; -webkit-text-size-adjust:100%; color:#323232; -webkit-font-smoothing: antialiased; container-type: inline-size; }
.lgzcontents *	{ letter-spacing:0; font-family: 'Noto Sans JP', sans-serif!important; font-weight: 500; font-style: normal; font-size:14px; line-height:1.75; font-feature-settings: "palt"; -webkit-text-size-adjust:100%; color:#212121; -webkit-font-smoothing: antialiased; }
.lgzcontents i	{ letter-spacing:.05em!important; font-weight: 700; }
.lgzcontents img, 
.lgzcontents picture	{ width: 100%; vertical-align: bottom; line-height: 1;  }
.lgzcontents ul:before,
.lgzcontents ol:before,
.lgzcontents dl:before, 
.lgzcontents ul:after, 
.lgzcontents ol:after, 
.lgzcontents dl:after	{ display: none!important; }
.lgzcontents img	{ width: 100%; vertical-align: bottom; line-height: 0; }
.lgzcontents a { transition: all .3s; color:#323232;}
.lgzcontents a:hover { color:#323232; text-decoration:none;}
.lgzcontents .small {font-size:80%;}
.lgzcontents .center-text	{ text-align: center; }

/* ------------ ANIMATION ------------- */
.scrollIn	{ opacity: 0; }
.scrollIn.active	{ transition: opacity 2.4s cubic-bezier(.24,.155,.275,.945); opacity: 1; transition-delay: .3s; }
@keyframes fadein	{ 
	from	{ opacity: 0; }
	to	{ opacity: 1; }
}
@keyframes blur	{ 
	from	{ opacity: 0; filter: blur(20px); }
	to	{ opacity: 1; filter: blur(0px); }
}

/* ------------ MAIN IMG ------------- */
.main_wrapper	{ width: 100%; position: relative; display: -webkit-flex; display: flex; padding: 0; margin: 0 0 2cqw; }
.main_wrapper picture,
.main_wrapper img	{ display: block; width: 100%; }
.main_wrapper .main_title	{ position: absolute; top: 50%; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 100%; left: 0; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1cqw; }
.main_title > h1	{ color:#fff; font-size: clamp(14px, 62px, 6vw); line-height: 1; font-weight: 700; letter-spacing:.03em; text-align: center; opacity: 0; transform: translateY(20px); transition: all 1s; }
.main_title > h2	{ color:#fff; font-size: clamp(13px, 58px, 5vw); line-height: 1.6; font-weight: 700; letter-spacing:.06em; text-align: center; opacity: 0; transform: translateY(20px); transition: all 1s; }
.main_title.active > h1	{ opacity: 1; transition-delay: .2s; transform: translateY(0); }
.main_title.active > h2	{ opacity: 1; transition-delay: .6s; transform: translateY(0); }
@media (min-width: 1000px) {
	.main_title > h1 br	{ display: none; }
}
@media (max-width: 999.9px) {
	.main_wrapper	{ margin: 0; }
	.main_title > h1	{ top: 4%; }
	.main_title > h1	{ font-size: 6vw; line-height: 1.4; }
	.main_title > h2	{ font-size: 5vw; }
}

/* ------------ MID AREA ------------- */
.midsetwrapper	{ width: 100%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; background-color: #fff; padding: 0; margin: 0 0 140px; }
.midsetheader	{ width: 100%; max-width: 1200px; display: -webkit-flex; display: flex; flex-direction: column; padding: 0; margin: 0 0 40px;  }
.midsetheader > h3	{ color:#2a2625; font-size: clamp(23px, 40px, 3.4vw); font-weight: 700; letter-spacing:.08em; line-height: 1; text-align: center; padding: 0 20px; margin: 0 0 30px; }
.midsetheader > strong	{ color:#2a2625; font-size: clamp(14px, 20px, 1.8vw); font-weight: 700; line-height: 1; text-align: center; padding: 0 30px; }
.midsetimages	{ width: 100%; max-width: 1400px; padding: 0; }
.item-slider .slick-slide	{ margin: 0 15px 0 0;  }
.matwap	{ display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; box-shadow: rgba(0, 0, 0, 0.16) 0px 4px 10px 0px; }
.material	{ width: 100%; overflow: hidden; padding: 0; margin: 0; list-style: none; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; }
.material li	{ width: 100%; height: 100%; }
.material li:first-child	{ z-index: 1; line-height: 0; position: relative; }
.material li:first-child::after	{ content:""; width: 100%; height: 40%; position: absolute; bottom: 0; left: 0; right: 0; background-image: linear-gradient(0deg, rgba(123, 79, 44, 1), rgba(150, 112, 74, 0.93) 20%, rgba(255, 255, 255, 0)); opacity: .4; }
.material li:nth-child(2)	{ z-index: 4; line-height: 0; position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 100%; background-color: rgba(255,255,255,1); transition:.5s cubic-bezier(.12,.51,.55,.94); transform: translateY(100%); }
.material li:nth-child(2)	{ padding: 20% 16%; display: -webkit-flex; display: flex; flex-direction: column; }
.material li:nth-child(2) > strong	{ color:#2a2625; font-size: clamp(18px, 24px, 1.5vw); font-weight: 700; line-height: 1.3; margin: 0 0 40px; }
.material li:nth-child(2) > p	{ color:#2a2625; font-size: clamp(12px, 16px, 1vw); line-height: 2; }
.material.active li:nth-child(2)	{ transform: translateY(0); }
.material li.mattle	{ z-index: 3; position: absolute; left: 0; bottom: 10px; right: 0; width: 100%; height: 66px; display: -webkit-flex; display: flex; align-items: center; z-index: 2; padding: 0 10px 0 60px;}
.material li.mattle > b	{ color:#fff; font-size: clamp(16px, 22px, 1.2vw); font-weight: 700; line-height: 1.3; white-space: nowrap; }
.material li.sptogglebtn	{ z-index: 6; position: absolute; left: 0; bottom: 0; right: 0; width: 100%; height: 62px;}
.material li.open_mark	{ z-index: 2; position: absolute; left: 15px; bottom: 25px; width: 32px; height: 32px; border-radius: 50%; background-color: rgba(0, 0, 0, 0.15); border: 2px solid #fff; opacity: 1; transition:.5s cubic-bezier(.12,.51,.55,.94); }
.material li.open_mark::before, 
.material li.open_mark::after	{ content: ""; display: block; width: 12px; height: 2px; background-color: #fff; position: absolute; inset: 0; margin: auto; transition:.5s cubic-bezier(.12,.51,.55,.94);  }
.material li.open_mark::after	{ -webkit-transform: rotate(90deg); transform: rotate(90deg); }
@media (min-width: 1000px) {
	.midsetimages	{ width: 100%; padding: 0 2%; }
	.material li	{ cursor: pointer; }
	.material li.sptogglebtn	{ display: none; }
	.item-slider	{ display: -webkit-flex; display: flex; gap: 1.2%; }
}
@media (max-width: 999.99px) {
	.midsetwrapper	{ margin: 0 0 60px; }
	.midsetheader > h3	{ margin: 0 0 20px; }
	.item-slider .slick-slide	{ margin: 12px 12px 12px 0;  }
	.material li:nth-child(2) > strong	{ font-size: 5.6vw; margin: 0 0 30px; }
	.material li:nth-child(2) > p	{ font-size: 3.8vw; }
	.material li.mattle	{ height: 46px; padding: 0 10px 0 45px;}
	.material li.mattle > b	{ font-size:max(2vw,18px); }
	.material li.open_mark	{ z-index: 5; left: 10px; bottom: 20px; width: 24px; height: 24px; border: 1px solid #fff; }
	.material li.open_mark::before, 
	.material li.open_mark::after	{ width: 8px; height: 1px; }
	.material.active li.open_mark	{ border: 1px solid #000; transform:rotate(225deg); background-color: rgba(0, 0, 0, 0); }
	.material.active li.open_mark::before, 
	.material.active li.open_mark::after	{ background-color: #000; }
}

/* ------------ SLIDER OPTION ------------- */
.slider-img	{ margin: 0 10px; }
.section-slider	{ position: relative; padding: 50px 0 65px 40px; }
.section-slider-inner-box li { margin-right: 25px; }
.section-slider .slick-list { padding-right: 10%; }
@media (max-width: 999.99px) {
	.section-slider { padding: 30px 0 45px 30px; }
	.section-slider-inner-box li { margin-right: 15px; }
	.section-slider .slick-list { padding-right: 20%; }
}

/* ------------ SUSTAINABILITY ------------- */
.sustainability_wrapper	{ width: 100%; background-color: #F5F4F0; display: -webkit-flex; display: flex; align-items: center; justify-content: center; flex-direction: column; padding: 140px 40px 100px; margin: 0 0 100px; }
.sustainability_inner	{ width: 100%; max-width: 1200px; display: -webkit-flex; display: flex; align-items: flex-start; gap: 0 5%; }
.sustainability_inner .txt	{ width: 60%; }
.sustainability_inner .txt > h4	{ color:#2a2625; font-size: clamp(23px, 40px, 3.4vw); font-weight: 700; letter-spacing:.08em; line-height: 1; margin: 0 0 30px; }
.sustainability_inner .txt > h5	{ color:#2a2625; font-size: clamp(16px, 20px, 1.8vw); font-weight: 700; line-height: 1; margin: 0 0 40px; }
.sustainability_inner .txt > p	{ color:#2a2625; font-size: clamp(13px, 15px, 1.1vw); font-weight: 500; line-height: 1.9; letter-spacing:.08em; margin: 0 0 5px; }
.sustainability_inner .txt > ul	{ list-style: none; display: -webkit-flex; display: flex; flex-direction: column; padding: 10px 0 0; margin: 0 0 20px; }
.sustainability_inner .txt > ul > li	{ color:#2a2625; font-size: clamp(12px, 15px, 1vw); font-weight: 500; letter-spacing:.08em; line-height: 1.8; margin: 0 0 10px; }
.sustainability_inner .txt > ul > li b	{ color:#696969; font-weight: 700; font-size: clamp(13px, 16px, 1.1vw); letter-spacing:.08em; }
.sustainability_inner .txt .links	{ display: -webkit-flex; display: flex; border-top: 1px solid #696969; padding: 30px 0 0; }
.sustainability_inner .txt .links a	{ display: -webkit-flex; display: flex; align-items: center; gap: 0 10px; font-size: clamp(12px, 15px, 1vw); font-weight: 700; line-height: 1; }
.sustainability_inner .txt .links img	{ width: 13px; line-height: 1; transition: all .5s; }
.sustainability_inner .txt .links a:hover	{ color:#2a2625; }
.sustainability_inner .txt .links a:hover img	{ transform: translateX(15px); }
.sustainability_inner .img	{ width: 40%; line-height: 1; }
@media (max-width: 999.99px) {
	.sustainability_wrapper	{ padding: 60px 30px; margin: 0 0 40px; }
	.sustainability_inner	{ flex-direction: column; }
	.sustainability_inner .txt	{ width: 100%; order: 2; }
	.sustainability_inner .txt > h4	{ margin: 0 0 30px; }
	.sustainability_inner .txt > h5	{ margin: 0 0 30px; }
	.sustainability_inner .img	{ width: 100%; order: 1; margin: 0 0 40px; display: none; }
	.sustainability_inner .txt > p	{ font-size: 13px; line-height: 1.8; margin: 0 0 10px; }
	.sustainability_inner .txt > ul > li	{ font-size: 13px; margin: 0 0 10px; }
	.sustainability_inner .txt > a	{ width: 100%; text-align: center; font-size: 11px; padding: 8px 0 10px; white-space: nowrap; }
}

/* ------------ ITEM AREA ------------- */
.itemsetwraporld	{ width: 100%; display: -webkit-flex; display: flex; flex-direction: column; position: relative; background-color: #fff; padding: 40px 0 0; }
.itemsetheader	{ width: 100%; height: 180px; background-color: #00FF00; display: -webkit-flex; display: flex; align-items: center; position: relative; opacity: 0; transform: translateY(10px); transition: all .9s; }
.itemsetheader.active	{ opacity: 1; transform: translateY(0px); }
.itemsetimages	{ width: 100%; padding: 0 2%; }
.itemsetwrapper	{ margin: 0; }
.itemsetwrapper.soon	{ margin: 0; pointer-events: none; }
.itemsetinnersplit	{ padding: 0 2%; }
.itemsetinner	{ display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; }
.itemsetinner h4	{ width: 100%; margin: 0 0 24px; padding: 0 2%; color:#2a2625; font-size: clamp(16px, 32px, 1.9vw); font-weight: 500; letter-spacing:.08em; line-height: 1.3; }
.itemset	{ width: 100%; overflow: hidden; padding: 0; margin: 0; list-style: none; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; }
.itemset li	{ width: 100%; }
.itemset li:first-child	{ width: 100%; line-height: 1; overflow: hidden; position: relative; }
.itemset li:first-child .itemimg	{ position: absolute; top: 0; bottom: 0; left: 0; right: 0; width: 100%; height: 100%; transition: all .3s; }
a:hover .itemset li:first-child .itemimg	{ transform: scale(1.05); transform-origin: center; }
.itemset li:nth-child(2)	{ padding: 8px; color:#2a2625; font-size: 15px; font-weight: 500; line-height: 1.7; letter-spacing:.08em; }
.itemset li:nth-child(2) > span	{ color:#888888; font-weight: 400; line-height: 1.2; }
.itemset li:nth-child(2) > span.current	{ color:#e50000; font-weight: 400; line-height: 1.2; }
.itemset li:nth-child(2) > span.yotei	{ color:#000; font-weight: 400; font-size: 13px; }
@media (max-width: 999.99px) {
	.itemsetimages	{ padding: 0; }
	.itemsetinner	{ margin: 0 0 30px; }
	.itemsetinner h4	{ margin: 0; padding: 0 35px; line-height: 1.5; }
	.itemset li:nth-child(2)	{ font-size: 13px; padding: 5px 0; }
	.itemset li:nth-child(2) > span	{ font-size: 12px; line-height: 1.2; }
	.itemset li:nth-child(2) > span.yotei	{ font-size: 12px; }
	.itemset li:nth-child(2) > span.current	{ font-size: 12px; }
}

.item-detailarea	{ width: 100%; display: -webkit-flex; display: flex; flex-wrap: wrap; gap: 20px 2%; flex-wrap: wrap; margin: 0; }
.item-detailarea > a	{ width: 32%; }
@media (min-width: 1000px) {
	.itemwaprep .itemsetwrapimg	{ order: 2; }
	.itemwaprep .itemsetinner	{ order: 1; }
	.itemsetinner	{ padding: 40px 0 0; }
	.itemsetinner h4 br.both	{ display: inline-block; }
	.itemsetinnersplit	{ width: 100%; display: -webkit-flex; display: flex; gap: 1.2%; align-items: flex-end; }
	.itemsetinnersplit .itemsetinner	{ width: 50%; }
	.itemsetinnersplit .item-detailarea	{ gap: 2.2%; flex-wrap: nowrap; }
	.itemsetinnersplit .item-detailarea > a	{ width: 50%; }
	.itemsetinnersplit .itemsetinner h4,
	.itemsetinnersplit .itemsetimages	{ padding: 0; }
}
@media (max-width: 999.99px) {
	.itemsetwraporld	{ padding: 0 4%; margin: 0 0 40px; }
	.itemsetwraporld h4	{ margin: 0 0 20px; }
	.itemsetwrapimg	{ width: 100%; margin: 0 0 30px; }
	.itemsetinner	{ width: 100%; margin: 0; }
	.itemsetinner h3	{ margin: 0 0 20px; }
	.itemsetinner h4	{ margin: 0 0 30px; }
	.itemsetinner h4 br	{ display: none; }
	.item-detailarea	{ padding: 0; margin: 0 0 40px; }
	.item-detailarea  .itemsetwrapper	{ margin: 0; }
	.item-detailarea > a	{ width: 49%; }
	.itemsetwraporld	{ margin: 0; }
}

/* ------------ ITEM COL2 ------------- */
.itemset2colwrapper	{ width: 100%; display: -webkit-flex; display: flex; align-items: flex-start; gap: 0; margin: 0; padding: 0 2%; position: relative; }
.item2colSticky	{ width: 100%; position: -webkit-sticky; position: sticky; top: 64px; right: 0; display: -webkit-flex; display: flex; align-items: center; justify-content: center; }
.item2coltxtwrapper	{ width: 100%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; flex-direction: column; padding: 0; }
.item2coltxtInner	{ width: 80%; max-width: 900px; display: -webkit-flex; display: flex; flex-direction: column; justify-content: center; gap: 1cqw; margin: 0 0 5cqw; }
.item2coltxtInner > strong	{ font-family: "Montserrat", sans-serif; font-weight: 300; font-style: normal; font-size: 4cqw; line-height: 1; margin: 0 0 1em; }
.item2coltxtInner > h3	{ color: #000; font-size: 1.7cqw; line-height: 1.8; font-weight: 700; letter-spacing: .08em; margin: 0; }
.item2coltxtInner > p	{ color: #000; font-size: 1cqw; line-height: 1.8; font-weight: 600; letter-spacing: .08em; margin: 0; opacity: 1; }
@media (min-width: 1000px) {
	.item2colSticky	{ width: 50%; }
	.item2coltxtwrapper	{ width: 50%; padding: 8cqw 0 8cqw 2cqw; }
	.reflect .item2colSticky	{ order: 2; }
	.reflect .item2coltxtwrapper	{ order: 1; padding: 8cqw 2cqw 8cqw 0; }
}
@media (max-width: 999.99px) {
	.itemset2colwrapper	{ flex-wrap: wrap; padding: 10px; }
	.item2coltxtwrapper	{ padding: 8% 0 0; }
	.item2coltxtInner	{ width: 100%; gap: 1.8cqw; margin: 0 0 8cqw; padding: 0 5%; }
	.item2coltxtInner > strong	{ font-size: 13cqw; line-height: 1.6; margin: 0 0 2cqw; }
	.item2coltxtInner > h3	{ font-size: 6.6cqw; line-height: 1.5; font-weight: 700; letter-spacing: .08em; margin: 0 0 2cqw; }
	.item2coltxtInner > p	{ font-size: 3.6cqw; line-height: 1.8; font-weight: 600; letter-spacing: .08em; margin: 0; opacity: 1; }
}

/* ------------ SLIDER OPTION ------------- */
.item2colSticky .slm-button-prev,
.item2colSticky .swiper-rtl .slm-button-next	{ left: var(--swiper-navigation-sides-offset,0px); right: auto }
.item2colSticky .slm-button-next,
.item2colSticky .swiper-rtl .slm-button-prev	{ right: var(--swiper-navigation-sides-offset,0px); left: auto }
.item2colSticky .slm-button-next,
.item2colSticky .slm-button-prev	{ z-index: 5; }
.item2colSticky .slm-button-prev, 
.item2colSticky .slm-button-next	{ color: #fff; background-color: rgba(0, 0, 0, 0); width: 60px; height: 60px; }
.item2colSticky .slm-button-prev::after, 
.item2colSticky .slm-button-next::after	{ font-size: 30px; font-weight: 300; }
@media (min-width: 1000px) {
	/* .item2colSticky .swiper	{ max-height: calc(100vh - 64px); } */
}
@media (max-width: 999.99px) {
	.item2colSticky .slm-button-prev, 
	.item2colSticky .slm-button-next	{ width: 30px; height: 80px; top: 45%; }
	.item2colSticky .slm-button-prev::after, 
	.item2colSticky .slm-button-next::after	{ font-size: 18px; }
}

.item2colSticky .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, 
.item2colSticky .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet	{ margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px); }
.item2colSticky .swiper-pagination-bullet { width: 12px; height: 12px; background-color: transparent; border: 1px solid #fff; opacity: 1; }
.item2colSticky .swiper-pagination-bullet-active { background-color: #fff; border: 1px solid #fff; }
@media (max-width: 999.99px) {
	.item2colSticky .swiper-pagination-bullet { width: 8px; height: 8px; }
	.item2colSticky .swiper-horizontal > .swiper-pagination-bullets, 
	.item2colSticky .swiper-pagination-bullets.swiper-pagination-horizontal, 
	.item2colSticky .swiper-pagination-custom, 
	.item2colSticky .swiper-pagination-fraction { bottom: 2px;}
}

/* ------------ BLOCK ------------- */
@media (max-width: 999.99px)	{ .pconly { display: none!important; } }
@media (min-width: 1000px)	{ .pconly { display: inline-block; } }
@media (max-width: 999.99px)	{ .sponly { display: inline-block; } }
@media (min-width: 1000px)	{ .sponly { display: none!important; } }

.no-transition * {
  transition: none !important;
}
