@charset "EUC-JP";


/******************************************************************************************************

 body/common
 
****************************************************************************************************/
body { position: relative; line-height: 160%;padding-bottom: 41px; }
@media screen and (max-width: 640px) {
	body { padding-bottom: 92px; }
}
a:link, a:visited { color: #333; }
a:hover, a:active { text-decoration: none; }

.caption { font-size: 10px; line-height: 150%; clear:both; }
.autowrap { display: inline-block; }

.img img { width: 100%; height: auto; }

.pt10 { padding-top: 10px; }
.pt20 { padding-top: 20px; }
.pt40 { padding-top: 40px; }

.pb10 { padding-bottom: 10px; }
.pb20 { padding-bottom: 20px; }


span.sub { vertical-align: sub; font-size:9px; padding-bottom:2px}


/*pageTop*/
.pageTop a {
	width: 100%;
	padding: 7px 0 8px;
	display: block;
	background: #7f7f7f;
	text-align: center;
}
.pageTop a:hover { background: #aaa;}


/**/
.sp { display: none; }

@media screen and (max-width: 640px) {
	.sp { display: block; }
	.pc { display: none; }
}


h1 { width: 100%; height: 31px; padding-top: 10px; text-align: center; background-color: #eaeaea; font-size: 10px; color: #555; position: absolute; bottom: 0px; right:0; line-height: 120%; }
@media screen and (max-width: 640px) {
h1 { bottom: 51px; }
}

.txt { font-family: "Noto SansJapanese Light", "Lucida Grande", "Lucida Sans Unicode","Noto SansJapanese",¡ÈÞâ¥´¥·¥Ã¥¯¡É, YuGothic, "¥Ò¥é¥®¥Î³Ñ¥´¥·¥Ã¥¯ ProN", Hiragino Kaku Gothic ProN , sans-serif; }


/*wrap
-------------------*/
#wrap { width: 100%; max-width:1120px; margin: auto; box-shadow: 0px 0px 8px -5px #000; }


/*header
-------------------*/
#header {
	width: 100%;
	background: #fff;
  height: 50px;
}
#headerInner {
	margin: 0 auto;
	position: fixed;
  top: 0;
  width: 100%;
  max-width: 1120px;
  overflow: hidden;
  background-color: #fff;
  z-index: 30;
}
#header .logo { float: left; margin-left: 15px; margin-top: 5px; }
#header ul { float: right; text-align: left; }
#header li { display: inline-block; margin-left: 10px; vertical-align: top; }
#header li.tel { margin-top: 14px; }
@-moz-document url-prefix() {
#header li.tel { margin-top: 13px; }
}
#header li.contact a { display: block; font-size: 17px; width: 210px; padding: 12px 0 16px; text-align: center; color: #fff; background-color: #4e9929; text-decoration: none; }
#header li.contact a:hover { background-color: #53ba21; }

@media screen and (max-width: 640px) {
  #header .logo { float: none; text-align: center; padding-bottom: 10px; }
  #header ul { float: none; width: 100%; border: 1px solid #ccc; border-width: 1px 0; background-color: #fff; }
  #header li { width: 50%; margin-left: 0; text-align: center; }
  #header li.contact a { width: 100%; }
  #headerInner { position: relative; }
  #header { height: inherit; }
  #header ul.fixed { position: fixed; z-index: 30; }
}
@media screen and (max-width: 430px) {
  #header li.contact a { font-size: 13px; }
  #header li.tel img { height: 15px; width: auto; }
  @-moz-document url-prefix() {
  #header li.tel { margin-top: 10px; }
  }
}

#thanks #header li.tel { margin-right: 10px; }
#thanks #thanksTxt { text-align: center; padding: 100px 0 120px; border-top: 1px solid #ccc; }
#thanks .mainCopy { font-size: 24px; margin-bottom: 40px; line-height: 1.8; }
#thanks .subCopy { font-size: 18px; margin-bottom: 40px; line-height: 1.8; }
#thanks .note { font-size: 14px; line-height: 1.8; margin-bottom: 40px; }
#thanks .btnTop { max-width: 270px; width: 94%; margin: auto; }
#thanks .btnTop a { display: block; text-align: center; background-color: #00a8df; color: #fff; text-decoration: none; font-size: 18px; padding: 10px 0; }
#thanks .btnTop a:hover { background-color: #37c6f5; }
@media screen and (max-width: 640px) {
  #thanks #header .js-floating { display: none; }
  #thanks #thanksTxt { padding: 50px 0 60px; }
}


/*main
-------------------*/
#main { width: 100%; padding-top: 120%; background:#b6ebff; overflow: hidden; position: relative; }
#main a img { transition: .4s; }
#main a:hover img { opacity: 0.8; }
#main .img_fit img { width: 100%; height: auto; }
.subcloud1,
.subcloud2,
.subcloud3,
.mainCopy01,
.mainCopy02,
.mainCopy03,
.question01,
.question02,
.question03,
.question04 { position: absolute; }

.main_base { }

.subcloud1,
.subcloud2,
.subcloud3 { max-width:273px; width: 24.375%; }
.subcloud1 { top: 15%; right: 10%; }
.subcloud2 { top: 25%; left: 3%; }
.subcloud3 { top: 40%; right: 19%; }


.mainCopy01,
.mainCopy02,
.mainCopy03 { text-align: center; width: 100%; }
.mainCopy01 { top:3%; left: 0; right: 0; width: 100%; max-width:940px; margin: 0 auto; }
.mainCopy01 img { width: 90%; height: auto; }
.mainCopy03 { bottom:22%; left: 8%; width: 84.375%; max-width: 945px; }


.question01 { left: 7%; top: 15%; width: 54.821%; max-width: 614px; }
.question02 { right: 4%; top: 26%; width: 54.821%; max-width: 614px; }
.question03 { left: 4%; top: 35%; width: 54.821%; max-width: 614px; }
.question04 { right: 7%; top: 46%; width: 54.821%; max-width: 614px; }

@media screen and (max-width: 480px) {
  #main { padding-top: 210%; }
  .question01 { top: 14%; width: 80%; max-width: 614px; }
  .question02 { top: 30%; width: 80%; max-width: 614px; }
  .question03 { top: 46%; width: 80%; max-width: 614px; }
  .question04 { top: 61%; width: 80%; max-width: 614px; }
  .mainCopy03 { bottom: 15%; }
}


/*apply
-------------------*/
.apply { text-align: center; padding: 30px 0; border: 1px solid #eaeaea; border-width: 1px 0; }
.apply img { max-width: 96%; height: auto; }
.apply a:hover { opacity: 0.7; }
@media screen and (max-width: 640px) {
  .apply { padding: 15px 0; }
}


/*section
-------------------*/
.section { text-align: center; }
h3 { margin-bottom: 60px; }
h3 img { max-width: 94%; height: auto; }
@media screen and (max-width: 640px) {
  h3 { margin-bottom: 30px; }
}

/*ex
-------------------*/
.ex {}
.exBox .txt { text-align: left; font-size: 14px; line-height: 1.8; margin-top: 10px; margin-bottom: 40px; }
.exBox .before { display: inline-block; max-width: 456px; width: 41%; vertical-align: top; margin: 1%; }
.exBox .before .txt { margin-left: 30px; }
.exBox .before img,
.exBox .arrow img,
.exBox .after img { width: 100%; height: auto; }
.exBox .arrow { display: inline-block; max-width: 37px; width: 4%; vertical-align: top; margin-top: 10%; }
.exBox .after { display: inline-block; max-width: 475px; width: 43%; vertical-align: top; margin: 1%; }
@media screen and (max-width: 640px) {
  .exBox { border-bottom: 1px solid #ccc; padding-bottom: 40px; margin-bottom: 30px; }
  .exBox.noborder { border-bottom: none; margin-bottom: 0; }
  .exBox .txt { margin-bottom: 20px; }
  .exBox .before { display: block; width: 94%; margin: auto; }
  .exBox .arrow { display: block; width: 94%; margin: auto; margin-top: 0px; margin-bottom: 20px; }
  .exBox .after { display: block; width: 94%; margin: auto; }
}
@media screen and (max-width: 480px) {
  .exBox.noborder { padding-bottom: 20px; }
}



/*block1
-------------------*/
#block1 { background: url(../img/bg_block1.png); padding-top: 60px; }
#block1 p img { max-width: 100%; height: auto; }
@media screen and (max-width: 640px) {
  #block1 { padding-top: 30px; }
}


/*block2
-------------------*/
#block2 { background-color: #fff7e4; padding-bottom: 60px; }
#block2 h3 { margin-bottom: 20px; }
#block2 li { display: inline-block; margin: 2%; max-width: 370px; width: 43%; }
#block2 li img { width: 100%; height: auto; }
@media screen and (max-width: 640px) {
}


/*block3
-------------------*/
#block3 { padding-top: 60px; }
.detail_area { background-color: #00a9b4; color: #fff; overflow: hidden; padding:30px 0 0; }
.detail_area .txt { float: left; margin-left: 50px; text-align: left; font-size: 18px; line-height: 1.8; width: 70%; }
.detail_area .txt .notice { color: #fcff00; }
.detail_area .pic { float: right; margin-right: 30px; max-width: 217px; width: 20%; }
.detail_area .pic img { margin-bottom: -5px; margin-top: 30px; width: 100%; height: auto; }
@media screen and (max-width: 800px) {
  .detail_area .txt { float: none; margin-left: auto; margin: auto; width: 90%; }
  .detail_area .pic { float: none; margin-right: auto; max-width: 217px; width: 100%; margin: 0 auto; }
}
@media screen and (max-width: 640px) {
  #block3 { padding-top: 30px; }
}


/*block4
-------------------*/
#block4 { background-color: #eefbff; padding: 60px 0; overflow: hidden; }
#block4 .left { float: left; text-align: left; margin-left: 4%; width: 48%; }
#block4 .left img { max-width: 100%; height: auto; }
#block4 h4 { margin-bottom: 30px; }
#block4 .txt { margin-bottom: 30px; font-size: 16px; line-height: 1.8; }
#block4 .right { float: right; max-width: 517px; width: 47%; margin-top: 5%; }
#block4 .right img { width: 100%; height: auto; }
@media screen and (max-width: 800px) {
  #block4 .left { float: none; text-align: left; margin-left: auto; width: 92%; margin: auto; }
  #block4 .right { float: none; max-width: 517px; width: 100%; margin-top: 5%; margin: 0 auto 20px; }
  #block4 .txt br { display: none; }
}


/*block5
-------------------*/
#block5 { background-color: #eefbff; padding-bottom: 50px; }
@media screen and (max-width: 480px) {
  #block5 { padding-bottom: 30px; }
}


/*block6
-------------------*/
#block6 { background: url(../img/bg_section.png); padding-top: 60px; }


/*media
-------------------*/
#media { background: url(../img/bg_section.png); padding-top: 60px; padding-bottom: 50px; }
#media h3 { margin-bottom: 50px; }
#media .news { margin: 0 auto 70px; max-width: 675px; width: 90%; }
#media .news img { width: 100%; height: auto; }
#media .newsbox { max-width: 1020px; width: 90%; margin: 0 auto 40px; box-shadow: 1px 1px 7px rgba(0,0,0,0.4); transition: .2s; }
#media .newsbox:hover { box-shadow: 0 0 0 rgba(0,0,0,0.4); }
#media .newsbox img { width: 100%; height: auto; }
#media .videobox { max-width: 1020px; width: 90%; margin: 0 auto 40px; box-shadow: 1px 1px 7px rgba(0,0,0,0.4); position: relative; }
#media .videobox img { width: 100%; height: auto; }
#media .videoArea { width: 63%; margin: auto; position: absolute; top: 7%; left: 3%; }
#media .video { position:relative; width:100%; padding-top:56.25%; }
#media .video iframe{ position:absolute; top:0; right:0; width:100%; height:100%; }
@media screen and (max-width: 640px) {
  #media .videoArea { width: 94%; top: 45%; left: 0; right: 0; margin: auto; }
}

/*block7
-------------------*/
#block7 { background: url(../img/bg_section.png); padding-top: 60px; padding-bottom: 30px; }
#block7 dl { max-width: 940px; width: 94%; margin: 0 auto 70px; text-align: left; font-size: 18px; line-height: 1.8; }
#block7 dt { background: url(../img/icon_q@2x.png) top left no-repeat; background-size: 44px 33px; padding: 6px 0 10px 60px; margin-bottom: 15px; }
#block7 dd { background: url(../img/icon_a@2x.png) top left no-repeat; background-size: 46px 37px; padding: 6px 0 10px 60px; }
#block7 .cam img { max-width: 90%; height: auto; }
@media screen and (max-width: 640px) {
  #block7 dl { font-size: 15px; }
}


/*-------------------------------------
contactTel
-------------------------------------*/
#contactTel { width: 90%; margin: 0 auto 50px; }
#contactTel .tel { width: 100%; padding-top: 10px; overflow: hidden; zoom:1; }
#contactTel .tel p { float: left; }
#contactTel .tel01 { width: 316px; padding-right: 10px; }
#contactTel .tel02 { color: #01a4da; font-size: 16px; }
#contactTel .tel02 small { font-size: 12px; }
#contactTel .des { width: 100%; padding:10px 20px; margin-top: 20px; margin-bottom: 20px; border: 1px solid #ccc; font-size: 16px; text-align: center; background: #f8f8f8; box-sizing: border-box; }
#contactTel .des p { margin: 5px; }
#contactTel .des .org { font-weight: bolder; color: #f9a022; margin-top: 15px; }
#contactTel .des .org img { vertical-align: middle; }
@media screen and (max-width: 640px) {
	#contactTel .tel { padding-bottom: 20px; text-align:  center; }
	#contactTel .tel p { width: 90%; margin: 0 auto; float: none; }
  #contactTel .tel01 { max-width: 316px; width: 100%; margin-bottom: 5px; padding-right: 0; }
	#contactTel .tel02 { width: 80%; }
  #contactTel .des { font-size: 13px; }
  #contactTel .des .org img { height: 25px; width: auto; }
}




/*-------------------------------------
requestForm
-------------------------------------*/

#requestForm { padding-top: 50px; text-align: left; }
#requestForm .contact_ttl { color: #fff; background-color: #00a4da; font-size: 13px; padding: 5px 0 5px 10px; margin-bottom: 15px; }
.othreContents .contact_ttl { width: 90%; margin: 0 auto; }
#requestForm .notice { width: 90%; margin: auto; }
#requestForm h4{
	width: 100%;
	padding: 5px;
	margin-bottom: 15px;
	color: #00a4da;
	font-size: 13px;
	font-weight: bolder;
	background: #e6f4f9;
	box-sizing: border-box;
}
#requestForm h4 span {
	color: #f9a022;
}

#requestForm h5 {
	width: 100%;
	margin:10px 0 5px;
	font-size: 11px;
	color: #888;
}

/*-------------------------------------
section
-------------------------------------*/
#requestForm .section {
	width: 90%;
	margin: 0 auto 30px;
	box-sizing: border-box;
  text-align: left;
}
#requestForm .section.submit { margin-bottom: 0; }


#requestForm .section ul {
	margin-bottom: 10px;
}
#requestForm .section li {
	margin-right: 15px;
	display: inline-block;  
	*display: inline; 
	*zoom: 1;
}
#requestForm .section .caption {
	margin-bottom: 10px;
}

#requestForm .section div {
	padding-right: 15px;
	float: left;
}
#requestForm .section div.sw {
	padding-top: 3em;
}

/*attention*/
#requestForm .section.attention {
	color: #f9a022;
}
#requestForm .section.attention a {
	color: #f9a022;
	text-decoration: underline;
}
#requestForm .section.attention a:hover {
	text-decoration:none;
}

/*submit*/
#requestForm .section.submit {
	width: 100%;
	padding: 25px 10px;
	text-align: center;
	background: url(../img/bg_submit.gif) #eee;
}


/*-------------------------------------
security
-------------------------------------*/

.security {
	width: 100%;
	padding: 20px 0;
	margin-bottom: 15px;
	border-bottom: 1px solid #ccc;
	border-top: 1px solid #ccc;
}
.securityInner {
	max-width: 980px;
  width: 94%;
	margin: 0 auto;
  overflow: hidden;
}
.securityInner .fleft { float: left; margin-right:60px; }
.securityInner .txt {
	padding: 15px 0 0 0;
  overflow: hidden;
}

textarea {
	width: 100%;
	padding: 5px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	border:1px solid #ccc;
	box-sizing: border-box;
}



input[type="text"] {
	padding: 5px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	border:1px solid #ccc;
	box-sizing: border-box;
}
input[type="checkbox"] {
	margin-right: 3px;
}
input[type="button"] {
	margin-top: 10px;
}





@media screen and (max-width: 640px) {
	.othreContents {
		width: 100%;
		padding: 0 10px 30px;
		box-sizing: border-box;
	}
	
	#requestForm .section div {
		padding-right: 0;
		float: none;
	}
	
	
	input[type="text"] {
		width: 100%;
	}
	
	#requestForm .section.mailaddress div {
		width: 47%;
		float: left;
	}
	#requestForm .section.mailaddress div.sw {
		width:5%;
		text-align: center;
	}
	
	.securityInner {
		width: 100%;
		box-sizing: border-box;
	}
  .securityInner .fleft { float: none; margin: 0 auto; margin-right: auto; text-align: center; }
}


/*footer
-------------------*/
#footer ul { text-align: center; }
#footer li { display: inline-block; margin: 15px; }
#footer .copyright { text-align: center; font-size: 10px; margin: 30px auto; }
.btn_plusidea { max-width: 1053px; width: 96%; margin: 50px auto 30px; }
.btn_plusidea img { width: 100%; height: auto; }
.btn_plusidea a:hover img { opacity: 0.8; }
@media screen and (max-width: 640px) {
  #footer li img { max-width: 100%; height: auto; }
  .securityInner .txt {
    padding: 15px 0 0 0px;
    overflow: hidden;
    width: 92%;
    margin: 0 auto;
  }
}




/******************************************************************************************************

 clear fix
 
***************************************************************************************************/
#header:after,
#breadcrumbs:after,
#container:after,
#contents:after,
.section:after,
#footer:after {
  display : block;
  clear : both;
  content : '';
}
#header,
#breadcrumbs,
#container,
#contents,
.section,
#footer { zoom : 1; }




/*Æ°¤­*/
/*mv*/
.item-mv { opacity: 0; transition: .8s; transform: translate(0, 100px); -webkit-transform: translate(0, 100px); }
.mv { opacity: 1.0; transform: translate(0, 0); -webkit-transform: translate(0, 0); }

.cloud2 {
  animation-name: cloud2;
  animation-duration: 2.5s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}
.cloud2:hover { animation-play-state: paused; }
@keyframes cloud2 {
	0% {transform:translate(0, -4%);}
	50% {transform:translate(0, 0%);}
	100% {transform:translate(0, -4%);}
}

.cloud3 {
  animation-name: cloud3;
  animation-duration: 2s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}
.cloud3:hover { animation-play-state: paused; }
@keyframes cloud3 {
	0% {transform:translate(0, -3%);}
	50% {transform:translate(0, 0%);}
	100% {transform:translate(0, -3%);}
}
