@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=Open+Sans:400,300);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/****  lsf  ****/
@font-face {
	font-family: 'LigatureSymbols';
	src: url('fonts/LigatureSymbols-2.11.eot');
	src: url('fonts/LigatureSymbols-2.11.eot?#iefix') format('embedded-opentype'),
	     url('fonts/LigatureSymbols-2.11.woff') format('woff'),
	     url('fonts/LigatureSymbols-2.11.ttf') format('truetype'),
	     url('fonts/LigatureSymbols-2.11.svg#LigatureSymbols') format('svg');
	font-weight: normal;
	font-style: normal;
}

.lsf, .lsf-icon:before {
	font-family: 'LigatureSymbols';
	-webkit-text-rendering: optimizeLegibility;
	-moz-text-rendering: optimizeLegibility;
	-ms-text-rendering: optimizeLegibility;
	-o-text-rendering: optimizeLegibility;
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
	-moz-font-smoothing: antialiased;
	-ms-font-smoothing: antialiased;
	-o-font-smoothing: antialiased;
	font-smoothing: antialiased;
	-webkit-font-feature-settings: "liga" 1, "dlig" 1;
	-moz-font-feature-settings: "liga=1, dlig=1";
	-ms-font-feature-settings: "liga" 1, "dlig" 1;
	-o-font-feature-settings: "liga" 1, "dlig" 1;
	font-feature-settings: "liga" 1, "dlig" 1;
}

.lsf-icon:before {
	content:attr(title);
	margin-right:0.3em;
	font-size:130%;
}

/* ===================================================================
basic.css
=================================================================== */

/* bodyの設定 */
body{
	overflow-y: scroll;
	position: relative;
	color: #000;
	font-family: 'Noto Sans Japanese', 'Hiragino Kaku Gothic ProN', Meiryo, Helvetica, Arial, sans-serif;
	font-weight: 400;
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
	display: flex;
	align-items: center;
	min-height: 100vh;
	flex-direction: column;
}
*{
	-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%;
}
html{	font-size: 62.5%;}
body{
	font-size: 16px;
	font-size: 1.6rem;
}

hr{
	border: 0;
	background: #cfcfcf;
	height:1px;
	margin-bottom: 30px;
}
img{
	vertical-align: bottom;	
}

p,
table th, table td,
dt, dd{
	font-weight: 300;
}

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


/*	header
------------------------------------------------------------*/
.fixed{
	position:fixed;
	top: 0;
	width: 100%;
	z-index: 1000;
}

header{
/*	overflow: hidden;*/
	height: 150px;
	background: #748087;
	border-top: 5px solid #DE220B;
}
#header{
	width:100%;
	height: 100px;
	text-align: center;
	z-index:9999;
	background: #fff;
}
h1#logo,
p#logo{
	position: fixed;
	top: 30px;
	left: 35px;
	margin: 0;
	padding: 0;
	z-index: 100;
}
h1#logo img,
p#logo img{
	width: 370px;
	height:50px !important;
}
h1#logo a:hover img,
p#logo:hover img{
	filter:alpha(opacity=100);
	-moz-opacity: 1;
	opacity: 1;
}
.nav-block h1#logo,
.nav-block p#logo{
	display:none;
}
#header_right{
	overflow: hidden;
}
#header_right > div{
	float: right;
	margin: 31px 25px 0 0;
}

/* Googleサイト内検索 */
#googlesearch{
	float: right;
	width: 220px;
	margin-right: 12px;
}

/* フォントサイズ変更 */
dl#fontZoom{
	float: right;
	margin: 36px 6px 0 0;
	padding: 0;
	height: 30px;
	overflow: hidden;
}
dl#fontZoom dt{
	float: left;
	width: 35px;
	font-size: 14px;
	font-size: 1.4rem;
	font-weight: 400;
	color: #333;
}
dl#fontZoom dd{
	float: left;
	margin: 0;
	padding: 3px 10px 2px 10px;
	display: block;
/*	width: 26px;*/
	height: 26px;
	line-height: 18px;
	background: #ccc;
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: 400;
	text-align: center;
	cursor: pointer;
	border-left: none;
}
dl#fontZoom dd:hover,
#fontZoom dd.active{
	background: #333;
	color: #fff;
	text-decoration: none;
}

/* 多言語 */
ul#language{
	float: right;
	display: flex;
	margin: 36px 35px 0 13px;
}
ul#language li a{
	display: block;
	width: 60px;
	height: 26px;
	padding: 3px 10px 2px 10px;
	background: #ccc;
	color: #000;
	font-size: 12px;
	font-size: 1.2rem;
	font-weight: 400;
	text-decoration: none;
	border-left: none;
}
ul#language li a.active,
ul#language li a:hover{
	background: #333;
	color: #fff;
}

/* SNS */
#header_right ul.sns{
	float: right;
	display: flex;
	margin: 22px 15px 0 13px;
	padding: 0;
}
#header_right ul.sns li a{
	display: block;
	width: 35px;
	margin-left: 10px;
	height: 25px;
	padding: 2px 0;
	color: #666;
	font-size: 33px;
	font-size: 3.3rem;
	text-decoration: none;
}
#header_right ul.sns li a:hover {
	color: #333;
}
@media (max-width: 1280px) {
	h1#logo,
	p#logo{
		left: 12px;
	}
	h1#logo img,
	p#logo img{
		width: 360px;
		height:50px;
	}
	ul#language{
		margin: 48px 10px 0 13px;
	}
	#header_right > div{
		margin: 43px 10px 0 0;
	}
	#header_right ul.sns{
		margin: 32px 5px 0 13px;
	}
	#header_right ul.sns li a{
		margin-left: 3px;
	}
}
@media (max-width: 1120px) {
	ul#language{
		position: absolute;
		top: -20px;
		right: 12px;
	}
	dl#fontZoom{
		position: absolute;
		top: -20px;
		right: 150px;
	}
	#googlesearch{
		position: absolute;
		top: 20px;
		right: 12px;
	}
	#header_right ul.sns{
		position: absolute;
		top: 20px;
		right: 240px;
	}
}
@media (max-width: 830px) {
	header {
		background: none;
		height: 110px;
	}
	#header {
		width: 100%;
		height: 50px;
		text-align: center;
		z-index: 9999;
		background: #fff;
	}
	ul#language{
		position: absolute;
		top: -33px;
		right: -2px;
	}
	h1#logo,
	p#logo{
		display:none;
	}
	dl#fontZoom{
		display:none;
	}
	#header_right ul.sns{
		display:none;
	}
	.nav-block h1#logo,
	.nav-block p#logo{
		display:block;
		float:left;
		position:static;
		margin:13px 0 0 20px;
	}
	.nav-block h1#logo img,
	.nav-block p#logo img {
		width: 22rem;
	}
	/* Google Search */
	#header_right > div {
		float: none;
		margin: 5px 10px 0 10px;
	}
}


/*	Gnavi
------------------------------------------------------------*/
.nav-block{
	width: 100%;
	background: #748085;
}
#gnav{
	width: 1200px;
	height: 46px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	background: transparent;
}
#gnav li a{
	display: block;
	line-height: 46px;
	text-align: center;
	text-decoration: none;
	transition: .5s;
	font-size: 15px;
	font-size: 1.5rem;
	font-weight: 200;
	color: #fff;
}
#gnav li a:hover,
#gnav li a.on{
	color: #fff;
	background: #de220b;
}

.dropmenu{
	*zoom: 1;
	list-style-type: none;
	width: 1200px;
	height: 46px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	background: transparent;
}
.dropmenu:before, .dropmenu:after{
	content: "";
	display: table;
}
.dropmenu:after{
	clear: both;
}
.dropmenu li{
	position: relative;
	float: left;
	width: 20%;
/*	width: calc(100% / 7);*/
	margin: 0;
	padding: 0;
	text-align: center;
	letter-spacing: 0em;
	font-weight: 300;
}
.dropmenu li a{
	display: block;
	margin: 0;
	padding: 0;
	line-height: 50px;
	color: #fff;
	font-size: 16px;
	font-size: 1.6rem;
	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: 46px;
	left: 0;
	margin: 0;
	padding: 0;
	z-index: 1000;
}
.dropmenu li ul li{
	width: 250px;
	float: left;
}
.dropmenu li ul li a{
	padding: 12px 15px;
	line-height: 130% !important;
	border-bottom: 1px solid #f77f7f;
	background: #de220b;
	text-align: left !important;
	color: #fff;
	font-size: 13px !important;
	font-size: 1.3rem !important;
	font-weight: 300;
}
.dropmenu li ul li:first-child {
	border-top: 1px solid #f77f7f;
}
.dropmenu li ul li:last-child a{
	border-bottom: none;
}
.dropmenu li:hover > a,
.dropmenu li.on > a{
	background: #de220b;
	color: #fff;
}
.dropmenu li ul li a:hover{
	background: #b01306 !important;
	color: #fff !important;
}


#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;
}


@media (max-width: 1200px) {
	#gnav{
		width: 100%;
	}
}
@media (max-width: 830px) {
	.nav-block{
		overflow:hidden;
	}
	.dropmenu{
		display: block;
	}
	.dropmenu > li,
	.drawer-menu li{
		width: 100% !important;
	}
	#gnav li a{
		display: block;
		padding: 8px 10px 8px 18px;
		line-height: 33px;
		text-align: left;
	}
	.dropmenu li ul{
		display: none;
	}
}


/*	contents
------------------------------------------------------------*/
.bg-gray{
	overflow: hidden;
	text-align: center;
	background: #f0f0f0;
	padding-bottom: 110px;
}

.bg-black{
	overflow: hidden;
	text-align: center;
	background: #0d0d0d;
	padding-bottom: 110px;
}


@media (max-width: 796px) {
	.bg-gray,
	.bg-black{
		padding-bottom: 50px;
	}
}

#container{
	flex-grow: 1;
	width: 100%;
}

#contents{
	width: 1120px;
	margin: 126px auto 0;
	overflow: hidden;
}
#contents p{
	margin-bottom: 20px;
}


/* パンくず */
ul#breadcrumbs{
	width: 1120px;
	margin: 15px auto 0;
	padding: 0;
	font-size: 11px;
	font-size: 1.1rem;
	list-style: none;
}
ul#breadcrumbs li{
	display: inline-block;
	margin-right: 5px;
}
ul#breadcrumbs li:after{
	content: ">";
	padding-left: 5px;
}
ul#breadcrumbs li:last-child:after{
	content: "";
	padding-left: 5px;
}


/*	バナー
------------------------------------------------------------*/
.bnr-block{
	margin: 10px 0 0;
	padding: 55px 0;
	background: #ededed;
}
.bnr-block ul{
	width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	overflow: hidden;
}
.bnr-block ul li{
	width: 220px;
	margin: 0 auto;
}

@media (max-width: 1220px) {
	.bnr-block ul{
		width: 96%;
		margin-left: 4%;
		margin-right: 4%;
		justify-content: left;
	}
	.bnr-block ul li{
		margin-bottom: 10px;
		margin-left: 5px;
		margin-right: 5px;
	}
}
@media (max-width: 1000px) {
	.bnr-block ul li{
		width: calc((100% - 35px) / 4);
	}
	.bnr-block ul li:last-child{
		margin-right: 0;
	}
	.bnr-block ul li img{
		width: 100%;
	}
}
@media (max-width: 600px) {
	.bnr-block ul li{
		width: 44%;
	}
	.bnr-block ul li:nth-child(2n){
		margin-right: 0;
	}
}


/*	フッターGnavi
------------------------------------------------------------*/
.fGnavi{
	padding: 54px 0;
	background: #748087;
	margin-top:80px;
}
.fGnavi > ul{
	width: 1200px;
	margin: 0 auto;
	border-top: 1px solid #a5a5a5;
	font-size: 14px;
	font-size: 1.3rem;
}
.fGnavi > ul > li{
	display: flex;
	flex: wrap;
	padding: 12px 30px;
	border-bottom: 1px solid #a5a5a5;
	overflow: hidden;
}
.fGnavi > ul > li > a{
	width: 160px;
}
.fGnavi > ul > li a{
	color: #ededed;
	text-decoration: none;
}
.fGnavi ul li ul{
	display: flex;
	flex: wrap;
	overflow: hidden;
}
.fGnavi ul li ul > li{
	padding: 0 8px;
	border-left: 1px solid #ededed;
}
.fGnavi ul li ul > li:last-child{
	border-right: 1px solid #ededed;
}
@media (max-width: 830px) {
	.fGnavi{
		padding: 0 0;
		margin-top: 20px;
	}
	.fGnavi > ul{
		width:100%;
	}
	.fGnavi ul li ul{
		display: none;
	}
	.fGnavi > ul > li a {
		display: block;
		width:100%;
		padding: 12px 30px;
	}
	.fGnavi > ul > li {
		display: block;
		padding: 0;
	}
}


/*	ページトップ
------------------------------------------------------------*/
#pagetop {
	position: fixed;
	bottom: 376px;
	right: 0;
}
#pagetop a {
	display: block;
	z-index: 999;
	padding: 0;
	width: 65px;
	height: 58px;
	color: #fff;
	font-size: 1.0rem;
	font-weight: bold;
	text-decoration: none;
	text-indent: -9999px;
	text-align: center;
	line-height: 0.8rem;
	background: #4d4d4d url("../images/ico-top.svg") no-repeat center 18px;
	background-size: 33px auto;
	filter:alpha(opacity=75);
	-moz-opacity: 0.75;
	opacity: 0.75;
}
#pagetop a:hover {
	text-decoration: none;
	background: #9f9f9f url("../images/ico-top.svg") no-repeat center 18px;
}
@media (max-width: 790px) {
	#pagetop{
		bottom: 60px;
	}
	#pagetop a {
		width: 40px;
		height: 38px;
		background: #000 url("../images/ico-top.svg") no-repeat center 10px;
		background-size: 25px auto;
	}
	#pagetop a:hover {
		background: #333 url("../images/ico-top.svg") no-repeat center 10px;
		background-size: 25px auto;
	}
}


/*	footer
------------------------------------------------------------*/
footer{
	width: 100%;
	padding: 40px 0;
	background: #222;
}
#footer{
	width: 1200px;
	margin: 0 auto;
	overflow: hidden;
}

#footer ul{
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 8px;
	padding-bottom: 13px;
	display: flex;
	flex-flow: row wrap;
	justify-content: center;
	width: 1200px;
}
#footer ul li{
	margin-bottom: 10px;
	padding: 0 10px;
	border-left: 1px solid #ccc;
	font-size: 14px;
	font-size: 1.4rem;
}
#footer ul li:nth-child(6){
	border-right: 1px solid #ccc;
}
#footer ul li a{
	color: #ccc;
	text-decoration: none;
}
#footer ul li a:hover{
	color: #ccc;
	text-decoration: underline;
}
#footer ul li:last-child{
	border-right: 1px solid #ccc;
}

/* sns */
#footer ul.sns{
	display: flex;
	margin: 0 15px 50px 13px;
	padding: 0;
	width: 100%;
}
#footer ul.sns li{
	border-left: none;
	border-right: none;
}
#footer ul.sns li a{
	display: block;
	width: 35px;
	margin-left: 10px;
	height: 25px;
	padding: 2px 0;
	color: #fff;
	font-size: 33px;
	font-size: 3.3rem;
	text-decoration: none;
}

/* logo */
.fLogo{
	width: 385px;
	margin: 0 auto;
	text-align: center;
}

/* Address */
.address{
	margin: 40px auto;
}
.address p{
	margin-bottom: 0;
	font-size: 13px;
	font-size: 1.3rem;
	color: #ccc;
	text-align: center;
	font-weight: 100;
}

/* Copyright */
.copy{
	margin: 0;
	text-align: center;
	font-size: 12px;
	font-size: 1.2rem;
	color: #ccc;
	font-weight: 100;
}


@media (min-width: 601px) {
	.address p br.br{
		display: none;
	}
}
@media (max-width: 1220px) {
	#footer{
		width: 94%;
		margin: 0 3%;
	}
}
@media (max-width: 860px) {
	#footer ul.fLink{
		flex-wrap: wrap;
	}
	#footer ul li{
		margin-bottom: 10px;
	}
	#footer ul{
		width: 100%;
	}
	#footer ul.sns li a{
		width: 20px;
		margin-left: 10px;
		height: 35px;
		padding: 2px 0;
		color: #fff;
		font-size: 33px;
		font-size: 3.3rem;
		text-decoration: none;
	}
	#footer ul.sns{
		margin: 0px 0px 30px 0px
	}
	.copy{
		font-weight:100;
	}
}
@media (max-width: 600px) {
	footer{
		padding: 20px 0;
	}
	#footer ul{
		margin-bottom: 0;
	}
	#footer ul li{
		font-size: 11px;
		font-size: 1.1rem;
	}
	.fLogo{
		width: 94%;
		margin: 0 3%;
	}
	.fLogo img{
		width: 70%;
	}
	.address{
		margin: 20px 0;
	}
	.address p{
		margin-right: 10px;
		font-size: 11px;
		font-size: 1.1rem;
	}
}
/* 404 */
.errpage h2{
	margin-top:180px;
	font-size:20px;
	font-size:2.0rem;
}
.errpage .column{
	padding: 40px 70px 0;
	margin: 0 3% 10px;
}

@media (max-width: 790px) {
	.errpage h2{
		margin-top:130px;
		font-size:18px;
		font-size:1.8rem;
	}
	.errpage .column{
		width:94%;
		padding: 30px 20px 0 20px;
		margin:0 3% 10px;
	}
}