@charset "UTF-8";
/* -----------------------------------------------------------
reset
----------------------------------------------------------- */
* {
	margin: 0;
	padding: 0;
}

html {
	overflow-y: scroll;
}

div, h1, h2, h3, h4, h5, h6, p, dl, dt, dd, ol, ul, li, form, input, textarea, button, table, tr, th, td, article, aside, footer, header, hgroup, nav, section, a, span {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
	margin: 0;
	padding: 0;
}

address, caption, cite, code, dfn, em, th, var {
	font-style: normal;
	font-weight: normal;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

q:before, q:after {
	content: '';
}

object,
embed {
	vertical-align: top;
}

hr, legend {
	display: none;
	border: none;
}

abbr, acronym, fieldset {
	border: 0;
}

tr, th, td, caption {
	vertical-align: top;
	font-style: normal;
	font-weight: normal;
	text-align: left;
}

ol, ul {
	list-style: none;
}

h1, h2, h3, h4, h5, h6 {
	font-style: normal;
	font-weight: normal;
	font-size: 100%;
}

img {
	border: 0;
	font-size: 0;
	line-height: 0;
	vertical-align: bottom;
}

html {
	overflow-y: scroll;
}

html, body {
	background: #f7b52b;
}

body {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo","Osaka","ＭＳ Ｐゴシック", "MS P Gothic",Verdana,Arial, Helvetica, sans-serif;
	color: #222222;
	line-height: 1.6;
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	min-width: 1100px;
	overflow: hidden;
}

@media only screen and (max-width: 750px) {
	body {
		min-width: 320px;
		font-size: 12px;
	}
}

input, textarea {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo","Osaka","ＭＳ Ｐゴシック", "MS P Gothic",Verdana,Arial, Helvetica, sans-serif;
}

strong {
	font-weight: bold;
}

a {
	color: #222222;
	text-decoration: none;
	transition: opacity .3s;
}

a:focus {
	outline: none;
}

@media screen and (min-width: 751px) {
	a:hover {
		color: #222222;
		opacity: .8;
	}
}

img {
	max-width: 100%;
	height: auto;
}

@media screen and (min-width: 751px) {
	.only-sp {
		display: none;
	}
}

@media screen and (max-width: 750px) {
	.only-pc {
		display: none;
	}
}

.tpl-inner {
	width: 1100px;
	margin: auto;
}

@media screen and (max-width: 750px) {
	.tpl-inner {
		width: 100%;
	}
}

#header {
	background-color: #fdd000;
	padding: 7px 0 11px;
	overflow: hidden;
}

@media screen and (max-width: 750px) {
	#header {
		padding: 3px 0 5px;
	}
}

#header .logo {
	float: right;
	margin-right: 20px;
	font-size: 0;
}

@media screen and (max-width: 750px) {
	#header .logo {
		width: 86px;
		height: auto;
		margin-right: 10px;
	}
}

#footer {
	color: #FFF;
	position: relative;
}

#footer .footer-head {
	background-color: #e71a0f;
	padding: 64px 0 130px;
}

@media screen and (max-width: 750px) {
	#footer .footer-head {
		padding: 8% 4% 23%;
	}
}

#footer .footer-head .tpl-inner {
	display: flex;
}

@media screen and (max-width: 750px) {
	#footer .footer-head .tpl-inner {
		display: block;
	}
}

#footer .footer-head .title {
	width: 244px;
}

@media screen and (max-width: 750px) {
	#footer .footer-head .title {
		width: 100%;
		margin-bottom: 6%;
	}
}

#footer .footer-head .title img {
	width: 190px;
	height: auto;
}

@media screen and (max-width: 750px) {
	#footer .footer-head .title img {
		width: 45%;
	}
}

#footer .footer-head .title span {
	display: block;
	font-size: 14px;
	margin-top: 1em;
}

@media screen and (max-width: 750px) {
	#footer .footer-head .title span {
		font-size: 10px;
	}
}

#footer .footer-head .caution {
	margin-top: 1em;
	font-size: 14px;
	font-weight: 300;
	text-indent: -1em;
	margin-left: 1em;
}

@media screen and (max-width: 750px) {
	#footer .footer-head .caution {
		font-size: 11px;
	}
}

#footer .footer-bot {
	background-color: #f7b52b;
	padding: 7px 0 11px;
	overflow: hidden;
}

#footer .footer-bot .logo {
	float: right;
	margin-right: 20px;
	font-size: 0;
}

@media screen and (max-width: 750px) {
	#footer .footer-bot .logo {
		width: 86px;
		height: auto;
		margin-right: 10px;
	}
}

#footer .blank {
	color: #FFF;
	text-decoration: underline;
	padding-right: 18px;
	background: url(../img/icon-blank.png) right 50% no-repeat;
}

.pagetop {
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 10;
	display: none;
}

@media screen and (max-width: 750px) {
	.pagetop {
		width: 64px;
		right: 3%;
		bottom: 5px;
	}
}

.pagetop.absolute {
	position: absolute;
	top: -140px;
	bottom: auto;
}

@media screen and (max-width: 750px) {
	.pagetop.absolute {
		top: -80px;
	}
}

.pagetop a {
	display: block;
}

@media screen and (min-width: 751px) {
	.pagetop a {
		width: 112px;
		position: relative;
		text-align: right;
	}
}

.main-kv {
	background: url(../img/bg-main-pc.jpg) 50% 0 no-repeat #fdd000;
}

@media screen and (max-width: 750px) {
	.main-kv {
		background: url(../img/bg-main-sp.jpg) 0 0 no-repeat;
		background-size: contain;
	}
}

.main-kv .tpl-inner {
	position: relative;
	height: 562px;
}

@media screen and (max-width: 750px) {
	.main-kv .tpl-inner {
		height: 141.73333vw;
		text-align: center;
		padding: 8.4vw 7.2vw 0;
	}
}

.main-kv .kv-left,
.main-kv .kv-right {
	position: absolute;
	top: 39px;
	transition: transform .6s;
	transform: scale(0);
}

@media screen and (max-width: 750px) {
	.main-kv .kv-left,
	.main-kv .kv-right {
		position: static;
	}
}

.complete .main-kv .kv-left, .complete
.main-kv .kv-right {
	transform: scale(1);
}

.main-kv .kv-left {
	left: -44px;
	z-index: 2;
}

.main-kv .kv-right {
	right: -80px;
	z-index: 1;
	transition-delay: .8s;
}

.sec-limited {
	text-align: left;
	position: relative;
	z-index: 3;
}

.sec-limited .bg-wrap {
	background-color: #e71a0f;
	padding: 12px 0 17px;
	position: relative;
	z-index: 2;
}

@media screen and (max-width: 750px) {
	.sec-limited .bg-wrap {
		padding: 3% 5% 3% 8%;
	}
}

.sec-limited .tpl-inner {
	padding-left: 40px;
	position: relative;
}

@media screen and (max-width: 750px) {
	.sec-limited .tpl-inner {
		padding-left: 0;
	}
}

.sec-limited .tpl-inner.close {
	padding-left: 0;
	text-align: center;
}

.sec-limited .tpl-inner .limit {
	opacity: .5;
}

.sec-limited .close-txt {
	position: absolute;
	z-index: 2;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}

@media screen and (max-width: 750px) {
	.sec-limited .close-txt {
		top: -20%;
		left: -9%;
		transform: translateX(0);
		width: 114%;
		max-width: initial;
	}
}

.nav-wrap {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1100px;
}

.nav-wrap.fixed {
	position: fixed;
}

.nav-btn {
	position: absolute;
	right: 15px;
	top: -20px;
	display: flex;
}

@media screen and (max-width: 750px) {
	.nav-btn {
		position: fixed;
		top: auto;
		right: auto;
		bottom: 5px;
		left: 3%;
		z-index: 20;
		width: 142px;
	}
	.nav-btn.absolute {
		position: absolute;
		bottom: auto;
		top: -78px;
	}
}

@media screen and (min-width: 751px) {
	.nav-btn.sp-nav {
		display: none;
	}
}

.nav-btn .item {
	position: relative;
}

@media screen and (max-width: 750px) {
	.nav-btn .item {
		width: 50%;
	}
}

.nav-btn .item:first-child {
	margin-right: -20px;
	z-index: 2;
}

@media screen and (max-width: 750px) {
	.nav-btn .item:first-child {
		margin-right: 0;
	}
}

.sec-title {
	position: relative;
	z-index: 3;
	font-size: 0;
	display: flex;
	justify-content: center;
	align-items: center;
}

.sec-title .icon {
	margin-right: 30px;
	animation: icon 1.5s steps(2, start) infinite;
}

@media screen and (max-width: 750px) {
	.sec-title .icon {
		margin-right: 3%;
	}
}

.sec-title .sub {
	position: absolute;
	left: 50%;
	bottom: -13px;
	transform: translateX(-50%);
}

@media screen and (max-width: 750px) {
	.sec-title .sub {
		bottom: 1.6vw;
	}
}

.sec-present {
	text-align: center;
	position: relative;
	z-index: 2;
}

.sec-present:after {
	content: '';
	display: block;
	width: calc(100% + 20px);
	height: 100px;
	background: url(../img/bg-present-bot.png) 0 0 repeat;
	position: absolute;
	z-index: 1;
	bottom: -30px;
	left: 0;
	transform: rotate(2deg);
}

@media screen and (max-width: 750px) {
	.sec-present:after {
		background-size: 2%;
		bottom: -1%;
	}
}

.sec-present .bg-wrap {
	background: url(../img/bg-present.png) 0 0 repeat #fdd000;
	position: relative;
	z-index: 2;
	padding-top: 92px;
	padding-bottom: 88px;
}

@media screen and (max-width: 750px) {
	.sec-present .bg-wrap {
		background-size: 6%;
		padding: 10% 0 4%;
	}
}

.sec-present .main-read {
	text-align: center;
}

@media screen and (max-width: 750px) {
	.sec-present .main-read {
		padding: 0 6% 10%;
	}
}

.sec-present .present-area {
	width: 1100px;
	padding-top: 80px;
	margin: 0 auto;
}

@media screen and (max-width: 750px) {
	.sec-present .present-area {
		width: 100%;
		padding-top: 6%;
	}
}

.sec-present .present-area .sec-title {
	margin-bottom: 44px;
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .sec-title {
		margin-bottom: 10%;
	}
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .sec-title .icon {
		width: 13.06667vw;
		padding-bottom: 2.66667vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .sec-title .main {
		width: 44.13333vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .sec-title .sub {
		width: 10.66667vw;
	}
}

.sec-present .present-area .ph {
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .ph {
		margin-top: -8.4vw;
	}
}

.sec-present .present-area .price {
	width: 792px;
	position: absolute;
	bottom: 200px;
	left: 150px;
	z-index: 1;
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .price {
		width: 84.26667vw;
		bottom: 30.13333vw;
		left: 8.26667vw;
	}
}

.sec-present .present-area .left,
.sec-present .present-area .right {
	position: absolute;
	top: 0;
	z-index: 2;
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .left,
	.sec-present .present-area .right {
		width: 50%;
		top: 23%;
	}
}

@media screen and (min-width: 751px) {
	.sec-present .present-area .left {
		left: -50px;
	}
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .left {
		left: 0;
	}
}

@media screen and (min-width: 751px) {
	.sec-present .present-area .right {
		right: -82px;
	}
}

@media screen and (max-width: 750px) {
	.sec-present .present-area .right {
		right: 0;
	}
}

.sec-present .step1,
.sec-present .step2,
.sec-present .step3 {
	transition: all .5s;
}

.sec-present .step1 {
	opacity: 0;
	transform: translateY(20px);
}

.sec-present .step2 {
	opacity: 0;
	transform: scale(0);
}

.sec-present .step3 {
	opacity: 0;
}

.sec-present .step3.left {
	transform: translateX(-20px);
}

.sec-present .step3.right {
	transform: translateX(20px);
}

.sec-present .is-show .step1 {
	opacity: 1;
	transform: translateY(0);
	transition-delay: .4s;
}

.sec-present .is-show .step2 {
	opacity: 1;
	transform: scale(1);
	transition-delay: .8s;
}

.sec-present .is-show .step3 {
	opacity: 1;
	transform: translateX(0);
	transition-delay: 1.2s;
}

.sec-howto {
	text-align: center;
	position: relative;
	z-index: 1;
	background: url(../img/bg-howto.png) 0 0 repeat #fdd000;
	padding-top: 146px;
	padding-bottom: 135px;
}

@media screen and (max-width: 750px) {
	.sec-howto {
		padding-top: 15%;
		padding-bottom: 24%;
		background-size: 14%;
	}
}

.sec-howto .tpl-inner {
	width: 960px;
}

@media screen and (max-width: 750px) {
	.sec-howto .tpl-inner {
		width: 100%;
	}
}

.sec-howto .sec-title {
	margin-bottom: 132px;
}

@media screen and (max-width: 750px) {
	.sec-howto .sec-title {
		margin-bottom: 16%;
	}
}

.sec-howto .sec-title .icon {
	margin-right: 10px;
}

@media screen and (max-width: 750px) {
	.sec-howto .sec-title .icon {
		margin-right: 1%;
		width: 15.46667vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-howto .sec-title .main {
		width: 38.4vw;
	}
}

.sec-howto .sec-title .sub {
	bottom: 0;
}

@media screen and (max-width: 750px) {
	.sec-howto .sec-title .sub {
		width: 13.73333vw;
		bottom: 0;
	}
}

.sec-howto .inq-btn {
	width: 660px;
	margin: 0 auto 65px;
}

@media screen and (max-width: 750px) {
	.sec-howto .inq-btn {
		width: 90%;
		margin-bottom: 5%;
	}
}

.sec-howto .inq-btn li + li {
	margin-top: 30px;
}

@media screen and (max-width: 750px) {
	.sec-howto .inq-btn li + li {
		margin-top: 5%;
	}
}

.sec-howto .more-btn {
	text-align: center;
	margin-bottom: 74px;
}

@media screen and (max-width: 750px) {
	.sec-howto .more-btn {
		margin-bottom: 5%;
	}
}

.sec-howto .more-btn a {
	display: inline-block;
	border-radius: 10px;
	background-color: #000;
	padding: 15px;
	width: 600px;
	text-align: center;
	position: relative;
	font-size: 0;
}

@media screen and (max-width: 750px) {
	.sec-howto .more-btn a {
		border-radius: 5px;
		width: 84%;
		padding: 4% 23%;
	}
}

.sec-howto .more-btn span {
	position: absolute;
	top: 50%;
	right: 5%;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	border: 2px solid #FFF;
	border-radius: 50%;
}

@media screen and (max-width: 750px) {
	.sec-howto .more-btn span {
		width: 16px;
		height: 16px;
		border-width: 1px;
	}
}

.sec-howto .more-btn span:before, .sec-howto .more-btn span:after {
	content: '';
	display: block;
	width: 18px;
	height: 2px;
	background-color: #FFF;
	position: absolute;
	top: calc(50% - 1px);
	left: calc(50% - 9px);
}

@media screen and (max-width: 750px) {
	.sec-howto .more-btn span:before, .sec-howto .more-btn span:after {
		width: 10px;
		height: 1px;
		top: calc(50% - .5px);
		left: calc(50% - 5px);
	}
}

.sec-howto .more-btn span:after {
	transform: rotate(90deg);
}

.sec-howto.close .tpl-inner {
	position: relative;
}

.sec-howto.close .close-wrap {
	position: absolute;
	z-index: 10;
	left: 0;
	top: -20px;
	width: 100%;
	height: calc(100% + 20px + 30px);
	background-color: rgba(0, 0, 0, 0.5);
	text-align: center;
	padding-top: 95px;
}

@media screen and (max-width: 750px) {
	.sec-howto.close .close-wrap {
		padding: 10% 16%;
		top: -8%;
		width: 94%;
		left: 3%;
		height: 112%;
	}
}

.sns-list {
	display: flex;
	justify-content: center;
}

@media screen and (max-width: 750px) {
	.sns-list {
		width: 84%;
		margin: auto;
	}
}

.sns-list li {
	width: 260px;
	height: 60px;
	text-align: center;
}

@media screen and (max-width: 750px) {
	.sns-list li {
		width: calc(90% / 3);
		height: auto;
	}
}

.sns-list li:not(:last-child) {
	margin-right: 40px;
}

@media screen and (max-width: 750px) {
	.sns-list li:not(:last-child) {
		margin-right: 5%;
	}
}

.sns-list li.is-show:nth-child(2) {
	transition-delay: .2s;
}

.sns-list li.is-show:nth-child(3) {
	transition-delay: .4s;
}

.sns-list a {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #FFF;
	font-size: 15px;
	font-weight: 700;
}

@media screen and (max-width: 750px) {
	.sns-list a {
		display: block;
		font-size: 10px;
		text-align: center;
		padding: 17%;
	}
}

.sns-list a img {
	width: auto;
	height: 28px;
	margin-right: 13px;
}

@media screen and (max-width: 750px) {
	.sns-list a img {
		height: 8vw;
		margin-right: 0;
		margin-bottom: 3%;
	}
}

.sns-list .twitter {
	background-color: #19a1f2;
}

.sns-list .facebook {
	background-color: #4167b2;
}

.sns-list .line {
	background-color: #00b830;
}

.sec-post {
	text-align: center;
	position: relative;
	z-index: 2;
}

.sec-post:before, .sec-post:after {
	content: '';
	display: block;
	width: calc(100% + 20px);
	height: 100px;
	position: absolute;
	z-index: 1;
	left: 0;
	transform: rotate(2deg);
}

.sec-post:before {
	background: url(../img/bg-post.png) 0 0 repeat;
	top: -30px;
}

@media screen and (max-width: 750px) {
	.sec-post:before {
		background-size: 2%;
		top: -9%;
	}
}

.sec-post:after {
	background: url(../img/bg-post.png) 0 0 repeat;
	bottom: -30px;
}

@media screen and (max-width: 750px) {
	.sec-post:after {
		background-size: 2%;
		bottom: -4%;
	}
}

.sec-post .bg-wrap {
	background-color: #f7b52b;
	padding-top: 78px;
	padding-bottom: 118px;
	position: relative;
	z-index: 2;
}

@media screen and (max-width: 750px) {
	.sec-post .bg-wrap {
		padding-top: 6%;
		padding-bottom: 10%;
	}
}

.sec-post .bg-wrap:before, .sec-post .bg-wrap:after {
	content: '';
	display: block;
	width: calc(50% - 230px);
	height: 100%;
	position: absolute;
	top: 0;
	z-index: 1;
}

@media screen and (max-width: 750px) {
	.sec-post .bg-wrap:before, .sec-post .bg-wrap:after {
		width: 22%;
		height: 27vw;
	}
}

.sec-post .bg-wrap:before {
	left: 0;
	background: url(../img/bg-post-ttl-left.png) right 100px repeat-x;
}

@media screen and (max-width: 750px) {
	.sec-post .bg-wrap:before {
		background-size: auto 44%;
		background-position: right 80%;
	}
}

.sec-post .bg-wrap:after {
	right: 0;
	background: url(../img/bg-post-ttl-right.png) 0 100px repeat-x;
}

@media screen and (max-width: 750px) {
	.sec-post .bg-wrap:after {
		background-size: auto 44%;
		background-position: 0 80%;
	}
}

.sec-post .sec-title {
	margin-bottom: 112px;
	z-index: 2;
}

@media screen and (max-width: 750px) {
	.sec-post .sec-title {
		margin-bottom: 14%;
	}
}

.sec-post .sec-title .sub {
	bottom: -36px;
}

@media screen and (max-width: 750px) {
	.sec-post .sec-title .sub {
		width: 29.33333vw;
		bottom: -5.33333vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-post .sec-title .icon {
		width: 16vw;
		margin-right: 3%;
	}
	.sec-post .sec-title .main {
		width: 27.33333vw;
	}
}

.sec-movie {
	text-align: center;
	position: relative;
	z-index: 1;
	background: url(../img/bg-movie.png) 0 0 repeat;
	padding-top: 121px;
	padding-bottom: 163px;
}

@media screen and (max-width: 750px) {
	.sec-movie {
		background-size: 10%;
		padding: 12% 4% 100px;
	}
}

.sec-movie .sec-title {
	margin-bottom: 30px;
}

@media screen and (max-width: 750px) {
	.sec-movie .sec-title {
		margin-bottom: 4%;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .sec-title .main {
		width: 32.93333vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .sec-title .icon {
		width: 16.53333vw;
	}
}

.sec-movie .label {
	margin-bottom: 25px;
}

@media screen and (max-width: 750px) {
	.sec-movie .label {
		width: 32vw;
		margin: 0 auto 5%;
	}
}

.sec-movie .col3 .mv-item {
	width: calc((100% - 40px) / 3);
}

@media screen and (min-width: 751px) {
	.sec-movie .col3 .mv-item:nth-child(n + 4) {
		margin-top: 40px;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .col3 .mv-item {
		width: 100%;
	}
	.sec-movie .col3 .mv-item + .mv-item {
		margin-top: 5%;
	}
}

.sec-movie .cont-webcm {
	margin-bottom: 100px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-webcm {
		padding: 0 10%;
		margin-bottom: 10%;
	}
}

.sec-movie .cont-webcm .col1 {
	width: 603px;
	margin: 0 auto;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-webcm .col1 {
		width: 100%;
	}
}

.sec-movie .cont-webcm .col1 .bg.none {
	height: 333px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-webcm .col1 .bg.none {
		height: 40vw;
	}
}

.sec-movie .cont-webcm .col3 {
	width: 940px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-webcm .col3 {
		width: 100%;
		display: block;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-webcm .col3 .bg.none {
		height: 40vw;
	}
}

.sec-movie .cont-howto {
	margin-bottom: 135px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-howto {
		margin-bottom: 13%;
	}
}

.sec-movie .cont-howto .col3 {
	width: 940px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-howto .col3 {
		width: 100%;
	}
	.sec-movie .cont-howto .col3 .mv-item {
		width: calc((100% - 3%) / 2);
	}
	.sec-movie .cont-howto .col3 .mv-item + .mv-item {
		margin-top: 0;
	}
	.sec-movie .cont-howto .col3 .mv-item:nth-child(n + 3) {
		margin-top: 5%;
	}
}

.sec-movie .cont-othercamp .sec-title {
	margin-bottom: 100px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .sec-title {
		margin-bottom: 18%;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .sec-title .main {
		width: 62.13333vw;
	}
}

.sec-movie .cont-othercamp .sec-title .sub {
	bottom: -50px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .sec-title .sub {
		width: 32.8vw;
		bottom: -8vw;
	}
}

.sec-movie .cont-othercamp .txt-link {
	margin-top: 70px;
	margin-bottom: 30px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .txt-link {
		margin: 8% auto 6%;
		width: 10.26667vw;
	}
}

.sec-movie .cont-othercamp .link-item {
	display: inline-block;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .link-item {
		padding: 0 5%;
	}
}

.sec-movie .cont-othercamp .link-item + .link-item {
	margin-top: 23px;
}

@media screen and (max-width: 750px) {
	.sec-movie .cont-othercamp .link-item + .link-item {
		margin-top: 5%;
	}
}

@media screen and (min-width: 751px) {
	.sec-movie .mv-wrap.delay1 .is-show:nth-child(2) {
		transition-delay: .2s;
	}
	.sec-movie .mv-wrap.delay1 .is-show:nth-child(3) {
		transition-delay: .4s;
	}
	.sec-movie .mv-wrap.delay2 .is-show:nth-child(2), .sec-movie .mv-wrap.delay2 .is-show:nth-child(5) {
		transition-delay: .2s;
	}
	.sec-movie .mv-wrap.delay2 .is-show:nth-child(3), .sec-movie .mv-wrap.delay2 .is-show:nth-child(6) {
		transition-delay: .4s;
	}
}

.sec-movie .mv-wrap + .mv-wrap {
	margin-top: 25px;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap + .mv-wrap {
		margin-top: 5%;
	}
}

.sec-movie .mv-wrap .mv-item a {
	position: relative;
	display: block;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .mv-item a {
		margin-bottom: 5%;
	}
}

.sec-movie .mv-wrap .mv-item a:after {
	content: '';
	display: block;
	width: 64px;
	height: 64px;
	background: url(../img/icon-play.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	left: calc(50% - 32px);
	top: calc(50% - 32px);
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .mv-item a:after {
		width: 36px;
		height: 36px;
		left: calc(50% - 18px);
		top: calc(50% - 18px);
	}
}

.sec-movie .mv-wrap .bg {
	background-color: #b5b5b5;
	border: 5px solid #FFF;
	border-radius: 10px;
	width: 100%;
	margin-bottom: 15px;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .bg {
		margin-bottom: 2%;
		border-width: 3px;
	}
}

.sec-movie .mv-wrap .bg.none {
	background-image: url(../img/txt-comingsoon.png);
	background-position: 50% 50%;
	background-repeat: no-repeat;
	background-size: 70%;
	height: 175px;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .bg.none {
		height: 40vw;
	}
}

.sec-movie .mv-wrap p {
	text-align: left;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.4;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap p {
		font-size: 12px;
	}
}

.sec-movie .mv-wrap .num {
	overflow: hidden;
}

.sec-movie .mv-wrap .num dt {
	float: left;
	font-size: 0;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .num dt {
		width: 5.06667vw;
	}
}

.sec-movie .mv-wrap .num dd {
	text-align: left;
	margin-top: -5px;
	padding-left: 50px;
	font-size: 22px;
	font-weight: 700;
}

@media screen and (max-width: 750px) {
	.sec-movie .mv-wrap .num dd {
		font-size: 12px;
		margin-top: -3px;
		padding-left: 6.66667vw;
	}
}

@media screen and (max-width: 750px) {
	.sec-movie .bnr-wrap {
		padding: 0 5%;
	}
}

@media screen and (max-width: 750px) {
	.mfp-container {
		padding: 0 3%;
	}
}

.mfp-bg {
	opacity: .6;
}

.mfp-wrap {
	min-width: 1100px;
}

@media screen and (max-width: 750px) {
	.mfp-wrap {
		min-width: 100%;
	}
}

.mfp-content {
	max-width: 1100px;
}

.mfp-content .mfp-iframe-scaler {
	overflow: auto;
}

.modal-wrap {
	background-color: #FFF;
	padding: 12% 0 8%;
	border-radius: 20px;
	position: relative;
}

@media screen and (max-width: 750px) {
	.modal-wrap {
		padding: 16% 0 5%;
		border-radius: 10px;
	}
}

.modal-wrap .inner {
	width: 960px;
	margin: 0 auto;
}

@media screen and (max-width: 750px) {
	.modal-wrap .inner {
		width: 100%;
		padding: 0 3%;
	}
}

.popup-modal-close {
	position: absolute;
	top: -40px;
	right: 0;
	width: 33px;
	height: 33px;
}

@media screen and (max-width: 750px) {
	.popup-modal-close {
		top: 10px;
		right: 10px;
		width: 16px;
		height: 16px;
	}
}

.modal-wrap .popup-modal-close {
	top: 20px;
	right: 20px;
}

.modal-wrap .popup-modal-close:before, .modal-wrap .popup-modal-close:after {
	background-color: #333;
}

.popup-modal-close:before, .popup-modal-close:after {
	content: '';
	display: block;
	width: 100%;
	height: 2px;
	background-color: #FFF;
	position: absolute;
	top: calc(50% - 1px);
	left: 0;
}

@media screen and (max-width: 750px) {
	.popup-modal-close:before, .popup-modal-close:after {
		height: 1px;
		top: calc(50% - .5px);
	}
}

.popup-modal-close:before {
	transform: rotate(45deg);
}

.popup-modal-close:after {
	transform: rotate(-45deg);
}

.step-box {
	width: 100%;
	border: 10px solid #000;
	border-radius: 20px;
	box-shadow: 1.532px 1.286px 0px 0px rgba(0, 0, 0, 0.14);
	background-color: #FFF;
	position: relative;
	text-align: left;
}

@media screen and (max-width: 750px) {
	.step-box {
		border-width: 6px;
	}
}

.step-box + .step-box {
	margin-top: 127px;
}

@media screen and (max-width: 750px) {
	.step-box + .step-box {
		margin-top: 83px;
	}
}

.step-box + .step-box:before {
	content: '';
	display: block;
	width: 67px;
	height: 59px;
	background: url(../img/icon-down.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	top: -106px;
	left: 50%;
	transform: translateX(-50%);
}

@media screen and (max-width: 750px) {
	.step-box + .step-box:before {
		width: 50px;
		height: 46px;
		top: -72px;
	}
}

.step-box .label {
	display: inline-block;
	position: absolute;
	left: 50%;
	top: -36px;
	transform: translateX(-50%);
}

@media screen and (max-width: 750px) {
	.step-box .label {
		top: -17px;
	}
	.step-box .label img {
		height: 30px;
	}
}

.step-box .detail-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
}

@media screen and (max-width: 750px) {
	.step-box .detail-wrap {
		display: block;
	}
}

.step-box .detail-wrap .txt {
	width: 60%;
}

@media screen and (max-width: 750px) {
	.step-box .detail-wrap .txt {
		width: 100%;
		text-align: center;
	}
}

.step-box .detail-wrap .txt p {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.4;
}

@media screen and (max-width: 750px) {
	.step-box .detail-wrap .txt p {
		font-size: 12px;
	}
}

.step-box .detail-wrap .txt p.caution {
	font-size: 16px;
	margin-top: 1em;
	line-height: 1.6 !important;
}

@media screen and (max-width: 750px) {
	.step-box .detail-wrap .txt p.caution {
		font-size: 10px;
	}
}

.step-box .detail-wrap .ph {
	text-align: right;
	width: 40%;
	position: relative;
}

@media screen and (max-width: 750px) {
	.step-box .detail-wrap .ph {
		width: 100%;
	}
}

.step-box .tbl {
	margin-top: 10px;
	width: 367px;
	display: flex;
	font-weight: 900;
	line-height: 1.4;
}

@media screen and (max-width: 750px) {
	.step-box .tbl {
		width: 100%;
		margin-top: 5%;
	}
}

.step-box .tbl dt {
	background-color: #e71a0f;
	color: #FFF;
	font-size: 18px;
	padding: 15px;
	display: flex;
	align-items: center;
	margin-right: 5px;
}

@media screen and (max-width: 750px) {
	.step-box .tbl dt {
		font-size: 11px;
		padding: 5%;
		margin-right: 2%;
	}
}

.step-box .tbl dd {
	flex: 1;
	background-color: #fee400;
	font-size: 19px;
	padding: 30px 15px;
}

@media screen and (max-width: 750px) {
	.step-box .tbl dd {
		font-size: 11px;
		padding: 5%;
	}
}

#modal01 .step-box {
	padding: 0 37px;
}

@media screen and (max-width: 750px) {
	#modal01 .step-box {
		padding: 10% 12%;
	}
}

#modal01 .link {
	color: #1da1f2;
}

#modal01 .font-red {
	color: #e71a0f;
}

#modal01 .balloon {
	position: absolute;
	z-index: 2;
}

@media screen and (min-width: 751px) {
	#modal01 .step1 {
		padding-top: 30px;
		padding-bottom: 24px;
	}
}

@media screen and (max-width: 750px) {
	#modal01 .step1 .txt {
		margin-bottom: 2em;
	}
	#modal01 .step1 .ph {
		width: 70%;
		margin: 0 auto 8%;
	}
}

#modal01 .step1 .btn {
	display: block;
	width: 304px;
	margin-top: 30px;
}

@media screen and (max-width: 750px) {
	#modal01 .step1 .btn {
		display: none;
	}
}

#modal01 .step1 .balloon {
	top: -80px;
	right: -100px;
}

@media screen and (max-width: 750px) {
	#modal01 .step1 .balloon {
		width: 51%;
		top: -6%;
		right: -34%;
	}
}

#modal01 .step1 .img {
	width: 276px;
	height: auto;
}

@media screen and (max-width: 750px) {
	#modal01 .step1 .img {
		width: 100%;
	}
}

@media screen and (min-width: 751px) {
	#modal01 .step2 {
		padding-top: 64px;
		padding-bottom: 46px;
		padding-right: 30px;
	}
}

@media screen and (max-width: 750px) {
	#modal01 .step2 p {
		margin-bottom: 1em;
	}
}

#modal01 .step2 .detail-wrap {
	display: block;
	position: relative;
}

#modal01 .step2 .detail-wrap .txt {
	width: 100%;
	text-align: left;
}

#modal01 .step2 .detail-wrap .ph {
	width: 463px;
	position: absolute;
	top: 0;
	right: 18px;
}

@media screen and (max-width: 750px) {
	#modal01 .step2 .detail-wrap .ph {
		display: none;
	}
}

@media screen and (min-width: 751px) {
	#modal01 .step3 {
		padding-top: 120px;
		padding-bottom: 64px;
	}
}

@media screen and (max-width: 750px) {
	#modal01 .step3 {
		padding-bottom: 6%;
	}
	#modal01 .step3 .txt {
		margin-bottom: 2em;
	}
	#modal01 .step3 .ph {
		width: 70.4%;
		margin: 0 auto 8%;
	}
}

#modal01 .step3 p {
	line-height: 2em;
}

#modal01 .step3 .balloon {
	top: -90px;
	right: -94px;
}

@media screen and (max-width: 750px) {
	#modal01 .step3 .balloon {
		width: 51%;
		top: -6%;
		right: -34%;
	}
}

#modal01 .step3 .img {
	width: 267px;
	height: auto;
}

@media screen and (max-width: 750px) {
	#modal01 .step3 .img {
		width: 100%;
	}
}

#modal01 .step3 .btn {
	text-align: center;
	margin-top: 22px;
}

@media screen and (max-width: 750px) {
	#modal01 .step3 .btn {
		margin: 5% -13% 0;
		width: 126%;
	}
}

#modal02 .step-box {
	padding: 0 40px;
}

@media screen and (max-width: 750px) {
	#modal02 .step-box {
		padding: 10% 12%;
	}
}

#modal02 .detail-wrap .txt {
	text-align: center;
}

#modal02 .detail-wrap .txt span {
	color: #e93130;
}

#modal02 .detail-wrap .ph {
	text-align: center;
}

@media screen and (min-width: 751px) {
	#modal02 .step1 {
		padding-top: 60px;
		padding-bottom: 60px;
		padding-right: 30px;
	}
}

@media screen and (max-width: 750px) {
	#modal02 .step1 p {
		margin-bottom: 1em;
	}
}

#modal02 .step1 .detail-wrap {
	display: block;
	position: relative;
}

#modal02 .step1 .detail-wrap .txt {
	width: 100%;
	text-align: left;
}

#modal02 .step1 .detail-wrap .ph {
	width: 463px;
	position: absolute;
	top: -10px;
	right: 0;
}

@media screen and (max-width: 750px) {
	#modal02 .step1 .detail-wrap .ph {
		display: none;
	}
}

@media screen and (min-width: 751px) {
	#modal02 .step2 {
		padding-top: 60px;
		padding-bottom: 22px;
	}
}

@media screen and (max-width: 750px) {
	#modal02 .step2 {
		padding: 10% 1% 3% 2%;
	}
	#modal02 .step2 .detail-wrap {
		display: flex;
	}
	#modal02 .step2 .detail-wrap .ph {
		width: 70%;
		padding-left: 2%;
	}
	#modal02 .step2 .detail-wrap .txt {
		padding-left: 2%;
	}
	#modal02 .step2 .detail-wrap .txt p {
		font-size: 15px;
	}
	#modal02 .step2 .detail-wrap .txt p.caution {
		font-size: 10px;
	}
}

@media screen and (min-width: 751px) {
	#modal02 .step3 {
		padding-top: 54px;
		padding-bottom: 54px;
	}
}

@media screen and (max-width: 750px) {
	#modal02 .step3 {
		padding: 10% 2% 3%;
	}
	#modal02 .step3 .detail-wrap {
		display: flex;
	}
	#modal02 .step3 .detail-wrap .ph {
		width: 70%;
		padding-left: 2%;
	}
	#modal02 .step3 .detail-wrap .txt {
		padding-left: 2%;
	}
	#modal02 .step3 .detail-wrap .txt p {
		font-size: 15px;
	}
	#modal02 .step3 .detail-wrap .txt p.caution {
		font-size: 10px;
	}
}

#modal02 .step3 .detail-wrap .txt p {
	line-height: 1.6;
}

#modal02 .btn {
	text-align: center;
	margin-top: 25px;
}

@media screen and (max-width: 750px) {
	#modal02 .btn {
		margin-top: 5%;
	}
}

#modal03 {
	background-color: #222;
}

#modal03 .popup-modal-close:before, #modal03 .popup-modal-close:after {
	background-color: #FFF;
}

#modal03 .inner {
	background-color: #222;
	color: #FFF;
}

#modal03 .head {
	color: #222222;
	background-color: #fdd000;
	font-size: 20px;
	width: 100%;
	height: 40px;
	line-height: 40px;
	text-align: center;
}

@media screen and (max-width: 750px) {
	#modal03 .head {
		font-size: 4.8vw;
		height: 8vw;
		line-height: 8vw;
	}
}

#modal03 .requirements-text {
	color: #FFF;
	font-size: 14px;
	line-height: 2em;
	height: 440px;
	overflow-y: scroll;
	padding-right: 1em;
	padding: 4%;
}

#modal03 .requirements-list + .requirements-list {
	margin-top: 1em;
}

#modal03 .requirements-list a {
	color: #FFF;
	text-decoration: underline;
}

#modal03 .requirements-list a:hover {
	text-decoration: underline;
}

/*-------------
ANIMATION
--------------------------------------*/
.ani {
	transition: all .5s;
	will-change: transform;
}

.anime-down {
	opacity: 0;
	transform: translateY(-20px);
}

.anime-down.is-show {
	opacity: 1;
	transform: translateY(0);
}

.anime-up {
	opacity: 0;
	transform: translateY(20px);
}

.anime-up.is-show {
	opacity: 1;
	transform: translateY(0);
}

.anime-left {
	opacity: 0;
	transform: translateX(-20px);
}

.anime-left.is-show {
	opacity: 1;
	transform: translateX(0);
}

.anime-right {
	opacity: 0;
	transform: translateX(20px);
}

.anime-right.is-show {
	opacity: 1;
	transform: translateX(0);
}

.anime-bic {
	opacity: 0;
	transform: scale(0);
}

.anime-bic.is-show {
	opacity: 1;
	transform: scale(1);
}

@keyframes icon {
	0% {
		transform: rotate(30deg);
	}
	100% {
		transform: rotate(0deg);
	}
}
