@charset "UTF-8";
/* -------------------------------------
header
------------------------------------- */
header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 5;
}
header.fixed {
  position: fixed;
  background-color: rgba(255,255,255,0.7);
  box-shadow: rgba(000, 000, 000, 0.12) 2px 2px 6px 3px;
}

header #head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap:20px;
  padding-left: 20px;
  transition:all 0.3s;
}
header.fixed #head {
  /*padding:10px 0;*/
}
header #head .head_top {
  width: 22%;
  max-width:314px;
  min-width:200px;
}
header #head .head_top #logo {
  width: 100%;
  max-width:314px;
}
header #head .head_top #logo a {
  display:flex;
  align-items:center;
}
header #head .head_top #logo a .logo_wh,header.active #head .head_top #logo a .logo_wh {
  display:none;
}
header #head .head_top #logo a .logo_bl,header.active #head .head_top #logo a .logo_bl {
  display:block;
}

/*snsアイコン*/
header #head .nav_sns {
  display:flex;
  align-items:center;
  padding:0 25px 5px 15px;
}
header #head .sns_icon .logo_wh,header.active #head .sns_icon .logo_wh {
  display:none;
}
header #head .sns_icon .logo_bl,header.active #head .sns_icon .logo_bl {
  display:block;
}

header nav {
  transition: all 0.4s;
}
header.fixed nav {
  
}
header.fixed nav #gnav {
  justify-content:center;
}

header nav #gnav {
  width: 100%;
  display: flex;
  flex-wrap:wrap;
  justify-content: flex-end;
}


header nav #gnav .navbk {
  display: flex;
  flex-wrap:wrap;
  position:relative;
  z-index:3;
}
header nav #gnav li a {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  height:100%;
  padding:30px;
}

header.fixed nav #gnav li.nav_item a {
    color: #073582;
}
header nav #gnav li a .en {
  font-family: english-grotesque, sans-serif;
  font-weight:100;
  font-size:18px;
  line-height:1;
}
header nav #gnav li.nav_item a,header.fixed nav #gnav li. a {
  color:#073582;
  transition:all 0.3s;
}
header nav #gnav li:hover a .en,header nav #gnav li.np a .en {
  font-weight:500;
}
header nav #gnav li.nav_item a span {
  padding-bottom:4px;
  position:relative;
  z-index:1;
}
header nav #gnav li.nav_item a span:before {
  content:"";
  display:block;
  width:0;
  height:1px;
  border-radius:50%;
  background-color:#073582;
  position:absolute;
  bottom:0;
  left:50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index:0;
  transition:all 0.3s;
}
header nav #gnav li.nav_item:hover a span:before {
  width:100%;
}

header nav #gnav li a .ja {
  font-family: m-plus-1c, sans-serif;
  font-weight:700;
  font-size:14px;
}
header nav #gnav li.bgsq {
  text-align:center;
  width:150px;
  height:125px;
  /*padding:10px;*/
  transition:all 0.3s;
}
header nav #gnav li.bgsq a {
  padding:10px;
}
header.fixed nav #gnav li.bgsq {
  height:90px;
}
header nav #gnav li a .nav_icon {
  max-width:38px;
  display:block;
  margin:0 auto;
}
header nav #gnav li a .nav_icon.on {
  display:none;
}
header nav #gnav li a:hover .nav_icon.off,
header.active #contact a .nav_icon.off {
  display:none;
}
header nav #gnav li a:hover .nav_icon.on,
header.active #contact a .nav_icon.on  {
  display:block;
}

#calendar a {
  color:#fff;
  background-color:#073582;
  transition: all 0.3s;
}
#calendar a:hover {
  opacity: 0.8;
}
#contact a  {
  color:#646464;
  /*width:150px;*/
  background-color:#fff;
  transition:all 0.3s;
}
#contact a:hover,header.active #contact a {
  color:#fff;
  background-color:#8aa0c4;
}


header .head_top a#menu_btn {
  display: none;
  width: 38px;
  height: 38px;
  position: absolute;
  right: 10px;
  top: 10px;
  z-index: 5;
  transition: all 0.4s;
}

header .head_top a#menu_btn,
header .head_top a#menu_btn span {
  display: inline-block;
  transition: all 0.4s;
}

header .head_top a#menu_btn {
  display: none;
  width: 49px;
  height: 49px;
  position: absolute;
  right: 10px;
  top: 10px;
  z-index: 5;
}

header .head_top a#menu_btn span {
  width: 36px;
  height: 3px;
  margin: 0 auto;
  border-radius: 10px;
  background-color: #013268;
  position: absolute;
  left: 0;
  right: 0;
}

header .head_top a#menu_btn span:nth-of-type(1) {
  top: 13px;
}

header .head_top a#menu_btn span:nth-of-type(2) {
  top: 24px;
}

header .head_top a#menu_btn span:nth-of-type(3) {
  top: 34px;
}



header .head_top a#menu_btn.active span:nth-of-type(1) {
  transform: translateY(11px) rotate(-330deg);
}

header .head_top a#menu_btn.active span:nth-of-type(2) {
  opacity: 0;
}

header .head_top a#menu_btn.active span:nth-of-type(3) {
  transform: translateY(-10px) rotate(330deg);
}



@media screen and (max-width: 1440px) {

}

@media screen and (max-width: 1280px) {
header nav #gnav li a {
        padding:20px;
}
header nav #gnav li.bgsq {
    text-align: center;
    width: 132px;
    height: 90px;
}

}

@media screen and (max-width: 1100px) {
header #head .nav_sns {
    padding: 0 15px 5px 10px;
}
header nav #gnav li a {
        padding:10px;
}


}

@media screen and (max-width: 1060px) {

}

@media screen and (max-width: 980px) {

/* -------------------------------------
header
------------------------------------- */
header.fixed {
  /*background-color: transparent;
  box-shadow: none;*/
  min-height:72px;
}
header.active {
  position:relative;
  top:0;
  bottom:0;
}
header.fixed #head {
  /*padding: 20px 0;*/
  }
header #head {
  width:100%;
  padding-left:0;
  z-index: 5;
}
header #head .head_top {
  width:100%;
  max-width:100%;
  padding:15px 15px;
  position: relative;
  top: 0;
  z-index:5;
}
header.active #head .head_top {
  position: fixed;
}
  
header #head .head_top #logo {
  width: 45%;
  max-width:200px;
}

header #head .nav_sns {
    justify-content:center;
    padding:0;
    margin-bottom:25px;
}
  
header .head_top a#menu_btn {
  display: block;
}
header #head nav {
  display: none;
  width: 100%;
  max-width:100%;
  height: 100vh;
  padding: 70px 0 60px;
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -20;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -ms-transition: all 0.5s;
  -o-transition: all 0.5s;
}
header.active #head nav {
  display: flex;
  flex-direction: column;
  /*justify-content: center;*/
  align-items: center;
  width:100%;
  padding-top:70px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 4;
}

header nav #gnav {
  display:block;
  max-width: 400px;
  margin: 0 auto;
}

header nav #gnav .navbk.nav_top {
  flex-direction: column;
  /*align-items: center;*/
  padding:30px 0;
}
header nav #gnav .navbk.nav_btm {
    flex-wrap: nowrap;
    width:100%;
}
header nav #gnav li.bgsq {
  width:50%;
}
header nav #gnav li.bgsq a {
    /*width: 125px;*/
    width:100%;
}
header nav #gnav li a .ja {
    font-size: 13px;
}

}

@media screen and (max-width: 920px) {
}

@media screen and (max-width: 880px) {
}

}

@media screen and (max-width: 800px) {
}

@media screen and (max-width: 768px) {

.sp {
    display: block;
}

  

}

@media screen and (max-width: 700px) {
}

@media screen and (max-width: 640px) {




}

@media screen and (max-width: 600px) {


}

@media screen and (max-width: 500px) {

}

@media screen and (max-width: 400px) {

}
@media screen and (max-width: 380px) {



}

@media screen and (max-width: 320px) {

}

@media screen and (min-width: 981px) {
  header #head nav {
    display:block!important;
  }
}
