@charset "UTF-8";
h1, ul {
  margin: 0;
  padding: 0;
  font-size: 100%;
  font-weight: normal;
}

/* !Header
---------------------------------------------------------- */
#header-box .index-wrapper {
  height: 80px;
  top: 0;
  left: 0;
  width: 100%;
  background: #FFF;
}

#header-top {
  border-bottom: solid 14px #013567;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  background: #fff;
}
#header-top img {
  border: none;
  line-height: 0;
  vertical-align: 0;
  width: 227px;
  padding-top: 1.2%;
}
#header-top .index-wrapper {
  position: relative;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 1280px;
  font-size: 14px;
}
#header-top a {
  color: #4a4a4a;
  transition: opacity 0.3s;
  text-decoration: none;
}
#header-top a:hover {
  opacity: 0.7;
}
#header-top .logo {
  padding-top: 4px;
}
#header-top .text_area {
  padding-top: 5px;
  line-height: 1.4;
  text-align: right;
}

/* !Footer
---------------------------------------------------------- */
#footer-box {
  width: 100%;
  background-color: #013567;
  font-size: 11px;
  color: #fff;
}

.footer-content {
  width: 1056px;
  margin: auto;
  padding: 50px 0px 20px 0px;
}

.footer-block {
  display: inline-block;
}

.footer-left {
  width: 350px;
  margin: auto;
  text-align: left;
  float: left;
}

.footer-left-img {
  padding: 20px 0px 20px 0px;
}

.footer-left-corp {
  padding: 10px 0px 10px 0px;
  font-size: 16px;
  letter-spacing: -1px;
}
.footer-left-corp a {
  color: #FFF;
}

.footer-left-copy, .footer-left-address {
  padding: 5px 0px 5px 0px;
  font-size: 16px;
  letter-spacing: -1px;
}

.footer-right {
  width: 706px;
  margin: auto;
  text-align: left;
  float: left;
}

.footer-case-title {
  margin: auto;
  text-align: center;
  font-size: 28px;
  font-weight: bold;
  padding: 5px 0px 10px 0px;
}

.footer-case-box {
  margin: auto;
  text-align: center;
  font-size: 15px;
  padding: 15px 0px 40px 0px;
}
.footer-case-box a {
  color: #FFF;
}

.footer-right-blockA, .footer-right-blockB {
  width: 333px;
  text-align: left;
  float: left;
  margin: 0px 10px 0px 10px;
}

.footer-sitemap {
  margin: 10px 40px 10px 10px;
  text-align: right;
  float: right;
  font-size: 16px;
}
.footer-sitemap a {
  outline: none;
  color: #FFF;
  text-decoration: none;
}

.footer-right ul li {
  height: 45px;
}

.footer-inquiry-box img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.footer-mark {
  margin: auto;
  text-align: center;
  padding: 60px 0px 0px 0px;
  font-size: 18px;
}

#footer_top {
  padding: 46px 0;
  border-bottom: none;
  text-align: left;
}

footer a {
  font-size: 11px;
  color: #fff;
}

.footer_inner_menu {
  text-align: center;
  text-decoration: none;
  padding-top: 28px;
}
.footer_inner_menu li {
  display: inline-block;
  font-size: 14px;
  border-right: 1px solid #fff;
  padding: 0px 21px;
}
.footer_inner_menu li a {
  color: #fff;
}
.footer_inner_menu li:last-child {
  border-right: none;
  padding-right: 0px;
}

.footer_menu th {
  vertical-align: top;
  text-align: left;
  width: 120px;
  line-height: 1.8;
}
.footer_menu td {
  padding-bottom: 30px;
}

.footer_menu_contents {
  width: 100%;
  letter-spacing: -0.4em;
}
.footer_menu_contents li {
  display: inline-block;
  letter-spacing: normal;
  margin-left: 60px;
  line-height: 1.8;
}

/**
 * Footer Add CSS
 *****************************/
#footer_bottom {
  background-color: #001c36;
  padding: 0;
}

.footer_menu {
  width: 100%;
}
.footer_menu a {
  outline: none;
  color: #FFF;
  text-decoration: none;
}

.footer_inner {
  width: 967px;
  margin: 0 auto;
}
.footer_inner h1 {
  text-align: center;
  font-size: 16px;
}

.go_top {
  text-align: center;
  color: #fff;
  cursor: pointer;
  font-weight: bold;
  margin-bottom: 50px;
}

.copyright {
  text-align: center;
  color: #fff;
  padding: 15px 0;
  margin: 0;
  font-size: 14px;
  letter-spacing: 0;
}

.footer_bottom_menu {
  margin: 0 auto;
  text-align: center;
}
.footer_bottom_menu li {
  display: inline-block;
  border-right: 1px solid #fff;
  line-height: 1;
  padding: 0 10px 0 10px;
}
.footer_bottom_menu li a {
  color: #fff !important;
  font-size: 12px;
  outline: none;
  text-decoration: none;
}
.footer_bottom_menu li:last-child {
  border-right: none;
}

/* Media Test(640-) ミニ画面での表示設定
******************************************************************************/
@media screen and (max-width: 640px) {
  #header-box .index-wrapper {
    height: auto;
  }

  #header-top {
    padding-top: 5px;
    height: 60px;
    border-bottom: solid 10px #013567;
  }
  #header-top .text_area {
    padding-top: 0;
  }
  #header-top .index-wrapper {
    width: 100%;
    max-width: 1080px;
  }
  #header-top .logo {
    width: 30%;
    padding: 0 0 0 3%;
  }
  #header-top .logo img {
    width: 100%;
  }
  #header-top .text_area {
    margin: 0 3% 0 0;
    line-height: 1.4;
    font-family: "Noto Sans JP Medium", sans-serif;
    letter-spacing: -1px;
  }
  #header-top .text_area a:first-of-type {
    font-size: 12px;
  }
  #header-top .text_area a:nth-of-type(2) {
    padding-right: 14px;
  }
  #header-top .text_area a:nth-of-type(2),
#header-top .text_area a:nth-of-type(3) {
    font-size: 14px;
  }

  #footer_top {
    display: block;
  }

  #footer-box .sp {
    padding: 18px 0px 25px 0;
  }

  #footer-top {
    height: 130px;
    margin-bottom: 11px;
  }

  .sp .footer_inner {
    max-width: 1080px;
    width: 100%;
  }
  .sp .footer_inner h1 {
    font-size: 3vw;
  }
  .sp .footer_inner ul {
    padding-top: 2.5vw;
    flex-wrap: wrap;
    width: 75%;
    margin: 0 auto;
  }

  #footer_bottom .footer_inner {
    width: 100%;
    max-width: 1080px;
  }
}
