@charset "utf-8";

/* **********************************************************
	header
********************************************************** */
header {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	position: absolute;
	top: 0px;
	left: 0px;
	padding: 12px 10px 0 10px;
	width: 100%;
	z-index: 100;
}

header.fixed {
	background-color: #151515;
	border-bottom: 1px solid #6f6a5f;
	-moz-box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
	-webkit-box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
	box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
	position: fixed;
	padding: 0 10px;
	height: auto;
}

header .header__main {
	display: table;
	width: 100%;
}

header .header__logo {
	display: table-cell;
	vertical-align: middle;
}

header.fixed .header__logo {
	padding: 15px 0;
}

header.fixed .header__logo {
	width: 110px;
}

header .header__logo dl {
	display: table;
}

header .header__logo dt {
	display: table-cell;
	font-size: 0;
	line-height: 0;
	vertical-align: middle;
}

header .header__logo dt img {
	width: 110px;
	height: auto;
}

header .header__logo dd {
	color: #ffffff;
	display: table-cell;
	font-size: 10px;
	font-size: 1.0rem;
	vertical-align: middle;
	padding-left: 15px;
}

header.fixed .header__logo dd {
	display: none;
}

header .header__inline_navi {
	display: none;
}

header.fixed .header__inline_navi {
	display: table-cell;
	vertical-align: middle;
	padding-top: 0;
	padding-bottom: 0;
	padding-left: 2%;
	padding-right: 2%;
}

header .header__inline_navi br {
	display: none;
}

header .header__inline_navi .navi {
	background: url(/common/images/line_header_navi.png) right top repeat-y;
	display: table;
	width: 100%;
}

header .header__inline_navi .navi>a {
	background: url(/common/images/line_header_navi.png) left top repeat-y;
	color: #ffffff;
	font-size: 12px;
	font-size: 1rem;
	display: table-cell;
	text-align: center;
	position: relative;
	vertical-align: middle;
	padding: 0 5px;
}

header .header__inline_navi .navi>a:hover {
	color: #ffffff;
	text-decoration: none;
	padding-left: 5px;
	padding-right: 5px;
}

/* add 20161222 */
header .header__link {
	display: table-cell;
	vertical-align: middle;
	padding: 0 0 0 1.5%;
}

header.fixed .header__link {
	display: table-cell;
	vertical-align: middle;
	padding: 0 0 0 1.5%;
}

header .header__link br {
	display: none;
}

header .header__link .navi {
	background: url(/common/images/line_header_navi.png) right top repeat-y;
	display: table;
	width: 100%;
}

header .header__link a {
	background: url(/common/images/line_header_navi.png) left top repeat-y;
	color: #ffffff;
	font-size: 12px;
	font-size: 1.2rem;
	display: table-cell;
	text-align: center;
	position: relative;
	vertical-align: middle;
	padding: 0 10px;
}

header .header__link a:hover {
	color: #ffffff;
	text-decoration: none;
}

header .header__link a:hover:after {
	content: " ";
	border-top: 1px solid #ffffff;
	position: absolute;
	left: 0px;
	bottom: -8px;
	overflow: hidden;
	width: 100%;
	height: 1px;
}

@media (max-width: 640px) {
	header.fixed .header__link {
		padding: 0 1.5% 0 1.5%;
	}
}

/**/

header.selected_1 .header__inline_navi .navi>a.current_1:after,
header.selected_2 .header__inline_navi .navi>a.current_2:after,
header.selected_3 .header__inline_navi .navi>a.current_3:after,
header.selected_4 .header__inline_navi .navi>a.current_4:after,
header.selected_5 .header__inline_navi .navi>a.current_5:after,
header .header__inline_navi .navi>a.current:after,
header .header__inline_navi .navi>a:hover:after {
	content: " ";
	border-top: 1px solid #ffffff;
	position: absolute;
	left: 0px;
	bottom: -8px;
	overflow: hidden;
	width: 100%;
	height: 1px;
}

header.selected_1.hover .header__inline_navi a.current_1:after,
header.selected_2.hover .header__inline_navi a.current_2:after,
header.selected_3.hover .header__inline_navi a.current_3:after,
header.selected_4.hover .header__inline_navi a.current_4:after,
header.selected_5.hover .header__inline_navi a.current_5:after {
	display: none;
}

header .header__info {
	display: table-cell;
	vertical-align: middle;
}

header.fixed .header__info {
	width: 338px;
}

header .header__info ul {
	float: right;
	display: table;
}

header .header__info li {
	display: table-cell;
	vertical-align: middle;
}

header .header__info li.text {
	color: #ffffff;
	font-size: 10px;
	font-size: 1.0rem;
	font-weight: bold;
	padding-right: 10px;
}

header.fixed .header__info li.text {
	display: none;
}

header .header__info li.tel {
	padding-right: 10px;
	width: 176px;
}

header .header__info li.tel img {
	width: 100%;
	height: auto;
}

header .header__info li.btn {
	width: 137px;
}

header .header__info li.btn img {
	display: none;
}

header .header__info li.btn a {
	background-repeat: no-repeat;
	background-image: url(/common/images/btn_mail.png);
	color: #ffffff;
	display: block;
	font-size: 10px;
	font-size: 1.0rem;
	text-align: center;
	line-height: 30px;
	padding-left: 15px;
}

header .header__info li.btn a:hover {
	background-repeat: no-repeat;
	background-image: url(../images/btn_mail_on.png);
	text-decoration: none;
}

header .header__menu {
	display: none;
}

header .header__navi {
	margin-top: 35px;
	padding-bottom: 7px;
	padding-left: 0px;
	margin-left: 4%;
}

header.fixed .header__navi {
	display: none;
	margin-left: 0px;
}

header .header__navi br {
	display: none;
}

header .header__navi .navi {
	background: url(/common/images/line_header_navi.png) right top repeat-y;
	display: table;
	margin-top: 0;
	margin-right: 2%;
	margin-left: 2%;
	margin-bottom: 0;
	width: 90%;
}

header .header__navi a {
	background: url(/common/images/line_header_navi.png) left top repeat-y;
	color: #ffffff;
	display: table-cell;
	text-align: center;
	position: relative;
	vertical-align: middle;
	padding-top: 0;
	padding-bottom: 0;
	width: 16.666%;
	margin-right: 0px;
}

header .header__navi a:hover {
	color: #ffffff;
	text-decoration: none;
}

header.selected_1 .header__navi .navi>a.current_1:after,
header.selected_2 .header__navi .navi>a.current_2:after,
header.selected_3 .header__navi .navi>a.current_3:after,
header.selected_4 .header__navi .navi>a.current_4:after,
header.selected_5 .header__navi .navi>a.current_5:after,
header .header__navi .navi>a.current:after,
header .header__navi .navi>a:hover:after {
	content: " ";
	border-top: 1px solid #ffffff;
	position: absolute;
	left: 0px;
	bottom: -8px;
	overflow: hidden;
	width: 100%;
	height: 1px;
}

header.selected_1.hover .header__navi a.current_1:after,
header.selected_2.hover .header__navi a.current_2:after,
header.selected_3.hover .header__navi a.current_3:after,
header.selected_4.hover .header__navi a.current_4:after,
header.selected_5.hover .header__navi a.current_5:after {
	display: none;
}

header .header__sub_navi {
	background: url(/common/images/bg_header.png);
	display: none;
	margin: 0 -10px;
	padding-bottom: 35px;
}

header .header__sub_navi dl {
	padding-top: 35px;
}

header .header__sub_navi dt {
	font-weight: bold;
	text-align: center;
}

header .header__sub_navi dt span {
	display: inline-block;
	font-size: 12px;
	font-size: 1.2rem;
	vertical-align: middle;
	margin-left: 10px;
}

header .header__sub_navi dd {
	margin-top: 30px;
}

header .header__sub_navi dd.machining {
	margin-top: 30px;
	padding: 0 35%;
}

header .header__sub_navi dd ul {
	display: table;
	width: 100%;
}

header .header__sub_navi dd li {
	display: table-cell;
	overflow: hidden;
	position: relative;
	vertical-align: top;
	width: 10%;
}

header .header__sub_navi dd.machining li {
	width: 33.33%;
}

header .header__sub_navi dd li:after {
	background: url(/common/images/line_header_subnavi.png) no-repeat;
	content: " ";
	position: absolute;
	left: 0px;
	top: 24px;
	overflow: hidden;
	width: 100%;
	height: 2px;
}

header .header__sub_navi dd li.no01:after {
	left: 50%;
}

header .header__sub_navi dd.machining li.no03:after {
	left: auto;
	right: 50%;
}

header .header__sub_navi dd li.no10:after {
	left: auto;
	right: 50%;
}

header .header__sub_navi dd li a {
	color: #004d92;
	display: block;
	font-size: 12px;
	font-size: 1.2rem;
	text-align: center;
	position: relative;
	padding: 55px 3px 0 3px;
	z-index: 2;
}

header .header__sub_navi dd li.current a,
header .header__sub_navi dd li a:hover {
	color: #00a2c9;
	text-decoration: none;
}

header .header__sub_navi dd li.no01 a {
	background: url(/common/images/no_01.png) center top no-repeat;
}

header .header__sub_navi dd li.no01.current a,
header .header__sub_navi dd li.no01 a:hover {
	background: url(/common/images/no_on_01.png) center top no-repeat;
}

header .header__sub_navi dd li.no02 a {
	background: url(/common/images/no_02.png) center top no-repeat;
}

header .header__sub_navi dd li.no02.current a,
header .header__sub_navi dd li.no02 a:hover {
	background: url(/common/images/no_on_02.png) center top no-repeat;
}

header .header__sub_navi dd li.no03 a {
	background: url(/common/images/no_03.png) center top no-repeat;
}

header .header__sub_navi dd li.no03.current a,
header .header__sub_navi dd li.no03 a:hover {
	background: url(/common/images/no_on_03.png) center top no-repeat;
}

header .header__sub_navi dd li.no03ex a {
	background: url(/common/images/no_03ex.png) center top no-repeat;
}

header .header__sub_navi dd li.no03ex.current a,
header .header__sub_navi dd li.no03ex a:hover {
	background: url(/common/images/no_on_03ex.png) center top no-repeat;
}

header .header__sub_navi dd li.no04 a {
	background: url(/common/images/no_04.png) center top no-repeat;
}

header .header__sub_navi dd li.no04.current a,
header .header__sub_navi dd li.no04 a:hover {
	background: url(/common/images/no_on_04.png) center top no-repeat;
}

header .header__sub_navi dd li.no05 a {
	background: url(/common/images/no_05.png) center top no-repeat;
}

header .header__sub_navi dd li.no05.current a,
header .header__sub_navi dd li.no05 a:hover {
	background: url(/common/images/no_on_05.png) center top no-repeat;
}

header .header__sub_navi dd li.no06 a {
	background: url(/common/images/no_06.png) center top no-repeat;
}

header .header__sub_navi dd li.no06.current a,
header .header__sub_navi dd li.no06 a:hover {
	background: url(/common/images/no_on_06.png) center top no-repeat;
}

header .header__sub_navi dd li.no07 a {
	background: url(/common/images/no_07.png) center top no-repeat;
}

header .header__sub_navi dd li.no07.current a,
header .header__sub_navi dd li.no07 a:hover {
	background: url(/common/images/no_on_07.png) center top no-repeat;
}

header .header__sub_navi dd li.no08 a {
	background: url(/common/images/no_08.png) center top no-repeat;
}

header .header__sub_navi dd li.no08.current a,
header .header__sub_navi dd li.no08 a:hover {
	background: url(/common/images/no_on_08.png) center top no-repeat;
}

header .header__sub_navi dd li.no09 a {
	background: url(/common/images/no_09.png) center top no-repeat;
}

header .header__sub_navi dd li.no09.current a,
header .header__sub_navi dd li.no09 a:hover {
	background: url(/common/images/no_on_09.png) center top no-repeat;
}

header .header__sub_navi dd li.no10 a {
	background: url(../images/no_07.png) center top no-repeat;
}

header .header__sub_navi dd li.no10.current a,
header .header__sub_navi dd li.no10 a:hover {
	background: url(/common/images/no_on_07.png) center top no-repeat;
}

header .header__sp_navi {
	display: none;
}

/* ****************************
	@media
**************************** */
@media (min-width: 641px) and (max-width: 999px) {
	header .header__logo dd {
		display: none;
	}

	header .header__navi br {
		display: inline;
	}

	header .header__inline_navi br {
		display: inline;
	}

	header.fixed .header__info {
		width: 137px;
	}

	header.fixed .header__info ul {
		float: none;
		display: block;
	}

	header.fixed .header__info li {
		display: block;
		text-align: right;
		vertical-align: middle;
	}

	header .header__info li.text {
		display: none;
	}

	header.fixed .header__info li.text {
		display: none;
	}

	header.fixed .header__info li.tel {
		padding: 0;
		width: 152px;
	}

	header.fixed .header__info li.tel img {
		width: 100%;
		height: auto;
	}

	header.fixed .header__info li.btn {
		padding-top: 3px;
		width: 137px;
	}

	header.fixed .header__info li.btn img {
		display: none;
	}

	header.fixed .header__info li.btn a {
		background: url(/common/images/btn_mail.png) no-repeat;
		color: #ffffff;
		display: block;
		font-size: 10px;
		font-size: 1.0rem;
		text-align: center;
		line-height: 30px;
		padding-left: 15px;
	}

	header.fixed .header__info li.btn a:hover {
		background: url(/common/images/btn_mail_on.png) no-repeat;
		text-decoration: none;
	}
}

@media (max-width: 640px) {
	header {
		background-color: #151515;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		position: fixed;
		top: 0px;
		left: 0px;
		padding: 0 0 0 5px;
		width: 100%;
		z-index: 100;
	}

	header.fixed {
		background-color: #151515;
		border-bottom: 0px;
		-moz-box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
		-webkit-box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
		box-shadow: 0px 1px 0px rgba(0, 0, 0, 0);
		position: fixed;
		overflow: hidden;
		padding: 0 0 0 5px;
	}

	header .header__main {
		display: table;
		width: 100%;
	}

	header .header__logo {
		display: table-cell;
		vertical-align: middle;
	}

	header.fixed .header__logo {
		padding: 0;
	}

	header.fixed .header__logo {
		width: 61px;
	}

	header .header__logo dl {
		display: table;
	}

	header .header__logo dt {
		display: table-cell;
		font-size: 0;
		line-height: 0;
		vertical-align: middle;
	}

	header .header__logo dt img {
		width: 61px;
		height: auto;
	}

	header .header__logo dd {
		display: none;
	}

	header.fixed .header__logo dd {
		display: none;
	}

	header .header__inline_navi {
		display: none;
	}

	header.fixed .header__inline_navi {
		display: none;
	}

	header .header__info {
		display: table-cell;
		vertical-align: middle;
	}

	header.fixed .header__info {
		width: auto;
	}

	header .header__info ul {
		float: right;
		display: table;
	}

	header .header__info li {
		display: table-cell;
		vertical-align: middle;
	}

	header .header__info li.text {
		display: none;
	}

	header.fixed .header__info li.text {
		display: none;
	}

	header .header__info li.tel {
		font-size: 0;
		line-height: 0;
		padding-right: 10px;
		width: 116px;
	}

	header .header__info li.tel img {
		width: 100%;
		height: auto;
	}

	header .header__info li.btn {
		width: 38px;
	}

	header .header__info li.btn img {
		display: inline;
		width: 38px;
		height: 35px;
	}

	header .header__info li.btn span {
		display: none;
	}

	header .header__info li.btn a {
		background: none;
		color: #ffffff;
		display: block;
		font-size: 0;
		font-size: 0;
		text-align: center;
		line-height: 0;
		padding-left: 0;
	}

	header .header__info li.btn a:hover {
		background: none;
		text-decoration: none;
	}

	header .header__menu {
		display: table-cell;
		vertical-align: middle;
		width: 38px;
	}

	header .header__menu p {
		background: url(/common/images/btn_header_menu.png) no-repeat;
		background-size: 38px 35px;
		overflow: hidden;
		text-align: left;
		text-indent: -9999px;
		width: 38px;
		height: 35px;
	}

	header .header__menu.opened p {
		background: url(/common/images/btn_header_menu_close.png) no-repeat;
		background-size: 38px 35px;
	}

	header .header__navi {
		display: none;
	}

	header.fixed .header__navi {
		display: none;
	}

	header .header__sub_navi {
		display: none;
	}

	header .header__sp_navi {
		border-top: 1px solid #313131;
		background-color: #151515;
		color: #ffffff;
		display: none;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		text-align: left;
	}

	header .header__sp_navi a {
		color: #ffffff;
		display: block;
		padding: 10px 15px 10px 1em;
	}

	header .header__sp_navi a:hover {
		color: #ffffff;
		text-decoration: none;
	}

	header .header__sp_navi a span {
		background: url(/common/images/arw_link_sp.png) right center no-repeat;
		background-size: 8px 8px;
		display: block;
		padding-right: 15px;
	}

	header .header__sp_navi>p {
		border-bottom: 1px solid #313131;
	}

	header .header__sp_navi dt {
		border-bottom: 1px solid #313131;
		padding: 10px 15px 10px 1em;
	}

	header .header__sp_navi dt span {
		background: url(/common/images/arw_toggle_open_sp.png) right center no-repeat;
		background-size: 8px 8px;
		display: block;
		padding-right: 15px;
	}

	header .header__sp_navi dt.opened span {
		background: url(/common/images/arw_toggle_close_sp.png) right center no-repeat;
		background-size: 8px 8px;
	}

	header .header__sp_navi dd {
		background-color: #252525;
		display: none;
	}

	header .header__sp_navi dd p {
		border-bottom: 1px solid #313131;
		padding: 10px 15px 10px 1em;
	}

	header .header__sp_navi dd ul {
		border-bottom: 1px solid #313131;
		padding-left: 1em;
	}

	header .header__sp_navi dd li {
		border-bottom: 1px solid #313131;
	}

	header .header__sp_navi dd li:last-of-type {
		border-bottom: 0px;
	}

	header .header__sp_navi dd .sub_link {
		padding: 0;
	}

	header .header__sp_navi dd .sub_link a {
		padding: 10px 15px 10px 1em;
		background: url(/common/images/arw_link_sp.png) right 15px center no-repeat;
		background-size: 8px 8px;
	}
}








.c-nav__item:last-child .c-nav__link_sub {
	width: 136.875%;
	max-width: 219px;
	position: absolute;
	right: 0;
	bottom: -78px;
}

.c-nav__item:last-child .c-nav__link_sub::before {
	content: '';
	position: absolute;
	top: 10px;
	right: 10px;
	bottom: 10px;
	left: 10px;
	background: rgba(0, 0, 0, 0);
	-webkit-transition: 300ms;
	transition: 300ms;
}

.c-nav__item:last-child .c-nav__link_sub:hover::before {
	background: rgba(123, 141, 154, 0.9);
	top: 1px;
	right: 1px;
	bottom: 1px;
	left: 1px;
}

.c-nav__item:last-child .c-nav__link_sub img {
	width: 100%;
}

.c-nav__item:last-child .c-nav__link_sub .c-nav__subtxt {
	padding-left: 20%;
	width: 100%;
	position: absolute;
	left: 0;
	top: 50%;
	text-align: left;
	color: #fff;
	font-size: 15px;
	line-height: 1.25;
	z-index: 2;
	transform: translateY(-45%);
	box-sizing: border-box;
}

.c-nav__item:last-child .c-nav__link_sub .c-nav__subtxt .sml {
	margin: 0 0 0.2em 1em;
	display: inline-block;
	vertical-align: bottom;
	font-size: 9px;
}


.accordion {
	display: table-cell;
	text-align: center;
	position: relative;
	vertical-align: middle;
}

.accordion__title a {
	text-align: center;
	color: #fff;
}

header .header__inline_navi .accordion__title a {
	font-size: 1rem;
	text-decoration: none;
	color: #ffffff;
}

.accordion__content {
	width: 380px;
	position: absolute;
	left: 0;
	top: 22px;
	z-index: 3;
	display: none;
	padding-top: 7px !important;
}

header.fixed .accordion__content {
	padding-top: 21px !important;
}

@media (min-width: 641px) and (max-width: 999px) {
	header.fixed .accordion__content {
		padding-top: 26px !important;
	}
}

.accordion__content--inner {
	background-color: rgba(0, 0, 0, .8);
}

.accordion__content a:hover::after {
	display: none;
}


.accordion__content li a {
	display: flex;
	align-items: center;
	position: relative;
	text-decoration: none;
	width: 100%;
}

.accordion__content li a .image {
	aspect-ratio: 5/4;
	width: 100px;
}

.accordion__content li a .image img {
	width: 100%;
}

.accordion__content li a .text {
	padding-left: 20px;
	color: #ffffff;
	font-size: 1em;
	position: relative;
	z-index: 9;
	transition: all .3s;
}

.accordion__content li a:hover .text {
	transform: translateX(20px);
}

.accordion__content li a::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, .8);
	z-index: 4;
	opacity: 0;
	transition: all .3s;
}

.accordion__content li a:hover::before {
	opacity: 1;
}

.accordion__content li a::after {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: 20px;
	width: 30px;
	aspect-ratio: 83/20;
	background-image: url('/common/images/strength_nav_arrow.png');
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	z-index: 4;
	opacity: 0;
	transition: all .3s;
}

.accordion__content li a:hover::after {
	display: block;
	opacity: 1;
}