@charset "utf-8";
/*---------------------------------------------
Reset
---------------------------------------------*/

html {
	color: #333;
	overflow-y: scroll;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif;
	font-size: 62.5%;
	line-height:1.5;
}

h1, h2, h3, h4, h5, h6 { font-weight: normal; margin: 0; padding: 0; }
img { border: none; vertical-align: bottom; max-width: 100%; height: auto; margin: 0; padding: 0; }
div, dl, dt, dd, form, input, ul, ol, li, p, select, textarea, span, th, td { margin: 0; padding: 0;}
*, *:before, *:after { box-sizing: border-box;}

/*---------------------------------------------
Style
---------------------------------------------*/
body {
	text-align: center;
	margin: 0 auto;
	padding: 0;
	font-size:1.8rem;
}


.for_pc{
	display:block;
	margin:0 auto;
}

.for_sp{
	display:none;
	margin:0 auto;
}

/* sp */
@media screen and (max-width: 750px){

	body {
		font-size:1.5rem;
	}
	.for_pc{
		display:none;
		margin:0 auto;
	}
	.for_sp{
		display:block;
		margin:0 auto;
	}
}

/* =========================================================
共通
========================================================= */
.note{
	font-size: 1.6rem;
	text-align: left;
}
@media screen and (max-width: 750px){
	.note{
	font-size: 1.4rem;
	}
}

/* =========================================================
ヘッダー
========================================================= */
header{
	position: relative;
}

.haikei{
	width: 100%;
	display: block;
}

.subttl{
	background-color: #333;
	color: #FFF;
	font-size: 2.2rem;
	font-weight: 700;
	padding: 0.8rem 0;
}

.header_flex{
	display: flex;
	max-width: 1200px;
	margin: 2rem auto;
}

h1, .schedule_box{
	width: 50%;
	margin: 0 auto;
}

.schedule_box{
	padding: 2rem;
	margin-top: 3rem;
}

.schedule_ttl{
	background-color: #E50012;
	color: #FFF;
	font-size: 2rem;
	font-weight: 700;
	padding: 0.5rem 0;
	margin-bottom: 1rem;
}

.schedule{
	font-weight: 700;
	font-size: 3.4rem;
}

.schedule span{
	font-size: 2.4rem;
}

.red{
	color: #E50012;
}

.apipia{
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
}

.apipia img{
	max-width: 50vh;
	margin: 0 auto;
}

@media screen and (max-width: 750px){
	.subttl{
	background-color: #333;
	color: #FFF;
	font-size: 1.8rem;
	font-weight: 700;
	padding: 0.8rem 0;
}
	.header_flex{
	display: block;
	max-width: 90%;
	margin: 2rem auto;
}
	h1, .schedule_box{
	width: 100%;
	margin: 0 auto;
}
	.schedule{
	font-weight: 700;
	font-size: 2rem;
}
	.schedule span{
	font-size: 1.6rem;
}
.apipia img{
	/*max-width: 70%;*/
    max-width: 70vw;
	margin: 0 auto;
}
}

/* =========================================================
100万人majicaセール
========================================================= */
#majica_sale{
	background: url("../img/100majica_haikei.png"), #191F61;
	background-repeat: no-repeat, no-repeat;
	background-size: contain ,auto;
	padding: 8rem  0 4rem;
}

.majica_sale_logo{
	max-width: 50%;
	margin: 0 auto 0;
}

.majica_sale_txt{
	color: #FFF;
	font-weight: 700;
	font-size: 2.6rem;
}

.majica_sale_btn a{
	display: inline-block;
	padding: 1.5rem 6rem;
	background-color: #FFF;
	color: #231815;
	font-weight: 700;
	font-size: 2.6rem;
	margin: 2rem 0;
	border-radius: 100px;
	text-decoration: none;
}

.majica_sale_btn a:hover{
	opacity: 0.8;
}

@media screen and (max-width: 750px){
	#majica_sale{
	background: url("../img/100majica_haikei_sp.png"), #191F61;
	background-repeat: no-repeat, no-repeat;
	background-size: contain ,auto;
	padding: 4rem  0 4rem;
}
	.majica_sale_logo{
	max-width: 90%;
	margin: 0 auto 0;
}
	.majica_sale_txt{
		font-size: 1.8rem;
		margin-top: 1rem;
	}
	
	.majica_sale_btn a{
		font-size: 2rem;
	}
}
/* =========================================================
キャンペーン概要
========================================================= */
#about{
	border-top: solid 4px #000;
	border-left: solid 4px #000;
	border-right: solid 4px #000;
	background-color: #E50012;
}

.about_inner{
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	padding-bottom: 10rem;
}

.about_ttl{
	font-weight: 700;
	font-size: 2.4rem;
	margin: 4rem 0 2rem;
	padding: 0.5rem 0;
	background-image: linear-gradient(90deg, rgba(224, 162, 8, 1), rgba(255, 248, 147, 1) 50%, rgba(224, 162, 8, 1));
}

.nuigurumi{
	max-width: 80%;
	margin: 4rem auto;
}

.about_box{
	background-color: #FFF;
	border-radius: 30px;
	padding: 4rem 2rem 6rem;
	max-width: 900px;
	margin: 0 auto;
	font-weight: 800;
	font-size: 2.6rem;
	line-height: 1.8;
	box-shadow: 4px 4px 0 #A20000;
}

.about_box p span{
	color: #E50012;
}

.apitan{
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0;
	max-width: 32%;
	margin: 0 auto;
}
@media screen and (max-width: 750px){
	.about_inner{
		padding-bottom: 7rem;
	}
	.about_ttl{
		font-size: 1.8rem;
		margin: 2rem 0 1rem;
	}
	.nuigurumi{
		max-width: 95%;
	}
	
	.about_box{
		max-width: 90%;
		font-size: 2rem;
		line-height: 1.7;
		border-radius: 20px;
		padding: 4rem 2rem 5rem;
	}
	
	.apitan{
		max-width: 60%;
	}
}

/* =========================================================
キャンペーン内容
========================================================= */
#content{
	display: grid;
	grid-template-columns: 1fr 1fr;
	border-top: solid 4px #000;
	border-left: solid 4px #000;
	border-right: solid 4px #000;
}

.movie, .howto{
	width: 100%;
	margin: 0 auto;
	padding-bottom: 2rem;
}

.movie{
	border-right: solid 4px #000;
}

.movie{
	background-color: #FFD107;
}
.howto{
	background-color: #FFF;
}

.content_ttl{
	max-width: 50%;
	margin: 4rem auto;
}

/* ===動画 movie=== */

.movie_btn a{
	display: inline-block;
	padding: 1.5rem 4rem;
	background-color:#E50012;
	color: #FFF;
	font-weight: 700;
	font-size: 2rem;
	margin: 4rem 0 0;
	text-decoration: none;
}

.movie_btn a:hover{
	opacity: 0.8;
}

.douga{
	max-width: 80%;
	margin: 0 auto 0;
}

/* ===応募方法 howto=== */

.howto_inner{
	max-width: 80%;
	margin: 0 auto;
	padding-bottom: 2rem;
}

.howto_box{
	position: relative;
	border: solid 4px #000;
	background-color: #FFD107;
	padding: 2rem 2rem 2rem 8rem;
	text-align: left;
	font-weight: 800;
	font-size: 2rem;
	color: #231815;
	margin-bottom: 2rem;
	line-height: 1.8;
}

.number{
	position: absolute;
	top: 0;
	left: 0;
}

.follow_btn, .post_btn{
	text-align: center;
}
	
.follow_btn a, .post_btn a{
		display: inline-block;
	padding: 1.5rem 6rem;
		font-weight: 700;
	font-size: 2rem;
	border-radius: 100px;
	text-decoration: none;
	margin: 1rem 0 0;
}

.follow_btn a{
	background-color: #231815;
	color: #FFF;
}

.post_btn a{
	background-color: #FFF;
	color: #231815;
}

.follow_btn a:hover, .post_btn a:hover{
	opacity: 0.8;
}

@media screen and (max-width: 750px){
	#content{
		display: block;
	}
	.content_ttl{
		max-width: 80%;
		padding-top: 2rem;
		margin: 0 auto 2rem;
	}
/* ===動画 movie=== */
	.movie{
	border-right: solid 0px #000;
	border-bottom: solid 4px #000;
}
	.movie_btn a{
			display: block;
	padding: 1.5rem 0;
				font-size: 2.2rem;
		max-width: 90%;
		margin: 2rem auto 0;
	}
/* ===応募方法 howto=== */
	.howto_inner{
		max-width: 90%;
	}
	.howto_box{
		padding: 8rem 2rem 2rem;
		font-size: 1.8rem;
	}
	
	.howto .note{
		margin-bottom: 1rem;
	}
	
	.number{
	position: absolute;
	top: 0;
	left: 0;
}
	
	.follow_btn a, .post_btn a{
					display: block;
	padding: 1.5rem 0;
				font-size: 1.8rem;
		max-width: 100%;
		margin: 2rem auto 1rem;
	}
}

/* =========================================================
ループ　文字
========================================================= */
.loop02 {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    display: flex;
    overflow: hidden;
	background-color: #231815;
}
.loop02__box {
    display: flex;
    animation: loop-list 50s linear infinite;
}
.loop02__item {
    width: calc(100vw / 4);
    display: block;
}
.loop02__item img {
    width: 80%;
}

.loop02 ul{
	list-style-type: none;
}

@keyframes loop-list {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-100%);
    }
}
.loop02:hover .loop02__box {
    animation-play-state: paused;
}

@media screen and (max-width: 750px){
	.loop02__item {
    width: calc(100vw / 2);
    display: block;
}
	.loop02__item img {
    width: 100%;
}
}

/* =========================================================
応募規約
========================================================= */
#kiyaku{
	border: solid 4px #000;
	background-color: #E50012;
	padding: 6rem 0 4rem;
}

#kiyaku .note{
	text-align: center;
}

.kiyaku_inner{
	max-width: 900px;
	margin: 0 auto;
}

.kiyaku_ttl{
	position: absolute;
	top: -2rem;
	left: 0;
	right: 0;
	max-width: 40%;
	margin: 0 auto;
}

.kiyaku_box{
	position: relative;
	background-color: #FFF;
	border-radius: 20px;
	padding: 6rem 4rem 4rem;
	margin-bottom: 4rem;
}

.present{
	font-weight: 600;
	font-size: 2.2rem;
	margin-bottom: 2rem;
}

.present span{
	font-weight: 500;
	font-size: 1.8rem;
}

.center{
	font-weight: 500;
	margin-bottom: 2rem;
}

#kiyaku ul{
	text-align: left;
	list-style-type: none;
}

#kiyaku li{
	margin: 1rem 0;
}

#kiyaku a{
	color: #E50012;
}

#kiyaku a:hover{
	background-color: #E50012;
	color: #FFF;
}

@media screen and (max-width: 750px){
	.kiyaku_inner{
		max-width: 90%;
	}
	.kiyaku_ttl{
		max-width: 80%;
	}
	.kiyaku_box{
		border-radius: 10px;
		padding: 3rem 2rem 2rem;
	}
	#kiyaku .note{
	text-align: left;
}
	.present{
		margin-top: 1rem;
		font-size: 2rem;
	}
	.present span{
	font-weight: 500;
	font-size: 1.6rem;
}
}

/* =========================================================
ページトップ リンク
========================================================= */

/*リンクの形状*/
#page-top a{
	display: flex;
	justify-content:center;
	align-items:center;
	text-align: center;
	text-transform: uppercase; 
	text-decoration: none;
	font-size:1.6rem;
	transition:all 0.3s;
}

#page-top a:hover{
	opacity: 0.8;
}

/*リンクを右下に固定*/
#page-top {
	position: fixed;
	right: 2%;
	bottom:2%;
	z-index: 2;
    /*はじめは非表示*/
	opacity: 0;
	transform: translateY(100px);
}

/*　上に上がる動き　*/

#page-top.UpMove{
	animation: UpAnime 0.5s forwards;
    bottom: 10px;
}
@keyframes UpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }
  to {
    opacity: 1;
	transform: translateY(0);
  }
}

/*　下に下がる動き　*/

#page-top.DownMove{
	animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
  from {
  	opacity: 1;
	transform: translateY(0);
  }
  to {
  	opacity: 1;
	transform: translateY(100px);
  }
}

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

#page-top.UpMove {
    animation: UpAnime 0.5s forwards;
    bottom: 10px;
}
}

@media screen and (max-width: 750px){
	#page-top {
	right: 1%;
	bottom:2%;
	}
	#page-top a{
		width: 80%;
		height: 80%;
	}
}

/*---------------------------------------------
フッター
---------------------------------------------*/

footer{
	width: 100%;
	padding: 20px 0;
	font: Arial, Helvetica, sans-serif;
	background: #2b2b2b;
	font-size: 90%;
}

footer a{
	color: #fff;
	text-decoration: none;
}

footer address{
	color: #fff;
}

/* sp */
@media screen and (max-width: 520px){
	footer{
		padding:10px 0;
	}

	footer a{
	font-size: 0.5em;
	}
	
	#page-top a{
	margin: 0 -10px 0 0;
	}
}



