@charset "UTF-8";
html {
  height: 100%;
overflow-x: hidden;
}
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  display: flex;
  flex-direction: column;
  word-break: break-all;
}
.content {
  flex: 1;
}
.wrap {
  max-width: 980px;
  margin: 1rem auto;
}
.flex_d {
  display: flex;
  margin: 0;
}
h1 {
  margin: 0;
}
h1 a img {
  width: 500px;
}
dl dd {
  margin: 0;
}
/* blockSlip */
#blockSkip ul {
  margin: 0;
  padding: 0;
}
#blockSkip li {
  display: block;
  margin: 0;
  padding: 0;
  position: absolute;
  text-align: left;
}
#blockSkip a {
  display: inline;
  font-size: 110%;
  font-weight: bold;
  left: -1000em;
  padding: 5px;
  position: absolute;
  text-align: center;
  text-decoration: none;
  top: 0;
  width: 250px;
  z-index: 99;
}
#blockSkip a:focus, #blockSkip a:active {
  background: none repeat scroll 0 0 #fff !important;
  border: 2px solid #000;
  left: 10px;
  position: absolute;
  top: 10px;
  width: 250px;
}
/*ヘッダー*/
.site {
  background-color: #fff;
}
.site a {
  display: flex;
  align-items: center;
  height: 5rem;
  width: 500px;
}
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
}
.h_logo {
  width: 500px;
  padding-left: 20px;
  display: block;
}
.splogo {
  width: 100px;
  padding-left: 20px;
  display: none;
}
.hzindex {}
.hsp {
  padding-bottom: 7rem;
}
.hsptop {
  padding-bottom: 2rem;
}
.footerFixed {
  min-height: 100vh; /* ←コンテンツの高さの最小値＝ブラウザの高さに指定 */
  position: relative; /* ←相対位置 */
  padding-bottom: 60px; /* ←フッターの高さを指定 */
  box-sizing: border-box;
}
/*SANグローバルメニュー*/
.g_nav ul {
  list-style-type: none;
  padding: 0;
}
.g_nav_span {
  display: block;
  width: 100%;
  background-color: #23298B;
  color: #ffffff;
  text-align: center;
  padding: 0.4rem 0;
  border: 1px solid #545ABC;
  font-size: 1.0rem;
}
.g_nav_li {
  width: 20%;
  outline: none;
}
.g_nav_li_ul {
  margin: 2rem 5rem;
  display: flex;
  flex-wrap: wrap;
}
.g_nav_li_cont {
  width: 100%;
  background-color: #E2FCFF;
  height: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
}
.g_nav_li_ul li a {
  display: block;
  padding-left: 20px;
  padding-right: 20px;
  margin: 1rem 2rem;
}
.g_nav_li_ul li a::before {
  content: "";
  width: 10px; /* 幅指定 */
  height: 10px; /* 高さ指定 */
  display: inline-block; /* インラインブロックにする */
  background-color: #5C63D6; /* 背景色指定 */
  border-radius: 50%; /* 要素を丸くする */
  position: relative; /* 位置調整 */
  top: -1px; /* 位置調整 */
  margin-right: 5px; /* 余白指定 */
}
.focused {
  height: auto;
}
.g_nav ul li:focus-within ul.focused li {
  height: auto;
  overflow: visible;
}
.g_nav_li:hover .g_nav_span {
  background-color: #545ABC;
}
.g_nav_li:focus .g_nav_span {
  background-color: #545ABC;
}
.g_nav_li_ul a:focus {
  background-color: #CEE8EB;
  color: #0000EE;
}
.sp_nav {
  display: none;
  position: relative;
}
.g_nav_li_ul a:hover {
  color: #0000EE;
}
.g_nav_li_ul a:visited {
  color: #551A8B;
}
/*sp クローバルメニュー*/
#global-nav {
  display: none;
  width: 90%;
  margin-left: 22px;
  margin: 0 auto;
  overflow-y: scroll;
  height: 80vh;
}
#global-nav.open {
  display: block;
}
.c-button {
  display: inline-block;
  text-decoration: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  background-color: transparent;
  cursor: pointer;
  width: 36px;
  height: 36px;
}
.p-hamburger {
  position: absolute;
  right: 30px;
  top: -70px;
}
.p-hamburger:hover, .p-hamburger:focus {}
.p-hamburger__line {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 36px;
  height: 5px;
  background-color: #000000;
  -webkit-transition: inherit;
  transition: inherit;
}
.p-hamburger__line::before, .p-hamburger__line::after {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background-color: inherit;
  content: '';
  -webkit-transition: inherit;
  transition: inherit;
}
.p-hamburger__line::before {
  top: -15px;
}
.p-hamburger__line::after {
  top: 15px;
}
.p-hamburger[aria-expanded="true"] .p-hamburger__line {
  background-color: transparent;
}
.p-hamburger[aria-expanded="true"] .p-hamburger__line::before, .p-hamburger[aria-expanded="true"] .p-hamburger__line::after {
  top: 0;
  background-color: #000000;
}
.p-hamburger[aria-expanded="true"] .p-hamburger__line::before {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.p-hamburger[aria-expanded="true"] .p-hamburger__line::after {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
.u-visuallyHidden {
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
  overflow: hidden;
  border: 0;
  padding: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  margin: -1px;
}
.sp_nav {
  background-color: #fff;
}
.sp_nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.sp_nav_button {
  width: 100%;
  background-color: #23298B;
  color: #ffffff;
  text-align: center;
  padding: 10px 0;
  border: 1px solid #545ABC;
  font-size: 1.0rem;
  cursor: pointer;
}
.sp_nav_li_ul a {
  display: block;
  width: 90%;
  background-color: #E2FCFF;
  padding: 10px 5%;
  text-decoration: none;
  border-bottom: 1px solid #9AD2EF;
  height: 2em;
  line-height: 2;
}
.sp_nav_button:hover {
  background-color: #545ABC;
}
.sp_nav_button:focus {
  background-color: #545ABC;
}
.sp_nav_li_ul a:hover {
  background-color: #CEE8EB;
}
.sp_nav_li_ul a:focus {
  background-color: #CEE8EB;
}
.sp_nav_li_ul {
  display: none;
}
#sp_sub_menu1.open {
  display: block;
}
#sp_sub_menu1.open li {
  display: block;
  width: 100%;
}
#sp_sub_menu1.open li a {
  display: block;
}
#sp_sub_menu2.open {
  display: block;
}
#sp_sub_menu2.open li {
  display: block;
  width: 100%;
}
#sp_sub_menu2.open li a {
  display: block;
}
#sp_sub_menu3.open {
  display: block;
}
#sp_sub_menu3.open li {
  display: block;
  width: 100%;
}
#sp_sub_menu3.open li a {
  display: block;
}
#sp_sub_menu4.open {
  display: block;
}
#sp_sub_menu4.open li {
  display: block;
  width: 100%;
}
#sp_sub_menu4.open li a {
  display: block;
}
#sp_sub_menu5.open {
  display: block;
}
#sp_sub_menu5.open li {
  display: block;
  width: 100%;
}
#sp_sub_menu5.open li a {
  display: block;
}
.sp-menu-btn {
  width: 100%;
  background-color: #BFC5CA;
  color: #000000;
  text-align: center;
  padding: 10px 0;
  border: 1px solid #545ABC;
  font-size: 1.0rem;
  margin-top: 10px;
  margin-bottom: 10px;
  cursor: pointer;
}
.sp-menu-btn:hover {
  background-color: #8D9398;
}
.sp-menu-btn:focus {
  background-color: #8D9398;
}
.is-drawerActive .wrap {
  display: none;
}
.is-drawerActive footer {
  display: none;
}
/*パンくずリスト*/
.pl {
  list-style-type: none;
  margin-top: 20;
  display: flex;
}
.pl li::after {
  content: "＞";
  margin-left: 0.5em;
  margin-right: 0.5em;
}
/*メイン部分*/
main {
  width: 90%;
  margin: 0 auto;
  line-height: 2rem;
}
/*フッダー*/
footer {
  background-color: #E2E2E2;
  width: 100%;
  margin: 0;
  position: sticky;
  top: 100vh;
}
.f_nav {
  margin-top: -1rem;
}
.flex_f {
  display: flex;
  justify-content: center;
  background-color: #23298B;
  color: #ffffff;
  margin: 0;
  padding: 0;
}
.flex_f_ul {
  padding: 0;
}
.flex_f li {
  margin: 0;
  padding: 0;
  width: 20%;
  list-style: none;
}
.f_nav_span {
  display: block;
  padding: 0.4rem 20%;
  font-size: 1.0rem;
  text-align: center;
  color: #fff;
}
.flex_f a {
  display: block;
  text-decoration: none;
  text-decoration-line: none;
}
.flex_f a:hover {
  background-color: #545ABC;
}

.f_con1 {
  width: 60%;
  margin: 0 auto;
  /*text-align: center;*/
}
.f_con2 {
  text-align: center;
  padding-bottom: 2rem;
}
.flex_f_logo {
  display: flex;
  justify-content: center;
}
.f_list {
  list-style-type: none;
  padding-left: 20px;
  padding-right: 20px;
}
address dt {
  padding: 2%;
}
@media screen and (max-width:768px) {
  .h_logo {
    display: none;
  }
  .splogo {
    margin-top: 1rem;
    display: block;
  }
  .site {
    margin: 0;
    height: 0;
    padding-top: 0.1rem;
    padding-bottom: 6rem;
  }
  .site a {
    width: 100px;
  }
  .g_nav {
    display: none;
  }
  .sp_nav {
    display: block;
  }
  .flex_f {
    display: block;
  }
  .flex_f li {
    width: 100%;
  }
  .flex_f_logo {
    display: block;
  }
  .f_con1 {
    text-align: center;
  }

	
}