@charset "utf-8";

/* -------------------------------------------------------------- */

body {
	font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size: 16px;
}

/* リンク設定
------------------------------------------------------------*/

a {
	text-decoration: none;
}

a:hover {
	color: #73c4e6;
}

a:active,
a:focus {
	outline: 0;
}

/* 全体
------------------------------------------------------------*/

.align-center {
	text-align: center;
}

* {
	padding: 0;
	margin: 0;
}

body {
	border-top: 8px solid #da241f;
	position: relative;
}

#wrapper {
	max-width: 1920px;
	display: flex;
	flex-wrap: wrap;
}


.slicknav_menu {
	display: none;
}

.u-bold {
	font-weight: bold;
}

.u-mt-1 {
	margin-top: 1em;
}

.u-mr-1 {
	margin-right: 1em;
}

/*************
	/* smartPhone
	*************/

@media screen and (max-width: 767px) {

	.js #menu {
		display: none;
	}

	.js .slicknav_menu {
		display: block;
	}

}


/*************
/* ヘッダー
*************/

header {
	width: 20%;
}

header #logo {
	border-bottom: 1px solid #ddd;
	background: #fff;
}

header #logo img {
	width: 80%;
	padding: 5% 10% 5% 10%;
}

/*************
	/* smartPhone
	*************/

@media screen and (max-width: 767px) {

	header {
		width: 50%;
		position: absolute;
		top: 14px;
		left: 8px;
	}

	header #logo {
		border-bottom: 0px solid #ddd;
	}

	header #logo img {
		width: 100px;
		padding: 0;
	}

}

/**************************
/* ナビゲーション
**************************/

#menu {
	background: #fffafa;
}

#menu .sub_title {
	padding-top: 10px;
	border-bottom: 1px solid #ddd;
}

#menu .sub_title .en {
	margin-left: 16px;
	color: #da241f;
	font-size: 3vw;
	font-family: aharoni, Helvetica, "游ゴシック", "Yu Gothic", sans-serif;
	font-style: oblique;
	transition: all 1s;
}

@media screen and (min-width:768px) and (max-width: 1024px) {
	#menu .sub_title .en {
		font-weight: bold;
	}
}

#menu .sub_title .jp {
	margin-left: 16px;
	font-size: 80%;
	color: #999;
	display: block;
}

#menu .sub_title .en:hover {
	color: #fabb00;
}

#menu .sub_title .sub-menu {
	overflow: hidden;
	position: relative;
	max-height: 0;
	opacity: 0;
	transition: all 600ms;
}

#menu .sub_title:hover .sub-menu {
	max-height: 500px;
	opacity: 1;
}

#menu .sub_title .sub-menu .brand {
	font-size: 80%;
	font-weight: bold;
	width: 100%;
	height: 30px;
}

#menu .sub_title .sub-menu .brand a {
	margin-left: 2em;
	display: inline-block;
	font-size: 100%;
	color: #da241f;
}

#menu .sub_title .sub-menu .brand a:hover {
	color: #fabb00;
}

#menu .sub_title .menu_h {
	color: #999;
	display: block;
	cursor: pointer;
}

#menu .sub_title .sub-menu ul {
	padding-bottom: 1em;
}

#menu .sub_title .sub-menu li a {
	color: #999;
	font-weight: bold;
	display: block;
	line-height: 2;
	margin-left: 20px;
}

#menu .sub_title .sub-menu li a:hover {
	color: #fabb00;
}




/*************
	/* PC-TAB
	*************/

@media screen and (min-width: 768px) {

	.for_sp {
		display: none;
	}

}

/*************
	/* TAB
	*************/

@media screen and (min-width:768px) and (max-width: 1024px) {
	#menu .sub_title .sub-menu li a {
		font-size: 75%;
		margin-left: 1em;
	}
}

/*************
	/* smartPhone
	*************/

@media screen and (max-width: 767px) {

	#menu .sub_title {
		position: absolute;
		z-index: 99;
		text-align: center;
		width: 12.3%;
		line-height: 80px;
		border-right: 10px solid #ccc;
		margin-top: 1em;
	}




}


/*************
/* フッター
*************/

#footer {
	border-top: 1px solid #ddd;
	padding-top: 1em;
	color: #ccc;
	line-height: 2.5;
	font-size: 80%;
	width: 100%;
}

#footer #footer_wrap {
	width: 900px;
	height: 230px;
	margin: 0 auto;
	display: flex;
}

#footer #footer_wrap figure {
	width: 95px;
	margin-right: 1.5em;
	margin-left: 1.5em;
	flex-shrink: 0;
}

#footer #footer_wrap figure img {
	width: 100%;
}

#footer #footer_wrap nav {
	display: flex;
}

#footer #footer_wrap nav ul {
	margin-right: 1.5em;
}


#footer #footer_wrap nav ul li:first-child {
	color: #333;
	font-weight: bold;
}

#footer .obi {
	background: #da241f;
	width: 100%;
	padding: 1em 0
}

#footer .obi div {
	width: 768px;
	height: 60px;
	margin: 0 auto;
}

#footer .obi p {
	margin-right: 1em;
	display: inline-block;
}

#footer .de {
	width: 2.8em;
	margin-left: 0.5em;
}

/*************
	/* smartPhone
	*************/

@media screen and (max-width: 767px) {
	#footer {
		line-height: 2;
		font-size: 70%;
		border-width: 0;
	}

	#footer #footer_wrap {
		height: 160px;
	}

	#footer .obi p {
		margin-left: 1em;
	}

	#footer .obi div {
		width: 100%;
		height: 100%;
		margin: 0 auto;
	}
}