/*
Theme Name: E.IDEAL
Theme URI: https://e-ideal.co.jp/
Author: E.IDEAL
Author URI: https://e-ideal.co.jp/
Description: E.IDEAL
*/

html {
  font-size: 2.56410256vw;
}

.html-scroll-stop { overflow: hidden; }

body {
  width: 100%;
  height: 100%;
  background-color: #000810;
  -webkit-text-size-adjust: 100%;
  font-family: 'Libertinus Sans', '游ゴシック', 游ゴシック体, YuGothic, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', 'メイリオ', 'ＭＳ Ｐゴシック', 'MS P Gothic', Osaka, Arial, Helvetica, Verdana, sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  font-weight: 400;
  color: #fff;
}

@media screen and (min-width: 769px) {
  html { font-size: 0.7142857100vw; }
}

@media screen and (min-width: 1401px) {
  html { font-size: 62.5%; }
}

*,
*:before,
*:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }

img { width: auto; height: auto; max-width: 100%; border: none; vertical-align: top; }
picture { display: block; position: relative; width: 100%; }

/* utility
------------------------------------------------ */
.u-r-lists { margin: 0; padding: 0; list-style: none; }
.u-r-btn { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; font-family: inherit; cursor: pointer; }
.u-r-input { -webkit-appearance: none; -moz-appearance: none; -ms-appearance: none; appearance: none; position: relative; padding: 0; background: none; border: none; border-radius: 0; box-shadow: none; font-family: inherit; }
.u-object-fit { width: 100%; height: 100%; max-width: inherit; object-fit: cover; font-family: 'object-fit: cover;'; }

.u-f-TimesNewRoman { font-family: 'Times New Roman', serif; }

.u-text-underline { text-decoration: underline; }

@media screen and (max-width: 768px) {
  .u-d-mobile { display: inherit !important; }
  .u-d-desktop { display: none !important; }
}

@media screen and (min-width: 769px) {
  .u-d-mobile { display: none !important; }
  .u-d-desktop { display: inherit !important; }
}

/* component
------------------------------------------------ */
/* link */
.link-skipcontent { position: absolute; margin: -1px; width: 1px; height: 1px; overflow: hidden; }

/* title */
.title-page { margin: 0 0 2rem; text-align: center; font-size: 2.8rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1428571428; }

@media screen and (min-width: 769px) {
  .title-page { margin-bottom: 2rem; font-size: 3.6rem; line-height: 1.1388888888; }
}

/* button */
.btn-read { display: inline-block; position: relative; vertical-align: top; font-size: 1.6rem; letter-spacing: 0.01em; line-height: 1.1875; color: #D69C00; }
.btn-read::before,
.btn-read::after { content: ''; position: absolute; top: 50%; left: 0.7rem; width: 1.1rem; height: 0.1rem; background-color: #D69C01; }
.btn-read::before { transform: translateY(-50%); }
.btn-read::after { transition: transform 0.4s ease; transform: translateY(-50%) rotate(90deg); }
.btn-read.is-active::after { transform: translateY(-50%) rotate(0); }
.btn-read > span { display: inline-block; position: relative; padding-left: 3.4rem; vertical-align: top; }
.btn-read > span::before { content: ''; position: absolute; top: 50%; left: 0.28rem; transform: translateY(-50%) rotate(45deg); width: 1.8rem; height: 1.8rem; border: 0.1rem solid #D69C01; }
.btn-view { display: inline-block; position: relative; padding: 0.5rem 3.2rem 0.5rem 1.4rem; border: 0.1rem solid #D69C00; border-radius: 1.5rem; text-decoration: none; vertical-align: top; font-size: 1.6rem; letter-spacing: 0.01em; line-height: 1.1875; color: #D69C00; }
.btn-view::after { content: ''; position: absolute; top: 50%; right: 1.2rem; transform: translateY(-50%); width: 0; height: 0; border: 0.5rem solid transparent; border-right: none; border-left: 0.8rem solid #D69C01; }

@media screen and (max-width: 768px) {
  .btn-view { padding-bottom: 0.2rem; font-size: 1.4rem; letter-spacing: 0.01em; line-height: 1.35714285714; }
}

@media screen and (min-width: 769px) {
  .btn-read { font-size: 1.6rem; line-height: 1.1875; }
  .btn-read::before,
  .btn-read::after { left: 0.7rem; width: 1.1rem; height: 0.1rem; }
  .btn-read > span { padding-left: 3.4rem; }
  .btn-read > span::before { left: 0.28rem; width: 1.8rem; height: 1.8rem; border-width: 0.1rem; }
  .btn-view { padding: 0.5rem 3.2rem 0.5rem 1.4rem; border-width: 0.1rem; border-radius: 1.5rem; font-size: 1.6rem; line-height: 1.1875; }
  .btn-view::after { right: 1.2rem; border-top-width: 0.5rem; border-bottom-width: 0.5rem; border-left-width: 0.8rem; }
}

/* notfound */
.notfound { display: flex; justify-content: center; align-items: center; margin: 0; min-height: 100dvh; text-align: center; font-size: 3rem; font-weight: 700; line-height: 1.4; }

@media screen and (min-width: 769px) {
  .notfound { font-size: 4rem; }
}

/* container
------------------------------------------------ */
.l-container { position: relative; }
.l-main { position: relative; }
.l-wrap { position: relative; }

@media screen and (max-width: 768px) {
  .l-wrap { padding: 0 3.5rem; }
}

@media screen and (min-width: 769px) {
  .l-wrap { padding: 0 8rem; }
}

/* header
------------------------------------------------ */
.l-hd { position: fixed; bottom: 0; left: 0; width: 100%; z-index: 10; }
.l-hd-logo { position: absolute; bottom: 3.5rem; left: 3.5rem; margin: 0; width: 11.5rem; }
.l-hd-logo > a { display: block; width: 100%; }
.l-hd-menu { position: absolute; bottom: 5rem; right: 3.5rem; width: 3rem; height: 3rem; border: 0.2rem solid #fff; border-radius: 0.3rem; text-indent: -9999px; white-space: nowrap; overflow: hidden; }
.l-hd-menu > i { position: absolute; top: 0.8rem; width: 100%; height: 100%; }
.l-hd-menu > i::before,
.l-hd-menu > i::after { content: ''; position: absolute; left: 0; transition: opacity 0.4s ease; width: 0.4rem; height: 0.4rem; background-color: #fff; border-radius: 50%; }
.l-hd-menu > i::before { top: 0; }
.l-hd-menu > i::after { top: 0.6rem; }
.l-hd-menu > i:nth-of-type(1) { left: 0.5rem; }
.l-hd-menu > i:nth-of-type(2) { left: 1.1rem; }
.l-hd-menu > i:nth-of-type(3) { left: 1.7rem; }
.l-hd-menu[aria-expanded=true] > i:nth-of-type(1),
.l-hd-menu[aria-expanded=true] > i:nth-of-type(3) { opacity: 0; }
.l-hd-menu[aria-expanded=true] > i:nth-of-type(2) { top: 0; left: 0; }
.l-hd-menu[aria-expanded=true] > i:nth-of-type(2)::before,
.l-hd-menu[aria-expanded=true] > i:nth-of-type(2)::after { top: 50%; left: 50%; transition: width 0.4s ease, height 0.4s ease; width: 1rem; height: 0.1rem; background-color: #fff; border-radius: 0.6rem; }
.l-hd-menu[aria-expanded=true] > i:nth-of-type(2)::before { transform: translate(-50%,-50%) rotate(45deg); }
.l-hd-menu[aria-expanded=true] > i:nth-of-type(2)::after { transform: translate(-50%,-50%) rotate(-45deg); }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .l-hd-logo { bottom: 5rem; left: 8rem; width: 15rem; }
  .l-hd-menu { display: none; }
}

/* gnav */
.l-gnav { position: absolute; bottom: 10rem; }
.l-gnav-links__item { text-align: right; font-size: 1.6rem; line-height: 1.5625; }
.l-gnav-links__item > a { display: inline-block; text-decoration: none; vertical-align: top; color: #fff; }

@media screen and (max-width: 768px) {
  .l-gnav { pointer-events: none; right: 3.5rem; transition: opacity 0.4s ease; opacity: 0; }
  .l-gnav[aria-hidden=false] { pointer-events: inherit; opacity: 1; }
  .l-gnav-links__item:not(:first-child) { margin-top: 1.5rem; }
}

@media screen and (min-width: 769px) {
  .l-gnav { bottom: 5rem; left: 26.3rem; opacity: 1 !important; }
  .l-gnav-links { display: flex; gap: 2.14285714283rem; }
  .l-gnav-links__item { font-size: 1.6rem; line-height: 1.5625; }
}

/* top
------------------------------------------------ */
/* scroll */
.top-scroll { position: relative; padding-top: 100dvh; width: 100%; }
.top-scroll-content { position: relative; width: 100%; }

/* visual */
.top-visual { position: fixed; top: 0; left: 0; width: 100%; height: 100dvh; overflow: hidden; }
.top-visual-media { position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; z-index: -1; }
.top-visual-media__movie { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); width: 100%; height: 100%; }
.top-visual-media__movie video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.top-visual-sns { display: flex; gap: 1rem; position: absolute; top: 4rem; right: 3.5rem; }
.top-visual-sns__item { width: 3rem; font-size: 1rem; line-height: 1; }
.top-visual-sns__item > a { display: block; width: 100%; }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .top-visual-sns { top: 3rem; right: 8rem; }
  .top-visual-sns__item { width: 2.5rem; }
}

/* horizontal */
.top-horizontal { position: relative; width: 100%; height: calc((100vw * 5) + 100dvh); z-index: 2; }
.top-horizontal-sticky { position: sticky; top: 0; left: 0; height: 100dvh; overflow-x: hidden; overflow-y: hidden; }
.top-horizontal-wrap { display: flex; justify-content: flex-start; position: relative; width: auto; height: 100%; }
.top-horizontal-cover { position: relative; width: 200vw; height: 100%; min-width: 200vw; }
.top-horizontal-cover__info { position: absolute; top: 0; left: 3.5rem; padding: 4rem 0; width: calc(100vw - (3.5rem * 2)); }
.top-horizontal-cover__title { margin: 0; font-size: 2.8rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1428571428; }
.top-horizontal-cover__title:not(:first-child) { margin-top: 2.8rem; }
.top-horizontal-cover__copy { margin: 2rem 0 0; font-size: 2rem; letter-spacing: -0.02em; line-height: 1.25; }
.top-horizontal-cover__explain { margin-top: 1.8rem; padding-left: 0.8rem; border-left: 0.1rem solid #fff; font-family: 'Times New Roman', serif; font-size: 1.4rem; line-height: 1.1428571428; color: #fff; }
.top-horizontal-cover__explain p { margin: 0; }
.top-horizontal-cover__explain p + p { margin-top: 1.6rem; }
.top-horizontal-cover__text { margin-top: 1.2rem; font-size: 1.4rem; letter-spacing: -0.02em; line-height: 1.2142857142; }
.top-horizontal-cover__text p { margin: 0; }
.top-horizontal-cover__text p + p { margin-top: 26px; }
.top-horizontal-cover__photo { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.top-horizontal-cover__photo picture { height: 100%; }
.top-horizontal-block { position: relative; width: 200vw; height: 100%; min-width: 200vw; }
.top-horizontal-block__info { position: absolute; top: 0; left: 3.5rem; padding: 4rem 0; width: calc(100vw - (3.5rem * 2)); }
.top-horizontal-block__title { margin: 0; font-size: 2.8rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1428571428; }
.top-horizontal-block__copy { margin: 2rem 0 0; font-size: 2rem; letter-spacing: -0.02em; line-height: 1.25; }
.top-horizontal-block__text { margin-top: 1rem; font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.top-horizontal-block__text p { margin: 0; }
.top-horizontal-block__text p + p { margin-top: 1.2142857142em; }
.top-horizontal-block__photo { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.top-horizontal-block__photo picture { height: 100%; }

.top-horizontal-indicator { position: absolute; bottom: 3.6rem; right: 2rem; width: 20.6rem; height: 0.1rem; }
.top-horizontal-indicator { background-color: #D69C01; }
.top-horizontal-indicator__hand { position: absolute; top: 50%; width: 0; height: 0.2rem; transform: translateY(-50%); background-color: #fff; }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
  .top-horizontal-cover { width: 100vw; min-width: 100vw; }
  .top-horizontal-cover__info { top: 0; left: 8rem; padding: 10rem 0; width: calc(100% - (8rem * 2)); }
  .top-horizontal-cover__title { font-size: 3.6rem; line-height: 1.1388888888; }
  .top-horizontal-cover__title:not(:first-child) { margin-top: 5.8rem; }
  .top-horizontal-cover__copy { margin-top: 2rem; font-size: 2.5rem; line-height: 1.12; }
  .top-horizontal-cover__explain { margin-top: 3rem; padding-left: 1rem; max-width: 68.6rem; font-size: 2.5rem; line-height: 1.12; }
  .top-horizontal-cover__explain p + p { margin-top: 2rem; }
  .top-horizontal-cover__text { margin-top: 3rem; font-size: 2.5rem; line-height: 1.2; }
  .top-horizontal-cover__text p + p { margin-top: 34px; }
  .top-horizontal-block { width: 100vw; min-width: 100vw; }
  .top-horizontal-block__info { top: 0; left: 8rem; padding: 10rem 0; width: calc(100% - (8rem * 2)); }
  .top-horizontal-block__title { font-size: 3.6rem; line-height: 1.1388888888; }
  .top-horizontal-block__copy { margin-top: 1.7rem; max-width: 47.8rem; font-size: 2.5rem; line-height: 1.12; }
  .top-horizontal-block__text { margin-top: 2rem; max-width: 34rem; font-size: 1.6rem; line-height: 1.5; }
  .top-horizontal-block__text p + p { margin-top: 1.5em; }
  .top-horizontal-indicator { bottom: 5rem; right: 8rem; width: 30rem; height: 0.1rem; }
  .top-horizontal-indicator__hand { height: 0.2rem; }
}

/* block */
.top-block { position: relative; width: 100%; z-index: 2; }
.top-block-info { position: relative; padding: 5rem 3.5rem; width: 100%; min-height: calc((652 * 100 / 390) * 1vw); }
.top-block-title { margin: 0; font-size: 2.8rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1428571428; }
.top-block-copy { margin: 2rem 0 0; font-size: 2rem; letter-spacing: -0.02em; line-height: 1.28571428571; }
.top-block-copy2 { margin: 2rem 0 0; font-size: 1.4rem; line-height: 1.15; }
.top-block-text { margin-top: 1rem; font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.top-block-text p { margin: 0; }
.top-block-text p + p { margin-top: 1.2142857142em; }
.top-block-read { margin-top: 1.6rem; }
.top-block-btn { margin-top: 2rem; }
.top-block-omotenashi { position: absolute; right: 3.5rem; width: 4.596rem; }
.top-block-omotenashi img { width: 100%; max-width: inherit; }
.top-block-photo { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: -1; }
.top-block-photo picture { height: 100%; }

.top-block.is-company,
.top-block.is-company .top-block-info { min-height: 100dvh; }

@media screen and (max-width: 768px) {
  .top-block-copy,
  .top-block-text { width: calc(100% - 3rem); }
  .top-block-omotenashi { bottom: 3rem; }
}

@media screen and (min-width: 769px) {
  .top-block-info { padding: 10rem 8rem; min-height: calc((788 * 100 / 1400) * 1vw); }
  .top-block-title { font-size: 3.6rem; line-height: 1.1388888888; }
  .top-block-copy { margin-top: 2rem; font-size: 2.5rem; line-height: 1.12; }
  .top-block-copy2 { margin-top: 2rem; font-size: 2.5rem; letter-spacing: -0.02em; line-height: 1.28; }
  .top-block-text { max-width: 34rem; font-size: 1.6rem; line-height: 1.5; }
  .top-block-text p + p { margin-top: 1.5em; }
  .top-block-read { margin-top: 3rem; max-width: 34rem; }
  .top-block-btn { margin-top: 1.2rem; }
  .top-block-btn { margin-top: 2rem; }
  .top-block-omotenashi { top: 10rem; right: 8rem; width: 8rem; }
}

/* more */
.top-more { display: none; }

/* omotenashi */
.top-omotenashi-copy { margin: 0; font-size: 2rem; letter-spacing: -0.02em; line-height: 1.25; }
.top-omotenashi-text { font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.top-omotenashi-text p { margin: 0; }
.top-omotenashi-text p + p { margin-top: 1.2857142857em; }

@media screen and (max-width: 768px) {
  .top-omotenashi-copy,
  .top-omotenashi-text { width: calc(100% - 3rem); }
}

@media screen and (min-width: 769px) {
  .top-omotenashi-copy { max-width: 34rem; font-size: 2.5rem; line-height: 1.2; }
  .top-omotenashi-text { margin-left: auto; max-width: 34rem; font-size: 1.6rem; line-height: 1.5; }
  .top-omotenashi-text p + p { margin-top: 1.5em; }
}

/* company */
.top-company-section { position: relative; padding: 4rem 0 16rem; background-color: #000810; }
.top-company-introduce { margin: 0 0 3.5rem; font-family: 'Times New Roman', serif; font-size: 2.2rem; letter-spacing: -0.02em; line-height: 1.1363636363; }
.top-company-name { margin: 0 0 1rem; font-size: 2.2rem; letter-spacing: -0.02em; line-height: 1.1363636363; }
.top-company-text { font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.top-company-text p { margin: 0; }
.top-company-text p + p { margin-top: 1.2857142857em; }
.top-company-signature { margin-top: 2rem; }
.top-company-signature__above { display: flex; justify-content: flex-end; align-items: center; gap: 1rem; }
.top-company-signature__ja { margin: 0; font-size: 1.1rem; font-weight: 500; letter-spacing: 0.01em; line-height: 1; }
.top-company-signature__en { margin: 0; font-size: 1.3rem; letter-spacing: -0.02em; line-height: 1.1538461538; }
.top-company-signature__en::before { content: '/'; padding-right: 0.4em; font-weight: 700; }
.top-company-signature__ar { margin: 1.2rem 0 0 auto; max-width: 15.185rem; }
.top-company-profile { margin-top: 33.4rem; }
.top-company-profile__title { margin: 0 0 4rem; font-size: 2.8rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1428571428; }
.top-company-profile__box { margin: 0; }
.top-company-profile__box__title,
.top-company-profile__box__text { font-size: 2rem; line-height: 1.25; }
.top-company-profile__box__title { letter-spacing: -0.02em; }
.top-company-profile__box__text { margin: 0; }
.top-company-profile__box__text a { text-decoration: none; color: #fff; }

@media screen and (max-width: 768px) {
  .top-company-photo { margin-top: 15.2rem; }
  .top-company-profile__box__title:not(:first-child) { margin-top: 3rem; }
  .top-company-profile__box__text { margin-top: 1rem; }
}

@media screen and (min-width: 769px) {
  .top-company-section { padding: 9.8rem 0 30rem; z-index: 1; }
  .top-company-introduce { margin-bottom: 4rem; font-size: 2.5rem; letter-spacing: 0; line-height: 1.2; }
  .top-company-name { margin-bottom: 1rem; font-size: 2.8rem; line-height: 1.1428571428; }
  .top-company-text { max-width: 34rem; font-size: 1.6rem; letter-spacing: 0.004em; line-height: 1.5; }
  .top-company-text p + p { margin-top: 1.5em; }
  .top-company-photo { pointer-events: none; position: absolute; top: 0; right: 0; width: 71.0714285714%; z-index: -1; }
  .top-company-signature { margin-top: 6.2rem; }
  .top-company-signature__above { gap: 1.2rem; }
  .top-company-signature__ja { font-size: 2.3rem; line-height: 1.0434782608; }
  .top-company-signature__en { font-size: 2.6rem; line-height: 1.1153846153; }
  .top-company-signature__ar { margin-top: 2.2rem; max-width: 30rem; }
  .top-company-profile { margin-top: 36.6rem; }
  .top-company-profile__title { margin-bottom: 4rem; font-size: 3.6rem; line-height: 1.1388888888; }
  .top-company-profile__box { display: grid; grid-template-columns: 19.8rem calc(100% - 19.8rem); }
  .top-company-profile__box__title,
  .top-company-profile__box__text { padding-top: 2rem; font-size: 2rem; line-height: 1.25; }
  .top-company-profile__box__title { padding-right: 1rem; }
  .top-company-profile__box__text { padding-left: 4rem; border-left: 0.1rem solid #fff; }
  .top-company-profile__box__title:first-child,
  .top-company-profile__box__title:first-child + .top-company-profile__box__text { padding-top: 0; }
}

/* product
------------------------------------------------ */
.product-block { position: relative; }
.product-block-info { position: relative; padding: 4rem 3.5rem 2.5rem; z-index: 3; }
.product-block-title__num,
.product-block-title__name { font-size: 2.2rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.1363636363; }
.product-block-title__name { margin: 0; }
.product-block-title__name .post-edit-link { font-size: 1.1rem; color: #fff; }
.product-block-text { margin-top: 2rem; font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.product-block-text p { margin: 0; }
.product-block-text p + p { margin-top: 1.2857142857em; }
.product-block-read { margin-top: 1.2rem; }
.product-block-map { position: absolute; z-index: 2; }
.product-block-map img { width: 100%; max-width: inherit; }
.product-block-photo { position: relative; z-index: 1; }
.product-block-photo picture { height: 100%; }

@media screen and (max-width: 768px) {
  .product-block-title__num { display: block; }
  .product-block-text { width: calc(100% - 3rem); }
  .product-block-media { position: relative; padding-top: 10rem; }
  .product-block-map { top: 0; left: 3.5rem; width: 16rem; }
}

@media screen and (min-width: 769px) {
  .product-block-info { padding: 10rem 8rem; min-height: calc((810 * 100 / 1400) * 1vw); }
  .product-block-title { display: flex; flex-wrap: wrap; }
  .product-block-title__num,
  .product-block-title__name { font-size: 3.2rem; line-height: 1.15625; }
  .product-block-title__num { margin-right: 0.2em; }
  .product-block-title__name .post-edit-link { font-size: 1.4rem; }
  .product-block-text { margin-top: 3rem; max-width: 34rem; font-size: 1.3rem; letter-spacing: 0.01em; line-height: 1.6153846153; }
  .product-block-text p + p { margin-top: 1.6153846153em; }
  .product-block-read { margin-top: 2.4rem; }
  .product-block-media { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
  .product-block-map { position: absolute; top: 32rem; left: 26rem; width: 29.5rem; }
  .product-block-photo { position: absolute; top: 0; right: 0; width: 81rem; height: 100%; }
}

/* nav */
.product-nav { pointer-events: none; position: fixed; top: 50%; right: 4rem; transition: opacity 0.4s ease; transform: translateY(-50%); width: 9rem; height: 48.6rem; border-right: 0.1rem solid #D69D04; opacity: 0; overscroll-behavior: none; z-index: 5; }
.product-nav-frame { position: relative; overflow: hidden; width: 100%; height: 100%; }
.product-nav-move { display: grid; position: absolute; top: 0; left: 0; width: 8rem; }
.product-nav-item { position: relative; margin-left: auto; width: calc(((42 * 100) / 80) * 1%); }
.product-nav-item.is-next { width: calc(((62 * 100) / 80) * 1%); }
.product-nav-item.is-active { width: 100%; }
.product-nav-item > a { display: block; position: relative; aspect-ratio: 1 / 1.35; width: 100%; overflow: hidden; }
.product-nav-item > a img { position: absolute; top: 0; left: 0; }

.product-nav.is-start { pointer-events: inherit; opacity: 1; }
.product-nav-move.is-animation { transition: transform 0.4s ease; }
/* .product-nav-move.is-animation .product-nav-item { transition: width 0.4s ease; } */

@media screen and (max-width: 768px) {
  .product-nav { display: none; }
}

@media screen and (min-width: 769px) {
}

/* lineup */
.product-lineup { position: relative; }

@media screen and (max-width: 768px) {
}

@media screen and (min-width: 769px) {
}

/* detail */
.product-detail { position: relative; }
.product-detail-content { position: relative; padding: 4rem 0 24.5rem; }
.product-detail-block { position: relative; }
.product-detail-block + .product-detail-block { padding-top: 2rem; }
.product-detail-info { position: relative; }
.product-detail-title { margin: 0; font-size: 2.5rem; font-weight: 400; letter-spacing: -0.02em; line-height: 1.12; }
.product-detail-text { margin: 0; font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.product-detail-text:not(:first-child) { margin-top: 2rem; }
.product-detail-attentions { margin-top: 2rem; }
.product-detail-attentions__item { position: relative; padding-left: 1em; font-family: 'Times New Roman', serif; font-size: 1rem; letter-spacing: -0.02em; line-height: 1.4; }
.product-detail-attentions__item::before { content: '※'; position: absolute; top: 0; left: 0; }
.product-detail-materials { display: grid; row-gap: 0.6rem; grid-template-columns: 9.8rem 1fr; margin: 4.8rem 0 0; }
.product-detail-materials__title,
.product-detail-materials__text { font-size: 1.8rem; line-height: 1.4444444444; }
.product-detail-materials__text { margin: 0; }
.product-detail-tags { display: grid; gap: 0.8rem; grid-template-columns: repeat(5,calc((100% / 5) - (0.8rem / (4 / 5)))); margin-top: 2.4rem; }
.product-detail-tags__item { position: relative; }
.product-detail-tags__icon { display: block; width: 100%; }
.product-detail-tags__icon img { width: 100%; max-width: inherit; }
.product-detail-tags__name { margin: 0.2rem 0 0 -0.8rem; width: calc(100% + (0.8rem * 2)); text-align: center; font-size: 0.7rem; letter-spacing: -0.02em; line-height: 1.2857142857; }
.product-detail-gallery { display: flex; flex-wrap: wrap; row-gap: 2rem; column-gap: calc((12 * 100 / 320) * 1%); }
.product-detail-gallery__item { width: calc((180 * 100 / 320) * 1%); }
.product-detail-gallery__item:nth-of-type(4n),
.product-detail-gallery__item:nth-of-type(4n+1) { width: calc((128 * 100 / 320) * 1%); }

@media screen and (max-width: 768px) {
  .product-detail-block { display: flex; flex-wrap: wrap; }
  .product-detail-block.is-primary { row-gap: 10rem; }
  .product-detail-block.is-secondary { flex-flow: column-reverse; row-gap: 4rem; }
  .product-detail-info { padding: 0 3.5rem; }
  .product-detail-text { width: calc(100% - 3rem); }
  .product-detail-tags { width: calc(100% - 3rem); }
  .product-detail-gallery { padding: 0 3.5rem; }
}

@media screen and (min-width: 769px) {
  .product-detail-content { padding: 10rem 8rem; }
  .product-detail-block { display: flex; column-gap: 5rem; }
  .product-detail-block + .product-detail-block { padding-top: 5.5rem; }
  .product-detail-info { width: 34rem; }
  .product-detail-title { font-size: 2.8rem; letter-spacing: 0.01em; line-height: 1.1428571428; }
  .product-detail-text { font-size: 1.6rem; letter-spacing: 0.004em; line-height: 1.5; }
  .product-detail-text:not(:first-child) { margin-top: 2rem; }
  .product-detail-attentions { margin-top: 2rem; }
  .product-detail-attentions__item { font-size: 1.3rem; letter-spacing: 0.01em; line-height: 1.3076923076; }
  .product-detail-materials { row-gap: 0.6rem; grid-template-columns: 9.8rem 1fr; margin-top: 4.8rem; }
  .product-detail-materials__title,
  .product-detail-materials__text { font-size: 1.8rem; line-height: 1.5; }
  .product-detail-tags { gap: 0.8rem; grid-template-columns: repeat(5,calc((100% / 5) - (0.8rem / (4 / 5)))); margin-top: 2.4rem; }
  .product-detail-tags__name { margin: 0.2rem 0 0 -0.8rem; width: calc(100% + (0.8rem * 2)); text-align: center; font-size: 0.7rem; line-height: 1.2857142857; }
  .product-detail-media { width: calc(100% - (34rem + 5rem)); }
  .product-detail-gallery { row-gap: 5.5rem; column-gap: calc((30 * 100 / 850) * 1%); }
  .product-detail-gallery__item { width: calc((480 * 100 / 850) * 1%); }
  .product-detail-gallery__item:nth-of-type(4n),
  .product-detail-gallery__item:nth-of-type(4n+1) { width: calc((340 * 100 / 850) * 1%); }
}

/* contact
------------------------------------------------ */
.contact { position: relative; padding: 4rem 0 16.5rem; }
.contact-above { position: relative; }
.contact-copy { margin: 0 0 0.5rem; text-align: center; font-family: 'Times New Roman', serif; font-size: 2.2rem; letter-spacing: -0.02em; line-height: 1.1363636363; }
.contact-text { margin: 0; text-align: center; font-family: 'Times New Roman', serif; font-size: 1.4rem; letter-spacing: -0.01em; line-height: 1.2857142857; }
.contact-flow { display: grid; row-gap: 2.3rem; column-gap: calc((30 * 100 / 320) * 1%); grid-template-columns: repeat(4,calc((50 * 100 / 320) * 1%)); margin-top: 4rem; }
.contact-flow-item { position: relative; }
.contact-flow-num { margin: 0; text-align: center; font-size: 2.6rem; letter-spacing: 0.01em; line-height: 1.1153846153; }
.contact-flow-icon { display: block; position: relative; margin: 0 auto; aspect-ratio: 1 / 1.44; }
.contact-flow-icon img { position: absolute; top: 50%; left: 0; transform: translateY(-50%); }
.contact-flow-info { position: relative; aspect-ratio: 1 / 0.5; }
.contact-flow-text { position: absolute; top: 0; left: 50%; transform: translateX(-50%); margin: 0; text-align: center; white-space: nowrap; font-size: 1.1rem; letter-spacing: -0.02em; line-height: 1.0909090909; }
.contact-flow-item:not(:last-child) .contact-flow-icon::after { content: ''; position: absolute; top: 50%; right: -2rem; transform: translateY(-50%); width: 0.8rem; height: 1.2rem; background: url(./_assets/img/icon/arrow1.svg) no-repeat center center; background-size: 100% 100%; }
.contact-flow-item:nth-of-type(2) .contact-flow-icon img { left: 0.5rem; }
.contact-form { margin-top: 20rem; }
.contact-form-required { margin-bottom: 0.5rem; text-align: right; font-size: 1.1rem; line-height: 1.45; }
.contact-form-parts { display: grid; gap: 0.8rem; position: relative; }
.contact-form-parts:not(:first-child) { margin-top: 2rem; }
.contact-form-parts.is-multi { grid-template-columns: repeat(2,calc(50% - (0.8rem / 2))); }
.contact-form-label { position: absolute; margin: -1px; width: 1px; height: 1px; font-size: 2.2rem; font-weight: 400; letter-spacing: 0.01em; line-height: 1.1363636363; overflow: hidden; }
.contact-form-parts input[type=text],
.contact-form-parts input[type=email],
.contact-form-parts input[type=tel],
.contact-form-parts textarea { padding: 0.8rem 1rem; width: 100%; height: 5rem; background-color: #DEDEDE; border-radius: 0.5rem; box-shadow: inset 0.5rem 0.5rem 0.7rem rgba(0, 0, 0, 0.16); font-size: 1.1rem; font-weight: 400; letter-spacing: 0.01em; line-height: 1.1818181818; }
.contact-form-parts textarea { height: 15.2rem; }
.contact-form-parts input[type=text]::placeholder,
.contact-form-parts input[type=email]::placeholder,
.contact-form-parts input[type=tel]::placeholder,
.contact-form-parts textarea::placeholder { color: #6F6F6F; }
.contact-form-submit { position: relative; margin-top: 2rem; }
.contact-form-submit > input { display: block; margin: 0 auto; width: 11.5rem; height: 2.5rem; border: 0.1rem solid #D79C00; border-radius: 0.5rem; font-size: 1.1rem; font-weight: 400; letter-spacing: 0.01em; line-height: 1.1818181818; color: #D69C01; cursor: pointer; }
.wpcf7-not-valid-tip { margin-top: 0.6em; font-size: 1.4rem; }
.wpcf7-spinner { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); }
.wpcf7 form .wpcf7-response-output { padding: 1em; font-size: 1.4rem; }

@media screen and (max-width: 768px) {
  .contact-text { margin: 0 auto; max-width: 25.6rem; }

  .wpcf7 form .wpcf7-response-output { margin: 20px 3.5rem 10px; }
}

@media screen and (min-width: 769px) {
  .contact { padding: 9.4rem 0 13.4rem; }
  .contact::after { content: ''; position: absolute; top: 0; right: 0; width: 71.0714285714%; height: 100%; background: url(./_assets/img/contact/bg-desktop.jpg) no-repeat center center; background-size: cover; z-index: -1; }
  .contact-above > .l-wrap,
  .contact-form > .l-wrap { margin: 0 auto; max-width: calc(65rem + (8rem * 2)); }
  .contact-copy { margin-bottom: 0.8rem; font-size: 2.5rem; letter-spacing: 0; line-height: 1.2; }
  .contact-text { font-size: 1.6rem; letter-spacing: 0.004em; line-height: 1.5; }
  .contact-flow { column-gap: calc((35 * 100 / 650) * 1%); grid-template-columns: repeat(7,calc((60 * 100 / 650) * 1%)); margin-top: 7rem; }
  .contact-flow-num { font-size: 3.1rem; line-height: 1.1612903225; }
  .contact-flow-icon { aspect-ratio: 1 / 1.44; }
  .contact-flow-info { aspect-ratio: 1 / 0.5; }
  .contact-flow-text { font-size: 1.3rem; line-height: 1.1538461538; }
  .contact-flow-item:not(:last-child) .contact-flow-icon::after { right: -2.2rem; width: 0.8rem; height: 1.2rem; }
  .contact-flow-item:nth-of-type(2) .contact-flow-icon img { left: 0.5rem; }
  .contact-form { margin-top: 37.2rem; }
  .contact-form-required { margin-bottom: 1rem; font-size: 2rem; }
  .contact-form-parts { gap: 1rem; }
  .contact-form-parts:not(:first-child) { margin-top: 2rem; }
  .contact-form-parts.is-multi { grid-template-columns: repeat(2,calc(50% - (1rem / 2))); }
  .contact-form-label { font-size: 2.2rem; font-weight: 400; letter-spacing: 0.01em; line-height: 1.1363636363; }
  .contact-form-parts input[type=text],
  .contact-form-parts input[type=email],
  .contact-form-parts input[type=tel],
  .contact-form-parts textarea { padding: 1.2rem 2rem; height: 5rem; border-radius: 1rem; font-size: 2rem; line-height: 1.15; }
  .contact-form-parts textarea { padding: 2rem; height: 19.5rem; }
  .contact-form-submit { margin-top: 4.8rem; }
  .contact-form-submit > input { width: 18.6rem; height: 3.7rem; border-width: 0.1rem; border-radius: 1rem; font-size: 2rem; line-height: 1.15; }

  .wpcf7 form .wpcf7-response-output { margin: 40px auto 60px; max-width: 65rem; text-align: center; }
}
