@charset "utf-8";
/* CSS Document */
html, body, div, h1, h2, h3, h4, h5, h6, p, span, a, img, ol, ul, li, footer, header, section, article, aside, figure {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	box-sizing: border-box;
}
html {font-size: 62.5%;/* 10px */}
body {
	font-family: "Lato", "Noto Sans JP", "メイリオ", Meiryo, sans-serif;
	-webkit-text-size-adjust: 100%;
	background: #fff2f8 url("../img/bg.svg") center top/200px repeat;
	overflow-wrap: break-word;
	word-break: break-all;
	color: #221e1f;
	border-bottom: 20px solid #fe1c80;
	padding-bottom: 15vw;
}
html, body{
	overflow-x: hidden;
	-webkit-overflow-scrolling: touch;
}
header, footer {width: 100%;}
img {
	max-width:100%;
	margin:0;
	padding:0;
	vertical-align:bottom;
}
a img {border: none;}
a {-webkit-tap-highlight-color: rgba(237,185,206,0.50);}
a:link {
	color: #fe1c80;
	text-decoration: none;
}
a:visited {
	color: #fe1c80;
	text-decoration: none;
}
a:active {
	color: #fe1c80;
	text-decoration: none;
}
::-moz-selection {
	background-color: #b9ede0;
}
::selection {
	background-color: #b9ede0;
}
ul {
	padding-left: 2em;
	margin-bottom: 1em;
}
ol {
	padding-left: 2em;
	margin-bottom: 0.5em;
}
.pc {display: none;}
.marginB10 {margin-bottom: 1em;}
.marginB20 {margin-bottom: 2em;}
.flex_cont {
	display: flex;
	justify-content: space-between;
}
.flex_item2 {
	flex-basis: 50%;
}
.flex_item2 + .flex_item2 {text-align: right;}

.logo_box {
	width: 96vw;
	margin: 0 auto;
}
.flex_cont.caption_box {
	flex-wrap: wrap;
	position: relative;
	height: 66vw;
}
.flex_cont.caption_box .flex_item2 {
	flex-basis: 100%;
	position: relative;
	z-index: 10;
}
.flex_cont.caption_box .flex_item2 img {
	max-width: 54vw;
}
.flex_cont.caption_box .flex_item2 + .flex_item2 {
	position: absolute;
	z-index: 1;
}
.flex_cont.caption_box .flex_item2 + .flex_item2 img {
	max-width: 100%;
}
#catch{background: #fe1c80 url("../img/bg_h1.svg") center top/57px repeat;}
h1 {text-align: center;}
h2 {text-align: center;}
#prize,
#point,
#howto_tw,
#howto_web {
	width: 96vw;
	margin: 5vw auto;
	padding-bottom: 5vw;
	background-color: #FFF;
	border-radius: 5vw;
}
.flex_cont.prize {
	display: flex;
	flex-wrap: wrap;
}
.flex_cont.prize .flex_item2 {
	flex-basis: 100%;
}
.btn_point_box {
	width: 86vw;
	margin: 0 auto;
}
.flex_cont.btn {
	width: 96vw;
	margin: 7vw auto;
}
.flex_cont.btn .flex_item2 img {max-width: 46vw;}
.howto_tw02,
.howto_web01 {
	position: relative;
	z-index: 1;
}
#howto_tw .btn_dl {
	position: absolute;
	top: 17vw;
	left: 20vw;
	z-index: 10;
}
#howto_web .btn_dl {
	position: absolute;
	top: 17vw;
	left: 20vw;
	z-index: 10;
}
#howto_tw .btn_dl img,
#howto_web .btn_dl img {max-width: 38vw;}
#howto_tw .btn_apply,
#howto_web .btn_apply {text-align: center;}
#howto_tw .btn_apply img,
#howto_web .btn_apply img {max-width: 57vw;}



#socialhub {
	background-color: #FFF;
	margin: 10vw auto;
	padding-bottom:5vw;
}
h2.socialhub {padding:0;}
.social_box {
	width: 95.83%;
	max-width: 920px;
	margin: 0 auto 0;
}

/* for shutlerock */
.sr-sh-theme-card__wrapper {
	margin: 3% !important;
}
.ngdialog .sr-sh-theme-btn,
.sr-sh .sr-sh-theme-btn {
	color: transparent!important;
	background-color:transparent!important;
	border: none!important;
	border-radius: 0!important;
	padding: 0!important;
	margin: 0!important;
	width: 54vw;
	height: 12.5vw;
	background: url(../img/btn_more_sp.png) 0 0/cover no-repeat;
}
.ngdialog .sr-sh-theme-btn.selected,
.ngdialog .sr-sh-theme-btn:active,
.ngdialog .sr-sh-theme-btn:focus,
.ngdialog .sr-sh-theme-btn:hover,
.sr-sh .sr-sh-theme-btn.selected,
.sr-sh .sr-sh-theme-btn:active,
.sr-sh .sr-sh-theme-btn:focus,
.sr-sh .sr-sh-theme-btn:hover {
	color: transparent!important;
	background-color: transparent!important;
}
.sr-sh-theme-statistics__item--shares {display: none!important;}/* シェアボタン非表示 */
.sr-sh-theme-card__wrapper .sr-sh-sizer, .sr-sh-theme-item{
	width: 33.3333% !important;
}
.sr-sh-theme-card__wrapper .sr-sh-theme-card.hover,
.sr-sh-theme-card__wrapper .sr-sh-theme-card:hover,
.sr-sh-theme-card__wrapper .sr-sh-theme-card.hover .sr-sh-theme-card__media,
.sr-sh-theme-card__wrapper .sr-sh-theme-card:hover .sr-sh-theme-card__media {
	min-height: 0px;
	background: transparent;
}
.sr-sh-theme-card__wrapper .sr-sh-theme-card.hover, .sr-sh-theme-card__wrapper .sr-sh-theme-card:hover {
	min-height: 100px!important;
}
.sr-sh-theme-card__wrapper .sr-sh-theme-card.hover .sr-sh-theme-card__media, .sr-sh-theme-card__wrapper .sr-sh-theme-card:hover .sr-sh-theme-card__media {
	min-height: 100px!important;
}

/* ---------- for login window ------------- */
.sr-sh-filters.sr-sh-theme-filters.sr-sh-navigation.sr-sh-theme-navigation,
.sr-sh-signin__link.sr-sh-theme-signin__link,
.sr-sh-theme-facebook-wrapper {
	display: none;
}
.sr-sh hr, .ngdialog hr {
	margin-top: 0px;
	margin-bottom: 10px;
}
@media screen and (min-width: 700px) {
	.ngdialog.ngdialog-theme-default .ngdialog-content .sr-sh-theme-dialog-body {
		padding: 0 20px 20px 20px;
	}
}
.sr-sh-theme-rule {
	margin-top: 20px;
}

.sr-sh-theme-rule {
	display: none;
}

.sr-sh-theme-card__description-show {
	font-size: 11px;
}

@media screen and (max-width: 480px) {
	.sr-sh-theme-card__description-show {
		font-size: 7px;
	}
}

.ng-toast .ng-toast__message .alert {
	display: unset !important;
	font-size: 19px;
	font-weight: 600;
	width: 600px;
}
.sr-sh .alert {
	padding: 30px;
	margin-bottom: 20px;
	border: 1px solid transparent;
	border-radius: 2px;
}
.ngdialog.ngdialog-theme-default .ngdialog-content .sr-sh-theme-dialog-header {
	padding-right: 3em!important;
}
/* //for shutlerock */

#note,
#rules {
	background-color: #fff;
	max-width: 960px;
	margin: 0 auto 5vw;
	padding: 5vw;
}
h3 {
	font-size: 1.4rem;
	font-size: 14px;
	font-weight: 400;
	margin: 2em auto 0;
	text-indent: -0.5em;
}
h4 {
	font-size: 1.4rem;
	font-size: 14px;
	font-weight: 400;
}
#note p,
#rules p {
	font-size: 1.4rem;
	font-size: 14px;
	font-weight: 400;
}
#note p.indent,
#rules p.indent {
	text-indent: -1em;
	padding-left: 1em;
}
#note p.indent2 {
	text-indent: -7em;
	padding-left: 7em;
}
#note p.notice {
	font-size: 1.2rem;
	font-size: 12px;
	font-weight: 400;
}
#note li,
#rules li {
	font-size: 1.4rem;
	font-size: 14px;
	font-weight: 400;
}
#note a:link,
#rules a:link,
#note a:visited,
#rules a:visited {
	text-decoration: underline;
}
#note a:hover,
#rules a:hover,
#note a:active,
#rules a:active {
	text-decoration: none;
}

#page-top {
	margin: 0;
	position: fixed;
	bottom: 30px;
	right: 10px;
	font-size: 12px;
	z-index: 10;
}
#page-top a {
	background: #fe1c80;
	opacity: 0.5;
	text-decoration: none;
	color: #fff;
	width: 6em;
	height: 6em;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 50%;
}
#page-top a:hover {
	text-decoration: none;
	background: #fe1c80;
	opacity: 0.8;
}
