@charset "UTF-8";
/* top.css */





	

.video-container {
  height: 50vh;
  position: relative;
  overflow: hidden;
}

@media (min-width: 600px) {
  .video-container {
    height: 100vh;
  }
}
 
video {
  	-o-object-fit: cover;
     	object-fit: cover;
  	position: absolute;
  	height: 100%;
  	width: 100%;
  	top: 0;
  	left: 0;
	z-index: 10;
}


.flex {
	display: flex;
}

.between{
	justify-content: space-between;
}





/* pc */
@media screen and (min-width: 501px) {

#wrap_header {
	height: 100vh;
	max-width: 1000px;
}

#header_content {
 	position: absolute;
 	z-index: 200;
 	display: flex;
 	width: 100%;
 	justify-content: center;
 	align-items: center;
 	text-align:center;
	margin-top: -90%;
}	


/*------------  ナビゲーション ------------*/		
	
#wrap_top_left {
	width: 90%;
	position: relative;
	padding: 0 0 53% 0;
	top:0;
	margin-top: -53%;
	margin-bottom: -0.0em;
	white-space: nowrap;
}	
	
#wrap_top_left ul#navbox {
	text-align: right;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	display: flex;
    margin: 0 auto;
    padding: 0 0;
    list-style-type: none;
	margin-left: 65%;
	z-index: 690;	
}	
	
#wrap_top_left ul#navbox li {
	width: 18%;
	position: relative;
	padding: 0 0 0 0;
	margin: 0 0;
}
	
#wrap_top_left ul#navbox li a {
	display: inline-block;
	text-align: center;
	text-decoration: none;
	outline: none;
	font-family: fot-tsukuardgothic-std, sans-serif;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	font-style: normal;
	font-weight: 400;
	color: #ffffff;
	font-size: 1.6em;
	font-display: swap;
}		

	
#wrap_top_left ul#navbox li.line a::after {
  position: absolute;
  top: 0;
  content: '';
  width: 1px;
  height: 180px;
  background: #FFF28A;
  left: 29px;
  transform: scale(0);
  transition: transform 0.5s;
  transform-origin: left center;
}

#wrap_top_left ul#navbox li.line a:hover::after {
  transform: scale(1)
}	
	
	
	
	


/* 時間差フェードインアニメーション */
/* 1秒間かけてフェードイン */
.fadeIn1s {
    animation-name: fadeIn1s;
    animation-delay: 1s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn1s {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}
/* 0.5秒間かけてフェードイン */
.fadeIn500ms {
    animation-name: fadeIn500ms;
    animation-delay: 500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
/* 1.5秒間かけてフェードイン */
.fadeIn1500ms {
    animation-name: fadeIn1500ms;
    animation-delay: 1500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn1500ms {
    0% {
    }
    100% {
        transform: translateY(0);
        opacity: 1;
    }
}
/* 2秒間かけてフェードイン */
.fadeIn2s {
    animation-name: fadeIn2s;
    animation-delay: 2s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn2s {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
/* 2.5秒間かけてフェードイン */
.fadeIn2500ms {
    animation-name: fadeIn2500ms;
    animation-delay: 2500ms;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn2500ms {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
/* 3秒間かけてフェードイン */
.fadeIn3s {
    animation-name: fadeIn3s;
    animation-delay: 3s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    opacity: 0;
}
@keyframes fadeIn3s {
    0% {
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}
	
	
	
	
	
	
#wrap_top_right {
	width: 10%;
	height: 100vh;
	padding: 0 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #ffffff solid;
	white-space: nowrap;
	z-index: 290;
}	
	
	
#wrap_top_right .pad_toplogo {
	width:75%;
	position: relative;
	padding:0 0 0 3%;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
)	

}


	
	
	
	
/*------------  BAR ------------*/	

#bar_top01 {
	position: relative;
	width: 100%;
	height: 276px;
	background-image: url(../images/top_bar01.webp);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center top;
	margin-top: -0.0em;
	padding: -120% 0 0 0;
	margin-top: -27%;
	z-index: 4;
}


#wrap_top_w01 {
	width: 89.86%;
	height: 100%;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: -2%;
	margin-bottom: -0.0em;
	border-right: 1.5px #ffffff solid;
	white-space: nowrap;
	z-index: 10;
}


/*------------ スクロール ------------*/	

#scroll {
	position: absolute;
	bottom: 0;
	padding: 0 0 0 40%;
	margin-left: -15px;
	margin-top: -0.0em;
	margin-bottom: 3%;
	z-index: 200;
}
#scroll a {
	top: 0;
	position: relative;
}
#scroll a span {
  position: absolute;
  bottom: 20px;
  left: 50%;
  width: 30px;
  height: 50px;
  margin-left: -15px;
  border: 2px solid #fff;
  border-radius: 50px;
  box-sizing: border-box;
}
#scroll a span::before {
  position: absolute;
  top: 10px;
  left: 50%;
  content: '';
  width: 6px;
  height: 6px;
  margin-left: -3px;
  background-color: #fff;
  border-radius: 100%;
  -webkit-animation: sdb 2s infinite;
  animation: sdb 2s infinite;
  box-sizing: border-box;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    -webkit-transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}


#scroll a:link {
	color: #ffffff;
	text-decoration:none;
	outline: none;
}

#scroll a:visited {
	color: #ffffff;
	text-decoration: none;
	outline: none;
}

#scroll a:hover {
	color: #ffb2cb;
	text-decoration: underline;
	outline: none;
}

#scroll a:active {
	color: #fed3e1;
	text-decoration: underline;
	outline: none;
}



	
	
	
/*------------ メッセージ------------*/		

#wrap_top_b01 {
	width: 	90%;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-right: 1.5px #000000 solid;
	box-sizing: border-box;
	z-index: 100;
}

#wrap_toptitle {
	width: 10%;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	box-sizing: border-box;	
}

#wrap_toptitle h2 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.06em;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 2.6em;
	padding: 115% 0 0 30%;
	position: relative;
	font-display: swap;
}


#wrap_top_b01 .pad_space {
		height: 8%;
}
	
#wrap_top_b01 .vertical-text-outer {
	text-align: right;
	z-index: 40;
}

#wrap_top_b01 .vertical-text-outer .vertical-text-inner {
  	writing-mode: vertical-rl;
  	display: inline-block;
  	height: 700px;
  	text-align: justify;
	margin-top: 2%;
	margin-right: 6%;
	margin-bottom: 14%;
}


#wrap_top_b01 .vertical-text-outer .vertical-text-inner p.font_txt {
	font-family:YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
	font-style: normal;
	font-weight: 400;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	text-align: left;
	top: 0;
	font-size: 1.3em;
	letter-spacing: 0.1em;
	line-height: 2.9em;
	padding: 0 0 0 0;
	position: relative;
	margin-left: 7.2%;
	font-display: swap;
}
	
.pad_topelememt01 {
	width: 100%;
	padding: 0 0 0 0;
	margin-top: -48%;
	margin-bottom: -0.0em;
	position: relative;
	z-index: 10;
}	
	
	

	
	
	
	
/*------------  TOPICS ------------*/	


#wrap_news {
	width: 100%;
	display: flex;
	z-index: 40;
	margin-top: -1%;
}
	

#wrap_news .pad_left {
	width: 10%;
}

#wrap_news .pad_right {
	width: 90%;
	position: relative;
	padding: 12% 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #323232 solid;
	box-sizing: border-box;
	margin-left: -0.0em;
	z-index: 22;
}


#wrap_news .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.06em;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 2.6em;
	padding: 47% 0 0 7%;
	position: relative;
}

/*------------  BANNER 01 ------------*/	
	
#box_newsbanner {
	width: 68%;
	border: 1px #989898 solid;
	display: flex;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: 5%;
}	
	
#box_newsbanner a {
	display:block;
	position:absolute;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	text-indent: -9999px;
	z-index: 10000;
	transition-duration: 0.5s;
} 

#box_newsbanner .left_icon {
	width: 50%;
	padding: 1% 1% 0 1%;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
}
#box_newsbanner .right {
	width: 42%;
	padding: 2% 2% 2% 3%;
	top: 0;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
}
	
#box_newsbanner .right .txt {
	text-align: left;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
	color: #212121;
	top: 0;
	font-size: 1.1em;
	letter-spacing: 0.1em;
	line-height: 1.6em;
	font-display: swap;
}	
	
#box_newsbanner .right .banner_bu {
	width: 70%;
 	position: relative;
	border-radius: 3px;
  	padding: 4% 3% 4% 3%;
  	background-color: #a09143;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
  	color: #ffffff;
  	line-height: 1.0em;
	font-size:1.2em;
  	text-align: center;
  	transition: .2s;
	margin-left: 27%;
}
	
#box_newsbanner .right .banner_bu::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 9px;
  height: 9px;
  margin: auto;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  transition: .2s;
  box-sizing: border-box;
}	
	
	
#box_newsbanner:hover .right .banner_bu {
	background: #FFD401;
	transition: background-color .4s;
}	
	

	
/*------------  TOPICS ------------*/	
	
#wrap_topics {
	width: 68%;
	border-bottom: 1px #8f8f8f solid;
	display: flex;
	position: relative;
	padding:  0 0 1% 0;
	margin-top: 1%;
	margin-bottom: 1%;
	z-index: 20;
}	

#wrap_topics .font_year {
	width: 15%;
	text-align: left;
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.06em;
	color: #212121;
	top: 0;
	font-size: 1.1em;
	padding: 1% 0 0 2%;
	position: relative;
}	

#wrap_topics .font_news {
	width: 82%;
	text-align: left;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
	color: #212121;
	letter-spacing: 0.06em;
	line-height: 1.2em;
	top: 0;
	font-size: 1.2em;
	padding: 1% 0 0 4%;
	position: relative;
	
}	
	
	
/*------------  WORKS ------------*/	


#background_topworks {
	width: 100%;
	background-image: url(../images/top_worksbg.webp);
	background-repeat: no-repeat;
	background-size:contain;
	background-color: #091418;
	padding: 0 0 0 0;
	top:0;
	margin-top: -9%;
	margin-bottom: -0.0em;
	position: relative;
	z-index:1;
}	
	

#wrap_works {
	width: 100%;
	display: flex;
	z-index: 40;
	margin-top: -3%;
}
	
#wrap_works .pad_left {
	width: 10%;
}

#wrap_works .pad_right {
	width: 90%;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: 2%;
	margin-bottom: -0.0em;
	border-left: 1.5px #ffffff solid;
	box-sizing: border-box;
	margin-left: -0.0em;
}

#wrap_works .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.06em;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #ffffff;
	top: 0;
	font-size: 2.6em;
	padding: 280% 0 0 7%;
	position: relative;
}	
	

#wrap_worksframe {
	width: 68%;
	background-color: #ffffff;
	position: relative;
	padding:  2% 0 2% 0;
	margin-top: 29%;
	margin-bottom: 9%;
	z-index: 20;
}		
	





.slider-cell {
	margin: 0 20px;
	z-index: 300;
	position: relative;
}

figure {
  	display: flex;
  	flex-flow: column;
  	padding: 5px;
  	max-width: 820px;
  	margin: auto;
	position: relative;
}

figure img {
	position: relative;
  	max-width: 820px;
  	max-height: 950px;
}

figcaption {
  color: #323232;
	font-family: "Sawarabi Mincho"; 
	font-style: normal;
	font-weight: 100;
	color: #323232;
	top: 0;
	font-size: 1.3em;
	letter-spacing: 0.1em;
	padding: 3px;
	text-align: center;
}


.banner_worksbu {
	width: 20%;
 	position: relative;
	border-radius: 3px;
  	padding: 1% 2% 1% 2%;
  	background: rgb(11 28 22 / 0%);
	border: 1px #ffffff solid;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
  	color: #ffffff;
  	line-height: 1.0em;
	font-size:1.2em;
  	text-align: center;
  	transition: .2s;
	margin-bottom: 11%;
}
	
.banner_worksbu::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 9px;
  height: 9px;
  margin: auto;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  transition: .2s;
  box-sizing: border-box;
}	
	
	
.banner_worksbu:hover {
	background: #c7b867;
	transition: background-color .4s;
}	


	
	

/*------------  BAR02 ------------*/	

#bar_top02 {
	position: relative;
	width: 100%;
	height: 210px;
	background-image: url(../images/top_bar02.webp);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center top;
	margin-top: -0.0em;
	padding: -20% 0 0 0;
	margin-top: -1%;
	z-index: 4;
}


#wrap_top_w02 {
	width: 10%;
	height: 100%;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-right: 1.5px #ffffff solid;
	white-space: nowrap;
	z-index: 10;
}
	
	

/*------------  note ------------*/	


#wrap_note {
	width: 100%;
	display: flex;
	z-index: 2;
	margin-top: -0.0em;
}
	

#wrap_note .pad_left {
	width: 10%;
}

#wrap_note .pad_right {
	width: 90%;
	position: relative;
	padding: 5% 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #323232 solid;
	box-sizing: border-box;
	margin-left: -0.0em;
	z-index: 22;
}


#wrap_note .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.06em;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 2.6em;
	padding: 47% 0 0 7%;
	position: relative;
}
	
.inner {
	display: flex;
	justify-content: space-evenly;
	position:relative;
	z-index:10;
}	
	
ul#note {
	width: 88%;
	padding: 0 0 5% 6%;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	display: flex;
}	

ul#note li {
	width:450px;
	height:220px;
	position: relative;
	margin-top: -0.0em;
	margin-left:3%;
	margin-right:3%;
	overflow: hidden;
}
	

ul#note li .title_bu {
	width: 100%;
	font-family: fot-tsukuaoldmin-pr6n, sans-serif;
	font-style: normal;
	font-weight: 400;
	color: #323232;
	top: 0;
	font-size: 2.5em;
	letter-spacing: 0.008rem;
	text-align: left;
	padding: 11% 0 0 7%;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	position: absolute;
	z-index: 15;
}


ul#note li img {
	transition:0.7s all;
}

ul#note li img:hover {
  transform:scale(1.08,1.08);
  transition:0.7s all;
}

	
	
.banner_notebu {
	width: 37%;
 	position: relative;
	border-radius: 3px;
  	padding: 2% 2% 2% 2%;
  	background: rgb(11 28 22 / 0%);
	border: 1px #212121 solid;
	font-family: fot-tsukuaoldmin-pr6n, sans-serif;
	font-style: normal;
	font-weight: 400;
	color: #323232;
	font-size: 1.8em;
	letter-spacing: 0.02em;
  	text-align: center;
  	transition: .2s;
	margin-left: 9%;
	margin-bottom: 11%;
}
	
.banner_notebu::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 9px;
  height: 9px;
  margin: auto;
  border-top: 2px solid #212121;
  border-right: 2px solid #212121;
  transform: rotate(45deg);
  transition: .2s;
  box-sizing: border-box;
}	
	

.banner_notebu:hover {
	background: #c7b867;
	transition: background-color .4s;
}		

	
}
	


	

/*------------ smartPhone  ------------*/	
@media screen and (max-width: 500px) {
/*ここにスマホ用スタイルを記述*/



/*--------- トップ動画  ----------*/

#wrap_header {
	height: 100vh;
}

 
.pad_topvideo {
	overflow:hidden;
	margin-top:-0.0rem; 
	margin-bottom:-0.0rem; 
	height: 100vh;
	top:0;	
}
	
	
#bg_video{
	position: absolute;
	overflow:hidden;
	right: 0;
	bottom: 0;
	min-width: 100%;
	min-height: 100%;
	width: 100%;
	height: 100vh;
	z-index: 0;
	background-color:#ffffff;
	background-size: contain;
}



#header_content {
	position: relative;
	z-index: 2;
	display: flex;
	width: 100%;
	justify-content: center;
	align-items: center;
	text-align:center;
	margin: auto;
	margin-top: -215%;
}


#header_content #wrap_box_w01 {
	width: 	18%;
	height: 102vh;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #ffffff solid;
	box-sizing: border-box;
	margin-left: 82%;
}

#header_content #wrap_box_w01 .pad_title {
	width: 90%;
	position: relative;
	padding: 146% 0 0 0;
	margin-top: 146%;
	margin-bottom: -0.0em;
	box-sizing: border-box;	
}
	


/*------------ スクロール ------------*/	

#scroll {
	position: absolute;
	bottom: 0;
	padding: 0 0 0 50%;
	margin-left: -15px;
	margin-top: -0.0em;
	margin-bottom: 20%;
	z-index: 20;
}
#scroll a {
	top: 0;
	position: relative;
}
#scroll a span {
  position: absolute;
  bottom: 20px;
  left: 50%;
  width: 30px;
  height: 50px;
  margin-left: -15px;
  border: 2px solid #fff;
  border-radius: 50px;
  box-sizing: border-box;
}
#scroll a span::before {
  position: absolute;
  top: 10px;
  left: 50%;
  content: '';
  width: 6px;
  height: 6px;
  margin-left: -3px;
  background-color: #fff;
  border-radius: 100%;
  -webkit-animation: sdb 2s infinite;
  animation: sdb 2s infinite;
  box-sizing: border-box;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    -webkit-transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: translate(0, 0);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    transform: translate(0, 20px);
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}


#scroll a:link {
	color: #ffffff;
	text-decoration:none;
	outline: none;
}

#scroll a:visited {
	color: #ffffff;
	text-decoration: none;
	outline: none;
}

#scroll a:hover {
	color: #ffb2cb;
	text-decoration: underline;
	outline: none;
}

#scroll a:active {
	color: #fed3e1;
	text-decoration: underline;
	outline: none;
}

	
	

/*------------  BAR ------------*/	

#bar_top01 {
	position: relative;
	width: 100%;
	height: 146px;
	background-image: url(../images/top_bar01_smp.webp);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center top;
	margin-top: -0.0em;
	padding: -120% 0 0 0;
	margin-top: 4%;
	z-index: 2;
}


#wrap_top_w01 {
	width:82%;
	height: 100vh;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: -2%;
	margin-bottom: -0.0em;
	border-right: 1.5px #ffffff solid;
	white-space: nowrap;
	z-index: 10;
}
	
	

/*------------ メッセージ------------*/		

#wrap_top_b01 {
	width: 	82%;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-right: 1.5px #000000 solid;
	height: 590px;
	box-sizing: border-box;
	z-index: 10;
}

#wrap_toptitle {
	width: 18%;
	position: relative;
	padding: 0 0 0 0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
}

#wrap_toptitle h2 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.02rem;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 1.4rem;
	padding: 33% 0 0 35%;
	margin-top: 33%;
	position: relative;
	font-display: swap;
}

#wrap_top_b01 .pad_space {
		height: 0.5%;
}
	
#wrap_top_b01 .vertical-text-outer {
	z-index: 40;
}

#wrap_top_b01 .vertical-text-outer .vertical-text-inner {
  	display: inline-block;
  	height: 700px;
  	text-align: justify;
	margin-top: 4%;
	margin-right: 6%;
	margin-bottom: -0.0rem;
}


#wrap_top_b01 .vertical-text-outer .vertical-text-inner p.font_txt {
	font-family:YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
	font-style: normal;
	font-weight: 400;
	color: #212121;
	text-align: left;
	top: 0;
	font-size: 0.8rem;
	letter-spacing: 0.05rem;
	line-height: 1.5rem;
	padding: 0 0 0 0;
	position: relative;
	margin-left: 7.2%;
	z-index: 30;
}
	
.pad_topelememt01 {
	width: 100%;
	padding: 0 0 0 0;
	margin-top: -48%;
	margin-bottom: -0.0em;
	position: relative;
	z-index: 10;
}	
	

/*------------  TOPICS ------------*/	


#wrap_news {
	width: 100%;
	display: flex;
	z-index: 20;
	margin-top: -1%;
}
	

#wrap_news .pad_left {
	width: 18%;
}

#wrap_news .pad_right {
	width: 82%;
	position: relative;
	padding: 18% 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #323232 solid;
	box-sizing: border-box;
	margin-left: -0.0em;
	z-index: 22;
}


#wrap_news .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.02rem;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 1.4rem;
	padding: 55% 0 0 7%;
	position: relative;
}

/*------------  BANNER 01 ------------*/	
	
#box_newsbanner {
	width: 88%;
	border: 1px #989898 solid;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: 5%;
	z-index: 30;
}	
	
#box_newsbanner a {
	position:absolute;
	display: block;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	text-indent: -9999px;
	z-index: 10;
	transition-duration: 0.5s;
} 

#box_newsbanner .icon {
	width: 95%;
	padding: 3% 1% 0 1%;
	top: 0;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
}
#box_newsbanner .bottom {
	width: 93%;
	padding: 2% 2% 0 4%;
	top: 0;
	position: relative;
	margin-top: -4%;
	margin-bottom: -0.0em;
}
	
#box_newsbanner .bottom .txt {
	text-align: left;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
	color: #212121;
	top: 0;
	font-size: 0.9rem;
	letter-spacing: 0.05rem;
	line-height: 1.05rem;
}	


	

	
/*------------  TOPICS ------------*/	
	
#wrap_topics {
	width: 88%;
	border-bottom: 1px #8f8f8f solid;
	position: relative;
	padding:  0 0 5% 0;
	margin-top: 1%;
	margin-bottom: 1%;
	z-index: 20;
}	

#wrap_topics .font_year {
	text-align: left;
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.01rem;
	color: #212121;
	top: 0;
	font-size: 0.76rem;
	padding: 4% 0 2% 2%;
	position: relative;
	margin-top: -0.0rem;
	margin-bottom: -0.0rem;
}	

#wrap_topics .font_news {
	text-align: left;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
	color: #212121;
	letter-spacing: 0.1rem;
	line-height: 1.06rem;
	top: 0;
	font-size: 0.8rem;
	padding: 0 0 0 2%;
	position: relative;
	margin-top: -0.0rem;
	margin-bottom: -0.0rem;
}	
		

/*------------  WORKS ------------*/	


#background_topworks {
	width: 100%;
	background-image: url(../images/top_worksbg.webp);
	background-repeat: no-repeat;
	background-size:contain;
	background-color: #091418;
	padding: 0 0 0 0;
	top:0;
	margin-top: -9%;
	margin-bottom: -0.0em;
	position: relative;
	z-index:1;
}	
	

#wrap_works {
	width: 100%;
	display: flex;
	z-index: 40;
	margin-top: -3%;
}
	
#wrap_works .pad_left {
	width: 18%;
}

#wrap_works .pad_right {
	width: 82%;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: 2%;
	margin-bottom: -0.0em;
	border-left: 1.5px #ffffff solid;
	box-sizing: border-box;
	margin-left: -0.0em;
}

#wrap_works .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.02rem;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #ffffff;
	top: 0;
	font-size: 1.4rem;
	padding: 130% 0 0 7%;
	position: relative;
}	
	

#wrap_worksframe {
	width: 88%;
	background-color: #ffffff;
	position: relative;
	padding:  2% 0 2% 0;
	margin-top: 29%;
	margin-bottom: 9%;
	z-index: 20;
}		
	





.slider-cell {
	margin: 0 20px;
	z-index: 300;
	position: relative;
}

figure {
  	display: flex;
  	flex-flow: column;
  	padding: 5px;
  	max-width: 820px;
  	margin: auto;
	position: relative;
}

figure img {
	position: relative;
  	max-width: 820px;
  	max-height: 950px;
}

figcaption {
  color: #323232;
	font-family:YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";  
	font-style: normal;
	font-weight: 100;
	color: #323232;
	top: 0;
	font-size: 0.72rem;
	letter-spacing: 0.07rem;
	padding: 3px;
	text-align: center;
}


.banner_worksbu {
	width: 45%;
 	position: relative;
	border-radius: 3px;
  	padding: 4% 2% 4% 1%;
  	background: rgb(11 28 22 / 0%);
	border: 1px #ffffff solid;
	font-family: fot-tsukuardgothic-std, sans-serif;
	font-style: normal;
	font-weight: 100;
  	color: #ffffff;
  	line-height: 0.07rem;
	font-size:0.78rem;
  	text-align: center;
  	transition: .2s;
	margin-bottom: 11%;
}
	
.banner_worksbu::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  width: 9px;
  height: 9px;
  margin: auto;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  transition: .2s;
  box-sizing: border-box;
}	
	

/*------------  BAR02 ------------*/	

#bar_top02 {
	position: relative;
	width: 100%;
	height: 170px;
	background-image: url(../images/top_bar02_smp.webp);
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: center top;
	margin-top: -0.0em;
	padding: -20% 0 0 0;
	margin-top: -1%;
	z-index: 4;
}


#wrap_top_w02 {
	width: 18%;
	height: 100%;
	position: relative;
	padding: 0 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-right: 1.5px #ffffff solid;
	white-space: nowrap;
	z-index: 10;
}
	
		


/*------------  NOTE ------------*/	


#wrap_note {
	width: 100%;
	display: flex;
	z-index: 2;
	margin-top: -0.0em;
}
	

#wrap_note .pad_left {
	width: 18%;
}

#wrap_note .pad_right {
	width: 82%;
	position: relative;
	padding: 5% 0 0 0;
	top:0;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
	border-left: 1.5px #323232 solid;
	box-sizing: border-box;
	margin-left: -0.0em;
	z-index: 22;
}


#wrap_note .pad_left h3 {
	font-family: "Montserrat", sans-serif;
	font-style: normal;
	font-weight:300;
	letter-spacing: 0.02rem;
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	color: #212121;
	top: 0;
	font-size: 1.4rem;
	padding: 47% 0 0 7%;
	position: relative;
}
	
ul#note {
	width: 82%;
	padding: 15% 0 5% 0;
	position: relative;
	margin-top: -0.0em;
	margin-bottom: -0.0em;
}	

ul#note li {
	position: relative;
	margin-top: -0.0em;
	padding: 0 0 6% 0;
}
	

ul#note li .title_bu {
	width: 100%;
	font-family: fot-tsukuaoldmin-pr6n, sans-serif;
	font-style: normal;
	font-weight: 400;
	color: #323232;
	top: 0;
	font-size: 1.4rem;
	letter-spacing: 0.008rem;
	text-align: left;
	padding: 11% 0 0 7%;
	margin-top: -0.0rem;
	margin-bottom: -0.0rem;
	position: absolute;
	z-index: 15;
}



	
	
.banner_notebu {
	width: 77%;
 	position: relative;
	border-radius: 3px;
  	padding: 3% 4% 3% 0;
  	background: rgb(11 28 22 / 0%);
	border: 1px #212121 solid;
	font-family: fot-tsukuaoldmin-pr6n, sans-serif;
	font-style: normal;
	font-weight: 400;
	color: #323232;
	font-size: 1.2rem;
	letter-spacing: 0.01rem;
  	text-align: center;
  	transition: .2s;
	margin-left: 9%;
	margin-bottom: 21%;
}
	
.banner_notebu::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 25px;
  width: 9px;
  height: 9px;
  margin: auto;
  border-top: 2px solid #212121;
  border-right: 2px solid #212121;
  transform: rotate(45deg);
  transition: .2s;
  box-sizing: border-box;
}	
	

.banner_notebu:hover {
	background: #c7b867;
	transition: background-color .4s;
}		
	
}	
	
	
.banner_worksbu a:link {
	color: #ffffff;
	text-decoration:none;
	outline: none;
}

.banner_worksbu a:visited {
	color: #ffffff;
	text-decoration: none;
	outline: none;
}

.banner_worksbu a:hover {
	color: #ffffff;
	text-decoration: none;
	outline: none;
}

.banner_worksbu a:active {
	color: #ffffff;
	text-decoration: none;
	outline: none;
}
