/*------------------------------------------------------------
color
------------------------------------------------------------*/
/*
------------------------------------------------------------*/
/* [ easy transform ]
-------------------------------------------------*/
/*------------------------------------------------------------
base
------------------------------------------------------------*/
@media only screen and (max-width: 768px) {
  .sp,
  .SP {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .sp,
  .SP {
    display: block !important;
  }
}
@media screen and (min-width: 767px) {
  .sp,
  .SP {
    display: none !important;
  }
}

@media only screen and (max-width: 767px) {
  .pc,
  .PC {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc,
  .PC {
    display: none !important;
  }
}

/*------------------------------------------------------------
nav
------------------------------------------------------------*/
.fixed-nav {
  position: fixed;
  right: 0;
  bottom: 50%;
  transform: translateY(50%);
  width: -moz-fit-content;
  width: fit-content;
  z-index: 1000;
}
@media screen and (max-width: 767px) {
  .fixed-nav {
    bottom: 0;
    transform: none;
    width: 100%;
  }
}
.fixed-nav ul {
  display: flex;
  flex-direction: column;
  border: 2px solid #036eb7;
  border-right: none;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .fixed-nav ul {
    border-width: 2px;
  }
}
@media screen and (max-width: 767px) {
  .fixed-nav ul {
    border: none;
    border-top: 1px solid #036eb7;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(24px, 1fr));
    width: 100%;
  }
}
.fixed-nav ul li {
  background-color: #fff;
  width: 78px;
  height: 78px;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li {
    width: auto;
    height: 70px;
  }
}
.fixed-nav ul li:not(:last-child) {
  border-bottom: 2px solid #036eb7;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li:not(:last-child) {
    border-bottom: none;
    border-right: 1px solid #036eb7;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .fixed-nav ul li:not(:last-child) {
    border-width: 2px;
  }
}
.fixed-nav ul li:last-child {
  height: 78px;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li:last-child {
    height: 70px;
  }
}
.fixed-nav ul li a[href*=features] img {
  width: 23px;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li a[href*=features] img {
    width: 20px;
  }
}
.fixed-nav ul li a.request img {
  width: 19px;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li a.request img {
    width: 16px;
  }
}
.fixed-nav ul li img {
  width: 24px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li img {
    width: 20px;
  }
}
.fixed-nav ul li span {
  display: block;
  display: grid;
  place-content: center;
  height: 24px;
}
@media screen and (max-width: 767px) {
  .fixed-nav ul li span {
    height: 20px;
  }
}
.fixed-nav ul a {
  display: grid;
  gap: 3px;
  height: 100%;
  place-content: center;
  text-align: center;
  color: #036eb7;
  font-size: 12px;
  line-height: 1.25;
  font-weight: 700;
  letter-spacing: 0;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .fixed-nav ul a {
    font-size: 12px;
  }
}
@media screen and (max-width: 767px) {
  .fixed-nav ul a {
    font-size: 10px;
  }
}

/*------------------------------------------------------------
footer
------------------------------------------------------------*/
@media screen and (max-width: 767px) {
  footer.footer {
    margin-bottom: 71px !important;
  }
}
@media screen and (max-width: 1069px) {
  footer.footer #pc_pager_top.act {
    bottom: 12% !important;
  }
}/*# sourceMappingURL=common.css.map */