@charset 'utf-8';

/*---------------------------------------------------------------------- */
/* Top Styles
------------------------------------------------------------------------ */

/* Utillities
---------------------------------------------------------- */

/* Magnific Popup --------------------------------- */

.mfp-bg {
	background: #000;
	opacity: .7;
}

.mfp-close {
	display: none;
	position: fixed;
	padding: 0;
	line-height: 60px;
	opacity: 1;
}

.mfp-close:hover,
.mfp-close:focus {
	opacity: .7;
}

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
	top: 50px;
	right: 50px;
	padding-right: 0;
	width: 60px;
	height: 60px;
	background: url(../images/btn-close.png) no-repeat right top;
	text-indent: -9999px;
	text-align: left;
}

.mfp-counter {
	display: none;
}

.mfp-arrow:active {
	margin-top: 0;
}

.mfp-arrow:hover,
.mfp-arrow:focus {
	opacity: .7;
}

.mfp-arrow:before,
.mfp-arrow:after {
	display: none;
}

.mfp-iframe-holder {
	padding: 20px;
}

.mfp-iframe-holder .mfp-content {
	max-width: 1200px;
}

/* Main image in popup */
img.mfp-img {
	padding: 40px;
}

.mfp-figure:after {
	display: none;
}

/**
* Simple fade transition,
*/
.mfp-fade.mfp-bg.mfp-ready {
	opacity: .7;
}

/* Section --------------------------------- */

.section,
.block {
	box-sizing: border-box;
}


/* Layout
---------------------------------------------------------- */

/* Base --------------------------------- */

#header {
	margin-bottom: 60px;
}

/* #main --------------------------------- */

/* #main-visual */

#main-visual {
	position: relative;
	margin: 0 auto 90px auto;
	width: 1200px;
	height: 1514px;
}

#main-visual .bg,
#main-visual .shadow,
#main-visual .title,
#main-visual .catch,
#main-visual .touch,
#main-visual .chara,
#main-visual .tamotsu,
#main-visual .niwaka,
#main-visual .arisa,
#main-visual .matome,
#main-visual .video-thumb,
#main-visual .video-title {
	position: absolute;
	opacity: 0;
}

#main-visual .bg {
	transition: all 300ms linear;
}

#main-visual .shadow,
#main-visual .title,
#main-visual .catch,
#main-visual .touch,
#main-visual .chara,
#main-visual .video-thumb,
#main-visual .video-title {
	transition: all 300ms linear 2500ms;
}

#main-visual .tamotsu,
#main-visual .niwaka,
#main-visual .arisa,
#main-visual .matome {
	transition: all 1000ms cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

#main-visual .tamotsu { -webkit-transform: translate3d(0, -100px, 0); transform: translate3d(0, -100px, 0); }
#main-visual .niwaka { -webkit-transform: translate3d(0, 100px, 0); transform: translate3d(0, 100px, 0); }
#main-visual .arisa { -webkit-transform: translate3d(100px, 100px, 0); transform: translate3d(100px, 100px, 0); }
#main-visual .matome { -webkit-transform: translate3d(-100px, 100px, 0); transform: translate3d(-100px, 100px, 0); }

#main-visual.active .bg,
#main-visual.active .shadow,
#main-visual.active .title,
#main-visual.active .catch,
#main-visual.active .touch,
#main-visual.active .chara,
#main-visual.active .video-thumb,
#main-visual.active .video-title {
	opacity: 1;
}

#main-visual.active .tamotsu,
#main-visual.active .niwaka,
#main-visual.active .arisa,
#main-visual.active .matome {
	opacity: 1;
	-webkit-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}

#main-visual.active .tamotsu { transition-delay: 400ms; }
#main-visual.active .niwaka { transition-delay: 800ms; }
#main-visual.active .arisa { transition-delay: 1200ms; }
#main-visual.active .matome { transition-delay: 1600ms; }

#main-visual .chara,
#main-visual .tamotsu,
#main-visual .niwaka,
#main-visual .arisa,
#main-visual .matome {
	background-position: left top;
	background-repeat: no-repeat;
}

#main-visual .bg {
	top: 82px;
	left: 0;
}

#main-visual .shadow {
	bottom: 0;
	left: 88px;
}

#main-visual .title {
	top: 0;
	left: 21px;
}

#main-visual .catch {
	top: 87px;
	right: 0;
}

#main-visual .touch {
	top: 1184px;
	left: 3px;
}

#main-visual .chara {
	top: 214px;
	left: 100px;
	width: 938px;
	height: 289px;
}

#main-visual .tamotsu {
	top: 170px;
	left: 479px;
	width: 307px;
	height: 996px;
}

#main-visual .niwaka {
	top: 424px;
	left: 445px;
	width: 344px;
	height: 997px;
}

#main-visual .arisa {
	top: 287px;
	left: 610px;
	width: 517px;
	height: 1143px;
}

#main-visual .matome {
	top: 240px;
	left: 72px;
	width: 646px;
	height: 1268px;
}

#main-visual .video-thumb {
	top: 1262px;
	left: 834px;
}

#main-visual .video-thumb a {
	display: block;
}

#main-visual .video-title {
	top: 1488px;
	left: 838px;
}

#main-visual .chara img,
#main-visual .tamotsu img,
#main-visual .niwaka img,
#main-visual .arisa img,
#main-visual .matome img {
	position: absolute;
	top: 0;
	left: 0;
	transition: opacity 300ms linear; 
}

#main-visual img.off {
	opacity: 1;
}

#main-visual img.on {
	opacity: 0;
}

#main-visual.on  img.off {
	opacity: 0;
}

#main-visual.on img.on {
	opacity: 1;
}

/* #main-content */

#main-content {
	display: flex;
	flex-flow: row wrap;
	justify-content: space-between;
}

/* #section-news, #section-twitter */

#section-news,
#section-twitter {
	margin-bottom: 80px;
	padding: 25px 30px;
	width: 580px;
	height: 437px;
	border: 5px solid #000;
	background: #fff;
	overflow: hidden;
}

#section-news .section-header,
#section-twitter .section-header {
	position: relative;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 4px solid #000;
}

#section-news .section-header {
	margin-bottom: 0;
}

#section-news .section-content ul li {
	display: flex;
	flex-flow: row nowrap;
	padding: 14px 0;
	border-top: 2px solid #ededed;
	box-sizing: border-box;
	font-size: 2.2rem;
}

#section-news .section-content ul li:first-child {
	border-top: 0;
}

#section-news .section-content ul li .date,
#section-news .section-content ul li .title {
	display: block;
}

#section-news .section-content ul li .date {
	width: 145px;
}

#section-news .section-content ul li .title {
	width: 366px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

#section-twitter .section-header .btn-follow {
	display: block;
	position: absolute;
	top: 0;
	right: 0;
}

#section-twitter .section-header .btn-follow iframe {
	width: 110px;
	height: 28px;
}

#section-twitter .widget-twitter {
	width: 100%;
	height: 300px;
}

/* #banner */

#banner {
	margin: 0 auto 0 auto;
	width: 1040px;
}

#banner ul {
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	margin: 0 -40px -40px 0;
}

#banner ul li {
	margin: 0 40px 40px 0;
	width: 500px;
}

