@charset "utf-8";
/*-----------------------------------------------------------------------------
basic
-----------------------------------------------------------------------------*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	list-style: none;
}
html {
	overflow-y: scroll;
	background-color: #fff;
  -ms-overflow-style: scrollbar;
}
body {
	color: #d4d4d4;
	font-size: 14px;
  line-height: 1.6;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
  letter-spacing: 0.05em;
  background-color: #111;
}
body.modal-open {
  padding-right: 0 !important;
}
.ltsn {
  letter-spacing: normal;
}
strong {
	font-weight: bold;
}
.x-small { font-size: 10px; line-height: 1.6; }
.small { font-size: 12px; line-height: 1.6; }
.middle { font-size: 14px; }
.large { font-size: 16px; }
.x-large { font-size: 18px; }
.x2-large { font-size: 20px; }
.x3-large { font-size: 22px; }
.x4-large { font-size: 24px; }
.x5-large { font-size: 26px; }
.max-large { font-size: 40px; }
.italic {
	font-style: italic;
}
img {
	vertical-align: bottom;
	border: none;
}
.white { color: #ffffff; }
.red { color: #C00; }
.blue { color: #2e7fc2; }
.lblue { color: #027ad5; }
.purple { color: #c27dbc; }
.orange { color: #d4d4d4; }
.green { color: #508019; }
.brown { color: #8c5e39; }
.gray { color: #b2b2b2; }
.f-right {
	float: right;
	margin-left: 15px !important;
}
.f-left {
	float: left;
	margin-right: 15px !important;
}
.pointer {
	cursor: pointer;
}
.clear {
	clear: both;
}
.mb0  { margin-bottom: 0 !important; }
.mb5  { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb80 { margin-bottom: 80px !important; }
.mt10 { margin-top: 10px !important; }
.mt20 { margin-top: 20px !important; }
.pad10 { padding: 10px; }
.pad15 { padding: 15px; }
.pad20 { padding: 20px; }
.pr05 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pl10 { padding-left: 10px !important; }
.pt5 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt20 { padding-top: 20px !important; }
.pt30 { padding-top: 30px !important; }
.pt40 { padding-top: 40px !important; }
.pt50 { padding-top: 50px !important; }
.pb5 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb50 { padding-bottom: 50px !important; }
.space { display: inline-block; }
.space-12 { padding-left: 12.6em; }
.space-11 { padding-left: 11.55em; }
.space-10 { padding-left: 10.5em; }
.space-9 { padding-left: 9.45em; }
.space-8 { padding-left: 8.4em; }
.space-7 { padding-left: 7.35em; }
.space-6 { padding-left: 6.3em; }
.space-5 { padding-left: 5.25em; }
.space-4 { padding-left: 4.2em; }
.space-3 { padding-left: 3.15em; }
.space-2 { padding-left: 2.1em; }
.space-1 { padding-left: 1.05em; }
.w20 { width: 20%; }
.w25 { width: 25%; }
.w33 { width: 33.33333333%; }
.w50 { width: 50%; }
.w60 { width: 60%; }
.w70 { width: 70%; }
.w80 { width: 80%; }
.w100 { width: 100%; }
a {
	font-size: 100%;
	vertical-align: baseline;
}
a:link {
	color: #d4d4d4 !important;
	text-decoration: underline;
}
a:visited {
	color: #d4d4d4 !important;
	text-decoration: underline;
}
a:hover {
	color: #fff !important;
	text-decoration: none;
}
a:active {
	color: #d4d4d4 !important;
	text-decoration:none;
}
a:focus {
	color: #d4d4d4 !important;
	text-decoration:none;
}
.pc a.opacity {
	-webkit-transition: all 0.6s ease-out;
	-moz-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.pc a.opacity:hover {
	-webkit-opacity: 0.6;
	-moz-opacity: 0.6;
	opacity: 0.6;
}
a.opacity img {
	box-shadow: #000 0 0 0;
}
.indent {
	padding-left: 1em;
	text-indent: -1em;
}
.indent span.icon {
  display: inline-block;
  width: 1em;
  text-indent: 0;
}
.indent-icon {
	position: relative;
	padding-left: 1.2em;
}
.indent-icon::after {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	color: #d4d4d4;
}
.indent-icon.dot::after {
	content: "\f192";
}
.indent-icon.check::after {
	content: "\f046";
}
.indent-icon.color-2::after {
	color: #c00;
}
.bb {
	padding-bottom: 10px;
	border-bottom: 2px solid #ddd;
}
a.btn {
  position: relative;
	display: inline-block;
	padding: 17px 45px;
	line-height: 1;
	color: #fff !important;
	text-decoration: none;
	text-align: center;
	/*
  background-color: #d4d4d4;
  */
	border-radius: 0;
  /*
  -webkit-box-shadow: 1px 1px 1px rgba(0,0,0,0.7);
  box-shadow: 1px 1px 1px rgba(0,0,0,0.7);
  */
  z-index: 1;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
a.btn.line {
	color: #d4d4d4 !important;
	border: 1px solid #aaa;
}
a.btn.line::before {
  position: absolute;
  content: '';
  top: 50%;
  right: 0;
  width: 25px;
  height: 1px;
  background-color: #aaa;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.pc a.btn:hover {
  -webkit-opacity: .6;
  opacity: .6;
}
.pc a.btn.line:hover {
  -webkit-opacity: 1;
  opacity: 1;
  color: #fff !important;
	border: 1px solid #fff;
}
.pc a.btn.line:hover::before {
  background-color: #fff;
}
@media screen and (max-width: 1023px) {
	.text-center.left-md {
		text-align: left;
	}
}
@media screen and (max-width: 767px) {
	body {
		font-size: 13px;
		line-height: 1.6;
	}
  body.fixed-top {
    padding-top: 68px;
  }
	.x-small { font-size: 11px; }
	.small { font-size: 12px; }
	.middle { font-size: 13px; }
	.large { font-size: 14px; }
	.x-large { font-size: 15px; }
	.x2-large { font-size: 16px; }
	.x3-large { font-size: 17px; }
	.x4-large { font-size: 18px; }
  .x5-large { font-size: 19px; }
	.max-large { font-size: 30px; }
  .xs-mb5  { margin-bottom: 5px !important; }
  .xs-mb10 { margin-bottom: 10px !important; }
  .xs-mb15 { margin-bottom: 15px !important; }
  .xs-mb20 { margin-bottom: 20px !important; }
  .xs-mb25 { margin-bottom: 25px !important; }
  .xs-mb30 { margin-bottom: 30px !important; }
  .xs-mb40 { margin-bottom: 40px !important; }
  .xs-mb50 { margin-bottom: 50px !important; }
  .xs-mt10 { margin-top: 10px !important; }
  .xs-mt20 { margin-top: 20px !important; }
  .xs-mt30 { margin-top: 30px !important; }
  .xs-mt40 { margin-top: 40px !important; }
  .xs-mt50 { margin-top: 50px !important; }
	.text-center.left-xs {
		text-align: left;
	}
  .xs-text-left {
    text-align: left;
  }
	.btn {
		padding: 10px;
	}
	a.btn {
		padding-left: 0;
		padding-right: 0;
		width: 100%;
	}
	.text-center.left-xs {
		text-align: left;
	}
  .xs-nospace {
    padding-left: 0 !important;
  }
  .xs-w100 { width: 100%; }
	.xs-w75 { width: 75%; }
	.xs-w50 { width: 50%; }
  .xs-w40 { width: 40%; }
  .xs-w30 { width: 30%; }
  .xs-w25 { width: 25%; }
}
/*-----------------------------------------------------------------------------
container-fluid
-----------------------------------------------------------------------------*/
.container-fluid {
  max-width: 1170px;
}
/*-----------------------------------------------------------------------------
header
-----------------------------------------------------------------------------*/
#header {
  position: relative;
  width: 100%;
  height: 100px;
  line-height: 1;
}
@media print {
  #header .logo {
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  #header {
    position: relative;
    width: 100%;
    height: auto;
    padding: 0;
  }
  #header > .container-fluid > .row {
    background: none;
  }
  #header .logo {
    width: 75%;
    margin: 0;
    padding: 15px 0 0;
  }
  #header .contact_box {
    width: 100%;
    height: inherit;
    float: none;
  }
}
/*-----------------------------------------------------------------------------
nav
-----------------------------------------------------------------------------*/
.nav_container {
  position: relative;
  width: 100%;
  text-align: right;
}
.main_nav.navbar {
  display: inline-block;
  border-radius: 0;
  min-height: inherit;
}
.main_nav .navbar-brand {
  display: none;
  height: auto;
  padding: 0 15px;
  line-height: 1;
}
.main_nav .navbar-toggle {
  position: absolute;
  top: -37px;
  right: -10px;
  margin: 0;
  padding-left: 15px;
  padding-bottom: 5px;
  background-color: transparent;
  border: none;
  color: #d4d4d4;
}
.main_nav .navbar-toggle:hover,
.main_nav .navbar-toggle:focus {
  background-color: transparent;
}
.main_nav .navbar-toggle .icon-bar {
  background-color: #fff;
}
.main_nav .navbar-collapse {
  padding: 0;
}
.main_nav .nav.navbar-nav {
  width: 100%;
  height: 100px;
}
.main_nav .nav.navbar-nav > li {
  height: 100%;
  text-align: center;
}
.main_nav .nav.navbar-nav > li a {
  width: 100%;
  height: 100px;
  position: relative;
  display: inline-block;
  padding: 44px 15px 0;
  color: #d4d4d4 !important;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 1;
  letter-spacing: normal;
  background-color: transparent !important;
  -webkit-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
.main_nav .nav.navbar-nav > li a span {
  display: block;
  margin-top: 10px;
  font-size: 12px;
}
.main_nav .nav.navbar-nav > li a::before {
  position: absolute;
  content: '';
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 0;
  background-color: #d4d4d4;
  -webkit-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
.main_nav .nav.navbar-nav > li.active a,
body.pc .main_nav .nav.navbar-nav > li > a:hover {
  color: #fff !important;
}
.main_nav .nav.navbar-nav > li.active a::before,
body.pc .main_nav .nav.navbar-nav > li > a:hover::before {
  height: 20px;
}
@media screen and (max-width: 1024px) {
  .main_nav .nav.navbar-nav li a {
    padding-right: 10px;
    padding-left: 10px;
  }
}
@media screen and (max-width: 767px) {
  .nav_container {
    width: 100%;
    height: auto;
    border-top: none;
  }
  .nav_container::before {
    display: none;
  }
  .main_nav {
    height: auto;
    margin: 0;
    padding: 0;
  }
  .main_nav.navbar {
    display: block;
    position: static;
    min-height: inherit;
  }
  .main_nav.navbar .navbar-header {
    padding-top: 15px;
  }
  .main_nav.navbar-fixed-top {
    height: auto;
    padding-top: 0;
    background-color: rgba(255,255,255,1);
  }
  .main_nav .navbar-default {
    padding: 0;
  }
  .main_nav .navbar-brand {
    padding-top: 18px;
  }
  .navbar-fixed-top.main_nav .navbar-brand {
    display: inline-block;
  }
  .main_nav .navbar-header img {
    max-width: 220px;
  }
  .main_nav .navbar-collapse {
    max-height: none;
    border-top: none;
  }
  .main_nav .navbar-toggle span {
    -webkit-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
  }
  .main_nav .navbar-toggle[aria-expanded="true"] span:nth-child(2) {
    -webkit-transform: translateY(6px) rotateZ(45deg);
    transform: translateY(6px) rotateZ(45deg);
  }
  .main_nav .navbar-toggle[aria-expanded="true"] span:nth-child(3) {
    background-color: transparent;
  }
  .main_nav .navbar-toggle[aria-expanded="true"] span:nth-child(4) {
    -webkit-transform: translateY(-6px) rotateZ(135deg);
    transform: translateY(-6px) rotateZ(135deg);
  }
  .main_nav .navbar-toggle span.font {
    display: inline-block;
    margin-left: -3px;
    padding-top: 7px;
    font-size: 10px;
    line-height: 1;
  }
  .main_nav .nav.navbar-nav {
    float: none;
    height: inherit;
    margin: 0;
    padding: 0 0 15px;
    background: none;
    border: none !important;
  }
  .main_nav .nav.navbar-nav li {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    text-align: left;
    background: none;
    border: none;
  }
  .main_nav .nav.navbar-nav > li:first-child {
    padding-left: 0;
  }
  .main_nav .nav.navbar-nav > li > a {
    height: auto;
    display: block;
    border-bottom: none;
    margin-bottom: 10px;
    padding: 8px 0 8px 12px;
    background: #111 !important;
    color: #d4d4d4 !important;
    font-size: 14px;
    font-weight: normal;
    line-height: 30px;
    border-radius: 0;
    text-align: left;
    /* box-shadow: 0px 1px 3px 0px #ccc inset; */
    box-shadow: none;
    border: 1px solid #aaa;
  }
  .main_nav .nav.navbar-nav > li a span {
    display: inline;
    float: right;
    margin: 0 12px 0 0;
  }
  .main_nav .nav.navbar-nav > li.active > a {
    color: #fff !important;
  }
  .main_nav .nav.navbar-nav > li.active a::before {
    top: 50%;
    right: 0;
    bottom: auto;
    left: auto;
    width: 25px;
    height: 1px;
  }
}
/*-----------------------------------------------------------------------------
common
-----------------------------------------------------------------------------*/
h1, h2, h3, h4, h5, h6 {
 font-weight: inherit;
}
.headline-outer {
  margin-bottom: 50px;
  text-align: center;
}
.headline {
  position: relative;
  padding-bottom: 30px;
  color: #d4d4d4;
  font-size: 30px;
  text-align: center;
  line-height: 1;
}
.headline::after {
  position: absolute;
  content: '';
  width: 160px;
  height: 2px;
  left: 50%;
  bottom: 0;
  margin-left: -80px;
  background-color: #c00025;
}
.headline01 {
  font-size: 34px;
  line-height: 0.8;
}
.headline02 {
  font-size: 30px;
  line-height: 1.0;
}
.headline03 {
  font-size: 24px;
  line-height: 1.2;
}
.headline-en {
  font-size: 13px;
  letter-spacing: 0.1em;
}
.headline-ll {
  padding: 0.4em 0 0.4em 0.6em;
  border-left: 2px solid #c00025;
}
.headline-ul {
  padding-bottom: 10px;
  border-bottom: 1px solid #ddd;
}
.line-left {
  padding-left: 5px;
  border-left: 3px solid #0061ac;
}
.line-bottom {
  padding-bottom: 10px;
  border-bottom: 1px dotted #ccc;
}
.bread {
  padding: 5px 0;
  background-color: #222;
}
.breadcrumb {
  margin: 0;
  padding: 10px 0;
  background-color: transparent;
}
.breadcrumb,
.breadcrumb > .active,
.breadcrumb a {
  color: #d4d4d4 !important;
}
.table > tbody > tr > th {
  background-color: #f6f6f6;
}
@media screen and (max-width: 1024px) {
  .headline {
    font-size: 26px;
  }
  .headline span {
    font-size: 12px;
  }
  .headline01 {
    font-size: 30px;
  }
  .headline02 {
    font-size: 24px;
  }
  .headline03 {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    padding: 5px 0;
    font-size: 10px;
  }
  .headline-outer {
    margin-bottom: 30px;
  }
  .headline {
    padding-bottom: 15px;
    font-size: 20px;
  }
  .headline span {
    font-size: 10px;
  }
  .headline-ll {
    line-height: 1.4;
  }
  .headline01 {
    font-size: 22px;
  }
  .headline02 {
    font-size: 20px;
    line-height: 1.4;
  }
  .headline02.mb30 {
    margin-bottom: 20px !important;
  }
  .headline03 {
    font-size: 18px;
    line-height: 1.4;
  }
  .headline-en {
    font-size: 12px;
  }
}
@media screen and (max-width: 320px) {
  .headline01 {
    font-size: 20px;
  }
  .headline02 {
    font-size: 18px;
  }
  .headline03 {
    font-size: 16px;
  }
}
ul.normal {
  list-style-type: disc;
}
ul.normal li {
  margin: 0 0 10px 20px;
  list-style-type: disc;
}
ul.normal.dot_line li {
  margin: 0 0 10px 20px;
  padding-bottom: 10px;
  list-style-type: disc;
  border-bottom: 1px solid #ddd;
}
ol.normal {
  list-style-type: decimal;
}
ol.normal li {
  margin: 0 0 0 22px;
  list-style-type: decimal;
}
.well {
  margin: 0 auto;
  background-color: #222;
  border-color: #333;
  border-radius: 0;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.5);
}
.common_box {
  padding: 15px;
  border: 1px solid #ddd;
}
/*-----------------------------------------------------------------------------
mainimage & page main title
-----------------------------------------------------------------------------*/
.page-ttl {
  position: relative;
  display: table;
  width: 100%;
  height: 300px;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
.wn .page-ttl {
  background-image: url(../images/wn_title_bg.jpg);
}
.product .page-ttl {
  background-image: url(../images/product_title_bg.jpg);
}
.about-us .page-ttl {
  background-image: url(../images/about-us_title_bg.jpg);
}
.company .page-ttl {
  background-image: url(../images/company_title_bg.jpg);
}
.contact .page-ttl {
  background-image: url(../images/contact_title_bg.jpg);
}
.page-ttl h2 {
  position: relative;
  display: table-cell;
  color: #d4d4d4;
  font-size: 36px;
  line-height: 1;
  text-align: center;
  vertical-align: middle;
  letter-spacing: .2em;
}
.page-ttl h2 span {
  display: block;
  margin-top: .5em;
  font-size: 50%;
  letter-spacing: .1em;
}
@media screen and (max-width: 1024px) {
  .page-ttl {
    height: 250px;
  }
}
@media screen and (max-width: 767px) {
  .page-ttl {
    height: 35vw;
  }
  .pc .page-ttl {
    background-attachment: scroll;
  }
  .page-ttl h2 {
    font-size: 24px;
  }
}
/*-----------------------------------------------------------------------------
section common
-----------------------------------------------------------------------------*/
.common-cont {
  padding: 50px 0;
  overflow: hidden;
}
main > .common-cont:first-of-type {
  padding-top: 100px;
}
main > .common-cont:last-of-type {
  padding-bottom: 100px;
}
@media screen and (max-width: 1023px) {
  article {
    padding: 0;
  }
  .common-cont {
    padding: 40px 0;
  }
  main > .common-cont:first-of-type {
    padding-top: 80px;
  }
  main > .common-cont:last-of-type {
    padding-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .common-cont {
    padding: 30px 0;
  }
  main > .common-cont:first-of-type {
    padding-top: 50px;
  }
  main > .common-cont:last-of-type {
    padding-bottom: 50px;
  }
}
/*-----------------------------------------------------------------------------
home
-----------------------------------------------------------------------------*/
/*-- swiper
---------------*/
.main-area {
  max-height: 610px;
  margin-bottom: 80px;
}
.outer {
  width: 100%;
  overflow: hidden;
  position: relative;
  background: linear-gradient(to bottom, #111111 0%,#222222 100%);
}
.inner {
  max-width: 1140px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.swiper-container {
  width: 100%;
  height: auto;
  overflow: visible;
  z-index: 1;
  background: url(../images/main_bg.png) no-repeat center center;
  background-size: cover;
}
.swiper-pagination {
  padding-top: 10px;
  background-color: #111;
}
.swiper-slide-hako {
  height: auto;
}
.slide-img img {
  width: 100%;
  height: auto;
}
.swiper-pagination {
  position: relative !important;
  margin-top: 10px;
}
.swiper-pagination-bullet {
  width: 34px;
  height: 2px;
  text-align: center;
  line-height: 30px;
  font-size: 12px;
  font-weight: bold;
  color: #fff;
  opacity: 1;
  border-radius: 0%;
  background: #c00025;
  margin-left: 3px;
  margin-right: 3px;
}
.swiper-pagination-bullet-active {
  color: #21428f;
  background: #d4d4d4;
  position: relative;
}
.swiper-pagination-bullet-active::after {
  content: "";
  position: absolute;
  z-index: 100;
  right: 17px;
  height: 60px;
  width: 1px;
  bottom: 0px;
  background: #d4d4d4;
  opacity: 0.5;
}
.swiper-button-next {
  right: -20px !important;
}
.swiper-button-prev {
  left: -20px !important;
}
.swiper-slide-next,
.swiper-slide-prev {
  border-radius: 4px;
}
.home #main01 {
  position: relative;
  width: 100%;
  padding: 80px 0 70px;
  background: url(../images/index_main01_bg.png) center center no-repeat;
  background-size: cover;
}
.home #main01::after {
  position: absolute;
  content: '';
  top: 0;
  left: 50%;
  margin-left: -1px;
  width: 2px;
  height: 100%;
  background-color: #111;
}
.home #main01 .headline {
  letter-spacing: .2em;
}
.home #main01 .headline span {
  display: block;
  margin-top: 10px;
  font-size: 50%;
  font-weight: bold;
  text-align: center;
  letter-spacing: normal;
}
.home #main01 .txt {
  text-align: center;
}

.home #main01 a {
  display:block;
  text-decoration:none;
}


.home #main02 {
  width: 100%;
  padding: 75px 0 70px;
}
.home #main02 h2 {
  margin-bottom: 30px;
  font-size: 30px;
  letter-spacing: .2em;
}
.home #main02 .info {
  padding: 20px 0 10px 20px;
  border-left: 1px solid #d4d4d4;
}
.home #main02 .info table {
  width: 100%;
}
.home #main02 .info td {
  padding: 10px 0;
  vertical-align: top;
}
.home #main02 .info tr:first-of-type td {
  padding-top: 0;
}
.home #main02 .info .date {
  width: 178px;
}
.home #main02 .info .date.new p {
  background: url(../images/icon_new.png) 6.9em center no-repeat;
  background-size: 61px 16px;
}
.home #main02 .info .txt {
  word-break: break-word;
}
.home #main02 .info .txt a.detail {
  display: inline-block;
  padding: 4px;
  color: #d4d4d4 !important;
  font-size: 12px;
  text-decoration: none;
  border-radius: 3px;
  background-color: #666;
  line-height: 1;
  -webkit-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
.home #main02 .info .txt a.detail:hover {
  -webkit-opacity: .6;
  opacity: .6;
}
.home #main02 .info .txt a.pdf {
  position: relative;
  margin-left: 5px;
  padding-left: 1.2em;
  display: inline-block;
}
.home #main02 .info .txt a.pdf::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c1";
  color: #d61d1d !important;
}
.home #main02 .info .txt a.word {
  position: relative;
  margin-left: 5px;
  padding-left: 1.2em;
  display: inline-block;
}
.home #main02 .info .txt a.word::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c2";
  color: #2e7fc2 !important;
}
.home #main02 .info .txt a.excel {
  position: relative;
  margin-left: 5px;
  padding-left: 1.2em;
  display: inline-block;
}
.home #main02 .info .txt a.excel::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c3";
  color: #1a9923 !important;
}
@media screen and (max-width: 1240px) {
  .swiper-button-prev {
    left: 20px !important;
  }
  .swiper-button-next {
    right: 20px !important;
  }
}
@media screen and (max-width: 1140px) {
  .main-area {
    margin-bottom: 50px;
  }
}
@media screen and (max-width: 1060px) {
  .home #main01 .txt {
    text-align: left;
  }
  .home #main01 .txt br.ctl {
    display: none;
  }
}
@media screen and (max-width: 991px) {
  .main-area {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .swiper-container {
    background: url(../images/main_bg_sp.png) no-repeat right bottom;
    background-size: 60px auto;
  }
  .swiper-pagination {
    padding-top: 0;
  }
  .swiper-pagination-bullet-active::after {
    height: 30px;
  }
  .home .swiper-button-prev,
  .home .swiper-button-next {
    display: none;
  }
  .home #main01 {
    padding: 35px 0;
    background: url(../images/index_main01_bg_sp.png) center center no-repeat;
    background-size: cover;
  }
  .home #main01::after {
    display: none;
  }
  .home #main01 .headline span {
    margin-top: 0;
  }
  .home #main02 {
    padding: 35px 0;
  }
  .home #main02 h2 {
    margin-bottom: 15px;
    font-size: 20px;
  }
  .home #main02 .info {
    padding: 20px 0;
    border-left: none;
    border-top: 1px solid #d4d4d4;
  }
  .home #main02 .info td {
    display: block;
    padding: 0;
  }
  .home #main02 .info .date {
    width: 100%;
    padding: 10px 0 5px;
  }
  .home #main02 .info .area {
    width: 100%;
    padding-bottom: 10px;
  }
}
@media print {

}
/*-----------------------------------------------------------------------------
detail
-----------------------------------------------------------------------------*/
.detail main * {
  word-wrap: break-word;
}
.detail #main01 .title {
  margin-bottom: 50px;
	font-size: 18px;
  font-weight: bold;
}
.detail #main01 .big_image {
  margin-bottom: 50px;
	text-align: center;
  height: 400px;
}
.detail #main01 .big_image img {
  position: relative;
  width: auto;
  height: auto;
  max-width: 100%;
	max-height: 400px;
}
.detail #main01 .html {
  margin-bottom: 50px;
}
.detail #main01 .imgs {
	margin-bottom: 20px;
}
.detail #main01 .imgs > div {
	margin-bottom: 30px;
}
.detail #main01 .box-img {
	text-align: center;
  height: 250px;
}
.detail #main01 .box-img .box-img-inner {
  width: 100%;
  display: block;
  position: relative;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.detail #main01 .box-img img {
  position: relative;
  width: auto;
  height: auto;
  max-width: 100%;
	max-height: 250px;
}
.detail #main01 .box-img a {
  cursor: pointer;
}
.detail #main01 .box-img_comment {
  margin-top: 5px;
  font-size: 13px;
  text-align: center;
}
.detail #main01 .files {
  margin-bottom: 50px;
}
.detail #main01 .files li {
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #444;
}
.detail #main01 .files li a {
  position: relative;
  padding-left: 1.2em;
  display: inline-block;
}
.detail #main01 .files li a.pdf::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c1";
  color: #d61d1d !important;
}
.detail #main01 .files li a.word::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c2";
  color: #2e7fc2 !important;
}
.detail #main01 .files li a.excel::before {
	position: absolute;
	font-family: FontAwesome;
	top: 0;
	left: 0;
	content: "\f1c3";
  color: #1a9923 !important;
}
@media screen and (max-width: 992px) {
  .detail #main01 .title {
    margin-bottom: 30px;
    font-size: 16px;
  }
  .detail #main01 .big_image {
    margin-bottom: 30px;
  }
  .detail #main01 .html {
    margin-bottom: 30px;
  }
  .detail #main01 .imgs {
    margin-bottom: 10px;
  }
  .detail #main01 .box-img {
    height: 200px;
  }
  .detail #main01 .box-img img {
    max-height: 200px;
  }
  .detail #main01 .files {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .detail #main01 .title {
    margin-bottom: 20px;
    font-size: 14px;
  }
  .detail #main01 .big_image {
    margin-bottom: 20px;
    height: auto;
  }
  .detail #main01 .big_image img {
    max-height: 300px;
  }
  .detail #main01 .html {
    margin-bottom: 20px;
  }
  .detail #main01 .imgs > div {
    margin-bottom: 20px;
  }
  .detail #main01 .box-img {
    height: auto;
  }
  .detail #main01 .box-img .box-img-inner {
    width: auto;
    top: 0;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
  .detail #main01 .box-img img {
    max-height: 200px;
  }
  .detail #main01 .box-img_comment {
    font-size: 12px;
  }
}
/*-----------------------------------------------------------------------------
sidebar
-----------------------------------------------------------------------------*/
.sidebar .category_tit {
  padding-bottom: 10px;
  text-align: center;
  line-height: 1;
  font-weight: bold;
  border-bottom: 2px solid #c00025;
}
.sidebar .category_list {
	margin-bottom: 50px;
}
.sidebar .category_list a {
	position: relative;
	display: block;
	padding: 10px 10px 10px 20px;
  color: #d4d4d4 !important;
	border-bottom: 1px solid #444;
	text-decoration: none;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
  line-height: 1.4;
}
.pc.sidebar .category_list a:hover {
  background-color: #444;
}
.sidebar .category_list a::after {
	content: "\f105";
	position: absolute;
	font-family: FontAwesome;
	top: 50%;
	left: 10px;
	margin-top: -0.8em;
	color: #c00025;
}
@media screen and (max-width: 767px) {
  .sidebar .category_tit {
    margin-top: 40px;
  }
  .sidebar .category_list {
    margin-bottom: 30px;
  }
  .sidebar .category_list:last-of-type {
    margin-bottom: 0;
  }
}
/*-----------------------------------------------------------------------------
product
-----------------------------------------------------------------------------*/
.product main * {
  word-wrap: break-word;
}
.product #main01 .box {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid #444;
}
.product #main01 .box:last-of-type {
  margin-bottom: 0;
}
.product #main01 .box .img {
  text-align: center;
}
.product #main01 .box .img img {
  max-width: 100%;
  max-height: 250px;
  height: auto;
}
.product #main01 .box .html {
  margin-bottom: 15px;
}
.product #main01 .paging {
  margin-top: 40px;
	text-align: center;
	line-height: 1;
}
.product #main01 .paging span.current,
.product #main01 .paging span.paging-text {
  margin: 0px 1px;
  color: #d4d4d4;
  border: 1px solid #666;
  zoom: 1;
  display: inline-block;
  overflow: hidden;
  text-decoration: none;
}
.product #main01 .paging span.paging-text a {
  padding: 8px;
  display: block;
  color: #d4d4d4;
  text-decoration: none;
}
.product #main01 .paging span.current {
  border: 1px solid #666;
  color: #c00025;
  zoom: 1;
  padding: 8px;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
}
.product #main01 .paging span.paging-text a:hover {
  color: #c00025 !important;
  text-decoration: none;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .product #main01 .box .img {
    margin-bottom: 15px;
  }
  .product #main01 .box {
    margin-bottom: 30px;
    padding-bottom: 30px;
  }
}
/*-----------------------------------------------------------------------------
about-us
-----------------------------------------------------------------------------*/
.about-us #main01 .well h3 {
  line-height: 1.6;
}
@media print {
  .about-us #main01 .well {
    margin-bottom: 200px !important;
  }
}
/*-----------------------------------------------------------------------------
company
-----------------------------------------------------------------------------*/
.company #main01 li {
  display: flex;
  margin: 0 0 5px;
  padding: 0;
}
.company #main01 li::before {
  content: '・';
  display: block;
}
.company .table {
  border-top: 1px solid #444 !important;
}
.company .table > tbody > tr > th,
.company .table > tbody > tr > td {
  vertical-align: middle;
  padding: 10px 15px;
  border: none !important;
  border-bottom: 1px solid #444 !important;
}
.company .table > tbody > tr > th {
  width: 20%;
  font-weight: normal;
  background-color: transparent;
  background-color: #222;
}
.company .g-maps {
  position: relative;
  padding-bottom: 35%;
  height: 0;
  overflow: hidden;
}
.company .g-maps iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}
.company #main03 li {
  display: flex;
  margin: 0 0 5px;
  padding: 0;
}
.company #main03 li::before {
  content: '・';
  display: block;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .company #main01 li {
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .company .table > tbody > tr > th {
    width: auto;
    border: none !important; 
    font-weight: bold;
  }
  .company .table > tbody > tr > td {
    padding: 0 0 10px;
  }
  .company .g-maps {
    padding-bottom: 75%;
  }
}
/*-----------------------------------------------------------------------------
contact 
-----------------------------------------------------------------------------*/
.contact #main01 .tel {
  line-height: 1;
}
.contact .form-horizontal .radio,
.contact .form-horizontal .checkbox,
.contact .form-horizontal .radio-inline,
.contact .form-horizontal .checkbox-inline {
  padding-top: 0;
}
.contact.tablet .form-horizontal .radio-inline::after,
.contact.tablet .form-horizontal .checkbox-inline::after {
  content: ".";
  width: 0;
  font-size: 0;
  color: transparent;
  margin-right: 1px;
}
.contact .form-horizontal {
  padding: 0 15px;
}
.contact .form-control {
  height: auto;
  padding: 10px;
  color: #d4d4d4;
  font-size: 16px;
  background-color: #222;
  border: 1px solid #666;
}
.form-horizontal .form-group {
  margin-bottom: 0;
  padding: 15px 0;
  border-top: 1px solid #555;
}
.form-horizontal .control-label {
  padding: 0 15px;
}
.contact .has-error .form-control {
  background-color: #faf5f5;
}
.contact .checkbox-inline,
.contact .radio-inline {
  margin-right: 20px;
}
.contact .checkbox-inline::after {
  content: ".";
  width: 0;
  font-size: 0;
  color: transparent;
  margin-right: 1px;
}
.contact .privacy_box {
  margin-top: 10px;
  padding: 20px;
  border: 2px solid #444;
}
.pc.contact button.btn i {
  -webkit-transition: all 0.6s ease-out;
  -ms-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
.pc.contact button.btn:hover i {
  -webkit-transform: translate(3px, 0);
  -ms-transform: translate(3px, 0);
  transform: translate(3px, 0);
}
.pc.contact button.btn.btn_back:hover i {
  -webkit-transform: translate(-3px, 0);
  -ms-transform: translate(-3px, 0);
  transform: translate(-3px, 0);
}
@media screen and (max-width: 767px) {
  .contact #main01 .tel.max-large {
    font-size: 26px;
  }
  .contact #main01 .tel img {
    width: 40px;
    height: auto;
  }
  .contact main .note {
    font-size: 12px;
  }
  .contact .form-horizontal {
    padding: 0;
  }
  .form-horizontal .form-group {
    padding: 10px 0;
    border-top: none;
  }
  .form-horizontal .control-label {
    padding: 0 15px 5px;
  }
  .contact .checkbox-inline,
  .contact .radio-inline {
    display: block;
    margin: 0;
  }
  .contact input,
  .contact textarea {
    font-size: 16px;
  }
  .contact .privacy_box {
    padding: 10px;
    font-size: 10px;
  }
  .contact .btn {
    width: 100%;
  }
}
@media screen and (max-width: 320px) {
  .contact main .note {
    font-size: 10px;
  }
}
/*-----------------------------------------------------------------------------
footer 
-----------------------------------------------------------------------------*/
#footer {
  line-height: 1;
  overflow: hidden;
  background: #222;
}
#footer .footer_inner {
  width: 100%;
  padding: 50px 0;
  font-size: 14px;
  line-height: 1;
}
#footer .footer_inner .row > div:nth-child(2) {
  border-right: 1px solid #d4d4d4;
}
#footer .logo {
  margin-bottom: 25px;
}
#footer .txt {
  margin-bottom: 5px;
  line-height: 1.4;
}
#footer .footer_menu {
  padding: 15px 0;
}
#footer .footer_menu-list li {
  margin-bottom: 10px;
}
#footer .footer_menu-list li a {
  position: relative;
  padding-left: 10px;
  color: #d4d4d4 !important;
  text-decoration: none;
  -webkit-transition: all 0.6s ease-out;
  transition: all 0.6s ease-out;
}
#footer .footer_menu-list li a::before {
  position: absolute;
	font-family: FontAwesome;
	top: 50%;
	left: 0;
  margin-top: -7px;
	color: #d4d4d4;
	content: "\f105";
}
.pc #footer .footer_menu-list li a:hover {
  color: #fff !important;
}
#footer .footer_inner .txt {
  line-height: 1.5;
}
#footer .footer_inner .txt .ctl {
  display: none;
}
#footer .footer_inner .button {
  text-align: right;
}
#footer .copyright {
  padding: 14px;
  font-size: 12px;
  text-align: center;
  background-color: #111;
  line-height: 1;
}
.back-top {
  display: none;
  position: fixed;
  right: 20px;
  bottom: 20px;
  cursor: pointer;
  margin: 0;
  z-index: 50;
}
.back-top img {
  -webkit-transition: opacity 0.6s ease-out;
  -moz-transition: opacity 0.6s ease-out;
  transition: opacity 0.6s ease-out;
}
body.pc .back-top img:hover {
  -webkit-opacity: 0.6;
  -moz-opacity: 0.6;
  opacity: 0.6;
}
@media screen and (max-width: 991px) {
  #footer .footer_inner .txt {
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
  #footer .footer_inner {
    padding: 30px 0;
  }
  #footer .footer_inner .row > div:nth-child(2) {
    border-right: none;
  }
  #footer .logo {
    margin-bottom: 15px;
    text-align: center;
  }
  #footer .logo img {
    width: 75%;
    height: auto;
  }
  #footer .footer_inner .txt {
    font-size: 14px;
  }
  #footer .footer_menu {
    margin: 0 0 20px;
    padding: 0;
  }
  #footer .footer_menu-list {
    width: 100%;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
  }
  #footer .footer_menu-list li {
    padding: 0 !important;
  }
  #footer .footer_menu-list li {
    width: 50%;
    margin: 0;
    padding: 0;
  }
  #footer .footer_menu-list li a {
    display: block;
    padding: 15px 10px 15px 15px;
    font-size: 14px;
  }
  #footer .footer_inner .txt {
    text-align: center;
    line-height: 1.8;
  }
  #footer .footer_inner .txt a {
    color: #fff !important;
  }
  #footer .footer_inner .bnr {
    margin-bottom: 30px;
    text-align: center;
  }
  #footer .footer_inner .bnr a.btn {
    padding: 20px 0;
  }
  #footer .copyright {
    padding-bottom: 30px;
    font-size: 11px;
    text-align: center;
  }
  .back-top {
    width: 30px;
    right: 15px;
    bottom: 20px;
  }
}
@media print {
  .back-top {
    display: none !important;
  }
}