/*--------------------------------------------------------
  Function
--------------------------------------------------------*/
/*--------------------------------------------------------
  Font
--------------------------------------------------------*/
main {
  font-family: "Roboto", sans-serif;
  font-size: max(15px, 0.78125vw);
  line-height: 1.8;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-weight: 400;
  background-color: #090D11;
  color: #FFFFFF;
}
@media (max-width: 768px) {
  main {
    font-size: 0.8125rem;
    letter-spacing: 0;
  }
}

#main {
  overflow: clip;
  margin-top: 0;
  padding-top: 80px;
}

section {
  position: relative;
}

#wrapper {
  overflow: clip;
}

/*--------------------------------------------------------
  Layout
--------------------------------------------------------*/
.container {
  max-width: calc(75vw + 72px);
  margin: 0 auto;
  padding: 0 36px;
  height: 100%;
  container-type: inline-size;
}
@media (max-width: 768px) {
  .container {
    padding: 0 clamp(16px, 4.6875vw, 36px);
    max-width: initial;
  }
}
.container section {
  z-index: 2;
}

.col2 {
  display: flex;
}

/*--------------------------------------------------------
  Component
--------------------------------------------------------*/
.btn--cv {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 9.375vw;
  padding: 1rem 2rem;
  border: 1px solid currentColor;
  color: #FFFFFF;
  font-family: "Noto Serif JP", serif;
  font-size: max(13px, 0.9375vw);
  line-height: 1;
  text-decoration: none;
  transition: all 0.3s ease;
}
.btn--cv::after {
  position: absolute;
  top: 50%;
  right: 0;
  display: block;
  width: 3.125vw;
  height: 1px;
  background: #FFFFFF;
  transform: translate(50%, -50%);
  content: "";
  mix-blend-mode: difference;
}
.btn--cv:hover {
  background: #FFFFFF;
  color: #000000;
  border-color: #FFFFFF;
  opacity: 1;
}
.btn--black {
  color: #000000;
}
.btn--black::after {
  background: currentColor;
  mix-blend-mode: initial;
}
.btn--black:hover {
  background: #000000;
  color: #FFFFFF;
  border-color: #000000;
}

.nav-list {
  list-style: none;
}

.bg-object {
  position: absolute;
  top: 0;
  width: 50%;
  height: auto;
  aspect-ratio: 558/335;
  background-image: url("/common/product/yumezukuri/_assets/img/bg-line.png");
  background-size: contain;
  content: "";
  opacity: 0.5;
  mix-blend-mode: lighten;
  z-index: 0;
}
.bg-object:nth-of-type(odd) {
  left: calc(-1 * (50svw - 50cqw));
}
.bg-object:nth-of-type(even) {
  right: calc(-1 * (50svw - 50cqw));
}
.bg-object:nth-of-type(1) {
  rotate: 180deg;
}
.bg-object:nth-of-type(2) {
  top: 100vh;
  transform: scale(-1, 1);
}
.bg-object:nth-of-type(3) {
  transform: scale(1, -1);
  top: 34%;
  left: 25%;
}
.bg-object:nth-of-type(4) {
  transform: scale(-1, -1);
  top: 45.5%;
}

.local-nav {
  position: sticky;
  margin-left: 3.3333333333vw;
  top: 30%;
  z-index: 1000;
}
@media (max-width: 768px) {
  .local-nav {
    display: none;
  }
}

.local-nav-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 1.25vw;
  margin-top: 8.3333333333vw;
}

.local-nav-link {
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  opacity: 0.4;
  mix-blend-mode: difference;
  transition: opacity 300ms ease;
}
.local-nav-link.active {
  opacity: 1;
}

.sp-local-nav {
  display: none;
}
@media (max-width: 768px) {
  .sp-local-nav {
    display: block;
    position: fixed;
    bottom: 0;
    left: 50%;
    z-index: 1000;
    transform: translateX(-50%);
  }
}
.sp-local-nav .local-nav-list {
  justify-content: center;
  align-items: center;
  gap: 3.3333333333vw;
  background: #090D11;
  color: #FFFFFF;
  width: 100vw;
  height: 100vh;
}

.sp-local-nav-toggle {
  display: none;
  transition: opacity 600ms ease;
}
@media (max-width: 768px) {
  .sp-local-nav-toggle {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;
    position: fixed;
    bottom: -1rem;
    left: 50%;
    z-index: 1000;
    transform: translateX(-50%);
    border: none;
    width: 120px;
    min-height: 2.5rem;
    padding-top: 1rem;
    padding-bottom: 2rem;
    background: #000000;
    color: #FFFFFF;
    font-size: 0.875rem;
    font-weight: 400;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    border-right: 1px solid rgba(255, 255, 255, 0.2);
    border-left: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 4px 4px 0 0;
  }
}
.sp-local-nav-toggle[aria-expanded=false] + .local-nav-list {
  display: none;
}
.sp-local-nav-toggle .bar1,
.sp-local-nav-toggle .bar2 {
  transition: transform 0.4s cubic-bezier(0.4, 1, 0.4, 1), opacity 0.3s;
  transform-origin: center;
}
.sp-local-nav-toggle[aria-expanded=true] .bar1 {
  transform: rotate(45deg) translate(0, 2px);
}
.sp-local-nav-toggle[aria-expanded=true] .bar2 {
  transform: rotate(-45deg) translate(0, -2px);
}
.sp-local-nav-toggle[aria-expanded=true] + .local-nav-list {
  display: flex;
}
.sp-local-nav-toggle.is-hidden {
  opacity: 0;
  visibility: hidden;
}

.tablist {
  display: flex;
  gap: 2.0833333333vw;
  margin-bottom: 3.3333333333vw;
  padding-top: 1.875vw;
}
@media (max-width: 768px) {
  .tablist {
    gap: 0;
    justify-content: space-between;
    margin-bottom: 2rem;
  }
}
.tablist .tab {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1;
  background: transparent;
  border: none;
  border-radius: 0;
  color: #FFFFFF;
  cursor: pointer;
  align-items: center;
}
@media (max-width: 768px) {
  .tablist .tab {
    padding: 0;
  }
}
.tablist .tab.is-visible {
  opacity: 0.4;
}
.tablist .tab[aria-selected=true] {
  opacity: 1 !important;
}
.tablist .tab[aria-selected=true]::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  content: "";
  background: #9B9BC3;
  filter: blur(40px);
  width: 80%;
  height: 10%;
  z-index: -1;
}
.tablist .tab[aria-selected=true]::after {
  position: absolute;
  top: calc(100% + 0.8333333333vw);
  left: 50%;
  background: rgba(255, 255, 255, 0.5);
  width: 1px;
  height: 2.5vw;
  content: "";
}
@media (max-width: 768px) {
  .tablist .tab[aria-selected=true]::after {
    top: calc(100% + 1rem);
    height: 1rem;
  }
}
.tablist .tab:nth-of-type(2)::before {
  background: #A69E7E;
}
.tablist .tab:nth-of-type(3)::before {
  background: #A77F54;
}
.tablist .tab:nth-of-type(4)::before {
  background: #C65116;
}
.tablist .thumb {
  z-index: 1;
}
.tablist img {
  width: 100%;
  mix-blend-mode: lighten;
}
.tablist .label {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: max(24px, 1.875vw);
  line-height: 1.6;
  letter-spacing: 0.04em;
  font-weight: 400;
  line-height: 1.3;
  align-items: center;
}
@media (max-width: 768px) {
  .tablist .label {
    font-size: max(20px, 3.125vw);
  }
}
@media (max-width: 768px) {
  .tablist .label {
    font-size: 0.875rem;
    line-height: 1.2;
  }
}
.tablist .label .small {
  font-size: 0.75em;
}

.panels {
  margin-bottom: 4.1666666667vw;
}
.panels .panel {
  padding: 2.0833333333vw;
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 4px;
}
@media (max-width: 768px) {
  .panels .panel {
    padding: 1rem;
  }
}
.panels .panel-title {
  font-family: "Noto Serif JP", serif;
  font-size: 1.125rem;
  letter-spacing: 0.08em;
  line-height: 1.8;
  margin-bottom: 1rem;
}
@media (max-width: 768px) {
  .panels .panel-title {
    font-size: 1rem;
    line-height: 1.5;
    letter-spacing: unset;
  }
}

.text-gold {
  color: #DFC168;
}

/*--------------------------------------------------------
  Section
--------------------------------------------------------*/
.concept {
  height: calc(clamp(840px, 100lvh, 1080px) - 80px);
  color: #FFFFFF;
}
.concept > * {
  z-index: 1;
}
@media (max-width: 768px) {
  .concept {
    display: flex;
    flex-direction: column;
    height: auto;
    background-position: 65%;
    overflow: initial;
    margin-bottom: min(720px - 50vw, 380px);
  }
}
.concept .slider__img-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.concept .slider__img-container::after {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 400vw;
  height: 400vh;
  background: #090D11;
  border-radius: 50%;
  filter: blur(300px);
  content: "";
  z-index: 10;
  animation: conceptAfterOut 4000ms ease-out forwards;
  animation-delay: 600ms;
}
@media (max-width: 768px) {
  .concept .slider__img-container::after {
    filter: blur(100px);
  }
}
@keyframes conceptAfterOut {
  to {
    transform: translate(100%, 100%);
    opacity: 0;
  }
}
.concept .slider__img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
}
.concept .slider__img-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}
.concept .slider__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.1);
  transform-origin: left bottom;
  will-change: transform, opacity;
  backface-visibility: hidden;
  opacity: 0;
  transition: opacity 1.5s linear, transform 6s linear;
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 768px) {
  .concept .slider__img {
    transform-origin: right bottom;
  }
}
.concept .slider__img.active {
  opacity: 1 !important;
  z-index: 3;
  animation: pan var(--slide-dur, 6s) linear forwards;
}
.concept .slider__img.prev {
  opacity: 0;
  z-index: 2;
  transform: scale(1);
}
.concept .slider__img.hidden {
  opacity: 0;
  z-index: 0;
  transform: scale(1.1);
}
.concept__body {
  display: flex;
  flex-direction: column;
  justify-content: end;
  flex: 1;
}
@media (max-width: 768px) {
  .concept__body {
    position: absolute;
    top: 100%;
    right: 0;
    transform: translateY(-10%);
    color: #000000;
    background: #FFFFFF;
    margin-left: 2rem;
    padding: 1rem calc(50svw - 50cqw) 1rem 1rem;
  }
  .concept__body.fade-simple {
    opacity: 1;
    transform: translateY(-10%);
  }
}
.concept__scroller {
  position: absolute;
  top: 50%;
  right: 2.0833333333vw;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.8333333333vw;
  font-family: "Noto Serif JP", serif;
  font-size: max(13px, 0.8333333333vw);
  letter-spacing: 0.24em;
  transform: translateY(-50%);
  writing-mode: vertical-rl;
}
@media (max-width: 768px) {
  .concept__scroller {
    top: 40%;
    font-size: 0.625rem;
  }
}
.concept__scroller::after {
  position: absolute;
  top: calc(100% + 16px);
  left: 50%;
  content: "";
  display: inline-block;
  width: 1px;
  height: 80px;
  background: #FFFFFF;
  animation: scroll 2s infinite;
}
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.concept__wrapper {
  display: flex;
  height: 100%;
}
.concept__container {
  display: flex;
  flex-direction: column;
  width: 60%;
  font-family: "Noto Serif JP", serif;
}
@media (max-width: 768px) {
  .concept__container {
    width: 100%;
    padding-bottom: 6rem;
  }
}
@media (max-width: 768px) {
  .concept__animation.fade-simple {
    opacity: 1;
    transform: translateY(0%);
  }
}
.concept__title {
  display: inline-flex;
  flex-direction: column;
  margin-right: auto;
  font-weight: 400;
  margin-top: 3.3333333333vw;
  margin-bottom: 2.0833333333vw;
  line-height: 1.5;
  letter-spacing: 0.08em;
  font-size: max(28px, 2.0833333333vw);
}
@media (max-width: 768px) {
  .concept__title {
    font-size: 1.3rem;
    margin-top: 2rem;
    margin-bottom: 4rem;
  }
}
.concept__title br.sp {
  display: none;
}
@media (max-width: 768px) {
  .concept__title br.sp {
    display: initial;
  }
}
.concept__title strong {
  font-size: 1.6em;
  font-weight: 400;
}
.concept__desc {
  margin-bottom: 1.25vw;
  font-size: max(14px, 0.7291666667vw);
  letter-spacing: 0.08em;
  line-height: 1.6;
}
@media (max-width: 768px) {
  .concept__desc {
    font-size: max(13px, 0.6770833333vw);
    line-height: 1.5;
  }
}
.concept__desc-line {
  margin: 0;
}
.concept__desc-line + .concept__desc-line {
  margin-top: 1em;
}
.concept__cta {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: start;
  margin-bottom: 3rem;
}
@media (max-width: 768px) {
  .concept__cta {
    margin-top: 2rem;
    margin-bottom: 0;
  }
}
.concept__cta .btn--cv {
  background: #FFFFFF;
  color: #000000;
}
@media (max-width: 768px) {
  .concept__cta .btn--cv {
    width: 100%;
  }
}
.concept__info {
  display: flex;
  align-items: end;
  margin-top: 1.25vw;
  margin-bottom: 24px;
}
@media (max-width: 768px) {
  .concept__info {
    justify-content: space-between;
  }
}
.concept__name {
  margin-right: 24px;
}
.concept__name-ja {
  font-size: 2.5rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media (max-width: 768px) {
  .concept__name-ja {
    font-size: 1.75rem;
  }
}
.concept__name-en {
  font-size: 10px;
  letter-spacing: 0.1em;
}
.concept__price {
  margin: 0;
}
.concept__price-currency {
  font-size: max(14px, 0.9375vw);
}
.concept__price-value {
  font-size: max(24px, 1.5625vw);
}
.concept__price-tax {
  font-size: max(12px, 0.8333333333vw);
}
.concept__price-note {
  font-size: max(11px, 0.7291666667vw);
  margin-top: 3rem;
}
@media (max-width: 768px) {
  .concept__price-note {
    margin-top: 1rem;
  }
}

.story {
  display: flex;
  flex-direction: column;
  gap: 18.75vw;
  margin-block: 12.5vw;
}
@media (max-width: 768px) {
  .story {
    gap: 10rem;
  }
}
.story__title-container {
  position: absolute;
  top: -2.8%;
  left: -2.8%;
  z-index: 1;
  mix-blend-mode: difference;
}
@media (max-width: 768px) {
  .story__title-container {
    top: -1.5%;
    left: 0;
  }
}
.story__annotation {
  font-family: "Noto Serif JP", serif;
  font-size: max(18px, 1.0416666667vw);
  line-height: 2.4;
  letter-spacing: 0.08em;
  font-weight: 500;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 4px;
}
@media (max-width: 768px) {
  .story__annotation {
    font-size: 1rem;
    line-height: 1.6;
  }
}
@media (max-width: 768px) {
  .story__annotation {
    padding: 0.75rem;
  }
}
.story__title {
  display: flex;
  flex-direction: column-reverse;
  font-family: "Noto Serif JP", serif;
  font-size: 3.3333333333vw;
  font-weight: 300;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
@media (max-width: 768px) {
  .story__title {
    font-size: max(30px, 4.1666666667vw);
  }
}
.story__title-ja {
  line-height: 1.2;
}
.story__title-en {
  font-size: max(9px, 0.25em);
  font-weight: 600;
  letter-spacing: 0.4em;
  color: #DFC168;
}
.story__first-block {
  position: relative;
  display: flex;
  align-items: center;
}
@media (max-width: 1280px) {
  .story__first-block {
    align-items: start;
  }
}
@media (max-width: 768px) {
  .story__first-block {
    flex-direction: column;
    align-items: start;
    gap: 1.5rem;
  }
}
.story__first-img {
  width: 50%;
  margin: 0;
  aspect-ratio: 3/2;
}
@media (max-width: 768px) {
  .story__first-img {
    width: auto;
    margin-right: calc(-1 * (50svw - 50cqw));
  }
}
.story__first-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 4px;
}
@media (max-width: 768px) {
  .story__first-img img {
    border-radius: 4px 0 0 4px;
  }
}
.story__first-desc {
  display: flex;
  flex-direction: column;
  gap: 1em;
  width: 40%;
  margin-left: 2em;
  font-family: "Noto Serif JP", serif;
  font-size: max(15px, 0.78125vw);
  line-height: 2.4;
  letter-spacing: 0.08em;
  font-weight: 500;
}
@media (max-width: 768px) {
  .story__first-desc {
    font-size: 0.8125rem;
  }
}
@media (max-width: 768px) {
  .story__first-desc {
    width: 100%;
    margin-left: 0;
    gap: 1.5em;
  }
}
.story__first-desc .story__line {
  text-align: left;
}
@media (max-width: 768px) {
  .story__first-desc .story__line {
    text-align: center;
  }
}
.story__block {
  display: flex;
  flex-direction: column;
  gap: 2em;
  width: max(440px, 40%);
  margin: 0 auto;
  font-family: "Noto Serif JP", serif;
  font-size: max(15px, 0.78125vw);
  line-height: 2.4;
  letter-spacing: 0.08em;
  font-weight: 500;
}
@media (max-width: 768px) {
  .story__block {
    font-size: 0.8125rem;
  }
}
@media (max-width: 768px) {
  .story__block {
    width: 100%;
    padding: 0;
  }
}
.story__block + .story__block {
  margin-top: 18.75vw;
}
.story__line {
  text-align: center;
}
.story__line br.sp {
  display: none;
}
@media (max-width: 768px) {
  .story__line br.pc {
    display: none;
  }
  .story__line br.sp {
    display: initial;
  }
}
.story__parallax {
  position: relative;
  z-index: 1;
  mix-blend-mode: difference;
}
.story__imgs {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  z-index: -1;
}
.story__img {
  position: absolute;
  border-radius: 4px;
}
@media (max-width: 768px) {
  .story__img {
    opacity: 0.3;
  }
}
.story__img-01 {
  top: -5%;
  right: 2%;
  width: 12.8125vw;
  height: auto;
  aspect-ratio: 2/3;
}
@media (max-width: 768px) {
  .story__img-01 {
    width: 25.5208333333vw;
  }
}
.story__img-02 {
  top: 20%;
  left: 4%;
  width: 11.4583333333vw;
  height: auto;
  aspect-ratio: 1/1;
}
@media (max-width: 768px) {
  .story__img-02 {
    width: 22.9166666667vw;
  }
}
.story__img-03 {
  top: 60%;
  right: 4%;
  width: 12.5vw;
  height: auto;
  aspect-ratio: 3/2;
}
@media (max-width: 768px) {
  .story__img-03 {
    width: 25vw;
  }
}
.story__img-04 {
  top: 80%;
  left: 2%;
  width: 12.5vw;
  height: auto;
  aspect-ratio: 2/3;
}
@media (max-width: 768px) {
  .story__img-04 {
    width: 25vw;
  }
}
.story__line {
  margin-top: 0;
}

.product {
  margin-top: 16.6666666667vw;
}
@media (max-width: 768px) {
  .product {
    margin-top: 6rem;
  }
}
.product__title-container {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  color: #FFFFFF;
  mix-blend-mode: difference;
  transform: translateY(-47.5%);
}
@media (max-width: 768px) {
  .product__title-container {
    right: initial;
    left: 0;
    transform: translateY(-43%);
  }
}
.product__title {
  display: flex;
  flex-direction: column-reverse;
  font-family: "Noto Serif JP", serif;
  font-size: 3.3333333333vw;
  font-weight: 300;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  min-width: 2.8em;
}
@media (max-width: 768px) {
  .product__title {
    font-size: max(30px, 4.1666666667vw);
  }
}
.product__title-ja {
  position: relative;
  line-height: 1.2;
  letter-spacing: 0.15em;
  padding-top: 10.4166666667vw;
}
@media (max-width: 768px) {
  .product__title-ja {
    padding-top: 4.5rem;
  }
}
.product__title-ja::before {
  position: absolute;
  left: 50%;
  top: 0;
  display: block;
  width: 1px;
  height: 9.375vw;
  background: #FFFFFF;
  content: "";
}
@media (max-width: 768px) {
  .product__title-ja::before {
    height: 4rem;
  }
}
.product__title-en {
  font-size: 0.25em;
  font-weight: 600;
  letter-spacing: 0.4em;
  padding-top: 10.4166666667vw;
  color: #DFC168;
}
@media (max-width: 768px) {
  .product__title-en {
    padding-top: 4.6rem;
  }
}
.product__img {
  margin: 0;
  overflow: hidden;
  border-radius: 4px;
  margin-bottom: 1.25vw;
  aspect-ratio: 16/9;
}
@media (max-width: 768px) {
  .product__img {
    aspect-ratio: 1/1;
    margin-bottom: 1.5rem;
  }
}
.product__img img {
  max-width: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product__desc {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin-bottom: 6.25vw;
  font-family: "Roboto", sans-serif;
  font-size: max(15px, 0.78125vw);
  line-height: 1.8;
  letter-spacing: 0.04em;
  font-weight: 400;
}
@media (max-width: 768px) {
  .product__desc {
    font-size: 0.8125rem;
    letter-spacing: 0;
  }
}
@media (max-width: 768px) {
  .product__desc {
    margin-bottom: 4rem;
  }
}
.product__line {
  margin: 0;
}
.product__method {
  display: grid;
  grid-template-rows: max-content 1fr;
  column-gap: 1.6666666667vw;
  row-gap: 1.25vw;
  margin-bottom: 4.1666666667vw;
  padding: 3.3333333333vw 5vw;
  color: #FFFFFF;
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 4px;
}
@media (max-width: 768px) {
  .product__method {
    display: flex;
    flex-direction: column;
    padding: 1rem;
  }
}
.product__method-title {
  display: flex;
  align-items: baseline;
  grid-row: 1/2;
  grid-column: 1/2;
  font-family: "Noto Serif JP", serif;
  font-size: 2.2916666667vw;
  font-weight: 400;
}
@media (max-width: 768px) {
  .product__method-title {
    font-size: max(28px, 4.1666666667vw);
  }
}
.product__method-title-ruby {
  font-size: 0.4em;
}
.product__method-desc {
  grid-row: 2/3;
  grid-column: 1/2;
  font-family: "Noto Serif JP", serif;
  font-size: max(15px, 0.78125vw);
  line-height: 2.4;
  letter-spacing: 0.08em;
  font-weight: 500;
  line-height: 1.8;
}
@media (max-width: 768px) {
  .product__method-desc {
    font-size: 0.8125rem;
  }
}
.product__method-line + .product__method-line {
  margin-top: 1em;
}
.product__method-img {
  grid-row: 1/3;
  grid-column: 2/3;
  border-radius: 4px;
  overflow: hidden;
}
@media (max-width: 768px) {
  .product__method-img {
    order: -1;
    margin-bottom: 1rem;
  }
}
.product__method-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.taste {
  padding-top: 4.1666666667vw;
}
.taste__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 3.3333333333vw;
}
@media (max-width: 768px) {
  .taste__title {
    margin-bottom: 2.25rem;
  }
}
.taste__title::after {
  display: block;
  width: 80px;
  height: 1px;
  margin-top: 1.25vw;
  background: currentColor;
  content: "";
}
.taste__title-ja {
  font-family: "Noto Serif JP", serif;
  font-size: 3.3333333333vw;
  font-weight: 300;
}
@media (max-width: 768px) {
  .taste__title-ja {
    font-size: max(30px, 4.1666666667vw);
  }
}
.taste__title-en {
  font-family: "Noto Serif JP", serif;
  font-size: max(13px, 0.8333333333vw);
  letter-spacing: 0.4em;
  color: #DFC168;
}
.taste__desc {
  font-family: "Roboto", sans-serif;
  font-size: max(15px, 0.78125vw);
  line-height: 2;
  letter-spacing: 0.04em;
  font-weight: 400;
  text-align: center;
  margin-bottom: 4.1666666667vw;
}
@media (max-width: 768px) {
  .taste__desc {
    font-size: 0.8125rem;
    letter-spacing: 0;
  }
}
@media (max-width: 768px) {
  .taste__desc {
    margin-bottom: 2.25rem;
  }
  .taste__desc br {
    display: none;
  }
}
.taste__window {
  margin-bottom: 8.3333333333vw;
}
@media (max-width: 768px) {
  .taste__window {
    margin-bottom: 4rem;
    margin-right: calc(-1 * (50svw - 35cqw));
    margin-left: calc(-1 * (50svw - 35cqw));
  }
}
.taste__window-frame {
  position: relative;
  clip-path: url(#tasteClip);
  -webkit-clip-path: url(#tasteClip);
  aspect-ratio: 1056/669;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 0;
  overflow: visible;
}
.taste__window-img {
  width: 100%;
}
.taste__block-title {
  margin-bottom: 0.8333333333vw;
  font-family: "Noto Serif JP", serif;
  font-size: max(24px, 1.875vw);
  line-height: 1.6;
  letter-spacing: 0.04em;
  font-weight: 400;
  text-align: center;
}
@media (max-width: 768px) {
  .taste__block-title {
    font-size: max(20px, 3.125vw);
  }
}
@media (max-width: 768px) {
  .taste__block-title {
    margin-bottom: 1rem;
  }
}
.taste__temp {
  display: flex;
  gap: 3.3333333333vw;
  margin: 8.3333333333vw 0;
}
@media (max-width: 768px) {
  .taste__temp {
    gap: 0;
  }
}
.taste__temp .taste__list {
  display: flex;
  flex-direction: column;
  gap: 0.4166666667vw;
  margin: 8.3333333333vw 0;
  padding: 0;
  list-style: none;
}
@media (max-width: 768px) {
  .taste__temp .taste__list {
    width: calc(100% - 2rem);
  }
}
.taste__temp .taste__item {
  transform: translateY(24px) !important;
  transition: opacity 0.45s ease, transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), filter 0.6s ease;
  will-change: opacity, transform, filter;
}
@media (max-width: 768px) {
  .taste__temp .taste__item {
    height: auto;
  }
}
.taste__temp .taste__inner {
  top: 30%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.875vw;
}
@media (max-width: 768px) {
  .taste__temp .taste__inner {
    position: relative;
    top: 0;
    gap: 1.5rem;
  }
}
.taste__temp .taste__item-title {
  margin: 0;
  margin-bottom: 0.8333333333vw;
  font-family: "Noto Serif JP", serif;
  font-family: "Noto Serif JP", serif;
  font-size: max(18px, 1.0416666667vw);
  line-height: 2.4;
  letter-spacing: 0.08em;
  font-weight: 500;
  font-weight: 600;
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .taste__temp .taste__item-title {
    font-size: 1rem;
    line-height: 1.6;
  }
}
@media (max-width: 768px) {
  .taste__temp .taste__item-title {
    margin-bottom: 0.5rem;
  }
}
.taste__temp .taste__item.is-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.design__header {
  position: relative;
  display: flex;
  align-items: end;
  height: 20.8333333333vw;
  margin: 4.1666666667vw calc(-1 * (50svw - 50cqw)) 1.875vw 0;
  padding: 2.0833333333vw;
  border-radius: 4px 0 0 4px;
}
@media (max-width: 768px) {
  .design__header {
    padding: 1.5rem calc(50svw - 50cqw);
    margin: 0 calc(-1 * (50svw - 50cqw)) 2.25rem;
    border-radius: 0;
    height: auto;
    aspect-ratio: 5/4;
  }
}
.design__header-figure {
  position: absolute;
  top: 0;
  left: 0;
  margin-right: calc(-1 * (50svw - 50cqw));
  width: 100%;
  height: 100%;
  border-radius: 4px 0 0 4px;
  z-index: 0;
  overflow: hidden;
}
@media (max-width: 768px) {
  .design__header-figure {
    border-radius: 0;
    margin-right: initial;
  }
}
.design__header-img {
  width: 100%;
}
@media (max-width: 768px) {
  .design__header-img {
    height: 100%;
    object-fit: cover;
  }
}
.design__title {
  display: flex;
  flex-direction: column;
  z-index: 1;
}
.design__title-ja {
  font-family: "Noto Serif JP", serif;
  font-size: 3.3333333333vw;
  font-weight: 300;
}
@media (max-width: 768px) {
  .design__title-ja {
    font-size: max(30px, 4.1666666667vw);
  }
}
.design__title-en {
  margin-left: 0.5em;
  font-family: "Noto Serif JP", serif;
  font-size: max(13px, 0.8333333333vw);
  letter-spacing: 0.4em;
}
.design__body {
  display: flex;
  gap: 3.3333333333vw;
  margin-bottom: 6.25vw;
}
.design__desc {
  width: 100%;
  margin: 0;
}
.design__cta {
  width: calc(50svw - 50cqw);
  flex-shrink: 0;
}
.design__panels {
  margin-bottom: 8.3333333333vw;
}
@media (max-width: 768px) {
  .design__panels {
    margin-bottom: 1.5rem;
  }
}
.design__panels-row {
  display: flex;
}
.design__panels-row:nth-child(even) {
  flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .design__panels-row:nth-child(even) {
    flex-direction: column;
    margin-bottom: 1.5rem;
  }
}
@media (max-width: 768px) {
  .design__panels-row {
    flex-direction: column;
    margin-bottom: 2.25rem;
  }
}
.design__panel {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  flex: 1;
  max-width: 50%;
  margin: 0;
  aspect-ratio: 1/1;
}
@media (max-width: 768px) {
  .design__panel {
    max-width: 100%;
  }
}
.design__panel:has(h3) {
  padding: 2.0833333333vw;
}
@media (max-width: 768px) {
  .design__panel:has(h3) {
    aspect-ratio: auto;
  }
}
@media (max-width: 768px) {
  .design figure.design__panel {
    border-radius: 4px;
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    overflow: hidden;
  }
}
.design__panel-title {
  font-family: "Noto Serif JP", serif;
  font-size: max(24px, 1.875vw);
  line-height: 1.6;
  letter-spacing: 0.04em;
  font-weight: 400;
  margin-bottom: 1em;
}
@media (max-width: 768px) {
  .design__panel-title {
    font-size: max(20px, 3.125vw);
  }
}
@media (max-width: 768px) {
  .design__panel-title {
    margin-top: 1em;
  }
}
.design__panel-subtitle {
  display: block;
  font-size: 0.666667em;
  text-align: center;
  line-height: 1;
}
@media (max-width: 768px) {
  .design__panel-desc {
    text-align: center;
  }
}
.design__panels-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about {
  margin: 4.1666666667vw calc(-1 * (50svw - 50cqw)) 0;
  background: #FFFFFF;
  color: #000000;
}
.about__header {
  position: relative;
  overflow: hidden;
  margin-bottom: 3.3333333333vw;
}
@media (max-width: 768px) {
  .about__header {
    margin-bottom: 2.25rem;
  }
}
.about__figure {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 0;
  aspect-ratio: 3/1;
  overflow: hidden;
}
@media (max-width: 768px) {
  .about__figure {
    aspect-ratio: 2/1;
  }
}
.about__img {
  object-fit: cover;
  width: 100%;
}
@media (max-width: 768px) {
  .about__img {
    height: 150%;
  }
}
.about__label {
  position: absolute;
  bottom: -2px;
  right: 0;
  background: #FFFFFF;
  padding: 0.8333333333vw;
  border-radius: 4px 4px 0 0;
  font-family: "Noto Serif JP", serif;
}
@media (max-width: 768px) {
  .about__label {
    padding: 0.5rem 1rem;
    border-radius: 4px 0 0 0;
    right: calc(-1 * (50svw - 53cqw));
  }
}
.about__label-ja {
  font-size: 1.25vw;
  font-weight: 400;
}
@media (max-width: 768px) {
  .about__label-ja {
    font-size: 1.125rem;
    line-height: 1;
  }
}
.about__label-en {
  font-size: 0.625vw;
  opacity: 0.5;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .about__label-en {
    font-size: 0.5625rem;
    line-height: 1;
    letter-spacing: 0;
  }
}
.about__body {
  display: flex;
  align-items: center;
  gap: 3.3333333333vw;
}
@media (max-width: 768px) {
  .about__body {
    flex-direction: column;
    gap: 2.25rem;
  }
}
.about__logo {
  flex: 1;
}
@media (max-width: 768px) {
  .about__logo {
    max-width: 80%;
  }
}
.about__desc {
  flex: 2;
}
.about__desc .about__line:first-child {
  margin: 0;
}

.profile {
  padding: 8.3333333333vw 0;
}
@media (max-width: 768px) {
  .profile {
    padding: 4rem 0;
  }
}
.profile__list {
  display: flex;
  flex-direction: column;
  gap: 3.3333333333vw;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (max-width: 768px) {
  .profile__list {
    gap: 2.26rem;
  }
}
.profile__item {
  display: flex;
  gap: 2.5vw;
}
.profile__item:nth-of-type(1) .profile__img {
  object-position: right center;
}
@media (max-width: 768px) {
  .profile__item {
    flex-direction: column;
  }
}
.profile__title {
  display: flex;
  flex-direction: column;
  gap: 0.4166666667vw;
  margin-bottom: 4.1666666667vw;
}
@media (max-width: 768px) {
  .profile__title {
    margin-bottom: 2.25rem;
  }
}
.profile__title::after {
  display: block;
  width: 80px;
  height: 1px;
  margin-top: 1.25vw;
  background: currentColor;
  content: "";
}
.profile__title-ja {
  font-family: "Noto Serif JP", serif;
  font-size: 2.2916666667vw;
  font-weight: 400;
}
@media (max-width: 768px) {
  .profile__title-ja {
    font-size: max(28px, 4.1666666667vw);
  }
}
.profile__title-en {
  font-family: "Noto Serif JP", serif;
  font-size: max(14px, 0.8333333333vw);
  letter-spacing: 0.4em;
  line-height: 1.6;
  font-weight: 400;
  color: #DFC168;
}
@media (max-width: 768px) {
  .profile__title-en {
    font-size: max(12px, 0.7291666667vw);
    line-height: 1;
  }
}
.profile__figure {
  flex: 1;
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.1);
  aspect-ratio: 3/2;
  border-radius: 4px;
  overflow: hidden;
}
@media (max-width: 768px) {
  .profile__figure {
    margin-bottom: 0.5rem;
  }
}
.profile__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.profile__item-body {
  flex: 2;
}
.profile__item-header {
  font-family: "Noto Serif JP", serif;
}
.profile__item-position {
  margin: 0 0 0.4166666667vw 0;
  letter-spacing: 0.08em;
}
@media (max-width: 768px) {
  .profile__item-position {
    line-height: 1.2;
  }
}
.profile__name {
  display: flex;
  align-items: center;
  gap: 0.8333333333vw;
  margin-bottom: 1.25vw;
}
.profile__name-ja {
  font-size: max(24px, 1.6666666667vw);
  font-weight: 400;
}
@media (max-width: 768px) {
  .profile__name-ja {
    font-size: 1.5rem;
  }
}
.profile__name-en {
  font-size: 0.75rem;
  font-weight: 400;
  opacity: 0.5;
}

/*--------------------------------------------------------
  CTA
--------------------------------------------------------*/
.cta {
  position: relative;
}
.cta__wrapper {
  padding: 4.1666666667vw 0;
  margin-right: calc(-1 * (50svw - 50cqw));
}
@media (max-width: 768px) {
  .cta__wrapper {
    padding: 4rem 0;
  }
}
.cta__container {
  display: flex;
  align-items: center;
  padding: 2.0833333333vw calc(50svw - 50cqw) 2.0833333333vw 0;
  background: linear-gradient(to right, #16191D 20%, #0A0E12 100%);
  border-radius: 4px 0 0 4px;
}
@media (max-width: 768px) {
  .cta__container {
    padding: 1.5rem calc(50svw - 50cqw) 1.5rem 1rem;
  }
}
.cta__product {
  position: relative;
  flex: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 4.1666666667vw;
}
@media (max-width: 768px) {
  .cta__product {
    position: absolute;
    left: -5%;
    top: calc(4rem + 15%);
    width: min((100% - (50svw - 50cqw) - 1rem) / 2, 200px);
  }
}
.cta__product::before {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: clamp(120px, 80%, 260px);
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjYzIiBoZWlnaHQ9IjI2NCIgdmlld0JveD0iMCAwIDI2MyAyNjQiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggb3BhY2l0eT0iMC41IiBkPSJNMjYyLjA2MiAxMjIuMDYxQzI1OS40NTQgODguMjk0OCAyNDMuODkzIDU2Ljg0NCAyMTguNjMyIDM0LjI4NkMxOTMuMzcyIDExLjcyNzkgMTYwLjM2OCAtMC4xOTA2NjMgMTI2LjUyMyAxLjAyMjgyQzkyLjY3NzggMi4yMzYzMSA2MC42MTIzIDE2LjQ4NzggMzcuMDMyMSA0MC43OTdDMTMuNDUxOCA2NS4xMDYyIDAuMTgyODU5IDk3LjU5MDcgNS45Mjg1ZS0wNSAxMzEuNDU3Qy0wLjAxNDAxMDkgMTQ0Ljg5IDIuNDc2NTMgMTU4LjIwOCA3LjM0NDA0IDE3MC43MjlDMTAuMTcxNyAxNzcuNjA5IDE0LjAwOTcgMTg0LjAyOSAxOC43MzEzIDE4OS43NzdDMjcuNzM5NCAyMDAuNTIzIDQwLjI3MjUgMjA3LjcxOSA1NC4wOTQ1IDIxMC4wODFDNzEuNTg5OSAyMTMuNzY4IDg5LjgzMjMgMjEwLjcwNiAxMDUuMTY1IDIwMS41MDlDMTE1LjI2NSAxOTYuMDkxIDEyMy44MDYgMTg4LjE3MyAxMjkuOTcxIDE3OC41MTFDMTMxLjk4MSAxNzUuNDIzIDEzMy43ODUgMTcyLjIwNSAxMzUuMzcxIDE2OC44NzlDMTM3LjUzMyAxNjQuNDkyIDEzOS4xNSAxNTkuODU2IDE0MC4xODQgMTU1LjA3NUMxNDEuOTM2IDE0Ni44NTUgMTQxLjM5NCAxMzguMzExIDEzOC42MTggMTMwLjM3N0MxMzguNTUxIDEzMC4xNzUgMTM4LjQ3IDEyOS45ODUgMTM4LjM4OSAxMjkuNzgzQzEzOC4xMzkgMTI5LjEwOCAxMzcuODY5IDEyOC40NjcgMTM3LjU4NSAxMjcuODMyTDEzNy40MDMgMTI3LjQ0MUMxMzQuOTYzIDEyMS44OTMgMTMwLjg2MiAxMTcuMjQgMTI1LjY2NSAxMTQuMTIzQzExNC45NTIgMTA3LjI4NSAxMDMuMjM1IDEwOS4yNzcgMTExLjIgMTI1LjMzNUMxMTQuNjc5IDEzMi41MDIgMTE1LjYgMTQwLjY0NSAxMTMuODEgMTQ4LjQwOEMxMTIuMDE5IDE1Ni4xNzIgMTA3LjYyNSAxNjMuMDg5IDEwMS4zNTggMTY4LjAwOEM5OS4xNTgyIDE2Ni4xNzcgOTcuMTM1NiAxNjQuMTQzIDk1LjMxNjcgMTYxLjkzM0M4OS44NjMzIDE1NS4yODQgODYuNDEwMiAxNDcuMjIzIDg1LjM1OSAxMzguNjg4Qzg0LjMwNzggMTMwLjE1MyA4NS43MDE5IDEyMS40OTUgODkuMzc5MSAxMTMuNzIyQzkzLjA1NjIgMTA1Ljk0OCA5OC44NjUyIDk5LjM3ODMgMTA2LjEzIDk0Ljc3N0MxMTMuMzk1IDkwLjE3NTggMTIxLjgxNyA4Ny43MzIyIDEzMC40MTcgODcuNzMwNUMxMzEuOTA5IDg3LjczMDUgMTMzLjQxNCA4Ny44MTE1IDEzNC45MzMgODcuOTUzM0MxNDUuNzQzIDg5LjAxOTcgMTU1LjgxMyA5My45Mjc1IDE2My4zMTMgMTAxLjc4NkMxNzAuODE0IDEwOS42NDQgMTc1LjI0NyAxMTkuOTMxIDE3NS44MDkgMTMwLjc3OUMxNzYuMzcxIDE0MS42MjggMTczLjAyNCAxNTIuMzE4IDE2Ni4zNzYgMTYwLjkwOUMxNTkuNzI4IDE2OS41IDE1MC4yMTkgMTc1LjQyMiAxMzkuNTc3IDE3Ny42QzEzMy44NDMgMTg5LjEzMSAxMjQuNzggMTk4LjY3NSAxMTMuNTYyIDIwNC45OThDMTE2LjcxNiAyMDUuNzQ2IDExOS45MTYgMjA2LjI4NSAxMjMuMTQgMjA2LjYxMkMxMjUuNjExIDIwNi44NTUgMTI4LjA1NCAyMDYuOTc2IDEzMC40OTEgMjA2Ljk3NkMxNDcuNTcgMjA3LjAyIDE2NC4xMzggMjAxLjE1NyAxNzcuMzg5IDE5MC4zODJDMTkwLjYzOSAxNzkuNjA2IDE5OS43NTYgMTY0LjU4IDIwMy4xOTQgMTQ3Ljg1MUMyMDYuNjMyIDEzMS4xMjIgMjA0LjE4IDExMy43MTkgMTk2LjI1MyA5OC41OTA4QzE4OC4zMjYgODMuNDYzIDE3NS40MTMgNzEuNTQxMyAxNTkuNzAxIDY0Ljg0NjVDMTQzLjk4OSA1OC4xNTE2IDEyNi40NDUgNTcuMDk1NSAxMTAuMDQ0IDYxLjg1N0M5My42NDE5IDY2LjYxODUgNzkuMzkxMiA3Ni45MDQ3IDY5LjcwNjggOTAuOTcyM0M2MC4wMjIzIDEwNS4wNCA1NS41IDEyMi4wMjMgNTYuOTA2MiAxMzkuMDQ0QzU4LjMxMjQgMTU2LjA2NSA2NS41NjA4IDE3Mi4wNzYgNzcuNDIyNiAxODQuMzYzQzcyLjU3OTkgMTg1LjIxMyA2Ny42MTU4IDE4NS4wNzYgNjIuODI3IDE4My45NjNDNTguMDM4MiAxODIuODUgNTMuNTIzMSAxODAuNzgyIDQ5LjU1MTcgMTc3Ljg4NEM0My45MDgzIDE3My4yNzggMzkuMjU2NSAxNjcuNTc3IDM1Ljg3NyAxNjEuMTI1QzMyLjQ5NzYgMTU0LjY3MiAzMC40NjA2IDE0Ny42MDIgMjkuODg5IDE0MC4zNEMyNy4zOTIyIDExNi43OTYgMzQuMTM0NSA5My4yMDM1IDQ4LjY5NDUgNzQuNTM0M0M1OC44ODggNjAuNTY4OSA3Mi40NjI4IDQ5LjQyMjQgODguMTQ0NyA0Mi4xNDExQzEwMy44MjcgMzQuODU5OCAxMjEuMTAyIDMxLjY4MjMgMTM4LjM0OCAzMi45MDdDMTUzLjM3NCAzMy44MTQ5IDE2Ny45OTggMzguMTIxNSAxODEuMTE4IDQ1LjUwMjFDMTk0LjIzOCA1Mi44ODI3IDIwNS41MTEgNjMuMTQ1IDIxNC4wODkgNzUuNTE1NEMyMjIuNjY3IDg3Ljg4NTggMjI4LjMyNSAxMDIuMDQyIDIzMC42MzcgMTE2LjkxN0MyMzIuOTQ5IDEzMS43OTEgMjMxLjg1NCAxNDYuOTk3IDIyNy40MzYgMTYxLjM4N0MyMjMuMDE4IDE3NS43NzggMjE1LjM5MiAxODguOTc4IDIwNS4xMzEgMTk5Ljk5MkMxOTQuODcgMjExLjAwNyAxODIuMjQ0IDIxOS41NSAxNjguMjAyIDIyNC45NzZDMTU0LjE2MSAyMzAuNDAyIDEzOS4wNzEgMjMyLjU3IDEyNC4wNyAyMzEuMzE3QzEwOS4wNjkgMjMwLjA2NCA5NC41NDc1IDIyNS40MjIgODEuNjAwNyAyMTcuNzQyQzYyLjQ0MzggMjIxLjA5NiA0Mi43MTU3IDIxNy44NSAyNS42NDMzIDIwOC41MzVDMjcuMTA2OCAyMTEuMTMxIDI4LjcxMzUgMjEzLjY0NCAzMC40NTYgMjE2LjA2MkM0Mi41ODcgMjMxLjA1MiA1Ny45NTg1IDI0My4wOTcgNzUuNDE0NyAyNTEuMjkxQzkyLjg3MSAyNTkuNDg2IDExMS45NTggMjYzLjYxNiAxMzEuMjQgMjYzLjM3MkMxNDkuMzE2IDI2My4zNTMgMTY3LjE5MyAyNTkuNjAzIDE4My43NTMgMjUyLjM1N0MyMDAuMzEzIDI0NS4xMTEgMjE1LjIgMjM0LjUyNiAyMjcuNDgxIDIyMS4yNjNDMjM5Ljc2MyAyMDggMjQ5LjE3NSAxOTIuMzQ1IDI1NS4xMjggMTc1LjI3OEMyNjEuMDgyIDE1OC4yMTEgMjYzLjQ1IDE0MC4wOTkgMjYyLjA4MiAxMjIuMDc0IiBmaWxsPSIjMDkwRDExIi8+PC9zdmc+");
  background-image: none !important;
  background-size: contain;
  background-position: center;
  transform: translate(-50%, -50%);
  content: "";
}
@media (max-width: 768px) {
  .cta__product::before {
    width: min(120px, 80%);
  }
}
.cta__img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -48%);
  max-width: none;
  width: min(136px, 35%);
}
@media (max-width: 768px) {
  .cta__img {
    /* width: clamp(58px, 40%, 64px); */
    width: clamp(35px, 25%, 50px);
  }
}
@media (max-width: 420px) {
  .cta__img {
    transform: translate(-50%, -43%);
  }
}
@media (max-width: 389px) {
  .cta__img {
    transform: translate(-50%, -35%);
  }
}
.cta__block {
  flex: 6;
}
.cta__info {
  display: flex;
  flex-direction: column;
  margin-bottom: 2vw;
  margin-top: 0.5vw;
  font-family: "Noto Serif JP", serif;
}
@media (max-width: 768px) {
  .cta__info {
    margin-bottom: 0.5rem;
    margin-top: 0.5rem;
  }
}
.cta__extra {
  display: flex;
  align-items: baseline;
  gap: 1.25vw;
  margin-bottom: 1.25vw;
  padding-left: 7%;
}
@media (max-width: 768px) {
  .cta__extra {
    flex-direction: column;
    margin-left: 45%;
    margin-bottom: 1rem;
    padding-left: initial;
  }
}
.cta__title {
  font-size: 1.5vw;
  font-weight: 400;
  padding-left: 7%;
}
@media (max-width: 768px) {
  .cta__title {
    font-size: 1rem;
    line-height: 1.6;
    margin-left: 45%;
    padding-left: initial;
  }
}
.cta__amount {
  font-size: 1.3vw;
}
@media (max-width: 768px) {
  .cta__amount {
    font-size: 0.875rem;
  }
}
.cta__price {
  margin: 0;
  font-family: "Noto Serif JP", serif;
}
.cta__price-currency {
  font-size: max(14px, 0.625vw);
}
.cta__price-value {
  font-size: max(20px, 1.0416666667vw);
}
@media (max-width: 768px) {
  .cta__price-value {
    font-size: 1rem;
  }
}
.cta__price-tax {
  font-size: max(12px, 0.7291666667vw);
}
@media (max-width: 768px) {
  .cta__price-tax {
    font-size: 0.75rem;
  }
}
.cta__desc {
  font-family: "Noto Serif JP", serif;
  font-size: max(15px, 0.78125vw);
  line-height: 1.8;
  letter-spacing: 0.08em;
  font-weight: 400;
}
@media (max-width: 768px) {
  .cta__desc {
    font-size: max(12px, 0.6770833333vw);
    letter-spacing: 0;
  }
}
.cta__btn {
  width: 50%;
  margin-left: 7%;
}
@media (max-width: 768px) {
  .cta__btn {
    width: 100%;
    margin-left: initial;
  }
}
.cta.cta--white .cta__container {
  background: linear-gradient(to right, #F0F0F0 20%, #FEFEFE 100%);
}
.cta.cta--white .cta__product::before {
  background-image: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjYzIiBoZWlnaHQ9IjI2MyIgdmlld0JveD0iMCAwIDI2MyAyNjMiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGcgc3R5bGU9Im1peC1ibGVuZC1tb2RlOm11bHRpcGx5IiBvcGFjaXR5PSIwLjEiPjxwYXRoIGQ9Ik0yNjIuMDYyIDEyMS4zNzRDMjU5LjQ1NCA4Ny42MDczIDI0My44OTMgNTYuMTU2NSAyMTguNjMyIDMzLjU5ODVDMTkzLjM3MiAxMS4wNDA0IDE2MC4zNjggLTAuODc4MTYzIDEyNi41MjMgMC4zMzUzMjVDOTIuNjc3OCAxLjU0ODgxIDYwLjYxMjMgMTUuODAwMyAzNy4wMzIxIDQwLjEwOTVDMTMuNDUxOCA2NC40MTg3IDAuMTgyODU5IDk2LjkwMzIgNS45Mjg1ZS0wNSAxMzAuNzdDLTAuMDE0MDEwOSAxNDQuMjAzIDIuNDc2NTMgMTU3LjUyMSA3LjM0NDA0IDE3MC4wNDFDMTAuMTcxNyAxNzYuOTIxIDE0LjAwOTcgMTgzLjM0MSAxOC43MzEzIDE4OS4wODlDMjcuNzM5NCAxOTkuODM2IDQwLjI3MjUgMjA3LjAzMiA1NC4wOTQ1IDIwOS4zOTNDNzEuNTg5OSAyMTMuMDggODkuODMyMyAyMTAuMDE4IDEwNS4xNjUgMjAwLjgyMUMxMTUuMjY1IDE5NS40MDQgMTIzLjgwNiAxODcuNDg2IDEyOS45NzEgMTc3LjgyNEMxMzEuOTgxIDE3NC43MzUgMTMzLjc4NSAxNzEuNTE4IDEzNS4zNzEgMTY4LjE5MkMxMzcuNTMzIDE2My44MDQgMTM5LjE1IDE1OS4xNjggMTQwLjE4NCAxNTQuMzg4QzE0MS45MzYgMTQ2LjE2NyAxNDEuMzk0IDEzNy42MjMgMTM4LjYxOCAxMjkuNjlDMTM4LjU1MSAxMjkuNDg3IDEzOC40NyAxMjkuMjk4IDEzOC4zODkgMTI5LjA5NUMxMzguMTM5IDEyOC40MiAxMzcuODY5IDEyNy43NzkgMTM3LjU4NSAxMjcuMTQ1TDEzNy40MDMgMTI2Ljc1M0MxMzQuOTYzIDEyMS4yMDYgMTMwLjg2MiAxMTYuNTUzIDEyNS42NjUgMTEzLjQzNkMxMTQuOTUyIDEwNi41OTggMTAzLjIzNSAxMDguNTg5IDExMS4yIDEyNC42NDdDMTE0LjY3OSAxMzEuODE1IDExNS42IDEzOS45NTcgMTEzLjgxIDE0Ny43MjFDMTEyLjAxOSAxNTUuNDg0IDEwNy42MjUgMTYyLjQwMSAxMDEuMzU4IDE2Ny4zMjFDOTkuMTU4MiAxNjUuNDkgOTcuMTM1NiAxNjMuNDU2IDk1LjMxNjcgMTYxLjI0NkM4OS44NjMzIDE1NC41OTcgODYuNDEwMiAxNDYuNTM2IDg1LjM1OSAxMzguMDAxQzg0LjMwNzggMTI5LjQ2NiA4NS43MDE5IDEyMC44MDggODkuMzc5MSAxMTMuMDM0QzkzLjA1NjIgMTA1LjI2MSA5OC44NjUyIDk4LjY5MDggMTA2LjEzIDk0LjA4OTVDMTEzLjM5NSA4OS40ODgzIDEyMS44MTcgODcuMDQ0NyAxMzAuNDE3IDg3LjA0M0MxMzEuOTA5IDg3LjA0MyAxMzMuNDE0IDg3LjEyNCAxMzQuOTMzIDg3LjI2NThDMTQ1Ljc0MyA4OC4zMzIyIDE1NS44MTMgOTMuMjQgMTYzLjMxMyAxMDEuMDk4QzE3MC44MTQgMTA4Ljk1NiAxNzUuMjQ3IDExOS4yNDMgMTc1LjgwOSAxMzAuMDkyQzE3Ni4zNzEgMTQwLjk0IDE3My4wMjQgMTUxLjYzMSAxNjYuMzc2IDE2MC4yMjJDMTU5LjcyOCAxNjguODEzIDE1MC4yMTkgMTc0LjczNSAxMzkuNTc3IDE3Ni45MTNDMTMzLjg0MyAxODguNDQzIDEyNC43OCAxOTcuOTg4IDExMy41NjIgMjA0LjMxMUMxMTYuNzE2IDIwNS4wNTggMTE5LjkxNiAyMDUuNTk3IDEyMy4xNCAyMDUuOTI0QzEyNS42MTEgMjA2LjE2NyAxMjguMDU0IDIwNi4yODkgMTMwLjQ5MSAyMDYuMjg5QzE0Ny41NyAyMDYuMzMzIDE2NC4xMzggMjAwLjQ3IDE3Ny4zODkgMTg5LjY5NEMxOTAuNjM5IDE3OC45MTkgMTk5Ljc1NiAxNjMuODkzIDIwMy4xOTQgMTQ3LjE2NEMyMDYuNjMyIDEzMC40MzUgMjA0LjE4IDExMy4wMzEgMTk2LjI1MyA5Ny45MDMzQzE4OC4zMjYgODIuNzc1NSAxNzUuNDEzIDcwLjg1MzggMTU5LjcwMSA2NC4xNTlDMTQzLjk4OSA1Ny40NjQxIDEyNi40NDUgNTYuNDA4IDExMC4wNDQgNjEuMTY5NUM5My42NDE5IDY1LjkzMSA3OS4zOTEyIDc2LjIxNzIgNjkuNzA2OCA5MC4yODQ4QzYwLjAyMjMgMTA0LjM1MiA1NS41IDEyMS4zMzYgNTYuOTA2MiAxMzguMzU3QzU4LjMxMjQgMTU1LjM3OCA2NS41NjA4IDE3MS4zODggNzcuNDIyNiAxODMuNjc2QzcyLjU3OTkgMTg0LjUyNSA2Ny42MTU4IDE4NC4zODkgNjIuODI3IDE4My4yNzZDNTguMDM4MiAxODIuMTYyIDUzLjUyMzEgMTgwLjA5NCA0OS41NTE3IDE3Ny4xOTZDNDMuOTA4MyAxNzIuNTkxIDM5LjI1NjUgMTY2Ljg5IDM1Ljg3NyAxNjAuNDM3QzMyLjQ5NzYgMTUzLjk4NSAzMC40NjA2IDE0Ni45MTQgMjkuODg5IDEzOS42NTJDMjcuMzkyMiAxMTYuMTA5IDM0LjEzNDUgOTIuNTE2IDQ4LjY5NDUgNzMuODQ2OEM1OC44ODggNTkuODgxNCA3Mi40NjI4IDQ4LjczNDkgODguMTQ0NyA0MS40NTM2QzEwMy44MjcgMzQuMTcyMyAxMjEuMTAyIDMwLjk5NDggMTM4LjM0OCAzMi4yMTk1QzE1My4zNzQgMzMuMTI3NCAxNjcuOTk4IDM3LjQzNCAxODEuMTE4IDQ0LjgxNDZDMTk0LjIzOCA1Mi4xOTUyIDIwNS41MTEgNjIuNDU3NSAyMTQuMDg5IDc0LjgyNzlDMjIyLjY2NyA4Ny4xOTgzIDIyOC4zMjUgMTAxLjM1NCAyMzAuNjM3IDExNi4yMjlDMjMyLjk0OSAxMzEuMTA0IDIzMS44NTQgMTQ2LjMwOSAyMjcuNDM2IDE2MC43QzIyMy4wMTggMTc1LjA5IDIxNS4zOTIgMTg4LjI5IDIwNS4xMzEgMTk5LjMwNUMxOTQuODcgMjEwLjMyIDE4Mi4yNDQgMjE4Ljg2MiAxNjguMjAyIDIyNC4yODhDMTU0LjE2MSAyMjkuNzE0IDEzOS4wNzEgMjMxLjg4MiAxMjQuMDcgMjMwLjYyOUMxMDkuMDY5IDIyOS4zNzYgOTQuNTQ3NSAyMjQuNzM1IDgxLjYwMDcgMjE3LjA1NUM2Mi40NDM4IDIyMC40MDkgNDIuNzE1NyAyMTcuMTYzIDI1LjY0MzMgMjA3Ljg0OEMyNy4xMDY4IDIxMC40NDQgMjguNzEzNSAyMTIuOTU2IDMwLjQ1NiAyMTUuMzc0QzQyLjU4NyAyMzAuMzY0IDU3Ljk1ODUgMjQyLjQxIDc1LjQxNDcgMjUwLjYwNEM5Mi44NzEgMjU4Ljc5OCAxMTEuOTU4IDI2Mi45MjkgMTMxLjI0IDI2Mi42ODVDMTQ5LjMxNiAyNjIuNjY1IDE2Ny4xOTMgMjU4LjkxNSAxODMuNzUzIDI1MS42NjlDMjAwLjMxMyAyNDQuNDI0IDIxNS4yIDIzMy44MzggMjI3LjQ4MSAyMjAuNTc1QzIzOS43NjMgMjA3LjMxMyAyNDkuMTc1IDE5MS42NTggMjU1LjEyOCAxNzQuNTkxQzI2MS4wODIgMTU3LjUyMyAyNjMuNDUgMTM5LjQxMSAyNjIuMDgyIDEyMS4zODciIGZpbGw9IiMxQTEzMTEiLz48L2c+PC9zdmc+");
  background-image: none !important;
}

/*--------------------------------------------------------
  Animation
--------------------------------------------------------*/
.fade-text {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(20px);
  transition: all 1.2s ease-out;
  transition-delay: var(--delay, 0ms);
}

.fade {
  opacity: 0.05;
  filter: blur(16px);
  transition: all 1.2s ease-out;
  transition-delay: var(--delay, 0ms);
}
.fade.concept__title {
  transition: all 1.4s ease-out 400ms;
}

.fade-simple {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.8s ease-out;
  transition-delay: var(--delay, 0ms);
}
.fade-simple.concept__animation {
  transition: all 0.6s ease-out 1800ms;
}

.fade-text.is-visible {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.fade.is-visible {
  opacity: 1;
  filter: blur(0);
}

.fade-simple.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.clip-reveal {
  clip-path: inset(0 0 100% 0);
  -webkit-clip-path: inset(0% 0% 100% 0%);
  will-change: clip-path, transform;
}

.clip-reveal.is-visible {
  animation: clipRevealY 1200ms cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  -webkit-animation: clipRevealY 1200ms cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  animation-delay: var(--delay, 0ms);
  -webkit-animation-delay: var(--delay, 0ms);
}

@keyframes clipRevealY {
  from {
    clip-path: inset(0% 0% 100% 0%);
  }
  to {
    clip-path: inset(0% 0% 0% 0%);
  }
}
@-webkit-keyframes clipRevealY {
  from {
    -webkit-clip-path: inset(0% 0% 100% 0%);
  }
  to {
    -webkit-clip-path: inset(0% 0% 0% 0%);
  }
}
.clip-reveal-x {
  clip-path: inset(0 100% 0 0);
  will-change: clip-path, transform;
}

.clip-reveal-x.is-visible {
  animation: clipRevealX 800ms cubic-bezier(0.2, 0.8, 0.2, 1) forwards;
  animation-delay: var(--delay, 0ms);
}

@keyframes clipRevealX {
  to {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes pan {
  from {
    transform: scale(1.05);
  }
  to {
    transform: scale(1);
  }
}
@media (max-width: 768px) {
  @keyframes pan {
    0% {
      transform: scale(1.15);
    }
    100% {
      transform: scale(1);
    }
  }
}
