@charset "utf-8";
/* ===========================================================


	Title: common.css
	Created: 2017-10-2


=========================================================== */
/*

	body
	header
	global-navigation
	contens
	topicpath
	main
	aside
	btPageTop
	footer


=========================================================== */
/*

	body


=========================================================== */
html {
	font-size: 62.5%
}
body {
	font-family: "Noto Sans JP", "游ゴシック", "YuGothic", "メイリオ", Meiryo, sans-serif;
	font-weight: 400;
	color: #111;
	text-align: center;
	font-size: 14px;
	font-size: 1.4rem;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	font-feature-settings : "palt" 1;
}
main {
	font-weight: 300 !important;
}
html * {
	max-height: 999999px;
} /* Chrome font size adjust  */


/* ===========================================================


	header


=========================================================== */
header {
	position: fixed;
	top: 0;
	width: 100%;
	height: 80px;
	z-index: 99;
	background-color: #fff;
	border-bottom: solid 1px rgba(221,221,221,0.00);
}
header.header__fix {
	border-bottom: solid 1px rgba(221,221,221,1.00);
}
@media screen and (max-width: 767px) {
}

/* logo
........................................................... */
header h1 {
	position: relative;
	display: inline-block;
	float: left;
	z-index: 11;
	margin: 0;
	padding: 16px 0 0 20px;
}
header h1 a {
	position: relative;
	display: block;
	background-position: 0 50%;
	background-repeat: no-repeat;
	width: 500px;
	height: 34px;
	background-image: url(../img/ja/common/logo.png);
	background-size: 230px auto;
	/*　Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
@media screen and (max-width: 1024px) {
	header h1 {
		padding: 20px 0 0 20px;
	}
}
@media screen and (max-width: 767px) {
	header h1 {
		padding: 23px 0 0 15px;
	}
	header h1 a {
		width: 182px;
		height: 60px;
		background-position: 0 0;
		background-size: 180px auto;
	}
}

/* header__language
........................................................... */
.header--language {
	float: right;
	margin: 0;
	font-size: 14px;
	font-size: 1.4rem;
}
.header--language a, .header--language a:link, .header--language a:visited {
	position: relative;
	display: block;
	width: 80px;
	height: 80px;
	line-height: 80px;
	text-align: center;
	color: #fff;
	background-color: #da0000;
	border-bottom: solid 1px #da0000;
	text-transform: uppercase;
}
.header--language a:hover {
	text-decoration: none;
	background-color: #fff;
	border-bottom: solid 1px #ddd;
	color: #da0000;
}
.header--language a span {
	display: block;
	/*　Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
.header--language a:before {
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 80px;
	height: 80px;
	line-height: 80px;
	content: "EN";
	font-weight: bold;
	display: inline-block;
	text-indent: 0;
	z-index: 1;
}
.header--language a:after {
	position: absolute;
	content: " ";
	top: 50%;
	left: 0;
	width: 100%;
	height: 0;
	opacity: 0;
	background-color: #fff;
	display: block;
	transition: all .2s ease-in;
	z-index: 0;
}
.header--language a:hover:after {
	top: 0;
	height: 100%;
	opacity: 1;
}
@media screen and (max-width: 1024px) {
	.header--language {
		position: relative;
		margin: 0 60px 0 0;
		z-index: 11;
	}
	.header--language a, .header--language a:link, .header--language a:visited {
		width: 60px;
	}
	.header--language a:before {
		width: 60px;
	}
}
@media screen and (max-width: 767px) {
	.header--language {
		font-size: 13px;
		font-size: 1.3rem;
	}
	.header--language a, .header--language a:link, .header--language a:visited {
		width: 40px;
		height: 40px;
		line-height: 40px;
	}
	.header--language a:before {
		width: 40px;
		height: 40px;
		line-height: 40px;
	}
}

/* .header__search
----------------------------------------------------------- */
.header__search-close, .header__search-close span {
	display: none;
}
.header__search {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #da0000;
	z-index: 999998;
	text-align: center;
}
.header__search form {
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	height: 40px;
	line-height: 40px;
	width : calc(100% - 40%);
	margin: -20px 20% 0;
	border-bottom: solid 1px #fff;
}
.header__search form input[type="text"] {
	font-size: 24px;
	font-size: 2.4rem;
	height: 40px;
	line-height: 40px;
	margin: 0;
	padding: 0;
	width : calc(100% - 30px);
	display: block;
	float: left;
	color: #fff;
	background: none;
	border: none;
}
.header__search form input:focus {
	outline: none !important;
	background: none;
}
.header__search form input[type="submit"] {
	margin: 0;
	padding: 0;
	height: 40px;
	line-height: 40px;
	width: 30px;
	float: right;
	border: none;
	background-color: transparent;
	background-repeat: no-repeat;
	background-position: 50% 50%;
	background-image: url(../img/common/ic/ic_search_a.png);
	background-size: 13px 13px;
	/*Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
/* header__search-open */
.header__search-open {
	float: right;
	display: block;
	position: relative;
	text-align: center;
	background-color: #da0000;
}
.header__search-open span {
	position: relative;
	display: block;
	width: 80px;
	height: 80px;
	line-height: 80px;
	background-repeat: no-repeat;
	background-position: 50% 48%;
	background-image: url(../img/common/ic/ic_search_a.png);
	background-size: 13px 13px;
	border-left: solid 1px #da0000;
	border-bottom: solid 1px #da0000;
	/*　Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
	z-index: 1;
}
.header__search-open:hover {
	cursor: pointer;
}
.header__search-open:hover span {
	background-image: url(../img/common/ic/ic_search_b.png);
	border-left: solid 1px #ddd;
	border-bottom: solid 1px #ddd;
}
.header__search-open:after {
	position: absolute;
	content: " ";
	top: 50%;
	left: 0;
	width: 100%;
	height: 0;
	opacity: 0;
	background-color: #fff;
	display: block;
	transition: all .2s ease-in;
	z-index: 0;
}
.header__search-open:hover:after {
	top: 0;
	height: 100%;
	opacity: 1;
}
/* header__search-close */
.header__search-close {
	position: fixed;
	z-index: 9999;
	top: 30px;
	right: 30px;
	content: " ";
	height: 50px;
	width: 50px;
	z-index: 999999;
	transition: .3s ease-in-out;
}
.header__search-close:hover {
	cursor: pointer;
}
.header__search-close span {
	display: block;
	/*　Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
.header__search-close:before,  .header__search-close:after {
	position: absolute;
	top: 50%;
	left: 50%;
	content: " ";
	display: block;
	width: 50px;
	height: 2px;
	background-color: #fff;
	margin: -1px 0 0 -25px;
}
.header__search-close:before {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.header__search-close:after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.header__search-close:hover {
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}
@media screen and (max-width: 1024px) {
	.header__search-open {
		position: relative;
		z-index: 11;
	}
	.header__search-open span {
		width: 60px;
		background-position: 50% 50%;
	}
}
@media screen and (max-width: 767px) {	
	.header__search form {
		margin: -20px 10% 0;
		width : calc(100% - 20%);
	}
	.header__search-open {
		margin: 40px -40px 0 0;
	}
	.header__search-open span {
		width: 40px;
		height: 40px;
		line-height: 40px;
	}
}

/* -----------------------------------------------------------

	global-navigation

----------------------------------------------------------- */
nav {
}
.global-navigation {
	position: absolute;
	top: 0;
	right: 180px;
}
.global-navigation ul.gn {
	margin 0;
}
.global-navigation ul.gn a:hover {
	text-decoration: none;
}

/* gn__primary
........................................................... */
.global-navigation > ul.gn > li {
	position: relative;
	margin: 0;
	float: left;
}
.global-navigation ul.gn > a {
	display: none;
}
.global-navigation ul.gn li a.gn__primary {
	position: relative;
	overflow: hidden;
	display: block;
	padding: 0 20px;
	height: 80px;
	line-height: 86px;
	font-size: 14px;
	font-size: 1.4rem;
	letter-spacing: 1px;
	color: #111111;
}
.global-navigation ul.gn li a.gn__primary:hover,
.global-navigation ul.gn li a.gn-over {
	color: #da0000;
}
/* current */
#about .global-navigation ul.gn li#gn__about a.gn__primary, #feature .global-navigation ul.gn li#gn__feature a.gn__primary, #portfolio .global-navigation ul.gn li#gn__portfolio a.gn__primary, #finance .global-navigation ul.gn li#gn__finance a.gn__primary, #ir .global-navigation ul.gn li#gn__ir a.gn__primary, #esg .global-navigation ul.gn li#gn__esg a.gn__primary {
	color: #da0000;
}
#about .global-navigation ul.gn li#gn__about a.gn__primary:after,
#feature .global-navigation ul.gn li#gn__feature a.gn__primary:after,
#portfolio .global-navigation ul.gn li#gn__portfolio a.gn__primary:after,
#finance .global-navigation ul.gn li#gn__finance a.gn__primary:after,
#ir .global-navigation ul.gn li#gn__ir a.gn__primary:after,
#esg .global-navigation ul.gn li#gn__esg a.gn__primary:after {
	position: absolute;
	left: 50%;
	bottom: 0;
	content: "";
	width: 60px;
	height: 5px;
	margin-left: -30px;
	background-color: #da0000;
	display: block;
}

/* gn__secondary
........................................................... */
.global-navigation ul.gn .gn__secondary {
	display: none;
	position: absolute;
	top: 80px;
	left: 50%;
	z-index: 999900;
	width: 240px;
	margin: 0 0 0 -120px;
	text-align: left;
	background-color: #da0000;
	padding: 15px;
}
.global-navigation ul.gn li#gn-ir .gn__secondary {
	left: inherit;
	right: 0;
	margin: 0 -20px 0 0;
}
.global-navigation ul.gn .gn__secondary li {
	margin: 0;
	font-size: 13px;
	font-size: 1.3rem;
}
.global-navigation ul.gn .gn__secondary li ul {
	display: none;
}
.global-navigation ul.gn .gn__secondary li a {
	display: block;
	padding: 6px 10px 6px 20px;
	color: #fff;
	position: relative;
}
.global-navigation ul.gn .gn__secondary li a:before {
	position: absolute;
	top: 14px;
	left: 5px;
	content: "";
	vertical-align: middle;
	display: inline-block;
	width: 7px;
	height: 7px;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.global-navigation ul.gn .gn__secondary li a:link, .global-navigation ul.gn .gn__secondary li a:visited {
	color: #fff;
	text-decoration: none;
}
.global-navigation ul.gn .gn__secondary li a:hover {
	background-color: rgba(255,255,255,0.40);
}
.global-navigation ul.gn .gn__secondary li a.current {
	background-color: rgba(255,255,255,1.00);
	color: #da0000;
}
.global-navigation ul.gn .gn__secondary li a.current:before {
	border-top: 1px solid #da0000;
	border-right: 1px solid #da0000;
}

/* ===========================================================


	slicknav_nav


=========================================================== */
.slicknav_menu {
	display: none;
}
@media screen and (max-width: 1024px) {
	.global-navigation {
		position: static;
		top: 0;
		right: 0;
	}
	.gn {
		display: none !important;
	}
	/* -----------------------------------------------------------

		slicknav_menu

	----------------------------------------------------------- */
	.slicknav_menu {
		font-size: 16px;
		position: absolute;
		top: 0;
	 	*zoom: 1;
		display: block;
		padding: 0;
		min-width: 100%;
		z-index: 10;
	}
	.slicknav_menu * {
		box-sizing: border-box;
	}
	.slicknav_menu * {
		box-sizing: border-box;
	}
	.slicknav_menu:before {
		content: " ";
		display: table;
	}
	.slicknav_menu:after {
		content: " ";
		display: table;
		clear: both;
	}
	.slicknav_menu_inner {
		height: 100%;
		position: relative;
		overflow: scroll;
		overflow-x: hidden;
		overflow-y: auto;
	}
	/* -----------------------------------------------------------

		slicknav_btn

	----------------------------------------------------------- */
	.slicknav_btn {
		position: relative;
		z-index: 2;
		text-decoration: none;
		display: block;
		vertical-align: middle;
		float: right;
		width: 60px;
		height: 80px;
		cursor: pointer;
		background-color: #da0000;
	}
	.slicknav_btn .slicknav_icon-bar + .slicknav_icon-bar {
		margin-top: 3px;
	}
	.slicknav_menu .slicknav_menutxt {
	}
	.slicknav_menu .slicknav_icon {
		position: relative;
		display: block;
		width: 60px;
		height: 80px;
	}
	.slicknav_menu .slicknav_no-text {
		margin: 0;
	}
	.slicknav_menu .slicknav_icon-bar {
		display: block;
		width: 20px;
		height: 2px;
		margin: 34px 0 0 20px;
		transition: .3s ease-in-out;
		background-color: #fff;
	}
	/* slicknav_open
	........................................................... */
	.slicknav_menu .slicknav_open {
		background-color: #da0000;
	}
	.slicknav_menu .slicknav_open .slicknav_icon-bar {
		background-color: #fff;
	}
	.slicknav_menu .slicknav_open .slicknav_icon-bar:first-child {
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		margin-top: 39px;
	}
	.slicknav_menu .slicknav_open .slicknav_icon-bar:nth-of-type(2) {
		opacity: 0
	}
	.slicknav_menu .slicknav_open .slicknav_icon-bar:last-child {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		margin-top: -7px;
	}
	/* -----------------------------------------------------------

		slicknav_nav

	----------------------------------------------------------- */
	.slicknav_nav {
		clear: both;
		text-align: left;
		background-color: #da0000;
		color: #fff;
		border-top: solid 1px #AF0101;
		/*navi scroll*/
		width: 100% !important;
		height: 100%;
		position: fixed;
		z-index: 99999;
		margin: 0;
		padding: 0 0 80px;
		top: 80px;
		left: 0;
		overflow: scroll !important;
		display: block;
	}
	.slicknav_nav li {
		display: block;
		margin: 0;
		padding: 0;
		clear: both;
	}
	.slicknav_nav a.gn__primary {
		display: block !important;
		padding: 15px 20px !important;
		color: #fff;
		font-weight: bold;
		border-bottom: solid 1px #AF0101;
		font-size: 15px;
	}
	.slicknav_nav a.gn__primary br {
		display: none;
	}
	.slicknav_nav a.gn__primary:hover {
		text-decoration: none !important;
	}
	.slicknav_nav a.gn__primary span {
		color: #fff;
	}
	.slicknav_nav ul.gn__secondary {
		display: block;
		overflow: hidden;
		width: 100% !important;
		margin: 0 !important;
		padding: 0;
		background-color: #fff;
	}
	.slicknav_nav ul li + li {
		border-top: solid 1px #ddd;
	}
	.slicknav_nav ul li a {
		position: relative;
		display: block;
		padding: 15px 40px 15px 20px;
		text-decoration: none;
		color: #AF0101;
		line-height: 18px;
		font-size: 13px !important;
	}
	.slicknav_nav ul li a:before {
		position: absolute;
		content: " ";
		vertical-align: middle;
		top: 50%;
		right: 20px;
		width: 10px;
		height: 10px;
		margin: -5px 0 0;
		border-top: 1px solid #da0000;
		border-right: 1px solid #da0000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	/* 3rd */
	.slicknav_nav ul li ul {
		border-top: solid 1px #245897;
		padding-left: 20px;
	}
	/* slicknav option */
	.slicknav_nav .slicknav_arrow {
	}
	.slicknav_nav .slicknav_item {
		position: relative;
		cursor: pointer;
	}
	.slicknav_nav .slicknav_item .slicknav_arrow i {
		position: absolute;
		right: 10px;
		top: 50%;
		width: 20px;
		height: 20px;
		line-height: 17px;
		margin: -10px 0 0;
		text-align: center;
		color: #fff;
		border: solid 1px #fff;
		font-size: 15px;
	}
	.slicknav_nav .slicknav_item .slicknav_arrow i.icon-plus:before {
		content: "+" !important;
	}
	.slicknav_nav .slicknav_item .slicknav_arrow i.icon-minus:before {
		content: "-" !important;
	}
	.slicknav_nav .slicknav_item a {
		display: inline;
		padding: 0;
		margin: 0;
	}
	.slicknav_nav .slicknav_row {
		display: block;
	}
	.slicknav_nav .slicknav_row:hover {
		-webkit-border-radius: 0;
		-moz-border-radius: 0;
		border-radius: 0;
		background: none;
		color: inherit;
		text-decoration: none;
	}
}

/* ===========================================================


	topic-path


=========================================================== */
.topic-path {
	clear: both;
	position: relative;
	height: 40px;
	line-height: 40px;
	overflow: hidden;
	width: 100%;
	margin: 0;
	background-color: #da0000;
}
.topic-path ol {
	width: 1200px;
	margin: 0 auto;
	clear: both;
	height: 40px;
	line-height: 40px;
	font-size: 12px;
	font-size: 1.2rem;
	color: #fff;
}
.topic-path ol li {
	float: left;
	margin: 0;
}
.topic-path ol li:before {
	content: "/";
	padding: 0 12px;
	color: #fff !important;
}
.topic-path ol li:first-child {
	padding: 0
}
.topic-path ol li:first-child:before {
	content: "";
	padding: 0;
}
.topic-path ol li a {
}
.topic-path ol li:before {
	content: "/";
}
.topic-path ol a:link, .topic-path ol a:visited {
	text-decoration: underline;
	color: #fff;
}
.topic-path ol a:hover {
	text-decoration: none;
}
@media screen and (max-width: 1024px) {
	.topic-path {
		width: auto;
		height: auto;
		line-height: 1.2;
		margin: 20px 0 0;
		padding: 10px 0;
		z-index: 90;
	}
	.topic-path ol {
		width: auto;
		margin: 0 20px;
		height: auto;
		line-height: 1.8;
	}
}
/* ===========================================================


	contens


=========================================================== */
.contents {
	width: 1200px;
	margin: 0 auto;
	padding: 410px 0 0;
	text-align: center;
}
@media screen and (max-width: 1024px) {
	.contents {
		width: 100%;
		padding: 370px 0 0;
	}
}
@media screen and (max-width: 767px) {
	.contents {
		padding: 350px 0 0;
	}
}

/* ===========================================================


	title


=========================================================== */
.title {
	position: absolute;
	top: 120px;
	left: 0;
	width: 100%;
	min-width: 1200px;
	height: 250px;
	background-size: cover;
	background-repeat: 50% 100%;
	background-color: #000;
	text-align: left;
	background-image: url(../img/common/title/title.png);
}
#about .title {background-image: url(../img/common/title/title_about.png);}
#feature .title {background-image: url(../img/common/title/title_feature.png);}
#portfolio .title {background-image: url(../img/common/title/title_portfolio.png);}
#finance .title {background-image: url(../img/common/title/title_finance.png);}
#ir .title {background-image: url(../img/common/title/title_ir.png);}
#esg .title {background-image: url(../img/common/title/title_esg.png);}
.title h1 {
	margin: 0 auto;
	padding: 85px 0 0;
	color: #fff;
	font-size: 20px;
	font-size: 2.0rem;
	letter-spacing: 5px;
	display: block;
	line-height: 30px;
	text-align: center;
	font-weight: bold;
	letter-spacing: 3px;
}
.title h1 strong {
	font-family: 'Droid Sans', sans-serif;
	font-weight: 700 !important;
	font-size: 42px;
	font-size: 4.2rem;
	letter-spacing: 1px;
	display: block;
	line-height: 50px;
}
@media screen and (max-width: 1024px) {
	.title {
		top: 80px;
		min-width: 300px;
		display: table;
	}
	.title h1 {
		display: table-cell;
		vertical-align: middle;
		padding: 0 20px;
		height: 250px;
		width: 100%;
	}
	.title h1 strong {
		display: block;
		line-height: 1.2;
		padding: 0 0 5px;
	}
}
@media screen and (max-width: 767px) {
	.title h1 {
		font-size: 18px;
		font-size: 1.8rem;
	}
	.title h1 strong {
		font-size: 30px;
		font-size: 3.0rem;
	}
}

/* ===========================================================


	main


=========================================================== */
main {
	width: 900px;
	margin: 0 auto;
	padding: 0 0 50px;
	text-align: left;
}
main:after {
	content: "";
	display: block;
	clear: both;
}
main section, .cont-margin {
	margin-bottom: 60px !important;
}
@media screen and (max-width: 1024px) {
	main {
		float: none;
		width: auto;
		margin: 0 20px;
		padding: 0 0 10px;
	}
}

/* -----------------------------------------------------------

	tit

----------------------------------------------------------- */
main h2 {
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 1.2;
	margin: 0 0 30px;
	padding: 20px 0 20px;
	letter-spacing: 3px;
	color: #111;
	position: relative;
	text-align: center;
	overflow: hidden;
}
main h2:after {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	width: 2px;
	height: 300px;
	margin-top: -150px;
	background-color: #da0000;
	transform: rotate(45deg);
	z-index: -1;
}
main h2 span {
	display: inline-block;
	background-color: #fff;
	padding: 5px;
	position: relative;
}
@media screen and (max-width: 767px) {
	main h2 {
		font-size: 22px;
		font-size: 2.2rem;
	}
}
main h3 {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.4;
	padding: 10px;
	margin: 0 0 20px;
	background-color: #FAE3E2;
	color: #da0000;
	border-left: solid 3px #da0000;
}
main h4 {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.4;
	margin: 0 0 10px;
	color: #da0000;
}
h4 {
}
h5 {
}
h6 {
}
em {
	color: #da0000;
}
strong {
	font-weight: bold!important;
}
.read {
	font-size: 20px;
	font-size: 2.0rem;
	line-height: 35px;
	letter-spacing: 1px;
}
.blue {
	color: #da0000;
}
.emphasis {
	border: solid 1px #da0000;
	padding: 20px;
}
.ffReset {
	font-family: "ＭＳ ゴシック", "MS Gothic", "Osaka－等幅", Osaka-mono, monospace !important;
}
.txt-ss {
	font-size: 10px !important;
	font-size: 1.0rem !important;
}
.txt-s {
	font-size: 12px !important;
	font-size: 1.2rem !important;
}
.txt-l {
	font-size: 16px !important;
	font-size: 1.6rem !important;
}
.txt-ll {
	font-size: 20px !important;
	font-size: 2.0rem !important;
}
/* -----------------------------------------------------------

	text

----------------------------------------------------------- */
p, ul, ol, dl, .indent-table {
	margin: 0 0 20px;
	line-height: 1.8;
}
ul li, ol li {
	margin: 0;
}
ol ol {
	padding: 5px 0 0;
}
/* -----------------------------------------------------------

	link

----------------------------------------------------------- */
a:link, a:visited {
	text-decoration: none;
	color: #da0000;
	-webkit-transition: all 0.2s ease-in-out;
	-moz-transition: all 0.2s ease-in-out;
	-o-transition: all 0.2s ease-in-out;
	transition: all .2s ease-in-out;
}
a:hover {
	text-decoration: underline;
	color: #111;
}
.link-reverse a:link, .link-reverse a:visited, a.link-reverse:link, a.link-reverse:visited {
	color: #111;
	text-decoration: underline;
}
.link-reverse a:hover, a.link-reverse:hover {
	color: #da0000;
	text-decoration: underline;
}
/* link-a
........................................................... */
.link-a, .link-a a {
	position: relative;
	padding-left: 10px;
}
.link-a:before, .link-a a:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 0;
	width: 0;
	height: 0;
	margin-top: -3px;
	border-style: solid;
	border-width: 3.5px 0 3.5px 4px;
	border-color: transparent transparent transparent #da0000;
}
.link-b, .link-b a {
	position: relative;
	padding-left: 15px;
}
.link-b:before, .link-b a:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 0;
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 1px solid #da0000;
	border-right: 1px solid #da0000;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
/* blank
........................................................... */
.blank {
	background-image: url(../img/common/ic/ic_blank_a.png) !important;
	background-size: 9px 9px !important;
	background-repeat: no-repeat !important;
	background-position: 98% 50% !important;
	padding: 0 18px 0 0 !important;
}
/* -----------------------------------------------------------

	link-button

----------------------------------------------------------- */
/* link-button__a
........................................................... */
.link-button__a a {
	height: 60px;
	line-height: 60px;
	padding: 0 60px 0 60px;
	display: inline-block;
	color: #da0000 !important;
	border: solid 1px #da0000;
	text-align: center;
	position: relative;
	overflow: hidden;
	letter-spacing: 1px;
}
.link-button__a a span {
	position: relative;
	z-index: 1;
}
.link-button__a a:before {
	position: absolute;
	content: " ";
	vertical-align: middle;
	top: 50%;
	right: 15px;
	width: 10px;
	height: 10px;
	margin: -6px 0 0 0;
	border-top: 1px solid #da0000;
	border-right: 1px solid #da0000;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	z-index: 1;
}
.link-button__a a:after {
	position: absolute;
	content: " ";
	top: 50%;
	left: 0;
	width: 100%;
	height: 0;
	opacity: 0;
	background-color: #da0000;
	display: block;
	transition: all .2s ease-in;
	z-index: 0;
}
/*hover*/
.link-button__a a:hover {
	/*background-color: #da0000;*/
	color: #fff !important;
	text-decoration: none;
}
.link-button__a a:hover:before {
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
}
.link-button__a a:hover:after {
	top: 0;
	height: 100%;
	opacity: 1;
}
/* link-button__b
........................................................... */
.link-button__b a {
	height: 40px;
	line-height: 40px;
	padding: 0 60px 0 60px;
	display: inline-block;
	color: #111 !important;
	border: solid 1px #ccc;
	text-align: center;
	position: relative;
	overflow: hidden;
	letter-spacing: 1px;
}
.link-button__b a:before {
	position: absolute;
	content: " ";
	vertical-align: middle;
	top: 50%;
	right: 15px;
	width: 6px;
	height: 6px;
	margin: -4px 0 0 0;
	border-top: 1px solid #111;
	border-right: 1px solid #111;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.link-button__b a:after {
	position: absolute;
	content: " ";
	vertical-align: middle;
	top: 50%;
	right: 15px;
	width: 14px;
	height: 1px;
	background-color: #111;
	margin-top: -1px;
}
/* hover */
.link-button__b a:hover {
	text-decoration: none;
	color: #fff !important;
	background-color: #da0000;
	border: solid 1px #da0000;
}
.link-button__b a:hover:before {
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
}
.link-button__b a:hover:after {
	background-color: #fff;
}
/* -----------------------------------------------------------

	table

----------------------------------------------------------- */
table {
	width: 900px;
	margin: 0 0 20px;
	border-top: solid 1px #ddd;
}

@media screen and (max-width: 1024px) {
table {
	width: 100%;
}
}
table th {
	width: 25%;
	padding: 10px;
	border-bottom: solid 1px #ddd;
	background: #f0f0f0;
	font-weight: bold;
}
table td {
	border-bottom: solid 1px #ddd;
	border-right: solid 1px #ddd;
	padding: 10px;
	vertical-align: top;
}
table tr:nth-child(odd) td {
}
table td:last-child {
	border-right: none;
}
table img {
	vertical-align: text-bottom;
}
table th.th-2nd, table tr.th-2nd th {
	background: #f5f5f5 !important;
}
table td.td-2nd {
	vertical-align: middle;
	text-align: center;
	background: #f2f6fa;
}
table.td-padding-mini td {
	padding: 2px 8px;
}
table.padding-mini th, table.padding-mini td {
	padding: 2px 8px;
}
table .sub-total th, table .sub-total td, table .sub-total {
	background: #f2f6fa;
	border-right: solid 1px #fff;
}
table .total th, table .total td, table .total {
	background: #555;
	color: #fff;
	border-right: solid 1px #fff;
}
table th.noline, table td.noline {
	border: none;
}
/* th-top
........................................................... */
table.th-top th {
	width: auto;
	text-align: center;
	border-right: solid 1px #ddd;
}
table.th-top th:last-child {
	border-right: none;
}
table.th-top td {
}
table.th-top th.firstChild, table.th-top td.firstChild {
}
table.th-top th.firstChild-none {
	border-left: solid 1px #fff !important;
}
table.th-top td.firstChild-none {
	border-left: solid 1px #ccc !important;
}
/* min-tabl
........................................................... */
table.min-table {
}
/* scroll-table , responsive-table
........................................................... */
.scroll-table {
}
.scroll-graph {
}
.scroll-caution {
	display: none;
}
.responsive-table {
}

@media screen and (max-width: 1024px) {
.scroll-wrap {
	overflow: auto;
	position: relative;
	width: 100%;
}
.scroll-table th, .scroll-table td {
	white-space: nowrap;
}
.scroll-graph {
	width: 900px;
}
.scroll-caution {
	display: block;
	margin: 0 0 5px;
	font-size: 12px;
	color: #999;
	padding: 0 0 0 45px;
	background-image: url(../img/common/ic/ic_scroll_side.png);
	background-size: 40px 13px;
	background-position: 0 50%;
	background-repeat: no-repeat;
}
.responsive-table {
	width: 100%;
	border-left: none;
}
table.responsive-table tr th {
	display: block;
	width: auto !important;
	border-right: none;
}
.responsive-table td {
	display: block;
	width: auto !important;
	border-right: none;
}
.responsive-table .nbsp {
	display: none;
}
.responsive-table th.cell-width-1, .responsive-table td.cell-width-1 {
	width: auto !important;
}
}
/* img
........................................................... */
.img img, .img {
	width: 100%;
	height: auto;
}
.responsive-img img, img.responsive-img {
}

@media screen and (max-width: 1024px) {
.responsive-img img, img.responsive-img {
	width: 100% !important;
	height: auto;
}
}
/* column
........................................................... */
.column-1 {
	width: 430px;
}
.column-2-left {
	width: 430px;
	float: left;
}
.column-2-right {
	width: 430px;
	float: right;
}
.column-2-left table, .column-2-right table {
	width: 430px;
}
.column-3-left {
	width: 280px;
	float: left;
}
.column-3-center {
	width: 280px;
	margin: 0 0 0 30px;
	float: left;
}
.column-3-right {
	width: 280px;
	float: right;
}
.column-2w-left {
	width: 600px;
	float: left;
}
.column-2w-right {
	width: 600px;
	float: right;
}

@media screen and (max-width: 1024px) {
.column-1, .column-2-left, .column-2-right, .column-2-left table, .column-2-right table, .column-3-left, .column-3-center, .column-3-right, .column-2w-left, .column-2w-right {
	width: 100%;
	float: none;
	margin: 0;
}
}
/* ===========================================================


	aside


=========================================================== */
aside {
	position: absolute;
	top: 80px;
	left: 0;
	width: 100%;
	background-color: #da0000;
	text-align: center;
	height: 40px;
}
@media screen and (max-width: 1024px) {
	aside {
		display: none;
	}
}
/* -----------------------------------------------------------

	side-navigation

----------------------------------------------------------- */
aside ul {
	position: relative;
	display: inline-block;
	/*width: 1200px;*/
	text-align: center;
	margin: 0 auto;
	line-height: 40px;
}

aside li {
	position: relative;
	display: inline-block;
	margin: 0;
	padding: 5px;
}
aside li:first-child:before {
	position: absolute;
	top: 10px;
	left: 0;
	display: block;
	content: "";
	width: 1px;
	height: 20px;
	background-color: #A00100;
}
aside li:after {
	position: absolute;
	top: 10px;
	right: 0;
	display: block;
	content: "";
	width: 1px;
	height: 20px;
	background-color: #A00100;
}
aside li a {
	font-size: 13px;
	font-size: 1.3rem;
	padding: 0 15px;
	color: #fff !important;
	line-height: 30px;
	display: block;
}
aside li a:hover {
	text-decoration: none;
	background-color: rgba(255,255,255,0.40);
}
aside li a.current {
	background-color: rgba(255,255,255,1.00);
	color: #da0000 !important;
}

/* ===========================================================


	bt-pagetop


=========================================================== */
body .bt-pagetop {
	clear: both;
	width: 50px;
	height: 50px;
	margin: 0;
	display: none;
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 95;
}
.bt-pagetop a {
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	background-color: #da0000;
	opacity: 1;
	/*　Scott Kellum Method */
	overflow: hidden;
	text-indent: 100%;
	white-space: nowrap;
}
.bt-pagetop a:before {
	content: " ";
	position: absolute;
	top: 18px;
	left: 50%;
	margin: 0 0 0 -8px;
	width: 16px;
	border-top: solid 1px #fff;
}
.bt-pagetop a:after {
	content: " ";
	position: absolute;
	top: 50%;
	left: 50%;
	margin: 0 0 0 -5px;
	width: 10px;
	height: 10px;
	border-top: solid 1px #fff;
	border-left: solid 1px #fff;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.bt-pagetop a:hover {
	opacity: 0.5;
}
@media screen and (max-width: 767px) {
	body .bt-pagetop {
		width: 40px;
		height: 40px;
		bottom: 0;
	}
	.bt-pagetop a {
		width: 40px;
		height: 40px;
	}
	.bt-pagetop a:before {
		top: 15px;
		left: 50%;
		margin: 0 0 0 -7px;
		width: 14px;
	}
	.bt-pagetop a:after {
		top: 50%;
		left: 50%;
		margin: 0 0 0 -5px;
		width: 9px;
		height: 9px;
	}
}

/* ===========================================================


	footer


=========================================================== */
footer {
	position: relative;
	clear: both;
	overflow: hidden;
	border-top: solid 2px #da0000;
	text-align: left;
}
footer:before {
	position: absolute;
	left: 50%;
	bottom: 55px;
	content: "";
	display: block;
	width: 257px;
	height: 14px;
	margin-left: 343px;
	background-image: url(../img/ja/common/logo_txt.png);
	background-size: 257px auto;
}
footer:after {
	position: absolute;
	left: 0;
	bottom: 100px;
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: #ddd;
}
footer a, footer a:link, footer a:visited {
	color: #111;
	text-decoration: none;
}
footer a:hover {
	color: #da0000;
	text-decoration: none;
}
footer a.current {
	font-weight: bold;
}
@media screen and (max-width: 1024px) {
	footer {
		padding: 0;
	}
	footer:before {
		left: 0;
		bottom: 35px;
		margin-left: 0;
		width: 100%;
		background-position: 50% 50%;
		background-repeat: no-repeat;
	}
	footer:after {
		background-color: transparent;
	}
}
@media screen and (max-width: 767px) {
	footer:before {
		background-image: url(../img/ja/common/logo_txt_sp.png);
		background-size: 182px auto;
		background-position: 50% 50%;
		background-repeat: no-repeat;
	}
}

/* footer-navigation
........................................................... */
.footer-navigation {
	width: 1200px;
	margin: 0 auto;
	padding: 30px 0 60px;
}
@media screen and (max-width: 1024px) {
	.footer-navigation {
		display: none;
	}
}
.footer-navigation section {
	width: 193px;
	float: left;
}

.footer-navigation h1 {
	font-size: 16px;
	font-size: 1.6rem;
	margin: 0 0 10px;
}
.footer-navigation h1 a:link,
.footer-navigation h1 a:visited {
	color: #da0000 !important;
}
.footer-navigation h1 a:hover {
	color: #111;
}
.footer-navigation ul  {
	font-size: 13px;
	font-size: 1.3rem;
	line-height: 1.4;
	margin: 0 40px 0 0;
	padding: 0;
}
.footer-navigation li {
	margin: 0 0 2px;
	overflow: hidden;
}
.footer-navigation ul a {
	padding: 2px 0 2px 10px;
	display: block;
	position: relative;
}
.footer-navigation ul a:before {
	position: absolute;
	top: 6px;
	left: 0;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 4px 0 4px 5px;
	border-color: transparent transparent transparent #aaa;
}

/* footer-support-navigation
........................................................... */
.footer-support-navigation {
	width: 1200px;
	padding: 0;
	margin: 0 auto;
	height: 80px;
	line-height: 80px;
}
.footer-support-navigation ul {
	display: inline-block;
	margin: 0;
}
.footer-support-navigation li {
	display: inline-block;
	margin: 0;
	padding: 0;
}
.footer-support-navigation li a {
	border-left: solid 1px #ddd;
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1;
	padding: 0 15px;
}
.footer-support-navigation li:first-child a {
	padding: 0 10px 0 0;
	border-left: none;
}
@media screen and (max-width: 1024px) {
	.footer-support-navigation {
		position: relative;
		left: inherit;
		bottom: inherit;
		width: 100%;
		margin-left: inherit;
		line-height: 1.2;
		height: inherit;
	}
	.footer-support-navigation ul {
		width: 100%;
		line-height: 1.2;
		height: inherit;
	}
	.footer-support-navigation li {
		display: block;
	}
	.footer-support-navigation li a, .footer-support-navigation li:first-child a {
		position: relative;
		display: block;
		margin: 0;
		padding: 15px 30px 15px 20px;
		border: none;
		border-bottom: solid 1px #ddd;
		height: auto;
		line-height: 1.4;
		font-size: 13px;
		text-decoration: none;
	}
	.footer-support-navigation li a:before {
		position: absolute;
		content: " ";
		vertical-align: middle;
		top: 50%;
		right: 20px;
		width: 10px;
		height: 10px;
		margin: -5px 0 0;
		border-top: 1px solid #da0000;
		border-right: 1px solid #da0000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
}


/* copyright
........................................................... */
.copyright {
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 600px;
	text-align: right;
	line-height: 80px;
	height: 80px;
	margin: 0;
}
.copyright small {
	font-size: 12px;
	font-size: 1.2rem;
}
.copyright br {
	display: none;
}
@media screen and (max-width: 1024px) {
	.copyright {
		position: relative;
		left: inherit;
		bottom:: inherit;
		width: 100%;
		text-align: center;
		line-height: 1.2;
		height: inherit;
		padding: 20px 20px 60px;
	}
	.copyright br {
		display: block;
	}
}
