@charset "utf-8";
body {
	background-color: #fff;
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto,
		"NotoSansCJKjp", MotoyaLCedar, "メイリオ", Meiryo, sans-serif;
	position: relative;
}
.img_responsive {
	display: block;
	max-width: 100%;
	height: auto;
	margin: auto;
}
.alpha {
	display: inline-block;
	-webkit-transition: 0.4s ease;
	transition: 0.4s ease;
}
.alpha:hover {
	filter: alpha(opacity=70);
	opacity: 0.7;
}
.visible_sp {
	display: none;
}
.contents {
	width: 100%;
	position: relative;
}
.wrapper {
	max-width: 750px;
	margin: 0 auto;
}
.wrapper_inner {
	max-width: 650px;
	margin: 0 auto;
}
.contents_btn {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	text-align: center;
	z-index: 9999;
}
.contents_btn a {
	cursor: pointer;
	display: block;
	max-width: 750px;
	margin: 0 auto;
}
.contents_btn a img {
	width: 100%;
}
.contents_cta .cta {
	position: relative;
}
.contents_cta_btn {
	position: absolute;
	width: 100%;
	text-align: center;
	margin: 0 auto;
	padding: 0 9%;
}
.contents_cta_btn01 {
	bottom: 54%;
}
.contents_cta_btn02 {
	bottom: 5%;
}
.contents_cta_btn03 {
	bottom: 18%;
}
.contents_cta_btn a {
	cursor: pointer;
	display: inline-block;
}
.contents_cta_btn a img {
	width: 100%;
	animation: btnZoom 1s ease 0s infinite alternate;
}
.contents_cta_btn02 a img,
.contents_cta_btn03 a img {
	animation: none;
}
@keyframes btnZoom {
	from {
		transform: scale(0.9, 0.9);
	}
	to {
		transform: scale(1, 1);
	}
}
.contents_footer .contents_footer_inner {
	background-color: #fff;
	padding: 30px 15px;
	text-align: center;
}
.contents_footer ul {
	display: inline-block;
}
.contents_footer ul li {
	display: inline-block;
	border-right: 1px solid #1c1c1c;
	margin-right: 5px;
	padding-right: 10px;
}
.contents_footer ul li:last-child {
	border-right: none;
	margin-right: 0;
	padding-right: 0;
}
.contents_footer ul li a {
	color: #1c1c1c;
	display: block;
	width: 100%;
	text-decoration: none;
	font-size: 14px;
}
.contents_footer .copy {
	color: #1c1c1c;
	text-align: center;
	margin-bottom: 5px;
}
@media (max-width: 575px) {
	.visible_sp {
		display: block;
	}
	.contents_footer .contents_footer_inner {
		padding: 30px 5px;
	}
	.contents_footer ul li {
		margin-right: 3px;
		padding-right: 6px;
	}
	.contents_footer ul li a {
		font-size: 12px;
	}
	.contents_footer .copy {
		font-size: 11px;
	}
}
@media (max-width: 360px) {
	.contents_footer ul li a {
		font-size: 10px;
	}
}

.contents17 .contents_inner06 {
	margin-top: -0.5px;
}

/* 動画・アニメーション共通 */
.contents_inner {
	position: relative;
	overflow: hidden;
}
.movie_wrapper {
	line-height: 0;
}
.movie_wrapper video {
	object-fit: cover;
	height: 100%;
	width: 100%;
}

/* movie02 */
.contents09 .movie_wrapper.movie_wrapper01 {
	width: 100%;
	padding: 0;
}
/* movie03 */
.contents09 .movie_wrapper.movie_wrapper02 {
	position: absolute;
	bottom: 49.2%;
	width: 100%;
	padding: 0 4%;
	z-index: -1;
}
/* movie04 */
.contents12 .movie_wrapper.movie_wrapper01 {
	position: absolute;
	bottom: 10%;
	width: 100%;
	padding: 0 4%;
	z-index: -1;
}
.contents12 .movie_wrapper.movie_wrapper01 video {
	transform: scale(1.9);
}

/* テキスト・パーツ共通 */
.contents01_text01 {
	position: absolute;
	top: 5%;
	width: 100%;
	padding: 0 9%;
	text-align: center;
}
.contents01_text02 {
	position: absolute;
	bottom: 4.5%;
	width: 100%;
	padding: 0 4%;
	text-align: center;
}
/* .contents02 */
.contents02_parts01 {
	position: absolute;
	bottom: 2.5%;
	width: 100%;
	padding: 0 1% 0 17.2%;
}
.contents02_parts02 {
	position: absolute;
	bottom: 0;
	width: 100%;
	padding: 0;
}
/* .contents02_icon {
	position: absolute;
	width: 100%;
}
.contents02_icon01 {
	top: 22.8%;
	padding: 0 56.3% 0 5%;
}
.contents02_icon02 {
	top: 43.1%;
	padding: 0 63.8% 0 5%;
}
.contents02_icon03 {
	top: 63.9%;
	padding: 0 58.9% 0 5%;
}
.contents02_icon04 {
	top: 30.7%;
	padding: 0 5% 0 58.7%;
}
.contents02_icon05 {
	top: 51.2%;
	padding: 0 5% 0 64.8%;
}
.contents02_icon06 {
	top: 71.3%;
	padding: 0 5% 0 64.9%;
} */

.contents02_icon_wrapper {
	position: absolute;
	width: 100%;
	display: flex;
	justify-content: space-between;
}
.contents02_icon01_wrapper {
	top: 22.8%;
	padding: 0 5%;
}
.contents02_icon02_wrapper {
	top: 43.1%;
	padding: 0 5%;
}
.contents02_icon03_wrapper {
	top: 63.9%;
	padding: 0 5%;
}
.contents02_icon04 {
	padding-top: 13.9%;
	padding-left: 19%;
}
.contents02_icon05 {
	padding-top: 13.9%;
	padding-left: 32%;
}
.contents02_icon06 {
	padding-top: 12.4%;
	padding-left: 26%;
}

/* .contents03 */
.contents03 .contents_inner {
	overflow: visible;
}
.contents03_text01 {
	position: absolute;
	top: 23.5%;
	width: 100%;
	padding: 0 0 0 5%;
	text-align: center;
}
.contents03_text02 {
	position: absolute;
	top: 56.5%;
	width: 100%;
	padding: 0 5% 0 0;
	text-align: center;
}
.contents03_text03 {
	position: absolute;
	bottom: -9%;
	width: 100%;
	padding: 0 35%;
	text-align: center;
	z-index: 2;
}
/* contents04 */
.contents04_text01 {
	position: absolute;
	top: 8.5%;
	width: 100%;
	padding: 0 10%;
	text-align: center;
}
.contents04_list {
	position: absolute;
	top: 42%;
	width: 100%;
	padding: 0 0 0 51%;
}
.contents04_list div {
	margin-bottom: 3%;
}
/* contents05 */
.contents05_list01 {
	position: absolute;
	top: 25%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
}
/* contents06 */
.contents06_text01 {
	position: absolute;
	top: 1%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
}
/* contents07 */
.contents07_text01 {
	position: absolute;
	top: 6%;
	width: 100%;
	padding: 0 13%;
	text-align: center;
}
/* contents09 */
.contents09_parts {
	position: absolute;
	width: 100%;
	padding: 0 37%;
	text-align: center;
}
.contents09_point01 .contents09_parts {
	top: 13%;
}
.contents09_point02 .contents09_parts {
	top: 3.1%;
}
.contents09_point03 .contents09_parts {
	top: 2%;
}
.contents09_point04 .contents09_parts {
	top: 1.3%;
}
.contents09_point04 .contents09_parts02 {
	top: inherit;
	bottom: 0.7%;
}
.contents09_text01 {
	position: absolute;
	top: 22.5%;
	width: 100%;
	padding: 0 8%;
	text-align: center;
}
.contents09_text02 {
	position: absolute;
	top: 16.5%;
	width: 100%;
	padding: 0 8%;
	text-align: center;
}
.contents09_text03 {
	position: absolute;
	bottom: 0.5%;
	width: 100%;
	padding: 0 6%;
	text-align: center;
}
.contents09_text04 {
	position: absolute;
	top: 12%;
	width: 100%;
	padding: 0 14%;
	text-align: center;
}
.contents09_text05 {
	position: absolute;
	top: 1%;
	width: 100%;
	padding: 0 14%;
	text-align: center;
}
.contents09_text06 {
	position: absolute;
	bottom: 30.5%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
}
.contents09_arrow {
	position: absolute;
	bottom: 11.8%;
	width: 100%;
	padding: 0 56% 0 10%;
}
.contents09_arrow .cls-1 {
	fill: none;
	stroke: #fff;
	stroke-linecap: round;
	stroke-miterlimit: 10;
	stroke-width: 4px;
}
/* contents10 */
.contents10_text01 {
	position: absolute;
	top: 23.5%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
}
.contents10_parts01 {
	position: absolute;
	top: 15%;
	width: 100%;
	padding: 0 20% 0 12%;
}
/* contents11 */
.contents11_text01 {
	position: absolute;
	top: 5%;
	width: 100%;
	padding: 0 10% 0 80%;
	text-align: center;
}
.contents11_text02 {
	position: absolute;
	bottom: 4%;
	width: 100%;
	padding: 0 6%;
	text-align: center;
}
/* contents12 */
.contents12_text01 {
	position: absolute;
	bottom: 5.5%;
	width: 100%;
	padding: 0 9%;
	text-align: center;
}

/* slide01 */
.contents05 .slide_wrapper {
	position: absolute;
	bottom: 2%;
	left: 0;
	z-index: 1;
	padding: 0 6%;
	width: 100%;
}
.contents05 .slide01 .swiper-wrapper {
	z-index: 3;
}
.contents05 .slide01 .swiper-slide {
	position: relative;
}

/* アニメーション */
@keyframes spin {
	from {
		transform: rotate(360deg);
	}
	to {
		transform: rotate(0deg);
	}
}
.rotate {
	animation: spin 14s linear infinite;
	transform-origin: center center;
}

/* FVアニメーション */
/* movie01 */
.contents_fv .movie_wrapper.movie_wrapper01 {
	position: absolute;
	top: 11%;
	width: 100%;
	padding: 0 1%;
	z-index: -1;
}
.contents_fv .movie_wrapper.movie_wrapper01 video {
	transform: scale(1.2);
}

.fv_slide02 .before_after {
	display: flex;
	flex-wrap: wrap;
	position: absolute;
	top: 15%;
	width: 100%;
}
.fv_slide02 .before_after .before,
.fv_slide02 .before_after .after {
	width: 50%;
}
.fv_slide02_text {
	position: absolute;
	bottom: 2%;
	width: 100%;
	padding: 0 9%;
	text-align: center;
}
.fv_slide03 .icon_wrapper {
	position: absolute;
	bottom: 23%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
	gap: 3%;
}
.fv_slide03 .icon_wrapper .icon {
	width: calc((100% - 6%) / 3);
}
.fv_slide03 .icon_wrapper .icon.icon02 {
	padding-top: 6%;
}
.fv_slide03_text {
	position: absolute;
	bottom: 3%;
	width: 100%;
	padding: 0 5%;
	text-align: center;
}
