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

body {
  margin: 0;
}

.layout-container {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  background: #fff;
  color: #231815;
  font-weight: 400;
  font-size: calc(1.4 * var(--rem));
  line-height: 1.8571428571;
  letter-spacing: 0.1em;
  font-family: Yakuhanjp, "Noto Sans JP", sans-serif;
  text-align: justify;
  word-break: break-all;
  font-feature-settings: "palt" 1;
  font-optical-sizing: auto;
}
@media screen and (min-width: 769px) {
  .layout-container .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .layout-container .only-pc {
    display: none !important;
  }
}
.layout-container .hover-opacity a,
.layout-container .hover-opacity button,
.layout-container .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .hover-opacity a:hover,
  .layout-container .hover-opacity button:hover,
  .layout-container .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  .layout-container .hover-opacity a:active,
  .layout-container .hover-opacity button:active,
  .layout-container .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  .layout-container .hover-write a:hover span,
  .layout-container .hover-write button:hover span,
  .layout-container .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  .layout-container .hover-write a:active span,
  .layout-container .hover-write button:active span,
  .layout-container .hover-write label:active span {
    background-size: 100% 1px;
  }
}
.layout-container .hover-write a span,
.layout-container .hover-write button span,
.layout-container .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-container .hover-rewrite a:hover span::before,
  .layout-container .hover-rewrite button:hover span::before,
  .layout-container .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-container .hover-rewrite a:active span::before,
  .layout-container .hover-rewrite button:active span::before,
  .layout-container .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container .hover-rewrite a span,
.layout-container .hover-rewrite button span,
.layout-container .hover-rewrite label span {
  position: relative;
}
.layout-container .hover-rewrite a span::before,
.layout-container .hover-rewrite button span::before,
.layout-container .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-container 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-container a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
.layout-container 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-container .hover-image a:hover figure img,
  .layout-container .hover-image button:hover figure img,
  .layout-container .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  .layout-container .hover-image a:active figure img,
  .layout-container .hover-image button:active figure img,
  .layout-container .hover-image label:active figure img {
    scale: 1.08;
  }
}
.layout-container .hover-image a figure,
.layout-container .hover-image button figure,
.layout-container .hover-image label figure {
  overflow: hidden;
}
.layout-container .hover-image a figure img,
.layout-container .hover-image button figure img,
.layout-container .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
.layout-container .hover-black-button a,
.layout-container .hover-black-button button,
.layout-container .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-container .hover-black-button a:hover,
  .layout-container .hover-black-button button:hover,
  .layout-container .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-container .hover-black-button a:hover::before, .layout-container .hover-black-button a:hover::after,
  .layout-container .hover-black-button button:hover::before,
  .layout-container .hover-black-button button:hover::after,
  .layout-container .hover-black-button label:hover::before,
  .layout-container .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  .layout-container .hover-black-button a:active,
  .layout-container .hover-black-button button:active,
  .layout-container .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-container .hover-black-button a:active::before, .layout-container .hover-black-button a:active::after,
  .layout-container .hover-black-button button:active::before,
  .layout-container .hover-black-button button:active::after,
  .layout-container .hover-black-button label:active::before,
  .layout-container .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
.layout-container .hover-black-button a::before, .layout-container .hover-black-button a::after,
.layout-container .hover-black-button button::before,
.layout-container .hover-black-button button::after,
.layout-container .hover-black-button label::before,
.layout-container .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .hover-white-button a,
.layout-container .hover-white-button button,
.layout-container .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-container .hover-white-button a:hover,
  .layout-container .hover-white-button button:hover,
  .layout-container .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-container .hover-white-button a:hover::before, .layout-container .hover-white-button a:hover::after,
  .layout-container .hover-white-button button:hover::before,
  .layout-container .hover-white-button button:hover::after,
  .layout-container .hover-white-button label:hover::before,
  .layout-container .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  .layout-container .hover-white-button a:active,
  .layout-container .hover-white-button button:active,
  .layout-container .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-container .hover-white-button a:active::before, .layout-container .hover-white-button a:active::after,
  .layout-container .hover-white-button button:active::before,
  .layout-container .hover-white-button button:active::after,
  .layout-container .hover-white-button label:active::before,
  .layout-container .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
.layout-container .hover-white-button a::before, .layout-container .hover-white-button a::after,
.layout-container .hover-white-button button::before,
.layout-container .hover-white-button button::after,
.layout-container .hover-white-button label::before,
.layout-container .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-container .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  .layout-container .tips__nav__list.-fixed {
    top: 62px;
  }
}
.layout-container *,
.layout-container *::before,
.layout-container *::after {
  box-sizing: border-box;
}
.layout-container * {
  margin: 0;
}
.layout-container body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.layout-container img,
.layout-container picture,
.layout-container video,
.layout-container canvas,
.layout-container svg {
  display: block;
  max-width: 100%;
}
.layout-container input,
.layout-container button,
.layout-container textarea,
.layout-container select {
  font: inherit;
}
.layout-container p,
.layout-container h1,
.layout-container h2,
.layout-container h3,
.layout-container h4,
.layout-container h5,
.layout-container h6 {
  overflow-wrap: break-word;
}
.layout-container #root,
.layout-container #__next {
  isolation: isolate;
}
.layout-container * {
  letter-spacing: 0.1em;
}
.layout-container *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.layout-container a,
.layout-container button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container a *,
.layout-container button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container h1,
.layout-container h2,
.layout-container h3,
.layout-container h4,
.layout-container h5,
.layout-container h6 {
  font-size: inherit;
  font-weight: inherit;
}
.layout-container ul,
.layout-container ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.layout-container a {
  color: #231815;
  text-decoration: none;
}
.layout-container em {
  font-style: normal;
}
.layout-container sup {
  font-size: 0.5em;
}
.layout-container img,
.layout-container picture,
.layout-container video,
.layout-container canvas,
.layout-container svg {
  height: auto;
}
.layout-container svg {
  overflow: visible;
}
.layout-container img,
.layout-container iframe,
.layout-container 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-container picture {
  display: contents;
}
.layout-container button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
.layout-container .splide__container {
  box-sizing: border-box;
  position: relative;
}
.layout-container .splide__list {
  backface-visibility: hidden;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}
.layout-container .splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}
.layout-container .splide__pagination {
  display: flex;
}
.layout-container .splide:not(.is-overflow) .splide__pagination {
  display: none;
}
.layout-container .splide__progress__bar {
  width: 0;
}
.layout-container .splide {
  position: relative;
  visibility: hidden;
}
.layout-container .splide.is-initialized,
.layout-container .splide.is-rendered {
  visibility: visible;
}
.layout-container .splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}
.layout-container .splide__slide img {
  vertical-align: bottom;
}
.layout-container .splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}
.layout-container .splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}
.layout-container .splide__toggle.is-active .splide__toggle__play,
.layout-container .splide__toggle__pause {
  display: none;
}
.layout-container .splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}
.layout-container .splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}
@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.layout-container .splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
       user-select: none;
}
.layout-container .splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}
.layout-container .splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}
.layout-container .splide--rtl {
  direction: rtl;
}
.layout-container .splide__track--ttb > .splide__list {
  display: block;
}
.layout-container .splide__arrow svg {
  display: none;
}
.layout-container .splide__pagination__page {
  display: block;
}
.layout-container .splide__progress__bar {
  background: #ccc;
  height: 3px;
}
.layout-container .splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.layout-container .splide__slide:focus {
  outline: 0;
}
@supports (outline-offset: -3px) {
  .layout-container .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .layout-container .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .layout-container .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .layout-container .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }
  .layout-container .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.layout-container .splide__toggle {
  cursor: pointer;
}
.layout-container .splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}
.layout-container .splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}
.layout-container .splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}
.layout-container .splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}
@media screen and (max-width: 768px) {
  .layout-container {
    font-size: calc(1.2 * var(--rem));
    line-height: 2;
  }
}
.layout-container .component-breadcrumb {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  line-height: 1;
  margin-top: calc(3.8 * var(--rem));
}
@media screen and (min-width: 769px) {
  .layout-container .component-breadcrumb .only-sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .layout-container .component-breadcrumb .only-pc {
    display: none !important;
  }
}
.layout-container .component-breadcrumb .hover-opacity a,
.layout-container .component-breadcrumb .hover-opacity button,
.layout-container .component-breadcrumb .hover-opacity label {
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-opacity a:hover,
  .layout-container .component-breadcrumb .hover-opacity button:hover,
  .layout-container .component-breadcrumb .hover-opacity label:hover {
    opacity: 0.6;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-opacity a:active,
  .layout-container .component-breadcrumb .hover-opacity button:active,
  .layout-container .component-breadcrumb .hover-opacity label:active {
    opacity: 0.6;
  }
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-write a:hover span,
  .layout-container .component-breadcrumb .hover-write button:hover span,
  .layout-container .component-breadcrumb .hover-write label:hover span {
    background-size: 100% 1px;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-write a:active span,
  .layout-container .component-breadcrumb .hover-write button:active span,
  .layout-container .component-breadcrumb .hover-write label:active span {
    background-size: 100% 1px;
  }
}
.layout-container .component-breadcrumb .hover-write a span,
.layout-container .component-breadcrumb .hover-write button span,
.layout-container .component-breadcrumb .hover-write label span {
  position: relative;
  background: linear-gradient(#231815) no-repeat left bottom/0% 1px;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-rewrite a:hover span::before,
  .layout-container .component-breadcrumb .hover-rewrite button:hover span::before,
  .layout-container .component-breadcrumb .hover-rewrite label:hover span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-rewrite a:active span::before,
  .layout-container .component-breadcrumb .hover-rewrite button:active span::before,
  .layout-container .component-breadcrumb .hover-rewrite label:active span::before {
    animation: rewrite-after 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container .component-breadcrumb .hover-rewrite a span,
.layout-container .component-breadcrumb .hover-rewrite button span,
.layout-container .component-breadcrumb .hover-rewrite label span {
  position: relative;
}
.layout-container .component-breadcrumb .hover-rewrite a span::before,
.layout-container .component-breadcrumb .hover-rewrite button span::before,
.layout-container .component-breadcrumb .hover-rewrite label span::before {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #231815;
}
@keyframes rewrite-after {
  0% {
    scale: 1;
    transform-origin: right center;
  }
  50% {
    scale: 0 1;
    transform-origin: right center;
  }
  50.000001% {
    scale: 0 1;
    transform-origin: left center;
  }
  100% {
    scale: 1;
    transform-origin: left center;
  }
}
@media (hover: hover) {
  .layout-container .component-breadcrumb a:has(.hover-arrow):hover .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb a:has(.hover-arrow):active .hover-arrow::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container .component-breadcrumb a:has(.hover-arrow) .hover-arrow {
  display: block;
  overflow: hidden;
}
.layout-container .component-breadcrumb a:has(.hover-arrow) .hover-arrow::before {
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
          mask: url("/assets/img/common/arw.svg") no-repeat center/contain;
  will-change: translate;
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-image a:hover figure img,
  .layout-container .component-breadcrumb .hover-image button:hover figure img,
  .layout-container .component-breadcrumb .hover-image label:hover figure img {
    scale: 1.08;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-image a:active figure img,
  .layout-container .component-breadcrumb .hover-image button:active figure img,
  .layout-container .component-breadcrumb .hover-image label:active figure img {
    scale: 1.08;
  }
}
.layout-container .component-breadcrumb .hover-image a figure,
.layout-container .component-breadcrumb .hover-image button figure,
.layout-container .component-breadcrumb .hover-image label figure {
  overflow: hidden;
}
.layout-container .component-breadcrumb .hover-image a figure img,
.layout-container .component-breadcrumb .hover-image button figure img,
.layout-container .component-breadcrumb .hover-image label figure img {
  transition: scale 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: scale;
}
.layout-container .component-breadcrumb .hover-black-button a,
.layout-container .component-breadcrumb .hover-black-button button,
.layout-container .component-breadcrumb .hover-black-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-black-button a:hover,
  .layout-container .component-breadcrumb .hover-black-button button:hover,
  .layout-container .component-breadcrumb .hover-black-button label:hover {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-container .component-breadcrumb .hover-black-button a:hover::before, .layout-container .component-breadcrumb .hover-black-button a:hover::after,
  .layout-container .component-breadcrumb .hover-black-button button:hover::before,
  .layout-container .component-breadcrumb .hover-black-button button:hover::after,
  .layout-container .component-breadcrumb .hover-black-button label:hover::before,
  .layout-container .component-breadcrumb .hover-black-button label:hover::after {
    background-color: #231815 !important;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-black-button a:active,
  .layout-container .component-breadcrumb .hover-black-button button:active,
  .layout-container .component-breadcrumb .hover-black-button label:active {
    background-color: #fff !important;
    color: #231815 !important;
  }
  .layout-container .component-breadcrumb .hover-black-button a:active::before, .layout-container .component-breadcrumb .hover-black-button a:active::after,
  .layout-container .component-breadcrumb .hover-black-button button:active::before,
  .layout-container .component-breadcrumb .hover-black-button button:active::after,
  .layout-container .component-breadcrumb .hover-black-button label:active::before,
  .layout-container .component-breadcrumb .hover-black-button label:active::after {
    background-color: #231815 !important;
  }
}
.layout-container .component-breadcrumb .hover-black-button a::before, .layout-container .component-breadcrumb .hover-black-button a::after,
.layout-container .component-breadcrumb .hover-black-button button::before,
.layout-container .component-breadcrumb .hover-black-button button::after,
.layout-container .component-breadcrumb .hover-black-button label::before,
.layout-container .component-breadcrumb .hover-black-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .component-breadcrumb .hover-white-button a,
.layout-container .component-breadcrumb .hover-white-button button,
.layout-container .component-breadcrumb .hover-white-button label {
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .hover-white-button a:hover,
  .layout-container .component-breadcrumb .hover-white-button button:hover,
  .layout-container .component-breadcrumb .hover-white-button label:hover {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-container .component-breadcrumb .hover-white-button a:hover::before, .layout-container .component-breadcrumb .hover-white-button a:hover::after,
  .layout-container .component-breadcrumb .hover-white-button button:hover::before,
  .layout-container .component-breadcrumb .hover-white-button button:hover::after,
  .layout-container .component-breadcrumb .hover-white-button label:hover::before,
  .layout-container .component-breadcrumb .hover-white-button label:hover::after {
    background-color: #fff !important;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .hover-white-button a:active,
  .layout-container .component-breadcrumb .hover-white-button button:active,
  .layout-container .component-breadcrumb .hover-white-button label:active {
    border-color: #231815 !important;
    background-color: #231815 !important;
    color: #fff !important;
  }
  .layout-container .component-breadcrumb .hover-white-button a:active::before, .layout-container .component-breadcrumb .hover-white-button a:active::after,
  .layout-container .component-breadcrumb .hover-white-button button:active::before,
  .layout-container .component-breadcrumb .hover-white-button button:active::after,
  .layout-container .component-breadcrumb .hover-white-button label:active::before,
  .layout-container .component-breadcrumb .hover-white-button label:active::after {
    background-color: #fff !important;
  }
}
.layout-container .component-breadcrumb .hover-white-button a::before, .layout-container .component-breadcrumb .hover-white-button a::after,
.layout-container .component-breadcrumb .hover-white-button button::before,
.layout-container .component-breadcrumb .hover-white-button button::after,
.layout-container .component-breadcrumb .hover-white-button label::before,
.layout-container .component-breadcrumb .hover-white-button label::after {
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@keyframes translate-back {
  0% {
    translate: 0;
  }
  50% {
    translate: 100% 0;
  }
  50.000001% {
    translate: -100% 0;
  }
  100% {
    translate: 0;
  }
}
.layout-container .component-breadcrumb .tips__nav__list.-fixed {
  top: 80px;
}
@media screen and (max-width: 768px) {
  .layout-container .component-breadcrumb .tips__nav__list.-fixed {
    top: 62px;
  }
}
.layout-container .component-breadcrumb *,
.layout-container .component-breadcrumb *::before,
.layout-container .component-breadcrumb *::after {
  box-sizing: border-box;
}
.layout-container .component-breadcrumb * {
  margin: 0;
}
.layout-container .component-breadcrumb body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.layout-container .component-breadcrumb img,
.layout-container .component-breadcrumb picture,
.layout-container .component-breadcrumb video,
.layout-container .component-breadcrumb canvas,
.layout-container .component-breadcrumb svg {
  display: block;
  max-width: 100%;
}
.layout-container .component-breadcrumb input,
.layout-container .component-breadcrumb button,
.layout-container .component-breadcrumb textarea,
.layout-container .component-breadcrumb select {
  font: inherit;
}
.layout-container .component-breadcrumb p,
.layout-container .component-breadcrumb h1,
.layout-container .component-breadcrumb h2,
.layout-container .component-breadcrumb h3,
.layout-container .component-breadcrumb h4,
.layout-container .component-breadcrumb h5,
.layout-container .component-breadcrumb h6 {
  overflow-wrap: break-word;
}
.layout-container .component-breadcrumb #root,
.layout-container .component-breadcrumb #__next {
  isolation: isolate;
}
.layout-container .component-breadcrumb * {
  letter-spacing: 0.1em;
}
.layout-container .component-breadcrumb *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.layout-container .component-breadcrumb a,
.layout-container .component-breadcrumb button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container .component-breadcrumb a *,
.layout-container .component-breadcrumb button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container .component-breadcrumb h1,
.layout-container .component-breadcrumb h2,
.layout-container .component-breadcrumb h3,
.layout-container .component-breadcrumb h4,
.layout-container .component-breadcrumb h5,
.layout-container .component-breadcrumb h6 {
  font-size: inherit;
  font-weight: inherit;
}
.layout-container .component-breadcrumb ul,
.layout-container .component-breadcrumb ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.layout-container .component-breadcrumb a {
  color: #231815;
  text-decoration: none;
}
.layout-container .component-breadcrumb em {
  font-style: normal;
}
.layout-container .component-breadcrumb sup {
  font-size: 0.5em;
}
.layout-container .component-breadcrumb img,
.layout-container .component-breadcrumb picture,
.layout-container .component-breadcrumb video,
.layout-container .component-breadcrumb canvas,
.layout-container .component-breadcrumb svg {
  height: auto;
}
.layout-container .component-breadcrumb svg {
  overflow: visible;
}
.layout-container .component-breadcrumb img,
.layout-container .component-breadcrumb iframe,
.layout-container .component-breadcrumb video {
  display: block;
  width: 100%;
  height: auto;
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -o-user-drag: none;
  user-drag: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  pointer-events: auto;
}
.layout-container .component-breadcrumb picture {
  display: contents;
}
.layout-container .component-breadcrumb button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .layout-container .component-breadcrumb {
    width: auto;
    margin-top: calc(1.6 * var(--rem));
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.layout-container .component-breadcrumb .component-breadcrumb-links {
  display: flex;
}
.layout-container .component-breadcrumb .component-breadcrumb-links__item:not(:has(a)), .layout-container .component-breadcrumb .component-breadcrumb-links__item a span {
  display: flex;
  align-items: center;
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .layout-container .component-breadcrumb .component-breadcrumb-links__item:not(:has(a)), .layout-container .component-breadcrumb .component-breadcrumb-links__item a span {
    font-size: calc(1 * var(--rem));
  }
}
.layout-container .component-breadcrumb .component-breadcrumb-links__item {
  display: flex;
  align-items: center;
}
.layout-container .component-breadcrumb .component-breadcrumb-links__item a span {
  padding: calc(0.2 * var(--rem)) 0;
  color: #898989;
  transition: background-size 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .component-breadcrumb .component-breadcrumb-links__item a span:hover {
    color: #231815;
  }
}
@media (hover: none) {
  .layout-container .component-breadcrumb .component-breadcrumb-links__item a span:active {
    color: #231815;
  }
}
.layout-container .component-breadcrumb .component-breadcrumb-links__item:nth-of-type(n + 2)::before {
  margin: 0 calc(1.2 * var(--rem));
  content: "/";
}
@media screen and (max-width: 768px) {
  .layout-container .component-breadcrumb .component-breadcrumb-links__item:nth-of-type(n + 2)::before {
    margin: 0 calc(1 * var(--rem));
  }
}
.layout-container .component-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  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);
  will-change: opacity;
}
.layout-container .component-modal:has(.component-modal__content.is-modal-active) {
  opacity: 1;
  visibility: visible;
}
.layout-container .component-modal__overlay {
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: #231815;
  opacity: 0.3;
}
.layout-container .component-modal__wrapper {
  position: absolute;
  inset: 0;
  overflow: auto;
  pointer-events: none;
}
.layout-container .component-modal__inner {
  display: flex;
  align-items: center;
  position: relative;
  min-height: 100%;
  padding: calc(11 * var(--rem)) 0;
}
@media screen and (max-width: 768px) {
  .layout-container .component-modal__inner {
    padding: calc(8 * var(--rem)) calc(2 * var(--rem));
  }
}
.layout-container .component-modal__inner > * {
  pointer-events: auto;
}
.layout-container .component-modal__close {
  position: absolute;
  top: calc(-4 * var(--rem));
  right: 0;
}
.layout-container .component-modal__close button {
  width: calc(2 * var(--rem));
  height: calc(2 * var(--rem));
  display: block;
  position: relative;
}
.layout-container .component-modal__close button::before, .layout-container .component-modal__close button::after {
  display: block;
  width: calc(2.5 * var(--rem));
  height: calc(0.2 * var(--rem));
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(0.2 * var(--rem));
  background-color: #fff;
  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-container .component-modal__close button::before {
  rotate: -45deg;
}
.layout-container .component-modal__close button::after {
  rotate: 45deg;
}
.layout-container .component-modal__content {
  width: 100%;
  max-width: calc(96 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
.layout-container .component-modal__movie iframe {
  aspect-ratio: 16/9;
}
@media screen and (max-width: 768px) {
  .layout-container .component-modal__movie--responsive iframe {
    aspect-ratio: 9/16;
  }
}
.layout-container .component-partial {
  /*
    Josh's Custom CSS Reset
    https://www.joshwcomeau.com/css/custom-css-reset/
  */
  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;
}
.layout-container .component-partial *,
.layout-container .component-partial *::before,
.layout-container .component-partial *::after {
  box-sizing: border-box;
}
.layout-container .component-partial * {
  margin: 0;
}
.layout-container .component-partial body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.layout-container .component-partial img,
.layout-container .component-partial picture,
.layout-container .component-partial video,
.layout-container .component-partial canvas,
.layout-container .component-partial svg {
  display: block;
  max-width: 100%;
}
.layout-container .component-partial input,
.layout-container .component-partial button,
.layout-container .component-partial textarea,
.layout-container .component-partial select {
  font: inherit;
}
.layout-container .component-partial p,
.layout-container .component-partial h1,
.layout-container .component-partial h2,
.layout-container .component-partial h3,
.layout-container .component-partial h4,
.layout-container .component-partial h5,
.layout-container .component-partial h6 {
  overflow-wrap: break-word;
}
.layout-container .component-partial #root,
.layout-container .component-partial #__next {
  isolation: isolate;
}
.layout-container .component-partial * {
  letter-spacing: 0.1em;
}
.layout-container .component-partial *:not(:has(a)) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  cursor: default;
}
.layout-container .component-partial a,
.layout-container .component-partial button {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container .component-partial a *,
.layout-container .component-partial button * {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
  cursor: pointer !important;
}
.layout-container .component-partial h1,
.layout-container .component-partial h2,
.layout-container .component-partial h3,
.layout-container .component-partial h4,
.layout-container .component-partial h5,
.layout-container .component-partial h6 {
  font-size: inherit;
  font-weight: inherit;
}
.layout-container .component-partial ul,
.layout-container .component-partial ol {
  list-style: none;
  padding: 0;
  margin: 0;
}
.layout-container .component-partial a {
  color: #231815;
  text-decoration: none;
}
.layout-container .component-partial em {
  font-style: normal;
}
.layout-container .component-partial sup {
  font-size: 0.5em;
}
.layout-container .component-partial img,
.layout-container .component-partial picture,
.layout-container .component-partial video,
.layout-container .component-partial canvas,
.layout-container .component-partial svg {
  height: auto;
}
.layout-container .component-partial svg {
  overflow: visible;
}
.layout-container .component-partial img,
.layout-container .component-partial iframe,
.layout-container .component-partial 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-container .component-partial picture {
  display: contents;
}
.layout-container .component-partial button {
  padding: 0;
  border: none;
  background-color: transparent;
  color: inherit;
  touch-action: manipulation;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .layout-container .component-partial {
    padding-right: 0;
    padding-left: 0;
    font-size: calc(1.2 * var(--rem));
    line-height: 2;
  }
}
.layout-container .section__inner {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .layout-container .section__inner {
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.layout-container .section__link a {
  padding: calc(0.8 * var(--rem)) 0;
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0.2em;
}
.layout-container .about-hero {
  width: 100%;
  max-width: calc(144 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  padding-top: calc(1 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero {
    padding-top: calc(5.3 * var(--rem));
    text-align: left;
  }
}
.layout-container .about-hero__heading {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  gap: calc(0 * var(--rem)) calc(4.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__heading {
    flex-direction: column;
    align-items: flex-start;
    padding: 0 calc(2 * var(--rem));
  }
}
.layout-container .about-hero__heading-en {
  font-size: calc(5 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__heading-en {
    font-size: calc(3 * var(--rem));
  }
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__heading-ja {
    margin-top: calc(0.4 * var(--rem));
  }
}
.layout-container .about-hero__body {
  gap: calc(0 * var(--rem)) calc(12 * var(--rem));
  margin-top: calc(13.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__body {
    flex-direction: column;
    margin-top: calc(7.6 * var(--rem));
  }
}
.layout-container .about-hero__image {
  flex-shrink: 0;
  width: calc(68 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__image {
    width: 100%;
  }
}
.layout-container .about-hero__content {
  margin-top: calc(-1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__content {
    margin-top: calc(8.6 * var(--rem));
    padding: 0 calc(2 * var(--rem));
  }
}
.layout-container .about-hero__subheading-en {
  font-size: calc(5 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1.24;
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__subheading-en {
    font-size: calc(3.8 * var(--rem));
    line-height: 1.2631578947;
  }
}
.layout-container .about-hero__subheading-ja {
  display: block;
  margin-top: calc(2.6 * var(--rem));
  font-size: calc(2.2 * var(--rem));
  line-height: 1.8181818182;
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__subheading-ja {
    margin-top: calc(1.4 * var(--rem));
    font-size: calc(2 * var(--rem));
    line-height: 2;
  }
}
.layout-container .about-hero__text {
  margin-top: calc(3.2 * var(--rem));
  font-size: calc(1.6 * var(--rem));
  line-height: 3.125;
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__text {
    margin-top: calc(5.4 * var(--rem));
    font-size: calc(1.4 * var(--rem));
    line-height: 3.2142857143;
  }
}
.layout-container .about-hero__text:nth-of-type(n + 2) {
  margin-top: calc(5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-hero__text:nth-of-type(n + 2) {
    margin-top: calc(4.4 * var(--rem));
  }
}
.layout-container .about-movie {
  margin-top: calc(23.2 * var(--rem));
  padding: calc(15.6 * var(--rem)) 0 calc(17 * var(--rem));
  background-color: #f2f3f3;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie {
    margin-top: calc(12 * var(--rem));
    padding: calc(13.4 * var(--rem)) 0 calc(14.4 * var(--rem));
  }
}
.layout-container .about-movie__head {
  width: 100%;
  max-width: calc(105 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__head {
    flex-direction: column;
    gap: calc(3 * var(--rem));
  }
}
.layout-container .about-movie__head > * {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__head > * {
    width: 100%;
  }
}
.layout-container .about-movie__heading {
  font-size: calc(5 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__heading {
    font-size: calc(3 * var(--rem));
    text-align: center;
  }
}
.layout-container .about-movie__thumbnail {
  width: 100%;
  max-width: calc(65 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  margin-top: calc(5.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__thumbnail {
    margin-top: calc(2.2 * var(--rem));
  }
}
.layout-container .about-movie__thumbnail button {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
}
.layout-container .about-movie__thumbnail button::before, .layout-container .about-movie__thumbnail button::after {
  display: block;
  width: calc(8 * var(--rem));
  height: calc(8 * var(--rem));
  content: "";
  position: absolute;
  bottom: calc(3 * var(--rem));
  left: calc(3 * var(--rem));
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__thumbnail button::before, .layout-container .about-movie__thumbnail button::after {
    width: calc(6 * var(--rem));
    height: calc(6 * var(--rem));
    bottom: calc(2 * var(--rem));
    left: calc(2 * var(--rem));
  }
}
.layout-container .about-movie__thumbnail button::before {
  border: 1px solid #fff;
  border-radius: 50%;
}
.layout-container .about-movie__thumbnail button::after {
  translate: calc(0.3 * var(--rem)) 0;
  background-color: #fff;
  -webkit-mask: url("/assets/img/common/arw_triangle.svg") no-repeat center/calc(2 * var(--rem)) calc(2.4 * var(--rem));
          mask: url("/assets/img/common/arw_triangle.svg") no-repeat center/calc(2 * var(--rem)) calc(2.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__thumbnail button::after {
    translate: calc(0.2 * var(--rem)) 0;
    -webkit-mask-size: calc(1.4 * var(--rem)) calc(1.6 * var(--rem));
            mask-size: calc(1.4 * var(--rem)) calc(1.6 * var(--rem));
  }
}
.layout-container .about-movie__link {
  margin-top: calc(3.6 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie__link {
    margin-top: calc(2.8 * var(--rem));
  }
}
.layout-container .about-movie__link a span {
  padding: calc(0.7 * var(--rem)) 0;
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0;
}
.layout-container .about-movie + .component-breadcrumb {
  margin-top: calc(15.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .about-movie + .component-breadcrumb {
    margin-top: calc(9.6 * var(--rem));
  }
}
.layout-container .gift-overlay {
  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);
}
.layout-container .gift-hero {
  height: calc(100vh - calc(25 * var(--rem)));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-hero {
    height: auto;
  }
}
.layout-container .gift-hero__image {
  height: 100%;
}
.layout-container .gift-hero__image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.layout-container .gift-header {
  position: sticky;
  top: 0;
  right: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 999;
  height: calc(5.5 * var(--rem));
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header {
    height: calc(6 * var(--rem));
  }
}
.layout-container .gift-header__logo a svg {
  width: calc(9.5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header__logo a svg {
    width: calc(9.4 * var(--rem));
  }
}
.layout-container .gift-header__hamburger {
  position: absolute;
  top: 0;
  right: calc(2 * var(--rem));
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header__hamburger {
    right: 0;
  }
}
.layout-container .gift-header__hamburger button {
  width: calc(7.4 * var(--rem));
  height: 100%;
  position: relative;
}
.layout-container .gift-header__hamburger button::before, .layout-container .gift-header__hamburger button::after {
  display: block;
  width: calc(3.4 * var(--rem));
  height: 1px;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  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);
  will-change: translate, rotate;
}
.layout-container .gift-header__hamburger button::before {
  translate: -50% calc(0.5 * var(--rem));
}
.layout-container .gift-header__hamburger button::after {
  translate: -50% calc(-0.5 * var(--rem));
}
.layout-container .gift-header .gift-header-links {
  position: fixed;
  top: calc(5.5 * var(--rem));
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  gap: calc(2.2 * var(--rem));
  translate: 100% 0;
  width: calc(30 * var(--rem));
  padding: calc(6.5 * var(--rem)) calc(3 * var(--rem));
  background-color: #fff;
  line-height: 1;
  transition: translate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: translate;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header .gift-header-links {
    top: calc(6 * var(--rem));
    gap: calc(3.8 * var(--rem));
    width: 100%;
    padding: calc(5.4 * var(--rem)) 0 calc(4 * var(--rem)) calc(4 * var(--rem));
  }
}
.layout-container .gift-header .gift-header-links__en {
  font-size: calc(1.4 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1.1666666667;
  letter-spacing: 0.12em;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header .gift-header-links__en {
    font-size: calc(2.4 * var(--rem));
  }
}
.layout-container .gift-header .gift-header-links__ja {
  margin-top: calc(0.4 * var(--rem));
  font-size: calc(0.8 * var(--rem));
  letter-spacing: 0.4em;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-header .gift-header-links__ja {
    margin-top: calc(0.6 * var(--rem));
    font-size: calc(1.2 * var(--rem));
  }
}
.layout-container .gift-introduction {
  padding-top: calc(8.4 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-introduction {
    padding-top: calc(5.6 * var(--rem));
  }
}
.layout-container .gift-introduction__heading > * {
  display: block;
}
.layout-container .gift-introduction__heading-en {
  font-size: calc(5 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1.2;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-introduction__heading-en {
    font-size: calc(3.5 * var(--rem));
  }
}
.layout-container .gift-introduction__heading-ja {
  margin-top: calc(2.2 * var(--rem));
  font-size: calc(2 * var(--rem));
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-introduction__heading-ja {
    font-size: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-introduction__text {
  margin-top: calc(1.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-introduction__text {
    margin-top: calc(2.4 * var(--rem));
  }
}
.layout-container .gift-section__inner {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-section__inner {
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.layout-container .gift-section__heading {
  font-size: calc(4 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  line-height: 1.3;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-section__heading {
    font-size: calc(2.8 * var(--rem));
    line-height: 1.2857142857;
  }
}
.layout-container .gift-section__heading--large {
  font-size: calc(4.8 * var(--rem));
  line-height: 1.25;
}
.layout-container .gift-section__text {
  line-height: 2;
  letter-spacing: 0.16em;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-section__text {
    line-height: 2;
  }
}
.layout-container .gift-section__links {
  width: 100%;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: center;
  gap: calc(4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-section__links {
    gap: calc(3.2 * var(--rem));
  }
}
.layout-container .gift-section__link a span,
.layout-container .gift-section .gift-contents-slider__link span,
.layout-container .gift-section .gift-wide-note__item a span {
  padding: calc(0.4 * var(--rem)) 0;
  font-size: calc(1.2 * var(--rem));
}
.layout-container .gift-seasonal {
  padding-top: calc(13.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-seasonal {
    padding-top: calc(10.4 * var(--rem));
  }
}
.layout-container .gift-seasonal .gift-section__inner {
  width: 100%;
  max-width: calc(80 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
.layout-container .gift-seasonal .gift-section__text {
  margin-top: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-seasonal .gift-section__text {
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-seasonal__banner {
  margin-top: calc(3.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-seasonal__banner {
    margin-top: calc(3.4 * var(--rem));
  }
}
.layout-container .gift-selection {
  padding-top: calc(10.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection {
    padding-top: calc(9.2 * var(--rem));
  }
}
.layout-container .gift-selection .gift-section__inner {
  width: 100%;
  max-width: calc(80 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
.layout-container .gift-selection .gift-section__text {
  margin-top: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-section__text {
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-selection .gift-selection-anchors {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: calc(2 * var(--rem)) calc(1.3 * var(--rem));
  margin-top: calc(4.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-selection-anchors {
    flex-direction: column;
    gap: calc(1 * var(--rem));
    margin-top: calc(3.4 * var(--rem));
  }
}
.layout-container .gift-selection .gift-selection-anchors__item {
  width: calc(33.333333% - calc(0.8666666 * var(--rem)));
  height: calc(6.5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-selection-anchors__item {
    width: calc(26.4 * var(--rem));
    height: calc(7 * var(--rem));
  }
}
.layout-container .gift-selection .gift-selection-anchors__item a {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
  padding-top: calc(1 * var(--rem));
  background-image: linear-gradient(120deg, #fefdfd, #ebeef0);
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-selection-anchors__item a {
    display: flex;
    justify-content: center;
    flex-direction: column;
    padding: calc(0 * var(--rem)) calc(2 * var(--rem));
    background-image: linear-gradient(120deg, #f8f8f8, #fefdfd 30%, #ebeef0 90%);
    text-align: left;
  }
}
.layout-container .gift-selection .gift-selection-anchors__en {
  font-size: calc(2 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
  letter-spacing: 0.025em;
}
.layout-container .gift-selection .gift-selection-anchors__ja {
  margin-top: calc(0.4 * var(--rem));
  font-size: calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-selection-anchors__ja {
    margin-top: calc(0.6 * var(--rem));
    font-size: calc(1.2 * var(--rem));
  }
}
.layout-container .gift-selection .gift-selection-anchors .hover-arrow {
  position: absolute;
  right: 50%;
  bottom: calc(0.4 * var(--rem));
  width: calc(0.8 * var(--rem));
  height: calc(1.1 * var(--rem));
  translate: -50% 0;
  rotate: 90deg;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-selection .gift-selection-anchors .hover-arrow {
    bottom: 50%;
    right: calc(2 * var(--rem));
    translate: 0 50%;
  }
}
.layout-container .gift-selection .gift-selection-anchors .hover-arrow::before {
  background-color: #231815;
  -webkit-mask-image: url("/assets/img/common/arw_line.svg");
          mask-image: url("/assets/img/common/arw_line.svg");
}
.layout-container .gift-contents {
  margin-top: calc(10 * var(--rem));
  padding-bottom: calc(2.2 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents {
    margin-top: calc(6 * var(--rem));
  }
}
.layout-container .gift-contents__heading {
  margin-top: calc(4.6 * var(--rem));
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents__heading {
    margin-top: calc(3.8 * var(--rem));
  }
}
.layout-container .gift-contents__heading > * {
  display: block;
}
.layout-container .gift-contents__heading-en {
  font-size: calc(3 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents__heading-en {
    font-size: calc(2.5 * var(--rem));
  }
}
.layout-container .gift-contents__heading-ja {
  margin-top: calc(0.8 * var(--rem));
}
.layout-container .gift-contents .gift-section__text {
  margin-top: calc(1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-section__text {
    margin-top: calc(3 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
.layout-container .gift-contents .gift-contents-slider .splide__track {
  padding-top: calc(3.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider .splide__track {
    padding-top: calc(0.2 * var(--rem));
  }
}
@media screen and (min-width: 769px) {
  .layout-container .gift-contents .gift-contents-slider .splide__list {
    display: flex !important;
    gap: calc(0.8 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider .splide__slide {
  display: flex;
  flex-direction: column;
  width: calc(25% - calc(0.6 * var(--rem)));
  padding-bottom: calc(0.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider .splide__slide {
    width: calc(23.6 * var(--rem));
  }
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider .splide__slide:last-of-type {
    width: calc(38.6 * var(--rem));
    padding-right: calc(15 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider .splide__pagination {
  display: flex;
  justify-content: center;
  margin-top: calc(3.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider .splide__pagination {
    margin-top: calc(2.6 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider .splide__pagination button {
  width: calc(0.8 * var(--rem));
  height: calc(0.8 * var(--rem));
  position: relative;
  padding: calc(0.75 * var(--rem));
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .gift-contents .gift-contents-slider .splide__pagination button:before {
  display: block;
  width: calc(0.5 * var(--rem));
  height: calc(0.5 * var(--rem));
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(0.5 * var(--rem));
  background-color: #e6e6e6;
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .gift-contents .gift-contents-slider .splide__pagination button.is-active {
  width: calc(2.7 * var(--rem));
}
.layout-container .gift-contents .gift-contents-slider .splide__pagination button.is-active::before {
  width: calc(1.7 * var(--rem));
  background-color: #898989;
}
.layout-container .gift-contents .gift-contents-slider__image img {
  width: auto;
  height: calc(29.4 * var(--rem));
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider__image img {
    height: calc(21.2 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider__heading {
  position: relative;
  margin-top: calc(1.8 * var(--rem));
  font-size: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-contents-slider__heading {
    margin-top: calc(1 * var(--rem));
  }
}
.layout-container .gift-contents .gift-contents-slider__heading > * {
  display: block;
}
.layout-container .gift-contents .gift-contents-slider__heading-en {
  line-height: 1.3333333333;
  letter-spacing: 0.01em;
}
.layout-container .gift-contents .gift-contents-slider__heading-ja {
  margin-top: calc(0.2 * var(--rem));
  line-height: 1.5;
  letter-spacing: 0.025em;
}
.layout-container .gift-contents .gift-contents-slider__link {
  margin-top: auto;
  padding-top: calc(1.8 * var(--rem));
}
.layout-container .gift-contents .gift-contents-slider__link span {
  position: relative;
}
.layout-container .gift-contents .gift-contents-slider__link span::after {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: #231815;
}
.layout-container .gift-contents .gift-section__links {
  margin-top: calc(7 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents .gift-section__links {
    margin-top: calc(7.4 * var(--rem));
  }
}
.layout-container .gift-contents#gift-her .splide__slide:nth-of-type(1) .gift-contents-slider__image {
  translate: 0 calc(-3.5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-her .splide__slide:nth-of-type(1) .gift-contents-slider__image {
    translate: 0 calc(-2.52 * var(--rem));
  }
}
.layout-container .gift-contents#gift-her .splide__slide:nth-of-type(2) .gift-contents-slider__image {
  translate: 0 calc(-2.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-her .splide__slide:nth-of-type(2) .gift-contents-slider__image {
    translate: 0 calc(-1.584 * var(--rem));
  }
}
.layout-container .gift-contents#gift-her .splide__slide:nth-of-type(3) .gift-contents-slider__image {
  translate: 0 calc(-1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-her .splide__slide:nth-of-type(3) .gift-contents-slider__image {
    translate: 0 calc(-1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-her .splide__slide:nth-of-type(4) .gift-contents-slider__image {
  translate: 0 calc(1.4 * var(--rem));
  scale: 0.9;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-her .splide__slide:nth-of-type(4) .gift-contents-slider__image {
    translate: 0 calc(1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-him .splide__slide:nth-of-type(1) .gift-contents-slider__image {
  translate: 0 calc(-1.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-him .splide__slide:nth-of-type(1) .gift-contents-slider__image {
    translate: 0 calc(-1.296 * var(--rem));
  }
}
.layout-container .gift-contents#gift-him .splide__slide:nth-of-type(2) .gift-contents-slider__image {
  translate: 0 calc(-1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-him .splide__slide:nth-of-type(2) .gift-contents-slider__image {
    translate: 0 calc(-1.152 * var(--rem));
  }
}
.layout-container .gift-contents#gift-him .splide__slide:nth-of-type(3) .gift-contents-slider__image {
  translate: 0 calc(-1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-him .splide__slide:nth-of-type(3) .gift-contents-slider__image {
    translate: 0 calc(-1.152 * var(--rem));
  }
}
.layout-container .gift-contents#gift-him .splide__slide:nth-of-type(4) .gift-contents-slider__image {
  translate: 0 calc(-1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-him .splide__slide:nth-of-type(4) .gift-contents-slider__image {
    translate: 0 calc(-1.152 * var(--rem));
  }
}
.layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(1) .gift-contents-slider__image {
  translate: 0 calc(1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(1) .gift-contents-slider__image {
    translate: 0 calc(1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(2) .gift-contents-slider__image {
  translate: 0 calc(-0.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(2) .gift-contents-slider__image {
    translate: 0 calc(-0.576 * var(--rem));
  }
}
.layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(3) .gift-contents-slider__image {
  translate: 0 calc(-0.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(3) .gift-contents-slider__image {
    translate: 0 calc(-0.576 * var(--rem));
  }
}
.layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(4) .gift-contents-slider__image {
  translate: 0 calc(1.4 * var(--rem));
  scale: 0.9;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-friend .splide__slide:nth-of-type(4) .gift-contents-slider__image {
    translate: 0 calc(1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(1) .gift-contents-slider__image {
  translate: 0 calc(-1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(1) .gift-contents-slider__image {
    translate: 0 calc(-0.864 * var(--rem));
  }
}
.layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(2) .gift-contents-slider__image {
  translate: 0 calc(-0.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(2) .gift-contents-slider__image {
    translate: 0 calc(-0.576 * var(--rem));
  }
}
.layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(3) .gift-contents-slider__image {
  translate: 0 calc(0.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(3) .gift-contents-slider__image {
    translate: 0 calc(0.576 * var(--rem));
  }
}
.layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(4) .gift-contents-slider__image {
  translate: 0 calc(-0.8 * var(--rem));
  scale: 0.94;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-wedding .splide__slide:nth-of-type(4) .gift-contents-slider__image {
    translate: 0 calc(-0.576 * var(--rem));
  }
}
.layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(1) .gift-contents-slider__image {
  translate: 0 calc(-1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(1) .gift-contents-slider__image {
    translate: 0 calc(-1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(2) .gift-contents-slider__image {
  translate: 0 calc(0 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(2) .gift-contents-slider__image {
    translate: 0 calc(0 * var(--rem));
  }
}
.layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(3) .gift-contents-slider__image {
  translate: 0 calc(1.4 * var(--rem));
  scale: 0.9;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(3) .gift-contents-slider__image {
    translate: 0 calc(1.008 * var(--rem));
  }
}
.layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(4) .gift-contents-slider__image {
  translate: 0 calc(-1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-contents#gift-housewarming .splide__slide:nth-of-type(4) .gift-contents-slider__image {
    translate: 0 calc(-0.864 * var(--rem));
  }
}
.layout-container .gift-wide {
  padding-top: calc(15 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide {
    padding-top: calc(12 * var(--rem));
  }
}
.layout-container .gift-wide .gift-section__text {
  margin-top: calc(2.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-section__text {
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-wide .gift-section__link {
  margin-top: calc(1.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-section__link {
    margin-top: calc(2 * var(--rem));
  }
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents {
    display: flex;
    flex-direction: column;
    gap: calc(8 * var(--rem));
  }
}
.layout-container .gift-wide .gift-wide-contents__item {
  display: flex;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents__item {
    flex-direction: column;
  }
}
.layout-container .gift-wide .gift-wide-contents__item > * {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents__item > * {
    width: 100%;
  }
}
.layout-container .gift-wide .gift-wide-contents__item:nth-of-type(1) .gift-section__heading {
  padding-top: calc(4.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents__item:nth-of-type(1) .gift-section__heading {
    padding-top: 0;
  }
}
@media screen and (min-width: 769px) {
  .layout-container .gift-wide .gift-wide-contents__item:nth-of-type(even) {
    flex-direction: row-reverse;
  }
}
.layout-container .gift-wide .gift-wide-contents__content {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents__content {
    padding-top: calc(3.2 * var(--rem));
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-note {
  margin-top: calc(4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents .gift-wide-note {
    width: 100%;
    max-width: calc(34.4 * var(--rem));
    margin-left: auto;
    margin-right: auto;
    margin-top: calc(2.4 * var(--rem));
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-note__item {
  padding-left: 1em;
  text-indent: -1em;
  font-size: calc(1.2 * var(--rem));
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents .gift-wide-note__item {
    font-size: calc(1 * var(--rem));
    line-height: 1.6;
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-note__item::before {
  content: "※";
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-note__item a {
  font-size: calc(1.2 * var(--rem));
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents .gift-wide-note__item a {
    font-size: calc(1 * var(--rem));
    line-height: 1.6;
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion {
  width: calc(43 * var(--rem));
  margin-top: calc(2.4 * var(--rem));
  font-size: calc(1.2 * var(--rem));
  line-height: 1.5;
  border: 1px solid #231815;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents .gift-wide-accordion {
    width: 100%;
    max-width: calc(34.4 * var(--rem));
    margin-left: auto;
    margin-right: auto;
    font-size: calc(1 * var(--rem));
    line-height: 1.6;
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion:has(.gift-wide-accordion__heading button.is-clicked) .gift-wide-accordion__heading button::before {
  rotate: 0deg;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion:has(.gift-wide-accordion__heading button.is-clicked) .gift-wide-accordion__wrapper {
  grid-template-rows: 1fr !important;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion:has(.gift-wide-accordion__heading button.is-clicked) .gift-wide-accordion__text {
  opacity: 1;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__heading {
  position: relative;
  z-index: 1;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__heading button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: calc(5 * var(--rem));
  position: relative;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__heading button::before, .layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__heading button::after {
  display: block;
  width: calc(1.2 * var(--rem));
  height: 1px;
  content: "";
  position: absolute;
  top: 50%;
  right: calc(2 * var(--rem));
  translate: 0 -50%;
  background-color: #231815;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__heading button::before {
  rotate: -90deg;
  transition: rotate 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: rotate;
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__wrapper {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__inner {
  overflow: hidden;
  margin-top: calc(-0.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__inner {
    margin-top: calc(0 * var(--rem));
  }
}
.layout-container .gift-wide .gift-wide-contents .gift-wide-accordion__text {
  opacity: 0;
  padding: 0 calc(2 * var(--rem)) calc(1.8 * var(--rem));
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: opacity;
}
.layout-container .gift-foot {
  padding: calc(13 * var(--rem)) 0 calc(12 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot {
    padding: calc(10 * var(--rem)) 0 calc(8 * var(--rem));
  }
}
.layout-container .gift-foot .gift-section__heading {
  margin-top: calc(-1.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-section__heading {
    margin-top: 0;
  }
}
.layout-container .gift-foot .gift-section__text {
  margin-top: calc(2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-section__text {
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-foot .gift-section__link {
  margin-top: calc(1.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-section__link {
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .gift-foot .gift-foot-contents {
  display: flex;
  flex-direction: column;
  gap: calc(7.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-foot-contents {
    gap: calc(8.4 * var(--rem));
  }
}
.layout-container .gift-foot .gift-foot-contents__item {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-foot-contents__item {
    flex-direction: column;
  }
}
.layout-container .gift-foot .gift-foot-contents__item > * {
  width: 50%;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-foot-contents__item > * {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .layout-container .gift-foot .gift-foot-contents__content {
    padding-top: calc(3.6 * var(--rem));
  }
}
.layout-container .gift-foot .gift-foot-contents .gift-section__link a {
  padding: calc(0.8 * var(--rem)) 0;
}
.layout-container .gift-footer {
  margin-top: calc(7.2 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-footer {
    margin-top: calc(5.8 * var(--rem));
  }
}
.layout-container .gift-footer .gift-footer-links {
  display: inline-flex;
  font-size: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .gift-footer .gift-footer-links {
    font-size: calc(1 * var(--rem));
  }
}
.layout-container .gift-footer .gift-footer-links__item:nth-of-type(n + 2)::before {
  margin: 0 calc(0.5 * var(--rem));
  content: "｜";
}
.layout-container .gift-footer__copy {
  margin-top: calc(2.6 * var(--rem));
  padding: calc(2 * var(--rem));
  background-color: #000;
  color: #fff;
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-footer__copy {
    margin-top: calc(2.4 * var(--rem));
  }
}
.layout-container .gift-footer__copy-logo {
  width: 100%;
  max-width: calc(5.6 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: block;
}
.layout-container .gift-footer__copy-text {
  display: inline-block;
  margin-top: calc(0.6 * var(--rem));
  font-size: calc(1 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .gift-footer__copy-text {
    font-size: calc(0.8 * var(--rem));
  }
}
.layout-container .home-hero {
  position: relative;
  overflow: hidden;
  height: calc(100vh + 2.1 * var(--rem));
  padding-bottom: calc(5.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero {
    height: calc(100dvh + 2.1 * var(--rem));
    padding-bottom: calc(12.6 * var(--rem));
  }
}
.layout-container .home-hero__heading {
  font-size: 0;
}
.layout-container .home-hero__media {
  position: relative;
  height: 100%;
}
.layout-container .home-hero__media::after {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background-color: #fff;
}
.layout-container .home-hero__media img,
.layout-container .home-hero__media video {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.layout-container .home-hero .home-hero-slider {
  position: absolute;
  right: 0;
  bottom: 0;
  width: calc(44 * var(--rem));
  margin-top: calc(-9 * var(--rem));
  margin-right: calc(-1 * var(--rem));
  margin-left: auto;
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider {
    width: 100%;
    margin-right: 0;
    margin-top: calc(-2 * var(--rem));
  }
}
.layout-container .home-hero .home-hero-slider .splide__slide {
  height: calc(14 * var(--rem));
  padding: 0 calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider .splide__slide {
    height: calc(12.6 * var(--rem));
    padding: 0 0 0 calc(4 * var(--rem));
  }
}
.layout-container .home-hero .home-hero-slider .splide__slide a {
  display: flex;
  gap: calc(2 * var(--rem));
  padding: calc(2 * var(--rem));
  background-color: #ebeef0;
}
.layout-container .home-hero .home-hero-slider .splide__pagination {
  display: flex;
  justify-content: flex-end;
  padding: calc(0.3 * var(--rem)) calc(1.3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider .splide__pagination {
    padding-right: calc(0.3 * var(--rem));
  }
}
.layout-container .home-hero .home-hero-slider .splide__pagination button {
  width: calc(1.5 * var(--rem));
  height: calc(1.5 * var(--rem));
  display: block;
  position: relative;
}
.layout-container .home-hero .home-hero-slider .splide__pagination button:before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(0.5 * var(--rem));
  height: calc(0.5 * var(--rem));
  border-radius: 100%;
  translate: -50% -50%;
  background-color: #e6e6e6;
  transition: background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .home-hero .home-hero-slider .splide__pagination button.is-active::before {
  background-color: #898989;
}
.layout-container .home-hero .home-hero-slider__image {
  width: calc(13.2 * var(--rem));
  height: calc(10 * var(--rem));
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider__image {
    width: calc(11.2 * var(--rem));
    height: calc(8.6 * var(--rem));
  }
}
.layout-container .home-hero .home-hero-slider__image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider__content {
    padding-top: calc(0.4 * var(--rem));
  }
}
.layout-container .home-hero .home-hero-slider__heading {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-weight: 700;
  font-size: calc(1.2 * var(--rem));
  line-height: 1.6666666667;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider__heading {
    font-size: calc(1 * var(--rem));
    letter-spacing: 0.05em;
  }
}
.layout-container .home-hero .home-hero-slider__text {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  margin-top: calc(1.4 * var(--rem));
  margin-top: calc(0.4 * var(--rem));
  line-height: 1.4;
}
@media screen and (max-width: 768px) {
  .layout-container .home-hero .home-hero-slider__text {
    margin-top: calc(0.4 * var(--rem));
    font-size: calc(1.1 * var(--rem));
  }
}
.layout-container .home-section__inner {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 768px) {
  .layout-container .home-section__inner {
    padding-right: calc(2 * var(--rem));
    padding-left: calc(2 * var(--rem));
  }
}
.layout-container .home-section__inner:has(.home-section__image) {
  max-width: 100%;
  padding-right: calc(2 * var(--rem));
  padding-left: calc(2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-section__inner:has(.home-section__image) {
    padding: 0;
  }
}
.layout-container .home-section__heading, .layout-container .home-section__subheading {
  line-height: 1;
  text-align: center;
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-container .home-section__heading {
  font-size: calc(5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-section__heading {
    font-size: calc(3 * var(--rem));
  }
}
.layout-container .home-section__subheading {
  font-size: calc(3 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-section__subheading {
    font-size: calc(2 * var(--rem));
  }
}
.layout-container .home-section__text {
  text-align: center;
}
.layout-container .home-section__text span {
  font-size: calc(1.8 * var(--rem));
  font-family: Yakuhanjp, "Figtree", sans-serif;
}
.layout-container .home-section__link {
  text-align: center;
}
.layout-container .home-section__link a span {
  padding: calc(0.8 * var(--rem)) 0;
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0.2em;
}
.layout-container .home-section__image {
  position: relative;
  z-index: 1;
}
.layout-container .home-section__image::before {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(rgba(31, 31, 31, 0) 74%, rgba(0, 0, 0, 0.54) 100%);
}
.layout-container .home-section__image .home-section__heading {
  position: absolute;
  right: 0;
  bottom: calc(3.6 * var(--rem));
  left: 0;
  color: #fff;
}
.layout-container .home-products {
  padding-top: calc(9.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products {
    padding-top: calc(8.4 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents {
  display: flex;
  flex-direction: column;
  gap: calc(12.4 * var(--rem));
  margin-top: calc(4.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents {
    margin-top: calc(2.4 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-categories {
  width: 100%;
  max-width: calc(120 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
  gap: calc(1.8 * var(--rem));
  margin-top: calc(4.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-categories {
    flex-wrap: wrap;
    gap: calc(2.4 * var(--rem)) calc(0.4 * var(--rem));
    margin-top: calc(3.6 * var(--rem));
    padding: 0 calc(2 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-categories__item {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-categories__item {
    width: calc(50% - calc(0.2 * var(--rem)));
  }
}
.layout-container .home-products .home-products-contents .home-products-categories__heading {
  margin-top: calc(1 * var(--rem));
  text-align: center;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-categories__heading {
    margin-top: calc(1.2 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-section__link {
  margin-top: calc(3.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-section__link {
    margin-top: calc(3.2 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new {
  margin-top: calc(-1.4 * var(--rem));
  margin-left: calc(-1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new {
    margin-top: calc(3.2 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrows {
  width: 100%;
  max-width: calc(140 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: flex-end;
  gap: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__arrows {
    display: none;
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrow {
  width: calc(3.4 * var(--rem));
  height: calc(3.4 * var(--rem));
  border-radius: 100%;
  position: relative;
  overflow: hidden;
  border: 1px solid #898989;
  transition: border-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__arrow:hover::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__arrow:active::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrow::before {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  background-color: #898989;
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/calc(1.1 * var(--rem)) calc(0.7 * var(--rem));
          mask: url("/assets/img/common/arw.svg") no-repeat center/calc(1.1 * var(--rem)) calc(0.7 * var(--rem));
  transition: background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: translate;
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrow[disabled] {
  border-color: #e6e6e6;
  pointer-events: none;
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrow[disabled]::before {
  background-color: #e6e6e6;
}
.layout-container .home-products .home-products-contents .home-products-new .splide__arrow--prev {
  rotate: 180deg;
}
.layout-container .home-products .home-products-contents .home-products-new .splide__track {
  margin-top: calc(2 * var(--rem)) !important;
  padding: 0 calc((100% - calc(144 * var(--rem))) / 2 + calc(12 * var(--rem)) - calc(0.5 * var(--rem))) !important;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__track {
    margin: 0 !important;
    padding-right: calc(35.4 * var(--rem)) !important;
    padding-right: calc(1 * var(--rem)) !important;
    padding-left: calc(2 * var(--rem)) !important;
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__slide {
  width: calc(30.5 * var(--rem));
  padding: 0 calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__slide {
    width: calc(24 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__slide:last-of-type {
  width: calc(29.5 * var(--rem));
  padding-right: 0;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__slide:last-of-type {
    width: calc(59.4 * var(--rem));
    margin-right: calc(35.4 * var(--rem)) !important;
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__pagination {
  display: none;
  justify-content: center;
  margin-top: calc(3.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new .splide__pagination {
    display: flex;
  }
}
.layout-container .home-products .home-products-contents .home-products-new .splide__pagination button {
  width: calc(0.8 * var(--rem));
  height: calc(0.8 * var(--rem));
  position: relative;
  padding: calc(0.6 * var(--rem));
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .home-products .home-products-contents .home-products-new .splide__pagination button:before {
  display: block;
  width: calc(0.4 * var(--rem));
  height: calc(0.4 * var(--rem));
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(0.4 * var(--rem));
  background-color: #e6e6e6;
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .home-products .home-products-contents .home-products-new .splide__pagination button.is-active {
  width: calc(1.9 * var(--rem));
}
.layout-container .home-products .home-products-contents .home-products-new .splide__pagination button.is-active::before {
  width: calc(1.1 * var(--rem));
  background-color: #898989;
}
.layout-container .home-products .home-products-contents .home-products-new__image {
  width: calc(28.5 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new__image {
    width: calc(22 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new__content {
  padding-top: calc(1.8 * var(--rem));
}
.layout-container .home-products .home-products-contents .home-products-new__heading {
  font-weight: 700;
  font-size: calc(1.2 * var(--rem));
  line-height: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new__heading {
    font-size: calc(1 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new__text {
  margin-top: calc(0.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new__text {
    margin-top: calc(0.2 * var(--rem));
  }
}
.layout-container .home-products .home-products-contents .home-products-new__note {
  margin-top: calc(0.6 * var(--rem));
  color: #898989;
  font-size: calc(1.2 * var(--rem));
  line-height: 1.4;
}
@media screen and (max-width: 768px) {
  .layout-container .home-products .home-products-contents .home-products-new__note {
    margin-top: calc(0.4 * var(--rem));
    font-size: calc(1 * var(--rem));
  }
}
.layout-container .home-store {
  width: 100%;
  max-width: calc(144 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  padding-top: calc(17.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-store {
    padding-top: calc(14 * var(--rem));
  }
}
.layout-container .home-store .home-section__text {
  margin-top: calc(4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-store .home-section__text {
    margin-top: calc(2.4 * var(--rem));
  }
}
.layout-container .home-store .home-section__link {
  margin-top: calc(2.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-store .home-section__link {
    margin-top: calc(3 * var(--rem));
  }
}
.layout-container .home-gift {
  width: 100%;
  max-width: calc(144 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  padding-top: calc(16.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-gift {
    padding-top: calc(14 * var(--rem));
  }
}
.layout-container .home-gift .home-section__text {
  margin-top: calc(4 * var(--rem));
  line-height: 1.8;
}
@media screen and (max-width: 768px) {
  .layout-container .home-gift .home-section__text {
    margin-top: calc(2.5 * var(--rem));
  }
}
.layout-container .home-gift .home-section__link {
  margin-top: calc(2.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-gift .home-section__link {
    margin-top: calc(2.8 * var(--rem));
  }
}
.layout-container .home-ambassador {
  padding-top: calc(16.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador {
    padding-top: calc(14.8 * var(--rem));
  }
}
.layout-container .home-ambassador .home-section__inner {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador .home-section__inner {
    flex-direction: column;
  }
}
.layout-container .home-ambassador .home-section__text {
  margin-top: calc(2.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador .home-section__text {
    margin-top: calc(2.2 * var(--rem));
  }
}
.layout-container .home-ambassador .home-section__link {
  margin-top: calc(4.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador .home-section__link {
    margin-top: calc(2.8 * var(--rem));
  }
}
.layout-container .home-ambassador__thumbnail {
  flex-shrink: 0;
  order: 1;
  width: calc(67.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador__thumbnail {
    order: 0;
    width: 100%;
  }
}
.layout-container .home-ambassador__thumbnail button {
  width: 100%;
  height: 100%;
  display: block;
  position: relative;
}
.layout-container .home-ambassador__thumbnail button::before, .layout-container .home-ambassador__thumbnail button::after {
  display: block;
  width: calc(8 * var(--rem));
  height: calc(8 * var(--rem));
  content: "";
  position: absolute;
  bottom: calc(3 * var(--rem));
  left: calc(3 * var(--rem));
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador__thumbnail button::before, .layout-container .home-ambassador__thumbnail button::after {
    width: calc(6 * var(--rem));
    height: calc(6 * var(--rem));
    bottom: calc(2 * var(--rem));
    left: calc(2 * var(--rem));
  }
}
.layout-container .home-ambassador__thumbnail button::before {
  border: 1px solid #fff;
  border-radius: 50%;
}
.layout-container .home-ambassador__thumbnail button::after {
  translate: calc(0.3 * var(--rem)) 0;
  background-color: #fff;
  -webkit-mask: url("/assets/img/common/arw_triangle.svg") no-repeat center/calc(2 * var(--rem)) calc(2.4 * var(--rem));
          mask: url("/assets/img/common/arw_triangle.svg") no-repeat center/calc(2 * var(--rem)) calc(2.4 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador__thumbnail button::after {
    translate: calc(0.2 * var(--rem)) 0;
    -webkit-mask-size: calc(1.4 * var(--rem)) calc(1.6 * var(--rem));
            mask-size: calc(1.4 * var(--rem)) calc(1.6 * var(--rem));
  }
}
.layout-container .home-ambassador__content {
  flex: 1;
  margin-top: calc(-0.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-ambassador__content {
    margin-top: calc(1.8 * var(--rem));
  }
}
.layout-container .home-journal {
  padding-top: calc(14.4 * var(--rem));
}
.layout-container .home-journal .home-journal-slider {
  margin-top: calc(-1.6 * var(--rem));
  margin-left: calc(-1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider {
    margin-top: calc(3.6 * var(--rem));
    margin-left: 0;
  }
}
.layout-container .home-journal .home-journal-slider .splide__arrows {
  width: 100%;
  max-width: calc(140 * var(--rem));
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: flex-end;
  gap: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider .splide__arrows {
    display: none;
  }
}
.layout-container .home-journal .home-journal-slider .splide__arrow {
  width: calc(3.4 * var(--rem));
  height: calc(3.4 * var(--rem));
  border-radius: 100%;
  position: relative;
  overflow: hidden;
  border: 1px solid #898989;
  transition: border-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media (hover: hover) {
  .layout-container .home-journal .home-journal-slider .splide__arrow:hover::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
@media (hover: none) {
  .layout-container .home-journal .home-journal-slider .splide__arrow:active::before {
    animation: translate-back 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) forwards;
  }
}
.layout-container .home-journal .home-journal-slider .splide__arrow::before {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  background-color: #898989;
  -webkit-mask: url("/assets/img/common/arw.svg") no-repeat center/calc(1.1 * var(--rem)) calc(0.7 * var(--rem));
          mask: url("/assets/img/common/arw.svg") no-repeat center/calc(1.1 * var(--rem)) calc(0.7 * var(--rem));
  transition: background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  will-change: translate;
}
.layout-container .home-journal .home-journal-slider .splide__arrow[disabled] {
  border-color: #e6e6e6;
  pointer-events: none;
}
.layout-container .home-journal .home-journal-slider .splide__arrow[disabled]::before {
  background-color: #e6e6e6;
}
.layout-container .home-journal .home-journal-slider .splide__arrow--prev {
  rotate: 180deg;
}
.layout-container .home-journal .home-journal-slider .splide__track {
  margin-top: calc(2 * var(--rem)) !important;
  padding: 0 calc((100% - calc(144 * var(--rem))) / 2 + calc(12 * var(--rem)) - calc(0.5 * var(--rem))) !important;
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider .splide__track {
    margin: 0 !important;
    padding-right: calc(35.4 * var(--rem)) !important;
    padding-right: calc(1 * var(--rem)) !important;
    padding-left: calc(2 * var(--rem)) !important;
    padding: 0 !important;
  }
}
.layout-container .home-journal .home-journal-slider .splide__slide {
  width: calc(40.8 * var(--rem));
  padding: 0 calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider .splide__slide {
    width: calc(27 * var(--rem)) !important;
  }
}
@media screen and (min-width: 769px) {
  .layout-container .home-journal .home-journal-slider .splide__slide:last-of-type {
    width: calc(39.8 * var(--rem));
    padding-right: 0;
  }
}
.layout-container .home-journal .home-journal-slider .splide__pagination {
  display: none;
  justify-content: center;
  margin-top: calc(3.6 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider .splide__pagination {
    display: flex;
  }
}
.layout-container .home-journal .home-journal-slider .splide__pagination button {
  width: calc(0.8 * var(--rem));
  height: calc(0.8 * var(--rem));
  position: relative;
  padding: calc(0.6 * var(--rem));
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .home-journal .home-journal-slider .splide__pagination button:before {
  display: block;
  width: calc(0.4 * var(--rem));
  height: calc(0.4 * var(--rem));
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  border-radius: calc(0.4 * var(--rem));
  background-color: #e6e6e6;
  transition: width 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.layout-container .home-journal .home-journal-slider .splide__pagination button.is-active {
  width: calc(1.9 * var(--rem));
}
.layout-container .home-journal .home-journal-slider .splide__pagination button.is-active::before {
  width: calc(1.1 * var(--rem));
  background-color: #898989;
}
.layout-container .home-journal .home-journal-slider__image {
  width: calc(38.8 * var(--rem));
  height: calc(38.8 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider__image {
    width: calc(25 * var(--rem));
    height: calc(25 * var(--rem));
  }
}
.layout-container .home-journal .home-journal-slider__image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.layout-container .home-journal .home-journal-slider__content {
  padding-top: calc(1 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider__content {
    padding-top: calc(1.2 * var(--rem));
  }
}
.layout-container .home-journal .home-journal-slider__text {
  margin-top: calc(0.6 * var(--rem));
  font-size: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider__text {
    margin-top: calc(0.2 * var(--rem));
    font-size: calc(1 * var(--rem));
  }
}
.layout-container .home-journal .home-journal-slider__note {
  margin-top: calc(0.8 * var(--rem));
  color: #898989;
  font-size: calc(1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-journal .home-journal-slider__note {
    font-size: calc(1.2 * var(--rem));
  }
}
.layout-container .home-news {
  padding: calc(15.2 * var(--rem)) 0 calc(12 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-news {
    padding: calc(12 * var(--rem)) 0 calc(13.4 * var(--rem));
  }
}
.layout-container .home-news .home-section__inner {
  display: flex;
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-section__inner {
    flex-direction: column;
  }
}
.layout-container .home-news .home-section__heading {
  flex-shrink: 0;
  width: calc(30 * var(--rem));
  text-align: left;
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-section__heading {
    width: 100%;
    text-align: center;
  }
}
.layout-container .home-news .home-section__link {
  flex: 1;
  margin-top: auto;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-section__link {
    margin-top: calc(3.2 * var(--rem));
    text-align: center;
  }
}
.layout-container .home-news .home-section__link a {
  display: inline-block;
  margin-top: calc(-0.6 * var(--rem));
}
.layout-container .home-news .home-news-contents {
  width: calc(53 * var(--rem));
  margin-top: calc(-1.2 * var(--rem));
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-news-contents {
    width: 100%;
    margin-top: calc(1.6 * var(--rem));
  }
}
.layout-container .home-news .home-news-contents__item a span {
  display: block;
  padding: calc(1.2 * var(--rem)) 0;
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-news-contents__item a span {
    padding: calc(1.6 * var(--rem)) 0;
  }
}
.layout-container .home-news .home-news-contents__text {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  line-height: 1.6666666667;
  letter-spacing: 0.08em;
}
.layout-container .home-news .home-news-contents__date {
  display: block;
  margin-top: calc(1.4 * var(--rem));
  font-size: calc(1.2 * var(--rem));
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  .layout-container .home-news .home-news-contents__date {
    margin-top: calc(0.8 * var(--rem));
    font-size: calc(1 * var(--rem));
  }
}