@charset "UTF-8";
:root {
  --rem: calc(1660 / 1440 * 10px);
}
@media screen and (min-width: 769px) {
  :root .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  :root .only-pc {
    display: none !important;
  }
}
:root .hover-opacity a,
:root .hover-opacity button,
:root .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  :root .hover-opacity a:hover,
  :root .hover-opacity button:hover,
  :root .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  :root .hover-opacity a:active,
  :root .hover-opacity button:active,
  :root .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  :root .hover-write a:hover span,
  :root .hover-write button:hover span,
  :root .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  :root .hover-write a:active span,
  :root .hover-write button:active span,
  :root .hover-write label:active span {
    background-size: 100% 1px;
  }
}
:root .hover-write a span,
:root .hover-write button span,
:root .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  :root .hover-rewrite a:hover span::before,
  :root .hover-rewrite button:hover span::before,
  :root .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  :root .hover-rewrite a:active span::before,
  :root .hover-rewrite button:active span::before,
  :root .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
:root .hover-rewrite a span,
:root .hover-rewrite button span,
:root .hover-rewrite label span {
  position: relative;
}
:root .hover-rewrite a span::before,
:root .hover-rewrite button span::before,
:root .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  :root a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  :root a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
:root a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
:root a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  :root .hover-image a:hover figure img,
  :root .hover-image button:hover figure img,
  :root .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  :root .hover-image a:active figure img,
  :root .hover-image button:active figure img,
  :root .hover-image label:active figure img {
    scale: 1.08;
  }
}
:root .hover-image a figure,
:root .hover-image button figure,
:root .hover-image label figure {
  overflow: hidden;
}
:root .hover-image a figure img,
:root .hover-image button figure img,
:root .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
:root .hover-black-button a,
:root .hover-black-button button,
:root .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  :root .hover-black-button a:hover,
  :root .hover-black-button button:hover,
  :root .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  :root .hover-black-button a:hover::before, :root .hover-black-button a:hover::after,
  :root .hover-black-button button:hover::before,
  :root .hover-black-button button:hover::after,
  :root .hover-black-button label:hover::before,
  :root .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  :root .hover-black-button a:active,
  :root .hover-black-button button:active,
  :root .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  :root .hover-black-button a:active::before, :root .hover-black-button a:active::after,
  :root .hover-black-button button:active::before,
  :root .hover-black-button button:active::after,
  :root .hover-black-button label:active::before,
  :root .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
:root .hover-black-button a::before, :root .hover-black-button a::after,
:root .hover-black-button button::before,
:root .hover-black-button button::after,
:root .hover-black-button label::before,
:root .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
:root .hover-white-button a,
:root .hover-white-button button,
:root .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  :root .hover-white-button a:hover,
  :root .hover-white-button button:hover,
  :root .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  :root .hover-white-button a:hover::before, :root .hover-white-button a:hover::after,
  :root .hover-white-button button:hover::before,
  :root .hover-white-button button:hover::after,
  :root .hover-white-button label:hover::before,
  :root .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  :root .hover-white-button a:active,
  :root .hover-white-button button:active,
  :root .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  :root .hover-white-button a:active::before, :root .hover-white-button a:active::after,
  :root .hover-white-button button:active::before,
  :root .hover-white-button button:active::after,
  :root .hover-white-button label:active::before,
  :root .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
:root .hover-white-button a::before, :root .hover-white-button a::after,
:root .hover-white-button button::before,
:root .hover-white-button button::after,
:root .hover-white-button label::before,
:root .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
:root .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  :root .tips__nav__list.-fixed {
    top: 62px;
  }
}
@font-face {
  font-family: "Figtree";
  src: url("/assets/font/Figtree-Medium.woff2") format("woff2"), url("/assets/font/Figtree-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@media screen and (max-width: 1600px) {
  :root {
    --rem: 0.6944444444vw;
  }
}
@media screen and (max-width: 768px) {
  :root {
    --rem: 2.6041666667vw;
  }
}

body {
  height: auto !important;
}
body::before {
  display: block;
  content: "";
  position: fixed;
  inset: 0;
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  background-color: #231815;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), visibility 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media screen and (min-width: 769px) {
  body::before .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  body::before .only-pc {
    display: none !important;
  }
}
body::before .hover-opacity a,
body::before .hover-opacity button,
body::before .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body::before .hover-opacity a:hover,
  body::before .hover-opacity button:hover,
  body::before .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  body::before .hover-opacity a:active,
  body::before .hover-opacity button:active,
  body::before .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  body::before .hover-write a:hover span,
  body::before .hover-write button:hover span,
  body::before .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  body::before .hover-write a:active span,
  body::before .hover-write button:active span,
  body::before .hover-write label:active span {
    background-size: 100% 1px;
  }
}
body::before .hover-write a span,
body::before .hover-write button span,
body::before .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body::before .hover-rewrite a:hover span::before,
  body::before .hover-rewrite button:hover span::before,
  body::before .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body::before .hover-rewrite a:active span::before,
  body::before .hover-rewrite button:active span::before,
  body::before .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body::before .hover-rewrite a span,
body::before .hover-rewrite button span,
body::before .hover-rewrite label span {
  position: relative;
}
body::before .hover-rewrite a span::before,
body::before .hover-rewrite button span::before,
body::before .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  body::before a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body::before a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body::before a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
body::before a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  body::before .hover-image a:hover figure img,
  body::before .hover-image button:hover figure img,
  body::before .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  body::before .hover-image a:active figure img,
  body::before .hover-image button:active figure img,
  body::before .hover-image label:active figure img {
    scale: 1.08;
  }
}
body::before .hover-image a figure,
body::before .hover-image button figure,
body::before .hover-image label figure {
  overflow: hidden;
}
body::before .hover-image a figure img,
body::before .hover-image button figure img,
body::before .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
body::before .hover-black-button a,
body::before .hover-black-button button,
body::before .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body::before .hover-black-button a:hover,
  body::before .hover-black-button button:hover,
  body::before .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body::before .hover-black-button a:hover::before, body::before .hover-black-button a:hover::after,
  body::before .hover-black-button button:hover::before,
  body::before .hover-black-button button:hover::after,
  body::before .hover-black-button label:hover::before,
  body::before .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  body::before .hover-black-button a:active,
  body::before .hover-black-button button:active,
  body::before .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body::before .hover-black-button a:active::before, body::before .hover-black-button a:active::after,
  body::before .hover-black-button button:active::before,
  body::before .hover-black-button button:active::after,
  body::before .hover-black-button label:active::before,
  body::before .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
body::before .hover-black-button a::before, body::before .hover-black-button a::after,
body::before .hover-black-button button::before,
body::before .hover-black-button button::after,
body::before .hover-black-button label::before,
body::before .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
body::before .hover-white-button a,
body::before .hover-white-button button,
body::before .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body::before .hover-white-button a:hover,
  body::before .hover-white-button button:hover,
  body::before .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body::before .hover-white-button a:hover::before, body::before .hover-white-button a:hover::after,
  body::before .hover-white-button button:hover::before,
  body::before .hover-white-button button:hover::after,
  body::before .hover-white-button label:hover::before,
  body::before .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  body::before .hover-white-button a:active,
  body::before .hover-white-button button:active,
  body::before .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body::before .hover-white-button a:active::before, body::before .hover-white-button a:active::after,
  body::before .hover-white-button button:active::before,
  body::before .hover-white-button button:active::after,
  body::before .hover-white-button label:active::before,
  body::before .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
body::before .hover-white-button a::before, body::before .hover-white-button a::after,
body::before .hover-white-button button::before,
body::before .hover-white-button button::after,
body::before .hover-white-button label::before,
body::before .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
body::before .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  body::before .tips__nav__list.-fixed {
    top: 62px;
  }
}
@media (min-width: 767px) {
  body:has(.layout-header) {
    padding-top: 0;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) {
    padding-top: calc(7 * var(--rem));
  }
}
@media screen and (max-width: 768px) and (min-width: 769px) {
  body:has(.layout-header) .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  body:has(.layout-header) .only-pc {
    display: none !important;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-opacity a,
  body:has(.layout-header) .hover-opacity button,
  body:has(.layout-header) .hover-opacity label {
    transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-opacity a:hover,
  body:has(.layout-header) .hover-opacity button:hover,
  body:has(.layout-header) .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-opacity a:active,
  body:has(.layout-header) .hover-opacity button:active,
  body:has(.layout-header) .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-write a:hover span,
  body:has(.layout-header) .hover-write button:hover span,
  body:has(.layout-header) .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-write a:active span,
  body:has(.layout-header) .hover-write button:active span,
  body:has(.layout-header) .hover-write label:active span {
    background-size: 100% 1px;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-write a span,
  body:has(.layout-header) .hover-write button span,
  body:has(.layout-header) .hover-write label span {
    position: relative;
    background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
    transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-rewrite a:hover span::before,
  body:has(.layout-header) .hover-rewrite button:hover span::before,
  body:has(.layout-header) .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-rewrite a:active span::before,
  body:has(.layout-header) .hover-rewrite button:active span::before,
  body:has(.layout-header) .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-rewrite a span,
  body:has(.layout-header) .hover-rewrite button span,
  body:has(.layout-header) .hover-rewrite label span {
    position: relative;
  }
  body:has(.layout-header) .hover-rewrite a span::before,
  body:has(.layout-header) .hover-rewrite button span::before,
  body:has(.layout-header) .hover-rewrite label span::before {
    display: block;
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    height: 1px;
    background-color: #231815;
  }
  @keyframes rewrite-after {
    0% {
      scale: 1;
      transform-origin: right center;
    }
    50% {
      scale: 0 1;
      transform-origin: right center;
    }
    50.000001% {
      scale: 0 1;
      transform-origin: left center;
    }
    100% {
      scale: 1;
      transform-origin: left center;
    }
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) a:has(.hover-arrow) .hover-arrow {
    display: block;
    overflow: hidden;
  }
  body:has(.layout-header) a:has(.hover-arrow) .hover-arrow::before {
    display: block;
    width: 100%;
    height: 100%;
    content: "";
    -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
            mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
    will-change: translate;
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-image a:hover figure img,
  body:has(.layout-header) .hover-image button:hover figure img,
  body:has(.layout-header) .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-image a:active figure img,
  body:has(.layout-header) .hover-image button:active figure img,
  body:has(.layout-header) .hover-image label:active figure img {
    scale: 1.08;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-image a figure,
  body:has(.layout-header) .hover-image button figure,
  body:has(.layout-header) .hover-image label figure {
    overflow: hidden;
  }
  body:has(.layout-header) .hover-image a figure img,
  body:has(.layout-header) .hover-image button figure img,
  body:has(.layout-header) .hover-image label figure img {
    transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
    will-change: scale;
  }
  body:has(.layout-header) .hover-black-button a,
  body:has(.layout-header) .hover-black-button button,
  body:has(.layout-header) .hover-black-button label {
    transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-black-button a:hover,
  body:has(.layout-header) .hover-black-button button:hover,
  body:has(.layout-header) .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.layout-header) .hover-black-button a:hover::before, body:has(.layout-header) .hover-black-button a:hover::after,
  body:has(.layout-header) .hover-black-button button:hover::before,
  body:has(.layout-header) .hover-black-button button:hover::after,
  body:has(.layout-header) .hover-black-button label:hover::before,
  body:has(.layout-header) .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-black-button a:active,
  body:has(.layout-header) .hover-black-button button:active,
  body:has(.layout-header) .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.layout-header) .hover-black-button a:active::before, body:has(.layout-header) .hover-black-button a:active::after,
  body:has(.layout-header) .hover-black-button button:active::before,
  body:has(.layout-header) .hover-black-button button:active::after,
  body:has(.layout-header) .hover-black-button label:active::before,
  body:has(.layout-header) .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-black-button a::before, body:has(.layout-header) .hover-black-button a::after,
  body:has(.layout-header) .hover-black-button button::before,
  body:has(.layout-header) .hover-black-button button::after,
  body:has(.layout-header) .hover-black-button label::before,
  body:has(.layout-header) .hover-black-button label::after {
    transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  body:has(.layout-header) .hover-white-button a,
  body:has(.layout-header) .hover-white-button button,
  body:has(.layout-header) .hover-white-button label {
    transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}
@media (max-width: 768px) and (hover: hover) {
  body:has(.layout-header) .hover-white-button a:hover,
  body:has(.layout-header) .hover-white-button button:hover,
  body:has(.layout-header) .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.layout-header) .hover-white-button a:hover::before, body:has(.layout-header) .hover-white-button a:hover::after,
  body:has(.layout-header) .hover-white-button button:hover::before,
  body:has(.layout-header) .hover-white-button button:hover::after,
  body:has(.layout-header) .hover-white-button label:hover::before,
  body:has(.layout-header) .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (max-width: 768px) and (hover: none) {
  body:has(.layout-header) .hover-white-button a:active,
  body:has(.layout-header) .hover-white-button button:active,
  body:has(.layout-header) .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.layout-header) .hover-white-button a:active::before, body:has(.layout-header) .hover-white-button a:active::after,
  body:has(.layout-header) .hover-white-button button:active::before,
  body:has(.layout-header) .hover-white-button button:active::after,
  body:has(.layout-header) .hover-white-button label:active::before,
  body:has(.layout-header) .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .hover-white-button a::before, body:has(.layout-header) .hover-white-button a::after,
  body:has(.layout-header) .hover-white-button button::before,
  body:has(.layout-header) .hover-white-button button::after,
  body:has(.layout-header) .hover-white-button label::before,
  body:has(.layout-header) .hover-white-button label::after {
    transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  @keyframes translate-back {
    0% {
      translate: 0;
    }
    50% {
      translate: 100% 0;
    }
    50.000001% {
      translate: -100% 0;
    }
    100% {
      translate: 0;
    }
  }
  body:has(.layout-header) .tips__nav__list.-fixed {
    top: 80px;
  }
}
@media screen and (max-width: 768px) and (max-width: 768px) {
  body:has(.layout-header) .tips__nav__list.-fixed {
    top: 62px;
  }
}
body:has(.layout-header) .item-detail {
  margin-top: calc(-10 * var(--rem)) !important;
}
@media screen and (min-width: 769px) {
  body:has(.layout-header) .item-detail .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  body:has(.layout-header) .item-detail .only-pc {
    display: none !important;
  }
}
body:has(.layout-header) .item-detail .hover-opacity a,
body:has(.layout-header) .item-detail .hover-opacity button,
body:has(.layout-header) .item-detail .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-opacity a:hover,
  body:has(.layout-header) .item-detail .hover-opacity button:hover,
  body:has(.layout-header) .item-detail .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-opacity a:active,
  body:has(.layout-header) .item-detail .hover-opacity button:active,
  body:has(.layout-header) .item-detail .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-write a:hover span,
  body:has(.layout-header) .item-detail .hover-write button:hover span,
  body:has(.layout-header) .item-detail .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-write a:active span,
  body:has(.layout-header) .item-detail .hover-write button:active span,
  body:has(.layout-header) .item-detail .hover-write label:active span {
    background-size: 100% 1px;
  }
}
body:has(.layout-header) .item-detail .hover-write a span,
body:has(.layout-header) .item-detail .hover-write button span,
body:has(.layout-header) .item-detail .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-rewrite a:hover span::before,
  body:has(.layout-header) .item-detail .hover-rewrite button:hover span::before,
  body:has(.layout-header) .item-detail .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-rewrite a:active span::before,
  body:has(.layout-header) .item-detail .hover-rewrite button:active span::before,
  body:has(.layout-header) .item-detail .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body:has(.layout-header) .item-detail .hover-rewrite a span,
body:has(.layout-header) .item-detail .hover-rewrite button span,
body:has(.layout-header) .item-detail .hover-rewrite label span {
  position: relative;
}
body:has(.layout-header) .item-detail .hover-rewrite a span::before,
body:has(.layout-header) .item-detail .hover-rewrite button span::before,
body:has(.layout-header) .item-detail .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body:has(.layout-header) .item-detail a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
body:has(.layout-header) .item-detail a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-image a:hover figure img,
  body:has(.layout-header) .item-detail .hover-image button:hover figure img,
  body:has(.layout-header) .item-detail .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-image a:active figure img,
  body:has(.layout-header) .item-detail .hover-image button:active figure img,
  body:has(.layout-header) .item-detail .hover-image label:active figure img {
    scale: 1.08;
  }
}
body:has(.layout-header) .item-detail .hover-image a figure,
body:has(.layout-header) .item-detail .hover-image button figure,
body:has(.layout-header) .item-detail .hover-image label figure {
  overflow: hidden;
}
body:has(.layout-header) .item-detail .hover-image a figure img,
body:has(.layout-header) .item-detail .hover-image button figure img,
body:has(.layout-header) .item-detail .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
body:has(.layout-header) .item-detail .hover-black-button a,
body:has(.layout-header) .item-detail .hover-black-button button,
body:has(.layout-header) .item-detail .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-black-button a:hover,
  body:has(.layout-header) .item-detail .hover-black-button button:hover,
  body:has(.layout-header) .item-detail .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.layout-header) .item-detail .hover-black-button a:hover::before, body:has(.layout-header) .item-detail .hover-black-button a:hover::after,
  body:has(.layout-header) .item-detail .hover-black-button button:hover::before,
  body:has(.layout-header) .item-detail .hover-black-button button:hover::after,
  body:has(.layout-header) .item-detail .hover-black-button label:hover::before,
  body:has(.layout-header) .item-detail .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-black-button a:active,
  body:has(.layout-header) .item-detail .hover-black-button button:active,
  body:has(.layout-header) .item-detail .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.layout-header) .item-detail .hover-black-button a:active::before, body:has(.layout-header) .item-detail .hover-black-button a:active::after,
  body:has(.layout-header) .item-detail .hover-black-button button:active::before,
  body:has(.layout-header) .item-detail .hover-black-button button:active::after,
  body:has(.layout-header) .item-detail .hover-black-button label:active::before,
  body:has(.layout-header) .item-detail .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
body:has(.layout-header) .item-detail .hover-black-button a::before, body:has(.layout-header) .item-detail .hover-black-button a::after,
body:has(.layout-header) .item-detail .hover-black-button button::before,
body:has(.layout-header) .item-detail .hover-black-button button::after,
body:has(.layout-header) .item-detail .hover-black-button label::before,
body:has(.layout-header) .item-detail .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
body:has(.layout-header) .item-detail .hover-white-button a,
body:has(.layout-header) .item-detail .hover-white-button button,
body:has(.layout-header) .item-detail .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.layout-header) .item-detail .hover-white-button a:hover,
  body:has(.layout-header) .item-detail .hover-white-button button:hover,
  body:has(.layout-header) .item-detail .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.layout-header) .item-detail .hover-white-button a:hover::before, body:has(.layout-header) .item-detail .hover-white-button a:hover::after,
  body:has(.layout-header) .item-detail .hover-white-button button:hover::before,
  body:has(.layout-header) .item-detail .hover-white-button button:hover::after,
  body:has(.layout-header) .item-detail .hover-white-button label:hover::before,
  body:has(.layout-header) .item-detail .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  body:has(.layout-header) .item-detail .hover-white-button a:active,
  body:has(.layout-header) .item-detail .hover-white-button button:active,
  body:has(.layout-header) .item-detail .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.layout-header) .item-detail .hover-white-button a:active::before, body:has(.layout-header) .item-detail .hover-white-button a:active::after,
  body:has(.layout-header) .item-detail .hover-white-button button:active::before,
  body:has(.layout-header) .item-detail .hover-white-button button:active::after,
  body:has(.layout-header) .item-detail .hover-white-button label:active::before,
  body:has(.layout-header) .item-detail .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
body:has(.layout-header) .item-detail .hover-white-button a::before, body:has(.layout-header) .item-detail .hover-white-button a::after,
body:has(.layout-header) .item-detail .hover-white-button button::before,
body:has(.layout-header) .item-detail .hover-white-button button::after,
body:has(.layout-header) .item-detail .hover-white-button label::before,
body:has(.layout-header) .item-detail .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
body:has(.layout-header) .item-detail .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  body:has(.layout-header) .item-detail .tips__nav__list.-fixed {
    top: 62px;
  }
}
@media (max-width: 768px) {
  body:has(.layout-header) .item-detail {
    margin-top: -14px !important;
  }
}
@media screen and (min-width: 769px) {
  body:has(.header-nav-links__item.is-hover) .only-sp, body:has(.header-head__hamburger button.is-clicked) .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  body:has(.header-nav-links__item.is-hover) .only-pc, body:has(.header-head__hamburger button.is-clicked) .only-pc {
    display: none !important;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-opacity a,
body:has(.header-nav-links__item.is-hover) .hover-opacity button,
body:has(.header-nav-links__item.is-hover) .hover-opacity label, body:has(.header-head__hamburger button.is-clicked) .hover-opacity a,
body:has(.header-head__hamburger button.is-clicked) .hover-opacity button,
body:has(.header-head__hamburger button.is-clicked) .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-opacity a:hover,
  body:has(.header-nav-links__item.is-hover) .hover-opacity button:hover,
  body:has(.header-nav-links__item.is-hover) .hover-opacity label:hover, body:has(.header-head__hamburger button.is-clicked) .hover-opacity a:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-opacity button:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-opacity a:active,
  body:has(.header-nav-links__item.is-hover) .hover-opacity button:active,
  body:has(.header-nav-links__item.is-hover) .hover-opacity label:active, body:has(.header-head__hamburger button.is-clicked) .hover-opacity a:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-opacity button:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-write a:hover span,
  body:has(.header-nav-links__item.is-hover) .hover-write button:hover span,
  body:has(.header-nav-links__item.is-hover) .hover-write label:hover span, body:has(.header-head__hamburger button.is-clicked) .hover-write a:hover span,
  body:has(.header-head__hamburger button.is-clicked) .hover-write button:hover span,
  body:has(.header-head__hamburger button.is-clicked) .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-write a:active span,
  body:has(.header-nav-links__item.is-hover) .hover-write button:active span,
  body:has(.header-nav-links__item.is-hover) .hover-write label:active span, body:has(.header-head__hamburger button.is-clicked) .hover-write a:active span,
  body:has(.header-head__hamburger button.is-clicked) .hover-write button:active span,
  body:has(.header-head__hamburger button.is-clicked) .hover-write label:active span {
    background-size: 100% 1px;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-write a span,
body:has(.header-nav-links__item.is-hover) .hover-write button span,
body:has(.header-nav-links__item.is-hover) .hover-write label span, body:has(.header-head__hamburger button.is-clicked) .hover-write a span,
body:has(.header-head__hamburger button.is-clicked) .hover-write button span,
body:has(.header-head__hamburger button.is-clicked) .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-rewrite a:hover span::before,
  body:has(.header-nav-links__item.is-hover) .hover-rewrite button:hover span::before,
  body:has(.header-nav-links__item.is-hover) .hover-rewrite label:hover span::before, body:has(.header-head__hamburger button.is-clicked) .hover-rewrite a:hover span::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-rewrite button:hover span::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-rewrite a:active span::before,
  body:has(.header-nav-links__item.is-hover) .hover-rewrite button:active span::before,
  body:has(.header-nav-links__item.is-hover) .hover-rewrite label:active span::before, body:has(.header-head__hamburger button.is-clicked) .hover-rewrite a:active span::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-rewrite button:active span::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-rewrite a span,
body:has(.header-nav-links__item.is-hover) .hover-rewrite button span,
body:has(.header-nav-links__item.is-hover) .hover-rewrite label span, body:has(.header-head__hamburger button.is-clicked) .hover-rewrite a span,
body:has(.header-head__hamburger button.is-clicked) .hover-rewrite button span,
body:has(.header-head__hamburger button.is-clicked) .hover-rewrite label span {
  position: relative;
}
body:has(.header-nav-links__item.is-hover) .hover-rewrite a span::before,
body:has(.header-nav-links__item.is-hover) .hover-rewrite button span::before,
body:has(.header-nav-links__item.is-hover) .hover-rewrite label span::before, body:has(.header-head__hamburger button.is-clicked) .hover-rewrite a span::before,
body:has(.header-head__hamburger button.is-clicked) .hover-rewrite button span::before,
body:has(.header-head__hamburger button.is-clicked) .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) a:has(.hover-arrow):hover .hover-arrow::before, body:has(.header-head__hamburger button.is-clicked) a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) a:has(.hover-arrow):active .hover-arrow::before, body:has(.header-head__hamburger button.is-clicked) a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body:has(.header-nav-links__item.is-hover) a:has(.hover-arrow) .hover-arrow, body:has(.header-head__hamburger button.is-clicked) a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
body:has(.header-nav-links__item.is-hover) a:has(.hover-arrow) .hover-arrow::before, body:has(.header-head__hamburger button.is-clicked) a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-image a:hover figure img,
  body:has(.header-nav-links__item.is-hover) .hover-image button:hover figure img,
  body:has(.header-nav-links__item.is-hover) .hover-image label:hover figure img, body:has(.header-head__hamburger button.is-clicked) .hover-image a:hover figure img,
  body:has(.header-head__hamburger button.is-clicked) .hover-image button:hover figure img,
  body:has(.header-head__hamburger button.is-clicked) .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-image a:active figure img,
  body:has(.header-nav-links__item.is-hover) .hover-image button:active figure img,
  body:has(.header-nav-links__item.is-hover) .hover-image label:active figure img, body:has(.header-head__hamburger button.is-clicked) .hover-image a:active figure img,
  body:has(.header-head__hamburger button.is-clicked) .hover-image button:active figure img,
  body:has(.header-head__hamburger button.is-clicked) .hover-image label:active figure img {
    scale: 1.08;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-image a figure,
body:has(.header-nav-links__item.is-hover) .hover-image button figure,
body:has(.header-nav-links__item.is-hover) .hover-image label figure, body:has(.header-head__hamburger button.is-clicked) .hover-image a figure,
body:has(.header-head__hamburger button.is-clicked) .hover-image button figure,
body:has(.header-head__hamburger button.is-clicked) .hover-image label figure {
  overflow: hidden;
}
body:has(.header-nav-links__item.is-hover) .hover-image a figure img,
body:has(.header-nav-links__item.is-hover) .hover-image button figure img,
body:has(.header-nav-links__item.is-hover) .hover-image label figure img, body:has(.header-head__hamburger button.is-clicked) .hover-image a figure img,
body:has(.header-head__hamburger button.is-clicked) .hover-image button figure img,
body:has(.header-head__hamburger button.is-clicked) .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
body:has(.header-nav-links__item.is-hover) .hover-black-button a,
body:has(.header-nav-links__item.is-hover) .hover-black-button button,
body:has(.header-nav-links__item.is-hover) .hover-black-button label, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button button,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-black-button a:hover,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:hover,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:hover, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.header-nav-links__item.is-hover) .hover-black-button a:hover::before, body:has(.header-nav-links__item.is-hover) .hover-black-button a:hover::after,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:hover::before,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:hover::after,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:hover::before,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:hover::after, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:hover::before, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:hover::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:hover::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:hover::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:hover::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-black-button a:active,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:active,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:active, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body:has(.header-nav-links__item.is-hover) .hover-black-button a:active::before, body:has(.header-nav-links__item.is-hover) .hover-black-button a:active::after,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:active::before,
  body:has(.header-nav-links__item.is-hover) .hover-black-button button:active::after,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:active::before,
  body:has(.header-nav-links__item.is-hover) .hover-black-button label:active::after, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:active::before, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a:active::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:active::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button button:active::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:active::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-black-button a::before, body:has(.header-nav-links__item.is-hover) .hover-black-button a::after,
body:has(.header-nav-links__item.is-hover) .hover-black-button button::before,
body:has(.header-nav-links__item.is-hover) .hover-black-button button::after,
body:has(.header-nav-links__item.is-hover) .hover-black-button label::before,
body:has(.header-nav-links__item.is-hover) .hover-black-button label::after, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a::before, body:has(.header-head__hamburger button.is-clicked) .hover-black-button a::after,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button button::before,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button button::after,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button label::before,
body:has(.header-head__hamburger button.is-clicked) .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
body:has(.header-nav-links__item.is-hover) .hover-white-button a,
body:has(.header-nav-links__item.is-hover) .hover-white-button button,
body:has(.header-nav-links__item.is-hover) .hover-white-button label, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button button,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body:has(.header-nav-links__item.is-hover) .hover-white-button a:hover,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:hover,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:hover, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:hover,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.header-nav-links__item.is-hover) .hover-white-button a:hover::before, body:has(.header-nav-links__item.is-hover) .hover-white-button a:hover::after,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:hover::before,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:hover::after,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:hover::before,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:hover::after, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:hover::before, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:hover::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:hover::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:hover::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:hover::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  body:has(.header-nav-links__item.is-hover) .hover-white-button a:active,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:active,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:active, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:active,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body:has(.header-nav-links__item.is-hover) .hover-white-button a:active::before, body:has(.header-nav-links__item.is-hover) .hover-white-button a:active::after,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:active::before,
  body:has(.header-nav-links__item.is-hover) .hover-white-button button:active::after,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:active::before,
  body:has(.header-nav-links__item.is-hover) .hover-white-button label:active::after, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:active::before, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a:active::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:active::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button button:active::after,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:active::before,
  body:has(.header-head__hamburger button.is-clicked) .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
body:has(.header-nav-links__item.is-hover) .hover-white-button a::before, body:has(.header-nav-links__item.is-hover) .hover-white-button a::after,
body:has(.header-nav-links__item.is-hover) .hover-white-button button::before,
body:has(.header-nav-links__item.is-hover) .hover-white-button button::after,
body:has(.header-nav-links__item.is-hover) .hover-white-button label::before,
body:has(.header-nav-links__item.is-hover) .hover-white-button label::after, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a::before, body:has(.header-head__hamburger button.is-clicked) .hover-white-button a::after,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button button::before,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button button::after,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button label::before,
body:has(.header-head__hamburger button.is-clicked) .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
body:has(.header-nav-links__item.is-hover) .tips__nav__list.-fixed, body:has(.header-head__hamburger button.is-clicked) .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  body:has(.header-nav-links__item.is-hover) .tips__nav__list.-fixed, body:has(.header-head__hamburger button.is-clicked) .tips__nav__list.-fixed {
    top: 62px;
  }
}
body:has(.header-nav-links__item.is-hover)::before, body:has(.header-head__hamburger button.is-clicked)::before {
  opacity: 0.2;
  visibility: visible;
}
body:has(.header-nav-links__item.is-hover) .layout-header::after, body:has(.header-head__hamburger button.is-clicked) .layout-header::after {
  opacity: 1 !important;
}
@media screen and (min-width: 769px) {
  body:has(.header-nav-links__item.is-hover) .layout-header .header-nav-mega::after, body:has(.header-head__hamburger button.is-clicked) .layout-header .header-nav-mega::after {
    opacity: 1 !important;
  }
}
body:has(.header-nav-links__item.is-hover) .layout-header .header-head__hamburger button::before, body:has(.header-head__hamburger button.is-clicked) .layout-header .header-head__hamburger button::before {
  translate: 0 calc(0.55 * var(--rem));
  rotate: -30deg;
}
body:has(.header-nav-links__item.is-hover) .layout-header .header-head__hamburger button::after, body:has(.header-head__hamburger button.is-clicked) .layout-header .header-head__hamburger button::after {
  translate: 0 calc(-0.55 * var(--rem));
  rotate: 30deg;
}
@media screen and (max-width: 768px) {
  body:has(.header-nav-links__item.is-hover) .layout-header .header-nav, body:has(.header-head__hamburger button.is-clicked) .layout-header .header-nav {
    grid-template-rows: 1fr !important;
    opacity: 1;
    visibility: visible;
  }
}
body.is-locked {
  overflow: hidden;
}
body.is-locked .layout-container .layout-header,
body.is-locked .layout-container .layout-content,
body.is-locked .layout-container .layout-footer {
  overflow: auto;
  scrollbar-gutter: stable;
}
body.is-header-fixed {
  padding-top: 0;
}
body.is-header-fixed .layout-header {
  position: fixed;
}
@media screen and (min-width: 769px) {
  body.is-header-white .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  body.is-header-white .only-pc {
    display: none !important;
  }
}
body.is-header-white .hover-opacity a,
body.is-header-white .hover-opacity button,
body.is-header-white .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body.is-header-white .hover-opacity a:hover,
  body.is-header-white .hover-opacity button:hover,
  body.is-header-white .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  body.is-header-white .hover-opacity a:active,
  body.is-header-white .hover-opacity button:active,
  body.is-header-white .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  body.is-header-white .hover-write a:hover span,
  body.is-header-white .hover-write button:hover span,
  body.is-header-white .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  body.is-header-white .hover-write a:active span,
  body.is-header-white .hover-write button:active span,
  body.is-header-white .hover-write label:active span {
    background-size: 100% 1px;
  }
}
body.is-header-white .hover-write a span,
body.is-header-white .hover-write button span,
body.is-header-white .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body.is-header-white .hover-rewrite a:hover span::before,
  body.is-header-white .hover-rewrite button:hover span::before,
  body.is-header-white .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body.is-header-white .hover-rewrite a:active span::before,
  body.is-header-white .hover-rewrite button:active span::before,
  body.is-header-white .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body.is-header-white .hover-rewrite a span,
body.is-header-white .hover-rewrite button span,
body.is-header-white .hover-rewrite label span {
  position: relative;
}
body.is-header-white .hover-rewrite a span::before,
body.is-header-white .hover-rewrite button span::before,
body.is-header-white .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  body.is-header-white a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  body.is-header-white a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
body.is-header-white a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
body.is-header-white a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  body.is-header-white .hover-image a:hover figure img,
  body.is-header-white .hover-image button:hover figure img,
  body.is-header-white .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  body.is-header-white .hover-image a:active figure img,
  body.is-header-white .hover-image button:active figure img,
  body.is-header-white .hover-image label:active figure img {
    scale: 1.08;
  }
}
body.is-header-white .hover-image a figure,
body.is-header-white .hover-image button figure,
body.is-header-white .hover-image label figure {
  overflow: hidden;
}
body.is-header-white .hover-image a figure img,
body.is-header-white .hover-image button figure img,
body.is-header-white .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
body.is-header-white .hover-black-button a,
body.is-header-white .hover-black-button button,
body.is-header-white .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body.is-header-white .hover-black-button a:hover,
  body.is-header-white .hover-black-button button:hover,
  body.is-header-white .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body.is-header-white .hover-black-button a:hover::before, body.is-header-white .hover-black-button a:hover::after,
  body.is-header-white .hover-black-button button:hover::before,
  body.is-header-white .hover-black-button button:hover::after,
  body.is-header-white .hover-black-button label:hover::before,
  body.is-header-white .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  body.is-header-white .hover-black-button a:active,
  body.is-header-white .hover-black-button button:active,
  body.is-header-white .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  body.is-header-white .hover-black-button a:active::before, body.is-header-white .hover-black-button a:active::after,
  body.is-header-white .hover-black-button button:active::before,
  body.is-header-white .hover-black-button button:active::after,
  body.is-header-white .hover-black-button label:active::before,
  body.is-header-white .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
body.is-header-white .hover-black-button a::before, body.is-header-white .hover-black-button a::after,
body.is-header-white .hover-black-button button::before,
body.is-header-white .hover-black-button button::after,
body.is-header-white .hover-black-button label::before,
body.is-header-white .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
body.is-header-white .hover-white-button a,
body.is-header-white .hover-white-button button,
body.is-header-white .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  body.is-header-white .hover-white-button a:hover,
  body.is-header-white .hover-white-button button:hover,
  body.is-header-white .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body.is-header-white .hover-white-button a:hover::before, body.is-header-white .hover-white-button a:hover::after,
  body.is-header-white .hover-white-button button:hover::before,
  body.is-header-white .hover-white-button button:hover::after,
  body.is-header-white .hover-white-button label:hover::before,
  body.is-header-white .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  body.is-header-white .hover-white-button a:active,
  body.is-header-white .hover-white-button button:active,
  body.is-header-white .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  body.is-header-white .hover-white-button a:active::before, body.is-header-white .hover-white-button a:active::after,
  body.is-header-white .hover-white-button button:active::before,
  body.is-header-white .hover-white-button button:active::after,
  body.is-header-white .hover-white-button label:active::before,
  body.is-header-white .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
body.is-header-white .hover-white-button a::before, body.is-header-white .hover-white-button a::after,
body.is-header-white .hover-white-button button::before,
body.is-header-white .hover-white-button button::after,
body.is-header-white .hover-white-button label::before,
body.is-header-white .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
body.is-header-white .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  body.is-header-white .tips__nav__list.-fixed {
    top: 62px;
  }
}
body.is-header-white .layout-header::after {
  opacity: 0;
}
body.is-header-white .header-head__logo path {
  fill: #fff !important;
}
body.is-header-white .header-head__button a,
body.is-header-white .header-nav-language-links__item,
body.is-header-white .header-nav-links__text a span,
body.is-header-white .header-nav-links__text button span {
  color: #fff !important;
}
body.is-header-white .header-head__button a {
  border-color: #fff !important;
}
@media (hover: hover) {
  body.is-header-white .header-head__button a:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
}
@media (hover: none) {
  body.is-header-white .header-head__button a:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
}
@media (hover: hover) {
  body.is-header-white .header-nav-language-links a span:hover,
  body.is-header-white .header-nav-language-links__item a span:hover {
    background-image: linear-gradient(#fff) !important;
    color: #fff !important;
  }
}
@media (hover: none) {
  body.is-header-white .header-nav-language-links a span:active,
  body.is-header-white .header-nav-language-links__item a span:active {
    background-image: linear-gradient(#fff) !important;
    color: #fff !important;
  }
}
body.is-header-white .header-nav-language-links__item:not(:has(a))::after {
  background-color: #fff !important;
}
body.is-header-white .header-nav-links__text a span,
body.is-header-white .header-nav-language-links__item a span {
  background-image: linear-gradient(#fff) !important;
}
body.is-header-white .header-head__hamburger button::before, body.is-header-white .header-head__hamburger button::after {
  background-color: #fff !important;
}
body.is-header-white.is-scrolled .layout-header::after, body.is-header-white:has(.header-nav-links__item.is-hover) .layout-header::after, body.is-header-white:has(.header-head__hamburger button.is-clicked) .layout-header::after {
  opacity: 0.9;
}
body.is-header-white.is-scrolled .header-head__logo path, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__logo path, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__logo path {
  fill: #231815 !important;
}
body.is-header-white.is-scrolled .header-head__button a,
body.is-header-white.is-scrolled .header-nav-language-links__item,
body.is-header-white.is-scrolled .header-nav-links__text a span,
body.is-header-white.is-scrolled .header-nav-links__text button span, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__button a,
body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item,
body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-links__text a span,
body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-links__text button span, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__button a,
body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item,
body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-links__text a span,
body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-links__text button span {
  color: #231815 !important;
}
body.is-header-white.is-scrolled .header-head__button a, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__button a, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__button a {
  border-color: #231815 !important;
}
@media (hover: hover) {
  body.is-header-white.is-scrolled .header-head__button a:hover, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__button a:hover, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__button a:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
}
@media (hover: none) {
  body.is-header-white.is-scrolled .header-head__button a:active, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__button a:active, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__button a:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
}
@media (hover: hover) {
  body.is-header-white.is-scrolled .header-nav-language-links a span:hover,
  body.is-header-white.is-scrolled .header-nav-language-links__item a span:hover, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links a span:hover,
  body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item a span:hover, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links a span:hover,
  body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item a span:hover {
    color: #231815 !important;
  }
  body.is-header-white.is-scrolled .header-nav-language-links a span:hover::after,
  body.is-header-white.is-scrolled .header-nav-language-links__item a span:hover::after, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links a span:hover::after,
  body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item a span:hover::after, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links a span:hover::after,
  body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item a span:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  body.is-header-white.is-scrolled .header-nav-language-links a span:active,
  body.is-header-white.is-scrolled .header-nav-language-links__item a span:active, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links a span:active,
  body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item a span:active, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links a span:active,
  body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item a span:active {
    color: #231815 !important;
  }
  body.is-header-white.is-scrolled .header-nav-language-links a span:active::after,
  body.is-header-white.is-scrolled .header-nav-language-links__item a span:active::after, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links a span:active::after,
  body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item a span:active::after, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links a span:active::after,
  body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item a span:active::after {
    background-color: #231815 !important;
  }
}
body.is-header-white.is-scrolled .header-nav-language-links__item:not(:has(a))::after, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item:not(:has(a))::after, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item:not(:has(a))::after {
  background-color: #231815 !important;
}
body.is-header-white.is-scrolled .header-nav-links__text a span,
body.is-header-white.is-scrolled .header-nav-language-links__item a span, body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-links__text a span,
body.is-header-white:has(.header-nav-links__item.is-hover) .header-nav-language-links__item a span, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-links__text a span,
body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-nav-language-links__item a span {
  background-image: linear-gradient(#231815) !important;
}
body.is-header-white.is-scrolled .header-head__hamburger button::before, body.is-header-white.is-scrolled .header-head__hamburger button::after, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__hamburger button::before, body.is-header-white:has(.header-nav-links__item.is-hover) .header-head__hamburger button::after, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__hamburger button::before, body.is-header-white:has(.header-head__hamburger button.is-clicked) .header-head__hamburger button::after {
  background-color: #231815 !important;
}
body.is-breadcrumb-none .component-breadcrumb--footer {
  display: none !important;
}
body.is-l-footer-none .l-footer {
  display: none !important;
}
body.on-hamburger .gift-overlay {
  opacity: 0.2;
  visibility: visible;
}
body.on-hamburger .gift-header__hamburger button::before, body.on-hamburger .gift-header__hamburger button::after {
  translate: -50% 0;
}
body.on-hamburger .gift-header__hamburger button::before {
  rotate: 30deg;
}
body.on-hamburger .gift-header__hamburger button::after {
  rotate: -30deg;
}
body.on-hamburger .gift-header-links {
  translate: 0 !important;
}

.component-breadcrumb {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  line-height: 1;
  margin-top: calc(3.8 * var(--rem));
}
@media screen and (min-width: 769px) {
  .component-breadcrumb .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .component-breadcrumb .only-pc {
    display: none !important;
  }
}
.component-breadcrumb .hover-opacity a,
.component-breadcrumb .hover-opacity button,
.component-breadcrumb .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .component-breadcrumb .hover-opacity a:hover,
  .component-breadcrumb .hover-opacity button:hover,
  .component-breadcrumb .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-opacity a:active,
  .component-breadcrumb .hover-opacity button:active,
  .component-breadcrumb .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  .component-breadcrumb .hover-write a:hover span,
  .component-breadcrumb .hover-write button:hover span,
  .component-breadcrumb .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-write a:active span,
  .component-breadcrumb .hover-write button:active span,
  .component-breadcrumb .hover-write label:active span {
    background-size: 100% 1px;
  }
}
.component-breadcrumb .hover-write a span,
.component-breadcrumb .hover-write button span,
.component-breadcrumb .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .component-breadcrumb .hover-rewrite a:hover span::before,
  .component-breadcrumb .hover-rewrite button:hover span::before,
  .component-breadcrumb .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-rewrite a:active span::before,
  .component-breadcrumb .hover-rewrite button:active span::before,
  .component-breadcrumb .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.component-breadcrumb .hover-rewrite a span,
.component-breadcrumb .hover-rewrite button span,
.component-breadcrumb .hover-rewrite label span {
  position: relative;
}
.component-breadcrumb .hover-rewrite a span::before,
.component-breadcrumb .hover-rewrite button span::before,
.component-breadcrumb .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  .component-breadcrumb a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .component-breadcrumb a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.component-breadcrumb a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
.component-breadcrumb a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  .component-breadcrumb .hover-image a:hover figure img,
  .component-breadcrumb .hover-image button:hover figure img,
  .component-breadcrumb .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-image a:active figure img,
  .component-breadcrumb .hover-image button:active figure img,
  .component-breadcrumb .hover-image label:active figure img {
    scale: 1.08;
  }
}
.component-breadcrumb .hover-image a figure,
.component-breadcrumb .hover-image button figure,
.component-breadcrumb .hover-image label figure {
  overflow: hidden;
}
.component-breadcrumb .hover-image a figure img,
.component-breadcrumb .hover-image button figure img,
.component-breadcrumb .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
.component-breadcrumb .hover-black-button a,
.component-breadcrumb .hover-black-button button,
.component-breadcrumb .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .component-breadcrumb .hover-black-button a:hover,
  .component-breadcrumb .hover-black-button button:hover,
  .component-breadcrumb .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .component-breadcrumb .hover-black-button a:hover::before, .component-breadcrumb .hover-black-button a:hover::after,
  .component-breadcrumb .hover-black-button button:hover::before,
  .component-breadcrumb .hover-black-button button:hover::after,
  .component-breadcrumb .hover-black-button label:hover::before,
  .component-breadcrumb .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-black-button a:active,
  .component-breadcrumb .hover-black-button button:active,
  .component-breadcrumb .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .component-breadcrumb .hover-black-button a:active::before, .component-breadcrumb .hover-black-button a:active::after,
  .component-breadcrumb .hover-black-button button:active::before,
  .component-breadcrumb .hover-black-button button:active::after,
  .component-breadcrumb .hover-black-button label:active::before,
  .component-breadcrumb .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
.component-breadcrumb .hover-black-button a::before, .component-breadcrumb .hover-black-button a::after,
.component-breadcrumb .hover-black-button button::before,
.component-breadcrumb .hover-black-button button::after,
.component-breadcrumb .hover-black-button label::before,
.component-breadcrumb .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.component-breadcrumb .hover-white-button a,
.component-breadcrumb .hover-white-button button,
.component-breadcrumb .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .component-breadcrumb .hover-white-button a:hover,
  .component-breadcrumb .hover-white-button button:hover,
  .component-breadcrumb .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .component-breadcrumb .hover-white-button a:hover::before, .component-breadcrumb .hover-white-button a:hover::after,
  .component-breadcrumb .hover-white-button button:hover::before,
  .component-breadcrumb .hover-white-button button:hover::after,
  .component-breadcrumb .hover-white-button label:hover::before,
  .component-breadcrumb .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  .component-breadcrumb .hover-white-button a:active,
  .component-breadcrumb .hover-white-button button:active,
  .component-breadcrumb .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .component-breadcrumb .hover-white-button a:active::before, .component-breadcrumb .hover-white-button a:active::after,
  .component-breadcrumb .hover-white-button button:active::before,
  .component-breadcrumb .hover-white-button button:active::after,
  .component-breadcrumb .hover-white-button label:active::before,
  .component-breadcrumb .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
.component-breadcrumb .hover-white-button a::before, .component-breadcrumb .hover-white-button a::after,
.component-breadcrumb .hover-white-button button::before,
.component-breadcrumb .hover-white-button button::after,
.component-breadcrumb .hover-white-button label::before,
.component-breadcrumb .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
.component-breadcrumb .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  .component-breadcrumb .tips__nav__list.-fixed {
    top: 62px;
  }
}
.component-breadcrumb *,
.component-breadcrumb *::before,
.component-breadcrumb *::after {
  box-sizing: border-box;
}
.component-breadcrumb * {
  margin: 0;
}
.component-breadcrumb body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.component-breadcrumb img,
.component-breadcrumb picture,
.component-breadcrumb video,
.component-breadcrumb canvas,
.component-breadcrumb svg {
  display: block;
  max-width: 100%;
}
.component-breadcrumb input,
.component-breadcrumb button,
.component-breadcrumb textarea,
.component-breadcrumb select {
  font: inherit;
}
.component-breadcrumb p,
.component-breadcrumb h1,
.component-breadcrumb h2,
.component-breadcrumb h3,
.component-breadcrumb h4,
.component-breadcrumb h5,
.component-breadcrumb h6 {
  overflow-wrap: break-word;
}
.component-breadcrumb #root,
.component-breadcrumb #__next {
  isolation: isolate;
}
.component-breadcrumb * {
  letter-spacing: 0.1em;
}
.component-breadcrumb *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.component-breadcrumb a,
.component-breadcrumb button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.component-breadcrumb a *,
.component-breadcrumb button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.component-breadcrumb h1,
.component-breadcrumb h2,
.component-breadcrumb h3,
.component-breadcrumb h4,
.component-breadcrumb h5,
.component-breadcrumb h6 {
  font-size: inherit;
  font-weight: inherit;
}
.component-breadcrumb ul,
.component-breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.component-breadcrumb a {
  color: #231815;
  text-decoration: none;
}
.component-breadcrumb em {
  font-style: normal;
}
.component-breadcrumb sup {
  font-size: 0.5em;
}
.component-breadcrumb img,
.component-breadcrumb picture,
.component-breadcrumb video,
.component-breadcrumb canvas,
.component-breadcrumb svg {
  height: auto;
}
.component-breadcrumb svg {
  overflow: visible;
}
.component-breadcrumb img,
.component-breadcrumb iframe,
.component-breadcrumb video {
  display: block;
  width: 100%;
  height: auto;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  pointer-events: auto;
}
.component-breadcrumb picture {
  display: contents;
}
.component-breadcrumb button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .component-breadcrumb {
    width: auto;
    margin-top: calc(1.6 * var(--rem));
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.component-breadcrumb .component-breadcrumb-links {
  display: flex;
}
.component-breadcrumb .component-breadcrumb-links__item:not(:has(a)), .component-breadcrumb .component-breadcrumb-links__item a span {
  display: flex;
  align-items: center;
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .component-breadcrumb .component-breadcrumb-links__item:not(:has(a)), .component-breadcrumb .component-breadcrumb-links__item a span {
    font-size: calc(1 * var(--rem));
  }
}
.component-breadcrumb .component-breadcrumb-links__item {
  display: flex;
  align-items: center;
}
.component-breadcrumb .component-breadcrumb-links__item a span {
  padding: calc(0.2 * var(--rem)) 0;
  color: #898989;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .component-breadcrumb .component-breadcrumb-links__item a span:hover {
    color: #231815;
  }
}
@media (hover: none) {
  .component-breadcrumb .component-breadcrumb-links__item a span:active {
    color: #231815;
  }
}
.component-breadcrumb .component-breadcrumb-links__item:nth-of-type(n + 2)::before {
  margin: 0 calc(1.2 * var(--rem));
  content: "/";
}
@media screen and (max-width: 768px) {
  .component-breadcrumb .component-breadcrumb-links__item:nth-of-type(n + 2)::before {
    margin: 0 calc(1 * var(--rem));
  }
}

.layout-footer {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  margin-top: calc(3.8 * var(--rem));
  background-color: #000;
  font-weight: 400;
  font-size: calc(1.4 * var(--rem));
  line-height: 1.8571428571;
  letter-spacing: 0.1em;
  font-family: Yakuhanjp, "Noto Sans JP", sans-serif;
  text-align: justify;
  word-break: break-all;
  font-feature-settings: "palt" 1;
  font-optical-sizing: auto;
}
@media screen and (min-width: 769px) {
  .layout-footer .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .layout-footer .only-pc {
    display: none !important;
  }
}
.layout-footer .hover-opacity a,
.layout-footer .hover-opacity button,
.layout-footer .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-footer .hover-opacity a:hover,
  .layout-footer .hover-opacity button:hover,
  .layout-footer .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  .layout-footer .hover-opacity a:active,
  .layout-footer .hover-opacity button:active,
  .layout-footer .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  .layout-footer .hover-write a:hover span,
  .layout-footer .hover-write button:hover span,
  .layout-footer .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  .layout-footer .hover-write a:active span,
  .layout-footer .hover-write button:active span,
  .layout-footer .hover-write label:active span {
    background-size: 100% 1px;
  }
}
.layout-footer .hover-write a span,
.layout-footer .hover-write button span,
.layout-footer .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-footer .hover-rewrite a:hover span::before,
  .layout-footer .hover-rewrite button:hover span::before,
  .layout-footer .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-footer .hover-rewrite a:active span::before,
  .layout-footer .hover-rewrite button:active span::before,
  .layout-footer .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-footer .hover-rewrite a span,
.layout-footer .hover-rewrite button span,
.layout-footer .hover-rewrite label span {
  position: relative;
}
.layout-footer .hover-rewrite a span::before,
.layout-footer .hover-rewrite button span::before,
.layout-footer .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  .layout-footer a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-footer a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-footer a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
.layout-footer a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  .layout-footer .hover-image a:hover figure img,
  .layout-footer .hover-image button:hover figure img,
  .layout-footer .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  .layout-footer .hover-image a:active figure img,
  .layout-footer .hover-image button:active figure img,
  .layout-footer .hover-image label:active figure img {
    scale: 1.08;
  }
}
.layout-footer .hover-image a figure,
.layout-footer .hover-image button figure,
.layout-footer .hover-image label figure {
  overflow: hidden;
}
.layout-footer .hover-image a figure img,
.layout-footer .hover-image button figure img,
.layout-footer .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
.layout-footer .hover-black-button a,
.layout-footer .hover-black-button button,
.layout-footer .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-footer .hover-black-button a:hover,
  .layout-footer .hover-black-button button:hover,
  .layout-footer .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-footer .hover-black-button a:hover::before, .layout-footer .hover-black-button a:hover::after,
  .layout-footer .hover-black-button button:hover::before,
  .layout-footer .hover-black-button button:hover::after,
  .layout-footer .hover-black-button label:hover::before,
  .layout-footer .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  .layout-footer .hover-black-button a:active,
  .layout-footer .hover-black-button button:active,
  .layout-footer .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-footer .hover-black-button a:active::before, .layout-footer .hover-black-button a:active::after,
  .layout-footer .hover-black-button button:active::before,
  .layout-footer .hover-black-button button:active::after,
  .layout-footer .hover-black-button label:active::before,
  .layout-footer .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
.layout-footer .hover-black-button a::before, .layout-footer .hover-black-button a::after,
.layout-footer .hover-black-button button::before,
.layout-footer .hover-black-button button::after,
.layout-footer .hover-black-button label::before,
.layout-footer .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-footer .hover-white-button a,
.layout-footer .hover-white-button button,
.layout-footer .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-footer .hover-white-button a:hover,
  .layout-footer .hover-white-button button:hover,
  .layout-footer .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-footer .hover-white-button a:hover::before, .layout-footer .hover-white-button a:hover::after,
  .layout-footer .hover-white-button button:hover::before,
  .layout-footer .hover-white-button button:hover::after,
  .layout-footer .hover-white-button label:hover::before,
  .layout-footer .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  .layout-footer .hover-white-button a:active,
  .layout-footer .hover-white-button button:active,
  .layout-footer .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-footer .hover-white-button a:active::before, .layout-footer .hover-white-button a:active::after,
  .layout-footer .hover-white-button button:active::before,
  .layout-footer .hover-white-button button:active::after,
  .layout-footer .hover-white-button label:active::before,
  .layout-footer .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
.layout-footer .hover-white-button a::before, .layout-footer .hover-white-button a::after,
.layout-footer .hover-white-button button::before,
.layout-footer .hover-white-button button::after,
.layout-footer .hover-white-button label::before,
.layout-footer .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
.layout-footer .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  .layout-footer .tips__nav__list.-fixed {
    top: 62px;
  }
}
.layout-footer *,
.layout-footer *::before,
.layout-footer *::after {
  box-sizing: border-box;
}
.layout-footer * {
  margin: 0;
}
.layout-footer body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.layout-footer img,
.layout-footer picture,
.layout-footer video,
.layout-footer canvas,
.layout-footer svg {
  display: block;
  max-width: 100%;
}
.layout-footer input,
.layout-footer button,
.layout-footer textarea,
.layout-footer select {
  font: inherit;
}
.layout-footer p,
.layout-footer h1,
.layout-footer h2,
.layout-footer h3,
.layout-footer h4,
.layout-footer h5,
.layout-footer h6 {
  overflow-wrap: break-word;
}
.layout-footer #root,
.layout-footer #__next {
  isolation: isolate;
}
.layout-footer * {
  letter-spacing: 0.1em;
}
.layout-footer *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.layout-footer a,
.layout-footer button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-footer a *,
.layout-footer button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-footer h1,
.layout-footer h2,
.layout-footer h3,
.layout-footer h4,
.layout-footer h5,
.layout-footer h6 {
  font-size: inherit;
  font-weight: inherit;
}
.layout-footer ul,
.layout-footer ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.layout-footer a {
  color: #231815;
  text-decoration: none;
}
.layout-footer em {
  font-style: normal;
}
.layout-footer sup {
  font-size: 0.5em;
}
.layout-footer img,
.layout-footer picture,
.layout-footer video,
.layout-footer canvas,
.layout-footer svg {
  height: auto;
}
.layout-footer svg {
  overflow: visible;
}
.layout-footer img,
.layout-footer iframe,
.layout-footer video {
  display: block;
  width: 100%;
  height: auto;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  pointer-events: auto;
}
.layout-footer picture {
  display: contents;
}
.layout-footer button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .layout-footer {
    margin-top: calc(1.6 * var(--rem));
    font-size: calc(1.2 * var(--rem));
    line-height: 2;
  }
}
.layout-footer * {
  color: #fff !important;
}
.layout-footer__inner {
  position: relative;
  padding: calc(3 * var(--rem)) calc(2 * var(--rem)) calc(3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer__inner {
    padding: calc(2.4 * var(--rem)) calc(2 * var(--rem)) calc(3.6 * var(--rem));
  }
}
.layout-footer .footer-top {
  padding: 0 calc(1 * var(--rem));
  text-align: right;
  line-height: 1;
}
.layout-footer .footer-top a {
  display: inline-flex;
  align-items: center;
  gap: calc(0.4 * var(--rem));
  font-size: calc(1.2 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-top a {
    font-size: calc(1 * var(--rem));
  }
}
.layout-footer .footer-top a .hover-arrow {
  width: calc(1 * var(--rem));
  height: calc(1 * var(--rem));
  rotate: -90deg;
}
.layout-footer .footer-top a .hover-arrow::before {
  background-color: #fff;
}
.layout-footer .footer-nav {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
  gap: calc(5 * var(--rem)) calc(17.6 * var(--rem));
  margin-top: calc(3.8 * var(--rem));
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav {
    flex-direction: column;
    margin-top: calc(2.2 * var(--rem));
  }
}
.layout-footer .footer-nav .footer-nav-contents {
  display: flex;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents {
    flex-wrap: wrap;
    gap: calc(5.4 * var(--rem)) calc(6 * var(--rem));
  }
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(1) {
    width: 100%;
  }
}
.layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(2) {
  margin-left: calc(13 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(2) {
    margin-left: 0;
  }
}
.layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(3) {
  margin-left: calc(16.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(3) {
    margin-left: 0;
  }
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents__item:nth-of-type(n + 2) {
    width: calc(50% - calc(3 * var(--rem)));
  }
}
.layout-footer .footer-nav .footer-nav-contents__text:not(:has(a)), .layout-footer .footer-nav .footer-nav-contents__text a {
  font-size: calc(1.6 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-footer .footer-nav .footer-nav-contents__text:nth-of-type(n + 2) {
  margin-top: calc(2.8 * var(--rem));
}
.layout-footer .footer-nav .footer-nav-contents__text a span {
  background-image: linear-gradient(#fff);
}
.layout-footer .footer-nav .footer-nav-contents__content {
  display: flex;
  gap: calc(7.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents__content {
    gap: calc(6 * var(--rem));
  }
}
.layout-footer .footer-nav .footer-nav-contents .footer-nav-contents-links {
  display: flex;
  flex-direction: column;
  gap: calc(1.6 * var(--rem));
  margin-top: calc(1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-contents .footer-nav-contents-links {
    gap: calc(1.4 * var(--rem));
    width: 100%;
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-footer .footer-nav .footer-nav-contents .footer-nav-contents-links a span {
  background-image: linear-gradient(#fff);
  font-size: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav__content {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
.layout-footer .footer-nav .footer-nav-links {
  display: flex;
  flex-direction: column;
  gap: calc(2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-links {
    width: 100%;
  }
}
.layout-footer .footer-nav .footer-nav-links a span {
  padding: calc(0.4 * var(--rem)) 0;
  background-image: linear-gradient(#fff);
  font-size: calc(1.2 * var(--rem));
}
.layout-footer .footer-nav .footer-nav-links a[target=_blank] span {
  display: inline-flex;
  align-items: center;
  gap: calc(0.8 * var(--rem));
}
.layout-footer .footer-nav .footer-nav-links a[target=_blank] span::after {
  display: block;
  width: calc(1 * var(--rem));
  height: calc(1 * var(--rem));
  content: "";
  background-color: #fff;
  -webkit-mask: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
          mask: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav .footer-nav-sns, .layout-footer .footer-nav__button {
    margin-top: calc(3.2 * var(--rem)) !important;
  }
}
.layout-footer .footer-nav .footer-nav-sns {
  display: flex;
  align-items: center;
  gap: calc(2.4 * var(--rem));
  margin-top: calc(5.2 * var(--rem));
}
.layout-footer .footer-nav .footer-nav-sns__item {
  width: calc(2.7 * var(--rem));
}
.layout-footer .footer-nav__button {
  margin-top: calc(2.6 * var(--rem));
}
.layout-footer .footer-nav__button a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(18 * var(--rem));
  height: calc(5 * var(--rem));
  gap: calc(0.8 * var(--rem));
  border: 1px solid #fff;
  border-radius: calc(5 * var(--rem));
  font-size: calc(1.4 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-nav__button a {
    height: calc(6 * var(--rem));
  }
}
.layout-footer .footer-nav__button a::after {
  display: block;
  width: calc(1 * var(--rem));
  height: calc(1 * var(--rem));
  content: "";
  background-color: #fff;
  -webkit-mask: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
          mask: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
}
.layout-footer .footer-foot {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: calc(12 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-foot {
    flex-direction: column;
    align-items: center;
    margin-top: calc(3.6 * var(--rem));
  }
}
.layout-footer .footer-foot .footer-foot-language {
  display: flex;
  align-items: center;
  gap: calc(2.4 * var(--rem));
  order: 1;
  padding-right: calc(1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-foot .footer-foot-language {
    order: 0;
    padding-right: 0;
  }
}
.layout-footer .footer-foot .footer-foot-language__label {
  font-size: calc(1 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links {
  display: flex;
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item {
  display: flex;
  align-items: center;
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item a, .layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:not(:has(a)) {
  font-size: calc(1.2 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item a, .layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:not(:has(a)) {
    font-size: calc(1.4 * var(--rem));
  }
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:first-of-type {
  position: relative;
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:first-of-type::after {
  display: block;
  width: calc(0.3 * var(--rem));
  height: calc(0.3 * var(--rem));
  content: "";
  position: absolute;
  bottom: calc(0.2 * var(--rem));
  left: calc(50% - calc(0.2 * var(--rem)));
  translate: -50% 0;
  border-radius: 50%;
  background-color: #fff;
  transition: background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:nth-of-type(n + 2)::before {
  margin: 0 calc(0.6 * var(--rem));
  color: #898989 !important;
  content: "｜";
}
.layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:nth-of-type(n + 2) a span {
  background-image: linear-gradient(#fff);
  color: #898989 !important;
  transition: background 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:nth-of-type(n + 2) a span:hover {
    color: #fff !important;
  }
}
@media (hover: none) {
  .layout-footer .footer-foot .footer-foot-language .footer-foot-language-links__item:nth-of-type(n + 2) a span:active {
    color: #fff !important;
  }
}
.layout-footer .footer-foot__logo {
  position: absolute;
  bottom: calc(2.8 * var(--rem));
  left: 50%;
  translate: -50% 0;
  width: calc(20.9 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-foot__logo {
    position: static;
    translate: 0;
    margin-top: calc(4.8 * var(--rem));
  }
}
.layout-footer .footer-foot__logo svg path {
  fill: #fff;
}
.layout-footer .footer-foot__copy {
  order: -1;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-footer .footer-foot__copy {
    order: 0;
    margin-top: calc(3.2 * var(--rem));
    text-align: center;
  }
}
.layout-footer .footer-foot__copy-logo {
  display: inline-block;
  width: calc(6.2 * var(--rem));
}
.layout-footer .footer-foot__copy-text {
  display: block;
  margin-top: calc(1 * var(--rem));
  font-size: calc(1 * var(--rem));
}