body{
	margin: 0px;
	padding:0px;
	background-color: #FCFDFF;
	} 

img{
	border-style: none;
	}

/***パララックス***/
div.parallax {
  position: relative;
  height: 100%;
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 100%;
  background-attachment: fixed; }

@media (max-width: 768px) {
  div.parallax {
    position: inherit;
    height: auto;
    background-position: right bottom;
    background-size: 70%;
    background-attachment: inherit;
    background-repeat: no-repeat; } }


#head{
	position:relative;
	background-color: #A1D8E6;
	width: 100%;
	padding-top: 40px;
	text-align:center;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	}


#in-head{
	width: 100%;
	padding-bottom: 20px;
	background-color: #FCFDFF;
	margin: 0 auto;
	vertical-align:top;
	display:table;
	}

#top-logo{
	width: 100%;
	background-color: #FCFDFF;
	padding: 40px 0 20px 0;
	text-align:center;
	}

#button{
	text-align:center;
	display:table-cell;
	margin: 0 auto;
	vertical-align:top;
	}

.in-button{
	text-align: center;
	padding-right: 40px;
	display:inline-block;
	margin: 0 auto;
	vertical-align:top;
	}

#button li{
	float:left;
	text-decoration: none;
	list-style:none;
}


@media (max-width:768px) {
	


#in-head{
	width: 100%;
	padding-bottom: 20px;
	background-color: #FCFDFF;
	margin: 0 auto;
	vertical-align:none;
	display:block;
	}

#top-logo{
	width: 100%;
	background-color: #FCFDFF;
	padding: 40px 0 40px 0;
	text-align:center;
	}
	
#top-logo img{
	width: 75%;
	height: auto;
	}

#button{
	text-align:center;
	display:block;
	vertical-align:none;
	}

.in-button{
	display:block;
	vertical-align:none;
	}

#button li{
	float:none;
	text-decoration: none;
	list-style:none;
}

}

/* パソコンで見たときは"pc"のclassがついた画像が表示される */
.pc { display: block !important; }
.sp { display: none !important; }
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media only screen and (max-width: 768px) {
.pc { display: none !important; }
.sp { display: block !important;
	padding: 0;
	margin: 0;
	}
}


/****メニュー全体****/
.icon {
  background: #fff;
  border: 1px solid #DDF1FA;
  cursor: pointer;
  height: 50px;
  position: relative;
  width: 50px;
  display: none;
  margin-bottom: 0.4em;
}

.icon span {
  background: #DDF1FA;
  display: block;
  height: 16%;
  left: 50%;
  margin: -8% 0 0 -42%;
  position: absolute;
  top: 50%;
  width: 84%;
}

.icon span::before,
.icon span::after {
  background: #DDF1FA;
  content: "";
  display: block;
  height: 100%;
  left: 50%;
  margin: -8% 0 0 -50%;
  position: absolute;
  top: 50%;
  width: 100%;
}

.icon span::before {
  margin-top: -38%;
}

.icon span::after {
  margin-top: 19%;
}

@media screen and (max-width: 768px) {
  .icon {
    display: inline-block;
  }
}


.menu-container {
  margin: 0;
}

.menu-container .menu {
  border: 1px solid #ccc;
  display: flex;
  justify-content: space-between;
  list-style: none;
  margin: 0;
  padding: 0;
}

.menu-container .menu .menu-item {
  flex: 1;
}

.menu-container .menu .menu-item a {
  background: #fff;
  border-right: 1px solid #ccc;
  color: #333;
  display: block;
  padding: 0.6em 0.4em;
  text-align: center;
  text-decoration: none;
}

.menu-container .menu .menu-item a:hover {
  background: #ccc;
  color: #ffffff;
}

.menu-container .menu .menu-item:last-child a {
  border-right: none;
}

#modal-overlay {
  background-color: rgba(0, 0, 0, 0.6);
  display: none;
  height: 120%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .menu-container .menu {
    -webkit-transform: translate(-50%, -50%);
    background: #fff;
    display: none;
    height: auto;
    left: 50%;
    position: fixed;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    z-index: 100;
  }
  .menu-container .menu .menu-item a {
    border-bottom: 1px solid #ccc;
    border-right: none;
  }
  .menu-container .menu .menu-item:last-child a {
    border-bottom: none;
  }
}

#main{
	width: 100%;
	}

	
#top-pic{
	width: 100%;
	margin-bottom: 40px;
	text-align:center;
	}


#top-pic img{
	width: 100%;
	line-height: 0;
	vertical-align: bottom;
	margin: 0 auto;
}

@media (max-width:768px) {
	
#top-pic{
	width: 100%;
	text-align:center;
	}


#top-pic img{
	width: 100%;
	height: auto;
	margin: 0 auto;
}
	

.welcome{
	text-align: center;
	line-height: 1.6em;
}
	
}


#foot{
	background-color:#171C61;
	width: 100%;
	height:100px;
	text-align:center;
	padding-top:10px;
	font-family: 'Open Sans', sans-serif;
	}


#in-foot{
	width: 100%;
	margin: 0 auto;
	text-align:center;
	color: #FFFFFF;
	font-size: small;
	}

#contents{
	background-color: #FCFDFF;
	background-attachment: fixed;
	width: 100%;
	margin: 0 auto;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	}

#contents-pr{
	background-color: #FCFDFF;
	background-attachment: fixed;
	width: 100%;
	margin: 0 auto;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	}

#contents-tp{
	background-color: #FCFDFF;
	background-attachment: fixed;
	width: 100%;
	margin: 0 auto;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	}

#in-contents{
	width:980px;
	min-height: 300px;
	padding:20px 0 100px 0; 
	margin: 0 auto;
	}


.title{
	position:relative;
	width: 100%;
	background-attachment: fixed;
	text-align:center;
	padding: 0 0 20px 0;
	margin: 0 0 60px 0;
	border-bottom:#333333 1px dashed;
	}


.ct-title{
	text-align: left;
	font-size: x-large;
	 background-color: #FFFFFF;
	padding: 0 0 10px 0;
	margin: 0 0 10px 0;
	border-bottom:#333333 1px dashed;
	}


.newsarea {
	 width:620px;
	 margin: 0 20px 0 0;
	 display:table-cell;
	overflow: hidden;
     }

.newsarea a{
	text-decoration: none;
	color: inherit;	
     }


.newsarea a:hover{
	 color: #0099ff;
     }


.newsli{
	 width:100%;
	 padding: 0 0 10px 0px;
	 margin: 0 0 10px 0;
	 border-bottom:#333333 1px dashed;
	 box-sizing: border-box;
     }


.newsarea li{
	 width:100%;
	 padding: 20px 20px;
	 margin: 0 0 0 0;
	 background-color: #EEEEEE;
	box-sizing: border-box;
	 list-style: none;
     }

.daydate{
	font-weight: bold;
	margin: 0 0 10px 0;
}

.newsdate{
	font-size: medium;
	margin: 0 auto;
}

.twitterarea {
	 width:340px;
	padding-left: 20px;
	 margin: 0 auto;
	 display:table-cell;
     }

.Profile {
	 width:100%;
	display: table;
	line-height: 0;
     }


.imgarea {
	 width:480px;
	background-color: #FFF;
	padding: 0 10px 0 0;
	 margin: 0 20px 0 0;
	display: table-cell;
	vertical-align: middle;
     }

.imgarea img{
	 margin: 0 auto;
	line-height: 0;
	border: none;
     }

.prarea {
	 width:480px;
	background-color: #DDF1FA;
    padding: 40px 20px 20px 20px; 
	display: table-cell;
	vertical-align: top;
     }

.prareatx {
	 width:100%;
	 background-color: #DDF1FA;
	vertical-align: top;
     }

.prarea img{
	line-height: 0;
	 margin: 0 auto;
	border: none;
     }

.prdate{
	margin-bottom: 20px;
}

.prarea li{
	 font-size: 15px;
	line-height: 1.6em;
	 list-style: none;
     }


.prarea li p{
	 font-weight: bold;
	display: inline;
     }


.prname{
	 text-align: center;
	margin: 0 0 30px 0;
	 }

.primg{
	text-align: left;
	margin: 10px 0 10px 10px;
	 }

.prtxt{ 
	text-align: justify;
	text-justify: inter-ideograph;
	line-height: 1.6em;
	font-size: 15px;
	margin: 0 0 20px 0;
	 }

.imgarea img{
	 margin: 0 auto;
	border: none;
     }


.works {
	 width:100%;
	text-align: center;
	line-height: 0;
     }

.wkarea {
	 width:800px;
	min-height: 800px;
	text-align: left;
	 background-color: #DDF1FA;
    padding: 40px;
	box-sizing: border-box;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }

.wkarea p{
	 font-weight: bold;
     }

.wkarea a{
	 text-decoration: none;
     }

.wkarea li{
	 font-size: small;
     }


.news {
	 width:100%;
	text-align: center;
	line-height: 0;
     }

.nwarea {
	 width:800px;
	text-align: left;
	 background-color: #DDF1FA;
    padding: 40px;
	box-sizing: border-box;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }

.nwarea2 {
	 width:800px;
	text-align: left;
	min-height: 600px;
	 background-color: #DDF1FA;
    padding: 40px;
	box-sizing: border-box;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }

.nwtxt{ 
	line-height: 1.6em;
	font-size: 15px;
	padding: 10px;
	text-align: justify;
	text-justify: inter-ideograph;
	 }

.nwarea p{
	 font-weight: bold;
     }

.rd{color: #FF0000;
	 font-weight: bold;
     }

.nwarea2 p{
	 font-weight: bold;
     }

.nwarea li{
	 font-size: 15px;
	line-height: 1.6em;
	 list-style: none;
	width:100%;
	 padding: 0 0 30px 0px;
	 margin: 0 0 30px 0;
	 border-bottom:#333333 1px dashed;
	 box-sizing: border-box;
     }

.nwarea a{
	text-decoration: none;
	color: inherit;	
     }


.nwarea a:hover{
	 color: #0099ff;
     }

.vsample {
	 width:100%;
	 display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
     }

.vsarea {
	 width:480px;
	text-align: left;
	 background-color:#DDF1FA;
	padding: 0 20px;
	margin-bottom: 20px;
	box-sizing: border-box;
	vertical-align: top;
     }

.vsarea2 {
	 width:480px;
	text-align: left;
	 background-color:#DDF1FA;
	padding: 0 20px;
	margin-bottom: 20px;
	box-sizing: border-box;
	vertical-align: top;
     }

.vsarea audio{
	margin-bottom: 10px;
     }

.vsarea2 audio{
	margin-bottom: 10px;
     }

.vstxt{ 
	line-height: 1.6em;
	font-size: 14px;
	margin: 0 0 20px 0;
	text-align: justify;
	text-justify: inter-ideograph;
	 }

.vstxt2{ 
	line-height: 1.6em;
	font-size: small;
	margin: 0 0 10px 0;
	text-align: justify;
	text-justify: inter-ideograph;
	 }

.vsarea h3 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
  margin-bottom: 20px;
}

.vsarea2 h3 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
  margin-bottom: 10px;
}

.odtxt{ 
	line-height: 1.6em;
	margin: 0 0 20px 0;
	 }

.odtxt p{ 
	font-weight: bold;
	display: inline;
	 }


.wkarea h3 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
}

.nwarea h2 {
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  margin: 0 0 20px 0;
}

.nwarea h3 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
  margin-bottom: 10px;
}

.nwarea h4 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
  margin-bottom: 10px;
}

.nwarea h5 {
     position: relative;
	color: #333333;/*文字色*/
	font-size: large;
	margin: 0 0 10px 0;
	padding-left: 13px;
}
h5::before {
     position: absolute;
     content: '';
     width: 0;
     height: 0;
     border: solid 6px transparent;
     border-left: solid 8px #333333;
     top: 50%;
     left: 0;
     margin-top: -5px;
}

.nwarea h6 {
     position: relative;
     padding-left: 1.5em;
	font-size: 15px;
	font-weight: bold;
	margin: 0 auto;
}
 
h6::after {
     position: absolute;
     top: 50%;
     left:0;
     transform:translateY(-50%);
     content: '';
     width: 10px;
     height:10px;
     border: solid 4px #4863AD;
     border-radius:100%;
}

.nwarea2 h3 {
  padding: 0.25em 0.5em;/*上下 左右の余白*/
  color: #333333;/*文字色*/
  background: transparent;/*背景透明に*/
  border-left: solid 5px #4863AD;/*左線*/
  margin-bottom: 10px;
}


.order {
	 width:100%;
	min-height: 800px;
	text-align: center;
	line-height: 0;
	margin-bottom: 60px;
     }

.formbutton1{
	text-align:left;
	margin:0;
	padding: 0;
	}

input#submit_button {
    padding: 15px 40px;
    font-size: 1.6em;
}


input.name{
width:200px;
height:20px;
}

input.mail{
width:300px;
height:20px;
}


.welcome{
	text-align: center;
}


.modal { 
    position:fixed; 
    display:none; 
    z-index:9999; 
    top:40%; 
    left:50%; 
    width:400px; 
    height:200px; 
    margin:-120px 0 0 -220px; 
    padding:20px; 
    text-align:center;
    background: #fff;
 }

/*ここから下は装飾用のCSSです*/

.modal div{ 
    display:flex;
    justify-content: center;
    align-items: center;
    height:100%;
    width:100%;
}
.modal a { cursor:pointer;
			text-decoration: none;}
.md_txt dt {margin-bottom:20px; }
.md_txt dd {width:100%; margin: 0 auto;}
.nobt{
    border:1px solid #eee;
	border-radius: 10px;
    padding:10px;
}
.yesbt{
    border:1px solid #eee;
	border-radius: 10px;
    padding:10px;
}


@media (max-width:768px) {
	
#in-contents{
	width:100%;
	padding:20px 0 100px 0; 
	margin: 0 auto;
	}
	
.title img{
	width: auto;
	height: 70px;
	border: none;
	line-height: 0;
	}


.ct-title{
	text-align: left;
	font-size: x-large;
	 background-color: #FFFFFF;
	padding: 0 0 10px 0;
	margin: 0 0 10px 0;
	border-bottom:#333333 1px dashed;
	}

	
.welcome{
	text-align: center;
	line-height: 1.6em;
}
	

.newsarea {
	 width:100%;
	padding: 0 20px;
	 margin: 0 0 50px 0;
	box-sizing: border-box;
	 display:block;
     }

.newsli{
	 width:100%;
	 padding: 0 0 10px 0px;
	 margin: 0 0 10px 0;
	 border-bottom:#333333 1px dashed;
	 box-sizing: border-box;
     }


.newsarea li{
	 width:100%;
	 padding: 20px 20px;
	 margin: 0 0 0 0;
	 background-color: #EEEEEE;
	box-sizing: border-box;
	 list-style: none;
     }

.daydate{
	font-weight: bold;
	margin: 0 0 10px 0;
}

.newsdate{
	font-size: medium;
	margin: 0 auto;
}

.twitterarea {
	 width:100%;
	padding: 0 20px;
	 margin: 0 auto;
	box-sizing: border-box;
	 display:block;
     }	

	
.imgarea {
	 width:100%;
	background-color: transparent;
	padding: 20px 10px 20px 10px;
	 margin: 0 auto;
	box-sizing: border-box;
	 display:block;
     }

.imgarea img{
	width: 100%;
	height: auto;
	 margin: 0 auto;
	border: none;
     }

.prarea {
	 width:100%;
	padding: 0 10px 0 10px;
	background-color: transparent;
	box-sizing: border-box;
	 display:block;
	 vertical-align: top;
     }

.prareatx {
	 width:100%;
	padding: 40px 20px 40px 20px;
	 background-color: #DDF1FA;
	box-sizing: border-box;
	vertical-align: top;
     }
	
.works {
	 width:100%;
	padding: 0 10px;
	text-align: center;
	box-sizing: border-box;
	line-height: 0;
     }

	
.order {
	 width:100%;
	padding: 0 10px;
	text-align: center;
	box-sizing: border-box;
	line-height: 0;
     }
	
.wkarea {
	 width:100%;
	text-align: left;
	 background-color: #DDF1FA;
    padding: 20px;
	box-sizing: border-box;
	display: block;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }
	
.nwarea {
	 width:100%;
	text-align: left;
	 background-color: #DDF1FA;
    padding: 20px;
	box-sizing: border-box;
	display: block;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }
	
.nwarea2 {
	 width:100%;
	text-align: left;
	min-height: none;
	 background-color: #DDF1FA;
    padding: 20px;
	box-sizing: border-box;
	display: block;
	margin: 0 auto;
	line-height: 1.6em;
	vertical-align: top;
     }
	
	
.news {
	 width:100%;
	padding: 0 10px;
	text-align: center;
	box-sizing: border-box;
	line-height: 0;
     }
	
	
.vsample {
	 width:100%;
	 display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	flex-wrap: wrap;
	padding: 0 20px;
	box-sizing: border-box;
	justify-content: space-between;
     }
	
	
.vsarea {
	 width:100%;
	text-align: left;
	 background-color:#DDF1FA;
	padding: 0 20px;
	margin-bottom: 20px;
	display:  block;
	vertical-align: top;
     }
	
.vsarea audio{
	margin-bottom: 10px;
     }
	
	
}


#cont-title{
	text-align:center;
	padding: 0 0 20px 0;
	margin: 0 0 60px 0;
	border-bottom:#FFCC00 2px dashed;
	}

#in-ctbox{
	width:100%;
	display: flex;
  	display: -ms-flexbox;
	display: -webkit-box;
	-webkit-box-pack:justify;
	-webkit-justify-content: space-between;
    justify-content: space-between;
    -ms-flex-pack: space-between;
	list-style: none;
	}


.ctbox{
	width: 220px;
	padding: 0;
	background-color:#FFF;
	border:1px solid #FFCC00;
	border-radius:6px;
	-webkit-border-radius:6px;
	-moz-border-radius:6px;
	}

.ctbox img{
	width: 100%;
	padding: 0;
  	margin: 10px 0 5px 0;
	}

.ctbox a{
	color: #103593;
	text-decoration: none;
}
.ctbox a:hover {
	color: #5F3894;
	text-decoration: underline;
}

a:hover img{
opacity:0.8;
filter:alpha(opacity=80);
-ms-filter: “alpha( opacity=80 )”;
}


.ct-text{
	padding: 0 0 0 10px;
	margin: 10px 0 10px 0;
	height: 80px;
	font-size: small;
	text-align: left;
	color: #333333;
	}

.ct-release{
	padding: 0 10px 0 0;
	margin: 0 0 10px 0;
	font-size: x-small;
	text-align: right;
	color: #999999;
	}


.p-frame {
	display: inline-block;
	box-shadow: 0px 0px 20px -5px rgba(0, 0, 0, 0.4);
	margin-bottom:12px;
	}

.c-both {
	clear: both;
	padding: 0px;
	margin: 0px;
	}

.page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
	}

