@charset "utf-8";

/* 星空の背景のスタイル */
.stars {
  position: relative;
  width: 100%; /* 星空の横幅 */
  overflow: hidden; /* 星が枠外にはみ出すのを防ぐ */
}

/* 星のスタイル */
.star {
  position: absolute;
  display: block;
  background-color: #fff; /* 星の色 */
  border-radius: 50%;
  box-shadow: 0 0 4px 2px rgba(#fff, 0.2); /* 星の影 */
  opacity: 0;
  animation: twinkle 5s infinite;
}

/* 星がキラキラ光るアニメーション */
@keyframes twinkle {
  0% {
    opacity: 0;
  }

  50% {
    transform: scale(1.1);
    opacity: 1;
  }

  100% {
    opacity: 0;
    transform: scale(1);
  }
}





/*===============================================
●画面の横幅が769px以上
===============================================*/
@media screen and (min-width : 769px ){
#pc------------------------------------------- {
}
#catch {
	position: relative;
	color: #fff;
	background-image: url("../images/pc/m_bg.png");
}
#catch h1 {
	margin-left: auto;
	margin-right: auto;
}






#detail {
	background-color: #151738;
	padding-bottom: 50px;
	margin-top: -150px;
}
#detail .box {
	border: 1px solid #fff;
	width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 50px;
	padding-bottom: 50px;
}
#detail .box h2 {
	font-size: 53px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-bottom: 60px;
}
#detail .box h2 span {
	font-size: 40px;
	margin-top: 2vw;
	margin-left: 20px;
}
#detail .box dl {
	margin-bottom: 30px;
}
#detail .box dt {
	background-color: #B6B8C3;
	font-size: 38px;
	width: 190px;
	height: 50px;
	line-height: 50px;
	font-family: 'Noto Serif JP', serif;
	color: #0C1036;
	margin-right: 10px;
	display: inline-block;
}
#detail .box dd {
	font-size: 38px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	line-height: 1.1em;
	display: inline-block;
	text-align: left;
}
#detail .box dl+dl dt {
	position: relative;
	top: -16px;
}
#detail .box dl+figure img {
	width: 300px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 0px;
}
#detail .box dl+figure+p {
	color: #fff;
	font-size: 20px;
	margin-top: 30px;
}
#detail nav ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 1280px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 50px;
}
#detail nav ul li {
	width: 170px;
	padding-left: 20px;
	padding-right: 20px;
	border-left: 1px solid #CCA7FF;
	margin-bottom: 40px;
}
#detail nav ul li img {
	width: 100%;
	height: auto;
}
#detail nav ul li:nth-of-type(6)
{
	border-right: 1px solid #CCA7FF;
}




.iconstars {
	width: 500px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 50px;
	margin-bottom: 50px;
}
.iconstars img {
	width: 30px;
}
.iconstars img+img {
	margin-left: 5px;
}




#about {
	background-color: #0A1335;
	padding-top: 100px;
	padding-bottom: 40px;
}
#about h2 {
	font-size: 60px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#about h2+figure+p {
	color: #fff;
	text-align: left;
	width: 780px;
	font-size: 32px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.8em;
	padding-bottom: 100px;
}
#about .box {
	position: relative;
	background-color: #0A1335;
	width: 1280px;
	margin-left: auto;
	margin-right: auto;
	margin-top: -1px;
}
#about .box h3 {
	color: #fff;
	font-size: 60px;
	font-family: 'Noto Serif JP', serif;
	text-align: left;
	line-height: 1.4em;
	margin-bottom: -30px;
}
#about .box h3 em {
	font-family: 'Noto Serif JP', serif;
}
#about .box figure img {
	width: 100%;
	height: 600px;
	object-fit: cover;
}
#about .box .iconstars {
	text-align: left;
	width: auto;
	margin-left: 50px;
}
#about .box .iconstars img {
	width: 23px;
	height: auto;
}
#about .box p {
	color: #fff;
	line-height: 1.8em;
	text-align: left;
	position: relative;
	z-index: 3;
	font-weight: 200;
	font-size: 32px;
}
#about .box .colorbox {
	background-color: #784FD7;
	width: 830px;
	height: 400px;
	position: relative;
	z-index: 1;
}
#about .box1 h3 {
	margin-left: 50px;
	text-indent: -0.5em;
	margin-top: -450px;
}
#about .box1 p {
	margin-left: 50px;
	margin-top: 220px;
}
#about .box1 .colorbox {
	margin-top: -370px;
}
#about .box1 .colorbox+figure {
	text-align: right;
	position: relative;
	z-index: 2;
	margin-top: -360px;
	margin-right: 190px;
}
#about .box1 .colorbox+figure img {
	width: 450px;
}
#about .box2 h3 {
	text-align: right;
	padding-top: 80px;
}
#about .box2 h3 em {
	margin-left: -37px;
}
#about .box2 p {
	text-align: right;
	margin-right: 50px;
	margin-top: 140px;
}
#about .box2 .colorbox {
	margin-left: 450px;
	margin-top: -340px;
}
#about .box2 .colorbox+figure {
	text-align: left;
	position: relative;
	z-index: 2;
	margin-top: -255px;
}
#about .box2 .colorbox+figure img {
	width: 600px;
	height: 400px;
	object-fit: cover;
}
#about .box3 h3 {
	margin-left: 50px;
	padding-top: 80px;
}
#about .box3 p {
	margin-left: 50px;
	margin-top: 140px;
}
#about .box3 .colorbox {
	margin-top: -310px;
}
#about .box3 .colorbox+figure {
	text-align: right;
	margin-top: -340px;
	margin-right: 200px;
	position: relative;
	z-index: 2;
}
#about .box3 .colorbox+figure img {
	width: 450px;
}
#about .box4 h3 {
	display: flex;
	justify-content: flex-end;
	margin-right: 50px;
	padding-top: 100px;
	margin-bottom: 20px;
}
#about .box4 h3 em {
	margin-left: -0.5em;
}
#about .box4 p {
	text-align: right;
	margin-right: 50px;
	margin-top: -555px;
}
#about .box4 .colorbox {
	margin-top: -340px;
	margin-left: 450px;
}
#about .box4 h3+figure {
	text-align: left;
	position: relative;
	z-index: 2;
	top: 220px;
}
#about .box4 h3+figure img {
	width: 790px!important;
	height: 600px;
	object-fit: cover;
}
#about .alpha {
	background-color: #0A1335;
	padding-top: 50px;
	padding-bottom: 50px;
	width: 1280px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 400px;
}
#about .alpha div {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	color: #fff;
	border: 1px solid #fff;
	padding-bottom: 20px;
}
#about .alpha div h3 {
	font-size: 60px;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
	padding-top: 50px;
	margin-bottom: 50px;
}
#about .alpha div li {
	text-indent: -1.2em;
	padding-left: 1.2em;
	font-size: 32px;
	margin-left: 50px;
	line-height: 1.2em;
	margin-bottom: 40px;
}





#message {
	background-color: #545871;
	padding-top: 100px;
	padding-bottom: 100px;
}
#message h2 {
	font-size: 60px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#message p {
	color: #fff;
	font-size: 4.10256410256vw;
	width: 800px;
	margin-left: auto;
	margin-right: auto;
	font-size: 20px;
	line-height: 1.8em;
}
#message p+p {
	margin-top: 3vw;
	font-family: 'Noto Serif JP', serif;
}





#access {
	background-color: #0A1335;
	padding-top: 80px;
	padding-bottom: 80px;
}
#access .box {
	background-color: #CBACFC;
	border-radius: 40px;
	width: 670px;
	margin-left: auto;
	margin-right: auto;
	padding-top: 25px;
	padding-bottom: 15px;
	position: relative;
}
#access .box a {
	display: block;
	width: 100%;
	height: 100%;
	z-index: 999;
	position: absolute;
	left: 0px;
	top: 0px;
	border-radius: 40px;
	transition: 0.3s;
}
#access .box a:hover {
	background-color: #fff;
	opacity: 0.3;
	transition: 0.3s;
}
#access .box p {
	font-size: 32px;
	color: #0C1036;
}
#access .box p+p {
	font-size: 50px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-top: 15px;
}
#access .box p+figure {
	width: 162px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 25px;
}
#access .box p+figure img {
	width: 100%;
	height: auto;
}
#access h2 {
	font-size: 60px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	margin-top: 100px;
	margin-bottom: -20px;
}
#access iframe {
	height: 450px;
	margin-bottom: 20px;
	margin-top: -30px;
}
#access h3 {
	font-size: 50px;
	font-family: 'Noto Serif JP', serif;
	color: #fff;
}
#access h3+p {
	font-size: 32px;
	color: #fff;
	margin-top: 20px;
	line-height: 1.2em;
}





#faq {
	background-color: #545871;
	padding-top: 80px;
	padding-bottom: 80px;
	font-size: 60px;
	color: #fff;
}
#faq h2 {
	font-size: 60px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#faq dl {
	width: 800px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#faq dl dt {
	margin-bottom: 20px;
	font-size: 20px;
	line-height: 1.5em;
}
#faq dl dd {
	padding-bottom: 70px;
	margin-bottom: 30px;
	border-bottom: 5px solid #B6B7C3;
	font-size: 20px;
	line-height: 1.5em;
}
#faq dl dd.last {
	border-bottom: none;
	padding-bottom: 0px;
	margin-bottom: 0px;
}





#contact {
	background-color: #0A1335;
	color: #fff;
	padding-top: 80px;
	padding-bottom: 80px;
}
#contact h2 {
	font-size: 60px;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#contact dl {
	text-align: left;
	width: 450px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 40px;
	line-height: 1.9em;
}
#contact dl::after {
	content: ".";   
  display: block;   
  height: 0;   
  clear: both;   
  visibility: hidden;  
}
#contact dl dt {
	float: left;
	clear: left;
}
#contact dl dd {
	float: left;
}
#contact dl dd a {
	color: #fff;
	text-decoration: none;
}
#pagetop {
	text-align: right;
	margin-right: 50px;
	margin-top: -70px;
}
#pagetop img {
	width: 70px;
}





footer {
	height: 100px;
	line-height: 100px;
	background-color: #DAC4FD;
	color: #0A1335;
}
footer small {
	font-size: 28px;
}
}



/*===============================================
●画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:768px){
	
/*===============================================
●sp-tablet
===============================================*/
#sptablet------------------------------------------- {
}
#catch {
	position: relative;
	background-color: #0A1335;
	height: 137vw;
	color: #fff;
}
#catch h1 {
	position: absolute;
	left: 0px;
	right: 0px;
	z-index: 99;
	width: 27.1794871795vw;
	margin-left: auto;
	margin-right: auto;
	top: 25vw;
}
#catch h1+figure {
	position: absolute;
	left: 0px;
	top: 0px;
	right: 0px;
}






#detail {
	background-color: #121432;
	padding-bottom: 5vw;
}
#detail .box {
	border: 1px solid #fff;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	padding-top: 6vw;
	padding-bottom: 5vw;
}
#detail .box h2 {
	font-size: 6.79487179487vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
}
#detail .box h2 span {
	font-size: 5.12820512821vw;
	display: block;
	margin-top: 2vw;
}
#detail .box dt {
	background-color: #B6B8C3;
	font-size: 4.87179487179vw;
	font-family: 'Noto Serif JP', serif;
	color: #0C1036;
	width: 24.358974359vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 3vw;
}
#detail .box dd {
	font-size: 4.87179487179vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	margin-top: 2vw;
}
#detail .box dl+figure {
	width: 24.358974359vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 5vw;
}
#detail .box dl+figure+p {
	color: #fff;
	font-size: 3.58974358974vw;
}
#detail nav ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 6vw;
}
#detail nav ul li {
	width: 28%;
	padding-left: 2vw;
	padding-right: 2vw;
	border-left: 1px solid #CCA7FF;
	margin-bottom: 3vw;
}
#detail nav ul li:nth-of-type(3),
#detail nav ul li:nth-of-type(6)
{
	border-right: 1px solid #CCA7FF;
}




.iconstars {
	width: 20.7692307692vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 2vw;
	margin-bottom: 3vw;
}
.iconstars img {
	width: 2.94871794872vw;
}
.iconstars img+img {
	margin-left: 0.5vw;
}




#about {
	background-color: #545871;
	padding-top: 8vw;
}
#about h2 {
	font-size: 6.41025641026vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#about h2+figure+p {
	color: #fff;
	text-align: left;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.8em;
	padding-bottom: 5vw;
}
#about .box {
	position: relative;
	background-color: #0A1335;
}
#about .box h3 {
	color: #fff;
	font-size: 7.69230769231vw;
	font-family: 'Noto Serif JP', serif;
	text-align: left;
	line-height: 1.4em;
}
#about .box h3 em {
	font-family: 'Noto Serif JP', serif;
}
#about .box .iconstars {
	text-align: left;
	width: auto;
	margin-left: 5vw;
}
#about .box p {
	font-size: 4.10256410256vw;
	color: #fff;
	line-height: 1.8em;
	text-align: left;
	position: relative;
	z-index: 3;
	font-weight: 200;
}
#about .box .colorbox {
	background-color: #784FD7;
	width: 76.9230769231vw;
	height: 51.2820512821vw;
	position: relative;
	z-index: 1;
}
#about .box1 h3 {
	margin-left: 5vw;
	margin-top: -21vw;
	text-indent: -0.5em;
}
#about .box1 p {
	margin-left: 5vw;
	margin-top: 5vw;
}
#about .box1 .colorbox {
	margin-top: -47.5vw;
}
#about .box1 .colorbox+figure {
	text-align: right;
	margin-top: -33vw;
	position: relative;
	z-index: 2;
}
#about .box1 .colorbox+figure img {
	width: 57.6923076923vw;
}
#about .box2 h3 {
	display: flex;
	justify-content: flex-end;
	margin-right: 3vw;
	padding-top: 3vw;
}
#about .box2 h3 em {
	margin-left: -0.5em;
}
#about .box2 p {
	text-align: right;
	margin-right: 8vw;
	margin-top: 9vw;
}
#about .box2 .colorbox {
	margin-top: -44vw;
	margin-left: 18.5vw;
}
#about .box2 .colorbox+figure {
	text-align: left;
	margin-top: -30vw;
	position: relative;
	z-index: 2;
}
#about .box2 .colorbox+figure img {
	width: 76.9230769231vw;
}
#about .box3 h3 {
	margin-left: 5vw;
	padding-top: 5vw;
}
#about .box3 p {
	margin-left: 5vw;
	margin-top: 10vw;
}
#about .box3 .colorbox {
	margin-top: -38.5vw;
}
#about .box3 .colorbox+figure {
	text-align: right;
	margin-top: -28vw;
	position: relative;
	z-index: 2;
}
#about .box3 .colorbox+figure img {
	width: 57.6923076923vw;
}
#about .box4 h3 {
	display: flex;
	justify-content: flex-end;
	margin-right: 3vw;
	padding-top: 5vw;
}
#about .box4 h3 em {
	margin-left: -0.5em;
}
#about .box4 p {
	text-align: right;
	margin-right: 8vw;
	margin-top: -18vw;
}
#about .box4 .colorbox {
	margin-top: -44vw;
	margin-left: 18.5vw;
}
#about .box4 .colorbox+figure {
	text-align: left;
	margin-top: -30vw;
	position: relative;
	z-index: 2;
}
#about .box4 .colorbox+figure img {
	width: 76.9230769231vw;
}
#about .alpha {
	background-color: #0A1335;
	padding-top: 7vw;
	padding-bottom: 10vw;
}
#about .alpha div {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	color: #fff;
	border: 1px solid #fff;
}
#about .alpha div h3 {
	font-size: 7.69230769231vw;
	font-family: 'Noto Serif JP', serif;
	text-align: center;
	padding-top: 5vw;
	margin-bottom: 7vw;
}
#about .alpha div li {
	text-indent: -1.2em;
	padding-left: 1.2em;
	font-size: 4.10256410256vw;
	margin-left: 5vw;
	margin-bottom: 5vw;
}





#message {
	background-color: #545871;
	padding-top: 7vw;
	padding-bottom: 7vw;
}
#message h2 {
	font-size: 6.41025641026vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#message p {
	color: #fff;
	font-size: 4.10256410256vw;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
}
#message p+p {
	margin-top: 3vw;
	font-family: 'Noto Serif JP', serif;
}





#access {
	background-color: #0A1335;
	padding-top: 10vw;
	padding-bottom: 10vw;
}
#access .box {
	background-color: #CBACFC;
	border-radius: 6.41025641026vw;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	padding-top: 3vw;
	padding-bottom: 1vw;
	position: relative;
}
#access .box a {
	display: block;
	width: 100%;
	height: 100%;
	z-index: 999;
	position: absolute;
	left: 0px;
	top: 0px;
	border-radius: 6.41025641026vw;
	transition: 0.3s;
}
#access .box p {
	font-size: 4.10256410256vw;
	color: #0C1036;
}
#access .box p+p {
	font-size: 6.41025641026vw;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	margin-top: 1vw;
}
#access .box p+figure {
	width: 20.7692307692vw;
	margin-left: auto;
	margin-right: auto;
	margin-top: 3vw;
}
#access h2 {
	font-size: 6.41025641026vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
	margin-top: 10vw;
}
#access iframe {
	height: 57.6923076923vw;
	margin-bottom: 1vw;
}
#access h3 {
	font-size: 6.41025641026vw;
	font-family: 'Noto Serif JP', serif;
	color: #fff;
}
#access h3+p {
	font-size: 4.10256410256vw;
	color: #fff;
	margin-top: 2vw;
}





#faq {
	background-color: #545871;
	padding-top: 8vw;
	padding-bottom: 8vw;
	font-size: 4.10256410256vw;
	color: #fff;
}
#faq h2 {
	font-size: 6.41025641026vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#faq dl {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}
#faq dl dt {
	margin-bottom: 3vw;
}
#faq dl dd {
	padding-bottom: 7vw;
	margin-bottom: 3vw;
	border-bottom: 5px solid #B6B7C3;
}
#faq dl dd.last {
	border-bottom: none;
	padding-bottom: 0px;
	margin-bottom: 0px;
}





#contact {
	background-color: #0A1335;
	color: #fff;
	padding-top: 7vw;
	padding-bottom: 7vw;
}
#contact h2 {
	font-size: 6.41025641026vw;
	color: #fff;
	font-family: 'Noto Serif JP', serif;
}
#contact dl {
	text-align: left;
	width: 90%;
	margin-left: auto;
	margin-right: auto;
	margin-top: 2vw;
}
#contact dl::after {
	content: ".";   
  display: block;   
  height: 0;   
  clear: both;   
  visibility: hidden;  
}
#contact dl dt {
	float: left;
	clear: left;
}
#contact dl dd {
	float: left;
}
#contact dl dd a {
	color: #fff;
	text-decoration: none;
}
#pagetop {
	text-align: right;
	margin-right: 5vw;
	margin-top: -7vw;
}
#pagetop img {
	width: 8.97435897436vw;
}





footer {
	height: 12.8205128205vw;
	line-height: 12.8205128205vw;
	background-color: #DAC4FD;
	color: #0A1335;
}
footer small {
	font-size: 3.58974358974vw;
}
}



/*===============================================
●画面の横幅が400pxまで
===============================================*/
@media screen and (max-width:400px){
/*===============================================
●sp400
===============================================*/
#sp400------------------------------------------- {
}
}



/*===============================================
●画面の横幅が320pxまで
===============================================*/
@media screen and (max-width:320px){
/*===============================================
●sp320
===============================================*/
#sp320------------------------------------------- {
}
}



/*===============================================
●画面の横幅が481pxから768pxまで
===============================================*/
@media screen and (min-width:481px) and (max-width:768px) {
/*===============================================
●tablet
===============================================*/
#tab------------------------------------------- {
}
}