@charset "UTF-8";

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-size: 100%;
	font: inherit;
	vertical-align: middle;
}

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

body {
	margin: 0; 
	padding: 0; 
	color: #222; 
	font-size : 14px; 
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",Osaka, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; 
	background: ghostwhite;
	line-height: 1.2;
}

ol,ul {
	list-style: none;
}

blockquote,q {
	quotes: none;
}

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

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

h2 {
	font-size: 16px;
	font-weight: bold;
	color: lightseagreen;
	background: #e6f6f5;
	margin-top: 15px;
	margin-bottom: 0px;
	border-radius: 4px;
	padding: 5px 0;
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border: 2px solid lightseagreen;
}

h3 {
	font-size: 14px;
	font-weight: bold;
	color: navy;
	text-align: left;
	padding-left: 5px;
	border-left: 4px solid lightseagreen;
}

small {
	font-size: 0.8em;
}

a {
text-decoration: none;
}


.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}


/* @group Header */
#hgroup {
	width: 100%;
  	max-width: 960px;
 	margin: 0 auto;
	padding: 0;
	position: relative;
}

#hgroup h1 {
	display: block;
	float: left;
}

.logo {
	color: lightseagreen; 
	font-size: 10px;
	position: absolute; 
	top: 83px; 
	left: 100px;
	text-decoration: none;
}

#header-sub {
	float: right;
}

#header-sub strong {
	font-weight: bold;
	text-align: right;
	position: absolute;
	top: 15px; 
	right: 5px;
}

.kusaon-btn {
	color: #FFF;
	text-decoration: none;
	font-weight: bold;
	text-align: center;
	font-size: 13px;
	display: block;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0.00, #2dd9cf), color-stop(0.50, #0dc4ba), color-stop(0.50, #20b2aa), color-stop(1.00, #18857f));
	background: -webkit-linear-gradient(top, #2dd9cf 0%, #0dc4ba 50%, #20b2aa 50%, #18857f 100%);
	background: -moz-linear-gradient(top, #2dd9cf 0%, #0dc4ba 50%, #20b2aa 50%, #18857f 100%);
	background: -o-linear-gradient(top, #2dd9cf 0%, #0dc4ba 50%, #20b2aa 50%, #18857f 100%);
	background: -ms-linear-gradient(top, #2dd9cf 0%, #0dc4ba 50%, #20b2aa 50%, #18857f 100%);
	background: linear-gradient(to bottom, #2dd9cf 0%, #0dc4ba 50%, #20b2aa 50%, #18857f 100%);
	-moz-border-radius: 4px;
	-webkit-border-radius: 4px;
	border-radius: 4px;	
	border: 1px solid silver;
	-moz-box-shadow: 1px 1px 1px rgba(000,000,000,0.3),inset 0px 0px 3px rgba(255,255,255,0.5);
	-webkit-box-shadow: 1px 1px 1px rgba(000,000,000,0.3),inset 0px 0px 3px rgba(255,255,255,0.5);
	width: 200px;
	padding: 10px 0;
	-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
	opacity: 1;
	position: absolute;
	top: 55px; 
	right: 5px;

}

.kusaon-btn:hover {
	opacity: 0.8;
}

#header-480w {
	display: none;
}

/* @group Nav */

.animenu > ul:after {
	content: "";
	display: table;
	clear: both;
}

body {
	-webkit-animation: bugfix infinite 1s;
}

@-webkit-keyframes bugfix {
	from {
		padding: 0;
	}

	to {
		padding: 0;
	}
}

.animenu {
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
	padding: 0;
	clear: both;

}

.animenu * {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.animenu ul {
	margin: 0;
	padding: 0;
	list-style: none;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	-ms-border-radius: 3px;
	-o-border-radius: 3px;
	border-radius: 3px; /*メニューバーを丸くする*/ 
}

.animenu li {
	position: relative;
}

.animenu li:hover > ul {
	opacity: 1;
	visibility: visible;
	margin: 0;
}

.animenu li:hover > a {
	color: white;
}

.animenu input[type=checkbox] {
	position: absolute;
	top: -9999px;
	left: -9999px;
}

.animenu label {
	display: none;
	cursor: pointer;
	user-select: none;
}

.animenu > ul {
	border: 1px solid #040404;
	background-color: #111111;
	background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(255, 255, 255, 0.2)), color-stop(100%, rgba(255, 255, 255, 0)));
	background-image: -webkit-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
	background-image: -moz-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
	background-image: -o-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
	background-image: linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
	-webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
	-moz-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
	box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
}

.animenu > ul > li {
	float: left;
	border-right: 1px solid #1e1e1e;
	-webkit-box-shadow: 1px 0 0 #444;
	-moz-box-shadow: 1px 0 0 #444;
	box-shadow: 1px 0 0 #444;
}

.animenu > ul > li > a {
	float: left;
	padding: 1em 3em;
}

.animenu > ul a {
	color: #ccc;
	text-decoration: none;
	text-shadow: 0 1px 0 #111111; /* マウスオーバー文字カラー */
}

.animenu > ul ul {
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 1;
	opacity: 0;
	visibility: hidden;
	margin: 2em 0 0 0;
	background-color: #373737;
	background-image: none;
	-webkit-transition-property: margin, opacity;
	-moz-transition-property: margin, opacity;
	-o-transition-property: margin, opacity;
	transition-property: margin, opacity;
	-webkit-transition-duration: .15s;
	-moz-transition-duration: .15s;
	-o-transition-duration: .15s;
	transition-duration: .15s;
	-webkit-transition-timing-function: ease-in-out;
	-moz-transition-timing-function: ease-in-out;
	-o-transition-timing-function: ease-in-out;
	transition-timing-function: ease-in-out;
}

.animenu > ul ul li {
	display: block;
	-webkit-box-shadow: 0 1px 0 #1e1e1e, 0 2px 0 #515151;
	-moz-box-shadow: 0 1px 0 #1e1e1e, 0 2px 0 #515151;
	box-shadow: 0 1px 0 #1e1e1e, 0 2px 0 #515151;
}

.animenu > ul ul li:first-child > a {
	-webkit-border-radius: 3px 3px 0 0;
	-moz-border-radius: 3px 3px 0 0;
	-ms-border-radius: 3px 3px 0 0;
	-o-border-radius: 3px 3px 0 0;
	border-radius: 3px 3px 0 0;
}

.animenu > ul ul li:first-child > a:after {
	content: '';
	position: absolute;
	left: 2em;
	top: -12px;
	border: 6px solid transparent;
	border-bottom-color: inherit;
}

.animenu > ul ul li:last-child {
	-webkit-box-shadow: none;
	-moz-box-shadow: none;
	box-shadow: none;
}

.animenu > ul ul li:last-child > a {
	-webkit-border-radius: 0 0 3px 3px;
	-moz-border-radius: 0 0 3px 3px;
	-ms-border-radius: 0 0 3px 3px;
	-o-border-radius: 0 0 3px 3px;
	border-radius: 0 0 3px 3px;
}

.animenu > ul ul a {
	padding: .8em 1.6em;
	width: 150px;
	display: block;
	border-color: #373737;
}

.animenu > ul ul a:hover {
	background-color: lightseagreen; /* マウスオーバー背景カラー */
	border-color: lightseagreen; /* 矢印 */
}

@media screen and (max-width: 640px) {
	#hgroup, #photozou {
		display: none;
	}
	
	#header-480w {
		margin: 0;
		padding: 0;
		display: block;
    	width: 100%;
	}
	
	.kusaon-btn {
		width:180px;	
	}
	
  .animenu > ul, .animenu > ul ul {
    	visibility: visible;
    	opacity: 1;
    	display: none;
	}

	.animenu input[type=checkbox]:checked ~ label,
	.animenu input[type=checkbox] ~ label:hover {
		color: white;
	}
  
	.animenu label {
		border: 1px solid #040404;
		background-color: #111111;
		background-image: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, rgba(255, 255, 255, 0.2)), color-stop(100%, rgba(255, 255, 255, 0)));
		background-image: -webkit-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
		background-image: -moz-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
		background-image: -o-linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
		background-image: linear-gradient(rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
		-webkit-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
		-moz-box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
		box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
		color: #999;
		text-shadow: 0 1px 0 #111111;
		-webkit-border-radius: 3px;
		-moz-border-radius: 3px;
		-ms-border-radius: 3px;
		-o-border-radius: 3px;
		border-radius: 3px;
		position: relative;
		display: block;
		padding: 1em 3em;
	}
	
	.animenu label:before {
		position: absolute;
		left: .5em;
		top: .2em;
		content: "\2261";
		font-size: 2em;
	}
	
	.animenu > ul {
		position: relative;
		border-color: #111;
		margin: .5em 0 !important;
		padding: .25em;
		-webkit-box-shadow: none;
		-moz-box-shadow: none;
		box-shadow: none;
		background-color: #111111;
		background-image: none;
	}
	
	.animenu > ul:after {
 		content: '';
		position: absolute;
		left: 2em;
		top: -12px;
		border: 6px solid transparent;
		border-bottom-color: inherit;
	}
	
	.animenu > ul li {
		display: block;
	}
	
	.animenu > ul > li {
		float: none;
		border: 1px solid #1e1e1e;
		-webkit-box-shadow: none;
		-moz-box-shadow: none;
		box-shadow: none;
		background-color: #111;
		background-image: none;
	}
	
	.animenu > ul > li > a {
		float: none;
		display: block;
		padding: 1em;
	}
	
	.animenu > ul ul {
		position: static;
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		-ms-border-radius: 0;
		-o-border-radius: 0;
		border-radius: 0;
		background-color: #2b2b2b;
		background-image: none;
		margin: 0;
		-webkit-transition-property: none;
		-moz-transition-property: none;
		-o-transition-property: none;
		transition-property: none;
	}
	
	.animenu > ul ul li:first-child > a {
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		-ms-border-radius: 0;
		-o-border-radius: 0;
		border-radius: 0;
	}
	
	.animenu > ul ul li:first-child > a:after {
		content: none;
	}
	
	.animenu > ul ul li:last-child > a {
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		-ms-border-radius: 0;
		-o-border-radius: 0;
		border-radius: 0;
	}
	
	.animenu > ul ul a {
		padding-left: 2em;
		display: block;
		width: auto;
	}
	
	.animenu input[type=checkbox]:checked ~ ul {
		display: block;
	}
	
	.animenu input[type=checkbox]:checked ~ ul ul {
		display: block;
	}
	
	.kusaon-btn {
		top: 6px;
		opacity: 1;
		padding: 6px 0;

	}
}

@media screen and (max-width: 768px) {
	#header-sub strong {
		font-size:12px;
	}
	
	.animenu > ul > li > a {
    	padding: 1em 1em;
	}
}

/* @end */

/* @group Contents */

#contents {
	width: 95%; /* スクロールバーが重ならない */
  	max-width: 960px;
	margin: 0 auto; /* 左右に余白が生まれる */
	text-align: center;
	overflow: hidden; /* floatしたpaddingやmarginを有効にする */
}

#contents img { 
	box-shadow : none
}

/* @end */

/* @group Footer */

footer {
	clear: both;
	width: 100%;
  	max-width: 960px;
	margin: 10px auto 0; 
	padding: 24px 0;
	color: #333;
	text-align: center;
	border-top-style: solid;
	border-top-color: #666;
	border-top-width: thin;
}

/* @end */

/* footer ad */
#ad2 {
	width: 100%;
  	max-width: 960px;
	margin: 0 auto; 
	text-align: center;
}

.ad2-box {
	display: inline-block;
	color: #F00;
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 24px;
}

.ad2-box p {
	margin-bottom: 5px;
}

/* スクロールするとページトップへ戻るボタンがフェードして表示 */
#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 90%;
	opacity: .3;
}

#page-top a {
	background: #666;
	text-decoration: none;
	color: #fff;
	width: 80px;
	padding: 20px 0;
	text-align: center;
	display: block;
	border-radius: 5px;
}

#page-top a:hover {
	text-decoration: none;
	background: #999;
}

/* @end */
