@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond&display=swap');


body { background: #fff; color: #000; font-family: "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif; overflow-x:hidden;/* -moz-osx-font-smoothing:grayscale; -webkit-font-smoothing:antialiased;*/}
#logo { position: fixed; top: 0; left: 0; width: 100%; margin: 0 auto; text-align: center; padding: 40px 0; z-index: 1; background: linear-gradient(0deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 75%)}
#logo img { width: 120px; height: auto}

@media screen and (max-width: 767px) {
	#logo { margin: 0 auto; text-align: center; padding: 28px 0}
	#logo img { width: 88px; height: auto}
}

.drawer { position: fixed; top: 35px; right: 35px; width: 46px; height: 25px; padding-top: 1px; box-sizing: border-box; padding-top: 0px; z-index: 20; cursor: pointer; pointer-events: auto; color: #000; text-align: center}

@media screen and (max-width: 767px) {
	.drawer { display: block; right: 0; top: 4px; padding-top: 20px; width: 70px; height: 70px}
	#factory .drawer { display: none}
}

.drawer_wrapper { margin-bottom: 5px; width: 28px; cursor: pointer; display: inline-block}

@media screen and (max-width: 767px) {
	.drawer_wrapper { margin-bottom: 5px; width: 24px}
}

.drawer_text { font-size: 12px; letter-spacing: 0.1em}
.js_drawerOpen .drawer_text.drawer_text__menu { display: none}
.drawer_text.drawer_text__close { display: none}
.js_drawerOpen .drawer_text.drawer_text__close { display: block}

@media screen and (max-width: 767px) {
	.drawer_text { font-size: 10px; padding-top: 2px}
	.drawer_text svg path { transition: all 200ms cubic-bezier(0.16, 0.52, 0.25, 1); fill: #000}
}

@media screen and (max-width: 767px) {
	.js_drawerOpen .drawer_text svg path {
	fill: #000
	}
}

.drawer span.drawer_bar { display: block; width: 100%; margin: 0 auto 8px; height: 2px; background: #000; transition: all .3s ease-in-out}
.drawer span.drawer_bar:last-child { margin-bottom: 0}
.js_drawerOpen .drawer span.drawer_bar { background: #000}

@media screen and (max-width: 767px) {
	.drawer span.drawer_bar { margin: 0 auto 7px; left: 0; top: 0; background: #000}
}

.js_drawerOpen .drawer span.drawer_bar.top { transform: translateY(9px) rotate(-45deg)}
.js_drawerOpen .drawer span.drawer_bar.middle { opacity: 0}
.js_drawerOpen .drawer span.drawer_bar.bottom { transform: translateY(-11px) rotate(45deg)}
.drawerButton.drawerButton__close { top: 2%; right: 2%}
.drawerButton__close span.drawer_bar { display: block; width: 35px; margin: 0 auto; height: 4px; background: #000}
.drawerButton__close span.drawer_bar.top { transform: translateY(5px) rotate(-45deg)}
.drawerButton__close span.drawer_bar.bottom { transform: translateY(-6px) rotate(45deg)}

.nav { position: fixed; right: 0; top: 0; height: 100vh; background-color: rgba(255, 255, 255, 0.95); width: 0; z-index: 3; box-sizing: border-box; transition: all 150ms ease-out; overflow: hidden; display: flex; justify-content: center; align-items: center; text-align: center}
.js_drawerOpen .nav { width: 450px}

@media screen and (max-width: 767px) {
	.js_drawerOpen .nav { width: 100%; opacity: .95; padding: 0 5%}
 	.js_drawerOpen .drawer span.drawer_bar.top {transform: translateY(1px) rotate(-45deg);margin: 0}
	.js_drawerOpen .drawer span.drawer_bar.bottom { transform: translateY(-10px) rotate(45deg)}
}

.nav_item { color: #000 !important; font-size: 15px; line-height: 1.8; text-align: center}
.nav_item a {   display: block}
.nav_item.copy { border-bottom: none}
.nav_item img { width: auto; height: 16px}

@media screen and (max-width: 767px) { 
	.nav_item {margin-left: 0}
}


main { color: #000; margin: 0 auto 100px; text-align: center}
.slidebox { width: 100%; margin:0 auto}
.slider { padding:102px 0 0}
.slider li { background-repeat: no-repeat;
			background-size: cover;
			background-position: center;
			/*height: 78.5vh;*/
			margin: 0}
.slider li img { width: 100%; height: auto}
.slider li.img01 { background-image: url(../img/pic01.jpg) }
.slider li.img02 { background-image: url(../img/pic02.jpg) }
.slider li.img03 { background-image: url(../img/pic03.jpg) }
.slider li.img04 { background-image: url(../img/pic04.jpg) }
.slider li.img05 { background-image: url(../img/pic05.jpg) }
.slider li.img06 { background-image: url(../img/pic06.jpg) }
.slider li.img07 { background-image: url(../img/pic07.jpg) }
.slider li.img08 { background-image: url(../img/pic08.jpg) }
.slider li.img09 { background-image: url(../img/pic09.jpg) }
.slider li.img10 { background-image: url(../img/pic10.jpg) }
.slider li.img11 { background-image: url(../img/pic11.jpg) }
video.movie { margin: 0 auto; width: 420px; height: 100%; background: #000}

@media screen and (max-width: 767px) {
	main { margin: 0 auto 50px}
	.slider { padding: 74px 0 0}
	video.movie { padding: 74px 0 0; width: 100%}
}

@media only screen 
    and (device-width : 375px) 
    and (device-height : 812px) {
	.slider li { height: 81.5vh }
 }
 

@media screen and (max-width: 320px) {
	#logo { padding: 8.4% 0 6.6% }
	.slider li { height: 75.5vh }
}


  @media screen and (max-width:767px){
    .only_sp{display:none}
  }
  @media screen and (min-width:768px){
    .only_pc{display:none}
  }


h1 { /*font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;*/ font-size: 16px; font-weight: bold; margin: 0 auto 20px; text-align: center}
h1 span { font-weight: normal }
p.lead { font-size: 12px; letter-spacing: 0.075em; line-height: 2.0em; margin: 0 auto 120px; text-align: center}

ul.navigation { display: flex; flex-wrap: wrap; justify-content: left; margin: 0 auto 150px; width: 1000px}
ul.navigation li { margin: 0 10px 10px; text-align: center; width: 31.2%}
ul.navigation li a { border: 1px solid #666; display: block ; font-size: 14px; padding: 14px 20px; box-sizing: border-box; width: 100%}

section.contents { margin: 0 auto 120px; width: 960px}
section.contents ul.collection { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 0 auto 210px; width: 980px}
section.contents ul.collection li { margin: 0 auto 70px; width: 47.5%}
section.contents ul.collection li img { width: 100%; height: auto}
section.contents ul.collection li p { font-size: 16px; letter-spacing: 0.015em; margin: 20px auto 0; text-align: center}

section.contents h2 { font-size: 22px; letter-spacing: 0.075em; margin:0 auto 50px; text-align: center}
section.contents h2 small { display: inline-block; font-size: 15px; letter-spacing: 0; margin-left: 10px}

section.contents dl { position: relative; border-top: 1px solid #000; margin: 0 auto; width: 725px}
section.contents dl dt.date { position: absolute; left: 0; padding: 25px 0 25px 160px; width: 220px; font-size: 12px; letter-spacing: 0.5px}
section.contents dl dd.text { border-bottom: 1px solid #000; padding-left: 220px; font-size: 12px; letter-spacing: 0.5px}
section.contents dl dd.text a { display: block; padding: 25px}


#news, #collection { padding-top: 100px; margin-top: -100px}


@media screen and (max-width: 767px) {
	h1 {font-size: 14px; margin: 0 auto 15px}
	p.lead { font-size: 11px; line-height: 1.8em; margin: 0 auto 80px}

	ul.navigation { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 0 auto 100px; width: 75.5%}
	ul.navigation li { line-height: 1; margin: 0 auto 15px; text-align: center; width: 100%}
	ul.navigation li a { font-size: 14px; padding: 10px 20px; box-sizing: border-box}
	ul.navigation img { height: 14px}

	section.contents { margin: 0 auto 60px; width: 100%}
	section.contents h2 { font-size: 16px; letter-spacing: 0.15em; line-height: 1; margin:0 auto 20px; width: 82%}
	section.contents h2 img { width: auto; height: 18px}
	section.contents ul.collection { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 0 auto; width: 100%}
	section.contents ul.collection li { margin: 0 auto 60px; width: 100%}
	section.contents ul.collection li img { width: 100%; height: auto}
	section.contents ul.collection li p { font-size: 14px}
	section.contents ul.collection li p img { width: auto; height: 12px; padding-top: 14px; box-sizing: content-box}
	section.contents h2#news { font-size: 12px; letter-spacing: 0.075em; margin:0 auto 15px}

	section.contents h2 img { width: auto; height: 18px}
	section.contents ul.news { display: flex; flex-wrap: wrap; justify-content: space-between; margin: 0 auto 80px; width: 82%}
	section.contents ul.news li { margin: 0 auto 20px; width: 100%}
	#news, #collection { padding-top: 80px; margin-top: -80px}
	section.contents dl {  margin: 0 auto; position: relative; width: 84.5%}
	section.contents dl dt.date { padding: 25px 0 25px 20px; width: 26%; font-size: 11px}
	section.contents dl dd.text { border-bottom: 1px solid #000; padding-left: 26%; font-size: 11px; letter-spacing: 0.5px}
	section.contents dl dd.text a { display: block; padding: 25px}

}



/*--------------------------------------------------------------------
  3. #footer
--------------------------------------------------------------------*/
footer { background:#4d4d4d; font-family: sans-serif}
footer a:hover { text-decoration: underline}
#foot01{ line-height: 1.}
#foot01 .inner{ box-sizing: border-box; width:1130px; line-height: 1; margin:0 auto; padding:50px 40px; display: flex; flex-wrap: wrap; justify-content: space-between}
#foot01 .link { color: #fff; font-size: 12px; width: 120px}
#foot01 .nav-open { pointer-events: none}
#foot01 .link li ul { border-top: 1px solid #333; padding-top: 10px; margin-top: 10px}
#foot01 .link li ul li { position: relative; font-size: 11px; line-height: 2; padding-left: 15px; white-space: nowrap}
#foot01 .link li ul li:before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
    width: 7px;
    height: 7px;
    border: 1px solid;
    border-color: #fff #fff transparent transparent;
    transform: rotate(45deg) skew(-16deg, -16deg);
    transition: all .4s;
}

#foot02 { margin: 0 auto}
#foot02 .inner { border-top: 1px solid #333; margin: 0 auto; padding:20px 0 50px; width:1130px}
#foot02 .navi { float:right; line-height: 1}
#foot02 .navi li { color: #fff; display:inline-block; font-size:10px; margin-right:30px}
#foot02 .navi li a { color:#fff}


@media screen and (max-width:767px){
	#foot01 .link li ul { display: none}
	#foot01 .nav-open { position: relative; pointer-events: auto}
	#foot01 .nav-open:after {position: absolute;top: 0;bottom: 0;right: 0;margin: auto;content: "";vertical-align: middle;width: 10px;height: 10px;border: 1px solid;border-color: #fff #fff transparent transparent;transform: rotate(135deg);transition: all .4s}
	#foot01 .nav-open.active:after {transform: rotate(-45deg)}

	#foot01 .inner { width:100%; padding:0}
	#foot01 .link { font-size: 11px; width: 100%}
	#foot01 .link li { border-bottom: 1px solid #333; padding: 15px}
	#foot01 .link li ul { border-top: none; padding-top: 0; margin-top: 10px}
	#foot01 .link li ul li { position: relative; font-size: 11px; line-height: 2; padding-left: 15px; border-bottom:none; padding: 0}
	#foot01 .link li ul li:before { content: none; vertical-align: middle; width: 7px; height: 7px; border: 1px solid; border-color: #fff #fff transparent transparent; transform: rotate(45deg) skew(-16deg, -16deg); transition: all .4s}
	#foot01 .link li ul li a { display: block}

	#foot02 .inner { border-top: none; margin: 0 auto; padding: 0; width:auto}
	#foot02 .navi { display: flex; flex-wrap: wrap; justify-content: space-between; float:none; line-height: auto}
	#foot02 .navi li { color: #fff; display:inline-block; font-size:10px; margin-right:0; text-align: center}
	#foot02 .navi li:nth-child(1) { order: 5; width: 100%; padding: 30px 0 15px}
	#foot02 .navi li:nth-child(2) { order: 1; width: 50%}
	#foot02 .navi li:nth-child(3) { order: 2; width: 50%}
	#foot02 .navi li:nth-child(4) { order: 3; width: 50%}
	#foot02 .navi li:nth-child(5) { order: 4; width: 50%}
	#foot02 .navi li a { display: block; padding: 15px 0; border-bottom: 1px solid #333; border-right: 1px solid #333}
	#foot02 .navi li:nth-child(3) a, #foot02 .navi li:nth-child(5) a { border-right: none}
}



/*-----------------------------------------------------------------
	about
-------------------------------------------------------------------*/
#about main { padding: 100px 0 200px; width: 650px}
#about main .banner { margin: 0 auto 60px}
#about main h3 { font-size: 13px; font-weight: bold; letter-spacing: 0.15em; margin: 20px auto 30px;  padding-bottom: 30px; border-bottom: 1px solid #ccc}
#about main h3 small { font-size: 12px; letter-spacing: 0.05em}
#about main h2 { font-size: 14px; font-weight: bold; letter-spacing: 0.1em; margin: 40px auto 10px}
#about main h2 small { font-size: 15px}
#about main h1 { font-size: 13px; font-weight: bold; letter-spacing: 0.15em; margin: 70px auto 30px;  padding-bottom: 30px; border-bottom: 1px solid #ccc}
#about main h1 small { font-size: 12px}
#about main p { font-size: 12px; letter-spacing: 0.075em; line-height: 2.2em}


@media screen and (max-width: 767px) {
	#about main { padding: 70px 0 80px; width: 100%}
	#about main .banner { margin: 0 auto 60px}
	#about main h3 { font-size: 12px; line-height: 1.5; margin: 20px auto 25px;  padding-bottom: 25px; width: 85.0%}
	#about main h3 small { font-size: 11px}
	#about main h2 { font-size: 13px; margin: 30px auto 10px}
	#about main h2 small { font-size: 14p}
	#about main h1 { font-size: 12px; margin: 70px auto 25px;  padding-bottom: 25px; width: 85.0%}
	#about main h1 small { font-size: 11px}
	#about main p { font-size: 11px; letter-spacing: 0.045em; margin: 0 auto; width: 85.0%}
}



a.rollover, a.rollover img { transition:opacity 0.5s; -webkit-backface-visibility: hidden; backface-visibility: hidden}
a.rollover:hover, a.rollover:hover img { opacity: 0.75}

