@charset "UTF-8";
/* CSS Document */


/*--------------------------------------------------


    INDEX PAGE
	

---------------------------------------------------*/

#main{
	width:100%;
	position:relative;
	overflow:hidden;
	margin-top: 80px;
	z-index: -1;
}

.Opening_text{
	position: absolute;
	top:30%;
	left: 30%;
	transform: translate(-30%, -30%);
	-webkit-transform:translate(-30%, -30%);
	z-index: 9;
	white-space: nowrap;
}

.Opening_text p{
	font-size:60px;
	margin-bottom:15px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	line-height:1.3;
	letter-spacing: 5px;
}

.Opening_text span{
	font-size:20px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 200;
	letter-spacing: 5px;
}


@media screen and (max-width: 1099px) {
#main{
	margin-top: 50px;
}
}

@media screen and (max-width: 768px) {
.Opening_text{
  width:90%;
}

.Opening_text p{
	font-size:24px;
	margin-bottom:15px;
}

.Opening_text span{
	font-size:14px;
}
}


/* メインビジュアル
=========================================*/

/*-- Pick UP Swiper --*/
.swiper-container.swiper1{
	width: 100%;
	height:auto;
}

.swiper-container.swiper1 .swiper-wrapper{
	height: auto !important;
}

.swiper-container.swiper1 img{
	width: 100%;
	height:auto;
}



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

.topics{
	width:1100px;
	min-height: 300px;
	margin: 0 auto;
	position: relative;
	background-color: #FFFFFF;
	margin-top: -30px;
}

.topics h2{
	display:block;
	color:#1B4499;
	font-size:20px;
	transform-origin: 0 0;
	transform:rotate(90deg);
	position: absolute;
	top: 60px;
	left: 75px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 200;
	letter-spacing: 3px;
	padding-bottom: 10px;
}

.topics h2:before {
  content: '';
  position: absolute;
  left: 25px;
  bottom: -10px;
  display: inline-block;
  width: 45px;
  height: 6px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #1B4499;
}

.topics dl{
	position:absolute;
	width: 940px;
	top: 60px;
	right: 30px;
}

.topics dl dt{
	color:#FFFFFF;
	float: left;
	font-size: 12px;
	text-align: center;
	width: 120px;
	height: 18px;
	line-height: 18px;
}

.topics dl dt.topics-red{
	background-color: #ED675A;
}

.topics dl dt.topics-sky{
	background-color: #8DBDD3;
}

.topics dl dt.topics-blue{
	background-color: #00699C;
}

.topics dl dt.topics-gray{
	background-color: #AFAFAF;
}

.topics dl dt:after {
	content: "";
    clear: both;
	display: block;
}

.topics dl dd{
	margin-left: 140px;
	margin-bottom:1em;
}

.topics dl dd a{
	color:#204380;
}

.topics dl dd a:hover{
	text-decoration:underline;
}

.topics-list{
	position: absolute;
	top: 15px;
	right: 30px;
	display: block;
	color: #1B4499;
	width: 100px;
	height: 25px;
	line-height: 25px;
	text-align: center;
	border: 1px #1B4499 solid;
}

.topics-list:hover{
	color: #FFFFFF;
	background-color: #1B4499;
	text-decoration: none;
}

@media screen and (max-width: 1099px) {
.topics{
	width:96%;
	margin-top: -30px;
}

.topics h2{
	top: 15%;
	left: 7%;
	padding-bottom: 10px;
	transform-origin: 0 0;
	transform:rotate(90deg);
}

.topics dl{
	width: 85%;
	top: 15%;
	right: 0%;
	left: 10%;
}

.topics dl dt{
	width: 15%;
}

.topics dl dd{
	margin-left: 17%;
}

.topics-list{
	top: 5%;
	right: 3%;
	width: 10%;
}
}


@media screen and (max-width: 768px) {
.topics{
	width:90%;
	margin:0 auto;
	padding:15px 0;
}

.topics h2{
	position:static;
	font-size:16px;
	margin-bottom:10px;
	transform:none;
}

.topics dl{
	position: static;
	width: 100%;
	top: 0;
	right: 0;
}

.topics dl dt{
	width:30%;
	float:none;
	margin-bottom: 5px;
}

.topics dl dd{
	margin-left:0;
}
	
.topics-list{
	position:static;
	top: 0;
	right: 0;
	width: 100%;
	height: 40px;
	line-height: 40px;
}
}




/*INDEX CONTENT  -----------------------------------------------*/
.index-cont{
	width: 1440px;
	height:auto;
	margin: 0 auto;
	display: flex;
	flex-wrap:wrap;
	justify-content: space-between;
}

.index-cont > div{
	background-color: #000000;
	position: relative;
	overflow: hidden;
}

.index-cont > div:nth-child(1),
.index-cont > div:nth-child(3),
.index-cont > div:nth-child(5){
	margin-right: 30px;
}

.index-cont > div:nth-child(n+1):nth-child(-n+4){
	margin-bottom: 30px;
}

.index-cont a{
	display: block;
}

.index-cont a .bg{
	opacity: 0.5;
	overflow: hidden;
}

.index-cont a .bg img{
	display: block;
	width: 100%;
}

.index-cont a:hover .bg{
	opacity: 1;
	-webkit-transition: all .8s;
	transition: all .8s;
}

.index-cont a p{
	position: absolute;
	top:50px;
	left: 50%;
	transform: translate(-50%, 0);
	-webkit-transform:translate(-50%, 0);
	color: #FFFFFF;
	font-size: 28px;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	line-height: 1.3;
	letter-spacing: 3px;
	-webkit-filter: drop-shadow(1px 1px 3px rgba(0,0,0,0.5));
	filter: drop-shadow(1px 1px 3px #000000);
}

.index-cont a p span{
	display: block;
	font-size: 14px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 200;
	letter-spacing: 1px;
}

.whats-btn{
	width: 730px;
}

.pick-products-box{
	background-color: #FFFFFF !important;
	width: 680px;
	max-height: 790px;
}

.pickup-btn{
	position: relative;
	background-color: #000000;
	margin-bottom: 30px;
}


/*-- Pick UP Swiper --*/
.swiper-container.swiper2{
	width: 680px;
	height:auto;
}

.swiper-container.swiper2 .swiper-wrapper{
	height: auto !important;
}

.swiper-container.swiper2 img{
	width: 100%;
	height:auto;
}
/*-- END Swiper --*/

.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 20px !important;
}

.products-btn{
	position: relative;
	background-color: #000000;
	max-height: 380px;
}

.movie-btn{
	width: 460px;
}

.recipe-btn{
	width: 950px;
}

.corporate-btn{
	width: 950px;
}

.recruit-btn{
	width: 460px;
}


.more-btn{
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%, 0%);
	-webkit-transform:translate(-50%, 0%);
	width: 150px;
	height: 45px;
	line-height: 45px;
	background-color: #FFFFFF;
	text-align: center;
	color: #1B4499;
	font-family: 'Noto Serif JP', serif;
	font-weight: 200;
	letter-spacing: 1px;
}

.more-btn:before {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 0px;
  display: inline-block;
  width: 110px;
  height: 5px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: #1B4499;
}


/*BANNER*/
.banner-box{
	width: 100%;
	display: flex;
	justify-content: center;
	background-color: #FFFFFF !important;
	margin: 90px 0;
}

.banner-box a{
	width: 325px;
}

.banner-box a + a{
	margin-left: 45px;
}

.banner-box a img{
	display: block;
	width: 100%;
	height: auto;
}

.banner-box a:hover{
	opacity: 0.5;
	-webkit-transition: all .3s;
	transition: all .3s;
}



@media screen and (max-width: 1499px) {
.index-cont{
	width:96%;
	height:auto;
}
	
.index-cont > div:nth-child(1),
.index-cont > div:nth-child(3),
.index-cont > div:nth-child(5){
	margin-right: 0 !important;
}
	
.index-cont > div:nth-child(n+1):nth-child(-n+4){
	margin-bottom: 2.5% !important;
}
	
.whats-btn{
	width: 51%;
}
	
.pick-products-box{
	width: 47%;
}
	
.pickup-btn{
	width: 100%;
	margin-bottom: 6%;
}
	
.swiper-container.swiper2{
   width: 100%;
}

.products-btn{
	width: 100%;
}

.movie-btn{
	width: 32%;
}

.recipe-btn{
	width: 66%;
}

.corporate-btn{
	width: 66%;
}

.recruit-btn{
	width: 32%;
}
	
.banner-box{
	margin: 5% 0 !important;
}
	
.banner-box a:nth-child(n+1):nth-child(-n+3){
	margin-right: 2.5% !important;
}
}




@media screen and (max-width: 768px) {
.index-cont{
	height:auto;
	min-height:auto;
	background:none;
}
	
.index-cont > div:nth-child(1),
.index-cont > div:nth-child(3),
.index-cont > div:nth-child(5){
	margin-right: 0px;
}
	
.index-cont > div:nth-child(n+1):nth-child(-n+4){
	margin-bottom: 0%;
}

.index-cont > div{
	margin-bottom: 15px !important;
}

.index-cont a p{
	position: absolute;
	top:50px;
	left: 50%;
	transform: translate(-50%, 0);
	-webkit-transform:translate(-50%, 0);
	font-size: 18px;
	-ms-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	letter-spacing: 0px;
	text-align: center;
}

.index-cont a p span{
	font-size: 12px;
	letter-spacing: 0px;
}

.whats-btn,
.products-btn,
.movie-btn,
.recipe-btn,
.corporate-btn,
.recruit-btn{
	width: 100%;
	height: 200px;
	overflow: hidden;
}
	
.pick-products-box{
	width: 100%;
}

.pickup-btn{
	width: 100%;
}


/*-- Pick UP Swiper --*/
.swiper-container.swiper2{
	width: 100%;
}
/*-- END Swiper --*/

.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 20px !important;
}

.more-btn{
	width: 50%;
	letter-spacing: 0px;
	height: 35px;
	line-height: 35px;
}


/*BANNER*/
.banner-box{
	width: 100%;
	display: block;
	margin: 0 auto !important;
}
	
.banner-box a{
	width: 100%;
}

.banner-box a + a{
	margin-left: 0;
	margin-top: 10px;
}
	
.banner-box a:nth-child(n+1):nth-child(-n+3){
	margin-right: 0% !important;
}
}

