@charset "utf-8";
/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=block');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=block');

html {
	position:relative;
}

* {
	margin:0;
	padding:0;
	font-family:"Roboto","Helvetica Neue",YakuHanJP, 'Noto Sans JP',"Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体","Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3",Osaka,"CI",Meiryo,"メイリオ","lroSVbN","ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

body {
    font-family: YakuHanMP,"Noto Serif JP",serif;
    font-optical-sizing: auto;
    font-weight: 500;
    line-height: 1.8;
    text-align: justify;
    word-break: break-all;
    background: url(img/bg.jpg) no-repeat left top/cover;
}

body.cp_modal {
	overflow:hidden;
}

#mw_cp * {
	text-shadow:none;
	letter-spacing:-0.01px;
	line-height:1.6;
	-webkit-text-size-adjust:100%;
	font-size:12px;
	font-weight: 400;
	font-style: normal;
	color:#232323;
    outline : none;
	font-feature-settings: "palt";
}

#mw_cp {
	width:640px;
	margin:0 auto;
	position:relative;
	-webkit-box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2);
	box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2);
	background: #000000;
	background: linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgba(117, 113, 84, 1) 50%, rgba(0, 0, 0, 1) 100%);
}

#mw_cp::before {
	background:url(../img/bg.jpg) center center;
	background-size:cover;
	content:"";
	display:block;
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100vh;
	height:100dvh;
	min-height:100vh;
	min-height:100dvh;
	z-index:-5;
}

a {
	outline:0;
	border:0;
	color:#0099ff;
	text-decoration:none;
}

img {
	border:0;
    outline : none;
    vertical-align: bottom;
}

ul,
li,
ol {
	list-style:none;
}

/* メインビジュアル */

#mw_cp #mainvisual {
}

#mw_cp #mainvisual img {
	width:100%;
}

#mw_cp h1 {
	padding:5px 0 10px 0;
}

/* プレミア */

#mw_cp #premiere {
	padding:5px 0 0 0;
}

#mw_cp #premiere img {
	width:100%;
}

#mw_cp .place_box {
	margin:0 5%;
}

#mw_cp .place_box_in {
	margin:10px 0 0 0;
}

#mw_cp .step {
	padding:0 0 30px 0;
	margin:0 5%;
}

#mw_cp .step h3 {
	padding:0 0 15px 0;
}

#mw_cp .step p {
	font-size:24px;
	font-weight:700;
	color:#ffffff;
	text-align:center;
}

#mw_cp .step_movie {
	margin:30px 0 0 0;
}

#mw_cp .step_but {
	margin:40px 0 0 0;
}

#mw_cp .step_but_in {
	margin:20px 0 0 0;
	filter:alpha(opacity=35);
	-moz-opacity: 0.35;
	opacity: 0.35;
}

#mw_cp .step_but_in.ended {
	filter:alpha(opacity=100);
	-moz-opacity: 1;
	opacity:1;
	cursor:pointer;
	transition:1.0s;
}

#mw_cp .step_text {
	margin:40px 0 0 0;
	font-size:16px;
	font-weight:700;
	color:#ffffff;
}

#mw_cp .step_list ul {
	margin:25px 0 20px 0;
}

#mw_cp .step_list li {
	list-style-type: none;
	padding:0 0 0 14px;
	position:relative;
	font-size:14px;
	font-weight:400;
	color:#ffffff;
}

#mw_cp .step_list li a {
	font-size:14px;
	font-weight:400;
	color:#f2ac04;
}

#mw_cp .step_list li:before {
	display: inline;
	content: "※";
	position: absolute;
	top:0;
	left:0;
}

/* シーンカット */

#mw_cp .ph_box {
	overflow:hidden;
	position:relative;
	z-index:10;
}

#mw_cp .ph_box * {
	width:auto !important;
	height:250px !important;
}

#mw_cp .ph,
#mw_cp .ph * {
	width:100%;
}

/* リンク */

#mw_cp .links {
	padding:20px 6.5% 60px 6.5%;
}

#mw_cp .links .links_item {
	padding:30px 5% 0 5%;
}

#mw_cp .links h3 {
	margin:0 0 10px 0;
}

#mw_cp .links ul {
	margin:30px 0 0 0;
	display: flex;
	justify-content: center;
    gap:7px;
}

#mw_cp .links img {
	width:100%;
}

#mw_cp .links_but {
	margin:15px 15% 0 15%;
}

#mw_cp .links_but img {
	width:100%;
}

/* フッター */

#mw_cp #mw_footer {
	padding:10px 0 30px 0;
}

#mw_cp #mw_footer .content {
	position:relative;
}

#mw_cp #mw_footer .footer_logo {
	text-align:center;
}

#mw_cp #mw_footer .footer_logo img {
	width:100%;
}

#mw_cp #mw_footer .footer_logo a {
	display:inline-block;
	margin-right:5px;
}

#mw_cp #mw_footer .footer_link {
	text-align:center;
	padding:20px 15px 0 15px;
}

#mw_cp #mw_footer .footer_link_in {
	display:inline-block;
	border-right:1px solid #cccccc;
	padding:0 10px;
	margin:0 3px 0 0;
}

#mw_cp #mw_footer .footer_link_in:last-child {
	border-right:0;
	margin:0 1px 0 0;
	padding:0 10px 0 6px;
}

#mw_cp #mw_footer .footer_link_in a {
	font-size:10px;
	color:#232323;
	position:relative;
	z-index:10;
}

#mw_cp #mw_footer .link_but {
	padding:0 0 20px 0;
	text-align:center;
	margin:30px 0 0 0;
}

#mw_cp #mw_footer .link_but_in {
	padding:0 5px 10px 5px;
	display:inline-block;
	padding:0 15% 3% 15%;
	width:60%;
}

#mw_cp #mw_footer .link_but_in a {
	display:block;
	border-radius:50px;
	line-height:50px;
	height:50px;
	text-align:center;
	color:#ffffff;
	font-size:16px;
	text-decoration: none;
	border:1px solid #ffffff;
	position:relative;
	z-index:10;
}

#mw_cp #mw_footer .link_but_in a::after {
	content: '';
	position: absolute;
	top:calc(50% - 3px);
	right:30px;
	vertical-align: middle;
	color: #faf700;
	line-height: 1;
	width:6px;
	height:6px;
	border-top:2px solid #ffffff;
	border-right:2px solid #ffffff;
	transform: rotate(45deg);
}

#mw_cp #mw_footer .release {
	text-align:center;
	font-size:12px;
	padding:15px 15px 0 15px;
	font-weight:500;
	color:#ffffff;
}

#mw_cp #mw_footer .copyright {
	text-align:center;
	font-size:10px;
	padding:5px 15px 0 15px;
	color:#ffffff;
}

/* 予告 */

#mw_cp .ytMovie_box {
	position:relative;
	padding-bottom:56.5%;
	height:0;
	overflow:hidden;
}

#mw_cp .ytMovie_box iframe {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

/* ストーリー */

#mw_cp #story {
	background:url(../img/bg_story.png) no-repeat top center;
	background-size:100% auto;
}

#mw_cp #story .story_ph {
	margin:0 6.5%;
}

#mw_cp #story .story_ph img {
	width:100%;
}

#mw_cp #story h4 {
    padding:8px 0 10px 0;
	text-align:center;
}

#mw_cp #story h4 img {
	width:100%;
}

#mw_cp #story h5 img {
	width:100%;
}

#mw_cp .story_item_movie {
	margin:0 6.5%;
}

#mw_cp .story_theater {
	margin:50px 0 0 0;
	text-align:center;
}

#mw_cp .story_footer {
	margin:50px 0 0 0;
	text-align:center;
}

#mw_cp #story .story_text {
	margin:20px 0 0 0;
	font-size:26px;
	font-weight:700;
	text-align:center;
	color:#ffffff;
}

#mw_cp #story .story_text span {
	font-size:26px;
	font-weight:700;
	color:#e4007f;
}

#mw_cp #story .story_intro {
	margin:15px 6.5% 25px 6.5%;
}

#mw_cp #story .story_intro p {
	font-size:18px;
	font-weight:600;
	text-align: justify;
	text-justify: inter-ideograph;
	color:#ffffff;
}

#mw_cp #story .story_intro p span {
	font-size:18px;
	font-weight:800;
	color:#e4007f;
}

/* 規約 */

#mw_cp .kiyaku_box {
	display:none;
}

#mw_cp .kiyaku_box_in {
	position:fixed;
	background:rgba(0,0,0,0.85);
	top:0;
	left:0;
	bottom:0;
	right:0;
	z-index:1010 !important;
}

#mw_cp .kiyaku_text {
	position:fixed;
	top:17%;
	left:10%;
	bottom:17%;
	right:10%;
	background:#ffffff;
	z-index:1011 !important;
}

#mw_cp .kiyaku_text_in_out {
	overflow-y:scroll;
	scrollbar-width:10px;
	margin:auto;
	height:100%;
}

#mw_cp .kiyaku_text_in {
	position:relative;
	padding:30px 70px 50px 70px;
	z-index:1012 !important;
	margin:auto;
}

#mw_cp .kiyaku_text_in_out::-webkit-scrollbar {
	width:10px;
}

#mw_cp .kiyaku_text_in_out::-webkit-scrollbar-track {
	background:#ffffff;
}

#mw_cp .kiyaku_text_in_out::-webkit-scrollbar-thumb {
	background-color: rgba(0, 0, 0, 0.5);
	box-shadow:0 0 0 1px rgba(255, 255, 255, 0.5);
}

#mw_cp .kiyaku_text_in_out::-webkit-scrollbar-corner {
	display: none;
}

#mw_cp .kiyaku_text h5 {
	font-size:30px;
	color:#232323;
	font-weight:900;
	text-align:center;
	padding:25px 0 13px 0;
}

#mw_cp .kiyaku_text .step_box {
	margin:0 auto 5px auto;
}

#mw_cp .kiyaku_text .step_h {
	font-size:24px;
	font-weight:700;
	padding:5px 10px 5px 0;
	letter-spacing:0.1em;
	text-align:center;
}

#mw_cp .kiyaku_text .step_d {
	font-size:20px;
	text-align:center;
	letter-spacing:0.05em;
}

#mw_cp .kiyaku_text .step_d a {
	font-size:20px;
	color:#232323;
	text-decoration:underline;
}

#mw_cp .kiyaku_text .attention {
	font-size:18px;
	text-align:center;
	padding:0 0 10px 0;
}

#mw_cp .kiyaku_text .attention a {
	font-size:18px;
	color:#232323;
	text-decoration:underline;
}

#mw_cp .kiyaku_text ul {
	margin:10px 0 0 0;
}

#mw_cp .kiyaku_text li {
	list-style-type: none;
	padding:0 0 0 16px;
	font-size:16px;
	position:relative;
}

#mw_cp .kiyaku_text li b,
#mw_cp .kiyaku_text li span {
	font-size:16px;
}

#mw_cp .kiyaku_text li a {
	font-size:16px;
	color:#232323;
	text-decoration:underline;
}

#mw_cp .kiyaku_text li:before {
	display: inline;
	content: "※";
	position: absolute;
	top:0;
	left:0;
}

#mw_cp .kiyaku_text::-webkit-scrollbar {
	width:10px;
}

#mw_cp .kiyaku_text::-webkit-scrollbar-track{
	background: #fff;
}

#mw_cp .kiyaku_text::-webkit-scrollbar-thumb {
	background-color: rgba(0, 0, 0, 0.5);
	box-shadow:0 0 0 1px rgba(255, 255, 255, 0.5);
}

#mw_cp .kiyaku_close {
	display:block;
	position:fixed;
	top:100px;
	right:20px;
	width:60px;
	height:60px;
	transition:0.35s;
	cursor: pointer;
	z-index:1013 !important;
}

#mw_cp .kiyaku_close:hover {
	opacity:0.5;
}

#mw_cp .kiyaku_close::before,
#mw_cp .kiyaku_close::after {
	content: "";
	position: absolute;
	top:50%;
	left:50%;
	width:2px;
	height:60px;
	background:#ffffff;
}
 
#mw_cp .kiyaku_close::before {
	transform: translate(-50%,-50%) rotate(45deg);
}

#mw_cp .kiyaku_close::after {
	transform: translate(-50%,-50%) rotate(-45deg);
}

/* ボタン */

#mw_cp .but_box_in a ,
#mw_cp .but_box_in span {
	display:block;
	font-size:18px;
	font-weight:500;
	color:#ffffff;
	text-decoration:none;
	transition:1.0s;
	border-radius:85px;
	padding:15px 20px 15px 0;
	text-align:center;
	position:relative;
	border:1px solid #ffffff;
}

#mw_cp .but_box_in a::after,
#mw_cp .but_box_in span::after {
	content: '';
	position: absolute;
	top:calc(50% - 5px);
	right:30px;
	vertical-align: middle;
	color: #faf700;
	line-height: 1;
	width:10px;
	height:10px;
	border-top:3px solid #ffffff;
	border-right:3px solid #ffffff;
	transform: rotate(45deg);
}

#mw_cp .but_box {
	padding:0 28% 30px 28%;
}

#mw_cp .but_box_in {
	margin:15px 0 0 0;
}

#mw_cp .but_box_in span,
#mw_cp .but_box_in a,
#mw_cp .but_box_in img {
	display:block;
}

#mw_cp .but_box_in img {
	width:100%;
}

/* 当選 */

#mail {
	background:#ffffff;
	padding:5px 0 15px 0;
}

#mail img {
	width:100%;
}

/* 応募締切 */

#mw_cp .shimekiri {
	font-size:30px;
	text-align:center;
	font-weight:700;
	color:#f2ac04;
}

#mw_cp .shimekiri span {
	font-size:60px;
	font-weight:700;
	color:#f2ac04;
}

/* レシポンシブ */

#mw_cp .only_sp {
	display:none;
}

@media screen and (max-width:640px) {

	body {
		min-width:320px;
	}

	#mw_cp {
		width:100%;
	}

	#mw_cp h1 {
		padding:5px 0 7px 0;
	}

	/* コンテント */

	#mw_cp #invitation::before {
		width:100%;
	}

	/* シーンカット */

	#mw_cp .ph_box * {
	    height:200px !important;
	}

	/* ステップ */
	
	#mw_cp .step p {
		font-size:16px;
	}

	#mw_cp .step_but {
	    margin:30px 0 0 0;
	}

	#mw_cp .step_but_in {
		margin:10px 0 0 0;
	}

	#mw_cp .step_text {
		margin:30px 0 0 0;
		font-size:14px;
	}

	#mw_cp .step_list ul {
		margin:25px 0 0 0;
	}

	#mw_cp .step_list li {
	    padding:0 0 0 12px;
	    font-size:12px;
	}

	#mw_cp .step_list li a {
		font-size:12px;
	}

	/* リンク */

	#mw_cp .links {
		padding:10px 6.5% 50px 6.5%;
	}

	#mw_cp .links .links_item {
		padding:10px 3.5% 0 3.5%;
	}

	#mw_cp .links h3 {
		margin:0 0 5px 0;
	}

	#mw_cp .links ul {
		margin:20px 0 0 0;
	}

	#mw_cp .links li a {
		width:37.5px;
		height:37.5px;
	}

	/* ストーリー */

	#mw_cp #story .story_text {
		margin:20px 0 0 0;
		font-size:18px;
	}

	#mw_cp #story .story_text span {
		font-size:18px;
	}

	#mw_cp #story .story_intro {
		margin:15px 6.5% 25px 6.5%;
	}

	#mw_cp #story .story_intro p {
		font-size:14px;
	}

	#mw_cp #story .story_intro p span {
		font-size:14px;
	}

	/* 規約 */

	#mw_cp .kiyaku_box_in {
		position:fixed;
		background:rgba(0,0,0,0.85);
		top:0;
		left:0;
		bottom:0;
		right:0;
		z-index:1010 !important;
	}

	#mw_cp .kiyaku_text {
		position:fixed;
		top:17%;
		left:10%;
		bottom:17%;
		right:10%;
		background:#ffffff;
		z-index:1011 !important;
		overflow-y:scroll;
		scrollbar-color:#999999 #ffffff;
		scrollbar-width: thin;
		align-items: center;
		margin:auto;
	}

	#mw_cp .kiyaku_text_in {
		position:relative;
		padding:5px 30px 30px 30px;
		z-index:1012 !important;
		display:none;
		margin:auto;
	}

	#mw_cp .kiyaku_text h5 {
		font-size:16px;
		color:#232323;
		font-weight: 700;
		font-style: normal;
		text-align:center;
		padding:25px 0 13px 0;
	}

	#mw_cp .kiyaku_text .step_box {
		margin:0 auto 5px auto;
	}

	#mw_cp .kiyaku_text .step_h {
		font-size:18px;
		font-weight: 700;
		font-style: normal;
		padding:5px 0 5px 0;
		letter-spacing:0.1em;
		text-align:center;
	}

	#mw_cp .kiyaku_text .step_d {
		font-size:14px;
		letter-spacing:0.05em;
		text-align:center;
	}

	#mw_cp .kiyaku_text .step_d a {
		font-size:14px;
		color:#232323;
		text-decoration:underline;
	}

	#mw_cp .kiyaku_text .attention {
		font-size:14px;
		padding:0 0 10px 0;
	}

	#mw_cp .kiyaku_text .attention a {
		font-size:14px;
		color:#232323;
		text-decoration:underline;
	}

	#mw_cp .kiyaku_text ul {
		margin:10px 0 0 0;
	}

	#mw_cp .kiyaku_text li {
		list-style-type: none;
		padding:0 0 0 10px;
		font-size:10px;
	}

	#mw_cp .kiyaku_text li b,
	#mw_cp .kiyaku_text li span {
		font-size:10px;
	}

	#mw_cp .kiyaku_text li a {
		font-size:10px;
		color:#232323;
		text-decoration:underline;
	}

	#mw_cp .kiyaku_text li:before {
		display: inline;
		content: "※";
	}

	#mw_cp .kiyaku_text::-webkit-scrollbar {
		width:10px;
	}

	#mw_cp .kiyaku_text::-webkit-scrollbar-track{
		background: #fff;
	}

	#mw_cp .kiyaku_text::-webkit-scrollbar-thumb {
		background-color: rgba(0, 0, 0, 0.5);
		box-shadow:0 0 0 1px rgba(255, 255, 255, 0.5);
	}

	#mw_cp .kiyaku_close {
		display:block;
		position:fixed;
		top:70px;
		right:10px;
		width:40px;
		height:40px;
		transition:0.35s;
		cursor: pointer;
		z-index:1013 !important;
	}

	#mw_cp .kiyaku_close:hover {
		opacity:0.5;
	}

	#mw_cp .kiyaku_close::before,
	#mw_cp .kiyaku_close::after {
		content: "";
		position: absolute;
		top:50%;
		left:50%;
		width:2px;
		height:40px;
		background:#ffffff;
	}
	 
	#mw_cp .kiyaku_close::before {
		transform: translate(-50%,-50%) rotate(45deg);
	}
	 
	#mw_cp .kiyaku_close::after {
		transform: translate(-50%,-50%) rotate(-45deg);
	}

	/* フッター */

	#mw_cp .footer {
		margin:30px 0 30px 0;
	}

	#mw_cp .footer .copyright {
		font-size:12px;
	}

	#mw_cp #mw_footer .link_but_in {
	    width:80%;
		padding: 0 0 3% 0;
		margin:0 auto;
	}

	#mw_cp #mw_footer .link_but_in a {
	    font-size:14px;
	}

	/* ボタン */

	#mw_cp .but_box_in a ,
	#mw_cp .but_box_in span {
		font-size:16px;
	}

	#mw_cp .but_box {
		padding:5px 15% 20px 15%;
	}

	/* 応募締切 */

	#mw_cp .shimekiri {
		font-size:20px;
	}

	#mw_cp .shimekiri span {
		font-size:40px;
	}


	/* レシポンシブ */

	#mw_cp .only_pc {
		display:none;
	}

	#mw_cp .only_sp {
		display:block;
	}

}

/* 効果 */
h1,h2,h3,.place_box_in,.event_in,#story h4,#story .story_item,p {
	visibility:hidden;
}