@charset "UTF-8"; /* 2025.07.09 */


/*==================================
ヘッダー
==================================*/
header.header01 {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 9;
  padding: 1em;
  font-size: 0.875em;
  font-weight: bold;
  background: #fff;
  border-bottom: 1px solid #c0c0c0;
}
@media screen and (max-width: 768px) {
  header.header01 {
    padding: 0 0 0 1em;
  }
}
header.header01 a {
  transition: opacity 0.3s;
}
header.header01 a:hover {
  opacity: 0.8;
}
header.header01 .logo {
  margin: 0.5em 1em 0.5em 0;
  max-width: 50%;
}
header.header01 .global-nav {
  flex-grow: 1;
}
@media screen and (max-width: 768px) {
  header.header01 .global-nav {
    display: none;
    position: fixed;
    right: 0;
    left: 0;
    bottom: 0;
    padding: 2em;
    color: #fff;
    background: #004ea2;
  }
}
@media screen and (min-width: 769px) {
  header.header01 .global-nav {
    display: block !important;
  }
}
header.header01 .global-nav ul {
  justify-content: flex-end;
}
@media screen and (max-width: 768px) {
  header.header01 .global-nav ul li {
    border-top: 1px dotted #fff;
  }
}
@media screen and (min-width: 769px) {
  header.header01 .global-nav ul li:not(:last-of-type) {
    margin-right: 2em;
  }
}
@media screen and (max-width: 768px) {
  header.header01 .global-nav ul li:last-of-type {
    border-bottom: 1px dotted #fff;
  }
}
header.header01 .global-nav ul li a {
  display: block;
  padding: 1em 0;
}
@media screen and (max-width: 768px) {
  header.header01 .global-nav ul li a {
    display: flex;
    align-items: flex-start;
    padding: 1em;
  }
  header.header01 .global-nav ul li a:before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    margin-top: 0.5em;
    margin-right: 0.5em;
    border-style: solid;
    border-width: 2.5px 0 2.5px 3.5px;
    border-color: transparent transparent transparent #ffffff;
  }
}
header.header01 .spNaviButton {
  position: relative;
  width: 80px;
  height: 80px;
  margin-left: 1em;
  background: #004ea2;
}
header.header01 .spNaviButton span, header.header01 .spNaviButton:before, header.header01 .spNaviButton:after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  width: 50%;
  height: 4px;
  margin: 0 auto;
  background: #fff;
}
header.header01 .spNaviButton:before {
  top: 24%;
  -webkit-transition: top 0.3s 0.3s, -webkit-transform 0.3s;
  transition: top 0.3s 0.3s, -webkit-transform 0.3s;
  transition: top 0.3s 0.3s, transform 0.3s;
  transition: top 0.3s 0.3s, transform 0.3s, -webkit-transform 0.3s;
}
header.header01 .spNaviButton span {
  top: 38%;
  -webkit-transition: 0s 0.3s;
  transition: 0s 0.3s;
}
header.header01 .spNaviButton:after {
  top: 53%;
  -webkit-transition: top 0.3s 0.3s, -webkit-transform 0.3s;
  transition: top 0.3s 0.3s, -webkit-transform 0.3s;
  transition: top 0.3s 0.3s, transform 0.3s;
  transition: top 0.3s 0.3s, transform 0.3s, -webkit-transform 0.3s;
}
header.header01 .spNaviButton.open:before, header.header01 .spNaviButton.open:after {
  top: 38%;
  -webkit-transition: top 0.3s, -webkit-transform 0.3s 0.3s;
  transition: top 0.3s, -webkit-transform 0.3s 0.3s;
  transition: top 0.3s, transform 0.3s 0.3s;
  transition: top 0.3s, transform 0.3s 0.3s, -webkit-transform 0.3s 0.3s;
}
header.header01 .spNaviButton.open:before {
  transform: rotate(45deg);
}
header.header01 .spNaviButton.open span {
  width: 0;
}
header.header01 .spNaviButton.open:after {
  transform: rotate(-45deg);
}
header.header01 .spNaviButton p {
  position: absolute;
  top: 67%;
  right: 0;
  left: 0;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-50%);
}
/*==================================
フッター
==================================*/
footer {
  padding-top: 2em;
  background-color: #fff;
  border-top: 1px solid #ccc;
}
footer .logo {
  margin-bottom: 1em;
}
footer .ftNav {
  flex-grow: 1;
  justify-content: flex-end;
  gap: 7%;
}
footer > div > div.flexL {
  max-width: 342px;
}
footer > div > div.flexL > a {
  font-size: 0.9375em;
}
@media screen and (min-width:576px) and (max-width: 768px) {
  footer .flexR.sp_bk {
    display: flex;
    justify-content: center;
  }
  footer > div > div.flexL {
    max-width: 342px;
    margin: 0 auto 30px;
  }
}
@media screen and (min-width: 768px) {
  footer .ftNav {
    margin-left: 2em;
  }
  footer .ftNav {
    margin: 0 0 0 1em;
  }
}
@media screen and (max-width: 767px) {
  footer .ftNav {
    margin: 2.25em 0 0 1em;
  }
  footer > div > div.flexL {
    margin: 0 auto;
  }
}
@media screen and (max-width: 575px) {
  footer .ftNav ul + ul {
    margin-top: 0.75em;
  }
}
@media screen and (max-width: 768px) {
  footer .btnStl06 {
    font-size: 0.875em;
  }
}
footer .ftNav ul:not(.flexBox) li + li {
  margin-top: 0.75em;
}
footer .ftNav ul li a, footer .ftNav > ul > li > span {
  display: flex;
  align-items: flex-start;
  font-weight: bold;
  line-height: 1.4em;
  position: relative;
}
footer .ftNav ul li a:before, footer .ftNav > ul > li > span:before {
  content: "";
  display: block;
  position: absolute;
  left: -18px;
  top: 20%;
  width: 12px;
  height: 12px;
  background: url("../img/arrowT_01.svg") no-repeat center center/contain;
}
footer .ftNav ul li a.sublink {
  color: #222;
  font-size: 0.9375em;
  font-weight: normal;
}
footer .ftNav ul li a.sublink::before {
  content: none;
}
footer .ftNav ul.childrenNav {
  margin-top: 0.4em;
  margin-left: 1em;
}

footer .ftNav ul.childrenNav li + li {
  margin-top: 0.25em;
}
footer .copyright {
  margin-top: 2.5em;
  padding: 0.5em;
  font-size: 0.8125em;
  background: #004ea2;
  color: #fff;
}

footer .ftNav ul.childrenNav li a {
    font-weight: normal;
}


footer .img_mapc {
  height: 58px;
  width: 100%;
  background-color: #77cada;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: .2s;
  right: 0;
  bottom: 0;
  position: fixed;
  z-index: 99;
}
footer .img_mapc img {
  height: 100%;
  max-height: 80%;
  width: auto;
}
footer .img_mapc:hover {
  opacity: .7;
}
@media (max-width: 767px) {
  footer .copyright {
    margin-bottom: 57px;
  }
  footer .img_mapc .pcOnly {
    display: none !important;
  }
  footer.home .img_mapc {
    display: none;
  }
  footer.home .img_mapc.plus01 {
    display: block!important;
  }
}
@media (min-width: 768px) {
  footer .img_mapc {
    right: 15px;
    bottom: 15px;
    width: 146px;
    height: auto;
    background: none;
  }
  footer .img_mapc .spOnly {
    display: none !important;
  }
}

