@charset "UTF-8";
/* Navigation */

/* gnav */
nav#gnav {
	display: none;
	position: absolute;
	right: 10px;
	bottom: 3px;
	width: 650px;
	text-align: right;
}
nav#gnav ul {
	position: absolute;
	right: 0;
	bottom: 0;
}
nav#gnav li { 
	clear: none;
	float: left;    
	padding: 0 0 0 1.3em;
	position: relative;
	
}
nav#gnav li:first-child {
	background: none
}
nav#gnav li a {
	display: block;
	font-size: 15px;
	color: #000;
	text-decoration: none;
	position: relative;
}
nav#gnav li a:after {
	content: '';
	border-bottom: 1px solid #000;
	width: 100%;
	position: absolute;
	left: 0;
	bottom: 0;
	opacity: 0;
	transition: all 0.3s ease;
}

nav#gnav li a:hover:after {
	opacity: 1;

}



/* モバイルナビゲーション */
#mnav {
	display: none;
	position: fixed;
	left: 0;
	height: 100%;
	top: 60px;
	background-color: rgba(39,170,234,0.9);
	width: 100%;
	z-index: 999999;
	
	transition: all 300ms 0s ease;

}
#mnav ul {
	height: 100%;
	padding: 30px 0px 90px;
 	overflow: auto;
 	-webkit-overflow-scrolling: touch;
}
#mnav li {
	text-align: center;
	margin-bottom: 10px;
	padding: 0 20px;
}
#mnav li a {
	color: #fff;
	font-size: 18px;
	text-decoration: none;
}

/* mnavのアイコンメニュー */
#mnav li.icn {
	clear: both;
	border-top: none;
	padding: 20px 0 0 0;

}
#mnav li.icn a {
	display: block;
	padding: 1.0em 0 1.0em 0;
	border: 1px solid #fff;
	text-align: center;
	margin-bottom: 20px;
	width: 280px;
	margin-left: auto;
	margin-right: auto;
}

#mnav li.icn a span {
	display: inline-block;
	background-repeat: no-repeat;
	background-position: 0 2px;
	background-size: 28px;
	padding-left: 34px;
}

#mnav li.icn a:nth-child(1) span {
	background-image: url(../img/nav/icn_mnav_1.png);
}
#mnav li.icn a:nth-child(2) span {
	background-image: url(../img/nav/icn_mnav_2.png);
}
#mnav li.icn a:nth-child(3) span {
	background-image: url(../img/nav/icn_mnav_3.png);
}


/* snav */
#snav {
	display: none;
	width: 100%;
	padding:0;
	text-align:left;
	background-color:#fff;
	border:0px solid;
}
#snav ul {
	/*max-width: 1020px;*/
	/*display: table;*/
}

#snav li {
	/*display: table-cell;*/
	clear: none;
	float: left;	
	border: 0px solid;
}
#snav li#snav_1 {
	width: 26.347%;
	
}
#snav li#snav_2 {
	width: 20.274%;
}
#snav li#snav_3 {
	width: 15.475%;
}
#snav li#snav_4 {
	width: 14.496%;
}
#snav li#snav_5 {
	width: 13.026%;
}
#snav li#snav_6 {
	width: 10.382%;
}

.snavfix {
	position: fixed;
	left: 0;
	top: 0;
	z-index: 9999;
}


/* bnav */
#bnav {
	padding-top: 30px;
	padding-bottom: 10px;
	background: -moz-linear-gradient(-45deg, rgba(254,252,230,1) 0%, rgba(254,240,214,1) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, rgba(254,252,230,1) 0%,rgba(254,240,214,1) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, rgba(254,252,230,1) 0%,rgba(254,240,214,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}
#bnav li {
	text-align: center;
	margin-bottom: 10px;
	border: 0px solid;	
}
#bnav li p {
	margin-top: 12px;
}
#bnav li .ph {
	overflow: auto;
}
#bnav li .ph a {
	display: block;
	max-width: 280px;
	max-height: 280px;
	overflow: hidden;
	border-radius:  100%;
	position: relative;
	margin-left: auto;
	margin-right: auto;
}
#bnav li .ph a:before {
	content: '';
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.2);
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	-webkit-opacity:0;
	opacity:0;
	transition: all 300ms 0s ease;
}
#bnav li .ph a:hover:before {
	-webkit-opacity:1;
	opacity:1;
}

#bnav li .ph a:after {
	content: '';
	width: 20px;
	height: 20px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	/*transform: rotate(45deg);*/
	position: absolute;
	top: 50%;
	left: 40%;
	-webkit-transform: rotate(45deg) translateY(-50%) translateX(-50%); /* Safari用 */
	transform: rotate(45deg) translateY(-50%)  translateX(-50%);
	-webkit-opacity:0;
	opacity:0;
	z-index: 3;
	transition: all 300ms 0s ease;	
}
#bnav li .ph a:hover:after {
	-webkit-opacity:1;
	opacity:1;
}
#bnav li .ph a img {
	-webkit-transition:  -webkit-transform 0.75s;
	transition: transform 0.75s;
}














@media handheld, print, screen and (min-width: 481px) {

#bnav {
	padding-top: 50px;
	padding-bottom: 20px;
}
#bnav li {
	margin-bottom: 20px;
}
#bnav li .ph a:after {
	width: 20px;
	height: 20px;
	top: 50%;
	left: 42%;
}

/* end of media query */
}


@media handheld, print, screen and (min-width: 801px) {

/* gnav */
nav#gnav {
	display: block;
}
/* snav */
#snav {
	display: block;
}

/* モバイルナビゲーション */
#mnav {
	display: none;
}


/* bnav */
#bnav {
	padding-top: 60px;
	padding-bottom: 30px;
}
#bnav li .ph a:after {
	width: 25px;
	height: 25px;
	top: 50%;
	left: 43%;
}

/* end of media query */	
}