@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@400;500;600&display=swap');
/* Micro clearfix */

.cf { zoom: 1; }
.cf:before, .cf:after { content: ""; display: table; }
.cf:after { clear: both; }

/* 必要要素の初期設定 */

body {
-webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 width: 100%;
 margin: 0;
 padding: 0;
 color:#333333;
 font-size: 12px;
 font-family: 'EB Garamond', serif;
 background-color:#e8e8e8;
 /*
 min-width:1000px;
 */
 
}

*:focus {
  outline: none;
}


a {
 text-decoration:none;
 outline:none;
}

a:focus{
	outline: none;
}

a:hover{
	opacity:0.7;	
}

a{
  -webkit-tap-highlight-color: rgba(0,0,0,0);
cursor:pointer;
}


ul {
 margin: 0;
 padding: 0;

}

li{
	list-style:none;	
}

/* ベースレイアウト */






#wrapper {
 width: 100%;
 margin: 0;
 padding:0;
	

 opacity: .0; 
	filter: alpha(opacity=0); 
	-ms-filter: "alpha(opacity=0)"; 
	-khtml-opacity: .0; 
	-moz-opacity: .0; 

	

}

.contents{
	width:100%;
	position:relative;
	height: 100vh;
}


.menubtn{
	position: fixed;
	display: block;
	top:20px;
	left: 30px;
	z-index: 9999;
	cursor: pointer;
}

.bgimg{
	width: 100%;
	position: fixed;
	overflow: hidden;
	display: block;
	top:0;
	left: 0;
	margin: 0;
	padding:0;
	
}
.message{
	width: 850px;
	display: block;
	text-align: center;
	margin: 0 auto;
	color: #ffffff;
	
	 position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  height: 80px;
}

.mes{
	font-size: 15px;
	line-height: 1.6em;
}

.overlay{
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	background: #000000;
	display: none;
}

.overlay .concept{
	display: block;
	position: absolute;
	bottom: 40px;
	left: 60px;
	width: 348px;
	font-size: 12px;
	color: #ffffff;
	line-height: 1.6em;
}

.overlay .overlogo{
	display: block;
	margin: 70px 0 0 60px;
}

.overlay .concept a{
	display: inline-block;
	color: #ffffff;
	margin: 0 4px 0  0;
}

.overlay .concept a:last-of-type{
	margin: 0 0 0  4px;
}

.overlay .experience{
	position: absolute;
	display: block;
	top:50px;
	right: 50px;
	
}

.overlay .close{
	position: absolute;
	display: block;
	right:110px;
	bottom: 70px;
	cursor: pointer;
	
}

.overlay .menu{
	position: absolute;
	display: block;
	top:200px;
	left: 60px;
}

.overlay .menu a{
	display: block;
	font-size: 14px;
	color: #ffffff;
	margin: 0 0 86px 0;
	letter-spacing: 0.04em;
}

/*experience*/

.exp{
	display: block;
	font-size: 14px;
	color: #707070;
	position: fixed;
	top:16px;
	right: 30px;
	z-index: 9980;
}
.expconcept{
	display: block;
	position: relative;
	width: 400px;
	margin: 0 auto;
}

.expconcept .econ{
	display: block;
	margin: 0 0 90px 0;
	
}

.expconcept .cursor{
	display: block;
	width: 16px;
	margin: 0 auto;
}


.ex_gallery{
	position: relative;
	display: block;
	width: 100%;
	z-index: 9990;
	background: #E8E8E8;
	padding: 70px 0;
}

.ex_gallery .inner{
	width: 1070px;
	display: block;
	margin: 70px auto 100px auto;
	overflow: hidden;
}

#slider {
  position: relative;
  width: 1070px;
  height: 804px;
  overflow: hidden;
}

.slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.active {
  opacity: 1;
}

.controls {
  position: relative;
  width: 100%;
 margin: 50px 0 0 0;
  text-align: center;
}

#prev, #next {
  cursor: pointer;
  margin: 0 40px;
  
  padding: 0;
  
}

#slide-number {
  color: #000000;
  font-size: 11px;
	padding: 0;
	margin: 0;
	letter-spacing: 0.8em;
}

.controls a{
	color: #000000;
	display: block;
	position: absolute;
	margin: 0 0 0 0;
	text-decoration: underline;
	font-size: 12px;
	right: 40px;
	top: 0;
}

.footer{
	clear: both;
	display: block;
	position: relative;
	width: 100%;
	text-align: center;
}
.footer p{
	text-align: center;
	width: 540px;
	margin: 200px auto 60px auto;
	font-size: 11px;
	line-height: 1.6em;
	color: #000000;
}


/*about*/
.about_cont{
	position: relative;
	display: block;
	width: 100%;
	z-index: 9990;
	background: #E8E8E8;
	padding: 0 0 70px 0;
	margin: 0;
	font-size: 13px;
	line-height: 1.9em;
}

.about_head{
	position: fixed;
	display: block;
	width: 780px;
	margin: -20px 0 0 0;
	left: 50%;
	transform: translateX(-50%);
	padding: 110px 0 60px 0;
	z-index: 9996;
	background: #e8e8e8;
	font-size: 14px;
	letter-spacing: 0.05em;
}

.about_cont .inner{
	display: block;
	position: relative;
	width: 780px;
	margin: 0 auto 0 auto;
	padding: 260px 0 0 0;
}

.about_cont .line{
	margin: 100px 0;
	height: 1px;
	width: 50px;
	border-bottom: 1px solid #cccccc;
}

.about_cont .atitle{
	font-size: 15px;
}

.space{
	display: inline-block;
	width: 20px;
}


.space2{
	display: inline-block;
	width: 10px;
}


.pc{
	display: block;
}

.sp{
	display:none;
}


@media only screen and (max-width: 1400px) {
	
	#top_message  .mcatch{
	position: absolute;
	top: 140px;
	left: 5%;
}
	
}

@media only screen and (max-width: 800px) {
	
	
.sp{
	display: block;
}

.pc{
	display:none;
}

	




#wrapper {
 width: 100%;
 margin: 0;
 padding:0;
	

 opacity: .0; 
	filter: alpha(opacity=0); 
	-ms-filter: "alpha(opacity=0)"; 
	-khtml-opacity: .0; 
	-moz-opacity: .0; 

	

}

.contents{
	width:100%;
	position:relative;
	height: 100vh;
}


.menubtn{
	position: fixed;
	display: block;
	top:20px;
	left: 30px;
	z-index: 9999;
	cursor: pointer;
}

.bgimg{
	width: 100%;
	position: fixed;
	overflow: hidden;
	display: block;
	top:0;
	left: 0;
	margin: 0;
	padding:0;
	
}
.message{
	width: 80%;
	display: block;
	text-align: center;
	margin: 0 auto;
	color: #ffffff;
	
	 position: fixed;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  height: 80px;
	overflow: hidden;
}

.mes{
	font-size: 15px;
	line-height: 1.6em;
}

.overlay{
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	background: #000000;
	display: none;
}

.overlay .concept{
	display: block;
	position: absolute;
	bottom: 40px;
	left: 5%;
	width: 55%;
	font-size: 12px;
	color: #ffffff;
	line-height: 1.6em;
}

.overlay .overlogo{
	display: block;
	margin: 60px 0 0 5%;
	width: 36%;
}
	
	.overlay .overlogo img{
		width: 100%;
		height: auto;
	}

.overlay .experience{
	position: absolute;
	display: block;
	top:50px;
	right: 5%;
	width: 34%;
	
}
	
	.overlay .experience img{
		width: 100%;
		height: auto;
	}

.overlay .close{
	position: absolute;
	display: block;
	right:12%;
	bottom: 50px;
	cursor: pointer;
	
}

/*experience*/

.exp{
	display: block;
	font-size: 14px;
	color: #707070;
	position: fixed;
	top:16px;
	right: 5%;
	z-index: 9980;
}
.expconcept{
	display: block;
	position: relative;
	width: 94%;
	margin: 0 auto;
}

.expconcept .econ{
	display: block;
	margin: 0 0 90px 0;
	
}
	
	.expconcept .econ img{
		width: 100%;
		height: auto;
	}

.expconcept .cursor{
	display: block;
	width: 16px;
	margin: 0 auto;
}


.ex_gallery{
	position: relative;
	display: block;
	width: 100%;
	z-index: 9990;
	background: #E8E8E8;
	padding: 70px 0;
}

.ex_gallery .inner{
	width: 100%;
	display: block;
	margin: 70px auto 100px auto;
	overflow: hidden;
}

#slider {
  position: relative;
  width: 100%;
  height: 360px;
  overflow: hidden;
}

.slide {
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1s ease-in-out;
}

.active {
  opacity: 1;
}

.controls {
  position: relative;
  width: 100%;
 margin: 50px 0 0 0;
  text-align: center;
}

#prev, #next {
  cursor: pointer;
  margin: 0 40px;
  
  padding: 0;
  
}

#slide-number {
  color: #000000;
  font-size: 11px;
	padding: 0;
	margin: 0;
	letter-spacing: 0.8em;
}

.controls a{
	color: #000000;
	display: block;
	position: relative;
	text-decoration: underline;
	font-size: 12px;
	right: 0;
	margin: 40px 0 0 0;
	top: 0;
}

.footer{
	clear: both;
	display: block;
	position: relative;
	width: 90%;
	margin: 0 auto;
	text-align: center;
}
.footer p{
	text-align: center;
	width: 100%;
	margin: 200px auto 20px auto;
	font-size: 11px;
	line-height: 1.6em;
	color: #000000;
}

/*about*/
.about_cont{
	position: relative;
	display: block;
	width: 100%;
	z-index: 9990;
	background: #E8E8E8;
	padding: 0 0 0px 0;
	margin: 0;
	font-size: 13px;
	line-height: 1.9em;
}

.about_head{
	position: fixed;
	display: none;
	width: 780px;
	margin: -20px 0 0 0;
	left: 50%;
	transform: translateX(-50%);
	padding: 110px 0 60px 0;
	z-index: 9996;
	background: #e8e8e8;
	font-size: 14px;
	letter-spacing: 0.05em;
}

.about_cont .inner{
	display: block;
	position: relative;
	width: 60%;
	margin: 0 auto 0 auto;
	padding: 60px 0 0 0;
}

.about_cont .line{
	margin: 100px 0;
	height: 1px;
	width: 50px;
	border-bottom: 1px solid #cccccc;
}

.about_cont .atitle{
	font-size: 15px;
}

.space{
	display: inline-block;
	width: 20px;
}
	
	.about_cont .atxt2{
	line-height: 1.6em;
}



	
	
}