@charset "UTF-8";

/*UNIQ*/

.loader-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px; /* Height of the progress bar */
  background-color: #f0f0f0;
}

.loader-bar {
  height: 100%;
  background-color: #007bff; /* Color of the progress bar */
  width: 0%; /* Initial width is 0 */
}

.content {
  display: none; /* Hide content initially */
  padding: 20px;
}

#maintop {
	position: relative;
	width: 100%;
	height: auto;

	padding-bottom: 0%;
	background-color: #000;
	z-index: 10;


}


@media screen and (min-width:320px) and (max-width:1050px) {
	#maintop {
		position: relative;
		width: 100%;
		padding-bottom: 10%;

		height: auto;
	}
}

#movie {
	position: relative;
	margin-top: -12px;
	padding-top: 2px;
	padding-bottom: 0%;
	width: 100%;
	height: auto;
	background: rgb(0, 0, 0);
	background: linear-gradient(0deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 100%);
	z-index: 15;


}

.maintop_headcopy {
	position: relative;
	padding-top: 6px;
	margin-left: 10px;
	width: 50%;
}

.maintop_logo {
	position: relative;
	width: 36%;
	margin-top: -8.5%;
	margin-left: 5%;
	margin-bottom: 0;
	z-index: 50;

}

.maintop_sublogo {
	position: relative;
	width: 37%;
	margin-top: 1.5vw;
	margin-left: 5.9%;
	padding-bottom: 1%;
	z-index: 180;
}

.maintop_rock {
	position: absolute;
	margin-top: -3%;
	left: 39%;
	width: 40%;
	z-index: 10;
}

.maintop_terry {
	position: absolute;
	left: 64%;
	margin-top: 5%;
	width: 60%;
	z-index: 51;

}


.maintop_thunder {
	position: absolute;
	transform: rotate(-2deg);
	top: -3%;
	right: 0%;
	width: 64%;
	z-index: 101;


}

.movielist {
	position: relative;
	z-index: 70;
	border-bottom: 1px solid #333333;
}

.movielist li {
	float: left;
}

.movielist li {
	width: 50%;
}



.mainimg {
	position: absolute;
	left: 0;
	width: 53.6vw;
	z-index: 5;
}

#intro {
	position: relative;
	padding-top: 0px;
	width: 100%;
	height: auto;
	z-index: 25;

}

.intro_headcopy {
	position: absolute;

	width: 50%;
	margin-top: 1%;
	right: 1%;
	z-index: 40;
}

.intro_infowrp {
	position: relative;
	width: 39%;
	left: 54.5%;

}

.intro_logo {
	position: absolute;
	width: 17%;
	margin-top: 21%;
	right: 19%;
	z-index: 200;
}

.textarea_m {
	font-size: min(1vw, 20px);
}

.textarea_intro_lead {
	position: absolute;
	margin-top: 10%;
	width: 39%;
	right: 6%;
	color: #fff;
	font-weight: 500;
	line-height: 1.8em;
	text-align: justify;
	z-index: 40;

}

.textarea_intro_lead2 {
	position: relative;
	margin-top: 3%;
	width: 100%;
	right: 0%;
	color: #fff;
	font-weight: 500;
	line-height: 1.8em;
	text-align: justify;
	z-index: 40;

}

.textarea_intro_copy span {
	color: #FF3300;

}

.textarea_intro_copy2 span {
	color: #FF3300;

}

.intro_backimg {
	position: absolute;
	width: 64.5%;
	right: 0;
	bottom: 0;
}

.characters_list {
	width: 70%;
	margin: 0 auto;
}

.characters_list li {
	width: 50%;
	float: left;

}

.characters_list li:first-child {}


#characters {
	position: relative;
	padding-top: 0px;
	width: 100%;
	height: auto;
	background-color: #000;
	overflow: hidden;
}

.maintopbg {
	background-image: url(../img/common/backimg.jpg);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: top center;
}


.intro_map {
	position: fixed;
	width: 75%;
	margin-top: 15%;
	right: -10%;
	z-index: 5;
}

.intro_subcopy {
	position: absolute;
	margin-top: 0%;
	left: 62.3%;
	width: 37%;
	z-index: 50;
}

.maintop_flash {
	position: absolute;
	z-index: 100;
	width: 120%;
	margin-top: -42%;
	right: -30%;
}



@media screen and (min-width:320px) and (max-width:1050px) {
	#intro {
		position: relative;
		padding-top: 0px;
		padding-bottom: 0%;
		width: 100%;
		height: auto;
		z-index: 25;

	}

	.textarea_m {
		font-size: min(3.8vw, 50px);
	}

	.intro_logo {
		position: relative;
		width: 70%;
		right: 0%;
		margin: -5% auto;
		margin-bottom: 5%;
		z-index: 200;
	}

	.intro_map {
		position: absolute;
		width: 145%;
		margin-top: -25%;
		right: -22%;
		z-index: 5;
	}

	.intro_headcopy {
		position: relative;

		width: 100%;
		margin-top: 2%;
		right: 0;
		z-index: 40;
	}

	.intro_subcopy {
		position: relative;
		margin-top: -5%;
		left: 3%;
		width: 92%;
		z-index: 50;
	}

	.intro_infowrp {
		position: relative;
		width: 90%;
		left: 0;
		right: 0;
		margin: 0 auto;

	}

	.mainimg {
		position: relative;
		margin-top: 2%;
		width: 100%;
		z-index: 10;
	}

	.maintopbg {
		background-image: url(../img/common/backimg_sp.jpg);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: top center;
		height: auto;
	}

	.maintop_flash {
		position: absolute;
		z-index: 100;
		width: 120%;
		margin-top: 2%;
		right: -8%;
	}

	.maintop_headcopy {
		position: relative;
		padding-top: 6px;
		margin-left: 6px;
		width: 97.5%;
	}

	.maintop_rock {
		position: absolute;
		margin-top: 20%;
		left: -20%;
		width: 80%;
		z-index: 10;
	}

	.maintop_terry {
		position: absolute;
		left: 25%;
		margin-top: 30%;
		width: 120%;
		z-index: 51;

	}

	.maintop_logo {
		position: relative;
		width: 100%;
		margin-top: 30%;
		margin-bottom: 0;
		margin-left: 0%;
		z-index: 202;

	}


	.maintop_thunder {
		position: absolute;
		top: -1%;
		right: -15%;
		width: 146%;
		z-index: 201;
	}

	.maintop_sublogo {
		position: relative;
		width: 95%;
		margin-top: -4%;
		margin-left: 3%;
		z-index: 250;
	}

	.movielist {
		position: relative;
		margin-bottom: 0;
		z-index: 70;
		border-bottom: 0px solid #333333;
	}

	.movielist li {
		float: left;
		border-top: 1px solid #555;
	}

	.movielist li {
		width: 100%;
		margin-bottom: 2%;
	}
}


.textarea_l {
	font-size: min(1.9vw, 35px);
}


.textarea_intro_copy {
	position: absolute;
	font-weight: 700;
	margin-top: 4%;
	width: 39%;
	right: 6%;
	color: #fff;
	font-weight: 600;
	z-index: 40;
	line-height: 1.25em;
	text-shadow: 1px 2px 10px #000;

}

.textarea_intro_copy2 {
	position: relative;
	margin-top: 3%;
	width: 100%;
	right: 0%;
	color: #fff;
	font-weight: 600;
	z-index: 40;
	line-height: 1.25em;

	letter-spacing: 0.1em;
}

.trailerbnr {
	position: absolute;
	width: 13%;
	bottom: 2%;
	right: 15px;
	z-index: 600;
	transition: transform 0.3s ease;
	/* 拡大/縮小のアニメーションを追加 */
}

.trailerbnr:hover {
	transform: scale(1.1);
	/* ホバー時に1.1倍に拡大 */
}

.ftwrp {
	position: absolute;
	margin-top: 0;
	width: 100%;
	height: 250px;
	background-color: rgba(0, 0, 0, 0.6);
	z-index: 20;

	overflow: hidden;
}

.ftsns {
	position: relative;
	width: 5%;
	margin: 10px auto;
	z-index: 100;

}

.ftsns li {
	position: relative;
	float: left;
	width: 32%;
	margin-right: 20px;
}

.ftsns li:last-child {
	margin-right: -30%;
}

.textarea_credit {
	position: relative;
	color: #fff;
	font-size: 1.2rem;
	text-align: center;
	margin-top: 10px;
}

.ftsnklogo {
	position: relative;
	text-align: center;
	padding-top: 55px;
	z-index: 100;
}

.ftmap {
	position: fixed;
	width: 140%;
	margin-top: -10%;
	margin-left: -10%;
	opacity: 0.8;
	filter: blur(2px);
	z-index: 6;
}


@media screen and (min-width:320px) and (max-width:1050px) {
	.ftsnklogo {
	position: relative;
	text-align: center;
	padding-top: 5%;
	z-index: 100;
}
	.ftwrp {
		position: absolute;
		margin-top: 0;
		width: 100%;
		height: auto;
		padding-bottom: 5%;
		background-color: rgba(0, 0, 0, 0.6);
		z-index: 20;

		overflow: hidden;
	}

	.ftmap {
		position: fixed;
		width: 300%;
		margin-top: 10%;
		margin-left: -50%;
		opacity: 0.8;
		filter: blur(1px);
		z-index: 6;
	}

	.textarea_l {
		font-size: min(7vw, 60px);
	}


	.ftsns {
		position: relative;
		width: 18%;
		margin: 10px auto;
		z-index: 100;

	}

	.ftsns li {
		position: relative;
		float: left;
		width: 39%;
		margin-right: 20px;
	}

	.ftsns li:last-child {
		margin-right: -30%;
	}

	.textarea_intro_copy {
		position: relative;
		width: 90%;
		text-align: center;
		right: 0%;
		margin: 3.5% auto;
		color: #fff;
		font-weight: 600;
		z-index: 40;
		letter-spacing: 0.05em;
	}

	.textarea_intro_copy2 {
		position: relative;
		width: 90%;
		text-align: center;
		right: 0%;
		margin: 10% auto;
		margin-bottom: 0;
		color: #fff;
		font-weight: 600;
		z-index: 40;
		letter-spacing: 0em;
	}

	.trailerbnr {
		position: absolute;
		width: 28%;
		bottom: 5%;

		z-index: 600;
	}

	.textarea_intro_lead {
		position: relative;
		width: 85%;
		right: 0%;
		color: #fff;
		font-weight: 500;
		line-height: 1.8em;
		text-align: justify;
		margin: 4% auto;
		z-index: 40;

	}

	.textarea_intro_lead2 {
		position: relative;
		width: 100%;
		right: 0%;
		color: #fff;
		font-weight: 500;
		line-height: 1.8em;
		text-align: justify;
		margin: 4% auto;
		z-index: 40;

	}
}


/*タブレット*/
@media screen and (min-width:768px) and (max-width:1050px) {

	.ftsns {
		position: relative;
		width: 10%;
		margin: 10px auto;
		z-index: 100;

	}

	.ftsns li {
		position: relative;
		float: left;
		width: 35%;
		margin-right: 20px;
	}

	.ftsns li:last-child {
		margin-right: -30%;
	}

	.textarea_m {
		font-size: min(3.8vw, 25px);
	}

	.maintop_logo {
		position: relative;
		width: 65%;
		margin: 35% auto;
		z-index: 202;
		margin-bottom: 0;

	}

	.maintop_sublogo {
		position: relative;
		width: 80%;
		margin: 0 auto;
		z-index: 80;
	}

	.maintop_rock {
		position: absolute;
		margin-top: 15%;
		left: -12%;
		width: 70%;
		z-index: 10;
	}

	.maintop_terry {
		position: absolute;
		left: 30%;
		margin-top: 30%;
		width: 110%;
		z-index: 51;

	}

	.textarea_l {
		font-size: min(7vw, 50px);
	}

	.intro_logo {
		position: relative;
		width: 50%;
		right: 0%;
		margin: -5% auto;
		margin-bottom: 0;
		z-index: 200;
	}
}


.maintop_logo_overlay {
	position: relative;
	width: 32%;
	margin-top: -23.5%;
	margin-left: 8.5%;
	mix-blend-mode: overlay;
	z-index: 25;
}

.topsns {
	position: absolute;
	margin-top: 5px;
	right: 10px;
	width: 7%;
	z-index: 210;
}

.topsns li {
	float: right;
	width: 15%;
	margin-left: 10px;
}

.topsns li:last-child {
	width: 50%;
	margin-left: -20%;
}

.topsnsbase {
	position: absolute;
	width: 9.5%;
	right: 0;
	border-bottom: 40px solid rgba(0, 0, 0, 0.8);
	border-left: 20px solid transparent;
	z-index: 200;
}


.maintop_dark {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 51%;
}


.sociallist {
	position: relative;
	margin-top: -2%;
	margin-bottom: 1.2%;
	width: 50%;
	margin-left: 33%;
}

.sociallist li {
	float: left;
	width: 20%;
}

.sociallist li:nth-child(3) {
	width: 28%;
}



/*NEWS*/
.news-list {
	list-style: none outside;
	margin: 0;

	padding-right: 10px;


}

.news-list .item span {
	display: flex;
	flex-wrap: wrap;
	flex-wrap: nowrap;
	text-decoration: none;
	font-weight: 500;
	font-size: min(1vw, 15px);
	color: #DCDCDC;
	border-bottom: 4px solid #000;
	padding: 10px 10px;
	transition: all .2s;
	background-color: #1A1A1A;

}

.news-list .item a {
	transition: all .2s;
}

.news-list .item a:link {
	color: #DCDCDC;
	text-decoration: none;
}

.news-list .item a:visited {
	color: #DCDCDC;
}

.news-list .item a:hover {
	color: #FF3300;
	text-decoration: none;
	transition: all .2s;
}

.news-list .item .date {
	margin: 0;
	width: 12%;
	font-size: min(0.8vw, 15px);
	color: #999;
	margin-top: 0.2%;
	margin-right: 15px;
	padding-left: 5px;
}


.news-list .item .category {
	margin: 0;
	width: 16%;
	margin-right: 1%;
}

.news-list .item .category span.catt {
	background: #FF3300;
	color: #000;
	text-align: center;
	font-weight: 600;
	display: inline-block;
	border-bottom: 0px;
	padding: 3px 3px;
	font-size: min(0.7vw, 15px);
	line-height: 1;
	width: 100%;
}

.news-list .item .title {
	margin: 0;
	width: 120%;

}

.news-list .item span .title {

	transition: all .3s;
}


/* 装飾 */

* {
	box-sizing: border-box;
}

a {
	text-decoration: none;
}


.main_latestnewstit {
	position: relative;
	margin-left: 6.1%;
	margin-top: -5.5%;
	width: 9%;
}

.latestnewswrp {
	position: relative;

	margin-left: 6.1%;
	width: 37%;
	overflow-y: scroll;
	height: 12vh;
	z-index: 500;

}

.latestnewswrp::-webkit-scrollbar {
	background: #1A1A1A;
	width: 8px;

}

.latestnewswrp::-webkit-scrollbar-thumb {
	background-color: #FF3300;

}


@media screen and (min-width:320px) and (max-width:1050px) {


	.main_latestnewstit {
		position: relative;

		width: 40%;
		margin: 3% auto;
		margin-bottom: 2%;
		z-index: 500;
	}

	.latestnewswrp {
		position: relative;

		margin-left: 0%;
		width: 95%;
		overflow-y: scroll;
		height: 30vh;
		z-index: 500;
		background-color: rgba(0, 0, 0, 0.5);
		margin: 0 auto;

	}

	.news-list {
		list-style: none outside;
		margin: 0;
		padding-left: 10px;
		padding-right: 10px;


	}

	.news-list li:first-child {
		padding-top: 20px;
	}

	.news-list .item span {
		display: inherit;
		flex-wrap: nowrap;
		text-decoration: none;
		font-weight: 500;
		font-size: min(4vw, 25px);
		color: #DCDCDC;
		border-bottom: 0px solid #000;

		transition: all .2s;
		background-color: transparent;

	}

	.news-list .item .date {
		margin: 0;
		width: 12%;
		font-size: min(3vw, 15px);
		color: #999;
		margin-top: 1%;
		margin-right: 15px;
		float: left;
		padding-left: 0px;
	}


	.news-list .item .category {
		margin: 0;
		width: 20%;
		padding: 0 20px 0 0;

		display: inline-block;
		margin-bottom: 0.3%;
	}

	.news-list .item .category span.catt {
		background: #FF3300;
		color: #000;
		text-align: center;
		font-weight: 600;
		display: inline-block;
		border-bottom: 0px;
		padding: 3px 20px;
		font-size: min(3vw, 15px);
		line-height: 1;
	}

	.news-list .item span {
		flex-wrap: wrap;
		/* flexアイテムを折り返し */
		justify-content: space-between;
		/* 要素を均等に配置 */
	}

	.news-list .item .date {
		width: auto;
		/* 横幅を自動調整 */
	}

	.news-list .item .category {
		width: auto;
		/* 横幅を自動調整 */
		margin-right: 0.5rem;
		/* カテゴリの間隔を調整 */
	}

	.news-list .item .title {
		margin: 6px 0 0;
		/* 上部に余白を追加 */
		width: 100%;
		/* 幅を100%に設定 */
	}
}


.top_backimg_map {
	position: absolute;
	width: 51%;
	right: 0;
	opacity: 0.7;
	z-index: 1;

}

.movieinnertit {
	position: absolute;
	bottom: 16%;
	width: 50%;
	margin-left: 22%;
	z-index: 100;
}

.evobnr {
	position: relative;

	width: 60%;
	margin: 7% auto;
	margin-bottom: 0;
	z-index: 100;
}

.evobnr a {
	transition: all .2s;
}

.evobnr a:hover {
	opacity: 0.7;
	transition: all .2s;
}

.intro_rock {
	position: absolute;
	margin-top: 69%;
	width: 17%;
	right: 38%;
}

.intro_terry {
	position: absolute;
	margin-top: 70%;
	width: 17%;
	right: -4%;
}

.spbr {
	display: none;
}

.langselect {
	position: absolute;
	width: 20%;
	right: 8px;
	margin-top: 35px;
	z-index: 20;
}

.langselect li {
	float: right;
	margin-right: 2%;
}


@media screen and (min-width:320px) and (max-width:1050px) {
	.movieinnertit {
		position: relative;
		bottom: inherit;
		margin-top: -11%;
		width: 70%;
		margin-left: 16%;
		z-index: 100;
	}

	.evobnr {
		position: relative;
		margin-top:15%;
		width: 80%;
		left: 0%;
		z-index: 100;
	}

	.spbr {
		display: block;
	}

	.langselect {
		position: relative;
		width: 22%;
		right: inherit;
		margin: 4% auto;
		z-index: 20;
	}

	.langselect li {
		width: 45%;
		float: left;
		margin-right: 10%;
	}

	.langselect li:last-child {
		margin-right: -10%;
	}


}


/*タブレット*/
@media screen and (min-width:768px) and (max-width:1050px) {
	.evobnr {
		position: relative;
		margin-top: 5%;
		width: 50%;
		left: 0%;
		z-index: 100;
	}
}

.overlay {
	position: fixed;
	width: 100%;
	height: 100vh;
	background-image: url(../img/common/01.png);
	z-index: 7;
}

.top_backimg_overlay {
	position: absolute;
	width: 45%;
	right: 0;
	height: 100vh;
	background-image: url(../img/common/01.png);
	z-index: 2;
}


.snklogo {
	position: absolute;
	right: 10px;
	z-index: 50;
}

.newtag {
	color: #FF3300;
}

.trigger1 {
	position: absolute;
}

.trigger2 {
	position: absolute;
	margin-top: 20%;
}

.moviebtn {
	position: absolute;
	width: 5%;
	margin-left: 22%;
	margin-top: 12vw;
	transition: all .2s;
	/* 全体のトランジションを追加 */
	z-index: 150;

}

.moviebtn a {
	transition: all .2s;
}

.moviebtn a:hover {
	opacity: 0.8;
	transition: all .2s;
}

.trigger0 {
	position: absolute;
	margin-top: -45%;
}

.announcementwrp {
	position: relative;
	width: 52%;
}

.intro_bigcopy {
	position: relative;
	width: 62%;
}

#midcopy {
	position: relative;
	z-index: 10;
	background: rgb(0, 0, 0, 0.2);
	padding-left: 12px;
	padding-bottom: 10px;
}

.introhead {
	position: relative;
	padding-top: 1.5vw;
	width: 100%;
	left: 0;
	z-index: 30;
}

.introstar {
	position: absolute;
	width: 32%;
	margin-top: -7%;
	left: -14%;
	z-index: 5;
}

.intro_charactersmovie {
	position: relative;
	width: 125%;
	margin-top: 0;
	right: 7.8%;
}

.moviebtn_intro {
	position: absolute;
	width: 15%;
	right: 36%;
	margin-top: 7vw;
	transition: all .2s;
	/* 全体のトランジションを追加 */
	z-index: 150;
}

.intro_last {
	position: relative;
	width: 100%;
	z-index: 100;
	margin-top: 2%;

}

.intro_lastsub {
	position: relative;
	width: 70%;
	z-index: 100;
	margin: 2% auto;
	padding-bottom: 6.3%;

}

.intro_lastlogo {
	position: relative;
	width: 33%;
	margin: 10% auto;
	margin-bottom: 0;
}

.movieinnertit_intro {
	position: absolute;
	margin-top: 17.0vw;
	left: 28%;
	width: 60%;
	z-index: 100;
}

.moviestar {
	position: absolute;
	width: 12%;
	left: 50%;
	z-index: 10;

}

.moviestarsp {
	position: absolute;
	width: 12%;
	left: 50%;
	z-index: 10;

}

@media screen and (min-width:320px) and (max-width:1050px) {
	.intro_lastsub {
	position: relative;
	width: 100%;
	z-index: 100;
	margin: 4% auto;
	padding-bottom: 6.3%;

}
	.intro_lastlogo {
	position: relative;
	width: 43%;
	margin: 10% auto;
	margin-bottom: 0;
}
	
	.trigger0 {
		position: absolute;
		margin-top: 40%;
	}

	.trigger2 {
		position: absolute;
		margin-top: -70%;
	}

	.introstar {
		position: absolute;
		width: 30%;
		margin-top: -7%;
		left: -13%;
		z-index: 5;
	}

	.intro_charactersmovie {
		position: relative;
		width: 100%;
		margin-top: 0;
		right: 0%;
	}

	.intro_bigcopysp {
		position: relative;
		width: 90%;
		margin: 10% auto;
		margin-bottom: 2%;
	}

	.announcementwrp {
		position: relative;
		width: 100%;
	}

	.moviestarsp {
		position: absolute;
		width: 50%;
		opacity: 0.8;

		left: 24%;
		z-index: 10;

	}
}


.trigger4 {
	position: absolute;
}

.moviestarflash {
	position: absolute;
	width: 12%;
	left: 50%;
	z-index: 11;

}

.introstarflash {
	position: absolute;
	width: 32%;
	margin-top: -7%;
	left: -14%;
	z-index: 15;
}