@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-pagination-bullet {
	width: 8px;
	height: 8px;
	display: inline-block;
	border-radius: 100%;
	background: #fff;
	opacity: .2;
}

.swiper-pagination-bullet-active {
    opacity: 1;
    background: #007aff;
}

/* ------------------------------------------------ */
section#episode {
	padding: 42px 0 60px;
	background: url("../images/ep_bg_line.png") 50% 0 repeat-y;
}

section#episode.xmas {
	margin-bottom: 100px;
	padding: 42px 0 0;
}

section#episode .epItem {
	margin-bottom: 76px;
}

section#episode .epTitle {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
}

section#episode .epTitle .icon {
	width: calc(50% - 0.5px);
	text-align: right;
}

section#episode .epTitle .icon img {
	width: 133px;
	max-width: 26.6%;
	height: auto;
}

/* X'mas ver */
section#episode #episode_xmas .epTitle .icon img {
	width: 260px;
	max-width: 52%;
}

section#episode .epTitle h2 {
	width: calc(50% - 0.5px);
	text-align: left;
}

section#episode .epTitle h2 img {
	width: 380px;
	max-width: 76%;
	height: auto;
}

/* X'mas ver */
section#episode #episode_xmas .epTitle h2 img {
	width: 400px;
	max-width: 80%;
}


section#episode .storyBox {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
}

section#episode .storyBox .image {
	width: calc(50% - 0.5px);
}
section#episode .storyBox .text {
	width: calc(50% - 0.5px);
}

section#episode .storyBox img {
	width: 100%;
	height: auto;
}

section#episode #episode_xmas .storyBox .text {
	background: url("../images/xmas_text_bg.png") center center no-repeat;
	background-size: cover;
}
section#episode #episode01 .storyBox .text {
	background: url("../images/ep1_text_bg.png") center center no-repeat;
	background-size: cover;
}
section#episode #episode02 .storyBox .text {
	background: url("../images/ep2_text_bg.png") center center no-repeat;
	background-size: cover;
}
section#episode #episode03 .storyBox .text {
	background: url("../images/ep3_text_bg.png") center center no-repeat;
	background-size: cover;
}

section#episode #episode_xmas .epTitle {
	flex-flow: row-reverse nowrap;
}

section#episode #episode_xmas .epTitle .icon {
	text-align: left;
}
section#episode #episode_xmas .epTitle h2 {
	text-align: right;
}

section#episode #episode_xmas .storyBox {
	flex-flow: row-reverse nowrap;
}

section#episode #episode02 .epTitle {
	flex-flow: row-reverse nowrap;
}

section#episode #episode02 .epTitle .icon {
	text-align: left;
}
section#episode #episode02 .epTitle h2 {
	text-align: right;
}

section#episode #episode02 .storyBox {
	flex-flow: row-reverse nowrap;
}

section#episode .epEnd {
	width: 100%;
	max-width: calc(649px + 10%);
	margin: 0 auto;
	padding: 0 5%;
}

section#episode .epEnd .continued {
	width: calc(50% - 0.5px);
	margin-left: auto;
}

section#episode .epEnd .continued.ep1 {
	background: #ffdf49;
}
section#episode .epEnd .continued.ep2 {
	background: #439fe5;
}

section#episode #episode_xmas + .epEnd {
	margin-bottom: 92px;
}

/* ------------------------------------------------ */

section#present {
	position: relative;
	margin-top: 9.5%;
	margin-bottom: 60px;
	background: #dbe7ec; /* Old browsers */
	background: -webkit-linear-gradient(#dbe7ec 0%, #dbe7ec 16%, #d4e1e6 26%, #c5d4da 41%, #b0c2c9 58%, #92a8b0 72%, #829aa3 83%, #78919b 86%, #718995 89%, #6c8391 94%, #6c8391 100%);
	background: -o-linear-gradient(#dbe7ec 0%, #dbe7ec 16%, #d4e1e6 26%, #c5d4da 41%, #b0c2c9 58%, #92a8b0 72%, #829aa3 83%, #78919b 86%, #718995 89%, #6c8391 94%, #6c8391 100%);
	background: linear-gradient(#dbe7ec 0%, #dbe7ec 16%, #d4e1e6 26%, #c5d4da 41%, #b0c2c9 58%, #92a8b0 72%, #829aa3 83%, #78919b 86%, #718995 89%, #6c8391 94%, #6c8391 100%);
}

section#present.closed::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.75);
}

section#present .closeMsg {
	position: absolute;
	top: 150px;
	left: 50%;
	display: block;
	width: 90%;
	max-width: 640px;
	padding: 2em 0;
	background-color: rgba(0,0,0,0.7);
	font-size: 2.6rem;
	color: #ffffff;
	z-index: 1;
	transform: translate(-50%,0);
	text-align: center;
}

section#present h2 {
	position: absolute;
	top: 0;
	left: 50%;
	width: 19.4%;
	margin-top: -9.7%;
	transform: translateX(-50%);
	z-index: 1;
}

section#present .secInr {
	padding-top: 12.6%;
	padding-bottom: 3.6%;
}

section#present h3 {
	margin: 0 0 2%;
}

@media (min-width: 1000px) {
section#present {
	margin-top: 95px;
}

section#present h2 {
	width: 194px;
	margin-top: -97px;
}

section#present .secInr {
	padding-top: 126px;
	padding-bottom: 36px;
}

section#present h3 {
	margin: 0 0 20px;
}
}

section#present .info {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;
	padding: 0 1% 0 1.3%;
	line-height: 1.5;
}

section#present .info p.about {
	width: 73.592%;
	font-size: 2.1vw;
}

@media (min-width: 1000px) {
section#present .info p.about {
	font-size: 2.1rem;
}
}

section#present .info p.closing {
	width: 26.408%;
}

section#present .hotelList {
	display: flex;
	flex-flow: row nowrap;
	justify-content: space-between;
	margin: 22px 0 10px;
}

section#present .hotelList ul {
	width: calc((100% - 10px) / 2);
}

section#present .hotelList li + li {
	margin-top: 10px;
}

section#present .hotelList + p {
	line-height: 1.5;
	font-size: 1.3rem;
	color: #ffffff;
}

section#present p span {
	display: inline-block;
	margin-right: .5em;
}
/* ------------------------------------------------ */
section#youtube {
	padding-top: 60px;
}

section#youtube .secInr {
	text-align: center;
}

section#youtube .secInr a img {
	border: 1px solid #cccccc;
}

section#youtube .secInr ul {
	display: flex;
	flex-flow: row nowrap;
	justify-content: center;
}

section#youtube .secInr ul li {
	 flex-basis: 47%;
	 max-width: 47%;
	 text-align: left;
}

section#youtube .secInr ul li + li {
	margin-left: 6%;
}

section#youtube .secInr ul li > a {
	display: block;
	margin-top: 1em;
	font-size: 1.4rem;
}

.movieBox {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.movieBox iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
	border: 0;
}
/* ================================================ */

@media (max-width: 640px) {

/* ------------------------------------------------ */
section#episode {
	padding: 28px 0 40px;
}

section#episode.xmas {
	margin-bottom: 68px;
	padding: 28px 0 0;
}

section#episode .epItem {
	margin-bottom: 52px;
}

section#episode .epTitle .icon img {
	max-width: 35%;
}

section#episode #episode_xmas .epTitle .icon img {
	max-width: 64.999%;
}

section#episode .epTitle h2 img,
section#episode #episode_xmas .epTitle h2 img {
	max-width: 100%;
}

section#episode .storyBox {
	display: block;
}

section#episode .storyBox .image {
	width: 100%;
}
section#episode .storyBox .text {
	width: 100%;
}

section#episode #episode_xmas + .epEnd {
	margin-bottom: 72px;
}

/* ------------------------------------------------ */
section#present {
	margin-bottom: 40px;
}

section#present h3 {
	margin: 0 0 2%;
}

section#present .info {
	display: block;
}

section#present .info p.about {
	width: 100%;
	margin-bottom: 1em;
	text-align: center;
	font-size: 2.8vw;
}

section#present .info p.closing {
	width: 100%;
	text-align: center;
}

section#present .info p.closing img {
	width: 180px;
	height: auto;
}

section#present .hotelList {
	display: block;
	margin: 22px 0 10px;
}

section#present .hotelList ul {
	width: 100%;
}

section#present .hotelList ul + ul {
	margin-top: 10px;
}

section#present .hotelList li {
	text-align: center;
}

section#present .hotelList li + li {
	margin-top: 10px;
}

section#present .hotelList + p {
	font-size: 1.2rem;
}
/* ------------------------------------------------ */
section#youtube {
	padding-top: 40px;
}

section#youtube .secInr ul {
	display: block;
}

section#youtube .secInr ul li {
	 width: 100%;
	 max-width: 100%;
	 text-align: center;
}

section#youtube .secInr ul li + li {
	margin-left: 0;
	margin-top: 32px;
}

}

/* ================================================ */

@media (max-width: 413px) {
}
