@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@100;300;400;500;700;800;900&family=Noto+Sans+JP:wght@100..900&display=swap');

/* CSS Document */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse;
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}
.both{
	clear:both;
}
p {
    display: block;
    -webkit-margin-before:0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
}
.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}
html{
font-family: 'Noto Sans JP', sans-serif,"游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
font-size:18px;
line-height:1.6;
color:#6D6D6D;
}
@media screen and (max-width: 900px){
	html{
		font-size:18px;
	}
	
}
@media screen and (max-width: 500px){
	html{
		font-size:4.2vw;
	}
	
}

img{
	display:block;
	max-width:100%;
	height:auto;
}
a,
a:hover,
a:active,
a:visited,
a:link{
	text-decoration:none;
	color:inherit;
}
ol, ul{
    list-style:none;
}

.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.both{
	clear:both;
}

.inline_block {
	display: inline-block;
	*display: inline;
	*zoom: 1;
}

span{
	display:inline-block;
	font-weight: inherit;
}

p{margin-bottom:20px;
}
p:last-child{margin-bottom:0px;
}







.site-header{
	padding: 0px;
	z-index: 800;
    position: fixed;
	top: 0;
    background: #071269;
    box-sizing: border-box;
    width: 100%;
	box-sizing: border-box;

}
.header_container{
    width: 100%;
    position: relative;
    display: flex;
    justify-content: space-between;
    margin: auto;
    align-items: center;
    padding-top: 10px;
    padding-bottom: 10px;
	padding-left: 20px;
	padding-right: 20px;	
	height: 70px;
	z-index: 1000;
    background:#000000;
	box-sizing: border-box;
	border-bottom: 3px solid #edda9f;
}
.header_container .hl{
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	height: 90px;
	width: 30%;
}
.header_container .hr{
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	height: 90px;
	width: 30%;
}
.header_container .center{
	position: absolute;
    height: 70px;
    top: 0px;
    width: 240px;
    display: block;
    right: 0;
    left: 0;
    margin: auto;
}

.headerlogo{
	width: 180px;
}
.headermain{
z-index: 1000;
}
.spnavibtn{
	align-items:center;
}
.navibtn .menubtn_open{
}
.navibtn .menubtn_close{
	display: none;
}
.navibtn.active .menubtn_open{
	display: none;
}
.navibtn.active .menubtn_close{
	display: block;
}


.copy2{
	width: 90%;
	display: block;
	margin: 2em auto;
}

.menubtn_open{
	cursor: pointer;
}
.spnavi{
		background-color: rgba(0,0,0,0.50);
		height: 100vh;
		position: fixed;
		width: 100%;
		top: 0;
		height: 100vh;
		left: 0;
		background-color: rgba(0,0,0,0.50);
		z-index: 90;
		cursor: pointer;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	flex-direction: column;
}
.spnavi_inner{
    position: relative;
    top: 0;
    margin: 0;
	overflow:auto;
	z-index: 910;
    left: 0;
    right: 0;
    top: 0px;
	background: #000040;
    box-sizing: border-box;
	padding: 15px;
    gap: 15px;
	padding-top: 20px;
	padding-top: 110px;
	padding-bottom: 40px;
	width: 100%;
	align-items: center;
	justify-content: flex-start;
	flex-direction: column;
    border-bottom: 3px solid #edda9f;
}
.spnavi,
.spnavi_inner{
	display:none;
}
.spnavi_bg{
		display: none;
		position: fixed;
		width: 100%;
		top: 0;
		height: 100vh;
		left: 0;
		background-color: rgba(0,0,0,0.50);
		z-index: 90;
		cursor: pointer;
	}
.spnavilogo{
	max-width: 300px;
	margin: auto;
	margin-top: 30px;
	width: 50%;
	display: none;
}
.spnavi.active{
	display:flex;
}

.popupmoviebox{
	position:fixed;
	width:90%;
	z-index:100001;
	display:none;
	left:5%;
	top:50%;
	margin-top:-25.3125%;	
}
.popupmoviebox iframe{
	width:100%;
}
.popupmoviebg{
	position:fixed;
	height:100vh;
	width:100vw;
	z-index:100000;
	display:none;
     top: 0;
    left: 0;
	background-color:rgba(0,0,0,0.70);
}
.moviethumb{
	cursor:pointer;
}

.youtubearea{
	padding:0 !important;
	width:100%;
	height:0;
	position:relative;
  padding-top: 56.25% !important;
  overflow:hidden;
  margin-bottom:20px;
}
.youtubearea iframe{
	width:100%;
	height:100%;
	position:absolute;
	top:-20%;
	right:-20%;
	left:-20%;
	bottom:-20%;
	margin:auto;
}



.head_navi a{
    font-family: 'Catamaran','Open Sans', sans-serif;
    letter-spacing: 0.15em;
	font-size:18px;
	font-weight: 700;
	display: block;
	padding: 10px 0 ;
	color: #5F5F5F;
}
.head_navi a:hover{
	color: #eb6ea5;
}
.head_navi ul{
	max-width: 1200px;
	margin: auto;
	display: flex;
	align-items:center;
	justify-content:flex-start;
    column-gap: 40px;
	flex-wrap: wrap;
}
.submenu{
	width: 50%;
    margin: auto;
}
.submenu li{
	position: relative;
	height: 50px;
	 display: flex;
	justify-content: space-between;
	border-bottom: 1px solid #2750b6;
	align-items: center;
}
.submenu li a{
	font-size:20px;
	font-weight: 600;
}
.submenu li:after{
	content: "";
	background-image: url("../images/navbtn.svg");
	display: block;
	width: 30px;
	height: 30px;
}
.subheader{
	background: #f1f1f1;
	height: 200px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.pankz{
	padding: 5px 20px;
	border-bottom: 1px solid #f1f1f1;
	font-size: 14px;
}
.pankz .inner{
	max-width: 1200px;
	margin: auto;
}
.pankz a{
	font-size: 14px;
	font-weight: 600;
	color:#5F5F5F ;
}
.pankz a:hover{
	color:#eb6ea5 ;
}

.pankz a:after{
	content: "";
    width: 0px;
    border-left: 6px solid #f1f1f1;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    height: 0px;
    display: inline-block;
    margin-left: 10px;
    margin-right: 10px;
}

html{
	
}
h1{
	display: block;
}
p{
	margin-bottom: 1rem;
}
.kome{
	font-size:0.8rem;
}
body{
	background-color: #000000;
}
img{
	width: 100%;
}
section{
	max-width: 800px;
margin: auto;
padding:5vw;
	color: #fff;
	position: relative;
	z-index: 1;
    overflow: hidden;width: 100%;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
	margin-top: -7px;
	padding-bottom: 10vw;
}

section.top{
	padding:0px;
	margin-top: 70px;
}
section.naibunabi{
	background: #000040;
	padding: 50px 30px 55px;
	
}
section.footer{
	background: #000040;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10vw;
	flex-wrap: wrap;
}
section.footer a{
	display: block;
	width: 200px;
}
@media screen and (min-width: 900px){
	section{
		padding:50px;
	}
	section.footer{
		padding:50px;
	}
	
}
.spnavimenu{
	max-width: 740px;
	
}
section.naibunabi .fle,
.spnavimenu{
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}
section.naibunabi a,
.spnavimenu a{
	font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 800;
	background: #ffff08;
    width: calc(50% - 15px);
    border-radius: 18px;
    text-align: center;
    color: #000040;
    padding: 0;
    display: block;
    font-size: min(3.8vw, 23px);
   
    line-height: 1.2;
    height: 3.3em;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
	 box-shadow: -2px -2px 7px 5px rgba(247, 255, 0, 0.2), 2px 2px 7px 5px rgba(202, 255, 104, 0.2);
	
}
section.naibunabi a.pink,
.spnavimenu a.pink{
	background: #ff4fbd;
	color: #ffffff;
	box-shadow: -2px -2px 7px 5px rgba(255, 93, 253, 0.2), 2px 2px 7px 5px rgba(255, 93, 253, 0.2);
}
.oubomade{
	display: flex;
	width: 90%;
	justify-content: center;
	margin: auto;
	margin-bottom: 2rem;
	align-items: center;
	line-height: 1;
}
.oubomade div{
	    font-size: min(5vw, 31px);
    /* margin: auto; */
    font-weight: 700;
}
.oubomade div.day{
	font-size: min(9vw, 55px);
    color: #83e60f;
    display: block;
    margin-left: 0.2rem;
    margin-right: 0.2rem;
}
.bgfiximg2{display: block;
    width: 100%;
    height: 100%;
    z-index: 0;
    position: fixed;
    overflow: hidden;
    filter: blur(0.5rem);
	 animation-name: anibg;
  animation-duration: 4s;
  animation-iteration-count:infinite;


}



@keyframes anibg{
  0%{
    filter: blur(0.5rem);
  }
	

  50%{
    filter: blur(0rem);
  }
  
  100%{
   filter: blur(0.5rem);
  }
}


.copyright{display: block;text-align: center;
width: 100%;font-size:0.8rem;}
a.topbtn{
	position: fixed;
    bottom: 20px;
    right: 20px;
	display: block;
	width: 60px;
	height: 60px;
	z-index: 100;
	
}
a.topbtn img{
	position: absolute;
	width: 60px;
	top: 0;
	left: 0;
}
a.topbtn img.kuru{
	 animation-name: animation;
  animation-duration: 4s;
  animation-iteration-count:infinite;
}


@keyframes animation{
  0%{
   transform: rotate(0);
  }
	

  50%{
   transform: rotate(359deg);
  }
  
  100%{
   transform: rotate(0);
  }
}
h2{
	text-align: center;
}
h2 > img{
	width: 90%;
	text-align: center;
	display: block;
	margin: auto;
	margin-bottom: 2rem;
	margin-top: 2rem;
}
h4{
	font-size: 1em;
    font-weight: 800;
    color: #ffff08;
}
ul.dotlist{
	margin-bottom: 1em;
}
ul.dotlist li{
	position: relative;
	padding-left: 1em;
	margin-bottom: 0.5em;
}
ul.dotlist li:before{
	content: "";
	width: 0.7em;
	height: 0.7em;
	border-radius: 50px;
	display: block;
	background: #ffff08;
	position: absolute;
	left: 0;
	top: 0.5em;
	
}
.copy1{
	font-size: min(4.3vw, 34px);
    font-weight: 800;
	color: #ffffff;
	text-align: center;
	
}
hr.dotstyle{
	background: url("../images/dotline.svg");
	display: block;
	border: none;
	height: 0;
	padding-top: 5%;
	width: 100%;
	background-repeat: no-repeat;
	margin: 2em auto;
}
strong.hash{
	color: #83e60f;
	display: block;
	font-weight: 800;
	font-size:1.2em;
}
ul.listtwo{
	display: flex;
	justify-content: space-between;
	align-items: center;
	/* border-top:1px solid #ffffff;*/
	padding-top: 1em;
	padding-bottom: 1em;
}
ul.listtwo:last-child{
	/*border-bottom:1px solid #ffffff;*/
}
ul.listtwo li:first-child{
	width: 20%;
}
ul.listtwo li:last-child{
	width: 78%;
}
.notes{
	width: 100%;
	height: 15rem;
	background: #ffffff;
	padding: 1rem;
	box-sizing: border-box;
	color: #3E3E3E;
	font-size:0.7rem;
	overflow-y: scroll;
	border-radius: 5px;
	margin-top: 0.5rem;
}
.notes h4{
	color: #3E3E3E;
}
.notes ul{margin-bottom: 1rem;}
.notes ul li{position: relative;padding-left: 10px;}
.notes ul li:before{
	content: "";
    width: 5px;
    height: 5px;
    display: block;
    position: absolute;
    top: 0.7em;
    background: #2797ff;
    left: 0;
    border-radius: 30px;
}
.step{
	position: relative;
}
a.ankerlink{
	display: block;
    background: #83e60f;
    padding: 0.3rem 0.8rem 0.35rem;
    box-sizing: border-box;
    border-radius: 10px;
    font-size: 0.9rem;
    width: 9rem;
    text-align: left;
    font-weight: 800;
    margin-top: 0.3rem;
    position: relative;
    padding-right: 1.6rem;
    transition: 0.5s;
	color: #210e4d;
	line-height: 1;
	transition: 0.5s;
}
a.ankerlink:after{
	content: "";
    display: block;
    width: 1em;
    height: 1em;
    background-repeat: no-repeat;
    background: url(../images/shitaarrow.svg);
    position: absolute;
    right: 0.5rem;
    top: 0.6rem;
    background-repeat: no-repeat;
	transition: 0.5s;
}
a.ankerlink:hover{
	background: #CDFF93;
}
a.ankerlink:hover:after{
	 top: 0.7rem;
}
.followbtn{
	position: absolute;
    top: 65%;
    width: 70%;
    left: 0;
    right: 0;
    margin: auto;
    transition: 0.5s;
}
.followbtn:hover{
	opacity: 0.5;
}
.hosoku{
	background: #FFFFFF;
    padding: 20px;
    border-radius: 30px;
    width: 80%;
    margin-left: 20%;
    margin-top: -30px;
    position: relative;
    color: #071269;
    box-sizing: border-box;
    font-size: 0.7rem;
	margin-bottom: 4rem;
}
@media screen and (min-width: 800px){
	.hosoku{
		font-size:18px;
	}
	
}

hr.aiueo{
	background: #DC2E31;
	height: 14px;
	width: 100%;
	max-width: 800px;
	position: relative;
	z-index: 15;
	border: none;
	margin: 0 auto;
	padding: 0;
	margin-top: -7px;
	background: url("../images/pink-line.png");
	background-repeat: repeat-x;
	background-size: cover;
}
hr.kakikukeko{
	background: #DC2E31;
	height: 14px;
	width: 100%;
	max-width: 800px;
	position: relative;
	z-index: 15;
	border: none;
	margin: 0 auto;
	padding: 0;
	margin-top: -7px;
	background: url("../images/blue-line.png");
	background-repeat: repeat-x;
	background-size: cover;
}
hr.aiueo + hr.kakikukeko{
	margin-top: 7px;
}
.pinkline{
	width: 100%;
	height: 14px;
	display: block;
}
.header_right{
	position: absolute;
    right: 20px;
    top: 20px;
	width: 30px;
}

.navibtn{
	display: block;
	width:35px;
}


.bgfiximg{
position: fixed;
    top: 0;
    width: 130%;
    overflow: hidden;
    max-width: 800px;
    margin: auto;
    display: block;
    left: 0;
    right: 0;
	z-index: 1;
}

.sidebtn{
position: fixed;
right: 0;
top:24vh;
	z-index: 100;
	display: none;
}
.sidebtn1{
	display: block;
	width: 60px;
	margin-bottom: 25px;
	transition: 0.3s;
   /* box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.0);
    animation:flash 0.5s linear infinite alternate;
	border-top: 2px solid #ffffff;
	border-left: 2px solid #ffffff;
	border-bottom: 2px solid #ffffff;*/
}
.sidebtn2{
	display: block;
		width: 60px;
	/*transition: 0.3s;
  border-top: 2px solid #ffffff;
	border-left: 2px solid #ffffff;
	border-bottom: 2px solid #ffffff;
    box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.0);
    animation:flash 0.5s linear infinite alternate;*/
}
.sidebtn1:hover,
.sidebtn2:hover{
    /*box-shadow: 0px 0px 7px 7px rgba(255,255,255,0.8) !important;*/
	opacity: 0.8;
}

@keyframes flash{
    0% {
    box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.0);}
    100% {
    box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.6);}
}
h5{
	font-size: 2.0rem;
	margin-bottom: 10px;
	margin-bottom: 0.5em;
	font-weight: 900;
	line-height: 1.3;
}
strong{
font-weight: 700;}



	

.modl1{font-size:1.8rem;margin-bottom: 5px;margin-top: 10px;color: #ffffff;font-weight: 700;text-align: center;}
.modl2{font-size:1.2rem;margin-bottom: 15px;color: #ffffff; text-align: center;}
.modl3{background: #ffffff;
    color: #020000;
    font-weight: 600;
    text-align: center;
    display: block;
    padding: 10px 20px;
    margin: auto;
    width: 240px;
    font-size: 1.4rem;
    border-radius: 20px;
}

.modalouter {
	position: fixed;
	width: 100%;
	z-index: 100001;
	display: none;
	left: 0;
	bottom: 0;
	margin: auto;
	top: 0;
	bottom: 0;
	box-sizing: border-box;
	align-items: center;
	height: 100vh;
	padding: 30px;
	background-color: rgba(0,0,0,0.40);
	flex-direction: column;
	justify-content: center;
	padding-top: 60px;
}
.modalbox {
	display: none;
	max-width: 600px;
	width: 100%;
	background-color:#ff2f9d;
	border-radius: 15px;
	max-height: calc(100vh - 80px);
	box-sizing: border-box;
	flex-direction: column;
	overflow: hidden;
}
.modalinner{
	overflow: auto;
	width: 100%;
}
.modaititle{
	line-height: 1;
    text-align: center;
    background-color: #ffffff;
    color: #ff2f9d;
    font-size: 28px;
    font-weight: 800;
    position: relative;
    font-family: "noto sans jp";
    padding: 16px;
}
.modal_close{
	position: absolute;
	height: calc(100% - 20px);
	width: auto;
	display: block;
	position: absolute;
	right: 10px;
	top: 0;
	bottom: 0;
	margin: auto;
}
.modal_close img{
	width: auto;
	height: 100%;
}
.modalcontent{
	padding: 20px;
}


a.link{
	color: #ff2f9d;
}
p.kome{
	font-size:1.3rem;
}