@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;
}

.layout-header {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  position: sticky;
  top: 0;
  right: 0;
  left: 0;
  z-index: 9999;
  margin-bottom: calc(10 * var(--rem));
  background-color: transparent !important;
  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;
  white-space: nowrap;
  scrollbar-gutter: stable;
}
@media screen and (min-width: 769px) {
  .layout-header .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .only-pc {
    display: none !important;
  }
}
.layout-header .hover-opacity a,
.layout-header .hover-opacity button,
.layout-header .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-header .hover-opacity a:hover,
  .layout-header .hover-opacity button:hover,
  .layout-header .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  .layout-header .hover-opacity a:active,
  .layout-header .hover-opacity button:active,
  .layout-header .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  .layout-header .hover-write a:hover span,
  .layout-header .hover-write button:hover span,
  .layout-header .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  .layout-header .hover-write a:active span,
  .layout-header .hover-write button:active span,
  .layout-header .hover-write label:active span {
    background-size: 100% 1px;
  }
}
.layout-header .hover-write a span,
.layout-header .hover-write button span,
.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 (hover: hover) {
  .layout-header .hover-rewrite a:hover span::before,
  .layout-header .hover-rewrite button:hover span::before,
  .layout-header .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-header .hover-rewrite a:active span::before,
  .layout-header .hover-rewrite button:active span::before,
  .layout-header .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-header .hover-rewrite a span,
.layout-header .hover-rewrite button span,
.layout-header .hover-rewrite label span {
  position: relative;
}
.layout-header .hover-rewrite a span::before,
.layout-header .hover-rewrite button span::before,
.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 (hover: hover) {
  .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 (hover: none) {
  .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;
  }
}
.layout-header a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
.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 (hover: hover) {
  .layout-header .hover-image a:hover figure img,
  .layout-header .hover-image button:hover figure img,
  .layout-header .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  .layout-header .hover-image a:active figure img,
  .layout-header .hover-image button:active figure img,
  .layout-header .hover-image label:active figure img {
    scale: 1.08;
  }
}
.layout-header .hover-image a figure,
.layout-header .hover-image button figure,
.layout-header .hover-image label figure {
  overflow: hidden;
}
.layout-header .hover-image a figure img,
.layout-header .hover-image button figure img,
.layout-header .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
.layout-header .hover-black-button a,
.layout-header .hover-black-button button,
.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 (hover: hover) {
  .layout-header .hover-black-button a:hover,
  .layout-header .hover-black-button button:hover,
  .layout-header .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-header .hover-black-button a:hover::before, .layout-header .hover-black-button a:hover::after,
  .layout-header .hover-black-button button:hover::before,
  .layout-header .hover-black-button button:hover::after,
  .layout-header .hover-black-button label:hover::before,
  .layout-header .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  .layout-header .hover-black-button a:active,
  .layout-header .hover-black-button button:active,
  .layout-header .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-header .hover-black-button a:active::before, .layout-header .hover-black-button a:active::after,
  .layout-header .hover-black-button button:active::before,
  .layout-header .hover-black-button button:active::after,
  .layout-header .hover-black-button label:active::before,
  .layout-header .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
.layout-header .hover-black-button a::before, .layout-header .hover-black-button a::after,
.layout-header .hover-black-button button::before,
.layout-header .hover-black-button button::after,
.layout-header .hover-black-button label::before,
.layout-header .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-header .hover-white-button a,
.layout-header .hover-white-button button,
.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 (hover: hover) {
  .layout-header .hover-white-button a:hover,
  .layout-header .hover-white-button button:hover,
  .layout-header .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-header .hover-white-button a:hover::before, .layout-header .hover-white-button a:hover::after,
  .layout-header .hover-white-button button:hover::before,
  .layout-header .hover-white-button button:hover::after,
  .layout-header .hover-white-button label:hover::before,
  .layout-header .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  .layout-header .hover-white-button a:active,
  .layout-header .hover-white-button button:active,
  .layout-header .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-header .hover-white-button a:active::before, .layout-header .hover-white-button a:active::after,
  .layout-header .hover-white-button button:active::before,
  .layout-header .hover-white-button button:active::after,
  .layout-header .hover-white-button label:active::before,
  .layout-header .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
.layout-header .hover-white-button a::before, .layout-header .hover-white-button a::after,
.layout-header .hover-white-button button::before,
.layout-header .hover-white-button button::after,
.layout-header .hover-white-button label::before,
.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;
  }
}
.layout-header .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  .layout-header .tips__nav__list.-fixed {
    top: 62px;
  }
}
.layout-header *,
.layout-header *::before,
.layout-header *::after {
  box-sizing: border-box;
}
.layout-header * {
  margin: 0;
}
.layout-header body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.layout-header img,
.layout-header picture,
.layout-header video,
.layout-header canvas,
.layout-header svg {
  display: block;
  max-width: 100%;
}
.layout-header input,
.layout-header button,
.layout-header textarea,
.layout-header select {
  font: inherit;
}
.layout-header p,
.layout-header h1,
.layout-header h2,
.layout-header h3,
.layout-header h4,
.layout-header h5,
.layout-header h6 {
  overflow-wrap: break-word;
}
.layout-header #root,
.layout-header #__next {
  isolation: isolate;
}
.layout-header * {
  letter-spacing: 0.1em;
}
.layout-header *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.layout-header a,
.layout-header button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-header a *,
.layout-header button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-header h1,
.layout-header h2,
.layout-header h3,
.layout-header h4,
.layout-header h5,
.layout-header h6 {
  font-size: inherit;
  font-weight: inherit;
}
.layout-header ul,
.layout-header ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.layout-header a {
  color: #231815;
  text-decoration: none;
}
.layout-header em {
  font-style: normal;
}
.layout-header sup {
  font-size: 0.5em;
}
.layout-header img,
.layout-header picture,
.layout-header video,
.layout-header canvas,
.layout-header svg {
  height: auto;
}
.layout-header svg {
  overflow: visible;
}
.layout-header img,
.layout-header iframe,
.layout-header 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-header picture {
  display: contents;
}
.layout-header button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .layout-header {
    position: fixed;
    margin-bottom: 0;
    font-size: calc(1.2 * var(--rem));
    line-height: 2;
  }
}
.layout-header * {
  color: #231815 !important;
}
.layout-header::after,
.layout-header .header-nav-mega::after {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: #fff;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: opacity;
}
.layout-header::after {
  opacity: 1;
}
.layout-header .header-nav-mega::after {
  opacity: 0;
}
.layout-header .header-nav-language-links__item,
.layout-header .header-nav-links__text a,
.layout-header .header-nav-links__text button {
  transition: color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-header__inner {
  display: flex;
  align-items: center;
  height: calc(8 * var(--rem));
  padding: 0 calc(2.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header__inner {
    height: calc(6.3 * var(--rem));
    padding: 0 0 0 calc(1.4 * var(--rem));
  }
}
.layout-header .header-head {
  display: contents;
}
@media screen and (max-width: 768px) {
  .layout-header .header-head {
    display: flex;
    align-items: center;
    width: 100%;
    height: 100%;
  }
}
.layout-header .header-head > * {
  position: relative;
  z-index: 1;
}
.layout-header .header-head__logo a {
  display: block;
  width: calc(10.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-head__logo a {
    width: calc(9.1 * var(--rem));
  }
}
.layout-header .header-head__logo a svg path {
  fill: #231815;
  transition: fill 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: fill;
}
.layout-header .header-head__button {
  order: 1;
  margin-left: calc(3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-head__button {
    order: 0;
    margin-left: auto;
  }
}
.layout-header .header-head__button a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(12.2 * var(--rem));
  height: calc(3 * var(--rem));
  border: 1px solid #231815;
  border-radius: calc(3 * var(--rem));
  color: #231815;
  font-size: calc(1.2 * 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-header .header-head__button a {
    width: calc(12.7 * var(--rem));
    height: calc(2.6 * var(--rem));
    font-weight: 500;
    font-size: calc(1.2 * var(--rem));
  }
}
.layout-header .header-head__hamburger {
  height: 100%;
}
.layout-header .header-head__hamburger button {
  width: calc(7.2 * var(--rem));
  height: 100%;
  position: relative;
  padding: 0 calc(1.8 * var(--rem));
}
.layout-header .header-head__hamburger button::before, .layout-header .header-head__hamburger button::after {
  display: block;
  width: calc(3.2 * var(--rem));
  height: 1px;
  content: "";
  position: absolute;
  left: calc(50% - calc(1.6 * var(--rem)));
  background-color: #231815;
  transition: translate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), rotate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: translate, scale;
}
.layout-header .header-head__hamburger button::before {
  top: calc(50% - calc(0.6 * var(--rem)));
}
.layout-header .header-head__hamburger button::after {
  bottom: calc(50% - calc(0.6 * var(--rem)));
}
.layout-header .header-nav {
  height: 100%;
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav {
    position: absolute;
    top: calc(6.3 * var(--rem));
    right: 0;
    bottom: 0;
    left: 0;
    display: grid;
    grid-template-rows: 0fr;
    opacity: 0;
    visibility: hidden;
    height: calc(100dvh - calc(6.3 * var(--rem)));
    background-color: #fff;
    transition: grid-template-rows 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), visibility 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
    will-change: opacity;
  }
}
.layout-header .header-nav__wrapper {
  display: contents;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav__wrapper {
    display: block;
    overflow: hidden;
  }
}
.layout-header .header-nav__inner {
  display: flex;
  align-items: center;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav__inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    overflow: auto;
    padding: calc(3.6 * var(--rem)) calc(2 * var(--rem)) calc(2 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-language-links,
  .layout-header .header-nav .header-nav-links__text {
    translate: calc(9.2 * var(--rem)) 0;
    transition: translate 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
    will-change: translate;
  }
}
.layout-header .header-nav .header-nav-language {
  display: flex;
  align-items: center;
  gap: calc(2.4 * var(--rem));
  order: 1;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-language {
    overflow: visible;
    margin-top: calc(2.4 * var(--rem));
  }
}
@media (hover: hover) {
  .layout-header .header-nav .header-nav-language:hover .header-nav-language-links {
    translate: 0;
  }
  .layout-header .header-nav .header-nav-language:hover .header-nav-language-links__item:nth-of-type(n + 2) {
    opacity: 1;
    transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.2s;
  }
  .layout-header .header-nav .header-nav-language:hover + .header-nav-links .header-nav-links__text {
    translate: 0;
  }
}
@media (hover: none) {
  .layout-header .header-nav .header-nav-language:active .header-nav-language-links {
    translate: 0;
  }
  .layout-header .header-nav .header-nav-language:active .header-nav-language-links__item:nth-of-type(n + 2) {
    opacity: 1;
    transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0.2s;
  }
  .layout-header .header-nav .header-nav-language:active + .header-nav-links .header-nav-links__text {
    translate: 0;
  }
}
.layout-header .header-nav .header-nav-language__label {
  font-size: calc(1 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-header .header-nav .header-nav-language .header-nav-language-links {
  display: flex;
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item {
  display: flex;
  align-items: center;
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item a, .layout-header .header-nav .header-nav-language .header-nav-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-header .header-nav .header-nav-language .header-nav-language-links__item a, .layout-header .header-nav .header-nav-language .header-nav-language-links__item:not(:has(a)) {
    font-size: calc(1.4 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item:first-of-type {
  position: relative;
  color: #231815;
  pointer-events: none;
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item:first-of-type::after {
  display: block;
  width: calc(0.4 * var(--rem));
  height: calc(0.4 * var(--rem));
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - calc(0.2 * var(--rem)));
  translate: -50% 0;
  border-radius: 50%;
  background-color: #231815;
  transition: background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-language .header-nav-language-links__item:first-of-type::after {
    width: calc(0.3 * var(--rem));
    height: calc(0.3 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-language .header-nav-language-links__item:nth-of-type(n + 2) {
    opacity: 0;
    transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1) 0s;
  }
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item:nth-of-type(n + 2)::before {
  margin: 0 calc(0.6 * var(--rem));
  color: #898989;
  content: "｜";
}
.layout-header .header-nav .header-nav-language .header-nav-language-links__item:nth-of-type(n + 2) a span {
  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) {
  .layout-header .header-nav .header-nav-language .header-nav-language-links__item:nth-of-type(n + 2) a span:hover {
    color: #231815;
  }
}
@media (hover: none) {
  .layout-header .header-nav .header-nav-language .header-nav-language-links__item:nth-of-type(n + 2) a span:active {
    color: #231815;
  }
}
.layout-header .header-nav .header-nav-links {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: flex-end;
  height: 100%;
  padding-right: calc(31 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links {
    flex-direction: column;
    gap: calc(2.8 * var(--rem));
    position: static;
    height: auto;
    padding: 0 calc(2 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links__item {
  height: 100%;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__item {
    height: auto;
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(1) .header-nav-links__text a {
    width: calc(14.7 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(2) .header-nav-links__text a {
    width: calc(13.7 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(3) .header-nav-links__text a {
    width: calc(10.4 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(4) .header-nav-links__text a {
    width: calc(8.8 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(5) .header-nav-links__text a {
    width: calc(15.7 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item:nth-of-type(6) .header-nav-links__text a {
    width: calc(9.9 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-header .header-nav .header-nav-links__item.is-hover .header-nav-mega {
    grid-template-rows: 1fr !important;
  }
}
.layout-header .header-nav .header-nav-links__text {
  height: 100%;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text {
    height: auto;
  }
}
.layout-header .header-nav .header-nav-links__text a {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding: 0 calc(2.6 * var(--rem));
  color: #231815;
  font-family: Yakuhanjp, "Figtree", sans-serif;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a {
    display: inline-block;
    padding: calc(0.8 * var(--rem)) 0;
    font-size: calc(2.4 * var(--rem));
    line-height: 1;
  }
}
.layout-header .header-nav .header-nav-links__text a span {
  padding: calc(0.5 * var(--rem)) 0;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a span {
    background-size: 100% 1px;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a.js-header-click span {
    padding-right: calc(3.8 * var(--rem));
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a.js-header-click span::before, .layout-header .header-nav .header-nav-links__text a.js-header-click span::after {
    display: block;
    width: calc(1.6 * var(--rem));
    height: 1px;
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    translate: 0 -50%;
    background-color: #231815;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a.js-header-click span::before {
    rotate: -90deg;
    transition: rotate 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
    will-change: rotate;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links__text a.js-header-click.is-clicked span::before {
    rotate: 0deg;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega {
  position: absolute;
  top: calc(8 * var(--rem));
  right: 0;
  left: 0;
  z-index: 1;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega {
    position: static;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega.is-clicked {
    grid-template-rows: 1fr !important;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega__inner {
    padding-bottom: calc(5 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega-contents__item:nth-of-type(n + 2) {
  margin-top: calc(6.8 * var(--rem));
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega-contents__item:nth-of-type(2) {
  margin-left: calc(8.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega-contents__item:nth-of-type(2) {
    margin: calc(3.2 * var(--rem)) 0 0;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega-contents__item:nth-of-type(3) {
  margin-left: calc(3.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-products .header-nav-mega-contents__item:nth-of-type(3) {
    margin: calc(2.6 * var(--rem)) 0 0;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega__inner {
    padding-bottom: calc(2.4 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(n + 3) {
  margin-left: calc(8.2 * var(--rem));
  padding-left: calc(8.2 * var(--rem));
  border-left: 1px solid #e6e6e6;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(n + 3) {
    padding: 0;
    border: none;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(2) {
    margin: calc(2.6 * var(--rem)) 0 0;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(3) {
    margin: calc(4 * var(--rem)) 0 0;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(3) .header-nav-mega-contents-links {
  width: calc(21.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(3) .header-nav-mega-contents-links {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(3) .header-nav-mega-contents-links__item {
    width: calc(50% - calc(1.7 * var(--rem)));
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(4) {
    margin: calc(5 * var(--rem)) 0 0;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega#header-store .header-nav-mega-contents__item:nth-of-type(4) .header-nav-mega-contents-links {
  flex-direction: column;
}
.layout-header .header-nav .header-nav-links .header-nav-mega__wrapper {
  overflow: hidden;
}
.layout-header .header-nav .header-nav-links .header-nav-mega__inner {
  width: 100%;
  max-width: calc(100 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  height: calc(34.8 * var(--rem));
  padding-top: calc(3.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega__inner {
    height: auto;
    padding-top: calc(3.2 * var(--rem));
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega__label {
  display: flex;
  align-items: center;
  gap: calc(3 * var(--rem));
  line-height: 1;
}
.layout-header .header-nav .header-nav-links .header-nav-mega__label-en {
  font-size: calc(3 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents {
  display: flex;
  margin-top: calc(3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents {
    flex-direction: column;
    margin-top: 0;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents * {
  letter-spacing: 0.2em;
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__item-inner {
  width: 100%;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label {
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label {
    font-size: calc(1.2 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label--small {
  font-size: calc(1.2 * var(--rem));
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label--en {
  position: relative;
  font-size: calc(1.2 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label--en {
    display: inline-flex;
    align-items: center;
    gap: calc(0.8 * var(--rem));
    padding: calc(0.8 * var(--rem)) 0;
    font-family: Yakuhanjp, "Noto Sans JP", sans-serif;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label--en::before {
    display: block;
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    transform-origin: right center;
    height: 1px;
    background-color: #231815;
    will-change: scale;
  }
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label--en::after {
    display: block;
    width: calc(1 * var(--rem));
    height: calc(1 * var(--rem));
    content: "";
    background: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label + * {
  margin-top: calc(2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__label + * {
    margin-top: calc(1.8 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__image {
  width: calc(25.7 * var(--rem));
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products {
  display: flex;
  gap: calc(2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products {
    flex-direction: column;
    gap: calc(1 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products__item a {
  display: block;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products__item a {
    display: flex;
    align-items: center;
    gap: calc(3 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products__image {
  width: calc(9.3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products__image {
    width: calc(8.4 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-products__text {
  margin-top: calc(1 * var(--rem));
  font-size: calc(1.2 * var(--rem));
  line-height: 1.5;
  text-align: center;
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__link a span,
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links__item a span {
  padding: calc(1 * var(--rem)) 0;
  font-size: calc(1.2 * var(--rem));
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__link a span,
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links__item a span {
    padding: calc(0.8 * var(--rem)) 0;
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__link a[target=_blank] span,
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links__item a[target=_blank] span {
  display: inline-flex;
  align-items: center;
  gap: calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__link a[target=_blank] span,
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links__item a[target=_blank] span {
    gap: calc(0.8 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents__link a[target=_blank] span::after,
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links__item a[target=_blank] span::after {
  display: block;
  width: calc(1 * var(--rem));
  height: calc(1 * var(--rem));
  content: "";
  background: url("/assets/img/common/icn_window.svg") no-repeat center/contain;
}
.layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links {
  display: flex;
  flex-wrap: wrap;
  gap: calc(2 * var(--rem)) calc(3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-header .header-nav .header-nav-links .header-nav-mega .header-nav-mega-contents .header-nav-mega-contents-links {
    gap: calc(2 * var(--rem)) calc(3.4 * var(--rem));
    padding: 0 calc(2 * var(--rem));
  }
}
.layout-header .header-nav .header-nav-sns {
  display: flex;
  align-items: center;
  gap: calc(1.8 * var(--rem));
  margin-top: auto;
  padding-top: calc(7 * var(--rem));
}
.layout-header .header-nav .header-nav-sns__item {
  width: calc(2.5 * var(--rem));
}

.header-clone {
  display: none !important;
}