@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;400&family=Noto+Serif+JP:wght@200;400;700&family=Roboto+Condensed:wght@400;700&display=swap');

* { min-height:0; min-width:0; box-sizing: border-box; }
*:focus	{ outline: none; }
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure, footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video {
  font-size: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  background: transparent;
}
body	{ color: #000; background-color: #fff; font-family: 'Noto Serif JP', serif; font-weight: 400; font-feature-settings: "palt"; -webkit-font-feature-settings: "palt"; letter-spacing:.1rem; height:100%; position: relative; }
img	{ display:inline-block; height: auto; width: 100%; max-width: 100%; backface-visibility: hidden; }
a, a:link, a:visited, a:active	{ color: #2C2C2C; text-decoration: none; }
a:hover	{ color: #000; font-style: normal; text-decoration: none; }
#pagetop	{ position: absolute; top: 0; left: 0;  }
@media (min-width: 768px) { 
	a .news_aLine	{ border-top: 1px solid transparent; border-bottom: 1px solid transparent; background: linear-gradient(#1e4098, #1e4098) 100% 100% / 0 1px no-repeat; transition: background-size .4s cubic-bezier(.23,1,.32,1) 0s; }
	.toppage a:hover .news_aLine	{ border-top: 1px solid transparent; border-bottom: 1px solid transparent; background: linear-gradient(#fff, #fff) 100% 100% / 0 1px no-repeat; transition: background-size .4s cubic-bezier(.23,1,.32,1) 0s; }
	a:hover .news_aLine, 
	.toppage a:hover .news_aLine	{ background-position: 0 100%; background-size: 100% 1px; }
}

/* ------------ INVIEW ------------- */
.fadein	{ opacity: 0; }
.fadein.inview	{ animation-name: fadeUp; animation-duration:1.5s; animation-fill-mode:forwards; }
.slidein	{ opacity: 0; }
.slidein.inview	{ animation-name: slidefade; animation-duration:1.5s; animation-fill-mode:forwards; }
@keyframes fadeUp	{
  from { opacity: 0; transform: translateY(30px); }
  to	{ opacity: 1; transform: translateY(0); }
}
@keyframes slidefade	{
  from { opacity: 0; transform: translateX(100px); }
  to	{ opacity: 1; transform: translateX(0); }
}
.marker	{ padding: 0 5px; background-image: linear-gradient(rgba(0,0,0,1), rgba(0,0,0,1)); background-size: 0 50%; background-position: 0 100%; background-repeat: no-repeat; transition: 1s; transition-delay: 0.2s; animation-delay: 0.2s; }
.marker.active	{ background-size: 100% 50%; }
.fadeUp	{ animation-name:fadeUpAnime; animation-duration:1.5s; animation-fill-mode:forwards; opacity: 0; }
@keyframes fadeUpAnime{
  from	{ opacity: 0; transform: translateY(100px); }
  to	{ opacity: 1; transform: translateY(0); }
}
.box	{ opacity: 0; }
.parallax-window	{ background: transparent; position: relative; }

/* ------------ HEADER ------------- */
header	{ display: -webkit-flex; display: flex; width: 100%; height: 400px; justify-content: space-between; position: fixed; top:0; left:0; z-index:18; padding: 20px 10%; margin: 0; transition: all .5s; background-color: rgba(0,0,0,0); }
header.second,
header.mini	{ height: 120px; background-color: rgba(0,0,0,0); padding: 20px 5%; }
header > h1	{ display: -webkit-flex; display: flex; align-items: center; padding: 0; margin: 0; z-index:22; }
header > h1 > a	{ width: 100%; line-height: 1; transition: all 0s; }
header > h1 > a > img	{ max-width: 280px; width: 100%; height: auto; opacity: 1; transition: all .5s; }
header.second > h1 > a > img, 
header.mini > h1 > a > img	{ width: 100px; }
@media (max-width: 767.9px) { 
	header	{ height: 200px; }
	header > h1 > a > img	{ width: 80%; max-width: 180px; }
	header.second,
	header.mini	{ height: 70px; }
	header.second > h1 > a > img, 
	header.mini > h1 > a > img	{ width: 60px; }
}

/* ------------ TOP MAIN ------------- */
.topmain	{ position: relative; width: 100%; height: 100vh; margin: 0; min-height: 680px; display: -webkit-flex; display: flex; align-items: center; justify-content: center; position: relative; pointer-events: none; }
.topmain__wrapper	{ width: 100%; height: 100%; display: -webkit-flex; display: flex; flex-direction: column; justify-content: flex-end; align-items: flex-end; padding: 6% 10%; margin: 0; position: relative; overflow: hidden; }
.topmain__wrapper > b	{ width: 90px; padding: 0; margin: 0 0 30px; }
.topmain__wrapper > p span	{ color:#fff; font-size: clamp(13px, 16px, 1.3vw); font-weight: 400; line-height: 1.3; padding: 0; text-align: center; position: relative; z-index: 2; }
.topmain__wrapper > h2	{ display: -webkit-flex; display: flex; position: relative; margin: 0 0 20px; padding: 0; }
.topmain__wrapper > h2::after	{ content:""; position: absolute; bottom: -5px; left: 100%; right: 0; width: 0; height: 50%; background-color: rgba(0,0,0,1); transition: all 1.5s; transition-delay: 0.6s; animation-delay: 0.6s; }
.topmain__wrapper > h2 span	{ color:#fff; font-size: clamp(22px, 48px, 3.5vw); font-weight: 400; line-height: 1.3; padding: 0; text-align: center; position: relative; z-index: 2; }
.topmain__wrapper > strong	{ display: -webkit-flex; display: flex; position: relative; margin: 0; padding: 0; }
.topmain__wrapper > strong::after	{ content:""; position: absolute; bottom: -5px; left: 100%; right: 0; width: 0; height: 50%; background-color: rgba(0,0,0,1); transition: all 1.5s; transition-delay: 0.6s; animation-delay: 0.6s; }
.topmain__wrapper > strong span	{ color:#fff; font-size: clamp(14px, 24px, 1.8vw); font-weight: 400; line-height: 1.6; padding: 0; text-align: center; position: relative; z-index: 2; }
.topmain__wrapper > h2.inview::after	{ left: 0; width: 100%; }
.topmain__wrapper > strong.inview::after	{ left: 0; width: 100%; }
@media (max-width: 767.9px) { 
	.topmain	{ min-height: 300px; }
	.topmain__wrapper	{ width: 100%; margin: 0; padding: 40px 20px; }
	.topmain__wrapper > b	{ width: 60px; padding: 0; margin: 0 0 20px; }
	.topmain__wrapper > h2	{ margin: 0 0 10px; }
	.topmain__wrapper > h2::after	{ bottom: -2px; }
	.topmain__wrapper > strong::after	{ bottom: -2px; }
	.topmain__wrapper > p::after	{ bottom: -2px; }
}
@media (max-width: 370px) { 
	.topmain__wrapper > h2 span	{ font-size: 20px; margin: 0 0 10px; }
	.topmain__wrapper > strong span	{ font-size: 12px; }
}

/* ------------ TOP SLIDER ------------- */
.topSlider	{ width: 100%; height: 100vh; position: fixed; top: 0; right: 0; bottom: 0; left: 0; transition: all 2s; z-index:-101; }
.topSlider::after	{ position: absolute; top: 0; right: 0; bottom: 0; left: 0; content:""; background-color: rgba(30,54,152,.3); transition: all 2s; mix-blend-mode: multiply; }
.topSlider.scrolldown::after	{ background-color: rgba(0,0,0,.7); transition: all 2s; }
.topSlider .slick-slider .slick-track,
.topSlider .slick-slider .slick-list	{ height: 100%; }
.tpslider	{ width: 100%; height: 100%; padding: 0; margin: 0; }
.tpslider .main01,
.tpslider .main02,
.tpslider .main03,
.tpslider .main04,
.tpslider .main05,
.tpslider .main06,
.tpslider .main07	{ width: 100%; height: 100%; padding: 0; margin: 0; }
.tpslider .main01	{ background: url(../images/main01.jpg) center center no-repeat; background-size: cover; }
.tpslider .main02	{ background: url(../images/main02.jpg) center center no-repeat; background-size: cover; }
.tpslider .main03	{ background: url(../images/main03.jpg) center center no-repeat; background-size: cover; }
.tpslider .main04	{ background: url(../images/main04.jpg) center center no-repeat; background-size: cover; }
.tpslider .main05	{ background: url(../images/main05.jpg) center center no-repeat; background-size: cover; }
.tpslider .slick-active .main01,
.tpslider .slick-active .main02	{ transform: scale(1.0); }
.slide-animation	{ animation: fadezoom 8s 0s forwards; }
@keyframes fadezoom { 0% { transform: scale(1); } 100% { transform: scale(1.1); }}
/* @media (max-width: 767.9px) { 
	.tpslider .main01	{ background: url(../images/main01s.jpg) center center no-repeat; background-size: cover; }
	.tpslider .main02	{ background: url(../images/main02s.jpg) center center no-repeat; background-size: cover; }
	.tpslider .main03	{ background: url(../images/main03s.jpg) center center no-repeat; background-size: cover; }
	.tpslider .main04	{ background: url(../images/main04s.jpg) center center no-repeat; background-size: cover; }
	.tpslider .main05	{ background: url(../images/main05s.jpg) center center no-repeat; background-size: cover; }
} */

/* ------------ LEAD ------------- */
.lead_area	{ width: 100%; min-height: 100vh; display: -webkit-flex; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; padding: 120px 15% 240px; }
.lead_wrapper	{ width: 100%; max-height: 1200px; }
.lead_wrapper > h3	{ margin: 0 0 30px; position: relative; z-index: 2; }
.lead_wrapper > h3 span	{ color:#fff; font-size: clamp(14px, 38px, 2.5vw); font-weight: 400; line-height: 1.3;  }
.lead_wrapper > h3 span b	{ font-size: clamp(18px, 62px, 3.5vw); font-weight: 400; }
.lead_wrapper > p	{ margin: 0 0 10px; color:#fff; font-size: clamp(13px, 16px, 1.1vw); font-weight: 400; line-height: 2;  }
@media (max-width: 767.9px) { 
	.lead_area	{ padding: 80px 40px 160px; }
	.lead_wrapper > h3	{ margin: 0 0 20px; }
	.lead_wrapper > p br	{ display: none; }
}

/* ------------ ABOUT ------------- */
.about_area	{ width: 100%; min-height: 100vh; display: -webkit-flex; display: flex; padding: 0; margin: 0; }
.about_img	{ width: 50%;}
.about_txt	{ width: 50%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; padding: 40px 8% 40px 5%; position: relative; background-color: #fff; }
.about_txt::after	{ content:""; position: absolute; right: 0; bottom: 0; width: 60%; height: 0; padding: 0 0 100%; background: url(../images/tree.png) right bottom / contain no-repeat; z-index: 1; opacity: .4;}
.about_txt_inner	{ padding: 0 0 100px; width: 100%; max-width: 1000px; position: relative; z-index: 2; }
.about_txt_inner > h3	{ margin: 0 0 30px; position: relative; z-index: 2; }
.about_txt_inner > h3 span	{ color:#000; font-size: clamp(14px, 38px, 2.5vw); font-weight: 400; line-height: 1.3;  }
.about_txt_inner > h3 span b	{ font-size: clamp(18px, 62px, 3.5vw); font-weight: 400; }
.about_txt_inner > h3 span.marker	{ background-image: linear-gradient(rgba(0,0,0,.2), rgba(0,0,0,.2)); }
.about_txt_inner > p	{ margin: 0 0 10px; color:#000; font-size: clamp(13px, 16px, 1.2vw); font-weight: 400; line-height: 2;  }
@media (max-width: 920px) { 
	.about_area	{ min-height: auto; flex-wrap: wrap; }
	.about_img	{ width: 100%; min-height: 300px; order:2; }
	.about_txt	{ width: 100%; padding: 80px 20px 40px; position: relative; order:1; }
	.about_txt::after	{  max-width: 320px; }
}

/* ------------ MAIN ------------- */
.main_area	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center; flex-wrap: wrap; padding: 120px 40px 240px; }
.main_area > h2	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center; }
.main_area > h2 span	{ color:#fff; font-size: clamp(22px, 56px, 4vw); font-weight: 400; line-height: 1.3; }
.main_area > strong	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center;  }
.main_area > strong span	{ color:#fff; font-size: clamp(11px, 16px, 1.2vw); font-weight: 400; line-height: 1.6; padding: 0; }
.sphere_series_wrapper	{ display: -webkit-flex; display: flex; flex-wrap: wrap; list-style-type: none; justify-content: center; width: 100%; max-width: 1200px; padding: 80px 0 0; }
.sphere_series_wrapper > li	{ width: calc(100% / 3 - 40px); margin: 0 20px; display: -webkit-flex; display: flex; align-items: center; justify-content: center; }
.sphere_series_wrapper > li > button, 
.sphere_series_wrapper > li > p	{ outline: none; border: none; border: 0; border-radius: 50%; width: 100%; height: 0; padding: 0 0 100%; margin: 0 0 80px; position: relative; background-color: #fff; transition: all .5s; z-index: 1; border: 1px solid #fff; }
.sphere_series_wrapper > li > button, 
.sphere_series_wrapper > li > p	{ 
	-webkit-filter:drop-shadow(0 0 10px rgba(255, 255, 255, 0.5));
	-moz-filter:drop-shadow(0 0 10px rgba(255, 255, 255, 0.5));
	-ms-filter:drop-shadow(0 0 10px rgba(255, 255, 255, 0.5));
	filter:drop-shadow(0 0 10px rgba(255, 255, 255, 0.5));
}
.sphere_series_wrapper > li > p::before	{ content:""; border-radius: 50%; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background-color: rgba(0,0,0,.5); z-index: 2;  }
.sphere_series_wrapper > li > button span, 
.sphere_series_wrapper > li > p span	{ color:#fff; font-size: clamp(14px, 22px, 1.5vw); font-weight: 400; position: absolute; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); bottom: -40px; white-space: nowrap; }
.sphere_series_wrapper > li > p i	{ color:#fff; font-size: clamp(11px, 16px, 1.1vw); font-weight: 400; font-style: normal; position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); white-space: nowrap; z-index: 3; }
.series01	{ background: url(../images/main01.jpg) center center / cover no-repeat; }
.series02	{ background: url(../images/sphere04.jpg) center center / cover no-repeat; }
.series03	{ background: url(../images/sphere03.jpg) center center / cover no-repeat; }
.series04	{ background: url(../images/sphere01.jpg) center center / cover no-repeat; }
.series05	{ background: url(../images/sphere02.jpg) center center / cover no-repeat; }
.series06	{ background: url(../images/sphere06.jpg) center center / cover no-repeat; }
.series07	{ background: url(../images/sphere07.jpg) center center / cover no-repeat; }
.series08	{ background: url(../images/sphere08.jpg) center center / cover no-repeat; }
.series09	{ background: url(../images/sphere09.jpg) center center / cover no-repeat; }
.series10	{ background: url(../images/sphere10.jpg) center center / cover no-repeat; }
.series11	{ background: url(../images/sphere11.jpg) center center / cover no-repeat; }
@media (min-width: 768px) { 
	.sphere_series_wrapper > li > button:hover	{ cursor: pointer; transform: translateY(-15px); border: 1px solid #fffc0c; box-shadow:0px 0px 20px 10px #fff inset;
	-webkit-filter:drop-shadow(0 0 20px rgba(255, 255, 255, 1));
	-moz-filter:drop-shadow(0 0 20px rgba(255, 255, 255, 1));
	-ms-filter:drop-shadow(0 0 20px rgba(255, 255, 255, 1));
	filter:drop-shadow(0 0 20px rgba(255, 255, 255, 1));
	}
}
@media (max-width: 767.9px) { 
	.main_area	{ padding: 100px 30px 180px; }
	.sphere_series_wrapper	{ padding: 30px 0 0; }
	.sphere_series_wrapper > li	{ width: 80%; margin: 0; }
	.sphere_series_wrapper > li > button, 
	.sphere_series_wrapper > li > p	{ margin: 0 0 60px; }
	.sphere_series_wrapper > li > button span, 
	.sphere_series_wrapper > li > p span	{ bottom: -30px; }
}

/* ------------ MODAL CUSTOM ------------- */
.modal-dialog	{ max-width: 600px; }
.modal-footer	{ justify-content: center; }
@media (max-width: 599px) { 
	.modal-dialog	{ max-width: 100%; }
}

/* ------------ MIXCOAT ------------- */
.mixcoat_area	{ width: 100%; display: -webkit-flex; display: flex; padding: 0; margin: 0; background-color: #fff; position: relative; z-index: 20; }
.mixcoat_img	{ width: 50%; background: url(../images/miximg.jpg) center center / cover no-repeat; }
.mixcoat_txt	{ width: 50%; display: -webkit-flex; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; padding: 100px 40px 100px 10%; position: relative; }
.mixcoat_txt_inner	{ padding: 0; width: 100%; max-width: 1000px; position: relative; z-index: 2; }
.mixcoat_txt_inner > h3	{ margin: 0 0 30px; position: relative; z-index: 2; }
.mixcoat_txt_inner > h3 span	{ color:#000; font-size: clamp(14px, 20px, 1.5vw); font-weight: 400; line-height: 1.3;  }
.mixcoat_txt_inner > h3 span b	{ font-size: clamp(20px, 32px, 2.5vw); font-weight: 400; }
.mixcoat_txt_inner > h3 span.marker	{ background-image: linear-gradient(rgba(0,0,0,.2), rgba(0,0,0,.2)); }
.mixcoat_txt_inner > p	{ margin: 0 0 10px; color:#000; font-size: clamp(13px, 16px, 1vw); font-weight: 400; line-height: 2;  }
.mixcoat_txt_inner > ul	{ padding: 20px 0 0; margin: 0 0 0 1em; }
.mixcoat_txt_inner > ul li	{ font-family:'Roboto Condensed', 'Noto Sans JP', Arial, sans-serif; letter-spacing:.08rem; font-size: clamp(13px, 16px, 1vw); font-weight: 400; }
@media (max-width: 920px) { 
	.mixcoat_area	{ min-height: auto; flex-wrap: wrap; }
	.mixcoat_img	{ width: 100%; min-height: 300px; order:2; }
	.mixcoat_txt	{ width: 100%; padding: 80px 20px 40px; position: relative; order:1; }
	.mixcoat_txt_inner > ul	{ padding: 10px 0 0; }
}

/* ------------ DRAWR MENU ------------- */
nav.sp	{ display: block; width: 400px; height: 100%; min-height: 100vh; background: rgba(255,255,255,1); margin: 0; padding: 0; position: fixed; top: 0; right: 0; left: auto; bottom: 0; z-index: 90; transform: translate(100vw); transition: all .5s; overflow: auto; }
nav.sp.open	{ transform: translateZ(0); }
.menuinner	{ display: block; padding: 0; margin: 0; width: 100%; height: 100%; display: -webkit-flex; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.menuinner > h2	{ padding: 0; margin: 0 0 10px; max-width: 220px; }
.menuinner > h2 a	{ display: block; }
.menuinner > ul.nav	{ width: 100%; max-width: 300px; display: -webkit-flex; display: flex; align-items: flex-start; justify-content: center; flex-direction: column; padding: 0; margin: 0 0 30px; border-bottom: 1px solid #ccc; }
.menuinner > ul.nav > li	{ width: 100%; list-style: none; padding: 0; margin: 0; position: relative; border-top: 1px solid #ccc; }
.menuinner > ul.nav > li > a	{ display: block; color:#1e4098; font-size: 15px; line-height: 1.5; font-weight: 700; letter-spacing:.05rem; padding: 10px 0; margin: 0; transition: all .5s; }
.menuinner > ul.subnav	{ width: 100%; max-width: 300px; display: -webkit-flex; display: flex; align-items: flex-start; justify-content: center; flex-direction: column; padding: 15px 0 0; margin: 0; border-top: 1px solid #666; }
.menuinner > ul.subnav > li	{ width: 100%; list-style: none; padding: 0; margin: 0; position: relative; }
.menuinner > ul.subnav > li > a	{ display: block; color:#1e4098; font-size: 14px; line-height: 1.5; font-weight: 700; letter-spacing:.05rem; padding: 0 0 10px; margin: 0; transition: all .5s; }
.menuinner > p	{ width: 100%; text-align: center; color:#666; font-size: 11px; line-height: 1.4; font-family:'Roboto Condensed', 'Noto Sans JP', Arial, sans-serif; letter-spacing:.08rem; padding: 40px 0 0; margin: 0; }
@media (min-width: 768px) { 
	.menuinner > ul.nav > li > a:hover, 
	.menuinner > ul.subnav > li > a:hover	{ color:#f9891a; }
}
@media (max-width: 767.9px) { 
	nav.sp	{ width: 100%; height: calc(var(--vh, 1vh) * 100); }
	.menuinner > ul.nav	{ max-width: 280px; width: 90%; }
	.menuinner > ul.subnav	{ max-width: 280px; width: 90%; }
	.menuinner > ul.subnav > li > a	{ font-size: 14px; }
}
@media (max-width: 374px) { 
	.menuinner > ul.nav > li > a	{ font-size: 14px; padding: 7px 0; }
	.menuinner > ul.subnav > li > a	{ font-size: 12px; }
	.menuinner > p	{ font-size: 9px; padding: 10px 0 0; }
}

.drwrapper	{ height: 100%; overflow-x: hidden; position: relative; }
.overlay	{ content: ""; display: block; width: 0; height: 0; position: absolute; top: 0; left: 0; z-index: 20; opacity: 0; transition: opacity .5s; background-color: rgba(0,0,0,.8); }
.overlay.open	{ width: 100%; height: 100%; opacity: 1; position: fixed; }
.menu-trigger	{ display: inline-block; width: 60px; height: 60px; vertical-align: middle; cursor: pointer; position: fixed; top: 0; left: auto; right: 0; z-index: 300; pointer-events: auto; transition: all .5s; }
.menu-trigger::before	{ content:""; width: 60px; height: 60px; position: fixed; top: 0; left: auto; right: 0; z-index: 299; background: rgba(0,0,0,.3); mix-blend-mode:multiply; }
.menu-trigger:hover	{ background: rgba(0,0,0,.8); }
.menu-trigger::before:hover	{  }
.menu-trigger span	{ display: inline-block; box-sizing: border-box; position: absolute; top: 20px; left: 20px; width: 20px; height: 3px; background-color: #fff; transition: all .5s; transform: translateX(0); transition: all .5s; z-index: 301; }
.menu-trigger.active	{ transition: all .5s; }
.menu-trigger.active span	{ background-color: #fff; }
.menu-trigger span:nth-of-type(1)	{ top: 18px; }
.menu-trigger.active span:nth-of-type(1)	{ transform: translateY(8px) rotate(-45deg); }
.menu-trigger span:nth-of-type(2)	{ top: 26px; }
.menu-trigger.active span:nth-of-type(2)	{ opacity: 0; }
.menu-trigger span:nth-of-type(3)	{ top: 34px; }
.menu-trigger.active span:nth-of-type(3)	{ transform: translateY(-8px) rotate(45deg); }
@media (max-width: 767.9px) { 
	.menu-trigger	{ width: 60px; height: 60px; }
	.menu-trigger span	{ top: 20px; left: 20px; width: 20px; }
	.menu-trigger.active	{ transition: all .5s; }
	.menu-trigger.active span	{ background-color: #fff; }
	.menu-trigger span:nth-of-type(1)	{ top: 20px; }
	.menu-trigger.active span:nth-of-type(1)	{ transform: translateY(8px) rotate(-45deg); }
	.menu-trigger span:nth-of-type(2)	{ top: 28px; }
	.menu-trigger.active span:nth-of-type(2)	{ opacity: 0; }
	.menu-trigger span:nth-of-type(3)	{ top: 36px; }
	.menu-trigger.active span:nth-of-type(3)	{ transform: translateY(-8px) rotate(45deg); }
}

/* ------------ GALLERY ------------- */
.gallery_area	{ display: -webkit-flex; display: flex; flex-wrap: wrap; width: 100%; padding: 0 0 40px; margin: 0; background-color: #f8f8f8; align-items: flex-end; }
.gallery_hdd	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center; flex-wrap: wrap; padding: 120px 20px 60px; }
.gallery_hdd > h2	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center; }
.gallery_hdd > h2 span	{ color:#000; font-size: clamp(22px, 56px, 4vw); font-weight: 400; line-height: 1.3; }
.gallery_hdd > strong	{ width: 100%; display: -webkit-flex; display: flex; justify-content: center;  }
.gallery_hdd > strong span	{ color:#000; font-size: clamp(11px, 16px, 1.2vw); font-weight: 400; line-height: 1.6; padding: 0; }
.glmainslider	{ width: 60%; }
.thumbnail	{ width: 40%; }
.thumbnail h3	{ width: 100%; padding: 0; margin: 0 0 40px; }
.thumbnail h3 span	{ display: inline-block; padding: 10px 5px 0 20px; margin: 0; color: #000; font-size: clamp(22px, 38px, 2.5vw); font-weight: 400; line-height: 1.3; }
.thumbnail h3 span.marker	{ background-image: linear-gradient(rgba(0,0,0,.2), rgba(0,0,0,.2)); }
.grimg	{ background: #000 center center / contain no-repeat; }
.grimg img	{ width: 100%; }
@media (min-width: 768px) { 
	.reflect .glmainslider	{ order:2; }
	.reflect .thumbnail	{ order:1; }
	.reflect .thumbnail h3	{ text-align: right;  }
	.reflect .thumbnail h3 span	{ display: inline-block; padding: 10px 20px 0 5px; margin: 0; color: #000; font-size: clamp(14px, 38px, 2.5vw); font-weight: 400; line-height: 1.3; }
}
@media (max-width: 767.9px) { 
	.gallery_hdd	{ padding: 100px 0 30px; }
	.glmainslider	{ width: 100%; }
	.thumbnail	{ width: 100%; }
	.thumbnail h3	{ margin: 0 0 5px; }
}

/* ------------ SLIDER OPTION ------------- */
.thumbnail .slick-track	{ display: -webkit-flex; display: flex; flex-wrap: wrap; width: 100%!important; gap: 5px; padding: 5px; }
.thumbnail .slick-track::before	{ display: none!important; }
.thumbnail .slick-track::after	{ display: none!important; }
.thumbnail .slick-track > *	{ width: calc(100% / 4 - 4px)!important; margin: 0; cursor: pointer; background-color: #000; }
.slick-prev, 
.slick-next	{ position: absolute; z-index: 3; top: 50%; cursor: pointer; outline: none; border-top: 2px solid #eee; border-right: 2px solid #eee; height: 20px; width: 20px; }
.slick-prev	{ left:20px; transform: rotate(-135deg); }
.slick-next	{ right:20px; transform: rotate(45deg); }
.thumbnail .slick-slide	{ opacity: .3; }
.thumbnail .slick-slide.slick-current	{ opacity: 1; }

/* ------------ GO TOP ------------- */
.gotop { position: fixed; bottom: 0; right: 0; transition: all 1s; opacity: 0; z-index: 40; width: 60px; height: 60px; pointer-events: none; }
.gotop a { display: -webkit-flex; display: flex; align-items: center; justify-content: center; line-height: 0; transition: all .5s; height: 100%; width: 100%; position: relative; }
.gotop a::before	{ content:""; width: 60px; height: 60px; position: fixed; bottom: 0; left: auto; right: 0; background: rgba(0,0,0,.3); mix-blend-mode:multiply; }
.gotop a span { color:#fff; font-size: 13px; font-weight: 500; line-height: 1; letter-spacing:.2rem; padding: 0; margin: 3px 0 0; }
.gotop a svg { color:#fff; width: 28px; padding: 0; margin: 0;  transform:rotate(-90deg); }
.gotop.fixed { opacity: 1; pointer-events: auto; }
@media (min-width: 768px) { 
	.gotop a:hover { background: rgba(0,0,0,.8); }
	.gotop > a:hover span,
	.gotop > a:hover .icon	{ color:#fff;  }
}
@media (max-width: 767.9px) { 
	.gotop a::before	{ display: none; }
}

/* ------------ FOOTER ------------- */
footer	{ display: -webkit-flex; display: flex; justify-content: center; flex-wrap: wrap; width: 100%; color:#fff; background-color: #475f84; background: linear-gradient(160deg, #4d91b3, #475f84); text-shadow: 1px 1px 1px #2e70a4; line-height: 1.4; text-align: left; position: relative; z-index: 20; }
footer	{ font-family:'Roboto Condensed', 'Noto Sans JP', Arial, sans-serif; letter-spacing:.08rem; }
footer a	{ color:#fff!important; font-weight:300; text-decoration: none; transition: all .5s; }
footer a:hover	{ color:#36d7ff!important; }
footer .wrapper	{ padding: 20px; width: 100%; max-width: 880px; }
footer .wrapper .bar	{ width: 100%; height: 1px; opacity: 0.5; background: white; }
.footer-stmap	{ width: 100%; margin: 60px 0 80px 0; display: flex; justify-content: space-between; }
.footer-stmap .footer-address	{ letter-spacing:.2rem; }
.footer-stmap .footer-address > strong	{ font-size: 20px; padding: 0 0 10px; font-weight:100; display: inline-block; }
.footer-stmap .footer-address > p	{ font-size: 14.4px; font-weight:100; padding: 0 0 5px; }
.footer-stmap .footer-address > p.sml	{ font-size: 12px; color:#c9d8e2; padding: 0 0 5px; }
.footer-stmap .footer-address > p .cp_tel	{ font-size: 24px; font-weight:400; }
.footer-stmap .footer-navilist	{ display: flex; justify-content: flex-end; }
.footer-stmap .footer-navilist ul	{ list-style-type: none; }
.footer-stmap .footer-navilist .navilist > li	{ font-size: 16px; padding: 0 0 11px; }
.footer-stmap .footer-navilist .navilist > li > ul	{ padding: 5px 0 0;  }
.footer-stmap .footer-navilist .navilist > li > ul > li	{ font-size: 13.5px; padding: 0 0 .4rem 1.5rem; text-indent: -1.2em; }
.footer-stmap .footer-navilist .pdr50	{ padding: 0 50px 0 0; }
.footer-sub	{ margin: 0 auto 20px; }
.footer-sub > ul	{ display: flex; justify-content: left; align-items: center; margin: 0 auto; list-style-type: none; }
.footer-sub > ul > li	{ font-size: 15px; margin-right: 30px; line-height: 1; flex-shrink: 0; }
.footer-sub > ul > li:last-child	{ margin-right: 0; }
.footer-bottom	{ width: 100%; margin: 20px 0 60px 0; display: flex; justify-content: space-between; align-items: center; }
.footer-bottom .footer-company	{ display: flex; align-items: center; margin: 0 auto; }
.footer-bottom .footer-company > .logo	{ max-width: 200px; }
.footer-bottom .footer-company > .logo img	{ width: 100%; filter: drop-shadow(1px 1px 1px rgba(0,0,0,0.4)); }
.footer-bottom .footer-company > .copyright	{ padding: 0 20px; color:#ffffff; font-size: 12px; letter-spacing:.1rem; }
.footer-bottom .footer-sns	{ display: flex; margin-right: 10px; }
.footer-bottom .footer-sns li	{ padding-left: 18px; font-size: 2rem; }
@media (max-width: 767.9px) { 
	footer.index	{ padding: 100px 0 0; }
	footer .wrapper .bar	{ display: none; }
	.footer-stmap	{ display:block; margin: 30px 0 30px 0; }
	.footer-stmap .footer-address	{ text-align: center; }
	.footer-stmap .footer-address > p	{ font-size: 13px; }
	.footer-stmap .footer-address > p.sml	{ font-size: 11px; }
	.footer-stmap .footer-address > p .cp_tel	{ font-size: 24px; }
	.footer-stmap .footer-navilist	{ padding: 30px 0 0; justify-content: center; }
	.footer-stmap .footer-navilist .navilist > li	{ font-size: 14.5px; padding: 5px 10px; }
	.footer-stmap .footer-navilist .navilist > li > ul > li	{ font-size: 12px; }
	.footer-stmap .footer-navilist .pdr50	{ padding: 0; }
	.footer-sub	{ padding: 20px 0; display: flex; justify-content: center; border-top: solid 1px rgba(255, 255, 255, 0.2); word-break: keep-all; }
	.footer-sub > ul > li	{ font-size: 12px; margin-right: 20px; }
	.footer-bottom	{ flex-direction: column-reverse; margin: 10px 0 30px 0; }
	.footer-bottom .footer-company	{ display:block; margin: 30px 0 20px; text-align: center; }
	.footer-bottom .footer-company > .logo	{ max-width: 160px; margin: 0 auto; }
	.footer-bottom .footer-company > .copyright	{ padding: 15px 0; font-size: 10px; }
	.footer-bottom .footer-sns	{ display: flex; width: 110px; margin: 10px auto; justify-content: space-between; }
}

/* ------------ BLOCK ------------- */
@media (max-width: 767.9px)	{ .pconly { display: none!important; } }
@media (min-width: 768px)	{ .pconly { display: inline-block!important; } }
@media (max-width: 767.9px)	{ .sponly { display: inline-block!important; } }
@media (min-width: 768px)	{ .sponly { display: none!important; } }
.noimg	{ display: none!important; }
.delay01	{ transition-delay: 0.1s; animation-delay: 0.1s; }
.delay02	{ transition-delay: 0.2s; animation-delay: 0.2s; }
.delay03	{ transition-delay: 0.3s; animation-delay: 0.3s; }
.delay04	{ transition-delay: 0.4s; animation-delay: 0.4s; }
.delay05	{ transition-delay: 0.5s; animation-delay: 0.5s; }
.delay06	{ transition-delay: 0.6s; animation-delay: 0.6s; }
.delay07	{ transition-delay: 0.7s; animation-delay: 0.7s; }
.delay08	{ transition-delay: 0.8s; animation-delay: 0.8s; }
.delay09	{ transition-delay: 0.9s; animation-delay: 0.9s; }
.delay10	{ transition-delay: 1s; animation-delay: 1s;}

/* ------------ clearfix ------------- */
span.clearfix	{ display:block; }
.clearfix:after	{ content:"."; display:block; height:0; clear:both; visibility:hidden; font-size:0; line-height:0; }
.clearfix	{ *overflow:hidden; *zoom:1; }
.clearfix:not(:target)	{ /* overflow:hidden\9; */ /* zoom:1\9; */ }
* html .clearfix	{ height:1%; overflow:visible; }

