@charset "utf-8";

/* 打消し用 */
h1, h2, h3, h4, h5, h6, p {
	font-weight: inherit;
}
button {
	background: none;
	border: none;
}
body {
	font-family: "M PLUS Rounded 1c", sans-serif;
	color: #353332;
	font-weight: 500;
	line-height: 1.75;
}
#contents01 {
	font-family: "M PLUS Rounded 1c", sans-serif;
	color: #353332;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.75;
}
#contents01 header {
	padding: 30px 10px 17.5px;
}
/* End 打消し用 */

#contents01 header > .btnWrap01 {
	margin-top: 20.5px;
	margin-left: auto;
	max-width: 980px;
}
#ct_bg {
	overflow: visible;
}
#ct_bg .swiperBlock01 .caption {
	position: static;
	overflow: visible;
	margin: 15px 0 0;
	clip: unset;
	white-space: unset;
	width: auto;
	height: auto;
	max-height: unset;
	font-size: 16px;
	color: initial;
}
#ct_bg .accordion .swiper-button-prev,
#ct_bg .accordion .swiper-button-next {
	top: 297px;
}
#ct_bg .section01 {
    padding: 100px 40px 82px;
    width: 100%;
    background: url(../images/top/bg02.png) repeat;
    position: relative;
    overflow: hidden;
}
#ct_bg .section01 .inner01 {
	margin-inline: auto;
	width: 100%;
	max-width: 780px;
}
#ct_bg .section01.type01 {
	padding-bottom: 172px;
	background: url(../images/top/bg03.png) repeat;
}

#ct_bg .section01.type02 {
	padding-bottom: 153px;
	background: url(../images/top/bg04.png) repeat;
}

/* parts */
.btnWrap01 {
	margin: auto;
	max-width: 980px;
}
.btnWrap01 > .inner01 {
	position: relative;
	display: flex;
	margin-left: auto;
	width: fit-content;
	overflow: hidden;
}
.btnWrap01 .text01 a {
	display: block;
	padding: 5px 8px;
	color: #9E65C9;
	font-size: 13px;
	line-height: 1.25;
	border-radius: 100vmax 0 0 100vmax;
	border-top: 1px solid #9E65C9;
	border-bottom: 1px solid #9E65C9;
	border-left: 1px solid #9E65C9;
	transition: background 0.3s, color 0.3s;
}
.btnWrap01 .text01:not(:first-child) a {
    padding: 5px 15.5px;
}
@media (any-hover: hover) {
  .btnWrap01 .text01 a:hover {
    background: #9E65C9;
    color: #FFF;
	opacity: 1!important;
  }
}
.btnWrap01 .text01 a.current {
	color: #FFF;
	background: #9E65C9;
	border-radius: 0 100vmax 100vmax 0;
	pointer-events: none;
}
#ct_bg .section01 .hgroup01 {
	position: relative;
	text-align: center;
}
#ct_bg .section01 .hgroup01 > .text01 {
	margin-top: 20px;
	font-size: 24px;
}
#ct_bg .section01 .inner01 > .text01 + .hgroup01 {
	margin-top: 100px;	
}
#ct_bg .section01 .heading01 {
	color: #FFAA64;
	font-size: 48px;
	font-weight: 800;
	line-height: 1.25;
}
#ct_bg .section01.type01 .heading01 {
	color: #9E65C9;
}
#ct_bg .section01.type02 .heading01 {
	color: #47B6ED;
}
#ct_bg .section01 .title01 {
	color: #0B308D;
	text-align: center;
	font-size: 32px;
	font-weight: 800;
	line-height: 1.25;
}
#ct_bg .section01 .title02 {
	color: #FFF155;
	text-align: center;
	font-size: 24px;
	font-weight: 800;
	line-height: 1.25;
}
#ct_bg .section01 .title03 {
	color: #005EB8;
	text-align: center;
	font-size: 40px;
	line-height: 1.25;
}
#ct_bg .section01 .text01 {
	font-size: 24px;
	text-align: center;
	transform: rotate(0.03deg);
}
#ct_bg .section01 .text02 {
	font-size: 20px;
	transform: rotate(0.03deg);
}
#ct_bg .section01 .wrap01 {
	display: flex;
	flex-wrap: wrap;
}
#ct_bg .section01 .block01 {
	margin-top: 20px;
	padding: 42px 60px 60.29px;
	background: #fff;
	border-radius: 40px;
}
#ct_bg .section01 .block01 .wrap01 {
	margin-top: 20.5px;
	justify-content: center;
	gap: 0 40px;
}
#ct_bg .section01 .block01 .wrap01 .image01 {
	width: calc( (100% - 40px) / 2 );
}
#ct_bg .section01 .block02 {
	padding-bottom: 32px;
	background: #fff;
	border-radius: 40px;
}
#ct_bg .section01 .block02 > .title01 {
	color: #fff;
	padding: 20px 0;
	border-radius: 40px 40px 0 0;
	background: #407EC9;
}
#ct_bg .section01 #rabbit.block02 > .title01 {
	background: #960051;
}
#ct_bg .section01 .block02 > .wrap01 {
	gap: 0 24px;
	margin-top: 32px;
	padding: 0 40px;
}
#ct_bg .section01 .block02 > .wrap01 .image01 {
	width: 100%;
	max-width: 155px;
}
#ct_bg .section01 .block02 > .wrap01 .text01 {
	width: calc( 100% - 24px - 155px );
	font-size: 20px;
	font-weight: 400;
	text-align: left;
}
#ct_bg .section01 .block03 {
	position: relative;
	padding: 0 54px;
	border-radius: 16px;
}
#ct_bg .section01 .accordion + .block03 {
	margin-top: 100px;
}
#ct_bg .section01 .block03 + .block03 {
	margin-top: 59.6px;
}
#ct_bg .section01 .block03 .ic01 {
	position: absolute;
	top: -30px;
	left: 50%;
	transform: translateX(-50%);
	width: 64px;
	aspect-ratio: 1 / 1;
}
#ct_bg .section01 .block03 .inner01 {
	padding: 40px;
	background: #fff;
	border-radius: 16px;
}
#ct_bg .section01 .block03 .inner01 .title03 + * {
	margin-top: 20px;
}
#ct_bg .section01 .block03 .inner01 .imageWrap01 {
	margin-inline: auto;
	width: 100%;
	max-width: 244px;
}
#ct_bg .section01 .block03 .inner01 .imageWrap01 + * {
	margin-top: 20px;
}
#ct_bg .section01 .block03 .inner01 .imageWrap01 .cap01 {
	display: block;
	margin-top: 8px;
}
#ct_bg .section01 .block03 .inner01 .wrap01 {
	gap: 0 40px;
}
#ct_bg .section01 .block03 .inner01 .wrap01 + * {
	margin-top: 20px;
}
#ct_bg .section01 .block03 .inner01 .wrap01 .image01 {
	width: calc( (100% - 40px) / 2 );
}
#ct_bg #sec02.section01 .accordion:not(:has(.popup_btn)) {
	padding: 0 54px;
}
#ct_bg #sec02.section01 .acdBox01 {
	position: relative;
}
#ct_bg #sec02.section01 .acdBox01 + .acdBox01 {
	margin-top: 54px;
}
#ct_bg #sec02.section01 .acdBox01 .ic01 {
	position: absolute;
	top: -24px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	width: 80px;
	aspect-ratio: 1 / 1;
}
#ct_bg #sec02.section01 .acdBox01 .dt {
	padding: 64px 42px 24px;
	border-radius: 16px 16px 0 0;
	background: #407EC9;
}
#ct_bg #sec02.section01 #rabbit.block02 + .accordion .acdBox01 .dt {
	background: #960051;
}
#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .title02 {
	margin-bottom: 24px;
	width: 100%;
}
#ct_bg #sec02.section01 .acdBox01 .dt .wrap01,
#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 {
	display: flex;
	gap: 0 32px;
	overflow: visible;
}
#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .image01,
#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 .image01 {
	width: 100%;
	max-width: 142px;
}
#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .text01,
#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 .text01 {
	width: calc( 100% - 32px - 142px );
	color: #FFF;
	font-size: 20px;
	text-align: left;
}
#ct_bg #sec02.section01 .acdBox01 .dd {
	padding: 24px 40px;
	background: #fff;
}
#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 .text01 {
	color: #353332;
}
#ct_bg .popup_btn a {
	display: block;
	text-align: center;
	color: #fff;
	font-size: 40px;
	line-height: 1.25;
}
#ct_bg .movie > .text01 {
	margin-top: 8.53px;
	color: #3C3C3A;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.48;
	letter-spacing: 0.24px;
	text-align: left;
}
#ct_bg .movie + .imageWrap01 {
	margin-top: 76px;
}
#ct_bg .linkArea ul {
	gap: 0 69px;
}
.mfp-container {
	height: 100vh;
}
.mfp-wrap:has( #pop01.popup01 ) {
	height: 100vh;
}
.mfp-wrap:has( #pop01.popup01 ) .mfp-content {
	overflow: hidden;
}
.mfp-container #pop01.popup01 {
	padding: 42px;
	max-width: 900px;
    max-height: 85vh;
}
.mfp-container #pop01.popup01 .inner01 {
	max-height: 80vh;
    width: 100%;
    padding: 30px 20px;
	overflow: auto;
}
.mfp-container .image01 img {
	width: 100%;
	height: auto;
}
#ct_bg .acdBox01 .btnWrap01 {
	margin-top: 24px;
}
#ct_bg .acdBox01 .btnWrap01 button {
	cursor: pointer;
	width: 159px;
	height: 42px;
}
#ct_bg .acdBox01 .btnWrap01 img {
  transition: opacity 0.3s ease;
}
#ct_bg .acdBox01 .dt .btnWrap01 img {
	transform: rotate(180deg);
}
#ct_bg .acdBox01 .dt.active .btnWrap01 img {
	transform: rotate(0deg);
}
@media (max-width: 1024px) {
	#ct_bg  .linkArea ul li:nth-child(1)::before {
		width: 100px;
        aspect-ratio: 141 / 108;
		background-repeat: no-repeat;
	}
	#ct_bg  .linkArea ul li:nth-child(1)::after {
		width: 80px;
        aspect-ratio: 113 / 172;
		background-repeat: no-repeat;
	}
	#ct_bg  .linkArea ul li:nth-child(2)::before {
		width: 80px;
        aspect-ratio: 115 / 175;
        background-repeat: no-repeat;
	}
	#ct_bg  .linkArea ul li:nth-child(2)::after {
		width: 100px;
        aspect-ratio: 139 / 128;
		background-repeat: no-repeat;
	}
}
@media (max-width: 768px) {
	body {
		overflow: clip;
	}
	body:has(.mfp-bg.mfp-ready) {
		overflow: hidden;
	}
	#contents01 {
		font-size: 4vw;
	}
	#contents01 header {
		padding: 0;
	}
	#contents01 header > .btnWrap01 {
        margin-top: 0;
        position: absolute;
        top: 2.5vw;
        right: 15vw;
	}
	#contents01 nav a {
		color: #fff;
	}
	.btnWrap01 .text01 a {
		padding: 1.25vw 2vw;
		font-size: 3vw;
	}
	.btnWrap01 .text01 a.current {
		padding: 1.25vw 3.75vw;
	}
	#ct_bg .section01 {
		padding: 10vw 5vw;
	}
	#ct_bg .section01 {
		padding: 8vw 5vw!important;
	}
	#ct_bg .section01 .hgroup01 > .text01 {
		font-size: 6vw;
	}
	#ct_bg .section01 .hgroup01 > .text01 {
		margin-top: 3.75vw;
	}
	#ct_bg .section01 .heading01 {
		font-size: 9.5vw;
	}
	#ct_bg .section01 .title01 {
		font-size: 7vw;
	}
	#ct_bg .section01 .title02 {
		font-size: 5vw;
	}
	#ct_bg .section01 .title03 {
		font-size: 7.5vw;
	}
	#ct_bg .section01 .text01 {
		font-size: 5vw;
	}
	#ct_bg .section01 .text02 {
		font-size: 4.5vw;
	}
	#ct_bg .movie {
		margin-top: 7.5vw;
	}
	#ct_bg .movie > .text01 {
		font-size: 3vw;
	}
	#ct_bg .movie + .imageWrap01 {
		margin-top: 7.5vw;
		margin-inline: calc( 50% - 50vw );
	}
	#ct_bg .section01 .block01 .wrap01 {
		gap: 0 2.5vw;
	}
	#ct_bg .section01 .block01 .wrap01 > .image01{
		width: calc( (100% - 2.5vw) / 2 );
	}
	#ct_bg .section01 .block01 {
		margin-top: 5vw;
		padding: 5vw;
		border-radius: 2.67vw;
	}
	#ct_bg .section01 .block02 {
		padding-bottom: 5vw;
		border-radius: 2.67vw;
	}
	#ct_bg .section01 .block02 > .title01 {
		padding: 2.5vw 0;
		border-radius: 2.67vw 2.67vw 0 0;
	}
	#ct_bg .section01 .block02 > .wrap01 {
		gap: 5vw;
		margin-top: 5vw;
		padding: 0 2.5vw;
	}
	#ct_bg .section01 .block02 > .wrap01 .image01 {
		margin-inline: auto;
		max-width: 25vw;
	}
	#ct_bg .section01 .block02 > .wrap01 .text01 {
		width: 100%;
		font-size: 4vw;
	}
	#ct_bg .section01 .accordion + .block03 {
		margin-top: 15vw;
	}
	#ct_bg .section01 .block03 {
		padding: 0;
	}
	#ct_bg .section01 .block03 + .block03 {
		margin-top: 10.63vw;
	}
	#ct_bg .section01 .block03 .ic01 {
		top: -5.63vw;
		width: 11.25vw;
	}
	#ct_bg .section01 .block03 .inner01 {
		padding: 10vw 5vw 5vw;
		border-radius: 2.67vw;
	}
	#ct_bg .section01 .block03 .inner01 .title03 + * {
		margin-top: 5vw;
	}
	#ct_bg #sec02.section01 .accordion:not(:has(.popup_btn)) {
		margin-top: 16.25vw;
		padding: 0;
	}
	#ct_bg #sec02 .accordion:not(:has(.popup_btn)) div.dt,
	#ct_bg #sec02 .accordion:not(:has(.popup_btn)) div.dd {
		padding: 12vw 5vw 6vw;
	}
	#ct_bg #sec02.section01 .acdBox01 + .acdBox01 {
		margin-top: 16.25vw;
	}
	#ct_bg .acdBox01 .btnWrap01 {
		margin-top: 6vw;
	}
	#ct_bg #sec02.section01 .acdBox01 .ic01 {
		top: -8.75vw;
		width: 17.5vw;
	}
	#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 {
		gap: 5vw;
	}
	#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .title02 {
		margin-bottom: 0;
		width: calc( 100% - 5vw - 25vw );
		text-align: left;
		order: 2;
	}
	#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .image01,
	#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 .image01 {
		max-width: 25vw;
		order: 1;
	}
	#ct_bg #sec02.section01 .acdBox01 .dt .wrap01 .text01 {
		width: 100%;
		font-size: 4vw;
		order: 3;
	}
	#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 .text01 {
		width: calc( 100% - 5vw - 25vw );
		font-size: 4vw;
		order: 2;
	}
	#ct_bg #sec02 .accordion:not(:has(.popup_btn)) div.dd {
		padding: 5vw;
	}
	#ct_bg #sec02.section01 .acdBox01 .dd .wrap01 {
		gap: 5vw;
		margin-top: 0;
	}
	#ct_bg .accordion:has(.popup_btn) {
		margin: 7.5vw 0!important;
		padding: 0!important;
	}
	#ct_bg .accordion:has(.btn01) {
		margin: 7.5vw 0;
	}
	#ct_bg .popup_btn a {
		font-size: 6.25vw;
	}
	#ct_bg .linkArea ul {
		gap: 7.5vw;
	}
	#ct_bg .linkArea ul li {
		width: 100%;
	}
	#ct_bg  .linkArea ul li:nth-child(1)::before {
		width: 22.68vw;
		background-repeat: no-repeat;
		top: 2.5vw;
		left: -5vw;
	}
	#ct_bg  .linkArea ul li:nth-child(1)::after {
		width: 17vw;
		background-repeat: no-repeat;
		height: 27.33vw;
		top: 1.325vw;
		right: -2.5vw;
	}
	#ct_bg  .linkArea ul li:nth-child(2)::before {
        width: 19.33vw;
        background-repeat: no-repeat;
        height: 29.43vw;
        top: -7vw;
        left: -1.5vw
	}
	#ct_bg  .linkArea ul li:nth-child(2)::after {
		width: 23.25vw;
		background-repeat: no-repeat;
		top: 13.75vw;
		right: -3vw;
	}
	#ct_bg .accordion .swiper-button-prev,
	#ct_bg .accordion .swiper-button-next {
		top: 50vw;
	}
	.mfp-container {
		height: 75vh;
	}
	.mfp-container #pop01.popup01 {
		margin-inline: 2.5vw;
        padding: 12vw 5vw 10vw;
	}
	.mfp-container #pop01.popup01 .inner01 {
		padding: 0;
		max-height: 65vh;
	}
	#ct_bg #sec01 .hgroup01::before {
		width: 16.55vw;
		transform: unset;
		left: 0;
        top: -10vw;
	}
	#ct_bg #sec01 .hgroup01::after {
		width: 20vw;
		top: -5.5vw;
		transform: unset;
		left: auto;
		right: 0;
	}
	#sec03::before {
		width: 20vw;
		transform: unset;
		left: 0;
		background-repeat: no-repeat;
		top: 25vw;
	}
	#sec03::after {
		width: 20vw;
		transform: unset;
		background-repeat: no-repeat;
		top: 20vw;
		left: auto;
		right: 0;
	}
}