
/* ===========================================
Top
=============================================*/
#top {
	background:#000 no-repeat center center fixed;
	background-size:cover;
}
#topBg {
	background:url(../img/top/block_loop.jpg) center center no-repeat;
	background-size:cover;
	position:fixed;
	top:50%;
	left:50%;
	transform:translate(-50%,-50%);
}
#videoBg {
	/*display:none;*/
	position:fixed;
	top:50%;
	left:50%;
	transform:translate(-50%,-50%);
}
#intro {
	width: 100%;
	height: 100%;
	background: #FFF;
	position: fixed;
	display: none;
}

#intro .scene {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	display: none;
}

#intro .scene h2 {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

#intro .scene h2 img {
	width: 100%;
}

#wrapper {
	position:relative;
	display: none;
}

#main {
	padding: 0;
}

#header {
	display: none;
}

#footer {
	color: #FFF;
	background: rgba(0,0,0,1);
	border-top: none;
}

#feature {
	width: 100%;
	height: 100vh;
	background:#fff;
	box-sizing: border-box;
	position: relative;
}

#feature ul {
	width: 100%;
	height: 100%;
	position: relative;
}

#feature ul li {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	opacity:0;
	overflow: hidden;
	display: none;
}
#feature .feature-1 {
	opacity:1;
}
/*#feature .feature-1 video {
	display:none;
}*/
#feature .feature-1 .bg {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	display: none;
	background:#000 no-repeat center center;
	background-size:cover;
}

#feature .featured,
#feature .program {
	background: #000;
}

#feature .featured a,
#feature .program a {
	display: block;
	opacity: 1;
}

#feature .featured a:hover .bg,
#feature .featured a:active .bg,
#feature .program a:hover .bg,
#feature .program a:active .bg {
	/* opacity: 0.8; */
}

#feature .featured .bg,
#feature .program .blur,
#feature .program .bg {
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
}

#feature .program .bg {
	background-size: contain;
}

#feature .movie {
	background: #000;
}

#feature .movie .player-wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

#feature .featured .title,
#feature .program .title,
#feature .movie .title {
	width: 100%;
	color: #FFF;
	position: absolute;
	bottom: -100%;
	left: 0;
	background-color: rgba(0,0,0,0.7);
	box-sizing: border-box;
}

#feature .featured .title h3,
#feature .program .title h3,
#feature .movie .title h3 {
	font-weight: normal;
}

#feature .program .title p.time,
#feature .program .title p.place {
	position: relative;
}

#feature .program .title p.time:before {
	background-image: url("../img/common/icon_calendar_w.svg");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

#feature .program .title p.place:before {
	background-image: url("../img/common/icon_access_w.svg");
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 0;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

#feature .program .title p.category span {
	background: #FFF;
	color: #000;
	font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
	display: inline-block;
}

#feature .program .title p.place {
	font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
}

#feature .movie iframe {
	width: 100% !important;
	height: 100% !important;
}

#feature .timeline {
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 0;
	overflow: hidden;
	z-index: 999;
	display: none;
}

#feature .timeline .bar {
	background: rgba(50,50,50,1.0);
	position: absolute;
	left: 0;
	top: 0;
}

#news {
	width: 100%;
	background: #FFF;
	border-bottom: 1px solid #d2d2d2;
	position: relative;
}

#news ul li {
	display: none;
}

#information {
	width: 100%;
	background: #FFF;
	position: relative;
	overflow: hidden;
}

#information .main-menu li {
	box-sizing: border-box;
	position: relative;
}

#information .main-menu li a {
	width: 100%;
	height: 100%;
	display: inline-block;
}

#information .main-menu li a:hover span,
#information .main-menu li a:active span {
	/* text-decoration: underline; */
}

#information .main-menu li i {
	display: block;
	position: absolute;
	left: 50%;
	-webkit-transform: translate(-50%,0);
	transform: translate(-50%, 0);
}

#information .main-menu li i img {
	width: 100%;
}

#information .main-menu li span {
	width: 100%;
	position: absolute;
	display: block;
}

#information .sub-menu li i {
	display: block;
	background: #000;
	border-radius: 50%;
	position: relative;
	-webkit-transition: 0.25s ease-in-out;
	transition: 0.25s ease-in-out;
}

#information .sub-menu li a:hover i,
#information .sub-menu li a:active i  {
	background: rgba(0,0,0,0.5);
	opacity: 1;
	-webkit-transition: 0.25s ease-in-out;
	transition: 0.25s ease-in-out;
}

#information .sub-menu li a:hover i img,
#information .sub-menu li a:active i img  {
	opacity: 1;
}

#information .sub-menu li i img {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate( -50% , -50% );
	transform: translate( -50% , -50% );
}

#wrapper .contents-block {
	width: 100%;
	background: #FFF;
	position: relative;
}

#wrapper .contents-block h2 {
	font-weight: normal;
	text-align: center;
}

#wrapper .contents-block .contents-menu {
	text-align: center;
}

#wrapper .contents-block .contents-menu li {
	white-space: nowrap;
	display: inline-block;
	position: relative;
}

#wrapper .contents-block .btn-more {
	text-align: center;
}

#wrapper .contents-block .btn-more a {
	text-align: center;
	border-bottom: 1px solid #000;
	margin-left: auto;
	margin-right: auto;
	display: inline-block;
	position: relative;
}

#wrapper .contents-block .btn-more a {
	text-decoration: none;
}

#wrapper .contents-block .btn-more a:hover {
	border-bottom: 1px solid rgba(0,0,0,0);
	opacity: 1;
}

#artist .artist-list li .img img {
	width: 100%;
	height: auto;
}

#artist .artist-list li .name .main,
#artist .artist-list li .name .sub {
	width: 100%;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	padding: 2px 0;
}

#artist .artist-list li a:hover p,
#artist .artist-list li a:active p {
	/* text-decoration: underline; */
}

#program p.date {
	text-align: center;
}

#program p.date span {
	background: #000;
	color: #FFF;
	display: inline-block;
}

#program .program-list li a {
	display: block;
}

#program .program-list li .img img {
	width: 100%;
	height: auto;
}

#program .program-list > li {
	border-top: 1px solid #d2d2d2;
	position: relative;
}

#program .program-list > li .img {
	float: left;
}

#program .program-list > li .data {
	float: right;
}

#program .program-list > li .data .category span {
	font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
	color: #FFF;
	background: #000;
	display: inline-block;
}

#program .program-list > li .data .category span.ticket {
	background: #FFF;
	color: #000;
	border: 1px solid #000;
	position: relative;
}

#program .program-list > li .data .category span.ticket:before {
	content: "";
	background: url("../img/common/icon_ticket.svg") no-repeat center center;
	display: block;
	position: absolute;
	top: 50%;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

#program .program-list > li .data .detail li {
	font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
	position: relative;
}

#program .program-list > li .data .detail > li:before {
	content: "";
	/* font-family: FontAwesome; */
	background-repeat: no-repeat;
	background-position: center center;
	text-align: center;
	display: block;
	position: absolute;
	top: 50%;
	left: 0;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
}

#program .program-list > li .data .detail > li:first-child:before {
	/* content: "\f183"; */
	background-image: url("../img/common/icon_human.svg");
}

#program .program-list > li .data .detail > li:nth-child(2):before {
	/* content: "\f041"; */
	background-image: url("../img/common/icon_map.svg");
}

#program .program-list > li .data .detail > li:nth-child(3):before {
	/* content: "\f073"; */
	background-image: url("../img/common/icon_calendar.svg");
}

#program .program-list > li .data .detail > li .supplement {
	background: #000;
	color: #FFF;
	white-space: nowrap;
	display: inline-block;
}

#instagram .instagram-list li {
	display: inline-block;
	vertical-align: middle;
}

#instagram .instagram-list li img {
	width: 100%;
}

#sns .sns-list {
	text-align: center;
}

#sns .sns-list li {
	display: inline-block;
}

#sns .sns-list li .icon {
	position: relative;
	border: 1px solid #d2d2d2;
	border-radius: 50%;
	-webkit-transition: 0.25s ease-in-out;
	transition: 0.25s ease-in-out;
}

#sns .sns-list li a:hover .icon,
#sns .sns-list li a:active .icon {
	background: #000;
	color: #FFF;
}

#sns .sns-list li a .icon .fa {
	-webkit-transition-duration: 0;
	transition-duration: 0;
	-webkit-transition: none;
	transition: none;
	opacity: 1;
}


/* ===========================================
PC
=============================================*/

@media screen and (min-width:960px) {

	#intro .scene-1 h2 {
		width: 37.5%;
		/* min-width: 540px; */
	}

	#intro .scene-2 h2 {
		width: 14.305%;
		/* min-width: 206px; */
	}

	#wrapper{
		/*background-image: url("../img/top/bg_pc.jpg");
		background-size: 1440px;
		background:#000;*/
	}

	#wrapper {
		padding: 0;
	}

	#footer {
/*		padding-top: 324px;*/
	}

	#feature {
		min-height: 576px;
		padding-top: 64px;
	}

	#feature .feature-1 {
		height: calc( 100% + 64px );
		margin-top: -64px;
	}

	#feature .feature-1 .bg video {
		position: absolute;
		left: 50%;
		top: 50%;
		z-index: 1;
		-webkit-transform: translate(-50%,-50%);
		transform: translate(-50%,-50%);
	}

	#feature .feature-2 {
		background:url(../img/top/Y_logo_motion_pc.jpg) no-repeat center center;
		background-size:cover;
	}

	#feature .featured .title,
	#feature .program .title,
	#feature .movie .title {
		padding: 50px 4%;
	}

	#feature .featured .title h3,
	#feature .program .title h3,
	#feature .movie .title h3 {
		font-size: 2.4rem;
		line-height: 1.5;
	}

	#feature .featured .title p,
	#feature .movie .title p {
		font-size: 1.2rem;
		margin-top: 8px;
	}

	#feature .program .title p.today {
		font-size: 2.0rem;
		line-height: 24px;
		float: left;
	}

	#feature .program .title p.time {
		font-size: 2.4rem;
		line-height: 24px;
		padding-left: 30px;
		margin-left: 30px;
		float: left;
	}

	#feature .program .title p.time:before {
		width: 21px;
		height: 21px;
	}

	#feature .program .title p.category {
		float: left;
		margin-top: 24px;
		margin-right: 10px;
	}

	#feature .program .title p.category span {
		font-size: 1.2rem;
		padding: 6px 16px;
		margin-right: 5px;
	}

	#feature .program .title h3 {
		float: left;
		margin-top: 18px;
	}

	#feature .program .title p.place {
		font-size: 1.6rem;
		padding-left: 26px;
		margin-top: 30px;
	}

	#feature .program .title p.place:before {
		width: 17px;
		height: 24px;
	}

	#feature .timeline {
		background: rgba(209,209,209,0.5);
	}

	#feature .timeline,
	#feature .timeline .bar {
		height: 4px;
	}

	#news {
		height: 55px;
		font-size: 1.4rem;
		line-height: 55px;
	}

	#news .inner {
		max-width: 1440px;
		margin: 0 auto;
	}

	#news ul {
		height: 55px;
		margin: 0 140px 0 32px;
		position: relative;
		box-sizing: border-box;
	}

	#news ul li {
		width: 100%;
		overflow: hidden;
		white-space: nowrap;
		text-overflow: ellipsis;
		position: absolute;
		top: 0;
		left: 0;
	}

	#news ul li .date {
		margin-right: 40px;
	}

	#news .btn-list a {
		padding-right: 21px;
		position: absolute;
		top: 0;
		right: 24px;
		display: block;
	}

	#news .btn-list a:after {
		content: "";
		display: block;
		position: absolute;
		top: 21px;
		right: 3px;
		width: 10px;
		height: 10px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#information .inner {
		max-width: 1440px;
		margin: 0 auto;
	}

	#information .title {
		margin-top: 60px;
		position: relative;
	}

	#information .title .main {
		text-align: center;
	}

	#information .title .main h2 {
		font-size: 5.2rem;
		font-weight: normal;
	}

	.en #information .title .main h2 {
		font-size: 3.6rem;
		line-height: 1.2;
	}

	#information .title .main h3.en {
		font-size: 2.6rem;
		font-weight: normal;
		margin-top: 22px;
	}

	.en #information .title .main h3.en {
		font-size: 2.4rem;
	}

	#information .title .main h3.jp {
		font-size: 1.4rem;
		font-weight: normal;
		margin-top: 8px;
	}

	#information .title .catch {
		font-size: 1.8rem;
		position: absolute;
		top: 50%;
		left: 4.6875%;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}
	#information .title .catch img {
		width:135px;
	}

	.en #information .title .catch {
		font-size: 1.4rem;
		line-height: 1.714;
	}

	#information .title .logo {
		position: absolute;
		top: 50%;
		right: 4.6875%;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#information .title .logo img {
		width: 108px;
		height: auto;
	}

	#information .term,
	#information .venue {
		width: 43.75%;
	}

	#information .term {
		margin: 60px 0 0 4.6875%;
		float: left;
	}

	#information .venue {
		margin: 60px 4.6875% 0 0;
		float: right;
	}

	#information .term h4,
	#information .venue h4 {
		font-size: 1.8rem;
		font-weight: normal;
	}

	#information .term h5,
	#information .venue h5 {
		font-size: 2.8rem;
		font-weight: normal;
		letter-spacing: -0.025em;
		margin-top: 16px;
	}

	#information .term p,
	#information .venue p {
		font-size: 1.8rem;
		line-height: 1.666;
		margin-top: 18px;
	}

	#information .main-menu {
		text-align: center;
		margin-top: 56px;
		margin-bottom: 62px;
	}

	#information .main-menu li {
		width: 21.4%;
		height: 104px;
		border-right: 1px solid #d2d2d2;
		font-size: 1.8rem;
		display: inline-block;
		margin: 0 0.8%;
	}

	#information .main-menu li:last-child {
		border-right: none;
	}

	#information .main-menu li.info i {
		width: 14px;
		top: 11px;
	}

	#information .main-menu li.ticket i {
		width: 54px;
		top: 5px;
	}

	#information .main-menu li.access i {
		width: 34px;
		top: 8px;
	}

	#information .main-menu li.schedule i {
		width: 52px;
		top: 12px;
	}

	#information .main-menu li span {
		bottom: 4px;
	}

	#information .sub-menu {
		width: 90.625%;
		text-align: center;
		margin: 62px auto;
	}

	#information .sub-menu li {
		font-size: 1.4rem;
		margin: 0 1.724%;
		display: inline-block;
	}

	#information .sub-menu li i {
		width: 80px;
		height: 80px;
		margin: 0 auto 16px auto;
	}

	#information .sub-menu li:first-child i img {
		width: 32px;
		margin-left: 2px;
	}

	#information .sub-menu li:nth-child(2) i img {
		width: 34px;
		margin-top: -3px;
	}

	#wrapper .contents-block {
		margin-top: 326px;
		padding: 80px 0;
	}

	#wrapper .contents-block .inner {
		max-width: 1440px;
		margin: 0 auto;
	}

	#wrapper .contents-block h2 {
		font-size: 4.8rem;
	}

	#wrapper .contents-block .contents-menu {
		margin-top: 40px;
	}

	#wrapper .contents-block .contents-menu li {
		font-size: 1.6rem;
		line-height: 2;
		margin: 0 22px;
	}

	#wrapper .contents-block .contents-menu li a {
		padding-right: 21px;
		display: block;
	}

	#wrapper .contents-block .contents-menu li a:after {
		content: "";
		display: block;
		position: absolute;
		top: 9px;
		right: 3px;
		width: 10px;
		height: 10px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#wrapper .contents-block .btn-more {
		font-size: 2.4rem;
		margin-top: 80px;
	}

	#wrapper .contents-block .btn-more a {
		padding: 0 26px 8px 0;
	}

	#wrapper .contents-block .btn-more a:after {
		content: "";
		display: block;
		position: absolute;
		top: 5px;
		right: 3px;
		width: 13px;
		height: 13px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#artist .artist-list {
		width: 90.625%;
		margin: 0 auto;
	}

	#artist .artist-list li {
		width: 31%;
		margin: 58px 3.448% 0 0;
		float: left;
		position: relative;
	}

	#artist .artist-list li:nth-child(3n) {
		margin: 58px 0 0 0;
	}

	#artist .artist-list li .img {
		width: 33.3%;
	}

	#artist .artist-list li .name {
		width: 100%;
		padding-left: 38.8%;
		box-sizing: border-box;
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#artist .artist-list li .name .main {
		font-size: 1.4rem;
	}

	#artist .artist-list li .name .sub {
		font-size: 1.2rem;
		font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
		margin-top: 4px;
	}

	#program p.date {
		margin-top: 20px;
	}

	#program p.date span {
		font-size: 2.4rem;
		padding: 10px 20px;
	}

	#program .program-list {
		width: 90.625%;
		margin: 30px auto 0 auto;
	}

	#program .program-list > li {
		width: 48.275%;
		margin-right: 3.448%;
		float: left;
	}

	#program .program-list > li a {
		padding: 48px 0;
	}

	#program .program-list > li:nth-child(even) {
		margin-right: 0;
	}

	#program .program-list > li:nth-child(-n+2) {
		border-top: none;
	}

	#program .program-list > li:nth-last-child(-n+2) a {
		padding-bottom: 0;
	}

	#program .program-list > li .img {
		width: 28.57%;
	}

	#program .program-list > li .data {
		width: 64.28%;
	}

	#program .program-list > li .data .category span {
		font-size: 1.2rem;
		padding: 6px 16px;
		margin-right: 6px;
	}

	#program .program-list > li .data .category span.ticket {
		padding-left: 34px;
	}

	#program  .program-list > li .data .category span.ticket:before {
		width: 17px;
		height: 18px;
		background-size: 17px 18px;
		left: 9px;
	}

	#program .program-list > li .data h3 {
		font-size: 2.4rem;
		font-weight: normal;
		line-height: 1.333;
		margin-top: 16px;
	}

	#program .program-list > li .data .detail li {
		font-size: 1.2rem;
		line-height: 1.5;
		margin-top: 20px;
		padding-left: 34px;
	}

	#program .program-list > li .data .detail li:nth-child(3) {
		line-height: 2;
	}

	#program .program-list > li .data .detail > li:before {
		width: 18px;
	}

	#program .program-list > li .data .detail > li:first-child:before {
		/* font-size: 2.0rem; */
		width: 21px;
		height: 24px;
		background-image: url("../img/common/icon_human.svg");
		background-size: 21px 24px;
	}

	#program .program-list > li .data .detail > li:nth-child(2):before {
		/* font-size: 2.0rem; */
		width: 21px;
		height: 24px;
		background-image: url("../img/common/icon_access.svg");
		background-size: 17px 24px;
	}

	#program .program-list > li .data .detail > li:nth-child(3):before {
		/* font-size: 1.8rem; */
		width: 21px;
		height: 21px;
		background-image: url("../img/common/icon_calendar.svg");
		background-size: 21px 21px;
	}

	#program .program-list > li .data .detail > li .supplement {
		font-size: 1.0rem;
		line-height: 1;
		padding: 5px 5px 4px 5px;
		-webkit-transform: translate(0, -1px);
		transform: translate(0, -1px);
	}

	#instagram .instagram-list {
		width: 90.062%;
		margin: 42px auto 0 auto;
	}

	#instagram .instagram-list li {
		width: calc( 20% - 25.6px );
		margin: 32px 32px 0 0;
	}

	#instagram .instagram-list li:nth-child(5n) {
		margin: 32px 0 0 0;
	}

	#sns .sns-list {
		margin: 60px 0 0 0;
	}

	#sns .sns-list li {
		margin: 0 32px;
	}

	#sns .sns-list li .icon {
		width: 100px;
		height: 100px;
		font-size: 4.4rem;
		line-height: 100px;
	}

	#sns .sns-list li p {
		font-size: 1.6rem;
		margin-top: 14px;
	}

}

@media screen and (min-width:1440px) {
	/*#wrapper {
		background-size: 100%;
	}*/
}


/* ===========================================
SP
=============================================*/

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

	#intro .scene-1 h2 {
		width: 72%;
		max-width: 270px;
	}

	#intro .scene-2 h2 {
		width: 27.466%;
		max-width: 103px;
	}

	/*#wrapper::before {
		content: "";
		z-index: -1;
		background-image: url("../img/top/bg_sp.jpg");
		background-size: 100%;
		background-repeat: repeat-y;
		background-position: center bottom;
		background-color:#000;
		display: block;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}

	#wrapper {
		background-size: 100%;
	}*/

	#footer {
		padding-top: 38px;
	}

	#feature {
		min-height: 320px;
		padding-top: 56px;
	}

	#feature.open {
		height: calc( 100vw + 56px );
		-webkit-transition: 1.0s ease;
		transition: 1.0s ease;
	}

	#feature .feature-1 {
		height: calc( 100% + 56px );
		margin-top: -56px;
	}
	#feature .feature-1 .bg video {
		position: absolute;
		padding-top: 56px;
		left: 50%;
		top: 50%;
		z-index: 1;
		-webkit-transform: translate(-50%,-50%);
		transform: translate(-50%,-50%);
	}

	#feature .feature-2 {
		background:url(../img/top/Y_logo_motion_sp.jpg) no-repeat center center;
		background-size:cover;
	}

	#feature .featured .title,
	#feature .program .title,
	#feature .movie .title {
		padding: 20px 5%;
	}

	#feature .featured .title h3,
	#feature .program .title h3,
	#feature .movie .title h3 {
		font-size: 1.8rem;
		line-height: 1.5;
	}

	#feature .featured .title p,
	#feature .movie .title p {
		font-size: 1.4rem;
		margin-top: 12px;
	}

	#feature .program .title p.today {
		font-size: 1.3rem;
		float: left;
	}

	#feature .program .title p.time {
		font-size: 1.3rem;
		padding-left: 20px;
		margin-left: 23px;
		float: left;
	}

	#feature .program .title p.time:before {
		width: 16px;
		height: 16px;
	}

	#feature .program .title p.category {
		position: absolute;
		top: 20px;
		right: 5%;
	}

	#feature .program .title p.category span {
		font-size: 1.0rem;
		padding: 5px 10px;
		margin-left: 5px;
	}

	#feature .program .title h3 {
		margin-top: 20px;
	}

	#feature .program .title p.place {
		font-size: 1.2rem;
		padding-left: 16px;
		margin-top: 20px;
	}

	#feature .program .title p.place:before {
		width: 10px;
		height: 14px;
	}

	#feature.open .feature-1 h2 {
		-webkit-transform: translate(-50%, -43%);
		transform: translate(-50%, -43%);
		-webkit-transition: 1.0s ease;
		transition: 1.0s ease;
	}

	#feature.open.end,
	#feature.open.end .feature-1 h2 {
		-webkit-transition-duration: 0;
		transition-duration: 0;
		-webkit-transition: none;
		transition: none;
	}

	#feature .timeline {
		background: rgba(158,158,158,1.0);
	}

	#feature .timeline,
	#feature .timeline .bar {
		height: 6px;
	}

	#news .inner {
		width: 92%;
		margin: 0 auto;
		position: relative;
	}

	#news ul {
		min-height: 78px;
		padding: 15px 0;
		margin: 0 108px 0 0;
		position: relative;
		box-sizing: border-box;
	}

	#news ul li {
		width: 100%;
		max-height: 58px;
		font-size: 1.2rem;
		line-height: 1.416;
		overflow: hidden;
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#news ul li .date {
		font-size: 1.0rem;
		display: block;
	}

	#news .btn-list a {
		font-size: 1.2rem;
		border: 1px solid #CCC;
		border-radius: 2px;
		padding: 16px 15px;
		position: absolute;
		top: 50%;
		right: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#information .title {
		margin-top: 40px;
		position: relative;
	}

	#information .title .main {
		text-align: center;
	}

	#information .title .main h2 {
		font-size: 2.8rem;
		font-weight: normal;
	}

	.en #information .title .main h2 {
		font-size: 2.6rem;
		line-height: 1.2;
	}

	#information .title .main h3.en {
		font-size: 1.8rem;
		font-weight: normal;
		margin-top: 18px;
	}

	.en #information .title .main h3.en {
		font-size: 1.6rem;
	}

	#information .title .main h3.jp {
		font-size: 1.0rem;
		font-weight: normal;
		margin-top: 8px;
	}

	#information .title .sub {
		width: 160px;
		height: 31px;
		margin: 32px auto 0 auto;
		position: relative;
	}

	.en #information .title .sub {
		width: 200px;
	}

	#information .title .catch {
		font-size: 1.0rem;
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}
	#information .title .catch img {
		width:75px;
	}

	#information .title .catch {
		line-height: 1.4;
		text-align: center;
	}

	#information .title .logo {
		position: absolute;
		top: 50%;
		right: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#information .title .logo img {
		width: 60px;
		height: 31px;
	}

	#information .term,
	#information .venue {
		width: 84%;
		margin: 36px auto 0 auto;
	}

	#information .term h4,
	#information .venue h4 {
		width: 2.2em;
		font-size: 1.4rem;
		font-weight: normal;
		float: left;
		margin-right: 10px;
	}

	#information .term .data,
	#information .venue .data {
		width: calc(100% - 2.2em - 10px);
		font-size: 1.4rem;
		float: left;
	}

	.en #information .term h4,
	.en #information .venue h4 {
		width: 4.4em;
	}

	.en #information .term .data,
	.en #information .venue .data {
		width: calc(100% - 4.4em - 10px);
	}

	#information .term h5,
	#information .venue h5 {
		font-size: 1.8rem;
		font-weight: normal;
	}

	#information .term p,
	#information .venue p {
		font-size: 1.4rem;
		line-height: 1.571;
		margin-top: 10px;
	}

	#information .main-menu {
		text-align: center;
		margin-top: 30px;
	}

	#information .main-menu li {
		width: 38%;
		height: 132px;
		border-top: 1px solid #d2d2d2;
		font-size: 1.4rem;
		display: inline-block;
		margin: 0 4%;
	}

	#information .main-menu li:nth-child(-n+2) {
		border-top: none;
	}

	#information .main-menu li a {
		display: block;
	}

	#information .main-menu li.info i {
		width: 14px;
		top: 30px;
	}

	#information .main-menu li.ticket i {
		width: 53px;
		top: 24px;
	}

	#information .main-menu li.access i {
		width: 34px;
		top: 29px;
	}

	#information .main-menu li.schedule i {
		width: 50px;
		top: 30px;
	}

	#information .main-menu li span {
		bottom: 26px;
	}

	#information .sub-menu {
		width: 92%;
		text-align: center;
		margin: 30px auto 60px auto;
	}

	#information .sub-menu li {
		font-size: 1.2rem;
		margin: 0 4.347%;
		display: inline-block;
	}

	#information .sub-menu li i {
		width: 60px;
		height: 60px;
		margin: 0 auto 12px auto;
	}

	#information .sub-menu li:first-child i img {
		width: 24px;
		margin-left: 2px;
	}

	#information .sub-menu li:nth-child(2) i img {
		width: 26px;
		margin-top: -2px;
	}

	#wrapper .contents-block {
		margin-top: 184px;
		padding: 50px 0;
	}

	#wrapper .contents-block h2 {
		font-size: 3.0rem;
	}

	#wrapper .contents-block .contents-menu {
		margin-top: 10px;
	}

	#wrapper .contents-block .contents-menu li {
		font-size: 1.3rem;
		line-height: 2;
		margin: 0 9px;
	}

	#wrapper .contents-block .contents-menu li a {
		padding-right: 14px;
		display: block;
	}

	#wrapper .contents-block .contents-menu li a:after {
		content: "";
		display: block;
		position: absolute;
		top: 9px;
		right: 3px;
		width: 6px;
		height: 6px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#wrapper .contents-block .btn-more {
		font-size: 1.68rem;
		margin-top: 50px;
	}

	#wrapper .contents-block .btn-more a {
		padding: 0 18px 6px 0;
	}

	#wrapper .contents-block .btn-more a:after {
		content: "";
		display: block;
		position: absolute;
		top: 3px;
		right: 3px;
		width: 9px;
		height: 9px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#artist .artist-list {
		width: 92%;
		margin: 0 auto;
	}

	#artist .artist-list li {
		border-top: 1px solid #d2d2d2;
		padding: 15px 0;
		position: relative;
	}

	#artist .artist-list li:after {
		content: "";
		display: block;
		position: absolute;
		top: 48px;
		right: 3px;
		width: 8px;
		height: 8px;
		border-top: 1px solid #000;
		border-right: 1px solid #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#artist .artist-list li:first-child {
		border-top: none;
	}

	#artist .artist-list li .img {
		width: 21.739%;
	}

	#artist .artist-list li .name {
		width: 100%;
		padding: 0 30px 0 26.08%;
		box-sizing: border-box;
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translate(0, -50%);
		transform: translate(0, -50%);
	}

	#artist .artist-list li .name .main {
		font-size: 1.4rem;
	}

	#artist .artist-list li .name .sub {
		font-size: 1.0rem;
		font-family: "Helvetica Neue", Helvetica, Arial, "Hiragino Kaku Gothic ProN", "游ゴシック体", "Yu Gothic", YuGothic, Meiryo, sans-serif;
		margin-top: 4px;
	}

	#program p.date {
		margin-top: 13px;
	}

	#program p.date span {
		font-size: 1.5rem;
		padding: 9px 10px;
	}

	#wrapper #program .contents-menu {
		margin-top: 34px;
	}

	#program .program-list {
		width: 92%;
		margin: 20px auto 0 auto;
	}

	#program .program-list > li {
		width: 100%;
	}

	#program .program-list > li a {
		padding: 30px 0;
	}

	#program .program-list > li:first-child{
		border-top: none;
	}

	#program .program-list > li:last-child a {
		padding-bottom: 0;
	}

	#program .program-list > li .img {
		width: 30.43%;
	}

	#program .program-list > li .data {
		width: 65.21%;
	}

	#program .program-list > li .data .category span {
		font-size: 1.0rem;
		padding: 5px 10px;
		margin-right: 5px;
	}

	#program .program-list > li .data .category span.ticket {
		padding-left: 25px;
	}

	#program .program-list > li .data .category span.ticket:before {
		width: 14px;
		height: 14px;
		background-size: 14px 14px;
		left: 5px;
	}

	#program .program-list > li .data h3 {
		font-size: 1.8rem;
		font-weight: normal;
		line-height: 1.333;
		margin-top: 18px;
	}

	#program .program-list > li .data .detail li {
		font-size: 1.0rem;
		line-height: 1.5;
		margin-top: 16px;
		padding-left: 25px;
	}

	#program .program-list > li .data .detail li:nth-child(3) {
		line-height: 2;
	}

	#program .program-list > li .data .detail > li:before {
		width: 16px;
	}

	#program .program-list > li .data .detail > li:first-child:before {
		/* font-size: 2.0rem; */
		width: 16px;
		height: 19px;
		background-image: url("../img/common/icon_human.svg");
		background-size: 16px 19px;
	}

	#program .program-list > li .data .detail > li:nth-child(2):before {
		/* font-size: 2.0rem; */
		width: 16px;
		height: 19px;
		background-image: url("../img/common/icon_access.svg");
		background-size: 13px 19px;
	}

	#program .program-list > li .data .detail > li:nth-child(3):before {
		/* font-size: 1.8rem; */
		width: 16px;
		height: 16px;
		background-image: url("../img/common/icon_calendar.svg");
		background-size: 16px 16px;
	}

	#program .program-list > li .data .detail > li .supplement {
		font-size: 0.9rem;
		line-height: 1;
		padding: 4px 3px 3px 3px;
		-webkit-transform: translate(0, -1px);
		transform: translate(0, -1px);
	}

	#instagram .instagram-list {
		width: 92%;
		margin: 10px auto 0 auto;
	}

	#instagram .instagram-list li {
		width: 30.43%;
		margin: 30px 4.34% 0 0;
	}

	#instagram .instagram-list li:nth-child(3n) {
		margin: 30px 0 0 0;
	}

	#sns .sns-list {
		margin: 46px 0 20px 0;
	}

	#sns .sns-list li {
		margin: 0 17px;
	}

	#sns .sns-list li .icon {
		width: 60px;
		height: 60px;
		font-size: 2.8rem;
		line-height: 60px;
	}

	#sns .sns-list li p {
		font-size: 1.2rem;
		margin-top: 12px;
	}

}
