@charset "UTF-8";

/******************************************************************************
 Layout
******************************************************************************/
.inner {
	width: 100%;
	margin: 0 auto;
	background: url(../images/bg.jpg) no-repeat top center / cover;
	overflow: hidden;
}

@media screen and (max-width: 425px) {
	.inner {
		background: url(../images/bg-sp.jpg) no-repeat top center / cover;
	}
}


/******************************************************************************
 component
******************************************************************************/
.c-pcNone {
	display: none;
}

.c-spNone {
	display: block;
}

@media screen and (max-width: 768px) {
	.c-pcNone {
		display: block;
	}

	.c-spNone {
		display: none;
	}
}

/******************************************************************************
 animate.css追加
******************************************************************************/

.mv-chara-move1 {
	animation: mv-chara-move1 3s infinite ease-in-out;
}

@keyframes mv-chara-move1 {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(13px);
	}
}

.mv-chara-move2 {
	animation: mv-chara-move2 3s infinite ease-in-out;
}

@keyframes mv-chara-move2 {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(5px);
	}
}

.mv-chara-move3 {
	animation: mv-chara-move3 4s infinite ease-in-out;
}

@keyframes mv-chara-move3 {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(18px);
	}
}

.mv-chara-move4 {
	animation: mv-chara-move4 2s infinite ease-in-out;
}

@keyframes mv-chara-move4 {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(7px);
	}
}

.mv-chara-move5 {
	animation: mv-chara-move5 1.3s infinite ease-in-out;
}

@keyframes mv-chara-move5 {

	0%,
	100% {
		transform: translateY(0);
	}

	50% {
		transform: translateY(5px);
	}
}




/******************************************************************************
 button
******************************************************************************/

#voice_story .apply-button {
	display: block;
	width: min(700px, 90%);
	height: 7.2vw;
	margin: 0 auto;
}

#voice_story .apply-button:hover {
	opacity: 0.5;
}

.apply-button-fixed-wrap {
	background-image: url(../images/btn_1_bg.png);
	background-size: cover;
	background-repeat: no-repeat;
	width: 100%;
	position: fixed;
	z-index: 150;
	bottom: 0;
}

.apply-button-fixed {
	display: block;
	width: min(700px, 90%);
	margin-inline: auto;
}

/* #voice_story .apply-button-fixed {
	display: block;
	background: url(../images/btn_1.png) no-repeat center center / contain;
	width: 29.1vw;
	height: 7.2vw;
	margin: 0 auto;
	
	bottom: 3%;
	left: 50%;
	transform: translateX(-50%);
} */

/* 
@media screen and (max-width: 425px) {
	#voice_story .apply-button-fixed {
		background: url(../images/button-sp.png) no-repeat center center / contain ;
		width: 58.8vw;
		height: 14.7vw;
		left: 50%;
		transform: translateX(-50%);
	}
} */

#voice_story .apply-button-fixed:hover {
	opacity: 0.5;
}

/******************************************************************************
 共通
******************************************************************************/
img {
	display: block;
	width: 100%;
	height: auto;
}

a {
	outline: none;
	text-decoration: none;
}

/******************************************************************************
 project
******************************************************************************/

/* メイン */
main {
	font-family: "Sans Serif JP", serif;
	overflow: hidden;
	position: relative;
}

.background {
	background: url(../images/fixed_bg.png);
	width: 100%;
	position: fixed;
	background-size: cover;
	background-position: center;
	height: 100vh;
	z-index: -5;
	position: fixed;

}

/* MV */

.mv {
	background-color:rgba(0, 181, 239, 0.8);
	width: 100%;
	margin-top: clamp(0em,2vw,3em);
}

.mv-chara-wrap {
	display: block;
	width: 60%;
	margin-inline: auto;
	position: relative;
}
@media screen and (max-width:768px) {
.mv-chara-wrap {
	display: block;
	width: 100%;
	margin-inline: auto;
	position: relative;
}
}
.mv-chara {
	position: relative;
	z-index: 100;
}

.mv-chara-move img {
	position: absolute;
	z-index: 50;
	top: 0;
}


/* sec1 */
.bg-white2 {
	position: absolute;
	background: linear-gradient(rgba(255, 255, 255, 1)80%, rgba(255, 255, 255, 0));
	width: 70%;
	margin-inline: auto;
	height: 100%;
	z-index: -1;
	right: 0;
	left: 0;
	margin: -9em auto;
}
@media screen and (max-width: 768px) {
	.bg-white2 {
		width: 87%;
		background: linear-gradient(rgba(255, 255, 255, 1)94%, rgba(255, 255, 255, 0));
	}
}
@media screen and (max-width: 500px) {
	.bg-white2 {
		width: 96%;
		background: linear-gradient(rgba(255, 255, 255, 1)94%, rgba(255, 255, 255, 0));
	}
}
.bg-white {
	position: absolute;
	background: #fff;
	width: 70%;
	margin-inline: auto;
	height: 100%;
	z-index: -1;
	right: 0;
	left: 0;
	margin: -9em auto;
}
@media screen and (max-width: 768px) {
	.bg-white {
		width: 96%;
	}
}
.sec1-box {
	width: 50%;
	margin-inline: auto;
	position: relative;
}
@media screen and (max-width: 1024px) {
	.sec1-box {
		width: 96%;
		margin-inline: auto;
		position: relative;
	}
}


.sec1-maru img {
	display: block;
}

.sec1_img7_pc {
	width: 50%;
	margin-inline: auto;
	margin-top: 4em;
	margin-bottom: 5em;
}

@media screen and (max-width: 768px) {
	.sec1_img7_pc {
		width:76%;
		margin-inline: auto;
		margin-top: 2.5em;
		margin-bottom: 1.5em;
	}
}
.sec1_img8_pc {
	margin-bottom: 5em;
}
@media screen and (max-width: 768px) {
	.sec1_img8_pc {
		margin-bottom: 2em;
	}
}
/* sec2 */
.sec2 {
	padding-bottom: 5em;
}
.sec2-item {
	position: relative;
	margin-top: 3em;
}
.dec1,.dec2 {
	position: relative;
}
.dec1-chara1 {
	position: absolute;
	width: 20%;
	right: 0;
	top: 0;
}
@media screen and (max-width: 768px) {
	.dec1-chara1 {
		width: 23%;
	}
}
.dec1-chara2 {
	position: absolute;
	width: 15%;
	left: 0;
	bottom: -20%;
}
@media screen and (max-width: 768px) {
	.dec1-chara2 {
		width: 18%;
		bottom: -18%;
	}
}
.dec2-chara1 {
	position: absolute;
	width: 15%;
	right: 0;
	top: 40%;
}
.dec2-chara2 {
	position: absolute;
	width: 15%;
	left: 0;
	bottom: 0;
}
@media screen and (max-width: 768px) {
	.dec2-chara2 {
		bottom: -20%;
	}
}
.sec2_img1_pc {
	margin-bottom: 5em;
}
.sec2 .sec2_img2_pc {
	position: absolute;
	width: min(500px, 40%);
	left: 0;
}
@media screen and (max-width: 768px) {
	.sec2 .sec2_img2_pc {
		position: absolute;
		width: min(500px, 63%);
	}
}
.sec2 .sec2_img7_pc {
	position: absolute;
	width: 84%;
	right: 0;
}
@media screen and (max-width: 768px) {
	.sec2 .sec2_img7_pc {
		position: absolute;
		width: 98%;
		right: 0;
	}
}
.sec2_img3_pc {
	padding-top: 7em;
	width: 80%;
	margin-inline: auto;
}
@media screen and (max-width: 768px) {
	.sec2_img3_pc {
		padding-top: 4em;
		width: 100%;
		margin-inline: auto;
	}
}

.flow-img {
	width: 68%;
	margin-inline: auto;
	display: grid;
	row-gap: 1em;
	padding-top: 7em;
}
@media screen and (max-width: 768px) {

	.flow-img {
		width: 95%;
		margin-inline: auto;
		display: grid;
		row-gap: .3em;
		padding-top: 3em;
	}
}
.sec2_img12_pc {
	width:7%;
	margin-inline: auto;
}

.sec2_img13_pc {
	width: min(600px,80%);
	margin-inline: auto;
	margin-top: 1em;
	margin-bottom: 4em;
}




/* footer */
footer {
	font-family: "Noto Sans JP";
	background: #00a0df;
	padding: 2em;
	color: #fff;
}

@media screen and (max-width: 425px) {
	footer {
		padding: 6.94% 0 6.1%;
	}
}
footer a{
	color: #fff;
}
footer ul {
	display: flex;
	justify-content: center;
	font-size: 1.1vw;
	column-gap: 1em;
}

@media screen and (max-width: 425px) {
	footer ul {
		font-size: 2.61vw;
	}
}

footer .company {
	display: block;
	width: fit-content;
}

footer .business-start {
	display: block;
	width: fit-content;
}

footer .copyright {
	display: block;
	width: fit-content;
	font-size: 12px;
	margin: 0 auto;
}

@media screen and (max-width: 425px) {
	footer .copyright {
		font-size: 2.18vw;
	}
}