@charset "UTF-8";
@import url(reset.css);
@import url(common.css);
/*** function ***/
/* ###################### */
/* ######## 変数 ######## */
/* ###################### */
/* カラー */
/* 書式 */
/* ###################### */
/* ######## 関数 ######## */
/* ###################### */
/* ###################### */
/* ######## 共通 ######## */
/* ###################### */
/* ボタン */
.btn {
  box-sizing: content-box;
}
.btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
}

/*******/
html {
  /* 1rem = 10px にする*/
  font-size: 62.5%;
  _font-size: 62.5%;
  *font-size: 62.5%;
  /*ウェブフォント用*/
  text-rendering: optimizeLegibility;
}

.face_book .fbcomments,
.face_book iframe,
.face_book .fb_iframe_widget,
.face_book .fb_iframe_widget[style],
.face_book .fb_iframe_widget iframe[style],
.face_book .fbcomments iframe[style],
.face_book .fb_iframe_widget span,
.face_book ._2p3a {
  width: 100% !important;
}

#wrapper {
  overflow: hidden;
}

/********共通********/
.cont {
  margin: 0 auto;
}

.ofi img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  font-family: "object-fit: cover; object-position: center;";
}

.fle {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.tel a {
  text-decoration: none;
  color: #3a3a3a;
}

.table table {
  width: 100%;
}
.table table tr th {
  box-sizing: border-box;
}
.table table tr td {
  box-sizing: border-box;
}

.h2_1 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #0d185b;
  letter-spacing: 0;
  line-height: 1;
}

/*********company***********/
.company .contents1 .text p:last-of-type {
  margin-bottom: 0;
}
.company .contents2 {
  padding-bottom: 0;
}
.company .contents2 .table th {
  background: #0d185b;
  color: #fff;
}
.company .contents2 .table td {
  background: #fff;
}
.company .contents2 .map iframe {
  width: 100%;
  height: 100%;
}

/*********about***********/
.about .bread {
  background: #fff;
}
.about .contents1 {
  background: #fff;
}
.about .contents1 .box h3 {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
}
.about .contents1 .box h3 div {
  border-bottom: solid 1px #adadad;
}
.about .contents1 .box ul li {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.about .contents1 .box ul li:last-of-type {
  margin-bottom: 0;
}
.about .contents1 .box ul li::before {
  content: "";
  display: inline-block;
  background: url(../image/about/con01-check.png) no-repeat center/contain;
}
.about .contents1 .box ul li span {
  display: inline-block;
}
.about .contents2 {
  padding-top: 0;
}
.about .contents2 .ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #0d185b;
  position: relative;
  z-index: 0;
}
.about .contents2 .ttl::after {
  content: "";
  width: 0;
  height: 0;
  border: solid transparent;
  border-top: solid #0d185b;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: calc(100% - 1px);
}
.about .contents2 .ttl h2 {
  color: #fff;
  font-weight: 400;
}
.about .contents2 .txt p:last-of-type {
  margin-bottom: 0;
}
.about .contents2 .list {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}
.about .contents2 .list li {
  background: #fff;
  box-sizing: border-box;
  border: solid 1px #3a3a3a;
  text-align: center;
  line-height: 1;
}
.about .contents3 .list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
.about .contents3 .list figure figcaption {
  text-align: center;
  line-height: 1;
  font-weight: 600;
}
.about .contents4 .list ul li {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.about .contents4 .list ul li:last-of-type {
  margin-bottom: 0;
}
.about .contents4 .list ul li::before {
  content: "";
  display: inline-block;
  background: url(../image/about/con04-check.png) no-repeat center/contain;
}
.about .contents4 .list ul li span {
  display: inline-block;
}
/*********feature***********/
.feature .contents1 .box:last-of-type {
  margin-bottom: 0;
}
.feature .contents1 .box .text h3 {
  font-size: 1rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
  position: relative;
  z-index: 0;
}
.feature .contents1 .box .text h3 .num {
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  color: #fff;
  background: url(../image/feature/con01-num-bg.png) no-repeat center/contain;
  box-sizing: border-box;
}
.feature .contents1 .box .text h3 div {
  border-bottom: solid 1px #adadad;
}
.feature .contents1 .box .text .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background: #0d185b;
  color: #fff;
  text-decoration: none;
  transition: all 0.3s;
  position: relative;
  z-index: 0;
}
.feature .contents1 .box .text .btn a::before {
  content: "";
  display: inline-block;
  background: url(../image/common/ig-icon.png) no-repeat center/contain;
}
.feature .contents1 .box .text .btn a::after {
  content: "";
  background: url(../image/common/btn-arrow.png) no-repeat center/contain;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.feature .contents1 .box .text .btn a:hover {
  text-decoration: none;
  background: #3a3a3a;
}

/*********corporate***********/
.corporate .contents1 .worksArea h3 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
}
.corporate .contents1 .worksArea .list .box dl dt {
  font-weight: 700;
  line-height: 1;
}
.corporate .contents2 .flow-list {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
}
.corporate .contents2 .flow-list .box figure {
  background: #e3e3e3;
  box-sizing: border-box;
  text-align: center;
}
.corporate .contents2 .flow-list .box figure figcaption .br {
  display: inline-block;
}

/*********individual***********/
.individual .contents1 .box dl dt {
  line-height: 1;
  font-weight: 600;
}
.individual .contents1 .list {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
}
.individual .contents1 .list.bg {
  background: #f3f3f3;
}
.individual .contents2 .box {
  background: #fff;
  box-sizing: border-box;
  border: solid 1px #0d185b;
}
.individual .contents2 .box:last-of-type {
  margin-bottom: 0;
}
.individual .contents2 .box .text {
  box-sizing: border-box;
}
.individual .contents2 .box .text h3 {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
}
.individual .contents3 .flow-list {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
}
.individual .contents3 .flow-list .box figure {
  background: #e3e3e3;
  box-sizing: border-box;
  text-align: center;
}
.individual .contents3 .flow-list .box figure figcaption .br {
  display: inline-block;
}

/*********index***********/
.index .contents1 {
  background: #fff;
  border-bottom: solid 2px #563116;
}
.index .contents1 .styled-dl01 dl {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
}
.index .contents1 .styled-dl01 dl:last-of-type {
  margin-bottom: 0;
}
.index .contents1 .styled-dl01 dl dt {
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1;
}
.index .contents1 .sns-link {
  display: flex;
  justify-content: center;
  align-items: center;
}
.index .contents1 .sns-link li {
  display: flex;
  justify-content: center;
  align-items: center;
}
.index .contents1 .sns-link li a {
  transition: all 0.3s;
}
.index .contents1 .sns-link li a:hover {
  opacity: 0.72;
}
.index .contents2 {
  border-top: solid #d4d4d4;
  background: url(../image/index/about-bg.png);
}
.index .contents2 h2 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #0d185b;
  letter-spacing: 0;
  line-height: 1;
  position: relative;
  z-index: 0;
}
.index .contents2 h2::before {
  content: "";
  background: url(../image/index/about-en.png) no-repeat top left/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  z-index: -1;
}
.index .contents2 h2 .min {
  display: block;
}
.index .contents3 .gallery .galleryswiper {
  overflow: hidden;
}
.index .contents3 .gallery li a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 0;
}
.index .contents3 .gallery li a::after {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../image/index/slide-hover-img.png) no-repeat center;
  background-color: rgba(13, 24, 91, 0.4);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  opacity: 0;
  transition: all 0.3s;
}
.index .contents3 .gallery li a:hover::after {
  opacity: 1;
}
.index .contents3 .gallery li a img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.index .contents4 .tab_wrp {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.index .contents4 .tab_wrp li {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #d4d4d4;
  border: solid 1px #5d67a8;
  border-bottom: none;
  color: rgba(13, 24, 91, 0.71);
  cursor: pointer;
  margin-left: -1px;
  position: relative;
  z-index: 0;
}
.index .contents4 .tab_wrp li:first-of-type {
  margin-left: 0;
}
.index .contents4 .tab_wrp li::after {
  content: "";
  width: 100%;
  height: 4px;
  background: #9b5e32;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.index .contents4 .tab_wrp li.current {
  background: #fff;
  border-color: #0d185b;
  color: #0d185b;
  z-index: 1;
}
.index .contents4 .tab_wrp li.current::after {
  background: #563116;
}
.index .contents4 .tab_txt {
  border: solid 1px #0d185b;
  background: #f6f6f6;
  box-sizing: border-box;
}
.index .contents4 .tab_txt .button-list {
  display: flex;
  justify-content: center;
  align-items: center;
  color: #3b2416;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}
.index .contents4 .tab_txt .button-list a {
  color: #3b2416;
  text-decoration: none;
}
.index .contents4 .tab_txt .listBox {
  box-sizing: border-box;
}
.index .contents4 .tab_txt .listBox .inBox {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  border-bottom: dotted 1px #bfbfbf;
}
.index .contents4 .bnrs {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.index .contents4 .bnrs li a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  transition: all 0.3s;
  position: relative;
  z-index: 0;
}
.index .contents4 .bnrs li a::before {
  content: "";
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  box-sizing: border-box;
  border: solid 1px #fff;
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: -1;
}
.index .contents4 .bnrs li a div {
  position: relative;
  z-index: 0;
}
.index .contents4 .bnrs li a div::before {
  content: "";
  position: absolute;
  z-index: 1;
}
.index .contents4 .bnrs li a:hover {
  text-decoration: none;
  background: rgba(13, 24, 91, 0.4);
}
.index .contents4 .bnrs li:nth-of-type(1) {
  background: url(../image/index/bnr-img1.png) no-repeat center/cover;
}
.index .contents4 .bnrs li:nth-of-type(1) div::before {
  background: url(../image/index/bnr-en1.png) no-repeat center/contain;
}
.index .contents4 .bnrs li:nth-of-type(2) {
  background: url(../image/index/bnr-img2.png) no-repeat center top/cover;
}
.index .contents4 .bnrs li:nth-of-type(2) div::before {
  background: url(../image/index/bnr-en2.png) no-repeat center/contain;
}
.index .contents5 {
  text-align: center;
}
.index .contents6 {
  background: url(../image/index/news-bg.png) no-repeat center/cover;
}
.index .contents6 .box {
  background: #fff;
  box-sizing: border-box;
}
.index .contents6 .ttl {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
  z-index: 0;
}
.index .contents6 .ttl::after {
  content: "";
  width: 100%;
  box-sizing: border-box;
  border-top: solid 1px #5d67a8;
  border-bottom: solid 1px #5d67a8;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
}
.index .contents6 .ttl h2 {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #0d185b;
  letter-spacing: 0;
  line-height: 1;
  position: relative;
  z-index: 0;
}
.index .contents6 .ttl h2::before {
  content: "";
  background: url(../image/index/news-en.png) no-repeat center left/contain;
  position: absolute;
  z-index: -1;
}
.index .contents6 .ttl .btn {
  width: 105px;
  height: 30px;
}
.index .contents6 .ttl .btn a {
  padding-left: 5px;
  background: #0d185b;
  border-radius: 15px;
  font-size: 1.3rem;
  color: #fff;
  line-height: 1;
  text-decoration: none;
  transition: all 0.3s;
}
.index .contents6 .ttl .btn a::after {
  content: "";
  display: inline-block;
  background: url(../image/index/news-link-arrow.png) no-repeat center/contain;
  width: 5px;
  height: 8px;
  margin-left: 4px;
}
.index .contents6 .ttl .btn a:hover {
  text-decoration: none;
  background: #3a3a3a;
}
.index .contents6 .list .sc {
  overflow-y: auto;
}
.index .contents6 .list .sc dl {
  border-bottom: dotted 1px #3b2416;
}
.index .contents6 .list .sc dl a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-decoration: none;
  box-sizing: border-box;
  color: #3a3a3a;
  transition: all 0.3s;
}
.index .contents6 .list .sc dl a:hover {
  text-decoration: none;
  background: rgba(13, 24, 91, 0.16);
}
.index .contents6 .list .sc dl dd {
  display: block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.index .contents7 {
  background: #fff;
}
.index .contents7 h2 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #0d185b;
  letter-spacing: 0;
  line-height: 1;
  position: relative;
  z-index: 0;
}
.index .contents7 h2::before {
  content: "";
  background: url(../image/index/company-en.png) no-repeat center left/contain;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
.index .contents7 .map {
  background: #f6f6f6;
}
.index .contents7 .map iframe {
  width: 100%;
  height: 100%;
}
.index .contents7 .table tr {
  border-bottom: dotted 1px #3b2416;
}
.index .contents7 .table th {
  font-weight: 600;
}

/****エラーページ*****/
.error .contents1 {
  overflow: hidden;
}
.error .contents1 a {
  color: #3a3a3a;
}
.error .contents1 a:hover {
  text-decoration: underline;
}

/*==================================================
プライバシーポリシー
================================================== */
.privacy .contents1 .h3_1 {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #3a3a3a;
}
.privacy .contents1 .item-box:last-child {
  margin-bottom: 0;
}

/*==================================================
 サイトマップ
================================================== */
.site .contents1 .site_list {
  margin: 0 auto;
}
.site .contents1 .site_list ul {
  background: #fff;
  border: solid 1px #0d185b;
}
.site .contents1 .site_list ul li {
  border-bottom: solid 1px #0d185b;
}
.site .contents1 .site_list ul li:last-of-type {
  border-bottom: none;
}
.site .contents1 .site_list ul li a {
  display: block;
  font-weight: 600;
  color: #3a3a3a;
  text-decoration: none;
  transition: all 0.3s;
}
.site .contents1 .site_list ul li a:hover {
  text-decoration: none;
  color: #0d185b;
}

/*==================================================
 ニュース
================================================== */
.news .contents1 {
  overflow: hidden;
}
.news .contents1 img {
  max-width: 100%;
}
.news .contents1 .list-box dl {
  background: #fff;
  border: solid 1px #0d185b;
}
.news .contents1 .list-box dl:last-of-type {
  margin-bottom: 0;
}
.news .contents1 .list-box dl a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-decoration: none;
  box-sizing: border-box;
  color: #3a3a3a;
  transition: all 0.3s;
}
.news .contents1 .list-box dl a:hover {
  text-decoration: none;
  background: rgba(13, 24, 91, 0.16);
}
.news .contents1 .list-box dl dd {
  display: block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

/*==================================================
 news詳細
================================================== */
.news_detail .contents1 {
  overflow: hidden;
}
.news_detail .contents1 .sec1 {
  margin: 0 auto;
}
.news_detail .contents1 .sec1 img {
  max-width: 100%;
}
.news_detail .contents1 .sec1 .h3_1 {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  color: #3a3a3a;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: solid 1px #3a3a3a;
}
.news_detail .contents1 .sec1 .post-data {
  text-align: right;
}
.news_detail .contents1 .sec1 .item-box {
  min-height: 230px;
  background: #fff;
  border: solid 1px #0d185b;
  box-sizing: border-box;
  zoom: 1;
}

/*==================================================
 お問い合わせ
================================================== */
.contact .contents1 .table th {
  background: #0d185b;
  color: #fff;
}
.contact .contents1 .table td {
  background: #fff;
}
.contact .contents1 .table td input[type=radio],
.contact .contents1 .table td input[type=checkbox] {
  display: none;
}
.contact .contents1 .table td input[type=radio] + label,
.contact .contents1 .table td input[type=checkbox] + label {
  display: inline-block;
  color: #3a3a3a;
  position: relative;
  z-index: 0;
}
.contact .contents1 .table td input[type=radio] + label:before,
.contact .contents1 .table td input[type=checkbox] + label:before {
  content: "";
  width: 10px;
  height: 10px;
  box-sizing: border-box;
  border: solid 1px #a0a0a0;
  border-radius: 3px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
}
.contact .contents1 .table td input[type=radio] + label:after,
.contact .contents1 .table td input[type=checkbox] + label:after {
  content: "";
  border-right: solid 2px #3a3a3a;
  border-bottom: solid 2px #3a3a3a;
  position: absolute;
  left: 3px;
  transform: rotate(45deg);
  opacity: 0;
}
.contact .contents1 .table td input[type=radio] + label:last-of-type,
.contact .contents1 .table td input[type=checkbox] + label:last-of-type {
  margin-right: 0;
}
.contact .contents1 .table td input[type=radio]:checked + label:after,
.contact .contents1 .table td input[type=checkbox]:checked + label:after {
  opacity: 1;
}

/* input設定 */
.input-mid {
  width: 60%;
  padding: 4px;
  box-sizing: border-box;
}

.input-min {
  padding: 4px;
  box-sizing: border-box;
}

.input-big {
  padding: 4px;
  box-sizing: border-box;
  width: 100%;
}

.contact form input {
  border: none;
  background: #f6f6f6;
  font-family: "Noto Sans JP", sans-serif;
}
.contact form textarea {
  display: block;
  width: 100%;
  padding: 4px;
  box-sizing: border-box;
  border: none;
  background: #f6f6f6;
  font-family: "Noto Sans JP", sans-serif;
}
.contact .clrred {
  color: #c00;
}
.contact .contact-recaptcha-wrap {
  text-align: center;
  margin: 0 auto;
  width: 304px;
}
.contact .contact-recaptcha-wrap input {
  text-align: center;
}

.mt5 {
  margin-top: 5px;
}

/* 必須マーク
-------------------------------------------------- */
.required-mark {
  display: inline-block;
  color: #fff;
  font-size: 1.2rem;
  line-height: 1;
}

/* 未記入エラー文
-------------------------------------------------- */
.error-text {
  margin: 0 0 5px;
  color: #f00;
}

/* 確認、バック、送信ボタン
-------------------------------------------------- */
.contact .contact-submits {
  text-align: center;
}
.contact .contact-submits input,
.contact .contact-submits button {
  display: inline-block;
  border: none;
  background: #0d185b;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  transition: all 0.3s;
}
.contact .contact-submits input:hover,
.contact .contact-submits button:hover {
  background: #3a3a3a;
  cursor: pointer;
}
.contact .contact-submits-wrap {
  text-align: center;
  margin: 0 auto;
}
.contact .contact-submits-wrap input {
  display: inline-block;
  border: none;
  background: #0d185b;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  transition: all 0.3s;
}
.contact .contact-submits-wrap input:hover {
  background: #3a3a3a;
  cursor: pointer;
}
.contact .contact-submits-wrap input:disabled {
  border-color: #aaa;
  background: #aaa;
  color: #fff;
}
.contact .contact-submits-wrap input:disabled:hover {
  background: #aaa;
  color: #fff;
  cursor: default;
}

/* セキュリティエラー
-------------------------------------------------- */
.sec-error-text {
  line-height: 50px;
  text-align: center;
  color: #f00;
  font-size: 16px;
  border: 2px solid #f00;
}

/*IEハック*/
@media screen\0  {
  /**ここに書く**/
}