@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-VariableFont_wght.ttf");
}
@font-face {
  font-family: "Roboto";
  src: url("../fonts/Roboto-VariableFont_wdth,wght.ttf");
}
.snavi {
  display: none;
}
@media screen and (min-width: 751px) {
  .snavi {
    display: unset;
    width: 27.2727272727vw;
    height: fit-content;
    padding: 20px 0 30px;
    border: 2px solid white;
    border-radius: 12px;
    box-shadow: 0 0 30px 0px lightgray;
  }
}
@media screen and (min-width: 1100px) {
  .snavi {
    width: 300px;
  }
}
@media screen and (min-width: 1500px) {
  .snavi {
    width: 20vw;
    padding: 1.3333333333vw 0 2vw;
    border-width: 0.1333333333vw;
    border-radius: 0.8vw;
    box-shadow: 0 0 2vw 0px lightgray;
  }
}
.snavi .menu {
  display: flex;
  align-items: center;
  height: 50px;
  padding: 0 22px 0 30px;
  color: #23afc0;
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 16px;
}
@media screen and (min-width: 1500px) {
  .snavi .menu {
    font-size: 1.0666666667vw;
  }
}
.snavi .menu.child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 22px 0 40px;
  background-color: #ecf0f3;
  color: #515354;
  font-size: 14px;
}
@media screen and (min-width: 1500px) {
  .snavi .menu.child {
    font-size: 0.9333333333vw;
  }
}
.snavi .menu.child .icon-arrow {
  width: 7px;
  height: 11px;
}
@media screen and (min-width: 1500px) {
  .snavi .menu.child .icon-arrow {
    width: 0.4666666667vw;
    height: 0.7333333333vw;
  }
}
.snavi .menu.child:hover {
  color: #8b8e8f;
}
.snavi .menu.child:active {
  color: #515354;
}
@media screen and (min-width: 1500px) {
  .snavi .menu {
    height: 3.3333333333vw;
    padding: 0 1.4666666667vw 0 2vw;
  }
  .snavi .menu.child {
    padding: 0 1.4666666667vw 0 2.6666666667vw;
  }
}

.snavi-sp {
  position: fixed;
  background-color: #f4f6f8;
  top: 13.3333333333vw;
  width: 100vw;
  height: calc(100vh - 100px);
  padding: 6.6666666667vw 0;
  margin-left: -6.6666666667vw;
  overflow-y: auto;
  z-index: 10;
}
.snavi-sp .menu {
  display: flex;
  align-items: center;
  height: 10.6666666667vw;
  padding: 0 6.6666666667vw;
  color: #23afc0;
  font-family: "Noto Sans JP";
  font-weight: 500;
}
@media screen and (max-width: 750px) {
  .snavi-sp .menu {
    font-size: clamp(14.4px, 3.1957390146vw, 24px) !important;
  }
}
.snavi-sp .menu.child {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-left: 8vw;
  background-color: #ecf0f3;
  color: #515354;
}
@media screen and (max-width: 750px) {
  .snavi-sp .menu.child {
    font-size: clamp(12.6px, 2.7962716378vw, 21px) !important;
  }
}
.snavi-sp .menu.child .icon-arrow {
  width: 0.9333333333vw;
  height: 1.4666666667vw;
}
.snavi-sp .menu.child:hover {
  color: #8b8e8f;
}
.snavi-sp .menu.child:active {
  color: #515354;
}