@charset "utf-8";


body {
		padding: 0;
		margin: 0;
		height:auto;
		background-color:#FFF; /* フッターと色を合わせる */
}





@media screen and (max-width: 900px) {

body {
		overflow:auto !important; /* スクロールバー有効 */
}

		
}


div.pc_img { display: block;!important; margin:0;}
div.sp_img { display:none;}

@media screen and (max-width: 480px) {
	div.pc_img { display:none;}
	div.sp_img { display: block;!important; margin:0;}	
}

/*
strong {color:#222 !important; font-weight:bold; background: #fff001;background: linear-gradient(rgba(255,240,1,0) 10%, #fff001 0%);}
*/
.gray_shadow{
	
	/*text-shadow: 
    rgba(25,25,25,.1) 2px 0px 4px, rgba(25,25,25,.1) -2px 0px 4px,
    rgba(25,25,25,.1) 0px -2px 4px, rgba(25,25,25,.1) -2px 0px 4px,
    rgba(25,25,25,.2) 2px 1px 8px, rgba(25,25,25,.2) -2px 1px 8px,
    rgba(25,25,25,.2) 2px -1px 8px, rgba(25,25,25,.2) -2px -1px 8px,
    rgba(25,25,25,.2) 2px 2px 12px, rgba(25,25,25,.2) -2px 2px 12px,
    rgba(25,25,25,.2) 2px -2px 12px, rgba(25,25,25,.2) -2px -2px 12px;*
    
}

.white_shadow{
	
    /*text-shadow: 
    rgba(255,255,255,1) 2px 0px 0px, rgba(255,255,255,1) -2px 0px 0px,
    rgba(255,255,255,1) 0px -2px 0px, rgba(255,255,255,1) -2px 0px 0px,
    rgba(255,255,255,1) 2px 1px 0px, rgba(255,255,255,1) -2px 1px 0px,
    rgba(255,255,255,1) 2px -1px 0px, rgba(255,255,255,1) -2px -1px 0px,
    rgba(255,255,255,1) 2px 2px 0px, rgba(255,255,255,1) -2px 2px 0px,
    rgba(255,255,255,1) 2px -2px 0px, rgba(255,255,255,1) -2px -2px 0px;*/
    

}



#fullpage{margin:0 !important; padding:0 !important:}

.parallax,.parallax_map {
/*  border-width:0 0 1px 0 !important;
  border-style:solid !important;
  border-color:#CCC !important;*/

}

#section0::after{

     border-width:0 0 1px 0 !important;
     border-style:solid !important;
     border-color:#CCC !important;
}


 .section {
 text-align:center;
 z-index: 0;
 position:relative;
 font-size:0;
 min-width:1100px;

}


.section_footer{
 text-align:center;
 z-index: 0;
 position:relative;
 font-size:0;
 min-width:1100px;
}

.top_menu{

    margin:0;
    padding:0;
}

.side_menu{
 
   margin:0;
   padding-left:300px !important;
}

.side_footer{
   min-width:920px;
   text-align:center;
}





/* @media screen and (max-height: 700px) {

.section {
  border-width:0;
  border-style:solid;
  border-color:#BBB;
  height:auto !important;
  
}

.top_menu{

    min-width:100px;
    margin:0 !important;
    padding:0 ;
}

.side_menu{

   min-width:100px !important;
   margin:0 !important;
   padding:0 !important;
}

}
*/

/* 縦スライド設定 */




@media screen and (max-width: 900px){
	
.section {
  border-width:0;
  border-style:solid;
  border-color:#BBB;
  height:auto !important;
   min-width:100px;
 
}

.section_footer{
  border-width:0;
  border-style:solid;
  border-color:#BBB;
  height:auto !important;
  min-width:100px;
}

.top_menu{

    margin:0;
    padding:0 ;
}

.side_menu{

   margin:0;
      padding-left:0 !important;
}

.side_footer{

    min-width:100px;
    margin:0 !important;
    padding:0 ;
}


}



/* 横スライド設定 */

.slide:nth-child(1) {
  background:transparent url(./../img/bg/top_image1.jpg) no-repeat bottom center;
  background-color: #FFF;
  background-size:cover;
}

.slide:nth-child(2) {
  background:transparent url(./../img/bg/top_image2.jpg) no-repeat bottom center;
  background-color: #FFF;
  background-size:cover;
}


.canvas {
  width: 100%;
  padding-top:2%;
}

@media screen and (max-width: 480px) {

	.canvas {
 	 width: 100%;
	 padding-top:15%;
	}
}

.fullcanvas {
  width: 100%;
  height: 100%;
  letter-spacing: -.4em; /* 文字間を詰めて隙間をなくす */
}


#particles-js {
width:100%;
height:100vh;

background-color: rgba(20,153,204,.6);/*
background-size: cover;
background-position: 50% 50%;
background-repeat: no-repeat;*/
position:absolute;
top:0;
left:0;
right:0;
bottom:0;
display:block;
z-index:0;
}

.message{
	width: 100%;
  height: 100%;
position:relative;
 display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size:1.8rem;
  line-height:160%;
  text-align:center;
  
}


.message div{
	display: block;
	width:85%;
	z-index:10000;
	padding-top:0;
	font-weight:normal !important;
	color:#FFF;
	letter-spacing:normal;
	
}

.message div font{
	text-align:left !important;
	display:block;
}

.preview_mode{
	position:fixed; 
	display:inline-block; 
	width:auto; 
	height:auto; 
	background-color:rgba(50,50,50,.4); 
	z-index:9999999999;
	top: 50%;
	left: 50%;
    	transform: translate(-50%,-50%);
    	-webkit-transform: translate(-50%,-50%);
    	-ms-transform: translate(-50%,-50%);
	text-align:center;
	-webkit-border-radius:10px;
	-moz-border-radius:10px;
	border-radius:10px;
	padding:1em 2em;
}


.preview_mode div{
	font-size:1.8rem; color:#FFF; font-weight:bold;
}


@media screen and (max-width: 900px) {

	
	.message div{
	padding:20vh 0 10vh 0;
	
	}

}



@media screen and (max-width: 480px) {

	.message{
		width: 100%;
  		height: 100%;
		/*font-size:1.4rem;*/
  
	}
	.preview_mode{
		padding:1em 1em;
	}

	.preview_mode div{
		/*font-size:1.4rem;*/
	}

	
}





.message div img{
	width:40%;
	max-width:240px;
	margin:2% 10%;
}

.message div h1{
	font-size:1.8rem;
	line-height:140%;
	font-weight:900;
}



.text_glow{
	
/*テキストグロー（白）*/
-moz-text-shadow:  1px 1px 0px rgba(255,255,255,.8),
				  -1px 1px 0px rgba(255,255,255,.8),
				   1px -1px 0px rgba(255,255,255,.8),
				  -1px -1px 0px rgba(255,255,255,.8);
-webkit-text-shadow: 1px 1px 0px rgba(255,255,255,.8),
					-1px 1px 0px rgba(255,255,255,.8),
					 1px -1px 0px rgba(255,255,255,.8),
					-1px -1px 0px rgba(255,255,255,.8);
text-shadow: 1px 1px 0px rgba(255,255,255,.8),
			-1px 1px 0px rgba(255,255,255,.8),
    		 1px -1px 0px rgba(255,255,255,.8),
			-1px -1px 0px rgba(255,255,255,.8);
}

.text_glow_blur{
	
/*テキストグロー（白ぼかし）*/

-moz-text-shadow:1px 2px 5px rgba(255,255,255,.8), -1px 2px 5px rgba(255,255,255,.8),
    1px -2px 5px rgba(255,255,255,.8), -1px -2px 5px rgba(255,255,255,.8),
    2px 1px 5px rgba(255,255,255,.8), -2px 1px 5px rgba(255,255,255,.8),
    2px -1px 5px rgba(255,255,255,.8), -2px -1px 5px rgba(255,255,255,.8),
    1px 1px 10px rgba(255,255,255,.4), -1px 1px 10px rgba(255,255,255,.4),
    1px -1px 10px rgba(255,255,255,.4), -1px -1px 10px rgba(255,255,255,.4);
	
-webkit-text-shadow:1px 2px 5px rgba(255,255,255,.8), -1px 2px 5px rgba(255,255,255,.8),
    1px -2px 5px rgba(255,255,255,.8), -1px -2px 5px rgba(255,255,255,.8),
    2px 1px 5px rgba(255,255,255,.8), -2px 1px 5px rgba(255,255,255,.8),
    2px -1px 5px rgba(255,255,255,.8), -2px -1px 5px rgba(255,255,255,.8),
    1px 1px 10px rgba(255,255,255,.4), -1px 1px 10px rgba(255,255,255,.4),
    1px -1px 10px rgba(255,255,255,.4), -1px -1px 10px rgba(255,255,255,.4);
			
text-shadow:1px 2px 5px rgba(255,255,255,.8), -1px 2px 5px rgba(255,255,255,.8),
    1px -2px 5px rgba(255,255,255,.8), -1px -2px 5px rgba(255,255,255,.8),
    2px 1px 5px rgba(255,255,255,.8), -2px 1px 5px rgba(255,255,255,.8),
    2px -1px 5px rgba(255,255,255,.8), -2px -1px 5px rgba(255,255,255,.8),
    1px 1px 10px rgba(255,255,255,.4), -1px 1px 10px rgba(255,255,255,.4),
    1px -1px 10px rgba(255,255,255,.4), -1px -1px 10px rgba(255,255,255,.4);
}



.text_shadow{
	
/*テキストシャドウ（黒）*/
-moz-text-shadow: 1px 1px 2px rgba(0,0,0,.6);
-webkit-text-shadow: 1px 1px 2px rgba(0,0,0,.6);
text-shadow: 1px 1px 2px rgba(0,0,0,.6);
}


.box_shadow{
	
/*ボックスシャドウ*/
-webkit-box-shadow: 10px 10px 10px rgba(0,0,0,.3);
-moz-box-shadow: 10px 10px 10px rgba(0,0,0,.3);
box-shadow: 10px 10px 10px rgba(0,0,0,.3);
	
}


.img100{width:100%;}
.img90{width:90%; margin:5%;}





footer{width:100%;
padding:100px 0 80px 0;
/* margin-top:100px; */
}


.footer_waku{
	width: 56%;
	font-size: 0;
    	margin:0 22% 0 22%;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;
}
.footer_logo{
	background-color:#FFF;
	padding:20px 10px;
	margin-bottom:20px;
	text-align:center;
	width:auto;
	display:inline-block;
}

.footer_logo img{
	
	padding:0 ;
	width:100%;
	max-width:240px;
}


.footer_title{
	font-size: 21px !important;
	font-weight:bold;
	line-height:1.5;
	text-align:center;
}

.footer_waku div{
	font-size: 1.4rem;
	line-height:1.5;
	text-align:center;
	
}

.footer_table{
	margin:20px auto 50px auto;
	width:auto;
	
}

.footer_list{
	width:auto;
	text-align:center;
	list-style-type:none;
	padding:0;
	margin:0;
	display:flex;
	flex-wrap:wrap;
}

.footer_list li{width:auto; min-width:23%; text-align:left; padding:1% 1% 1% 0;}

@media screen and (max-width: 900px) {

	.footer_waku{
		width: 80%;
		font-size: 0;
    		margin:0 10% 0 10%;
		color:#FFF;
		letter-spacing:normal;
		text-align:center;	

	}
	.footer_waku div{
		/*font-size: 1.4rem;*/
		line-height:1.5;
		text-align:center !important;
	
	}
	.footer_list li{width:100% !important; text-align:center;}
}

.footer_waku a{text-decoration:none !important; color:#FFF !important;}
.footer_waku a:hover{text-decoration:none !important; color:#FFFF99 !important;}

.footer_head{
	width: 60%;
	font-size: 0;
    	padding:5px 20% 0px 20%;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;	
	margin:0;
	background-color:#555;	
	
}

.side_footer_head{
	width: calc(100% - 370px);
	font-size: 0;
    	padding:5px 20px 0px 350px;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;	
	margin:0;
	background-color:#555;	
	
}

.para_footer_head{
	position:absolute; bottom:0; right:0;
	width: 60%;
	font-size: 0;
    	padding:20px 20% 40px 20%;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;	
	margin:0;
	background-color:#555;

}

.footer_head a ,.side_footer_head a , .para_footer_head a{text-decoration:none !important; color:#FFF !important; font-size:1.4rem !important;}
.footer_head a:hover,.side_footer_head a:hover,.para_footer_head a:hover{text-decoration:none !important; color:#FFFF99 !important;}

.footer_head img,.side_footer_head img,.para_footer_head img{
	padding:10px 20px 20px 20px ;
	width:calc(100% - 40px);
	max-width:300px;
}

.footer_head div,.side_footer_head div,.para_footer_head div{
	font-size: 1.4rem;
	line-height:1.5;
	text-align:left;
	
}


footer hr{ width:100%; border-width:1px 0 0 0; border-color:#FFF; border-style:solid;}

.para_footer{height:100vh;}

.footer_box{
	
	margin:0;
	position: absolute;
	top:0;
	left:0;
  	width:auto;
	display:inline-block; 
	margin:0 0 1em 0;
	vertical-align:middle;
	position: relative;
	
}

.footer_box_logo{text-align:right !important;}
.footer_box_text{text-align:left !important;}
.footer_box_list{text-align:center !important;}

.footer_box_logo img{max-width:200px;}

@media screen and (max-width: 640px) {

	footer{
	    padding:80px 0 60px 0;
	    margin-top:0;
	}





	.footer_head,.side_footer_head{
	width: 90%;
	font-size: 0;
    	padding:5px 5% 70px 5%;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;	
	margin:0;
	
	}

	.para_footer_head{
	position:relative;
	width: 80%;
	font-size: 0;
    	padding:40px 10% 180px 10%;
	color:#FFF;
	letter-spacing:normal;
	text-align:center;	
	margin:0;
	}

	.footer_head div ,.side_footer_head div ,.para_footer_head div{
	/*font-size: 1.2rem;*/
	line-height:1.5;
	text-align:center;
	}

	.footer_head a ,.side_footer_head a , .para_footer_head a{/*font-size:1.2rem !important;*/}

	.footer_list{
	
	margin:0 10% 0 10%;
	}

	.footer_list li{width:100% !important; text-align:center;}


	.para_footer{height:auto;}
	

	.footer_box{
		width:100%;
		margin:0;
	}

	.footer_box_logo,.footer_box_text{text-align:center !important;}
}

#wrapper{visibility:hidden;} /* ローディング後visibleになる */

#loader-bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background:rgba(255,255,255,.2);
	z-index: 9999999991;
	overflow: hidden;
	

}
/*
#loader-bg::after {
	background-color:rgba(255,255,255,0);
	background:
	    url(../img/bg_white2.png);
    	overflow:hidden;
  	 content:"\A";
    	position: fixed;
    	z-index: -1;
    	top:0;
    	bottom:0;
    	width:100%;
	height: 100%;
}
*/
#loader-bg::after {
	backdrop-filter:blur(35px);
    	overflow:hidden;
  	 content:"\A";
    	position: fixed;
    	z-index: -1;
    	top:0;
    	bottom:0;
    	width:100%;
	height: 100%;
}

#loader-inner {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 200px;
	height: 200px;
	margin-top: -100px;
	margin-left: -100px;
	text-align: center;
	font-size:14px !important;
	/* color: #0099CC; */
	z-index: 9999999992;
}

#loader
{
    width: 80px; /*ローディングアイコンの横サイズ*/
    height: 80px; /*ローディングアイコンの縦サイズ*/
    border-radius: 50%;  /*CSS3で円を書く*/
    /* border: 10px solid #0099CC;*/  /*円に○の白枠をつける*/
    /* border-right-color: transparent; */ /*円の右にC状の空きをつける*/
	margin:0 50px;
}

#loader
{
    animation: spin 1s linear infinite; /*1秒毎にくるくる回転するアニメーション*/
}

@keyframes spin
{
    0% { transform: rotate(0deg);   opacity: 0.2; } /*0%の時は20％の透明度*/
    50%  { transform: rotate(180deg); opacity: 1.0; } /*50%の時は透明度なし*/
    100%   { transform: rotate(360deg); opacity: 0.2; } /*100%の時に20％の透明度に戻る*/
 
}

.campaign_box{
    position:relative;
    background:#FFFFFF;
    padding:10px;
	margin-bottom:20px;
    text-align:center;
    border:2px solid #CCC;
    color:#222;
    font-size:1.4rem !important;
    border-radius:10px;
    -webkit-border-radius:10px;
    -moz-border-radius:10px;
	display:inline-block;
}
.campaign_box:after,.campaign_box:before{
    border: solid transparent;
    content:'';
    height:0;
    width:0;
    pointer-events:none;
    position:absolute;
    top:100%;
    left:50%;
}
.campaign_box:after{
    border-color: rgba(255, 255, 255, 0);
    border-top-width:10px;
    border-bottom-width:10px;
    border-left-width:10px;
    border-right-width:10px;
    margin-left: -10px;
    border-top-color:#FFFFFF;
}
.campaign_box:before{
    border-color: rgba(0, 0, 0, 0);
    border-top-width:12px;
    border-bottom-width:12px;
    border-left-width:12px;
    border-right-width:12px;
    margin-left: -12px;
    margin-top: 2px;
    border-top-color:#CCC;
}

.campaign_box p {
  color:#FF3366;
  font-size:1.8rem !important;
  line-height:1.1 !important;
  font-weight:bold !important;
  margin: 0;
  padding: 0;
}

.campaign_price{
  display:block;
  font-size:1.4rem !important;
  margin: 0;
  padding: 0;
}

.campaign_price h1{
  display:inline-block;
  color:#FF3366;
  font-size:2.8rem !important;
  font-weight:bold !important;
  margin: 0;
  padding: 0;
}

.campaign_price div{
  display:inline-block;
  color:#222;
  font-size:1.6rem !important;
  font-weight:bold !important;
  margin: 5px 0;
  padding: .2em .7em;;
  background-color:#F8D949;
}

@media screen and (max-width: 640px) {
	
.campaign_box{
    /*font-size:1.2rem !important;*/
	padding:10px;
	margin-bottom:20px;
}
.campaign_box p {
  /*font-size:1.5rem !important;*/
}
.campaign_price{
  /*font-size:1.2rem !important;*/
}

.campaign_price h1{
  /*font-size:2.1rem !important;*/
}
	
}


.grecaptcha-badge {

	/* 前面に出すなら値を大きく */
	z-index: 10000 !important;

	/* 表示を消す */
	/* visibility: hidden !important;*/

	/* 正の値を大きくすると上に、負なら下に移動 */
	bottom: 60px !important;

}

		.modal{
			display: none;
			height: 100vh;
			position: fixed;
			top: 0;
			bottom:0;
			width: 100%;
			z-index:99999999 !important;
			
		}
		.modal__bg{
			background: rgba(0,0,0,.7);
			height: 100vh;
			position: absolute;
			width: 100%;
			
		}
		.modal__content{
			left: 50%;
			position: absolute;
			top: 50%;
			transform: translate(-50%,-50%);
		}
		
		.modal__content div{
			position:relative;
			width:auto;
			max-width:500px;
			}
		.modal__content div img{
			width:auto;
			max-width:500px;
			}
		
		
		.js-modal-close{ 
			position:absolute;
			top:0;
			right:0;
			width:20px;
			height:20px;
			cursor:pointer;
			background:transparent url(./../img/ads_close.png) no-repeat center center;z-index:99999999 !important;
		}
@media screen and (max-width: 580px) {
	
	.modal__content div{
			width:90vw;
			}
		.modal__content div img{
			width:100%;
			}
		

}