body {
	max-width: 1440px;
	margin: 0 auto;
	width: 100%;
	height: 100vh;
	z-index: 0;
	font-family: "Hiragino Sans", sans-serif;
}

a {
	color: #022735;
}

.wrapper {
	background-image: url(../img/bg.webp);
	background-repeat: no-repeat;
	background-position: center center;
	background-attachment: fixed;
	background-size: cover;
	/* aspect-ratio: 5000/2777; */
	display: flex;
	/* justify-content: space-between; */
	max-width: 1440px;
	width: 100%;
	height: auto;
	margin: 0 auto;
	overflow: hidden;
}

.pc_left {
	/* max-width: 523.5px; */
	/* width: calc((100% - 393px) / 2); */
	width: 664px;
	/* flex-shrink: 0; */
	/* width: 46.111%; */
	min-width: 308px;
	height: 100vh;
	position: fixed;
	top: 0;
	/* 位置計算: 画面中央 - (コンテンツ幅/2) - サイドバー幅 - 余白 */
	/* left: calc(50% - (393px / 2) - 664px + 138px); */
}

@media screen and (max-width: 1440px) {
	.pc_left {
		width: 45%;
		min-width: 0;
	}
}

@media screen and (max-width: 1140px) {
	.pc_left {
		width: calc(100% - 393px);
		min-width: 0;
	}
}

.pc_left_item {
	display: flex;
	flex-direction: column;
	gap: 44px;
	/* position: absolute; */
	width: 370px;
	height: auto;
	margin: 36.625% auto 0 25.15%;
	/* margin: 213px auto 0 25.15%; */
	/* top: calc(213px / 100vh * 100%); */
	/* top: 26.625%;
	left: 25.15%; */
	/* top: 30.75%;
	left: 8.263%; */
	/* margin: calc(100vh / 3) auto 0; */
	transform: translateY(-4rem);
	opacity: 0;
	transition: transform 1s cubic-bezier(0.3, 1, 0.6, 1), opacity 0.3s ease;
	z-index: 10;
}

.pc_left_item.is_active {
	/* clip-path: inset(0 0 0 0); */
	transform: translateY(0);
	opacity: 1;
}
.pc_left_cta {
	display: block;
	/* width: 55.183%; */
	width: 100%;
	height: auto;
	/* top: 30.75%;
	left: 8.263%; */
	/* margin: 4.423% auto 0; */
	margin: 0 auto;
	transform: translateY(-4rem);
	opacity: 0;
	/* transition: transform 1s cubic-bezier(0.5, 0, 0.8, 1), opacity 0.3s ease; */
	transition: transform 1s cubic-bezier(0.1, 0, 0.8, 1), opacity 0.3s ease;

	z-index: 10;
}
.pc_left_cta.is_active {
	/* clip-path: inset(0 0 0 0); */
	transform: translateY(0);
	opacity: 1;
}
.pc_left_cta img {
	width: 100%;
	height: auto;
	transition: all 0.2s ease;
}
.pc_left_cta img:hover {
	opacity: 0.5;
}

.app_btns {
	width: 100%;
	display: flex;
	justify-content: space-between;
	gap: 3.2%;
}

.pc_right {
	max-width: 523.5px;
	/* width: calc((100% - 393px) / 2); */
	/* width: 26.597%; */
	width: 383px;
	/* flex-shrink: 0; */
	height: 100vh;
	position: fixed;
	/* right: 0; */
	left: calc(46.111% + 393px);
}

.pc_right_item {
	position: absolute;
	bottom: 80px;
	right: 20.887%;
	width: 180px;
	height: 180px;
	opacity: 0;
	transform: translateY(-4rem);
	transition: transform 1s cubic-bezier(0.3, 1, 0.6, 1), opacity 0.3s ease;
	z-index: 10;
}

.pc_right_item.is_active {
	/* clip-path: inset(0 0 0 0); */
	transform: translateY(0);
	opacity: 1;
}

@media screen and (max-width: 1350px) {
	.pc_right {
		width: calc(100% - 664px - 393px);
	}

	.pc_right_item {
		left: 45%;
	}
}

@media screen and (max-width: 1140px) {
	.pc_right {
		display: none;
	}
	.pc_right_item {
		display: none;
	}
}

main {
	/* max-width: 393px;
	width: 393px; */
	max-width: 407px;
	width: 100%;
	margin: 30px auto 0 46.111%;
	/* margin: 30px auto 0 auto; */
	border-radius: 50px;
	border: 7px solid rgba(255, 255, 255, 0.05);
	box-shadow: 0 4px 24px 0 #00000033;
}
/* header {
	max-width: 393px;
	width: 100%;
	margin: 0 auto;
	height: 96px;
	padding: 0 6.106%;
	display: flex;
	justify-content: space-between;
	align-items: center;
} */

@media screen and (max-width: 1140px) {
	.pc_left {
		width: calc(100% - 393px);
	}
	main {
		/* margin: 0 0 0 308px; */
		margin: 0 3% 0 auto;
	}
}

@media screen and (max-width: 1000px) {
	.pc_left {
		width: calc(60% - 393px);
	}
	main {
		/* margin: 0 0 0 308px; */
		margin: 0 3% 0 auto;
	}
}

@media screen and (max-width: 900px) {
	.pc_left_item {
		width: 270px;
	}
}

@media screen and (max-width: 740px) {
	.pc_left {
		display: none;
	}
	.pc_left_item {
		display: none;
	}
	.pc_left_cta {
		display: none;
	}
	main {
		width: min(393px, 100%);
		margin: 0 auto;
	}
}

.fv {
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	aspect-ratio: 393/639;
	overflow: hidden;
	border-radius: 50px;
}

/* fade animation */
.fade {
	opacity: 0;
	transform: translateY(4rem);
	-webkit-transform: translateY(4rem); /* Safari向け */
}
@keyframes fade {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		-webkit-transform: translateY(0); /* Safari向け */
	}
}
@-webkit-keyframes fade {
	/* Safari向け */
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateY(0);
		-webkit-transform: translateY(0);
	}
}
.fade.is-animation {
	animation: fade 0.8s ease;
	-webkit-animation: fade 0.8s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.zoom {
	opacity: 0;
	transform: scale(0);
	-webkit-transform: scale(0); /* Safari向け */
}
@keyframes zoom {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: scale(1);
		-webkit-transform: scale(1); /* Safari向け */
	}
}
@-webkit-keyframes zoom {
	/* Safari向け */
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: scale(1);
		-webkit-transform: scale(1); /* Safari向け */
	}
}
.zoom.is-animation {
	animation: zoom 0.8s ease;
	-webkit-animation: zoom 0.8s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.fade-fast {
	opacity: 0;
	transform: scale(0.1) translateY(70rem);
	-webkit-transform: scale(0.1) translateY(70rem); /* Safari向け */
}
@keyframes fade-fast {
	0% {
		opacity: 0;
	}
	65% {
		opacity: 1;
		transform: scale(1.15) translateY(0);
		-webkit-transform: scale(1.15) translateY(0); /* Safari向け */
	}
	100% {
		opacity: 1;
		transform: scale(1) translateY(0);
		-webkit-transform: scale(1) translateY(0); /* Safari向け */
	}
}
@-webkit-keyframes fade-fast {
	/* Safari向け */
	0% {
		opacity: 0;
	}
	65% {
		opacity: 1;
		transform: scale(1.15) translateY(0);
		-webkit-transform: scale(1.15) translateY(0); /* Safari向け */
	}
	100% {
		opacity: 1;
		transform: scale(1) translateY(0);
		-webkit-transform: scale(1) translateY(0); /* Safari向け */
	}
}
.fade-fast.is-animation {
	animation: fade-fast 0.8s ease;
	-webkit-animation: fade-fast 0.8s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.fade-left {
	opacity: 0;
	transform: translateX(-20rem);
	-webkit-transform: translateX(-20rem); /* Safari向け */
}
@keyframes fade-left {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateX(0);
		-webkit-transform: translateX(0); /* Safari向け */
	}
}
@-webkit-keyframes fade-left {
	/* Safari向け */
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateX(0);
		-webkit-transform: translateX(0);
	}
}
.fade-left.is-animation {
	animation: fade-left 0.8s ease;
	-webkit-animation: fade-left 0.8s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.fade-right {
	opacity: 0;
	transform: translateX(20rem);
	-webkit-transform: translateX(20rem); /* Safari向け */
}
@keyframes fade-right {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateX(0);
		-webkit-transform: translateX(0); /* Safari向け */
	}
}
@-webkit-keyframes fade-right {
	/* Safari向け */
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
		transform: translateX(0);
		-webkit-transform: translateX(0);
	}
}
.fade-right.is-animation {
	animation: fade-right 0.8s ease;
	-webkit-animation: fade-right 0.8s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.left_to_right {
	opacity: 0;
	clip-path: inset(0 100% 0 0);
	/* transition: all 0.8s ease; */
}
@keyframes left_to_right {
	0% {
		opacity: 0;
		clip-path: inset(0 100% 0 0);
	}
	100% {
		opacity: 1;
		clip-path: inset(0 0 0 0);
	}
}
@-webkit-keyframes left_to_right {
	/* Safari向け */
	0% {
		opacity: 0;
		-webkit-clip-path: inset(0 100% 0 0);
	}
	100% {
		opacity: 1;
		-webkit-clip-path: inset(0 0 0 0);
	}
}
.left_to_right.is-animation {
	animation: left_to_right 1s forwards;
	-webkit-animation: left_to_right 1s forwards; /* Safari向け */
}

.left_to_right_chain {
	opacity: 0;
	clip-path: inset(0 100% 0 0);
	/* transition: all 1s ease; */
}
@keyframes left_to_right_chain {
	0% {
		opacity: 0;
		clip-path: inset(0 100% 0 0);
	}
	100% {
		opacity: 1;
		clip-path: inset(0 0 0 0);
	}
}
@-webkit-keyframes left_to_right_chain {
	/* Safari向け */
	0% {
		opacity: 0;
		-webkit-clip-path: inset(0 100% 0 0);
	}
	100% {
		opacity: 1;
		-webkit-clip-path: inset(0 0 0 0);
	}
}
.left_to_right_chain.is-animation {
	animation: left_to_right_chain 1s forwards;
	-webkit-animation: left_to_right_chain 1s forwards; /* Safari向け */
}

.rotate-shake {
	transform: rotate(0) translateY(0);
	-webkit-transform: rotate(0) translateY(0); /* Safari向け */
}
@keyframes rotate-shake {
	0% {
		transform: rotate(0) translateY(0);
		-webkit-transform: rotate(0) translateY(0); /* Safari向け */
	}
	50% {
		transform: rotate(0) translateY(0rem);
		-webkit-transform: rotate(0) translateY(0rem); /* Safari向け */
	}
	55% {
		transform: rotate(0) translateY(0);
		-webkit-transform: rotate(0) translateY(0); /* Safari向け */
	}
	60% {
		transform: rotate(-10deg) translateY(-1.3rem);
		-webkit-transform: rotate(-10deg) translateY(-1.3rem); /* Safari向け */
	}
	65% {
		transform: rotate(10deg) translateY(-1.3rem);
		-webkit-transform: rotate(10deg) translateY(-1.3rem); /* Safari向け */
	}
	70% {
		transform: rotate(-15deg) translateY(-1.3rem);
		-webkit-transform: rotate(-15deg) translateY(-1.3rem); /* Safari向け */
	}
	75% {
		transform: rotate(15deg) translateY(-1.3rem);
		-webkit-transform: rotate(15deg) translateY(-1.3rem); /* Safari向け */
	}
	80% {
		transform: rotate(-10deg) translateY(-1.3rem);
		-webkit-transform: rotate(-10deg) translateY(-1.3rem); /* Safari向け */
	}
	85% {
		transform: rotate(10deg) translateY(-1.3rem);
		-webkit-transform: rotate(10deg) translateY(-1.3rem); /* Safari向け */
	}
	90% {
		transform: rotate(-8deg) translateY(-1.3rem);
		-webkit-transform: rotate(-8deg) translateY(-1.3rem); /* Safari向け */
	}
	95% {
		transform: rotate(5deg) translateY(-1.3rem);
		-webkit-transform: rotate(5deg) translateY(-1.3rem); /* Safari向け */
	}
	90% {
		transform: rotate(-3deg) translateY(-1.3rem);
		-webkit-transform: rotate(-3deg) translateY(-1.3rem); /* Safari向け */
	}
	100% {
		transform: rotate(0) translateY(0rem);
		-webkit-transform: rotate(0) translateY(0rem); /* Safari向け */
	}
}
@-webkit-keyframes rotate-shake {
	/* Safari向け */
	0% {
		transform: rotate(0) translateY(0);
		-webkit-transform: rotate(0) translateY(0); /* Safari向け */
	}
	50% {
		transform: rotate(0) translateY(0rem);
		-webkit-transform: rotate(0) translateY(0rem); /* Safari向け */
	}
	55% {
		transform: rotate(0) translateY(0);
		-webkit-transform: rotate(0) translateY(0); /* Safari向け */
	}
	60% {
		transform: rotate(-10deg) translateY(-1.3rem);
		-webkit-transform: rotate(-10deg) translateY(-1.3rem); /* Safari向け */
	}
	65% {
		transform: rotate(10deg) translateY(-1.3rem);
		-webkit-transform: rotate(10deg) translateY(-1.3rem); /* Safari向け */
	}
	70% {
		transform: rotate(-15deg) translateY(-1.3rem);
		-webkit-transform: rotate(-15deg) translateY(-1.3rem); /* Safari向け */
	}
	75% {
		transform: rotate(15deg) translateY(-1.3rem);
		-webkit-transform: rotate(15deg) translateY(-1.3rem); /* Safari向け */
	}
	80% {
		transform: rotate(-10deg) translateY(-1.3rem);
		-webkit-transform: rotate(-10deg) translateY(-1.3rem); /* Safari向け */
	}
	85% {
		transform: rotate(10deg) translateY(-1.3rem);
		-webkit-transform: rotate(10deg) translateY(-1.3rem); /* Safari向け */
	}
	90% {
		transform: rotate(-8deg) translateY(-1.3rem);
		-webkit-transform: rotate(-8deg) translateY(-1.3rem); /* Safari向け */
	}
	95% {
		transform: rotate(5deg) translateY(-1.3rem);
		-webkit-transform: rotate(5deg) translateY(-1.3rem); /* Safari向け */
	}
	90% {
		transform: rotate(-3deg) translateY(-1.3rem);
		-webkit-transform: rotate(-3deg) translateY(-1.3rem); /* Safari向け */
	}
	100% {
		transform: rotate(0) translateY(0rem);
		-webkit-transform: rotate(0) translateY(0rem); /* Safari向け */
	}
}
.rotate-shake.is-animation {
	animation: rotate-shake 1.6s ease;
	-webkit-animation: rotate-shake 1.6s ease; /* Safari向け */
	animation-fill-mode: both;
	-webkit-animation-fill-mode: both; /* Safari向け */
}

.logo {
	position: absolute;
	top: 5.477%;
	left: 5.763%;
	width: 25.445%;
	height: auto;
	transition: top 0.5s cubic-bezier(0.5, 2.3, 1, 1), opacity 0.3s ease;
	opacity: 0;
	z-index: 0;
}

.logo.is_active {
	/* clip-path: inset(0 0 0 0); */
	/* transform: translateX(-50%); */
	top: 4.508%;
	opacity: 1;
}

.logo img {
	width: 100%;
	height: auto;
	opacity: 1;
	transition: all 0.2s ease;
}

.logo img:hover {
	opacity: 0.5;
}

.fv_item01 {
	position: absolute;
	top: 50.464%;
	left: 38.58%;
	/* left: 50%; */
	width: 23.3%;
	height: auto;

	/* transform: rotate(0) scale(2); */
	transform: rotate(0);
	transition: transform 1.5s cubic-bezier(0.8, 0.3, 0.83, 1),
		top 0.5s cubic-bezier(0.3, 0.1, 0.6, 1), opacity 0.3s ease;
	opacity: 0;
	z-index: 20;
}

.fv_item01.is_active {
	/* clip-path: inset(0 0 0 0); */
	/* transform: translateX(-50%); */
	top: 30.464%;
	opacity: 1;
	/* transform: rotate(-180deg) scale(1); */
	transform: rotate(180deg);
}

.fv_item01.is_active2 {
	/* clip-path: inset(0 0 0 0); */
	/* transform: translateX(-50%); */
	/* transform: rotate(0deg) scale(1); */
	transform: rotate(0deg);
	top: 30.464%;
	opacity: 1;
	animation: rotate-image 10s linear infinite;
}

@keyframes rotate-image {
	0% {
		transform: rotate(0);
	}
	25% {
		transform: rotate(-45deg);
	}
	50% {
		transform: rotate(-90deg);
	}
	75% {
		transform: rotate(-135deg);
	}
	100% {
		transform: rotate(-180deg);
	}
}

.fv_item02 {
	position: absolute;
	top: 14.71%;
	left: 0;
	width: 45%;
	border-radius: 20px;
	border: 4.91px solid rgba(234, 234, 234, 0.2);
	/* clip-path: inset(0 0 100% 0);
	transition: clip-path 1s cubic-bezier(0.1, 0.5, 0.6, 1); */
	opacity: 0;
	transform: translate(100%, 0);
	/* transition: transform 1s cubic-bezier(0.3, 1, 0.6, 1), opacity 0.3s ease; */
	transition: transform 1.2s cubic-bezier(0.2, 1, 0.4, 1.1), opacity 0.3s ease;
	z-index: 10;
	box-shadow: 0px -4.02px 34.16px rgba(0, 0, 0, 0.14);
}

.fv_item02.is_active {
	/* clip-path: inset(0 0 0 0); */
	transform: translate(5.763%, 0);
	opacity: 1;
}

.fv_item03 {
	position: absolute;
	top: 14.71%;
	right: 0;
	width: 45%;
	border-radius: 20px;
	border: 4.91px solid rgba(234, 234, 234, 0.2);
	/* clip-path: inset(0 0 100% 0);
	transition: clip-path 1s cubic-bezier(0.1, 0.5, 0.6, 1); */
	opacity: 0;
	transform: translate(-100%, 0);
	/* transition: transform 1s cubic-bezier(0.3, 1, 0.6, 1), opacity 0.3s ease; */
	transition: transform 1.2s cubic-bezier(0.2, 1, 0.4, 1.1), opacity 0.3s ease;
	z-index: 9;
	box-shadow: 0px -4.02px 34.16px rgba(0, 0, 0, 0.14);
}

.fv_item03.is_active {
	/* clip-path: inset(0 0 0 0); */
	transform: translate(-5.763%, 0);
	opacity: 1;
}

.fv_item04 {
	position: absolute;
	bottom: 0;
	/* left: 31.74%; */
	left: 0;
	/* width: 40.712%; */
	width: 100%;
	opacity: 0;
	transform: translateY(6rem);
	transition: transform 1s cubic-bezier(0.2, 1, 0.4, 1.5), opacity 0.3s ease;
	z-index: 1;
}

.fv_item04.is_active {
	transform: translateY(0);
	opacity: 1;
}
.fv_item05 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	opacity: 0;
	transform: translateY(-23rem);
	transition: transform 1s cubic-bezier(0.2, 0.4, 0.3, 1), opacity 0.2s ease;
	z-index: 10;
}

.fv_item05.is_active {
	opacity: 1;
}
.fv_item05.is_active2 {
	transform: translateY(0);
	opacity: 1;
}
.fv_item06 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: auto;
	clip-path: inset(0 100% 0 0);
	/* transition: clip-path 5s cubic-bezier(0.19, 1, 0.22, 1) ; */
	transition: clip-path 2s cubic-bezier(0.4, 0.5, 0.9, 0.7);
	/* transition: left 3s cubic-bezier(0.19, 1, 0.22, 1), opacity 2s ease; */
	/* left: 40%; */
	z-index: 0;
}

.fv_item06.is_active {
	clip-path: inset(0 0 0 0);
}
/* @media screen and (max-width: 560px) {
	.fv_item06.is_active {
		right: 6.877%;
	}
} */

.cta {
	position: absolute;
	bottom: 2.049%;
	left: 50%;
	transform: translate(-50%, 2em);
	width: 69.211%;
	height: auto;
	transition: transform 1s cubic-bezier(0.2, 0.4, 0.3, 1), opacity 0.2s ease;
	z-index: 15;
	opacity: 0;
}
.cta.is_active {
	opacity: 1;
	transform: translate(-50%, 0);
}
.cta:hover {
	opacity: 0.5;
}

.cta span {
	display: inline-block;
	width: 100%;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	overflow: hidden;
	border-radius: 50px;
	z-index: 30;
}

.cta span::before {
	position: absolute;
	content: "";
	display: inline-block;
	top: -180px;
	left: 0;
	width: 30px;
	height: 100%;
	background-color: #fff;
	transition: 300ms;
	animation: shinyshiny 2.5s ease-in-out infinite;
}

/* sec01 */
.sec01 {
	/* background-image: url(../img/sec01_bg.webp);
	background-size: cover;
	background-position: center center; */
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	aspect-ratio: 502/4999;
}

.sec01_item01 {
	position: absolute;
	/* top: 65.059%; */
	top: 0;
	left: 0;
	width: 100%;
	transition: all 1s ease;
}

.sec02 {
	background-image: url(../img/sec02.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	aspect-ratio: 1572/2180;
	overflow: hidden;
	margin-top: -1px;
}

.sec02_item01 {
	position: absolute;
	top: 0;
	/* bottom: 0; */
	left: 0;
	width: 100%;
	transition: all 1s ease;
}

.sec02_item02 {
	position: absolute;
	/* top: 0; */
	bottom: 0;
	left: 0;
	width: 100%;
	height: auto;
	transition: all 1s ease;
}

/* .sec02_item05 {
	position: absolute;
	bottom: 12.795%;
	left: calc(50% - 8.9055%);
	width: 17.811%;
	height: auto;
	transition: all 1s ease;
} */

/* sec03 */
.sec03 {
	background-image: url(../img/sec03.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	aspect-ratio: 1572/2936;
	overflow: hidden;
	margin-top: -1px;
}

.sec03_item01 {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: auto;
	transition: all 1s ease;
}

.link_btn01 {
	display: inline-block;
	position: absolute;
	/* top: 31.753%; */
	bottom: 5.858%;
	/* width: 141px; */
	width: 58.015%;
	/* height: 22px; */
	height: 2.588%;
	/* left: 33px; */
	left: 25.811%;
	/* margin: 0 auto; */
	z-index: 30;
	cursor: pointer;
}

.link_btn01_item {
	width: 100%;
	text-align: center;
	display: block;
	height: 100%;
}

.link_btn01_item:hover {
	background-color: #c0e2ee;
}

/* sec04 */
.sec04 {
	background-image: url(../img/sec04.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 10;
	width: 100%;
	height: auto;
	aspect-ratio: 1572/2548;
}
.sec04_item01 {
	position: absolute;
	/* top: 0; */
	bottom: 0;
	left: 0;
	width: 100%;
	transition: all 1s ease;
}

/* sec05 */
.sec05 {
	background-image: url(../img/sec05.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 10;
	width: 100%;
	height: auto;
	aspect-ratio: 766/5000;
	margin-top: -1px;
}

.sec05_item01 {
	position: absolute;
	top: 11.583%;
	left: 4.834%;
	width: 19.465%;
	transition: all 1s ease;
}

.sec05_cta {
	position: absolute;
	bottom: 3.12%;
	left: 50%;
	transform: translate(-50%, 0);
	width: 69.211%;
	height: auto;
	z-index: 15;
	opacity: 1;
}

.sec05_cta:hover {
	opacity: 0.5;
}

.sec05_cta span {
	display: inline-block;
	width: 100%;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	overflow: hidden;
	border-radius: 50px;
	z-index: 30;
}

.sec05_cta span::before {
	position: absolute;
	content: "";
	display: inline-block;
	top: -180px;
	left: 0;
	width: 30px;
	height: 100%;
	background-color: #fff;
	transition: 300ms;
	animation: shinyshiny 2.5s ease-in-out infinite;
}

/* sec06 */
.sec06 {
	background-image: url(../img/sec06.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 11;
	width: 100%;
	height: auto;
	aspect-ratio: 1572/3120;
	margin-top: -1px;
}

.sec06_cta {
	position: absolute;
	bottom: 6.666%;
	left: 50%;
	transform: translate(-50%, 0);
	width: 69.211%;
	height: auto;
	z-index: 15;
	opacity: 1;
}

.sec06_cta:hover {
	opacity: 0.5;
}

.sec06_cta span {
	display: inline-block;
	width: 100%;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	overflow: hidden;
	border-radius: 50px;
	z-index: 30;
}

.sec06_cta span::before {
	position: absolute;
	content: "";
	display: inline-block;
	top: -180px;
	left: 0;
	width: 30px;
	height: 100%;
	background-color: #fff;
	transition: 300ms;
	animation: shinyshiny 2.5s ease-in-out infinite;
}

@-webkit-keyframes shinyshiny {
	0% {
		-webkit-transform: scale(0) rotate(45deg);

		opacity: 0;
	}

	70% {
		-webkit-transform: scale(0) rotate(45deg);

		opacity: 0.5;
	}

	71% {
		-webkit-transform: scale(4) rotate(45deg);

		opacity: 1;
	}

	100% {
		-webkit-transform: scale(50) rotate(45deg);

		opacity: 0;
	}
}

/* footer */
footer {
	background-image: url(../img/footer.webp);
	background-size: cover;
	background-position: center center;
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	aspect-ratio: 1572/864;
	border-radius: 0 0 50px 50px;
	font-size: 12px;
	margin-top: -23px;
}

.footer_item01 {
	position: absolute;
	bottom: 31.481%;
	left: 5.597%;
	color: #fff;
}

.footer_item02 {
	position: absolute;
	bottom: 31.481%;
	left: 24.936%;
	color: #fff;
}

.copyright {
	position: absolute;
	bottom: 17.592%;
	left: 5.597%;
	color: #fff;
}
