@charset "utf-8";

section {
	display: block;
	width: 100%;
	padding: 0 5%;
}

.secInr {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

/* ------------------------------------------------ */
.swiper-slide > img {
	width: 100%;
}

.swiper-slide.slide02 {
	background-color: #FFFFFF;
}

.swiper-slide.slide02 p {
	position: absolute;
	left: 50%;
}

.swiper-slide.slide02 p.episode {
	width: 20.526%;
	top: 25.8%;
	transform: translateX(-50%);
}

@keyframes episode-num {
	from {
		opacity: 0;
		transform: translate(-50%, 100%);
	}

	to {
 		opacity: 1;
		transform: translate(-50%, 0);
	}
}

.swiper-slide.slide02.swiper-slide-active p.episode {
	animation-name: episode-num;
	animation-duration: 1.2s;
	animation-delay: .5s;
	animation-fill-mode: both;
}

.swiper-slide.slide02 p.title {
	width: 28.947%;
	top: 52.4%;
	transform: translateX(-50%);
}

@keyframes episode-title {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

.swiper-slide.slide02.swiper-slide-active p.title {
	animation-name: episode-title;
	animation-duration: 1s;
	animation-delay: 1.6s;
	animation-fill-mode: both;
}

#slider-ep01 .swiper-slide.slide03 {
	background: url(../images/slider_ep1_02.png) center center no-repeat;
	background-size: cover;
}

#slider-ep02 .swiper-slide.slide03 {
	background: url(../images/slider_ep2_02.png) center center no-repeat;
	background-size: cover;
}

#slider-ep03 .swiper-slide.slide03 {
	background: url(../images/slider_ep3_02.png) center center no-repeat;
	background-size: cover;
}

.swiper-slide.slide03 p {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
}

.swiper-slide.slide03 p.text01 img,
.swiper-slide.slide03 p.text02 img,
.swiper-slide.slide03 p.text03 img {
	-webkit-mask-size: 0 100%;
	-webkit-mask-image: url(../images/slider_mask.png);
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-position: 0 0;
	mask-image: url(../images/slider_mask.png);
	mask-repeat: no-repeat;
	mask-position: 0 0;
	mask-size: 0 100%;
}

@keyframes episode-text {
	from {
		-webkit-mask-size: 0 100%;
		mask-size: 0 100%;
	}
	to {
		-webkit-mask-size: 100% 100%;
		mask-size: 100% 100%;
	}
}

.swiper-slide.slide03.swiper-slide-active p.text01 img {
	animation-name: episode-text;
	animation-duration: 1.5s;
	animation-delay: 2.0s;
	animation-fill-mode: both;
}

.swiper-slide.slide03.swiper-slide-active p.text02 img {
	animation-name: episode-text;
	animation-duration: 2.5s;
	animation-delay: 3.0s;
	animation-fill-mode: both;
}

.swiper-slide.slide03.swiper-slide-active p.text03 img {
	animation-name: episode-text;
	animation-duration: 1.5s;
	animation-delay: 3.8s;
	animation-fill-mode: both;
}

.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	display: inline-block;
	border-radius: 100%;
	background: #fff;
	opacity: .2;
}

.swiper-pagination-bullet-active {
	opacity: 1;
	background: #F5F5EB;
}

/* ------------------------------------------------ */
section#episode {
	padding: 72px 0 60px;
	background-color: #F5F5EB;
}

section#episode .epItem {
	margin-bottom: 18px;
}

section#episode .epTitle {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: flex-start;
	margin: 0 0 -5.52%;
}

section#episode .epTitle .icon {
	width: 38.596%;
	text-align: right;
	padding: 0 2.46% 1.05% 0;
	mix-blend-mode: multiply;
}

section#episode .epTitle .icon img {
	width: 55.582%;
	height: auto;
}

section#episode .epTitle h2 {
	width: 61.404%;
	text-align: left;
	padding: 0 0 1.93% 0;
}

section#episode .epTitle h2 img {
	width: 46.571%;
	height: auto;
}

section#episode .storyBox {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
}

section#episode .storyBox .image {
	width: 61.404%;
}
section#episode .storyBox .text {
	width: 38.596%;
	padding: 5.702% 0 0;
}

section#episode .storyBox img {
	width: 100%;
	height: auto;
}
section#episode .storyBox .image img {
	box-shadow: 2px 4px 4px rgba(0,0,0,.3);
}

section#episode #episode01 {
	background: url("../images/ep1_story_bg.png") center bottom no-repeat;
	background-size: 100% auto;
}
section#episode #episode02 {
	background: url("../images/ep2_story_bg.png") center bottom no-repeat;
	background-size: 100% auto;
}
section#episode #episode03 {
	background: url("../images/ep3_story_bg.png") center bottom no-repeat;
	background-size: 100% auto;
}

section#episode #episode01 .storyBox {
	flex-flow: row-reverse nowrap;
}

section#episode #episode02 .epTitle {
	flex-flow: row-reverse nowrap;
}

section#episode #episode02 .epTitle .icon {
	text-align: left;
	padding: 0 0 1.05% 2.46%;
}
section#episode #episode02 .epTitle h2 {
	text-align: right;
}

section#episode #episode03 .storyBox {
	flex-flow: row-reverse nowrap;
}

section#episode .epItem + figure {
	width: 81.14%;
	margin: 0 auto 12%;
}

section#episode .epItem + figure:last-of-type {
	margin-bottom: 28px;
}

section#episode .secInr {
	text-align: center;
}

@media (min-width: 1000px) {
section#episode .epItem + figure {
	margin: 0 auto 120px;
}
}

/* ------------------------------------------------ */
section#present {
	position: relative;
	margin-bottom: 60px;
	padding-top: 3.6%;
	padding-bottom: 6.5%;
	background: #302700 url("../images/present_bg.png") center bottom no-repeat;
	background-size: contain;
}

/* CLOSED */
section#present.closed::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.6);
}

section#present .closeMsg {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 60.3%;
	max-width: 603px;
	z-index: 1;
	transform: translate(-50%,-50%);
}

section#present .presentTitle {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto -2%;
}

section#present .presentTitle h2 {
	order: 1;
}
section#present .presentTitle p {
	order: 3;
}
section#present .presentTitle .badge {
	order: 2;
}

section#present .secInr {
	padding: 20px 20px 16px;
	background-color: #FFFFFF;
}

@media (min-width: 1000px) {
section#present {
	padding-top: 36px;
	padding-bottom: 65px;
}

section#present .closeMsg {
	width: 100%;
	max-width: 603px;
}
}

section#present p.about {
	padding: 0 0 0 0.7%;
	line-height: 1.5;
	font-size: 2.2vw;
	color: #595757;
}

section#present p.about strong {
	font-size: 2.5vw;
	font-weight: 700;
	color: #ff0000;
}

@media (min-width: 1000px) {
section#present p.about {
	font-size: 2.2rem;
}

section#present p.about strong {
	font-size: 2.5rem;
}
}

section#present .presentList {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	margin: 1.563% 0 0;
}

section#present .presentList li {
	width: 32.708%;
}

section#present .presentList li:nth-of-type(2) {
	width: 34.584%;
	border-left: 1px solid #707070;
	border-right: 1px solid #707070;	
}

section#present .btn {
	margin: 3.438% 0 3.125%;
	text-align: center;
}

section#present p.note {
	line-height: 1.5;
	font-size: 1.3rem;
}

section#present p.note span {
	display: inline-block;
}

/* ------------------------------------------------ */
section#youtube {
	padding-top: 60px;
}

section#youtube .secInr {
	text-align: center;
}

/* ================================================ */

@media (max-width: 640px) {

/* ------------------------------------------------ */
section#episode {
	padding: 48px 0 42px;
}

section#episode .epItem {
	margin-bottom: 12px;
}

section#episode .epTitle {
	margin: 0;
	align-items: center;
	justify-content: flex-start;
}

section#episode .epTitle .icon {
	width: 26%;
	padding: 0 2.46% 1.05%;
}

section#episode .epTitle .icon img {
	width: 100%;
}

section#episode .epTitle h2 {
	width: 74%;
	padding: 0 0 1.93% 0;
}

section#episode .epTitle h2 img {
	width: 68%;
}

section#episode .storyBox {
	display: block;
}

section#episode .storyBox .image {
	width: 100%;
}
section#episode .storyBox .text {
	width: 100%;
	padding: 0 2.5%;
}

section#episode #episode01 {
	background: url("../images/ep1_story_bg.png") left bottom no-repeat;
	background-size: auto 70%;
}
section#episode #episode02 {
	background: url("../images/ep2_story_bg.png") right bottom no-repeat;
	background-size: auto 70%;
}
section#episode #episode03 {
	background: url("../images/ep3_story_bg.png") left bottom no-repeat;
	background-size: auto 74%;
}

section#episode .epItem + figure {
	width: 90%;
}

section#episode #episode02 .epTitle {
	flex-flow: row nowrap;
}

section#episode #episode02 .epTitle .icon {
	text-align: right;
	padding: 0 2.46% 1.05%;
}
section#episode #episode02 .epTitle h2 {
	text-align: left;
}


/* ------------------------------------------------ */
section#present {
	margin-bottom: 40px;
}

section#present .closeMsg {
	top: 12%;
	width: 80%;
	transform: translate(-50%,0);
}


section#present .presentTitle {
	display: block;
	margin: 0 auto -3%;
	text-align: center;
}

section#present .presentTitle h2 {
	margin-bottom: 12px;
}

section#present .presentTitle p {
	margin-bottom: 18px;
}

section#present p.about {
	font-size: 3.2vw;
}

section#present p.about strong {
	font-size: 3.6vw;
}

section#present .presentList {
	display: block;
	text-align: center;
}

section#present .presentList li {
	width: 100%;
	padding: 20px;
}

section#present .presentList li:nth-of-type(2) {
	width: 100%;
	border-top: 1px solid #707070;
	border-bottom: 1px solid #707070;	
	border-left: none;
	border-right: none;	
}


/* ------------------------------------------------ */
section#youtube {
	padding-top: 40px;
}
}

/* ================================================ */

@media (max-width: 413px) {
}
