[data-anime].is-show {
  opacity: 1;
  filter: none;
  transform: none;
}

[data-anime=c-anime-box].is-show [data-anime] {
  opacity: 1;
  filter: none;
  transform: none;
}

[data-anime=c-fade] {
  opacity: 0;
  transition: opacity 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

[data-anime=c-fade-in] {
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-anime=c-mask-right] {
  opacity: 0;
  clip-path: inset(0% 100% 0% 0%);
  transition: opacity 1.6s cubic-bezier(0.165, 0.84, 0.44, 1), clip-path 1.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-anime=c-blur] {
  filter: blur(2px);
  opacity: 0;
  transform: scale(1.01);
  transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 1s cubic-bezier(0.165, 0.84, 0.44, 1), filter 1.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-anime=c-blur-in] {
  filter: blur(2px);
  opacity: 0;
  transform: translateY(5px) scale(1.01);
  transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 1s cubic-bezier(0.165, 0.84, 0.44, 1), filter 1.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

[data-anime=c-scale] {
  transform: scale(1.01);
  transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1);
}

/*-------------------------------------------> Viewport size */
/*-------------------------------------------> Design comp size */
/*-------------------------------------------> Media queries */
/*-------------------------------------------> SP : contents width */
/*-------------------------------------------> PC : contents width */
/*-------------------------------------------> web font */
/*-------------------------------------------> hover animation */
/*-------------------------------------------> font size (rem) */
/*-------------------------------------------> percentage (%) */
/*-------------------------------------------> vw ( width / height / padding / margin / position / and more ) */
/*-------------------------------------------> line-height */
/*-------------------------------------------> half */
/*-------------------------------------------> Overwrite logo size (local navi) */
.localnavi {
  padding-inline: 30px 0;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .localnavi {
    display: none;
  }
}
.localnavi > p {
  width: auto;
}
.localnavi > p a img {
  width: 100%;
  max-height: 21px;
}
.localnavi .localnavi-item {
  display: grid;
  align-items: center;
  grid-template-columns: repeat(2, auto);
}
.localnavi .localnavi-item .name {
  font-size: 1.6rem;
  line-height: 1.1;
  font-family: "Noto Sans JP", "Yu Gothic", YuGothic, "Hiragino Sans", sans-serif;
  font-weight: bold;
  margin-left: 14px;
  padding-left: 14px;
  border-left: 1px solid #000;
}
.localnavi .localnavi-box {
  width: auto;
  float: none;
}
.localnavi .local-menu {
  float: none;
  padding-inline: 64px 15px;
}
@media screen and (max-width: 1199px) {
  .localnavi .local-menu {
    padding-inline: 34px 15px;
  }
}
@media screen and (max-width: 1050px) {
  .localnavi .local-menu {
    padding-inline: 10px 10px;
  }
}
.localnavi .local-menu li a {
  font-size: 1.2rem;
  padding: 0 10px;
}
@media screen and (max-width: 1420px) {
  .localnavi .local-menu li a {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 1199px) {
  .localnavi .local-menu li a {
    font-size: 1.1rem;
    padding: 0 5px;
  }
}
@media screen and (max-width: 1050px) {
  .localnavi .local-menu li a {
    font-size: 1.1rem;
    padding: 0 3px;
  }
}
.localnavi .local-menu li button {
  font-size: 1.2rem;
  padding: 0 10px;
}
.localnavi .local-menu .accordion {
  margin-left: 20px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .localnavi .local-menu .accordion {
    margin-left: 0;
  }
}
.localnavi .local-menu .accordion::before {
  content: "";
  width: 1px;
  height: 18px;
  background-color: rgba(0, 0, 0, 0.1);
  position: absolute;
  left: -10px;
  top: 0;
  bottom: 0;
  margin-block: auto;
}
@media screen and (max-width: 768px) {
  .localnavi .local-menu .accordion::before {
    display: none;
  }
}
.localnavi .local-menu .accordion ~ .accordion {
  margin-left: 0;
}
.localnavi .local-menu .accordion ~ .accordion::before {
  display: none;
}
.localnavi .local-menu .accordion button {
  color: #000;
  display: flex;
  gap: 8px;
}
@media screen and (max-width: 768px) {
  .localnavi .local-menu .accordion button {
    width: 100%;
    background-color: #fff;
    border: none;
  }
}
.localnavi .local-menu .accordion button::after {
  content: "";
  min-width: 6px;
  min-height: 9px;
  margin-top: 2px;
  background-color: #000;
  mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 6 9'><path d='M0 0 L6 4.5 L0 9 Z' fill='black'/></svg>") no-repeat center/contain;
  -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 6 9'><path d='M0 0 L6 4.5 L0 9 Z' fill='black'/></svg>") no-repeat center/contain;
  transform: rotate(90deg);
}
@media screen and (max-width: 768px) {
  .localnavi .local-menu .accordion button::after {
    width: 4px;
    height: 7px;
    position: static;
    margin: 0;
  }
}
@media screen and (max-width: 768px) {
  .localnavi .local-menu .accordion .localnav-sp__link {
    justify-content: space-between;
  }
}
.localnavi .local-menu .accordion .localnav-sp__link::before {
  display: none;
}
.localnavi .local-menu .accordion .accordion-menu {
  min-width: 180px;
  padding-bottom: 10px;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  padding-inline: 14px;
  background-color: #fff;
  display: none;
}
.localnavi .local-menu .accordion .accordion-group + .accordion-group {
  margin-top: 10px;
}
.localnavi .local-menu .accordion .accordion-parent {
  font-size: 1.3rem;
  line-height: 1.2307692308;
  font-weight: 500;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  padding: 10px 0;
  padding-right: 18px;
  height: auto;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.localnavi .local-menu .accordion .accordion-parent:after, .localnavi .local-menu .accordion .accordion-parent:before {
  bottom: 0;
  content: "";
  display: block;
  margin: auto;
  position: absolute;
  top: 0;
  z-index: 1;
}
.localnavi .local-menu .accordion .accordion-parent:before {
  border-top: 2px solid;
  height: 2px;
  width: 11px;
  right: 1px;
}
.localnavi .local-menu .accordion .accordion-parent:after {
  border-right: 2px solid;
  border-top: 2px solid;
  height: 6px;
  transform: rotate(45deg);
  width: 6px;
  right: 0;
}
@media (hover: hover) {
  .localnavi .local-menu .accordion .accordion-parent {
    transition: opacity 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
  .localnavi .local-menu .accordion .accordion-parent:hover {
    box-shadow: none;
    opacity: 0.7;
  }
}
.localnavi .local-menu .accordion .accordion-children {
  text-align: left;
  margin-top: 4px;
}
.localnavi .local-menu .accordion .accordion-children a {
  padding: 0;
  height: auto;
  font-size: 1.2rem;
  line-height: 1.75;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 6px;
}
.localnavi .local-menu .accordion .accordion-children a::before {
  content: "";
  width: 5px;
  height: 1px;
  background-color: #000;
}
@media (hover: hover) {
  .localnavi .local-menu .accordion .accordion-children a {
    transition: opacity 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }
  .localnavi .local-menu .accordion .accordion-children a:hover {
    box-shadow: none;
    opacity: 0.7;
  }
}
.localnavi .local-menu .is-open .accordion-menu {
  display: block;
}
.localnavi.--product-desc-hidden .localnavi-box .local-menu .accordion {
  margin-left: 0;
}
.localnavi.--product-desc-hidden .localnavi-box .local-menu .accordion::before {
  display: none;
}

.localnav-sp .localnav-sp__list .accordion {
  color: #3a3a3a;
  position: relative;
}
.localnav-sp .localnav-sp__list .accordion .localnav-sp__link {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #fff;
  border: none;
}
.localnav-sp .localnav-sp__list .accordion > button::after {
  content: "";
  min-width: 6px;
  min-height: 9px;
  position: static;
  margin: 0;
  background-color: #000;
  mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 6 9'><path d='M0 0 L6 4.5 L0 9 Z' fill='black'/></svg>") no-repeat center/contain;
  -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 6 9'><path d='M0 0 L6 4.5 L0 9 Z' fill='black'/></svg>") no-repeat center/contain;
  transform: rotate(90deg);
}
.localnav-sp .localnav-sp__list .accordion > button::before {
  display: none;
}
.localnav-sp .localnav-sp__list .accordion .accordion-menu {
  border-top: 1px solid #d0d0d0;
  width: 100%;
  background-color: #fff;
  display: none;
}
.localnav-sp .localnav-sp__list .accordion .accordion-group + .accordion-group {
  border-top: 1px solid #d0d0d0;
}
.localnav-sp .localnav-sp__list .accordion .accordion-parent {
  font-weight: 500;
  padding-left: 32px;
  height: auto;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.localnav-sp .localnav-sp__list .accordion .accordion-children {
  text-align: left;
}
.localnav-sp .localnav-sp__list .accordion .accordion-children li {
  border-top: 1px solid #d0d0d0;
  position: relative;
}
.localnav-sp .localnav-sp__list .accordion .accordion-children li::before {
  content: "";
  width: 5px;
  height: 1px;
  display: block;
  margin: auto;
  background-color: #3a3a3a;
  position: absolute;
  inset: 0;
  right: auto;
  left: 32px;
  z-index: 1;
  pointer-events: none;
}
.localnav-sp .localnav-sp__list .accordion .accordion-children a {
  padding-left: 46px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.localnav-sp .localnav-sp__list .is-open .accordion-menu {
  display: block;
}