@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Lato&family=Noto+Sans+JP:wght@100..900&display=swap');
#contents { width: 100%!important; max-width: 100%!important; padding: 0; margin: 0; }
#pisss { width: 100%!important; max-width: 100%!important; }
#pi { width: 100%!important; max-width: 100%!important; margin: 0; background-color: transparent!important; padding: 0; }
#pi > img { display: none!important; }
#site_body { overflow-x: visible!important; }
body	{ background-color: #fff; }
picture	{ width: 100%; vertical-align: bottom; line-height: 1; }
.seach_sort_wrapper,
.search_contents,
.bread	{ background-color: #fff; }
.result_suggest { margin-bottom: 0; }
.product_list	{ background-color: transparent; }
.pi_description	{ padding: 0!important; background-color: transparent; }

.pi_lgzformat	{ display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; padding: 0; margin: 0; position: relative; font-feature-settings: "palt"; -webkit-text-size-adjust:100%; -webkit-font-smoothing: antialiased; background-color: transparent; }
.pi_lgzformat, 
.pi_lgzformat li, 
.pi_lgzformat a	{ font-family: "Lato", sans-serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; }
.pi_lgzformat *, 
.pi_lgzformat div, 
.pi_lgzformat div *	{ letter-spacing:-.02rem; }
.pi_lgzformat .en	{ font-family: "Lato", sans-serif; font-weight: 400; font-style: normal; }
.pi_lgzformat ul:before,
.pi_lgzformat ol:before,
.pi_lgzformat dl:before, 
.pi_lgzformat ul:after, 
.pi_lgzformat ol:after, 
.pi_lgzformat dl:after	{ display: none!important; }
.pi_lgzformat img	{ width: 100%; vertical-align: bottom; line-height: 0; }
.pi_lgzformat .small {font-size:80%;}
.pi_lgzformat .center-text	{ text-align: center; }
.pi_lgzformat > h3	{ font-size: 38px; font-weight: 700; line-height: 1; text-align: center; margin: 0 auto 70px; padding: 140px 0 0; letter-spacing:-.05rem;}
.pi_lgzformat_inner	{ width: 100%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; background-color: #e5e7eb; z-index: 2; }
/* ------------ FADEIN ------------- */
.fadein	{ opacity: 0; }
.fadein.scrollin	{ transition: opacity .92s cubic-bezier(.24,.155,.275,.945); opacity: 1; transition-delay: .3s; }
a.ancpoint1	{ display: inline-block; width: 100%; height: 0;  transform: translateY(-40px); }
a.ancpoint2	{ display: inline-block; width: 100%; height: 0;  transform: translateY(-107px); }
@media (max-width: 767.9px) {
	a.ancpoint1	{ transform: translateY(-40px); }
	a.ancpoint2	{ transform: translateY(-86px); }
}
.fadeinmain	{ width: 100%; padding: 0; margin: 0; animation-name: fadein; animation-duration: 1.5s; animation-iteration-count: 1; }
@keyframes fadein	{ 
	from	{ opacity: 0; transform: translateY(0); }
	to	{ opacity: 1; transform: translateY(0); }
}

/* ------------ MAIN AREA ------------- */
.mainarea	{ width: 100%; padding: 10px; background-color: #fff; }
@media (max-width: 767.9px) {
	.mainarea	{ padding: 0; }
}
/* ------------ INTRODUCTION ------------- */
.introduction-wrapper	{ width: 100%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; padding: 150px 9.75% 170px; margin: 0; background-color: #fff; }
.introduction	{ width: 100%; max-width: 100%; position: relative; }
.introduction-txt	{ position: absolute; top: 0; left: 0; width: 42%; }
.introduction-txt p	{ font-family: "Noto Sans JP", sans-serif!important; font-size: clamp(12px, 13px, 1vw); line-height: 2.38; letter-spacing:.1rem; text-align: justify; text-justify: inter-character; }
.introduction-img	{ list-style-type: none; padding: 30px 0 0 9.43%; display: -webkit-flex; display: flex; justify-content: space-between;}
.introduction-img li	{ width: 44.79%; }
.introduction-img li a	{ display: -webkit-flex; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; width: 100%; opacity: 1; transition: all .5s; }
.introduction-img li a:hover	{ text-decoration: none; }
.introduction-img li a *	{ line-height: 1; }
.introduction-img li a > img	{ width: 100%; }
.introduction-img li a > p	{ width: 100%; padding: 24px 0 0; vertical-align: middle; }
.introduction-img li a > p span	{ display: block; width: 100%; position: relative; padding: 0; color:#000; font-size: clamp(20px, 27px, 2vw); vertical-align: middle; }
.introduction-img li a > p span::before,
.introduction-img li a > p span::after	{ position: absolute; bottom: 3px; right: 0; margin: auto; content: ""; vertical-align: middle; }
.introduction-img li a > p span::before	{ bottom: 12px; right: -3px; width: 24px; height: 1px; background: #000; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.introduction-img li a > p span::after	{ width: 15px; height: 15px; border-right: 1px solid #000; border-bottom: 1px solid #000; }
@media (min-width: 768px) {
	.introduction-img li:first-child	{ order: 2; }
	.introduction-img li:last-child	{ order: 1; padding: 350px 0 0; }
	.introduction-img li a:hover, 
	.introduction-img li a:hover > p span	{ color:#000; text-decoration: none; opacity: .6; }
}
@media (max-width: 767.9px) {
	.introduction-wrapper	{ padding: 90px 25px 0; }
	.introduction-txt	{ position: static; width: 100%; margin: 0 0 70px; }
	.introduction-img	{ padding: 0; flex-direction: column; }
	.introduction-img li	{ width: 100%; padding: 0; }
	.introduction-img li:first-child	{ padding: 0 0 0 20%; margin: 0 0 60px; }
	.introduction-img li:last-child	{ padding: 0 20% 0 0; margin: 0 0 90px; }
	.introduction-img li a > p	{ padding: 12px 0 0; }
}
/* ------------ HEROS ------------- */
.middle-wrapper	{ width: 100%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; padding: 0 40px 90px; margin: 0; background-color: #fff; }
.middle-wrapper.mid	{ padding: 100px 40px 90px; }
.middle-inner	{ width: 100%; max-width: 100%; }
.wide-wrapper	{ width: 100%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; padding: 100px 0; margin: 0; }
.full-inner	{ width: 100%; aspect-ratio: 11 / 7; display: -webkit-flex; display: flex; align-items: center; justify-content: center; }
.fullimg01	{ width: 100%; aspect-ratio: 11 / 7; position: relative; }
.fullimg01::before	{ content:""; position: fixed;  top: 50px; left: 0; right: 0; bottom: 0; width: 100%; height: 100vh; background: url(PC_12_landscape.jpg) center bottom / cover no-repeat; z-index: -1; transition: all .5s; opacity: 0; }
.fullimg01.active::before	{ transition: opacity .92s cubic-bezier(.24,.155,.275,.945); opacity: 1; transition-delay: .3s; }
.fullimg02	{ width: 100%; aspect-ratio: 11 / 7; position: relative; }
.fullimg02::before	{ content:""; position: fixed;  top: 50px; left: 0; right: 0; bottom: 0; width: 100%; height: 100vh; background: url(PC_30_landscape_re.jpg) center center / cover no-repeat; z-index: -1; transition: all .5s; opacity: 0; }
.fullimg02.active::before	{ transition: opacity .92s cubic-bezier(.24,.155,.275,.945); opacity: 1; transition-delay: .3s; }
@media (max-width: 767.9px) {
	.middle-wrapper	{ padding: 0 12px 40px; margin: 0; background-color: #fff; }
	.middle-wrapper.mid	{ padding: 50px 12px 57px; }
	.full-inner	{ aspect-ratio: 45 / 64; }
	.fullimg01	{ aspect-ratio: 45 / 64; }
	.fullimg01::before	{ background: url(SP_12_landscape.jpg) center bottom / cover no-repeat; height: calc(100vh - 110px); }
	.fullimg02	{aspect-ratio: 45 / 64; }
	.fullimg02::before	{ background: url(SP_30_landscape_re.jpg) center center / cover no-repeat; height: calc(100vh - 110px); }
}
/* ------------ ITEMS ------------- */
.itemland-ww	{ width: 100%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0 40px; margin: 0; position: relative; }
.itemland-wrapper	{ width: 100%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 0 40px; margin: 0; position: relative; background-color: #fff; }
.itemland-header	{ width: 100%; max-width: 100%; height: 64px; padding: 10px 0 0; position: -webkit-sticky; position: sticky; top: 45px; left: 40px; right: 40px; background-color: #fff; z-index: 4; display: -webkit-flex; display: flex; justify-content: space-between; }
.itemland-header strong, 
.itemland-header ul	{ width: calc(50% - 10px); border-top: 1px solid #000; border-bottom: 1px solid #000; }
.itemland-header strong	{ display: -webkit-flex; display: flex; align-items: center; font-size: clamp(17px, 23px, 2vw); font-weight: 400; letter-spacing:0; line-height: 1; padding: 0; }
.itemland-header ul	{ display: -webkit-flex; display: flex; align-items: center; justify-content: flex-end; list-style-type: none; }
.itemland-header ul li	{ line-height: 1; }
.itemland-header ul li a:hover	{ text-decoration: none; }
.itemland-header ul li span	{ color:#000; font-size: 15px; line-height: 1; letter-spacing:.07rem; display: inline-block; position: relative; transition: all .5s; }
.itemland-header ul li span::after	{ content:""; position: absolute; bottom: 0; top: 100%; left: 0; right: 100%; width: 0; height: 1px; background-color: #000; opacity: 0; transition: all .5s; }
.itemland-header ul li:last-child	{ margin: 0 0 0 36px; }
.itemland-header ul li:last-child span	{ color:#C7C7C7; }
.itemland-header ul.active li span	{ color:#C7C7C7; }
.itemland-header ul.active li:last-child span	{ color:#000; }
@media (max-width: 767.9px) {
	.itemland-wrapper	{ padding: 0; }
	.itemland-header	{ height: 50px; top: 41px; left: 0; right: 0; padding: 10px 12px 0; }
	.itemland-header strong, 
	.itemland-header ul	{ width: calc(50% - 5px); }
	.itemland-header ul li span	{ font-size: 10px; }
	.itemland-header ul li:last-child	{ margin: 0 0 0 20px; }
}
.itemland-inner	{ width: 100%; max-width: 100%; position: relative; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.itemland	{ width: 100%; max-width: 100%; position: relative; display: -webkit-flex; display: flex; align-items: flex-start; justify-content: space-between; padding: 0 0 100px; margin: 0; }
.itemland.btmsps	{ margin: 0 0 80px; }
.itemland-img	{ width: calc(50% - 10px); padding: 27px 2.75% 0; position: -webkit-sticky; position: sticky; top: 109px; left: 0; right: 0; }
.itemland-items	{ width: calc(50% - 10px); padding: 27px 0 20% 3.33%; display: -webkit-flex; display: flex; flex-wrap: wrap; }
@media (max-width: 767.9px) {
	.itemland	{ flex-direction: column; padding: 0 12px; margin: 0 0 40px; }
	.itemland.btmsps	{ margin: 0 0 18px; }
	.itemland-img	{ width: 100%; padding: 22px 0 0; position: static; top: 0; }
	.itemland-items	{ width: 100%; padding: 27px 0 0; justify-content: space-between; }
}
.itemland-onecol	{ width: 100%; display: -webkit-flex; display: flex; justify-content: space-between; margin: 0 0 50px; }
.onecol-img	{ width: 52.72%; }
.onecol-txt	{ width: 47.28%; display: -webkit-flex; display: flex; flex-direction: column; justify-content: space-between; padding: 0 2% 0 4.54%; }
.onecol-txt p	{ font-size: clamp(10px, 13px, 1vw); line-height: 1.4; }
.onecol-txt p.antr	{ font-size: clamp(10px, 14px, 1vw); }
.onecol-txt p b	{ display: block; font-size: clamp(12px, 18px, 1.6vw); margin: 0 0 4px; }
.onecol-txt p strong, 
.onecol-txt p a	{ display: inline-block; line-height: 1; font-weight: 400; font-style: normal; text-decoration: none; padding: 30px 0 0; }
.onecol-txt p a:hover	{ text-decoration: none; }
.onecol-txt p strong span, 
.onecol-txt p a span	{ font-size: clamp(15px, 18px, 1.6vw); line-height: 1; font-weight: 400; font-style: normal; text-decoration: none; position: relative; transition: all .5s; }
.onecol-txt p strong span::after, 
.onecol-txt p a span::after	{ content:""; position: absolute; bottom: 0; top: 100%; left: 0; right: 0; width: 100%; height: 1px; background-color: #000; opacity: 1; transition: all .5s; }
.onecol-txt p strong span, 
.onecol-txt p strong span::after	{ opacity: .4; }
@media (min-width: 768px) {
	.itemland-header ul li a:hover span	{ color:#000; }
	.itemland-header ul li a:hover span::after	{ right: 0; width: 100%; opacity: 1; }
	.onecol-txt p a:hover span, 
	.onecol-txt p a:hover span::after	{ color:#000; opacity: .4; }
}
@media (max-width: 767px) {
	.itemland-onecol	{ width: calc(50% - 5px); margin: 0 0 28px; flex-direction: column; }
	.onecol-img	{ width: 100%; }
	.onecol-txt	{ width: 100%; padding: 10px 0 0; margin: 0; }
	.onecol-txt p.antr	{ margin: 0 0 14px; }
	.onecol-txt p strong, 
	.onecol-txt p a	{ display: block; width: 100%; text-align: right; padding: 5px 0 0; }
}
/* ------------ BOTTOM ------------- */
.bottom-wrapper	{ padding: 90px 40px 180px; width: 100%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; background-color: #fff; }
.bottom-inner	{ width: 100%; max-width: 960px; display: -webkit-flex; display: flex; }
.bottom-inner > p	{ width: 50%; line-height: 1; vertical-align: bottom; }
.bottom-inner > a	{ width: 50%; display: -webkit-flex; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 50px; background-color: #000; transition: all .5s;}
.bottom-inner > a:hover	{ text-decoration: none; }
.bottom-inner > a > b	{ color:#fff; font-size: clamp(29px, 30px, 2.8vw); line-height: 1; letter-spacing:.02rem; font-weight: 400; margin: 0 0 34px; }
.bottom-inner > a > span	{ font-family: "Noto Sans JP", sans-serif!important; color:#fff; font-size: clamp(12px, 14px, 1.2vw); line-height: 1.7; letter-spacing:.1rem; text-align: center; font-weight: 500; margin: 0 0 40px; }
.bottom-inner > a > i	{ width: 130px; height: 32px; display: -webkit-flex; display: flex; align-items: center; justify-content: center; border: 1px solid #fff; font-style: normal; }
.bottom-inner > a > i > span	{ color:#fff; font-size: clamp(13px, 15px, 1.8vw); line-height: 2; font-weight: 400; position: relative; }
.bottom-inner > a > i > span::after	{ content:""; position: absolute; top: 8px; right: -16px; width: 9px; height: 7px; background: url(ow.svg) center center / cover no-repeat; }
@media (min-width: 768px) {
	.bottom-inner > a:hover	{ background-color: #999; }
}
@media (max-width: 767px) {
	.bottom-wrapper	{ padding: 50px 12px 150px; }
	.bottom-inner	{ flex-direction: column; }
	.bottom-inner > p	{ width: 100%; }
	.bottom-inner > a	{ width: 100%; padding: 60px 20px 50px; }
	.bottom-inner > a > i > span	{ line-height: 2; }
	.bottom-inner > a > i > span::after	{ top: 6px; }
}
/* ------------ BLOCK ------------- */
@media (max-width: 767px)	{ .pconly { display: none!important; } }
@media (min-width: 768px)	{ .pconly { display: inline-block; } }
@media (max-width: 767px)	{ .sponly { display: inline-block; } }
@media (min-width: 768px)	{ .sponly { display: none!important; } }

