@charset "utf-8";

main video {
	width: 100%;
	pointer-events: none;
}

.mTit02 {
	font-size: 4.6rem;
}

@media screen and (max-width: 1080px) {
    .mTit02 {
        font-size: 3vw;
    }
}

@media screen and (max-width: 768px) {
    .mTit02 {
        font-size: min(6vw, 4.6rem);
    }
}

/* mv */
.mv {
	position: relative;
	overflow: hidden;
}

.mv .videoWrap {
	position: relative;
	line-height: 0;
}

.mv .videoWrap::before {
	content: '';
	display: block;
	height: calc(100vh - 80px);
}

.mv .videoWrap::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 50%;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0));
	z-index: 1;
}


.mv .videoWrap video {
	position: absolute;
	top: 50%;
	left: 50%;
	width: auto;
	height: auto;
	min-width: 100%;
	min-height: 100%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
}

.mv img {
	width: 100%;
	line-height: 0;
}

.mv .mvLogo {
	position: fixed;
	z-index: 5;
	top: 100px;
	left: 20px;
	width: 11%;
	max-width: 202px;
}

.mv .mvTxt {
	position: absolute;
	left: 5%;	
	bottom: 8%;
	color: #fff;
	text-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
	z-index: 2;
}

.mv .mvTxt .mTit {
	line-height: 1.4;
	margin-bottom: 2rem;
	transition-delay: 1s;
}

.mv .mvTxt .mTit span {
	transition-delay: 1s;
}

.mv .mvTxt p {
	font-size: 1.8rem;
	transition: opacity 2s;
	opacity: 0;
}

.mv.is-show .mvTxt p {
	opacity: 1;
}

.mv.first-load .mvTxt .mTit,
.mv.first-load .mvTxt .mTit span {
	transition-delay: 4s !important;
}
.mv.first-load .mvTxt p {
	transition-delay: 1.5s;
}

@media screen and (max-width: 1080px) {
	.mv .mvTxt .mTit {
		font-size: 3vw;
	}

	.mv .mvTxt p {
		margin: 2rem 0 0;
		font-size: 1.8vw;
	}
}

@media screen and (max-width: 768px) {
	.mv .mvTxt .mTit {
		font-size: min(7vw, 5.6rem);
	}

	.mv .mvTxt p {
		margin: 1rem 0 0;
		font-size: min(4vw,  2.4rem);
	}

	.mv .mvLogo {
		top: 80px;
		left: 10px;
		width: 110px;
	}

	.mv .videoWrap::before {
		height: 70vh;
	}

	.mv .videoWrap::after {
		content: '';
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
	}

	.mv .videoWrap video {
		position: absolute;
		width: auto;
		height: 100%;
		top: 50%;
		left: 50%;
		transform: translate(-50%,-50%);
		min-width: unset;
		min-height: unset;
	}

	.mv .mvTxt {
		bottom: 10%;
	}
}




/* contents */
.contents {
	position: relative;
	padding: 8% 0;
	color: #fff;
}

.contents img {
	width: 100%;
}

.contents div[id^="box"] {
	position: relative;
	z-index: 2;
}

.contents .btnMore {
    width: 200px;
    height: 48px;
    border-radius: 60px;
    justify-content: center;
    align-items: center;
    margin: 2rem 0 0;
    background: #ffffff;
    color: #000000;
    transition: all 0.3s;
    font-family: "Roboto", sans-serif !important;
}

.contents .btnMore:hover {
    background: #D0B782;
}

.author {
	font-size: 2.4rem;
	line-height: 1.6;
	margin-top: 1rem;
}

.boxTxt {
	color: #fff;
}

.commonTxt {
	margin-top: 3rem;
}

@media screen and (max-width: 1400px) {

}

@media screen and (max-width: 768px) {
	.contents {
		padding: 6rem 0;
	}

	.contents::after {
		display: none;
	}

	.contents .btnMore {
		height: 40px;
		font-size: 1.4rem;
	}

	.author {
		font-size: min(4vw, 2.4rem);
		margin: 0.5rem 0 0;
	}

	.commonTxt {
		margin-top: 1rem;
	}	
}


/* box01 */
#box01 {
	align-items: center;
}

#box01 .img {
	width: 43%;
}

#box01 .boxTxt {
	width: 50%;
}

@media screen and (max-width: 768px) {
	#box01 {
		display: block;
	}

	#box01 .img {
		width: 95%;
		margin-bottom: 3rem;
	}

	#box01 .boxTxt {
		padding: 0 30px;
		width: 100%;
	}
}

/* box02 */
#box02 {
	margin: 8% 0;
}

#box02 .container {
	position: relative;
}

#box02 .boxTxt {
	position: absolute;
	top: 10%;
	left: 10%;
}

@media screen and (max-width: 768px) {
	#box02 {
		margin: 6rem 0 12rem;
	}

	#box02 .img {
		position: relative;
		height: 34vh;
		min-height: 400px;
	}

	#box02 .img::before {
		content: '';
		display: block;
		width: 100%;
		padding-bottom: 80%;
	}

	#box02 .img video {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		-webkit-transform: translate(-50%, -50%);
		width: 130%;
	}

	#box02 .boxTxt {
		top: 50%;
		transform: translateY(-50%);
		-webkit-transform: translateY(-50%);
		left: 0;
		right: 0;
		margin: 0 auto;
		padding: 0 5vw;
	}
}

/* box03 */
#box03 {
	align-items: center;
}

#box03 .img {
	width: 49%;
	order: 2;
	margin-right: -8%;
}

#box03 .boxTxt {
	order: 1;
	width: 50%;
	margin-top: 2%;
}

#box03 .boxTxt .video {
	width: 67%;
	margin: 10% -10% 0 auto;
}

@media screen and (max-width: 768px) {
	#box03 {
		position: relative;
	}

	#box03 .img {
		width: 40%;
		order: 1;
		margin: 0 0 0 auto;
	}

	#box03 .boxTxt {
		margin: -20vw auto 0;
		order: 2;
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	#box03 .boxTxt .gr {
		order: 2;
	}

	#box03 .boxTxt .video {
		order: 1;
		width: 55%;
		margin: 0 auto 2rem 0;
	}

}

/* box04 */
#box04 {
	margin: 8% 0;
}

#box04 .container {
	position: relative;
}

#box04 .backTxt {
	font-size: 20rem;
	color: #2A2A2A;
	margin: 0 0 5% -15%;
	line-height: 1;
}

#box04 .backTxt span {
	position: relative;
  display: inline-block;
	opacity: 0; 
	transform: matrix(1, 0, 0, 1, 150, 0); 
	transition: .6s;
}

#box04 .backTxt.is-view span {
	opacity: 1; 
	transform: matrix(1, 0, 0, 1, 0, 0);
} 

#box04 .img01 {
	position: relative;
	z-index: 4;
	width: 50%;
	margin: 0 0 0 -15%;
	
}

#box04 .img02 {
	position: relative;
	z-index: 3;
	margin: -20px 0 0 0;	
}

#box04 .img02:before {
	content: '';
	display: block;
	width: 100%;
	padding-bottom: 43%;
}

#box04 .img02 video {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
}


#box04 .mTit02 {
	margin: 0 0 2rem;
}

#box04 .boxTxt {
	position: absolute;
	z-index: 5;
	top: 6%;
	left: 50%;
	width: 50%;
	margin: 0;
}

#box04 .boxTxt .flexBox p {
	width: 60%;
}

#box04 .boxTxt .flexBox .logo-haccp {
	width: 33%;
}

#box04 .boxTxt .flexBox .logo-haccp a {
	transition: all 0.3s;
}

#box04 .boxTxt .flexBox .logo-haccp a:hover {
	opacity: 0.8;
}

#box04 .boxTxt .flexBox .logo-haccp img {
	width: 100%;
}

#box04 .time {
	margin-top: 6rem;
}

@media screen and (max-width: 1366px) {
	#box04 .backTxt {
		font-size: 9vw;
		margin: 0 0 5% -15px;
	}

	#box04 .img01 {
		margin: 0 0 0 -15px;
	}

	#box04 .boxTxt {
		top: 0;
		left: 54%;
	}

	#box04 .boxTxt .flexBox p {
		width: 100%;
	}

	#box04 .boxTxt .flexBox .logo-haccp {
		max-width: 180px;
		margin: 2rem 0 0 0;
		width: 50%;
	}
}

@media screen and (max-width: 768px) {
	#box04 {
		margin: 6rem 0;
	}

	#box04 .img01 {
		width: 65%;
		margin: 0 auto 0 -30px;
	}

	#box04 .img02 {
		width: 100%;
		margin: -3vw 0 0 auto;
		background: #000;
	}

	#box04 .img02 video {
		width: calc(100% + 4px);
	}

	#box04 .backTxt {
		font-size: min(13vw, 6rem);
		margin: 0 0 2rem;
	}

	#box04 .boxTxt {
		position: static;
		width: 100%;
		margin-top: 2rem;
	}

}

/* box05 */
#box05 {
	background: #ffffff;
	padding: 4% 0;
	color: #000;
}

#box05 .container {
	max-width: 900px;
}

#box05 .mTit02 {
	text-align: center;
	margin: 0 0 4rem;
}

#box05 .cLogo {
	width: 36%;
}

#box05 .commonTxt {
	width: 58%;
	margin-top: 0;
}

@media screen and (max-width: 768px) {
	#box05 {
		padding: 4rem 0;
	}

	#box05 .container {
		position: relative;
	}

	#box05 .mTit02 {
		width: 69%;
		margin-bottom: 2rem;
		text-align: left;
	}

	#box05 .commonTxt {
		width: 100%;
	}

	#box05 .cLogo {
		position: absolute;
		top: 0;
		right: 0;
	}

}


/* box06 */
#box06 {
	margin: 8% 0 0;
}

#box06 .list01 {
	text-align: center;
}

#box06 .list01 .item {
	width: 30%;
}

#box06 .list01 .item .video {
	line-height: 1;
}

#box06 .list01 .item video {
	width: 100%;
}

#box06 .list01 .itemTit {
	line-height: 1.6;
	margin: 1.5rem 0;
	font-size: 2.4rem;
}

#box06 .list01 .btnMore {
	width: 140px;
	margin: 0 auto;
	font-size: min(3.5vw, 1.4rem);
}

#box06 .list01 .item a:hover .btnMore {
	background: #D0B782;
}

#box06 .list02 {
	margin-top: 10rem;
}

#box06 .list02 li {
	width: 46%;
}

#box06 .list02 a {
	position: relative;
	display: block;
}

#box06 .list02 a .inner {
	width: 100%;
	text-align: center;
	position: absolute;  
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%); 
	-webkit-transform: translate(-50%, -50%);
}

#box06 .list02 a .itemTit {
	font-size: 3.6rem;
	line-height: 1;
	margin-bottom: 2rem;
}

#box06 .list02 a .btnMore {
	margin: 0 auto;
	width: 165px;
	height: 32px;
	background: #111111;
	color: #fff;
	font-size: 1.4rem;
	transition: all 0.3s;
}

#box06 .list02 a:hover .btnMore {
	background: #D0B782;
}

@media screen and (max-width: 1400px) {
	#box06 .list01 .itemTit {
		font-size: 1.6rem;
	}

	#box06 .list02 a .itemTit {
		font-size: 2rem;
	}
}

@media screen and (max-width: 768px) {
	#box06 {
		margin: 4rem 0 0;
	}

	#box06 .list01 .item {
		width: 100%;
		margin-bottom: 2rem;
	}

	#box06 .list01 .item:last-child {
		margin-bottom: 0;
	}

	#box06 .list01 .itemTit {
		font-size: min(3.5vw, 2.4rem);
		line-height: 1.4;
	}

	#box06 .list02 {
		margin-top: 4rem;
	}

	#box06 .list02 li {
		width: 100%;
		margin-bottom: 2rem;
	}

	#box06 .list02 li:last-child {
		margin-bottom: 0;
	}

	#box06 .list02 li img {
		min-height: 150px;
		object-fit: cover;
		object-position: center;
	}

	#box06 .list02 a .itemTit {
		font-size: min(6vw, 3rem);
		margin-bottom: 2rem;
	}
}


/* Loading */
.no-scroll {
    overflow: hidden !important;
    position: fixed; 
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

#loading {
	background: #111111;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 999;
}

#loading p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 9999;
	width: 280px;
}

@media screen and (max-width: 768px) {
	#loading p {
		width: 36%;
		max-width: 150px;
	}

	#loading p img {
		width: 100%;
	}
}
/* End Loading */


@media screen and (max-width: 768px) {

	.slick-dots {
		margin-top: 30px;
	}

	.slick-arrow {
		top: 35px;
	}

	.slick-next {
		right: calc(50% - 670px);
	}

	.slick-prev {
		left: calc(50% - 670px);
	}

	.partner-slide a:hover {
		opacity: .8;
	}

	.slick-slide {
		width: 50vw;
		margin: 0 3vw;
		overflow: hidden;
		line-height: 1;
		background: #111111;
	}

	.slick-slide img {
		width: 100%;
	}

	.slick-arrow {
		top: calc(11.75vw - 18px);
	}

	.slick-next {
		right: calc(15vw - 40px);
	}

	.slick-prev {
		left: calc(15vw - 40px);
	}
}


/* Modal */
.fancybox-bg {
	/*background: #000;*/
}

.fancybox-is-open .fancybox-bg {
	opacity: 0.95
}

.fancybox-content {
	max-width: 640px;
	width: 95%;
	padding: 0;
	background: transparent;
}

.fancybox-button {
	width: 28px;
	height: 28px;
}

.fancybox-button svg path {
	fill: black;
}

.fancybox-slide--html .fancybox-close-small {
	background: #ffffff;
	border-radius: 50%;
	right: 1rem;
	top: 1rem;
	opacity: 1;
	padding: 5px;
}

@media (max-width: 768px) {

	.fancybox-button {
		width: 30px;
		height: 30px;
	}

	.fancybox-content {
		padding: 6rem 2rem 4rem;
	}

	.fancybox-slide--html .fancybox-close-small {
		top: 1rem;
		right: 1rem;
	}
}

.modal {
	display: none;
}

.modal-inner {
	align-items: stretch;
	/*max-height: 50vh;*/
	/*overflow: scroll;*/
}

.modal-inner .colL {
	width: 41%;
}

.modal-inner .colR {
	background: #000;
	width: 57%;
	padding: 30px;
	align-items: center;
	justify-content: center;
	border: 1px solid #ffffff;
}

@media (max-width: 768px) {
	.modal-inner .colR p {
		font-size: min(3vw, 1.4rem);		
	}

	.modal-inner .colR {
		padding: 3vw;
	}
}
/* End Modal */