@charset "UTF-8";
@import url(//fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/* ===================================================================
basic.css：共通指定
=================================================================== */

/* bodyの設定 */
body{
	overflow-y: scroll;
	position: relative;
	color: #000;
	font-size: 16px;
	font-family: 'Noto Sans Japanese','メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif;
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
	background: #333;
}
*{
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	     -o-box-sizing: border-box;
	    -ms-box-sizing: border-box;
	        box-sizing: border-box;
}
html,body{
	width: 100%;
}
#wrapper{
	width: 100%;
	margin:0 auto;
	overflow:hidden;
	background: #fff;	
}

.clr{clear: both;}
.clearfix {
	*zoom: 1;
}
.clearfix:before,
.clearfix:after {
	content: " ";
	display: table;
}
.clearfix:after {
	clear: both;
}

/* リンク */
a{
	outline: none;
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	background: transparent;
	color: #000;
	text-decoration: underline;
}
a:hover{text-decoration: none;}
a[name],a[name]:hover,a[name]:active{}
a[href] {outline: none;}
a:visited {color: #000;}
a:hover img{
	filter:alpha(opacity=75);
	-moz-opacity: 0.75;
	opacity: 0.75;
}


/*	header
------------------------------------------------------------*/
header{
/*	overflow: hidden;*/
	background: #fff;
}
#header{
	width: 100%;
	height: 85px;
	z-index: 9999;
	overflow: hidden;
}
#head_left{
	float: left;
	width: 65%;
	margin-left: 20px;
}
#head_right{
	float: right;
}
#header h1,
#header .logo{
	float: left;
	width: 200px;
	margin: 0;
}
#header h1 a,
#header .logo a{
	display: block;
	text-indent: -9999px;
	height: 85px;
	width: 200px;
	margin-left: 0px;
	background: url("/images/colorlogo_en.png") 0 center no-repeat;
	background-size: 199px;
}
.copy_txt{
	float: left;
	margin: 25px 0 0 10px;
	padding: 0 0 0 15px;
	border-left: 1px solid #666;
	line-height: 150%;
	font-size: 0.8em;
}

/* 多言語 */
ul#language{
	float: right;
	overflow: hidden;
	margin: 16px 30px 0 10px;
}
ul#language li{
	float: left;
	padding: 0;
	border-right: 1px solid #000;
	line-height: 1.2;
}
ul#language li:first-child{
	border-left: 1px solid #000;
}
ul#language li a{
	font-size: 0.875em;
	padding: 0 6px;
	text-decoration: none;
}
ul#language li a:hover{
	text-decoration: underline;
}
#kogeilogo{
	float: left;
	margin: 12px 0 -6px;
}

/* Google Search Box */
#googlesearch{
	clear: both;
	display:block;
	float: right;
	width: 274px;
	margin-top: 3px;
	margin-right: 14px;
}
#googlesearch .cse .gsc-control-cse, .gsc-control-cse{
	padding: 0 !important;
}
#googlesearch .gsc-input-box{
	border: 1px solid #ccc;
	border-right: none;
	height: 30px;
}
#googlesearch .gsc-input-box table{
	margin: 0;
	height: 30px;
}
table.gsc-search-box{
	margin-top: 0;
}
#googlesearch .cse table.gsc-search-box th,
#googlesearch table.gsc-search-box th,
#googlesearch .cse table.gsc-search-box td,
#googlesearch table.gsc-search-box td{
	padding: 0px;
	border:0;
}
#googlesearch input.gsc-input{
	border: 2px solid #999;
	width:150px;
	height:30px;
	font-size:12px;
	float:right;
	margin:0;
	padding: 3px 6px !important;
	background: none !important;
}
#googlesearch input.gsc-search-button{
	background: url(/images/ico_search.png) no-repeat 0 0;
	background-size: 40px auto;
	border: none;
	text-indent: -999px;
	height: 30px;
	width: 40px;
	margin: 0;
	border-radius: 0px;
	-moz-border-radius: 0px;
	-webkit-border-radius: 0px;
	cursor: pointer;
}
.gsc-branding{
	display: none;
}


/*	Gnav
------------------------------------------------------------*/
#gnav{
	background: #ededed;
}
.dropmenu{
	*zoom: 1;
	list-style-type: none;
	width: 1000px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
	letter-spacing: -0.4em;
}
.dropmenu:before, .dropmenu:after{
	content: "";
	display: table;
}
.dropmenu:after{
	clear: both;
}
.dropmenu li{
	position: relative;
	margin: 0;
	padding: 0;
	text-align: center;
	display: inline-block;
	letter-spacing: 0em;
}
.dropmenu li a{
	display: block;
	margin: 0;
	padding: 0 20px;
	line-height: 60px;
	color: #333;
	text-decoration: none;
	-webkit-transition: all 0.6s ease;
	-moz-transition: all 0.6s ease;
	-o-transition: all 0.6s ease;
}
.dropmenu li ul{
	list-style: none;
	position: absolute;
	top: 100%;
	left: 0;
	margin: 0;
	padding: 0;
	border-bottom: 1px solid #ccc;
}
.dropmenu li ul li{
	width: 350px;
	float: left;
}
.dropmenu li ul li a{
	padding: 8px 15px;
	line-height: 130%;
	border: 1px solid #ccc;
	border-bottom: none;
	background: #fff;
	text-align: left;
	font-size: 0.875em;
}
.dropmenu li:hover > a{
	background: #ee5aa7;
	color: #fff;
}
.dropmenu li ul li a:hover{
	background: #f9dce7;
	color: #000;
}
#fade-in { position: relative; z-index: 6; }
#fade-in li ul{
	opacity: 0;
	visibility: hidden;
	transition: .5s;
}
#fade-in li:hover ul{
	visibility: visible;
	opacity: 1;
}


/*	共通枠
------------------------------------------------------------*/
.container{
	margin: -1px auto 0;
	padding: 10px 0 50px;
	width: 100%;
	background-color:#fff;
}
.container p{
	font-size: 1.125em;
	line-height: 180%;
	margin-top: 15px;
	margin-bottom: 26px;
	letter-spacing: -0.03em;
}
.wrapper{
	width: 1000px;
	margin: 0 auto;
	overflow: hidden;
}

/* 詳細ページ：イメージ画像 */
#ttl_bar{
	width: 100%;
	height: 100px;
	overflow: hidden;
	top: 145px;
	left: 0;
}
.color-change-5x {
	-webkit-animation: color-change-5x 24s linear infinite alternate both;
	        animation: color-change-5x 24s linear infinite alternate both;
}
/**
 * ----------------------------------------
 * animation color-change-5x
 * ----------------------------------------
 */
@-webkit-keyframes color-change-5x {
	0% {
		background: #ef59bd;
	}
	25% {
		background: #f9b458;
	}
	50% {
		background: #2fd33b;
	}
	75% {
		background: #21afed;
	}
	100% {
		background: #9c70fc;
	}
}
@keyframes color-change-5x {
	0% {
		background: #ef59bd;
	}
	25% {
		background: #f9b458;
	}
	50% {
		background: #2fd33b;
	}
	75% {
		background: #21afed;
	}
	100% {
		background: #9c70fc;
	}
}


/* パンくず */
ol.breadcrumb{
	margin: 0 0 5px;
	padding: 0;
	list-style-type: none;
	font-size: 0.8em;
}

ol.breadcrumb li{
	padding-left: 10px;
	display: inline;
}
ol.breadcrumb li:first-child{
	padding-left: 0;
}
ol.breadcrumb li a{
	padding-right: 10px;
	text-decoration: none;
}
ol.breadcrumb li a:hover{
	text-decoration: underline;
}


/* 背景グレー */
.bggray{
	background-color:#ededed;
	overflow: hidden;
}

/* text */
.lead_txt{
	font-size: 1.125em;
	font-weight: 600;
	width: 1000px;
	margin: 0 auto 40px;
}
.indent_txt{
	margin: 0 20px 6px !important;
	padding-left:1em;
	text-indent:-1em;
}

/*	footer
------------------------------------------------------------*/
#footer{
	padding: 30px 0 40px;
	background: #333;
	text-align: center;
	color: #fff;
}

#link{
	position: relative;
	overflow: hidden;
}
#link ul{
	float:left;
	left:50%;
	position:relative;
}
#link ul li{
	float:left;
	left:-50%;
	position:relative;
}
#link ul.footerlink li{
	border-right:1px solid #fff;
	line-height: 1.0;
}
#link ul.footerlink li:first-child{
	border-left:1px solid #fff;
}
#link ul.footerlink li a{
	padding: 0 10px;
	color: #fff;
	font-size: 0.813em;
	text-decoration: none;
}
#link ul.footerlink li a:hover{
	text-decoration: underline;
}
#link ul.sns{
	clear: left;
	margin-top: 36px;
}
#link ul.sns li{
	margin: 0 7px;
}

#link ul.sns li img{
	width:40px;
}

#footer .name{
	font-size: 1.05em;
	margin: 20px auto 8px;
}
#footer .name img{
	margin-bottom:15px;
}
#footer .address{
	font-size: 0.750em;
	margin-bottom: 5px;
}
#footer .address br{
	display: none;
}
#footer .copy{
	font-size: 0.7em;
}


/* =============== Responsive =============== */

@media (max-width: 1020px) {
	#ttl_bar{
		height: 90px;
	}
}
@media (max-width: 899px) {
	#ttl_bar{
		display: none;
	}
}
@media (min-width: 750px) and (max-width: 899px) {
	#header{
		height: auto;
	}
	.copy_txt{
		display: none;
	}
	#head_left{
		width: 50%;
		margin-left: 16px;
	}
	#head_right{
		margin-right: 10px;
	}
	ul#language{
		12px 5% 0 0
	}
	#googlesearch{
		margin-right: -5px;
	}
}
@media (max-width: 770px) {
	#header{
		height: auto;
	}
	.copy_txt{
		display: none;
	}
	#head_left, #head_right{
		width: 100%;
		float: none; 
		overflow: hidden;
		margin-top: 0px;
		margin-left: 2px;
	}
	#head_right{

		margin-top:-22px;
	}
	#header h1, #header .logo {
		margin-top: 10px;
		width: 84%;
	}
	#header h1 a, #header .logo a{
		height: 60px;
		background-position: 0 center;
		background-size: 155px;
	}
	ul#language{
		margin: 0px 8px 10px 0;
	}
	#googlesearch{
		float: right;
		margin-right: 5px;
	}
	#kogeilogo{
		position: absolute;
		right:0;
		top:0;
		width: 90px;
		margin: 5px 5px 0;
	}
	#kogeilogo img{
		width: 100%;
	}
}
@media (max-width: 599px) {
	#googlesearch{
		display: none;
		margin-right: 0px;
	}
}
@media (max-width: 380px) {
	#header h1 a, #header .logo a {
		height: 54px;
		background-size: 155px;
	}
	#googlesearch{
		width: 190px;
	}
}
@media (min-width: 900px) {
	/* 3本線メニュー */
	#menu{
		display: none;
	}
}
@media (max-width: 899px) {
	#gnav{
		background: #ededed;
		overflow: hidden;
	}
	#menu{
		float: right;
	}
	/* 3本線メニュー */
	#ico-menu{
		display: block;
		width: 46px;
		height:46px;
		position: relative;
		top: 0;
		right: 17px;
		z-index: 3;
	}
	#ico-menu span{
		display: block;
		background: #000;
		width: 35px;
		height: 4px;
		position: absolute;
		left: 9px;
		transition: all 0.4s;
		-webkit-transition: all 0.4s;
		-moz-transition: all 0.4s;
	}
	#ico-menu span:first-child{
		top: 11px;
	}
	#ico-menu span:nth-child(2){
		margin-top: -2px;
		top: 50%;
	}
	#ico-menu span:last-child{
		bottom: 11px;
	}
	#ico-menu.active span:first-child {
		-webkit-transform: translateY(11px) rotate(45deg);
		-moz-transform: translateY(11px) rotate(45deg);
		-ms-transform: translateY(11px) rotate(45deg);
		transform: translateY(11px) rotate(45deg);
	}
	#ico-menu.active span:nth-child(2){
		opacity: 0;
	}
	#ico-menu.active span:last-child{
		-webkit-transform: translateY(-9px) rotate(-45deg);
		-moz-transform: translateY(-9px) rotate(-45deg);
		-ms-transform: translateY(-9px) rotate(-45deg);
		transform: translateY(-9px) rotate(-45deg);
	}

	/* Gnav */
	#fade-in{
		display: none;
		width: 100%;
		min-width: 100%;
		margin: 0;
		padding: 0;
		position: relative;
		background: #fff;
		list-style: none;
		overflow: hidden;
		-webkit-box-shadow:0 2px 4px rgba(0, 0, 0, 0.3), 0 0 5px rgba(0, 0, 0, 0.1) inset;
		-moz-box-shadow:0 2px 4px rgba(0, 0, 0, 0.3), 0 0 5px rgba(0, 0, 0, 0.1) inset;
		box-shadow:0 2px 4px rgba(0, 0, 0, 0.3), 0 0 5px rgba(0, 0, 0, 0.1) inset;
	}
	#fade-in li ul {
		visibility: visible;
		opacity: 1;
	}

	/* アコーディオン */
	.accordion {
		width: 100%;
	}
	.accordion > ul > li > a {
		display: block;
		font-weight: 400;
		text-decoration: none;
		background-color: #ededed;
		border-bottom: 1px solid #ccc;
		cursor: pointer;
		padding: 8px 14px;
		position: relative;
	}
	.accordion > ul > li:first-child > a {
		border-top: 1px solid #ccc;
	}
	.accordion > ul > li > a:hover{
		background-color: #ee5aa7;
		color: #fff;
	}
	.accordion > ul > li > a:after,
	.accordion > ul > li > a.active:after{
		font-size: 14px;
		position: absolute;
		right: 18px;
		top: 10px;
		color: #333;
	}
	.accordion > ul > li > a:hover:after,
	.accordion > ul > li > a.active:after{
		color: #fff;
	}
	.accordion > ul > li > a:after{
		content: "▼";
	}
	.accordion > ul > li > a.active:after{
		content: "▲";
	}
	.accordion > ul > li > ul {
		display: none;
	}
	.accordion > ul > li > ul > li > a{
		display: block;
		font-size: 0.875em;
		font-weight: 300;
		background-color: #fff;
		border-bottom: 1px solid #ccc;
		padding: 4px 40px 4px 16px;
		position: relative;
		text-decoration: none;
		line-height: 140%;
	}
	.accordion > ul > li > ul > li > a:hover{
		background-color: #f9dce7;
	}
	.accordion > ul > li > ul > li > a:before{
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 50%;
		right: 22px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		background: #000;
	}
	.accordion > ul > li > ul > li > a:after{
		display: block;
		content: "";
		position: absolute;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		top: 50%;
		right: 25px;
		width: 10px;
		height: 10px;
		margin-top: -5px;
		background: #fff;
	}
	.accordion > ul > li > ul > li > a:hover:after{
		background: #f9dce7;
	}
}
@media (max-width: 599px) {
	#ico-menu{
		right: 10px;
	}
}
@media screen and (max-width: 1020px) {
	.container{
		padding: 10px 3% 50px;
	}
	.wrapper{
		width: 100%;
		margin: 0;
	}
}
@media (max-width: 770px) {
	#ttl_bar{
		height: 70px;
	}
}
@media (max-width: 600px) {
	.container{
		padding-bottom: 10px;
	}
	.container p{
		font-size: 1em;
	}
}
@media (max-width: 500px) {
	#ttl_bar{
		height: 40px;
	}
}

@media (max-width: 820px) {
	#footer .address br{
		display: block;;
	}
}
@media (max-width: 800px) {
	ul.footerlink li{
		margin-bottom: 8px;
	}
	ul.footerlink li:nth-child(4){
		clear: left;
		border-left:1px solid #fff;
		margin-left: 25px;
	}
	#link ul.sns{
		margin-top: 18px;
	}
	#footer .name{
		margin-top: 18px;
	}
	#footer .copy{
		font-size: 0.688em;
	}
}
@media (max-width: 400px) {
	ul.footerlink{
		float: none !important;
		width: 265px;
		margin: 0 auto;
		left: 0 !important;
	}
	ul.footerlink li{
		width: 130px;
		left: 0 !important;
		border-left: 1px solid #fff;
		font-size: 0.813em;
	}
	ul.footerlink li:nth-child(4){
		clear: none !important;
		margin-left: 0;
	}
	ul.footerlink li:nth-child(even){
		border-left: none;
	}
	#footer .name{
		font-size: 0.813em;
	}
	#footer .address{
		font-size: 0.563em;
	}
	#footer .copy{
		font-size: 0.438em;
	}
}
