@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: #333;
	font-size: 15px;
  line-height: 1.8;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
  letter-spacing: 0.05em;
}
.serif {
	font-family: "Roboto Slab" , Garamond , "Times New Roman" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , YuMincho,	'Yu Mincho', "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
}
.ltsn {
  letter-spacing: normal;
}
strong {
	font-weight: bold;
}
.x-small { font-size: 11px; line-height: 1.6; }
.small { font-size: 13px; line-height: 1.6; }
.middle { font-size: 15px; }
.large { font-size: 17px; }
.x-large { font-size: 19px; }
.x2-large { font-size: 21px; }
.x3-large { font-size: 23px; }
.x4-large { font-size: 25px; }
.x5-large { font-size: 27px; }
.max-large { font-size: 50px; }
.italic {
	font-style: italic;
}
img {
	vertical-align: bottom;
	border: none;
}
img.frame {
	padding: 8px;
	background-color: #fff;
	border: 1px solid #eee;
	-webkit-box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.15);
	-moz-box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.15);
	box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.15);
}
.white { color: #ffffff; }
.red { color: #a00; }
.blue { color: #004a88; }
.lblue { color: #4da5e4; }
.purple { color: #c27dbc; }
.orange { color: #c60; }
.green { color: #8fc320; }
.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; }
.pad20 { padding: 20px; }
.pr05 { padding-right: 5px !important; }
.pr10 { padding-right: 10px !important; }
.pr20 { padding-right: 20px !important; }
.pl05 { padding-left: 5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !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%; }
.w90 { width: 90%; }
.w100 { width: 100%; }
a {
	font-size: 100%;
	vertical-align: baseline;
}
a:link {
	color: #004a88 !important;
	text-decoration: underline;
}
a:visited {
	color: #004a88 !important;
	text-decoration: underline;
}
a:hover {
	color: #004a88 !important;
	text-decoration: none;
}
a:active {
	color: #004a88 !important;
	text-decoration:none;
}
a:focus {
	color: #004a88 !important;
	text-decoration:none;
}
.pc a.opacity {
	-webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.pc a.opacity:hover {
	-webkit-opacity: 0.6;
	opacity: 0.6;
}
a.opacity img {
	box-shadow: #000 0 0 0;
}
.indent {
	padding-left: 1.1em;
	text-indent: -1.1em;
}
.indent span.icon {
  display: inline-block;
  width: 1.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: #bb2525;
}
.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 {
	display: inline-block;
	padding: 18px 150px;
	line-height: 1;
	color: #fff !important;
  font-size: 20px;
	text-decoration: none;
	text-align: center;
	background: #004a88;
	-webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
  border: none;
  border-radius: 0;
}
a.btn.line {
	color: #004a88 !important;
	background-color: transparent;
	border: 2px solid #004a88;
}
.pc a.btn.line:hover {
  color: #fff !important;
  background-color: #004a88;
}
a.btn.line_white {
	color: #fff !important;
	background-color: transparent;
	border: 2px solid #fff;
}
.pc a.btn.line_white:hover {
  color: #333 !important;
  background-color: #fff;
}
/*-----------------------------------------------------------------------------
common
-----------------------------------------------------------------------------*/
.container {
  max-width: none !important;
  width: 1000px;
}
.page-ttl {
  position: relative;
	display: table;
	width: 100%;
	height: 300px;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
}
.company .page-ttl {
	background-image: url(../images/company_title_bg.jpg);
}
.about .page-ttl {
	background-image: url(../images/about_title_bg.jpg);
}
.service .page-ttl {
	background-image: url(../images/service_title_bg.jpg);
}
.contact .page-ttl {
	background-image: url(../images/contact_title_bg.jpg);
}
.page-ttl h2 {
  position: relative;
	display: table-cell;
	color: #fff;
	font-size: 40px;
	line-height: 1;
	text-align: center;
	vertical-align: middle;
  letter-spacing: 0.1em;
}
.page-ttl h2 .en {
	display: block;
	margin-top: 10px;
	font-size: 50%;
}
.headline {
  text-align: center;
}
.headline span {
  display: inline-block;
  padding: 10px 0 10px 60px;
  color: #004a88;
	font-size: 27px;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  background: url(../images/headline_bg.png) 0 center no-repeat;
}
.headline.white span {
  color: #fff;
  background: url(../images/headline_w_bg.png) 0 center no-repeat;
}
.headline h3 {
  font-weight: bold;
}
.headline01 {
	padding: 12px 10px 10px;
	font-size: 3.2rem;
	line-height: 1.2;
}
.headline01 > span {
	font-size: 1.5rem;
	color: #666;
}
.headline02 {
	font-size: 2.2rem;
	line-height: 1.2;
}
.headline03 {
	font-size: 1.8rem;
	line-height: 1.2;
}
.headline-ll {
	padding: 5px 0 5px 0.4em;
	border-left: 5px solid #2f559e;
}
.common_box {
	display: inline-block;
	padding: 15px 30px;
	background-color: #f1f1f1;
	border: 1px solid #DDD;
}
table.normal {
	width: 100%;
	border-collapse: collapse;
	border-top: 1px solid #ddd;
}
table.normal th {
	padding: 10px;
	text-align: left;
	font-weight: bold;
	border: 1px solid #ddd;
	background-color: #f5f5f5;
	white-space: nowrap;
	vertical-align: top;
}
table.normal td {
	padding: 10px;
	border: 1px solid #ddd;
}
table.table th {
  background-color: #f5f5f5;
}
.cols-left {
	float: left;
}
.cols-right {
	float: right;
}
ul.normal {
	list-style-type: square;
}
ul.normal li {
	margin: 0 0 5px 17px;
  padding-bottom: 5px;
	list-style-type: square;
  border-bottom: 1px solid #ddd;
}
ol.normal {
	list-style-type: decimal;
}
ol.normal li {
	margin: 0 0 0 22px;
	list-style-type: decimal;
}
.breadcrumb-box {
	width: 100%;
  margin-bottom: 30px;
	padding: 20px 0;
	list-style: none;
	font-size: 1.2rem;
	background-color: #f2ebdc;
	border-radius: 0;
  border-top: 1px solid #fff;
}
.breadcrumb-list {
	width: 1000px;
	margin: auto;
}
.breadcrumb-list > li {
	display: inline-block;
}
.breadcrumb-list > li + li:before {
	padding: 0 5px;
	color: #ccc;
	content: "/\00a0";
}
.breadcrumb-list > .active {
	color: #555;
}
article {
	
}
.common_inner {
	padding: 50px 0;
	overflow: hidden;
}
main section:first-of-type .common_inner {
	padding-top: 75px;
}
main section:last-of-type .common_inner {
	padding-bottom: 100px;
}
sup {
  font-size: 80%;
  vertical-align: text-top;
}
/*-----------------------------------------------------------------------------
header
-----------------------------------------------------------------------------*/
.main_header {
	width: 100%;
  height: 90px;
  line-height: 1;
}
.main_header h1 {
  padding: 22px 0;
}
.main_nav > ul {
  width: 100%;
	overflow: hidden;
}
.main_nav {
  padding-left: 20px;
}
.main_nav > ul > li {
  position: relative;
  width: 20%;
	float: left;
}
.main_nav > ul > li::before {
	position: absolute;
  content: '';
  width: 100%;
  height: 0;
  bottom: 0;
  left: 0;
  background-color: #fff;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
  z-index: 5;
}
.pc .main_nav > ul > li:hover::before,
.main_nav > ul > li.cr::before {
  height: 100%;
  background-color: #004a88;
}
.main_nav > ul > li > a {
  position: relative;
  display: block;
  width: 100%;
  height: 90px;
  padding-top: 27px;
  color: #333 !important;
  font-size: 15px;
  text-decoration: none !important;
  text-align: center;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
  z-index: 10;
}
.main_nav > ul > li > a span {
  display: block;
  margin-top: 5px;
  font-size: 12px;
}
.pc .main_nav > ul > li > a:hover,
.main_nav > ul > li.cr > a {
  color: #fff !important;
}
/*-----------------------------------------------------------------------------
home
-----------------------------------------------------------------------------*/
.home #main00 {
  position: relative;
  width: 100%;
}
.home #main00 .flexslider {
	width: 100%;
	height: 50vw;
	position: relative;
	overflow: hidden;
  margin: 0 auto;
}
.home.pc #main00 .flexslider {
  height: -webkit-calc(100vh - 90px);
	height: calc(100vh - 90px);
}
@media print { 
  .home #main00 .flexslider,
  .home.pc #main00 .flexslider {
    height: 60vw;
  }
}
.home #main00 .flexslider .slides {
  width: 100%;
  height: 100%;
}
.home #main00 .flexslider .slides li {
  width: 100%;
  height: 100%;
  background: url(../images/main1.jpg) center center no-repeat;
  background-size: cover;
}
.home #main00 .flexslider .slides li:nth-child(2) {
  background: url(../images/main2.jpg) center center no-repeat;
  background-size: cover;
}
.home #main00 .flexslider .slides li:nth-child(3) {
  background: url(../images/main3.jpg) center center no-repeat;
  background-size: cover;
}
.home #main00 .outer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  z-index: 100;
}
.home #main00 .outer .inner {
  position: absolute;
  width: 1000px;
  top: 50%;
  left: 50%;
  margin-left: -500px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.home #main00 .inner h2 {
  margin-bottom: 50px;
}
.home.pc #main00 .inner h2 {
  margin-bottom: 150px;
}
.home #main00 .inner a.btn {
  padding-right: 45px;
  padding-left: 45px;
  font-size: 18px;
}
.home #main01 {
  position: relative;
  width: 100%;
  padding: 90px 0;
}
.home #main02 {
  width: 100%;
  padding: 90px 0 110px;
  line-height: 1;
  background: url(../images/index_main02_bg.png) center 0 no-repeat;
}
.home #main03 {
  position: relative;
  width: 100%;
  padding: 100px 0 60px;
  line-height: 1;
  background: url(../images/index_main03_bg.png) center 0 no-repeat;
}
.home #main03::before {
  position: absolute;
  content: '';
  top: 38px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #004a88;
}
.home #main03 .topix {
  max-height: 290px;
  overflow: auto;
}
.home #main03 .topix dt {
  padding-top: 30px;
  float: left;
  font-weight: normal;
}
.home #main03 .topix dt .new {
  display: inline-block;
  margin-left: 10px;
  font-size: 13px;
  color: #880020;
}
.home #main03 .topix dd {
  min-height: 82px;
	padding: 30px 0 30px 185px;
	border-bottom: 1px dotted #aaa;
}
/*-----------------------------------------------------------------------------
about, service, company
-----------------------------------------------------------------------------*/
.about #main02,
.service #main02,
.company #main02 {
  background: #f5f5f5;
}
/*-----------------------------------------------------------------------------
company
-----------------------------------------------------------------------------*/
.company main iframe {
	padding: 4px;
	border: 1px solid #ddd;
}
/*-----------------------------------------------------------------------------
contact
-----------------------------------------------------------------------------*/
.contact .well {
  line-height: 1;
}
.contact .forms {
	padding: 50px 100px;
	border: 10px solid #f5f5f5;
	border-radius: 0;
  background-color: #fff;
}
.contact.mobile .forms {
  padding: 25px;
  border: 5px solid #f5f5f5;
}
.contact label {
  display: block;
  margin-bottom: 5px;
}
.contact label span {
  font-weight: normal;
}
.contact .radios label,
.contact .checks label {
  font-size: 16px;
  font-weight: normal;
	display: inline-block;
	margin-right: 30px;
  margin-left: 5px;
}
.contact .form-control {
  height: inherit;
  padding: 15px;
  font-size: 18px;
  border: 3px solid #eee;
}
.contact .form-control:focus {
  border: 3px solid #004a88;
}
.contact .panel-body {
  padding: 0;
}
.contact .privacy_box {
  height: 300px;
  padding: 15px;
	font-size: 12px;
	overflow: auto;
}
.contact button.btn_submit {
	position: relative;
	background-color: #004a88;
	border-radius: 50px;
	cursor: pointer;
	font-size: 20px;
	letter-spacing: 1px;
	padding: 10px 70px;
	border: none;
  color: #fff;
	text-align: center;
	text-decoration: none;
	-webkit-transition: opacity 0.6s ease-out;
	transition: opacity 0.6s ease-out;
}
.contact button.btn_submit i {
	-webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.contact button.btn_submit:hover {
	-webkit-opacity: 0.6;
	opacity: 0.6;
}
.contact button.btn_submit:hover i {
	-webkit-transform: translateX(5px);
	transform: translateX(5px);
}
.contact button.btn_submit.btn_back:hover i {
	-webkit-transform: translateX(-5px);
	transform: translateX(-5px);
}
/*-----------------------------------------------------------------------------
footer 
-----------------------------------------------------------------------------*/
.main_footer {
  width: 100%;
  line-height: 1;
}
.main_footer .inner {
  padding: 10px 0;
  color: #fff;
  font-size: 15px;
  background-color: #004a88;
  text-align: center;
}
.main_footer .inner ul {
  display: inline-block;
	overflow: hidden;
}
.main_footer .inner ul > li {
  position: relative;
	float: left;
  padding: 0 20px;
}
.main_footer .inner ul > li:first-of-type {
  padding-left: 0;
}
.main_footer .inner ul > li::after {
	position: absolute;
  content: '';
  top: -1px;
  right: 0;
  width: 1px;
  height: 17px;
  background-color: #fff;
}
.main_footer .inner ul > li:last-of-type::after {
  display: none;
}
.main_footer .inner ul > li > a {
  position: relative;
  display: inline-block;
  color: #fff !important;
  font-size: 15px;
  text-decoration: none !important;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.pc .main_footer .inner ul > li > a:hover {
  -webkit-opacity: 0.8;
	opacity: 0.8;
}
.main_footer .logo {
  padding: 30px 0;
}
.main_footer .tel {
  margin-bottom: 20px;
  padding-top: 30px;
  font-size: 24px;
  text-align: right;
}
.main_footer .tel .fax {
  display: inline-block;
  margin-left: 20px;
}
.main_footer .txt {
  margin-bottom: 12px;
  font-size: 14px;
  text-align: right;
}
.main_footer .copyright {
  padding-bottom: 30px;
  font-size: 14px;
  text-align: right;
}
.back-top {
	position: fixed;
	display: none;
	right: 20px;
  bottom: 20px;
  width: 55px;
  height: 55px;
  line-height: 1;
  z-index: 999;
  background-color: #2D2D2D;
  cursor: pointer;
  text-align: center;
  -webkit-transition: all 0.6s ease-out;
	transition: all 0.6s ease-out;
}
.back-top i {
  display: inline-block;
  padding-top: 3px;
	color: #fff;
  font-size: 44px;
}
body.pc .back-top:hover {
	-webkit-opacity: 0.6;
	opacity: 0.6;
}